﻿/* Shared stylesheet for core pages.
   Source: extracted/merged from:
   - redesign/service.html
   - redesign/variant-a-v3.html
   - redesign/doctors.html
   - redesign/actions.html
   - redesign/before_after.html
*/

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scrollbar-gutter:stable}
:root{
  /* Palette v2 */
  --white:#ffffff;
  --bg:#f3f2f3;
  --surface:#ffffff;
  --border:#d6d0cd;
  --muted:#e4e2e4;
  --accent:#b7b8ea;
  --accent-rgb:183,184,234;
  --brand:#6e18a2;
  --brand-rgb:110,24,162;

  /* Map palette to existing tokens */
  --primary:var(--accent);
  --primary-dark:var(--accent);
  --primary-light:var(--accent);
  --blue:var(--accent);
  --lavender:var(--muted);
  --cream:var(--bg);

  --black:#111;
  --gray-50:var(--bg);
  --gray-100:var(--muted);
  --gray-200:var(--border);
  --gray-300:var(--border);
  --gray-400:#9ca3af;--gray-500:#6b7280;--gray-600:#4b5563;--gray-700:#374151;--gray-800:#1f2937;

  /* Rounded corners (v3) */
  --radius:12px;--radius-sm:8px;--radius-lg:20px;--radius-xl:28px;--pill:999px;

  --shadow-sm:0 1px 3px rgba(0,0,0,.06);--shadow:0 4px 20px rgba(0,0,0,.08);--shadow-lg:0 12px 40px rgba(0,0,0,.1);
  --transition:all .3s cubic-bezier(.4,0,.2,1);
  /* Responsive container: must work on mobile */
  --container:clamp(320px,92vw,1560px);

  /* Typography weights (A v2: lighter overall) */
  --fw-light:300;
  --fw-regular:400;
  --fw-medium:500;
  --fw-semibold:600;
}
html{scroll-behavior:smooth}
body{font-family:'Manrope',system-ui,-apple-system,'Segoe UI',sans-serif;color:var(--black);background:var(--bg);line-height:1.6;overflow-x:hidden;-webkit-font-smoothing:antialiased;font-weight:var(--fw-regular)}

/* Replace old purple-tinted accents with new palette */
.hero-kicker,
.about-label{background:rgba(var(--accent-rgb),.22) !important;border-color:rgba(var(--accent-rgb),.45) !important}
.mega-services-results .res strong mark{background:rgba(var(--accent-rgb),.28) !important}
.mega-services-quick a.is-highlight{background:rgba(var(--accent-rgb),.22) !important}
.filter-btn.active{color:var(--black) !important;box-shadow:0 8px 20px rgba(var(--accent-rgb),.35) !important}
.filter-count{background:rgba(var(--accent-rgb),.28) !important;color:var(--black) !important}
.mm-promo{border-color:rgba(var(--accent-rgb),.35) !important}
.quiz-option:hover{background:rgba(var(--accent-rgb),.14) !important}
.quiz-option.selected{background:rgba(var(--accent-rgb),.24) !important;color:var(--black) !important}

img{max-width:100%;display:block}
a{text-decoration:none;color:inherit;transition:var(--transition)}
button{font-family:inherit;cursor:pointer;border:none;outline:none}
ul{list-style:none}
.container{max-width:var(--container);margin:0 auto;padding:0 24px}
.section{padding:96px 0}
.section-label{font-size:12px;font-weight:var(--fw-medium);letter-spacing:2px;text-transform:uppercase;color:var(--brand);margin-bottom:12px}
.section-title{font-size:clamp(28px,4vw,42px);font-weight:var(--fw-semibold);line-height:1.15;margin-bottom:14px;color:var(--black)}
.section-subtitle{font-size:17px;color:var(--gray-500);max-width:560px;line-height:1.7}
.section-subtitle--spaced{margin-bottom:18px}
.section-subtitle--xl{margin-bottom:48px}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:var(--fw-medium);font-size:15px;padding:14px 32px;border-radius:var(--pill);transition:var(--transition);white-space:nowrap;border:none;cursor:pointer}
.btn-primary{background:var(--primary);color:var(--black);box-shadow:0 4px 20px rgba(0,0,0,.12)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 32px rgba(0,0,0,.16)}
.btn-outline{border:2px solid var(--primary);color:var(--primary);background:transparent}
.btn-outline:hover{background:var(--primary);color:var(--black)}
.btn-white{background:#fff;color:var(--primary);font-weight:var(--fw-semibold);box-shadow:var(--shadow)}
.btn-white:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.btn-sm{padding:10px 24px;font-size:13px}
.btn:focus-visible,
.contact-channel:focus-visible,
.actions-card-link:focus-visible,
.service-card:focus-visible,
.clinic-card:focus-visible,
.review-card:focus-visible{
  outline:3px solid rgba(var(--accent-rgb),.7);
  outline-offset:2px;
}
.btn-primary:hover,
.btn-outline:hover,
.btn-white:hover{
  filter:saturate(1.03);
}
.btn-primary:active,
.btn-outline:active,
.btn-white:active{
  transform:translateY(0);
}

/* ===== Lead modals (Booking / Callback) ===== */
body.modal-open{overflow:hidden}
.ld-modal-overlay{
  position:fixed;
  inset:0;
  z-index:3000;
  display:flex;
  align-items:flex-start;
  justify-content:center;
  padding:24px;
  background:rgba(17,24,39,.52);
  backdrop-filter:blur(10px);
  opacity:0;
  visibility:hidden;
  transition:opacity .18s ease, visibility 0s linear .18s;
  overflow:auto;
  -webkit-overflow-scrolling:touch;
}
.ld-modal-overlay.is-open{opacity:1;visibility:visible;transition:opacity .18s ease, visibility 0s}
.ld-modal{
  width:min(720px, 100%);
  background:rgba(255,255,255,.96);
  border:1px solid rgba(0,0,0,.08);
  border-radius:22px;
  box-shadow:0 30px 80px rgba(0,0,0,.28);
  overflow:hidden;
  transform:translateY(10px);
  transition:transform .18s ease;
  max-height:calc(100dvh - 48px);
  display:flex;
  flex-direction:column;
}
.ld-modal-overlay.is-open .ld-modal{transform:translateY(0)}
.ld-modal-close{
  position:absolute;
  right:14px;
  top:12px;
  width:42px;
  height:42px;
  border-radius:14px;
  border:1px solid rgba(0,0,0,.10);
  background:rgba(255,255,255,.8);
  color:var(--gray-700);
  font-size:22px;
  line-height:1;
  cursor:pointer;
  z-index:3;
}
.ld-modal-close:hover{background:#fff;color:var(--black)}
.ld-modal{position:relative}
.ld-modal-head{
  padding:22px 22px 8px;
  background:linear-gradient(135deg, rgba(155,38,168,.12), rgba(199,230,245,.28));
  border-bottom:1px solid rgba(0,0,0,.06);
  position:sticky;
  top:0;
  z-index:2;
}
.ld-modal-kicker{font-size:12px;font-weight:var(--fw-semibold);letter-spacing:.08em;text-transform:uppercase;color:var(--gray-600)}
.ld-modal-title{margin:8px 0 0;font-size:40px;line-height:1.05;letter-spacing:-.02em}
.ld-modal-form{
  padding:18px 22px 22px;
  display:grid;
  gap:12px;
  overflow:auto;
  -webkit-overflow-scrolling:touch;
}
.ld-field{display:grid;gap:6px}
.ld-field-label{font-size:12px;color:var(--gray-600);font-weight:600}
.ld-input{
  width:100%;
  min-height:46px;
  padding:12px 14px;
  border-radius:14px;
  border:1px solid var(--gray-200);
  background:#fff;
  font:inherit;
  outline:none;
}
.ld-input:focus{border-color:rgba(155,38,168,.45);box-shadow:0 0 0 4px rgba(155,38,168,.12)}
.ld-checks{margin-top:2px;display:grid;gap:12px}
.ld-check{
  display:grid;
  grid-template-columns:18px 1fr;
  gap:10px;
  align-items:start;
  font-size:13px;
  line-height:1.5;
  color:var(--gray-700);
}
.ld-check input{margin-top:2px;accent-color:var(--primary)}
.ld-check a{color:var(--primary);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:3px}
.ld-warning{
  font-size:13px;
  line-height:1.5;
  padding:10px 12px;
  border-radius:14px;
  border:1px solid rgba(155,38,168,.18);
  background:rgba(155,38,168,.06);
  color:var(--gray-800);
}
.ld-warning b{color:var(--primary)}
.ld-modal-actions{margin-top:8px;display:flex;gap:10px}
.ld-modal-actions .btn{width:100%}

/* Validation hint (simple) */
.ld-modal-form.is-submitted input:invalid{border-color:rgba(220,38,38,.55);box-shadow:0 0 0 4px rgba(220,38,38,.10)}

@media(max-width:680px){
  .ld-modal-overlay{padding:14px;padding-top:calc(14px + env(safe-area-inset-top, 0px));padding-bottom:calc(14px + env(safe-area-inset-bottom, 0px))}
  .ld-modal{max-height:calc(100dvh - 28px)}
  .ld-modal-title{font-size:30px}
  .ld-modal-head{padding:18px 16px 8px}
  .ld-modal-form{padding:14px 16px 16px}
}

/* Unified service-hero rhythm on internal pages */
.service-hero .service-hero-body{
  display:flex;
  flex-direction:column;
  justify-content:center;
  min-height:100%;
  padding:36px clamp(20px,2.1vw,34px);
  gap:16px;
}
.service-hero .service-title{
  font-size:clamp(28px,3.2vw,42px);
  line-height:1.1;
  letter-spacing:-.02em;
  margin:0;
}
.service-hero .section-subtitle{
  margin:0;
  max-width:62ch;
  font-size:16px;
  line-height:1.65;
}
.service-hero .service-price,
.service-hero .service-cta{margin-top:2px !important}
.service-hero .service-meta{margin-top:8px}

/* Unified cards style (clinics/reviews/equipment) */
.clinic-card,
.review-card,
.equipment-showcase-item{
  border-radius:var(--radius-lg);
  border:1px solid var(--gray-200);
  box-shadow:var(--shadow-sm);
}
.clinic-card:hover,
.review-card:hover,
.equipment-showcase-item:hover{
  border-color:rgba(var(--accent-rgb),.6);
  box-shadow:var(--shadow);
}

/* Service: credit/instalment strip in hero */
.service-credit{
  margin-top:14px;
  padding:12px 14px;
  border-radius:16px;
  border:1px dashed rgba(var(--accent-rgb),.5);
  background:rgba(var(--accent-rgb),.08);
  display:flex;
  align-items:flex-start;
  gap:14px;
  flex-wrap:wrap;
}
.service-credit-info{min-width:0;flex:1 1 0}
.service-credit-kicker{
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.08em;
  font-weight:var(--fw-semibold);
  color:var(--gray-700);
  margin-bottom:4px;
}
.service-credit-text{
  font-size:13px;
  line-height:1.5;
  color:var(--gray-700);
}
.service-credit-actions{flex-shrink:0;display:flex;align-items:center}
.service-credit-btn{
  white-space:nowrap;
}
@media(max-width:768px){
  .service-credit{align-items:stretch}
  .service-credit-actions{width:100%;justify-content:flex-start}
  .service-credit-btn{width:100%}
}

/* Payment online: certificates (two-step) */
.cert-flow{margin-top:18px}
.cert-step[hidden]{display:none !important}
.cert-card{
  border:1px solid var(--gray-200);
  background:var(--white);
  border-radius:var(--radius-xl);
  box-shadow:var(--shadow-sm);
  overflow:hidden;
  display:grid;
  grid-template-columns:1.1fr .9fr;
  min-height:460px;
}
.cert-card-body{padding:22px 22px 22px;display:flex;flex-direction:column;gap:14px}
.cert-kicker{font-size:12px;font-weight:var(--fw-semibold);letter-spacing:.08em;text-transform:uppercase;color:var(--gray-600)}
.cert-title{margin:0;font-size:28px;line-height:1.15;letter-spacing:-.02em}
.cert-text{margin:0;color:var(--gray-700);max-width:62ch;line-height:1.65}
.cert-denoms{display:flex;flex-wrap:wrap;gap:10px;margin-top:6px}
.cert-denom{
  border:1px solid var(--gray-200);
  background:rgba(var(--accent-rgb),.06);
  color:var(--black);
  border-radius:999px;
  padding:10px 14px;
  font-size:18px;
  cursor:pointer;
  transition:transform .12s ease, box-shadow .12s ease, border-color .12s ease, background .12s ease;
  position:relative;
  padding-right:44px;
}
.cert-denom:hover{transform:translateY(-1px);box-shadow:0 12px 26px rgba(0,0,0,.08);border-color:rgba(var(--accent-rgb),.55)}
.cert-denom::after{
  content:'';
  position:absolute;
  right:10px;
  top:50%;
  transform:translateY(-50%);
  width:26px;
  height:26px;
  border-radius:999px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(255,255,255,.55);
  border:1px solid rgba(0,0,0,.16);
  box-shadow:0 8px 18px rgba(0,0,0,.06);
  opacity:.55;
}
.cert-denom.is-active{
  background:linear-gradient(135deg, rgba(var(--accent-rgb),.22), rgba(var(--brand-rgb),.10));
  border-color:rgba(var(--accent-rgb),1);
  box-shadow:0 18px 40px rgba(0,0,0,.14), 0 0 0 6px rgba(var(--accent-rgb),.10);
  transform:translateY(-1px);
}
.cert-denom.is-active::after{
  content:'✓';
  position:absolute;
  right:10px;
  top:50%;
  transform:translateY(-50%);
  width:26px;
  height:26px;
  border-radius:999px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(var(--accent-rgb),.22);
  border:1px solid rgba(var(--accent-rgb),.65);
  color:var(--black);
  font-weight:700;
  font-size:14px;
  line-height:1;
  opacity:1;
  box-shadow:0 10px 22px rgba(0,0,0,.10);
}
.cert-denom:focus-visible{
  outline:3px solid rgba(199,230,245,.95);
  outline-offset:3px;
}
.cert-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:2px}
.cert-footer{margin-top:auto;display:flex;flex-direction:column;gap:10px}
.cert-note{font-size:12px;color:var(--gray-600);line-height:1.6}
.cert-card-media{
  background:
    linear-gradient(135deg, rgba(155,38,168,.10), rgba(199,230,245,.24)),
    url("./gift.png");
  background-size:cover;
  background-position:center;
  min-height:320px;
}
.pay-grid{
  display:grid;
  grid-template-columns:1fr minmax(320px, 520px);
  gap:18px;
  align-items:start;
}
.pay-side{
  border:1px solid var(--gray-200);
  background:rgba(var(--accent-rgb),.06);
  border-radius:var(--radius-xl);
  padding:18px;
  box-shadow:var(--shadow-sm);
}
.pay-badge{display:inline-flex;gap:10px;align-items:center;font-weight:var(--fw-semibold);letter-spacing:-.01em}
.pay-badge svg{width:22px;height:22px;color:var(--primary)}
.pay-back{margin-top:14px;display:inline-flex;align-self:flex-start}
.pay-merchant{margin-top:10px;font-weight:var(--fw-semibold);color:var(--black)}
.pay-merchant span{display:block;margin-top:4px;font-weight:var(--fw-medium);color:var(--gray-600)}
.pay-summary{margin-top:12px;color:var(--gray-700);line-height:1.6}
.pay-summary b{color:var(--black)}
.pay-links{margin-top:14px;display:flex;gap:10px;flex-wrap:wrap}
.cert-faq{margin-top:14px}
.pay-form-card{
  border:1px solid var(--gray-200);
  background:var(--white);
  border-radius:var(--radius-xl);
  box-shadow:var(--shadow-sm);
  padding:18px;
}
.pay-form{display:grid;gap:12px}
.pay-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:6px}
.pay-actions .btn{flex:1 1 160px}
.pay-legal{font-size:12px;color:var(--gray-600);line-height:1.6;margin-top:6px}
.pay-legal a{color:var(--primary);text-decoration:underline;text-underline-offset:3px}

@media(max-width:980px){
  .cert-card{grid-template-columns:1fr}
  .cert-card-media{min-height:220px;order:-1}
  .pay-grid{grid-template-columns:1fr}
}
@media(max-width:480px){
  .cert-card-body{padding:16px}
  .cert-title{font-size:22px}
  .cert-denom{padding:9px 12px;font-size:15px;padding-right:40px}
  .pay-side,.pay-form-card{padding:14px}
}

/* Gift certificates page: tighten vertical rhythm between adjacent sections on mobile */
@media(max-width:768px){
  #giftList.section{padding-bottom:28px}
  #certificatePay.section{padding-top:28px}
}
@media(max-width:480px){
  #giftList.section{padding-bottom:22px}
  #certificatePay.section{padding-top:22px}
}

/* Service: vertical video stories carousel before prices */
.video-stories{
  padding:0;
  margin-bottom:28px;
}
.video-stories-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:18px;
  margin-bottom:16px;
}
.video-stories-title{
  font-size:20px;
  line-height:1.3;
  margin:0 0 6px;
}
.video-stories-subtitle{
  font-size:13px;
  line-height:1.6;
  color:var(--gray-600);
  max-width:420px;
}
.video-stories-legend{
  display:flex;
  align-items:center;
  gap:8px;
  font-size:12px;
  color:var(--gray-500);
  white-space:nowrap;
}
.video-stories-dot{
  width:8px;
  height:8px;
  border-radius:999px;
  background:var(--primary);
  box-shadow:0 0 0 4px rgba(var(--accent-rgb),.24);
}
.video-stories-track{
  display:flex;
  gap:14px;
  overflow-x:auto;
  scrollbar-width:none;
  -webkit-overflow-scrolling:touch;
  padding:4px 2px 2px;
  scroll-snap-type:x mandatory;
}
.video-stories-track::-webkit-scrollbar{display:none}
.video-story{
  flex:0 0 220px;
  max-width:220px;
  scroll-snap-align:start;
}
.video-story--large{
  flex:0 0 300px;
  max-width:300px;
}
.video-story--large .video-story-name{
  font-size:15px;
}
.video-story--large .video-story-note{
  font-size:12.5px;
}
.video-story--large .video-story-badge{
  font-size:12px;
}
.video-story-link{
  display:flex;
  flex-direction:column;
  gap:8px;
}
.video-story-media{
  position:relative;
  border-radius:24px;
  padding-top:182%;
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
  overflow:hidden;
}
.video-story-badge{
  position:absolute;
  left:10px;
  top:10px;
  padding:3px 8px;
  border-radius:999px;
  background:rgba(0,0,0,.6);
  color:#fff;
  font-size:11px;
  font-weight:var(--fw-semibold);
}
.video-story-icon{
  position:absolute;
  right:10px;
  bottom:10px;
  width:32px;
  height:32px;
  border-radius:999px;
  background:rgba(0,0,0,.7);
}
.video-story-icon::before{
  content:'';
  position:absolute;
  inset:9px 11px 9px 13px;
  border-style:solid;
  border-width:7px 0 7px 11px;
  border-color:transparent transparent transparent #fff;
}
.video-story-body{
  padding:6px 2px 0;
}
.video-story-label{
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.08em;
  color:var(--gray-500);
  margin-bottom:2px;
}
.video-story-name{
  font-size:14px;
  font-weight:var(--fw-semibold);
  color:var(--black);
  margin-bottom:2px;
}
.video-story-note{
  font-size:12px;
  line-height:1.5;
  color:var(--gray-600);
}
.video-stories-nav{
  margin-top:10px;
  justify-content:flex-start;
}
.video-stories-nav button{
  width:34px;
  height:34px;
  border-radius:999px;
}
@media(max-width:900px){
  .video-stories-head{
    flex-direction:column;
    align-items:flex-start;
  }
  .video-stories-legend{
    white-space:normal;
  }
}
@media(max-width:600px){
  .video-story{flex:0 0 170px;max-width:170px}
  .video-story--large{flex:0 0 210px;max-width:210px}
}

/* ===== Service: top promo block (old-site inspired, new UI) ===== */
.service-promo-top{
  padding:26px 0 10px;
}
.service-promo-card{
  border-radius:var(--radius-xl);
  border:1px solid var(--gray-200);
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(10px);
  box-shadow:var(--shadow-sm);
  overflow:hidden;
  display:grid;
  grid-template-columns:minmax(260px, 520px) 1fr;
  align-items:stretch;
}
.service-promo-media{
  min-height:220px;
  background:
    linear-gradient(90deg, rgba(0,0,0,.10) 0%, rgba(0,0,0,.06) 55%, rgba(0,0,0,0) 100%),
    url("https://msk.laserdoctor.ru/upload/resize_cache/iblock/aa8/1408_644_1/q4i8woo1i17cpp67chd4f79kv1tkt5vu.webp") center/cover no-repeat;
}
.service-promo-body{
  padding:22px 22px 20px;
  display:flex;
  flex-direction:column;
  gap:12px;
  min-width:0;
}
.service-promo-badges{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  align-items:center;
}
.service-promo-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:6px 12px;
  border-radius:999px;
  font-size:12px;
  font-weight:var(--fw-semibold);
  background:rgba(var(--accent-rgb),.16);
  border:1px solid rgba(var(--accent-rgb),.38);
  color:var(--black);
}
.service-promo-badge--strong{
  background:rgba(var(--accent-rgb),.30);
  border-color:rgba(var(--accent-rgb),.55);
}
.service-promo-title{
  margin:0;
  font-size:22px;
  line-height:1.2;
  letter-spacing:-.2px;
}
.service-promo-text{
  margin:0;
  font-size:13.5px;
  line-height:1.65;
  color:var(--gray-700);
  max-width:72ch;
}
.service-promo-meta{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
  color:var(--gray-600);
  font-size:12.5px;
}
.service-promo-date{
  display:inline-flex;
  align-items:center;
  color: #9b4242;
  font-weight: 600;
  gap:8px;
  padding:6px 10px;
  border-radius:999px;
  background:var(--gray-50);
  border:1px solid var(--gray-200);
}
.service-promo-link{
  color:var(--primary);
  font-weight:var(--fw-semibold);
}
.service-promo-link:hover{text-decoration:underline}
.service-promo-actions{
  margin-top:2px;
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}
.service-promo-actions .btn{
  flex:0 0 auto;
}
/* Icon-only buttons for promo secondary actions */
.btn.btn-icon{
  width:46px;
  height:46px;
  padding:0;
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
}
.btn.btn-icon svg{
  width:20px;
  height:20px;
}
@media(min-width:981px){
  .service-promo-actions .btn{
    min-height:46px;
  }
  .service-promo-actions .btn.btn-primary{
    box-shadow:0 10px 26px rgba(0,0,0,.14);
  }
}
@media(max-width:980px){
  .service-promo-card{
    grid-template-columns:1fr;
  }
  .service-promo-media{
    min-height:210px;
  }
}
@media(max-width:560px){
  .service-promo-top{padding:18px 0 6px}
  .service-promo-body{padding:16px 16px 14px}
  .service-promo-title{font-size:18px}
  .service-promo-actions .btn{width:100%}
}

/* Service credit nav (instalment button look like carousel controls) */
.service-credit-nav{
  margin-top:0;
}
.service-credit-nav button{
  width:auto !important;
  padding:0 16px;
  border-radius:999px !important;
  font-weight:var(--fw-semibold);
  white-space:nowrap;
}

/* ===== Video modal (open on same site) ===== */
.video-modal-overlay{
  position:fixed;
  inset:0;
  z-index:3200;
  display:none;
  align-items:flex-start;
  justify-content:center;
  padding:24px;
  background:rgba(17,24,39,.52);
  backdrop-filter:blur(10px);
  overflow-y:auto;
}
.video-modal-overlay.is-open{display:flex}
.video-modal{
  width:min(560px, 100%);
  background:rgba(255,255,255,.96);
  border:1px solid rgba(0,0,0,.08);
  border-radius:22px;
  box-shadow:0 30px 80px rgba(0,0,0,.28);
  overflow:hidden;
  display:flex;
  flex-direction:column;
  max-height:calc(100vh - 48px);
}
.video-modal-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:16px 16px 12px;
  border-bottom:1px solid rgba(0,0,0,.06);
  background:linear-gradient(135deg, rgba(155,38,168,.10), rgba(199,230,245,.22));
  position:relative;
  z-index:2;
}
.video-modal-title{
  font-size:14px;
  font-weight:var(--fw-semibold);
  color:var(--black);
  letter-spacing:-.2px;
  min-width:0;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.video-modal-close{
  width:42px;height:42px;
  border-radius:14px;
  border:1px solid rgba(0,0,0,.10);
  background:rgba(255,255,255,.85);
  color:var(--gray-700);
  font-size:22px;line-height:1;
  cursor:pointer;
}
.video-modal-close:hover{background:#fff;color:var(--black)}
.video-modal-player{
  width:100%;
  background:#000;
  position:relative;
  /* Vertical stories feel: 9:16 */
  padding-top:0;
  aspect-ratio:9/16;
  flex:1 1 auto;
  overflow:hidden;
  z-index:1;
}
.video-modal-player iframe{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  border:0;
}
.video-modal-player video{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  border:0;
  object-fit:cover;
  background:#000;
}
.video-modal-actions{
  padding:12px 16px 16px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
  position:relative;
  z-index:2;
}

.video-modal-arrows{
  margin-top:0;
}
.video-modal-cta-nav{
  margin-top:0;
}
.video-modal-cta-nav button{
  width:auto !important;
  padding:0 16px;
  border-radius:999px !important;
  font-weight:var(--fw-semibold);
  white-space:nowrap;
  height:46px;
}
.video-modal-share-btn{
  white-space:nowrap;
}

@media(max-width:680px){
  .video-modal-overlay{padding:14px}
  .video-modal-head{padding:14px 12px 10px}
  .video-modal-actions{padding:10px 12px 14px}
}

/* Trust micro-block */
.trust-strip{padding:0 0 14px}
.trust-strip-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:10px;
}
.trust-chip{
  border:1px solid var(--gray-200);
  border-radius:12px;
  background:var(--white);
  padding:10px 12px;
  font-size:12px;
  line-height:1.4;
  color:var(--gray-700);
}
.trust-chip b{display:block;color:var(--black);font-size:13px}

/* Mobile sticky CTA (internal pages) */
.mobile-sticky-cta{
  display:none;
}
body.has-mobile-sticky-cta{padding-bottom:86px}
@media(max-width:980px){
  .trust-strip-grid{grid-template-columns:1fr}
  .header{padding-top:env(safe-area-inset-top,0)}
  .mm-head{padding-top:calc(14px + env(safe-area-inset-top,0))}
  .mobile-sticky-cta{
    display:flex;
    position:fixed;
    left:10px;
    right:10px;
    bottom:calc(10px + env(safe-area-inset-bottom, 0px));
    z-index:1400;
    gap:8px;
    padding:8px;
    border:1px solid var(--gray-200);
    border-radius:14px;
    background:rgba(255,255,255,.94);
    backdrop-filter:blur(8px);
    box-shadow:0 8px 28px rgba(17,17,17,.14);
  }
  .mobile-sticky-cta .btn{
    width:100%;
    min-height:44px;
    padding:10px 12px;
    font-size:13px;
  }
  .to-top{
    bottom:calc(92px + env(safe-area-inset-bottom, 0px)) !important;
  }
}

/* Visual marker for unresolved placeholders */
.content-empty{
  outline:2px dashed rgba(190,88,122,.35);
  outline-offset:2px;
}
/* Fade-in should never hide content if JS doesn't run */
.fade-in{opacity:1;transform:none}
.fade-in.visible{opacity:1;transform:none}
@media (prefers-reduced-motion: no-preference){
  html.has-anim .fade-in{opacity:0;transform:translateY(30px);transition:opacity .7s ease,transform .7s ease}
  html.has-anim .fade-in.visible{opacity:1;transform:translateY(0)}
}

/* Mobile polish: spacing, typography, overflow */
@media(max-width:768px){
  .container{padding:0 16px}
  .section{padding:56px 0}
  .section-title{overflow-wrap:anywhere;hyphens:auto}
  .section-subtitle{font-size:15px;line-height:1.65}
  .section-subtitle--xl{margin-bottom:28px}
  .btn{font-size:14px;padding:12px 18px;white-space:normal}
  .btn-sm{font-size:13px;padding:10px 14px}
  .promo-bar{padding-left:16px;padding-right:44px}
  .promo-timer b{min-width:26px}
  .header-top-left .info-item{white-space:normal}
  .clinic-link{white-space:normal}
}
@media(max-width:480px){
  .container{padding:0 10px}
  .section{padding:48px 0}
  .section-title{font-size:clamp(22px,7vw,30px);line-height:1.15}
  .section-subtitle--xl{margin-bottom:22px}
  .btn{width:100%}
  .hero-buttons .btn{width:auto}
}

/* Services section: keep desktop spacious, tighten on mobile (Android complaint) */
.services-variant-a .section-subtitle.section-subtitle--spaced{margin-bottom:48px}
@media(max-width:768px){
  .services-variant-a .section-subtitle.section-subtitle--spaced{margin-bottom:28px}
}
@media(max-width:480px){
  .services-variant-a .section-subtitle.section-subtitle--spaced{margin-bottom:22px}
}

/* ===== 1. PROMO TIMER BAR ===== */
.promo-bar{background:var(--accent);color:var(--black);padding:10px 20px;text-align:center;font-size:14px;font-weight:var(--fw-medium);position:relative;z-index:1100;display:flex;align-items:center;justify-content:center;gap:16px;flex-wrap:wrap}
.promo-bar.hidden{display:none}
.promo-timer{display:inline-flex;gap:6px;font-weight:var(--fw-semibold)}
.promo-timer b{background:rgba(255,255,255,.2);padding:2px 8px;border-radius:4px;min-width:30px;text-align:center;font-variant-numeric:tabular-nums}
.promo-close{position:absolute;right:16px;top:50%;transform:translateY(-50%);background:none;color:#fff;font-size:1.2rem;opacity:.7;padding:4px}
.promo-close:hover{opacity:1}

/* ===== 2. HEADER ===== */
.header{position:sticky;top:0;z-index:1000;background:var(--surface);border-bottom:1px solid var(--gray-200);transition:box-shadow .3s}
.header.scrolled{box-shadow:0 2px 24px rgba(0,0,0,.06)}

.header-top{border-bottom:1px solid var(--gray-100);padding:6px 0;font-size:13px;color:var(--gray-500)}
.header-top .container{display:flex;align-items:center;justify-content:space-between}
.header-top-left{display:flex;align-items:center;gap:20px}
.header-top-left .city-select{color:var(--primary);font-weight:var(--fw-medium);cursor:pointer;display:flex;align-items:center;gap:4px}
.header-top-left .city-select svg{width:14px;height:14px}
.city-switch-wrap{position:relative;display:inline-flex}
.city-popup{position:absolute;top:calc(100% + 6px);left:0;z-index:1000;min-width:220px;background:var(--white);border:1px solid var(--gray-200);border-radius:12px;box-shadow:var(--shadow-md);padding:6px;display:flex;flex-direction:column;gap:2px}
.city-popup[hidden]{display:none}
.city-popup-item{appearance:none;-webkit-appearance:none;border:none;background:transparent;text-align:left;padding:10px 12px;border-radius:10px;cursor:pointer;font:inherit;color:var(--gray-700);transition:var(--transition);display:flex;align-items:center;justify-content:space-between;gap:12px}
.city-popup-item:hover{background:rgba(var(--accent-rgb),.14);color:var(--black)}
.city-popup-item[aria-checked="true"]{background:rgba(var(--accent-rgb),.10);color:var(--black);font-weight:var(--fw-semibold)}
.city-popup-item[aria-checked="true"]::after{content:"✓";color:var(--brand,#6e18a2)}
.header-top-left .info-item{display:flex;align-items:center;gap:6px;white-space:nowrap}
.header-top-left .info-item svg{width:14px;height:14px;opacity:.5}
.header-top-right{display:flex;align-items:center;gap:16px}
.header-top-right a{font-weight:500;transition:color .2s}
.header-top-right a:hover{color:var(--primary)}
.social-icons{display:flex;gap:10px;margin-left:8px}
.social-icons a{width:28px;height:28px;border-radius:50%;background:var(--gray-100);display:flex;align-items:center;justify-content:center;transition:var(--transition)}
.social-icons a:hover{background:var(--primary);color:#fff}
.social-icons a svg{width:14px;height:14px}

.header-main{padding:12px 0;position:relative}
.header-main .container{display:flex;align-items:center;justify-content:space-between;gap:20px}
.header-logo img{height:42px;width:auto;display:block}
.header-logo .logo-mobile{display:none}
.header-logo .logo-fallback{display:none;font-size:20px;font-weight:var(--fw-semibold);letter-spacing:-.5px;line-height:1}
.header-logo.is-fallback img{display:none !important}
.header-logo.is-fallback .logo-fallback{display:block}
.header-nav{display:flex;gap:2px;align-items:stretch;flex-wrap:wrap}
.header-nav > .nav-item{display:flex;align-items:stretch}
.header-nav > a,
.header-nav > .nav-item > .nav-item-btn{
  font-size:14px;font-weight:500;color:var(--gray-600);
  padding:8px 14px;border-radius:var(--radius-sm);
  transition:var(--transition);
  position:static;
  cursor:pointer;
  display:inline-flex;align-items:center;justify-content:flex-start;gap:4px;
  white-space:normal;line-height:1.2;
  flex:0 1 auto;max-width:160px;text-align:left;
  overflow-wrap:anywhere;hyphens:auto;
  background:transparent;
}
.header-nav > .nav-item > .nav-item-btn{border:0}
.header-nav > a:hover,
.header-nav > .nav-item:hover > .nav-item-btn,
.header-nav > .nav-item.is-open > .nav-item-btn{
  background:var(--gray-50);color:var(--primary)
}
.header-nav > .nav-item > .nav-item-btn svg{width:12px;height:12px;display:block;transform-origin:center;transition:transform .2s}
.header-nav > .nav-item:hover > .nav-item-btn svg,
.header-nav > .nav-item.is-open > .nav-item-btn svg{transform:rotate(180deg)}
.header-right{display:flex;align-items:center;gap:16px}
.header-phone{font-weight:var(--fw-semibold);font-size:15px;color:var(--black);white-space:nowrap}
.header-phone:hover{color:var(--primary)}
.header-callback{font-size:13px;font-weight:500;color:var(--gray-500);border-bottom:1px dashed var(--gray-400);padding-bottom:1px;cursor:pointer}
.header-callback:hover{color:var(--primary);border-color:var(--primary)}

/* Home page only: hero acts as header background */
body.home-hero-header{--home-header-offset:126px}
body.home-hero-header #heroSection{
  margin-top:calc(var(--home-header-offset) * -1);
  padding-top:0 !important;
}
body.home-hero-header .header,
body.home-hero-header .header *{transition:none !important}

/* State A: header is over hero (transparent) */
body.home-hero-header .header.header-over-hero{
  background:transparent !important;
  border-bottom-color:transparent !important;
  box-shadow:none !important;
}
body.home-hero-header .header.header-over-hero .header-top,
body.home-hero-header .header.header-over-hero .header-main{background:transparent !important}
body.home-hero-header .header.header-over-hero .header-top{border-bottom-color:rgba(255,255,255,.24) !important}
body.home-hero-header .header.header-over-hero .header-top,
body.home-hero-header .header.header-over-hero .header-top a,
body.home-hero-header .header.header-over-hero .header-top-left .city-select,
body.home-hero-header .header.header-over-hero .header-top-left .info-item,
body.home-hero-header .header.header-over-hero .header-nav > a,
body.home-hero-header .header.header-over-hero .header-nav > .nav-item > .nav-item-btn,
body.home-hero-header .header.header-over-hero .header-phone,
body.home-hero-header .header.header-over-hero .header-callback{color:#fff !important}
body.home-hero-header .header.header-over-hero .social-icons a{background:rgba(255,255,255,.14) !important;color:#fff !important}

/* State B: active/hover/focus/menu-open while over hero (classic white) */
body.home-hero-header .header.header-over-hero.header-hero-active{
  background:var(--surface) !important;
  border-bottom-color:var(--gray-200) !important;
}
body.home-hero-header .header.header-over-hero.header-hero-active .header-top,
body.home-hero-header .header.header-over-hero.header-hero-active .header-main{background:var(--surface) !important}
body.home-hero-header .header.header-over-hero.header-hero-active .header-top{border-bottom-color:var(--gray-100) !important}
body.home-hero-header .header.header-over-hero.header-hero-active .header-top,
body.home-hero-header .header.header-over-hero.header-hero-active .header-top a,
body.home-hero-header .header.header-over-hero.header-hero-active .header-top-left .city-select,
body.home-hero-header .header.header-over-hero.header-hero-active .header-top-left .info-item,
body.home-hero-header .header.header-over-hero.header-hero-active .header-nav > a,
body.home-hero-header .header.header-over-hero.header-hero-active .header-nav > .nav-item > .nav-item-btn,
body.home-hero-header .header.header-over-hero.header-hero-active .header-phone,
body.home-hero-header .header.header-over-hero.header-hero-active .header-callback{color:var(--gray-600) !important}
body.home-hero-header .header.header-over-hero.header-hero-active .social-icons a{background:var(--gray-100) !important;color:var(--gray-600) !important}

/* Mega Menu */
.mega-menu{position:absolute;top:100%;left:50%;right:auto;width:min(1750px,calc(100vw - 60px));background:var(--white);border-top:1px solid var(--gray-200);box-shadow:0 16px 48px rgba(0,0,0,.1);opacity:0;visibility:hidden;transform:translate(-50%,-8px);transition:opacity .2s ease,transform .2s ease,visibility 0s linear .2s;z-index:999}
.mega-menu{max-width:calc(100% - 24px)}
.nav-item:hover .mega-menu,
.nav-item.is-open .mega-menu{
  opacity:1;visibility:visible;transform:translate(-50%,0);transition:opacity .2s ease,transform .2s ease,visibility 0s; border-radius:0 0 20px 20px;
}
.mega-menu-inner{width:100%;max-width:1750px;margin:0 auto;padding:36px 24px;display:grid;grid-template-columns:minmax(220px,1fr) minmax(220px,1fr) minmax(220px,1fr) 300px;gap:36px}
.mega-col h4,
.mega-col .mega-title{font-size:14px;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--black);margin-bottom:16px}
.mega-tree-col h5,
.mega-tree-col .mega-subtitle{font-size:13px;font-weight:var(--fw-semibold);margin:0 0 8px;color:var(--black);letter-spacing:-.2px}
.mega-col a{display:block;font-size:14px;color:var(--gray-600);padding:6px 0;transition:color .2s}
.mega-col a:hover{color:var(--primary)}
/* Override generic `.mega-col a{...}` styles */
.mega-col a.mega-actions-all-btn{
  display:inline-flex;
  width:fit-content;
  max-width:100%;
  align-items:center;
  justify-content:center;
  gap:8px;
  margin-top:12px;
  padding:10px 14px;
  border-radius:12px;
  font-size:13px;
  font-weight:var(--fw-semibold);
  color:#fff !important;
  background:var(--primary);
  text-decoration:none;
  line-height:1;
  transition:transform .12s ease, box-shadow .12s ease, background-color .12s ease, filter .12s ease;
}
.mega-col a.mega-actions-all-btn:hover{
  color:#fff !important;
  background:var(--primary);
  filter:saturate(1.05) brightness(0.98);
  box-shadow:0 10px 24px rgba(0,0,0,.12);
  transform:translateY(-1px);
}
.mega-col a.mega-actions-all-btn:active{transform:translateY(0)}
.mega-promo{background:#dddddd;border-radius:var(--radius);padding:28px;display:flex;flex-direction:column;justify-content:flex-end}
.mega-promo h4,
.mega-promo .mega-title{font-size:18px;font-weight:var(--fw-semibold);color:var(--black);margin-bottom:8px;text-transform:none;letter-spacing:0}
.mega-promo p{font-size:13px;color:var(--gray-600);margin-bottom:16px;overflow-wrap:anywhere;hyphens:auto}
.mega-promo.has-image{position:relative;overflow:hidden}
.mega-promo.has-image::before{
  content:'';
  position:absolute;
  inset:0;
  background:
    linear-gradient(180deg, rgb(255 255 255 / 0%) 0%, rgb(255 255 255 / 0%) 55%, rgb(255 255 255 / 18%) 100%),
    url(sale.jpg);
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
  filter:saturate(1.05) contrast(1.02);
}
.mega-promo.has-image > *{position:relative;z-index:1}
.mega-promo-wrap{display:flex;flex-direction:row;gap:16px;height:100%}
.mega-promo-wrap .mega-promo{flex:1;min-width:0}

/* Mega menu: services tree */
.mega-menu-inner.is-services{grid-template-columns:320px 1fr 300px}
.mega-services-left{border-right:1px solid var(--gray-100);padding-right:16px;min-width:0}
.mega-services-left h4{font-size:13px;font-weight:var(--fw-semibold);color:var(--gray-500);margin-bottom:10px;text-transform:uppercase;letter-spacing:.5px}
.mega-services-list{display:flex;flex-direction:column;gap:6px;max-height:520px;overflow:auto;padding-right:8px}
.mega-services-cat{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 12px;border-radius:14px;font-weight:var(--fw-semibold);color:var(--black);cursor:pointer}
.mega-services-cat:hover{background:var(--gray-50);color:var(--primary)}
.mega-services-cat.is-active{background:var(--gray-50);color:var(--primary)}
.mega-services-panel{max-height:520px;overflow:auto;padding-right:8px;min-width:0}
.mega-services-tools{display:flex;gap:10px;align-items:center;margin-bottom:12px}
.mega-services-search{flex:1;display:flex;gap:10px;align-items:center;padding:12px 14px;border-radius:16px;border:1px solid var(--gray-200);background:var(--gray-50)}
.mega-services-search input{border:none;outline:none;background:transparent;width:100%;font-size:14px}
.mega-services-toggle{flex:0 0 auto;border:1px solid var(--gray-200);background:var(--white);border-radius:14px;padding:12px 12px;font-weight:var(--fw-semibold);cursor:pointer}
.mega-services-toggle:hover{background:var(--gray-50)}
.mega-services-quick{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}
.mega-services-quick section{border:1px solid var(--gray-100);border-radius:16px;padding:12px;background:var(--white)}
.mega-services-quick h5{font-size:13px;font-weight:var(--fw-semibold);margin:0 0 8px;color:var(--black);letter-spacing:-.2px}
.mega-services-quick a{display:block;padding:6px 0;color:var(--gray-600);font-weight:var(--fw-medium)}
.mega-services-quick a:hover{color:var(--primary)}
.mega-services-results{display:none;border:1px solid var(--gray-100);border-radius:16px;padding:12px;background:var(--white)}
.mega-services-results .res{display:flex;justify-content:space-between;gap:12px;padding:10px 10px;border-radius:14px}
.mega-services-results .res:hover{background:var(--gray-50)}
.mega-services-results .res strong{font-weight:var(--fw-semibold);color:var(--black)}
.mega-services-results .res span{font-size:12px;color:var(--gray-500);font-weight:var(--fw-medium)}
.mega-services-results .res strong mark{background:rgba(155,38,168,.12);color:inherit;padding:0 3px;border-radius:6px}
.mega-services-tree{display:none}
.mega-tree a.is-highlight,
.mega-services-quick a.is-highlight{background:rgba(155,38,168,.10);border-radius:10px;padding:6px 8px;margin-left:-8px;margin-right:-8px}
@media(max-width:1200px){
  .mega-services-quick{grid-template-columns:repeat(2,minmax(0,1fr))}
}
.services-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}
@media(max-width:1024px){.services-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:768px){.services-grid{grid-template-columns:1fr}}
.mega-tree{display:flex;flex-direction:column;gap:10px}
.mega-tree details{border:1px solid var(--gray-100);border-radius:16px;padding:10px 12px;background:var(--gray-50)}
.mega-tree details[open]{background:var(--white)}
.mega-tree summary{cursor:pointer;font-weight:var(--fw-semibold);list-style:none}
.mega-tree summary::-webkit-details-marker{display:none}
.mega-tree .mega-tree-children{margin-top:8px;display:flex;flex-direction:column;gap:6px;padding-left:10px}
.mega-tree a{color:var(--gray-600);font-weight:var(--fw-medium)}
.mega-tree a:hover{color:var(--primary)}

.mobile-toggle{display:none;background:none;flex-direction:column;gap:5px;padding:8px}
.mobile-toggle span{display:block;width:24px;height:2px;background:var(--black);border-radius:2px;transition:var(--transition)}

/* Mobile menu (GoldApple-like, full-screen, multi-level) */
.mm-overlay{position:fixed;inset:0;background:rgba(17,24,39,.46);backdrop-filter:blur(8px);opacity:0;visibility:hidden;transition:opacity .22s ease,visibility .22s ease;z-index:2000}
.mm-panel{position:fixed;top:0;right:0;height:100vh;max-height:100vh;height:100dvh;max-height:100dvh;width:min(520px,100vw);background:var(--white);transform:translateX(105%);transition:transform .28s cubic-bezier(.2,.8,.2,1);z-index:2001;display:flex;flex-direction:column;min-height:0;overflow:hidden;overscroll-behavior:contain;box-shadow:-24px 0 60px rgba(0,0,0,.18)}
body.mm-open{overflow:hidden}
body.mm-open .mm-overlay{opacity:1;visibility:visible}
body.mm-open .mm-panel{transform:translateX(0);width:100vw;max-width:100vw;left:0;right:0;box-shadow:none}
.mm-head{flex-shrink:0;position:sticky;top:0;z-index:3;background:rgba(255,255,255,.96);backdrop-filter:blur(14px);padding:14px 16px 12px;border-bottom:1px solid var(--gray-100);display:flex;flex-direction:column;gap:10px}
.mm-head-top{display:flex;align-items:center;justify-content:space-between;gap:12px}
.mm-brand{display:flex;align-items:center;gap:10px;font-weight:var(--fw-semibold);letter-spacing:-.3px;font-size:16px}
.mm-brand img{height:24px;width:auto;display:block}
.mm-close{width:44px;height:44px;border-radius:14px;background:var(--gray-100);display:flex;align-items:center;justify-content:center}
.mm-close svg{width:20px;height:20px}
.mm-close:hover{background:var(--gray-200)}
.mm-search{display:flex;gap:10px;align-items:center;padding:12px 14px;border-radius:16px;border:1px solid var(--gray-200);background:var(--gray-50)}
.mm-search input{border:none;outline:none;background:transparent;width:100%;font-size:15px}
.mm-body{flex:1 1 0;min-height:0;padding:14px 30px max(18px,env(safe-area-inset-bottom,0));overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;touch-action:pan-y;display:flex;flex-direction:column;gap:14px}
.mm-actions{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center}
.mm-actions .btn{width:100%}
.mm-icon-btn{width:44px;height:44px;border-radius:14px;background:var(--gray-100);display:flex;align-items:center;justify-content:center;border:1px solid var(--gray-200)}
.mm-icon-btn:hover{background:var(--gray-200)}
.mm-icon-btn svg{width:20px;height:20px}
.mm-screens{position:relative;overflow-x:hidden;min-width:0}
.mm-track{display:flex;width:400%;transition:transform .28s cubic-bezier(.2,.8,.2,1);will-change:transform}
.mm-screen{flex:0 0 25%;padding-right:8px}
.mm-title{font-weight:var(--fw-semibold);font-size:16px;letter-spacing:-.2px;margin:6px 0 10px}
.mm-back{display:flex;align-items:center;gap:10px;font-weight:var(--fw-semibold);padding:12px 12px;border-radius:14px;background:var(--gray-50);border:1px solid var(--gray-200);width:100%}
.mm-back:hover{background:var(--gray-100)}
.mm-list{display:flex;flex-direction:column}
.mm-item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 12px;border-radius:14px;font-weight:var(--fw-medium);color:var(--black)}
.mm-item:hover{background:var(--gray-50);color:var(--primary)}
.mm-sub{font-size:12px;color:var(--gray-500);font-weight:var(--fw-regular);margin-top:-8px;padding:0 12px 10px}
.mm-divider{height:1px;background:var(--gray-100);margin:10px 0}
.mm-promo{border-radius:18px;padding:16px;background:linear-gradient(135deg,var(--lavender),var(--blue));border:1px solid rgba(155,38,168,.12)}
.mm-promo h4{font-size:16px;font-weight:var(--fw-semibold);margin-bottom:6px}
.mm-promo p{font-size:13px;color:var(--gray-600);margin-bottom:12px}
@media(max-width:768px){
  .mm-panel{width:100vw;box-shadow:none}
}
@media (hover: none) and (pointer: coarse){
  .mm-panel{width:100vw;max-width:100vw;box-shadow:none;right:0;left:0}
}

/* ===== 3. HERO SLIDER ===== */
.hero{position:relative;overflow:hidden;background:#fff}
.hero-slides{position:relative;min-height:clamp(620px,84vh,920px)}
.hero-slide{
  position:absolute;inset:0;
  opacity:0;transition:opacity .8s ease;
  display:block;pointer-events:none;
  overflow:hidden;
  background:transparent;
}
.hero-slide::before{
  content:'';
  position:absolute;
  inset:0;
  background:
    linear-gradient(90deg, rgba(0,0,0,.14) 0%, rgba(0,0,0,.10) 34%, rgba(0,0,0,.04) 62%, rgba(0,0,0,.02) 100%),
    var(--slide-bg) center/cover no-repeat;
  transform: scale(1.02);
  filter: saturate(1.02) contrast(1.02);
}
.hero-slide::after{
  content:'';
  position:absolute;
  inset:0;
  background: radial-gradient(1200px 520px at 18% 55%, rgba(0,0,0,.06), rgba(0,0,0,0) 62%);
  pointer-events:none;
}
.hero-slide > .container{height:100%;position:relative;z-index:2}
.hero-slide.active{opacity:1;pointer-events:auto}
.hero-slide:nth-child(1){--slide-bg:linear-gradient(180deg,#3f4e67 0%, #6d84a6 58%, #b9cee4 100%)}
.hero-slide:nth-child(2){--slide-bg:linear-gradient(180deg,#9b6e5a 0%, #cfa07a 55%, #e7bb91 100%)}
.hero-slide:nth-child(3){--slide-bg:url("./1.jpg")}
.hero-slide:nth-child(4){--slide-bg:linear-gradient(180deg,#214a3a 0%, #2f7a63 60%, #8fe0c3 100%)}
.hero-slide-video{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  z-index:0;
  filter:saturate(1.02) contrast(1.02);
}
.hero-slide--video::before{
  background:
    linear-gradient(90deg, rgba(0,0,0,.22) 0%, rgba(0,0,0,.14) 34%, rgba(0,0,0,.08) 62%, rgba(0,0,0,.04) 100%),
    var(--slide-bg) center/cover no-repeat;
}
.hero-copy{
  position:absolute;
  right:56px;
  top:clamp(145px, 21vh, 220px);
  transform:none;
  width:520px;
  max-width:520px;
  color:#fff;
}
.hero-copy h1{
  margin:0 0 12px;
  font-size:clamp(34px,4.4vw,56px);
  font-weight:var(--fw-semibold);
  line-height:1.02;
  letter-spacing:-.02em;
  display:-webkit-box;
  -webkit-box-orient:vertical;
  -webkit-line-clamp:2;
  line-clamp:2;
  overflow:hidden;
  min-height:calc(2 * 1.02em);
}
.hero-copy p{
  margin:0 0 18px;
  font-size:15px;
  line-height:1.45;
  color:rgba(255,255,255,.88);
  display:-webkit-box;
  -webkit-box-orient:vertical;
  -webkit-line-clamp:2;
  line-clamp:2;
  overflow:hidden;
  min-height:calc(2 * 1.45em);
}
.hero-kicker{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:5px 11px;
  background:rgba(255,255,255,.14);
  border:1px solid rgba(255,255,255,.16);
  border-radius:999px;
  font-size:11px;
  font-weight:var(--fw-semibold);
  color:#fff;
  margin-bottom:14px;
  min-height:28px;
}
.hero-kicker.is-empty{opacity:0}
.hero-arrows{
  position:absolute;
  inset:0;
  z-index:1;
  display:flex;
  justify-content:space-between;
  pointer-events:none;
}
.hero-arrow{
  width:25%;
  height:100%;
  border:0;
  border-radius:0;
  background:transparent;
  box-shadow:none;
  backdrop-filter:none;
  display:block;
  pointer-events:auto;
  transition:none;
}
.hero-arrow.prev{
  cursor:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='44' height='44' viewBox='0 0 44 44'%3E%3Cpath d='M27 11L16 22l11 11' fill='none' stroke='%23ffffff' stroke-width='3.2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") 22 22,
  w-resize;
}
.hero-arrow.next{
  cursor:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='44' height='44' viewBox='0 0 44 44'%3E%3Cpath d='M17 11l11 11-11 11' fill='none' stroke='%23ffffff' stroke-width='3.2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") 22 22,
  e-resize;
}
.hero-arrow svg{display:none}
.hero-dots{position:absolute;bottom:20px;left:50%;transform:translateX(-50%);display:flex;gap:10px;z-index:3}
.hero-dot{width:5px;height:5px;border-radius:50%;background:rgba(255,255,255,.55);cursor:pointer;transition:var(--transition);border:0;padding:0}
.hero-dot.active{background:#fff}
/* .hero-side removed per request */
.btn-ga{
  display:inline-flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  min-width:300px;
  padding:13px 20px;
  border-radius:var(--pill);
  background:var(--primary);
  color:var(--black);
  border:1px solid rgba(var(--accent-rgb),.55);
  box-shadow:0 6px 24px rgba(var(--accent-rgb),.34);
  font-size:12px;
  font-weight:var(--fw-semibold);
  letter-spacing:.06em;
  text-transform:uppercase;
}
.btn-ga:hover{
  transform:translateY(-2px);
  background:#c9caef;
  border-color:#c9caef;
  color:var(--black);
  box-shadow:0 10px 30px rgba(var(--accent-rgb),.42);
}
.btn-ga:active{
  transform:translateY(0);
  box-shadow:0 4px 16px rgba(var(--accent-rgb),.28);
}
.btn-ga-ic{
  font-size:16px;
  line-height:1;
  opacity:.9;
}
.hero-pack{
  position:absolute;
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.14);
  box-shadow:0 24px 60px rgba(0,0,0,.14);
  border-radius:22px;
  backdrop-filter:blur(6px);
}
.hero-pack--left{width:160px;height:420px;left:-22px;top:80px;transform:rotate(-12deg)}
.hero-pack--center{width:190px;height:420px;left:120px;top:30px;transform:rotate(-22deg)}
.hero-pack--right{width:240px;height:120px;left:320px;top:210px;transform:rotate(20deg)}
/* hero-progress removed per request */
@media(max-width:768px){
  .hero-slides{min-height:clamp(420px,96vw,520px)}
  .hero-copy{
    left:0px;
    right:16px;
    top:56px;
    bottom:16px;
    transform:none;
    width:min(340px, calc(100% - 32px));
    max-width:min(340px, calc(100% - 32px));
    display:flex;
    flex-direction:column;
    align-items:flex-start;
  }
  .hero-kicker{display:none}
  .hero-copy h1{font-size:clamp(28px,8vw,40px)}
  .hero-copy p{font-size:13px;min-height:0}
  .hero-arrows{display:none}
  .hero-dots{top:18px;bottom:auto;left:18px;transform:none;gap:8px}
  .btn-ga{min-width:220px;margin-top:auto}
}

@media(min-width:769px){
  .btn-ga{min-width:300px}
}

@media(max-width:520px){
  .btn-ga{
    width:auto;
    min-width:220px;
    padding:12px 14px;
    font-size:12px;
    letter-spacing:.05em;
  }
  .hero-copy{
    top:54px;
    bottom:14px;
  }
}

@media(max-width:420px){
  .hero-slide-grid{gap:10px;padding:14px 0 138px}
  .hero-slide-media{min-height:clamp(220px,32vh,320px)}
  .hero-kicker{font-size:11px;padding:6px 12px;margin-bottom:12px}
  .hero-slide-content h1{font-size:clamp(22px,6.0vw,30px);margin-bottom:10px}
  .hero-slide-content p{font-size:13px;margin-bottom:14px}
  .hero-arrow{width:56px;height:44px}
}

/* ===== 4. ABOUT ===== */
.about{background:var(--white)}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.about-label{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;background:rgba(155,38,168,.06);border:1px solid rgba(155,38,168,.12);border-radius:var(--pill);font-size:12px;font-weight:600;color:var(--primary);margin-bottom:20px}
.about-text .section-subtitle{margin-bottom:32px}
.about-list{display:flex;flex-direction:column;gap:14px;margin-bottom:36px}
.about-list-item{display:flex;align-items:flex-start;gap:14px}
.about-list-icon{width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,var(--primary),var(--primary-dark));display:flex;align-items:center;justify-content:center;flex-shrink:0}
.about-list-icon svg{width:18px;height:18px;color:#fff}
.about-list-item p{font-size:15px;color:var(--gray-600);padding-top:6px;line-height:1.5}
.about-stats{display:flex;gap:32px;margin-bottom:36px;flex-wrap:wrap}
.about-stat{text-align:center}
.about-stat-value{font-size:28px;font-weight:var(--fw-semibold);color:var(--primary);line-height:1}
.about-stat-label{font-size:12px;color:var(--gray-400);margin-top:4px;font-weight:500}
.about-visual{
  position:relative;
  border-radius:var(--radius-xl);
  overflow:hidden;
  background: url('4.png') center/cover no-repeat;
  aspect-ratio:4/3;
  max-height:540px;
  display:flex;
  align-items:center;
  justify-content:center
}
.about-visual::before{
  content:'';
  position:absolute;
  inset:0;
  background: linear-gradient(180deg, rgba(0,0,0,.08), rgba(0,0,0,.22));
}
.about-visual-placeholder{display:none}
.about-visual-play{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;cursor:pointer}
.about-visual-play .play-btn{width:72px;height:72px;border-radius:50%;background:rgba(255,255,255,.9);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;box-shadow:0 8px 32px rgba(0,0,0,.15);transition:var(--transition)}
.about-visual-play .play-btn:hover{transform:scale(1.1);box-shadow:0 12px 40px rgba(0,0,0,.2)}
.about-visual-play .play-btn svg{width:28px;height:28px;color:var(--primary);margin-left:4px}

/* ===== 5. SERVICES (bento grid) ===== */
.services{background:var(--bg)}
.services-bento{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.service-card{background:var(--white);border-radius:var(--radius);border:1px solid var(--gray-200);padding:28px;position:relative;overflow:hidden;transition:var(--transition);cursor:pointer}
.service-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--primary),var(--primary-light));transform:scaleX(0);transition:transform .3s;transform-origin:left}
.service-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:transparent}
.service-card:hover::before{transform:scaleX(1)}
.service-card-lg{grid-column:span 2;grid-row:span 2;min-height:360px;display:flex;flex-direction:column;justify-content:flex-end;background:linear-gradient(135deg,var(--lavender),#e8d5f5);border-color:transparent}
.service-card-lg h3{font-size:24px}
.service-stack{grid-column:span 2;grid-row:span 2;display:grid;grid-template-rows:1fr 1fr;gap:16px}
.service-card-split{background:linear-gradient(135deg,var(--lavender),#e8d5f5);border-color:transparent;display:flex;flex-direction:column;justify-content:flex-end;min-height:172px}
.service-icon{width:56px;height:56px;border-radius:14px;background: rgb(248 238 247);display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.service-icon svg{width:30px;height:30px;color:var(--primary)}
.service-icon img{width:42px;height:42px;object-fit:contain;display:block}
.services-variant-a .service-card{padding-top:92px}
.services-variant-a .service-icon{
  position:absolute;
  top:28px;
  left:28px;
  margin:0;
}
.service-card h3{font-size:17px;font-weight:var(--fw-semibold);margin-bottom:8px;color:var(--black)}
.service-card p{font-size:13px;color:var(--gray-500);line-height:1.5;margin-bottom:12px}
.service-link{font-size:13px;font-weight:600;color:var(--primary);display:inline-flex;align-items:center;gap:6px}
.service-link:hover{gap:10px}
.service-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:auto}
.service-tags span{font-size:12px;background:rgba(255,255,255,.7);padding:4px 12px;border-radius:var(--pill);color:var(--gray-600);font-weight:500}

/* ===== 6. DOCTORS ===== */
@keyframes carouselWiggle{0%,100%{transform:translateY(0)}40%{transform:translateY(-1px)}70%{transform:translateY(1px)}}
.doctors{background:var(--white)}
.doctors-scroll-wrap{position:relative}
.doctors-scroll{display:flex;gap:20px;overflow-x:auto;padding:4px 0 20px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.doctors-scroll::-webkit-scrollbar{display:none}
.doctor-card{min-width:260px;max-width:260px;background:var(--white);border-radius:var(--radius);overflow:hidden;border:1.5px solid var(--gray-200);transition:var(--transition);scroll-snap-align:start;flex-shrink:0}
.doctor-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:rgba(155,38,168,.15)}
.doctor-photo{height:200px;background:linear-gradient(135deg,rgba(155,38,168,.08),rgba(199,230,245,.15));display:flex;align-items:center;justify-content:center}
.doctor-photo svg{width:48px;height:48px;color:var(--gray-300);opacity:.5}
.doctor-info{padding:20px}
.doctor-name{font-size:15px;font-weight:var(--fw-semibold);margin-bottom:4px;line-height:1.3}
.doctor-role{font-size:12px;color:var(--gray-500);margin-bottom:6px}
.doctor-clinic{font-size:12px;color:var(--primary);font-weight:600;margin-bottom:8px}
.doctor-stars{display:flex;gap:2px}
.doctor-stars svg{width:14px;height:14px;fill:#f59e0b}
.doctor-head{padding:14px;display:flex;gap:12px;align-items:flex-start}
.doctor-avatar{align-self:flex-start}
.doctor-avatar{width:80px;height:80px;border-radius:20px;background:rgba(var(--accent-rgb),.10);border:1px solid rgba(var(--accent-rgb),.22);overflow:hidden;flex:0 0 auto}
.doctor-avatar img{width:100%;height:100%;object-fit:cover;display:block}
.doctor-sub{margin-top:4px;color:var(--gray-600);font-size:12px;line-height:1.35}
.doctor-body{padding:0 14px 14px;display:flex;flex-direction:column;flex:1}
.doctor-tags{display:flex;gap:8px;flex-wrap:wrap;}
.doctor-tag{display:inline-flex;align-items:center;gap:6px;padding:5px 8px;border-radius:999px;border:1px solid rgba(var(--accent-rgb),.22);background:rgba(var(--accent-rgb),.10);color:var(--black);font-size:10px;font-weight:var(--fw-medium)}
.doctor-clinics{margin: 10px 0px;display:flex;gap:8px;flex-wrap:wrap}
.clinic-chip{display:inline-flex;align-items:center;gap:6px;padding:7px 10px;border-radius:14px;border:1px solid rgba(0,0,0,.08);background:rgba(255,255,255,.92);color:var(--black);font-size:12px;text-decoration:none}
.clinic-chip svg{width:14px;height:14px;opacity:.7}
.doctor-actions{margin-top:auto;padding-top:12px;border-top:1px solid var(--gray-100);display:grid;gap:10px}
.doctor-actions .btn{width:100%;justify-content:center;text-align:center}
.doctors-nav{display:flex;gap:10px;margin-top:20px}
.doctors-nav button{
  width:74px;height:46px;border-radius:18px;
  border:1px solid rgba(155,38,168,.55);
  background:rgba(255,255,255,.92);
  box-shadow:0 10px 22px rgba(0,0,0,.10);
  display:flex;align-items:center;justify-content:center;
  color:var(--black);
  transition:transform .15s ease, box-shadow .15s ease, background .15s ease, opacity .15s ease;
  position:relative;overflow:hidden;
}
.doctors-nav button:hover{
  transform:translateY(-1px);
  background:#fff;
  animation:carouselWiggle .55s ease-in-out;
  box-shadow:0 14px 30px rgba(0,0,0,.12);
}
.doctors-nav button:active{transform:translateY(0)}
.doctors-nav button:focus-visible{outline:3px solid rgba(199,230,245,.95);outline-offset:3px}
.doctors-nav button[disabled]{opacity:.55;cursor:not-allowed;box-shadow:none;animation:none !important}
.doctors-nav button svg{width:20px;height:20px}

/* Doctors catalog grid (doctors.html, before_after.html) */
.doctors-cards{
  margin-top:14px;
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:16px;
}
/* Max 5 cards per row on wide screens */
@media(min-width:1400px){.doctors-cards{grid-template-columns:repeat(5,1fr)}}
@media(max-width:1200px){.doctors-cards{grid-template-columns:repeat(3,1fr)}}
@media(max-width:980px){.doctors-cards{grid-template-columns:repeat(2,1fr)}}
@media(max-width:680px){.doctors-cards{grid-template-columns:1fr}}
.doctors-cards .doctor-card{
  border:1px solid var(--gray-200);
  background:var(--white);
  border-radius:var(--radius-lg);
  overflow:hidden;
  box-shadow:var(--shadow-sm);
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
  display:flex;
  flex-direction:column;
  min-height:340px;
  min-width:0;
  max-width:none;
  width:100%;
}
.doctors-cards .doctor-card:hover{transform:translateY(-2px);box-shadow:var(--shadow);border-color:rgba(var(--accent-rgb),.55)}

/* Make carousel doctor cards match doctors.html (same look, fixed width) */
.doctors-scroll .doctor-card{
  border:1px solid var(--gray-200);
  background:var(--white);
  border-radius:var(--radius-lg);
  overflow:hidden;
  box-shadow:var(--shadow-sm);
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
  display:flex;
  flex-direction:column;
  min-height:340px;
  width:320px;
  min-width:320px;
  max-width:320px;
  flex:0 0 320px;
}
.doctors-scroll .doctor-card:hover{transform:translateY(-2px);box-shadow:var(--shadow);border-color:rgba(var(--accent-rgb),.55)}
@media(max-width:1024px){
  .doctors-scroll .doctor-card{width:280px;min-width:280px;max-width:280px;flex-basis:280px}
}
@media(max-width:560px){
  .doctors-scroll .doctor-card{width:86vw;min-width:86vw;max-width:86vw;flex-basis:86vw}
}

#actionsTop .service-hero-body,
#doctorsTop .service-hero-body{display:flex;flex-direction:column}
#actionsTop .actions-hero-stats,
#doctorsTop .doctors-hero-stats{margin-top:auto;padding-top:14px}

/* Doctors mobile pagination (doctors.html) */
.doctors-pagination{
  margin-top:18px;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:14px;
  flex-wrap:wrap;
}
.doctors-pagination[hidden]{display:none !important}
.doctors-page-numbers{display:flex;gap:8px;flex-wrap:wrap;align-items:center;justify-content:center}
.doctors-page-num{
  border:1px solid var(--gray-200);
  background:var(--white);
  color:var(--black);
  padding:8px 10px;
  min-width:38px;
  border-radius:12px;
  font-size:13px;
  font-weight:var(--fw-medium);
  cursor:pointer;
  transition:var(--transition);
}
.doctors-page-num:hover{border-color:rgba(var(--accent-rgb),.7);box-shadow:var(--shadow-sm)}
.doctors-page-num.is-active{background:rgba(var(--accent-rgb),.18);border-color:rgba(var(--accent-rgb),.9)}
.doctors-page-dots{padding:0 4px;color:var(--gray-500);font-size:14px;line-height:1}
.doctors-pagination-status{
  font-size:13px;
  font-weight:var(--fw-medium);
  color:var(--gray-600);
  min-width:min(100%,12rem);
  text-align:center;
  line-height:1.4;
}
.doctors-page-btn{min-width:96px}

/* ===== 7. QUIZ ===== */
.quiz{background:linear-gradient(135deg,#f5eef8,#eef2fb)}
.quiz-box{max-width:680px;width:100%;justify-self:stretch;margin:0 auto;background:var(--white);border-radius:var(--radius-xl);padding:48px;box-shadow:var(--shadow-lg);position:relative;overflow:hidden}
.quiz-box::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--primary),var(--blue),var(--primary))}
.quiz-progress{display:flex;gap:8px;margin-bottom:32px}
.quiz-dot{flex:1;height:4px;border-radius:2px;background:var(--gray-200);transition:background .3s}
.quiz-dot.active,.quiz-dot.done{background:var(--primary)}
.quiz-question{font-size:24px;font-weight:var(--fw-semibold);margin-bottom:8px;text-align:center}
.quiz-hint{font-size:14px;color:var(--gray-500);margin-bottom:28px;text-align:center}
.quiz-options{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.quiz-option{padding:20px;border-radius:var(--radius);border:2px solid var(--gray-200);background:var(--gray-50);font-size:15px;font-weight:600;color:var(--black);text-align:center;transition:var(--transition);cursor:pointer}
.quiz-option:hover{border-color:var(--primary);background:rgba(155,38,168,.04)}
.quiz-option.selected{border-color:var(--primary);background:rgba(155,38,168,.08);color:var(--primary)}
.quiz-option svg{display:block;margin:0 auto 10px;width:100px;height:100px;color:var(--primary);overflow:visible;stroke-linecap:round;stroke-linejoin:round}
.quiz-option img{display:block;margin:0 auto 10px;width:100px;height:100px;object-fit:contain}
.quiz-steps{position:relative}
.quiz-step{display:none}
.quiz-step.active{display:block}
.quiz-step-title{font-size:13px;font-weight:var(--fw-medium);color:var(--gray-600);margin-bottom:14px;text-align:center}
@media(max-width:560px){
  .quiz-box{max-width:100%;width:100%;margin:0;padding:24px 18px}
  .quiz-progress{margin-bottom:20px}
  .quiz-question{font-size:18px}
  .quiz-hint{font-size:13px;margin-bottom:18px}
  .quiz-options{grid-template-columns:repeat(2,minmax(0,1fr))}
  .quiz-option{padding:16px;font-size:14px}
  .quiz-option svg{width:100px;height:100px;margin-bottom:8px;overflow:visible;stroke-linecap:round;stroke-linejoin:round}
  .quiz-option img{width:100px;height:100px;margin-bottom:8px}
}

@media(max-width:420px){
  .quiz-options{grid-template-columns:1fr}
}

/* Variant A v3 quiz layout additions */
.quiz-layout{display:grid;grid-template-columns:minmax(280px,.95fr) minmax(320px,1.25fr);gap:28px;align-items:start}
.quiz-copy{padding:6px 0}
.quiz-copy .section-label{margin-bottom:12px}
.quiz-copy .section-title{margin-bottom:14px}
.quiz-copy .section-subtitle{max-width:520px}
@media(max-width:560px){
  .quiz-layout{grid-template-columns:1fr;gap:16px}
  .quiz-copy{padding:0}
}

/* ===== 8. CLINICS ===== */
.clinics{background:var(--white)}
.clinic-filters{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:36px;justify-content:flex-start}
.filter-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 18px;border-radius:999px;border:1.5px solid var(--gray-200);background:var(--white);font-size:13px;font-weight:600;color:var(--gray-600);transition:var(--transition)}
.filter-btn:hover{border-color:var(--primary);color:var(--primary)}
.filter-btn.active{background:var(--primary);border-color:var(--primary);color:#fff;box-shadow:0 8px 20px rgba(155,38,168,.25)}
.filter-count{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:22px;padding:0 7px;border-radius:999px;background:rgba(155,38,168,.08);color:var(--primary);font-size:12px;font-weight:var(--fw-medium)}
.filter-btn.active .filter-count{background:rgba(255,255,255,.25);color:#fff}
.clinics-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}
.clinic-card{background:var(--white);border-radius:var(--radius-lg);border:1px solid var(--gray-200);padding:0;transition:var(--transition);display:flex;flex-direction:column;overflow:hidden;box-shadow:var(--shadow-sm)}
.clinic-card:hover{border-color:var(--primary);box-shadow:var(--shadow-lg);transform:translateY(-3px)}
.clinic-card-media{display:block;width:100%;height:260px;object-fit:cover;border-bottom:1px solid var(--gray-100)}
.clinic-card-body{padding:22px;display:flex;flex-direction:column;flex:1}
.clinics-carousel-wrap{position:relative}
.clinics-carousel{
  display:flex;
  gap:16px;
  overflow-x:auto;
  padding:4px 4px 18px;
  scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
}
.clinics-carousel::-webkit-scrollbar{display:none}
.clinics-carousel .clinic-card{
  flex:0 0 360px;
  min-width:360px;
  max-width:360px;
  scroll-snap-align:start;
}
.clinic-card-head{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:16px}
.clinic-number{width:32px;height:32px;border-radius:50%;background:rgba(var(--brand-rgb),.10);color:var(--brand);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:var(--fw-semibold);flex-shrink:0}
.clinic-district{font-size:11px;font-weight:var(--fw-medium);text-transform:uppercase;letter-spacing:.8px;color:var(--brand);background:rgba(var(--brand-rgb),.06);padding:6px 12px;border-radius:999px}
.clinic-address{font-size:18px;font-weight:var(--fw-semibold);margin-bottom:10px;line-height:1.25;color:var(--black)}
.clinic-metro{display:inline-flex;align-items:center;gap:8px;font-size:14px;color:var(--gray-600);margin-bottom:16px}
.metro-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.clinic-info{display:flex;flex-direction:column;gap:8px;margin-bottom:18px;flex:1}
.clinic-info-row{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--gray-600)}
.clinic-info-row svg{flex-shrink:0;color:var(--primary);opacity:.9}
.clinic-actions{display:flex;gap:10px;align-items:center;margin-top:auto}
.clinic-actions .btn{flex:1}
.clinic-link{font-size:13px;font-weight:var(--fw-medium);color:var(--primary);display:inline-flex;align-items:center;gap:6px;white-space:nowrap}
.clinic-link:hover{color:var(--primary-dark)}
.no-results{grid-column:1/-1;text-align:center;padding:60px 20px;color:var(--gray-500);border:1px dashed var(--gray-300);border-radius:var(--radius)}

/* ===== ACTIONS cards ===== */
.actions-cards{
  margin-top:14px;
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:16px;
}
@media(max-width:980px){.actions-cards{grid-template-columns:1fr}}
.actions-card{
  border:1px solid var(--gray-200);
  background:var(--white);
  border-radius:var(--radius-lg);
  overflow:hidden;
  box-shadow:var(--shadow-sm);
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.actions-card:hover{transform:translateY(-2px);box-shadow:var(--shadow);border-color:rgba(var(--accent-rgb),.55)}
.actions-card-link{display:flex;flex-direction:column;height:100%;color:inherit;text-decoration:none}
.actions-cover{height:240px;background-size:cover;background-position:center;position:relative}
.actions-cover::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg, rgba(255,255,255,0) 20%, rgba(0,0,0,.30) 100%);pointer-events:none}
.actions-label{position:absolute;right:12px;top:12px;padding:6px 10px;border-radius:999px;background:rgba(255,255,255,.92);border:1px solid rgba(0,0,0,.08);font-size:12px;font-weight:var(--fw-semibold)}
.actions-body{padding:14px 14px 16px;display:flex;flex-direction:column;min-height:0;flex:1}
.actions-badge{display:inline-flex;align-items:center;gap:6px;padding:7px 10px;border-radius:999px;border:1px solid rgba(var(--accent-rgb),.22);background:rgba(var(--accent-rgb),.10);color:var(--black);font-size:12px;font-weight:var(--fw-medium)}
.actions-body b{display:block;margin-top:10px;font-size:15px;letter-spacing:-.2px;line-height:1.35}
.actions-body p{margin-top:8px;color:var(--gray-600);font-size:13px;line-height:1.65;margin-bottom:12px}
.actions-kv{margin-top:auto;padding-top:12px;border-top:1px solid var(--gray-100);display:grid;grid-template-columns:1fr 1fr;gap:10px}
.actions-kv-item{display:flex;gap:10px;align-items:flex-start;padding:10px 10px;border-radius:16px;border:1px solid rgba(var(--accent-rgb),.18);background:rgba(var(--accent-rgb),.08)}
.actions-kv-icon{width:30px;height:30px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.85);border:1px solid rgba(0,0,0,.06);flex:0 0 auto}
.actions-kv-icon svg{width:16px;height:16px;opacity:.75}
.actions-kv-text{min-width:0}
.actions-kv-k{color:var(--gray-600);font-size:12px;line-height:1.2}
.actions-kv-v{margin-top:4px;font-weight:var(--fw-semibold);color:var(--black);font-size:13px;line-height:1.25}
@media(max-width:420px){.actions-kv{grid-template-columns:1fr}}

/* Actions carousel (service.html) */
.actions-carousel-wrap{position:relative}
.actions-carousel-track{
  display:flex;
  gap:16px;
  overflow-x:auto;
  padding:4px 0 20px;
  scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
}
.actions-carousel-track::-webkit-scrollbar{display:none}
.actions-carousel-track > .actions-card{
  flex:0 0 420px;
  min-width:420px;
  max-width:420px;
  scroll-snap-align:start;
}
@media(max-width:1024px){
  .actions-carousel-track > .actions-card{flex-basis:360px;min-width:360px;max-width:360px}
}
@media(max-width:560px){
  .actions-carousel-track > .actions-card{flex-basis:86vw;min-width:86vw;max-width:86vw}
}

/* ===== 9. BEAUTY CALENDAR / OFFERS ===== */
.seasonal{background:linear-gradient(135deg,var(--lavender),var(--blue));padding:80px 0}
.seasonal .container{text-align:center}
.seasonal-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:28px}
.seasonal-card{border-radius:var(--radius);background:var(--white);padding:32px 24px;text-align:center;border:1px solid rgba(155,38,168,.10);transition:var(--transition)}
.seasonal-card:hover{border-color:var(--primary);transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.seasonal-icon{width:56px;height:56px;border-radius:50%;background:rgba(155,38,168,.10);margin:0 auto 16px;display:flex;align-items:center;justify-content:center;font-size:22px;line-height:1;font-family:"Apple Color Emoji","Segoe UI Emoji","Noto Color Emoji",system-ui,sans-serif;user-select:none}
.seasonal-title{font-size:17px;font-weight:var(--fw-semibold);margin-bottom:8px;color:var(--black)}
.seasonal-desc{font-size:13px;color:var(--gray-600);font-weight:500;line-height:1.6}

/* Deals (merge Seasonal + Offers) */
.deals{padding:80px 0;background:linear-gradient(135deg,rgba(155,38,168,.06),rgba(199,230,245,.22))}
.deals .container{text-align:left}
.deals-layout{margin-top:26px;display:grid;grid-template-columns:1fr;gap:18px;align-items:start}
.deals-panel{border:1px solid var(--gray-200);background:rgba(255,255,255,.86);backdrop-filter:blur(10px);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:18px}
.deals-panel h3{margin:0;font-size:15px;font-weight:var(--fw-semibold);letter-spacing:-.2px}
.deals-panel p{margin:6px 0 0;color:var(--gray-600);font-size:13px;line-height:1.65}
.deals-head{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;margin-bottom:14px}
.deals-link{font-size:13px;font-weight:var(--fw-semibold);color:var(--primary);white-space:nowrap}
.deals-link:hover{text-decoration:underline}

/* Seasonal cards inside deals */
.deals .seasonal-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-top:0}
.deals .seasonal-card{padding:16px;text-align:left;border-radius:18px}
.deals .seasonal-card:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.deals .seasonal-icon{margin:0 0 10px;width:44px;height:44px;border-radius:14px}
.deals .seasonal-title{font-size:14px;margin-bottom:6px}
.deals .seasonal-desc{font-size:12.5px}
.deals-cta{margin-top:12px;display:flex;gap:10px;flex-wrap:wrap;justify-content:center}
.deals-cta .btn{flex:0 1 auto;min-width:180px;max-width:220px}

/* Offers grid inside deals */
.deals .offers-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}
.deals .offers-card--media{background:rgba(255,255,255,.92);flex-direction:row}
.deals .offers-media{flex:0 0 200px;min-height:150px}
.deals .offers-body{padding:14px}
.deals .offers-body h3{font-size:14px}
.deals .offers-body p{font-size:12.5px}
.deals .offers-actions.is-stack{margin-top:auto}

@media(max-width:980px){
  .deals .seasonal-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
  .deals .offers-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media(max-width:680px){
  .deals .seasonal-grid{grid-template-columns:1fr}
  .deals .offers-grid{grid-template-columns:1fr}
  .deals .offers-card--media{flex-direction:column}
  .deals .offers-media{flex:0 0 auto;min-height:180px}
}

.offers{background:var(--white)}
.offers-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.offers-card{border:1px solid var(--gray-200);background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:18px;display:flex;flex-direction:column;min-height:260px}
.offers-card:hover{border-color:rgba(155,38,168,.25);box-shadow:var(--shadow);transform:translateY(-2px)}
.offers-icon{width:56px;height:56px;border-radius:18px;background:linear-gradient(135deg,rgba(155,38,168,.12),rgba(199,230,245,.35));display:flex;align-items:center;justify-content:center;font-size:22px;line-height:1;font-family:"Apple Color Emoji","Segoe UI Emoji","Noto Color Emoji",system-ui,sans-serif;margin-bottom:12px;user-select:none}
.offers-card h3{margin:0;font-size:16px;font-weight:var(--fw-semibold);letter-spacing:-.2px;line-height:1.25}
.offers-card p{margin-top:8px;color:var(--gray-600);font-size:13px;line-height:1.65}
.offers-actions{margin-top:auto;display:flex;gap:10px;flex-wrap:wrap}
.offers-actions .btn{flex:1 1 160px}

/* Offers: media cards (variant-a-v3 выгодные предложения) */
.offers-card--media{padding:0;flex-direction:row;min-height:0;overflow:hidden;align-items:stretch}
.offers-card--media .offers-icon{display:none}
.offers-media{flex:0 0 160px;min-height:140px;background:#f1f1f1 center/cover no-repeat}
.offers-body{flex:1;display:flex;flex-direction:column;padding:18px;min-width:0}
.offers-body h3{font-size:15px}
.offers-body p{margin: 10px 0;}
.offers-actions.is-stack{flex-direction:column;flex-wrap:nowrap}
.offers-actions.is-stack .btn{flex:0 0 auto;width:100%}
@media(max-width:680px){
  .offers-card--media{flex-direction:column}
  .offers-media{flex:0 0 auto;min-height:170px}
}
@media(max-width:1100px){.offers-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:680px){.offers-grid{grid-template-columns:1fr}.offers-actions .btn{flex:1 1 100%}}

.beauty-program{background:var(--white)}
.beauty-program .program-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:22px}
.beauty-program .program-card{background:var(--gray-50);border:1px solid var(--gray-200);border-radius:var(--radius);padding:22px;transition:var(--transition);display:flex;flex-direction:column;min-height:240px}
.beauty-program .program-card:hover{border-color:rgba(155,38,168,.35);box-shadow:var(--shadow);transform:translateY(-3px)}
.beauty-program .program-icon{width:52px;height:52px;border-radius:16px;background:linear-gradient(135deg,rgba(155,38,168,.12),rgba(199,230,245,.35));display:flex;align-items:center;justify-content:center;font-size:22px;line-height:1;font-family:"Apple Color Emoji","Segoe UI Emoji","Noto Color Emoji",system-ui,sans-serif;margin-bottom:14px;user-select:none}
.beauty-program .program-icon svg{width:22px;height:22px;stroke:var(--primary);fill:none;stroke-width:2}
.beauty-program .program-title{font-size:16px;font-weight:var(--fw-semibold);line-height:1.25;margin-bottom:8px}
.beauty-program .program-desc{font-size:13px;color:var(--gray-600);line-height:1.6;margin-bottom:12px}
.beauty-program .program-proc{margin-top:auto;font-size:12px;font-weight:var(--fw-medium);color:var(--primary);opacity:.95;line-height:1.45}
.beauty-program .program-price{margin-top:10px;font-size:18px;font-weight:var(--fw-semibold);letter-spacing:-.2px}
.beauty-program .program-price small{font-size:12px;font-weight:var(--fw-medium);color:var(--gray-500);margin-right:4px}
@media(max-width:1024px){
  .beauty-program .program-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:560px){
  .beauty-program .program-grid{grid-template-columns:1fr}
}

/* ===== 10. BEFORE/AFTER (base cards) ===== */
.before-after{background:var(--bg)}
.ba-intro{max-width:560px;margin-bottom:48px}
/* Unified card sizing across pages.
   - In grid contexts, cards keep a consistent minimum width and wrap.
   - In carousel contexts, cards use the same width token. */
:root{--ba-card-w:460px}
.ba-grid{
  display:grid;
  gap:20px;
  margin-bottom:32px;
  grid-template-columns:repeat(auto-fit,minmax(min(100%,var(--ba-card-w)),1fr));
}
.ba-card{background:var(--white);border-radius:var(--radius);overflow:hidden;border:1.5px solid var(--gray-200);transition:var(--transition)}
.ba-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.ba-compare{
  position:relative;
  height:260px;
  overflow:hidden;
  --pos:50%;
  --ba-before: url('dot_do.jpg');
  --ba-after: url('dot_posle.jpg');
}
.ba-layer{position:absolute;inset:0}
.ba-layer.ba-before{background: var(--ba-before) center/cover no-repeat}
.ba-layer.ba-after{background: var(--ba-after) center/cover no-repeat;clip-path:inset(0 0 0 var(--pos))}
/* Совместимость: в ранних билдах карточки Д/П использовали .ba-img — без этих правил фон не рисовался */
.ba-img{position:absolute;inset:0}
.ba-img.ba-before{background: var(--ba-before) center/cover no-repeat}
.ba-img.ba-after{background: var(--ba-after) center/cover no-repeat;clip-path:inset(0 0 0 var(--pos))}
.ba-handle{position:absolute;top:0;bottom:0;left:var(--pos);width:2px;background:rgba(255,255,255,.95);z-index:3;transform:translateX(-1px);cursor:ew-resize;display:flex;align-items:center;justify-content:center;touch-action:none}
.ba-handle::before{content:'';position:absolute;inset:0;box-shadow:0 0 0 9999px rgba(0,0,0,.02)}
.ba-slider-circle{width: 30px;
  height: 40px;
  border-radius: 10px;background:rgba(255,255,255,.95);backdrop-filter:blur(8px);box-shadow:var(--shadow);display:flex;align-items:center;justify-content:center}
.ba-slider-circle svg{width:16px;height:16px;color:var(--gray-700)}
.ba-hint{position:absolute;top:10px;left:10px;right:10px;z-index:2;display:flex;justify-content:space-between;pointer-events:none}
.ba-hint span{font-size:11px;font-weight:var(--fw-medium);letter-spacing:.05em;text-transform:uppercase;padding:4px 10px;border-radius:999px;color:#fff}
.ba-hint .before{background:rgba(134,142,150,.9)}
.ba-hint .after{background:rgba(155,38,168,.9)}
.ba-tag{position:absolute;bottom:8px;font-size:11px;font-weight:var(--fw-medium);text-transform:uppercase;letter-spacing:.05em;padding:4px 10px;border-radius:4px;color:#fff;z-index:3}
.ba-tag.before{left:8px;background:var(--gray-400)}
.ba-tag.after{right:8px;background:var(--primary)}
.ba-card-body{padding:16px 20px}
.ba-card-body h4,
.ba-card-body .ba-title{font-size:15px;font-weight:600;margin-bottom:4px}
.ba-card-body p{font-size:13px;color:var(--gray-500)}

/* BEFORE/AFTER page layout (before_after.html) */
.ba-page{display:grid;grid-template-columns:340px 1fr;gap:22px;align-items:start;margin-top:18px}
.ba-sidebar{position:sticky;top:calc(74px + var(--vv-top, 0px));z-index:800}
.ba-sidebar-card{
  border:1px solid var(--gray-200);
  background:var(--white);
  border-radius:var(--radius-xl);
  box-shadow:var(--shadow-sm);
  padding:14px;
}
.ba-sidebar-title{font-size:13px;font-weight:var(--fw-semibold);letter-spacing:.3px;color:var(--gray-600);text-transform:uppercase}
.ba-search{margin-top:10px;display:flex;gap:10px;align-items:center;padding:12px 14px;border-radius:16px;border:1px solid var(--gray-200);background:rgba(255,255,255,.92)}
.ba-search svg{width:18px;height:18px;opacity:.6;flex:0 0 auto}
.ba-search input{border:none;outline:none;background:transparent;width:100%;font-size:14px}
.ba-list{
  margin-top:12px;
  display:flex;
  flex-direction:column;
  gap:6px;
  max-height:min(560px,calc(100vh - 220px));
  overflow:auto;
  padding-right:6px;
  scrollbar-width:thin;
  scrollbar-gutter:stable;
  scrollbar-color:rgba(110,24,162,.28) transparent;
  -webkit-overflow-scrolling:touch;
  /* subtle edge fades to “frame” the scroll */
  -webkit-mask-image:linear-gradient(to bottom, transparent 0, #000 14px, #000 calc(100% - 14px), transparent 100%);
  mask-image:linear-gradient(to bottom, transparent 0, #000 0px, #000 calc(100% - 14px), transparent 100%);
}
.ba-list::-webkit-scrollbar{width:8px}
.ba-list::-webkit-scrollbar-track{background:transparent}
.ba-list::-webkit-scrollbar-thumb{
  background:rgba(110,24,162,.22);
  border-radius:999px;
  border:2px solid transparent;
  background-clip:content-box;
}
.ba-list:hover::-webkit-scrollbar-thumb{background:rgba(110,24,162,.30)}
.ba-item,
.ba-list-item{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  width:100%;
  padding:10px 12px;
  border-radius:14px;
  border:1px solid transparent;
  background:transparent;
  color:var(--gray-700);
  font-weight:var(--fw-semibold);
  font-size:13px;
  cursor:pointer;
  transition:var(--transition);
  text-align:left;
  appearance:none;
  -webkit-appearance:none;
  outline:none;
}
.ba-item:hover,
.ba-list-item:hover{background:rgba(var(--accent-rgb),.14);border-color:rgba(var(--accent-rgb),.22)}
.ba-item.active,
.ba-list-item.is-active{
  /* background: rgba(var(--accent-rgb), .24); */
  border-color:#ededed;
  color:var(--black);
}
.ba-item small,
.ba-list-item small{font-weight:var(--fw-medium);color:var(--gray-500)}
.ba-list-item small{white-space:nowrap}
.ba-list-item:focus-visible{
  outline:3px solid rgba(199,230,245,.95);
  outline-offset:3px;
}
.ba-reset{
  margin-top:12px;
  width:100%;
  height:46px;
  border-radius:16px;
  background:rgba(255,255,255,.96);
  box-shadow:var(--shadow-sm);
  border-color:rgba(var(--accent-rgb),.35);
}
.ba-reset:hover{
  background:#fff;
  border-color:rgba(var(--accent-rgb),.55);
  box-shadow:0 14px 30px rgba(0,0,0,.10);
  transform:translateY(-1px);
}
.ba-reset:active{transform:translateY(0)}

.ba-main{min-width:0}
.ba-main-head{display:flex;align-items:flex-end;justify-content:space-between;gap:14px;flex-wrap:wrap}
.ba-main-head .meta{color:var(--gray-500);font-size:13px}
.ba-main-sub{margin-top:10px;color:var(--gray-600);font-size:13px;line-height:1.7;max-width:860px}

.ba-carousel-wrap{margin-top:18px;position:relative}
.ba-carousel{display:flex;gap:16px;overflow-x:auto;padding:4px 4px 18px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.ba-carousel::-webkit-scrollbar{display:none}
.ba-carousel .ba-card{
  flex:0 0 var(--ba-card-w);
  width:var(--ba-card-w);
  max-width:var(--ba-card-w);
  scroll-snap-align:start;
}
.ba-carousel-nav{display:flex;gap:10px;margin-top:10px}
.ba-carousel-nav button{
  width:74px;height:46px;border-radius:18px;
  border:1px solid #bfc0ed;
  background:rgba(255,255,255,.92);
  box-shadow:0 10px 22px rgba(0,0,0,.10);
  display:flex;align-items:center;justify-content:center;
  color:var(--black);
  transition:transform .15s ease, box-shadow .15s ease, background .15s ease, opacity .15s ease;
  position:relative;overflow:hidden;
}
.ba-carousel-nav button:hover{
  transform:translateY(-1px);
  background:#fff;
  animation:carouselWiggle .55s ease-in-out;
  box-shadow:0 14px 30px rgba(0,0,0,.12);
}
.ba-carousel-nav button:active{transform:translateY(0)}
.ba-carousel-nav button:focus-visible{outline:3px solid rgba(199,230,245,.95);outline-offset:3px}
.ba-carousel-nav button[disabled]{opacity:.55;cursor:not-allowed;box-shadow:none;animation:none !important}
.ba-carousel-nav svg{width:20px;height:20px}

/* Actions carousel controls row (promos only) */
.actions-carousel-controls{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:10px}
.actions-carousel-controls .ba-carousel-nav{margin-top:0}
.actions-carousel-controls .actions-carousel-all{
  height:44px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  padding:0 16px;
  font-weight:var(--fw-semibold);
}
@media(max-width:560px){
  .actions-carousel-controls{flex-wrap:wrap}
}
@media(max-width:1024px){
  .ba-page{grid-template-columns:320px 1fr}
  :root{--ba-card-w:320px}
}
@media(max-width:820px){
  .ba-page{grid-template-columns:1fr}
  .ba-sidebar{position:static}
  .ba-list{max-height:none}
  .ba-sidebar-card{padding:12px}
  .ba-select{display:block}
}

/* Info blocks (before_after.html) */
.card{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm)}
.steps-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:18px}
.step{padding:18px}
.step-top{display:flex;align-items:center;justify-content:space-between;gap:12px}
.step-num{width:42px;height:42px;border-radius:14px;background:rgba(var(--accent-rgb),.26);border:1px solid rgba(var(--accent-rgb),.42);display:flex;align-items:center;justify-content:center;font-weight:var(--fw-semibold)}
.step h3{margin-top:10px;font-size:16px;line-height:1.25;letter-spacing:-.2px}
.step p{margin-top:8px;color:var(--gray-600);font-size:13px;line-height:1.7}

.chip{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;background:var(--gray-50);border:1px solid var(--gray-200);font-size:12px;color:var(--gray-700);font-weight:var(--fw-medium)}

.faq{margin-top:18px}
.faq details{border:1px solid var(--gray-200);background:var(--white);border-radius:18px;padding:14px 14px;margin-top:10px}
.faq details[open]{box-shadow:var(--shadow-sm)}
.faq summary{cursor:pointer;font-weight:var(--fw-semibold);list-style:none;display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.faq summary::-webkit-details-marker{display:none}
.faq summary span{flex:1;min-width:0}
.faq summary i{
  font-style:normal;
  opacity:.8;
  width:18px;
  min-width:18px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-weight:var(--fw-semibold);
}
.faq .a{margin-top:10px;color:var(--gray-600);font-size:13px;line-height:1.75}

.reviews-mini{margin-top:18px;display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.review{padding:18px}
.review .stars{color:#f59e0b;letter-spacing:1px;font-size:14px}
.review p{margin-top:10px;color:var(--gray-600);font-size:13px;line-height:1.7}
.review b{display:block;margin-top:10px;font-weight:var(--fw-semibold)}
.review small{display:block;margin-top:2px;color:var(--gray-500);font-size:12px}

.safety-grid{margin-top:18px;display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.safety{padding:18px}
.safety h3{margin-top:10px;font-size:16px;line-height:1.25;letter-spacing:-.2px}
.safety p{margin-top:8px;color:var(--gray-600);font-size:13px;line-height:1.7}
.safety-ic{width:44px;height:44px;border-radius:14px;background:rgba(var(--accent-rgb),.26);border:1px solid rgba(var(--accent-rgb),.42);display:flex;align-items:center;justify-content:center}
.safety-ic svg{width:20px;height:20px;opacity:.85}

.disclaimer{margin-top:18px;padding:14px 16px;border-radius:18px;background:rgba(255,255,255,.86);border:1px solid var(--gray-200);color:var(--gray-600);font-size:12.5px;line-height:1.7}
.disclaimer b{color:var(--black);font-weight:var(--fw-semibold)}

/* Offers carousel (before_after.html) */
.offers-carousel-wrap{position:relative;margin-top:18px}
.offers-carousel{display:flex;gap:16px;overflow-x:auto;padding:4px 4px 18px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.offers-carousel::-webkit-scrollbar{display:none}
.offers-carousel > .offers-card{
  flex:0 0 420px;
  min-width:420px;
  max-width:420px;
  scroll-snap-align:start;
}
.offers-cover{height:240px;border-radius:16px;background:linear-gradient(135deg,rgba(155,38,168,.08),rgba(199,230,245,.15)) center/cover no-repeat;position:relative;overflow:hidden;border:1px solid var(--gray-100)}
.offers-label{position:absolute;left:12px;top:12px;background:rgba(255,255,255,.92);border:1px solid rgba(0,0,0,.08);padding:6px 10px;border-radius:999px;font-size:12px;font-weight:var(--fw-semibold)}
.offers-badge{display:inline-flex;align-items:center;gap:6px;margin-top:12px;font-size:12px;font-weight:var(--fw-semibold);color:var(--black);background:rgba(var(--accent-rgb),.20);border:1px solid rgba(var(--accent-rgb),.38);padding:6px 10px;border-radius:999px;max-width:100%}
.offers-kv{margin-top:12px;display:grid;grid-template-columns:1fr 1fr;gap:10px}
.offers-kv-item{display:flex;gap:10px;align-items:flex-start;padding:10px 12px;border-radius:16px;background:var(--gray-50);border:1px solid var(--gray-200)}
.offers-kv-ic{width:34px;height:34px;border-radius:12px;background:rgba(var(--accent-rgb),.20);border:1px solid rgba(var(--accent-rgb),.36);display:flex;align-items:center;justify-content:center;flex:0 0 auto}
.offers-kv-ic svg{width:16px;height:16px;opacity:.8}
.offers-kv-k{font-size:11px;color:var(--gray-500);font-weight:var(--fw-medium);text-transform:uppercase;letter-spacing:.06em}
.offers-kv-v{margin-top:2px;font-size:12px;font-weight:var(--fw-semibold);color:var(--black)}
@media(max-width:1024px){
  .offers-carousel > .offers-card{flex-basis:360px;min-width:360px;max-width:360px}
}
@media(max-width:560px){
  .offers-carousel > .offers-card{flex-basis:86vw;min-width:86vw;max-width:86vw}
  .offers-cover{height:200px}
}

@media(max-width:1024px){
  .steps-grid{grid-template-columns:1fr}
  .reviews-mini{grid-template-columns:1fr}
  .safety-grid{grid-template-columns:1fr}
}

/* Footer maps (service.html bottom map section) */
.footer__info-maps{background:var(--white);border-top:1px solid var(--gray-200);padding:72px 0}
.footer__maps-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:18px}
.footer__maps-title{margin:0;font-size:clamp(22px,3vw,30px);font-weight:var(--fw-semibold);letter-spacing:-.2px}
.footer__maps-sub{color:var(--gray-500);font-size:14px;max-width:560px;line-height:1.65;margin-top:8px}
.footer__maps-layout{display:grid;grid-template-columns:420px 1fr;gap:18px;align-items:stretch}
.footer__maps-panel{border:1px solid var(--gray-200);background:var(--gray-50);border-radius:var(--radius-lg);padding:14px;min-height:520px;display:flex;flex-direction:column}
.footer__maps-toolbar{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-bottom:12px}
.footer__maps-search{flex:1;min-width:220px;display:flex;gap:10px;align-items:center;padding:12px 14px;border-radius:16px;border:1px solid var(--gray-200);background:var(--white)}
.footer__maps-search input{border:none;outline:none;background:transparent;width:100%;font-size:14px}
.footer__maps-count{font-size:12px;color:var(--gray-500);font-weight:var(--fw-medium)}
.footer__maps-list{overflow:auto;min-height:0;display:flex;flex-direction:column;gap:10px;padding-right:6px}
.footer__maps-item{border:1px solid var(--gray-200);background:var(--white);border-radius:16px;padding:12px 12px;cursor:pointer;transition:var(--transition)}
.footer__maps-item:hover{border-color:rgba(var(--accent-rgb),.55);box-shadow:0 10px 28px rgba(0,0,0,.06);transform:translateY(-1px)}
.footer__maps-item.is-active{border-color:rgba(var(--accent-rgb),.75);background:rgba(var(--accent-rgb),.10)}
.footer__maps-item-top{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}
.footer__maps-item-title{font-weight:var(--fw-semibold);line-height:1.25}
.footer__maps-item-meta{margin-top:6px;color:var(--gray-500);font-size:13px;line-height:1.45}
.footer__maps-chip{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:var(--fw-medium);text-transform:uppercase;letter-spacing:.06em;padding:4px 10px;border-radius:999px;background:var(--chip-bg, rgba(var(--accent-rgb),.16));color:var(--chip-fg, var(--black))}
.footer__maps-chip--metro{
  text-transform:none;
  letter-spacing:0;
  font-size:10px;
  border:1px solid rgba(0,0,0,.08);
  background:var(--chip-bg, #0078C9);
  color:var(--chip-fg, #fff);
}
.footer__maps-item-meta{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.footer__maps-sep{opacity:.55}
.footer__maps-actions{margin-top:10px;display:flex;gap:10px;flex-wrap:wrap}
.footer__maps-actions a{font-size:13px;font-weight:var(--fw-semibold)}
.footer__maps-map{border:1px solid var(--gray-200);background:var(--gray-50);border-radius:var(--radius-lg);overflow:hidden;min-height:520px;position:relative}
.footer__maps-map iframe{border:0;width:100%;height:100%;min-height:520px;display:block;-webkit-filter:grayscale(1) saturate(0) contrast(1.05);filter:grayscale(1) saturate(0) contrast(1.05)}
.footer__maps-map-fallback{position:absolute;inset:0;display:none;align-items:center;justify-content:center;text-align:center;padding:24px;color:var(--gray-600)}
.footer__maps-map-fallback a{color:var(--primary);text-decoration:underline}
@media(max-width:1024px){
  .footer__maps-layout{grid-template-columns:1fr}
  .footer__maps-panel,.footer__maps-map{min-height:460px}
  .footer__maps-map iframe{min-height:460px}
}

/* Clinics section uses the same layout, but more compact (matches laserdoctor.ru) */
.clinics .footer__maps-layout{max-width:100%}
.clinics .footer__maps-panel,
.clinics .footer__maps-map{min-height:360px}
.clinics .footer__maps-map iframe{min-height:360px}
.clinics .footer__maps-list{max-height:460px}

/* Footer compact (before_after.html) */
.footer{background:var(--white);border-top:1px solid var(--gray-200)}
.footer-grid{display:grid;grid-template-columns:1.2fr repeat(4,1fr);gap:24px;padding:56px 0}
.footer-logo img{height:34px}
.footer-brand p{
  font-size:12px;
  padding:10px 0;
}
.footer-col h4,
.footer-col .footer-title{font-size:13px;font-weight:var(--fw-semibold);margin-bottom:12px;color:var(--black)}
.footer-col a{display:block;color:var(--gray-600);font-size:13px;padding:6px 0}
.footer-col a:hover{color:var(--primary)}
.footer-bottom{border-top:1px solid var(--gray-100);padding:18px 0;display:flex;gap:16px;justify-content:space-between;align-items:flex-start;color:var(--gray-500);font-size:12px;flex-wrap:wrap}
.footer-socials{display:flex;gap:10px}
.footer-socials a{width:34px;height:34px;border-radius:50%;background:var(--gray-100);display:flex;align-items:center;justify-content:center}
.footer-socials a:hover{background:var(--primary)}
.footer-socials svg{width:16px;height:16px}

/* ===== 11. CONTACT BOOKING ===== */
.contact{background:var(--white)}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.contact-text h2{font-size:clamp(28px,4vw,42px);font-weight:var(--fw-semibold);line-height:1.15;margin-bottom:16px}
.contact-text p{font-size:17px;color:var(--gray-500);line-height:1.7;margin-bottom:32px;max-width:480px}
.contact-channels{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.contact-channel{display:flex;align-items:center;gap:14px;padding:20px;background:var(--gray-50);border-radius:var(--radius);border:1px solid var(--gray-200);transition:var(--transition);cursor:pointer;min-width:0}
.contact-channel:hover{border-color:var(--primary);box-shadow:var(--shadow)}
.contact-channel-icon{width:44px;height:44px;border-radius:12px;background:var(--primary);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.contact-channel-icon svg{width:22px;height:22px;color:#fff}
.contact-channel-text{font-size:14px;font-weight:600;color:var(--black);min-width:0;line-height:1.2;overflow-wrap:normal;word-break:normal;hyphens:none;flex:1 1 auto}
.contact-channel-text span{display:block;margin-top:4px;font-size:12px;font-weight:400;color:var(--gray-500);line-height:1.2;overflow-wrap:break-word;word-break:normal}

/* ===== 12. REVIEWS ===== */
.reviews{background:var(--bg)}
.reviews-overall{display:flex;align-items:center;gap:16px;margin-bottom:48px;padding:24px;background:var(--white);border-radius:var(--radius);border:1px solid var(--gray-200)}
.reviews-overall .rating-num{font-size:48px;font-weight:var(--fw-semibold);color:var(--black)}
.reviews-overall .rating-info{text-align:left}
.reviews-overall .stars{color:#f59e0b;font-size:20px;letter-spacing:2px}
.reviews-overall .rating-count{font-size:14px;color:var(--gray-500)}
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.review-card{background:var(--white);border-radius:var(--radius-lg);border:1px solid var(--gray-200);padding:28px;transition:var(--transition);box-shadow:var(--shadow-sm)}
.review-card:hover{box-shadow:var(--shadow)}
.reviews-grid--carousel{
  display:flex;
  gap:16px;
  overflow-x:auto;
  padding:4px 4px 12px;
  scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
}
.reviews-grid--carousel::-webkit-scrollbar{display:none}
.reviews-grid--carousel .review-card{
  flex:0 0 380px;
  min-width:380px;
  max-width:380px;
  scroll-snap-align:start;
}
.review-verified{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:#059669;background:#ecfdf5;padding:4px 12px;border-radius:var(--pill);margin-bottom:16px}
.review-verified svg{width:14px;height:14px;display:block;flex:0 0 auto}
.review-text{font-size:14px;color:var(--gray-600);line-height:1.7;margin-bottom:16px}
.review-author{font-size:14px;font-weight:var(--fw-semibold);color:var(--black)}
.review-date{font-size:12px;color:var(--gray-400)}

/* ===== 13. ARTICLES ===== */
.articles{background:var(--white)}
.articles-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:20px}
.articles-carousel-wrap{margin-top:18px}
.articles-carousel{display:flex;gap:16px;overflow:auto;scroll-snap-type:x mandatory;scrollbar-width:none;padding-bottom:8px}
.articles-carousel::-webkit-scrollbar{display:none}
.articles-carousel > .article-card{flex:0 0 420px;min-width:420px;max-width:420px;scroll-snap-align:start;display:block;text-decoration:none;color:inherit}
.articles-carousel .article-meta{padding-bottom:18px}
@media(max-width:1024px){
  .articles-carousel > .article-card{flex-basis:360px;min-width:360px;max-width:360px}
}
@media(max-width:560px){
  .articles-carousel > .article-card{flex-basis:86vw;min-width:86vw;max-width:86vw}
}
.article-card{border-radius:var(--radius);overflow:hidden;border:1px solid var(--gray-200);transition:var(--transition);background:var(--white)}
.article-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.article-img{height:180px;background:linear-gradient(135deg,rgba(var(--accent-rgb),.18),rgba(0,0,0,.02));display:flex;align-items:center;justify-content:center;color:rgba(0,0,0,.35)}
.article-img img{width:100%;height:100%;object-fit:cover}
.article-body{padding:18px 16px 8px}
.article-tag{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:var(--fw-semibold);color:var(--gray-600);background:var(--gray-50);border:1px solid var(--gray-200);border-radius:999px;padding:6px 10px;margin-bottom:10px}
.article-body h4,
.article-body .article-title{font-size:16px;line-height:1.3;letter-spacing:-.2px;margin:0 0 8px;color:var(--black)}
.article-body p{font-size:14px;line-height:1.7;color:var(--gray-600);margin:0}
.article-meta{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:12px 16px 16px;color:var(--gray-500);font-size:12px}

/* Licenses carousel (static) */
.licenses-carousel-wrap{margin-top:18px}
.licenses-carousel-track{display:flex;gap:16px;overflow:auto;scroll-snap-type:x mandatory;scrollbar-width:none;padding-bottom:8px}
.licenses-carousel-track::-webkit-scrollbar{display:none}
.licenses-slide{flex:0 0 300px;min-width:300px;max-width:300px;scroll-snap-align:start;display:block;text-decoration:none;color:inherit}
.licenses-slide-media{border-bottom:1px solid var(--gray-200);background:linear-gradient(135deg,rgba(var(--accent-rgb),.10),rgba(0,0,0,.02));display:flex;align-items:center;justify-content:center}
.licenses-slide-media img{width:100%;height:100%;object-fit:cover;display:block}
@media(max-width:560px){
  .licenses-slide{flex-basis:260px;min-width:260px;max-width:260px}
}

/* Unified carousel buttons */
.carousel-wrap{position:relative}
.carousel-nav-left{
  position:absolute;
  left:-14px;
  top:50%;
  transform:translateY(-50%);
  display:flex;
  flex-direction:column;
  gap:10px;
  z-index:4;
}
.carousel-btn{
  width:74px;
  height:46px;
  border-radius:18px;
  border:1px solid rgba(var(--accent-rgb),.55);
  background:rgba(255,255,255,.92);
  box-shadow:0 10px 22px rgba(0,0,0,.10);
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--black);
  transition:transform .15s ease, box-shadow .15s ease, background .15s ease, opacity .15s ease;
  position:relative;
  overflow:hidden;
}
.carousel-btn:hover{
  transform:translateY(-1px);
  background:#fff;
  animation:carouselWiggle .55s ease-in-out;
  box-shadow:0 14px 30px rgba(0,0,0,.12);
}
.carousel-btn:active{transform:translateY(0)}
.carousel-btn:focus-visible{outline:3px solid rgba(199,230,245,.95);outline-offset:3px}
.carousel-btn[disabled]{opacity:.55;cursor:not-allowed;box-shadow:none;animation:none !important}
.carousel-btn svg{width:20px;height:20px}
@media(max-width:900px){.carousel-nav-left{left:-6px}}
@media(max-width:600px){.carousel-nav-left{left:-2px}}

/* Variants (subservices): horizontal one-line scroll */
.variants-scroll{
  display:flex;
  gap:18px;
  overflow-x:auto;
  padding:4px 0 12px;
  scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
}
.variants-scroll::-webkit-scrollbar{display:none}
.variants-scroll > .service-card{
  flex:0 0 auto;
  min-width:360px;
  max-width:360px;
  scroll-snap-align:start;
}
@media(max-width:1024px){
  .variants-scroll > .service-card{min-width:320px;max-width:320px}
}
@media(max-width:560px){
  .variants-scroll > .service-card{min-width:86vw;max-width:86vw}
}

/* ===== ACTIONS / DOCTORS custom select ===== */
.actions-select,.doctors-select,.ba-select{display:none}
.actions-filters,
.doctors-filters{
  margin-top:14px;
  display:grid;
  grid-template-columns:1.2fr .8fr .8fr auto;
  gap:10px;
  align-items:center;
  width:100%;
  min-width:0;
}
.doctors-filters > *{min-width:0}

.actions-search,
.doctors-search,
.actions-select,
.doctors-select,
.ba-select{
  height:44px;
  width:100%;
  max-width:100%;
  padding:0 14px;
  border-radius:14px;
  border:1px solid var(--gray-200);
  background:rgba(255,255,255,.92);
  box-shadow:var(--shadow-sm);
  font-size:13px;
  outline:none;
}
.actions-select,
.doctors-select,
.ba-select{
  -webkit-appearance:none;
  appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:right 12px center;
  padding-right:36px;
}
.actions-search:focus,
.doctors-search:focus,
.actions-select:focus,
.doctors-select:focus,
.ba-select:focus{
  border-color:rgba(var(--accent-rgb),.55);
  box-shadow:0 0 0 4px rgba(var(--accent-rgb),.14);
}

.actions-clear,
.doctors-clear{height:44px}

@media(max-width:980px){
  .actions-filters,
  .doctors-filters{grid-template-columns:1fr 1fr;gap:10px}
  .actions-search,
  .doctors-search{grid-column:1 / -1}
  .actions-clear,
  .doctors-clear{grid-column:1 / -1}
}
@media(max-width:640px){
  .doctors-filters{grid-template-columns:1fr}
  .doctors-filters .doctors-clear{width:100%;justify-content:center}
}

.ui-select{position:relative;min-width:0}
.ui-select-btn{
  height:44px;
  width:100%;
  padding:0 12px;
  border-radius:14px;
  border:1px solid var(--gray-200);
  background:rgba(255,255,255,.92);
  box-shadow:var(--shadow-sm);
  font-size:13px;
  color:var(--black);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
}
.ui-select-btn:hover{border-color:rgba(var(--accent-rgb),.35)}
.ui-select-btn:focus-visible{outline:3px solid rgba(199,230,245,.95);outline-offset:3px}
.ui-select-btn .v{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ui-select-btn .caret{width:18px;height:18px;flex:0 0 auto;opacity:.7;display:inline-flex}
.ui-select-btn .caret svg{width:18px;height:18px}
.ui-select-pop{
  position:absolute;
  top:calc(100% + 8px);
  left:0;right:0;
  background:rgba(255,255,255,.98);
  border:1px solid rgba(0,0,0,.08);
  border-radius:16px;
  box-shadow:0 18px 48px rgba(0,0,0,.16);
  padding:8px;
  display:none;
  z-index:50;
}
.ui-select.is-open .ui-select-pop{display:block}
.ui-select-opt{
  width:100%;
  text-align:left;
  padding:10px 12px;
  border-radius:12px;
  color:var(--gray-700);
  background:transparent;
  border:none;
  font:inherit;
}
.ui-select-opt:hover{background:rgba(var(--accent-rgb),.10);color:var(--black)}
.ui-select-opt[aria-selected="true"]{background:rgba(var(--accent-rgb),.18);color:var(--black)}
.ui-select-pop{max-height:320px;overflow:auto}

/* ===== RESPONSIVE ===== */
@media(max-width:1576px){
  /* Small desktop/tablet/mobile: keep classic layout (hero is NOT under header) */
  body.home-hero-header{--home-header-offset:0px}
  body.home-hero-header #heroSection{
    margin-top:0 !important;
    padding-top:0 !important;
  }
  body.home-hero-header .header{
    background:var(--surface) !important;
    border-bottom-color:var(--gray-200) !important;
    box-shadow:0 2px 24px rgba(0,0,0,.06) !important;
  }
  body.home-hero-header .header-top,
  body.home-hero-header .header-main{
    background:var(--surface) !important;
  }
  body.home-hero-header .header-top,
  body.home-hero-header .header-top a,
  body.home-hero-header .header-top-left .city-select,
  body.home-hero-header .header-top-left .info-item,
  body.home-hero-header .header-nav > a,
  body.home-hero-header .header-nav > .nav-item > .nav-item-btn,
  body.home-hero-header .header-phone,
  body.home-hero-header .header-callback{
    color:var(--gray-600) !important;
  }
  body.home-hero-header .social-icons a{
    background:var(--gray-100) !important;
    color:var(--gray-600) !important;
  }
}
@media(max-width:1024px){
  .header-nav{display:none}
  .mobile-toggle{display:flex}
  .header-phone,.header-callback{display:none}
  .header-logo .logo-desktop{display:none}
  .header-logo .logo-mobile{display:block;height:28px}
  .about-grid,.contact-grid{grid-template-columns:1fr;gap: 0px;}
  .services-bento{grid-template-columns:repeat(2,1fr)}
  .service-card-lg,.service-stack{grid-column:span 2}
  .footer-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:768px){
  .services-variant-a .service-card{
    padding-top:78px;
  }
  .services-variant-a .service-icon{
    top:20px;
    left:20px;
  }
  .header-top{display:none}
  .services-bento{grid-template-columns:1fr}
  .service-card-lg,.service-stack{grid-column:span 1;grid-row:auto}
  .ba-grid,.reviews-grid,.articles-grid,.clinics-grid{grid-template-columns:1fr}
  .seasonal-grid{grid-template-columns:repeat(2,1fr)}
  .seasonal-icon{width:48px;height:48px;font-size:20px;margin:0 auto 12px}
  .beauty-program .program-icon{width:48px;height:48px;font-size:20px}
  .contact-channels{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
  .contact-channel{padding:14px;gap:12px}
  .hero-slide-content{padding:15px 6px 110px;max-width:680px}
  .footer-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .clinic-filters{justify-content:center}
}

@media(max-width:560px){
  .contact-grid{gap:0}
  .contact-channels{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
  .contact-channel{align-items:center;padding:10px 12px;min-height:auto;gap:10px}
  .contact-channel-icon{width:38px;height:38px;flex-shrink:0;border-radius:10px}
  .contact-channel-icon svg{width:18px;height:18px}
  .contact-channel-text{font-size:12px;line-height:1.25;white-space:nowrap;letter-spacing:-0.3px}
  .contact-channel-text span{font-size:10px;margin-top:1px;white-space:normal;display:block;line-height:1.2}
  .contact-channel-wide{grid-column:span 2}
  .footer-grid{grid-template-columns:1fr}
}
@media(max-width:480px){
  .seasonal-grid{grid-template-columns:1fr}
  .contact-channels{grid-template-columns:1fr;gap:8px}
  .contact-channel{padding:10px 12px}
  .contact-channel-wide{grid-column:auto}
  .contact-channel-text{font-size:12px}
  .contact-channel-text span{font-size:10px}
  .footer-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:380px){
  .container{padding:0}
  .section{padding:72px 0}
  .section-title{font-size:clamp(24px,8vw,30px)}
  .section-subtitle{font-size:15px;line-height:1.55}
  .btn{padding:12px 18px;font-size:14px}
  .contact-channels{grid-template-columns:1fr;gap:8px}
  .contact-channel{padding:10px 12px;gap:10px}
  .contact-channel-icon{width:36px;height:36px;border-radius:10px}
  .contact-channel-icon svg{width:18px;height:18px}
  .contact-channel-text{font-size:12px;white-space:nowrap;letter-spacing:-0.2px}
  .contact-channel-text span{font-size:10px;white-space:normal}
  .contact-channel-wide{grid-column:auto}
  .hero-slide-content{padding:22px 12px 96px}
  .promo-bar{padding-left:10px;padding-right:10px;font-size:12px}
}
@media(max-width:340px){
  .container{padding:0 12px}
  .section{padding:64px 0}
  .section-label{letter-spacing:1.4px}
  .section-title{font-size:clamp(22px,8.2vw,28px);line-height:1.1}
  .section-subtitle{font-size:14px;line-height:1.5}
  .btn{padding:11px 16px;font-size:13.5px}
  .contact-channel{padding:8px 10px;gap:8px}
  .contact-channel-icon{width:32px;height:32px;border-radius:8px}
  .contact-channel-icon svg{width:16px;height:16px}
  .contact-channel-text{font-size:11px;letter-spacing:-0.3px}
  .contact-channel-text span{font-size:9px}
  .promo-bar{font-size:11.5px;gap:10px}
  .promo-bar > span{flex:1 1 100%;line-height:1.25}
  .promo-timer{gap:4px}
  .promo-timer b{min-width:20px}
}

/* ===== BREADCRUMBS (service.html, doctors.html, actions.html, before_after.html) ===== */
.breadcrumbs{padding:18px 0 8px;color:var(--gray-500);font-size:13px}
.breadcrumbs a{color:var(--gray-600)}
.breadcrumbs span{color:var(--gray-400)}
.breadcrumbs{max-width:100%}
.breadcrumbs .row{display:flex;flex-wrap:wrap;gap:8px;align-items:center;max-width:100%;min-width:0}
.breadcrumbs .row > *{min-width:0;max-width:100%}
.breadcrumbs a,.breadcrumbs span{overflow-wrap:anywhere;word-break:break-word}
@media(max-width:768px){
  .breadcrumbs{padding:12px 4px 6px}
  .breadcrumbs .row{padding-left:0}
}

/* ===== SERVICE HERO + SUBNAV + PRICES (service.html) ===== */
.service-hero{padding:0 0 20px 0}
.service-hero-card{border:1px solid var(--gray-200);background:linear-gradient(135deg, rgba(255,255,255,.92), rgba(255,255,255,.82));border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow)}
.service-hero-grid{display:grid;grid-template-columns:1.12fr .88fr;min-width:0}
.service-hero-media{min-height:320px;background:#ddd center/cover no-repeat;min-width:0}
.detail-doctor-page .section{padding:64px 0}
.detail-doctor-page #doctorTop.section{padding:0 0 42px}
.detail-doctor-page .ba-intro{max-width:760px;margin-bottom:28px}
.detail-doctor-page .service-card{box-shadow:var(--shadow-sm)}
.u-text-primary{color:var(--primary)}
.u-icon-18{width:18px;height:18px}
.u-icon-18-muted{width:18px;height:18px;opacity:.6}
.mm-arrow{opacity:.55}
.mega-menu-inner-about{grid-template-columns:240px 1fr 300px;max-width:1180px}
.mega-menu-inner-actions{grid-template-columns:1fr 1fr 280px}
.detail-doctor-page .doctor-tag{
  padding:8px 14px;
  font-size:12px;
  border-radius:999px;
  background:rgba(var(--accent-rgb),.12);
  border:1px solid rgba(var(--accent-rgb),.22);
}
.detail-doctor-page .service-hero-card{
  border-radius:32px;
  border:1px solid rgba(209,214,224,.9);
  background:linear-gradient(135deg,rgba(255,255,255,.96),rgba(250,250,253,.92));
  box-shadow:0 24px 60px rgba(28,32,54,.10);
}
.detail-doctor-page .service-hero-grid{grid-template-columns:minmax(320px,.86fr) minmax(420px,1.14fr)}
.doctor-hero-media{
  display:flex;
  align-items:stretch;
  justify-content:center;
  min-height:360px;
  background:linear-gradient(180deg,#d8d8dd,#cfcfd6);
}
.doctor-hero-photo{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center top;
  display:block;
}
.doctor-hero-subtitle{
  margin-top:12px;
  max-width:560px;
  font-size:17px;
  line-height:1.7;
  color:var(--gray-600);
}
.doctor-hero-meta{margin-top:18px}
.doctor-clinic-metro{
  color:var(--gray-600);
  font-size:12px;
  line-height:1.45;
}
.doctor-hero-price{
  margin-top:22px;
  padding-top:20px;
  border-top:1px solid var(--gray-200);
}
.doctor-hero-note{
  display:block;
  margin-top:6px;
  max-width:360px;
  color:var(--gray-600);
}
.detail-doctor-page .service-meta{grid-template-columns:repeat(2,minmax(0,1fr))}
.detail-doctor-page .service-meta .meta{min-height:92px;justify-content:center}
.detail-doctor-page .service-meta .meta.meta-wide{grid-column:1 / -1}
.detail-doctor-page .service-meta .meta span{overflow:visible;text-overflow:clip}
.doctor-profile-subtitle{
  margin-bottom:24px;
  max-width:760px;
}
.doctor-profile-grid{
  display:grid;
  grid-template-columns:minmax(0,1.7fr) minmax(320px,380px);
  gap:20px;
  align-items:start;
}
.doctor-profile-main,
.doctor-profile-aside{display:grid;gap:18px;min-width:0}
.doctor-profile-main > *,
.doctor-profile-aside > *{width:100%}
.detail-doctor-page .doctor-card{
  min-width:0;
  max-width:none;
  flex-shrink:1;
}
.doctor-profile-main .doctor-card{
  min-height:100%;
  display:flex;
  flex-direction:column;
  justify-content:flex-start;
}
.doctor-card{
  padding:22px;
  width:100%;
  cursor:default;
  border-radius:24px;
}
.detail-doctor-page .doctor-card::before{display:none}
.detail-doctor-page .doctor-card:hover{
  transform:none;
  box-shadow:0 16px 36px rgba(21,27,48,.06);
  border-color:var(--gray-200);
}
.doctor-card-title{
  margin:0 0 14px;
  font-size:24px;
  line-height:1.15;
}
.doctor-tags{display:flex;gap:10px;flex-wrap:wrap}
.doctor-about-text{
  margin-top:18px;
  max-width:none;
  color:var(--gray-600);
  font-size:15px;
  line-height:1.8;
}
.doctor-aside-title{
  font-size:24px;
  font-weight:var(--fw-semibold);
  letter-spacing:-.2px;
  margin-bottom:16px;
}
.doctor-aside-list{
  display:grid;
  gap:12px;
  font-size:14px;
  color:var(--gray-600);
  line-height:1.7;
}
.doctor-aside-list b{color:var(--black)}
.doctor-aside-actions{margin-top:20px;display:flex;gap:10px;flex-wrap:wrap}
.doctor-services,
.doctor-education,
.doctor-certs{background:var(--bg)}
.doctor-services .section-title,
.doctor-education .section-title,
.doctor-certs .section-title{max-width:820px}
.doctor-services-inner,
.doctor-education-inner{
  margin-top:0;
  background:rgba(255,255,255,.82);
  backdrop-filter:blur(12px);
  border-radius:28px;
  padding:24px;
  border:1px solid rgba(220,224,233,.9);
  box-shadow:0 18px 44px rgba(29,34,58,.06);
}
.doctor-certs-subtitle{max-width:760px;margin-bottom:20px}
.doctor-certs-table-wrap{
  overflow:auto;
  border:1px solid rgba(220,224,233,.9);
  border-radius:28px;
  background:rgba(255,255,255,.88);
  box-shadow:0 18px 44px rgba(29,34,58,.06);
}
.doctor-certs-table{
  width:100%;
  min-width:760px;
  border-collapse:separate;
  border-spacing:0;
}
.doctor-certs-table th,
.doctor-certs-table td{
  padding:18px 20px;
  text-align:left;
  vertical-align:top;
  border-bottom:1px solid var(--gray-100);
  font-size:14px;
  line-height:1.65;
}
.doctor-certs-table th{
  background:rgba(var(--accent-rgb),.08);
  font-size:12px;
  font-weight:var(--fw-semibold);
  color:var(--gray-600);
  text-transform:uppercase;
  letter-spacing:.04em;
}
.doctor-certs-table tr:last-child td{border-bottom:none}
.doctor-certs-table tbody tr:hover td{background:rgba(var(--accent-rgb),.05)}
.doctor-services-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:18px;
}
.doctor-services-item{
  padding:20px;
  border-radius:24px;
  cursor:default;
  background:linear-gradient(180deg,rgba(255,255,255,.98),rgba(248,248,252,.94));
}
.detail-doctor-page .doctor-services-item::before{display:none}
.detail-doctor-page .doctor-services-item:hover{
  transform:none;
  border-color:rgba(var(--accent-rgb),.18);
  box-shadow:0 16px 34px rgba(24,30,54,.07);
}
.doctor-services-item-title{
  font-size:18px;
  font-weight:var(--fw-semibold);
  margin-bottom:14px;
}
.doctor-services-links{
  display:grid;
  gap:10px;
}
.doctor-services-links a{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  min-height:48px;
  padding:12px 14px;
  border-radius:16px;
  border:1px solid rgba(214,218,230,.95);
  background:rgba(250,250,253,.96);
  color:var(--gray-700);
  font-size:14px;
  line-height:1.5;
  font-weight:var(--fw-medium);
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease, background .18s ease, color .18s ease;
}
.doctor-services-links a::after{
  content:'↗';
  color:var(--primary);
  font-size:14px;
  line-height:1;
  flex:0 0 auto;
}
.doctor-services-links a:hover,
.doctor-services-links a:focus-visible{
  background:linear-gradient(135deg,rgba(var(--accent-rgb),.16),rgba(199,230,245,.22));
  border-color:rgba(var(--accent-rgb),.34);
  color:var(--black);
  box-shadow:0 14px 28px rgba(30,36,62,.08);
  transform:translateY(-1px);
}
.doctor-services-links a:focus-visible{outline:none}
.doctor-education-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:18px;
  margin-top:18px;
}
.doctor-education-block-title{
  margin-bottom:14px;
  font-size:18px;
  font-weight:var(--fw-semibold);
  line-height:1.3;
}
.doctor-edu-list{
  margin:0;
  padding-left:18px;
  color:var(--gray-700);
  line-height:1.8;
  font-size:14px;
}
.doctor-ba-1{--ba-before:url('https://laserdoctor.ru/upload/iblock/258/w7rs3030qomw5wx5j72k1td9zbz072fg.jpg');--ba-after:url('https://laserdoctor.ru/upload/iblock/646/gw9n1l1evetyntxx01f2rwn2ynw5tkkz.jpg')}
.doctor-ba-2{--ba-before:url('https://laserdoctor.ru/upload/iblock/aa5/tl18ye9bh5m9fdndzqa3vet9k46485o4.jpg');--ba-after:url('https://laserdoctor.ru/upload/iblock/00d/gtwrt85tl99b9pw2sm69mg0m7s3zu2dt.jpg')}
.doctor-ba-3{--ba-before:url('https://laserdoctor.ru/upload/iblock/aa5/tl18ye9bh5m9fdndzqa3vet9k46485o4.jpg');--ba-after:url('https://laserdoctor.ru/upload/iblock/00d/gtwrt85tl99b9pw2sm69mg0m7s3zu2dt.jpg')}
.doctor-ba-4{--ba-before:url('https://laserdoctor.ru/upload/iblock/9c0/xkogt7s0o6uyart1pk6rznthu7prb4mw.jpg');--ba-after:url('https://laserdoctor.ru/upload/iblock/5e8/iumtx8dtm3a4dqetgxygih2app7vquya.jpg')}
.doctor-reviews-head{display:flex;gap:12px;align-items:flex-end;justify-content:space-between;flex-wrap:wrap}
.doctor-reviews-title{margin:0}
.doctor-reviews-actions{display:flex;gap:10px;flex-wrap:wrap}
.doctor-reviews-grid{margin-top:22px;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}
.doctor-review-card{
  padding:20px;
  cursor:default;
  border-radius:24px;
}
.detail-doctor-page .doctor-review-card::before{display:none}
.detail-doctor-page .doctor-review-card:hover{
  transform:none;
  box-shadow:0 16px 36px rgba(21,27,48,.06);
  border-color:var(--gray-200);
}
.doctor-review-meta{
  display:grid;
  gap:6px;
  margin-bottom:14px;
}
.doctor-review-procedure{
  font-size:12px;
  font-weight:var(--fw-semibold);
  color:var(--primary);
  text-transform:uppercase;
  letter-spacing:.04em;
}
.doctor-review-clinic{
  font-size:12px;
  color:var(--gray-500);
}
.doctor-review-name{font-weight:var(--fw-semibold);font-size:17px;line-height:1.3}
.doctor-review-text{margin-top:10px;color:var(--gray-600);font-size:14px;line-height:1.75}
.doctor-review-date{margin-top:14px;color:var(--gray-500);font-size:12px}
.contact-channel-telegram{background:#229ED9}
.contact-channel-vk{background:#4C75A3}
.contact-channel-primary{background:var(--primary)}
.contact-channel-icon-white{width:20px;height:20px;color:#fff}
.contact-channel-geo-white{color:#fff}
.contact-channel-wide{grid-column:span 2}
.footer-contact-meta{margin-top:16px;font-size:14px;color:var(--gray-500)}
.service-hero-body{padding:22px 22px 18px;min-width:0}
.service-badges{display:flex;gap:10px;flex-wrap:wrap}
.service-badge{display:inline-flex;align-items:center;gap:6px;padding:7px 12px;border-radius:999px;background:rgba(var(--accent-rgb),.22);border:1px solid rgba(var(--accent-rgb),.40);font-size:12px;font-weight:var(--fw-medium)}
.hero-expert{
  margin-top:10px;
  display:flex;
  align-items:center;
  gap:10px;
  padding:10px 12px;
  border-radius:16px;
  border:1px solid rgba(0,0,0,.08);
  background:rgba(255,255,255,.78);
  backdrop-filter:blur(10px);
  max-width:100%;
  min-width:0;
}
.hero-expert-photo{
  width:64px;
  height:64px;
  border-radius:14px;
  object-fit:cover;
  display:block;
  flex:0 0 auto;
  background:linear-gradient(135deg,rgba(var(--accent-rgb),.10),rgba(199,230,245,.22));
  border:1px solid rgba(var(--accent-rgb),.22);
}
.hero-expert-meta{min-width:0}
.hero-expert-label{font-size:11px;color:var(--gray-500);line-height:1.1}
.hero-expert-name{margin-top:2px;font-size:13px;font-weight:var(--fw-semibold);color:var(--black);line-height:1.2}
.hero-expert-position{margin-top:2px;font-size:12px;color:var(--gray-600);line-height:1.25;display:-webkit-box;line-clamp:2;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.service-title{margin-top:12px;font-size:clamp(26px,3.2vw,40px);line-height:1.12;font-weight:var(--fw-semibold);letter-spacing:-.2px}
.service-price{margin-top:14px;display:flex;align-items:flex-end;justify-content:space-between;gap:14px;flex-wrap:wrap}
.service-price .p{font-size:14px;color:var(--gray-500)}
.service-price .p b{display:inline-block;font-size:24px;color:var(--black);letter-spacing:-.2px}
.service-cta{display:flex;gap:10px;flex-wrap:wrap}

/* Hero meta cards (duration/course/recovery/equipment) */
.service-meta{
  margin-top:14px;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
}
.service-meta .meta{
  border:1px solid var(--gray-200);
  background:rgba(255,255,255,.92);
  border-radius:14px;
  padding:12px 14px;
  box-shadow:var(--shadow-sm);
  display:flex;
  flex-direction:column;
  gap:6px;
  min-width:0;
}
.service-meta .meta b{
  font-size:12px;
  letter-spacing:.2px;
  color:var(--gray-600);
}

.price-table.is-collapsed table tbody tr s{
  font-size: 11px;
  color: #ccc;
  margin-left: 10px;
}
.service-meta .meta span{
  font-size:13px;
  font-weight:var(--fw-semibold);
  color:var(--black);
  line-height:1.25;
  overflow:hidden;
  text-overflow:ellipsis;
}
@media(max-width:560px){
  .service-meta{grid-template-columns:1fr}
}
@media(max-width:980px){
  .service-hero-grid,
  .detail-doctor-page .service-hero-grid{grid-template-columns:1fr}
  .service-hero-media{min-height:240px}
  .doctor-hero-media{min-height:320px}
  .doctor-profile-grid,
  .doctor-services-grid,
  .doctor-reviews-grid,
  .doctor-education-grid{grid-template-columns:1fr}
  .contact-channel-wide{grid-column:auto}
  .detail-doctor-page .section{padding:48px 0}
}
@media(max-width:768px){
  .detail-doctor-page #doctorTop.section{padding:0 0 28px}
  .detail-doctor-page .section{padding:40px 0}
  .doctor-hero-media{min-height:250px}
  .doctor-card,
  .doctor-services-inner,
  .doctor-education-inner,
  .doctor-review-card{padding:18px}
  .doctor-card-title,
  .doctor-aside-title{font-size:20px}
  .doctor-services-item-title,
  .doctor-education-block-title{font-size:17px}
  .doctor-review-name{font-size:16px}
  .doctor-services-links a{padding:11px 12px;min-height:44px;font-size:13px}
  .service-cta{display:grid;grid-template-columns:1fr;width:100%}
  .service-cta .btn{width:100%;justify-content:center}
}

.hero-oldprice{
  display:inline-flex;
  align-items:center;
  gap:10px;
  font-size:16px;
  color:var(--gray-600);
  letter-spacing:-.1px;
  transform-origin:left center;
}
.hero-oldprice s{text-decoration-thickness:2px;text-decoration-color:rgba(0,0,0,.35)}
.hero-oldprice .tag{
  display:inline-flex;
  align-items:center;
  gap:6px;
  margin-left:8px;
  padding:4px 8px;
  border-radius:999px;
  border:1px solid rgba(var(--accent-rgb),.32);
  background:rgba(var(--accent-rgb),.16);
  color:var(--black);
  font-size:12px;
  font-weight:var(--fw-semibold);
}

.service-subnav{position:sticky;top:calc(64px + var(--vv-top, 0px));z-index:900;margin-top:14px}
.service-subnav .bar{border:1px solid var(--gray-200);background:rgba(255,255,255,.72);backdrop-filter:blur(10px);border-radius:16px;box-shadow:var(--shadow-sm);overflow:auto}
.service-subnav .items{display:flex;gap:8px;padding:10px}
.service-subnav a{flex:0 0 auto;padding:10px 12px;border-radius:14px;font-size:13px;color:var(--gray-600)}
.service-subnav a:hover{background:rgba(var(--accent-rgb),.18);color:var(--black)}
@media(max-width:768px){
  .service-subnav{top:calc(56px + var(--vv-top, 0px))}
  .service-subnav .bar{overflow:visible}
  .service-subnav .items{display:grid;grid-template-columns:1fr 1fr;gap:8px}
  .service-subnav a{white-space:normal;text-align:center;justify-content:center;min-height:42px;display:flex;align-items:center}
}
@media(min-width:981px){
  .service-subnav .bar{overflow:visible}
  .service-subnav .items{width:100%;justify-content:space-between;gap:6px}
  .service-subnav a{flex:1 1 0;justify-content:center;text-align:center;white-space:nowrap;padding-left:10px;padding-right:10px}
}

/* Service content grids (about/process blocks) */
.service-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media(max-width:980px){.service-grid-2{grid-template-columns:1fr}}

/* Service bullet lists */
.service-list{margin-top:10px;display:grid;gap:10px}
.service-li{display:flex;gap:10px;align-items:flex-start}
.service-dot{width:10px;height:10px;border-radius:999px;background:rgba(var(--accent-rgb),.55);margin-top:7px;flex:0 0 auto}

/* Make service cards match production (only in these sections) */
#about .service-card,
#process .service-card{
  border:1px solid var(--gray-200);
  background:var(--white);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-sm);
  padding:18px;
  cursor:default;
  height: max-content;
}
#about .service-card::before,
#process .service-card::before{display:none !important}
#about .service-card:hover,
#process .service-card:hover{transform:none;box-shadow:var(--shadow-sm);border-color:var(--gray-200)}

.price-table{overflow:auto;border-radius:var(--radius-lg);border:1px solid var(--gray-200);background:var(--white)}
.price-table.is-collapsed{position:relative}
.price-table.is-collapsed::after{
  content:'';
  position:sticky;
  display:block;
  left:0;
  bottom:0;
  width:100%;
  pointer-events:none;
  background:linear-gradient(to bottom, rgba(255,255,255,0), rgba(255,255,255,.92));
}


.price-table.is-collapsed > table > thead > tr{background: none;}
.price-table.is-collapsed > table > tfoot > tr{background: none;}
.price-table table{width:100%;border-collapse:separate;border-spacing:0;min-width:820px}
.price-table th,.price-table td{padding:12px 14px;border-bottom:1px solid var(--gray-100);text-align:left;font-size:13px;vertical-align:top}
.price-table th{font-size:12px;color:var(--gray-600);font-weight:var(--fw-semibold);background:rgba(var(--accent-rgb),.10)}
.price-table tr:last-child td{border-bottom:none}
.price-table tr:hover{background: #dfdff0;}
.price-table tbody tr.is-hidden{display:none}

.price-table tfoot td{
  padding:10px 14px;
  background:linear-gradient(to bottom, rgba(255,255,255,.0), rgba(255,255,255,.92));
  position:sticky;
  bottom:0;
  border-bottom:none;
}
.price-toggle-btn{
  width:100%;
  height:44px;
  border-radius:14px;
  border:1px solid rgba(var(--accent-rgb),.55);
  background:#bfc0ed;
  box-shadow:var(--shadow-sm);
  color:var(--black);
  font-weight:var(--fw-semibold);
  cursor:pointer;
  transition:transform .15s ease, box-shadow .15s ease, background .15s ease;
}
.price-toggle-btn:hover{transform:translateY(-1px);background:#fff;box-shadow:0 14px 30px rgba(0,0,0,.10)}
.price-toggle-btn:active{transform:translateY(0)}
.price-toggle-btn:focus-visible{outline:3px solid rgba(199,230,245,.95);outline-offset:3px}

.price-cards{display:none}
.price-cards .group{margin:14px 0 8px;font-weight:var(--fw-semibold);color:var(--black)}
.price-card{border:1px solid var(--gray-200);background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:14px}
.price-card + .price-card{margin-top:10px}
.price-cards-toggle{margin-top:12px}
.price-card.is-hidden{display:none}
.price-card .title{font-weight:var(--fw-semibold);letter-spacing:-.2px;line-height:1.35}
.price-card .meta{margin-top:6px;color:var(--gray-600);font-size:12px;line-height:1.45}
.price-pairs{margin-top:10px;display:grid;gap:8px}
.price-pair{display:flex;align-items:baseline;justify-content:space-between;gap:10px;padding:10px 10px;border-radius:14px;background:rgba(var(--accent-rgb),.10);border:1px solid rgba(var(--accent-rgb),.22)}
.price-pair .k{color:var(--gray-600);font-size:12px;line-height:1.25}
.price-pair .v{font-weight:var(--fw-semibold);color:var(--black);white-space:nowrap}

@media(max-width:980px){
  .price-scroll-hint{display:none !important}
  .price-table{display:none}
  .price-cards{display:block}
}
.price-scroll-hint{
  display:none;
  margin:-4px 0 10px;
  padding:8px 12px;
  border-radius:12px;
  border:1px solid rgba(var(--accent-rgb),.36);
  background:linear-gradient(90deg, rgba(var(--accent-rgb),.14), rgba(var(--accent-rgb),.06));
  color:var(--gray-600);
  font-size:12px;
  font-weight:var(--fw-medium);
  align-items:center;
  gap:8px;
}
.price-scroll-hint::before{content:'↔';font-size:14px;line-height:1}
.price-scroll-hint.is-visible{display:inline-flex}
.price-scroll-hint.is-hidden{display:none}
@media(min-width:981px){.price-scroll-hint{display:none !important}}

/* Prices page: nested accordion */
.prices-accordion{display:grid;gap:10px;margin-top:16px}
.prices-acc-l1{
  border:1px solid var(--gray-200);
  background:var(--white);
  border-radius:18px;
  padding:12px 14px;
}
.prices-acc-l1[open]{box-shadow:var(--shadow-sm)}
.prices-acc-l1 > summary,
.prices-acc-l2 > summary{
  list-style:none;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  cursor:pointer;
}
.prices-acc-l1 > summary::-webkit-details-marker,
.prices-acc-l2 > summary::-webkit-details-marker{display:none}
.prices-acc-l1 > summary span{font-weight:var(--fw-semibold);font-size:16px}
.prices-acc-l1 > summary i,
.prices-acc-l2 > summary i{
  font-style:normal;
  opacity:.8;
  font-size:18px;
  line-height:1;
  width:18px;
  min-width:18px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  transform:none;
}
.prices-acc-l1-body{margin-top:10px;display:grid;gap:8px}
.prices-acc-l2{
  border:1px solid var(--gray-100);
  background:var(--gray-50);
  border-radius:14px;
  padding:10px 12px;
}
.prices-acc-l2 > summary span{font-weight:var(--fw-semibold);font-size:14px}
.prices-rows{margin-top:10px;display:grid}
.prices-row{
  display:flex;
  align-items:baseline;
  justify-content:space-between;
  gap:12px;
  padding:10px 0;
  border-top:1px solid var(--gray-200);
}
.prices-row:first-child{border-top:1px solid var(--gray-200)}
.prices-row span{font-size:13px;color:var(--gray-700);line-height:1.35}
.prices-row b{white-space:nowrap;font-size:13px}
.prices-help-card{
  margin-top:14px;
  padding:16px 18px;
  display:flex;
  gap:14px;
  align-items:center;
  justify-content:space-between;
  flex-wrap:wrap;
}
.prices-help-title{font-weight:var(--fw-semibold)}
.prices-help-sub{color:var(--gray-600);font-size:13px;line-height:1.6;margin-top:4px}
.prices-help-actions{display:flex;gap:10px;flex-wrap:wrap}

.steps{display:grid;gap:10px;counter-reset:step}
.steps .step{display:grid;grid-template-columns:auto 1fr;gap:12px;padding:14px;border-radius:16px;border:1px solid var(--gray-200);background:rgba(255,255,255,.82)}
.steps .step::before{counter-increment:step;content:counter(step);width:34px;height:34px;border-radius:14px;display:flex;align-items:center;justify-content:center;background:rgba(var(--accent-rgb),.22);border:1px solid rgba(var(--accent-rgb),.40);font-weight:var(--fw-semibold)}
.steps .step b{display:block}
.steps .step p{margin-top:4px;color:var(--gray-600);font-size:13px;line-height:1.65}

/* ===== FLOATING: SCROLL TO TOP ===== */
.to-top{
  position:fixed;
  right:clamp(14px,2vw,22px);
  bottom:calc(clamp(14px,2vw,22px) + env(safe-area-inset-bottom) + var(--vv-bottom, 0px));
  width:46px;height:46px;
  border-radius:999px;
  border:1px solid rgba(0,0,0,.12);
  background:rgba(255,255,255,.92);
  box-shadow:var(--shadow);
  display:flex;align-items:center;justify-content:center;
  opacity:0;visibility:hidden;transform:translateY(8px);
  transition:opacity .2s ease,transform .2s ease,visibility .2s ease,background .2s ease;
  z-index:5000;
}
.to-top:hover{background:#fff;transform:translateY(4px)}
.to-top.is-visible{opacity:1;visibility:visible;transform:translateY(0)}
.to-top svg{width:18px;height:18px}
@media(max-width:480px){.to-top{width:44px;height:44px}}

/* Landscape-only overlay (portrait-first layout) */
.landscape-overlay{
  position:fixed;
  inset:0;
  z-index:6000;
  display:none;
  align-items:center;
  justify-content:center;
  padding:24px;
  background:
    radial-gradient(1200px 600px at 20% 10%, rgba(var(--accent-rgb),.18), transparent 60%),
    radial-gradient(900px 500px at 80% 30%, rgba(199,230,245,.30), transparent 55%),
    linear-gradient(135deg, rgba(255,255,255,.92), rgba(255,255,255,.82));
  backdrop-filter:blur(14px);
}
.landscape-card{
  width:min(640px,100%);
  background:rgba(255,255,255,.86);
  border:1px solid rgba(var(--accent-rgb),.22);
  box-shadow:0 24px 80px rgba(0,0,0,.12);
  border-radius:var(--radius-lg);
  padding:20px;
}
.landscape-top{display:flex;align-items:flex-start;justify-content:space-between;gap:14px}
.landscape-title{font-size:18px;font-weight:var(--fw-semibold);letter-spacing:-.2px}
.landscape-sub{margin-top:6px;color:var(--gray-600);line-height:1.55;font-size:13px}
.landscape-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}
.landscape-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding:10px 14px;
  border-radius:14px;
  border:1px solid var(--gray-200);
  background:var(--white);
  font-weight:var(--fw-semibold);
}
.landscape-btn.primary{
  border-color:rgba(var(--accent-rgb),.36);
  background:rgba(var(--accent-rgb),.16);
  color:var(--black);
}
.landscape-mini{
  margin-top:14px;
  border-radius:16px;
  border:1px solid rgba(var(--accent-rgb),.18);
  background:linear-gradient(135deg, rgba(var(--accent-rgb),.08), rgba(199,230,245,.18));
  padding:14px;
  position:relative;
  overflow:hidden;
}
.landscape-mini::before{
  content:'';
  position:absolute;
  inset:-40px;
  opacity:.55;
  background:conic-gradient(from 180deg, rgba(var(--accent-rgb),.35), rgba(199,230,245,.35), rgba(var(--accent-rgb),.35));
  filter:blur(22px);
  animation:spin 10s linear infinite;
}
.landscape-mini-inner{position:relative;display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}
.landscape-metric{background:rgba(255,255,255,.75);border:1px solid rgba(255,255,255,.65);border-radius:14px;padding:12px}
.landscape-metric b{display:block;font-size:18px;font-weight:var(--fw-semibold)}
.landscape-metric span{display:block;margin-top:2px;font-size:12px;color:var(--gray-600);font-weight:var(--fw-medium)}
@keyframes spin{to{transform:rotate(360deg)}}
@media (orientation: landscape) and (max-width: 1024px){
  body:not(.landscape-dismissed) .landscape-overlay{display:flex}
  body:not(.landscape-dismissed){overflow:hidden}
}

/* ===== FOLLOW (subscribe) ===== */
.follow{background:linear-gradient(135deg,rgba(var(--accent-rgb),.18),rgba(255,255,255,.75));border-top:1px solid var(--gray-100);border-bottom:1px solid var(--gray-100)}
.follow-inner{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;flex-wrap:wrap}
.follow-title{font-size:clamp(22px,3.2vw,34px);font-weight:var(--fw-semibold);line-height:1.15;margin:0 0 8px}
.follow-sub{color:var(--gray-600);font-size:15px;line-height:1.7;max-width:560px;margin:0}
.follow-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;flex:1;min-width:min(520px,100%)}
.follow-card{display:flex;align-items:center;gap:12px;padding:14px 14px;border:1px solid var(--gray-200);border-radius:16px;background:var(--white);box-shadow:var(--shadow-sm);transition:var(--transition)}
.follow-card:hover{transform:translateY(-2px);box-shadow:var(--shadow);border-color:transparent}
.follow-ic{width:44px;height:44px;border-radius:14px;display:flex;align-items:center;justify-content:center;background:rgba(var(--accent-rgb),.22);color:var(--black);flex:0 0 auto}
.follow-ic svg{width:20px;height:20px}
.follow-meta b{display:block;font-weight:var(--fw-semibold);line-height:1.2}
.follow-meta span{display:block;color:var(--gray-600);font-size:12px;line-height:1.3;margin-top:2px}
@media(max-width:1024px){.follow-grid{grid-template-columns:repeat(2,minmax(0,1fr));min-width:0}}
@media(max-width:520px){.follow-inner{align-items:stretch}.follow-grid{grid-template-columns:1fr}}

/* ===== NEWSLETTER (Подписаться на рассылку) ===== */
.u-sr{
  position:absolute !important;
  width:1px;height:1px;
  padding:0;margin:-1px;
  overflow:hidden;clip:rect(0,0,0,0);
  white-space:nowrap;border:0;
}
.newsletter{padding:54px 0}
.newsletter-card{
  border:1px solid var(--gray-200);
  border-radius:var(--radius-xl);
  overflow:hidden;
  box-shadow:0 24px 60px rgba(28,32,54,.08);
  background:
    radial-gradient(900px 520px at 20% 10%, rgba(var(--accent-rgb),.16), transparent 60%),
    linear-gradient(135deg, rgba(255,255,255,.92), rgba(255,255,255,.84));
}
.newsletter-grid{display:grid;grid-template-columns:1.05fr .95fr;min-width:0}
.newsletter-body{padding:28px 28px 26px}
.newsletter-sub{margin:10px 0 0;color:var(--gray-600);line-height:1.65;max-width:52ch}
.newsletter-form{display:flex;gap:10px;align-items:stretch;margin-top:18px;flex-wrap:wrap}
.newsletter-field{flex:1;min-width:min(320px,100%)}
.newsletter-field input{
  width:100%;
  height:44px;
  border-radius:14px;
  border:1px solid var(--gray-200);
  background:rgba(255,255,255,.95);
  padding:0 14px;
  outline:none;
  transition:var(--transition);
}
.newsletter-field input:focus{border-color:rgba(var(--accent-rgb),.55);box-shadow:0 0 0 4px rgba(var(--accent-rgb),.18)}
.newsletter-note{margin-top:10px;color:var(--gray-500);font-size:12px;line-height:1.55;max-width:64ch}
.newsletter-media{
  min-height:280px;
  background:
    linear-gradient(135deg, rgba(0,0,0,.10), rgba(0,0,0,0)),
    url('./img/новости,_акции_и_ползные_материалы.jpg') center/cover no-repeat,
    url('./2.jpg') center/cover no-repeat;
}

/* New pages utilities */
.service-hero-media--reviews{background-image:url('./2.jpg')}
.service-hero-media--clinics{background-image:url('https://laserdoctor.ru/upload/resize_cache/iblock/155/480_360_2/1orikc1hm1hdsy1sy8dyz6pjq5b0c7hv.jpg')}
.service-hero-media--clinic-detail{background-image:url('https://laserdoctor.ru/upload/iblock/155/1orikc1hm1hdsy1sy8dyz6pjq5b0c7hv.jpg')}
.service-hero-media--vacancies{background-image:url('./img/vacancies.html.jpg')}
.service-hero-media--equipment{background-image:url('./img/оборудование клиник (1).jpg')}
.service-hero-media--payment{background-image:url('./img/оплата онлайн.jpg')}
.service-hero-media--gift{background-image:url('./img/подарочный сертификат.jpg')}
.service-hero-media--before-after{background-image:url('./img/before_after.html.jpg')}
.service-subtitle-offset{margin-top:10px}
.service-price-offset{margin-top:14px}
.service-price-note{display:block;margin-top:4px}
.section-grid-top{margin-top:16px}
.section-grid-top-lg{margin-top:20px}
.btn-top-auto{margin-top:auto}
.map-block-lg{margin-top:18px;min-height:420px}
.review-card-text{margin-top:10px;color:var(--gray-600)}
.review-card-meta{margin-top:14px;font-size:13px;color:var(--gray-500)}
.error-page-card{padding:42px 28px;text-align:center}
.error-page-title{margin-bottom:10px}
.error-page-sub{max-width:720px;margin:0 auto}
.error-page-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-top:18px}
.error-page-image{
  width:min(420px,100%);
  margin:0 auto 16px;
  border-radius:18px;
  border:1px solid var(--gray-200);
  box-shadow:var(--shadow-sm);
  overflow:hidden;
}
.error-page-image img{display:block;width:100%;height:auto}
.equipment-card{padding:0 !important;overflow:hidden}
.equipment-card-media{
  width:100%;
  height:260px;
  object-fit:cover;
  border-bottom:1px solid var(--gray-100);
  display:block;
}
.equipment-card-body{padding:16px 16px 18px}
.equipment-card-body h3{margin:0}
.equipment-card-body p{margin-top:8px}
.equipment-showcase{
  margin-top:20px;
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:28px 26px;
}
.equipment-showcase-item{
  background:transparent;
  border:none;
  border-radius:0;
  padding:0;
  box-shadow:none;
}
.equipment-showcase-grid{
  display:grid;
  grid-template-columns:minmax(0,1.22fr) minmax(220px,.78fr);
  gap:16px;
  align-items:start;
}
.equipment-showcase-title{
  font-size:28px;
  line-height:1.02;
  letter-spacing:-.015em;
  margin:0 0 5px;
  color:#bd4aa7;
}
.equipment-showcase-meta{
  font-size:10px;
  font-weight:var(--fw-semibold);
  color:var(--gray-600);
  text-transform:uppercase;
  letter-spacing:.09em;
}
.equipment-showcase-desc{
  margin-top:12px;
  color:var(--gray-700);
  font-size:12px;
  line-height:1.58;
  max-width:95%;
}
.equipment-showcase-media{
  width:100%;
  height:320px;
  object-fit:contain;
  object-position:center bottom;
}
.equipment-showcase-line{
  margin-top:12px;
  height:12px;
  border-radius:0;
  background:#d8eef9;
}
.clinic-gallery{margin-top:16px}
.clinic-gallery-track{
  display:flex;
  gap:14px;
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
  padding:2px 2px 12px;
}
.clinic-gallery-track::-webkit-scrollbar{display:none}
.clinic-gallery-photo{
  flex:0 0 360px;
  min-width:360px;
  max-width:360px;
  height:240px;
  border-radius:16px;
  overflow:hidden;
  border:1px solid var(--gray-200);
  box-shadow:var(--shadow-sm);
  scroll-snap-align:start;
}
.clinic-gallery-photo img{width:100%;height:100%;display:block;object-fit:cover}
@media(max-width:980px){
  .newsletter-grid{grid-template-columns:1fr}
  .newsletter-media{min-height:220px;order:-1}
  .newsletter-body{padding:22px}
  .clinic-gallery-photo{flex-basis:80vw;min-width:80vw;max-width:80vw;height:220px}
  .clinics-carousel .clinic-card{flex-basis:84vw;min-width:84vw;max-width:84vw}
  .reviews-grid--carousel .review-card{flex-basis:78vw;min-width:78vw;max-width:78vw}
  .contact.section{padding-top:54px;padding-bottom:54px}
  .contact-grid{gap:22px}
  .contact-text p{font-size:15px;line-height:1.6;max-width:unset;margin-bottom:18px}
  .contact-channels{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
  .contact-channel{min-height:56px;padding:12px 12px;gap:10px}
  .contact-channel-icon{width:36px;height:36px;border-radius:10px}
  .contact-channel-icon svg{width:18px;height:18px}
  .contact-channel-text{font-size:12px;line-height:1.2;white-space:normal;letter-spacing:0}
  .contact-channel-text span{font-size:10px;margin-top:2px;line-height:1.2}
  .contact-channel-wide{grid-column:1/-1}
  .equipment-card-media{height:220px}
  .clinic-card-media{height:220px}
  .equipment-showcase{grid-template-columns:1fr}
  .equipment-showcase-grid{grid-template-columns:minmax(0,1.1fr) minmax(200px,.9fr)}
  .equipment-showcase-media{height:280px}
  .equipment-showcase-title{font-size:25px}
  .equipment-showcase-desc{max-width:100%}
}

@media(max-width:560px){
  .contact.section{padding-top:44px;padding-bottom:44px}
  .contact-grid{gap:16px}
  .contact-text h2{font-size:clamp(22px,7.2vw,30px);margin-bottom:10px}
  .contact-text p{font-size:14px;line-height:1.55;margin-bottom:14px}
  .contact-channels{grid-template-columns:1fr;gap:8px}
  .contact-channel{padding:12px;gap:10px}
  .contact-channel-wide{grid-column:auto}
  .equipment-card-media{height:200px}
  .clinic-card-media{height:200px}
  .equipment-showcase-grid{grid-template-columns:1fr}
  .equipment-showcase-media{height:230px;object-position:center}
  .equipment-showcase-title{font-size:22px}
  .equipment-showcase-media{height:240px}
  .equipment-showcase-line{height:9px}
}

