/* ============================================================
   INSURAV v4 — market intelligence product
   Dark fintech system · Golos Text + JetBrains Mono
   ============================================================ */

/* ---------- tokens ---------- */
/* ===== LIGHT (default) ===== */
:root{
  --bg:        #f6f7fb;
  --bg-2:      #eef1f7;
  --panel:     #ffffff;
  --panel-2:   #f3f5fa;
  --panel-3:   #e7ebf3;
  --line:      rgba(11,16,32,.09);
  --line-2:    rgba(11,16,32,.14);
  --line-3:    rgba(11,16,32,.24);

  --ink:       #0b1020;
  --ink-2:     #3a4256;
  --muted:     #687087;
  --faint:     #9aa2b4;

  --accent:    #2f63e6;
  --accent-2:  #1e51d6;
  --accent-ink:#ffffff;
  --accent-dim:rgba(47,99,230,.09);
  --accent-line:rgba(47,99,230,.30);

  --pos:       #12a05f;
  --neg:       #d83a40;
  --warn:      #c98a18;

  --grad-end:  #f1f4fa;
  --tint:      rgba(11,16,32,.022);
  --hover:     rgba(11,16,32,.04);
  --track:     rgba(11,16,32,.08);
  --dot:       rgba(11,16,32,.055);
  --nav-bg:    rgba(246,247,251,.82);
  --shadow-lg: 0 30px 70px -34px rgba(11,16,32,.22);
  --shadow-md: 0 22px 50px -30px rgba(11,16,32,.16);
  --bar-min:   linear-gradient(90deg,#9aa6c0,#bcc5d8);
  --bar-max:   linear-gradient(90deg,#6b5aff,#8b7bff);

  --sans: "Golos Text", system-ui, -apple-system, sans-serif;
  --mono: "JetBrains Mono", ui-monospace, "SFMono-Regular", monospace;

  --wrap: 1200px;
  --pad: 32px;
  --radius: 14px;
  --radius-sm: 9px;
}

/* ===== DARK ===== */
[data-theme="dark"]{
  --bg:#0a0d14; --bg-2:#0e121b; --panel:#131825; --panel-2:#1a2030; --panel-3:#222a3c;
  --line:rgba(255,255,255,.07); --line-2:rgba(255,255,255,.12); --line-3:rgba(255,255,255,.20);
  --ink:#eef1f7; --ink-2:#c2c9d8; --muted:#8b94a8; --faint:#5b6478;
  --accent:#5aa2ff; --accent-2:#7bb6ff; --accent-ink:#06101f;
  --accent-dim:rgba(90,162,255,.14); --accent-line:rgba(90,162,255,.34);
  --pos:#45d495; --neg:#ff7a7a; --warn:#f3c969;
  --grad-end:#0f1420; --tint:rgba(255,255,255,.015); --hover:rgba(255,255,255,.03);
  --track:rgba(255,255,255,.06); --dot:rgba(255,255,255,.045); --nav-bg:rgba(10,13,20,.72);
  --shadow-lg:0 40px 90px -40px rgba(0,0,0,.8); --shadow-md:0 30px 70px -40px rgba(0,0,0,.7);
  --bar-min:linear-gradient(90deg,#3a4a66,#5a6f96); --bar-max:linear-gradient(90deg,#6b5aff,#8b7bff);
}
html{ background:var(--bg); }
body, .nav.scrolled, .console, .doc, .role, .field-group input, .field-group textarea{ transition:background .35s ease, border-color .35s ease, color .35s ease; }

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0;
  background:var(--bg);
  color:var(--ink);
  font-family:var(--sans);
  font-size:17px;
  line-height:1.6;
  font-weight:400;
  letter-spacing:-0.005em;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
::selection{ background:var(--accent); color:var(--accent-ink); }

a{ color:inherit; text-decoration:none; }
h1,h2,h3,h4{ margin:0; font-weight:600; letter-spacing:-0.025em; line-height:1.08; text-wrap:balance; }
p{ margin:0; text-wrap:pretty; }
button{ font-family:inherit; cursor:pointer; }
.tnum{ font-variant-numeric:tabular-nums; }

.wrap{ max-width:var(--wrap); margin:0 auto; padding:0 var(--pad); }
.wrap-read{ max-width:880px; }

/* ---------- shared bits ---------- */
.eyebrow{
  font-family:var(--mono);
  font-size:11.5px;
  font-weight:500;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--accent);
  display:inline-flex;
  align-items:center;
  gap:9px;
}
.eyebrow::before{
  content:"";
  width:7px; height:7px; border-radius:50%;
  background:var(--accent);
  box-shadow:0 0 0 4px var(--accent-dim);
}
.eyebrow.plain::before{ display:none; }

.btn{
  display:inline-flex; align-items:center; gap:9px;
  font-family:var(--sans);
  font-size:15px; font-weight:600;
  letter-spacing:-0.01em;
  padding:13px 20px;
  border-radius:10px;
  border:1px solid transparent;
  transition:transform .18s ease, background .2s ease, border-color .2s ease, box-shadow .2s ease;
  white-space:nowrap;
}
.btn svg{ width:17px; height:17px; flex:none; }
.btn-primary{
  background:var(--accent);
  color:var(--accent-ink);
  box-shadow:0 1px 0 rgba(255,255,255,.25) inset, 0 8px 24px -10px var(--accent);
}
.btn-primary:hover{ background:var(--accent-2); transform:translateY(-1px); }
.btn-ghost{
  background:transparent;
  color:var(--ink);
  border-color:var(--line-2);
}
.btn-ghost:hover{ border-color:var(--line-3); background:var(--hover); }
.rlink{
  font-family:var(--mono); font-size:13px; letter-spacing:.04em;
  color:var(--ink-2); display:inline-flex; align-items:center; gap:6px;
  transition:color .2s, gap .2s;
}
.rlink:hover{ color:var(--accent); gap:10px; }

.section{ padding:108px 0; position:relative; }
.section.tight{ padding:84px 0; }
.section.alt{ background:var(--bg-2); }
.section.alt::before, .section.alt::after{
  content:""; position:absolute; left:0; right:0; height:1px; background:var(--line);
}
.section.alt::before{ top:0; } .section.alt::after{ bottom:0; }

.sec-head{ max-width:760px; margin-bottom:54px; }
.sec-head .eyebrow{ margin-bottom:18px; }
.sec-head h2{ font-size:clamp(1.9rem,3.4vw,2.8rem); }
.sec-head p{ margin-top:18px; color:var(--muted); font-size:18px; max-width:620px; }

.dept{
  display:flex; align-items:baseline; gap:14px;
  font-family:var(--mono); font-size:12px; letter-spacing:.04em;
  color:var(--faint); margin-bottom:24px;
  border-bottom:1px solid var(--line); padding-bottom:14px;
}
.dept .no{ color:var(--accent); font-weight:600; }
.dept .nm{ color:var(--ink-2); text-transform:uppercase; letter-spacing:.16em; }
.dept .meta{ margin-left:auto; color:var(--faint); }

/* reveal */
.reveal{ opacity:0; transform:translateY(18px); transition:opacity .7s cubic-bezier(.2,.7,.2,1), transform .7s cubic-bezier(.2,.7,.2,1); }
.reveal.in{ opacity:1; transform:none; }
.reveal[data-d="1"]{ transition-delay:.07s; }
.reveal[data-d="2"]{ transition-delay:.14s; }
.reveal[data-d="3"]{ transition-delay:.21s; }
.reveal[data-d="4"]{ transition-delay:.28s; }
.reveal[data-d="5"]{ transition-delay:.35s; }
.reveal[data-d="6"]{ transition-delay:.42s; }
@media (prefers-reduced-motion: reduce){ .reveal{ opacity:1; transform:none; } }

/* ============================================================ NAV */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:100;
  height:66px;
  border-bottom:1px solid transparent;
  transition:background .3s, border-color .3s, backdrop-filter .3s;
}
.nav.scrolled{
  background:var(--nav-bg);
  backdrop-filter:blur(16px) saturate(140%);
  -webkit-backdrop-filter:blur(16px) saturate(140%);
  border-bottom-color:var(--line);
}
.nav-inner{ height:100%; display:flex; align-items:center; gap:28px; flex-wrap:nowrap; }
.nav-brand{
  display:flex; align-items:center; gap:9px;
  font-weight:600; font-size:18px; letter-spacing:.01em;
}
.nav-brand .mk{ font-weight:700; }
.nav-brand .dot{ color:var(--accent); }
.nav-brand .badge{
  font-family:var(--mono); font-size:9.5px; letter-spacing:.12em;
  text-transform:uppercase; color:var(--faint); white-space:nowrap;
  border:1px solid var(--line-2); border-radius:5px; padding:3px 6px; margin-left:4px;
}
.nav-links{ display:flex; gap:22px; margin-left:4px; flex-wrap:nowrap; }
.nav-links a{
  font-size:14.5px; color:var(--ink-2); transition:color .2s; position:relative; white-space:nowrap;
}
.nav-links a:hover{ color:var(--ink); }
.nav-cta{ margin-left:auto; display:flex; align-items:center; gap:14px; }
.nav-cta .rlink{ font-family:var(--sans); font-size:14.5px; letter-spacing:-0.01em; }
.nav .btn{ padding:9px 16px; font-size:14px; }
.theme-toggle{
  width:36px; height:36px; flex:none; display:flex; align-items:center; justify-content:center;
  background:transparent; border:1px solid var(--line-2); border-radius:9px;
  color:var(--ink-2); transition:border-color .2s, color .2s, background .2s;
}
.theme-toggle:hover{ border-color:var(--line-3); color:var(--ink); background:var(--hover); }
.theme-toggle svg{ width:17px; height:17px; }
.theme-toggle .moon{ display:none; }
.theme-toggle .sun{ display:block; }
[data-theme="dark"] .theme-toggle .moon{ display:block; }
[data-theme="dark"] .theme-toggle .sun{ display:none; }
@media(max-width:1080px){ .nav-links{ display:none; } }
@media(max-width:600px){ .nav-cta .rlink{ display:none; } }

/* ============================================================ HERO */
.hero{
  position:relative;
  padding:148px 0 96px;
  overflow:hidden;
}
.hero::before{
  content:""; position:absolute; inset:0;
  background-image:
    radial-gradient(circle at 1px 1px, var(--dot) 1px, transparent 0);
  background-size:32px 32px;
  -webkit-mask-image:radial-gradient(120% 80% at 70% 0%, #000 0%, transparent 72%);
          mask-image:radial-gradient(120% 80% at 70% 0%, #000 0%, transparent 72%);
  pointer-events:none;
}
.hero::after{
  content:""; position:absolute; top:-220px; right:-180px;
  width:680px; height:680px; border-radius:50%;
  background:radial-gradient(circle, var(--accent-dim) 0%, transparent 65%);
  filter:blur(20px); pointer-events:none;
}
.hero-grid{
  position:relative; z-index:1;
  display:grid; grid-template-columns:1.04fr 1.12fr; gap:60px; align-items:center;
}
.hero-lead .eyebrow{ margin-bottom:22px; }
.hero h1{
  font-size:clamp(2.5rem,4.7vw,4.1rem);
  letter-spacing:-0.035em;
  line-height:1.02;
}
.hero h1 em{ font-style:normal; color:var(--accent); }
.hero .sub{
  margin-top:26px; font-size:18.5px; line-height:1.62; color:var(--ink-2);
  max-width:520px;
}
.hero .sub b{ color:var(--ink); font-weight:600; }
.hero-actions{ margin-top:34px; display:flex; align-items:center; gap:22px; flex-wrap:wrap; }
.hero-chips{
  margin-top:40px; padding-top:26px; border-top:1px solid var(--line);
  display:flex; gap:30px; flex-wrap:wrap;
}
.hero-chips .c .k{
  font-family:var(--mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase;
  color:var(--faint); margin-bottom:6px;
}
.hero-chips .c .v{ font-size:15px; color:var(--ink-2); font-weight:500; }

/* ---- product console ---- */
.console{
  position:relative;
  background:linear-gradient(180deg, var(--panel) 0%, var(--grad-end) 100%);
  border:1px solid var(--line-2);
  border-radius:18px;
  box-shadow:var(--shadow-lg);
  overflow:hidden;
}
.console-top{
  display:flex; align-items:center; gap:12px;
  padding:14px 18px; border-bottom:1px solid var(--line);
  background:var(--tint);
}
.console-top .brand{ font-weight:600; font-size:13.5px; display:flex; align-items:center; gap:7px; }
.console-top .brand .dot{ color:var(--accent); }
.console-top .live{
  margin-left:auto; display:flex; align-items:center; gap:7px;
  font-family:var(--mono); font-size:11px; letter-spacing:.08em; color:var(--muted);
}
.console-top .live .pulse{
  width:7px; height:7px; border-radius:50%; background:var(--pos);
  box-shadow:0 0 0 0 rgba(69,212,149,.5); animation:pulse 2.2s infinite;
}
@keyframes pulse{ 0%{box-shadow:0 0 0 0 rgba(69,212,149,.5);} 70%{box-shadow:0 0 0 7px rgba(69,212,149,0);} 100%{box-shadow:0 0 0 0 rgba(69,212,149,0);} }

.console-tabs{ display:flex; gap:4px; padding:11px 14px 0; border-bottom:1px solid var(--line); }
.ctab{
  font-family:var(--mono); font-size:12px; letter-spacing:.03em;
  color:var(--muted); background:none; border:0;
  padding:8px 13px 12px; border-bottom:2px solid transparent;
  transition:color .2s, border-color .2s; margin-bottom:-1px; white-space:nowrap;
}
.ctab:hover{ color:var(--ink-2); }
.ctab.active{ color:var(--ink); border-bottom-color:var(--accent); }

.console-body{ padding:20px; }
.passport{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--line); border:1px solid var(--line); border-radius:10px; overflow:hidden; margin-bottom:18px; }
.passport .c{ background:var(--panel); padding:12px 13px; }
.passport .k{ font-family:var(--mono); font-size:9.5px; letter-spacing:.14em; text-transform:uppercase; color:var(--faint); margin-bottom:5px; }
.passport .v{ font-size:14px; font-weight:600; color:var(--ink); }

.figure-row{ display:flex; align-items:flex-end; justify-content:space-between; gap:16px; margin-bottom:16px; }
.figure-row .big{ font-size:42px; font-weight:600; letter-spacing:-0.03em; line-height:1; white-space:nowrap; }
.figure-row .big .cur{ font-size:24px; color:var(--muted); font-weight:500; }
.figure-row .cap{ text-align:right; font-size:12px; color:var(--muted); line-height:1.5; }
.figure-row .cap b{ color:var(--pos); font-family:var(--mono); font-size:12.5px; }

.spark{ height:46px; width:100%; margin-bottom:18px; display:block; }

.bars{ display:flex; flex-direction:column; gap:11px; margin-bottom:6px; }
.bar{ display:grid; grid-template-columns:42px 1fr 64px; align-items:center; gap:12px; }
.bar .nm{ font-family:var(--mono); font-size:11px; letter-spacing:.08em; color:var(--muted); }
.bar .track{ height:8px; border-radius:5px; background:var(--track); overflow:hidden; }
.bar .fill{ display:block; height:100%; width:0; border-radius:5px; transition:width 1.1s cubic-bezier(.2,.8,.2,1); }
.bar.min .fill{ background:var(--bar-min); }
.bar.avg .fill{ background:linear-gradient(90deg,var(--accent),var(--accent-2)); }
.bar.max .fill{ background:var(--bar-max); }
.bar .val{ font-family:var(--mono); font-size:13px; text-align:right; color:var(--ink); font-variant-numeric:tabular-nums; }

.console-foot{
  display:flex; align-items:center; gap:10px; padding:13px 20px;
  border-top:1px solid var(--line); background:var(--tint);
  font-family:var(--mono); font-size:11px; letter-spacing:.04em; color:var(--faint);
}
.console-foot .fx{ display:flex; align-items:center; gap:6px; }
.console-foot .fx svg{ width:13px; height:13px; color:var(--accent); }
.console-foot .right{ margin-left:auto; color:var(--muted); }

@media(max-width:980px){
  .hero-grid{ grid-template-columns:1fr; gap:48px; }
  .hero{ padding:128px 0 72px; }
}

/* ============================================================ MARQUEE / STAT STRIP */
.strip{ border-top:1px solid var(--line); border-bottom:1px solid var(--line); background:var(--bg-2); }
.strip-inner{ display:grid; grid-template-columns:repeat(4,1fr); }
.strip-inner .s{ padding:30px var(--pad); border-left:1px solid var(--line); }
.strip-inner .s:first-child{ border-left:0; }
.strip-inner .num{ font-size:30px; font-weight:600; letter-spacing:-0.03em; white-space:nowrap; }
.strip-inner .num .u{ color:var(--accent); }
.strip-inner .lbl{ margin-top:6px; font-size:13.5px; color:var(--muted); }
@media(max-width:760px){ .strip-inner{ grid-template-columns:repeat(2,1fr); } .strip-inner .s:nth-child(odd){ border-left:0; } .strip-inner .s:nth-child(3),.strip-inner .s:nth-child(4){ border-top:1px solid var(--line); } }

/* ============================================================ DIRECTIONS */
.dir-tabs{ display:flex; gap:10px; margin-bottom:26px; flex-wrap:wrap; }
.dir-tab{
  display:flex; align-items:center; gap:10px;
  background:var(--panel); border:1px solid var(--line-2); border-radius:12px;
  padding:13px 18px; color:var(--ink-2);
  transition:border-color .2s, background .2s, color .2s; flex:1; min-width:200px;
}
.dir-tab .ix{ font-family:var(--mono); font-size:12px; color:var(--faint); }
.dir-tab .t{ font-weight:600; font-size:15.5px; white-space:nowrap; }
.dir-tab .ar{ margin-left:auto; color:var(--faint); transition:transform .2s,color .2s; }
.dir-tab:hover{ border-color:var(--line-3); }
.dir-tab.active{ background:var(--accent-dim); border-color:var(--accent-line); color:var(--ink); }
.dir-tab.active .ix{ color:var(--accent); }
.dir-tab.active .ar{ color:var(--accent); transform:translateX(3px); }

.dir-panel{
  display:grid; grid-template-columns:1.25fr 1fr; gap:0;
  background:var(--panel); border:1px solid var(--line-2); border-radius:16px; overflow:hidden;
  min-height:330px;
}
.dir-left{ padding:34px 36px; }
.dir-left .eyebrow{ margin-bottom:18px; }
.dir-left h3{ font-size:24px; line-height:1.16; }
.dir-left p{ margin-top:14px; color:var(--muted); font-size:15.5px; max-width:480px; }
.fields-label{ margin-top:26px; font-family:var(--mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--faint); margin-bottom:13px; }
.fields{ display:flex; flex-wrap:wrap; gap:8px; }
.field{
  font-family:var(--mono); font-size:12px; letter-spacing:.01em;
  color:var(--ink-2); background:var(--panel-2); border:1px solid var(--line);
  border-radius:7px; padding:6px 10px;
}
.dir-right{ background:var(--bg-2); border-left:1px solid var(--line); padding:30px 30px; display:flex; flex-direction:column; gap:1px; }
.sample-row{ background:var(--panel); padding:15px 16px; }
.sample-row:first-child{ border-radius:10px 10px 0 0; }
.sample-row .k{ font-family:var(--mono); font-size:10px; letter-spacing:.14em; text-transform:uppercase; color:var(--faint); margin-bottom:5px; }
.sample-row .v{ font-size:14px; color:var(--ink); font-weight:500; }
.sample-row.out{ background:var(--accent-dim); border-radius:0 0 10px 10px; margin-top:auto; }
.sample-row.out .k{ color:var(--accent); }
.sample-row.out .v{ font-family:var(--mono); font-size:13px; }
@media(max-width:820px){ .dir-panel{ grid-template-columns:1fr; } .dir-right{ border-left:0; border-top:1px solid var(--line); } }

/* ============================================================ REPORT / PRODUCT ANATOMY */
.report{ display:grid; grid-template-columns:0.82fr 1.18fr; gap:46px; align-items:start; }
.report-aside{ position:sticky; top:96px; }
.report-aside h2{ font-size:clamp(1.8rem,3vw,2.5rem); }
.report-aside .lead{ margin-top:18px; color:var(--muted); font-size:17px; }
.kv-list{ margin-top:30px; display:flex; flex-direction:column; }
.kv{ display:flex; align-items:baseline; justify-content:space-between; gap:14px; padding:14px 0; border-bottom:1px solid var(--line); }
.kv:first-child{ border-top:1px solid var(--line); }
.kv .k{ font-weight:600; font-size:15px; }
.kv .d{ font-family:var(--mono); font-size:11.5px; letter-spacing:.06em; color:var(--accent); }

.doc{ background:var(--panel); border:1px solid var(--line-2); border-radius:16px; overflow:hidden; box-shadow:var(--shadow-md); }
.doc-head{ border-bottom:1px solid var(--line); }
.doc-tabs{ display:flex; gap:2px; padding:12px 14px 0; }
.doc-tab{
  font-family:var(--mono); font-size:12.5px; letter-spacing:.02em; color:var(--muted);
  background:none; border:0; padding:9px 15px 13px; border-bottom:2px solid transparent;
  transition:color .2s, border-color .2s; margin-bottom:-1px; white-space:nowrap;
}
.doc-tab:hover{ color:var(--ink-2); }
.doc-tab.active{ color:var(--ink); border-bottom-color:var(--accent); }
.doc-file{ padding:10px 18px; font-family:var(--mono); font-size:11px; letter-spacing:.05em; color:var(--faint); background:var(--tint); display:flex; align-items:center; gap:8px; }
.doc-file::before{ content:""; width:7px; height:7px; border-radius:2px; background:var(--pos); }

.doc-passport{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--line); border-bottom:1px solid var(--line); }
.doc-passport .cell{ background:var(--panel); padding:14px 16px; }
.doc-passport .k{ font-family:var(--mono); font-size:9.5px; letter-spacing:.13em; text-transform:uppercase; color:var(--faint); margin-bottom:6px; }
.doc-passport .v{ font-size:13.5px; font-weight:600; }

.matrix{ width:100%; border-collapse:collapse; }
.matrix th{
  text-align:right; font-family:var(--mono); font-size:10.5px; letter-spacing:.1em; text-transform:uppercase;
  color:var(--faint); font-weight:500; padding:14px 18px; border-bottom:1px solid var(--line);
}
.matrix th:first-child{ text-align:left; }
.matrix td{ text-align:right; padding:15px 18px; font-size:14.5px; border-bottom:1px solid var(--line); color:var(--ink-2); font-variant-numeric:tabular-nums; }
.matrix td:first-child{ text-align:left; font-weight:500; color:var(--ink); font-variant-numeric:normal; }
.matrix tr:last-child td{ border-bottom:0; }
.matrix tr.you td{ background:var(--accent-dim); color:var(--ink); }
.matrix tr.you td:first-child{ color:var(--accent); font-weight:600; }
.matrix tr:not(.you):hover td{ background:var(--hover); }
@media(max-width:860px){ .report{ grid-template-columns:1fr; gap:32px; } .report-aside{ position:static; } .doc-passport{ grid-template-columns:repeat(2,1fr); } }

/* ============================================================ ROLES */
.roles{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.role{
  background:var(--panel); border:1px solid var(--line); border-radius:14px; padding:30px 28px;
  transition:border-color .25s, transform .25s; position:relative; overflow:hidden;
}
.role::before{ content:""; position:absolute; top:0; left:0; width:100%; height:2px; background:var(--accent); transform:scaleX(0); transform-origin:left; transition:transform .35s ease; }
.role:hover{ border-color:var(--line-2); transform:translateY(-3px); }
.role:hover::before{ transform:scaleX(1); }
.role .tag{ font-family:var(--mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--accent); }
.role h3{ margin-top:14px; font-size:20px; line-height:1.2; }
.role ul{ list-style:none; padding:0; margin:20px 0 0; display:flex; flex-direction:column; gap:12px; }
.role li{ position:relative; padding-left:22px; font-size:14.5px; color:var(--muted); line-height:1.5; }
.role li::before{ content:""; position:absolute; left:0; top:8px; width:9px; height:9px; border:1.5px solid var(--accent); border-radius:2px; }
@media(max-width:820px){ .roles{ grid-template-columns:1fr; } }

/* ============================================================ FLOW */
.flow{ display:grid; grid-template-columns:repeat(4,1fr); gap:0; border:1px solid var(--line-2); border-radius:16px; overflow:hidden; background:var(--panel); }
.step{ padding:30px 26px; border-left:1px solid var(--line); position:relative; }
.step:first-child{ border-left:0; }
.step .num{ font-family:var(--mono); font-size:11.5px; letter-spacing:.1em; color:var(--accent); }
.step .ico{ width:34px; height:34px; border:1px solid var(--line-2); border-radius:9px; display:flex; align-items:center; justify-content:center; margin:16px 0 18px; color:var(--ink-2); }
.step .ico svg{ width:17px; height:17px; }
.step h3{ font-size:17.5px; }
.step p{ margin-top:10px; font-size:14px; color:var(--muted); line-height:1.55; }
.step .tags{ margin-top:16px; display:flex; gap:6px; flex-wrap:wrap; }
.step .tags span{ font-family:var(--mono); font-size:10.5px; color:var(--faint); border:1px solid var(--line); border-radius:6px; padding:3px 7px; }
@media(max-width:880px){ .flow{ grid-template-columns:repeat(2,1fr); } .step:nth-child(odd){ border-left:0; } .step:nth-child(3),.step:nth-child(4){ border-top:1px solid var(--line); } }
@media(max-width:480px){ .flow{ grid-template-columns:1fr; } .step{ border-left:0; border-top:1px solid var(--line); } .step:first-child{ border-top:0; } }

/* ============================================================ PRICING */
.price-grid{ display:grid; grid-template-columns:1.05fr 1fr; gap:24px; align-items:start; }
.price-card{ background:var(--panel); border:1px solid var(--line-2); border-radius:16px; padding:38px 36px; }
.price-card .label{ font-family:var(--mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--accent); }
.price-card h3{ margin-top:14px; font-size:24px; line-height:1.18; }
.price-card p{ margin-top:16px; color:var(--muted); font-size:15.5px; }
.price-list{ list-style:none; padding:0; margin:24px 0 28px; display:flex; flex-direction:column; gap:13px; }
.price-list li{ display:flex; gap:11px; align-items:flex-start; font-size:14.5px; color:var(--ink-2); }
.price-list svg{ width:18px; height:18px; color:var(--accent); flex:none; margin-top:1px; }

.sla{ background:linear-gradient(180deg,var(--panel-2),var(--panel)); border:1px solid var(--line-2); border-radius:16px; overflow:hidden; }
.sla-tabs{ display:flex; gap:2px; padding:14px 16px 0; border-bottom:1px solid var(--line); }
.sla-tab{ font-family:var(--mono); font-size:12.5px; color:var(--muted); background:none; border:0; padding:9px 13px 14px; border-bottom:2px solid transparent; transition:color .2s,border-color .2s; margin-bottom:-1px; white-space:nowrap; }
.sla-tab:hover{ color:var(--ink-2); }
.sla-tab.active{ color:var(--ink); border-bottom-color:var(--accent); }
.sla-body{ padding:30px 32px; }
.sla-headline{ font-size:26px; font-weight:600; letter-spacing:-0.025em; }
.sla-sub{ margin-top:7px; font-family:var(--mono); font-size:12.5px; color:var(--accent); letter-spacing:.03em; }
.sla-rows{ margin-top:26px; display:flex; flex-direction:column; }
.sla-rows .r{ display:flex; justify-content:space-between; align-items:center; padding:15px 0; border-bottom:1px solid var(--line); }
.sla-rows .r:first-child{ border-top:1px solid var(--line); }
.sla-rows .k{ font-size:14px; color:var(--muted); }
.sla-rows .v{ font-weight:600; font-size:15px; }
@media(max-width:840px){ .price-grid{ grid-template-columns:1fr; } }

/* ============================================================ FAQ */
.faq{ display:flex; flex-direction:column; border-top:1px solid var(--line-2); }
.qa{ border-bottom:1px solid var(--line-2); }
.qa-q{
  width:100%; text-align:left; background:none; border:0; color:var(--ink);
  font-family:var(--sans); font-size:18px; font-weight:500; letter-spacing:-0.015em;
  padding:24px 44px 24px 0; position:relative; transition:color .2s;
}
.qa-q:hover{ color:var(--accent); }
.qa-q .ic{ position:absolute; right:4px; top:50%; width:16px; height:16px; transform:translateY(-50%); }
.qa-q .ic::before,.qa-q .ic::after{ content:""; position:absolute; background:var(--accent); border-radius:2px; transition:transform .3s; }
.qa-q .ic::before{ top:7px; left:0; width:16px; height:2px; }
.qa-q .ic::after{ left:7px; top:0; width:2px; height:16px; }
.qa.open .qa-q .ic::after{ transform:scaleY(0); }
.qa-a{ max-height:0; overflow:hidden; transition:max-height .35s ease; }
.qa-a p{ padding:0 60px 26px 0; color:var(--muted); font-size:16px; line-height:1.65; }

/* ============================================================ CTA */
.cta{ position:relative; overflow:hidden; background:linear-gradient(180deg,var(--bg-2),var(--bg)); border:1px solid var(--line-2); border-radius:22px; }
.cta::before{ content:""; position:absolute; top:-160px; left:-120px; width:540px; height:540px; border-radius:50%; background:radial-gradient(circle,var(--accent-dim),transparent 66%); pointer-events:none; }
.cta-grid{ position:relative; z-index:1; display:grid; grid-template-columns:1fr 1fr; }
.cta-left{ padding:52px 48px; border-right:1px solid var(--line); }
.cta-left .eyebrow{ margin-bottom:20px; }
.cta-left h2{ font-size:clamp(1.7rem,2.8vw,2.4rem); }
.cta-left .lead{ margin-top:18px; color:var(--ink-2); font-size:16.5px; max-width:440px; }
.cta-points{ margin-top:30px; display:flex; flex-direction:column; gap:1px; }
.cta-points .p{ display:flex; gap:16px; align-items:baseline; padding:14px 0; border-top:1px solid var(--line); }
.cta-points .p .k{ font-family:var(--mono); font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--accent); min-width:96px; }
.cta-points .p .v{ font-size:15px; color:var(--ink-2); }

.form-wrap{ padding:52px 48px; }
.form-grid{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.field-group{ display:flex; flex-direction:column; gap:7px; }
.field-group.full{ grid-column:1/-1; }
.field-group label{ font-family:var(--mono); font-size:10.5px; letter-spacing:.12em; text-transform:uppercase; color:var(--faint); }
.field-group input,.field-group textarea{
  background:var(--panel); border:1px solid var(--line-2); border-radius:9px;
  color:var(--ink); font-family:var(--sans); font-size:15px; padding:12px 13px; transition:border-color .2s, background .2s;
}
.field-group input::placeholder,.field-group textarea::placeholder{ color:var(--faint); }
.field-group input:focus,.field-group textarea:focus{ outline:none; border-color:var(--accent-line); background:var(--panel-2); }
.field-group textarea{ resize:vertical; min-height:80px; }
.form-wrap .btn-primary{ margin-top:20px; width:100%; justify-content:center; }
.form-foot{ margin-top:16px; text-align:center; font-size:13.5px; color:var(--muted); }
.form-foot a{ color:var(--accent); }
.form-consent{ margin-top:14px; font-size:12.5px; line-height:1.55; color:var(--faint); text-align:center; }
.form-consent a{ color:var(--muted); text-decoration:underline; text-underline-offset:2px; transition:color .2s; }
.form-consent a:hover{ color:var(--accent); }
.form-success{ display:none; flex-direction:column; align-items:center; text-align:center; padding:40px 0; }
.form-success.show{ display:flex; }
.form-success .check{ width:56px; height:56px; border-radius:50%; background:var(--accent-dim); border:1px solid var(--accent-line); display:flex; align-items:center; justify-content:center; color:var(--accent); margin-bottom:18px; }
.form-success h3{ font-size:21px; }
.form-success p{ margin-top:10px; color:var(--muted); font-size:15px; max-width:320px; }
@media(max-width:780px){ .cta-grid{ grid-template-columns:1fr; } .cta-left{ border-right:0; border-bottom:1px solid var(--line); padding:40px 32px; } .form-wrap{ padding:40px 32px; } .form-grid{ grid-template-columns:1fr; } }

/* ============================================================ FOOTER */
.colophon{ border-top:1px solid var(--line); padding:64px 0 40px; }
.colo-top{ display:grid; grid-template-columns:1.7fr 1fr 1fr; gap:40px; padding-bottom:44px; border-bottom:1px solid var(--line); }
.colo-brand{ font-size:24px; font-weight:700; letter-spacing:.01em; }
.colo-brand .dot{ color:var(--accent); }
.colo-top p{ margin-top:16px; color:var(--muted); font-size:14.5px; max-width:360px; line-height:1.6; }
.colo-col h4{ font-family:var(--mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--faint); font-weight:500; margin-bottom:16px; }
.colo-col a{ display:block; color:var(--ink-2); font-size:14.5px; padding:5px 0; transition:color .2s; }
.colo-col a:hover{ color:var(--accent); }
.colo-bottom{ padding-top:28px; display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap; }
.colo-bottom span{ font-family:var(--mono); font-size:11.5px; letter-spacing:.04em; color:var(--faint); }
@media(max-width:760px){ .colo-top{ grid-template-columns:1fr 1fr; } .colo-top > div:first-child{ grid-column:1/-1; } }

/* ============================================================ RICHER DATA + SCROLL ANIMATIONS */
/* sparkline draws itself in (driven by JS timer, same as the bars — robust) */
.spark-line{ stroke-dasharray:1; stroke-dashoffset:1; transition:stroke-dashoffset 1.4s cubic-bezier(.4,.55,.2,1) .15s; }

/* competitive matrix rows slide in when the doc scrolls into view (transition = end-state always applies) */
.matrix tbody tr{ opacity:0; transform:translateY(8px); transition:opacity .55s cubic-bezier(.2,.7,.2,1), transform .55s cubic-bezier(.2,.7,.2,1); }
.doc.seen .matrix tbody tr{ opacity:1; transform:none; }
.doc.seen .matrix tbody tr:nth-child(2){ transition-delay:.08s; }
.doc.seen .matrix tbody tr:nth-child(3){ transition-delay:.16s; }
.doc.seen .matrix tbody tr:nth-child(4){ transition-delay:.24s; }
.doc.seen .matrix tbody tr:nth-child(5){ transition-delay:.32s; }

/* passport cells fade up with the doc */
.doc-passport .cell{ opacity:0; transform:translateY(6px); transition:opacity .5s ease, transform .5s ease; }
.doc.seen .doc-passport .cell{ opacity:1; transform:none; }
.doc.seen .doc-passport .cell:nth-child(2){ transition-delay:.06s; }
.doc.seen .doc-passport .cell:nth-child(3){ transition-delay:.12s; }
.doc.seen .doc-passport .cell:nth-child(4){ transition-delay:.18s; }

/* direction field chips pop in on panel render (base stays visible if animation can't run) */
.field{ animation:chipIn .45s ease; }
@keyframes chipIn{ from{ opacity:0; transform:translateY(5px) scale(.97); } to{ opacity:1; transform:none; } }

/* subtle hover lift on workflow steps */
.step{ transition:background .25s ease; }
.step:hover{ background:var(--hover); }

@media (prefers-reduced-motion: reduce){
  .matrix tbody tr,
  .doc-passport .cell{ opacity:1; transform:none; transition:none; }
  .spark-line{ stroke-dasharray:none; stroke-dashoffset:0; transition:none; }
  .field{ animation:none; }
}

/* ============================================================ COOKIE BANNER */
.colo-legal{ display:flex; gap:20px; flex-wrap:wrap; }
.colo-legal a{ font-family:var(--mono); font-size:11.5px; letter-spacing:.03em; color:var(--faint); transition:color .2s; }
.colo-legal a:hover{ color:var(--accent); }

.cookie{
  position:fixed; left:0; right:0; bottom:0; z-index:200;
  padding:16px var(--pad);
  background:var(--nav-bg);
  backdrop-filter:blur(16px) saturate(140%); -webkit-backdrop-filter:blur(16px) saturate(140%);
  border-top:1px solid var(--line-2);
  box-shadow:0 -18px 40px -30px rgba(11,16,32,.4);
  transform:translateY(120%); transition:transform .55s cubic-bezier(.2,.7,.2,1);
}
.cookie.show{ transform:none; }
.cookie-inner{ max-width:var(--wrap); margin:0 auto; display:flex; align-items:center; gap:28px; }
.cookie-txt{ font-size:14px; color:var(--ink-2); max-width:720px; line-height:1.5; }
.cookie-txt a{ color:var(--accent); text-decoration:underline; text-underline-offset:2px; }
.cookie-actions{ margin-left:auto; display:flex; gap:12px; flex-shrink:0; }
.cookie .btn{ padding:10px 18px; font-size:14px; }
@media(max-width:720px){
  .cookie-inner{ flex-direction:column; align-items:flex-start; gap:14px; }
  .cookie-actions{ margin-left:0; width:100%; }
  .cookie-actions .btn{ flex:1; justify-content:center; }
}

/* ============================================================ LEGAL / DOC PAGES */
.legal-nav{
  position:sticky; top:0; z-index:60; height:64px;
  background:var(--nav-bg); backdrop-filter:blur(14px) saturate(140%); -webkit-backdrop-filter:blur(14px) saturate(140%);
  border-bottom:1px solid var(--line);
}
.legal-nav .wrap{ height:100%; display:flex; align-items:center; gap:20px; }
.legal-back{ display:inline-flex; align-items:center; gap:8px; font-family:var(--mono); font-size:12.5px; letter-spacing:.02em; color:var(--muted); transition:color .2s, gap .2s; white-space:nowrap; }
.legal-back:hover{ color:var(--accent); gap:11px; }
.legal-back svg{ width:15px; height:15px; }
.legal-nav .nav-brand{ margin-left:4px; }
.legal-nav .right{ margin-left:auto; display:flex; align-items:center; gap:14px; }

.legal{ padding:56px 0 96px; }
.legal .wrap{ max-width:840px; }
.legal-head{ margin-bottom:46px; padding-bottom:30px; border-bottom:1px solid var(--line); }
.legal-head .eyebrow{ margin-bottom:16px; }
.legal-head h1{ font-size:clamp(1.9rem,3.6vw,2.7rem); letter-spacing:-0.03em; }
.legal-head .meta{ margin-top:18px; font-family:var(--mono); font-size:12px; letter-spacing:.04em; color:var(--faint); }
.legal-toc{ margin:0 0 8px; padding:18px 22px; background:var(--panel); border:1px solid var(--line); border-radius:12px; }
.legal-toc .t{ font-family:var(--mono); font-size:10.5px; letter-spacing:.14em; text-transform:uppercase; color:var(--faint); margin-bottom:12px; }
.legal-toc ol{ margin:0; padding-left:20px; columns:2; column-gap:36px; }
.legal-toc li{ margin-bottom:8px; }
.legal-toc a{ color:var(--ink-2); font-size:14px; transition:color .2s; }
.legal-toc a:hover{ color:var(--accent); }
.legal-body{ }
.legal-body section{ margin-top:40px; scroll-margin-top:84px; }
.legal-body h2{ font-size:20px; line-height:1.25; display:flex; gap:12px; align-items:baseline; }
.legal-body h2 .n{ color:var(--accent); font-family:var(--mono); font-size:14px; flex:none; }
.legal-body p{ color:var(--ink-2); font-size:16px; line-height:1.72; margin:14px 0 0; }
.legal-body ul{ margin:14px 0 0; padding:0; list-style:none; }
.legal-body li{ position:relative; padding-left:24px; color:var(--ink-2); font-size:15.5px; line-height:1.6; margin-top:10px; }
.legal-body li::before{ content:""; position:absolute; left:3px; top:9px; width:7px; height:7px; border:1.5px solid var(--accent); border-radius:2px; }
.fill{ font-family:var(--mono); font-size:.9em; background:var(--accent-dim); color:var(--accent); padding:1px 7px; border-radius:5px; border:1px dashed var(--accent-line); white-space:nowrap; }
.legal-note{ margin-top:34px; padding:18px 22px; background:var(--panel); border:1px solid var(--line); border-left:2px solid var(--accent); border-radius:10px; }
.legal-note p{ margin:0; font-size:14.5px; color:var(--muted); }
.legal-foot{ margin-top:60px; padding-top:28px; border-top:1px solid var(--line); display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap; }
.legal-foot span, .legal-foot a{ font-family:var(--mono); font-size:11.5px; letter-spacing:.04em; color:var(--faint); }
.legal-foot a:hover{ color:var(--accent); }
@media(max-width:600px){ .legal-toc ol{ columns:1; } }

/* ===== Mobile horizontal-overflow hardening (added) ===== */
html { overflow-x: hidden; }
.hero, .cta { overflow: hidden; }              /* обрезаем декоративные glow, чтобы не вылезали вбок */
img, video { max-width: 100%; height: auto; }
@media (max-width: 760px) {
  .console-tabs, .doc-tabs, .sla-tabs { overflow-x: auto; -webkit-overflow-scrolling: touch; }
}
@media (max-width: 600px) {
  .nav-inner { gap: 12px; }
  .nav-brand .badge { display: none; }         /* длинный бейдж рвал фикс-шапку на мобиле */
  .nav-cta { gap: 10px; }
  .nav-cta .btn-primary { padding: 10px 14px; font-size: 13px; }
}
