/* ============================================================
   TransLogix — Courier & Transport Management — Design System
   ============================================================ */
:root{
  --c-bg:#f4f6fb; --c-surface:#ffffff; --c-surface-2:#f8fafc;
  --c-ink:#0f1b34; --c-ink-2:#475069; --c-ink-3:#8a93a8; --c-line:#e6e9f2;
  --c-primary:#1b3a8f; --c-primary-2:#2a52d4; --c-primary-soft:#eaf0ff;
  --c-accent:#ff6a2b; --c-accent-soft:#fff0e8;
  --c-green:#1e9e6a; --c-green-soft:#e6f7ef;
  --c-amber:#c7860a; --c-amber-soft:#fdf3e0;
  --c-red:#d83a3a; --c-red-soft:#fdeaea;
  --c-blue:#2563c9; --c-blue-soft:#e8f0fd;
  --c-purple:#6b46c1; --c-purple-soft:#efe9fb;
  --r-sm:6px; --r:10px; --r-lg:16px;
  --sh-sm:0 1px 2px rgba(15,27,52,.06); --sh:0 4px 16px rgba(15,27,52,.08);
  --sh-lg:0 12px 40px rgba(15,27,52,.14);
  --side-w:248px; --top-h:60px;
  --ff:'Inter',system-ui,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:var(--ff);background:var(--c-bg);color:var(--c-ink);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}
a{color:var(--c-primary-2);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3,h4{margin:0;font-weight:700;letter-spacing:-.01em}
small{color:var(--c-ink-3)}
.muted{color:var(--c-ink-3)}
.mono{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace}

/* ---------- Layout shell ---------- */
.app{display:flex;min-height:100vh}
.sidebar{width:var(--side-w);background:#0d1b3d;color:#cdd6f0;position:fixed;inset:0 auto 0 0;display:flex;flex-direction:column;z-index:40;transition:transform .2s}
.brand{display:flex;align-items:center;gap:10px;padding:16px 18px;border-bottom:1px solid rgba(255,255,255,.08)}
.brand .logo{width:34px;height:34px;border-radius:9px;background:linear-gradient(135deg,var(--c-accent),#ffb061);display:grid;place-items:center;font-weight:800;color:#fff;box-shadow:var(--sh-sm)}
.brand b{color:#fff;font-size:16px;letter-spacing:-.02em}
.brand span{display:block;font-size:11px;color:#8ea0cf}
.nav{flex:1;overflow-y:auto;padding:10px 10px 20px}
.nav-group{margin-top:14px}
.nav-group>.lbl{font-size:10.5px;text-transform:uppercase;letter-spacing:.09em;color:#6f80b0;padding:6px 10px}
.nav a{display:flex;align-items:center;gap:11px;padding:9px 11px;border-radius:8px;color:#c3cdea;font-weight:500;font-size:13.5px;margin:1px 0}
.nav a:hover{background:rgba(255,255,255,.06);text-decoration:none;color:#fff}
.nav a.active{background:linear-gradient(90deg,var(--c-primary-2),#3a63e6);color:#fff;box-shadow:var(--sh-sm)}
.nav a .ic{width:18px;text-align:center;font-size:15px;opacity:.95}
.nav a .badge{margin-left:auto}
.side-foot{padding:12px;border-top:1px solid rgba(255,255,255,.08);font-size:11px;color:#7e8fc0}

.main{flex:1;margin-left:var(--side-w);min-width:0;display:flex;flex-direction:column}
.topbar{height:var(--top-h);background:var(--c-surface);border-bottom:1px solid var(--c-line);display:flex;align-items:center;gap:14px;padding:0 20px;position:sticky;top:0;z-index:30}
.topbar .hamb{display:none;border:0;background:transparent;font-size:20px;cursor:pointer}
.search{flex:1;max-width:460px;position:relative}
.search input{width:100%;min-width:0;padding:9px 12px 9px 34px;border:1px solid var(--c-line);border-radius:9px;background:var(--c-surface-2);font-size:13.5px}
.search input:focus{outline:none;border-color:var(--c-primary-2);background:#fff}
.search .si{position:absolute;left:11px;top:9px;color:var(--c-ink-3)}
.search-pop{position:absolute;top:42px;left:0;right:0;background:#fff;border:1px solid var(--c-line);border-radius:10px;box-shadow:var(--sh-lg);padding:6px;display:none;max-height:340px;overflow:auto}
.search-pop a{display:block;padding:8px 10px;border-radius:7px;color:var(--c-ink)}
.search-pop a:hover{background:var(--c-primary-soft);text-decoration:none}
.search-pop .cat{font-size:10px;text-transform:uppercase;color:var(--c-ink-3);padding:8px 10px 2px;letter-spacing:.06em}
.top-actions{display:flex;align-items:center;gap:8px;margin-left:auto}
.icon-btn{position:relative;width:38px;height:38px;border-radius:9px;border:1px solid var(--c-line);background:#fff;cursor:pointer;font-size:16px;display:grid;place-items:center;color:var(--c-ink-2)}
.icon-btn:hover{border-color:var(--c-primary-2);color:var(--c-primary-2)}
.icon-btn .dot{position:absolute;top:-3px;right:-3px;background:var(--c-accent);color:#fff;font-size:10px;border-radius:20px;padding:1px 5px;font-weight:700}
.role-pick{display:flex;align-items:center;gap:8px;border:1px solid var(--c-line);border-radius:9px;padding:5px 10px;background:#fff}
.role-pick select{border:0;background:transparent;font-weight:600;font-size:13px;color:var(--c-ink);cursor:pointer}
.role-pick select:focus{outline:none}
.avatar{width:34px;height:34px;border-radius:50%;background:var(--c-primary);color:#fff;display:grid;place-items:center;font-weight:700;font-size:13px}

.dropdown{position:relative}
.menu{position:absolute;right:0;top:46px;background:#fff;border:1px solid var(--c-line);border-radius:11px;box-shadow:var(--sh-lg);min-width:230px;padding:7px;display:none;z-index:50}
.menu.open{display:block}
.menu a,.menu button{display:flex;align-items:center;gap:10px;width:100%;text-align:left;padding:9px 10px;border-radius:8px;border:0;background:transparent;color:var(--c-ink);font-size:13.5px;cursor:pointer;font-family:var(--ff)}
.menu a:hover,.menu button:hover{background:var(--c-primary-soft);text-decoration:none}
.menu .hd{font-size:10.5px;text-transform:uppercase;letter-spacing:.06em;color:var(--c-ink-3);padding:8px 10px 3px}

/* ---------- Page ---------- */
.content{padding:22px 26px 60px;max-width:1320px;width:100%;margin:0 auto}
.crumbs{display:flex;align-items:center;gap:7px;font-size:12.5px;color:var(--c-ink-3);margin-bottom:12px;flex-wrap:wrap}
.crumbs a{color:var(--c-ink-2)}
.crumbs .sep{opacity:.5}
.page-head{display:flex;align-items:flex-start;gap:16px;margin-bottom:20px;flex-wrap:wrap}
.page-head .ph-title h1{font-size:23px}
.page-head .ph-title p{margin:4px 0 0;color:var(--c-ink-2);font-size:13.5px}
.page-head .ph-actions{margin-left:auto;display:flex;gap:9px;flex-wrap:wrap}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:7px;padding:9px 15px;border-radius:9px;border:1px solid var(--c-line);background:#fff;color:var(--c-ink);font-weight:600;font-size:13.5px;cursor:pointer;font-family:var(--ff);transition:.12s;text-decoration:none}
.btn:hover{border-color:var(--c-primary-2);color:var(--c-primary-2);text-decoration:none}
.btn-primary{background:var(--c-primary-2);border-color:var(--c-primary-2);color:#fff}
.btn-primary:hover{background:#1f44bd;color:#fff}
.btn-accent{background:var(--c-accent);border-color:var(--c-accent);color:#fff}
.btn-accent:hover{background:#ec5d22;color:#fff}
.btn-ghost{background:transparent;border-color:transparent}
.btn-sm{padding:6px 11px;font-size:12.5px}
.btn-block{width:100%;justify-content:center}
.btn[disabled]{opacity:.5;cursor:not-allowed}

/* ---------- Cards / grid ---------- */
.grid{display:grid;gap:16px}
.cols-2{grid-template-columns:repeat(2,1fr)}
.cols-3{grid-template-columns:repeat(3,1fr)}
.cols-4{grid-template-columns:repeat(4,1fr)}
.card{background:var(--c-surface);border:1px solid var(--c-line);border-radius:var(--r-lg);box-shadow:var(--sh-sm)}
.card-pad{padding:18px}
.card-head{display:flex;align-items:center;gap:10px;padding:15px 18px;border-bottom:1px solid var(--c-line)}
.card-head h3{font-size:15px}
.card-head .ch-actions{margin-left:auto;display:flex;gap:8px}
.card-body{padding:18px}

.kpi{position:relative;overflow:hidden}
.kpi .kpi-ic{position:absolute;right:14px;top:14px;width:42px;height:42px;border-radius:12px;display:grid;place-items:center;font-size:20px}
.kpi .kpi-lbl{font-size:12.5px;color:var(--c-ink-2);font-weight:600}
.kpi .kpi-val{font-size:27px;font-weight:800;letter-spacing:-.02em;margin:6px 0 2px}
.kpi .kpi-sub{font-size:12px;font-weight:600}
.up{color:var(--c-green)} .down{color:var(--c-red)}
.drag-handle{cursor:grab}

/* ---------- Badges / pills ---------- */
.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:30px;font-size:11.5px;font-weight:700;line-height:1.4}
.b-green{background:var(--c-green-soft);color:var(--c-green)}
.b-amber{background:var(--c-amber-soft);color:var(--c-amber)}
.b-red{background:var(--c-red-soft);color:var(--c-red)}
.b-blue{background:var(--c-blue-soft);color:var(--c-blue)}
.b-purple{background:var(--c-purple-soft);color:var(--c-purple)}
.b-gray{background:#eef1f7;color:var(--c-ink-2)}
.b-accent{background:var(--c-accent-soft);color:var(--c-accent)}
.dot-i{width:7px;height:7px;border-radius:50%;display:inline-block}

/* ---------- Tables ---------- */
.table-wrap{overflow-x:auto}
table.tbl{width:100%;border-collapse:collapse;font-size:13.5px}
.tbl thead th{text-align:left;padding:11px 14px;background:var(--c-surface-2);color:var(--c-ink-2);font-size:11.5px;text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--c-line);white-space:nowrap;cursor:pointer;user-select:none}
.tbl thead th .sort{opacity:.4;font-size:10px}
.tbl tbody td{padding:12px 14px;border-bottom:1px solid var(--c-line);vertical-align:middle}
.tbl tbody tr:hover{background:var(--c-primary-soft)}
.tbl tbody tr{cursor:pointer}
.tbl .num{text-align:right;font-variant-numeric:tabular-nums}
.table-toolbar{display:flex;align-items:center;gap:10px;padding:13px 16px;flex-wrap:wrap}
.table-toolbar .tt-search{position:relative;flex:1;min-width:200px;max-width:320px}
.table-toolbar .tt-search input{width:100%;padding:8px 10px 8px 30px;border:1px solid var(--c-line);border-radius:8px;font-size:13px}
.table-toolbar .tt-search .si{position:absolute;left:9px;top:8px;color:var(--c-ink-3)}
.chip{display:inline-flex;align-items:center;gap:6px;padding:6px 11px;border:1px solid var(--c-line);border-radius:30px;font-size:12.5px;background:#fff;cursor:pointer;font-weight:600;color:var(--c-ink-2)}
.chip.on{background:var(--c-primary-soft);border-color:var(--c-primary-2);color:var(--c-primary-2)}
.pager{display:flex;align-items:center;gap:6px;padding:12px 16px;justify-content:flex-end;font-size:13px;color:var(--c-ink-2)}
.pager button{min-width:32px;height:32px;border:1px solid var(--c-line);background:#fff;border-radius:7px;cursor:pointer}
.pager button.on{background:var(--c-primary-2);color:#fff;border-color:var(--c-primary-2)}

/* ---------- Forms ---------- */
.form-grid{display:grid;gap:16px}
.field{display:flex;flex-direction:column;gap:6px}
.field label{font-size:12.5px;font-weight:600;color:var(--c-ink-2)}
.field label .req{color:var(--c-red)}
.field input,.field select,.field textarea{padding:9px 11px;border:1px solid var(--c-line);border-radius:8px;font-size:13.5px;font-family:var(--ff);background:#fff;width:100%}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--c-primary-2);box-shadow:0 0 0 3px rgba(42,82,212,.12)}
.field .hint{font-size:11.5px;color:var(--c-ink-3)}
.field .err{font-size:11.5px;color:var(--c-red)}
.field.invalid input{border-color:var(--c-red)}
.section-title{font-size:13px;font-weight:700;color:var(--c-primary);text-transform:uppercase;letter-spacing:.05em;margin:6px 0 2px;display:flex;align-items:center;gap:9px}
.section-title .n{width:22px;height:22px;border-radius:50%;background:var(--c-primary);color:#fff;display:grid;place-items:center;font-size:12px}
.fs{border:1px solid var(--c-line);border-radius:12px;padding:18px;margin-bottom:16px}
.autosave{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--c-green);font-weight:600}

/* ---------- Alerts / toasts ---------- */
.alert{display:flex;gap:11px;padding:13px 15px;border-radius:11px;border:1px solid var(--c-line);background:#fff;align-items:flex-start}
.alert .ai{font-size:17px;margin-top:1px}
.alert.ok{background:var(--c-green-soft);border-color:#bfe8d4} .alert.ok .ai{color:var(--c-green)}
.alert.warn{background:var(--c-amber-soft);border-color:#f3e0b8} .alert.warn .ai{color:var(--c-amber)}
.alert.err{background:var(--c-red-soft);border-color:#f3c9c9} .alert.err .ai{color:var(--c-red)}
.alert.info{background:var(--c-blue-soft);border-color:#cfe0f8} .alert.info .ai{color:var(--c-blue)}
.toast-wrap{position:fixed;bottom:22px;right:22px;display:flex;flex-direction:column;gap:10px;z-index:90}
.toast{background:#0d1b3d;color:#fff;padding:13px 18px;border-radius:11px;box-shadow:var(--sh-lg);display:flex;gap:10px;align-items:center;animation:slidein .25s;font-size:13.5px;font-weight:500;max-width:calc(100vw - 44px)}
.toast .tk{color:var(--c-green)}
@keyframes slidein{from{transform:translateY(12px);opacity:0}to{transform:none;opacity:1}}

/* ---------- Modal ---------- */
.modal-back{position:fixed;inset:0;background:rgba(13,27,61,.5);display:none;align-items:center;justify-content:center;z-index:80;padding:20px}
.modal-back.open{display:flex}
.modal{background:#fff;border-radius:16px;box-shadow:var(--sh-lg);width:100%;max-width:560px;max-height:90vh;overflow:auto}
.modal-head{display:flex;align-items:center;padding:16px 20px;border-bottom:1px solid var(--c-line)}
.modal-head h3{font-size:16px}
.modal-head .x{margin-left:auto;border:0;background:transparent;font-size:20px;cursor:pointer;color:var(--c-ink-3)}
.modal-body{padding:20px}
.modal-foot{display:flex;gap:10px;justify-content:flex-end;padding:14px 20px;border-top:1px solid var(--c-line)}

/* ---------- Timeline (tracking) ---------- */
.timeline{position:relative;padding-left:30px}
.timeline:before{content:"";position:absolute;left:9px;top:6px;bottom:6px;width:2px;background:var(--c-line)}
.tl-step{position:relative;padding:0 0 22px}
.tl-step .nub{position:absolute;left:-30px;top:1px;width:20px;height:20px;border-radius:50%;background:#fff;border:2px solid var(--c-line);display:grid;place-items:center;font-size:10px;color:var(--c-ink-3)}
.tl-step.done .nub{background:var(--c-green);border-color:var(--c-green);color:#fff}
.tl-step.curr .nub{background:var(--c-accent);border-color:var(--c-accent);color:#fff;box-shadow:0 0 0 4px var(--c-accent-soft)}
.tl-step .t-title{font-weight:700;font-size:13.5px}
.tl-step .t-meta{font-size:12px;color:var(--c-ink-3);margin-top:2px}
.tl-step.todo{opacity:.55}

/* progress steps (forms / workflow) */
.steps{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:18px}
.steps .st{display:flex;align-items:center;gap:8px;padding:7px 13px;border:1px solid var(--c-line);border-radius:30px;font-size:12.5px;font-weight:600;color:var(--c-ink-3);background:#fff}
.steps .st .n{width:20px;height:20px;border-radius:50%;background:#eef1f7;display:grid;place-items:center;font-size:11px}
.steps .st.on{border-color:var(--c-primary-2);color:var(--c-primary-2);background:var(--c-primary-soft)}
.steps .st.on .n{background:var(--c-primary-2);color:#fff}
.steps .st.done{color:var(--c-green)} .steps .st.done .n{background:var(--c-green);color:#fff}

/* ---------- Misc ---------- */
.split{display:grid;grid-template-columns:1.6fr 1fr;gap:16px}
.list-row{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid var(--c-line)}
.list-row:last-child{border-bottom:0}
.list-row .lr-ic{width:36px;height:36px;border-radius:10px;display:grid;place-items:center;font-size:16px;flex-shrink:0}
.kv{display:grid;grid-template-columns:140px 1fr;gap:8px 14px;font-size:13.5px}
.kv dt{color:var(--c-ink-3);font-weight:600}
.kv dd{margin:0;font-weight:600}
.tag{display:inline-block;padding:2px 8px;border-radius:6px;background:var(--c-surface-2);border:1px solid var(--c-line);font-size:12px;font-weight:600}
.barcode{height:54px;background:repeating-linear-gradient(90deg,#0d1b3d 0 2px,#fff 2px 4px,#0d1b3d 4px 5px,#fff 5px 9px);border-radius:4px}
.qr{width:96px;height:96px;border-radius:8px;background:
  conic-gradient(#0d1b3d 90deg,#fff 0 180deg,#0d1b3d 0 270deg,#fff 0) ,
  repeating-conic-gradient(#0d1b3d 0 25%,#fff 0 50%) 0 0/22px 22px;border:5px solid #fff;box-shadow:inset 0 0 0 2px #0d1b3d}
.map-mock{height:280px;border-radius:14px;background:
  linear-gradient(rgba(27,58,143,.06),rgba(27,58,143,.06)),
  repeating-linear-gradient(0deg,#e9edf6 0 1px,transparent 1px 38px),
  repeating-linear-gradient(90deg,#e9edf6 0 1px,transparent 1px 38px),#f1f4fb;
  position:relative;border:1px solid var(--c-line);overflow:hidden}
.map-mock .pin{position:absolute;transform:translate(-50%,-100%);font-size:22px;filter:drop-shadow(0 3px 4px rgba(0,0,0,.2))}
.map-mock .route-line{position:absolute;height:3px;background:repeating-linear-gradient(90deg,var(--c-accent) 0 10px,transparent 10px 18px);border-radius:3px}
.bar-chart{display:flex;align-items:flex-end;gap:10px;height:170px;padding-top:10px}
.bar-chart .bar{flex:1;background:linear-gradient(180deg,var(--c-primary-2),#6c8cf0);border-radius:7px 7px 0 0;position:relative;min-width:14px;transition:.2s}
.bar-chart .bar:hover{filter:brightness(1.08)}
.bar-chart .bar span{position:absolute;bottom:-20px;left:0;right:0;text-align:center;font-size:11px;color:var(--c-ink-3)}
.donut{width:150px;height:150px;border-radius:50%;background:conic-gradient(var(--c-primary-2) 0 55%,var(--c-accent) 0 78%,var(--c-green) 0 92%,var(--c-amber) 0);position:relative;margin:0 auto}
.donut:after{content:"";position:absolute;inset:26px;background:#fff;border-radius:50%}
.legend{display:flex;flex-direction:column;gap:8px;font-size:13px}
.legend i{width:11px;height:11px;border-radius:3px;display:inline-block;margin-right:8px}
.spark{height:46px;display:flex;align-items:flex-end;gap:3px}
.spark i{flex:1;background:var(--c-primary-soft);border-radius:2px}

.empty{text-align:center;padding:40px 20px;color:var(--c-ink-3)}
.empty .ei{font-size:34px;margin-bottom:8px}
hr.sep{border:0;border-top:1px solid var(--c-line);margin:18px 0}
.flex{display:flex;align-items:center;gap:10px}
.flex-wrap{flex-wrap:wrap}
.between{justify-content:space-between}
.gap-6{gap:6px}.gap-16{gap:16px}
.mt-0{margin-top:0}.mt-8{margin-top:8px}.mt-16{margin-top:16px}.mt-24{margin-top:24px}
.mb-0{margin-bottom:0}.mb-8{margin-bottom:8px}.mb-16{margin-bottom:16px}
.w-100{width:100%}.text-r{text-align:right}.text-c{text-align:center}
.scope-note{display:inline-flex;gap:7px;align-items:center;background:var(--c-amber-soft);color:var(--c-amber);border:1px solid #f3e0b8;border-radius:8px;padding:5px 11px;font-size:12px;font-weight:600}
.avatar-sm{width:28px;height:28px;border-radius:50%;background:var(--c-primary-soft);color:var(--c-primary);display:inline-grid;place-items:center;font-weight:700;font-size:11px}

/* ---------- Login ---------- */
.login-wrap{min-height:100vh;display:grid;grid-template-columns:1.1fr 1fr}
.login-hero{background:linear-gradient(135deg,#0d1b3d,#1b3a8f 60%,#2a52d4);color:#fff;padding:54px;display:flex;flex-direction:column;justify-content:space-between;position:relative;overflow:hidden}
.login-hero:after{content:"";position:absolute;right:-80px;bottom:-80px;width:340px;height:340px;border-radius:50%;background:rgba(255,106,43,.18)}
.login-form{display:flex;align-items:center;justify-content:center;padding:40px}
.login-card{width:100%;max-width:380px}
.role-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:18px 0}
.role-opt{border:1px solid var(--c-line);border-radius:11px;padding:12px;cursor:pointer;text-align:left;background:#fff;font-family:var(--ff)}
.role-opt:hover{border-color:var(--c-primary-2)}
.role-opt.sel{border-color:var(--c-primary-2);background:var(--c-primary-soft)}
.role-opt b{display:block;font-size:13px}
.role-opt small{font-size:11px}

/* ---------- Responsive ---------- */
.search{min-width:0}                 /* allow search to shrink inside flex topbar */
.top-actions{flex-shrink:0}

@media(max-width:1100px){
  .cols-4{grid-template-columns:repeat(2,1fr)}
  .cols-3{grid-template-columns:repeat(2,1fr)}
  .split{grid-template-columns:1fr}
}

/* ---- Tablet / mobile: sidebar becomes an off-canvas drawer ---- */
@media(max-width:820px){
  /* keep main full-width; the drawer must KEEP its width (do NOT zero --side-w) */
  .main{margin-left:0;width:100%}
  .sidebar{width:282px;max-width:86vw;transform:translateX(-100%);
           transition:transform .25s ease;will-change:transform}
  .sidebar.open{transform:translateX(0);box-shadow:var(--sh-lg)}
  .topbar{padding:0 12px;gap:10px}
  .topbar .hamb{display:grid;place-items:center;width:38px;height:38px;border:1px solid var(--c-line);border-radius:9px}
  .login-wrap{grid-template-columns:1fr}
  .login-hero{display:none}
  .cols-2,.cols-3,.cols-4{grid-template-columns:1fr}
  .search{max-width:none}
  .page-head{gap:12px}
  .page-head .ph-actions{margin-left:0;width:100%}
  .page-head .ph-actions .btn,.page-head .ph-actions select{flex:1;justify-content:center;min-width:0}
  .content{max-width:100%}
}

/* ---- Phones: trim non-essential topbar controls to prevent overflow ---- */
@media(max-width:640px){
  #favBtn,#recBtn{display:none}            /* favorites & recents reachable from menus/pages */
  .role-pick .rp-lbl{display:none}
  .role-pick{padding:5px 8px}
  .role-pick select{max-width:120px}
}
@media(max-width:520px){
  .content{padding:16px 13px 56px}
  .crumbs{font-size:11.5px}
  .page-head .ph-title h1{font-size:20px}
  .search input{font-size:13px}
  .modal-back{padding:12px}
  .kv{grid-template-columns:118px 1fr}
  .steps{gap:5px}
  .steps .st{padding:6px 10px;font-size:11.5px}
  .scope-note{display:flex;flex-wrap:wrap;max-width:100%}
  .login-form{padding:24px 16px}
  .role-grid{grid-template-columns:1fr}
  .toast-wrap{left:13px;right:13px;bottom:13px}
}
@media(max-width:380px){
  #qaBtn{display:none}                     /* quick-action ＋ also reachable from sidebar links */
  .role-pick select{max-width:96px}
}

.backdrop{position:fixed;inset:0;background:rgba(13,27,61,.45);z-index:35;display:none}
.backdrop.show{display:block}
@media(min-width:821px){.backdrop{display:none!important}}
body.nav-open{overflow:hidden}           /* lock page scroll while drawer is open */
