/* ============================================================
   DOMproxy – доменное бюро · вариант 7 «НЕО-БРУТАЛИЗМ»
   Жирные обводки, твёрдые тени, капс, моно-ярлыки, цветные блоки
   HTML5 + CSS3, без фреймворков
   ============================================================ */

:root{
  --ink:    #0E1116;   /* чёрный (обводки/текст) */
  --paper:  #FFFFFF;
  --cream:  #FFF7E8;   /* тёплая подложка */
  --blue:   #0039A6;
  --blue-l: #1E54C8;
  --red:    #D52B1E;
  --ink-2:  #3C434F;

  --bd:     3px solid var(--ink);
  --bd2:    2px solid var(--ink);
  --sh:     7px 7px 0 var(--ink);
  --sh-sm:  4px 4px 0 var(--ink);
  --sh-lg:  12px 12px 0 var(--ink);

  --wrap:   1240px;
  --pad:    clamp(16px, 4vw, 48px);

  --font:   'Golos Text', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  --mono:   'Spline Sans Mono', ui-monospace, Menlo, monospace;
  --e:      cubic-bezier(.3,1.2,.5,1);
}

*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; scroll-padding-top:140px; -webkit-text-size-adjust:100%; }
@media (prefers-reduced-motion: reduce){
  html{ scroll-behavior:auto; }
  *,*::before,*::after{ animation-duration:.001ms !important; animation-iteration-count:1 !important; transition-duration:.001ms !important; }
}
body{
  font-family:var(--font); color:var(--ink); background:var(--paper);
  font-size:17px; line-height:1.55; -webkit-font-smoothing:antialiased; overflow-x:hidden;
  min-height:100vh; display:flex; flex-direction:column;
}
#main{ flex:1 0 auto; }   /* контент тянется, прижимая футер к низу */
.ft{ flex-shrink:0; }
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; cursor:pointer; border:none; background:none; color:inherit; }
ul,ol{ list-style:none; }
::selection{ background:var(--red); color:#fff; }

.skip{ position:absolute; left:-999px; top:0; background:var(--ink); color:#fff; padding:10px 16px; z-index:3000; }
.skip:focus{ left:8px; top:8px; }

h1,h2,h3{ line-height:1.02; letter-spacing:-.02em; font-weight:900; }

.tag{ display:inline-block; font-family:var(--mono); font-size:12.5px; font-weight:600; letter-spacing:.02em; }
.tag--mono{ background:var(--ink); color:#fff; padding:5px 11px; }
.tag--light{ background:#fff; color:var(--ink); }

/* ---------- КНОПКИ ---------- */
.bbtn{ display:inline-flex; align-items:center; justify-content:center; gap:.5em; padding:13px 24px;
  border:var(--bd); font-weight:800; font-size:15.5px; letter-spacing:-.01em; white-space:nowrap;
  box-shadow:var(--sh-sm); transition:transform .12s var(--e), box-shadow .12s var(--e), background .2s; }
.bbtn--lg{ padding:16px 30px; font-size:17px; box-shadow:var(--sh); }
.bbtn--block{ width:100%; }
.bbtn:hover{ transform:translate(-2px,-2px); box-shadow:9px 9px 0 var(--ink); }
.bbtn:active{ transform:translate(2px,2px); box-shadow:2px 2px 0 var(--ink); }
.bbtn--blue{ background:var(--blue); color:#fff; }
.bbtn--red{ background:var(--red); color:#fff; }
.bbtn--ghost{ background:#fff; color:var(--ink); }

/* ---------- БЕГУЩАЯ СТРОКА ---------- */
.mq{ background:var(--red); color:#fff; border-bottom:var(--bd); overflow:hidden; }
.mq__t{ display:inline-flex; white-space:nowrap; padding:9px 0; font-family:var(--mono); font-weight:700;
  font-size:14px; letter-spacing:.04em; text-transform:uppercase; animation:mq 32s linear infinite; }
.mq__t span{ padding:0 18px; }
.mq__t i{ font-style:normal; }
@keyframes mq{ from{ transform:translateX(0); } to{ transform:translateX(-50%); } }

/* ---------- ШАПКА ---------- */
.hd{ position:sticky; top:0; z-index:900; background:var(--paper); border-bottom:var(--bd); padding:14px var(--pad); }
.hd__in{ max-width:var(--wrap); margin:0 auto; display:flex; align-items:center; gap:20px; }
.logo{ display:inline-flex; align-items:center; gap:11px; font-weight:900; }
.logo__b{ width:38px; height:38px; background:var(--blue); color:#fff; border:var(--bd2); box-shadow:var(--sh-sm);
  display:grid; place-items:center; font-size:22px; font-weight:900; flex:none;
  transform:rotate(-3deg); transition:transform .12s var(--e), box-shadow .12s var(--e); }
.logo__t{ display:inline-flex; align-items:center; gap:7px; font-size:24px; letter-spacing:-.02em; text-transform:none; }
.logo__d{ position:relative; top:2px; }
.logo__a{ background:var(--blue); color:#fff; border:var(--bd2); box-shadow:var(--sh-sm);
  padding:1px 9px 2px; transform:rotate(-2deg); transition:transform .12s var(--e), box-shadow .12s var(--e); }
.logo:hover .logo__b{ transform:rotate(0) translate(-2px,-2px); box-shadow:6px 6px 0 var(--ink); }
.logo:hover .logo__a{ transform:rotate(0) translate(-2px,-2px); box-shadow:6px 6px 0 var(--ink); }
.logo:active .logo__b,.logo:active .logo__a{ transform:translate(1px,1px); box-shadow:2px 2px 0 var(--ink); }
.hd__nav{ display:flex; gap:6px; margin-left:auto; }
.hd__nav>a,.hd__drop-t{ display:inline-flex; align-items:center; gap:6px; padding:9px 13px; font-size:15px; font-weight:700; border:2px solid transparent; transition:border-color .15s, background .15s, color .15s; }
.hd__nav>a:hover,.hd__drop-t:hover{ border-color:var(--ink); background:var(--cream); }
.hd__nav>a.is-active,.hd__drop-t.is-active{ background:var(--ink); border-color:var(--ink); color:#fff; }

/* ---------- ДРОПДАУН УСЛУГ ---------- */
.hd__drop{ position:relative; }
.hd__chev{ width:8px; height:8px; border-right:2.5px solid currentColor; border-bottom:2.5px solid currentColor;
  transform:translateY(-2px) rotate(45deg); transition:transform .18s var(--e); }
.hd__drop:hover .hd__chev,.hd__drop:focus-within .hd__chev{ transform:translateY(0) rotate(225deg); }
.hd__drop:hover .hd__drop-t,.hd__drop:focus-within .hd__drop-t{ border-color:var(--ink); background:var(--ink); color:#fff; }

.hd__menu{ position:absolute; top:calc(100% + 10px); left:0; min-width:340px; z-index:950;
  background:var(--paper); border:var(--bd); box-shadow:var(--sh); padding:6px;
  max-height:min(72vh, 600px); overflow-y:auto;
  opacity:0; visibility:hidden; transform:translateY(-8px); transition:opacity .16s, transform .16s var(--e), visibility .16s; }
.hd__drop:hover .hd__menu,.hd__drop:focus-within .hd__menu{ opacity:1; visibility:visible; transform:translateY(0); }
.hd__menu::before{ content:""; position:absolute; bottom:100%; left:0; right:0; height:12px; }
.hd__menu a{ display:flex; align-items:center; gap:11px; padding:11px 13px; font-size:15px; font-weight:700;
  border:2px solid transparent; transition:background .12s, border-color .12s, color .12s; }
.hd__menu a:hover,.hd__menu a:focus-visible{ background:var(--cream); border-color:var(--ink); }
.hd__menu-no{ font-family:var(--mono); font-size:12px; font-weight:700; color:#fff; background:var(--blue);
  border:var(--bd2); padding:2px 6px; flex:none; }
.hd__menu a:nth-child(odd) .hd__menu-no{ background:var(--red); }
.hd__menu-all{ justify-content:center; margin-top:4px; background:var(--ink); color:#fff; font-family:var(--mono);
  font-size:13px; letter-spacing:.02em; }
.hd__menu-all:hover,.hd__menu-all:focus-visible{ background:var(--blue) !important; border-color:var(--ink) !important; color:#fff; }
.hd__cta{ flex:none; }

.burger{ display:none; width:46px; height:46px; border:var(--bd2); box-shadow:var(--sh-sm); flex-direction:column; gap:4px; align-items:center; justify-content:center; background:#fff; }
.burger span{ width:22px; height:2.5px; background:var(--ink); transition:transform .25s, opacity .2s; }
.burger.is-open span:nth-child(1){ transform:translateY(6.5px) rotate(45deg); }
.burger.is-open span:nth-child(2){ opacity:0; }
.burger.is-open span:nth-child(3){ transform:translateY(-6.5px) rotate(-45deg); }

.drawer{ position:fixed; inset:0; z-index:1100; background:var(--cream); padding:16px var(--pad) 32px;
  display:flex; flex-direction:column; gap:18px; transform:translateX(100%); transition:transform .3s var(--e); overflow-y:auto; }
.drawer.is-open{ transform:translateX(0); }
.drawer__top{ display:flex; align-items:center; justify-content:space-between; }
.drawer__close{ position:relative; width:46px; height:46px; border:var(--bd2); box-shadow:var(--sh-sm); background:#fff; flex:none; }
.drawer__close::before,.drawer__close::after{ content:""; position:absolute; left:10px; right:10px; top:50%; height:2.5px; background:var(--ink); }
.drawer__close::before{ transform:translateY(-50%) rotate(45deg); }
.drawer__close::after{ transform:translateY(-50%) rotate(-45deg); }
.drawer__close:active{ transform:translate(1px,1px); box-shadow:2px 2px 0 var(--ink); }
.drawer__zones{ display:flex; gap:8px; }
.drawer__nav{ display:flex; flex-direction:column; gap:10px; }
.drawer__nav a{ padding:14px 16px; font-size:20px; font-weight:800; border:var(--bd); box-shadow:var(--sh-sm); background:#fff;
  transition:transform .12s var(--e), box-shadow .12s var(--e); }
.drawer__nav a:active{ transform:translate(2px,2px); box-shadow:2px 2px 0 var(--ink); }
.drawer__nav a.is-active{ background:var(--blue); color:#fff; }
.drawer__cta{ margin-top:2px; }
.drawer__contacts{ display:flex; flex-direction:column; gap:10px; margin-top:auto; }
.drawer__contact{ display:flex; flex-direction:column; gap:2px; padding:12px 16px; border:var(--bd); box-shadow:var(--sh-sm); background:#fff; }
.drawer__contact-l{ font-family:var(--mono); font-size:11.5px; font-weight:700; letter-spacing:.05em; text-transform:uppercase; color:var(--ink-2); }
.drawer__contact-v{ font-size:18px; font-weight:900; }
.drawer__hours{ font-family:var(--mono); font-size:12px; color:var(--ink-2); }

/* ---------- HERO ---------- */
.hero{ position:relative; border-bottom:var(--bd); padding:clamp(48px,7vw,96px) var(--pad);
  background:
    repeating-linear-gradient(0deg, transparent, transparent 38px, rgba(14,17,22,.05) 38px, rgba(14,17,22,.05) 39px),
    repeating-linear-gradient(90deg, transparent, transparent 38px, rgba(14,17,22,.05) 38px, rgba(14,17,22,.05) 39px),
    var(--cream); }
.hero__in{ max-width:var(--wrap); margin:0 auto; position:relative; z-index:1; }
.hero__sticker{ position:absolute; top:0; right:0; z-index:2; font-family:var(--mono); font-weight:700; font-size:14px;
  background:var(--red); color:#fff; border:var(--bd); box-shadow:var(--sh-sm); padding:10px 16px; transform:rotate(7deg); }
.hero__h1{ font-size:clamp(40px,9vw,108px); font-weight:900; letter-spacing:-.04em; line-height:.92; text-transform:uppercase; margin:18px 0; }
.hl{ display:inline-block; padding:0 .12em; border:var(--bd); box-shadow:var(--sh-sm); }
.hl--blue{ background:var(--blue); color:#fff; transform:rotate(-1.5deg); }
.hl--red{ background:var(--red); color:#fff; transform:rotate(1.5deg); }
.hero__zones{ display:flex; gap:12px; margin:22px 0; }
.chip{ font-family:var(--mono); font-weight:700; font-size:17px; padding:8px 16px; border:var(--bd); box-shadow:var(--sh-sm); background:#fff; }
.chip--b{ background:var(--blue); color:#fff; }
.chip--r{ background:var(--red); color:#fff; }
.hero__lead{ max-width:60ch; font-size:clamp(16px,1.5vw,20px); font-weight:500; }
.hero__cta{ margin-top:30px; display:flex; gap:14px; flex-wrap:wrap; }

/* ---------- СЕКЦИИ ---------- */
.sec{ padding:clamp(48px,6vw,90px) var(--pad); border-bottom:var(--bd); }
.sec--cream{ background:var(--cream); }
.sec--blue{ background:var(--blue); color:#fff; }

.sh{ max-width:var(--wrap); margin:0 auto clamp(30px,4vw,48px); }
.sh__no{ font-family:var(--mono); font-size:15px; font-weight:700; }
.sh__t{ font-size:clamp(30px,5vw,60px); font-weight:900; letter-spacing:-.03em; text-transform:uppercase; margin:8px 0 14px; }
.sh__d{ max-width:54ch; font-size:17px; font-weight:500; color:var(--ink-2); }
.sh--light .sh__d{ color:rgba(255,255,255,.85); }

/* ---------- BENTO-СЕТКА (брутал) ---------- */
.bgrid{ max-width:var(--wrap); margin:0 auto; display:grid; gap:clamp(16px,2vw,22px); }
.bgrid--2{ grid-template-columns:repeat(2,1fr); }
.bgrid--3{ grid-template-columns:repeat(3,1fr); }
.bgrid--4{ grid-template-columns:repeat(4,1fr); }

.bx{ background:#fff; border:var(--bd); box-shadow:var(--sh); padding:clamp(22px,2.2vw,30px);
  display:flex; flex-direction:column; transition:transform .14s var(--e), box-shadow .14s var(--e); }
.bx:hover{ transform:translate(-3px,-3px); box-shadow:var(--sh-lg); }
.bx--blue{ background:var(--blue); color:#fff; }
.bx--red{ background:var(--red); color:#fff; }
.bx--paper{ background:#fff; color:var(--ink); }
.bx__no{ font-family:var(--mono); font-size:14px; font-weight:700; }
.bx__step{ display:inline-grid; place-items:center; width:46px; height:46px; background:var(--red); color:#fff;
  border:var(--bd2); box-shadow:var(--sh-sm); font-size:18px; font-weight:900; margin-bottom:16px; }
.bx__t{ font-size:clamp(18px,1.9vw,22px); font-weight:800; letter-spacing:-.02em; margin:12px 0 10px; }
.bx__d{ font-size:15px; font-weight:500; line-height:1.55; flex:1; }
.bx--blue .bx__d,.bx--red .bx__d{ color:rgba(255,255,255,.86); }
.bx__link{ margin-top:18px; font-family:var(--mono); font-size:14px; font-weight:700; align-self:flex-start;
  border-bottom:3px solid var(--red); padding-bottom:2px; transition:gap .2s; }
.bx--blue .bx__link, .bx__link--light{ border-bottom-color:#fff; color:#fff; }
.bx__price{ margin-top:16px; font-family:var(--mono); }
.bx__price b{ display:block; font-size:18px; font-weight:700; letter-spacing:-.01em; }
.bx__price span{ font-size:12.5px; font-weight:500; color:var(--ink-2); }
.bx--blue .bx__price span, .bx--red .bx__price span{ color:rgba(255,255,255,.82); }

/* ---------- Плавающая панель услуги (цена + CTA) ---------- */
.svc-bar{ position:fixed; left:0; right:0; bottom:0; z-index:920;
  background:var(--paper); border-top:var(--bd); box-shadow:0 -6px 18px rgba(14,17,22,.10);
  transform:translateY(110%); transition:transform .26s var(--e); }
.svc-bar.is-show{ transform:translateY(0); }
.svc-bar__in{ max-width:var(--wrap); margin:0 auto; padding:11px var(--pad);
  display:flex; align-items:center; justify-content:space-between; gap:16px; }
.svc-bar__info{ display:flex; flex-direction:column; gap:1px; min-width:0; font-family:var(--mono); }
.svc-bar__name{ font-size:12px; font-weight:600; letter-spacing:.05em; text-transform:uppercase; color:var(--ink-2);
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.svc-bar__price{ display:flex; align-items:baseline; gap:9px; font-size:clamp(17px,2vw,21px); font-weight:700; letter-spacing:-.01em; }
.svc-bar__price i{ font-style:normal; font-size:12px; font-weight:500; color:var(--ink-2); }
.svc-bar__btn{ flex:none; box-shadow:var(--sh-sm); }
body.svc-bar-shown .totop{ bottom:calc(var(--svc-bar-h, 70px) + 16px); }
body.svc-bar-shown .cookie{ bottom:calc(var(--svc-bar-h, 70px) + 16px); }
@media (max-width:560px){
  .svc-bar__name{ display:none; }
  .svc-bar__in{ padding:9px 14px; gap:12px; }
  .svc-bar__btn{ padding:11px 16px; font-size:14px; }
}
.bx--exp{ flex-direction:row; gap:20px; align-items:flex-start; }
.bx__m{ width:58px; height:58px; flex:none; background:var(--ink); color:#fff; border:var(--bd2); box-shadow:var(--sh-sm);
  display:grid; place-items:center; font-size:18px; font-weight:900; }
.bx--exp .bx__t{ margin-top:0; }
.bx--post .post__m{ display:flex; align-items:center; justify-content:space-between; gap:12px; margin-bottom:14px; }
.bx--post time{ font-family:var(--mono); font-size:13px; }
.bx--post .bx__t{ flex:1; }

/* ---------- ЦИФРЫ (полоса) ---------- */
.band{ border-bottom:var(--bd); padding-inline:var(--pad); }
.band__in{ max-width:var(--wrap); margin:0 auto; display:grid; grid-template-columns:repeat(4,1fr); }
.band__i{ padding:clamp(26px,3vw,42px) clamp(18px,2vw,28px); border-right:var(--bd); display:flex; flex-direction:column; gap:8px; }
.band__i:first-child{ padding-left:0; }
.band__i:last-child{ padding-right:0; }
.band__i:last-child{ border-right:none; }
.band__i:nth-child(2){ background:var(--blue); color:#fff; }
.band__i:nth-child(3){ background:var(--red); color:#fff; }
.band__n{ font-size:clamp(40px,5vw,68px); font-weight:900; letter-spacing:-.04em; line-height:1; font-variant-numeric:tabular-nums; }
.band__l{ font-family:var(--mono); font-size:13px; font-weight:600; letter-spacing:.02em; }

/* ---------- FAQ ---------- */
.faq{ max-width:var(--wrap); margin:0 auto; display:flex; flex-direction:column; gap:14px; }
.faq__i{ border:var(--bd); box-shadow:var(--sh-sm); background:#fff; transition:box-shadow .15s, transform .15s; }
.faq__i[open]{ box-shadow:var(--sh); }
.faq__q{ display:flex; align-items:center; justify-content:space-between; gap:18px; padding:20px 22px;
  font-size:clamp(16.5px,1.7vw,20px); font-weight:800; letter-spacing:-.02em; list-style:none; cursor:pointer; }
.faq__q::-webkit-details-marker{ display:none; }
.faq__ic{ position:relative; width:24px; height:24px; flex:none; border:var(--bd2); }
.faq__ic::before,.faq__ic::after{ content:""; position:absolute; background:var(--ink); transition:transform .25s; }
.faq__ic::before{ left:4px; right:4px; top:9px; height:2.5px; }
.faq__ic::after{ top:4px; bottom:4px; left:9px; width:2.5px; }
.faq__i[open] .faq__ic{ background:var(--red); border-color:var(--ink); }
.faq__i[open] .faq__ic::before,.faq__i[open] .faq__ic::after{ background:#fff; }
.faq__i[open] .faq__ic::after{ transform:scaleY(0); }
.faq__a{ border-top:var(--bd2); }
.faq__a p{ padding:18px 22px; font-size:16px; font-weight:500; line-height:1.6; color:var(--ink-2); }

/* ---------- CTA + ФОРМА ---------- */
.cta{ position:relative; max-width:var(--wrap); margin:0 auto; background:var(--ink); color:#fff;
  border:var(--bd); box-shadow:var(--sh-lg); padding:clamp(28px,3.5vw,52px); }
.cta__sticker{ position:absolute; top:-18px; right:24px; font-family:var(--mono); font-weight:700; font-size:13px;
  background:var(--red); color:#fff; border:var(--bd); box-shadow:var(--sh-sm); padding:9px 14px; transform:rotate(-5deg); z-index:2; }
.cta__grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(28px,4vw,52px); align-items:start; }
.cta__t{ font-size:clamp(28px,3.6vw,50px); font-weight:900; text-transform:uppercase; letter-spacing:-.03em; color:#fff; margin:14px 0 0; }
.cta__d{ margin-top:16px; font-size:17px; font-weight:500; color:rgba(255,255,255,.8); line-height:1.6; max-width:42ch; }
.cta__contacts{ margin-top:26px; display:flex; flex-direction:column; gap:6px; }
.cta__contacts a{ font-size:20px; font-weight:900; }
.cta__contacts a:hover{ color:#FFD2CD; }
.cta__contacts span{ font-family:var(--mono); font-size:13px; color:rgba(255,255,255,.6); margin-top:4px; }

/* Компактный CTA (страницы без формы) */
.cta--sm{ box-shadow:var(--sh); padding:clamp(20px,2.4vw,34px); }
.cta--sm .cta__grid{ gap:clamp(20px,3vw,40px); align-items:center; }
.cta--sm .cta__t{ font-size:clamp(22px,2.4vw,32px); margin-top:8px; }
.cta--sm .cta__d{ margin-top:10px; }
.cta__side{ display:flex; flex-direction:column; gap:16px; align-items:flex-start; justify-content:center; }
.cta__side .cta__contacts{ margin-top:0; }
.cta__side .cta__contacts a{ font-size:18px; }

/* Тонкая CTA-полоса (одна строка: призыв + кнопка) */
.ctab{ max-width:var(--wrap); margin:0 auto; background:var(--blue); color:#fff; border:var(--bd); box-shadow:var(--sh);
  display:flex; align-items:center; justify-content:space-between; gap:clamp(16px,3vw,40px);
  padding:clamp(16px,2vw,24px) clamp(20px,3vw,38px); }
.ctab__t{ font-size:clamp(19px,2.4vw,30px); font-weight:900; letter-spacing:-.02em; text-transform:uppercase; line-height:1.05; }
.ctab__btn{ flex:none; }
/* Контейнер для кнопок в секции (выравнивание по ширине --wrap) */
.sec-cta{ max-width:var(--wrap); margin:0 auto; display:flex; flex-wrap:wrap; gap:12px; }
@media (max-width:640px){ .ctab{ flex-direction:column; align-items:flex-start; gap:14px; } .ctab__btn{ width:100%; } }

/* ============================================================
   СТРАНИЦА СТАТЬИ
   ============================================================ */
.article{ max-width:var(--wrap); margin:0 auto; }
.article__tag{ display:inline-block; font-family:var(--mono); font-size:11.5px; font-weight:700; letter-spacing:.04em;
  text-transform:uppercase; background:var(--ink); color:#fff; padding:5px 11px; }
.article__h1{ font-size:clamp(27px,4.2vw,50px); font-weight:900; letter-spacing:-.03em; text-transform:uppercase;
  line-height:1.03; margin:16px 0 14px; }
.article__meta{ display:flex; flex-wrap:wrap; gap:6px 16px; font-family:var(--mono); font-size:13px; font-weight:600;
  color:var(--ink-2); padding-bottom:22px; border-bottom:var(--bd); }
.article__lead{ font-size:clamp(18px,2vw,22px); font-weight:600; line-height:1.55; color:var(--ink); margin:26px 0; }
.article__body{ font-size:17px; line-height:1.72; color:var(--ink-2); }
.article__body h2{ font-size:clamp(22px,2.6vw,30px); font-weight:900; letter-spacing:-.02em; text-transform:uppercase;
  color:var(--ink); margin:38px 0 14px; scroll-margin-top:150px; }
.article__body h3{ font-size:20px; font-weight:800; letter-spacing:-.01em; color:var(--ink); margin:26px 0 10px; }
.article__body p{ margin:0 0 16px; }
.article__body ul,.article__body ol{ margin:4px 0 20px; display:flex; flex-direction:column; gap:10px; }
.article__body li{ position:relative; padding-left:32px; }
.article__body ul li::before{ content:""; position:absolute; left:2px; top:8px; width:12px; height:12px;
  background:var(--blue); border:var(--bd2); }
.article__body ol{ counter-reset:n; }
.article__body ol li{ counter-increment:n; }
.article__body ol li::before{ content:counter(n); position:absolute; left:0; top:0; width:24px; height:24px;
  background:var(--ink); color:#fff; font-family:var(--mono); font-size:12px; font-weight:700; display:grid; place-items:center; }
.article__body a{ font-weight:700; color:var(--ink); border-bottom:3px solid var(--red); }
.article__body strong{ color:var(--ink); font-weight:800; }

.note{ background:var(--cream); border:var(--bd); border-left:8px solid var(--blue); box-shadow:var(--sh-sm);
  padding:18px 20px; margin:26px 0; font-size:16px; line-height:1.6; color:var(--ink); }
.note b{ display:block; font-family:var(--mono); font-size:12px; letter-spacing:.05em; text-transform:uppercase;
  color:var(--blue); margin-bottom:6px; }

.toc{ border:var(--bd); box-shadow:var(--sh-sm); background:#fff; padding:18px 20px; margin:26px 0; }
.toc__t{ font-family:var(--mono); font-size:12px; font-weight:700; letter-spacing:.05em; text-transform:uppercase;
  color:var(--ink-2); margin-bottom:12px; }
.toc ol{ counter-reset:t; display:flex; flex-direction:column; gap:9px; }
.toc li{ counter-increment:t; }
.toc a{ font-weight:700; border-bottom:2px solid transparent; }
.toc a:hover{ border-color:var(--ink); }
.toc a::before{ content:counter(t,decimal-leading-zero)"  "; font-family:var(--mono); color:var(--red); }

.author{ display:flex; align-items:center; gap:16px; border:var(--bd); box-shadow:var(--sh-sm); background:#fff;
  padding:18px 20px; margin:34px 0 0; }
.author__ava{ width:54px; height:54px; flex:none; background:var(--ink); color:#fff; border:var(--bd2); box-shadow:var(--sh-sm);
  display:grid; place-items:center; font-weight:900; font-size:16px; }
.author__name{ font-weight:800; font-size:16px; }
.author__role{ font-family:var(--mono); font-size:13px; color:var(--ink-2); }

/* ============================================================
   ПРОВЕРКА ДОМЕНА
   ============================================================ */
.dom-form{ max-width:var(--wrap); margin:0 auto 10px; display:flex; gap:12px; flex-wrap:wrap; }
.dom-input{ flex:1; min-width:240px; padding:15px 18px; font-family:inherit; font-size:18px; font-weight:600;
  background:var(--cream); color:var(--ink); border:var(--bd); transition:box-shadow .15s, background .15s; }
.dom-input::placeholder{ color:#8A8170; }
.dom-input:focus{ outline:none; background:#fff; box-shadow:var(--sh-sm); }
.dom-form .bbtn{ flex:none; }
.dom-hint{ max-width:var(--wrap); margin:0 auto; font-family:var(--mono); font-size:13px; color:var(--ink-2); }

.dom-msg{ max-width:var(--wrap); margin:26px auto 0; border:var(--bd); box-shadow:var(--sh-sm); padding:18px 20px; font-weight:700; background:#fff; }
.dom-msg--err{ background:#FFF0EE; border-left:8px solid var(--red); }

.dom-free{ max-width:var(--wrap); margin:28px auto 0; background:var(--blue); color:#fff; border:var(--bd); box-shadow:var(--sh-lg);
  padding:clamp(22px,3vw,40px); display:flex; gap:clamp(16px,2.5vw,28px); align-items:flex-start; }
.dom-free__ic{ flex:none; width:60px; height:60px; background:#fff; color:var(--blue); border:var(--bd); box-shadow:var(--sh-sm);
  display:grid; place-items:center; font-size:32px; font-weight:900; }
.dom-free__t{ font-size:clamp(20px,2.6vw,32px); font-weight:900; text-transform:uppercase; letter-spacing:-.02em; line-height:1.06; margin:12px 0 16px; color:#fff; }
.dom-free__meta{ display:flex; flex-wrap:wrap; gap:8px 26px; margin-bottom:22px; font-size:16px; }
.dom-free__meta b{ font-weight:800; }
@media (max-width:640px){ .dom-free{ flex-direction:column; } }

.dom-alts{ max-width:var(--wrap); margin:18px auto 0; display:flex; flex-wrap:wrap; align-items:center; gap:10px; }
.dom-alts__t{ font-family:var(--mono); font-size:13px; font-weight:700; color:var(--ink-2); }
.dom-alt{ font-family:var(--mono); font-weight:700; padding:9px 14px; border:var(--bd2); box-shadow:var(--sh-sm); background:#fff;
  transition:transform .12s var(--e), box-shadow .12s var(--e); }
.dom-alt:hover{ transform:translate(-2px,-2px); box-shadow:6px 6px 0 var(--ink); }

.dom-card{ max-width:var(--wrap); margin:28px auto 0; border:var(--bd); box-shadow:var(--sh); background:#fff; padding:clamp(20px,2.6vw,34px); }
.dom-card__head{ display:flex; justify-content:space-between; align-items:flex-start; gap:16px; flex-wrap:wrap; padding-bottom:18px; border-bottom:var(--bd); }
.dom-card__t{ font-size:clamp(22px,3vw,38px); font-weight:900; letter-spacing:-.03em; margin-top:8px; word-break:break-all; }
.dom-verdict{ flex:none; font-family:var(--mono); font-weight:700; font-size:13px; padding:9px 14px; border:var(--bd2); box-shadow:var(--sh-sm); }
.dom-verdict--good{ background:var(--blue); color:#fff; }
.dom-verdict--ok{ background:var(--cream); color:var(--ink); }
.dom-verdict--warn{ background:var(--red); color:#fff; }
@media (max-width:640px){ .dom-verdict{ flex:none; width:100%; text-align:center; } }

.dom-facts{ display:grid; grid-template-columns:repeat(2,1fr); margin:20px 0 6px; border-top:var(--bd2); border-left:var(--bd2); }
.dom-fact{ display:flex; flex-direction:column; gap:3px; padding:12px 16px; border-right:var(--bd2); border-bottom:var(--bd2); }
.dom-fact__l{ font-family:var(--mono); font-size:11.5px; font-weight:700; letter-spacing:.04em; text-transform:uppercase; color:var(--ink-2); }
.dom-fact__v{ font-weight:700; word-break:break-word; }
@media (max-width:640px){ .dom-facts{ grid-template-columns:1fr; } }

.dom-sub{ font-family:var(--mono); font-size:13px; font-weight:700; letter-spacing:.05em; text-transform:uppercase; color:var(--ink-2); margin:26px 0 12px; }
.dom-check{ display:flex; flex-direction:column; gap:8px; }
.dom-check__i{ display:flex; align-items:center; gap:12px; padding:11px 14px; border:var(--bd2); background:#fff; font-weight:600; }
.dom-check__i i{ font-style:normal; color:var(--ink-2); font-family:var(--mono); font-size:13px; margin-left:4px; }
.dom-check__m{ flex:none; width:26px; height:26px; display:grid; place-items:center; border:var(--bd2); font-weight:900; font-size:14px; }
.dom-check__i.is-ok .dom-check__m{ background:var(--blue); color:#fff; }
.dom-check__i.is-no .dom-check__m{ background:var(--red); color:#fff; }
.dom-check__i.is-warn .dom-check__m{ background:#fff; color:var(--red); }
.dom-check__i.is-unknown .dom-check__m{ background:var(--cream); color:var(--ink-2); }

/* Призыв: домен не прошёл идентификацию (UNVERIFIED) */
.dom-ident{ max-width:var(--wrap); margin:28px auto 0; background:var(--red); color:#fff; border:var(--bd); box-shadow:var(--sh-lg);
  padding:clamp(22px,2.8vw,36px); display:flex; gap:clamp(16px,2.5vw,26px); align-items:flex-start; }
.dom-ident__ic{ flex:none; width:58px; height:58px; background:#fff; color:var(--red); border:var(--bd); box-shadow:var(--sh-sm);
  display:grid; place-items:center; font-size:34px; font-weight:900; }
.dom-ident__t{ font-size:clamp(20px,2.6vw,30px); font-weight:900; text-transform:uppercase; letter-spacing:-.02em; line-height:1.06; margin:10px 0 10px; color:#fff; }
.dom-ident p{ font-size:16px; line-height:1.55; color:rgba(255,255,255,.92); margin-bottom:18px; max-width:62ch; }
@media (max-width:640px){ .dom-ident{ flex-direction:column; } }

/* ---------- COOKIE-баннер ---------- */
.cookie{ position:fixed; left:16px; bottom:16px; z-index:1000; max-width:340px;
  background:var(--cream); color:var(--ink); border:var(--bd); box-shadow:var(--sh);
  padding:18px 20px; display:flex; flex-direction:column; gap:12px; }
.cookie[hidden]{ display:none; }
.cookie__t{ font-size:14px; line-height:1.5; }
.cookie__t a{ border-bottom:2px solid var(--red); font-weight:700; }
.cookie__t a:hover{ color:var(--blue); }
.cookie__btns{ display:flex; gap:10px; }
.cookie__btns .bbtn{ flex:1; padding:11px 16px; font-size:14px; box-shadow:var(--sh-sm); }
@media (max-width:480px){ .cookie{ left:12px; right:84px; bottom:12px; max-width:none; } }

/* Кнопка «наверх» */
.totop{ position:fixed; right:16px; bottom:16px; z-index:900; width:50px; height:50px;
  display:grid; place-items:center; background:var(--ink); color:#fff; border:var(--bd); box-shadow:var(--sh-sm);
  opacity:0; visibility:hidden; transform:translateY(10px);
  transition:opacity .2s, transform .2s var(--e), background .15s; }
.totop.is-show{ opacity:1; visibility:visible; transform:translateY(0); }
.totop:hover{ background:var(--blue); }
.totop:active{ transform:translate(2px,2px); box-shadow:2px 2px 0 var(--ink); }
.totop__a{ display:block; width:11px; height:11px; border-top:3px solid currentColor; border-right:3px solid currentColor;
  transform:rotate(-45deg); margin-top:3px; }
@media (max-width:480px){ .totop{ right:12px; bottom:12px; } }

.bform{ position:relative; background:#fff; color:var(--ink); border:var(--bd); box-shadow:var(--sh); padding:clamp(22px,2.4vw,32px); }
.bfld{ margin-bottom:14px; display:flex; flex-direction:column; gap:6px; }
.binput{ width:100%; padding:14px 15px; background:var(--cream); color:var(--ink); font-family:inherit; font-size:16px;
  font-weight:500; border:var(--bd2); transition:box-shadow .15s, background .15s; }
.binput::placeholder{ color:#8A8170; }
.binput:focus{ outline:none; background:#fff; box-shadow:var(--sh-sm); }
.barea{ resize:vertical; min-height:88px; line-height:1.5; }
.bfld.has-err .binput{ border-color:var(--red); background:#FFF0EE; }
.berr{ font-family:var(--mono); font-size:12px; color:var(--red); font-weight:600; }
.bcaptcha__q{ display:block; font-family:var(--mono); font-size:14px; font-weight:700; margin-bottom:10px; line-height:1.4; }
.bcaptcha__opts{ display:flex; gap:10px; flex-wrap:wrap; }
.bcaptcha__opt{ min-width:56px; padding:10px 16px; border:var(--bd2); box-shadow:var(--sh-sm); background:#fff;
  font-weight:900; font-size:16px; transition:transform .1s var(--e), box-shadow .1s var(--e), background .12s, color .12s; }
.bcaptcha__opt:hover{ transform:translate(-2px,-2px); box-shadow:6px 6px 0 var(--ink); }
.bcaptcha__opt.is-sel{ background:var(--blue); color:#fff; border-color:var(--ink); }
.bfld.has-err .berr::before{ content:attr(data-err); }
.bagree{ display:flex; align-items:flex-start; gap:11px; margin:4px 0 18px; cursor:pointer; font-size:13px; line-height:1.5; color:var(--ink-2); }
.bagree input{ position:absolute; opacity:0; width:0; height:0; }
.bagree__box{ width:22px; height:22px; border:var(--bd2); flex:none; margin-top:1px; position:relative; background:#fff; transition:background .15s; }
.bagree input:checked + .bagree__box{ background:var(--blue); }
.bagree input:checked + .bagree__box::after{ content:""; position:absolute; left:6px; top:2px; width:6px; height:11px; border:solid #fff; border-width:0 3px 3px 0; transform:rotate(45deg); }
.bagree.has-err .bagree__box{ border-color:var(--red); }
.bok{ position:absolute; inset:0; background:var(--blue); color:#fff; display:flex; flex-direction:column;
  align-items:center; justify-content:center; text-align:center; padding:36px; gap:12px; }
.bok[hidden]{ display:none; }
.bok__ic{ width:60px; height:60px; background:#fff; color:var(--blue); border:var(--bd); display:grid; place-items:center; font-size:30px; font-weight:900; }
.bok h3{ font-size:24px; font-weight:900; text-transform:uppercase; }
.bok p{ font-size:15.5px; max-width:330px; line-height:1.6; color:rgba(255,255,255,.9); }

/* ---------- ФУТЕР ---------- */
.ft{ background:var(--ink); color:rgba(255,255,255,.7); padding:clamp(40px,5vw,64px) var(--pad) 32px; }
.ft__top{ max-width:var(--wrap); margin:0 auto; display:grid; grid-template-columns:auto 1fr auto; gap:clamp(24px,4vw,56px);
  align-items:center; padding-bottom:30px; border-bottom:2px solid rgba(255,255,255,.2); }
.logo--ft .logo__t{ color:#fff; }
.logo--ft .logo__b{ border-color:rgba(255,255,255,.9); box-shadow:4px 4px 0 rgba(255,255,255,.22); }
.logo--ft .logo__a{ background:var(--blue-l); color:#fff; border-color:rgba(255,255,255,.9); box-shadow:4px 4px 0 rgba(255,255,255,.22); }
.logo--ft:hover .logo__b,.logo--ft:hover .logo__a{ box-shadow:6px 6px 0 rgba(255,255,255,.22); }
.ft__about{ font-size:14.5px; line-height:1.55; max-width:52ch; }
.ft__contacts{ display:flex; flex-direction:column; gap:8px; text-align:right; }
.ft__contacts a{ font-size:18px; font-weight:700; color:#fff; letter-spacing:.01em; transition:color .15s; }
.ft__contacts a:first-child{ font-size:20px; letter-spacing:.02em; }
.ft__contacts a:hover{ color:var(--red); }
.ft__bottom{ max-width:var(--wrap); margin:0 auto; display:flex; align-items:center; justify-content:space-between;
  gap:16px; padding-top:24px; flex-wrap:wrap; font-family:var(--mono); font-size:12.5px; color:rgba(255,255,255,.55); }
.ft__legal{ display:flex; gap:20px; }
.ft__legal a:hover{ color:#fff; }

/* ---------- REVEAL ---------- */
.reveal{ opacity:0; transform:translateY(20px); transition:opacity .5s var(--e), transform .5s var(--e); }
.reveal.is-in{ opacity:1; transform:translateY(0); }

/* ---------- АДАПТИВ ---------- */
@media (max-width:1000px){
  .hd__nav,.hd__cta{ display:none; }
  .burger{ display:flex; margin-left:auto; }
  .bgrid--3,.bgrid--4{ grid-template-columns:repeat(2,1fr); }
  .band__in{ grid-template-columns:repeat(2,1fr); }
  .band__i:nth-child(2){ border-right:none; }
  .band__i:nth-child(1),.band__i:nth-child(2){ border-bottom:var(--bd); }
  .band__i:nth-child(3){ padding-left:0; }
  .band__i:nth-child(2){ padding-right:0; }
  .cta__grid{ grid-template-columns:1fr; }
  .ft__top{ grid-template-columns:1fr; text-align:left; }
  .ft__contacts{ text-align:left; }
}
@media (max-width:640px){
  body{ font-size:16px; }
  .bgrid--2,.bgrid--3,.bgrid--4{ grid-template-columns:1fr; }
  .band{ padding-inline:0; }
  .band__in{ grid-template-columns:1fr; }
  .band__i,
  .band__i:first-child,.band__i:last-child,
  .band__i:nth-child(2),.band__i:nth-child(3){ padding:24px var(--pad); border-right:none; border-bottom:var(--bd); }
  .band__i:last-child{ border-bottom:none; }
  .bx--exp{ flex-direction:column; }
  .ft__bottom{ flex-direction:column; align-items:flex-start; }
}

/* ============================================================
   ВНУТРЕННИЕ СТРАНИЦЫ (контакты / о компании / блог)
   ============================================================ */

/* ---------- Хлебные крошки ---------- */
.crumbs{ max-width:var(--wrap); margin:0 auto 18px; display:flex; flex-wrap:wrap; align-items:center; gap:9px;
  font-family:var(--mono); font-size:13px; font-weight:600; color:var(--ink-2); }
.crumbs a{ border-bottom:2px solid transparent; transition:border-color .15s; }
.crumbs a:hover{ border-color:var(--ink); color:var(--ink); }
.crumbs i{ font-style:normal; opacity:.45; }
.crumbs b{ color:var(--ink); }

/* ---------- Интро страницы «О компании»: текст + акцентная карточка ---------- */
.about-intro{ max-width:var(--wrap); margin:0 auto; display:grid; grid-template-columns:1.5fr 1fr;
  gap:clamp(22px,3vw,44px); align-items:start; }
.lead p{ font-size:clamp(17px,1.7vw,20px); font-weight:500; line-height:1.6; color:var(--ink-2); max-width:62ch; }
.lead p + p{ margin-top:14px; }
.lead strong{ color:var(--ink); font-weight:800; }
.about-card{ position:relative; background:var(--ink); color:#fff; border:var(--bd); box-shadow:var(--sh);
  padding:clamp(22px,2.4vw,30px); }
.about-card__big{ display:block; font-family:var(--font); font-size:clamp(26px,3.4vw,40px); font-weight:900;
  letter-spacing:-.03em; line-height:1.02; margin:14px 0 12px; }
.about-card p{ font-size:15px; font-weight:500; line-height:1.55; color:rgba(255,255,255,.82); }
.about-card__sticker{ position:absolute; top:-16px; right:18px; font-family:var(--mono); font-weight:700; font-size:12.5px;
  background:var(--red); color:#fff; border:var(--bd); box-shadow:var(--sh-sm); padding:7px 12px; transform:rotate(-4deg); }
@media (max-width:860px){ .about-intro{ grid-template-columns:1fr; } .lead p{ max-width:none; } }

/* ---------- Страница контактов ---------- */
.cont{ max-width:var(--wrap); margin:0 auto; display:grid; grid-template-columns:1fr 1fr; gap:clamp(22px,3vw,44px); align-items:start; }
.cont__cards{ display:flex; flex-direction:column; gap:16px; }
.cont__card{ display:flex; flex-direction:column; gap:5px; padding:20px 22px; border:var(--bd); box-shadow:var(--sh-sm); background:#fff; }
.cont__card--blue{ background:var(--blue); color:#fff; }
.cont__card--ink{ background:var(--ink); color:#fff; }
.cont__l{ font-family:var(--mono); font-size:12px; font-weight:700; letter-spacing:.05em; text-transform:uppercase; color:var(--ink-2); }
.cont__card--blue .cont__l,.cont__card--ink .cont__l{ color:rgba(255,255,255,.7); }
.cont__v{ font-size:clamp(19px,2.2vw,24px); font-weight:900; letter-spacing:-.02em; }
.cont__v a:hover{ color:var(--blue); }
.cont__card--blue .cont__v a:hover,.cont__card--ink .cont__v a:hover{ color:#FFD2CD; }
.cont__note{ font-size:14.5px; font-weight:500; line-height:1.55; }
@media (max-width:860px){ .cont{ grid-template-columns:1fr; } }

/* ---------- Рубрики и карточки блога ---------- */
.rubs{ max-width:var(--wrap); margin:0 auto clamp(26px,3vw,40px); display:flex; flex-wrap:wrap; gap:10px; }
.rub{ font-family:var(--mono); font-size:13px; font-weight:700; padding:9px 14px; border:var(--bd2); box-shadow:var(--sh-sm);
  background:#fff; transition:transform .12s var(--e), box-shadow .12s var(--e), background .15s, color .15s; }
.rub:hover{ transform:translate(-2px,-2px); box-shadow:6px 6px 0 var(--ink); }
.rub--active{ background:var(--blue); color:#fff; }

/* ---------- Пагинация блога ---------- */
.pager{ max-width:var(--wrap); margin:clamp(28px,4vw,44px) auto 0; display:flex; flex-wrap:wrap; gap:10px; justify-content:center; }
.pager__btn{ min-width:46px; height:46px; padding:0 12px; display:inline-grid; place-items:center; border:var(--bd2); box-shadow:var(--sh-sm);
  background:#fff; font-family:var(--mono); font-weight:900; font-size:16px;
  transition:transform .12s var(--e), box-shadow .12s var(--e), background .12s, color .12s; }
.pager__btn:hover{ transform:translate(-2px,-2px); box-shadow:6px 6px 0 var(--ink); }
.pager__btn.is-active{ background:var(--blue); color:#fff; border-color:var(--ink); }
.pager__btn.is-disabled{ opacity:.4; box-shadow:none; pointer-events:none; }

/* ---------- Страницы ошибок (404/500/503) ---------- */
.errpage{ min-height:100vh; display:flex; align-items:center; justify-content:center; padding:40px var(--pad);
  background:
    repeating-linear-gradient(0deg, transparent, transparent 38px, rgba(14,17,22,.05) 38px, rgba(14,17,22,.05) 39px),
    repeating-linear-gradient(90deg, transparent, transparent 38px, rgba(14,17,22,.05) 38px, rgba(14,17,22,.05) 39px),
    var(--cream); }
.err{ max-width:660px; text-align:center; }
.err__logo{ margin-bottom:28px; }
.err__code{ display:block; font-weight:900; font-size:clamp(96px,24vw,210px); line-height:.86; letter-spacing:-.05em; color:var(--blue); }
.err__t{ font-size:clamp(26px,4vw,46px); font-weight:900; text-transform:uppercase; letter-spacing:-.03em; margin:8px 0 14px; }
.err__d{ font-size:17px; font-weight:500; color:var(--ink-2); line-height:1.6; max-width:48ch; margin:0 auto 26px; }
.err__btns{ display:flex; gap:12px; flex-wrap:wrap; justify-content:center; }
.post__tag{ align-self:flex-start; font-family:var(--mono); font-size:11px; font-weight:700; letter-spacing:.04em;
  text-transform:uppercase; background:var(--ink); color:#fff; padding:4px 9px; margin-bottom:12px; }
.bx--blue .post__tag,.bx--red .post__tag{ background:#fff; color:var(--ink); }
.post__meta{ margin-top:16px; padding-top:14px; border-top:2px solid rgba(14,17,22,.12);
  font-family:var(--mono); font-size:12.5px; font-weight:600; color:var(--ink-2); }
.bx--blue .post__meta,.bx--red .post__meta{ border-top-color:rgba(255,255,255,.3); color:rgba(255,255,255,.85); }
