/* ═══════════════════════════════════════════════════════
   ScrapBid Pro v5 - Clean Modern UI
   ═══════════════════════════════════════════════════════ */
*{margin:0;padding:0;box-sizing:border-box}
:root{
  --primary:#0f3460;--primary-light:#1a4a8a;--primary-dark:#0a2240;
  --accent:#10b981;--accent-light:#34d399;--success:#10b981;
  --danger:#ef4444;--warning:#f59e0b;--info:#0ea5e9;
  --bg:#f1f5f9;--bg2:#f8fafc;--surface:#fff;--surface2:#f8fafc;
  --text:#1e293b;--text1:#334155;--text2:#475569;--text3:#94a3b8;
  --border:#e2e8f0;--border2:#cbd5e1;
  --shadow:0 1px 3px rgba(0,0,0,.08);--shadow2:0 4px 12px rgba(0,0,0,.12);
  --radius:8px;--radius-lg:12px;
  --sidebar-w:240px;
}
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;background:var(--bg);color:var(--text);font-size:14px;line-height:1.5}
a{color:var(--primary);text-decoration:none}
input,select,textarea{font-family:inherit;font-size:13px;padding:8px 12px;border:1px solid var(--border);border-radius:var(--radius);width:100%;outline:none;transition:border .2s;background:var(--surface)}
input:focus,select:focus,textarea:focus{border-color:var(--primary)}
textarea{resize:vertical;min-height:80px}

/* ── BUTTONS ─────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border:none;border-radius:var(--radius);cursor:pointer;font-size:13px;font-weight:600;transition:all .2s;white-space:nowrap}
.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-light)}
.btn-success{background:var(--accent);color:#fff}.btn-success:hover{background:#059669}
.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:#dc2626}
.btn-warning{background:var(--warning);color:#fff}.btn-warning:hover{background:#d97706}
.btn-ghost{background:transparent;color:var(--primary);border:1px solid var(--border)}.btn-ghost:hover{background:var(--surface2);border-color:var(--border2)}
.btn-sm{padding:5px 10px;font-size:12px}.btn-xs{padding:3px 8px;font-size:11px}
.btn-full{width:100%;justify-content:center;padding:10px}
.btn:disabled{opacity:.5;cursor:not-allowed}

/* ── LOGIN ───────────────────────────────────────────── */
.login-body{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,var(--primary-dark),var(--primary))}
.login-card{background:var(--surface);border-radius:var(--radius-lg);padding:32px;width:100%;max-width:420px;box-shadow:var(--shadow2)}
.login-brand{text-align:center;margin-bottom:24px}
.brand-icon-lg{font-size:40px;display:block;margin-bottom:8px}
.login-brand h1{font-size:22px;color:var(--primary)}
.login-brand p{font-size:12px;color:var(--text3)}
.login-error{background:#fef2f2;color:var(--danger);padding:8px 12px;border-radius:var(--radius);font-size:12px;border:1px solid #fecaca;margin-bottom:12px}
.login-demo{margin-top:20px;padding-top:16px;border-top:1px solid var(--border)}
.demo-title{font-size:11px;font-weight:700;color:var(--text3);text-transform:uppercase;margin-bottom:8px;letter-spacing:.5px}
.demo-grid{display:flex;flex-direction:column;gap:6px}
.demo-item{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:var(--surface2);border-radius:var(--radius);cursor:pointer;transition:background .2s;border:1px solid transparent}
.demo-item:hover{background:#e0f2fe;border-color:#bae6fd}
.demo-role{font-size:11px;font-weight:700;color:var(--primary)}
.demo-cred{font-size:11px;color:var(--text3);font-family:monospace}

/* ── LAYOUT ──────────────────────────────────────────── */
#app{display:flex;flex-direction:column;min-height:100vh}

/* Desktop top nav */
.topnav{display:flex;align-items:center;padding:0 12px;background:var(--primary-dark);color:#fff;height:46px;position:sticky;top:0;z-index:100;gap:0;box-shadow:0 1px 4px rgba(0,0,0,.2)}
.topnav-left{display:flex;align-items:center;gap:6px;flex-shrink:0}
.topnav-brand{font-size:14px;color:#fff;white-space:nowrap;padding:0 8px 0 0;border-right:1px solid rgba(255,255,255,.1);margin-right:4px}
.topnav-brand b{font-weight:700}
.topnav-menu{display:flex;align-items:center;flex:1;gap:1px}
.topnav-right{display:flex;align-items:center;gap:2px;flex-shrink:0;margin-left:auto}

/* Nav items — flat buttons */
.tn-item{display:flex;align-items:center;gap:5px;padding:0 11px;color:rgba(255,255,255,.7);cursor:pointer;font-size:12px;white-space:nowrap;height:46px;border-bottom:2px solid transparent;transition:all .12s;position:relative;user-select:none}
.tn-item:hover{color:#fff;background:rgba(255,255,255,.07)}
.tn-item.active{color:#fff;border-bottom-color:var(--accent)}
.tn-icon{font-size:15px;line-height:1}
.tn-label{font-weight:500}
.tn-arrow{font-size:8px;opacity:.5;margin-left:1px}

/* Dropdown menus */
.tn-drop{position:relative}
.tn-drop-menu{display:none;position:absolute;top:100%;left:0;min-width:180px;background:var(--surface);border-radius:0 0 8px 8px;box-shadow:0 8px 24px rgba(0,0,0,.18);border:1px solid var(--border);border-top:2px solid var(--accent);z-index:200;padding:4px 0;animation:tnFadeIn .12s ease}
.tn-drop:hover .tn-drop-menu,.tn-drop-menu:hover{display:block}
.tn-drop-menu.right{left:auto;right:0}
.tn-drop-menu::before{content:'';position:absolute;top:-10px;left:0;right:0;height:10px}
@keyframes tnFadeIn{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}
.tn-dd-item{display:flex;align-items:center;gap:8px;padding:8px 14px;color:var(--text1);font-size:12px;cursor:pointer;transition:background .1s;white-space:nowrap}
.tn-dd-item:hover{background:var(--bg);color:var(--primary)}
.tn-dd-item.active{color:var(--primary);font-weight:600;background:#eff6ff}
.tn-dd-icon{font-size:14px;width:18px;text-align:center;flex-shrink:0}
.tn-dd-sep{height:1px;background:var(--border);margin:4px 0}
.tn-dd-head{padding:6px 14px 2px;font-size:9px;font-weight:700;text-transform:uppercase;color:var(--text3);letter-spacing:.6px}

/* Module switcher dropdown */
.mod-switch{display:flex;align-items:center;gap:5px;padding:0 10px;height:46px;cursor:pointer;color:rgba(255,255,255,.7);font-size:12px;transition:all .12s;border-left:1px solid rgba(255,255,255,.08)}
.mod-switch:hover{color:#fff;background:rgba(255,255,255,.07)}
.mod-active-dot{width:6px;height:6px;border-radius:50%;background:var(--accent)}
.mod-switch-menu{min-width:200px}
.mod-switch-menu .tn-dd-item{padding:10px 14px}
.mod-switch-menu .tn-dd-item.active{border-left:3px solid var(--accent)}
/* Company switcher */
.comp-switch{display:flex;align-items:center;gap:4px;padding:0 8px;height:46px;cursor:pointer;color:rgba(255,255,255,.6);font-size:11px;border-left:1px solid rgba(255,255,255,.08)}
.comp-switch:hover{color:#fff;background:rgba(255,255,255,.05)}
.comp-switch-menu{min-width:220px}
.comp-switch-menu .tn-dd-item{padding:8px 14px;font-size:12px}
.comp-switch-menu .tn-dd-item.active{border-left:3px solid var(--accent);font-weight:700}
.comp-switch-menu .tn-dd-head{padding:8px 14px;font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--text3)}
.comp-badge{display:inline-block;padding:1px 6px;border-radius:10px;font-size:9px;font-weight:600;background:var(--bg2);color:var(--text2);margin-left:4px}

/* User avatar dropdown */
.tn-avatar{width:30px;height:30px;border-radius:50%;background:rgba(255,255,255,.15);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#fff;cursor:pointer;transition:all .15s;flex-shrink:0}
.tn-avatar:hover{background:rgba(255,255,255,.25)}
.tn-user-menu{min-width:220px}
.tn-user-info{padding:12px 14px;border-bottom:1px solid var(--border)}
.tn-user-name{font-size:13px;font-weight:600;color:var(--text)}
.tn-user-role{font-size:10px;color:var(--text3)}
.tn-user-company{font-size:10px;color:var(--accent);margin-top:1px}

/* Notification bell */
.tn-bell{position:relative;cursor:pointer;padding:0 8px;height:46px;display:flex;align-items:center;color:rgba(255,255,255,.6);font-size:16px;transition:color .15s}
.tn-bell:hover{color:#fff}
.tn-bell-badge{position:absolute;top:8px;right:3px;background:var(--danger);color:#fff;font-size:8px;font-weight:700;min-width:15px;height:15px;border-radius:50%;display:flex;align-items:center;justify-content:center;padding:0 3px}

/* Hidden elements */
.sidebar{display:none}
.sb-overlay{display:none}
.menu-toggle{display:none}
.role-badge,.company-badge{display:none}
.topnav-user{display:none}
.btn-logout-top{display:none}

/* Main content — full width */
.main-wrap{flex:1;display:flex;flex-direction:column;min-height:calc(100vh - 46px)}
.content{flex:1;padding:16px 20px;overflow-y:auto}

/* ── SUPERPROCURE STYLE TABLE (Transport) ─────────────── */
.sp-tbl{width:100%;border-collapse:collapse;font-size:12px}
.sp-tbl thead th{padding:8px 12px;text-align:left;font-size:11px;font-weight:600;color:var(--text2);border-bottom:2px solid var(--border);background:var(--bg2)}
.sp-tbl .sp-row td{padding:10px 12px;border-bottom:1px solid var(--border);vertical-align:top}
.sp-tbl .sp-row:hover td{background:#f8faff}
.sp-tbl .sp-sub td{background:var(--bg2)}

/* ── LISTING CARDS (unified for all modules) ─────────── */
.lc{background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:8px 12px;margin-bottom:6px;cursor:pointer;transition:all .15s}
.lc:hover{border-color:var(--primary);box-shadow:0 2px 8px rgba(0,0,0,.06)}
.lc-row1{display:flex;align-items:center;gap:8px;margin-bottom:4px}
.lc-row2{display:flex;align-items:center;gap:4px;flex-wrap:wrap;margin-bottom:3px}
.lc-row3{display:flex;align-items:center;gap:4px;font-size:10px;color:var(--text3)}
.lc-uid{font-size:12px;font-weight:700;color:var(--primary);white-space:nowrap}
.lc-route{font-size:12px;font-weight:600;color:var(--text)}
.lc-spacer{flex:1}
.lc-timer{font-family:'SF Mono',Monaco,monospace;font-size:13px;font-weight:700;white-space:nowrap}
.lc-timer.green,.lc-timer.safe{color:var(--accent)}
.lc-timer.orange,.lc-timer.warn{color:var(--warning)}
.lc-timer.red,.lc-timer.live{color:var(--danger)}
.lc-timer.upcoming{color:var(--info)}
.lc-tag{display:inline-flex;align-items:center;padding:1px 6px;border-radius:3px;font-size:10px;font-weight:500;white-space:nowrap}
.lc-muted{background:#f1f5f9;color:#475569}
.lc-mode{background:#dbeafe;color:#1e40af;font-weight:600}
.lc-pri{background:#fef3c7;color:#92400e}
.lc-auto{background:#fef3c7;color:#92400e}
.lc-rank{font-size:11px;font-weight:700;color:var(--accent);background:#dcfce7;padding:1px 6px;border-radius:3px}
.lc-amount{font-size:11px;font-weight:600;color:var(--text)}
.lc-nobid{font-size:10px;color:var(--danger);font-weight:500}

/* ── TRADING TERMINAL COMPACT FORM ────────────────────── */
.tc-box{background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:6px 8px}
.tc-hdr{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--text3);padding:2px 0 4px;border-bottom:1px solid var(--border);margin-bottom:5px;display:flex;justify-content:space-between;align-items:center}
.tc-grid2{display:grid;grid-template-columns:1fr 1fr;gap:4px 6px}
.tc-grid3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:4px 6px}
.tc-f{margin-bottom:3px}
.tc-f label{display:block;font-size:9px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.3px;margin-bottom:1px}
.tc-inp{width:100%;padding:4px 6px;font-size:11px;border:1px solid var(--border);border-radius:4px;background:var(--surface);outline:none;transition:border .15s}
.tc-inp:focus{border-color:var(--primary)}
.tc-sel{width:100%;padding:3px 4px;font-size:11px;border:1px solid var(--border);border-radius:4px;background:var(--surface);outline:none;cursor:pointer}
.tc-sel:focus{border-color:var(--primary)}
.tc-add{font-size:10px;padding:2px 8px;background:var(--accent);color:#fff;border:none;border-radius:4px;cursor:pointer;font-weight:600}
.tc-add:hover{background:#059669}
.tc-tbl{width:100%;border-collapse:collapse;font-size:10px;table-layout:auto}
.tc-tbl th{padding:3px 4px;text-align:left;font-size:9px;font-weight:600;color:var(--text3);text-transform:uppercase;border-bottom:1px solid var(--border)}
.tc-tbl td{padding:3px 2px}
.tc-tbl input,.tc-tbl select{padding:3px 4px;font-size:10px;border:1px solid var(--border);border-radius:3px;width:100%;box-sizing:border-box}
.tc-tbl .tc-del{background:none;border:none;color:var(--danger);cursor:pointer;font-size:13px;padding:0 2px}
.tc-tbl td:last-child{width:24px;text-align:center}

/* ── FORMS ───────────────────────────────────────────── */
.form-group{margin-bottom:12px}
.form-group label{display:block;font-size:12px;font-weight:600;color:var(--text2);margin-bottom:4px}
.form-row{display:grid;gap:12px;margin-bottom:12px}
.form-row.cols-2{grid-template-columns:1fr 1fr}
.form-row.cols-3{grid-template-columns:1fr 1fr 1fr}
.form-row.cols-4{grid-template-columns:1fr 1fr 1fr 1fr}
.form-row.cols-5{grid-template-columns:1fr 1fr 1fr 1fr 1fr}

/* ── STATS ───────────────────────────────────────────── */
.stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;margin-bottom:20px}
.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px;text-align:center;box-shadow:var(--shadow)}
.stat-label{font-size:11px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.3px}
.stat-val{font-size:28px;font-weight:800;color:var(--text);margin:4px 0}
.stat-sub{font-size:11px;color:var(--text3)}
.stat-card.green{border-left:4px solid var(--accent)}.stat-card.green .stat-val{color:var(--accent)}
.stat-card.blue{border-left:4px solid var(--info)}.stat-card.blue .stat-val{color:var(--info)}
.stat-card.amber{border-left:4px solid var(--warning)}.stat-card.amber .stat-val{color:var(--warning)}
.stat-card.red{border-left:4px solid var(--danger)}.stat-card.red .stat-val{color:var(--danger)}

/* ── PANELS ──────────────────────────────────────────── */
.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:16px;overflow:hidden;box-shadow:var(--shadow)}
.panel-hdr{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid var(--border);background:var(--surface2)}
.panel-title{font-size:14px;font-weight:700;color:var(--text)}
.panel-body{padding:16px}
.panel-body.p{padding:16px}

/* ── TABLES ──────────────────────────────────────────── */
.tbl-wrap{overflow-x:auto}
table{width:100%;border-collapse:collapse}
thead{background:var(--surface2)}
th{padding:10px 12px;text-align:left;font-size:11px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.3px;border-bottom:2px solid var(--border)}
td{padding:10px 12px;border-bottom:1px solid var(--border);font-size:13px}
tr:hover{background:var(--surface2)}
.winner-row{background:#ecfdf5!important}
table.item-bids{font-size:12px}
table.item-bids th{font-size:10px;padding:6px 8px}
table.item-bids td{padding:6px 8px}

/* ── BADGES ──────────────────────────────────────────── */
.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:20px;font-size:11px;font-weight:600}
.badge-active{background:#dcfce7;color:#166534}
.badge-draft{background:#e0e7ff;color:#3730a3}
.badge-closed{background:#fef3c7;color:#92400e}
.badge-cancelled{background:#fee2e2;color:#991b1b}
.badge-pending{background:#fef9c3;color:#854d0e}
.badge-approved{background:#dcfce7;color:#166534}
.badge-rejected{background:#fee2e2;color:#991b1b}
.badge-won{background:#dcfce7;color:#166534;font-weight:700}
.badge-lost{background:#f1f5f9;color:#64748b}
.badge-lowest{background:#dbeafe;color:#1e40af}
.badge-highest{background:#fce7f3;color:#9d174d}

/* ── RANK BADGES ─────────────────────────────────────── */
.rank-badge{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;font-size:12px;font-weight:800}
.rank-1{background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#78350f}
.rank-2{background:linear-gradient(135deg,#d1d5db,#9ca3af);color:#374151}
.rank-3{background:linear-gradient(135deg,#d97706,#b45309);color:#fff}
.rank-other{background:var(--surface2);color:var(--text2);border:1px solid var(--border)}

/* ── TABS ────────────────────────────────────────────── */
.tabs{display:flex;gap:0;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;margin-bottom:16px}
.tab{flex:1;padding:10px 16px;text-align:center;cursor:pointer;font-size:13px;font-weight:600;color:var(--text3);transition:all .2s;border-bottom:2px solid transparent}
.tab:hover{background:var(--surface2);color:var(--text)}
.tab.active{color:var(--primary);border-bottom-color:var(--primary);background:var(--surface2)}

/* ── VIEW TOGGLE ─────────────────────────────────────── */
.view-toggle{display:inline-flex;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}
.view-toggle-btn{padding:6px 14px;font-size:12px;font-weight:600;cursor:pointer;border:none;background:transparent;color:var(--text3);transition:all .15s}
.view-toggle-btn.active{background:var(--primary);color:#fff}

/* ── MODALS ──────────────────────────────────────────── */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:200;display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeIn .15s}
.modal-box{background:var(--surface);border-radius:var(--radius-lg);width:100%;max-width:640px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow2);animation:slideUp .2s}
.modal-box.wide{max-width:800px}
.modal-hdr{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border)}
.modal-hdr h3{font-size:16px;font-weight:700}
.modal-close{background:none;border:none;font-size:20px;cursor:pointer;color:var(--text3);padding:4px}
.modal-body{padding:20px;overflow-y:auto;flex:1}
.modal-footer{padding:12px 20px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:8px;background:var(--surface2)}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes slideUp{from{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}

/* ── TOAST ───────────────────────────────────────────── */
.toast{position:fixed;top:20px;right:20px;padding:12px 20px;border-radius:var(--radius);font-size:13px;font-weight:600;z-index:300;animation:slideIn .3s;box-shadow:var(--shadow2);max-width:400px}
.toast-success{background:#dcfce7;color:#166534;border:1px solid #86efac}
.toast-error{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}
.toast-info{background:#dbeafe;color:#1e40af;border:1px solid #93c5fd}
@keyframes slideIn{from{transform:translateX(100%);opacity:0}to{transform:translateX(0);opacity:1}}

/* ── LOADING ─────────────────────────────────────────── */
.loading-wrap{display:flex;justify-content:center;padding:40px}
.spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.empty{text-align:center;padding:32px;color:var(--text3);font-size:14px}

/* ── COUNTDOWN ───────────────────────────────────────── */
.countdown{font-family:'SF Mono',Monaco,monospace;font-weight:700;font-size:16px}
.countdown.green{color:var(--accent)}.countdown.orange{color:var(--warning)}.countdown.red{color:var(--danger)}
.countdown.blink{animation:blink .5s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}

/* ── LIVE INDICATOR ──────────────────────────────────── */
.live-dot{width:8px;height:8px;border-radius:50%;background:var(--danger);display:inline-block;animation:pulse 1.5s infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}

/* ── SSE STATUS ──────────────────────────────────────── */
.sse-status{display:inline-flex;align-items:center;gap:4px;font-size:11px;padding:2px 8px;border-radius:20px}
.sse-connected{background:#dcfce7;color:#166534}
.sse-disconnected{background:#fee2e2;color:#991b1b}

/* ── BID ITEM CARD ───────────────────────────────────── */
.bid-item-card{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);padding:12px;margin-bottom:8px}
.bid-item-card .item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.bid-item-card .item-header b{font-size:13px}
.bid-item-card .bid-input-row{display:grid;grid-template-columns:1fr 1fr auto;gap:8px;align-items:end}

/* ── RANKING DISPLAY ─────────────────────────────────── */
.rank-display{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);margin-top:6px}
.rank-label{font-size:16px;font-weight:800;font-family:monospace}
.rank-label.l{color:#1e40af}.rank-label.h{color:#9d174d}

/* ── AUTO-EXTEND BADGE ───────────────────────────────── */
.extend-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:20px;font-size:10px;font-weight:700;background:#fef3c7;color:#92400e;border:1px solid #fde68a}

/* ── RESPONSIVE (MOBILE APP-LIKE) ────────────────────── */
@media(max-width:768px){
  html,body{overflow-x:hidden!important;width:100%!important}
  #app{overflow-x:hidden;width:100%}
  .main-wrap{width:100%;max-width:100vw;overflow-x:hidden}
  .content{padding:10px 8px;overflow-x:hidden;max-width:100%;box-sizing:border-box}

  /* Show sidebar + hamburger on mobile */
  .sidebar{display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;width:260px;background:var(--primary-dark);color:#fff;z-index:200;transform:translateX(-100%);transition:transform .3s;box-shadow:none}
  .sidebar.open{transform:translateX(0);box-shadow:4px 0 20px rgba(0,0,0,.3)}
  .sb-brand{padding:16px;display:flex;align-items:center;gap:10px;border-bottom:1px solid rgba(255,255,255,.1)}
  .brand-icon{font-size:24px}.brand-name{font-size:15px;font-weight:700}.brand-user{font-size:11px;opacity:.7}
  #sb-nav{flex:1;overflow-y:auto;padding:8px 0}
  .nav-item{display:flex;align-items:center;gap:8px;padding:10px 16px;color:rgba(255,255,255,.75);cursor:pointer;font-size:13px;transition:all .15s;border-left:3px solid transparent}
  .nav-item:hover{background:rgba(255,255,255,.08);color:#fff}
  .nav-item.active{background:rgba(255,255,255,.12);color:#fff;border-left-color:var(--accent)}
  .nav-section{padding:12px 16px 4px;font-size:10px;font-weight:700;text-transform:uppercase;color:rgba(255,255,255,.35);letter-spacing:.8px}
  .sb-footer{padding:12px 16px;border-top:1px solid rgba(255,255,255,.1)}
  .btn-logout{width:100%;padding:8px;background:rgba(255,255,255,.08);color:rgba(255,255,255,.8);border:none;border-radius:var(--radius);cursor:pointer;font-size:13px}
  .sb-overlay{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:199;display:none}
  .sb-overlay.show{display:block}
  .menu-toggle{display:block!important;font-size:22px;padding:4px 8px;cursor:pointer;background:none;border:none;color:#fff}
  .topnav{height:44px;padding:0 8px}
  .topnav-menu{display:none}
  .tn-bell{font-size:14px;padding:0 6px}
  .tn-avatar{width:26px;height:26px;font-size:10px}
  .tn-drop-menu{display:none!important}
  .mod-switch{font-size:10px;padding:0 4px;height:44px;gap:2px}
  .mod-switch .tn-arrow{display:none}
  .comp-switch{font-size:10px;padding:0 4px;height:44px;gap:2px}
  .comp-switch .tn-arrow{display:none}
  /* Mobile tap to open menus */
  .tn-drop.mob-open>.tn-drop-menu{display:block!important;position:fixed;top:44px;left:0;right:0;border-radius:0;min-width:100vw;max-height:60vh;overflow-y:auto;z-index:250}
  /* Sidebar switchers */
  .sb-switcher{display:flex;flex-direction:column;gap:4px;padding:8px 12px;border-bottom:1px solid rgba(255,255,255,.1)}
  .sb-sw-btn{display:flex;align-items:center;gap:6px;padding:8px 10px;border-radius:6px;background:rgba(255,255,255,.08);color:rgba(255,255,255,.8);cursor:pointer;font-size:12px;font-weight:600;border:none;width:100%;text-align:left}
  .sb-sw-btn:hover{background:rgba(255,255,255,.15)}
  .sb-sw-btn.active{background:rgba(255,255,255,.12);border-left:3px solid var(--accent)}
  .sb-sw-label{font-size:9px;text-transform:uppercase;letter-spacing:.8px;color:rgba(255,255,255,.3);font-weight:700;padding:4px 0 2px}

  /* ══ UNIVERSAL TABLE FIX ══ */
  table{font-size:11px!important;min-width:0!important;word-break:break-word}
  th{padding:4px 6px!important;font-size:10px!important;white-space:nowrap}
  td{padding:5px 6px!important;font-size:11px!important}
  /* Parent containers scroll horizontally */
  .tbl-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:0 -8px;padding:0 8px}
  .panel-body{overflow-x:auto;-webkit-overflow-scrolling:touch}
  .panel-body.p{overflow-x:auto;-webkit-overflow-scrolling:touch}

  /* ══ STATS / INFO GRID ══ */
  .stats-row{grid-template-columns:repeat(2,1fr)!important;gap:6px}
  .stat-card{padding:8px}
  .stat-val{font-size:16px}
  .sp-info-grid{grid-template-columns:repeat(2,1fr)!important;gap:4px}
  .sp-info-item{padding:6px 8px}
  .sp-info-item .val{font-size:12px}

  /* ══ PANELS ══ */
  .panel{border-radius:var(--radius);overflow:hidden}
  .panel-hdr{padding:8px 10px;flex-wrap:wrap;gap:4px;font-size:12px}
  .panel-hdr .panel-title{font-size:13px}
  .panel-body.p{padding:8px 10px}

  /* ══ FORMS ══ */
  .form-row.cols-2,.form-row.cols-3,.form-row.cols-4,.form-row.cols-5{grid-template-columns:1fr}
  .form-group{margin-bottom:6px}
  .form-group input,.form-group select,.form-group textarea{font-size:14px!important;padding:10px 10px!important;box-sizing:border-box}
  /* Table inputs stay compact */
  table input,table select{font-size:12px!important;padding:3px 4px!important}

  /* ══ MODALS ══ */
  .modal-overlay{padding:2px}
  .modal-box{max-width:100%!important;max-height:96vh;border-radius:var(--radius);margin:0}
  .modal-box.wide{max-width:100%!important}
  .modal-hdr{padding:10px 12px;font-size:14px}
  .modal-body{padding:8px;max-height:74vh;overflow-y:auto}
  .modal-footer{padding:6px 8px;flex-wrap:wrap;gap:4px}
  /* Modal form labels compact */
  .modal-body .form-group label{font-size:11px;margin-bottom:2px}
  .modal-body b{font-size:12px}

  /* ══ BUTTONS ══ */
  .btn{padding:7px 10px;font-size:12px;white-space:normal}
  .btn-sm{padding:5px 8px;font-size:11px}
  .btn-xs{padding:3px 6px;font-size:10px}
  .btn-full{padding:12px}

  /* ══ TABS ══ */
  .tabs{gap:0;overflow-x:auto;-webkit-overflow-scrolling:touch}
  .tab{font-size:11px;padding:8px 10px;flex:1;text-align:center;white-space:nowrap;min-width:0}

  /* ══ COUNTDOWN / BADGES ══ */
  .countdown{font-size:12px!important}
  .badge{font-size:10px;padding:1px 5px}
  .extend-badge{font-size:9px;padding:1px 5px}

  /* ══ TRANSPORT — Trading Terminal Form ══ */
  .tt-body{grid-template-columns:1fr!important}
  .tt-col:first-child{border-right:none;border-bottom:1px solid var(--border)}
  .tt-col{padding:6px 8px!important;gap:3px!important}
  .tt-row{flex-wrap:wrap;gap:3px!important}
  .tt-f{min-width:calc(50% - 3px)!important;flex:1 1 calc(50% - 3px)}
  .tt-f.tt-f2{min-width:100%!important}
  .tt-f.tt-f3{min-width:calc(33% - 3px)!important;flex:1 1 calc(33% - 3px)} /* 3-col fields */
  .tt-inp{padding:6px 6px!important;font-size:12px!important}
  select.tt-inp{padding:5px 4px!important;font-size:11px!important}
  .tt-f label{font-size:8px!important;margin-bottom:0!important}
  .tt-sec{font-size:8px!important;padding:1px 0!important;margin-top:2px}
  .tt-sep{margin:2px 0!important}
  .tt-top{padding:4px 8px!important}
  .tt-title{font-size:12px!important}
  .tt-hint{font-size:7px!important}
  .tt-submit{position:sticky;bottom:0;background:var(--surface);padding:6px 0;z-index:5;border-top:1px solid var(--border)}
  .tt-btn{padding:8px 12px!important;font-size:12px!important}
  .tt-btn-go{flex:1;text-align:center;padding:10px!important}

  /* ══ SP CARDS + INFO GRID — Ultra compact ══ */
  .sp-card{margin-bottom:6px}
  .sp-card-hdr{flex-wrap:wrap;gap:4px;padding:6px 8px}
  .sp-card-body{padding:6px 8px}
  .sp-route{font-size:11px!important;gap:3px!important;flex-wrap:wrap}
  .sp-route-line{min-width:14px!important;flex:0 0 14px!important}
  .sp-route b{font-size:12px}
  .sp-load-id{font-size:10px}
  .sp-badge{font-size:8px!important;padding:1px 5px!important}
  .sp-timer{font-size:11px!important;padding:2px 5px!important}
  .sp-meta{gap:3px 6px!important;font-size:10px!important;margin-top:3px!important}
  .sp-meta-item{gap:2px}
  .sp-date-block{min-width:36px}
  .sp-date-block .day{font-size:14px}
  .sp-date-block .month{font-size:8px}
  .sp-date-block .time{font-size:9px}
  .sp-bid-row{grid-template-columns:30px 1fr!important;row-gap:3px}
  .sp-bid-row>div:nth-child(n+3){padding-left:36px;font-size:10px}
  .sp-rank{width:22px!important;height:22px!important;font-size:9px!important}
  .sp-info-grid{gap:3px!important}
  .sp-info-item{padding:4px 6px!important}
  .sp-info-item .lbl{font-size:8px!important}
  .sp-info-item .val{font-size:11px!important}
  .sp-bid-trail{font-size:9px!important}
  .sp-bid-rate{font-size:13px!important}
  /* Listing cards — prevent header overflow */
  .lc{margin-bottom:4px!important}
  .lc-row1,.lc-row2{flex-wrap:wrap!important;gap:3px!important;padding:6px 8px!important}
  .lc-uid{font-size:10px!important}
  .lc-route{font-size:11px!important}
  .lc-timer{font-size:11px!important}
  .lc-tag{font-size:9px!important;padding:0 4px!important}
  .lc-amount{font-size:11px!important}
  /* Shipping chips */
  .sh-chip{font-size:9px!important;padding:1px 5px!important}

  /* ══ TRANSPORT BIDDER — Bid form stack ══ */
  .tc-f[style*="width:100px"],.tc-f[style*="width:110px"],.tc-f[style*="width:130px"],.tc-f[style*="width:80px"]{width:calc(50% - 4px)!important;min-width:0!important}
  .tc-f[style*="min-width:150px"],.tc-f[style*="min-width:120px"]{min-width:100%!important}
  .tc-row,.tc-f-row{flex-wrap:wrap!important}

  /* ══ TRANSPORT — Bid listing grid ══ */
  div[style*="grid-template-columns:40px"]{grid-template-columns:1fr!important;gap:2px!important}
  div[style*="grid-template-columns:40px"]>div:first-child{display:none} /* hide # column */

  /* ══ SCRAP BIDDER — Bid entries ══ */
  .bid-entry-row{flex-wrap:wrap!important;gap:4px}
  div[style*="grid-template-columns:1fr 1fr"]{grid-template-columns:1fr!important}

  /* ══ SHIPPING — Container tables ══ */
  .sh-bid-tbl{display:block;overflow-x:auto}

  /* ══ VIEW TOGGLE ══ */
  .view-toggle{margin-top:4px}
  .view-toggle-btn{font-size:10px;padding:4px 8px}

  /* ══ LOGIN ══ */
  .login-body{padding:8px}
  .login-card{margin:0 auto;padding:16px;max-width:100%;width:100%;box-sizing:border-box}
  .login-brand h1{font-size:18px}
  .demo-grid{font-size:11px}
  .demo-item{padding:6px 8px}

  /* ══ GENERIC OVERFLOW PREVENTION ══ */
  *{max-width:100vw}
  div[style*="display:flex"]{max-width:100%}
  div[style*="display:grid"]{max-width:100%;overflow-x:auto}
  img{max-width:100%;height:auto}
  pre,code{overflow-x:auto;max-width:100%;word-break:break-all}
  /* Prevent any inline style grid from overflowing */
  div[style*="grid-template-columns:repeat(auto-fill,minmax(250px"]{grid-template-columns:1fr!important}
  div[style*="grid-template-columns:repeat(auto-fit,minmax(160px"]{grid-template-columns:repeat(auto-fit,minmax(120px,1fr))!important}
}

@media(max-width:480px){
  .content{padding:6px 4px}
  .stats-row{grid-template-columns:1fr!important}
  .sp-info-grid{grid-template-columns:repeat(2,1fr)!important}
  .tabs{flex-wrap:wrap}
  .tab{flex:1;min-width:70px;font-size:10px;padding:7px 6px}
  .panel-hdr{flex-direction:column;align-items:flex-start;gap:3px}
  .page-title{font-size:13px}
  td,th{padding:3px 4px!important;font-size:10px!important}
  .form-group label{font-size:11px}
  /* TT: Keep 2-col default! Only tt-f2 goes full-width */
  .tt-f{min-width:calc(50% - 2px)!important}
  .tt-f.tt-f2{min-width:100%!important}
  .tt-f.tt-f3{min-width:calc(33% - 2px)!important;flex:1 1 calc(33% - 2px)}
  .tt-inp{padding:5px 5px!important;font-size:11px!important}
  .tt-f label{font-size:7px!important}
  div[style*="grid-template-columns:repeat(auto-fit,minmax(120px"]{grid-template-columns:1fr!important}
  div[style*="grid-template-columns:repeat(auto-fill,minmax(200px"]{grid-template-columns:1fr!important}
  .tc-f[style*="width"]{width:100%!important;min-width:0!important}
  .btn{font-size:11px;padding:6px 8px}
  /* SP card extreme compact */
  .sp-card-hdr{padding:4px 6px!important}
  .sp-card-body{padding:4px 6px!important}
  .sp-route{font-size:10px!important}
  .sp-route b{font-size:11px!important}
  .sp-meta{font-size:9px!important}
  .sp-date-block{display:none!important} /* hide date block on tiny screens */
  .sp-info-item .val{font-size:10px!important}
  /* Listing cards */
  .lc-row1,.lc-row2{padding:4px 6px!important}
  .lc-spacer{display:none!important}
  /* Hide empty Action columns on mobile */
  th:empty,td:empty{display:none}
}

/* PWA-like */
html{overscroll-behavior:none}
body{-webkit-tap-highlight-color:transparent}

/* ── ULTRA-COMPACT ITEM BIDS ─────────────────────────── */
table.item-bids{border-collapse:collapse;width:100%}
table.item-bids th{padding:4px 8px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.3px;border-bottom:1px solid var(--border);background:var(--surface2);color:var(--text3)}
table.item-bids td{padding:4px 8px;border-bottom:1px solid var(--border);font-size:11px;line-height:1.3}
table.item-bids tr:last-child td{border-bottom:none}
table.item-bids tr:hover{background:var(--surface2)}

/* Dark header row for location columns */
table.item-bids tr.hdr-dark th{background:#1e293b!important;color:#fff!important}
table.item-bids tr.hdr-sub th{background:#334155!important;color:#e2e8f0!important;font-size:9px!important;text-transform:none!important}

/* Location group header */
.loc-hdr{padding:6px 12px;background:#1e293b;color:#fff;font-size:12px;font-weight:600}

/* Resizable column table */
table.col-table{table-layout:fixed}
table.col-table th{position:relative;overflow:hidden;text-overflow:ellipsis}
table.col-table th .col-resize{position:absolute;right:-2px;top:0;bottom:0;width:5px;cursor:col-resize;z-index:5;background:transparent}
table.col-table th .col-resize:hover,table.col-table th .col-resize.active{background:var(--accent)}
table.col-table td{overflow:hidden;text-overflow:ellipsis}

/* Sticky columns for bid table horizontal scroll */
.sticky-col{position:sticky;z-index:2;background:var(--surface)}
thead .sticky-col{background:#1e3a5f;z-index:4}
.hdr-sub .sticky-col{background:#2d4a6f;z-index:4}
tr:nth-child(even) .sticky-col{background:var(--bg)}
tr:hover .sticky-col{background:#f0f9ff}

/* ── ALLOTMENT HIGHLIGHT ─────────────────────────────── */
.allot-row{background:#ecfdf5!important}
.allot-badge{display:inline-flex;align-items:center;gap:3px;padding:1px 6px;border-radius:10px;font-size:9px;font-weight:700;background:#dcfce7;color:#166534;border:1px solid #86efac}

/* ── MODULE SWITCHER PILL ─────────────────────────────── */
.mod-pill{padding:3px 10px;border-radius:20px;border:1px solid rgba(255,255,255,.2);background:transparent;color:rgba(255,255,255,.7);font-size:10px;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap}
.mod-pill:hover{background:rgba(255,255,255,.1);color:#fff}
.mod-pill.active{background:var(--accent);color:#fff;border-color:var(--accent)}
@media(max-width:768px){.mod-pill{font-size:9px;padding:2px 7px}}

/* ── TOPBAR RESPONSIVE: Icon-only on small laptops ──── */
@media(max-width:1280px){
  .tn-item{padding:0 8px;gap:3px}
  .tn-label{font-size:11px}
}
@media(max-width:1100px){
  .tn-item{padding:0 6px;gap:0;justify-content:center;flex-direction:column}
  .tn-label{font-size:8px;opacity:.7;line-height:1}
  .tn-icon{font-size:16px;line-height:1}
  .tn-item.active .tn-label{opacity:1}
  .topnav-brand{font-size:12px;padding-right:4px;margin-right:2px}
  .topnav-brand b{font-size:11px}
}
@media(max-width:960px){
  .tn-label{display:none!important} /* icon-only */
  .tn-item{padding:0 8px;min-width:0}
  .tn-icon{font-size:18px}
  .tn-arrow{font-size:8px;margin-left:1px}
  /* Tooltip on hover */
  .tn-item{position:relative}
  .tn-item:hover::after{content:attr(title);position:absolute;top:100%;left:50%;transform:translateX(-50%);background:#1e293b;color:#fff;padding:3px 8px;border-radius:4px;font-size:11px;white-space:nowrap;z-index:300;pointer-events:none;box-shadow:0 2px 8px rgba(0,0,0,.3)}
  .topnav-brand b{display:none}
  .mod-switch .tn-label{display:inline!important;font-size:10px} /* keep module name visible */
  .comp-switch .tn-label{display:none!important}
}

/* ── SHIPPING SPECIFIC ────────────────────────────────── */
.badge-highest{background:linear-gradient(135deg,#f97316,#ea580c)!important;color:#fff!important}
.badge-pending_approval{background:#fef3c7;color:#92400e;border:1px solid #fcd34d}
.badge-allocated{background:#dcfce7;color:#166534;border:1px solid #86efac}
.badge-approved{background:#d1fae5;color:#065f46;border:1px solid #6ee7b7}

/* ── ULTRA COMPACT SHIPPING UI (Stock Market App Style) ── */
.sh-card{background:var(--surface);border:1px solid var(--border);border-radius:8px;margin-bottom:6px;overflow:hidden;cursor:pointer;transition:box-shadow .15s}
.sh-card:active{box-shadow:0 0 0 2px var(--primary-light)}
.sh-card-top{display:flex;justify-content:space-between;align-items:center;padding:8px 10px;gap:4px}
.sh-card-left{flex:1;min-width:0}
.sh-card-uid{font-size:13px;font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sh-card-route{font-size:11px;color:var(--text2);margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sh-card-right{text-align:right;flex-shrink:0}
.sh-card-meta{display:flex;gap:6px;padding:0 10px 6px;flex-wrap:wrap;align-items:center}
.sh-chip{display:inline-flex;align-items:center;gap:2px;padding:1px 6px;border-radius:10px;font-size:9px;font-weight:600;white-space:nowrap}
.sh-chip-sea{background:#dbeafe;color:#1e40af}.sh-chip-air{background:#fef3c7;color:#92400e}
.sh-chip-bid{background:#dcfce7;color:#166534}.sh-chip-nobid{background:#fef2f2;color:#991b1b}
.sh-chip-rank{background:#ede9fe;color:#5b21b6}.sh-chip-pri{background:#fce7f3;color:#9d174d}
.sh-timer{font-size:11px;font-weight:700;font-variant-numeric:tabular-nums}
.sh-timer.live{color:#dc2626;animation:sh-pulse 1.5s infinite}.sh-timer.warn{color:#f59e0b}.sh-timer.safe{color:#059669}
.sh-timer.upcoming{color:var(--info)}
@keyframes sh-pulse{0%,100%{opacity:1}50%{opacity:.6}}

/* Detail page */
.sh-detail-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--border);border-radius:6px;overflow:hidden;margin:6px 0}
.sh-detail-cell{background:var(--surface);padding:6px 8px}
.sh-detail-cell .sh-dl{font-size:9px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.3px}
.sh-detail-cell .sh-dv{font-size:12px;font-weight:600;color:var(--text);margin-top:1px}
.sh-detail-cell.wide{grid-column:span 2}
.sh-note{background:#fffbeb;border-left:3px solid #f59e0b;padding:6px 8px;font-size:11px;margin:4px 0;border-radius:0 4px 4px 0}

/* Bid form compact */
.sh-bid-panel{border:1px solid var(--primary);border-radius:8px;overflow:hidden;margin:6px 0}
.sh-bid-hdr{background:var(--primary);color:#fff;padding:6px 10px;font-size:12px;font-weight:700;display:flex;justify-content:space-between;align-items:center}
.sh-bid-body{padding:8px}
.sh-bid-fields{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:6px;margin-bottom:6px}
.sh-bid-fields label{font-size:9px;font-weight:700;color:var(--text3);text-transform:uppercase;display:block;margin-bottom:2px}
.sh-bid-fields select,.sh-bid-fields input{font-size:12px;padding:5px 6px;border-radius:4px}
.sh-bid-tbl{width:100%;border-collapse:collapse;font-size:10px}
.sh-bid-tbl th{background:var(--surface2);padding:4px 3px;font-size:9px;font-weight:700;color:var(--text3);text-transform:uppercase;white-space:nowrap;text-align:center;border-bottom:2px solid var(--border)}
.sh-bid-tbl td{padding:3px 2px;text-align:center;border-bottom:1px solid var(--border)}
.sh-bid-tbl input{width:100%;min-width:45px;font-size:11px;padding:4px 3px;text-align:right;border:1px solid var(--border);border-radius:3px}
.sh-bid-tbl input:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 1px var(--primary-light)}
.sh-bid-tbl .sh-rt{font-weight:700;color:var(--primary);font-size:11px;white-space:nowrap}
.sh-bid-tbl .sh-foot td{background:#f0fdf4;font-weight:700;font-size:10px;border-top:2px solid var(--accent)}
.sh-bid-tbl .sh-grand{font-size:13px;color:var(--accent)}
.sh-bid-actions{display:flex;gap:8px;align-items:center;margin-top:6px}
.sh-bid-actions .btn{flex:1}

/* Existing bids strip */
.sh-mybid{display:flex;justify-content:space-between;align-items:center;padding:6px 8px;border-left:3px solid var(--accent);background:var(--surface);border-radius:0 6px 6px 0;margin-bottom:4px}
.sh-mybid-info{font-size:11px}.sh-mybid-info b{font-size:12px}
.sh-mybid-rate{font-size:14px;font-weight:800;color:var(--accent)}

/* Container pills */
.sh-cont-row{display:flex;gap:4px;flex-wrap:wrap;padding:4px 0}
.sh-cont-pill{background:var(--surface2);border:1px solid var(--border);border-radius:4px;padding:3px 6px;font-size:10px;display:inline-flex;gap:4px;align-items:center}
.sh-cont-pill b{color:var(--primary)}

@media(max-width:1024px){
  .sh-detail-grid{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:480px){
  .sh-detail-grid{grid-template-columns:1fr 1fr}
  .sh-bid-fields{grid-template-columns:1fr 1fr}
  .sh-bid-tbl{font-size:9px}
  .sh-bid-tbl input{min-width:38px;font-size:10px;padding:3px 2px}
  .sh-bid-tbl th{font-size:8px;padding:3px 2px}
}

/* ── SCRAP COMPACT CARDS (Stock Market App Feel) ─────── */
.sc-card{background:var(--surface);border:1px solid var(--border);border-radius:8px;margin-bottom:6px;overflow:hidden;cursor:pointer;transition:box-shadow .15s}
.sc-card:active{box-shadow:0 0 0 2px var(--primary-light)}
.sc-card-top{display:flex;justify-content:space-between;align-items:center;padding:8px 10px}
.sc-card-title{font-size:13px;font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0}
.sc-card-meta{display:flex;gap:4px;padding:0 10px 6px;flex-wrap:wrap;align-items:center;font-size:10px}
.sc-chip{display:inline-flex;align-items:center;gap:2px;padding:1px 6px;border-radius:10px;font-size:9px;font-weight:600;white-space:nowrap;background:#f1f5f9;color:#475569}
.sc-chip-h{background:#fef3c7;color:#92400e}.sc-chip-l{background:#dbeafe;color:#1e40af}
.sc-chip-bid{background:#dcfce7;color:#166534}.sc-chip-nobid{background:#fef2f2;color:#991b1b}
.sc-timer{font-size:12px;font-weight:700;font-variant-numeric:tabular-nums;flex-shrink:0}
.sc-items-row{display:flex;gap:3px;padding:2px 10px 6px;overflow-x:auto;flex-wrap:nowrap}
.sc-item-pill{background:var(--surface2);border:1px solid var(--border);border-radius:4px;padding:2px 6px;font-size:9px;white-space:nowrap;flex-shrink:0}


/* Loading Skeleton */
.skeleton-wrap{padding:16px}
.skeleton-row{margin-bottom:14px}
.skeleton-block{background:linear-gradient(90deg,var(--surface2) 25%,var(--border) 50%,var(--surface2) 75%);background-size:200% 100%;border-radius:4px;animation:shimmer 1.5s infinite}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}

/* Empty State */
.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 16px;text-align:center}
.empty-state-icon{font-size:48px;margin-bottom:12px;opacity:.6}
.empty-state-text{font-size:14px;color:var(--text3);max-width:280px;line-height:1.5}

/* ═══ SP-STYLE TRANSPORT UI ═══ */
.sp-card{background:var(--surface);border:1px solid var(--border);border-radius:8px;margin-bottom:8px;overflow:hidden;transition:box-shadow .15s}
.sp-card:hover{box-shadow:0 2px 8px rgba(0,0,0,.08)}
.sp-card-hdr{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;border-bottom:1px solid var(--border);background:var(--bg)}
.sp-card-body{padding:10px 12px}
.sp-badge{display:inline-block;font-size:9px;font-weight:700;padding:2px 8px;border-radius:10px;text-transform:uppercase;letter-spacing:.5px}
.sp-badge-auction{background:#dbeafe;color:#1e40af}
.sp-badge-indent{background:#fef3c7;color:#92400e}
.sp-badge-live{background:#dcfce7;color:#166534}
.sp-badge-closed{background:#f3f4f6;color:#6b7280}
.sp-badge-allotted{background:#d1fae5;color:#065f46}
.sp-badge-cancelled{background:#fee2e2;color:#991b1b}
.sp-badge-draft{background:#e0e7ff;color:#3730a3}
.sp-badge-offline{background:#fef3c7;color:#92400e;border:1px solid #fcd34d}
.sp-rank{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;font-weight:800;font-size:12px;color:#fff}
.sp-rank-1{background:linear-gradient(135deg,#059669,#10b981)}
.sp-rank-2{background:linear-gradient(135deg,#2563eb,#3b82f6)}
.sp-rank-3{background:linear-gradient(135deg,#d97706,#f59e0b)}
.sp-rank-n{background:#9ca3af}
.sp-route{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:600}
.sp-route-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.sp-route-dot.from{background:#059669}
.sp-route-dot.to{background:#dc2626}
.sp-route-line{flex:1;height:2px;background:linear-gradient(90deg,#059669,#dc2626);min-width:30px}
.sp-timer{font-family:'Courier New',monospace;font-size:13px;font-weight:700;color:var(--danger);padding:3px 8px;border:1px solid var(--danger);border-radius:4px;background:#fef2f2}
.sp-timer.live{animation:pulse-border 1.5s infinite}
@keyframes pulse-border{0%,100%{border-color:var(--danger)}50%{border-color:transparent}}
.sp-meta{display:flex;flex-wrap:wrap;gap:8px;font-size:11px;color:var(--text3);margin-top:6px}
.sp-meta-item{display:flex;align-items:center;gap:3px}
.sp-meta-item b{color:var(--text)}
.sp-bid-row{display:grid;grid-template-columns:40px 1.5fr 1fr 80px 80px auto;gap:8px;align-items:center;padding:10px 12px;border-bottom:1px solid var(--border)}
.sp-bid-row:hover{background:var(--bg)}
.sp-bid-rate{font-size:16px;font-weight:800;color:var(--primary)}
.sp-bid-trail{font-size:10px;color:var(--text3);margin-top:2px}
.sp-load-id{font-size:11px;color:var(--primary);font-weight:700;font-family:'Courier New',monospace}
.sp-date-block{text-align:center;min-width:50px}
.sp-date-block .day{font-size:18px;font-weight:800;color:var(--primary);line-height:1}
.sp-date-block .month{font-size:9px;color:var(--text3);text-transform:uppercase;font-weight:600}
.sp-date-block .time{font-size:10px;color:var(--text2)}
.sp-info-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:6px;margin:8px 0}
.sp-info-item{padding:6px 8px;background:var(--bg);border-radius:6px;border-left:3px solid var(--primary)}
.sp-info-item .lbl{font-size:9px;color:var(--text3);text-transform:uppercase;font-weight:600}
.sp-info-item .val{font-size:13px;font-weight:700;color:var(--text)}
.sp-actions{display:flex;gap:4px;flex-wrap:wrap}
.sp-btn-bid{background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;border:none;padding:6px 16px;border-radius:6px;font-weight:700;font-size:12px;cursor:pointer;transition:transform .1s}
.sp-btn-bid:hover{transform:scale(1.03)}
.sp-btn-bid:disabled{opacity:.5;cursor:not-allowed;transform:none}

/* ═══ SP FORM — MOBILE-FIRST ═══ */
.sp-form{max-width:800px;margin:0 auto;display:flex;flex-direction:column;gap:8px}
.sp-form-section{background:var(--surface);border:1px solid var(--border);border-radius:8px;overflow:hidden}
.sp-form-hdr{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;background:var(--bg);cursor:pointer;user-select:none;font-size:12px;font-weight:700;color:var(--primary);letter-spacing:.5px;border-bottom:1px solid var(--border)}
.sp-form-hdr:active{background:var(--border)}
.sp-form-arrow{font-size:10px;transition:transform .2s}
.sp-form-body{padding:10px 14px;display:flex;flex-direction:column;gap:8px;transition:all .2s}
.sp-form-body.sp-collapsed{display:none}
.sp-form-row{display:flex;gap:8px;flex-wrap:wrap}
.sp-form-field{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}
.sp-form-field label{font-size:10px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.3px}
.sp-form-field.sp-form-grow{flex:2}
.sp-inp{width:100%;padding:8px 10px;border:1px solid var(--border);border-radius:6px;font-size:13px;background:var(--surface);color:var(--text);outline:none;transition:border-color .15s;box-sizing:border-box}
.sp-inp:focus{border-color:var(--primary);box-shadow:0 0 0 2px rgba(37,99,235,.1)}
.sp-inp::placeholder{color:var(--text3);font-size:11px}
select.sp-inp{appearance:auto}
.sp-form-actions{display:flex;justify-content:flex-end;gap:8px;padding:8px 0;position:sticky;bottom:0;background:var(--bg);z-index:5;border-top:1px solid var(--border);margin-top:4px;padding:12px 0}

/* MOBILE: Stack everything vertically */
@media(max-width:600px){
  .sp-form-row{flex-direction:column;gap:6px}
  .sp-form-field{min-width:100%!important;max-width:100%!important}
  .sp-form-field.sp-form-grow{flex:1}
  .sp-form-hdr{padding:12px 14px;font-size:13px}
  .sp-form-body{padding:12px 14px;gap:10px}
  .sp-inp{padding:10px 12px;font-size:14px}
  .sp-form-actions{padding:14px 8px}
  .sp-form-actions .sp-btn-bid{width:100%;text-align:center}
  .sp-info-grid{grid-template-columns:1fr 1fr!important}
  .sp-bid-row{grid-template-columns:36px 1fr!important;row-gap:6px}
  .sp-bid-row>div:nth-child(n+3){padding-left:44px}
  .sp-card-body{padding:8px 10px}
  .sp-route{flex-wrap:wrap;font-size:12px!important}
}
@media(min-width:601px) and (max-width:900px){
  .sp-form-row{flex-wrap:wrap}
  .sp-form-field{min-width:calc(50% - 4px)}
}

/* ═══ TRADING TERMINAL — Zerodha/Groww Compact ═══ */
.tt{background:var(--surface);border:1px solid var(--border);border-radius:8px;overflow:hidden;font-size:11px}
.tt-top{display:flex;justify-content:space-between;align-items:center;padding:6px 12px;background:linear-gradient(135deg,#1e3a5f,#1e40af);color:#fff}
.tt-title{font-weight:800;font-size:13px;letter-spacing:1px}
.tt-body{display:grid;grid-template-columns:1fr 1fr;gap:0}
.tt-col{padding:8px 10px;display:flex;flex-direction:column;gap:4px}
.tt-col:first-child{border-right:1px solid var(--border)}
.tt-sec{font-size:9px;font-weight:800;color:var(--primary);letter-spacing:1.5px;padding:2px 0;text-transform:uppercase}
.tt-sep{height:1px;background:var(--border);margin:4px 0}
.tt-row{display:flex;gap:4px;align-items:end}
.tt-f{display:flex;flex-direction:column;gap:1px;flex:1;min-width:0}
.tt-f label{font-size:8px;font-weight:700;color:var(--text3);letter-spacing:.5px;text-transform:uppercase;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tt-f.tt-f2{flex:2}
.tt-f.tt-f3{flex:1;min-width:0;max-width:none}
.tt-inp{width:100%;padding:5px 6px;border:1px solid var(--border);border-radius:4px;font-size:11px;background:var(--bg);color:var(--text);outline:none;box-sizing:border-box;transition:border .15s}
.tt-inp:focus{border-color:var(--primary);background:var(--surface)}
.tt-inp.tt-hl{border-color:#f59e0b;background:#fffbeb;font-weight:700}
.tt-inp.tt-dim{color:var(--text3);font-size:10px}
.tt-inp::placeholder{color:var(--text3);font-size:10px}
select.tt-inp{appearance:auto;padding:4px 4px;font-size:10px}
.tt-hint{font-size:8px;color:var(--text3);margin-top:1px}
.tt-submit{display:flex;gap:6px;justify-content:flex-end;margin-top:6px;padding-top:6px;border-top:1px solid var(--border)}
.tt-btn{padding:6px 14px;border:none;border-radius:4px;font-weight:700;font-size:11px;cursor:pointer;transition:all .1s}
.tt-btn-go{background:linear-gradient(135deg,#059669,#10b981);color:#fff;padding:8px 24px;font-size:12px;letter-spacing:.5px}
.tt-btn-go:hover{transform:scale(1.02);box-shadow:0 2px 8px rgba(5,150,105,.3)}
.tt-btn-ghost{background:transparent;color:var(--text3);border:1px solid var(--border)}
.tt-btn-ghost:hover{background:var(--bg)}
.tt-actions{display:flex;gap:4px}

/* Mobile: stack columns */
@media(max-width:700px){
  .tt-body{grid-template-columns:1fr}
  .tt-col:first-child{border-right:none;border-bottom:1px solid var(--border)}
  .tt-row{flex-wrap:wrap}
  .tt-f{min-width:calc(33% - 4px)}
  .tt-f.tt-f2{min-width:calc(66% - 4px)}
  .tt-inp{padding:7px 8px;font-size:12px}
  .tt-f label{font-size:9px}
  .tt-submit{position:sticky;bottom:0;background:var(--surface);padding:8px 0;z-index:5}
  .tt-btn-go{flex:1;text-align:center;padding:10px}
}
@media(max-width:400px){
  .tt-f{min-width:calc(50% - 2px)!important}
  .tt-f.tt-f2{min-width:100%!important}
  .tt-f.tt-f3{min-width:calc(50% - 2px)!important} /* 3-col → 2-col on tiny */
}

/* ═══ FMS MODULE — Jira/HubSpot Style ═══ */
.fms-board{display:flex;gap:10px;overflow-x:auto;padding-bottom:16px;-webkit-overflow-scrolling:touch;min-height:calc(100vh - 180px)}
.fms-col{min-width:280px;max-width:300px;flex-shrink:0;background:var(--bg);border-radius:12px;display:flex;flex-direction:column}
.fms-col-hdr{padding:10px 14px;display:flex;align-items:center;gap:8px;border-bottom:3px solid var(--col-color,var(--primary))}
.fms-col-dot{width:10px;height:10px;border-radius:50%;background:var(--col-color,var(--primary))}
.fms-col-title{font-weight:800;font-size:12px;flex:1;letter-spacing:0.3px;text-transform:uppercase}
.fms-col-count{font-size:10px;font-weight:700;color:var(--text3);background:var(--surface);padding:2px 8px;border-radius:12px}
.fms-col-body{flex:1;overflow-y:auto;padding:8px;display:flex;flex-direction:column;gap:8px;max-height:calc(100vh - 240px)}
.fms-card{background:var(--surface);border-radius:10px;padding:12px;border:1px solid var(--border);cursor:pointer;transition:all .15s}
.fms-card:hover{box-shadow:0 4px 12px rgba(0,0,0,.1);transform:translateY(-1px)}
.fms-card.overdue{border-left:3px solid #dc2626;background:#fef2f220}
.fms-card-id{font-size:10px;color:var(--primary);font-weight:800;letter-spacing:.5px}
.fms-card-title{font-weight:700;font-size:12px;margin:4px 0 8px;line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.fms-card-footer{display:flex;justify-content:space-between;align-items:center}
.fms-avatar{display:inline-flex;width:24px;height:24px;border-radius:50%;color:#fff;font-size:10px;font-weight:700;align-items:center;justify-content:center;flex-shrink:0}
.fms-avatar-sm{width:20px;height:20px;font-size:9px}
.fms-pri{font-size:9px;font-weight:800;padding:2px 6px;border-radius:4px;text-transform:uppercase;letter-spacing:.5px}
.fms-pri-urgent{background:#dc262615;color:#dc2626}.fms-pri-high{background:#f59e0b15;color:#d97706}
.fms-pri-normal{background:#3b82f615;color:#3b82f6}.fms-pri-low{background:#94a3b815;color:#6b7280}
.fms-badge{display:inline-block;padding:2px 8px;border-radius:12px;font-size:9px;font-weight:700;letter-spacing:.3px}
.fms-badge-pending{background:#f1f5f9;color:#64748b}.fms-badge-in_progress{background:#dbeafe;color:#2563eb}
.fms-badge-completed{background:#dcfce7;color:#059669}.fms-badge-rejected{background:#fee2e2;color:#dc2626}
.fms-badge-skipped{background:#f1f5f9;color:#9ca3af}.fms-badge-blocked{background:#ede9fe;color:#7c3aed}
.fms-tag{display:inline-block;font-size:9px;padding:1px 6px;border-radius:4px;background:var(--bg);color:var(--text3)}
.fms-pipeline{display:flex;align-items:center;gap:0;overflow-x:auto;padding:6px 0}
.fms-pipe-step{display:flex;align-items:center;flex-shrink:0}
.fms-pipe-circle{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800;border:2px solid;transition:all .2s}
.fms-pipe-circle.done{background:#059669;border-color:#059669;color:#fff}
.fms-pipe-circle.active{background:#2563eb;border-color:#2563eb;color:#fff;box-shadow:0 0 0 3px #2563eb30}
.fms-pipe-circle.pending{background:var(--surface);border-color:#d1d5db;color:#9ca3af}
.fms-pipe-line{width:32px;height:2px;flex-shrink:0}
.fms-pipe-line.done{background:#059669}.fms-pipe-line.pending{background:#d1d5db}
.fms-detail-grid{display:grid;grid-template-columns:1fr 320px;gap:14px}
@media(max-width:900px){.fms-detail-grid{grid-template-columns:1fr}.fms-board .fms-col{min-width:240px}}
@media(max-width:600px){.fms-board .fms-col{min-width:85vw}}
.fms-task-row{padding:14px;border-bottom:1px solid var(--border);display:flex;gap:12px;transition:background .15s}
.fms-task-row:hover{background:var(--bg)}
.fms-task-row.done{background:#f0fdf4}.fms-task-row.overdue{background:#fef2f2}
.fms-task-circle{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:11px;flex-shrink:0;color:#fff}
.fms-timeline-item{display:flex;gap:10px;padding:8px 0;border-bottom:1px solid var(--border)}
.fms-timeline-dot{width:8px;height:8px;border-radius:50%;margin-top:6px;flex-shrink:0}
.fms-stat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px;margin-bottom:16px}
.fms-stat{border-radius:12px;padding:14px;background:var(--surface);border:1px solid var(--border);text-align:center;cursor:pointer;transition:all .15s}
.fms-stat:hover{box-shadow:0 2px 10px rgba(0,0,0,.08);transform:translateY(-1px)}
.fms-stat-val{font-size:28px;font-weight:900;line-height:1}
.fms-stat-label{font-size:10px;color:var(--text3);margin-top:4px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}
.fms-wf-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:14px;margin-bottom:10px;cursor:pointer;transition:all .15s}
.fms-wf-card:hover{box-shadow:0 4px 12px rgba(0,0,0,.08);border-color:var(--primary)}
.fms-inst-row{background:var(--surface);border-radius:12px;padding:14px;margin-bottom:8px;border:1px solid var(--border);cursor:pointer;transition:all .15s}
.fms-inst-row:hover{box-shadow:0 3px 10px rgba(0,0,0,.08)}
.fms-inst-row.overdue{border-left:3px solid #dc2626}
.fms-progress{height:6px;background:var(--bg);border-radius:3px;overflow:hidden;flex:1;max-width:140px}
.fms-progress-fill{height:100%;border-radius:3px;transition:width .3s}
.fms-sidebar-panel{background:var(--surface);border:1px solid var(--border);border-radius:12px;margin-bottom:12px;overflow:hidden}
.fms-sidebar-hdr{padding:10px 14px;font-weight:800;font-size:11px;text-transform:uppercase;letter-spacing:.5px;background:var(--bg);border-bottom:1px solid var(--border);color:var(--text2)}
.fms-sidebar-body{padding:12px 14px}
.fms-detail-row{display:flex;gap:8px;padding:5px 0;font-size:11px;border-bottom:1px solid var(--border)}
.fms-detail-row:last-child{border-bottom:none}
.fms-detail-label{color:var(--text3);min-width:80px;font-weight:600}
.fms-detail-val{color:var(--text1);font-weight:600}
.fms-empty-col{text-align:center;color:var(--text3);font-size:11px;padding:30px 10px}
.fms-actions{display:flex;gap:4px;align-items:center}
