/* ============================================================
   Наркологический центр Люберцы — design system
   Editorial / atmospheric system adapted from ElevenLabs spec.
   ============================================================ */

:root{
  /* ink + body — softened: deep sapphire (default theme) */
  --primary:#20384a;
  --primary-active:#16263a;
  --ink:#212e3a;
  --body:#505b58;
  --body-strong:#2c3a37;
  --muted:#6f7a77;
  --muted-soft:#9aa5a1;

  /* hairlines */
  --hairline:#e7e5e4;
  --hairline-soft:#f0efed;
  --hairline-strong:#d6d3d1;

  /* surfaces */
  --canvas:#f5f5f4;
  --canvas-soft:#fafaf9;
  --surface-card:#ffffff;
  --surface-strong:#f0efed;
  --surface-dark:#1b2a3a;
  --surface-dark-elevated:#243750;
  --deep:#1b2a3a;
  --deep-elev:#243750;
  --on-primary:#ffffff;
  --on-dark:#ffffff;
  --on-dark-soft:#a8a29e;

  /* atmospheric gradient stops */
  --g-mint:#a7e5d3;
  --g-peach:#f4c5a8;
  --g-lavender:#c8b8e0;
  --g-sky:#a8c8e8;
  --g-rose:#e8b8c4;

  /* semantic */
  --success:#16a34a;
  --error:#dc2626;

  /* accent used for the "urgent" tone — calm teal by default */
  --accent:#1f8a7a;          /* derived from mint, deepened */
  --accent-soft:#e3f3ef;

  /* radii */
  --r-xs:4px; --r-sm:6px; --r-md:8px; --r-lg:12px;
  --r-xl:16px; --r-xxl:24px; --pill:9999px;

  /* spacing */
  --s-xxs:4px; --s-xs:8px; --s-sm:12px; --s-base:16px; --s-md:20px;
  --s-lg:24px; --s-xl:32px; --s-xxl:48px; --s-section:96px;

  --maxw:1200px;

  --font-display:'Inter',system-ui,-apple-system,sans-serif;
  --font-body:'Inter',system-ui,-apple-system,sans-serif;

  --shadow-soft:0 4px 16px rgba(12,10,9,.04);
  --shadow-card:0 1px 2px rgba(12,10,9,.04), 0 12px 40px -24px rgba(12,10,9,.18);
}

/* Urgent tone: warmer, redder accent + slightly stronger contrast */
body.tone-urgent{
  --accent:#c0392b;
  --accent-soft:#f7e6e2;
}

*{box-sizing:border-box;}
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth;}
body{
  margin:0;
  font-family:var(--font-body);
  background:var(--canvas);
  color:var(--body);
  font-size:16px;
  line-height:1.5;
  letter-spacing:.16px;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}

/* ---------- typography ---------- */
.display,h1,h2,h3{font-family:var(--font-display);font-weight:600;letter-spacing:-0.02em;color:var(--ink);margin:0;}
h1{font-size:clamp(40px,6.2vw,68px);line-height:1.04;letter-spacing:-1.4px;}
h2{font-size:clamp(30px,3.8vw,44px);line-height:1.1;letter-spacing:-.6px;}
h3{font-size:clamp(24px,2.6vw,30px);line-height:1.16;letter-spacing:-.3px;}
.eyebrow{
  font-family:var(--font-body);
  font-weight:600;font-size:12px;line-height:1.4;letter-spacing:.96px;
  text-transform:uppercase;color:var(--muted);
}
.lead{font-size:clamp(17px,1.5vw,19px);line-height:1.62;color:var(--body);max-width:62ch;}
p{margin:0 0 var(--s-base);text-wrap:pretty;}
.muted{color:var(--muted);}

/* ---------- layout ---------- */
.container{max-width:var(--maxw);margin:0 auto;padding:0 24px;}
.section{padding:clamp(56px,8vw,96px) 0;}
.section--tight{padding:clamp(40px,5vw,64px) 0;}
.section--soft{background:var(--canvas-soft);}
.stack-sm>*+*{margin-top:var(--s-sm);}
.stack>*+*{margin-top:var(--s-base);}
.stack-lg>*+*{margin-top:var(--s-lg);}
.center{text-align:center;}
.center .lead{margin-left:auto;margin-right:auto;}
.grid{display:grid;gap:var(--s-lg);}
@media(min-width:760px){.g2{grid-template-columns:repeat(2,1fr);}.g3{grid-template-columns:repeat(3,1fr);}}
@media(min-width:980px){.g4{grid-template-columns:repeat(4,1fr);}}
.flex{display:flex;}
.wrap{flex-wrap:wrap;}
.items-center{align-items:center;}
.gap-sm{gap:var(--s-sm);}
.gap{gap:var(--s-base);}
.gap-lg{gap:var(--s-lg);}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-family:var(--font-body);font-weight:500;font-size:15px;line-height:1;
  border-radius:var(--pill);padding:13px 22px;border:1px solid transparent;
  cursor:pointer;transition:transform .15s ease,background .2s ease,border-color .2s,box-shadow .2s;
  white-space:nowrap;
}
.btn:active{transform:translateY(1px);}
.btn-primary{background:var(--primary);color:var(--on-primary);}
.btn-primary:hover{background:var(--primary-active);}
.btn-outline{background:transparent;color:var(--ink);border-color:var(--hairline-strong);}
.btn-outline:hover{border-color:var(--ink);}
.btn-accent{background:var(--accent);color:#fff;}
.btn-accent:hover{filter:brightness(.94);}
.btn-lg{padding:16px 28px;font-size:16px;}
.btn-text{background:transparent;color:var(--ink);padding:6px 0;font-weight:500;}
.btn-text .arr{transition:transform .2s;}
.btn-text:hover .arr{transform:translateX(4px);}
.btn svg{width:18px;height:18px;}

/* ---------- badges ---------- */
.badge{
  display:inline-flex;align-items:center;gap:7px;
  background:var(--surface-strong);color:var(--ink);
  font-weight:600;font-size:12px;letter-spacing:.8px;text-transform:uppercase;
  border-radius:var(--pill);padding:6px 13px;
}
.badge-live{background:var(--accent-soft);color:var(--accent);}
.dot{width:7px;height:7px;border-radius:50%;background:currentColor;flex:none;}
.dot-pulse{position:relative;}
.dot-pulse::after{content:"";position:absolute;inset:-4px;border-radius:50%;background:currentColor;opacity:.35;animation:pulse 1.8s ease-out infinite;}
@keyframes pulse{0%{transform:scale(.6);opacity:.5;}100%{transform:scale(2.2);opacity:0;}}

/* ---------- atmospheric orbs ---------- */
.orb-wrap{position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:0;}
.orb{position:absolute;border-radius:50%;filter:blur(46px);opacity:var(--orb-opacity,.62);mix-blend-mode:multiply;}
.orb-mint{background:radial-gradient(circle at 30% 30%,var(--g-mint),transparent 68%);}
.orb-peach{background:radial-gradient(circle at 30% 30%,var(--g-peach),transparent 68%);}
.orb-lav{background:radial-gradient(circle at 30% 30%,var(--g-lavender),transparent 68%);}
.orb-sky{background:radial-gradient(circle at 30% 30%,var(--g-sky),transparent 68%);}
.orb-rose{background:radial-gradient(circle at 30% 30%,var(--g-rose),transparent 68%);}
@keyframes drift{0%,100%{transform:translate(0,0) scale(1);}50%{transform:translate(3%,-4%) scale(1.06);}}
.orb-drift{animation:drift 18s ease-in-out infinite;}

/* ---------- cards ---------- */
.card{
  background:var(--surface-card);border:1px solid var(--hairline);
  border-radius:var(--r-xl);padding:var(--s-lg);
  transition:box-shadow .25s ease,transform .25s ease,border-color .25s;
}
.card-hover:hover{box-shadow:var(--shadow-soft);transform:translateY(-2px);border-color:var(--hairline-strong);}
.card-pad-lg{padding:var(--s-xl);}
.orb-card{
  position:relative;overflow:hidden;background:var(--canvas-soft);
  border:1px solid var(--hairline-soft);border-radius:var(--r-xxl);padding:var(--s-xl);
}

/* ---------- placeholder image slot ---------- */
.ph{
  position:relative;border-radius:var(--r-xl);overflow:hidden;
  background:
    repeating-linear-gradient(135deg,#efeeec 0 14px,#e9e7e4 14px 28px);
  border:1px solid var(--hairline);
  display:flex;align-items:center;justify-content:center;min-height:200px;color:var(--muted);
}
.ph span{
  font-family:'Inter',system-ui,sans-serif;font-size:12px;letter-spacing:.4px;
  background:rgba(255,255,255,.82);padding:6px 12px;border-radius:var(--pill);
  border:1px solid var(--hairline);
}
.ph-round{border-radius:50%;}

/* ---------- topbar + header ---------- */
.topbar{background:var(--deep);color:var(--on-dark);font-size:13.5px;letter-spacing:.2px;}
.topbar .container{display:flex;align-items:center;justify-content:space-between;height:38px;gap:16px;}
.topbar a{color:var(--on-dark);opacity:.92;}
.topbar .tb-left{display:flex;align-items:center;gap:18px;flex:none;}
.topbar .tb-item{display:flex;align-items:center;gap:7px;color:var(--on-dark-soft);white-space:nowrap;}
.topbar .tb-item svg{width:15px;height:15px;flex:none;}
.topbar .tb-item b{color:var(--on-dark);font-weight:500;}
@media(max-width:720px){.topbar .tb-hide{display:none;}}

header.site{position:sticky;top:0;z-index:60;background:rgba(245,245,244,.86);backdrop-filter:blur(14px);border-bottom:1px solid var(--hairline);}
.nav{display:flex;align-items:center;justify-content:space-between;height:68px;gap:20px;}
.brand{display:flex;align-items:center;gap:11px;}
.brand .logo{width:38px;height:38px;border-radius:11px;background:var(--deep);color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:22px;font-weight:300;}
.brand .bt{line-height:1.1;}
.brand .bt b{font-weight:500;font-size:15px;color:var(--ink);letter-spacing:.1px;display:block;}
.brand .bt span{font-size:11.5px;color:var(--muted);letter-spacing:.3px;}
.menu{display:none;align-items:center;gap:26px;}
.menu a{font-weight:500;font-size:15px;color:var(--body-strong);position:relative;padding:4px 0;}
.menu a:hover{color:var(--ink);}
.menu a.active{color:var(--ink);}
.menu a.active::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:2px;background:var(--ink);border-radius:2px;}
.nav-actions{display:flex;align-items:center;gap:12px;}
.nav-phone{display:none;flex-direction:column;align-items:flex-end;line-height:1.05;}
.nav-phone b{font-size:17px;font-weight:600;color:var(--ink);letter-spacing:.2px;white-space:nowrap;}
.nav-phone span{font-size:11px;color:var(--accent);font-weight:600;letter-spacing:.4px;text-transform:uppercase;}
@media(min-width:1040px){.menu{display:flex;}.nav-phone{display:flex;}}

/* mobile menu */
.burger{display:flex;flex-direction:column;gap:4px;width:42px;height:42px;border:1px solid var(--hairline-strong);border-radius:12px;background:var(--surface-card);align-items:center;justify-content:center;cursor:pointer;}
.burger span{width:18px;height:1.6px;background:var(--ink);border-radius:2px;}
@media(min-width:1040px){.burger{display:none;}}
.drawer{position:fixed;inset:0;z-index:80;background:rgba(12,10,9,.4);backdrop-filter:blur(2px);opacity:0;visibility:hidden;transition:.25s;}
.drawer.open{opacity:1;visibility:visible;}
.drawer-panel{position:absolute;top:0;right:0;bottom:0;width:min(86vw,360px);background:var(--canvas);padding:22px;overflow-y:auto;transform:translateX(100%);transition:.3s cubic-bezier(.2,.8,.2,1);display:flex;flex-direction:column;gap:6px;}
.drawer.open .drawer-panel{transform:none;}
.drawer-panel a{padding:13px 12px;border-radius:10px;font-weight:500;color:var(--body-strong);font-size:16px;}
.drawer-panel a:hover{background:var(--surface-strong);}
.drawer-panel .sub{padding-left:24px;font-size:14.5px;color:var(--body);font-weight:400;}
.drawer-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;}
.drawer-close{width:40px;height:40px;border-radius:10px;border:1px solid var(--hairline-strong);background:var(--surface-card);font-size:20px;cursor:pointer;color:var(--ink);}
.drawer-cta{margin-top:14px;display:flex;flex-direction:column;gap:10px;}

/* dropdown for services */
.has-drop{position:relative;}
.drop{position:absolute;top:calc(100% + 10px);left:50%;transform:translateX(-50%) translateY(6px);background:var(--surface-card);border:1px solid var(--hairline);border-radius:var(--r-lg);box-shadow:var(--shadow-card);padding:8px;min-width:300px;opacity:0;visibility:hidden;transition:.2s;}
.has-drop:hover .drop{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0);}
.drop a{display:block;padding:9px 12px;border-radius:8px;font-size:14.5px;font-weight:400;color:var(--body-strong);}
.drop a::after{display:none;}
.drop a:hover{background:var(--surface-strong);color:var(--ink);}

/* ---------- hero ---------- */
.hero{position:relative;overflow:hidden;}
.hero-inner{position:relative;z-index:1;padding:clamp(48px,7vw,86px) 0 clamp(40px,5vw,64px);}
.hero-trust{display:flex;flex-wrap:wrap;gap:10px 22px;}
.hero-trust .ti{display:flex;align-items:center;gap:9px;font-size:14.5px;color:var(--body-strong);font-weight:500;}
.hero-trust .ti .ic{width:30px;height:30px;border-radius:50%;background:var(--surface-strong);display:flex;align-items:center;justify-content:center;color:var(--accent);flex:none;}
.hero-trust .ti svg{width:16px;height:16px;}

/* ---------- steps ---------- */
.steps{counter-reset:st;display:grid;gap:2px;}
.step{display:grid;grid-template-columns:auto 1fr;gap:18px;padding:20px 0;border-top:1px solid var(--hairline);align-items:start;}
.step:last-child{border-bottom:1px solid var(--hairline);}
.step .num{font-family:var(--font-display);font-weight:300;font-size:34px;color:var(--accent);line-height:1;min-width:46px;}
.step h4{margin:0 0 4px;font-size:17px;font-weight:600;color:var(--ink);font-family:var(--font-body);letter-spacing:0;}
.step p{margin:0;font-size:15px;color:var(--body);}

/* ---------- list ---------- */
.tick{list-style:none;padding:0;margin:0;display:grid;gap:11px;}
.tick li{position:relative;padding-left:30px;color:var(--body-strong);font-size:15.5px;}
.tick li::before{content:"";position:absolute;left:0;top:2px;width:19px;height:19px;border-radius:50%;background:var(--accent-soft);}
.tick li::after{content:"";position:absolute;left:6px;top:7px;width:7px;height:4px;border-left:1.6px solid var(--accent);border-bottom:1.6px solid var(--accent);transform:rotate(-45deg);}

/* ---------- guarantees ---------- */
.guard{display:grid;gap:0;}
.guard .gi{display:grid;grid-template-columns:auto 1fr;gap:18px;padding:22px 0;border-top:1px solid var(--hairline);align-items:start;}
.guard .gi:last-child{border-bottom:1px solid var(--hairline);}
.guard .gn{width:42px;height:42px;border-radius:50%;border:1px solid var(--hairline-strong);display:flex;align-items:center;justify-content:center;color:var(--accent);}
.guard h4{margin:0 0 4px;font-size:16.5px;font-weight:600;color:var(--ink);font-family:var(--font-body);}
.guard p{margin:0;font-size:14.5px;color:var(--body);}

/* ---------- tables / prices ---------- */
.price-card{background:var(--surface-card);border:1px solid var(--hairline);border-radius:var(--r-xl);overflow:hidden;}
.price-card h3{padding:22px 26px 6px;}
.price-head{padding:20px 26px;border-bottom:1px solid var(--hairline);display:flex;align-items:baseline;justify-content:space-between;gap:12px;}
.price-head .eyebrow{margin-bottom:6px;}
.ptable{width:100%;border-collapse:collapse;}
.ptable td{padding:15px 26px;border-top:1px solid var(--hairline-soft);font-size:15.5px;color:var(--body-strong);}
.ptable tr:first-child td{border-top:none;}
.ptable td:last-child{text-align:right;font-weight:600;color:var(--ink);white-space:nowrap;font-variant-numeric:tabular-nums;}
.ptable tr:hover td{background:var(--canvas-soft);}
.price-note{padding:16px 26px;border-top:1px solid var(--hairline);font-size:13.5px;color:var(--muted);}

/* featured dark price */
.price-card.dark{background:var(--surface-dark);border-color:var(--surface-dark);}
.price-card.dark h3,.price-card.dark .ptable td:last-child{color:#fff;}
.price-card.dark .ptable td{color:var(--on-dark-soft);border-color:rgba(255,255,255,.08);}
.price-card.dark .price-head{border-color:rgba(255,255,255,.1);}
.price-card.dark tr:hover td{background:var(--surface-dark-elevated);}

/* ---------- forms / calculator ---------- */
.field label{display:block;font-size:13px;font-weight:600;letter-spacing:.4px;text-transform:uppercase;color:var(--muted);margin-bottom:9px;}
.opts{display:flex;flex-wrap:wrap;gap:8px;}
.opt{
  font-size:14.5px;font-weight:500;color:var(--body-strong);
  background:var(--surface-card);border:1px solid var(--hairline-strong);
  border-radius:var(--pill);padding:9px 16px;cursor:pointer;transition:.15s;user-select:none;
}
.opt:hover{border-color:var(--ink);}
.opt.sel{background:var(--ink);color:#fff;border-color:var(--ink);}
.input{
  width:100%;height:48px;background:var(--surface-card);border:1px solid var(--hairline-strong);
  border-radius:var(--r-md);padding:12px 16px;font-family:var(--font-body);font-size:15.5px;color:var(--ink);
  transition:border-color .15s,box-shadow .15s;
}
.input:focus{outline:none;border-color:var(--ink);box-shadow:0 0 0 3px rgba(12,10,9,.06);}
textarea.input{height:auto;min-height:88px;resize:vertical;}
.calc-result{
  background:var(--deep);color:#fff;border-radius:var(--r-xl);padding:26px;text-align:center;
}
.calc-result .rv{font-family:var(--font-display);font-weight:300;font-size:46px;line-height:1;letter-spacing:-1px;}
.calc-result .rl{color:var(--on-dark-soft);font-size:13px;text-transform:uppercase;letter-spacing:.8px;margin-bottom:8px;}

/* ---------- floating call (mobile) ---------- */
.fab{position:fixed;right:16px;bottom:16px;z-index:70;display:flex;gap:10px;}
.fab a{width:54px;height:54px;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 10px 28px -8px rgba(12,10,9,.5);}
.fab .call{background:var(--accent);color:#fff;}
.fab .wa{background:#25d366;color:#fff;}
.fab a svg{width:24px;height:24px;}
@media(min-width:1040px){.fab{display:none;}}

/* ---------- footer ---------- */
footer.site{background:var(--deep);color:var(--on-dark-soft);padding:64px 0 32px;}
footer.site a{color:var(--on-dark-soft);}
footer.site a:hover{color:#fff;}
.foot-grid{display:grid;gap:36px;grid-template-columns:1fr;}
@media(min-width:760px){.foot-grid{grid-template-columns:1.4fr 1fr 1fr;}}
@media(min-width:1040px){.foot-grid{grid-template-columns:1.6fr 1fr 1fr 1.1fr;}}
.foot-grid h5{color:#fff;font-family:var(--font-body);font-size:13px;font-weight:600;letter-spacing:.8px;text-transform:uppercase;margin:0 0 16px;}
.foot-links{display:grid;gap:10px;font-size:14.5px;}
.foot-brand .brand .bt b{color:#fff;}
.foot-brand .brand .bt span{color:var(--on-dark-soft);}
.foot-brand p{font-size:14px;color:var(--on-dark-soft);max-width:34ch;margin-top:14px;}
.foot-phone{font-family:var(--font-display);font-weight:300;font-size:30px;color:#fff;letter-spacing:-.5px;}
.foot-bottom{border-top:1px solid rgba(255,255,255,.1);margin-top:44px;padding-top:22px;display:flex;flex-wrap:wrap;gap:12px 24px;justify-content:space-between;font-size:13px;color:var(--muted-soft);}
.foot-bottom a{font-size:13px;}

/* ---------- cookie ---------- */
.cookie{position:fixed;left:16px;right:16px;bottom:16px;z-index:90;max-width:560px;margin:0 auto;background:var(--surface-dark-elevated);color:#fff;border-radius:var(--r-lg);padding:16px 18px;display:flex;gap:14px;align-items:center;box-shadow:var(--shadow-card);transition:.3s;}
.cookie.hide{transform:translateY(160%);opacity:0;visibility:hidden;}
.cookie p{margin:0;font-size:13px;color:var(--on-dark-soft);line-height:1.5;}
.cookie a{color:#fff;text-decoration:underline;}
.cookie .btn{flex:none;padding:10px 18px;font-size:14px;}

/* ---------- breadcrumb ---------- */
.crumb{display:flex;flex-wrap:wrap;gap:8px;align-items:center;font-size:13.5px;color:var(--muted);padding:18px 0 0;}
.crumb a:hover{color:var(--ink);}
.crumb .sep{opacity:.5;}

/* ---------- misc ---------- */
.divider{height:1px;background:var(--hairline);border:none;margin:0;}
.kicker-row{display:flex;align-items:center;gap:14px;}
.kicker-row::after{content:"";flex:1;height:1px;background:var(--hairline);}
.cta-band{position:relative;overflow:hidden;background:var(--canvas-soft);border:1px solid var(--hairline);border-radius:var(--r-xxl);padding:clamp(40px,6vw,72px);text-align:center;}
.prose p{font-size:16.5px;line-height:1.66;color:var(--body);}
.prose h2{margin:38px 0 14px;}
.prose h3{margin:30px 0 12px;}
.prose ul{padding-left:0;}
.anchor-list{display:flex;flex-wrap:wrap;gap:8px;}
.chip{font-size:13.5px;color:var(--body-strong);background:var(--surface-card);border:1px solid var(--hairline-strong);border-radius:var(--pill);padding:7px 14px;transition:.15s;}
.chip:hover{border-color:var(--ink);}

/* ============================================================
   SURFACE MODES (Tweaks: «Тёмные блоки» / «Светлая шапка» / «Всё светлое»)
   ============================================================ */

/* ---- Светлая шапка: только верхняя строка контактов становится светлой ---- */
.surf-lighthead .topbar,
.surf-light .topbar{
  background:var(--surface-card);
  color:var(--body-strong);
  border-bottom:1px solid var(--hairline);
}
.surf-lighthead .topbar a,
.surf-light .topbar a{color:var(--body-strong);}
.surf-lighthead .topbar .tb-item,
.surf-light .topbar .tb-item{color:var(--muted);}
.surf-lighthead .topbar .tb-item b,
.surf-light .topbar .tb-item b{color:var(--body-strong);}
/* логотип в светлом режиме — мягкий контур вместо тёмной плашки */
.surf-lighthead .brand .logo,
.surf-light .brand .logo{
  background:var(--accent-soft);
  color:var(--accent);
  border:1px solid var(--hairline);
}

/* ---- Всё светлое: убираем тёмные футер / калькулятор / тёмную карточку цен ---- */
.surf-light footer.site{
  background:var(--canvas-soft);
  color:var(--body);
  border-top:1px solid var(--hairline);
}
.surf-light footer.site a{color:var(--body);}
.surf-light footer.site a:hover{color:var(--ink);}
.surf-light footer.site h5{color:var(--ink);}
.surf-light .foot-brand .brand .bt b,
.surf-light .foot-phone{color:var(--ink);}
.surf-light .foot-brand .brand .bt span,
.surf-light .foot-brand p,
.surf-light .foot-grid .foot-links span{color:var(--muted);}
.surf-light .foot-bottom{border-top:1px solid var(--hairline);color:var(--muted);}

.surf-light .calc-result{
  background:var(--accent-soft);
  color:var(--ink);
  border:1px solid var(--hairline);
}
.surf-light .calc-result .rl{color:var(--accent);}
.surf-light .calc-result .rv{color:var(--ink);}
.surf-light .calc-result p{color:var(--body) !important;}

.surf-light .price-card.dark{
  background:var(--surface-card);
  border-color:var(--hairline);
}
.surf-light .price-card.dark h3,
.surf-light .price-card.dark .ptable td:last-child{color:var(--ink);}
.surf-light .price-card.dark .ptable td{color:var(--body-strong);border-color:var(--hairline-soft);}
.surf-light .price-card.dark .price-head{border-color:var(--hairline);}
.surf-light .price-card.dark .price-head .eyebrow{color:var(--muted) !important;}
.surf-light .price-card.dark tr:hover td{background:var(--canvas-soft);}
.surf-light .price-card.dark .price-note{color:var(--muted) !important;}

/* мягкая рамка-разделитель под шапкой, чтобы светлый хедер «держал» структуру */
.surf-light header.site{box-shadow:0 1px 0 var(--hairline);}


/* ============ Версия для слабовидящих (ГОСТ Р 52872-2019) ============ */
.a11y-btn{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:10px;border:1px solid rgba(0,0,0,.15);background:transparent;cursor:pointer;color:inherit;}
.a11y-btn svg{width:22px;height:22px;}
:focus-visible{outline:3px solid #1a56c4 !important;outline-offset:2px;}
.a11y-panel{display:none;position:fixed;top:0;left:0;right:0;z-index:9999;background:#fff;color:#000;border-bottom:3px solid #000;padding:14px 18px;font-size:16px;line-height:1.5;}
.a11y-panel.open{display:block;}
.a11y-panel .a11y-row{display:flex;flex-wrap:wrap;gap:10px 22px;align-items:center;max-width:1200px;margin:0 auto;}
.a11y-panel b{font-size:17px;margin-right:6px;}
.a11y-panel .grp{display:flex;gap:6px;align-items:center;flex-wrap:wrap;}
.a11y-panel .grp span{font-weight:600;margin-right:2px;}
.a11y-panel button{font:inherit;padding:6px 12px;border:2px solid #000;background:#fff;color:#000;border-radius:8px;cursor:pointer;}
.a11y-panel button[aria-pressed="true"]{background:#000;color:#fff;}
.a11y-panel .a11y-close{margin-left:auto;font-size:22px;line-height:1;padding:4px 12px;}
html.a11y-f1 body{zoom:1.25;}
html.a11y-f2 body{zoom:1.5;}
html.a11y-ls body *{letter-spacing:.08em !important;word-spacing:.16em !important;}
html.a11y-noimg img,html.a11y-noimg .ph,html.a11y-noimg .orb,html.a11y-noimg .orb-wrap{visibility:hidden !important;}
html.a11y-cc body *{animation:none !important;transition:none !important;text-shadow:none !important;box-shadow:none !important;background-image:none !important;}
html.a11y-cc .orb,html.a11y-cc .orb-wrap{display:none !important;}
html.a11y-bw body, html.a11y-bw body *{background-color:#fff !important;color:#000 !important;border-color:#000 !important;}
html.a11y-bw a{color:#000 !important;text-decoration:underline !important;}
html.a11y-wb body, html.a11y-wb body *{background-color:#000 !important;color:#fff !important;border-color:#fff !important;}
html.a11y-wb a{color:#fff !important;text-decoration:underline !important;}
html.a11y-bl body, html.a11y-bl body *{background-color:#9DD1FF !important;color:#063462 !important;border-color:#063462 !important;}
html.a11y-bl a{color:#063462 !important;text-decoration:underline !important;}
html.a11y-bw .btn, html.a11y-wb .btn, html.a11y-bl .btn{border:2px solid currentColor !important;}

/* ============ Фикс наложения блоков на мобильных ============ */
.sticky-col{position:sticky;top:96px;}
@media(max-width:980px){
  .sticky-col{position:static !important;top:auto !important;}
  .section .grid.g2{align-items:start;}
}


/* ============ Иллюстрации вместо плейсхолдеров ============ */
.ph{display:flex;align-items:center;justify-content:center;}
.ph .ill{position:relative;z-index:1;width:64%;max-width:220px;height:auto;color:var(--accent);opacity:.92;}
.ph .ill.big{max-width:300px;}
.ill-doc{width:78%;max-width:240px;}
.map-frame{width:100%;min-height:340px;border:0;border-radius:24px;display:block;}
@media(max-width:760px){.map-frame{min-height:280px;}}

/* ============ Отзывы ============ */
.reviews-grid{display:grid;grid-template-columns:1fr;gap:20px;}
@media(min-width:760px){.reviews-grid{grid-template-columns:repeat(2,1fr);}}
.review-card{background:var(--surface-card);border:1px solid var(--hairline);border-radius:var(--r-xl);padding:24px;display:flex;flex-direction:column;gap:14px;}
.review-head{display:flex;align-items:center;gap:12px;}
.review-ava{width:44px;height:44px;border-radius:50%;background:var(--deep);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:19px;flex:none;}
.review-head b{display:block;font-size:15.5px;color:var(--ink);}
.review-meta{display:block;font-size:13px;color:var(--muted-ink,#6b7c79);}
.review-stars{margin-left:auto;display:flex;align-items:center;}
.review-text{margin:0;font-size:15px;line-height:1.65;color:var(--ink);}

/* ============ Фотографии (автоподмена на локальные) ============ */
.photo-slot{position:relative;overflow:hidden;width:100%;height:100%;background:var(--canvas-soft);display:flex;align-items:center;justify-content:center;}
.photo-slot img{width:100%;height:100%;object-fit:cover;display:block;}
.article-photo{width:100%;aspect-ratio:16/7;border-radius:18px;overflow:hidden;margin:6px 0 26px;border:1px solid var(--hairline);}
.article-photo .photo-slot{min-height:100%;}
@media(max-width:600px){.article-photo{aspect-ratio:16/9;}}
.ph-card{border-radius:12px;}
.lic-wide{width:100%;border:1px solid var(--hairline);border-radius:16px;overflow:hidden;background:var(--canvas-soft);}
.lic-wide img{display:block;}
html.a11y-noimg .photo-slot img,html.a11y-noimg .lic-wide img,html.a11y-noimg .article-photo{visibility:hidden;}

/* ============ Гео-отзыв (мягкий, не жёсткий блок) ============ */
.geo-review{position:relative;max-width:760px;margin:0 auto;background:linear-gradient(135deg,rgba(43,179,163,.07),rgba(43,179,163,.02));border:1px solid var(--hairline);border-left:4px solid var(--accent);border-radius:var(--r-xl);padding:30px 32px 26px;}
.geo-review-q{color:var(--accent);line-height:0;margin-bottom:8px;}
.geo-review-text{margin:0 0 18px;font-size:17px;line-height:1.66;color:var(--ink);font-style:italic;}
.geo-review-author{display:flex;align-items:center;gap:12px;flex-wrap:wrap;}
.geo-review-ava{width:42px;height:42px;border-radius:50%;background:var(--deep);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:18px;flex:none;}
.geo-review-author b{display:block;font-size:15px;color:var(--ink);}
.geo-review-meta{display:block;font-size:13px;color:var(--muted-ink,#6b7c79);}
.geo-review-stars{margin-left:auto;color:#f0a830;font-size:16px;letter-spacing:1px;}
.geo-review-more{display:inline-block;margin-top:16px;color:var(--accent);font-weight:600;font-size:14px;}
@media(max-width:560px){.geo-review-stars{margin-left:0;width:100%;}}

/* ============ Карусель отзывов на главной ============ */
.rev-carousel{position:relative;}
.rc-track{display:flex;gap:20px;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;padding:4px 2px 14px;scrollbar-width:none;}
.rc-track::-webkit-scrollbar{display:none;}
.rc-item{flex:0 0 min(360px,82vw);scroll-snap-align:start;}
.rc-btn{position:absolute;top:50%;transform:translateY(-50%);z-index:2;width:42px;height:42px;border-radius:50%;border:1px solid var(--hairline-strong);background:var(--canvas);color:var(--ink);font-size:24px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 14px rgba(0,0,0,.08);}
.rc-btn:hover{background:var(--deep);color:#fff;}
.rc-prev{left:-12px;}
.rc-next{right:-12px;}
@media(max-width:760px){.rc-prev{left:-6px;}.rc-next{right:-6px;}}
html.a11y-cc .rc-track{scroll-behavior:auto;}

/* ============ Фиксы после деплоя: фото, логотип в футере ============ */
.photo-slot{position:absolute;inset:0;}
.article-photo{position:relative;}
.ph{padding:0;}
footer.site .brand .logo{background:var(--accent);color:#fff;border:1px solid rgba(255,255,255,.28);}

/* ============ Мобильная устойчивость вёрстки ============ */
html,body{overflow-x:hidden;max-width:100%;}
h1,h2,h3,.lead{overflow-wrap:break-word;}
.grid>*{min-width:0;}
@media(max-width:560px){
  h1{font-size:clamp(30px,8.4vw,40px);letter-spacing:-0.4px;line-height:1.08;}
  h2{font-size:clamp(24px,6.8vw,32px);}
  .container{padding-left:18px;padding-right:18px;}
  .rc-btn{display:none;}
  .cta-band{padding:34px 20px;}
  .rc-item{flex:0 0 86vw;}
  .review-stars{margin-left:0;}
}

/* ============ Мобайл: кнопки не распирают блоки ============ */
@media(max-width:600px){
  .btn{white-space:normal;line-height:1.25;}
  .card,.price-card,.cta-band,.calc-result{min-width:0;max-width:100%;}
  .opts .opt{font-size:13.5px;padding:8px 13px;}
  .nav-actions .btn{white-space:nowrap;}
}

/* ============ Мобайл: шапка — только лого, глаз и бургер ============ */
@media(max-width:680px){
  .nav-actions .btn-accent,.nav-actions .btn-blue{display:none;}
  .nav-actions .btn-orange{padding:9px 14px;font-size:13.5px;}
  .nav-actions{gap:8px;}
  .brand .bt span{display:none;}
  .brand .bt b{font-size:14px;}
  .nav{gap:10px;}
}

/* ============ Мобайл: бургер в тёмной верхней строке ============ */
.tb-burger{display:none;}
@media(max-width:680px){
  .tb-burger{display:flex;width:34px;height:34px;border-radius:9px;border:1px solid rgba(255,255,255,.3);background:transparent;}
  .tb-burger span{background:#fff;width:16px;}
  .nav .burger{display:none;}
  .topbar .container{height:44px;}
}

/* ============ Мобайл: таблицы цен не обрезаются ============ */
@media(max-width:600px){
  .ptable td{padding:12px 14px;font-size:14px;}
  .ptable td:last-child{white-space:normal;min-width:84px;}
  .ptable td:first-child{overflow-wrap:break-word;}
  .price-card{max-width:100%;}
  .price-note{padding:12px 14px;}
}

/* ---- blue form buttons ---- */
.btn-blue{background:#da7756;color:#fff;}
.btn-blue:hover{filter:brightness(.92);}
.js-lead-form button[type=submit],#calcSubmit{background:#da7756;}
.js-lead-form button[type=submit]:hover,#calcSubmit:hover{filter:brightness(.92);}
html.a11y-bw .btn-blue,html.a11y-bw .js-lead-form button[type=submit],html.a11y-bw #calcSubmit{background:#000;}
/* ---- lead modal ---- */
#leadModal{position:fixed;inset:0;z-index:1200;display:none;align-items:center;justify-content:center;padding:20px;}
#leadModal.open{display:flex;}
#leadModal .lm-back{position:absolute;inset:0;background:rgba(12,38,35,.55);}
#leadModal .lm-card{position:relative;z-index:1;background:var(--paper,#fff);border-radius:20px;max-width:440px;width:100%;max-height:92vh;overflow:auto;padding:26px;box-shadow:0 24px 70px rgba(0,0,0,.28);}
#leadModal .lm-close{position:absolute;top:8px;right:12px;background:none;border:0;font-size:28px;cursor:pointer;color:#999;line-height:1;}
@media(max-width:480px){#leadModal .lm-card{padding:20px 16px;}}
/* orange header button */
.btn-orange{background:#da7756;color:#fff;}
.btn-orange:hover{filter:brightness(.93);}
html.a11y-bw .btn-orange{background:#000;}

/* spacing around header lead button */
.nav-actions .btn-orange{margin-left:14px;}
@media(max-width:680px){.nav-actions .btn-orange{margin-left:10px;margin-right:4px;}}

/* ---- geo route block: faded background photo ---- */
.geo-route-bg{position:relative;overflow:hidden;}
.geo-route-bg::before{content:"";position:absolute;top:0;bottom:0;right:0;width:62%;background:url(/assets/img/geo-route-bg.jpg) right 30%/cover no-repeat;opacity:.34;filter:saturate(.8);-webkit-mask-image:linear-gradient(to left,#000 50%,transparent 100%);mask-image:linear-gradient(to left,#000 50%,transparent 100%);pointer-events:none;}
@media(max-width:680px){.geo-route-bg::before{width:100%;opacity:.18;}}
.geo-route-bg .container{position:relative;z-index:1;}
.geo-route-bg .price-card{background:rgba(255,255,255,.92);backdrop-filter:blur(2px);}
