/* ============================================================================
   SALON & TRESOR · Portal-Styles (V8.7)
   ========================================================================== */

/* ============ PRIVATER SALON BANNER ============ */
.salon-banner{
  display:flex;align-items:center;gap:14px;
  margin:0 0 22px;
  padding:14px 20px;
  background:linear-gradient(180deg,#fbf6ec 0%,#f5eddc 100%);
  border:1px solid rgba(184,148,90,.28);
  border-left:3px solid var(--gold, #b8945a);
  border-radius:10px;
  box-shadow:0 2px 8px rgba(20,35,58,.04);
  font-family:'Inter',sans-serif;
  font-size:13px;color:#3d3528;
  line-height:1.5;
}
.salon-banner__icon{
  color:var(--gold, #b8945a);
  font-size:18px;line-height:1;flex:none;
}
.salon-banner__text{flex:1;min-width:0}
.salon-banner__text strong{
  font-family:'Cormorant Garamond',serif;
  font-size:15px;font-weight:500;color:#14233a;
  letter-spacing:.01em;
}
.salon-banner__text span{color:#5a5040}
.salon-banner__avatars{
  display:flex;gap:-4px;flex:none;align-items:center;
}
.salon-banner__avatars .salon-avatar{
  display:inline-flex;align-items:center;justify-content:center;
  width:30px;height:30px;border-radius:50%;
  background:#fff;border:2px solid #fbf6ec;
  margin-left:-8px;
  font-size:10px;font-weight:600;letter-spacing:.04em;
  color:#14233a;
  box-shadow:0 1px 3px rgba(20,35,58,.15);
  cursor:default;
  font-family:'Inter',sans-serif;
}
.salon-banner__avatars .salon-avatar:first-child{margin-left:0}
.salon-avatar--owner{background:#f4ead5;color:#8a6a3e;border-color:#f9f0de}
.salon-avatar--arch {background:#e3eef8;color:#2a5a8e;border-color:#f0f5fb}
.salon-avatar--mgmt {background:#d9eee4;color:#2d7a4f;border-color:#ebf6f0}

@media (max-width: 760px){
  .salon-banner{flex-wrap:wrap;padding:12px 14px}
  .salon-banner__avatars{order:3;margin-left:auto}
  .salon-banner__text{font-size:12px}
}

/* ============ TRESOR-GATE (vor der Sektion) ============ */
.tresor-gate{
  --gold: #b8945a;
  --gold-bright: #e4c287;
  --navy: #0f1d3f;
  --navy-deep: #050a1c;
  position:relative;
  margin:0 0 28px;
  padding:40px 28px 28px;
  border-radius:14px;
  background:
    radial-gradient(ellipse at 50% 30%,#1a2544 0%,#0a1530 45%,#050a1c 80%,#02050f 100%);
  color:#fff;
  text-align:center;
  overflow:hidden;
  box-shadow:0 24px 60px rgba(5,10,28,.35),inset 0 1px 0 rgba(184,148,90,.1);
  min-height:520px;
}
.tresor-gate::before{
  /* Goldener Lichtschein von oben */
  content:"";position:absolute;top:-40px;left:50%;transform:translateX(-50%);
  width:540px;height:180px;
  background:radial-gradient(ellipse at 50% 0%,rgba(184,148,90,.22) 0%,transparent 65%);
  pointer-events:none;z-index:1;
}
.tresor-gate__stage{
  position:relative;z-index:2;
  display:grid;grid-template-columns:minmax(360px,420px) 1fr;gap:44px;align-items:center;
  max-width:1040px;margin:0 auto;
  padding:20px 0 30px;
}
@media (max-width:960px){
  .tresor-gate__stage{grid-template-columns:1fr;gap:28px}
}

/* -- PORTAL / TÜR -- */
.tresor-gate__portal{
  position:relative;
  width:100%;max-width:420px;height:440px;
  margin:0 auto;
  padding:20px;
  background:
    linear-gradient(180deg,#1a2544 0%,#0a1128 100%);
  border:1px solid rgba(184,148,90,.22);
  border-radius:6px;
  box-shadow:
    inset 0 0 40px rgba(0,0,0,.5),
    0 6px 18px rgba(0,0,0,.4);
}
.tresor-gate__inscription{
  position:absolute;top:-30px;left:50%;transform:translateX(-50%);
  font-family:'Cormorant Garamond',serif;font-style:italic;
  color:var(--gold);font-size:15px;letter-spacing:.32em;text-transform:uppercase;
  white-space:nowrap;
  text-shadow:0 0 12px rgba(184,148,90,.45);
  z-index:3;
}
.tresor-gate__opening{
  position:absolute;inset:20px;
  border-radius:50%;
  background:radial-gradient(circle,#000 0%,#050a1c 80%,#0a1128 100%);
  box-shadow:inset 0 0 30px rgba(0,0,0,.9);
  perspective:1600px;
  overflow:visible;
}
.tresor-gate__vault{
  position:absolute;inset:0;border-radius:50%;
  background:
    radial-gradient(ellipse at 50% 60%,rgba(184,148,90,.14) 0%,transparent 35%),
    radial-gradient(circle at 50% 50%,#1a1208 0%,#0a0804 60%,#000 100%);
  box-shadow:inset 0 0 60px rgba(0,0,0,.98);
}
.tresor-gate__door{
  position:absolute;inset:0;border-radius:50%;
  transform-style:preserve-3d;
  transform-origin:left center;
  transition:transform .2s;
  cursor:pointer;
}
.tresor-gate__jamb{
  position:absolute;top:2%;bottom:2%;left:-6px;width:10px;
  background:linear-gradient(90deg,#1a2544 0%,#0f1d3f 50%,#050818 100%);
  border-radius:2px;
  box-shadow:inset 0 0 4px rgba(0,0,0,.6);
  z-index:1;
}
.tresor-gate__frame{
  position:absolute;inset:0;border-radius:50%;
  background:radial-gradient(circle at 30% 25%,#4a5a7e 0%,#2a3a5e 25%,#1a2544 50%,#0a1128 80%,#050818 100%);
  box-shadow:
    inset 0 0 30px rgba(0,0,0,.7),
    inset 0 6px 20px rgba(255,255,255,.08),
    0 8px 20px rgba(0,0,0,.5);
  transition:transform 1.6s cubic-bezier(.45,.05,.2,1);
}
/* Nieten am Rand */
.tresor-gate__rivets{position:absolute;inset:0;border-radius:50%;pointer-events:none}
.tresor-gate__rivets::before,
.tresor-gate__rivets::after{
  content:"";position:absolute;inset:12px;border-radius:50%;
  background:
    repeating-conic-gradient(from 0deg,
      transparent 0deg 14.9deg,
      rgba(184,148,90,.55) 14.9deg 15.1deg,
      transparent 15.1deg 30deg);
  -webkit-mask:radial-gradient(circle, transparent 87%, #000 87%, #000 93%, transparent 93%);
          mask:radial-gradient(circle, transparent 87%, #000 87%, #000 93%, transparent 93%);
}
.tresor-gate__rivets::after{opacity:.3;filter:blur(1px)}
/* Speichenrad */
.tresor-gate__wheel-wrap{
  position:absolute;top:50%;left:50%;width:55%;height:55%;
  transform:translate(-50%,-50%);
  transition:transform 1.1s cubic-bezier(.4,.05,.3,1);
}
.tresor-gate__wheel{
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
}
.tresor-gate__wheel .spoke{
  position:absolute;top:50%;left:50%;
  width:50%;height:4px;margin-top:-2px;
  background:linear-gradient(90deg,rgba(184,148,90,.3) 0%,var(--gold) 40%,var(--gold-bright) 60%,rgba(184,148,90,.4) 100%);
  transform-origin:0 50%;
  border-radius:2px;
  box-shadow:0 1px 2px rgba(0,0,0,.5);
}
.tresor-gate__wheel .spoke::after{
  content:"";position:absolute;right:-8px;top:50%;margin-top:-8px;
  width:16px;height:16px;border-radius:50%;
  background:radial-gradient(circle at 30% 30%,var(--gold-bright) 0%,var(--gold) 55%,#6a4e28 100%);
  box-shadow:0 1px 3px rgba(0,0,0,.6),inset 0 1px 1px rgba(255,255,255,.3);
}
.spoke--n {transform:rotate(-90deg)}
.spoke--ne{transform:rotate(-45deg)}
.spoke--e {transform:rotate(0deg)}
.spoke--se{transform:rotate(45deg)}
.spoke--s {transform:rotate(90deg)}
.spoke--sw{transform:rotate(135deg)}
.spoke--w {transform:rotate(180deg)}
.spoke--nw{transform:rotate(-135deg)}
.tresor-gate__wheel .hub{
  position:absolute;top:50%;left:50%;width:20%;height:20%;
  transform:translate(-50%,-50%);
  border-radius:50%;
  background:radial-gradient(circle at 35% 30%,#6a4e28 0%,#3a2812 50%,#1a1208 100%);
  box-shadow:inset 0 1px 2px rgba(184,148,90,.4),0 0 8px rgba(0,0,0,.8);
}
/* Scharniere */
.tresor-gate__hinge{
  position:absolute;left:-14px;width:14px;height:30px;
  background:linear-gradient(90deg,#2a3a5e 0%,#1a2544 50%,#0a1128 100%);
  border-radius:3px 0 0 3px;
  box-shadow:inset 0 0 3px rgba(0,0,0,.6);
  z-index:2;
}
.tresor-gate__hinge--top{top:18%}
.tresor-gate__hinge--bot{bottom:18%}
/* Öffnen-Animation */
.tresor-gate__door.opening .tresor-gate__wheel-wrap{transform:translate(-50%,-50%) rotate(720deg)}
.tresor-gate__door.opening .tresor-gate__frame{
  animation:tresorGateOpen 1.6s cubic-bezier(.45,.05,.2,1) forwards;
  animation-delay:1.1s;
}
@keyframes tresorGateOpen{
  0%  {transform:rotateY(0deg)}
  100%{transform:rotateY(-88deg)}
}

/* -- NAMENSSCHILD (im Portal unter der Tür) -- */
.tresor-gate__nameplate{
  position:absolute;left:50%;bottom:-32px;transform:translateX(-50%);
  min-width:360px;max-width:90%;
  padding:13px 42px 11px;
  text-align:center;
  display:flex;flex-direction:column;gap:5px;align-items:center;
  background:linear-gradient(180deg,#16264c 0%,#0f1d3f 45%,#0a1630 100%);
  color:var(--gold);
  border-radius:2px;
  border:1px solid rgba(184,148,90,.55);
  outline:1px solid rgba(184,148,90,.22);outline-offset:3px;
  font-family:'Cormorant Garamond',serif;
  box-shadow:
    inset 0 1px 0 rgba(184,148,90,.22),
    inset 0 -1px 0 rgba(0,0,0,.5),
    0 8px 20px rgba(0,0,0,.7),
    0 0 26px rgba(184,148,90,.14);
  z-index:10;
}
.tresor-gate__nameplate .couple{
  position:relative;
  font-size:20px;font-weight:400;
  letter-spacing:.015em;font-style:italic;
  color:var(--gold-bright);
  text-shadow:0 1px 2px rgba(0,0,0,.7);
  white-space:nowrap;line-height:1.2;
  padding:0 26px;
}
.tresor-gate__nameplate .couple::before,
.tresor-gate__nameplate .couple::after{
  content:"❖";position:absolute;top:50%;transform:translateY(-52%);
  font-size:9px;color:rgba(184,148,90,.55);font-style:normal;
}
.tresor-gate__nameplate .couple::before{left:4px}
.tresor-gate__nameplate .couple::after{right:4px}
.tresor-gate__nameplate .couple .amp{
  margin:0 10px;color:var(--gold);font-weight:300;font-size:18px;
}
.tresor-gate__nameplate .divider{
  width:110px;height:1px;
  background:linear-gradient(90deg,transparent 0%,rgba(184,148,90,.55) 50%,transparent 100%);
}
.tresor-gate__nameplate .wohnung{
  font-size:10px;font-weight:500;letter-spacing:.34em;text-transform:uppercase;
  color:#d4b578;font-family:'Inter',sans-serif;
}

/* -- INHALTS-VORSCHAU (rechts neben Tür) -- */
.tresor-preview{
  background:rgba(255,255,255,.03);
  border:1px solid rgba(184,148,90,.2);
  border-radius:10px;
  padding:22px 24px;
  text-align:left;
  backdrop-filter:blur(4px);
}
.tresor-preview__head{margin-bottom:16px;padding-bottom:14px;border-bottom:1px solid rgba(184,148,90,.18)}
.tresor-preview__eyebrow{
  display:block;font-family:'Inter',sans-serif;
  font-size:10px;font-weight:600;letter-spacing:.28em;text-transform:uppercase;
  color:var(--gold);margin-bottom:6px;
}
.tresor-preview__title{
  margin:0;
  font-family:'Cormorant Garamond',serif;
  font-size:24px;font-weight:500;color:#fff;letter-spacing:.005em;
}
.tresor-preview__hint{
  margin:6px 0 0;font-family:'Inter',sans-serif;
  font-size:12px;color:rgba(255,255,255,.58);line-height:1.5;
}
.tresor-preview__list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:2px}
.tresor-preview__item{
  display:grid;grid-template-columns:22px 1fr auto;gap:12px;align-items:center;
  padding:10px 6px;
  border-bottom:1px solid rgba(184,148,90,.08);
  font-family:'Inter',sans-serif;font-size:13px;
}
.tresor-preview__item:last-child{border-bottom:0}
.tresor-preview__icon{
  color:var(--gold);font-size:14px;line-height:1;text-align:center;
  opacity:.85;
}
.tresor-preview__label{color:rgba(255,255,255,.86);font-weight:500}
.tresor-preview__meta{
  color:rgba(212,181,120,.78);
  font-size:11px;font-weight:500;letter-spacing:.04em;
  font-family:'Inter',sans-serif;
  white-space:nowrap;
}

/* -- Footer & Button -- */
.tresor-gate__sub{
  margin:40px 0 18px;
  font-family:'Cormorant Garamond',serif;font-style:italic;
  font-size:14px;color:rgba(255,255,255,.65);
  letter-spacing:.02em;
}
.tresor-gate__btn{
  display:inline-block;
  padding:12px 36px;
  background:linear-gradient(180deg,var(--gold-bright) 0%,var(--gold) 50%,#8a6a3e 100%);
  color:#1a1208;
  border:1px solid rgba(184,148,90,.6);
  border-radius:2px;
  font-family:'Inter',sans-serif;
  font-size:12px;font-weight:600;letter-spacing:.28em;text-transform:uppercase;
  cursor:pointer;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.4),
    inset 0 -1px 0 rgba(0,0,0,.2),
    0 4px 12px rgba(0,0,0,.4),
    0 0 24px rgba(184,148,90,.2);
  transition:transform .15s ease, box-shadow .15s ease;
}
.tresor-gate__btn:hover{
  transform:translateY(-1px);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.5),
    inset 0 -1px 0 rgba(0,0,0,.2),
    0 6px 16px rgba(0,0,0,.5),
    0 0 30px rgba(184,148,90,.3);
}
.tresor-gate__btn:active{transform:translateY(0)}

/* -- Ausgeblendet für Rollen ohne Zugriff -- */
.tresor-denied{
  margin:0 0 22px;
  padding:40px 28px;
  background:linear-gradient(180deg,#f7f3ea 0%,#f0e8d5 100%);
  border:1px solid #e1d5b8;
  border-radius:12px;
  text-align:center;
  color:#5a5040;
}
.tresor-denied__icon{
  font-size:42px;margin-bottom:14px;opacity:.45;color:#8a7a58;
}
.tresor-denied h2{
  margin:0 0 10px;
  font-family:'Cormorant Garamond',serif;
  font-size:24px;font-weight:500;color:#14233a;
  letter-spacing:.005em;
}
.tresor-denied p{
  margin:0;font-family:'Inter',sans-serif;
  font-size:14px;line-height:1.55;color:#6a5f4a;
  max-width:520px;margin-left:auto;margin-right:auto;
}

/* -- Responsive -- */
@media (max-width:640px){
  .tresor-gate{padding:28px 18px 22px;min-height:auto}
  .tresor-gate__portal{height:360px}
  .tresor-gate__stage{gap:22px;padding:14px 0 20px}
  .tresor-gate__nameplate{min-width:280px;padding:10px 22px 8px}
  .tresor-gate__nameplate .couple{font-size:16px;padding:0 18px}
  .tresor-gate__nameplate .couple .amp{font-size:14px;margin:0 6px}
  .tresor-preview{padding:16px 18px}
  .tresor-preview__title{font-size:20px}
}

/* ============================================================
   SECRETS — hinter der Tresortür, nur Käufer + Bauherrschaft
   ============================================================ */
.secrets-intro{
  margin:0 0 22px;padding:16px 20px;
  background:linear-gradient(135deg,rgba(15,29,63,.04),rgba(184,148,90,.06));
  border-left:3px solid #b8945a;
  border-radius:4px;
  font-family:'Inter',sans-serif;font-size:13.5px;line-height:1.6;color:#3d4c6a;
}
.secrets-intro strong{color:#0f1d3f;font-weight:600}

.secrets-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:16px;
  margin:0;
}

.secrets-card{
  position:relative;
  background:#fff;
  border:1px solid rgba(15,29,63,.08);
  border-radius:6px;
  padding:20px 22px 18px;
  box-shadow:0 1px 3px rgba(15,29,63,.04);
  transition:box-shadow .18s ease, transform .18s ease;
}
.secrets-card:hover{
  box-shadow:0 4px 14px rgba(15,29,63,.08);
  transform:translateY(-1px);
}
.secrets-card::before{
  content:"";position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,#0f1d3f,#b8945a 55%,#0f1d3f);
  border-radius:6px 6px 0 0;
}

.secrets-card__head{
  display:grid;
  grid-template-columns:38px 1fr;
  grid-template-rows:auto auto;
  column-gap:12px;row-gap:4px;
  align-items:center;margin-bottom:14px;
  padding-bottom:12px;
  border-bottom:1px dashed rgba(15,29,63,.09);
}
.secrets-card__head .secrets-card__icon{grid-row:1 / span 2}
.secrets-card__icon{
  width:38px;height:38px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,#0f1d3f,#16264c);
  color:#e4c287;
  font-size:18px;
  border-radius:4px;
  box-shadow:0 1px 2px rgba(15,29,63,.2);
}
.secrets-card__head h2{
  margin:0;
  font-family:'Cormorant Garamond',serif;
  font-size:19px;font-weight:500;color:#0f1d3f;
  letter-spacing:.005em;line-height:1.15;
}
.secrets-card__count{
  display:inline-flex;align-items:center;gap:5px;
  padding:2px 8px;border-radius:10px;
  background:rgba(184,148,90,.12);color:#8a6d3f;
  font-family:'Inter',sans-serif;
  font-size:10px;font-weight:600;letter-spacing:.04em;
  white-space:nowrap;
  justify-self:start;
}
.secrets-card__count::before{
  content:"●";font-size:7px;color:#b8945a;
}

.secrets-list{
  list-style:none;padding:0;margin:0;
  font-family:'Inter',sans-serif;
}
.secrets-list li{
  padding:10px 0 12px;
  border-bottom:1px solid rgba(15,29,63,.05);
  display:flex;flex-direction:column;gap:2px;
}
.secrets-list li:last-child{border-bottom:none;padding-bottom:2px}
.secrets-list li strong{
  font-size:13.5px;font-weight:600;color:#0f1d3f;letter-spacing:.01em;
}
.secrets-list li span{
  font-size:12.5px;color:#3d4c6a;line-height:1.5;
}
.secrets-list li em{
  font-style:normal;
  font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;
  color:#b8945a;font-weight:600;margin-top:2px;
}

/* Info-Banner am Ende der Secrets-Sektion */
.info-banner.info-banner--tresor{
  margin-top:22px;padding:16px 20px;
  background:linear-gradient(135deg,rgba(15,29,63,.05),rgba(184,148,90,.08));
  border:1px solid rgba(184,148,90,.25);
  border-left:3px solid #b8945a;
  border-radius:4px;
  font-family:'Inter',sans-serif;
  font-size:12.5px;line-height:1.6;color:#3d4c6a;
  display:flex;gap:10px;flex-wrap:wrap;
}
.info-banner.info-banner--tresor strong{
  color:#0f1d3f;font-weight:600;letter-spacing:.02em;
  white-space:nowrap;
}

@media (max-width:640px){
  .secrets-grid{grid-template-columns:1fr}
  .secrets-card{padding:16px 18px 14px}
}

/* ============================================================
   SECRETS-EDITOR — Toolbar, Actions, Empty-States, Dialog
   ============================================================ */
.secrets-toolbar{
  display:flex;align-items:center;gap:14px;flex-wrap:wrap;
  margin:0 0 16px;padding:12px 14px;
  background:#fbf8f1;border:1px dashed rgba(184,148,90,.35);border-radius:8px;
}
.secrets-toolbar__add{
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 14px;border-radius:6px;
  background:#0f1d3f;color:#e4c287;border:1px solid #0f1d3f;
  font-family:'Inter',sans-serif;font-size:13px;font-weight:600;letter-spacing:.01em;
  cursor:pointer;transition:background .14s ease, transform .14s ease;
}
.secrets-toolbar__add span[aria-hidden]{font-size:16px;line-height:1;color:#e4c287}
.secrets-toolbar__add:hover{background:#16264c;transform:translateY(-1px)}
.secrets-toolbar__hint{
  flex:1;min-width:200px;
  font-family:'Inter',sans-serif;font-size:12px;color:#5a5040;line-height:1.5;
}
.secrets-toolbar__restore{
  margin-left:auto;padding:7px 12px;
  background:transparent;color:#8a6d3f;
  border:1px solid rgba(184,148,90,.4);border-radius:6px;
  font-family:'Inter',sans-serif;font-size:12px;font-weight:500;
  cursor:pointer;transition:all .14s ease;
}
.secrets-toolbar__restore:hover{background:rgba(184,148,90,.1);color:#6e5630}

/* Card-Actions (Edit/Delete der Kategorie) */
.secrets-card__head{position:relative}
.secrets-card__actions{
  position:absolute;top:0;right:0;
  display:flex;gap:4px;
  opacity:0;transition:opacity .18s ease;
}
.secrets-card:hover .secrets-card__actions,
.secrets-card:focus-within .secrets-card__actions{opacity:1}
.secrets-iconbtn{
  width:26px;height:26px;display:inline-flex;align-items:center;justify-content:center;
  background:#fff;border:1px solid rgba(15,29,63,.15);border-radius:5px;
  color:#5a6a85;font-size:12px;line-height:1;cursor:pointer;
  transition:all .14s ease;padding:0;
}
.secrets-iconbtn:hover{background:#0f1d3f;color:#e4c287;border-color:#0f1d3f}

/* Item-Layout mit Actions */
.secrets-list li{
  flex-direction:row !important;
  align-items:flex-start;
  gap:10px;
}
.secrets-item-body{
  flex:1;min-width:0;
  display:flex;flex-direction:column;gap:2px;
}
.secrets-item-actions{
  display:flex;gap:4px;flex:none;
  opacity:0;transition:opacity .18s ease;
}
.secrets-list li:hover .secrets-item-actions,
.secrets-list li:focus-within .secrets-item-actions{opacity:1}

/* Add-Item-Button unten in jeder Karte */
.secrets-add-item{
  display:block;width:100%;margin-top:12px;padding:8px 10px;
  background:transparent;border:1px dashed rgba(184,148,90,.4);border-radius:6px;
  color:#8a6d3f;font-family:'Inter',sans-serif;font-size:12px;font-weight:500;
  cursor:pointer;transition:all .14s ease;
}
.secrets-add-item:hover{background:rgba(184,148,90,.08);color:#6e5630;border-style:solid}

/* Empty-States */
.secrets-empty-cat{
  padding:16px 4px;text-align:center;
  font-family:'Inter',sans-serif;font-size:12px;color:#8a7e65;font-style:italic;
  border-top:1px dashed rgba(15,29,63,.08);
}
.secrets-empty-grid{
  grid-column:1/-1;
  padding:32px 20px;text-align:center;
  background:#fff;border:1px dashed rgba(184,148,90,.35);border-radius:8px;
  font-family:'Inter',sans-serif;font-size:13.5px;color:#5a5040;
}

/* Dialog */
.secrets-dlg-backdrop{
  position:fixed;inset:0;z-index:9999;
  background:rgba(10,18,35,.48);
  display:flex;align-items:center;justify-content:center;
  padding:20px;
  animation:secretsFadeIn .16s ease-out;
}
@keyframes secretsFadeIn{ from{opacity:0} to{opacity:1} }
.secrets-dlg{
  width:100%;max-width:460px;max-height:90vh;overflow:auto;
  background:#fff;border-radius:10px;
  box-shadow:0 20px 60px rgba(10,18,35,.32);
  font-family:'Inter',sans-serif;
  display:flex;flex-direction:column;
}
.secrets-dlg__head{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 20px;border-bottom:1px solid rgba(15,29,63,.08);
  font-family:'Cormorant Garamond',serif;font-size:19px;font-weight:500;color:#0f1d3f;
}
.secrets-dlg__close{
  background:transparent;border:none;color:#5a6a85;font-size:18px;cursor:pointer;
  width:28px;height:28px;border-radius:5px;
  display:inline-flex;align-items:center;justify-content:center;
}
.secrets-dlg__close:hover{background:rgba(15,29,63,.06);color:#0f1d3f}
.secrets-dlg__body{padding:18px 20px;display:flex;flex-direction:column;gap:14px}
.secrets-dlg-field{display:flex;flex-direction:column;gap:6px}
.secrets-dlg-field > span{
  font-size:11.5px;font-weight:600;color:#5a6a85;
  letter-spacing:.08em;text-transform:uppercase;
}
.secrets-dlg-field input[type=text],
.secrets-dlg-field textarea{
  width:100%;padding:9px 11px;
  background:#fbf8f1;border:1px solid rgba(15,29,63,.12);border-radius:6px;
  font-family:'Inter',sans-serif;font-size:13.5px;color:#0f1d3f;
  outline:none;transition:border-color .14s ease, background .14s ease;
  resize:vertical;
}
.secrets-dlg-field input[type=text]:focus,
.secrets-dlg-field textarea:focus{
  border-color:#b8945a;background:#fff;
}
.secrets-icon-choices{
  display:flex;flex-wrap:wrap;gap:6px;
}
.secrets-icon-choice{
  width:34px;height:34px;display:inline-flex;align-items:center;justify-content:center;
  background:#fbf8f1;border:1px solid rgba(15,29,63,.12);border-radius:6px;
  color:#0f1d3f;font-size:15px;cursor:pointer;
  transition:all .14s ease;padding:0;
}
.secrets-icon-choice:hover{background:#fff;border-color:#b8945a}
.secrets-icon-choice.is-active{
  background:#0f1d3f;color:#e4c287;border-color:#0f1d3f;
}
.secrets-dlg__foot{
  display:flex;justify-content:flex-end;gap:8px;
  padding:12px 20px 16px;border-top:1px solid rgba(15,29,63,.06);
}
.secrets-dlg__cancel,
.secrets-dlg__save{
  padding:8px 16px;border-radius:6px;
  font-family:'Inter',sans-serif;font-size:13px;font-weight:600;
  cursor:pointer;transition:all .14s ease;
}
.secrets-dlg__cancel{
  background:transparent;color:#5a6a85;border:1px solid rgba(15,29,63,.15);
}
.secrets-dlg__cancel:hover{background:rgba(15,29,63,.04);color:#0f1d3f}
.secrets-dlg__save{
  background:#0f1d3f;color:#e4c287;border:1px solid #0f1d3f;
}
.secrets-dlg__save:hover{background:#16264c}

@media (max-width:560px){
  .secrets-toolbar__restore{margin-left:0;width:100%}
  .secrets-card__actions{opacity:1}
  .secrets-item-actions{opacity:1}
}

/* ============================================================
   COCKPIT-TABELLE — Zeile klickbar, "Öffnen"-Button pro Zeile
   ============================================================ */
.cockpit__row--clickable{cursor:pointer;transition:background-color .14s ease}
.cockpit__row--clickable:hover{background:rgba(184,148,90,.08)}
.cockpit__row--clickable:hover .cockpit__open{
  background:#0f1d3f;color:#e4c287;border-color:#0f1d3f;
}
.cockpit__th-action{width:120px;text-align:right}
.cockpit__action{text-align:right;white-space:nowrap}
.cockpit__open{
  display:inline-flex;align-items:center;gap:6px;
  padding:6px 12px;border-radius:4px;
  border:1px solid rgba(15,29,63,.2);
  background:#fff;color:#0f1d3f;
  font-family:'Inter',sans-serif;font-size:12px;font-weight:600;
  letter-spacing:.02em;cursor:pointer;
  transition:all .14s ease;
}
.cockpit__open:hover{
  background:#0f1d3f;color:#e4c287;border-color:#0f1d3f;
  box-shadow:0 1px 3px rgba(15,29,63,.18);
}
.cockpit__open--disabled{
  color:#b4b9c4;border-color:transparent;background:transparent;
  cursor:default;font-size:14px;padding:6px 12px;
}

/* ============================================================
   CHALET-KACHELN AUFKLAPPEN (Bauherrschaft/Architekt/Bauleitung)
   ============================================================ */
.chalet-tile.is-expandable{
  cursor:pointer;position:relative;transition:box-shadow .18s ease;
}
.chalet-tile.is-expandable:hover{
  box-shadow:0 6px 18px rgba(15,29,63,.1);
}
.chalet-tile.is-expandable:focus-visible{
  outline:2px solid #b8945a;outline-offset:3px;
}
.chalet-tile__chev{
  position:absolute;top:14px;right:16px;
  font-size:14px;color:#b8945a;
  transition:transform .22s ease;
  pointer-events:none;
}
.chalet-tile.is-open .chalet-tile__chev{
  transform:rotate(180deg);
}

.chalet-tile__panel{
  grid-column:1 / -1;
  margin-top:14px;
  animation:chaletExpand .24s ease;
}
@keyframes chaletExpand{
  from{opacity:0;transform:translateY(-4px)}
  to{opacity:1;transform:translateY(0)}
}

.chalet-units{
  list-style:none;margin:0;padding:0;
  background:#fff;border-radius:6px;
  box-shadow:inset 0 0 0 1px rgba(15,29,63,.08);
  overflow:hidden;
}
.chalet-unit{
  display:grid;
  grid-template-columns:60px 1fr 80px 95px 105px;
  align-items:center;
  gap:12px;
  padding:10px 14px;
  border-top:1px solid rgba(15,29,63,.06);
  font-family:'Inter',sans-serif;
  font-size:12.5px;
  color:#3d4c6a;
}
.chalet-unit:first-child{border-top:none}
.chalet-unit--active{
  background:linear-gradient(90deg,rgba(184,148,90,.08),transparent);
  box-shadow:inset 3px 0 0 #b8945a;
}
.chalet-unit--frei{opacity:.7}

.chalet-unit__id{font-size:13px;color:#0f1d3f}
.chalet-unit__id strong{font-weight:700;letter-spacing:.02em}
.chalet-unit__crown{color:#b8945a;font-size:10px;margin-left:2px}
.chalet-unit__buyer{
  font-size:12.5px;color:#3d4c6a;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.chalet-unit__sqm{
  font-variant-numeric:tabular-nums;
  font-size:11.5px;color:#6a5f4a;
  text-align:right;
}
.chalet-unit__pill{
  display:inline-block;
  padding:2px 10px;border-radius:12px;
  font-size:10.5px;font-weight:600;letter-spacing:.04em;
  text-transform:uppercase;
  text-align:center;
  white-space:nowrap;
}
.chalet-unit__pill--verkauft{background:#e6f3ec;color:#2e7d4f}
.chalet-unit__pill--reserviert{background:#fbf0df;color:#a6761f}
.chalet-unit__pill--frei{background:#f2f2f4;color:#7a8090}

.chalet-unit__open{
  display:inline-flex;align-items:center;justify-content:center;
  padding:5px 11px;border-radius:4px;
  border:1px solid rgba(15,29,63,.2);
  background:#fff;color:#0f1d3f;
  font-family:'Inter',sans-serif;font-size:11.5px;font-weight:600;
  letter-spacing:.02em;cursor:pointer;
  transition:all .14s ease;
  white-space:nowrap;
}
.chalet-unit__open:hover{
  background:#0f1d3f;color:#e4c287;border-color:#0f1d3f;
}
.chalet-unit__open.is-active{
  background:#b8945a;color:#fff;border-color:#b8945a;cursor:default;
}
.chalet-unit__open--disabled{
  color:#b4b9c4;border-color:transparent;background:transparent;
  cursor:default;padding:5px 11px;
}

@media (max-width:720px){
  .chalet-unit{
    grid-template-columns:50px 1fr 85px;
    grid-template-rows:auto auto;
    row-gap:4px;
  }
  .chalet-unit__buyer{grid-column:2 / span 2}
  .chalet-unit__sqm{grid-column:1;font-size:11px}
  .chalet-unit__pill{grid-column:2;justify-self:start}
  .chalet-unit__open{grid-column:3;grid-row:2;justify-self:end}
}

/* -- Schlüssel-Hint unterhalb des Tresor-Portals (expliziter UX-Hinweis) -- */
.tresor-gate__portal{position:relative}
.tresor-gate__portal .tresor-gate__hint{
  position:absolute;
  left:50%;
  /* sitzt knapp über dem Nameplate, zwischen Rad-Kreis und dem Namen */
  bottom:60px;
  transform:translateX(-50%);
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 16px 8px 12px;
  background:linear-gradient(180deg,#b8945a 0%,#8a6a3a 100%);
  color:#0f1d3f;
  border-radius:999px;
  font-family:'Inter',sans-serif;
  font-size:11px;
  font-weight:600;
  letter-spacing:.06em;
  text-transform:uppercase;
  box-shadow:
    0 4px 14px rgba(0,0,0,.5),
    0 0 0 2px rgba(15,29,63,.4),
    inset 0 1px 0 rgba(255,255,255,.35);
  cursor:pointer;
  z-index:5;
  animation:tresorHintPulse 2.4s ease-in-out infinite;
  white-space:nowrap;
}
.tresor-gate__hint-key{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:22px;height:22px;
  border-radius:50%;
  background:#0f1d3f;
  color:#e4c287;
  box-shadow:inset 0 1px 2px rgba(0,0,0,.6);
  animation:tresorKeyWiggle 2.4s ease-in-out infinite;
}
.tresor-gate__hint-key svg{display:block}
.tresor-gate__hint-text{line-height:1}

@keyframes tresorHintPulse{
  0%,100%{
    box-shadow:
      0 4px 14px rgba(0,0,0,.5),
      0 0 0 2px rgba(15,29,63,.4),
      0 0 0 0 rgba(228,194,135,.55),
      inset 0 1px 0 rgba(255,255,255,.35);
    transform:translateX(-50%) scale(1);
  }
  50%{
    box-shadow:
      0 4px 14px rgba(0,0,0,.5),
      0 0 0 2px rgba(15,29,63,.4),
      0 0 0 10px rgba(228,194,135,0),
      inset 0 1px 0 rgba(255,255,255,.35);
    transform:translateX(-50%) scale(1.04);
  }
}
@keyframes tresorKeyWiggle{
  0%,70%,100%{transform:rotate(0deg)}
  80%{transform:rotate(-18deg)}
  90%{transform:rotate(14deg)}
}

/* Hint ausblenden sobald der Tresor sich öffnet */
.tresor-gate.is-unlocking .tresor-gate__portal .tresor-gate__hint{
  opacity:0;
  transform:translateX(-50%) scale(.9);
  transition:opacity .4s ease, transform .4s ease;
  pointer-events:none;
  animation:none;
}

/* Button mit Icon */
.tresor-gate__btn{
  display:inline-flex !important;
  align-items:center;
  gap:10px;
}
.tresor-gate__btn-icon{
  flex:0 0 auto;
  opacity:.9;
}

/* Mobile: Hint etwas kleiner, knapp unter dem Rad */
@media (max-width:720px){
  .tresor-gate__portal .tresor-gate__hint{
    bottom:48px;
    font-size:10px;
    padding:6px 12px 6px 8px;
  }
  .tresor-gate__hint-key{width:20px;height:20px}
  .tresor-gate__hint-key svg{width:14px;height:14px}
}
