/* ═══════════════════════════════════════════════
   LISOVSKA SCHOOL · V2 «NOIR»
   Темна розкіш: майже-чорний, латунь, Cormorant.
   ═══════════════════════════════════════════════ */
:root{
  --bg:#0E0D0C;
  --bg2:#171412;
  --ink:#EFEAE2;
  --ink-dim:rgba(239,234,226,.62);
  --brass:#B89B5E;
  --brass-hi:#D9BC7A;
  --bordo:#450000;
  --line:rgba(239,234,226,.14);
  --serif:'Cormorant Garamond',Georgia,serif;
  --sans:'Manrope',system-ui,sans-serif;
  --ease:cubic-bezier(.22,.61,.2,1);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:auto}
body{
  background:var(--bg);color:var(--ink);font-family:var(--sans);
  font-weight:300;font-size:16px;line-height:1.6;overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{display:block}
button{font:inherit;color:inherit;background:none;border:none;cursor:pointer}
a{color:inherit;text-decoration:none}

/* зерно */
.grain{position:fixed;inset:-100%;z-index:99;pointer-events:none;opacity:.05;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='240' height='240'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='240' height='240' filter='url(%23n)' opacity='.6'/%3E%3C/svg%3E");
  animation:grain 8s steps(10) infinite}
@keyframes grain{0%,100%{transform:translate(0,0)}20%{transform:translate(-4%,3%)}40%{transform:translate(3%,-4%)}60%{transform:translate(-2%,-3%)}80%{transform:translate(4%,2%)}}

/* ── NAV ── */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:50;display:flex;align-items:center;gap:38px;
  padding:22px 44px;transition:background .4s,padding .4s;
}
.nav.is-solid{background:rgba(14,13,12,.86);backdrop-filter:blur(14px);padding:14px 44px;border-bottom:1px solid var(--line)}
.nav__logo{font-family:var(--serif);font-size:24px;letter-spacing:.04em}
.nav__logo span{color:var(--brass)}
.nav__links{display:flex;gap:28px;margin-left:auto}
.nav__links a{font-size:13px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-dim);transition:color .3s}
.nav__links a:hover{color:var(--brass-hi)}

/* ── КНОПКИ ── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:15px 30px;font-size:13px;letter-spacing:.16em;text-transform:uppercase;font-weight:500;
  transition:all .35s var(--ease);white-space:nowrap}
.btn--brass{background:var(--brass);color:#141210}
.btn--brass:hover{background:var(--brass-hi);transform:translateY(-2px)}
.btn--line{border:1px solid var(--brass);color:var(--brass-hi)}
.btn--line:hover{background:var(--brass);color:#141210}
.btn--ghostw{border:1px solid var(--line);color:var(--ink)}
.btn--ghostw:hover{border-color:var(--ink)}
.btn--big{padding:19px 44px;font-size:14px}
.linkbtn{color:var(--brass-hi);border-bottom:1px solid var(--brass);padding-bottom:1px}

/* ── HERO ── */
.hero{position:relative;height:100svh;display:flex;flex-direction:column;justify-content:flex-end}
.hero__media{position:absolute;inset:0;overflow:hidden}
.hero__img{width:100%;height:112%;object-fit:cover;transform-origin:center}
.hero__veil{position:absolute;inset:0;background:
  linear-gradient(180deg,rgba(14,13,12,.55) 0%,rgba(14,13,12,.12) 38%,rgba(14,13,12,.82) 100%)}
.hero__content{position:relative;z-index:2;padding:0 44px;max-width:1060px;margin-bottom:11vh}
.hero__kicker{font-size:12px;letter-spacing:.3em;text-transform:uppercase;color:var(--brass-hi);margin-bottom:26px}
.hero__h1{font-family:var(--serif);font-weight:500;font-size:clamp(44px,7.4vw,110px);line-height:1.02;letter-spacing:.01em}
.hero__h1 em{font-style:italic;color:var(--brass-hi)}
.hl{display:block;overflow:hidden}
.hl>span{display:inline-block;transform:translateY(110%)}
.hero__sub{max-width:520px;margin-top:26px;color:var(--ink-dim);font-size:clamp(15px,1.25vw,18px)}
.hero__cta{display:flex;gap:18px;margin-top:38px;flex-wrap:wrap}
.hero__meta{position:relative;z-index:2;display:flex;justify-content:space-between;align-items:center;
  padding:20px 44px;border-top:1px solid var(--line);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-dim)}
.hero__scroll{display:flex;align-items:center;gap:10px}
.hero__scroll i{width:1px;height:34px;background:var(--brass);display:block;animation:drop 1.8s var(--ease) infinite}
@keyframes drop{0%{transform:scaleY(0);transform-origin:top}45%{transform:scaleY(1);transform-origin:top}55%{transform:scaleY(1);transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* ── STATS ── */
.stats{display:grid;grid-template-columns:repeat(4,1fr);border-bottom:1px solid var(--line)}
.stat{padding:44px 20px;text-align:center;border-left:1px solid var(--line)}
.stat:first-child{border-left:none}
.stat b,.stat b i{font-family:var(--serif);font-weight:500;font-size:clamp(34px,3.6vw,56px);color:var(--brass-hi);font-style:normal}
.stat span{display:block;margin-top:6px;font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-dim)}

/* ── TICKER ── */
.ticker{overflow:hidden;border-bottom:1px solid var(--line);padding:14px 0}
.ticker__track{display:flex;white-space:nowrap;animation:tick 30s linear infinite;
  font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--brass)}
@keyframes tick{to{transform:translateX(-50%)}}

/* ── SECTION базове ── */
.section{padding:120px 44px}
.kicker{font-size:12px;letter-spacing:.3em;text-transform:uppercase;color:var(--brass);margin-bottom:18px}
.kicker--brass{color:var(--brass-hi)}
.h2{font-family:var(--serif);font-weight:500;font-size:clamp(34px,4.6vw,68px);line-height:1.06;margin-bottom:26px}
.h2 em{color:var(--brass-hi);font-style:italic}

/* ── МАНІФЕСТ ── */
.manifest{max-width:1060px;margin:0 auto}
.manifest__txt{font-family:var(--serif);font-weight:400;font-size:clamp(26px,3.4vw,50px);line-height:1.3}
.manifest__txt em{color:var(--brass-hi)}
.manifest__txt .w{display:inline-block;opacity:.14;transition:opacity .5s}
.manifest__txt .w.on{opacity:1}

/* ── ГОРИЗОНТАЛЬНІ КЕЙСИ ── */
.cases{padding-top:110px}
.cases__head{padding:0 44px;margin-bottom:50px}
.cases__pin{overflow:hidden}
.cases__track{display:flex;gap:26px;padding:0 44px;will-change:transform;width:max-content}
.ccard{position:relative;width:clamp(420px,44vw,680px);height:72vh;min-height:440px;flex:none;overflow:hidden;cursor:zoom-in}
.ccard img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.ccard:hover img{transform:scale(1.045)}
.ccard__cap{position:absolute;left:0;right:0;bottom:0;padding:70px 26px 22px;
  background:linear-gradient(transparent,rgba(10,9,8,.85))}
.ccard__cap b{display:block;font-family:var(--serif);font-weight:500;font-size:27px}
.ccard__cap span{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-dim)}
.ccard__idx{position:absolute;top:18px;right:22px;font-family:var(--serif);font-size:19px;color:rgba(239,234,226,.8);
  border:1px solid rgba(239,234,226,.35);width:52px;height:52px;display:flex;align-items:center;justify-content:center;border-radius:50%}
.ccard--last{background:var(--bg2);cursor:default;display:flex;align-items:center;justify-content:center;border:1px solid var(--line)}
.ccard__more{text-align:center;padding:40px}
.ccard__more p{font-family:var(--serif);font-size:30px;line-height:1.3;margin-bottom:30px}
.ccard__more em{color:var(--brass-hi)}

/* ── ШЛЯХ ── */
.path__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);margin-top:44px}
.pstep{background:var(--bg);padding:48px 36px 56px}
.pstep__n{font-family:var(--serif);font-size:64px;color:var(--brass);line-height:1;display:block;margin-bottom:26px}
.pstep h3{font-family:var(--serif);font-weight:500;font-size:28px;margin-bottom:14px}
.pstep p{color:var(--ink-dim);font-size:15px}
.pstep b{color:var(--brass-hi);font-weight:500}

/* ── FULLSCREEN розділи ── */
.full{position:relative;height:100svh;overflow:hidden;display:flex;align-items:flex-end}
.full--tall{height:110svh}
.full__img{position:absolute;inset:0;width:100%;height:116%;object-fit:cover}
.full__cap{position:relative;z-index:2;width:100%;padding:60px 44px;
  background:linear-gradient(transparent,rgba(10,9,8,.8))}
.full__quote{font-family:var(--serif);font-size:clamp(28px,3.8vw,54px);font-weight:500;line-height:1.2;max-width:800px}
.full__sig{display:block;margin-top:18px;font-size:13px;letter-spacing:.22em;text-transform:uppercase;color:var(--brass-hi)}
.full__cap--stats{display:flex;gap:8vw;flex-wrap:wrap}
.full__cap--stats b{font-family:var(--serif);font-weight:500;font-size:clamp(30px,3.4vw,52px);color:var(--brass-hi);display:block}
.full__cap--stats span{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-dim)}
.full__note{position:absolute;bottom:14px;right:44px;z-index:2;font-size:11px;color:rgba(239,234,226,.4)}

/* ── ПРОГРАМА ── */
.program{max-width:1160px;margin:0 auto}
.prog{list-style:none;margin-top:34px;border-top:1px solid var(--line)}
.prog li{display:grid;grid-template-columns:1fr auto;grid-template-areas:"t m" "s m";
  padding:26px 8px;border-bottom:1px solid var(--line);align-items:center;gap:2px 30px;transition:background .3s,padding .3s}
.prog li:hover{background:var(--bg2);padding-left:20px}
.prog b{grid-area:t;font-family:var(--serif);font-weight:500;font-size:clamp(20px,2.2vw,30px)}
.prog span{grid-area:s;color:var(--ink-dim);font-size:14px}
.prog i{grid-area:m;font-style:normal;font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--brass-hi);white-space:nowrap}

/* ── ОЛЕНА ── */
.olena__grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:70px;max-width:1160px;margin:0 auto;align-items:center}
.olena__ph{overflow:hidden}
.olena__ph img{width:100%;aspect-ratio:3/4;object-fit:cover;object-position:82% 22%}
.olena__facts{list-style:none;margin:26px 0;display:grid;gap:12px}
.olena__facts li{padding-left:26px;position:relative;color:var(--ink-dim)}
.olena__facts li::before{content:"—";position:absolute;left:0;color:var(--brass)}
.olena__q{font-family:var(--serif);font-size:clamp(19px,1.8vw,25px);font-style:italic;line-height:1.45;color:var(--ink);
  border-left:2px solid var(--brass);padding-left:26px}

/* ── ВІДГУКИ ── */
.rev{padding-right:0}
.rev__rail{display:flex;gap:20px;overflow-x:auto;padding:34px 44px 20px 0;scrollbar-width:none;cursor:grab}
.rev__rail::-webkit-scrollbar{display:none}
.rev__rail img{height:340px;border-radius:10px;flex:none;filter:none}

/* ── ЦІНА ── */
.price{position:relative;padding:140px 44px;overflow:hidden}
.price__bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.5}
.price::before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(10,9,8,.92) 0%,rgba(10,9,8,.55) 60%,rgba(10,9,8,.3) 100%)}
.price__card{position:relative;z-index:2;max-width:520px;border:1px solid var(--brass);padding:52px 46px;background:rgba(14,13,12,.72);backdrop-filter:blur(8px)}
.price__h{font-family:var(--serif);font-weight:500;font-size:clamp(46px,5vw,72px);color:var(--brass-hi)}
.price__old{color:var(--ink-dim);margin:6px 0 26px;font-size:14px}
.price__list{list-style:none;display:grid;gap:11px;margin-bottom:34px}
.price__list li{padding-left:26px;position:relative;font-size:15px;color:var(--ink)}
.price__list li::before{content:"◆";position:absolute;left:0;font-size:9px;top:6px;color:var(--brass)}
.price__or{margin-top:18px;font-size:14px;color:var(--ink-dim)}

/* ── FAQ ── */
.faq{max-width:900px;margin:0 auto}
.faq__list{margin-top:30px;border-top:1px solid var(--line)}
.faq details{border-bottom:1px solid var(--line)}
.faq summary{list-style:none;cursor:pointer;padding:24px 40px 24px 4px;position:relative;
  font-family:var(--serif);font-size:clamp(19px,1.9vw,26px);font-weight:500}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";position:absolute;right:8px;top:50%;transform:translateY(-50%);
  font-size:26px;color:var(--brass);transition:transform .3s}
.faq details[open] summary::after{transform:translateY(-50%) rotate(45deg)}
.faq details p{padding:0 4px 26px;color:var(--ink-dim);max-width:700px}

/* ── ФІНАЛ ── */
.finale{position:relative;min-height:92svh;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden}
.finale__bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.42}
.finale::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at center,rgba(10,9,8,.25),rgba(10,9,8,.9))}
.finale__inner{position:relative;z-index:2;padding:60px 24px}
.finale__h{font-family:var(--serif);font-weight:500;font-size:clamp(38px,5.6vw,84px);line-height:1.08;margin-bottom:44px}
.finale__h em{color:var(--brass-hi);font-style:italic}
.finale__cta{display:flex;gap:18px;justify-content:center;flex-wrap:wrap}
.finale__ps{margin-top:44px;font-size:14px;color:var(--ink-dim);font-style:italic}

.foot{display:flex;justify-content:space-between;padding:26px 44px;border-top:1px solid var(--line);
  font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-dim)}

/* ── МОДАЛКА ── */
.modal{position:fixed;inset:0;z-index:100;display:none;align-items:center;justify-content:center;background:rgba(8,7,6,.8);backdrop-filter:blur(6px)}
.modal.is-open{display:flex}
.modal__card{background:var(--bg2);border:1px solid var(--brass);padding:48px 44px;max-width:440px;width:calc(100% - 40px);position:relative}
.modal__x{position:absolute;top:14px;right:16px;font-size:18px;color:var(--ink-dim)}
.modal__h{font-family:var(--serif);font-size:32px;font-weight:500;margin-bottom:8px}
.modal__sub{color:var(--ink-dim);font-size:14px;margin-bottom:26px}
.modal input{width:100%;background:transparent;border:1px solid var(--line);color:var(--ink);
  padding:15px 16px;margin-bottom:14px;font:inherit;font-size:15px}
.modal input:focus{outline:none;border-color:var(--brass)}
.modal input.is-err{border-color:#a33}
.modal .btn{width:100%}
.modal__ok{color:var(--brass-hi);margin-top:16px}

/* ── LIGHTBOX ── */
.lightbox{position:fixed;inset:0;z-index:110;display:none;align-items:center;justify-content:center;background:rgba(8,7,6,.92)}
.lightbox.is-open{display:flex}
.lightbox img{max-width:92vw;max-height:90vh;object-fit:contain}
.lightbox__x{position:absolute;top:22px;right:30px;font-size:22px;color:var(--ink)}

/* ── REVEAL ── */
.js .reveal{opacity:0;transform:translateY(30px)}

@media(prefers-reduced-motion:reduce){
  .js .reveal{opacity:1;transform:none}
  .ticker__track{animation:none}
  .grain{animation:none}
}

/* ── АДАПТИВ ── */
@media(max-width:1100px){
  .olena__grid{grid-template-columns:1fr;gap:40px}
  .path__grid{grid-template-columns:1fr}
}
@media(max-width:760px){
  .nav{padding:16px 20px}
  .nav__links{display:none}
  .section{padding:80px 20px}
  .hero__content{padding:0 20px}
  .hero__meta{padding:16px 20px}
  .hero__meta span:last-child{display:none}
  .stats{grid-template-columns:1fr 1fr}
  .stat{border-top:1px solid var(--line)}
  .cases__head{padding:0 20px}
  .cases__track{gap:14px;padding:0 20px}
  .ccard{width:82vw;height:60vh}
  .full__cap--stats{gap:26px}
  .price{padding:90px 20px}
  .price__card{padding:38px 26px}
  .rev__rail img{height:250px}
  .foot{flex-direction:column;gap:6px;text-align:center}
}
