:root{
  --ink:#0c1220;--ink2:#1a2540;--ink3:#243050;
  --steel:#3d4f72;--slate:#6b7c9e;--fog:#9daabf;--pale:#dde3ef;--snow:#f2f4f9;--white:#fff;
  --accent:#1e6fff;--accent2:#4a8fff;--gold:#e09b20;--gold2:#f5bc45;
  --str:#e07820;--str2:#f59940;
  --ok:#10b981;--warn:#f59e0b;--err:#ef4444;--hold:#8b44e0;
  --sh:0 2px 16px rgba(12,18,32,.07);--sh2:0 8px 32px rgba(12,18,32,.13);--sh3:0 20px 60px rgba(12,18,32,.18);
  --ff:'Bricolage Grotesque',sans-serif;--fb:'Mulish',sans-serif;
  --r:12px;--r2:18px;--r3:24px;
}
*{margin:0;padding:0;box-sizing:border-box}
html,body{height:100%;font-family:var(--fb);color:var(--ink);background:var(--snow);font-size:14px}

/* LOADER */
#ld{position:fixed;inset:0;background:var(--ink);z-index:9999;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:20px;transition:opacity .5s}
#ld.out{opacity:0;pointer-events:none}
.ld-mark{width:52px;height:52px;border-radius:14px;background:linear-gradient(135deg,var(--accent),var(--gold));display:flex;align-items:center;justify-content:center;font-size:1.5rem}
.ld-name{font-family:var(--ff);font-size:1.6rem;font-weight:800;color:#fff}
.ld-name span{color:var(--gold2)}
.ld-bar{width:220px;height:3px;background:rgba(255,255,255,.1);border-radius:99px;overflow:hidden}
.ld-prog{height:100%;background:linear-gradient(90deg,var(--accent),var(--gold2));border-radius:99px;width:0;transition:width .35s ease}
.ld-msg{font-size:.72rem;color:rgba(255,255,255,.35);letter-spacing:.8px;text-transform:uppercase}

/* AUTH */
#auth,#login-screen{display:none;min-height:100vh;background:var(--ink);align-items:center;justify-content:center;position:relative;overflow:hidden}
#auth.on,#login-screen.on{display:flex}
.auth-pattern{position:absolute;inset:0;background-image:repeating-linear-gradient(0deg,transparent,transparent 39px,rgba(255,255,255,.025) 39px,rgba(255,255,255,.025) 40px),repeating-linear-gradient(90deg,transparent,transparent 39px,rgba(255,255,255,.025) 39px,rgba(255,255,255,.025) 40px)}
.auth-glow{position:absolute;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(30,111,255,.12),transparent 70%);top:50%;left:50%;transform:translate(-50%,-50%);pointer-events:none}
.auth-box{position:relative;z-index:2;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:var(--r3);padding:44px 40px;width:440px;backdrop-filter:blur(24px)}
.auth-logo{display:flex;align-items:center;gap:12px;margin-bottom:32px}
.auth-mark{width:42px;height:42px;border-radius:11px;background:linear-gradient(135deg,var(--accent),var(--gold));display:flex;align-items:center;justify-content:center;font-size:1.1rem}
.auth-brand{font-family:var(--ff);font-size:1.1rem;font-weight:800;color:#fff}
.auth-tagline{font-size:.58rem;color:rgba(255,255,255,.35);text-transform:uppercase;letter-spacing:1px;margin-top:1px}
.auth-h{font-family:var(--ff);font-size:1.7rem;font-weight:800;color:#fff;margin-bottom:5px}
.auth-sub{font-size:.78rem;color:rgba(255,255,255,.4);line-height:1.6;margin-bottom:26px}
.role-row{display:flex;gap:8px;margin-bottom:22px}
.rb{flex:1;padding:10px 6px;border-radius:10px;border:1.5px solid rgba(255,255,255,.1);background:transparent;color:rgba(255,255,255,.45);font-family:var(--ff);font-size:.68rem;font-weight:700;cursor:pointer;transition:all .18s;text-align:center;line-height:1.3}
.rb:hover{border-color:rgba(255,255,255,.3);color:rgba(255,255,255,.75)}
.rb.on{background:rgba(30,111,255,.2);border-color:var(--accent2);color:#fff}
.rb .rb-ico{display:block;font-size:1rem;margin-bottom:3px}
.f-lbl{font-size:.62rem;font-weight:700;color:rgba(255,255,255,.4);text-transform:uppercase;letter-spacing:.7px;margin-bottom:5px}
.f-inp-d{width:100%;background:rgba(255,255,255,.07);border:1.5px solid rgba(255,255,255,.1);border-radius:9px;padding:11px 14px;color:#fff;font-family:var(--fb);font-size:.85rem;outline:none;transition:border .18s;margin-bottom:13px}
.f-inp-d:focus{border-color:var(--accent2)}
.f-inp-d::placeholder{color:rgba(255,255,255,.22)}
.sign-btn{width:100%;padding:13px;border-radius:12px;border:none;background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;font-family:var(--ff);font-size:.9rem;font-weight:700;cursor:pointer;transition:all .2s;margin-top:4px;box-shadow:0 6px 20px rgba(30,111,255,.4)}
.sign-btn:hover{transform:translateY(-1px)}
.auth-note{text-align:center;font-size:.65rem;color:rgba(255,255,255,.2);margin-top:14px}

/* APP SHELL */
#app{display:none;height:100vh;flex-direction:column;overflow:hidden}
#loading-screen{position:fixed;inset:0;background:var(--ink);z-index:9999;flex-direction:column;align-items:center;justify-content:center;gap:20px}
#app.on{display:flex}
#topbar{flex-shrink:0;height:54px;background:var(--white);border-bottom:1px solid var(--pale);display:flex;align-items:center;padding:0 18px;gap:12px;box-shadow:var(--sh);z-index:50}
.tb-logo{display:flex;align-items:center;gap:9px;flex-shrink:0;cursor:pointer}
.tb-mark{width:30px;height:30px;border-radius:8px;background:linear-gradient(135deg,var(--accent),var(--gold));display:flex;align-items:center;justify-content:center;font-size:.85rem}
.tb-name{font-family:var(--ff);font-size:.92rem;font-weight:800;color:var(--ink)}
.tb-div{width:1px;height:22px;background:var(--pale);flex-shrink:0}
.breadcrumb{display:flex;align-items:center;gap:5px;flex:1;overflow:hidden}
.bc{font-size:.7rem;font-weight:600;color:var(--fog);white-space:nowrap}
.bc.active{color:var(--ink)}
.bc-sep{font-size:.6rem;color:var(--pale)}
.tb-right{display:flex;align-items:center;gap:8px;flex-shrink:0}
.role-badge{font-size:.6rem;font-weight:800;padding:3px 10px;border-radius:99px;text-transform:uppercase;letter-spacing:.5px;background:rgba(30,111,255,.1);color:var(--accent)}
.user-pill{display:flex;align-items:center;gap:8px;padding:4px 10px;border-radius:9px;border:1px solid var(--pale)}
.user-av{width:24px;height:24px;border-radius:7px;background:linear-gradient(135deg,var(--accent),var(--gold));display:flex;align-items:center;justify-content:center;font-family:var(--ff);font-size:.6rem;font-weight:800;color:#fff}
.user-nm{font-size:.72rem;font-weight:700;color:var(--ink)}
.logout-btn{padding:5px 11px;border-radius:8px;border:1px solid var(--pale);background:transparent;font-size:.68rem;font-weight:600;color:var(--slate);cursor:pointer;transition:all .15s;font-family:var(--fb)}
.logout-btn:hover{border-color:rgba(239,68,68,.3);color:var(--err)}

/* BODY / SIDEBAR */
#body{flex:1;display:flex;overflow:hidden}
#side{width:228px;flex-shrink:0;background:var(--white);border-right:1px solid var(--pale);display:flex;flex-direction:column;overflow-y:auto}
.side-sec{padding:14px 10px 4px}
.side-sec-lbl{font-size:.56rem;font-weight:800;color:var(--fog);text-transform:uppercase;letter-spacing:1.2px;padding:0 8px 6px}
.nav-item{display:flex;align-items:center;gap:9px;padding:9px 10px;border-radius:10px;cursor:pointer;transition:all .15s;border:none;background:transparent;width:100%;text-align:left;margin-bottom:1px;font-family:var(--fb)}
.nav-item:hover{background:var(--snow)}
.nav-item.on{background:linear-gradient(135deg,rgba(30,111,255,.07),rgba(30,111,255,.03));border:1px solid rgba(30,111,255,.12)}
.ni-ico{width:28px;height:28px;border-radius:8px;background:var(--pale);display:flex;align-items:center;justify-content:center;font-size:.8rem;flex-shrink:0;transition:all .15s}
.nav-item.on .ni-ico{background:linear-gradient(135deg,var(--accent),var(--accent2))}
.ni-lbl{font-size:.77rem;font-weight:600;color:var(--slate)}
.nav-item.on .ni-lbl{color:var(--accent);font-weight:700}
.ni-badge{margin-left:auto;font-size:.58rem;font-weight:800;padding:2px 7px;border-radius:99px;background:var(--pale);color:var(--slate)}
.nav-item.on .ni-badge{background:rgba(30,111,255,.12);color:var(--accent)}
.side-proj-box{margin:10px;border-radius:14px;padding:14px;background:linear-gradient(135deg,var(--ink),var(--ink2))}
.spb-tag{font-size:.56rem;font-weight:700;color:rgba(255,255,255,.35);text-transform:uppercase;letter-spacing:.8px;margin-bottom:4px}
.spb-name{font-family:var(--ff);font-size:.88rem;font-weight:800;color:#fff;line-height:1.25}

/* CONTENT */
#content{flex:1;overflow-y:auto;overflow-x:hidden}
.screen{display:none}.screen.on{display:block}
.pw{padding:22px;max-width:1380px}

/* KPI CARDS */
.dash-kpis{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;margin-bottom:16px}
.kpi-card{background:var(--white);border:1.5px solid var(--pale);border-radius:var(--r);padding:14px;box-shadow:var(--sh)}
.kpi-ico{width:32px;height:32px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:.8rem;margin-bottom:9px}
.kpi-val{font-family:var(--ff);font-size:1.65rem;font-weight:800;line-height:1}
.kpi-lbl{font-size:.58rem;font-weight:800;color:var(--slate);text-transform:uppercase;letter-spacing:.5px;margin-top:5px}
.kpi-sub{font-size:.62rem;color:var(--fog);margin-top:2px}

/* CARDS */
.g2{display:grid;grid-template-columns:1.5fr 1fr;gap:12px;margin-bottom:12px}
.card{background:var(--white);border:1.5px solid var(--pale);border-radius:var(--r2);box-shadow:var(--sh)}
.card-h{padding:13px 16px;border-bottom:1px solid var(--pale);display:flex;align-items:center;justify-content:space-between}
.card-title{font-family:var(--ff);font-size:.85rem;font-weight:800;color:var(--ink)}
.card-badge{font-size:.58rem;font-weight:700;padding:3px 9px;border-radius:99px;background:rgba(30,111,255,.08);color:var(--accent)}
.card-b{padding:14px 16px}

/* STAGE BARS */
.stage-row{display:flex;align-items:center;gap:9px;margin-bottom:9px}
.sr-lbl{font-size:.7rem;color:var(--slate);font-weight:600;width:100px;flex-shrink:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sr-bar{flex:1;height:8px;background:var(--pale);border-radius:99px;overflow:hidden}
.sr-fill{height:100%;border-radius:99px}
.sr-pct{font-size:.68rem;font-weight:800;width:36px;text-align:right;flex-shrink:0}
.sr-count{font-size:.62rem;color:var(--fog);width:60px;text-align:right;flex-shrink:0}

/* ITEMS TABLE */
.items-wrap{overflow-x:auto;overflow-y:auto;max-height:calc(100vh - 260px)}
.items-tbl{width:100%;border-collapse:collapse;font-size:.74rem}
.items-tbl th{padding:9px 12px;background:var(--snow);font-size:.58rem;font-weight:800;color:var(--slate);text-transform:uppercase;letter-spacing:.5px;border-bottom:1.5px solid var(--pale);white-space:nowrap;text-align:left;position:sticky;top:0;z-index:2}
.items-tbl td{padding:10px 12px;border-bottom:1px solid var(--pale);vertical-align:middle}
.items-tbl tr:hover td{background:var(--snow)}
.items-tbl tr.held td{background:rgba(139,68,224,.03)}
.sdot{width:22px;height:22px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:.62rem;font-weight:800;cursor:pointer;transition:all .15s;border:1.5px solid transparent}
.sdot.done{background:rgba(16,185,129,.15);color:var(--ok);border-color:rgba(16,185,129,.3)}
.sdot.pend{background:var(--pale);color:var(--fog);border-color:var(--pale)}
.sdot.hold{background:rgba(139,68,224,.1);color:var(--hold);border-color:rgba(139,68,224,.2)}
.sdot.editable:hover{transform:scale(1.15)}
.sbadge{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:99px;font-size:.62rem;font-weight:700;white-space:nowrap}
.sb-done{background:rgba(16,185,129,.1);color:var(--ok)}
.sb-prog{background:rgba(30,111,255,.1);color:var(--accent)}
.sb-pend{background:rgba(107,124,158,.1);color:var(--slate)}
.sb-hold{background:rgba(139,68,224,.1);color:var(--hold)}

/* SEARCH + FILTER */
.sf-row{display:flex;align-items:center;gap:9px;margin-bottom:12px;flex-wrap:wrap}
.srch{flex:1;min-width:180px;border:1.5px solid var(--pale);border-radius:9px;padding:9px 13px;font-family:var(--fb);font-size:.8rem;color:var(--ink);outline:none;transition:border .18s;background:var(--white)}
.srch:focus{border-color:var(--accent2)}
.filter-chip{padding:7px 13px;border-radius:9px;border:1.5px solid var(--pale);background:var(--white);font-size:.68rem;font-weight:700;color:var(--slate);cursor:pointer;transition:all .15s;white-space:nowrap;font-family:var(--fb)}
.filter-chip:hover{border-color:var(--accent2);color:var(--accent)}
.filter-chip.on{border-color:var(--accent);background:rgba(30,111,255,.07);color:var(--accent)}

/* PROJECT CARDS */
.proj-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px}
.proj-card{background:var(--white);border:1.5px solid var(--pale);border-radius:var(--r2);overflow:hidden;cursor:pointer;transition:all .2s;box-shadow:var(--sh)}
.proj-card:hover{transform:translateY(-2px);box-shadow:var(--sh2)}
.pc-stripe{height:4px;background:linear-gradient(90deg,var(--str),var(--str2))}
.pc-body{padding:16px}
.pc-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:10px}
.pc-code{font-family:var(--ff);font-size:1.3rem;font-weight:800;color:var(--ink)}
.pc-type-tag{font-size:.58rem;font-weight:800;padding:3px 9px;border-radius:99px;background:rgba(224,120,32,.1);color:var(--str)}
.pc-name{font-size:.78rem;color:var(--slate);margin-bottom:10px}
.pc-pbar{height:5px;background:var(--pale);border-radius:99px;overflow:hidden;margin-bottom:8px}
.pc-pfill{height:100%;border-radius:99px;transition:width .8s ease;background:var(--str)}
.pc-stats{display:flex;border-top:1px solid var(--pale);margin:0 -16px;padding:0}
.pcs{flex:1;padding:8px 6px;text-align:center;border-right:1px solid var(--pale)}
.pcs:last-child{border-right:none}
.pcs-v{font-family:var(--ff);font-size:.9rem;font-weight:800;color:var(--ink)}
.pcs-l{font-size:.53rem;color:var(--slate);font-weight:700;text-transform:uppercase;letter-spacing:.3px;margin-top:2px}

/* UPDATE PANEL */
#update-overlay{display:none;position:fixed;inset:0;background:rgba(12,18,32,.45);z-index:200;backdrop-filter:blur(4px)}
#update-overlay.on{display:flex;align-items:flex-start;justify-content:flex-end}
#update-panel{width:480px;height:100%;background:var(--white);box-shadow:var(--sh3);overflow-y:auto;transform:translateX(100%);transition:transform .3s cubic-bezier(.16,1,.3,1)}
#update-overlay.on #update-panel{transform:translateX(0)}
.up-hdr{padding:20px;background:linear-gradient(135deg,var(--ink),var(--ink2));display:flex;align-items:flex-start;gap:12px}
.up-hdr-ico{width:38px;height:38px;border-radius:10px;background:rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0}
.up-title{font-family:var(--ff);font-size:1rem;font-weight:800;color:#fff}
.up-sub{font-size:.68rem;color:rgba(255,255,255,.45);margin-top:2px}
.up-close{margin-left:auto;width:28px;height:28px;border-radius:8px;background:rgba(255,255,255,.1);border:none;color:rgba(255,255,255,.6);cursor:pointer;font-size:.9rem;flex-shrink:0;transition:background .15s}
.up-body{padding:20px}
.up-section{margin-bottom:20px}
.up-sec-title{font-size:.62rem;font-weight:800;color:var(--slate);text-transform:uppercase;letter-spacing:.8px;margin-bottom:10px;padding-bottom:6px;border-bottom:1px solid var(--pale)}
.up-inp{width:100%;border:1.5px solid var(--pale);border-radius:9px;padding:9px 12px;font-family:var(--fb);font-size:.82rem;color:var(--ink);outline:none;transition:border .18s;background:var(--white)}
.up-inp:focus{border-color:var(--accent2)}
.up-textarea{resize:vertical;min-height:70px}
.hold-toggle{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;border:1.5px solid var(--pale);background:var(--white);cursor:pointer;transition:all .15s}
.hold-toggle.active{border-color:var(--hold);background:rgba(139,68,224,.06)}
.ht-ico{font-size:1rem}
.ht-text{font-size:.78rem;font-weight:700;color:var(--ink)}
.ht-sub{font-size:.62rem;color:var(--slate);margin-top:1px}
.ht-switch{margin-left:auto;width:36px;height:20px;border-radius:99px;background:var(--pale);position:relative;transition:background .2s}
.hold-toggle.active .ht-switch{background:var(--hold)}
.ht-knob{position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:#fff;transition:transform .2s;box-shadow:0 1px 4px rgba(0,0,0,.15)}
.hold-toggle.active .ht-knob{transform:translateX(16px)}
.stage-update-row{display:flex;align-items:center;gap:8px;padding:9px 12px;border-radius:10px;border:1.5px solid var(--pale);background:var(--white);margin-bottom:7px}
.stage-update-row.done-row{border-color:rgba(16,185,129,.2);background:rgba(16,185,129,.03)}
.sur-ico{font-size:.9rem;flex-shrink:0;width:22px;text-align:center}
.save-btn{width:100%;padding:12px;border-radius:12px;border:none;background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;font-family:var(--ff);font-size:.88rem;font-weight:700;cursor:pointer;transition:all .2s;margin-top:4px}
.save-btn:hover{transform:translateY(-1px)}

/* TOAST */
#toast{position:fixed;bottom:22px;left:50%;transform:translateX(-50%) translateY(16px);background:var(--ink);color:#fff;padding:10px 20px;border-radius:10px;font-size:.76rem;font-weight:600;opacity:0;transition:all .3s;z-index:9999;pointer-events:none;white-space:nowrap}
#toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* UPLOAD SCREEN */
.upload-hero{background:linear-gradient(135deg,var(--ink),var(--ink2));border-radius:var(--r3);padding:28px;margin-bottom:20px}
.uh-title{font-family:var(--ff);font-size:1.65rem;font-weight:800;color:#fff;margin-bottom:6px}
.uh-sub{font-size:.77rem;color:rgba(255,255,255,.45);line-height:1.7;max-width:560px}
.drop-zone{border:2px dashed var(--pale);border-radius:var(--r2);padding:40px 30px;text-align:center;cursor:pointer;transition:all .2s;background:var(--white)}
.drop-zone:hover,.drop-zone.drag{border-color:var(--accent);background:rgba(30,111,255,.03)}
.dz-ico{font-size:2.2rem;margin-bottom:12px}
.dz-title{font-family:var(--ff);font-size:1rem;font-weight:700;color:var(--ink);margin-bottom:5px}
.dz-sub{font-size:.72rem;color:var(--slate);margin-bottom:16px}
.dz-btn{display:inline-flex;align-items:center;gap:6px;padding:9px 20px;border-radius:10px;border:none;background:var(--accent);color:#fff;font-family:var(--ff);font-size:.78rem;font-weight:700;cursor:pointer}
#file-input{display:none}
.detect-result{background:var(--white);border:1.5px solid var(--pale);border-radius:var(--r2);padding:20px;margin-top:16px;display:none}
.col-chips{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:14px}
.col-chip{font-size:.62rem;padding:3px 10px;border-radius:99px;font-weight:600}
.cc-match{background:rgba(16,185,129,.1);color:var(--ok);border:1px solid rgba(16,185,129,.2)}
.cc-warn{background:rgba(245,158,11,.1);color:var(--warn);border:1px solid rgba(245,158,11,.2)}
.cc-miss{background:rgba(239,68,68,.08);color:var(--err);border:1px solid rgba(239,68,68,.15)}
.import-btn{display:inline-flex;align-items:center;gap:7px;padding:11px 24px;border-radius:12px;border:none;background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;font-family:var(--ff);font-size:.85rem;font-weight:700;cursor:pointer;box-shadow:0 4px 16px rgba(30,111,255,.3)}

/* ANIMATIONS */
@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.screen.on>.pw>*{animation:fadeUp .28s ease forwards}

/* ── RESPONSIVE / MOBILE ─────────────────────────────────────────── */

/* Mobile bottom nav bar */
#mobile-nav{display:none;position:fixed;bottom:0;left:0;right:0;background:var(--white);border-top:1px solid var(--pale);z-index:100;padding:8px 0 env(safe-area-inset-bottom,8px)}
.mob-nav-items{display:flex;justify-content:space-around;align-items:center}
.mob-nav-item{display:flex;flex-direction:column;align-items:center;gap:3px;padding:6px 12px;border:none;background:transparent;cursor:pointer;color:var(--slate);font-family:var(--fb);font-size:.55rem;font-weight:700;text-transform:uppercase;letter-spacing:.3px;min-width:56px;border-radius:10px;transition:all .15s}
.mob-nav-item.on{color:var(--accent);background:rgba(30,111,255,.08)}
.mob-nav-item .mn-ico{font-size:1.2rem;line-height:1}

@media(max-width:768px){
  /* Hide desktop sidebar, show mobile nav */
  #side{display:none!important}
  #mobile-nav{display:block}
  #content{padding-bottom:72px}

  /* Page padding */
  .pw{padding:12px}

  /* Top bar compact */
  #topbar{padding:0 12px;gap:8px}
  .tb-name{font-size:.8rem}
  .breadcrumb{display:none}
  .user-pill{padding:3px 8px}
  .user-nm{font-size:.65rem}
  .logout-btn{padding:4px 8px;font-size:.62rem}
  .role-badge{display:none}

  /* KPI cards — 2 columns on mobile */
  .dash-kpis{grid-template-columns:1fr 1fr!important;gap:8px}
  .kpi-card{padding:12px}
  .kpi-val{font-size:1.3rem}
  .kpi-lbl{font-size:.6rem}
  .kpi-sub{font-size:.55rem}

  /* Two column grid becomes single */
  .g2{grid-template-columns:1fr!important}

  /* Project cards */
  .proj-grid{grid-template-columns:1fr!important}

  /* Items table — horizontal scroll */
  .items-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
  .items-tbl{font-size:.65rem;min-width:600px}
  .items-tbl th,.items-tbl td{padding:6px 8px}

  /* Update panel full screen on mobile */
  #update-overlay.on{align-items:flex-end}
  #update-panel{width:100%!important;height:92vh;border-radius:20px 20px 0 0}

  /* Auth box full width */
  .auth-box{width:calc(100vw - 32px)!important;padding:28px 20px!important}

  /* Cards */
  .card{border-radius:12px}
  .card-h,.card-b{padding:12px}

  /* Stage rows */
  .stage-row{gap:6px}
  .sr-lbl{font-size:.65rem;width:70px!important}
  .sr-pct{font-size:.65rem}

  /* Admin panel table — stack on mobile */
  #users-list table{display:block;overflow-x:auto}

  /* Supervisor cards */
  #dash-supervisors .sr-lbl{width:70px!important;font-size:.65rem}

  /* Report screen */
  #sc-report .pw{padding:10px}
}

@media(max-width:480px){
  .dash-kpis{grid-template-columns:1fr 1fr!important}
  .kpi-val{font-size:1.1rem}
  .auth-box{padding:20px 16px!important}
  .auth-h{font-size:1.4rem}
}

/* ── TODAY'S UPDATES HIGHLIGHT (24-hour) ─────────────────────────────── */
tr.row-recent {
  background: linear-gradient(90deg, rgba(30,111,255,.06) 0%, transparent 100%) !important;
  border-left: 3px solid var(--accent) !important;
  animation: recentPulse 2s ease-in-out;
}
tr.row-recent td:first-child {
  border-left: 3px solid var(--accent);
}
@keyframes recentPulse {
  0%   { background: rgba(30,111,255,.15); }
  100% { background: rgba(30,111,255,.06); }
}

/* Recent badge on tag/joint ID */
.recent-badge {
  display: inline-block;
  padding: 1px 6px;
  border-radius: 99px;
  background: linear-gradient(135deg,#1e6fff,#4a8fff);
  color: #fff;
  font-size: .52rem;
  font-weight: 800;
  letter-spacing: .3px;
  margin-left: 5px;
  vertical-align: middle;
  white-space: nowrap;
}

/* Today filter button */
.filter-today-btn {
  padding: 5px 12px;
  border-radius: 8px;
  border: 1.5px solid var(--accent);
  background: rgba(30,111,255,.08);
  color: var(--accent);
  font-size: .65rem;
  font-weight: 700;
  cursor: pointer;
  font-family: var(--fb);
  transition: all .15s;
  white-space: nowrap;
}
.filter-today-btn.active {
  background: var(--accent);
  color: #fff;
}
.filter-today-btn:hover {
  background: var(--accent);
  color: #fff;
}
