/* =========================================================
   ЛогоЙога — «Тёплая практика»
   Palette: warm paper · deep forest · sage · clay accent
   ========================================================= */

:root{
  --paper:      #F6EFE2;
  --paper-2:    #EFE6D5;
  --surface:    #E2E9D9;
  --card:       #FFFCF5;
  --ink:        #22312A;
  --ink-soft:   #4C5A52;
  --forest:     #2F4A3A;
  --forest-700: #25382C;
  --sage:       #6E8B76;
  --sage-soft:  #A9C0AD;
  --sage-tint:  #DDE7DA;
  --clay:       #C8704A;
  --clay-600:   #B45F3C;
  --clay-soft:  #E7B69C;
  --gold:       #D6A24B;
  --line:       #E2D7C4;

  --shadow-sm: 0 2px 10px rgba(47,74,58,.06);
  --shadow:    0 14px 38px -16px rgba(47,74,58,.28);
  --shadow-lg: 0 36px 80px -36px rgba(47,74,58,.42);

  --r-sm: 14px;
  --r:    22px;
  --r-lg: 34px;

  --ff-serif: "Spectral", Georgia, serif;
  --ff-sans:  "Manrope", system-ui, sans-serif;

  --maxw: 1180px;
  --gut: clamp(18px, 5vw, 64px);
}

*,*::before,*::after{ box-sizing:border-box; }

html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%;
  overflow-x:hidden; overflow-x:clip; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }

body{
  margin:0;
  font-family:var(--ff-sans);
  color:var(--ink);
  background:var(--paper);
  line-height:1.6;
  font-size:clamp(16px,1.05vw,18px);
  -webkit-font-smoothing:antialiased;
  width:100%;
  overflow-x:hidden; overflow-x:clip;
}

img{ max-width:100%; height:auto; display:block; }
a{ color:inherit; text-decoration:none; }

.container{
  width:100%;
  max-width:var(--maxw);
  margin:0 auto;
  padding-inline:var(--gut);
}

/* ---------- Typography helpers ---------- */
h1,h2,h3{ font-family:var(--ff-serif); font-weight:600; line-height:1.08; letter-spacing:-.01em; margin:0; }
.u-accent{ color:var(--clay); font-style:italic; }

.eyebrow{
  font-size:.78rem; font-weight:700; letter-spacing:.16em; text-transform:uppercase;
  color:var(--clay-600); margin:0 0 14px;
}
.eyebrow--center{ text-align:center; }
.eyebrow--light{ color:var(--clay-soft); }

.section{ padding:clamp(64px,9vw,128px) 0; position:relative; }
/* Alternating surface rhythm — visual separation between blocks */
.how, .video, .results, .curators, .reviews{ background:var(--paper); }
.program, .pricing, .experts, .faq{ background:var(--surface); }
.section__head{ max-width:720px; margin:0 auto clamp(40px,6vw,68px); text-align:center; }
.section__head--left{ margin-inline:0; text-align:left; }
.section__title{ font-size:clamp(1.9rem,4.4vw,3.4rem); }
.section__title--left{ text-align:left; }
.section__sub{ color:var(--ink-soft); font-size:1.08rem; margin:18px 0 0; }
.section__sub--left{ text-align:left; }

/* ---------- Buttons ---------- */
.btn{
  --bg:var(--forest); --fg:#fff;
  display:inline-flex; align-items:center; justify-content:center; gap:.5em;
  font-family:var(--ff-sans); font-weight:700; font-size:.98rem; line-height:1;
  white-space:nowrap;
  padding:15px 26px; border-radius:999px; border:2px solid transparent;
  background:var(--bg); color:var(--fg); cursor:pointer;
  transition:transform .25s cubic-bezier(.2,.8,.2,1), box-shadow .25s, background .25s, color .25s;
  box-shadow:var(--shadow-sm);
}
.btn:hover{ transform:translateY(-3px); box-shadow:var(--shadow); }
.btn:active{ transform:translateY(-1px); }
.btn--primary{ --bg:var(--clay); --fg:#fff; }
.btn--primary:hover{ --bg:var(--clay-600); }
.btn--clay{ --bg:#fff; --fg:var(--forest-700); }
.btn--outline{ --bg:transparent; --fg:var(--forest); border-color:var(--forest); box-shadow:none; }
.btn--outline:hover{ --bg:var(--forest); --fg:#fff; }
.btn--ghost{ --bg:transparent; --fg:var(--forest); box-shadow:none; }
.btn--ghost:hover{ --bg:var(--sage-tint); }
.btn--lg{ padding:19px 34px; font-size:1.06rem; }
.btn--sm{ padding:11px 20px; font-size:.9rem; }
.btn--block{ width:100%; }

/* ---------- Header ---------- */
.header{
  position:fixed; inset:0 0 auto; z-index:60;
  transition:background .3s, box-shadow .3s, padding .3s;
  padding:14px 0;
}
.header.is-stuck{
  background:rgba(246,239,226,.82);
  backdrop-filter:saturate(1.4) blur(14px);
  box-shadow:0 1px 0 var(--line);
  padding:9px 0;
}
.header__inner{ display:flex; align-items:center; gap:22px; }
.logo{ display:inline-flex; align-items:center; gap:10px; color:var(--forest); font-weight:800; }
.logo__mark{ display:inline-flex; }
.logo__text{ font-family:var(--ff-serif); font-size:1.4rem; font-weight:600; letter-spacing:-.01em; }
.logo--light{ color:#fff; }

.nav{ display:flex; gap:2px; margin-left:auto; }
.nav__link{
  font-size:.92rem; font-weight:600; color:var(--ink-soft); white-space:nowrap;
  padding:8px 11px; border-radius:999px; transition:color .2s, background .2s;
}
.nav__link:hover{ color:var(--forest); background:var(--sage-tint); }
.nav__link--accent{ color:var(--clay-600); }
.header__cta{ margin-left:4px; }

.burger{ display:none; width:44px; height:44px; border:none; background:transparent; cursor:pointer; margin-left:auto; }
.burger span{ display:block; width:24px; height:2px; margin:5px auto; background:var(--forest); border-radius:2px; transition:.3s; }
.burger[aria-expanded="true"] span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.burger[aria-expanded="true"] span:nth-child(2){ opacity:0; }
.burger[aria-expanded="true"] span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

/* ---------- Hero ---------- */
.hero{ position:relative; padding:clamp(120px,16vw,180px) 0 clamp(56px,8vw,96px); overflow:hidden; }
.hero__bg{ position:absolute; inset:0; z-index:0; pointer-events:none; }
.hero__bg-img{ position:absolute; inset:0;
  background:url("../images/gen/hero-bg.jpg") right center/cover no-repeat; opacity:.9; }
.hero__bg-img::after{ content:""; position:absolute; inset:0;
  background:linear-gradient(95deg, var(--paper) 14%, rgba(246,239,226,.55) 40%, rgba(246,239,226,0) 66%); }
.blob{ position:absolute; border-radius:50%; filter:blur(60px); opacity:.45; }
.blob--1{ width:42vw; height:42vw; max-width:560px; max-height:560px; right:-10vw; top:-8vw;
  background:radial-gradient(circle at 30% 30%, var(--sage-soft), transparent 70%); }
.grain{
  position:absolute; inset:0; opacity:.05; mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

.hero__inner{ position:relative; z-index:1; display:grid; grid-template-columns:1.15fr .85fr; gap:clamp(30px,5vw,72px); align-items:center; }
.hero__title{ font-size:clamp(2rem,4.4vw,3.3rem); margin:0 0 22px; }
.hero__lead{ font-size:clamp(1.05rem,1.5vw,1.24rem); color:var(--ink-soft); max-width:38ch; margin:0 0 24px; }
.hero__lead b{ color:var(--ink); font-weight:700; }

.hero__chips{ display:flex; flex-wrap:wrap; gap:8px; margin-bottom:30px; }
.chip{
  font-size:.84rem; font-weight:600; color:var(--ink-soft);
  padding:7px 14px; border-radius:999px; background:rgba(255,255,255,.6);
  border:1px solid var(--line); position:relative; padding-left:26px;
}
.chip::before{ content:""; position:absolute; left:12px; top:50%; width:7px; height:7px; margin-top:-3.5px;
  border-radius:50%; background:var(--clay); }

.hero__actions{ display:flex; flex-wrap:wrap; gap:14px; margin-bottom:34px; }

.hero__trust{ list-style:none; display:flex; flex-wrap:wrap; gap:26px; padding:0; margin:0; }
.hero__trust li{ font-size:.92rem; color:var(--ink-soft); }
.hero__trust b{ display:block; font-family:var(--ff-serif); font-size:1.7rem; color:var(--forest); line-height:1; }

/* Hero art / breathing */
.hero__art{ position:relative; display:grid; place-items:center; min-height:360px; }
.breath{ position:relative; width:min(70%,320px); aspect-ratio:1; display:grid; place-items:center; }
.breath__ring{ position:absolute; inset:0; border-radius:50%; border:1.5px solid var(--sage-soft);
  animation:breathe 6s ease-in-out infinite; }
.breath__ring--2{ inset:14%; opacity:.7; animation-delay:.3s; border-color:var(--sage); }
.breath__ring--3{ inset:-12%; opacity:.4; animation-delay:.6s; }
.breath__core{
  position:relative; z-index:2; width:54%; aspect-ratio:1; border-radius:50%;
  background:linear-gradient(150deg, var(--forest), var(--sage));
  color:#fff; display:grid; place-content:center; justify-items:center; gap:8px; text-align:center;
  box-shadow:var(--shadow-lg); animation:breathe-core 6s ease-in-out infinite;
}
.breath__label{ font-size:.8rem; font-weight:600; letter-spacing:.04em; opacity:.92; }
@keyframes breathe{ 0%,100%{ transform:scale(1); } 50%{ transform:scale(1.08); } }
@keyframes breathe-core{ 0%,100%{ transform:scale(1); box-shadow:var(--shadow); } 50%{ transform:scale(1.05); box-shadow:var(--shadow-lg); } }

.hero__art-card{
  position:absolute; background:var(--card); border:1px solid var(--line);
  border-radius:var(--r-sm); padding:12px 16px; box-shadow:var(--shadow);
  font-size:.86rem; font-weight:600; display:flex; align-items:center; gap:9px; max-width:200px;
}
.hero__art-emoji{ font-size:1.3rem; }
.hero__art-card--a{ top:6%; left:-4%; animation:floaty 7s ease-in-out infinite; }
.hero__art-card--b{ bottom:4%; right:-6%; animation:floaty 7s ease-in-out infinite .8s; }
@keyframes floaty{ 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(-12px); } }

.hero__scroll{ position:absolute; left:50%; bottom:22px; transform:translateX(-50%); z-index:2;
  width:26px; height:42px; border:2px solid var(--sage); border-radius:14px; display:grid; }
.hero__scroll span{ width:4px; height:8px; background:var(--clay); border-radius:2px; margin:6px auto 0;
  animation:scrolldot 1.8s ease-in-out infinite; }
@keyframes scrolldot{ 0%{ opacity:0; transform:translateY(0);} 40%{opacity:1;} 80%{ opacity:0; transform:translateY(12px);} }

/* ---------- Marquee ---------- */
.marquee{ background:var(--forest); color:var(--paper); padding:16px 0; overflow:hidden; }
.marquee__track{ display:flex; gap:28px; white-space:nowrap; width:max-content; animation:marquee 28s linear infinite; }
.marquee__track span{ font-family:var(--ff-serif); font-size:1.15rem; font-style:italic; opacity:.92; }
.marquee__track span:nth-child(even){ color:var(--gold); font-style:normal; }
@keyframes marquee{ to{ transform:translateX(-50%); } }

/* ---------- Self-check ---------- */
.check{ background:var(--surface); }
.check__grid{ display:grid; grid-template-columns:1.3fr .85fr; gap:clamp(24px,4vw,48px); align-items:start; }
.check__list{ display:grid; gap:12px; }
.symptom{ display:flex; gap:16px; align-items:flex-start; cursor:pointer;
  background:var(--card); border:1px solid var(--line); border-radius:var(--r);
  padding:18px 20px; transition:border-color .2s, box-shadow .2s, transform .2s, background .2s; }
.symptom:hover{ box-shadow:var(--shadow-sm); transform:translateX(3px); }
.symptom__input{ position:absolute; opacity:0; width:0; height:0; }
.symptom__box{ flex:none; width:26px; height:26px; border-radius:8px; border:2px solid var(--sage);
  display:grid; place-items:center; margin-top:2px; transition:background .2s, border-color .2s; }
.symptom__box::after{ content:""; width:12px; height:7px; border-left:2.5px solid #fff; border-bottom:2.5px solid #fff;
  transform:rotate(-45deg) scale(0); transform-origin:center; transition:transform .2s; margin-top:-2px; }
.symptom__input:checked + .symptom__box{ background:var(--clay); border-color:var(--clay); }
.symptom__input:checked + .symptom__box::after{ transform:rotate(-45deg) scale(1); }
.symptom__input:focus-visible + .symptom__box{ outline:3px solid var(--sage-soft); outline-offset:2px; }
.symptom:has(.symptom__input:checked){ border-color:var(--clay-soft); background:#fff; }
.symptom__body b{ display:block; font-size:1.05rem; }
.symptom__body small{ color:var(--ink-soft); font-size:.92rem; line-height:1.45; display:block; margin-top:2px; }

.check__result{ position:sticky; top:96px; background:var(--forest); color:var(--paper);
  border-radius:var(--r-lg); padding:clamp(26px,3vw,38px); box-shadow:var(--shadow-lg); overflow:hidden; }
.check__result::before{ content:""; position:absolute; right:-40px; top:-40px; width:180px; height:180px;
  border-radius:50%; background:radial-gradient(circle, rgba(214,162,75,.35), transparent 70%); }
.check__gauge{ position:relative; display:flex; align-items:baseline; gap:8px; }
.check__count{ font-family:var(--ff-serif); font-size:4.6rem; line-height:1; color:#fff; transition:color .3s; }
.check__total{ font-size:1.1rem; opacity:.8; }
.check__bar{ position:relative; height:8px; border-radius:999px; background:rgba(255,255,255,.16); margin:16px 0 22px; overflow:hidden; }
.check__bar span{ position:absolute; inset:0; width:0; border-radius:999px;
  background:linear-gradient(90deg, var(--sage-soft), var(--clay)); transition:width .5s cubic-bezier(.2,.8,.2,1); }
.check__verdict{ position:relative; font-size:1.5rem; color:#fff; margin:0 0 8px; }
.check__hint{ position:relative; color:rgba(246,239,226,.85); font-size:.98rem; margin:0 0 22px; }
.check__note{ position:relative; text-align:center; font-size:.82rem; opacity:.7; margin:12px 0 0; }

/* ---------- How it works / chain ---------- */
.how__body{ display:grid; grid-template-columns:.92fr 1.08fr; gap:clamp(26px,4vw,56px);
  align-items:center; max-width:960px; margin:0 auto clamp(48px,7vw,84px); }
.how__figure{ margin:0; border-radius:var(--r-lg); overflow:hidden; background:var(--card);
  border:1px solid var(--line); box-shadow:var(--shadow); }
.how__figure img{ width:100%; display:block; }
.chain{ max-width:560px; margin:0 auto clamp(48px,7vw,84px); display:grid; gap:10px; text-align:center; }
.how__body .chain{ max-width:none; margin:0; }
.chain__node{ background:var(--card); border:1px solid var(--line); border-radius:var(--r);
  padding:18px 22px; box-shadow:var(--shadow-sm); position:relative; }
.chain__node b{ font-family:var(--ff-serif); font-size:1.25rem; display:block; }
.chain__node small{ color:var(--ink-soft); }
.chain__num{ position:absolute; left:18px; top:50%; transform:translateY(-50%);
  width:30px; height:30px; border-radius:50%; background:var(--sage-tint); color:var(--forest);
  font-weight:800; font-size:.9rem; display:grid; place-items:center; }
.chain__arrow{ color:var(--sage); font-size:1.4rem; line-height:.5; }
.chain__break{ margin-top:10px; background:linear-gradient(135deg, var(--clay), var(--clay-600));
  color:#fff; border-radius:var(--r); padding:22px 26px; font-weight:600; font-size:1.05rem;
  box-shadow:var(--shadow); display:flex; gap:12px; align-items:center; justify-content:center; text-align:left; }
.chain__break-icon{ font-size:1.8rem; flex:none; }

.pillars{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
.pillar{ background:var(--card); border:1px solid var(--line); border-radius:var(--r); padding:26px 22px;
  box-shadow:var(--shadow-sm); transition:transform .25s, box-shadow .25s; }
.pillar:hover{ transform:translateY(-6px); box-shadow:var(--shadow); }
.pillar__icon{ display:block; width:62px; height:62px; border-radius:16px; overflow:hidden;
  margin-bottom:14px; box-shadow:var(--shadow-sm); }
.pillar__icon img{ width:100%; height:100%; object-fit:cover; }
.pillar h3{ font-size:1.25rem; margin-bottom:8px; }
.pillar p{ color:var(--ink-soft); font-size:.96rem; margin:0; }

/* ---------- Program cards ---------- */
.cards{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.card{ background:var(--card); border:1px solid var(--line); border-radius:var(--r-lg); padding:32px 28px;
  box-shadow:var(--shadow-sm); transition:transform .25s, box-shadow .25s; position:relative; overflow:hidden; }
.card::after{ content:""; position:absolute; right:-30px; bottom:-30px; width:120px; height:120px;
  border-radius:50%; background:var(--sage-tint); opacity:0; transition:opacity .3s; }
.card:hover{ transform:translateY(-6px); box-shadow:var(--shadow); }
.card:hover::after{ opacity:.5; }
.card__icon{ position:relative; z-index:1; display:block; width:66px; height:66px; border-radius:18px;
  overflow:hidden; margin-bottom:16px; box-shadow:var(--shadow-sm); }
.card__icon img{ width:100%; height:100%; object-fit:cover; }
.card h3{ position:relative; z-index:1; font-size:1.35rem; margin-bottom:8px; }
.card p{ position:relative; z-index:1; color:var(--ink-soft); margin:0; }

/* ---------- Ladder / funnel ---------- */
.steps{ background:var(--surface); }
.ladder{ list-style:none; counter-reset:step; padding:0; margin:0;
  display:grid; grid-template-columns:repeat(5,1fr); gap:14px; align-items:stretch; }
.ladder__step{ background:var(--card); border:1px solid var(--line); border-radius:var(--r);
  padding:24px 20px; box-shadow:var(--shadow-sm); display:flex; flex-direction:column;
  transition:transform .25s, box-shadow .25s; position:relative; }
.ladder__step:hover{ transform:translateY(-5px); box-shadow:var(--shadow); }
.ladder__tag{ align-self:flex-start; font-size:.74rem; font-weight:800; letter-spacing:.04em; text-transform:uppercase;
  padding:5px 11px; border-radius:999px; background:var(--sage-tint); color:var(--forest); margin-bottom:14px; }
.ladder__tag--price{ background:var(--paper-2); color:var(--ink-soft); }
.ladder__step--free .ladder__tag{ background:var(--clay); color:#fff; }
.ladder__step h3{ font-size:1.12rem; margin-bottom:8px; }
.ladder__step p{ color:var(--ink-soft); font-size:.92rem; margin:0 0 16px; flex:1; }
.ladder__link{ font-weight:700; color:var(--clay-600); font-size:.95rem; }
.ladder__link:hover{ color:var(--clay); }
.ladder__step--goal{ background:var(--forest); color:var(--paper); border-color:var(--forest); }
.ladder__step--goal h3{ color:#fff; }
.ladder__step--goal p{ color:rgba(246,239,226,.8); }
.ladder__step--goal .ladder__link{ color:var(--gold); }
.ladder__tag--goal{ background:var(--gold); color:var(--forest-700); }

/* ---------- Pricing ---------- */
.plans{ display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:24px; max-width:880px; margin:0 auto; }
.plan{ background:var(--card); border:1px solid var(--line); border-radius:var(--r-lg);
  padding:clamp(28px,3vw,40px); box-shadow:var(--shadow-sm); display:flex; flex-direction:column; position:relative; }
.plan--featured{ background:linear-gradient(180deg,#fff, #fbf6ec); border:2px solid var(--clay-soft);
  box-shadow:var(--shadow-lg); }
.plan__badge{ position:absolute; top:-14px; left:50%; transform:translateX(-50%);
  background:var(--clay); color:#fff; font-size:.78rem; font-weight:800; letter-spacing:.05em;
  text-transform:uppercase; padding:7px 18px; border-radius:999px; box-shadow:var(--shadow-sm); }
.plan__name{ font-size:1.6rem; margin-bottom:10px; }
.plan__price{ font-family:var(--ff-serif); font-size:1.2rem; color:var(--ink-soft); margin:0 0 8px; }
.plan__price span{ font-size:3rem; color:var(--forest); font-weight:600; }
.plan__price small{ font-size:1rem; }
.plan__caption{ color:var(--ink-soft); margin:0 0 22px; }
.plan__list{ list-style:none; padding:0; margin:0 0 28px; display:grid; gap:12px; flex:1; }
.plan__list li{ position:relative; padding-left:30px; font-size:.98rem; }
.plan__list li::before{ content:""; position:absolute; left:0; top:6px; width:18px; height:18px;
  border-radius:50%; background:var(--sage-tint);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%232F4A3A' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E");
  background-size:11px; background-repeat:no-repeat; background-position:center; }
.plan--featured .plan__list li::before{ background-color:var(--clay-soft); }
.pricing__foot{ text-align:center; margin:30px 0 0; color:var(--ink-soft); }
.pricing__foot a{ color:var(--clay-600); font-weight:700; border-bottom:1px solid var(--clay-soft); }

/* ---------- Author ---------- */
.author{ background:var(--forest); color:var(--paper); }
.author__inner{ display:grid; grid-template-columns:.8fr 1.2fr; gap:clamp(30px,5vw,72px); align-items:center; }
.author .eyebrow{ color:var(--gold); }
.author__photo{ position:relative; padding-bottom:18px; }
.author__photo-main{ width:100%; aspect-ratio:4/5; object-fit:cover; border-radius:var(--r-lg);
  box-shadow:var(--shadow-lg); border:1px solid rgba(255,255,255,.12); }
.author__inset{ position:absolute; left:-22px; bottom:0; width:46%; aspect-ratio:3/4; object-fit:cover;
  border-radius:var(--r); border:4px solid var(--forest); box-shadow:var(--shadow);
  transform:rotate(-3deg); background:var(--forest); }
.author__sticker{ position:absolute; right:-14px; top:24px; background:var(--gold); color:var(--forest-700);
  font-size:.82rem; font-weight:700; line-height:1.25; padding:12px 16px; border-radius:var(--r-sm);
  box-shadow:var(--shadow); transform:rotate(4deg); }
.author__role{ color:var(--gold); font-weight:600; margin:14px 0 18px; }
.author__text{ color:rgba(246,239,226,.9); max-width:54ch; }
.author__text b{ color:#fff; }
.author__creds{ list-style:none; padding:0; margin:20px 0 28px; display:grid; gap:10px; }
.author__creds li{ position:relative; padding-left:24px; color:rgba(246,239,226,.86); }
.author__creds li::before{ content:"✦"; position:absolute; left:0; color:var(--gold); }
.author__actions{ display:flex; flex-wrap:wrap; gap:12px; }
.author .btn--outline{ --fg:#fff; border-color:rgba(255,255,255,.5); }
.author .btn--outline:hover{ --bg:#fff; --fg:var(--forest); border-color:#fff; }
.author .btn--ghost{ --fg:#fff; }
.author .btn--ghost:hover{ --bg:rgba(255,255,255,.12); }

/* ---------- Curators ---------- */
.curators__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; max-width:920px; margin:0 auto; }
.curator{ background:var(--card); border:1px solid var(--line); border-radius:var(--r-lg);
  padding:18px 18px 26px; box-shadow:var(--shadow-sm); text-align:center;
  transition:transform .25s, box-shadow .25s; }
.curator:hover{ transform:translateY(-6px); box-shadow:var(--shadow); }
.curator__photo{ border-radius:var(--r); overflow:hidden; margin-bottom:18px; aspect-ratio:4/5;
  background:var(--sage-tint); }
.curator__photo img{ width:100%; height:100%; object-fit:cover; transition:transform .5s ease; }
.curator:hover .curator__photo img{ transform:scale(1.05); }
.curator h3{ font-size:1.3rem; margin-bottom:4px; }
.curator__role{ color:var(--clay-600); font-weight:600; font-size:.92rem; margin:0 0 12px; }
.curator__quote{ color:var(--ink-soft); font-style:italic; font-family:var(--ff-serif); font-size:1.02rem; margin:0; }

/* ---------- Results / before-after ---------- */
.results{ background:var(--paper); }
.ba-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.ba-card{ position:relative; margin:0; background:var(--card); border:1px solid var(--line);
  border-radius:var(--r-lg); overflow:hidden; box-shadow:var(--shadow-sm);
  transition:transform .25s, box-shadow .25s; }
.ba-card:hover{ transform:translateY(-5px); box-shadow:var(--shadow); }
.ba-card img{ width:100%; aspect-ratio:1/1; object-fit:cover; display:block; }
.ba-card__tag{ position:absolute; top:14px; left:14px; z-index:2; background:rgba(34,49,42,.82);
  color:#fff; font-size:.74rem; font-weight:800; letter-spacing:.04em; text-transform:uppercase;
  padding:6px 12px; border-radius:999px; backdrop-filter:blur(4px); }
.ba-card figcaption{ padding:16px 18px; font-weight:600; color:var(--forest); font-size:.98rem; }
.results__note{ text-align:center; color:var(--ink-soft); font-size:.9rem; margin:28px 0 0; }

/* ---------- Quotes / reviews ---------- */
.experts__grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:22px; max-width:920px; margin:0 auto; }
.reviews__grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:22px; }
.quote{ background:var(--card); border:1px solid var(--line); border-radius:var(--r-lg);
  padding:32px 30px; margin:0; box-shadow:var(--shadow-sm); position:relative; }
.quote::before{ content:"“"; position:absolute; top:6px; left:22px; font-family:var(--ff-serif);
  font-size:4rem; color:var(--sage-soft); line-height:1; }
.quote p{ position:relative; font-family:var(--ff-serif); font-size:1.18rem; font-style:italic;
  color:var(--ink); margin:18px 0 22px; }
.quote footer{ display:flex; flex-direction:row; align-items:center; gap:13px; }
.quote__avatar{ width:52px; height:52px; border-radius:50%; object-fit:cover; flex:none;
  box-shadow:var(--shadow-sm); border:2px solid #fff; }
.quote__who{ display:flex; flex-direction:column; }
.quote__who b{ font-size:1rem; }
.quote__who span{ font-size:.88rem; color:var(--ink-soft); }
.quote--expert{ background:linear-gradient(180deg,#fff,#fbf6ec); border-color:var(--clay-soft); }
.quote--expert::before{ color:var(--clay-soft); }

/* Expert cards (with photo) */
.expert-card{ display:grid; grid-template-columns:150px 1fr; gap:22px; align-items:start;
  background:linear-gradient(180deg,#fff,#fbf6ec); border:1px solid var(--clay-soft);
  border-radius:var(--r-lg); padding:24px; box-shadow:var(--shadow-sm); }
.expert-card__photo{ border-radius:var(--r); overflow:hidden; aspect-ratio:3/4; background:var(--sage-tint); }
.expert-card__photo img{ width:100%; height:100%; object-fit:cover; }
.expert-card__body blockquote{ margin:0 0 16px; font-family:var(--ff-serif); font-style:italic;
  font-size:1.06rem; line-height:1.5; color:var(--ink); }
.expert-card__name{ font-weight:700; font-size:1.02rem; margin:0 0 3px; color:var(--forest); }
.expert-card__role{ font-size:.84rem; color:var(--ink-soft); margin:0; }

/* Course video */
.video__frame{ position:relative; max-width:900px; margin:0 auto; aspect-ratio:16/9;
  border-radius:var(--r-lg); overflow:hidden; box-shadow:var(--shadow-lg);
  background:var(--forest-700); border:1px solid var(--line); }
.video__frame iframe{ position:absolute; inset:0; width:100%; height:100%; border:0; }

/* ---------- FAQ ---------- */
.faq__inner{ display:grid; grid-template-columns:.85fr 1.15fr; gap:clamp(30px,5vw,64px); align-items:start; }
.faq .section__head{ position:sticky; top:100px; }
.faq__list{ display:grid; gap:12px; }
.faq__item{ background:var(--card); border:1px solid var(--line); border-radius:var(--r); padding:4px 24px;
  transition:box-shadow .25s, border-color .25s; }
.faq__item[open]{ box-shadow:var(--shadow-sm); border-color:var(--sage-soft); }
.faq__item summary{ cursor:pointer; list-style:none; padding:18px 36px 18px 0; font-weight:700; font-size:1.08rem;
  position:relative; color:var(--forest); }
.faq__item summary::-webkit-details-marker{ display:none; }
.faq__item summary::after{ content:"+"; position:absolute; right:0; top:50%; transform:translateY(-50%);
  font-size:1.6rem; font-weight:400; color:var(--clay); transition:transform .3s; }
.faq__item[open] summary::after{ transform:translateY(-50%) rotate(45deg); }
.faq__item p{ margin:0 0 18px; color:var(--ink-soft); animation:faqIn .35s ease; }
.faq__img{ width:100%; border-radius:var(--r); margin:0 0 18px; box-shadow:var(--shadow-sm); animation:faqIn .35s ease; }
@keyframes faqIn{ from{ opacity:0; transform:translateY(-6px); } to{ opacity:1; transform:none; } }

/* ---------- For professionals ---------- */
.pro{ background:var(--paper); }
.pro__card{ display:grid; grid-template-columns:1.4fr .8fr; gap:clamp(26px,4vw,56px);
  background:linear-gradient(140deg, var(--forest), var(--forest-700)); color:var(--paper);
  border-radius:var(--r-lg); padding:clamp(30px,4vw,56px); box-shadow:var(--shadow-lg); position:relative; overflow:hidden; }
.pro__card::before{ content:""; position:absolute; right:-60px; top:-60px; width:300px; height:300px;
  border-radius:50%; background:radial-gradient(circle, rgba(214,162,75,.28), transparent 70%); }
.pro__title{ position:relative; font-size:clamp(1.7rem,3vw,2.4rem); margin:0 0 16px; }
.pro__lead{ position:relative; color:rgba(246,239,226,.88); margin:0 0 22px; max-width:52ch; }
.pro__facts{ position:relative; list-style:none; padding:0; margin:0; display:grid; gap:11px; }
.pro__facts li{ position:relative; padding-left:26px; color:rgba(246,239,226,.92); }
.pro__facts li::before{ content:"→"; position:absolute; left:0; color:var(--gold); font-weight:700; }
.pro__cta{ position:relative; background:rgba(255,255,255,.07); border:1px solid rgba(255,255,255,.14);
  border-radius:var(--r); padding:30px 26px; display:flex; flex-direction:column; justify-content:center; text-align:center; }
.pro__price{ font-family:var(--ff-serif); font-size:3rem; color:#fff; margin:0; line-height:1; }
.pro__price-note{ color:var(--gold); font-weight:600; margin:4px 0 20px; }
.pro__cta-note{ font-size:.85rem; color:rgba(246,239,226,.7); margin:14px 0 0; }

/* ---------- Final CTA ---------- */
.final{ position:relative; text-align:center; overflow:hidden;
  background-image:linear-gradient(rgba(246,239,226,.84), rgba(239,230,213,.93)), url("../images/gen/cta-band.jpg");
  background-size:cover; background-position:center 35%; }
.final__inner{ max-width:680px; margin:0 auto; }
.final__leaf{ font-size:2.6rem; display:block; margin-bottom:14px; }
.final__title{ font-size:clamp(2rem,4.5vw,3.2rem); margin-bottom:18px; }
.final__sub{ color:var(--ink-soft); font-size:1.1rem; margin:0 auto 30px; max-width:46ch; }
.final__note{ font-size:.86rem; color:var(--ink-soft); margin:16px 0 0; }

/* ---------- Footer ---------- */
.footer{ background:var(--forest-700); color:rgba(246,239,226,.78); padding:64px 0 28px; }
.footer__inner{ display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:36px; padding-bottom:40px;
  border-bottom:1px solid rgba(255,255,255,.1); }
.footer__tagline{ margin:14px 0 0; max-width:34ch; font-size:.95rem; }
.footer__nav, .footer__contacts{ display:flex; flex-direction:column; gap:10px; }
.footer__nav a:hover, .footer__contacts a:hover{ color:#fff; }
.footer__contacts-title{ color:#fff; font-weight:700; margin:0 0 4px; font-family:var(--ff-serif); }
.footer__bottom{ display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:12px;
  padding-top:22px; font-size:.86rem; }
.footer__bottom a:hover{ color:#fff; }

/* ---------- Sticky mobile CTA ---------- */
.sticky-cta{ display:none; position:fixed; left:50%; transform:translateX(-50%); bottom:14px; z-index:55;
  width:calc(100% - 28px); max-width:460px;
  background:var(--clay); color:#fff; text-align:center; font-weight:700; padding:16px;
  border-radius:999px; box-shadow:0 12px 30px -8px rgba(200,112,74,.6); }

/* ---------- Reveal animation ---------- */
.reveal{ opacity:0; transform:translateY(26px); transition:opacity .7s ease, transform .7s cubic-bezier(.2,.8,.2,1); }
.reveal.is-in{ opacity:1; transform:none; }
@media (prefers-reduced-motion: reduce){
  .reveal{ opacity:1; transform:none; transition:none; }
  .breath__ring,.breath__core,.hero__art-card,.marquee__track,.hero__scroll span{ animation:none !important; }
}

/* =========================================================
   Responsive
   ========================================================= */
@media (max-width:1024px){
  .pillars{ grid-template-columns:repeat(2,1fr); }
  .cards{ grid-template-columns:repeat(2,1fr); }
  .ladder{ grid-template-columns:repeat(2,1fr); }
  .ladder__step--goal{ grid-column:1 / -1; }
  .ba-grid{ grid-template-columns:repeat(2,1fr); }
}

@media (max-width:860px){
  .nav, .header__cta{ display:none; }
  .burger{ display:block; }
  .header.is-open .nav{
    display:flex; flex-direction:column; position:absolute; top:100%; left:0; right:0;
    background:var(--paper); padding:18px var(--gut) 26px; gap:4px; box-shadow:var(--shadow);
    border-top:1px solid var(--line);
  }
  .header.is-open .nav__link{ padding:12px; font-size:1.05rem; }

  .hero__inner{ grid-template-columns:1fr; }
  .hero__art{ order:-1; min-height:280px; }
  .hero__lead{ max-width:none; }
  .hero__scroll{ display:none; }
  .hero__bg-img{ opacity:.5; background-position:center top; }
  .hero__bg-img::after{ background:linear-gradient(180deg, rgba(246,239,226,.05) 0%, rgba(246,239,226,.45) 42%, var(--paper) 74%); }

  .check__grid{ grid-template-columns:1fr; }
  .check__result{ position:static; }

  .faq__inner{ grid-template-columns:1fr; }
  .faq .section__head{ position:static; }

  .author__inner{ grid-template-columns:1fr; }
  .author__photo{ max-width:340px; margin:0 auto; }

  .how__body{ grid-template-columns:1fr; max-width:520px; }
  .how__figure{ max-width:420px; margin:0 auto; }

  .pro__card{ grid-template-columns:1fr; }

  .experts__grid, .reviews__grid{ grid-template-columns:1fr; }

  .sticky-cta{ display:block; }
  body{ padding-bottom:84px; }
}

@media (max-width:760px){
  .curators__grid{ grid-template-columns:1fr; max-width:380px; }
}

@media (max-width:560px){
  .pillars, .cards, .ladder{ grid-template-columns:1fr; }
  .plans{ grid-template-columns:1fr; }
  .ba-grid{ grid-template-columns:1fr; }
  .ladder__step--goal{ grid-column:auto; }
  .footer__inner{ grid-template-columns:1fr; gap:28px; }
  .hero__trust{ gap:18px; }
  .hero__art-card{ display:none; }
  .chain__break{ flex-direction:column; text-align:center; }
  .author__inset{ width:40%; left:-10px; }
  .expert-card{ grid-template-columns:104px 1fr; gap:15px; padding:18px; }
}
