/* FinnHub — fresh stylesheet (2026-06-21)
   New design system: dark navy + emerald/teal palette, fh- prefixed classes. */

@font-face{font-family:'DM Sans';font-style:normal;font-weight:400;font-display:swap;src:url(fonts/dmsans-400.woff2) format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'DM Sans';font-style:normal;font-weight:700;font-display:swap;src:url(fonts/dmsans-700.woff2) format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Outfit';font-style:normal;font-weight:600;font-display:swap;src:url(fonts/outfit-600.woff2) format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Outfit';font-style:normal;font-weight:800;font-display:swap;src:url(fonts/outfit-800.woff2) format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Space Grotesk';font-style:normal;font-weight:700;font-display:swap;src:url(fonts/spacegrotesk-700.woff2) format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'JetBrains Mono';font-style:normal;font-weight:600;font-display:swap;src:url(fonts/jetbrains-600.woff2) format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}

:root{
  /* New palette: deep navy + emerald + teal accent */
  --fh-bg-1:#0a1628;
  --fh-bg-2:#0f1f3a;
  --fh-bg-3:#15294a;
  --fh-bg-card:#1a3050;
  --fh-bg-card-hi:#223a5e;
  --fh-bg-input:#1e3658;
  --fh-text-1:#eef4ff;
  --fh-text-2:#b8c7df;
  --fh-text-3:#7a8cab;
  --fh-emerald:#10b981;
  --fh-emerald-bright:#34d399;
  --fh-emerald-dark:#059669;
  --fh-teal:#06b6d4;
  --fh-teal-bright:#22d3ee;
  --fh-cyan:#67e8f9;
  --fh-mint:#a7f3d0;
  --fh-glow-1:rgba(16,185,129,0.45);
  --fh-glow-2:rgba(6,182,212,0.35);
  --fh-grad-1:linear-gradient(135deg,#10b981 0%,#06b6d4 100%);
  --fh-grad-2:linear-gradient(135deg,#34d399 0%,#22d3ee 100%);
  --fh-grad-card:linear-gradient(145deg,#1a3050 0%,#0f1f3a 100%);
  --fh-border-1:rgba(255,255,255,0.07);
  --fh-border-2:rgba(255,255,255,0.14);
  --fh-shadow-lg:0 28px 56px rgba(0,0,0,0.55);
  --fh-shadow-card:0 10px 28px rgba(0,0,0,0.38);
  --fh-r-sm:10px;
  --fh-r-md:16px;
  --fh-r-lg:22px;
  --fh-r-xl:30px;
  --fh-fast:0.2s ease;
  --fh-smooth:0.4s ease;
  --fh-bounce:0.5s cubic-bezier(0.34,1.56,0.64,1);
  --fh-chart-invested:#06b6d4;
  --fh-chart-returns:#34d399;
  --fh-chart-total:#67e8f9;
  --fh-chart-real:#a7f3d0;
  --fh-chart-posttax:#fbbf24;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--fh-bg-1);
  color:var(--fh-text-1);
  font-family:'DM Sans',system-ui,-apple-system,sans-serif;
  font-size:16px;
  line-height:1.6;
  min-height:100vh;
  overflow-x:hidden;
  position:relative;
}
body::before{
  content:"";
  position:fixed;
  inset:0;
  background:
    radial-gradient(circle at 15% 20%,rgba(16,185,129,0.08) 0%,transparent 40%),
    radial-gradient(circle at 85% 80%,rgba(6,182,212,0.08) 0%,transparent 40%),
    radial-gradient(circle at 50% 50%,rgba(34,211,238,0.04) 0%,transparent 60%);
  pointer-events:none;
  z-index:0;
}
.fh-sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.fh-skip-link{position:absolute;top:-40px;left:8px;background:var(--fh-emerald);color:#0a1628;padding:8px 16px;border-radius:8px;text-decoration:none;font-weight:700;z-index:1000;transition:top var(--fh-fast)}
.fh-skip-link:focus{top:8px}
.fh-bg-particles{position:fixed;inset:0;pointer-events:none;z-index:1;overflow:hidden}
.fh-bg-particles::before,.fh-bg-particles::after{
  content:"";position:absolute;width:600px;height:600px;border-radius:50%;
  filter:blur(80px);opacity:0.35;
  animation:fhFloat 20s ease-in-out infinite;
}
.fh-bg-particles::before{background:var(--fh-emerald);top:-200px;left:-200px}
.fh-bg-particles::after{background:var(--fh-teal);bottom:-200px;right:-200px;animation-delay:-10s}
@keyframes fhFloat{
  0%,100%{transform:translate(0,0) scale(1)}
  33%{transform:translate(80px,-60px) scale(1.1)}
  66%{transform:translate(-60px,80px) scale(0.9)}
}

.fh-app{max-width:1280px;margin:0 auto;padding:24px 20px 60px;position:relative;z-index:2}

/* Header */
.fh-header{
  display:flex;flex-direction:column;align-items:center;text-align:center;
  padding:32px 20px 24px;margin-bottom:16px;
  background:var(--fh-grad-card);
  border:1px solid var(--fh-border-1);
  border-radius:var(--fh-r-lg);
  box-shadow:var(--fh-shadow-card);
}
.fh-logo-wrap{display:flex;align-items:center;gap:12px;margin-bottom:10px}
.fh-logo-mark{
  width:48px;height:48px;border-radius:14px;
  background:var(--fh-grad-1);
  display:flex;align-items:center;justify-content:center;
  font-size:26px;
  box-shadow:0 6px 18px var(--fh-glow-1);
}
.fh-logo-text{
  font-family:'Outfit',sans-serif;font-weight:800;font-size:30px;
  background:var(--fh-grad-2);-webkit-background-clip:text;background-clip:text;color:transparent;
  letter-spacing:-0.5px;
}
.fh-tagline{color:var(--fh-text-2);font-size:14px;font-weight:500;max-width:560px}

/* Ad slot (kept for AdSense) */
.fh-ad-banner{
  background:linear-gradient(135deg,rgba(16,185,129,0.05),rgba(6,182,212,0.05));
  border:1px solid var(--fh-border-2);
  border-radius:var(--fh-r-md);
  padding:14px 16px;text-align:center;
  color:var(--fh-text-3);font-size:11px;font-weight:600;
  letter-spacing:1.5px;text-transform:uppercase;
  margin:16px 0;
  position:relative;overflow:hidden;
}
.fh-ad-banner::before{
  content:"";position:absolute;inset:0;
  background:repeating-linear-gradient(45deg,transparent,transparent 12px,rgba(255,255,255,0.015) 12px,rgba(255,255,255,0.015) 24px);
  pointer-events:none;
}
.fh-ad-inline{
  background:linear-gradient(135deg,rgba(16,185,129,0.05),rgba(6,182,212,0.05));
  border:1px solid var(--fh-border-2);
  border-radius:var(--fh-r-md);
  padding:18px 16px;text-align:center;
  color:var(--fh-text-3);font-size:11px;font-weight:600;
  letter-spacing:1.5px;text-transform:uppercase;
  margin:24px 0;
  position:relative;overflow:hidden;
}
.fh-ad-inline::before{
  content:"";position:absolute;inset:0;
  background:repeating-linear-gradient(45deg,transparent,transparent 12px,rgba(255,255,255,0.015) 12px,rgba(255,255,255,0.015) 24px);
  pointer-events:none;
}

/* Navigation */
.fh-nav{
  display:flex;flex-wrap:wrap;justify-content:center;gap:6px;
  padding:10px;margin:12px 0 24px;
  background:var(--fh-bg-card);
  border:1px solid var(--fh-border-1);
  border-radius:var(--fh-r-lg);
  box-shadow:var(--fh-shadow-card);
  position:sticky;top:12px;z-index:50;
  backdrop-filter:blur(12px);
}
.fh-nav-link{
  display:inline-flex;align-items:center;gap:6px;
  padding:8px 14px;border-radius:var(--fh-r-sm);
  color:var(--fh-text-2);text-decoration:none;font-size:14px;font-weight:600;
  transition:all var(--fh-fast);white-space:nowrap;
}
.fh-nav-link:hover{background:var(--fh-bg-card-hi);color:var(--fh-text-1)}
.fh-nav-link.fh-active{
  background:var(--fh-grad-1);color:#0a1628;
  box-shadow:0 4px 12px var(--fh-glow-1);
}

/* Main content */
.fh-main{display:block}
.fh-card{
  background:var(--fh-grad-card);
  border:1px solid var(--fh-border-1);
  border-radius:var(--fh-r-xl);
  padding:32px;margin-bottom:24px;
  box-shadow:var(--fh-shadow-card);
}
.fh-card-title{
  font-family:'Outfit',sans-serif;font-weight:700;font-size:22px;
  color:var(--fh-text-1);margin-bottom:20px;
  display:flex;align-items:center;gap:10px;
}
.fh-dot{width:8px;height:8px;border-radius:50%;background:var(--fh-emerald);box-shadow:0 0 12px var(--fh-glow-1)}

/* Input grid */
.fh-input-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px;margin-bottom:20px}
.fh-input-group{display:flex;flex-direction:column;gap:8px}
.fh-input-group label{font-size:13px;color:var(--fh-text-2);font-weight:600;letter-spacing:0.2px}
.fh-input-row{display:flex;align-items:center;gap:8px;background:var(--fh-bg-input);border:1px solid var(--fh-border-2);border-radius:var(--fh-r-sm);padding:10px 14px;transition:border var(--fh-fast),box-shadow var(--fh-fast)}
.fh-input-row:focus-within{border-color:var(--fh-emerald);box-shadow:0 0 0 3px var(--fh-glow-1)}
.fh-input-row input{
  background:transparent;border:none;outline:none;
  color:var(--fh-text-1);
  font-family:'JetBrains Mono',monospace;
  font-size:16px;font-weight:600;width:100%;
  -webkit-text-fill-color:var(--fh-text-1); /* Safari autofill fix */
}
.fh-input-row input::placeholder{color:var(--fh-text-3)}
.fh-input-row input::-webkit-outer-spin-button,
.fh-input-row input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
.fh-input-row input[type=number]{-moz-appearance:textfield}
.fh-currency{color:var(--fh-emerald-bright);font-weight:700;font-size:16px}
.fh-suffix{color:var(--fh-text-2);font-size:13px;font-weight:600}
.fh-slider-row{margin-top:4px}
.fh-slider-row input[type=range]{
  width:100%;-webkit-appearance:none;appearance:none;
  height:6px;background:var(--fh-bg-input);border-radius:3px;outline:none;
  border:1px solid var(--fh-border-1);
}
.fh-slider-row input[type=range]::-webkit-slider-thumb{
  -webkit-appearance:none;appearance:none;
  width:18px;height:18px;border-radius:50%;
  background:var(--fh-emerald);cursor:pointer;
  box-shadow:0 0 10px var(--fh-glow-1);
  border:2px solid var(--fh-bg-1);
}
.fh-slider-row input[type=range]::-moz-range-thumb{
  width:18px;height:18px;border-radius:50%;
  background:var(--fh-emerald);cursor:pointer;border:2px solid var(--fh-bg-1);
}

/* SIP options */
.fh-sip-opts{display:flex;flex-wrap:wrap;align-items:center;gap:14px;padding:14px;background:var(--fh-bg-input);border-radius:var(--fh-r-md);margin-bottom:16px}
.fh-sip-opts select{background:var(--fh-bg-2);color:var(--fh-text-1);border:1px solid var(--fh-border-2);border-radius:var(--fh-r-sm);padding:6px 10px;font-family:inherit;font-weight:600}
.fh-stepup{display:flex;align-items:center;gap:10px;color:var(--fh-text-2);font-size:13px}
.fh-stepup input[type=range]{width:120px}
.fh-stepup-val{color:var(--fh-emerald-bright);font-weight:700;min-width:36px}

/* Tax toggle */
.fh-tax-row{
  display:flex;flex-wrap:wrap;align-items:center;gap:12px;
  padding:14px 16px;background:var(--fh-bg-input);
  border:1px solid var(--fh-border-1);border-radius:var(--fh-r-md);
  margin-bottom:18px;font-size:14px;color:var(--fh-text-1);font-weight:500;
}
.fh-tax-row label{display:flex;align-items:center;gap:10px;cursor:pointer}
.fh-tax-row input[type=checkbox]{
  width:20px;height:20px;accent-color:var(--fh-emerald);
  cursor:pointer;
  border:2px solid var(--fh-border-2);border-radius:5px;
  background:var(--fh-bg-2);
  appearance:none;-webkit-appearance:none;
  position:relative;flex-shrink:0;
  transition:background var(--fh-fast),border-color var(--fh-fast);
}
.fh-tax-row input[type=checkbox]:checked{
  background:var(--fh-emerald);border-color:var(--fh-emerald);
}
.fh-tax-row input[type=checkbox]:checked::after{
  content:"✓";position:absolute;
  top:50%;left:50%;transform:translate(-50%,-50%);
  color:#0a1628;font-size:14px;font-weight:900;
}
.fh-tax-hint{color:var(--fh-text-3);font-size:12px;font-weight:400}

/* Calculate button */
.fh-btn-calc{
  display:block;width:100%;padding:16px 24px;
  background:var(--fh-grad-1);color:#0a1628;
  border:none;border-radius:var(--fh-r-md);
  font-family:'Outfit',sans-serif;font-weight:700;font-size:17px;cursor:pointer;
  box-shadow:0 8px 22px var(--fh-glow-1);
  transition:transform var(--fh-fast),box-shadow var(--fh-fast);
}
.fh-btn-calc:hover{transform:translateY(-2px);box-shadow:0 12px 28px var(--fh-glow-1)}
.fh-btn-calc:active{transform:translateY(0)}

/* Results */
.fh-results{margin-top:24px}
.fh-result-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;margin-bottom:20px}
.fh-result-card{
  background:var(--fh-bg-card);
  border:1px solid var(--fh-border-2);
  border-left-width:3px;
  border-radius:var(--fh-r-md);padding:16px;text-align:center;
  transition:transform var(--fh-fast),border-color var(--fh-fast);
}
.fh-result-card:hover{transform:translateY(-2px)}
.fh-result-card.fh-invested{border-left-color:var(--fh-teal-bright)}
.fh-result-card.fh-returns{border-left-color:var(--fh-emerald-bright)}
.fh-result-card.fh-total{border-left-color:var(--fh-cyan)}
.fh-result-card.fh-real{border-left-color:var(--fh-mint)}
.fh-result-card.fh-posttax{border-left-color:var(--fh-chart-posttax)}
.fh-result-label{
  font-size:11px;color:var(--fh-text-2);
  text-transform:uppercase;letter-spacing:1px;
  margin-bottom:8px;font-weight:600;
}
.fh-result-value{
  font-family:'JetBrains Mono',monospace;
  font-size:22px;font-weight:700;color:var(--fh-text-1);
}

/* Charts */
.fh-charts-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:18px;margin-bottom:20px}
.fh-chart-box{background:var(--fh-bg-card);border:1px solid var(--fh-border-1);border-radius:var(--fh-r-md);padding:16px}
.fh-chart-box h4{font-family:'Outfit',sans-serif;font-size:15px;color:var(--fh-text-2);margin-bottom:12px;text-align:center}

/* Table */
.fh-table-wrap{overflow-x:auto;background:var(--fh-bg-card);border:1px solid var(--fh-border-1);border-radius:var(--fh-r-md);padding:12px;margin-bottom:20px}
.fh-table-wrap table{width:100%;border-collapse:collapse;font-size:13px}
.fh-table-wrap th{color:var(--fh-text-3);font-weight:600;text-align:left;padding:8px;border-bottom:1px solid var(--fh-border-2)}
.fh-table-wrap td{padding:8px;border-bottom:1px solid var(--fh-border-1);font-family:'JetBrains Mono',monospace}

/* Knowledge / info cards */
.fh-info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;margin-top:20px}
.fh-info-card{background:var(--fh-bg-card);border:1px solid var(--fh-border-1);border-radius:var(--fh-r-md);padding:18px;transition:transform var(--fh-fast),border-color var(--fh-fast)}
.fh-info-card:hover{transform:translateY(-3px);border-color:var(--fh-emerald)}
.fh-info-icon{font-size:24px;display:block;margin-bottom:8px}
.fh-info-card h3{font-family:'Outfit',sans-serif;font-size:15px;color:var(--fh-text-1);margin-bottom:6px}
.fh-info-card p{font-size:13px;color:var(--fh-text-2);line-height:1.5}

/* Homepage hero (reorganized) */
.fh-hero{text-align:center;padding:20px 0 30px}
.fh-hero-eyebrow{display:inline-block;background:rgba(16,185,129,0.12);color:var(--fh-emerald-bright);padding:6px 14px;border-radius:999px;font-size:12px;font-weight:700;letter-spacing:1px;text-transform:uppercase;margin-bottom:16px}
.fh-hero-title{font-family:'Outfit',sans-serif;font-weight:800;font-size:48px;line-height:1.1;background:var(--fh-grad-2);-webkit-background-clip:text;background-clip:text;color:transparent;margin-bottom:14px;letter-spacing:-1px}
.fh-hero-sub{font-size:18px;color:var(--fh-text-2);max-width:680px;margin:0 auto 24px;line-height:1.55}
.fh-hero-cta{display:flex;flex-wrap:wrap;justify-content:center;gap:12px;margin-bottom:32px}
.fh-cta-primary{background:var(--fh-grad-1);color:#0a1628;padding:14px 28px;border-radius:var(--fh-r-md);text-decoration:none;font-family:'Outfit',sans-serif;font-weight:700;box-shadow:0 8px 20px var(--fh-glow-1);transition:transform var(--fh-fast)}
.fh-cta-primary:hover{transform:translateY(-2px)}
.fh-cta-ghost{
  background:rgba(255,255,255,0.04);
  color:var(--fh-text-1);
  padding:14px 28px;border-radius:var(--fh-r-md);text-decoration:none;
  font-family:'Outfit',sans-serif;font-weight:600;font-size:15px;
  border:1.5px solid var(--fh-border-2);
  transition:all var(--fh-fast);
  display:inline-flex;align-items:center;gap:8px;
}
.fh-cta-ghost:hover{
  background:var(--fh-bg-card-hi);
  border-color:var(--fh-emerald);
  color:var(--fh-emerald-bright);
  transform:translateY(-1px);
}

/* Why FinnHub section (NEW — not in old site) */
.fh-why{margin:32px 0;padding:28px;background:var(--fh-bg-card);border:1px solid var(--fh-border-1);border-radius:var(--fh-r-lg)}
.fh-why h3{font-family:'Outfit',sans-serif;font-size:24px;color:var(--fh-text-1);margin-bottom:6px;text-align:center}
.fh-why-sub{text-align:center;color:var(--fh-text-2);font-size:14px;margin-bottom:22px}
.fh-why-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}
.fh-why-card{padding:18px;background:var(--fh-bg-input);border-radius:var(--fh-r-md);border-left:3px solid var(--fh-emerald)}
.fh-why-card h4{font-family:'Outfit',sans-serif;color:var(--fh-emerald-bright);font-size:15px;margin-bottom:8px}
.fh-why-card p{color:var(--fh-text-2);font-size:13px;line-height:1.5}

/* Calc grid on homepage */
.fh-calc-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin:24px 0}
.fh-calc-tile{display:block;background:var(--fh-bg-card);border:1px solid var(--fh-border-1);border-radius:var(--fh-r-md);padding:22px;text-decoration:none;color:inherit;transition:all var(--fh-smooth)}
.fh-calc-tile:hover{transform:translateY(-4px);border-color:var(--fh-emerald);box-shadow:0 12px 24px var(--fh-glow-2)}
.fh-calc-tile-icon{font-size:30px;display:block;margin-bottom:10px}
.fh-calc-tile h4{font-family:'Outfit',sans-serif;font-size:17px;color:var(--fh-text-1);margin-bottom:6px}
.fh-calc-tile p{font-size:13px;color:var(--fh-text-2);line-height:1.5}

/* Stats row */
.fh-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:14px;margin:24px 0;text-align:center}
.fh-stat-num{font-family:'Outfit',sans-serif;font-weight:800;font-size:36px;background:var(--fh-grad-2);-webkit-background-clip:text;background-clip:text;color:transparent}
.fh-stat-lbl{color:var(--fh-text-3);font-size:12px;text-transform:uppercase;letter-spacing:1px;margin-top:4px}

.fh-center{text-align:center}
.fh-mt-16{margin-top:16px}
.fh-mt-20{margin-top:20px}
.fh-mb-10{margin-bottom:10px}
.fh-section-title{font-family:'Outfit',sans-serif;font-size:22px;color:var(--fh-text-1);text-align:center;margin-bottom:6px}
.fh-section-sub{text-align:center;color:var(--fh-text-2);font-size:14px;margin-bottom:22px}
.fh-cta-wide{display:inline-block;width:auto;padding:14px 32px;margin:8px auto}

/* Author box */
.fh-author{display:flex;gap:16px;align-items:flex-start;background:var(--fh-bg-card);border:1px solid var(--fh-border-1);border-radius:var(--fh-r-md);padding:18px;margin:24px 0}
.fh-author-avatar{width:54px;height:54px;border-radius:50%;background:var(--fh-grad-1);display:flex;align-items:center;justify-content:center;font-size:28px;flex-shrink:0}
.fh-author h4{font-family:'Outfit',sans-serif;font-size:16px;color:var(--fh-text-1);margin-bottom:4px}
.fh-author p{font-size:13px;color:var(--fh-text-2);margin-bottom:4px;line-height:1.5}

/* Disclaimer */
.fh-disclaimer{background:rgba(245,158,11,0.06);border:1px solid rgba(245,158,11,0.25);border-left:3px solid #fbbf24;border-radius:var(--fh-r-md);padding:14px 18px;font-size:13px;color:var(--fh-text-2);margin:18px 0;line-height:1.55}

/* Footer */
.fh-footer{text-align:center;padding:24px 16px;margin-top:32px;border-top:1px solid var(--fh-border-1);color:var(--fh-text-3);font-size:13px}
.fh-footer p{margin-bottom:8px}
.fh-footer a{color:var(--fh-emerald-bright);text-decoration:none;margin:0 6px}
.fh-footer a:hover{text-decoration:underline}

/* Cookie banner */
.fh-cookie{
  position:fixed;bottom:16px;left:16px;right:16px;max-width:640px;margin:0 auto;
  background:var(--fh-bg-card);border:1px solid var(--fh-border-2);border-radius:var(--fh-r-md);
  padding:14px 18px;display:flex;flex-wrap:wrap;align-items:center;gap:12px;
  box-shadow:var(--fh-shadow-lg);z-index:200;font-size:13px;color:var(--fh-text-2);
}
.fh-cookie span{flex:1;min-width:200px;line-height:1.5}
.fh-cookie a{color:var(--fh-emerald-bright);text-decoration:none;font-weight:600}
.fh-cookie a:hover{text-decoration:underline}
.fh-cookie button{
  background:var(--fh-grad-1);color:#0a1628;border:none;
  padding:10px 20px;border-radius:var(--fh-r-sm);
  font-weight:700;cursor:pointer;font-family:inherit;font-size:14px;
  white-space:nowrap;
  box-shadow:0 4px 12px var(--fh-glow-1);
  transition:transform var(--fh-fast);
}
.fh-cookie button:hover{transform:translateY(-1px)}
/* When cookie banner is visible, push body content up so nothing overlaps.
   Uses a body class toggled by script.js (more reliable than :has()). */
body.fh-cookie-visible{padding-bottom:140px}
@media(max-width:600px){
  body.fh-cookie-visible{padding-bottom:180px}
  .fh-cookie{flex-direction:column;align-items:stretch;text-align:center}
  .fh-cookie button{width:100%}
}
/* Fallback for browsers that support :has() if class fails */
body:has(.fh-cookie:not([style*="display: none"])){padding-bottom:140px}

/* Modal pages (about, privacy, terms, contact) */
.fh-page{max-width:760px;margin:0 auto;padding:8px 4px}
.fh-page h2{font-family:'Outfit',sans-serif;font-size:28px;color:var(--fh-text-1);margin-bottom:12px}
.fh-page h3{font-family:'Outfit',sans-serif;font-size:18px;color:var(--fh-emerald-bright);margin:18px 0 8px}
.fh-page p{margin-bottom:12px;color:var(--fh-text-2);line-height:1.65}
.fh-back-link{display:inline-block;margin-top:16px;color:var(--fh-emerald-bright);text-decoration:none;font-weight:600}
.fh-back-link:hover{text-decoration:underline}

/* Blog article page */
.fh-article{max-width:760px;margin:0 auto}
.fh-crumb{font-size:12px;color:var(--fh-text-3);margin-bottom:8px}
.fh-crumb a{color:var(--fh-emerald-bright);text-decoration:none}
.fh-pub-date{font-size:12px;color:var(--fh-text-3);margin-bottom:14px}
.fh-article h2{font-family:'Outfit',sans-serif;font-size:28px;color:var(--fh-text-1);margin-bottom:16px;line-height:1.25}
.fh-article h3{font-family:'Outfit',sans-serif;font-size:19px;color:var(--fh-emerald-bright);margin:22px 0 10px}
.fh-article p{color:var(--fh-text-2);line-height:1.7;margin-bottom:14px}
.fh-article strong{color:var(--fh-text-1)}
.fh-article a{color:var(--fh-teal-bright);text-decoration:none;border-bottom:1px dotted}
.fh-article a:hover{color:var(--fh-cyan)}
.fh-article-nav{display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;margin-top:24px;padding-top:18px;border-top:1px solid var(--fh-border-1);font-size:14px}
.fh-article-nav a{color:var(--fh-emerald-bright);text-decoration:none}

/* Blog index grid */
.fh-blog-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px;margin-top:20px}
.fh-blog-card{display:block;background:var(--fh-bg-card);border:1px solid var(--fh-border-1);border-radius:var(--fh-r-md);padding:18px;text-decoration:none;color:inherit;transition:all var(--fh-smooth)}
.fh-blog-card:hover{transform:translateY(-3px);border-color:var(--fh-emerald)}
.fh-blog-tag{display:inline-block;background:rgba(16,185,129,0.12);color:var(--fh-emerald-bright);font-size:11px;font-weight:700;padding:3px 10px;border-radius:999px;margin-bottom:8px;letter-spacing:0.5px}
.fh-blog-card h4{font-family:'Outfit',sans-serif;font-size:16px;color:var(--fh-text-1);margin-bottom:6px;line-height:1.3}
.fh-blog-card p{font-size:13px;color:var(--fh-text-2);line-height:1.5}

/* FAQ */
.fh-faq-item{background:var(--fh-bg-card);border:1px solid var(--fh-border-1);border-radius:var(--fh-r-md);padding:16px;margin-bottom:12px}
.fh-faq-item h3{font-family:'Outfit',sans-serif;font-size:15px;color:var(--fh-text-1);margin-bottom:6px}
.fh-faq-item p{font-size:14px;color:var(--fh-text-2);line-height:1.6}

/* Insights */
.fh-insight-card{background:var(--fh-bg-card);border:1px solid var(--fh-border-1);border-radius:var(--fh-r-md);padding:18px;margin-bottom:14px}
.fh-insight-card h3{font-family:'Outfit',sans-serif;color:var(--fh-emerald-bright);font-size:16px;margin-bottom:6px}
.fh-insight-card p{font-size:14px;color:var(--fh-text-2);line-height:1.6}

/* Modal (cookie/terms popup) */
.fh-modal{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.75);z-index:300;align-items:center;justify-content:center;padding:20px}
.fh-modal.fh-open{display:flex}
.fh-modal-box{background:var(--fh-grad-card);border:1px solid var(--fh-border-2);border-radius:var(--fh-r-lg);padding:24px;max-width:560px;max-height:80vh;overflow-y:auto;position:relative}
.fh-modal-close{position:absolute;top:12px;right:14px;background:none;border:none;color:var(--fh-text-3);font-size:24px;cursor:pointer}

.fh-hide{display:none}

/* Responsive */
@media(max-width:768px){
  .fh-hero-title{font-size:34px}
  .fh-hero-sub{font-size:16px}
  .fh-card{padding:20px}
  .fh-nav{position:static}
  .fh-nav-link{padding:6px 10px;font-size:13px}
  .fh-result-value{font-size:18px}
  .fh-stats{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:480px){
  .fh-hero-title{font-size:28px}
  .fh-logo-text{font-size:24px}
  .fh-input-grid{grid-template-columns:1fr}
}

/* ===== Missing classes added for visual completeness ===== */

/* Author details inner container */
.fh-author-details{flex:1;min-width:0}
.fh-author-details h4{font-family:'Outfit',sans-serif;font-size:16px;color:var(--fh-text-1);margin-bottom:4px}
.fh-author-details p{font-size:13px;color:var(--fh-text-2);margin-bottom:4px;line-height:1.5}

/* Blog index cards */
.fh-blog-intro{font-size:15px;color:var(--fh-text-2);line-height:1.6;margin-bottom:18px;max-width:680px}
.fh-blog-divider{grid-column:1/-1;height:1px;background:var(--fh-border-1);margin:14px 0}
.fh-blog-card-num{display:inline-block;background:rgba(6,182,212,0.12);color:var(--fh-teal-bright);font-family:'JetBrains Mono',monospace;font-size:11px;font-weight:700;padding:2px 8px;border-radius:6px;margin-right:8px}
.fh-blog-card-title{font-family:'Outfit',sans-serif;font-size:16px;color:var(--fh-text-1);margin-bottom:6px;line-height:1.3}
.fh-crumb-link{color:var(--fh-emerald-bright);text-decoration:none}
.fh-crumb-link:hover{text-decoration:underline}

/* FAQ */
.fh-faq-section{max-width:780px;margin:0 auto}
.fh-faq-answer{color:var(--fh-text-2);font-size:14px;line-height:1.65;margin-top:6px}

/* Page title (insights, blogs, faq heading) */
.fh-page-title{font-family:'Outfit',sans-serif;font-size:28px;color:var(--fh-text-1);margin-bottom:14px;text-align:center}
.fh-page-title-margin{margin-top:30px;margin-bottom:14px;text-align:center}

/* SIP select dropdown */
.fh-sip-select{
  background:var(--fh-bg-2);color:var(--fh-text-1);
  border:1px solid var(--fh-border-2);border-radius:var(--fh-r-sm);
  padding:6px 12px;font-family:inherit;font-weight:600;font-size:14px;cursor:pointer;
}
.fh-sip-select:focus{outline:none;border-color:var(--fh-emerald)}

/* Stat tile (single stat inside .fh-stats grid) */
.fh-stat{
  background:var(--fh-bg-card);border:1px solid var(--fh-border-1);
  border-radius:var(--fh-r-md);padding:18px 12px;text-align:center;
  transition:transform var(--fh-fast),border-color var(--fh-fast);
}
.fh-stat:hover{transform:translateY(-2px);border-color:var(--fh-emerald)}

/* Step-up slider inside .fh-stepup */
.fh-stepup-slider{
  -webkit-appearance:none;appearance:none;
  width:120px;height:6px;background:var(--fh-bg-input);
  border-radius:3px;outline:none;cursor:pointer;
}
.fh-stepup-slider::-webkit-slider-thumb{
  -webkit-appearance:none;appearance:none;
  width:18px;height:18px;border-radius:50%;
  background:var(--fh-emerald);cursor:pointer;
  box-shadow:0 0 10px var(--fh-glow-1);
}
.fh-stepup-slider::-moz-range-thumb{
  width:18px;height:18px;border-radius:50%;
  background:var(--fh-emerald);cursor:pointer;border:none;
}

/* Modal — visible state */
.fh-modal.fh-open{display:flex}

/* Smooth scroll for tab nav clicks */
html{scroll-behavior:smooth;scroll-padding-top:80px}

/* Focus-visible for accessibility */
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible{
  outline:2px solid var(--fh-emerald-bright);outline-offset:2px;border-radius:4px;
}

/* Print-friendly: hide nav/ad/cookie on print */
@media print{
  .fh-nav,.fh-ad-banner,.fh-ad-inline,.fh-cookie,.fh-bg-particles{display:none!important}
  .fh-app{max-width:100%;padding:0}
  body{background:#fff;color:#000}
}

