/* SOlutica — Design System v2 */
/* Legacy variable aliases (used in privacy/termini inline styles) */

:root{
  /* Legacy aliases */
  --color-bg:#0A0A0B;
  --color-fg:#F5F3EE;
  --color-primary:#ED1B24;
  --color-primary-dark:#CC2222;
  --color-card-bg:#101013;
  --color-border:#1F1F25;
  --color-muted:#A8A6A0;
  --font-sans:'Inter',sans-serif;
  /* Design system */
  --bg:#0A0A0B;
  --bg-elev:#101013;
  --bg-elev-2:#15151A;
  --line:#1F1F25;
  --line-2:#2A2A33;
  --ink:#F5F3EE;
  --ink-dim:#A8A6A0;
  --ink-mute:#6E6C66;
  --red:#ED1B24;
  --red-glow:237,27,36;
  --red-soft:#FF3B43;
  --grid-rgb:255,255,255;
  --serif:'Inter',sans-serif;
  --sans:'Inter',sans-serif;
  --mono:'JetBrains Mono',ui-monospace,monospace;
  --pad:clamp(20px,4vw,80px);
  --maxw:1440px;
  --nav-bg:rgba(10,10,11,.6);
  --nav-bg-scrolled:rgba(10,10,11,.88);
  --surface-hover:rgba(255,255,255,.015);
  --surface-subtle:rgba(255,255,255,.02);
  --surface-faint:rgba(255,255,255,.03);
  --surface-active:rgba(255,255,255,.05);
  --stripe-rgb:255,255,255;
  --overlay-bg:rgba(0,0,0,.8);
  --ink-rgb:245,243,238;
}

/* ── LIGHT THEME ── */
[data-theme="light"]{
  --color-bg:#F8F6F1;
  --color-fg:#1A1915;
  --color-card-bg:#EDEAE4;
  --color-border:#D4D1CB;
  --color-muted:#9C9A94;
  --bg:#F8F6F1;
  --bg-elev:#EDEAE4;
  --bg-elev-2:#E4E1DB;
  --line:#D4D1CB;
  --line-2:#C4C1BB;
  --ink:#1A1915;
  --ink-dim:#5C5A54;
  --ink-mute:#9C9A94;
  --grid-rgb:0,0,0;
  --nav-bg:rgba(248,246,241,.72);
  --nav-bg-scrolled:rgba(248,246,241,.94);
  --surface-hover:rgba(0,0,0,.025);
  --surface-subtle:rgba(0,0,0,.03);
  --surface-faint:rgba(0,0,0,.04);
  --surface-active:rgba(0,0,0,.07);
  --stripe-rgb:0,0,0;
  --overlay-bg:rgba(0,0,0,.55);
  --ink-rgb:26,25,21;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--bg);color:var(--ink);font-family:var(--sans);font-feature-settings:"ss01","cv11";}
body{
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  font-size:16px;
  line-height:1.5;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:none;cursor:pointer}
img,svg{display:block;max-width:100%}
::selection{background:var(--red);color:#fff}

/* ---------- LAYOUT ---------- */
.shell,.container{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad);position:relative}

/* ---------- BACKGROUND GRID ---------- */
.bg-grid{
  position:fixed;inset:0;pointer-events:none;z-index:0;
  background-image:
    linear-gradient(to right,rgba(var(--grid-rgb),.025) 1px,transparent 1px),
    linear-gradient(to bottom,rgba(var(--grid-rgb),.025) 1px,transparent 1px);
  background-size:80px 80px;
  mask-image:radial-gradient(ellipse at top,#000 0%,transparent 70%);
}
.bg-noise{
  position:fixed;inset:0;pointer-events:none;z-index:1;opacity:.04;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='1.2' numOctaves='2'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
}
main,header,footer{position:relative;z-index:2}

/* ---------- NAV ---------- */
.nav{
  position:sticky;top:0;z-index:50;
  backdrop-filter:blur(18px) saturate(140%);
  -webkit-backdrop-filter:blur(18px) saturate(140%);
  background:var(--nav-bg);
  border-bottom:1px solid transparent;
  transition:border-color .3s,background .3s;
}
.nav.scrolled{border-bottom-color:var(--line);background:var(--nav-bg-scrolled)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:72px;gap:32px}
.logo-img{height:22px;width:auto;filter:drop-shadow(0 0 24px rgba(237,27,36,.35))}
.nav-links{display:flex;gap:4px;flex:1;justify-content:center}
.nav-links a{
  font-size:13px;letter-spacing:.01em;color:var(--ink-dim);
  padding:8px 14px;border-radius:8px;transition:color .2s,background .2s;
  font-weight:450;
}
.nav-links a:hover,.nav-links a.active{color:var(--ink);background:var(--surface-faint)}
.nav-cta{display:flex;align-items:center;gap:12px}
.nav-status{
  display:flex;align-items:center;gap:8px;
  font-family:var(--mono);font-size:11px;color:var(--ink-mute);text-transform:uppercase;letter-spacing:.08em;
}
.dot{width:6px;height:6px;border-radius:50%;background:#34D399;box-shadow:0 0 0 0 rgba(52,211,153,.6);animation:pulse 2.4s infinite}
.lang-switch{display:flex;align-items:center}
.lang-btn{font-family:var(--mono);font-size:11px;font-weight:500;letter-spacing:.1em;color:var(--ink-mute);text-transform:uppercase;padding:5px 10px;border:1px solid var(--line);border-radius:6px;transition:all .2s}
.lang-btn:hover{color:var(--ink);border-color:var(--ink-dim)}
.mobile-lang-switch{margin-top:32px;padding-top:24px;border-top:1px solid var(--line)}
.mobile-lang-switch .lang-btn{font-size:14px;letter-spacing:.06em;padding:10px 16px;width:100%;text-align:center;display:block}

/* ---------- THEME TOGGLE ---------- */
.theme-toggle{
  width:34px;height:34px;border-radius:8px;
  border:1px solid var(--line-2);
  display:flex;align-items:center;justify-content:center;
  color:var(--ink-mute);cursor:pointer;background:none;
  transition:all .2s;flex-shrink:0;
}
.theme-toggle:hover{border-color:var(--ink-dim);color:var(--ink)}
.theme-toggle svg{width:15px;height:15px}
.theme-toggle .icon-sun{display:none}
.theme-toggle .icon-moon{display:block}
[data-theme="light"] .theme-toggle .icon-sun{display:block}
[data-theme="light"] .theme-toggle .icon-moon{display:none}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(52,211,153,.5)}70%{box-shadow:0 0 0 8px rgba(52,211,153,0)}100%{box-shadow:0 0 0 0 rgba(52,211,153,0)}}

/* ---------- BUTTONS ---------- */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:11px 18px;font-size:13px;font-weight:500;letter-spacing:.005em;
  border-radius:999px;transition:all .25s cubic-bezier(.2,.8,.2,1);
  white-space:nowrap;
}
.btn .arr{transition:transform .25s}
.btn:hover .arr{transform:translateX(3px)}
.btn-primary{background:var(--red);color:#fff;box-shadow:0 0 0 1px rgba(237,27,36,.5),0 8px 24px -8px rgba(237,27,36,.6)}
.btn-primary:hover{background:#FF2630;box-shadow:0 0 0 1px rgba(237,27,36,.7),0 14px 38px -8px rgba(237,27,36,.8),inset 0 1px 0 rgba(255,255,255,.18)}
.btn-ghost,.btn-outline{color:var(--ink);border:1px solid var(--line-2);background:var(--surface-subtle);border-radius:999px;display:inline-flex;align-items:center;gap:10px;padding:11px 18px;font-size:13px;font-weight:500;transition:all .25s cubic-bezier(.2,.8,.2,1);cursor:pointer;white-space:nowrap;}
.btn-ghost:hover,.btn-outline:hover{border-color:var(--ink-dim);background:var(--surface-active)}
.btn-link{padding:0;color:var(--ink);font-weight:500}
.btn-link:hover{color:var(--red)}

/* ---------- HERO ---------- */
.hero{position:relative;padding:80px 0 0;overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:80px;align-items:center;min-height:78vh}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.16em;
  color:var(--ink-dim);
  padding:7px 12px 7px 10px;border:1px solid var(--line-2);border-radius:999px;
  background:var(--surface-hover);
  margin-bottom:36px;
}
.hero-eyebrow::before{content:"";width:5px;height:5px;background:var(--red);border-radius:50%;box-shadow:0 0 12px var(--red)}
.hero h1{
  font-family:var(--sans);
  font-size:clamp(44px,7.2vw,104px);
  line-height:.95;
  letter-spacing:-.04em;
  font-weight:500;
  color:var(--ink);
  margin-bottom:32px;
}
.hero h1 em{font-style:normal;color:var(--red);font-weight:500;position:relative;display:inline-block}
.hero h1 em::after{
  content:"";position:absolute;left:0;right:0;bottom:.06em;height:.04em;
  background:var(--red);transform:scaleX(0);transform-origin:left;
  animation:underline 1.4s .8s cubic-bezier(.7,0,.3,1) forwards;
}
@keyframes underline{to{transform:scaleX(1)}}
.hero-sub{
  font-size:clamp(16px,1.25vw,19px);
  color:var(--ink-dim);max-width:520px;line-height:1.55;font-weight:400;
  margin-bottom:48px;
}
.hero-ctas{display:flex;gap:12px;align-items:center;flex-wrap:wrap;margin-bottom:64px}
.hero-meta{
  display:flex;flex-wrap:wrap;gap:6px 26px;
  font-family:var(--mono);font-size:11px;color:var(--ink-mute);
  text-transform:uppercase;letter-spacing:.1em;
  padding-top:28px;border-top:1px solid var(--line);max-width:560px;
}
.hero-meta span{display:inline-flex;align-items:center;gap:8px}
.hero-meta span::before{content:"";width:3px;height:3px;background:var(--ink-mute);border-radius:50%}

/* hero visual */
.hero-visual{position:relative;height:620px;width:100%}
.hero-visual-frame{
  position:absolute;inset:0;
  border:1px solid var(--line);border-radius:14px;
  background:
    radial-gradient(ellipse 80% 60% at 50% 50%,rgba(237,27,36,.06),transparent 70%),
    linear-gradient(180deg,var(--bg-elev) 0%,var(--bg) 100%);
  overflow:hidden;
}
.hero-visual canvas{position:absolute;inset:0;width:100%;height:100%}
.hero-visual-corners{position:absolute;inset:14px;pointer-events:none}
.hero-visual-corners::before,.hero-visual-corners::after,
.hero-visual-corners > i:first-child,.hero-visual-corners > i:last-child{
  content:"";position:absolute;width:14px;height:14px;border:1px solid var(--ink-dim);
}
.hero-visual-corners::before{top:0;left:0;border-right:0;border-bottom:0}
.hero-visual-corners::after{top:0;right:0;border-left:0;border-bottom:0}
.hero-visual-corners > i:first-child{bottom:0;left:0;border-right:0;border-top:0}
.hero-visual-corners > i:last-child{bottom:0;right:0;border-left:0;border-top:0}
.hero-visual-label{
  position:absolute;top:18px;left:18px;
  font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--ink-mute);display:flex;align-items:center;gap:8px;
}
.hero-visual-label::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--red);box-shadow:0 0 12px rgba(237,27,36,.8)}
.hero-visual-readout{
  position:absolute;bottom:18px;left:18px;right:18px;
  display:flex;justify-content:space-between;
  font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--ink-mute);
}
.hero-visual-readout b{color:var(--ink-dim);font-weight:500}

/* logo strip */
.logos{
  margin-top:96px;padding:32px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);
}
.logos-inner{display:flex;align-items:center;gap:48px;justify-content:space-between}
.logos-label{
  font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-mute);
  white-space:nowrap;
}
.logos-track{
  display:flex;gap:56px;align-items:center;flex:1;
  font-family:var(--mono);font-size:13px;color:var(--ink-dim);letter-spacing:.04em;
  overflow:hidden;mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);
}
.logos-track > div{display:flex;gap:56px;animation:marquee 38s linear infinite;white-space:nowrap}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.logos-track .stk{display:inline-flex;align-items:center;gap:10px}
.logos-track .stk i{display:inline-block;width:6px;height:6px;background:var(--ink-mute);transform:rotate(45deg)}

/* ---------- SECTION HEADER ---------- */
.section{padding:140px 0;position:relative}
.section-head{display:grid;grid-template-columns:auto 1fr;gap:80px;align-items:end;margin-bottom:80px}
.section-num{
  font-family:var(--mono);font-size:12px;color:var(--red);letter-spacing:.16em;text-transform:uppercase;
  display:flex;align-items:center;gap:12px;
}
.section-num::after{content:"";display:block;width:80px;height:1px;background:var(--line-2)}
.section-title{
  font-size:clamp(36px,4.2vw,64px);line-height:1;letter-spacing:-.03em;font-weight:500;
  max-width:14ch;
}
.section-title em{font-style:normal;color:var(--ink-mute)}
.section-kicker{
  font-family:var(--mono);font-size:11px;color:var(--ink-mute);text-transform:uppercase;letter-spacing:.16em;
  margin-bottom:18px;
}

/* ---------- METRICS ---------- */
.metrics{
  display:grid;grid-template-columns:repeat(4,1fr);
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
}
.metric{
  padding:48px 32px;border-right:1px solid var(--line);
  position:relative;overflow:hidden;
}
.metric:last-child{border-right:0}
.metric-label{
  font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-mute);
  margin-bottom:18px;display:flex;align-items:center;gap:8px;
}
.metric-label::before{content:"";width:6px;height:6px;background:var(--red);border-radius:50%}
.metric-num{
  font-size:clamp(48px,5vw,76px);line-height:.95;letter-spacing:-.04em;font-weight:500;
  color:var(--ink);font-feature-settings:"tnum","ss01";
}
.metric-num sup{font-size:.45em;color:var(--red);vertical-align:top;margin-left:4px;font-weight:500}
.metric-desc{margin-top:14px;color:var(--ink-dim);font-size:14px;max-width:24ch;line-height:1.4}

/* ---------- SERVICES ---------- */
.services{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid var(--line)}
.service{
  border-right:1px solid var(--line);border-bottom:1px solid var(--line);
  padding:40px 36px 44px;position:relative;overflow:hidden;
  transition:background .35s;
  min-height:340px;display:flex;flex-direction:column;
  cursor:pointer;
}
.service:nth-child(3n){border-right:0}
.service::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at var(--mx,50%) var(--my,0%),rgba(237,27,36,.12),transparent 50%);
  opacity:0;transition:opacity .4s;pointer-events:none;
}
.service:hover{background:var(--surface-hover)}
.service:hover::before{opacity:1}
.service:hover .service-arrow{color:var(--red);transform:translate(4px,-4px)}
.service-tag{
  position:absolute;top:40px;left:36px;
  font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--red);
  padding:5px 9px;border:1px solid rgba(237,27,36,.4);border-radius:4px;background:rgba(237,27,36,.06);
}
.service-num{
  font-family:var(--mono);font-size:11px;color:var(--ink-mute);letter-spacing:.14em;
  position:absolute;top:24px;right:28px;
}
.service h3{
  font-size:28px;line-height:1.05;letter-spacing:-.02em;font-weight:500;margin-top:88px;margin-bottom:14px;
}
.service p{color:var(--ink-dim);font-size:14.5px;line-height:1.5;margin-bottom:28px;max-width:42ch}
.service-foot{display:flex;align-items:center;justify-content:space-between;margin-top:auto}
.service-stack{display:flex;gap:6px;flex-wrap:wrap}
.service-stack span{
  font-family:var(--mono);font-size:10px;color:var(--ink-mute);letter-spacing:.06em;
  padding:3px 7px;border:1px solid var(--line-2);border-radius:3px;
}
.service-arrow{
  font-size:18px;color:var(--ink-dim);transition:all .3s;
  width:34px;height:34px;border-radius:50%;border:1px solid var(--line-2);
  display:flex;align-items:center;justify-content:center;
}

/* ---------- WHY ---------- */
.why{display:grid;grid-template-columns:1fr 1.3fr;gap:96px;align-items:start}
.why-list{display:flex;flex-direction:column;gap:0}
.why-item{
  padding:32px 0;border-top:1px solid var(--line);
  display:grid;grid-template-columns:80px 1fr auto;gap:32px;align-items:start;
  cursor:pointer;transition:padding .3s;
}
.why-item:hover{padding-left:14px}
.why-item:last-child{border-bottom:1px solid var(--line)}
.why-item-num{font-family:var(--mono);font-size:12px;color:var(--ink-mute);padding-top:6px;letter-spacing:.1em}
.why-item h4{font-size:24px;font-weight:500;letter-spacing:-.015em;margin-bottom:8px;line-height:1.15}
.why-item p{color:var(--ink-dim);font-size:14.5px;line-height:1.55;max-width:48ch}
.why-item-arr{color:var(--ink-mute);font-size:18px;padding-top:6px;transition:color .25s,transform .25s}
.why-item:hover .why-item-arr{color:var(--red);transform:rotate(-45deg)}

/* diag */
.diag{
  position:sticky;top:120px;
  border:1px solid var(--line);border-radius:14px;
  background:linear-gradient(180deg,var(--bg-elev) 0%,var(--bg) 100%);
  padding:28px;height:560px;display:flex;flex-direction:column;overflow:hidden;
}
.diag-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;font-family:var(--mono);font-size:11px;color:var(--ink-mute);letter-spacing:.14em;text-transform:uppercase}
.diag-head .live{color:#34D399;display:flex;align-items:center;gap:7px}
.diag-head .live::before{content:"";width:6px;height:6px;background:#34D399;border-radius:50%;animation:pulse 2s infinite}
.diag-rows{display:flex;flex-direction:column;gap:14px;flex:1}
.diag-row{
  display:grid;grid-template-columns:1fr auto;gap:16px;align-items:center;
  font-family:var(--mono);font-size:12px;
}
.diag-row .lbl{color:var(--ink-dim)}
.diag-row .lbl em{font-style:normal;color:var(--ink-mute);font-size:.9em}
.diag-row .val{color:var(--ink);font-weight:500}
.bar{grid-column:1/-1;height:3px;background:var(--line);border-radius:2px;overflow:hidden;}
.bar > i{display:block;height:100%;background:linear-gradient(90deg,var(--red),var(--red-soft));border-radius:2px;transform-origin:left;transform:scaleX(0)}
.diag-foot{
  margin-top:auto;padding-top:20px;border-top:1px solid var(--line);
  display:flex;justify-content:space-between;font-family:var(--mono);font-size:10px;color:var(--ink-mute);letter-spacing:.14em;text-transform:uppercase;
}

/* ---------- CASES (homepage) ---------- */
.cases{display:flex;flex-direction:column;gap:0;border-top:1px solid var(--line)}
.case{
  display:grid;grid-template-columns:200px 1fr 1.1fr;
  gap:60px;padding:56px 0;border-bottom:1px solid var(--line);
  align-items:center;position:relative;
  transition:padding .35s,background .35s;
  cursor:pointer;
}
.case:hover{padding-left:24px;padding-right:24px;background:var(--surface-hover)}
.case-meta{font-family:var(--mono);font-size:11px;color:var(--ink-mute);letter-spacing:.14em;text-transform:uppercase;display:flex;flex-direction:column;gap:8px}
.case-meta b{color:var(--red);font-weight:500}
.case-body h3{font-size:30px;font-weight:500;letter-spacing:-.02em;line-height:1.1;margin-bottom:14px}
.case-body p{color:var(--ink-dim);font-size:14.5px;line-height:1.55;max-width:46ch;margin-bottom:18px}
.case-tags{display:flex;gap:6px;flex-wrap:wrap}
.case-tags span{font-family:var(--mono);font-size:10px;color:var(--ink-mute);padding:3px 7px;border:1px solid var(--line-2);border-radius:3px}
.case-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.case-stat .n{font-size:44px;line-height:1;letter-spacing:-.03em;font-weight:500;font-feature-settings:"tnum"}
.case-stat .n em{font-style:normal;color:var(--red);font-size:.55em;margin-left:2px}
.case-stat .l{font-family:var(--mono);font-size:10px;color:var(--ink-mute);letter-spacing:.12em;text-transform:uppercase;margin-top:8px}
.case-arrow{
  position:absolute;right:0;top:50%;transform:translateY(-50%);
  width:44px;height:44px;border-radius:50%;border:1px solid var(--line-2);
  display:flex;align-items:center;justify-content:center;color:var(--ink-dim);
  transition:all .3s;
}
.case:hover .case-arrow{background:var(--red);border-color:var(--red);color:#fff;transform:translateY(-50%) translateX(20px) rotate(-45deg)}

/* ---------- PROCESS ---------- */
.process{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:1px solid var(--line)}
.step{
  padding:40px 32px 48px;border-right:1px solid var(--line);position:relative;
  min-height:280px;display:flex;flex-direction:column;
}
.step:last-child{border-right:0}
.step-num{font-family:var(--mono);font-size:11px;color:var(--red);letter-spacing:.14em;margin-bottom:auto}
.step-glyph{
  width:42px;height:42px;border:1px solid var(--line-2);border-radius:50%;
  display:flex;align-items:center;justify-content:center;margin:48px 0 28px;
  font-family:var(--mono);font-size:13px;color:var(--ink);
}
.step h4{font-size:21px;font-weight:500;letter-spacing:-.01em;margin-bottom:10px}
.step p{color:var(--ink-dim);font-size:13.5px;line-height:1.5}
.step::after{
  content:"";position:absolute;top:50%;right:-7px;width:14px;height:14px;
  border-top:1px solid var(--line);border-right:1px solid var(--line);
  transform:translateY(-50%) rotate(45deg);background:var(--bg);
}
.step:last-child::after{display:none}

/* ---------- CTA SECTION ---------- */
.cta-section{
  position:relative;padding:160px var(--pad);text-align:center;overflow:hidden;
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
}
.cta-section::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(ellipse 60% 80% at 50% 100%,rgba(237,27,36,.18),transparent 70%);
  pointer-events:none;
}
.cta-section .shell,.cta-section .container{position:relative}
.cta-eyebrow{
  font-family:var(--mono);font-size:11px;color:var(--red);letter-spacing:.18em;text-transform:uppercase;margin-bottom:32px;
}
.cta-section h2{
  font-size:clamp(48px,7vw,108px);line-height:.95;letter-spacing:-.04em;font-weight:500;
  margin:0 auto 32px;max-width:14ch;
}
.cta-section h2 em{font-style:normal;color:var(--red)}
.cta-section p{color:var(--ink-dim);font-size:18px;max-width:52ch;margin:0 auto 48px;line-height:1.5}
.cta-buttons{display:inline-flex;gap:12px;flex-wrap:wrap;justify-content:center}

/* ---------- FOOTER ---------- */
footer{padding:80px 0 40px;border-top:1px solid var(--line);background:var(--bg)}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:64px;margin-bottom:64px}
.foot-brand .logo-img{height:24px;margin-bottom:24px}
.foot-brand p{color:var(--ink-dim);font-size:14px;line-height:1.55;max-width:36ch;margin-bottom:24px}
.foot-stack{display:flex;flex-wrap:wrap;gap:6px}
.foot-stack span{font-family:var(--mono);font-size:10px;color:var(--ink-mute);padding:3px 7px;border:1px solid var(--line-2);border-radius:3px}
.foot-col h5{font-family:var(--mono);font-size:11px;color:var(--ink-mute);letter-spacing:.14em;text-transform:uppercase;margin-bottom:20px;font-weight:500}
.foot-col ul{list-style:none;display:flex;flex-direction:column;gap:12px}
.foot-col a{color:var(--ink-dim);font-size:14px;transition:color .2s}
.foot-col a:hover{color:var(--red)}
.foot-bottom{padding-top:32px;border-top:1px solid var(--line);display:flex;justify-content:space-between;font-family:var(--mono);font-size:11px;color:var(--ink-mute);letter-spacing:.08em;text-transform:uppercase}

/* ---------- REVEAL ---------- */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .9s cubic-bezier(.2,.7,.2,1),transform .9s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}
.reveal.d2{transition-delay:.16s}
.reveal.d3{transition-delay:.24s}

/* ================================================ */
/* PAGE-SPECIFIC                                    */
/* ================================================ */

/* ---------- PAGE HEADER ---------- */
.page-head{padding:80px 0 60px;border-bottom:1px solid var(--line);position:relative;}
.page-head .bread{
  display:flex;align-items:center;gap:10px;
  font-family:var(--mono);font-size:11px;color:var(--ink-mute);
  letter-spacing:.14em;text-transform:uppercase;margin-bottom:32px;
}
.page-head .bread a{color:var(--ink-mute);transition:color .2s}
.page-head .bread a:hover{color:var(--red)}
.page-head .bread span{color:var(--line-2)}
.page-head .bread b{color:var(--ink);font-weight:500}
.page-head h1{
  font-size:clamp(40px,6.4vw,96px);line-height:.95;letter-spacing:-.04em;
  font-weight:500;max-width:18ch;margin-bottom:28px;
}
.page-head h1 em{font-style:normal;color:var(--red)}
.page-head .lead{
  font-size:clamp(16px,1.2vw,19px);color:var(--ink-dim);
  max-width:62ch;line-height:1.55;
}
.page-head-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:80px;align-items:end}

/* ---------- FAQ ---------- */
.faq{display:flex;flex-direction:column;border-top:1px solid var(--line)}
.faq details{border-bottom:1px solid var(--line);padding:24px 0;cursor:pointer}
.faq summary{
  list-style:none;display:flex;justify-content:space-between;align-items:center;gap:24px;
  font-size:18px;font-weight:500;letter-spacing:-.01em;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{
  content:"+";font-family:var(--mono);font-size:24px;color:var(--ink-dim);
  transition:transform .25s,color .25s;line-height:1;
}
.faq details[open] summary::after{transform:rotate(45deg);color:var(--red)}
.faq .ans{margin-top:14px;color:var(--ink-dim);font-size:15px;line-height:1.6;max-width:72ch}

/* ---------- TIMELINE ---------- */
.timeline{display:grid;grid-template-columns:120px 1fr;gap:0}
.tl-year{
  font-family:var(--mono);font-size:13px;color:var(--red);letter-spacing:.1em;padding-top:28px;
  border-right:1px solid var(--line);padding-right:24px;
}
.tl-row{padding:28px 0 28px 32px;border-bottom:1px solid var(--line);grid-column:2}
.tl-row h4{font-size:18px;font-weight:500;margin-bottom:6px}
.tl-row p{color:var(--ink-dim);font-size:14.5px;line-height:1.55;max-width:60ch}
.timeline > .tl-year{border-bottom:1px solid var(--line)}
.timeline > .tl-year:last-of-type{border-bottom:0}

/* ---------- VALUES ---------- */
.values{display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.value{padding:48px 36px;border-right:1px solid var(--line);position:relative;}
.value:last-child{border-right:0}
.value .vk{font-family:var(--mono);font-size:11px;color:var(--red);letter-spacing:.16em;text-transform:uppercase;margin-bottom:32px}
.value h3{font-size:28px;font-weight:500;letter-spacing:-.02em;margin-bottom:14px;line-height:1.1}
.value p{color:var(--ink-dim);font-size:14.5px;line-height:1.55}

/* ---------- TEAM CARD ---------- */
.team-card{
  display:grid;grid-template-columns:340px 1fr;gap:64px;
  border:1px solid var(--line);border-radius:14px;overflow:hidden;
  background:linear-gradient(180deg,var(--bg-elev) 0%,var(--bg) 100%);
}
.team-photo{
  background:var(--bg-elev-2);
  min-height:420px;position:relative;overflow:hidden;
  display:flex;align-items:flex-end;justify-content:center;padding:0;
}
.team-portrait{
  width:100%;height:100%;object-fit:cover;object-position:center top;
  position:absolute;inset:0;display:block;
}
.team-photo .ph{
  font-family:var(--mono);font-size:11px;color:var(--ink-mute);letter-spacing:.14em;text-transform:uppercase;
  position:absolute;bottom:18px;left:18px;right:18px;display:flex;justify-content:space-between;
}
.team-photo .ph::before{content:"";position:absolute;top:-18px;left:0;right:0;height:1px;background:var(--line)}
.team-glyph{
  font-size:140px;font-weight:500;color:var(--ink);letter-spacing:-.05em;
  line-height:.85;mix-blend-mode:difference;
}
.team-info{padding:48px 48px 48px 0;display:flex;flex-direction:column;justify-content:center}
.team-info .role{font-family:var(--mono);font-size:11px;color:var(--red);letter-spacing:.16em;text-transform:uppercase;margin-bottom:18px}
.team-info h3{font-size:44px;font-weight:500;letter-spacing:-.03em;line-height:1;margin-bottom:18px}
.team-info p{color:var(--ink-dim);font-size:15.5px;line-height:1.6;margin-bottom:24px;max-width:54ch}
.team-info .links{display:flex;gap:18px;font-family:var(--mono);font-size:12px;color:var(--ink-dim);flex-wrap:wrap}
.team-info .links a{display:inline-flex;align-items:center;gap:6px;transition:color .2s}
.team-info .links a:hover{color:var(--red)}

/* ---------- CASE TILE GRID ---------- */
.case-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.case-tile{
  border:1px solid var(--line);border-radius:14px;padding:32px;
  background:linear-gradient(180deg,var(--bg-elev) 0%,var(--bg) 100%);
  display:flex;flex-direction:column;min-height:380px;
  transition:all .35s;position:relative;overflow:hidden;
}
.case-tile:hover{border-color:var(--line-2);transform:translateY(-4px);box-shadow:0 30px 60px -30px rgba(var(--ink-rgb),.25)}
.case-tile-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:auto;font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-mute)}
.case-tile-head b{color:var(--red);font-weight:500}
.case-tile h3{font-size:28px;font-weight:500;letter-spacing:-.02em;margin-top:80px;margin-bottom:14px;line-height:1.05}
.case-tile p{color:var(--ink-dim);font-size:14px;line-height:1.55;margin-bottom:24px}
.case-tile-stats{display:flex;gap:32px;margin-bottom:20px;border-top:1px solid var(--line);padding-top:20px}
.case-tile-stats div .n{font-size:28px;font-weight:500;letter-spacing:-.02em;line-height:1}
.case-tile-stats div .n em{font-style:normal;color:var(--red);font-size:.55em;margin-left:2px}
.case-tile-stats div .l{font-family:var(--mono);font-size:9px;color:var(--ink-mute);letter-spacing:.1em;text-transform:uppercase;margin-top:6px}
.case-tile-foot{display:flex;justify-content:space-between;align-items:center}
.case-tile-tags{display:flex;gap:6px;flex-wrap:wrap}
.case-tile-tags span{font-family:var(--mono);font-size:10px;color:var(--ink-mute);padding:3px 7px;border:1px solid var(--line-2);border-radius:3px}

/* ---------- BLOG GRID ---------- */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid var(--line)}
.blog-card{
  border-right:1px solid var(--line);border-bottom:1px solid var(--line);
  padding:32px 28px 36px;display:flex;flex-direction:column;
  min-height:340px;transition:background .25s;cursor:pointer;
}
.blog-card:nth-child(3n){border-right:0}
.blog-card:hover{background:var(--surface-hover)}
.blog-card .meta{display:flex;justify-content:space-between;font-family:var(--mono);font-size:10px;color:var(--ink-mute);letter-spacing:.14em;text-transform:uppercase;margin-bottom:auto}
.blog-card .meta b{color:var(--red);font-weight:500}
.blog-card h3{font-size:22px;font-weight:500;letter-spacing:-.015em;margin-top:64px;margin-bottom:12px;line-height:1.2}
.blog-card p{color:var(--ink-dim);font-size:14px;line-height:1.5;margin-bottom:24px}
.blog-card .read{font-family:var(--mono);font-size:11px;color:var(--ink-dim);letter-spacing:.1em;text-transform:uppercase;display:flex;justify-content:space-between;border-top:1px solid var(--line);padding-top:14px;margin-top:auto}
.blog-card:hover .read{color:var(--red)}

/* ---------- CONTACT FORM ---------- */
.contact{display:grid;grid-template-columns:1fr 1fr;gap:80px;padding:80px 0}
.contact-info h2{font-size:clamp(32px,3.4vw,48px);font-weight:500;letter-spacing:-.025em;line-height:1.05;margin-bottom:24px}
.contact-info p{color:var(--ink-dim);font-size:16px;line-height:1.55;margin-bottom:40px;max-width:42ch}
.contact-list{display:flex;flex-direction:column;gap:24px;border-top:1px solid var(--line);padding-top:24px}
.contact-list .row{display:grid;grid-template-columns:120px 1fr;gap:16px;align-items:center;font-family:var(--mono)}
.contact-list .k{font-size:11px;color:var(--ink-mute);letter-spacing:.14em;text-transform:uppercase}
.contact-list .v{font-size:14px;color:var(--ink)}
.contact-list .v a:hover{color:var(--red)}

.form{
  border:1px solid var(--line);border-radius:14px;padding:36px;
  background:linear-gradient(180deg,var(--bg-elev) 0%,var(--bg) 100%);
}
.form .row2{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}
.form label{display:block;font-family:var(--mono);font-size:11px;color:var(--ink-mute);letter-spacing:.14em;text-transform:uppercase;margin-bottom:8px}
.form input[type="text"],.form input[type="email"],.form input[type="tel"],.form input,.form textarea,.form select{
  width:100%;background:var(--bg);border:1px solid var(--line-2);border-radius:8px;
  padding:14px 16px;color:var(--ink);font-family:var(--sans);font-size:15px;
  transition:border-color .2s,background .2s;
}
.form input:focus,.form textarea:focus,.form select:focus{outline:none;border-color:var(--red);background:var(--bg-elev)}
.form textarea{min-height:140px;resize:vertical;font-family:var(--sans)}
.form .field{margin-bottom:14px}
.form .submit-row{display:flex;justify-content:space-between;align-items:center;margin-top:24px;padding-top:24px;border-top:1px solid var(--line);font-family:var(--mono);font-size:11px;color:var(--ink-mute);letter-spacing:.1em;text-transform:uppercase}
.checkbox-row{display:flex;gap:10px;align-items:flex-start;font-size:12px;color:var(--ink-mute);font-family:var(--mono);letter-spacing:.06em}
.checkbox-row input[type="checkbox"]{width:auto;margin-top:2px;accent-color:var(--red)}
.checkbox-row a{color:var(--red)}
.form-error{font-family:var(--mono);font-size:11px;color:var(--red);margin-top:6px;display:block}
.alert-success{
  background:rgba(52,211,153,.08);
  border:1px solid rgba(52,211,153,.3);
  border-radius:8px;padding:16px 20px;
  font-family:var(--mono);font-size:13px;
  color:#34D399;margin-bottom:24px;letter-spacing:.04em;
}

/* ---------- SOVEREIGN AI ---------- */
.sov-hero{display:grid;grid-template-columns:1.2fr 1fr;gap:80px;align-items:start}
.sov-tag{display:flex;align-items:center;gap:10px;font-family:var(--mono);font-size:11px;color:var(--ink-dim);text-transform:uppercase;letter-spacing:.14em;margin-bottom:28px}
.sov-dot{width:8px;height:8px;background:var(--red);border-radius:50%;box-shadow:0 0 12px var(--red)}
.sov-title{font-size:clamp(22px,2.4vw,32px);font-weight:500;letter-spacing:-.02em;line-height:1.2;margin-bottom:24px}
.sov-title em{font-style:normal;color:var(--red)}
.sov-lede{color:var(--ink-dim);font-size:15px;line-height:1.6;margin-bottom:36px;max-width:56ch}
.sov-pillars{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);margin-bottom:32px}
.sov-pill{padding:18px 0;border-right:1px solid var(--line);text-align:center}
.sov-pill:last-child{border-right:0}
.sov-pill-num{display:block;font-size:22px;font-weight:500;letter-spacing:-.02em}
.sov-pill-num i{font-style:normal;font-size:.65em;color:var(--ink-dim)}
.sov-pill-lbl{display:block;font-family:var(--mono);font-size:10px;color:var(--ink-mute);letter-spacing:.12em;text-transform:uppercase;margin-top:6px}
.sov-feats{list-style:none;display:flex;flex-direction:column;gap:14px}
.sov-feats li{font-size:14.5px;color:var(--ink-dim);line-height:1.55;padding-left:18px;position:relative}
.sov-feats li::before{content:"—";position:absolute;left:0;color:var(--red);font-weight:600}
.sov-feats li b{color:var(--ink);font-weight:500}
.sov-right{position:sticky;top:120px;display:flex;flex-direction:column;gap:24px}
.sov-rack{border:1px solid var(--line);border-radius:12px;overflow:hidden;background:var(--bg-elev)}
.sov-rack-head{padding:12px 16px;background:var(--bg-elev-2);border-bottom:1px solid var(--line);display:flex;align-items:center;gap:8px}
.sov-rack-dot{width:10px;height:10px;border-radius:50%;background:var(--line-2)}
.sov-rack-dot.amber{background:#F59E0B}
.sov-rack-dot.green{background:#34D399}
.sov-rack-id{font-family:var(--mono);font-size:10px;color:var(--ink-mute);letter-spacing:.1em;margin-left:auto}
.sov-rack-body{padding:20px;display:flex;flex-direction:column;gap:16px}
.sov-rack-stat{display:grid;grid-template-columns:1fr;gap:8px;font-family:var(--mono);font-size:12px}
.sov-rack-stat > div{display:flex;justify-content:space-between}
.sov-rack-stat .k{color:var(--ink-mute)}
.sov-rack-stat .v{color:var(--ink);font-weight:500;display:flex;align-items:center;gap:6px}
.sov-led{width:6px;height:6px;background:#34D399;border-radius:50%;box-shadow:0 0 6px rgba(52,211,153,.8)}
.sov-rack-bars{display:flex;flex-direction:column;gap:6px}
.sov-bar{display:flex;align-items:flex-end;gap:3px;height:48px}
.sov-bar span{flex:1;background:var(--red);border-radius:2px 2px 0 0;opacity:.6}
.sov-bar-lbl{font-family:var(--mono);font-size:9px;color:var(--ink-mute);letter-spacing:.12em;text-transform:uppercase}
.sov-cli{font-family:var(--mono);font-size:11px;color:var(--ink-dim);line-height:1.6;background:var(--bg);padding:12px;border-radius:6px;border:1px solid var(--line);overflow-x:auto;white-space:pre}
.sov-rack-foot{padding:12px 16px;border-top:1px solid var(--line);background:var(--bg-elev-2);display:flex;justify-content:space-between;align-items:center}
.sov-rack-port{display:flex;gap:4px}
.sov-rack-port i{width:8px;height:8px;background:var(--line-2);border-radius:50%}
.sov-rack-power{font-family:var(--mono);font-size:10px;color:var(--ink-mute);letter-spacing:.1em}
/* ---------- SOVEREIGN PLATFORM --------- */
.sov-platform{display:grid;grid-template-columns:1fr 1.2fr;gap:80px;align-items:start}
.sov-platform-img{position:sticky;top:120px}
.sov-device-photo{width:100%;border-radius:12px;border:1px solid var(--line);display:block}
.sov-platform-badge{
  margin-top:16px;display:flex;align-items:center;gap:10px;
  font-family:var(--mono);font-size:11px;color:var(--ink-mute);letter-spacing:.08em;
}
.sov-specs{display:flex;flex-direction:column;border-top:1px solid var(--line);margin-top:8px}
.sov-spec{display:grid;grid-template-columns:120px 1fr;gap:16px;padding:12px 0;border-bottom:1px solid var(--line);font-family:var(--mono);font-size:12px}
.sov-spec .k{color:var(--ink-mute);letter-spacing:.06em}
.sov-spec .v{color:var(--ink)}
@media(max-width:1100px){.sov-platform{grid-template-columns:1fr;gap:40px}.sov-platform-img{position:static}}
.sov-teaser{border:1px solid var(--line);border-radius:14px;padding:48px;background:linear-gradient(135deg,var(--bg-elev) 0%,var(--bg) 100%);position:relative;overflow:hidden}
.sov-teaser::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 60% 80% at 100% 50%,rgba(237,27,36,.06),transparent 70%);pointer-events:none}
.sov-teaser-body{position:relative;max-width:680px}
.sov-usecases{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:1px solid var(--line);margin-top:80px}
.sov-uc{padding:32px 28px;border-right:1px solid var(--line)}
.sov-uc:last-child{border-right:0}
.sov-uc-num{font-family:var(--mono);font-size:11px;color:var(--red);letter-spacing:.14em;display:block;margin-bottom:16px}
.sov-uc h5{font-size:17px;font-weight:500;margin-bottom:10px}
.sov-uc p{font-size:13.5px;color:var(--ink-dim);line-height:1.55}

/* ---------- MOBILE NAV ---------- */
.nav-mobile-toggle{
  display:none;
  width:40px;height:40px;border-radius:8px;
  border:1px solid var(--line-2);align-items:center;justify-content:center;
  color:var(--ink-dim);cursor:pointer;background:none;
  transition:all .2s;flex-shrink:0;
}
.nav-mobile-toggle:hover{border-color:var(--ink-dim);color:var(--ink)}
#navMobilePanel{
  display:none;position:fixed;inset:0;z-index:49;
  background:var(--bg);flex-direction:column;
  padding:96px var(--pad) 48px;
  border-top:1px solid var(--line);
}
#navMobilePanel.active{display:flex}
.mobile-nav-links{display:flex;flex-direction:column;gap:0}
.mobile-nav-links a{
  font-size:clamp(26px,6vw,36px);font-weight:500;letter-spacing:-.025em;
  color:var(--ink-dim);padding:14px 0;
  border-bottom:1px solid var(--line);
  transition:color .2s,padding-left .2s;
}
.mobile-nav-links a:hover{color:var(--ink);padding-left:8px}
.mobile-nav-footer{margin-top:48px;display:flex;flex-direction:column;gap:12px}

/* ---------- COOKIE BANNER ---------- */
#cookie-banner{
  position:fixed;bottom:0;left:0;right:0;z-index:200;
  background:var(--bg-elev);
  border-top:1px solid var(--line);
  transform:translateY(100%);
  transition:transform .4s cubic-bezier(.2,.8,.2,1);
}
#cookie-banner.visible,#cookie-banner.show{transform:translateY(0)}
.cookie-banner-content{padding:20px var(--pad);max-width:var(--maxw);margin:0 auto}
.cookie-banner-header{display:flex;gap:20px;align-items:flex-start}
.cookie-banner-text h3{font-size:15px;font-weight:500;margin-bottom:6px;color:var(--ink);font-family:var(--sans)}
.cookie-banner-text p{font-size:13px;color:var(--ink-dim);line-height:1.5;max-width:72ch}
.cookie-banner-text p a{color:var(--red)}
.cookie-banner-actions{display:flex;gap:8px;margin-top:12px;flex-wrap:wrap}
#cookie-close{margin-left:auto;flex-shrink:0;width:36px;height:36px;border-radius:6px;border:1px solid var(--line-2);display:inline-flex;align-items:center;justify-content:center;color:var(--ink-dim);transition:all .2s}
#cookie-close:hover{border-color:var(--ink-dim);color:var(--ink)}

/* ---------- COOKIE DIALOG ---------- */
#cookie-customize-dialog{
  display:none;position:fixed;inset:0;z-index:300;
  background:var(--overlay-bg);backdrop-filter:blur(4px);
  align-items:center;justify-content:center;padding:20px;
}
#cookie-customize-dialog.visible,#cookie-customize-dialog.show{display:flex}
.cookie-dialog-content{
  background:var(--bg-elev);
  border:1px solid var(--line);
  border-radius:14px;width:100%;max-width:480px;
}
.cookie-dialog-header{padding:28px 28px 0}
.cookie-dialog-header h2{font-size:22px;font-weight:500;margin-bottom:8px}
.cookie-dialog-header p{font-size:14px;color:var(--ink-dim)}
.cookie-dialog-body{padding:20px 28px;display:flex;flex-direction:column;gap:0}
.cookie-option{display:flex;justify-content:space-between;align-items:center;gap:24px;padding:16px 0;border-top:1px solid var(--line)}
.cookie-option:first-child{border-top:0;padding-top:0}
.cookie-option-info h4{font-size:14px;font-weight:500;margin-bottom:4px}
.cookie-option-info p{font-size:13px;color:var(--ink-dim);line-height:1.4}
.cookie-option-toggle{flex-shrink:0}
.cookie-dialog-footer{padding:0 28px 28px;display:flex;justify-content:flex-end;gap:10px}

/* toggle switch */
.toggle-switch{position:relative;display:inline-block;width:44px;height:24px;flex-shrink:0}
.toggle-switch input{opacity:0;width:0;height:0;position:absolute}
.toggle-slider{
  position:absolute;cursor:pointer;inset:0;
  background:var(--line-2);border-radius:24px;
  transition:.3s;
}
.toggle-slider::before{
  content:"";position:absolute;
  width:18px;height:18px;left:3px;bottom:3px;
  background:var(--ink-mute);border-radius:50%;
  transition:.3s;
}
.toggle-switch input:checked + .toggle-slider{background:var(--red)}
.toggle-switch input:checked + .toggle-slider::before{transform:translateX(20px);background:#fff}
.toggle-switch input:disabled + .toggle-slider{opacity:.6;cursor:not-allowed}
.toggle-switch input:checked:disabled + .toggle-slider{background:#34D399}

/* ================================================ */
/* RESPONSIVE                                       */
/* ================================================ */
@media (max-width:1100px){
  .nav-links{display:none}
  .nav-mobile-toggle{display:flex}
  .nav-status{display:none}
  .hero-grid{grid-template-columns:1fr;gap:48px;min-height:auto;padding-bottom:40px}
  .hero-visual{height:480px}
  .services{grid-template-columns:repeat(2,1fr)}
  .service:nth-child(3n){border-right:1px solid var(--line)}
  .service:nth-child(2n){border-right:0}
  .why{grid-template-columns:1fr;gap:48px}
  .diag{position:static;height:auto}
  .case{grid-template-columns:1fr;gap:24px;padding:40px 0}
  .case-arrow{display:none}
  .process{grid-template-columns:repeat(2,1fr)}
  .step:nth-child(2n){border-right:0}
  .step:nth-child(1)::after,.step:nth-child(2)::after{display:none}
  .metrics{grid-template-columns:repeat(2,1fr)}
  .metric:nth-child(2){border-right:0}
  .metric:nth-child(1),.metric:nth-child(2){border-bottom:1px solid var(--line)}
  .foot-grid{grid-template-columns:1fr 1fr;gap:40px}
  .section{padding:80px 0}
  .section-head{grid-template-columns:1fr;gap:24px}
  .page-head-grid{grid-template-columns:1fr;gap:32px}
  .values{grid-template-columns:1fr}
  .value{border-right:0;border-bottom:1px solid var(--line)}
  .value:last-child{border-bottom:0}
  .team-card{grid-template-columns:1fr}
  .team-info{padding:32px}
  .case-grid{grid-template-columns:1fr}
  .contact{grid-template-columns:1fr;gap:48px;padding:48px 0}
  .timeline{grid-template-columns:1fr}
  .tl-year{border-right:0;border-bottom:1px solid var(--line);padding:20px 0 8px}
  .tl-row{padding-left:0}
  .sov-hero{grid-template-columns:1fr;gap:48px}
  .sov-right{position:static}
  .sov-pillars{grid-template-columns:repeat(2,1fr)}
  .sov-usecases{grid-template-columns:repeat(2,1fr)}
  .sov-uc{border-bottom:1px solid var(--line)}
  .sov-uc:nth-child(2n){border-right:0}
}
@media (max-width:640px){
  .services{grid-template-columns:1fr}
  .service{border-right:0!important}
  .metrics{grid-template-columns:1fr}
  .metric{border-right:0!important;border-bottom:1px solid var(--line)}
  .process{grid-template-columns:1fr}
  .step{border-right:0!important}
  .step::after{display:none}
  .foot-grid{grid-template-columns:1fr}
  .case-stats{grid-template-columns:1fr 1fr}
  .hero-meta{font-size:10px;gap:6px 16px}
  .form .row2{grid-template-columns:1fr}
  .cookie-banner-actions .btn{font-size:12px;padding:9px 14px}
  .sov-pillars{grid-template-columns:1fr}
  .sov-pill{border-right:0!important;border-bottom:1px solid var(--line)}
  .sov-usecases{grid-template-columns:1fr}
  .sov-uc{border-right:0!important}
}
