/* ============================================================
   AIDOLAB · Бери ИИ и делай
   Watercolour enchanted-forest aesthetic
   Palette drawn from the host portraits:
   lavender · sage/forest green · antique gold · soft sky blue
   ============================================================ */

:root{
  /* paper */
  --paper:        #f6f1e7;
  --paper-warm:   #f3ead9;
  --parchment:    #fbf6ec;

  /* ink */
  --ink:          #3b3450;   /* deep violet-grey */
  --ink-soft:     #524b66;   /* AA on paper */
  --ink-faint:    #6b6480;   /* AA on paper */

  /* watercolour hues */
  --violet:       #9a7fc4;
  --violet-deep:  #6f549e;
  --lilac:        #c4b0dd;
  --sage:         #7fa67f;
  --green-deep:   #4f7257;   /* slightly deeper for text contrast */
  --gold:         #c89a3c;   /* decorative / gradient stops */
  --gold-deep:    #a87c22;   /* decorative / gradient stops */
  --gold-text:    #876211;   /* AA gold for small label text */
  --sky:          #7fa9d4;
  --rose:         #d39bb0;

  --line:         rgba(111, 84, 158, .18);
  --line-gold:    rgba(168, 124, 34, .35);

  --shadow-soft:  0 18px 50px -22px rgba(80, 60, 120, .45);
  --shadow-card:  0 24px 60px -28px rgba(70, 55, 110, .5);

  --radius:       22px;
  --radius-lg:    30px;

  --maxw:         1160px;

  --font-display: "Cormorant Garamond", Georgia, serif;
  --font-deco:    "Marcellus", Georgia, serif;
  --font-body:    "Manrope", system-ui, sans-serif;
  --font-hand:    "Caveat", cursive;
}

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

html{ scroll-behavior:smooth; scroll-padding-top:84px; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }

/* Visible keyboard focus for all interactive elements */
:focus-visible{ outline:2.5px solid var(--violet-deep); outline-offset:3px; border-radius:4px; }
a:focus-visible, .btn:focus-visible, summary:focus-visible{ outline-offset:4px; }
/* Older browsers that lack :focus-visible still get a focus ring */
@supports not selector(:focus-visible){
  a:focus, .btn:focus, summary:focus, button:focus{ outline:2.5px solid var(--violet-deep); outline-offset:3px; }
}

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

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

/* ============================================================
   Atmosphere — layered watercolour washes + paper grain
   ============================================================ */
.atmosphere{
  position:fixed; inset:0; z-index:-2; overflow:hidden;
  background:
    radial-gradient(120% 80% at 50% -10%, #efe7fb 0%, rgba(239,231,251,0) 55%),
    linear-gradient(180deg, #f7f2ea 0%, #f1ead9 40%, #eef1e8 70%, #f5eee0 100%);
}
/* Мягкость «акварели» зашита в сами градиенты — без filter:blur и blend-mode,
   чтобы фон не пересобирался каждый кадр (это давало ~30 FPS на скролле) */
.wash{ position:absolute; border-radius:50%; opacity:.6; will-change:transform; }
.wash--1{
  width:60vw; height:60vw; left:-15vw; top:-10vh;
  background:radial-gradient(circle at 40% 40%, rgba(196,176,221,.75) 0%, rgba(196,176,221,.35) 35%, rgba(196,176,221,0) 72%);
  animation:drift1 26s ease-in-out infinite alternate;
}
.wash--2{
  width:55vw; height:55vw; right:-18vw; top:25vh;
  background:radial-gradient(circle at 50% 50%, rgba(183,211,176,.7) 0%, rgba(183,211,176,.32) 35%, rgba(183,211,176,0) 72%);
  animation:drift2 32s ease-in-out infinite alternate;
}
.wash--3{
  width:50vw; height:50vw; left:10vw; bottom:-15vh;
  background:radial-gradient(circle at 50% 50%, rgba(231,207,154,.6) 0%, rgba(231,207,154,.28) 35%, rgba(231,207,154,0) 74%);
  opacity:.45;
  animation:drift3 38s ease-in-out infinite alternate;
}
@keyframes drift1{ to{ transform:translate(6vw,5vh) scale(1.12); } }
@keyframes drift2{ to{ transform:translate(-5vw,-4vh) scale(1.15); } }
@keyframes drift3{ to{ transform:translate(4vw,-6vh) scale(1.1); } }

.grain{
  position:absolute; inset:0; opacity:.22;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.4'/%3E%3C/svg%3E");
}

/* fireflies */
.fireflies{ position:absolute; inset:0; }
.firefly{
  position:absolute; width:6px; height:6px; border-radius:50%;
  background:radial-gradient(circle, rgba(255,244,200,.95), rgba(255,228,150,0) 70%);
  animation:floatUp linear infinite;
}
@keyframes floatUp{
  0%{ transform:translateY(0) scale(.6); opacity:0; }
  15%{ opacity:1; }
  85%{ opacity:.9; }
  100%{ transform:translateY(-115vh) scale(1.1); opacity:0; }
}
@media (prefers-reduced-motion: reduce){
  .wash,.firefly{ animation:none !important; }
}

/* ============================================================
   Typography helpers
   ============================================================ */
h1,h2,h3,h4{ font-family:var(--font-display); font-weight:600; line-height:1.12; margin:0; color:var(--ink); }
h2{ font-size:clamp(2rem, 1.4rem + 2.4vw, 3.2rem); letter-spacing:.01em; }
h3{ font-size:clamp(1.4rem, 2.2vw, 1.9rem); }
p{ margin:0 0 1em; }

.kicker{
  display:inline-block;
  font-family:var(--font-body);
  font-weight:700; font-size:.72rem; letter-spacing:.28em; text-transform:uppercase;
  color:var(--violet-deep);
  padding-bottom:.4rem; position:relative; margin-bottom:.4rem;
}
.kicker::after{
  content:"✦"; margin-left:.6em; color:var(--gold); letter-spacing:0;
}
.kicker--gold{ color:var(--gold-text); }

.section{ max-width:var(--maxw); margin:0 auto; padding:clamp(3.5rem,7vw,6.5rem) clamp(1.2rem,5vw,2.5rem); }
.section__head{ text-align:center; max-width:760px; margin:0 auto clamp(2rem,4vw,3.2rem); }
.section__head--left{ text-align:left; margin-left:0; }
.section__sub{ color:var(--ink-soft); font-size:1.08rem; margin-top:.9rem; }

/* ============================================================
   Buttons
   ============================================================ */
.btn{
  --c1:var(--violet); --c2:var(--violet-deep);
  display:inline-flex; align-items:center; justify-content:center; gap:.5em;
  font-family:var(--font-body); font-weight:700; font-size:1rem;
  color:#fff; text-align:center;
  padding:.85em 1.7em; border-radius:999px; border:none; cursor:pointer;
  background:linear-gradient(135deg, var(--c1), var(--c2));
  box-shadow:0 12px 28px -12px rgba(111,84,158,.8), inset 0 1px 0 rgba(255,255,255,.25);
  transition:transform .25s ease, box-shadow .25s ease, filter .25s ease;
}
.btn:hover{ transform:translateY(-2px); box-shadow:0 18px 36px -14px rgba(111,84,158,.9); filter:saturate(1.08); }
.btn:active{ transform:translateY(0); }
.btn--ghost{
  background:transparent; color:var(--violet-deep);
  border:1.5px solid var(--line-gold);
  box-shadow:none;
}
.btn--ghost:hover{ background:rgba(255,255,255,.5); box-shadow:var(--shadow-soft); }
.btn--small{ padding:.6em 1.2em; font-size:.9rem; }
.btn--full{ width:100%; padding:1em; font-size:1.05rem; }

/* ============================================================
   Navigation
   ============================================================ */
.nav{
  position:sticky; top:0; z-index:50;
  display:flex; align-items:center; gap:1.5rem;
  max-width:var(--maxw); margin:0 auto;
  padding:.85rem clamp(1.2rem,5vw,2.5rem);
}
/* Блюр включается только у «прилипшей» шапки — узкая полоса, дёшево для GPU */
.nav.is-stuck::before{
  -webkit-backdrop-filter:blur(8px);
  backdrop-filter:blur(8px);
}
.nav::before{
  content:""; position:absolute; inset:0; z-index:-1;
  background:rgba(247,242,234,.88);
  border-bottom:1px solid var(--line);
  opacity:0; transition:opacity .3s ease;
}
.nav.is-stuck::before{ opacity:1; }
.nav__brand{ display:flex; align-items:center; gap:.5rem; font-family:var(--font-deco); font-size:1.35rem; letter-spacing:.06em; }
.nav__sigil{ color:var(--gold); }
.nav__name{ color:var(--ink); }
.nav__links{ display:flex; gap:1.6rem; margin-left:auto; font-weight:600; font-size:.95rem; }
.nav__links a{ color:var(--ink-soft); position:relative; padding:.2em 0; }
.nav__links a::after{
  content:""; position:absolute; left:0; bottom:-2px; width:0; height:2px;
  background:linear-gradient(90deg,var(--violet),var(--gold)); transition:width .25s ease;
}
.nav__links a:hover{ color:var(--ink); }
.nav__links a:hover::after{ width:100%; }
.nav .btn{ margin-left:.4rem; }

.nav__burger{ display:none; flex-direction:column; justify-content:center; align-items:center; gap:5px; background:none; border:none; cursor:pointer; width:44px; height:44px; padding:10px; margin-left:auto; }
.nav__burger span{ width:24px; height:2px; background:var(--ink); border-radius:2px; transition:.3s; }
.nav__burger[aria-expanded="true"] span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.nav__burger[aria-expanded="true"] span:nth-child(2){ opacity:0; }
.nav__burger[aria-expanded="true"] span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

/* ============================================================
   Hero
   ============================================================ */
.hero{
  position:relative;
  max-width:var(--maxw); margin:0 auto;
  padding:clamp(3rem,8vw,6rem) clamp(1.2rem,5vw,2.5rem) clamp(4rem,9vw,7rem);
  text-align:center;
}
.hero__frame{
  position:relative;
  max-width:880px; margin:0 auto;
  padding:clamp(2.2rem,5vw,4rem) clamp(1.4rem,5vw,3.5rem);
}
/* ornamental watercolour frame */
.hero__frame::before{
  content:""; position:absolute; inset:0; z-index:-1;
  background:rgba(251,246,236,.55);
  border:1.5px solid var(--line-gold);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-soft), inset 0 0 60px rgba(196,176,221,.25);
}
.hero__frame::after{
  content:""; position:absolute; inset:10px; z-index:-1;
  border:1px solid rgba(168,124,34,.25); border-radius:calc(var(--radius-lg) - 8px);
  pointer-events:none;
}
.hero__badge{
  display:inline-block;
  font-family:var(--font-body); font-weight:700; font-size:.78rem; letter-spacing:.18em;
  text-transform:uppercase; color:var(--violet-deep);
  background:rgba(154,127,196,.14); border:1px solid var(--line-gold);
  padding:.55em 1.2em; border-radius:999px; margin:0 0 1.4rem;
}
.hero__title{
  display:flex; flex-direction:column; align-items:center; gap:.4rem;
  margin:.2rem 0 1.3rem;
}
.hero__line--display{
  font-family:var(--font-display); font-weight:700; line-height:.98;
  font-size:clamp(2.6rem, 1.6rem + 5vw, 5.6rem);
  color:var(--violet-deep); /* fallback if background-clip:text unsupported */
  background:linear-gradient(135deg, var(--violet-deep), var(--green-deep) 55%, var(--gold-deep));
  -webkit-background-clip:text; background-clip:text;
  -webkit-text-fill-color:transparent;
  overflow-wrap:anywhere;
}
.hero__line--sub{
  font-family:var(--font-display); font-weight:500; font-style:italic;
  font-size:clamp(1.3rem, 3.2vw, 2.1rem); color:var(--ink-soft);
}
.hero__lede{
  max-width:680px; margin:0 auto 1.8rem; font-size:1.12rem; color:var(--ink-soft);
}
.hero__bullets{
  list-style:none; margin:0 auto 2rem; padding:0; max-width:760px;
  display:flex; flex-wrap:wrap; justify-content:center; gap:.7rem;
}
.hero__bullets li{
  position:relative; font-weight:600; font-size:.92rem; color:var(--ink);
  background:rgba(255,255,255,.55); border:1px solid var(--line);
  padding:.55em 1em .55em 2em; border-radius:999px; box-shadow:var(--shadow-soft);
}
.hero__bullets li::before{ content:"✦"; position:absolute; left:.85em; color:var(--gold); }
.hero__cta{ display:flex; gap:1rem; justify-content:center; flex-wrap:wrap; margin-bottom:1.6rem; }
.hero__meta{
  margin:0; font-weight:600; font-size:.92rem; color:var(--green-deep);
  letter-spacing:.01em;
}

/* ============================================================
   Case — what is a case
   ============================================================ */
.case__definition{
  font-family:var(--font-display); font-size:clamp(1.4rem,2.8vw,2rem); line-height:1.3;
  color:var(--ink); max-width:720px; margin:1rem auto 0;
}
.case__subtitle{
  text-align:center; font-size:1.5rem; color:var(--violet-deep);
  margin:0 0 1.6rem;
}
.cases{
  display:grid; gap:clamp(1rem,2.2vw,1.4rem);
  grid-template-columns:repeat(auto-fill, minmax(min(240px,100%),1fr));
}
.case-card{
  background:rgba(255,255,255,.6); border:1px solid var(--line);
  border-radius:18px; padding:1.5rem 1.5rem 1.6rem;
  box-shadow:var(--shadow-soft);
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.case-card:hover{ transform:translateY(-4px); box-shadow:var(--shadow-card); border-color:var(--line-gold); }
.case-card__icon{
  display:inline-grid; place-items:center; width:40px; height:40px; margin-bottom:.8rem;
  font-size:1.1rem; color:#fff; border-radius:12px;
  background:linear-gradient(135deg,var(--violet),var(--green-deep));
  box-shadow:0 8px 18px -8px rgba(111,84,158,.7);
}
.case-card h4{ font-family:var(--font-display); font-size:1.3rem; margin:0 0 .5rem; }
.case-card p{ margin:0; font-size:.97rem; color:var(--ink-soft); }
.case__progress{
  max-width:820px; margin:2.6rem auto 0; text-align:center;
  font-size:1.08rem; color:var(--ink-soft);
}
.highlight{
  max-width:760px; margin:2rem auto 0; text-align:center;
  font-family:var(--font-display); font-size:clamp(1.25rem,2.4vw,1.6rem); line-height:1.35;
  color:var(--ink); font-style:italic;
  background:
    radial-gradient(120% 140% at 0% 0%, rgba(231,207,154,.3), transparent 55%),
    radial-gradient(120% 140% at 100% 100%, rgba(154,127,196,.28), transparent 55%),
    rgba(251,246,236,.85);
  border:1.5px solid var(--line-gold); border-radius:var(--radius-lg);
  padding:clamp(1.4rem,3vw,2rem) clamp(1.4rem,4vw,2.6rem);
  box-shadow:var(--shadow-soft);
}

/* ============================================================
   Program / modules (collapsible)
   ============================================================ */
.module{
  position:relative;
  background:rgba(251,246,236,.6);
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  margin-bottom:1.4rem;
  box-shadow:var(--shadow-soft);
  overflow:hidden;
}
.module::before{
  content:""; position:absolute; left:0; top:0; bottom:0; width:6px; z-index:1;
  background:linear-gradient(var(--violet),var(--green-deep));
}
.module[data-accent="green"]::before{ background:linear-gradient(var(--sage),var(--green-deep)); }
.module[data-accent="gold"]::before{ background:linear-gradient(var(--gold),var(--gold-deep)); }
.module[data-accent="violet"]::before{ background:linear-gradient(var(--lilac),var(--violet-deep)); }

.module__head{
  position:relative; display:block; cursor:pointer; list-style:none;
  padding:clamp(1.4rem,3.2vw,2.2rem) clamp(3rem,5vw,3.6rem) clamp(1.4rem,3.2vw,2.2rem) clamp(1.6rem,4vw,2.6rem);
  transition:background .25s ease;
}
.module__head::-webkit-details-marker{ display:none; }
.module__head:hover{ background:rgba(255,255,255,.35); }
.module__head--static{ cursor:default; }
.module__head--static:hover{ background:none; }
.module__heading{ display:flex; align-items:center; gap:.9rem; flex-wrap:wrap; margin-bottom:.5rem; }
.module__num{
  font-family:var(--font-deco); font-size:1rem; letter-spacing:.04em; color:#fff;
  background:linear-gradient(135deg,var(--violet),var(--violet-deep));
  padding:.2em .7em; border-radius:8px;
}
.module[data-accent="green"] .module__num{ background:linear-gradient(135deg,var(--sage),var(--green-deep)); }
.module[data-accent="gold"] .module__num{ background:linear-gradient(135deg,var(--gold),var(--gold-deep)); }
.module__meta{
  font-family:var(--font-body); font-weight:700; font-size:.75rem; letter-spacing:.14em;
  text-transform:uppercase; color:var(--gold-text);
}
.module__head h3{ margin:.2rem 0 .6rem; color:var(--ink); max-width:780px; }
.module__head p{ color:var(--ink-soft); margin:0; max-width:820px; }
.module__toggle{
  position:absolute; right:clamp(1.2rem,3vw,2rem); top:clamp(1.6rem,3.4vw,2.4rem);
  width:26px; height:26px;
}
.module__toggle::before,.module__toggle::after{
  content:""; position:absolute; top:50%; left:50%; background:var(--violet-deep);
  border-radius:2px; transform:translate(-50%,-50%); transition:transform .3s ease, opacity .3s ease;
}
.module__toggle::before{ width:14px; height:2px; }
.module__toggle::after{ width:2px; height:14px; }
.module[open] .module__toggle::after{ transform:translate(-50%,-50%) scaleY(0); opacity:0; }

.module__body{
  padding:0 clamp(1.6rem,4vw,2.6rem) clamp(1.6rem,3.5vw,2.4rem);
  animation:moduleReveal .4s ease;
}
@keyframes moduleReveal{ from{ opacity:0; transform:translateY(-6px); } to{ opacity:1; transform:none; } }
@media (prefers-reduced-motion: reduce){ .module__body{ animation:none; } }

.lessons{ list-style:none; margin:0 0 1.4rem; padding:0; display:grid; gap:1rem; grid-template-columns:repeat(auto-fill, minmax(min(240px,100%),1fr)); }
.lesson{
  background:rgba(255,255,255,.6);
  border:1px solid var(--line);
  border-radius:18px; padding:1.3rem 1.4rem;
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.lesson:hover{ transform:translateY(-4px); box-shadow:var(--shadow-card); border-color:var(--line-gold); }
.lesson__top{ display:flex; align-items:flex-start; gap:.7rem; margin-bottom:.6rem; }
.lesson__n{
  flex:none; display:grid; place-items:center; width:34px; height:34px;
  font-family:var(--font-deco); color:#fff; border-radius:10px;
  background:linear-gradient(135deg,var(--violet),var(--violet-deep));
  box-shadow:0 6px 14px -6px rgba(111,84,158,.7);
}
.module[data-accent="green"] .lesson__n{ background:linear-gradient(135deg,var(--sage),var(--green-deep)); }
.module[data-accent="gold"] .lesson__n{ background:linear-gradient(135deg,var(--gold),var(--gold-deep)); }
.lesson__top h4{ font-family:var(--font-display); font-size:1.18rem; line-height:1.2; margin:.15rem 0 0; }
.lesson p{ font-size:.96rem; color:var(--ink-soft); margin:0 0 .9rem; }
.deliverable{
  margin:0; font-size:1rem; color:var(--ink);
  background:rgba(154,127,196,.1); border:1px solid var(--line-gold);
  border-radius:14px; padding:1rem 1.3rem;
}
.deliverable strong{ color:var(--gold-text); }
.module--final{ text-align:center; border-style:dashed; }
.module--final .module__head{ margin-inline:auto; }
.module--final .module__heading{ justify-content:center; }
.program__cta{ text-align:center; margin-top:2rem; }

/* ============================================================
   Hosts
   ============================================================ */
.hosts__grid{ display:grid; gap:clamp(1.4rem,3vw,2.2rem); grid-template-columns:repeat(auto-fit,minmax(min(240px,100%),1fr)); }
.host{
  margin:0; background:rgba(251,246,236,.65);
  border:1px solid var(--line-gold); border-radius:var(--radius-lg);
  overflow:hidden; box-shadow:var(--shadow-card);
  transition:transform .3s ease, box-shadow .3s ease;
}
.host:hover{ transform:translateY(-6px); box-shadow:0 32px 70px -28px rgba(70,55,110,.6); }
.host__portrait{ position:relative; aspect-ratio:1/1; overflow:hidden; }
.host__portrait img{ width:100%; height:100%; object-fit:cover; transition:transform .6s ease; }
.host:hover .host__portrait img{ transform:scale(1.05); }
.host__portrait::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, transparent 55%, rgba(59,52,80,.28));
  pointer-events:none;
}
.host figcaption{ padding:1.4rem 1.5rem 1.7rem; }
.host__name{ font-size:1.6rem; margin:0 0 .2rem; }
.host__role{
  display:block; font-family:var(--font-body); font-weight:700; font-size:.8rem;
  letter-spacing:.08em; text-transform:uppercase; color:var(--gold-text); margin-bottom:.8rem;
}
.host figcaption p{ font-size:.96rem; color:var(--ink-soft); margin:0; }

/* ============================================================
   Audience
   ============================================================ */

/* ============================================================
   Audience / fit
   ============================================================ */
.audience__cols{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(1.2rem,3vw,1.8rem); }
.fit-card{
  border-radius:var(--radius-lg); padding:clamp(1.5rem,3.5vw,2.4rem);
  box-shadow:var(--shadow-soft); border:1px solid var(--line);
  background:rgba(251,246,236,.7);
}
.fit-card--yes{ border-color:rgba(79,114,87,.4); background:linear-gradient(160deg, rgba(127,166,127,.14), rgba(251,246,236,.85)); }
.fit-card--no{ border-style:dashed; background:linear-gradient(160deg, rgba(211,155,176,.12), rgba(251,246,236,.85)); }
.fit-card h3{ display:flex; align-items:center; gap:.6rem; font-size:1.35rem; margin:0 0 1.1rem; }
.fit-mark{
  flex:none; display:grid; place-items:center; width:30px; height:30px; border-radius:50%;
  font-size:.95rem; font-weight:800; color:#fff;
}
.fit-card--yes .fit-mark{ background:linear-gradient(135deg,var(--sage),var(--green-deep)); }
.fit-card--no .fit-mark{ background:linear-gradient(135deg,#d39bb0,#b25a6e); }
.fit-card ul{ list-style:none; margin:0; padding:0; display:grid; gap:.85rem; }
.fit-card li{ position:relative; padding-left:1.6rem; color:var(--ink); font-size:.98rem; }
.fit-card--yes li::before{ content:"✓"; position:absolute; left:0; color:var(--green-deep); font-weight:800; }
.fit-card--no li::before{ content:"✕"; position:absolute; left:0; color:#b25a6e; font-weight:800; }

/* ============================================================
   Outcomes
   ============================================================ */
.outcomes__card{
  background:
    radial-gradient(120% 120% at 0% 0%, rgba(231,207,154,.22), transparent 55%),
    radial-gradient(120% 120% at 100% 100%, rgba(196,176,221,.22), transparent 55%),
    rgba(251,246,236,.82);
  border:1px solid var(--line-gold); border-radius:var(--radius-lg);
  padding:clamp(1.8rem,4vw,3rem); box-shadow:var(--shadow-card);
}
.outcomes__card .section__head{ margin:0 0 1.8rem; }
.outcomes__list{
  list-style:none; margin:0; padding:0;
  display:grid; grid-template-columns:repeat(auto-fit, minmax(min(260px,100%),1fr)); gap:1.1rem 1.6rem;
}
.outcomes__list li{ display:flex; gap:.8rem; align-items:flex-start; }
.outcomes__list li > span{ color:var(--gold); font-size:1.05rem; line-height:1.5; flex:none; }
.outcomes__list strong{ display:block; font-family:var(--font-display); font-size:1.2rem; color:var(--ink); }
.outcomes__list p{ margin:.15rem 0 0; font-size:.95rem; color:var(--ink-soft); }

/* ============================================================
   Guarantee
   ============================================================ */
.guarantee{
  display:flex; align-items:center; gap:1.4rem; margin-top:clamp(1.4rem,3vw,2rem);
  background:rgba(251,246,236,.75); border:1px solid var(--line-gold); border-radius:var(--radius-lg);
  padding:clamp(1.4rem,3vw,2rem) clamp(1.5rem,4vw,2.4rem); box-shadow:var(--shadow-soft);
}
.guarantee__icon{ font-size:2.4rem; flex:none; line-height:1; }
.guarantee h3{ font-size:1.4rem; margin:0 0 .4rem; }
.guarantee p{ margin:0; color:var(--ink-soft); font-size:1rem; }

/* ============================================================
   FAQ
   ============================================================ */
.faq__list{ max-width:820px; margin:0 auto; display:flex; flex-direction:column; gap:.9rem; }
.faq-item{
  background:rgba(251,246,236,.7); border:1px solid var(--line);
  border-radius:18px; overflow:hidden; box-shadow:var(--shadow-soft);
  transition:border-color .25s ease;
}
.faq-item[open]{ border-color:var(--line-gold); }
.faq-q{
  position:relative; display:flex; align-items:center; justify-content:space-between; gap:1rem;
  list-style:none; cursor:pointer;
  font-family:var(--font-display); font-size:clamp(1.15rem,2vw,1.45rem); font-weight:600; color:var(--ink);
  padding:1.2rem 1.5rem; transition:background .2s ease;
}
.faq-q::-webkit-details-marker{ display:none; }
.faq-q:hover{ background:rgba(255,255,255,.4); }
.faq-item[open] .faq-q{ color:var(--violet-deep); }
.faq-toggle{ position:relative; flex:none; width:24px; height:24px; }
.faq-toggle::before,.faq-toggle::after{
  content:""; position:absolute; top:50%; left:50%; background:var(--violet-deep);
  border-radius:2px; transform:translate(-50%,-50%); transition:transform .3s ease, opacity .3s ease;
}
.faq-toggle::before{ width:14px; height:2px; }
.faq-toggle::after{ width:2px; height:14px; }
.faq-item[open] .faq-toggle::after{ transform:translate(-50%,-50%) rotate(90deg); opacity:0; }
.faq-a{ padding:0 1.5rem 1.4rem; color:var(--ink-soft); font-size:1rem; line-height:1.65; }
.faq-a strong{ color:var(--gold-text); }

/* ============================================================
   Pricing + Enroll
   ============================================================ */
.pricing__grid{ display:grid; grid-template-columns:.85fr 1.15fr; gap:clamp(1.4rem,3vw,2.2rem); align-items:stretch; }
.price-card{
  display:flex; flex-direction:column;
  background:linear-gradient(160deg, rgba(111,84,158,.96), rgba(85,122,94,.94));
  color:#fff; border-radius:var(--radius-lg); padding:clamp(1.8rem,4vw,2.6rem);
  box-shadow:var(--shadow-card);
}
.price-card .kicker{ color:#f3d68a; }
.price-card__title{ color:#fff; font-size:1.7rem; margin:.3rem 0 .6rem; }
.price-card__amount{
  font-family:var(--font-display); font-weight:700; font-size:clamp(2.6rem, 1.8rem + 3vw, 3.6rem);
  line-height:1; margin:.4rem 0 .3rem; color:#fff;
}
.price-card__perunit{ margin:0 0 1.2rem; font-size:.88rem; color:rgba(255,255,255,.85); }
.price-card__list{ list-style:none; margin:0 0 1.2rem; padding:0; display:grid; gap:.7rem; }
.price-card__list li{ position:relative; padding-left:1.7rem; color:rgba(255,255,255,.96); font-size:.97rem; }
.price-card__list li::before{ content:"✦"; position:absolute; left:0; color:#f3d68a; }
.price-card__note{
  margin:0 0 1.2rem; font-size:.85rem; color:rgba(255,255,255,.88);
  padding:.8rem 1rem; background:rgba(255,255,255,.1); border-radius:12px;
}
.price-card__meta{ margin:auto 0 0; font-weight:600; font-size:.9rem; color:rgba(255,255,255,.9); }

.enroll__card{
  text-align:left;
  background:
    radial-gradient(120% 120% at 0% 0%, rgba(231,207,154,.3), transparent 55%),
    radial-gradient(120% 120% at 100% 100%, rgba(154,127,196,.3), transparent 55%),
    rgba(251,246,236,.9);
  border:1.5px solid var(--line-gold); border-radius:var(--radius-lg);
  padding:clamp(2rem,5vw,3.5rem);
  box-shadow:var(--shadow-card);
}
.enroll__card h2{ margin:.4rem 0 .8rem; }
.enroll__brand{
  font-weight:700;
  color:var(--violet-deep); /* fallback if background-clip:text unsupported */
  background:linear-gradient(135deg, var(--violet-deep), var(--green-deep) 55%, var(--gold-deep));
  -webkit-background-clip:text; background-clip:text;
  -webkit-text-fill-color:transparent;
}
.enroll__amp{
  font-family:var(--font-deco); font-size:.75em; color:var(--gold);
  -webkit-text-fill-color:var(--gold);
}
@media (forced-colors: active){
  .enroll__brand, .enroll__amp{ -webkit-text-fill-color:currentColor; color:CanvasText; }
}
.enroll__card > p{ color:var(--ink-soft); margin:0 0 1rem; }
.enroll__scarcity{
  margin:0 0 1.6rem; font-weight:600; font-size:.9rem; color:var(--green-deep);
}
.enroll__dot{
  display:inline-block; vertical-align:middle; margin-right:.5rem;
  width:9px; height:9px; border-radius:50%; background:#5fae6e;
  box-shadow:0 0 0 0 rgba(95,174,110,.6); animation:pulseDot 2s ease-out infinite;
}
@keyframes pulseDot{ 0%{ box-shadow:0 0 0 0 rgba(95,174,110,.55); } 70%{ box-shadow:0 0 0 8px rgba(95,174,110,0); } 100%{ box-shadow:0 0 0 0 rgba(95,174,110,0); } }
@media (prefers-reduced-motion: reduce){ .enroll__dot{ animation:none; } }
.enroll__hint{ margin:.8rem 0 0; font-size:.82rem; color:var(--ink-faint); text-align:center; }
.enroll__steps{
  margin:0 0 1.4rem; padding:0; list-style:none; counter-reset:step; display:grid; gap:.7rem;
}
.enroll__steps li{
  position:relative; padding-left:2.4rem; color:var(--ink); font-size:.97rem;
  min-height:1.7rem; line-height:1.4; display:block;
}
.enroll__steps li::before{
  counter-increment:step; content:counter(step);
  position:absolute; left:0; top:0; width:1.7rem; height:1.7rem; border-radius:50%;
  display:grid; place-items:center; font-family:var(--font-deco); font-size:.85rem; color:#fff;
  background:linear-gradient(135deg,var(--violet),var(--violet-deep));
}
/* Telegram CTA button */
.btn--tg{ --c1:#2aabee; --c2:#229ed9; }
.btn__tg-icon{ font-size:1.15em; transform:translateY(-1px); }

/* ============================================================
   Footer
   ============================================================ */
.footer{
  border-top:1px solid var(--line);
  background:rgba(247,242,234,.6);
  margin-top:2rem;
}
.footer__inner{
  max-width:var(--maxw); margin:0 auto;
  padding:clamp(2.2rem,5vw,3.2rem) clamp(1.2rem,5vw,2.5rem) 1.5rem;
  display:flex; justify-content:space-between; gap:2rem; flex-wrap:wrap;
}
.footer__brand{ max-width:340px; }
.footer__brand .nav__name{ font-family:var(--font-deco); font-size:1.3rem; }
.footer__brand .nav__sigil{ font-size:1.2rem; }
.footer__brand p{ margin:.6rem 0 0; color:var(--ink-soft); font-size:.95rem; }
.footer__nav{ display:flex; flex-direction:column; gap:.5rem; font-weight:600; color:var(--ink-soft); }
.footer__nav a:hover{ color:var(--ink); }
.footer__copy{ text-align:center; color:var(--ink-faint); font-size:.85rem; padding:1rem 0 1.6rem; margin:0; }

/* ============================================================
   Reveal on scroll
   ============================================================ */
.reveal{ opacity:0; transform:translateY(28px); transition:opacity .7s ease, transform .7s ease; }
.reveal.is-in{ opacity:1; transform:none; }
@media (prefers-reduced-motion: reduce){
  .reveal{ opacity:1 !important; transform:none !important; }
}

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width:860px){
  .pricing__grid{ grid-template-columns:1fr; }
  .nav__links{ display:none; }
  .nav .btn--small{ display:none; }
  .nav__burger{ display:flex; }
  .nav__links.is-open{
    display:flex; flex-direction:column; gap:.4rem;
    position:absolute; top:100%; left:0; right:0;
    background:rgba(247,242,234,.97); -webkit-backdrop-filter:blur(12px); backdrop-filter:blur(12px); z-index:60;
    padding:1rem clamp(1.2rem,5vw,2.5rem); border-bottom:1px solid var(--line);
    box-shadow:var(--shadow-soft);
  }
  .nav__links.is-open a{ padding:.7em 0; min-height:44px; display:flex; align-items:center; }
}
@media (max-width:560px){
  .audience__cols{ grid-template-columns:1fr; }
}

/* Forced-colors / Windows High Contrast — keep the gradient title visible */
@media (forced-colors: active){
  .hero__line--display{ -webkit-text-fill-color:currentColor; color:CanvasText; }
}

/* ============================================================
   Interactive polish — motion & micro-interactions
   (вся анимация уважает prefers-reduced-motion)
   ============================================================ */

/* Прогресс чтения — золотая нить под шапкой */
.scroll-progress{
  position:fixed; top:0; left:0; height:3px; width:100%; z-index:80;
  transform-origin:0 50%; transform:scaleX(0);
  background:linear-gradient(90deg, var(--violet), var(--gold), var(--green-deep));
  pointer-events:none;
}

/* Активный раздел в навигации (scrollspy) */
.nav__links a.is-active{ color:var(--ink); }
.nav__links a.is-active::after{ width:100%; }

/* Появление hero — поэтапная хореография */
@keyframes riseIn{ from{ opacity:0; transform:translateY(22px); } to{ opacity:1; transform:none; } }
@keyframes inkFlow{ from{ background-position:0% 50%; } to{ background-position:100% 50%; } }
@media (prefers-reduced-motion: no-preference){
  .hero__badge,.hero__line--sub,.hero__lede,.hero__bullets li,.hero__cta,.hero__meta{
    opacity:0; animation:riseIn .8s cubic-bezier(.22,.8,.3,1) forwards;
  }
  .hero__badge{ animation-delay:.08s; }
  .hero__line--sub{ animation-delay:.42s; }
  .hero__lede{ animation-delay:.56s; }
  .hero__bullets li:nth-child(1){ animation-delay:.70s; }
  .hero__bullets li:nth-child(2){ animation-delay:.78s; }
  .hero__bullets li:nth-child(3){ animation-delay:.86s; }
  .hero__bullets li:nth-child(4){ animation-delay:.94s; }
  .hero__bullets li:nth-child(5){ animation-delay:1.02s; }
  .hero__cta{ animation-delay:1.12s; }
  .hero__meta{ animation-delay:1.26s; }
  /* заголовок: вход + «живые» акварельные переливы градиента */
  .hero__line--display{
    opacity:0; background-size:220% 220%;
    animation:riseIn .9s cubic-bezier(.22,.8,.3,1) .22s forwards,
              inkFlow 9s ease-in-out 1.4s infinite alternate;
  }
  .enroll__brand{ background-size:220% 220%; animation:inkFlow 9s ease-in-out infinite alternate; }
}

/* Кнопки: шиммер при наведении + отклик нажатия */
.btn{ position:relative; overflow:hidden; }
.btn::after{
  content:""; position:absolute; inset:0; pointer-events:none;
  background:linear-gradient(110deg, transparent 32%, rgba(255,255,255,.38) 50%, transparent 68%);
  transform:translateX(-130%);
}
.btn--ghost::after{
  background:linear-gradient(110deg, transparent 32%, rgba(168,124,34,.16) 50%, transparent 68%);
}
@media (prefers-reduced-motion: no-preference){
  .btn:hover::after{ animation:sheen .9s ease; }
}
@keyframes sheen{ to{ transform:translateX(130%); } }
.btn:active{ transform:translateY(0) scale(.97); }

/* 3D-наклон карточек с бликом, следящим за курсором (класс вешает JS) */
.tilt{ --gx:50%; --gy:50%; position:relative; will-change:transform; }
.tilt::after{
  content:""; position:absolute; inset:0; border-radius:inherit; z-index:2; pointer-events:none;
  background:radial-gradient(420px circle at var(--gx) var(--gy), rgba(255,255,255,.28), transparent 62%);
  opacity:0; transition:opacity .35s ease;
}
.tilt:hover::after{ opacity:1; }

/* Каскад уроков при раскрытии модуля */
@media (prefers-reduced-motion: no-preference){
  details[open] .lesson{ animation:riseIn .45s cubic-bezier(.22,.8,.3,1) both; }
  details[open] .lesson:nth-child(1){ animation-delay:.04s; }
  details[open] .lesson:nth-child(2){ animation-delay:.11s; }
  details[open] .lesson:nth-child(3){ animation-delay:.18s; }
  details[open] .lesson:nth-child(4){ animation-delay:.25s; }
  details[open] .lesson:nth-child(5){ animation-delay:.32s; }
}

/* Каскад reveal-карточек (задержку выставляет JS) */
.reveal{ transition-delay:var(--rd, 0ms); }

/* Кнопка «наверх» */
.to-top{
  position:fixed; right:clamp(1rem,3vw,2rem); bottom:clamp(1rem,3vw,2rem); z-index:70;
  width:52px; height:52px; border-radius:50%; border:1.5px solid var(--line-gold);
  background:rgba(251,246,236,.92); color:var(--violet-deep); font-size:1.25rem; cursor:pointer;
  box-shadow:var(--shadow-card); display:grid; place-items:center;
  opacity:0; transform:translateY(14px); pointer-events:none;
  transition:opacity .3s ease, transform .3s ease, background .2s ease;
}
.to-top.is-show{ opacity:1; transform:none; pointer-events:auto; }
.to-top:hover{ background:#fff; transform:translateY(-3px); }

/* Искры по клику на кнопки */
.spark{
  position:fixed; z-index:90; pointer-events:none; color:var(--gold);
  font-size:13px; line-height:1; will-change:transform,opacity;
}
