/* 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;
  --section-muted:#eceaee;
  --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[hidden]{display:none !important}
.ld-modal-overlay.is-open{display:flex !important;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}
}

/* Bitrix web-form inside ld-modal */
.ld-modal-form--bitrix form{
  display:grid;
  gap:12px;
  margin:0;
}
.ld-modal-form--bitrix .form_block_title{display:none !important}
.ld-modal-form--bitrix input.text,
.ld-modal-form--bitrix select,
.ld-modal-form--bitrix textarea.inputtextarea{
  width:100%;
  min-height:46px;
  padding:12px 14px;
  border-radius:14px;
  border:1px solid var(--gray-200);
  background:#fff;
  font:inherit;
  outline:none;
  box-sizing:border-box;
}
.ld-modal-form--bitrix textarea.inputtextarea{min-height:96px;resize:vertical}
.ld-modal-form--bitrix input.text:focus,
.ld-modal-form--bitrix select:focus,
.ld-modal-form--bitrix textarea.inputtextarea:focus{
  border-color:rgba(155,38,168,.45);
  box-shadow:0 0 0 4px rgba(155,38,168,.12);
}
.ld-modal-form--bitrix input.text.is_error,
.ld-modal-form--bitrix select.is_error{border-color:rgba(220,38,38,.55)}
.ld-modal-form--bitrix .chb_label{
  display:grid;
  grid-template-columns:18px 1fr;
  gap:10px;
  align-items:start;
  font-size:13px;
  line-height:1.5;
  color:var(--gray-700);
  margin:0;
}
.ld-modal-form--bitrix .chb_label input{margin-top:2px;accent-color:var(--primary)}
.ld-modal-form--bitrix .chb_label a{color:var(--primary)}
.ld-modal-form--bitrix .submit.cta-link,
.ld-modal-form--bitrix input[type="submit"].submit{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:100%;
  min-height:48px;
  padding:12px 24px;
  border:0;
  border-radius:14px;
  background:var(--primary);
  color:#fff;
  font:inherit;
  font-weight:var(--fw-semibold);
  cursor:pointer;
}
.ld-modal-form--bitrix .submit.cta-link:disabled,
.ld-modal-form--bitrix input[type="submit"].submit:disabled{opacity:.55;cursor:not-allowed}
.ld-modal-form--bitrix .form-errors,
.ld-modal-form--bitrix .errortext{color:#b91c1c;font-size:13px}
.video-container iframe{width:100%;height:100%;border:0;border-radius:var(--radius-lg)}

/* 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:14px;
  line-height:1.65;
}
.service-hero .service-price,
.service-hero .service-cta{margin-top:2px !important}
.service-hero .service-meta{margin-top:8px}

/* Articles page hero — match redesign/articles.html */
.service-hero--articles{
  padding:0 0 24px;
  background:transparent;
}
.service-hero--articles .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);
  box-shadow:var(--shadow);
}
.service-hero--articles .service-hero-grid{grid-template-columns:1.12fr .88fr}
.service-hero--articles .service-hero-media{min-height:clamp(300px,34vw,400px)}
.service-hero--articles .service-hero-body{
  padding:36px clamp(22px,2.2vw,36px);
  gap:14px;
}
.service-hero--articles .service-badges{gap:10px;margin:0}
.service-hero--articles .service-title{
  margin-top:0;
  font-size:clamp(30px,3.4vw,44px);
  font-weight:var(--fw-semibold);
  line-height:1.1;
  letter-spacing:-.02em;
}
.service-hero--articles .section-subtitle{
  margin:10px 0 0;
  font-size:16px;
  line-height:1.65;
  color:var(--gray-500);
  max-width:52ch;
}
.service-hero--articles .service-price{
  margin-top:14px !important;
  align-items:flex-end;
  gap:16px;
}
.service-hero--articles .service-price .p{
  margin:0;
  font-size:14px;
  color:var(--gray-500);
  line-height:1.5;
}
.service-hero--articles .service-price .p b{
  display:block;
  font-size:clamp(22px,2.2vw,28px);
  font-weight:var(--fw-semibold);
  color:var(--black);
  letter-spacing:-.02em;
  margin-bottom:4px;
}
.service-hero--articles .service-price .p span{
  display:block;
  margin-top:0;
  font-size:14px;
  color:var(--gray-500);
}
.service-hero--articles .service-cta{gap:10px;flex-shrink:0}
@media(max-width:980px){
  .service-hero--articles .service-hero-grid{grid-template-columns:1fr}
  .service-hero--articles .service-hero-media{min-height:260px}
  .service-hero--articles .service-price{
    flex-direction:column;
    align-items:stretch;
  }
  .service-hero--articles .service-cta{display:flex;flex-wrap:wrap}
}

/* Unified cards style (clinics/reviews) */
.clinic-card,
.review-card{
  border-radius:var(--radius-lg);
  border:1px solid var(--gray-200);
  box-shadow:var(--shadow-sm);
}
.clinic-card:hover,
.review-card: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("./img/подарочный сертификат.jpg");
  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:0;
}
.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;
  flex-wrap:nowrap;
  align-items:stretch;
  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-embed-inline{
  margin-top:14px;
  max-width:860px;
  aspect-ratio:16/9;
  border-radius:var(--radius-lg);
  overflow:hidden;
  background:var(--gray-100);
}
.video-embed-inline iframe{
  display:block;
  width:100%;
  height:100%;
  border:0;
}
.video-story{
  flex:0 0 220px;
  max-width:220px;
  scroll-snap-align:start;
}
.video-story--large,
.video-story--featured{
  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;
  color:inherit;
  text-decoration:none;
}
.video-story-link--static{cursor:default}
.video-story-media{
  position:relative;
  border-radius:24px;
  height:clamp(320px,42vw,400px);
  padding-top:0;
  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:clamp(20px,3vw,32px) 0 clamp(8px,2vw,16px);
}
.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(135deg,rgba(var(--accent-rgb),.22),rgba(0,0,0,.04));
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
}
.service-promo-body{
  padding:22px 22px 20px;
  display:flex;
  flex-direction:column;
  gap:12px;
  min-width:0;
}
.service-promo-body .actions-hero-stats{margin-top: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;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
}
.service-promo-actions .btn{
  flex:0 0 auto;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:46px;
}
/* Icon-only buttons for promo secondary actions */
.btn.btn-icon{
  width:54px;
  height:54px;
  padding:0;
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
}
.service-promo-actions .btn.btn-icon{
  flex:0 0 54px;
  min-height:54px;
}
.btn.btn-icon svg{
  width:24px;
  height:24px;
  display:block;
}
.service-promo-actions .btn.btn-icon svg{
  stroke-width:1.75;
}
@media(min-width:981px){
  .service-promo-actions{
    flex-wrap:nowrap;
  }
}
@media(min-width:981px){
  .service-promo-actions .btn{
    min-height:54px;
  }
  .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;margin-bottom:4px}
.trust-chip p{margin:0;font-size:12px;line-height:1.55;color:var(--gray-600)}

/* 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;
}
/* 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}
  .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%}
  .js-articles-bar .js-articles-pagination .btn,
  .js-articles-bar .js-articles-pagination a.btn,
  .js-articles-bar .js-articles-pagination button.btn,
  .js-articles-bar .ld-articles-pagination .btn,
  .js-articles-bar .ld-articles-pagination a.btn,
  .js-articles-bar .ld-articles-pagination button.btn{width:auto!important}
  .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(--promo-bar-bg,var(--accent));
  color:var(--promo-bar-fg,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-bar--editor-off{opacity:.55;outline:2px dashed rgba(110,24,162,.45);outline-offset:-2px}
.promo-bar__off-badge{font-size:11px;font-weight:var(--fw-semibold);text-transform:uppercase;letter-spacing:.04em;opacity:.85}
.promo-bar__message{flex:0 1 auto;min-width:0;text-align:center}
.promo-bar__cta{flex-shrink:0;font-size:13px;padding:8px 18px;white-space:nowrap}
.promo-timer{display:inline-flex;gap:6px;font-weight:var(--fw-semibold);flex-shrink:0}
.promo-timer b{background:color-mix(in srgb, currentColor 14%, transparent);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:currentColor;font-size:1.2rem;opacity:.55;padding:4px;border:0;cursor:pointer;line-height:1}
.promo-close:hover{opacity:.9}
.ld-promo-bar-edit{
  background:#f8f4fb;
  border-bottom:1px solid #e0d8e8;
  padding:10px 20px;
  font-size:13px;
  line-height:1.45;
  color:#3d3648;
}
.ld-promo-bar-edit__title{font-weight:var(--fw-semibold);color:#6e18a2;margin-bottom:4px}
.ld-promo-bar-edit__hint{margin:0 0 10px;color:#6b6578;font-size:12px}
.ld-promo-bar-edit__hint code{font-size:11px}
.ld-promo-bar-edit__grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
  gap:8px 16px;
}
.ld-promo-bar-edit__field{display:flex;flex-direction:column;gap:4px;font-size:12px;color:#6b6578}
.ld-promo-bar-edit__value{font-size:14px;color:#1c2036}
.ld-menu-edit{display:none !important}
  margin:12px auto 0;max-width:var(--container,1200px);padding:14px 16px;
  border:1px dashed #c9b8e8;border-radius:12px;background:#faf8ff;
}
.ld-menu-edit__title{font-weight:var(--fw-semibold);color:#6e18a2;margin-bottom:4px}
.ld-menu-edit__hint{margin:0 0 10px;color:#6b6578;font-size:12px}
.ld-menu-edit__list{margin:0;padding-left:18px;font-size:13px;line-height:1.7}
.deals-layout--single{grid-template-columns:1fr!important}

/* ===== 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-image:
    linear-gradient(180deg, rgb(255 255 255 / 0%) 0%, rgb(255 255 255 / 0%) 55%, rgb(255 255 255 / 18%) 100%),
    url(/bitrix/templates/redesign_tpl/assets/about-clinic.jpg);
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
  filter:saturate(1.05) contrast(1.02);
}
.mega-promo.has-image[style*="--mega-promo-bg"]::before{
  background-image:
    linear-gradient(180deg, rgb(255 255 255 / 0%) 0%, rgb(255 255 255 / 0%) 55%, rgb(255 255 255 / 18%) 100%),
    var(--mega-promo-bg);
}
.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-tree{display:none;max-height:min(520px,58vh);overflow:auto;padding-right:4px}
.mega-services-tree.is-open{display:block}
.mega-services-quick{display:none}
.mega-services-quick.is-open{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);max-height:min(520px,58vh);overflow:auto}
.mega-services-results.is-open{display:block}
.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-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)}
.mega-services-pager{display:flex;align-items:center;justify-content:center;gap:12px;margin-top:12px;padding-top:12px;border-top:1px solid var(--gray-100)}
.mega-services-pager-btn{border:1px solid var(--gray-200);background:var(--white);border-radius:12px;padding:8px 14px;font-weight:var(--fw-semibold);cursor:pointer;font-size:13px}
.mega-services-pager-btn:hover:not(:disabled){background:var(--gray-50)}
.mega-services-pager-btn:disabled{opacity:.4;cursor:default}
.mega-services-pager-info{font-size:13px;color:var(--gray-500);font-weight:var(--fw-medium)}
.mega-services-empty{margin:0;padding:8px;color:var(--gray-500);font-size:14px}
.mega-tree-section-link{color:inherit;text-decoration:none}
.mega-tree-section-link: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:100%;transition:transform .28s cubic-bezier(.2,.8,.2,1);will-change:transform}
.mm-screen{flex:0 0 100%;min-width:0;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}
.mm-promo-stack{display:grid;gap:12px;margin-top:12px}
.mm-promo.has-image{position:relative;overflow:hidden;min-height:168px;display:flex;flex-direction:column;justify-content:flex-end}
.mm-promo.has-image::before{
  content:'';
  position:absolute;
  inset:0;
  background-image:
    linear-gradient(180deg,rgb(255 255 255 / 0%) 0%,rgb(255 255 255 / 0%) 55%,rgb(255 255 255 / 18%) 100%),
    url(/bitrix/templates/redesign_tpl/assets/about-clinic.jpg);
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
  filter:saturate(1.05) contrast(1.02);
}
.mm-promo.has-image[style*="--mega-promo-bg"]::before{
  background-image:
    linear-gradient(180deg,rgb(255 255 255 / 0%) 0%,rgb(255 255 255 / 0%) 55%,rgb(255 255 255 / 18%) 100%),
    var(--mega-promo-bg);
}
.mm-promo.has-image > *{position:relative;z-index:1}
@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('about-clinic.jpg') 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;overflow:hidden;flex-shrink:0}
.service-icon svg{width:30px;height:30px;color:var(--primary)}
.service-icon img{width:42px;height:42px;max-width:100%;max-height:100%;object-fit:contain;display:block}
.quiz-option .ld-icon-img,
.quiz-option img{
  display:block;
  margin:0 auto;
  width:100px;
  height:100px;
  object-fit:contain;
}
.ld-service-icon-placeholder{display:flex;align-items:center;justify-content:center;width:42px;height:42px;color:var(--primary)}
.ld-service-icon-placeholder svg{width:28px;height:28px;display:block}
.services-variant-a .service-card{
  display:flex;
  flex-direction:column;
  padding-top:92px;
  padding-bottom:28px;
  min-height:200px;
}
.services-variant-a .service-card-split{
  justify-content:flex-end;
  min-height:172px;
}
.services-variant-a .service-icon{
  position:absolute;
  top:28px;
  left:28px;
  margin:0;
  width:56px;
  height:56px;
}
.services-variant-a .service-icon .ld-icon-img--service,
.services-variant-a .service-icon img{
  width:42px;
  height:42px;
  margin:0;
  object-fit:contain;
}
.services-variant-a .service-card h3,
.services-variant-a .service-card p{width:100%}
.services-variant-a .service-link{
  margin-top:6px;
  align-self:flex-start;
}
.services-variant-a .service-link--push{
  margin-top:auto;
}
.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;margin-top: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:0;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:10px 0 0;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;
  padding:14px;
  box-sizing:border-box;
}
.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,
.service-hero-body .service-meta.actions-hero-stats{margin-top:0;margin-bottom:14px;padding-top:0}

/* Unified Bitrix pager (reviews, articles, actions, equipment) */
.ld-pager{
  margin-top:24px;
  justify-content:center;
}
.ld-pager .bx-pagination,
.ld-pager .pagination,
.ld-pager ul{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  align-items:center;
  justify-content:center;
  list-style:none;
  margin:0;
  padding:0;
}
.ld-pager .bx-pagination a,
.ld-pager .bx-pagination span,
.ld-pager .pagination a,
.ld-pager .pagination span,
.ld-pager li a,
.ld-pager li span{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:38px;
  min-height:38px;
  padding:8px 12px;
  border:1px solid var(--gray-200);
  border-radius:12px;
  font-size:13px;
  font-weight:var(--fw-medium);
  color:var(--black);
  background:var(--white);
  text-decoration:none;
  transition:var(--transition);
}
.ld-pager .bx-pagination a:hover,
.ld-pager .pagination a:hover,
.ld-pager li a:hover{
  border-color:rgba(var(--accent-rgb),.7);
  box-shadow:var(--shadow-sm);
}
.ld-pager .bx-pagination span.bx-active,
.ld-pager .pagination .active span,
.ld-pager li.active span{
  background:rgba(var(--accent-rgb),.18);
  border-color:rgba(var(--accent-rgb),.9);
}

/* Doctors pagination — unified with ld-pager-bar */
.doctors-pagination.ld-pager-bar{
  margin-top:18px;
  display:block;
  grid-template:none;
}
.doctors-pagination.ld-pager-bar .doctors-pagination-status{margin:0}
.doctors-pagination[hidden]{display:none !important}
.ld-page-breadcrumbs-wrap--top{padding-top:16px;padding-bottom:0}
.program-carousel-wrap{margin-top:8px}
.program-carousel-track{
  display:flex;
  gap:16px;
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  padding:4px 2px 12px;
  -webkit-overflow-scrolling:touch;
}
.program-card--carousel{
  flex:0 0 min(300px,85vw);
  scroll-snap-align:start;
}
.program-carousel-nav{margin-top:8px}
.doctors-page-numbers{display:flex;gap:8px;flex-wrap:nowrap;align-items:center;justify-content:center;max-width:100%;overflow-x:auto}
.doctors-page-ellipsis{padding:0 4px;color:var(--gray-500);font-size:13px;user-select:none}
.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-ellipsis{display:inline-flex;align-items:center;justify-content:center;min-width:28px;height:36px;padding:0 4px;color:var(--gray-500);font-size:14px;user-select:none;pointer-events:none}
.js-articles-bar.service-card{
  margin-top:18px;
  padding:12px 14px;
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  cursor:default;
  overflow:visible;
}
.js-articles-bar.service-card::before{display:none!important}
.js-articles-bar.service-card:hover{
  transform:none;
  box-shadow:var(--shadow-sm);
  border-color:var(--gray-200);
}
.js-articles-status,
.ld-articles-status{
  color:var(--gray-600);
  font-size:13px;
  flex:0 0 auto;
  margin:0;
}
.js-articles-pagination,
.ld-articles-pagination{
  display:flex;
  flex-direction:row;
  flex-wrap:nowrap;
  align-items:center;
  justify-content:flex-end;
  gap:10px;
  margin:0;
  padding:0;
  max-width:100%;
}
.js-articles-bar .js-articles-pagination .btn,
.js-articles-bar .js-articles-pagination a.btn,
.js-articles-bar .js-articles-pagination button.btn,
.js-articles-bar .ld-articles-pagination .btn,
.js-articles-bar .ld-articles-pagination a.btn,
.js-articles-bar .ld-articles-pagination button.btn{
  display:inline-flex!important;
  width:auto!important;
  max-width:none!important;
  flex:0 0 auto!important;
  margin:0!important;
  white-space:nowrap!important;
}
.js-articles-pagination .doctors-page-numbers,
.ld-articles-pagination .doctors-page-numbers{
  display:inline-flex;
  flex-direction:row;
  flex-wrap:nowrap;
  align-items:center;
  gap:8px;
  margin:0;
  overflow:visible;
  max-width:none;
  flex-shrink:0;
}
.js-articles-pagination .doctors-page-numbers[data-ld-server-pages] a.doctors-page-num,
.ld-articles-pagination .doctors-page-numbers[data-ld-server-pages] a.doctors-page-num{
  flex-shrink:0;
}
.js-articles-pagination .doctors-page-num,
.ld-articles-pagination .doctors-page-num{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  text-decoration:none;
  box-sizing:border-box;
}
.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{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:10px}  
.deals-grid{
  margin-top:22px;
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:16px;
}
.deals-grid-card{
  background:rgba(255,255,255,.92);
  min-height:100%;
  flex-direction:column;
}
.deals-grid-media{
  flex:0 0 auto;
  width:100%;
  min-height:190px;
  background-color:var(--gray-100);
  background-position:center;
  background-size:cover;
}
.deals-grid .offers-body{padding:16px;flex:1}
.deals-grid .offers-body h3{font-size:15px}
.deals-grid .offers-body p{font-size:12.5px}

@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))}
  .deals-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}
  .deals-grid{grid-template-columns:1fr}
  .deals-grid-media{min-height:190px}
}

.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{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{ }
.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-card--media{padding:0;overflow:hidden;min-height:280px}
.beauty-program .program-media{flex:0 0 auto;height:140px;min-height:140px;background:#f1f1f1 center/cover no-repeat;border-radius:var(--radius) var(--radius) 0 0}
.beauty-program .program-body{flex:1;display:flex;flex-direction:column;padding:18px;min-width:0}
.beauty-program .program-icon{display:none}
.cert-instruction{margin-top:16px;padding:16px;border-radius:var(--radius);border:1px solid var(--gray-200);background:var(--white)}
.cert-instruction-title{font-size:15px;font-weight:var(--fw-semibold);margin:0 0 10px}
#actionContent .service-card:hover,
.service-hero--articles .service-hero-card:hover{
  transform:none;
  box-shadow:var(--shadow-sm);
  border-color:var(--gray-200);
}
#actionContent .service-card:hover::before,
.service-hero--articles .service-hero-card:hover::before{
  transform:scaleX(0);
}
@media(max-width:768px){
  #doctorBio table,
  #doctorBio .ld-article-body table,
  #doctorBio td,
  #doctorBio th{font-size:11px}
}
.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(--white)}
.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)}
.ba-drag-hint{margin-top:6px;font-size:12px;color:var(--gray-400)}

/* BEFORE/AFTER page layout (before_after.html) */
.ba-page{display:grid;grid-template-columns:340px 1fr;gap:22px;align-items:start;margin-top:0}
.ba-main .ba-intro{max-width:none;margin-bottom:24px}
.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:16px;
}
.ba-sidebar-label{margin-bottom:12px}
.ba-filters-advanced{margin-top:12px;border:1px solid var(--gray-200);border-radius:14px;background:var(--gray-50)}
.ba-filters-advanced summary{
  padding:10px 12px;font-size:13px;font-weight:var(--fw-medium);color:var(--gray-700);cursor:pointer;list-style:none;
}
.ba-filters-advanced summary::-webkit-details-marker{display:none}
.ba-filters-advanced[open] summary{border-bottom:1px solid var(--gray-200)}
.ba-filters{display:grid;gap:8px;padding:10px 12px 12px}
.ba-filter-select,.ba-filters select{
  width:100%;padding:10px 12px;border:1px solid var(--gray-200);border-radius:12px;
  font:inherit;font-size:13px;background:var(--white);color:var(--gray-800)
}
.ba-empty{font-size:14px;color:var(--gray-600);line-height:1.5;padding:8px 0}
.ba-search{margin-top:0;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--end{justify-content:flex-end}
.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;
  cursor:pointer;
  transition:box-shadow .2s ease,border-color .2s ease;
}
.faq details:hover{border-color:rgba(var(--accent-rgb),.45)}
.faq details[open]{box-shadow:var(--shadow-sm);border-color:rgba(var(--accent-rgb),.35)}
.faq summary{cursor:inherit;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);
  transition:transform .2s ease;
}
.faq details[open] summary i{transform:rotate(45deg)}
.faq .a{margin-top:10px;color:var(--gray-600);font-size:13px;line-height:1.75}
.faq details:first-child{margin-top:0}

#process .service-grid-2{align-items:start}
#process .service-accordion.faq{margin-top:0}

.ld-article-body a,
.ld-article-body a.empty_button,
.ld-rich-well a{
  color:var(--primary);
  font-weight:var(--fw-semibold);
  text-decoration:underline;
  text-underline-offset:3px;
}
.ld-article-body a:hover{opacity:.85}

.service-advantages-grid{margin-top:18px;display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.service-advantage-card{padding:18px;border:1px solid var(--gray-200);border-radius:18px;background:var(--white)}
.service-advantage-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;overflow:hidden}
.service-advantage-ic img{width:100%;height:100%;object-fit:contain;display:block}
.service-advantage-title{margin-top:10px;font-size:16px;line-height:1.25;letter-spacing:-.2px;font-weight:var(--fw-semibold)}
.service-advantage-text{margin-top:8px;color:var(--gray-600);font-size:13px;line-height:1.7}
@media (max-width:980px){
  .service-advantages-grid{grid-template-columns:1fr}
}

.price-table tbody tr.price-row-hidden{display:none !important}
.price-table.is-price-expanded tbody tr.price-row-hidden{display:table-row !important}

.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;filter:none!important;-webkit-filter:none!important}
#clinicsMapFrame{filter:none!important;-webkit-filter:none!important}
.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-contact-meta{margin-top:16px;font-size:14px;line-height:1.5;color:var(--gray-500)}
.footer-contact-meta a{color:var(--black);font-weight:var(--fw-semibold);text-decoration:none}
.footer-contact-meta a:hover{color:var(--primary)}
.footer-legal{
  display:block;
  width:100%;
  clear:both;
  padding:20px 0 24px;
  margin-top:4px;
  color:var(--gray-500);
  border-bottom:1px solid var(--gray-100);
  box-sizing:border-box;
}
.footer-legal [id^="bx_incl_area"],
.footer-legal .footer-legal-text,
.footer-legal .bx-area{
  display:block;
  width:100%;
  max-width:100%;
  box-sizing:border-box;
  font-size:11px;
  line-height:1.65;
  font-weight:var(--fw-regular);
  color:var(--gray-500);
  letter-spacing:.01em;
}
/* Юридический текст подвала (CMS include + обёртка Bitrix #bx_incl_area_*) */
.footer-legal .footer-legal-text p,
.footer-legal-text p,
.footer-legal [id^="bx_incl_area"] p,
.footer-legal .bx-area p{
  font-size:11px;
  margin:0 0 10px;
  padding:0;
  max-width:none;
  line-height:1.65;
  color:var(--gray-500);
}
.footer-legal .footer-legal-text p:first-child,
.footer-legal-text p:first-child,
.footer-legal [id^="bx_incl_area"] p:first-child{
  margin-top:0;
}
.footer-legal .footer-legal-text p:last-child,
.footer-legal-text p:last-child,
.footer-legal [id^="bx_incl_area"] p:last-child{
  margin-bottom:0;
}
.footer-legal .footer-legal-text a,
.footer-legal-text a,
.footer-legal [id^="bx_incl_area"] a{
  color:var(--gray-500);
  text-decoration:underline;
  text-underline-offset:2px;
}
.footer-legal .footer-legal-text a:hover,
.footer-legal-text a:hover,
.footer-legal [id^="bx_incl_area"] a:hover{
  color:var(--gray-600);
}
/* Старый include: пустой блок Facebook в подвале */
.footer-legal .bx-eshop-facebook-plugin,
.footer-legal iframe,
.footer-legal table{display:none!important;height:0!important;overflow:hidden!important}
.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:start}
.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(--white)}
.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-text[data-ld-review-text],
.review-card-text[data-ld-review-text]{
  display:-webkit-box;
  -webkit-box-orient:vertical;
  -webkit-line-clamp:6;
  line-clamp:6;
  overflow:hidden;
}
[data-ld-review-card].is-review-expanded .review-text[data-ld-review-text],
[data-ld-review-card].is-review-expanded .review-card-text[data-ld-review-text]{
  -webkit-line-clamp:unset;
  line-clamp:unset;
  overflow:visible;
}
.review-expand-btn{
  margin-top:8px;
  padding:0;
  border:0;
  background:none;
  color:var(--primary);
  font-size:13px;
  font-weight:var(--fw-medium);
  cursor:pointer;
  text-decoration:underline;
  text-underline-offset:3px;
}
.review-expand-btn:hover{color:var(--primary-dark,#7a1f8a)}
.review-author-row{display:flex;align-items:flex-start;gap:12px;margin-top:auto}
.review-author-photo{width:40px;height:40px;border-radius:50%;object-fit:cover;flex:0 0 40px}
.review-author{font-size:14px;font-weight:var(--fw-semibold);color:var(--black)}
.review-meta{font-size:12px;color:var(--gray-500);margin-top:4px;line-height:1.4}
.review-date{font-size:12px;color:var(--gray-400);margin-top:4px}

/* ===== 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:none;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}
.license-lightbox-overlay{
  position:fixed;
  inset:0;
  z-index:3100;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:24px;
  background:rgba(17,24,39,.78);
  backdrop-filter:blur(8px);
}
.license-lightbox-overlay[hidden]{display:none !important}
.license-lightbox-img{
  max-width:min(92vw,900px);
  max-height:min(88vh,1200px);
  width:auto;
  height:auto;
  object-fit:contain;
  border-radius:var(--radius);
  box-shadow:var(--shadow-lg);
  background:var(--white);
}
.license-lightbox-close{
  position:absolute;
  top:16px;
  right:16px;
  width:44px;
  height:44px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.35);
  background:rgba(255,255,255,.12);
  color:#fff;
  font-size:28px;
  line-height:1;
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
}
.license-lightbox-close:hover{background:rgba(255,255,255,.22)}
@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}}

/* Карусель вариантов процедуры (subservices) */
#subservices .variants-carousel-wrap,
.variants-carousel-wrap{
  margin-top:18px;
  position:relative;
  width:100%;
  max-width:100%;
  min-width:0;
  overflow:hidden;
}
#subservices .variants-carousel,
.variants-carousel{
  display:flex !important;
  flex-direction:row !important;
  flex-wrap:nowrap !important;
  align-items:stretch;
  gap:16px;
  width:100%;
  max-width:100%;
  min-width:0;
  overflow-x:auto;
  overflow-y:hidden;
  padding:4px 4px 12px;
  scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
}
#subservices .variants-carousel::-webkit-scrollbar,
.variants-carousel::-webkit-scrollbar{display:none}
#subservices .variants-carousel > .variants-carousel-card,
#subservices .variants-carousel > a.service-card,
.variants-carousel > .variants-carousel-card,
.variants-carousel > .service-card,
.variants-carousel > a.service-card{
  flex:0 0 300px !important;
  min-width:300px !important;
  max-width:300px !important;
  width:300px !important;
  scroll-snap-align:start;
  text-decoration:none;
  color:inherit;
  display:block;
  box-sizing:border-box;
}
#subservices .variants-carousel-text,
.variants-carousel-text{margin-top:8px;color:var(--gray-600);font-size:13px;line-height:1.55}
#subservices .ba-carousel-nav{display:flex;gap:10px;margin-top:10px}
@media(max-width:1024px){
  #subservices .variants-carousel > .variants-carousel-card,
  #subservices .variants-carousel > a.service-card,
  .variants-carousel > .variants-carousel-card,
  .variants-carousel > .service-card,
  .variants-carousel > a.service-card{
    flex-basis:280px !important;
    min-width:280px !important;
    max-width:280px !important;
    width:280px !important;
  }
}
@media(max-width:560px){
  #subservices .variants-carousel > .variants-carousel-card,
  #subservices .variants-carousel > a.service-card,
  .variants-carousel > .variants-carousel-card,
  .variants-carousel > .service-card,
  .variants-carousel > a.service-card{
    flex-basis:86vw !important;
    min-width:86vw !important;
    max-width:86vw !important;
    width:86vw !important;
  }
}
/* legacy alias */
.variants-scroll{display:flex;gap:16px;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 300px;min-width:300px;max-width:300px;scroll-snap-align:start}

/* ===== ACTIONS / DOCTORS custom select ===== */
.actions-select,.doctors-select,.ba-select{display:none}
.actions-filters,
.doctors-filters{
  margin-top:14px;
  display:grid;
  grid-template-columns:minmax(0,1.2fr) minmax(0,.8fr) minmax(0,.8fr) auto auto;
  gap:10px;
  align-items:center;
  width:100%;
  min-width:0;
}
.actions-filters--search-only{
  grid-template-columns:minmax(0,1fr) auto auto;
}
.actions-filters--4col{
  grid-template-columns:minmax(0,1.2fr) minmax(0,.8fr) auto auto;
}
.doctors-filters{
  grid-template-columns:minmax(0,1.2fr) minmax(0,.8fr) auto auto;
}
.ld-reviews-filters .ld-reviews-filter-form{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr)) auto;
  gap:10px;
  align-items:center;
  width:100%;
  min-width:0;
}
.ld-filter-submit{
  min-width:96px;
  justify-content:center;
  white-space:nowrap;
}
.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-filters--search-only{grid-template-columns:1fr}
  .actions-search,
  .doctors-search{grid-column:1 / -1}
  .actions-clear,
  .doctors-clear{grid-column:1 / -1}
  .ld-reviews-filters .ld-reviews-filter-form{grid-template-columns:1fr 1fr}
  .ld-filter-submit{width:100%}
}
@media(max-width:640px){
  .doctors-filters,
  .actions-filters{grid-template-columns:1fr}
  .ld-reviews-filters .ld-reviews-filter-form{grid-template-columns:1fr}
  .doctors-filters .doctors-clear,
  .actions-filters .actions-clear,
  .actions-filters--search-only .ld-filter-submit{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;
    padding-bottom:24px;
    min-height:0;
  }
  .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__message{flex:1 1 100%;line-height:1.25;width:100%}
  .promo-timer{gap:4px}
  .promo-timer b{min-width:20px}
}

/* Крошки внутри hero / обёртки ui-страниц */
.ld-page-breadcrumbs-wrap{
  padding-top:0px;
  padding-bottom:4px;
}
.ld-page-breadcrumbs-wrap .breadcrumbs,
.ld-page-breadcrumbs-wrap nav.breadcrumbs{
  margin-top:0;
  margin-bottom:0;
}

/* ===== BREADCRUMBS (все внутренние страницы редизайна) ===== */
.breadcrumbs,
nav.breadcrumbs{
  color:var(--gray-500);
  font-size:13px;
  height:auto;
  min-height:30px;
  margin-top:0;
  padding:0;
  line-height:1.4;
  max-width:100%;
  overflow:visible;
  text-align:left;
  white-space:normal;
  border:0;
}
.breadcrumbs a{color:var(--gray-600)}
.breadcrumbs span{color:var(--gray-400)}
.breadcrumbs .row{
  display:flex;
  flex-wrap:wrap;
  gap:6px 8px;
  align-items:center;
  max-width:100%;
  min-width:0;
  height:100%;
  padding-left: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,
  nav.breadcrumbs{
    margin-top:0;
    min-height:28px;
    line-height:1.35;
  }
}

/* ===== SERVICE HERO + SUBNAV + PRICES (service.html) ===== */
.service-hero{padding:0 0 clamp(16px,3vw,24px) 0}
.service-hero.service-hero--articles{padding:0 0 24px}
.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 1fr 1fr}
.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}
.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:12px 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}
.ld-page-section[id]{scroll-margin-top:120px}
.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:760;
  margin-top:12px;
}
.service-subnav .bar{
  border:1px solid var(--gray-200);
  background:rgba(255,255,255,.88);
  backdrop-filter:blur(12px);
  border-radius:999px;
  box-shadow:0 12px 30px rgba(21,27,48,.08);
  overflow:hidden;
  pointer-events:auto;
}
.service-subnav .items{
  display:flex;
  flex-wrap:nowrap;
  gap:6px;
  padding:6px;
  overflow-x:auto;
  overscroll-behavior-x:contain;
  scrollbar-width:none;
  -webkit-overflow-scrolling:touch;
}
.service-subnav .items::-webkit-scrollbar{display:none}
.service-subnav a{
  flex:0 0 auto;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:40px;
  padding:9px 13px;
  border-radius:999px;
  font-size:13px;
  font-weight:var(--fw-medium);
  color:var(--gray-600);
  text-decoration:none;
  white-space:nowrap;
  transition:background .15s ease,color .15s ease,box-shadow .15s ease;
}
.service-subnav a:hover,
.service-subnav a.is-active{
  background:rgba(var(--accent-rgb),.18);
  color:var(--black);
  box-shadow:inset 0 0 0 1px rgba(var(--accent-rgb),.26);
}
@media(max-width:768px){
  .service-subnav{
    top:calc(62px + var(--vv-top, 0px));
    margin:0;
    padding:6px 0;
    background:rgba(247,245,249,.94);
    backdrop-filter:blur(12px);
    pointer-events:auto;
  }
  .service-subnav .container{padding-left:0;padding-right:0;max-width:none}
  .service-subnav .bar{border:0;border-radius:0;background:transparent;box-shadow:none;overflow:visible}
  .service-subnav .items{gap:8px;max-height:none;overflow-x:auto;overflow-y:hidden;padding:4px 16px 6px}
  .service-subnav a{min-height:40px;padding:9px 14px;border:1px solid rgba(21,27,48,.10);background:#fff;box-shadow:0 8px 18px rgba(21,27,48,.06);font-size:13px;font-weight:600;line-height:1}
  .service-subnav a.is-active{box-shadow:0 10px 24px rgba(var(--accent-rgb),.14)}
}
@media(min-width:981px){
  .service-subnav .items{width:100%;justify-content:flex-start}
}

/* Service content grids (about/process blocks) */
.service-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.services-catalog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;margin-top: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-contra-note{margin-top:12px;color:var(--gray-600);font-size:13px}
.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,
#contra .service-card,
#advantages .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,
#contra .service-card::before,
#advantages .service-card::before{display:none !important}
#about .service-card:hover,
#process .service-card:hover,
#contra .service-card:hover,
#advantages .service-card:hover{transform:none;box-shadow:var(--shadow-sm);border-color:var(--gray-200)}

#faq .service-faq-list.faq{margin-top:14px}

.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 tbody tr:hover{background: #dfdff0;}
.price-table tbody tr.is-hidden{display:none}

.price-table tfoot tr,
.price-table tfoot tr:hover{background:#fff}
.price-table tfoot td{
  padding:10px 14px;
  background:#fff;
  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 !important}
  .price-cards{display:block !important}
  #pricesBlock .price-cards:not(:empty) ~ .price-table{display:none !important}
  #pricesBlock .price-cards:empty{display:none !important}
  #pricesBlock .price-cards:empty ~ .price-table{display:block !important}
}
.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: BA-like parent service navigator */
.ld-prices-layout{display:grid;grid-template-columns:340px minmax(0,1fr);gap:22px;align-items:start}
.ld-prices-sidebar{position:sticky;top:calc(74px + var(--vv-top, 0px));z-index:800}
.ld-prices-sidebar-card{
  border:1px solid var(--gray-200);
  background:var(--white);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-sm);
  padding:16px;
}
.ld-prices-sidebar-label{margin-bottom:12px}
.ld-prices-parent-search{margin-bottom:12px}
.ld-prices-clinic-select{
  margin-top:12px;
  padding:12px;
  border:1px solid var(--gray-200);
  border-radius:14px;
  background:var(--gray-50);
}
.ld-prices-clinic-select label{
  display:block;
  margin-bottom:8px;
  color:var(--gray-600);
  font-size:13px;
  line-height:1.4;
}
.ld-prices-clinic-select label span{display:block;color:var(--black);font-weight:var(--fw-semibold)}
.ld-prices-clinic-select select{
  width:100%;
  min-width:0;
  border:1px solid var(--gray-200);
  border-radius:12px;
  padding:10px 12px;
  font:inherit;
  font-size:13px;
  background:var(--white);
}
.ld-prices-filters{margin-top:12px}
.ld-prices-parent-list{max-height:430px;width:100%;padding:0;margin-top:12px}
.ld-prices-parent-item{
  width:100%;
  max-width:100%;
  box-sizing:border-box;
  appearance:none;
  border:none;
  font:inherit;
  cursor:pointer;
}
.ld-prices-filters select,
.ld-prices-clinic-select select{
  display:block;
  width:100%;
  max-width:none;
  min-width:0;
  padding:11px 36px 11px 12px;
  border:1px solid var(--gray-200);
  border-radius:14px;
  background-color:var(--white);
  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;
  background-size:12px 12px;
  -webkit-appearance:none;
  appearance:none;
  font:inherit;
  font-size:13px;
}
.ld-prices-parent-item[hidden],
.ld-prices-parent-panel[hidden],
.ld-prices-group[hidden],
.ld-prices-table tr[hidden]{display:none !important}
.ld-prices-main{min-width:0}
.ld-prices-parent-panel{display:grid;gap:14px}
.ld-prices-main-head{
  padding:0;
  border:none;
  border-radius:0;
  background:transparent;
  box-shadow:none;
}
.ld-prices-main-head .meta{color:var(--gray-500);font-size:13px}
.ld-prices-table-card{
  border:1px solid var(--gray-200);
  border-radius:var(--radius-lg);
  background:var(--white);
  box-shadow:var(--shadow-sm);
  padding:18px;
}
.ld-prices-group + .ld-prices-group{margin-top:18px}
.ld-prices-group h4{
  display:flex;
  align-items:baseline;
  justify-content:space-between;
  gap:12px;
  margin:0 0 10px;
  font-size:16px;
  font-weight:var(--fw-semibold);
  letter-spacing:-.2px;
}
.ld-prices-group h4 span{font-size:13px;color:var(--gray-600);font-weight:var(--fw-medium);white-space:nowrap}
.ld-prices-table.price-table{border-radius:16px}
.ld-prices-table table{min-width:620px}
.ld-prices-table th:last-child,
.ld-prices-table td:last-child{text-align:right;white-space:nowrap}
.ld-prices-empty{margin-top:10px}
.ld-prices-parent-note{margin-top:0}
.prices-accordion{display:grid;gap:10px;margin-top:16px}
.ld-prices-main .prices-accordion{margin-top:0}
.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{
  list-style:none;
  display:grid;
  grid-template-columns:minmax(0,1fr) 24px;
  align-items:center;
  gap:12px;
  cursor:pointer;
}
.prices-acc-l2 > summary{
  list-style:none;
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(100px,auto) 24px;
  align-items:center;
  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-acc-l2-from{
  text-align:right;
  white-space:nowrap;
  font-size:13px;
  color:var(--gray-600);
}
.prices-rows{margin-top:10px;display:grid}
.prices-row{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(100px,auto);
  align-items:center;
  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;min-width:0}
.prices-row b{white-space:nowrap;font-size:13px;text-align:right}
.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}

@media(max-width:980px){
  .ld-prices-layout{grid-template-columns:1fr}
  .ld-prices-sidebar{position:static;top:auto}
  .ld-prices-parent-list{max-height:320px}
  .ld-prices-table-card{padding:14px}
}

.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{
  width:100%;
  max-width:none;
  box-sizing:border-box;
  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.ld-subscribe-wrap .container{width:100%;max-width:var(--container)}
@media (max-width:1024px){
  body.home-hero-header section.newsletter.ld-subscribe-wrap .container{padding:0}
}
.newsletter.ld-subscribe-wrap .ld-subscribe-embed .subscribe,
.newsletter.ld-subscribe-wrap .ld-subscribe-embed #subscribe_block,
.newsletter.ld-subscribe-wrap .ld-subscribe-embed .in-wrap{
  max-width:none !important;
  width:100% !important;
  margin:0 !important;
  padding:0 !important;
}
.newsletter-grid{display:grid;grid-template-columns:1.05fr .95fr;min-width:0;width:100%}
.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-form input.date-mask{min-width:140px}
.newsletter-note{margin-top:10px;color:var(--gray-500);font-size:12px;line-height:1.55;max-width:64ch}
.newsletter-success{padding:12px 14px;background:#f0fdf4;color:#166534;border-radius:8px;font-size:14px}

/* Make newsletter card "feel wider" with generous internal space on redesign pages (matches prototype padding and fill) */
.newsletter-body{padding:28px 28px 26px}
.newsletter-form .newsletter-field input,
.newsletter-form .newsletter-field .date-mask { min-height:46px; }
.ld-subscribe-embed .newsletter-form .newsletter-note,
.newsletter-form .newsletter-note{grid-column:1 / -1; width:100%; max-width:none;}
.newsletter-media{
  position:relative;
  min-height:280px;
  overflow:hidden;
  border-radius:0 var(--radius-xl) var(--radius-xl) 0;
  background-position:center center !important;
  background-size:cover !important;
  background-repeat:no-repeat !important;
  background:
    linear-gradient(135deg, rgba(0,0,0,.10), rgba(0,0,0,0)),
    url('./img/новости,_акции_и_ползные_материалы.jpg') center/cover no-repeat,
    url('about-clinic.jpg') center/cover no-repeat;
}

/* New pages utilities */
.service-hero-media--reviews{background-image:url('about-clinic.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{/* фон из SLIDESHOW[0] в redesign_clinic_detail */}
.service-hero-media--vacancies{background-image:url('./img/vacancies.html.jpg')}
.service-hero-media--equipment{background-color:#e8e8ee}
.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-hero-media--articles{background-image:url('about-clinic.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:flex;
  flex-direction:column;
  gap:0;
}
.equipment-showcase-item{
  background:transparent;
  border:none;
  border-radius:0;
  padding:0 0 4px;
  box-shadow:none;
}
.equipment-showcase-item:hover{
  border-color:transparent;
  box-shadow:none;
  transform: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%;
  display:-webkit-box;
  -webkit-box-orient:vertical;
  -webkit-line-clamp:8;
  line-clamp:8;
  overflow:hidden;
}
.equipment-showcase-grid{align-items:start}
.equipment-showcase-media{
  width:100%;
  height:320px;
  object-fit:contain;
  object-position:center bottom;
}
.equipment-showcase-media--empty{
  min-height:320px;
  background:linear-gradient(180deg,rgba(var(--accent-rgb),.04) 0%,transparent 72%);
}
.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;border-radius:var(--radius-xl) var(--radius-xl) 0 0}
  .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{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}
}

/* redesign-home-fullwidth-v3 — только home-секции на всю ширину; ld-page-section использует .container */
body.home-hero-header main.page > section#quiz,
body.home-hero-header main.page > section.quiz.ld-home-section,
body.home-hero-header main.page > section.ld-home-section,
body.home-hero-header main.page > section.clinics,
body.home-hero-header main.page > section.beauty-program,
body.home-hero-header main.page > section.before-after,
body.home-hero-header main.page > section.contact,
body.home-hero-header main.page > section.reviews:not(.ld-page-section),
body.home-hero-header main.page > section.articles:not(.ld-page-section),
body.home-hero-header main.page > section.newsletter {
  max-width: none !important;
  width: 100% !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
}

body.home-hero-header main.page > section.ld-page-section {
  max-width: none !important;
  width: 100% !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  padding-left: 0;
  padding-right: 0;
  box-sizing: border-box;
}
body.home-hero-header main.page > section.ld-page-section > .container {
  max-width: var(--container);
  margin-left: auto;
  margin-right: auto;
  width: 100%;
  box-sizing: border-box;
}

/* Service page: unified vertical rhythm + explicit surface bands */
body.home-hero-header main.page > section.ld-page-section.section {
  padding-block: clamp(48px, 6vw, 72px);
}
body.home-hero-header main.page > section.ld-section-surface--plain {
  background: transparent;
}
body.home-hero-header main.page > section.ld-section-surface--white {
  background: var(--white);
  border-top: 1px solid var(--gray-200);
}
body.home-hero-header main.page > section.ld-section-surface--muted {
  background: var(--section-muted);
  border-top: 1px solid var(--gray-200);
}
body.home-hero-header main.page > section.ld-section-surface--accent {
  background: rgba(var(--accent-rgb), .08);
  border-top: 1px solid var(--gray-200);
}
body.home-hero-header main.page > section.ld-page-section.service-hero.section {
  padding-block: 0 clamp(16px, 3vw, 24px);
  background: transparent;
  border-top: none;
}
body.home-hero-header main.page > section.ld-page-section.service-promo-top {
  padding-block: clamp(20px, 3vw, 32px) clamp(8px, 2vw, 16px);
}
body.home-hero-header main.page > section.ld-page-section.video-stories {
  padding-block: clamp(48px, 6vw, 72px);
  margin-bottom: 0;
}

.ld-section-page-title { margin: 0 0 18px; }
.service-section-groups { display: grid; gap: 20px; margin-top: 12px; }
.service-section-group {
  padding: clamp(16px, 3vw, 24px);
  border: 1px solid var(--gray-200);
  border-radius: 16px;
  background: var(--white);
  box-shadow: var(--shadow-sm);
}
.service-section-group-title { margin: 0 0 14px; font-size: 20px; letter-spacing: -.02em; }
.service-section-group-title a { color: inherit; text-decoration: none; }
.service-section-group-title a:hover { color: var(--primary); }
.service-links-grid { display: flex; flex-wrap: wrap; gap: 12px; }
.service-link-chip {
  display: inline-flex;
  align-items: center;
  padding: 10px 16px;
  border-radius: 999px;
  border: 1px solid var(--gray-200);
  background: var(--gray-50);
  color: var(--gray-800);
  text-decoration: none;
  font-size: 14px;
  line-height: 1.35;
  transition: var(--transition);
}
.service-link-chip:hover {
  border-color: rgba(var(--accent-rgb), .55);
  color: var(--primary);
  background: var(--white);
  box-shadow: var(--shadow-sm);
}
.ld-service-section-grid { margin-top: 12px; }
.ld-service-section-grid .service-card {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 12px;
  min-height: 120px;
  padding: 20px 22px;
  text-decoration: none;
  color: inherit;
  border: 1px solid var(--gray-200);
  border-radius: 16px;
  background: var(--white);
  box-shadow: var(--shadow-sm);
  transition: var(--transition);
}
.ld-service-section-grid .service-card:hover {
  border-color: rgba(var(--accent-rgb), .45);
  box-shadow: var(--shadow);
  transform: translateY(-2px);
}
.service-card-more { color: var(--primary); font-weight: var(--fw-semibold); font-size: 14px; }
.ld-section-description { margin-top: 0; }

.ld-pager-bar {
  margin-top: 18px;
  padding: 12px 14px;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.ld-pager-bar .ld-articles-status { color: var(--gray-600); font-size: 13px; margin: 0; }
.ld-pager-bar .ld-articles-pagination {
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
  margin: 0;
}
.ld-pager-bar .ld-articles-pagination .btn { width: auto; }
.ld-pager-bar .ld-articles-pages {
  display: inline-flex;
  flex-wrap: nowrap;
  align-items: center;
  gap: 8px;
  margin: 0;
  overflow: visible;
  max-width: none;
}

#ldModalOverlay .ld-modal-form--bitrix form,
#ldModalOverlay .ld-modal-form.ld-modal-form--bitrix form {
  display: grid !important;
  gap: 12px;
  width: 100%;
  margin: 0;
}
#ldModalOverlay .ld-modal-form--bitrix input.text,
#ldModalOverlay .ld-modal-form--bitrix select,
#ldModalOverlay .ld-modal-form--bitrix textarea.inputtextarea {
  display: block !important;
  width: 100% !important;
  box-sizing: border-box;
}
#ldModalOverlay .ld-modal-form--bitrix .ld-modal-consents {
  display: block;
  width: 100%;
  min-width: 0;
  font-size: 13px;
  line-height: 1.55;
  color: var(--gray-700);
}
#ldModalOverlay .ld-modal-form--bitrix .ld-modal-consents .chb {
  float: left;
  margin: 3px 10px 0 0;
}
#ldModalOverlay .ld-modal-form--bitrix .ld-modal-consents .chb_label {
  display: block;
  overflow: hidden;
  min-width: 0;
  word-break: normal;
  font-weight: var(--fw-regular);
}
#ldModalOverlay .ld-modal-form--bitrix .ld-modal-consents .chb_label span { display: inline; }
#ldModalOverlay .ld-modal-form--bitrix .ld-modal-consents a { color: var(--primary); }
#ldModalOverlay .ld-modal-form--bitrix .submit.cta-link,
#ldModalOverlay .ld-modal-form--bitrix input[type="submit"].submit {
  appearance: none;
  -webkit-appearance: none;
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  width: 100% !important;
  min-height: 48px;
  padding: 12px 24px;
  border: 0;
  border-radius: 14px;
  background: var(--primary);
  color: #fff;
  font: inherit;
  font-weight: var(--fw-semibold);
  cursor: pointer;
}
#ldModalOverlay .ld-modal-form--bitrix .form_block_title { display: none !important; }

/* CMS booking CTA from content manager */
.ld-rich-content a.main_button,
.content_zone a.main_button,
.ld-section-description a.main_button,
.ld-service-detail-wrap a.main_button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  margin: 16px 0;
  padding: 14px 32px;
  border: none;
  border-radius: var(--pill);
  background: var(--primary);
  color: var(--black);
  font-weight: var(--fw-semibold);
  font-size: 15px;
  line-height: 1.2;
  text-decoration: none;
  box-shadow: 0 4px 20px rgba(0,0,0,.12);
  cursor: pointer;
  transition: var(--transition);
  white-space: nowrap;
}
.ld-rich-content a.main_button:hover,
.content_zone a.main_button:hover,
.ld-section-description a.main_button:hover,
.ld-service-detail-wrap a.main_button:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 32px rgba(0,0,0,.16);
  color: var(--black);
  text-decoration: none;
}

/* Rich CMS content wells (service sections, articles) */
.ld-rich-well {
  margin-top: 40px;
  padding: clamp(20px, 4vw, 36px);
  border: 1px solid var(--gray-200);
  border-radius: 16px;
  background: var(--gray-50);
}
.ld-rich-content { font-size: 16px; line-height: 1.7; color: var(--gray-800); }
.ld-rich-content > :first-child { margin-top: 0; }
.ld-rich-content > :last-child { margin-bottom: 0; }
.ld-rich-content p { margin: 0 0 1em; }
.ld-rich-content ul,
.ld-rich-content ol { margin: 0 0 1em; padding-left: 1.4em; }
.ld-rich-content li { margin-bottom: .35em; }
.ld-rich-content img {
  max-width: 100%;
  height: auto;
  border-radius: 12px;
}
.ld-rich-content h2,
.ld-rich-content h3 {
  margin: 1.4em 0 .6em;
  font-size: clamp(20px, 2.5vw, 26px);
  line-height: 1.25;
  color: var(--black);
}
.ld-rich-content [style*="background"],
.ld-rich-content .ld-callout {
  margin: 1.2em 0;
  padding: 14px 18px;
  border-radius: 12px;
  background: rgba(var(--accent-rgb), .1) !important;
  border: 1px solid rgba(var(--accent-rgb), .2);
}
.ld-rich-content::after { content: ""; display: table; clear: both; }

/* Legacy Bitrix blocks inside redesign shell */
.ld-service-detail-wrap,
.ld-clinic-detail-wrap,
.ld-prices-legacy-wrap,
.ld-certificates-wrap,
.ld-services-catalog-wrap,
.ld-clinics-legacy-wrap,
.ld-before-after-legacy-wrap,
.ld-reviews-legacy-wrap {
  max-width: 100%;
}
.ld-page-section + .ld-service-detail-wrap {
  margin-top: 0;
}
.ld-legacy-wrap .content_block,
.ld-service-detail-wrap .content_block,
.ld-clinic-detail-wrap .content_block,
.ld-prices-legacy-wrap .content_block {
  padding: 0;
  background: transparent;
  border: none;
}

/* Legacy price_list → визуально как prices-accordion из прототипа */
.prices-accordion-shell .price_list_block{background:transparent;border:none;box-shadow:none}
.prices-accordion-shell .price_list_block_container{margin-bottom:16px}
.prices-accordion-shell .price_list_block_select label{font-size:14px;color:var(--gray-600)}
.prices-accordion-shell .price_list_block_select select,
.prices-accordion-shell .price_list_block_search .input{
  border:1px solid var(--gray-200);border-radius:var(--radius);padding:10px 12px;font:inherit;min-width:200px
}
.prices-accordion-shell .price_list_block_item{
  border:1px solid var(--gray-200);border-radius:var(--radius-lg);margin-bottom:10px;background:var(--white);overflow:hidden
}
.prices-accordion-shell .price_list_item_header{
  padding:16px 18px;cursor:pointer;font-weight:var(--fw-semibold);font-size:16px;display:flex;align-items:center;justify-content:space-between
}
.prices-accordion-shell .price_list_item_header::after{content:'+';color:var(--primary);font-size:20px;line-height:1}
.prices-accordion-shell .price_list_item_header.opened::after{content:'−'}
.prices-accordion-shell .price_list_item_body{padding:0 18px 16px}
.prices-accordion-shell .price_list_block_search_result_table .row.th{font-weight:var(--fw-semibold);border-bottom:1px solid var(--gray-200)}
.prices-accordion-shell .price_list_block_search_result_table .row{padding:10px 0;border-bottom:1px solid var(--gray-100)}
/* redesign_price_list: grid из блока выше, не flex legacy */
.prices-accordion-shell .prices-row{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(100px,auto);
  align-items:center;
  gap:12px;
  flex-wrap:unset;
}
.prices-accordion-shell .prices-acc-l2 > summary{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(100px,auto) 24px;
  align-items:center;
  gap:12px;
}
.prices-accordion-shell .prices-row span{min-width:0}
.prices-accordion-shell .prices-row b{text-align:right;white-space:nowrap}
.prices-accordion-shell .prices-acc-l2-from{text-align:right;white-space:nowrap}
.prices-accordion-shell .price_list_block_search_result_table .row{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(100px,auto);
  align-items:center;
  gap:12px;
  flex-wrap:unset;
}
.prices-help-card{
  margin-top:24px;padding:20px;border-radius:var(--radius-lg);border:1px solid var(--gray-200);
  display:flex;flex-wrap:wrap;gap:16px;align-items:center;justify-content:space-between
}
.prices-help-title{font-weight:var(--fw-semibold);margin-bottom:4px}
.prices-help-sub{font-size:14px;color:var(--gray-600)}
.prices-help-actions{display:flex;gap:10px;flex-wrap:wrap}

/* Прайс: раскладка родительских разделов */
.prices-accordion-shell .ld-prices-component.ld-prices-layout{
  display:grid !important;
  grid-template-columns:minmax(300px,360px) minmax(0,1fr) !important;
  gap:24px !important;
  align-items:start !important;
}
.prices-accordion-shell .ld-prices-component .ld-prices-sidebar{position:sticky !important;top:calc(82px + var(--vv-top,0px)) !important}
.prices-accordion-shell .ld-prices-component .ld-prices-sidebar-card,
.prices-accordion-shell .ld-prices-component .ld-prices-main-head,
.prices-accordion-shell .ld-prices-component .ld-prices-table-card,
.prices-accordion-shell .ld-prices-component .ld-prices-parent-note{
  border:1px solid var(--gray-200) !important;
  border-radius:24px !important;
  background:#fff !important;
  box-shadow:0 18px 42px rgba(21,27,48,.07) !important;
}
.prices-accordion-shell .ld-prices-component .ld-prices-sidebar-card{padding:18px !important}
.prices-accordion-shell .ld-prices-component .ld-prices-main-head{display:flex !important;align-items:flex-end !important;justify-content:space-between !important;gap:16px !important;padding:18px 20px !important}
.prices-accordion-shell .ld-prices-component .ld-prices-table-card{padding:18px !important}
.prices-accordion-shell .ld-prices-component .ld-prices-parent-note{display:block !important;margin:0 !important;padding:18px 20px !important}
.prices-accordion-shell .ld-prices-component .ld-prices-parent-list{display:flex !important;flex-direction:column !important;gap:8px !important;max-height:min(520px,calc(100vh - 320px)) !important;overflow:auto !important}
.prices-accordion-shell .ld-prices-component .ld-prices-parent-item{display:grid !important;grid-template-columns:minmax(0,1fr) auto !important;align-items:center !important;width:100% !important;padding:12px 13px !important;border:1px solid var(--gray-200) !important;border-radius:16px !important;background:#fff !important;text-align:left !important}
.prices-accordion-shell .ld-prices-component .ld-prices-parent-item.is-active{background:rgba(var(--accent-rgb),.16) !important;border-color:rgba(var(--accent-rgb),.55) !important}
.prices-accordion-shell .ld-prices-component .price-table.ld-prices-table{display:block !important;overflow:auto !important;border:1px solid var(--gray-200) !important;border-radius:18px !important;background:#fff !important}
.prices-accordion-shell .ld-prices-component .ld-prices-table table{width:100% !important;min-width:640px !important;border-collapse:separate !important;border-spacing:0 !important}
.prices-accordion-shell .ld-prices-component .ld-prices-table th,
.prices-accordion-shell .ld-prices-component .ld-prices-table td{padding:13px 16px !important;border-bottom:1px solid var(--gray-100) !important;font-size:14px !important;line-height:1.35 !important}
.prices-accordion-shell .ld-prices-component .ld-prices-table th:last-child,
.prices-accordion-shell .ld-prices-component .ld-prices-table td:last-child{text-align:right !important;white-space:nowrap !important;width:160px !important}
.prices-accordion-shell .ld-prices-component .ld-prices-clinic-select select,
.prices-accordion-shell .ld-prices-component .ld-prices-filters select{max-width:none !important;width:100% !important;min-width:0 !important}
@media(max-width:980px){
  .prices-accordion-shell .ld-prices-component.ld-prices-layout{grid-template-columns:1fr !important}
  .prices-accordion-shell .ld-prices-component .ld-prices-sidebar{position:static !important;top:auto !important}
  .prices-accordion-shell .ld-prices-component .price-table.ld-prices-table{display:block !important}
  .prices-accordion-shell .ld-prices-component .ld-prices-table table{min-width:560px !important}
}
.ld-legacy-wrap .actions_filter select,
.ld-reviews-filters select {
  min-width: 160px;
}
.ld-reviews-pager {
  margin-top: 24px;
  text-align: center;
}
.review-card--negative {
  border-color: #fecaca;
}
.visually-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* Clinic detail (legacy shell inside redesign) */
.clinic-detail-page .clinic-card-block {
  max-width: var(--container, 1200px);
  margin: 0 auto;
  padding: 24px 16px 40px;
}
.clinic-detail-page .clinic-detail-text p {
  margin: 0 0 12px;
  line-height: 1.65;
  color: var(--gray-700);
}
.clinic-detail-page .clinic-detail-text .subtitle {
  font-size: clamp(20px, 2.4vw, 28px);
  font-weight: var(--fw-semibold);
  margin-bottom: 12px;
}
.clinic-detail-page .twosides_map_container,
.clinic-detail-page .map-wrapper.clinic-detail-map {
  min-height: 280px;
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: var(--gray-100);
}
.clinic-detail-page .map-wrapper.clinic-detail-map iframe {
  width: 100%;
  min-height: 280px;
  border: 0;
}
.clinics-photo-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 12px;
}
.clinics-photo-item {
  aspect-ratio: 4/3;
  border-radius: var(--radius-lg);
  background-size: cover;
  background-position: center;
}

/* Service legacy inside redesign */
.ld-service-detail-wrap .procedure-description {
  max-width: var(--container, 1200px);
  margin: 0 auto;
  padding: 0 16px 40px;
}
.ld-service-detail-wrap .section-title {
  font-family: inherit;
  color: var(--gray-900);
}

/* About pages */
.about-grid-2{display:grid;grid-template-columns:1.1fr .9fr;gap:28px;align-items:center}
.section-subtitle--wide{max-width:860px}
.about-visual-card{position:relative;min-height:320px;border-radius:var(--radius-lg);background-size:cover;background-position:center;background-color:var(--gray-100)}
.offers-card--media .offers-media.ld-cms-media-slot{flex:0 0 200px;min-height:150px;border-radius:var(--radius-lg) 0 0 var(--radius-lg)}
.deals-grid-card.offers-card--media .deals-grid-media.ld-cms-media-slot{flex:0 0 auto;min-height:190px;border-radius:var(--radius-lg) var(--radius-lg) 0 0}
.offers-card-text p{margin:0}

/* Главная: блок выгодных предложений */
#deals[data-ld-home-deals-cms] .deals-layout{margin-top:26px}
#deals[data-ld-home-deals-cms] .offers-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-top:0}
#deals[data-ld-home-deals-cms] .offers-card--media .offers-media.ld-cms-media-slot,
#deals[data-ld-home-deals-cms] .offers-card--media .offers-media{min-width:140px;min-height:140px;border-radius:var(--radius-lg) 0 0 var(--radius-lg)}
@media(max-width:1100px){#deals[data-ld-home-deals-cms] .offers-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:680px){
  #deals[data-ld-home-deals-cms] .offers-grid{grid-template-columns:1fr}
  #deals[data-ld-home-deals-cms] .offers-card--media{flex-direction:column}
  #deals[data-ld-home-deals-cms] .offers-card--media .offers-media,
  #deals[data-ld-home-deals-cms] .offers-card--media .offers-media.ld-cms-media-slot{flex:0 0 auto;width:100%;min-width:0;min-height:170px;border-radius:var(--radius-lg) var(--radius-lg) 0 0}
}
.about-rich-text{font-size:15px;line-height:1.65;color:var(--gray-700)}
.about-rich-text p{margin:0 0 12px}
.about-stats-row{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:12px}
.about-stat-card{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius-lg);padding:18px 16px;text-align:center}
.about-stat-value{font-size:clamp(22px,2.5vw,30px);font-weight:var(--fw-bold);color:var(--primary);line-height:1.1}
.about-stat-label{margin-top:6px;font-size:13px;color:var(--gray-600);line-height:1.35}
.about-values-grid,.about-docs-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-top:20px}
.about-values-intro{margin-top:4px;margin-bottom:4px;color:var(--gray-600);max-width:720px}
.about-value-card h3,.about-doc-card h3{font-size:16px;margin:0 0 8px}
.about-doc-tiles{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-top:20px}
.about-doc-tile{
  display:flex;align-items:center;gap:14px;padding:16px 18px;border:1px solid var(--gray-200);border-radius:var(--radius-xl);
  background:var(--white);text-decoration:none;color:inherit;transition:var(--transition);box-shadow:var(--shadow-sm);
}
.about-doc-tile:hover{border-color:rgba(var(--accent-rgb),.45);transform:translateY(-2px);box-shadow:var(--shadow)}
.about-doc-tile-icon{
  flex:0 0 auto;width:44px;height:44px;border-radius:14px;display:flex;align-items:center;justify-content:center;
  background:rgba(var(--accent-rgb),.12);color:var(--primary);
}
.about-doc-tile-icon svg{width:22px;height:22px}
.about-doc-tile-body{display:flex;flex-direction:column;gap:4px;min-width:0;flex:1}
.about-doc-tile-body strong{font-size:15px;font-weight:var(--fw-semibold);line-height:1.3}
.about-doc-tile-body span{font-size:13px;color:var(--gray-600);line-height:1.45}
.about-doc-tile-chevron{flex:0 0 auto;color:var(--gray-400);display:flex}
.about-doc-tile-chevron svg{width:18px;height:18px}
.about-doc-card{display:flex;flex-direction:column;gap:10px;text-decoration:none;color:inherit}
.about-doc-card:hover{border-color:var(--primary)}
.about-legal-text{font-size:14px}
.about-founder-section{position:relative;overflow:hidden}
.about-founder-grid{display:grid;grid-template-columns:minmax(280px,.95fr) 1.05fr;gap:clamp(24px,4vw,48px);align-items:center}
.about-founder-media{position:relative}
.about-founder-photo{
  min-height:clamp(360px,42vw,520px);
  border-radius:calc(var(--radius-lg) + 6px);
  background-size:cover;
  background-position:center top;
  background-color:var(--gray-100);
  box-shadow:0 24px 60px rgba(155,38,168,.16);
}
.about-founder-photo img{width:100%;height:100%;object-fit:cover;border-radius:inherit;display:block;min-height:inherit}
.about-founder-chip{
  position:absolute;left:18px;bottom:18px;
  display:inline-flex;align-items:center;padding:8px 14px;border-radius:999px;
  background:rgba(255,255,255,.92);backdrop-filter:blur(8px);
  font-size:13px;font-weight:var(--fw-semibold);color:var(--primary);
  border:1px solid rgba(155,38,168,.18);
}
.about-founder-name{margin-bottom:8px}
.about-founder-role{font-size:16px;line-height:1.5;color:var(--gray-600);margin:0 0 18px}
.about-founder-quote{
  margin:0 0 20px;padding:18px 20px 18px 22px;
  border-left:4px solid var(--primary);
  background:linear-gradient(135deg,rgba(155,38,168,.08),rgba(183,184,234,.14));
  border-radius:0 var(--radius-lg) var(--radius-lg) 0;
  font-size:clamp(17px,2.2vw,20px);line-height:1.55;font-weight:var(--fw-medium);color:var(--black);
}
.about-founder-text{margin-top:4px}
@media (max-width:1024px){
  .about-grid-2{grid-template-columns:1fr}
  .about-stats-row{grid-template-columns:repeat(3,minmax(0,1fr))}
  .about-founder-grid{grid-template-columns:1fr}
  .about-founder-photo{min-height:300px}
}
@media (max-width:640px){
  .about-stats-row,.about-values-grid,.about-docs-grid,.about-doc-tiles{grid-template-columns:1fr}
}

/* До/После — детальная сетка раздела */
.ld-ba-detail .section-head{margin-bottom:24px}
.ld-ba-detail .section-subtitle{max-width:900px}
.ld-ba-detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px}
.ld-ba-detail-image{position:relative;overflow:hidden;border-radius:24px;background:#f4edf6}
.ld-ba-detail-image img{display:block;width:100%;height:auto}
.ld-ba-detail-chips{position:absolute;left:12px;top:12px;display:flex;gap:8px}
.ld-ba-detail-body{margin-top:16px}
.ld-ba-detail-title{margin:0 0 10px}
.ld-ba-detail-meta{margin:0 0 6px;color:var(--gray-700)}
.ld-ba-detail-meta--spaced{margin:0 0 12px}
.ld-ba-detail-reviews{margin-top:32px}

/* Мобильное меню */
.mm-search svg{width:18px;height:18px;opacity:.6;flex:0 0 auto}
.mm-back svg{width:18px;height:18px;flex:0 0 auto}
.mm-chevron{opacity:.55}
.logo-fallback-accent{color:var(--primary)}
.hero-pitch-note{display:block;margin-top:4px}

/* Страница услуги: отступы блоков */
.service-block-mt{margin-top:14px}
.service-block-mt-lg{margin-top:18px}
.service-price-warning{margin-top:14px}
.text-primary{color:var(--primary)}
.section-title--sm{font-size:1.25rem;margin-bottom:12px}
.service-card--pad{padding:18px}
.service-hero-body .service-meta{margin-top:14px}
.service-hero-body .service-price{margin-top:14px}
.doctor-service-link{display:block;margin:6px 0}
.articles-grid--spaced{margin-top:18px}
.section-title--spaced{margin-top:20px}
.service-block-mt-xl{margin-top:24px}
.service-process-side-title{font-size:14px}
.service-other-title{display:block;font-size:16px;letter-spacing:-.2px}
.service-other-text{margin-top:8px;color:var(--gray-600);font-size:13px;line-height:1.6}
.service-other-link{display:inline-flex;align-items:center;gap:8px;margin-top:12px;color:var(--primary);font-weight:var(--fw-semibold)}
#process .service-grid-2.service-block-mt{margin-top:14px}
#pricesBlock .price-gender-toggle{margin-top:14px;display:flex;gap:10px;flex-wrap:wrap}
#pricesBlock .ld-price-clinic-select{margin:10px 0 14px}
#pricesBlock .ld-price-combo{margin-top:24px}
#pricesBlock .ld-price-combo .section-title{font-size:1.25rem;margin-bottom:12px}
#pricesBlock .ld-price-custom{margin-top:24px}
@media(max-width:980px){
  #pricesBlock .price-table{display:none!important}
  #pricesBlock .price-cards{display:block!important}
  #pricesBlock .price-cards:not(:empty) ~ .price-table{display:none!important}
  #pricesBlock .price-cards:empty{display:none!important}
  #pricesBlock .price-cards:empty ~ .price-table{display:block!important}
}

.ld-partial-missing{border:2px solid #c00;padding:20px}
.ld-partial-missing h1{color:#c00;margin:0 0 8px}

/* ===== Режим правки контента (bitrix_include_areas=Y) ===== */
body.ld-edit-mode .ld-cms-include-host,
body.ld-edit-mode .ld-cms-rich-host,
body.ld-edit-mode [id^="bx_incl_area"]{
  position:relative;
  cursor:pointer;
  border-radius:6px;
  transition:outline-color .15s ease, background-color .15s ease;
}
body.ld-edit-mode .ld-cms-include-host:hover,
body.ld-edit-mode .ld-cms-rich-host:hover,
body.ld-edit-mode [id^="bx_incl_area"]:hover{
  outline:1px dashed rgba(155,38,168,.45);
  outline-offset:2px;
  background:rgba(155,38,168,.04);
}
body.ld-edit-mode .ld-cms-include-host--h1,
body.ld-edit-mode .ld-cms-include-host--h2,
body.ld-edit-mode .ld-cms-include-host--h3{font-weight:inherit}
body.ld-edit-mode .ld-cms-include-host--p,
body.ld-edit-mode .ld-cms-include-host--span{line-height:inherit}
body.ld-edit-mode .ld-cms-include-host [id^="bx_incl_area"],
body.ld-edit-mode .ld-cms-rich-host [id^="bx_incl_area"]{
  display:block;
  width:100%;
  min-height:1.25em;
  cursor:pointer;
}
body.ld-edit-mode .ld-cms-include-host--span{display:inline-block}
body.ld-edit-mode .service-hero-media--cms-edit{cursor:pointer}
/* Подсказка: двойной клик по рамке include — штатный Bitrix */
body.ld-edit-mode [id^="bx_incl_area"]{
  outline:1px dashed transparent;
  outline-offset:2px;
  border-radius:4px;
}
body.ld-edit-mode [id^="bx_incl_area"]:hover{
  outline-color:rgba(155,38,168,.5);
  background:rgba(155,38,168,.04);
}

/* Режим правки: overflow visible (z-index — только в assets/bx-edit.css) */
body.ld-edit-mode.bx-admin-mode .service-hero-card,
body.ld-edit-mode.bx-admin-mode .service-hero,
body.ld-edit-mode.bx-admin-mode .ld-page-section,
body.ld-edit-mode.bx-admin-mode .ld-cms-include-host,
body.ld-edit-mode.bx-admin-mode .ld-cms-rich-host,
body.ld-edit-mode.bx-admin-mode [id^="bx_incl_area"],
body.ld-edit-mode.bx-admin-mode main.page{
  overflow:visible !important;
}

body.ld-edit-mode.bx-admin-mode .about-grid-2 > .ld-cms-include-host,
body.ld-edit-mode.bx-admin-mode .about-grid-2 > .about-visual-card,
body.ld-edit-mode.bx-admin-mode .about-grid-2 > .ld-cms-media-slot {
  min-width: 0;
}

/* Сетки «О нас»: карточки остаются grid-items внутри bx_incl_area */
body.ld-edit-mode.bx-admin-mode .about-values-grid [id^="bx_incl_area"],
body.ld-edit-mode.bx-admin-mode .about-doc-tiles [id^="bx_incl_area"]{
  display:contents;
}


