/* === Систематик — design tokens === */
:root{
  --ink:#0A0A0B;
  --graphite:#1A1A1C;
  --fog:#2A2A2D;
  --paper:#F4F2EC;
  --bone:#E8E5DD;
  --mist:#A8A8AA;
  --mute:rgba(244,242,236,0.55);
  --rule:rgba(244,242,236,0.12);
  --ruleInk:rgba(10,10,11,0.12);
  --acid:#C8FF3F;

  --max:1440px;
  --gutter:32px;
  --pad:48px;
}

*{box-sizing:border-box}
html{overflow-x:hidden}
html,body{margin:0;padding:0;background:var(--paper);color:var(--ink);
  font-family:"Inter Tight","Helvetica Neue",sans-serif;
  font-size:16px;line-height:1.5;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer;padding:0}

.display,.h1,.h2,.h3{font-family:Geist,"Helvetica Neue",sans-serif;font-weight:600;letter-spacing:-0.035em;line-height:0.95}
.display{font-size:clamp(56px,9vw,148px);letter-spacing:-0.05em;line-height:0.86}
.h1{font-size:clamp(40px,5.6vw,80px)}
.h2{font-size:clamp(28px,3.6vw,52px);letter-spacing:-0.03em}
.h3{font-size:clamp(20px,2vw,28px);letter-spacing:-0.02em}
.mono{font-family:"JetBrains Mono",ui-monospace,monospace}
.caps{text-transform:uppercase;letter-spacing:0.18em;font-size:11px}
.eyebrow{font-family:"JetBrains Mono",ui-monospace,monospace;font-size:11px;letter-spacing:0.22em;text-transform:uppercase;color:rgba(10,10,11,0.55)}
.eyebrow.on-dark{color:var(--mute)}

.wrap{max-width:var(--max);margin:0 auto;padding:0 var(--pad)}
@media (max-width:760px){:root{--pad:20px}}

/* === Header === */
[data-slot="header"]{height:64px}
.hdr{position:fixed;top:0;left:0;right:0;z-index:50;background:rgba(244,242,236,0.78);backdrop-filter:saturate(160%) blur(14px);-webkit-backdrop-filter:saturate(160%) blur(14px);border-bottom:1px solid var(--ruleInk)}
.hdr.on-dark{background:rgba(10,10,11,0.7);border-bottom-color:var(--rule);color:var(--paper)}
.hdr-inner{display:flex;align-items:center;justify-content:space-between;height:64px;max-width:var(--max);margin:0 auto;padding:0 var(--pad)}
.hdr-brand{display:flex;align-items:center;gap:10px}
.hdr-brand .name{font-family:Geist;font-weight:600;letter-spacing:-0.02em;font-size:18px}
.hdr-nav{display:flex;align-items:center;gap:6px}
.hdr-nav a{padding:8px 12px;border-radius:8px;font-size:13.5px;font-weight:500;color:rgba(10,10,11,0.7);transition:color .15s,background .15s;white-space:nowrap}
.hdr.on-dark .hdr-nav a{color:rgba(244,242,236,0.7)}
.hdr-nav a:hover{color:var(--ink);background:rgba(10,10,11,0.05)}
.hdr.on-dark .hdr-nav a:hover{color:var(--paper);background:rgba(244,242,236,0.06)}
.hdr-nav a.active{color:var(--ink)}
.hdr.on-dark .hdr-nav a.active{color:var(--paper)}
.hdr-cta{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border-radius:10px;background:var(--ink);color:var(--paper);font-weight:500;font-size:14px;border:1px solid var(--ink);transition:transform .15s,background .15s;white-space:nowrap}
.hdr.on-dark .hdr-cta{background:var(--acid);color:var(--ink);border-color:var(--acid)}
.hdr-cta:hover{transform:translateY(-1px)}
.hdr-cta .dot{width:6px;height:6px;border-radius:50%;background:var(--acid);box-shadow:0 0 8px var(--acid);flex:none}
.hdr.on-dark .hdr-cta .dot{background:var(--ink);box-shadow:none}
.hdr-cta .icon{display:none;font-family:"JetBrains Mono",ui-monospace,monospace;font-size:14px;line-height:1}

.burger{display:none;width:40px;height:40px;border:1px solid var(--ruleInk);border-radius:10px;align-items:center;justify-content:center}
.hdr.on-dark .burger{border-color:var(--rule)}
.burger span,.burger span::before,.burger span::after{display:block;width:18px;height:1.5px;background:currentColor;position:relative;transition:.25s}
.burger span::before{content:"";position:absolute;top:-6px;left:0;width:18px}
.burger span::after{content:"";position:absolute;top:6px;left:0;width:18px}
/* Compact CTA earlier so the nav has breathing room */
@media (max-width:1200px){
  .hdr-cta .label{display:none}
  .hdr-cta .icon{display:inline}
  .hdr-cta{padding:0;width:40px;height:40px;justify-content:center;border-radius:10px}
  .hdr-cta .dot{display:none}
}
@media (max-width:980px){
  .hdr-nav{display:none}
  .burger{display:inline-flex}
}

/* === Drawer === */
.drawer-bg{position:fixed;inset:0;background:rgba(10,10,11,0.4);opacity:0;pointer-events:none;transition:opacity .25s;z-index:60}
.drawer{position:fixed;top:0;right:0;bottom:0;width:min(420px,90vw);background:var(--ink);color:var(--paper);transform:translateX(100%);transition:transform .35s cubic-bezier(.2,.7,.2,1);z-index:61;display:flex;flex-direction:column;padding:24px 28px}
body.drawer-open .drawer-bg{opacity:1;pointer-events:auto}
body.drawer-open .drawer{transform:translateX(0)}
.drawer-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:32px}
.drawer-close{width:36px;height:36px;border:1px solid var(--rule);border-radius:10px;display:inline-flex;align-items:center;justify-content:center;font-size:18px;color:var(--paper)}
.drawer-nav{display:flex;flex-direction:column;gap:2px}
.drawer-nav a{padding:14px 0;border-bottom:1px solid var(--rule);font-family:Geist;font-size:22px;letter-spacing:-0.02em;display:flex;justify-content:space-between;align-items:center}
.drawer-nav a .num{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:0.16em;color:var(--mute)}
.drawer-foot{margin-top:auto;padding-top:24px;border-top:1px solid var(--rule);font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:0.14em;text-transform:uppercase;color:var(--mute);display:flex;flex-direction:column;gap:8px}

/* === Hero === */
.hero{background:var(--ink);color:var(--paper);position:relative;overflow:hidden}
.hero-inner{max-width:var(--max);margin:0 auto;padding:120px var(--pad) 96px;position:relative}
.hero h1{margin:24px 0 0}
.hero .lede{margin-top:32px;max-width:680px;font-size:20px;line-height:1.45;color:rgba(244,242,236,0.78)}
.hero .ctas{display:flex;gap:12px;margin-top:40px;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;gap:10px;padding:14px 20px;border-radius:10px;font-weight:500;font-size:15px;transition:transform .15s;border:1px solid transparent}
.btn-acid{background:var(--acid);color:var(--ink);border-color:var(--acid)}
.btn-ghost{border-color:var(--rule);color:var(--paper)}
.btn:hover{transform:translateY(-1px)}
.hero-marks{position:absolute;top:0;right:0;width:280px;height:280px;background:var(--acid);transform:rotate(45deg) translate(60%,-60%);transform-origin:center}
.hero-meta{display:flex;justify-content:space-between;align-items:flex-end;border-top:1px solid var(--rule);padding-top:24px;margin-top:96px;font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:0.16em;text-transform:uppercase;color:var(--mute)}
@media (max-width:560px){.hero-meta{flex-direction:column;align-items:flex-start;gap:8px;margin-top:48px}}

/* === Sections === */
section{padding:120px 0}
section.tight{padding:80px 0}
section.dark{background:var(--ink);color:var(--paper)}
section.graphite{background:var(--graphite);color:var(--paper)}
section.bone{background:var(--bone)}
.sec-head{display:flex;justify-content:space-between;align-items:flex-end;gap:32px;margin-bottom:48px;flex-wrap:wrap}
.sec-head .left{max-width:680px}
.sec-head h2{margin:12px 0 0}
.sec-head .right{font-family:"JetBrains Mono",monospace;font-size:12px;color:rgba(10,10,11,0.55);letter-spacing:0.1em;max-width:340px;line-height:1.6}
section.dark .sec-head .right,section.graphite .sec-head .right{color:var(--mute)}

/* === Cards (направления) === */
.dir-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:1px;background:var(--ruleInk);border:1px solid var(--ruleInk)}
section.dark .dir-grid,section.graphite .dir-grid{background:var(--rule);border-color:var(--rule)}
.dir-card{grid-column:span 6;background:var(--paper);padding:40px;display:flex;flex-direction:column;gap:24px;min-height:340px;position:relative;transition:background .2s}
section.dark .dir-card,section.graphite .dir-card{background:var(--ink)}
.dir-card.feature{grid-column:span 12;min-height:420px;background:var(--ink);color:var(--paper)}
.dir-card.feature .acid{color:var(--acid)}
.dir-card .num{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:rgba(10,10,11,0.45)}
.dir-card.feature .num,section.dark .dir-card .num{color:var(--mute)}
.dir-card h3{margin:0;font-family:Geist;font-weight:600;font-size:32px;letter-spacing:-0.025em;line-height:1.05}
.dir-card.feature h3{font-size:56px;letter-spacing:-0.04em;max-width:80%}
.dir-card p{margin:0;color:rgba(10,10,11,0.7);max-width:46ch}
.dir-card.feature p,section.dark .dir-card p{color:rgba(244,242,236,0.7)}
.dir-card .tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:auto}
.tag{font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:0.14em;text-transform:uppercase;padding:5px 10px;border:1px solid rgba(10,10,11,0.15);border-radius:999px;color:rgba(10,10,11,0.65)}
section.dark .tag,.dir-card.feature .tag{border-color:var(--rule);color:var(--mute)}
.dir-card .arrow{position:absolute;top:32px;right:32px;width:40px;height:40px;border-radius:50%;border:1px solid rgba(10,10,11,0.15);display:flex;align-items:center;justify-content:center;font-family:"JetBrains Mono",monospace;font-size:14px;transition:transform .25s,background .2s,color .2s}
.dir-card.feature .arrow,section.dark .dir-card .arrow{border-color:var(--rule);color:var(--paper)}
.dir-card:hover{background:var(--bone)}
section.dark .dir-card:hover{background:#141416}
.dir-card.feature:hover{background:#08080a}
.dir-card:hover .arrow{transform:translate(4px,-4px) rotate(-45deg);background:var(--acid);color:var(--ink);border-color:var(--acid)}
@media (max-width:900px){.dir-card{grid-column:span 12;min-height:auto;padding:28px}.dir-card.feature h3{font-size:36px;max-width:100%}}

/* === Process steps (без сетки-коробочки) === */
.steps{display:flex;flex-direction:column;margin-top:24px}
.step{display:grid;grid-template-columns:120px 1fr 1.2fr;gap:48px;align-items:start;padding:40px 0;border-top:1px solid var(--ruleInk);transition:padding-left .25s}
section.dark .step,section.graphite .step{border-top-color:var(--rule)}
.step:last-child{border-bottom:1px solid var(--ruleInk)}
section.dark .step:last-child,section.graphite .step:last-child{border-bottom-color:var(--rule)}
.step:hover{padding-left:16px}
.step .n{font-family:"JetBrains Mono",monospace;font-size:13px;letter-spacing:0.16em;color:rgba(10,10,11,0.5);text-transform:uppercase;padding-top:6px}
section.dark .step .n,section.graphite .step .n{color:var(--mute)}
.step h4{margin:0;font-family:Geist;font-weight:500;font-size:clamp(28px,3vw,40px);letter-spacing:-0.025em;line-height:1}
.step p{margin:0;color:rgba(10,10,11,0.7);font-size:16px;line-height:1.55;max-width:46ch;padding-top:8px}
section.dark .step p,section.graphite .step p{color:rgba(244,242,236,0.72)}
.step h4 em{font-style:normal;color:var(--acid);font-weight:500}
section:not(.dark):not(.graphite) .step h4 em{color:var(--ink);background:var(--acid);padding:0 6px;margin-left:-2px}
@media (max-width:760px){.step{grid-template-columns:1fr;gap:12px;padding:28px 0}}

/* === Cases === */
.cases{display:grid;grid-template-columns:repeat(2,1fr);gap:32px;margin-top:24px}
.case{padding:40px;display:flex;flex-direction:column;gap:20px;min-height:340px;background:var(--paper);border:1px solid var(--ruleInk);position:relative;overflow:hidden;transition:transform .25s,border-color .25s}
section.dark .case,section.graphite .case{background:rgba(244,242,236,0.03);border-color:var(--rule)}
.case::before{content:"";position:absolute;top:0;left:0;width:0;height:3px;background:var(--acid);transition:width .35s cubic-bezier(.2,.7,.2,1)}
.case:hover{transform:translateY(-4px);border-color:var(--ink)}
section.dark .case:hover,section.graphite .case:hover{border-color:var(--paper)}
.case:hover::before{width:100%}
.case .meta{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:rgba(10,10,11,0.55);display:flex;justify-content:space-between}
section.dark .case .meta,section.graphite .case .meta{color:var(--mute)}
.case h4{margin:0;font-family:Geist;font-weight:600;font-size:26px;letter-spacing:-0.025em;line-height:1.15}
.case .kvs{display:grid;grid-template-columns:auto 1fr;gap:10px 24px;margin-top:auto;font-size:15px;line-height:1.45}
.case .kvs dt{font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:0.16em;text-transform:uppercase;color:rgba(10,10,11,0.5);padding-top:3px}
section.dark .case .kvs dt,section.graphite .case .kvs dt{color:var(--mute)}
.case .kvs dd{margin:0;color:rgba(10,10,11,0.88)}
section.dark .case .kvs dd,section.graphite .case .kvs dd{color:rgba(244,242,236,0.92)}
.case .result{font-family:Geist;font-weight:600;color:var(--ink);background:var(--acid);align-self:flex-start;padding:8px 14px;font-size:14px;letter-spacing:-0.01em}
@media (max-width:760px){.cases{grid-template-columns:1fr;gap:16px}}

/* === Lead form === */
.lead{background:var(--ink);color:var(--paper);position:relative;overflow:hidden}
.lead-inner{max-width:var(--max);margin:0 auto;padding:120px var(--pad);display:grid;grid-template-columns:1fr 1fr;gap:64px;position:relative}
.lead .accent{position:absolute;top:-80px;right:-80px;width:400px;height:400px;background:var(--acid);transform:rotate(45deg);opacity:0.95}
.lead-left{position:relative}
.lead-left h2{margin:16px 0 24px}
.lead-left .promise{display:flex;flex-direction:column;gap:14px;margin-top:32px;font-family:"JetBrains Mono",monospace;font-size:12px;letter-spacing:0.14em;text-transform:uppercase;color:var(--mute)}
.lead-left .promise b{color:var(--acid);font-weight:500}
.lead-form{position:relative;background:var(--graphite);padding:40px;border:1px solid var(--rule)}
.lead-form h3{margin:0 0 24px;font-family:Geist;font-weight:600;font-size:22px;letter-spacing:-0.02em}
.field{display:flex;flex-direction:column;gap:8px;margin-bottom:18px}
.field label{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:0.16em;text-transform:uppercase;color:var(--mute)}
.field input,.field textarea,.field select{
  background:transparent;border:none;border-bottom:1px solid var(--rule);
  padding:10px 0;color:var(--paper);font:400 16px/1.4 "Inter Tight",sans-serif;
  outline:none;transition:border-color .2s;
}
.field input:focus,.field textarea:focus,.field select:focus{border-bottom-color:var(--acid)}
.field textarea{resize:vertical;min-height:80px}
.field .err{color:#ff8466;font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:0.1em}
.lead-submit{width:100%;background:var(--acid);color:var(--ink);padding:18px;font-family:Geist;font-weight:600;font-size:16px;letter-spacing:-0.01em;border-radius:0;transition:transform .15s,background .2s;margin-top:8px;display:flex;align-items:center;justify-content:center;gap:10px}
.lead-submit:hover{transform:translateY(-1px)}
.lead-submit:disabled{opacity:0.6;transform:none;cursor:wait}
.lead-foot{margin-top:18px;font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:0.14em;color:var(--mute);line-height:1.7}
.lead-foot a{color:var(--mute);border-bottom:1px solid var(--rule)}
.lead-consent{display:flex;align-items:flex-start;gap:10px;margin:8px 0 18px;font-family:"Inter Tight",sans-serif;font-size:13px;line-height:1.45;color:var(--mute);cursor:pointer}
.lead-consent input[type=checkbox]{appearance:none;-webkit-appearance:none;width:16px;height:16px;border:1px solid var(--rule);background:transparent;border-radius:3px;flex:none;margin-top:2px;cursor:pointer;position:relative;transition:border-color .15s,background .15s}
.lead-consent input[type=checkbox]:checked{background:var(--acid);border-color:var(--acid)}
.lead-consent input[type=checkbox]:checked::after{content:"";position:absolute;left:4px;top:1px;width:5px;height:9px;border:solid var(--ink);border-width:0 2px 2px 0;transform:rotate(45deg)}
.lead-consent a{color:var(--paper);border-bottom:1px solid var(--rule)}
.lead-consent a:hover{color:var(--acid);border-bottom-color:var(--acid)}
.lead-success{display:none;padding:24px;background:rgba(200,255,63,0.08);border-left:3px solid var(--acid);font-family:"JetBrains Mono",monospace;font-size:13px;color:var(--paper);letter-spacing:0.04em}
.lead-success.show{display:block}
.lead-success .ttl{display:block;font-family:Geist;font-weight:600;font-size:22px;color:var(--acid);letter-spacing:-0.02em;margin-bottom:8px;text-transform:none}
@media (max-width:900px){.lead-inner{grid-template-columns:1fr;padding:80px var(--pad)}.lead .accent{width:240px;height:240px;top:-60px;right:-60px}}

/* === Service hero === */
.shero{background:var(--ink);color:var(--paper);position:relative;overflow:hidden}
.shero-inner{max-width:var(--max);margin:0 auto;padding:96px var(--pad) 80px;position:relative;display:grid;grid-template-columns:1.4fr 1fr;gap:48px;align-items:end}
.shero h1{font-family:Geist;font-weight:600;font-size:clamp(32px,7vw,108px);letter-spacing:-0.045em;line-height:0.92;margin:24px 0 0;word-break:break-word}
.shero .crumbs{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--mute);display:flex;gap:8px;align-items:center}
.shero .crumbs a:hover{color:var(--paper)}
.shero .stats{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.shero .stat .v{font-family:Geist;font-weight:600;font-size:44px;letter-spacing:-0.03em;color:var(--acid)}
.shero .stat .k{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:0.16em;text-transform:uppercase;color:var(--mute);margin-top:6px}
.shero-meta{max-width:var(--max);margin:0 auto;padding:24px var(--pad);border-top:1px solid var(--rule);display:flex;justify-content:space-between;font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:0.16em;text-transform:uppercase;color:var(--mute);flex-wrap:wrap;gap:16px}
@media (max-width:900px){.shero-inner{grid-template-columns:1fr;align-items:start}}

/* === In/Out lists === */
.inout{display:grid;grid-template-columns:1fr 1fr;gap:48px;margin-top:24px}
.inout .col{padding:0}
.inout .ttl{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:0.18em;text-transform:uppercase;margin-bottom:24px;padding-bottom:12px;border-bottom:1px solid var(--ruleInk)}
section.dark .inout .ttl,section.graphite .inout .ttl{border-bottom-color:var(--rule)}
.inout .yes .ttl{color:var(--acid)}
.inout .no .ttl{color:rgba(10,10,11,0.4)}
section.dark .inout .no .ttl,section.graphite .inout .no .ttl{color:rgba(244,242,236,0.35)}
.inout ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:14px}
.inout li{font-family:Geist;font-size:18px;letter-spacing:-0.01em;line-height:1.35;padding-left:28px;position:relative}
.inout .yes li::before{content:"→";position:absolute;left:0;top:0;color:var(--acid);font-weight:700;font-size:18px}
.inout .no li{color:rgba(10,10,11,0.45);text-decoration:line-through;text-decoration-color:rgba(10,10,11,0.25)}
section.dark .inout .no li,section.graphite .inout .no li{color:rgba(244,242,236,0.4)}
.inout .no li::before{content:"—";position:absolute;left:0;top:-1px;color:rgba(10,10,11,0.4);font-weight:700;font-size:18px;text-decoration:none}
section.dark .inout .no li::before,section.graphite .inout .no li::before{color:rgba(244,242,236,0.4)}
@media (max-width:760px){.inout{grid-template-columns:1fr;gap:32px}}

/* === Stack chips === */
.stack{display:flex;flex-wrap:wrap;gap:10px}
.stack .chip{padding:10px 18px;border:1px solid var(--ruleInk);font-family:"JetBrains Mono",monospace;font-size:13px;letter-spacing:0.04em;transition:border-color .2s,color .2s}
.stack .chip:hover{border-color:var(--acid);color:var(--acid)}
section.dark .stack .chip,section.graphite .stack .chip{border-color:var(--rule);color:var(--paper)}

/* === Adjacent services === */
.adj{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:24px}
.adj a{padding:32px;display:flex;flex-direction:column;gap:12px;min-height:220px;transition:background .2s,transform .2s,border-color .2s;background:transparent;border:1px solid var(--ruleInk);position:relative}
section.dark .adj a,section.graphite .adj a{border-color:var(--rule)}
.adj a:hover{transform:translateY(-3px);border-color:var(--ink);background:var(--bone)}
section.dark .adj a:hover,section.graphite .adj a:hover{border-color:var(--paper);background:rgba(244,242,236,0.04)}
.adj .num{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:rgba(10,10,11,0.5)}
section.dark .adj .num,section.graphite .adj .num{color:var(--mute)}
.adj h4{margin:0;font-family:Geist;font-weight:600;font-size:24px;letter-spacing:-0.025em}
.adj .arr{margin-top:auto;font-family:"JetBrains Mono",monospace;font-size:13px;color:rgba(10,10,11,0.55);letter-spacing:0.1em}
section.dark .adj .arr,section.graphite .adj .arr{color:var(--mute)}
@media (max-width:760px){.adj{grid-template-columns:1fr;gap:12px}}

/* === Footer === */
footer.foot{background:var(--ink);color:var(--paper);padding:80px 0 32px}
.foot-inner{max-width:var(--max);margin:0 auto;padding:0 var(--pad);display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:48px}
.foot h4{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:0.2em;text-transform:uppercase;color:var(--mute);margin:0 0 16px;font-weight:500}
.foot ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
.foot ul a{color:rgba(244,242,236,0.85);font-size:15px}
.foot ul a:hover{color:var(--acid)}
.foot-brand{display:flex;flex-direction:column;gap:18px}
.foot-brand .name{font-family:Geist;font-weight:600;font-size:32px;letter-spacing:-0.03em}
.foot-brand p{margin:0;color:var(--mute);max-width:38ch;font-size:14px;line-height:1.55}
footer.foot .foot-brand .ink-line{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:0.18em;color:var(--acid)}
.foot-geo{max-width:var(--max);margin:56px auto 0;padding:20px var(--pad);border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);display:flex;flex-wrap:wrap;gap:8px 24px;align-items:baseline}
.foot-geo-label{font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:0.2em;text-transform:uppercase;color:var(--acid);white-space:nowrap}
.foot-geo-cities{font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:0.1em;color:rgba(244,242,236,0.38);line-height:1.6}
.foot-bottom{max-width:var(--max);margin:0 auto;padding:24px var(--pad) 0;border-top:none;display:flex;justify-content:space-between;font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:0.14em;text-transform:uppercase;color:var(--mute);flex-wrap:wrap;gap:16px}
@media (max-width:900px){.foot-inner{grid-template-columns:1fr 1fr}}
@media (max-width:560px){.foot-inner{grid-template-columns:1fr}}

/* === Reveal on scroll === */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
.reveal.delay-1{transition-delay:.08s}
.reveal.delay-2{transition-delay:.16s}
.reveal.delay-3{transition-delay:.24s}
.reveal.delay-4{transition-delay:.32s}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* === Logo mark === */
.mark{display:inline-block;width:28px;height:28px;flex:0 0 auto;position:relative}
.mark svg{width:100%;height:100%}

/* TG floating */
.tg-fab{position:fixed;right:20px;bottom:20px;z-index:40;width:56px;height:56px;border-radius:50%;background:var(--ink);color:var(--paper);display:flex;align-items:center;justify-content:center;box-shadow:0 12px 40px rgba(0,0,0,.25);transition:transform .2s,background .2s}
.tg-fab:hover{transform:translateY(-3px);background:var(--acid);color:var(--ink)}

/* === Prices === */
.prices{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--ruleInk);border:1px solid var(--ruleInk);margin-top:24px}
section.dark .prices,section.graphite .prices{background:var(--rule);border-color:var(--rule)}
.price-card{background:var(--paper);padding:36px;display:flex;flex-direction:column;gap:14px;min-height:200px;transition:background .2s}
section.dark .price-card,section.graphite .price-card{background:var(--ink)}
.price-card:hover{background:var(--bone)}
section.dark .price-card:hover,section.graphite .price-card:hover{background:#141416}
.price-card-head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;flex-wrap:wrap}
.price-card h4{margin:0;font-family:Geist;font-weight:600;font-size:22px;letter-spacing:-0.02em;line-height:1.2}
.price-val{font-family:Geist;font-weight:600;font-size:18px;letter-spacing:-0.015em;color:var(--ink);background:var(--acid);padding:4px 10px;white-space:nowrap}
section.dark .price-val,section.graphite .price-val{color:var(--ink)}
.price-card p{margin:0;color:rgba(10,10,11,0.65);font-size:14.5px;line-height:1.5;max-width:46ch}
section.dark .price-card p,section.graphite .price-card p{color:rgba(244,242,236,0.7)}
.prices-foot{display:flex;justify-content:space-between;align-items:center;margin-top:32px;flex-wrap:wrap;gap:20px}
@media (max-width:760px){.prices{grid-template-columns:1fr}.price-card{padding:28px}.prices-foot{flex-direction:column;align-items:flex-start}}

/* === Partners (главная) === */
.partners{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--rule);border:1px solid var(--rule);margin-top:24px}
.partner{background:var(--ink);padding:32px;display:flex;gap:20px;align-items:flex-start;transition:background .2s}
.partner:hover{background:#141416}
.partner .p-logo{width:64px;height:64px;flex:none;background:var(--acid);color:var(--ink);display:flex;align-items:center;justify-content:center;font-family:Geist;font-weight:700;font-size:18px;letter-spacing:-0.02em}
.partner h4{margin:0 0 6px;font-family:Geist;font-weight:600;font-size:20px;letter-spacing:-0.02em;color:var(--paper)}
.partner p{margin:0;font-size:14px;line-height:1.5;color:rgba(244,242,236,0.7);max-width:32ch}
@media (max-width:760px){.partners{grid-template-columns:1fr}}

/* === Price summary on home === */
.prices-row{margin-top:24px;border-top:1px solid var(--ruleInk)}
.price-row{display:grid;grid-template-columns:60px 1fr auto;gap:24px;align-items:center;padding:24px 0;border-bottom:1px solid var(--ruleInk);transition:padding-left .25s,background .15s;cursor:pointer}
.price-row:hover{padding-left:16px;background:rgba(10,10,11,0.02)}
.price-row .num{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:0.18em;color:rgba(10,10,11,0.45);text-transform:uppercase}
.price-row .ttl{font-family:Geist;font-weight:500;font-size:clamp(22px,2.4vw,30px);letter-spacing:-0.025em;color:var(--ink)}
.price-row .from{font-family:Geist;font-weight:600;font-size:18px;letter-spacing:-0.015em;color:var(--ink);background:var(--acid);padding:6px 12px;white-space:nowrap}
@media (max-width:560px){.price-row{grid-template-columns:40px 1fr;gap:12px}.price-row .from{grid-column:2;justify-self:start;margin-top:6px}}

/* === Blog teasers on home === */
.blog-teasers{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--ruleInk);border:1px solid var(--ruleInk);margin-top:24px}
.blog-teaser{background:var(--paper);padding:36px 32px;display:flex;flex-direction:column;gap:14px;text-decoration:none;color:inherit;transition:background .2s;min-height:220px}
.blog-teaser:hover{background:var(--bone)}
.blog-teaser .eyebrow{color:var(--acid);background:var(--ink);padding:3px 8px;align-self:flex-start}
.blog-teaser h3{margin:0;font-family:Geist,sans-serif;font-weight:600;font-size:clamp(16px,1.5vw,20px);letter-spacing:-0.02em;line-height:1.2;color:var(--ink);flex:1}
.blog-teaser-arrow{font-family:"JetBrains Mono",monospace;font-size:13px;color:rgba(10,10,11,0.35);align-self:flex-end;transition:transform .2s,color .2s}
.blog-teaser:hover .blog-teaser-arrow{color:var(--ink);transform:translate(3px,-3px)}
.blog-all{display:inline-flex;align-items:center;gap:8px;margin-top:28px;font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:rgba(10,10,11,0.55);border-bottom:1px solid var(--ruleInk);padding-bottom:3px;transition:color .15s,border-color .15s}
.blog-all:hover{color:var(--ink);border-color:var(--ink)}
@media(max-width:900px){.blog-teasers{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.blog-teasers{grid-template-columns:1fr}.blog-teaser{padding:24px;min-height:auto}}

/* === Экспресс-аудит CTA === */
.audit-cta{background:var(--bone);padding:72px 0;border-top:1px solid var(--ruleInk);border-bottom:1px solid var(--ruleInk)}
.audit-cta-inner{display:grid;grid-template-columns:1.5fr 1fr;gap:64px;align-items:start}
.audit-cta h2{margin-top:8px}
.audit-list{list-style:none;padding:0;margin:20px 0 0;display:flex;flex-direction:column;gap:10px}
.audit-list li{padding-left:28px;position:relative;font-size:16px;line-height:1.4;color:rgba(10,10,11,0.8)}
.audit-list li::before{content:"→";position:absolute;left:0;top:2px;font-size:12px;color:var(--acid);background:var(--ink);padding:0 3px;line-height:1.5}
.audit-card{background:var(--ink);color:var(--paper);padding:36px;display:flex;flex-direction:column;gap:20px}
.audit-price-note{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:0.15em;text-transform:uppercase;color:rgba(244,242,236,0.45)}
.audit-meta{margin:0;font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:0.1em;color:rgba(244,242,236,0.35);line-height:1.7}
.audit-form{display:flex;flex-direction:column;gap:12px;max-height:0;overflow:hidden;opacity:0;transition:max-height .4s ease,opacity .3s ease}
.audit-form.open{max-height:600px;opacity:1}
.audit-field{display:flex;flex-direction:column;gap:5px}
.audit-field label{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:0.1em;color:rgba(244,242,236,0.5)}
.audit-field input{padding:10px 14px;border:1px solid rgba(244,242,236,0.15);background:rgba(244,242,236,0.06);font:inherit;font-size:15px;color:var(--paper);outline:none;transition:border-color .15s}
.audit-field input:focus{border-color:rgba(244,242,236,0.5)}
.audit-field input::placeholder{color:rgba(244,242,236,0.25)}
.audit-consent{display:flex;align-items:flex-start;gap:8px;font-size:12px;color:rgba(244,242,236,0.4);cursor:pointer;line-height:1.5}
.audit-consent a{color:rgba(244,242,236,0.4);text-decoration:underline}
@media(max-width:900px){.audit-cta-inner{grid-template-columns:1fr;gap:36px}}

/* === Doc pages (privacy / offer / requisites) === */
.doc{padding:96px 0 80px;background:var(--paper);min-height:60vh}
.doc-inner{max-width:760px;margin:0 auto;padding:0 var(--pad)}
.doc .crumbs{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:rgba(10,10,11,0.55);display:flex;gap:8px;margin-bottom:32px}
.doc .crumbs a:hover{color:var(--ink)}
.doc h1{font-family:Geist;font-weight:600;font-size:clamp(36px,5vw,56px);letter-spacing:-0.035em;line-height:1;margin:0 0 16px}
.doc .updated{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:0.16em;text-transform:uppercase;color:rgba(10,10,11,0.5);margin-bottom:48px}
.doc h2{font-family:Geist;font-weight:600;font-size:22px;letter-spacing:-0.02em;margin:40px 0 12px}
.doc h3{font-family:Geist;font-weight:600;font-size:17px;letter-spacing:-0.015em;margin:24px 0 8px}
.doc p,.doc li{font-size:15.5px;line-height:1.65;color:rgba(10,10,11,0.85);max-width:64ch;text-wrap:pretty}
.doc ul,.doc ol{padding-left:22px;margin:8px 0 16px}
.doc li{margin-bottom:6px}
.doc strong{font-weight:600;color:var(--ink)}
.doc .req-grid{display:grid;grid-template-columns:160px 1fr;gap:14px 24px;font-size:15px;line-height:1.5;margin-top:24px;padding:24px;background:var(--bone)}
.doc .req-grid dt{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:0.16em;text-transform:uppercase;color:rgba(10,10,11,0.55);padding-top:3px}
.doc .req-grid dd{margin:0;color:var(--ink)}
@media (max-width:560px){.doc .req-grid{grid-template-columns:1fr;gap:4px 0}.doc .req-grid dd{margin-bottom:12px}}


/* === Team === */
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--rule);border:1px solid var(--rule)}
.member{background:var(--ink);padding:40px;display:flex;flex-direction:column;gap:24px;min-height:340px;position:relative;color:var(--paper)}
.member .avatar{width:96px;height:96px;position:relative;background:var(--paper);overflow:hidden;flex:none}
.member .avatar::before{content:"";position:absolute;top:0;right:0;width:24px;height:24px;background:var(--acid)}
.member .avatar::after{content:"";position:absolute;top:50%;left:-10%;right:-10%;height:1px;background:var(--ink);transform:rotate(-45deg);transform-origin:center}
.member .avatar .ini{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:Geist;font-weight:600;font-size:34px;letter-spacing:-0.03em;color:var(--ink);z-index:2}
.member .role{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--mute)}
.member h4{margin:0;font-family:Geist;font-weight:600;font-size:28px;letter-spacing:-0.025em;line-height:1.05;color:var(--paper)}
.member p{margin:0;color:rgba(244,242,236,0.72);font-size:15px;line-height:1.55;max-width:32ch}
.member .skills{margin-top:auto;display:flex;flex-wrap:wrap;gap:6px}
.member .skills .tag{font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:0.14em;text-transform:uppercase;padding:5px 10px;border:1px solid var(--rule);border-radius:999px;color:var(--mute)}
@media (max-width:900px){.team-grid{grid-template-columns:1fr}.member{padding:28px;min-height:auto}}

/* === Reviews === */
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--ruleInk);border:1px solid var(--ruleInk);margin-top:24px}
.review{background:var(--paper);padding:40px;display:flex;flex-direction:column;gap:24px;min-height:320px;position:relative}
.review::before{content:"\201C";position:absolute;top:18px;right:24px;font-family:Geist;font-weight:600;font-size:96px;line-height:1;color:var(--acid);opacity:0.55}
.review blockquote{margin:0;font-family:Geist;font-weight:500;font-size:19px;line-height:1.45;letter-spacing:-0.015em;color:var(--ink);max-width:38ch;text-wrap:pretty}
.review .who{margin-top:auto;border-top:1px solid var(--ruleInk);padding-top:18px;display:flex;flex-direction:column;gap:2px}
.review .who .name{font-family:Geist;font-weight:600;font-size:15px;letter-spacing:-0.01em;color:var(--ink)}
.review .who .pos{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:0.14em;text-transform:uppercase;color:rgba(10,10,11,0.55)}
@media (max-width:900px){.reviews-grid{grid-template-columns:1fr}.review{padding:28px;min-height:auto}}

/* === CTA variants on direction page === */
.cta-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--rule);border:1px solid var(--rule);margin-top:24px}
.cta-card{background:var(--ink);color:var(--paper);padding:40px;display:flex;flex-direction:column;gap:18px;min-height:340px;position:relative}
.cta-card.hot{background:var(--acid);color:var(--ink)}
.cta-card .lvl{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:0.2em;text-transform:uppercase;display:flex;align-items:center;gap:10px}
.cta-card.hot .lvl{color:rgba(10,10,11,0.6)}
.cta-card:not(.hot) .lvl{color:var(--mute)}
.cta-card .lvl::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--acid);box-shadow:0 0 10px var(--acid)}
.cta-card.hot .lvl::before{background:var(--ink);box-shadow:none}
.cta-card.warm .lvl::before{background:#FFB85F;box-shadow:0 0 10px rgba(255,184,95,0.5)}
.cta-card.cold .lvl::before{background:var(--mist);box-shadow:none}
.cta-card h4{margin:0;font-family:Geist;font-weight:600;font-size:24px;letter-spacing:-0.02em;line-height:1.1}
.cta-card p{margin:0;color:rgba(244,242,236,0.72);font-size:14.5px;line-height:1.5;max-width:36ch}
.cta-card.hot p{color:rgba(10,10,11,0.7)}
.cta-card .actions{margin-top:auto;display:flex;flex-direction:column;gap:10px}
.cta-card .btn{justify-content:space-between;width:100%}
.cta-card.hot .btn-acid{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.cta-card .btn-line{display:flex;align-items:center;gap:10px;font-size:13.5px;font-family:"JetBrains Mono",monospace;letter-spacing:0.04em;color:rgba(244,242,236,0.7);padding:12px 16px;border:1px solid var(--rule);border-radius:10px;transition:border-color .15s,color .15s}
.cta-card .btn-line:hover{border-color:var(--paper);color:var(--paper)}
.cta-card.hot .btn-line{color:rgba(10,10,11,0.7);border-color:rgba(10,10,11,0.18)}
.cta-card.hot .btn-line:hover{border-color:var(--ink);color:var(--ink)}
.cta-card .meta{margin-top:6px;font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:0.14em;text-transform:uppercase;color:var(--mute)}
.cta-card.hot .meta{color:rgba(10,10,11,0.55)}
@media (max-width:900px){.cta-grid{grid-template-columns:1fr}.cta-card{min-height:auto;padding:28px}}

/* === Footer extension === */
footer.foot .foot-inner{grid-template-columns:1.4fr 1fr 1fr 1fr 1fr}
@media (max-width:1100px){footer.foot .foot-inner{grid-template-columns:1fr 1fr 1fr}}
@media (max-width:760px){footer.foot .foot-inner{grid-template-columns:1fr 1fr}}
@media (max-width:480px){footer.foot .foot-inner{grid-template-columns:1fr}}
.foot-bottom{flex-wrap:wrap;gap:12px 24px}
.foot-bottom .req{display:flex;flex-wrap:wrap;gap:4px 18px;color:var(--mute)}
.foot-bottom .req b{color:rgba(244,242,236,0.78);font-weight:500}

.hp-field{position:absolute !important;left:-9999px !important;top:-9999px !important;width:1px;height:1px;padding:0;margin:0;overflow:hidden;opacity:0;pointer-events:none;border:0}
.lead-error{margin-top:12px;padding:10px 14px;background:rgba(255,100,80,0.12);color:#ff8466;font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:0.1em;line-height:1.6}

/* === SEO hidden heading === */
.seo-heading{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* === FAQ === */
.faq-section{padding:80px 0;background:var(--bone)}
.faq-section>h2{max-width:var(--max);margin:0 auto 48px;padding:0 var(--pad);font-family:Geist;font-weight:600;font-size:clamp(28px,3.6vw,52px);letter-spacing:-0.03em;line-height:0.95;color:var(--ink)}
.faq-item{max-width:var(--max);margin:0 auto;padding:32px var(--pad);border-top:1px solid var(--ruleInk);display:grid;grid-template-columns:1fr 1.4fr;gap:48px;align-items:start;transition:padding-left .25s}
.faq-item:last-child{border-bottom:1px solid var(--ruleInk)}
.faq-item:hover{padding-left:calc(var(--pad) + 16px)}
.faq-item h3{font-family:Geist;font-weight:500;font-size:clamp(18px,1.8vw,22px);letter-spacing:-0.02em;margin:0;color:var(--ink);line-height:1.25}
.faq-item p{margin:0;font-size:16px;line-height:1.55;color:rgba(10,10,11,0.7)}
@media(max-width:760px){.faq-item{grid-template-columns:1fr;gap:12px;padding:24px var(--pad)}.faq-item:hover{padding-left:var(--pad)}}

/* === Lead contacts (Telegram + phone near form) === */
.lead-contacts{display:flex;flex-direction:column;gap:12px;margin-top:28px;padding-top:28px;border-top:1px solid var(--rule)}
.lead-contact-item{display:inline-flex;align-items:center;gap:10px;font-family:"JetBrains Mono",monospace;font-size:13px;letter-spacing:0.04em;color:rgba(244,242,236,0.8);transition:color .15s}
.lead-contact-item:hover{color:var(--acid)}
.lead-contact-item svg{flex:none;color:var(--acid)}

/* === Telegram link in header === */
.hdr-tg{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:0.14em;color:rgba(10,10,11,0.55);padding:8px 10px;border-radius:8px;transition:color .15s,background .15s;white-space:nowrap}
.hdr-tg:hover{color:var(--ink);background:rgba(10,10,11,0.05)}
.hdr.on-dark .hdr-tg{color:var(--mute)}
.hdr.on-dark .hdr-tg:hover{color:var(--paper);background:rgba(244,242,236,0.06)}
@media(max-width:980px){.hdr-tg{display:none}}
