:root{
  --bg:#f4f5f7;
  --surf:#ffffff;
  --card:#ffffff;
  --card2:#f8f9fc;
  --border:#e4e7ef;
  --border2:#d1d5e0;
  --gold:#c72030;
  --gold2:#e8002d;
  --blue:#1d4ed8;
  --teal:#0369a1;
  --green:#16a34a;
  --red:#c72030;
  --purple:#7c3aed;
  --orange:#c2410c;
  --text:#0f172a;
  --sub:#475569;
  --muted:#94a3b8;
  --font-display:'Cormorant Garamond',serif;
  --font-body:'DM Sans',sans-serif;
  --font-mono:'Fira Mono',monospace;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--font-body);background:#f0f2f7;color:#0f172a;min-height:100vh;overflow-x:hidden}
::selection{background:rgba(199,32,48,.2);color:#c72030}
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:#f0f2f7}
::-webkit-scrollbar-thumb{background:#c72030;border-radius:3px}

/* ── LAYOUT ── */
.layout{display:flex;min-height:100vh}
.sidebar{width:248px;background:#1a1d2e;border-right:1px solid #252840;display:flex;flex-direction:column;position:fixed;height:100vh;z-index:200;top:0;left:0;transition:transform .3s ease}
.main-area{margin-left:248px;flex:1;min-height:100vh;display:flex;flex-direction:column}
.topbar{background:#ffffff;border-bottom:1px solid var(--border);box-shadow:0 1px 4px rgba(0,0,0,.06);padding:12px 32px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100;backdrop-filter:blur(12px)}
.page-content{padding:28px 32px;max-width:1480px;width:100%;margin:0 auto;flex:1}
.page{display:none;animation:fadeIn .3s ease}
.page.active{display:block;max-height:calc(100vh - 54px);overflow-y:auto;overflow-x:hidden}
.ri-tab{padding:9px 18px;border:none;background:none;font-size:12px;font-weight:600;font-family:var(--font-body);color:var(--sub);cursor:pointer;border-bottom:2.5px solid transparent;margin-bottom:-2px;transition:all .2s;letter-spacing:.04em;text-transform:uppercase}
.ri-tab.active,.ri-tab:hover{color:#c72030;border-bottom-color:#c72030}
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

/* ── SIDEBAR ── */
.logo-area{padding:28px 22px 16px}
.logo-name{font-family:var(--font-display);font-size:22px;font-weight:600;color:#ffffff;font-style:italic;letter-spacing:.02em;line-height:1.2}
.logo-sub{font-size:9px;color:rgba(255,255,255,.45);font-weight:600;letter-spacing:.18em;text-transform:uppercase;margin-top:3px}
.logo-dot{display:inline-block;width:6px;height:6px;background:var(--green);border-radius:50%;margin-right:5px;animation:blink 2.4s ease-in-out infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}
.nav-divider{border:none;border-top:1px solid rgba(255,255,255,.1);margin:8px 0}
.nav{flex:1;padding:4px 10px;overflow-y:auto;min-height:0;-webkit-overflow-scrolling:touch}
.nav::-webkit-scrollbar{width:4px}
.nav::-webkit-scrollbar-thumb{background:rgba(255,255,255,.15);border-radius:2px}
.nav::-webkit-scrollbar-track{background:transparent}
.nav-item{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;background:transparent;border:1px solid transparent;border-radius:7px;color:rgba(255,255,255,.55);font-weight:400;letter-spacing:.01em;cursor:pointer;font-size:13px;font-family:var(--font-body);text-align:left;margin-bottom:2px;transition:all .18s ease}
.nav-item .nav-icon{font-size:15px;width:20px;text-align:center;opacity:.8;flex-shrink:0}
.nav-item:hover{background:rgba(255,255,255,.08);color:#ffffff}
.nav-item.active{background:rgba(199,32,48,.25);border-color:rgba(199,32,48,.5);color:#ff6b7a}
.nav-item.active .nav-icon{opacity:1}
.sidebar-footer{padding:14px 18px;border-top:1px solid rgba(255,255,255,.1)}
.sidebar-footer .label{font-size:9px;color:rgba(255,255,255,.35);font-weight:600;letter-spacing:.15em;text-transform:uppercase;margin-bottom:7px}
.tag-cloud{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:10px}
.sidebar-date{font-size:10px;color:rgba(255,255,255,.3);margin-top:6px}

/* ── TOPBAR ── */
.breadcrumb{display:flex;align-items:center;gap:8px;font-size:13px}
.breadcrumb .crumb-home{color:#94a3b8;font-size:13px}
.breadcrumb .sep{color:var(--border2)}
.breadcrumb .crumb-page{color:#0f172a;font-weight:500}
.topbar-right{display:flex;align-items:center;gap:14px}
.live-badge{display:flex;align-items:center;gap:5px;font-size:10px;font-weight:500;letter-spacing:.06em;color:var(--green);padding:4px 10px;background:rgba(22,163,74,.08);border:1px solid rgba(22,163,74,.2);border-radius:20px}
.topbar-info{font-size:12px;color:#94a3b8}

/* ── TYPOGRAPHY ── */
.page-eyebrow{font-size:10px;color:#c72030;font-weight:600;letter-spacing:.16em;text-transform:uppercase;margin-bottom:6px}
.page-title{font-family:var(--font-display);font-size:38px;font-weight:600;color:#0f172a;letter-spacing:-.01em;line-height:1.15;margin-bottom:6px}
.page-sub{font-size:14px;color:#475569;margin-bottom:28px;font-weight:300;line-height:1.65}
.section-label{font-size:10px;font-weight:600;letter-spacing:.15em;text-transform:uppercase;color:#c72030;margin-bottom:12px}
.section-title{font-family:var(--font-display);font-size:24px;font-weight:500;color:#0f172a;letter-spacing:-.005em;margin-bottom:6px}

/* ── CARDS ── */
.card{background:#ffffff;border:1px solid #e4e7ef;border-radius:10px;padding:24px;box-shadow:0 1px 4px rgba(0,0,0,.05)}
.card-sm{background:#ffffff;border:1px solid #e4e7ef;border-radius:8px;padding:16px;box-shadow:0 1px 3px rgba(0,0,0,.04)}
.card:hover{border-color:rgba(199,32,48,.3);box-shadow:0 3px 12px rgba(199,32,48,.08)}
.card-accent-top{border-top:3px solid var(--red)}
.card-accent-blue{border-top:3px solid var(--blue)}
.card-accent-teal{border-top:3px solid var(--teal)}
.card-accent-green{border-top:3px solid var(--green)}

/* ── GRIDS ── */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:18px}
.grid-4{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:16px}
.grid-5{display:grid;grid-template-columns:repeat(5,1fr);gap:14px}

/* ── KPI CARDS ── */
.kpi{background:#ffffff;border:1px solid #e4e7ef;border-radius:8px;padding:18px 20px;box-shadow:0 1px 4px rgba(0,0,0,.05)}
.kpi-label{font-size:10px;color:#94a3b8;font-weight:600;letter-spacing:.12em;text-transform:uppercase;margin-bottom:8px}
.kpi-value{font-family:var(--font-display);font-size:32px;font-weight:600;line-height:1;letter-spacing:-.02em}
.kpi-sub{font-size:11px;color:#94a3b8;margin-top:5px}

/* ── BADGES / TAGS ── */
.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:100px;font-size:10px;font-weight:600;letter-spacing:.04em}
.tag{display:inline-block;padding:2px 9px;border-radius:4px;font-size:10px;font-weight:500;letter-spacing:.04em}
.tag-gold{background:rgba(199,32,48,.1);color:#c72030;border:1px solid rgba(199,32,48,.25)}
.tag-blue{background:rgba(29,78,216,.1);color:var(--blue);border:1px solid rgba(29,78,216,.2)}
.tag-teal{background:rgba(3,105,161,.1);color:var(--teal);border:1px solid rgba(3,105,161,.25)}
.tag-green{background:rgba(22,163,74,.1);color:var(--green);border:1px solid rgba(22,163,74,.2)}
.tag-purple{background:rgba(124,58,237,.1);color:var(--purple);border:1px solid rgba(124,58,237,.2)}
.tag-muted{background:#f1f3f8;color:#475569;border:1px solid #e4e7ef}
.tag-orange{background:rgba(230,126,34,.15);color:var(--orange);border:1px solid rgba(230,126,34,.25)}

/* ── BUTTONS ── */
.btn{padding:9px 22px;border-radius:6px;cursor:pointer;font-size:12px;font-weight:500;font-family:var(--font-body);transition:all .2s;letter-spacing:.04em;text-transform:uppercase}
.btn-red{background:rgba(199,32,48,.08);border:1px solid rgba(199,32,48,.35);color:#c72030}
.btn-red:hover{background:rgba(199,32,48,.15)}
.btn-solid{background:#c72030;border:none;color:#ffffff;font-weight:600}
.btn-solid:hover{background:#a01828}
.btn-blue{background:rgba(29,78,216,.08);border:1px solid rgba(29,78,216,.3);color:var(--blue)}
.btn-blue:hover{background:rgba(29,78,216,.15)}
.btn-teal{background:rgba(3,105,161,.08);border:1px solid rgba(3,105,161,.3);color:var(--teal)}
.btn-sm{padding:5px 14px;font-size:12px}
.btn-xs{padding:3px 9px;font-size:11px}
.btn-full{width:100%;text-align:center}

/* ── FORM ELEMENTS ── */
input,select,textarea{background:#f8fafc;border:1px solid #e4e7ef;color:#0f172a;padding:9px 14px;border-radius:7px;font-size:13px;font-family:var(--font-body);outline:none;transition:border-color .2s}
input:focus,select:focus,textarea:focus{border-color:rgba(199,32,48,.5);box-shadow:0 0 0 3px rgba(199,32,48,.08)}
input::placeholder{color:#b0bac9}
select option{background:#ffffff;color:#0f172a}

/* ── PROGRESS BAR ── */
.score-bar-wrap{background:#e8edf5;border-radius:99px;overflow:hidden}
.score-bar-fill{height:100%;border-radius:99px;transition:width .8s ease}

/* ── TABLE ── */
.data-table{width:100%;border-collapse:collapse}
.data-table th{font-size:9px;color:#c72030;font-weight:600;letter-spacing:.18em;text-transform:uppercase;padding:10px 16px;text-align:left;border-bottom:2px solid rgba(199,32,48,.2);background:#fafbfd}
.data-table td{padding:12px 16px;border-bottom:1px solid #edf0f7;font-size:13px;font-weight:400}
.data-table tr:last-child td{border-bottom:none}
.data-table tr:hover td{background:rgba(199,32,48,.03)}
.data-table .mono{font-family:var(--font-mono);font-size:11px;letter-spacing:.02em}

/* ── DIVIDER ── */
hr.divider{border:none;border-top:1px solid var(--border);margin:20px 0}

/* ── CHART CONTAINER ── */
.chart-wrap{position:relative;width:100%;height:220px}
.chart-wrap-lg{position:relative;width:100%;height:280px}
.chart-wrap-sm{position:relative;width:100%;height:160px}

/* ── SCORE RING ── */
.score-ring-wrap{position:relative;width:110px;height:110px;flex-shrink:0}
.score-ring-canvas{position:absolute;top:0;left:0}
.score-ring-inner{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center}
.score-ring-value{font-family:var(--font-display);font-size:24px;font-weight:600;line-height:1;letter-spacing:-.02em}
.score-ring-label{font-size:9px;color:#94a3b8;letter-spacing:.1em;text-transform:uppercase}

/* ── CHAT ── */
.chat-wrap{display:flex;flex-direction:column;height:calc(100vh - 260px);min-height:400px}
.chat-messages{flex:1;overflow-y:auto;padding:0 0 16px;display:flex;flex-direction:column;gap:14px}
.chat-bubble{display:flex;gap:12px;align-items:flex-start}
.chat-bubble.user{flex-direction:row-reverse}
/* AI markdown rendering — only applied on .chat-body.markdown bubbles. */
.chat-body.markdown > *:first-child{margin-top:0}
.chat-body.markdown > *:last-child{margin-bottom:0}
.chat-body.markdown h1,.chat-body.markdown h2,.chat-body.markdown h3,.chat-body.markdown h4{font-family:var(--font-display);font-weight:700;color:#0f172a;margin:16px 0 8px;line-height:1.3;letter-spacing:-.01em}
.chat-body.markdown h1{font-size:19px;border-bottom:1px solid #e4e7ef;padding-bottom:6px}
.chat-body.markdown h2{font-size:16px}
.chat-body.markdown h3{font-size:13px;color:#c72030;letter-spacing:.04em;text-transform:uppercase}
.chat-body.markdown h4{font-size:12px;color:#475569;letter-spacing:.06em;text-transform:uppercase}
.chat-body.markdown p{margin:8px 0;line-height:1.65;color:#0f172a}
.chat-body.markdown strong{font-weight:700;color:#0f172a}
.chat-body.markdown em{font-style:italic}
.chat-body.markdown ul,.chat-body.markdown ol{margin:8px 0;padding-left:22px}
.chat-body.markdown li{margin:4px 0;line-height:1.6;color:#0f172a}
.chat-body.markdown li::marker{color:#c72030}
.chat-body.markdown code{background:#f1f5f9;color:#c72030;padding:1px 6px;border-radius:3px;font-family:var(--font-mono,'SFMono-Regular',Consolas,monospace);font-size:12px}
.chat-body.markdown pre{background:#0a0a0a;color:#e5e7eb;padding:14px 16px;border-radius:8px;overflow-x:auto;margin:12px 0;font-size:12px;line-height:1.55;font-family:var(--font-mono,'SFMono-Regular',Consolas,monospace);white-space:pre}
.chat-body.markdown pre code{background:transparent;color:#e5e7eb;padding:0;font-size:12px;border-radius:0}
.chat-body.markdown table{border-collapse:collapse;margin:12px 0;width:100%;font-size:12px}
.chat-body.markdown th,.chat-body.markdown td{border:1px solid #e4e7ef;padding:6px 10px;text-align:left;vertical-align:top}
.chat-body.markdown th{background:#f8fafc;font-weight:700;color:#0f172a;font-size:11px;letter-spacing:.04em;text-transform:uppercase}
.chat-body.markdown blockquote{border-left:3px solid #c72030;padding-left:12px;margin:12px 0;color:#475569;font-style:italic}
.chat-body.markdown a{color:#c72030;text-decoration:underline}
.chat-body.markdown hr{border:0;border-top:1px solid #e4e7ef;margin:16px 0}
/* Mermaid-rendered capital-stack diagrams (we replace ```mermaid``` blocks
   with an SVG flowchart, see _ahaRenderMermaidIn). */
.chat-body.markdown .mermaid{margin:16px 0;background:linear-gradient(180deg,#fafbfc,#f1f5f9);border:1px solid #e4e7ef;border-radius:10px;padding:18px 14px;text-align:center;overflow-x:auto}
.chat-body.markdown .mermaid svg{max-width:100%;height:auto;font-family:var(--font-body)!important}
.chat-body.markdown .mermaid.aha-mermaid-loading{color:#94a3b8;font-size:11px;text-align:left;font-family:var(--font-mono,monospace);white-space:pre;background:#fafbfc}
.chat-avatar{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;flex-shrink:0;font-weight:600}
.chat-avatar.ai{background:rgba(199,32,48,.15);color:#c72030}
.chat-avatar.user{background:rgba(42,114,229,.2);color:var(--blue)}
.chat-body{background:#f8fafc;border:1px solid #e4e7ef;border-radius:10px;padding:12px 16px;max-width:80%;font-size:13px;line-height:1.68;color:#0f172a;white-space:pre-wrap}
.chat-bubble.user .chat-body{background:rgba(199,32,48,.06);border-color:rgba(199,32,48,.15)}
.chat-input-area{border-top:1px solid var(--border);padding-top:14px;display:flex;gap:10px}
.typing-dot{width:7px;height:7px;border-radius:50%;background:#c72030;display:inline-block;animation:typingPulse 1.3s ease-in-out infinite}
.typing-dot:nth-child(2){animation-delay:.2s}
.typing-dot:nth-child(3){animation-delay:.4s}
@keyframes typingPulse{0%,100%{opacity:.2;transform:scale(.8)}50%{opacity:1;transform:scale(1)}}

/* ── TIMELINE ── */
.timeline-item{display:flex;gap:16px;position:relative}
.timeline-item:not(:last-child)::after{content:'';position:absolute;left:19px;top:40px;width:2px;bottom:-12px;background:rgba(199,32,48,.2)}
.timeline-num{width:38px;height:38px;border-radius:50%;background:rgba(199,32,48,.1);border:2px solid rgba(199,32,48,.35);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:#c72030;flex-shrink:0}
.timeline-body{flex:1;padding-bottom:20px}

/* ── HERO SECTION ── */
.hero{background:linear-gradient(135deg,#1a1d2e 0%,#c72030 55%,#8b0018 100%);padding:80px 40px 64px;position:relative;overflow:hidden}
.hero-mesh{position:absolute;inset:0;background:radial-gradient(ellipse 60% 60% at 80% 50%,rgba(255,255,255,.07) 0%,transparent 60%),radial-gradient(ellipse 40% 40% at 10% 80%,rgba(0,0,0,.15) 0%,transparent 50%);pointer-events:none}
.hero-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);background-size:52px 52px;pointer-events:none}
.hero-content{position:relative;max-width:780px}
.hero-eyebrow{display:inline-flex;align-items:center;gap:8px;padding:5px 14px;background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.3);border-radius:100px;font-size:10px;color:#ffffff;font-weight:500;letter-spacing:.18em;text-transform:uppercase;margin-bottom:24px}
.hero-title{font-family:var(--font-display);font-size:68px;font-weight:700;color:#ffffff;letter-spacing:-.01em;font-style:normal;line-height:1.08;margin-bottom:22px}
.hero-title span{color:#ffffff;font-style:normal;font-weight:700}
.hero-desc{font-size:17px;color:rgba(255,255,255,.85);font-weight:300;line-height:1.75;max-width:600px;margin-bottom:38px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}
/* Hero visual: dashboard imagery on the right of the hero */
.hero-visual{position:absolute;right:40px;top:50%;transform:translateY(-50%);width:560px;max-width:42vw;pointer-events:none;z-index:2}
.hero-visual-glow{position:absolute;inset:-40px;background:radial-gradient(ellipse at center,rgba(245,184,0,.25) 0%,rgba(199,32,48,.12) 40%,transparent 70%);filter:blur(40px);z-index:0}
.hero-visual-frame{position:relative;border-radius:14px;overflow:hidden;box-shadow:0 30px 70px rgba(0,0,0,.55),0 0 0 1px rgba(255,255,255,.08),inset 0 0 0 1px rgba(255,255,255,.05);transform:perspective(1400px) rotateY(-6deg) rotateX(2deg);transform-origin:center}
.hero-visual-frame img{display:block;width:100%;height:auto}
.hero-visual-tint{position:absolute;inset:0;background:linear-gradient(135deg,rgba(26,29,46,.18) 0%,transparent 35%,transparent 65%,rgba(139,0,24,.22) 100%);pointer-events:none}
.hero-visual-chip{position:absolute;display:inline-flex;align-items:center;gap:8px;padding:8px 14px;background:rgba(15,23,42,.85);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.12);border-radius:100px;font-size:11px;font-weight:600;color:#fff;letter-spacing:.02em;box-shadow:0 8px 24px rgba(0,0,0,.4);z-index:3}
.hero-visual-chip-top{top:-14px;left:24px}
.hero-visual-chip-bottom{bottom:18px;right:-12px;background:rgba(245,184,0,.95);color:#1a1d2e;border-color:rgba(245,184,0,.4)}
@media (max-width:1180px){.hero-visual{width:480px;right:24px}}
@media (max-width:980px){.hero-visual{display:none}}
.stat-strip{background:#ffffff;border-bottom:1px solid var(--border);box-shadow:0 2px 8px rgba(0,0,0,.06);padding:18px 40px}
.stat-strip-inner{display:grid;grid-template-columns:repeat(9,1fr);gap:24px;max-width:1480px;margin:0 auto}
.stat-item .sv{font-family:var(--font-display);font-size:26px;color:#c72030;font-weight:600;letter-spacing:-.01em}
.stat-item .sl{font-size:11px;color:#64748b;font-weight:400;letter-spacing:.01em;margin-top:3px;line-height:1.4}

/* ── FEATURE CARDS ── */
.feature-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;padding:48px 40px}
.feature-card{background:#ffffff;border:1px solid #e4e7ef;border-radius:12px;padding:28px;cursor:default;transition:all .22s ease;position:relative;overflow:hidden;box-shadow:0 1px 3px rgba(0,0,0,.05)}
.feature-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:#c72030;opacity:0;transition:opacity .25s}
.feature-card:hover{border-color:#d1d5db;transform:translateY(-2px);box-shadow:0 6px 20px rgba(0,0,0,.08)}
.feature-card:hover::before{opacity:1}
.feature-icon{font-size:24px;margin-bottom:14px}
.feature-title{font-family:var(--font-display);font-size:18px;font-weight:600;color:#0f172a;letter-spacing:-.005em;margin-bottom:8px}
.feature-desc{font-size:13px;color:#475569;line-height:1.65;font-weight:400}
.feature-cta{font-size:12px;font-weight:500;margin-top:14px;display:flex;align-items:center;gap:4px}

/* ── INVESTOR CARD ── */
.investor-card{background:#f8fafc;border:1px solid #e4e7ef;border-radius:8px;padding:12px 14px}
.investor-name{font-size:13px;font-weight:600;color:#0f172a}
.investor-type{font-size:11px;color:#94a3b8}
.match-score{font-family:var(--font-mono);font-size:15px;font-weight:500}

/* ── DOC ITEM ── */
.doc-item{display:flex;justify-content:space-between;align-items:center;padding:9px 12px;background:#f8fafc;border-radius:7px;border:1px solid #e4e7ef}
.doc-name{font-size:12px;color:#0f172a}
.doc-date{font-size:10px;color:#94a3b8}

/* ── MODEL OUTPUT ── */
.output-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:20px}
.output-item{background:#f8fafc;border-radius:7px;border:1px solid #e4e7ef;padding:12px 14px}
.output-label{font-size:9px;color:#94a3b8;font-weight:500;letter-spacing:.14em;text-transform:uppercase;margin-bottom:4px}
.output-val{font-family:var(--font-display);font-size:20px;font-weight:600;letter-spacing:-.01em}

/* ── GUARANTEE CARD ── */
.guarantee-card{background:#f8fafc;border:1px solid #e4e7ef;border-radius:8px;padding:14px 16px}
.guarantee-name{font-size:13px;font-weight:600;color:#0f172a;margin-bottom:8px}
.guarantee-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}
.gk{font-size:9px;color:#94a3b8;font-weight:600;text-transform:uppercase;letter-spacing:.08em}
.gv{font-size:11px;color:#475569;margin-top:2px}

/* ── COUNTRY SELECTOR ── */
.country-pills{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:24px}
.cpill{padding:5px 14px;border-radius:100px;font-size:12px;cursor:pointer;font-family:var(--font-body);transition:all .18s;border:1px solid #e4e7ef;background:transparent;color:#475569}
.cpill:hover{border-color:var(--border2);color:#0f172a}
.cpill.active{background:rgba(199,32,48,.1);border-color:rgba(199,32,48,.4);color:#c72030;font-weight:600}

/* ── RADAR PLACEHOLDER ── */
.radar-container{width:100%;height:260px;position:relative}

/* ── MOBILE TOGGLE ── */
.menu-toggle{display:none;background:none;border:none;color:#0f172a;font-size:20px;cursor:pointer;padding:4px}
@media(max-width:900px){
  .sidebar{transform:translateX(-100%)}
  .sidebar.open{transform:translateX(0)}
  .main-area{margin-left:0}
  .menu-toggle{display:block}
  .feature-grid{grid-template-columns:1fr 1fr;padding:28px}
  .grid-4{grid-template-columns:1fr 1fr}
  .stat-strip-inner{grid-template-columns:repeat(3,1fr)}
  .hero-title{font-size:38px}
  .page-content{padding:20px}
}
@media(max-width:600px){
  .feature-grid{grid-template-columns:1fr;padding:20px}
  .grid-2,.grid-3{grid-template-columns:1fr}
  .grid-4,.grid-5{grid-template-columns:1fr 1fr}
  .stat-strip-inner{grid-template-columns:repeat(2,1fr)}
}

/* ── DEAL ROOM TABS ── */
.dr-tabs{display:flex;gap:0;margin-bottom:28px;border-bottom:2px solid #e4e7ef}
.dr-tab{display:flex;align-items:center;gap:7px;padding:11px 22px;background:transparent;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;cursor:pointer;font-family:var(--font-body);font-size:13px;font-weight:500;color:#94a3b8;letter-spacing:.01em;transition:all .18s}
.dr-tab:hover{color:#0f172a}
.dr-tab.active{color:#c72030;border-bottom-color:#c72030;font-weight:600}
.dr-tab-icon{font-size:15px}
.dr-tab-badge{background:#c72030;color:#fff;font-size:10px;font-weight:700;padding:1px 7px;border-radius:100px;margin-left:3px}

/* ── SUBMIT PROJECT FORM ── */
.spf-steps{display:flex;align-items:center;margin-bottom:28px;gap:0}
.spf-step{display:flex;align-items:center;gap:8px;cursor:default}
.spf-step-num{width:28px;height:28px;border-radius:50%;background:#e4e7ef;color:#94a3b8;font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center;transition:all .25s;flex-shrink:0}
.spf-step.active .spf-step-num{background:#c72030;color:#fff}
.spf-step.done .spf-step-num{background:rgba(22,163,74,.15);color:#16a34a;border:1px solid rgba(22,163,74,.3)}
.spf-step.done .spf-step-num::after{content:'✓'}
.spf-step-label{font-size:11px;font-weight:600;letter-spacing:.04em;color:#94a3b8;text-transform:uppercase;white-space:nowrap}
.spf-step.active .spf-step-label{color:#c72030}
.spf-step.done .spf-step-label{color:#16a34a}
.spf-step-line{flex:1;height:2px;background:#e4e7ef;min-width:20px;max-width:60px}
.spf-step.done + .spf-step-line{background:rgba(22,163,74,.3)}

.spf-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.spf-span2{grid-column:span 2}
.spf-field{display:flex;flex-direction:column;gap:5px}
.spf-label{font-size:11px;color:#475569;font-weight:500;letter-spacing:.04em;text-transform:uppercase}
.spf-req{color:#c72030}
.spf-input{background:#f8fafc;border:1px solid #e4e7ef;color:#0f172a;padding:9px 13px;border-radius:7px;font-size:13px;font-family:var(--font-body);outline:none;transition:border-color .2s;width:100%}
.spf-input:focus{border-color:rgba(199,32,48,.5);box-shadow:0 0 0 3px rgba(199,32,48,.07)}
.spf-input.error{border-color:#e05454;background:#fff8f8}
.spf-textarea{resize:vertical;min-height:100px}
.spf-input-group{display:flex;gap:8px;align-items:center}
.spf-currency{width:auto;min-width:70px;flex-shrink:0}
.spf-input-flex{flex:1}
.spf-de-row{display:flex;gap:12px;align-items:flex-start}

.spf-nav{display:flex;justify-content:space-between;align-items:center;margin-top:24px;padding-top:20px;border-top:1px solid #e4e7ef}

/* SDG chips */
.spf-sdg-grid{display:flex;flex-wrap:wrap;gap:8px;margin-top:6px}
.spf-sdg-tile{position:relative;user-select:none}
.spf-sdg-selected{}

/* Dropzone */
.spf-dropzone{border:2px dashed #d1d5e0;border-radius:10px;padding:36px 24px;text-align:center;cursor:pointer;transition:all .2s;background:#fafbfc}
.spf-dropzone:hover,.spf-dz-active{border-color:#c72030;background:rgba(199,32,48,.03)}
.spf-dz-icon{font-size:28px;color:#94a3b8;margin-bottom:10px}
.spf-dz-title{font-size:14px;font-weight:500;color:#475569;margin-bottom:4px}
.spf-dz-sub{font-size:12px;color:#94a3b8}

/* Uploaded file row */
.spf-file-row{display:flex;align-items:center;gap:12px;padding:10px 14px;background:#f8fafc;border:1px solid #e4e7ef;border-radius:8px}
.spf-file-icon{width:32px;height:32px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;flex-shrink:0}
.spf-file-name{font-size:13px;font-weight:500;color:#0f172a;flex:1}
.spf-file-size{font-size:11px;color:#94a3b8}
.spf-file-remove{background:none;border:none;color:#94a3b8;cursor:pointer;font-size:16px;padding:2px 6px;border-radius:4px;transition:color .15s}
.spf-file-remove:hover{color:#c72030}

/* Recommended doc checklist */
.spf-doc-checklist{display:grid;grid-template-columns:1fr 1fr;gap:7px}
.spf-doc-check{display:flex;align-items:center;gap:8px;padding:8px 12px;border-radius:7px;border:1px solid #e4e7ef;background:#fafbfc;font-size:12px;color:#475569}
.spf-doc-check.ticked{background:rgba(22,163,74,.05);border-color:rgba(22,163,74,.25);color:#16a34a}
.spf-doc-check .spf-dc-icon{font-size:14px;flex-shrink:0}

/* Declarations */
.spf-declarations{background:#fafbfc;border:1px solid #e4e7ef;border-radius:10px;padding:20px;display:flex;flex-direction:column;gap:12px}
.spf-check-row{display:flex;align-items:flex-start;gap:10px;cursor:pointer;font-size:13px;color:#475569;line-height:1.55}
.spf-checkbox{width:16px;height:16px;flex-shrink:0;cursor:pointer;margin-top:2px;accent-color:#c72030}

/* Success screen */
.spf-ref-box{background:#f0fdf4;border:1px solid rgba(22,163,74,.25);border-radius:8px;padding:16px 20px;text-align:left}
.spf-ref-box .ref-label{font-size:10px;color:#16a34a;font-weight:600;letter-spacing:.12em;text-transform:uppercase;margin-bottom:4px}
.spf-ref-box .ref-id{font-family:var(--font-mono);font-size:14px;color:#0f172a;font-weight:500}

/* Submitted project cards */
.sub-proj-card{background:#fff;border:1px solid #e4e7ef;border-radius:10px;padding:22px;box-shadow:0 1px 4px rgba(0,0,0,.05)}
.sub-proj-status{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:100px;font-size:10px;font-weight:600;background:rgba(199,32,48,.08);color:#c72030;border:1px solid rgba(199,32,48,.2)}

@media(max-width:700px){
  .spf-grid-2{grid-template-columns:1fr}
  .spf-span2{grid-column:span 1}
  .spf-steps{overflow-x:auto;padding-bottom:4px}
  .spf-doc-checklist{grid-template-columns:1fr}
  .spf-step-label{display:none}
}

/* ── COUNTRY PERSPECTIVE ── */
.cp-tabs{display:flex;gap:0;margin-bottom:24px;border-bottom:2px solid #e4e7ef;flex-wrap:wrap}
.cp-tab{padding:10px 20px;background:transparent;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;cursor:pointer;font-family:var(--font-body);font-size:13px;font-weight:500;color:#94a3b8;letter-spacing:.01em;transition:all .18s;white-space:nowrap}
.cpr-banner{display:grid;grid-template-columns:minmax(0,340px) minmax(0,1fr);gap:0;background:#fff;border:1px solid #e4e7ef;border-top:3px solid var(--red);border-radius:10px;overflow:hidden;margin-bottom:16px;box-shadow:0 1px 4px rgba(0,0,0,.05);min-height:200px}
.cpr-banner-media{position:relative;background:#0f172a center/cover no-repeat;overflow:hidden}
.cpr-banner-media::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent 75%,rgba(255,255,255,.04) 100%);pointer-events:none}
.cpr-banner-fallback{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font:600 110px/1 var(--font-display),serif;color:rgba(255,255,255,.08);letter-spacing:.04em;text-transform:uppercase}
.cpr-banner-info{padding:22px 26px;display:flex;flex-direction:column;justify-content:center;gap:10px;min-width:0}
.cpr-banner-eyebrow{font-size:10px;font-weight:700;color:#c72030;letter-spacing:.16em;text-transform:uppercase}
.cpr-banner-name{font-family:var(--font-display);font-size:38px;font-weight:600;color:#0f172a;letter-spacing:-.015em;line-height:1.05;margin:0}
.cpr-banner-name em{font-style:italic;font-weight:400;color:#64748b;font-size:24px;letter-spacing:.01em;margin-left:8px}
.cpr-banner-meta{display:flex;flex-wrap:wrap;gap:10px;margin-top:6px}
.cpr-banner-chip{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:600;background:#f8fafc;border:1px solid #e4e7ef;color:#475569;font-family:var(--font-body)}
.cpr-banner-chip strong{color:#0f172a;font-weight:700}
.cpr-banner-chip.sov{background:#fef2f2;border-color:#fecaca;color:#b91c1c}
.cpr-banner-chip.sov strong{color:#7f1d1d}
.cpr-banner-attr{font-size:9px;color:#94a3b8;letter-spacing:.06em;text-transform:uppercase;margin-top:4px}
@media(max-width:760px){.cpr-banner{grid-template-columns:1fr}.cpr-banner-media{min-height:160px}.cpr-banner-name{font-size:30px}.cpr-banner-name em{font-size:18px}}
.cp-tab:hover{color:#0f172a}
.cp-tab.active{color:#c72030;border-bottom-color:#c72030;font-weight:600}
.cp-panel{animation:fadeIn .25s ease}

/* NDP cards */
.ndp-pillar{padding:12px 14px;border-radius:8px;border-left:3px solid var(--pc,#c72030);background:#fafbfc;border:1px solid #e4e7ef;border-left-width:3px}
.ndp-target-row{display:flex;justify-content:space-between;align-items:center;padding:9px 0;border-bottom:1px solid #f1f3f8}
.ndp-target-row:last-child{border-bottom:none}
.ndp-target-label{font-size:13px;color:#475569}
.ndp-target-val{font-family:var(--font-mono);font-size:13px;color:#0f172a;font-weight:500}

/* Opportunity cards */
.opp-card{background:#fff;border:1px solid #e4e7ef;border-radius:10px;overflow:hidden;box-shadow:0 1px 4px rgba(0,0,0,.05);transition:all .2s}
.opp-card:hover{border-color:rgba(199,32,48,.3);box-shadow:0 4px 16px rgba(199,32,48,.08);transform:translateY(-2px)}
.opp-card-header{padding:16px 18px 12px;border-bottom:1px solid #f0f2f7}
.opp-card-sector{font-size:9px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:3px 9px;border-radius:100px;display:inline-block;margin-bottom:8px}
.opp-card-name{font-family:var(--font-display);font-size:16px;font-weight:600;color:#0f172a;line-height:1.35}
.opp-card-body{padding:14px 18px}
.opp-meta{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:12px}
.opp-meta-item .oml{font-size:9px;color:#94a3b8;font-weight:600;letter-spacing:.1em;text-transform:uppercase}
.opp-meta-item .omv{font-size:13px;color:#0f172a;font-weight:500;margin-top:2px}
.opp-card-footer{padding:10px 18px;background:#fafbfc;border-top:1px solid #f0f2f7;display:flex;justify-content:space-between;align-items:center}
.opp-stage-bar{height:4px;border-radius:99px;background:#e4e7ef;margin-top:8px;overflow:hidden}
.opp-stage-fill{height:100%;border-radius:99px;background:linear-gradient(90deg,#c72030,#fd6925)}

/* Map popup override */
.leaflet-popup-content-wrapper{border-radius:8px!important;box-shadow:0 4px 20px rgba(0,0,0,.15)!important;font-family:var(--font-body)!important}
.leaflet-popup-content{font-size:12px;color:#0f172a;line-height:1.5;margin:10px 14px!important}
.lp-name{font-weight:600;font-size:14px;margin-bottom:4px;font-family:var(--font-display)}
.lp-capex{color:#c72030;font-family:var(--font-mono);font-weight:500}

/* Country Perspective */
.cp-tabs{display:flex;gap:0;margin-bottom:24px;border-bottom:2px solid #e4e7ef;flex-wrap:wrap}
.cp-tab{padding:10px 20px;background:transparent;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;cursor:pointer;font-family:var(--font-body);font-size:13px;font-weight:500;color:#94a3b8;letter-spacing:.01em;transition:all .18s;white-space:nowrap}
.cpr-banner{display:grid;grid-template-columns:minmax(0,340px) minmax(0,1fr);gap:0;background:#fff;border:1px solid #e4e7ef;border-top:3px solid var(--red);border-radius:10px;overflow:hidden;margin-bottom:16px;box-shadow:0 1px 4px rgba(0,0,0,.05);min-height:200px}
.cpr-banner-media{position:relative;background:#0f172a center/cover no-repeat;overflow:hidden}
.cpr-banner-media::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent 75%,rgba(255,255,255,.04) 100%);pointer-events:none}
.cpr-banner-fallback{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font:600 110px/1 var(--font-display),serif;color:rgba(255,255,255,.08);letter-spacing:.04em;text-transform:uppercase}
.cpr-banner-info{padding:22px 26px;display:flex;flex-direction:column;justify-content:center;gap:10px;min-width:0}
.cpr-banner-eyebrow{font-size:10px;font-weight:700;color:#c72030;letter-spacing:.16em;text-transform:uppercase}
.cpr-banner-name{font-family:var(--font-display);font-size:38px;font-weight:600;color:#0f172a;letter-spacing:-.015em;line-height:1.05;margin:0}
.cpr-banner-name em{font-style:italic;font-weight:400;color:#64748b;font-size:24px;letter-spacing:.01em;margin-left:8px}
.cpr-banner-meta{display:flex;flex-wrap:wrap;gap:10px;margin-top:6px}
.cpr-banner-chip{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:600;background:#f8fafc;border:1px solid #e4e7ef;color:#475569;font-family:var(--font-body)}
.cpr-banner-chip strong{color:#0f172a;font-weight:700}
.cpr-banner-chip.sov{background:#fef2f2;border-color:#fecaca;color:#b91c1c}
.cpr-banner-chip.sov strong{color:#7f1d1d}
.cpr-banner-attr{font-size:9px;color:#94a3b8;letter-spacing:.06em;text-transform:uppercase;margin-top:4px}
@media(max-width:760px){.cpr-banner{grid-template-columns:1fr}.cpr-banner-media{min-height:160px}.cpr-banner-name{font-size:30px}.cpr-banner-name em{font-size:18px}}
.cp-tab:hover{color:#0f172a}
.cp-tab.active{color:#c72030;border-bottom-color:#c72030;font-weight:600}
.cp-panel{animation:fadeIn .25s ease}
/* News */
.news-filter-btn{background:transparent;border:1px solid #e4e7ef;color:#94a3b8;transition:all .18s;outline:none !important;box-shadow:none !important;-webkit-tap-highlight-color:transparent}
.news-filter-btn:focus,.news-filter-btn:focus-visible,.news-filter-btn:focus-within,.news-filter-btn:active,.news-filter-btn:hover{outline:0 !important;outline-offset:0 !important;box-shadow:none !important}
.news-filter-btn::-moz-focus-inner{border:0 !important}
.news-filter-btn.active{background:rgba(199,32,48,.1);border-color:rgba(199,32,48,.35);color:#c72030}
@keyframes spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}

/* ── Auth Modal ── */
#auth-overlay{position:fixed;inset:0;background:rgba(10,10,10,.72);z-index:9000;display:none;align-items:center;justify-content:center;backdrop-filter:blur(6px)}
#auth-overlay.open{display:flex}
.auth-card{background:#fff;border-radius:16px;width:100%;max-width:480px;margin:16px;overflow:hidden;box-shadow:0 32px 80px rgba(0,0,0,.35)}
.auth-header{background:#0a0a0a;padding:28px 32px 22px;position:relative}
.auth-header-logo{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.auth-type-tabs{display:flex;gap:0;border-bottom:1px solid rgba(255,255,255,.12);margin:-2px 0 0}
.auth-type-tab{padding:9px 18px;background:transparent;border:none;border-bottom:2px solid transparent;color:rgba(255,255,255,.45);font-size:12px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;cursor:pointer;font-family:var(--font-body);transition:all .18s;white-space:nowrap}
.auth-type-tab.active{color:#ffffff;border-bottom-color:#c72030}
.auth-body{padding:28px 32px 24px}
.auth-field{margin-bottom:14px}
.auth-field label{display:block;font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#475569;margin-bottom:5px}
.auth-field input,.auth-field select{width:100%;padding:10px 13px;border:1.5px solid #e4e7ef;border-radius:8px;font-size:13px;font-family:var(--font-body);color:#0f172a;background:#f8fafc;outline:none;transition:border .18s;box-sizing:border-box}
.auth-field input:focus,.auth-field select:focus{border-color:#c72030;background:#fff}
.auth-btn{width:100%;padding:12px;border-radius:8px;border:none;font-size:13px;font-weight:700;font-family:var(--font-body);cursor:pointer;letter-spacing:.04em;text-transform:uppercase;transition:all .18s;margin-top:4px}
.auth-btn-primary{background:#c72030;color:#fff}
.auth-btn-primary:hover{background:#a81a28}
.auth-btn-admin{background:#0a0a0a;color:#fff}
.auth-btn-admin:hover{background:#1a1a1a}
.auth-divider{text-align:center;color:#94a3b8;font-size:11px;margin:14px 0;position:relative}
.auth-divider::before,.auth-divider::after{content:'';position:absolute;top:50%;width:42%;height:1px;background:#e4e7ef}
.auth-divider::before{left:0}.auth-divider::after{right:0}
.auth-error{background:#fff5f5;border:1px solid #fecaca;border-radius:7px;padding:8px 12px;font-size:12px;color:#c72030;margin-bottom:12px;display:none}
.auth-success{background:#f0fdf4;border:1px solid #bbf7d0;border-radius:7px;padding:8px 12px;font-size:12px;color:#16a34a;margin-bottom:12px;display:none}
/* Topbar user chip */
.topbar-user-chip{display:flex;align-items:center;gap:7px;padding:5px 12px 5px 6px;background:rgba(199,32,48,.08);border:1px solid rgba(199,32,48,.2);border-radius:100px;cursor:pointer;transition:all .18s}
.topbar-user-chip:hover{background:rgba(199,32,48,.15)}
.topbar-user-avatar{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:#fff}
.topbar-user-name{font-size:12px;font-weight:600;color:#0f172a}
.topbar-user-badge{font-size:9px;font-weight:700;padding:1px 6px;border-radius:100px;letter-spacing:.06em;text-transform:uppercase}
.badge-admin{background:#0a0a0a;color:#fff}
.badge-member{background:rgba(199,32,48,.12);color:#c72030}
/* Sign-in buttons in topbar */
.auth-topbar-btns{display:flex;gap:7px;align-items:center}

/* AI Document Extractor */
.ai-extract-box{background:#f8fafc;border:1.5px dashed #c72030;border-radius:12px;padding:24px;margin-bottom:22px;position:relative;overflow:hidden;transition:border-color .2s}
.ai-extract-box:hover{border-color:#c72030;background:#f1f5f9}
.ai-extract-box.dragging{border-color:#c72030;background:#e0f2fe}
.ai-extract-glow{position:absolute;inset:0;background:radial-gradient(ellipse 60% 60% at 50% 0%,rgba(199,32,48,.12),transparent 70%);pointer-events:none}
.ai-extract-icon{width:48px;height:48px;border-radius:12px;background:rgba(199,32,48,.15);border:1px solid rgba(199,32,48,.3);display:flex;align-items:center;justify-content:center;font-size:22px;margin:0 auto 12px;flex-shrink:0}
.ai-extract-progress{height:3px;background:rgba(255,255,255,.1);border-radius:100px;overflow:hidden;margin:14px 0 0}
.ai-extract-bar{height:100%;background:linear-gradient(90deg,#c72030,#ff6b6b);border-radius:100px;width:0;transition:width .4s ease}
.ai-field-highlight{animation:aiHighlight .8s ease-out;border-color:#c72030!important;background:#fff5f5!important}
@keyframes aiHighlight{0%{box-shadow:0 0 0 3px rgba(199,32,48,.4)}100%{box-shadow:none}}
.ai-extract-results{background:#f0fdf4;border:1px solid #bbf7d0;border-radius:8px;padding:12px 14px;margin-top:12px;font-size:12px;color:#166534;display:none}
.ai-extract-warning{background:#fff8f0;border:1px solid #fed7aa;border-radius:8px;padding:10px 12px;margin-top:10px;font-size:12px;color:#92400e;display:none}


/* ── SA Projects Platform scoped styles — LIGHT THEME ── */

/* Scoped CSS variables — light / white with Aha red accent */
#page-saprojects {
  --bg:#FFFFFF; --surface:#FFFFFF; --surface2:#F8FAFC;
  --border:#E4E7EF; --border-soft:rgba(0,0,0,.07);
  --text:#0F172A; --muted:#64748B; --muted-light:#94A3B8;
  --accent:#C72030; --accent2:#C72030;
  --accent-bg:rgba(199,32,48,.06); --accent-bg2:rgba(199,32,48,.10);
  --c-saic:#0284C7; --c-reipppp:#16A34A; --c-ci:#D97706;
  --c-infra:#7C3AED; --c-minerals:#B45309; --c-dffe:#EA580C; --c-cp:#0D9488;
  --panel-w:320px;
  --shadow:0 2px 12px rgba(0,0,0,.08);
  --shadow-lg:0 8px 32px rgba(0,0,0,.12);
}

/* ── LAYOUT ── */
#page-saprojects .sa-wrap { display:flex; flex:1; overflow:hidden; position:relative; background:var(--bg); }

/* ── LEFT PANEL ── */
#page-saprojects .panel {
  width:var(--panel-w); background:var(--surface);
  border-right:1px solid var(--border);
  display:flex; flex-direction:column; flex-shrink:0; overflow:hidden;
  box-shadow:2px 0 8px rgba(0,0,0,.04);
}
#page-saprojects .panel-top {
  padding:12px 14px 10px; border-bottom:1px solid var(--border); flex-shrink:0;
  background:var(--surface);
}

/* ── SEARCH ── */
#page-saprojects .srch { position:relative; margin-bottom:10px; }
#page-saprojects .srch-ico { position:absolute; left:9px; top:50%; transform:translateY(-50%); color:var(--muted); font-size:13px; pointer-events:none; }
#page-saprojects .srch input {
  width:100%; background:var(--surface2); border:1.5px solid var(--border);
  color:var(--text); padding:8px 10px 8px 30px; border-radius:8px;
  font-family:'Space Grotesk',sans-serif; font-size:12px; outline:none; transition:border-color .18s;
}
#page-saprojects .srch input::placeholder { color:var(--muted-light); }
#page-saprojects .srch input:focus { border-color:var(--accent); background:#FFF; }

/* ── SOURCE TABS ── */
#page-saprojects .stabs { display:flex; gap:3px; margin-bottom:10px; flex-wrap:wrap; }
#page-saprojects .stab {
  flex:1; min-width:36px; padding:5px 3px; background:var(--surface2); border:1.5px solid var(--border);
  border-radius:6px; font-size:9px; font-weight:700; text-transform:uppercase; letter-spacing:.4px;
  cursor:pointer; text-align:center; color:var(--muted); transition:all .14s; white-space:nowrap;
}
#page-saprojects .stab:hover { border-color:var(--accent); color:var(--accent); background:var(--accent-bg); }
#page-saprojects .stab[data-s="all"].on { border-color:var(--accent); color:var(--accent); background:var(--accent-bg); }
#page-saprojects .stab[data-s="reipppp"].on { border-color:var(--c-reipppp); color:var(--c-reipppp); background:rgba(22,163,74,.08); }
#page-saprojects .stab[data-s="ci"].on { border-color:var(--c-ci); color:var(--c-ci); background:rgba(217,119,6,.08); }
#page-saprojects .stab[data-s="infra"].on { border-color:var(--c-infra); color:var(--c-infra); background:rgba(124,58,237,.08); }
#page-saprojects .stab[data-s="minerals"].on { border-color:var(--c-minerals); color:var(--c-minerals); background:rgba(180,83,9,.08); }
#page-saprojects .stab[data-s="saic"].on { border-color:var(--c-saic); color:var(--c-saic); background:rgba(2,132,199,.08); }
#page-saprojects .stab[data-s="dffe"].on { border-color:var(--c-dffe); color:var(--c-dffe); background:rgba(234,88,12,.08); }
#page-saprojects .stab[data-s="cp"].on { border-color:var(--c-cp); color:var(--c-cp); background:rgba(13,148,136,.08); }

/* ── FILTER CHIPS ── */
#page-saprojects .flabel { font-size:8.5px; text-transform:uppercase; letter-spacing:1.2px; color:var(--muted); margin-bottom:6px; }
#page-saprojects .chips { display:flex; flex-wrap:wrap; gap:3px; }
#page-saprojects .chip { padding:2px 8px; border-radius:20px; font-size:9.5px; font-weight:600; cursor:pointer; border:1.5px solid transparent; opacity:.45; transition:all .13s; white-space:nowrap; }
#page-saprojects .chip.on { opacity:1; border-color:currentColor; }

/* ── PROJECT COUNT BADGE ── */
#page-saprojects .cbadge { font-size:10px; color:var(--muted); padding:6px 14px 4px; flex-shrink:0; border-bottom:1px solid var(--border); background:var(--surface2); }

/* ── PROJECT LIST ── */
#page-saprojects .plist { flex:1; overflow-y:auto; padding:2px 0; background:var(--surface); }
#page-saprojects .plist::-webkit-scrollbar { width:4px; }
#page-saprojects .plist::-webkit-scrollbar-thumb { background:var(--border); border-radius:2px; }
#page-saprojects .pi { padding:9px 14px; border-bottom:1px solid var(--border); cursor:pointer; transition:background .12s; position:relative; }
#page-saprojects .pi:hover { background:var(--surface2); }
#page-saprojects .pi.sel { background:rgba(199,32,48,.04); }
#page-saprojects .pi.sel::before { content:''; position:absolute; left:0; top:0; bottom:0; width:3px; border-radius:0 2px 2px 0; }
#page-saprojects .pi[data-src="saic"].sel::before { background:var(--c-saic); }
#page-saprojects .pi[data-src="reipppp"].sel::before { background:var(--c-reipppp); }
#page-saprojects .pi[data-src="ci"].sel::before { background:var(--c-ci); }
#page-saprojects .pi[data-src="infra"].sel::before { background:var(--c-infra); }
#page-saprojects .pi[data-src="minerals"].sel::before { background:var(--c-minerals); }
#page-saprojects .pi[data-src="dffe"].sel::before { background:var(--c-dffe); }
#page-saprojects .pi[data-src="cp"].sel::before { background:var(--c-cp); }
#page-saprojects .pi-row1 { display:flex; align-items:flex-start; gap:5px; margin-bottom:2px; }
#page-saprojects .pi-ico { flex-shrink:0; margin-top:2px; }
#page-saprojects .pi-name { font-size:11.5px; font-weight:600; line-height:1.3; flex:1; color:var(--text); }
#page-saprojects .pi-tag { font-size:8px; font-weight:700; padding:2px 5px; border-radius:3px; text-transform:uppercase; letter-spacing:.3px; flex-shrink:0; margin-top:1px; color:#fff; }
#page-saprojects .pi-row2 { display:flex; justify-content:space-between; font-size:9.5px; }
#page-saprojects .pi-loc { color:var(--muted); flex:1; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; padding-right:6px; }
#page-saprojects .pi-val { color:var(--accent); font-weight:700; white-space:nowrap; }
#page-saprojects .no-res { padding:28px 14px; text-align:center; color:var(--muted); font-size:12px; }

/* ── MAP CONTROLS (satellite/labels) ── */
#page-saprojects .map-controls { display:flex; gap:6px; align-items:center; }
#page-saprojects .ctrl-btn {
  display:flex; align-items:center; gap:5px; padding:5px 11px;
  background:#F8FAFC; border:1.5px solid var(--border); border-radius:7px;
  cursor:pointer; transition:all .18s; font-family:'Space Grotesk',sans-serif;
  font-size:10.5px; font-weight:600; color:var(--muted); white-space:nowrap;
}
#page-saprojects .ctrl-btn:hover { border-color:var(--accent); color:var(--accent); }
#page-saprojects .ctrl-btn.on { background:var(--accent-bg); border-color:var(--accent); color:var(--accent); }
#page-saprojects .ctrl-dot { width:7px; height:7px; border-radius:50%; background:var(--muted); transition:background .18s; }
#page-saprojects .ctrl-btn.on .ctrl-dot { background:var(--accent); }

/* ── DRAWER (right panel detail) ── */
#page-saprojects .drawer {
  position:absolute; right:0; top:0; bottom:0; width:320px; background:var(--surface);
  border-left:1px solid var(--border); display:flex; flex-direction:column;
  transform:translateX(100%); transition:transform .28s cubic-bezier(.4,0,.2,1);
  z-index:400; box-shadow:var(--shadow-lg);
}
#page-saprojects .drawer.open { transform:translateX(0); }
#page-saprojects .drtop { padding:14px 16px 10px; border-bottom:1px solid var(--border); flex-shrink:0; background:var(--surface); }
#page-saprojects .dr-close { display:flex; justify-content:flex-end; margin-bottom:8px; }
#page-saprojects .xbtn { background:var(--surface2); border:1px solid var(--border); color:var(--muted); width:28px; height:28px; border-radius:6px; cursor:pointer; font-size:13px; display:flex; align-items:center; justify-content:center; transition:all .15s; }
#page-saprojects .xbtn:hover { background:rgba(199,32,48,.08); border-color:var(--accent); color:var(--accent); }
#page-saprojects .dr-badge { display:inline-block; font-size:9px; font-weight:700; padding:2px 8px; border-radius:4px; text-transform:uppercase; letter-spacing:.4px; margin-bottom:6px; color:#fff; }
#page-saprojects .dr-title { font-family:'Syne',sans-serif; font-size:16px; font-weight:700; line-height:1.3; color:var(--text); }
#page-saprojects .dr-div { height:1px; background:var(--border); margin-top:10px; }
#page-saprojects .drbody { flex:1; overflow-y:auto; padding:14px 16px; }
#page-saprojects .dg { display:grid; grid-template-columns:1fr 1fr; gap:8px; margin-bottom:14px; }
#page-saprojects .dg-item { background:var(--surface2); border:1px solid var(--border); border-radius:7px; padding:8px 10px; }
#page-saprojects .dg-label { font-size:9px; text-transform:uppercase; letter-spacing:.8px; color:var(--muted); margin-bottom:3px; }
#page-saprojects .dg-val { font-size:13px; font-weight:600; color:var(--text); }
#page-saprojects .dsect { font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:.8px; color:var(--muted); margin-bottom:6px; margin-top:12px; }
#page-saprojects .ddesc { font-size:12px; line-height:1.65; color:var(--text); }
#page-saprojects .coordbox { display:flex; align-items:center; gap:8px; background:var(--surface2); border:1px solid var(--border); border-radius:7px; padding:8px 10px; font-size:11px; color:var(--text); font-family:monospace; }
#page-saprojects .copybtn { margin-left:auto; padding:3px 10px; background:var(--accent-bg); border:1px solid var(--accent); color:var(--accent); border-radius:4px; font-size:9px; font-weight:700; letter-spacing:.6px; cursor:pointer; transition:all .15s; }
#page-saprojects .copybtn:hover { background:var(--accent); color:#fff; }
#page-saprojects .centrebtn { width:100%; margin-top:12px; padding:9px; background:var(--accent); color:#fff; border:none; border-radius:8px; font-size:12px; font-weight:700; cursor:pointer; transition:opacity .15s; font-family:'Space Grotesk',sans-serif; }
#page-saprojects .centrebtn:hover { opacity:.88; }

/* ── SATELLITE INFO BOX ── */
#page-saprojects .sat-info { background:rgba(199,32,48,.05); border:1px solid rgba(199,32,48,.2); border-radius:8px; padding:10px 12px; margin-bottom:12px; display:none; }
#page-saprojects .sat-info-title { font-size:11px; font-weight:700; color:var(--accent); margin-bottom:5px; }
#page-saprojects .sat-info-body { font-size:10.5px; line-height:1.55; color:var(--text); }
#page-saprojects .sat-info-coords { font-family:monospace; font-size:10px; color:var(--muted); margin-top:6px; }

/* ── LEGEND ── */
#page-saprojects .legpanel {
  position:absolute; bottom:16px; left:330px; background:var(--surface);
  border:1px solid var(--border); border-radius:10px; padding:10px 14px;
  font-size:10px; box-shadow:var(--shadow); z-index:300; min-width:180px;
}
#page-saprojects .legtitle { font-size:9px; font-weight:700; text-transform:uppercase; letter-spacing:.8px; color:var(--muted); margin-bottom:7px; }
#page-saprojects .legitem { display:flex; align-items:center; gap:7px; margin-bottom:5px; font-size:10.5px; color:var(--text); font-weight:500; }

/* ── TOAST NOTIFICATIONS ── */
#page-saprojects .toast {
  position:fixed; bottom:20px; right:20px; background:var(--text); color:#fff;
  padding:9px 16px; border-radius:8px; font-size:12px; font-weight:600;
  opacity:0; transition:opacity .3s; z-index:9999; pointer-events:none;
}
#page-saprojects .toast.show { opacity:1; }
#page-saprojects .sat-toast { position:absolute; bottom:16px; right:16px; z-index:600; pointer-events:none; }
#page-saprojects .sat-toast-inner { background:var(--text); color:#fff; padding:7px 12px; border-radius:6px; font-size:11px; font-weight:600; opacity:0; transition:opacity .3s; }

/* ── LEAFLET POPUP overrides for light theme ── */
#page-saprojects .leaflet-popup-content-wrapper { background:#fff; border:1px solid var(--border); border-radius:10px; box-shadow:var(--shadow); color:var(--text); }
#page-saprojects .leaflet-popup-tip { background:#fff; }
#page-saprojects .leaflet-popup-content { margin:10px 14px; font-family:'Space Grotesk',sans-serif; font-size:12px; }

/* ── CLUSTER MARKERS ── */
.marker-cluster-small, .marker-cluster-medium, .marker-cluster-large { border-radius:50% !important; }
.marker-cluster-small div { background:rgba(199,32,48,.85) !important; color:#fff !important; font-weight:700 !important; }
.marker-cluster-medium div { background:rgba(199,32,48,.9) !important; color:#fff !important; font-weight:700 !important; }
.marker-cluster-large div { background:rgba(180,20,20,.95) !important; color:#fff !important; font-weight:700 !important; }

/* ── SA Projects: tabbed page with embedded map ── */
/* The map tab pane gets an explicit height so the Leaflet container has dimensions. */
#sa-pane-map { display:none; }
#sa-pane-map.active { display:flex; flex-direction:column; }
#sa-pane-map .sa-map-host { display:flex; flex-direction:column; flex:1; min-height:0; height:calc(100vh - 240px); min-height:600px; border:1px solid var(--border); border-radius:12px; overflow:hidden; background:#fff; box-shadow:0 4px 14px rgba(15,23,42,.06); }
#page-saprojects .sa-wrap { display:flex; flex:1; overflow:hidden; position:relative; background:#fff; min-height:0; }
#page-saprojects .panel { height:100%; }
#page-saprojects #sa-map { height:100%; flex:1; }
/* Map toolbar above the map area */
.sa-map-toolbar { display:flex; align-items:center; gap:12px; flex-wrap:wrap; padding:12px 16px; background:linear-gradient(135deg,#0b3d2e 0%,#1a1d2e 100%); border-bottom:1px solid rgba(255,255,255,.08); flex-shrink:0; }
.sa-map-toolbar .sa-map-stats { display:flex; gap:0; align-items:center; margin-left:auto; }
.sa-map-toolbar .sa-map-stats > div { text-align:center; padding:0 14px; border-left:1px solid rgba(255,255,255,.10); }
.sa-map-toolbar .sa-map-stats > div:first-child { border-left:none; }
.sa-map-toolbar .hstat-val { font-size:16px; font-weight:700; font-family:var(--font-display); line-height:1.1; }
.sa-map-toolbar .hstat-lbl { font-size:8.5px; color:rgba(255,255,255,.55); text-transform:uppercase; letter-spacing:.08em; margin-top:2px; }
/* Leaflet attribution on light tiles */
#page-saprojects .leaflet-control-attribution { background:rgba(255,255,255,.85) !important; color:#555 !important; }




/* ── Trust signal styles ────────────────────────────────────────── */
.ts-conf-badge{display:inline-flex;align-items:center;gap:4px;font-size:9px;font-weight:700;padding:2px 8px;border-radius:20px;border-width:1px;border-style:solid;letter-spacing:.04em;white-space:nowrap}
.ts-source-pill{display:inline-flex;align-items:center;font-size:9px;font-weight:700;padding:2px 7px;border-radius:4px;letter-spacing:.04em}
.ts-updated{font-size:10px;color:#94a3b8;margin-top:5px;display:flex;align-items:center;gap:4px}
.ts-verify-link{font-size:9px;color:#c72030;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:3px;padding:0;background:none;border:none;font-family:var(--font-body)}
.ts-verify-link:hover{text-decoration:underline;color:#a01020}
#ts-verify-overlay{position:fixed;inset:0;background:rgba(10,10,10,.55);z-index:9800;display:none;align-items:center;justify-content:center;backdrop-filter:blur(4px)}
#ts-verify-overlay.open{display:flex}
#ts-verify-modal{background:#fff;border-radius:14px;width:min(620px,94vw);max-height:85vh;overflow-y:auto;box-shadow:0 24px 64px rgba(0,0,0,.22);display:flex;flex-direction:column;animation:ts-modal-in .18s ease-out}
.ts-vm-header{padding:20px 24px 16px;border-bottom:1px solid #e4e7ef;position:sticky;top:0;background:#fff;z-index:2;display:flex;align-items:center;justify-content:space-between}
.ts-vm-body{padding:20px 24px;display:flex;flex-direction:column;gap:18px}
.ts-vm-section-label{font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#c72030;margin-bottom:8px}
.ts-vm-row{display:flex;gap:8px;justify-content:space-between;align-items:flex-start;padding:8px 0;border-bottom:1px solid #f0f2f7;font-size:12px}
.ts-vm-row:last-child{border-bottom:none}
.ts-json-toggle{cursor:pointer;font-size:11px;font-weight:600;color:#475569;display:flex;align-items:center;gap:5px;padding:7px 12px;background:#f8fafc;border:1px solid #e4e7ef;border-radius:7px;width:100%;text-align:left;font-family:var(--font-body)}
.ts-json-body{display:none;background:#0f172a;border-radius:7px;padding:14px;margin-top:8px;overflow-x:auto}
.ts-json-body.open{display:block}
.ts-json-body pre{font-family:var(--font-mono,monospace);font-size:11px;color:#e2e8f0;white-space:pre-wrap;word-break:break-all;margin:0}
.ts-disc-row{display:flex;flex-direction:column;gap:6px;padding:10px 14px;background:#fff8e1;border:1px solid #fde68a;border-radius:8px}
.pl-card-new-badge{position:absolute;top:-1px;left:-1px;background:#c72030;color:#fff;font-size:8px;font-weight:800;padding:2px 7px;border-radius:10px 0 8px 0;letter-spacing:.06em;z-index:2;text-transform:uppercase}
@keyframes ts-modal-in{from{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}

/* ── Cache / Live-data UI ───────────────────────────────────────── */
#pipeline-live-bar{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px;background:#fff;border:1px solid #e4e7ef;border-radius:8px;padding:9px 16px;margin-bottom:14px;font-size:12px;font-family:var(--font-body)}
#plb-dot{width:8px;height:8px;border-radius:50%;background:#94a3b8;display:inline-block;flex-shrink:0;transition:background .4s}
#plb-text{color:#64748b}
#plb-refresh-btn{padding:4px 12px;border:1px solid #e4e7ef;border-radius:6px;background:#f8fafc;font-size:11px;font-weight:600;color:#475569;cursor:pointer;font-family:var(--font-body)}
#plb-refresh-btn:hover{background:#f1f5f9}
#pipeline-stale-banner{display:none;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;background:#fff8e1;border:1px solid #f59e0b;border-radius:8px;padding:9px 16px;margin-bottom:14px;font-size:12px;font-family:var(--font-body)}
.aha-cache-changed{animation:aha-card-glow 700ms ease-out forwards}
.aha-cache-new{animation:aha-card-appear 600ms ease-out forwards}
@keyframes aha-card-glow{0%{box-shadow:0 0 0 3px rgba(199,32,48,.5)}100%{box-shadow:none}}
@keyframes aha-card-appear{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}
@keyframes plb-pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(1.4)}}
.plb-pulsing{animation:plb-pulse 2s ease-in-out infinite}
#adm-cache-panel .cache-tbl{width:100%;border-collapse:collapse;font-size:12px}
#adm-cache-panel .cache-tbl th{padding:8px 12px;text-align:left;font-size:10px;font-weight:700;color:#94a3b8;text-transform:uppercase;letter-spacing:.08em;background:#f8fafc;border-bottom:1px solid #e4e7ef}
#adm-cache-panel .cache-tbl td{padding:9px 12px;border-bottom:1px solid #f0f2f7;color:#475569;vertical-align:middle}
#adm-cache-panel .cache-tbl tr:last-child td{border-bottom:none}

/* ════════════════════════════════════════════════════════════════════
   COMPREHENSIVE MOBILE RESPONSIVENESS (supplementary block)
   Layered on top of the existing partial mobile rules above. Uses
   three breakpoints: 1024 (tablet), 768 (phone-landscape), 480 (small phone).
   Augments, doesn't replace.
   ════════════════════════════════════════════════════════════════════ */

/* Mobile sidebar backdrop — appears when sidebar is open on small screens.
   z-index is below the sidebar (which we bump to 1200) so the sidebar
   stays fully visible above this overlay. */
.sidebar-backdrop{display:none;position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:1100;animation:fadeIn .25s ease}
body.sidebar-open .sidebar-backdrop{display:block}

/* Belt-and-braces: when body.sidebar-open is set (which the toggle reliably
   does — proven because the backdrop appears), force the sidebar visible
   on top of everything. Uses body class (not .sidebar.open) so it's
   immune to specificity wars with the original 900px-breakpoint rules. */
body.sidebar-open .sidebar{
  transform:translateX(0) !important;
  z-index:1200 !important;
  visibility:visible !important;
  pointer-events:auto !important;
}

/* Floating mobile menu button. Hidden on desktop; hidden on mobile when
   the topbar is visible (which has its own hamburger); shown otherwise.
   The :has() check is a one-liner — on home page the topbar has
   display:none, so the floating button appears. */
.floating-menu-btn{display:none;position:fixed;top:12px;left:12px;z-index:160;width:44px;height:44px;border-radius:12px;background:#1a1d2e;color:#fff;border:none;font-size:22px;cursor:pointer;box-shadow:0 4px 14px rgba(0,0,0,.25);align-items:center;justify-content:center;line-height:1}
.floating-menu-btn:active{transform:scale(.95)}
@media (max-width: 1024px) {
  /* Show whenever the topbar is hidden (home page). */
  body:has(#topbar[style*="display:none"]) .floating-menu-btn{display:flex}
  /* When the sidebar is open, hide the button (the X is in the sidebar). */
  body.sidebar-open .floating-menu-btn{display:none}
}

/* ── Tablet (≤ 1024px) ── */
@media (max-width: 1024px) {
  .sidebar{transform:translateX(-100%);width:280px;box-shadow:4px 0 24px rgba(0,0,0,.18)}
  .sidebar.open{transform:translateX(0)}
  .main-area{margin-left:0}
  .menu-toggle{display:block !important;font-size:22px;padding:6px 10px;margin-right:4px}
  .topbar{padding:10px 16px}
  .page-content{padding:20px 18px;max-width:100%}
  .page.active{max-height:calc(100vh - 60px)}
  .grid-3,.grid-4,.grid-5{grid-template-columns:1fr 1fr}
  .page-title{font-size:32px;line-height:1.2}
  .kpi-value{font-size:26px}
  .topbar-info{display:none}
  .breadcrumb{font-size:12px}
}

/* ── Phone (≤ 768px) — the big collapse ── */
@media (max-width: 768px) {
  /* Layout */
  .topbar{padding:10px 14px;flex-wrap:wrap;gap:8px}
  .page-content{padding:18px 14px}
  /* Hide bulky topbar items, keep brand minimal */
  .topbar-info,.live-badge{display:none}
  .breadcrumb{font-size:11px;gap:4px}
  .breadcrumb .crumb-home{display:none}
  .breadcrumb .sep:first-of-type{display:none}

  /* Typography */
  .page-title{font-size:26px;letter-spacing:-.005em}
  .page-sub{font-size:13px;margin-bottom:18px;line-height:1.55}
  .page-eyebrow{font-size:9px}
  .section-title{font-size:20px}
  .section-label{font-size:9px;letter-spacing:.12em}

  /* All grids stack */
  .grid-2,.grid-3,.grid-4,.grid-5{grid-template-columns:1fr;gap:12px}

  /* Cards + KPI tighten */
  .card{padding:18px;border-radius:10px}
  .card-sm{padding:14px}
  .kpi{padding:14px 16px}
  .kpi-value{font-size:24px}
  .kpi-label{font-size:9px}
  .kpi-sub{font-size:10px}
  .btn{padding:8px 16px;font-size:11px}
  .btn-sm{padding:5px 12px;font-size:11px}

  /* Tender portal — country switcher tablets */
  #tender-country-switcher{gap:8px !important;margin:14px 0 6px !important}
  #tender-country-switcher .tender-tablet{padding:6px 12px 6px 6px !important}
  #tender-country-switcher .tender-tablet > div:first-child{width:44px !important;height:32px !important}
  #tender-country-switcher .tender-tablet > div:last-child > div:first-child{font-size:9px !important}
  #tender-country-switcher .tender-tablet > div:last-child > div:last-child{font-size:11px !important}

  /* Tender list + detail panel → stack vertically */
  .generic-tender-tab > div[style*="grid-template-columns:minmax"]{grid-template-columns:1fr !important;gap:12px !important}
  #satender-sa > div[style*="grid-template-columns"],
  #satender-tz > div[style*="grid-template-columns"]{grid-template-columns:1fr !important}
  /* Detail panels lose sticky behaviour on mobile (no room for it) */
  #ke-detail,#tz-detail,#sa-detail,#gh-detail,#ma-detail,#rw-detail,#wb-detail,#ted-detail{position:static !important;max-height:none !important}

  /* Stats strips — already responsive but tighten */
  [class*="-stats"]{grid-template-columns:repeat(2,1fr) !important;gap:8px !important}

  /* Filter rows — stack on small screens */
  [class*="quick-find"] [style*="grid-template-columns"],
  [style*="grid-template-columns:repeat(auto-fit"]{grid-template-columns:1fr !important}

  /* Modals — full-bleed with safe padding */
  [style*="position:fixed"][style*="inset:0"][style*="z-index:9999"] > div{
    max-width:100% !important;
    width:calc(100% - 24px) !important;
    margin:0 12px !important;
    max-height:calc(100vh - 24px) !important;
  }

  /* Tables — horizontal scroll wrapper */
  table{display:block;overflow-x:auto;white-space:nowrap;-webkit-overflow-scrolling:touch}

  /* Hero areas (homepage) */
  .hero-title{font-size:32px !important;line-height:1.15 !important}
  .hero-sub{font-size:14px !important}
  .hero{padding:28px 18px !important}

  /* Inline cards that used min-width:240/280 — let them shrink */
  [style*="min-width:240px"],[style*="min-width:280px"]{min-width:0 !important}

  /* Sidebar — full overlay on very small screens */
  .sidebar{width:84vw;max-width:300px}

  /* DR (Deal Room) tabs scroll horizontally */
  .dr-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;flex-wrap:nowrap}
  .dr-tab{flex-shrink:0}
}

/* ── Small phone (≤ 480px) ── */
@media (max-width: 480px) {
  .page-title{font-size:22px}
  .page-sub{font-size:12px}
  .section-title{font-size:18px}
  .kpi-value{font-size:22px}
  .topbar{padding:8px 12px}
  .page-content{padding:14px 10px}
  .card{padding:14px;border-radius:8px}
  .card-sm{padding:12px}
  .btn{padding:7px 14px;font-size:11px}
  /* Country tablets become tighter still */
  #tender-country-switcher .tender-tablet > div:last-child > div:last-child{display:none}  /* hide the long description, keep just the country name */
  /* Stats strips become single-column on phone-portrait */
  [class*="-stats"]{grid-template-columns:1fr !important}
}

/* Sidebar nav scrolls if too long for short viewports */
@media (max-height: 640px) {
  .sidebar .nav{overflow-y:auto;max-height:calc(100vh - 180px)}
}

/* iOS Safari bottom-bar safe area */
@supports (padding: max(0px)) {
  body{padding-bottom:env(safe-area-inset-bottom)}
}

/* ════════════════════════════════════════════════════════════════════
   Round-2 mobile fixes — caught from a 400px viewport screenshot:
   - Hero title still wrapping wider than viewport on small phones
   - Verify-email banner forcing single-line layout, pushes page width
   - Various inline absolute-positioned elements that need shrinking
   ════════════════════════════════════════════════════════════════════ */

@media (max-width: 768px) {
  /* Defensive overflow guards on every layout container */
  .main-area,.hero,.hero-content,.page,.page.active,.page-content,
  .topbar,.dr-content,.cpr-banner,.satp-row{max-width:100% !important;overflow-x:hidden}

  /* Hero title — bring down further so it never clips on phones */
  .hero-title{font-size:28px !important;line-height:1.15 !important;letter-spacing:-.005em !important}
  /* Drop the forced line break, but inject a space so "Meets" and "Africa's"
     don't smush into "MeetsAfrica's". */
  .hero-title br{display:none}
  .hero-title span::before{content:" "}

  /* Push the hero brand block to the right of the floating menu button so
     they don't overlap. The hamburger is at left:12px width:44px (= 56px).
     Add 48px of left padding so the AHA AFRICA logo + tagline start clear of it. */
  .hero-content > div:first-child{padding-left:48px}

  /* Verify-email banner — was single-line, now wraps cleanly */
  #verify-banner{padding:8px 12px !important;font-size:11px !important;line-height:1.5 !important;text-align:left !important}
  #verify-banner strong{display:block;margin-bottom:2px}
  #verify-banner button{font-size:10px !important;padding:3px 10px !important;margin-left:4px !important}

  /* Floating auth chip — keep small + away from menu button */
  #floating-auth{top:auto !important;bottom:14px !important;right:14px !important;flex-direction:column;gap:6px}
  #floating-auth button{font-size:10px !important;padding:6px 14px !important}

  /* Hero footer links row — never get pushed off-screen */
  .hero-content > div[style*="margin-top:24px"]{flex-wrap:wrap !important}

  /* CPR banner (Country Perspective hero) — stack image + text */
  .cpr-banner-name{font-size:22px !important;line-height:1.2 !important}
  .cpr-banner-name em{font-size:14px !important}

  /* Floating menu button — slight shift down so it doesn't sit on top of
     the verify-email banner when both visible */
  body:has(#verify-banner:not([style*="display:none"])) .floating-menu-btn{top:54px !important}
}

@media (max-width: 480px) {
  /* Even smaller titles on phone-portrait */
  .hero-title{font-size:23px !important}
  .hero-desc{font-size:13px !important;line-height:1.6 !important}
  .hero{padding:24px 14px !important}

  /* Topbar — drop more chrome on small phones */
  .topbar{padding:8px 10px !important}
  .breadcrumb .crumb-page{max-width:170px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:inline-block}

  /* All KPI/stats numbers tighter */
  .kpi-value{font-size:20px}
  [style*="font-size:32px"][style*="font-weight:700"],
  [style*="font-size:30px"][style*="font-weight:700"]{font-size:22px !important}
}

/* ════════════════════════════════════════════════════════════════════
   Round-3: defensive catch-all for inline-style overflow on every page.
   Targets common patterns by attribute selectors so we don't have to
   refactor 20K lines of HTML. Applied page-wide on phones.
   ════════════════════════════════════════════════════════════════════ */

@media (max-width: 768px) {
  /* Make ALL inline flex rows wrap by default. The only pages that
     intentionally don't wrap are dr-tabs (handled separately above) and
     the country switcher (which already wraps via flex-wrap:wrap inline). */
  .page-content div[style*="display:flex"]:not(.dr-tabs):not(#tender-country-switcher):not([style*="flex-wrap"]){flex-wrap:wrap}

  /* Multi-column inline grids → 1 column. This catches the inline
     `grid-template-columns:1fr 1fr 1fr` etc. that's sprinkled all over. */
  .page-content div[style*="grid-template-columns:repeat(3"],
  .page-content div[style*="grid-template-columns:repeat(4"],
  .page-content div[style*="grid-template-columns:repeat(5"],
  .page-content div[style*="grid-template-columns:1fr 1fr 1fr"],
  .page-content div[style*="grid-template-columns:1fr 1fr"]:not([class*="-stats"]){grid-template-columns:1fr !important}

  /* Inline min-width:300/350/400/420/500 etc. → unconstrained on mobile */
  [style*="min-width:300px"],[style*="min-width:320px"],[style*="min-width:340px"],
  [style*="min-width:350px"],[style*="min-width:360px"],[style*="min-width:380px"],
  [style*="min-width:400px"],[style*="min-width:420px"],[style*="min-width:450px"],
  [style*="min-width:500px"],[style*="min-width:520px"],[style*="min-width:600px"],
  [style*="min-width:720px"],[style*="min-width:800px"]{min-width:0 !important}

  /* Inline fixed-width sidebars / panels (width:300px+ etc) collapse */
  [style*="width:320px"],[style*="width:340px"],[style*="width:360px"],
  [style*="width:380px"],[style*="width:400px"],[style*="width:420px"],
  [style*="width:480px"]:not(.hero-visual):not([style*="max-width"]){width:auto !important;max-width:100% !important}

  /* Sticky sidebars / detail panels go static on mobile (no room) */
  [style*="position:sticky"]{position:static !important;max-height:none !important}

  /* Pricing cards — usually grid with 2-3 cols */
  #page-pricing div[style*="grid-template-columns"]{grid-template-columns:1fr !important}
  #page-pricing div[style*="display:flex"][style*="gap"]{flex-wrap:wrap}

  /* Admin panel cards/grids stack */
  #page-admin div[style*="grid-template-columns"]{grid-template-columns:1fr !important}

  /* Country Perspective featured-nation tablets row */
  #page-country div[style*="display:grid"][style*="repeat"]{grid-template-columns:repeat(2,1fr) !important;gap:10px !important}
  #page-country div[style*="display:flex"][style*="gap:28px"]{flex-wrap:wrap;gap:16px !important;padding:18px !important}

  /* Project Pipeline list — usually has wide rows with side panels */
  #page-pipeline div[style*="grid-template-columns"]{grid-template-columns:1fr !important}

  /* Toolkit / Project Preparation */
  #page-toolkit div[style*="grid-template-columns"]{grid-template-columns:1fr !important}

  /* Regional / SA / Tanzania infrastructure dashboards.
     NOTE: SA Infra Platform's actual element id is `page-saprojects`
     (with the trailing 's'). Both spellings included for safety. */
  #page-regional div[style*="grid-template-columns"],
  #page-saprojects div[style*="grid-template-columns"],
  #page-saproj div[style*="grid-template-columns"],
  #page-tanzania div[style*="grid-template-columns"]{grid-template-columns:1fr !important}

  /* SA + Tanzania heroes use `260px 1fr` (fixed flag + flex text). Stack on phone. */
  #page-saprojects div[style*="grid-template-columns:260px 1fr"],
  #page-tanzania   div[style*="grid-template-columns:260px 1fr"],
  #page-regional   div[style*="grid-template-columns:260px 1fr"]{
    grid-template-columns:1fr !important;
    padding:0 !important;
  }

  /* SA/Tanzania mini-stat strip (3 columns inside hero banner) — stack */
  #page-saprojects div[style*="grid-template-columns:repeat(3"],
  #page-tanzania   div[style*="grid-template-columns:repeat(3"],
  #page-regional   div[style*="grid-template-columns:repeat(3"]{
    grid-template-columns:repeat(3,1fr) !important;
    gap:8px !important;
  }

  /* SA/Tanzania content-with-sidebar layouts (main 2fr + sidebar 1fr) — stack */
  #page-saprojects div[style*="grid-template-columns:2fr 1fr"],
  #page-tanzania   div[style*="grid-template-columns:2fr 1fr"],
  #page-regional   div[style*="grid-template-columns:2fr 1fr"],
  #page-saprojects div[style*="grid-template-columns:3fr 1fr"],
  #page-tanzania   div[style*="grid-template-columns:3fr 1fr"]{
    grid-template-columns:1fr !important;
  }

  /* SA flag-tablet container with fixed min-height becomes shorter on phone */
  #page-saprojects div[style*="min-height:200px"],
  #page-tanzania   div[style*="min-height:200px"]{min-height:140px !important}

  /* Home-page stat strip — was cramped at 2-col. Horizontal scroll so each
     number ("$367.9B", "200+", "344") stays readable at full size. */
  .stat-strip{position:relative;padding:14px 14px !important;overflow-x:auto;-webkit-overflow-scrolling:touch}
  .stat-strip-inner{display:flex !important;grid-template-columns:none !important;gap:22px !important;min-width:max-content;padding:0 4px}
  .stat-item{flex:0 0 auto;min-width:130px}
  /* Right-edge fade so users see content goes off-screen */
  .stat-strip::after{content:'';position:absolute;right:0;top:0;bottom:0;width:32px;background:linear-gradient(90deg,transparent,#fff);pointer-events:none}

  /* ════════════════════════════════════════════════════════════
     UNIVERSAL: any multi-column inline `repeat(N,1fr)` grid → horizontal
     scroller on mobile. Catches all 26+ `repeat(3,1fr)`, 9× `repeat(4,1fr)`,
     9× `repeat(6,1fr)`, 5× `repeat(5,1fr)` instances across pages.
     Each card peeks ~80% viewport so users see swipe affordance.
     ════════════════════════════════════════════════════════════ */
  div[style*="grid-template-columns:repeat(3,1fr)"]:not(.stat-strip-inner),
  div[style*="grid-template-columns:repeat(4,1fr)"]:not(.stat-strip-inner),
  div[style*="grid-template-columns:repeat(5,1fr)"]:not(.stat-strip-inner),
  div[style*="grid-template-columns:repeat(6,1fr)"]:not(.stat-strip-inner),
  div[style*="grid-template-columns:repeat(9,1fr)"]:not(.stat-strip-inner),
  .feature-grid {
    display:flex !important;
    grid-template-columns:none !important;
    overflow-x:auto !important;
    -webkit-overflow-scrolling:touch;
    scroll-snap-type:x proximity;
    gap:12px !important;
    padding:8px 4px 14px !important;
    scrollbar-width:thin;
    scrollbar-color:rgba(199,32,48,.3) transparent;
    /* Allow the row to bleed out to the page edges so cards "drift" off-screen
       naturally instead of stopping at parent padding. */
    margin-left:-14px !important;
    margin-right:-14px !important;
  }
  div[style*="grid-template-columns:repeat(3,1fr)"]::-webkit-scrollbar,
  div[style*="grid-template-columns:repeat(4,1fr)"]::-webkit-scrollbar,
  div[style*="grid-template-columns:repeat(5,1fr)"]::-webkit-scrollbar,
  div[style*="grid-template-columns:repeat(6,1fr)"]::-webkit-scrollbar,
  div[style*="grid-template-columns:repeat(9,1fr)"]::-webkit-scrollbar,
  .feature-grid::-webkit-scrollbar { height:4px; }
  div[style*="grid-template-columns:repeat(3,1fr)"]::-webkit-scrollbar-thumb,
  div[style*="grid-template-columns:repeat(4,1fr)"]::-webkit-scrollbar-thumb,
  div[style*="grid-template-columns:repeat(5,1fr)"]::-webkit-scrollbar-thumb,
  div[style*="grid-template-columns:repeat(6,1fr)"]::-webkit-scrollbar-thumb,
  div[style*="grid-template-columns:repeat(9,1fr)"]::-webkit-scrollbar-thumb,
  .feature-grid::-webkit-scrollbar-thumb { background:rgba(199,32,48,.35);border-radius:2px; }

  /* Children of these horizontal carousels get fixed width so the row is
     forced wider than the viewport. flex:0 0 means don't grow/shrink. */
  div[style*="grid-template-columns:repeat(3,1fr)"] > *,
  div[style*="grid-template-columns:repeat(4,1fr)"] > *,
  div[style*="grid-template-columns:repeat(5,1fr)"] > *,
  div[style*="grid-template-columns:repeat(6,1fr)"] > *,
  div[style*="grid-template-columns:repeat(9,1fr)"] > *,
  .feature-grid > * {
    flex:0 0 78% !important;
    min-width:240px !important;
    max-width:320px !important;
    scroll-snap-align:start;
  }

  /* The asymmetric 2-col layout (1.05fr 1fr) — usually image + text, keep stacked */
  div[style*="grid-template-columns:1.05fr 1fr"]{grid-template-columns:1fr !important}
  /* 2-col repeat — stack, not scroll (only 2 items doesn't justify carousel) */
  div[style*="grid-template-columns:repeat(2,1fr)"]:not(.stat-strip-inner){
    grid-template-columns:1fr !important;
  }

  /* ════════════════════════════════════════════════════════════
     Inline flex stats strip used on the home page:
     <div style="display:flex;justify-content:center;border-radius:12px;
                 background:#fff;overflow:hidden">
       <div style="flex:1;text-align:center;padding:24px 16px">…</div>×N
     </div>
     This is the "500+ Active Members / 54 Countries / $367.9B Pipeline /
     344 DFI Mandates" strip. By default overflow:hidden + flex:1 prevents
     any horizontal scroll. Override on mobile to scroll smoothly.
     ════════════════════════════════════════════════════════════ */
  div[style*="display:flex"][style*="border-radius:12px"][style*="overflow:hidden"]:not(.stat-strip):not(.feature-grid){
    overflow-x:auto !important;
    overflow-y:hidden !important;
    justify-content:flex-start !important;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:thin;
    scrollbar-color:rgba(199,32,48,.3) transparent;
  }
  div[style*="display:flex"][style*="border-radius:12px"][style*="overflow:hidden"]:not(.stat-strip):not(.feature-grid)::-webkit-scrollbar{height:4px}
  div[style*="display:flex"][style*="border-radius:12px"][style*="overflow:hidden"]:not(.stat-strip):not(.feature-grid)::-webkit-scrollbar-thumb{background:rgba(199,32,48,.35);border-radius:2px}
  /* Children: was flex:1 (equal share), now fixed-width so the row spills. */
  div[style*="display:flex"][style*="border-radius:12px"][style*="overflow:hidden"]:not(.stat-strip):not(.feature-grid) > div[style*="text-align:center"]{
    flex:0 0 auto !important;
    min-width:160px !important;
  }

  /* AI page (chat-like layout) */
  #page-ai div[style*="grid-template-columns"]{grid-template-columns:1fr !important}

  /* Any iframe or visual that's wider than the viewport */
  iframe,canvas,svg{max-width:100% !important;height:auto}

  /* Images that have explicit width attributes — keep aspect */
  img[width]{max-width:100% !important;height:auto !important}

  /* Buttons inside flex rows shouldn't overflow */
  button{max-width:100%;white-space:normal;word-break:break-word}

  /* Long URLs / refs in tender detail panels — wrap instead of pushing width */
  [style*="word-break"],pre,code{word-break:break-all;overflow-wrap:anywhere}
}

@media (max-width: 480px) {
  /* Even tighter — Country Perspective tablets go single column */
  #page-country div[style*="display:grid"][style*="repeat"]{grid-template-columns:1fr !important}

  /* Padding shrinks more */
  .page-content > *{padding-left:0;padding-right:0}
  [style*="padding:24px"],[style*="padding:28px"]{padding:14px !important}
  [style*="padding:32px"]{padding:16px !important}
}
/* Africa Infra News — 2 cards per row on desktop, 1 on narrow screens. */
@media(max-width:860px){#news-grid{grid-template-columns:1fr !important}}
