/* ===========================================================
   Hello Expansion – Admin-Dashboard (Precision White)
   =========================================================== */
:root{
  --navy:#0a2150;--navy-2:#143a7a;--ink:#1d1d1f;--muted:#86868b;
  --line:#e6e6ea;--bg:#f5f5f7;--card:#fff;--accent:#0071e3;
  --green:#1c7a44;--red:#c0392b;--amber:#b7791f;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Inter,Roboto,Arial,sans-serif;background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased}
button,input,select,textarea{font-family:inherit}
.hidden{display:none!important}

/* ---- Login ---- */
.login{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}
.login-card{background:#fff;border-radius:22px;box-shadow:0 18px 60px rgba(10,33,80,.12);padding:42px 38px;width:100%;max-width:400px;text-align:center}
.login-card img{height:42px;margin-bottom:8px}
.login-card h1{font-size:20px;font-weight:600;margin-bottom:4px}
.login-card p{color:var(--muted);font-size:13.5px;margin-bottom:26px}
.login-card input{width:100%;padding:13px 15px;border:1px solid var(--line);border-radius:12px;font-size:15px;margin-bottom:12px}
.login-card input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(0,113,227,.12)}
.login-card .btn{width:100%}
.login-err{color:var(--red);font-size:13.5px;margin-bottom:12px;min-height:18px}
.demo-note{background:#eef4ff;color:#27457e;border-radius:12px;padding:11px 14px;font-size:12.5px;margin-bottom:20px;line-height:1.5}

/* ---- Topbar ---- */
.top{background:#fff;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:10}
.top-in{max-width:1080px;margin:0 auto;display:flex;align-items:center;gap:16px;padding:13px 22px}
.top img{height:30px}
.badge-mode{font-size:11px;font-weight:600;padding:4px 9px;border-radius:20px}
.badge-mode.cloud{background:#e8f7ee;color:var(--green)}
.badge-mode.local{background:#fff4e5;color:var(--amber)}
.top .spacer{flex:1}
.top .who{font-size:13px;color:var(--muted);text-align:right;line-height:1.3}
.top .who b{color:var(--ink);display:block;font-size:13.5px}
.role-chip{display:inline-block;font-size:10.5px;font-weight:600;text-transform:uppercase;letter-spacing:.4px;background:var(--navy);color:#fff;padding:2px 7px;border-radius:6px;margin-top:2px}

/* ---- Tabs ---- */
.tabs{max-width:1080px;margin:0 auto;display:flex;gap:4px;padding:14px 22px 0}
.tab{background:none;border:none;padding:10px 16px;border-radius:10px 10px 0 0;font-size:14.5px;font-weight:500;color:var(--muted);cursor:pointer}
.tab.active{color:var(--navy);background:#fff;border:1px solid var(--line);border-bottom-color:#fff;margin-bottom:-1px}

/* ---- Inhalt ---- */
.wrap{max-width:1080px;margin:0 auto;padding:24px 22px 80px}
.bar{display:flex;align-items:center;gap:12px;margin-bottom:18px}
.bar h2{font-size:20px;font-weight:600}
.bar .spacer{flex:1}

/* ---- Buttons ---- */
.btn{border:none;cursor:pointer;font-size:14.5px;font-weight:600;padding:11px 18px;border-radius:11px;background:var(--navy);color:#fff;display:inline-flex;align-items:center;gap:7px}
.btn:disabled{opacity:.55;cursor:default}
.btn.ghost{background:#fff;border:1px solid var(--line);color:var(--ink)}
.btn.sm{padding:8px 13px;font-size:13px;border-radius:9px}
.btn.danger{background:#fff;border:1px solid #f0c9c4;color:var(--red)}

/* ---- Karten/Listen ---- */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:14px}
.pcard{background:#fff;border:1px solid var(--line);border-radius:16px;padding:18px;display:flex;flex-direction:column;gap:14px}
.pcard .head{display:flex;align-items:center;gap:13px}
.pcard .ava{width:48px;height:48px;border-radius:50%;flex:0 0 48px;background:linear-gradient(160deg,var(--navy),var(--navy-2));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;overflow:hidden}
.pcard .ava img{width:100%;height:100%;object-fit:cover}
.pcard .nm b{font-size:15.5px}
.pcard .nm span{display:block;color:var(--muted);font-size:13px;margin-top:1px}
.pcard .slug{font-size:12px;color:var(--muted);background:var(--bg);padding:3px 8px;border-radius:6px;font-family:ui-monospace,Menlo,monospace}
.pcard .stat{display:flex;gap:18px;font-size:13px;color:var(--muted)}
.pcard .stat b{color:var(--ink);font-size:15px}
.pcard .acts{display:flex;gap:8px;flex-wrap:wrap}
.pill{font-size:11px;font-weight:600;padding:3px 9px;border-radius:20px}
.pill.on{background:#e8f7ee;color:var(--green)}
.pill.off{background:#f0f0f3;color:var(--muted)}

/* ---- Tabelle ---- */
table{width:100%;border-collapse:collapse;background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden}
th,td{text-align:left;padding:13px 15px;font-size:14px;border-bottom:1px solid var(--line)}
th{background:var(--bg);color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.4px;font-weight:600}
tr:last-child td{border-bottom:none}
td .mini{color:var(--muted);font-size:12.5px}
select.role-sel{padding:7px 10px;border:1px solid var(--line);border-radius:9px;font-size:13.5px}

/* ---- Statistik ---- */
.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:14px;margin-bottom:22px}
.kpi{background:#fff;border:1px solid var(--line);border-radius:16px;padding:18px 20px}
.kpi .n{font-size:30px;font-weight:700;letter-spacing:-.5px}
.kpi .l{color:var(--muted);font-size:13px;margin-top:4px}
.chart{background:#fff;border:1px solid var(--line);border-radius:16px;padding:20px}
.chart h3{font-size:14px;font-weight:600;margin-bottom:16px}
.bars{display:flex;align-items:flex-end;gap:10px;height:150px}
.bars .b{flex:1;display:flex;flex-direction:column;align-items:center;gap:7px;height:100%;justify-content:flex-end}
.bars .b .col{width:100%;background:linear-gradient(180deg,var(--navy-2),var(--navy));border-radius:7px 7px 0 0;min-height:3px;transition:height .3s}
.bars .b .v{font-size:12px;font-weight:600}
.bars .b .d{font-size:11px;color:var(--muted)}

.empty-box{background:#fff;border:1px dashed var(--line);border-radius:16px;padding:48px;text-align:center;color:var(--muted)}

/* ---- Editor-Modal ---- */
.modal{position:fixed;inset:0;background:rgba(10,20,40,.45);display:flex;align-items:stretch;justify-content:flex-end;z-index:50}
.modal-panel{background:var(--bg);width:min(960px,100%);height:100%;display:grid;grid-template-columns:1fr 380px;overflow:hidden;box-shadow:-20px 0 60px rgba(0,0,0,.2)}
@media(max-width:860px){.modal-panel{grid-template-columns:1fr}.modal-prev{display:none}}
.modal-form{overflow:auto;padding:24px 26px 40px}
.modal-form .mhead{display:flex;align-items:center;margin-bottom:18px}
.modal-form .mhead h2{font-size:18px;font-weight:600}
.modal-form .mhead .x{margin-left:auto;background:#fff;border:1px solid var(--line);border-radius:10px;width:34px;height:34px;font-size:18px;cursor:pointer;color:var(--muted)}
.group{background:#fff;border-radius:14px;padding:18px 18px 6px;margin-bottom:14px;border:1px solid var(--line)}
.group h3{font-size:12px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);margin-bottom:13px}
.fld{margin-bottom:13px}
.fld label{display:block;font-size:13px;font-weight:500;margin-bottom:5px}
.fld .sub{color:var(--muted);font-weight:400}
.fld input{width:100%;padding:10px 13px;border:1px solid var(--line);border-radius:10px;font-size:14.5px}
.fld input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(0,113,227,.12)}
.photo-up{display:flex;align-items:center;gap:16px;margin-bottom:16px}
.photo-prev{width:72px;height:72px;flex:0 0 72px;border-radius:50%;overflow:hidden;background:linear-gradient(160deg,var(--navy),var(--navy-2));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:24px}
.photo-prev img{width:100%;height:100%;object-fit:cover}
.photo-acts{display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.photo-hint{width:100%;font-size:12px;color:var(--muted);margin-top:2px}
.two{display:grid;grid-template-columns:1fr 1fr;gap:11px}
.row3{display:grid;grid-template-columns:90px 1fr 1fr;gap:11px}
@media(max-width:520px){.two,.row3{grid-template-columns:1fr}}
.switch{display:flex;align-items:center;gap:10px;font-size:14px}
.switch input{width:auto}
.modal-actions{display:flex;gap:10px;position:sticky;bottom:0;background:linear-gradient(to top,var(--bg) 75%,transparent);padding:14px 0 2px}
.modal-prev{background:#e9e9ee;display:flex;align-items:center;justify-content:center;padding:20px}
.modal-prev iframe{width:330px;max-width:100%;height:680px;border:none;border-radius:26px;background:#fff;box-shadow:0 16px 44px rgba(10,33,80,.18)}

.toast{position:fixed;left:50%;bottom:26px;transform:translateX(-50%) translateY(20px);background:var(--navy);color:#fff;padding:12px 20px;border-radius:12px;font-size:14px;opacity:0;transition:.25s;pointer-events:none;z-index:90}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast.err{background:var(--red)}
