:root{
  --bg:#fbf9f3;--card:#fff;--sidebar:#ffffff;--sidebar-hover:#fdf3da;
  --primary:#d97706;--primary-light:#fef3c7;--primary-dark:#b45309;--primary-gradient:linear-gradient(135deg,#fbbf24,#f59e0b,#d97706);
  --green:#16a34a;--green-light:#f0fdf4;--red:#ef4444;--red-light:#fef2f2;
  --amber:#f59e0b;--amber-light:#fffbeb;--violet:#7c3aed;--violet-light:#f5f3ff;
  --cyan:#0ea5e9;--cyan-light:#e0f2fe;
  --accent:#b45309;--accent-light:#fef3c7;
  --text:#0f172a;--text2:#475569;--text3:#444444;--border:#e2e8f0;
  --radius:12px;--shadow:0 1px 3px rgba(0,0,0,.04),0 2px 8px rgba(0,0,0,.03);
  --shadow-lg:0 4px 20px rgba(0,0,0,.07);
}
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:'Inter',system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text);overflow:hidden;height:100vh}
::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#c1c9d4;border-radius:10px}::-webkit-scrollbar-thumb:hover{background:#a0aab5}
.app{display:flex;height:100vh}

/* Sidebar — Light with brand accent */
.sidebar{width:240px;background:var(--sidebar);color:var(--text);display:flex;flex-direction:column;flex-shrink:0;transition:.25s ease;border-right:1px solid var(--border)}
.sidebar.collapsed{width:64px}
.sidebar-head{padding:14px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:center;gap:10px;min-height:62px}
.sidebar-head .sidebar-logo-full{height:28px;width:auto;max-width:170px;object-fit:contain;display:block}
.sidebar-head .sidebar-logo-mark{height:32px;width:32px;object-fit:contain;display:none}
.collapsed .sidebar-head{padding:14px 8px}
.collapsed .sidebar-head .sidebar-logo-full{display:none}
.collapsed .sidebar-head .sidebar-logo-mark{display:block}
.collapsed .nav-label,.collapsed .sw-text{display:none}
.mode-switch{padding:10px 12px;border-bottom:1px solid var(--border)}
.sw{display:flex;background:var(--bg);border-radius:8px;padding:3px;gap:2px}
.sw button{flex:1;padding:7px 0;border:none;border-radius:6px;font-size:11px;font-weight:600;cursor:pointer;transition:.2s;background:transparent;color:var(--text3);font-family:inherit}
.sw button.ac{background:var(--primary-gradient);color:#1f2937;box-shadow:0 2px 8px rgba(245,158,11,.25)}.sw button.aa{background:linear-gradient(135deg,#7c3aed,#8b5cf6);color:#fff;box-shadow:0 2px 8px rgba(124,58,237,.25)}
.nav{flex:1;padding:6px 8px;overflow-y:auto}
.ni{display:flex;align-items:center;gap:11px;padding:9px 14px;border-radius:9px;cursor:pointer;font-size:12.5px;font-weight:500;color:var(--text2);transition:.2s;margin-bottom:1px;border:none;background:none;width:100%;text-align:left;font-family:inherit}
.ni:hover{background:var(--sidebar-hover);color:var(--primary)}
.ni.active{background:var(--primary-light);color:var(--primary);font-weight:600}
.ni.aa{background:var(--violet-light);color:var(--violet);font-weight:600}
.ni i{width:18px;text-align:center;font-size:14px;flex-shrink:0}
.ni .nav-badge{margin-left:auto;background:var(--red);color:#fff;font-size:9px;padding:1px 6px;border-radius:8px;font-weight:700}

/* Main */
.main{flex:1;display:flex;flex-direction:column;overflow:hidden}
.topbar{background:var(--card);border-bottom:1px solid var(--border);padding:0 24px;height:54px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.tb-badge{padding:4px 12px;border-radius:20px;font-size:10px;font-weight:700;letter-spacing:.6px;text-transform:uppercase}
.tb-badge.c{background:var(--primary-light);color:var(--primary)}.tb-badge.a{background:var(--violet-light);color:var(--violet)}
.tb-right{display:flex;align-items:center;gap:10px}
.notif{position:relative;width:34px;height:34px;border-radius:9px;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;cursor:pointer;background:#fff;font-size:13px;color:var(--text2);transition:.15s}
.notif:hover{background:var(--primary-light);border-color:var(--primary);color:var(--primary)}
.notif .dot{position:absolute;top:5px;right:5px;width:6px;height:6px;background:var(--red);border-radius:50%;border:2px solid #fff}
.avatar{width:34px;height:34px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff}
.av-c{background:var(--primary-gradient);color:#1f2937}.av-a{background:linear-gradient(135deg,#7c3aed,#8b5cf6)}

/* User menu (topbar) */
.user-menu{position:relative}
.user-chip{display:flex;align-items:center;gap:9px;background:#fff;border:1px solid var(--border);border-radius:13px;padding:4px 12px 4px 4px;cursor:pointer;font-family:inherit;transition:.15s}
.user-chip:hover{background:var(--bg);border-color:var(--primary)}
.user-chip-txt{display:flex;flex-direction:column;align-items:flex-start;line-height:1.15}
.user-chip-greet{font-size:12.5px;font-weight:700;color:var(--text)}
.user-chip-role{font-size:9px;font-weight:700;letter-spacing:.5px;color:var(--text3)}
.user-dropdown{position:absolute;top:calc(100% + 10px);right:0;width:280px;background:#fff;border:1px solid var(--border);border-radius:14px;box-shadow:0 16px 44px rgba(0,0,0,.16);z-index:120;overflow:hidden;opacity:0;visibility:hidden;transform:translateY(-6px);transition:.16s}
.user-dropdown.open{opacity:1;visibility:visible;transform:translateY(0)}
.ud-head{background:var(--primary-light);padding:20px;display:flex;flex-direction:column;align-items:center;gap:8px}
.ud-avatar{width:60px;height:60px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:800;color:#1f2937}
.ud-online{font-size:11.5px;font-weight:600;color:var(--green);display:flex;align-items:center;gap:6px}
.ud-dot{width:7px;height:7px;border-radius:50%;background:var(--green);display:inline-block;box-shadow:0 0 0 3px rgba(22,163,74,.18)}
.ud-info{padding:14px 18px;border-bottom:1px solid var(--border)}
.ud-row{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--text);padding:5px 0}
.ud-row i{width:15px;text-align:center;color:var(--text3);font-size:12px}
.ud-row span{word-break:break-all}
.ud-sep{height:1px;background:transparent}
.ud-item{display:flex;align-items:center;gap:11px;width:100%;padding:11px 18px;border:none;background:none;font-family:inherit;font-size:13px;font-weight:500;color:var(--text);cursor:pointer;text-align:left;transition:.13s}
.ud-item i{width:16px;text-align:center;color:var(--text3);font-size:13px}
.ud-item:hover{background:var(--sidebar-hover);color:var(--primary)}
.ud-item:hover i{color:var(--primary)}
.ud-item.ud-danger{color:var(--red);border-top:1px solid var(--border)}
.ud-item.ud-danger i{color:var(--red)}
.ud-item.ud-danger:hover{background:var(--red-light)}
.ud-version{text-align:right;padding:8px 18px 12px;font-size:10.5px;color:var(--text3)}
@media(max-width:768px){
  .user-chip-txt{display:none}
  .user-dropdown{width:calc(100vw - 24px);right:-6px;position:fixed;top:auto}
}
.content{flex:1;overflow-y:auto;padding:24px}

/* Cards */
.card{background:var(--card);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow);padding:22px;margin-bottom:18px;transition:.15s}
.ch{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.ch h3{font-size:14px;font-weight:700}

/* Stats */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:18px}
.stat{background:var(--card);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow);padding:18px;transition:.25s}
.stat:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.st-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.st-ic{width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:15px}
.st-ic.bl{background:var(--primary-light);color:var(--primary)}.st-ic.gr{background:var(--green-light);color:var(--green)}
.st-ic.vi{background:var(--violet-light);color:var(--violet)}.st-ic.am{background:var(--amber-light);color:var(--amber)}
.st-ic.re{background:var(--red-light);color:var(--red)}.st-ic.cy{background:var(--cyan-light);color:var(--cyan)}
.st-tr{font-size:11px;font-weight:600;display:flex;align-items:center;gap:3px}
.st-tr.up{color:var(--green)}.st-tr.dn{color:var(--red)}
.st-val{font-size:22px;font-weight:800;letter-spacing:-.5px}
.st-lbl{font-size:11px;color:var(--text3);margin-top:2px}
.st-sub{font-size:10px;color:var(--text3);margin-top:3px}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:999px;font-size:12.5px;font-weight:600;cursor:pointer;border:none;transition:.2s;font-family:inherit}
.btn-p{background:#111827;color:#fff;box-shadow:0 2px 8px rgba(17,24,39,.25)}.btn-p:hover{background:#1f2937;box-shadow:0 4px 16px rgba(245,158,11,.3);transform:translateY(-1px)}
.btn-s{background:var(--primary-gradient);color:#1f2937;box-shadow:0 2px 8px rgba(245,158,11,.3)}.btn-s:hover{box-shadow:0 4px 16px rgba(245,158,11,.45);transform:translateY(-1px)}
.btn-o{background:#fff;color:var(--text);border:1px solid var(--border)}.btn-o:hover{background:var(--bg);border-color:var(--text3)}
.btn-d{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;box-shadow:0 2px 8px rgba(239,68,68,.15)}.btn-d:hover{box-shadow:0 4px 16px rgba(239,68,68,.25);transform:translateY(-1px)}
.btn-sm{padding:5px 11px;font-size:11.5px;border-radius:999px}
.btn-icon{width:32px;height:32px;padding:0;display:flex;align-items:center;justify-content:center;border-radius:8px;border:1px solid var(--border);background:#fff;cursor:pointer;color:var(--text2);font-size:12px;transition:.15s}
.btn-icon:hover{background:var(--bg)}

/* Tables */
.tbl{width:100%;border-collapse:separate;border-spacing:0;font-size:12.5px}
.tbl thead th{background:var(--bg);padding:9px 14px;font-size:10px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.6px;text-align:left;border-bottom:1px solid var(--border)}
.tbl thead th:first-child{border-radius:10px 0 0 0}.tbl thead th:last-child{border-radius:0 10px 0 0}
.tbl tbody td{padding:11px 14px;border-bottom:1px solid var(--border);vertical-align:middle}
.tbl tbody tr:hover{background:#f8fafd}
.tbl tbody tr:last-child td{border-bottom:none}
.mono{font-family:'SF Mono','Fira Code','JetBrains Mono',monospace;font-size:11.5px}

/* Badges */
.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:20px;font-size:10.5px;font-weight:600}
.b-gr{background:var(--green-light);color:#059669}.b-re{background:var(--red-light);color:#dc2626}
.b-am{background:var(--amber-light);color:#d97706}.b-bl{background:var(--primary-light);color:var(--primary)}
.b-vi{background:var(--violet-light);color:var(--violet)}.b-gy{background:#f1f5f9;color:#64748b}
.b-cy{background:var(--cyan-light);color:#059669}
.b-dot{width:5px;height:5px;border-radius:50%;display:inline-block}

/* Inputs */
.sb{position:relative}.sb input{width:100%;padding:9px 13px 9px 36px;border:1px solid var(--border);border-radius:9px;font-size:12.5px;font-family:inherit;background:#fff;transition:.2s;outline:none}
.sb input:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(245,158,11,.12)}
.sb i{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text3);font-size:12px}
.inf{padding:9px 13px;border:1px solid var(--border);border-radius:9px;font-size:12.5px;font-family:inherit;width:100%;outline:none;transition:.2s;background:#fff}
.inf:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(245,158,11,.12)}
.sel{padding:9px 13px;border:1px solid var(--border);border-radius:9px;font-size:12.5px;font-family:inherit;background:#fff;cursor:pointer;outline:none;width:100%;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%2394a3b8' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}
.sel:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(245,158,11,.12)}
.fg{margin-bottom:14px}.fg label{display:block;font-size:11px;font-weight:600;color:var(--text2);margin-bottom:5px;text-transform:uppercase;letter-spacing:.3px}
.fg .req{color:var(--red)}

/* Modal */
.mo{position:fixed;inset:0;background:rgba(15,23,42,.4);backdrop-filter:blur(6px);z-index:100;display:none;align-items:center;justify-content:center;padding:20px}
.mo.show{display:flex}.ml{background:#fff;border-radius:16px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 25px 60px rgba(0,0,0,.15);animation:mIn .2s ease}
@keyframes mIn{from{transform:translateY(16px) scale(.98);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}
.ml-h{padding:20px 22px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;background:#fff;z-index:2;border-radius:16px 16px 0 0}
.ml-h h3{font-size:16px;font-weight:700}.ml-b{padding:22px}
.ml-c{width:30px;height:30px;border-radius:8px;border:none;background:var(--bg);cursor:pointer;font-size:13px;color:var(--text2);display:flex;align-items:center;justify-content:center;transition:.15s}
.ml-c:hover{background:var(--red-light);color:var(--red)}

/* Toggle */
.tog{width:40px;height:22px;border-radius:11px;background:#d1d5db;position:relative;cursor:pointer;transition:.2s;border:none;flex-shrink:0}
.tog.on{background:var(--primary)}.tog::after{content:'';position:absolute;width:16px;height:16px;border-radius:50%;background:#fff;top:3px;left:3px;transition:.2s;box-shadow:0 1px 4px rgba(0,0,0,.12)}.tog.on::after{left:21px}

/* AI Voice toggle */
.ai-toggle{position:relative;width:40px;height:22px;display:inline-block}
.ai-toggle input{display:none}
.ai-toggle .slider{position:absolute;inset:0;background:#d1d5db;border-radius:11px;cursor:pointer;transition:.2s}
.ai-toggle input:checked+.slider{background:var(--primary)}
.ai-toggle .slider:before{content:'';position:absolute;width:16px;height:16px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:.2s}
.ai-toggle input:checked+.slider:before{transform:translateX(18px)}

/* Progress */
.prog{height:5px;background:var(--bg);border-radius:3px;overflow:hidden}.prog-bar{height:100%;border-radius:3px;transition:.3s}

/* Steps */
.steps{display:flex;align-items:center;gap:0;margin-bottom:24px}
.step-item{flex:1;display:flex;align-items:center;gap:8px;position:relative}
.step-dot{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;border:2px solid var(--border);color:var(--text3);flex-shrink:0;transition:.2s;background:#fff}
.step-item.done .step-dot{background:var(--green);border-color:var(--green);color:#fff}
.step-item.current .step-dot{background:var(--primary);border-color:var(--primary);color:#fff}
.step-info .step-title{font-size:11px;font-weight:600;color:var(--text)}.step-info .step-sub{font-size:9px;color:var(--text3)}
.step-line{flex:1;height:2px;background:var(--border);margin:0 6px}.step-item.done+.step-line,.step-item.done .step-line{background:var(--green)}

/* Compliance Card */
.comp-card{border:2px solid var(--border);border-radius:12px;padding:16px;margin-bottom:10px;transition:.2s;cursor:pointer}
.comp-card:hover{border-color:var(--primary);background:var(--primary-light)}
.comp-card.uploaded{border-color:var(--green);background:var(--green-light)}
.comp-card .cc-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:5px}
.comp-card .cc-icon{width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:15px}
.comp-card .cc-title{font-size:13px;font-weight:600}.comp-card .cc-desc{font-size:11px;color:var(--text2)}
.comp-card .cc-status{font-size:10px;font-weight:600}

/* DID Flow */
.did-flow{display:flex;gap:10px;margin-bottom:18px;flex-wrap:wrap}
.did-flow .dfs{flex:1;min-width:140px}
.did-flow .dfs label{display:block;font-size:10px;font-weight:600;color:var(--text3);margin-bottom:5px;text-transform:uppercase;letter-spacing:.5px}
.did-results{display:grid;gap:8px;margin-top:14px}
.did-card{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;background:var(--bg);border:2px solid transparent;border-radius:12px;cursor:pointer;transition:.2s}
.did-card:hover{border-color:var(--primary);background:var(--primary-light)}.did-card.sel{border-color:var(--primary);background:var(--primary-light)}
.did-card .dn{font-family:'SF Mono','Fira Code',monospace;font-size:14px;font-weight:600}.did-card .dm{font-size:10px;color:var(--text3);margin-top:2px}
.did-card .dp{font-size:15px;font-weight:700;color:var(--primary)}
.did-card .dc{width:20px;height:20px;border-radius:50%;border:2px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:10px;color:#fff;transition:.15s}
.did-card.sel .dc{background:var(--primary);border-color:var(--primary)}
.cart-s{background:linear-gradient(135deg,#fef3c7,#fffaf0);border:1px solid #fcd34d;border-radius:12px;padding:18px;margin-top:14px}
.cart-s h4{font-size:13px;font-weight:700;margin-bottom:8px}
.dterm-btn{transition:.15s}.dterm-btn:hover{border-color:var(--primary)!important}
.dterm-active,.dterm-active:hover{border-color:var(--primary)!important;background:var(--primary-light)!important;box-shadow:0 0 0 2px rgba(245,158,11,.18)}
.bstep{flex:1;padding:9px 10px;font-size:11.5px;font-weight:600;color:var(--text3);cursor:pointer;display:flex;align-items:center;gap:5px;transition:.15s;border-bottom:2px solid transparent}
.bstep:hover{color:var(--text2);background:#f8fafd}.bstep.active{color:var(--primary);border-bottom-color:var(--primary);background:var(--primary-light)}
.bstep.done{color:var(--green)}.bstep.done .bstep-n{background:var(--green);color:#fff}
.bstep-n{width:18px;height:18px;border-radius:50%;background:#e2e8f0;color:var(--text3);font-size:9px;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.bstep.active .bstep-n{background:var(--primary);color:#fff}
.cl{display:flex;justify-content:space-between;font-size:12.5px;padding:3px 0;color:var(--text2)}
.ct{display:flex;justify-content:space-between;font-size:14px;font-weight:700;padding-top:8px;margin-top:8px;border-top:1px solid #fcd34d}

/* Alert Banner */
.alert-bar{padding:12px 18px;border-radius:10px;display:flex;align-items:center;gap:10px;margin-bottom:18px;font-size:12.5px}
.alert-bar.warn{background:#fffbeb;border:1px solid #fcd34d;color:#92400e}
.alert-bar.info{background:var(--primary-light);border:1px solid #fcd34d;color:#b45309}
.alert-bar.ok{background:var(--green-light);border:1px solid #86efac;color:#166534}
.alert-bar.err{background:var(--red-light);border:1px solid #fca5a5;color:#991b1b}
.alert-bar i{font-size:16px;flex-shrink:0}

/* Chart */
.chart-area{background:linear-gradient(180deg,#f8fafc,#f0f7fa);border-radius:12px;height:200px;display:flex;align-items:flex-end;padding:18px;gap:4px;overflow:hidden}
.chart-bar{flex:1;background:var(--primary-gradient);border-radius:5px 5px 0 0;transition:.3s;min-height:8px;opacity:.75}
.chart-bar:hover{opacity:1;transform:scaleY(1.04);transform-origin:bottom}

/* Grid */
.g2{display:grid;grid-template-columns:1fr 1fr;gap:14px}.g3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}

/* Locked overlay */
.locked-section{position:relative;overflow:hidden;border-radius:var(--radius);border:2px dashed var(--border)}
.locked-section .lock-ov{position:absolute;inset:0;background:rgba(255,255,255,.88);backdrop-filter:blur(4px);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:2;border-radius:var(--radius)}
.locked-section .lock-ov i{font-size:28px;color:var(--amber);margin-bottom:8px}
.locked-section .lock-ov p{font-size:13px;font-weight:600;color:var(--text)}
.locked-section .lock-ov span{font-size:11px;color:var(--text2);margin-top:3px}

/* Anim */
.page{animation:fadeIn .25s ease}
@keyframes fadeIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(245,158,11,.4)}50%{box-shadow:0 0 0 10px rgba(245,158,11,0)}}
@media(max-width:1024px){.stats{grid-template-columns:repeat(2,1fr)}.g2,.g3{grid-template-columns:1fr}}

/* ============ MOBILE RESPONSIVE ============ */
/* Mobile menu toggle button (hamburger) */
.mobile-menu-btn{display:none;background:var(--primary);color:#fff;border:none;width:40px;height:40px;border-radius:8px;cursor:pointer;font-size:16px;margin-right:10px;align-items:center;justify-content:center}

@media(max-width:768px){
  body{overflow:auto}
  .app{flex-direction:column;height:auto;min-height:100vh}
  .sidebar{position:fixed;top:0;left:-280px;width:270px;height:100vh;z-index:100;transition:left .3s ease;box-shadow:2px 0 12px rgba(0,0,0,.1)}
  .sidebar.mobile-open{left:0}
  .sidebar.collapsed{width:270px;left:-280px}
  .main{margin-left:0!important;width:100%;overflow:visible!important}
  .mobile-menu-btn{display:inline-flex}
  .sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:99}
  .sidebar-overlay.active{display:block}

  /* Topbar — 2 row layout */
  .topbar{flex-direction:column;align-items:stretch!important;gap:8px;padding:10px 12px!important;height:auto!important}
  .topbar>div:first-child{width:100%;justify-content:flex-start}
  .tb-right{width:100%;justify-content:space-between;gap:6px!important;flex-wrap:wrap}
  #tbBalArea{gap:6px!important;margin-right:0!important;flex-wrap:wrap;flex:1;min-width:0}
  #tbPrefix,#tbBal{padding:5px 10px!important;flex:1;justify-content:center;min-width:0}
  #tbPrefix span,#tbBal span{font-size:11px!important;white-space:nowrap}
  .tb-badge{font-size:10px!important;padding:4px 10px!important}
  #tComp{display:none}
  .notif{width:34px;height:34px;flex-shrink:0}
  .avatar{width:34px;height:34px;font-size:12px;flex-shrink:0}

  /* Content */
  .content{padding:12px!important;overflow-x:hidden;width:100%;max-width:100vw}
  .page{padding:0!important;width:100%;max-width:100%}
  h2{font-size:17px!important}
  html,body{max-width:100vw;overflow-x:hidden}

  /* Prevent content overflow */
  .card,.stat{max-width:100%;box-sizing:border-box}
  .card *{max-width:100%}
  pre,code,.mono{word-break:break-all;white-space:normal}

  /* Stats */
  .stats{grid-template-columns:1fr!important;gap:8px;margin-bottom:12px}
  .stats[style*="grid-template-columns"]{grid-template-columns:1fr!important}
  .stat{padding:14px!important}
  .st-val{font-size:18px!important}
  .st-lbl{font-size:11px!important}

  /* Cards */
  .card{padding:14px!important;margin-bottom:12px!important;border-radius:10px}
  .ch{flex-direction:column;align-items:flex-start!important;gap:6px;margin-bottom:10px}
  .ch h3{font-size:14px!important}

  /* Tables — horizontal scroll wrapper */
  .tbl{font-size:11px;min-width:100%;width:max-content}
  .tbl th,.tbl td{padding:8px 10px!important;white-space:nowrap}
  .tbl td .mono{font-size:11px!important}
  /* Wrap all tables in scrollable container */
  .card{overflow-x:auto!important;-webkit-overflow-scrolling:touch}
  .card[style*="padding:0"]{overflow-x:auto!important}
  /* Table inside scrollable card */
  .card table{display:table;width:auto;min-width:100%}

  /* Grid layouts to single column */
  .g2,.g3,.g4{grid-template-columns:1fr!important}

  /* Forms */
  .fg{margin-bottom:10px}
  .inf,.sel{padding:10px 12px!important;font-size:13px!important}
  .btn{padding:10px 16px!important;font-size:13px!important}
  .btn-sm{padding:6px 10px!important;font-size:11px!important}

  /* Modals */
  .ml{max-width:calc(100vw - 20px)!important;margin:10px auto!important;max-height:calc(100vh - 20px);overflow-y:auto}
  .ml-h{padding:14px 16px!important}
  .ml-h h3{font-size:15px!important}
  .ml-b{padding:14px!important}

  /* Login */
  #loginScreen>div{padding:12px!important}
  #loginStep1,#loginStep2,#signupForm{padding:20px!important;border-radius:14px!important}
  #signupForm>div[style*="grid-template-columns:1fr 1fr"]{grid-template-columns:1fr!important}
  /* OTP 6-digit input field on mobile */
  #otpContainer{gap:4px!important}
  #otpContainer input{width:36px!important;height:46px!important;font-size:18px!important}

  /* ANY inline grid-template-columns that are multi-column — collapse */
  [style*="grid-template-columns:repeat(3,1fr)"],
  [style*="grid-template-columns:repeat(4,1fr)"],
  [style*="grid-template-columns:repeat(5,1fr)"]{grid-template-columns:1fr!important}
  [style*="grid-template-columns:repeat(auto-fit,minmax"]{grid-template-columns:1fr!important}
  [style*="grid-template-columns:repeat(auto-fill,minmax"]{grid-template-columns:1fr!important}
  [style*="grid-template-columns:1fr 1fr"]{grid-template-columns:1fr!important}
  [style*="grid-template-columns:1fr 1fr 1fr"]{grid-template-columns:1fr!important}

  /* Tab buttons — wrap */
  div[style*="display:flex"][style*="background:var(--bg)"][style*="border-radius:12px"]{overflow-x:auto;flex-wrap:nowrap!important;-webkit-overflow-scrolling:touch}
  div[style*="display:flex"][style*="background:var(--bg)"][style*="border-radius:12px"]>button{flex-shrink:0;white-space:nowrap}

  /* Status filter bars — wrap */
  div[style*="flex-wrap:wrap"]{flex-wrap:wrap!important;gap:6px!important}

  /* Trunk cards on dashboard — single column */
  #content [style*="grid-template-columns:repeat(2,1fr)"]{grid-template-columns:1fr!important}

  /* Inline flex with gap that needs wrapping on mobile */
  .ch[style*="display:flex"]{flex-wrap:wrap}
}

/* Full-page loader */
.app-loader{position:fixed;inset:0;z-index:9999;background:linear-gradient(135deg,#fdf6db 0%,#f7e288 50%,#f2cf57 100%);display:none;align-items:center;justify-content:center;font-family:'Inter',sans-serif;opacity:0;transition:opacity .2s ease}
.app-loader.show{display:flex;opacity:1}
.app-loader-card{background:#fff;border-radius:18px;padding:32px 40px;box-shadow:0 20px 60px rgba(0,0,0,.12),0 8px 24px rgba(245,158,11,.08);display:flex;flex-direction:column;align-items:center;gap:14px;min-width:280px;max-width:90vw;animation:loaderPop .35s cubic-bezier(.34,1.56,.64,1)}
.app-loader-logo{height:32px;width:auto;max-width:180px;object-fit:contain;margin-bottom:4px}
.app-loader-ring{width:48px;height:48px;border-radius:50%;border:3.5px solid #fde6c0;border-top-color:#f59e0b;animation:loaderSpin 750ms linear infinite}
.app-loader-msg{font-size:14px;font-weight:700;color:#0f172a;text-align:center;letter-spacing:-.2px}
.app-loader-sub{font-size:12px;color:#64748b;text-align:center;margin-top:-6px}
@keyframes loaderSpin{to{transform:rotate(360deg)}}
@keyframes loaderPop{from{transform:translateY(8px) scale(.96);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}

@media(max-width:480px){
  .stat{padding:10px!important}
  .st-val{font-size:16px!important}
  .st-lbl{font-size:10px!important}
  [style*="font-size:36px"]{font-size:28px!important}
  [style*="font-size:20px;font-weight:800"]{font-size:16px!important}
  .tbl th,.tbl td{padding:6px 4px!important;font-size:10px!important}
  [style*="grid-template-columns:repeat(4,1fr)"]{grid-template-columns:1fr!important}
  [style*="grid-template-columns:repeat(5,1fr)"]{grid-template-columns:1fr!important}
}
