/* ── Variables ───────────────────────────────────────── */
:root{
  --navy:#1e2d4f; --navy2:#253563; --navy3:#2d3f72;
  --blue:#4169c8; --blue2:#5b7fe0;
  --ok:#22c55e; --warn:#f59e0b; --err:#ef4444; --info:#3b82f6;
  --bg:#f4f6fb; --card:#fff; --border:#e2e8f0; --border2:#d1d9e6;
  --tx:#1a2340; --tx2:#5a6a8a; --tx3:#94a3b8;
  --sb:260px; --tb:58px;
  --r:8px; --r2:12px; --r3:16px;
  --sh1:0 1px 4px rgba(26,35,64,.07);
  --sh2:0 4px 18px rgba(26,35,64,.1);
  --sh3:0 10px 40px rgba(26,35,64,.16);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:14.5px}
body{font-family:'Sarabun',sans-serif;background:var(--bg);color:var(--tx);line-height:1.6;display:flex;min-height:100vh}

/* ── Sidebar ─────────────────────────────────────────── */
.sidebar{
  width:var(--sb);height:100vh;background:var(--navy);
  display:flex;flex-direction:column;position:fixed;top:0;left:0;z-index:300;
  transition:transform .3s;
}
.sb-logo{display:flex;align-items:center;gap:10px;padding:18px 20px 14px;border-bottom:1px solid rgba(255,255,255,.07)}
.sb-logo img,.sb-logo-img{height:26px;width:auto;flex-shrink:0;border-radius:5px;background:#fff;padding:3px 7px}
.sb-name{font-size:.84rem;font-weight:800;color:#fff;letter-spacing:.3px}
.sb-sub{font-size:.64rem;color:rgba(255,255,255,.4);margin-top:1px}
.sb-user{display:flex;align-items:center;gap:9px;padding:12px 16px;background:rgba(255,255,255,.04);border-bottom:1px solid rgba(255,255,255,.06)}
.sb-av{width:32px;height:32px;border-radius:50%;background:var(--blue);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.82rem;flex-shrink:0}
.sb-uname{font-size:.8rem;font-weight:600;color:#fff}
.sb-urole{font-size:.65rem;color:rgba(255,255,255,.4)}
.sb-nav{flex:1;overflow-y:auto;padding:8px 8px 0}
.sb-nav::-webkit-scrollbar{width:3px}
.sb-nav::-webkit-scrollbar-thumb{background:rgba(255,255,255,.1);border-radius:3px}
.nav-sec{font-size:.61rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:rgba(255,255,255,.28);padding:12px 8px 4px}
.nav-link{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:7px;text-decoration:none;color:rgba(255,255,255,.58);font-size:.82rem;font-weight:500;margin-bottom:1px;transition:all .15s;position:relative}
.nav-link i{width:18px;text-align:center;font-size:.8rem}
.nav-link:hover{background:rgba(255,255,255,.07);color:rgba(255,255,255,.9)}
.nav-link.active{background:var(--blue);color:#fff}
.nav-badge{margin-left:auto;background:var(--err);color:#fff;border-radius:20px;padding:1px 6px;font-size:.62rem;font-weight:700;min-width:18px;text-align:center;font-style:normal}
.nav-link.active .nav-badge{background:rgba(255,255,255,.3)}
.sb-foot{padding:8px 8px 14px;border-top:1px solid rgba(255,255,255,.07);flex-shrink:0}
.nav-logout{color:rgba(255,120,100,.8)!important}
.nav-logout:hover{background:rgba(255,80,60,.12)!important;color:rgba(255,140,120,.95)!important}

/* ── Main ────────────────────────────────────────────── */
.main{flex:1;margin-left:var(--sb);display:flex;flex-direction:column;min-height:100vh}
.page{flex:1;padding:22px 26px}

/* ── Topbar ──────────────────────────────────────────── */
.topbar{height:var(--tb);background:#fff;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 24px;position:sticky;top:0;z-index:200;box-shadow:var(--sh1);gap:14px}
.sidebar-toggle{display:none;background:none;border:none;cursor:pointer;color:var(--tx2);font-size:1.1rem;padding:6px}
.tb-title{font-size:.95rem;font-weight:700;color:var(--tx)}
.tb-bc{display:flex;align-items:center;gap:4px;font-size:.69rem;color:var(--tx3);margin-top:1px}
.tb-bc a{color:var(--blue);text-decoration:none}.tb-bc a:hover{text-decoration:underline}
.tb-bc span:not(:first-child){margin-left:0}
.tb-right{display:flex;align-items:center;gap:8px;flex-shrink:0}
.tb-logo{height:20px;width:auto;border-radius:4px;background:#fff;padding:2px 5px}
.tb-bell{position:relative;width:34px;height:34px;border-radius:50%;background:var(--bg);border:1px solid var(--border2);display:flex;align-items:center;justify-content:center;text-decoration:none;color:var(--tx2);font-size:.88rem;transition:all .15s}
.tb-bell:hover{background:#e8edf5;color:var(--navy)}
.tb-bell.has-notif sup{position:absolute;top:0;right:0;width:8px;height:8px;background:var(--err);border-radius:50%;border:2px solid #fff;font-size:0}
.tb-av{width:32px;height:32px;border-radius:50%;background:var(--navy);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.75rem;cursor:default}

/* ── Cards ───────────────────────────────────────────── */
.card{background:var(--card);border-radius:var(--r2);border:1px solid var(--border);box-shadow:var(--sh1);overflow:hidden}
.card+.card{margin-top:16px}
.card-head{padding:13px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:10px}
.card-title{font-size:.87rem;font-weight:700;color:var(--tx);display:flex;align-items:center;gap:7px}
.card-body{padding:16px 18px}
.card-actions{display:flex;align-items:center;gap:7px}

/* ── Welcome banner ──────────────────────────────────── */
.welcome{background:linear-gradient(120deg,var(--navy) 0%,var(--navy3) 55%,var(--blue2) 100%);border-radius:var(--r3);padding:22px 26px;margin-bottom:20px;color:#fff;position:relative;overflow:hidden}
.welcome::before{content:'';position:absolute;top:-50px;right:-50px;width:220px;height:220px;border-radius:50%;background:rgba(255,255,255,.05)}
.welcome-title{font-size:1.3rem;font-weight:800;margin-bottom:3px;position:relative}
.welcome-sub{font-size:.81rem;color:rgba(255,255,255,.65);position:relative}
.welcome-alert{display:inline-flex;align-items:center;gap:8px;margin-top:10px;background:rgba(255,255,255,.14);border-radius:7px;padding:6px 14px;font-size:.8rem;position:relative}
.welcome-alert a{color:#fff;font-weight:700;text-decoration:underline}

/* ── Stats ───────────────────────────────────────────── */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:20px}
@media(max-width:880px){.stats{grid-template-columns:1fr 1fr}}
.stat{background:var(--card);border-radius:var(--r2);border:1px solid var(--border);padding:15px 17px;box-shadow:var(--sh1);position:relative;overflow:hidden;transition:box-shadow .2s,transform .2s}
.stat:hover{box-shadow:var(--sh2);transform:translateY(-1px)}
.stat::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;border-radius:var(--r2) var(--r2) 0 0}
.stat.cb::before{background:var(--blue)}.stat.cg::before{background:var(--ok)}
.stat.co::before{background:var(--warn)}.stat.cr::before{background:var(--err)}
.stat.cp::before{background:#8b5cf6}.stat.ct::before{background:#14b8a6}
.stat-val{font-size:1.6rem;font-weight:800;color:var(--tx);line-height:1;margin-bottom:3px}
.stat-val.blue{color:var(--blue)}.stat-val.green{color:var(--ok)}
.stat-val.orange{color:var(--warn)}.stat-val.red{color:var(--err)}
.stat-lbl{font-size:.73rem;color:var(--tx2);font-weight:500}
.stat-sub{font-size:.68rem;color:var(--tx3);margin-top:2px}

/* ── Buttons ─────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:5px;padding:7px 14px;border-radius:var(--r);font-size:.8rem;font-weight:600;cursor:pointer;border:none;text-decoration:none;transition:all .15s;font-family:inherit;line-height:1;white-space:nowrap}
.btn-primary{background:var(--navy);color:#fff}.btn-primary:hover{background:var(--navy3)}
.btn-blue{background:var(--blue);color:#fff}.btn-blue:hover{background:var(--blue2)}
.btn-success{background:var(--ok);color:#fff}.btn-success:hover{filter:brightness(1.08)}
.btn-warning{background:var(--warn);color:#fff}.btn-warning:hover{filter:brightness(1.08)}
.btn-danger{background:var(--err);color:#fff}.btn-danger:hover{filter:brightness(1.08)}
.btn-ghost{background:transparent;color:var(--tx2);border:1px solid var(--border2)}.btn-ghost:hover{background:var(--bg);color:var(--navy)}
.btn-sm{padding:5px 11px;font-size:.74rem}
.btn-lg{padding:10px 22px;font-size:.9rem}
.btn-icon{width:30px;height:30px;padding:0;justify-content:center;border-radius:7px}

/* ── Forms ───────────────────────────────────────────── */
.fg{margin-bottom:13px}
.fg label,.form-label{display:block;font-size:.75rem;font-weight:600;color:var(--tx2);margin-bottom:4px}
.fc,.form-control{width:100%;padding:8px 11px;border:1.5px solid var(--border2);border-radius:var(--r);background:#fff;color:var(--tx);font-size:.83rem;font-family:inherit;transition:border .15s,box-shadow .15s;outline:none}
.fc:focus,.form-control:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(65,105,200,.1)}
textarea.fc,textarea.form-control{resize:vertical}
select.fc,select.form-control{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'%3E%3Cpath fill='%2394a3b8' d='M10 14l-5-5h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 9px center;background-size:14px;padding-right:28px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:13px}
.form-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:13px}
.form-hint,.form-helper{font-size:.7rem;color:var(--tx3);margin-top:3px}
.required{color:var(--err)}

/* ── Tables ──────────────────────────────────────────── */
.tbl-wrap{overflow-x:auto}
.tbl{width:100%;border-collapse:collapse;font-size:.82rem}
.tbl thead th{padding:9px 14px;text-align:left;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--tx3);background:#f8f9fc;border-bottom:1px solid var(--border)}
.tbl tbody td{padding:11px 14px;border-bottom:1px solid #f0f3f9;vertical-align:middle}
.tbl tbody tr:last-child td{border:none}
.tbl tbody tr:hover td{background:#fafbfd}
.cm{font-weight:500;color:var(--tx)}.cs{font-size:.72rem;color:var(--tx3);margin-top:2px}

/* ── Badges ──────────────────────────────────────────── */
.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:20px;font-size:.69rem;font-weight:700;white-space:nowrap}
.badge-w{background:#fef9c3;color:#854d0e;border:1px solid #fde68a}
.badge-s{background:#dcfce7;color:#15803d;border:1px solid #bbf7d0}
.badge-d{background:#fee2e2;color:#b91c1c;border:1px solid #fecaca}
.badge-i{background:#dbeafe;color:#1d4ed8;border:1px solid #bfdbfe}
.badge-p{background:#ede9fe;color:#5b21b6;border:1px solid #ddd6fe}
.badge-g{background:#f1f5f9;color:#64748b;border:1px solid #e2e8f0}
.rbadge{display:inline-flex;align-items:center;padding:2px 7px;border-radius:5px;font-size:.68rem;font-weight:700}
.risk-l{background:#dcfce7;color:#15803d}.risk-m{background:#fef9c3;color:#854d0e}
.risk-h{background:#fee2e2;color:#b91c1c}.risk-c{background:#4c1d95;color:#fff}

/* ── Alerts ──────────────────────────────────────────── */
.alert{padding:10px 14px;border-radius:var(--r);margin-bottom:14px;display:flex;align-items:flex-start;gap:9px;font-size:.82rem}
.alert i{margin-top:1px;flex-shrink:0}
.alert-s{background:#dcfce7;color:#15803d;border:1px solid #bbf7d0}
.alert-d{background:#fee2e2;color:#b91c1c;border:1px solid #fecaca}
.alert-w{background:#fef9c3;color:#854d0e;border:1px solid #fde68a}
.alert-i{background:#dbeafe;color:#1e40af;border:1px solid #bfdbfe}
.alert-success{background:#dcfce7;color:#15803d;border:1px solid #bbf7d0}
.alert-danger{background:#fee2e2;color:#b91c1c;border:1px solid #fecaca}
.alert-warning{background:#fef9c3;color:#854d0e;border:1px solid #fde68a}
.alert-info{background:#dbeafe;color:#1e40af;border:1px solid #bfdbfe}

/* ── Modal ───────────────────────────────────────────── */
.overlay{position:fixed;inset:0;background:rgba(10,20,50,.55);backdrop-filter:blur(3px);z-index:1000;display:none;align-items:center;justify-content:center;padding:20px}
.overlay.show{display:flex}
.modal{background:#fff;border-radius:var(--r3);width:100%;max-width:540px;box-shadow:var(--sh3);animation:mIn .18s ease}
@keyframes mIn{from{opacity:0;transform:translateY(-10px) scale(.98)}}
.mhead{padding:15px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.mtitle{font-size:.9rem;font-weight:700}
.mclose{background:none;border:none;cursor:pointer;color:var(--tx3);font-size:1rem;padding:2px;line-height:1}
.mclose:hover{color:var(--tx)}
.mbody{padding:16px 18px;max-height:65vh;overflow-y:auto}
.mfoot{padding:12px 18px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:8px}

/* ── Pagination ──────────────────────────────────────── */
.pgn{display:flex;align-items:center;justify-content:space-between;padding:12px 18px;border-top:1px solid var(--border)}
.pgn-btns{display:flex;gap:3px}
.pgn-btn{width:30px;height:30px;border-radius:var(--r);background:var(--bg);color:var(--tx2);display:flex;align-items:center;justify-content:center;text-decoration:none;font-size:.77rem;font-weight:500;border:1px solid var(--border2);transition:all .13s}
.pgn-btn:hover,.pgn-btn.on{background:var(--navy);color:#fff;border-color:var(--navy)}
.pgn-info{font-size:.72rem;color:var(--tx3)}

/* ── Filter tabs ─────────────────────────────────────── */
.ftabs{display:flex;gap:4px;margin-bottom:15px;flex-wrap:wrap}
.ftab{padding:6px 12px;border-radius:7px;background:var(--card);color:var(--tx2);text-decoration:none;font-size:.77rem;font-weight:500;border:1px solid var(--border2);display:inline-flex;align-items:center;gap:5px;transition:all .13s}
.ftab:hover{border-color:var(--blue);color:var(--blue);background:#eef2fb}
.ftab.on{background:var(--navy);color:#fff;border-color:var(--navy)}
.ftab em{background:rgba(0,0,0,.1);border-radius:20px;padding:0 5px;font-size:.64rem;font-weight:700;font-style:normal}
.ftab.on em{background:rgba(255,255,255,.25)}

/* ── Approve checklist row ───────────────────────────── */
.cl-cat{padding:7px 16px;font-size:.67rem;font-weight:700;text-transform:uppercase;letter-spacing:.7px;color:var(--tx3);background:#f8f9fc;border-top:1px solid var(--border)}
.cl-row{display:flex;align-items:center;padding:9px 16px;border-bottom:1px solid #f0f3f9;gap:10px}
.cl-row:last-child{border:none}
.cl-text{flex:1;font-size:.82rem}
.cl-btns{display:flex;gap:3px;flex-shrink:0}
.cl-btn{padding:3px 9px;border-radius:5px;font-size:.7rem;font-weight:600;cursor:pointer;border:1.5px solid var(--border2);background:#f8f9fc;font-family:inherit;transition:all .13s}
.cl-btn.p{border-color:#bbf7d0;color:#15803d;background:#dcfce7}
.cl-btn.f{border-color:#fecaca;color:#b91c1c;background:#fee2e2}
.cl-btn.n{color:var(--tx3)}
.cl-btn.p.on{background:var(--ok);color:#fff;border-color:var(--ok)}
.cl-btn.f.on{background:var(--err);color:#fff;border-color:var(--err)}
.cl-btn.n.on{background:#64748b;color:#fff;border-color:#64748b}

/* ── Permit list (approvals) ─────────────────────────── */
.plist-item{padding:13px 16px;border-bottom:1px solid #f0f3f9;cursor:pointer;transition:background .12s}
.plist-item:hover{background:#f4f7ff}
.plist-item.on{background:#eef2fb;border-left:3px solid var(--navy)}
.plist-item.urgent{border-left:3px solid var(--err)}
.pno{font-family:monospace;font-weight:700;color:var(--navy);font-size:.83rem}
.detail-panel{background:var(--card);border-radius:var(--r2);border:1px solid var(--border);min-height:400px}

/* ── Worker picker ───────────────────────────────────── */
.worker-list{max-height:260px;overflow-y:auto;border:1.5px solid var(--border2);border-radius:var(--r);padding:6px}
.worker-opt{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:6px;cursor:pointer;margin-bottom:3px;transition:background .12s}
.worker-opt:hover{background:#f0f4ff}
.worker-opt:has(input:checked){background:#f0fdf4;border:1px solid #bbf7d0}
.worker-opt input{width:15px;height:15px;accent-color:var(--navy);flex-shrink:0}
.wbadge{font-size:.68rem;padding:2px 8px;border-radius:20px;font-weight:600;flex-shrink:0}
.wbadge.ok{background:#dcfce7;color:#15803d}
.wbadge.no{background:#fef9c3;color:#854d0e}

/* ── Step bar ────────────────────────────────────────── */
.steps{display:flex;gap:0;margin-bottom:22px}
.step{flex:1;text-align:center;position:relative}
.step-n{width:30px;height:30px;border-radius:50%;background:var(--border);color:var(--tx3);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.8rem;margin:0 auto 5px;transition:all .2s}
.step.on .step-n{background:var(--navy);color:#fff}
.step.done .step-n{background:var(--ok);color:#fff}
.step-l{font-size:.7rem;color:var(--tx3)}
.step.on .step-l{color:var(--navy);font-weight:600}
.step::after{content:'';position:absolute;top:15px;left:50%;right:-50%;height:2px;background:var(--border);z-index:-1}
.step:last-child::after{display:none}
.step.done::after{background:var(--ok)}

/* ── Timeline ────────────────────────────────────────── */
.tl{padding:14px 18px}
.tl-item{display:flex;gap:11px;padding-bottom:18px;position:relative}
.tl-item:not(:last-child)::before{content:'';position:absolute;left:9px;top:20px;bottom:0;width:2px;background:var(--border)}
.tl-dot{width:20px;height:20px;border-radius:50%;flex-shrink:0;margin-top:2px}
.tl-dot.sub{background:var(--blue)}.tl-dot.ok{background:var(--ok)}
.tl-dot.no{background:var(--err)}.tl-dot.act{background:var(--warn)}.tl-dot.done{background:#8b5cf6}
.tl-t{font-weight:600;font-size:.83rem}.tl-s{font-size:.73rem;color:var(--tx3)}.tl-d{font-size:.7rem;color:var(--tx3);margin-top:1px}

/* ── QR box ──────────────────────────────────────────── */
.qr-box{text-align:center;padding:16px}
#qrcode{display:inline-block;padding:10px;background:#fff;border-radius:8px;border:1.5px solid var(--border)}
.qr-no{font-family:monospace;font-weight:700;font-size:.87rem;margin-top:8px;color:var(--tx)}

/* ── Utility ─────────────────────────────────────────── */
.tag{display:inline-flex;align-items:center;padding:2px 7px;border-radius:5px;background:#f0f3f9;border:1px solid var(--border2);font-size:.72rem;color:var(--tx2);font-weight:500}
.pno-link{color:var(--navy);font-family:monospace;font-weight:700;text-decoration:none;font-size:.81rem}
.pno-link:hover{text-decoration:underline;color:var(--blue)}
.act-btns{display:flex;gap:4px}
.g12{display:grid;gap:12px}
.g14{display:grid;gap:14px}
.mt14{margin-top:14px}.mt20{margin-top:20px}
.mb14{margin-bottom:14px}
.txt-muted{color:var(--tx3)}
.txt-sm{font-size:.78rem}
.fw6{font-weight:600}.fw7{font-weight:700}
.empty{padding:50px 20px;text-align:center;color:var(--tx3)}
.empty i{font-size:2.4rem;display:block;margin-bottom:12px;opacity:.3}

/* ── Auth pages ──────────────────────────────────────── */
body.auth{display:block;background:#f0f3fa;min-height:100vh}
.auth-wrap{display:flex;min-height:100vh}
.auth-side{width:400px;min-height:100vh;background:linear-gradient(160deg,var(--navy) 0%,#24387a 60%,#2e52a8 100%);display:flex;flex-direction:column;padding:44px 40px;position:relative;overflow:hidden;flex-shrink:0}
.auth-side::before{content:'';position:absolute;top:-90px;right:-60px;width:260px;height:260px;border-radius:50%;background:rgba(255,255,255,.05)}
.auth-side::after{content:'';position:absolute;bottom:-70px;left:-50px;width:200px;height:200px;border-radius:50%;background:rgba(255,255,255,.04)}
.auth-logo{z-index:1}
.auth-logo img{height:36px;width:auto;margin-bottom:14px;display:block;background:#fff;border-radius:6px;padding:4px 10px}
.auth-logo-name{font-size:1.45rem;font-weight:800;color:#fff}
.auth-logo-sub{font-size:.8rem;color:rgba(255,255,255,.55);margin-top:2px}
.auth-feats{margin-top:auto;z-index:1}
.auth-feat{display:flex;align-items:center;gap:11px;padding:11px 13px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.1);border-radius:8px;margin-bottom:8px;color:rgba(255,255,255,.88);font-size:.8rem}
.auth-feat-ic{font-size:1.05rem;flex-shrink:0}
.auth-main{flex:1;display:flex;align-items:center;justify-content:center;padding:34px;background:#f0f3fa}
.auth-card{background:#fff;border-radius:var(--r3);padding:36px;width:100%;max-width:420px;box-shadow:0 8px 40px rgba(26,45,79,.12);border:1px solid var(--border)}
.auth-card-logo{display:flex;align-items:center;gap:9px;margin-bottom:24px}
.auth-card-logo img{height:26px;width:auto;background:#fff;border-radius:5px;padding:2px 6px}
.auth-card-name{font-size:.93rem;font-weight:800;color:var(--navy)}
.auth-card-sub{font-size:.67rem;color:var(--tx3);text-transform:uppercase;letter-spacing:.5px}
.auth-inp{position:relative}
.auth-inp i{position:absolute;left:11px;top:50%;transform:translateY(-50%);color:var(--tx3);font-size:.85rem}
.auth-inp .fc{padding-left:33px;height:41px;font-size:.86rem}
.auth-submit{width:100%;height:42px;background:var(--navy);color:#fff;border:none;border-radius:var(--r);font-size:.9rem;font-weight:700;cursor:pointer;font-family:inherit;transition:background .15s;margin-top:6px}
.auth-submit:hover{background:var(--navy3)}
.auth-foot{text-align:center;font-size:.74rem;color:var(--tx3);margin-top:15px}
.auth-foot a{color:var(--blue);text-decoration:none;font-weight:600}
.demo-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-top:10px}
.demo-btn{padding:7px 8px;border-radius:7px;border:1.5px solid var(--border2);background:var(--bg);cursor:pointer;text-align:left;font-family:inherit;transition:all .13s}
.demo-btn:hover{border-color:var(--blue);background:#eef2fb}
.demo-r{font-size:.62rem;color:var(--tx3);text-transform:uppercase;letter-spacing:.4px}
.demo-n{font-weight:700;color:var(--tx);font-size:.78rem}
@media(max-width:680px){.auth-side{display:none}}

/* ── Role cards (register) ───────────────────────────── */
.role-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:14px}
.role-card{padding:12px;border-radius:8px;border:2px solid var(--border2);cursor:pointer;text-align:center;transition:all .13s;position:relative}
.role-card:hover{border-color:var(--blue);background:#eef2fb}
.role-card input{display:none}
.role-card.on{border-color:var(--navy);background:#eef2fb}
.role-card.on::after{content:'✓';position:absolute;top:5px;right:7px;font-size:.74rem;color:var(--navy);font-weight:800}
.role-ic{font-size:1.4rem;margin-bottom:4px}
.role-name{font-size:.76rem;font-weight:700;color:var(--tx)}
.role-desc{font-size:.66rem;color:var(--tx3);margin-top:2px}

/* ── Users admin table ───────────────────────────────── */
.role-pill{display:inline-flex;align-items:center;padding:2px 9px;border-radius:20px;font-size:.69rem;font-weight:700;gap:4px}
.rp-admin{background:#4c1d95;color:#fff}.rp-jpr{background:#1d4ed8;color:#fff}
.rp-contractor{background:#854d0e;color:#fef9c3;border:1px solid #fde68a}
.rp-security{background:#0f766e;color:#ccfbf1;border:1px solid #99f6e4}

/* ── Scan page ───────────────────────────────────────── */
.scan-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;align-items:start}
@media(max-width:760px){.scan-grid{grid-template-columns:1fr}}
.scan-box{border:2px dashed var(--border2);border-radius:var(--r2);padding:24px;text-align:center;color:var(--tx3);background:#f8f9fc}
.checkin-row{display:flex;align-items:center;justify-content:space-between;padding:9px 0;border-bottom:1px solid #f0f3f9}
.checkin-row:last-child{border:none}
.ci-in{background:#dcfce7;color:#15803d;font-size:.72rem;font-weight:700;padding:2px 8px;border-radius:20px}
.ci-out{background:#f1f5f9;color:#64748b;font-size:.72rem;font-weight:700;padding:2px 8px;border-radius:20px}

/* ── Permit view ─────────────────────────────────────── */
.view-grid{display:grid;grid-template-columns:1fr 290px;gap:16px;align-items:start}
@media(max-width:860px){.view-grid{grid-template-columns:1fr}}
.view-col{display:flex;flex-direction:column;gap:14px}
.permit-hdr-card{background:var(--card);border-radius:var(--r2);border:1px solid var(--border);padding:15px 18px;margin-bottom:14px;display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;box-shadow:var(--sh1)}
.permit-chip{background:var(--navy);color:#fff;border-radius:6px;padding:5px 12px;font-family:monospace;font-size:.9rem;font-weight:700}
.permit-meta{display:flex;gap:12px;flex-wrap:wrap;font-size:.77rem;color:var(--tx2)}
.permit-meta span{display:flex;align-items:center;gap:4px}
.dg{display:grid;grid-template-columns:1fr 1fr}
.di{padding:10px 16px;border-bottom:1px solid #f0f3f9}
.di.full{grid-column:1/-1}
.di label{display:block;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:var(--tx3);margin-bottom:2px}
.di value{display:block;font-weight:500;font-size:.84rem}

/* ── Mini stats ──────────────────────────────────────── */
.mini-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:18px}
@media(max-width:680px){.mini-stats{grid-template-columns:1fr 1fr}}
.ms{background:var(--card);border-radius:10px;border:1px solid var(--border);padding:13px 15px}
.ms.d{border-left:3px solid var(--err)}.ms.s{border-left:3px solid var(--ok)}.ms.w{border-left:3px solid var(--warn)}
.ms-val{font-size:1.5rem;font-weight:800;color:var(--tx);line-height:1}
.ms-lbl{font-size:.72rem;color:var(--tx3);margin-top:2px}

/* ── Induction ───────────────────────────────────────── */
.ind-grid{display:grid;grid-template-columns:260px 1fr;gap:16px;align-items:start}
@media(max-width:800px){.ind-grid{grid-template-columns:1fr}}
.course-item{display:flex;align-items:center;gap:9px;padding:10px 13px;border-bottom:1px solid #f0f3f9;text-decoration:none;color:var(--tx);transition:background .12s}
.course-item:hover,.course-item.on{background:#eef2fb}
.course-item.on{border-left:3px solid var(--navy)}
.ci-icon{width:28px;height:28px;background:#eef2fb;border-radius:6px;display:flex;align-items:center;justify-content:center;color:var(--navy);flex-shrink:0;font-size:.8rem}
.ci-nm{font-weight:500;font-size:.81rem}.ci-mt{font-size:.7rem;color:var(--tx3)}
.q-opt{display:flex;align-items:center;gap:8px;padding:8px 11px;border-radius:7px;cursor:pointer;border:1.5px solid var(--border2);margin-bottom:6px;transition:all .13s}
.q-opt:hover{border-color:var(--blue);background:#eef2fb}
.q-opt input{display:none}
.q-opt:has(input:checked){border-color:var(--navy);background:#eef2fb}
.q-letter{width:24px;height:24px;border-radius:50%;background:#f0f3f9;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.72rem;flex-shrink:0;transition:all .13s}
.q-opt:has(input:checked) .q-letter{background:var(--navy);color:#fff}

/* ── Notifications ───────────────────────────────────── */
.notif-item{display:flex;align-items:flex-start;gap:11px;padding:12px 17px;border-bottom:1px solid #f0f3f9;text-decoration:none;color:var(--tx);transition:background .12s;position:relative}
.notif-item:hover{background:#fafbfd}
.notif-item.unread{background:#f4f7ff}
.notif-ic{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:.95rem;flex-shrink:0}
.notif-t{font-weight:600;font-size:.83rem;margin-bottom:2px}
.notif-m{color:var(--tx3);font-size:.76rem;margin-bottom:3px}
.notif-d{font-size:.68rem;color:var(--tx3)}
.unread-dot{width:8px;height:8px;background:var(--blue);border-radius:50%;flex-shrink:0;margin-top:5px}

/* ── Reports ─────────────────────────────────────────── */
.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:18px}
@media(max-width:860px){.kpi-grid{grid-template-columns:1fr 1fr}}
.bar-chart{display:flex;align-items:flex-end;gap:8px;height:100px}
.bar-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px}
.bar{width:100%;background:var(--blue);border-radius:4px 4px 0 0;min-height:2px;opacity:.85;transition:height .4s}
.bar:hover{opacity:1}
.bar-lbl{font-size:.63rem;color:var(--tx3)}
.bar-val{font-size:.68rem;font-weight:700;color:var(--navy)}

/* ── Responsive ──────────────────────────────────────── */
@media(max-width:860px){
  .sidebar{transform:translateX(-100%)}
  .sidebar.open{transform:translateX(0)}
  .main{margin-left:0}
  .sidebar-toggle{display:block}
  .stats{grid-template-columns:1fr 1fr}
  .form-row{grid-template-columns:1fr}
}


/* ── datetime-local: hide AM/PM (Chrome Windows) ────────── */
input[type="datetime-local"]::-webkit-datetime-edit-ampm-field,
input[type="time"]::-webkit-datetime-edit-ampm-field {
  display: none !important;
  width: 0 !important;
  visibility: hidden !important;
}
