/* ============================================================
   ТРАНСФОРМАТОРЫ — стиль «инженерный чертёж» (blueprint)
   ============================================================ */

:root{
  --bg:        #0a253c;   /* основной фон листа */
  --bg-2:      #0c2c47;   /* секции-чередование */
  --panel:     rgba(13, 52, 84, .55);
  --ink:       #dcefff;   /* основной текст */
  --ink-dim:   #8fb4d0;   /* приглушённый текст */
  --line:      #6fa8d6;   /* чертёжная линия */
  --line-soft: rgba(120,175,220,.22);
  --accent:    #46d4ff;   /* голубой акцент / поток */
  --accent-2:  #ffcf6b;   /* янтарный / ток, медь */
  --good:      #5fe3a1;
  --bad:       #ff7d7d;

  --grid-fine:  rgba(120,175,220,.06);
  --grid-bold:  rgba(120,175,220,.10);

  --font-head: "Space Grotesk", system-ui, sans-serif;
  --font-body: "Inter", system-ui, -apple-system, sans-serif;
  --font-mono: "JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;

  --wrap: 1120px;
  --radius: 4px;
}

*{ box-sizing:border-box; margin:0; padding:0; }

html{ scroll-behavior:smooth; scroll-padding-top:84px; }

body{
  font-family:var(--font-body);
  color:var(--ink);
  background-color:var(--bg);
  background-image:
    linear-gradient(var(--grid-bold) 1px, transparent 1px),
    linear-gradient(90deg, var(--grid-bold) 1px, transparent 1px),
    linear-gradient(var(--grid-fine) 1px, transparent 1px),
    linear-gradient(90deg, var(--grid-fine) 1px, transparent 1px);
  background-size:120px 120px, 120px 120px, 24px 24px, 24px 24px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

.wrap{ width:100%; max-width:var(--wrap); margin-inline:auto; padding-inline:24px; }

a{ color:var(--accent); text-decoration:none; }
b{ color:#fff; font-weight:600; }

/* ---------- метки по углам листа ---------- */
.crop-marks{ position:fixed; inset:14px; pointer-events:none; z-index:60; }
.crop{ position:absolute; width:18px; height:18px; border:0 solid var(--line); opacity:.6; }
.crop.tl{ top:0; left:0; border-top-width:1.5px; border-left-width:1.5px; }
.crop.tr{ top:0; right:0; border-top-width:1.5px; border-right-width:1.5px; }
.crop.bl{ bottom:0; left:0; border-bottom-width:1.5px; border-left-width:1.5px; }
.crop.br{ bottom:0; right:0; border-bottom-width:1.5px; border-right-width:1.5px; }

/* ============================================================
   ШАПКА
   ============================================================ */
.site-header{
  position:sticky; top:0; z-index:50;
  background:rgba(10,37,60,.82);
  backdrop-filter:blur(10px);
}
.header-inner{ display:flex; align-items:center; justify-content:space-between; height:64px; }
.header-rule{ height:1px; background:var(--line-soft); }

.brand{ display:flex; align-items:center; gap:10px; color:var(--ink); }
.brand__ico{ width:30px; height:30px; color:var(--accent); }
.brand__txt{ font-family:var(--font-mono); font-weight:700; letter-spacing:.06em; font-size:.82rem; }
.brand__dot{ color:var(--accent); }

.nav{ display:flex; gap:4px; }
.nav a{
  font-family:var(--font-mono); font-size:.78rem; color:var(--ink-dim);
  padding:8px 12px; border-radius:var(--radius); letter-spacing:.02em;
  transition:color .2s, background .2s;
}
.nav a:hover{ color:var(--ink); background:rgba(120,175,220,.08); }
.nav a.active{ color:var(--accent); }

.nav-toggle{ display:none; flex-direction:column; gap:5px; background:none; border:1px solid var(--line-soft);
  border-radius:var(--radius); padding:9px 8px; cursor:pointer; }
.nav-toggle span{ width:22px; height:2px; background:var(--ink); transition:.25s; }
.nav-toggle[aria-expanded="true"] span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] span:nth-child(2){ opacity:0; }
.nav-toggle[aria-expanded="true"] span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

/* ============================================================
   HERO
   ============================================================ */
.hero{ position:relative; padding:72px 0 56px; }
.hero-grid{ display:grid; grid-template-columns:1.15fr .85fr; gap:48px; align-items:center; }

.tag{ font-family:var(--font-mono); font-size:.74rem; letter-spacing:.22em; color:var(--accent);
  border:1px solid var(--line-soft); display:inline-block; padding:5px 12px; border-radius:2px; margin-bottom:22px; }

.hero h1{
  font-family:var(--font-head); font-weight:700; line-height:.98;
  font-size:clamp(2.8rem, 7vw, 5.4rem); letter-spacing:-.01em; color:#fff;
  text-transform:uppercase; hyphens:auto;
}
.lead{ margin-top:22px; font-size:1.12rem; color:var(--ink-dim); max-width:46ch; }
.lead b{ color:var(--ink); }

.hero-actions{ display:flex; gap:14px; margin-top:30px; flex-wrap:wrap; }

.btn{ font-family:var(--font-mono); font-size:.85rem; letter-spacing:.03em; padding:13px 22px;
  border-radius:var(--radius); border:1px solid transparent; cursor:pointer; transition:.2s; display:inline-block; }
.btn--sm{ padding:9px 14px; font-size:.78rem; }
.btn--solid{ background:var(--accent); color:#06243a; font-weight:600; }
.btn--solid:hover{ background:#7fe2ff; box-shadow:0 0 24px rgba(70,212,255,.35); }
.btn--ghost{ border-color:var(--line); color:var(--ink); }
.btn--ghost:hover{ background:rgba(120,175,220,.1); }

.hero-specs{ display:flex; gap:30px; margin-top:40px; flex-wrap:wrap; }
.hero-specs dt{ font-family:var(--font-mono); font-size:.7rem; letter-spacing:.08em; color:var(--ink-dim); text-transform:uppercase; }
.hero-specs dd{ font-family:var(--font-head); font-size:1.5rem; color:var(--accent); font-weight:600; margin-top:3px; }

/* чертёж в hero */
.hero-fig{ position:relative; }
.hero-draw{ width:100%; height:auto; color:var(--line); filter:drop-shadow(0 0 20px rgba(70,212,255,.06)); }
.hd-dim{ font-family:var(--font-mono); font-size:9px; fill:var(--ink-dim); text-anchor:middle; letter-spacing:.06em; }
.hd-lbl{ font-family:var(--font-mono); font-size:13px; fill:var(--accent); }
.hd-lbl--c{ fill:var(--ink-dim); font-size:11px; }
.hd-coil{ color:var(--accent-2); }
.hd-coil--2{ color:var(--accent); }
.hero-fig figcaption{ font-family:var(--font-mono); font-size:.72rem; color:var(--ink-dim); text-align:center; margin-top:8px; }

.scroll-hint{ position:absolute; bottom:18px; left:50%; transform:translateX(-50%);
  font-size:1.3rem; color:var(--ink-dim); animation:bob 1.8s ease-in-out infinite; }
@keyframes bob{ 0%,100%{ transform:translate(-50%,0); } 50%{ transform:translate(-50%,8px); } }

/* ============================================================
   СЕКЦИИ — общее
   ============================================================ */
.section{ padding:84px 0; position:relative; }
.section--alt{ background:var(--bg-2); border-block:1px solid var(--line-soft); }

.sec-head{ margin-bottom:46px; position:relative; }
.sec-num{ font-family:var(--font-mono); font-size:.8rem; color:var(--accent); letter-spacing:.1em; }
.sec-head h2{ font-family:var(--font-head); font-weight:600; font-size:clamp(1.8rem,4vw,2.7rem);
  color:#fff; line-height:1.05; margin-top:6px; }
.sec-head h2::before{ content:""; display:inline-block; width:34px; height:1px; background:var(--line);
  vertical-align:middle; margin-right:14px; }
.sec-sub{ font-family:var(--font-mono); color:var(--ink-dim); font-size:.86rem; margin-top:12px; margin-left:48px; }

.cols-2{ display:grid; grid-template-columns:1.4fr .85fr; gap:36px; align-items:start; }

.prose p{ margin-bottom:16px; font-size:1.05rem; color:var(--ink-dim); }
.prose p:last-child{ margin-bottom:0; }
.prose b{ color:var(--ink); }

/* боковая заметка */
.note{ border:1px solid var(--line-soft); border-left:2px solid var(--accent);
  background:var(--panel); border-radius:var(--radius); padding:22px 24px; }
.note__hd{ font-family:var(--font-mono); font-size:.76rem; color:var(--accent); letter-spacing:.05em; margin-bottom:14px; }
.note p{ color:var(--ink-dim); }
.ticks{ list-style:none; display:grid; gap:11px; }
.ticks li{ position:relative; padding-left:24px; color:var(--ink); font-size:.96rem; }
.ticks li::before{ content:"▸"; position:absolute; left:0; color:var(--accent); }

/* ============================================================
   КАК РАБОТАЕТ
   ============================================================ */
.how-grid{ display:grid; grid-template-columns:1.1fr .9fr; gap:40px; align-items:start; }

.scheme{ border:1px solid var(--line-soft); border-radius:var(--radius);
  background:rgba(8,30,49,.5); padding:18px; }
.scheme__svg{ width:100%; height:auto; display:block; }
.scheme figcaption{ font-family:var(--font-mono); font-size:.74rem; color:var(--ink-dim); text-align:center; margin-top:6px; }
.scheme__controls{ display:flex; align-items:center; gap:14px; margin-top:14px; flex-wrap:wrap;
  padding-top:14px; border-top:1px dashed var(--line-soft); }
.scheme__hint{ font-family:var(--font-mono); font-size:.72rem; color:var(--ink-dim); }

/* схема: статичные элементы */
.core-outer{ fill:rgba(120,175,220,.05); stroke:var(--line); stroke-width:1.5; }
.core-window{ fill:var(--bg); stroke:var(--line); stroke-width:1; }
.core-lam{ stroke:var(--line); stroke-width:.5; opacity:.4; }
.winding ellipse{ fill:none; stroke-width:2.4; }
.winding--prim ellipse{ stroke:var(--accent-2); }
.winding--sec ellipse{ stroke:var(--accent); }
.src, .load{ fill:none; stroke:var(--line); stroke-width:1.6; }
.src-sine{ stroke:var(--accent-2); stroke-width:2; }
.load-x{ stroke:var(--accent); stroke-width:2; }

.lbl{ font-family:var(--font-mono); font-size:13px; fill:var(--ink); }
.lbl--sm{ font-size:10px; }
.lbl--c{ fill:var(--ink-dim); }
.lbl--dim{ fill:var(--ink-dim); font-size:11px; }
.lbl--flux{ fill:var(--accent); font-size:12px; }
.lbl--prim{ fill:var(--accent-2); }
.lbl--sec{ fill:var(--accent); }
.leader{ stroke:var(--line-soft); stroke-width:1; stroke-dasharray:2 3; }
.leader--prim{ stroke:var(--accent-2); opacity:.5; }
.leader--sec{ stroke:var(--accent); opacity:.5; }

/* анимация: магнитный поток */
.flux-path{ stroke:var(--accent); stroke-width:2.2; stroke-dasharray:10 8;
  filter:drop-shadow(0 0 4px rgba(70,212,255,.5)); animation:fluxFlow 1.4s linear infinite; }
.flux-arrow-head{ fill:var(--accent); }
@keyframes fluxFlow{ to{ stroke-dashoffset:-36; } }

/* анимация: ток в проводах */
.wire{ stroke-width:2.4; stroke-dasharray:6 9; }
.wire--prim{ stroke:var(--accent-2); animation:wireFlow 1s linear infinite; }
.wire--sec{ stroke:var(--accent); animation:wireFlow 1s linear infinite; }
@keyframes wireFlow{ to{ stroke-dashoffset:-30; } }

/* пульсация обмоток */
.winding--prim{ animation:pulseWarm 1.4s ease-in-out infinite; }
.winding--sec{ animation:pulseCool 1.4s ease-in-out infinite .2s; }
@keyframes pulseWarm{ 0%,100%{ opacity:.75; } 50%{ opacity:1; } }
@keyframes pulseCool{ 0%,100%{ opacity:.7; } 50%{ opacity:1; } }

/* пауза */
.scheme.is-paused .flux-path,
.scheme.is-paused .wire,
.scheme.is-paused .winding{ animation-play-state:paused; }

/* шаги */
.steps{ list-style:none; display:grid; gap:8px; counter-reset:s; }
.steps li{ display:flex; gap:16px; padding:16px; border:1px solid transparent; border-radius:var(--radius);
  transition:.2s; }
.steps li:hover{ border-color:var(--line-soft); background:var(--panel); }
.steps__n{ flex:none; width:34px; height:34px; display:grid; place-items:center; border-radius:50%;
  border:1px solid var(--accent); color:var(--accent); font-family:var(--font-mono); font-weight:700; font-size:.9rem; }
.steps__why .steps__n{ border-color:var(--accent-2); color:var(--accent-2); }
.steps h3{ font-family:var(--font-head); font-size:1.05rem; color:#fff; margin-bottom:4px; }
.steps p{ color:var(--ink-dim); font-size:.95rem; }

/* ============================================================
   УСТРОЙСТВО
   ============================================================ */
.parts-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--line-soft);
  border:1px solid var(--line-soft); border-radius:var(--radius); overflow:hidden; }
.part{ background:var(--bg); padding:26px 22px; position:relative; transition:.2s; }
.section--alt .part{ background:var(--bg-2); }
.part:hover{ background:rgba(70,212,255,.06); }
.part__id{ font-family:var(--font-mono); font-size:.74rem; color:var(--accent); }
.part h3{ font-family:var(--font-head); font-size:1.06rem; color:#fff; margin:12px 0 8px; }
.part p{ font-size:.9rem; color:var(--ink-dim); }

/* ============================================================
   ВИДЫ
   ============================================================ */
.type-block{ margin-bottom:36px; }
.type-block:last-child{ margin-bottom:0; }
.type-block__h{ font-family:var(--font-mono); font-size:.82rem; color:var(--accent); letter-spacing:.04em;
  margin-bottom:16px; padding-bottom:8px; border-bottom:1px dashed var(--line-soft); }
.cards{ display:grid; grid-template-columns:repeat(auto-fill,minmax(220px,1fr)); gap:14px; }
.card{ border:1px solid var(--line-soft); border-radius:var(--radius); padding:20px; background:var(--panel);
  position:relative; transition:.2s; overflow:hidden; }
.card::before{ content:""; position:absolute; top:10px; right:10px; width:8px; height:8px;
  border-top:1px solid var(--line); border-right:1px solid var(--line); opacity:.5; }
.card:hover{ transform:translateY(-3px); border-color:var(--accent); box-shadow:0 8px 30px rgba(0,0,0,.25); }
.card h4{ font-family:var(--font-head); font-size:1.08rem; color:#fff; margin-bottom:8px; }
.card p{ font-size:.9rem; color:var(--ink-dim); }

/* ============================================================
   ПРИМЕНЕНИЕ
   ============================================================ */
.use-hero{ margin-bottom:30px; }
.use-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.use{ border:1px solid var(--line-soft); border-radius:var(--radius); padding:24px; background:var(--panel);
  transition:.2s; }
.use:hover{ border-color:var(--accent); transform:translateY(-3px); }
.use__ico{ font-size:1.8rem; display:block; margin-bottom:12px; }
.use h3{ font-family:var(--font-head); font-size:1.1rem; color:#fff; margin-bottom:6px; }
.use p{ font-size:.92rem; color:var(--ink-dim); }

/* ============================================================
   ФОРМУЛЫ + КАЛЬКУЛЯТОР
   ============================================================ */
.formula-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:14px; margin-bottom:34px; }
.formula{ border:1px solid var(--line-soft); border-radius:var(--radius); padding:24px 18px; text-align:center;
  background:var(--panel); }
.formula__eq{ font-family:var(--font-mono); font-size:1.05rem; color:var(--accent); font-weight:500; }
.formula__eq sub{ font-size:.7em; }
.formula figcaption{ margin-top:12px; font-size:.82rem; color:var(--ink-dim); }

.calc{ border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; background:rgba(8,30,49,.5); }
.calc__head{ padding:22px 26px; border-bottom:1px solid var(--line-soft); }
.calc__head h3{ font-family:var(--font-head); font-size:1.25rem; color:#fff; }
.calc__head p{ color:var(--ink-dim); font-size:.9rem; margin-top:4px; }
.calc__body{ display:grid; grid-template-columns:1fr 1fr; }

.calc__inputs{ padding:26px; display:grid; gap:18px; align-content:start; border-right:1px solid var(--line-soft); }
.field{ display:grid; gap:7px; }
.field span{ font-family:var(--font-mono); font-size:.78rem; color:var(--ink-dim); }
.field i{ color:var(--ink-dim); opacity:.7; font-style:normal; }
.field input{ font-family:var(--font-mono); font-size:1rem; color:var(--ink); background:var(--bg);
  border:1px solid var(--line-soft); border-radius:var(--radius); padding:11px 13px; transition:.2s; width:100%; }
.field input:focus{ outline:none; border-color:var(--accent); box-shadow:0 0 0 3px rgba(70,212,255,.15); }

.calc__out{ padding:26px; display:grid; gap:18px; align-content:start; }
.calc__verdict{ font-family:var(--font-mono); font-size:.92rem; padding:10px 14px; border-radius:var(--radius);
  border:1px dashed var(--line); color:var(--accent); text-align:center; }
.calc__verdict.up{ color:var(--accent-2); border-color:var(--accent-2); }
.calc__verdict.down{ color:var(--accent); border-color:var(--accent); }
.calc__verdict.iso{ color:var(--good); border-color:var(--good); }
.calc__rows{ display:grid; gap:1px; background:var(--line-soft); border:1px solid var(--line-soft); border-radius:var(--radius); overflow:hidden; }
.calc__rows>div{ display:flex; justify-content:space-between; align-items:center; gap:12px;
  background:var(--bg); padding:13px 16px; }
.calc__rows dt{ font-size:.86rem; color:var(--ink-dim); }
.calc__rows dd{ font-family:var(--font-mono); font-size:1.1rem; color:#fff; font-weight:500; }

.calc__bars{ display:grid; gap:10px; }
.bar{ display:flex; align-items:center; gap:10px; }
.bar__lbl{ font-family:var(--font-mono); font-size:.74rem; color:var(--ink-dim); width:24px; }
.bar__track{ flex:1; height:10px; background:var(--bg); border:1px solid var(--line-soft); border-radius:99px; overflow:hidden; }
.bar__fill{ height:100%; width:0; background:var(--accent-2); transition:width .4s ease; }
.bar__fill--2{ background:var(--accent); }

/* ============================================================
   КВИЗ
   ============================================================ */
.quiz{ border:1px solid var(--line-soft); border-radius:var(--radius); background:rgba(8,30,49,.4); padding:8px; }
.q{ padding:22px; border-bottom:1px dashed var(--line-soft); }
.q:last-of-type{ border-bottom:none; }
.q__head{ display:flex; gap:12px; align-items:baseline; margin-bottom:16px; }
.q__n{ font-family:var(--font-mono); font-size:.78rem; color:var(--accent); flex:none; }
.q__text{ font-family:var(--font-head); font-size:1.1rem; color:#fff; }
.q__opts{ display:grid; gap:9px; }
.opt{ display:flex; gap:12px; align-items:center; text-align:left; width:100%;
  font-family:var(--font-body); font-size:.96rem; color:var(--ink);
  background:var(--bg); border:1px solid var(--line-soft); border-radius:var(--radius);
  padding:13px 16px; cursor:pointer; transition:.18s; }
.opt:hover:not(:disabled){ border-color:var(--accent); background:rgba(70,212,255,.06); }
.opt__mark{ font-family:var(--font-mono); font-size:.8rem; color:var(--ink-dim); flex:none;
  width:24px; height:24px; display:grid; place-items:center; border:1px solid var(--line-soft); border-radius:50%; }
.opt.correct{ border-color:var(--good); background:rgba(95,227,161,.1); color:#fff; }
.opt.correct .opt__mark{ border-color:var(--good); color:var(--good); }
.opt.wrong{ border-color:var(--bad); background:rgba(255,125,125,.1); }
.opt.wrong .opt__mark{ border-color:var(--bad); color:var(--bad); }
.opt:disabled{ cursor:default; }
.q__fb{ margin-top:12px; font-size:.88rem; font-family:var(--font-mono); color:var(--ink-dim);
  padding-left:36px; min-height:0; }

.quiz__bar{ display:flex; align-items:center; justify-content:space-between; gap:16px; flex-wrap:wrap;
  padding:22px; border-top:1px solid var(--line-soft); margin-top:4px; }
.quiz__score{ font-family:var(--font-mono); color:var(--ink); font-size:.95rem; }
.quiz__score b{ color:var(--accent); font-size:1.3rem; }
.quiz__bar-wrap{ flex:1; min-width:160px; height:8px; background:var(--bg); border:1px solid var(--line-soft);
  border-radius:99px; overflow:hidden; }
.quiz__bar-fill{ height:100%; width:0; background:var(--accent); transition:width .5s ease; }

/* ============================================================
   ИСТОРИЯ / ФАКТЫ
   ============================================================ */
.timeline{ list-style:none; display:grid; gap:0; }
.timeline li{ display:grid; grid-template-columns:74px 1fr; gap:18px; padding:18px 0;
  border-bottom:1px dashed var(--line-soft); }
.timeline li:last-child{ border-bottom:none; }
.timeline__yr{ font-family:var(--font-mono); font-weight:700; color:var(--accent); font-size:1.1rem; }
.timeline p{ color:var(--ink-dim); font-size:.96rem; }

.facts{ display:grid; grid-template-columns:1fr 1fr; gap:14px; align-content:start; }
.fact{ border:1px solid var(--line-soft); border-radius:var(--radius); padding:22px; background:var(--panel); text-align:center; }
.fact__big{ font-family:var(--font-head); font-weight:700; font-size:1.7rem; color:var(--accent); display:block; }
.fact p{ font-size:.84rem; color:var(--ink-dim); margin-top:8px; }

/* ============================================================
   ПОДВАЛ — основная надпись чертежа
   ============================================================ */
.title-block{ border-top:2px solid var(--line); margin-top:0; }
.tb-grid{ display:grid; grid-template-columns:2.4fr 1fr 0.7fr 0.7fr 1.6fr; }
.tb-cell{ border-right:1px solid var(--line-soft); padding:18px 20px; display:grid; gap:5px; align-content:center; }
.tb-cell:last-child{ border-right:none; }
.tb-k{ font-family:var(--font-mono); font-size:.66rem; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-dim); }
.tb-v{ font-family:var(--font-head); color:var(--ink); font-size:.96rem; }
.tb-cell--nav{ display:flex; flex-wrap:wrap; gap:4px 14px; align-content:center; }
.tb-cell--nav a{ font-family:var(--font-mono); font-size:.76rem; color:var(--ink-dim); }
.tb-cell--nav a:hover{ color:var(--accent); }
.tb-foot{ text-align:center; font-family:var(--font-mono); font-size:.72rem; color:var(--ink-dim);
  padding:16px; border-top:1px solid var(--line-soft); }

/* ============================================================
   ПОЯВЛЕНИЕ ПРИ СКРОЛЛЕ
   ============================================================ */
.reveal{ opacity:0; transform:translateY(22px); transition:opacity .6s ease, transform .6s ease; }
.reveal.in{ opacity:1; transform:none; }

/* ============================================================
   АДАПТИВ
   ============================================================ */
@media (max-width:900px){
  .nav{ position:fixed; inset:64px 0 auto 0; flex-direction:column; gap:0;
    background:rgba(8,30,49,.98); border-bottom:1px solid var(--line-soft);
    padding:8px 24px 20px; transform:translateY(-130%); transition:transform .3s ease; }
  .nav.open{ transform:none; }
  .nav a{ padding:14px 0; border-bottom:1px dashed var(--line-soft); font-size:.9rem; }
  .nav-toggle{ display:flex; }

  .hero-grid{ grid-template-columns:1fr; gap:36px; }
  .hero-fig{ max-width:360px; margin-inline:auto; }
  .how-grid{ grid-template-columns:1fr; }
  .cols-2{ grid-template-columns:1fr; }
  .parts-grid{ grid-template-columns:repeat(2,1fr); }
  .use-grid{ grid-template-columns:1fr 1fr; }
  .formula-grid{ grid-template-columns:1fr 1fr; }
  .facts{ grid-template-columns:1fr 1fr; }
}

@media (max-width:600px){
  .section{ padding:60px 0; }
  .sec-sub{ margin-left:0; }
  .calc__body{ grid-template-columns:1fr; }
  .calc__inputs{ border-right:none; border-bottom:1px solid var(--line-soft); }
  .parts-grid{ grid-template-columns:1fr; }
  .use-grid{ grid-template-columns:1fr; }
  .formula-grid{ grid-template-columns:1fr; }
  .tb-grid{ grid-template-columns:1fr 1fr; }
  .tb-cell{ border-right:none; border-bottom:1px solid var(--line-soft); }
  .hero-specs{ gap:20px; }
}

/* ============================================================
   ВСПЛЫВАЮЩИЕ ПОДСКАЗКИ
   ============================================================ */
.tip{ position:fixed; z-index:80; max-width:280px; pointer-events:none;
  font-family:var(--font-mono); font-size:.8rem; line-height:1.5; color:var(--ink);
  background:#06203a; border:1px solid var(--accent); border-radius:var(--radius);
  padding:10px 13px; box-shadow:0 10px 34px rgba(0,0,0,.55);
  opacity:0; transform:translateY(5px); transition:opacity .12s ease, transform .12s ease; }
.tip.show{ opacity:1; transform:none; }
.tip::before{ content:"▸ "; color:var(--accent); }

/* зоны-подсказки на схеме «как работает» */
.hit{ fill:transparent; cursor:help; }
.hit:hover, .hit:focus{ fill:rgba(70,212,255,.10); outline:none; }
.hit:focus{ stroke:var(--accent); stroke-width:1; stroke-dasharray:3 3; }

/* ============================================================
   РАЗРЕЗ МАСЛЯНОГО ТРАНСФОРМАТОРА
   ============================================================ */
.cut-wrap{ display:grid; grid-template-columns:1.1fr .9fr; gap:30px; align-items:center; margin-bottom:42px;
  border:1px solid var(--line-soft); border-radius:var(--radius); background:rgba(8,30,49,.5); padding:26px; }
.cutaway__svg{ width:100%; height:auto; color:var(--line); max-height:460px; }
.cutaway figcaption{ font-family:var(--font-mono); font-size:.74rem; color:var(--ink-dim); text-align:center; margin-top:8px; }

.cut-ground{ stroke:var(--line); stroke-width:1; opacity:.5; }
.cut-ground--2{ opacity:.3; }
.cut-part{ cursor:help; }
.cut-part .ln{ fill:none; stroke:var(--line); stroke-width:1.6; transition:stroke .15s, filter .15s; }
.cut-part .lam{ stroke:var(--line); stroke-width:.5; opacity:.4; }
.cut-part .oilfill{ fill:rgba(255,207,107,.07); stroke:rgba(255,207,107,.28); stroke-width:1; stroke-dasharray:3 3; transition:.15s; }
.cut-part .tank{ fill:rgba(120,175,220,.04); }
.wind-hv{ stroke:var(--accent) !important; }
.wind-lv{ stroke:var(--accent-2) !important; }
.cut-part.hot .ln{ stroke:var(--accent); filter:drop-shadow(0 0 5px rgba(70,212,255,.75)); }
.cut-part.hot .oilfill{ fill:rgba(255,207,107,.18); stroke:var(--accent-2); }

.cut-badge{ cursor:help; }
.cut-badge circle{ fill:var(--bg); stroke:var(--line); stroke-width:1; transition:.15s; }
.cut-badge text{ font-family:var(--font-mono); font-size:11px; fill:var(--ink-dim); transition:.15s; }
.cut-badge.hot circle{ stroke:var(--accent); fill:var(--accent); }
.cut-badge.hot text{ fill:#06243a; }

.cut-legend{ list-style:none; display:grid; gap:8px; }
.cut-li{ display:flex; align-items:center; gap:12px; padding:11px 14px; border:1px solid var(--line-soft);
  border-radius:var(--radius); cursor:pointer; transition:.15s; color:var(--ink); font-size:.95rem; }
.cut-li:hover, .cut-li.hot, .cut-li:focus{ border-color:var(--accent); background:rgba(70,212,255,.08); outline:none; }
.cut-li__n{ font-family:var(--font-mono); font-size:.8rem; width:24px; height:24px; flex:none; display:grid; place-items:center;
  border:1px solid var(--accent); color:var(--accent); border-radius:50%; }

/* ============================================================
   ФОТО-ПЛАСТИНЫ (blueprint → реальное фото при наведении)
   ============================================================ */
.plate{ margin:0; }
.plate__frame{ position:relative; border:1px solid var(--line); border-radius:var(--radius); overflow:hidden;
  background:#06203a; }
.plate--wide .plate__frame{ aspect-ratio:16/7; }
.plate--mid .plate__frame{ aspect-ratio:4/3; }
.plate img{ display:block; width:100%; height:100%; object-fit:cover;
  filter:grayscale(1) contrast(1.05) brightness(.9); transition:filter .35s ease; }
.plate__frame::after{ content:""; position:absolute; inset:0; background:var(--accent); mix-blend-mode:color;
  opacity:.6; transition:opacity .35s ease; pointer-events:none; }
.plate__frame::before{ content:""; position:absolute; inset:0; z-index:2; pointer-events:none;
  box-shadow:inset 0 0 0 1px rgba(120,175,220,.22); }
.plate:hover img, .plate:focus-within img{ filter:none; }
.plate:hover .plate__frame::after, .plate:focus-within .plate__frame::after{ opacity:0; }
.plate__tag{ position:absolute; top:8px; left:8px; z-index:3; font-family:var(--font-mono); font-size:.66rem;
  letter-spacing:.12em; color:var(--accent); background:rgba(6,32,58,.82); border:1px solid var(--line-soft);
  padding:3px 9px; border-radius:2px; }
.plate figcaption{ font-family:var(--font-mono); font-size:.74rem; color:var(--ink-dim); margin-top:9px;
  display:flex; justify-content:space-between; gap:14px; flex-wrap:wrap; }
.plate figcaption .credit{ opacity:.65; }

.plate-row{ display:grid; grid-template-columns:.9fr 1.1fr; gap:28px; align-items:center; margin-top:34px;
  padding-top:30px; border-top:1px dashed var(--line-soft); }
.plate-row__txt p{ color:var(--ink-dim); font-size:1rem; }

/* адаптив новых блоков */
@media (max-width:900px){
  .cut-wrap{ grid-template-columns:1fr; }
  .plate-row{ grid-template-columns:1fr; gap:18px; }
  .plate--wide .plate__frame{ aspect-ratio:16/9; }
}
@media (max-width:600px){
  .cut-wrap{ padding:16px; }
  .plate figcaption{ font-size:.68rem; }
}

/* ============================================================
   ПОДСКАЗКИ НА КАРТОЧКАХ ВИДОВ
   ============================================================ */
.card[data-tip]{ cursor:help; padding-bottom:36px; }
.card[data-tip]::after{ content:"i"; position:absolute; right:12px; bottom:12px;
  width:19px; height:19px; display:grid; place-items:center;
  font-family:var(--font-mono); font-size:.72rem; font-style:italic; color:var(--ink-dim);
  border:1px solid var(--line-soft); border-radius:50%; transition:.2s; }
.card[data-tip]:hover::after, .card[data-tip]:focus::after{ color:var(--accent); border-color:var(--accent); }
.card[data-tip]:focus{ outline:none; border-color:var(--accent); }

/* ============================================================
   ЛАЙТБОКС
   ============================================================ */
.plate img{ cursor:zoom-in; }
.lightbox{ position:fixed; inset:0; z-index:100; display:flex; align-items:center; justify-content:center;
  padding:32px; background:rgba(4,16,28,.93); backdrop-filter:blur(5px);
  opacity:0; visibility:hidden; transition:opacity .25s ease, visibility .25s ease; }
.lightbox.open{ opacity:1; visibility:visible; }
.lightbox__fig{ margin:0; max-width:min(1100px,92vw); display:flex; flex-direction:column; gap:12px; }
.lightbox__fig img{ max-width:100%; max-height:82vh; object-fit:contain; cursor:zoom-out;
  border:1px solid var(--line); border-radius:var(--radius); box-shadow:0 20px 70px rgba(0,0,0,.6); }
.lightbox__fig figcaption{ font-family:var(--font-mono); font-size:.78rem; color:var(--ink-dim); text-align:center; }
.lightbox__close{ position:absolute; top:18px; right:22px; width:44px; height:44px; cursor:pointer;
  background:rgba(8,30,49,.85); color:var(--ink); border:1px solid var(--line); border-radius:var(--radius);
  font-size:1.1rem; transition:.2s; }
.lightbox__close:hover{ border-color:var(--accent); color:var(--accent); box-shadow:0 0 20px rgba(70,212,255,.3); }

@media (prefers-reduced-motion:reduce){
  *{ animation:none !important; scroll-behavior:auto; }
  .reveal{ opacity:1; transform:none; }
}
