:root{
  --bg:#070A14; --bg-2:#0B0F1D; --bg-grad-1:#0e1530; --bg-grad-2:#1a1226;
  --surface:rgba(255,255,255,.045); --surface-2:rgba(255,255,255,.07);
  --surface-solid:#10172A; --surface-solid-2:#141C33;
  --border:rgba(255,255,255,.085); --border-strong:rgba(255,255,255,.16);
  --text:#EEF1F8; --text-2:#C3CADC; --muted:#8089A0;
  --gold:#E6BD6E; --gold-2:#C99746; --gold-soft:rgba(230,189,110,.14);
  --blue:#5B8DEF; --teal:#3FD5C7; --emerald:#46D58C; --amber:#F5B544; --rose:#FF6470; --violet:#9C84F2;
  --good:#46D58C; --warn:#F5B544; --bad:#FF6470;
  --shadow:0 24px 60px -20px rgba(0,0,0,.7); --shadow-sm:0 8px 24px -12px rgba(0,0,0,.6);
  --ring:rgba(230,189,110,.5);
  --rail:74px; --side:248px; --top:70px;
  --r-lg:22px; --r-md:16px; --r-sm:11px;
}
html[data-theme="light"]{
  --bg:#EAEEF7; --bg-2:#F3F6FC; --bg-grad-1:#dfe7fb; --bg-grad-2:#f3ecfb;
  --surface:rgba(255,255,255,.72); --surface-2:rgba(255,255,255,.92);
  --surface-solid:#FFFFFF; --surface-solid-2:#F7F9FE;
  --border:rgba(15,23,42,.09); --border-strong:rgba(15,23,42,.16);
  --text:#101728; --text-2:#37415A; --muted:#697288;
  --gold:#B6862F; --gold-2:#9C7224; --gold-soft:rgba(182,134,47,.12);
  --shadow:0 24px 50px -24px rgba(30,41,80,.32); --shadow-sm:0 10px 26px -14px rgba(30,41,80,.28);
  --ring:rgba(182,134,47,.45);
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html,body{height:100%}
body{
  font-family:'Inter','IBM Plex Sans Arabic',system-ui,-apple-system,'Segoe UI',sans-serif;
  background:var(--bg); color:var(--text); overflow-x:hidden;
  -webkit-font-smoothing:antialiased; line-height:1.5;
  transition:background .5s ease,color .35s ease;
}
html[dir="rtl"] body{font-family:'IBM Plex Sans Arabic','Inter',system-ui,'Segoe UI',Tahoma,sans-serif}
.mono{font-family:'JetBrains Mono','IBM Plex Sans Arabic',ui-monospace,monospace;font-feature-settings:"tnum" 1}
.disp{font-family:'Sora','IBM Plex Sans Arabic',system-ui,sans-serif}
html[dir="rtl"] .disp{font-family:'IBM Plex Sans Arabic','Sora',sans-serif}
::-webkit-scrollbar{width:9px;height:9px}
::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:20px}
::-webkit-scrollbar-track{background:transparent}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
:focus-visible{outline:2px solid var(--ring);outline-offset:2px;border-radius:6px}

/* ambient background */
.aura{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.aura::before,.aura::after{content:"";position:absolute;width:60vw;height:60vw;border-radius:50%;filter:blur(110px);opacity:.5;transition:opacity .5s}
.aura::before{background:radial-gradient(circle,var(--bg-grad-1),transparent 70%);top:-22vw;inset-inline-start:-16vw;animation:float1 26s ease-in-out infinite}
.aura::after{background:radial-gradient(circle,var(--bg-grad-2),transparent 70%);bottom:-26vw;inset-inline-end:-18vw;animation:float2 30s ease-in-out infinite}
html[data-theme="light"] .aura::before,html[data-theme="light"] .aura::after{opacity:.8}
@keyframes float1{50%{transform:translate(8vw,6vw) scale(1.1)}}
@keyframes float2{50%{transform:translate(-7vw,-5vw) scale(1.08)}}

/* ============ shell ============ */
.shell{position:relative;z-index:1;min-height:100vh}

/* rail */
.rail{position:fixed;inset-block:0;inset-inline-start:0;width:var(--rail);z-index:60;
  display:flex;flex-direction:column;align-items:center;gap:6px;padding:18px 0;
  background:linear-gradient(var(--surface-solid),var(--surface-solid));
  border-inline-end:1px solid var(--border);backdrop-filter:blur(20px)}
html[data-theme="dark"] .rail{background:rgba(8,11,21,.7)}
.rail .logo{width:42px;height:42px;border-radius:13px;display:grid;place-items:center;color:#0b0f1d;
  background:linear-gradient(135deg,var(--gold),var(--gold-2));box-shadow:0 8px 22px -8px var(--gold);margin-bottom:14px;flex:0 0 auto}
.rail .logo svg{width:24px;height:24px}
.rail-btn{width:46px;height:46px;border-radius:14px;display:grid;place-items:center;color:var(--muted);
  position:relative;transition:.22s;flex:0 0 auto}
.rail-btn svg{width:21px;height:21px}
.rail-btn:hover{color:var(--text);background:var(--surface)}
.rail-btn.on{color:var(--gold);background:var(--gold-soft)}
.rail-btn.on::before{content:"";position:absolute;inset-inline-start:-18px;top:50%;transform:translateY(-50%);
  width:4px;height:24px;border-radius:4px;background:var(--gold)}
.rail-sp{flex:1}

/* topbar */
.top{position:fixed;inset-block-start:0;inset-inline-start:var(--rail);inset-inline-end:0;height:var(--top);z-index:55;
  display:flex;align-items:center;gap:16px;padding:0 26px;
  border-block-end:1px solid var(--border);backdrop-filter:blur(22px);
  background:color-mix(in srgb,var(--bg) 72%,transparent)}
.brand{display:flex;flex-direction:column;line-height:1.1}
.brand b{font-size:15px;letter-spacing:.3px;font-weight:700}
.brand span{font-size:10.5px;color:var(--muted);letter-spacing:1.6px;text-transform:uppercase;font-weight:600}
html[dir="rtl"] .brand span{letter-spacing:.4px}
.search{flex:1;max-width:440px;display:flex;align-items:center;gap:10px;height:42px;padding:0 16px;
  border-radius:13px;background:var(--surface);border:1px solid var(--border);color:var(--muted);transition:.2s}
.search:focus-within{border-color:var(--border-strong);background:var(--surface-2)}
.search svg{width:17px;height:17px;flex:0 0 auto}
.search input{flex:1;background:none;border:none;color:var(--text);font-size:13.5px;outline:none}
.search input::placeholder{color:var(--muted)}
.search kbd{font-size:10px;padding:3px 7px;border-radius:6px;background:var(--surface-2);border:1px solid var(--border);color:var(--muted);font-family:'JetBrains Mono',monospace}
.top-actions{display:flex;align-items:center;gap:9px;margin-inline-start:auto}
.tbtn{width:42px;height:42px;border-radius:13px;display:grid;place-items:center;color:var(--text-2);
  background:var(--surface);border:1px solid var(--border);transition:.2s;position:relative}
.tbtn:hover{color:var(--text);background:var(--surface-2);transform:translateY(-1px)}
.tbtn svg{width:19px;height:19px}
.tbtn .dot{position:absolute;top:9px;inset-inline-end:9px;width:8px;height:8px;border-radius:50%;background:var(--rose);border:2px solid var(--surface-solid)}
.lang{padding:0 14px;width:auto;gap:7px;font-weight:700;font-size:13px;letter-spacing:.5px}
.profile{display:flex;align-items:center;gap:10px;padding:5px 6px;border-radius:13px;background:var(--surface);border:1px solid var(--border)}
.avatar{width:34px;height:34px;border-radius:10px;background:linear-gradient(135deg,var(--gold),var(--violet));
  display:grid;place-items:center;color:#0b0f1d;font-weight:800;font-size:13px;flex:0 0 auto}
.profile .who{line-height:1.15}
.profile .who b{font-size:12.5px;display:block;font-weight:700}
.profile .who span{font-size:10.5px;color:var(--muted)}

/* main */
.main{margin-inline-start:var(--rail);padding:calc(var(--top) + 26px) 30px 40px;max-width:1640px}
.view{display:none;animation:rise .5s cubic-bezier(.2,.7,.2,1) both}
.view.active{display:block}
@keyframes rise{from{opacity:0;transform:translateY(14px)}}

/* page head */
.phead{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;flex-wrap:wrap;margin-bottom:24px}
.phead h1{font-size:30px;font-weight:800;letter-spacing:-.5px;line-height:1.1}
.phead h1 .g{background:linear-gradient(120deg,var(--gold),var(--gold-2));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.phead .sub{color:var(--muted);font-size:13.5px;margin-top:7px;display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.livepill{display:inline-flex;align-items:center;gap:7px;font-size:11.5px;font-weight:600;color:var(--good);
  background:color-mix(in srgb,var(--good) 14%,transparent);padding:5px 11px;border-radius:30px}
.livepill .pulse{width:7px;height:7px;border-radius:50%;background:var(--good);animation:pulse 1.8s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 color-mix(in srgb,var(--good) 60%,transparent)}70%{box-shadow:0 0 0 7px transparent}}
.cta{display:inline-flex;align-items:center;gap:10px;height:48px;padding:0 22px;border-radius:14px;font-weight:700;font-size:14px;
  color:#0b0f1d;background:linear-gradient(135deg,var(--gold),var(--gold-2));box-shadow:0 14px 30px -12px var(--gold);transition:.22s}
.cta:hover{transform:translateY(-2px);box-shadow:0 20px 40px -14px var(--gold)}
.cta svg{width:19px;height:19px}

/* card base */
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);
  backdrop-filter:blur(18px);box-shadow:var(--shadow-sm);position:relative;overflow:hidden}
.card.solid{background:var(--surface-solid)}
html[data-theme="dark"] .card{background:linear-gradient(160deg,rgba(255,255,255,.055),rgba(255,255,255,.02))}
.card-h{display:flex;align-items:center;justify-content:space-between;padding:18px 20px 0}
.card-h h3{font-size:14.5px;font-weight:700;letter-spacing:.2px}
.card-h .hint{font-size:11.5px;color:var(--muted)}
.seg{display:flex;gap:3px;background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:3px}
.seg button{font-size:11px;font-weight:600;color:var(--muted);padding:5px 11px;border-radius:7px;transition:.18s}
.seg button.on{color:var(--text);background:var(--surface-2)}

/* KPI grid */
.kgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:18px}
.kpi{padding:18px;border-radius:var(--r-md);background:var(--surface);border:1px solid var(--border);
  backdrop-filter:blur(16px);position:relative;overflow:hidden;transition:.25s;cursor:default}
html[data-theme="dark"] .kpi{background:linear-gradient(160deg,rgba(255,255,255,.05),rgba(255,255,255,.015))}
.kpi:hover{transform:translateY(-3px);border-color:var(--border-strong);box-shadow:var(--shadow)}
.kpi .ico{width:40px;height:40px;border-radius:12px;display:grid;place-items:center;margin-bottom:14px}
.kpi .ico svg{width:20px;height:20px}
.kpi .lab{font-size:12px;color:var(--muted);font-weight:600;letter-spacing:.2px}
.kpi .val{font-size:27px;font-weight:700;margin-top:4px;letter-spacing:-.5px}
.kpi .val small{font-size:13px;color:var(--muted);font-weight:600;margin-inline-start:3px}
.kpi .delta{display:inline-flex;align-items:center;gap:4px;font-size:11.5px;font-weight:700;margin-top:9px;
  padding:3px 8px;border-radius:20px}
.kpi .delta svg{width:12px;height:12px}
.delta.up{color:var(--good);background:color-mix(in srgb,var(--good) 13%,transparent)}
.delta.down{color:var(--bad);background:color-mix(in srgb,var(--bad) 13%,transparent)}
.delta.flat{color:var(--muted);background:var(--surface-2)}
.kpi .bar{position:absolute;inset-block-end:0;inset-inline-start:0;height:3px;width:100%;background:var(--accent,var(--gold));opacity:.65}
.tint-gold{--accent:var(--gold)} .tint-blue{--accent:var(--blue)} .tint-teal{--accent:var(--teal)}
.tint-emer{--accent:var(--emerald)} .tint-amber{--accent:var(--amber)} .tint-rose{--accent:var(--rose)} .tint-violet{--accent:var(--violet)}
.kpi .ico{background:color-mix(in srgb,var(--accent) 18%,transparent);color:var(--accent)}

/* command row */
.cmd{display:grid;grid-template-columns:1.05fr 1.55fr 1fr;gap:18px;margin-bottom:18px}

/* gauge */
.gauge-card{padding:20px;display:flex;flex-direction:column;align-items:center;text-align:center}
.gauge-wrap{position:relative;width:230px;height:230px;margin:6px 0 4px}
.gauge-wrap svg{transform:rotate(-90deg);width:100%;height:100%}
.gauge-center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}
.gauge-center .num{font-size:54px;font-weight:800;letter-spacing:-2px;line-height:1}
.gauge-center .of{font-size:12px;color:var(--muted);margin-top:2px}
.gauge-center .tag{margin-top:9px;font-size:11px;font-weight:700;letter-spacing:.5px;padding:4px 12px;border-radius:20px;
  color:var(--good);background:color-mix(in srgb,var(--good) 14%,transparent)}
.gscore-legend{display:flex;gap:18px;margin-top:8px}
.gscore-legend div{font-size:11px;color:var(--muted)}
.gscore-legend b{display:block;font-size:16px;color:var(--text);font-weight:700;margin-top:2px}

/* attendance pulse */
.pulse-card{padding:20px}
.attn-rings{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-top:16px}
.attn-ring{display:flex;align-items:center;gap:13px;padding:13px;border-radius:14px;background:var(--surface);border:1px solid var(--border)}
.ring-vis{width:50px;height:50px;flex:0 0 auto;position:relative}
.ring-vis svg{transform:rotate(-90deg)}
.ring-vis span{position:absolute;inset:0;display:grid;place-items:center;font-size:12px;font-weight:700}
.attn-ring .meta b{font-size:18px;font-weight:700;display:block}
.attn-ring .meta span{font-size:11px;color:var(--muted)}

/* alerts */
.alerts-card{padding:20px;display:flex;flex-direction:column}
.alert-item{display:flex;gap:12px;padding:13px 0;border-block-end:1px solid var(--border)}
.alert-item:last-child{border:none}
.alert-ico{width:36px;height:36px;border-radius:11px;flex:0 0 auto;display:grid;place-items:center}
.alert-ico svg{width:17px;height:17px}
.a-crit{background:color-mix(in srgb,var(--bad) 16%,transparent);color:var(--bad)}
.a-warn{background:color-mix(in srgb,var(--warn) 16%,transparent);color:var(--warn)}
.a-info{background:color-mix(in srgb,var(--blue) 16%,transparent);color:var(--blue)}
.alert-item .body b{font-size:13px;font-weight:600;display:block;line-height:1.35}
.alert-item .body span{font-size:11.5px;color:var(--muted)}
.alert-item .time{font-size:10.5px;color:var(--muted);margin-inline-start:auto;white-space:nowrap}

/* chart grid */
.cgrid{display:grid;grid-template-columns:1.6fr 1fr;gap:18px;margin-bottom:18px}
.chart-box{padding:20px}
.chart-canvas{position:relative;height:280px;margin-top:14px}
.chart-canvas.sm{height:240px}
.legend{display:flex;gap:16px;margin-top:6px;flex-wrap:wrap}
.legend i{display:inline-flex;align-items:center;gap:7px;font-size:12px;color:var(--text-2);font-style:normal}
.legend i b{width:11px;height:11px;border-radius:4px;display:inline-block}

/* feed grid */
.fgrid{display:grid;grid-template-columns:1.4fr 1fr;gap:18px}
.note-list{padding:8px 20px 12px;display:flex;flex-direction:column}
.note{display:flex;gap:13px;padding:15px 0;border-block-end:1px solid var(--border)}
.note:last-child{border:none}
.note-flag{width:4px;border-radius:4px;flex:0 0 auto}
.note .nbody{flex:1;min-width:0}
.note .ntop{display:flex;align-items:center;gap:9px;margin-bottom:5px;flex-wrap:wrap}
.tag{font-size:10.5px;font-weight:700;letter-spacing:.3px;padding:3px 9px;border-radius:20px}
.note h4{font-size:13.5px;font-weight:600}
.note p{font-size:12px;color:var(--muted);margin-top:3px}
.note .nmeta{display:flex;align-items:center;gap:14px;margin-top:9px;font-size:11px;color:var(--muted)}
.note .nmeta span{display:inline-flex;align-items:center;gap:5px}
.note .nmeta svg{width:13px;height:13px}
.badge{font-size:10px;font-weight:700;padding:3px 9px;border-radius:20px;text-transform:uppercase;letter-spacing:.4px}
.b-open{color:var(--amber);background:color-mix(in srgb,var(--amber) 15%,transparent)}
.b-prog{color:var(--blue);background:color-mix(in srgb,var(--blue) 15%,transparent)}
.b-done{color:var(--good);background:color-mix(in srgb,var(--good) 15%,transparent)}
.b-crit{color:var(--bad);background:color-mix(in srgb,var(--bad) 15%,transparent)}

/* outside-zone list */
.zone-list{padding:6px 20px 14px;display:flex;flex-direction:column}
.zrow{display:flex;align-items:center;gap:13px;padding:13px 0;border-block-end:1px solid var(--border)}
.zrow:last-child{border:none}
.zrow .av{width:38px;height:38px;border-radius:11px;display:grid;place-items:center;font-weight:700;font-size:13px;color:#0b0f1d;flex:0 0 auto}
.zrow .zb{flex:1;min-width:0}
.zrow .zb b{font-size:13px;font-weight:600;display:block}
.zrow .zb span{font-size:11.5px;color:var(--muted);display:inline-flex;align-items:center;gap:5px}
.zrow .zb span svg{width:12px;height:12px}
.zrow .reason{font-size:11px;font-weight:600;color:var(--teal);background:color-mix(in srgb,var(--teal) 13%,transparent);padding:4px 10px;border-radius:20px;white-space:nowrap}

/* table */
.tbl-wrap{padding:8px 0 4px;overflow-x:auto}
table{width:100%;border-collapse:collapse;min-width:600px}
th{font-size:11px;text-transform:uppercase;letter-spacing:.6px;color:var(--muted);font-weight:700;text-align:start;padding:13px 20px;border-block-end:1px solid var(--border)}
td{padding:14px 20px;font-size:13px;border-block-end:1px solid var(--border)}
tbody tr{transition:.15s}
tbody tr:hover{background:var(--surface)}
td .who2{display:flex;align-items:center;gap:11px}
td .av2{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;font-weight:700;font-size:12px;color:#0b0f1d;flex:0 0 auto}
td b{font-weight:600}
.plate{font-family:'JetBrains Mono',monospace;font-size:12px;font-weight:600;padding:4px 9px;border-radius:7px;background:var(--surface-2);border:1px solid var(--border)}

/* mini stat row for sub-views */
.srow{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:18px}
.stat{padding:20px;border-radius:var(--r-md);background:var(--surface);border:1px solid var(--border);backdrop-filter:blur(16px)}
html[data-theme="dark"] .stat{background:linear-gradient(160deg,rgba(255,255,255,.05),rgba(255,255,255,.015))}
.stat .lab{font-size:12px;color:var(--muted);font-weight:600}
.stat .val{font-size:26px;font-weight:700;margin-top:7px;letter-spacing:-.5px}

/* FAB */
.fab{position:fixed;inset-block-end:28px;inset-inline-end:28px;z-index:50}
.fab .main-fab{width:58px;height:58px;border-radius:19px;display:grid;place-items:center;color:#0b0f1d;
  background:linear-gradient(135deg,var(--gold),var(--gold-2));box-shadow:0 16px 36px -10px var(--gold);transition:.3s}
.fab .main-fab svg{width:26px;height:26px;transition:.3s}
.fab.open .main-fab svg{transform:rotate(135deg)}
.fab .menu{position:absolute;inset-block-end:70px;inset-inline-end:4px;display:flex;flex-direction:column;gap:11px;align-items:flex-end}
.fab .menu .fitem{display:flex;align-items:center;gap:11px;opacity:0;transform:translateY(14px) scale(.9);pointer-events:none;transition:.28s}
.fab.open .menu .fitem{opacity:1;transform:none;pointer-events:auto}
.fab.open .menu .fitem:nth-child(1){transition-delay:.04s}
.fab.open .menu .fitem:nth-child(2){transition-delay:.08s}
.fab.open .menu .fitem:nth-child(3){transition-delay:.12s}
.fitem .lbl{font-size:12px;font-weight:600;padding:6px 11px;border-radius:9px;background:var(--surface-solid);border:1px solid var(--border);box-shadow:var(--shadow-sm)}
.fitem .b{width:44px;height:44px;border-radius:14px;display:grid;place-items:center;background:var(--surface-solid);border:1px solid var(--border);color:var(--text-2);box-shadow:var(--shadow-sm);transition:.2s}
.fitem .b:hover{color:var(--gold);transform:scale(1.08)}
.fitem .b svg{width:19px;height:19px}

/* modal */
.modal{position:fixed;inset:0;z-index:200;display:none}
.modal.open{display:block}
.modal .scrim{position:absolute;inset:0;background:rgba(4,6,14,.72);backdrop-filter:blur(8px);animation:fade .3s}
@keyframes fade{from{opacity:0}}
.sheet{position:absolute;inset:24px;border-radius:26px;background:var(--bg-2);border:1px solid var(--border);
  box-shadow:var(--shadow);display:flex;flex-direction:column;overflow:hidden;animation:pop .4s cubic-bezier(.2,.8,.2,1)}
html[data-theme="dark"] .sheet{background:linear-gradient(180deg,#0c1222,#080b16)}
@keyframes pop{from{opacity:0;transform:scale(.97) translateY(10px)}}
.sheet-head{display:flex;align-items:center;gap:16px;padding:20px 28px;border-block-end:1px solid var(--border);flex:0 0 auto}
.sheet-head .si{width:46px;height:46px;border-radius:14px;display:grid;place-items:center;color:#0b0f1d;background:linear-gradient(135deg,var(--gold),var(--gold-2));flex:0 0 auto}
.sheet-head .si svg{width:24px;height:24px}
.sheet-head h2{font-size:21px;font-weight:800;letter-spacing:-.3px}
.sheet-head p{font-size:12.5px;color:var(--muted);margin-top:2px}
.sheet-head .x{margin-inline-start:auto;width:42px;height:42px;border-radius:13px;background:var(--surface);border:1px solid var(--border);display:grid;place-items:center;color:var(--text-2);transition:.2s}
.sheet-head .x:hover{color:var(--text);background:var(--surface-2)}
.sheet-head .x svg{width:19px;height:19px}
.sheet-body{flex:1;overflow-y:auto;padding:24px 28px;display:grid;grid-template-columns:340px 1fr;gap:26px;align-items:start}
.import-col h4,.fill-col h4{font-size:12px;text-transform:uppercase;letter-spacing:1px;color:var(--gold);font-weight:700;margin-bottom:14px;display:flex;align-items:center;gap:8px}
.import-col h4 svg,.fill-col h4 svg{width:15px;height:15px}
.imp-grid{display:grid;grid-template-columns:1fr 1fr;gap:11px}
.imp{padding:14px;border-radius:13px;background:var(--surface);border:1px solid var(--border)}
.imp .l{font-size:11px;color:var(--muted);font-weight:600}
.imp .v{font-size:21px;font-weight:700;margin-top:4px;letter-spacing:-.5px}
.imp.full{grid-column:1/-1}
.imp-list{margin-top:11px;display:flex;flex-direction:column;gap:8px}
.imp-list .il{display:flex;justify-content:space-between;align-items:center;font-size:12.5px;padding:9px 0;border-block-end:1px solid var(--border)}
.imp-list .il:last-child{border:none}
.imp-list .il span{color:var(--muted)}
.field{margin-bottom:16px}
.field label{display:block;font-size:12.5px;font-weight:600;margin-bottom:7px}
.field label .req{color:var(--rose)}
.field textarea,.field input,.field select{width:100%;background:var(--surface);border:1px solid var(--border);border-radius:12px;
  padding:12px 14px;color:var(--text);font-size:13.5px;font-family:inherit;resize:vertical;transition:.2s}
.field textarea{min-height:74px}
.field textarea:focus,.field input:focus,.field select:focus{outline:none;border-color:var(--gold);background:var(--surface-2)}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.eval{display:flex;gap:10px;margin-top:4px}
.eval button{flex:1;padding:12px;border-radius:12px;border:1px solid var(--border);background:var(--surface);font-weight:600;font-size:13px;color:var(--text-2);transition:.18s}
.eval button.on{border-color:var(--accent);color:var(--accent);background:color-mix(in srgb,var(--accent) 12%,transparent)}
.eval button[data-v="excellent"]{--accent:var(--good)} .eval button[data-v="good"]{--accent:var(--blue)}
.eval button[data-v="fair"]{--accent:var(--amber)} .eval button[data-v="poor"]{--accent:var(--rose)}
.sheet-foot{display:flex;align-items:center;gap:14px;padding:18px 28px;border-block-start:1px solid var(--border);flex:0 0 auto}
.sheet-foot .prog{flex:1;font-size:12px;color:var(--muted)}
.sheet-foot .prog .pbar{height:6px;border-radius:6px;background:var(--surface-2);margin-top:7px;overflow:hidden}
.sheet-foot .prog .pbar i{display:block;height:100%;border-radius:6px;background:linear-gradient(90deg,var(--gold),var(--gold-2));width:0;transition:.4s}
.btn-ghost{height:46px;padding:0 20px;border-radius:13px;background:var(--surface);border:1px solid var(--border);font-weight:600;font-size:13.5px;color:var(--text-2);transition:.2s}
.btn-ghost:hover{color:var(--text);background:var(--surface-2)}

/* toast */
.toasts{position:fixed;inset-block-start:84px;inset-inline-end:24px;z-index:300;display:flex;flex-direction:column;gap:10px}
.toast{display:flex;align-items:center;gap:12px;padding:14px 18px;border-radius:14px;background:var(--surface-solid);
  border:1px solid var(--border);box-shadow:var(--shadow);min-width:280px;animation:tin .35s cubic-bezier(.2,.8,.2,1)}
@keyframes tin{from{opacity:0;transform:translateX(20px)}}
html[dir="rtl"] .toast{animation:tinr .35s cubic-bezier(.2,.8,.2,1)}
@keyframes tinr{from{opacity:0;transform:translateX(-20px)}}
.toast.out{animation:tout .3s forwards}
@keyframes tout{to{opacity:0;transform:translateX(20px)}}
.toast .ti{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;flex:0 0 auto}
.toast .ti svg{width:18px;height:18px}
.toast b{font-size:13px;display:block}.toast span{font-size:11.5px;color:var(--muted)}
.t-ok .ti{background:color-mix(in srgb,var(--good) 16%,transparent);color:var(--good)}
.t-info .ti{background:color-mix(in srgb,var(--blue) 16%,transparent);color:var(--blue)}

/* mobile nav */
.mtoggle{display:none}
.mobnav{display:none}
.placeholder{padding:60px 20px;text-align:center;color:var(--muted)}
.placeholder svg{width:48px;height:48px;margin-bottom:14px;color:var(--gold);opacity:.7}
.placeholder h3{font-size:18px;color:var(--text);font-weight:700;margin-bottom:6px}

/* ===== responsive ===== */
@media(max-width:1180px){
  .cmd{grid-template-columns:1fr 1fr}
  .cmd .gauge-card{grid-column:1/-1}
  .cgrid,.fgrid{grid-template-columns:1fr}
  .sheet-body{grid-template-columns:1fr}
}
@media(max-width:920px){
  .kgrid{grid-template-columns:repeat(2,1fr)}
  .srow{grid-template-columns:repeat(2,1fr)}
  .cmd{grid-template-columns:1fr}
  .search{display:none}
}
@media(max-width:760px){
  :root{--rail:0px}
  .rail{transform:translateX(-100%)}
  html[dir="rtl"] .rail{transform:translateX(100%)}
  .rail.show{transform:none;box-shadow:var(--shadow)}
  .top{inset-inline-start:0;padding:0 16px;gap:10px}
  .main{padding:calc(var(--top) + 18px) 16px 90px}
  .mtoggle{display:grid}
  .brand{display:none}
  .phead h1{font-size:24px}
  .profile .who{display:none}
  .mobnav{display:flex;position:fixed;inset-block-end:0;inset-inline:0;z-index:60;height:64px;
    background:var(--surface-solid);border-block-start:1px solid var(--border);backdrop-filter:blur(20px);
    align-items:center;justify-content:space-around;padding:0 8px}
  html[data-theme="dark"] .mobnav{background:rgba(8,11,21,.92)}
  .mobnav button{display:flex;flex-direction:column;align-items:center;gap:3px;color:var(--muted);font-size:9.5px;font-weight:600}
  .mobnav button svg{width:21px;height:21px}
  .mobnav button.on{color:var(--gold)}
  .fab{inset-block-end:80px}
  .sheet{inset:0;border-radius:0}
  .toasts{inset-inline:12px;inset-block-start:78px}
  .toast{min-width:0;width:100%}
}
@media(max-width:460px){
  .kgrid,.srow{grid-template-columns:1fr 1fr;gap:11px}
  .kpi .val{font-size:23px}
}
@media(prefers-reduced-motion:reduce){*{animation-duration:.01ms!important;transition-duration:.01ms!important}}

/* ============ LOGIN PAGE ============ */
.login-wrap{min-height:100vh;display:grid;grid-template-columns:1.1fr 1fr;position:relative;z-index:1}
.login-art{position:relative;overflow:hidden;display:flex;flex-direction:column;justify-content:space-between;padding:48px;
  background:linear-gradient(150deg,var(--bg-grad-1),var(--bg-2) 60%,var(--bg-grad-2));border-inline-end:1px solid var(--border)}
.login-art .lbrand{display:flex;align-items:center;gap:13px;position:relative;z-index:2}
.login-art .lbrand .lg{width:48px;height:48px;border-radius:15px;display:grid;place-items:center;color:#0b0f1d;
  background:linear-gradient(135deg,var(--gold),var(--gold-2));box-shadow:0 10px 26px -8px var(--gold)}
.login-art .lbrand .lg svg{width:26px;height:26px}
.login-art .lbrand b{font-size:20px;font-weight:800;letter-spacing:.5px}
.login-art .lbrand span{font-size:11px;color:var(--muted);display:block;letter-spacing:1.4px;text-transform:uppercase}
html[dir="rtl"] .login-art .lbrand span{letter-spacing:.4px;text-transform:none}
.login-art .lhero{position:relative;z-index:2;max-width:440px}
.login-art .lhero h1{font-size:42px;font-weight:800;letter-spacing:-1px;line-height:1.08}
.login-art .lhero h1 .g{background:linear-gradient(120deg,var(--gold),var(--gold-2));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.login-art .lhero p{color:var(--text-2);font-size:15px;margin-top:16px;line-height:1.6}
.login-art .lstats{display:flex;gap:30px;margin-top:30px;position:relative;z-index:2}
.login-art .lstats div b{font-size:26px;font-weight:800;display:block;font-family:'JetBrains Mono',monospace}
.login-art .lstats div span{font-size:12px;color:var(--muted)}
.login-orb{position:absolute;border-radius:50%;filter:blur(80px);opacity:.5}
.login-orb.a{width:380px;height:380px;background:var(--gold);top:-80px;inset-inline-end:-100px;opacity:.18}
.login-orb.b{width:320px;height:320px;background:var(--violet);bottom:-60px;inset-inline-start:-80px;opacity:.16}

.login-form-side{display:flex;align-items:center;justify-content:center;padding:40px;background:var(--bg)}
.login-card{width:100%;max-width:400px}
.login-card h2{font-size:26px;font-weight:800;letter-spacing:-.5px}
.login-card .lsub{color:var(--muted);font-size:13.5px;margin:6px 0 26px}
.login-card .field{margin-bottom:16px}
.login-card label{display:block;font-size:12.5px;font-weight:600;margin-bottom:8px}
.login-card .inp{display:flex;align-items:center;gap:11px;background:var(--surface);border:1px solid var(--border);
  border-radius:13px;padding:0 15px;height:50px;transition:.2s}
.login-card .inp:focus-within{border-color:var(--gold);background:var(--surface-2)}
.login-card .inp svg{width:18px;height:18px;color:var(--muted);flex:0 0 auto}
.login-card .inp input{flex:1;background:none;border:none;outline:none;color:var(--text);font-size:14px;font-family:inherit}
.login-card .row{display:flex;align-items:center;justify-content:space-between;margin:4px 0 22px}
.login-card .row label{display:flex;align-items:center;gap:8px;font-weight:500;color:var(--text-2);margin:0;cursor:pointer}
.login-card .row input{accent-color:var(--gold);width:15px;height:15px}
.login-btn{width:100%;height:52px;border-radius:14px;font-weight:700;font-size:15px;color:#0b0f1d;
  background:linear-gradient(135deg,var(--gold),var(--gold-2));box-shadow:0 14px 30px -12px var(--gold);transition:.2s;
  display:flex;align-items:center;justify-content:center;gap:10px}
.login-btn:hover{transform:translateY(-2px)}
.login-btn svg{width:19px;height:19px}
.login-err{background:color-mix(in srgb,var(--bad) 13%,transparent);color:var(--bad);border:1px solid color-mix(in srgb,var(--bad) 30%,transparent);
  padding:12px 15px;border-radius:12px;font-size:13px;font-weight:600;margin-bottom:18px;display:flex;align-items:center;gap:9px}
.login-err svg{width:17px;height:17px;flex:0 0 auto}
.login-top{display:flex;justify-content:flex-end;gap:9px;margin-bottom:24px}
.demo-box{margin-top:26px;padding:16px;border-radius:14px;background:var(--surface);border:1px solid var(--border)}
.demo-box .dh{font-size:11px;text-transform:uppercase;letter-spacing:1px;color:var(--gold);font-weight:700;margin-bottom:11px}
.demo-row{display:flex;align-items:center;gap:10px;padding:7px 0;cursor:pointer;border-radius:9px;transition:.15s;font-size:12.5px}
.demo-row:hover{background:var(--surface-2);padding-inline:8px}
.demo-row .dr{width:30px;height:30px;border-radius:9px;display:grid;place-items:center;font-weight:700;font-size:11px;color:#0b0f1d;flex:0 0 auto}
.demo-row .dm{flex:1;min-width:0}
.demo-row .dm b{display:block;font-weight:600}
.demo-row .dm span{color:var(--muted);font-size:11px}
.demo-row .dpass{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--muted)}

/* ============ extra utility (settings/forms) ============ */
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.card-pad{padding:22px}
.card-pad h3{font-size:15px;font-weight:700;margin-bottom:4px}
.card-pad .ch{font-size:12.5px;color:var(--muted);margin-bottom:16px}
.frow{margin-bottom:14px}
.frow label{display:block;font-size:12.5px;font-weight:600;margin-bottom:7px}
.frow input,.frow select,.frow textarea{width:100%;background:var(--surface);border:1px solid var(--border);border-radius:11px;
  padding:11px 13px;color:var(--text);font-size:13.5px;font-family:inherit;transition:.2s}
.frow input:focus,.frow select:focus,.frow textarea:focus{outline:none;border-color:var(--gold);background:var(--surface-2)}
.frow textarea{min-height:80px;resize:vertical}
.frow .two{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.btn{height:46px;padding:0 20px;border-radius:13px;font-weight:700;font-size:13.5px;color:#0b0f1d;
  background:linear-gradient(135deg,var(--gold),var(--gold-2));display:inline-flex;align-items:center;gap:9px;transition:.2s}
.btn:hover{transform:translateY(-1px)}.btn svg{width:17px;height:17px}
.btn-soft{height:46px;padding:0 18px;border-radius:13px;background:var(--surface);border:1px solid var(--border);
  font-weight:600;font-size:13px;color:var(--text-2);display:inline-flex;align-items:center;gap:8px;transition:.2s}
.btn-soft:hover{color:var(--text);background:var(--surface-2)}
.role-pill{font-size:11px;font-weight:700;padding:4px 11px;border-radius:20px;background:var(--gold-soft);color:var(--gold)}
.flash{position:fixed;inset-block-start:84px;inset-inline:0;margin:auto;z-index:120;width:max-content;max-width:90%;
  background:var(--surface-solid);border:1px solid var(--border);box-shadow:var(--shadow);border-radius:13px;
  padding:13px 20px;font-size:13.5px;font-weight:600;display:flex;align-items:center;gap:10px;animation:tin .4s}
.flash svg{width:18px;height:18px;color:var(--gold)}
.empty-row td{text-align:center;color:var(--muted);padding:30px}
.dot-method{width:8px;height:8px;border-radius:50%;display:inline-block}
@media(max-width:980px){.login-wrap{grid-template-columns:1fr}.login-art{display:none}.grid2,.grid3{grid-template-columns:1fr}}

/* ---- user cell in tables ---- */
.ucell{display:flex;align-items:center;gap:11px}
.ucell .av.sm{width:34px;height:34px;border-radius:10px;font-size:12px;flex:0 0 auto}
.ucell b{display:block;font-weight:600;font-size:13.5px}
.ucell span{font-size:11.5px;color:var(--muted)}
.muted{color:var(--muted)}
td .muted{font-size:12.5px}
/* ---- report cards ---- */
.report-card{display:flex;flex-direction:column;align-items:flex-start;gap:4px}
.report-card h3{margin-top:6px}
.report-card .ch{flex:1;margin-bottom:14px}
.rc-ico{width:46px;height:46px;border-radius:14px;display:grid;place-items:center;margin-bottom:8px}
.rc-ico svg{width:23px;height:23px}

/* ---- inline row actions (CRUD) ---- */
.icon-btn{width:32px;height:32px;border-radius:9px;display:inline-grid;place-items:center;background:var(--surface);
  border:1px solid var(--border);color:var(--text-2);cursor:pointer;transition:.15s;vertical-align:middle}
.icon-btn svg{width:15px;height:15px}
.icon-btn:hover{background:var(--surface-2);color:var(--text)}
.icon-btn.del:hover{background:color-mix(in srgb,var(--bad) 16%,transparent);color:var(--bad);border-color:color-mix(in srgb,var(--bad) 35%,transparent)}
.row-actions{display:flex;gap:6px;align-items:center}
.row-actions form{display:inline}
.mini-select{height:32px;border-radius:9px;background:var(--surface);border:1px solid var(--border);color:var(--text-2);
  font-size:12px;font-family:inherit;padding:0 8px;cursor:pointer}
.mini-select:focus{outline:none;border-color:var(--gold)}

/* ---- avatars (uploaded photos) ---- */
.avimg{padding:0!important;overflow:hidden}
.avimg img{width:100%;height:100%;object-fit:cover;display:block}
.avatar.lg{width:54px;height:54px;border-radius:15px;font-size:18px}
.avatar.xl{width:84px;height:84px;border-radius:20px;font-size:26px}
.avatar.xl svg{width:34px;height:34px;color:var(--muted)}

/* ---- login extras ---- */
.lfoot-note{display:flex;align-items:center;gap:9px;color:var(--muted);font-size:12.5px}
.lfoot-note svg{width:16px;height:16px;color:var(--gold)}
.login-hint{display:flex;align-items:center;gap:8px;margin-top:18px;color:var(--muted);font-size:12px;line-height:1.5}
.login-hint svg{width:16px;height:16px;flex:0 0 auto;color:var(--gold)}

/* ---- mandatory check-in gate ---- */
.gate-wrap{min-height:100vh;display:grid;place-items:center;padding:24px;position:relative;z-index:1}
.gate-card{width:100%;max-width:560px;background:var(--card);border:1px solid var(--border);border-radius:24px;padding:28px;box-shadow:var(--shadow)}
.gate-head{display:flex;align-items:center;gap:15px;margin-bottom:18px}
.gate-head h2{font-family:'Sora',sans-serif;font-size:21px;font-weight:700}
.gate-head p{color:var(--muted);font-size:13px;margin-top:3px}
.gate-map{width:100%;height:280px;border-radius:16px;overflow:hidden;border:1px solid var(--border);z-index:1}
.gate-status{display:flex;align-items:center;gap:11px;margin:16px 0;padding:13px 16px;border-radius:13px;
  background:var(--surface);border:1px solid var(--border);font-size:14px;font-weight:500}
.gate-status .gs-ico{width:22px;height:22px;flex:0 0 auto;color:var(--muted)}
.gate-status .gs-ico svg{width:22px;height:22px}
.gate-status.good{background:color-mix(in srgb,var(--good) 12%,transparent);border-color:color-mix(in srgb,var(--good) 35%,transparent);color:var(--good)}
.gate-status.bad{background:color-mix(in srgb,var(--bad) 12%,transparent);border-color:color-mix(in srgb,var(--bad) 35%,transparent);color:var(--bad)}
.gate-actions{display:flex;gap:10px;margin-top:12px}
.gate-actions .btn-soft{flex:1;justify-content:center}

/* ---- settings: user form / switch / zone add ---- */
.userform-grid{display:flex;gap:22px;align-items:flex-start;flex-wrap:wrap;margin-bottom:6px}
.avatar-pick{display:flex;flex-direction:column;align-items:center;gap:10px;flex:0 0 auto}
.avatar-prev{width:84px;height:84px;border-radius:20px;background:var(--surface);border:1px dashed var(--border);display:grid;place-items:center;overflow:hidden}
.avatar-prev svg{width:34px;height:34px;color:var(--muted)}
.switch-row{display:flex;align-items:center;gap:10px;margin:6px 0 14px;font-size:13.5px;cursor:pointer}
.switch-row input{width:18px;height:18px;accent-color:var(--gold)}
.zone-add{display:flex;gap:8px;flex-wrap:wrap;margin:12px 0}
.zone-add input{flex:1;min-width:90px;height:40px;border-radius:10px;background:var(--surface);border:1px solid var(--border);color:var(--text);padding:0 12px;font-family:inherit;font-size:13px}
.zone-add input:focus{outline:none;border-color:var(--gold)}
.zone-add .btn{flex:0 0 auto}
/* leaflet dark tweak */
.leaflet-container{background:var(--surface);font-family:inherit}
