/* ─── RESET & TOKENS ─────────────────────────────────────────────────────── */
*{box-sizing:border-box;margin:0;padding:0}
:root{
  --navy:#0b1e3d;--navy2:#122545;--navy3:#1a3158;
  --accent:#2563eb;--accent-light:#eef5ff;--accent-mid:#bfdbfe;--accent-dark:#1d4ed8;
  --teal:#0f766e;--teal-light:#f0fdfa;
  --amber:#b45309;--amber-light:#fffbeb;
  --red:#b91c1c;--red-light:#fef2f2;
  --green:#15803d;--green-light:#f0fdf4;
  --border:#e9ebf0;--border2:#dcdfe6;
  --bg:#f6f8fb;--surface:#fff;--surface2:#f3f5f9;
  --text:#0f172a;--text2:#475569;--text3:#8b94a3;
  --font:'DM Sans',sans-serif;--mono:'DM Mono',monospace;
  --r:8px;--r2:12px;--r3:16px;--sidebar:240px;--topbar:58px;
  --shadow-sm:0 1px 2px rgba(15,23,42,.04),0 1px 3px rgba(15,23,42,.045);
  --shadow:0 1px 3px rgba(15,23,42,.06),0 6px 16px rgba(15,23,42,.05);
  --shadow-md:0 4px 16px rgba(15,23,42,.08),0 2px 6px rgba(15,23,42,.04);
  --shadow-lg:0 24px 60px rgba(15,23,42,.20),0 8px 22px rgba(15,23,42,.12);
}
body{font-family:var(--font);font-size:14px;color:var(--text);background:var(--bg);line-height:1.5;
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}
/* Tabular figures everywhere numbers matter — columns line up to the digit. */
.stat-val,td,th,.badge,.bank-bar-amount,.fx-pill,input[type=number],.assumption-input,.mono{font-variant-numeric:tabular-nums}
a{color:inherit;text-decoration:none}
button{font-family:var(--font);cursor:pointer}
input,select,textarea{font-family:var(--font)}

/* ─── LAYOUT ─────────────────────────────────────────────────────────────── */
.shell{display:flex;height:100vh;overflow:hidden}
.sidebar{width:var(--sidebar);background:linear-gradient(180deg,#0b1e3d 0%,#0a1a35 100%);display:flex;flex-direction:column;flex-shrink:0;overflow-y:auto;border-right:1px solid rgba(0,0,0,.2)}
.sidebar-brand{padding:18px 16px 14px;border-bottom:1px solid rgba(255,255,255,.08)}
.brand-logo{font-size:16px;font-weight:700;color:#fff;letter-spacing:-.3px;display:flex;align-items:center;gap:8px}
.brand-sub{font-size:11px;color:rgba(255,255,255,.4);margin-top:3px}
.sidebar-role{padding:10px 16px;margin:8px 12px;border-radius:var(--r);font-size:11px;font-weight:500;cursor:pointer;transition:.15s}
.role-rec{background:rgba(37,99,235,.25);color:#93c5fd;border:1px solid rgba(37,99,235,.3)}
.role-cfo{background:rgba(15,118,110,.25);color:#5eead4;border:1px solid rgba(15,118,110,.3)}
.role-rec.active,.role-cfo.active{opacity:1}
.role-rec:not(.active),.role-cfo:not(.active){opacity:.45}
.sidebar-section{padding:10px 14px 5px;font-size:10px;font-weight:600;color:rgba(255,255,255,.32);text-transform:uppercase;letter-spacing:.1em;margin-top:8px}
.nav-item{display:flex;align-items:center;gap:10px;padding:8px 12px;margin:1px 8px;border-radius:var(--r);font-size:13px;font-weight:500;color:rgba(255,255,255,.6);cursor:pointer;transition:.13s;border:none;background:none;width:calc(100% - 16px);text-align:left;position:relative}
.nav-item:hover{background:rgba(255,255,255,.07);color:#fff}
.nav-item.active{background:rgba(37,99,235,.22);color:#fff;font-weight:600}
.nav-item.active::before{content:"";position:absolute;left:-8px;top:50%;transform:translateY(-50%);width:3px;height:18px;border-radius:0 3px 3px 0;background:#60a5fa}
.nav-item.active i{color:#93c5fd}
.nav-item i{font-size:16px;width:18px;flex-shrink:0;transition:.13s}
.nav-badge{margin-left:auto;background:rgba(239,68,68,.9);color:#fff;font-size:10px;font-weight:600;padding:1px 7px;border-radius:10px;min-width:18px;text-align:center}

/* ── Collapsible nav groups ────────────────────────────────── */
.nav-group{margin-top:4px}
.nav-group-header{display:flex;align-items:center;gap:9px;padding:7px 14px;width:100%;border:none;background:none;color:rgba(255,255,255,.4);font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;cursor:pointer;transition:.15s;user-select:none}
.nav-group-header:hover{color:rgba(255,255,255,.7)}
.nav-group-header .nav-group-icon{font-size:13px;width:16px;flex-shrink:0;opacity:.6}
.nav-group-header .nav-group-label{flex:1;text-align:left}
.nav-group-header .nav-group-arrow{font-size:12px;margin-left:auto;transition:transform .25s ease;opacity:.5}
.nav-group.collapsed .nav-group-arrow{transform:rotate(-90deg)}
.nav-group-items{overflow:hidden;transition:max-height .28s cubic-bezier(.4,0,.2,1),opacity .22s ease;max-height:600px;opacity:1}
.nav-group.collapsed .nav-group-items{max-height:0;opacity:0}
.nav-group-items .nav-item{padding:7px 12px 7px 22px;font-size:12.5px}
.nav-group.has-active>.nav-group-header{color:rgba(255,255,255,.65)}
.nav-group.has-active>.nav-group-header .nav-group-icon{opacity:1;color:#93c5fd}
.nav-group-count{margin-left:auto;background:rgba(255,255,255,.1);color:rgba(255,255,255,.5);font-size:9px;padding:1px 6px;border-radius:8px;font-weight:600;margin-right:4px}
.nav-group+.nav-group{margin-top:2px}

/* ── Intelligence page premium styles ──────────────────────── */
@keyframes fadeSlideUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
@keyframes scaleIn{from{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}
@keyframes pulseGlow{0%,100%{box-shadow:0 0 0 0 rgba(37,99,235,.15)}50%{box-shadow:0 0 24px 4px rgba(37,99,235,.12)}}
@keyframes countUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
@keyframes gaugeStroke{from{stroke-dashoffset:283}to{stroke-dashoffset:var(--gauge-offset,0)}}
@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}

.intel-page{animation:fadeSlideUp .4s ease-out both}
.intel-hero{animation:scaleIn .35s ease-out both;animation-delay:.1s}
.intel-card{animation:fadeSlideUp .35s ease-out both;border-radius:12px;border:1px solid var(--border);background:var(--surface);overflow:hidden;transition:box-shadow .2s,transform .15s}
.intel-card:hover{box-shadow:0 8px 32px rgba(0,0,0,.08);transform:translateY(-1px)}
.intel-card:nth-child(1){animation-delay:.05s}
.intel-card:nth-child(2){animation-delay:.1s}
.intel-card:nth-child(3){animation-delay:.15s}
.intel-card:nth-child(4){animation-delay:.2s}

/* Health score gauge */
.health-gauge-wrap{position:relative;width:180px;height:180px;margin:0 auto}
.health-gauge-svg{width:100%;height:100%;transform:rotate(-90deg)}
.health-gauge-bg{fill:none;stroke:var(--border);stroke-width:10}
.health-gauge-fill{fill:none;stroke-width:10;stroke-linecap:round;animation:gaugeStroke 1.2s cubic-bezier(.4,0,.2,1) forwards}
.health-gauge-score{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}
.health-gauge-num{font-size:44px;font-weight:800;letter-spacing:-2px;line-height:1}
.health-gauge-rating{font-size:14px;font-weight:700;margin-top:4px;text-transform:uppercase;letter-spacing:.5px}

/* Severity stat cards */
.severity-card{border-radius:10px;padding:16px 20px;text-align:center;color:#fff;position:relative;overflow:hidden;min-width:120px;flex:1}
.severity-card::before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.12),transparent);pointer-events:none}
.severity-card .sev-num{font-size:28px;font-weight:800;line-height:1.1}
.severity-card .sev-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;opacity:.85;margin-top:4px}
.sev-total{background:linear-gradient(135deg,#1e3a5f,#2563eb)}
.sev-critical{background:linear-gradient(135deg,#991b1b,#dc2626)}
.sev-high{background:linear-gradient(135deg,#9a3412,#ea580c)}
.sev-medium{background:linear-gradient(135deg,#92400e,#d97706)}
.sev-low{background:linear-gradient(135deg,#1e40af,#3b82f6)}

/* Recommendation cards enhanced */
.rec-card{border-radius:10px;border:1px solid var(--border);background:var(--surface);padding:16px 20px;margin-bottom:10px;position:relative;overflow:hidden;animation:fadeSlideUp .3s ease-out both;transition:box-shadow .2s,transform .15s}
.rec-card:hover{box-shadow:0 4px 20px rgba(0,0,0,.06);transform:translateY(-1px)}
.rec-card::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px}
.rec-card.urgency-critical::before{background:linear-gradient(180deg,#ef4444,#dc2626)}
.rec-card.urgency-high::before{background:linear-gradient(180deg,#f97316,#ea580c)}
.rec-card.urgency-medium::before{background:linear-gradient(180deg,#f59e0b,#d97706)}
.rec-card.urgency-low::before{background:linear-gradient(180deg,#60a5fa,#3b82f6)}
.rec-card:nth-child(1){animation-delay:.05s}
.rec-card:nth-child(2){animation-delay:.1s}
.rec-card:nth-child(3){animation-delay:.15s}
.rec-card:nth-child(4){animation-delay:.2s}
.rec-card:nth-child(5){animation-delay:.25s}

/* Component score bars */
.comp-score-bar{height:6px;border-radius:3px;background:var(--bg2);overflow:hidden;flex:1;max-width:120px}
.comp-score-fill{height:100%;border-radius:3px;transition:width .8s cubic-bezier(.4,0,.2,1)}

/* Briefing metric rows */
.briefing-metric{display:flex;align-items:center;gap:12px;padding:12px 16px;border-bottom:1px solid var(--border);animation:fadeSlideUp .25s ease-out both;transition:background .15s}
.briefing-metric:hover{background:rgba(37,99,235,.03)}
.briefing-metric:nth-child(1){animation-delay:.05s}
.briefing-metric:nth-child(2){animation-delay:.08s}
.briefing-metric:nth-child(3){animation-delay:.11s}
.briefing-metric:nth-child(4){animation-delay:.14s}
.briefing-metric:nth-child(5){animation-delay:.17s}
.briefing-metric .metric-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.briefing-metric .metric-name{flex:1;font-size:13px;font-weight:500}
.briefing-metric .metric-val{font-size:13px;font-weight:700;font-family:var(--mono)}

/* Intel page header bar */
.intel-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}
.intel-title{font-size:20px;font-weight:800;letter-spacing:-.5px;display:flex;align-items:center;gap:10px}
.intel-title i{font-size:22px;color:var(--accent)}
.intel-actions{display:flex;gap:8px}

/* ─── Copilot premium ─────────────────────────────────────────────────── */
.copilot-shell{display:flex;flex-direction:column;height:calc(100vh - 170px);min-height:440px;padding:0;overflow:hidden}
.copilot-header-strip{display:flex;align-items:center;justify-content:space-between;padding:10px 18px;background:linear-gradient(135deg,rgba(37,99,235,.06),rgba(99,102,241,.04));border-bottom:1px solid var(--border);flex-shrink:0;gap:12px;flex-wrap:wrap}
.copilot-status{display:flex;align-items:center;gap:8px;font-size:12px;font-weight:600;color:var(--accent)}
.copilot-pulse{width:8px;height:8px;border-radius:50%;background:#16a34a;box-shadow:0 0 0 0 rgba(22,163,74,.5);animation:livePulse 2s ease-in-out infinite}
@keyframes livePulse{0%,100%{box-shadow:0 0 0 0 rgba(22,163,74,.45)}50%{box-shadow:0 0 0 6px rgba(22,163,74,0)}}
.copilot-badge{font-size:10.5px;color:var(--text3);display:flex;align-items:center;gap:5px}
.copilot-badge i{font-size:12px;color:var(--green,#16a34a)}
.copilot-thread{flex:1;overflow-y:auto;padding:16px 18px;scroll-behavior:smooth}
.copilot-input-area{border-top:1px solid var(--border);padding:12px 18px;flex-shrink:0;background:var(--surface)}
.copilot-suggestions{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:10px}
.copilot-suggestions .btn{font-size:11px;padding:4px 10px;border-radius:20px;transition:background .15s,transform .1s}
.copilot-suggestions .btn:hover{transform:translateY(-1px)}
.copilot-input-row{display:flex;gap:8px}
.copilot-input-row input{flex:1;border-radius:10px;padding:10px 14px;font-size:13px;border:1.5px solid var(--border2);transition:border-color .2s,box-shadow .2s}
.copilot-input-row input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(37,99,235,.1);outline:none}
.copilot-send-btn{border-radius:10px!important;padding:10px 16px!important}

/* ─── Narrative premium ───────────────────────────────────────────────── */
.narrative-config-head{padding:16px 22px;border-bottom:1px solid var(--border);background:linear-gradient(135deg,rgba(37,99,235,.04),transparent)}
.narrative-config-hint{display:flex;align-items:flex-start;gap:6px;font-size:11px;color:var(--text3);margin-top:10px;line-height:1.5;padding:8px 12px;background:var(--bg);border-radius:var(--r);border:1px dashed var(--border)}
.narrative-config-hint i{font-size:14px;color:var(--accent);flex-shrink:0;margin-top:1px}

.main{flex:1;display:flex;flex-direction:column;overflow:hidden}
.topbar{height:var(--topbar);background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 20px;flex-shrink:0;z-index:10}
.topbar-left{display:flex;align-items:center;gap:12px;min-width:0;flex:1}
.page-title{font-size:17px;font-weight:700;letter-spacing:-.3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.topbar-right{display:flex;align-items:center;gap:8px;flex-shrink:0}

/* Page toolbar — contextual controls below the topbar */
.page-toolbar{display:flex;align-items:center;justify-content:space-between;padding:8px 20px;background:var(--surface2);border-bottom:1px solid var(--border);flex-shrink:0;gap:12px;min-height:44px}
.page-toolbar.hidden{display:none}
.page-toolbar-left{display:flex;align-items:center;gap:12px;min-width:0;flex:1}
.page-toolbar-right{display:flex;align-items:center;gap:8px;flex-shrink:0}

/* min-width:0 lets the flex content shrink to the viewport so wide tables scroll
   inside their .tbl-wrap instead of spilling off-screen (the whole-view overflow). */
.content{flex:1;min-width:0;overflow-y:auto;padding:24px}
.page{display:none}
.page.active{display:block}

/* ─── STAT CARDS ─────────────────────────────────────────────────────────── */
.stat-grid{display:grid;gap:14px;margin-bottom:20px}
/* Dynamic stat grids (variable card count) flow responsively into columns */
#cash-ccy-summary{grid-template-columns:repeat(auto-fill,minmax(210px,1fr))}
.cols-4{grid-template-columns:repeat(4,1fr)}
.cols-3{grid-template-columns:repeat(3,1fr)}
.cols-2{grid-template-columns:repeat(2,1fr)}
.stat{background:var(--surface);border:1px solid var(--border);border-radius:var(--r2);padding:18px;box-shadow:var(--shadow-sm);transition:box-shadow .18s,transform .18s}
.stat:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}
.stat-label{font-size:11px;color:var(--text3);font-weight:600;text-transform:uppercase;letter-spacing:.06em;margin-bottom:9px}
.stat-val{font-size:24px;font-weight:600;letter-spacing:-.7px;line-height:1.1}
.stat-sub{font-size:11.5px;color:var(--text3);margin-top:6px;display:flex;align-items:center;gap:4px}
.up{color:var(--green)}.down{color:var(--red)}

/* ─── CARDS ──────────────────────────────────────────────────────────────── */
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r2);overflow:hidden;margin-bottom:16px;box-shadow:var(--shadow-sm)}
.card-head{padding:14px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:10px}
.card-title{font-size:13px;font-weight:600;display:flex;align-items:center;gap:8px;letter-spacing:-.1px}
.card-title i{color:var(--accent);font-size:16px}
.card-body{padding:18px}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}

/* Grid/flex children default to min-width:auto and refuse to shrink below their
   content — pin them to 0 so a wide card never blows the layout past the screen. */
.stat-grid>*,.grid-2>*,.grid-3>*,.card{min-width:0}

/* ─── TABLES ─────────────────────────────────────────────────────────────── */
.tbl-wrap{overflow-x:auto;max-width:100%}
table{width:100%;border-collapse:collapse;font-size:12.5px}
th{padding:10px 14px;text-align:left;font-size:10.5px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--border);white-space:nowrap;background:var(--surface)}
td{padding:11px 14px;border-bottom:1px solid var(--border);color:var(--text);vertical-align:middle}
th:first-child,td:first-child{padding-left:18px}
th:last-child,td:last-child{padding-right:18px}
tr:last-child td{border-bottom:none}
tbody tr{transition:background .1s}
tbody tr:hover td{background:var(--accent-light)}
.tr-total td{font-weight:600;background:var(--surface2);border-top:1.5px solid var(--border2)}
.tr-subtotal td{font-weight:600;color:var(--text2)}

/* ─── BADGES ─────────────────────────────────────────────────────────────── */
.badge{display:inline-flex;align-items:center;gap:4px;font-size:10.5px;font-weight:600;padding:3px 9px;border-radius:6px;white-space:nowrap;letter-spacing:.01em;line-height:1.4}
.b-green{background:var(--green-light);color:var(--green)}
.b-red{background:var(--red-light);color:var(--red)}
.b-amber{background:var(--amber-light);color:var(--amber)}
.b-blue{background:var(--accent-light);color:var(--accent)}
.b-teal{background:var(--teal-light);color:var(--teal)}
.b-gray{background:var(--surface2);color:var(--text2)}

/* ─── BUTTONS ────────────────────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:7px 14px;border-radius:var(--r);font-size:12.5px;font-weight:600;border:1px solid var(--border2);background:var(--surface);color:var(--text);cursor:pointer;transition:.13s;white-space:nowrap;box-shadow:var(--shadow-sm)}
.btn:hover{background:var(--surface2);border-color:#cdd2db}
.btn:active{transform:translateY(.5px)}
.btn:focus-visible{outline:none;box-shadow:0 0 0 3px rgba(37,99,235,.25)}
.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent);box-shadow:0 1px 2px rgba(37,99,235,.28)}
.btn-primary:hover{background:var(--accent-dark);border-color:var(--accent-dark)}
.btn-sm{padding:5px 11px;font-size:12px}
.btn-group{display:flex;gap:8px;flex-wrap:wrap}

/* ─── FORMS ──────────────────────────────────────────────────────────────── */
.form-row{display:grid;gap:12px;margin-bottom:12px}
.form-group{display:flex;flex-direction:column;gap:4px}
label{font-size:12px;font-weight:600;color:var(--text2)}
input[type=text],input[type=number],input[type=date],input[type=email],input[type=password],input[type=search],select,textarea{
  padding:8px 11px;border:1px solid var(--border2);border-radius:var(--r);font-size:13px;
  color:var(--text);background:var(--surface);width:100%;transition:.13s
}
input::placeholder,textarea::placeholder{color:var(--text3)}
input:hover,select:hover,textarea:hover{border-color:#cdd2db}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(37,99,235,.12)}

/* ─── UPLOAD ZONE ────────────────────────────────────────────────────────── */
.upload-zone{border:1.5px dashed var(--border2);border-radius:var(--r2);padding:28px;text-align:center;cursor:pointer;transition:.2s;background:var(--bg)}
.upload-zone:hover,.upload-zone.drag{border-color:var(--accent);background:var(--accent-light)}
.upload-zone i{font-size:28px;color:var(--text3);display:block;margin-bottom:8px}

/* ─── PROGRESS ───────────────────────────────────────────────────────────── */
.progress{height:6px;background:var(--surface2);border-radius:3px;overflow:hidden}
.progress-fill{height:100%;border-radius:3px;transition:width .4s}

/* ─── STATUS DOTS ────────────────────────────────────────────────────────── */
.dot{width:8px;height:8px;border-radius:50%;display:inline-block;flex-shrink:0}
.dot-green{background:var(--green)}.dot-red{background:var(--red)}.dot-amber{background:var(--amber)}

/* ─── REC STATEMENT ──────────────────────────────────────────────────────── */
.rec-side{border:1px solid var(--border);border-radius:var(--r2);overflow:hidden}
.rec-side-head{padding:10px 14px;background:var(--surface2);border-bottom:1px solid var(--border);font-size:12px;font-weight:500}
.rec-row{display:flex;justify-content:space-between;padding:8px 14px;border-bottom:1px solid var(--border);font-size:13px}
.rec-row:last-child{border-bottom:none}
.rec-row.total{font-weight:500;background:var(--surface2)}
.rec-row.positive span:last-child{color:var(--green)}
.rec-row.negative span:last-child{color:var(--red)}

/* ─── FX ─────────────────────────────────────────────────────────────────── */
.fx-pill{font-size:11px;padding:2px 7px;border-radius:4px;font-family:var(--mono);font-weight:500}

/* ─── CHARTS ─────────────────────────────────────────────────────────────── */
.chart-wrap{position:relative;width:100%}

/* ─── BANK BARS ──────────────────────────────────────────────────────────── */
.bank-bar{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--border)}
.bank-bar:last-child{border-bottom:none}
.bank-bar-name{font-size:12.5px;font-weight:500;min-width:140px}
.bank-bar-fill-wrap{flex:1;height:8px;background:var(--surface2);border-radius:4px;overflow:hidden}
.bank-bar-fill{height:100%;border-radius:4px;background:var(--accent);transition:width .5s}
.bank-bar-amount{font-size:12px;font-family:var(--mono);min-width:110px;text-align:right}
.bank-bar-currency{font-size:11px;color:var(--text3);min-width:36px}

/* ─── ROLE CARDS (User Management) ───────────────────────────────────────── */
.role-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:18px}
.role-card{display:flex;align-items:center;gap:10px;padding:12px 14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r2);box-shadow:var(--shadow-sm)}
.role-card-icon{width:34px;height:34px;border-radius:var(--r);display:flex;align-items:center;justify-content:center;font-size:17px;flex-shrink:0}
.role-card strong{display:block;font-size:12.5px;font-weight:600;color:var(--text);line-height:1.3}
.role-card span{display:block;font-size:11px;color:var(--text3);line-height:1.3;margin-top:1px}
@media (max-width:900px){.role-cards{grid-template-columns:repeat(2,1fr)}}
@media (max-width:500px){.role-cards{grid-template-columns:1fr}}

/* ─── ALERTS ─────────────────────────────────────────────────────────────── */
.alert{padding:11px 14px;border-radius:var(--r2);font-size:12.5px;line-height:1.5;margin-bottom:12px;display:flex;align-items:flex-start;gap:9px;border:1px solid transparent}
.alert i{font-size:16px;flex-shrink:0;margin-top:1px}
.alert-info{background:var(--accent-light);color:#1e40af;border-color:#dbe6fe}
.alert-success{background:var(--green-light);color:var(--green);border-color:#c7eed1}
.alert-warn{background:var(--amber-light);color:#92400e;border-color:#fde9c8}
.alert-error{background:var(--red-light);color:var(--red);border-color:#fecaca}

/* ─── FORECAST ASSUMPTIONS ───────────────────────────────────────────────── */
.assumption-row{display:grid;grid-template-columns:1fr auto auto;gap:8px;align-items:center;margin-bottom:8px}
.assumption-label{font-size:12.5px}
.assumption-input{width:80px;text-align:right;font-family:var(--mono)}

/* ─── SECTION HEADERS ────────────────────────────────────────────────────── */
.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;gap:12px;flex-wrap:wrap}
.section-title{font-size:18px;font-weight:700;letter-spacing:-.3px;color:var(--text)}

/* ─── SCROLLBAR ──────────────────────────────────────────────────────────── */
::-webkit-scrollbar{width:8px;height:8px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:#cbd2dc;border-radius:4px;border:2px solid transparent;background-clip:padding-box}
::-webkit-scrollbar-thumb:hover{background:#aeb6c2;background-clip:padding-box}
.sidebar::-webkit-scrollbar-thumb{background:rgba(255,255,255,.14);background-clip:padding-box}

/* ─── PERIOD TABS ────────────────────────────────────────────────────────── */

/* ─── REC TYPE TABS ──────────────────────────────────────────────────────── */
.rec-type-tabs{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}
.rec-type-tab{padding:6px 14px;border-radius:8px;font-size:12.5px;font-weight:600;cursor:pointer;border:1px solid var(--border2);background:var(--surface);color:var(--text2);transition:.13s;box-shadow:var(--shadow-sm)}
.rec-type-tab:hover{border-color:#cdd2db;color:var(--text)}
.rec-type-tab.active{background:var(--navy);color:#fff;border-color:var(--navy);box-shadow:0 1px 2px rgba(11,30,61,.25)}

/* ─── MODAL ──────────────────────────────────────────────────────────────── */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(11,30,61,.5);backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);z-index:100;align-items:center;justify-content:center;padding:20px}
.modal-overlay.open{display:flex;animation:overlayIn .18s ease}
.modal{background:var(--surface);border-radius:var(--r3);padding:26px;width:480px;max-width:95vw;border:1px solid var(--border);box-shadow:var(--shadow-lg);animation:modalIn .22s cubic-bezier(.2,.8,.2,1)}
.modal-title{font-size:16px;font-weight:600;margin-bottom:18px;display:flex;align-items:center;justify-content:space-between;letter-spacing:-.2px}
@keyframes overlayIn{from{opacity:0}to{opacity:1}}
@keyframes modalIn{from{opacity:0;transform:translateY(10px) scale(.985)}to{opacity:1;transform:none}}

/* ─── TOAST ──────────────────────────────────────────────────────────────── */
.toast{position:fixed;bottom:24px;right:24px;background:var(--navy);color:#fff;padding:11px 18px;border-radius:10px;font-size:13px;font-weight:500;z-index:200;opacity:0;transform:translateY(8px);transition:.25s;pointer-events:none;box-shadow:var(--shadow-lg)}
.toast.show{opacity:1;transform:none}

/* ─── EMPTY STATE ────────────────────────────────────────────────────────── */
.empty{text-align:center;padding:40px 20px;color:var(--text3)}
.empty i{font-size:36px;display:block;margin-bottom:10px;opacity:.5}

/* ─── DIVIDER ────────────────────────────────────────────────────────────── */
.divider{height:1px;background:var(--border);margin:16px 0}

/* ─── HELP / KNOWLEDGE BASE ──────────────────────────────────────────────── */
.help-quickstart{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px;margin-bottom:22px}
.help-qs-card{display:flex;flex-direction:column;align-items:center;gap:10px;padding:18px 12px;border-radius:12px;border:1px solid var(--border);background:var(--surface);cursor:pointer;transition:box-shadow .2s,transform .15s;animation:fadeSlideUp .3s ease-out both}
.help-qs-card:hover{box-shadow:0 8px 28px rgba(0,0,0,.08);transform:translateY(-2px)}
.help-qs-card:nth-child(1){animation-delay:.03s}.help-qs-card:nth-child(2){animation-delay:.06s}.help-qs-card:nth-child(3){animation-delay:.09s}.help-qs-card:nth-child(4){animation-delay:.12s}.help-qs-card:nth-child(5){animation-delay:.15s}.help-qs-card:nth-child(6){animation-delay:.18s}
.help-qs-icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:20px}
.help-qs-label{font-size:12.5px;font-weight:600;text-align:center;color:var(--text)}
.help-search-wrap{position:relative;margin-bottom:18px;max-width:520px}
.help-search-wrap i{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--text3);font-size:17px}
.help-search-wrap input{padding-left:38px;height:44px;font-size:13.5px;border-radius:10px;border:1.5px solid var(--border2);transition:border-color .2s,box-shadow .2s}
.help-search-wrap input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(37,99,235,.1);outline:none}
.help-cat{font-size:11px;font-weight:700;color:var(--accent);text-transform:uppercase;letter-spacing:.1em;margin:26px 0 10px;display:flex;align-items:center;gap:8px}
.help-cat::after{content:"";flex:1;height:1px;background:var(--border)}
.help-cat:first-child{margin-top:0}
.help-item{border:1px solid var(--border);border-radius:10px;background:var(--surface);box-shadow:var(--shadow-sm);margin-bottom:8px;overflow:hidden;transition:box-shadow .15s}
.help-item:hover{box-shadow:0 4px 16px rgba(0,0,0,.05)}
.help-q{width:100%;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 18px;background:none;border:none;text-align:left;cursor:pointer;font-family:var(--font);transition:background .12s}
.help-q:hover{background:var(--surface2)}
.help-q-title{display:flex;align-items:center;gap:10px;font-size:13.5px;font-weight:600;color:var(--text)}
.help-q-title i{color:var(--accent);font-size:18px;flex-shrink:0}
.help-chev{color:var(--text3);font-size:16px;flex-shrink:0;transition:transform .2s}
.help-a{padding:2px 18px 18px 46px;font-size:13px;color:var(--text2);line-height:1.7}
.help-a ul,.help-a ol{margin:8px 0 0;padding-left:18px}
.help-a li{margin-bottom:6px}
.help-a b{color:var(--text);font-weight:600}
.help-a .help-step{display:flex;gap:12px;align-items:flex-start;margin:10px 0;padding:10px 14px;border-radius:8px;background:var(--bg);border:1px solid var(--border)}
.help-a .help-step-num{min-width:26px;height:26px;border-radius:50%;background:var(--accent);color:#fff;font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.help-a .help-step-text{font-size:12.5px;line-height:1.6}
.help-a .help-step-text b{color:var(--text)}
.help-a .help-tip{display:flex;gap:8px;align-items:flex-start;margin:10px 0;padding:10px 14px;border-radius:8px;background:rgba(37,99,235,.04);border:1px dashed rgba(37,99,235,.2);font-size:12px;line-height:1.55}
.help-a .help-tip i{color:var(--accent);font-size:15px;flex-shrink:0;margin-top:1px}
.help-a .help-nav-link{display:inline-flex;align-items:center;gap:4px;padding:2px 10px;border-radius:6px;background:var(--accent-light,#eef2ff);color:var(--accent);font-size:11.5px;font-weight:600;cursor:pointer;border:none;font-family:var(--font);margin:2px 0;transition:background .15s}
.help-a .help-nav-link:hover{background:rgba(37,99,235,.15)}
.help-footer{margin-top:22px;padding:16px 20px;border-radius:10px;background:var(--bg);border:1px solid var(--border);font-size:12px;color:var(--text3);line-height:1.6}

/* Per-page "?" button */
.page-help-btn{padding:5px 8px}
.page-help-btn i{font-size:15px;color:var(--text2)}

/* ─── HELP DRAWER (contextual slide-in) ──────────────────────────────────── */
.help-drawer-overlay{display:none;position:fixed;inset:0;background:rgba(11,30,61,.35);z-index:550}
.help-drawer-overlay.open{display:block;animation:overlayIn .18s ease}
.help-drawer{position:fixed;top:0;right:0;height:100vh;width:420px;max-width:94vw;background:var(--surface);
  border-left:1px solid var(--border);box-shadow:var(--shadow-lg);z-index:560;display:flex;flex-direction:column;
  transform:translateX(100%);transition:transform .26s cubic-bezier(.2,.8,.2,1)}
.help-drawer.open{transform:none}
.help-drawer-head{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;border-bottom:1px solid var(--border)}
.help-drawer-head .ttl{display:flex;align-items:center;gap:8px;font-size:15px;font-weight:600}
.help-drawer-head .ttl i{color:var(--accent)}
.help-drawer-head button{background:none;border:none;cursor:pointer;color:var(--text3);font-size:18px;padding:4px;border-radius:var(--r)}
.help-drawer-head button:hover{background:var(--surface2);color:var(--text)}
.help-drawer-search{position:relative;padding:12px 16px;border-bottom:1px solid var(--border)}
.help-drawer-search i{position:absolute;left:28px;top:50%;transform:translateY(-50%);color:var(--text3);font-size:16px}
.help-drawer-search input{padding-left:34px}
.help-drawer-body{flex:1;overflow-y:auto;padding:12px 16px}
.help-drawer-foot{padding:12px 16px;border-top:1px solid var(--border)}
.help-drawer-link{width:100%;display:flex;align-items:center;gap:10px;padding:10px 12px;border:1px solid var(--border);border-radius:var(--r);background:var(--surface);cursor:pointer;font-family:var(--font);font-size:13px;font-weight:500;color:var(--text);text-align:left;margin-bottom:7px;transition:.12s}
.help-drawer-link:hover{background:var(--surface2);border-color:var(--border2)}
.help-drawer-link>span{flex:1;min-width:0}
.help-drawer-link>i:first-child{color:var(--accent);font-size:17px;flex-shrink:0}
.help-drawer-chev{color:var(--text3);font-size:15px;flex-shrink:0}
.help-drawer-art-title{display:flex;align-items:center;gap:9px;font-size:15px;font-weight:600;margin-bottom:12px;letter-spacing:-.2px}
.help-drawer-art-title i{color:var(--accent);font-size:19px}
.help-drawer-art-body{font-size:13px;color:var(--text2);line-height:1.65}
.help-drawer-more{font-size:11px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.07em;margin:20px 0 8px}
.help-drawer-hint{font-size:12px;color:var(--text3);margin-bottom:12px}

/* ─── TOOLTIPS ───────────────────────────────────────────────────────────── */
.tip-i{color:var(--text3);font-size:14px;cursor:help;vertical-align:middle}
.tip-i:hover{color:var(--accent)}
.tip-pop{position:fixed;z-index:600;max-width:260px;background:#0b1e3d;color:#fff;font-size:11.5px;line-height:1.5;
  padding:8px 11px;border-radius:8px;box-shadow:var(--shadow-lg);pointer-events:none;opacity:0;transform:translateY(3px);
  transition:opacity .13s,transform .13s;font-weight:400;letter-spacing:.1px}
.tip-pop.show{opacity:1;transform:none}
.tip-pop::after{content:"";position:absolute;left:50%;margin-left:-5px;border:5px solid transparent}
.tip-pop:not(.below)::after{top:100%;border-top-color:#0b1e3d}
.tip-pop.below::after{bottom:100%;border-bottom-color:#0b1e3d}

/* ─── LOGIN ──────────────────────────────────────────────────────────────── */
.login-overlay{
  display:none;position:fixed;inset:0;z-index:500;overflow:hidden;
  background:linear-gradient(135deg,#0b1e3d 0%,#15327e 45%,#2563eb 100%);
  align-items:center;justify-content:center;padding:24px
}
/* giant wordmark laid across the blue background */
.login-bg-word{
  position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%) rotate(-8deg);
  font-weight:700;font-size:27vw;line-height:.8;white-space:nowrap;letter-spacing:-.04em;
  color:#fff;opacity:.09;pointer-events:none;user-select:none
}
.login-shell{
  position:relative;z-index:1;display:flex;align-items:center;gap:56px;
  width:100%;max-width:940px
}
.login-hero{flex:1;color:#fff;min-width:0}
.login-logo-badge{
  width:56px;height:56px;border-radius:15px;display:flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.25);font-size:27px;margin-bottom:20px
}
.login-wordmark{font-size:60px;font-weight:700;letter-spacing:-.03em;line-height:1;margin-bottom:10px}
.login-wordmark span{color:#93c5fd}
.login-tagline{font-size:15px;color:rgba(255,255,255,.78);margin-bottom:28px}
.login-features{list-style:none;display:flex;flex-direction:column;gap:13px}
.login-features li{display:flex;align-items:center;gap:11px;font-size:13.5px;color:rgba(255,255,255,.88)}
.login-features li i{color:#93c5fd;font-size:18px;flex-shrink:0}
.login-card{
  background:var(--surface);border-radius:16px;padding:32px;width:384px;max-width:95vw;flex-shrink:0;
  box-shadow:0 24px 70px rgba(0,0,0,.45)
}
.login-brand{display:flex;align-items:center;gap:9px;margin-bottom:4px;font-size:19px;font-weight:500;color:var(--navy)}
.login-sub{font-size:12.5px;color:var(--text3);margin-bottom:20px}
.login-error{color:var(--red);font-size:12px;margin-bottom:10px;display:none}
.login-hint{font-size:11px;color:var(--text3);margin-top:16px;line-height:1.6;border-top:1px solid var(--border);padding-top:12px}
.login-avatar,.sidebar-avatar{
  width:34px;height:34px;border-radius:50%;background:var(--accent);color:#fff;
  display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:500;flex-shrink:0
}
@media(max-width:820px){
  .login-shell{flex-direction:column;gap:22px;max-width:420px}
  .login-hero{text-align:center}
  .login-logo-badge{margin:0 auto 14px}
  .login-wordmark{font-size:44px}
  .login-features{display:none}
  .login-bg-word{font-size:58vw}
}

/* ─── SIDEBAR USER BLOCK ─────────────────────────────────────────────────── */
.sidebar-user{display:flex;align-items:center;gap:9px;padding:10px 14px;border-top:1px solid rgba(255,255,255,.08)}
.sidebar-user .sidebar-avatar{width:30px;height:30px;font-size:11px}
.sidebar-user-name{font-size:12.5px;color:#fff;font-weight:500;line-height:1.2}
.sidebar-user-role{font-size:10.5px;color:rgba(255,255,255,.45)}
.sidebar-logout{background:none;border:none;color:rgba(255,255,255,.4);cursor:pointer;margin-left:auto;padding:4px;font-size:16px}
.sidebar-logout:hover{color:#fca5a5}

/* ─── TENANT PICKER & SWITCHER ───────────────────────────────────────────── */
.tenant-picker-item{display:flex;align-items:center;gap:12px;width:100%;padding:12px 14px;border:1px solid var(--border);border-radius:var(--r);background:var(--bg);cursor:pointer;text-align:left;transition:border-color .15s,background .15s}
.tenant-picker-item:hover{border-color:var(--accent);background:var(--accent-bg,rgba(37,99,235,.06))}
.tenant-picker-icon{width:36px;height:36px;border-radius:8px;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.tenant-switch-item{display:flex;align-items:center;gap:6px;width:100%;padding:9px 12px;border:none;background:none;cursor:pointer;font-size:12.5px;text-align:left;border-bottom:1px solid var(--border)}
.tenant-switch-item:last-child{border-bottom:none}
.tenant-switch-item:hover:not(:disabled){background:var(--accent-bg,rgba(37,99,235,.06))}
.tenant-switch-item.active{background:rgba(34,197,94,.06);cursor:default}

/* ─── SPINNER ────────────────────────────────────────────────────────────── */
@keyframes spin{from{transform:rotate(0)}to{transform:rotate(360deg)}}
.spin{display:inline-block;animation:spin .7s linear infinite}

/* ─── PRINT ──────────────────────────────────────────────────────────────── */
@media print{
  .sidebar,.topbar,.btn,.btn-group{display:none!important}
  .content{padding:0}
  .page{display:block!important}
}

/* ─── SIDEBAR TOGGLE ─────────────────────────────────────────────────────── */
/* Always available so the user can hide the sidebar and reclaim full width. */
.sidebar-toggle{display:inline-flex;align-items:center;background:none;border:none;cursor:pointer;color:var(--text2);font-size:20px;padding:4px 6px;margin-right:2px;border-radius:var(--r)}
.sidebar-toggle:hover{background:var(--surface2)}
.shell.sidebar-collapsed .sidebar{display:none}
.sidebar-backdrop{display:none;position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:290}
.sidebar-backdrop.show{display:block}

/* ─── RESPONSIVE ─────────────────────────────────────────────────────────── */
/* Stack the paired cards full-width early so their tables are never clipped —
   most laptops at 125–150% display scaling land in the 900–1200px range. */
@media (max-width:1200px){
  .grid-2,.grid-3{grid-template-columns:1fr}
}
@media (max-width:900px){
  .page-toolbar{flex-wrap:wrap}
  .page-toolbar-left{order:2;width:100%}
  .page-toolbar-right{order:1;width:100%;justify-content:flex-end}
}
@media (max-width:1024px){
  .cols-4{grid-template-columns:repeat(2,1fr)}
  .cols-3{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:760px){
  .cols-4,.cols-3,.cols-2{grid-template-columns:1fr}
  .content{padding:16px}
  .topbar{padding:0 14px}
}
/* ─── INVESTMENT APPRAISAL ───────────────────────────────────────────────── */
.inv-tabs{display:flex;gap:2px;overflow-x:auto;padding:4px;background:var(--surface2);border-radius:var(--r2);margin-bottom:16px;border:1px solid var(--border)}
.inv-tab{padding:7px 12px;border-radius:8px;font-size:11.5px;font-weight:500;cursor:pointer;color:var(--text3);border:none;background:none;transition:.15s;white-space:nowrap;display:flex;align-items:center;gap:4px}
.inv-tab:hover{color:var(--text2);background:var(--surface)}
.inv-tab.active{background:var(--accent);color:#fff;box-shadow:0 1px 3px rgba(37,99,235,.25)}
.inv-section{animation:fadeIn .2s}
.inv-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.inv-form-grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}
.inv-cf-table{width:100%;border-collapse:collapse;font-size:12px}
.inv-cf-table th,.inv-cf-table td{padding:6px 8px;border:1px solid var(--border);text-align:right}
.inv-cf-table th{background:var(--surface2);font-weight:600;text-align:center;font-size:11px;color:var(--text2);position:sticky;top:0}
.inv-cf-table td:first-child,.inv-cf-table th:first-child{text-align:left;font-weight:500;position:sticky;left:0;background:var(--surface);z-index:1}
.inv-cf-table tr:hover td{background:var(--accent-light)}
.inv-cf-table .row-header{background:var(--surface2);font-weight:600;color:var(--text)}
.inv-cf-table input{width:100%;border:none;background:transparent;text-align:right;font-family:var(--mono);font-size:12px;padding:2px 0;outline:none}
.inv-cf-table input:focus{background:var(--accent-light);border-radius:3px}
.inv-metric{display:flex;flex-direction:column;align-items:center;padding:16px;border-radius:var(--r2);border:1px solid var(--border);background:var(--surface)}
.inv-metric-val{font-size:22px;font-weight:700;font-family:var(--mono)}
.inv-metric-label{font-size:11px;color:var(--text3);margin-top:2px}
.inv-metric-sub{font-size:11px;margin-top:4px;padding:2px 8px;border-radius:8px}
.inv-metric.green{border-color:var(--green)}.inv-metric.green .inv-metric-val{color:var(--green)}.inv-metric.green .inv-metric-sub{background:var(--green-light);color:var(--green)}
.inv-metric.red{border-color:var(--red)}.inv-metric.red .inv-metric-val{color:var(--red)}.inv-metric.red .inv-metric-sub{background:var(--red-light);color:var(--red)}
.inv-metric.amber{border-color:var(--amber)}.inv-metric.amber .inv-metric-val{color:var(--amber)}.inv-metric.amber .inv-metric-sub{background:var(--amber-light);color:var(--amber)}
.inv-heatmap{display:grid;grid-template-columns:auto repeat(3,1fr);gap:1px;font-size:11px}
.inv-heatmap-cell{padding:8px 12px;text-align:center;border-radius:4px;font-weight:500}
.inv-heatmap-header{background:var(--surface2);font-weight:600;color:var(--text2);padding:8px 12px;text-align:center;border-radius:4px}
@media (max-width:900px){.inv-tabs{flex-wrap:wrap}.inv-form-grid,.inv-form-grid-3{grid-template-columns:1fr}}

/* Below 640px the sidebar becomes a slide-in drawer (toggled by the hamburger) */
@media (max-width:640px){
  .sidebar{position:fixed;z-index:300;height:100vh;left:0;top:0;transform:translateX(-100%);transition:transform .2s;width:240px}
  .shell.sidebar-collapsed .sidebar{display:flex}  /* collapse-state doesn't apply in drawer mode */
  .sidebar.open{transform:none}
  .content{padding:14px}
}

/* ═══ ENTITY SELECTOR ═══ */
.entity-switcher{display:flex;align-items:center;gap:6px;padding:4px 12px;border:1px solid var(--border);border-radius:10px;cursor:pointer;transition:border-color .15s;background:var(--bg)}
.entity-switcher:hover{border-color:var(--accent)}
.entity-dropdown{position:absolute;top:calc(100% + 6px);left:0;background:var(--card);border:1px solid var(--border);border-radius:12px;box-shadow:0 8px 24px rgba(0,0,0,.1);min-width:200px;z-index:200;padding:6px}
.entity-dd-item{display:flex;align-items:center;gap:8px;padding:8px 12px;border-radius:8px;font-size:13px;font-weight:500;color:var(--text2);cursor:pointer;transition:background .1s}
.entity-dd-item:hover{background:var(--bg)}
.entity-dd-item.active{background:var(--accent-light);color:var(--accent);font-weight:600}
