/* =========================================================================
   Ремонт телевизоров на дому — Василий Зырянов
   Дизайн-система: «Тёплый мастер» (бирюза + янтарь, тёплая бумага)
   Mobile-first · крупно · контрастно · AAA-текст
   ========================================================================= */

/* ---------- 0. ШРИФТ (самохостинг, woff2) ----------
   Golos Text — вариативный шрифт: один файл на подмножество покрывает
   все веса 400–700. Файлы лежат в /fonts. */
@font-face{
  font-family:"Golos Text";
  font-style:normal;
  font-weight:400 700;
  font-display:swap;
  src:url("fonts/golos-text-cyrillic.woff2") format("woff2");
  unicode-range:U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
@font-face{
  font-family:"Golos Text";
  font-style:normal;
  font-weight:400 700;
  font-display:swap;
  src:url("fonts/golos-text-cyrillic-ext.woff2") format("woff2");
  unicode-range:U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
@font-face{
  font-family:"Golos Text";
  font-style:normal;
  font-weight:400 700;
  font-display:swap;
  src:url("fonts/golos-text-latin.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+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face{
  font-family:"Golos Text";
  font-style:normal;
  font-weight:400 700;
  font-display:swap;
  src:url("fonts/golos-text-latin-ext.woff2") format("woff2");
  unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

/* ---------- 1. ДИЗАЙН-ТОКЕНЫ ---------- */
:root{
  color-scheme: light dark;

  /* Светлая тема (по умолчанию) */
  --bg:#FAF6F0;
  --surface:#FFFFFF;
  --surface-2:#F3ECE1;
  --ink:#1E1813;
  --muted:#524A3E;
  --line:#E7DECF;
  --line-strong:#D8CCB8;

  --brand:#0C5E6B;
  --brand-ink:#094E59;
  --brand-tint:#E2EFF0;

  --accent:#B85C00;
  --accent-ink:#9A4D00;
  --accent-tint:#FBEBD6;

  --wa:#0B7A3E;
  --wa-press:#096733;

  --stop:#BC3A26;
  --stop-tint:#FBE9E5;

  --focus:#0C5E6B;

  /* Геометрия / тени */
  --radius:18px;
  --radius-sm:14px;
  --radius-pill:999px;
  --shadow:0 1px 2px rgba(30,24,19,.05), 0 12px 28px rgba(30,24,19,.08);
  --shadow-sm:0 1px 2px rgba(30,24,19,.05), 0 4px 14px rgba(30,24,19,.06);
  --ease:cubic-bezier(.2,.7,.2,1);

  /* Слой */
  --wrap:620px;
  --pad:20px;
}

/* Тёмная тема — по системе */
@media (prefers-color-scheme: dark){
  :root:not([data-theme="light"]){
    --bg:#161210;
    --surface:#211B16;
    --surface-2:#2A231C;
    --ink:#F0E8DE;
    --muted:#BCAE9C;
    --line:#352C22;
    --line-strong:#463A2C;

    --brand:#58C2D0;
    --brand-ink:#7FD3DE;
    --brand-tint:#15302F;

    --accent:#F3A93B;
    --accent-ink:#F3A93B;
    --accent-tint:#2E2212;

    --wa:#1A9A51;
    --wa-press:#15843F;

    --stop:#F08A74;
    --stop-tint:#2E1813;

    --focus:#58C2D0;

    --shadow:none;
    --shadow-sm:none;
  }
}

/* Тёмная тема — ручной выбор (переопределяет систему) */
:root[data-theme="dark"]{
  --bg:#161210;
  --surface:#211B16;
  --surface-2:#2A231C;
  --ink:#F0E8DE;
  --muted:#BCAE9C;
  --line:#352C22;
  --line-strong:#463A2C;

  --brand:#58C2D0;
  --brand-ink:#7FD3DE;
  --brand-tint:#15302F;

  --accent:#F3A93B;
  --accent-ink:#F3A93B;
  --accent-tint:#2E2212;

  --wa:#1A9A51;
  --wa-press:#15843F;

  --stop:#F08A74;
  --stop-tint:#2E1813;

  --focus:#58C2D0;

  --shadow:none;
  --shadow-sm:none;
}

/* ---------- 2. RESET ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:100%}
body{
  font-family:"Golos Text",-apple-system,"Segoe UI",Roboto,sans-serif;
  background:var(--bg);
  color:var(--ink);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,svg{display:block;max-width:100%}
a{color:var(--brand-ink)}
button{font:inherit}
:focus-visible{outline:3px solid var(--focus);outline-offset:2px;border-radius:8px}

/* ---------- 2b. ФОН: зерно («бумага») ----------
   Едва заметное монохромное зерно поверх всей страницы — убирает ощущение
   «плоского пластика». Слой не перехватывает клики и лежит ниже шапки/FAB. */
body::after{
  content:"";
  position:fixed;inset:0;z-index:90;
  pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.6'/%3E%3C/svg%3E");
  background-size:160px 160px;
  opacity:.045;
}
@media (prefers-color-scheme:dark){
  :root:not([data-theme="light"]) body::after{opacity:.06}
}
:root[data-theme="dark"] body::after{opacity:.06}

/* ---------- 3. ТИПОГРАФИКА / СЛОЙ ---------- */
.wrap{
  width:100%;
  max-width:var(--wrap);
  margin-inline:auto;
  padding-inline:max(var(--pad), env(safe-area-inset-left), env(safe-area-inset-right));
}
.section{padding-block:clamp(40px,9vw,72px)}
.section--alt{
  background:var(--surface-2);
  border-block:1px solid var(--line);
}

h1,h2,h3{line-height:1.2;letter-spacing:-.01em;text-wrap:balance;font-weight:700}
h1{font-size:clamp(2rem,8vw,2.6rem)}
h2{font-size:clamp(1.6rem,6vw,2rem)}
h3{font-size:1.25rem;font-weight:600}
p{text-wrap:pretty}

.section__head{margin-bottom:clamp(20px,5vw,32px)}
.section__title{margin-bottom:6px}
.section__lead{color:var(--muted);font-size:1.05rem}

.skip-link{
  position:absolute;left:8px;top:-100px;z-index:200;
  background:var(--surface);color:var(--brand-ink);
  padding:12px 18px;border-radius:var(--radius-sm);
  border:2px solid var(--brand);font-weight:600;
  transition:top .2s var(--ease);
}
.skip-link:focus{top:8px}

/* ---------- 4. КНОПКИ ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  min-height:56px;padding:14px 22px;
  border-radius:var(--radius-sm);
  font-size:1.05rem;font-weight:700;line-height:1.2;
  text-decoration:none;cursor:pointer;border:2px solid transparent;
  transition:background .16s var(--ease),border-color .16s var(--ease),transform .12s var(--ease);
}
.btn:active{transform:scale(.99)}
.btn .ico{width:22px;height:22px;flex:none}
.btn--block{display:flex;width:100%}

.btn--wa{background:var(--wa);color:#fff;min-height:58px;font-size:1.1rem}
.btn--wa:hover{background:var(--wa-press)}

.btn--outline{background:transparent;border-color:var(--brand);color:var(--brand-ink)}
.btn--outline:hover{background:var(--brand-tint)}

.btn-row{display:flex;flex-direction:column;gap:12px;margin-top:24px}
@media (min-width:560px){
  .btn-row{flex-direction:row}
  .btn-row .btn{flex:1}
}

/* ---------- 5. ШАПКА (sticky) ---------- */
.header{
  position:sticky;top:0;z-index:100;
  background:color-mix(in srgb, var(--bg) 88%, transparent);
  backdrop-filter:saturate(1.4) blur(10px);
  border-bottom:1px solid var(--line);
}
.header__inner{
  display:flex;align-items:center;gap:14px;
  min-height:64px;padding-block:8px;
}
.brand{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--ink);font-weight:700}
.brand__mark{
  width:40px;height:40px;flex:none;border-radius:12px;
  background:var(--brand);color:#fff;
  display:grid;place-items:center;font-weight:700;font-size:1.1rem;
}
.brand__mark svg{width:24px;height:24px}
.brand__name{font-size:1rem;line-height:1.1}
.brand__name small{display:block;font-weight:500;font-size:.7rem;color:var(--muted)}

.header__anchor{
  margin-left:auto;font-size:.82rem;font-weight:600;color:var(--brand-ink);
  text-decoration:none;text-align:right;line-height:1.2;
}
.header__anchor:hover{text-decoration:underline}

.theme-toggle{
  margin-left:auto;flex:none;
  width:48px;height:48px;border-radius:12px;
  border:2px solid var(--line-strong);background:var(--surface);
  color:var(--brand-ink);cursor:pointer;
  display:grid;place-items:center;
  transition:border-color .16s var(--ease),background .16s var(--ease);
}
.theme-toggle:hover{border-color:var(--brand)}
.theme-toggle svg{width:24px;height:24px}
.header__anchor + .theme-toggle{margin-left:14px}
.theme-toggle .moon{display:none}
:root[data-theme="dark"] .theme-toggle .sun{display:none}
:root[data-theme="dark"] .theme-toggle .moon{display:block}
@media (prefers-color-scheme:dark){
  :root:not([data-theme="light"]) .theme-toggle .sun{display:none}
  :root:not([data-theme="light"]) .theme-toggle .moon{display:block}
}

/* ---------- 5b. МЕНЮ ---------- */
.nav{
  margin-left:auto;
  display:flex;align-items:center;gap:2px;
}
.nav__link{
  padding:9px 13px;border-radius:10px;
  font-size:.96rem;font-weight:600;line-height:1;
  color:var(--ink);text-decoration:none;white-space:nowrap;
  transition:background .16s var(--ease),color .16s var(--ease);
}
.nav__link:hover{background:var(--brand-tint);color:var(--brand-ink)}
.header__inner .theme-toggle{margin-left:8px}

.nav-burger{
  display:none;flex:none;margin-left:auto;
  width:48px;height:48px;border-radius:12px;
  border:2px solid var(--line-strong);background:var(--surface);
  color:var(--ink);cursor:pointer;
  place-items:center;
  transition:border-color .16s var(--ease);
}
.nav-burger:hover{border-color:var(--brand)}
.nav-burger svg{width:24px;height:24px}
.nav-burger__close{display:none}
.nav-burger[aria-expanded="true"] .nav-burger__open{display:none}
.nav-burger[aria-expanded="true"] .nav-burger__close{display:block}

/* Мобильная версия: бургер + выпадающее меню */
@media (max-width:720px){
  .nav-burger{display:grid}
  .header__inner .theme-toggle{margin-left:8px}
  .nav{
    position:absolute;top:100%;left:0;right:0;
    margin-left:0;flex-direction:column;align-items:stretch;gap:2px;
    background:var(--bg);border-bottom:1px solid var(--line);
    box-shadow:var(--shadow);padding:8px;
    display:none;
  }
  .nav.is-open{display:flex}
  .nav__link{padding:14px 14px;font-size:1.05rem;border-radius:12px}
}

/* Отступ для якорей под липкой шапкой */
:target{scroll-margin-top:80px}
#top,#ceny,#voprosy,#kontakty{scroll-margin-top:80px}

/* ---------- 6. HERO ---------- */
.hero{
  position:relative;
  padding-block:clamp(36px,9vw,64px);
  background:radial-gradient(1100px 520px at 50% -160px,
    color-mix(in srgb, var(--brand) 14%, transparent), transparent 68%);
}
.hero__eyebrow{
  display:inline-block;font-size:.85rem;font-weight:600;color:var(--brand-ink);
  background:var(--brand-tint);padding:6px 14px;border-radius:var(--radius-pill);
  margin-bottom:18px;
}
.hero h1{margin-bottom:14px}
.hero__sub{font-size:1.15rem;color:var(--muted);margin-bottom:24px}
.hero__list{list-style:none;display:grid;gap:14px;margin-bottom:8px}
.hero__list li{
  display:flex;gap:12px;align-items:flex-start;
  font-size:1.05rem;
}
.hero__list .tick{
  flex:none;width:30px;height:30px;border-radius:50%;
  background:var(--brand-tint);color:var(--brand-ink);
  display:grid;place-items:center;margin-top:1px;
}
.hero__list .tick svg{width:18px;height:18px}

/* ---------- 7. КАРТОЧКИ / ПРЕИМУЩЕСТВА ---------- */
.card{
  background:var(--surface);border:1px solid var(--line);
  border-radius:var(--radius);box-shadow:var(--shadow);
  padding:clamp(20px,5vw,26px);
}
.benefits{display:grid;gap:14px}
@media (min-width:560px){.benefits{grid-template-columns:1fr 1fr}}
.benefit__icon{
  width:48px;height:48px;border-radius:14px;flex:none;
  background:var(--accent-tint);color:var(--accent-ink);
  display:grid;place-items:center;margin-bottom:14px;
}
.benefit__icon svg{width:26px;height:26px}
.benefit h3{margin-bottom:6px}
.benefit p{color:var(--muted);font-size:.98rem}

/* Карточка симптома, который чиню на дому — зелёный акцент */
.benefit--ok{border-left:3px solid var(--wa)}
.benefit__tick{
  width:34px;height:34px;border-radius:50%;flex:none;
  background:var(--wa);color:#fff;
  display:grid;place-items:center;margin-bottom:12px;
}
.benefit__tick svg{width:20px;height:20px}
/* Горизонтальные строки-карточки симптомов — всегда 1 колонка, иконка слева
   (не зависит от числа карточек; применяется только к блокам с .benefits--rows) */
.benefits--rows{grid-template-columns:1fr}
.benefits--rows .benefit{
  display:grid;grid-template-columns:auto 1fr;column-gap:16px;align-items:start;
}
.benefits--rows .benefit__tick{grid-column:1;grid-row:1 / 3;margin-bottom:0}
.benefits--rows .benefit h3{grid-column:2;align-self:center}
.benefits--rows .benefit p{grid-column:2}
/* Честная сноска «с этим — в сервис-центр» */
.benefit-note{
  margin-top:18px;color:var(--muted);font-size:.98rem;line-height:1.6;
  padding-left:14px;border-left:3px solid var(--stop);
}
/* Callout «Уточняйте у мастера» с WhatsApp-кнопкой */
.check-cta{
  margin-top:22px;display:flex;gap:18px;flex-wrap:wrap;
  align-items:center;justify-content:space-between;
  background:var(--accent-tint);border:1px solid var(--line);
  border-radius:var(--radius);padding:clamp(18px,4vw,24px);
}
.check-cta__text{flex:1 1 280px}
.check-cta__text strong{display:block;font-size:1.06rem;margin-bottom:5px;color:var(--ink)}
.check-cta__text p{color:var(--muted);font-size:.98rem;margin:0;line-height:1.55}
.check-cta .btn{flex:none}

/* ---------- Статья (страница подсветки) ---------- */
.prose p{color:var(--muted);font-size:1.05rem;line-height:1.6;margin-bottom:16px}
.prose p strong{color:var(--ink)}
.prose .lead{font-size:1.12rem}
.prose .warn{color:var(--accent-ink);font-weight:600}
.prose ul{margin:0 0 16px 0;padding:0;list-style:none;display:grid;gap:11px}
.prose ul li{position:relative;padding-left:26px;color:var(--muted);font-size:1.02rem;line-height:1.5}
.prose ul li::before{content:"";position:absolute;left:5px;top:.62em;width:8px;height:8px;border-radius:50%;background:var(--brand)}
.media{margin:22px 0;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:var(--surface-2)}
.media img{display:block;width:100%;height:auto}
.media figcaption{padding:11px 15px;font-size:.9rem;color:var(--muted)}

/* ---------- Хлебные крошки ---------- */
.crumbs{font-size:.9rem;color:var(--muted);margin-bottom:16px;display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.crumbs a{color:var(--brand-ink);text-decoration:none}
.crumbs a:hover{text-decoration:underline}
.crumbs span[aria-current]{color:var(--muted)}

/* ---------- 8. ОБО МНЕ ---------- */
.about__grid{display:grid;gap:24px}
@media (min-width:560px){.about__grid{grid-template-columns:200px 1fr;align-items:start}}
.about__photo{
  width:100%;max-width:240px;margin-inline:auto;aspect-ratio:1/1;
  border-radius:var(--radius);overflow:hidden;
  background:var(--surface-2);border:1px solid var(--line);
  cursor:zoom-in;
}
.about__photo img{width:100%;height:100%;object-fit:cover;object-position:center top}

/* ---------- ЛАЙТБОКС ---------- */
.lightbox{
  position:fixed;inset:0;z-index:9999;
  display:flex;align-items:center;justify-content:center;
  background:rgba(0,0,0,.85);
  padding:16px;
  animation:lb-in .18s ease;
}
.lightbox[hidden]{display:none}
@keyframes lb-in{from{opacity:0}to{opacity:1}}
.lightbox__img{
  max-width:100%;max-height:100%;
  object-fit:contain;border-radius:var(--radius);
  box-shadow:0 8px 40px rgba(0,0,0,.6);
}
.lightbox__close{
  position:fixed;top:20px;right:20px;
  width:56px;height:56px;border-radius:50%;
  background:#fff;border:none;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 16px rgba(0,0,0,.4);
  color:#111;
  transition:background .15s,transform .15s;
}
.lightbox__close:hover{background:#f0f0f0;transform:scale(1.08)}
.lightbox__close svg{width:24px;height:24px}

/* ---------- Окно «перед звонком» ---------- */
.call-modal{
  position:fixed;inset:0;z-index:10000;
  display:flex;align-items:center;justify-content:center;
  background:rgba(0,0,0,.6);
  padding:16px;
  animation:lb-in .18s ease;
}
.call-modal[hidden]{display:none}
.call-modal__card{
  position:relative;
  width:100%;max-width:420px;
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:28px 22px 22px;
  box-shadow:0 12px 48px rgba(0,0,0,.35);
  animation:cm-up .2s ease;
}
@keyframes cm-up{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
.call-modal__title{
  margin:0 28px 12px 0;
  font-size:1.15rem;line-height:1.3;color:var(--ink);
}
.call-modal__text{
  margin:0 0 20px;
  font-size:.95rem;line-height:1.5;color:var(--muted);
}
.call-modal__text strong{color:var(--ink)}
.call-modal__actions{display:flex;flex-direction:column;gap:12px}
.call-modal__close{
  position:absolute;top:12px;right:12px;
  width:40px;height:40px;border-radius:50%;
  background:transparent;border:none;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  color:var(--muted);
  transition:background .15s,color .15s;
}
.call-modal__close:hover{background:var(--brand-tint);color:var(--ink)}
.call-modal__close svg{width:22px;height:22px}
.about__body > * + *{margin-top:10px}
.about__body p{font-size:.9rem}
.about__lead{font-weight:600;font-size:.96rem !important;color:var(--ink)}

/* ---------- 9. ОТЗЫВЫ ---------- */
.reviews__source{color:var(--muted);font-size:.88rem;margin-bottom:16px}
.review-list{display:grid;gap:14px}
.review{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:20px 22px}
.review__head{display:flex;flex-wrap:wrap;justify-content:space-between;gap:4px 12px;margin-bottom:10px}
.review__name{font-weight:700}
.review__date{color:var(--muted);font-size:.88rem}
.review__stars{color:var(--accent);font-size:.95rem;letter-spacing:1px}
.review p{color:var(--muted);font-size:.98rem}
.reviews__link{display:inline-flex;align-items:center;gap:6px;margin-top:18px;font-weight:600;color:var(--brand-ink);text-decoration:none}
.reviews__link:hover{text-decoration:underline}
.reviews__link::after{content:"→"}

/* ---------- 10. ЭТАПЫ ---------- */
.steps{display:grid;gap:14px;counter-reset:step}
.step{
  display:grid;grid-template-columns:auto 1fr;gap:16px;align-items:start;
  background:var(--surface);border:1px solid var(--line);
  border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:20px 22px;
}
.step__num{
  counter-increment:step;flex:none;
  width:48px;height:48px;border-radius:50%;
  background:var(--brand);color:#fff;
  display:grid;place-items:center;font-weight:700;font-size:1.3rem;
}
.step__num::before{content:counter(step)}
.step h3{margin-bottom:4px}
.step p{color:var(--muted);font-size:.98rem}

/* ---------- 11. ЦЕНЫ / КВИЗ ---------- */
.quiz-intro{margin-bottom:8px}

/* ---------- 12. FAQ ---------- */
.faq{display:grid;gap:12px}
.faq details{
  background:var(--surface);border:1px solid var(--line);
  border-radius:var(--radius-sm);box-shadow:var(--shadow-sm);overflow:hidden;
}
.faq summary{
  list-style:none;cursor:pointer;
  display:flex;align-items:center;justify-content:space-between;gap:14px;
  padding:18px 20px;min-height:56px;
  font-weight:600;font-size:1.05rem;color:var(--ink);
}
.faq summary::-webkit-details-marker{display:none}
.faq summary .chev{
  flex:none;width:24px;height:24px;color:var(--brand-ink);
  transition:transform .22s var(--ease);
}
.faq details[open] summary .chev{transform:rotate(180deg)}
.faq .faq__a{padding:0 20px 20px;color:var(--muted);font-size:1rem}
.faq .faq__a p + p{margin-top:10px}

/* ---------- 13. КОНТАКТЫ ---------- */
.contact__grid{display:grid;gap:14px;margin-bottom:24px}
@media (min-width:560px){.contact__grid{grid-template-columns:1fr 1fr}}
.contact__card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:22px}
.contact__card .ic{
  width:48px;height:48px;border-radius:14px;display:grid;place-items:center;margin-bottom:12px;
}
.contact__card.is-wa .ic{background:var(--wa);color:#fff}
.contact__card.is-tel .ic{background:var(--brand-tint);color:var(--brand-ink)}
.contact__card .ic svg{width:26px;height:26px}
.contact__card h3{margin-bottom:4px}
.contact__card .val{font-weight:700;font-size:1.15rem;color:var(--ink);text-decoration:none;display:inline-block;margin-bottom:4px}
.contact__card .val:hover{color:var(--brand-ink)}
.contact__card .note{color:var(--muted);font-size:.9rem}
.contact__note{color:var(--muted);font-size:.95rem;margin-bottom:8px}

/* ---------- 14. ПОДВАЛ ---------- */
.footer{background:var(--surface-2);border-top:1px solid var(--line);padding-block:32px;margin-top:8px}
.footer__cols{display:grid;gap:24px;margin-bottom:24px}
@media (min-width:560px){.footer__cols{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}}
.footer__title{font-size:.75rem;font-weight:700;color:var(--ink);margin-bottom:12px}
.footer__links{list-style:none;padding:0;margin:0;display:grid;gap:8px}
.footer__links li{color:var(--muted);font-size:.72rem}
.footer__links a{color:var(--muted);font-size:.72rem;text-decoration:none}
.footer__links a:hover{color:var(--brand-ink)}
.footer__legal{color:var(--muted);font-size:.72rem;border-top:1px solid var(--line);padding-top:16px}
.footer p{color:var(--muted);font-size:.72rem}
.footer p + p{margin-top:6px}

/* ---------- 15. ПЛАВАЮЩАЯ КНОПКА (FAB) ---------- */
.fab{
  position:fixed;z-index:120;
  right:max(16px, env(safe-area-inset-right));
  bottom:max(16px, env(safe-area-inset-bottom));
  width:60px;height:60px;border-radius:50%;
  background:var(--wa);color:#fff;
  display:grid;place-items:center;text-decoration:none;
  box-shadow:0 6px 20px rgba(11,122,62,.4);
  opacity:0;transform:translateY(16px) scale(.85);pointer-events:none;
  transition:opacity .25s var(--ease),transform .25s var(--ease),background .16s var(--ease);
}
.fab svg{width:32px;height:32px}
.fab.is-visible{opacity:1;transform:none;pointer-events:auto}
.fab:hover{background:var(--wa-press)}

/* ---------- 16. КВИЗ: перепривязка токенов к странице ----------
   Конкретные значения (без самоссылки var(--x):var(--x), которая делает
   переменную невалидной). Светлая тема + отдельный блок для тёмной. */
#tvq-root{
  --ink:#1E1813 !important;
  --muted:#524A3E !important;
  --line:#E7DECF !important;
  --bg:#FFFFFF !important;
  --brand:#0C5E6B !important;
  --brand-ink:#094E59 !important;
  --brand-tint:#E2EFF0 !important;
  --wa:#0B7A3E !important;
  --wa-hi:#096733 !important;
  --stop:#BC3A26 !important;
  --stop-tint:#FBE9E5 !important;
  --shadow:0 1px 2px rgba(30,24,19,.05), 0 12px 28px rgba(30,24,19,.08) !important;
  padding:0 !important;
}
@media (prefers-color-scheme: dark){
  :root:not([data-theme="light"]) #tvq-root{
    --ink:#F0E8DE !important;
    --muted:#BCAE9C !important;
    --line:#352C22 !important;
    --bg:#211B16 !important;
    --brand:#58C2D0 !important;
    --brand-ink:#7FD3DE !important;
    --brand-tint:#15302F !important;
    --wa:#1A9A51 !important;
    --wa-hi:#15843F !important;
    --stop:#F08A74 !important;
    --stop-tint:#2E1813 !important;
    --shadow:none !important;
  }
}
[data-theme="dark"] #tvq-root{
  --ink:#F0E8DE !important;
  --muted:#BCAE9C !important;
  --line:#352C22 !important;
  --bg:#211B16 !important;
  --brand:#58C2D0 !important;
  --brand-ink:#7FD3DE !important;
  --brand-tint:#15302F !important;
  --wa:#1A9A51 !important;
  --wa-hi:#15843F !important;
  --stop:#F08A74 !important;
  --stop-tint:#2E1813 !important;
  --shadow:none !important;
}
#tvq-root .tvq{max-width:none !important;background:var(--surface)}
/* Крупнее кегль и тап-зоны для слабого зрения */
#tvq-root .fault{min-height:120px !important;padding:18px 16px !important}
#tvq-root .fault .lb{font-size:1rem !important}
#tvq-root .diag{padding:16px 18px !important;min-height:60px !important}
#tvq-root .diag .dl{font-size:1.05rem !important}
#tvq-root .diag .ds{font-size:.92rem !important}
#tvq-root .field input{font-size:1.05rem !important;padding:15px 16px !important;min-height:56px !important;border:2px solid #b0bec8 !important}
#tvq-root .field input::placeholder{color:var(--muted) !important;opacity:.7}
#tvq-root .wa{min-height:58px !important;font-size:1.08rem !important}
#tvq-root .ghost{min-height:56px !important;color:var(--brand-ink)}
#tvq-root .scale-track{background:var(--surface-2)}
#tvq-root .wa[data-disabled="true"]{background:#8da8b5 !important;color:#fff !important;cursor:not-allowed}

/* Критичные интерактивные состояния — конкретные цвета (надёжность > тонкости var) */
#tvq-root .wa:not([data-disabled="true"]){background:#0B7A3E !important;color:#fff !important}
#tvq-root .wa:not([data-disabled="true"]):hover{background:#096733 !important}
#tvq-root .diag[aria-pressed="true"]{border-color:#0C5E6B !important;background:#E2EFF0 !important}
#tvq-root .diag[aria-pressed="true"] .chk{background:#0C5E6B !important;border-color:#0C5E6B !important}
#tvq-root .diag[aria-pressed="true"] .chk::after{content:"✓" !important;color:#fff !important;font-size:13px !important;font-weight:700 !important;line-height:1 !important;border:0 !important;width:auto !important;height:auto !important;transform:none !important}
#tvq-root .scale-fill{background:linear-gradient(90deg,#16a3b8,#0C5E6B) !important}

@media (prefers-color-scheme: dark){
  :root:not([data-theme="light"]) #tvq-root .diag[aria-pressed="true"]{border-color:#58C2D0 !important;background:#15302F !important}
  :root:not([data-theme="light"]) #tvq-root .diag[aria-pressed="true"] .chk{background:#58C2D0 !important;border-color:#58C2D0 !important}
  :root:not([data-theme="light"]) #tvq-root .diag[aria-pressed="true"] .chk::after{color:#161210 !important}
  :root:not([data-theme="light"]) #tvq-root .wa:not([data-disabled="true"]){background:#1A9A51 !important}
  :root:not([data-theme="light"]) #tvq-root .wa:not([data-disabled="true"]):hover{background:#15843F !important}
}
[data-theme="dark"] #tvq-root .diag[aria-pressed="true"]{border-color:#58C2D0 !important;background:#15302F !important}
[data-theme="dark"] #tvq-root .diag[aria-pressed="true"] .chk{background:#58C2D0 !important;border-color:#58C2D0 !important}
[data-theme="dark"] #tvq-root .diag[aria-pressed="true"] .chk::after{color:#161210 !important}
[data-theme="dark"] #tvq-root .wa:not([data-disabled="true"]){background:#1A9A51 !important}
[data-theme="dark"] #tvq-root .wa:not([data-disabled="true"]):hover{background:#15843F !important}

#tvq-root :focus-visible{outline:3px solid var(--focus) !important;outline-offset:2px}

/* ---------- 17a. УТИЛИТЫ ОТСТУПОВ ---------- */
.mt-20{margin-top:20px}
.mt-28{margin-top:28px}

/* ---------- 17. REDUCED MOTION ---------- */
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important;scroll-behavior:auto !important}
}

/* ---------- 18. КВИЗ: базовые стили ----------
   Перенесено из inline <style> страниц (index / remont-televizorov-lg).
   Токены и тёмную тему переопределяет секция 16 выше (через !important);
   здесь — структура, типографика и анимации. Менять стили квиза — тут. */
#tvq-root *{box-sizing:border-box;margin:0;padding:0}
#tvq-root{
  --ink:#15212b; --muted:#51616f; --line:#e4e9ee; --bg:#ffffff;
  --brand:#0f7b8a; --brand-ink:#0a5b66; --brand-tint:#e7f3f5;
  --wa:#0b7a3e; --wa-hi:#0a6a36;
  --stop:#c1432f; --stop-tint:#fbeae6;
  --radius:16px; --radius-sm:11px;
  --shadow:0 1px 2px rgba(16,33,43,.05), 0 10px 30px rgba(16,33,43,.09);
  --ease:cubic-bezier(.2,.7,.2,1);
  font-family:inherit;
  color:var(--ink); line-height:1.45; -webkit-font-smoothing:antialiased;
  display:flex; justify-content:center; padding:8px;
}
#tvq-root .tvq{
  width:100%; max-width:560px; background:var(--bg);
  border:1px solid var(--line); border-radius:var(--radius);
  box-shadow:var(--shadow); padding:clamp(18px,5vw,28px); overflow:hidden;
}
#tvq-root .screen{display:none}
#tvq-root .screen.is-active{display:block; animation:tvq-in .32s var(--ease) both}
@keyframes tvq-in{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}

#tvq-root .eyebrow{font-size:.72rem;font-weight:700;letter-spacing:.09em;text-transform:uppercase;color:var(--brand-ink);margin-bottom:9px}
#tvq-root .title{font-size:clamp(1.28rem,4.6vw,1.65rem);font-weight:800;letter-spacing:-.015em;text-wrap:balance;outline:none}
#tvq-root .sub{color:var(--muted);font-size:.97rem;margin-top:7px;text-wrap:pretty}

#tvq-root .back{
  appearance:none;border:none;background:none;cursor:pointer;color:var(--muted);
  font:inherit;font-weight:600;font-size:.92rem;padding:6px 0;margin-bottom:8px;
}
#tvq-root .back:hover{color:var(--brand-ink)}

#tvq-root .hint{display:flex;gap:12px;align-items:center;margin-top:16px;padding:12px 14px;background:var(--brand-tint);border-radius:var(--radius-sm);color:var(--brand-ink);font-size:.86rem;line-height:1.35}
#tvq-root .hint-img{width:70px;height:42px;flex:none;color:var(--brand-ink)}

/* Неисправности */
#tvq-root .faults{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:18px}
#tvq-root .fault{
  display:flex;flex-direction:column;align-items:flex-start;gap:10px;text-align:left;
  background:var(--bg);border:2px solid var(--line);border-radius:var(--radius-sm);
  padding:14px 13px;min-height:104px;cursor:pointer;font:inherit;color:inherit;
  box-shadow:0 2px 6px rgba(16,33,43,.08);
  transition:border-color .18s var(--ease),transform .12s var(--ease),box-shadow .18s var(--ease),background .18s var(--ease);
}
#tvq-root .fault:hover{border-color:var(--brand);background:var(--brand-tint);box-shadow:0 4px 16px rgba(15,123,138,.18)}
#tvq-root .fault:active{transform:scale(.985)}
#tvq-root .fault .ic{color:var(--brand);width:30px;height:30px;flex:none}
#tvq-root .fault .lb{font-weight:700;font-size:.91rem;line-height:1.25}

/* Диагонали */
#tvq-root .diagonals{display:flex;flex-direction:column;gap:8px;margin-top:18px}
#tvq-root .diag{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  background:var(--bg);border:2px solid var(--line);border-radius:var(--radius-sm);
  padding:13px 15px;cursor:pointer;font:inherit;color:inherit;text-align:left;
  box-shadow:0 1px 4px rgba(16,33,43,.06);
  transition:border-color .16s var(--ease),background .16s var(--ease),box-shadow .16s var(--ease);
}
#tvq-root .diag:hover{border-color:var(--brand);box-shadow:0 2px 10px rgba(15,123,138,.14)}
#tvq-root .diag[aria-pressed="true"]{border-color:var(--brand);background:var(--brand-tint);box-shadow:0 2px 10px rgba(15,123,138,.14)}
#tvq-root .diag .dl{font-weight:700;font-size:1rem}
#tvq-root .diag .ds{color:var(--muted);font-size:.85rem;margin-left:8px;font-weight:500}
#tvq-root .diag .chk{width:22px;height:22px;border-radius:50%;border:2px solid #b0bec8;flex:none;display:grid;place-items:center;transition:.16s var(--ease)}
#tvq-root .diag[aria-pressed="true"] .chk{background:var(--brand);border-color:var(--brand)}
#tvq-root .diag[aria-pressed="true"] .chk::after{content:"✓";color:#fff;font-size:13px;font-weight:700;line-height:1}

/* Шкала цен */
#tvq-root .scale{margin-top:20px}
#tvq-root .scale-num{font-size:clamp(1.45rem,6vw,2rem);font-weight:800;color:var(--brand-ink);letter-spacing:-.02em;min-height:1.4em}
#tvq-root .scale-num.placeholder{font-size:1rem;font-weight:600;color:var(--muted)}
#tvq-root .scale-track{position:relative;height:14px;border-radius:99px;background:#dde3e8;margin-top:10px;overflow:hidden}
#tvq-root .scale-fill{position:absolute;top:0;bottom:0;left:0;width:0;border-radius:99px;background:linear-gradient(90deg,#16a3b8,var(--brand-ink));transition:left .4s var(--ease),width .4s var(--ease);box-shadow:0 0 0 1px rgba(10,91,102,.2)}
#tvq-root .scale-ends{display:flex;justify-content:space-between;color:var(--muted);font-size:.8rem;margin-top:7px;font-variant-numeric:tabular-nums}

/* Диапазон (осмотр) */
#tvq-root .range-big{margin-top:20px;background:var(--brand-tint);border-radius:var(--radius-sm);padding:20px;text-align:center}
#tvq-root .range-big span{display:block;font-size:clamp(1.5rem,6.5vw,2.1rem);font-weight:800;color:var(--brand-ink);letter-spacing:-.02em}
#tvq-root .range-big small{display:block;color:var(--muted);font-size:.82rem;margin-top:4px}

#tvq-root .diag-note{margin-top:10px;color:var(--muted);font-size:.82rem}
#tvq-root .disclaimer{margin-top:16px;color:var(--muted);font-size:.84rem;line-height:1.4;padding-left:13px;border-left:2px solid var(--line)}

/* Поле модели */
#tvq-root .field{display:block;margin-top:16px}
#tvq-root .field span{display:block;font-size:.85rem;font-weight:600;margin-bottom:6px}
#tvq-root .field em{color:var(--muted);font-style:normal;font-weight:500}
#tvq-root .field input{width:100%;font:inherit;font-size:1rem;padding:12px 14px;border:2px solid #b0bec8;border-radius:var(--radius-sm);background:var(--bg);color:var(--ink)}
#tvq-root .field input::placeholder{color:#9aa7b2}
#tvq-root .field input:focus{border-color:var(--brand)}

/* Кнопка WhatsApp */
#tvq-root .wa{
  display:flex;align-items:center;justify-content:center;gap:10px;margin-top:18px;
  background:var(--wa);color:#fff;text-decoration:none;font-weight:700;font-size:1.02rem;
  padding:15px 18px;border-radius:var(--radius-sm);min-height:52px;
  transition:background .16s var(--ease),transform .12s var(--ease);
}
#tvq-root .wa:hover:not([data-disabled="true"]){background:var(--wa-hi)}
#tvq-root .wa:active:not([data-disabled="true"]){transform:scale(.99)}
#tvq-root .wa-ico{width:22px;height:22px;flex:none}
#tvq-root .wa[data-disabled="true"]{background:#8da8b5;cursor:not-allowed;pointer-events:auto}

/* Не делаю */
#tvq-root .stop{text-align:center;padding:10px 4px 6px}
#tvq-root .stop-icon{width:54px;height:54px;border-radius:50%;background:var(--stop-tint);color:var(--stop);font-size:1.7rem;font-weight:800;display:grid;place-items:center;margin:6px auto 16px}
#tvq-root .stop .title{text-align:center}
#tvq-root .stop .sub{margin-top:10px}
#tvq-root .ghost{
  display:inline-flex;align-items:center;gap:8px;margin-top:20px;text-decoration:none;
  border:1.5px solid var(--line);border-radius:var(--radius-sm);padding:12px 18px;
  color:var(--brand-ink);font-weight:700;font-size:.95rem;transition:border-color .16s var(--ease)
}
#tvq-root .ghost:hover{border-color:var(--brand)}
#tvq-root .ghost::after{content:"↗";font-weight:600}

#tvq-root :focus-visible{outline:2px solid var(--brand);outline-offset:2px;border-radius:6px}

@media (max-width:360px){
  #tvq-root .faults{grid-template-columns:1fr}
  #tvq-root .fault{min-height:0;flex-direction:row;align-items:center}
}
@media (prefers-reduced-motion:reduce){
  #tvq-root .screen.is-active{animation:none}
  #tvq-root .scale-fill{transition:none}
  #tvq-root *{transition:none!important}
}
