/* Garage-Verwaltung · Panel-Layout & Komponenten.
   Baut auf base.css (Tokens, Buttons, Cards) auf. */

/* ============================ Login ============================ */
.login-screen{
  min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:1.4rem;
  background:
    radial-gradient(60% 80% at 85% -10%, rgba(166,130,76,.22), transparent 60%),
    radial-gradient(50% 70% at 0% 110%, rgba(71,138,201,.18), transparent 60%),
    linear-gradient(180deg, var(--ink) 0%, #0c1f33 100%);
}
/* Ohne diese Regel überschreibt .login-screen{display:flex} das hidden-Attribut
   (gleiche Spezifität, Author schlägt User-Agent) → Login bliebe nach dem
   Anmelden sichtbar und schöbe die App nach unten. */
.login-screen[hidden]{display:none}
.login-card{
  width:100%;max-width:400px;background:var(--paper);border-radius:20px;
  box-shadow:var(--shadow);padding:2.2rem 2rem 1.8rem;text-align:center;
}
.login-card .monogram{width:46px;height:46px;color:var(--brass);margin:0 auto .4rem}
.login-card .monogram svg{width:100%;height:100%}
.login-brand{font-family:'Cormorant Garamond',serif;font-size:1.7rem;color:var(--ink);line-height:1.1}
.login-sub{font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--brass);font-weight:500;margin-bottom:1.4rem}
.login-card form{text-align:left;margin-top:.6rem}
.login-card .field-msg{min-height:1.1rem}

/* ============================ Shell ============================ */
.app-shell{display:grid;grid-template-columns:248px 1fr;min-height:100dvh}
.app-shell[hidden]{display:none}
/* Backdrop nur im Mobil-Layout (Off-Canvas-Sidebar) sichtbar. Ohne diese
   Basisregel wäre der leere Div am Desktop ein sichtbares Grid-Item und würde
   die erste Spalte belegen → Sidebar/Inhalt verrutschen. */
.sidebar-backdrop{display:none}

.sidebar{
  background:linear-gradient(180deg,#13283f,#0f2236);color:#cdd8e2;
  display:flex;flex-direction:column;gap:.3rem;padding:1.3rem 1rem;position:sticky;top:0;height:100dvh;
}
.sidebar .brand{display:flex;flex-direction:column;line-height:1.1;text-decoration:none;padding:.2rem .6rem 1.1rem;border-bottom:1px solid rgba(255,255,255,.1);margin-bottom:.7rem}
.sidebar .brand b{font-family:'Cormorant Garamond',serif;font-size:1.4rem;color:#fff;font-weight:600}
.sidebar .brand span{font-size:.62rem;letter-spacing:.22em;text-transform:uppercase;color:var(--brass-soft);font-weight:500;margin-top:.1rem}
.nav-link{
  display:flex;align-items:center;gap:.7rem;width:100%;text-align:left;background:none;border:none;
  color:#bccada;padding:.7rem .8rem;border-radius:10px;cursor:pointer;font-size:.95rem;transition:background .18s,color .18s;
}
.nav-link svg{width:19px;height:19px;stroke:currentColor;flex:none;opacity:.85}
.nav-link:hover{background:rgba(255,255,255,.06);color:#fff}
.nav-link.active{background:rgba(166,130,76,.18);color:#fff}
.nav-link.active svg{stroke:var(--brass-soft);opacity:1}
.sidebar .nav-spacer{flex:1}
.sidebar .side-foot{font-size:.74rem;color:#7e8b99;padding:.6rem .8rem 0;border-top:1px solid rgba(255,255,255,.08);line-height:1.5}

.main{min-width:0;display:flex;flex-direction:column}
.topbar{
  position:sticky;top:0;z-index:30;display:flex;align-items:center;gap:1rem;
  background:rgba(246,242,234,.92);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);
  border-bottom:1px solid var(--line);padding:.85rem 1.6rem;
}
.topbar h1{font-size:1.7rem;margin:0}
.topbar .spacer{flex:1}
.menu-toggle{display:none;width:42px;height:42px;border:1px solid var(--line);background:#fff;border-radius:10px;cursor:pointer;align-items:center;justify-content:center}
.menu-toggle svg{width:20px;height:20px;stroke:var(--ink)}
.session-pill{display:inline-flex;align-items:center;gap:.45rem;font-size:.78rem;color:var(--muted);background:#fff;border:1px solid var(--line);border-radius:999px;padding:.35rem .7rem}
.session-pill i{width:8px;height:8px;border-radius:50%;background:var(--ok);display:inline-block}
.view{padding:1.6rem;max-width:1180px;width:100%;margin:0 auto;display:flex;flex-direction:column;gap:1.3rem}

/* ============================ Stat-Tiles ============================ */
.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem}
.stat{background:var(--paper);border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow-soft);padding:1.1rem 1.2rem;position:relative;overflow:hidden}
.stat::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--brass)}
.stat .n{font-family:'Cormorant Garamond',serif;font-size:2.4rem;font-weight:600;color:var(--ink);line-height:1}
.stat .l{font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-top:.35rem}
.stat.pending::before{background:var(--warn)}
.stat.confirmed::before{background:var(--ok)}
.stat.cancelled::before{background:var(--muted)}

.section-title{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}
.section-title h2{font-size:1.6rem}
.row-wrap{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.3rem;align-items:start}

/* ============================ Tabellen ============================ */
.toolbar{display:flex;flex-wrap:wrap;gap:.6rem;align-items:end}
.toolbar .field{margin:0}
.table-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:14px;background:var(--paper)}
table.data{width:100%;border-collapse:collapse;font-size:.92rem;min-width:680px}
table.data th{
  text-align:left;font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);
  font-weight:600;padding:.8rem 1rem;border-bottom:1px solid var(--line);white-space:nowrap;
}
table.data td{padding:.8rem 1rem;border-bottom:1px solid var(--line);vertical-align:middle}
table.data tr:last-child td{border-bottom:none}
table.data tbody tr{cursor:pointer;transition:background .12s}
table.data tbody tr:hover{background:rgba(166,130,76,.06)}
table.data .name{font-weight:500;color:var(--ink)}
table.data .sub{color:var(--muted);font-size:.82rem}
.num-cell{font-variant-numeric:tabular-nums;white-space:nowrap}

/* Status-Badges */
.badge{display:inline-flex;align-items:center;gap:.35rem;font-size:.72rem;font-weight:500;letter-spacing:.04em;padding:.25rem .6rem;border-radius:999px;text-transform:uppercase;border:1px solid transparent;white-space:nowrap}
.badge::before{content:"";width:7px;height:7px;border-radius:50%;background:currentColor}
.badge.pending{color:#946615;background:rgba(184,134,43,.12);border-color:rgba(184,134,43,.3)}
.badge.confirmed{color:#2c6047;background:rgba(59,109,79,.12);border-color:rgba(59,109,79,.3)}
.badge.cancelled{color:#6b6457;background:rgba(107,100,87,.1);border-color:rgba(107,100,87,.25)}
.badge.blocked{color:#13283f;background:rgba(19,40,63,.08);border-color:rgba(19,40,63,.2)}

/* ============================ Formulare (hell) ============================ */
.field{display:flex;flex-direction:column;gap:.35rem;margin-top:0}
.field label{font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);font-weight:500}
.field label .opt{color:var(--brass);letter-spacing:.04em}
.field input,.field select,.field textarea{
  width:100%;padding:.7rem .8rem;border:1px solid var(--line);background:#fff;color:var(--text);
  border-radius:9px;font-size:.95rem;transition:border-color .15s,box-shadow .15s;
}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--brass);box-shadow:0 0 0 3px rgba(166,130,76,.12)}
.field textarea{min-height:84px;resize:vertical}
.field.is-error input,.field.is-error textarea,.field.is-error select{border-color:#d98b8b;background:rgba(176,70,70,.05)}
.field-msg{display:block;font-size:.8rem;color:var(--danger);min-height:0}
.field-msg:empty{min-height:0}
.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.9rem}
.form-grid .full{grid-column:1/-1}
@media(max-width:600px){.form-grid{grid-template-columns:1fr}}
.inline-actions{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:.4rem}

/* ============================ Kalender ============================ */
.gcal{user-select:none}
.gcal-head{display:flex;align-items:center;justify-content:space-between;gap:.7rem;margin-bottom:.7rem}
.gcal-head .mon{font-family:'Cormorant Garamond',serif;font-size:1.35rem;color:var(--ink);font-weight:600;text-transform:capitalize}
.gcal-nav{width:36px;height:36px;border-radius:50%;border:1px solid var(--line);background:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--ink);transition:border-color .15s,opacity .15s}
.gcal-nav:hover:not(:disabled){border-color:var(--brass)}
.gcal-nav:disabled{opacity:.3;cursor:default}
.gcal-nav svg{width:18px;height:18px;stroke:currentColor}
.gcal-dow{display:grid;grid-template-columns:repeat(7,1fr);gap:3px;margin-bottom:3px}
.gcal-dow span{text-align:center;font-size:.62rem;letter-spacing:.04em;text-transform:uppercase;color:var(--muted)}
.gcal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px}
.gcal-day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:.82rem;border-radius:7px;color:var(--ink-soft);background:#fff;border:1px solid transparent}
.gcal-day.empty{visibility:hidden}
.gcal-day.past{color:#c9c2b4;background:transparent}
.gcal-day.free{background:rgba(59,109,79,.1);color:var(--ink)}
.gcal-day.booked{background:rgba(176,70,70,.14);color:#9c4040}
.gcal-day.blocked{background:rgba(19,40,63,.12);color:var(--ink);background-image:repeating-linear-gradient(45deg,transparent 0 4px,rgba(19,40,63,.08) 4px 8px)}
.gcal.pickable .gcal-day.free{cursor:pointer}
.gcal.pickable .gcal-day.free:hover{background:rgba(59,109,79,.28)}
.gcal-day.in-range{background:rgba(71,138,201,.22);border-radius:0;color:var(--ink)}
.gcal-day.edge{background:var(--ink);color:#fff;font-weight:500;border-radius:7px}
.gcal-day.edge.start{border-radius:7px 0 0 7px}
.gcal-day.edge.end{border-radius:0 7px 7px 0}
.gcal-day.edge.solo{border-radius:7px}
.gcal-legend{display:flex;flex-wrap:wrap;gap:.9rem;margin-top:.9rem;font-size:.78rem;color:var(--muted)}
.gcal-legend i{display:inline-block;width:11px;height:11px;border-radius:3px;margin-right:.35rem;vertical-align:-1px}
.gcal-legend .lf{background:rgba(59,109,79,.45)}
.gcal-legend .lb{background:rgba(176,70,70,.45)}
.gcal-legend .lk{background:rgba(19,40,63,.35)}
.gcal-legend .lr{background:var(--ink)}
.cal-months{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.4rem 1.6rem}

/* Preis-Vorschau */
.price-box{background:var(--ink);color:#e9eef3;border-radius:14px;padding:1.1rem 1.2rem}
.price-box .eyebrow{color:var(--brass-soft)}
.price-row{display:flex;justify-content:space-between;gap:1rem;padding:.4rem 0;border-bottom:1px solid rgba(255,255,255,.1);font-size:.92rem;color:#cdd8e2}
.price-row b{color:#fff}
.price-row.disc span,.price-row.disc b{color:#8fe3a8}
.price-row.total{border-bottom:none;padding-top:.7rem}
.price-row.total span{font-family:'Cormorant Garamond',serif;font-size:1.2rem;color:#fff}
.price-row.total b{font-family:'Cormorant Garamond',serif;font-size:1.5rem;color:var(--brass-soft)}

/* ============================ Drawer ============================ */
.drawer-overlay{position:fixed;inset:0;background:rgba(12,22,36,.5);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:none;z-index:60}
.drawer-overlay.open{display:block}
.drawer{
  position:fixed;top:0;right:0;height:100dvh;width:min(480px,94vw);background:var(--ivory);
  box-shadow:-20px 0 60px -30px rgba(0,0,0,.5);transform:translateX(100%);transition:transform .25s ease;
  z-index:61;display:flex;flex-direction:column;
}
.drawer.open{transform:translateX(0)}
.drawer-head{display:flex;align-items:center;gap:1rem;padding:1.2rem 1.4rem;border-bottom:1px solid var(--line);background:var(--paper)}
.drawer-head h2{font-size:1.45rem;margin:0}
.drawer-head .spacer{flex:1}
.drawer-close{width:38px;height:38px;border-radius:50%;border:1px solid var(--line);background:#fff;cursor:pointer;font-size:1.2rem;color:var(--ink);display:flex;align-items:center;justify-content:center}
.drawer-close:hover{border-color:var(--brass)}
.drawer-body{padding:1.3rem 1.4rem;overflow-y:auto;display:flex;flex-direction:column;gap:1.2rem}
.detail-list{display:grid;grid-template-columns:auto 1fr;gap:.55rem 1rem;font-size:.92rem}
.detail-list dt{color:var(--muted);font-size:.78rem;letter-spacing:.04em;text-transform:uppercase;padding-top:.1rem}
.detail-list dd{color:var(--ink);word-break:break-word}
.detail-list dd a{color:var(--ink);border-bottom:1px solid var(--brass-soft);text-decoration:none}

/* Timeline */
.timeline{display:flex;flex-direction:column;gap:.1rem;position:relative;padding-left:1.1rem}
.timeline .ev{position:relative;padding:.4rem 0 .55rem .3rem;font-size:.88rem}
.timeline .ev::before{content:"";position:absolute;left:-.85rem;top:.65rem;width:9px;height:9px;border-radius:50%;background:var(--brass);box-shadow:0 0 0 3px var(--ivory)}
.timeline .ev::after{content:"";position:absolute;left:-.5rem;top:.65rem;bottom:-.4rem;width:1px;background:var(--line)}
.timeline .ev:last-child::after{display:none}
.timeline .ev .t{color:var(--ink);font-weight:500;text-transform:capitalize}
.timeline .ev .d{color:var(--muted);font-size:.78rem}
.timeline .ev .note{color:var(--ink-soft)}

/* ============================ Toast / Misc ============================ */
.toasts{position:fixed;top:1rem;right:1rem;z-index:200;display:flex;flex-direction:column;gap:.6rem;max-width:360px}
.toast{background:var(--ink);color:#fff;border-radius:12px;padding:.8rem 1rem;box-shadow:var(--shadow);font-size:.9rem;display:flex;gap:.6rem;align-items:flex-start;animation:toastIn .2s ease-out}
.toast.ok{border-left:3px solid var(--ok)}
.toast.err{border-left:3px solid var(--danger)}
.toast.info{border-left:3px solid var(--brass)}
@keyframes toastIn{from{opacity:0;transform:translateX(12px)}to{opacity:1;transform:none}}
.empty-state{text-align:center;color:var(--muted);padding:2.4rem 1rem;font-size:.95rem}
.empty-state svg{width:42px;height:42px;stroke:var(--brass-soft);margin:0 auto .6rem;display:block;opacity:.7}
.spinner{width:18px;height:18px;border-radius:50%;border:2px solid rgba(255,255,255,.35);border-top-color:#fff;animation:spin .7s linear infinite;display:inline-block}
.btn-light .spinner,.btn-ghost .spinner{border-color:rgba(19,40,63,.25);border-top-color:var(--ink)}
@keyframes spin{to{transform:rotate(360deg)}}
.loading-row{display:flex;align-items:center;gap:.6rem;color:var(--muted);padding:1.4rem;font-size:.9rem}
.loading-row .spinner{border-color:rgba(19,40,63,.2);border-top-color:var(--ink)}

/* ============================ Responsive ============================ */
@media(max-width:860px){
  .app-shell{grid-template-columns:1fr}
  .sidebar{position:fixed;left:0;top:0;width:260px;z-index:70;transform:translateX(-100%);transition:transform .25s ease}
  .sidebar.open{transform:translateX(0)}
  .menu-toggle{display:flex}
  .sidebar-backdrop{position:fixed;inset:0;background:rgba(12,22,36,.45);z-index:65;display:none}
  .sidebar-backdrop.open{display:block}
}
@media(max-width:600px){
  .topbar{padding:.7rem 1rem}
  .topbar h1{font-size:1.4rem}
  .view{padding:1.1rem 1rem}
  .session-pill .txt{display:none}
}
