﻿
/* ══════════════════════════════════════════
   RESET & ROOT
══════════════════════════════════════════ */
*{box-sizing:border-box;margin:0;padding:0}
:root{
  --ink:#03030d;--ink2:#07071a;--ink3:#0d0d24;--ink4:#14142e;--ink5:#1c1c3a;
  --b:rgba(255,255,255,0.055);--b2:rgba(255,255,255,0.09);--b3:rgba(255,255,255,0.15);
  --t:#f0f0fa;--t2:#8080aa;--t3:#44446a;
  --G:#00d4aa;--Gd:rgba(0,212,170,0.09);--Gg:rgba(0,212,170,0.28);
  --A:#e8a020;--Ad:rgba(232,160,32,0.09);
  --R:#ff3355;--Rd:rgba(255,51,85,0.09);
  --B:#3d8fff;--Bd:rgba(61,143,255,0.09);
  --P:#9d7af5;--Pd:rgba(157,122,245,0.09);
  --C:#00d4d4;--Cd:rgba(0,212,212,0.09);
  --gold:#d4af37;--goldD:rgba(212,175,55,0.09);
}
html{scroll-behavior:smooth}
body{font-family:'Cairo',sans-serif;background:var(--ink);color:var(--t);direction:rtl;overflow-x:hidden;min-height:100vh;position:relative}
body::before{content:'';position:fixed;inset:0;pointer-events:none;z-index:0;opacity:.03;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)'/%3E%3C/svg%3E");background-repeat:repeat;background-size:200px}*{font-family:inherit}.land-logo,.slider-title{font-family:'Cairo',sans-serif!important}h1,h2,h3,.slide-title{font-family:'Cairo',sans-serif!important}code,pre,.mono,#mkt-ticker-inner,.trust-num{font-family:'JetBrains Mono',monospace!important}
::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:var(--ink2)}::-webkit-scrollbar-thumb{background:var(--ink5);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--b3)}

/* ══ ANIMATIONS ══ */
@keyframes fadeUp{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes pulseDot{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(1.5)}}
@keyframes ticker{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
@keyframes glow{0%,100%{box-shadow:0 0 20px var(--Gg)}50%{box-shadow:0 0 45px var(--Gg),0 0 80px rgba(0,232,122,0.1)}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
@keyframes scanLine{0%{transform:translateY(-100%)}100%{transform:translateY(100vh)}}
@keyframes gradShift{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}
@keyframes countUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
@keyframes slideDown{from{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}
@keyframes shake{0%,100%{transform:translateX(0)}25%{transform:translateX(-6px)}75%{transform:translateX(6px)}}
@keyframes chartDraw{from{stroke-dashoffset:2000}to{stroke-dashoffset:0}}
@keyframes barGrow{from{height:0;opacity:0}to{opacity:1}}
@keyframes ripple{0%{transform:scale(0);opacity:.6}100%{transform:scale(4);opacity:0}}
@keyframes newBadge{0%{opacity:0;transform:scale(.6)}100%{opacity:1;transform:scale(1)}}

.fu{animation:fadeUp .5s ease both}
.fi{animation:fadeIn .4s ease both}

/* ══ SHARED COMPONENTS ══ */
.card{background:var(--ink2);border:1px solid var(--b2);border-radius:8px;box-shadow:0 1px 3px rgba(0,0,0,.4)}
.badge{display:inline-flex;align-items:center;gap:3px;padding:3px 9px;border-radius:100px;font-size:11px;font-weight:700;white-space:nowrap}
.bG{background:var(--Gd);color:var(--G)}.bA{background:var(--Ad);color:var(--A)}
.bR{background:var(--Rd);color:var(--R)}.bB{background:var(--Bd);color:var(--B)}
.bP{background:var(--Pd);color:var(--P)}.b-gold{background:var(--goldD);color:var(--gold)}
.btn-g{background:var(--G);color:#000;border:none;padding:12px 24px;border-radius:6px;font-family:'Cairo',sans-serif;font-size:13px;font-weight:900;letter-spacing:.03em;cursor:pointer;display:inline-flex;align-items:center;gap:8px;box-shadow:0 0 20px var(--Gg);animation:glow 3s infinite;transition:all .2s;position:relative;overflow:hidden}
.btn-g:hover{background:#05f585;transform:translateY(-2px)}
.btn-g:disabled{background:var(--ink4);color:var(--t3);cursor:not-allowed;box-shadow:none;animation:none;transform:none}
.btn-ghost{background:transparent;color:var(--t2);border:1px solid var(--b2);padding:11px 20px;border-radius:6px;font-family:'Cairo',sans-serif;font-size:12px;font-weight:700;cursor:pointer;display:inline-flex;align-items:center;gap:7px;transition:all .2s}
.btn-ghost:hover{background:var(--ink3);border-color:var(--b3);color:var(--t)}
.spin{width:20px;height:20px;border-radius:50%;border:2px solid var(--b2);border-top-color:var(--G);animation:spin .7s linear infinite;display:inline-block;flex-shrink:0}
.prog-track{height:5px;background:var(--ink4);border-radius:3px;overflow:hidden}
.prog-fill{height:100%;border-radius:3px;transition:width 1.2s cubic-bezier(.4,0,.2,1)}
.input-field{background:var(--ink2);border:1px solid var(--b2);border-radius:6px;color:var(--t);padding:10px 14px;font-family:'Cairo',sans-serif;font-size:14px;width:100%;transition:border-color .2s;outline:none}
.input-field:focus{outline:none;border-color:var(--G);box-shadow:0 0 0 3px rgba(0,212,170,0.12)}
.input-field::placeholder{color:var(--t3)}

/* ══ PAGES ══ */
.page{display:none;min-height:100vh}.page.active{display:block}#page-auth.active{display:flex!important}#page-app.active{display:grid!important;grid-template-columns:220px 1fr;height:100vh}
.page.active{display:block}
#page-auth.active ~ * .land-nav, #page-app.active ~ * .land-nav { display:none!important; }
body:has(#page-auth.active) .land-nav,
body:has(#page-auth.active) .land-ticker-bar,
body:has(#page-auth.active) .land-mkt-bar,
body:has(#page-app.active) .land-nav,
body:has(#page-app.active) .land-ticker-bar,
body:has(#page-app.active) .land-mkt-bar,
body:has(#page-admin.active) .land-nav,
body:has(#page-admin.active) .land-ticker-bar,
body:has(#page-admin.active) .land-mkt-bar { display:none!important; }

/* ══════════════════════════════════════════
   LANDING PAGE — Redesigned v2
══════════════════════════════════════════ */
#page-landing{background:var(--ink);overflow-x:hidden;overflow-y:visible}

/* STICKY NAV */
.land-nav{position:fixed;top:0;left:0;right:0;z-index:700;height:56px;display:flex;align-items:center;padding:0 20px;background:rgba(3,3,13,0.92);backdrop-filter:blur(20px) saturate(1.4);border-bottom:1px solid var(--b2);border-top:2px solid var(--A);gap:12px;box-sizing:border-box}
.land-logo{font-family:'Cairo',sans-serif;font-size:22px;font-weight:800;letter-spacing:-.05em;flex-shrink:0}
.land-logo span{color:var(--G)}
.land-nav-links{display:flex;align-items:center;gap:4px;margin-right:auto}
.nav-link{background:none;border:none;color:var(--t2);font-family:'Cairo',sans-serif;font-size:13px;font-weight:600;cursor:pointer;padding:6px 10px;border-radius:5px;letter-spacing:.04em;text-transform:uppercase;transition:all .15s}
.nav-link:hover,.nav-link.active{color:var(--t)}

/* NEWS TICKER (top) */
.land-ticker-bar{height:30px;overflow:hidden;display:flex;align-items:center;background:#000010;border-bottom:1px solid var(--b2);position:fixed;top:56px;left:0;right:0;z-index:499}
.ticker-label{padding:0 12px;background:var(--R);border-radius:2px;height:100%;display:flex;align-items:center;font-size:10px;font-weight:900;letter-spacing:.08em;flex-shrink:0}
.ticker-scroll{flex:1;overflow:hidden}
.ticker-inner-txt{white-space:nowrap;animation:ticker 45s linear infinite;font-size:11px;font-weight:700;display:inline-block;padding:0 6px}

/* MARKET BAR */
.land-mkt-bar{height:40px;overflow:hidden;display:flex;align-items:center;background:var(--ink2);border-top:1px solid var(--b2);border-bottom:1px solid var(--b2);position:fixed;top:86px;left:0;right:0;z-index:498}
.mkt-scroll{flex:1;overflow:hidden}
.mkt-scroll-inner{white-space:nowrap;animation:ticker 28s linear infinite;display:inline-block}
.mkt-pill{display:inline-flex;align-items:center;gap:6px;padding:0 14px;border-left:1px solid var(--b);height:40px}
.mkt-sym{font-size:10px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:var(--t2)}
.mkt-prc{font-size:12px;font-family:'JetBrains Mono',monospace;font-weight:600}
.mkt-chg{font-size:10px;font-family:'JetBrains Mono',monospace;font-weight:700}

/* MAIN CONTENT AREA */
.land-body{display:grid;grid-template-columns:minmax(0,1fr) 340px;gap:0;max-width:1400px;margin:0 auto;padding:24px 32px}
.land-body > .feature-story{min-width:0}
.land-body > .land-sidebar{min-width:0}

/* FEATURE STORY */
.feature-story{padding-left:0;border-left:none}
.story-hero{position:relative;border-radius:8px;overflow:hidden;cursor:pointer;transition:transform .2s;border:1px solid var(--b2);background:var(--ink2);isolation:isolate;z-index:1}
.story-hero:hover{transform:translateY(-2px)}
.story-hero-img{width:100%;height:320px;object-fit:cover;display:block;background:linear-gradient(135deg,var(--ink3),var(--ink4));position:relative;z-index:1}
.story-hero > div:first-child{position:relative;z-index:1}
.story-hero-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(5,5,14,.95) 0%,rgba(5,5,14,.3) 50%,transparent 100%);z-index:2;pointer-events:none}
.story-hero-content{position:absolute;bottom:0;left:0;right:0;padding:24px 28px;z-index:3}
.story-cat-bar{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.story-title{font-family:'Cairo',sans-serif;font-size:clamp(20px,2.4vw,28px);font-weight:800;line-height:1.25;margin-bottom:12px}
.story-meta{display:flex;gap:12px;align-items:center;font-size:12px;color:rgba(255,255,255,.55)}
.trust-chip{font-family:'JetBrains Mono',monospace;font-size:10px;font-weight:700;padding:2px 8px;border-radius:3px;background:rgba(0,212,170,0.12);color:var(--G);border:1px solid rgba(0,212,170,0.2);display:inline-flex;align-items:center;gap:5px}

/* NEWS LIST */
.news-section{padding:0}
.section-hdr{padding:14px 20px;border-bottom:1px solid var(--b);display:flex;align-items:center;justify-content:space-between;position:sticky;top:120px;background:rgba(5,5,14,.95);backdrop-filter:blur(12px);z-index:10}
.section-hdr-title{font-size:13px;font-weight:800;letter-spacing:.05em;display:flex;align-items:center;gap:7px}
.news-item{display:flex;gap:12px;padding:14px 20px;border-bottom:1px solid var(--b);cursor:pointer;transition:background .18s;position:relative}
.news-item:hover{background:var(--ink2)}
.news-item.breaking{border-right:3px solid var(--R)}
.news-item.pivot{border-right:3px solid var(--A)}
.ni-trust{width:38px;height:38px;position:relative;flex-shrink:0;margin-top:2px}
.ni-body{flex:1;min-width:0}
.ni-wrap{border-radius:6px;border:1px solid var(--b);background:var(--ink2);transition:border-color .2s,background .2s}
.ni-wrap:hover{border-color:var(--b2);background:var(--ink3)}
.ni-cat{font-size:9px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;margin-bottom:5px}
.ni-title{font-size:15px;font-weight:700;line-height:1.55;font-family:'Cairo',sans-serif;margin-bottom:5px;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.ni-footer{display:flex;gap:8px;align-items:center;font-size:10px;color:var(--t3);font-family:'JetBrains Mono',monospace;letter-spacing:.03em}
.ni-new{background:var(--G);color:#000;font-size:9px;font-weight:900;padding:2px 7px;border-radius:100px;letter-spacing:.05em;animation:newBadge .4s ease}
.read-more-blur{padding:14px 20px;border-bottom:1px solid var(--b);cursor:pointer;position:relative;overflow:hidden}
.blur-card{display:none!important}
.blur-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:8px}

/* SIDEBAR */
.land-sidebar{border-right:1px solid var(--b2);padding-right:24px;display:flex;flex-direction:column;gap:1px}
.sidebar-block{background:var(--ink2);border:1px solid var(--b2);border-radius:8px;padding:16px;margin-bottom:12px;width:100%}
.sb-title{font-size:11px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--t3);margin-bottom:14px;padding-bottom:10px;border-bottom:1px solid var(--b)}

/* MARKET CARDS */
.mkt-card{display:flex;align-items:center;justify-content:space-between;padding:9px 12px;border-radius:8px;background:var(--ink3);border:1px solid var(--b);margin-bottom:7px;transition:all .2s}
.mkt-card:hover{border-color:var(--b2);transform:translateX(-2px)}
.mkt-card-name{font-size:13px;font-weight:800}
.mkt-card-price{font-family:'JetBrains Mono',monospace;font-size:13px;font-weight:600}
.mkt-card-chg{font-family:'JetBrains Mono',monospace;font-size:11px;font-weight:700}

/* AD SLOTS */
.ad-slot{background:var(--ink3);border:1px dashed var(--b2);border-radius:10px;padding:14px;text-align:center;margin-bottom:14px;cursor:pointer;transition:all .2s}
.ad-slot:hover{border-color:var(--b3);background:var(--ink4)}
.ad-label{font-size:9px;color:var(--t3);letter-spacing:.12em;text-transform:uppercase;margin-bottom:6px}

/* TRENDING */
.trend-item{display:flex;gap:10px;align-items:flex-start;padding:10px 0;border-bottom:1px solid var(--b);cursor:pointer;transition:all .2s}
.trend-item:last-child{border-bottom:none}
.trend-item:hover .trend-title{color:var(--G)}
.trend-num{font-family:'JetBrains Mono',monospace;font-size:18px;font-weight:600;color:var(--t3);line-height:1;min-width:24px}
.trend-title{font-size:12px;font-weight:700;line-height:1.45;color:var(--t);transition:color .2s}
.trend-cnt{font-size:10px;color:var(--t3);margin-top:3px}

/* FEATURE ANALYSIS */
.analysis-card{background:linear-gradient(135deg,rgba(0,232,122,.06),transparent);border:1px solid rgba(0,232,122,.18);border-radius:12px;padding:16px;margin-bottom:14px}

/* FOOTER */
.flink{font-size:13px;color:var(--t2);margin-bottom:9px;cursor:pointer;transition:color .18s}.flink:hover{color:var(--G)}
.land-footer{background:#030310;border-top:1px solid var(--b2);padding:48px 32px 32px;margin-top:0}
footer{background:#030310;border-top:1px solid var(--b2);padding:48px 32px 32px}
.sf-link{display:block;background:none;border:none;color:var(--t3);font-family:'Cairo',sans-serif;font-size:13px;padding:5px 0;cursor:pointer;text-align:right;transition:color .15s}
.sf-link:hover{color:var(--t)}

/* FILTER TABS */
.filter-tabs{display:flex;gap:4px;overflow-x:auto;padding:10px 20px 0;border-bottom:1px solid var(--b);scrollbar-width:none}
.filter-tabs::-webkit-scrollbar{display:none}
.ftab{background:transparent;border:none;color:var(--t3);font-family:'Cairo',sans-serif;font-size:12px;font-weight:700;cursor:pointer;padding:7px 14px;border-radius:8px 8px 0 0;border-bottom:2px solid transparent;transition:all .2s;white-space:nowrap}
.ftab.active{color:var(--G);border-bottom-color:var(--G);background:var(--Gd)}
.ftab:hover{color:var(--t)}

@media(max-width:900px){.land-body{grid-template-columns:1fr}.land-sidebar{display:none}}

/* ══════════════════════════════════════════
   AUTH PAGE
══════════════════════════════════════════ */
#page-auth{display:none;background:var(--ink);min-height:100vh;align-items:center;justify-content:center;position:fixed;inset:0;z-index:99999;overflow-y:auto}
#page-auth.active{display:flex;flex-direction:column}
.auth-container{width:100%;max-width:440px;padding:20px}
.auth-card{background:var(--ink2);border:1px solid var(--b2);border-radius:20px;padding:36px;position:relative;overflow:hidden}
.auth-card::before{content:'';position:absolute;top:-60px;left:50%;transform:translateX(-50%);width:220px;height:220px;background:radial-gradient(circle,rgba(0,232,122,.08),transparent 70%);pointer-events:none}
.auth-tab-row{display:flex;background:var(--ink3);border-radius:10px;padding:4px;margin-bottom:28px}
.auth-tab{flex:1;padding:9px;border:none;border-radius:8px;cursor:pointer;font-family:'Cairo',sans-serif;font-size:14px;font-weight:700;background:transparent;color:var(--t3);transition:all .2s}
.auth-tab.active{background:var(--ink2);color:var(--t);box-shadow:0 2px 10px rgba(0,0,0,.4)}
.form-label{font-size:11px;font-weight:700;color:var(--t3);display:block;margin-bottom:7px;letter-spacing:.07em;text-transform:uppercase}
.form-group{margin-bottom:18px}
.error-msg{background:var(--Rd);border:1px solid rgba(255,45,85,.2);color:var(--R);border-radius:9px;padding:10px 14px;font-size:13px;margin-bottom:16px;display:none}

/* ══════════════════════════════════════════
   APP SHELL (dashboard)
══════════════════════════════════════════ */
#page-app{display:none;position:fixed;inset:0;z-index:9999;overflow:hidden}
#page-app.active{display:grid;grid-template-columns:220px 1fr;height:100vh}
.sidebar{background:var(--ink2);border-left:1px solid var(--b);position:sticky;top:0;height:100vh;display:flex;flex-direction:column;overflow-y:auto;flex-shrink:0}
.main-content{overflow:hidden;display:flex;flex-direction:column}
.logo-wrap{font-family:'Cairo',sans-serif;font-size:22px;font-weight:800;letter-spacing:-.05em;padding:20px 18px;border-bottom:1px solid var(--b)}
.logo-wrap span{color:var(--G)}
.nav-section-lbl{font-size:9px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--t3);padding:12px 14px 6px;margin-top:4px}
.nav-item{display:flex;align-items:center;gap:10px;padding:10px 16px;width:100%;background:none;border:none;color:var(--t2);font-family:'Cairo',sans-serif;font-size:13px;font-weight:600;cursor:pointer;text-align:right;border-radius:6px;transition:all .15s;position:relative}
.nav-item:hover{background:var(--ink3);color:var(--t)}
.nav-item.active{background:rgba(0,212,170,0.1);color:var(--G);border-right:2px solid var(--G)}
.nav-item .ic{font-size:16px;flex-shrink:0}
.nav-item .lock-ic{font-size:11px;position:absolute;left:10px;opacity:.5}
.app-sidebar{width:220px;background:#050510;border-left:1px solid var(--b2);display:flex;flex-direction:column;position:fixed;top:0;right:0;bottom:0;z-index:100}
.nav-divider{height:1px;background:var(--b);margin:8px 12px}
.topbar{background:rgba(5,5,14,0.92);backdrop-filter:blur(24px);border-bottom:1px solid var(--b);padding:12px 24px;display:flex;align-items:center;gap:12px;position:sticky;top:0;z-index:100;flex-shrink:0}
.search-box{display:flex;align-items:center;gap:8px;background:var(--ink3);border:1px solid var(--b2);border-radius:9px;padding:7px 14px;width:240px}
.search-box input{background:transparent;border:none;outline:none;color:var(--t);font-size:13px;font-family:'Cairo',sans-serif;width:100%}
.search-box input::placeholder{color:var(--t3)}
.ticker-wrap{background:var(--R);overflow:hidden;height:28px;display:flex;align-items:center;flex-shrink:0}
.ticker-live-badge{padding:0 12px;background:rgba(0,0,0,.3);height:100%;display:flex;align-items:center;font-size:10px;font-weight:900;letter-spacing:.06em;flex-shrink:0}
.ticker-track{flex:1;overflow:hidden}
.mkt-ticker{background:var(--ink3);border-bottom:1px solid var(--b);height:36px;overflow:hidden;display:flex;align-items:center}
.mkt-inner-wrap{white-space:nowrap;animation:ticker 30s linear infinite;display:inline-block}
.mkt-item{display:inline-flex;align-items:center;gap:8px;padding:0 20px;font-size:12px;border-right:1px solid var(--b)}
.mkt-name{font-weight:700;color:var(--t2)}.up{color:var(--G)}.dn{color:var(--R)}
.stat-card{background:var(--ink2);border:1px solid var(--b);border-radius:16px;padding:20px;position:relative;overflow:hidden;transition:all .2s}
.stat-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--accent,var(--G));opacity:.8}
.stat-card:hover{border-color:var(--b2);transform:translateY(-2px)}
.tab-row{display:flex;gap:3px;background:var(--ink3);padding:3px;border-radius:10px}
.tab-btn{flex:1;padding:8px 14px;border-radius:8px;font-size:12px;font-weight:700;color:var(--t3);transition:all .2s;background:transparent;border:none;cursor:pointer;font-family:'Cairo',sans-serif;white-space:nowrap}
.tab-btn.active{background:var(--ink2);color:var(--t);box-shadow:0 2px 12px rgba(0,0,0,.4)}
.stk-table{width:100%;border-collapse:collapse}
.stk-table th{padding:9px 14px;text-align:right;font-size:10px;font-weight:700;color:var(--t3);letter-spacing:.07em;text-transform:uppercase;border-bottom:1px solid var(--b)}
.stk-table td{padding:11px 14px;font-size:13px;border-bottom:1px solid var(--b)}
.stk-table tr:last-child td{border-bottom:none}
.stk-table tr:hover td{background:var(--ink3)}
.news-row{display:flex;gap:0;border-radius:16px;overflow:hidden;border:1px solid var(--b);background:var(--ink2);cursor:pointer;transition:all .2s}
.news-row:hover{border-color:var(--b2);transform:translateY(-2px);box-shadow:0 8px 30px rgba(0,0,0,.4)}
.news-row.open{border-color:rgba(0,232,122,.25)}
.trust-panel{padding:16px 14px;display:flex;flex-direction:column;align-items:center;gap:6px;border-left:1px solid var(--b);min-width:88px;flex-shrink:0;justify-content:center}
.chat-bubble{border-radius:14px;padding:12px 16px;max-width:82%;font-size:14px;line-height:1.8;animation:slideDown .3s ease}
.chat-user{background:var(--Bd);border:1px solid rgba(45,143,255,.2);margin-right:auto;color:var(--t)}
.chat-ai{background:var(--ink3);border:1px solid var(--b2);margin-left:auto;color:var(--t)}
.typing span{display:inline-block;width:6px;height:6px;background:var(--G);border-radius:50%;animation:pulseDot 1.2s infinite}
.typing span:nth-child(2){animation-delay:.2s}.typing span:nth-child(3){animation-delay:.4s}

/* ══════════════════════════════════════════
   PAYWALL OVERLAY
══════════════════════════════════════════ */
.paywall{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;padding:40px;text-align:center}
.paywall-icon{font-size:56px;margin-bottom:20px;animation:float 4s ease-in-out infinite}
.paywall-title{font-size:22px;font-weight:800;margin-bottom:10px}
.paywall-sub{font-size:14px;color:var(--t2);max-width:400px;line-height:1.7;margin-bottom:28px}
.plans-mini{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-bottom:24px}
.plan-mini-card{background:var(--ink3);border:1px solid var(--b2);border-radius:14px;padding:20px;min-width:150px;text-align:center;cursor:pointer;transition:all .25s}
.plan-mini-card:hover{border-color:var(--G);transform:translateY(-3px)}
.plan-mini-card.sel{border-color:var(--G);background:var(--Gd)}

/* ══════════════════════════════════════════
   ADMIN PANEL
══════════════════════════════════════════ */
#page-admin{display:none;background:var(--ink);position:fixed;inset:0;z-index:9999;overflow-y:auto}
#page-admin.active{display:block}
.admin-shell{display:flex;height:100vh}
.admin-sidebar{width:220px;background:#050510;border-left:1px solid var(--b2);display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow-y:auto}
.admin-header{padding:16px;border-bottom:1px solid var(--b2);background:linear-gradient(180deg,#080820 0%,#050510 100%)}
.admin-nav-item{display:flex;align-items:center;gap:10px;padding:10px 14px;width:100%;background:none;border:none;color:var(--t2);font-family:'Cairo',sans-serif;font-size:13px;font-weight:600;cursor:pointer;border-radius:6px;text-align:right;transition:all .15s}
.admin-nav-item:hover{background:var(--ink3);color:var(--t)}
.admin-nav-item.active{background:rgba(0,212,170,0.1);color:var(--G)}
.admin-main{flex:1;overflow-y:auto;background:var(--ink)}

/* SUBSCRIPTION BADGE */
.plan-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 12px;border-radius:100px;font-size:11px;font-weight:800}
.plan-free{background:var(--Bd);color:var(--B)}
.plan-pro{background:var(--Gd);color:var(--G)}
.plan-elite{background:var(--goldD);color:var(--gold)}

/* UPGRADE MODAL */
#upgrade-modal{display:none;position:fixed;inset:0;background:rgba(0,0,0,.75);backdrop-filter:blur(10px);z-index:1000;align-items:center;justify-content:center;padding:20px}
#upgrade-modal.open{display:flex}
#auth-modal .modal-card,.modal-card{background:var(--ink2);border:1px solid var(--b2);border-radius:12px;padding:32px;max-width:440px;width:100%;position:relative;animation:fadeUp .4s ease;box-shadow:0 24px 80px rgba(0,0,0,.6)}
.modal-close{position:absolute;top:16px;left:16px;background:var(--ink4);border:none;color:var(--t2);width:32px;height:32px;border-radius:50%;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;transition:all .2s}
.modal-close:hover{background:var(--ink3);color:var(--t)}

/* ══ SHARED PERSISTENT NAV (static pages overlay) ══ */
#static-overlay { font-family:'Cairo',sans-serif; color:var(--t); direction:rtl; }
#static-nav {
  position:fixed; top:0; left:0; right:0; z-index:700;
  height:56px; display:flex; align-items:center; padding:0 28px; gap:16px;
  background:rgba(3,3,13,0.95); backdrop-filter:blur(20px) saturate(1.4);
  border-bottom:1px solid var(--b2); border-top:2px solid var(--A);
}
#static-nav .sn-logo { font-family:'Cairo',sans-serif; font-size:22px; font-weight:800; letter-spacing:-.05em; cursor:pointer; flex-shrink:0; }
#static-nav .sn-logo span { color:var(--G); }
#static-nav .sn-links { display:flex; gap:4px; }
#static-nav .sn-link { background:transparent; border:none; color:var(--t2); font-family:'Cairo',sans-serif; font-size:13px; font-weight:700; cursor:pointer; padding:7px 14px; border-radius:8px; transition:all .18s; }
#static-nav .sn-link:hover { color:var(--t); background:var(--ink3); }
#static-nav .sn-link.active { color:var(--G); }
#static-nav .sn-actions { margin-right:auto; display:flex; gap:8px; }
/* .sf-link defined in footer section below */
/* App back-to-home button */
.home-back-btn { position:fixed; bottom:20px; left:20px; z-index:200; background:var(--ink3); border:1px solid var(--b2); border-radius:100px; padding:8px 16px; font-size:12px; font-weight:700; color:var(--t2); cursor:pointer; display:flex; align-items:center; gap:6px; transition:all .2s; font-family:'Cairo',sans-serif; box-shadow:0 4px 20px rgba(0,0,0,.4); }
.home-back-btn:hover { color:var(--G); border-color:var(--G); }

/* ── DROPDOWN NAV ── */
.nav-dropdown{position:relative;display:inline-flex}
.nav-dropdown-btn{background:none;border:none;color:var(--t2);font-family:'Cairo',sans-serif;font-size:13px;font-weight:600;cursor:pointer;padding:6px 10px;border-radius:5px;letter-spacing:.04em;text-transform:uppercase;transition:all .15s;display:flex;align-items:center;gap:5px}
.nav-dropdown-btn:hover,.nav-dropdown-btn.open{color:var(--t);background:var(--ink3)}
.nav-dropdown-btn .arrow{font-size:9px;transition:transform .2s;opacity:.6}
.nav-dropdown-btn.open .arrow{transform:rotate(180deg)}
.nav-dropdown-menu{display:none;position:absolute;top:calc(100% + 8px);right:0;background:var(--ink2);border:1px solid var(--b2);border-radius:8px;padding:6px;min-width:180px;box-shadow:0 16px 40px rgba(0,0,0,.5);z-index:1000}
.nav-dropdown-menu.open{display:block;animation:slideDown .15s ease}
.dd-item{display:flex;align-items:center;gap:8px;width:100%;padding:9px 12px;background:none;border:none;color:var(--t2);font-family:'Cairo',sans-serif;font-size:13px;cursor:pointer;border-radius:5px;text-align:right;transition:all .12s;white-space:nowrap}
.dd-item:hover{background:var(--ink3);color:var(--t)}
.dd-item .dd-ic{font-size:15px;flex-shrink:0}
.dd-sep{height:1px;background:var(--b);margin:4px 6px}
/* ── CATEGORY PAGES ── */
.cat-page{display:none;padding:0}
.cat-page.active{display:block}
.cat-header{display:flex;align-items:center;gap:12px;padding:16px 0 14px;border-bottom:1px solid var(--b2);margin-bottom:16px;background:rgba(3,3,13,.95);backdrop-filter:blur(16px);position:sticky;top:126px;z-index:10}
.cat-header-icon{font-size:28px}
.cat-header-title{font-size:16px;font-weight:800;font-family:'Cairo',sans-serif;letter-spacing:-.01em}
.cat-header-sub{font-size:11px;color:var(--t3);margin-top:2px;font-family:'Cairo',sans-serif;font-weight:400}
/* (legacy grid rule superseded by masonry column-count block below) */
.cat-news-list > *{min-width:0}

/* ══════════════════════════════════════════
   RESPONSIVE — FULL MOBILE SUPPORT
══════════════════════════════════════════ */

/* ── Tablet (≤1100px) ── */
@media(max-width:1100px){
  .land-body{grid-template-columns:minmax(0,1fr) 300px}
  .land-nav{padding:0 16px;gap:8px}
  .land-nav-links{gap:2px}
  .nav-link{padding:6px 10px;font-size:12px}
  .nav-dropdown-btn{padding:6px 10px;font-size:12px}
}

/* ── Mobile Nav (≤768px) ── */
@media(max-width:768px){
  /* Sidebar hidden on mobile */
  .land-body{grid-template-columns:1fr;margin-top:108px}
  .land-sidebar{display:none}
  .feature-story{border-left:none}

  /* Nav: logo + hamburger only */
  .land-nav{height:52px;padding:0 14px;gap:10px}
  .land-nav-links{display:none}
  .land-nav .btn-ghost{display:none}
  .land-nav .btn-g{display:flex!important;padding:6px 10px;font-size:12px}

  /* Hamburger menu button */
  .hamburger-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;background:var(--ink3);border:1px solid var(--b2);cursor:pointer;flex-shrink:0;margin-right:auto}
  .hamburger-btn span{display:block;width:18px;height:2px;background:var(--t);border-radius:2px;transition:all .2s;position:relative}
  .hamburger-btn span::before,.hamburger-btn span::after{content:'';display:block;width:18px;height:2px;background:var(--t);border-radius:2px;position:absolute;transition:all .2s}
  .hamburger-btn span::before{top:-5px}
  .hamburger-btn span::after{top:5px}

  /* Mobile menu drawer */
  .mobile-menu{display:none!important;position:fixed;top:56px;left:0;right:0;bottom:0;background:var(--ink2);z-index:699;overflow-y:auto;padding:16px;border-top:1px solid var(--b);animation:slideDown .2s ease}.mobile-menu.open{display:block!important}
    .mobile-menu-section{margin-bottom:20px}
  .mobile-menu-title{font-size:10px;font-weight:800;color:var(--t3);letter-spacing:.1em;text-transform:uppercase;margin-bottom:10px;padding:0 4px}
  .mobile-menu-item{display:flex;align-items:center;gap:10px;padding:12px 14px;border-radius:10px;cursor:pointer;color:var(--t);font-size:14px;font-weight:700;transition:background .18s;border:none;background:transparent;width:100%;text-align:right;font-family:'Cairo',sans-serif}
  .mobile-menu-item:hover,.mobile-menu-item:active{background:var(--ink3)}
  .mobile-menu-item .mi-ic{font-size:18px;width:28px;text-align:center;flex-shrink:0}
  .mobile-menu-divider{height:1px;background:var(--b);margin:8px 0}
  .mobile-menu-auth{display:flex;gap:10px;padding:12px 0;margin-top:8px}
  .mobile-menu-auth .btn-ghost,.mobile-menu-auth .btn-g{flex:1;justify-content:center;font-size:14px;padding:11px}

  /* Tickers */
  .land-ticker-bar{top:52px}
  .land-mkt-bar{top:82px;height:30px}
  .ticker-inner-txt{font-size:10px}
  .mkt-pill{padding:0 12px;font-size:11px}

  /* Feature story */
  .story-hero-content{padding:16px 16px}
  .story-title{font-size:18px}
  .story-cat-bar{flex-wrap:wrap;gap:6px}

  /* Category header */
  .cat-header{top:110px;padding:12px 14px;gap:8px}
  .cat-header-icon{font-size:22px}
  .cat-header-title{font-size:15px}
  .cat-header-sub{font-size:11px}
  .cat-header .btn-ghost{display:none}

  /* News items */
  .news-item{padding:12px 14px;gap:10px}
  .ni-title{font-size:13px}

  /* Report section */
  #trending-section [style*="grid-template-columns:repeat(4"]{grid-template-columns:repeat(2,1fr) !important}

  /* Dropdown: disabled on mobile (use mobile menu) */
  .nav-dropdown-menu{display:none !important}

  /* Logo size */
  .land-logo{font-size:20px}
}

/* ── Small mobile (≤420px) ── */
@media(max-width:420px){
  .land-nav .btn-g{display:flex!important;padding:5px 8px;font-size:11px}
  .story-title{font-size:16px}
  .story-hero > div:first-child{height:240px !important}
  .cat-header-sub{display:none}
  #trending-section [style*="grid-template-columns:repeat(4"]{grid-template-columns:1fr 1fr !important}
}

/* ══════════════════════════════════════════
   LAYOUT STABILITY FIXES
══════════════════════════════════════════ */
*{box-sizing:border-box}
img,svg,video{max-width:100%;height:auto}
.land-nav,.land-ticker-bar,.land-mkt-bar{will-change:transform}
#page-landing{overflow-x:hidden}
.cat-news-list{min-height:0}
.land-body{overflow-x:hidden}

/* Story title as h2 */
.story-title{font-family:'Cairo',sans-serif;font-size:clamp(16px,2.4vw,26px);font-weight:800;line-height:1.3;margin-bottom:10px;color:var(--t)}
.story-meta{display:flex;gap:10px;align-items:center;font-size:11px;color:rgba(255,255,255,.55);flex-wrap:wrap}

/* Section headers as h2/h3 */
.cat-header-title{font-size:17px;font-weight:800;margin:0}
.cat-header-sub{font-size:12px;color:var(--t2);margin:2px 0 0}
.sb-title{font-size:11px;font-weight:800;color:var(--t3);letter-spacing:.1em;text-transform:uppercase;margin-bottom:12px}

/* ══ HERO SLIDER ══ */
.hero-slider{position:relative;width:100%;height:480px;overflow:hidden;background:var(--ink2);border-bottom:1px solid var(--b2)}
.slider-track{display:flex;height:100%;transition:transform .7s cubic-bezier(.4,0,.2,1)}
.slide{min-width:100%;height:100%;position:relative;overflow:hidden;flex-shrink:0}
.slide-bg{position:absolute;inset:0;background-size:cover;background-position:center;z-index:1}
.slide-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(5,5,14,.92) 0%,rgba(5,5,14,.5) 60%,transparent 100%);z-index:2}
.slide-content{position:absolute;bottom:0;left:0;right:0;padding:36px 40px;max-width:800px;margin:0 auto;direction:rtl;text-align:center;display:flex;flex-direction:column;align-items:center;z-index:3}
.slide-eyebrow{display:inline-flex;align-items:center;gap:6px;font-size:10px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;padding:5px 12px;border-radius:3px;margin-bottom:14px}
.slide-title{font-family:'Cairo',sans-serif;font-weight:800;font-size:clamp(20px,2.8vw,32px);line-height:1.25;margin-bottom:12px;color:#fff}
.slide-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-size:11px;color:rgba(255,255,255,.5);margin-bottom:20px;font-family:'JetBrains Mono',monospace;letter-spacing:.04em}
.slide-trust{display:inline-flex;align-items:center;gap:5px;background:rgba(0,232,122,.18);border:1px solid rgba(0,232,122,.3);color:var(--G);font-size:11px;font-weight:800;padding:3px 10px;border-radius:100px}
.slide-cta{font-family:'Cairo',sans-serif;display:inline-flex;align-items:center;gap:8px;background:var(--G);color:#000;font-size:13px;font-weight:800;padding:10px 22px;border-radius:8px;border:none;cursor:pointer;font-family:'Cairo',sans-serif;transition:all .2s}
.slide-cta:hover{background:#00ff88;transform:translateY(-1px)}
/* Slider controls */
.slider-dots{position:absolute;bottom:16px;left:50%;transform:translateX(-50%);display:flex;gap:7px;z-index:10}
.slider-dot{width:7px;height:7px;border-radius:50%;background:rgba(255,255,255,.3);border:none;cursor:pointer;transition:all .3s;padding:0}
.slider-dot.active{width:24px;border-radius:4px;background:var(--G)}
.slider-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:10;width:40px;height:40px;border-radius:50%;background:rgba(5,5,14,.6);border:1px solid rgba(255,255,255,.15);color:#fff;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;backdrop-filter:blur(8px)}
.slider-arrow:hover{background:rgba(0,232,122,.2);border-color:var(--G);color:var(--G)}
.slider-arrow.prev{right:16px}
.slider-arrow.next{left:16px}
.slider-progress{position:absolute;bottom:0;left:0;right:0;height:3px;background:rgba(255,255,255,.1);z-index:10}
.slider-progress-bar{height:100%;background:var(--G);width:0%;transition:width linear}
.slide-counter{position:absolute;top:16px;left:20px;font-family:'JetBrains Mono',monospace;font-size:11px;color:rgba(255,255,255,.4);z-index:10;letter-spacing:.08em}

.nc-card{padding:18px;background:var(--ink2);border:1px solid var(--b2);border-radius:12px;transition:background .18s,border-color .18s,transform .18s;display:block;overflow:hidden;min-width:0;word-wrap:break-word;overflow-wrap:anywhere}
/* Clamp card title to max 4 lines so a runaway headline doesn't create huge tall cards */
.nc-card .nc-title,.nc-card [data-role="title"]{display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden}
.nc-card *{min-width:0;max-width:100%}
.nc-card a, .nc-card img{max-width:100%;word-break:break-word}
.nc-card:hover{background:var(--ink3);border-color:var(--b3);transform:translateY(-2px)}
[data-theme="light"] .nc-card{background:#ffffff;border-color:rgba(0,0,0,.08)}
[data-theme="light"] .nc-card:hover{background:#fafbff}

/* ══ APP LAYOUT CSS ══ */
#page-app .sidebar{width:220px;height:100vh;overflow-y:auto;background:var(--ink2);border-left:1px solid var(--b);display:flex;flex-direction:column;flex-shrink:0}
#page-app .main-content{flex:1;height:100vh;overflow:hidden;display:flex;flex-direction:column;min-width:0}
#page-app .topbar{height:54px;min-height:54px;background:var(--ink2);border-bottom:1px solid var(--b);display:flex;align-items:center;padding:0 20px;gap:12px;flex-shrink:0}
#page-content{flex:1;overflow-y:auto;background:var(--ink)}


/* ══ APP FORCED LAYOUT ══ */
#page-app .sidebar{width:220px!important;height:100vh!important;overflow-y:auto;background:var(--ink2);border-left:1px solid var(--b);display:flex!important;flex-direction:column;flex-shrink:0;position:relative;z-index:1}
#page-app .main-content{flex:1!important;height:100vh!important;overflow:hidden;display:flex!important;flex-direction:column;min-width:0;position:relative}
#page-app .topbar{height:54px;min-height:54px;flex-shrink:0;background:var(--ink2);border-bottom:1px solid var(--b);display:flex;align-items:center;padding:0 20px;gap:12px}
#page-content{flex:1!important;overflow-y:auto!important;background:var(--ink);display:block}

/* ══════════════════════════════════════════
   FEATURE 2 — SLIDER CENTERING
══════════════════════════════════════════ */
.slide-eyebrow{justify-content:center}
.slide-meta{justify-content:center}
.slide-cta{margin:0 auto}

/* ══════════════════════════════════════════
   FEATURE 3 — LIGHT MODE
══════════════════════════════════════════ */
[data-theme="light"]{
  --ink:#f0f2f5;--ink2:#ffffff;--ink3:#e4e6ea;--ink4:#d4d6da;--ink5:#c4c6ca;
  --b:rgba(0,0,0,0.1);--b2:rgba(0,0,0,0.15);--b3:rgba(0,0,0,0.22);
  --t:#111827;--t2:#374151;--t3:#6b7280;
  --G:#059669;--Gd:rgba(5,150,105,0.12);--Gg:rgba(5,150,105,0.25);
  --A:#b45309;--Ad:rgba(180,83,9,0.1);
  --R:#dc2626;--Rd:rgba(220,38,38,0.1);
  --B:#2563eb;--Bd:rgba(37,99,235,0.1);
  --P:#7c3aed;--Pd:rgba(124,58,237,0.1);
  --C:#0891b2;--Cd:rgba(8,145,178,0.1);
  --gold:#92400e;--goldD:rgba(146,64,14,0.1);
}
[data-theme="light"] .land-nav,
[data-theme="light"] .sidebar,
[data-theme="light"] .admin-sidebar,
[data-theme="light"] .topbar{background:rgba(255,255,255,0.97);backdrop-filter:blur(24px);box-shadow:0 1px 8px rgba(0,0,0,0.1);border-color:rgba(0,0,0,0.1)}
[data-theme="light"] .land-ticker-bar,
[data-theme="light"] .land-mkt-bar{background:rgba(255,255,255,0.95);backdrop-filter:blur(12px);border-color:rgba(0,0,0,0.08)}
[data-theme="light"] .ticker-wrap{background:#dc2626}
[data-theme="light"] .slide-overlay{background:linear-gradient(to top,rgba(0,0,0,.75) 0%,rgba(0,0,0,.3) 50%,transparent 100%)}
[data-theme="light"] .slide-title{color:#ffffff;text-shadow:0 2px 8px rgba(0,0,0,.5)}
[data-theme="light"] .slide-meta{color:rgba(255,255,255,.8)}
[data-theme="light"] .slide-eyebrow span{color:#fff!important;background:rgba(255,255,255,.2)!important;border-color:rgba(255,255,255,.3)!important}
[data-theme="light"] .slide-cta{background:#059669;color:#fff;border:none}
[data-theme="light"] .auth-card,[data-theme="light"] #page-auth{background:var(--ink)!important}
[data-theme="light"] #page-auth > div > div > div{background:var(--ink2)!important;border-color:rgba(0,0,0,0.12)!important;box-shadow:0 4px 24px rgba(0,0,0,0.08)!important}
[data-theme="light"] .input-field{background:#fff;border-color:var(--b2);color:var(--t)}
[data-theme="light"] .stk-table tr:hover td{background:var(--ink3)}
[data-theme="light"] .chat-ai{background:var(--ink3)}
[data-theme="light"] ::-webkit-scrollbar-thumb{background:var(--ink4)}
[data-theme="light"] .card{background:var(--ink2);border-color:rgba(0,0,0,0.08);box-shadow:0 1px 3px rgba(0,0,0,0.06)}
[data-theme="light"] .news-row{background:var(--ink2);border-color:rgba(0,0,0,0.08)}
[data-theme="light"] .stat-card{background:var(--ink2);border-color:rgba(0,0,0,0.06)}
[data-theme="light"] .nav-item{color:var(--t2)}
[data-theme="light"] .nav-item:hover{background:var(--ink3)}
[data-theme="light"] .nav-item.active{background:var(--Gd);color:var(--G)}
[data-theme="light"] .btn-ghost{border-color:rgba(0,0,0,0.15);color:var(--t2)}
[data-theme="light"] .btn-ghost:hover{background:var(--ink3)}
[data-theme="light"] body{background:var(--ink)}
[data-theme="light"] .story-hero-overlay{background:linear-gradient(to top,rgba(255,255,255,.97) 0%,rgba(255,255,255,.6) 50%,rgba(255,255,255,.1) 100%)}
[data-theme="light"] .story-hero-content .story-title,[data-theme="light"] .story-hero-content h2{color:var(--t)!important;text-shadow:none}
[data-theme="light"] .story-hero-content time,[data-theme="light"] .story-hero-content .story-meta{color:var(--t3)!important}
[data-theme="light"] .story-hero > div:first-child{background:linear-gradient(135deg,#e8edf5 0%,#dde3ed 40%,#e2dde8 100%)!important}
[data-theme="light"] .story-hero .trust-chip{background:rgba(5,150,105,.15);color:#059669}
[data-theme="light"] .story-cat-bar span:first-child{background:rgba(220,38,38,.1)!important;color:#dc2626!important}
[data-theme="light"] .hero-slider{background:var(--ink)}
[data-theme="light"] .slide-bg{background:linear-gradient(135deg,#e0e5ed 0%,#d5dbe5 50%,#e2dde8 100%)!important}
[data-theme="light"] .slide-overlay{background:linear-gradient(135deg,rgba(255,255,255,.93) 0%,rgba(255,255,255,.5) 70%,transparent 100%)!important}
[data-theme="light"] .slide-title{color:#111827!important;text-shadow:none!important}
[data-theme="light"] .slide-meta{color:#374151!important}
[data-theme="light"] .slide-meta span{color:#374151!important}
[data-theme="light"] .slide-trust{background:rgba(5,150,105,.15)!important;border-color:rgba(5,150,105,.3)!important;color:#059669!important}
[data-theme="light"] .slide-eyebrow{background:rgba(220,38,38,.1)!important;border-color:rgba(220,38,38,.25)!important}
[data-theme="light"] .slide-counter{color:rgba(0,0,0,.3)!important}
[data-theme="light"] .story-hero-bg{background:linear-gradient(135deg,#e8edf5 0%,#dde3ed 40%,#e2dde8 100%)!important}
[data-theme="light"] .story-hero-glow{background:radial-gradient(ellipse,rgba(5,150,105,.12) 0%,transparent 65%)!important}
[data-theme="light"] .story-hero-fade{background:linear-gradient(to top,rgba(255,255,255,.95),transparent)!important}
[data-theme="light"] .story-hero-overlay{background:linear-gradient(to top,rgba(255,255,255,.97) 0%,rgba(255,255,255,.6) 50%,rgba(255,255,255,.1) 100%)!important}
[data-theme="light"] .story-hero-content .story-title,[data-theme="light"] .story-hero-content h2{color:#111827!important;text-shadow:none!important}
[data-theme="light"] .story-hero-content time,[data-theme="light"] .story-hero-content .story-meta{color:#6b7280!important}
[data-theme="light"] .story-cat-bar span:first-child{background:rgba(220,38,38,.1)!important;color:#dc2626!important}
[data-theme="light"] .story-cat-bar .trust-chip{background:rgba(5,150,105,.15)!important;color:#059669!important}
[data-theme="light"] .hero-slider .slide-overlay{background:linear-gradient(135deg,rgba(255,255,255,.95) 0%,rgba(255,255,255,.6) 60%,transparent 100%)}
[data-theme="light"] .slider-arrow{background:rgba(0,0,0,.08);border-color:rgba(0,0,0,.15);color:var(--t)}
[data-theme="light"] .slider-arrow:hover{background:rgba(5,150,105,.15);border-color:#059669;color:#059669}
[data-theme="light"] .slider-dot{background:rgba(0,0,0,.2)}
[data-theme="light"] .slider-progress{background:rgba(0,0,0,.08)}
[data-theme="light"] .slide-counter{color:rgba(0,0,0,.3)}

/* Light mode: slider decorative price numbers */
[data-theme="light"] .slide-price-deco{opacity:.45!important;color:#92400e!important}
/* Light mode: featured story price */
[data-theme="light"] .hero-price-num{color:#92400e!important}
/* Light mode: paywall lock-teaser overlay */
[data-theme="light"] .lock-teaser-overlay{background:rgba(240,242,245,.9)!important}
[data-theme="light"] .lock-teaser-overlay div{color:var(--t)!important}
/* Light mode: ad slots */
[data-theme="light"] .ad-slot{background:var(--ink2)!important;border-color:rgba(0,0,0,0.08)!important}
[data-theme="light"] .ad-label{color:var(--t3)!important}
/* Light mode: sidebar blocks */
[data-theme="light"] .sidebar-block{background:var(--ink2)!important;border-color:rgba(0,0,0,0.08)!important}
/* Light mode: section headers */
[data-theme="light"] .section-hdr{background:transparent!important}
[data-theme="light"] .section-hdr-title{color:var(--t)!important}
/* Light mode: cat header */
[data-theme="light"] .cat-header{background:var(--ink2)!important;border-color:rgba(0,0,0,0.08)!important;backdrop-filter:none!important}
[data-theme="light"] .cat-header-title{color:var(--t)!important}
[data-theme="light"] .cat-header-sub{color:var(--t3)!important}
/* Light mode: footer */
[data-theme="light"] footer{background:var(--ink2)!important;border-color:rgba(0,0,0,0.08)!important}
[data-theme="light"] .sf-link{color:var(--t2)!important}
[data-theme="light"] .sf-link:hover{color:var(--G)!important}
/* Light mode: landing body area */
[data-theme="light"] .land-body{background:var(--ink)}
[data-theme="light"] .feature-story{background:var(--ink)}
[data-theme="light"] .land-sidebar{background:var(--ink)}
/* Light mode: filter tabs */
[data-theme="light"] .filter-btn{background:var(--ink2);border-color:rgba(0,0,0,0.1);color:var(--t2)}
[data-theme="light"] .filter-btn.active{background:var(--Gd);border-color:var(--G);color:var(--G)}
/* Light mode: navbar */
[data-theme="light"] .land-nav{background:rgba(255,255,255,.95)!important;border-color:rgba(0,0,0,0.08)!important;backdrop-filter:blur(12px)}
[data-theme="light"] .land-nav a,[data-theme="light"] .land-nav button{color:var(--t2)!important}
/* Light mode: news list items */
[data-theme="light"] .cat-news-list > div{border-color:rgba(0,0,0,0.06)!important}
/* Light mode: more-news paywall */
[data-theme="light"] div[style*="rgba(5,5,14,.7)"]{background:rgba(255,255,255,.85)!important}

/* Theme toggle button */
.theme-toggle{background:var(--ink3);border:1px solid var(--b2);width:36px;height:36px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;transition:all .2s;flex-shrink:0;padding:0}
.theme-toggle:hover{background:var(--ink4);border-color:var(--b3)}

/* ══════════════════════════════════════════
   FEATURE 5 — MOBILE RESPONSIVE
══════════════════════════════════════════ */

/* Hamburger button */
.mobile-hamburger{display:none;background:var(--ink3);border:1px solid var(--b2);width:36px;height:36px;border-radius:8px;cursor:pointer;align-items:center;justify-content:center;font-size:18px;flex-shrink:0;padding:0;color:var(--t)}
.mobile-hamburger:hover{background:var(--ink4)}

/* Mobile sidebar overlay */
.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:9998;backdrop-filter:blur(4px)}
.sidebar-overlay.open{display:block}

/* Tablet (≤1024px) */
@media(max-width:1024px){
  #page-app{grid-template-columns:180px 1fr!important}
  #page-app .sidebar{width:180px!important}
  .land-body{grid-template-columns:minmax(0,1fr) 280px}
  .slide-title{font-size:clamp(18px,2.4vw,26px)}
}

/* Mobile (≤768px) */
@media(max-width:768px){
  .mobile-hamburger{display:flex!important}

  /* Landing page */
  .land-nav{padding:0 12px;gap:8px}
  .land-nav-links{display:none!important}
  .land-body{grid-template-columns:1fr!important;margin-top:108px!important}
  .land-sidebar{display:none!important}
  .feature-story{border-left:none}
  .land-ticker-bar{top:52px}
  .land-mkt-bar{top:82px;height:26px}
  .hero-slider{height:320px;margin-top:112px}
  .slide-content{padding:20px 16px}
  .slide-title{font-size:18px!important}
  .story-title{font-size:16px!important}
  .news-item{padding:12px 14px}
  .ni-title{font-size:13px}
  .cat-header{top:106px!important;padding:10px 14px}

  /* App layout */
  #page-app{grid-template-columns:1fr!important;grid-template-rows:1fr!important}
  #page-app .sidebar{position:fixed!important;right:-260px;top:0;bottom:0;width:260px!important;height:100vh!important;z-index:9999;transition:right .3s ease;flex-direction:column!important;overflow-y:auto!important;overflow-x:hidden!important;box-shadow:-4px 0 20px rgba(0,0,0,.3)}
  #page-app .sidebar.mobile-open{right:0!important}
  #page-app .main-content{width:100%!important;height:100vh!important}
  .topbar{padding:0 12px!important;gap:8px!important}
  .topbar .search-box{display:none!important}
  .mkt-ticker{display:none!important}
  .ticker-wrap{font-size:10px}

  /* Admin layout */
  .admin-shell{grid-template-columns:1fr!important}
  .admin-sidebar{position:fixed!important;right:-260px;top:0;bottom:0;width:260px!important;z-index:9999;transition:right .3s ease}
  .admin-sidebar.open{right:0!important}
  .admin-main{padding:16px!important}

  /* Auth page */
  #page-auth .auth-card,
  #page-auth > div > div > div:nth-child(2){padding:20px!important}

  /* Footer */
  footer > div:first-child{grid-template-columns:1fr!important;gap:24px!important}
}

/* ══════════════════════════════════════════
   FEATURE 6 — FINAL PATCHES (v20260421)
   - Admin light-mode header fix
   - Cairo font site-wide override
   - Login page light-mode + toggle
   - Unified app grid layout
══════════════════════════════════════════ */

/* Cairo everywhere — kill off Spectral/Syne display fonts users don't want */
html, body, .auth-brand-name, .app-brand-name, .land-logo,
h1, h2, h3, h4, h5, h6, p, span, a, li, td, th, div,
button, input, select, textarea, label,
[style*="Spectral"], [style*="Syne"], [style*="Cairo"]{
  font-family: 'Cairo', 'Tajawal', sans-serif !important;
}
/* Keep JetBrains Mono only for market tickers + numeric readouts */
.mkt-prc, .ticker-price, .float-data, .float-ticker, .trend-num,
.mkt-pill .mkt-prc, .hero-price-num, .stk-table td:nth-child(n+2){
  font-family: 'JetBrains Mono', 'Cairo', monospace !important;
}

/* Admin sidebar — fix light-mode dark header bug */
[data-theme="light"] .admin-header{
  background: linear-gradient(180deg, #ffffff 0%, #f5f6fa 100%) !important;
  border-bottom-color: rgba(0,0,0,.08) !important;
}
[data-theme="light"] .admin-sidebar{
  background: #ffffff !important;
  border-left-color: rgba(0,0,0,.08) !important;
}
[data-theme="light"] .admin-sidebar .admin-header span,
[data-theme="light"] .app-sidebar .app-brand-name{
  color: #0f172a !important;
}
[data-theme="light"] .admin-nav-item{color: #374151 !important}
[data-theme="light"] .admin-nav-item:hover{background: rgba(0,0,0,.04) !important; color: #111827 !important}
[data-theme="light"] .admin-nav-item.active{background: rgba(5,150,105,.12) !important; color: #059669 !important}
[data-theme="light"] .nav-section-lbl{color: #6b7280 !important}

/* App sidebar in light mode */
[data-theme="light"] .app-sidebar{
  background: #ffffff !important;
  border-left: 1px solid rgba(0,0,0,.08) !important;
}
[data-theme="light"] .app-topbar{
  background: rgba(255,255,255,.97) !important;
  border-bottom: 1px solid rgba(0,0,0,.08) !important;
  backdrop-filter: blur(10px);
}
[data-theme="light"] .app-main{background: #f5f6fa !important}
[data-theme="light"] .app-user-chip{background: rgba(5,150,105,.05) !important; border-bottom-color: rgba(0,0,0,.06) !important}
[data-theme="light"] .app-user-name{color: #111827 !important}
[data-theme="light"] .topbar-btn{background: #ffffff !important; border-color: rgba(0,0,0,.12) !important; color: #374151 !important}
[data-theme="light"] .topbar-btn:hover{background: #f5f6fa !important; color: #111827 !important}

/* Login page — light mode */
[data-theme="light"] body.auth-body,
[data-theme="light"] .auth-body{
  background: #f5f6fa !important;
}
[data-theme="light"] .auth-visual{
  background: linear-gradient(160deg, #eef1f6 0%, #e3e6ee 50%, #eef1f6 100%) !important;
}
[data-theme="light"] .auth-visual::before{opacity:.3}
[data-theme="light"] .auth-brand-name,
[data-theme="light"] .auth-brand-arabic,
[data-theme="light"] .auth-brand-tagline,
[data-theme="light"] .auth-wordmark{color: #0f172a !important; text-shadow: none !important}
[data-theme="light"] .auth-brand-arabic{color: #475569 !important}
[data-theme="light"] .auth-brand-tagline{color: #b45309 !important}
[data-theme="light"] .auth-panel,
[data-theme="light"] .auth-split > div:last-child{
  background: #ffffff !important;
  color: #111827;
  box-shadow: -8px 0 30px rgba(0,0,0,.06);
}
[data-theme="light"] .auth-greeting-title{color: #0f172a !important}
[data-theme="light"] .auth-greeting-sub{color: #6b7280 !important}
[data-theme="light"] .auth-tabs{background: #f0f2f5 !important; border-color: rgba(0,0,0,.06) !important}
[data-theme="light"] .auth-tab{color: #6b7280 !important}
[data-theme="light"] .auth-tab.active{background: #ffffff !important; color: #059669 !important; box-shadow: 0 2px 8px rgba(0,0,0,.06) !important}
[data-theme="light"] .auth-form input,
[data-theme="light"] .auth-panel input{
  background: #f5f6fa !important;
  border: 1px solid rgba(0,0,0,.1) !important;
  color: #111827 !important;
}
[data-theme="light"] .auth-form input::placeholder{color: #9ca3af !important}
[data-theme="light"] .auth-form label,
[data-theme="light"] .auth-panel label{color: #374151 !important}
[data-theme="light"] .auth-submit,
[data-theme="light"] .auth-panel button[type="submit"]{
  background: linear-gradient(135deg,#f59e0b 0%,#d97706 100%) !important;
  color: #ffffff !important;
  box-shadow: 0 4px 16px rgba(217,119,6,.3) !important;
}
[data-theme="light"] .auth-trust,
[data-theme="light"] .auth-trust-text{color: #475569 !important}
[data-theme="light"] .auth-back-home{color: #6b7280 !important}
[data-theme="light"] .auth-back-home:hover{color: #059669 !important}

/* Floating theme toggle on login page — top-right, opposite side from logo */
.login-theme-toggle{
  position: fixed; top: 20px; right: 20px; z-index: 1000;
  width: 40px; height: 40px; border-radius: 50%;
  background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.15);
  color: #e8a020; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  font-size: 18px; transition: all .2s;
  backdrop-filter: blur(10px);
}
.login-theme-toggle:hover{background: rgba(255,255,255,.14); transform: scale(1.05)}
[data-theme="light"] .login-theme-toggle{
  background: rgba(0,0,0,.05) !important;
  border-color: rgba(0,0,0,.1) !important;
  color: #b45309 !important;
}

/* Unified app grid — RTL: declared col-1 sits on the RIGHT inline-start.
   So 220px first = sidebar on right, 1fr second = main filling the rest to the left. */
#page-app.active{
  display: grid !important;
  grid-template-columns: 220px 1fr !important;
  grid-template-rows: 52px 1fr !important;
  width: 100vw !important; max-width: 100vw !important;
  height: 100vh !important; overflow: hidden !important;
  inset: 0 !important;
}
#page-app.active .app-sidebar{
  grid-column: 1 !important; grid-row: 1 / 3 !important;
  position: relative !important; top: auto !important; right: auto !important;
  bottom: auto !important; left: auto !important;
  width: auto !important; height: auto !important;
}
#page-app.active .app-topbar{
  grid-column: 2 !important; grid-row: 1 !important;
  min-width: 0 !important; width: auto !important;
  position: relative !important;
}
#page-app.active .app-main{
  grid-column: 2 !important; grid-row: 2 !important;
  min-width: 0 !important; width: auto !important;
  overflow-y: auto !important; overflow-x: hidden !important;
}

/* Small mobile (≤480px) */
@media(max-width:480px){
  .card{padding:14px!important}
  .stat-card{padding:12px!important}
  .hero-slider{height:280px;margin-top:96px}
  .slide-content{padding:16px 12px}
  .slide-title{font-size:16px!important}
  .slide-cta{padding:8px 16px;font-size:12px}
  .land-nav{height:48px}
  .land-ticker-bar{top:48px}
  .land-mkt-bar{top:78px}
  .topbar{height:46px!important;min-height:46px!important}
}


/* ── Global Cairo font override ── */
/* Cairo everywhere by default. JetBrains Mono only when explicitly requested for tickers. */
html, body, button, input, textarea, select, .auth-body, .auth-brand-tagline,
.mkt-sym, .mkt-prc, .float-data, .float-ticker, .nav-section-lbl,
.app-brand-name, .app-brand-sub, .app-user-name, .app-user-plan,
.auth-wordmark, .auth-brand-name, .auth-brand-arabic, .auth-greeting-title,
.auth-greeting-sub, .auth-label, .auth-input, .auth-submit, .auth-tab,
.auth-error, .auth-trust-text, .auth-forgot, .auth-footer-link, .auth-back-home{
  font-family: 'Cairo', 'Segoe UI', Tahoma, Arial, sans-serif !important;
}

/* ══════════════════════════════════════════════════════════════════
   MOBILE RESPONSIVE — v20260424
   Slide-in drawer sidebars for user + admin dashboards
   Reflowed landing grid, simplified topbars, larger tap targets
════════════════════════════════════════════════════════════════════ */

/* Mobile hamburger button — shared between user + admin dashboards */
.m-hamburger{
  display:none;
  width:38px; height:38px;
  background:var(--ink3); border:1px solid var(--b2); border-radius:8px;
  color:var(--t); cursor:pointer;
  align-items:center; justify-content:center;
  font-size:18px; font-weight:700;
  flex-shrink:0;
  transition:background .15s;
}
.m-hamburger:hover{background:var(--ink4)}
.m-hamburger:active{transform:scale(.96)}
[data-theme="light"] .m-hamburger{
  background:#ffffff; border-color:rgba(0,0,0,.12); color:#111827;
}

/* Admin-specific floating hamburger (admin has no topbar) */
.m-admin-hamburger{
  display:none;
  position:fixed; top:12px; right:12px;
  width:44px; height:44px;
  background:rgba(5,5,16,.92); border:1px solid var(--b2); border-radius:10px;
  color:var(--A); cursor:pointer;
  align-items:center; justify-content:center;
  font-size:20px;
  z-index:10000;
  backdrop-filter:blur(10px);
  box-shadow:0 4px 16px rgba(0,0,0,.3);
}
[data-theme="light"] .m-admin-hamburger{
  background:rgba(255,255,255,.95); color:#d97706; border-color:rgba(0,0,0,.1);
}

/* Drawer backdrop (both dashboards) */
.m-backdrop{
  display:none;
  position:fixed; inset:0;
  background:rgba(0,0,0,.55);
  z-index:9998;
  backdrop-filter:blur(3px);
  animation:mFade .2s ease;
}
.m-backdrop.open, .m-backdrop.m-show{display:block}
@keyframes mFade{from{opacity:0}to{opacity:1}}

/* ── Mobile layout: ≤ 860px ────────────────────────────── */
@media (max-width: 860px){

  /* Show hamburger buttons */
  .m-hamburger{display:inline-flex}
  .m-admin-hamburger{display:inline-flex}

  /* ───── USER DASHBOARD ───── */
  #page-app.active,
  #page-app{
    grid-template-columns: 1fr !important;
    grid-template-rows: 52px 1fr !important;
    width:100vw !important;
  }
  #page-app.active .app-sidebar,
  .app-sidebar{
    position:fixed !important;
    top:0 !important; right:-280px !important; left:auto !important; bottom:0 !important;
    width:280px !important; height:100vh !important;
    z-index:9999 !important;
    transition:right .28s ease !important;
    box-shadow:-8px 0 24px rgba(0,0,0,.35);
    grid-column:auto !important; grid-row:auto !important;
  }
  #page-app.active .app-sidebar.m-open,
  .app-sidebar.m-open{ right:0 !important }
  #page-app.active .app-topbar{
    grid-column:1 !important; grid-row:1 !important;
    padding:0 10px !important; gap:8px !important;
  }
  #page-app.active .app-main{
    grid-column:1 !important; grid-row:2 !important;
    padding:14px !important;
  }

  /* Topbar slims on mobile */
  .app-topbar-mkt{display:none !important}
  .app-topbar-title #page-title{font-size:14px !important}
  .app-topbar-actions{gap:4px !important}
  .topbar-btn{width:36px !important; height:36px !important}

  /* ───── ADMIN DASHBOARD ───── */
  .admin-shell{display:block !important; height:auto !important; min-height:100vh}
  .admin-sidebar{
    position:fixed !important;
    top:0 !important; right:-300px !important; left:auto !important; bottom:0 !important;
    width:300px !important; height:100vh !important;
    z-index:9999 !important;
    transition:right .28s ease !important;
    box-shadow:-8px 0 24px rgba(0,0,0,.35);
  }
  .admin-sidebar.m-open{right:0 !important}
  .admin-main{
    padding:60px 14px 20px !important;  /* top padding leaves room for floating hamburger */
    width:100% !important;
    min-height:100vh;
  }

  /* Larger tap targets inside drawers */
  .nav-item, .admin-nav-item{
    padding:12px 14px !important;
    font-size:13px !important;
    min-height:44px;
  }

  /* ───── LANDING PAGE ───── */
  .land-nav{height:52px; padding:0 12px; gap:6px}
  .land-nav-links{display:none !important}
  .land-logo{font-size:16px !important}
  .land-logo img{height:36px !important}
  .land-ticker-bar{top:52px; height:30px; font-size:11px}
  .land-mkt-bar{top:82px; height:28px; overflow-x:auto; white-space:nowrap; scrollbar-width:none}
  .land-mkt-bar::-webkit-scrollbar{display:none}
  .land-body{
    grid-template-columns:1fr !important;
    margin-top:112px !important;
    padding:12px !important;
    gap:12px !important;
  }
  .land-sidebar{display:none !important}
  .hero-slider{height:300px; margin-top:112px}
  .slide-content{padding:18px 14px !important}
  .slide-title{font-size:16px !important; line-height:1.4 !important}
  .slide-meta{font-size:11px !important; flex-wrap:wrap}
  .slide-eyebrow{font-size:10px !important}
  .slide-cta{padding:9px 16px !important; font-size:12px !important}

  /* News grid collapses to 1 column on small phones */
  .cat-news-list{
    grid-template-columns:1fr !important;
    gap:10px !important;
  }
  .nc-card{padding:14px !important}
  .cat-header{top:110px !important; padding:10px 2px !important}
  .cat-header-title{font-size:14px !important}
  .cat-header-sub{font-size:10px !important}

  /* Footer stacks */
  footer > div:first-child{
    grid-template-columns:1fr !important;
    gap:22px !important;
    text-align:center;
  }

  /* Hide the floating market-ticker overlay if any */
  .mkt-ticker, .ticker-wrap{font-size:10px}

  /* ───── LOGIN PAGE ───── */
  .auth-split{grid-template-columns:1fr !important}
  .auth-visual{display:none !important}
  .auth-panel{padding:28px 20px !important}
  .auth-panel-top{top:14px !important; left:14px !important; right:14px !important}
  .auth-greeting-title{font-size:22px !important}

  /* Upgrade modal on mobile */
  .modal-card{max-width:100% !important; padding:20px !important}

  /* Dashboard cards inside app-main */
  .dash-grid, .stat-grid{
    grid-template-columns:1fr !important;
    gap:10px !important;
  }
  .stat-card{padding:14px !important}
  .card{padding:14px !important}

  /* Admin internal tables scroll horizontally */
  .admin-main table{min-width:520px}
  .admin-main .tbl-wrap, .admin-main table{
    display:block; overflow-x:auto; -webkit-overflow-scrolling:touch;
  }

  /* Theme toggle stays tappable */
  .theme-toggle{width:36px; height:36px; font-size:16px}
}

/* Very small phones (≤ 400px) — even tighter spacing */
@media (max-width: 400px){
  #page-app.active .app-main{padding:10px !important}
  .admin-main{padding:56px 10px 16px !important}
  .nc-card{padding:12px !important}
  .hero-slider{height:260px}
  .slide-title{font-size:15px !important}
  .app-brand-name, .admin-header span{font-size:11px !important}
}

/* ══════════════════════════════════════════════════════════════════
   MOBILE RESPONSIVE v2 — v20260427
   Comprehensive fixes: KPI overflow, slider arrows, login overlap,
   inline-grid 2-col reflow, text clamp
════════════════════════════════════════════════════════════════════ */

/* ── Global mobile safety (always on, never breaks desktop) ── */
html, body{overflow-x:hidden;max-width:100vw}

/* ── Hero slider: arrows + CTA repositioned at ≤860 ── */
@media (max-width: 860px){

  /* Arrows move from vertical-center to lower corners so they never overlap title */
  .slider-arrow{
    top:auto !important;
    bottom:14px !important;
    transform:none !important;
    width:36px !important; height:36px !important;
    font-size:14px !important;
    background:rgba(5,5,14,.72) !important;
  }
  .slider-arrow.prev{right:12px !important}
  .slider-arrow.next{left:12px !important}

  /* Dots: move up so CTA doesn't collide */
  .slider-dots{bottom:58px !important}

  /* Slide content: add room at bottom for arrows + dots + CTA */
  .slide-content{padding-bottom:84px !important}

  /* CTA: center, full-width-ish, sit ABOVE dots/arrows */
  .slide-cta{
    display:flex !important; width:auto !important;
    margin:12px auto 0 !important;
    justify-content:center !important;
  }

  /* ── Landing top nav: show Login button alongside Signup ── */
  .land-nav .btn-ghost.m-show-login{display:inline-flex !important;padding:6px 12px;font-size:12px}

  /* ── Login page: stop theme-toggle from overlapping top row ── */
  .login-theme-toggle{
    top:auto !important; bottom:18px !important;
    right:18px !important;
    width:42px !important; height:42px !important;
  }
  .auth-panel-top{
    top:14px !important; left:16px !important; right:16px !important;
    gap:10px; flex-wrap:wrap;
  }
  .auth-wordmark{font-size:16px !important}
  .auth-back-home{font-size:11px !important}

  /* ── User dashboard topbar: shrink action buttons ── */
  #page-app .app-topbar{padding:0 10px !important; gap:6px !important}
  #page-app .topbar-btn{
    width:32px !important; height:32px !important;
    padding:0 !important; font-size:11px !important;
  }
  #page-app .app-topbar-title{flex:1; min-width:0; overflow:hidden}
  #page-app .app-topbar-title #page-title{
    font-size:13px !important;
    white-space:nowrap; overflow:hidden; text-overflow:ellipsis; display:block;
  }
  #page-app .app-topbar-mkt{display:none !important}

  /* ── App + Admin main content: overflow safety ── */
  .app-main, .admin-main{
    min-width:0 !important;
    overflow-x:hidden !important;
    width:100% !important;
    max-width:100vw !important;
  }
  .app-main > *, .admin-main > *{max-width:100%}

  /* ── Inline-styled repeat(N,1fr) grids → 2 columns on mobile ── */
  .app-main [style*="repeat(3,1fr)"],
  .app-main [style*="repeat(4,1fr)"],
  .app-main [style*="repeat(5,1fr)"],
  .app-main [style*="repeat(3, 1fr)"],
  .app-main [style*="repeat(4, 1fr)"],
  .app-main [style*="repeat(5, 1fr)"],
  .admin-main [style*="repeat(3,1fr)"],
  .admin-main [style*="repeat(4,1fr)"],
  .admin-main [style*="repeat(5,1fr)"],
  .admin-main [style*="repeat(3, 1fr)"],
  .admin-main [style*="repeat(4, 1fr)"],
  .admin-main [style*="repeat(5, 1fr)"]{
    grid-template-columns: repeat(2, minmax(0,1fr)) !important;
    gap:10px !important;
  }

  /* Two-column charts/splits collapse to stacked */
  .app-main [style*="grid-template-columns:1.4fr 1fr"],
  .app-main [style*="grid-template-columns:1fr 1fr"],
  .app-main [style*="grid-template-columns:2fr 1fr"],
  .app-main [style*="grid-template-columns:1fr 2fr"],
  .admin-main [style*="grid-template-columns:1.4fr 1fr"],
  .admin-main [style*="grid-template-columns:1fr 1fr"],
  .admin-main [style*="grid-template-columns:2fr 1fr"],
  .admin-main [style*="grid-template-columns:1fr 2fr"]{
    grid-template-columns: minmax(0,1fr) !important;
  }

  /* ── Stat/KPI cards: prevent cramped vertical text ── */
  .stat-card, .admin-main .stat-card{
    padding:12px 14px !important;
    min-width:0;
    overflow:hidden;
  }
  .stat-card *, .admin-main .stat-card *{min-width:0; max-width:100%}
  /* Big numbers inside KPI cards: clamp size + no wrap */
  .stat-card > div[style*="font-size:30px"],
  .stat-card > div[style*="font-size:24px"],
  .stat-card > div[style*="font-size:28px"],
  .admin-main .stat-card > div[style*="font-size:30px"],
  .admin-main .stat-card > div[style*="font-size:24px"],
  .admin-main .stat-card > div[style*="font-size:28px"]{
    font-size:clamp(18px, 6vw, 24px) !important;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:clip;
  }
  /* Header rows inside stat-card that must stay horizontal */
  .stat-card > div[style*="display:flex"]{flex-wrap:nowrap !important}
  .stat-card > div[style*="justify-content:space-between"]{gap:6px}

  /* Card internal grids shrink more */
  .card [style*="repeat(4,1fr)"],
  .card [style*="repeat(3,1fr)"]{
    grid-template-columns: repeat(2, minmax(0,1fr)) !important;
  }

  /* ── Admin sidebar header: prevent logo/toggle overlap ── */
  #page-admin .admin-header{
    padding:10px 12px !important;
    flex-wrap:wrap; gap:8px;
  }
  #page-admin .admin-header img{height:32px !important}
  #page-admin .admin-header .theme-toggle{
    width:32px !important; height:32px !important; font-size:14px !important;
  }

  /* ── Analyzer page: back-arrow next to input ── */
  .analyzer-back, [onclick*="backToFeed"], .news-row .ic-back{
    position:static !important;
    transform:none !important;
  }

  /* ── Bias map / commodity cards: always fill track, never overflow ── */
  .bias-card, .commodity-card, .cmd-card{min-width:0; overflow:hidden}
  .bias-card *, .commodity-card *, .cmd-card *{min-width:0; max-width:100%}
  .cmd-card [style*="font-size:34px"],
  .cmd-card [style*="font-size:28px"],
  .commodity-card [style*="font-size:34px"],
  .commodity-card [style*="font-size:28px"]{
    font-size:clamp(18px, 7vw, 26px) !important;
    white-space:nowrap;
  }

  /* ── Editorial newsletter: force flex-row splits to stack ── */
  #admin-content > div[style*="display:flex"][style*="gap:"]{flex-wrap:wrap}
  #admin-content aside, #admin-content > div > aside{width:100% !important; max-width:100% !important}

  /* ── Tables inside admin always scroll horizontally ── */
  .admin-main table{display:block; overflow-x:auto; max-width:100%; min-width:0}
}

/* ── Very small phones (≤ 480px): single-col everything ── */
@media (max-width: 480px){
  .app-main [style*="repeat(3,1fr)"],
  .app-main [style*="repeat(4,1fr)"],
  .app-main [style*="repeat(5,1fr)"],
  .admin-main [style*="repeat(3,1fr)"],
  .admin-main [style*="repeat(4,1fr)"],
  .admin-main [style*="repeat(5,1fr)"]{
    grid-template-columns: minmax(0,1fr) !important;
  }
  .stat-card > div[style*="font-size:30px"],
  .admin-main .stat-card > div[style*="font-size:30px"]{
    font-size:22px !important;
  }
  .hero-slider{height:280px !important}
  .slide-title{font-size:15px !important}
}

/* ══════════════════════════════════════════════════════════════════
   MOBILE RESPONSIVE v3 — v20260428 patches
   - Catch ALL 2-track grids (1.6fr 1fr etc.)
   - Tab-rows become horizontally scrollable
   - Dashboard news card + markets panel stack on mobile
═══════════════════════════════════════════════════════════════════ */
@media (max-width: 860px){

  /* Catch-all for ANY 2-column N fr M fr grid inside dashboards → stack */
  .app-main [style*="grid-template-columns:1.6fr"],
  .app-main [style*="grid-template-columns:1.5fr"],
  .app-main [style*="grid-template-columns:1.2fr"],
  .app-main [style*="grid-template-columns:.6fr"],
  .app-main [style*="grid-template-columns:0.6fr"],
  .admin-main [style*="grid-template-columns:1.6fr"],
  .admin-main [style*="grid-template-columns:1.5fr"],
  .admin-main [style*="grid-template-columns:1.2fr"]{
    grid-template-columns: minmax(0,1fr) !important;
  }

  /* Tab rows (editorial, newsletter, etc.) scroll horizontally */
  .tab-row{
    overflow-x:auto !important;
    flex-wrap:nowrap !important;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:none;
    justify-content:flex-start !important;
  }
  .tab-row::-webkit-scrollbar{display:none}
  .tab-row .tab-btn{flex:0 0 auto !important; white-space:nowrap}

  /* Market rows: prevent clipping — allow value wrap */
  .app-main .card [style*="justify-content:space-between"][style*="align-items:center"]{
    gap:8px; flex-wrap:wrap;
  }

  /* News card inside overview: trust ring + title row must stay horizontal,
     title gets full remaining width */
  .app-main .card [style*="display:flex"][style*="gap:12px"]{
    flex-wrap:nowrap !important;
  }
  .app-main .card [style*="display:flex"][style*="gap:12px"] > [style*="flex:1"]{
    min-width:0 !important; flex:1 !important;
  }

  /* Ensure the active tab pill doesn't overflow its container */
  .tab-btn.active{box-shadow:none !important}
}

/* Extra narrow (≤ 520px): force dashboard overview 2-col grids to single col */
@media (max-width: 520px){
  .app-main [style*="1.6fr"],
  .app-main [style*="1.5fr"],
  .app-main [style*="grid-template-columns:1fr 1fr"],
  .admin-main [style*="grid-template-columns:1fr 1fr"]{
    grid-template-columns: minmax(0,1fr) !important;
  }
}

/* ═══════════════════════════════════════════════════════════════════
   BASIRA DESKTOP — Al Jazeera editorial aesthetic overlay (v20260434)
   Layers on top of existing theme tokens. Keeps all legacy selectors
   working; introduces Cairo display + JetBrains Mono + --aj-red accent.
═══════════════════════════════════════════════════════════════════ */
:root{
  --aj-red:#ee1c25;
  --aj-red-dark:#c41820;
  --aj-red-soft:rgba(238,28,37,.12);
  --aj-red-border:rgba(238,28,37,.28);
  --aj-cream:#f7f3ea;
  --aj-ink:#0e0e12;
}
html[data-theme="light"]{
  --R:#ee1c25;
  --Rd:rgba(238,28,37,.1);
}
html:not([data-theme="light"]){
  --R:#ee1c25;
  --Rd:rgba(238,28,37,.15);
}

/* Body typography → Cairo, numeric → JetBrains Mono */
body{font-family:'Cairo','Tajawal','Segoe UI',sans-serif;-webkit-font-smoothing:antialiased}
.mkt-sym,.mkt-prc,.mkt-chg,.mkt-card-price,.slide-trust,.trend-num{font-family:'JetBrains Mono',ui-monospace,monospace}

/* ── TOP RIBBON (land-nav) — sticky, AJ red underline ── */
.land-nav{
  position:fixed;top:0;left:0;right:0;z-index:700;
  display:flex;align-items:center;gap:12px;
  height:56px;padding:0 20px;
  background:var(--ink);
  border-bottom:1px solid var(--b);
  backdrop-filter:saturate(140%) blur(6px);
  -webkit-backdrop-filter:saturate(140%) blur(6px);
}
.land-nav::after{
  content:"";position:absolute;right:24px;bottom:-1px;
  width:96px;height:3px;background:var(--aj-red);border-radius:2px;
  box-shadow:0 0 0 4px transparent;
}
html[data-theme="light"] .land-nav{background:var(--aj-cream);border-bottom-color:rgba(0,0,0,.08)}

/* Category nav pills: flatter, AJ-style */
.land-nav .nav-link,.land-nav .nav-dropdown-btn{
  font-family:'Cairo',sans-serif;font-weight:800;letter-spacing:-.01em;
  transition:color .15s;
}
.land-nav .nav-link:hover,.land-nav .nav-dropdown-btn:hover{color:var(--aj-red)}

/* THE PULSE wordmark sub-label — red */
.land-nav [style*="THE PULSE"]{color:var(--aj-red)!important}

/* ── BREAKING/LIVE TICKER — AJ slow marquee ── */
.land-ticker-bar{
  background:var(--ink2);border-bottom:1px solid var(--b);
  border-top:1px solid var(--b);
}
.land-ticker-bar .ticker-label{background:var(--aj-red)!important}
.ticker-inner-txt{animation-duration:95s!important;animation-timing-function:linear!important}

/* ── HERO SLIDER — tighter editorial frame ── */
.hero-slider{
  border-radius:0;
  border-top:0;border-bottom:1px solid var(--b);
  box-shadow:none;
}
.slide-eyebrow{
  font-family:'Cairo',sans-serif;font-weight:900;letter-spacing:.04em;
  text-transform:none;font-size:11px;
  padding:5px 12px;border-radius:3px;
}
.slide-title{
  font-family:'Cairo',sans-serif;font-weight:900;line-height:1.25;
  letter-spacing:-.02em;
}
.slide-cta{
  background:var(--aj-red);color:#fff;
  font-family:'Cairo',sans-serif;font-weight:800;
  border-radius:3px;padding:10px 18px;
  box-shadow:0 4px 14px rgba(238,28,37,.35);
}

/* ── MAIN BODY GRID — editorial hero row + 3-col news ── */
.land-body{
  max-width:1400px;margin:0 auto;
  display:grid;
  grid-template-columns:minmax(0,1fr) 320px;
  gap:28px;padding:24px 24px 40px;
}
@media(max-width:980px){
  .land-body{grid-template-columns:minmax(0,1fr);padding:16px}
  .land-sidebar{order:2}
}

/* Category header — blurry sticky bar, pushed up so it doesn't cover card titles */
.cat-header{
  padding:14px 20px 12px!important;
  border-bottom:1px solid var(--b);
  background:rgba(3,3,13,.72)!important;
  backdrop-filter:saturate(160%) blur(14px)!important;
  -webkit-backdrop-filter:saturate(160%) blur(14px)!important;
  position:sticky!important;
  top:56px!important;   /* sits right under the fixed land-nav (56px tall) — was 126px */
  z-index:10;
  margin-bottom:24px!important;
}
html[data-theme="light"] .cat-header{
  background:rgba(247,243,234,.75)!important;
  border-bottom-color:rgba(0,0,0,.08);
}
/* Breathing room so the first row of cards clears the sticky bar */
.cat-page{position:relative}
.cat-news-list{padding-top:22px!important}
.cat-header-title{
  font-family:'Cairo',sans-serif;font-weight:900;
  font-size:22px;letter-spacing:-.02em;
}

/* News list — CSS MASONRY via column-count so tall cards don't leave empty gaps next to short ones */
.cat-news-list{
  display:block!important;
  column-count:3;
  column-gap:18px;
  padding:18px 20px 22px;
}
.cat-news-list > *{
  display:inline-block;   /* required for column flow */
  width:100%;
  break-inside:avoid;
  -webkit-column-break-inside:avoid;
  page-break-inside:avoid;
  margin:0 0 18px;
  vertical-align:top;
}
.cat-news-list .nc-card{height:auto!important}
@media(max-width:1100px){.cat-news-list{column-count:2}}
@media(max-width:640px){.cat-news-list{column-count:1}}

.cat-news-list .news-item{
  background:var(--ink2);
  border:1px solid var(--b);
  border-radius:6px;
  padding:14px;
  display:flex;flex-direction:column;gap:10px;
  transition:transform .18s,border-color .18s,box-shadow .18s;
}
.cat-news-list .news-item:hover{
  border-color:var(--aj-red-border);
  box-shadow:0 6px 20px rgba(0,0,0,.18);
  transform:translateY(-2px);
}
.cat-news-list .news-item .ni-cat{
  font-family:'Cairo',sans-serif;font-weight:900;font-size:11px;
  letter-spacing:.04em;color:var(--aj-red)!important;
  text-transform:uppercase;
}
.cat-news-list .news-item .ni-title{
  font-family:'Cairo',sans-serif;font-weight:800;line-height:1.4;
  font-size:15px;letter-spacing:-.01em;
}
.cat-news-list .news-item .ni-footer{
  font-size:11px;color:var(--t3);display:flex;gap:6px;flex-wrap:wrap;
}

/* ── SIDEBAR ── */
.land-sidebar .sb-title{
  font-family:'Cairo',sans-serif;font-weight:900;
  font-size:13px;letter-spacing:.04em;
  border-right:3px solid var(--aj-red);
  padding-right:10px;margin-bottom:12px;
}
.land-sidebar .sidebar-block{
  background:var(--ink2);border:1px solid var(--b);
  border-radius:6px;padding:16px;margin-bottom:16px;
}

/* ── TRENDING LIST — AJ numbered ── */
.trend-item{padding:10px 0;border-bottom:1px solid var(--b);display:flex;gap:12px;align-items:flex-start;cursor:pointer}
.trend-item:last-child{border-bottom:0}
.trend-num{
  font-family:'JetBrains Mono',monospace;font-weight:700;
  color:var(--aj-red);font-size:18px;flex-shrink:0;line-height:1;
}
.trend-title{font-family:'Cairo',sans-serif;font-weight:700;font-size:13px;line-height:1.5}
.trend-cnt{font-size:11px;color:var(--t3);margin-top:4px}

/* ── FOOTER — minimalist with AJ red rule ── */
footer{
  background:var(--ink2)!important;
  border-top:3px solid var(--aj-red)!important;
}
.sf-link{
  display:block;font-family:'Cairo',sans-serif;font-weight:700;
  font-size:13px;color:var(--t2);background:none;border:0;padding:6px 0;
  cursor:pointer;text-align:right;
}
.sf-link:hover{color:var(--aj-red)}

/* ── ADMIN CHROME RESKIN ── */
.admin-sidebar{
  background:var(--ink2)!important;
  border-top:3px solid var(--aj-red)!important;
  border-left:1px solid var(--b);
}
html[dir="rtl"] .admin-sidebar{border-left:0;border-right:0}
.admin-sidebar .admin-header{background:var(--ink);border-bottom:1px solid var(--b)!important}
.admin-sidebar .nav-section-lbl{
  font-family:'Cairo',sans-serif;font-weight:900;font-size:10px;
  letter-spacing:.14em;color:var(--aj-red);
  padding:14px 10px 6px;text-transform:uppercase;
}
.admin-nav-item{
  font-family:'Cairo',sans-serif;font-weight:700;font-size:13px;
  padding:10px 12px;border-radius:4px;transition:background .15s,color .15s;
  color:var(--t2);text-align:right;display:flex;align-items:center;gap:8px;
}
.admin-nav-item:hover{background:var(--ink3);color:var(--t)}
.admin-nav-item.active{background:var(--aj-red-soft);color:var(--aj-red);border-right:3px solid var(--aj-red)}

/* ADMIN badge sub-label in red */
.admin-header [style*="ADMIN"]{color:var(--aj-red)!important}

/* Admin main content area uses Cairo */
.admin-main,.admin-main *{font-family:'Cairo','Tajawal',sans-serif}

/* Section header accent in admin */
.admin-main h1,.admin-main h2,.admin-main h3{
  font-family:'Cairo',sans-serif;font-weight:900;letter-spacing:-.02em;
}

/* ═══════════════════════════════════════════════════════════════════
   BASIRA DESKTOP — Landing layout fixes (v20260436)
   Resolves: invisible nav strip, fixed-chrome content overlap,
   broken-image placeholders.
═══════════════════════════════════════════════════════════════════ */

/* Push landing content below the fixed nav (56px) + ticker (30px) */
#page-landing{padding-top:86px}
@media(max-width:768px){#page-landing{padding-top:82px}}

/* Consolidated NAV — solid background, clear text, AJ red underline.
   Overrides the legacy .land-nav rule (~line 82) and earlier overlay. */
.land-nav{
  position:fixed;top:0;left:0;right:0;z-index:700;
  display:flex;align-items:center;gap:14px;
  height:56px;padding:0 22px;
  background:#03030d;
  border-bottom:1px solid rgba(255,255,255,.08);
  backdrop-filter:none;-webkit-backdrop-filter:none;
  box-shadow:0 1px 0 rgba(0,0,0,.4);
}
html[data-theme="light"] .land-nav{
  background:#f7f3ea;
  border-bottom-color:rgba(0,0,0,.1);
}
.land-nav::after{
  content:"";position:absolute;right:22px;bottom:-1px;
  width:120px;height:3px;background:var(--aj-red,#ee1c25);border-radius:0;
}
.land-nav .nav-link,.land-nav .nav-dropdown-btn{
  color:var(--t);font-family:'Cairo',sans-serif;font-weight:700;
  font-size:13px;letter-spacing:0;
}
.land-nav .nav-link:hover,.land-nav .nav-dropdown-btn:hover{color:var(--aj-red,#ee1c25)}
html[data-theme="light"] .land-nav .nav-link,
html[data-theme="light"] .land-nav .nav-dropdown-btn{color:#111!important}

/* Consolidated TICKER — solid, readable */
.land-ticker-bar{
  position:fixed;top:56px;left:0;right:0;z-index:499;
  height:30px;display:flex;align-items:center;overflow:hidden;
  background:#07071a;border-bottom:1px solid rgba(255,255,255,.06);
  border-top:0;
}
html[data-theme="light"] .land-ticker-bar{background:#ede6d6;border-bottom-color:rgba(0,0,0,.08)}
.land-ticker-bar .ticker-inner-txt{
  color:var(--t);font-family:'Cairo',sans-serif;font-weight:700;font-size:12px;
  animation:ticker 95s linear infinite;
}
html[data-theme="light"] .land-ticker-bar .ticker-inner-txt{color:#111}

/* Hero slider: no extra desktop margin now that #page-landing is offset */
@media(min-width:769px){.hero-slider{margin-top:0!important}}

/* News card IMAGE safety — never show browser broken-image icon */
.cat-news-list img[src=""],
.cat-news-list img:not([src]),
.news-item img[src=""],
.news-item img:not([src]){display:none!important}
.cat-news-list img,.news-item img{
  background:var(--ink3);
  min-height:0;
}

/* Light-mode landing body */
html[data-theme="light"] #page-landing{background:#faf8f3}
