/* =========================
   Vars & utilities
========================= */
:root{
  --ink: #2a1a10;
  --peach-1: #FFC697;
  --peach-2: #FF9F72;
  --beige: #FFF7F1;
}

.spacer{ height:32px; background:var(--beige); }

/* =========================
   HERO
========================= */
.hero{
  position:relative; width:100%; height:90vh;
  overflow:hidden; background:#000;
}
.hero__video{
  position:absolute; inset:0; width:100%; height:100%;
  object-fit:cover; opacity:0; transition:opacity .6s ease;
}
.hero__video.active{ opacity:1; }
.hero__overlay{
  position:absolute; inset:0; pointer-events:none; z-index:1;
  background:
    radial-gradient(120% 80% at 20% 10%, rgba(255,180,120,.35), rgba(255,180,120,0) 60%),
    linear-gradient(rgba(0,0,0,.25), rgba(0,0,0,.25));
}
.hero__content{
  position:absolute; bottom:1rem; right:.5rem; z-index:2; text-align:left;
}
.hero__content h1{
  font-family:'Montserrat', sans-serif;
  margin:1em; color:#fff; font-weight:900; font-size:5.5em; line-height:1.1;
  text-shadow:0 4px 18px rgba(0,0,0,.5);
}

/* =========================
   ABOUT
========================= */
.about{ position:relative; min-height:100vh; background:#000; overflow:hidden; margin-top:4em; }
.about__media, .about__img{ display:block; width:100%; height:100vh; object-fit:cover; }
.about__img{ object-position:center; }
.about__overlay{
  position:absolute; inset:0; z-index:1; pointer-events:none;
  background:
    radial-gradient(60% 50% at 90% 90%, rgba(0,0,0,.46), rgba(0,0,0,0) 70%),
    linear-gradient(rgba(0,0,0,.18), rgba(0,0,0,.18)),
    radial-gradient(120% 80% at 15% 10%, rgba(255,180,120,.22), rgba(255,180,120,0) 60%);
}
.about__content {
  position: absolute;
  left: clamp(2rem, 6vw, 8em);
  right: 2rem;                   /* даём возможность расширяться */
  bottom: 6vh;
  z-index: 2;
  max-width: min(650px, 45vw);
  color: #fff;
  text-align: left;
  padding: 2.5em;
  background: rgba(0,0,0,.5);
  border-radius: 16px;
  -webkit-backdrop-filter: blur(4px);
  backdrop-filter: blur(4px);
  box-shadow: 0 12px 40px rgba(0,0,0,.35);
  overflow: visible;             /* убираем прокрутку */
  max-height: none;              /* снимаем ограничение */
}
.about__content h3{
  margin:0 0 1.2rem; font-weight:800; font-size:clamp(20px,2.6vw,34px); line-height:1.15;
}
.about__content p{
  margin:0; font-size:clamp(14px,1.4vw,18px); line-height:1.45; letter-spacing:.04em;
}

/* =========================
   BUTTONS
========================= */
.btn-cta{
  margin-top:1.2em; display:inline-flex; align-items:center; justify-content:center; gap:.5rem;
  padding:.9rem 1.15rem; border-radius:14px; text-decoration:none; font-weight:400;
  font-size:clamp(14px,1.5vw,18px); letter-spacing:.04em; color:#fff !important;
  background:var(--peach-2);
  transition:transform .12s ease, box-shadow .12s ease, filter .2s ease;
  -webkit-tap-highlight-color:transparent; user-select:none;
}
.btn-cta *{ user-select:none; }
.btn-cta__icon{ width:1.15em; height:1.15em; flex:0 0 auto; }
.btn-cta:hover{ transform:translateY(-1px); filter:brightness(1.03); }
.btn-cta:active{ transform:translateY(0); }
.btn-cta:focus{ outline:none; }
.btn-cta:focus-visible{ outline:2px solid #FFE3D0; outline-offset:3px; border-radius:16px; }
.btn-cta:link, .btn-cta:visited, .btn-cta:hover, .btn-cta:active{ text-decoration:none; color:var(--ink); }
.btn-cta::selection, .btn-cta *::selection{ background:transparent; }
.btn-cta::-moz-selection, .btn-cta *::-moz-selection{ background:transparent; }

.btn-ghost{
  display:inline-flex; align-items:center; justify-content:center;
  padding:.9rem 1.15rem; border-radius:14px; font-weight:800;
  font-size:clamp(14px,1.5vw,16px); letter-spacing:.02em;
  text-decoration:none; -webkit-tap-highlight-color:transparent; user-select:none;
  color:var(--ink); background:transparent; border:2px solid #FFD9C6;
  box-shadow:0 2px 0 rgba(0,0,0,.04) inset;
  transition:transform .12s ease, box-shadow .12s ease, filter .2s ease, border-color .12s ease;
}
.btn-ghost:hover{ transform:translateY(-1px); border-color:var(--peach-1); }
.btn-ghost:focus{ outline:none; }
.btn-ghost:focus-visible{ outline:2px solid #FFE3D0; outline-offset:3px; border-radius:16px; }

/* =========================
   SPLIT + SLIDER
========================= */
.split{
  background:#fff; color:var(--ink); min-height:90svh;
  display:grid; gap:32px; grid-template-columns:.8fr 1.2fr; align-items:center;
  padding:clamp(24px,4vw,48px);
}
.split__left{ max-width:550px; margin-left:4em; margin-right:2em; }
.split__left h2{
  margin:0 0 1.8rem; font-weight:900; font-size:clamp(28px,4.6vw,52px);
}
.split__left p{
  margin:.6rem 0; font-size:clamp(16px,1.7vw,18px); line-height:1.55; letter-spacing:.01em;
}
.slider{
  width:100%; max-width:1260px; position:relative; height:min(70svh,760px);
  border-radius:14px; overflow:hidden; background:#eee;
}
.slide{ position:absolute; inset:0; opacity:0; transition:opacity .7s ease; }
.slide.active{ opacity:1; }
.slide img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; display:block; }
.slider__nav{
  position:absolute; top:50%; transform:translateY(-50%); z-index:2;
  width:44px; height:44px; border:0; border-radius:999px;
  background:rgba(0,0,0,.35); color:#fff; font-size:26px; line-height:44px; text-align:center; cursor:pointer;
}
.slider__nav:hover{ background:rgba(0,0,0,.5); }
.slider__nav.prev{ left:10px; }
.slider__nav.next{ right:10px; }
.slider__dots{
  position:absolute; left:50%; bottom:12px; transform:translateX(-50%);
  display:flex; gap:8px; z-index:2;
}
.slider__dots button{
  width:9px; height:9px; border:0; border-radius:999px; background:rgba(0,0,0,.25); cursor:pointer;
}
.slider__dots button[aria-selected="true"]{ background:#000; width:22px; }

/* =========================
   FLOW (steps carousel)
========================= */
.flow{ background:#fff; color:var(--ink); padding:clamp(40px,6vw,80px) 20px; }
.flow__head{ max-width:750px; margin:0 20em 3em; }
.flow__head h2{ margin:0 0 1rem; font-weight:900; font-size:clamp(28px,4.5vw,48px); }
.flow__head p{ margin:0 0 2em; font-size:clamp(16px,1.6vw,18px); line-height:1.55; letter-spacing:.01em; }
.flow__viewport{ position:relative; max-width:1280px; margin:0 auto; }
.flow__track{
  display:flex; gap:16px; overflow-x:auto; scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch; overscroll-behavior-x:contain;
  scrollbar-width:none; padding:10px;
}
.flow__track::-webkit-scrollbar{ display:none; }
.step-card{
  scroll-snap-align:center; scroll-snap-stop:always; flex:0 0 auto;
  width:min(90vw,960px); border-radius:16px; background:#fff;
  box-shadow:0 2px 0 rgba(0,0,0,.05) inset, 0 10px 28px rgba(0,0,0,.06);
  padding:2em; position:relative; transform:scale(.98);
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
  border:1px solid #F1ECE7;
}
.step-card.is-active{
  transform:scale(1.02); box-shadow:0 16px 40px rgba(255,159,114,.18); border-color:#FFD9C6;
}
.step-chip{
  position:absolute; top:2.7em; left:2em; display:inline-grid; place-items:center;
  width:34px; height:34px; border-radius:999px;
  background:linear-gradient(180deg,var(--peach-1),var(--peach-2));
  color:var(--ink); font-weight:800; font-size:16px;
}
.step-card h3{
  margin:0 0 .25rem 3em; font-weight:800; font-size:clamp(18px,2.2vw,24px);
}
.step-sub{ margin:0 0 .75rem 4.5em; color:#5a4a40; letter-spacing:.01em; }
.shot{ border-radius:12px; overflow:hidden; background:#f5f2ef; }
.shot picture, .shot img{ display:block; width:100%; height:auto; }
.shot img{ object-fit:cover; }
.flow__nav{
  position:absolute; top:50%; transform:translateY(-50%);
  width:44px; height:44px; border:0; border-radius:999px;
  background:rgba(0,0,0,.35); color:#fff; font-size:26px; line-height:44px;
  text-align:center; cursor:pointer; z-index:2; -webkit-tap-highlight-color:transparent;
}
.flow__nav:hover{ background:rgba(0,0,0,.5); }
.flow__nav.prev{ left:-4em; }
.flow__nav.next{ right:-4em; }
.flow__dots{ display:flex; gap:8px; justify-content:center; margin-top:14px; }
.flow__dots button{
  width:9px; height:9px; border-radius:999px; border:0; background:rgba(0,0,0,.18); cursor:pointer; padding:0;
}
.flow__dots button[aria-selected="true"]{ background:#000; width:22px; }

/* =========================
   WHY 2x2
========================= */
.why2x2{ background:#fff; color:var(--ink); padding:clamp(40px,6vw,96px) 20px; }
.why2x2__wrap{
  max-width:1280px; margin:0 auto; display:grid; gap:5em;
  grid-template-columns:1.1fr 1fr; align-items:center;
}
.why2x2__grid{
  display:grid; gap:clamp(10px,1.6vw,16px);
  grid-template-columns:1fr 1fr; grid-auto-rows:1fr;
  height:min(78svh,860px);
}
.tile{
  margin:0; border-radius:16px; overflow:hidden; background:#f5f2ef;
  box-shadow:0 2px 0 rgba(0,0,0,.04) inset, 0 10px 24px rgba(0,0,0,.06);
}
.tile picture, .tile img{ display:block; width:100%; height:100%; }
.tile img{ object-fit:cover; object-position:50% 50%; }
.why2x2__content{ max-width:620px; }
.why2x2__content h2{
  margin:0 0 1.2em; font-weight:900; font-size:clamp(28px,4.6vw,48px);
}
.why2x2__content .lead{
  margin:.25rem 0 1rem; color:#5a4a40; font-size:clamp(16px,1.7vw,18px);
  letter-spacing:.01em; line-height:1.55;
}
.why2x2__content p{
  margin:.75rem 0; font-size:clamp(15px,1.6vw,17px); line-height:1.55; letter-spacing:.01em;
}
.why2x2__list{
  counter-reset:why; list-style:none; padding:0; margin:3em 0 0; display:grid; gap:.65rem;
}
.why2x2__list li{ position:relative; padding-left:3em; margin-bottom:1em; }
.why2x2__list li::before{
  counter-increment:why; content:counter(why);
  position:absolute; left:0; top:.05rem; width:2rem; height:2rem; border-radius:999px;
  display:grid; place-items:center; font-weight:800; color:var(--ink);
  background:linear-gradient(180deg,var(--peach-1),var(--peach-2));
  box-shadow:0 6px 16px rgba(255,159,114,.25);
}

/* =========================
   REVIEWS
========================= */
.reviews{ background:#fff; color:var(--ink); padding:clamp(40px,6vw,96px) 20px; }
.reviews__head{ max-width:650px; margin:0 20em 3em; text-align:left; }
.reviews__head h2{ margin:0 0 .5rem; font-weight:900; font-size:clamp(28px,4.5vw,48px); }
.reviews__head p{
  margin:0; font-size:clamp(16px,1.6vw,18px); line-height:1.55; letter-spacing:.01em; color:#5a4a40;
}
.reviews__viewport{ position:relative; max-width:1280px; margin:0 auto; }
.reviews__track{
  display:flex; gap:16px; overflow-x:auto; scroll-snap-type:x mandatory;
  padding:8px; -webkit-overflow-scrolling:touch; overscroll-behavior-x:contain; scrollbar-width:none;
}
.reviews__track::-webkit-scrollbar{ display:none; }
.review-card{
  scroll-snap-align:center; scroll-snap-stop:always; flex:0 0 auto;
  width:min(86vw,780px); min-height:260px; border-radius:16px; background:#fff;
  border:1px solid #F1ECE7; box-shadow:0 2px 0 rgba(0,0,0,.05) inset, 0 10px 28px rgba(0,0,0,.06);
  padding:3em; transform:scale(.98);
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.review-card.is-active{ transform:scale(1.02); border-color:#FFD9C6; box-shadow:0 16px 40px rgba(255,159,114,.18); }
.review-quote{ margin:0 0 .75rem; font-size:clamp(18px,2.1vw,22px); line-height:1.5; }
.review-author{ display:block; font-style:normal; font-weight:700; letter-spacing:.01em; color:#5a4a40; }
.reviews__nav{
  position:absolute; top:50%; transform:translateY(-50%); width:44px; height:44px; border:0; border-radius:999px;
  background:rgba(0,0,0,.35); color:#fff; font-size:26px; line-height:44px; text-align:center; cursor:pointer; z-index:2;
  -webkit-tap-highlight-color:transparent;
}
.reviews__nav:hover{ background:rgba(0,0,0,.5); }
.reviews__nav.prev{ left:-4em; }
.reviews__nav.next{ right:-4em; }
.reviews__dots{ display:flex; gap:8px; justify-content:center; margin-top:14px; }
.reviews__dots button{
  width:9px; height:9px; border-radius:999px; border:0; background:rgba(0,0,0,.18); cursor:pointer; padding:0;
}
.reviews__dots button[aria-selected="true"]{ background:#000; width:22px; }

/* =========================
   SUBSCRIPTIONS
========================= */
.subs{ background:#fff; color:var(--ink); padding:clamp(40px,6vw,96px) 20px; }
.subs .container{ max-width:1280px; margin:0 auto; }
.subs__head{ max-width:880px; margin:0 auto 24px; text-align:center; }
.subs__eyebrow{
  display:inline-block; margin:0 0 .4rem; padding:.25rem .6rem;
  font-weight:800; letter-spacing:.03em; font-size:.9rem; color:var(--ink);
  border-radius:999px; background:linear-gradient(180deg,#FFE6CF,#FFD2B6);
}
.subs__head h2{ margin:.2rem 0 .8em; font-weight:900; font-size:clamp(28px,4.6vw,48px); }
.subs__lead{
  margin:0 auto 3em; max-width:760px; font-size:clamp(16px,1.6vw,18px);
  line-height:1.55; letter-spacing:.01em; color:#5a4a40;
}
.subs__grid{
  display:grid; gap:16px; grid-template-columns:repeat(3,minmax(0,1fr)); align-items:stretch;
}
.plan{
  position:relative; background:#fff; border:1px solid #F1ECE7; border-radius:16px;
  box-shadow:0 2px 0 rgba(0,0,0,.05) inset, 0 10px 28px rgba(0,0,0,.06);
  padding:2.5em; display:flex; flex-direction:column; gap:.75rem;
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.plan:hover{ transform:translateY(-2px); box-shadow:0 16px 40px rgba(255,159,114,.16); border-color:#FFD9C6; }
.plan__badge{
  position:absolute; top:12px; right:12px; padding:.28rem .55rem; border-radius:999px;
  background:linear-gradient(180deg,var(--peach-1),var(--peach-2));
  color:var(--ink); font-weight:800; font-size:.85rem; letter-spacing:.02em; box-shadow:0 8px 20px rgba(255,159,114,.28);
}
.is-featured{ border-color:#FFD9C6; box-shadow:0 2px 0 rgba(0,0,0,.05) inset, 0 18px 46px rgba(255,159,114,.22); }
.plan__title{ margin:0; font-weight:900; font-size:clamp(18px,2.2vw,22px); }
.plan__desc{ margin:0; color:#5a4a40; letter-spacing:.01em; line-height:1.55; }
.plan__meta{ display:flex; align-items:baseline; gap:.75rem; margin-top:.25rem; }
.plan__price{ font-weight:900; font-size:clamp(22px,3vw,28px); }
.plan__amount{ font-variant-numeric:tabular-nums; }
.plan__dur{ color:#7a6a60; font-weight:600; }

/* =========================
   CLOSING
========================= */
.closing{
  position:relative; overflow:hidden; min-height:72svh;
  display:grid; place-items:center; padding:clamp(40px,6vw,96px) 20px;
  color:var(--ink); background:#fff;
}
.closing::before{
  content:""; position:absolute; inset:-10%;
  background:
    radial-gradient(60% 50% at 80% 20%, rgba(255,195,150,.25), rgba(255,195,150,0) 60%),
    radial-gradient(70% 60% at 15% 85%, rgba(255,159,114,.18), rgba(255,159,114,0) 65%),
    linear-gradient(#fff,#fff);
  z-index:0; pointer-events:none;
}
.closing__wrap{ position:relative; z-index:1; max-width:980px; text-align:center; }
.closing h2{
  margin:0 0 .8em; font-weight:900; font-size:clamp(28px,4.8vw,52px); letter-spacing:-.01em;
}
.closing__lead{
  margin:.25rem 0 1rem; font-size:clamp(16px,1.7vw,20px);
  line-height:1.5; letter-spacing:.01em; color:#5a4a40;
}
.closing p{ margin:.6rem 0; font-size:clamp(15px,1.6vw,18px); line-height:1.55; letter-spacing:.01em; }
.closing__actions{ margin-top:1.2rem; display:flex; gap:.75rem; justify-content:center; flex-wrap:wrap; }

/* =========================
   MEDIA QUERIES (все вместе)
========================= */

/* reduce motion */
@media (prefers-reduced-motion: reduce){
  .slide, .step-card{ transition:none; }
  .btn-ghost{ transition:none; }
}


/* экраны до ~1400 шириной (твои 1380×780 попадают сюда) */
@media (max-width: 1400px) {
  .about__content{
    bottom: 5vh;
    max-height: calc(50vh - 5vh);
    max-width: min(640px, 60vw);
    padding: 2rem;
  }
  .about__content h3{ font-size: clamp(20px, 2.2vw, 30px); }
  .about__content p { font-size: clamp(14px, 1.2vw, 16px); }
}

@media (max-height: 850px) {
  .about__content h3 { font-size: 1.8rem; }
  .about__content p  { font-size: 0.9rem; }
}

@media (max-height: 750px) {
  .about__content h3 { font-size: 1.6rem; }
  .about__content p  { font-size: 0.8rem; }
}


/* мобильные */
@media (max-width: 767px){
  .about__media, .about__img{ height: 100svh; } /* корректная высота на мобиле */
  .about__content{
    left: 0; right: 0; transform: none;
    bottom: 0;
    max-height: 50svh;            /* нижняя половина экрана */
    border-radius: 0;
    padding: 1.1rem 1rem 1.2rem;
  }
  .about__content h3{ font-size: 20px; }
  .about__content p { font-size: 14px; }
}

/* ≤ 1024px */
@media (max-width:1024px){

  .hero{ height: 90svh; }
  .hero__content{
    left: 1rem; right: 1rem;
    bottom: max(1rem, env(safe-area-inset-bottom));
  }
  .hero__content h1{
    margin: 0 0.5em 1em;
    font-size: 4.5em;
    line-height: 1.1;
  }
  .about {
    min-height: 70vh;
    }
  .about__media, .about__img {
    height: 70vh;
    }
  .about__content{ left:2em; right:2em; bottom:2em; max-width:none; padding:2em 2em; }

  .about__content h3 {
    margin: 0 0 1em;
    font-size: 2.5em;
    }
  .about__content p {
    margin: 0 0 1em;
    font-size: 1.4em;
    }

  .btn-cta {
        margin-top: 1.2em;
        padding: .9rem 1.15rem;
        font-size: 1.4em;
    }
  .split__left {
    max-width: 85%;
    margin-left: 2em;
    margin-right: 2em;
}
  .split__left h2 {
    font-size: 3em
    }
  .split__left p {
    margin: .6rem 0;
    font-size: 1.4em;
    line-height: 1.55;
    letter-spacing: .01em;
}

  .why2x2__wrap{ grid-template-columns:1fr; }
  .why2x2__content {
        max-width: 40em;
        margin: 0 2em 1em 2em;
    }

  .why2x2__content h2 {
        font-size: 3em;
    }

  .why2x2__content .lead {
        font-size: 1.4em
    }
  .why2x2__content p {
        font-size: 1.4em
    }
  .why2x2__list {
        font-size: 1.4em
    }
  .why2x2__grid{ height:auto; }
  .tile img{ aspect-ratio:3 / 4; }

  .subs__grid{ grid-template-columns:1fr 1fr; }
  .split{ grid-template-columns:1fr; min-height: 75svh; }
  .slider{ height:35svh; }

  .flow__head {
        max-width: 30em;
        margin: 0 2em 3em;
    }
  .flow__head h2 {
    margin: 0 0 1rem;
    font-weight: 900;
    font-size: 3em;
    }

  .flow__head p {
        margin: 0 0 2em;
        font-size: 1.4em;
        }
  .flow__nav.prev{ left:6px; } .flow__nav.next{ right:6px; }

  .step-chip {
        top: 2em;
        left: 2em;
        width: 2em;
        height: 2em;
        font-size: 1.4em;
    }
  .step-card h3 {
        margin: 0.3em 1em .2em 3em;
        font-size: 2em;
    }

    .step-sub {
        margin: 0 0 .85rem 5em;
        color: #5a4a40;
        letter-spacing: .01em;
        font-size: 1.2em;
    }

  .shot img{ aspect-ratio:auto; }

  .reviews__nav.prev{ left:6px; } .reviews__nav.next{ right:6px; }
  .review-card{ width:80vw; }

  .reviews__head {
        max-width: 30em;
        margin: 0 2em 3em;
    }
  .reviews__head h2 {
        margin: 0 0 1rem;
        font-weight: 900;
        font-size: 3em;
        }

  .reviews__head p {
        margin: 0 0 2em;
        font-size: 1.4em;
        }
  .review-quote {
            margin: 0 0 .75rem;
            font-size: 1.6em;
            line-height: 1.5;
    }

  .review-author {
        font-size: 1.6em;
    }

  .reviews__nav {
        width: 1.5em;
        font-size: 2em;
    }
  .review-card {
        padding: 4em;
    }

  .subs__head {
        max-width: 50em;
    }
  .subs__head h2 {
        margin: 0 0 1rem;
        font-weight: 900;
        font-size: 3em;
        }

  .subs__head p {
        font-size: 1.4em;
        }
  .subs__lead br{ display:none; }             /* убираем переносы в тексте */

  .subs__grid{
    display: flex;
    gap: 1em;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    padding: 6px 10px 12px;
    margin: 0 -10px;                          /* на весь экран до краёв */
    scrollbar-width: none;
  }
  .subs__grid::-webkit-scrollbar{ display:none; }

  .plan{
    flex: 0 0 65vw;                           /* одна карточка ~ во весь экран */
    scroll-snap-align: center;
    padding: 2em;
    border-radius: 14px;
  }
  .plan__title {
        font-size: 2em;
    }
  .plan__desc {
        font-size: 1.4em
    }
  .plan__price {
        font-size: 1.6em;
    }
  .plan__meta {
        align-items: center;
        gap: 2em;
        margin-top: .25rem;
    }
  .plan__dur {
        font-size: 1.4em
    }
  .plan__badge{ top: 1em; right: 1em; }

  .closing {
        min-height: 50svh;
        padding: 1.5em;
    }
  .closing h2 {
        font-size: 3em;
    }
  .closing p {
        font-size: 1.6em;
    }
}



