/* ============================================================
   hyper.css — FIRMAPOLE «hyper»: видеофоны + мега-гротеск + кинетика.
   Третий вариант витрины. Контент тот же, что у neo, эстетика — на максимум.
   ============================================================ */

:root{
  --bg:#05070a;
  --bg2:#0a0d10;
  --ink:#f3f5ee;
  --mut:#8e978c;
  --line:rgba(243,245,238,.12);
  --lime:#c6ff1a;
  --lime2:#9ae600;
  --acid:#d8ff2e;
  --r:18px;
  --pad:clamp(20px,5vw,90px);
  --maxw:1320px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;background:var(--bg);color:var(--ink);
  font-family:"Space Grotesk","Inter",system-ui,sans-serif;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;cursor:none;
}
@media (hover:none){body{cursor:auto}}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
::selection{background:var(--lime);color:#06120a}

/* ---------- ГЛОБАЛЬНЫЕ FX-СЛОИ ---------- */
.grain{
  position:fixed;inset:-50%;z-index:9000;pointer-events:none;opacity:.06;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  animation:grain 6s steps(8) infinite;mix-blend-mode:overlay;
}
@keyframes grain{
  0%{transform:translate(0,0)}10%{transform:translate(-4%,-2%)}20%{transform:translate(3%,-4%)}
  30%{transform:translate(-2%,3%)}40%{transform:translate(4%,2%)}50%{transform:translate(-3%,-3%)}
  60%{transform:translate(2%,4%)}70%{transform:translate(-4%,2%)}80%{transform:translate(3%,-2%)}
  90%{transform:translate(-2%,-4%)}100%{transform:translate(0,0)}
}
.scan{
  position:fixed;inset:0;z-index:8999;pointer-events:none;opacity:.4;mix-blend-mode:soft-light;
  background:repeating-linear-gradient(0deg,transparent 0 2px,rgba(0,0,0,.5) 2px 3px);
}
.cursor{
  position:fixed;top:0;left:0;width:26px;height:26px;border-radius:50%;z-index:9999;
  border:1.5px solid var(--lime);pointer-events:none;mix-blend-mode:difference;
  transform:translate(-50%,-50%);transition:width .2s,height .2s,background .2s;
  will-change:transform;
}
.cursor.is-hot{width:54px;height:54px;background:var(--lime);border-color:var(--lime)}
@media (hover:none){.cursor{display:none}}
.progress{position:fixed;top:0;left:0;right:0;height:3px;z-index:9001;background:transparent}
.progress i{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--lime),var(--acid));box-shadow:0 0 16px var(--lime)}

/* ---------- ВИДЕОФОНЫ ---------- */
.vbg{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;
  filter:saturate(1.15) contrast(1.05);
}
.vbg--soft{opacity:.5;filter:saturate(1.1) blur(2px)}
.hero__veil{position:absolute;inset:0;z-index:1;background:
  radial-gradient(120% 90% at 80% 10%,rgba(198,255,26,.10),transparent 55%),
  linear-gradient(180deg,rgba(5,7,10,.35),rgba(5,7,10,.86) 70%,var(--bg))}
.blk__veil{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,var(--bg),rgba(5,7,10,.78),var(--bg))}
.lead__veil{position:absolute;inset:0;z-index:1;background:
  radial-gradient(90% 80% at 15% 30%,rgba(198,255,26,.14),transparent 60%),
  linear-gradient(180deg,rgba(5,7,10,.55),rgba(5,7,10,.9))}

/* ---------- ТИПОГРАФИКА ---------- */
.mega{
  font-family:"Bricolage Grotesque","Anton",sans-serif;font-weight:800;
  font-size:clamp(3.4rem,12.5vw,12rem);line-height:.86;letter-spacing:-.03em;
  text-transform:uppercase;margin:.12em 0 .28em;text-wrap:balance;
}
.mega--sm{font-size:clamp(2.6rem,7vw,5.6rem)}
.h2{
  font-family:"Bricolage Grotesque",sans-serif;font-weight:800;
  font-size:clamp(1.9rem,5vw,4.2rem);line-height:.95;letter-spacing:-.025em;
  text-transform:uppercase;margin:.1em 0 .35em;text-wrap:balance;
}
.kicker{
  font-family:"Space Mono",monospace;font-size:.74rem;letter-spacing:.34em;
  text-transform:uppercase;color:var(--lime);display:inline-block;
}
.lede{color:var(--mut);font-size:clamp(1rem,1.5vw,1.18rem);max-width:60ch;margin:.4em 0 0}

/* split-анимация заголовков по словам */
[data-split] .w{display:inline-block;overflow:hidden;vertical-align:top}
[data-split] .w i{display:inline-block;font-style:inherit;transform:translateY(108%);transition:transform .8s cubic-bezier(.16,1,.3,1)}
[data-split].in .w i{transform:translateY(0)}

/* generic reveal */
[data-rv]{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s cubic-bezier(.16,1,.3,1)}
[data-rv].in{opacity:1;transform:none}

/* ---------- КНОПКИ ---------- */
.btn{
  --bg-btn:var(--lime);
  position:relative;display:inline-flex;align-items:center;gap:.5em;
  font-family:"Space Grotesk",sans-serif;font-weight:700;font-size:.96rem;
  padding:.85em 1.5em;border-radius:100px;background:var(--bg-btn);color:#06120a;
  border:1.5px solid var(--bg-btn);will-change:transform;
  transition:transform .25s cubic-bezier(.16,1,.3,1),box-shadow .25s,background .2s,color .2s;
}
.btn:hover{box-shadow:0 0 0 4px rgba(198,255,26,.18),0 14px 40px rgba(198,255,26,.22)}
.btn--ghost{background:transparent;color:var(--ink);border-color:var(--line)}
.btn--ghost:hover{border-color:var(--lime);color:var(--lime);box-shadow:none}
.btn--xl{font-size:1.05rem;padding:1.05em 1.9em}
.full{width:100%}

/* ---------- HEADER ---------- */
.hd{
  position:fixed;top:0;left:0;right:0;z-index:8000;
  display:flex;align-items:center;justify-content:space-between;gap:20px;
  padding:14px var(--pad);
  background:linear-gradient(180deg,rgba(5,7,10,.7),transparent);
  backdrop-filter:blur(6px);transition:transform .4s,background .3s;
}
.hd.is-hidden{transform:translateY(-110%)}
.hd.is-solid{background:rgba(5,7,10,.86);border-bottom:1px solid var(--line);backdrop-filter:blur(14px)}
.logo{font-family:"Bricolage Grotesque",sans-serif;font-weight:800;font-size:1.32rem;letter-spacing:-.02em;display:flex;align-items:center;gap:.45em;text-transform:uppercase}
.logo i{font-style:normal;color:var(--lime)}
.logo__dot{width:11px;height:11px;border-radius:50%;background:var(--lime);box-shadow:0 0 14px var(--lime);animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.45;transform:scale(.8)}}
.hd__nav{display:flex;gap:26px;font-family:"Space Mono",monospace;font-size:.78rem;letter-spacing:.12em;text-transform:uppercase}
.hd__nav a{position:relative;color:var(--mut);transition:color .2s}
.hd__nav a::after{content:"";position:absolute;left:0;bottom:-5px;width:0;height:1.5px;background:var(--lime);transition:width .3s}
.hd__nav a:hover{color:var(--ink)}.hd__nav a:hover::after{width:100%}
@media (max-width:860px){.hd__nav{display:none}}

/* ---------- HERO ---------- */
.hero{position:relative;min-height:100svh;display:flex;flex-direction:column;justify-content:flex-end;overflow:hidden;padding:0 var(--pad) clamp(40px,7vh,90px)}
.hero__in{position:relative;z-index:2;max-width:var(--maxw);width:100%;margin:0 auto}
.hero__sub{color:#cfd6cb;font-size:clamp(1.02rem,1.7vw,1.32rem);max-width:62ch;margin:.2em 0 1.8em;line-height:1.5}
.hero__cta{display:flex;gap:14px;flex-wrap:wrap}
.hero__tags{display:flex;gap:10px;flex-wrap:wrap;margin-top:2rem}
.hero__tags b{font-family:"Space Mono",monospace;font-size:.72rem;letter-spacing:.14em;padding:.55em .9em;border:1px solid var(--line);border-radius:100px;color:var(--mut);background:rgba(255,255,255,.02)}
.hero__scroll{position:absolute;right:var(--pad);bottom:34px;z-index:2;font-family:"Space Mono",monospace;font-size:.7rem;letter-spacing:.3em;color:var(--mut);writing-mode:vertical-rl;animation:bob 2.4s ease-in-out infinite}
@keyframes bob{0%,100%{transform:translateY(0);opacity:.5}50%{transform:translateY(10px);opacity:1}}

/* ---------- ТИКЕР / МАРКИ ---------- */
.ticker{position:relative;z-index:2;overflow:hidden;border-block:1px solid var(--line);padding:.65em 0;margin-bottom:auto;background:rgba(198,255,26,.04)}
.ticker--top{margin-top:84px}
.ticker__t{display:inline-flex;align-items:center;gap:1.4em;white-space:nowrap;font-family:"Bricolage Grotesque",sans-serif;font-weight:800;font-size:1.05rem;text-transform:uppercase;letter-spacing:.02em;animation:marq 28s linear infinite;will-change:transform}
.ticker__t span:nth-child(even){color:var(--lime)}
@keyframes marq{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ---------- STATS ---------- */
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border-block:1px solid var(--line);margin:0}
.stat{background:var(--bg);padding:clamp(28px,5vw,64px) var(--pad);text-align:center}
.stat__n{font-family:"Bricolage Grotesque",sans-serif;font-weight:800;font-size:clamp(3rem,9vw,7rem);line-height:.9;color:var(--lime);letter-spacing:-.03em}
.stat__l{font-family:"Space Mono",monospace;font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;color:var(--mut);margin-top:.6em}
@media (max-width:720px){.stats{grid-template-columns:1fr}}

/* ---------- БЛОКИ ---------- */
.blk{position:relative;padding:clamp(70px,11vw,150px) var(--pad);max-width:var(--maxw);margin:0 auto;overflow:hidden}
.blk--calc{max-width:none;padding-inline:0}
.blk--calc>.sec-head,.blk--calc>.calc{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--pad);position:relative;z-index:2}
.sec-head{display:flex;gap:clamp(16px,3vw,42px);align-items:flex-start;margin-bottom:clamp(36px,5vw,68px)}
.idx{font-family:"Space Mono",monospace;font-size:.82rem;color:var(--lime);padding-top:.6em;flex:none}
.sec-head>div{flex:1}

/* objects */
.objects{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
.obj{background:var(--bg2);padding:clamp(22px,2.6vw,38px);min-height:230px;display:flex;flex-direction:column;position:relative;transition:background .3s,transform .3s;transform-style:preserve-3d}
.obj:hover{background:#10150f}
.obj__n{font-family:"Space Mono",monospace;font-size:.78rem;color:var(--mut);position:absolute;top:18px;right:20px}
.obj__ic{font-size:2.6rem;line-height:1;margin-bottom:auto}
.obj h3{font-family:"Bricolage Grotesque",sans-serif;font-weight:800;font-size:1.35rem;text-transform:uppercase;letter-spacing:-.01em;margin:1.4em 0 .35em}
.obj__blurb{color:var(--mut);font-size:.96rem;line-height:1.5;margin:0}
@media (max-width:900px){.objects{grid-template-columns:1fr 1fr}}
@media (max-width:560px){.objects{grid-template-columns:1fr}}

/* calc */
.calc{border:1px solid var(--line);border-radius:var(--r);background:rgba(10,13,16,.72);backdrop-filter:blur(10px);overflow:hidden}
.calc__top{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line)}
.calc__f{background:var(--bg2);padding:18px 20px;display:flex;flex-direction:column;gap:9px}
.calc__f label{font-family:"Space Mono",monospace;font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;color:var(--mut)}
.calc__f select,.calc__f input{appearance:none;background:#070a0c;border:1px solid var(--line);border-radius:10px;color:var(--ink);font:inherit;font-size:.98rem;padding:.7em .8em;transition:border .2s,box-shadow .2s}
.calc__f select:focus,.calc__f input:focus{outline:none;border-color:var(--lime);box-shadow:0 0 0 3px rgba(198,255,26,.16)}
.calc__out{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line)}
.metric{background:var(--bg2);padding:26px 20px;text-align:center}
.metric b{display:block;font-family:"Bricolage Grotesque",sans-serif;font-weight:800;font-size:clamp(1.8rem,4vw,2.9rem);line-height:1;letter-spacing:-.02em}
.metric.is-cost b{color:var(--lime)}
.metric small{font-family:"Space Mono",monospace;font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:var(--mut);margin-top:.6em;display:block}
.calc__foot{display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap;padding:20px;border-top:1px solid var(--line)}
.calc__foot p{color:var(--mut);font-size:.82rem;max-width:60ch;margin:0;line-height:1.5}
@media (max-width:760px){.calc__top{grid-template-columns:1fr 1fr}.calc__out{grid-template-columns:1fr}}

/* price-list */
.price-list{border-top:1px solid var(--line)}
.price-row{display:grid;grid-template-columns:auto 1fr auto auto;align-items:center;gap:clamp(14px,2vw,32px);padding:clamp(18px,2.4vw,30px) 4px;border-bottom:1px solid var(--line);transition:background .25s,padding-left .25s}
.price-row:hover{background:linear-gradient(90deg,rgba(198,255,26,.07),transparent);padding-left:18px}
.price-row__i{font-family:"Space Mono",monospace;font-size:.8rem;color:var(--mut)}
.price-row__name{font-family:"Bricolage Grotesque",sans-serif;font-weight:800;font-size:clamp(1.15rem,2.4vw,1.7rem);text-transform:uppercase;letter-spacing:-.01em}
.price-row__desc{color:var(--mut);font-size:.92rem;margin-top:.25em;max-width:52ch}
.price-row__unit{font-family:"Space Mono",monospace;font-size:.68rem;letter-spacing:.12em;color:var(--lime);border:1px solid var(--line);padding:.4em .7em;border-radius:100px}
.price-row__val{font-family:"Bricolage Grotesque",sans-serif;font-weight:800;font-size:clamp(1.3rem,2.6vw,1.9rem);white-space:nowrap}
.price-row__val u{font-family:"Space Mono",monospace;font-size:.62rem;color:var(--mut);text-decoration:none;letter-spacing:.06em}
@media (max-width:680px){.price-row{grid-template-columns:auto 1fr;row-gap:8px}.price-row__unit{grid-column:1/2;justify-self:start}.price-row__val{grid-column:2/3;justify-self:end}}

/* steps */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.step{border:1px solid var(--line);border-radius:var(--r);padding:26px 22px;background:var(--bg2);transition:transform .3s,border-color .3s}
.step:hover{transform:translateY(-6px);border-color:var(--lime)}
.step__n{font-family:"Bricolage Grotesque",sans-serif;font-weight:800;font-size:2.4rem;color:var(--lime);line-height:1;letter-spacing:-.03em}
.step h3{font-family:"Space Grotesk",sans-serif;font-weight:700;font-size:1.1rem;margin:.7em 0 .35em}
.step p{color:var(--mut);font-size:.92rem;line-height:1.5;margin:0}
@media (max-width:900px){.steps{grid-template-columns:1fr 1fr}}
@media (max-width:520px){.steps{grid-template-columns:1fr}}

/* info / delivery */
.info{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.info__c{border:1px solid var(--line);border-radius:var(--r);padding:clamp(26px,3.4vw,46px);background:linear-gradient(180deg,var(--bg2),var(--bg));transition:transform .3s,border-color .3s}
.info__c:hover{border-color:var(--lime)}
.info__c h3{font-family:"Bricolage Grotesque",sans-serif;font-weight:800;font-size:clamp(1.4rem,3vw,2.2rem);text-transform:uppercase;letter-spacing:-.02em;margin:.6em 0 .4em}
.info__c p{color:var(--mut);line-height:1.6;margin:0}
@media (max-width:760px){.info{grid-template-columns:1fr}}

/* ---------- LEAD ---------- */
.lead{position:relative;overflow:hidden;padding:clamp(70px,11vw,150px) var(--pad)}
.lead__in{position:relative;z-index:2;max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,70px);align-items:center}
.lead__contacts{display:flex;flex-direction:column;gap:6px;margin-top:1.6em;font-family:"Bricolage Grotesque",sans-serif;font-weight:800;font-size:clamp(1.2rem,2.5vw,1.8rem)}
.lead__contacts a:hover{color:var(--lime)}
.form{display:grid;grid-template-columns:1fr 1fr;gap:12px;background:rgba(10,13,16,.8);backdrop-filter:blur(12px);border:1px solid var(--line);border-radius:var(--r);padding:clamp(20px,3vw,34px)}
.form input,.form textarea{background:#070a0c;border:1px solid var(--line);border-radius:10px;color:var(--ink);font:inherit;font-size:.98rem;padding:.85em .9em;transition:border .2s,box-shadow .2s}
.form input:focus,.form textarea:focus{outline:none;border-color:var(--lime);box-shadow:0 0 0 3px rgba(198,255,26,.16)}
.form textarea{resize:vertical}
.consent{display:flex;align-items:flex-start;gap:9px;color:var(--mut);font-size:.82rem;line-height:1.4}
.consent input{width:18px;height:18px;accent-color:var(--lime);flex:none}
.notice{grid-column:1/-1;background:rgba(198,255,26,.12);border:1px solid var(--lime);border-radius:10px;padding:.9em 1em;color:var(--ink);font-size:.92rem;margin:0}
.notice em{color:var(--mut);font-style:normal}
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
@media (max-width:760px){.lead__in,.form{grid-template-columns:1fr}}

/* ---------- FOOTER ---------- */
.ft{border-top:1px solid var(--line);overflow:hidden}
.ft__mega{font-family:"Bricolage Grotesque","Anton",sans-serif;font-weight:800;font-size:clamp(3rem,13vw,11rem);line-height:1;text-transform:uppercase;letter-spacing:-.03em;white-space:nowrap;color:transparent;-webkit-text-stroke:1.5px rgba(243,245,238,.22);padding:.18em 0;animation:marq 32s linear infinite}
.ft__row{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;padding:26px var(--pad);font-family:"Space Mono",monospace;font-size:.76rem;letter-spacing:.06em;color:var(--mut);border-top:1px solid var(--line)}
.ft__row a:hover{color:var(--lime)}
.ft__badge{color:var(--lime);border:1px solid var(--line);padding:.4em .8em;border-radius:100px}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition:none!important}
  [data-rv],[data-split] .w i{opacity:1!important;transform:none!important}
  .vbg{display:none}
}
