/* =========================================================
   Живой пар — лендинг. Тёплая «дышащая» эстетика для 30+
   Cormorant (display) + Manrope (body)
   ========================================================= */

:root{
  --cream:#f5ecdd;
  --cream-2:#efe3d0;
  --paper:#fffdf8;
  --ink:#2a241d;
  --ink-soft:#6c6051;
  --cedar:#7c5230;
  --amber:#c8743b;
  --amber-deep:#a9531f;
  --herb:#5e7355;
  --line:#e6dac4;
  --line-soft:#efe6d6;
  --shadow:0 18px 50px -22px rgba(74,48,22,.45);
  --shadow-sm:0 8px 26px -14px rgba(74,48,22,.4);
  --radius:20px;
  --radius-sm:14px;
  --maxw:1180px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;background:var(--cream);color:var(--ink);
  font-family:"Manrope",system-ui,sans-serif;
  font-size:19px;line-height:1.65;font-weight:400;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px;width:100%}

/* texture grain overlay */
body::before{
  content:"";position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.5;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.035'/%3E%3C/svg%3E");
}
.wrap,header,section,footer,.contact-dock,.mobile-bar,.modal{position:relative;z-index:2}

/* ---------- Типографика ---------- */
h1,h2,h3{font-family:"Cormorant",Georgia,serif;font-weight:600;line-height:1.06;letter-spacing:.002em;margin:0}
h2{font-size:clamp(2.1rem,4.6vw,3.4rem)}
h3{font-size:1.5rem;font-weight:600}
em{font-style:italic;color:var(--amber-deep)}
.eyebrow{
  font-family:"Manrope";font-weight:700;font-size:.82rem;letter-spacing:.18em;
  text-transform:uppercase;color:var(--amber-deep);margin:0 0 14px;
}
.eyebrow.center,h2.center,.section-lead.center{text-align:center}
.section-lead{font-size:1.16rem;color:var(--ink-soft);max-width:62ch;margin:18px auto 0}
.center.section-lead{margin-left:auto;margin-right:auto}

/* ---------- Кнопки ---------- */
.btn{
  --bg:var(--amber);--fg:#fff;
  display:inline-flex;align-items:center;justify-content:center;gap:.5em;
  font-family:"Manrope";font-weight:700;font-size:1rem;
  padding:.85em 1.5em;border-radius:999px;border:1.5px solid transparent;
  background:var(--bg);color:var(--fg);cursor:pointer;
  transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .2s,color .2s;
  box-shadow:0 10px 24px -12px rgba(168,83,31,.7);white-space:nowrap;
}
.btn:hover{transform:translateY(-2px);box-shadow:0 16px 30px -12px rgba(168,83,31,.75)}
.btn:active{transform:translateY(0)}
.btn-primary{background:linear-gradient(135deg,var(--amber),var(--amber-deep));color:#fff}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--cedar);box-shadow:none}
.btn-ghost:hover{background:var(--paper);border-color:var(--amber)}
.btn-lg{font-size:1.08rem;padding:1.02em 1.9em}
.btn-sm{padding:.6em 1.1em;font-size:.94rem}
.btn-block{display:flex;width:100%}

/* ---------- Шапка ---------- */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(245,236,221,.82);backdrop-filter:saturate(140%) blur(12px);
  border-bottom:1px solid transparent;transition:border-color .3s,box-shadow .3s,background .3s;
}
.site-header.scrolled{border-color:var(--line);box-shadow:0 6px 24px -18px rgba(74,48,22,.6)}
.header-inner{display:flex;align-items:center;gap:24px;height:78px}
.logo{display:flex;align-items:center;gap:10px;color:var(--cedar);flex-shrink:0}
.logo-mark{display:grid;place-items:center;width:42px;height:42px;border-radius:50%;
  background:radial-gradient(circle at 35% 30%,#fff8ed,#efddc4);color:var(--amber-deep);
  box-shadow:inset 0 0 0 1px var(--line)}
.logo-text{font-family:"Cormorant";font-weight:600;font-size:1.7rem;color:var(--ink);letter-spacing:.01em}
.main-nav{display:flex;gap:28px;margin-left:8px;flex:1}
.main-nav a{font-weight:600;font-size:.98rem;color:var(--ink-soft);position:relative;padding:4px 0}
.main-nav a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;background:var(--amber);transition:width .25s var(--ease)}
.main-nav a:hover{color:var(--ink)}
.main-nav a:hover::after{width:100%}
.header-cta{display:flex;align-items:center;gap:18px;flex-shrink:0}
.header-phone{font-weight:700;color:var(--ink);font-size:1.02rem}
.header-phone:hover{color:var(--amber-deep)}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;padding:8px;cursor:pointer}
.burger span{width:26px;height:2.5px;background:var(--ink);border-radius:2px;transition:.3s}
.burger[aria-expanded="true"] span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
.burger[aria-expanded="true"] span:nth-child(2){opacity:0}
.burger[aria-expanded="true"] span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}

.mobile-menu{
  position:fixed;inset:78px 0 0;z-index:49;background:var(--cream);
  display:flex;flex-direction:column;gap:6px;padding:24px 28px;overflow-y:auto;
  animation:slideDown .3s var(--ease);
}
.mobile-menu a{font-family:"Cormorant";font-size:1.7rem;font-weight:600;padding:12px 0;border-bottom:1px solid var(--line-soft)}
.mobile-menu a.btn{font-family:"Manrope";font-size:1.05rem;margin-top:16px;border-bottom:0}
@keyframes slideDown{from{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:none}}

/* ---------- Герой ---------- */
.hero{position:relative;min-height:92vh;display:flex;align-items:center;overflow:hidden;
  padding:64px 0 90px}
.hero-bg{
  position:absolute;inset:0;z-index:0;
  background:
    radial-gradient(120% 90% at 75% 15%,rgba(255,248,236,.0),rgba(245,236,221,.55) 60%,var(--cream) 100%),
    linear-gradient(180deg,rgba(40,30,20,.18),rgba(40,30,20,.42)),
    url("../img/hero.jpg") center/cover no-repeat;
  background-color:#cdb79a;
}
.hero-steam{position:absolute;inset:0;z-index:1;pointer-events:none;overflow:hidden}
.hero-steam span{
  position:absolute;bottom:-120px;width:340px;height:340px;border-radius:50%;
  background:radial-gradient(circle,rgba(255,250,240,.5),rgba(255,250,240,0) 65%);
  filter:blur(6px);animation:rise 14s ease-in infinite;
}
.hero-steam span:nth-child(1){left:12%;animation-delay:0s}
.hero-steam span:nth-child(2){left:46%;width:420px;height:420px;animation-delay:4s}
.hero-steam span:nth-child(3){left:74%;animation-delay:8s}
@keyframes rise{
  0%{transform:translateY(0) scale(.7);opacity:0}
  20%{opacity:.7}
  100%{transform:translateY(-90vh) scale(1.5);opacity:0}
}
.hero-inner{position:relative;z-index:2;max-width:860px;color:#fff8ee}
.hero .eyebrow{color:#ffd9b0}
.hero-title{
  font-size:clamp(3rem,8.5vw,6.6rem);font-weight:500;color:#fff;
  text-shadow:0 4px 30px rgba(40,24,10,.4);margin-bottom:.3em;
}
.hero-title em{color:#ffcaa0}
.hero-sub{font-size:clamp(1.1rem,2.1vw,1.42rem);max-width:50ch;color:#fdf3e6;
  text-shadow:0 2px 14px rgba(40,24,10,.45);margin:0 0 36px}
.hero-sub strong{color:#fff;font-weight:700}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:46px}
.hero .btn-ghost{color:#fff;border-color:rgba(255,255,255,.7);backdrop-filter:blur(2px)}
.hero .btn-ghost:hover{background:rgba(255,255,255,.14);border-color:#fff}
.trust-row{list-style:none;display:flex;gap:42px;padding:0;margin:0;flex-wrap:wrap}
.trust-row li{display:flex;flex-direction:column}
.trust-row b{font-family:"Cormorant";font-size:2.4rem;font-weight:600;color:#fff;line-height:1}
.trust-row span{font-size:.92rem;color:#f3e2cf;font-weight:600}
.scroll-hint{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);z-index:3;
  width:26px;height:42px;border:2px solid rgba(255,255,255,.6);border-radius:14px}
.scroll-hint span{position:absolute;top:8px;left:50%;width:4px;height:8px;margin-left:-2px;
  background:#fff;border-radius:2px;animation:scrolldot 1.8s infinite}
@keyframes scrolldot{0%{opacity:0;transform:translateY(0)}30%{opacity:1}60%{opacity:1;transform:translateY(12px)}100%{opacity:0;transform:translateY(16px)}}

/* ---------- Секции базово ---------- */
.section{padding:96px 0}
.section.about{padding-top:104px}

/* ---------- О процедуре ---------- */
.about-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:64px;align-items:center}
.about-copy p{margin:0 0 18px;color:var(--ink-soft)}
.about-copy p strong{color:var(--ink)}
.about-copy h2{margin-bottom:24px}
.disclaimer{font-size:.98rem;background:var(--cream-2);border-left:3px solid var(--herb);
  padding:14px 18px;border-radius:0 12px 12px 0}
.disclaimer a{color:var(--amber-deep);font-weight:700;border-bottom:1px solid currentColor}
.about-media{position:relative}
.about-media img{width:100%;border-radius:var(--radius);box-shadow:var(--shadow);object-fit:cover;aspect-ratio:4/5}
.about-badge{position:absolute;left:-22px;bottom:34px;background:var(--paper);
  border-radius:16px;padding:14px 22px;box-shadow:var(--shadow-sm);border:1px solid var(--line);
  display:flex;flex-direction:column;text-align:center}
.about-badge b{font-family:"Cormorant";font-size:2.1rem;font-weight:600;color:var(--amber-deep);line-height:1}
.about-badge span{font-size:.82rem;font-weight:600;color:var(--ink-soft)}

.fact-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:64px}
.fact{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-sm);
  padding:24px;text-align:center;box-shadow:var(--shadow-sm)}
.fact b{display:block;font-family:"Cormorant";font-size:2.3rem;font-weight:600;color:var(--ink);line-height:1}
.fact span{font-size:.92rem;color:var(--ink-soft);font-weight:600}

/* ---------- Как проходит ---------- */
.how{background:linear-gradient(180deg,var(--cream),var(--cream-2));}
.steps{list-style:none;counter-reset:s;display:grid;grid-template-columns:repeat(4,1fr);
  gap:22px;padding:0;margin:56px 0 0}
.step{position:relative;background:var(--paper);border:1px solid var(--line);
  border-radius:var(--radius);padding:30px 26px 28px;box-shadow:var(--shadow-sm)}
.step-num{position:absolute;top:-18px;left:26px;width:40px;height:40px;border-radius:50%;
  display:grid;place-items:center;font-family:"Cormorant";font-weight:600;font-size:1.4rem;color:#fff;
  background:linear-gradient(135deg,var(--amber),var(--amber-deep));box-shadow:var(--shadow-sm)}
.step-ico{font-size:2.1rem;display:block;margin:12px 0 14px}
.step h3{margin-bottom:8px}
.step p{font-size:.98rem;color:var(--ink-soft);margin:0}

/* ---------- Польза / карта тела ---------- */
.benefits-layout{display:grid;grid-template-columns:.85fr 1.15fr;gap:54px;align-items:center;margin-top:56px}
.bodymap{position:relative;justify-self:center;width:100%;max-width:330px}
.bodymap-img{width:100%;opacity:.92;filter:drop-shadow(0 14px 30px rgba(124,82,48,.25))}
.dot{position:absolute;left:var(--x);top:var(--y);transform:translate(-50%,-50%);
  background:linear-gradient(135deg,var(--amber),var(--amber-deep));color:#fff;border:0;cursor:pointer;
  font-family:"Manrope";font-weight:700;font-size:.74rem;padding:.4em .7em;border-radius:999px;
  white-space:nowrap;box-shadow:var(--shadow-sm);transition:transform .25s var(--ease)}
.dot::before{content:"";position:absolute;inset:-6px;border-radius:999px;border:2px solid var(--amber);
  opacity:.5;animation:pulse 2.6s var(--ease) infinite}
.dot:hover,.dot.is-active{transform:translate(-50%,-50%) scale(1.12)}
@keyframes pulse{0%{transform:scale(.9);opacity:.6}70%{transform:scale(1.5);opacity:0}100%{opacity:0}}
.benefits-cards{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.benefit-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-sm);
  padding:24px 22px;box-shadow:var(--shadow-sm);transition:transform .25s var(--ease),border-color .25s,box-shadow .25s}
.benefit-card:hover,.benefit-card.is-active{transform:translateY(-4px);border-color:var(--amber);box-shadow:var(--shadow)}
.b-ico{font-size:1.9rem;display:block;margin-bottom:10px}
.benefit-card h3{font-size:1.25rem;margin-bottom:6px}
.benefit-card p{font-size:.95rem;color:var(--ink-soft);margin:0}

/* ---------- Сравнение ---------- */
.compare{background:linear-gradient(180deg,var(--cream-2),var(--cream))}
.compare-toggle{display:inline-flex;background:var(--cream-2);border:1px solid var(--line);
  border-radius:999px;padding:5px;margin:34px auto 28px;gap:4px;justify-self:center}
.compare .wrap{display:flex;flex-direction:column;align-items:center}
.compare h2,.compare .eyebrow,.compare .section-lead{align-self:stretch}
.ct-btn{font-family:"Manrope";font-weight:700;font-size:1rem;padding:.7em 1.6em;border-radius:999px;
  border:0;background:transparent;color:var(--ink-soft);cursor:pointer;transition:.25s}
.ct-btn.is-active{background:linear-gradient(135deg,var(--amber),var(--amber-deep));color:#fff;box-shadow:var(--shadow-sm)}
.compare-card{width:100%;max-width:680px;background:var(--paper);border:1px solid var(--line);
  border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}
.cc-row{display:flex;justify-content:space-between;gap:20px;padding:18px 28px;border-bottom:1px solid var(--line-soft)}
.cc-row:last-child{border-bottom:0}
.cc-label{color:var(--ink-soft);font-weight:600}
.cc-val{font-weight:700;text-align:right}
.compare-card[data-mode="banya"] .cc-val{color:var(--cedar)}
.compare-card[data-mode="par"] .cc-val{color:var(--herb)}

/* ---------- Наука ---------- */
.science-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:60px;align-items:start}
.science-head h2{margin:0 0 18px}
.science-head p{color:var(--ink-soft)}
.science-note{display:flex;gap:14px;align-items:flex-start;margin-top:22px;background:var(--cream-2);
  border:1px solid var(--line);border-radius:var(--radius-sm);padding:18px 20px}
.science-note span{font-size:1.4rem;color:var(--herb);line-height:1}
.science-note p{margin:0;font-size:.98rem}
.science-note strong{color:var(--ink)}
.accordion details{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-sm);
  margin-bottom:14px;box-shadow:var(--shadow-sm);overflow:hidden}
.accordion summary{cursor:pointer;list-style:none;padding:22px 26px;font-family:"Cormorant";
  font-size:1.5rem;font-weight:600;display:flex;justify-content:space-between;align-items:center;gap:16px}
.accordion summary::-webkit-details-marker{display:none}
.accordion summary::after{content:"+";font-family:"Manrope";font-weight:700;font-size:1.6rem;
  color:var(--amber-deep);transition:transform .3s var(--ease);line-height:1}
.accordion details[open] summary::after{transform:rotate(45deg)}
.acc-body{padding:0 26px 24px}
.acc-body p{margin:0 0 12px;color:var(--ink-soft);font-size:1rem}
.acc-body p:last-child{margin-bottom:0}

/* ---------- Цены ---------- */
.prices{background:linear-gradient(180deg,var(--cream),var(--cream-2))}
.price-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:54px}
.price-card{position:relative;background:var(--paper);border:1px solid var(--line);
  border-radius:var(--radius);padding:30px 26px;box-shadow:var(--shadow-sm);
  display:flex;flex-direction:column;transition:transform .25s var(--ease),box-shadow .25s}
.price-card:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.price-card.is-featured{border-color:var(--amber);box-shadow:var(--shadow);
  background:linear-gradient(180deg,#fff,#fff6ea)}
.price-tag{position:absolute;top:-13px;left:50%;transform:translateX(-50%);
  background:linear-gradient(135deg,var(--amber),var(--amber-deep));color:#fff;font-size:.76rem;
  font-weight:700;letter-spacing:.04em;padding:.35em 1em;border-radius:999px;white-space:nowrap}
.price-card h3{font-size:1.35rem;margin-bottom:14px}
.price{display:flex;align-items:baseline;gap:6px;margin-bottom:4px;white-space:nowrap}
.price b{font-family:"Cormorant";font-size:2.7rem;font-weight:600;color:var(--ink);line-height:1;white-space:nowrap}
.price .cur{font-size:1.4rem;color:var(--ink-soft);font-weight:700}
.price-sub{margin:0 0 20px;color:var(--ink-soft);font-weight:600;font-size:.95rem}
.price-card ul{list-style:none;padding:0;margin:0 0 24px;flex:1}
.price-card li{padding:7px 0 7px 26px;position:relative;font-size:.98rem;color:var(--ink-soft);border-bottom:1px solid var(--line-soft)}
.price-card li:last-child{border-bottom:0}
.price-card li::before{content:"✓";position:absolute;left:0;color:var(--herb);font-weight:800}

/* ---------- Отзывы ---------- */
.reviews-actions{display:flex;align-items:center;justify-content:center;gap:24px;flex-wrap:wrap;margin:30px 0 40px}
.reviews-rating{font-size:1.05rem;color:var(--ink-soft);font-weight:600}
.reviews-rating b{font-family:"Cormorant";font-size:1.7rem;color:var(--ink)}
.stars{color:var(--amber);letter-spacing:.05em}
.reviews-wall{columns:3;column-gap:20px}
.rev-card{break-inside:avoid;background:var(--paper);border:1px solid var(--line);
  border-radius:var(--radius-sm);padding:22px 24px;margin:0 0 20px;box-shadow:var(--shadow-sm)}
.rev-stars{color:var(--amber);letter-spacing:.08em;font-size:1.05rem;margin-bottom:10px}
.rev-card p{margin:0 0 16px;font-size:1.02rem}
.rev-card footer{display:flex;align-items:center;gap:12px}
.rev-ava{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;flex-shrink:0;
  background:linear-gradient(135deg,#efddc4,#e3c9a4);color:var(--cedar);font-family:"Cormorant";
  font-weight:600;font-size:1.4rem}
.rev-card footer b{display:block;font-size:1rem}
.rev-card footer small{color:var(--ink-soft);font-size:.85rem}
.rev-video .rev-play{display:flex;flex-direction:column;justify-content:flex-end;
  height:200px;border-radius:12px;margin-bottom:16px;padding:16px;position:relative;overflow:hidden;
  background:linear-gradient(160deg,#5e7355,#3f5038);color:#fff}
.rev-video .rev-play::after{content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 50% 42%,rgba(255,255,255,.16),transparent 55%)}
.rev-play .play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:58px;height:58px;border-radius:50%;background:rgba(255,255,255,.92);color:var(--herb);
  display:grid;place-items:center;font-size:1.3rem;padding-left:4px;box-shadow:0 8px 20px rgba(0,0,0,.25);
  transition:transform .25s var(--ease)}
.rev-video:hover .play{transform:translate(-50%,-50%) scale(1.1)}
.rev-vlabel{position:relative;z-index:1;font-weight:700;font-size:.9rem}

/* ---------- Форма заявки ---------- */
.lead{background:linear-gradient(140deg,#3f5038,#2f3c2a);color:#f3ecdf}
.lead-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.lead .eyebrow{color:#bcd0a8}
.lead-copy h2{color:#fff;margin-bottom:20px}
.lead-copy p{color:#dfe6d4}
.lead-points{list-style:none;padding:0;margin:24px 0 0;display:grid;gap:12px}
.lead-points li{padding-left:32px;position:relative;color:#e8eede}
.lead-points li::before{content:"✓";position:absolute;left:0;width:22px;height:22px;border-radius:50%;
  background:var(--amber);color:#fff;font-size:.8rem;font-weight:800;display:grid;place-items:center}
.lead-form{background:var(--paper);border-radius:var(--radius);padding:34px 32px;box-shadow:var(--shadow);color:var(--ink)}
.lead-form label,.modal-card label{display:block;font-weight:700;font-size:.92rem;margin-bottom:16px;color:var(--ink)}
.lead-form input,.lead-form select,.lead-form textarea,
.modal-card input,.modal-card textarea{
  width:100%;margin-top:7px;padding:.85em 1em;border:1.5px solid var(--line);border-radius:12px;
  font-family:"Manrope";font-size:1rem;font-weight:500;background:#fffdf9;color:var(--ink);transition:border-color .2s,box-shadow .2s}
.lead-form input:focus,.lead-form select:focus,.lead-form textarea:focus,
.modal-card input:focus,.modal-card textarea:focus{outline:0;border-color:var(--amber);box-shadow:0 0 0 4px rgba(200,116,59,.16)}
.lead-form textarea,.modal-card textarea{resize:vertical}
.form-fine{font-size:.8rem;color:var(--ink-soft);font-weight:500;text-align:center;margin:14px 0 0}
.form-ok{margin:14px 0 0;background:#eef4e6;border:1px solid #c9dab2;color:#41613a;
  padding:14px 16px;border-radius:12px;font-weight:600;font-size:.95rem;text-align:center}

/* ---------- Контакты ---------- */
.contacts-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:start}
.contacts-list{list-style:none;padding:0;margin:26px 0 0;display:grid;gap:20px}
.contacts-list li{display:flex;gap:16px}
.ci-ico{font-size:1.5rem;flex-shrink:0;width:46px;height:46px;border-radius:12px;display:grid;place-items:center;
  background:var(--cream-2);border:1px solid var(--line)}
.contacts-list b{display:block;font-size:1.02rem}
.contacts-list p{margin:2px 0 0;color:var(--ink-soft);font-size:.98rem}
.contacts-list a{color:var(--amber-deep);font-weight:700}
.contacts-channels{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:26px}
.chan{display:flex;align-items:center;gap:10px;padding:.85em 1.1em;border-radius:12px;
  background:var(--paper);border:1px solid var(--line);font-weight:700;font-size:.98rem;
  box-shadow:var(--shadow-sm);transition:transform .2s var(--ease),border-color .2s}
.chan span{font-size:1.2rem}
.chan:hover{transform:translateY(-2px);border-color:var(--amber)}
.qr-card{display:flex;gap:18px;align-items:center;margin-top:26px;background:var(--paper);
  border:1px solid var(--line);border-radius:var(--radius-sm);padding:18px 20px;box-shadow:var(--shadow-sm)}
.qr-card img{width:120px;height:120px;border-radius:10px;background:#fff;border:1px solid var(--line-soft)}
.qr-card b{font-size:1.05rem}
.qr-card p{margin:4px 0 0;font-size:.92rem;color:var(--ink-soft)}
.map-frame{position:relative;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--line)}
.map-frame img{width:100%;height:520px;object-fit:cover}
.map-btn{position:absolute;left:20px;bottom:20px}

/* ---------- Подвал ---------- */
.site-footer{background:#241f19;color:#cdc2b1;padding:64px 0 30px;margin-top:0}
.footer-inner{display:grid;grid-template-columns:1.4fr 1fr 1.1fr;gap:44px;padding-bottom:40px;border-bottom:1px solid #3a332a}
.footer-brand .logo-text{color:#fff;font-size:1.8rem}
.footer-brand p{margin:12px 0 0;font-size:.96rem;max-width:36ch;color:#a99e8c}
.footer-nav{display:flex;flex-direction:column;gap:10px}
.footer-nav a{color:#cdc2b1;font-weight:600;font-size:.98rem}
.footer-nav a:hover{color:var(--amber)}
.footer-phone{font-family:"Cormorant";font-size:1.7rem;font-weight:600;color:#fff}
.footer-contact p{font-size:.94rem;color:#a99e8c;margin:8px 0 14px}
.footer-soc{display:flex;gap:14px}
.footer-soc a{font-weight:700;color:var(--amber);font-size:.95rem}
.footer-fine{padding-top:22px}
.footer-fine p{font-size:.82rem;color:#8b8170;margin:0;max-width:90ch}

/* ---------- Плавающий док ---------- */
.contact-dock{position:fixed;right:18px;top:50%;transform:translateY(-50%);z-index:40;
  display:flex;flex-direction:column;gap:12px}
.dock-btn{width:54px;height:54px;border-radius:50%;display:grid;place-items:center;font-size:1.4rem;
  background:var(--paper);border:1px solid var(--line);box-shadow:var(--shadow-sm);position:relative;
  transition:transform .2s var(--ease),background .2s}
.dock-btn:hover{transform:scale(1.08);background:#fff}
.dock-btn::after{content:attr(data-tip);position:absolute;right:64px;top:50%;transform:translateY(-50%);
  background:var(--ink);color:#fff;font-size:.78rem;font-weight:700;padding:.35em .7em;border-radius:8px;
  white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .2s}
.dock-btn:hover::after{opacity:1}

/* ---------- Мобильная полоса ---------- */
.mobile-bar{display:none;position:fixed;left:0;right:0;bottom:0;z-index:45;
  background:rgba(255,253,248,.96);backdrop-filter:blur(10px);border-top:1px solid var(--line);
  padding:10px 14px calc(10px + env(safe-area-inset-bottom));gap:10px}
.mobile-bar a{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;
  padding:.9em;border-radius:12px;font-weight:700;font-size:1rem}
.mb-call{background:var(--paper);border:1.5px solid var(--cedar);color:var(--ink)}
.mb-book{background:linear-gradient(135deg,var(--amber),var(--amber-deep));color:#fff}

/* ---------- Модалка ---------- */
.modal{position:fixed;inset:0;z-index:60;display:grid;place-items:center;padding:20px}
.modal[hidden]{display:none}
.mobile-menu[hidden]{display:none}
.modal-backdrop{position:absolute;inset:0;background:rgba(36,24,12,.55);backdrop-filter:blur(3px);animation:fade .25s}
.modal-card{position:relative;background:var(--paper);border-radius:var(--radius);padding:36px 34px;
  width:100%;max-width:520px;box-shadow:var(--shadow);max-height:92vh;overflow-y:auto;animation:pop .3s var(--ease)}
@keyframes fade{from{opacity:0}to{opacity:1}}
@keyframes pop{from{opacity:0;transform:translateY(16px) scale(.98)}to{opacity:1;transform:none}}
.modal-x{position:absolute;top:14px;right:16px;background:none;border:0;font-size:2rem;line-height:1;
  color:var(--ink-soft);cursor:pointer}
.modal-card h3{font-size:2rem;margin-bottom:6px}
.modal-lead{color:var(--ink-soft);margin:0 0 22px;font-size:1rem}
.star-pick{display:inline-flex;gap:4px;margin-top:8px}
.star-pick button{background:none;border:0;font-size:2rem;color:var(--line);cursor:pointer;line-height:1;transition:color .15s}
.star-pick button.on{color:var(--amber)}
.file-label input{margin-top:8px;font-size:.9rem}

/* ---------- Анимация появления ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .hero-steam,.scroll-hint span,.dot::before{animation:none}
  html{scroll-behavior:auto}
}

/* =========================================================
   Адаптив
   ========================================================= */
@media (max-width:1024px){
  .main-nav{display:none}
  .burger{display:flex}
  .header-cta .header-phone{display:none}
  .about-grid,.science-grid,.lead-grid,.contacts-grid{grid-template-columns:1fr;gap:40px}
  .benefits-layout{grid-template-columns:1fr;gap:36px}
  .bodymap{max-width:280px}
  .steps,.price-grid{grid-template-columns:1fr 1fr}
  .fact-strip{grid-template-columns:1fr 1fr}
  .reviews-wall{columns:2}
  .footer-inner{grid-template-columns:1fr 1fr}
  .contact-dock{display:none}
}
@media (max-width:640px){
  body{font-size:18px}
  .wrap{padding:0 18px}
  .section{padding:68px 0}
  .header-inner{height:66px}
  .mobile-menu{inset:66px 0 0}
  .hero{min-height:auto;padding:56px 0 80px}
  .hero-actions{flex-direction:column;align-items:stretch}
  .hero-actions .btn{width:100%}
  .trust-row{gap:26px}
  .trust-row b{font-size:2rem}
  .steps,.price-grid,.fact-strip,.benefits-cards,.contacts-channels{grid-template-columns:1fr}
  .reviews-wall{columns:1}
  .about-badge{left:auto;right:16px;bottom:16px}
  .footer-inner{grid-template-columns:1fr;gap:30px}
  .mobile-bar{display:flex}
  body{padding-bottom:74px}
  .map-frame img{height:360px}
  .map-btn{left:14px;bottom:14px;right:14px}
}
