: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 a{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;color:var(--muted);font-size:10px;font-weight:600;text-decoration:none;min-width:0;height:100%}
  .mobnav a span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}
  .mobnav a svg{width:22px;height:22px;flex:0 0 auto}
  .mobnav a.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}

/* ============ Phase 5: check-in hero, closings, notifications ============ */
/* icon consistency: any inline svg defaults to a sane size unless a rule sets it */
.main svg, .top svg { vertical-align: middle; }

/* check-in / check-out hero */
.checkcard{background:var(--card);border:1px solid var(--border);border-radius:20px;padding:20px 22px;margin-bottom:20px;
  display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;box-shadow:var(--shadow)}
.cc-info{display:flex;align-items:center;gap:15px}
.cc-state{display:flex;align-items:center;gap:9px;font-weight:700;font-size:15px;margin-bottom:7px}
.cc-times{display:flex;gap:16px;flex-wrap:wrap;font-size:12.5px;color:var(--muted)}
.cc-times b{color:var(--text)}
.cc-action{display:flex;flex-direction:column;align-items:flex-end;gap:9px}
.cc-status{font-size:12.5px;font-weight:600;min-height:16px;color:var(--muted)}
.cc-status.good{color:var(--good)} .cc-status.bad{color:var(--bad)}
.dotpulse{width:10px;height:10px;border-radius:50%;flex:0 0 auto}
.dotpulse.on{background:var(--good);box-shadow:0 0 0 4px color-mix(in srgb,var(--good) 22%,transparent)}
.dotpulse.off{background:var(--amber);box-shadow:0 0 0 4px color-mix(in srgb,var(--amber) 22%,transparent)}
.dotpulse.done{background:var(--muted)}
.bigbtn{display:inline-flex;align-items:center;gap:10px;border:none;cursor:pointer;font-family:inherit;font-weight:800;
  font-size:15px;padding:14px 26px;border-radius:14px;color:#0b0f1d;transition:.2s}
.bigbtn svg{width:20px;height:20px}
.bigbtn.in{background:linear-gradient(135deg,#34d399,#10b981)}
.bigbtn.out{background:linear-gradient(135deg,#fbbf24,#f59e0b)}
.bigbtn.done{background:var(--surface);color:var(--good);border:1px solid var(--border);cursor:default}
.bigbtn:hover:not(.done){transform:translateY(-1px);filter:brightness(1.05)}
.bigbtn:disabled{opacity:.6;cursor:wait}

/* daily closing question grid */
.qgrid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px 18px;margin-bottom:8px}
.qitem label{font-size:12.5px;color:var(--text-2);margin-bottom:5px;display:block}
@media(max-width:640px){.qgrid{grid-template-columns:1fr}}

/* notifications */
.notif-wrap{position:relative}
.notif-badge{position:absolute;top:6px;inset-inline-end:6px;min-width:16px;height:16px;padding:0 4px;border-radius:9px;
  background:var(--rose);color:#fff;font-size:10px;font-weight:800;display:grid;place-items:center;border:2px solid var(--surface-solid)}
.notif-panel{position:absolute;inset-inline-end:0;top:48px;width:330px;max-width:88vw;background:var(--surface-solid);
  border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow);z-index:60;overflow:hidden}
.notif-head{display:flex;align-items:center;justify-content:space-between;padding:13px 16px;border-bottom:1px solid var(--border)}
.linkbtn{background:none;border:none;color:var(--gold);font-family:inherit;font-size:12px;font-weight:700;cursor:pointer}
.notif-list{max-height:360px;overflow:auto}
.notif-item{display:flex;gap:10px;padding:12px 16px;border-bottom:1px solid var(--border)}
.notif-item .ni-dot{width:8px;height:8px;border-radius:50%;background:transparent;margin-top:6px;flex:0 0 auto}
.notif-item.unread{background:color-mix(in srgb,var(--gold) 6%,transparent)}
.notif-item.unread .ni-dot{background:var(--gold)}
.ni-body b{font-size:13px;display:block}.ni-body p{font-size:12px;color:var(--muted);margin:2px 0 0}
.ni-time{font-size:11px;color:var(--muted);margin-top:3px;display:block}
.notif-empty{padding:24px;text-align:center;color:var(--muted);font-size:13px}

/* manager metrics */
.metric-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px}
.metric{background:var(--surface);border:1px solid var(--border);border-radius:13px;padding:14px 16px}
.metric .mlab{font-size:12px;color:var(--muted);margin-bottom:6px;min-height:32px}
.metric .mval{font-size:24px;font-weight:800;color:var(--gold);font-family:'Sora',sans-serif}
.metric .msub{font-size:11px;color:var(--muted);margin-top:3px}

/* closing feed */
.closing-feed{display:flex;flex-direction:column;gap:14px}
.closing-entry .ce-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:13px;flex-wrap:wrap;gap:8px}
.ans-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:8px;margin-bottom:12px}
.ans{background:var(--surface);border:1px solid var(--border);border-radius:11px;padding:9px 12px}
.ans .a-q{font-size:11.5px;color:var(--muted);margin-bottom:3px}
.ans .a-v{font-size:16px;font-weight:800;color:var(--text)}
.ce-text > div{margin-bottom:8px}
.ce-text .cl{font-size:12px;font-weight:700;color:var(--text-2);display:block;margin-bottom:2px}
.ce-text p{font-size:13px;color:var(--text);white-space:pre-line}
.chiptag{background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:5px 13px;font-size:12.5px;color:var(--text-2)}
.qcat-h{font-weight:700;font-size:13px;color:var(--gold);margin:16px 0 6px;padding-inline-start:8px;border-inline-start:3px solid var(--gold)}
.row-off{opacity:.5}
.badge.ok{background:color-mix(in srgb,var(--good) 16%,transparent);color:var(--good)}
.btn-soft.sm{padding:7px 12px;font-size:12.5px}
.btn-soft.sm svg{width:14px;height:14px}

/* ============ Mobile polish + notifications + PWA ============ */
/* notifications: clean dropdown on desktop, anchored sheet on mobile */
.notif-panel{position:absolute;inset-inline-end:0;top:52px;width:340px;max-width:92vw}
@media(max-width:760px){
  .notif-panel{position:fixed;top:64px;inset-inline:10px;width:auto;max-width:none}
  .notif-list{max-height:60vh}
  /* leave room for bottom nav */
  .main{padding-bottom:84px}
}
/* icon safety: inline action icons never balloon */
.mobnav svg,.fab svg,.notif-item svg{max-width:24px;max-height:24px}

/* mobile login brand (shown only when the art column is hidden) */
.login-mbrand{display:none}
@media(max-width:980px){
  .login-mbrand{display:flex;align-items:center;gap:12px;margin-bottom:26px}
  .login-mbrand .lg{width:46px;height:46px;border-radius:14px;display:grid;place-items:center;color:#0b0f1d;
    background:linear-gradient(135deg,var(--gold),#e0b552);flex:0 0 auto}
  .login-mbrand .lg svg{width:24px;height:24px}
  .login-mbrand b{font-size:19px;font-weight:800;display:block;line-height:1.1}
  .login-mbrand span{font-size:10.5px;color:var(--muted);letter-spacing:1px;text-transform:uppercase}
  .login-card{padding:30px 22px!important}
  .login-side{align-items:flex-start!important;padding:24px 18px!important}
}
@media(max-width:460px){
  .login-card h2{font-size:30px!important}
}

/* ============ Cross-browser icon safety (Safari/iOS fix) ============
   Safari gives inline <svg> with viewBox but no width/height the full
   container size → giant icons. :where() = zero specificity, so every
   existing .x svg rule (and chart svgs at width:100%) overrides this. */
svg:where(:not([width])){width:20px;height:20px;flex:0 0 auto}

/* ============ Mobile side drawer (reliable, direction-safe) ============ */
@media(max-width:760px){
  /* hidden by default via display (no transform sliver possible) */
  .rail{display:none!important;transform:none!important;visibility:visible!important}
  .rail.show{display:flex!important;position:fixed!important;inset-block:0;inset-inline-start:0;
    width:76vw;max-width:288px;z-index:200;padding:18px 12px;overflow-y:auto;
    background:var(--surface-solid)!important;border-inline-end:1px solid var(--border);
    box-shadow:0 0 0 100vmax rgba(2,4,10,.6), 0 10px 50px rgba(0,0,0,.6)}     /* solid panel + dim backdrop */
  .rail.show .rail-btn{width:100%;flex-direction:row;align-items:center;justify-content:flex-start;gap:14px;padding:11px 14px;border-radius:12px;height:auto}
  .rail.show .rail-btn::after{content:attr(data-label);font-size:13px;font-weight:600}
}

/* ============ Note dialog / reply thread ============ */
.modal-overlay{position:fixed;inset:0;z-index:300;display:flex;align-items:center;justify-content:center;
  padding:20px;background:rgba(2,4,10,.62);backdrop-filter:blur(3px)}
.modal-card{width:100%;max-width:620px;max-height:88vh;display:flex;flex-direction:column;
  background:var(--surface-solid);border:1px solid var(--border);border-radius:18px;box-shadow:0 30px 80px rgba(0,0,0,.5);overflow:hidden}
.modal-head{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:14px 18px;border-bottom:1px solid var(--border)}
.modal-body{padding:18px;overflow-y:auto}
.modal-foot{display:flex;align-items:center;gap:8px;flex-wrap:wrap;padding:13px 18px;border-top:1px solid var(--border);background:color-mix(in srgb,var(--surface) 60%,transparent)}
.msg-body{font-size:14px;line-height:1.75;color:var(--text);background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:12px 14px;margin:0 0 14px}
.thread{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}
.reply{display:flex;gap:10px;align-items:flex-start}
.reply.mine{flex-direction:row-reverse}
.reply .rb{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:9px 12px;max-width:80%}
.reply.mine .rb{background:color-mix(in srgb,var(--gold) 14%,var(--surface));border-color:color-mix(in srgb,var(--gold) 30%,var(--border))}
.reply .rh{display:flex;gap:8px;align-items:baseline;margin-bottom:3px}
.reply .rh b{font-size:12.5px}.reply .rh span{font-size:10.5px;color:var(--muted)}
.reply .rb p{margin:0;font-size:13.5px;line-height:1.6;color:var(--text)}
.reply-form{display:flex;gap:8px;align-items:flex-end}
.reply-form textarea{flex:1;margin:0}
.avatar.sm{width:30px;height:30px;font-size:11px;flex:0 0 auto}
.btn-soft.sm{padding:6px 12px;font-size:12px}
.btn-soft.on{background:var(--gold);color:#0b0f1d;border-color:var(--gold);font-weight:800}
@media(max-width:600px){ .modal-card{max-width:100%;max-height:92vh} .reply .rb{max-width:88%} }

/* ownership credit */
.login-credit{margin-top:12px;font-size:11.5px;letter-spacing:.5px;color:var(--muted);opacity:.85}
.login-credit.form{text-align:center;margin-top:8px}
.app-credit{text-align:center;padding:14px;font-size:11px;color:var(--muted);opacity:.7;letter-spacing:.4px}

/* account info rows */
.krow{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:11px 0;border-top:1px solid var(--line2);font-size:13.5px}
.krow:first-of-type{border-top:none}
.krow .muted{font-size:12.5px}

/* On-Leave / Day-Off status badge (distinct from present/absent) */
.badge.b-leave{color:#b9a3f5;background:color-mix(in srgb,#8b6df0 18%,transparent);border-color:color-mix(in srgb,#8b6df0 34%,transparent)}

/* role permission matrix */
.perm-tbl th{font-size:11px;letter-spacing:.04em;white-space:nowrap;padding:8px 10px}
.perm-tbl td{padding:9px 10px;border-top:1px solid var(--line2)}
.perm-tbl input[type=checkbox]{width:17px;height:17px;accent-color:var(--gold);cursor:pointer}

/* notifications dropdown footer + page unread row */
.notif-foot{display:block;text-align:center;padding:11px;font-size:12.5px;font-weight:700;color:var(--gold);
  text-decoration:none;border-top:1px solid var(--border)}
.notif-foot:hover{background:rgba(217,180,90,.06)}
.note.unread-row{background:rgba(217,180,90,.05)}

/* email settings switches + task filter tabs */
.switch-row{display:flex;align-items:center;gap:10px;padding:9px 0;font-size:13.5px;cursor:pointer}
.switch-row input[type=checkbox]{width:18px;height:18px;accent-color:var(--gold);cursor:pointer}
.tabs{display:flex;gap:8px;flex-wrap:wrap}
.tabs .tab{padding:8px 15px;border-radius:10px;border:1px solid var(--border);background:var(--surface);
  color:var(--muted);font-size:13px;font-weight:600;text-decoration:none}
.tabs .tab.on{background:var(--gold);color:#0b0f1d;border-color:var(--gold)}
.tabs .tab .mono{opacity:.7}

/* report-recipient chips */
.recip-chips{display:flex;flex-wrap:wrap;gap:7px;margin-top:10px;align-items:center}
.recip-count{font-size:11px;font-weight:800;color:#0b0f1d;background:var(--gold);border-radius:20px;padding:2px 9px}
.recip-chip{font-size:12px;padding:4px 11px;border-radius:20px;border:1px solid var(--border);background:var(--surface);color:var(--text)}
.recip-chip.bad{color:var(--rose);border-color:color-mix(in srgb,var(--rose) 40%,transparent)}

/* financial details / attachments */
.row-click{cursor:pointer}
.row-click:hover{background:rgba(217,180,90,.05)}
.rowlink{color:inherit;text-decoration:none}
.kv-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px 20px;margin-top:6px}
.kv-grid>div{display:flex;flex-direction:column;gap:2px;border-bottom:1px dashed var(--border);padding:7px 0}
.kv-grid span{font-size:11.5px;color:var(--muted)}
.kv-grid b{font-size:13.5px;color:var(--text)}
.att-block{margin-top:16px;border-top:1px solid var(--border);padding-top:14px}
.att-head{font-size:12.5px;font-weight:700;color:var(--muted);letter-spacing:.03em;margin-bottom:10px;text-transform:uppercase}
.att-list{display:flex;flex-direction:column;gap:8px}
.att-item{display:flex;align-items:center;gap:8px;justify-content:space-between;background:var(--surface);border:1px solid var(--border);border-radius:9px;padding:7px 11px}
.att-link{display:flex;align-items:center;gap:9px;color:var(--text);text-decoration:none;font-size:13px;min-width:0}
.att-link svg{width:18px;height:18px;color:var(--gold);flex:none}
.att-link span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.att-add{display:flex;gap:10px;align-items:center;margin-top:12px;flex-wrap:wrap}
.att-add input[type=file]{font-size:12.5px}
.edit-block{margin-top:16px;border-top:1px solid var(--border);padding-top:14px}
.btn-soft.sm.on{background:var(--gold);color:#0b0f1d;border-color:var(--gold)}

/* clickable dashboard cards + alerts */
a.kpi{text-decoration:none;color:inherit;cursor:pointer;transition:transform .12s,box-shadow .12s}
a.kpi:hover{transform:translateY(-2px);box-shadow:0 10px 26px rgba(0,0,0,.28)}
a.alert-link{text-decoration:none;color:inherit;cursor:pointer;border-radius:10px;transition:background .12s}
a.alert-link:hover{background:rgba(217,180,90,.06)}

/* finance date filter bar */
.filter-bar{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin:0 0 16px;padding:12px 14px;background:var(--surface);border:1px solid var(--border);border-radius:12px}
.fb-presets{display:flex;gap:8px;flex-wrap:wrap}
.chip{display:inline-flex;align-items:center;padding:6px 13px;border-radius:20px;font-size:12.5px;font-weight:600;background:var(--surface-2);color:var(--text-2);text-decoration:none;border:1px solid transparent;transition:all .12s}
.chip:hover{border-color:var(--gold)}
.chip.on{background:var(--gold);color:#0b0f1d}
.fb-range{display:flex;align-items:center;gap:8px}
.fb-range input[type=date]{padding:6px 10px;font-size:12.5px}
.fb-sep{color:var(--muted)}
.fb-label{margin-inline-start:auto;font-size:12.5px;color:var(--muted);font-weight:600}

/* ---------- Employees section ---------- */
.av.lg{width:52px;height:52px;font-size:16px;border-radius:14px}
.av.prof{width:92px;height:92px;font-size:30px;border-radius:22px}
.avlogo{background:var(--surface-2);border:1px solid var(--border)}
.avlogo img{width:100%;height:100%;object-fit:contain;padding:18%;box-sizing:border-box}
.emp-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px}
.emp-card{display:flex;align-items:center;gap:13px;padding:14px 16px;background:var(--surface);border:1px solid var(--border);border-radius:16px;text-decoration:none;color:inherit;transition:transform .12s,border-color .12s,box-shadow .12s}
.emp-card:hover{transform:translateY(-2px);border-color:var(--gold);box-shadow:0 10px 26px rgba(0,0,0,.26)}
.emp-card-b{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1}
.emp-card-b b{font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.emp-card .sm{font-size:11.5px}
.emp-id{display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.eid-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px 26px}
.eid-grid .k{display:block;font-size:11px;color:var(--muted);margin-bottom:3px}
.eid-grid b{font-size:13.5px}
.prof-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:880px){.prof-grid{grid-template-columns:1fr}}
.mini-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:9px 0;border-top:1px solid var(--border)}
.mini-row:first-of-type{border-top:none}
.mini-row b{font-size:13.5px}
.mini-row .sm{font-size:11.5px;margin-top:2px}
.back-link{display:inline-block;color:var(--muted);text-decoration:none;font-size:12.5px;margin-bottom:6px}
.back-link:hover{color:var(--gold)}
.phead .sub{color:var(--muted);font-size:13px;margin:2px 0 0}

/* ---------- themed confirmation modal ---------- */
.confirm-ov{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;background:rgba(6,10,22,.66);backdrop-filter:blur(3px);animation:cfade .14s ease}
.confirm-ov[hidden]{display:none}
.confirm-card{width:min(380px,92vw);background:var(--surface);border:1px solid var(--border);border-radius:18px;padding:24px 22px;text-align:center;box-shadow:0 24px 60px rgba(0,0,0,.5);animation:cpop .16s ease}
.confirm-ic{width:52px;height:52px;margin:0 auto 12px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:color-mix(in srgb,var(--rose) 16%,transparent);color:var(--rose)}
.confirm-ic svg{width:26px;height:26px}
.confirm-card p{margin:0 0 20px;font-size:14.5px;color:var(--text);line-height:1.6}
.confirm-actions{display:flex;gap:10px;justify-content:center}
.confirm-actions .btn-soft,.confirm-actions .btn-danger{min-width:104px;justify-content:center}
.btn-danger{display:inline-flex;align-items:center;gap:7px;padding:9px 18px;border-radius:11px;border:1px solid transparent;background:var(--rose);color:#fff;font-weight:700;font-size:13px;cursor:pointer;transition:filter .12s}
.btn-danger:hover{filter:brightness(1.08)}
@keyframes cfade{from{opacity:0}to{opacity:1}}
@keyframes cpop{from{opacity:0;transform:translateY(8px) scale(.97)}to{opacity:1;transform:none}}

/* ---------- Intelligence layer ---------- */
.intel-2col{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:900px){.intel-2col{grid-template-columns:1fr}}
.intel-brain{background:linear-gradient(160deg,rgba(212,165,72,.07),var(--surface))}
.brain-row{display:flex;gap:10px;margin-bottom:12px}
.brain-row input{flex:1;background:var(--surface-2);border:1px solid var(--border);border-radius:12px;padding:12px 15px;color:var(--text);font-family:inherit;font-size:14px}
.brain-row input:focus{outline:none;border-color:var(--gold)}
.ex-chips{display:flex;flex-wrap:wrap;gap:7px;align-items:center}
.ex-chips .chip{cursor:pointer;text-decoration:none}
.qresult{margin-top:14px;border-top:1px solid var(--border);padding-top:14px}
.qhead{display:flex;align-items:center;justify-content:space-between;gap:12px}
.qmsg{padding:12px 14px;border-radius:12px;background:var(--surface-2);color:var(--muted);font-size:13px}
.qmsg.warn{background:color-mix(in srgb,var(--rose) 12%,transparent);color:var(--rose)}
.kg-form .two{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.kg-form .ck,.sim-form .ck{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--muted);margin:8px 0;cursor:pointer}
.imp-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:12px 0}
.imp{background:var(--surface-2);border:1px solid var(--border);border-radius:12px;padding:11px 13px}
.imp .l{font-size:11px;color:var(--muted);margin-bottom:4px}
.imp .v{font-size:15px;font-weight:800;display:flex;align-items:center;gap:6px}
.reasons{font-size:12.5px;color:var(--muted)}
.reasons ul{margin:6px 14px 0;padding:0}
.reasons li{margin-bottom:5px;line-height:1.6}
.note-ind{margin-top:12px;font-size:11px;color:var(--muted);background:var(--surface-2);border:1px dashed var(--border);border-radius:10px;padding:9px 12px}
.rk-low{background:color-mix(in srgb,var(--emerald) 18%,transparent)!important;color:var(--emerald)!important}
.rk-med{background:color-mix(in srgb,var(--gold) 20%,transparent)!important;color:var(--gold-2)!important}
.rk-high{background:color-mix(in srgb,var(--rose) 18%,transparent)!important;color:var(--rose)!important}

/* relationship graph */
.rel-wrap{background:radial-gradient(circle at 50% 45%,rgba(212,165,72,.06),transparent 70%);border-radius:14px;padding:6px}

/* fingerprint */
.fp-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;margin-bottom:6px}
@media(max-width:600px){.fp-grid{grid-template-columns:1fr 1fr}}
.fp{background:var(--surface-2);border:1px solid var(--border);border-radius:11px;padding:10px 12px}
.fp .k{display:block;font-size:10.5px;color:var(--muted);margin-bottom:4px}
.fp b{font-size:14px}
.anom-h{font-size:11px;font-weight:800;color:var(--gold);letter-spacing:.5px;margin:12px 0 8px;text-transform:uppercase}
.anom{display:flex;align-items:flex-start;gap:8px;font-size:12.3px;line-height:1.5;padding:9px 11px;border-radius:10px;margin-bottom:7px}
.anom svg{flex:none;margin-top:2px}
.anom.ok{background:color-mix(in srgb,var(--emerald) 12%,transparent);color:var(--emerald)}
.anom.warn{background:color-mix(in srgb,var(--rose) 12%,transparent);color:var(--rose)}
.anom.info{background:color-mix(in srgb,var(--gold) 12%,transparent);color:var(--gold-2)}

/* risk meter */
.risk-meter{height:12px;border-radius:8px;background:var(--surface-2);border:1px solid var(--border);overflow:hidden;margin:4px 0 6px}
.rm-bar{height:100%;border-radius:8px}
.rm-bar.rk-low{background:var(--emerald)}.rm-bar.rk-med{background:var(--gold)}.rm-bar.rk-high{background:var(--rose)}
.rm-val{font-size:12px;color:var(--muted);text-align:end;margin-bottom:4px}
.reason-row{display:flex;align-items:center;gap:9px;font-size:12.5px;padding:7px 0;border-top:1px solid var(--border)}
.reason-row:first-of-type{border-top:none}
.rdot{flex:none;width:8px;height:8px;border-radius:50%}
.rdot.rk-low{background:var(--emerald)}.rdot.rk-med{background:var(--gold)}.rdot.rk-high{background:var(--rose)}
.rw{margin-inline-start:auto;color:var(--muted);font-size:11px}
.imp .v{direction:ltr;justify-content:flex-end}

/* driver break button */
.bigbtn.brk{background:linear-gradient(135deg,var(--amber),#b9851f);color:#1a1205;margin-top:8px}
.bigbtn.brk:hover{filter:brightness(1.06)}

/* ===== global search results ===== */
.srch-ic{width:34px;height:34px;border-radius:10px;display:flex;align-items:center;justify-content:center;
  background:color-mix(in srgb,var(--gold) 13%,transparent);border:1px solid var(--border)}
.srch-ic svg{width:18px;height:18px}
.sr-list{display:flex;flex-direction:column;gap:8px}
.sr-item{display:flex;align-items:center;justify-content:space-between;gap:14px;text-decoration:none;color:inherit;
  padding:11px 14px;border:1px solid var(--border);border-radius:12px;background:var(--surface-2);transition:.15s}
.sr-item:hover{border-color:var(--gold);background:color-mix(in srgb,var(--gold) 7%,var(--surface-2))}
.sr-main{min-width:0;flex:1}
.sr-title{font-weight:700;font-size:14px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sr-desc{font-size:12px;color:var(--text-2);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sr-meta{display:flex;align-items:center;gap:10px;flex:none}
.sr-view{font-size:12px;font-weight:700;color:var(--gold);white-space:nowrap}

/* ============ Grouped rail flyout menus ============ */
.rail-group{position:relative;display:flex;flex-direction:column;align-items:center;flex:0 0 auto}
.rail-group > .rail-btn{cursor:pointer;border:0;background:transparent;font:inherit}
.rail-group.on > .rail-btn{color:var(--gold);background:var(--gold-soft)}
.rail-group.on > .rail-btn::before{content:"";position:absolute;inset-inline-start:-18px;top:50%;transform:translateY(-50%);width:4px;height:24px;border-radius:4px;background:var(--gold)}
.rail-fly{position:absolute;inset-inline-start:calc(100% + 12px);top:-6px;min-width:194px;
  background:var(--surface-solid);border:1px solid var(--border);border-radius:14px;padding:8px;
  box-shadow:var(--shadow);display:none;z-index:80}
.rail-group:hover > .rail-fly,.rail-group.open > .rail-fly{display:block}
.rail-fly-h{font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);padding:6px 10px 8px}
.rail-fly-link{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:10px;color:var(--text);
  text-decoration:none;font-size:13.5px;font-weight:600;white-space:nowrap;transition:.16s}
.rail-fly-link svg{width:18px;height:18px;flex:0 0 auto}
.rail-fly-link:hover{background:var(--surface)}
.rail-fly-link.on{color:var(--gold);background:var(--gold-soft)}

@media(max-width:760px){
  /* inside the mobile drawer, flyouts become inline accordions (no side overflow) */
  .rail.show .rail-group{width:100%;align-items:stretch}
  .rail.show .rail-group > .rail-btn{width:100%;flex-direction:row;align-items:center;justify-content:flex-start;gap:14px;padding:11px 14px;border-radius:12px;height:auto}
  .rail.show .rail-group > .rail-btn::after{content:attr(data-label);font-size:13px;font-weight:600}
  .rail.show .rail-fly{position:static;inset-inline-start:auto;top:auto;display:none;min-width:0;
    box-shadow:none;border:0;background:transparent;padding:2px 0 6px;margin-inline-start:14px;
    border-inline-start:1px solid var(--border)}
  .rail.show .rail-group:hover > .rail-fly{display:none}
  .rail.show .rail-group.open > .rail-fly{display:block}
  .rail.show .rail-fly-h{display:none}
}

/* ============================================================
   iOS / PWA — safe areas, notch & Dynamic Island, native feel
   (env() insets are 0 on desktop, so these are no-ops there)
   ============================================================ */
:root{
  --sat:env(safe-area-inset-top,0px);
  --sab:env(safe-area-inset-bottom,0px);
  --sal:env(safe-area-inset-left,0px);
  --sar:env(safe-area-inset-right,0px);
}
html{-webkit-text-size-adjust:100%}
.shell{min-height:100vh;min-height:100dvh}
/* avoid white rubber-band flash + own the pull gesture in standalone */
html,body{background:var(--bg)}
@media (display-mode: standalone){ body{overscroll-behavior-y:none} }

/* fixed top bar: background extends under the status bar; content stays below it */
.top{
  height:calc(var(--top) + var(--sat));
  padding-block-start:var(--sat);
  padding-inline-start:max(26px,var(--sal));
  padding-inline-end:max(26px,var(--sar));
}
/* content clears the taller bar and respects side + bottom insets */
.main{
  padding-top:calc(var(--top) + var(--sat) + 26px);
  padding-inline-start:max(30px,var(--sal));
  padding-inline-end:max(30px,var(--sar));
  padding-bottom:calc(40px + var(--sab));
}

@media(max-width:760px){
  .top{
    padding-inline-start:max(16px,var(--sal));
    padding-inline-end:max(16px,var(--sar));
  }
  .main{
    padding-top:calc(var(--top) + var(--sat) + 18px);
    padding-inline-start:max(16px,var(--sal));
    padding-inline-end:max(16px,var(--sar));
    padding-bottom:calc(90px + var(--sab));
  }
  /* bottom nav sits above the home indicator */
  .mobnav{
    height:calc(64px + var(--sab));
    padding-bottom:var(--sab);
    padding-inline-start:max(8px,var(--sal));
    padding-inline-end:max(8px,var(--sar));
  }
  /* side drawer respects top/bottom insets */
  .rail.show{
    padding-top:calc(18px + var(--sat));
    padding-bottom:calc(18px + var(--sab));
    padding-inline-start:max(12px,var(--sal));
  }
  /* floating action button above the bottom nav + home indicator */
  .fab{ inset-block-end:calc(80px + var(--sab)); inset-inline-end:calc(20px + var(--sar)); }
  /* prevent iOS auto-zoom when focusing form fields (font must be >=16px) */
  input,select,textarea{ font-size:16px }
  /* toasts clear the notch */
  .toasts{ inset-block-start:calc(78px + var(--sat)) }
}

/* landscape: respect the notch on whichever side it lands */
@media(max-width:760px) and (orientation:landscape){
  .main{ padding-inline-start:max(20px,var(--sal)); padding-inline-end:max(20px,var(--sar)); }
}

/* login screen — respect notch / home indicator */
.login-wrap{min-height:100dvh}
.login-form-side{
  padding-block-start:max(0px,var(--sat));
  padding-block-end:max(0px,var(--sab));
  padding-inline-start:max(0px,var(--sal));
  padding-inline-end:max(0px,var(--sar));
}
@media(max-width:980px){
  .login-form-side{padding-block-start:calc(20px + var(--sat));padding-block-end:calc(20px + var(--sab))}
}

/* ============================================================
   Mobile experience refinements (item 5)
   ============================================================ */
/* smooth, contained horizontal scrolling for wide tables */
.tbl-wrap{-webkit-overflow-scrolling:touch;overscroll-behavior-x:contain}
/* never let long unbreakable strings (emails, tokens, plates) break the layout */
td, .kv-grid div, .eid-grid div{overflow-wrap:anywhere}
img{max-width:100%}

@media(max-width:760px){
  /* collapse multi-column content grids so nothing is cramped or unreadable */
  .cmd,.cgrid,.fgrid,.grid2,.grid3,.field-row,.frow .two,.two,.imp-grid,.qgrid,
  .intel-2col,.prof-grid,.kv-grid,.fp-grid,.kg-form .two,.attn-rings{
    grid-template-columns:1fr;
  }
  .kgrid,.srow{grid-template-columns:repeat(2,1fr)}
  /* tables go edge-to-edge to use the full width before scrolling */
  .tbl-wrap{margin-inline:-4px}
  table{min-width:520px}
  th,td{padding-block:11px}
  /* comfortable, thumb-friendly touch targets (>=44px) */
  .btn,.btn-soft{height:48px}
  .btn-danger{min-height:44px}
  .tbtn,.sheet-head .x,.lang{min-width:44px;min-height:44px}
  .chip,.pill,.badge{min-height:30px;display:inline-flex;align-items:center}
  /* action buttons/links inside table rows */
  td .btn,td .btn-soft,td .btn-danger,td a.act,td button{min-height:40px}
  /* overlays clear the notch / home indicator and add breathing room */
  .modal-overlay,.confirm-ov{
    padding:calc(16px + var(--sat)) 14px calc(16px + var(--sab));
  }
  .confirm-card{width:100%;max-width:420px}
}

@media(max-width:460px){
  .kgrid,.srow{grid-template-columns:1fr}
  /* stack footer/modal actions full-width for one-handed taps */
  .sheet-foot,.modal-foot,.confirm-actions{flex-wrap:wrap}
  .confirm-actions .btn-soft,.confirm-actions .btn-danger{flex:1}
}

/* ============================================================
   Mobile sidebar — polished drawer (refinement #2)
   Desktop rail is unchanged; these rules apply only in the drawer.
   ============================================================ */
.rail-brand{display:none}
@media(max-width:760px){
  .rail.show{
    width:80vw; max-width:300px; padding:0; gap:0;
    -webkit-overflow-scrolling:touch; overscroll-behavior:contain;
    flex-direction:column; align-items:stretch;
  }
  /* drawer header: logo + brand name */
  .rail.show .logo{
    width:auto; height:auto; margin:0; border-radius:0; place-items:center;
    display:flex; gap:12px; align-items:center; justify-content:flex-start;
    padding:calc(18px + var(--sat)) 18px 16px; color:var(--text);
    background:transparent; border-bottom:1px solid var(--border);
  }
  .rail.show .logo > svg,.rail.show .logo > img{
    width:38px;height:38px;flex:0 0 auto;
    background:linear-gradient(135deg,var(--gold),var(--gold-2));
    color:#0b0f1d;border-radius:11px;padding:7px;
  }
  .rail.show .logo > img{background:none;padding:0;object-fit:contain}
  .rail-brand{
    display:block; font-size:16px; font-weight:800; letter-spacing:-.2px; color:var(--text);
    white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
  }
  /* scroll area + consistent rhythm */
  .rail.show{ }
  .rail.show > .rail-btn,
  .rail.show .rail-group{ margin:2px 10px; }
  .rail.show .rail-sp{ flex:0 0 auto; height:1px; background:var(--border); margin:10px 14px; }

  /* items: comfortable 48px touch targets, clear typography */
  .rail.show .rail-btn{
    width:auto; min-height:48px; height:auto; gap:14px; padding:12px 14px;
    border-radius:12px; justify-content:flex-start; font-weight:600;
  }
  .rail.show .rail-btn svg{width:22px;height:22px;flex:0 0 auto}
  .rail.show .rail-btn::after{font-size:14.5px;font-weight:600;line-height:1.2;
    white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .rail.show .rail-btn.on{background:var(--gold-soft);color:var(--gold)}
  .rail.show .rail-btn.on::before{display:none}              /* hide off-canvas active bar */

  /* group header chevron (direction-neutral up/down), smooth rotate */
  .rail.show .rail-group > .rail-btn{position:relative;width:100%}
  .rail.show .rail-group > .rail-btn::before{
    content:"";position:absolute;inset-inline-end:16px;inset-inline-start:auto;top:50%;
    width:8px;height:8px;border-right:2px solid currentColor;border-bottom:2px solid currentColor;
    background:none;border-radius:0;
    transform:translateY(-70%) rotate(45deg);transition:transform .25s ease;opacity:.55;
  }
  .rail.show .rail-group.open > .rail-btn::before{transform:translateY(-30%) rotate(-135deg);opacity:.9}

  /* accordion: smooth height + fade, no clipping */
  .rail.show .rail-fly{
    display:block!important; max-height:0; overflow:hidden; opacity:0;
    padding:0; margin:0 14px 0 18px; border:0; background:transparent;
    border-inline-start:1px solid var(--border);
    transition:max-height .28s ease, opacity .2s ease, padding .28s ease;
  }
  html[dir="rtl"] .rail.show .rail-fly{margin:0 18px 0 14px}
  .rail.show .rail-group.open > .rail-fly{max-height:520px;opacity:1;padding:4px 0 6px}
  .rail.show .rail-fly-h{display:none}
  .rail.show .rail-fly-link{
    min-height:42px;gap:12px;padding:10px 12px;border-radius:10px;font-size:13.5px;font-weight:500;
  }
  .rail.show .rail-fly-link svg{width:18px;height:18px}
  .rail.show .rail-fly-link.on{background:var(--gold-soft);color:var(--gold)}

  /* bottom actions get a little breathing room above the home indicator */
  .rail.show > .rail-btn:last-child{margin-bottom:calc(12px + var(--sab))}
}

/* impersonation banner (Super Admin support mode) */
.imp-banner{display:flex;align-items:center;gap:12px;flex-wrap:wrap;
  background:linear-gradient(90deg,color-mix(in srgb,var(--gold) 22%,var(--surface-solid)),var(--surface-solid));
  border:1px solid color-mix(in srgb,var(--gold) 50%,var(--border));color:var(--text);
  border-radius:var(--r-md);padding:11px 16px;margin-bottom:16px;font-size:13.5px}
.imp-banner svg{color:var(--gold);flex:0 0 auto}
.imp-banner span{flex:1;min-width:140px}
.imp-exit{font:inherit;font-weight:700;font-size:12.5px;cursor:pointer;color:#0b0f1d;
  background:linear-gradient(135deg,var(--gold),var(--gold-2));border:0;border-radius:9px;padding:8px 16px;min-height:38px}
.imp-exit:hover{filter:brightness(1.05)}

/* platform announcements on dashboard */
.ann-card{display:flex;align-items:flex-start;gap:14px;background:var(--surface-solid);
  border:1px solid var(--border);border-radius:var(--r-md);padding:14px 16px;margin-bottom:14px}
.ann-ic{flex:0 0 auto;margin-top:1px}
.ann-body{flex:1;min-width:0}
.ann-title{font-weight:700;font-size:14.5px;display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.ann-badge{font-size:10.5px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:2px 8px;border-radius:999px}
.ann-text{color:var(--text-2);font-size:13px;line-height:1.65;margin-top:5px}
.ann-dismiss{flex:0 0 auto}
.ann-dismiss button{font:inherit;font-size:12px;font-weight:600;cursor:pointer;color:var(--text-2);
  background:var(--surface);border:1px solid var(--border);border-radius:9px;padding:7px 12px;min-height:36px;white-space:nowrap}
.ann-dismiss button:hover{color:var(--text);background:var(--surface-2)}
@media(max-width:600px){.ann-card{flex-wrap:wrap}.ann-dismiss{width:100%}.ann-dismiss button{width:100%}}

/* financial export bar */
.export-bar{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:18px}
.export-lab{font-size:12.5px;color:var(--muted);font-weight:600}
@media(max-width:600px){.export-bar{margin-bottom:14px}.export-bar .btn-soft{flex:1;text-align:center}}

/* PWA install button */
#pwaInstall{display:inline-flex;align-items:center;gap:7px;width:auto;padding:0 12px}
#pwaInstall .pwa-label{font-size:12.5px;font-weight:700}
@media(max-width:760px){#pwaInstall .pwa-label{display:none}#pwaInstall{padding:0;width:40px}}

/* announcement entries inside the notification bell */
.notif-item.ann{background:color-mix(in srgb,var(--gold) 6%,transparent)}
.ni-tag{display:inline-block;font-size:9.5px;font-weight:800;letter-spacing:.05em;text-transform:uppercase;
  color:var(--gold);background:var(--gold-soft);padding:1px 6px;border-radius:5px;vertical-align:middle;margin-inline-end:4px}
