/* ============================================================
   Dietly — Light-theme adaptation of the Pencil (Brainly) system
   Built on colors_and_type.css tokens (Figtree, spacing, radii).
   Brand: Dietly green + warm yellow pop, on warm-light surfaces.
   ============================================================ */

:root{
  /* ---- Surfaces (light) ---- */
  --page:       #F1F6F1;     /* warm light green-gray page */
  --page-2:     #E9F1EA;     /* alt band */
  --surface:    #FFFFFF;     /* cards */
  --surface-2:  #FBFCFB;
  --ink-0:      #0C1A12;     /* headlines */
  --ink-1:      #243029;     /* body */
  --ink-2:      #5C6B62;     /* secondary */
  --ink-3:      #8C988F;     /* tertiary / meta */
  --line:       #E2EAE3;     /* hairline */
  --line-2:     #D2DED5;     /* stronger */

  /* ---- Accent: GREEN (default, matches Dietly logo) ---- */
  --accent:        #18A957;  /* confident green for CTAs on white */
  --accent-strong: #0C7C3C;
  --accent-deep:   #07431F;
  --accent-ink:    #0A5A2C;  /* accent text on tint */
  --accent-soft:   #E6F6EC;  /* tint surface */
  --accent-softer: #F1FAF4;
  --accent-glow:   rgba(24,169,87,0.32);
  --on-accent:     #FFFFFF;

  /* logo lime — decorative only */
  --lime: #7ED957;

  /* ---- Warm pop ---- */
  --pop:        #F5A623;
  --pop-deep:   #B26A00;
  --pop-soft:   #FFF1D6;

  /* ---- Star / rating ---- */
  --star: #FBBE2E;

  --maxw: 1200px;
  --pad: clamp(20px, 5vw, 64px);
  --header-h: 72px;

  --ring: 0 0 0 4px var(--accent-glow);
  --card-shadow: 0 1px 2px rgba(12,26,18,.05), 0 8px 24px -12px rgba(12,26,18,.18);
  --card-shadow-lg: 0 2px 4px rgba(12,26,18,.06), 0 24px 48px -20px rgba(12,26,18,.28);
}

/* indigo accent variant (tweak) */
:root[data-accent="indigo"]{
  --accent:        #163bf3;
  --accent-strong: #133191;
  --accent-deep:   #0c114d;
  --accent-ink:    #1d33a8;
  --accent-soft:   #ebeeff;
  --accent-softer: #f4f6ff;
  --accent-glow:   rgba(22,59,243,0.30);
}

/* ---- Base overrides (colors_and_type.css is dark; we go light) ---- */
html{ font-size:16px; -webkit-text-size-adjust:100%; }
body{
  background: var(--page);
  color: var(--ink-1);
  font-family: var(--font-primary);
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}
h1,h2,h3,h4,h5,h6{ color: var(--ink-0); letter-spacing:-0.02em; }
p{ color: var(--ink-1); }
a{ color: var(--accent-ink); }
a:hover{ color: var(--accent-strong); }
::selection{ background: var(--accent-soft); color: var(--accent-deep); }
img{ display:block; max-width:100%; }
*,*::before,*::after{ box-sizing:border-box; }

/* ---- Layout ---- */
.wrap{ width:100%; max-width: var(--maxw); margin:0 auto; padding-inline: var(--pad); }
.section{ padding-block: clamp(56px, 9vw, 112px); }
.section--tight{ padding-block: clamp(40px, 6vw, 72px); }
.band{ background: var(--surface); }
.band-soft{ background: var(--page-2); }

/* ---- Eyebrow / kicker ---- */
.kicker{
  display:inline-flex; align-items:center; gap:8px;
  font-size: var(--fs-small); font-weight:700; letter-spacing:.04em;
  text-transform:uppercase; color: var(--accent-ink);
  background: var(--accent-soft); border:1px solid color-mix(in srgb, var(--accent) 18%, transparent);
  padding:6px 14px; border-radius: var(--r-pill);
}
.kicker .dot{ width:6px;height:6px;border-radius:50%;background:var(--accent); }

.section-head{ max-width: 720px; margin:0 auto; text-align:center; }
.section-head.left{ margin:0; text-align:left; }
.section-title{
  font-weight:900; line-height:1.04; letter-spacing:-0.03em;
  font-size: clamp(30px, 4.6vw, 52px); color:var(--ink-0);
  margin-top:18px; text-wrap:balance;
}
.section-sub{
  margin-top:16px; font-size: clamp(16px,1.6vw,19px);
  color: var(--ink-2); line-height:1.6; text-wrap:pretty;
}

/* ---- Buttons ---- */
.btn{
  font-family:var(--font-primary); font-weight:800; cursor:pointer; border:0;
  display:inline-flex; align-items:center; justify-content:center; gap:9px;
  height:52px; padding:0 26px; border-radius: var(--r-pill); font-size:16px;
  letter-spacing:-0.01em; transition: transform .12s var(--ease-regular),
    box-shadow .2s var(--ease-regular), background .2s var(--ease-regular), color .2s;
  text-decoration:none; white-space:nowrap;
}
.btn svg{ width:19px;height:19px; }
.btn:active{ transform: scale(.97); }
.btn--primary{ background:var(--accent); color:var(--on-accent);
  box-shadow: 0 1px 2px rgba(0,0,0,.12), 0 10px 24px -8px var(--accent-glow); }
.btn--primary:hover{ background:var(--accent-strong); color:#fff;
  box-shadow: 0 2px 4px rgba(0,0,0,.14), 0 16px 30px -8px var(--accent-glow); transform:translateY(-1px); }
.btn--ghost{ background:var(--surface); color:var(--ink-0); box-shadow: inset 0 0 0 1.5px var(--line-2); }
.btn--ghost:hover{ background:var(--page); box-shadow: inset 0 0 0 1.5px var(--accent); color:var(--accent-strong); transform:translateY(-1px); }
.btn--pop{ background:var(--ink-0); color:#fff; }
.btn--pop:hover{ background:#1c2b22; transform:translateY(-1px); }
.btn--sm{ height:44px; padding:0 20px; font-size:15px; }
.btn--lg{ height:56px; padding:0 32px; font-size:17px; }
.btn--block{ width:100%; }
.btn--white{ background:#fff; color:var(--accent-strong); }
.btn--white:hover{ background:#fff; transform:translateY(-1px); box-shadow:0 14px 30px -10px rgba(0,0,0,.3); }
.btn--outline-white{ background:transparent; color:#fff; box-shadow: inset 0 0 0 1.5px rgba(255,255,255,.5); }
.btn--outline-white:hover{ background:rgba(255,255,255,.12); box-shadow: inset 0 0 0 1.5px #fff; }

/* ---- Chips / pills ---- */
.chip{
  display:inline-flex; align-items:center; gap:8px; background:var(--surface);
  border:1px solid var(--line); border-radius:var(--r-pill);
  padding:8px 14px; font-size:14px; font-weight:700; color:var(--ink-1);
  box-shadow: var(--card-shadow);
}
.chip svg{ width:16px;height:16px; }

/* stars */
.stars{ display:inline-flex; gap:2px; }
.stars svg{ width:18px;height:18px; }
.icon-accent{ filter: none; }

/* ============================================================
   HEADER
   ============================================================ */
.site-header{
  position:sticky; top:0; z-index:60; height:var(--header-h);
  display:flex; align-items:center;
  background: color-mix(in srgb, var(--page) 82%, transparent);
  backdrop-filter: blur(14px) saturate(1.4);
  border-bottom:1px solid transparent;
  transition: border-color .3s, background .3s, box-shadow .3s;
}
.site-header.scrolled{
  background: color-mix(in srgb, var(--surface) 86%, transparent);
  border-bottom-color: var(--line);
  box-shadow: 0 6px 24px -18px rgba(12,26,18,.5);
}
.nav{ display:flex; align-items:center; gap:28px; width:100%; }
.brand{ display:flex; align-items:center; gap:10px; height:34px; }
.brand img{ height:30px; width:auto; }
.nav-links{ display:flex; align-items:center; gap:4px; margin-inline:auto; }
.nav-links a{
  color:var(--ink-1); font-weight:600; font-size:15px; padding:9px 16px;
  border-radius:var(--r-pill); transition: background .15s, color .15s;
}
.nav-links a:hover{ background:var(--accent-soft); color:var(--accent-strong); }
.nav-cta{ display:flex; align-items:center; gap:10px; }
.nav-toggle{ display:none; background:var(--surface); border:1px solid var(--line);
  width:46px;height:46px;border-radius:14px; align-items:center;justify-content:center;cursor:pointer; }
.nav-toggle svg{ width:22px;height:22px; }

/* mobile drawer */
.mobile-menu{ position:fixed; inset:var(--header-h) 0 auto 0; z-index:55;
  background:var(--surface); border-bottom:1px solid var(--line);
  padding:16px var(--pad) 24px; transform:translateY(-120%); transition:transform .32s var(--ease-entry);
  box-shadow: var(--card-shadow-lg); }
.mobile-menu.open{ transform:translateY(0); }
.mobile-menu a{ display:block; padding:14px 8px; font-weight:700; font-size:18px; color:var(--ink-0); border-bottom:1px solid var(--line); }
.mobile-menu .btn{ margin-top:16px; }

/* ============================================================
   HERO
   ============================================================ */
.hero{ position:relative; padding-top: clamp(36px,6vw,64px); padding-bottom: clamp(48px,7vw,96px); overflow:hidden; }
.hero-grid{ display:grid; grid-template-columns: 1.05fr .95fr; gap: clamp(28px,5vw,64px); align-items:center; }
.hero-copy{ max-width:620px; }
.hero h1{
  font-weight:900; letter-spacing:-0.035em; line-height:1.0;
  font-size: clamp(40px, 6.4vw, 74px); color:var(--ink-0); text-wrap:balance;
}
.hero h1 .accent{ color:var(--accent); position:relative; white-space:nowrap; }
.hero h1 .accent .uline{ position:absolute; left:0; right:0; bottom:.04em; height:.13em;
  background:var(--pop); border-radius:var(--r-pill); z-index:-1; opacity:.9; }
.hero-sub{ margin-top:22px; font-size: clamp(17px,1.7vw,20px); color:var(--ink-2); line-height:1.6; max-width:540px; text-wrap:pretty; }
.hero-cta{ display:flex; flex-wrap:wrap; gap:14px; margin-top:32px; }
.hero-trust{ display:flex; align-items:center; gap:18px; margin-top:30px; flex-wrap:wrap; }
.hero-trust .avatars{ display:flex; }
.hero-trust .avatars span{ width:38px;height:38px;border-radius:50%; border:2.5px solid var(--page);
  margin-left:-12px; background-size:cover; background-position:center; box-shadow:0 2px 6px rgba(0,0,0,.12); }
.hero-trust .avatars span:first-child{ margin-left:0; }
.hero-trust .t-meta{ font-size:14px; color:var(--ink-2); line-height:1.35; }
.hero-trust .t-meta b{ color:var(--ink-0); }

/* hero visual */
.hero-visual{ position:relative; }
.hero-photo{ position:relative; border-radius: 32px 32px 32px 8px; overflow:hidden;
  aspect-ratio: 4/5; background:var(--page-2); box-shadow: var(--card-shadow-lg); }
.hero-photo img{ width:100%; height:100%; object-fit:cover; object-position:center 18%; }
.hero-photo::after{ content:""; position:absolute; inset:0;
  background: linear-gradient(180deg, transparent 55%, rgba(7,12,9,.32)); }
.hero-blob{ position:absolute; border-radius:50%; filter:blur(8px); z-index:-1; }
.hero-blob.a{ width:340px;height:340px; background:var(--accent-soft); top:-60px; right:-40px; }
.hero-blob.b{ width:220px;height:220px; background:var(--pop-soft); bottom:-30px; left:-50px; }

/* floating chips on hero */
.float{ position:absolute; z-index:3; background:var(--surface); border:1px solid var(--line);
  border-radius:18px; padding:12px 15px; box-shadow: var(--card-shadow-lg); }
.float--rating{ top:6%; left:-6%; display:flex; align-items:center; gap:11px; }
.float--rating .num{ font-size:26px; font-weight:900; color:var(--ink-0); line-height:1; }
.float--rating .sub{ font-size:12px; color:var(--ink-2); margin-top:3px; }
.float--review{ bottom:10%; right:-8%; max-width:230px; }
.float--review .rv-top{ display:flex; align-items:center; gap:9px; margin-bottom:7px; }
.float--review .rv-av{ width:30px;height:30px;border-radius:50%;background-size:cover;background-position:center; }
.float--review .rv-name{ font-size:13px; font-weight:800; color:var(--ink-0); }
.float--review p{ font-size:12.5px; color:var(--ink-2); line-height:1.45; }
.float--country{ bottom:-3%; left:6%; display:flex; align-items:center; gap:9px; }
.float--country svg{ width:18px;height:18px; }
.float--country b{ color:var(--ink-0); }
.float small{ display:block; }

/* ============================================================
   MARQUEE / TRUST STRIP
   ============================================================ */
.statstrip{ display:grid; grid-template-columns: repeat(4,1fr); gap:1px; background:var(--line);
  border:1px solid var(--line); border-radius: var(--r-l); overflow:hidden; box-shadow:var(--card-shadow); }
.statstrip .cell{ background:var(--surface); padding:26px 22px; text-align:center; }
.statstrip .num{ font-size: clamp(28px,3.4vw,40px); font-weight:900; color:var(--ink-0); line-height:1; letter-spacing:-.03em; }
.statstrip .num .u{ color:var(--accent); }
.statstrip .lbl{ margin-top:8px; font-size:14px; color:var(--ink-2); font-weight:600; }

/* ============================================================
   FEATURE CARDS (What you get)
   ============================================================ */
.feature-grid{ display:grid; grid-template-columns: repeat(3,1fr); gap:22px; margin-top:48px; }
.fcard{ background:var(--surface); border:1px solid var(--line); border-radius:var(--r-xl);
  padding:32px; box-shadow:var(--card-shadow); transition: transform .25s var(--ease-regular), box-shadow .25s, border-color .25s; position:relative; overflow:hidden; }
.fcard:hover{ transform:translateY(-6px); box-shadow:var(--card-shadow-lg); border-color:color-mix(in srgb,var(--accent) 30%, var(--line)); }
.fcard .ficon{ width:60px;height:60px;border-radius:18px; display:flex;align-items:center;justify-content:center;
  background:var(--accent-soft); margin-bottom:22px; }
.fcard .ficon svg{ width:30px;height:30px; }
.fcard h3{ font-size:22px; font-weight:800; }
.fcard p{ margin-top:11px; color:var(--ink-2); line-height:1.6; font-size:15.5px; }
.fcard .flist{ margin-top:18px; display:flex; flex-direction:column; gap:10px; }
.fcard .flist li{ display:flex; align-items:center; gap:10px; font-size:14.5px; color:var(--ink-1); font-weight:600; list-style:none; }
.fcard .flist li svg{ width:18px;height:18px; flex:none; }
.fcard .corner{ position:absolute; top:-30px; right:-30px; width:120px;height:120px; border-radius:50%;
  background:var(--accent-softer); z-index:0; }
.fcard > *{ position:relative; z-index:1; }

/* icon recolor helpers (DS icons are dark-stroked on dark; here we tint) */
.i-accent{ filter: invert(38%) sepia(86%) saturate(420%) hue-rotate(96deg) brightness(92%) contrast(90%); }

/* ============================================================
   TRANSFORMATIONS
   ============================================================ */
.ba{ display:grid; grid-template-columns: 1.1fr .9fr; gap:40px; align-items:center; margin-top:48px; }
.ba-slider{ position:relative; width:100%; aspect-ratio: 3/5; border-radius:var(--r-l); overflow:hidden; container-type: inline-size;
  user-select:none; box-shadow:var(--card-shadow-lg); background:#000; cursor:ew-resize; }
.ba-slider img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; object-position:top center; pointer-events:none; }
.ba-after-wrap{ position:absolute; inset:0; overflow:hidden; width:50%; }
.ba-after-wrap img{ width:100cqw; max-width:none; height:100%; object-fit:cover; object-position:top center; display:block; }
.ba-handle{ position:absolute; top:0; bottom:0; left:50%; width:3px; background:#fff; transform:translateX(-50%); z-index:2; box-shadow:0 0 0 1px rgba(0,0,0,.15); }
.ba-handle .knob{ position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); width:46px;height:46px;border-radius:50%;
  background:#fff; box-shadow:0 4px 14px rgba(0,0,0,.35); display:flex;align-items:center;justify-content:center; }
.ba-handle .knob::before{ content:"‹ ›"; font-weight:900; color:var(--ink-0); font-size:16px; letter-spacing:-1px; }
.ba-tag{ position:absolute; bottom:14px; z-index:3; font-size:12px; font-weight:800; letter-spacing:.08em; text-transform:uppercase;
  color:#fff; background:rgba(7,12,9,.6); padding:6px 12px; border-radius:var(--r-pill); backdrop-filter:blur(4px); }
.ba-tag.before{ left:14px; } .ba-tag.after{ right:14px; background:var(--accent); }

.ba-copy .res{ display:flex; flex-direction:column; gap:18px; margin-top:24px; }
.ba-copy .res-row{ display:flex; align-items:center; gap:14px; }
.ba-copy .res-row .rnum{ font-size:30px; font-weight:900; color:var(--accent); min-width:84px; letter-spacing:-.03em; }
.ba-copy .res-row .rlbl{ font-size:15px; color:var(--ink-2); }

.tgrid{ display:grid; grid-template-columns: repeat(4,1fr); gap:18px; margin-top:48px; }
.tcard{ position:relative; border-radius:var(--r-l); overflow:hidden; aspect-ratio: 4/5; background:var(--page-2);
  box-shadow:var(--card-shadow); transition: transform .25s var(--ease-regular), box-shadow .25s; }
.tcard:hover{ transform:translateY(-5px); box-shadow:var(--card-shadow-lg); }
.tcard img{ width:100%; height:100%; object-fit:cover; transition: transform .5s var(--ease-regular); }
.tcard:hover img{ transform:scale(1.05); }
.tcard .cap{ position:absolute; left:0; right:0; bottom:0; padding:34px 16px 14px;
  background:linear-gradient(transparent, rgba(7,12,9,.82)); color:#fff; }
.tcard .cap .nm{ font-weight:800; font-size:15px; }
.tcard .cap .rs{ font-size:13px; color:#cdeedb; font-weight:700; margin-top:2px; display:flex;align-items:center;gap:6px; }
.tcard .badge{ position:absolute; top:12px; right:12px; background:var(--accent); color:#fff;
  font-size:12px; font-weight:800; padding:5px 11px; border-radius:var(--r-pill); box-shadow:0 4px 12px rgba(0,0,0,.25); }
.tcard.more{ display:flex; align-items:center; justify-content:center; background:var(--accent-soft); border:1px dashed color-mix(in srgb,var(--accent) 40%, transparent); }
.tcard.more a{ text-align:center; font-weight:800; color:var(--accent-strong); font-size:17px; }
.tcard.more .big{ font-size:40px; font-weight:900; display:block; }

/* ============================================================
   HOW IT WORKS
   ============================================================ */
.steps{ display:grid; grid-template-columns: repeat(5,1fr); gap:0; margin-top:54px; position:relative; }
.step{ position:relative; padding:0 16px; text-align:center; }
.step .ring{ width:64px;height:64px; margin:0 auto 20px; border-radius:50%; background:var(--surface);
  border:2px solid var(--line); display:flex;align-items:center;justify-content:center; position:relative; z-index:2;
  box-shadow:var(--card-shadow); transition:.25s; }
.step .ring .n{ font-size:22px; font-weight:900; color:var(--accent); }
.step:hover .ring{ border-color:var(--accent); transform:translateY(-3px); }
.step h4{ font-size:17px; font-weight:800; }
.step p{ margin-top:8px; font-size:14px; color:var(--ink-2); line-height:1.5; }
.steps .track{ position:absolute; top:32px; left:10%; right:10%; height:2px; background:var(--line); z-index:1; }
.steps .track::after{ content:""; position:absolute; inset:0; background:linear-gradient(90deg,var(--accent),var(--lime)); transform-origin:left; transform:scaleX(var(--p,0)); transition:transform 1.1s var(--ease-regular); }

/* ============================================================
   TRAINER
   ============================================================ */
.trainer{ display:grid; grid-template-columns: .9fr 1.1fr; gap:clamp(28px,5vw,64px); align-items:center; }
.trainer-photo{ position:relative; border-radius:28px 28px 28px 8px; overflow:hidden; aspect-ratio:4/5;
  box-shadow:var(--card-shadow-lg); background:var(--page-2); }
.trainer-photo img{ width:100%;height:100%;object-fit:cover; }
.trainer-photo .pcard{ position:absolute; left:16px; bottom:16px; right:16px; background:rgba(255,255,255,.94);
  backdrop-filter:blur(8px); border-radius:16px; padding:14px 16px; display:flex;align-items:center;gap:12px; box-shadow:var(--card-shadow); }
.trainer-photo .pcard .pc-ic{ width:42px;height:42px;border-radius:12px;background:var(--accent-soft);display:flex;align-items:center;justify-content:center; flex:none;}
.trainer-photo .pcard .pc-ic svg{ width:22px;height:22px; }
.trainer-photo .pcard b{ color:var(--ink-0); font-size:14px; }
.trainer-photo .pcard small{ color:var(--ink-2); font-size:12.5px; }
.trainer-creds{ display:flex; flex-direction:column; gap:14px; margin-top:28px; }
.cred{ display:flex; gap:14px; align-items:flex-start; }
.cred .ci{ width:44px;height:44px;border-radius:13px;background:var(--accent-soft);display:flex;align-items:center;justify-content:center;flex:none; }
.cred .ci svg{ width:22px;height:22px; }
.cred b{ display:block; color:var(--ink-0); font-size:16px; }
.cred span{ color:var(--ink-2); font-size:14.5px; line-height:1.5; }

/* ============================================================
   PRICING
   ============================================================ */
.price-toggle{ display:inline-flex; background:var(--page-2); border:1px solid var(--line); border-radius:var(--r-pill);
  padding:5px; margin:28px auto 0; position:relative; gap:4px; }
.price-toggle button{ border:0; background:transparent; cursor:pointer; font-family:inherit;
  font-weight:800; font-size:15px; color:var(--ink-2); padding:11px 26px; border-radius:var(--r-pill); position:relative; z-index:2; transition:color .2s; white-space:nowrap; }
.price-toggle button.active{ color:#fff; }
.price-toggle .slider{ position:absolute; top:5px; bottom:5px; left:5px; width:calc(50% - 5px);
  background:var(--accent); border-radius:var(--r-pill); transition: transform .32s var(--ease-regular); z-index:1; box-shadow:0 6px 16px -6px var(--accent-glow); }
.price-toggle.fitness .slider{ transform: translateX(100%); }

.price-grid{ display:grid; grid-template-columns: repeat(3,1fr); gap:22px; margin-top:42px; align-items:stretch; }
.pcard{ background:var(--surface); border:1px solid var(--line); border-radius:var(--r-xl); padding:32px 28px;
  display:flex; flex-direction:column; box-shadow:var(--card-shadow); transition: transform .25s, box-shadow .25s, border-color .25s; position:relative; }
.pcard:hover{ transform:translateY(-6px); box-shadow:var(--card-shadow-lg); }
.pcard.featured{ border-color:var(--accent); box-shadow: var(--card-shadow-lg), 0 0 0 1px var(--accent); }
.pcard.featured::before{ content:"Most popular"; position:absolute; top:-13px; left:50%; transform:translateX(-50%);
  background:var(--accent); color:#fff; font-size:12px; font-weight:800; padding:6px 16px; border-radius:var(--r-pill); letter-spacing:.02em; box-shadow:0 8px 18px -6px var(--accent-glow); }
.pcard .pname{ font-size:18px; font-weight:800; color:var(--ink-0); }
.pcard .pdesc{ font-size:13.5px; color:var(--ink-3); margin-top:4px; min-height:20px; }
.pcard .pprice{ margin-top:20px; display:flex; align-items:flex-end; gap:6px; }
.pcard .pprice .amt{ font-size:46px; font-weight:900; color:var(--ink-0); letter-spacing:-.04em; line-height:.9; }
.pcard .pprice .per{ font-size:14px; color:var(--ink-3); font-weight:600; padding-bottom:6px; }
.pcard .pfeat{ list-style:none; margin:24px 0 0; padding:24px 0 0; border-top:1px solid var(--line); display:flex; flex-direction:column; gap:13px; flex:1; }
.pcard .pfeat li{ display:flex; gap:11px; align-items:flex-start; font-size:14.5px; color:var(--ink-1); }
.pcard .pfeat li svg{ width:19px;height:19px;flex:none; margin-top:1px; }
.pcard .btn{ margin-top:26px; }
.price-pane{ display:none; }
.price-pane.active{ display:block; animation: fade .4s var(--ease-entry); }
@keyframes fade{ from{ opacity:0; transform:translateY(10px);} to{ opacity:1; transform:none; } }

/* ============================================================
   TESTIMONIALS
   ============================================================ */
.tm-head{ display:flex; align-items:center; justify-content:space-between; gap:24px; flex-wrap:wrap; }
.tm-rating{ display:flex; align-items:center; gap:14px; background:var(--surface); border:1px solid var(--line);
  border-radius:var(--r-l); padding:16px 22px; box-shadow:var(--card-shadow); }
.tm-rating .big{ font-size:40px; font-weight:900; color:var(--ink-0); line-height:1; letter-spacing:-.03em; }
.tm-rating .meta{ font-size:13px; color:var(--ink-2); }
.tm-rating .meta b{ color:var(--ink-0); }
.tm-grid{ columns: 3; column-gap:22px; margin-top:42px; }
.tcard-r{ break-inside:avoid; margin-bottom:22px; background:var(--surface); border:1px solid var(--line);
  border-radius:var(--r-l); padding:26px; box-shadow:var(--card-shadow); transition:transform .2s, box-shadow .2s; }
.tcard-r:hover{ transform:translateY(-4px); box-shadow:var(--card-shadow-lg); }
.tcard-r .rv-stars{ margin-bottom:14px; }
.tcard-r p{ font-size:15.5px; line-height:1.6; color:var(--ink-1); }
.tcard-r .hl{ background:var(--accent-soft); color:var(--accent-deep); padding:1px 4px; border-radius:4px; font-weight:600; box-decoration-break:clone; }
.tcard-r .rv-by{ display:flex; align-items:center; gap:12px; margin-top:20px; }
.tcard-r .rv-by .av{ width:44px;height:44px;border-radius:50%; background:var(--accent-soft); color:var(--accent-strong);
  display:flex;align-items:center;justify-content:center;font-weight:800;font-size:16px; flex:none; background-size:cover;background-position:center; }
.tcard-r .rv-by .nm{ font-weight:800; color:var(--ink-0); font-size:15px; }
.tcard-r .rv-by .mt{ font-size:12.5px; color:var(--ink-3); display:flex;align-items:center;gap:6px; }
.tcard-r .gverified{ display:inline-flex; align-items:center; gap:4px; }
.tcard-r .gverified svg{ width:14px;height:14px; }

/* ============================================================
   CTA BAND
   ============================================================ */
.cta-band{ position:relative; overflow:hidden; border-radius:var(--r-xxl); padding: clamp(40px,6vw,72px);
  background: radial-gradient(120% 140% at 85% 10%, var(--accent-strong), var(--accent-deep));
  color:#fff; text-align:center; box-shadow:var(--card-shadow-lg); }
.cta-band h2{ color:#fff; font-size:clamp(30px,4.4vw,50px); font-weight:900; letter-spacing:-.03em; text-wrap:balance; }
.cta-band p{ color:rgba(255,255,255,.86); max-width:560px; margin:18px auto 0; font-size:18px; line-height:1.6; }
.cta-band .hero-cta{ justify-content:center; }
.cta-band .blob{ position:absolute; border-radius:50%; background:rgba(255,255,255,.08); }
.cta-band .blob.a{ width:400px;height:400px; top:-160px; left:-120px; }
.cta-band .blob.b{ width:280px;height:280px; bottom:-140px; right:-80px; background:rgba(245,166,35,.18); }
.cta-band .seal{ position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); width:120%; opacity:.05; }

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{ background:var(--ink-0); color:rgba(255,255,255,.7); padding-block: clamp(48px,6vw,80px) 32px; }
.footer-grid{ display:grid; grid-template-columns: 1.6fr 1fr 1fr 1.2fr; gap:40px; }
.site-footer .brand img{ height:30px; filter:brightness(0) invert(1); }
.footer-about{ margin-top:18px; font-size:14.5px; line-height:1.6; color:rgba(255,255,255,.6); max-width:300px; }
.footer-social{ display:flex; gap:10px; margin-top:20px; }
.footer-social a{ width:42px;height:42px;border-radius:12px; background:rgba(255,255,255,.08); display:flex;align-items:center;justify-content:center; transition:.2s; }
.footer-social a:hover{ background:var(--accent); transform:translateY(-2px); }
.footer-social a svg{ width:20px;height:20px; filter:brightness(0) invert(1); }
.footer-col h5{ color:#fff; font-size:14px; font-weight:800; letter-spacing:.04em; text-transform:uppercase; margin-bottom:18px; }
.footer-col a, .footer-col .fc-row{ display:flex; align-items:center; gap:10px; color:rgba(255,255,255,.66); font-size:14.5px; padding:7px 0; transition:color .15s; }
.footer-col a:hover{ color:#fff; }
.footer-col .fc-row svg{ width:17px;height:17px; flex:none; filter:brightness(0) invert(1); opacity:.7; }
.footer-bottom{ margin-top:48px; padding-top:24px; border-top:1px solid rgba(255,255,255,.12);
  display:flex; align-items:center; justify-content:space-between; gap:16px; flex-wrap:wrap; font-size:13.5px; color:rgba(255,255,255,.5); }

/* ---- reveal animation ---- */
.reveal{ opacity:0; transform:translateY(28px); transition: opacity .7s var(--ease-regular), transform .7s var(--ease-regular); }
.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;}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1024px){
  .hero-grid{ grid-template-columns:1fr; }
  .hero-visual{ max-width:460px; margin-inline:auto; width:100%; }
  .float--rating{ left:0; } .float--review{ right:0; }
  .feature-grid{ grid-template-columns:1fr; }
  .tgrid{ grid-template-columns: repeat(3,1fr); }
  .price-grid{ grid-template-columns:1fr; max-width:480px; margin-inline:auto; }
  .trainer{ grid-template-columns:1fr; } .trainer-photo{ max-width:420px; margin-inline:auto; width:100%; }
  .tm-grid{ columns:2; }
  .ba{ grid-template-columns:1fr; } .ba-slider{ max-width:460px; margin-inline:auto; width:100%; }
  .steps{ grid-template-columns: repeat(2,1fr); gap:36px 16px; } .steps .track{ display:none; }
  .footer-grid{ grid-template-columns: 1fr 1fr; gap:32px; }
}
@media (max-width: 640px){
  :root{ --header-h:64px; }
  .nav-links{ display:none; }
  .nav-cta .btn--ghost{ display:none; }
  .nav-toggle{ display:flex; }
  .tgrid{ grid-template-columns: repeat(2,1fr); gap:12px; }
  .statstrip{ grid-template-columns: repeat(2,1fr); }
  .tm-grid{ columns:1; }
  .steps{ grid-template-columns:1fr; }
  .tm-head{ flex-direction:column; align-items:flex-start; }
  .float{ transform:scale(.9); }
  .hero h1{ font-size: clamp(36px,11vw,52px); }
}
