/* ============================================================
   ТЕРРА — улучшенная главная · слой-надстройка (грузится ПОСЛЕ styles.css)
   Фокус: ритм, чистая типошкала, тише эмбиент, 3 направления героя,
   единая полоса пруфа, лого-стрип, full-bleed контраст-секция.
   ============================================================ */

:root{
  /* чистая модульная типошкала (вместо дробных 14.5/13.5/12.5) */
  --fs-eyebrow: 13px;
  --fs-cap:     14px;
  --fs-body:    16px;
  --fs-lead:    19px;
  --fs-h4:      20px;
  --fs-h3:      24px;
  --fs-h2:      clamp(30px, 4vw, 46px);
  --fs-display: clamp(40px, 6.4vw, 72px);
  --tracking-tight: -.03em;
}

/* ---------- тише эмбиент: меньше пятен, тоньше зерно ---------- */
body::after{ opacity:.02; }
[data-theme="light"] body::before{
  background:
    radial-gradient(46% 40% at 10% -2%, color-mix(in oklab,var(--secondary) 7%, transparent) 0%, transparent 62%),
    radial-gradient(40% 44% at 96% 0%, color-mix(in oklab,var(--brand) 5%, transparent) 0%, transparent 64%);
}

/* ---------- ритм: единый вертикальный шаг, аккуратные хедеры ---------- */
.section{ padding:104px 0; }
.section-head{ margin-bottom:52px; max-width:760px; }
.section-title{ font-size:var(--fs-h2); letter-spacing:var(--tracking-tight); text-wrap:balance; }
.section-sub{ font-size:var(--fs-lead); text-wrap:pretty; }
.eyebrow{ font-size:var(--fs-eyebrow); }

/* единообразие текста карточек по новой шкале */
.cell p,.ai-card p,.case p,.ind p,.layer p,.why p,.modgrid li{ font-size:var(--fs-cap); }
.cell h3,.ai-card h3{ font-size:var(--fs-h4); }
.case h3{ font-size:var(--fs-h3); }

/* ============================================================
   HERO — переработанный
   ============================================================ */
.hero{ padding:148px 0 64px; }
.hero h1{ font-size:var(--fs-display); letter-spacing:-.035em; line-height:1.02; }
.hero-sub{ font-size:var(--fs-lead); max-width:48ch; }

/* тоньше фоновая сетка */
.hero-grid{ opacity:.4; background-size:64px 64px; }

/* --- общий каркас --- */
.hero-inner{ gap:54px; }

/* продуктовый визуал: реальный скрин в «окне браузера» */
.hero-shot{
  position:relative; border-radius:16px; overflow:hidden;
  border:1px solid var(--border);
  box-shadow:0 40px 90px -40px rgba(20,18,45,.45), 0 2px 0 rgba(255,255,255,.5) inset;
  background:var(--elevated);
  transform:perspective(1600px) rotateY(-7deg) rotateX(2deg);
  transition:transform .6s var(--ease);
}
.hero-shot:hover{ transform:perspective(1600px) rotateY(-3deg) rotateX(1deg); }
.hero-shot .bar{
  display:flex; align-items:center; gap:7px; padding:11px 14px;
  border-bottom:1px solid var(--hairline); background:color-mix(in oklab,var(--bg-2) 70%,transparent);
}
.hero-shot .bar i{ width:11px; height:11px; border-radius:50%; background:var(--muted-2); opacity:.5; }
.hero-shot .bar .addr{
  margin-left:10px; font-size:12px; color:var(--muted); flex:1;
  background:var(--card); border:1px solid var(--hairline); border-radius:7px;
  padding:5px 12px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}
.hero-shot img{ display:block; width:100%; height:auto; }
.hero-shot .live{
  position:absolute; top:64px; right:14px; display:flex; align-items:center; gap:7px;
  font-size:12px; font-weight:600; color:#fff; background:rgba(10,12,20,.6);
  backdrop-filter:blur(6px); border-radius:999px; padding:6px 12px;
}
.hero-shot .live .pulse{ width:7px;height:7px;border-radius:50%;background:var(--growth);
  box-shadow:0 0 0 0 color-mix(in oklab,var(--growth) 60%,transparent); animation:pulse 2s infinite; }
@keyframes pulse{0%{box-shadow:0 0 0 0 color-mix(in oklab,var(--growth) 55%,transparent)}70%{box-shadow:0 0 0 10px transparent}100%{box-shadow:0 0 0 0 transparent}}

/* --- единая полоса пруфа (заменяет разбросанные плавашки) --- */
.hero-proof{ margin-top:46px; }
.proof-bar{
  display:grid; grid-template-columns:repeat(4,1fr);
  border:1px solid var(--border); border-radius:var(--radius);
  background:color-mix(in oklab,var(--card) 70%,transparent);
  backdrop-filter:blur(10px); overflow:hidden;
}
.proof-bar .pb{ padding:22px 24px; border-left:1px solid var(--hairline); }
.proof-bar .pb:first-child{ border-left:0; }
.proof-bar .pb .v{
  font-size:clamp(26px,3vw,36px); font-weight:800; letter-spacing:-.02em; line-height:1;
  background:linear-gradient(120deg,var(--brand),var(--violet) 55%,var(--secondary));
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.proof-bar .pb .l{ font-size:13px; color:var(--muted); margin-top:8px; }

/* --- лого-стрип клиентов/партнёров (плейсхолдеры, монохром) --- */
.hero-logos{ margin-top:30px; }
.logo-strip{ display:flex; flex-wrap:wrap; align-items:center; gap:14px 34px; }
.logo-strip .lbl{ font-size:12px; letter-spacing:.06em; text-transform:uppercase; color:var(--muted-2); margin-right:6px; }
.logo-ph{
  display:inline-flex; align-items:center; gap:9px;
  font-weight:700; font-size:15px; letter-spacing:-.01em; color:var(--muted);
  opacity:.62; filter:grayscale(1); transition:.25s;
}
.logo-ph:hover{ opacity:1; filter:grayscale(0); color:var(--text); }
.logo-ph svg{ width:22px; height:22px; }

/* ============================================================
   ПЕРЕКЛЮЧАТЕЛЬ НАПРАВЛЕНИЙ ГЕРОЯ (Tweaks: data-hero)
   product (по умолчанию) | editorial | aurora
   ============================================================ */
.hero-visual--product, .hero-visual--aurora{ display:none; }

/* product: сплит — копия слева, реальный скрин справа */
body[data-hero="product"] .hero-visual--product{ display:block; }
body[data-hero="product"] .hero-inner{ grid-template-columns:1.02fr 1.18fr; }

/* aurora: исходная генеративная иллюстрация + плавающие карточки */
body[data-hero="aurora"] .hero-visual--aurora{ display:block; position:relative; height:440px; }
body[data-hero="aurora"] .hero-proof{ display:none; }   /* в этом режиме цифры — на плавашках */
body[data-hero="aurora"] .hero-logos{ margin-top:42px; }

/* editorial: центрированная подача, скрин — широкой полосой под копией */
body[data-hero="editorial"] .hero-inner{ grid-template-columns:1fr; text-align:center; justify-items:center; }
body[data-hero="editorial"] .hero-copy{ max-width:920px; }
body[data-hero="editorial"] .hero-sub{ max-width:62ch; margin-left:auto; margin-right:auto; }
body[data-hero="editorial"] .hero-cta,
body[data-hero="editorial"] .hero-trust{ justify-content:center; }
body[data-hero="editorial"] .hero-badge{ margin-left:auto; margin-right:auto; }
body[data-hero="editorial"] .hero-visual--product{ display:block; width:100%; margin-top:8px; }
body[data-hero="editorial"] .hero-shot{ transform:none; }
body[data-hero="editorial"] .hero-shot:hover{ transform:translateY(-4px); }

/* ============================================================
   FULL-BLEED контраст-секция (SC TERRA) — пауза в ритме
   тёмная полоса даже в светлой теме
   ============================================================ */
#scterra{
  background:
    radial-gradient(80% 120% at 12% 0%, color-mix(in oklab,var(--violet) 26%, transparent), transparent 52%),
    radial-gradient(70% 120% at 100% 100%, color-mix(in oklab,var(--secondary) 20%, transparent), transparent 55%),
    #0B0A11;
  color:#EDEAF2;
  border-top:1px solid rgba(255,255,255,.08);
  border-bottom:1px solid rgba(255,255,255,.08);
  margin-top:8px;
}
#scterra .section-title{ color:#fff; }
#scterra .section-sub,#scterra .role li,#scterra .frame-cap{ color:#A39CB0; }
#scterra .grad-text{ background:linear-gradient(120deg,#fff,#FFC2BE 50%,#FF8095); -webkit-background-clip:text; background-clip:text; color:transparent; }
#scterra .panel,#scterra .metric,#scterra .frame{ background:rgba(255,255,255,.04); border-color:rgba(255,255,255,.10); }
#scterra .flow .step{ background:rgba(255,255,255,.05); border-color:rgba(255,255,255,.12); color:#EDEAF2; }
#scterra .role{ background:rgba(255,255,255,.04); border-color:rgba(255,255,255,.10); }
#scterra .role h5{ color:#fff; }
#scterra .metric .v{ background:linear-gradient(120deg,#fff,#FFC2BE); -webkit-background-clip:text; background-clip:text; color:transparent; }
#scterra .frame-cap{ background:#13121A; border-color:rgba(255,255,255,.12); }
#scterra .frame-mobile{ border-color:#000; }

/* ============================================================
   мелкая полировка
   ============================================================ */
/* единый «тихий» hover: меньше прыжков */
.bento .cell:hover,.ai-card:hover,.case:hover,.ind:hover{ transform:translateY(-3px); }

/* тех-стек: убрать слишком пёстрые точки → нейтральнее */
.tech span{ background:var(--muted-2); }
.tech:hover span{ background:var(--primary); }

/* отзывы: звёзды нейтральнее (золото вместо зелёного) */
.quote .stars{ color:#E8A93C; }

/* новая 8-я ячейка bento — свой цвет иконки */
.bento .cell:nth-child(8) .ic{ background:color-mix(in oklab,#2E6FF2 14%,transparent); color:#2E6FF2; }

/* фикс переполнения KPI в карточке кейса (длинные значения) */
.case .kpis .v{ font-size:clamp(17px,1.5vw,21px); word-break:break-word; }

/* ---------- Широкая панель-ссылка «Все проекты» ---------- */
.allprojects{ margin-top:46px; }
.allprojects-card{
  display:flex; align-items:center; justify-content:space-between; gap:32px; flex-wrap:wrap;
  padding:38px 44px; border-radius:var(--radius-lg); overflow:hidden; position:relative;
  border:1px solid rgba(255,255,255,.10); cursor:pointer; text-decoration:none;
  background:
    radial-gradient(70% 130% at 8% 0%, color-mix(in oklab,var(--violet) 30%, transparent), transparent 55%),
    radial-gradient(60% 130% at 100% 100%, color-mix(in oklab,var(--secondary) 24%, transparent), transparent 58%),
    #0B0A11;
  transition:transform .3s var(--ease), box-shadow .3s var(--ease);
}
.allprojects-card:hover{ transform:translateY(-3px); box-shadow:0 30px 60px -28px rgba(20,10,40,.7); }
.allprojects-card .ap-left{ display:flex; align-items:center; gap:24px; min-width:0; }
.ap-ic{
  flex:none; width:60px; height:60px; border-radius:16px; display:grid; place-items:center;
  background:rgba(255,255,255,.07); border:1px solid rgba(255,255,255,.14); color:#fff;
}
.ap-ic svg{ width:28px; height:28px; }
.ap-text .ap-eyebrow{ font-size:12px; letter-spacing:.08em; text-transform:uppercase; color:#A39CB0; margin-bottom:7px; }
.ap-text h3{ font-size:clamp(22px,2.4vw,30px); letter-spacing:-.02em; color:#fff; line-height:1.1; text-wrap:balance; }
.ap-text p{ font-size:14px; color:#A39CB0; margin-top:8px; max-width:54ch; }
.ap-cta{
  flex:none; display:inline-flex; align-items:center; gap:11px; padding:15px 26px; border-radius:999px;
  font-weight:600; font-size:15px; color:#0B0A11; background:#fff;
  transition:gap .25s var(--ease);
}
.allprojects-card:hover .ap-cta{ gap:16px; }
.ap-cta svg{ width:19px; height:19px; }
@media (max-width:680px){
  .allprojects-card{ padding:30px 26px; }
  .ap-cta{ width:100%; justify-content:center; }
}

/* ---------- Отзывы · слайдер ---------- */.treviews-head{ display:flex; align-items:flex-end; justify-content:space-between; gap:24px; flex-wrap:wrap; margin-bottom:40px; }
.treviews-head .section-title{ margin-bottom:0; }
.tnav{ display:flex; gap:10px; flex:none; }
.tbtn{ width:48px; height:48px; border-radius:50%; border:1px solid var(--border); background:var(--card);
  display:grid; place-items:center; color:var(--text); transition:.2s var(--ease); }
.tbtn:hover:not(:disabled){ border-color:var(--primary); color:var(--primary); transform:translateY(-2px); }
.tbtn:disabled{ opacity:.38; cursor:default; color:var(--muted); }
.tbtn svg{ width:20px; height:20px; }
.tcarousel{ overflow:hidden; }
.tcarousel-track{ display:flex; gap:var(--gap); transition:transform .55s var(--ease); will-change:transform; }
.tcarousel-track .quote{ flex:0 0 calc((100% - var(--gap)) / 2); margin:0; }
.tcarousel-track .quote blockquote{ text-wrap:pretty; }
.tdots{ display:flex; gap:8px; justify-content:center; margin-top:30px; }
.tdot{ width:8px; height:8px; border-radius:50%; background:var(--border); border:0; cursor:pointer; padding:0; transition:.3s var(--ease); }
.tdot:hover{ background:var(--muted); }
.tdot.active{ background:var(--primary); width:26px; border-radius:5px; }
@media (max-width:760px){ .tcarousel-track .quote{ flex-basis:100%; } }

/* ---------- Технологии · сворачиваемый стек (аккордеон) ---------- */
.stack-col{ display:flex; flex-direction:column; }
.stack-panel{
  flex:1; margin-top:24px; display:flex; flex-direction:column;
  border:1px solid var(--border); border-radius:var(--radius-lg); background:var(--card);
  padding:4px 24px 22px;
}
.stack-groups{ display:flex; flex-direction:column; }
.stack-group{ border-bottom:1px solid var(--hairline); }
.stack-group:last-of-type{ border-bottom:0; }
.sg-head{
  width:100%; display:flex; align-items:center; justify-content:space-between; gap:14px;
  padding:16px 2px; background:none; cursor:pointer; text-align:left;
}
.sg-head .sg-label{
  display:flex; align-items:center; gap:9px; margin:0;
  font-size:12.5px; letter-spacing:.06em; text-transform:uppercase; color:var(--text); font-weight:600;
}
.sg-head .sg-label::before{ content:""; width:16px; height:1.5px; background:var(--primary); opacity:.75; }
.sg-right{ display:flex; align-items:center; gap:12px; color:var(--muted-2); }
.sg-count{ font-size:12px; font-variant-numeric:tabular-nums; }
.chev{ width:18px; height:18px; color:var(--muted); transition:transform .3s var(--ease); }
.stack-group.open .chev{ transform:rotate(180deg); }
.sg-body{ overflow:hidden; max-height:0; transition:max-height .4s var(--ease); }
.stack-group.open .sg-body{ max-height:360px; }
.sg-body .stack{ margin-top:0; padding:2px 0 18px; }
.tech.ru{ border-color:color-mix(in oklab,var(--growth) 36%,var(--border)); }
.tech.ru span{ background:var(--growth); }
.stack-legend{
  display:flex; align-items:center; gap:8px; margin-top:auto; padding-top:18px;
  font-size:12.5px; color:var(--muted); border-top:1px solid var(--hairline);
}
.stack-legend i{ width:8px; height:8px; border-radius:50%; background:var(--growth); flex:none; }

/* правый блок «Почему» — заполняет высоту вровень с левым */
.why-col{ display:flex; flex-direction:column; }
.why-col > .grid{ flex:1; grid-auto-rows:1fr; margin-top:24px !important; }
.why{ height:100%; align-items:center; }

/* ---------- Процесс · улучшенный горизонтальный степпер ---------- */.timeline{ position:relative; gap:0; }
.timeline::before{
  content:""; position:absolute; top:23px; left:8%; right:8%; height:2px;
  background:linear-gradient(90deg,var(--brand),var(--violet) 50%,var(--secondary));
  opacity:.45;
}
.tl-step{ text-align:center; padding:0 14px; }
.tl-step::before{
  position:relative; z-index:1; top:auto; left:auto;
  margin:0 auto 18px; width:48px; height:48px; font-size:16px;
  border:4px solid var(--bg);
  box-shadow:0 8px 18px -8px color-mix(in oklab,var(--primary) 60%,transparent);
  transition:transform .25s var(--ease), box-shadow .25s var(--ease);
}
.tl-step::after{ display:none; }   /* убираем посегментную линию — есть общая градиентная */
.tl-step:hover::before{ transform:translateY(-3px) scale(1.07); box-shadow:0 14px 26px -10px color-mix(in oklab,var(--primary) 70%,transparent); }
.tl-step h4{ font-size:15px; margin-bottom:6px; }
.tl-step p{ font-size:13px; text-wrap:balance; }
@media (max-width:980px){
  .timeline{ grid-template-columns:repeat(2,1fr); gap:26px 16px; }
  .timeline::before{ display:none; }
  .tl-step{ text-align:left; padding:0; }
  .tl-step::before{ margin:0 0 14px; }
}

/* ---------- Платформа ARL · слои — равная высота с панелью справа ---------- */
.layers{ height:100%; }
@media (min-width:601px){
  .layers{ display:flex; flex-direction:column; gap:14px; }
  .layer{ flex:1; align-items:center; }     /* карточки делят высоту колонки поровну, контент по центру */
}
.layer .tags{ display:flex; flex-wrap:wrap; gap:7px; margin-top:13px; }
.layer .tags span{
  font-size:11.5px; color:var(--muted); line-height:1;
  border:1px solid var(--border); border-radius:8px; padding:5px 9px;
  background:color-mix(in oklab,var(--bg-2) 55%,transparent);
}
.layer:hover .n{ box-shadow:0 8px 20px -8px color-mix(in oklab,var(--primary) 60%,transparent); }

/* ---------- ERP ARL · карта модулей (улучшенная панель) ---------- */
.modpanel{ padding:28px; }
.modpanel-head{ display:flex; align-items:flex-start; justify-content:space-between; gap:18px; margin-bottom:22px; }
.modpanel-head h4{ font-size:var(--fs-h3); letter-spacing:-.02em; }
.modpanel-head p{ color:var(--muted); font-size:14px; margin-top:7px; max-width:42ch; }
.modcount{
  flex:none; display:flex; flex-direction:column; align-items:center; justify-content:center;
  width:64px; height:64px; border-radius:18px; line-height:1;
  background:color-mix(in oklab,var(--primary) 12%,transparent);
  border:1px solid color-mix(in oklab,var(--primary) 28%,transparent);
}
.modcount b{ font-size:26px; font-weight:800; letter-spacing:-.03em; color:var(--primary); }
.modcount span{ font-size:10px; letter-spacing:.06em; text-transform:uppercase; color:var(--primary); opacity:.8; margin-top:2px; }

.modules{ display:grid; grid-template-columns:repeat(3,1fr); gap:10px; }
.mod{
  display:flex; flex-direction:column; gap:11px; padding:15px 14px;
  border:1px solid var(--border); border-radius:14px;
  background:color-mix(in oklab,var(--bg-2) 55%,transparent);
  transition:transform .25s var(--ease), border-color .25s, box-shadow .25s, background .25s;
}
.mod:hover{ transform:translateY(-3px); border-color:color-mix(in oklab,var(--primary) 38%,var(--border)); box-shadow:var(--shadow-lg); background:var(--card); }
.mod .mi{ width:36px; height:36px; border-radius:10px; display:grid; place-items:center; }
.mod .mi svg{ width:19px; height:19px; }
.mod b{ font-size:13.5px; font-weight:600; letter-spacing:-.01em; line-height:1.25; color:var(--text); }
/* многоцветная иконография — как в bento */
.mod:nth-child(6n+1) .mi{ background:color-mix(in oklab,#E11D3A 13%,transparent); color:#E11D3A; }
.mod:nth-child(6n+2) .mi{ background:color-mix(in oklab,#2E6FF2 13%,transparent); color:#2E6FF2; }
.mod:nth-child(6n+3) .mi{ background:color-mix(in oklab,#E8830C 15%,transparent); color:#E8830C; }
.mod:nth-child(6n+4) .mi{ background:color-mix(in oklab,#0A86C9 13%,transparent); color:#0A86C9; }
.mod:nth-child(6n+5) .mi{ background:color-mix(in oklab,#1A8F45 13%,transparent); color:#1A8F45; }
.mod:nth-child(6n+6) .mi{ background:color-mix(in oklab,#7C3AED 14%,transparent); color:#7C3AED; }
.modnote{
  display:flex; align-items:center; gap:10px; margin-top:16px; padding-top:16px;
  border-top:1px solid var(--hairline); font-size:13px; color:var(--muted);
}
.modnote svg{ width:17px; height:17px; color:var(--primary); flex:none; }
.modnote b{ color:var(--text); font-weight:600; }
@media (max-width:600px){ .modules{ grid-template-columns:repeat(2,1fr); } }

/* в тёмной полосе SC TERRA модули не используются, но на всякий — корректный фон */
#scterra .mod{ background:rgba(255,255,255,.04); border-color:rgba(255,255,255,.10); }

/* контейнер чуть шире для воздуха на больших экранах */
@media (min-width:1400px){ :root{ --maxw:1240px; } }

/* адаптив героя */
@media (max-width:980px){
  body[data-hero="product"] .hero-inner{ grid-template-columns:1fr; }
  /* копия должна идти ПЕРЕД скрином на узких экранах (перебиваем order:-1 из styles.css) */
  body[data-hero="product"] .hero-visual--product,
  body[data-hero="editorial"] .hero-visual--product{ order:0; }
  .hero-shot{ transform:none; }
  .proof-bar{ grid-template-columns:repeat(2,1fr); }
  .proof-bar .pb:nth-child(3){ border-left:0; }
  .proof-bar .pb:nth-child(odd){ border-left:0; }
  .proof-bar .pb{ border-top:1px solid var(--hairline); }
  .proof-bar .pb:nth-child(-n+2){ border-top:0; }
}
@media (max-width:600px){
  .proof-bar{ grid-template-columns:1fr; }
  .proof-bar .pb{ border-left:0; border-top:1px solid var(--hairline); }
  .proof-bar .pb:first-child{ border-top:0; }
}

/* ============================================================
   ВНУТРЕННИЕ СТРАНИЦЫ (общий слой)
   ============================================================ */
.pp-hero{ padding:148px 0 8px; }
.pp-hero .crumbs{ display:flex; align-items:center; gap:9px; font-size:13px; color:var(--muted); margin-bottom:20px; flex-wrap:wrap; }
.pp-hero .crumbs a{ color:var(--muted); text-decoration:none; }
.pp-hero .crumbs a:hover{ color:var(--primary); }
.pp-hero .crumbs svg{ width:14px; height:14px; opacity:.5; }
.pp-hero h1{ font-size:clamp(36px,5vw,60px); letter-spacing:-.035em; line-height:1.04; margin-bottom:18px; text-wrap:balance; }
.pp-hero .lead{ font-size:var(--fs-lead); color:var(--muted); max-width:62ch; text-wrap:pretty; }
.pp-secondary-note{ display:inline-flex; align-items:center; gap:9px; margin-bottom:18px; font-size:12.5px; letter-spacing:.04em;
  text-transform:uppercase; color:var(--muted-2); border:1px solid var(--border); border-radius:999px; padding:7px 14px; background:var(--card); }
.pp-secondary-note::before{ content:""; width:7px; height:7px; border-radius:50%; background:var(--muted-2); }

.pp-stats{ display:flex; flex-wrap:wrap; gap:14px 40px; margin-top:30px; }
.pp-stats .s b{ font-size:30px; font-weight:800; letter-spacing:-.02em; white-space:nowrap;
  background:linear-gradient(120deg,var(--brand),var(--violet) 55%,var(--secondary));
  -webkit-background-clip:text; background-clip:text; color:transparent; }
.pp-stats .s span{ display:block; font-size:13px; color:var(--muted); margin-top:3px; }

.pp-cta-row{ display:flex; flex-wrap:wrap; gap:14px; margin-top:32px; }

/* проза / контентные секции */
.prose{ max-width:760px; }
.prose p{ font-size:var(--fs-body); color:var(--muted); line-height:1.7; margin:0 0 18px; text-wrap:pretty; }
.prose p strong, .prose strong{ color:var(--text); font-weight:600; }
.lead-2{ font-size:var(--fs-lead); color:var(--text); line-height:1.6; margin-bottom:22px; text-wrap:pretty; }

/* двухколоночный сплит для деталки */
.split{ display:grid; grid-template-columns:1.1fr .9fr; gap:56px; align-items:start; }
@media (max-width:920px){ .split{ grid-template-columns:1fr; gap:36px; } }

/* список фич */
.featlist{ display:grid; gap:14px; }
.featlist .fi{ display:flex; gap:14px; align-items:flex-start; }
.featlist .fi .chk{ flex:none; width:26px; height:26px; border-radius:8px; display:grid; place-items:center; margin-top:1px;
  background:color-mix(in oklab,var(--growth) 14%,transparent); color:var(--growth); }
.featlist .fi .chk svg{ width:15px; height:15px; }
.featlist .fi h4{ font-size:15px; font-weight:600; margin-bottom:3px; }
.featlist .fi p{ font-size:13.5px; color:var(--muted); line-height:1.55; }

/* карточки-хабы (продукты/услуги) */
.hubgrid{ display:grid; grid-template-columns:repeat(2,1fr); gap:var(--gap); }
@media (max-width:760px){ .hubgrid{ grid-template-columns:1fr; } }
.hubcard{ display:flex; flex-direction:column; padding:30px; border:1px solid var(--border); border-radius:var(--radius-lg);
  background:var(--card); text-decoration:none; color:var(--text); transition:transform .28s var(--ease), border-color .28s, box-shadow .28s; position:relative; }
.hubcard:hover{ transform:translateY(-4px); border-color:color-mix(in oklab,var(--primary) 35%,var(--border)); box-shadow:var(--shadow-lg); }
.hubcard .ic{ width:50px; height:50px; border-radius:13px; display:grid; place-items:center; margin-bottom:20px; }
.hubcard .ic svg{ width:25px; height:25px; }
.hubcard .tag{ position:absolute; top:26px; right:26px; font-size:11px; font-weight:600; letter-spacing:.04em; text-transform:uppercase;
  color:var(--primary); background:color-mix(in oklab,var(--primary) 11%,transparent); border-radius:999px; padding:5px 11px; }
.hubcard h3{ font-size:21px; letter-spacing:-.02em; margin-bottom:10px; }
.hubcard p{ font-size:14px; color:var(--muted); line-height:1.6; margin-bottom:20px; flex:1; text-wrap:pretty; }
.hubcard .more{ display:inline-flex; align-items:center; gap:8px; font-weight:600; font-size:14px; color:var(--primary); }
.hubcard .more svg{ width:17px; height:17px; transition:transform .25s var(--ease); }
.hubcard:hover .more svg{ transform:translateX(4px); }
.hubcard.is-secondary{ opacity:.92; }
.hubcard.is-secondary .ic{ background:var(--bg-2); color:var(--muted); }
.hubcard .ic.c-red{ background:color-mix(in oklab,#E11D3A 13%,transparent); color:#E11D3A; }
.hubcard .ic.c-blue{ background:color-mix(in oklab,#2E6FF2 13%,transparent); color:#2E6FF2; }
.hubcard .ic.c-violet{ background:color-mix(in oklab,#7C3AED 14%,transparent); color:#7C3AED; }
.hubcard .ic.c-cyan{ background:color-mix(in oklab,#0A86C9 13%,transparent); color:#0A86C9; }
.hubcard .ic.c-green{ background:color-mix(in oklab,#1A8F45 13%,transparent); color:#1A8F45; }
.hubcard .ic.c-amber{ background:color-mix(in oklab,#E8830C 15%,transparent); color:#E8830C; }

/* числовые слои/шаги для деталки СУБД */
.archlayers{ display:grid; gap:14px; }
.archrow{ display:flex; gap:18px; align-items:flex-start; padding:22px; border:1px solid var(--border); border-radius:var(--radius); background:var(--card); }
.archrow .num{ flex:none; width:40px; height:40px; border-radius:11px; display:grid; place-items:center; font-weight:800; font-size:16px; color:#fff;
  background:linear-gradient(135deg,var(--brand),var(--violet)); }
.archrow h4{ font-size:17px; margin-bottom:7px; letter-spacing:-.01em; }
.archrow p{ font-size:14px; color:var(--muted); line-height:1.6; }

/* блок «скачать документацию» */
.doclist{ display:grid; gap:12px; }
.docitem{ display:flex; align-items:center; gap:14px; padding:16px 20px; border:1px solid var(--border); border-radius:var(--radius);
  background:var(--card); text-decoration:none; color:var(--text); transition:.22s var(--ease); }
.docitem:hover{ border-color:var(--primary); transform:translateX(3px); }
.docitem .di-ic{ flex:none; width:38px; height:38px; border-radius:10px; display:grid; place-items:center;
  background:color-mix(in oklab,var(--secondary) 12%,transparent); color:var(--secondary); }
.docitem .di-ic svg{ width:19px; height:19px; }
.docitem b{ font-size:14.5px; font-weight:600; display:block; }
.docitem span{ font-size:12.5px; color:var(--muted); }
.docitem .arrow{ margin-left:auto; color:var(--muted); }

/* контактная страница */
.contact-grid{ display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:start; }
@media (max-width:920px){ .contact-grid{ grid-template-columns:1fr; gap:32px; } }
.field{ display:flex; flex-direction:column; gap:7px; margin-bottom:16px; }
.field label{ font-size:13px; font-weight:500; color:var(--text); }
.field input, .field textarea{ font:inherit; font-size:15px; padding:13px 15px; border:1px solid var(--border); border-radius:12px;
  background:var(--bg-2); color:var(--text); transition:.2s var(--ease); width:100%; }
.field input:focus, .field textarea:focus{ outline:none; border-color:var(--primary); background:var(--card); box-shadow:0 0 0 3px color-mix(in oklab,var(--primary) 14%,transparent); }
.field textarea{ resize:vertical; min-height:120px; }
.contact-info .ci-row{ display:flex; gap:16px; align-items:flex-start; padding:18px 0; border-bottom:1px solid var(--hairline); }
.contact-info .ci-row:last-child{ border-bottom:0; }
.contact-info .ci-ic{ flex:none; width:42px; height:42px; border-radius:11px; display:grid; place-items:center;
  background:color-mix(in oklab,var(--primary) 11%,transparent); color:var(--primary); }
.contact-info .ci-ic svg{ width:20px; height:20px; }
.contact-info .ci-row h4{ font-size:13px; color:var(--muted); font-weight:500; margin-bottom:4px; }
.contact-info .ci-row a, .contact-info .ci-row p{ font-size:16px; color:var(--text); text-decoration:none; font-weight:500; line-height:1.5; }
.contact-info .ci-row a:hover{ color:var(--primary); }
.map-wrap{ margin-top:18px; border-radius:var(--radius-lg); overflow:hidden; border:1px solid var(--border); height:340px; }
.map-wrap iframe{ width:100%; height:100%; border:0; display:block; filter:grayscale(.2); }
.form-ok{ display:none; padding:22px; border-radius:var(--radius); background:color-mix(in oklab,var(--growth) 12%,transparent);
  border:1px solid color-mix(in oklab,var(--growth) 35%,transparent); color:var(--text); font-size:15px; }

/* nav dropdown */
.nav-links .has-sub{ position:relative; }
.nav-links .submenu{ position:absolute; top:100%; left:50%; transform:translateX(-50%) translateY(8px);
  min-width:230px; padding:8px; background:var(--card); border:1px solid var(--border); border-radius:14px;
  box-shadow:var(--shadow-lg); opacity:0; visibility:hidden; transition:.2s var(--ease); z-index:60; }
.nav-links .has-sub:hover .submenu{ opacity:1; visibility:visible; transform:translateX(-50%) translateY(2px); }
.nav-links .submenu a{ display:block; padding:9px 12px; border-radius:9px; font-size:14px; color:var(--text); white-space:nowrap; }
.nav-links .submenu a:hover{ background:var(--bg-2); color:var(--primary); }
@media (max-width:860px){ .nav-links .submenu{ position:static; transform:none; opacity:1; visibility:visible; box-shadow:none; border:0; padding:4px 0 4px 14px; min-width:0; } }

/* ============================================================
   КАРТОЧКА РЕКВИЗИТОВ (страница контактов)
   ============================================================ */
.req-card{ border:1px solid var(--border); border-radius:var(--radius-lg); background:var(--card); overflow:hidden; }
.req-card .rc-head{ display:flex; align-items:center; gap:14px; padding:24px 28px; border-bottom:1px solid var(--hairline);
  background:color-mix(in oklab,var(--bg-2) 60%,transparent); }
.req-card .rc-head .rc-ic{ flex:none; width:44px; height:44px; border-radius:12px; display:grid; place-items:center;
  background:color-mix(in oklab,var(--primary) 11%,transparent); color:var(--primary); }
.req-card .rc-head .rc-ic svg{ width:22px; height:22px; }
.req-card .rc-head h3{ font-size:19px; letter-spacing:-.02em; }
.req-card .rc-head p{ font-size:13px; color:var(--muted); margin-top:2px; }
.req-card .rc-head .rc-copy{ margin-left:auto; }
.req-cols{ display:grid; grid-template-columns:repeat(3,1fr); gap:0; }
@media (max-width:860px){ .req-cols{ grid-template-columns:1fr 1fr; } }
@media (max-width:560px){ .req-cols{ grid-template-columns:1fr; } }
.req-col{ padding:24px 28px; border-left:1px solid var(--hairline); }
.req-col:first-child{ border-left:0; }
@media (max-width:860px){ .req-col:nth-child(odd){ border-left:0; } .req-col{ border-top:1px solid var(--hairline); } .req-col:nth-child(-n+2){ border-top:0; } }
@media (max-width:560px){ .req-col{ border-left:0; border-top:1px solid var(--hairline); } .req-col:first-child{ border-top:0; } }
.req-col h4{ font-size:12px; letter-spacing:.06em; text-transform:uppercase; color:var(--muted-2); margin-bottom:16px; }
.req-row{ margin-bottom:14px; }
.req-row:last-child{ margin-bottom:0; }
.req-row .k{ font-size:12.5px; color:var(--muted); margin-bottom:2px; }
.req-row .v{ font-size:14.5px; font-weight:500; color:var(--text); line-height:1.45; word-break:break-word; }
.req-row .v a{ color:var(--text); text-decoration:none; }
.req-row .v a:hover{ color:var(--primary); }
.req-codes{ display:grid; grid-template-columns:repeat(4,1fr); gap:14px 22px; padding:22px 28px; border-top:1px solid var(--hairline);
  background:color-mix(in oklab,var(--bg-2) 40%,transparent); }
@media (max-width:760px){ .req-codes{ grid-template-columns:repeat(2,1fr); } }
.req-codes .rc{ }
.req-codes .rc .k{ font-size:11px; letter-spacing:.05em; text-transform:uppercase; color:var(--muted-2); margin-bottom:3px; }
.req-codes .rc .v{ font-size:14px; font-weight:600; color:var(--text); font-variant-numeric:tabular-nums; }

/* ============================================================
   ОБЩИЕ СТИЛИ СТРАНИЦ УСЛУГ (xgrid, mgroup, scale-band, minicases)
   ============================================================ */
.xgrid{ display:grid; grid-template-columns:repeat(3,1fr); gap:var(--gap); }
@media (max-width:900px){ .xgrid{ grid-template-columns:1fr 1fr; } }
@media (max-width:600px){ .xgrid{ grid-template-columns:1fr; } }
.xcard{ padding:26px; border:1px solid var(--border); border-radius:var(--radius-lg); background:var(--card); transition:transform .25s var(--ease), border-color .25s, box-shadow .25s; }
.xcard:hover{ transform:translateY(-3px); border-color:color-mix(in oklab,var(--primary) 30%,var(--border)); box-shadow:var(--shadow-lg); }
.xcard .ic{ width:46px; height:46px; border-radius:12px; display:grid; place-items:center; margin-bottom:18px; }
.xcard .ic svg{ width:23px; height:23px; }
.xcard h3{ font-size:18px; letter-spacing:-.01em; margin-bottom:9px; }
.xcard p{ font-size:14px; color:var(--muted); line-height:1.6; text-wrap:pretty; }
.xcard .m{ margin-top:14px; font-size:13px; font-weight:600; color:var(--primary); }
.xcard:nth-child(6n+1) .ic{ background:color-mix(in oklab,#E11D3A 13%,transparent); color:#E11D3A; }
.xcard:nth-child(6n+2) .ic{ background:color-mix(in oklab,#2E6FF2 13%,transparent); color:#2E6FF2; }
.xcard:nth-child(6n+3) .ic{ background:color-mix(in oklab,#7C3AED 14%,transparent); color:#7C3AED; }
.xcard:nth-child(6n+4) .ic{ background:color-mix(in oklab,#0A86C9 13%,transparent); color:#0A86C9; }
.xcard:nth-child(6n+5) .ic{ background:color-mix(in oklab,#1A8F45 13%,transparent); color:#1A8F45; }
.xcard:nth-child(6n+6) .ic{ background:color-mix(in oklab,#E8830C 15%,transparent); color:#E8830C; }

.mgroup{ margin-top:26px; }
.mgroup > .ml{ display:flex; align-items:center; gap:10px; font-size:13px; letter-spacing:.05em; text-transform:uppercase; color:var(--muted-2); margin-bottom:14px; }
.mgroup > .ml::before{ content:""; width:18px; height:1.5px; background:var(--primary); opacity:.7; }

.scale-band{ margin-top:8px; color:#EDEAF2;
  background:
    radial-gradient(70% 130% at 10% 0%, color-mix(in oklab,var(--violet) 26%, transparent), transparent 54%),
    radial-gradient(64% 130% at 100% 100%, color-mix(in oklab,var(--secondary) 20%, transparent), transparent 56%),
    #0B0A11;
  border-top:1px solid rgba(255,255,255,.08); border-bottom:1px solid rgba(255,255,255,.08); }
.scale-band .eyebrow{ color:#FF8095; }
.scale-band h2{ color:#fff; }
.scale-band .section-sub, .scale-band .lead-2{ color:#A39CB0; }
.scale-band .prose p{ color:#A39CB0; }
.scale-band .prose strong{ color:#fff; }
.scale-stats{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; margin-top:38px; }
@media (max-width:760px){ .scale-stats{ grid-template-columns:1fr 1fr; } }
.scale-stats .ss{ padding:24px; border:1px solid rgba(255,255,255,.12); border-radius:var(--radius); background:rgba(255,255,255,.04); }
.scale-stats .ss b{ display:block; font-size:clamp(26px,3vw,36px); font-weight:800; letter-spacing:-.02em; line-height:1;
  background:linear-gradient(120deg,#fff,#FFC2BE 55%,#FF8095); -webkit-background-clip:text; background-clip:text; color:transparent; }
.scale-stats .ss span{ display:block; font-size:13px; color:#A39CB0; margin-top:9px; }
.scale-band .featlist .fi h4{ color:#fff; }
.scale-band .featlist .fi p{ color:#A39CB0; }

.minicases{ display:grid; grid-template-columns:repeat(3,1fr); gap:var(--gap); }
@media (max-width:900px){ .minicases{ grid-template-columns:1fr; } }

/* ============================================================
   МОБИЛЬНОЕ МЕНЮ: CTA «Обсудить проект» — в конце меню
   ============================================================ */
.nav-links .nav-cta{ display:none; }
@media (max-width:980px){
  /* убираем кнопку из верхней панели — она переедет в меню */
  .nav-actions .btn-primary{ display:none; }
  /* CTA последним пунктом выпадающего меню, на всю ширину */
  .header.menu-open .nav-links .nav-cta{
    display:inline-flex; justify-content:center; width:100%;
    margin-top:8px; color:#fff; font-size:16px;
  }
  /* у подменю в мобильном меню — лёгкий отступ, как было */
  .header.menu-open .nav-links{
    align-items:stretch;
    max-height:calc(100vh - 72px);
    max-height:calc(100dvh - 72px);
    overflow-y:auto;
    -webkit-overflow-scrolling:touch;
    overscroll-behavior:contain;
    padding-bottom:28px;
  }
}

/* ============================================================
   ИСПРАВЛЕНИЯ МОБИЛЬНОЙ ВЁРСТКИ
   (1fr резолвится шире контейнера из-за min-content → minmax(0,1fr))
   ============================================================ */
@media (max-width:980px){
  .hero-inner{ grid-template-columns:minmax(0,1fr) !important; gap:32px !important; }
  .hero-copy, .hero-visual, .hero-visual--product, .hero-shot{ min-width:0; max-width:100%; }
  .hero-shot img{ max-width:100%; height:auto; }
  .hero-shot .bar .addr{ overflow:hidden; text-overflow:ellipsis; }
}
@media (max-width:760px){
  .g-2, .g-3, .g-4, .grid,
  .bento, .modules, .modgrid, .roles, .metrics-row, .cta-grid,
  .timeline, .hubgrid, .xgrid, .minicases, .split, .contact-grid{
    grid-template-columns:minmax(0,1fr) !important;
  }
  .proof-bar, .scale-stats{ grid-template-columns:repeat(2, minmax(0,1fr)) !important; }
  /* карточки и ячейки не должны распирать строку */
  .cell, .ai-card, .ind, .case, .hubcard, .xcard, .quote, .why, .layer{ min-width:0; }
  .modules .mod, .modgrid li{ min-width:0; }
}
@media (max-width:560px){
  .proof-bar, .scale-stats, .req-cols, .req-codes{ grid-template-columns:minmax(0,1fr) !important; }
}
