/* MintCues — The Sovereign Archive */
/* Exact match to design screenshots */
/* Primary #002046 · Secondary #3b6934 · Surface #f7f9fb */

@import url('https://fonts.googleapis.com/css2?family=Newsreader:ital,opsz,wght@0,6..72,300..800;1,6..72,300..800&family=Manrope:wght@200..800&display=swap');

:root {
  --primary:            #002046;
  --primary-mid:        #1b365d;
  --primary-dim:        #aec7f7;
  --on-primary:         #ffffff;
  --secondary:          #3b6934;
  --secondary-container:#b9eeab;
  --on-secondary-cont:  #3f6d38;
  --surface:            #f7f9fb;
  --surface-low:        #f2f4f6;
  --surface-mid:        #eceef0;
  --surface-high:       #e6e8ea;
  --surface-highest:    #e0e3e5;
  --white:              #ffffff;
  --on-surface:         #191c1e;
  --on-surface-var:     #44474e;
  --outline:            #74777f;
  --outline-var:        #c4c6cf;
  --error:              #ba1a1a;
  --tertiary:           #162132;
  --font-h:  'Newsreader', Georgia, serif;
  --font-b:  'Manrope', system-ui, sans-serif;
  /* No borders — depth via background only */
  --shadow: 0 12px 32px -4px rgba(25,28,30,.06);
  --shadow-sm: 0 2px 8px -2px rgba(25,28,30,.04);
  --shadow-lg: 0 24px 56px -8px rgba(25,28,30,.10);
  --r: .25rem; --r-sm: .125rem; --r-md: .375rem; --r-lg: .5rem; --r-xl: .75rem;
  --ease: .22s ease;

  /* ── Compatibility aliases (older template vars) ── */
  --font-headline:              'Newsreader', Georgia, serif;
  --font-body:                  'Manrope', system-ui, sans-serif;
  --font-mono:                  'DM Mono', monospace;
  --primary-container:          #1b365d;
  --on-primary-container:       #87a0cd;
  --surface-container-lowest:   #ffffff;
  --surface-container-low:      #f2f4f6;
  --surface-container:          #eceef0;
  --surface-container-high:     #e6e8ea;
  --surface-container-highest:  #e0e3e5;
  --on-surface-variant:         #44474e;
  --outline-variant:            #c4c6cf;
  --on-secondary-container:     #3f6d38;
  --secondary-fixed-dim:        #a1d494;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--font-b);background:var(--surface);color:var(--on-surface);line-height:1.7;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
button{cursor:pointer;font-family:inherit;border:none;background:none}
input,select,textarea{font-family:inherit}
img{display:block;max-width:100%}

/* ── Layout ── */
.wrap{max-width:1280px;margin:0 auto;padding:0 2rem}
.wrap-sm{max-width:900px;margin:0 auto;padding:0 2rem}
.wrap-xs{max-width:680px;margin:0 auto;padding:0 2rem}

/* ── NAV — Glassmorphism, exact match ── */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:200;
  background:rgba(247,249,251,.88);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid rgba(196,198,207,.15);
}
.nav-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem;max-width:1280px;margin:0 auto;padding:0 1.25rem;height:64px;flex-wrap:nowrap}
.nav-logo{font-family:var(--font-h);font-size:1.25rem;font-weight:600;font-style:italic;color:var(--primary);letter-spacing:-.01em;display:flex;align-items:center;gap:.625rem;flex:0 0 auto;white-space:nowrap}
.nav-logo img{height:32px;width:auto;max-width:160px;object-fit:contain}
.nav-links{display:flex;align-items:center;justify-content:center;gap:.125rem;flex:1 1 auto;min-width:0;flex-wrap:nowrap;overflow:hidden}
.nav-link{font-size:.78rem;font-weight:500;color:var(--on-surface-var);padding:.35rem .65rem;border-radius:var(--r);transition:color var(--ease),background var(--ease);white-space:nowrap;flex:0 0 auto}
.nav-link:hover{color:var(--primary);background:rgba(0,32,70,.04)}
.nav-link.active{color:var(--primary);font-weight:700;border-bottom:2px solid var(--primary);border-radius:0;padding-bottom:calc(.35rem - 2px)}
.nav-actions{display:flex;align-items:center;gap:.6rem;flex:0 0 auto;white-space:nowrap}
.nav-search-input{background:var(--surface-mid);border:none;border-radius:var(--r-md);padding:.4rem 1rem .4rem 2.25rem;font-size:.8rem;color:var(--on-surface);width:156px;transition:all var(--ease)}
.nav-search-input:focus{outline:none;background:var(--white);width:240px;box-shadow:var(--shadow-sm)}
.nav-search-wrap{position:relative;display:flex;align-items:center}
.nav-search-icon{position:absolute;left:.6rem;color:var(--outline);pointer-events:none}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem 1.375rem;border-radius:var(--r-md);font-size:.75rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;transition:all var(--ease);cursor:pointer;border:none}
.btn-primary{background:var(--primary);color:var(--on-primary);box-shadow:0 2px 8px rgba(0,32,70,.2)}
.btn-primary:hover{background:var(--primary-mid);box-shadow:0 4px 16px rgba(0,32,70,.28);transform:translateY(-1px)}
.btn-secondary{background:var(--white);color:var(--primary);border:1px solid rgba(196,198,207,.4)}
.btn-secondary:hover{border-color:var(--primary);background:rgba(0,32,70,.02)}
.btn-green{background:var(--secondary);color:#fff}
.btn-green:hover{background:#2d5228}
.btn-ghost{background:transparent;color:var(--primary);padding:0;letter-spacing:0;text-transform:none;font-size:.875rem;font-weight:600}
.btn-ghost:hover{color:var(--secondary)}
.btn-sm{padding:.375rem .85rem;font-size:.68rem}
.btn-lg{padding:.75rem 2rem;font-size:.8rem}
.btn-xl{padding:1rem 2.5rem;font-size:.875rem}

/* Search overlay */
.search-overlay{position:fixed;inset:0;z-index:500;background:rgba(25,28,30,.7);backdrop-filter:blur(8px);display:flex;align-items:flex-start;justify-content:center;padding-top:120px;opacity:0;pointer-events:none;transition:opacity .2s}
.search-overlay.open{opacity:1;pointer-events:all}
.search-box{width:100%;max-width:640px;padding:0 1rem}
.search-box input{width:100%;padding:1rem 1.5rem;background:var(--white);border:none;border-radius:var(--r-lg);font-family:var(--font-h);font-size:1.25rem;color:var(--on-surface);box-shadow:var(--shadow-lg)}
.search-box input:focus{outline:2px solid var(--primary)}
.search-hint{text-align:center;margin-top:.75rem;font-size:.75rem;color:rgba(255,255,255,.5);letter-spacing:.04em}

/* ── TICKER — screenshot 2 style ── */
.ticker{background:var(--white);border-bottom:1px solid rgba(196,198,207,.2);padding:.6rem 0;overflow:hidden}
.ticker-inner{display:flex;align-items:center;gap:1.5rem;max-width:1280px;margin:0 auto;padding:0 2rem}
.ticker-track{display:flex;gap:2rem;animation:ticker-run 50s linear infinite;white-space:nowrap}
.ticker-item{display:flex;align-items:center;gap:.5rem;font-size:.75rem;font-weight:500;color:var(--on-surface-var)}
.ticker-sym{font-weight:800;font-size:.7rem;letter-spacing:.04em;color:var(--on-surface)}
.ticker-up{color:#22c55e;font-weight:700}
.ticker-dn{color:#ef4444;font-weight:700}
@keyframes ticker-run{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ── HERO — screenshot 2 style: white bg, asymmetric ── */
.hero{background:var(--white);padding:5.5rem 0 4rem}
.hero-inner{display:grid;grid-template-columns:1fr 420px;gap:4rem;align-items:center}
.hero-eyebrow{font-size:.65rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--secondary);margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}
.hero-eyebrow::before{content:'';width:24px;height:2px;background:var(--secondary);border-radius:1px}
.hero-title{font-family:var(--font-h);font-size:clamp(2.5rem,5vw,4rem);font-weight:800;color:var(--primary);line-height:1.05;letter-spacing:-.03em;margin-bottom:1.25rem}
.hero-excerpt{font-size:1rem;line-height:1.75;color:var(--on-surface-var);margin-bottom:2rem;max-width:480px}
.hero-actions{display:flex;align-items:center;gap:1.25rem;flex-wrap:wrap}
.hero-byline{font-size:.8rem;color:var(--outline);letter-spacing:.02em}
.hero-img-wrap{position:relative;border-radius:var(--r-lg);overflow:hidden;aspect-ratio:4/3;background:var(--surface-mid);display:flex;align-items:center;justify-content:center;font-size:5rem}
.hero-img-wrap img{width:100%;height:100%;object-fit:cover}
.hero-pullquote{position:absolute;bottom:1.5rem;left:1.5rem;right:1.5rem;background:rgba(22,33,50,.85);backdrop-filter:blur(8px);color:rgba(255,255,255,.9);padding:1rem 1.25rem;border-radius:var(--r-md);font-family:var(--font-h);font-style:italic;font-size:.875rem;line-height:1.6}

/* ── SECTION LABELS ── */
.section-label{font-size:1.5rem;font-weight:800;color:var(--primary);font-family:var(--font-h);margin-bottom:.5rem}
.section-sub{font-size:.8125rem;color:var(--on-surface-var);text-transform:uppercase;letter-spacing:.08em;margin-bottom:2rem}
.section-divider{width:40px;height:3px;background:var(--secondary);border-radius:1px;margin:.625rem 0 2rem}

/* ── ARTICLE CARDS — no borders, shadow only ── */
.cards-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}
.cards-grid-2{grid-template-columns:repeat(2,1fr)}
.cards-grid-4{grid-template-columns:repeat(4,1fr)}

.card{background:var(--white);border-radius:var(--r-lg);box-shadow:var(--shadow);overflow:hidden;display:flex;flex-direction:column;transition:box-shadow var(--ease),transform var(--ease)}
.card:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px)}
.card-native{position:relative}
.card-native::after{content:'Sponsored';position:absolute;top:.625rem;right:.625rem;background:rgba(25,28,30,.5);color:rgba(255,255,255,.8);font-size:.6rem;letter-spacing:.06em;font-weight:700;text-transform:uppercase;padding:.2rem .5rem;border-radius:var(--r-sm);z-index:2}

.card-img{aspect-ratio:16/9;overflow:hidden;position:relative;background:var(--surface-low);display:flex;align-items:center;justify-content:center;font-size:3rem}
.card-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.card:hover .card-img img{transform:scale(1.04)}
.card-cat-tag{position:absolute;top:.75rem;left:.75rem;font-size:.6rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--on-primary);background:var(--primary);padding:.2rem .6rem;border-radius:var(--r-sm)}

.card-body{padding:1.375rem 1.5rem;flex:1;display:flex;flex-direction:column}
.card-eyebrow{font-size:.6rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--secondary);margin-bottom:.5rem}
.card-title{font-family:var(--font-h);font-size:1.0625rem;font-weight:700;color:var(--on-surface);line-height:1.3;margin-bottom:.625rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;transition:color var(--ease)}
.card:hover .card-title{color:var(--primary)}
.card-excerpt{font-size:.8125rem;line-height:1.65;color:var(--on-surface-var);-webkit-line-clamp:3;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden;flex:1;margin-bottom:1rem}
.card-footer{display:flex;justify-content:space-between;align-items:center;padding-top:.875rem;border-top:1px solid rgba(196,198,207,.18);font-size:.7rem;color:var(--outline);letter-spacing:.03em}
.card-readtime{color:var(--secondary);font-weight:600}

/* Featured large card (screenshot 2 layout) */
.card-xl .card-img{aspect-ratio:3/2}
.card-xl .card-title{font-size:1.3125rem;-webkit-line-clamp:3}

/* Editor's choice dark card */
.card-dark{background:var(--primary);color:var(--on-primary)}
.card-dark .card-eyebrow{color:rgba(174,199,247,.7)}
.card-dark .card-title{color:var(--on-primary)}
.card-dark:hover .card-title{color:var(--primary-dim)}
.card-dark .card-footer{border-top-color:rgba(255,255,255,.12);color:rgba(255,255,255,.5)}

/* List item — no dividers, whitespace separates */
.list-item{display:flex;gap:1rem;align-items:flex-start;padding:1.25rem 0}
.list-thumb{width:80px;height:64px;border-radius:var(--r);flex-shrink:0;overflow:hidden;background:var(--surface-low);display:flex;align-items:center;justify-content:center;font-size:1.25rem}
.list-thumb img{width:100%;height:100%;object-fit:cover}
.list-eyebrow{font-size:.6rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--secondary);margin-bottom:.3rem}
.list-title{font-family:var(--font-h);font-size:.9375rem;font-weight:700;line-height:1.35;color:var(--on-surface);transition:color var(--ease)}
.list-item:hover .list-title{color:var(--primary)}
.list-meta{font-size:.7rem;color:var(--outline);margin-top:.3rem}

/* ── INSIGHT BOX (green callout, signature component) ── */
.insight-box{background:rgba(185,238,171,.35);border-left:4px solid var(--secondary);padding:1.5rem 2rem;margin:2.5rem 0;border-radius:0 var(--r) var(--r) 0}
.insight-box-label{font-family:var(--font-h);font-style:italic;font-size:1.0625rem;font-weight:700;color:var(--on-secondary-cont);margin-bottom:.5rem}
.insight-box p{font-size:.9375rem;color:var(--on-secondary-cont);line-height:1.75}

/* ── SIDEBAR WIDGETS ── */
.widget{background:var(--white);border-radius:var(--r-xl);box-shadow:var(--shadow);overflow:hidden;margin-bottom:2rem}
.widget-head{background:var(--primary);color:#fff;padding:.875rem 1.375rem;font-size:.65rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase}
.widget-body{padding:1.25rem 1.375rem}

/* Newsletter widget — screenshot 3/4 dark version */
.nl-widget{background:var(--primary);border-radius:var(--r-xl);padding:1.75rem;margin-bottom:2rem}
.nl-widget h3{font-family:var(--font-h);font-style:italic;font-size:1.375rem;color:#fff;margin-bottom:.5rem}
.nl-widget p{font-size:.8rem;color:rgba(255,255,255,.65);margin-bottom:1.25rem;line-height:1.7}
.nl-input-wrap{position:relative}
.nl-input{width:100%;background:rgba(255,255,255,.92);border:none;border-radius:var(--r-md);padding:.75rem 5.5rem .75rem 1rem;font-size:.875rem;color:var(--on-surface)}
.nl-input:focus{outline:2px solid var(--secondary)}
.nl-btn{position:absolute;right:.375rem;top:50%;transform:translateY(-50%);background:var(--secondary);color:#fff;border:none;border-radius:var(--r);padding:.5rem .875rem;font-size:.7rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;cursor:pointer;transition:background var(--ease)}
.nl-btn:hover{background:#2d5228}

/* Market sparkline widget */
.market-widget{padding:1.25rem 1.5rem}
.market-widget-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:1rem}
.market-label{font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;color:var(--on-surface-var);margin-bottom:.25rem}
.market-title{font-family:var(--font-h);font-size:1.0625rem;font-weight:700;color:var(--primary)}
.market-change{font-weight:700;font-size:1.125rem;color:var(--secondary)}
.sparkline{height:5rem;display:flex;align-items:flex-end;gap:2px;margin-bottom:.5rem}
.spark-bar{flex:1;border-radius:var(--r-sm) var(--r-sm) 0 0;transition:opacity .2s}

/* Trending */
.trend-item{display:flex;gap:.75rem;align-items:flex-start;padding:.875rem 0;transition:background .15s;cursor:pointer}
.trend-item:hover{background:rgba(0,32,70,.02);margin:0 -1.375rem;padding-left:1.375rem;padding-right:1.375rem}
.trend-num{font-family:var(--font-h);font-size:1.75rem;font-weight:700;color:var(--surface-highest);min-width:2rem;line-height:1;flex-shrink:0}
.trend-eyebrow{font-size:.6rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--secondary);margin-bottom:.2rem}
.trend-title{font-size:.8125rem;font-weight:600;line-height:1.4;color:var(--on-surface);transition:color var(--ease)}
.trend-item:hover .trend-title{color:var(--primary)}
.trend-meta{font-size:.65rem;color:var(--outline);margin-top:.2rem}

/* ── ARTICLE PAGE — screenshot 1 ── */
.article-header{background:var(--white);padding:7rem 0 0}
.article-breadcrumb{font-size:.7rem;letter-spacing:.06em;text-transform:uppercase;color:var(--on-surface-var);margin-bottom:1.25rem}
.article-breadcrumb a{color:var(--secondary);font-weight:600}
.article-eyebrow{font-size:.65rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--secondary);margin-bottom:.875rem}
.article-title{font-family:var(--font-h);font-size:clamp(2.25rem,5vw,3.5rem);font-weight:800;color:var(--primary);line-height:1.08;letter-spacing:-.025em;margin-bottom:0}
.article-byline{display:flex;align-items:center;gap:1.25rem;flex-wrap:wrap;padding:1.25rem 0;border-top:1px solid rgba(196,198,207,.2);border-bottom:1px solid rgba(196,198,207,.2);margin-top:1.5rem}
.byline-avatar{width:42px;height:42px;border-radius:50%;background:var(--surface-mid);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.0625rem;color:var(--primary);overflow:hidden;flex-shrink:0}
.byline-avatar img{width:100%;height:100%;object-fit:cover}
.byline-name{font-size:.875rem;font-weight:700;color:var(--primary)}
.byline-role{font-size:.65rem;color:var(--on-surface-var);text-transform:uppercase;letter-spacing:.06em}
.byline-sep{color:var(--outline-var);font-size:.875rem}
.byline-meta{font-size:.7rem;color:var(--outline);letter-spacing:.05em;text-transform:uppercase}
.byline-actions{margin-left:auto;display:flex;gap:.5rem}
.byline-btn{width:34px;height:34px;border-radius:50%;background:var(--surface-mid);color:var(--on-surface-var);display:flex;align-items:center;justify-content:center;font-size:.875rem;transition:all var(--ease)}
.byline-btn:hover{background:var(--primary);color:#fff}

.article-hero-img{margin-top:2rem;border-radius:var(--r-lg) var(--r-lg) 0 0;overflow:hidden;aspect-ratio:16/7;background:var(--surface-low);display:flex;align-items:center;justify-content:center;font-size:5rem}
.article-hero-img img{width:100%;height:100%;object-fit:cover}
.article-hero-caption{font-size:.7rem;color:var(--on-surface-var);font-style:italic;text-align:right;margin-top:.5rem;padding:0 .5rem}

/* Article layout */
.article-layout{display:grid;grid-template-columns:1fr 320px;gap:4rem;padding:3rem 0}

/* Prose — screenshot 1 exact typography */
.prose{max-width:100%}
.prose>p:first-of-type::first-letter{float:left;font-family:var(--font-h);font-size:5.5rem;line-height:4rem;padding-right:.75rem;padding-top:.25rem;color:var(--primary);font-weight:700}
.prose h2{font-family:var(--font-h);font-size:1.75rem;font-weight:700;color:var(--primary);margin:2.5rem 0 1rem;line-height:1.2}
.prose h3{font-family:var(--font-h);font-size:1.25rem;font-weight:700;color:var(--on-surface);margin:2rem 0 .75rem}
.prose p{font-size:1rem;line-height:1.8;margin-bottom:1.25rem;color:var(--on-surface)}
.prose ul,.prose ol{margin:.5rem 0 1.5rem 1.5rem}
.prose li{font-size:1rem;line-height:1.75;margin-bottom:.4rem}
.prose blockquote{margin:2rem 0;padding:1.5rem 2rem;background:rgba(185,238,171,.35);border-left:4px solid var(--secondary);border-radius:0 var(--r) var(--r) 0}
.prose blockquote p{font-family:var(--font-h);font-style:italic;font-size:1.125rem;color:var(--on-secondary-cont);margin:0;line-height:1.7}
.prose table{width:100%;border-collapse:collapse;margin:1.5rem 0;font-size:.875rem}
.prose th{background:var(--primary);color:#fff;padding:.625rem 1rem;text-align:left;font-weight:600}
.prose td{padding:.625rem 1rem;border-bottom:1px solid var(--surface-high)}
.prose tr:nth-child(even) td{background:var(--surface-low)}
.prose a{color:var(--secondary);text-decoration:underline;text-underline-offset:3px}
.prose code{background:var(--surface-mid);padding:.125rem .375rem;border-radius:var(--r-sm);font-size:.875rem}
.prose strong{font-weight:700;color:var(--on-surface)}
.prose img{border-radius:var(--r-lg);margin:1.5rem 0}

/* Disclaimer */
.disclaimer{background:var(--surface-low);border-radius:var(--r-lg);padding:1rem 1.5rem;font-size:.75rem;color:var(--on-surface-var);margin:2rem 0;border-left:3px solid var(--secondary)}

/* Tags */
.tags-list{display:flex;flex-wrap:wrap;gap:.5rem;margin:1.5rem 0}
.tag{background:var(--surface-mid);color:var(--on-surface-var);padding:.25rem .75rem;border-radius:var(--r-xl);font-size:.75rem;font-weight:500;transition:all var(--ease)}
.tag:hover{background:rgba(0,32,70,.08);color:var(--primary)}

/* ── CATEGORIES STRIP ── */
.cats-strip{background:var(--surface-low);border-bottom:none}
.cats-inner{display:flex;gap:.25rem;padding:.875rem 0;overflow-x:auto;scrollbar-width:none}
.cats-inner::-webkit-scrollbar{display:none}
.cat-pill{display:flex;align-items:center;gap:.375rem;padding:.4rem 1rem;border-radius:20px;font-size:.75rem;font-weight:600;white-space:nowrap;cursor:pointer;transition:all var(--ease);color:var(--on-surface-var);background:var(--white);box-shadow:var(--shadow-sm)}
.cat-pill:hover{color:var(--primary);box-shadow:var(--shadow)}
.cat-pill.active{background:var(--primary);color:#fff}

/* ── FOOTER — screenshot 2 ── */
.site-footer{background:var(--surface-low);margin-top:5rem}
.footer-main{padding:4rem 0 3rem}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem}
.footer-logo{font-family:var(--font-h);font-style:italic;font-size:1.25rem;color:var(--primary);font-weight:700;margin-bottom:.875rem}
.footer-desc{font-size:.8125rem;line-height:1.75;color:var(--on-surface-var);margin-bottom:1.25rem}
.footer-soc{display:flex;gap:.5rem}
.footer-soc-btn{width:32px;height:32px;border-radius:50%;background:var(--surface-mid);color:var(--on-surface-var);display:flex;align-items:center;justify-content:center;font-size:.75rem;transition:all var(--ease)}
.footer-soc-btn:hover{background:var(--primary);color:#fff}
.footer-col-label{font-size:.65rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--primary);margin-bottom:1rem}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:.625rem}
.footer-col ul a{font-size:.8125rem;color:var(--on-surface-var);transition:color var(--ease)}
.footer-col ul a:hover{color:var(--secondary)}
.footer-bottom{border-top:1px solid rgba(196,198,207,.25);padding:1.5rem 0;display:flex;justify-content:space-between;align-items:center;font-size:.7rem;letter-spacing:.06em;text-transform:uppercase;color:var(--on-surface-var)}
.footer-disc{font-size:.7rem;color:var(--on-surface-var);max-width:680px;margin-top:.375rem;line-height:1.6;opacity:.65}

/* ── PAGINATION ── */
.pagination{display:flex;gap:.375rem;justify-content:center;margin:3rem 0}
.page-btn{width:36px;height:36px;border-radius:var(--r);background:var(--white);color:var(--on-surface-var);box-shadow:var(--shadow-sm);font-size:.8125rem;font-weight:500;display:flex;align-items:center;justify-content:center;transition:all var(--ease);text-decoration:none;border:none;cursor:pointer}
.page-btn:hover,.page-btn.active{background:var(--primary);color:#fff}
.page-btn.disabled{opacity:.35;cursor:not-allowed}

/* ── FORMS ── */
.form-group{margin-bottom:1.25rem}
.form-label{display:block;font-size:.7rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;margin-bottom:.375rem;color:var(--on-surface-var)}
.form-input,.form-select,.form-textarea{width:100%;background:var(--surface-highest);border:none;border-bottom:2px solid rgba(196,198,207,.3);padding:.625rem 0;font-size:.9375rem;color:var(--on-surface);transition:border-color .2s,background .2s;border-radius:0}
.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-bottom-color:var(--primary);background:var(--white)}
.form-input.box,.form-select.box,.form-textarea.box{padding:.625rem .875rem;border:1.5px solid var(--outline-var);border-radius:var(--r-md)}
.form-input.box:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(0,32,70,.08);background:var(--white)}
.form-textarea{resize:vertical;min-height:90px;line-height:1.6}
.form-hint{font-size:.7rem;color:var(--outline);margin-top:.3rem}

/* ── ALERTS ── */
.alert{padding:.875rem 1.125rem;border-radius:var(--r-lg);margin-bottom:1rem;font-size:.8125rem;display:flex;align-items:flex-start;gap:.625rem}
.alert-ok{background:rgba(185,238,171,.3);color:var(--on-secondary-cont)}
.alert-err{background:#fef2f2;color:#dc2626}
.alert-info{background:rgba(174,199,247,.25);color:var(--primary)}
.alert-warn{background:rgba(255,214,168,.3);color:#7c4a00}

/* ── CALCULATORS ── */
.calc-card{background:var(--white);border-radius:var(--r-xl);box-shadow:var(--shadow);padding:2rem;margin-bottom:1.5rem}
.calc-result{background:var(--primary);color:#fff;border-radius:var(--r-lg);padding:1.75rem;text-align:center}
.calc-result-label{font-size:.65rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;opacity:.7;margin-bottom:.5rem}
.calc-result-value{font-family:var(--font-h);font-size:2.5rem;font-weight:700}

/* ── PROGRESS BAR ── */
#read-progress{position:fixed;top:0;left:0;height:2px;background:var(--secondary);z-index:9999;width:0;transition:width .1s}

/* ── RESPONSIVE ── */
@media(max-width:1024px){
  .cards-grid{grid-template-columns:repeat(2,1fr)}
  .hero-inner{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .article-layout{grid-template-columns:1fr}
  .cards-grid-4{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:768px){
  .cards-grid,.cards-grid-2{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr;gap:2rem}
  .nav-links{display:none}
  .nav-search-input{display:none}
  .article-title{font-size:2rem}
  .hero-title{font-size:2.25rem}
  .hero{padding:4rem 0 3rem}
}
@keyframes fade-up{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}
.animate{animation:fade-up .5s ease both}
.d1{animation-delay:.1s}.d2{animation-delay:.2s}.d3{animation-delay:.3s}


.nav-toggle{display:none;background:var(--white);border:1px solid rgba(196,198,207,.35);border-radius:var(--r);padding:.55rem .8rem;font-size:1rem;color:var(--primary);box-shadow:var(--shadow-sm)}

@media(max-width:1180px){
  .nav-inner{padding:0 1rem;gap:.75rem}
  .nav-link{padding:.32rem .48rem;font-size:.74rem}
  .nav-search-input{width:132px}
  .btn-sm{padding:.34rem .72rem;font-size:.64rem}
}
@media(max-width:1024px){
  .wrap{width:min(100% - 28px,var(--maxw))}
  .hero{padding-top:4rem !important}
  .hero-actions{flex-direction:column;align-items:flex-start}
  .article-layout{gap:2rem}
  .nav-links{gap:0}
}

@media(max-width:768px){
  .nav-inner{position:relative;gap:.75rem;flex-wrap:wrap}
  .nav-toggle{display:inline-flex;align-items:center;justify-content:center;order:3}
  .nav-actions{margin-left:auto}
  .nav-links{display:none;flex-direction:column;gap:.25rem;width:100%;background:var(--white);padding:.75rem;border-radius:var(--r-lg);box-shadow:var(--shadow);order:4}
  .nav-links.open{display:flex}
  .nav-link{padding:.8rem .5rem;border-bottom:1px solid rgba(196,198,207,.18)}
  .nav-link:last-child{border-bottom:none}
  .ticker-item{font-size:.7rem}
  .hero-pullquote{position:static;margin-top:1rem;width:auto;max-width:none}
  .article-header{padding-top:5.5rem}
  .article-byline{align-items:flex-start}
  .byline-actions{margin-left:0;width:100%}
  .prose>p:first-of-type::first-letter{font-size:4rem;line-height:3rem;padding-right:.5rem}
  .ad-inline-link{flex-direction:column;align-items:flex-start !important}
  .ad-inline-link > span{width:100%;text-align:center}
  .footer-bottom{flex-direction:column;align-items:flex-start;gap:.75rem}
  table{display:block;overflow-x:auto}
}
@media(max-width:560px){
  body{overflow-x:hidden}
  .wrap{width:min(100% - 20px,var(--maxw))}
  .btn,.btn-lg,.btn-sm{max-width:100%}
  .card-body{padding:1rem}
  .market-widget,.widget-body,.calc-card{padding:1rem}
  .article-title{font-size:1.7rem}
  .hero-title{font-size:1.9rem}
  .prose p,.prose li{font-size:.96rem}
}


/* --- Performance & mobile refinements --- */
img{max-width:100%;height:auto}
.nav-logo img{display:block;height:32px;width:auto;max-width:160px;object-fit:contain;flex:0 0 auto}
.content-shell,.article-shell{min-width:0}
.content-shell > *,.article-shell > *{min-width:0}
.content-sidebar,.article-sidebar{min-width:0}
.ticker{overflow:hidden}

@media(max-width:1024px){
  .content-shell{grid-template-columns:1fr !important;gap:2rem !important}
  .content-sidebar{order:2}
  .article-shell{grid-template-columns:1fr !important;gap:2rem !important}
  .article-sidebar{position:static !important;top:auto !important}
}

@media(max-width:768px){
  html{-webkit-text-size-adjust:100%}
  .ticker{display:none}
  .nav{top:0}
  .nav-inner{padding:.7rem 0;align-items:center}
  .nav-logo{max-width:150px;min-width:0}
  .nav-logo img{height:32px;width:auto;max-width:150px;object-fit:contain}
  .nav-actions{width:auto;min-width:0;gap:.5rem}
  .nav-links{width:100%;margin-top:.25rem}
  .hero{padding-top:4.6rem !important}
  .hero-inner{grid-template-columns:1fr !important;gap:1.25rem !important}
  .hero-img-wrap{min-height:220px}
  .page-main{padding:2.1rem 0 !important}
  .cards-grid,.cards-grid-2,.cards-grid-4{grid-template-columns:1fr !important;gap:1rem !important}
  .cats-inner{padding:.65rem 0}
  .cat-pill{padding:.42rem .8rem;font-size:.72rem}
  .section-label{font-size:1.4rem}
}

@media(max-width:560px){
  .nav-search-wrap{display:none}
  .nav-actions .btn{padding:.42rem .7rem;font-size:.62rem}
  .hero-title{font-size:1.75rem}
  .hero-excerpt{font-size:.95rem}
  .article-shell .prose{font-size:.95rem}
  .article-shell .prose p{font-size:.95rem;line-height:1.75}
  .ad-inline-wrap{padding:1rem 1rem !important}
  .ad-inline-wrap .ad-inline-link{gap:.85rem !important}
}


/* Premium AI article blocks */
.prose .ai-lead{font-size:1.125rem;line-height:1.9;color:var(--on-surface);margin-bottom:1.5rem}
.prose .ai-section{margin:2rem 0}
.prose .ai-callout{margin:1.75rem 0;padding:1.125rem 1.25rem;border:1px solid rgba(24,54,130,.14);background:linear-gradient(180deg,rgba(174,199,247,.16),rgba(255,255,255,.92));border-radius:var(--r-lg);box-shadow:var(--shadow-sm)}
.prose .ai-callout strong{display:block;font-family:var(--font-h);font-size:.82rem;letter-spacing:.08em;text-transform:uppercase;color:var(--primary);margin-bottom:.5rem}
.prose .ai-callout p:last-child{margin-bottom:0}
.prose .ai-keypoints{list-style:none;margin:1rem 0 1.5rem 0;padding:0;display:grid;gap:.75rem}
.prose .ai-keypoints li{position:relative;padding:.85rem 1rem .85rem 2.5rem;background:var(--white);border:1px solid var(--surface-high);border-radius:var(--r);box-shadow:var(--shadow-sm);margin:0}
.prose .ai-keypoints li::before{content:'✓';position:absolute;left:1rem;top:.9rem;width:1rem;height:1rem;display:flex;align-items:center;justify-content:center;color:var(--primary);font-weight:700}
.prose .ai-table-wrap{margin:1.5rem 0;overflow-x:auto;border:1px solid var(--surface-high);border-radius:var(--r-lg);background:var(--white);box-shadow:var(--shadow-sm)}
.prose .ai-data-table{margin:0 !important;min-width:640px}
.prose .ai-quote{margin:2rem 0;padding:1.5rem 2rem;background:linear-gradient(180deg,rgba(185,238,171,.28),rgba(185,238,171,.16));border-left:4px solid var(--secondary);border-radius:0 var(--r) var(--r) 0}
@media (max-width: 768px){
  .prose .ai-lead{font-size:1.04rem;line-height:1.8}
  .prose .ai-callout{padding:1rem}
  .prose .ai-keypoints li{padding:.8rem .9rem .8rem 2.25rem}
}

/* --- Mobile hotfix April 2026 --- */
@media (max-width: 900px){
  html,body{width:100%;max-width:100%;overflow-x:hidden}
  body{position:relative}
  .wrap{width:calc(100% - 24px) !important;max-width:none !important;margin-left:auto !important;margin-right:auto !important}

  /* Header */
  .nav{position:sticky;top:0;z-index:1000}
  .nav-inner{display:grid !important;grid-template-columns:auto 1fr auto !important;align-items:center !important;gap:.75rem !important;padding:.7rem 0 !important}
  .nav-logo{max-width:140px !important}
  .nav-logo img{height:30px !important;max-width:140px !important}
  .nav-toggle{order:2;justify-self:center;display:inline-flex !important}
  .nav-actions{order:3;justify-self:end;margin-left:0 !important}
  .nav-actions .btn{padding:.5rem .8rem !important;font-size:.68rem !important;white-space:nowrap}
  .nav-links{order:4;grid-column:1 / -1;width:100% !important}

  /* Home + category layouts */
  .content-shell,
  .article-shell,
  .article-layout,
  .footer-grid,
  .cards-grid,
  .cards-grid-2,
  .cards-grid-4{display:block !important;grid-template-columns:1fr !important;gap:0 !important}

  .content-shell > *,
  .article-shell > *,
  .article-layout > *,
  .cards-grid > *,
  .cards-grid-2 > *,
  .cards-grid-4 > *{width:100% !important;max-width:100% !important;min-width:0 !important}

  .content-sidebar,
  .article-sidebar{display:block !important;position:static !important;top:auto !important;margin-top:1.25rem !important;width:100% !important}
  .content-sidebar > *,
  .article-sidebar > *{width:100% !important;max-width:100% !important}

  .card,
  .card-xl,
  .market-widget,
  .widget,
  .widget-card,
  .calc-card,
  .article-main article,
  .article-main aside{width:100% !important;max-width:100% !important;min-width:0 !important}

  .card{margin-bottom:1rem !important}
  .card-img{aspect-ratio:16/10 !important}
  .card-title{font-size:1.35rem !important;line-height:1.2 !important;display:-webkit-box !important;-webkit-line-clamp:3 !important;-webkit-box-orient:vertical !important;overflow:hidden !important}
  .card-excerpt{display:-webkit-box !important;-webkit-line-clamp:3 !important;-webkit-box-orient:vertical !important;overflow:hidden !important}

  /* Hero */
  .hero{padding:4.8rem 0 2rem !important}
  .hero-inner{display:block !important}
  .hero-inner > * + *{margin-top:1rem !important}
  .hero-title{font-size:2rem !important;line-height:1.05 !important}
  .hero-excerpt{max-width:none !important}
  .hero-actions{display:flex !important;flex-direction:column !important;align-items:flex-start !important;gap:.8rem !important}
  .hero-img-wrap{min-height:210px !important;aspect-ratio:16/10 !important}
  .hero-pullquote{position:static !important;left:auto !important;right:auto !important;bottom:auto !important;margin:1rem !important}

  /* Category pills */
  .cats-strip{overflow:hidden}
  .cats-inner{display:flex !important;flex-wrap:nowrap !important;overflow-x:auto !important;gap:.55rem !important;padding-bottom:.35rem !important;scrollbar-width:none}
  .cats-inner::-webkit-scrollbar{display:none}
  .cat-pill{flex:0 0 auto !important}

  /* Article page */
  .article-main{padding:2rem 0 !important}
  .article-main .prose,
  .article-main .prose *{max-width:100% !important}
  .article-main .prose{overflow-wrap:anywhere !important;word-break:break-word !important}
  .article-main .prose > p:first-of-type::first-letter{float:none !important;font-size:3.1rem !important;line-height:1 !important;padding:.1rem .35rem 0 0 !important;display:inline-block !important}
  .article-main .prose p,
  .article-main .prose li{font-size:1rem !important;line-height:1.8 !important}
  .article-main .prose blockquote,
  .prose .ai-callout,
  .prose .ai-quote{padding:1rem !important;margin:1.25rem 0 !important}
  .article-main .prose table,
  .prose .ai-data-table{display:block !important;min-width:520px !important}

  /* Widgets and promos */
  .article-sidebar form,
  .article-sidebar input,
  .article-sidebar button{max-width:100% !important}
  .article-sidebar > div,
  .content-sidebar > div{margin-bottom:1rem !important}

  /* Fix extra right-side blank space from absolute/fixed children */
  img,svg,iframe,table{max-width:100%}
}

@media (max-width: 560px){
  .wrap{width:calc(100% - 18px) !important}
  .nav-logo{max-width:122px !important}
  .nav-logo img{height:28px !important;max-width:122px !important}
  .nav-actions .btn{padding:.46rem .72rem !important;font-size:.64rem !important}
  .hero-title{font-size:1.78rem !important}
  .section-label{font-size:1.7rem !important}
  .card-body{padding:1rem !important}
  .article-main .prose > p:first-of-type::first-letter{font-size:2.7rem !important;padding-right:.28rem !important}
}
