/* ============================================================
   surdologalmaty.kz — main.css
   Тёплая палитра (терракота, золото, шалфей), без синего.
   ============================================================ */

:root{
  /* Фоны */
  --bg-cream:#FAF7F2;
  --bg-ivory:#F5EFE6;
  --bg-warm:#EDE3D2;
  --bg-white:#FFFEFB;

  /* Акценты */
  --terracotta:#B87333;
  --terracotta-deep:#8B4F1F;
  --terracotta-bg:#F5DFC8;
  --gold:#C9A961;
  --gold-deep:#9B7F3D;
  --gold-bg:#F5EBD2;
  --sage:#7A8F6B;
  --sage-deep:#536846;
  --sage-bg:#E5EBDB;

  /* Текст */
  --text-deep:#2C2416;
  --text-body:#4A3F2D;
  --text-muted:#8B7F6B;
  --text-white:#F5EEE2;

  /* Тёмный фон (используется в "флагман"-карточке "Ночное обследование") */
  --bg-dark:#2C2416;

  /* Линии */
  --border-soft:rgba(44,36,22,.10);
  --border-strong:rgba(44,36,22,.18);

  /* Тени */
  --shadow-sm:0 1px 2px rgba(44,36,22,.06);
  --shadow-md:0 4px 12px rgba(44,36,22,.08);
  --shadow-lg:0 10px 30px rgba(44,36,22,.12);

  /* Радиусы */
  --radius-sm:8px;
  --radius-md:12px;
  --radius-lg:18px;

  /* Шрифты */
  --serif:'Cormorant Garamond', Georgia, serif;
  --sans:'Manrope', system-ui, -apple-system, sans-serif;

  /* Layout */
  --container:1200px;
  --header-h:68px;
}

*,*::before,*::after{ box-sizing:border-box; }

html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; overflow-x:clip; }
body{
  margin:0;
  font-family:var(--sans);
  font-size:16px;
  line-height:1.6;
  color:var(--text-body);
  background:var(--bg-cream);
  /* v21: НЕ ставим overflow-x:hidden на body — ломает position:sticky хедера на Safari/Chrome (Mac).
     overflow-x:clip на html удерживает горизонтальную прокрутку, не разрушая sticky-контекст. */
  overflow-x:clip;
}
/* Фолбэк для старых браузеров без overflow:clip — менее жёсткое ограничение, sticky продолжает работать */
@supports not (overflow:clip) {
  html, body { overflow-x:hidden; }
}

img{ max-width:100%; height:auto; display:block; }

a{ color:var(--terracotta-deep); text-decoration:none; }
a:hover{ color:var(--terracotta); text-decoration:underline; }

h1,h2,h3,h4,h5,h6{
  font-family:var(--serif); font-weight:500;
  color:var(--text-deep); line-height:1.2;
  margin:0 0 .5em;
}

.container{
  width:100%;
  max-width:var(--container);
  margin:0 auto;
  padding:0 20px;
}
@media (min-width:1024px){
  .container{ padding:0 32px; }
}

/* ============================================================
   КНОПКИ
   ============================================================ */
.btn{
  display:inline-flex;
  align-items:center; justify-content:center; gap:8px;
  padding:12px 22px;
  font:500 15px/1 var(--sans);
  border:1px solid transparent;
  border-radius:var(--radius-md);
  cursor:pointer;
  text-decoration:none;
  transition:all 200ms ease;
  white-space:nowrap;
  min-height:44px;
}
.btn-sm{ padding:9px 16px; font-size:14px; min-height:38px; }
.btn-lg{ padding:15px 28px; font-size:16px; min-height:52px; }
.btn-primary{ background:var(--terracotta); color:#fff; border-color:var(--terracotta); }
.btn-primary:hover{ background:var(--terracotta-deep); border-color:var(--terracotta-deep); color:#fff; text-decoration:none; transform:translateY(-1px); box-shadow:var(--shadow-md);}
.btn-secondary{ background:var(--bg-white); color:var(--text-deep); border-color:var(--border-strong); }
.btn-secondary:hover{ background:var(--bg-warm); color:var(--text-deep); text-decoration:none; }
.btn-ghost{ background:transparent; color:var(--text-deep); border-color:transparent; }
.btn-ghost:hover{ background:var(--bg-warm); color:var(--text-deep); text-decoration:none; }
.btn:disabled{ opacity:.5; cursor:not-allowed; transform:none !important; }

/* ============================================================
   HEADER
   ============================================================ */
.site-header{
  position:sticky; top:0; z-index:100;
  background:rgba(255,254,251,.92);
  backdrop-filter:saturate(180%) blur(8px);
  -webkit-backdrop-filter:saturate(180%) blur(8px);
  border-bottom:1px solid var(--border-soft);
}
.header-inner{
  display:flex; align-items:center; gap:20px;
  min-height:var(--header-h);
  padding:10px 20px;
}
@media (min-width:1024px){
  .header-inner{ padding:10px 32px; }
}

.logo{
  display:flex; align-items:center; gap:10px;
  text-decoration:none; color:inherit;
  flex-shrink:0;
}
.logo:hover{ text-decoration:none; color:inherit; }
.logo-mark{
  width:42px; height:42px;
  border-radius:50%;
  background:linear-gradient(135deg,#fffbf0,#f5eed9);
  border:1.5px solid var(--gold);
  display:flex; align-items:center; justify-content:center;
  color:var(--terracotta);
  flex-shrink:0;
  box-shadow:0 2px 8px rgba(201,169,97,.18);
}
.logo-text{ display:flex; flex-direction:column; line-height:1.2; min-width:0; }
.logo-surname{ font-family:var(--serif); font-size:16px; font-weight:500; color:var(--text-deep); white-space:nowrap; }
.logo-role{ font-size:11px; color:var(--text-muted); letter-spacing:.05em; text-transform:uppercase; white-space:nowrap; }

.main-nav{
  display:flex; align-items:center; gap:6px;
  margin-left:auto;
  flex-wrap:nowrap;
}
.main-nav a{
  padding:8px 14px;
  border-radius:var(--radius-md);
  font-size:14px; font-weight:500;
  color:var(--text-deep);
  text-decoration:none;
  white-space:nowrap;
  transition:background 150ms;
}
.main-nav a:hover{ background:var(--bg-warm); color:var(--text-deep); text-decoration:none; }
.main-nav a.is-active{ background:var(--gold-bg); color:var(--terracotta-deep); }

.header-actions{
  display:flex; align-items:center; gap:10px;
  flex-shrink:0;
}
.header-phone{
  display:inline-flex; align-items:center; gap:6px;
  font-size:14px; font-weight:500;
  color:var(--text-deep);
  text-decoration:none;
  padding:8px 12px;
  border-radius:var(--radius-md);
}
.header-phone:hover{ background:var(--bg-warm); color:var(--text-deep); text-decoration:none; }

.nav-toggle{
  display:none;
  background:transparent; border:1px solid var(--border-strong);
  border-radius:var(--radius-md);
  width:42px; height:42px;
  cursor:pointer; align-items:center; justify-content:center;
  color:var(--text-deep);
}

/* Адаптив хедера */
@media (max-width:1024px){
  .main-nav{
    display:none;
    position:absolute; top:100%; left:0; right:0;
    background:var(--bg-white);
    flex-direction:column; align-items:stretch;
    padding:14px 20px; gap:0;
    border-bottom:1px solid var(--border-soft);
    box-shadow:var(--shadow-md);
  }
  .main-nav.is-open{ display:flex; }
  .main-nav a{ padding:14px 16px; border-bottom:1px solid var(--border-soft); border-radius:0; font-size:16px; }
  .main-nav a:last-child{ border-bottom:none; }
  .nav-toggle{ display:inline-flex; }
  .header-phone span{ display:none; }
  .header-phone{ padding:8px; }
}
@media (max-width:640px){
  .header-actions .btn{ display:none; }
  .logo-role{ display:none; }
}

/* ============================================================
   HERO И СТРАНИЦЫ
   ============================================================ */
main{ min-height:60vh; }

.hero{
  background:linear-gradient(165deg, var(--bg-cream) 0%, var(--bg-ivory) 50%, var(--bg-warm) 100%);
  padding:70px 0 90px;
  position:relative; overflow:hidden;
}
@media (max-width:768px){ .hero{ padding:48px 0 64px; } }

.hero-grid{
  display:grid;
  grid-template-columns:1.1fr 1fr;
  gap:60px;
  align-items:center;
}
@media (max-width:1024px){ .hero-grid{ grid-template-columns:1fr; gap:40px; } }

.kicker{
  display:inline-flex; align-items:center; gap:8px;
  padding:6px 14px;
  background:var(--bg-white);
  border:1px solid var(--border-soft);
  border-radius:20px;
  font-size:12px; color:var(--gold-deep); font-weight:500;
  margin-bottom:18px;
}
.kicker .dot{
  width:6px; height:6px; border-radius:50%;
  background:var(--sage); animation:pulse 2s infinite;
}
@keyframes pulse{
  0%,100%{ opacity:1; } 50%{ opacity:.4; }
}

.hero h1{
  font-family:var(--serif);
  font-size:clamp(30px,5vw,52px);
  line-height:1.12;
  margin-bottom:20px;
  color:var(--text-deep);
  letter-spacing:-.02em;
  font-weight:500;
}
.hero h1 .pre{
  display:block;
  font-size:.5em;
  color:var(--terracotta-deep);
  letter-spacing:.05em;
  text-transform:uppercase;
  margin-bottom:10px;
}
.hero h1 em{ color:var(--terracotta); font-style:italic; }

.hero p{
  font-size:clamp(15px,2vw,17px);
  line-height:1.7;
  color:var(--text-body);
  max-width:560px;
  margin:0 0 14px;
}

.hero-buttons{ display:flex; gap:12px; flex-wrap:wrap; margin:28px 0; }
@media (max-width:560px){
  .hero-buttons{ flex-direction:column; }
  .hero-buttons .btn{ width:100%; }
}

.hero-stats{ display:flex; gap:30px; flex-wrap:wrap; }
.hero-stat .num{ font-family:var(--serif); font-size:32px; color:var(--terracotta); line-height:1; font-weight:500; }
.hero-stat .lbl{ font-size:12px; color:var(--text-muted); margin-top:4px; }

.hero-card{
  background:var(--bg-white);
  border:1px solid var(--border-soft);
  border-radius:var(--radius-lg);
  padding:24px;
  box-shadow:var(--shadow-md);
}
.hero-card h3{ font-size:18px; margin-bottom:14px; }

.hero-paths{ display:flex; flex-direction:column; gap:12px; }
.path-card{
  display:flex; gap:14px; align-items:flex-start;
  padding:16px;
  background:var(--bg-cream);
  border:1px solid var(--border-soft);
  border-radius:var(--radius-md);
  cursor:pointer;
  text-align:left;
  width:100%;
  font:inherit;
  color:var(--text-deep);
  transition:all 200ms;
}
.path-card:hover{ border-color:var(--gold); transform:translateY(-1px); box-shadow:var(--shadow-sm); }
.path-card .ico{
  width:42px; height:42px;
  border-radius:50%;
  background:var(--gold-bg);
  display:flex; align-items:center; justify-content:center;
  font-size:20px;
  flex-shrink:0;
}
.path-card .lbl{ font-family:var(--serif); font-size:16px; font-weight:600; margin-bottom:2px; color:var(--text-deep); }
.path-card .sub{ font-size:13px; color:var(--text-muted); }

/* ============================================================
   СЕКЦИИ
   ============================================================ */
.section{ padding:70px 0; }
.section.alt{ background:var(--bg-white); }
@media (max-width:768px){ .section{ padding:48px 0; } }

.section-head{ text-align:center; max-width:680px; margin:0 auto 40px; }
.section-kicker{
  display:inline-block;
  font-size:12px; letter-spacing:.15em; text-transform:uppercase;
  color:var(--terracotta-deep);
  margin-bottom:12px; font-weight:500;
}
.section-title{ font-family:var(--serif); font-size:clamp(26px,3.5vw,38px); margin-bottom:14px; line-height:1.18; }
.section-lead{ font-size:16px; line-height:1.65; color:var(--text-body); }

/* Карточки услуг */
.services-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(260px,1fr));
  gap:20px;
}
.service-card{
  display:flex; flex-direction:column;
  padding:22px;
  background:var(--bg-white);
  border:1px solid var(--border-soft);
  border-radius:var(--radius-lg);
  transition:all 250ms;
  text-decoration:none;
  color:inherit;
}
.service-card:hover{ transform:translateY(-2px); box-shadow:var(--shadow-md); border-color:var(--gold); color:inherit; text-decoration:none; }
.service-card .ico{ font-size:30px; margin-bottom:14px; }
.service-card .name{ font-family:var(--serif); font-size:18px; color:var(--text-deep); margin-bottom:6px; font-weight:600; }
.service-card .desc{ font-size:13.5px; color:var(--text-body); line-height:1.55; margin-bottom:14px; flex:1; }
.service-card .price{ display:flex; justify-content:space-between; align-items:baseline; padding-top:14px; border-top:1px solid var(--border-soft); }
.service-card .price-val{ font-family:var(--serif); font-size:20px; color:var(--terracotta); font-weight:500; }
.service-card .price-dur{ font-size:12px; color:var(--text-muted); }

/* ============================================================
   FAQ
   ============================================================ */
.faq{ max-width:780px; margin:0 auto; }
.faq-item{
  background:var(--bg-white);
  border:1px solid var(--border-soft);
  border-radius:var(--radius-md);
  margin-bottom:10px;
  overflow:hidden;
}
.faq-q{
  display:flex; justify-content:space-between; align-items:center;
  padding:18px 22px;
  cursor:pointer;
  font-family:var(--serif); font-size:18px; font-weight:500; color:var(--text-deep);
  list-style:none;
  user-select:none;
}
.faq-q::-webkit-details-marker{ display:none; }
.faq-q::after{ content:'+'; font-size:24px; color:var(--terracotta); transition:transform 200ms; line-height:1; }
.faq-item[open] .faq-q::after{ content:'−'; }
.faq-a{ padding:0 22px 20px; color:var(--text-body); line-height:1.7; font-size:15px; }

/* ============================================================
   REVIEWS
   ============================================================ */
.reviews-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(300px,1fr));
  gap:18px;
}
.review-card{
  background:var(--bg-white);
  border:1px solid var(--border-soft);
  border-radius:var(--radius-lg);
  padding:22px;
}
.review-stars{ display:flex; gap:2px; color:var(--gold); margin-bottom:12px; }
.review-stars svg{ width:16px; height:16px; }
.review-text{ font-size:15px; line-height:1.65; color:var(--text-body); margin-bottom:14px; font-style:italic; }
.review-meta{ display:flex; align-items:center; gap:12px; padding-top:14px; border-top:1px solid var(--border-soft); }
.review-avatar{
  width:42px; height:42px; border-radius:50%;
  background:var(--gold-bg); color:var(--terracotta-deep);
  display:flex; align-items:center; justify-content:center;
  font-family:var(--serif); font-weight:600; font-size:15px;
  flex-shrink:0;
}
.review-name{ font-weight:600; color:var(--text-deep); font-size:14px; }
.review-context{ font-size:12px; color:var(--text-muted); }

/* ============================================================
   CTA БЛОК
   ============================================================ */
.cta-band{
  background:linear-gradient(165deg, var(--gold-bg), var(--terracotta-bg));
  padding:60px 0;
  position:relative; overflow:hidden;
}
.cta-band-inner{ max-width:720px; margin:0 auto; text-align:center; }
.cta-band h2{ font-size:clamp(26px,4vw,38px); margin-bottom:14px; }
.cta-band h2 em{ color:var(--terracotta); font-style:italic; }
.cta-band p{ font-size:16px; color:var(--text-body); line-height:1.6; margin-bottom:24px; }
.cta-band .actions{ display:flex; gap:12px; justify-content:center; flex-wrap:wrap; }
@media (max-width:520px){ .cta-band .actions{ flex-direction:column; } .cta-band .actions .btn{ width:100%; } }

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{
  background:var(--text-deep);
  color:#D9CDB7;
  padding:50px 0 24px;
  margin-top:0;
}
.footer-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(180px,1fr));
  gap:32px;
  margin-bottom:32px;
}
.footer-title{
  font-family:var(--serif);
  color:#FAF7F2;
  font-size:16px;
  font-weight:500;
  margin-bottom:14px;
}
.footer-link{
  display:block;
  color:#B8A988;
  font-size:14px;
  padding:4px 0;
  text-decoration:none;
}
.footer-link:hover{ color:var(--gold); text-decoration:none; }
.footer-text{
  color:#B8A988;
  font-size:13px;
  line-height:1.5;
  padding:4px 0;
}
.footer-legal{
  border-top:1px solid rgba(255,255,255,.1);
  padding-top:20px;
  display:flex;
  justify-content:space-between;
  flex-wrap:wrap;
  gap:14px;
  font-size:12px;
  color:#8B7F6B;
}

/* ============================================================
   МОДАЛКИ (унифицированный стиль)
   ============================================================ */
.modal{
  position:fixed; inset:0;
  z-index:9999;
  display:none;
  align-items:flex-start;
  justify-content:center;
  padding:24px 16px;
  overflow-y:auto;
  -webkit-overflow-scrolling:touch;
  background:rgba(44,36,22,.65);
  backdrop-filter:blur(4px);
  -webkit-backdrop-filter:blur(4px);
}
.modal.is-open{ display:flex; }
.modal-inner{
  position:relative;
  background:var(--bg-cream);
  border-radius:var(--radius-lg);
  max-width:560px;
  width:100%;
  margin:auto;
  box-shadow:0 20px 60px rgba(0,0,0,.3);
  animation:modalIn 280ms ease;
}
@keyframes modalIn{
  from{ opacity:0; transform:translateY(20px) scale(.97); }
  to{ opacity:1; transform:translateY(0) scale(1); }
}
.modal-close{
  position:absolute; top:14px; right:14px;
  width:36px; height:36px;
  border-radius:50%;
  background:var(--bg-white);
  border:1px solid var(--border-soft);
  cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  color:var(--text-deep);
  z-index:2;
}
.modal-close:hover{ background:var(--bg-warm); }

.modal-body{ padding:28px 28px 24px; }
.modal-title{
  font-family:var(--serif);
  font-size:24px;
  font-weight:500;
  color:var(--text-deep);
  margin-bottom:8px;
  padding-right:32px;
}
.modal-sub{ font-size:14px; color:var(--text-muted); margin-bottom:18px; }

/* ============================================================
   ФОРМЫ
   ============================================================ */
.field{ display:flex; flex-direction:column; gap:6px; margin-bottom:14px; }
.field label{ font-size:13px; color:var(--text-deep); font-weight:500; }
.field input,
.field textarea,
.field select{
  width:100%;
  padding:12px 14px;
  font:400 15px/1.5 var(--sans);
  color:var(--text-deep);
  background:var(--bg-white);
  border:1px solid var(--border-strong);
  border-radius:var(--radius-md);
  transition:border-color 150ms;
}
.field input:focus,
.field textarea:focus,
.field select:focus{
  outline:none;
  border-color:var(--terracotta);
  box-shadow:0 0 0 3px rgba(184,115,51,.12);
}
.field textarea{ resize:vertical; min-height:96px; }
.field-hint{ font-size:12px; color:var(--text-muted); }
.field-error{ font-size:12px; color:#B23A48; }

/* Чекбоксы / радиогруппы */
.choice-list{ display:flex; flex-direction:column; gap:8px; }
.choice{
  display:flex; gap:10px; align-items:flex-start;
  padding:12px 14px;
  background:var(--bg-white);
  border:1px solid var(--border-soft);
  border-radius:var(--radius-md);
  cursor:pointer;
  font-size:14px;
}
.choice:hover{ border-color:var(--gold); }
.choice input{ margin:2px 0 0; flex-shrink:0; }
.choice.is-selected{ border-color:var(--terracotta); background:var(--terracotta-bg); }

/* Шаги виджета записи */
.steps{
  display:flex; gap:6px; padding:14px 28px 0;
  font-size:11px; color:var(--text-muted);
  letter-spacing:.05em; text-transform:uppercase;
}
.steps .step{
  flex:1; height:3px; background:var(--border-soft); border-radius:2px;
  position:relative;
}
.steps .step.is-done{ background:var(--terracotta); }
.steps .step.is-current{ background:var(--gold); }

.bw-actions{ display:flex; gap:10px; margin-top:18px; padding-top:18px; border-top:1px solid var(--border-soft); }
.bw-actions .btn{ flex:1; }

/* Сетка дат для виджета */
.slots-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(110px, 1fr));
  gap:8px;
}
.slot-btn{
  padding:10px 8px;
  background:var(--bg-white);
  border:1px solid var(--border-soft);
  border-radius:var(--radius-md);
  font:500 14px var(--sans);
  color:var(--text-deep);
  cursor:pointer;
  text-align:center;
  transition:all 150ms;
}
.slot-btn:hover{ border-color:var(--gold); }
.slot-btn.is-selected{
  background:var(--terracotta-bg);
  border-color:var(--terracotta);
  color:var(--terracotta-deep);
}
.slot-btn .d{ display:block; font-size:11px; color:var(--text-muted); text-transform:uppercase; margin-bottom:2px; }
.slot-btn .t{ font-weight:600; }

/* Звёзды для отзывов */
.stars-input{ display:flex; gap:6px; }
.stars-input button{
  background:transparent; border:0; cursor:pointer;
  color:var(--border-strong); padding:2px;
  font-size:0; line-height:0;
}
.stars-input button svg{ width:30px; height:30px; }
.stars-input button.is-active{ color:var(--gold); }

/* Toast / результат */
.bw-success{
  text-align:center;
  padding:36px 24px;
}
.bw-success-ico{
  width:64px; height:64px; margin:0 auto 16px;
  border-radius:50%;
  background:var(--sage-bg); color:var(--sage-deep);
  display:flex; align-items:center; justify-content:center;
}
.bw-success-ico svg{ width:30px; height:30px; }
.bw-success h3{ font-size:22px; margin-bottom:8px; }
.bw-success p{ color:var(--text-body); line-height:1.6; }

/* ============================================================
   ТАБЛИЦА АДМИНКИ + LIST UTIL
   ============================================================ */
.admin-table{
  width:100%; border-collapse:collapse;
  background:var(--bg-white);
  border-radius:var(--radius-md);
  overflow:hidden;
  box-shadow:var(--shadow-sm);
}
.admin-table th, .admin-table td{
  padding:12px 14px; text-align:left;
  border-bottom:1px solid var(--border-soft);
  font-size:14px;
}
.admin-table th{ background:var(--bg-warm); font-weight:600; color:var(--text-deep); }

.tag{
  display:inline-block;
  padding:2px 8px;
  border-radius:4px;
  font-size:12px;
  font-weight:500;
}
.tag-pending{ background:#FBE9C7; color:#7A4F00; }
.tag-approved{ background:var(--sage-bg); color:var(--sage-deep); }
.tag-rejected{ background:#F5D7D7; color:#8B2A2A; }

/* ============================================================
   PROSE — для статических страниц с текстом (about, blog, legal)
   ============================================================ */
.prose{
  max-width:760px; margin:0 auto;
  font-size:16px; line-height:1.75; color:var(--text-body);
}
.prose h1{ font-size:clamp(28px,4vw,42px); margin-bottom:18px; }
.prose h2{ font-size:clamp(22px,3vw,30px); margin:32px 0 14px; }
.prose h3{ font-size:clamp(18px,2.5vw,22px); margin:26px 0 12px; }
.prose p{ margin:0 0 16px; }
.prose ul, .prose ol{ padding-left:22px; margin:0 0 18px; }
.prose li{ margin-bottom:6px; }
.prose blockquote{
  margin:24px 0; padding:16px 22px;
  border-left:3px solid var(--gold);
  background:var(--gold-bg);
  font-style:italic;
  color:var(--text-deep);
}
.prose strong{ color:var(--text-deep); }
.prose a{ color:var(--terracotta-deep); border-bottom:1px solid var(--terracotta-bg); }
.prose a:hover{ color:var(--terracotta); border-color:var(--terracotta); text-decoration:none; }

/* Page hero (короткий) */
.page-hero{
  background:linear-gradient(165deg, var(--bg-cream), var(--bg-ivory));
  padding:60px 0 40px;
  text-align:center;
}
.page-hero h1{
  font-family:var(--serif);
  font-size:clamp(28px,4vw,44px);
  font-weight:500;
  margin:0 0 12px;
  letter-spacing:-.01em;
}
.page-hero h1 em{ color:var(--terracotta); font-style:italic; }
.page-hero p{
  max-width:640px; margin:0 auto;
  font-size:17px; color:var(--text-body); line-height:1.65;
}

/* Блок с двумя колонками */
.two-col{
  display:grid; grid-template-columns:1fr 1fr; gap:40px;
  align-items:start;
}
@media (max-width:768px){ .two-col{ grid-template-columns:1fr; gap:28px; } }

/* Бокс с фактами */
.fact-list{
  background:var(--bg-white);
  border:1px solid var(--border-soft);
  border-radius:var(--radius-lg);
  padding:24px;
}
.fact-list ul{ list-style:none; padding:0; margin:0; }
.fact-list li{
  display:flex; gap:10px; align-items:flex-start;
  padding:10px 0;
  border-bottom:1px solid var(--border-soft);
}
.fact-list li:last-child{ border-bottom:none; }
.fact-list li::before{
  content:'';
  width:8px; height:8px; margin-top:8px;
  flex-shrink:0;
  border-radius:50%; background:var(--terracotta);
}

/* Fixed bottom CTA для мобилы */
.mobile-fab{
  position:fixed; bottom:20px; right:20px;
  z-index:90;
  display:none;
  flex-direction:column; gap:10px;
}
.mobile-fab .btn{
  box-shadow:0 8px 24px rgba(184,115,51,.35);
  border-radius:50px;
}
@media (max-width:640px){
  .mobile-fab{ display:flex; }
  .mobile-fab .btn{ padding:12px 18px; font-size:14px; }
}

/* Утилиты */
.text-center{ text-align:center; }
.mt-0{margin-top:0!important;} .mt-1{margin-top:8px;} .mt-2{margin-top:16px;} .mt-3{margin-top:24px;} .mt-4{margin-top:32px;}
.mb-0{margin-bottom:0!important;} .mb-1{margin-bottom:8px;} .mb-2{margin-bottom:16px;} .mb-3{margin-bottom:24px;} .mb-4{margin-bottom:32px;}
.hide-on-mobile{ }
@media (max-width:768px){ .hide-on-mobile{ display:none; } }
.show-on-mobile{ display:none; }
@media (max-width:768px){ .show-on-mobile{ display:block; } }

/* Hearing test widget specifics */
.ht-progress{
  height:6px; background:var(--border-soft); border-radius:3px;
  margin-bottom:18px; overflow:hidden;
}
.ht-progress-bar{ height:100%; background:var(--terracotta); transition:width 300ms; }
.ht-tone-btn{
  display:block; width:100%;
  padding:18px;
  background:var(--gold-bg);
  border:2px solid var(--gold);
  color:var(--text-deep);
  border-radius:var(--radius-md);
  font:500 16px var(--sans);
  cursor:pointer;
  margin-bottom:12px;
}
.ht-tone-btn:hover{ background:var(--gold); }
.ht-tone-btn.is-playing{ background:var(--terracotta); border-color:var(--terracotta); color:#fff; }

.ht-yn{ display:flex; gap:10px; }
.ht-yn .btn{ flex:1; }

.ht-result-card{
  text-align:center;
  padding:24px;
  background:var(--bg-white);
  border:1px solid var(--border-soft);
  border-radius:var(--radius-md);
  margin-bottom:18px;
}
.ht-result-num{ font-family:var(--serif); font-size:48px; color:var(--terracotta); font-weight:500; line-height:1; }
.ht-result-cat{ font-size:18px; color:var(--text-deep); margin-top:4px; }

/* Print */
@media print{
  .site-header, .site-footer, .modal, .mobile-fab, .cta-band{ display:none !important; }
}

/* ============================================================
   FALLBACK ZAGLUSHKA для модалок
   ============================================================
   Скрываем модалки в неактивном состоянии. Защита на случай
   если CSS виджета не успел инжектнуться, и HTML модалки
   попал в DOM как обычный текст.
   ============================================================ */
#htModal:not(.active),
#bwModal:not(.active),
#hearingTestModal:not(.active),
#reviewModal:not(.active),
.ht-modal:not(.active),
.bw-modal:not(.active),
.rv-modal:not(.active),
.modal:not(.active):not(.modal--inline) {
  display: none !important;
}

/* Доп. защита: если виджет hearing-test инжектит контент в body
   до подгрузки CSS — он не должен ломать layout */
[data-hearing-test-content]:not(.active),
.hearing-test-inline:not(.active) {
  display: none !important;
}


/* === MOBILE FIXES (inlined from mobile-fixes.css) === */
/* =============================================================
   mobile-fixes.css · 2026-05-04
   Целевые фиксы для iOS Safari, Android Chrome, Samsung Internet
   Подключается ПОСЛЕ main.css
   ============================================================= */

/* iOS Safari: безопасные отступы для iPhone X+ (notch / home indicator) */
@supports (padding-top: env(safe-area-inset-top)) {
  body {
    padding-top: env(safe-area-inset-top);
    padding-bottom: env(safe-area-inset-bottom);
  }
  header {
    padding-top: env(safe-area-inset-top) !important;
  }
}

/* iOS: убираем 300ms задержку клика и серый блик при тапе */
button,
a,
[role="button"],
.btn,
.btn-primary,
.btn-secondary,
.btn-lg,
input[type="submit"],
input[type="button"],
.bw-btn,
.ht-btn,
.oa-btn,
.rv-star,
.cat-card,
.svc-card {
  touch-action: manipulation;
  -webkit-tap-highlight-color: rgba(201, 169, 97, 0.15);
}

/* iOS: input/textarea фикс — отключаем масштабирование при фокусе (минимум 16px) */
input[type="text"],
input[type="tel"],
input[type="email"],
input[type="number"],
textarea,
select {
  font-size: 16px !important;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  border-radius: 8px;
}

/* iOS Safari: фикс для position:fixed в модалках — viewport units правильнее */
.bw-modal,
.ht-modal,
.oa-modal,
.rv-modal {
  /* Используем dvh (dynamic viewport height) — учитывает динамическую высоту в iOS */
  height: 100vh;
  height: 100dvh;
  /* Поддержка для устройств с notch */
  padding-top: env(safe-area-inset-top, 0);
  padding-bottom: env(safe-area-inset-bottom, 0);
}

/* iOS: отключаем "pull-to-refresh" внутри модалок */
.bw-modal.active,
.ht-modal.active,
.oa-modal.active,
.rv-modal.active {
  overscroll-behavior: contain;
}

/* iOS: предотвращаем баг с overflow-y: scroll в модалках */
.bw-inner,
.ht-inner,
.oa-inner,
.rv-modal-inner {
  -webkit-overflow-scrolling: touch;
  overflow-y: auto;
}

/* iOS Safari: фикс для button с SVG внутри — клик по svg должен идти на button */
button > svg,
.btn > svg,
.rv-star > svg,
.bw-btn > svg,
.ht-btn > svg,
.oa-btn > svg {
  pointer-events: none;
}

/* iOS: предотвращаем выделение текста при долгом тапе на кнопках */
button,
a.btn,
.btn-primary,
.btn-secondary,
.btn-lg,
.bw-btn,
.ht-btn,
.oa-btn,
.rv-star,
.cat-card,
.svc-card {
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none;
  -webkit-touch-callout: none;
}

/* Android Chrome: фикс для input с placeholder — цвет должен быть consistent */
input::placeholder,
textarea::placeholder {
  opacity: 1;
  color: #8B7F6B;
}

/* Все мобильные браузеры: smooth scroll отключаем когда модалка открыта */
body.modal-open {
  overflow: hidden;
  position: fixed;
  width: 100%;
}

/* iOS: фикс для sticky header — может моргать */
header {
  -webkit-backdrop-filter: blur(14px);
  backdrop-filter: blur(14px);
  transform: translateZ(0); /* Hardware acceleration */
  will-change: transform;
}

/* Touch targets: минимум 44x44 для iOS WCAG-compliance */
@media (hover: none) and (pointer: coarse) {
  button,
  a.btn,
  .btn-primary,
  .btn-secondary,
  .nav a,
  .lang-switcher a {
    min-height: 44px;
    min-width: 44px;
  }
}

/* Очень узкие экраны (<375px, старые iPhone SE) */
@media (max-width: 380px) {
  .container {
    padding-left: 12px !important;
    padding-right: 12px !important;
  }
  h1 { font-size: 26px !important; line-height: 1.2 !important; }
  h2 { font-size: 22px !important; line-height: 1.25 !important; }
  .btn-lg {
    padding: 13px 18px !important;
    font-size: 14px !important;
  }
}

/* iOS Safari: dropdown меню должно быть выше всего */
.nav-dropdown,
.nav-dropdown-menu {
  z-index: 9999;
}

/* iOS Safari: смайлики/эмодзи могут быть огромными — ограничиваем */
.cat-card-icon,
.svc-card-icon,
.feature-icon {
  font-size: clamp(20px, 4vw, 28px);
  line-height: 1;
}

/* Высокий DPI экранов (Retina): SVG звёзды должны быть чёткими */
@media (-webkit-min-device-pixel-ratio: 2), (min-resolution: 192dpi) {
  .rv-star svg path {
    shape-rendering: geometricPrecision;
  }
}
