:root{
  --bg:#0b1220;
  --bg2:#0f172a;
  --panel:#111a2e;
  --panel2:#162034;
  --line:#1f2c47;
  --line2:#283655;
  --text:#e6edf7;
  --muted:#8b9bb8;
  --accent:#ffb01f;        /* Jamaica gold */
  --accent2:#1aa84a;       /* Jamaica green */
  --accent3:#0ea5e9;       /* link blue */
  --danger:#ef4444;
  --warn:#f59e0b;
  --ok:#22c55e;
  --pink:#ec4899;
  --purple:#a855f7;
  --radius:12px;
  --radius-sm:8px;
  --shadow: 0 4px 16px rgba(0,0,0,.25);
  --grad-gold: linear-gradient(135deg,#ffb01f 0%,#ff8c1a 100%);
  --grad-green: linear-gradient(135deg,#1aa84a 0%,#0e7a36 100%);
  --grad-dark: linear-gradient(135deg,#0b1220 0%,#162034 100%);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;font-size:14px;line-height:1.45}
button{font:inherit;color:inherit;cursor:pointer;border:none;background:none}
a{color:var(--accent3);text-decoration:none}
input,select,textarea{font:inherit;color:var(--text);background:var(--panel2);border:1px solid var(--line2);border-radius:var(--radius-sm);padding:.55rem .75rem;outline:none;width:100%}
input:focus,select:focus,textarea:focus{border-color:var(--accent)}
label{display:block;color:var(--muted);font-size:.78rem;margin-bottom:.3rem;text-transform:uppercase;letter-spacing:.04em}
hr{border:0;border-top:1px solid var(--line);margin:1rem 0}
.row{display:flex;gap:1rem}
.col{flex:1}
.muted{color:var(--muted)}
.tiny{font-size:.72rem}
.small{font-size:.82rem}
.bold{font-weight:600}
.center{text-align:center}
.right{text-align:right}
.spacer{flex:1}
.grid{display:grid;gap:1rem}
.g2{grid-template-columns:repeat(2,1fr)}
.g3{grid-template-columns:repeat(3,1fr)}
.g4{grid-template-columns:repeat(4,1fr)}
.g5{grid-template-columns:repeat(5,1fr)}
@media(max-width:1100px){.g4,.g5{grid-template-columns:repeat(2,1fr)}.g3{grid-template-columns:1fr}}
@media(max-width:700px){.g2,.g4,.g5{grid-template-columns:1fr}}

/* Layout */
.app{display:flex;min-height:100vh}
.sidebar{width:248px;background:var(--bg2);border-right:1px solid var(--line);padding:1rem .75rem;flex-shrink:0;position:sticky;top:0;height:100vh;overflow-y:auto}
.main{flex:1;display:flex;flex-direction:column;min-width:0}
.topbar{height:64px;border-bottom:1px solid var(--line);background:var(--bg2);display:flex;align-items:center;padding:0 1.25rem;gap:1rem;position:sticky;top:0;z-index:10}
.content{flex:1;padding:1.5rem;background:var(--bg);overflow-x:hidden}

/* Brand */
.brand{display:flex;align-items:center;gap:.6rem;padding:.4rem .5rem 1rem .5rem}
.brand-logo{width:36px;height:36px;border-radius:10px;background:var(--grad-gold);display:flex;align-items:center;justify-content:center;font-weight:800;color:#1a1300;font-size:18px;box-shadow:0 4px 12px rgba(255,176,31,.35)}
.brand-name{font-weight:700;font-size:1.05rem;letter-spacing:.02em}
.brand-name span{color:var(--accent2)}

/* Nav */
.nav-section{font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);padding:.75rem .5rem .35rem .5rem}
.nav-item{display:flex;align-items:center;gap:.65rem;padding:.55rem .7rem;border-radius:var(--radius-sm);color:var(--text);font-size:.88rem;cursor:pointer;margin-bottom:2px}
.nav-item:hover{background:var(--panel)}
.nav-item.active{background:var(--panel);color:var(--accent);font-weight:600;box-shadow:inset 3px 0 0 var(--accent)}
.nav-item .ico{width:18px;height:18px;flex-shrink:0;opacity:.85}
.nav-item .badge{margin-left:auto;background:var(--accent);color:#1a1300;border-radius:999px;padding:1px 7px;font-size:.7rem;font-weight:700}
.nav-item .badge.green{background:var(--accent2);color:#fff}
.nav-item .badge.red{background:var(--danger);color:#fff}

/* Topbar */
.role-switcher{background:var(--panel);border:1px solid var(--line2);padding:.45rem .75rem;border-radius:999px;display:flex;align-items:center;gap:.6rem;cursor:pointer;font-size:.85rem}
.role-switcher:hover{border-color:var(--accent)}
.role-avatar{width:28px;height:28px;border-radius:50%;background:var(--grad-green);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.78rem;color:#fff}
.search{flex:1;max-width:520px;position:relative}
.search input{padding-left:2.4rem;background:var(--panel)}
.search .ico{position:absolute;left:.8rem;top:50%;transform:translateY(-50%);opacity:.5}
.iconbtn{width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;background:var(--panel);border:1px solid var(--line2);position:relative}
.iconbtn:hover{border-color:var(--accent)}
.dot{position:absolute;top:8px;right:8px;width:8px;height:8px;border-radius:50%;background:var(--danger);box-shadow:0 0 0 2px var(--bg2)}

/* Cards */
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:1rem;box-shadow:var(--shadow)}
.card h3{margin:.1rem 0 .9rem 0;font-size:1rem}
.card h2{margin:.1rem 0 1rem 0;font-size:1.15rem}
.card-h{display:flex;align-items:center;justify-content:space-between;margin-bottom:.85rem}
.card-h h2,.card-h h3{margin:0}

/* KPI */
.kpi{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:1rem;position:relative;overflow:hidden;cursor:pointer;transition:all .15s ease}
.kpi:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 8px 20px rgba(255,176,31,.15)}
.kpi:active{transform:translateY(0)}
.kpi .label{color:var(--muted);font-size:.78rem;text-transform:uppercase;letter-spacing:.06em}
.kpi .v{font-size:1.6rem;font-weight:700;margin-top:.25rem}
.kpi .delta{font-size:.78rem;margin-top:.3rem}
.kpi .delta.up{color:var(--ok)}
.kpi .delta.down{color:var(--danger)}
.kpi .ico{position:absolute;right:1rem;top:1rem;width:32px;height:32px;border-radius:8px;background:var(--panel2);display:flex;align-items:center;justify-content:center;opacity:.7}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:.5rem;background:var(--panel2);border:1px solid var(--line2);padding:.55rem .9rem;border-radius:var(--radius-sm);font-weight:500;font-size:.86rem;color:var(--text);transition:all .15s ease}
.btn:hover{border-color:var(--accent)}
.btn-primary{background:var(--grad-gold);color:#1a1300;border-color:transparent;font-weight:700}
.btn-primary:hover{filter:brightness(1.05)}
.btn-green{background:var(--grad-green);color:#fff;border-color:transparent;font-weight:600}
.btn-ghost{background:transparent;border-color:var(--line2)}
.btn-danger{background:#7f1d1d;border-color:#991b1b;color:#fecaca}
.btn-sm{padding:.35rem .6rem;font-size:.78rem}

/* Tags / chips */
.chip{display:inline-flex;align-items:center;gap:.3rem;padding:.2rem .55rem;border-radius:999px;font-size:.72rem;font-weight:600;background:var(--panel2);border:1px solid var(--line2);color:var(--muted)}
.chip.ok{color:#86efac;background:rgba(34,197,94,.12);border-color:rgba(34,197,94,.3)}
.chip.warn{color:#fbbf24;background:rgba(245,158,11,.12);border-color:rgba(245,158,11,.3)}
.chip.danger{color:#fca5a5;background:rgba(239,68,68,.12);border-color:rgba(239,68,68,.3)}
.chip.gold{color:#fcd34d;background:rgba(255,176,31,.12);border-color:rgba(255,176,31,.35)}
.chip.blue{color:#7dd3fc;background:rgba(14,165,233,.12);border-color:rgba(14,165,233,.3)}
.chip.purple{color:#d8b4fe;background:rgba(168,85,247,.12);border-color:rgba(168,85,247,.3)}
.chip.pink{color:#f9a8d4;background:rgba(236,72,153,.12);border-color:rgba(236,72,153,.3)}

/* Table */
.table{width:100%;border-collapse:collapse}
.table th,.table td{text-align:left;padding:.7rem .8rem;border-bottom:1px solid var(--line);font-size:.85rem;vertical-align:middle}
.table th{color:var(--muted);font-weight:600;font-size:.72rem;text-transform:uppercase;letter-spacing:.04em;background:var(--panel2);position:sticky;top:0}
.table tr:hover td{background:var(--panel2)}
.table .actions{text-align:right;white-space:nowrap}

/* Tabs (page switching) */
.screen{display:none;animation:fade .25s ease}
.screen.active{display:block}
@keyframes fade{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}
.page-h{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem;gap:1rem;flex-wrap:wrap}
.page-h h1{margin:0;font-size:1.4rem;font-weight:700}
.page-h .sub{color:var(--muted);font-size:.85rem;margin-top:.2rem}

/* Inner tabs */
.tabs{display:flex;gap:.25rem;background:var(--panel2);padding:.25rem;border-radius:var(--radius-sm);width:fit-content;margin-bottom:1rem;flex-wrap:wrap}
.tab{padding:.45rem .9rem;border-radius:6px;font-size:.83rem;color:var(--muted);cursor:pointer}
.tab.active{background:var(--panel);color:var(--text);box-shadow:var(--shadow)}
.tab:hover{color:var(--text)}

/* Modals */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.65);display:none;align-items:center;justify-content:center;z-index:100;padding:1rem}
.modal-overlay.show{display:flex}
.modal{background:var(--panel);border:1px solid var(--line2);border-radius:var(--radius);max-width:720px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 24px 64px rgba(0,0,0,.5)}
.modal.wide{max-width:980px}
.modal-h{padding:1.1rem 1.25rem;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between}
.modal-h h2{margin:0;font-size:1.05rem}
.modal-b{padding:1.25rem}
.modal-f{padding:.9rem 1.25rem;border-top:1px solid var(--line);display:flex;justify-content:flex-end;gap:.5rem}
.close{font-size:1.4rem;color:var(--muted);cursor:pointer;line-height:1}

/* Stepper */
.stepper{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem;position:relative}
.stepper:before{content:'';position:absolute;top:18px;left:0;right:0;height:2px;background:var(--line2);z-index:0}
.step{position:relative;z-index:1;text-align:center;flex:1}
.step .b{width:36px;height:36px;border-radius:50%;background:var(--panel2);border:2px solid var(--line2);display:flex;align-items:center;justify-content:center;font-weight:700;margin:0 auto .35rem auto;font-size:.85rem}
.step.done .b{background:var(--accent2);border-color:var(--accent2);color:#fff}
.step.active .b{background:var(--accent);border-color:var(--accent);color:#1a1300}
.step .lbl{font-size:.74rem;color:var(--muted)}
.step.active .lbl{color:var(--text)}

/* Map mock */
.map-wrap{position:relative;background:linear-gradient(160deg,#0e2433 0%,#0a1a26 100%);border:1px solid var(--line);border-radius:var(--radius);height:420px;overflow:hidden}
.map-pin{position:absolute;width:14px;height:14px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 4px rgba(255,176,31,.25),0 0 12px rgba(255,176,31,.5);transform:translate(-50%,-50%);cursor:pointer}
.map-pin.green{background:var(--accent2);box-shadow:0 0 0 4px rgba(26,168,74,.25)}
.map-pin.red{background:var(--danger);box-shadow:0 0 0 4px rgba(239,68,68,.25)}
.map-pin.pulse{animation:pulse 2s infinite}
@keyframes pulse{0%,100%{transform:translate(-50%,-50%) scale(1)}50%{transform:translate(-50%,-50%) scale(1.4)}}
.map-label{position:absolute;background:rgba(0,0,0,.75);color:#fff;padding:2px 8px;border-radius:6px;font-size:.7rem;transform:translate(-50%,8px);pointer-events:none;white-space:nowrap}
.route{position:absolute;height:2px;background:linear-gradient(90deg,var(--accent2),var(--accent));transform-origin:left center;border-radius:2px}

/* Progress bar */
.progress{background:var(--panel2);border-radius:999px;height:8px;overflow:hidden}
.progress > div{height:100%;background:var(--grad-green);border-radius:999px}

/* Chat */
.chat-wrap{display:grid;grid-template-columns:280px 1fr;gap:0;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;height:620px}
@media(max-width:900px){.chat-wrap{grid-template-columns:1fr}}
.chat-list{border-right:1px solid var(--line);overflow-y:auto}
.chat-list .item{padding:.85rem 1rem;border-bottom:1px solid var(--line);cursor:pointer;display:flex;gap:.7rem;align-items:flex-start}
.chat-list .item:hover{background:var(--panel2)}
.chat-list .item.active{background:var(--panel2);border-left:3px solid var(--accent)}
.av{width:36px;height:36px;border-radius:50%;background:var(--grad-green);display:flex;align-items:center;justify-content:center;font-weight:700;color:#fff;font-size:.78rem;flex-shrink:0}
.av.gold{background:var(--grad-gold);color:#1a1300}
.av.purple{background:linear-gradient(135deg,#a855f7,#7c3aed)}
.av.pink{background:linear-gradient(135deg,#ec4899,#be185d)}
.av.blue{background:linear-gradient(135deg,#0ea5e9,#0369a1)}
.chat-thread{display:flex;flex-direction:column;min-height:0}
.thread-h{padding:.85rem 1.1rem;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:.7rem;background:var(--panel2)}
.thread-body{flex:1;overflow-y:auto;padding:1.1rem;display:flex;flex-direction:column;gap:.6rem}
.msg{max-width:75%;padding:.55rem .8rem;border-radius:14px;font-size:.85rem;line-height:1.4}
.msg.in{background:var(--panel2);align-self:flex-start;border-bottom-left-radius:4px}
.msg.out{background:var(--accent2);color:#fff;align-self:flex-end;border-bottom-right-radius:4px}
.msg .meta{font-size:.65rem;opacity:.7;margin-top:.2rem}
.thread-input{padding:.7rem;border-top:1px solid var(--line);display:flex;gap:.5rem;background:var(--panel2)}

/* Doc card */
.doc-card{background:var(--panel2);border:1px solid var(--line2);border-radius:var(--radius-sm);padding:.85rem;display:flex;align-items:flex-start;gap:.7rem;cursor:pointer;transition:all .15s ease}
.doc-card:hover{border-color:var(--accent);background:var(--panel)}
.doc-card:hover .doc-icon{transform:scale(1.05)}
.doc-icon{transition:transform .15s ease}
.doc-icon{width:42px;height:54px;background:var(--grad-gold);border-radius:6px;display:flex;align-items:center;justify-content:center;color:#1a1300;font-weight:800;font-size:.72rem;flex-shrink:0}
.doc-icon.green{background:var(--grad-green);color:#fff}
.doc-icon.red{background:linear-gradient(135deg,#ef4444,#b91c1c);color:#fff}

/* Toast */
.toast{position:fixed;bottom:1.5rem;right:1.5rem;background:var(--panel);border:1px solid var(--accent2);border-left:4px solid var(--accent2);padding:.85rem 1.1rem;border-radius:var(--radius);box-shadow:var(--shadow);z-index:200;font-size:.86rem;display:flex;align-items:center;gap:.7rem;opacity:0;transform:translateY(20px);transition:all .25s}
.toast.show{opacity:1;transform:translateY(0)}

/* Signature pad */
.sig-pad{background:#fff;border:2px dashed var(--line2);border-radius:var(--radius-sm);height:140px;display:flex;align-items:center;justify-content:center;color:#666;font-style:italic;cursor:crosshair;position:relative}
.sig-pad.signed{font-style:normal;color:#000;font-family:'Brush Script MT','Lucida Handwriting',cursive;font-size:2rem}

/* Checkoff */
.check-item{display:flex;align-items:center;gap:.7rem;padding:.65rem .85rem;background:var(--panel2);border:1px solid var(--line2);border-radius:var(--radius-sm);margin-bottom:.45rem;cursor:pointer}
.check-item.checked{background:rgba(34,197,94,.08);border-color:rgba(34,197,94,.3)}
.check-box{width:22px;height:22px;border:2px solid var(--line2);border-radius:5px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-weight:800;color:#fff;font-size:.85rem}
.check-item.checked .check-box{background:var(--accent2);border-color:var(--accent2)}

/* Pricing */
.tier{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:1.25rem;position:relative;cursor:pointer;transition:all .15s ease}
.tier:hover{border-color:var(--accent);transform:translateY(-3px);box-shadow:0 12px 28px rgba(255,176,31,.18)}
.tier.featured{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent),0 12px 32px rgba(255,176,31,.15)}
.tier .price{font-size:2rem;font-weight:800;margin:.4rem 0 .15rem 0}
.tier .price small{font-size:.85rem;font-weight:500;color:var(--muted)}
.tier ul{list-style:none;padding:0;margin:.9rem 0}
.tier li{padding:.35rem 0;font-size:.85rem;display:flex;gap:.5rem;align-items:flex-start}
.tier li:before{content:'✓';color:var(--accent2);font-weight:800;flex-shrink:0}

/* Sparkbar */
.sparkbar{display:flex;align-items:flex-end;gap:3px;height:48px}
.sparkbar span{flex:1;background:linear-gradient(180deg,var(--accent),rgba(255,176,31,.3));border-radius:2px;min-height:4px}

/* Misc */
.divider{height:1px;background:var(--line);margin:1rem 0}
.list-item{display:flex;align-items:center;gap:.8rem;padding:.65rem 0;border-bottom:1px solid var(--line)}
.list-item:last-child{border-bottom:none}
.flag{display:inline-block;width:18px;height:12px;background:linear-gradient(to bottom,#000 33%,#ffb01f 33% 66%,#1aa84a 66%);border-radius:2px;vertical-align:middle;margin-right:.3rem}
.notice{padding:.7rem .9rem;border-radius:var(--radius-sm);background:rgba(14,165,233,.1);border:1px solid rgba(14,165,233,.3);color:#7dd3fc;font-size:.85rem;display:flex;gap:.6rem;align-items:flex-start}
.notice.warn{background:rgba(245,158,11,.1);border-color:rgba(245,158,11,.3);color:#fbbf24}
.notice.ok{background:rgba(34,197,94,.1);border-color:rgba(34,197,94,.3);color:#86efac}
.notice.danger{background:rgba(239,68,68,.1);border-color:rgba(239,68,68,.3);color:#fca5a5}

/* Scrollbars */
::-webkit-scrollbar{width:8px;height:8px}
::-webkit-scrollbar-thumb{background:var(--line2);border-radius:4px}
::-webkit-scrollbar-thumb:hover{background:var(--muted)}

/* Pulse on bell */
.pulse-dot{animation:bellpulse 1.8s ease-in-out infinite}
@keyframes bellpulse{0%,100%{opacity:1}50%{opacity:.4}}

/* ============ VIDEO/MEETINGS ============ */
.video-wrap{background:#000;border-radius:var(--radius);overflow:hidden;position:relative;aspect-ratio:16/9;border:1px solid var(--line2)}
.video-self{position:absolute;right:14px;bottom:14px;width:160px;aspect-ratio:16/9;background:#1a1a2a;border:2px solid var(--bg2);border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;box-shadow:0 4px 16px rgba(0,0,0,.4)}
.video-main{width:100%;height:100%;background:radial-gradient(circle at 30% 30%, #1e3a5f 0%, #0a1a26 70%);display:flex;align-items:center;justify-content:center;color:#fff;position:relative}
.video-main .label{position:absolute;bottom:14px;left:14px;background:rgba(0,0,0,.6);color:#fff;padding:4px 10px;border-radius:8px;font-size:.78rem}
.call-controls{display:flex;justify-content:center;gap:.6rem;padding:.85rem;background:var(--panel2);border-top:1px solid var(--line)}
.call-btn{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--panel);border:1px solid var(--line2);color:var(--text)}
.call-btn:hover{border-color:var(--accent)}
.call-btn.end{background:var(--danger);border-color:var(--danger);color:#fff}
.call-btn.active{background:var(--accent2);border-color:var(--accent2);color:#fff}

/* Meeting tiles grid */
.tiles{display:grid;gap:8px;grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}
.tile{aspect-ratio:4/3;background:radial-gradient(circle at 50% 40%,#1e3a5f,#0a1a26);border-radius:10px;display:flex;align-items:flex-end;justify-content:flex-start;padding:.5rem;color:#fff;font-weight:600;font-size:.8rem;position:relative;border:1px solid var(--line2);cursor:pointer;transition:all .15s ease}
.tile:hover{border-color:var(--accent);transform:scale(1.02)}
.tile.speaker{box-shadow:0 0 0 2px var(--accent2)}
.tile .mic{position:absolute;top:8px;right:8px;width:22px;height:22px;border-radius:50%;background:rgba(0,0,0,.6);display:flex;align-items:center;justify-content:center;font-size:.6rem}
.tile .mic.muted{background:var(--danger)}

/* Inbox */
.inbox-wrap{display:grid;grid-template-columns:300px 1fr;gap:0;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;height:680px}
@media(max-width:900px){.inbox-wrap{grid-template-columns:1fr}}
.inbox-list{border-right:1px solid var(--line);overflow-y:auto}
.inbox-item{padding:.85rem 1rem;border-bottom:1px solid var(--line);cursor:pointer;display:flex;gap:.7rem;align-items:flex-start;position:relative}
.inbox-item:hover{background:var(--panel2)}
.inbox-item.unread{background:rgba(255,176,31,.05)}
.inbox-item.unread:before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--accent)}
.inbox-item.active{background:var(--panel2)}
.inbox-detail{padding:1.5rem;overflow-y:auto}
.notif-icon{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.95rem;flex-shrink:0}

/* Accounting */
.acct-row{display:flex;justify-content:space-between;padding:.4rem 0;border-bottom:1px dashed var(--line);font-size:.88rem}
.acct-row.total{border-top:2px solid var(--line2);border-bottom:none;font-weight:700;padding-top:.6rem;margin-top:.4rem}
.acct-row.subtotal{border-bottom:1px solid var(--line2);font-weight:600}
.acct-pos{color:#86efac}
.acct-neg{color:#fca5a5}

/* Misc helpers used by various screens */
.hl{background:linear-gradient(120deg,transparent 50%,rgba(255,176,31,.25) 50%);padding:0 2px}

/* Universal clickable affordance — set on any element that auto-wire makes clickable */
.clickable, .list-item.clickable, .card.clickable, .chip.clickable, [data-action]{cursor:pointer;transition:all .15s ease}
.card.clickable:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 8px 20px rgba(255,176,31,.12)}
.list-item.clickable:hover{background:var(--panel2);border-radius:6px;padding-left:.4rem;padding-right:.4rem}
.chip.clickable:hover{border-color:var(--accent);transform:scale(1.05)}
[data-action]:hover{filter:brightness(1.08)}

/* Inbox items get a hover affordance */
.inbox-item{transition:background .12s ease}
.inbox-item:hover{background:var(--panel2)}

/* ============ LANDING PAGE ============ */
/* When the landing screen is showing, hide the app chrome for a clean,
   full-bleed marketing view. Toggled by showScreen() in core.js. */
.app.landing-mode .sidebar,
.app.landing-mode .topbar{display:none}
.app.landing-mode .content{padding:0}

.landing{
  max-width:1080px;margin:0 auto;padding:0 1.5rem 3rem 1.5rem;
  min-height:100vh;
  background:
    radial-gradient(1100px 480px at 70% -10%, rgba(255,176,31,.10), transparent 60%),
    radial-gradient(900px 420px at 10% 0%, rgba(26,168,74,.10), transparent 55%);
}

/* Minimal top bar */
.lp-top{display:flex;align-items:center;justify-content:space-between;padding:1.4rem 0;gap:1rem;flex-wrap:wrap}
.lp-top-actions{display:flex;gap:.6rem;align-items:center}

/* Hero */
.lp-hero{text-align:center;padding:3.5rem 0 2.5rem 0;max-width:760px;margin:0 auto}
.lp-eyebrow{margin-bottom:1.4rem}
.lp-h1{font-size:3.1rem;line-height:1.08;font-weight:800;letter-spacing:-.02em;margin:0 0 1.1rem 0}
.lp-sub{font-size:1.12rem;line-height:1.6;color:var(--muted);margin:0 auto 2rem auto;max-width:600px}
.lp-cta{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap;margin-bottom:1.8rem}
.lp-cta-main{font-size:1rem;padding:.8rem 1.5rem}
.lp-cta-alt{font-size:1rem;padding:.8rem 1.5rem}
.lp-trust{display:flex;gap:.5rem;justify-content:center;flex-wrap:wrap}

/* Stats strip */
.lp-stats{display:grid;grid-template-columns:repeat(5,1fr);gap:1rem;
  background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);
  padding:1.5rem 1rem;margin:1rem 0 3.5rem 0;box-shadow:var(--shadow)}
.lp-stat{text-align:center}
.lp-stat-v{font-size:1.7rem;font-weight:800;color:var(--accent)}
.lp-stat-l{font-size:.78rem;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;margin-top:.25rem}

/* Generic section */
.lp-section{margin-bottom:3.5rem}
.lp-section-h{text-align:center;margin-bottom:1.8rem}
.lp-section-h h2{font-size:1.8rem;font-weight:800;margin:0 0 .5rem 0;letter-spacing:-.01em}
.lp-section-h p{margin:0;font-size:1rem}

/* Role cards */
.lp-roles{gap:1rem}
.lp-role{cursor:pointer;transition:all .15s ease;display:flex;flex-direction:column;gap:.55rem;align-items:flex-start}
.lp-role:hover{border-color:var(--accent);transform:translateY(-3px);box-shadow:0 12px 28px rgba(255,176,31,.15)}
.lp-role .av{width:42px;height:42px}
.lp-role .bold{font-size:1.05rem}
.lp-role-go{color:var(--accent);font-size:.82rem;font-weight:600;margin-top:.2rem}

/* Top menu bar */
.lp-nav{display:flex;gap:.15rem;align-items:center;flex-wrap:wrap;justify-content:center}
.lp-navlink{background:none;border:0;color:var(--text);font:inherit;font-size:.9rem;font-weight:600;
  padding:.45rem .75rem;border-radius:8px;cursor:pointer;transition:background .15s ease,color .15s ease}
.lp-navlink:hover{background:var(--panel);color:var(--accent)}

/* "I am a …" role chooser (Broker · Carrier · Shipper) */
.lp-iam{gap:1rem}
.lp-iam-card{display:flex;flex-direction:column;align-items:flex-start;gap:.65rem;text-align:left;padding:1.5rem;
  transition:border-color .15s ease,transform .15s ease,box-shadow .15s ease}
.lp-iam-card:hover{border-color:var(--accent);transform:translateY(-3px);box-shadow:0 12px 28px rgba(255,176,31,.15)}
.lp-iam-eyebrow{text-transform:uppercase;letter-spacing:.08em;font-size:.72rem;font-weight:700}
.lp-iam-role{font-size:1.8rem;font-weight:800;line-height:1;letter-spacing:-.01em}
.lp-iam-more{margin:.15rem 0}
.lp-iam-card p{margin:.1rem 0 0 0;font-size:.92rem;line-height:1.55}

/* Feature cards */
.lp-feat{text-align:left;display:flex;flex-direction:column;gap:.5rem}
.lp-feat-ico{font-size:1.8rem}
.lp-feat .bold{font-size:1.05rem}

/* Final CTA */
.lp-final{text-align:center;background:var(--grad-dark);border:1px solid var(--line2);
  border-radius:var(--radius);padding:3rem 1.5rem;margin-bottom:2.5rem}
.lp-final h2{font-size:2rem;font-weight:800;margin:0 0 .6rem 0}
.lp-final p{margin:0 0 1.5rem 0;font-size:1.02rem}

/* Footer */
.lp-foot{display:flex;align-items:center;justify-content:center;gap:.6rem;padding-top:1rem;border-top:1px solid var(--line)}

@media(max-width:900px){
  .lp-h1{font-size:2.3rem}
  .lp-stats{grid-template-columns:repeat(2,1fr);gap:1.25rem}
}
@media(max-width:700px){
  .lp-h1{font-size:1.9rem}
  .lp-sub{font-size:1rem}
}

/* ============ ACCESSIBILITY ============ */
/* Screen-reader-only text */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
/* Skip link */
.skip-link{position:absolute;left:-999px;top:0;z-index:300;background:var(--accent);color:#1a1300;padding:.6rem 1rem;border-radius:0 0 var(--radius-sm) 0;font-weight:700}
.skip-link:focus{left:0}
/* Visible keyboard focus everywhere */
:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:4px}
/* Nav items + brand are now <button> — reset to match prior look */
.brand{width:100%;text-align:left;background:none;border:0;font:inherit}
.nav-item{width:100%;text-align:left;font:inherit}
.role-switcher{text-align:left}
.close{background:none;border:0;padding:0 .25rem}
@media(prefers-reduced-motion:reduce){*{animation-duration:.01ms!important;transition-duration:.01ms!important}}

/* ============ MOBILE NAV (drawer) ============ */
.hamburger{display:none}
.nav-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:40;border:0}
@media(max-width:900px){
  .hamburger{display:inline-flex}
  .sidebar{position:fixed;top:0;left:0;z-index:50;height:100dvh;transform:translateX(-100%);transition:transform .22s ease;box-shadow:0 0 40px rgba(0,0,0,.5)}
  .app.nav-open .sidebar{transform:translateX(0)}
  /* topbar stays sticky; content is full width since sidebar is now overlaid */
  .content{padding:1rem}
}
/* Keep the drawer hidden/irrelevant on the landing screen */
.app.landing-mode .hamburger,
.app.landing-mode .nav-backdrop{display:none!important}

/* Declutter the topbar on phones: drop secondary controls, trim the role chip. */
@media(max-width:700px){
  .topbar{gap:.6rem;padding:0 .8rem}
  .role-switcher{padding:.35rem;gap:0}
  .role-switcher > div:not(.role-avatar),
  .role-switcher > svg{display:none}
  .topbar .iconbtn[title="Quick call"],
  .topbar .iconbtn[title="Help"]{display:none}
  #postLoadBtn{padding:.5rem .7rem;font-size:.8rem}
  #postLoadBtn svg{display:none}
}

/* ============ RESPONSIVE TABLES ============ */
.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:0 -.25rem}
.table-wrap > .table{min-width:560px}

/* ============ GLOBAL SEARCH ============ */
.search{position:relative}
.search-results{position:absolute;top:calc(100% + 6px);left:0;right:0;background:var(--panel);border:1px solid var(--line2);border-radius:var(--radius-sm);box-shadow:var(--shadow);max-height:340px;overflow-y:auto;z-index:30;padding:.35rem}
.search-results .sr-item{display:flex;align-items:center;gap:.6rem;padding:.5rem .6rem;border-radius:6px;cursor:pointer;width:100%;text-align:left;background:none;border:0;font:inherit;color:var(--text)}
.search-results .sr-item:hover,.search-results .sr-item[aria-selected="true"]{background:var(--panel2)}
.search-results .sr-empty{padding:.7rem .6rem;color:var(--muted);font-size:.85rem}
.search-results .sr-cat{font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);padding:.4rem .6rem .2rem}

/* Tabs: indicate keyboard focus + selected state for assistive tech */
.tab[aria-selected="true"]{background:var(--panel);color:var(--text);box-shadow:var(--shadow)}
