/* Локальные шрифты (Oswald + Montserrat, subset cyrillic+latin). Подключены через npm @fontsource. */
@font-face{font-family:'Montserrat';font-style:normal;font-weight:400;font-display:swap;src:url('fonts/montserrat-cyrillic-400-normal.woff2') format('woff2');unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116}
@font-face{font-family:'Montserrat';font-style:normal;font-weight:400;font-display:swap;src:url('fonts/montserrat-latin-400-normal.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Montserrat';font-style:normal;font-weight:500;font-display:swap;src:url('fonts/montserrat-cyrillic-500-normal.woff2') format('woff2');unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116}
@font-face{font-family:'Montserrat';font-style:normal;font-weight:500;font-display:swap;src:url('fonts/montserrat-latin-500-normal.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Montserrat';font-style:normal;font-weight:600;font-display:swap;src:url('fonts/montserrat-cyrillic-600-normal.woff2') format('woff2');unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116}
@font-face{font-family:'Montserrat';font-style:normal;font-weight:600;font-display:swap;src:url('fonts/montserrat-latin-600-normal.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Montserrat';font-style:normal;font-weight:700;font-display:swap;src:url('fonts/montserrat-cyrillic-700-normal.woff2') format('woff2');unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116}
@font-face{font-family:'Montserrat';font-style:normal;font-weight:700;font-display:swap;src:url('fonts/montserrat-latin-700-normal.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Montserrat';font-style:normal;font-weight:800;font-display:swap;src:url('fonts/montserrat-cyrillic-800-normal.woff2') format('woff2');unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116}
@font-face{font-family:'Montserrat';font-style:normal;font-weight:800;font-display:swap;src:url('fonts/montserrat-latin-800-normal.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Oswald';font-style:normal;font-weight:400;font-display:swap;src:url('fonts/oswald-cyrillic-400-normal.woff2') format('woff2');unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116}
@font-face{font-family:'Oswald';font-style:normal;font-weight:400;font-display:swap;src:url('fonts/oswald-latin-400-normal.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Oswald';font-style:normal;font-weight:500;font-display:swap;src:url('fonts/oswald-cyrillic-500-normal.woff2') format('woff2');unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116}
@font-face{font-family:'Oswald';font-style:normal;font-weight:500;font-display:swap;src:url('fonts/oswald-latin-500-normal.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Oswald';font-style:normal;font-weight:600;font-display:swap;src:url('fonts/oswald-cyrillic-600-normal.woff2') format('woff2');unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116}
@font-face{font-family:'Oswald';font-style:normal;font-weight:600;font-display:swap;src:url('fonts/oswald-latin-600-normal.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Oswald';font-style:normal;font-weight:700;font-display:swap;src:url('fonts/oswald-cyrillic-700-normal.woff2') format('woff2');unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116}
@font-face{font-family:'Oswald';font-style:normal;font-weight:700;font-display:swap;src:url('fonts/oswald-latin-700-normal.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
/* ============================================================
   ДОКТОР АТФ — site.css  ·  LIGHT theme (matches doctor-atf.ru)
   White / #fafafa dominant · red #d12c3d · dark accents #151b26
   ============================================================ */
:root{
  --red:#d12c3d; --red-600:#b8222f; --red-700:#9c1c27; --red-soft:#fcecee; --red-2:#ce260c;
  --ink:#151b26; --ink-2:#1d2533; --ink-3:#10151e;
  --bg:#ffffff; --bg-soft:#fafafa; --bg-soft2:#f3f4f6;
  --txt:#171c26; --txt-2:#3c4250; --muted:#6b7280; --muted-2:#9aa0ac;
  --line:#e7e9ed; --line-2:#dde0e6; --line-dark:#283041;
  --gold:#f5a623;
  --surface:#171d28; --surface-2:#1f2733; --surface-3:#2b3442; --bg-2:#1f2733;
  --r-sm:8px; --r:12px; --r-lg:18px; --r-xl:26px;
  --maxw:1240px;
  --shadow-sm:0 1px 2px rgba(20,27,38,.05),0 2px 8px rgba(20,27,38,.04);
  --shadow:0 12px 34px -14px rgba(20,27,38,.22);
  --shadow-lg:0 26px 60px -22px rgba(20,27,38,.32);
  --font:'Montserrat',system-ui,sans-serif;
  --display:'Oswald','Montserrat',sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--txt);font-family:var(--font);font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4,p{margin:0}
button{font-family:inherit;cursor:pointer}
input,textarea,select{font-family:inherit}
::selection{background:var(--red);color:#fff}
.container{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.red{color:var(--red)}
.muted{color:var(--muted)}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;height:52px;padding:0 26px;border:none;border-radius:var(--r);font-size:15px;font-weight:600;letter-spacing:.01em;white-space:nowrap;transition:transform .12s,background .15s,box-shadow .15s,color .15s}
.btn:active{transform:translateY(1px)}
.btn-red{background:var(--red);color:#fff;box-shadow:0 10px 24px -12px rgba(209,44,61,.85)}
.btn-red:hover{background:var(--red-600)}
.btn-dark{background:var(--ink);color:#fff}
.btn-dark:hover{background:var(--ink-2)}
.btn-ghost{background:#fff;color:var(--txt);border:1.5px solid var(--line-2)}
.btn-ghost:hover{border-color:var(--ink);background:#fff}
.btn-ghost-light{background:rgba(255,255,255,.08);color:#fff;border:1.5px solid rgba(255,255,255,.22)}
.btn-ghost-light:hover{background:rgba(255,255,255,.16)}
.btn-lg{height:58px;padding:0 34px;font-size:16px}
.btn-sm{height:44px;padding:0 18px;font-size:14px;border-radius:var(--r-sm)}
.btn-block{width:100%}

/* ---------- section heading ---------- */
.sec{padding:78px 0}
.sec-sm{padding:48px 0}
.sec-soft{background:var(--bg-soft)}
.kicker{display:inline-flex;align-items:center;gap:9px;font-size:12.5px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--red);margin-bottom:16px}
.kicker::before{content:"";width:26px;height:2px;background:var(--red)}
.h-sec{font-family:var(--display);font-size:clamp(28px,3.4vw,42px);font-weight:600;line-height:1.06;letter-spacing:.01em;text-transform:uppercase;color:var(--ink)}
.sec-sub{color:var(--muted);font-size:17px;margin-top:14px;max-width:620px}
.sec-head{margin-bottom:42px}
.dark .h-sec{color:#fff}
.dark .sec-sub{color:#aab1bd}

/* ============================================================
   TOPBAR + HEADER  (dark, so white logo reads)
   ============================================================ */
.topbar{background:var(--ink-3);color:#aab1bd;font-size:13px;border-bottom:1px solid var(--line-dark)}
.topbar .container{display:flex;align-items:center;justify-content:space-between;gap:20px;height:42px}
.topbar .socials{display:flex;gap:7px;flex-wrap:wrap}
.topbar .socials a{width:25px;height:25px;border-radius:6px;overflow:hidden;display:flex;align-items:center;justify-content:center;transition:.15s;color:#cfd4dc;background:rgba(255,255,255,.08)}
.topbar .socials a svg{width:62%;height:62%;fill:currentColor;display:block}
.topbar .socials a.has-img{background:rgba(255,255,255,.08)}
.topbar .socials a.has-img img{width:100%;height:100%;object-fit:cover;display:block}
/* optical size normalization: equalize visible glyph across differing viewBoxes */
.socials a[title="MAX"] svg,.foot-soc a[title="MAX"] svg{width:80%;height:80%}
.socials a[title="WhatsApp"] svg,.foot-soc a[title="WhatsApp"] svg{width:74%;height:74%}
.socials a[title="Google Карты"] svg,.foot-soc a[title="Google Карты"] svg{width:74%;height:74%}
.socials a[title="Авито"] svg,.foot-soc a[title="Авито"] svg{width:94%;height:94%}
.topbar .socials a:hover{transform:translateY(-1px);opacity:.85}
.topbar .socials a:hover{transform:translateY(-1px);opacity:.9}
.topbar .tb-right{display:flex;align-items:center;gap:22px}
.topbar .tb-right a{color:#cfd4dc;transition:.15s}
.topbar .tb-right a:hover{color:#fff}
.tb-loc{display:inline-flex;align-items:center;gap:7px}

.header{position:sticky;top:0;z-index:60;background:var(--ink);border-bottom:1px solid var(--line-dark);transition:box-shadow .2s}
.header.scrolled{box-shadow:0 10px 30px -14px rgba(0,0,0,.45)}
.header .container{display:flex;align-items:center;gap:14px;height:74px}
.logo{display:flex;align-items:center;gap:11px;flex:0 0 auto}
.logo img{height:42px;width:auto;display:block}
.logo .lt b{display:block;font-family:var(--display);font-size:18px;font-weight:600;letter-spacing:.04em;line-height:1;color:#fff;text-transform:uppercase;white-space:nowrap}
.logo .lt span{display:block;font-size:9.5px;text-transform:uppercase;color:#8b93a1;margin-top:3px;letter-spacing:.275em;white-space:nowrap;text-indent:.275em;text-align:center}
.nav{display:flex;align-items:center;gap:0;margin-left:4px;flex-wrap:nowrap;list-style:none;padding:0}
.nav > li{position:relative}
.nav > li > a{display:flex;align-items:center;gap:5px;padding:8px 8px;font-size:12px;font-weight:600;letter-spacing:0;color:#d4d8df;border-radius:8px;white-space:nowrap;transition:.15s;text-transform:uppercase}
.nav > li > a:hover{color:#fff;background:rgba(255,255,255,.07)}
.nav .caret{width:8px;height:8px;opacity:.55;transition:transform .2s;flex:0 0 auto}
.nav > li:hover .caret{transform:rotate(180deg)}
.dropdown{position:absolute;top:calc(100% + 6px);left:0;background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:8px;box-shadow:var(--shadow-lg);opacity:0;visibility:hidden;transform:translateY(8px);transition:.18s;z-index:5}
.dropdown.menu1{min-width:240px}
.nav > li:hover .dropdown{opacity:1;visibility:visible;transform:translateY(0)}
.dropdown.brands{display:grid;grid-template-columns:repeat(3,minmax(120px,1fr));gap:2px}
.dropdown a{display:block;padding:9px 14px;font-size:13.5px;font-weight:500;color:var(--txt-2);border-radius:8px;white-space:nowrap;transition:.12s;text-transform:none}
.dropdown a:hover{background:var(--red-soft);color:var(--red)}
.header .hactions{margin-left:auto;display:flex;align-items:center;gap:10px;flex:0 0 auto}
.header .htel{display:flex;flex-direction:column;align-items:flex-end;justify-content:center;line-height:1.15;text-align:right;transition:color .15s}
.header .htel b{font-family:var(--display);font-size:17px;font-weight:600;letter-spacing:.01em;color:#fff;white-space:nowrap}
.header .htel span{font-size:10.5px;color:#8b93a1}
.header .htel:hover b{color:var(--red)}
.burger{display:none;width:46px;height:46px;border-radius:10px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16);color:#fff;align-items:center;justify-content:center}

/* mobile menu */
.mmenu{position:fixed;inset:0;z-index:90;background:var(--ink);color:#fff;transform:translateX(100%);transition:transform .3s;display:flex;flex-direction:column;overflow-y:auto}
.mmenu.open{transform:translateX(0)}
.mmenu-top{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--line-dark)}
.mmenu-top .logo img{height:40px}
.mmenu nav{padding:14px 22px}
.mmenu nav a{display:block;padding:14px 0;font-size:16px;border-bottom:1px solid var(--line-dark);font-weight:600;color:#e7e9ed;text-transform:uppercase;letter-spacing:.02em}
.mmenu .mm-foot{padding:22px;margin-top:auto;border-top:1px solid var(--line-dark);display:flex;flex-direction:column;gap:12px}

/* ============================================================
   HERO  (light)
   ============================================================ */
.hero{position:relative;overflow:hidden;background:var(--bg-soft);border-bottom:1px solid var(--line)}
.hero::before{content:"";position:absolute;top:-180px;right:-160px;width:620px;height:620px;border-radius:50%;background:radial-gradient(circle,rgba(209,44,61,.08),transparent 68%);z-index:0}
.hero-inner{position:relative;z-index:1;display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:center;padding:58px 0 50px}
.hero .eyebrow{display:inline-flex;align-items:center;gap:8px;white-space:nowrap;max-width:100%;overflow:hidden;text-overflow:ellipsis;font-size:12px;font-weight:700;letter-spacing:.06em;color:var(--muted);text-transform:uppercase;padding:8px 15px;border:1px solid var(--line-2);border-radius:100px;background:#fff;margin-bottom:22px}
.hero .eyebrow b{color:var(--red);font-weight:700}
.hero h1{font-family:var(--display);font-size:clamp(32px,4.4vw,52px);font-weight:600;line-height:1.04;letter-spacing:.005em;text-transform:uppercase;color:var(--ink)}
.hero h1 .l2{display:block;font-size:.56em;font-weight:500;color:var(--txt-2);margin-top:14px;letter-spacing:.01em;text-transform:none;font-family:var(--font)}
.hero h1 .l2 b{color:var(--red);font-weight:700}
.hero .lead{color:var(--txt-2);font-size:17px;line-height:1.6;max-width:540px;margin-top:22px}
.hero-form{display:flex;gap:10px;margin-top:28px;max-width:560px;flex-wrap:wrap}
.field{position:relative;flex:1;min-width:170px}
.field input{width:100%;height:54px;border-radius:var(--r);border:1.5px solid var(--line-2);background:#fff;color:var(--txt);padding:0 18px;font-size:15px;outline:none;transition:.15s}
.field input::placeholder{color:var(--muted-2)}
.field input:focus{border-color:var(--red);box-shadow:0 0 0 3px var(--red-soft)}
.hero-form .btn{height:54px;flex:0 0 auto}
.consent{font-size:12px;color:var(--muted-2);margin-top:14px;max-width:520px}
.consent a{color:var(--muted);text-decoration:underline}

.hero-media{position:relative}
.hero-media .shot{position:relative;border-radius:var(--r-xl);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow-lg);aspect-ratio:4/3.2}
.hero-media .shot img{width:100%;height:100%;object-fit:cover}
.hero-badge{position:absolute;left:-18px;bottom:24px;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:16px 20px;box-shadow:var(--shadow);display:flex;align-items:center;gap:14px}
.hero-badge .hb-ic{width:44px;height:44px;border-radius:11px;background:var(--red-soft);color:var(--red);display:flex;align-items:center;justify-content:center;flex:0 0 auto}
.hero-badge b{font-family:var(--display);font-size:22px;color:var(--ink);display:block;line-height:1}
.hero-badge span{font-size:12.5px;color:var(--muted)}
.hero-rate{position:absolute;left:-12px;top:22px;background:var(--ink);color:#fff;border-radius:var(--r-lg);padding:13px 18px;box-shadow:var(--shadow);display:flex;gap:16px}
.hero-rate .hr{text-align:center}
.hero-rate .hr b{font-family:var(--display);font-size:20px;line-height:1;display:block}
.hero-rate .hr .stars{color:var(--gold);font-size:11px;letter-spacing:1px}
.hero-rate .hr span{font-size:10.5px;color:#9aa0ac}
.hero-rate .hrdiv{width:1px;background:rgba(255,255,255,.14)}
.hero-award{position:absolute;right:20px;bottom:14px;width:76px;filter:drop-shadow(0 8px 18px rgba(0,0,0,.3))}
.hero-award img{width:100%;height:auto;display:block}

/* feature tiles strip (below hero) */
.hero-tiles{position:relative;z-index:1;display:grid;grid-template-columns:repeat(4,1fr);gap:16px;padding:0 0 60px}
.ftile{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:20px;box-shadow:var(--shadow-sm)}
.ftile .fi{width:42px;height:42px;border-radius:11px;background:var(--red-soft);color:var(--red);display:flex;align-items:center;justify-content:center;margin-bottom:14px}
.ftile h4{font-size:16px;font-weight:700;margin-bottom:5px;color:var(--ink)}
.ftile p{font-size:13px;color:var(--muted);line-height:1.45}
a.ftile{text-decoration:none;color:inherit;transition:.16s;display:block}
a.ftile:hover{border-color:var(--line-2);box-shadow:var(--shadow);transform:translateY(-3px)}
a.ftile:hover h4{color:var(--red)}

/* ============================================================
   STATS
   ============================================================ */
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.stat{text-align:center;padding:34px 18px;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-sm)}
.stat b{font-family:var(--display);display:block;font-size:52px;font-weight:600;line-height:1;color:var(--ink)}
.stat b em{font-style:normal;color:var(--red)}
.stat .stat-div{width:46px;height:3px;background:var(--red-2);margin:14px auto 12px;border-radius:2px}
.stat span{display:block;color:var(--muted);font-size:14.5px}

/* ============================================================
   VARIANT CARDS  (white, image on top)
   ============================================================ */
.vargrid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.vcard{position:relative;display:flex;flex-direction:column;padding:250px 24px 24px;border-radius:var(--r-lg);border:1px solid var(--line);background:#fff;box-shadow:var(--shadow-sm);overflow:hidden;transition:.18s;min-height:auto}
.vcard:hover{box-shadow:var(--shadow);transform:translateY(-3px)}
.vcard-bg{position:absolute;top:0;left:0;right:0;height:230px;z-index:0;overflow:hidden;border-bottom:1px solid var(--line)}
.vcard-bg img{width:100%;height:100%;object-fit:cover;object-position:center 28%}
.vcard-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(21,27,38,.05),rgba(21,27,38,.28))}
.vcard > *:not(.vcard-bg){position:relative;z-index:1}
.vcard h3{font-family:var(--display);font-size:21px;font-weight:600;letter-spacing:.01em;text-transform:uppercase;color:var(--ink)}
.vcard p.vdesc{font-size:13.5px;color:var(--txt-2);line-height:1.55;margin-top:9px}
.vcard .vprice{font-family:var(--display);font-size:30px;font-weight:600;color:var(--ink);margin-top:16px;letter-spacing:.01em}
.vcard .vwarr{display:inline-flex;align-items:center;gap:8px;font-size:13px;color:var(--muted);margin-top:4px;margin-bottom:18px}
.vcard .vwarr .dot{width:7px;height:7px;border-radius:50%;background:var(--red)}
.vcard .btn{margin-top:auto}

/* wide trade-in card */
.vcard.wide{grid-column:1/-1;flex-direction:row;align-items:stretch;padding:0;min-height:auto}
.vcard.wide .vcard-bg{position:relative;width:300px;height:auto;flex:0 0 300px;border-bottom:0;border-right:1px solid var(--line)}
.vcard.wide .vcard-bg::after{background:linear-gradient(90deg,rgba(21,27,38,.12),rgba(21,27,38,.28))}
.vcard.wide .vc-main{flex:1;padding:30px 34px;display:flex;flex-direction:column;justify-content:center}
.vcard.wide .vc-main h3{font-size:24px}
.vcard.wide .vc-main .vprice{margin-top:14px}
.vcard.wide .vc-actions{display:flex;align-items:center;padding:30px 34px 30px 0}
.disclaimer{font-size:12.5px;color:var(--muted-2);margin-top:18px;max-width:760px}

/* ============================================================
   CERTIFICATES
   ============================================================ */
.certgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;align-items:start}
.cert{margin:0}
.cert .cert-img{border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--line);background:#fff;aspect-ratio:3/4;box-shadow:var(--shadow-sm);transition:.18s}
.cert.landscape .cert-img{aspect-ratio:4/3}
.cert .cert-img img{width:100%;height:100%;object-fit:contain;padding:8px;display:block}
.cert:hover .cert-img{box-shadow:var(--shadow);transform:translateY(-3px)}
.cert figcaption{margin-top:13px;font-size:13.5px;color:var(--txt-2);line-height:1.45;text-align:center}

/* ============================================================
   INTRO / ABOUT
   ============================================================ */
.intro{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center}
.intro .ph{border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--line);aspect-ratio:16/11;box-shadow:var(--shadow)}
.intro .ph img{width:100%;height:100%;object-fit:cover}
.intro p{color:var(--txt-2);font-size:15.5px;line-height:1.7;margin-top:16px}
.intro .lead-p{font-size:18px;color:var(--txt)}
.intro-media-mob{display:none}

/* gallery */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.gallery .g{border-radius:var(--r);overflow:hidden;border:1px solid var(--line);aspect-ratio:4/3;box-shadow:var(--shadow-sm)}
.gallery .g img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.gallery .g:hover img{transform:scale(1.06)}

/* brands */
.brands{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}
.brand{padding:11px 22px;border:1px solid var(--line-2);border-radius:100px;font-family:var(--display);font-size:15px;font-weight:500;letter-spacing:.08em;color:var(--txt-2);text-transform:uppercase;background:#fff;transition:.15s}
.brand:hover{color:var(--red);border-color:var(--red);box-shadow:var(--shadow-sm)}
.brand.has-logo{display:inline-flex;align-items:center;gap:9px}
.brand.has-logo .blogo{width:18px;height:18px;flex:none;background:var(--ink);transition:.14s}
.brand.has-logo:hover .blogo{background:var(--red)}
.brand-logo.has-logo{justify-content:flex-start;gap:11px}
.brand-logo.has-logo .brand-badge{margin-left:auto}
.brand-logo .blogo-lg{width:26px;height:26px;flex:none;background:var(--ink)}

/* ============================================================
   CTA BAND  (dark accent)
   ============================================================ */
.ctaband{position:relative;overflow:hidden;background:var(--ink)}
.ctaband::after{content:"";position:absolute;inset:0;background:radial-gradient(70% 130% at 85% 10%,rgba(209,44,61,.28),transparent 60%)}
.ctaband .container{position:relative;z-index:1;display:flex;align-items:center;justify-content:space-between;gap:40px;padding:56px 24px;flex-wrap:wrap}
.ctaband h2{font-family:var(--display);font-size:clamp(24px,3vw,36px);font-weight:600;letter-spacing:.01em;text-transform:uppercase;color:#fff;max-width:560px}
.ctaband h2 b{color:var(--red)}
.ctaband p{color:#aab1bd;margin-top:12px;max-width:520px}
.ctaband:not(.sec){background:var(--bg-soft);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.ctaband:not(.sec)::after{background:radial-gradient(70% 130% at 85% 10%,rgba(209,44,61,.08),transparent 60%)}
.ctaband:not(.sec) h2{color:var(--ink)}
.ctaband:not(.sec) p{color:var(--muted)}
.ctaband.light h2{color:var(--ink)}
.ctaband.light p{color:var(--muted)}
.ctaband-form{display:flex;gap:12px;flex-wrap:wrap;min-width:300px;flex:1;max-width:540px}
.ctaband-form .field input{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.16);color:#fff}
.ctaband-form .field input::placeholder{color:#8b93a1}
.ctaband-form .field input:focus{border-color:var(--red);box-shadow:none}

/* ============================================================
   ADVANTAGES
   ============================================================ */
.advgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.adv{padding:30px 28px;border:1px solid var(--line);border-radius:var(--r-lg);background:#fff;box-shadow:var(--shadow-sm);transition:.18s}
.adv:hover{box-shadow:var(--shadow);transform:translateY(-3px);border-color:var(--line-2)}
.adv .an{font-family:var(--display);font-size:15px;font-weight:600;letter-spacing:.1em;color:var(--red);margin-bottom:16px}
.adv .ai{width:50px;height:50px;border-radius:13px;background:var(--red-soft);color:var(--red);display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.adv h3{font-family:var(--display);font-size:19px;font-weight:600;text-transform:uppercase;letter-spacing:.01em;margin-bottom:10px;color:var(--ink)}
.adv p{color:var(--muted);font-size:14px;line-height:1.6}

/* ============================================================
   REVIEWS (Yandex + Avito tabs)
   ============================================================ */
.rev-tabs{display:flex;gap:10px;margin-bottom:24px}
.rev-tab{display:inline-flex;align-items:center;gap:10px;padding:11px 20px;border:1.5px solid var(--line-2);border-radius:100px;background:#fff;font-size:14.5px;font-weight:600;color:var(--txt-2);transition:.15s}
.rev-tab .rstar{color:var(--gold);font-size:12px;letter-spacing:.5px}
.rev-tab .rnum{font-family:var(--display);font-size:16px;color:var(--ink)}
.rev-tab.active{border-color:var(--red);background:var(--red-soft);color:var(--red)}
.rev-tab.active .rnum{color:var(--red)}
.rev-panel{display:none}
.rev-panel.active{display:block}
.reviews-wrap{background:#fff;border:1px solid var(--line);border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--shadow-sm)}
.reviews-widget{width:100%;height:560px;border:0;display:block}
.avito-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.acard{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:24px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column}
.acard .ahead{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.acard .aav{width:44px;height:44px;border-radius:50%;background:var(--bg-soft2);display:flex;align-items:center;justify-content:center;font-family:var(--display);font-weight:600;color:var(--ink);flex:0 0 auto}
.acard .an2{font-weight:700;font-size:14.5px;color:var(--ink)}
.acard .adate{font-size:12px;color:var(--muted-2)}
.acard .astars{color:var(--gold);font-size:13px;letter-spacing:1px;margin-bottom:10px}
.acard p{font-size:14px;color:var(--txt-2);line-height:1.6;flex:1}
.acard .acar{margin-top:14px;font-size:12.5px;color:var(--muted);border-top:1px solid var(--line);padding-top:12px}
.avito-foot{display:flex;align-items:center;justify-content:space-between;gap:18px;margin-top:20px;padding:18px 24px;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);flex-wrap:wrap}
.avito-foot .af-rate{display:flex;align-items:center;gap:14px}
.avito-foot .af-num{font-family:var(--display);font-size:34px;color:var(--ink);line-height:1}
.avito-foot .af-meta .astars{color:var(--gold);font-size:14px;letter-spacing:1px}
.avito-foot .af-meta span{font-size:13px;color:var(--muted)}

/* ============================================================
   ACCORDION
   ============================================================ */
.steps{display:grid;grid-template-columns:1fr;gap:12px}
.step{border:1px solid var(--line);border-radius:var(--r-lg);background:#fff;box-shadow:var(--shadow-sm);overflow:hidden;transition:.15s}
.step.open{border-color:var(--line-2);box-shadow:var(--shadow-sm)}
.step-head{display:flex;align-items:center;gap:20px;padding:22px 26px;width:100%;background:none;border:0;color:inherit;text-align:left}
.step-head .sn{font-family:var(--display);font-size:18px;font-weight:600;color:var(--red);flex:0 0 auto;min-width:34px}
.step-head h3{font-family:var(--display);font-size:18px;font-weight:500;text-transform:uppercase;letter-spacing:.01em;flex:1;color:var(--ink)}
.step-head .plus{width:30px;height:30px;flex:0 0 auto;position:relative;border:1px solid var(--line-2);border-radius:8px}
.step-head .plus::before,.step-head .plus::after{content:"";position:absolute;background:var(--red);top:50%;left:50%;transform:translate(-50%,-50%)}
.step-head .plus::before{width:13px;height:2px}
.step-head .plus::after{width:2px;height:13px;transition:transform .25s}
.step.open .plus::after{transform:translate(-50%,-50%) scaleY(0)}
.step-body{max-height:0;overflow:hidden;transition:max-height .3s ease}
.step-body p{padding:0 26px 22px 80px;color:var(--muted);font-size:14.5px;line-height:1.65}

/* FAQ (accordion variant, no numbers) */
.faq .step-head{gap:16px;padding:20px 24px}
.faq .step-head h3{text-transform:none;font-weight:600;font-size:16.5px;letter-spacing:0;line-height:1.4}
.faq .step-body p{padding:0 24px 20px 24px}
.faq-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;align-items:start}
@media(max-width:760px){.faq-grid{grid-template-columns:1fr}}

/* «Что входит в капремонт» — прозрачность цены */
.inc{display:grid;grid-template-columns:340px 1fr;gap:40px;align-items:center}
.inc-aside .inc-price{font-family:var(--display);font-size:40px;font-weight:700;color:var(--ink);line-height:1;letter-spacing:-.01em}
.inc-aside .inc-price span{display:block;font-family:var(--body);font-size:14px;font-weight:500;color:var(--muted);margin-top:8px}
.inc-aside p{color:var(--txt-2);font-size:15px;line-height:1.6;margin-top:18px}
.inc-note{margin-top:18px;display:flex;gap:10px;align-items:flex-start;background:var(--red-soft);border-radius:var(--r-lg);padding:14px 16px}
.inc-note svg{flex:0 0 auto;color:var(--red);margin-top:1px}
.inc-note span{font-size:13.5px;line-height:1.5;color:var(--ink);font-weight:500}
.inc-list{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.inc-item{display:flex;gap:12px;align-items:flex-start;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:16px 18px;box-shadow:var(--shadow-sm)}
.inc-item .ic{flex:0 0 auto;width:26px;height:26px;border-radius:50%;background:var(--red-soft);color:var(--red);display:flex;align-items:center;justify-content:center;margin-top:1px}
.inc-item span{font-size:14.5px;line-height:1.45;color:var(--txt);font-weight:500}
@media(max-width:880px){.inc{grid-template-columns:1fr;gap:26px}}
@media(max-width:560px){.inc-list{grid-template-columns:1fr}}

/* ============================================================
   VIDEO (dark accent)
   ============================================================ */
.video-grid{display:grid;grid-template-columns:1.6fr 1fr;gap:20px}
.video-main{border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--line-dark);background:#000}
.video-main iframe{width:100%;aspect-ratio:16/9;border:0;display:block}
.video-main .vcap{padding:16px 20px;background:var(--ink-2)}
.video-main .vcap h4{color:#fff;font-size:16px;font-weight:600}
.video-list{display:flex;flex-direction:column;gap:12px}
.vli{display:flex;gap:14px;padding:12px;border:1px solid var(--line-dark);border-radius:var(--r);background:var(--ink-2);cursor:pointer;transition:.15s}
.vli:hover{border-color:var(--red);background:#222b3a}
.vli.active{border-color:var(--red)}
.vli .vth{width:112px;aspect-ratio:16/9;border-radius:8px;background:#0c1119;flex:0 0 auto;display:flex;align-items:center;justify-content:center;color:var(--red);position:relative;overflow:hidden}
.vli .vth img{width:100%;height:100%;object-fit:cover;opacity:.7}
.vli .vth .vpl{position:absolute;inset:0;display:flex;align-items:center;justify-content:center}
.vli .vinfo{display:flex;flex-direction:column;justify-content:center}
.vli h4{font-size:13.5px;font-weight:600;line-height:1.35;color:#fff}
.vli span{font-size:12px;color:#9aa0ac;margin-top:4px}

/* ============================================================
   CATALOG
   ============================================================ */
.cat-tabs{display:flex;gap:10px;margin-bottom:26px;flex-wrap:wrap}
.cat-tab{padding:10px 20px;border:1.5px solid var(--line-2);border-radius:100px;font-size:14px;font-weight:600;color:var(--txt-2);background:#fff;transition:.15s}
.cat-tab.active{background:var(--red);border-color:var(--red);color:#fff}
.prodgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.prod{border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;background:#fff;box-shadow:var(--shadow-sm);transition:.18s}
.prod:hover{box-shadow:var(--shadow);transform:translateY(-3px)}
.prod .pimg{position:relative;aspect-ratio:4/3;background:var(--bg-soft2)}
.prod .pimg img{width:100%;height:100%;object-fit:cover}
.prod .pbadge{position:absolute;top:12px;right:12px;background:var(--green-soft);color:var(--green);font-size:11.5px;font-weight:700;padding:5px 11px;border-radius:100px}
.prod .pbadge.order{background:#e9ebee;color:#6b7280}
.prod .pbody{padding:18px 20px}
.prod .ptag{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--red);font-weight:700}
.prod h3{font-family:var(--display);font-size:17px;font-weight:600;text-transform:uppercase;letter-spacing:.01em;margin:7px 0 12px;color:var(--ink)}
.prod .pmeta{display:flex;justify-content:space-between;align-items:center;border-top:1px solid var(--line);padding-top:14px}
.prod .pprice b{font-family:var(--display);font-size:20px;font-weight:600;color:var(--ink)}
.prod .pprice span{font-size:12px;color:var(--muted);display:block}

/* ============================================================
   ARTICLES
   ============================================================ */
.artgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.art{border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;background:#fff;box-shadow:var(--shadow-sm);transition:.18s}
.art:hover{box-shadow:var(--shadow);transform:translateY(-3px)}
.art .aimg{aspect-ratio:16/10;background:var(--bg-soft2)}
.art .aimg img{width:100%;height:100%;object-fit:cover}
.art .abody{padding:20px 22px}
.art .acat{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--red);font-weight:700}
.art h3{font-size:17px;font-weight:700;line-height:1.32;margin:9px 0 10px;color:var(--ink)}
.art p{color:var(--muted);font-size:14px;line-height:1.55}
.art .alink{display:inline-flex;align-items:center;gap:7px;color:var(--red);font-size:14px;font-weight:600;margin-top:14px}
a.art{display:block;text-decoration:none;color:inherit}
a.art:hover{border-color:var(--line-2);box-shadow:var(--shadow);transform:translateY(-3px)}
a.art:hover .alink{gap:12px}

/* ============================================================
   CONTACTS + MAP
   ============================================================ */
.contacts{display:grid;grid-template-columns:.9fr 1.1fr;gap:0;border:1px solid var(--line);border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--shadow-sm)}
.contacts .cinfo{padding:44px 42px;background:#fff}
.contacts .cmap{min-height:440px;background:var(--bg-soft2)}
.contacts .cmap iframe{width:100%;height:100%;border:0;display:block}
.crow{display:flex;gap:16px;padding:18px 0;border-bottom:1px solid var(--line)}
.crow:last-of-type{border-bottom:0}
.crow .ci{width:44px;height:44px;border-radius:11px;background:var(--red-soft);color:var(--red);display:flex;align-items:center;justify-content:center;flex:0 0 auto}
.crow .cl{font-size:13px;color:var(--muted)}
.crow .cv{font-size:18px;font-weight:700;margin-top:2px;color:var(--ink)}
.crow .cv.big{font-family:var(--display);font-size:24px;font-weight:600}

/* ============================================================
   FOOTER (dark)
   ============================================================ */
.footer{background:var(--ink);border-top:1px solid var(--line-dark);padding:60px 0 28px;color:#cfd4dc}
.foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.1fr;gap:40px}
.foot-grid h4{font-family:var(--display);font-size:13px;letter-spacing:.1em;text-transform:uppercase;color:#8b93a1;margin-bottom:18px;font-weight:600}
.foot-grid a{display:block;color:#cfd4dc;font-size:14px;padding:6px 0;transition:.12s}
.foot-grid a:hover{color:var(--red)}
.foot-about .logo{margin-bottom:4px;display:inline-flex;width:fit-content}
.foot-about p{color:#9aa0ac;font-size:14px;line-height:1.6;margin-top:16px}
.foot-soc{display:flex;gap:10px;margin-top:18px}
.foot-soc a{width:38px;height:38px;border-radius:10px;overflow:hidden;display:flex;align-items:center;justify-content:center;transition:.15s;color:#cfd4dc;background:rgba(255,255,255,.08)}
.foot-soc a svg{width:62%;height:62%;fill:currentColor;display:block}
.foot-soc a.has-img{background:rgba(255,255,255,.08)}
.foot-soc a.has-img img{width:100%;height:100%;object-fit:cover;display:block}
.foot-soc a:hover{transform:translateY(-2px);opacity:.9}
.foot-soc a:hover{transform:translateY(-2px);opacity:.9}
.foot-bottom{border-top:1px solid var(--line-dark);margin-top:46px;padding-top:24px;display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;color:#8b93a1;font-size:13px}
.foot-bottom a{color:#aab1bd;text-decoration:underline}
.foot-bottom .fb-links{display:flex;gap:20px;flex-wrap:wrap}

/* whatsapp float */
.wa-float{position:fixed;right:22px;bottom:22px;z-index:80;display:flex;align-items:center;gap:10px;background:#1FA855;color:#fff;height:56px;padding:0 20px;border-radius:100px;font-weight:600;font-size:15px;box-shadow:0 14px 34px -10px rgba(31,168,85,.6);transition:.18s}
.wa-float:hover{background:#178a44;transform:translateY(-2px)}
/* mobile sticky action bar */
.mbar{position:fixed;left:0;right:0;bottom:0;z-index:85;display:none;gap:10px;padding:9px 12px;padding-bottom:calc(9px + env(safe-area-inset-bottom));background:rgba(255,255,255,.94);backdrop-filter:blur(10px);border-top:1px solid var(--line);box-shadow:0 -6px 20px -8px rgba(20,27,38,.18)}
.mbar a{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:8px;height:50px;border-radius:12px;font-weight:600;font-size:15px;letter-spacing:.01em}
.mbar .mbar-call{background:#fff;border:1.5px solid var(--line-2);color:var(--ink)}
.mbar .mbar-lead{background:var(--red);color:#fff;box-shadow:0 8px 20px -10px rgba(209,44,61,.85)}
@media(max-width:760px){.mbar{display:flex}body{padding-bottom:72px}.wa-float{bottom:84px;right:14px}}

/* ============================================================
   SEO TEXT BLOCK  (читаемый текстовый блок для Яндекс/Google)
   ============================================================ */
.seo .container{max-width:1080px}
.seo-text{max-width:920px}
.seo-text h3{font-family:var(--display);font-size:19px;font-weight:600;text-transform:uppercase;letter-spacing:.01em;color:var(--ink);margin:30px 0 8px}
.seo-text p{color:var(--txt-2);font-size:15.5px;line-height:1.78;margin-top:13px}
.seo-text p:first-of-type{margin-top:18px}
.seo-text b{color:var(--ink)}
.seo-text a:not(.btn){color:var(--red);border-bottom:1px solid rgba(209,44,61,.32);transition:.15s;font-weight:500}
.seo-text a:not(.btn):hover{border-bottom-color:var(--red)}
.seo-text ul{margin:12px 0 0;padding:0;list-style:none;display:grid;gap:8px}
.seo-text .seo-cols{display:grid;grid-template-columns:1fr 1fr;gap:6px 44px}
.seo-text ul li{position:relative;padding-left:24px;color:var(--txt-2);font-size:15px;line-height:1.6}
.seo-text ul li::before{content:"";position:absolute;left:3px;top:9px;width:7px;height:7px;border-radius:50%;background:var(--red)}
.seo-text ul li b{font-weight:600}
.seo-tags{display:flex;flex-wrap:wrap;gap:9px;margin-top:30px;padding-top:26px;border-top:1px solid var(--line)}
.seo-tags .stl{flex:0 0 100%;font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted-2);font-weight:700;margin-bottom:2px}
.seo-tags a{font-size:13px;color:var(--txt-2);background:#fff;border:1px solid var(--line-2);border-radius:100px;padding:8px 15px;transition:.14s}
.seo-tags a:hover{border-color:var(--red);color:var(--red);box-shadow:var(--shadow-sm)}
@media(max-width:680px){.seo-text .seo-cols{grid-template-columns:1fr}}

/* ============================================================
   LINK HUB  (перелинковка — карты внутренних ссылок)
   ============================================================ */
.linkhub{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.lh-col{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:24px 24px 12px;box-shadow:var(--shadow-sm);transition:.18s}
.lh-col:hover{box-shadow:var(--shadow);border-color:var(--line-2)}
.lh-col h3{display:flex;align-items:center;gap:10px;font-family:var(--display);font-size:13.5px;font-weight:600;letter-spacing:.09em;text-transform:uppercase;color:var(--muted);margin-bottom:12px;padding-bottom:13px;border-bottom:1px solid var(--line)}
.lh-col h3::before{content:"";width:18px;height:2px;background:var(--red);flex:0 0 auto}
.lh-col a{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:9px 0;font-size:14.5px;font-weight:500;color:var(--txt-2);border-bottom:1px solid var(--line);transition:.13s}
.lh-col a:last-child{border-bottom:0}
.lh-col a:hover{color:var(--red);padding-left:5px}
.lh-col a .lh-meta{font-size:12px;font-weight:500;color:var(--muted-2);white-space:nowrap}
.lh-col a:hover .lh-meta{color:var(--red)}
.lh-col a.lh-all{color:var(--red);font-weight:600}
@media(max-width:880px){.linkhub{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.linkhub{grid-template-columns:1fr}}

/* reveal */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:1100px){
  .nav,.topbar{display:none}
  .burger{display:flex}
  .header .htel{display:none}
  .hero-inner{grid-template-columns:1fr;gap:36px}
  .hero-media{max-width:520px}
  .hero-rate{padding:10px 14px;gap:12px;left:-8px;top:16px}
  .hero-rate .hr b{font-size:17px}
  .hero-badge{padding:11px 14px}
  .hero-badge b{font-size:18px}
  .hero-award{width:74px;right:14px;bottom:12px}
  .video-grid{grid-template-columns:1fr}
  .gallery{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:880px){
  .vargrid,.advgrid,.prodgrid,.artgrid,.stats,.avito-grid,.certgrid{grid-template-columns:1fr 1fr}
  .intro,.contacts{grid-template-columns:1fr}
  .contacts .cmap{min-height:320px}
  .vcard.wide{flex-direction:column}
  .vcard.wide .vcard-bg{width:auto;flex:0 0 200px;border-right:0;border-bottom:1px solid var(--line)}
  .vcard.wide .vc-actions{padding:0 34px 30px}
  .sec{padding:56px 0}
}
@media(max-width:580px){
  .container{padding:0 16px}
  .hero-tiles,.vargrid,.advgrid,.prodgrid,.artgrid,.stats,.gallery,.avito-grid{grid-template-columns:1fr 1fr}
  .stat b{font-size:40px}
  .hero-form{flex-direction:column}
  .hero-form .btn{width:100%}
  .hero-rate{display:none}
  .hero-badge{padding:8px 11px;left:-6px;gap:8px}
  .hero-badge .hb-ic{width:30px;height:30px}
  .hero-badge b{font-size:15px}
  .hero-badge span{font-size:10.5px}
  .hero-award{width:78px;right:10px;bottom:9px}
  .ftile{display:grid;grid-template-columns:auto 1fr;grid-template-rows:auto auto;column-gap:13px;align-items:center;padding:14px 16px}
  .ftile .fi{grid-row:1/3;align-self:center;margin-bottom:0;width:38px;height:38px}
  .ftile h4{grid-column:2;margin-bottom:2px}
  .ftile p{grid-column:2}
  .wa-float span{display:none}
  .wa-float{padding:0;width:56px;justify-content:center}
  .foot-grid{grid-template-columns:1fr 1fr}
  .avito-foot{flex-direction:column;align-items:flex-start}
}
@media(max-width:430px){
  .hero-tiles,.gallery,.prodgrid,.artgrid,.avito-grid,.vargrid,.stats,.advgrid,.certgrid{grid-template-columns:1fr}
  .vcard{padding-top:240px}
  .rev-tabs{flex-wrap:wrap}
  .rev-tab{flex:1 1 auto;justify-content:center}
  .foot-grid{grid-template-columns:1fr}
  .hero-award{width:66px;right:8px;bottom:8px}
  .hero-badge{padding:7px 10px}
  .hero-badge b{font-size:14px}
  .hero-badge .hb-ic{width:26px;height:26px}
}

/* ============================================================
   HEADER SEARCH BUTTON
   ============================================================ */
.search-btn{width:46px;height:46px;border-radius:10px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16);color:#fff;display:flex;align-items:center;justify-content:center;flex:0 0 auto;transition:.15s}
.search-btn:hover{background:var(--red);border-color:var(--red)}
.mmenu .msearch{font-size:17px}

/* ============================================================
   SITE SEARCH OVERLAY (#19)
   ============================================================ */
#searchOverlay{position:fixed;inset:0;z-index:130;display:none}
#searchOverlay.open{display:block}
.so-backdrop{position:absolute;inset:0;background:rgba(10,13,19,.62);backdrop-filter:blur(4px)}
.so-box{position:relative;max-width:640px;margin:9vh auto 0;background:#fff;border-radius:var(--r-lg);box-shadow:var(--shadow-lg);overflow:hidden;animation:soPop .2s ease}
@keyframes soPop{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:none}}
.so-bar{display:flex;align-items:center;gap:12px;padding:16px 18px;border-bottom:1px solid var(--line);color:var(--muted)}
.so-bar input{flex:1;border:none;outline:none;font-size:17px;color:var(--ink);background:none}
.so-close{background:var(--bg-soft2);border:1px solid var(--line);color:var(--muted);border-radius:7px;padding:5px 9px;font-size:11px;font-weight:700;letter-spacing:.04em}
.so-results{max-height:56vh;overflow-y:auto;padding:8px}
.so-hint{padding:22px 16px;color:var(--muted);font-size:14px;text-align:center}
.so-hint a{color:var(--red);font-weight:600}
.so-item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:13px 16px;border-radius:10px;color:var(--txt);font-size:15px;font-weight:500;transition:.12s}
.so-item:hover,.so-item:focus{background:var(--red-soft);color:var(--red)}
.so-go{color:var(--muted);font-size:16px}
.so-item:hover .so-go{color:var(--red)}
@media(max-width:560px){.so-box{margin:0;border-radius:0;height:100%}.so-results{max-height:calc(100% - 70px)}}

/* ============================================================
   LEAD FORM MODAL (#6) — простая форма «оставить контакт»
   ============================================================ */
/* calculator quiz modal — light theme (styles injected from site.js) */
#calcModal .cm-dialog{color:var(--txt)}
#leadModal{position:fixed;inset:0;z-index:130;display:none;align-items:center;justify-content:center;padding:20px}
#leadModal.open{display:flex}
.lm-backdrop{position:absolute;inset:0;background:rgba(10,13,19,.7);backdrop-filter:blur(5px)}
.lm-dialog{position:relative;width:460px;max-width:100%;background:#fff;border-radius:var(--r-xl);box-shadow:var(--shadow-lg);padding:40px 38px 32px;animation:soPop .22s ease}
.lm-close{position:absolute;top:16px;right:16px;width:36px;height:36px;border-radius:9px;background:var(--bg-soft2);border:1px solid var(--line);color:var(--muted);font-size:14px}
.lm-close:hover{color:var(--ink);background:var(--line)}
.lm-head{margin-bottom:22px}
.lm-ctx{display:none;align-items:center;gap:9px;max-width:100%;background:var(--red-soft);color:var(--red);border-radius:100px;padding:7px 15px 7px 13px;font-size:12.5px;font-weight:700;line-height:1.2;margin-bottom:14px}
.lm-ctx .cm-ctx-dot{width:7px;height:7px;border-radius:50%;background:var(--red);flex:0 0 auto}
.lm-head h3{font-family:var(--display);font-size:25px;font-weight:600;line-height:1.12;text-transform:uppercase;color:var(--ink);letter-spacing:.01em}
.lm-head h3 .red{color:var(--red)}
.lm-head p{font-size:14px;color:var(--muted);margin-top:10px;line-height:1.5}
.lm-form{display:flex;flex-direction:column;gap:12px}
.lm-form .field{flex:none}
.lm-consent{display:flex;align-items:flex-start;gap:9px;font-size:11.5px;color:var(--muted);line-height:1.45;margin-top:2px}
.lm-consent input{margin-top:2px;flex:0 0 auto}
.lm-consent a{color:var(--muted);text-decoration:underline}
.lm-done{text-align:center;padding:8px 0}
.lm-check{width:62px;height:62px;border-radius:50%;background:#1FA855;color:#fff;font-size:30px;display:flex;align-items:center;justify-content:center;margin:0 auto 18px}
.lm-done h3{font-family:var(--display);font-size:24px;font-weight:600;text-transform:uppercase;color:var(--ink)}
.lm-done p{color:var(--muted);font-size:14px;line-height:1.6;margin:12px 0 22px}
.lm-done p b{color:var(--txt)}
@media(max-width:520px){.lm-dialog{padding:34px 22px 24px}.lm-head h3{font-size:22px}}

/* heading marker — чистый чёрный текст без подложки */
.hl-mark{color:var(--ink)}
/* убраны иконки в блоках-карточках (этапы/сценарии/гарантии) — глобально */
.iconrow .ic{display:none!important}

/* ============================================================
   #7 — ЧТО ВХОДИТ В КАПРЕМОНТ + ФОРМА «РАССЧИТАТЬ СТОИМОСТЬ»
   ============================================================ */
.kr-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:42px}
.kr-item{position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:26px 22px 24px;transition:.18s;overflow:hidden}
.kr-item::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--red);transform:scaleY(0);transform-origin:top;transition:transform .22s}
.kr-item:hover{border-color:var(--red-soft);box-shadow:var(--shadow);transform:translateY(-3px)}
.kr-item:hover::before{transform:scaleY(1)}
.kr-n{font-family:var(--mono,ui-monospace,monospace);font-size:13px;font-weight:600;letter-spacing:.1em;color:var(--red)}
.kr-item h3{font-family:var(--display);font-weight:600;font-size:18px;color:var(--ink);margin:12px 0 8px;line-height:1.18}
.kr-item p{font-size:13.5px;color:var(--muted);line-height:1.5}
.kr-item .kr-price{display:inline-block;margin-top:12px;font-size:12.5px;font-weight:600;color:var(--txt);background:var(--bg-soft2);border-radius:7px;padding:4px 10px}
.kr-cta{display:grid;grid-template-columns:1.05fr .95fr;gap:0;margin-top:40px;background:var(--bg-soft);border:1px solid var(--line);border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--shadow-lg)}
.kr-cta-copy{padding:46px 48px;color:var(--txt);display:flex;flex-direction:column;justify-content:center;background:var(--bg-soft)}
.kr-cta-copy .kicker{color:var(--red)}
.kr-cta-copy h3{font-family:var(--display);font-weight:600;font-size:30px;line-height:1.12;color:var(--ink);margin:10px 0 14px}
.kr-cta-copy h3 .red{color:var(--red)}
.kr-cta-copy p{font-size:15.5px;line-height:1.6;color:var(--muted);max-width:440px}
.kr-bullets{display:flex;flex-wrap:wrap;gap:8px 16px;margin-top:20px}
.kr-bullets span{font-size:13px;color:var(--txt);display:inline-flex;align-items:center;gap:7px}
.kr-bullets span::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--red)}
.kr-form{background:#fff;padding:40px 42px;display:flex;flex-direction:column;gap:12px;justify-content:center}
.kr-form h4{font-family:var(--display);font-weight:600;font-size:21px;color:var(--ink);text-transform:uppercase;letter-spacing:.01em;margin-bottom:6px}
.kr-form h4 .red{color:var(--red)}
.kr-form .field{flex:none}
.kr-form .consent{font-size:11.5px;color:var(--muted);line-height:1.45;margin-top:2px}
.kr-form .consent a{color:var(--muted);text-decoration:underline}
@media(max-width:980px){
  .kr-grid{grid-template-columns:repeat(2,1fr)}
  .kr-cta{grid-template-columns:1fr}
  .kr-cta-copy{padding:34px 28px}
  .kr-cta-copy h3{font-size:25px}
  .kr-form{padding:30px 28px}
}
@media(max-width:560px){ .kr-grid{grid-template-columns:1fr} }

/* ============================================================
   #8 — ЦЕННОСТЬ БЕСПЛАТНОЙ ДИАГНОСТИКИ
   ============================================================ */
.dv-wrap{display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:center}
.dv-copy .h-sec{margin-bottom:14px}
.dv-copy .h-sec .red{color:var(--red)}
.dv-copy>p{font-size:16px;line-height:1.65;color:var(--txt);max-width:560px}
.dv-list{list-style:none;margin:24px 0 28px;display:flex;flex-direction:column;gap:13px}
.dv-list li{position:relative;padding-left:38px;font-size:15.5px;line-height:1.45;color:var(--txt)}
.dv-list li b{color:var(--ink)}
.dv-list li::before{content:"";position:absolute;left:0;top:-2px;width:25px;height:25px;border-radius:50%;background:var(--red-soft);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23d12c3d' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6L9 17l-5-5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:center}
.dv-media{position:relative}
.dv-media img{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:var(--r-xl);box-shadow:var(--shadow-lg)}
.dv-badge{position:absolute;left:-20px;bottom:-20px;background:var(--red);color:#fff;border-radius:var(--r-lg);padding:20px 26px;box-shadow:var(--shadow-lg);text-align:center}
.dv-badge b{display:block;font-family:var(--display);font-weight:700;font-size:42px;line-height:1}
.dv-badge span{font-size:12.5px;opacity:.92;letter-spacing:.02em;margin-top:4px;display:block;max-width:130px}
.dv-note{margin-top:14px;font-size:13px;color:var(--muted)}
.dv-media-mob{display:none}
@media(max-width:880px){
  .dv-media{display:none}
  .dv-media-mob{display:block;position:relative;max-width:440px;margin:20px 0 26px}
  .dv-media-mob img{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:var(--r-xl);box-shadow:var(--shadow-lg)}
  .dv-media-mob .dv-badge{left:auto;right:18px;bottom:-16px;padding:16px 20px}
  .dv-media-mob .dv-badge b{font-size:34px}
  .dv-wrap{grid-template-columns:1fr;gap:34px}
  .dv-media{max-width:440px}
  .dv-badge{left:auto;right:18px;bottom:-16px;padding:16px 20px}
  .dv-badge b{font-size:34px}
}

/* short certificates (#13) */
.certgrid.compact{display:flex;flex-wrap:wrap;gap:18px;justify-content:center}
.certgrid.compact .cert{width:210px;flex:0 0 auto}
.certgrid.compact .cert-img{aspect-ratio:3/4}
.certrow-note{text-align:center;margin-top:22px;font-size:14px;color:var(--muted)}
.certrow-note a{color:var(--red);font-weight:600}

/* ============================================================
   COOKIE / CONSENT BANNER + SETTINGS MODAL (#1) — 152-ФЗ
   ============================================================ */
.ck-bar{position:fixed;left:0;right:0;bottom:0;z-index:140;background:var(--ink);color:#cfd4dc;border-top:3px solid var(--red);box-shadow:0 -16px 50px -20px rgba(0,0,0,.7);transform:translateY(110%);transition:transform .38s cubic-bezier(.2,.7,.2,1)}
.ck-bar.show{transform:translateY(0)}
.ck-inner{max-width:var(--maxw);margin:0 auto;padding:22px 28px;display:flex;align-items:center;gap:34px}
.ck-body{flex:1}
.ck-tag{display:inline-flex;align-items:center;gap:9px;font-family:var(--mono,ui-monospace,monospace);font-size:12px;font-weight:600;letter-spacing:.14em;color:var(--red);text-transform:uppercase;margin-bottom:11px}
.ck-dot{width:8px;height:8px;border-radius:50%;background:var(--red);box-shadow:0 0 0 4px rgba(209,44,61,.18)}
.ck-txt{line-height:1.55;font-size:15px;color:#c3c9d2;max-width:780px}
.ck-txt a{color:#fff;text-decoration:underline;text-underline-offset:2px}
.ck-act{display:flex;align-items:stretch;gap:10px;flex:0 0 auto}
.ck-btn{font-family:var(--display);font-weight:600;font-size:15px;border-radius:11px;padding:14px 26px;transition:.16s;white-space:nowrap;letter-spacing:.01em;cursor:pointer;display:inline-flex;align-items:center;gap:9px}
.ck-btn-primary{background:var(--red);color:#fff;border:1px solid var(--red)}
.ck-btn-primary:hover{background:var(--red-600);border-color:var(--red-600)}
.ck-btn-primary span{transition:transform .16s}
.ck-btn-primary:hover span{transform:translateX(4px)}
.ck-btn-line{background:transparent;color:#e7eaef;border:1px solid rgba(255,255,255,.28);text-transform:uppercase;font-size:13px;letter-spacing:.06em}
.ck-btn-line:hover{border-color:#fff;background:rgba(255,255,255,.06)}
.ck-btn-ghost{background:transparent;color:#7e8794;border:1px solid rgba(255,255,255,.14);text-transform:uppercase;font-size:13px;letter-spacing:.06em}
.ck-btn-ghost:hover{color:#cfd4dc;border-color:rgba(255,255,255,.3)}
/* settings modal */
.ck-modal{position:fixed;inset:0;z-index:150;display:none;align-items:center;justify-content:center;padding:24px}
.ck-modal.open{display:flex}
.ck-mback{position:absolute;inset:0;background:rgba(8,10,15,.74);backdrop-filter:blur(5px)}
.ck-mbox{position:relative;width:920px;max-width:100%;max-height:90vh;overflow-y:auto;background:var(--ink);color:#cfd4dc;border:1px solid var(--red);border-radius:18px;box-shadow:0 40px 90px -30px rgba(0,0,0,.8);padding:42px 46px 38px;animation:soPop .24s ease}
.ck-mtop{display:flex;align-items:center;justify-content:space-between;margin-bottom:22px}
.ck-mtop .ck-tag{margin-bottom:0}
.ck-back{background:none;border:none;color:#8b93a1;font-size:15px;cursor:pointer;transition:.15s}
.ck-back:hover{color:#fff}
.ck-mtitle{font-family:var(--display);font-weight:600;font-size:32px;color:#fff;letter-spacing:.005em;margin-bottom:26px}
.ck-opts{display:flex;flex-direction:column;gap:14px;margin-bottom:28px}
.ck-opt{display:flex;align-items:center;justify-content:space-between;gap:24px;background:rgba(255,255,255,.03);border:1px solid var(--line-dark);border-radius:13px;padding:22px 26px}
.ck-otext b{display:block;font-family:var(--display);font-weight:600;font-size:21px;color:#fff;margin-bottom:7px}
.ck-otext em{font-style:normal;color:#8b93a1;font-size:15px;line-height:1.5}
.ck-on{font-family:var(--mono,ui-monospace,monospace);font-size:12px;letter-spacing:.1em;color:#6f7783;flex:0 0 auto}
.ck-tog{width:58px;height:30px;border-radius:30px;background:#3a414c;border:none;position:relative;flex:0 0 auto;cursor:pointer;transition:.18s}
.ck-tog::after{content:"";position:absolute;top:3px;left:3px;width:24px;height:24px;border-radius:50%;background:#fff;transition:.18s}
.ck-tog.on{background:var(--red)}
.ck-tog.on::after{transform:translateX(28px)}
.ck-mact{display:flex;gap:12px}
@media(max-width:880px){
  .ck-inner{flex-direction:column;align-items:stretch;gap:18px;padding:18px 18px}
  .ck-act{display:grid;grid-template-columns:1fr 1fr;gap:9px}
  .ck-act .ck-btn-primary{grid-column:1 / -1;justify-content:center}
  .ck-act .ck-btn{justify-content:center;padding:13px 16px}
  .ck-mbox{padding:30px 22px 26px}
  .ck-mtitle{font-size:24px}
  .ck-opt{padding:18px;gap:16px}
  .ck-otext b{font-size:18px}.ck-otext em{font-size:13.5px}
  .ck-mact{flex-direction:column}
  .ck-mact .ck-btn{justify-content:center}
}

/* ============================================================
   ПРАВКИ — зелёные акценты · скрытие иконок/цифр · телефон · подвал
   ============================================================ */
:root{--green:#1f9d57;--green-600:#178a4a;--green-soft:#e7f6ee}
.green{color:var(--green)}
.kr-form h4 .green{color:var(--green)}
.kicker.kicker-green{color:var(--green)}
.kicker.kicker-green::before{background:var(--green)}

/* номер телефона полностью входит в поле */
.field input[type=tel]{letter-spacing:-.2px}
.field:has(> input[type=tel]){min-width:210px}

/* #2 — бейдж «0 ₽ диагностика» на фото: зелёная галочка/фон */
.hero-badge .hb-ic{background:var(--green-soft);color:var(--green)}

/* #9 — бейдж «0 ₽ диагностика и дефектовка» — зелёный текст на светло-зелёной подложке */
.dv-badge{background:var(--green-soft);color:var(--green)}
.dv-badge span{opacity:1}

/* бейджи «в наличии / под заказ» в таблице фонда */
.badge.in{background:var(--green-soft)!important;color:var(--green)!important;border-color:transparent!important}
.badge.order{background:#e9ebee!important;color:#6b7280!important;border-color:transparent!important}
/* #9 — зелёные галочки «почему диагностика бесплатная» */
.dv-list li::before{background-color:var(--green-soft);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%231f9d57' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6L9 17l-5-5'/%3E%3C/svg%3E")}

/* #5 — зелёные точки над «Получить консультацию» в вариантах */
.vcard .vwarr .dot{background:var(--green)}

/* #8 — зелёные точки в форме «капремонт от 50 000» */
.kr-bullets span::before{background:var(--green)}

/* #6 — убрать красные цифры этапов капремонта */
.kr-n{display:none}
/* #7 — убрать цены (диагностика / снятие-установка) */
.kr-item .kr-price{display:none}

/* #3 — убрать иконки в триггер-плитках */
.ftile .fi{display:none}

/* «Что входит в капремонт» (.inc) — подложка светло-зелёная, иконки/галочки зелёные */
.inc-note{background:var(--green-soft)}
.inc-note svg{color:var(--green)}
.inc-item .ic{background:var(--green-soft);color:var(--green)}

/* «Какие услуги мы оказываем» — зелёные точки списков */
.seo-text ul li::before{background:var(--green)}

/* #10 — «Наши преимущества»: убрать цифры-плашки и иконки, авто-нумерация красным */
.adv .an,.adv .ai{display:none}
.advgrid{counter-reset:advn}
.adv h3{counter-increment:advn}
.adv h3::before{content:counter(advn) ". ";color:var(--red);font-weight:700}
/* «Что входит в капремонт»: авто-нумерация заголовков красным */
.kr-grid{counter-reset:krn}
.kr-item h3{counter-increment:krn}
.kr-item h3::before{content:counter(krn) ". ";color:var(--red);font-weight:700}

/* убрать подписи под сертификатами */
.cert figcaption{display:none}

/* #13 — зелёные иконки в блоке «Приезжайте в Чалтырь» */
.crow .ci{background:var(--green-soft);color:var(--green)}

/* ============================================================
   FOOTER 2.0 — по образцу упакуем.рф (тёмный, в бренде Доктор АТФ)
   ============================================================ */
.foot-cta{display:grid;grid-template-columns:1.35fr .85fr;gap:48px;align-items:center;padding:40px;margin-bottom:46px;background:var(--bg-soft);border:1px solid var(--line);border-radius:var(--r-xl)}
.fc-eyebrow{display:inline-flex;align-items:center;gap:10px;font-family:var(--mono,ui-monospace,monospace);font-size:12px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:24px}
.fc-dot{width:9px;height:9px;border-radius:50%;background:var(--green);box-shadow:0 0 0 4px rgba(31,157,87,.2)}
.fc-h{font-family:var(--display);font-weight:600;font-size:clamp(28px,3.4vw,46px);line-height:1.04;letter-spacing:.005em;text-transform:uppercase;color:var(--ink)}
.fc-h em{font-style:italic;font-family:var(--font);font-weight:600;color:var(--red);text-transform:none}
.fc-step{border:1px solid var(--line);border-radius:var(--r-lg);padding:26px 28px;background:#fff;box-shadow:var(--shadow-sm)}
.fc-step-label{font-family:var(--mono,ui-monospace,monospace);font-size:11.5px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:14px}
.fc-step-text{font-size:17px;line-height:1.4;color:var(--txt-2);margin-bottom:22px}
.fc-step-text b{font-family:var(--display);font-size:24px;color:var(--green);margin-right:4px}
.fc-btn{display:flex;align-items:center;justify-content:space-between;gap:16px;width:100%;background:var(--red);color:#fff;border:none;height:62px;padding:0 28px;border-radius:var(--r);font-family:var(--display);font-weight:600;font-size:18px;letter-spacing:.02em;text-transform:uppercase;transition:.16s}
.fc-btn span{font-size:22px;transition:transform .16s}
.fc-btn:hover{background:var(--red-600)}
.fc-btn:hover span{transform:translateX(6px)}

.foot-cols{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr 1.2fr;gap:40px}
.fcol-h{font-family:var(--mono,ui-monospace,monospace);font-size:12px;font-weight:600;letter-spacing:.13em;text-transform:uppercase;color:#7e8794;margin-bottom:20px}
.fcol > a{display:block;color:#cfd4dc;font-size:14.5px;padding:7px 0;transition:.12s}
.fcol > a:hover{color:#fff}
.fcol > a.fbrand{display:flex;align-items:center;gap:11px}
.fcol > a.fbrand .blogo{width:20px;height:20px;flex:none;background:#cfd4dc;transition:.12s}
.fcol > a.fbrand:hover .blogo{background:#fff}
.fcol-brand .logo{margin-bottom:16px;display:inline-flex;width:fit-content}
.fcol-brand p{color:#9aa0ac;font-size:13.5px;line-height:1.6;margin:0 0 18px;max-width:320px}
.fc-contact .fc-line{margin-bottom:18px}
.fc-contact .fc-l{font-family:var(--mono,ui-monospace,monospace);font-size:11px;font-weight:600;letter-spacing:.13em;text-transform:uppercase;color:#7e8794;margin-bottom:7px}
.fc-contact .fc-tel{font-family:var(--display);font-size:24px;font-weight:600;color:#fff;letter-spacing:.01em;display:inline-block;transition:.15s}
.fc-contact .fc-tel:hover{color:var(--red)}
.fc-contact .fc-v{font-size:14.5px;color:#cfd4dc;line-height:1.5}
.fc-status{display:inline-flex;align-items:center;gap:8px;font-size:13.5px;color:#cfd4dc}
.fc-status::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--green);box-shadow:0 0 0 3px rgba(31,157,87,.22)}
@media(max-width:1100px){
  .foot-cta{grid-template-columns:1fr;gap:30px}
  .foot-cols{grid-template-columns:1fr 1fr 1fr;gap:32px 28px}
  .fcol-brand{grid-column:1/-1}
}
@media(max-width:600px){
  .foot-cols{grid-template-columns:1fr 1fr}
  .fc-step{padding:20px}
}

/* ============================================================
   CTA-полоса: форма → белая карточка + персонализация
   ============================================================ */
.ctaband-form{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--r-xl);
  box-shadow:var(--shadow-lg);
  padding:26px 26px 22px;
  gap:12px;
  flex:0 1 460px;
  min-width:300px;
  max-width:480px;
}
.ctaband-form .field input{background:#fff;border-color:var(--line-2);color:var(--txt)}
.ctaband-form .field input::placeholder{color:var(--muted-2)}
.ctaband-form .field input:focus{border-color:var(--red);box-shadow:0 0 0 3px var(--red-soft)}
.ctaband-form .consent{color:var(--muted-2) !important}
.ctaband-form .consent a{color:var(--muted) !important}
/* персональная «шапка» формы (инжектится в site.js) */
.cb-form-head{flex-basis:100%}
.cb-form-eyebrow{display:inline-flex;align-items:center;gap:7px;font-size:11.5px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--green);background:var(--green-soft);border-radius:100px;padding:6px 13px;margin-bottom:13px}
.cb-form-eyebrow .dot{width:6px;height:6px;border-radius:50%;background:var(--green);flex:0 0 auto}
.cb-form-head h4{font-family:var(--display);font-weight:600;font-size:21px;line-height:1.12;text-transform:uppercase;letter-spacing:.01em;color:var(--ink)}
.cb-form-head h4 .red{color:var(--red)}
.cb-form-head p{font-size:13px;color:var(--muted);margin-top:8px;line-height:1.45}
@media(max-width:760px){
  .ctaband-form{flex-basis:100%;max-width:100%;width:100%}
}

/* обменный фонд: персональная кнопка-заявка в строке */
.fund-cta-cell{text-align:right;white-space:nowrap;width:1%}
.btn.fund-cta{height:38px;padding:0 16px;font-size:13px;border-radius:var(--r-sm)}
@media(max-width:760px){
  .fund.reveal{overflow-x:auto;-webkit-overflow-scrolling:touch}
  .fund.reveal table{min-width:680px}
}

/* HERO MOBILE: фото после заголовка (≤1100px) — порядок: eyebrow → H1 → фото → текст → форма */
@media(max-width:1100px){
  .hero-inner{display:flex;flex-direction:column;align-items:stretch}
  .hero-copy{display:contents}
  .hero-copy .eyebrow{order:1}
  .hero-copy h1{order:2}
  .hero-media{order:3;max-width:100%;margin:6px 0 10px}
  .hero-copy .lead{order:4}
  .hero-copy .hero-form{order:5}
  .hero-copy .consent{order:6}
}

/* ===== МОБИЛЬНЫЕ ФИКСЫ ВЁРСТКИ ===== */
@media(max-width:760px){
  html,body{overflow-x:hidden}
  /* кнопки: переносим длинный текст, авто-высота — не вылезают за экран и не обрезаются */
  .btn{white-space:normal;height:auto;min-height:52px;padding:11px 20px;line-height:1.25;text-align:center}
  .fc-btn{height:auto;min-height:60px;padding:15px 22px;white-space:normal;line-height:1.2}
  /* длинные значения (адрес/телефон) переносятся, а не уезжают вправо */
  .crow .cv{word-break:break-word;overflow-wrap:anywhere}
}
/* блок «Техцентр»: на мобиле фото ПОД текстом */
@media(max-width:880px){
  .intro{display:flex;flex-direction:column}
  .intro .ph{display:none}
  .intro-media-mob{display:block;border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--line);aspect-ratio:16/11;box-shadow:var(--shadow);max-width:520px;margin:18px 0 22px}
  .intro-media-mob img{width:100%;height:100%;object-fit:cover}
}

a.prod{display:block;text-decoration:none;color:inherit}


/* mobile: переносим боковое фото внутрь текста (about-hero/diag-split/faults) */
.blk-media-mob{display:none}
@media(max-width:880px){
  .about-hero .ph,.diag-split .ph,.faults .ph{display:none}
  .blk-media-mob{display:block;border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--line);aspect-ratio:16/11;box-shadow:var(--shadow);max-width:520px;margin:18px 0 22px}
  .blk-media-mob img{width:100%;height:100%;object-fit:cover;display:block}
}
@media(max-width:880px){.tw-side{display:none}}

/* ===== Мобильная плотность и крупные фото (доработка) ===== */
@media(max-width:600px){
  .sec{padding:42px 0}
  .sec-sm{padding:30px 0}
  .sec-head{margin-bottom:24px}
  .sec-sub{font-size:15.5px;margin-top:10px}
  .gens .gen .gphoto{height:220px}
  .gens .gen .gtop{padding:16px 18px 13px}
  .gens .gen .gbody{padding:14px 18px;gap:8px}
  .gens .gen .gbtn{margin:0 18px 18px}
  .prodgrid{gap:14px}
}
@media(max-width:430px){
  .sec{padding:32px 0}
  .sec-head{margin-bottom:20px}
  .container{padding:0 14px}
  .gens .gen .gphoto{height:205px}
}
