/* =========================================================
   DIGICIUS v2 — Design system
   ========================================================= */

:root{
  /* — palette — */
  --bg:           #0B1020;
  --bg-2:         #0F1729;
  --bg-3:         #131C35;
  --ink:          #F5F1EA;
  --ink-2:        #D9D4CA;
  --ink-3:        #8C8779;
  --line:         rgba(245,241,234,.10);
  --line-2:       rgba(245,241,234,.18);

  /* gradient signature (logo DC → bleu → violet → corail) */
  --g1:           #7DA1F0;
  --g2:           #B49AE0;
  --g3:           #F5A7BB;
  --g-text:       linear-gradient(105deg, var(--g1) 0%, var(--g2) 45%, var(--g3) 100%);
  --g-soft:       linear-gradient(135deg, rgba(125,161,240,.18), rgba(245,167,187,.18));
  --g-line:       linear-gradient(90deg, var(--g1), var(--g3));

  /* type */
  --serif:        "Fraunces", "Instrument Serif", "Times New Roman", serif;
  --sans:         "Geist", -apple-system, BlinkMacSystemFont, sans-serif;
  --mono:         "Geist Mono", ui-monospace, "SF Mono", monospace;

  /* spatial */
  --pad-x:        clamp(20px, 4vw, 64px);
  --maxw:         1320px;

  /* motion */
  --ease:         cubic-bezier(.22,.61,.36,1);
  --ease-out:     cubic-bezier(.16,1,.3,1);
}

/* =========================================================
   Base
   ========================================================= */
*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility; }
body{
  margin:0;
  background: var(--bg);
  color: var(--ink);
  font-family: var(--sans);
  font-weight: 400;
  font-size: 16px;
  line-height: 1.55;
  letter-spacing: -0.005em;
  overflow-x: clip;
  position: relative;
}
img,svg{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; cursor:pointer; }
::selection{ background:rgba(245,167,187,.35); color:var(--ink); }

.skip-link{
  position:absolute; top:-100px; left:1rem; padding:.75rem 1rem;
  background:var(--ink); color:var(--bg); border-radius:6px; z-index:9999;
}
.skip-link:focus{ top:1rem; }

/* Honeypot — visually hidden but in the DOM for bots to trip on */
.hp-field{
  position:absolute !important;
  left:-9999px !important;
  width:1px !important; height:1px !important;
  opacity:0 !important; pointer-events:none !important;
}

/* — texture overlays — */
.grain{
  position:fixed; inset:0; pointer-events:none; z-index:1;
  background-image:
    radial-gradient(1200px 600px at 80% -10%, rgba(245,167,187,.10), transparent 60%),
    radial-gradient(1000px 600px at -10% 30%, rgba(125,161,240,.08), transparent 60%);
}
.noise-layer{
  position:fixed; inset:0; pointer-events:none; z-index:2; opacity:.05; mix-blend-mode:overlay;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1 0 0 0 0 1 0 0 0 0 1 0 0 0 0.6 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}

/* =========================================================
   Utility bar
   ========================================================= */
.utility-bar{
  position:relative; z-index:5;
  border-bottom:1px solid var(--line);
  background: rgba(11,16,32,.7);
  backdrop-filter: blur(8px);
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: .04em;
  color: var(--ink-2);
}
.u-wrap{
  max-width: var(--maxw); margin:0 auto;
  padding: 10px var(--pad-x);
  display:flex; align-items:center; gap:14px;
}
.u-pill, .u-mark{ display:inline-flex; align-items:center; gap:10px; color: var(--ink-2); }
.u-dot{
  width:6px; height:6px; border-radius:50%;
  background: var(--g3); box-shadow:0 0 12px var(--g3);
  animation: pulse 2s var(--ease) infinite;
}
.u-sep{ width:1px; height:14px; background:var(--line-2); }
.u-meta{ color: var(--ink-3); }
.u-link{ transition:color .2s; }
.u-link:hover{ color: var(--ink); }
.u-spacer{ flex:1; }
.u-lang{ display:flex; gap:2px; }
.u-lang a, .u-lang button{
  background:none; border:none; color: var(--ink-3);
  font-family: var(--mono); font-size:12px; padding:4px 10px;
  border-radius:4px; transition: color .2s, background .2s;
  text-decoration:none; letter-spacing:.06em; line-height:1;
}
.u-lang a[aria-current="true"], .u-lang button[aria-current="true"]{
  color:var(--ink); background: rgba(255,255,255,.06);
}
.u-lang a:hover, .u-lang button:hover{ color:var(--ink); }

@keyframes pulse{
  0%,100%{ opacity:1; transform:scale(1); }
  50%{ opacity:.5; transform:scale(1.4); }
}

/* =========================================================
   Header
   ========================================================= */
.site-header{
  position:sticky; top:0; z-index:50;
  border-bottom:1px solid transparent;
  background: rgba(11,16,32,.65);
  backdrop-filter: blur(16px) saturate(140%);
  transition: border-color .3s, background .3s;
}
.site-header.is-scrolled{
  border-color: var(--line);
  background: rgba(11,16,32,.85);
}
.header-wrap{
  max-width: var(--maxw); margin:0 auto;
  padding: 16px var(--pad-x);
  display:flex; align-items:center; gap:32px;
}
.logo-svg{ height:24px; width:auto; }
.logo-text{
  font-family: var(--sans);
  font-weight: 300;
  font-size: 22px;
  letter-spacing: .25em;
  fill: var(--ink);
}
.primary-nav{ flex:1; }
.primary-nav ul{
  list-style:none; padding:0; margin:0;
  display:flex; gap:2px; justify-content:center;
}
.primary-nav a{
  display:inline-flex; align-items:baseline; gap:4px;
  padding:8px 14px; border-radius:8px;
  font-size: 14px; color: var(--ink-2);
  transition: color .2s, background .2s;
  position:relative;
}
.primary-nav a:hover{ color: var(--ink); background: rgba(255,255,255,.04); }
.header-cta{ display:flex; gap:8px; align-items:center; }

.menu-btn{
  display:none;
  background:none; border:1px solid var(--line-2);
  width:44px; height:44px; border-radius:10px;
  flex-direction:column; justify-content:center; align-items:center; gap:4px;
}
.menu-btn span{ width:18px; height:1.5px; background:var(--ink); display:block; }

/* =========================================================
   Buttons
   ========================================================= */
.btn{
  display:inline-flex; align-items:center; gap:8px;
  padding: 10px 16px;
  font-size: 14px; font-weight: 500; line-height:1;
  border-radius: 999px; border:1px solid transparent;
  transition: transform .2s var(--ease), background .25s, border-color .25s, color .25s;
  white-space:nowrap;
}
.btn-lg{ padding: 14px 22px; font-size:15px; }
.btn-block{ width:100%; justify-content:center; }
.btn-primary{
  background: var(--ink);
  color: var(--bg);
  border-color: var(--ink);
}
.btn-primary:hover{
  background: transparent; color: var(--ink);
  transform: translateY(-1px);
}
.btn-ghost{
  background: transparent;
  border-color: var(--line-2);
  color: var(--ink);
}
.btn-ghost:hover{ border-color: var(--ink); background: rgba(255,255,255,.04); }
.btn-dot{
  width:6px; height:6px; border-radius:50%;
  background: var(--g3); box-shadow:0 0 10px var(--g3);
}
.btn-link{
  color: var(--ink-2); padding: 10px 0;
  border-bottom:1px solid transparent;
  border-radius:0;
}
.btn-link:hover{ color: var(--ink); }
.btn-link .muted{ color: var(--ink-3); font-weight:400; }
.dl-icon{
  display:inline-flex; align-items:center; justify-content:center;
  width:20px; height:20px; border:1px solid var(--line-2); border-radius:50%;
  font-size:11px;
}

/* =========================================================
   Section primitives
   ========================================================= */
.section-wrap{
  max-width: var(--maxw); margin:0 auto;
  padding: clamp(80px, 12vh, 140px) var(--pad-x);
  position:relative; z-index:3;
}
.section-head{ margin-bottom: clamp(40px, 6vh, 72px); max-width: 920px; }
.section-head.row{
  display:flex; justify-content:space-between; align-items:flex-end; gap:48px;
  max-width:none;
}
.sec-num{
  display:inline-block;
  font-family: var(--mono); font-size: 11px;
  letter-spacing: .15em; text-transform: uppercase;
  color: var(--ink-3);
  margin-bottom: 24px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--line);
}
.h-display{
  font-family: var(--serif);
  font-weight: 350;
  font-size: clamp(36px, 5.5vw, 76px);
  line-height: 1.02;
  letter-spacing: -0.025em;
  margin: 0;
  font-variation-settings: "opsz" 144, "SOFT" 30;
}
.h-display em{
  font-style: italic;
  font-variation-settings: "opsz" 144, "SOFT" 50, "WONK" 1;
  background: var(--g-text);
  -webkit-background-clip: text; background-clip: text;
  color: transparent;
}
.grad-text{
  background: var(--g-text);
  -webkit-background-clip: text; background-clip: text;
  color: transparent;
  font-style: italic;
}
.tm{ font-size: .35em; vertical-align: super; color: var(--ink-3); margin-left: 4px; }
.lede{
  font-size: clamp(16px, 1.15vw, 18px);
  color: var(--ink-2);
  max-width: 56ch;
  line-height: 1.65;
}
.lede.right{ text-align:left; max-width: 36ch; }

/* =========================================================
   Hero
   ========================================================= */
.hero{
  position:relative;
  padding: clamp(60px, 10vh, 120px) 0 clamp(80px, 12vh, 140px);
  overflow: hidden;
  isolation: isolate;
}
.hero-bg{ position:absolute; inset:0; z-index:0; }
.grid-lines{ position:absolute; inset:0; width:100%; height:100%; opacity:.7; }
.orb{
  position:absolute; border-radius:50%;
  filter: blur(60px);
  opacity: .55;
}
.orb-a{ width: 520px; height:520px; background: var(--g1); top: -180px; left: -100px; }
.orb-b{ width: 480px; height:480px; background: var(--g3); bottom: -180px; right: -80px; }
.orb-c{ width: 320px; height:320px; background: var(--g2); top: 40%; left: 50%; opacity:.35; }

.hero-wrap{
  position:relative; z-index:1;
  max-width: var(--maxw); margin:0 auto;
  padding: 0 var(--pad-x);
}
.eyebrow{
  display:inline-flex; align-items:center; gap:10px;
  font-family: var(--mono); font-size:12px;
  letter-spacing:.1em; text-transform:uppercase;
  color: var(--ink-2);
  padding: 8px 14px;
  border: 1px solid var(--line-2);
  border-radius: 999px;
  background: rgba(255,255,255,.02);
  margin-bottom: 36px;
  animation: rise .9s var(--ease-out) both;
}
.eb-dot{
  width:6px; height:6px; border-radius:50%;
  background: var(--g3); box-shadow:0 0 10px var(--g3);
}
.hero-h1{
  font-family: var(--serif);
  font-weight: 320;
  font-size: clamp(40px, 7.2vw, 108px);
  line-height: 0.98;
  letter-spacing: -0.035em;
  margin: 0 0 36px;
  font-variation-settings: "opsz" 144, "SOFT" 30;
  animation: rise 1.1s .1s var(--ease-out) both;
}
.hero-h1 em{
  font-style: italic;
  font-variation-settings: "opsz" 144, "SOFT" 60, "WONK" 1;
  background: var(--g-text);
  -webkit-background-clip: text; background-clip: text;
  color: transparent;
  padding-right: .05em;
}
.hero-sub{
  max-width: 60ch;
  font-size: clamp(16px, 1.3vw, 20px);
  line-height: 1.6;
  color: var(--ink-2);
  margin: 0 0 40px;
  animation: rise 1.1s .25s var(--ease-out) both;
}
.hero-sub-em{ display:block; color: var(--ink); margin-top: 12px; }
.hero-ctas{
  display:flex; flex-wrap:wrap; align-items:center; gap:20px;
  margin-bottom: 80px;
  animation: rise 1.1s .4s var(--ease-out) both;
}

.hero-trust{
  margin: 36px 0 60px;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  padding: 18px 0;
  animation: rise 1.1s .5s var(--ease-out) both;
}
.trust-strip{
  display:flex; flex-wrap:wrap; align-items:center; gap:14px;
  font-family: var(--mono); font-size: 12px;
  color: var(--ink-2);
  letter-spacing: .04em;
}
.ts-label{
  color: var(--ink-3); text-transform: uppercase; letter-spacing: .15em;
  font-size: 11px;
}
.ts-sep{ color: var(--ink-3); }

.hero-metrics{
  display:grid; grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: var(--line);
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  animation: rise 1.1s .55s var(--ease-out) both;
}
.metric{
  padding: 28px 4px 24px;
  background: var(--bg);
}
.metric-num{
  font-family: var(--serif);
  font-weight: 400;
  font-size: clamp(40px, 5vw, 64px);
  line-height: 1;
  letter-spacing: -0.04em;
  font-variation-settings: "opsz" 144;
}
.metric-num .num{
  background: var(--g-text);
  -webkit-background-clip: text; background-clip: text;
  color: transparent;
}
.metric-num small{ font-size: .35em; letter-spacing: 0; color: var(--ink-2); -webkit-text-fill-color: var(--ink-2); }
.metric-lbl{
  margin-top: 10px;
  font-size: 13px; color: var(--ink-2);
  line-height: 1.4;
  max-width: 28ch;
}

.scroll-cue{
  position:absolute; bottom: 24px; left: 50%; transform: translateX(-50%);
  display:flex; flex-direction:column; align-items:center; gap:10px;
  font-family: var(--mono); font-size: 11px; letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--ink-3);
}
.scroll-line{
  width:1px; height: 32px;
  background: linear-gradient(180deg, transparent, var(--ink-3));
  animation: scrollFade 2s var(--ease) infinite;
}
@keyframes scrollFade{
  0%{ transform: scaleY(0); transform-origin: top; }
  50%{ transform: scaleY(1); transform-origin: top; }
  51%{ transform: scaleY(1); transform-origin: bottom; }
  100%{ transform: scaleY(0); transform-origin: bottom; }
}

@keyframes rise{
  from{ opacity:0; transform: translateY(24px); }
  to{ opacity:1; transform: translateY(0); }
}

/* =========================================================
   Logo cloud (marquee)
   ========================================================= */
.logo-cloud{
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  background: linear-gradient(180deg, transparent, rgba(255,255,255,.015), transparent);
  padding: 40px 0;
  overflow:hidden;
  position:relative; z-index:3;
}
.lc-wrap{ max-width: var(--maxw); margin:0 auto; padding: 0 var(--pad-x); }
.lc-label{
  font-family: var(--mono); font-size: 11px; letter-spacing: .15em;
  text-transform: uppercase; color: var(--ink-3);
  margin: 0 0 24px;
}
.lc-track{
  display:flex; gap:64px;
  width: max-content;
  animation: marquee 60s linear infinite;
}
.lc-row{ display:flex; gap:64px; }
.lc-item{
  font-family: var(--serif);
  font-size: clamp(20px, 2vw, 28px);
  font-style: italic;
  font-weight: 400;
  color: var(--ink-2);
  display:inline-flex; align-items:center; gap:14px;
  white-space: nowrap;
}
.lc-item i{
  font-style: normal;
  color: var(--g3); font-size: .7em;
}
@keyframes marquee{
  from{ transform: translateX(0); }
  to{ transform: translateX(-50%); }
}

/* =========================================================
   Problem
   ========================================================= */
.problem{ position:relative; z-index:3; }
.problem-grid{
  display:grid; grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--line);
  border: 1px solid var(--line);
  border-radius: 16px;
  overflow:hidden;
}
.p-card{
  background: var(--bg);
  padding: 36px 32px 32px;
  display:flex; flex-direction:column;
  transition: background .3s;
}
.p-card:hover{ background: var(--bg-2); }
.p-card-head{
  display:flex; align-items:baseline; gap:14px;
  margin-bottom: 16px;
}
.p-num{
  font-family: var(--serif); font-style: italic;
  font-size: 28px;
  color: var(--g3);
  font-variation-settings: "opsz" 144, "SOFT" 60, "WONK" 1;
}
.p-card h3{
  font-family: var(--serif); font-weight: 400;
  font-size: 28px; letter-spacing: -.02em;
  margin: 0;
  font-variation-settings: "opsz" 144;
}
.p-card p{ color: var(--ink-2); font-size: 15px; line-height: 1.6; flex:1; }
.p-tag{
  font-family: var(--mono); font-size: 11px;
  letter-spacing: .1em; text-transform: uppercase;
  color: var(--ink-3);
  margin-top: 28px; padding-top: 16px;
  border-top: 1px solid var(--line);
}

.problem-quote{
  margin-top: 72px;
  padding: 48px 0;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  position:relative;
}
.problem-quote blockquote{
  font-family: var(--serif); font-weight: 350;
  font-size: clamp(22px, 2.4vw, 36px);
  line-height: 1.3;
  letter-spacing: -.015em;
  max-width: 32ch;
  margin: 0 auto;
  text-align: center;
  font-variation-settings: "opsz" 144;
  position:relative;
}
.q-mark{
  font-family: var(--serif);
  font-size: 6em; line-height: 0;
  position:absolute; top: -.1em; left: -.4em;
  color: var(--g3); opacity: .25;
}
.problem-quote cite{
  display:block;
  text-align:center;
  margin-top: 32px;
  font-style: normal;
  font-family: var(--mono); font-size: 12px;
  letter-spacing: .1em; color: var(--ink-3);
  text-transform: uppercase;
}

/* =========================================================
   Method
   ========================================================= */
.method{ position:relative; z-index:3; background: linear-gradient(180deg, transparent, rgba(125,161,240,.025) 40%, transparent); }
.phases{
  list-style:none; padding:0; margin: 0;
  display:grid; grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--line);
  border:1px solid var(--line);
  border-radius: 18px;
  overflow:hidden;
  position:relative;
}
.phase{
  background: var(--bg);
  padding: 36px 32px 40px;
  position:relative;
  counter-increment: phase;
}
.phase::before{
  content: counter(phase);
  position:absolute; top: 24px; right: 32px;
  font-family: var(--serif); font-style: italic;
  font-size: 72px; line-height: 1;
  color: transparent;
  -webkit-text-stroke: 1px var(--line-2);
  font-variation-settings: "opsz" 144, "WONK" 1;
}
.phases{ counter-reset: phase; }
.phase-head{
  display:flex; gap:14px; align-items:center;
  font-family: var(--mono); font-size: 11px;
  letter-spacing: .1em; text-transform: uppercase;
  color: var(--ink-3);
  margin-bottom: 28px; padding-bottom: 12px;
  border-bottom: 1px solid var(--line);
}
.phase-tag{
  padding: 4px 10px;
  border:1px solid var(--line-2); border-radius: 999px;
  color: var(--g3);
}
.phase h3{
  font-family: var(--serif); font-weight: 400;
  font-size: 32px; letter-spacing: -.02em;
  margin: 0 0 16px;
  font-variation-settings: "opsz" 144;
}
.phase p{ color: var(--ink-2); font-size: 15px; line-height: 1.6; margin: 0 0 24px; }
.phase-bullets{
  list-style:none; padding:0; margin:0;
  display:grid; gap: 8px;
}
.phase-bullets li{
  font-size: 14px; color: var(--ink-2);
  padding-left: 16px; position:relative;
}
.phase-bullets li::before{
  content:""; position:absolute; left:0; top: 10px;
  width: 6px; height: 1px; background: var(--g3);
}

.method-foot{
  margin-top: 56px;
  display:grid; grid-template-columns: 1fr 3fr;
  gap: 32px;
  align-items: start;
  padding: 28px 32px;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: var(--g-soft);
}
.mf-line{ height: 1px; background: var(--g-line); margin-top: 12px; }
.method-foot p{ margin: 0; color: var(--ink); font-size: 15px; line-height: 1.6; }
.method-foot strong{ color: var(--ink); font-weight: 600; }

/* =========================================================
   Services
   ========================================================= */
.services{ position:relative; z-index:3; }
.svc-grid{
  display:grid; grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--line);
  border:1px solid var(--line);
  border-radius: 18px;
  overflow:hidden;
}
.svc-card{
  background: var(--bg);
  padding: 36px 32px 32px;
  display:flex; flex-direction:column;
  position:relative; isolation:isolate;
  transition: background .35s;
}
.svc-card::before{
  content:""; position:absolute; inset:0;
  background: var(--g-soft);
  opacity: 0; transition: opacity .35s;
  z-index: -1;
}
.svc-card:hover{ background: var(--bg-2); }
.svc-card:hover::before{ opacity: .35; }
.svc-num{
  font-family: var(--mono); font-size: 12px;
  color: var(--ink-3);
  letter-spacing: .1em;
  margin-bottom: 24px;
}
.svc-card h3{
  font-family: var(--serif); font-weight: 400;
  font-size: 26px; letter-spacing: -.02em;
  margin: 0 0 16px;
  font-variation-settings: "opsz" 144;
}
.svc-card > p{ color: var(--ink-2); font-size: 14.5px; line-height: 1.6; margin: 0 0 24px; }
.svc-list{
  list-style:none; padding:0; margin:0 0 32px;
  display:grid; gap: 8px;
}
.svc-list li{
  font-size: 13.5px; color: var(--ink-2);
  padding: 6px 0 6px 16px;
  border-top: 1px solid var(--line);
  position:relative;
}
.svc-list li:last-child{ border-bottom: 1px solid var(--line); }
.svc-list li::before{
  content: "·"; position:absolute; left:0; top:6px;
  color: var(--g3); font-weight:700; font-size: 18px;
}
.svc-link{
  font-family: var(--mono); font-size: 12px;
  letter-spacing: .08em; text-transform: uppercase;
  color: var(--ink); margin-top: auto;
  display:inline-flex; align-items:center; gap:8px;
  padding-bottom: 4px; border-bottom: 1px solid var(--line-2);
  align-self: flex-start;
  transition: border-color .25s, gap .25s;
}
.svc-link:hover{ border-color: var(--g3); gap: 14px; }

/* =========================================================
   Industries
   ========================================================= */
.industries{ position:relative; z-index:3; }
.ind-grid{
  display:grid; grid-template-columns: repeat(4, 1fr);
  gap: 24px;
}
.ind{
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 28px 24px;
  background: rgba(255,255,255,.015);
  transition: border-color .3s, transform .3s;
}
.ind:hover{ border-color: var(--line-2); transform: translateY(-4px); }
.ind-mark{
  font-family: var(--mono); font-size: 11px;
  width: 36px; height: 36px;
  display:inline-flex; align-items:center; justify-content:center;
  border: 1px solid var(--line-2); border-radius: 8px;
  margin-bottom: 24px;
  color: var(--g3);
  letter-spacing: .05em;
}
.ind h3{
  font-family: var(--serif); font-weight: 400;
  font-size: 22px; letter-spacing: -.02em;
  margin: 0 0 12px;
  font-variation-settings: "opsz" 144;
}
.ind p{ color: var(--ink-2); font-size: 14px; line-height: 1.55; margin: 0 0 20px; }
.ind-tag{
  font-family: var(--mono); font-size: 10.5px;
  letter-spacing: .1em; text-transform: uppercase;
  color: var(--ink-3);
}
.ind-decline{
  margin-top: 48px; padding: 24px 28px;
  border:1px dashed var(--line-2); border-radius: 14px;
  display:flex; gap: 24px; align-items: baseline;
  flex-wrap: wrap;
}
.ind-decline h4{
  font-family: var(--mono); font-size: 11px;
  letter-spacing: .15em; text-transform: uppercase;
  color: var(--ink-3); margin: 0;
  white-space: nowrap;
}
.ind-decline p{ margin: 0; color: var(--ink-2); font-size: 14px; flex:1; min-width: 280px; }

/* =========================================================
   Case studies
   ========================================================= */
.work{ position:relative; z-index:3; }
.case-grid{
  display:grid; gap: 24px;
}
.case{
  display:grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 64px;
  padding: 48px 0;
  border-top: 1px solid var(--line);
  align-items: start;
}
.case:last-child{ border-bottom: 1px solid var(--line); }
.case-meta{
  font-family: var(--mono); font-size: 11px;
  letter-spacing: .1em; text-transform: uppercase;
  color: var(--ink-3);
  display:flex; gap: 14px; flex-wrap: wrap;
  margin-bottom: 20px;
}
.case-sector{ color: var(--g3); }
.case-title{
  font-family: var(--serif); font-weight: 350;
  font-size: clamp(28px, 3vw, 44px);
  letter-spacing: -.025em; line-height: 1.05;
  margin: 0 0 24px;
  font-variation-settings: "opsz" 144;
}
.case-title em{
  font-style: italic;
  font-variation-settings: "opsz" 144, "WONK" 1;
  color: var(--g3);
}
.case-summary{
  color: var(--ink-2); font-size: 15px; line-height: 1.6;
  margin: 0; max-width: 56ch;
}
.case-summary em{ color: var(--ink); font-style: italic; }
.case-kpis{
  display:grid; grid-template-columns: 1fr 1fr;
  gap: 1px;
  background: var(--line);
  border: 1px solid var(--line);
  border-radius: 12px; overflow: hidden;
  margin: 0;
}
.case-kpis div{
  background: var(--bg);
  padding: 22px 20px;
}
.case-kpis dt{
  font-family: var(--mono); font-size: 11px;
  letter-spacing: .08em; text-transform: uppercase;
  color: var(--ink-3); margin-bottom: 10px;
}
.case-kpis dd{
  font-family: var(--serif); font-weight: 400;
  font-size: clamp(28px, 3vw, 40px);
  letter-spacing: -.03em; line-height: 1;
  margin: 0;
  background: var(--g-text);
  -webkit-background-clip: text; background-clip: text;
  color: transparent;
  font-variation-settings: "opsz" 144;
}

/* =========================================================
   Testimonials
   ========================================================= */
.testimonials{ position:relative; z-index:3; }
.t-grid{
  display:grid;
  grid-template-columns: 1.6fr 1fr 1fr;
  grid-template-rows: auto auto;
  gap: 24px;
}
.t-card{
  margin: 0;
  padding: 32px 28px;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: rgba(255,255,255,.015);
  display:flex; flex-direction:column;
  transition: border-color .3s, transform .3s;
}
.t-card:hover{ border-color: var(--line-2); transform: translateY(-2px); }
.t-card blockquote{
  margin: 0 0 24px;
  font-family: var(--serif); font-weight: 350;
  font-size: 19px; line-height: 1.45;
  letter-spacing: -.015em;
  position:relative;
  font-variation-settings: "opsz" 144;
}
.t-card-feat{ grid-row: 1 / span 2; padding: 48px 40px; background: var(--g-soft); border-color: transparent; }
.t-card-feat blockquote{ font-size: clamp(22px, 2vw, 28px); }
.t-mark{
  position:absolute; top: -.4em; left: -.3em;
  font-family: var(--serif); font-size: 5em;
  line-height: 0; opacity: .15; color: var(--g3);
}
.t-card figcaption{
  margin-top: auto;
  padding-top: 18px; border-top: 1px solid var(--line);
  display:flex; flex-direction:column; gap: 4px;
  font-family: var(--mono); font-size: 12px;
  letter-spacing: .04em;
}
.t-name{ color: var(--ink); }
.t-role{ color: var(--ink-3); }

/* =========================================================
   Calculator
   ========================================================= */
.calc{ position:relative; z-index:3; }
.calc-aside{
  max-width: 36ch;
  font-family: var(--mono); font-size: 12px;
  color: var(--ink-3); line-height: 1.55;
  padding-left: 16px; border-left: 1px solid var(--line-2);
}
.calc-grid{
  display:grid; grid-template-columns: 1.3fr 1fr;
  gap: 48px; align-items: start;
  margin-top: 64px;
}
.calc-inputs{
  display:grid; gap: 36px;
}
.calc-row label{
  display:flex; justify-content:space-between; align-items: baseline;
  margin-bottom: 12px;
  font-size: 14px; color: var(--ink-2);
}
.calc-row output{
  font-family: var(--serif); font-weight: 400;
  font-size: 32px; line-height: 1; letter-spacing: -.02em;
  background: var(--g-text);
  -webkit-background-clip: text; background-clip: text;
  color: transparent;
  font-variation-settings: "opsz" 144;
}
.calc-row input[type=range]{
  -webkit-appearance:none; appearance:none;
  width: 100%; height: 4px; background: var(--line);
  border-radius: 4px; outline: none;
}
.calc-row input[type=range]::-webkit-slider-thumb{
  -webkit-appearance:none;
  width: 22px; height: 22px;
  border-radius: 50%;
  background: var(--ink);
  border: 4px solid var(--bg);
  box-shadow: 0 0 0 1px var(--g3), 0 0 16px rgba(245,167,187,.4);
  cursor: grab;
}
.calc-row input[type=range]::-moz-range-thumb{
  width: 22px; height: 22px; border-radius:50%;
  background: var(--ink); border: 4px solid var(--bg);
  box-shadow: 0 0 0 1px var(--g3);
  cursor:grab;
}
.r-marks{
  display:flex; justify-content:space-between;
  margin-top: 8px;
  font-family: var(--mono); font-size: 11px; color: var(--ink-3);
}

.calc-out{
  padding: 28px 32px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: rgba(255,255,255,.015);
  position: sticky; top: 110px;
}
.co-row{
  display:flex; justify-content:space-between; align-items: baseline;
  padding: 14px 0;
  border-bottom: 1px solid var(--line);
  font-size: 14px;
}
.co-row:last-of-type{ border-bottom: none; }
.co-lbl{ color: var(--ink-2); }
.co-val{
  font-family: var(--serif); font-size: 18px;
  font-variation-settings: "opsz" 144;
}
.co-row-feat{ margin-top: 8px; padding-top: 22px; border-top: 1px solid var(--line-2); border-bottom: none; }
.co-row-feat .co-lbl{ color: var(--ink); font-weight: 500; }
.co-val-big{
  font-size: clamp(28px, 3vw, 42px);
  background: var(--g-text);
  -webkit-background-clip: text; background-clip: text;
  color: transparent;
  letter-spacing: -.02em;
}
.co-cta{ width: 100%; justify-content: center; margin-top: 22px; }

/* =========================================================
   Insights / Articles
   ========================================================= */
.insights{ position:relative; z-index:3; }
.art-grid{
  display:grid;
  grid-template-columns: 1.6fr 1fr 1fr;
  grid-template-rows: auto auto;
  gap: 1px;
  background: var(--line);
  border: 1px solid var(--line);
  border-radius: 16px;
  overflow: hidden;
}
.art{
  background: var(--bg);
  padding: 28px 28px 32px;
  display:flex; flex-direction:column;
  transition: background .3s;
  cursor:pointer;
}
.art:hover{ background: var(--bg-2); }
.art-feat{ grid-row: 1 / span 2; padding: 44px 40px; }
.art-meta{
  display:flex; justify-content:space-between;
  font-family: var(--mono); font-size: 11px;
  letter-spacing: .08em; text-transform: uppercase;
  color: var(--ink-3);
  margin-bottom: 24px;
}
.art-cat{ color: var(--g3); }
.art h3{
  font-family: var(--serif); font-weight: 400;
  font-size: 22px; letter-spacing: -.02em;
  margin: 0 0 16px; line-height: 1.2;
  font-variation-settings: "opsz" 144;
  flex: 1;
}
.art-feat h3{ font-size: clamp(28px, 2.6vw, 40px); line-height: 1.1; }
.art p{ color: var(--ink-2); font-size: 14.5px; line-height: 1.55; margin: 0 0 24px; }
.art-foot{
  font-family: var(--mono); font-size: 11px;
  color: var(--ink-3); letter-spacing: .04em;
  display:flex; gap: 8px; margin-top: auto;
  padding-top: 16px; border-top: 1px solid var(--line);
}

/* =========================================================
   About
   ========================================================= */
.about{ position:relative; z-index:3; }
.about-grid{
  display:grid; grid-template-columns: 1.3fr 1fr;
  gap: 80px;
  align-items: start;
}
.about-left .h-display{ margin-bottom: 32px; }
.about-body{
  color: var(--ink-2); font-size: 16.5px; line-height: 1.65;
  max-width: 52ch;
  margin: 0 0 32px;
}
.about-body strong{ color: var(--ink); font-weight: 500; }
.certs{
  list-style:none; padding:0;
  display:grid; grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin: 0 0 40px;
}
.certs li{
  display:flex; align-items:center; gap: 10px;
  font-size: 13px; color: var(--ink-2);
  padding: 8px 12px;
  border: 1px solid var(--line); border-radius: 8px;
}
.certs li span{ color: var(--g3); }
.about-cta{ display:flex; gap: 16px; align-items: center; flex-wrap: wrap; }

.bio-stats-label{
  font-family: var(--mono); font-size: 11px;
  letter-spacing: .15em; text-transform: uppercase;
  color: var(--ink-3);
  margin: 0 0 20px;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--line);
}
.bio-stats{
  list-style:none; padding:0; margin: 0;
  display:grid; grid-template-columns: 1fr 1fr;
  gap: 1px;
  background: var(--line);
  border: 1px solid var(--line);
  border-radius: 14px; overflow: hidden;
}
.bio-stats li{
  background: var(--bg);
  padding: 18px 20px;
  display:flex; flex-direction: column; gap: 6px;
}
.bio-stats span{
  font-family: var(--serif); font-weight: 400;
  font-size: 28px; letter-spacing: -.02em; line-height: 1;
  background: var(--g-text);
  -webkit-background-clip: text; background-clip: text;
  color: transparent;
  font-variation-settings: "opsz" 144;
}
.bio-stats i{
  font-style: normal;
  font-family: var(--mono); font-size: 11px;
  letter-spacing: .08em; text-transform: uppercase;
  color: var(--ink-3);
}

/* =========================================================
   Lead magnet
   ========================================================= */
.magnet{ position:relative; z-index:3; }
.mg-card{
  display:grid; grid-template-columns: 1.4fr 1fr;
  gap: 64px;
  padding: 64px;
  border: 1px solid var(--line);
  border-radius: 24px;
  background:
    radial-gradient(ellipse at top right, rgba(245,167,187,.12), transparent 60%),
    radial-gradient(ellipse at bottom left, rgba(125,161,240,.10), transparent 60%),
    var(--bg-2);
  align-items: center;
}
.mg-left .h-display{ margin-bottom: 24px; }
.mg-list{
  list-style:none; padding:0; margin: 28px 0 0;
  display:grid; gap: 8px;
}
.mg-list li{
  font-size: 14px; color: var(--ink-2);
  padding-left: 22px; position:relative;
}
.mg-list li::before{
  content: "↓"; position:absolute; left:0; top:0;
  font-family: var(--mono); color: var(--g3);
}

.mg-form{
  display:flex; flex-direction:column; gap: 14px;
  padding: 32px;
  border: 1px solid var(--line-2);
  border-radius: 16px;
  background: var(--bg);
}
.mg-form-head{
  display:flex; align-items:center; gap: 10px;
  font-family: var(--mono); font-size: 12px;
  letter-spacing: .1em; text-transform: uppercase;
  color: var(--ink-3);
  padding-bottom: 16px; border-bottom: 1px solid var(--line);
}
.mg-head-num{ color: var(--g3); font-size: 16px; }
.mg-form label{ display:grid; gap: 8px; }
.mg-form label span{
  font-family: var(--mono); font-size: 11px;
  letter-spacing: .08em; text-transform: uppercase;
  color: var(--ink-3);
}
.mg-form input{
  background: var(--bg-2);
  border: 1px solid var(--line);
  color: var(--ink);
  padding: 12px 14px;
  border-radius: 8px;
  font: inherit;
  transition: border-color .2s;
}
.mg-form input:focus{ outline: none; border-color: var(--g3); }
.mg-fine{
  margin: 0; font-size: 11px; color: var(--ink-3);
  font-family: var(--mono); letter-spacing: .04em;
}

/* =========================================================
   FAQ
   ========================================================= */
.faq{ position:relative; z-index:3; }
.faq-list{
  border-top: 1px solid var(--line);
}
.faq-list details{
  border-bottom: 1px solid var(--line);
  padding: 24px 0;
}
.faq-list summary{
  list-style: none;
  display:flex; justify-content: space-between; align-items: center;
  gap: 24px;
  cursor: pointer;
  font-family: var(--serif); font-weight: 400;
  font-size: clamp(20px, 1.8vw, 26px);
  letter-spacing: -.015em;
  font-variation-settings: "opsz" 144;
  transition: color .2s;
}
.faq-list summary::-webkit-details-marker{ display:none; }
.faq-list summary:hover{ color: var(--g3); }
.faq-list summary i{
  flex-shrink: 0;
  width: 32px; height: 32px;
  border: 1px solid var(--line-2); border-radius: 50%;
  position:relative;
  transition: border-color .25s, transform .25s;
}
.faq-list summary i::before,
.faq-list summary i::after{
  content:""; position:absolute;
  top: 50%; left: 50%;
  width: 12px; height: 1.5px;
  background: var(--ink);
  transform: translate(-50%, -50%);
  transition: transform .25s;
}
.faq-list summary i::after{ transform: translate(-50%, -50%) rotate(90deg); }
.faq-list details[open] summary i{ border-color: var(--g3); }
.faq-list details[open] summary i::after{ transform: translate(-50%, -50%) rotate(0deg); }
.faq-list details p{
  margin: 18px 0 0;
  color: var(--ink-2); font-size: 15px; line-height: 1.65;
  max-width: 70ch;
}

/* =========================================================
   Contact
   ========================================================= */
.contact{ position:relative; z-index:3; }
.contact-grid{
  display:grid; grid-template-columns: 1fr 1.2fr;
  gap: 80px;
  align-items: start;
}
.ct-left .h-display{ margin-bottom: 24px; }
.ct-meta{
  list-style:none; padding:0; margin: 40px 0 0;
  display:grid; gap: 14px;
}
.ct-meta li{
  display:grid; grid-template-columns: 80px 1fr;
  gap: 16px; align-items: baseline;
  font-size: 14px; color: var(--ink);
  padding-bottom: 14px; border-bottom: 1px solid var(--line);
}
.ct-lbl{
  font-family: var(--mono); font-size: 11px;
  letter-spacing: .12em; text-transform: uppercase;
  color: var(--ink-3);
}

.ct-form{
  padding: 40px;
  border: 1px solid var(--line);
  border-radius: 20px;
  background: var(--bg-2);
  display:grid; gap: 18px;
}
.ct-row{ display:grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.ct-form label{ display:grid; gap: 8px; }
.ct-form label.full{ grid-column: 1 / -1; }
.ct-form label > span{
  font-family: var(--mono); font-size: 11px;
  letter-spacing: .08em; text-transform: uppercase;
  color: var(--ink-3);
}
.ct-form input,
.ct-form select,
.ct-form textarea{
  background: var(--bg);
  border: 1px solid var(--line);
  color: var(--ink);
  padding: 12px 14px;
  border-radius: 10px;
  font: inherit;
  transition: border-color .2s;
}
.ct-form input:focus,
.ct-form select:focus,
.ct-form textarea:focus{ outline: none; border-color: var(--g3); }
.ct-form textarea{ resize: vertical; }

.ct-chips{ display:flex; flex-wrap: wrap; gap: 8px; }
.chip{
  position:relative; cursor:pointer;
  display: inline-flex;
  padding: 8px 14px;
  border: 1px solid var(--line);
  border-radius: 999px;
  font-size: 13px; color: var(--ink-2);
  transition: border-color .2s, color .2s, background .2s;
}
.chip input{ position:absolute; opacity: 0; pointer-events: none; }
.chip:hover{ border-color: var(--line-2); }
.chip:has(input:checked){
  border-color: var(--g3);
  background: var(--g-soft);
  color: var(--ink);
}

.ct-actions{
  display:flex; align-items:center; gap: 16px; flex-wrap: wrap;
  margin-top: 8px;
}
.ct-or{ color: var(--ink-3); font-family: var(--mono); font-size: 12px; }
.ct-fine{
  margin: 0; font-size: 12px;
  font-family: var(--mono); color: var(--ink-3); letter-spacing: .03em;
}
.ct-fine a{ color: var(--ink-2); border-bottom: 1px solid var(--line-2); }

/* =========================================================
   Legal pages (Privacy / Cookies / Imprint)
   ========================================================= */
.legal-page{
  max-width: 820px;
  margin: 0 auto;
  padding: clamp(60px, 8vh, 100px) var(--pad-x) clamp(60px, 8vh, 100px);
  position:relative; z-index:3;
}
.legal-page .sec-num{
  display:inline-block;
  font-family: var(--mono); font-size: 11px;
  letter-spacing: .15em; text-transform: uppercase;
  color: var(--ink-3);
  margin-bottom: 24px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--line);
}
.legal-page h1{
  font-family: var(--serif);
  font-weight: 350;
  font-size: clamp(36px, 5vw, 64px);
  line-height: 1.02;
  letter-spacing: -0.025em;
  margin: 0 0 16px;
  font-variation-settings: "opsz" 144, "SOFT" 30;
}
.legal-page h1 em{
  font-style: italic;
  font-variation-settings: "opsz" 144, "WONK" 1;
  background: var(--g-text);
  -webkit-background-clip: text; background-clip: text;
  color: transparent;
}
.legal-page .last-updated{
  font-family: var(--mono); font-size: 12px;
  letter-spacing: .04em; color: var(--ink-3);
  margin: 0 0 48px;
  padding-bottom: 32px;
  border-bottom: 1px solid var(--line);
}
.legal-page h2{
  font-family: var(--serif);
  font-weight: 400;
  font-size: clamp(22px, 2vw, 28px);
  letter-spacing: -.015em;
  margin: 48px 0 16px;
  font-variation-settings: "opsz" 144;
}
.legal-page h3{
  font-family: var(--sans);
  font-weight: 600;
  font-size: 16px;
  margin: 28px 0 10px;
  color: var(--ink);
}
.legal-page p, .legal-page li{
  color: var(--ink-2);
  font-size: 15.5px;
  line-height: 1.7;
  max-width: 70ch;
}
.legal-page p{ margin: 0 0 14px; }
.legal-page ul, .legal-page ol{ padding-left: 22px; margin: 0 0 14px; }
.legal-page li{ margin-bottom: 6px; }
.legal-page a{
  color: var(--ink);
  border-bottom: 1px solid var(--line-2);
  transition: border-color .2s;
}
.legal-page a:hover{ border-color: var(--g3); }
.legal-page strong{ color: var(--ink); font-weight: 600; }
.legal-page .legal-meta{
  margin-top: 56px;
  padding: 24px 28px;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: rgba(255,255,255,.02);
}
.legal-page .legal-meta p{ margin: 0; font-size: 14px; }
.legal-page .back-link{
  display:inline-flex; align-items:center; gap: 8px;
  font-family: var(--mono); font-size: 12px;
  letter-spacing: .08em; text-transform: uppercase;
  color: var(--ink-2);
  margin-bottom: 40px;
  padding-bottom: 6px;
  border-bottom: 1px solid var(--line);
  transition: color .2s, border-color .2s;
}
.legal-page .back-link:hover{ color: var(--ink); border-color: var(--g3); }

/* =========================================================
   Footer
   ========================================================= */
.site-footer{
  position:relative; z-index:3;
  border-top: 1px solid var(--line);
  padding-top: 80px;
  margin-top: 40px;
  overflow:hidden;
}
.footer-wrap{ max-width: var(--maxw); margin:0 auto; padding: 0 var(--pad-x) 0; }
.ft-top{
  display:grid; grid-template-columns: 1fr 2fr;
  gap: 80px;
  padding-bottom: 64px;
  border-bottom: 1px solid var(--line);
}
.ft-brand .logo-svg{ height: 28px; margin-bottom: 24px; }
.ft-tag{
  color: var(--ink-2); font-size: 14.5px; line-height: 1.55;
  max-width: 36ch;
}
.ft-cols{
  display:grid; grid-template-columns: repeat(3, 1fr);
  gap: 32px;
}
.ft-cols h4{
  font-family: var(--mono); font-size: 11px;
  letter-spacing: .15em; text-transform: uppercase;
  color: var(--ink-3); margin: 0 0 20px;
}
.ft-cols ul{ list-style:none; padding:0; margin: 0; display:grid; gap: 10px; }
.ft-cols a, .ft-cols li{ font-size: 14px; color: var(--ink-2); transition: color .2s; }
.ft-cols a:hover{ color: var(--ink); }
.ft-co{
  font-family: var(--sans);
  font-weight: 600;
  letter-spacing: .04em;
  color: var(--ink);
  display: inline-block;
  margin-bottom: 4px;
}
.ft-vat{
  font-family: var(--mono);
  font-size: 12px;
  color: var(--ink-3);
  letter-spacing: .03em;
  padding-top: 8px;
  margin-top: 4px;
  border-top: 1px solid var(--line);
}

.ft-bottom{
  padding: 32px 0 40px;
  display:flex; flex-wrap: wrap; align-items: center;
  gap: 24px; justify-content: space-between;
  font-family: var(--mono); font-size: 12px;
  color: var(--ink-3); letter-spacing: .03em;
}
.ft-bottom ul{ list-style:none; padding:0; margin:0; display:flex; gap: 18px; }
.ft-bottom a{ color: var(--ink-2); }
.ft-bottom a:hover{ color: var(--ink); }
.ft-eu{ margin: 0; }

.ft-mono{
  overflow:hidden;
  line-height: 0;
  margin: 0 calc(var(--pad-x) * -1);
}
.ft-monogram{
  font-family: var(--sans);
  font-weight: 200;
  font-size: 220px;
  letter-spacing: .12em;
}

/* =========================================================
   Sticky CTA
   ========================================================= */
.sticky-cta{
  position: fixed; bottom: 22px; right: 22px;
  z-index: 60;
  display: inline-flex; align-items: center; gap: 10px;
  padding: 14px 20px 14px 18px;
  background: var(--ink); color: var(--bg);
  border-radius: 999px;
  font-size: 14px; font-weight: 500;
  box-shadow: 0 16px 40px rgba(0,0,0,.4), 0 0 0 1px var(--line);
  transform: translateY(120%);
  transition: transform .5s var(--ease-out), background .25s, color .25s;
}
.sticky-cta.is-visible{ transform: translateY(0); }
.sticky-cta:hover{ background: var(--g3); }
.sc-pulse{
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--g3);
  position: relative;
}
.sc-pulse::after{
  content:""; position:absolute; inset:0;
  border-radius:50%; background: var(--g3);
  animation: ping 1.6s ease-out infinite;
}
@keyframes ping{
  0%{ transform: scale(1); opacity:.8; }
  100%{ transform: scale(2.6); opacity:0; }
}

/* =========================================================
   Scroll reveal
   ========================================================= */
.reveal{ opacity: 0; transform: translateY(28px); transition: opacity .9s var(--ease-out), transform .9s var(--ease-out); }
.reveal.is-visible{ opacity: 1; transform: translateY(0); }

/* =========================================================
   Responsive
   ========================================================= */
@media (max-width: 1080px){
  .primary-nav{ display:none; }
  .menu-btn{ display:flex; }
  .hero-metrics{ grid-template-columns: repeat(2, 1fr); }
  .problem-grid, .svc-grid, .phases{ grid-template-columns: 1fr; }
  .ind-grid{ grid-template-columns: repeat(2, 1fr); }
  .case{ grid-template-columns: 1fr; gap: 32px; }
  .t-grid{ grid-template-columns: 1fr 1fr; }
  .t-card-feat{ grid-column: 1 / -1; grid-row: auto; }
  .art-grid{ grid-template-columns: 1fr 1fr; }
  .art-feat{ grid-column: 1 / -1; grid-row: auto; }
  .about-grid, .contact-grid, .mg-card{ grid-template-columns: 1fr; gap: 48px; }
  .calc-grid{ grid-template-columns: 1fr; }
  .calc-out{ position: static; }
  .method-foot{ grid-template-columns: 1fr; }
  .ft-top{ grid-template-columns: 1fr; }
  .ft-cols{ grid-template-columns: 1fr 1fr; }
  .ft-monogram{ font-size: 120px; }
}
@media (max-width: 640px){
  .u-wrap{ flex-wrap: wrap; gap: 8px; font-size: 11px; }
  .u-sep, .u-spacer, .u-lang{ display:none; }
  .header-cta .btn-ghost{ display:none; }
  .hero-metrics{ grid-template-columns: 1fr; }
  .section-head.row{ flex-direction: column; align-items: flex-start; }
  .ind-grid, .t-grid, .art-grid{ grid-template-columns: 1fr; }
  .ct-row{ grid-template-columns: 1fr; }
  .mg-card{ padding: 32px 24px; }
  .ft-cols{ grid-template-columns: 1fr; }
  .case-kpis{ grid-template-columns: 1fr 1fr; }
  .sticky-cta .sc-label{ display:none; }
  .sticky-cta{ padding: 14px; }
}
