/* ============================================================
   Ryan Group Hub — styles
   Brand: RYAN purple (lightened #8A4FC4 for screen readability) / gold #FFC637 · Est. 1948
   Dark "control room" default + light office theme
   ============================================================ */

:root{
  --purple:#8A4FC4; --purple-deep:#5E2D91; --purple-bright:#B388E8;
  --gold:#FFC637; --gold-soft:#FFD75E;
  --ok:#2BD576; --warn:#FFB020; --bad:#FF5A5F; --info:#4CC3FF;
  --radius:14px; --radius-sm:9px;
  --font:'Plus Jakarta Sans',system-ui,Segoe UI,Roboto,sans-serif;
  --mono:'JetBrains Mono',ui-monospace,Consolas,monospace;
}
[data-theme="dark"]{
  color-scheme:dark;
  --bg:#141022; --bg2:#1C1530; --panel:#251B3F; --panel2:#2F2350;
  --line:rgba(179,136,232,.24); --line2:rgba(255,255,255,.09);
  --text:#F6F2FC; --text-dim:#D3C8EC; --text-faint:#A99BCB;
  --chip:#352859; --shadow:0 10px 34px rgba(0,0,0,.38);
  --tile:#191230; --topbar:rgba(20,16,34,.86);
}
[data-theme="light"]{
  color-scheme:light;
  --bg:#F5F2FA; --bg2:#FFFFFF; --panel:#FFFFFF; --panel2:#F8F4FE;
  --line:rgba(138,79,196,.18); --line2:rgba(20,10,40,.08);
  --text:#241A38; --text-dim:#564B72; --text-faint:#7C7090;
  --chip:#F0E9FA; --shadow:0 8px 26px rgba(94,45,145,.12);
  --tile:#1F1834; --topbar:rgba(255,255,255,.9);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:var(--font);background:var(--bg);color:var(--text);font-size:15px;line-height:1.45;
  -webkit-font-smoothing:antialiased}
button{font-family:inherit;cursor:pointer}
input,select,textarea{font-family:inherit;accent-color:var(--purple-bright)}
a{color:var(--purple-bright)}
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-thumb{background:var(--chip);border-radius:8px}
::-webkit-scrollbar-track{background:transparent}

/* ---------------- splash ---------------- */
.splash{position:fixed;inset:0;z-index:100;display:flex;align-items:center;justify-content:center;overflow:auto}
.splash-bg{position:absolute;inset:0;background:
  radial-gradient(1100px 600px at 78% -10%, rgba(255,198,55,.18), transparent 55%),
  radial-gradient(900px 700px at 12% 110%, rgba(179,136,232,.34), transparent 60%),
  linear-gradient(155deg,#27163F 0%,#3D1E6E 48%,#1C1232 100%)}
.splash-bg::after{content:"";position:absolute;inset:0;opacity:.5;
  background-image:radial-gradient(rgba(255,255,255,.05) 1px,transparent 1.5px);background-size:26px 26px}
.splash-card{position:relative;width:min(460px,92vw);background:rgba(38,24,66,.82);backdrop-filter:blur(14px);
  border:1px solid rgba(179,136,232,.42);border-radius:22px;padding:34px 36px 22px;text-align:center;
  box-shadow:0 30px 80px rgba(0,0,0,.5);animation:rise .5s ease both}
@keyframes rise{from{transform:translateY(14px);opacity:0}to{transform:none;opacity:1}}
.splash-logo{background:#fff;border-radius:14px;padding:14px 18px;display:inline-block;margin-bottom:18px}
.splash-logo img{width:200px;display:block}
.splash h1{margin:.1em 0 0;font-size:30px;font-weight:800;letter-spacing:.5px;color:#fff}
.splash-sub{margin:.4em 0 1.6em;color:#DCCFF5}
.code-label{display:block;font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:#C2ACE8;margin-bottom:12px}
.code-row{display:flex;gap:12px;justify-content:center}
.code-digit{width:58px;height:68px;font-size:30px;font-weight:800;text-align:center;border-radius:12px;
  border:2px solid rgba(179,136,232,.55);background:rgba(255,255,255,.08);color:#fff;outline:none;
  transition:border .15s, transform .1s}
.code-digit:focus{border-color:var(--gold);transform:translateY(-2px)}
.code-hint{color:#BCA9E2;font-size:12.5px;margin-top:14px}
.code-error{display:none;color:#FF8A8E;font-size:13px;margin-top:6px}
.splash-card.shake{animation:shake .4s}
@keyframes shake{20%{transform:translateX(-9px)}40%{transform:translateX(8px)}60%{transform:translateX(-6px)}80%{transform:translateX(5px)}}
.who-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;text-align:left}
.who-card{display:flex;gap:11px;align-items:center;padding:11px 12px;border-radius:13px;border:1px solid rgba(179,136,232,.38);
  background:rgba(255,255,255,.07);color:#fff;transition:.15s}
.who-card:hover{background:rgba(255,192,0,.13);border-color:var(--gold);transform:translateY(-2px)}
.who-card .avatar{width:40px;height:40px;flex:0 0 40px;font-size:14px}
.who-card b{display:block;font-size:14.5px}
.who-card .who-meta{display:block;font-size:11.5px;color:#D6C7F2}
.modal .who-card{background:var(--chip);color:var(--text);border-color:var(--line)}
.modal .who-card .who-meta{color:var(--text-faint)}
.who-card.kiosk{grid-column:1/-1;justify-content:center;background:rgba(255,192,0,.10)}
.splash-foot{margin-top:20px;font-size:11px;color:#AC99D6}

/* ---------------- shell ---------------- */
.app{display:flex;min-height:100vh}
.sidebar{width:236px;flex:0 0 236px;background:linear-gradient(180deg,var(--bg2),var(--bg));border-right:1px solid var(--line);
  display:flex;flex-direction:column;position:sticky;top:0;height:100vh;z-index:30}
.brand{display:flex;gap:10px;align-items:center;padding:18px 16px 14px;cursor:pointer}
.brand-mark{background:var(--purple);color:var(--gold-soft);font-weight:800;letter-spacing:.14em;font-size:15px;
  padding:9px 10px;border-radius:10px;box-shadow:0 4px 14px rgba(138,79,196,.45)}
.brand-text{line-height:1.15}
.brand-top{display:block;font-weight:800;letter-spacing:.12em;font-size:13px}
.brand-sub{display:block;font-size:10.5px;color:var(--text-faint)}
.nav{flex:1;overflow:auto;padding:6px 10px 10px}
.nav-section{font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--text-faint);margin:14px 8px 6px}
.nav-item{display:flex;align-items:center;gap:11px;width:100%;text-align:left;background:none;border:0;color:var(--text-dim);
  padding:9px 10px;border-radius:10px;font-size:14px;font-weight:600;margin-bottom:2px;position:relative}
.nav-item .ico{width:21px;text-align:center;font-size:16px}
.nav-item:hover{background:var(--chip);color:var(--text)}
.nav-item.active{background:linear-gradient(90deg,rgba(112,48,160,.35),rgba(112,48,160,.12));color:var(--text)}
.nav-item.active::before{content:"";position:absolute;left:-10px;top:8px;bottom:8px;width:3.5px;border-radius:4px;background:var(--gold)}
.nav-item .badge{margin-left:auto;background:var(--gold-soft);color:#2E2000;font-size:11px;font-weight:800;border-radius:8px;padding:1px 7px}
.sidebar-foot{padding:12px;border-top:1px solid var(--line2)}
.evac-btn{width:100%;background:rgba(255,90,95,.12);border:1.5px solid rgba(255,90,95,.55);color:#FF7A7E;
  font-weight:800;letter-spacing:.12em;font-size:12.5px;padding:10px;border-radius:11px;display:flex;gap:9px;align-items:center;justify-content:center}
.evac-btn:hover{background:rgba(255,90,95,.22)}
.evac-dot{width:9px;height:9px;border-radius:50%;background:var(--bad);animation:pulse 1.6s infinite}
@keyframes pulse{50%{opacity:.35}}
.peats-tag{display:flex;align-items:center;gap:8px;margin-top:12px;color:var(--text-faint);font-size:11px}
.peats-tag img{height:20px;border-radius:4px;background:#fff;padding:2px 5px}

.main{flex:1;min-width:0;display:flex;flex-direction:column}
.topbar{position:sticky;top:0;z-index:25;display:flex;align-items:center;gap:14px;padding:10px 18px;
  background:var(--topbar);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.burger{display:none}
.page-title{font-size:18px;font-weight:800;white-space:nowrap}
.top-search{flex:1;max-width:520px;position:relative}
.top-search input{width:100%;padding:9px 14px;border-radius:11px;border:1px solid var(--line);background:var(--chip);
  color:var(--text);outline:none;font-size:13.5px}
.top-search input:focus{border-color:var(--purple-bright)}
.search-results{display:none;position:absolute;top:44px;left:0;right:0;background:var(--panel);border:1px solid var(--line);
  border-radius:12px;box-shadow:var(--shadow);max-height:330px;overflow:auto;z-index:50}
.search-results.open{display:block}
.sr-item{display:flex;gap:10px;align-items:center;padding:9px 13px;cursor:pointer;font-size:13.5px}
.sr-item:hover{background:var(--chip)}
.sr-item .t{color:var(--text-faint);font-size:11px;margin-left:auto;white-space:nowrap}
.top-meta{margin-left:auto;display:flex;align-items:center;gap:10px}
.weather{font-size:13px;color:var(--text-dim);white-space:nowrap}
.clock{font-family:var(--mono);font-size:13.5px;color:var(--text-dim);white-space:nowrap}
.icon-btn{background:var(--chip);border:1px solid var(--line);color:var(--text-dim);width:34px;height:34px;
  border-radius:10px;font-size:15px;line-height:1}
.icon-btn:hover{color:var(--text);border-color:var(--purple-bright)}
.me{display:flex;align-items:center;gap:9px;background:var(--chip);border:1px solid var(--line);border-radius:11px;
  padding:4px 11px 4px 5px;cursor:pointer;font-weight:700;font-size:13px;white-space:nowrap}
.me:hover{border-color:var(--gold)}
.me .avatar{width:27px;height:27px;font-size:11px}

.live-strip{display:flex;gap:26px;overflow:hidden;white-space:nowrap;padding:7px 0;border-bottom:1px solid var(--line2);
  background:linear-gradient(90deg,rgba(112,48,160,.10),transparent 30%,transparent 70%,rgba(255,192,0,.06));
  font-size:12.5px;color:var(--text-dim)}
.live-strip .li{display:inline-flex;gap:7px;align-items:center;animation:ticker .4s ease}
.live-strip .li .dot{width:7px;height:7px;border-radius:50%}
@keyframes ticker{from{opacity:0;transform:translateY(8px)}to{opacity:1}}

.view{flex:1;padding:20px 22px 30px;max-width:1660px;width:100%;margin:0 auto}
.app-foot{display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;padding:14px 22px 20px;color:var(--text-faint);
  font-size:11.5px;border-top:1px solid var(--line2)}

/* ---------------- common bits ---------------- */
.avatar{display:inline-flex;align-items:center;justify-content:center;border-radius:50%;
  background:linear-gradient(135deg,var(--purple),var(--purple-bright));color:#fff;font-weight:800;font-size:13px;
  width:34px;height:34px;flex:0 0 auto;text-transform:uppercase}
.avatar.gold{background:linear-gradient(135deg,#E5B225,var(--gold-soft));color:#2E2000}
.grid{display:grid;gap:16px}
.cards-4{grid-template-columns:repeat(4,1fr)}
.cards-3{grid-template-columns:repeat(3,1fr)}
.cards-2{grid-template-columns:repeat(2,1fr)}
@media (max-width:1250px){.cards-4{grid-template-columns:repeat(2,1fr)}.cards-3{grid-template-columns:repeat(2,1fr)}}
@media (max-width:760px){.cards-4,.cards-3,.cards-2{grid-template-columns:1fr}}
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:16px 18px;box-shadow:var(--shadow);min-width:0}
.card.flat{box-shadow:none}
.card h3{margin:0 0 4px;font-size:14.5px;font-weight:800;display:flex;align-items:center;gap:8px}
.card h3 .ico{font-size:16px}
.card .sub{color:var(--text-faint);font-size:12px;margin-bottom:12px}
.kpi{font-size:30px;font-weight:800;line-height:1.05;font-variant-numeric:tabular-nums}
.kpi small{font-size:13px;font-weight:600;color:var(--text-faint);margin-left:5px}
.kpi-row{display:flex;align-items:flex-end;justify-content:space-between;gap:10px}
.trend{font-size:12px;font-weight:700}
.trend.up{color:var(--ok)} .trend.down{color:var(--bad)} .trend.flat{color:var(--text-faint)}
.pill{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-weight:700;border-radius:99px;padding:3px 10px;white-space:nowrap}
.pill .dot{width:7px;height:7px;border-radius:50%}
.pill.ok{background:rgba(43,213,118,.13);color:var(--ok)} .pill.ok .dot{background:var(--ok)}
.pill.warn{background:rgba(255,176,32,.14);color:var(--warn)} .pill.warn .dot{background:var(--warn)}
.pill.bad{background:rgba(255,90,95,.13);color:var(--bad)} .pill.bad .dot{background:var(--bad)}
.pill.info{background:rgba(76,195,255,.13);color:var(--info)} .pill.info .dot{background:var(--info)}
.pill.dim{background:var(--chip);color:var(--text-faint)} .pill.dim .dot{background:var(--text-faint)}
.btn{border:1px solid var(--line);background:var(--chip);color:var(--text);font-weight:700;font-size:13px;
  padding:8px 14px;border-radius:10px;transition:.13s}
.btn:hover{border-color:var(--purple-bright);transform:translateY(-1px)}
.btn.primary{background:linear-gradient(135deg,var(--purple),var(--purple-bright));border-color:transparent;color:#fff;
  box-shadow:0 6px 18px rgba(112,48,160,.4)}
.btn.gold{background:linear-gradient(135deg,#EDB920,var(--gold-soft));border-color:transparent;color:#2E2000}
.btn.danger{background:rgba(255,90,95,.14);border-color:rgba(255,90,95,.5);color:#FF7A7E}
.btn.small{padding:5px 10px;font-size:12px;border-radius:8px}
.btn:disabled{opacity:.45;cursor:default;transform:none}
.table{width:100%;border-collapse:collapse;font-size:13.5px}
.table th{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--text-faint);text-align:left;
  padding:7px 10px;border-bottom:1px solid var(--line)}
.table td{padding:9px 10px;border-bottom:1px solid var(--line2);vertical-align:middle}
.table tr:hover td{background:rgba(155,81,224,.05)}
.mono{font-family:var(--mono);font-size:12.5px}
.muted{color:var(--text-faint)} .dim{color:var(--text-dim)}
.right{text-align:right} .center{text-align:center}
.row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.row.between{justify-content:space-between}
.spacer{flex:1}
.section-head{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin:26px 0 12px}
.section-head h2{margin:0;font-size:17px;font-weight:800}
.section-head .sub{color:var(--text-faint);font-size:12.5px}
input.field,select.field,textarea.field{width:100%;padding:10px 12px;border-radius:10px;border:1px solid var(--line);
  background:var(--chip);color:var(--text);outline:none;font-size:14px}
input.field:focus,select.field:focus,textarea.field:focus{border-color:var(--purple-bright)}
label.lbl{display:block;font-size:11.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  color:var(--text-faint);margin:12px 0 5px}
.feed{list-style:none;margin:0;padding:0;max-height:330px;overflow:auto}
.feed li{display:flex;gap:10px;align-items:flex-start;padding:8px 2px;border-bottom:1px solid var(--line2);font-size:13px}
.feed .when{font-family:var(--mono);font-size:11.5px;color:var(--text-faint);white-space:nowrap;padding-top:2px;width:52px}
.feed .dot{width:8px;height:8px;border-radius:50%;margin-top:5px;flex:0 0 8px}
.note{background:rgba(255,192,0,.08);border:1px dashed rgba(255,192,0,.4);border-radius:11px;padding:10px 14px;
  font-size:12.5px;color:var(--text-dim)}
.banner{display:flex;gap:12px;align-items:center;background:linear-gradient(90deg,rgba(112,48,160,.25),rgba(255,192,0,.10));
  border:1px solid var(--line);border-radius:var(--radius);padding:12px 16px;margin-bottom:18px}
.banner .ico{font-size:20px}
.banner b{font-weight:800}
.progress{height:8px;border-radius:6px;background:var(--chip);overflow:hidden}
.progress>i{display:block;height:100%;border-radius:6px;background:linear-gradient(90deg,var(--purple-bright),var(--gold));transition:width .6s}
.donut-leg{display:flex;flex-direction:column;gap:7px;font-size:12.5px}
.donut-leg .sw{width:10px;height:10px;border-radius:3px;display:inline-block;margin-right:7px}
.spark{display:block}

/* ---------------- home ---------------- */
.hero{display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap;margin-bottom:18px}
.hero h1{margin:0;font-size:24px;font-weight:800}
.hero .sub{color:var(--text-dim);font-size:13.5px;margin-top:3px}
.applinks{display:grid;grid-template-columns:repeat(auto-fill,minmax(118px,1fr));gap:10px}
.applink{display:flex;flex-direction:column;gap:8px;align-items:flex-start;background:var(--panel2);border:1px solid var(--line);
  border-radius:12px;padding:12px;color:var(--text);text-decoration:none;font-weight:700;font-size:12.5px;transition:.14s}
.applink:hover{transform:translateY(-3px);border-color:var(--gold)}
.applink .ico{font-size:21px}
.applink .ext{color:var(--text-faint);font-weight:500;font-size:10.5px}

/* ---------------- camera wall ---------------- */
.wall-tools{display:flex;align-items:center;gap:9px;flex-wrap:wrap;margin-bottom:13px}
.seg{display:inline-flex;background:var(--chip);border:1px solid var(--line);border-radius:10px;overflow:hidden}
.seg button{background:none;border:0;color:var(--text-dim);font-weight:700;font-size:12.5px;padding:7px 12px}
.seg button.active{background:linear-gradient(135deg,var(--purple),var(--purple-bright));color:#fff}
.wall{display:grid;gap:10px}
.wall.g2{grid-template-columns:repeat(2,1fr)} .wall.g3{grid-template-columns:repeat(3,1fr)} .wall.g4{grid-template-columns:repeat(4,1fr)}
@media (max-width:900px){.wall.g3,.wall.g4{grid-template-columns:repeat(2,1fr)}}
@media (max-width:600px){.wall.g2,.wall.g3,.wall.g4{grid-template-columns:1fr}}
.cam{position:relative;background:var(--tile);border-radius:12px;overflow:hidden;aspect-ratio:16/9;border:1px solid var(--line2);
  cursor:grab}
.cam.dragging{opacity:.4}
.cam.dragover{outline:2.5px dashed var(--gold);outline-offset:-3px}
.cam video,.cam iframe{width:100%;height:100%;object-fit:cover;display:block;border:0;pointer-events:none;background:#000}
.cam .cam-top{position:absolute;top:0;left:0;right:0;display:flex;align-items:center;gap:8px;padding:8px 10px;
  background:linear-gradient(180deg,rgba(0,0,0,.62),transparent);color:#fff;font-size:12px;font-weight:700;z-index:3}
.cam .rec{display:inline-flex;align-items:center;gap:5px;font-family:var(--mono);font-size:10px;color:#FF6B6E;letter-spacing:.06em}
.cam .rec i{width:7px;height:7px;border-radius:50%;background:#FF4D52;animation:pulse 1.4s infinite}
.cam .nvr{margin-left:auto;background:rgba(255,255,255,.16);border-radius:6px;padding:1px 7px;font-size:10px;font-weight:700}
.cam .cam-bot{position:absolute;left:0;right:0;bottom:0;display:flex;align-items:center;gap:8px;padding:7px 10px;
  background:linear-gradient(0deg,rgba(0,0,0,.6),transparent);color:#D9CFEA;font-family:var(--mono);font-size:10.5px;z-index:3}
.cam .demo-badge{background:rgba(255,215,94,.92);color:#2E2000;font-weight:800;border-radius:5px;padding:0 6px;font-size:9.5px;font-family:var(--font)}
.cam .cam-x{position:absolute;top:7px;right:7px;z-index:4;background:rgba(0,0,0,.45);border:0;color:#fff;border-radius:7px;
  width:24px;height:24px;font-size:11px;display:none}
.cam:hover .cam-x{display:block}
.cam .nosig{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;
  color:#9D8FC2;background:repeating-linear-gradient(45deg,#130D22,#130D22 12px,#181129 12px,#181129 24px)}
.cam .nosig b{font-family:var(--mono);letter-spacing:.2em;font-size:13px;color:#C0B0E5}
.cam-add{display:flex;align-items:center;justify-content:center;border:2px dashed var(--line);border-radius:12px;aspect-ratio:16/9;
  color:var(--text-faint);font-weight:700;background:none;font-size:14px}
.cam-add:hover{border-color:var(--gold);color:var(--gold)}
.cam-expand{position:fixed;inset:0;z-index:90;background:rgba(8,5,14,.92);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center}
.cam-expand-inner{width:min(1280px,94vw)}
.cam-expand-head{display:flex;align-items:center;justify-content:space-between;color:#fff;font-weight:800;padding:0 2px 10px}
.cam-expand-body{background:#000;border-radius:14px;overflow:hidden;aspect-ratio:16/9;position:relative}
.cam-expand-body video,.cam-expand-body iframe{width:100%;height:100%;border:0;object-fit:contain;background:#000}

/* ---------------- gatehouse ---------------- */
.door{display:flex;align-items:center;gap:14px;padding:13px 4px;border-bottom:1px solid var(--line2)}
.door .ic{width:42px;height:42px;border-radius:11px;display:flex;align-items:center;justify-content:center;font-size:19px;
  background:var(--chip)}
.door b{font-size:14px}
.door .meta{font-size:11.5px;color:var(--text-faint)}
.door .acts{margin-left:auto;display:flex;gap:7px}
.lockmap{position:relative;background:var(--panel2);border-radius:12px;border:1px solid var(--line2);overflow:hidden}
.lockmap svg{display:block;width:100%;height:auto}

/* ---------------- who's on site ---------------- */
.bignum{font-size:46px;font-weight:800;line-height:1;font-variant-numeric:tabular-nums}
.persona-row{display:flex;align-items:center;gap:11px;padding:9px 4px;border-bottom:1px solid var(--line2)}
.persona-row b{font-size:14px}
.persona-row .meta{font-size:11.5px;color:var(--text-faint)}
.filters{display:flex;gap:8px;flex-wrap:wrap}
.fchip{background:var(--chip);border:1px solid var(--line);color:var(--text-dim);border-radius:99px;font-size:12px;
  font-weight:700;padding:5px 13px}
.fchip.active{background:linear-gradient(135deg,var(--purple),var(--purple-bright));color:#fff;border-color:transparent}

/* ---------------- kiosk ---------------- */
.kiosk-wrap{max-width:880px;margin:0 auto}
.kiosk-big{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
@media (max-width:760px){.kiosk-big{grid-template-columns:1fr}}
.kiosk-choice{background:var(--panel);border:1.5px solid var(--line);border-radius:18px;padding:26px 18px;text-align:center;transition:.15s}
.kiosk-choice:hover{border-color:var(--gold);transform:translateY(-4px)}
.kiosk-choice .ico{font-size:40px}
.kiosk-choice b{display:block;font-size:17px;margin-top:10px}
.kiosk-choice span{display:block;font-size:12px;color:var(--text-faint);margin-top:4px}
.badge-card{background:linear-gradient(150deg,#fff,#F3EDFB);color:#241A38;border-radius:16px;padding:18px;max-width:340px;margin:0 auto;
  box-shadow:0 18px 50px rgba(0,0,0,.4);border-top:14px solid var(--purple)}
.badge-card.ctr{border-top-color:var(--gold)} .badge-card.drv{border-top-color:var(--info)}
.badge-card .v{font-family:var(--mono);font-size:11px;color:#6B6080}
.badge-card h2{margin:6px 0 2px;font-size:22px}
.badge-card .small{font-size:12.5px;color:#5E5378}
.induct{list-style:none;padding:0;margin:0 0 14px}
.induct li{display:flex;gap:10px;padding:8px 0;border-bottom:1px dashed var(--line);font-size:13.5px}

/* ---------------- production ---------------- */
.gauge-wrap{display:flex;gap:18px;align-items:center}
.market-row{display:flex;gap:16px;align-items:center}
.chiller{display:flex;flex-direction:column;gap:4px;background:var(--panel2);border:1px solid var(--line2);border-radius:11px;
  padding:10px 12px;min-width:0}
.chiller b{font-size:12px;color:var(--text-dim);white-space:nowrap}
.chiller .t{font-size:21px;font-weight:800;font-variant-numeric:tabular-nums}
.chiller-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(108px,1fr));gap:9px}

/* ---------------- documents ---------------- */
.drive{display:flex;gap:13px;align-items:center;background:var(--panel);border:1px solid var(--line);border-radius:13px;
  padding:13px 15px;color:var(--text);text-decoration:none;transition:.14s;position:relative}
.drive:hover{transform:translateY(-2px);border-color:var(--purple-bright)}
.drive .letter{width:42px;height:42px;border-radius:10px;background:linear-gradient(135deg,var(--purple),var(--purple-bright));
  color:#fff;font-weight:800;font-size:17px;display:flex;align-items:center;justify-content:center;flex:0 0 42px}
.drive.locked .letter{background:var(--chip);color:var(--text-faint)}
.drive b{font-size:14px;display:block}
.drive .meta{font-size:11.5px;color:var(--text-faint)}
.drive .lock{margin-left:auto;font-size:15px}

/* ---------------- systems ---------------- */
.sysrow{display:flex;align-items:center;gap:12px;padding:9px 2px;border-bottom:1px solid var(--line2);font-size:13.5px}
.sysrow .nm{font-weight:700;min-width:150px}
.sysrow .ip{font-family:var(--mono);font-size:11.5px;color:var(--text-faint)}
.toggle{position:relative;width:40px;height:22px;border-radius:99px;background:var(--chip);border:1px solid var(--line);transition:.15s}
.toggle::after{content:"";position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:var(--text-faint);transition:.15s}
.toggle.on{background:rgba(43,213,118,.25);border-color:var(--ok)}
.toggle.on::after{left:20px;background:var(--ok)}

/* ---------------- trucks & logistics ---------------- */
.trucks-grid{display:grid;grid-template-columns:2fr 1fr;gap:16px;align-items:start}
@media (max-width:1100px){.trucks-grid{grid-template-columns:1fr}}
.map-canvas{height:min(68vh,640px);min-height:380px;border-radius:11px;overflow:hidden;background:var(--tile);position:relative}
.truckrow{border:1px solid transparent;border-radius:11px;padding:9px 8px;cursor:pointer}
.truckrow:hover{background:var(--chip)}
.truckrow.sel{border-color:var(--gold);background:rgba(255,198,55,.08)}

/* ---------------- modal & toast ---------------- */
.modal-wrap{position:fixed;inset:0;z-index:80;background:rgba(8,5,14,.7);backdrop-filter:blur(6px);display:flex;
  align-items:center;justify-content:center;padding:18px;overflow:auto}
.modal{background:var(--panel);border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow);
  width:min(560px,94vw);max-height:92vh;overflow:auto;padding:22px 24px;animation:rise .25s ease}
.modal h2{margin:0 0 4px;font-size:19px}
.modal .sub{color:var(--text-faint);font-size:12.5px;margin-bottom:14px}
.toasts{position:fixed;right:18px;bottom:18px;z-index:95;display:flex;flex-direction:column;gap:9px;max-width:360px}
.toast{display:flex;gap:11px;align-items:flex-start;background:var(--panel);border:1px solid var(--line);border-left:4px solid var(--purple-bright);
  border-radius:12px;padding:11px 14px;box-shadow:var(--shadow);font-size:13px;animation:rise .3s ease}
.toast.ok{border-left-color:var(--ok)} .toast.warn{border-left-color:var(--warn)} .toast.bad{border-left-color:var(--bad)}
.toast b{display:block;font-size:13px}
.toast span{color:var(--text-dim);font-size:12px}

/* ---------------- evacuation ---------------- */
.evac-overlay{position:fixed;inset:0;z-index:85;background:
  radial-gradient(1200px 500px at 50% -10%,rgba(255,90,95,.35),transparent),#170A0E;overflow:auto;padding:26px}
.evac-head{display:flex;align-items:center;gap:16px;flex-wrap:wrap;color:#fff;margin-bottom:18px}
.evac-head h1{margin:0;font-size:26px;letter-spacing:.08em}
.evac-head .timer{font-family:var(--mono);font-size:26px;color:#FFB3B5}
.evac-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:10px}
.evac-person{display:flex;gap:10px;align-items:center;background:rgba(255,255,255,.06);border:1px solid rgba(255,90,95,.35);
  border-radius:12px;padding:10px 13px;color:#fff;cursor:pointer;text-align:left}
.evac-person .meta{font-size:11px;color:#F2BFC2}
.evac-person.done{background:rgba(43,213,118,.13);border-color:rgba(43,213,118,.5)}
.evac-person.done .meta{color:#9BE8BC}
.evac-bar{height:12px;border-radius:8px;background:rgba(255,255,255,.12);overflow:hidden;flex:1;min-width:220px}
.evac-bar>i{display:block;height:100%;background:linear-gradient(90deg,#FF5A5F,#FFC000);transition:width .4s}

/* ---------------- print (muster list) ---------------- */
@media print{
  body *{visibility:hidden}
  #evacOverlay,#evacOverlay *{visibility:visible}
  #evacOverlay{position:absolute;inset:0;background:#fff;color:#000}
  .evac-person{color:#000;border-color:#999}
}

/* ---------------- responsive ---------------- */
@media (max-width:980px){
  .sidebar{position:fixed;left:-260px;transition:left .25s;box-shadow:0 0 60px rgba(0,0,0,.5)}
  .sidebar.open{left:0}
  .burger{display:block}
  .page-title{font-size:15px}
  .top-search{display:none}
  .weather{display:none}
}
.kbd{font-family:var(--mono);font-size:11px;background:var(--chip);border:1px solid var(--line);border-bottom-width:2.5px;
  border-radius:6px;padding:1px 6px}
.fade-in{animation:rise .35s ease both}
.hidden{display:none!important}
