/* ============================================================
   Мастерская счастья — happy-lab.pro · редизайн
   Палитра = оригинал, перераспределённая для премиума (QPA C2)
   Канва: кремовый 70-80% · чернила: графит · акцент: коралл (CTA only)
   ============================================================ */

/* -------- Design tokens -------- */
:root{
  /* Brand hexes (из оригинала) + тинты/шейды того же тона */
  --cream:       #EFE7DB;   /* оригинал */
  --cream-1:     #F6F1E8;   /* светлее (канва) */
  --cream-2:     #FBF8F2;   /* почти белый тёплый */
  --sand:        #E3D89B;   /* оригинал бежевый */
  --sand-soft:   #DDD6AF;   /* оригинал бежевый-2 */
  --sand-deep:   #D2C079;   /* глубже для hover/border */
  --ink:         #1F201F;   /* оригинал графит */
  --ink-2:       #252525;   /* оригинал графит-2 */
  --ink-soft:    #57534d;   /* мягкий текст */
  --ink-mute:    #837d74;   /* приглушённый */
  --coral:       #FF8562;   /* оригинал коралл */
  --coral-deep:  #F95D51;   /* оригинал коралл-2 */
  --coral-press: #e6493d;   /* нажатие */
  --green:       #62C584;   /* оригинал — почти не используем */

  --line:        rgba(31,32,31,.12);
  --line-soft:   rgba(31,32,31,.07);
  --shadow-sm:   0 2px 10px rgba(60,40,24,.06);
  --shadow-md:   0 14px 40px -16px rgba(60,40,24,.28);
  --shadow-lg:   0 40px 90px -40px rgba(40,26,14,.45);
  --shadow-coral:0 18px 38px -14px rgba(233,73,61,.45);

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

  --maxw: 1200px;
  --gut: clamp(20px, 5vw, 56px);
  --sect: clamp(64px, 9vw, 132px);

  --ff-display: "Cormorant Garamond", "Times New Roman", Georgia, serif;
  --ff-ui: "Manrope", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
}

/* -------- Reset / base -------- */
*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }
body{
  margin:0;
  font-family:var(--ff-ui);
  color:var(--ink);
  background:var(--cream-1);
  line-height:1.6;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; }
::selection{ background:var(--coral); color:#fff; }

/* -------- Typography -------- */
h1,h2,h3,h4{ font-family:var(--ff-display); font-weight:600; line-height:1.04; margin:0; letter-spacing:-.01em; }
.h-display{ font-size:clamp(2.6rem, 6.4vw, 5.3rem); font-weight:500; }
h2.sect-title{ font-size:clamp(2.1rem, 4.4vw, 3.6rem); font-weight:500; }
h3{ font-size:clamp(1.4rem,2.2vw,1.9rem); }
p{ margin:0 0 1em; }
.lead{ font-size:clamp(1.05rem,1.5vw,1.28rem); color:var(--ink-soft); }

.eyebrow{
  font-family:var(--ff-ui); font-weight:700; font-size:.74rem;
  letter-spacing:.22em; text-transform:uppercase; color:var(--coral-deep);
  display:inline-flex; align-items:center; gap:.6em; margin:0 0 1.1rem;
}
.eyebrow::before{ content:""; width:26px; height:1px; background:currentColor; opacity:.7; }
.eyebrow.center{ justify-content:center; }
.eyebrow.center::after{ content:""; width:26px; height:1px; background:currentColor; opacity:.7; }

.serif-accent{ font-family:var(--ff-display); font-style:italic; font-weight:500; color:var(--coral-deep); }

/* -------- Layout -------- */
.wrap{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gut); }
.section{ padding-block:var(--sect); }
.sect-head{ max-width:680px; margin:0 auto clamp(40px,5vw,68px); text-align:center; }
.sect-head.left{ margin-inline:0; text-align:left; }
.sect-head p{ color:var(--ink-soft); }

/* -------- Buttons -------- */
.btn{
  --pad-y:1rem; --pad-x:1.7rem;
  display:inline-flex; align-items:center; justify-content:center; gap:.6em;
  padding:var(--pad-y) var(--pad-x);
  font-family:var(--ff-ui); font-weight:700; font-size:.93rem; letter-spacing:.02em;
  border:1px solid transparent; border-radius:var(--radius-pill);
  transition:transform .25s cubic-bezier(.2,.8,.2,1), box-shadow .25s, background .2s, color .2s, border-color .2s;
  white-space:nowrap; line-height:1;
}
.btn svg{ width:1.05em; height:1.05em; }
.btn-primary{ background:linear-gradient(135deg,var(--coral),var(--coral-deep)); color:#fff; box-shadow:var(--shadow-coral); }
.btn-primary:hover{ transform:translateY(-2px); box-shadow:0 24px 48px -14px rgba(233,73,61,.55); }
.btn-primary:active{ transform:translateY(0); background:var(--coral-press); }
.btn-ghost{ background:transparent; color:var(--ink); border-color:var(--line); }
.btn-ghost:hover{ border-color:var(--ink); background:rgba(31,32,31,.04); transform:translateY(-2px); }
.btn-dark{ background:var(--ink); color:var(--cream-1); }
.btn-dark:hover{ background:var(--ink-2); transform:translateY(-2px); box-shadow:var(--shadow-md); }
.btn-light{ background:var(--cream-2); color:var(--ink); }
.btn-light:hover{ transform:translateY(-2px); box-shadow:var(--shadow-md); }
.btn-lg{ --pad-y:1.15rem; --pad-x:2.1rem; font-size:1rem; }
.btn-block{ width:100%; }

/* -------- Header -------- */
.header{
  position:sticky; top:0; z-index:60;
  background:rgba(246,241,232,.78); backdrop-filter:blur(14px) saturate(1.2);
  border-bottom:1px solid transparent; transition:border-color .3s, box-shadow .3s, background .3s;
}
.header.scrolled{ border-color:var(--line-soft); box-shadow:var(--shadow-sm); background:rgba(246,241,232,.9); }
.nav{ display:flex; align-items:center; justify-content:space-between; gap:1.5rem; height:74px; }
.brand{ display:flex; align-items:center; gap:.7rem; }
.brand-mark{
  font-family:var(--ff-display); font-weight:600; font-size:1.42rem; line-height:1; letter-spacing:-.01em;
}
.brand-mark small{ display:block; font-family:var(--ff-ui); font-weight:600; font-size:.56rem; letter-spacing:.28em; text-transform:uppercase; color:var(--ink-mute); margin-top:.28em; }
.nav-links{ display:flex; align-items:center; gap:1.9rem; list-style:none; margin:0; padding:0; }
.nav-links a{ font-weight:600; font-size:.92rem; color:var(--ink-soft); transition:color .2s; position:relative; }
.nav-links a:hover{ color:var(--ink); }
.nav-right{ display:flex; align-items:center; gap:1.1rem; }
.nav-phone{ font-weight:700; font-size:.95rem; white-space:nowrap; }
.nav-phone span{ color:var(--ink-mute); font-weight:600; font-size:.72rem; display:block; letter-spacing:.06em; }
.burger{ display:none; flex-direction:column; gap:5px; background:none; border:0; padding:8px; }
.burger span{ width:24px; height:2px; background:var(--ink); border-radius:2px; transition:.3s; }

/* mobile nav drawer */
.mnav{ position:fixed; inset:0; z-index:70; background:var(--cream-1); transform:translateX(100%); transition:transform .4s cubic-bezier(.6,.05,.05,1); display:flex; flex-direction:column; padding:var(--gut); }
.mnav.open{ transform:translateX(0); }
.mnav-top{ display:flex; justify-content:space-between; align-items:center; }
.mnav-close{ background:none; border:0; font-size:2rem; line-height:1; color:var(--ink); }
.mnav ul{ list-style:none; margin:auto 0; padding:0; display:flex; flex-direction:column; gap:1.3rem; }
.mnav ul a{ font-family:var(--ff-display); font-size:2rem; }
.mnav .btn{ margin-top:1.4rem; }

/* -------- Hero -------- */
.hero{ position:relative; padding-top:clamp(34px,5vw,64px); padding-bottom:clamp(40px,6vw,80px); overflow:hidden; }
.hero::before{ /* тёплое сияние */
  content:""; position:absolute; top:-22%; right:-12%; width:60vw; height:60vw; max-width:780px; max-height:780px;
  background:radial-gradient(circle at center, rgba(255,133,98,.22), rgba(255,133,98,0) 62%);
  pointer-events:none; z-index:0;
}
.hero-grid{ position:relative; z-index:1; display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(28px,4vw,68px); align-items:center; }
.hero-copy{ max-width:600px; }
.hero h1{ margin-bottom:1.2rem; }
.hero .lead{ margin-bottom:1.7rem; max-width:34em; }

.fact-strip{ display:flex; flex-wrap:wrap; gap:.5rem 1.4rem; margin:0 0 1.9rem; padding:0; list-style:none; }
.fact-strip li{ display:flex; align-items:center; gap:.5em; font-weight:600; font-size:.92rem; color:var(--ink); }
.fact-strip li svg{ width:18px; height:18px; color:var(--coral-deep); flex:none; }
.fact-strip li + li{ position:relative; }
.hero-cta{ display:flex; flex-wrap:wrap; gap:.9rem; }

.hero-visual{ position:relative; }
.hero-img{
  position:relative; border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow-lg);
  aspect-ratio:4/4.4; background:var(--ink);
}
.hero-img img{ width:100%; height:100%; object-fit:cover; }
.hero-badge{
  position:absolute; left:-7%; bottom:9%; z-index:2;
  background:var(--cream-2); border-radius:18px; padding:.95rem 1.15rem; box-shadow:var(--shadow-md);
  display:flex; align-items:center; gap:.8rem; max-width:74%;
}
.hero-badge .hb-ic{ width:42px; height:42px; border-radius:12px; background:linear-gradient(135deg,var(--sand),var(--sand-soft)); display:grid; place-items:center; flex:none; font-size:1.3rem; }
.hero-badge b{ font-size:.92rem; }
.hero-badge small{ display:block; color:var(--ink-mute); font-size:.78rem; }
.hero-scent{
  position:absolute; right:-5%; top:7%; z-index:2; background:var(--ink); color:var(--cream-1);
  border-radius:var(--radius-pill); padding:.55rem 1.05rem; font-weight:600; font-size:.82rem; box-shadow:var(--shadow-md);
  display:flex; align-items:center; gap:.5em;
}

/* -------- Trust strip -------- */
.trust{ border-block:1px solid var(--line-soft); background:var(--cream-2); }
.trust-row{ display:flex; flex-wrap:wrap; align-items:center; justify-content:center; gap:clamp(16px,4vw,52px); padding-block:1.25rem; }
.trust-item{ display:flex; align-items:center; gap:.7rem; font-weight:600; font-size:.95rem; color:var(--ink-soft); }
.trust-item b{ color:var(--ink); }
.stars{ color:var(--coral-deep); letter-spacing:.1em; font-size:1.05rem; }
.trust-sep{ width:1px; height:30px; background:var(--line); }

/* -------- Pillars -------- */
.pillars-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(18px,2.4vw,30px); }
.pillar{ background:var(--cream-2); border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow-sm); border:1px solid var(--line-soft); transition:transform .35s, box-shadow .35s; }
.pillar:hover{ transform:translateY(-6px); box-shadow:var(--shadow-md); }
.pillar-img{ aspect-ratio:5/3.5; overflow:hidden; background:var(--ink); }
.pillar-img img{ width:100%; height:100%; object-fit:cover; transition:transform .6s; }
.pillar:hover .pillar-img img{ transform:scale(1.05); }
.pillar-body{ padding:1.5rem 1.5rem 1.7rem; }
.pillar-body h3{ margin-bottom:.5rem; }
.pillar-body p{ color:var(--ink-soft); font-size:.96rem; margin:0; }
.pillar-num{ font-family:var(--ff-display); font-style:italic; color:var(--coral-deep); font-size:1.1rem; }

/* -------- Process -------- */
.process{ background:linear-gradient(180deg,var(--cream-1),var(--cream)); }
.steps{ display:grid; grid-template-columns:repeat(4,1fr); gap:clamp(16px,2vw,26px); counter-reset:step; }
.step{ position:relative; padding-top:1.2rem; }
.step::before{
  counter-increment:step; content:"0" counter(step);
  font-family:var(--ff-display); font-size:2.4rem; color:var(--coral-deep); line-height:1; display:block; margin-bottom:.7rem;
}
.step h3{ font-size:1.2rem; margin-bottom:.4rem; }
.step p{ color:var(--ink-soft); font-size:.93rem; margin:0; }
.step:not(:last-child)::after{ content:""; position:absolute; top:1.9rem; right:-13px; width:26px; height:1px; background:var(--line); }

/* -------- Founder (тёмная якорная секция) -------- */
.founder{ background:var(--ink); color:var(--cream-1); position:relative; overflow:hidden; }
.founder::before{ content:""; position:absolute; bottom:-30%; left:-10%; width:50vw; height:50vw; max-width:640px; max-height:640px; background:radial-gradient(circle,rgba(255,133,98,.16),transparent 65%); }
.founder-grid{ position:relative; display:grid; grid-template-columns:.85fr 1.15fr; gap:clamp(30px,5vw,72px); align-items:center; }
.founder-photo{ border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow-lg); aspect-ratio:4/4.6; background:#000; }
.founder-photo img{ width:100%; height:100%; object-fit:cover; }
.founder .eyebrow{ color:var(--coral); }
.founder h2{ color:var(--cream-1); margin-bottom:1.2rem; }
.founder .lead{ color:rgba(251,248,242,.82); }
.founder-quote{ font-family:var(--ff-display); font-style:italic; font-size:clamp(1.3rem,2vw,1.7rem); line-height:1.4; color:var(--cream-2); border-left:2px solid var(--coral); padding-left:1.2rem; margin:1.6rem 0; }
.founder-creds{ display:flex; flex-wrap:wrap; gap:1.6rem; margin:1.6rem 0; padding:0; list-style:none; }
.founder-creds li{ }
.founder-creds .num{ font-family:var(--ff-display); font-size:2.4rem; color:var(--coral); line-height:1; }
.founder-creds .lbl{ font-size:.84rem; color:rgba(251,248,242,.7); }

/* -------- Formats (5 дверей → одна воронка) -------- */
.formats-grid{ display:grid; grid-template-columns:repeat(6,1fr); grid-auto-rows:minmax(190px,auto); gap:clamp(14px,1.8vw,22px); }
.fcard{ position:relative; border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow-sm); cursor:pointer; min-height:200px; border:1px solid var(--line-soft); transition:transform .35s, box-shadow .35s; background:var(--ink); }
.fcard:hover{ transform:translateY(-6px); box-shadow:var(--shadow-md); }
.fcard:focus-visible{ outline:3px solid var(--coral); outline-offset:3px; }
.fcard img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; transition:transform .6s; }
.fcard:hover img{ transform:scale(1.06); }
.fcard::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,rgba(20,16,12,0) 28%,rgba(20,16,12,.82)); }
.fcard-body{ position:absolute; left:0; right:0; bottom:0; z-index:2; padding:1.3rem 1.35rem; color:#fff; }
.fcard-body h3{ color:#fff; font-size:1.45rem; margin-bottom:.2rem; }
.fcard-price{ font-weight:700; font-size:.86rem; color:var(--sand); display:flex; align-items:center; gap:.4em; }
.fcard-price::after{ content:"→"; transition:transform .3s; }
.fcard:hover .fcard-price::after{ transform:translateX(5px); }
/* раскладка плиток */
.fcard.lg{ grid-column:span 3; min-height:300px; }
.fcard.md{ grid-column:span 3; }
.fcard.sm{ grid-column:span 2; }
@supports not (grid-template-columns:repeat(6,1fr)){ .formats-grid{ grid-template-columns:repeat(3,1fr);} }

/* -------- Pricing -------- */
.pricing{ background:var(--cream); }
.price-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(18px,2.4vw,28px); align-items:stretch; }
.price-card{ background:var(--cream-2); border:1px solid var(--line-soft); border-radius:var(--radius-lg); padding:2rem 1.8rem; display:flex; flex-direction:column; transition:transform .35s, box-shadow .35s; position:relative; }
.price-card:hover{ transform:translateY(-6px); box-shadow:var(--shadow-md); }
.price-card.featured{ background:var(--ink); color:var(--cream-1); box-shadow:var(--shadow-lg); }
.price-card.featured h3,.price-card.featured .price{ color:var(--cream-1); }
.price-tag{ position:absolute; top:1.4rem; right:1.4rem; background:var(--coral); color:#fff; font-weight:700; font-size:.72rem; letter-spacing:.05em; text-transform:uppercase; padding:.35rem .7rem; border-radius:var(--radius-pill); }
.price-card h3{ font-size:1.45rem; margin-bottom:.3rem; }
.price-card .psub{ color:var(--ink-mute); font-size:.9rem; margin-bottom:1.2rem; }
.price-card.featured .psub{ color:rgba(251,248,242,.6); }
.price{ font-family:var(--ff-display); font-size:2.9rem; font-weight:600; line-height:1; margin-bottom:.2rem; }
.price small{ font-family:var(--ff-ui); font-size:.95rem; font-weight:600; color:var(--ink-mute); }
.price-card.featured .price small{ color:rgba(251,248,242,.6); }
.price-feats{ list-style:none; margin:1.4rem 0 1.8rem; padding:0; display:flex; flex-direction:column; gap:.7rem; }
.price-feats li{ display:flex; gap:.6em; font-size:.94rem; color:var(--ink-soft); }
.price-card.featured .price-feats li{ color:rgba(251,248,242,.85); }
.price-feats li svg{ width:18px; height:18px; color:var(--coral-deep); flex:none; margin-top:.15em; }
.price-card.featured .price-feats li svg{ color:var(--coral); }
.price-card .btn{ margin-top:auto; }
.price-note{ text-align:center; color:var(--ink-mute); font-size:.9rem; margin-top:1.6rem; }

/* -------- Reviews -------- */
.reviews-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(16px,2.2vw,26px); }
.review{ background:var(--cream-2); border:1px solid var(--line-soft); border-radius:var(--radius); padding:1.8rem 1.7rem; box-shadow:var(--shadow-sm); display:flex; flex-direction:column; }
.review .stars{ margin-bottom:.9rem; }
.review p{ font-family:var(--ff-display); font-size:1.18rem; line-height:1.5; font-style:italic; color:var(--ink); margin-bottom:1.3rem; }
.review-by{ display:flex; align-items:center; gap:.8rem; margin-top:auto; }
.review-av{ width:42px; height:42px; border-radius:50%; background:linear-gradient(135deg,var(--sand),var(--coral)); display:grid; place-items:center; font-weight:700; color:#fff; flex:none; }
.review-by b{ font-size:.95rem; }
.review-by small{ display:block; color:var(--ink-mute); font-size:.8rem; }

/* -------- States line -------- */
.states{ background:linear-gradient(180deg,var(--cream),var(--cream-1)); }
.states-track{ display:flex; gap:18px; overflow-x:auto; scroll-snap-type:x mandatory; -webkit-overflow-scrolling:touch; padding:4px 2px 1.4rem; scrollbar-width:thin; scrollbar-color:var(--sand-deep) transparent; }
.states-track::-webkit-scrollbar{ height:7px; }
.states-track::-webkit-scrollbar-thumb{ background:var(--sand-deep); border-radius:10px; }
.states-track img{ width:230px; flex:none; border-radius:18px; box-shadow:var(--shadow-sm); scroll-snap-align:start; }

/* -------- Location -------- */
.loc-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(24px,4vw,56px); align-items:center; }
.loc-card{ background:var(--cream-2); border:1px solid var(--line-soft); border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow-md); }
.loc-card img{ width:100%; aspect-ratio:16/10; object-fit:cover; }
.loc-list{ list-style:none; margin:1.5rem 0; padding:0; display:flex; flex-direction:column; gap:1.1rem; }
.loc-list li{ display:flex; gap:.9rem; align-items:flex-start; }
.loc-list .li-ic{ width:38px; height:38px; border-radius:11px; background:var(--cream); display:grid; place-items:center; flex:none; color:var(--coral-deep); }
.loc-list b{ display:block; }
.loc-list small{ color:var(--ink-mute); }

/* -------- Booking -------- */
.booking{ background:var(--ink); color:var(--cream-1); position:relative; overflow:hidden; }
.booking::before{ content:""; position:absolute; top:-20%; right:-12%; width:46vw; height:46vw; max-width:620px; max-height:620px; background:radial-gradient(circle,rgba(255,133,98,.18),transparent 64%); }
.booking-grid{ position:relative; display:grid; grid-template-columns:1fr 1.05fr; gap:clamp(30px,5vw,72px); align-items:center; }
.booking .eyebrow{ color:var(--coral); }
.booking h2{ color:var(--cream-1); margin-bottom:1.1rem; }
.booking .lead{ color:rgba(251,248,242,.8); }
.booking-alts{ display:flex; flex-direction:column; gap:.8rem; margin-top:1.7rem; }
.alt-link{ display:flex; align-items:center; gap:.9rem; padding:.9rem 1.1rem; border:1px solid rgba(251,248,242,.16); border-radius:14px; transition:.25s; font-weight:600; }
.alt-link:hover{ background:rgba(251,248,242,.06); border-color:rgba(251,248,242,.3); transform:translateX(4px); }
.alt-link .ai{ width:34px; height:34px; border-radius:9px; display:grid; place-items:center; flex:none; }
.alt-link small{ display:block; color:rgba(251,248,242,.55); font-weight:500; font-size:.8rem; }

.form{ background:var(--cream-2); color:var(--ink); border-radius:var(--radius-lg); padding:clamp(1.5rem,3vw,2.4rem); box-shadow:var(--shadow-lg); }
.form-context{ display:none; align-items:center; gap:.5rem; background:var(--cream); border:1px solid var(--line); border-radius:var(--radius-pill); padding:.45rem .5rem .45rem 1rem; font-weight:600; font-size:.86rem; margin-bottom:1.2rem; width:fit-content; }
.form-context.show{ display:inline-flex; }
.form-context button{ background:var(--ink); color:#fff; border:0; width:22px; height:22px; border-radius:50%; font-size:.8rem; line-height:1; }
.field{ margin-bottom:1.1rem; }
.field label{ display:block; font-weight:600; font-size:.86rem; margin-bottom:.4rem; }
.field input,.field select{
  width:100%; padding:.85rem 1rem; border:1px solid var(--line); border-radius:13px; background:var(--cream-1);
  font-family:inherit; font-size:1rem; color:var(--ink); transition:border-color .2s, box-shadow .2s;
}
.field input:focus,.field select:focus{ outline:none; border-color:var(--coral); box-shadow:0 0 0 3px rgba(255,133,98,.18); }
.field-row{ display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.chips{ display:flex; flex-wrap:wrap; gap:.5rem; }
.chip{ padding:.6rem 1rem; border:1px solid var(--line); border-radius:var(--radius-pill); background:var(--cream-1); font-weight:600; font-size:.88rem; transition:.2s; }
.chip.active{ background:var(--ink); color:#fff; border-color:var(--ink); }
.form .btn{ margin-top:.4rem; }
.form-fine{ text-align:center; font-size:.78rem; color:var(--ink-mute); margin:.9rem 0 0; }
.form-fine a{ text-decoration:underline; }

/* -------- Footer -------- */
.footer{ background:var(--cream); border-top:1px solid var(--line-soft); padding-block:clamp(48px,6vw,72px) 2rem; }
.footer-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:clamp(28px,4vw,56px); margin-bottom:2.6rem; }
.footer .brand-mark{ font-size:1.6rem; margin-bottom:1rem; }
.footer p{ color:var(--ink-soft); font-size:.94rem; max-width:32ch; }
.footer h4{ font-family:var(--ff-ui); font-weight:700; font-size:.78rem; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-mute); margin:0 0 1.1rem; }
.footer ul{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:.7rem; }
.footer ul a{ color:var(--ink-soft); font-weight:600; font-size:.94rem; transition:color .2s; }
.footer ul a:hover{ color:var(--coral-deep); }
.socials{ display:flex; gap:.7rem; margin-top:1.2rem; }
.socials a{ width:42px; height:42px; border-radius:12px; background:var(--cream-2); border:1px solid var(--line-soft); display:grid; place-items:center; transition:.25s; }
.socials a:hover{ background:var(--ink); color:var(--cream-1); transform:translateY(-3px); }
.footer-legal{ border-top:1px solid var(--line-soft); padding-top:1.8rem; display:flex; flex-wrap:wrap; justify-content:space-between; gap:1rem; color:var(--ink-mute); font-size:.82rem; }

/* -------- Sticky mobile CTA -------- */
.mcta{ position:fixed; left:0; right:0; bottom:0; z-index:55; display:none; gap:.7rem; padding:.7rem var(--gut) calc(.7rem + env(safe-area-inset-bottom)); background:rgba(246,241,232,.92); backdrop-filter:blur(12px); border-top:1px solid var(--line); transform:translateY(120%); transition:transform .35s; }
.mcta.show{ transform:translateY(0); }
.mcta .btn-primary{ flex:1; }
.mcta .btn-call{ width:54px; flex:none; background:var(--ink); color:#fff; border-radius:var(--radius-pill); display:grid; place-items:center; }

/* -------- Reveal animation -------- */
.reveal{ opacity:0; transform:translateY(26px); transition:opacity .7s cubic-bezier(.2,.7,.2,1), transform .7s cubic-bezier(.2,.7,.2,1); }
.reveal.in{ opacity:1; transform:none; }
@media (prefers-reduced-motion: reduce){ .reveal{ opacity:1; transform:none; transition:none; } }

/* -------- Responsive -------- */
@media (max-width:980px){
  .nav-links,.nav-phone{ display:none; }
  .nav-right .btn-primary{ display:none; }
  .burger{ display:flex; }
  .nav{ height:66px; }
  .brand-mark{ font-size:1.16rem; }
  .brand-mark small{ font-size:.52rem; letter-spacing:.2em; margin-top:.2em; }
  .mcta{ display:flex; }
  .hero-grid{ grid-template-columns:1fr; }
  .hero-visual{ order:-1; max-width:460px; margin-inline:auto; }
  .founder-grid{ grid-template-columns:1fr; }
  .founder-photo{ max-width:420px; aspect-ratio:4/4; }
  .booking-grid{ grid-template-columns:1fr; }
  .loc-grid{ grid-template-columns:1fr; }
  .formats-grid{ grid-template-columns:repeat(4,1fr); }
  .fcard.lg,.fcard.md{ grid-column:span 2; }
  .fcard.sm{ grid-column:span 2; }
}
@media (max-width:760px){
  .pillars-grid{ grid-template-columns:1fr; max-width:460px; margin-inline:auto; }
  .steps{ grid-template-columns:1fr 1fr; gap:1.6rem 1.2rem; }
  .step:not(:last-child)::after{ display:none; }
  .price-grid{ grid-template-columns:1fr; max-width:440px; margin-inline:auto; }
  .reviews-grid{ grid-template-columns:1fr; max-width:460px; margin-inline:auto; }
  .footer-grid{ grid-template-columns:1fr 1fr; }
  body{ padding-bottom:0; }
}
@media (max-width:480px){
  .formats-grid{ grid-template-columns:1fr; }
  .fcard.lg,.fcard.md,.fcard.sm{ grid-column:span 1; }
  .field-row{ grid-template-columns:1fr; }
  .footer-grid{ grid-template-columns:1fr; }
  .hero-badge{ left:0; }
}

/* -------- Format cards as links -------- */
a.fcard{ display:block; text-decoration:none; color:inherit; }

/* -------- FAQ (GEO-friendly, native accordion) -------- */
.faq{ max-width:840px; margin:0 auto; }
.faq-item{ border-bottom:1px solid var(--line); }
.faq-item summary{ cursor:pointer; list-style:none; padding:1.35rem 0; font-family:var(--ff-display); font-size:clamp(1.2rem,2vw,1.5rem); font-weight:500; display:flex; justify-content:space-between; gap:1.2rem; align-items:center; }
.faq-item summary::-webkit-details-marker{ display:none; }
.faq-item summary::after{ content:"+"; color:var(--coral-deep); font-family:var(--ff-ui); font-weight:300; font-size:1.7rem; line-height:1; transition:transform .3s; flex:none; }
.faq-item[open] summary::after{ transform:rotate(45deg); }
.faq-item p{ color:var(--ink-soft); padding:0 0 1.4rem; margin:0; max-width:66ch; }

/* -------- Legal / privacy -------- */
.legal{ max-width:820px; margin:0 auto; }
.legal h1{ font-size:clamp(2rem,4vw,3rem); margin-bottom:1.4rem; }
.legal h2{ font-size:1.4rem; margin:2rem 0 .7rem; }
.legal p{ color:var(--ink-soft); font-size:.96rem; margin:0 0 .8rem; }
.legal a{ color:var(--coral-deep); text-decoration:underline; }

/* -------- Thank-you / spasibo -------- */
.thanks{ min-height:62vh; display:grid; place-items:center; text-align:center; }
.thanks h1{ font-size:clamp(2.2rem,5vw,3.6rem); margin-bottom:1rem; }
.thanks p{ color:var(--ink-soft); font-size:1.1rem; max-width:34ch; margin-inline:auto; }

/* ============ Navigation: desktop mega menu + premium mobile drawer ============ */
.nav-main{ display:flex; }
.nav-links li.has-mega{ position:static; display:flex; align-items:center; }
.nav-trigger{ display:inline-flex; align-items:center; gap:.4em; font-family:inherit; font-weight:600; font-size:.92rem; line-height:1; color:var(--ink-soft); background:none; border:0; padding:0; cursor:pointer; transition:color .2s; }
.nav-trigger .chev{ width:14px; height:14px; color:var(--coral-deep); transition:transform .3s ease; }
.nav-links li.has-mega:hover .nav-trigger,
.nav-trigger[aria-expanded="true"]{ color:var(--ink); }
.nav-links li.has-mega:hover .chev,
.nav-trigger[aria-expanded="true"] .chev{ transform:rotate(180deg); }

/* Mega panel — full-width under header */
.mega{ position:absolute; left:0; right:0; top:100%; background:var(--cream-2); border-top:1px solid var(--line-soft); border-bottom:1px solid var(--line-soft); box-shadow:var(--shadow-lg); opacity:0; visibility:hidden; transform:translateY(-12px); transition:opacity .25s ease, transform .25s ease, visibility .25s; z-index:60; }
.nav-links li.has-mega:hover .mega,
.mega.open{ opacity:1; visibility:visible; transform:translateY(0); }
.mega-grid{ display:grid; grid-template-columns:1.15fr .85fr; gap:2.2rem; padding:1.7rem var(--gut) 1.9rem; }
.mega-cards{ display:grid; grid-template-columns:1fr 1fr; gap:.35rem 1.2rem; align-content:start; }
.mega-card{ display:flex; align-items:center; gap:.9rem; padding:.65rem .7rem; border-radius:14px; transition:background .2s ease, transform .2s ease; }
.mega-card:hover{ background:var(--cream); transform:translateX(3px); }
.mega-thumb{ width:60px; height:60px; flex:none; border-radius:12px; overflow:hidden; background:var(--ink); }
.mega-thumb img{ width:100%; height:100%; object-fit:cover; }
.mega-tx{ display:flex; flex-direction:column; gap:.1rem; min-width:0; }
.mega-tx b{ font-size:.98rem; font-weight:700; color:var(--ink); }
.mega-tx small{ font-size:.8rem; color:var(--ink-mute); line-height:1.3; }
.mega-price{ font-family:var(--ff-display); font-style:italic; font-weight:600; font-size:.92rem; color:var(--coral-deep); margin-top:.05rem; }
.mega-promo{ background:var(--cream); border:1px solid var(--line-soft); border-radius:16px; padding:1.15rem; display:flex; flex-direction:column; }
.mega-promo-img{ aspect-ratio:16/9; border-radius:11px; overflow:hidden; background:var(--ink); margin-bottom:.85rem; }
.mega-promo-img img{ width:100%; height:100%; object-fit:cover; }
.mega-promo .eyebrow{ margin-bottom:.35rem; }
.mega-promo p{ font-size:.88rem; color:var(--ink-soft); margin:0 0 .6rem; }
.mega-facts{ display:flex; flex-wrap:wrap; gap:.35rem .9rem; list-style:none; padding:0; margin:0 0 .9rem; }
.mega-facts li{ font-size:.76rem; font-weight:600; color:var(--ink); position:relative; padding-left:.95rem; }
.mega-facts li::before{ content:""; position:absolute; left:0; top:50%; transform:translateY(-50%); width:5px; height:5px; border-radius:50%; background:var(--coral); }
.btn-block{ display:flex; width:100%; justify-content:center; }
.mega-promo .btn-block{ margin-top:auto; }

/* Burger → X */
.burger{ cursor:pointer; }
.burger span{ transform-origin:center; transition:transform .3s ease, opacity .2s ease; }
.burger.active span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.burger.active span:nth-child(2){ opacity:0; }
.burger.active span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

/* Premium mobile drawer */
.mnav{ overflow-y:auto; }
.mnav-top{ padding-bottom:1.1rem; border-bottom:1px solid var(--line-soft); }
.mnav-top .brand-mark{ font-size:1.18rem; }
.mnav-scroll{ flex:1 1 auto; padding:1.3rem 0; }
.mnav-label{ display:block; font-family:var(--ff-ui); font-weight:700; font-size:.7rem; letter-spacing:.18em; text-transform:uppercase; color:var(--ink-mute); margin-bottom:.85rem; }
.mnav-formats{ display:flex; flex-direction:column; gap:.5rem; margin-bottom:1.5rem; }
.mnav-fmt{ display:flex; align-items:center; gap:.85rem; padding:.55rem; border-radius:14px; background:var(--cream-2); border:1px solid var(--line-soft); transition:background .2s ease; }
.mnav-fmt:active{ background:var(--cream); }
.mnav-fmt-thumb{ width:52px; height:52px; flex:none; border-radius:11px; overflow:hidden; background:var(--ink); }
.mnav-fmt-thumb img{ width:100%; height:100%; object-fit:cover; }
.mnav-fmt-tx{ display:flex; flex-direction:column; flex:1 1 auto; }
.mnav-fmt-tx b{ font-size:1rem; color:var(--ink); font-weight:700; }
.mnav-fmt-tx small{ font-family:var(--ff-display); font-style:italic; color:var(--coral-deep); font-size:.9rem; }
.mnav-arrow{ width:20px; height:20px; color:var(--ink-mute); flex:none; }
.mnav .mnav-links{ list-style:none; margin:0; padding:0; display:block; gap:0; }
.mnav .mnav-links a{ display:block; font-family:var(--ff-display); font-size:1.45rem; padding:.5rem 0; border-bottom:1px solid var(--line-soft); color:var(--ink); }
.mnav-foot{ flex:none; padding-top:1.1rem; border-top:1px solid var(--line-soft); }
.mnav-contact{ display:flex; justify-content:center; gap:1.6rem; margin-top:.85rem; }
.mnav-contact a{ font-weight:700; color:var(--ink); }

@media (max-width:980px){ .mega{ display:none; } }
@media (min-width:981px){ .mnav{ display:none; } }
@media (max-width:1080px){ .mega-grid{ grid-template-columns:1.25fr .75fr; gap:1.6rem; } .mega-cards{ gap:.25rem .8rem; } }

/* ============ Booking modal (instant form — no scroll friction) ============ */
.modal{ position:fixed; inset:0; z-index:120; display:flex; align-items:flex-start; justify-content:center; padding:4vh 1rem; overflow-y:auto; visibility:hidden; pointer-events:none; }
.modal.open{ visibility:visible; pointer-events:auto; }
.modal-overlay{ position:fixed; inset:0; background:rgba(22,19,16,.55); backdrop-filter:blur(3px); opacity:0; transition:opacity .25s ease; }
.modal.open .modal-overlay{ opacity:1; }
.modal-card{ position:relative; z-index:1; width:100%; max-width:520px; margin:auto; background:var(--cream-2); border-radius:var(--radius-lg); box-shadow:var(--shadow-lg); padding:clamp(1.5rem,3.2vw,2.3rem); transform:translateY(16px) scale(.985); opacity:0; transition:transform .32s cubic-bezier(.2,.8,.2,1), opacity .26s ease; }
.modal.open .modal-card{ transform:translateY(0) scale(1); opacity:1; }
.modal-close{ position:absolute; top:.7rem; right:.7rem; width:38px; height:38px; border:0; background:var(--cream); border-radius:50%; font-size:1.45rem; line-height:1; color:var(--ink); cursor:pointer; transition:transform .25s ease, background .2s ease, color .2s ease; z-index:2; }
.modal-close:hover{ background:var(--ink); color:#fff; transform:rotate(90deg); }
.modal-head{ margin-bottom:1.3rem; padding-right:2.2rem; }
.modal-head h3{ font-family:var(--ff-display); font-weight:600; font-size:clamp(1.5rem,3vw,1.95rem); line-height:1.1; margin:.35rem 0 .45rem; }
.modal-head p{ color:var(--ink-mute); font-size:.9rem; margin:0; }
.modal-body .form{ box-shadow:none; padding:0; background:transparent; }
@media (max-width:560px){ .modal{ padding:0; align-items:flex-end; } .modal-card{ max-width:none; border-radius:22px 22px 0 0; } }

/* form invalid + active nav item */
.field input.invalid, .field select.invalid{ border-color:#e0564a !important; box-shadow:0 0 0 3px rgba(224,86,74,.16) !important; }
.mega-card.active{ background:var(--cream); box-shadow:inset 3px 0 0 var(--coral); }
.mnav-fmt.active{ border-color:var(--coral); }
