/* ============================================================
   TGENOME — layout & components.  Mobile-first. No PNG.
   ============================================================ */
*{margin:0;padding:0;box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{background:var(--bg);color:var(--ink);font-family:var(--ui);min-height:100svh}
:focus-visible{outline:2px solid var(--cyan);outline-offset:3px}
ul{list-style:none}
.fx-scan::after{content:"";position:fixed;inset:0;pointer-events:none;z-index:60;opacity:.5;
  background:repeating-linear-gradient(0deg,transparent 0 3px,rgba(0,0,0,.06) 3px 4px)}

/* пока идёт загрузочный экран — сайт нельзя листать */
html.boot-lock,html.boot-lock body{overflow:hidden;height:100%;touch-action:none;overscroll-behavior:none}

/* =================== ЗАГРУЗОЧНЫЙ ЭКРАН (дизайн 1920×1080, масштаб через JS) =================== */
#boot{position:fixed;inset:0;z-index:9999;background:#000;color:var(--green);font-family:var(--mono);
  display:grid;place-items:center;overflow:hidden;clip-path:inset(0 0 0 0)}
/* центрируем absolute+translate+scale — надёжнее grid-центрирования элемента больше вьюпорта;
   пропорции (uniform contain-scale) сохраняются на любом экране. transform задаётся в JS. */
.boot-fit{position:absolute;left:50%;top:50%;width:1920px;height:1080px;
  transform-origin:center center;transform:translate(-50%,-50%)}
.boot-stage{position:relative;width:1920px;height:1080px}

/* --- синие блоки с бинарём, ВПЛОТНУЮ к краям ЭКРАНА (вынесены из сцены,
       привязаны к вьюпорту, масштаб через --bs = тот же scale, что у сцены) --- */
.bin{position:absolute;z-index:2;width:calc(90px * var(--bs,1));color:#fff;
  font-size:calc(12px * var(--bs,1));line-height:1.55;letter-spacing:.14em;
  white-space:pre;overflow:hidden;padding:calc(12px * var(--bs,1)) 0;text-align:center;background:#1147F8;
  background-image:radial-gradient(rgba(255,255,255,.09) .8px,transparent 1.4px);
  background-size:calc(8px * var(--bs,1)) calc(8px * var(--bs,1))}
.bin.tl,.bin.bl{left:0}.bin.tr,.bin.br{right:0}
.binband{display:none}   /* горизонтальные полосы — только на мобилках */
.bin.tl,.bin.tr{top:calc(120px * var(--bs,1));height:calc(400px * var(--bs,1))}
.bin.bl,.bin.br{bottom:calc(140px * var(--bs,1));height:calc(250px * var(--bs,1))}

/* --- двойная синяя рамка: внешняя 1466×806, внутренняя 1400×770, штрих 4px --- */
.boot-frame-outer{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:1466px;height:806px;border:4px solid #2f54e6;pointer-events:none}
.boot-panel{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:1400px;height:770px;border:4px solid #2f54e6;background:rgba(4,8,24,.25);
  display:flex;justify-content:center}

/* --- контент строго в квадрате 770×770 по центру --- */
.boot-content{position:relative;width:770px;height:100%;
  display:flex;flex-direction:column;justify-content:space-between;padding:18px 0}
.boot-top{display:flex;flex-direction:column;align-items:center;gap:16px}
.boot-sub{font-size:22px;letter-spacing:.3em;text-transform:uppercase;color:#6f8dff}
.boot-sub .jp{color:#3a4f8f;margin-left:.7em}
/* сканлайны рисуются ВНУТРИ текста (SVG-clip) — без тёмного бокса и ореола за буквами */
.boot-titlewrap{position:relative;width:770px;overflow:visible;padding:16px 0 18px;line-height:0}
.boot-title{position:relative;z-index:1;display:block;width:770px;height:auto}

/* --- статус-блоки + //GAINING ACCESS --- */
.boot-lower{display:flex;flex-direction:column;align-items:center;gap:38px}
.boot-status{display:flex;justify-content:center;align-items:flex-start;width:100%;gap:130px}
.boot-modules{font-size:15px;line-height:2;letter-spacing:.1em}
.boot-modules .row{display:flex;justify-content:space-between;gap:2.5em;color:var(--green-dim);opacity:.3}
.boot-modules .row.on{opacity:1;color:var(--green)}
.boot-modules .row.ok .st{color:var(--green)}
/* индикаторы-квадратики убраны — статус [ OK ] не дублируем */
.boot-ind{display:none}
.boot-headline{font-family:var(--display);font-weight:400;text-transform:uppercase;text-align:center;
  font-size:66px;letter-spacing:.02em;color:var(--ink);line-height:1}
.boot-headline b{color:var(--green)}
#dots{color:var(--ink)}

/* --- финальная пиксельная галочка 550×300 (в нижней зоне, не на названии) --- */
.boot-check{position:absolute;left:50%;top:60%;transform:translate(-50%,-50%);
  width:550px;height:300px;display:flex;align-items:center;justify-content:center}
.boot-check svg{filter:drop-shadow(0 0 22px rgba(43,240,122,.5))}

/* --- лейблы под рамкой (только текст) --- */
.boot-icons{position:absolute;left:0;right:0;bottom:42px;text-align:center;
  font-family:var(--mono);font-size:18px;letter-spacing:.12em;color:#cfcfc9;white-space:nowrap}

/* =================== ТАКТИЧЕСКАЯ РАМКА =================== */
.frame{position:fixed;inset:var(--inset);pointer-events:none;z-index:40;border:1px solid var(--line)}
.frame .lab{position:absolute;font-family:var(--mono);font-size:var(--fs-tiny);color:var(--dim);
  text-transform:uppercase;letter-spacing:.14em;padding:3px 7px;background:var(--bg)}
.frame .t{top:-1px;left:50%;transform:translateX(-50%)}
.frame .bl{bottom:-1px;left:8px}.frame .br{bottom:-1px;right:8px}.frame .tr{top:-1px;right:8px}
.cross{position:absolute;width:14px;height:14px;opacity:.7}
.cross::before,.cross::after{content:"";position:absolute;background:var(--green)}
.cross::before{left:50%;top:0;width:1px;height:100%;transform:translateX(-50%)}
.cross::after{top:50%;left:0;height:1px;width:100%;transform:translateY(-50%)}
.cross.tl{top:-7px;left:-7px}.cross.trr{top:-7px;right:-7px}
.cross.bll{bottom:-7px;left:-7px}.cross.brr{bottom:-7px;right:-7px}
/* шапка перекрывает зону верхних меток рамки — прячем их, чтобы не дублировались */
.frame .t,.frame .tr{display:none}

/* =================== ШАПКА (sticky, навигация по якорям) =================== */
.site-head{position:sticky;top:0;z-index:50;background:rgba(5,7,11,.85);backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.sh-inner{display:flex;align-items:stretch}
.sh-logo{display:flex;align-items:center;gap:.55em;padding:0 22px;border-right:1px solid var(--line);
  font-family:var(--display);font-weight:400;font-size:1.35rem;letter-spacing:.06em;text-transform:uppercase;
  color:#fff;text-decoration:none;white-space:nowrap}
.sh-logo .sq{width:12px;height:12px;background:var(--blue);box-shadow:0 0 10px var(--blue);flex:none}
.sh-nav{display:flex;flex:1}
.sh-nav a{flex:1;display:flex;align-items:center;justify-content:center;padding:16px 14px;
  border-right:1px solid var(--line);text-decoration:none;
  font-family:var(--display);font-weight:400;font-size:1.05rem;letter-spacing:.05em;text-transform:uppercase;
  color:#e7e7e1;transition:background .18s,color .18s}
.sh-nav a:hover{background:rgba(26,77,255,.14);color:#fff}
.sh-cta{display:flex;align-items:center;justify-content:center;padding:0 26px;background:var(--blue);color:#fff;
  font-family:var(--mono);font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;text-decoration:none;font-weight:700;
  transition:filter .18s}
.sh-cta:hover{filter:brightness(1.15)}
/* бургер: «=» (закрыто) → «✕» (открыто) — только мобилка */
.sh-burger{display:none;width:40px;height:34px;border:1px solid var(--line);background:transparent;
  cursor:pointer;position:relative;flex:none;align-self:center;margin-right:14px}
.sh-burger span{display:none}
.sh-burger::before,.sh-burger::after{content:"";position:absolute;left:9px;right:9px;height:2px;background:var(--ink);
  transition:top .25s var(--ease),transform .25s var(--ease)}
.sh-burger::before{top:13px}
.sh-burger::after{top:21px}
.sh-burger.open::before{top:50%;transform:translateY(-50%) rotate(45deg)}
.sh-burger.open::after{top:50%;transform:translateY(-50%) rotate(-45deg)}
/* выпадающее меню M6 (моно по центру, пунктирная рамка) */
.sh-menu{display:none;flex-direction:column;gap:8px;padding:14px 16px;border-top:1px solid var(--line);
  background:rgba(5,8,14,.97)}
.sh-menu.open{display:flex}
.sh-menu a{text-align:center;padding:13px;border:1px dashed #2a3a6e;text-decoration:none;color:#cfcfc9;
  font-family:var(--mono);font-size:.84rem;letter-spacing:.16em;text-transform:uppercase;
  transition:border-color .18s,color .18s}
.sh-menu a:hover{border-style:solid;border-color:var(--green);color:#fff}
.sh-menu .sh-mcta{font-weight:700;background:var(--blue);color:#fff;border:0;margin-top:4px}

/* =================== СТАРТОВЫЙ ЭКРАН =================== */
.hero{position:relative;height:calc(100svh - var(--head-h));display:flex;flex-direction:column;overflow:hidden;
  padding:calc(var(--inset) + clamp(16px,2.4vw,30px))}
.hero-grid{flex:1;min-height:0;display:grid;grid-template-columns:1.25fr .85fr;
  gap:clamp(20px,4vw,56px);align-items:center}

/* ЛЕВО — контент + текстура */
.lead{position:relative;display:flex;flex-direction:column;gap:clamp(12px,1.8vh,22px);min-width:0}
.lead>*{position:relative;z-index:1}
.lead-tex{position:absolute;inset:-30px -10px;z-index:0;pointer-events:none;opacity:.6;
  background:
    radial-gradient(circle at 18% 36%,rgba(26,77,255,.10),transparent 58%),
    linear-gradient(rgba(43,240,122,.05) 1px,transparent 1px) 0 0/38px 38px,
    linear-gradient(90deg,rgba(43,240,122,.05) 1px,transparent 1px) 0 0/38px 38px,
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='120' height='120'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/></filter><rect width='100%25' height='100%25' filter='url(%23n)' opacity='0.5'/></svg>");
  mask-image:linear-gradient(90deg,#000 55%,transparent 92%)}
/* на мобилке текстура шапки идёт сверху-вниз */
@media (max-width:900px){
  .lead-tex{-webkit-mask-image:linear-gradient(180deg,#000 45%,transparent 95%);
            mask-image:linear-gradient(180deg,#000 45%,transparent 95%)}
}
.eyebrow{font-family:var(--mono);font-size:var(--fs-mono);letter-spacing:.24em;text-transform:uppercase;
  color:var(--green);display:flex;align-items:center;gap:.7em}
.eyebrow::before{content:"";width:10px;height:10px;background:var(--blue);box-shadow:0 0 10px var(--blue);flex:none}
.brand{font-family:var(--display);font-weight:400;line-height:.84;text-transform:uppercase;
  font-size:clamp(4rem,10.5vw,11.5rem);letter-spacing:.01em;color:var(--ink)}
.lede{font-size:clamp(1.05rem,1.7vw,1.5rem);color:#d7d7d1;line-height:1.55;max-width:52ch}
.lede b{color:#fff}
.steps{display:flex;flex-direction:column;gap:7px;border-left:1px solid var(--line);padding-left:14px}
.steps li{font-family:var(--mono);font-size:var(--fs-mono);text-transform:uppercase;letter-spacing:.05em;
  color:#bdbdb7;display:flex;gap:.8em;align-items:baseline}
.steps li .n{color:var(--green);font-weight:700}
.steps li b{color:#fff;font-weight:700}
.cta{align-self:flex-start;margin-top:4px;display:inline-flex;align-items:center;gap:.7em;text-decoration:none;
  font-family:var(--mono);font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:#fff;
  background:var(--blue);border:0;cursor:pointer;padding:.9em 1.5em;font-size:var(--fs-ui);
  transition:filter .15s var(--ease)}
.cta:hover,.cta:focus-visible{filter:brightness(1.15)}

/* ПРАВО — синяя панель */
.panel{position:relative;background:var(--blue);border:1px solid #4f6dff;height:100%;min-height:0;
  display:flex;flex-direction:column;overflow:hidden;box-shadow:0 0 60px rgba(26,77,255,.22)}
.panel::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:repeating-linear-gradient(0deg,transparent 0 3px,rgba(0,0,0,.10) 3px 4px)}
.panel-head{display:flex;justify-content:space-between;align-items:center;gap:1em;flex:none;
  font-family:var(--mono);font-size:var(--fs-mono);text-transform:uppercase;letter-spacing:.08em;
  color:#eaf0ff;padding:10px 12px;border-bottom:1px solid #4f6dff}
.panel-head .live{color:#bfffd6;display:flex;align-items:center;gap:6px}
.panel-head .live::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--green);
  box-shadow:0 0 8px var(--green);animation:blink 1.3s steps(2) infinite}
.schematic{flex:1;width:100%;min-height:0;padding:8px;display:block}
.panel-hud{display:flex;justify-content:space-between;gap:1em;flex-wrap:wrap;flex:none;
  font-family:var(--mono);font-size:var(--fs-mono);color:#cdd8ff;padding:10px 12px;border-top:1px solid #4f6dff}
.panel-hud .b{color:#fff}
@keyframes blink{50%{opacity:.35}}

/* --- живая схема (panel) --- */
.scope-wave{filter:drop-shadow(0 0 2px rgba(43,240,122,.7))}
.reticle{transform-box:fill-box;transform-origin:center;animation:reticlePulse 3.4s ease-in-out infinite}
@keyframes reticlePulse{0%,100%{transform:scale(1)}50%{transform:scale(1.18)}}
.scanline{animation:coreScan 2.4s ease-in-out infinite alternate}
@keyframes coreScan{from{transform:translateY(-16px)}to{transform:translateY(16px)}}
.logline{transform-box:fill-box;transform-origin:left center;animation:logType 3.5s steps(1,end) infinite}
@keyframes logType{0%{transform:scaleX(0);opacity:.2}10%{transform:scaleX(1);opacity:1}85%{transform:scaleX(1);opacity:1}95%,100%{transform:scaleX(0);opacity:.2}}
.flow-pulse{fill:#2BF07A;filter:drop-shadow(0 0 3px #2BF07A)}

/* бегущая полоска — внизу */
.ticker{overflow:hidden;border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  padding:8px 0;margin-top:clamp(14px,2.2vh,26px);flex:none}
.ticker-track{display:inline-flex;gap:2.4em;white-space:nowrap;font-family:var(--mono);
  font-size:var(--fs-mono);text-transform:uppercase;letter-spacing:.22em;color:var(--green-dim);will-change:transform}
.ticker-track b{color:var(--green)}
.ticker-track .s{color:var(--dim)}

/* =================== СЕКЦИИ (скелет) =================== */
html{scroll-behavior:smooth;scroll-padding-top:var(--head-h)}
.sections{position:relative;z-index:1}
.block{position:relative;border-top:1px solid var(--line);padding:clamp(60px,10vh,140px) 0}
.block-inner{width:100%;max-width:1200px;margin:0 auto;
  padding-inline:calc(var(--inset) + clamp(16px,3vw,40px))}
.block-head{display:flex;gap:clamp(16px,3vw,40px);align-items:flex-start;margin-bottom:clamp(24px,4vh,48px)}
.block-no{font-family:var(--display);font-weight:400;line-height:.9;font-size:clamp(3rem,7vw,6rem);
  margin-top:-.06em;flex:none;
  color:transparent;-webkit-text-stroke:1.5px var(--green);text-stroke:1.5px var(--green)}
.block-kicker{font-family:var(--mono);font-size:var(--fs-mono);letter-spacing:.22em;text-transform:uppercase;
  color:var(--green);margin-bottom:.6em}
.block-title{font-family:var(--display);font-weight:400;text-transform:uppercase;line-height:1.06;
  font-size:clamp(2rem,5vw,4rem);letter-spacing:.02em;color:var(--ink)}
.block-sub{font-size:var(--fs-lede);color:#bdbdb7;max-width:56ch;margin-top:.6em;line-height:1.5}
.block-body.placeholder{min-height:clamp(220px,34vh,420px);border:1px dashed #2a3550;
  display:grid;place-items:center;font-family:var(--mono);font-size:var(--fs-mono);letter-spacing:.15em;
  color:#3f4a66;text-transform:uppercase;
  background:repeating-linear-gradient(135deg,rgba(26,77,255,.04) 0 10px,transparent 10px 20px)}
.cta-block{position:relative;overflow:hidden;background:rgba(26,77,255,.05)}
/* анимированная сетка-мозаика за текстом «Sequence your channel» (рисуется кодом) */
.cta-grid{position:absolute;inset:0;width:100%;height:100%;z-index:0;opacity:.13;pointer-events:none;
  -webkit-mask-image:radial-gradient(130% 110% at 50% 45%,#000 30%,transparent 82%);
          mask-image:radial-gradient(130% 110% at 50% 45%,#000 30%,transparent 82%)}
.cta-block>.block-inner{position:relative;z-index:1}
/* мобилка: текстура чуть заметнее и направлена сверху-вниз */
@media (max-width:900px){
  .cta-grid{opacity:.2;
    -webkit-mask-image:linear-gradient(180deg,#000 0%,#000 60%,transparent 100%);
            mask-image:linear-gradient(180deg,#000 0%,#000 60%,transparent 100%)}
}

/* --- контентные секции: карточки-сетка + FAQ-аккордеон --- */
.gcards{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(12px,1.6vw,20px)}
.gcards-4{grid-template-columns:repeat(4,1fr)}
.gcard{position:relative;border:1px solid var(--line);background:rgba(26,77,255,.045);
  padding:clamp(16px,2vw,26px);overflow:hidden;
  clip-path:polygon(0 0,100% 0,100% calc(100% - 14px),calc(100% - 14px) 100%,0 100%)}
.gcard::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:repeating-linear-gradient(0deg,transparent 0 3px,rgba(0,0,0,.05) 3px 4px)}
.gcard .gc-no{font-family:var(--mono);font-size:var(--fs-mono);letter-spacing:.2em;color:var(--green)}
.gcard h3{font-family:var(--ui);font-weight:700;text-transform:uppercase;letter-spacing:.02em;
  font-size:clamp(1.05rem,1.5vw,1.3rem);color:#fff;margin:.5em 0 .35em}
.gcard p{color:#a9a9a3;font-size:var(--fs-ui);line-height:1.55;position:relative}

.faq-list{border-top:1px solid var(--line)}
.faq-item{border-bottom:1px solid var(--line)}
.faq-item>summary{cursor:pointer;list-style:none;display:flex;align-items:center;justify-content:space-between;
  gap:1.2em;padding:clamp(14px,2.2vh,22px) 0;font-family:var(--ui);font-weight:500;
  font-size:clamp(1rem,1.5vw,1.25rem);color:#fff;transition:color .2s var(--ease)}
.faq-item>summary:hover{color:var(--green)}
.faq-item>summary::-webkit-details-marker{display:none}
.faq-item>summary::after{content:"+";font-family:var(--mono);color:var(--green);font-size:1.3em;flex:none}
.faq-item[open]>summary::after{content:"–"}
.faq-item>p{color:#a9a9a3;font-size:var(--fs-lede);line-height:1.6;max-width:80ch;
  padding:0 0 clamp(14px,2.2vh,22px)}

/* PROOF: статистика reference build */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(12px,1.6vw,20px)}
.stat{border:1px solid var(--line);background:rgba(26,77,255,.045);padding:clamp(16px,2vw,26px);
  display:flex;flex-direction:column;gap:.3em}
.stat .num{font-family:var(--display);font-weight:400;line-height:.85;color:var(--green);
  font-size:clamp(2.4rem,5vw,4rem);padding-bottom:.14em} /* запятая Anton свисает ниже базовой линии */
.stat .lab{font-family:var(--mono);font-size:var(--fs-mono);letter-spacing:.18em;text-transform:uppercase;color:var(--dim)}
.formats{margin-top:clamp(18px,2.4vh,30px);color:#cfcfc9;font-size:var(--fs-lede);line-height:1.6;max-width:80ch}
.formats b{color:#fff}

@media (max-width:900px){ .gcards,.gcards-4{grid-template-columns:1fr 1fr} .stats{grid-template-columns:1fr 1fr} }
@media (max-width:560px){ .gcards,.gcards-4{grid-template-columns:1fr} }

/* --- секции-шаги: текст слева + БОЛЬШОЕ интерактивное облако точек справа --- */
.step-block{min-height:84svh;display:flex;align-items:center}
.step-block .block-inner{max-width:min(2200px,95vw)}
.step-grid{display:grid;grid-template-columns:.82fr 1.18fr;gap:clamp(24px,4vw,64px);align-items:center;width:100%}
.step-text{min-width:0}
.feat{display:flex;flex-direction:column;gap:14px;margin-top:6px}
.feat li{position:relative;padding-left:26px;font-size:var(--fs-lede);color:#cfcfc9;line-height:1.5}
.feat li::before{content:"";position:absolute;left:0;top:.55em;width:10px;height:10px;
  background:var(--green);box-shadow:0 0 10px var(--green);
  clip-path:polygon(50% 0,100% 50%,50% 100%,0 50%)}
.feat li b{color:#fff}
.cloud-wrap{position:relative;height:min(86vh,900px);width:100%;
  border:1px solid var(--line);background:
    radial-gradient(circle at 60% 50%,rgba(26,77,255,.12),transparent 70%);overflow:hidden}
.cloud-wrap::before{content:"";position:absolute;inset:0;pointer-events:none;z-index:2;
  background:repeating-linear-gradient(0deg,transparent 0 3px,rgba(0,0,0,.08) 3px 4px)}
.cloud-wrap::after{content:"HOVER · FOLLOW";position:absolute;left:10px;bottom:8px;z-index:2;
  font-family:var(--mono);font-size:var(--fs-tiny);letter-spacing:.18em;color:var(--green-dim);opacity:.7}
.pcloud{display:block;width:100%;height:100%;cursor:crosshair;touch-action:pan-y}

/* === DECODE: панель «YOUR CHANNEL → #DECODED» (scroll-driven морф через реальный SVG) === */
.cloud-wrap:has(.decode-stage){border:0;background:none;overflow:visible}
.cloud-wrap:has(.decode-stage)::before,
.cloud-wrap:has(.decode-stage)::after{display:none}
.decode-stage{--p:0;position:relative;width:100%;height:100%;overflow:hidden;
  background:var(--blue);
  clip-path:polygon(13% 0,100% 0,100% 87%,87% 100%,0 100%,0 13%);
  box-shadow:0 0 60px rgba(26,77,255,.35)}
/* SVG уже панели (синие поля по бокам + просвет между полос).
   Высота 265% от панели => окно = ~1 «секция» SVG: на старте видна цельная белая
   колонка, в конце — прямые цветные полосы.
   Морф проигрывается один раз, когда блок появляется в кадре (класс .is-playing):
   ~1с пауза на «YOUR CHANNEL», затем прокрутка до «#DECODED» и стоп навсегда. */
.ds-scroll{position:absolute;top:0;left:50%;height:265%;
  transform:translate(-50%,0);will-change:transform}
.ds-scroll img{display:block;height:100%;width:auto}
@keyframes dsScroll{
  from{transform:translate(-50%,0)}
  to{transform:translate(-50%,-62.26%)}
}
.decode-stage.is-playing .ds-scroll{
  animation:dsScroll 3.4s cubic-bezier(.22,.61,.36,1) 1s forwards}
@media (prefers-reduced-motion:reduce){
  .ds-scroll{transform:translate(-50%,-62.26%)}
}
.ds-cross{position:absolute;z-index:4;color:#fff;font-size:clamp(34px,4vw,64px);
  font-weight:300;line-height:1;font-family:var(--mono)}
.ds-cross-tr{top:14px;right:18px}
.ds-cross-bl{bottom:14px;left:18px}

/* decode на мобилках использует ту же логику height:265% — она не зависит от размера панели,
   поэтому отдельный мобильный оверрайд НЕ нужен (он раньше ломал прокрутку морфа). */

/* === общие синие панели шагов === */
.recon-stage{position:relative;width:100%;height:100%;overflow:hidden;background:var(--blue);
  clip-path:polygon(13% 0,100% 0,100% 87%,87% 100%,0 100%,0 13%);box-shadow:0 0 60px rgba(26,77,255,.35)}
/* мониторная текстура (горизонтальные сканлайны, как на .panel) — на всех синих панелях */
.decode-stage::after,.recon-stage::after{content:"";position:absolute;inset:0;
  pointer-events:none;z-index:7;background:repeating-linear-gradient(0deg,transparent 0 3px,rgba(0,0,0,.10) 3px 4px)}
.cloud-wrap:has(.recon-stage){border:0;background:none;overflow:visible}
.cloud-wrap:has(.recon-stage)::before,.cloud-wrap:has(.recon-stage)::after{display:none}

/* === 02 RECONSTRUCT: сборка контент-матрицы (play-once по скроллу) === */
.recon-stage .rc-hud{position:absolute;z-index:5;left:0;right:0;top:13px;text-align:center;
  font-family:var(--mono);font-size:11px;letter-spacing:.14em;color:#06102c}
.recon-stage .rc-hud b{color:#fff}
.recon-stage .rc-legend{position:absolute;left:13%;right:13%;top:12%;display:flex;flex-wrap:wrap;gap:7px;z-index:3}
.recon-stage .rc-chip{font-family:var(--mono);font-size:clamp(8px,.95vw,11px);letter-spacing:.08em;color:#08122e;
  background:var(--cc);padding:4px 8px;border-radius:2px;font-weight:700;opacity:0}
.recon-stage.is-playing .rc-chip{animation:rcChip .42s var(--ease) both;animation-delay:var(--d)}
@keyframes rcChip{from{opacity:0;transform:translateY(-10px) scale(.85)}to{opacity:1;transform:none}}
.recon-stage .rc-matrix{position:absolute;left:13%;right:13%;top:26%;bottom:12%;
  display:grid;grid-template-columns:repeat(7,1fr);grid-auto-rows:1fr;gap:clamp(4px,.85vw,9px)}
.recon-stage .rc-cell{border-radius:3px;background:rgba(255,255,255,.10)}
.recon-stage .rc-cell.f{background:var(--cc);opacity:0}
.recon-stage.is-playing .rc-cell.f{animation:rcCell .5s var(--ease) both;animation-delay:var(--d)}
@keyframes rcCell{from{opacity:0;transform:translate(var(--sx),var(--sy)) scale(.35) rotate(var(--r))}to{opacity:1;transform:none}}
.recon-stage .rc-scan{position:absolute;left:13%;right:13%;top:26%;height:2px;z-index:4;opacity:0;
  background:linear-gradient(90deg,transparent,var(--green),transparent);box-shadow:0 0 14px var(--green)}
/* линия идёт линейно и финиширует вместе с последним рядом блоков (~2.55с от старта сцены) */
.recon-stage.is-playing .rc-scan{animation:rcScan 2s linear .55s both}
@keyframes rcScan{0%{opacity:0;top:26%}6%{opacity:1}92%{opacity:1}100%{opacity:0;top:88%}}

@media (max-width:900px){
  .step-block{min-height:auto;padding-block:clamp(40px,7vh,72px)}
  .step-grid{grid-template-columns:1fr;gap:22px}
  /* панель-анимация = аккуратная карточка, заведомо ЧУТЬ МЕНЬШЕ экрана (не во всю высоту) */
  .cloud-wrap{height:auto;aspect-ratio:1/0.98;max-height:74svh;order:-1}
  .ds-cross{display:none}   /* угловые + на сжатых панелях налезают на анимацию — скрываем */

  /* 02 reconstruct: чуть выше легенда, плотнее матрица */
  .recon-stage .rc-legend{top:9%}
  .recon-stage .rc-matrix{top:24%;bottom:11%}
}

/* появление секций по скроллу: подъём + CRT-фокусировка из блюра */
.reveal-up{opacity:0;transform:translateY(24px);filter:blur(9px);
  transition:opacity .6s var(--ease),transform .6s var(--ease),filter .7s var(--ease)}
.reveal-up.in{opacity:1;transform:none;filter:none}

/* футер */
.site-footer{border-top:1px solid var(--line);padding:24px 0;font-family:var(--mono);
  font-size:var(--fs-tiny);letter-spacing:.14em;text-transform:uppercase;color:var(--dim)}
.site-footer .block-inner{display:flex;justify-content:space-between;gap:1em;flex-wrap:wrap}
.site-footer b{color:var(--green)}

/* ---- адаптив ---- */
@media (max-width:900px){
  /* шапка: прячем десктоп-навигацию и CTA, показываем бургер */
  .sh-nav,.sh-cta{display:none}
  .sh-logo{flex:1;border-right:0;padding:14px 18px;font-size:1.3rem}
  .sh-burger{display:block}
  .hero{height:auto;min-height:calc(100svh - var(--head-h));overflow:visible;padding-top:max(18px,4vh);padding-bottom:max(18px,4vh)}
  .hero-grid{grid-template-columns:1fr;gap:26px;align-items:stretch}
  .brand{font-size:clamp(3.2rem,15vw,6rem)}
  .lede{font-size:1.02rem;line-height:1.5;max-width:38ch}
  /* кнопка — ровно между блоком текста и блоком схемы, по центру */
  .cta{align-self:center;margin-top:12px}
  /* панель: спокойнее и компактнее — убираем мелкий технический шум */
  .panel{order:2;min-height:0;max-height:52svh;padding:14px}.lead{order:1}
  .schematic{flex:1;min-height:0;padding:4px}
  .schematic .g-hud,
  .schematic .corner-cross{display:none}
  .boot-side{display:none}
  .stepper{display:none}
  .block-head{flex-direction:column;gap:14px}
  /* рамку прижимаем к краям экрана (верхние метки скрыты — их роль выполняет шапка) */
  .frame{inset:0}
}
@media (max-width:520px){ .steps{display:none} .panel{max-height:48svh} }

/* ---- мобилка: общий компактный масштаб контента (всё было визуально крупным) ---- */
@media (max-width:600px){
  :root{ --fs-lede:clamp(.92rem,3.4vw,1.06rem); --fs-ui:clamp(.78rem,3vw,.9rem) }
  /* секции: меньше вертикального воздуха */
  .block{padding:42px 0}
  .step-block{min-height:auto;padding:42px 0}
  .block-head{margin-bottom:20px;gap:10px}
  /* заголовки и номера — ощутимо меньше */
  .brand{font-size:clamp(2.7rem,13vw,4.2rem)}
  .lede{font-size:.95rem;line-height:1.48}
  .block-no{font-size:2.4rem;-webkit-text-stroke-width:1.2px;margin-top:0}
  .block-title{font-size:1.55rem;line-height:1.12;letter-spacing:.01em}
  .block-kicker{margin-bottom:.45em}
  .block-sub{font-size:.95rem;max-width:none;margin-top:.5em}
  .feat{gap:10px;margin-top:4px}
  .feat li{font-size:.95rem;padding-left:22px}
  /* статистика / карточки / FAQ — спокойнее */
  .stat .num{font-size:2.1rem}
  .stat{padding:14px}
  .gcard{padding:16px}
  .gcard h3{font-size:1rem}
  .formats{font-size:.92rem;margin-top:14px}
  .faq-item>summary{font-size:.98rem;padding:14px 0}
  .faq-item>p{font-size:.92rem}
  /* анимационные панели шагов — чуть ниже, меньше доминируют */
  .step-grid{gap:20px}
  .cloud-wrap{max-height:62svh}
}

/* =================== МОУШН-СЛОЙ v47 (вход + скролл + микровзаимодействия) =================== */
/* побуквенный въезд TGENOME (JS оборачивает буквы в .ch) */
.brand .ch{display:inline-block;will-change:transform}
/* шапка прячется при скролле вниз, возвращается при скролле вверх */
.site-head{transition:transform .38s var(--ease)}
.site-head.hide{transform:translateY(-100%)}
/* CTA: блик-развёртка по ховеру + магнит (transform ставит JS) */
.cta,.sh-cta{position:relative;overflow:hidden;will-change:transform}
.cta::after,.sh-cta::after{content:"";position:absolute;top:0;bottom:0;left:-70%;width:45%;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,.38),transparent);
  transform:skewX(-18deg);pointer-events:none;transition:left .5s var(--ease)}
.cta:hover::after,.sh-cta:hover::after{left:130%}
/* карточки: подъём + зелёная кромка + свечение номера */
.gcard{transition:transform .3s var(--ease),border-color .3s var(--ease),box-shadow .3s var(--ease)}
@media (hover:hover){
  .gcard:hover{transform:translateY(-5px);border-color:rgba(43,240,122,.55);
    box-shadow:0 10px 34px rgba(26,77,255,.16)}
  .gcard:hover .gc-no{color:#fff;text-shadow:0 0 9px var(--green)}
  .stat{transition:border-color .3s var(--ease)}
  .stat:hover{border-color:rgba(43,240,122,.45)}
}
/* синяя hero-панель: лёгкий 3D-тилт за курсором (JS, только десктоп) */
.hero-grid{perspective:1100px}
.panel{will-change:transform}
/* переключатель языка в шапке */
.sh-lang{border:0;border-left:1px solid var(--line);background:transparent;color:#cfcfc9;
  font-family:var(--mono);font-size:.72rem;letter-spacing:.14em;padding:0 18px;cursor:pointer;
  text-transform:uppercase;transition:color .2s,background .2s}
.sh-lang:hover{color:var(--green);background:rgba(43,240,122,.07)}
@media (max-width:900px){.sh-lang{padding:9px 13px;align-self:center;border:1px solid var(--line);margin-right:10px}}
/* скан-луч над заголовком секции (запуск классом .scanned по скроллу) */
.block-head{position:relative}
.block-head::before{content:"";position:absolute;left:0;top:-12px;width:100%;height:1px;z-index:1;
  background:linear-gradient(90deg,transparent,var(--green) 30%,var(--cyan) 50%,var(--green) 70%,transparent);
  transform:scaleX(0);transform-origin:left;opacity:0;pointer-events:none}
.block-head.scanned::before{animation:headBeam 1.1s var(--ease) both}
@keyframes headBeam{0%{transform:scaleX(0);opacity:1}70%{transform:scaleX(1);opacity:1}100%{transform:scaleX(1);opacity:0}}
/* номер шага «загорается», когда секция в фокусе */
.block-no{transition:color .6s var(--ease),text-shadow .6s var(--ease)}
.block-no.lit{color:rgba(43,240,122,.14);text-shadow:0 0 22px rgba(43,240,122,.35)}
/* CTA: редкий радар-пинг — тянет глаз к точке конверсии */
@keyframes ctaPing{0%{box-shadow:0 0 0 0 rgba(26,77,255,.55)}75%{box-shadow:0 0 0 13px rgba(26,77,255,0)}100%{box-shadow:0 0 0 0 rgba(26,77,255,0)}}
.cta{animation:ctaPing 3.6s var(--ease) 2.2s infinite}
/* микрокопия под CTA (лид-магнит: бесплатный декод) */
.cta-note{font-family:var(--mono);font-size:var(--fs-tiny);letter-spacing:.18em;
  color:var(--green-dim);text-transform:uppercase}
/* в финальном CTA-блоке подпись отодвигаем от кнопки (учитывая радар-пинг) */
.cta-block .cta-note{margin-top:20px}
/* средняя CTA-полоса (точка входа посреди страницы) */
.cta-strip{padding:clamp(26px,4.5vh,44px) 0;background:rgba(26,77,255,.04)}
.strip-inner{display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap}
.strip-txt{font-family:var(--mono);font-size:var(--fs-ui);letter-spacing:.18em;color:var(--green-dim);
  text-transform:uppercase}
.strip-txt b{color:var(--green)}
@media (max-width:900px){
  .strip-inner{flex-direction:column;text-align:center}
  .cta-note{text-align:center;align-self:center}
}
/* ссылка в футере */
.site-footer a{color:var(--green);text-decoration:none}
.site-footer a:hover{text-decoration:underline}

/* ---- reduced motion ---- */
@media (prefers-reduced-motion:reduce){
  #boot{display:none!important}
  .ticker-track,.panel-head .live::before{animation:none!important}
  .reticle,.scanline,.logline{animation:none!important}
  .reveal-up{opacity:1;transform:none}
  html{scroll-behavior:auto}
  .boot-frame [data-draw]{stroke-dashoffset:0}
  .cta::after,.sh-cta::after{display:none}
  .gcard,.site-head{transition:none}
  .cta{animation:none}
  .block-head.scanned::before{animation:none}
  .reveal-up{filter:none}
}

/* ============ ЗАГРУЗОЧНЫЙ ЭКРАН: мобильная (портретная) раскладка ============
   Фиксированный 1920×1080-макет масштабируется JS-ом и в портрете разъезжается.
   Здесь нейтрализуем JS-трансформ (!important бьёт inline) и собираем флюид-колонку. */
@media (max-width:760px){
  #boot{padding:clamp(16px,5vw,30px)}
  .boot-fit{position:static!important;transform:none!important;width:100%!important;height:auto!important}
  .boot-stage{width:100%;height:auto;display:flex;flex-direction:column;align-items:center}
  .bin,.boot-icons,.boot-frame-outer{display:none}                 /* боковой бинарь и нижние подписи скрываем */
  .boot-panel{position:relative;left:auto;top:auto;transform:none;width:100%;max-width:520px;height:auto;
    border:2px solid #2f54e6;background:rgba(4,8,24,.25);
    padding:clamp(20px,6vw,32px) clamp(14px,4vw,22px)}
  /* горизонтальные полосы с бинарём: одна сверху, одна снизу экрана */
  .binband{display:block;position:fixed;left:0;right:0;z-index:2;height:60px;overflow:hidden;
    color:#fff;background:#1147F8;
    background-image:radial-gradient(rgba(255,255,255,.10) .8px,transparent 1.4px);background-size:7px 7px;
    font-family:var(--mono);font-size:10px;line-height:1.5;letter-spacing:.25em;
    white-space:normal;word-break:break-all;padding:7px 10px}
  .binband.top{top:0}
  .binband.bottom{bottom:0}
  .boot-content{position:static;width:100%;height:auto;justify-content:flex-start;
    gap:clamp(26px,7vw,42px);padding:0}
  .boot-top{gap:clamp(12px,3vw,18px)}
  .boot-sub{font-size:clamp(10px,2.6vw,14px);letter-spacing:.18em;text-align:center;white-space:normal}
  .boot-titlewrap{width:100%;padding:6px 0}
  .boot-title{width:100%}
  .boot-lower{gap:clamp(20px,6vw,34px)}
  /* логи и их статусы-индикаторы — строка-в-строку (одинаковая высота рядов, общий верх) */
  .boot-status{gap:clamp(16px,6vw,40px);align-items:flex-start}
  .boot-modules{font-size:clamp(10px,2.5vw,12.5px);line-height:1.9;letter-spacing:.08em}
  .boot-modules .row{gap:1.1em}
  .boot-headline{font-size:clamp(30px,9vw,52px)}
  /* галочка — абсолютно по центру панели (не влияет на поток, не «выдавливается» вниз) */
  .boot-check{position:absolute;left:50%;top:54%;transform:translate(-50%,-50%);
    width:auto;height:auto;margin:0;display:flex;justify-content:center;z-index:3}
  .boot-check svg{width:clamp(150px,46vw,220px);height:auto}
}
