/* FestivalPay Portal — Shell + Design-System (Slate/Amber).
   Plain CSS (kein Razor) -> @media/@keyframes brauchen kein Escaping. */
:root{
  --bg:#0b1220; --bg-1:#0f172a; --bg-2:#1e293b; --bg-3:#334155;
  --line:#26344b; --line-soft:#1d2940;
  --fg:#e8eef7; --fg-2:#aab6c8; --fg-mut:#7c8aa0; --fg-muted:#7c8aa0;
  --accent:#f59e0b; --accent-strong:#d97706; --amber-ink:#1a1206;
  --ok:#3fb950; --no:#f85149; --danger:#f85149; --success:#3fb950; --warning:#d8a72a; --border:#26344b;
  --r:14px; --r-sm:10px;
  --sans:"Inter Tight",system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
  --serif:"Fraunces",Georgia,"Times New Roman",serif;
  --mono:"JetBrains Mono",ui-monospace,Menlo,Consolas,monospace;
}
*{box-sizing:border-box}
html,body{margin:0;min-height:100%}
body{font-family:var(--sans);color:var(--fg);background:var(--bg);line-height:1.5;-webkit-font-smoothing:antialiased;
  background-image:radial-gradient(1100px 520px at 78% -8%,rgba(245,158,11,.09),transparent 60%),radial-gradient(900px 500px at -5% 0%,rgba(59,130,246,.06),transparent 55%);}
a{color:inherit;text-decoration:none}

/* ---- App shell ---- */
.app{display:grid;grid-template-columns:248px 1fr;min-height:100vh}
.sidebar{background:linear-gradient(180deg,#0e1626,#0c1320);border-right:1px solid var(--line);padding:18px 14px;display:flex;flex-direction:column;gap:4px;position:sticky;top:0;height:100vh}
.brand{display:flex;align-items:center;gap:10px;padding:6px 8px 16px}
.brand .mark{width:32px;height:32px;border-radius:9px;display:grid;place-items:center;background:linear-gradient(135deg,var(--accent),var(--accent-strong));color:var(--amber-ink);font-weight:700}
.brand b{font-family:var(--serif);font-weight:600;font-size:1.08rem}
.nav-label{color:var(--fg-mut);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;padding:14px 10px 6px}
.nav-item{display:flex;align-items:center;gap:11px;padding:9px 11px;border-radius:10px;color:var(--fg-2);font-size:.92rem;font-weight:500;position:relative}
.nav-item svg{width:18px;height:18px;opacity:.85;flex:none}
.nav-item:hover{background:#172238;color:var(--fg)}
.nav-item.active{background:#16223a;color:var(--fg)}
.nav-item.active::before{content:"";position:absolute;left:-14px;top:8px;bottom:8px;width:3px;border-radius:0 3px 3px 0;background:var(--accent)}
.nav-item.active svg{color:var(--accent);opacity:1}
.side-foot{margin-top:auto;border-top:1px solid var(--line);padding-top:12px;display:flex;align-items:center;gap:10px}
.side-foot .avatar{width:30px;height:30px;border-radius:50%;background:#243352;display:grid;place-items:center;font-size:.8rem;color:var(--fg-2);flex:none}
.side-foot small{color:var(--fg-mut)}
.side-foot .lo{margin-left:auto;background:none;border:0;color:var(--fg-mut);cursor:pointer;font-size:.82rem;font-family:inherit}
.side-foot .lo:hover{color:var(--fg)}

.main{min-width:0;display:flex;flex-direction:column}
.topbar{display:flex;align-items:center;gap:12px;padding:14px 26px;border-bottom:1px solid var(--line-soft);position:sticky;top:0;background:rgba(11,18,32,.72);backdrop-filter:blur(8px);z-index:5}
.hamb{display:none;width:38px;height:38px;border-radius:9px;border:1px solid var(--line);background:transparent;color:var(--fg);cursor:pointer}
.crumbs{color:var(--fg-mut);font-size:.85rem}
.crumbs b{color:var(--fg-2);font-weight:500}
.topbar .spacer{flex:1}
.content{padding:26px;max-width:1080px;width:100%;animation:rise .45s ease both}
h2{margin-top:0}

/* ---- Page head ---- */
.ph{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:4px}
.ph h1{font-family:var(--serif);font-weight:600;font-size:2rem;line-height:1.05;margin:0}
.ph p{color:var(--fg-2);margin:.45rem 0 0;font-size:.94rem;max-width:56ch}

/* ---- Buttons ---- */
.button{display:inline-flex;align-items:center;gap:8px;border:0;border-radius:10px;padding:10px 16px;font-size:.9rem;font-weight:600;cursor:pointer;font-family:inherit;background:var(--accent);color:var(--amber-ink);text-decoration:none}
.button svg{width:16px;height:16px}
.button:hover{background:var(--accent-strong)}
.button.secondary{background:transparent;border:1px solid var(--line);color:var(--fg)}
.button.secondary:hover{background:#172238;border-color:var(--bg-3)}
.button.danger{background:var(--no);color:#fff}
.button.danger:hover{filter:brightness(1.06)}
.button.sm{padding:7px 12px;font-size:.83rem;border-radius:9px}
.button:disabled{opacity:.45;cursor:not-allowed}

/* ---- Card / Panel ---- */
.card{background:linear-gradient(180deg,#121c2e,#0f1828);border:1px solid var(--line);border-radius:var(--r);box-shadow:0 16px 44px rgba(0,0,0,.32);padding:1.4rem;margin-bottom:1.4rem}
.card h2,.card h3{font-family:var(--serif);font-weight:500}
.panel{background:linear-gradient(180deg,#121c2e,#0f1828);border:1px solid var(--line);border-radius:var(--r);box-shadow:0 16px 44px rgba(0,0,0,.32);overflow:hidden}
.panel-head{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-bottom:1px solid var(--line-soft)}
.panel-head h2{font-family:var(--serif);font-weight:500;font-size:1.05rem;margin:0}
.panel-head .cnt{color:var(--fg-mut);font-size:.8rem;font-family:var(--mono)}

/* ---- Metrics ---- */
.metrics{display:flex;gap:10px;flex-wrap:wrap;margin:20px 0 16px}
.metric{background:var(--bg-1);border:1px solid var(--line);border-radius:12px;padding:11px 16px;min-width:120px}
.metric .k{color:var(--fg-mut);font-size:.74rem;letter-spacing:.05em}
.metric .v{font-family:var(--mono);font-size:1.45rem;font-weight:700;margin-top:3px}

/* ---- Edge list ---- */
.erows{list-style:none;margin:0;padding:0}
.erow{display:grid;grid-template-columns:1fr auto auto;align-items:center;gap:16px;padding:15px 20px;border-bottom:1px solid var(--line-soft)}
.erow:last-child{border-bottom:0}
.erow:hover{background:#13203559}
.eid{display:flex;align-items:center;gap:13px;min-width:0}
.esvr{width:38px;height:38px;border-radius:11px;background:#16233b;border:1px solid var(--line);display:grid;place-items:center;color:var(--fg-2);flex:none}
.esvr svg{width:19px;height:19px}
.enm{display:flex;align-items:center;gap:9px;font-weight:600;font-size:1.02rem;min-width:0}
.enm .t{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.edot{width:8px;height:8px;border-radius:50%;flex:none}
.edot.on{background:var(--ok);box-shadow:0 0 0 3px rgba(63,185,80,.18)}
.edot.off{background:var(--no);box-shadow:0 0 0 3px rgba(248,81,73,.16)}
.esub{color:var(--fg-mut);font-size:.82rem;margin-top:2px}
.esub .mono{font-family:var(--mono)}
.emeta{display:flex;gap:24px;text-align:right}
.emeta .k{color:var(--fg-mut);font-size:.7rem}
.emeta .v{font-size:.85rem;margin-top:2px}

/* ---- Badges ---- */
.badge{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;border-radius:999px;font-size:.75rem;font-weight:600}
.badge-success{background:rgba(63,185,80,.15);color:var(--ok)}
.badge-danger{background:rgba(248,81,73,.15);color:var(--no)}
.badge-warning{background:rgba(216,167,42,.16);color:#e8b84a}
.badge-info{background:rgba(245,158,11,.14);color:var(--accent)}

/* ---- last-seen severities ---- */
.last-seen-fresh{color:var(--ok)}
.last-seen-recent{color:var(--fg-2)}
.last-seen-warning{color:#e8b84a}
.last-seen-stale{color:var(--fg-mut)}

/* ---- Fields ---- */
.field{margin-bottom:1rem}
.field label{display:block;margin-bottom:.4rem;color:var(--fg-mut);font-size:.88rem}
.field input,.field select{width:100%;padding:.65rem .8rem;background:var(--bg-1);border:1px solid var(--line);border-radius:10px;color:var(--fg);font-size:1rem;font-family:inherit}
.field input:focus,.field select:focus{outline:none;border-color:var(--accent)}

/* ---- Alerts ---- */
.alert{padding:.8rem 1rem;border-radius:10px;margin-bottom:1rem;font-weight:600}
.alert-success{background:#10331f;color:#bbf7d0;border:1px solid #1c5235}
.alert-error{background:#3a1717;color:#fecaca;border:1px solid #5e2626}
.alert-info{background:#152b46;color:#cfe4ff;border:1px solid #244468}

.muted{color:var(--fg-mut)}
code{font-family:var(--mono);background:#0c1626;border:1px solid var(--line);border-radius:6px;padding:.05rem .35rem;font-size:.86em}
.codebox{font-family:var(--mono);font-weight:700;letter-spacing:.14em;color:#ffd27a}

@keyframes rise{from{opacity:0;transform:translateY(7px)}to{opacity:1;transform:none}}
@keyframes pop{from{opacity:0;transform:scale(.97)}to{opacity:1;transform:none}}
@keyframes fade{from{opacity:0}to{opacity:1}}

/* ---- Modal ---- */
.scrim{position:fixed;inset:0;background:rgba(5,9,17,.66);backdrop-filter:blur(3px);display:none;place-items:center;z-index:50;padding:20px}
.scrim.open{display:grid;animation:fade .15s ease both}
.modal{width:100%;max-width:460px;background:linear-gradient(180deg,#15203a,#101a2e);border:1px solid var(--line);border-radius:16px;box-shadow:0 30px 80px rgba(0,0,0,.6);padding:22px;animation:pop .16s ease both}
.modal h3{font-family:var(--serif);font-weight:600;margin:0 0 6px;font-size:1.3rem}
.modal p{color:var(--fg-2);font-size:.9rem;margin:0 0 14px}
.modal-acts{display:flex;justify-content:flex-end;gap:10px;margin-top:18px}

/* ---- Responsive ---- */
@media (max-width:900px){
  .app{grid-template-columns:1fr}
  .sidebar{position:fixed;left:0;top:0;width:248px;z-index:40;transform:translateX(-100%);transition:transform .22s ease}
  .sidebar.open{transform:none;box-shadow:0 0 0 100vmax rgba(0,0,0,.5)}
  .hamb{display:grid;place-items:center}
}
@media (max-width:680px){
  .erow{grid-template-columns:1fr;align-items:start;gap:12px}
  .emeta{justify-content:flex-start;text-align:left;gap:20px}
  .ph h1{font-size:1.6rem}
  .content{padding:18px}
}

/* ===== Portalweite Migration: fehlende Legacy-Klassen + Auth-Layout ===== */

/* Stats (Dashboard) */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-bottom:1.5rem}
.stat{background:var(--bg-1);border:1px solid var(--line);border-radius:12px;padding:1rem}
.stat-label{font-size:.85rem;color:var(--fg-mut);margin-bottom:.4rem}
.stat-value{font-size:1.5rem;font-weight:600;font-family:var(--mono)}

/* form-group (Alias von .field) + Button-Varianten */
.form-group{margin-bottom:1rem}
.form-group label{display:block;margin-bottom:.4rem;color:var(--fg-mut);font-size:.88rem}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:.65rem .8rem;background:var(--bg-1);border:1px solid var(--line);border-radius:10px;color:var(--fg);font-size:1rem;font-family:inherit}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--accent)}
.button.big{padding:.85rem 1.5rem;font-size:1.02rem;border-radius:11px}
.button.ghost{background:transparent;border:1px solid var(--line);color:var(--fg)}
.button.ghost:hover{background:#172238;border-color:var(--bg-3)}

/* Pre-Login (Auth) – zentriert, ohne Seitenleiste */
.authwrap{min-height:100vh;padding:24px 16px;animation:rise .45s ease both}
.authbrand{display:flex;align-items:center;justify-content:center;gap:10px;margin:7vh 0 0;font-family:var(--serif);font-size:1.35rem;font-weight:600}
.authbrand .mark{width:34px;height:34px;border-radius:9px;display:grid;place-items:center;background:linear-gradient(135deg,var(--accent),var(--accent-strong));color:var(--amber-ink);font-weight:700}
.authbrand small{color:var(--fg-mut);font-family:var(--sans);font-weight:500;font-size:.82rem}
