/* ═══════════════════════════════════════════════════════════
   FlexiMove — Shared Base Stylesheet
   Used by ALL pages. Do not duplicate — import this file.
═══════════════════════════════════════════════════════════ */

/* ── GOOGLE FONTS ── */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;600;700;900&family=Inter:wght@300;400;500;600;700&display=swap');

/* ── CSS CUSTOM PROPERTIES ── */
:root {
  /* Brand Colors */
  --forest:    #1a4731;
  --forest-d:  #122f21;
  --forest-l:  #e8f5ee;
  --forest-m:  #2d6a4f;
  --gold:      #d4a843;
  --gold-l:    #fdf3dc;
  --gold-d:    #b8891f;
  --cream:     #faf8f5;
  --cream-2:   #f2ede6;

  /* Neutral Scale */
  --n900: #0d1b2a;
  --n800: #1a2e3b;
  --n700: #2c3e50;
  --n600: #455a64;
  --n500: #607d8b;
  --n400: #90a4ae;
  --n300: #b0bec5;
  --n200: #dde3e7;
  --n100: #f0f3f5;

  /* Status */
  --green-ok: #22c55e;
  --amber-w:  #f59e0b;
  --red-x:    #ef4444;
  --blue-i:   #3b82f6;

  /* Typography */
  --ff-display: 'Merriweather',Georgia,serif;
  --ff-body:    'Inter', system-ui, sans-serif;

  /* Spacing */
  --max-w: 1180px;
  --rad:   10px;
  --rad-l: 16px;

  /* Shadows */
  --shadow-sm: 0 1px 4px rgba(13,27,42,.08);
  --shadow-md: 0 4px 16px rgba(13,27,42,.10);
  --shadow-lg: 0 8px 32px rgba(13,27,42,.14);
}

/* ── RESET ── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; font-size:16px; }
body {
  font-family: var(--ff-body);
  color: var(--n800);
  background: #fff;
  line-height: 1.65;
}
a { color:inherit; text-decoration:none; }
img { max-width:100%; height:auto; display:block; }
ul, ol { list-style:none; }
button { cursor:pointer; font-family:inherit; }

/* ── LAYOUT UTILITIES ── */
.container { max-width:var(--max-w); margin:0 auto; padding:0 24px; }
.sec       { padding:80px 0; }
.sec-sm    { padding:56px 0; }
.sec-lg    { padding:100px 0; }
.text-c    { text-align:center; }
.text-l    { text-align:left; }

/* Grids */
.grid-2 { display:grid; grid-template-columns:1fr 1fr; gap:32px; }
.grid-3 { display:grid; grid-template-columns:repeat(3,1fr); gap:28px; }
.grid-4 { display:grid; grid-template-columns:repeat(4,1fr); gap:24px; }
.art-layout { display:grid; grid-template-columns:1fr 300px; gap:48px; align-items:start; }

/* ── TYPOGRAPHY ── */
.eyebrow {
  display:inline-block;
  background:var(--forest-l);
  color:var(--forest);
  font-size:11px;
  font-weight:700;
  letter-spacing:.1em;
  text-transform:uppercase;
  padding:5px 14px;
  border-radius:20px;
  margin-bottom:14px;
}
.eyebrow-gold {
  background:var(--gold-l);
  color:var(--gold-d);
}
.h-display {
  font-family:var(--ff-display);
  font-size:clamp(28px,4.5vw,52px);
  font-weight:900;
  color:var(--n900);
  line-height:1.15;
  margin-bottom:16px;
}
.h-section {
  font-family:var(--ff-display);
  font-size:clamp(24px,3.5vw,40px);
  font-weight:800;
  color:var(--n900);
  line-height:1.2;
  margin-bottom:14px;
}
.h-card {
  font-family:var(--ff-display);
  font-size:20px;
  font-weight:700;
  color:var(--n900);
  margin-bottom:10px;
}
.lead {
  font-size:18px;
  color:var(--n600);
  line-height:1.8;
  max-width:660px;
  margin-bottom:28px;
}
.body-text p {
  font-size:16px;
  line-height:1.85;
  color:var(--n700);
  margin-bottom:18px;
}
.body-text h2 {
  font-family:var(--ff-display);
  font-size:clamp(22px,3vw,30px);
  font-weight:800;
  color:var(--n900);
  margin:44px 0 14px;
  scroll-margin-top:80px;
}
.body-text h3 {
  font-family:var(--ff-display);
  font-size:20px;
  font-weight:700;
  color:var(--n800);
  margin:28px 0 10px;
}
.body-text ul, .body-text ol {
  margin:0 0 20px 24px;
  list-style:disc;
}
.body-text ol { list-style:decimal; }
.body-text li {
  font-size:16px;
  line-height:1.75;
  color:var(--n700);
  margin-bottom:6px;
}
.divider {
  width:52px;
  height:4px;
  background:linear-gradient(90deg, var(--forest), var(--gold));
  border-radius:2px;
  margin-bottom:28px;
}
.divider-c { margin-left:auto; margin-right:auto; }

/* ── BUTTONS ── */
.btn {
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-weight:700;
  font-size:15px;
  border-radius:8px;
  padding:13px 28px;
  transition:all .2s;
  white-space:nowrap;
  border:none;
  text-decoration:none;
}
.btn-primary {
  background:var(--forest);
  color:#fff !important;
  box-shadow:0 4px 16px rgba(26,71,49,.3);
}
.btn-primary:hover {
  background:var(--forest-d);
  transform:translateY(-2px);
  box-shadow:0 8px 24px rgba(26,71,49,.4);
}
.btn-gold {
  background:var(--gold);
  color:var(--n900) !important;
  box-shadow:0 4px 16px rgba(212,168,67,.35);
}
.btn-gold:hover {
  background:var(--gold-d);
  transform:translateY(-2px);
  box-shadow:0 8px 24px rgba(212,168,67,.45);
}
.btn-outline {
  border:2px solid var(--forest);
  color:var(--forest) !important;
  background:transparent;
}
.btn-outline:hover { background:var(--forest-l); }
.btn-ghost {
  border:2px solid rgba(255,255,255,.3);
  color:#fff !important;
  background:rgba(255,255,255,.08);
}
.btn-ghost:hover { background:rgba(255,255,255,.18); }
.btn-lg { padding:16px 36px; font-size:16px; }
.btn-sm { padding:9px 18px; font-size:13px; }

@keyframes pulse-cta {
  0%,100% { box-shadow:0 4px 16px rgba(26,71,49,.3); }
  50%      { box-shadow:0 4px 28px rgba(26,71,49,.55); }
}
.btn-pulse { animation:pulse-cta 2.5s ease-in-out infinite; }

/* ── ANNOUNCEMENT BAR ── */
.ann-bar {
  background:var(--forest-d);
  color:rgba(255,255,255,.85);
  text-align:center;
  padding:9px 16px;
  font-size:13px;
  line-height:1.4;
}
.ann-bar a { color:var(--gold); font-weight:700; }

/* ── NAVBAR ── */
.nav {
  background:#fff;
  border-bottom:1px solid var(--n200);
  position:sticky;
  top:0;
  z-index:900;
  box-shadow:var(--shadow-sm);
}
.nav-inner {
  max-width:var(--max-w);
  margin:0 auto;
  padding:0 24px;
  height:66px;
  display:flex;
  align-items:center;
  gap:28px;
}
.nav-logo {
  font-family:var(--ff-display);
  font-size:24px;
  font-weight:900;
  color:var(--n900) !important;
  letter-spacing:-.5px;
  flex-shrink:0;
}
.nav-logo span { color:var(--forest); }
.nav-logo sup {
  font-size:10px;
  font-family:var(--ff-body);
  font-weight:700;
  color:var(--gold);
  letter-spacing:.05em;
  vertical-align:super;
}
.nav-links {
  display:flex;
  gap:2px;
  margin-left:auto;
}
.nav-links a {
  font-size:13.5px;
  font-weight:600;
  color:var(--n600) !important;
  padding:7px 12px;
  border-radius:6px;
  transition:all .15s;
}
.nav-links a:hover,
.nav-links a.active {
  background:var(--forest-l);
  color:var(--forest) !important;
}
.nav-cta { margin-left:10px; padding:9px 20px; font-size:13px; }

/* Hamburger */
.hamburger {
  display:none;
  flex-direction:column;
  gap:5px;
  background:none;
  border:none;
  padding:8px;
  margin-left:auto;
}
.hamburger span {
  width:22px;
  height:2px;
  background:var(--n700);
  border-radius:2px;
  transition:all .22s;
  display:block;
}
.hamburger.open span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.hamburger.open span:nth-child(2) { opacity:0; }
.hamburger.open span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }

/* Mobile menu */
.mob-menu {
  display:none;
  flex-direction:column;
  gap:2px;
  background:#fff;
  border-bottom:1px solid var(--n200);
  padding:8px 20px 16px;
}
.mob-menu.open { display:flex; }
.mob-menu a {
  padding:11px 14px;
  font-size:15px;
  font-weight:600;
  color:var(--n700) !important;
  border-radius:8px;
}
.mob-menu a:hover { background:var(--forest-l); color:var(--forest) !important; }
.mob-menu .mob-cta {
  color:var(--forest) !important;
  font-weight:700;
  margin-top:4px;
}

/* ── BREADCRUMB ── */
.breadcrumb {
  background:var(--cream);
  border-bottom:1px solid var(--n200);
  padding:12px 0;
}
.breadcrumb-inner {
  max-width:var(--max-w);
  margin:0 auto;
  padding:0 24px;
  font-size:13px;
  color:var(--n500);
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:6px;
}
.breadcrumb-inner a { color:var(--forest) !important; font-weight:500; }
.breadcrumb-inner .sep { color:var(--n300); }

/* ── PAGE HERO ── */
.page-hero {
  background:linear-gradient(135deg, var(--forest-d) 0%, var(--forest) 45%, #2d6a4f 100%);
  color:#fff;
  padding:72px 0 64px;
  position:relative;
  overflow:hidden;
}
.page-hero::before {
  content:'';
  position:absolute;
  inset:0;
  background-image:
    radial-gradient(circle at 20% 50%, rgba(212,168,67,.08) 0%, transparent 50%),
    radial-gradient(circle at 80% 20%, rgba(255,255,255,.04) 0%, transparent 40%);
  pointer-events:none;
}
/* Leaf texture lines */
.page-hero::after {
  content:'';
  position:absolute;
  inset:0;
  background-image:repeating-linear-gradient(
    60deg,
    transparent,
    transparent 40px,
    rgba(255,255,255,.015) 40px,
    rgba(255,255,255,.015) 41px
  );
  pointer-events:none;
}
.hero-inner {
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:1fr 340px;
  gap:48px;
  align-items:center;
}
.hero-tag {
  display:inline-flex;
  align-items:center;
  gap:8px;
  background:rgba(212,168,67,.2);
  border:1px solid rgba(212,168,67,.35);
  color:var(--gold);
  font-size:12px;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  padding:6px 14px;
  border-radius:20px;
  margin-bottom:18px;
}
.hero-h1 {
  font-family:var(--ff-display);
  font-size:clamp(30px,4.5vw,50px);
  font-weight:900;
  line-height:1.15;
  margin-bottom:18px;
  color:#fff;
}
.hero-h1 em { color:var(--gold); font-style:normal; }
.hero-sub {
  font-size:17px;
  line-height:1.8;
  color:rgba(255,255,255,.78);
  margin-bottom:30px;
  max-width:540px;
}
.hero-btns { display:flex; gap:12px; flex-wrap:wrap; }
.hero-meta {
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:10px;
  margin-bottom:18px;
  font-size:12.5px;
  color:rgba(255,255,255,.5);
}
.hero-meta .dot { width:3px; height:3px; border-radius:50%; background:rgba(255,255,255,.3); }
.hero-meta .highlight { color:var(--gold); font-weight:600; }

/* Score Card (used in hero) */
.score-card {
  background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.14);
  border-radius:var(--rad-l);
  padding:28px;
  backdrop-filter:blur(12px);
}
.score-top { text-align:center; margin-bottom:22px; }
.score-num {
  font-family:var(--ff-display);
  font-size:68px;
  font-weight:900;
  line-height:1;
  color:var(--gold);
}
.score-lbl {
  font-size:12px;
  color:rgba(255,255,255,.45);
  letter-spacing:.06em;
  text-transform:uppercase;
  margin-top:4px;
}
.score-row {
  display:flex;
  align-items:center;
  gap:10px;
  margin-bottom:10px;
}
.score-row:last-child { margin-bottom:0; }
.sr-name { font-size:12.5px; color:rgba(255,255,255,.7); flex:1; min-width:0; }
.sr-bar {
  flex:0 0 90px;
  height:6px;
  background:rgba(255,255,255,.12);
  border-radius:3px;
  overflow:hidden;
}
.sr-fill {
  height:100%;
  background:linear-gradient(90deg, var(--gold), #f0c060);
  border-radius:3px;
  transition:width .9s ease;
}
.sr-val { font-size:11px; font-weight:700; color:var(--gold); min-width:26px; text-align:right; }

/* ── CALLOUT BOXES ── */
.callout {
  border-radius:10px;
  padding:18px 22px;
  margin:24px 0;
  font-size:15px;
  line-height:1.75;
}
.callout strong { display:block; margin-bottom:4px; }
.callout-green  { background:#f0fdf4; border-left:4px solid var(--forest); color:var(--n700); }
.callout-green strong { color:var(--forest); }
.callout-gold   { background:var(--gold-l); border-left:4px solid var(--gold); color:var(--n700); }
.callout-gold strong { color:var(--gold-d); }
.callout-red    { background:#fef2f2; border-left:4px solid var(--red-x); color:var(--n700); }
.callout-red strong { color:#991b1b; }
.callout-blue   { background:#eff6ff; border-left:4px solid var(--blue-i); color:var(--n700); }
.callout-blue strong { color:#1e40af; }

/* ── CHECK LISTS ── */
.check-list { margin:0 0 24px; }
.check-list li {
  display:flex;
  gap:12px;
  padding:10px 0;
  border-bottom:1px solid var(--n100);
  font-size:15px;
  color:var(--n700);
  line-height:1.65;
}
.check-list li:last-child { border-bottom:none; }
.cli-ico {
  flex-shrink:0;
  width:22px;
  height:22px;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:11px;
  font-weight:800;
  margin-top:2px;
}
.ico-ok  { background:var(--forest-l); color:var(--forest); }
.ico-warn{ background:#fef3c7; color:#d97706; }
.ico-no  { background:#fee2e2; color:var(--red-x); }

/* ── FEATURE CARDS ── */
.card {
  background:#fff;
  border:1px solid var(--n200);
  border-radius:var(--rad-l);
  padding:28px;
  transition:box-shadow .2s, transform .2s;
}
.card:hover {
  box-shadow:var(--shadow-lg);
  transform:translateY(-3px);
}
.card-icon {
  width:52px;
  height:52px;
  background:var(--forest-l);
  border-radius:12px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:24px;
  margin-bottom:16px;
}
.card-icon-gold { background:var(--gold-l); }

/* ── STAT BLOCK ── */
.stat-block {
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:0;
  background:var(--n900);
  border-radius:var(--rad-l);
  overflow:hidden;
}
.stat-item {
  padding:32px 24px;
  text-align:center;
  border-right:1px solid rgba(255,255,255,.08);
}
.stat-item:last-child { border-right:none; }
.stat-num {
  font-family:var(--ff-display);
  font-size:42px;
  font-weight:900;
  color:var(--gold);
  line-height:1;
  margin-bottom:6px;
}
.stat-lbl { font-size:13px; color:rgba(255,255,255,.55); line-height:1.4; }

/* ── REVIEW CARDS ── */
.rv-card {
  background:#fff;
  border:1px solid var(--n200);
  border-radius:var(--rad-l);
  padding:24px;
  transition:box-shadow .2s;
}
.rv-card:hover { box-shadow:var(--shadow-md); }
.rv-stars { color:var(--gold); font-size:15px; margin-bottom:10px; }
.rv-name  { font-weight:700; font-size:15px; color:var(--n900); margin-bottom:3px; }
.rv-meta  { font-size:12px; color:var(--n400); margin-bottom:12px; }
.rv-text  { font-size:14px; color:var(--n600); line-height:1.75; }
.rv-badge {
  display:inline-block;
  margin-top:12px;
  background:var(--forest-l);
  color:var(--forest);
  font-size:11px;
  font-weight:700;
  padding:3px 10px;
  border-radius:20px;
}

/* ── DATA TABLES ── */
.dtable {
  width:100%;
  border-collapse:collapse;
  font-size:15px;
  margin:24px 0;
}
.dtable th {
  background:var(--n900);
  color:#fff;
  padding:13px 16px;
  text-align:left;
  font-weight:700;
  font-size:12.5px;
  letter-spacing:.04em;
  text-transform:uppercase;
}
.dtable th:first-child { border-radius:8px 0 0 0; }
.dtable th:last-child  { border-radius:0 8px 0 0; }
.dtable td {
  padding:13px 16px;
  border-bottom:1px solid var(--n200);
  vertical-align:top;
  color:var(--n700);
}
.dtable tr:hover td { background:var(--cream); }
.dtable tr:last-child td { border-bottom:none; }

/* Comparison table */
.comp-table {
  width:100%;
  border-collapse:collapse;
  font-size:14px;
  min-width:640px;
}
.comp-table th {
  background:var(--n900);
  color:#fff;
  padding:13px 16px;
  font-size:12px;
  font-weight:700;
  letter-spacing:.05em;
  text-transform:uppercase;
  text-align:center;
}
.comp-table th:first-child { text-align:left; }
.comp-table td {
  padding:13px 16px;
  border-bottom:1px solid var(--n200);
  text-align:center;
  vertical-align:middle;
  color:var(--n700);
}
.comp-table td:first-child { text-align:left; font-weight:600; color:var(--n900); }
.comp-table tr.row-hl td  { background:var(--forest-l); font-weight:700; }
.comp-table tr:hover td   { background:var(--cream); }
.chk { color:var(--forest); font-size:16px; font-weight:800; }
.x-no{ color:var(--red-x); font-size:16px; }
.mid { color:var(--amber-w); font-size:14px; }

/* Badges */
.badge {
  font-size:11.5px;
  font-weight:700;
  padding:3px 10px;
  border-radius:20px;
  display:inline-block;
}
.badge-green  { background:var(--forest-l); color:var(--forest); }
.badge-gold   { background:var(--gold-l); color:var(--gold-d); }
.badge-red    { background:#fee2e2; color:#991b1b; }

/* ── TOC ── */
.toc {
  background:var(--cream);
  border:1px solid var(--n200);
  border-left:4px solid var(--forest);
  border-radius:var(--rad);
  padding:24px 28px;
  margin:36px 0;
}
.toc h3 {
  font-family:var(--ff-display);
  font-size:15px;
  font-weight:800;
  color:var(--n900);
  margin-bottom:14px;
}
.toc ol {
  list-style:decimal;
  padding-left:20px;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:4px 28px;
}
.toc li { font-size:14px; line-height:1.6; }
.toc a  { color:var(--forest) !important; font-weight:500; }
.toc a:hover { text-decoration:underline; }

/* ── VERDICT BOX ── */
.verdict-box {
  background:var(--n900);
  color:#fff;
  border-radius:var(--rad-l);
  padding:36px;
  margin:32px 0;
}
.verdict-box h3 {
  font-family:var(--ff-display);
  font-size:24px;
  font-weight:900;
  color:#fff;
  margin-bottom:16px;
}
.verdict-box p {
  font-size:15px;
  line-height:1.8;
  color:rgba(255,255,255,.75);
  margin-bottom:12px;
}
.verdict-grid { display:grid; grid-template-columns:1fr 1fr; gap:18px; margin-top:24px; }
.vg-box { background:rgba(255,255,255,.07); border-radius:10px; padding:18px 20px; }
.vg-box h4 {
  font-size:12.5px;
  font-weight:800;
  letter-spacing:.06em;
  text-transform:uppercase;
  margin-bottom:12px;
}
.vg-pro h4 { color:#4ade80; }
.vg-con h4 { color:#f87171; }
.vg-box ul { padding:0; margin:0; }
.vg-box li {
  font-size:13.5px;
  color:rgba(255,255,255,.72);
  line-height:1.65;
  padding:4px 0;
  display:flex;
  gap:8px;
}
.vg-box li::before { flex-shrink:0; font-size:12px; margin-top:3px; }
.vg-pro li::before { content:'✓'; color:#4ade80; }
.vg-con li::before { content:'✗'; color:#f87171; }

/* ── FAQ ── */
.faq-item {
  border-bottom:1px solid var(--n200);
  overflow:hidden;
}
.faq-item:last-child { border-bottom:none; }
.fq-btn {
  width:100%;
  background:none;
  border:none;
  padding:20px 0;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:16px;
  text-align:left;
}
.fq-text { font-weight:700; font-size:16px; color:var(--n900); line-height:1.4; }
.fq-icon {
  flex-shrink:0;
  width:28px;
  height:28px;
  border-radius:50%;
  background:var(--n100);
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:16px;
  font-weight:400;
  color:var(--n600);
  transition:all .2s;
}
.faq-item.open .fq-icon {
  background:var(--forest);
  color:#fff;
  transform:rotate(45deg);
}
.fq-ans {
  display:none;
  padding:0 0 20px;
  font-size:15px;
  line-height:1.8;
  color:var(--n600);
}
.faq-item.open .fq-ans { display:block; }

/* ── SIDEBAR ── */
.sidebar { position:sticky; top:82px; }
.scard {
  background:#fff;
  border:1px solid var(--n200);
  border-radius:var(--rad-l);
  padding:22px;
  margin-bottom:20px;
}
.scard h4 {
  font-family:var(--ff-display);
  font-size:17px;
  font-weight:800;
  color:var(--n900);
  margin-bottom:16px;
}
.scard-price {
  background:var(--cream);
  border-radius:10px;
  padding:16px;
  text-align:center;
  margin-bottom:16px;
}
.sp-main {
  font-family:var(--ff-display);
  font-size:36px;
  font-weight:900;
  color:var(--n900);
}
.sp-orig { font-size:15px; color:var(--n400); text-decoration:line-through; margin:0 6px; }
.sp-save {
  background:var(--forest);
  color:#fff;
  font-size:11px;
  font-weight:700;
  padding:3px 9px;
  border-radius:20px;
}
.scard ul { padding:0; margin:0 0 16px; }
.scard li {
  font-size:13.5px;
  color:var(--n600);
  padding:7px 0;
  border-bottom:1px solid var(--n100);
  display:flex;
  gap:8px;
}
.scard li:last-child { border-bottom:none; }
.scard li::before { content:'✓'; color:var(--forest); font-weight:700; flex-shrink:0; }
.scard .btn { width:100%; justify-content:center; margin-bottom:8px; }
.scard-guarantee {
  font-size:12px;
  text-align:center;
  color:var(--n400);
  margin-top:8px;
}

/* ── CTA SECTION ── */
.cta-section {
  background:linear-gradient(135deg, #0d2b1a, var(--forest));
  color:#fff;
  padding:80px 0;
  text-align:center;
}
.cta-section h2 {
  font-family:var(--ff-display);
  font-size:clamp(26px,4vw,42px);
  font-weight:900;
  margin-bottom:14px;
}
.cta-section p {
  font-size:17px;
  color:rgba(255,255,255,.72);
  max-width:560px;
  margin:0 auto 32px;
  line-height:1.8;
}
.cta-btns { display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }
.cta-note {
  font-size:12px;
  color:rgba(255,255,255,.3);
  margin-top:24px;
  max-width:680px;
  margin-left:auto;
  margin-right:auto;
  line-height:1.6;
}

/* ── FOOTER ── */
footer {
  background:var(--n900);
  color:rgba(255,255,255,.55);
  padding:64px 0 32px;
}
.footer-grid {
  display:grid;
  grid-template-columns:2fr 1fr 1fr 1fr;
  gap:48px;
  margin-bottom:48px;
}
.fbrand h3 {
  font-family:var(--ff-display);
  font-size:22px;
  font-weight:900;
  color:#fff;
  margin-bottom:12px;
}
.fbrand h3 span { color:var(--gold); }
.fbrand p { font-size:14px; line-height:1.8; max-width:300px; }
.fcol h4 {
  font-size:12px;
  font-weight:700;
  color:rgba(255,255,255,.85);
  letter-spacing:.07em;
  text-transform:uppercase;
  margin-bottom:16px;
}
.fcol ul { padding:0; }
.fcol li { margin-bottom:9px; }
.fcol a { font-size:14px; color:rgba(255,255,255,.45) !important; transition:color .15s; }
.fcol a:hover { color:rgba(255,255,255,.85) !important; }
.footer-bot {
  border-top:1px solid rgba(255,255,255,.07);
  padding-top:28px;
}
.footer-disclaimer {
  font-size:12px;
  line-height:1.75;
  color:rgba(255,255,255,.25);
  max-width:980px;
  margin-bottom:14px;
}
.footer-copy { font-size:13px; color:rgba(255,255,255,.2); }

/* ── STICKY MOBILE BAR ── */
.sticky-bar {
  display:none;
  position:fixed;
  bottom:0;
  left:0;
  right:0;
  background:var(--n900);
  border-top:1px solid rgba(255,255,255,.1);
  padding:10px 18px;
  flex-direction:row;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  z-index:800;
}
.sticky-bar p { font-size:13px; color:rgba(255,255,255,.75); margin:0; }

/* ── SCROLL TO TOP ── */
#scrolltop {
  position:fixed;
  bottom:28px;
  right:24px;
  width:44px;
  height:44px;
  background:var(--forest);
  color:#fff !important;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:20px;
  opacity:0;
  pointer-events:none;
  transition:opacity .2s, transform .2s;
  z-index:700;
  box-shadow:0 3px 12px rgba(26,71,49,.4);
}
#scrolltop.vis { opacity:1; pointer-events:auto; }
#scrolltop:hover { transform:translateY(-2px); }

/* ── SECTION BACKGROUNDS ── */
.bg-cream  { background:var(--cream); }
.bg-cream2 { background:var(--cream-2); }
.bg-dark   { background:var(--n900); }
.bg-forest { background:var(--forest); }

/* ── OVERFLOW TABLE WRAPPER ── */
.table-wrap { overflow-x:auto; margin:24px 0; }

/* ── PRICING GRID ── */
.pricing-grid {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
  margin:32px 0;
}
.price-card {
  border:1px solid var(--n200);
  border-radius:var(--rad-l);
  overflow:hidden;
  text-align:center;
  transition:box-shadow .2s, transform .2s;
}
.price-card:hover { box-shadow:var(--shadow-lg); transform:translateY(-3px); }
.price-card.featured { border-color:var(--forest); border-width:2px; }
.price-head {
  background:var(--n100);
  padding:16px 20px 14px;
  font-weight:700;
  font-size:13px;
  color:var(--n600);
  text-transform:uppercase;
  letter-spacing:.05em;
}
.price-card.featured .price-head { background:var(--forest); color:#fff; }
.price-body { padding:24px 20px; }
.price-amount {
  font-family:var(--ff-display);
  font-size:42px;
  font-weight:900;
  color:var(--n900);
  line-height:1;
}
.price-card.featured .price-amount { color:var(--forest); }
.price-sub { font-size:13px; color:var(--n400); margin:6px 0 18px; }
.price-features { margin-bottom:20px; text-align:left; }
.price-features li {
  font-size:14px;
  color:var(--n600);
  padding:6px 0;
  border-bottom:1px solid var(--n100);
  display:flex;
  gap:8px;
}
.price-features li:last-child { border-bottom:none; }
.price-features li::before { content:'✓'; color:var(--forest); font-weight:700; flex-shrink:0; }
.price-guarantee { font-size:11.5px; color:var(--n400); margin-top:10px; }

/* ── TIMELINE ── */
.timeline { position:relative; padding-left:36px; }
.timeline::before {
  content:'';
  position:absolute;
  left:10px;
  top:8px;
  bottom:8px;
  width:2px;
  background:linear-gradient(180deg, var(--forest), var(--gold));
  border-radius:2px;
}
.tl-item { position:relative; margin-bottom:32px; }
.tl-item:last-child { margin-bottom:0; }
.tl-dot {
  position:absolute;
  left:-30px;
  top:4px;
  width:20px;
  height:20px;
  background:var(--forest);
  border:3px solid #fff;
  border-radius:50%;
  box-shadow:0 0 0 2px var(--forest);
}
.tl-week {
  font-size:12px;
  font-weight:800;
  color:var(--forest);
  letter-spacing:.06em;
  text-transform:uppercase;
  margin-bottom:4px;
}
.tl-title {
  font-weight:700;
  font-size:16px;
  color:var(--n900);
  margin-bottom:6px;
}
.tl-body { font-size:15px; color:var(--n600); line-height:1.75; }

/* ── INGREDIENT CARD ── */
.ing-card {
  display:flex;
  gap:20px;
  align-items:flex-start;
  background:#fff;
  border:1px solid var(--n200);
  border-radius:var(--rad-l);
  padding:24px;
  margin-bottom:20px;
  transition:box-shadow .2s;
}
.ing-card:hover { box-shadow:var(--shadow-md); }
.ing-icon {
  flex-shrink:0;
  width:56px;
  height:56px;
  background:var(--forest-l);
  border-radius:12px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:26px;
}
.ing-body h3 {
  font-family:var(--ff-display);
  font-size:18px;
  font-weight:700;
  color:var(--n900);
  margin-bottom:6px;
}
.ing-body .evidence {
  display:inline-block;
  font-size:11.5px;
  font-weight:700;
  padding:2px 10px;
  border-radius:20px;
  margin-bottom:10px;
}
.ing-body p { font-size:14.5px; color:var(--n600); line-height:1.75; margin:0; }

/* ── ANIMATIONS ── */
@keyframes fadeUp {
  from { opacity:0; transform:translateY(20px); }
  to   { opacity:1; transform:translateY(0); }
}
.fu  { animation:fadeUp .5s ease both; }
.fu2 { animation:fadeUp .5s .1s ease both; }
.fu3 { animation:fadeUp .5s .2s ease both; }
.fu4 { animation:fadeUp .5s .3s ease both; }

/* ── RESPONSIVE ── */
@media (max-width:1024px) {
  .hero-inner, .art-layout { grid-template-columns:1fr; }
  .sidebar { position:static; }
  .score-card { display:none; }
  .footer-grid { grid-template-columns:1fr 1fr; }
  .stat-block { grid-template-columns:1fr 1fr; }
  .toc ol { grid-template-columns:1fr; }
  .verdict-grid { grid-template-columns:1fr; }
  .pricing-grid { grid-template-columns:1fr; max-width:400px; margin-left:auto; margin-right:auto; }
}

@media (max-width:768px) {
  .sec, .sec-lg { padding:56px 0; }
  .sec-sm { padding:40px 0; }
  .nav-links, .nav-cta { display:none; }
  .hamburger { display:flex; }
  .grid-2, .grid-3, .grid-4 { grid-template-columns:1fr; }
  .footer-grid { grid-template-columns:1fr; gap:32px; }
  .sticky-bar { display:flex; }
  body { padding-bottom:62px; }
  .stat-block { grid-template-columns:1fr 1fr; }
  .stat-item { padding:24px 16px; }
  .stat-num { font-size:32px; }
  .ing-card { flex-direction:column; }
  .ing-icon { width:48px; height:48px; }
}

@media (max-width:480px) {
  .hero-btns { flex-direction:column; }
  .cta-btns  { flex-direction:column; align-items:center; }
  .stat-block { grid-template-columns:1fr; }
}

/* ── SHARED JS HELPERS ── */
.hidden { display:none; }

/* ── PRINT ── */
@media print {
  .nav, .sticky-bar, #scrolltop, .ann-bar, .sidebar { display:none !important; }
  .art-layout { grid-template-columns:1fr; }
}