/* ================== RESET ================== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
body{
  font-family:'Inter',system-ui,-apple-system,sans-serif;
  background:#0a0908;
  color:#ece6dd;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
  line-height:1.5;
  min-height:100svh;
  touch-action:pan-y;
  overscroll-behavior-y:none;
}
body.is-locked{overflow:hidden;touch-action:none}

/* Skip link */
.skip-link{
  position:absolute;left:-9999px;top:0;
  background:#d8b078;color:#0a0908;
  padding:8px 14px;font-size:13px;font-weight:600;z-index:99999;
}
.skip-link:focus{left:8px;top:8px}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
input,textarea,select{font:inherit;color:inherit}
::selection{background:#d8b078;color:#0a0908}

:root{
  --bg:#0a0908;
  --bg-2:#13110f;
  --ink:#ece6dd;
  --ink-dim:rgba(236,230,221,.55);
  --ink-faint:rgba(236,230,221,.18);
  --gold:#d8b078;
  --gold-dim:#a48655;
  --line:rgba(236,230,221,.12);
  --serif:'Cormorant Garamond',Georgia,serif;
}

/* ================== LOADER ================== */
.loader{
  position:fixed;inset:0;z-index:9999;background:#0a0908;
  display:flex;align-items:center;justify-content:center;
  transition:opacity .8s ease,visibility .8s ease;
}
.loader.is-hidden{opacity:0;visibility:hidden;pointer-events:none}
.loader__inner{text-align:center;width:min(380px,80vw)}
.loader__brand{
  font-family:var(--serif);font-size:42px;letter-spacing:.32em;
  color:var(--gold);margin-bottom:36px;font-weight:300;
}
.loader__bar{height:1px;background:var(--ink-faint);overflow:hidden;width:100%}
.loader__bar-fill{height:100%;background:var(--gold);width:0%;transition:width .4s ease}
.loader__hint{
  font-size:11px;letter-spacing:.32em;text-transform:uppercase;
  color:var(--ink-dim);margin-top:24px;
}

/* ================== NAV ================== */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:22px 48px;
  transition:background .4s ease,padding .4s ease;
}
.nav.is-scrolled{
  background:rgba(10,9,8,.92);
  backdrop-filter:blur(6px) saturate(140%);
  -webkit-backdrop-filter:blur(6px) saturate(140%);
  padding:14px 48px;
  border-bottom:1px solid var(--line);
}
.nav__logo{
  font-family:var(--serif);font-size:24px;letter-spacing:.2em;
  color:var(--gold);font-weight:300;
}
.nav__links{display:flex;gap:32px}
.nav__links a{
  font-size:12px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--ink-dim);transition:color .25s ease;
}
.nav__links a:hover{color:var(--ink)}
.nav__cta{
  font-size:12px;letter-spacing:.18em;text-transform:uppercase;
  padding:11px 22px;border:1px solid var(--ink-faint);border-radius:999px;
  transition:all .3s ease;
}
.nav__cta:hover{background:var(--gold);color:#0a0908;border-color:var(--gold)}

/* Burger */
.nav__burger{
  display:none;
  width:38px;height:38px;
  position:relative;
  border:1px solid var(--ink-faint);border-radius:8px;
  background:transparent;
}
.nav__burger span{
  position:absolute;left:9px;right:9px;height:1px;background:var(--ink);
  transition:transform .35s ease,opacity .25s ease,top .35s ease;
}
.nav__burger span:nth-child(1){top:13px}
.nav__burger span:nth-child(2){top:18px}
.nav__burger span:nth-child(3){top:23px}
.nav__burger.is-open span:nth-child(1){top:18px;transform:rotate(45deg);background:var(--gold)}
.nav__burger.is-open span:nth-child(2){opacity:0}
.nav__burger.is-open span:nth-child(3){top:18px;transform:rotate(-45deg);background:var(--gold)}

@media (max-width:860px){
  .nav{padding:14px 18px}
  .nav__links{display:none}
  .nav__cta{display:none}
  .nav__burger{display:block}
  .nav.is-scrolled{padding:10px 18px}
  .nav__logo{font-size:20px}
}

/* ================== MOBILE DRAWER ================== */
.mobile-menu{
  position:fixed;inset:0;z-index:90;
  background:rgba(10,9,8,.96);
  backdrop-filter:blur(6px) saturate(140%);
  -webkit-backdrop-filter:blur(6px) saturate(140%);
  display:flex;flex-direction:column;justify-content:center;align-items:center;
  padding:80px 28px 40px;
  opacity:0;visibility:hidden;pointer-events:none;
  transition:opacity .4s ease,visibility .4s ease;
}
.mobile-menu.is-open{opacity:1;visibility:visible;pointer-events:auto}
.mobile-menu__nav{display:flex;flex-direction:column;align-items:center;gap:18px;width:100%}
.mobile-menu__nav a{
  font-family:var(--serif);font-weight:300;
  font-size:32px;letter-spacing:.04em;color:var(--ink);
  padding:6px 12px;
  transition:color .3s ease,transform .3s ease;
}
.mobile-menu__nav a:hover,.mobile-menu__nav a:active{color:var(--gold)}
.mobile-menu__cta{
  margin-top:18px;
  font-family:'Inter',sans-serif !important;
  font-size:13px !important;letter-spacing:.22em;text-transform:uppercase;
  color:#0a0908 !important;background:var(--gold);
  padding:16px 32px !important;border-radius:999px;font-weight:500;
}
.mobile-menu__contacts{
  margin-top:48px;display:flex;flex-direction:column;align-items:center;gap:12px;
}
.mobile-menu__contacts a{
  font-size:13px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--ink-dim);
}
.mobile-menu__contacts a:hover{color:var(--gold)}

/* ================== STORY (TUNNEL) ================== */
.story{
  position:relative;
  /* 7 chapters × ~100svh — svh для стабильного pin на iOS Safari */
  height:780svh;
  background:#0a0908;
}
.story__sticky{
  position:sticky;top:0;
  height:100svh;
  width:100%;
  overflow:hidden;
}
.story__canvas{
  position:absolute;inset:0;width:100%;height:100%;display:block;
}
.story__vignette{
  position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(ellipse at center,rgba(10,9,8,.55) 0%,transparent 35%,rgba(10,9,8,.65) 100%),
    linear-gradient(180deg,rgba(10,9,8,.55) 0%,transparent 18%,transparent 78%,rgba(10,9,8,.75) 100%);
}

/* Story frames */
.frames{
  position:absolute;inset:0;pointer-events:none;
  display:flex;align-items:center;justify-content:center;
}
.frame{
  position:absolute;inset:0;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;padding:0 24px;
  opacity:0;transform:translateY(40px);
  transition:opacity .9s ease,transform .9s ease;
  pointer-events:none;
}
.frame.is-active{opacity:1;transform:translateY(0)}

/* Soft frosted-glass aura behind text — no visible frame */
.frame__panel{
  position:relative;
  display:inline-flex;flex-direction:column;align-items:center;
  padding:80px clamp(40px,8vw,140px) 90px;
  background:radial-gradient(ellipse at center,
    rgba(10,9,8,.78) 0%,
    rgba(10,9,8,.55) 28%,
    rgba(10,9,8,.25) 60%,
    transparent 100%);
  backdrop-filter:blur(6px) saturate(135%) brightness(.78);
  -webkit-backdrop-filter:blur(6px) saturate(135%) brightness(.78);
  /* fade blur smoothly into the tunnel — no rectangular edge */
  mask-image:radial-gradient(ellipse at center,#000 0%,#000 38%,rgba(0,0,0,.4) 70%,transparent 100%);
  -webkit-mask-image:radial-gradient(ellipse at center,#000 0%,#000 38%,rgba(0,0,0,.4) 70%,transparent 100%);
  max-width:min(94vw,1080px);
}
.frame__panel--hero{
  padding:90px clamp(48px,9vw,160px) 100px;
}
.frame__panel--finale{
  background:radial-gradient(ellipse at center,
    rgba(216,176,120,.14) 0%,
    rgba(10,9,8,.55) 30%,
    rgba(10,9,8,.22) 65%,
    transparent 100%);
}
.frame__eyebrow{
  font-size:11px;letter-spacing:.42em;text-transform:uppercase;
  color:var(--gold);margin-bottom:28px;
  display:inline-flex;align-items:center;gap:14px;
  text-shadow:0 2px 14px rgba(0,0,0,.95);
}
.frame__eyebrow::before,.frame__eyebrow::after{
  content:'';width:30px;height:1px;background:var(--gold);opacity:.7;
}
.frame__title{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(64px,14vw,220px);
  letter-spacing:.04em;line-height:.95;
  color:var(--ink);
  text-shadow:
    0 2px 18px rgba(0,0,0,.95),
    0 8px 60px rgba(0,0,0,.85),
    0 0 120px rgba(0,0,0,.7);
}
.frame__title--m{
  font-size:clamp(40px,7vw,98px);line-height:1.04;
}
.frame__title--xl{
  font-size:clamp(56px,11vw,170px);
}
.frame__title em{
  font-style:italic;color:var(--gold);font-weight:400;
}
.frame__sub{
  margin-top:24px;max-width:620px;
  font-size:clamp(14px,1.4vw,18px);
  letter-spacing:.02em;
  color:var(--ink);
  text-shadow:
    0 2px 14px rgba(0,0,0,.95),
    0 6px 40px rgba(0,0,0,.85);
}
.frame__scroll{
  position:absolute;bottom:48px;left:50%;transform:translateX(-50%);
  font-size:11px;letter-spacing:.32em;text-transform:uppercase;
  color:var(--ink-dim);
  animation:bounce 2.4s ease-in-out infinite;
}
@keyframes bounce{
  0%,100%{transform:translate(-50%,0);opacity:.55}
  50%{transform:translate(-50%,8px);opacity:1}
}

.progress{
  position:absolute;left:48px;bottom:36px;width:200px;height:1px;
  background:var(--ink-faint);
}
.progress__bar{
  height:100%;background:var(--gold);width:0%;transition:width .15s linear;
}
@media (max-width:860px){
  .progress{left:18px;width:100px;bottom:24px}
  .frame__scroll{bottom:24px;font-size:10px;letter-spacing:.24em}
  .story{height:560svh}
  .frame__panel{
    padding:60px 24px 70px;
    backdrop-filter:blur(6px) saturate(130%) brightness(.78);
    -webkit-backdrop-filter:blur(6px) saturate(130%) brightness(.78);
  }
  .frame__panel--hero{padding:70px 24px 80px}
  .frame__title{font-size:clamp(56px,18vw,120px)}
  .frame__title--m{font-size:clamp(32px,8.4vw,56px);line-height:1.08}
  .frame__title--xl{font-size:clamp(48px,15vw,90px)}
  .frame__sub{font-size:14px;margin-top:20px;padding:0 6px}
  .frame__eyebrow{font-size:10px;letter-spacing:.32em;margin-bottom:18px}
  .frame__eyebrow::before,.frame__eyebrow::after{width:18px}
}
@media (max-width:480px){
  .story{height:520svh}
  .frame__panel{padding:50px 20px 60px}
  .frame__title{font-size:clamp(48px,16vw,90px)}
  .frame__title--m{font-size:clamp(28px,8vw,46px)}
}

/* ================== GALLERY (CYLINDRIX) ================== */
.gallery{
  position:relative;
  height:200svh;
  background:#0a0908;
}
.gallery__sticky{
  position:sticky;top:0;height:100svh;width:100%;overflow:hidden;
}
.gallery__canvas{
  position:absolute;inset:0;width:100%;height:100%;display:block;
}
.gallery__overlay{
  position:absolute;inset:0;pointer-events:none;
  display:flex;flex-direction:column;justify-content:space-between;
  padding:120px 48px 48px;
}
.gallery__head{text-align:center}
.gallery__eyebrow{
  font-size:11px;letter-spacing:.42em;text-transform:uppercase;
  color:var(--gold);margin-bottom:14px;
}
.gallery__title{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(48px,7vw,96px);
  letter-spacing:.04em;line-height:1;
}
.gallery__hint{
  text-align:center;font-size:11px;letter-spacing:.32em;text-transform:uppercase;
  color:var(--ink-dim);
}

/* Mobile gallery fallback (image grid instead of WebGL cylinder) */
.gallery__mobile{display:none}
@media (max-width:760px){
  .gallery{height:auto;min-height:auto}
  .gallery__sticky{position:relative;height:auto}
  .gallery__canvas{display:none}
  .gallery__overlay{display:none}
  .gallery__mobile{
    display:block;
    padding:80px 20px 64px;background:#0a0908;
  }
  .gallery__mobile-title{
    font-family:var(--serif);font-weight:300;
    font-size:clamp(36px,9vw,56px);letter-spacing:.02em;line-height:1;
    text-align:center;margin-bottom:8px;
  }
  .gallery__mobile-sub{
    text-align:center;font-size:11px;letter-spacing:.32em;text-transform:uppercase;
    color:var(--gold);margin-bottom:32px;
  }
  .gallery__mobile-grid{
    display:grid;grid-template-columns:repeat(2,1fr);gap:8px;
  }
  .gallery__mobile-grid img{
    width:100%;aspect-ratio:3/4;object-fit:cover;
    border-radius:3px;
    filter:saturate(.94) contrast(1.02);
  }
  .gallery__mobile-grid a{
    display:block;overflow:hidden;border-radius:3px;
  }
}
@media (max-width:860px){
  .gallery__overlay{padding:100px 22px 32px}
}

/* ================== SERVICES (4 cards) ================== */
/* skill 3.2: разгружаем layout/paint для секций ниже первого экрана */
.services, .wedding, .team, .prices, .contact{
  content-visibility:auto;
  contain-intrinsic-size:1px 1200px;
}
.services{
  padding:140px 48px;
  background:linear-gradient(180deg,#0a0908 0%,#13110f 100%);
  border-top:1px solid var(--line);
}
.services__head{text-align:center;max-width:780px;margin:0 auto 80px}
.services__eyebrow{
  font-size:11px;letter-spacing:.42em;text-transform:uppercase;
  color:var(--gold);margin-bottom:18px;
}
.services__title{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(40px,5.6vw,72px);line-height:1.05;letter-spacing:.02em;
}
.services__title em{font-style:italic;color:var(--gold)}
.services__grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:18px;
  max-width:1440px;margin:0 auto;
}
.service{
  position:relative;display:flex;flex-direction:column;
  background:#0a0908;border:1px solid var(--line);border-radius:4px;
  overflow:hidden;
  transition:transform .45s cubic-bezier(.2,.8,.2,1),border-color .35s ease;
}
.service:hover{transform:translateY(-6px);border-color:rgba(216,176,120,.4)}
.service__media{
  position:relative;aspect-ratio:3/4;overflow:hidden;
}
.service__media img{
  width:100%;height:100%;object-fit:cover;
  filter:saturate(.92) contrast(1.02);
  transition:transform 1.4s cubic-bezier(.2,.8,.2,1);
}
.service:hover .service__media img{transform:scale(1.06)}
.service__media::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 30%,rgba(10,9,8,.55) 100%);
}
.service__body{padding:24px 24px 28px}
.service__num{
  font-family:var(--serif);font-style:italic;
  color:var(--gold);font-size:14px;margin-bottom:14px;
}
.service__name{
  font-family:var(--serif);font-weight:300;
  font-size:30px;line-height:1.05;letter-spacing:.02em;
  margin-bottom:14px;
}
.service__desc{
  font-size:13px;color:var(--ink-dim);line-height:1.55;
  margin-bottom:18px;min-height:82px;
}
.service__price{
  font-size:12px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--gold);padding-top:14px;border-top:1px solid var(--line);
}
@media (max-width:1100px){
  .services__grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:760px){
  .services{padding:72px 18px}
  .services__head{margin-bottom:48px}
  .services__title{font-size:clamp(28px,7vw,42px)}
  .services__grid{grid-template-columns:1fr;gap:14px}
  .service__body{padding:20px}
  .service__name{font-size:24px}
  .service__desc{min-height:auto}
}

/* ================== WEDDING ================== */
.wedding{
  padding:140px 48px;
  background:linear-gradient(180deg,#0a0908 0%,#13110f 100%);
  position:relative;overflow:hidden;
}
.wedding::before{
  content:'';position:absolute;top:-200px;left:-200px;
  width:500px;height:500px;border-radius:50%;
  background:radial-gradient(circle,rgba(216,176,120,.08),transparent 60%);
  pointer-events:none;
}
.wedding__inner{
  max-width:1280px;margin:0 auto;
  display:grid;grid-template-columns:1fr 1fr;gap:96px;align-items:center;
}
.wedding__eyebrow{
  font-size:11px;letter-spacing:.42em;text-transform:uppercase;
  color:var(--gold);margin-bottom:24px;
}
.wedding__title{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(40px,5.5vw,82px);line-height:1.02;
  margin-bottom:28px;letter-spacing:.02em;
}
.wedding__title em{font-style:italic;color:var(--gold)}
.wedding__lead{
  font-size:18px;color:var(--ink-dim);max-width:520px;margin-bottom:40px;line-height:1.65;
}
.wedding__list{list-style:none;margin-bottom:48px}
.wedding__list li{
  padding:18px 0;border-top:1px solid var(--line);
  display:flex;align-items:flex-start;gap:18px;
  font-size:15px;color:var(--ink);
}
.wedding__list li:last-child{border-bottom:1px solid var(--line)}
.wedding__list span{
  color:var(--gold);font-family:var(--serif);font-size:14px;font-style:italic;
  min-width:24px;
}
.wedding__cta{
  display:inline-flex;align-items:center;gap:14px;
  padding:18px 32px;border:1px solid var(--gold);border-radius:999px;
  font-size:13px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--gold);transition:all .35s ease;
}
.wedding__cta span{transition:transform .35s ease;display:inline-block}
.wedding__cta:hover{background:var(--gold);color:#0a0908}
.wedding__cta:hover span{transform:translateX(6px)}

.wedding__media{
  position:relative;height:640px;
}
.wedding__card{
  position:absolute;border-radius:4px;overflow:hidden;
  box-shadow:0 30px 90px -20px rgba(0,0,0,.7);
  transition:transform .8s cubic-bezier(.2,.8,.2,1);
}
.wedding__card img{width:100%;height:100%;object-fit:cover;filter:saturate(.92) contrast(1.02)}
.wedding__card--1{top:0;left:0;width:62%;height:65%;z-index:2}
.wedding__card--2{bottom:0;right:0;width:55%;height:55%;z-index:1}
.wedding__card--3{top:18%;right:0;width:30%;height:30%;z-index:3;border:1px solid rgba(216,176,120,.2)}
.wedding__media:hover .wedding__card--1{transform:translate(-12px,-12px)}
.wedding__media:hover .wedding__card--2{transform:translate(10px,10px)}
.wedding__media:hover .wedding__card--3{transform:translate(0,-8px) rotate(-2deg)}

@media (max-width:960px){
  .wedding{padding:72px 18px}
  .wedding__inner{grid-template-columns:1fr;gap:48px}
  .wedding__media{height:440px}
  .wedding__lead{font-size:16px;margin-bottom:32px}
  .wedding__list{margin-bottom:36px}
  .wedding__cta{padding:16px 26px;font-size:12px}
}
@media (max-width:480px){
  .wedding__media{height:340px}
  .wedding__card--1{width:74%;height:60%}
  .wedding__card--2{width:64%;height:50%}
  .wedding__card--3{width:38%;height:32%;top:8%}
}

/* ================== TEAM ================== */
.team{
  padding:140px 48px;background:#0a0908;
  border-top:1px solid var(--line);
}
.team__head{text-align:center;max-width:680px;margin:0 auto 80px}
.team__eyebrow{
  font-size:11px;letter-spacing:.42em;text-transform:uppercase;
  color:var(--gold);margin-bottom:18px;
}
.team__title{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(40px,5.6vw,72px);line-height:1.05;letter-spacing:.02em;
  margin-bottom:18px;
}
.team__lead{
  font-size:16px;color:var(--ink-dim);line-height:1.6;
}
.team__grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:32px 28px;
  max-width:1280px;margin:0 auto;
}
.member{
  position:relative;
}
.member__photo{
  position:relative;aspect-ratio:3/4;overflow:hidden;border-radius:4px;
  margin-bottom:18px;
}
.member__photo img{
  width:100%;height:100%;object-fit:cover;
  filter:saturate(.94) contrast(1.02);
  transition:transform 1.2s cubic-bezier(.2,.8,.2,1);
}
.member:hover .member__photo img{transform:scale(1.05)}
.member__photo::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 60%,rgba(10,9,8,.5) 100%);
  pointer-events:none;
}
.member__role{
  font-size:11px;letter-spacing:.24em;text-transform:uppercase;
  color:var(--gold);margin-bottom:8px;
}
.member__name{
  font-family:var(--serif);font-weight:300;
  font-size:28px;line-height:1.1;letter-spacing:.02em;margin-bottom:8px;
}
.member__years{
  font-size:13px;color:var(--ink-dim);line-height:1.5;
}
@media (max-width:960px){
  .team{padding:72px 18px}
  .team__head{margin-bottom:48px}
  .team__title{font-size:clamp(34px,8vw,50px)}
  .team__grid{grid-template-columns:repeat(2,1fr);gap:24px 14px}
  .member__name{font-size:22px}
}
@media (max-width:480px){
  .team__grid{grid-template-columns:repeat(2,1fr);gap:18px 10px}
  .member__role{font-size:10px;letter-spacing:.18em;margin-bottom:6px}
  .member__name{font-size:18px}
  .member__years{font-size:12px}
}

/* ================== PRICES ================== */
.prices{
  padding:140px 48px;background:#0a0908;
  border-top:1px solid var(--line);
}
.prices__head{text-align:center;max-width:600px;margin:0 auto 80px}
.prices__eyebrow{
  font-size:11px;letter-spacing:.42em;text-transform:uppercase;
  color:var(--gold);margin-bottom:14px;
}
.prices__title{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(36px,5vw,66px);line-height:1.05;
}
.prices__grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:18px;
  max-width:1440px;margin:0 auto;
}
@media (max-width:1200px){
  .prices__grid{grid-template-columns:repeat(2,1fr)}
}
.price{
  position:relative;padding:36px 28px;
  border:1px solid var(--line);border-radius:4px;
  background:linear-gradient(180deg,rgba(255,255,255,.015) 0%,transparent 100%);
  transition:border-color .35s ease,transform .35s ease;
}
.price:hover{border-color:rgba(216,176,120,.4);transform:translateY(-4px)}
.price--featured{
  border-color:var(--gold);
  background:linear-gradient(180deg,rgba(216,176,120,.06) 0%,transparent 100%);
}
.price__badge{
  position:absolute;top:-1px;right:24px;transform:translateY(-50%);
  background:var(--gold);color:#0a0908;
  padding:6px 14px;font-size:10px;letter-spacing:.24em;text-transform:uppercase;
  border-radius:999px;font-weight:600;
}
.price__name{
  font-size:13px;letter-spacing:.24em;text-transform:uppercase;
  color:var(--ink-dim);margin-bottom:24px;
}
.price__amount{
  font-family:var(--serif);font-weight:300;
  font-size:48px;line-height:1;color:var(--ink);margin-bottom:28px;
  letter-spacing:.02em;
}
.price__amount span{
  display:block;font-size:13px;letter-spacing:.24em;text-transform:uppercase;
  color:var(--ink-dim);font-family:'Inter';margin-bottom:8px;
}
.price__amount sup{
  font-size:18px;color:var(--ink-dim);margin-left:4px;font-weight:400;top:-22px;
}
.price__list{list-style:none;margin-bottom:36px}
.price__list li{
  padding:14px 0;font-size:14px;color:var(--ink);border-top:1px solid var(--line);
}
.price__list li:last-child{border-bottom:1px solid var(--line)}
.price__cta{
  display:block;text-align:center;
  padding:16px;border:1px solid var(--ink-faint);border-radius:999px;
  font-size:12px;letter-spacing:.2em;text-transform:uppercase;
  transition:all .3s ease;
}
.price__cta:hover{background:var(--ink);color:#0a0908;border-color:var(--ink)}
.price--featured .price__cta{
  background:var(--gold);color:#0a0908;border-color:var(--gold);
}
.price--featured .price__cta:hover{background:#0a0908;color:var(--gold)}

@media (max-width:960px){
  .prices{padding:72px 18px}
  .prices__head{margin-bottom:48px}
  .prices__title{font-size:clamp(28px,7vw,42px)}
  .prices__grid{grid-template-columns:1fr;gap:14px}
  .price{padding:30px 24px}
  .price__amount{font-size:40px;margin-bottom:24px}
}

/* ================== CONTACT ================== */
.contact{
  padding:140px 48px 0;background:#13110f;
  border-top:1px solid var(--line);
}
.contact__inner{
  max-width:1280px;margin:0 auto;
  display:grid;grid-template-columns:1fr 1fr;gap:96px;
  padding-bottom:120px;
}
.contact__title{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(48px,7vw,96px);line-height:1;letter-spacing:.02em;
  margin-bottom:28px;
}
.contact__lead{
  font-size:18px;color:var(--ink-dim);max-width:440px;margin-bottom:56px;line-height:1.6;
}
/* Messengers */
.messengers{
  display:grid;grid-template-columns:repeat(2,1fr);gap:14px;
  margin-bottom:48px;
}
.messenger{
  display:flex;align-items:center;gap:14px;
  padding:16px 18px;border:1px solid var(--line);border-radius:999px;
  font-size:14px;color:var(--ink);
  transition:all .35s ease;
  background:rgba(255,255,255,.01);
}
.messenger:hover{
  background:var(--gold);color:#0a0908;border-color:var(--gold);
  transform:translateY(-2px);
}
.messenger__icon{
  width:36px;height:36px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  background:rgba(216,176,120,.12);
  color:var(--gold);
  transition:background .35s ease,color .35s ease;
}
.messenger:hover .messenger__icon{
  background:#0a0908;color:var(--gold);
}
.messenger__icon--text{
  font-family:var(--serif);font-weight:500;font-size:18px;
  letter-spacing:.02em;
}
.messenger__txt{
  display:flex;flex-direction:column;gap:2px;line-height:1.2;
  font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--ink-dim);
}
.messenger:hover .messenger__txt{color:#0a0908}
.messenger__txt strong{
  font-weight:400;font-size:14px;letter-spacing:.02em;text-transform:none;
  color:var(--ink);
}
.messenger:hover .messenger__txt strong{color:#0a0908}
@media (max-width:540px){
  .messengers{grid-template-columns:1fr}
}

.contact__points{display:grid;gap:28px}
.contact__points > div{
  display:grid;grid-template-columns:120px 1fr;gap:20px;
  padding-bottom:20px;border-bottom:1px solid var(--line);
}
.contact__label{
  font-size:11px;letter-spacing:.32em;text-transform:uppercase;
  color:var(--gold);padding-top:3px;
}
.contact__value{font-size:16px}
.contact__form{display:grid;gap:22px;align-content:start}
.contact__form label{display:block}
.contact__form span{
  display:block;font-size:11px;letter-spacing:.24em;text-transform:uppercase;
  color:var(--ink-dim);margin-bottom:10px;
}
.contact__form input,.contact__form select,.contact__form textarea{
  width:100%;padding:14px 0;background:transparent;
  border:none;border-bottom:1px solid var(--line);
  color:var(--ink);font-size:16px;outline:none;
  transition:border-color .3s ease;
  font-family:inherit;resize:none;
}
.contact__form input::placeholder,.contact__form textarea::placeholder{color:rgba(236,230,221,.3)}
.contact__form input:focus,.contact__form select:focus,.contact__form textarea:focus{
  border-color:var(--gold);
}
.contact__form select{
  appearance:none;background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path d='M1 1l5 5 5-5' stroke='%23d8b078' stroke-width='1.4' fill='none'/></svg>") no-repeat right center;
  background-size:12px;padding-right:24px;
}
.contact__form select option{background:#13110f;color:var(--ink)}
.contact__form button{
  margin-top:8px;padding:18px;background:var(--gold);color:#0a0908;
  border-radius:999px;font-size:13px;letter-spacing:.2em;text-transform:uppercase;
  font-weight:600;transition:all .35s ease;
}
.contact__form button:hover{background:var(--ink);transform:translateY(-2px)}
.contact__priv{
  font-size:11px;color:var(--ink-faint);text-align:center;letter-spacing:.04em;
  line-height:1.6;
}
.contact__priv a{color:var(--ink-dim);border-bottom:1px solid var(--ink-faint)}
.contact__priv a:hover{color:var(--gold);border-color:var(--gold)}

/* 152-FZ consent checkbox */
.contact__consent{
  display:flex !important;align-items:flex-start;gap:12px;
  font-size:12px;line-height:1.55;color:var(--ink-dim);
  cursor:pointer;user-select:none;
  margin-top:4px;
}
.contact__consent input[type=checkbox]{
  appearance:none;-webkit-appearance:none;
  flex-shrink:0;
  width:18px;height:18px;margin-top:1px;
  border:1px solid var(--ink-faint);border-radius:3px;
  background:transparent;cursor:pointer;
  transition:background .25s ease,border-color .25s ease;
  position:relative;
}
.contact__consent input[type=checkbox]:checked{
  background:var(--gold);border-color:var(--gold);
}
.contact__consent input[type=checkbox]:checked::after{
  content:'';position:absolute;left:5px;top:1px;
  width:5px;height:10px;border:solid #0a0908;
  border-width:0 2px 2px 0;transform:rotate(45deg);
}
.contact__consent input[type=checkbox]:focus-visible{
  outline:2px solid var(--gold);outline-offset:2px;
}
.contact__consent span{display:block;flex:1}
.contact__consent a{
  color:var(--ink);border-bottom:1px solid var(--ink-faint);
}
.contact__consent a:hover{color:var(--gold);border-color:var(--gold)}
.contact__form button:disabled{
  opacity:.4;cursor:not-allowed;background:var(--ink-faint);color:var(--ink-dim);
}
.contact__form button:disabled:hover{transform:none;background:var(--ink-faint)}

@media (max-width:960px){
  .contact{padding:72px 18px 0}
  .contact__inner{grid-template-columns:1fr;gap:56px;padding-bottom:56px}
  .contact__title{font-size:clamp(40px,10vw,60px)}
  .contact__lead{font-size:16px;margin-bottom:40px}
  .contact__points > div{grid-template-columns:90px 1fr;gap:14px}
  .messengers{margin-bottom:36px}
}
@media (max-width:540px){
  .messengers{grid-template-columns:1fr}
  .messenger{padding:14px 16px}
  .contact__points > div{
    grid-template-columns:1fr;gap:6px;padding-bottom:18px;
  }
  .contact__label{padding-top:0;margin-bottom:2px}
  .contact__value{font-size:15px}
}

/* ================== FOOTER ================== */
.footer{
  border-top:1px solid var(--line);padding:40px 0 32px;
  display:grid;grid-template-columns:1.4fr 1fr;gap:28px;
  font-size:12px;letter-spacing:.06em;color:var(--ink-dim);
  max-width:1280px;margin:0 auto;
}
.footer__col{display:flex;flex-direction:column;gap:8px}
.footer__col:last-child{align-items:flex-end;text-align:right}
.footer__brand{font-size:13px;color:var(--ink);letter-spacing:.12em;margin-bottom:6px}
.footer__legal{font-size:11px;color:var(--ink-dim);line-height:1.55;letter-spacing:.02em}
.footer__socials{display:flex;gap:22px;margin-bottom:6px;flex-wrap:wrap;justify-content:flex-end}
.footer__socials a{transition:color .25s ease}
.footer__socials a:hover{color:var(--gold)}
.footer__links{display:flex;gap:18px;flex-wrap:wrap;justify-content:flex-end}
.footer__links a{
  font-size:11px;letter-spacing:.04em;color:var(--ink-dim);
  border-bottom:1px solid transparent;transition:color .25s ease,border-color .25s ease;
}
.footer__links a:hover{color:var(--gold);border-color:var(--gold)}
@media (max-width:760px){
  .footer{
    grid-template-columns:1fr;gap:24px;text-align:center;padding:32px 0;
  }
  .footer__col,.footer__col:last-child{align-items:center;text-align:center}
  .footer__socials,.footer__links{justify-content:center}
}

/* ================== COOKIE BANNER ================== */
.cookie{
  position:fixed;left:18px;right:18px;bottom:18px;
  z-index:200;
  background:rgba(13,11,10,.95);
  backdrop-filter:blur(6px) saturate(140%);
  -webkit-backdrop-filter:blur(6px) saturate(140%);
  border:1px solid var(--line);border-radius:14px;
  padding:18px 22px;
  box-shadow:0 24px 60px -12px rgba(0,0,0,.6);
  transform:translateY(20px);opacity:0;
  transition:transform .45s cubic-bezier(.2,.8,.2,1),opacity .45s ease;
  display:none;
}
.cookie[data-visible="true"]{display:block;transform:translateY(0);opacity:1}
.cookie__inner{
  display:grid;grid-template-columns:1fr auto;gap:18px;align-items:center;
  max-width:1180px;margin:0 auto;
}
.cookie__text{
  font-size:13px;line-height:1.55;color:var(--ink-dim);
}
.cookie__text a{color:var(--gold);border-bottom:1px solid rgba(216,176,120,.4)}
.cookie__text a:hover{color:var(--ink)}
.cookie__btns{display:flex;gap:10px;flex-shrink:0}
.cookie__btn{
  padding:11px 18px;font-size:12px;letter-spacing:.16em;text-transform:uppercase;
  border-radius:999px;font-weight:500;transition:all .3s ease;
  white-space:nowrap;
}
.cookie__btn--ok{background:var(--gold);color:#0a0908}
.cookie__btn--ok:hover{background:var(--ink);color:#0a0908}
.cookie__btn--no{
  background:transparent;color:var(--ink-dim);border:1px solid var(--ink-faint);
}
.cookie__btn--no:hover{color:var(--ink);border-color:var(--ink)}
@media (max-width:760px){
  .cookie{left:12px;right:12px;bottom:12px;padding:14px 16px;border-radius:12px}
  .cookie__inner{grid-template-columns:1fr;gap:14px}
  .cookie__btns{justify-content:flex-end}
  .cookie__text{font-size:12px}
}
