/* ============================================================
   C-PS · opp-diag — боевой сайт, дерзкий тёмный нейро-стиль
   Палитра экранного слоя из assets/screen-tokens.css.
   Hero + воронка — пик эффектов (Canvas). Контент — спокойнее для чтения.
   Моушен: transform/opacity/clip-path. reduced-motion обработан.
   ============================================================ */

*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
:root {
  /* ── Дизайн-система визитки «editorial-noir» — переопределяет screen-tokens.css ── */
  --disp:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;
  --body:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;
  --mono:"JetBrains Mono", ui-monospace, monospace;
  --maxw:1180px;
  --gutter:clamp(1.4rem,5vw,4rem);
  --sec:clamp(4.5rem,4rem+5vw,9rem);
  --line:#262C36;
  /* токены экрана → графит + единственный красный сигнал */
  --scr-void:#0B0D10; --scr-bg:#0B0D10; --scr-surface:#171B22; --scr-bezel:#171B22; --scr-edge:#262C36;
  --scr-text:#EEF1F5; --scr-text-mute:#8E97A4; --scr-text-phos:#EEF1F5;
  --scr-amber:#E5332A; --scr-amber-dim:rgba(229,51,42,.12);
  --scr-green:#FF4A40; --scr-green-dim:rgba(255,74,64,.14);
  --scr-bordo:#E5332A; --scr-bordo-core:#C91D15;
  --scr-glow-amber:0 0 1px rgba(229,51,42,.6),0 0 18px rgba(229,51,42,.5);
  --scr-glow-green:0 0 1px rgba(255,74,64,.6),0 0 14px rgba(255,74,64,.45);
  --scr-glow-soft:0 0 10px rgba(229,51,42,.32);
}
html { scroll-behavior:smooth; }
body {
  font-family:var(--body); color:var(--scr-text);
  line-height:1.62; overflow-x:hidden; -webkit-font-smoothing:antialiased;
  /* нуар-база: чернила с холодным тил-подтоном в тенях */
  background:
    radial-gradient(80% 50% at 78% 0%, rgba(229,51,42,.06), transparent 60%),
    radial-gradient(70% 60% at 10% 100%, rgba(229,51,42,.10), transparent 60%),
    var(--scr-void);
}
/* кино-виньетка поверх всего сайта (кадр) */
body::before {
  content:""; position:fixed; inset:0; z-index:9998; pointer-events:none;
  background:radial-gradient(125% 110% at 50% 40%, transparent 58%, rgba(3,5,12,.55) 100%);
}
body::after {
  content:""; position:fixed; inset:0; z-index:9999; pointer-events:none; opacity:.045;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
.wrap { max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gutter); width:100%; }
a { color:inherit; text-decoration:none; }
img,svg,canvas { display:block; max-width:100%; }

/* ── типографика общая ── */
.kicker { display:inline-flex; align-items:center; gap:.6rem; font-family:var(--mono);
  font-size:.74rem; letter-spacing:.26em; text-transform:uppercase; color:var(--scr-amber); margin-bottom:1.4rem; }
.kicker .led { width:7px; height:7px; border-radius:50%; background:var(--scr-green); box-shadow:var(--scr-glow-green); animation:pulse 1.6s ease-in-out infinite; }
.h2 { font-family:var(--disp); font-weight:700; line-height:1.04; letter-spacing:-.015em;
  font-size:clamp(1.8rem,1.3rem+2.4vw,3.2rem); margin-bottom:1.6rem; max-width:20ch; }
.prose p, .prose { color:var(--scr-text-mute); font-size:clamp(1rem,.96rem+.25vw,1.15rem); max-width:62ch; }
.prose p + p { margin-top:1.1rem; }
.sec-head { max-width:62ch; margin-bottom:clamp(2.4rem,4vw,3.6rem); }
.sec-sub { color:var(--scr-text-mute); font-size:clamp(1rem,.95rem+.3vw,1.2rem); max-width:54ch; }
.section { padding-block:var(--sec); position:relative; }
.margin-note { margin-top:clamp(2rem,3vw,3rem); font-family:var(--mono); font-size:.86rem;
  color:var(--scr-green); max-width:60ch; padding-left:1rem; border-left:2px solid var(--scr-green); text-shadow:var(--scr-glow-soft); }

/* ── кнопки ── */
.btn-primary { display:inline-flex; align-items:center; gap:.7rem; font-family:var(--mono);
  font-weight:500; font-size:.94rem; letter-spacing:.03em; color:var(--scr-void);
  background:var(--scr-amber); border:none; border-radius:10px; padding:1.05rem 1.7rem; cursor:pointer;
  box-shadow:var(--scr-glow-amber); transition:transform .3s var(--scr-ease), box-shadow .3s var(--scr-ease); }
.btn-primary:hover { transform:translateY(-3px); box-shadow:0 0 1px #E5332A,0 0 18px rgba(229,51,42,.85),0 0 46px rgba(229,51,42,.42); }
.btn-primary .a { transition:transform .3s var(--scr-ease); }
.btn-primary:hover .a { transform:translateX(5px); }
.link-ghost { font-family:var(--mono); font-size:.85rem; color:var(--scr-text-mute);
  border-bottom:1px solid var(--scr-edge); padding-bottom:2px; transition:color .25s,border-color .25s; }
.link-ghost:hover { color:var(--scr-text); border-color:var(--scr-amber); }
.accent { color:var(--scr-amber); }

/* ── ШАПКА ── */
.ticker { position:sticky; top:0; z-index:100; background:rgba(11,13,16,.82);
  backdrop-filter:blur(12px); border-bottom:1px solid var(--line); }
.ticker__inner { display:flex; justify-content:space-between; align-items:center; padding-block:.85rem; gap:1rem; }
.ticker__brand { display:flex; align-items:center; gap:.6rem; font-family:var(--disp); font-weight:600; font-size:.95rem; }
.ticker__brand i { font-style:normal; color:var(--scr-text-mute); font-weight:400; }
.ticker__cta { display:flex; align-items:center; gap:1.4rem; font-family:var(--mono); font-size:.82rem; }
.ticker__phone { color:var(--scr-text-mute); transition:color .25s; }
.ticker__phone:hover { color:var(--scr-text); }
.ticker__diag { color:var(--scr-text); }
@media (max-width:720px){ .ticker__phone{ display:none; } .ticker__diag{ font-size:.74rem; } .ticker__brand span{ display:none; } }

/* ── HERO ── */
.hero { position:relative; min-height:100svh; display:flex; align-items:center; overflow:hidden; isolation:isolate; }
.hero::before { content:""; position:absolute; inset:0; z-index:0;
  background:
    radial-gradient(58% 70% at 74% 42%, rgba(229,51,42,.16), transparent 60%),
    radial-gradient(48% 60% at 22% 72%, rgba(255,74,64,.10), transparent 60%),
    radial-gradient(120% 120% at 50% 0%, #171B22 0%, #12151B 55%, #0B0D10 100%); }
.hero__bg { position:absolute; inset:0; z-index:1; }
.hero__bg img { width:100%; height:100%; object-fit:cover; object-position:62% center; will-change:transform; }
#net { position:absolute; inset:0; z-index:2; width:100%; height:100%; mix-blend-mode:screen; opacity:.6; }
.hero::after { content:""; position:absolute; inset:0; z-index:5; pointer-events:none;
  background:radial-gradient(130% 100% at 50% 45%, transparent 52%, rgba(0,0,0,.6) 100%); }
.hero__grid { position:relative; z-index:4; display:grid; grid-template-columns:1.05fr .95fr;
  gap:clamp(1.5rem,4vw,3rem); align-items:center; padding-block:clamp(5rem,8vw,7rem); }
.hero__col { max-width:38rem; }
.hero__h1 { font-family:var(--disp); font-weight:800; line-height:.98; letter-spacing:-.02em;
  font-size:clamp(2.4rem,1.1rem+5.4vw,5.4rem); margin-bottom:1.5rem; }
.hero__h1 .l { display:block; }
.hero__h1 .accent { text-shadow:var(--scr-glow-amber); }
.hero__sub { font-size:clamp(1.05rem,.96rem+.4vw,1.28rem); color:var(--scr-text-mute); max-width:40ch; margin-bottom:2rem; }
.hero__hud { display:flex; gap:1.5rem; flex-wrap:wrap; font-family:var(--mono); font-size:.78rem;
  color:var(--scr-text-mute); margin-bottom:2.4rem; }
.hero__hud b { color:var(--scr-green); font-weight:500; text-shadow:var(--scr-glow-green); }
.hero__actions { display:flex; gap:1.1rem; align-items:center; flex-wrap:wrap; }

/* персонаж */
.hero__figwrap { display:flex; justify-content:center; align-items:center; perspective:1000px; }
.figure { position:relative; width:min(108%,460px); perspective:900px;
  filter:drop-shadow(20px 8px 54px rgba(229,51,42,.24)) drop-shadow(-14px 0 48px rgba(229,51,42,.30)); }
.hero__body { display:block; }
.hero__body img { display:block; width:100%; height:auto; }
/* голова-монитор — отдельный слой, крутится в 3D вокруг основания (шеи) */
.hero__head { position:absolute; left:23%; top:4%; width:55%; z-index:3; transform-origin:50% 90%; will-change:transform; }
.hero__head img { display:block; width:100%; height:auto; }
.fig-tint { position:absolute; inset:0; z-index:2; background:linear-gradient(180deg,transparent 26%,rgba(229,51,42,.14)); mix-blend-mode:screen; pointer-events:none; }
/* живой экран — жёстко вклеен в стекло монитора, боты выстраивают диагностические кадры */
.hero__screen { position:absolute; left:16%; top:14.5%; width:44%; height:41%; border-radius:15% / 17%; overflow:hidden;
  background:radial-gradient(120% 100% at 50% 40%, rgba(60,16,14,.5), rgba(5,3,3,.97) 84%);
  box-shadow:inset 0 0 22px rgba(0,0,0,.92), inset 0 0 7px rgba(229,51,42,.3); }
.hero__screen canvas { position:absolute; inset:0; width:100%; height:100%; }
#fx { position:absolute; inset:0; z-index:3; width:100%; height:100%; pointer-events:none; }
.hero__screen::after { content:""; position:absolute; inset:0; pointer-events:none;
  background:repeating-linear-gradient(0deg,transparent 0 2px,rgba(0,0,0,.34) 3px); }
.hero__pupil { position:absolute; left:50%; top:50%; width:15%; aspect-ratio:1; border-radius:50%;
  background:radial-gradient(circle, #ff9a93 0%, var(--scr-amber) 44%, rgba(229,51,42,0) 74%);
  box-shadow:0 0 9px 2px rgba(229,51,42,.7); transform:translate(-50%,-50%); transition:transform .08s linear; }
.scrollhint { position:absolute; bottom:1.5rem; left:50%; transform:translateX(-50%); z-index:5; font-family:var(--mono);
  font-size:.62rem; letter-spacing:.3em; text-transform:uppercase; color:var(--scr-text-mute);
  display:flex; flex-direction:column; align-items:center; gap:.5rem; }
.scrollhint .line { width:1px; height:32px; background:linear-gradient(var(--scr-amber),transparent); animation:drop 1.8s ease-in-out infinite; transform-origin:top; }
@media (max-width:880px){ .hero__grid{ grid-template-columns:1fr; } .hero__figwrap{ position:absolute; inset:0; z-index:2; opacity:.32; } .hero__col{ position:relative; z-index:4; } }

/* ── ПРОБЛЕМА ── */
.problema { background:linear-gradient(180deg,#0B0D10,#0B0D10); }
.criterion { margin-top:clamp(2rem,3vw,3rem); font-family:var(--disp); font-weight:600;
  font-size:clamp(1.2rem,1rem+1vw,1.7rem); color:var(--scr-text); max-width:26ch; line-height:1.25;
  padding-left:1.2rem; border-left:3px solid var(--scr-amber); }

/* ── split (решение / эксперт) ── */
.split { display:grid; grid-template-columns:1.4fr .6fr; gap:clamp(2rem,5vw,4.5rem); align-items:start; }
.pullquote { font-family:var(--disp); font-weight:600; font-size:clamp(1.3rem,1rem+1.4vw,2rem);
  line-height:1.2; color:var(--scr-amber); text-shadow:var(--scr-glow-soft); padding-top:2.6rem;
  border-top:2px solid var(--scr-amber); }
@media (max-width:820px){ .split{ grid-template-columns:1fr; } }

/* ── ЭТАПЫ ── */
.route { display:grid; gap:0; border-top:1px solid var(--line); }
.step { display:grid; grid-template-columns:auto 1fr; gap:clamp(1.2rem,3vw,2.6rem);
  padding-block:clamp(1.5rem,2.5vw,2.2rem); border-bottom:1px solid var(--line); transition:background .3s var(--scr-ease); }
.step:hover { background:rgba(229,51,42,.04); }
.step__num { font-family:var(--mono); font-size:1rem; color:var(--scr-amber); text-shadow:var(--scr-glow-soft); padding-top:.2rem; }
.step__title { font-family:var(--disp); font-weight:600; font-size:clamp(1.15rem,1rem+.7vw,1.6rem); color:var(--scr-text); margin-bottom:.5rem; }
.step__text { color:var(--scr-text-mute); max-width:64ch; font-size:1rem; }

/* ── МЕТОДОЛОГИЯ (bento) ── */
.metod { background:linear-gradient(180deg,#0B0D10,#0B0D10); }
.bento { display:grid; grid-template-columns:repeat(4,1fr); gap:1rem; }
.tile { grid-column:span 1; display:flex; flex-direction:column; gap:.6rem; padding:1.6rem;
  background:var(--scr-surface); border:1px solid var(--scr-edge); border-radius:14px;
  transition:transform .3s var(--scr-ease),box-shadow .3s var(--scr-ease),border-color .3s; }
.tile:hover { transform:translateY(-4px); border-color:var(--scr-amber); box-shadow:0 14px 30px rgba(0,0,0,.4),inset 0 0 30px rgba(229,51,42,.06); }
.tile--flagship { grid-column:span 2; grid-row:span 2; background:linear-gradient(150deg,#1a1f29,#12151B);
  box-shadow:inset 0 0 50px rgba(229,51,42,.08); }
.tile__tag { font-family:var(--mono); font-size:.68rem; letter-spacing:.16em; text-transform:uppercase; color:var(--scr-text-mute); }
.tile__abbr { font-family:var(--disp); font-weight:700; font-size:clamp(1.4rem,1rem+1.2vw,2rem); color:var(--scr-amber); text-shadow:var(--scr-glow-soft); }
.tile--flagship .tile__abbr { font-size:clamp(2rem,1.2rem+2.4vw,3.4rem); }
.tile__text { color:var(--scr-text-mute); font-size:.92rem; margin-top:auto; }
@media (max-width:760px){ .bento{ grid-template-columns:repeat(2,1fr); } .tile--flagship{ grid-column:span 2; grid-row:span 1; } }

/* ── РЕЗУЛЬТАТЫ ── */
.figures { display:flex; flex-wrap:wrap; gap:clamp(2rem,5vw,4.5rem); margin-block:1.6rem 1.4rem; }
.figure-stat__num { font-family:var(--disp); font-weight:800; font-size:clamp(2.6rem,1.6rem+3vw,4.2rem); line-height:1; color:var(--scr-text); }
.figure-stat__num .u { color:var(--scr-amber); }
.figure-stat__label { font-family:var(--mono); font-size:.74rem; letter-spacing:.06em; color:var(--scr-text-mute); margin-top:.5rem; max-width:18ch; }
.niches { color:var(--scr-text-mute); max-width:62ch; margin-bottom:2.4rem; }
.niches b { color:var(--scr-text); }
.cases { display:grid; grid-template-columns:1fr 1fr; gap:1.4rem; margin-bottom:2.2rem; }
.case { display:grid; grid-template-columns:auto 1fr; gap:1.4rem; align-items:start; padding:1.4rem;
  background:var(--scr-surface); border:1px solid var(--scr-edge); border-radius:14px; transition:transform .3s var(--scr-ease),border-color .3s,box-shadow .3s; }
.case:hover { transform:translateY(-4px); border-color:var(--scr-green); box-shadow:0 16px 34px rgba(0,0,0,.45); }
.case__doc { width:96px; border-radius:8px; overflow:hidden; border:1px solid var(--scr-edge); box-shadow:0 8px 18px rgba(0,0,0,.4); }
.case__doc img { width:100%; height:auto; filter:saturate(.6) brightness(.85); }
.case__client { font-family:var(--disp); font-weight:700; font-size:1.2rem; color:var(--scr-text); }
.case__sector { font-family:var(--mono); font-size:.72rem; color:var(--scr-amber); margin-block:.3rem .7rem; }
.case__result { color:var(--scr-text-mute); font-size:.9rem; }
.clients-note { color:var(--scr-text-mute); font-size:.92rem; max-width:62ch; }
@media (max-width:760px){ .cases{ grid-template-columns:1fr; } }

/* ── ЭКСПЕРТ ── */
.split--portrait { grid-template-columns:.7fr 1.3fr; align-items:center; }
.portrait { border-radius:16px; overflow:hidden; border:1px solid var(--scr-edge); box-shadow:0 26px 50px rgba(0,0,0,.5); position:relative; }
.portrait::after { content:""; position:absolute; inset:0; background:linear-gradient(180deg,transparent 50%,rgba(11,13,16,.5)),radial-gradient(120% 80% at 70% 20%,rgba(229,51,42,.14),transparent 60%); }
.portrait img { width:100%; height:auto; filter:grayscale(.35) contrast(1.05) brightness(.92); }
.credo { margin-top:1.8rem; font-family:var(--disp); font-weight:600; font-size:clamp(1.15rem,1rem+.9vw,1.65rem);
  line-height:1.3; color:var(--scr-amber); text-shadow:var(--scr-glow-soft); padding-left:1.2rem; border-left:3px solid var(--scr-amber); max-width:30ch; }
@media (max-width:820px){ .split--portrait{ grid-template-columns:1fr; } .portrait{ max-width:340px; } }

/* ── ВОРОНКА (пик дерзости) ── */
.voronka { background:#090A0D; overflow:hidden; isolation:isolate; }
#net2 { position:absolute; inset:0; z-index:0; width:100%; height:100%; opacity:.6; }
.voronka .wrap { position:relative; z-index:2; }
.entry-steps { display:grid; gap:1.2rem; margin-bottom:1.8rem; }
.entry-card { display:flex; justify-content:space-between; align-items:center; gap:1.5rem; flex-wrap:wrap;
  padding:clamp(1.6rem,3vw,2.4rem); border-radius:16px; background:linear-gradient(150deg,#1a1f29,#12151B);
  border:1px solid var(--scr-amber); box-shadow:inset 0 0 60px rgba(229,51,42,.1),0 20px 40px rgba(0,0,0,.45); }
.entry-card__body { display:flex; flex-direction:column; align-items:flex-start; gap:0; }
.entry-card__step { font-family:var(--mono); font-size:.72rem; letter-spacing:.12em; text-transform:uppercase; color:var(--scr-text-mute); margin-bottom:.7rem; }
.entry-card__name { font-family:var(--disp); font-weight:700; font-size:clamp(1.3rem,1rem+1.2vw,2rem); color:var(--scr-text); }
.entry-card__desc { color:var(--scr-text-mute); font-size:.95rem; max-width:48ch; margin-top:.5rem; }
.entry-card__body .btn-primary, .entry-card__body .link-ghost { margin-top:1.3rem; }
.entry-card__price { font-family:var(--disp); font-weight:800; font-size:clamp(2rem,1.4rem+2vw,3.2rem); color:var(--scr-amber); text-shadow:var(--scr-glow-amber); white-space:nowrap; align-self:center; }
/* Шаг 1 — бесплатный вход, главный акцент (зелень) */
.entry-card--free { border-color:var(--scr-green); box-shadow:inset 0 0 60px rgba(255,74,64,.12),0 20px 40px rgba(0,0,0,.45); }
.entry-card__price--free { color:var(--scr-green); text-shadow:var(--scr-glow-green); font-size:clamp(1.5rem,1rem+1.5vw,2.3rem); }
/* Шаг 2 — апселл, приглушён */
.entry-card--muted { border-color:var(--line); box-shadow:0 20px 40px rgba(0,0,0,.35); }
.voronka__body { margin-bottom:0; }

/* ── ЗАЯВКА (форма полного разбора) ── */
.lead-form { max-width:54rem; }
.lead-form__row { display:grid; grid-template-columns:1fr 1fr; gap:1.2rem; margin-bottom:1.2rem; }
.field { display:flex; flex-direction:column; gap:.5rem; }
.field__label { font-family:var(--mono); font-size:.74rem; letter-spacing:.1em; text-transform:uppercase; color:var(--scr-text-mute); }
.field__opt { text-transform:none; letter-spacing:0; opacity:.7; }
.field__input { font-family:var(--body); font-size:1rem; color:var(--scr-text); background:rgba(11,13,16,.6);
  border:1px solid var(--scr-edge); border-radius:10px; padding:.85rem 1rem; width:100%; transition:border-color .25s, box-shadow .25s; }
.field__input::placeholder { color:rgba(138,147,172,.6); }
.field__input:focus { outline:none; border-color:var(--scr-amber); box-shadow:0 0 0 3px rgba(229,51,42,.15); }
textarea.field__input { resize:vertical; min-height:3.2rem; }
select.field__input { appearance:none; cursor:pointer; }
.hp { position:absolute; left:-9999px; width:1px; height:1px; overflow:hidden; }
.consent { display:flex; gap:.7rem; align-items:flex-start; margin:1.4rem 0; font-size:.9rem; color:var(--scr-text-mute); cursor:pointer; }
.consent input { margin-top:.25rem; accent-color:var(--scr-amber); flex-shrink:0; }
.consent a { color:var(--scr-amber); text-decoration:underline; }
.lead-form__submit { border:0; cursor:pointer; }
.lead-form__submit[disabled] { opacity:.5; cursor:not-allowed; }
.lead-form__status { margin-top:1.2rem; font-family:var(--mono); font-size:.86rem; min-height:1.2em; }
.lead-form__status.ok { color:var(--scr-green); text-shadow:var(--scr-glow-soft); }
.lead-form__status.err { color:var(--scr-bordo); }
@media (max-width:640px){ .lead-form__row{ grid-template-columns:1fr; gap:1rem; } }

/* ── FAQ ── */
.qa { display:grid; gap:0; border-top:1px solid var(--line); max-width:62rem; }
.qa__item { border-bottom:1px solid var(--line); }
.qa__q { font-family:var(--disp); font-weight:600; font-size:clamp(1.05rem,1rem+.5vw,1.4rem); color:var(--scr-text);
  padding-block:1.4rem; cursor:pointer; list-style:none; display:flex; justify-content:space-between; gap:1rem; transition:color .25s; }
.qa__q::-webkit-details-marker { display:none; }
.qa__q::after { content:"+"; font-family:var(--mono); color:var(--scr-amber); transition:transform .3s var(--scr-ease); }
.qa__item[open] .qa__q::after { transform:rotate(45deg); }
.qa__q:hover { color:var(--scr-amber); }
.qa__a { color:var(--scr-text-mute); padding-bottom:1.5rem; max-width:64ch; font-size:1rem; }

/* ── FINAL ── */
.final { background:radial-gradient(120% 90% at 50% 0%,#171B22,#0B0D10 70%); text-align:center; }
.final__inner { max-width:46rem; margin-inline:auto; display:flex; flex-direction:column; align-items:center; }
.final .kicker { justify-content:center; }
.final__h2 { max-width:26ch; }
.final .prose { text-align:center; }
.final__sub { font-family:var(--mono); font-size:.84rem; color:var(--scr-text-mute); margin-block:1.4rem 2.2rem; }

/* ── FOOTER ── */
.footer { background:#0B0D10; border-top:1px solid var(--line); padding-block:clamp(3rem,4vw,4.5rem) 2rem; font-size:.9rem; color:var(--scr-text-mute); }
.footer__grid { display:grid; grid-template-columns:1.6fr 1fr 1fr; gap:2.5rem; margin-bottom:2.5rem; }
.footer__brand { display:flex; align-items:center; gap:.7rem; font-family:var(--disp); font-weight:600; color:var(--scr-text); margin-bottom:1rem; }
.footer__brand i { font-style:normal; color:var(--scr-text-mute); font-weight:400; }
.footer h4 { font-family:var(--mono); font-size:.74rem; letter-spacing:.14em; text-transform:uppercase; color:var(--scr-text); margin-bottom:1rem; }
.footer__grid a { display:block; color:var(--scr-text-mute); padding-block:.3rem; transition:color .25s; }
.footer__grid a:hover { color:var(--scr-amber); }
.footer__legal { display:flex; justify-content:space-between; gap:1rem; flex-wrap:wrap; padding-top:1.5rem; border-top:1px solid var(--line); font-family:var(--mono); font-size:.74rem; }
@media (max-width:760px){ .footer__grid{ grid-template-columns:1fr 1fr; } }

/* ── reveal по скроллу ── */
.reveal { opacity:0; transform:translateY(28px); transition:opacity .8s var(--scr-ease), transform .8s var(--scr-ease); }
.reveal.in { opacity:1; transform:none; }

/* scramble-decode: перебираемые символы */
.dud { color:var(--scr-green); opacity:.7; text-shadow:var(--scr-glow-green); }
.hero__h1 .accent .dud { color:var(--scr-amber); text-shadow:var(--scr-glow-amber); }

@keyframes pulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.4;transform:scale(.7)} }
@keyframes drop  { 0%,100%{transform:scaleY(.3);opacity:.4} 50%{transform:scaleY(1);opacity:1} }

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after { animation:none !important; }
  .reveal { opacity:1 !important; transform:none !important; }
  .head { transform:translateX(-50%) !important; }
  html { scroll-behavior:auto; }
}

/* ── Ф1: перекрас тёплых растров hero под графит+красный (визитка) ── */
.hero__bg img { filter:grayscale(1) brightness(.40) contrast(1.14); }
.figure img, .hero__body img, .hero__head img { filter:grayscale(1) contrast(1.07) brightness(.66); }
.hero__bg::after { content:""; position:absolute; inset:0; background:linear-gradient(180deg,transparent 30%,rgba(229,51,42,.06)); mix-blend-mode:screen; pointer-events:none; }
