/* ==========================================================================
   FSP Sprout — main stylesheet (ported & consolidated)
   FinanciallySavvyParent.com — primary #2E7D32 + honey-gold accent.
   Type: Newsreader (display) · Hanken Grotesk (UI/body)
   ========================================================================== */

:root{
  /* Brand greens */
  --forest:    #14401C;
  --pine:      #1B5E20;
  --primary:   #2E7D32;
  --leaf:      #43A047;
  --grass:     #66BB6A;
  --mint:      #A5D6A7;
  --wash:      #E8F5E9;
  --wash-2:    #DCEFDD;

  /* Honey gold accent */
  --gold:      #F4B740;
  --gold-deep: #D9941A;
  --gold-wash: #FDF3DC;

  /* Neutrals */
  --paper:     #F6FAF6;
  --white:     #FFFFFF;
  --ink:       #14241A;
  --slate:     #51635A;
  --muted:     #7C8C83;
  --line:      #E4EDE6;
  --line-2:    #D4E2D7;
  --gray-50:   #F2F5F3;

  /* Type families */
  --display: 'Newsreader', Georgia, 'Times New Roman', serif;
  --ui:      'Hanken Grotesk', system-ui, -apple-system, sans-serif;
  --body:    'Hanken Grotesk', system-ui, -apple-system, sans-serif;

  /* Radii */
  --r-xs: 8px;  --r-sm: 12px; --r-md: 16px; --r-lg: 22px; --r-xl: 30px; --r-pill: 999px;

  /* Shadows */
  --sh-sm: 0 1px 2px rgba(20,50,30,.06), 0 1px 3px rgba(20,50,30,.05);
  --sh-md: 0 10px 28px rgba(20,70,40,.09);
  --sh-lg: 0 24px 60px rgba(20,70,40,.14);
  --sh-gold:  0 12px 28px rgba(217,148,26,.28);
  --sh-green: 0 14px 30px rgba(46,125,50,.26);

  /* Layout */
  --container:      1200px;
  --container-wide: 1320px;
  --gutter: clamp(20px, 4vw, 40px);

  /* Spacing scale */
  --s1: 4px;  --s2: 8px;  --s3: 12px; --s4: 16px; --s5: 20px;
  --s6: 24px; --s8: 32px; --s10: 40px; --s12: 48px; --s16: 64px;
  --s20: 80px; --s24: 96px; --s30: 120px;
}

/* ---------- Reset / base ---------- */
*{ box-sizing: border-box; }
html{ -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body{
  margin: 0;
  font-family: var(--body);
  font-size: 17px;
  line-height: 1.7;
  color: var(--ink);
  background: var(--paper);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img{ max-width: 100%; height: auto; display: block; }
a{ color: inherit; text-decoration: none; }
button{ font-family: inherit; cursor: pointer; }
::selection{ background: var(--mint); color: var(--forest); }

h1,h2,h3,h4,h5{
  font-family: var(--display);
  color: var(--ink);
  margin: 0;
  line-height: 1.12;
  letter-spacing: -0.01em;
  font-weight: 700;
}
p{ margin: 0; }

/* ---------- Typo scale ---------- */
.display{ font-family:var(--display); font-weight:700; font-size: clamp(40px, 6vw, 66px); line-height:1.05; letter-spacing:-0.018em; }
.h1{ font-size: clamp(34px, 4.4vw, 50px); line-height:1.08; letter-spacing:-0.014em; }
.h2{ font-size: clamp(28px, 3.4vw, 38px); line-height:1.14; letter-spacing:-0.012em; }
.h3{ font-size: clamp(21px, 2vw, 26px);   line-height:1.24; letter-spacing:-0.008em; }
.h4{ font-family:var(--display); font-weight:700; font-size:20px; line-height:1.3; letter-spacing:-0.005em; }
.lead{ font-size: clamp(18px, 1.5vw, 21px); line-height:1.6; color: var(--slate); }
.small{ font-size: 15px; }
.eyebrow{
  font-family: var(--ui);
  font-weight: 700;
  font-size: 13px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--primary);
  display: inline-flex; align-items:center; gap:8px;
}
.muted{ color: var(--muted); }
.slate{ color: var(--slate); }

/* ---------- Layout helpers ---------- */
.container{ width:100%; max-width: var(--container); margin-inline:auto; padding-inline: var(--gutter); }
.container-wide{ max-width: var(--container-wide); }
.section{ padding-block: clamp(56px, 8vw, 112px); }
.section-sm{ padding-block: clamp(40px, 5vw, 64px); }
.center{ text-align:center; }
.stack{ display:flex; flex-direction:column; }
.row{ display:flex; align-items:center; }
.grid{ display:grid; gap: var(--s6); }

/* ---------- Buttons ---------- */
.btn{
  --bg: var(--primary); --fg:#fff; --bd: transparent;
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  font-family: var(--ui); font-weight:700; font-size:16px;
  padding: 14px 26px; border-radius: var(--r-pill);
  background: var(--bg); color: var(--fg); border:2px solid var(--bd);
  transition: transform .18s cubic-bezier(.34,1.56,.64,1), box-shadow .2s, background .2s;
  box-shadow: var(--sh-green); white-space:nowrap;
}
.btn:hover{ transform: translateY(-2px); }
.btn:active{ transform: translateY(0); }
.btn svg{ width:18px; height:18px; }
.btn--gold{ --bg: var(--gold); --fg:#3a2a06; box-shadow: var(--sh-gold); }
.btn--ghost{ --bg: transparent; --fg: var(--primary); --bd: var(--line-2); box-shadow:none; }
.btn--ghost:hover{ --bd: var(--primary); background: var(--wash); }
.btn--white{ --bg:#fff; --fg: var(--primary); box-shadow: var(--sh-md); }
.btn--lg{ padding: 17px 32px; font-size:17px; }
.btn--sm{ padding: 10px 18px; font-size:14px; box-shadow:none; }
.btn--block{ width:100%; }

/* ---------- Pills / chips / badges ---------- */
.chip{
  display:inline-flex; align-items:center; gap:7px;
  font-family:var(--ui); font-weight:700; font-size:13.5px;
  padding: 7px 14px; border-radius: var(--r-pill);
  background:#fff; color: var(--slate); border:1.5px solid var(--line-2);
  transition: all .16s ease;
}
.chip:hover{ border-color: var(--primary); color: var(--primary); background: var(--wash); }
.chip--active{ background: var(--primary); color:#fff; border-color: var(--primary); }
.chip .dot{ width:8px; height:8px; border-radius:50%; background: currentColor; opacity:.5; }

.badge{
  display:inline-flex; align-items:center; gap:6px;
  font-family:var(--ui); font-weight:700; font-size:12px; letter-spacing:.04em;
  text-transform:uppercase; padding:5px 11px; border-radius:7px;
  background: var(--wash); color: var(--primary);
}
.badge--gold{ background: var(--gold-wash); color: var(--gold-deep); }
.badge--solid{ background: var(--primary); color:#fff; }

/* Category color variants */
.cat-budget{ --c:#2E7D32; }
.cat-saving{ --c:#0E8C7E; }
.cat-invest{ --c:#5A53C9; }
.cat-teach{  --c:#D9941A; }
.cat-college{--c:#C0567A; }
.badge--cat{ background: color-mix(in srgb, var(--c) 12%, #fff); color: var(--c); }

/* ---------- Cards ---------- */
.card{
  background:#fff; border:1px solid var(--line); border-radius: var(--r-lg);
  overflow:hidden; transition: transform .22s ease, box-shadow .22s ease, border-color .22s;
  box-shadow: var(--sh-sm); display:flex; flex-direction:column;
}
.card:hover{ transform: translateY(-6px); box-shadow: var(--sh-lg); border-color: var(--line-2); }
.card__media{ position:relative; aspect-ratio: 16/10; overflow:hidden; }
.card__media img{ width:100%; height:100%; object-fit:cover; transition: transform .5s ease; }
.card:hover .card__media img{ transform: scale(1.05); }
.card__body{ padding: 20px 22px 24px; display:flex; flex-direction:column; gap:12px; flex:1; }
.card__title{ font-family:var(--display); font-weight:700; font-size:21px; line-height:1.22; letter-spacing:-0.008em; }
.card:hover .card__title{ color: var(--primary); }
.card__meta{ display:flex; align-items:center; gap:10px; font-size:13.5px; color: var(--muted); font-weight:600; }
.card__meta .sep{ width:3px; height:3px; border-radius:50%; background: currentColor; }

/* Image placeholders */
.ph{
  display:flex; align-items:center; justify-content:center; flex-direction:column; gap:10px;
  background: linear-gradient(135deg, var(--wash), var(--wash-2));
  color: var(--primary); width:100%; height:100%; position:relative;
}
.ph svg{ width:30%; max-width:88px; height:auto; opacity:.92; }
.ph__tag{
  position:absolute; bottom:10px; right:10px;
  font-family:var(--ui); font-weight:700; font-size:10px; letter-spacing:.08em; text-transform:uppercase;
  background: rgba(255,255,255,.78); color: var(--primary); padding:4px 8px; border-radius:6px;
}
.ph--gold{ background: linear-gradient(135deg, var(--gold-wash), #FBE6B8); color: var(--gold-deep); }
.ph--photo{ background: repeating-linear-gradient(45deg, #eef4ef, #eef4ef 12px, #e8f0e9 12px, #e8f0e9 24px); }

/* ---------- Author byline ---------- */
.byline{ display:flex; align-items:center; gap:12px; }
.avatar{ width:42px; height:42px; border-radius:50%; background: var(--mint); display:grid; place-items:center;
  font-family:var(--ui); font-weight:800; color: var(--forest); font-size:15px; flex:none; overflow:hidden; }
img.avatar{ object-fit:cover; }
.byline__name{ font-family:var(--ui); font-weight:700; font-size:14.5px; color:var(--ink); }
.byline__meta{ font-size:13px; color: var(--muted); }

/* ---------- Inputs ---------- */
.input, .textarea, select.input{
  width:100%; font-family: var(--body); font-size:16px; color: var(--ink);
  padding: 14px 18px; border-radius: var(--r-sm); border:1.5px solid var(--line-2);
  background:#fff; transition: border-color .16s, box-shadow .16s;
}
.input::placeholder{ color: var(--muted); }
.input:focus, .textarea:focus{ outline:none; border-color: var(--primary); box-shadow: 0 0 0 4px var(--wash); }
.field{ display:flex; flex-direction:column; gap:8px; }
.field > label{ font-family:var(--ui); font-weight:700; font-size:14px; color: var(--ink); }
.textarea{ font-family: var(--body); resize: vertical; min-height: 120px; }

/* ---------- Section heading block ---------- */
.sec-head{ display:flex; flex-direction:column; gap:14px; max-width: 640px; }
.sec-head.center{ margin-inline:auto; align-items:center; text-align:center; }
.sec-head__row{ display:flex; align-items:flex-end; justify-content:space-between; gap:20px; flex-wrap:wrap; }
.sec-link{ font-family:var(--ui); font-weight:700; font-size:15px; color:var(--primary); display:inline-flex; align-items:center; gap:7px; }
.sec-link .ic{ width:18px; height:18px; transition: transform .18s; }
.sec-link:hover .ic{ transform: translateX(3px); }

/* ---------- Divider ---------- */
.rule{ height:1px; background: var(--line); border:0; }

/* ---------- Reveal-on-scroll ---------- */
.reveal{ opacity:0; transform: translateY(22px); transition: opacity .7s cubic-bezier(.2,.7,.3,1), transform .7s cubic-bezier(.2,.7,.3,1); }
.reveal.in{ opacity:1; transform:none; }
.reveal.d1{ transition-delay:.08s; } .reveal.d2{ transition-delay:.16s; }
.reveal.d3{ transition-delay:.24s; } .reveal.d4{ transition-delay:.32s; }
@media (prefers-reduced-motion: reduce){
  .reveal{ opacity:1; transform:none; transition:none; }
  *{ scroll-behavior:auto !important; }
  .float-card{ animation:none !important; }
}

/* ---------- Decorative blobs ---------- */
.blob{ position:absolute; border-radius:50%; filter: blur(2px); opacity:.5; pointer-events:none; z-index:0; }

/* ==========================================================================
   SITE HEADER
   ========================================================================== */
.topbar{ background: var(--forest); color:#cfe6d2; font-size:13.5px; }
.topbar .container{ display:flex; align-items:center; justify-content:space-between; height:40px; gap:16px; }
.topbar a{ color:#eaf6ec; font-weight:600; }
.topbar__links{ display:flex; gap:20px; align-items:center; }

.site-header{ position:sticky; top:0; z-index:50; background: rgba(255,255,255,.86);
  backdrop-filter: blur(14px); border-bottom:1px solid var(--line); transition: box-shadow .25s, padding .25s; }
.site-header.scrolled{ box-shadow: var(--sh-md); }
.nav{ display:flex; align-items:center; justify-content:space-between; height:74px; gap:24px; }
.brand{ display:flex; align-items:center; gap:11px; font-family:var(--display); font-weight:700; font-size:21px; color:var(--ink); letter-spacing:-0.01em; }
.brand__mark{ width:42px; height:42px; flex:none; border-radius:13px; background: linear-gradient(150deg, var(--primary), var(--leaf));
  display:grid; place-items:center; box-shadow: var(--sh-green); }
.brand__mark svg{ width:26px; height:26px; }
.brand small{ display:block; font-family:var(--body); font-weight:600; font-size:11px; letter-spacing:.06em; color:var(--muted); text-transform:uppercase; margin-top:-2px; }
.nav__menu{ display:flex; align-items:center; gap:4px; list-style:none; margin:0; padding:0; }
.nav__menu > li > a{ display:inline-flex; align-items:center; gap:6px; font-family:var(--ui); font-weight:600; font-size:15.5px;
  color: var(--ink); padding:10px 14px; border-radius:10px; transition: background .15s, color .15s; }
.nav__menu > li > a:hover{ background: var(--wash); color: var(--primary); }
.nav__menu .has-sub > a::after{ content:""; width:7px; height:7px; border-right:2px solid currentColor; border-bottom:2px solid currentColor;
  transform: rotate(45deg) translateY(-2px); opacity:.5; margin-left:2px; }
.nav__actions{ display:flex; align-items:center; gap:12px; }
.icon-btn{ width:42px; height:42px; border-radius:12px; border:1.5px solid var(--line-2); background:#fff; display:grid; place-items:center; color:var(--slate); transition: all .15s; }
.icon-btn:hover{ border-color: var(--primary); color: var(--primary); }
.burger{ display:none; }

/* dropdown mega */
.has-sub{ position:relative; }
.subnav{ position:absolute; top:calc(100% + 8px); left:0; min-width:230px; background:#fff; border:1px solid var(--line);
  border-radius: var(--r-md); box-shadow: var(--sh-lg); padding:8px; opacity:0; visibility:hidden; transform: translateY(8px);
  transition: all .18s ease; z-index:60; }
.has-sub:hover .subnav, .has-sub:focus-within .subnav{ opacity:1; visibility:visible; transform:none; }
.subnav a{ display:flex; align-items:center; gap:11px; padding:10px 12px; border-radius:10px; font-weight:600; font-size:15px; color:var(--slate); }
.subnav a:hover{ background: var(--wash); color: var(--primary); }
.subnav a svg{ width:20px; height:20px; flex:none; color: var(--primary); }
.nav__menu a.is-active{ background: var(--wash); color: var(--primary); }

/* WP custom-logo container */
.brand .custom-logo-link{ display:inline-flex; }
.brand .custom-logo{ max-height: 56px; width: auto; }

/* Search overlay */
.search-overlay{ position:fixed; inset:0; z-index:99; background: rgba(20,40,26,.55); backdrop-filter: blur(3px);
  opacity:0; visibility:hidden; transition: opacity .22s; display:flex; align-items:flex-start; justify-content:center; padding-top:96px; }
.search-overlay.open{ opacity:1; visibility:visible; }
.search-overlay__panel{ width:min(720px, 92vw); background:#fff; border:1px solid var(--line); border-radius: var(--r-xl);
  box-shadow: var(--sh-lg); padding:20px; position:relative; }
.search-overlay__form{ display:flex; gap:10px; align-items:center; }
.search-overlay__input{ flex:1; font-size:17px; padding:14px 18px; }
.search-overlay__close{ position:absolute; top:14px; right:14px; }
.search-overlay.open .search-overlay__input{ animation: fade .25s ease both; }
@keyframes fade{ from{ opacity:0; transform: translateY(-4px); } to{ opacity:1; transform:none; } }

/* ==========================================================================
   FOOTER
   ========================================================================== */
.site-footer{ background: var(--forest); color:#bfdcc4; }
.footer-cta{ background: linear-gradient(135deg, var(--primary), var(--pine)); color:#fff; border-radius: var(--r-xl);
  padding: clamp(32px,5vw,56px); position:relative; overflow:hidden; }
.footer-main{ padding-block: clamp(48px,6vw,80px) 40px; }
.footer-grid{ display:grid; grid-template-columns: 1.6fr 1fr 1fr 1fr; gap: 40px; }
.footer-col h5{ font-family:var(--ui); color:#fff; font-size:13px; letter-spacing:.06em; text-transform:uppercase; margin-bottom:16px; font-weight:700; }
.footer-col ul{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:11px; }
.footer-col a{ color:#bfdcc4; font-size:15px; }
.footer-col a:hover{ color:#fff; }
.footer-bottom{ border-top:1px solid rgba(255,255,255,.12); padding-block:22px; display:flex; justify-content:space-between; align-items:center; gap:16px; flex-wrap:wrap; font-size:13.5px; color:#9cc0a3; }
.footer-brand{ display:flex; align-items:center; gap:11px; font-family:var(--display); font-weight:700; font-size:20px; color:#fff; margin-bottom:14px; }
.footer-brand .brand__mark{ box-shadow:none; }
.soc{ display:flex; gap:10px; }
.soc a{ width:38px; height:38px; border-radius:11px; background: rgba(255,255,255,.08); display:grid; place-items:center; color:#cfe6d2; transition: all .15s; }
.soc a:hover{ background: var(--gold); color:#3a2a06; }

/* ==========================================================================
   GRID PATTERNS
   ========================================================================== */
.cols-3{ grid-template-columns: repeat(3, 1fr); }
.cols-4{ grid-template-columns: repeat(4, 1fr); }
.cols-2{ grid-template-columns: repeat(2, 1fr); }

/* content + sidebar layout */
.with-sidebar{ display:grid; grid-template-columns: minmax(0,1fr) 340px; gap: 56px; align-items:start; }

/* ==========================================================================
   WIDGETS
   ========================================================================== */
.widget{ background:#fff; border:1px solid var(--line); border-radius: var(--r-lg); padding:24px; box-shadow: var(--sh-sm); }
.widget + .widget{ margin-top:24px; }
.widget h4{ font-family:var(--ui); font-weight:800; font-size:15px; letter-spacing:.02em; margin-bottom:16px; display:flex; align-items:center; gap:9px; }
.widget h4 .tick{ width:18px; height:3px; border-radius:3px; background: var(--gold); }
.widget ul{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:10px; }
.widget li a{ font-weight:600; color:var(--slate); font-size:15px; }
.widget li a:hover{ color:var(--primary); }
.sticky-side{ position:sticky; top:96px; }

.pop{ display:flex; gap:13px; align-items:flex-start; }
.pop + .pop{ margin-top:16px; padding-top:16px; border-top:1px solid var(--line); }
.pop__n{ font-family:var(--display); font-weight:800; font-size:22px; color:var(--mint); line-height:1; flex:none; width:24px; }
.pop h5{ font-family:var(--display); font-weight:700; font-size:14.5px; line-height:1.3; }
.pop .card__meta{ margin-top:4px; }
.side-news{ background:linear-gradient(135deg,var(--primary),var(--leaf)); border-radius:var(--r-lg); padding:24px; color:#fff; text-align:center; }
.side-news .il{ width:60px; height:60px; }
.side-news h4{ color:#fff; font-size:17px; margin:8px 0 6px; }
.side-news p{ color:#dcefe0; font-size:14px; margin-bottom:14px; }
.side-news input{ width:100%; border:0; border-radius:var(--r-pill); padding:11px 16px; font-family:var(--body); font-size:14px; margin-bottom:9px; }

/* ==========================================================================
   MOBILE DRAWER
   ========================================================================== */
.drawer{ position:fixed; inset:0; z-index:100; background: rgba(20,40,26,.45); backdrop-filter: blur(3px);
  opacity:0; visibility:hidden; transition: opacity .25s; }
.drawer.open{ opacity:1; visibility:visible; }
.drawer__panel{ position:absolute; top:0; right:0; height:100%; width:min(86vw, 360px); background:#fff;
  box-shadow: var(--sh-lg); padding:22px; display:flex; flex-direction:column; gap:18px;
  transform: translateX(100%); transition: transform .3s cubic-bezier(.4,0,.2,1); overflow-y:auto; }
.drawer.open .drawer__panel{ transform:none; }
.drawer__top{ display:flex; align-items:center; justify-content:space-between; }
.drawer__top .brand small{ display:none; }
.drawer__nav{ display:flex; flex-direction:column; gap:2px; border-top:1px solid var(--line); padding-top:14px; }
.drawer__nav .menu-item, .drawer__nav a, .drawer__nav li > a{
  font-family:var(--display); font-weight:600; font-size:21px; padding:13px 10px; border-radius:12px; color:var(--ink); display:block; }
.drawer__nav a:hover, .drawer__nav a.is-active, .drawer__nav .current-menu-item > a{ background: var(--wash); color: var(--primary); }
.drawer__soc{ display:flex; gap:10px; margin-top:auto; padding-top:10px; }
.drawer__soc a{ width:42px; height:42px; border-radius:12px; background: var(--wash); display:grid; place-items:center; color: var(--primary); }
.drawer__search input{ font-size:15px; padding:12px 16px; }

/* ==========================================================================
   HOMEPAGE
   ========================================================================== */
.hero{ position:relative; overflow:hidden; padding-block: clamp(40px,6vw,84px) clamp(48px,7vw,96px); }
.hero__grid{ display:grid; grid-template-columns: 1.05fr .95fr; gap: clamp(32px,5vw,64px); align-items:center; position:relative; z-index:2; }
.hero h1{ font-size: clamp(38px, 5.4vw, 62px); line-height:1.04; letter-spacing:-0.03em; margin:18px 0 20px; }
.hero h1 .hl{ position:relative; white-space:nowrap; color: var(--primary); }
.hero h1 .hl::after{ content:""; position:absolute; left:-2px; right:-2px; bottom:4px; height:14px; background: var(--gold); opacity:.35; border-radius:6px; z-index:-1; }
.hero__cta{ display:flex; gap:14px; flex-wrap:wrap; margin-top:28px; }
.hero__trust{ display:flex; gap:28px; margin-top:32px; flex-wrap:wrap; }
.hero__trust .num{ font-family:var(--display); font-weight:800; font-size:26px; color:var(--forest); letter-spacing:-0.02em; }
.hero__trust .lbl{ font-size:13.5px; color:var(--muted); font-weight:600; }
.hero__art{ position:relative; }
.hero__photo{ border-radius: var(--r-xl); aspect-ratio: 4/4.4; box-shadow: var(--sh-lg); border:1px solid var(--line); }
.float-card{ position:absolute; background:#fff; border:1px solid var(--line); border-radius: var(--r-md); box-shadow: var(--sh-lg); padding:14px 16px; display:flex; align-items:center; gap:12px; }
.float-card .il{ width:42px; height:42px; }
.float-card .ttl{ font-family:var(--display); font-weight:800; font-size:15px; line-height:1.15; }
.float-card .sub{ font-size:12px; color:var(--muted); font-weight:600; }
.fc-1{ top:8%; left:-26px; animation: bob 5s ease-in-out infinite; }
.fc-2{ bottom:12%; right:-22px; animation: bob 5s ease-in-out infinite .8s; }
.fc-3{ bottom:-18px; left:14%; animation: bob 6s ease-in-out infinite .4s; }
@keyframes bob{ 0%,100%{ transform: translateY(0);} 50%{ transform: translateY(-9px);} }

.statbar{ border-top:1px solid var(--line); border-bottom:1px solid var(--line); background:#fff; }
.statbar__grid{ display:grid; grid-template-columns: repeat(4,1fr); }
.statbar__item{ padding:26px 20px; text-align:center; border-right:1px solid var(--line); display:flex; flex-direction:column; gap:4px; }
.statbar__item:last-child{ border-right:0; }
.statbar__num{ font-family:var(--display); font-weight:800; font-size:30px; color:var(--primary); letter-spacing:-0.02em; }
.statbar__lbl{ font-size:14px; color:var(--slate); font-weight:600; }

.feat-grid{ display:grid; grid-template-columns: 1.5fr 1fr; gap:26px; }
.feat-lead{ position:relative; border-radius: var(--r-lg); overflow:hidden; min-height:420px; display:flex; flex-direction:column; justify-content:flex-end;
  color:#fff; border:1px solid var(--line); box-shadow: var(--sh-md); }
.feat-lead .ph, .feat-lead img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.feat-lead__scrim{ position:absolute; inset:0; background: linear-gradient(180deg, rgba(20,64,28,0) 30%, rgba(20,64,28,.86) 100%); }
.feat-lead__body{ position:relative; padding:30px; display:flex; flex-direction:column; gap:14px; }
.feat-lead__body h3{ color:#fff; font-size: clamp(24px,2.6vw,32px); }
.feat-lead__body p{ color:#e4f2e6; max-width:48ch; }
.feat-side{ display:flex; flex-direction:column; gap:18px; }
.feat-mini{ display:grid; grid-template-columns: 116px 1fr; gap:16px; background:#fff; border:1px solid var(--line); border-radius: var(--r-md); overflow:hidden; box-shadow: var(--sh-sm); transition: transform .2s, box-shadow .2s; }
.feat-mini:hover{ transform: translateX(4px); box-shadow: var(--sh-md); }
.feat-mini .ph{ min-height:100%; }
.feat-mini__b{ padding:14px 16px 14px 0; display:flex; flex-direction:column; gap:7px; justify-content:center; }
.feat-mini__b h4{ font-size:16.5px; line-height:1.25; }

.cat-grid{ display:grid; grid-template-columns: repeat(5,1fr); gap:18px; }
.cat-card{ background:#fff; border:1px solid var(--line); border-radius: var(--r-lg); padding:24px 20px; text-align:center; display:flex; flex-direction:column; align-items:center; gap:12px;
  transition: transform .2s, box-shadow .2s, border-color .2s; box-shadow: var(--sh-sm); }
.cat-card:hover{ transform: translateY(-6px); box-shadow: var(--sh-lg); border-color: var(--mint); }
.cat-card__ic{ width:74px; height:74px; border-radius:20px; display:grid; place-items:center; background: var(--wash); }
.cat-card__ic .il{ width:46px; height:46px; }
.cat-card h4{ font-size:17px; }
.cat-card .n{ font-size:13px; color:var(--muted); font-weight:700; }

.tip{ background: linear-gradient(135deg, var(--wash), #fff); border:1px solid var(--line); border-radius: var(--r-xl); overflow:hidden; position:relative; }
.tip__grid{ display:grid; grid-template-columns: 1.2fr 1fr; gap:40px; align-items:center; padding: clamp(28px,4vw,52px); }
.tip__art{ display:grid; place-items:center; }
.tip__art .il{ width:min(260px, 70%); height:auto; }
.tip__num{ font-family:var(--display); font-weight:800; font-size:13px; letter-spacing:.14em; text-transform:uppercase; color:var(--gold-deep); }

.promo{ background: var(--forest); border-radius: var(--r-xl); overflow:hidden; position:relative; color:#fff; }
.promo__grid{ display:grid; grid-template-columns: 1fr 1fr; gap:44px; align-items:center; padding: clamp(30px,4vw,56px); position:relative; z-index:2; }
.promo h2{ color:#fff; }
.promo ul{ list-style:none; margin:18px 0 26px; padding:0; display:flex; flex-direction:column; gap:12px; }
.promo li{ display:flex; align-items:flex-start; gap:11px; color:#dcefe0; font-weight:500; }
.promo li .tick{ width:24px; height:24px; border-radius:7px; background: var(--gold); color:#3a2a06; display:grid; place-items:center; flex:none; margin-top:1px; }
.promo-card{ background:#fff; border-radius: var(--r-lg); overflow:hidden; box-shadow: var(--sh-lg); color:var(--ink); }
.promo-card .ph{ aspect-ratio:16/10; }
.promo-card__b{ padding:22px; display:flex; flex-direction:column; gap:12px; }
.promo-price{ display:flex; align-items:baseline; gap:10px; }
.promo-price .now{ font-family:var(--display); font-weight:800; font-size:30px; color:var(--primary); }
.promo-price .was{ text-decoration:line-through; color:var(--muted); font-weight:600; }

.tst-grid{ display:grid; grid-template-columns: repeat(3,1fr); gap:22px; }
.tst{ background:#fff; border:1px solid var(--line); border-radius: var(--r-lg); padding:26px; box-shadow: var(--sh-sm); display:flex; flex-direction:column; gap:16px; margin:0; }
.tst__stars{ display:flex; gap:3px; color: var(--gold); }
.tst__stars .ic{ width:18px; height:18px; }
.tst p{ font-size:16.5px; line-height:1.6; color:var(--ink); margin:0; }
.tst .quote{ width:34px; height:34px; color: var(--mint); }

.news{ background: linear-gradient(135deg, var(--primary), var(--leaf)); border-radius: var(--r-xl); position:relative; overflow:hidden; color:#fff; }
.news__in{ position:relative; z-index:2; padding: clamp(36px,5vw,64px); text-align:center; max-width:680px; margin-inline:auto; }
.news h2{ color:#fff; }
.news form{ display:flex; gap:12px; margin-top:24px; background:#fff; padding:8px; border-radius: var(--r-pill); box-shadow: var(--sh-lg); }
.news input{ flex:1; border:0; background:transparent; padding:12px 18px; font-size:16px; font-family:var(--body); outline:none; }
.news .hintrow{ display:flex; gap:18px; justify-content:center; margin-top:18px; flex-wrap:wrap; color:#dcefe0; font-size:13.5px; font-weight:600; }
.news .hintrow span{ display:inline-flex; align-items:center; gap:6px; }
.news-success{ display:flex; flex-direction:column; align-items:center; gap:8px; margin-top:24px; padding:22px 24px; background:rgba(255,255,255,.12); border:1px solid rgba(255,255,255,.28); border-radius: var(--r-lg); box-shadow: var(--sh-md); }
.news-success__icon{ display:inline-flex; align-items:center; justify-content:center; width:42px; height:42px; border-radius:50%; background:var(--gold); color:#1b3a1f; box-shadow: 0 4px 14px rgba(0,0,0,.18); }
.news-success__title{ font-family: var(--display); font-size: clamp(22px, 3vw, 28px); color:#fff; margin-top:4px; }
.news-success__text{ color:#e4f2e6; font-size:15.5px; }

/* ==========================================================================
   BLOG INDEX / ARCHIVE / CATEGORY
   ========================================================================== */
.blog-top{ background:linear-gradient(180deg,var(--wash),var(--paper)); border-bottom:1px solid var(--line); }
.blog-top .container{ padding-block:clamp(32px,4vw,52px); }
.blog-top h1{ font-size:clamp(34px,4.6vw,52px); margin:12px 0 12px; }
.blog-feat{ display:grid; grid-template-columns:1.3fr 1fr; gap:30px; margin-top:30px; align-items:stretch; }
.blog-feat__lead{ position:relative; border-radius:var(--r-xl); overflow:hidden; min-height:380px; display:flex; flex-direction:column; justify-content:flex-end; color:#fff; box-shadow:var(--sh-md); }
.blog-feat__lead .ph, .blog-feat__lead img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.blog-feat__lead .scrim{ position:absolute; inset:0; background:linear-gradient(180deg,rgba(20,64,28,0) 35%,rgba(20,64,28,.88)); }
.blog-feat__lead .b{ position:relative; padding:32px; display:flex; flex-direction:column; gap:13px; }
.blog-feat__lead h2{ color:#fff; font-size:clamp(24px,2.8vw,32px); }
.blog-feat__side{ display:flex; flex-direction:column; gap:18px; }
.blog-feat__mini{ display:grid; grid-template-columns:120px 1fr; gap:15px; background:#fff; border:1px solid var(--line); border-radius:var(--r-md); overflow:hidden; box-shadow:var(--sh-sm); transition:transform .2s,box-shadow .2s; flex:1; }
.blog-feat__mini:hover{ transform:translateX(4px); box-shadow:var(--sh-md); }
.blog-feat__mini .ph{ height:100%; }
.blog-feat__mini .mb{ padding:14px 14px 14px 0; display:flex; flex-direction:column; gap:7px; justify-content:center; }
.blog-feat__mini h4{ font-size:16px; line-height:1.25; }

.filterbar{ position:sticky; top:74px; z-index:20; background:rgba(246,250,246,.92); backdrop-filter:blur(10px); border-bottom:1px solid var(--line); }
.filterbar .container{ display:flex; align-items:center; justify-content:space-between; gap:16px; padding-block:14px; }
.filterbar__chips{ display:flex; gap:9px; overflow-x:auto; padding-bottom:2px; }
.filterbar__chips::-webkit-scrollbar{ display:none; }
.resultcount{ font-size:14px; color:var(--muted); font-weight:600; white-space:nowrap; }
.sortsel{ display:flex; align-items:center; gap:8px; font-size:14px; color:var(--slate); font-weight:600; white-space:nowrap; }
.sortsel select{ font-family:var(--display); font-weight:700; font-size:14px; color:var(--ink); border:1.5px solid var(--line-2); border-radius:var(--r-pill); padding:8px 14px; background:#fff; }
.sortsel form{ display:inline-flex; align-items:center; }

.arch-hero{ background: linear-gradient(135deg, var(--wash), #fff); border-bottom:1px solid var(--line); position:relative; overflow:hidden; }
.arch-hero .container{ padding-block: clamp(32px,5vw,56px); position:relative; z-index:2; }
.arch-hero__grid{ display:grid; grid-template-columns:1fr auto; gap:32px; align-items:center; }
.arch-hero h1{ font-size:clamp(32px,4.2vw,46px); margin:12px 0 12px; }
.arch-hero .lead{ max-width:54ch; }
.arch-ic{ width:120px; height:120px; border-radius:30px; background:#fff; box-shadow:var(--sh-md); display:grid; place-items:center; border:1px solid var(--line); }
.arch-ic .il{ width:76px; height:76px; }
.arch-stats{ display:flex; gap:24px; margin-top:18px; }
.arch-stats .num{ font-family:var(--display); font-weight:800; font-size:20px; color:var(--primary); }
.arch-stats .lbl{ font-size:13px; color:var(--muted); font-weight:600; }

.arch-body{ display:grid; grid-template-columns: minmax(0,1fr) 320px; gap:48px; align-items:start; }

.pagination{ display:flex; gap:8px; justify-content:center; margin-top:44px; flex-wrap:wrap; }
.pagination a, .pagination span{ min-width:44px; height:44px; padding:0 10px; border-radius:12px; border:1px solid var(--line-2); background:#fff; display:grid; place-items:center; font-family:var(--display); font-weight:700; font-size:15px; color:var(--slate); transition:all .15s; }
.pagination a:hover{ border-color:var(--primary); color:var(--primary); }
.pagination .current, .pagination a.is-current{ background:var(--primary); color:#fff; border-color:var(--primary); }
.pagination .dots{ border:0; background:transparent; }
.page-numbers{ text-decoration:none; }

/* ==========================================================================
   SINGLE POST
   ========================================================================== */
.post-hero{ background: linear-gradient(180deg, var(--wash), var(--paper)); padding-block: clamp(28px,4vw,48px) 0; }
.crumb{ display:flex; align-items:center; gap:8px; font-size:13.5px; color:var(--muted); font-weight:600; margin-bottom:20px; flex-wrap:wrap; }
.crumb a:hover{ color:var(--primary); }
.crumb .sep{ opacity:.5; }
.post-head{ max-width:760px; }
.post-head h1{ font-size:clamp(30px,4.4vw,48px); line-height:1.08; margin:14px 0 18px; letter-spacing:-0.025em; }
.post-head .lead{ margin-bottom:22px; }
.post-meta{ display:flex; align-items:center; gap:20px; flex-wrap:wrap; padding-bottom:26px; }
.post-meta .byline{ gap:11px; }
.post-meta .m{ display:flex; align-items:center; gap:7px; font-size:14px; color:var(--slate); font-weight:600; }
.post-meta .m .ic{ width:16px; height:16px; color:var(--primary); }
.post-cover{ border-radius:var(--r-xl); overflow:hidden; aspect-ratio:16/8; box-shadow:var(--sh-lg); border:1px solid var(--line); margin-top:6px; }
.post-cover img, .post-cover .ph{ width:100%; height:100%; object-fit:cover; }

.post-body{ display:grid; grid-template-columns: 64px minmax(0,720px) 340px; gap:40px; align-items:start; justify-content:center; padding-block:clamp(36px,5vw,64px); }

.share-rail{ position:sticky; top:100px; display:flex; flex-direction:column; gap:10px; align-items:center; }
.share-rail .lbl{ font-size:11px; font-weight:700; color:var(--muted); text-transform:uppercase; letter-spacing:.08em; writing-mode:vertical-rl; margin-bottom:6px; }
.share-rail a{ width:44px; height:44px; border-radius:13px; border:1px solid var(--line-2); background:#fff; display:grid; place-items:center; color:var(--slate); transition:all .15s; }
.share-rail a:hover{ border-color:var(--primary); color:var(--primary); background:var(--wash); transform:translateY(-2px); }

.prose{ font-size:18px; line-height:1.75; color:var(--ink); }
.prose > p{ margin-bottom:24px; }
.prose > p:first-of-type::first-letter{ font-family:var(--display); font-weight:800; font-size:62px; line-height:.8; float:left; color:var(--primary); padding:6px 12px 0 0; }
.prose h2{ font-size:28px; margin:40px 0 14px; letter-spacing:-0.02em; }
.prose h3{ font-size:21px; margin:30px 0 10px; }
.prose ul{ margin:0 0 24px; padding-left:0; list-style:none; display:flex; flex-direction:column; gap:11px; }
.prose ul li{ position:relative; padding-left:32px; }
.prose ul li::before{ content:""; position:absolute; left:0; top:7px; width:18px; height:18px; border-radius:6px; background:var(--wash);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%232E7D32' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M5 12.5 10 17.5 19 7'/%3E%3C/svg%3E"); background-size:13px; background-repeat:no-repeat; background-position:center; }
.prose ol{ margin:0 0 24px 20px; padding:0; }
.prose ol li{ margin-bottom:8px; }
.prose a, .prose a.link{ color:var(--primary); font-weight:700; text-decoration:underline; text-decoration-color:var(--mint); text-underline-offset:3px; }
.prose strong{ font-weight:700; }
.prose blockquote{ border-left:4px solid var(--gold); padding:6px 0 6px 24px; margin:30px 0; font-family:var(--display); font-weight:700; font-size:24px; line-height:1.35; color:var(--forest); letter-spacing:-0.01em; font-style:normal; }
.prose img, .prose figure img{ border-radius:var(--r-md); margin:24px auto; }
.prose figcaption{ font-size:13.5px; color:var(--muted); margin-top:10px; text-align:center; }
.prose code{ background:var(--wash); color:var(--pine); padding:2px 7px; border-radius:6px; font-family:ui-monospace,SFMono-Regular,Menlo,monospace; font-size:.9em; }
.prose pre{ background:var(--gray-50); border:1px solid var(--line); border-radius:var(--r-md); padding:18px; overflow:auto; font-family:ui-monospace,SFMono-Regular,Menlo,monospace; font-size:14.5px; }
.callout{ background:var(--wash); border:1px solid var(--mint); border-radius:var(--r-lg); padding:24px 26px; margin:30px 0; display:flex; gap:18px; align-items:flex-start; }
.callout .il{ width:54px; height:54px; flex:none; }
.callout h4{ font-size:17px; margin-bottom:6px; color:var(--forest); }
.callout p{ margin:0; font-size:16px; color:var(--slate); line-height:1.6; }
.callout--gold{ background:var(--gold-wash); border-color:#F2D58A; }
.callout--gold h4{ color:var(--gold-deep); }
.pquote{ border-left:4px solid var(--gold); padding:6px 0 6px 24px; margin:30px 0; font-family:var(--display); font-weight:700; font-size:24px; line-height:1.35; color:var(--forest); letter-spacing:-0.01em; }
.fig{ margin:30px 0; }
.fig .ph{ border-radius:var(--r-lg); aspect-ratio:16/9; border:1px solid var(--line); }
.fig figcaption{ font-size:13.5px; color:var(--muted); margin-top:10px; text-align:center; }
.tags{ display:flex; gap:9px; flex-wrap:wrap; margin:36px 0; }
.author-box{ display:flex; gap:18px; align-items:flex-start; background:#fff; border:1px solid var(--line); border-radius:var(--r-lg); padding:24px; margin-top:8px; box-shadow:var(--sh-sm); }
.author-box .avatar{ width:64px; height:64px; font-size:22px; }
.author-box h4{ font-size:18px; }
.related{ background:linear-gradient(180deg,#fff,var(--paper)); border-top:1px solid var(--line); }
.post-progress{ position:fixed; top:0; left:0; height:3px; background:var(--gold); z-index:80; width:0; transition: width .12s linear; }
.admin-bar .post-progress{ top:32px; }
@media screen and (max-width: 782px){ .admin-bar .post-progress{ top:46px; } }

/* ==========================================================================
   ABOUT / DEFAULT PAGE
   ========================================================================== */
.ab-hero{ background:linear-gradient(135deg,var(--wash),#fff); border-bottom:1px solid var(--line); position:relative; overflow:hidden; }
.ab-hero .container{ padding-block:clamp(40px,6vw,80px); position:relative; z-index:2; text-align:center; }
.ab-hero h1{ font-size:clamp(34px,5vw,56px); margin:16px auto 18px; max-width:16ch; }
.ab-hero .lead{ max-width:60ch; margin-inline:auto; }
.mission{ display:grid; grid-template-columns:1fr 1fr; gap:50px; align-items:center; }
.mission .ph{ border-radius:var(--r-xl); aspect-ratio:4/3.4; box-shadow:var(--sh-lg); border:1px solid var(--line); }
.values{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.value{ background:#fff; border:1px solid var(--line); border-radius:var(--r-lg); padding:28px; box-shadow:var(--sh-sm); }
.value .ic-wrap{ width:62px; height:62px; border-radius:18px; background:var(--wash); display:grid; place-items:center; margin-bottom:16px; }
.value .ic-wrap .il{ width:40px; height:40px; }
.team{ display:grid; grid-template-columns:repeat(4,1fr); gap:22px; }
.member{ text-align:center; }
.member .ph{ aspect-ratio:1; border-radius:24px; margin-bottom:14px; border:1px solid var(--line); }
.bignum{ display:grid; grid-template-columns:repeat(4,1fr); gap:0; background:#fff; border:1px solid var(--line); border-radius:var(--r-xl); overflow:hidden; box-shadow:var(--sh-sm); }
.bignum > div{ padding:30px 20px; text-align:center; border-right:1px solid var(--line); }
.bignum > div:last-child{ border-right:0; }
.bignum .n{ font-family:var(--display); font-weight:800; font-size:clamp(28px,3vw,40px); color:var(--primary); letter-spacing:-0.02em; }
.bignum .l{ font-size:14px; color:var(--slate); font-weight:600; margin-top:4px; }

/* ==========================================================================
   RESOURCES
   ========================================================================== */
.res-hero{ background:linear-gradient(135deg,var(--wash),#fff); border-bottom:1px solid var(--line); position:relative; overflow:hidden; }
.res-hero .container{ padding-block:clamp(36px,5vw,60px); position:relative; z-index:2; }
.res-hero h1{ font-size:clamp(34px,4.6vw,52px); margin:14px 0 14px; max-width:18ch; }
.res-hero .lead{ max-width:58ch; }
.lead-magnet{ background:var(--forest); border-radius:var(--r-xl); overflow:hidden; color:#fff; position:relative; margin-top:34px; }
.lead-magnet__grid{ display:grid; grid-template-columns:1fr 1fr; gap:36px; align-items:center; padding:clamp(26px,3.5vw,44px); position:relative; z-index:2; }
.lead-magnet h2{ color:#fff; font-size:clamp(24px,3vw,34px); }
.lm-form{ display:flex; gap:10px; margin-top:20px; background:#fff; padding:7px; border-radius:var(--r-pill); max-width:440px; }
.lm-form input{ flex:1; border:0; background:transparent; padding:11px 16px; font-family:var(--body); font-size:15px; outline:none; }
.lm-art{ display:grid; place-items:center; }
.lm-art .il{ width:min(220px,70%); height:auto; }

.res-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.res-card{ background:#fff; border:1px solid var(--line); border-radius:var(--r-lg); overflow:hidden; box-shadow:var(--sh-sm); display:flex; flex-direction:column; transition:transform .2s,box-shadow .2s; }
.res-card:hover{ transform:translateY(-5px); box-shadow:var(--sh-lg); }
.res-card__top{ aspect-ratio:16/10; display:grid; place-items:center; position:relative; }
.res-card__type{ position:absolute; top:12px; left:12px; }
.res-card__b{ padding:20px 22px 22px; display:flex; flex-direction:column; gap:10px; flex:1; }
.res-card__b h3{ font-size:19px; line-height:1.25; }
.res-card__foot{ display:flex; align-items:center; justify-content:space-between; margin-top:auto; padding-top:6px; }
.dl{ font-size:13px; color:var(--muted); font-weight:600; display:flex; align-items:center; gap:6px; }
.res-card .il{ width:74px; height:74px; }

/* ==========================================================================
   COURSES
   ========================================================================== */
.co-hero{ background:linear-gradient(135deg,var(--wash),#fff); border-bottom:1px solid var(--line); position:relative; overflow:hidden; }
.co-hero .container{ padding-block:clamp(36px,5vw,60px); position:relative; z-index:2; }
.co-hero h1{ font-size:clamp(34px,4.6vw,52px); margin:14px 0 14px; max-width:16ch; }
.co-hero .lead{ max-width:56ch; }

.feat-course{ background:#fff; border:1px solid var(--line); border-radius:var(--r-xl); overflow:hidden; box-shadow:var(--sh-md); margin-top:32px; display:grid; grid-template-columns:1.1fr 1fr; }
.feat-course__media{ position:relative; min-height:340px; }
.feat-course__media .ph{ position:absolute; inset:0; }
.feat-course__b{ padding:clamp(26px,3vw,40px); display:flex; flex-direction:column; gap:14px; justify-content:center; }
.feat-course__b h2{ font-size:clamp(24px,2.8vw,32px); }
.course-incl{ list-style:none; margin:0; padding:0; display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.course-incl li{ display:flex; align-items:center; gap:9px; font-size:14.5px; color:var(--slate); font-weight:500; }
.course-incl .tick{ width:22px; height:22px; border-radius:7px; background:var(--wash); color:var(--primary); display:grid; place-items:center; flex:none; }
.pricerow{ display:flex; align-items:baseline; gap:12px; flex-wrap:wrap; }
.pricerow .now{ font-family:var(--display); font-weight:700; font-size:38px; color:var(--primary); letter-spacing:-0.01em; }
.pricerow .was{ text-decoration:line-through; color:var(--muted); font-weight:600; font-size:18px; }

.co-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.co-card{ background:#fff; border:1px solid var(--line); border-radius:var(--r-lg); overflow:hidden; box-shadow:var(--sh-sm); display:flex; flex-direction:column; transition:transform .2s,box-shadow .2s; }
.co-card:hover{ transform:translateY(-6px); box-shadow:var(--sh-lg); }
.co-card__top{ aspect-ratio:16/9; display:grid; place-items:center; position:relative; }
.co-card__top .il{ width:84px; height:84px; }
.co-card__b{ padding:20px 22px 22px; display:flex; flex-direction:column; gap:11px; flex:1; }
.co-card__meta{ display:flex; gap:14px; font-size:13px; color:var(--muted); font-weight:600; }
.co-card__meta span{ display:flex; align-items:center; gap:5px; }
.co-card__foot{ display:flex; align-items:center; justify-content:space-between; margin-top:auto; padding-top:8px; border-top:1px solid var(--line); }
.co-card__price{ font-family:var(--display); font-weight:700; font-size:24px; color:var(--primary); }
.lvl{ font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.05em; padding:4px 9px; border-radius:6px; background:var(--wash); color:var(--pine); }

.faq{ max-width:760px; margin-inline:auto; }
.faq details{ border:1px solid var(--line); border-radius:var(--r-md); background:#fff; padding:0 22px; margin-bottom:12px; box-shadow:var(--sh-sm); }
.faq summary{ list-style:none; cursor:pointer; padding:18px 0; font-family:var(--display); font-weight:600; font-size:18px; display:flex; justify-content:space-between; align-items:center; gap:16px; }
.faq summary::-webkit-details-marker{ display:none; }
.faq summary::after{ content:"+"; font-family:var(--ui); font-size:24px; color:var(--primary); font-weight:400; }
.faq details[open] summary::after{ content:"\2013"; }
.faq p{ padding:0 0 20px; color:var(--slate); font-size:16px; line-height:1.6; }

/* ==========================================================================
   CAMPAIGN LANDING (stripped-nav LP)
   ========================================================================== */
.lp-header{ position:sticky; top:0; z-index:50; background:rgba(255,255,255,.9); backdrop-filter:blur(12px); border-bottom:1px solid var(--line); }
.lp-header .container{ display:flex; align-items:center; justify-content:space-between; height:70px; }
.lp-brand{ display:flex; align-items:center; gap:10px; font-family:var(--display); font-weight:700; font-size:20px; }
.lp-brand .brand__mark{ width:38px; height:38px; border-radius:12px; background: linear-gradient(150deg, var(--primary), var(--leaf)); display:grid; place-items:center; }

.lp-hero{ position:relative; overflow:hidden; background:linear-gradient(160deg,var(--forest),var(--pine)); color:#fff; }
.lp-hero .container{ padding-block:clamp(40px,6vw,84px); position:relative; z-index:2; text-align:center; }
.lp-pill{ display:inline-flex; align-items:center; gap:8px; background:rgba(255,255,255,.12); border:1px solid rgba(255,255,255,.22); color:#fff; padding:7px 16px; border-radius:var(--r-pill); font-family:var(--ui); font-weight:700; font-size:13px; letter-spacing:.04em; }
.lp-hero h1{ color:#fff; font-size:clamp(36px,6vw,68px); line-height:1.04; letter-spacing:-0.015em; margin:20px auto 18px; max-width:16ch; }
.lp-hero h1 .gold{ color:var(--gold); }
.lp-hero .lead{ color:#dcefe0; max-width:54ch; margin:0 auto 14px; font-size:clamp(17px,1.6vw,20px); }
.lp-form{ display:flex; gap:10px; max-width:480px; margin:26px auto 14px; background:#fff; padding:8px; border-radius:var(--r-pill); box-shadow:var(--sh-lg); }
.lp-form input{ flex:1; border:0; background:transparent; padding:13px 18px; font-family:var(--body); font-size:16px; outline:none; }
.lp-trust{ display:flex; gap:22px; justify-content:center; flex-wrap:wrap; margin-top:14px; color:#bde0c2; font-size:13.5px; font-weight:600; }
.lp-trust span{ display:inline-flex; align-items:center; gap:6px; }
.lp-float{ position:absolute; opacity:.9; }
.lp-float .il{ filter:drop-shadow(0 12px 24px rgba(0,0,0,.2)); }

.steps{ display:grid; grid-template-columns:repeat(4,1fr); gap:22px; counter-reset:step; }
.step{ background:#fff; border:1px solid var(--line); border-radius:var(--r-lg); padding:26px 22px; box-shadow:var(--sh-sm); position:relative; }
.step__n{ width:40px; height:40px; border-radius:12px; background:var(--primary); color:#fff; font-family:var(--display); font-weight:700; display:grid; place-items:center; font-size:18px; margin-bottom:14px; }
.step h3{ font-size:18px; margin-bottom:7px; }

.lp-get{ background:var(--wash); border:1px solid var(--mint); border-radius:var(--r-xl); padding:clamp(28px,4vw,52px); display:grid; grid-template-columns:1fr 1fr; gap:40px; align-items:center; }
.lp-get ul{ list-style:none; margin:18px 0 0; padding:0; display:flex; flex-direction:column; gap:14px; }
.lp-get li{ display:flex; gap:12px; align-items:flex-start; font-size:16.5px; }
.lp-get li .tick{ width:26px; height:26px; border-radius:8px; background:var(--primary); color:#fff; display:grid; place-items:center; flex:none; margin-top:1px; }
.lp-get__art{ display:grid; place-items:center; }
.lp-get__art .il{ width:min(260px,72%); }

.lp-proof{ display:grid; grid-template-columns:repeat(3,1fr); gap:0; background:#fff; border:1px solid var(--line); border-radius:var(--r-xl); overflow:hidden; box-shadow:var(--sh-sm); }
.lp-proof > div{ padding:32px 20px; text-align:center; border-right:1px solid var(--line); }
.lp-proof > div:last-child{ border-right:0; }
.lp-proof .n{ font-family:var(--display); font-weight:700; font-size:clamp(30px,3.4vw,44px); color:var(--primary); }
.lp-proof .l{ font-size:14px; color:var(--slate); font-weight:600; margin-top:4px; }

.lp-final{ background:linear-gradient(135deg,var(--primary),var(--leaf)); border-radius:var(--r-xl); padding:clamp(32px,5vw,64px); text-align:center; color:#fff; position:relative; overflow:hidden; }
.lp-final h2{ color:#fff; }
.lp-foot{ background:var(--forest); color:#9cc0a3; text-align:center; padding:28px 20px; font-size:13.5px; }
.lp-foot a{ color:#cfe6d2; }

body.is-landing .footer-cta, body.no-footer-cta .footer-cta{ display:none; }

/* ==========================================================================
   CONTACT
   ========================================================================== */
.ct-hero{ background:linear-gradient(135deg,var(--wash),#fff); border-bottom:1px solid var(--line); }
.ct-hero .container{ padding-block:clamp(32px,4vw,52px); }
.ct-grid{ display:grid; grid-template-columns:1.3fr 1fr; gap:44px; align-items:start; }
.ct-form{ background:#fff; border:1px solid var(--line); border-radius:var(--r-xl); padding:clamp(24px,3vw,38px); box-shadow:var(--sh-sm); position:relative; }
.ct-row{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.ct-info{ display:flex; flex-direction:column; gap:16px; }
.ct-card{ background:#fff; border:1px solid var(--line); border-radius:var(--r-lg); padding:22px; display:flex; gap:14px; align-items:flex-start; box-shadow:var(--sh-sm); }
.ct-card .ic-wrap{ width:46px; height:46px; border-radius:13px; background:var(--wash); color:var(--primary); display:grid; place-items:center; flex:none; }
.ct-card h4{ font-size:16px; margin-bottom:3px; }

/* ==========================================================================
   COMMENTS
   ========================================================================== */
.comments-area{ margin-top:40px; }
.comments-title{ font-family:var(--display); font-size:24px; margin-bottom:18px; }
.comment-list{ list-style:none; padding:0; margin:0 0 24px; }
.comment-body{ padding:18px 0; border-top:1px solid var(--line); display:grid; grid-template-columns:60px 1fr; gap:14px; }
.comment-body .avatar{ width:48px; height:48px; }
.comment-author cite{ font-style:normal; font-weight:700; }
.comment-metadata{ font-size:13px; color:var(--muted); margin-bottom:6px; }
.comment-form .form-submit .submit{ font-family:var(--ui); font-weight:700; font-size:16px; padding:12px 22px; border-radius:var(--r-pill); background: var(--primary); color:#fff; border:0; }
.comment-form label{ font-family:var(--ui); font-weight:700; font-size:14px; }
.comment-form input[type="text"], .comment-form input[type="email"], .comment-form input[type="url"], .comment-form textarea{
  width:100%; font-family:var(--body); font-size:16px; padding:14px 18px; border:1.5px solid var(--line-2); border-radius:var(--r-sm); background:#fff;
}

/* ==========================================================================
   SUBSCRIBE MODAL (iframe popup — opened by the header Subscribe button)
   ========================================================================== */
.subscribe-modal{
	position:fixed; inset:0; z-index:110;
	background: rgba(20,40,26,.55); backdrop-filter: blur(3px);
	opacity:0; visibility:hidden; transition: opacity .22s;
	display:flex; align-items:center; justify-content:center;
	padding: clamp(12px, 4vh, 36px);
}
.subscribe-modal.open{ opacity:1; visibility:visible; }
.subscribe-modal__panel{
	/* 85vw on most screens, never narrower than 320px, never wider than 1200px on ultra-wide monitors */
	width:  clamp(320px, 85vw, 1200px);
	/* 92vh on most screens, capped so it never feels enormous on very tall windows */
	height: min(92vh, 920px);
	background:#fff;
	border-radius: var(--r-xl);
	box-shadow: var(--sh-lg);
	position:relative;
	overflow:hidden;
	display:flex; flex-direction:column;
	transform: translateY(12px) scale(.98);
	transition: transform .22s cubic-bezier(.2,.7,.3,1);
}
.subscribe-modal.open .subscribe-modal__panel{ transform: none; }
.subscribe-modal__head{
	display:flex; align-items:center; justify-content:space-between;
	padding: 14px 18px; gap:12px;
	border-bottom: 1px solid var(--line);
	background: var(--paper);
	flex: none;
}
.subscribe-modal__title{
	font-family: var(--display); font-weight:700; font-size:17px; margin:0; color: var(--ink);
}
.subscribe-modal__close{ flex:none; }
.subscribe-modal__body{
	position:relative; flex:1; min-height:0; background:#fff;
}
.subscribe-modal__loading{
	position:absolute; inset:0;
	display:flex; flex-direction:column; align-items:center; justify-content:center;
	gap:12px; color: var(--muted); background:#fff; z-index:1;
	transition: opacity .25s;
}
.subscribe-modal__loading.hidden{
	opacity:0; pointer-events:none;
}
.subscribe-modal__iframe{
	width:100%; height:100%;
	border:0; display:block;
	background:#fff;
}
.subscribe-modal__embed{
	position:relative; z-index:2;
	width:100%; height:100%;
	padding: 0;          /* Let Beehiiv's form use the full panel width — they design with their own padding */
	overflow-y: auto;
	background:#fff;
	/* Center horizontally in case Beehiiv's form has a narrower internal max-width */
	display:flex;
	align-items:flex-start;
	justify-content:center;
}
/* Safety net only: prevent accidental horizontal overflow from injected children
   while still letting Beehiiv control its own width/layout. */
.subscribe-modal__embed > *,
.subscribe-modal__embed iframe{
	max-width: 100% !important;
	width: 100%;
}
.subscribe-modal__fallback{
	display:flex; align-items:center; justify-content:center; gap:8px;
	padding:11px 16px; text-align:center;
	font-family: var(--ui); font-weight:600; font-size:13.5px;
	color: var(--primary);
	border-top: 1px solid var(--line);
	background: var(--paper);
	flex: none;
}
.subscribe-modal__fallback:hover{ background: var(--wash); color: var(--pine); }
.subscribe-modal__fallback .ic{ width:14px; height:14px; }
@media (max-width: 600px){
	.subscribe-modal{ padding:0; }
	.subscribe-modal__panel{
		width:100%; height:100%;
		max-height:100%; max-width:100%;
		border-radius:0;
	}
}

/* ==========================================================================
   SHARED ICONS
   ========================================================================== */
.ic, .il{ display:inline-block; vertical-align:middle; }
.ic{ fill:none; }
