:root {
  /* Constants - never flip (brand colors, text-on-orange) */
  --ink:#0e0e0e; --orange:#ff6a1a; --rust:#c44818; --warm:#efece6; --accentText:#ff6a1a;
  /* Theme-aware (default = dark) */
  --paper:#0a0a0a; --cream:#f4f1ea;
  --rule:#1c1c1c; --ruleSoft:#262626;
  --mute:#8b8b8b; --fog:#b8b3a8;
  --surface:#131313; --hero-bg:#1a1a1a; --marquee-ghost:#1a1a1a;
  --nav-bg:rgba(10,10,10,0.86);
}

/* Light theme - page surfaces & text flip; brand orange and ink stay constant. */
[data-theme="light"] {
  --paper:var(--warm);
  --cream:var(--ink);
  --rule:#d4d0c6;
  --ruleSoft:#c4bfb2;
  --mute:#6b6b6b;
  --fog:#5a5a5a;
  --accentText:#b83e13;
  --surface:#ffffff;
  --hero-bg:#f7f5ef;
  --marquee-ghost:#d8d3c5;
  --nav-bg:rgba(239,236,230,0.86);
}
* { box-sizing:border-box; }
html { scroll-behavior:smooth; }
html, body { margin:0; padding:0; }
body {
  background:var(--paper); color:var(--cream);
  font-family:"Archivo", system-ui, sans-serif;
  -webkit-font-smoothing:antialiased;
  line-height:1.5;
}
::selection { background:var(--orange); color:var(--ink); }
a { color:inherit; text-decoration:none; }
.mk-cyr {
  font-family: "Noto Sans", "Segoe UI", Arial, sans-serif;
  font-style: normal;
  font-language-override: "MKD";
  font-feature-settings: "locl" 1;
}

/* ====== Grid container ====== */
.container { max-width: 1320px; margin:0 auto; padding: 0 32px; }

/* ====== NAV ====== */
header.nav {
  position:sticky; top:0; z-index:50;
  background: var(--nav-bg);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--rule);
}
.nav-inner {
  display:grid; grid-template-columns:auto 1fr auto; align-items:center;
  height:64px; gap:32px;
}
.brand { display:flex; align-items:center; gap:12px; }
.brand .wm { font-family:"JetBrains Mono", monospace; font-weight:700; font-size:15px; letter-spacing:-0.02em; }
.nav-links { display:flex; gap:28px; justify-self:center; font-family:"JetBrains Mono", monospace; font-size:11px; text-transform:uppercase; letter-spacing:0.18em; color:var(--fog); }
.nav-links a:hover { color:var(--accentText); }
.nav-cta {
  background:var(--orange); color:var(--ink);
  padding:10px 16px;
  font-family:"JetBrains Mono", monospace; font-size:11px; letter-spacing:0.16em; text-transform:uppercase; font-weight:700;
  transition: background 0.2s;
}
.nav-cta:hover { background:#ffb088; }
.nav-right { display:flex; align-items:center; gap:12px; }
.theme-toggle {
  background: transparent;
  border: 1px solid var(--ruleSoft);
  padding: 9px 12px;
  cursor: pointer;
  font-family: "JetBrains Mono", monospace;
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--fog);
  transition: border-color 0.15s, color 0.15s;
}
.theme-toggle:hover { border-color: var(--cream); color: var(--cream); }
.theme-toggle::before { content: "Light"; }
[data-theme="light"] .theme-toggle::before { content: "Dark"; }
@media (max-width: 760px) {
  .nav-links { display:none; }
  .theme-toggle { display:none; }
}

/* ====== HERO ====== */
.hero { padding: 96px 0 80px; border-bottom:1px solid var(--rule); }
.hero-grid { display:grid; grid-template-columns: 1.4fr 1fr; gap:64px; align-items:center; }
.hero .eyebrow { font-family:"JetBrains Mono", monospace; font-size:11px; letter-spacing:0.2em; text-transform:uppercase; color:var(--accentText); margin: 0 0 28px; display:flex; align-items:center; gap:12px; }
.hero .eyebrow::before { content:""; width:24px; height:1px; background:var(--accentText); }
.hero h1 { font-size: clamp(48px, 6vw, 96px); line-height:0.96; letter-spacing:-0.035em; font-weight:800; margin:0 0 28px; }
.hero h1 em { font-style:normal; color:var(--accentText); }
.hero .lede { font-size:20px; line-height:1.5; color:var(--fog); max-width: 540px; margin: 0 0 36px; }
.hero .ctas { display:flex; gap:14px; flex-wrap:wrap; }
.btn-primary {
  background:var(--orange); color:var(--ink);
  padding:14px 22px;
  font-family:"JetBrains Mono", monospace; font-size:12px; letter-spacing:0.18em; text-transform:uppercase; font-weight:700;
  transition: background 0.2s;
}
.btn-primary:hover { background:#ffb088; }
.btn-ghost {
  padding:14px 22px;
  font-family:"JetBrains Mono", monospace; font-size:12px; letter-spacing:0.18em; text-transform:uppercase;
  border:1px solid var(--ruleSoft);
  transition: border-color 0.2s, color 0.2s;
}
.btn-ghost:hover { border-color:var(--cream); color:var(--cream); }

/* hero animation panel */
.hero-art {
  aspect-ratio: 1;
  background: var(--hero-bg);
  border:1px solid var(--rule);
  padding:48px;
  display:flex; align-items:center; justify-content:center;
  position:relative;
  overflow:hidden;
}
.hero-art::before {
  content: "SKLOP / MARK · INTERACTIVE";
  position:absolute; top:14px; left:18px;
  font-family:"JetBrains Mono", monospace; font-size:10px; letter-spacing:0.16em; text-transform:uppercase; color:var(--mute);
  z-index:2;
}
.hero-art::after {
  content: "SKL · 001";
  position:absolute; bottom:14px; right:18px;
  font-family:"JetBrains Mono", monospace; font-size:10px; letter-spacing:0.16em; text-transform:uppercase; color:var(--accentText);
  z-index:2;
}
/* explode-on-hover logo - static at rest, pieces fly outward on hover, snap back smoothly */
.floaty-logo { width:100%; max-width:340px; }
.floaty-logo .cell, .floaty-logo .core {
  transform-origin:center;
  transform-box: fill-box;
  will-change: transform;
  transition:
    transform 1.1s cubic-bezier(.22,1,.36,1),
    opacity 0.6s ease;
  transform: translate(0,0) rotate(0deg);
}
.hero-art:hover .floaty-logo .cell {
  transition: transform 0.9s cubic-bezier(.34,1.4,.5,1);
  transform: translate(calc(var(--ex, 0) * 1px), calc(var(--ey, 0) * 1px)) rotate(var(--er, 0deg));
}
.hero-art:hover .floaty-logo .core {
  transition: transform 0.7s cubic-bezier(.34,1.3,.5,1);
  transform: scale(1.15);
}
.hero-art:hover .floaty-logo .cell:nth-of-type(1) { transition-delay: 0.00s; }
.hero-art:hover .floaty-logo .cell:nth-of-type(2) { transition-delay: 0.04s; }
.hero-art:hover .floaty-logo .cell:nth-of-type(3) { transition-delay: 0.08s; }
.hero-art:hover .floaty-logo .cell:nth-of-type(4) { transition-delay: 0.04s; }
.hero-art:hover .floaty-logo .cell:nth-of-type(5) { transition-delay: 0.04s; }
.hero-art:hover .floaty-logo .cell:nth-of-type(6) { transition-delay: 0.08s; }
.hero-art:hover .floaty-logo .cell:nth-of-type(7) { transition-delay: 0.04s; }
.hero-art:hover .floaty-logo .cell:nth-of-type(8) { transition-delay: 0.00s; }

/* meta strip */
.meta-strip { padding: 24px 0; border-bottom: 1px solid var(--rule); display:grid; grid-template-columns: repeat(4, 1fr); gap:32px; font-family:"JetBrains Mono", monospace; font-size:11px; text-transform:uppercase; letter-spacing:0.16em; color:var(--mute); }
.meta-strip .lab { color:var(--accentText); display:block; margin-bottom:6px; }

/* ====== SECTION CHROME ====== */
section { padding: 120px 0; border-bottom: 1px solid var(--rule); position:relative; }
.sec-head { display:grid; grid-template-columns: auto 1fr; gap:24px; align-items:end; padding-bottom: 24px; border-bottom:1px solid var(--rule); margin-bottom:56px; }
.sec-head .num { font-family:"JetBrains Mono", monospace; font-size:11px; letter-spacing:0.2em; color:var(--accentText); padding-bottom:10px; }
.sec-head h2 { margin:0; font-weight:800; font-size: clamp(36px, 4vw, 56px); letter-spacing:-0.025em; line-height:1; }
.sec-head h2 em { font-style:normal; color:var(--accentText); }
.sec-lede { font-size: 20px; max-width: 760px; line-height:1.55; color: var(--fog); margin: 0 0 56px; }

/* ====== SERVICES ====== */
.services { display:grid; grid-template-columns: repeat(3, 1fr); gap:0; border:1px solid var(--rule); }
.service { padding: 36px 32px; border-right:1px solid var(--rule); display:flex; flex-direction:column; gap:20px; min-height:340px; }
.service:last-child { border-right:none; }
.service .num-tag { font-family:"JetBrains Mono", monospace; font-size:11px; letter-spacing:0.18em; text-transform:uppercase; color:var(--accentText); }
.service h3 { font-size: 26px; line-height:1.15; letter-spacing:-0.02em; font-weight:700; margin:0; }
.service .desc { color:var(--fog); font-size:15px; line-height:1.6; flex:1; }
.service ul { list-style:none; padding:0; margin:0; font-family:"JetBrains Mono", monospace; font-size:10.5px; letter-spacing:0.14em; text-transform:uppercase; color:var(--mute); }
.service ul li { padding:6px 0; border-top:1px solid var(--rule); }
.service ul li:last-child { padding-bottom:0; }
@media (max-width:960px){ .services { grid-template-columns: 1fr; } .service { border-right:none; border-bottom:1px solid var(--rule);} .service:last-child { border-bottom:none; } }

/* ====== ETHOS ====== */
.ethos-grid { display:grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items:start; }
.ethos-art {
  aspect-ratio: 1;
  background: var(--surface);
  border:1px solid var(--rule);
  padding: 56px;
  display:flex; align-items:center; justify-content:center;
  position:relative;
  overflow:hidden;
}
.ethos-art::before {
  content:"02 / PULSE · 1.8S LOOP";
  position:absolute; top:14px; left:18px;
  font-family:"JetBrains Mono", monospace; font-size:10px; letter-spacing:0.16em; text-transform:uppercase; color:var(--mute);
}
.ethos-art::after {
  content:"SKL · 002";
  position:absolute; bottom:14px; right:18px;
  font-family:"JetBrains Mono", monospace; font-size:10px; letter-spacing:0.16em; text-transform:uppercase; color:var(--accentText);
}
/* pulse */
.anim-pulse .core { animation: pulseCore 1.8s ease-in-out infinite; transform-origin:center; }
.anim-pulse .ring { stroke:#ff6a1a; opacity:0; animation: pulseRing 1.8s ease-out infinite; transform-origin:70px 70px; }
.anim-pulse .ring.r2 { animation-delay:.6s }
.anim-pulse .ring.r3 { animation-delay:1.2s }
@keyframes pulseCore { 0%,100% { transform:scale(1); } 50% { transform:scale(1.18); } }
@keyframes pulseRing { 0% { opacity:0.6; transform:scale(.4); } 100% { opacity:0; transform:scale(2.6); } }

.principles { display:flex; flex-direction:column; gap:0; }
.principle { padding: 24px 0; border-bottom:1px solid var(--rule); display:grid; grid-template-columns: auto 1fr; gap: 24px; align-items:start; }
.principle:first-child { border-top: 1px solid var(--rule); }
.principle .pnum { font-family:"JetBrains Mono", monospace; font-size:11px; letter-spacing:0.2em; text-transform:uppercase; color:var(--accentText); padding-top:6px; min-width:36px; }
.principle h4 { margin:0 0 8px; font-size:20px; font-weight:700; letter-spacing:-0.015em; }
.principle p { margin:0; color:var(--fog); font-size:14.5px; line-height:1.6; }
@media (max-width: 880px) { .ethos-grid { grid-template-columns: 1fr; } }

/* ====== CAPABILITIES ====== */
.capabilities { display:grid; grid-template-columns: repeat(2, 1fr); gap:0; border:1px solid var(--rule); }
.capability { padding:0; border-right:1px solid var(--rule); border-bottom:1px solid var(--rule); position:relative; }
.capability:nth-child(2n) { border-right:none; }
.capability:nth-last-child(-n+2) { border-bottom:none; }
.cap-art { aspect-ratio: 16/10; padding:32px; display:flex; align-items:center; justify-content:center; background: var(--surface); position:relative; overflow:hidden; }
.cap-art::before {
  content: attr(data-id);
  position:absolute; top:14px; left:18px;
  font-family:"JetBrains Mono", monospace; font-size:10px; letter-spacing:0.16em; text-transform:uppercase; color:var(--mute);
}
.cap-foot { padding: 24px 28px; }
.cap-foot .pin { display:flex; gap:8px; flex-wrap:wrap; margin-top:8px; }
.cap-foot .pin span { font-family:"JetBrains Mono", monospace; font-size:9.5px; letter-spacing:0.16em; text-transform:uppercase; color:var(--mute); }
.cap-foot h3 { margin:0; font-size:22px; font-weight:700; letter-spacing:-0.015em; }
@media (max-width:880px){ .capabilities { grid-template-columns: 1fr; } .capability { border-right:none !important; } .capability:nth-last-child(-n+2) { border-bottom:1px solid var(--rule); } .capability:last-child { border-bottom:none; } }

/* anim 3 - scan */
.anim-scan .scanline { animation: scan 2.4s cubic-bezier(.4,.05,.2,1) infinite; }
@keyframes scan { 0% { transform: translateY(0); } 50% { transform: translateY(96px); } 100% { transform: translateY(0); } }
.anim-scan .cell-on { fill:#ff6a1a; opacity:0; animation: cellGlow 2.4s linear infinite; }
.anim-scan .cell-on.r1 { animation-delay: 0.0s; }
.anim-scan .cell-on.r2 { animation-delay: 0.6s; }
.anim-scan .cell-on.r3 { animation-delay: 1.2s; }
@keyframes cellGlow { 0%, 18% { opacity:0; } 25%, 30% { opacity:0.55; } 50%, 100% { opacity:0; } }

/* anim 4 - rotate */
.anim-rotate .quadrant { transform-origin:70px 70px; animation: rotateQ 8s ease-in-out infinite; }
.anim-rotate .quadrant.q2 { animation-delay:.3s; }
.anim-rotate .quadrant.q3 { animation-delay:.6s; }
.anim-rotate .quadrant.q4 { animation-delay:.9s; }
@keyframes rotateQ {
  0%, 100% { transform:rotate(0deg); }
  50% { transform:rotate(180deg); }
}

/* anim 5 - flow */
.anim-flow .dot { animation: flowDot 2.6s linear infinite; fill:#ff6a1a; }
.anim-flow .dot.d2 { animation-delay:.5s }
.anim-flow .dot.d3 { animation-delay:1.0s }
.anim-flow .dot.d4 { animation-delay:1.5s }
.anim-flow .dot.d5 { animation-delay:2.0s }
@keyframes flowDot {
  0% { offset-distance:0%; opacity:0; }
  10% { opacity:1; }
  90% { opacity:1; }
  100% { offset-distance:100%; opacity:0; }
}

/* ====== PROCESS ====== */
.process-grid { display:grid; grid-template-columns: repeat(4, 1fr); gap:0; border:1px solid var(--rule); }
.step { padding: 32px 24px 28px; border-right:1px solid var(--rule); }
.step:last-child { border-right:none; }
.step .step-num { font-family:"Archivo", sans-serif; font-weight:800; font-size:64px; letter-spacing:-0.04em; line-height:1; color:var(--accentText); margin-bottom:24px; }
.step h4 { margin:0 0 8px; font-size:20px; font-weight:700; letter-spacing:-0.015em; }
.step p { margin:0; color:var(--fog); font-size:14px; line-height:1.55; }
.step .timing { margin-top:16px; font-family:"JetBrains Mono", monospace; font-size:10px; letter-spacing:0.16em; text-transform:uppercase; color:var(--mute); padding-top:12px; border-top:1px solid var(--rule);}
@media (max-width:960px){ .process-grid { grid-template-columns: 1fr 1fr; } .step:nth-child(2) { border-right:none; } .step:nth-child(-n+2) { border-bottom: 1px solid var(--rule);} }

/* ====== STATS BAR ====== */
.stats { display:grid; grid-template-columns: repeat(4, 1fr); gap:0; border:1px solid var(--rule); margin-top: 56px; }
.stat { padding: 28px 24px; border-right:1px solid var(--rule); }
.stat:last-child { border-right:none; }
.stat .num { font-family:"Archivo", sans-serif; font-weight:800; font-size: 48px; letter-spacing:-0.025em; line-height:1; }
.stat .num em { font-style:normal; color:var(--accentText); }
.stat .lab { margin-top:10px; font-family:"JetBrains Mono", monospace; font-size:10px; letter-spacing:0.18em; text-transform:uppercase; color:var(--mute); }
@media (max-width:760px){ .stats { grid-template-columns: 1fr 1fr; } .stat:nth-child(2) { border-right:none; } .stat:nth-child(-n+2) { border-bottom:1px solid var(--rule); } }

/* ====== ABOUT ====== */
.about-grid { display:grid; grid-template-columns: 1.2fr 1fr; gap:64px; align-items:center; }
.about-grid h2 em { font-style:normal; color:var(--accentText); }
.about-grid p { font-size:18px; line-height:1.65; color: var(--fog); margin: 0 0 18px; }
.about-meta { background: var(--surface); border:1px solid var(--rule); padding:0; }
.about-meta dl { display:grid; grid-template-columns: 1fr 1fr; gap:0; margin:0; }
.about-meta div { padding:20px 22px; border-bottom:1px solid var(--rule); border-right:1px solid var(--rule); }
.about-meta div:nth-child(2n) { border-right:none; }
.about-meta div:nth-last-child(-n+2) { border-bottom:none; }
.about-meta dt { font-family:"JetBrains Mono", monospace; font-size:10px; letter-spacing:0.16em; text-transform:uppercase; color:var(--mute); margin-bottom:6px; }
.about-meta dd { margin:0; font-size:18px; font-weight:700; letter-spacing:-0.01em; }
.about-meta dd em { font-style:normal; color:var(--accentText); }
@media (max-width:880px){ .about-grid { grid-template-columns:1fr; } }

/* ====== CONTACT / CTA ====== */
.cta { background: var(--surface); padding: 96px 0; border-bottom:1px solid var(--rule); position:relative; overflow:hidden; }
.cta::before {
  content:"";
  position:absolute; right:-180px; top:50%; transform:translateY(-50%);
  width:520px; height:520px;
  background-image: radial-gradient(circle at center, rgba(255,106,26,0.08) 0%, rgba(255,106,26,0) 70%);
  pointer-events:none;
}
.cta-inner { position:relative; display:grid; grid-template-columns: 1.4fr 1fr; gap:64px; align-items:center; }
.cta h2 { font-size: clamp(40px, 5vw, 72px); line-height:0.98; letter-spacing:-0.03em; font-weight:800; margin:0 0 24px; }
.cta h2 em { font-style:normal; color:var(--accentText); }
.cta p { color:var(--fog); font-size:18px; line-height:1.55; margin:0 0 32px; max-width:540px; }
.cta-form {
  background: var(--surface); border:1px solid var(--rule);
  padding: 28px;
}
.cta-form .row { display:grid; grid-template-columns: 1fr; gap:14px; }
.cta-form label { display:block; font-family:"JetBrains Mono", monospace; font-size:10px; letter-spacing:0.18em; text-transform:uppercase; color:var(--mute); margin-bottom:8px; }
.cta-form input, .cta-form textarea, .cta-form select {
  width:100%; background: transparent; border: 1px solid var(--ruleSoft);
  padding:12px 14px; color: var(--cream);
  font-family:"Archivo", sans-serif; font-size:14px;
  transition: border-color 0.2s;
}
.cta-form select { appearance:none; background-image: linear-gradient(45deg, transparent 50%, var(--orange) 50%), linear-gradient(135deg, var(--orange) 50%, transparent 50%); background-position: calc(100% - 18px) 50%, calc(100% - 13px) 50%; background-size: 5px 5px; background-repeat:no-repeat; }
.cta-form select option { color: var(--cream); background: var(--surface); }
.cta-form select option:checked { color: var(--ink); background: var(--orange); }
.cta-form input:focus, .cta-form textarea:focus, .cta-form select:focus { outline:none; border-color:var(--orange); }
.cta-form textarea { resize:vertical; min-height: 100px; }
.cta-form button {
  margin-top: 6px;
  background: var(--orange); color:var(--ink); border:none;
  padding:14px 22px; cursor:pointer; width:100%;
  font-family:"JetBrains Mono", monospace; font-size:11px; letter-spacing:0.18em; text-transform:uppercase; font-weight:700;
  transition:background 0.2s;
}
.cta-form button:hover { background:#ffb088; }
.cta-form .hp { position:absolute; left:-9999px; width:1px; height:1px; opacity:0; pointer-events:none; }
.form-success {
  background: var(--surface); border:1px solid var(--rule);
  padding: 28px;
  text-align:center;
}
.form-success .ok {
  font-family:"JetBrains Mono", monospace; font-size:11px; letter-spacing:0.18em; text-transform:uppercase;
  color:var(--accentText); margin: 0 0 12px;
}
.form-success .msg { margin:0; font-size:15px; color:var(--cream); line-height:1.55; }
@media (max-width: 880px){ .cta-inner { grid-template-columns: 1fr; } }

/* ====== FOOTER ====== */
footer.foot { background: var(--paper); padding: 64px 0 32px; }
.foot-grid { display:grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap:48px; padding-bottom:48px; border-bottom:1px solid var(--rule); }
.foot-brand .lede { color:var(--fog); margin-top:12px; max-width:280px; font-size:13.5px; line-height:1.5; }
.foot-col h5 { margin:0 0 16px; font-family:"JetBrains Mono", monospace; font-size:10px; letter-spacing:0.18em; text-transform:uppercase; color:var(--accentText); font-weight:500; }
.foot-col a { display:block; padding: 5px 0; color:var(--fog); font-size:14px; }
.foot-col a:hover { color:var(--accentText); }
.foot-base { padding-top:24px; display:flex; justify-content:space-between; gap:24px; flex-wrap:wrap; font-family:"JetBrains Mono", monospace; font-size:10.5px; letter-spacing:0.14em; text-transform:uppercase; color:var(--mute); }
@media (max-width:880px){ .foot-grid { grid-template-columns:1fr 1fr; } }

/* ====== Marquee ====== */
.marquee { padding: 24px 0; border-bottom: 1px solid var(--rule); overflow:hidden; }
.marquee-track { display:flex; gap:48px; animation: marqueeMove 40s linear infinite; white-space:nowrap; }
.marquee-track span { font-family:"Archivo", sans-serif; font-weight:800; font-size: 56px; letter-spacing:-0.025em; color: var(--marquee-ghost); }
.marquee-track span em { color:var(--accentText); font-style:normal; }
@keyframes marqueeMove {
  0% { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

/* ====== MOBILE (< 760px) - tightened spacing, single-column layouts ====== */
@media (max-width: 760px) {
  .container { padding: 0 20px; }
  section { padding: 72px 0; }

  /* Nav */
  .nav-inner { gap: 16px; }
  .brand .wm { font-size: 13px; }
  .nav-cta { padding: 8px 12px; font-size: 10px; letter-spacing: 0.14em; }

  /* Hero - drop the animation, stack copy */
  .hero { padding: 48px 0 40px; }
  .hero-grid { grid-template-columns: 1fr; gap: 32px; }
  .hero-art { display: none; }
  .hero h1 { font-size: 44px; line-height: 0.98; margin-bottom: 22px; }
  .hero .eyebrow { margin-bottom: 22px; }
  .hero .lede { font-size: 17px; margin-bottom: 28px; }
  .ctas { gap: 10px; }
  .btn-primary, .btn-ghost { padding: 12px 18px; font-size: 11px; letter-spacing: 0.16em; }

  /* Meta strip - 2×2 */
  .meta-strip { grid-template-columns: 1fr 1fr; gap: 18px 20px; padding: 20px 0; }

  /* Section heads */
  .sec-head { margin-bottom: 36px; padding-bottom: 18px; gap: 16px; }
  .sec-head h2 { font-size: 36px; }
  .sec-lede { font-size: 16px; line-height: 1.55; margin-bottom: 36px; }

  /* Services */
  .service { padding: 26px 22px; min-height: 0; gap: 16px; }
  .service h3 { font-size: 22px; }

  /* Stats - already 2×2, just tighten */
  .stats { margin-top: 32px; }
  .stat { padding: 22px 18px; }
  .stat .num { font-size: 36px; }

  /* Ethos */
  .ethos-grid { gap: 32px; }
  .ethos-art { padding: 28px; }
  .principle { padding: 18px 0; gap: 16px; }
  .principle h4 { font-size: 18px; }

  /* Capabilities */
  .cap-art { padding: 22px; }
  .cap-foot { padding: 18px 22px; }
  .cap-foot h3 { font-size: 19px; }

  /* Process - keep 2×2, tighten */
  .step { padding: 24px 18px 22px; }
  .step .step-num { font-size: 48px; margin-bottom: 16px; }
  .step h4 { font-size: 18px; }

  /* About */
  .about-grid { gap: 32px; }
  .about-grid p { font-size: 16px; }
  .about-meta div { padding: 16px 18px; }
  .about-meta dd { font-size: 16px; }

  /* CTA */
  .cta { padding: 64px 0; }
  .cta-inner { gap: 36px; }
  .cta-form { padding: 22px; }
  .cta h2 { font-size: 40px; line-height: 1; }
  .cta p { font-size: 16px; margin-bottom: 24px; }

  /* Footer - stack to 1 col */
  footer.foot { padding: 48px 0 28px; }
  .foot-grid { grid-template-columns: 1fr; gap: 28px; padding-bottom: 28px; }
  .foot-base { font-size: 9.5px; gap: 12px; flex-direction: column; align-items: flex-start; }

  /* Marquee - proportional reduction */
  .marquee { padding: 18px 0; }
  .marquee-track { gap: 32px; }
  .marquee-track span { font-size: 38px; }
}
