/* ═══════════════════════════════════════════════════
   Lisovska School — «Палітра професії»
   editorial · cream + espresso + 6 dozed accents
   ═══════════════════════════════════════════════════ */

:root{
  --cream:#E6E2D6;
  --cream-lite:#F3EFE7;
  --ink:#1A181A;
  --espresso:#1A0F0A;
  --beige:#C2BCA9;
  --bordo:#450000;
  --navy:#132846;
  --sky:#8AA2BD;
  --forest:#1F2A22;
  --olive:#767564;
  --sand:#CCBF83;
  --ff-d:"Playfair Display",Georgia,serif;
  --ff-b:"Inter",-apple-system,sans-serif;
  --ease:cubic-bezier(.22,.61,.36,1);
  --shadow:0 20px 60px rgba(26,15,10,.10);
  --r-lg:18px; --r-sm:11px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:auto}
html.lenis,html.lenis body{height:auto}
.lenis.lenis-smooth{scroll-behavior:auto!important}
body{
  font-family:var(--ff-b);font-size:17px;line-height:1.6;color:var(--ink);
  background:var(--cream);-webkit-font-smoothing:antialiased;overflow-x:hidden;
}
img{display:block;max-width:100%}
button{font:inherit;cursor:pointer;background:none;border:none;color:inherit}
a{color:inherit}
h1,h2,h3{font-family:var(--ff-d);font-weight:600;line-height:1.08}
h2{font-size:clamp(28px,3.6vw,50px);letter-spacing:-.01em;perspective:600px}
.chr{display:inline-block;will-change:transform}
h2 em,h1 em{font-style:italic;font-weight:500}
.container{max-width:1240px;margin:0 auto;padding:0 32px}
.section{padding:110px 0}
.section--dark{background:var(--espresso);color:var(--cream)}
.section--dark ::selection{background:var(--sand);color:var(--espresso)}
::selection{background:var(--sky);color:var(--espresso)}

/* міліметрова сітка */
.mmgrid{position:relative}
.mmgrid::before{
  content:"";position:absolute;inset:0;pointer-events:none;opacity:.5;
  background-image:
    linear-gradient(rgba(26,15,10,.045) 1px,transparent 1px),
    linear-gradient(90deg,rgba(26,15,10,.045) 1px,transparent 1px),
    linear-gradient(rgba(26,15,10,.08) 1px,transparent 1px),
    linear-gradient(90deg,rgba(26,15,10,.08) 1px,transparent 1px);
  background-size:12px 12px,12px 12px,60px 60px,60px 60px;
}
.mmgrid>*{position:relative}

/* ── типоелементи ── */
.caption{
  font-size:12px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;
  color:var(--olive);
}
.sechead{position:relative;margin-bottom:52px;max-width:760px}
.secidx{
  position:absolute;top:-.42em;right:-20px;z-index:0;pointer-events:none;user-select:none;
  font-family:var(--ff-d);font-weight:700;font-size:clamp(90px,13vw,190px);line-height:1;
  color:transparent;-webkit-text-stroke:1.5px rgba(26,15,10,.13);
}
.section--dark .secidx{-webkit-text-stroke-color:rgba(230,226,214,.14)}
.sechead>*{position:relative;z-index:1}
.sechead__sub{margin-top:14px;font-size:18px;color:rgba(26,24,26,.72)}
.section--dark .sechead__sub{color:rgba(230,226,214,.72)}

/* chip-«викрас» — підпис секції як зразок фарби */
.chip{
  display:inline-flex;align-items:center;gap:9px;margin-bottom:18px;
  font-size:12px;font-weight:500;letter-spacing:.13em;text-transform:uppercase;
  color:var(--olive);
}
.chip::before{
  content:"";width:26px;height:16px;border-radius:4px;background:var(--c,var(--beige));
  box-shadow:inset 0 0 0 1px rgba(26,15,10,.12);
}
.chip--dark{color:var(--beige)}
.chip--dark::before{box-shadow:inset 0 0 0 1px rgba(230,226,214,.2)}
.dot{display:inline-block;width:9px;height:9px;border-radius:50%;background:var(--c,var(--sky));margin-right:9px;vertical-align:baseline}
.dot--pulse{animation:pulse 2s infinite}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(204,191,131,.5)}55%{box-shadow:0 0 0 7px rgba(204,191,131,0)}}

/* ── кнопки ── */
.btn{
  position:relative;display:inline-flex;align-items:center;justify-content:center;
  padding:16px 30px;border-radius:999px;font-weight:600;font-size:16px;
  letter-spacing:.01em;text-decoration:none;white-space:nowrap;
  transition:transform .3s var(--ease),box-shadow .3s var(--ease),color .35s var(--ease),border-color .3s;
  overflow:hidden;z-index:0;
}
.btn--s{padding:11px 22px;font-size:14px}
.btn--xl{padding:19px 40px;font-size:17px}
.btn--primary{background:var(--espresso);color:var(--cream)}
.btn--primary::before{
  content:"";position:absolute;inset:0;z-index:-1;background:var(--bordo);
  transform:scaleX(0);transform-origin:left;transition:transform .45s var(--ease);
}
.btn--primary:hover{transform:translateY(-2px);box-shadow:0 14px 34px rgba(26,15,10,.28)}
.btn--primary:hover::before{transform:scaleX(1)}
.section--dark .btn--primary{background:var(--cream);color:var(--espresso)}
.section--dark .btn--primary::before{background:var(--sand)}
.btn--ghost{border:1.5px solid rgba(26,15,10,.35);color:var(--ink);background:transparent}
.btn--ghost:hover{border-color:var(--ink);transform:translateY(-2px)}
.btn--ondark{border-color:rgba(230,226,214,.4);color:var(--cream)}
.btn--ondark:hover{border-color:var(--cream)}

/* ── плівкове зерно ── */
.grain{
  position:fixed;inset:-100%;z-index:300;pointer-events:none;opacity:.05;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23n)'/%3E%3C/svg%3E");
  animation:grain 7s steps(10) infinite;
}
@keyframes grain{
  0%,100%{transform:translate(0,0)}10%{transform:translate(-3%,2%)}30%{transform:translate(2%,-4%)}
  50%{transform:translate(-4%,-2%)}70%{transform:translate(3%,3%)}90%{transform:translate(-2%,4%)}
}

/* ── курсор-перекрестя (desktop, тільки коли .gl) ── */
.cursor{position:fixed;top:0;left:0;z-index:400;pointer-events:none;opacity:0;transition:opacity .3s}
.gl .cursor{opacity:1}
.gl body{cursor:none}
.gl a,.gl button,.gl .work,.gl .ba__handle,.gl input,.gl label{cursor:none}
.cursor__h,.cursor__v{position:absolute;background:rgba(26,15,10,.55)}
.cursor__h{width:26px;height:1px;left:-13px;top:0}
.cursor__v{width:1px;height:26px;left:0;top:-13px}
.cursor__dot{
  position:absolute;width:5px;height:5px;border-radius:50%;background:var(--bordo);
  left:-2.5px;top:-2.5px;transition:transform .25s var(--ease);
}
.cursor.is-link .cursor__dot{transform:scale(3.2);background:var(--sand)}
.cursor.is-dark .cursor__h,.cursor.is-dark .cursor__v{background:rgba(230,226,214,.6)}
@media (hover:none){.cursor{display:none}.gl body{cursor:auto}}

/* ══════════ NAV ══════════ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 32px;transition:background .3s,box-shadow .3s,border-color .3s;
  border-bottom:1px solid transparent;
}
.nav.is-solid{background:rgba(230,226,214,.92);backdrop-filter:blur(14px);border-bottom-color:rgba(194,188,169,.55)}
.nav__logo{display:flex;align-items:center;gap:11px;text-decoration:none;font-family:var(--ff-d);font-weight:700;font-size:15px;line-height:1.05;letter-spacing:.02em}
.nav__mark{width:34px;height:34px}
.nav__links{display:flex;gap:34px}
.nav__links a{
  text-decoration:none;font-size:15px;font-weight:500;position:relative;padding:4px 0;
}
.nav__links a::after{
  content:"";position:absolute;left:0;bottom:0;height:2px;width:100%;background:var(--bordo);
  transform:scaleX(0);transform-origin:left;transition:transform .3s var(--ease);
}
.nav__links a:hover::after{transform:scaleX(1)}
.nav__cta{display:flex;align-items:center;gap:14px}
.nav__burger{display:none;flex-direction:column;gap:6px;padding:8px}
.nav__burger span{width:24px;height:2px;background:var(--ink);transition:.3s}
.mobmenu{
  position:fixed;inset:0;z-index:99;background:var(--cream);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:30px;
  opacity:0;pointer-events:none;transition:opacity .3s;
}
.mobmenu.is-open{opacity:1;pointer-events:auto}
.mobmenu a{font-family:var(--ff-d);font-size:32px;text-decoration:none}

/* ══════════ B1 · HERO ══════════ */
.hero{min-height:100svh;display:flex;flex-direction:column;justify-content:center;padding:130px 0 40px;background:var(--cream)}
.hero__inner{display:grid;grid-template-columns:1.05fr .95fr;gap:60px;align-items:center;width:100%}
.hero__h1{font-size:clamp(38px,6.1vw,94px);margin:26px 0 24px;letter-spacing:-.02em}
.line-mask{display:block;overflow:hidden;padding-bottom:.08em;margin-bottom:-.08em}
.line-mask>span{display:block;transform:translateY(110%)}
.hero__lead{font-size:clamp(16px,1.4vw,19px);max-width:520px;color:rgba(26,24,26,.8)}
.hero__cta{display:flex;gap:16px;flex-wrap:wrap;margin-top:34px}
.hero__swatches{display:flex;align-items:center;gap:7px;margin-top:44px}
.sw{width:34px;height:20px;border-radius:5px;background:var(--c);box-shadow:inset 0 0 0 1px rgba(26,15,10,.1);transition:transform .3s var(--ease)}
.hero__swatches:hover .sw{transform:translateY(-3px)}
.sw:nth-child(2){transition-delay:.03s}.sw:nth-child(3){transition-delay:.06s}
.sw:nth-child(4){transition-delay:.09s}.sw:nth-child(5){transition-delay:.12s}.sw:nth-child(6){transition-delay:.15s}
.hero__swlabel{margin-left:10px;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--olive)}

.hero__vis{position:relative}
.hero__plan{position:relative;aspect-ratio:560/640;max-height:74vh;margin-left:auto}
#planSvg{width:100%;height:100%}
.hero__gl{position:absolute;inset:0;width:100%!important;height:100%!important}
.gl #planSvg,.gl .hero__dim{visibility:hidden}
.gl .hero__plan{aspect-ratio:4/3;width:100%;max-width:none}
.ld{stroke:var(--espresso);stroke-width:1.5;fill:none;stroke-linecap:round;stroke-linejoin:round}
.ld.thin{stroke-width:1;opacity:.55}
.hero__dim{position:absolute;font-size:11px;color:rgba(26,15,10,.6);letter-spacing:.08em}
.hero__dim--b{bottom:-4px;left:50%;transform:translateX(-50%)}
.hero__dim--r{right:-8px;top:50%;transform:rotate(90deg)}
.hero__photo{
  position:absolute;inset:4% 3% 5% 3%;overflow:hidden;border-radius:var(--r-sm);
  clip-path:polygon(0 0,0 0,0 100%,0 100%);z-index:2;
}
.hero__photo img{width:100%;height:100%;object-fit:cover}
.hero__phcap{
  position:absolute;left:14px;bottom:12px;font-size:11px;letter-spacing:.1em;text-transform:uppercase;
  color:#fff;background:rgba(26,15,10,.55);padding:6px 12px;border-radius:6px;backdrop-filter:blur(4px);
}
.hero__facts{
  margin-top:54px;display:flex;justify-content:center;align-items:center;gap:22px;flex-wrap:wrap;
  font-size:13px;letter-spacing:.06em;text-transform:uppercase;color:var(--olive);font-weight:500;
}
.hero__facts i{width:5px;height:5px;border-radius:50%;background:var(--beige)}

/* ══════════ B2 · STATS ══════════ */
.stats{background:var(--cream-lite);border-top:1px solid var(--beige);border-bottom:1px solid var(--beige);padding:52px 0 0}
.stats__row{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;text-align:center;padding-bottom:44px}
.stat b{display:block;font-family:var(--ff-d);font-weight:700;font-size:clamp(34px,3.6vw,52px);letter-spacing:-.02em}
.stat b em{font-style:normal;color:var(--beige)}
.stat span{font-size:14px;color:var(--olive)}
.marquee{overflow:hidden;border-top:1px solid var(--beige);padding:13px 0;white-space:nowrap}
.marquee__track{display:inline-flex;animation:marquee 38s linear infinite}
.marquee__track span{font-size:12.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--olive)}
@keyframes marquee{to{transform:translateX(-33.333%)}}
.marquee--dark{border-top:1px solid rgba(230,226,214,.14);border-bottom:1px solid rgba(230,226,214,.14);margin-bottom:70px}
.marquee--dark .marquee__track span{color:var(--sand);font-family:var(--ff-d);font-size:15px;letter-spacing:.2em}

/* ══════════ B3 · PAINS ══════════ */
.pains__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.pain{
  position:relative;background:var(--cream-lite);border:1px solid var(--beige);
  border-radius:var(--r-lg);padding:30px 28px;font-size:16.5px;line-height:1.55;
  transition:transform .35s var(--ease),box-shadow .35s var(--ease);
}
.pain::after{ /* «підгорнутий» куточок кальки */
  content:"";position:absolute;top:0;right:0;width:26px;height:26px;
  background:linear-gradient(225deg,var(--cream) 50%,rgba(194,188,169,.65) 50%);
  border-radius:0 var(--r-lg) 0 8px;
}
.pain:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.pains__valid{
  margin-top:56px;text-align:center;font-family:var(--ff-d);font-size:clamp(20px,2.2vw,28px);font-weight:500;
}
.pains__valid em{font-style:italic;border-bottom:2px solid var(--bordo)}

/* ══════════ B4 · БУЛО→СТАЛО ══════════ */
.ba{padding:110px 0 0;overflow:hidden}
.ba .sechead{margin-bottom:60px}
.ba__stage{position:relative}
.ba__frame{
  position:relative;aspect-ratio:4/3;width:min(94vw,calc(86vh*4/3));min-height:520px;
  margin:0 auto;overflow:hidden;user-select:none;border-radius:var(--r-sm);
}
.ba__after,.ba__before{position:absolute;inset:0}
.ba__after img,.ba__before img{width:100%;height:100%;object-fit:cover}
.ba__before{clip-path:inset(0 calc(100% - var(--pos,30%)) 0 0)}
.ba__before img{filter:sepia(.12) contrast(.98)}
.ba__handle{
  position:absolute;top:0;bottom:0;left:var(--pos,30%);width:2px;background:var(--cream);
  box-shadow:0 0 24px rgba(0,0,0,.4);cursor:ew-resize;z-index:3;
}
.ba__handle span{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:46px;height:46px;border-radius:50%;background:var(--cream);
  display:block;
}
.ba__handle span::before{content:"◂ ▸";position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:12px;color:var(--espresso);letter-spacing:2px}
.ba__tag{
  position:absolute;bottom:34px;z-index:2;font-size:13px;font-weight:600;letter-spacing:.18em;
  color:#fff;text-shadow:0 1px 10px rgba(0,0,0,.5);
}
.ba__tag i{display:block;font-style:normal;font-weight:400;font-size:12px;letter-spacing:.03em;text-transform:none;opacity:.85;max-width:230px;margin-top:6px}
.ba__tag--l{left:36px}
.ba__tag--r{right:36px;text-align:right}
.ba__tag--r i{margin-left:auto}

/* ══════════ B5 · STORIES ══════════ */
.stories__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;align-items:start}
.story{background:var(--cream-lite);border:1px solid var(--beige);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow)}
.story:nth-child(2){transform:translateY(22px)}
.story img{width:100%}
.story figcaption{padding:13px 18px;font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--olive)}
.stories__cta{display:flex;align-items:center;gap:22px;flex-wrap:wrap;margin-top:56px;justify-content:center}
.stories__note{font-size:14px;color:var(--olive)}

/* ══════════ B6 · STEPS ══════════ */
.steps{background:var(--cream)}
.steps__row{position:relative;display:grid;grid-template-columns:repeat(3,1fr);gap:30px;margin-top:10px}
.steps__route{position:absolute;top:34px;left:4%;width:92%;height:40px;z-index:0}
.steps__route path{stroke:var(--olive);stroke-width:1.6;fill:none}
.step{position:relative;z-index:1;background:var(--cream-lite);border:1px solid var(--beige);border-radius:var(--r-lg);padding:64px 28px 30px}
.step__num{
  position:absolute;top:-2px;left:28px;transform:translateY(-50%);
  font-family:var(--ff-d);font-weight:700;font-size:22px;
  background:var(--espresso);color:var(--cream);width:64px;height:64px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;border:5px solid var(--cream);
}
.step:nth-child(3) .step__num{background:var(--navy)}
.step:nth-child(4) .step__num{background:var(--bordo)}
.step h3{font-size:23px;margin-bottom:12px}
.step p{font-size:15.5px;color:rgba(26,24,26,.78)}
.steps__credit{margin-top:44px;text-align:center;font-weight:500}
.steps__cta{text-align:center;margin-top:26px}

/* ══════════ B7 · PROGRAM ══════════ */
.program{background:var(--cream-lite)}
.program__wrap{display:grid;grid-template-columns:52px 1fr;gap:30px}
.program__rail svg{width:20px;height:100%}
.program__rail path{stroke:var(--olive);stroke-width:1.6;stroke-dasharray:6 7;fill:none}
.acc{border:1px solid var(--beige);border-radius:var(--r-lg);background:var(--cream);margin-bottom:16px;overflow:hidden}
.acc__head{
  width:100%;display:flex;align-items:center;gap:22px;text-align:left;
  padding:26px 28px;
}
.acc__num{font-family:var(--ff-d);font-weight:700;font-size:34px;color:var(--beige);line-height:1}
.acc__title{font-family:var(--ff-d);font-weight:600;font-size:clamp(19px,1.9vw,24px);flex:1}
.acc__x{position:relative;width:22px;height:22px;flex:none}
.acc__x::before,.acc__x::after{content:"";position:absolute;top:50%;left:0;width:100%;height:2px;background:var(--ink);transition:transform .3s var(--ease)}
.acc__x::after{transform:rotate(90deg)}
.acc.is-open .acc__x::after{transform:rotate(0)}
.acc__body{display:grid;grid-template-rows:0fr;transition:grid-template-rows .35s var(--ease)}
.acc.is-open .acc__body{grid-template-rows:1fr}
.acc__in{overflow:hidden;padding:0 28px}
.acc.is-open .acc__in{padding-bottom:26px}
.acc__in p{max-width:640px;color:rgba(26,24,26,.8)}
.acc__artifact{margin-top:12px;font-weight:600;color:var(--forest)}
.program__proof{margin-top:44px;border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--beige);box-shadow:var(--shadow)}
.program__proof figcaption{padding:13px 18px;font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--olive);background:var(--cream)}

/* ══════════ B8 · FORMAT ══════════ */
.format__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.fmt{
  border:1px solid rgba(230,226,214,.16);border-radius:var(--r-lg);padding:32px 28px;
  background:rgba(230,226,214,.03);transition:background .35s,transform .35s var(--ease);
}
.fmt:hover{background:rgba(230,226,214,.07);transform:translateY(-4px)}
.fmt svg{width:34px;height:34px;stroke:var(--sand);stroke-width:1.7;fill:none;stroke-linecap:round;stroke-linejoin:round;margin-bottom:18px}
.fmt h3{font-size:20px;margin-bottom:9px;font-family:var(--ff-b);font-weight:600}
.fmt p{font-size:15px;color:rgba(230,226,214,.72)}

/* ══════════ B9/B14a · CHAPTER ══════════ */
.chapter{position:relative;height:96vh;min-height:540px;overflow:hidden}
.chapter__img{position:absolute;inset:-9% 0}
.chapter__img img{width:100%;height:100%;object-fit:cover}
.chapter::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(26,15,10,.18),transparent 30%,transparent 70%,rgba(26,15,10,.45))}
.chapter__dim{position:absolute;right:7%;top:14%;height:56%;width:40px;z-index:2}
.chapter__dim path{stroke:#fff;opacity:.9}
.chapter__dimtxt{
  position:absolute;right:calc(7% + 46px);top:42%;z-index:2;color:#fff;font-size:12px;letter-spacing:.1em;
  text-shadow:0 1px 8px rgba(0,0,0,.5);
}
.chapter__dimtxt--mat{right:auto;left:8%;top:20%}
.chapter__cap{
  position:absolute;left:0;right:0;bottom:34px;z-index:2;text-align:center;color:#fff;
  font-size:13px;letter-spacing:.14em;text-transform:uppercase;text-shadow:0 1px 8px rgba(0,0,0,.6);
  padding:0 20px;
}

/* ══════════ B10 · WORKS ══════════ */
.works{overflow:hidden}
.works__strip{
  display:flex;gap:26px;padding:10px 32px 26px;
  overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;
  scrollbar-width:none;
}
.works__strip::-webkit-scrollbar{display:none}
.work{
  flex:0 0 clamp(300px,32vw,460px);scroll-snap-align:center;cursor:zoom-in;
  border-radius:var(--r-lg);overflow:hidden;background:var(--cream-lite);
  border:1px solid var(--beige);box-shadow:var(--shadow);
}
.work{transform-style:preserve-3d;will-change:transform}
.work img{width:100%;aspect-ratio:4/3.1;object-fit:cover;transition:transform .6s var(--ease)}
.work:hover img{transform:scale(1.05)}
.work figcaption{padding:14px 20px;font-size:13px;letter-spacing:.08em;text-transform:uppercase;color:var(--olive)}

/* кейси студії — editorial-плитка */
.cases{margin-top:74px}
.cases__intro{max-width:640px;font-size:clamp(15px,1.25vw,18px);color:rgba(26,24,26,.75);margin-bottom:34px}
.cases__grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:225px;gap:16px}
.case{flex:none;width:auto;position:relative;border-radius:var(--r-sm);border:none;box-shadow:none;background:var(--espresso)}
.case img{height:100%;aspect-ratio:auto}
.case figcaption{
  position:absolute;left:0;right:0;bottom:0;padding:46px 20px 16px;text-transform:none;
  background:linear-gradient(transparent,rgba(26,15,10,.78));color:#fff;letter-spacing:0;
}
.case figcaption b{display:block;font-family:var(--serif);font-weight:600;font-size:19px;letter-spacing:.01em}
.case figcaption span{font-size:12px;letter-spacing:.07em;text-transform:uppercase;opacity:.8}
.case--a{grid-column:span 2;grid-row:span 2}
.case--b{grid-column:span 2}
@media(max-width:900px){
  .cases__grid{grid-template-columns:1fr 1fr;grid-auto-rows:180px}
  .case--a{grid-column:span 2}
  .case--b{grid-column:span 2}
}

/* ══════════ B11 · OLENA ══════════ */
.olena{position:relative;overflow:hidden;background:var(--cream)}
.olena__bg{
  position:absolute;top:6%;left:50%;transform:translateX(-50%);z-index:0;
  font-family:var(--ff-d);font-style:italic;font-weight:600;
  font-size:clamp(120px,24vw,360px);color:var(--beige);opacity:.35;white-space:nowrap;line-height:1;
  pointer-events:none;
}
.olena__wrap{position:relative;z-index:1;display:grid;grid-template-columns:.9fr 1.1fr;gap:64px;align-items:center}
.olena__photo{border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow)}
.olena__photo img{width:100%;aspect-ratio:4/3.4;object-fit:cover}
.olena__photo figcaption{padding:13px 18px;font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--olive);background:var(--cream-lite)}
.olena__quote{font-family:var(--ff-d);font-style:italic;font-size:clamp(20px,2vw,26px);line-height:1.4;margin-bottom:22px}
.olena__nums{display:flex;gap:38px;margin-top:30px;flex-wrap:wrap}
.olena__nums span{font-size:14px;color:var(--olive)}
.olena__nums b{display:block;font-family:var(--ff-d);font-size:34px;font-weight:700;color:var(--ink)}
.olena__team{margin-top:30px;padding:18px 22px;background:var(--cream-lite);border:1px solid var(--beige);border-radius:var(--r-sm);font-size:15px}

/* ══════════ B12 · TARIFF ══════════ */
.tariff{position:relative}
.tariff::before{ /* тепла «горіхова» смуга */
  content:"";position:absolute;top:0;left:0;right:0;height:6px;
  background:linear-gradient(90deg,var(--bordo),#5a2b12 30%,var(--sand) 60%,#5a2b12 85%,var(--bordo));
  opacity:.85;
}
.tariff__wrap{display:grid;grid-template-columns:1fr 1fr;gap:44px;align-items:start}
.tariff__stack h3{font-size:22px;margin-bottom:20px}
.tariff__stack ul{list-style:none}
.tariff__stack li{
  position:relative;padding:12px 0 12px 34px;border-bottom:1px solid rgba(230,226,214,.12);
  font-size:16px;color:rgba(230,226,214,.9);
}
.tariff__stack li::before{content:"✓";position:absolute;left:4px;color:var(--sand);font-weight:600}
.tariff__bt{margin-top:34px}
.tariff__bonuses li.tape{
  border:none;padding:12px 16px;margin-bottom:10px;background:rgba(204,191,131,.08);
  border-left:3px solid var(--sand);border-radius:0 8px 8px 0;
}
.tariff__bonuses li.tape::before{content:"+";left:auto;position:static;margin-right:10px;color:var(--sand)}
.tariff__rev{margin-top:36px;max-width:330px;border-radius:var(--r-sm);overflow:hidden;border:1px solid rgba(230,226,214,.15)}
.tariff__rev figcaption{padding:11px 15px;font-size:11.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--beige);background:rgba(230,226,214,.05)}

.tariff__card{
  background:var(--cream);color:var(--ink);border-radius:22px;padding:40px 38px;
  box-shadow:0 30px 90px rgba(0,0,0,.5);position:sticky;top:90px;
}
.tariff__flow{font-size:14px;color:var(--olive);line-height:1.5}
.tariff__flow b{color:var(--ink);font-weight:600}
.tariff__seats{margin-top:16px;font-size:14.5px;font-weight:600;color:var(--forest)}
.tariff__price{position:relative;display:flex;align-items:baseline;gap:18px;margin:24px 0 4px;flex-wrap:wrap}
.tariff__price s{color:var(--olive);font-size:20px}
.tariff__price b{font-family:var(--ff-d);font-weight:700;font-size:clamp(44px,4.4vw,60px);letter-spacing:-.02em}
.tariff__price b span{font-size:22px;font-weight:600}
.stamp{
  display:inline-block;padding:7px 14px;border:2.5px solid var(--bordo);border-radius:8px;
  color:var(--bordo);font-weight:700;font-size:15px;letter-spacing:.06em;
  transform:rotate(-5deg);background:rgba(69,0,0,.04);
}
.tariff__why{font-size:13.5px;color:var(--olive)}
.tariff__split{margin:18px 0 26px;font-size:16px}
.tariff__card .btn--primary{width:100%}
.tariff__note{margin-top:12px;font-size:13px;color:var(--olive);text-align:center}
.tariff__guarantee{margin-top:28px;border-top:1px dashed var(--beige);padding-top:22px}
.tariff__guarantee h4{font-family:var(--ff-d);font-size:20px;margin-bottom:8px}
.tariff__guarantee p{font-size:14.5px;color:rgba(26,24,26,.8)}
.tariff__not{margin-top:64px;max-width:640px}
.tariff__not h3{font-size:21px;margin-bottom:16px;color:var(--beige)}
.tariff__not ul{list-style:none}
.tariff__not li{padding:7px 0 7px 26px;position:relative;color:rgba(230,226,214,.78);font-size:15.5px}
.tariff__not li::before{content:"—";position:absolute;left:0;color:var(--bordo);filter:brightness(2.4)}
.tariff__bridge{
  margin-top:56px;display:flex;align-items:center;justify-content:space-between;gap:26px;flex-wrap:wrap;
  border:1px solid rgba(230,226,214,.16);border-radius:var(--r-lg);padding:28px 32px;
  background:rgba(230,226,214,.04);
}
.tariff__bridge p{font-size:17px;max-width:520px}

/* ══════════ B13 · MINI ══════════ */
.mini{background:var(--cream)}
.mini__card{
  position:relative;display:grid;grid-template-columns:1.3fr .7fr;gap:44px;
  background:var(--cream-lite);border:1px solid var(--beige);border-radius:24px;
  padding:56px 54px;box-shadow:var(--shadow);
}
.mini__tape{
  position:absolute;top:-14px;left:48px;transform:rotate(-3deg);
  background:var(--sand);color:var(--espresso);font-size:12px;font-weight:600;
  letter-spacing:.14em;text-transform:uppercase;padding:8px 20px;
  box-shadow:0 3px 10px rgba(26,15,10,.15);opacity:.92;
}
.mini__l h2{margin-bottom:24px}
.mini__l ul{list-style:none}
.mini__l li{position:relative;padding:8px 0 8px 28px;font-size:16px}
.mini__l li::before{content:"";position:absolute;left:2px;top:16px;width:9px;height:9px;border-radius:50%;background:var(--sky)}
.mini__r{display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;border-left:1px dashed var(--beige);padding-left:44px}
.mini__price{font-family:var(--ff-d);font-weight:700;font-size:76px;letter-spacing:-.02em;line-height:1}
.mini__credit{font-size:14px;color:var(--olive);margin:12px 0 26px;max-width:220px}

/* ══════════ B14b · REVIEWS ══════════ */
.reviews{background:var(--cream-lite);padding-bottom:80px}
.reviews .sechead{margin-bottom:36px}
.reviews__rail{
  display:flex;gap:22px;overflow-x:auto;padding:6px 32px 22px;
  scroll-snap-type:x proximity;scrollbar-width:none;cursor:grab;
}
.reviews__rail::-webkit-scrollbar{display:none}
.reviews__rail.is-drag{cursor:grabbing}
.revcard{
  flex:0 0 260px;scroll-snap-align:start;border-radius:var(--r-sm);overflow:hidden;
  border:1px solid var(--beige);background:#fff;box-shadow:var(--shadow);
}
.revcard img{width:100%;pointer-events:none}
.revcard--cert figcaption{padding:10px 14px;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--olive)}

/* ══════════ B14c · FAQ ══════════ */
.faq__wrap{display:grid;grid-template-columns:.8fr 1.2fr;gap:60px;align-items:start}
.faq .acc{background:var(--cream-lite)}
.faq .acc__head{padding:21px 24px}
.faq .acc__title{font-family:var(--ff-b);font-weight:600;font-size:17px}
.faq .acc__in{padding:0 24px}
.faq .acc.is-open .acc__in{padding-bottom:20px}
.faq .acc__in p{font-size:15.5px}

/* ══════════ B15 · FINALE ══════════ */
.finale{position:relative;text-align:center;overflow:hidden}
.finale::before{
  content:"";position:absolute;bottom:0;left:0;right:0;height:6px;
  background:linear-gradient(90deg,var(--bordo),#5a2b12 30%,var(--sand) 60%,#5a2b12 85%,var(--bordo));opacity:.85;
}
.finale__h{font-size:clamp(34px,5vw,68px);max-width:900px;margin:0 auto 56px}
.finale__paths{display:flex;justify-content:center;gap:34px;flex-wrap:wrap}
.fpath p{margin-top:14px;font-size:13.5px;color:rgba(230,226,214,.65)}
.finale__ps{
  max-width:560px;margin:80px auto 0;text-align:left;
  border-left:2px solid var(--sand);padding-left:28px;
}
.finale__ps p{font-family:var(--ff-d);font-style:italic;font-size:18px;line-height:1.6;color:rgba(230,226,214,.9)}
.finale__sign{
  display:inline-block;margin-top:14px;font-family:"Caveat",cursive;font-weight:600;
  font-size:44px;color:var(--sand);transform:rotate(-3deg);
}
.js:not(.static) .finale__sign{clip-path:inset(0 100% 0 0)}

/* ══════════ FOOTER ══════════ */
.footer{background:var(--ink);color:rgba(230,226,214,.75);padding:56px 0 26px;font-size:14.5px}
.footer__row{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:36px}
.footer__logo{font-family:var(--ff-d);font-weight:700;font-size:21px;color:var(--cream)}
.footer__brand p{margin-top:10px;font-size:13.5px}
.footer a{display:block;text-decoration:none;padding:4px 0;transition:color .2s}
.footer a:hover{color:var(--sand)}
.footer__copy{text-align:center;margin-top:44px;font-size:12.5px;color:rgba(230,226,214,.4)}

/* ══════════ STICKY CTA ══════════ */
.sticky-cta{
  position:fixed;left:14px;right:14px;bottom:14px;z-index:90;display:none;
  transform:translateY(120%);transition:transform .4s var(--ease);
}
.sticky-cta.is-on{transform:none}
.sticky-cta .btn{width:100%;box-shadow:0 12px 40px rgba(26,15,10,.35)}

/* ══════════ MODAL ══════════ */
.modal{position:fixed;inset:0;z-index:200;display:none;align-items:center;justify-content:center;padding:20px}
.modal.is-open{display:flex}
.modal__bg{position:absolute;inset:0;background:rgba(26,15,10,.72);backdrop-filter:blur(6px)}
.modal__card{
  position:relative;background:var(--cream);border-radius:22px;padding:44px 40px;
  width:min(460px,100%);box-shadow:0 40px 120px rgba(0,0,0,.5);
  animation:modalin .35s var(--ease);
}
@keyframes modalin{from{opacity:0;transform:translateY(24px) scale(.97)}}
.modal__x{position:absolute;top:16px;right:18px;font-size:18px;color:var(--olive);padding:6px}
.modal__card h3{font-size:26px;margin-bottom:6px}
.modal__sub{font-size:14px;color:var(--olive);margin-bottom:26px}
.modal__card label{display:block;margin-bottom:16px;font-size:13px;font-weight:500;color:var(--olive)}
.modal__card input:not([type=checkbox]){
  width:100%;margin-top:6px;padding:13px 16px;border:1px solid var(--beige);border-radius:10px;
  font:inherit;font-size:16px;background:var(--cream-lite);color:var(--ink);
}
.modal__card input:focus{outline:2px solid var(--sky);outline-offset:1px}
.modal__card input.is-err{border-color:var(--bordo);outline:1px solid var(--bordo)}
.modal__check{display:flex;gap:10px;align-items:flex-start;font-weight:400!important;margin:20px 0 24px!important}
.modal__check input{margin-top:3px}
.modal__card form .btn{width:100%}
.modal__ok{text-align:center;padding:20px 0}
.modal__ok h3{margin:18px 0 10px}
.modal__ok p{font-size:15px;color:rgba(26,24,26,.75)}
.stamp--ok{transform:rotate(-6deg);font-size:18px;padding:10px 20px}

/* ══════════ LIGHTBOX ══════════ */
.lightbox{
  position:fixed;inset:0;z-index:210;background:rgba(26,15,10,.93);
  display:none;align-items:center;justify-content:center;
}
.lightbox.is-open{display:flex}
.lightbox img{max-width:88vw;max-height:84vh;border-radius:10px}
.lightbox__x{position:absolute;top:22px;right:28px;color:var(--cream);font-size:22px}
.lightbox__nav{
  position:absolute;top:50%;transform:translateY(-50%);color:var(--cream);
  font-size:26px;padding:18px;transition:transform .2s;
}
.lightbox__nav:hover{transform:translateY(-50%) scale(1.2)}
.lightbox__nav--l{left:16px}.lightbox__nav--r{right:16px}
.lightbox__count{position:absolute;bottom:22px;left:50%;transform:translateX(-50%);color:var(--beige);font-size:13px;letter-spacing:.15em}

/* ══════════ REVEAL (JS керує) ══════════ */
.js .reveal{opacity:0;transform:translateY(22px)}
.js.static .reveal,.no-js .reveal{opacity:1!important;transform:none!important}
.js.static .line-mask>span{transform:none!important}
.js.static .hero__photo{clip-path:none!important}
.js.static .ba__before{--pos:50%}
.js.static .ld{stroke-dasharray:none!important;stroke-dashoffset:0!important}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001s!important;transition-duration:.001s!important}
  .js .reveal{opacity:1;transform:none}
  .js .line-mask>span{transform:none}
}

/* ══════════ АДАПТИВ ══════════ */
@media (max-width:1199px){
  .hero__inner{gap:40px}
  .format__grid,.pains__grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:900px){
  .section{padding:72px 0}
  .container{padding:0 20px}
  .nav{padding:12px 20px}
  .nav__links{display:none}
  .nav__burger{display:flex}
  .nav__cta .btn{display:none}
  .hero{padding-top:104px}
  .hero__inner{grid-template-columns:1fr}
  .hero__plan{max-height:none;max-width:480px;margin:0 auto}
  .hero__facts{display:grid;grid-template-columns:1fr 1fr;gap:12px;text-align:center}
  .hero__facts i{display:none}
  .stats__row{grid-template-columns:repeat(2,1fr)}
  .pains__grid,.stories__grid,.format__grid{grid-template-columns:1fr}
  .story:nth-child(2){transform:none}
  .steps__row{grid-template-columns:1fr;gap:44px}
  .steps__route{display:none}
  .program__wrap{grid-template-columns:1fr}
  .program__rail{display:none}
  .ba__frame{height:64vh}
  .ba__tag i{max-width:150px}
  .olena__wrap{grid-template-columns:1fr;gap:40px}
  .tariff__wrap{grid-template-columns:1fr}
  .tariff__card{position:static}
  .mini__card{grid-template-columns:1fr;padding:44px 26px;gap:30px}
  .mini__r{border-left:none;border-top:1px dashed var(--beige);padding:30px 0 0}
  .faq__wrap{grid-template-columns:1fr;gap:30px}
  .finale__paths{flex-direction:column;align-items:center}
  .footer__row{grid-template-columns:1fr 1fr}
  .sticky-cta{display:block}
  .chapter{height:70vh}
}
@media (max-width:480px){
  body{font-size:16px}
  .btn{padding:15px 24px;font-size:15px}
  .hero__cta .btn{width:100%}
  .stats__row{gap:16px}
  .mini__price{font-size:60px}
  .tariff__card{padding:32px 22px}
  .footer__row{grid-template-columns:1fr}
}
