/* ==========================================================================
   VM MEDIA — Design System
   ========================================================================== */

/* -- Tokens --------------------------------------------------------------- */
:root {
  /* Palette — dark ground */
  --bg: #0C2419;
  --bg-raised: #11301F;
  --surface: #163A27;
  --surface-hi: #1C4530;
  --ink: #EEF5EC;
  --ink-dim: #B5C6B9;
  --ink-muted: #7A8F80;
  --line: rgba(238, 245, 236, 0.08);
  --line-strong: rgba(238, 245, 236, 0.16);

  /* Palette — warm break sections (editorial bone) */
  --bone: #F4EFE3;
  --bone-hi: #EDE6D4;
  --ink-warm: #0A1E11;
  --ink-warm-dim: #4E5C51;
  --ink-warm-muted: #8A8577;
  --line-warm: rgba(10, 30, 17, 0.10);
  --line-warm-strong: rgba(10, 30, 17, 0.22);

  /* Accents */
  --lime: #D4FF80;
  --lime-hi: #E6FFA5;
  --lime-ink: #0A1E11;
  --sand: #C9A876;          /* burnt sand, used sparingly */
  --green: #4E9C2D;
  --green-dim: #2F6319;
  --red: #E8715C;           /* used only in "what we don't do" */
  --warn: #F4B860;

  /* Radius */
  --r-xs: 6px;
  --r-sm: 10px;
  --r-md: 16px;
  --r-lg: 24px;
  --r-xl: 36px;
  --r-pill: 999px;

  /* Spacing (8pt) */
  --s-1: 4px;
  --s-2: 8px;
  --s-3: 12px;
  --s-4: 16px;
  --s-5: 24px;
  --s-6: 32px;
  --s-7: 48px;
  --s-8: 64px;
  --s-9: 96px;
  --s-10: 128px;
  --s-11: 160px;
  --s-12: 200px;

  /* Type */
  --f-display: "Clash Display", "Clash Grotesk", "Inter", ui-sans-serif, system-ui, sans-serif;
  --f-body: "Inter", ui-sans-serif, system-ui, sans-serif;
  --f-mono: "JetBrains Mono", ui-monospace, Menlo, monospace;
  --f-serif: "Instrument Serif", "Times New Roman", Georgia, serif;
  --f-ar: "Noto Naskh Arabic", "Tajawal", "IBM Plex Arabic", "Inter", sans-serif;
  --f-ar-display: "Noto Naskh Arabic", "Tajawal", serif;

  /* Motion */
  --ease: cubic-bezier(0.22, 1, 0.36, 1);
  --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
  --t-fast: 220ms;
  --t-base: 400ms;
  --t-slow: 900ms;

  /* Layout */
  --maxw: 1440px;
  --gutter: clamp(20px, 4vw, 48px);
  --nav-h: 124px;
}

/* -- Reset ---------------------------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
html {
  -webkit-text-size-adjust: 100%;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  scroll-behavior: smooth;
}
body {
  background: var(--bg);
  color: var(--ink);
  font-family: var(--f-body);
  font-size: 16px;
  line-height: 1.55;
  font-weight: 400;
  overflow-x: hidden;
  background-image:
    radial-gradient(1200px 700px at 85% -10%, rgba(212, 255, 128, 0.06), transparent 60%),
    radial-gradient(1000px 600px at -10% 20%, rgba(78, 156, 45, 0.10), transparent 60%),
    radial-gradient(800px 500px at 50% 110%, rgba(78, 156, 45, 0.07), transparent 60%);
}
html[dir="rtl"] body { font-family: var(--f-ar); }

/* Noise overlay */
body::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  opacity: 0.035;
  mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

img, svg, video { display: block; max-width: 100%; }
button { font: inherit; color: inherit; background: none; border: 0; cursor: pointer; }
a { color: inherit; text-decoration: none; }
ul, ol { list-style: none; padding: 0; margin: 0; }
h1, h2, h3, h4, h5, h6, p { margin: 0; }
:focus-visible { outline: 2px solid var(--lime); outline-offset: 3px; border-radius: var(--r-xs); }

::selection { background: var(--lime); color: var(--lime-ink); }

/* -- Type ----------------------------------------------------------------- */
.eyebrow {
  font-family: var(--f-mono);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-dim);
  display: inline-flex;
  align-items: center;
  gap: var(--s-2);
}
.eyebrow::before {
  content: "";
  width: 24px;
  height: 1px;
  background: var(--lime);
}
html[dir="rtl"] .eyebrow { letter-spacing: 0; }

.display {
  font-family: var(--f-display);
  font-weight: 600;
  line-height: 0.95;
  letter-spacing: -0.025em;
  color: var(--ink);
}
.h1 { font-size: clamp(48px, 8.5vw, 140px); }
.h2 { font-size: clamp(40px, 6vw, 96px); }
.h3 { font-size: clamp(28px, 3.6vw, 48px); }
.h4 { font-size: clamp(20px, 2.2vw, 28px); font-weight: 500; line-height: 1.1; }

.lead {
  font-size: clamp(18px, 1.6vw, 22px);
  line-height: 1.45;
  color: var(--ink-dim);
  max-width: 64ch;
}
.body { color: var(--ink-dim); line-height: 1.65; }
.micro {
  font-family: var(--f-mono);
  font-size: 12px;
  letter-spacing: 0.05em;
  color: var(--ink-muted);
}

.tint-lime { color: var(--lime); }
.tint-dim { color: var(--ink-dim); }

/* Word reveal */
.reveal-word {
  display: inline-block;
  overflow: hidden;
  vertical-align: bottom;
}
.reveal-word > span {
  display: inline-block;
  transform: translateY(110%);
  transition: transform var(--t-slow) var(--ease-out);
}
.is-visible .reveal-word > span { transform: translateY(0); }
.is-visible .reveal-word:nth-child(2) > span { transition-delay: 80ms; }
.is-visible .reveal-word:nth-child(3) > span { transition-delay: 160ms; }
.is-visible .reveal-word:nth-child(4) > span { transition-delay: 240ms; }
.is-visible .reveal-word:nth-child(5) > span { transition-delay: 320ms; }
.is-visible .reveal-word:nth-child(6) > span { transition-delay: 400ms; }
.is-visible .reveal-word:nth-child(n+7) > span { transition-delay: 480ms; }

.fade-up { opacity: 0; transform: translateY(24px); transition: opacity var(--t-slow) var(--ease), transform var(--t-slow) var(--ease); }
.is-visible.fade-up, .is-visible .fade-up { opacity: 1; transform: none; }

/* -- Layout --------------------------------------------------------------- */
.shell { max-width: var(--maxw); margin-inline: auto; padding-inline: var(--gutter); }
.section { padding-block: clamp(80px, 10vw, 160px); position: relative; }
.section--sm { padding-block: clamp(56px, 7vw, 96px); }
.rule { height: 1px; background: var(--line); border: 0; margin: 0; }

/* -- Navigation ----------------------------------------------------------- */
.nav {
  position: fixed;
  inset-block-start: 0;
  inset-inline: 0;
  z-index: 50;
  padding-block: var(--s-4);
  transition: background var(--t-base) var(--ease), backdrop-filter var(--t-base) var(--ease), border-color var(--t-base);
  border-block-end: 1px solid transparent;
}
.nav.is-stuck {
  background: rgba(6, 17, 12, 0.72);
  backdrop-filter: blur(18px) saturate(1.2);
  -webkit-backdrop-filter: blur(18px) saturate(1.2);
  border-block-end-color: var(--line);
}
.nav__inner {
  max-width: var(--maxw);
  margin-inline: auto;
  padding-inline: var(--gutter);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--s-5);
}
.brand {
  display: flex;
  align-items: center;
  gap: var(--s-2);
  font-family: var(--f-display);
  font-weight: 600;
  font-size: 18px;
  letter-spacing: -0.01em;
}
.brand__dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--lime);
  box-shadow: 0 0 24px var(--lime);
  animation: pulse 2.4s var(--ease) infinite;
}
.brand__logo {
  height: 72px;
  width: auto;
  display: block;
  filter: drop-shadow(0 0 14px rgba(212, 255, 128, 0.1));
}
.brand__logo--lg { height: 88px; }
@media (max-width: 720px) {
  .brand__logo { height: 52px; }
  .brand__logo--lg { height: 64px; }
}
@keyframes pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: 0.6; transform: scale(0.85); }
}
.nav__links {
  display: flex;
  align-items: center;
  gap: var(--s-6);
  font-size: 14px;
  color: var(--ink-dim);
}
.nav__links a { position: relative; padding-block: 4px; transition: color var(--t-fast) var(--ease); }
.nav__links a::after {
  content: "";
  position: absolute;
  inset-inline: 0;
  inset-block-end: 0;
  height: 1px;
  background: currentColor;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--t-base) var(--ease);
}
html[dir="rtl"] .nav__links a::after { transform-origin: right; }
.nav__links a:hover { color: var(--ink); }
.nav__links a:hover::after { transform: scaleX(1); }
.nav__actions { display: flex; align-items: center; gap: var(--s-3); }
.lang {
  display: inline-flex;
  align-items: center;
  gap: var(--s-2);
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  padding: 10px 14px;
  border-radius: var(--r-pill);
  border: 1px solid var(--line);
  color: var(--ink-dim);
  transition: border-color var(--t-fast), color var(--t-fast);
}
.lang:hover { border-color: var(--line-strong); color: var(--ink); }
.lang__sep { width: 1px; height: 10px; background: var(--line); }
.lang__active { color: var(--lime); }

/* Mobile nav toggle */
.nav__toggle {
  display: none;
  width: 44px;
  height: 44px;
  border-radius: var(--r-pill);
  border: 1px solid var(--line);
  align-items: center;
  justify-content: center;
}
.nav__toggle span { width: 16px; height: 1px; background: currentColor; position: relative; transition: transform var(--t-base) var(--ease); }
.nav__toggle span::before, .nav__toggle span::after {
  content: ""; position: absolute; left: 0; right: 0; height: 1px; background: currentColor;
  transition: transform var(--t-base) var(--ease);
}
.nav__toggle span::before { top: -5px; }
.nav__toggle span::after { top: 5px; }
.nav.is-open .nav__toggle span { background: transparent; }
.nav.is-open .nav__toggle span::before { transform: translateY(5px) rotate(45deg); }
.nav.is-open .nav__toggle span::after { transform: translateY(-5px) rotate(-45deg); }

/* -- Button --------------------------------------------------------------- */
.btn {
  --_bg: var(--lime);
  --_fg: var(--lime-ink);
  --_bd: transparent;
  display: inline-flex;
  align-items: center;
  gap: var(--s-2);
  padding: 14px 22px;
  font-size: 14px;
  font-weight: 600;
  font-family: var(--f-body);
  letter-spacing: -0.01em;
  border-radius: var(--r-pill);
  background: var(--_bg);
  color: var(--_fg);
  border: 1px solid var(--_bd);
  position: relative;
  overflow: hidden;
  isolation: isolate;
  transition: transform var(--t-base) var(--ease), background var(--t-base) var(--ease);
}
.btn::after {
  content: "";
  position: absolute;
  inset: 0;
  background: var(--lime-hi);
  border-radius: inherit;
  transform: translateY(101%);
  transition: transform var(--t-base) var(--ease);
  z-index: -1;
}
.btn:hover::after { transform: translateY(0); }
.btn:active { transform: scale(0.98); }
.btn--ghost { --_bg: transparent; --_fg: var(--ink); --_bd: var(--line-strong); }
.btn--ghost::after { background: rgba(255, 255, 255, 0.04); }
.btn--dark { --_bg: var(--surface); --_fg: var(--ink); }
.btn--dark::after { background: var(--surface-hi); }
.btn__arrow {
  width: 18px;
  height: 18px;
  display: inline-grid;
  place-items: center;
  transition: transform var(--t-base) var(--ease);
}
.btn:hover .btn__arrow { transform: translateX(4px); }
html[dir="rtl"] .btn:hover .btn__arrow { transform: translateX(-4px) scaleX(-1); }
html[dir="rtl"] .btn__arrow { transform: scaleX(-1); }

/* -- Chip ----------------------------------------------------------------- */
.chip {
  display: inline-flex;
  align-items: center;
  gap: var(--s-2);
  padding: 8px 14px;
  border-radius: var(--r-pill);
  font-size: 12px;
  font-family: var(--f-mono);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  border: 1px solid var(--line);
  color: var(--ink-dim);
  background: rgba(255, 255, 255, 0.02);
}
.chip--lime { border-color: transparent; background: color-mix(in srgb, var(--lime) 18%, transparent); color: var(--lime); }
.chip__dot { width: 6px; height: 6px; border-radius: 50%; background: currentColor; }

/* -- Card ----------------------------------------------------------------- */
.card {
  background: var(--bg-raised);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: var(--s-7);
  position: relative;
  overflow: hidden;
  transition: border-color var(--t-base) var(--ease), transform var(--t-base) var(--ease);
}
.card:hover { border-color: var(--line-strong); }

/* ==========================================================================
   HOMEPAGE
   ========================================================================== */

/* -- Hero ----------------------------------------------------------------- */
.hero {
  position: relative;
  padding-block: calc(var(--nav-h) + 48px) clamp(64px, 8vw, 120px);
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
.hero__top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: var(--s-4);
  padding-block-end: var(--s-8);
}
.hero__locale {
  display: flex;
  align-items: center;
  gap: var(--s-3);
  color: var(--ink-muted);
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}
.hero__locale__pulse {
  width: 6px; height: 6px; border-radius: 50%; background: var(--lime);
  box-shadow: 0 0 0 0 var(--lime);
  animation: ring 2s infinite;
}
@keyframes ring {
  0%   { box-shadow: 0 0 0 0 color-mix(in srgb, var(--lime) 60%, transparent); }
  100% { box-shadow: 0 0 0 10px transparent; }
}

.hero__title {
  font-family: var(--f-display);
  font-weight: 600;
  font-size: clamp(56px, 11vw, 200px);
  line-height: 0.88;
  letter-spacing: -0.035em;
  margin-block-start: var(--s-5);
}
.hero__title em {
  font-style: normal;
  color: var(--lime);
  font-family: inherit;
}
.hero__title .outline {
  -webkit-text-stroke: 1px var(--ink);
  color: transparent;
}
.hero__title .row {
  display: flex;
  align-items: center;
  gap: clamp(12px, 1.5vw, 24px);
  flex-wrap: wrap;
}
.hero__marker {
  display: inline-block;
  width: clamp(48px, 6vw, 96px);
  aspect-ratio: 1.6;
  border-radius: var(--r-md);
  overflow: hidden;
  background: var(--lime);
  position: relative;
  transform: translateY(-6px) rotate(-4deg);
}
.hero__marker::after {
  content: "";
  position: absolute;
  inset: 3px;
  border-radius: calc(var(--r-md) - 3px);
  background: url("https://framerusercontent.com/images/Ys5mOWPKVWw6x4EPTkHyrdgotoE.gif") center/cover no-repeat;
}
.hero__foot {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: var(--s-8);
  align-items: end;
  padding-block-start: var(--s-8);
}
.hero__claim {
  max-width: 48ch;
  font-size: clamp(16px, 1.3vw, 19px);
  line-height: 1.5;
  color: var(--ink-dim);
}
.hero__cta { display: flex; gap: var(--s-3); flex-wrap: wrap; }

.hero__stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  margin-block-start: var(--s-8);
  background: var(--line);
  border-block: 1px solid var(--line);
}
.hero__stat {
  background: var(--bg);
  padding: var(--s-5) var(--s-5);
  display: flex;
  flex-direction: column;
  gap: var(--s-2);
}
.hero__stat__num {
  font-family: var(--f-display);
  font-size: clamp(28px, 3vw, 44px);
  font-weight: 600;
  letter-spacing: -0.02em;
  color: var(--ink);
  line-height: 1;
}
.hero__stat__num em { font-style: normal; color: var(--lime); }
.hero__stat__lbl {
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-muted);
}

/* -- Marquee -------------------------------------------------------------- */
.marq {
  position: relative;
  overflow: hidden;
  padding-block: var(--s-7);
  border-block: 1px solid var(--line);
  mask-image: linear-gradient(90deg, transparent, black 10%, black 90%, transparent);
  -webkit-mask-image: linear-gradient(90deg, transparent, black 10%, black 90%, transparent);
}
.marq__track {
  display: flex;
  gap: clamp(48px, 7vw, 96px);
  align-items: center;
  animation: marq 60s linear infinite;
  width: max-content;
}
@keyframes marq {
  to { transform: translateX(-50%); }
}
html[dir="rtl"] .marq__track { animation-direction: reverse; }
.marq--rev .marq__track { animation-direction: reverse; }
.marq__item {
  font-family: var(--f-display);
  font-weight: 500;
  font-size: clamp(22px, 2.4vw, 34px);
  color: var(--ink-dim);
  letter-spacing: -0.01em;
  white-space: nowrap;
  display: inline-flex;
  align-items: center;
  gap: clamp(48px, 7vw, 96px);
}
.marq__item::after {
  content: "";
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--lime);
  opacity: 0.6;
}
.marq--pill .marq__item {
  color: var(--ink);
  font-size: clamp(16px, 1.2vw, 18px);
  font-family: var(--f-body);
  font-weight: 500;
  padding: 12px 22px;
  border-radius: var(--r-pill);
  border: 1px solid var(--line);
  background: rgba(255,255,255,0.02);
}
.marq--pill .marq__item::after { display: none; }

/* -- Manifesto ------------------------------------------------------------ */
.manifesto {
  display: grid;
  grid-template-columns: 0.85fr 1.15fr;
  gap: var(--s-8);
  align-items: start;
}
.manifesto__eyebrow-col { position: sticky; top: calc(var(--nav-h) + 40px); }
.manifesto__body {
  font-family: var(--f-display);
  font-size: clamp(24px, 2.8vw, 42px);
  line-height: 1.15;
  font-weight: 500;
  letter-spacing: -0.02em;
  color: var(--ink-dim);
}
.manifesto__body strong {
  color: var(--ink);
  font-weight: 600;
}
.manifesto__body .lime { color: var(--lime); font-weight: 600; }

.manifesto__meta {
  margin-block-start: var(--s-7);
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--s-5);
  padding-block-start: var(--s-6);
  border-block-start: 1px solid var(--line);
}
.manifesto__meta__item .k { font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--ink-muted); display:block; margin-block-end: 6px; }
.manifesto__meta__item .v { font-size: 15px; color: var(--ink); }

/* -- Services ------------------------------------------------------------- */
.services__head {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: end;
  gap: var(--s-5);
  padding-block-end: var(--s-7);
}
.services__head h2 { max-width: 18ch; }
.services__grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: var(--s-4);
}
.service {
  position: relative;
  padding: var(--s-7);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  background: var(--bg-raised);
  overflow: hidden;
  min-height: 440px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  transition: border-color var(--t-base) var(--ease), background var(--t-base) var(--ease), transform var(--t-base) var(--ease);
}
.service:hover { border-color: var(--line-strong); }
.service--a { grid-column: span 7; background: var(--bg-raised); }
.service--b { grid-column: span 5; }
.service--c { grid-column: span 5; }
.service--d { grid-column: span 7; }
.service__num {
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--ink-muted);
}
.service__title {
  font-family: var(--f-display);
  font-weight: 600;
  font-size: clamp(30px, 3vw, 44px);
  line-height: 1;
  letter-spacing: -0.02em;
  margin-block-start: var(--s-4);
}
.service__desc {
  color: var(--ink-dim);
  font-size: 15px;
  max-width: 44ch;
  margin-block-start: var(--s-3);
}
.service__tags {
  display: flex; flex-wrap: wrap; gap: var(--s-2);
  margin-block-start: var(--s-5);
}
.service__tag {
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-dim);
  padding: 6px 10px;
  border-radius: var(--r-pill);
  border: 1px solid var(--line);
}
.service__link {
  display: inline-flex;
  align-items: center;
  gap: var(--s-2);
  margin-block-start: var(--s-6);
  font-size: 14px;
  font-weight: 500;
  color: var(--lime);
  align-self: flex-start;
}
.service__link svg { transition: transform var(--t-base) var(--ease); }
.service:hover .service__link svg { transform: translateX(4px); }
html[dir="rtl"] .service:hover .service__link svg { transform: translateX(-4px) scaleX(-1); }
html[dir="rtl"] .service__link svg { transform: scaleX(-1); }

.service__visual {
  position: absolute;
  inset-block-start: -10%;
  inset-inline-end: -10%;
  width: 60%;
  height: 70%;
  opacity: 0.7;
  pointer-events: none;
  transition: opacity var(--t-slow), transform var(--t-slow);
}
.service:hover .service__visual { opacity: 0.95; transform: translate(-8px, 8px); }
.service__visual--grid {
  background:
    linear-gradient(var(--line) 1px, transparent 1px) 0 0 / 44px 44px,
    linear-gradient(90deg, var(--line) 1px, transparent 1px) 0 0 / 44px 44px;
  mask-image: radial-gradient(circle at 70% 30%, black 0%, transparent 70%);
  -webkit-mask-image: radial-gradient(circle at 70% 30%, black 0%, transparent 70%);
}
.service__visual--rings {
  background:
    radial-gradient(circle at 70% 40%, color-mix(in srgb, var(--lime) 30%, transparent) 0%, transparent 60%),
    repeating-radial-gradient(circle at 70% 40%, var(--line) 0 1px, transparent 1px 48px);
}
.service__visual--scan {
  background:
    repeating-linear-gradient(180deg, transparent 0 20px, var(--line) 20px 21px);
  mask-image: linear-gradient(180deg, black, transparent);
  -webkit-mask-image: linear-gradient(180deg, black, transparent);
}
.service__visual--bars {
  display: flex;
  align-items: flex-end;
  gap: 6px;
  padding: 24px;
  opacity: 0.4;
}
.service__visual--bars span {
  flex: 1;
  background: var(--lime);
  border-radius: 2px;
}

/* -- Work / Case Studies -------------------------------------------------- */
.work__head {
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: end;
  gap: var(--s-6);
  padding-block-end: var(--s-8);
}
.work__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--s-6);
}
.work-item {
  display: block;
  position: relative;
  border-radius: var(--r-lg);
  overflow: hidden;
  isolation: isolate;
}
.work-item__media {
  aspect-ratio: 4 / 3;
  background: var(--surface);
  overflow: hidden;
  position: relative;
  border-radius: var(--r-lg);
}
.work-item__media img {
  width: 100%; height: 100%; object-fit: cover;
  transform: scale(1.02);
  transition: transform 1.2s var(--ease);
  filter: saturate(0.9) contrast(1.02);
}
.work-item:hover .work-item__media img { transform: scale(1.08); }
.work-item__body {
  padding-block-start: var(--s-5);
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: var(--s-5);
}
.work-item__meta { display: flex; align-items: center; gap: var(--s-2); margin-block-end: var(--s-3); }
.work-item__title { font-family: var(--f-display); font-size: clamp(28px, 2.6vw, 40px); font-weight: 600; letter-spacing: -0.02em; line-height: 1; }
.work-item__desc { color: var(--ink-dim); margin-block-start: var(--s-3); font-size: 15px; max-width: 52ch; }
.work-item__stats { display: flex; gap: var(--s-4); flex-wrap: wrap; margin-block-start: var(--s-5); }
.work-item__stat {
  display: flex; flex-direction: column; gap: 4px;
}
.work-item__stat .n {
  font-family: var(--f-display);
  font-size: clamp(22px, 2vw, 28px);
  font-weight: 600;
  letter-spacing: -0.02em;
  color: var(--lime);
}
.work-item__stat .l {
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-muted);
}
.work-item__arrow {
  width: 48px; height: 48px; border-radius: 50%;
  border: 1px solid var(--line-strong);
  display: grid; place-items: center;
  flex-shrink: 0;
  transition: background var(--t-base), border-color var(--t-base), color var(--t-base);
}
.work-item:hover .work-item__arrow { background: var(--lime); border-color: var(--lime); color: var(--lime-ink); }

/* -- UGC Dual Marquee ----------------------------------------------------- */
.ugc { padding-block: clamp(72px, 8vw, 120px); }
.ugc__head { text-align: center; max-width: 64ch; margin-inline: auto; margin-block-end: var(--s-8); }
.ugc__head h2 { margin-block-start: var(--s-4); }
.ugc__head p { margin-block-start: var(--s-4); margin-inline: auto; }
.ugc__rails { display: grid; gap: var(--s-4); }
.ugc__rail { overflow: hidden; mask-image: linear-gradient(90deg, transparent, black 8%, black 92%, transparent); -webkit-mask-image: linear-gradient(90deg, transparent, black 8%, black 92%, transparent); }
.ugc__track { display: flex; gap: var(--s-4); animation: marq 70s linear infinite; width: max-content; }
.ugc__rail--rev .ugc__track { animation-direction: reverse; animation-duration: 90s; }
.ugc__card {
  flex-shrink: 0;
  width: 220px;
  aspect-ratio: 9 / 16;
  border-radius: var(--r-md);
  overflow: hidden;
  background: var(--surface);
  position: relative;
  border: 1px solid var(--line);
}
.ugc__card img { width: 100%; height: 100%; object-fit: cover; }
.ugc__card::after {
  content: "";
  position: absolute;
  inset-block-end: 0;
  inset-inline: 0;
  height: 40%;
  background: linear-gradient(180deg, transparent, rgba(6,17,12,0.85));
  pointer-events: none;
}

/* -- Stats bento ---------------------------------------------------------- */
.stats {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  grid-auto-rows: minmax(180px, auto);
  gap: 1px;
  background: var(--line);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  overflow: hidden;
}
.stat-cell {
  background: var(--bg);
  padding: var(--s-6);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: var(--s-4);
  position: relative;
}
.stat-cell--wide { grid-column: span 3; grid-row: span 2; }
.stat-cell--mid { grid-column: span 2; }
.stat-cell--narrow { grid-column: span 3; }
.stat-cell--tall { grid-row: span 2; }
.stat-cell__num {
  font-family: var(--f-display);
  font-weight: 600;
  font-size: clamp(36px, 4.5vw, 72px);
  letter-spacing: -0.035em;
  line-height: 0.9;
  color: var(--ink);
}
.stat-cell__num em { font-style: normal; color: var(--lime); }
.stat-cell__lbl {
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-muted);
}
.stat-cell__text { color: var(--ink-dim); font-size: 15px; max-width: 32ch; }
.stat-cell--accent { background: var(--lime); color: var(--lime-ink); }
.stat-cell--accent .stat-cell__num, .stat-cell--accent .stat-cell__lbl, .stat-cell--accent .stat-cell__text { color: var(--lime-ink); }
.stat-cell--accent .stat-cell__num em { color: inherit; text-decoration: underline; text-decoration-thickness: 3px; text-underline-offset: 6px; }
.stat-cell__chart {
  position: absolute;
  inset: auto 0 0 0;
  height: 60%;
  background:
    linear-gradient(180deg, transparent, color-mix(in srgb, var(--lime) 14%, transparent)),
    repeating-linear-gradient(90deg, var(--line) 0 1px, transparent 1px 48px);
  opacity: 0.6;
  pointer-events: none;
}

/* -- Process -------------------------------------------------------------- */
.process { display: grid; grid-template-columns: 0.8fr 1.2fr; gap: var(--s-8); }
.process__col { position: sticky; top: calc(var(--nav-h) + 40px); align-self: start; }
.process__steps { display: grid; gap: var(--s-4); }
.step {
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: var(--s-6) var(--s-7);
  background: var(--bg-raised);
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: var(--s-6);
  transition: border-color var(--t-base), background var(--t-base);
}
.step:hover { border-color: var(--line-strong); background: var(--surface); }
.step__num {
  font-family: var(--f-display);
  font-weight: 600;
  font-size: clamp(40px, 3.5vw, 56px);
  letter-spacing: -0.03em;
  color: var(--lime);
  line-height: 1;
}
.step__body h3 { font-family: var(--f-display); font-size: clamp(20px, 1.8vw, 26px); font-weight: 600; letter-spacing: -0.01em; }
.step__body p { color: var(--ink-dim); margin-block-start: 6px; max-width: 54ch; font-size: 15px; }
.step__time {
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-muted);
  white-space: nowrap;
}

/* -- Team ----------------------------------------------------------------- */
.team__head { display: grid; grid-template-columns: 1fr 1fr; gap: var(--s-8); align-items: end; padding-block-end: var(--s-8); }
.team__grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--s-5); }
.team-card {
  position: relative;
  border-radius: var(--r-lg);
  overflow: hidden;
  background: var(--surface);
  border: 1px solid var(--line);
}
.team-card__img {
  aspect-ratio: 4 / 5;
  background: var(--surface-hi);
  overflow: hidden;
  filter: grayscale(0.2);
  transition: filter var(--t-slow);
}
.team-card:hover .team-card__img { filter: grayscale(0); }
.team-card__img img { width: 100%; height: 100%; object-fit: cover; }
.team-card__body { padding: var(--s-5) var(--s-6) var(--s-6); display: flex; align-items: center; justify-content: space-between; gap: var(--s-4); }
.team-card__name { font-family: var(--f-display); font-size: clamp(20px, 1.8vw, 26px); font-weight: 600; letter-spacing: -0.01em; }
.team-card__role { color: var(--lime); font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; margin-block-start: 4px; }

/* -- FAQ ------------------------------------------------------------------ */
.faq { display: grid; grid-template-columns: 0.8fr 1.2fr; gap: var(--s-8); }
.faq__list { border-block-start: 1px solid var(--line); }
.faq__item { border-block-end: 1px solid var(--line); }
.faq__q {
  width: 100%;
  text-align: start;
  padding: var(--s-6) 0;
  font-family: var(--f-display);
  font-size: clamp(20px, 1.8vw, 26px);
  font-weight: 500;
  letter-spacing: -0.01em;
  color: var(--ink);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--s-4);
}
.faq__q__icon {
  width: 36px; height: 36px;
  border-radius: 50%;
  border: 1px solid var(--line);
  display: grid; place-items: center;
  transition: transform var(--t-base) var(--ease), background var(--t-base), color var(--t-base);
  flex-shrink: 0;
}
.faq__q__icon::before, .faq__q__icon::after {
  content: ""; position: absolute;
  width: 12px; height: 1.5px;
  background: currentColor;
  transition: transform var(--t-base) var(--ease);
}
.faq__q__icon { position: relative; }
.faq__q__icon::after { transform: rotate(90deg); }
.faq__item.is-open .faq__q__icon { background: var(--lime); color: var(--lime-ink); border-color: var(--lime); }
.faq__item.is-open .faq__q__icon::after { transform: rotate(0deg); }
.faq__a {
  display: grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows var(--t-slow) var(--ease);
}
.faq__a > div {
  overflow: hidden;
  color: var(--ink-dim);
  max-width: 68ch;
  font-size: 16px;
  line-height: 1.65;
}
.faq__a > div > p { padding-block: 0 var(--s-6); }
.faq__item.is-open .faq__a { grid-template-rows: 1fr; }

/* -- Final CTA ------------------------------------------------------------ */
.finale {
  background: var(--lime);
  color: var(--lime-ink);
  border-radius: var(--r-xl);
  padding: clamp(48px, 7vw, 120px) clamp(32px, 5vw, 80px);
  position: relative;
  overflow: hidden;
  isolation: isolate;
}
.finale::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    radial-gradient(600px 400px at 100% 0%, rgba(6,17,12,0.15), transparent 60%),
    radial-gradient(500px 300px at 0% 100%, rgba(6,17,12,0.1), transparent 60%);
  pointer-events: none;
}
.finale__eyebrow { color: color-mix(in srgb, var(--lime-ink) 60%, transparent); }
.finale__eyebrow::before { background: var(--lime-ink); }
.finale h2 {
  font-family: var(--f-display);
  font-size: clamp(48px, 9vw, 160px);
  font-weight: 600;
  line-height: 0.9;
  letter-spacing: -0.035em;
  margin-block-start: var(--s-5);
  color: var(--lime-ink);
  max-width: 16ch;
}
.finale p { color: var(--lime-ink); opacity: 0.7; margin-block-start: var(--s-5); max-width: 52ch; font-size: 18px; }
.finale__actions { display: flex; gap: var(--s-3); flex-wrap: wrap; margin-block-start: var(--s-7); }
.finale .btn { background: var(--lime-ink); color: var(--lime); }
.finale .btn::after { background: #0a1d0d; }
.finale .btn--ghost { background: transparent; color: var(--lime-ink); border-color: rgba(8,20,6,0.25); }
.finale .btn--ghost::after { background: rgba(8,20,6,0.08); }

/* -- Footer --------------------------------------------------------------- */
.footer { padding-block: var(--s-9) var(--s-6); border-block-start: 1px solid var(--line); margin-block-start: var(--s-10); }
.footer__top {
  display: grid;
  grid-template-columns: 1.6fr 1fr 1fr 1fr;
  gap: var(--s-6);
  padding-block-end: var(--s-8);
}
.footer__brand p { color: var(--ink-dim); max-width: 42ch; margin-block-start: var(--s-4); }
.footer h5 { font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--ink-muted); margin-block-end: var(--s-3); font-weight: 500; }
.footer__links li { margin-block: 10px; }
.footer__links a { color: var(--ink-dim); transition: color var(--t-fast); }
.footer__links a:hover { color: var(--lime); }
.footer__bot {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-block-start: var(--s-5);
  border-block-start: 1px solid var(--line);
  color: var(--ink-muted);
  font-size: 13px;
  flex-wrap: wrap;
  gap: var(--s-3);
}

/* -- Cursor (desktop enhancement) ----------------------------------------- */
.cursor {
  position: fixed;
  top: 0; left: 0;
  width: 10px; height: 10px;
  border-radius: 50%;
  background: var(--lime);
  pointer-events: none;
  z-index: 100;
  transform: translate(-50%, -50%);
  mix-blend-mode: difference;
  transition: width var(--t-base), height var(--t-base), opacity var(--t-base);
  opacity: 0;
}
.cursor.is-active { opacity: 1; }
.cursor.is-hover { width: 48px; height: 48px; mix-blend-mode: normal; background: color-mix(in srgb, var(--lime) 30%, transparent); }
@media (pointer: coarse) { .cursor { display: none; } }

/* ==========================================================================
   RESPONSIVE
   ========================================================================== */
@media (max-width: 1024px) {
  .manifesto, .process, .faq, .team__head { grid-template-columns: 1fr; gap: var(--s-6); }
  .manifesto__eyebrow-col, .process__col { position: static; }
  .services__grid { grid-template-columns: 1fr; }
  .service--a, .service--b, .service--c, .service--d { grid-column: 1 / -1; }
  .work__grid, .team__grid { grid-template-columns: 1fr; }
  .stats { grid-template-columns: repeat(2, 1fr); }
  .stat-cell--wide, .stat-cell--mid, .stat-cell--narrow { grid-column: span 2; grid-row: auto; }
  .stat-cell--tall { grid-row: auto; }
  .footer__top { grid-template-columns: 1fr 1fr; }
  .hero__foot { grid-template-columns: 1fr; gap: var(--s-6); }
  .hero__stats { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 720px) {
  .nav__links { display: none; }
  .nav__toggle { display: flex; }
  .nav.is-open .nav__links {
    display: flex;
    position: absolute;
    top: 100%;
    inset-inline: 0;
    flex-direction: column;
    align-items: flex-start;
    padding: var(--s-5) var(--gutter) var(--s-7);
    background: rgba(6, 17, 12, 0.95);
    backdrop-filter: blur(18px);
    border-block-start: 1px solid var(--line);
    font-size: 28px;
    gap: var(--s-4);
  }
  .hero__stats { grid-template-columns: 1fr; }
  .services__head, .work__head { grid-template-columns: 1fr; align-items: start; }
  .footer__top { grid-template-columns: 1fr; }
  .step { grid-template-columns: auto 1fr; }
  .step__time { grid-column: 1 / -1; }
  .service { min-height: 360px; padding: var(--s-5); }
  .work-item__body { flex-direction: column; }
}

/* Reduce motion */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
  .reveal-word > span { transform: none; }
}

/* ==========================================================================
   V2 — EDITORIAL / OPERATOR VISION
   ========================================================================== */

/* Serif italic accent */
.serif-em {
  font-family: var(--f-serif);
  font-style: italic;
  font-weight: 400;
  letter-spacing: -0.01em;
}

/* Warm section — dark → bone tonal break */
.section-warm {
  background: var(--bone);
  color: var(--ink-warm);
  position: relative;
  isolation: isolate;
  border-radius: var(--r-xl);
  margin-inline: clamp(8px, 2vw, 24px);
  overflow: hidden;
}
.section-warm .eyebrow { color: var(--ink-warm-dim); }
.section-warm .eyebrow::before { background: var(--sand); }
.section-warm .display,
.section-warm h1, .section-warm h2, .section-warm h3, .section-warm h4,
.section-warm .body, .section-warm .lead, .section-warm p { color: var(--ink-warm); }
.section-warm .tint-dim, .section-warm .body, .section-warm .lead { color: var(--ink-warm-dim); }
.section-warm .tint-lime { color: var(--ink-warm); text-decoration: underline; text-decoration-color: var(--sand); text-decoration-thickness: 4px; text-underline-offset: 6px; }
.section-warm .rule, .section-warm hr { background: var(--line-warm); }
.section-warm::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    radial-gradient(800px 500px at 100% 0%, rgba(201, 168, 118, 0.18), transparent 60%),
    radial-gradient(600px 400px at 0% 100%, rgba(201, 168, 118, 0.10), transparent 60%);
  pointer-events: none;
  z-index: -1;
}

/* -- Compact announcement bar (above hero) ------------------------------- */
.announce {
  display: inline-flex;
  align-items: center;
  gap: var(--s-3);
  padding: 10px 16px;
  border-radius: var(--r-pill);
  border: 1px solid var(--line);
  background: rgba(255,255,255,0.02);
  font-size: 13px;
  color: var(--ink-dim);
}
.announce__label {
  font-family: var(--f-mono);
  font-size: 10px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--sand);
  border-inline-end: 1px solid var(--line);
  padding-inline-end: var(--s-3);
}

/* -- Editorial hero ------------------------------------------------------ */
.ed-hero {
  display: grid;
  grid-template-columns: 1.3fr 1fr;
  gap: var(--s-8);
  align-items: end;
  padding-block: calc(var(--nav-h) + 80px) var(--s-10);
}
.ed-hero__copy h1 {
  font-family: var(--f-display);
  font-weight: 600;
  font-size: clamp(52px, 8vw, 132px);
  line-height: 0.92;
  letter-spacing: -0.03em;
  margin-block-start: var(--s-6);
}
.ed-hero__copy h1 em.serif-em {
  color: var(--sand);
  font-size: 0.92em;
}
.ed-hero__copy h1 .lime {
  color: var(--lime);
  font-style: normal;
}
.ed-hero__copy p.lead {
  margin-block-start: var(--s-6);
  max-width: 48ch;
}
.ed-hero__cta { display: flex; flex-wrap: wrap; gap: var(--s-3); margin-block-start: var(--s-7); }

.ed-hero__panel {
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  background: linear-gradient(180deg, rgba(255,255,255,0.02), rgba(255,255,255,0));
  padding: var(--s-5);
  position: relative;
  overflow: hidden;
}
.ed-hero__panel__head {
  display: flex; justify-content: space-between; align-items: center;
  padding-block-end: var(--s-4);
  border-block-end: 1px solid var(--line);
  margin-block-end: var(--s-4);
}
.ed-hero__panel__head__title {
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-muted);
}
.ed-hero__panel__head__live {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--f-mono);
  font-size: 10px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--lime);
}
.ed-hero__panel__head__live::before {
  content: ""; width: 6px; height: 6px; border-radius: 50%; background: var(--lime);
  animation: pulse 1.8s var(--ease) infinite;
}
.ed-hero__panel__row {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: var(--s-3);
  padding-block: var(--s-3);
  border-block-end: 1px dashed var(--line);
  font-family: var(--f-mono);
  font-size: 13px;
}
.ed-hero__panel__row:last-child { border-block-end: 0; }
.ed-hero__panel__row .k { color: var(--ink-muted); letter-spacing: 0.08em; text-transform: uppercase; font-size: 11px; }
.ed-hero__panel__row .v { color: var(--ink); font-variant-numeric: tabular-nums; }
.ed-hero__panel__row .v.delta { color: var(--lime); }
.ed-hero__panel__foot {
  padding-block-start: var(--s-4);
  margin-block-start: var(--s-3);
  border-block-start: 1px solid var(--line);
  font-family: var(--f-mono);
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-muted);
  display: flex;
  justify-content: space-between;
}

/* -- Live board ticker --------------------------------------------------- */
.board {
  border-block: 1px solid var(--line);
  padding-block: 0;
  display: flex;
  align-items: stretch;
  overflow: hidden;
}
.board__label {
  flex-shrink: 0;
  padding: var(--s-5) var(--s-5);
  display: flex;
  align-items: center;
  gap: var(--s-3);
  border-inline-end: 1px solid var(--line);
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--lime);
  background: rgba(212,255,128,0.04);
  white-space: nowrap;
}
.board__label::before {
  content: ""; width: 8px; height: 8px; border-radius: 50%; background: var(--lime);
  box-shadow: 0 0 14px var(--lime);
  animation: pulse 1.8s var(--ease) infinite;
}
.board__track-wrap { flex: 1; overflow: hidden; mask-image: linear-gradient(90deg, transparent, black 6%, black 94%, transparent); -webkit-mask-image: linear-gradient(90deg, transparent, black 6%, black 94%, transparent); display: flex; align-items: center; }
.board__track {
  display: flex;
  gap: var(--s-8);
  animation: marq 80s linear infinite;
  width: max-content;
  padding-inline: var(--s-5);
}
.board__item {
  display: inline-flex;
  align-items: center;
  gap: var(--s-3);
  font-family: var(--f-mono);
  font-size: 13px;
  color: var(--ink-dim);
  white-space: nowrap;
}
.board__item .id { color: var(--ink-muted); letter-spacing: 0.1em; }
.board__item .metric { color: var(--ink); font-variant-numeric: tabular-nums; }
.board__item .delta { color: var(--lime); font-variant-numeric: tabular-nums; }
.board__item .delta.down { color: var(--sand); }
.board__item .time { color: var(--ink-muted); font-size: 11px; }

/* -- Silent logo grid ---------------------------------------------------- */
.clients {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 1px;
  background: var(--line);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  overflow: hidden;
}
.client {
  background: var(--bg);
  min-height: 120px;
  display: grid;
  place-items: center;
  padding: var(--s-5);
  font-family: var(--f-display);
  font-weight: 500;
  font-size: 20px;
  letter-spacing: -0.01em;
  color: var(--ink-muted);
  position: relative;
  transition: color var(--t-base), background var(--t-base);
}
.client:hover { color: var(--ink); background: var(--bg-raised); }
.client__hover {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: var(--s-4);
  font-family: var(--f-mono);
  font-size: 11px;
  color: var(--lime);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  opacity: 0;
  transition: opacity var(--t-base);
  pointer-events: none;
}
.client:hover .client__hover { opacity: 1; }

/* -- Lead case study (one hero feature) ---------------------------------- */
.lead-case {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: var(--s-8);
  align-items: stretch;
}
.lead-case__media {
  border-radius: var(--r-lg);
  overflow: hidden;
  background: var(--surface);
  aspect-ratio: 4 / 5;
  position: relative;
}
.lead-case__media img {
  width: 100%; height: 100%; object-fit: cover;
  filter: saturate(0.9) contrast(1.02);
}
.lead-case__body { display: flex; flex-direction: column; justify-content: space-between; gap: var(--s-7); }
.lead-case__kicker {
  display: flex;
  gap: var(--s-3);
  align-items: center;
  flex-wrap: wrap;
}
.lead-case__title {
  font-family: var(--f-display);
  font-weight: 600;
  font-size: clamp(44px, 5vw, 72px);
  line-height: 0.95;
  letter-spacing: -0.03em;
  margin-block-start: var(--s-4);
}
.lead-case__title em { font-style: normal; color: var(--lime); }
.lead-case__quote {
  font-family: var(--f-serif);
  font-style: italic;
  font-size: clamp(22px, 2vw, 28px);
  line-height: 1.35;
  color: var(--ink-dim);
  padding-block: var(--s-6);
  border-block: 1px solid var(--line);
}
.lead-case__stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--line);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  overflow: hidden;
}
.lead-case__stat {
  background: var(--bg);
  padding: var(--s-4) var(--s-5);
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.lead-case__stat .n {
  font-family: var(--f-display);
  font-size: clamp(28px, 2.6vw, 40px);
  font-weight: 600;
  letter-spacing: -0.025em;
  color: var(--lime);
}
.lead-case__stat .l {
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-muted);
}

/* -- Ledger (other engagements as table rows) ---------------------------- */
.ledger { border-block-start: 1px solid var(--line); }
.ledger__row {
  display: grid;
  grid-template-columns: 80px 2fr 1.5fr 1fr 1fr 48px;
  gap: var(--s-5);
  align-items: center;
  padding-block: var(--s-5);
  border-block-end: 1px solid var(--line);
  transition: background var(--t-base);
  cursor: pointer;
  color: var(--ink);
}
.ledger__row:hover { background: rgba(255,255,255,0.02); }
.ledger__row .idx {
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  color: var(--ink-muted);
}
.ledger__row .name {
  font-family: var(--f-display);
  font-size: clamp(20px, 1.8vw, 26px);
  font-weight: 500;
  letter-spacing: -0.01em;
}
.ledger__row .vertical { font-family: var(--f-mono); font-size: 12px; color: var(--ink-muted); letter-spacing: 0.08em; text-transform: uppercase; }
.ledger__row .result { font-family: var(--f-mono); font-size: 13px; color: var(--lime); font-variant-numeric: tabular-nums; }
.ledger__row .period { font-family: var(--f-mono); font-size: 11px; color: var(--ink-muted); letter-spacing: 0.06em; }
.ledger__row .arr {
  width: 36px; height: 36px; border-radius: 50%; border: 1px solid var(--line);
  display: grid; place-items: center;
  transition: background var(--t-base), border-color var(--t-base), color var(--t-base);
}
.ledger__row:hover .arr { background: var(--lime); border-color: var(--lime); color: var(--lime-ink); }

/* -- Brief (capabilities as document) ------------------------------------ */
.brief { display: grid; grid-template-columns: 0.7fr 1.3fr; gap: var(--s-8); align-items: start; }
.brief__head { position: sticky; top: calc(var(--nav-h) + 40px); }
.brief__doc {
  display: grid;
  gap: 0;
  border-block-start: 1px solid var(--line);
}
.brief__item {
  display: grid;
  grid-template-columns: 80px 1fr auto;
  gap: var(--s-5);
  padding-block: var(--s-6);
  border-block-end: 1px solid var(--line);
  align-items: baseline;
}
.brief__no {
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  color: var(--ink-muted);
  padding-block-start: 8px;
}
.brief__h {
  font-family: var(--f-display);
  font-size: clamp(24px, 2.2vw, 32px);
  font-weight: 500;
  letter-spacing: -0.015em;
  line-height: 1.15;
}
.brief__h .serif-em { display: inline; color: var(--sand); font-size: 1em; }
.brief__desc { color: var(--ink-dim); margin-block-start: var(--s-3); max-width: 58ch; font-size: 15px; line-height: 1.6; }
.brief__tags { display: flex; flex-wrap: wrap; gap: var(--s-2); margin-block-start: var(--s-4); }
.brief__tag {
  font-family: var(--f-mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-muted);
  padding: 4px 8px;
  border-radius: var(--r-pill);
  border: 1px solid var(--line);
}
.brief__link {
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--lime);
  white-space: nowrap;
  padding-block-start: 8px;
}

/* -- GCC Network Map ----------------------------------------------------- */
.map-wrap { display: grid; grid-template-columns: 1fr 1.4fr; gap: var(--s-8); align-items: center; }
.map-wrap__copy h2 em.serif-em { color: var(--sand); font-size: 0.9em; }
.map-legend { display: grid; gap: var(--s-3); margin-block-start: var(--s-6); border-block-start: 1px solid var(--line); padding-block-start: var(--s-6); }
.map-legend__row {
  display: grid; grid-template-columns: 1fr auto; gap: var(--s-4);
  font-family: var(--f-mono); font-size: 13px;
}
.map-legend__row .c { color: var(--ink-dim); letter-spacing: 0.06em; text-transform: uppercase; font-size: 11px; }
.map-legend__row .n { color: var(--ink); font-variant-numeric: tabular-nums; }
.map {
  aspect-ratio: 1.15;
  background: var(--bg-raised);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: var(--s-6);
  position: relative;
  overflow: hidden;
  background-image:
    linear-gradient(var(--line) 1px, transparent 1px),
    linear-gradient(90deg, var(--line) 1px, transparent 1px);
  background-size: 56px 56px;
  background-position: -1px -1px;
}
.map svg { width: 100%; height: 100%; }
.map__dot { fill: var(--lime); }
.map__ring { fill: none; stroke: var(--lime); stroke-width: 1; opacity: 0.4; transform-origin: center; }
.map__label {
  font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.12em;
  fill: var(--ink-dim); text-transform: uppercase;
}
.map__count { font-family: var(--f-display); font-weight: 600; font-size: 14px; fill: var(--lime); }

/* -- Engagement tiers ---------------------------------------------------- */
.tiers {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--s-4);
}
.tier {
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: var(--s-6) var(--s-6) var(--s-7);
  background: var(--bg-raised);
  display: flex;
  flex-direction: column;
  position: relative;
  overflow: hidden;
  transition: border-color var(--t-base), background var(--t-base);
}
.tier:hover { border-color: var(--line-strong); }
.tier--featured { background: var(--lime); color: var(--lime-ink); border-color: var(--lime); }
.tier--featured * { color: inherit !important; }
.tier--featured::before {
  content: "Most asked for";
  position: absolute; top: var(--s-4); right: var(--s-4);
  font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase;
  padding: 4px 10px; border-radius: var(--r-pill);
  background: var(--lime-ink); color: var(--lime);
}
html[dir="rtl"] .tier--featured::before { right: auto; left: var(--s-4); content: "الأكثر طلبًا"; }
.tier__name {
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--ink-muted);
}
.tier--featured .tier__name { color: var(--lime-ink); opacity: 0.65; }
.tier__price {
  font-family: var(--f-display);
  font-size: clamp(36px, 3.6vw, 56px);
  font-weight: 600;
  letter-spacing: -0.03em;
  line-height: 1;
  margin-block-start: var(--s-3);
}
.tier__price em { font-style: normal; font-family: var(--f-mono); font-size: 12px; letter-spacing: 0.14em; color: var(--ink-muted); text-transform: uppercase; display: block; margin-block-start: 6px; }
.tier--featured .tier__price em { color: var(--lime-ink); opacity: 0.65; }
.tier__who {
  padding-block: var(--s-5);
  border-block-start: 1px solid var(--line);
  margin-block-start: var(--s-5);
  font-family: var(--f-serif); font-style: italic;
  font-size: 18px; line-height: 1.4; color: var(--ink-dim);
}
.tier--featured .tier__who { color: var(--lime-ink); border-block-start-color: rgba(10,30,17,0.2); }
.tier__list { display: grid; gap: 10px; margin-block: var(--s-4) var(--s-6); }
.tier__list li { display: grid; grid-template-columns: 16px 1fr; gap: var(--s-3); font-size: 14px; line-height: 1.5; color: var(--ink-dim); }
.tier__list li::before {
  content: "+";
  font-family: var(--f-mono);
  color: var(--lime);
  font-weight: 500;
}
.tier--featured .tier__list li::before { color: var(--lime-ink); }
.tier--featured .tier__list li { color: var(--lime-ink); opacity: 0.85; }
.tier .btn { margin-block-start: auto; justify-content: center; }
.tier--featured .btn { background: var(--lime-ink); color: var(--lime); }
.tier--featured .btn::after { background: #050d06; }

/* -- Principles (numbered positions) ------------------------------------- */
.principles { display: grid; gap: 0; border-block-start: 1px solid var(--line); }
.principle {
  display: grid;
  grid-template-columns: 120px 1fr 2fr;
  gap: var(--s-6);
  padding-block: var(--s-7);
  border-block-end: 1px solid var(--line);
  align-items: baseline;
}
.principle__no {
  font-family: var(--f-mono);
  font-size: 12px;
  letter-spacing: 0.18em;
  color: var(--sand);
}
.principle__h {
  font-family: var(--f-display);
  font-size: clamp(28px, 3vw, 44px);
  font-weight: 600;
  line-height: 1;
  letter-spacing: -0.02em;
}
.principle__h em { font-style: normal; color: var(--lime); }
.principle__h .serif-em { color: var(--sand); font-size: 1em; }
.principle__body { font-size: 17px; line-height: 1.55; color: var(--ink-dim); max-width: 56ch; }

/* -- Refusal list ("what we don't do") ----------------------------------- */
.refuse__head { display: grid; grid-template-columns: 1fr 1fr; gap: var(--s-8); align-items: end; padding-block-end: var(--s-8); }
.refuse__list { display: grid; gap: var(--s-3); }
.refuse__item {
  display: grid;
  grid-template-columns: 48px 1fr;
  gap: var(--s-5);
  align-items: start;
  padding: var(--s-5) var(--s-6);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  background: rgba(232, 113, 92, 0.04);
}
.refuse__mark {
  width: 32px; height: 32px; border-radius: 50%;
  border: 1px solid var(--red);
  color: var(--red);
  display: grid; place-items: center;
  position: relative;
  flex-shrink: 0;
}
.refuse__mark::before, .refuse__mark::after {
  content: ""; position: absolute; width: 14px; height: 1.5px; background: currentColor;
}
.refuse__mark::before { transform: rotate(45deg); }
.refuse__mark::after { transform: rotate(-45deg); }
.refuse__h { font-family: var(--f-display); font-size: clamp(20px, 1.8vw, 26px); font-weight: 500; letter-spacing: -0.01em; }
.refuse__b { color: var(--ink-dim); font-size: 15px; margin-block-start: 6px; line-height: 1.5; }

/* -- Founders letter (warm section) -------------------------------------- */
.letter { display: grid; grid-template-columns: 1fr 1.4fr; gap: var(--s-8); padding: clamp(56px, 7vw, 120px) clamp(32px, 5vw, 80px); }
.letter__avatars {
  display: flex;
  gap: -12px;
  margin-block-end: var(--s-5);
}
.letter__avatars img {
  width: 64px; height: 64px; border-radius: 50%;
  object-fit: cover;
  border: 2px solid var(--bone);
  filter: grayscale(0.4) sepia(0.08);
}
.letter__avatars img:not(:first-child) { margin-inline-start: -20px; }
.letter__title {
  font-family: var(--f-serif);
  font-style: italic;
  font-size: clamp(32px, 3.5vw, 52px);
  line-height: 1.05;
  letter-spacing: -0.02em;
  color: var(--ink-warm);
}
.letter__body {
  font-family: var(--f-serif);
  font-size: 18px;
  line-height: 1.65;
  color: var(--ink-warm-dim);
  max-width: 62ch;
}
.letter__body p + p { margin-block-start: var(--s-4); }
.letter__body strong { color: var(--ink-warm); font-weight: 400; font-family: var(--f-serif); font-style: italic; }
.letter__sig {
  margin-block-start: var(--s-6);
  padding-block-start: var(--s-5);
  border-block-start: 1px solid var(--line-warm);
  display: flex; gap: var(--s-6); flex-wrap: wrap;
  font-family: var(--f-mono);
  font-size: 12px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-warm-dim);
}
.letter__sig strong { color: var(--ink-warm); font-weight: 500; font-family: var(--f-mono); font-style: normal; display: block; font-size: 14px; margin-block-end: 4px; }

/* -- Invitation (final) -------------------------------------------------- */
.invite {
  border: 1px solid var(--line);
  border-radius: var(--r-xl);
  padding: clamp(48px, 6vw, 96px);
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: var(--s-8);
  align-items: end;
  background:
    radial-gradient(600px 400px at 100% 0%, rgba(212,255,128,0.06), transparent 60%),
    var(--bg-raised);
}
.invite h2 {
  font-family: var(--f-display);
  font-size: clamp(44px, 6vw, 88px);
  font-weight: 600;
  letter-spacing: -0.03em;
  line-height: 0.95;
}
.invite h2 em.serif-em { color: var(--sand); font-size: 0.9em; }
.invite__quals {
  display: grid;
  gap: var(--s-3);
  padding-block-start: var(--s-5);
  border-block-start: 1px solid var(--line);
}
.invite__quals li {
  display: grid;
  grid-template-columns: 16px 1fr;
  gap: var(--s-3);
  font-size: 14px;
  color: var(--ink-dim);
  line-height: 1.5;
}
.invite__quals li::before { content: "→"; color: var(--sand); font-family: var(--f-mono); }
html[dir="rtl"] .invite__quals li::before { content: "←"; }

/* -- Responsive refinements ---------------------------------------------- */
@media (max-width: 1024px) {
  .ed-hero, .lead-case, .brief, .map-wrap, .tiers, .letter, .invite, .refuse__head { grid-template-columns: 1fr; gap: var(--s-6); }
  .brief__head { position: static; }
  .ledger__row { grid-template-columns: 40px 1.2fr 1fr 1fr 36px; }
  .ledger__row .period { display: none; }
  .clients { grid-template-columns: repeat(3, 1fr); }
  .principle { grid-template-columns: 80px 1fr; }
  .principle__body { grid-column: 1 / -1; padding-inline-start: 80px; }
}
@media (max-width: 720px) {
  .clients { grid-template-columns: repeat(2, 1fr); }
  .ledger__row { grid-template-columns: 32px 1fr 36px; font-size: 13px; }
  .ledger__row .vertical, .ledger__row .result, .ledger__row .period { display: none; }
  .board__label { display: none; }
  .principle { grid-template-columns: 1fr; gap: var(--s-2); padding-block: var(--s-5); }
  .principle__body { padding-inline-start: 0; }
  .brief__item { grid-template-columns: 40px 1fr; }
  .brief__link { grid-column: 1 / -1; padding-inline-start: 0; padding-block-start: var(--s-3); }
}

/* ==========================================================================
   V3 — KSA/GCC AGENCY REDESIGN (globe, jelly balls, testimonials, admin)
   ========================================================================== */

/* -- Hero (v3) with globe on the right ----------------------------------- */
.v3-hero {
  padding-block: calc(var(--nav-h) + 60px) clamp(60px, 7vw, 100px);
  display: grid;
  grid-template-columns: 1.05fr 1fr;
  gap: var(--s-8);
  align-items: center;
  min-height: calc(100vh - var(--nav-h));
}
.v3-hero__kicker {
  display: inline-flex;
  align-items: center;
  gap: var(--s-3);
  padding: 8px 16px;
  border-radius: var(--r-pill);
  border: 1px solid var(--line-strong);
  background: rgba(212,255,128,0.06);
  color: var(--lime);
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}
.v3-hero__kicker::before {
  content: "";
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--lime);
  box-shadow: 0 0 16px var(--lime);
  animation: pulse 1.8s var(--ease) infinite;
}
.v3-hero h1,
.v3-hero__h1 {
  font-family: var(--f-display);
  font-weight: 600;
  font-size: clamp(44px, 7.2vw, 108px);
  line-height: 0.98;
  letter-spacing: -0.03em;
  color: #EEF5EC;            /* explicit — was var(--ink), pure white on dark */
  margin: var(--s-5) 0 0;
  max-width: 16ch;
  display: block;
  visibility: visible;
  opacity: 1;
}
.v3-hero h1 em,
.v3-hero__h1 em {
  font-style: normal;
  color: var(--lime);
}
.v3-hero__lead {
  font-size: clamp(17px, 1.4vw, 20px);
  line-height: 1.55;
  color: var(--ink-dim);
  max-width: 52ch;
  margin-block-start: var(--s-6);
}
.v3-hero__cta { display: flex; gap: var(--s-3); flex-wrap: wrap; margin-block-start: var(--s-7); }

/* ---- Trust row under CTA ---- */
.trust-row {
  display: flex;
  align-items: center;
  gap: var(--s-5);
  margin-block-start: var(--s-6);
  padding-block-start: var(--s-5);
  border-block-start: 1px solid var(--line);
  flex-wrap: wrap;
}
.trust-row__k {
  font-family: var(--f-mono);
  font-size: 10px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-muted);
  position: relative;
  padding-inline-end: var(--s-3);
}
.trust-row__k::after {
  content: "";
  position: absolute;
  inset-inline-end: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 1px;
  height: 12px;
  background: var(--line);
}
.trust-row__marks {
  display: flex;
  align-items: center;
  gap: var(--s-5);
  flex-wrap: wrap;
}
.trust-mark {
  display: block;
  height: auto;
  transition: opacity var(--t-base) var(--ease), filter var(--t-base) var(--ease);
}
.trust-mark--logo {
  height: 20px;
  opacity: 0.82;
  transition: opacity var(--t-base);
}
.trust-mark--logo:hover { opacity: 1; }

/* ================================================================
   PREMIUM AGENCY-PARTNER BADGE
   — ambient halo + rotating dashed seal ring + circular seal text
   — verified checkmark tag + subtle float + hover boost
   ================================================================ */
.trust-badge {
  position: relative;
  display: inline-grid;
  place-items: center;
  width: 160px;
  height: 160px;
  flex-shrink: 0;
  text-decoration: none;
  animation: trust-float 5s var(--ease) infinite alternate;
  cursor: pointer;
  isolation: isolate;
}
@keyframes trust-float {
  from { transform: translateY(0); }
  to   { transform: translateY(-4px); }
}

/* Ambient glow that breathes behind everything */
.trust-badge__halo {
  position: absolute;
  inset: -12%;
  border-radius: 50%;
  background:
    radial-gradient(circle at 50% 50%, rgba(212, 255, 128, 0.32), transparent 55%);
  filter: blur(18px);
  z-index: 0;
  pointer-events: none;
  animation: trust-halo 3.4s var(--ease) infinite alternate;
}
@keyframes trust-halo {
  from { opacity: 0.55; transform: scale(0.94); }
  to   { opacity: 1;    transform: scale(1.05); }
}

/* Rotating dashed seal ring + curved "TikTok Marketing Partner" text */
.trust-badge__ring {
  position: absolute;
  inset: -4px;                /* sit just 4px outside the badge edge */
  z-index: 1;
  pointer-events: none;
  animation: trust-rotate 24s linear infinite;
}
.trust-badge__ring svg {
  width: 100%;
  height: 100%;
  display: block;
  overflow: visible;
  filter: drop-shadow(0 0 6px rgba(212, 255, 128, 0.35));
}
.trust-badge__seal-text {
  font-weight: 500;
  text-transform: uppercase;
}
@keyframes trust-rotate {
  from { transform: rotate(0deg); }
  to   { transform: rotate(360deg); }
}

/* The real badge image sits on top of the ring & halo */
.trust-badge__img {
  position: relative;
  z-index: 2;
  width: 132px;
  height: 132px;
  border-radius: 50%;
  display: block;
  filter:
    drop-shadow(0 10px 22px rgba(0, 0, 0, 0.6))
    drop-shadow(0 0 18px rgba(212, 255, 128, 0.22));
  transition: transform var(--t-base) var(--ease), filter var(--t-base) var(--ease);
}

/* Verified ✓ tag in the bottom-right quadrant */
.trust-badge__check {
  position: absolute;
  right: 4px;
  bottom: 4px;
  z-index: 3;
  width: 34px;
  height: 34px;
  border-radius: 50%;
  background: var(--lime);
  color: var(--lime-ink);
  display: grid;
  place-items: center;
  box-shadow:
    0 0 0 4px var(--bg),
    0 0 16px color-mix(in srgb, var(--lime) 55%, transparent);
  animation: trust-check-pop 1.8s var(--ease) infinite;
}
.trust-badge__check svg {
  width: 18px;
  height: 18px;
}
@keyframes trust-check-pop {
  0%, 100% { transform: scale(1);     box-shadow: 0 0 0 4px var(--bg), 0 0 14px color-mix(in srgb, var(--lime) 40%, transparent); }
  50%      { transform: scale(1.08);  box-shadow: 0 0 0 4px var(--bg), 0 0 26px color-mix(in srgb, var(--lime) 70%, transparent); }
}

/* Hover: ring speeds up, image lifts, halo intensifies */
.trust-badge:hover .trust-badge__ring { animation-duration: 8s; }
.trust-badge:hover .trust-badge__img {
  transform: scale(1.05);
  filter:
    drop-shadow(0 14px 28px rgba(0, 0, 0, 0.7))
    drop-shadow(0 0 28px rgba(212, 255, 128, 0.4));
}
.trust-badge:hover .trust-badge__halo {
  animation-duration: 1.6s;
}

@media (max-width: 720px) {
  .trust-row { gap: var(--s-3); }
  .trust-mark--logo { height: 16px; }
  .trust-row__k::after { display: none; }
  .trust-badge { width: 120px; height: 120px; }
  .trust-badge__img { width: 100px; height: 100px; }
  .trust-badge__check { width: 26px; height: 26px; }
  .trust-badge__check svg { width: 14px; height: 14px; }
}

/* GCC Close-up Map (glowing) */
.gcc-map-wrap {
  position: relative;
  aspect-ratio: 1;
  width: 100%;
  max-width: 620px;
  margin-inline: auto;
  border-radius: var(--r-xl);
  padding: var(--s-6);
  background:
    radial-gradient(ellipse 70% 70% at 50% 50%, rgba(212, 255, 128, 0.10), transparent 70%),
    radial-gradient(ellipse 120% 120% at 50% 120%, rgba(78, 156, 45, 0.12), transparent 60%),
    linear-gradient(180deg, var(--bg-raised), var(--bg));
  border: 1px solid var(--line);
  overflow: hidden;
  isolation: isolate;
}
.gcc-map-wrap::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(var(--line) 1px, transparent 1px),
    linear-gradient(90deg, var(--line) 1px, transparent 1px);
  background-size: 36px 36px;
  mask-image: radial-gradient(circle at center, black 30%, transparent 85%);
  -webkit-mask-image: radial-gradient(circle at center, black 30%, transparent 85%);
  pointer-events: none;
  opacity: 0.6;
  z-index: 0;
}
.gcc-map-wrap::after {
  content: "";
  position: absolute;
  inset: -20%;
  background: radial-gradient(circle at 50% 45%, rgba(212, 255, 128, 0.22), transparent 40%);
  filter: blur(40px);
  pointer-events: none;
  z-index: 0;
  animation: gcc-ambient 8s var(--ease) infinite alternate;
}
@keyframes gcc-ambient {
  from { opacity: 0.5; transform: scale(1); }
  to   { opacity: 0.9; transform: scale(1.08); }
}
.gcc-map {
  position: relative;
  z-index: 1;
  width: 100%;
  height: 100%;
  overflow: visible;
}
/* Peninsula layers */
.gcc-map__land-glow {
  fill: var(--lime);
  opacity: 0.08;
  filter: blur(24px);
}
.gcc-map__land {
  fill: color-mix(in srgb, var(--surface) 80%, var(--lime) 4%);
  stroke: color-mix(in srgb, var(--lime) 40%, transparent);
  stroke-width: 1.2;
}
.gcc-map__coast {
  fill: none;
  stroke: color-mix(in srgb, var(--lime) 70%, transparent);
  stroke-width: 0.8;
  stroke-dasharray: 2 3;
  opacity: 0.55;
}
/* City dots */
.gcc-city__dot { fill: var(--lime); }
.gcc-city__halo {
  fill: var(--lime);
  filter: blur(8px);
  opacity: 0.55;
}
.gcc-city__ring {
  fill: none;
  stroke: var(--lime);
  stroke-width: 1.2;
  transform-origin: center;
  transform-box: fill-box;
}
.gcc-city__label {
  font-family: var(--f-mono);
  font-size: 9.5px;
  letter-spacing: 0.18em;
  fill: var(--ink);
  text-transform: uppercase;
  paint-order: stroke;
  stroke: var(--bg);
  stroke-width: 2.5;
}
.gcc-city__count {
  font-family: var(--f-mono);
  font-size: 10px;
  fill: var(--lime);
  font-weight: 500;
}
/* Map overlay chrome */
.gcc-map-wrap__badge {
  position: absolute;
  top: var(--s-5);
  left: var(--s-5);
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 12px;
  border-radius: var(--r-pill);
  background: rgba(212, 255, 128, 0.1);
  border: 1px solid color-mix(in srgb, var(--lime) 30%, transparent);
  color: var(--lime);
  font-family: var(--f-mono);
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  z-index: 2;
}
.gcc-map-wrap__badge::before {
  content: "";
  width: 6px; height: 6px; border-radius: 50%; background: var(--lime);
  animation: pulse 1.8s var(--ease) infinite;
  box-shadow: 0 0 10px var(--lime);
}
.gcc-map-wrap__legend {
  position: absolute;
  bottom: var(--s-5);
  left: var(--s-5);
  display: grid;
  gap: 2px;
  font-family: var(--f-mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-muted);
  z-index: 2;
}
.gcc-map-wrap__legend strong {
  color: var(--lime);
  font-weight: 500;
  letter-spacing: 0.16em;
  font-size: 10px;
}
.gcc-map-wrap__compass {
  position: absolute;
  top: var(--s-5);
  right: var(--s-5);
  font-family: var(--f-mono);
  font-size: 10px;
  letter-spacing: 0.2em;
  color: var(--ink-muted);
  z-index: 2;
  text-transform: uppercase;
  display: grid;
  place-items: center;
  gap: 2px;
}
.gcc-map-wrap__compass svg { opacity: 0.6; }

@media (max-width: 1024px) {
  .gcc-map-wrap { max-width: 520px; }
}

/* ==========================================================================
   V3.2 — HERO SHOWCASE (UGC phone + live growth stat cards)
   ========================================================================== */
.hero-showcase {
  position: relative;
  aspect-ratio: 0.95;
  width: 100%;
  max-width: 620px;
  margin-inline: auto;
  display: grid;
  place-items: center;
}
.hero-showcase::before {
  content: "";
  position: absolute;
  inset: -8%;
  background:
    radial-gradient(circle at 50% 40%, rgba(212,255,128,0.14), transparent 55%),
    radial-gradient(circle at 75% 80%, rgba(78,156,45,0.16), transparent 55%);
  filter: blur(32px);
  z-index: 0;
  pointer-events: none;
  animation: showcase-pulse 6s var(--ease) infinite alternate;
}
@keyframes showcase-pulse {
  from { opacity: 0.7; transform: scale(1); }
  to   { opacity: 1; transform: scale(1.06); }
}

/* Phone / vertical creative frame */
.showcase-phone {
  position: relative;
  width: min(62%, 340px);
  aspect-ratio: 9 / 19;
  border-radius: 42px;
  padding: 10px;
  background: linear-gradient(180deg, #1a3a2a, #0e241a);
  box-shadow:
    0 50px 100px -40px rgba(0,0,0,0.8),
    0 0 0 1px var(--line-strong),
    inset 0 1px 0 rgba(255,255,255,0.05);
  z-index: 1;
}
.showcase-phone::before {
  /* notch */
  content: "";
  position: absolute;
  top: 14px;
  left: 50%;
  transform: translateX(-50%);
  width: 70px; height: 18px;
  border-radius: 12px;
  background: #050d08;
  z-index: 3;
}
.showcase-phone::after {
  /* speaker dot */
  content: "";
  position: absolute;
  top: 22px;
  left: calc(50% + 22px);
  width: 5px; height: 5px;
  border-radius: 50%;
  background: color-mix(in srgb, var(--lime) 60%, transparent);
  z-index: 4;
}
.showcase-screen {
  position: relative;
  width: 100%;
  height: 100%;
  border-radius: 34px;
  overflow: hidden;
  background: var(--surface);
}
.showcase-slot {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0;
  animation: showcase-cycle 20s infinite;
  will-change: opacity;
}
.showcase-slot:nth-child(1) { animation-delay: 0s; }
.showcase-slot:nth-child(2) { animation-delay: 5s; }
.showcase-slot:nth-child(3) { animation-delay: 10s; }
.showcase-slot:nth-child(4) { animation-delay: 15s; }
@keyframes showcase-cycle {
  0%, 22% { opacity: 1; }
  27%, 100% { opacity: 0; }
}
/* Overlay gradient + badge over the UGC */
.showcase-screen::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(6,17,12,0.25) 0%, transparent 20%, transparent 70%, rgba(6,17,12,0.55) 100%);
  pointer-events: none;
  z-index: 2;
}
.showcase-screen__tag {
  position: absolute;
  top: 48px;
  left: 14px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 10px;
  border-radius: var(--r-pill);
  background: rgba(6, 17, 12, 0.65);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border: 1px solid rgba(212,255,128,0.3);
  font-family: var(--f-mono);
  font-size: 9px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--lime);
  z-index: 3;
}
.showcase-screen__tag::before {
  content: "";
  width: 5px; height: 5px; border-radius: 50%; background: var(--lime);
  animation: pulse 1.6s var(--ease) infinite;
  box-shadow: 0 0 8px var(--lime);
}

.showcase-screen__handle {
  position: absolute;
  bottom: 14px;
  left: 14px;
  right: 14px;
  z-index: 3;
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: var(--f-body);
  font-size: 12px;
  color: rgba(255,255,255,0.9);
}
.showcase-screen__handle__avatar {
  width: 28px; height: 28px; border-radius: 50%;
  background: rgba(255,255,255,0.1);
  border: 1.5px solid var(--lime);
  overflow: hidden;
  flex-shrink: 0;
}
.showcase-screen__handle__avatar img { width: 100%; height: 100%; object-fit: cover; }
.showcase-screen__handle__name { font-weight: 500; }
.showcase-screen__handle__role { font-family: var(--f-mono); font-size: 10px; opacity: 0.7; letter-spacing: 0.08em; }

/* Floating stat cards */
.showcase-card {
  position: absolute;
  width: clamp(200px, 20vw, 240px);
  padding: 16px 18px 18px;
  border-radius: var(--r-md);
  background: rgba(17, 48, 31, 0.72);
  backdrop-filter: blur(24px) saturate(1.2);
  -webkit-backdrop-filter: blur(24px) saturate(1.2);
  border: 1px solid rgba(238, 245, 236, 0.15);
  box-shadow:
    0 30px 60px -30px rgba(0,0,0,0.7),
    0 0 0 1px rgba(212, 255, 128, 0.06);
  z-index: 2;
  animation: card-float 6s var(--ease) infinite alternate;
}
.showcase-card--a {
  top: 6%;
  left: -4%;
}
.showcase-card--b {
  bottom: 8%;
  right: -4%;
  animation-delay: -3s;
}
.showcase-card--c {
  bottom: 28%;
  left: -6%;
  width: clamp(170px, 16vw, 200px);
  animation-delay: -1.5s;
}
.showcase-card--d {
  top: 6%;
  right: -4%;
  width: clamp(200px, 18vw, 230px);
  animation-delay: -4.5s;
}

/* Platform tiles inside card D */
.platforms {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 8px;
  margin-block: 10px 2px;
}
.platform {
  position: relative;
  aspect-ratio: 1;
  border-radius: 10px;
  background: var(--_bg, rgba(238, 245, 236, 0.04));
  border: 1px solid var(--line);
  display: grid;
  place-items: center;
  padding: 7px;
  overflow: hidden;
  transition: transform var(--t-base) var(--ease), border-color var(--t-base), box-shadow var(--t-base);
  cursor: pointer;
}
.platform svg,
.platform img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: contain;
}
.platform img {
  padding: 0;
}
.platform:hover {
  transform: translateY(-2px);
  border-color: color-mix(in srgb, var(--lime) 30%, var(--line));
  box-shadow: 0 8px 20px -10px var(--_glow, rgba(212, 255, 128, 0.4));
}
.platform[data-platform="tiktok"] { --_bg: #0E1512; --_glow: rgba(254, 44, 85, 0.5); }
.platform[data-platform="snap"]   { --_bg: #1C1C08; --_glow: rgba(255, 252, 0, 0.45); }
.platform[data-platform="meta"]   { --_bg: #061222; --_glow: rgba(8, 102, 255, 0.5); }
.platform[data-platform="google"] { --_bg: #0E1512; --_glow: rgba(66, 133, 244, 0.45); }
/* Subtle pulsing ring behind the active one */
.platform[data-platform="tiktok"]::after {
  content: "";
  position: absolute;
  inset: -1px;
  border-radius: inherit;
  border: 1px solid color-mix(in srgb, var(--lime) 50%, transparent);
  opacity: 0;
  animation: platform-pulse 2.4s var(--ease) infinite;
  pointer-events: none;
}
@keyframes platform-pulse {
  0%, 60% { opacity: 0; transform: scale(1); }
  30%     { opacity: 1; transform: scale(1.04); }
  100%    { opacity: 0; transform: scale(1.1); }
}
@keyframes card-float {
  from { transform: translateY(0); }
  to   { transform: translateY(-10px); }
}
.showcase-card__head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 8px;
  margin-block-end: 10px;
}
.showcase-card__k {
  font-family: var(--f-mono);
  font-size: 9.5px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-muted);
}
.showcase-card__live {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-family: var(--f-mono);
  font-size: 9px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--lime);
}
.showcase-card__live::before {
  content: ""; width: 4px; height: 4px; border-radius: 50%; background: var(--lime);
  animation: pulse 1.6s var(--ease) infinite;
}
.showcase-card__v {
  font-family: var(--f-display);
  font-size: clamp(22px, 2.4vw, 30px);
  font-weight: 600;
  letter-spacing: -0.025em;
  color: var(--ink);
  line-height: 1;
  font-variant-numeric: tabular-nums;
}
.showcase-card__d {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--f-mono);
  font-size: 11px;
  color: var(--lime);
  margin-block-start: 4px;
  font-variant-numeric: tabular-nums;
}
.showcase-card__d.down { color: var(--sand); }

/* Sparkline SVG */
.spark {
  width: 100%;
  height: 54px;
  margin-block-start: 10px;
  overflow: visible;
}
.spark__grid {
  stroke: var(--line);
  stroke-width: 1;
}
.spark__area {
  fill: url(#spark-grad-lime);
  opacity: 0.55;
}
.spark__line {
  fill: none;
  stroke: var(--lime);
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-dasharray: 4 4;
  animation: spark-flow 2.4s linear infinite;
  filter: drop-shadow(0 0 4px color-mix(in srgb, var(--lime) 50%, transparent));
}
@keyframes spark-flow {
  to { stroke-dashoffset: -64; }
}
.spark__dot {
  fill: var(--lime);
  filter: drop-shadow(0 0 6px var(--lime));
}
.spark__dot-ring {
  fill: none;
  stroke: var(--lime);
  stroke-width: 1.5;
  transform-origin: center;
  transform-box: fill-box;
  animation: dot-ring 2s var(--ease) infinite;
  opacity: 0;
}
@keyframes dot-ring {
  0%   { r: 4; opacity: 0.9; }
  100% { r: 12; opacity: 0; }
}

/* Bars chart card (alt card with growing bars) */
.bars {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 3px;
  height: 54px;
  margin-block-start: 10px;
}
.bars span {
  flex: 1;
  background: linear-gradient(180deg, var(--lime), color-mix(in srgb, var(--lime) 30%, transparent));
  border-radius: 2px 2px 0 0;
  transform-origin: bottom;
  animation: bar-pulse 2.4s var(--ease) infinite;
}
.bars span:nth-child(1)  { animation-delay: 0.00s; }
.bars span:nth-child(2)  { animation-delay: 0.08s; }
.bars span:nth-child(3)  { animation-delay: 0.16s; }
.bars span:nth-child(4)  { animation-delay: 0.24s; }
.bars span:nth-child(5)  { animation-delay: 0.32s; }
.bars span:nth-child(6)  { animation-delay: 0.40s; }
.bars span:nth-child(7)  { animation-delay: 0.48s; }
.bars span:nth-child(8)  { animation-delay: 0.56s; }
.bars span:nth-child(9)  { animation-delay: 0.64s; }
.bars span:nth-child(10) { animation-delay: 0.72s; }
.bars span:nth-child(11) { animation-delay: 0.80s; }
.bars span:nth-child(12) { animation-delay: 0.88s; }
@keyframes bar-pulse {
  0%, 100% { transform: scaleY(0.6); opacity: 0.5; }
  50%      { transform: scaleY(1);   opacity: 1; }
}

@media (max-width: 1024px) {
  .hero-showcase { max-width: 520px; }
  .showcase-phone { width: 56%; }
  .showcase-card--a { left: 0; top: 4%; }
  .showcase-card--b { right: 0; bottom: 4%; }
  .showcase-card--c { display: none; }
  .showcase-card--d { right: 0; top: 4%; }
}
@media (max-width: 720px) {
  .showcase-card { width: 180px; padding: 12px 14px; }
  .showcase-card__v { font-size: 22px; }
  .showcase-card--a { left: -8px; }
  .showcase-card--b { right: -8px; }
  .showcase-card--d { display: none; }
}

/* -- Brand strip --------------------------------------------------------- */
.brand-strip {
  border-block: 1px solid var(--line);
  padding-block: var(--s-5);
  overflow: hidden;
  contain: layout paint;
}
.brand-strip__track {
  display: flex;
  gap: clamp(28px, 3.5vw, 56px);
  align-items: center;
  width: max-content;
  /* GPU-accelerated, high-FPS marquee */
  animation: brand-marq 40s linear infinite;
  will-change: transform;
  transform: translate3d(0, 0, 0);
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
  perspective: 1000px;
}
@keyframes brand-marq {
  from { transform: translate3d(0, 0, 0); }
  to   { transform: translate3d(-50%, 0, 0); }
}
/* pause on hover for polish */
.brand-strip:hover .brand-strip__track { animation-play-state: paused; }
.brand-strip__item {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 56px;
  width: 160px;
  flex-shrink: 0;
  transform: translateZ(0);
}
.brand-strip__item img {
  max-height: 100%;
  max-width: 100%;
  width: auto;
  height: auto;
  object-fit: contain;
  /* Unify logos to a single tonality so they live together on the dark green */
  filter: brightness(0) invert(1);
  opacity: 0.65;
  transition: opacity var(--t-base) var(--ease), filter var(--t-base) var(--ease);
}
.brand-strip__item:hover img {
  opacity: 1;
  filter: none;
}

/* -- Brands grid photo (under "trusted by") ------------------------------ */
.brands-grid {
  position: relative;
  margin: var(--s-7) 0 0;
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  overflow: hidden;
  background:
    radial-gradient(ellipse 80% 60% at 50% 50%, rgba(212, 255, 128, 0.06), transparent 60%),
    var(--bg-raised);
  isolation: isolate;
}
.brands-grid::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(12, 36, 25, 0.55) 0%, transparent 18%, transparent 78%, rgba(12, 36, 25, 0.7) 100%);
  pointer-events: none;
  z-index: 1;
}
/* Legacy (single-image) behaviour — kept for backward compat if anyone
   still passes a plain <img> inside .brands-grid */
.brands-grid img {
  display: block;
  width: 100%;
  height: auto;
  filter: saturate(0.95) contrast(1.02);
  mix-blend-mode: luminosity;
  opacity: 0.92;
}
/* --tiles variant: real 6-col grid of individual brand PNGs, rendered at
   their natural file size (no scaling, no filter, no gradient).
   Caption sits statically below the grid. */
.brands-grid--tiles {
  padding: var(--s-6) var(--s-5);
  background: transparent;      /* kill the radial/linear gradients */
  border: none;
}
.brands-grid--tiles::before { display: none; }     /* kill the dark overlay */
.brands-grid__row {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: var(--s-5) var(--s-6);
  align-items: center;
  justify-items: center;
}
.brands-grid__cell {
  display: flex;
  align-items: center;
  justify-content: center;
}
.brands-grid__cell img {
  /* Logos at their natural PNG size — no width / height set, no filter,
     no opacity, no blend mode. Shows exactly as the file is. */
  display: block;
  max-width: 100%;               /* only constraint: never overflow the cell */
  height: auto;
  width: auto;
}
.brands-grid--tiles .brands-grid__cap {
  position: static;
  margin-block-start: var(--s-6);
  padding-block-start: var(--s-5);
  border-block-start: 1px solid var(--line);
  inset: auto;
}
.brands-grid__cap {
  position: absolute;
  inset-block-end: var(--s-5);
  inset-inline-start: var(--s-5);
  inset-inline-end: var(--s-5);
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--s-4);
  z-index: 2;
  flex-wrap: wrap;
}
.brands-grid__cap__k,
.brands-grid__cap__v {
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}
.brands-grid__cap__k { color: var(--ink); }
.brands-grid__cap__v { color: var(--lime); }

@media (max-width: 1024px) {
  .brands-grid__row { grid-template-columns: repeat(4, 1fr); }
}
@media (max-width: 720px) {
  .brands-grid__cap { flex-direction: column; align-items: flex-start; gap: 4px; }
  .brands-grid__row { grid-template-columns: repeat(3, 1fr); gap: var(--s-4); }
  .brands-grid--tiles { padding: var(--s-4); }
}
@media (max-width: 430px) {
  .brands-grid__row { grid-template-columns: repeat(2, 1fr); }
}

/* -- Services (v3) ------------------------------------------------------- */
.svc-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--s-4);
}
.svc-card {
  padding: var(--s-6);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  background: var(--bg-raised);
  min-height: 400px;
  /* Grid with explicit rows — every card aligns at every row across the grid */
  display: grid;
  grid-template-rows: auto 80px 2.4em 1fr auto;
  gap: var(--s-4);
  align-items: start;
  position: relative;
  overflow: hidden;
  transition: border-color var(--t-base), background var(--t-base), transform var(--t-base);
}
.svc-card:hover { border-color: var(--lime); background: var(--surface); transform: translateY(-3px); }
.svc-card__num {
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  color: var(--lime);
  text-transform: uppercase;
  margin: 0;
  line-height: 1;
  padding-block-start: 2px;
}
/* ---- Animated visual slot (was a static 56×56 icon) ---------------- */
.svc-card__visual {
  position: relative;
  width: 100%;
  height: 80px;
  display: grid;
  place-items: center;
  border-radius: var(--r-md);
  border: 1px solid color-mix(in srgb, var(--lime) 18%, var(--line));
  background:
    radial-gradient(320px 120px at 50% 50%, rgba(212, 255, 128, 0.08), transparent 70%),
    rgba(212, 255, 128, 0.04);
  overflow: hidden;
  padding: 8px 16px;
  margin: 0;
}
/* SVG fills width, keeps its own aspect ratio (no stretch) */
.svc-card__visual svg {
  width: 100%;
  height: auto;
  max-height: 60px;
  display: block;
  overflow: visible;
}

/* Visual 1 — animated sparkline */
.svc-spark__line {
  animation: svc-spark-flow 2.4s linear infinite;
}
@keyframes svc-spark-flow {
  to { stroke-dashoffset: -64; }
}
.svc-spark__ring {
  transform-origin: 400px 4px;
  transform-box: view-box;
  animation: svc-spark-ring 2s var(--ease) infinite;
}
@keyframes svc-spark-ring {
  0%   { r: 3; opacity: 0.9; }
  100% { r: 14; opacity: 0; }
}

/* Visual 2 — vertical-video frames animating + play button + wave rail */
.svc-card__visual--frames {
  /* override default place-items:center — we stack rail + wave */
  display: flex;
  flex-direction: column;
  align-items: stretch;
  justify-content: center;
  padding: 6px 18px;
  gap: 3px;
}
.svc-frames__rail {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 4px;
  width: 100%;
}
.svc-frame {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  gap: 3px;
  flex: 1;
  max-width: 26px;
  aspect-ratio: 9 / 16;
  max-height: 44px;
  border-radius: 4px;
  background: linear-gradient(180deg, color-mix(in srgb, var(--lime) 35%, transparent), color-mix(in srgb, var(--lime) 10%, transparent));
  padding: 3px;
  animation: svc-frame-cycle 3.2s var(--ease) infinite;
  overflow: hidden;
  flex-shrink: 0;
}
.svc-frame i {
  display: block;
  height: 2px;
  border-radius: 1px;
  background: rgba(10, 20, 10, 0.45);
}
.svc-frame i:first-child { width: 70%; }
.svc-frame i:last-child  { width: 45%; }
.svc-frame:nth-child(1) { animation-delay: 0s; }
.svc-frame:nth-child(2) { animation-delay: 0.2s; }
.svc-frame:nth-child(3) { animation-delay: 0.4s; }
.svc-frame:nth-child(4) { animation-delay: 0.6s; }
.svc-frame:nth-child(5) { animation-delay: 0.8s; }
.svc-frame:nth-child(6) { animation-delay: 1.0s; }
.svc-frame:nth-child(7) { animation-delay: 1.2s; }
@keyframes svc-frame-cycle {
  0%, 100% { opacity: 0.45; transform: translateY(3px) scale(0.96); }
  50%      { opacity: 1;    transform: translateY(0)   scale(1);   }
}
.svc-frame__play {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 28px;
  height: 28px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: color-mix(in srgb, var(--bg) 82%, transparent);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  border: 1px solid color-mix(in srgb, var(--lime) 60%, transparent);
  color: var(--lime);
  box-shadow: 0 0 18px color-mix(in srgb, var(--lime) 35%, transparent);
  animation: svc-play-pulse 2.2s var(--ease) infinite;
  z-index: 2;
  pointer-events: none;
}
.svc-frame__play svg { width: 12px; height: 12px; }
@keyframes svc-play-pulse {
  0%, 100% { box-shadow: 0 0 18px color-mix(in srgb, var(--lime) 25%, transparent); }
  50%      { box-shadow: 0 0 32px color-mix(in srgb, var(--lime) 55%, transparent); }
}
/* Dashed wavy bottom rail connecting the frames */
.svc-frames__wave {
  display: block;
  width: 100%;
  height: 8px;
  max-height: none;
  opacity: 0.8;
  animation: svc-wave-flow 3s linear infinite;
}
@keyframes svc-wave-flow {
  to { transform: translateX(-20px); }
}

/* Visual 3 — network nodes */
.svc-nodes__lines line {
  animation: svc-nodes-flow 3s linear infinite;
}
@keyframes svc-nodes-flow {
  to { stroke-dashoffset: -28; }
}
.svc-nodes__dots > g > circle:first-child {
  transform-origin: center;
  transform-box: fill-box;
  animation: svc-node-breathe 2.8s var(--ease) infinite alternate;
}
.svc-nodes__dots > g:nth-child(2) > circle:first-child { animation-delay: -0.8s; }
.svc-nodes__dots > g:nth-child(3) > circle:first-child { animation-delay: -1.6s; }
.svc-nodes__dots > g:nth-child(4) > circle:first-child { animation-delay: -0.4s; }
.svc-nodes__dots > g:nth-child(5) > circle:first-child { animation-delay: -2.2s; }
.svc-nodes__dots > g:nth-child(6) > circle:first-child { animation-delay: -1.2s; }
@keyframes svc-node-breathe {
  from { transform: scale(1);    opacity: 0.6; }
  to   { transform: scale(1.18); opacity: 1;   }
}
.svc-card__title {
  font-family: var(--f-display);
  font-weight: 600;
  font-size: clamp(22px, 2vw, 28px);
  line-height: 1.1;
  letter-spacing: -0.015em;
  margin: 0;
  /* allow the title row (2.4em) to handle 1–2 line titles consistently */
  align-self: start;
}
.svc-card__desc {
  color: var(--ink-dim);
  font-size: 15px;
  line-height: 1.55;
  margin: 0;
}
.svc-card__link {
  display: inline-flex;
  align-items: center;
  gap: var(--s-2);
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--lime);
  margin: 0;
  padding-block-start: var(--s-3);
  border-block-start: 1px solid var(--line);
  justify-self: start;
  align-self: end;
}

/* -- Stats row (v3) ------------------------------------------------------ */
.stats-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--line);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  overflow: hidden;
}
.stats-row__cell {
  background: var(--bg-raised);
  padding: var(--s-7) var(--s-6);
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
}
.stats-row__num {
  font-family: var(--f-display);
  font-weight: 600;
  font-size: clamp(48px, 6vw, 84px);
  letter-spacing: -0.035em;
  line-height: 1;
  color: var(--lime);
}
.stats-row__num em { font-style: normal; color: var(--ink); font-size: 0.5em; vertical-align: top; margin-inline-start: 6px; }
.stats-row__lbl {
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-dim);
}

/* -- Why choose us ------------------------------------------------------- */
.why {
  display: grid;
  grid-template-columns: 0.85fr 1.15fr;
  gap: var(--s-8);
  align-items: start;
}
/* Sticky left column — anchored to the vertical middle of the viewport */
.why__intro {
  position: sticky;
  top: 50vh;
  transform: translateY(-50%);
  align-self: start;
}
.why__live {
  margin-block-start: var(--s-7);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  overflow: hidden;
  background: rgba(238, 245, 236, 0.02);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}
.why__live__row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 14px 18px;
  border-block-end: 1px solid var(--line);
  gap: var(--s-3);
}
.why__live__row:last-child { border-block-end: 0; }
.why__live__k {
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-muted);
}
.why__live__v {
  font-family: var(--f-display);
  font-size: 18px;
  font-weight: 600;
  letter-spacing: -0.01em;
  color: var(--ink);
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.pulse-dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--lime);
  box-shadow: 0 0 10px var(--lime);
  animation: pulse 1.6s var(--ease) infinite;
}

/* ---- Bento grid ---- */
.why__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-auto-rows: 1fr;
  gap: var(--s-4);
}
.why-item {
  position: relative;
  /* Two rows: fixed-height visual / flexible body — number aligns across all 4 cards */
  display: grid;
  grid-template-rows: 200px 1fr;
  gap: var(--s-4);
  padding: var(--s-6);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  background: linear-gradient(180deg, rgba(238, 245, 236, 0.02), rgba(238, 245, 236, 0.005));
  overflow: hidden;
  isolation: isolate;
  transition: border-color var(--t-base), background var(--t-base), transform var(--t-base);
}
.why-item::before {
  content: "";
  position: absolute;
  inset: -1px;
  background: radial-gradient(600px 200px at var(--mx, 50%) var(--my, 0%), rgba(212, 255, 128, 0.08), transparent 60%);
  opacity: 0;
  pointer-events: none;
  z-index: 0;
  transition: opacity var(--t-base);
  border-radius: inherit;
}
.why-item::after {
  /* corner tick — top-right */
  content: "";
  position: absolute;
  top: 10px;
  inset-inline-end: 10px;
  width: 14px; height: 14px;
  background:
    linear-gradient(90deg, var(--lime) 6px, transparent 6px 8px, var(--lime) 8px) top / 100% 1px no-repeat,
    linear-gradient(180deg, var(--lime) 6px, transparent 6px 8px, var(--lime) 8px) right / 1px 100% no-repeat;
  opacity: 0.35;
  pointer-events: none;
  z-index: 1;
}
.why-item:hover {
  border-color: color-mix(in srgb, var(--lime) 35%, var(--line));
  transform: translateY(-3px);
}
.why-item:hover::before { opacity: 1; }
.why-item:hover::after { opacity: 0.8; }

.why-item__visual {
  position: relative;
  z-index: 1;
  height: 200px;                 /* fixed — aligns body across all 4 cards */
  display: grid;
  grid-template-rows: 1fr auto;  /* graphic (flex) / tag-row (auto) */
  gap: var(--s-3);
  padding: var(--s-4) 0 var(--s-4);
  border-block-end: 1px solid var(--line);
  overflow: hidden;
  align-items: center;           /* centre each child vertically in its row */
}
/* Graphic sits in the first row, centred — preserves the child's own flex/grid layout */
.why-item__visual > *:first-child:not(.tag-row) {
  min-height: 0;
  justify-self: center;
  width: 100%;
  max-width: 100%;
}
.why-item__visual svg {
  width: 100%;
  height: auto;
  max-height: 110px;
}
/* Horizontal creator cluster — centred horizontally in its grid cell */
.why-item__visual--creators .creator-cluster {
  display: flex;
  align-items: center;
  justify-content: center;
  width: auto;
  max-width: 100%;
}
.why-item__body {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
}
.why-item__num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 34px; height: 34px;
  border-radius: 50%;
  border: 1px solid color-mix(in srgb, var(--lime) 40%, transparent);
  color: var(--lime);
  font-family: var(--f-mono);
  font-size: 11px;
  font-weight: 500;
  align-self: flex-start;
}
.why-item__h {
  font-family: var(--f-display);
  font-weight: 600;
  font-size: clamp(20px, 1.8vw, 26px);
  letter-spacing: -0.01em;
  line-height: 1.15;
}
.why-item__b { color: var(--ink-dim); font-size: 15px; line-height: 1.55; }

/* ---- Tag chips (shared across visuals) ---- */
.tag-row {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-block-start: auto;
}
.tag-chip {
  display: inline-flex;
  align-items: center;
  padding: 4px 9px;
  border-radius: var(--r-pill);
  border: 1px solid var(--line);
  background: rgba(238, 245, 236, 0.02);
  font-family: var(--f-mono);
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-dim);
  white-space: nowrap;
  transition: border-color var(--t-base), color var(--t-base);
}
.why-item:hover .tag-chip { border-color: color-mix(in srgb, var(--lime) 30%, var(--line)); color: var(--ink); }

/* ---- Team balls (lives in Team section now — large interactive canvas) ---- */
.team-balls-wrap {
  position: relative;
  width: 100%;
  margin-block-end: var(--s-9);
  border-radius: var(--r-xl);
  background:
    radial-gradient(600px 280px at 50% 40%, rgba(78, 156, 45, 0.18), transparent 60%),
    radial-gradient(500px 220px at 50% 100%, rgba(212, 255, 128, 0.08), transparent 60%),
    linear-gradient(180deg, var(--bg-raised), var(--bg));
  border: 1px solid var(--line);
  overflow: hidden;
  isolation: isolate;
}
.team-balls-wrap::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(238, 245, 236, 0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(238, 245, 236, 0.04) 1px, transparent 1px);
  background-size: 44px 44px;
  mask-image: radial-gradient(ellipse at center, black 30%, transparent 80%);
  -webkit-mask-image: radial-gradient(ellipse at center, black 30%, transparent 80%);
  pointer-events: none;
  z-index: 0;
}
.team-balls {
  position: relative;
  width: 100%;
  height: 480px;
  z-index: 1;
  touch-action: none;
}
.team-ball {
  position: absolute;
  top: 0;
  left: 0;
  width: var(--ball-size, 68px);
  height: var(--ball-size, 68px);
  border-radius: 50%;
  overflow: hidden;
  border: 3px solid var(--lime);
  background: var(--bg);
  box-shadow:
    0 0 0 4px color-mix(in srgb, var(--lime) 12%, transparent),
    0 14px 26px -10px rgba(0, 0, 0, 0.6);
  transition: box-shadow var(--t-base);
  will-change: transform;
  cursor: grab;
}
.team-ball img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.team-ball.is-near {
  box-shadow:
    0 0 0 4px color-mix(in srgb, var(--lime) 45%, transparent),
    0 0 36px color-mix(in srgb, var(--lime) 40%, transparent);
  z-index: 5;
}
.team-ball[data-lead="1"] {
  border-width: 4px;
  box-shadow:
    0 0 0 5px color-mix(in srgb, var(--lime) 28%, transparent),
    0 18px 30px -10px rgba(0, 0, 0, 0.7),
    0 0 32px color-mix(in srgb, var(--lime) 22%, transparent);
}
.team-balls__hint {
  position: absolute;
  bottom: var(--s-5);
  inset-inline-start: var(--s-5);
  z-index: 2;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-muted);
  padding: 6px 12px;
  border-radius: var(--r-pill);
  background: rgba(6, 17, 12, 0.55);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid var(--line);
}
@media (max-width: 720px) {
  .team-balls { height: 360px; }
}

/* ---- Visual A: Creator cluster ---- */
.creator-cluster {
  display: flex;
  align-items: center;
  padding-block: 6px;
}
.creator-cluster img {
  width: 44px; height: 44px;
  border-radius: 50%;
  border: 2px solid var(--bg);
  object-fit: cover;
  margin-inline-start: -12px;
  transition: transform var(--t-base), border-color var(--t-base);
  box-shadow: 0 4px 12px -4px rgba(0,0,0,0.5);
}
.creator-cluster img:first-child { margin-inline-start: 0; }
.creator-cluster img:nth-child(1) { z-index: 7; }
.creator-cluster img:nth-child(2) { z-index: 6; }
.creator-cluster img:nth-child(3) { z-index: 5; }
.creator-cluster img:nth-child(4) { z-index: 4; }
.creator-cluster img:nth-child(5) { z-index: 3; }
.creator-cluster img:nth-child(6) { z-index: 2; }
.creator-cluster img:nth-child(7) { z-index: 1; }
.why-item:hover .creator-cluster img { transform: translateY(-3px); }
.why-item:hover .creator-cluster img:nth-child(1) { transition-delay: 0ms; }
.why-item:hover .creator-cluster img:nth-child(2) { transition-delay: 40ms; }
.why-item:hover .creator-cluster img:nth-child(3) { transition-delay: 80ms; }
.why-item:hover .creator-cluster img:nth-child(4) { transition-delay: 120ms; }
.why-item:hover .creator-cluster img:nth-child(5) { transition-delay: 160ms; }
.why-item:hover .creator-cluster img:nth-child(6) { transition-delay: 200ms; }
.why-item:hover .creator-cluster img:nth-child(7) { transition-delay: 240ms; }
.creator-cluster__more {
  width: 44px; height: 44px;
  border-radius: 50%;
  border: 2px solid var(--bg);
  margin-inline-start: -12px;
  background: var(--lime);
  color: var(--lime-ink);
  font-family: var(--f-mono);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.04em;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  z-index: 8;
  position: relative;
  box-shadow: 0 0 24px color-mix(in srgb, var(--lime) 40%, transparent);
}

/* ---- Visual B: Sparkline chart ---- */
.why-item__visual--chart svg {
  width: 100%;
  height: 80px;
  display: block;
}
.why-spark-line {
  animation: why-spark-flow 2.4s linear infinite;
}
@keyframes why-spark-flow {
  to { stroke-dashoffset: -64; }
}
.why-spark-ring {
  transform-origin: 220px 10px;
  transform-box: view-box;
  animation: why-spark-ring 2s var(--ease) infinite;
  stroke-width: 1.5;
}
@keyframes why-spark-ring {
  0%   { r: 4; opacity: 0.9; }
  100% { r: 14; opacity: 0; }
}

/* ---- Visual C: Bar chart ---- */
.why-bars {
  display: flex;
  align-items: flex-end;
  gap: 4px;
  height: 90px;
  padding-block-end: 16px;
  position: relative;
}
.why-bars::after {
  content: "M1 → M12 growth";
  position: absolute;
  bottom: 0;
  inset-inline-start: 0;
  font-family: var(--f-mono);
  font-size: 9px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-muted);
}
.why-bars span {
  flex: 1;
  height: var(--h);
  background: linear-gradient(180deg, color-mix(in srgb, var(--lime) 60%, transparent), color-mix(in srgb, var(--lime) 10%, transparent));
  border-radius: 3px 3px 0 0;
  transform-origin: bottom;
  animation: why-bar-in 1.6s var(--ease) both;
  position: relative;
}
.why-bars span em { display: none; }
.why-bars span.is-peak {
  background: linear-gradient(180deg, var(--lime), color-mix(in srgb, var(--lime) 50%, transparent));
  box-shadow: 0 0 14px color-mix(in srgb, var(--lime) 40%, transparent);
  animation: why-bar-in 1.6s var(--ease) both, peak-glow 2.4s var(--ease) infinite alternate 1.8s;
}
.why-bars span:nth-child(1)  { animation-delay: 0.00s; }
.why-bars span:nth-child(2)  { animation-delay: 0.08s; }
.why-bars span:nth-child(3)  { animation-delay: 0.16s; }
.why-bars span:nth-child(4)  { animation-delay: 0.24s; }
.why-bars span:nth-child(5)  { animation-delay: 0.32s; }
.why-bars span:nth-child(6)  { animation-delay: 0.40s; }
.why-bars span:nth-child(7)  { animation-delay: 0.48s; }
.why-bars span:nth-child(8)  { animation-delay: 0.56s; }
.why-bars span:nth-child(9)  { animation-delay: 0.64s; }
.why-bars span:nth-child(10) { animation-delay: 0.72s; }
.why-bars span:nth-child(11) { animation-delay: 0.80s; }
.why-bars span:nth-child(12) { animation-delay: 0.88s; }
@keyframes why-bar-in {
  from { transform: scaleY(0); opacity: 0; }
  to   { transform: scaleY(1); opacity: 1; }
}
@keyframes peak-glow {
  from { box-shadow: 0 0 14px color-mix(in srgb, var(--lime) 30%, transparent); }
  to   { box-shadow: 0 0 28px color-mix(in srgb, var(--lime) 70%, transparent); }
}

/* ---- Visual D: Network nodes ---- */
.why-item__visual--nodes svg {
  width: 100%;
  height: 100px;
  display: block;
  overflow: visible;
}
.why-nodes__lines line {
  stroke-dasharray: 3 4;
  animation: why-nodes-flow 3s linear infinite;
}
@keyframes why-nodes-flow {
  to { stroke-dashoffset: -28; }
}
.why-nodes__signal {
  filter: drop-shadow(0 0 6px var(--lime));
}
.why-nodes__dots > g > circle:first-child {
  transform-origin: center;
  transform-box: fill-box;
  animation: node-breathe 3.2s var(--ease) infinite alternate;
}
.why-nodes__dots > g:nth-child(2) > circle:first-child { animation-delay: -0.8s; }
.why-nodes__dots > g:nth-child(3) > circle:first-child { animation-delay: -1.6s; }
.why-nodes__dots > g:nth-child(4) > circle:first-child { animation-delay: -0.4s; }
.why-nodes__dots > g:nth-child(5) > circle:first-child { animation-delay: -2.4s; }
.why-nodes__dots > g:nth-child(6) > circle:first-child { animation-delay: -1.2s; }
@keyframes node-breathe {
  from { transform: scale(1); opacity: 0.7; }
  to   { transform: scale(1.15); opacity: 1; }
}

/* ---- Responsive ---- */
@media (max-width: 1024px) {
  .why { grid-template-columns: 1fr; gap: var(--s-6); }
  .why__intro { position: static; }
}
@media (max-width: 720px) {
  .why__grid { grid-template-columns: 1fr; }
  .why-item { padding: var(--s-5); }
  .creator-cluster img,
  .creator-cluster__more { width: 36px; height: 36px; margin-inline-start: -10px; }
}

/* -- Jelly balls (creator network) --------------------------------------- */
.jelly {
  position: relative;
  padding-block: var(--s-8);
}
.jelly__canvas {
  position: relative;
  min-height: 560px;
  padding: var(--s-6) 0;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-content: center;
  gap: 14px;
  mask-image: radial-gradient(ellipse 90% 80% at center, black 60%, transparent 100%);
  -webkit-mask-image: radial-gradient(ellipse 90% 80% at center, black 60%, transparent 100%);
}
.jelly-ball {
  --size: clamp(58px, 5.4vw, 82px);
  width: var(--size);
  height: var(--size);
  border-radius: 50%;
  overflow: hidden;
  position: relative;
  border: 2px solid var(--line-strong);
  background: var(--bg-raised);
  will-change: transform;
  transition: border-color var(--t-fast), box-shadow var(--t-fast);
  flex-shrink: 0;
}
.jelly-ball img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 50%;
  filter: saturate(0.9) contrast(1.03);
}
.jelly-ball.is-near {
  border-color: var(--lime);
  box-shadow: 0 0 0 1px var(--lime), 0 0 32px color-mix(in srgb, var(--lime) 40%, transparent);
}
.jelly__center {
  position: absolute;
  inset-inline: 0;
  inset-block: 50%;
  transform: translateY(-50%);
  text-align: center;
  pointer-events: none;
  z-index: 5;
  mix-blend-mode: difference;
}
.jelly__center .k {
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--lime);
}
.jelly__center .v {
  font-family: var(--f-display);
  font-weight: 600;
  font-size: clamp(64px, 10vw, 140px);
  letter-spacing: -0.035em;
  color: var(--ink);
  line-height: 1;
  margin-block-start: var(--s-2);
}
.jelly__center .l {
  font-family: var(--f-display);
  font-weight: 500;
  font-size: clamp(14px, 1.2vw, 17px);
  color: var(--ink-dim);
  margin-block-start: var(--s-2);
}

/* -- Case studies (v3) --------------------------------------------------- */
.case-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--s-5);
}

/* ---- Compact case studies (v3) — 8 cards, hero-stat + sparkline ---- */
.case-mini-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--s-3);
}
.case-mini {
  position: relative;
  display: grid;
  grid-template-rows: auto 1fr auto;
  gap: var(--s-4);
  padding: var(--s-5);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  background:
    linear-gradient(180deg, rgba(238, 245, 236, 0.025), rgba(238, 245, 236, 0.005));
  text-decoration: none;
  color: inherit;
  isolation: isolate;
  overflow: hidden;
  transition: border-color var(--t-base), transform var(--t-base), background var(--t-base);
  min-height: 240px;
}
/* Radial green glow on hover — enters from the hero-stat area */
.case-mini::before {
  content: "";
  position: absolute;
  inset: -1px;
  background: radial-gradient(420px 220px at 50% 70%, rgba(212, 255, 128, 0.14), transparent 60%);
  opacity: 0;
  border-radius: inherit;
  pointer-events: none;
  z-index: 0;
  transition: opacity var(--t-base);
}
/* Big brand initials as a subtle watermark in the background */
.case-mini__mono {
  position: absolute;
  top: -8px;
  inset-inline-end: 14px;
  font-family: var(--f-display);
  font-weight: 700;
  font-size: clamp(56px, 5.5vw, 78px);
  letter-spacing: -0.03em;
  line-height: 1;
  color: rgba(212, 255, 128, 0.05);
  pointer-events: none;
  user-select: none;
  z-index: 0;
  transition: color var(--t-base);
}
.case-mini:hover {
  border-color: color-mix(in srgb, var(--lime) 35%, var(--line));
  transform: translateY(-4px);
}
.case-mini:hover::before { opacity: 1; }
.case-mini:hover .case-mini__mono { color: rgba(212, 255, 128, 0.09); }
.case-mini > * { position: relative; z-index: 1; }

/* Top row — brand + tag */
.case-mini__top {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: var(--s-3);
}
.case-mini__head {
  display: flex;
  flex-direction: column;
  gap: 5px;
}
.case-mini__brand {
  font-family: var(--f-display);
  font-weight: 600;
  font-size: clamp(18px, 1.5vw, 20px);
  letter-spacing: -0.01em;
  line-height: 1.05;
  color: var(--ink);
}
.case-mini__tag {
  font-family: var(--f-mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-muted);
}

/* Hero metric — the main visual */
.case-mini__hero {
  display: grid;
  grid-template-columns: 1fr auto;
  grid-template-rows: auto auto;
  gap: 2px 10px;
  align-items: end;
  padding-block: var(--s-4) var(--s-3);
}
.case-mini__hero-n {
  grid-row: 1;
  grid-column: 1;
  font-family: var(--f-display);
  font-weight: 700;
  font-size: clamp(32px, 3.2vw, 44px);
  letter-spacing: -0.03em;
  color: var(--lime);
  line-height: 0.95;
  font-variant-numeric: tabular-nums;
  text-shadow: 0 0 28px color-mix(in srgb, var(--lime) 20%, transparent);
}
.case-mini__hero-n em {
  font-style: normal;
  font-weight: 500;
  font-size: 0.55em;
  color: color-mix(in srgb, var(--lime) 70%, var(--ink-dim));
  padding-inline-start: 2px;
}
.case-mini__hero-l {
  grid-row: 2;
  grid-column: 1 / -1;
  font-family: var(--f-mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-dim);
  margin-block-start: 4px;
}
/* Trend sparkline — direction coded by [data-trend] on the card */
.case-mini__spark {
  grid-row: 1;
  grid-column: 2;
  width: 72px;
  height: 26px;
  align-self: end;
  color: var(--lime);
  opacity: 0.85;
  filter: drop-shadow(0 0 4px color-mix(in srgb, var(--lime) 30%, transparent));
  transition: opacity var(--t-base), transform var(--t-base);
}
.case-mini[data-trend="down"] .case-mini__spark { color: var(--lime); }
.case-mini:hover .case-mini__spark {
  opacity: 1;
  transform: translateX(-2px);
}
.case-mini__spark path {
  stroke-dasharray: 200;
  stroke-dashoffset: 200;
  animation: case-spark-draw 1.6s var(--ease) forwards;
}
.case-mini.is-visible .case-mini__spark path,
.case-mini__spark path {
  animation: case-spark-draw 1.6s var(--ease) forwards;
}
@keyframes case-spark-draw {
  to { stroke-dashoffset: 0; }
}

/* Secondary stat chips */
.case-mini__foot {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  padding-block-start: var(--s-3);
  border-block-start: 1px solid var(--line);
}
.case-mini__chip {
  font-family: var(--f-mono);
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-dim);
  padding: 4px 8px;
  border-radius: 6px;
  background: rgba(238, 245, 236, 0.04);
  border: 1px solid var(--line);
  white-space: nowrap;
  transition: border-color var(--t-base), color var(--t-base), background var(--t-base);
}
.case-mini:hover .case-mini__chip {
  border-color: color-mix(in srgb, var(--lime) 28%, var(--line));
  color: var(--ink);
}

/* Slide-in "Read case →" that replaces the chip row on hover */
.case-mini__cta {
  position: absolute;
  inset-inline-start: var(--s-5);
  inset-inline-end: var(--s-5);
  bottom: var(--s-5);
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--lime);
  opacity: 0;
  transform: translateY(8px);
  transition: opacity var(--t-base), transform var(--t-base);
  pointer-events: none;
  display: flex;
  align-items: center;
  gap: 6px;
  padding-block-start: var(--s-3);
  border-block-start: 1px solid color-mix(in srgb, var(--lime) 20%, transparent);
  background: linear-gradient(180deg, transparent, var(--bg) 50%);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  z-index: 2;
}
.case-mini__cta span { transition: transform var(--t-base); }
.case-mini:hover .case-mini__cta {
  opacity: 1;
  transform: translateY(0);
}
.case-mini:hover .case-mini__cta span { transform: translateX(4px); }

@media (max-width: 1180px) {
  .case-mini-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 900px) {
  .case-mini-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 560px) {
  .case-mini-grid { grid-template-columns: 1fr; }
}
.case {
  display: block;
  padding: var(--s-6);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  background: var(--bg-raised);
  transition: border-color var(--t-base), background var(--t-base);
  position: relative;
  overflow: hidden;
}
.case:hover { border-color: var(--lime); background: var(--surface); }
.case__img {
  aspect-ratio: 16 / 10;
  border-radius: var(--r-md);
  overflow: hidden;
  background: var(--surface);
  margin-block-end: var(--s-5);
}
.case__img img { width: 100%; height: 100%; object-fit: cover; transition: transform 1.2s var(--ease); }
.case:hover .case__img img { transform: scale(1.05); }
.case__kicker { display: flex; align-items: center; gap: var(--s-3); margin-block-end: var(--s-3); }
.case__title { font-family: var(--f-display); font-size: clamp(26px, 2.4vw, 36px); font-weight: 600; letter-spacing: -0.02em; line-height: 1; }
.case__desc { color: var(--ink-dim); font-size: 15px; line-height: 1.55; margin-block: var(--s-3) var(--s-5); }
.case__stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--line);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  overflow: hidden;
}
.case__stat {
  background: var(--bg-raised);
  padding: var(--s-4);
  text-align: center;
}
.case__stat .n {
  display: block;
  font-family: var(--f-display);
  font-weight: 600;
  font-size: clamp(22px, 2.2vw, 30px);
  letter-spacing: -0.02em;
  color: var(--lime);
  line-height: 1;
}
.case__stat .l {
  font-family: var(--f-mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-muted);
  margin-block-start: 6px;
  display: block;
}

/* -- Testimonials (3 vertical auto-scroll columns) ----------------------- */
.testi-wrap {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--s-5);
  max-height: 720px;
  overflow: hidden;
  mask-image: linear-gradient(to bottom, transparent, black 18%, black 82%, transparent);
  -webkit-mask-image: linear-gradient(to bottom, transparent, black 18%, black 82%, transparent);
}
.testi-col {
  display: flex;
  flex-direction: column;
  gap: var(--s-4);
  animation: testi-scroll linear infinite;
  will-change: transform;
}
.testi-col--1 { animation-duration: 34s; }
.testi-col--2 { animation-duration: 42s; }
.testi-col--3 { animation-duration: 38s; }
@keyframes testi-scroll {
  from { transform: translateY(0); }
  to { transform: translateY(-50%); }
}
.testi {
  padding: var(--s-6);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  background: var(--bg-raised);
  box-shadow: 0 20px 40px -30px rgba(212,255,128,0.15);
}
.testi__text {
  font-size: 15px;
  line-height: 1.6;
  color: var(--ink-dim);
}
.testi__head {
  margin-block-start: var(--s-5);
  display: flex;
  align-items: center;
  gap: var(--s-3);
}
.testi__avatar {
  width: 40px; height: 40px;
  border-radius: 50%;
  background: var(--surface);
  overflow: hidden;
  flex-shrink: 0;
}
.testi__avatar img { width: 100%; height: 100%; object-fit: cover; }
.testi__name {
  font-family: var(--f-display);
  font-size: 15px;
  font-weight: 500;
  letter-spacing: -0.01em;
  color: var(--ink);
}
.testi__role {
  font-family: var(--f-mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-muted);
  margin-block-start: 4px;
}

/* -- Process (v4) — alive / connected timeline --------------------------- */
.proc {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-auto-rows: 1fr;
  gap: var(--s-4);
  position: relative;
  margin-block-start: var(--s-8);
}

/* Progress rail (sits above the cards, anchors the flow of the 4 steps) */
.proc-rail {
  position: relative;
  height: 44px;
  margin-block: 0 var(--s-6);
  pointer-events: none;
}
.proc-rail__line,
.proc-rail__fill {
  position: absolute;
  top: 50%;
  inset-inline: 8px;
  height: 1px;
  transform: translateY(-50%);
}
.proc-rail__line {
  background: var(--line);
}
.proc-rail__fill {
  background: linear-gradient(90deg, var(--lime), color-mix(in srgb, var(--lime) 40%, transparent));
  width: 100%;
  box-shadow: 0 0 10px color-mix(in srgb, var(--lime) 35%, transparent);
  transform-origin: left;
  animation: rail-fill 4.5s var(--ease) infinite alternate;
}
@keyframes rail-fill {
  from { transform: translateY(-50%) scaleX(0.08); }
  to   { transform: translateY(-50%) scaleX(1); }
}
.proc-rail__tick {
  position: absolute;
  top: 50%;
  width: 44px; height: 44px;
  border-radius: 50%;
  border: 1px solid var(--line);
  background: var(--bg);
  transform: translate(-50%, -50%);
  display: grid;
  place-items: center;
}
.proc-rail__tick i {
  width: 10px; height: 10px;
  border-radius: 50%;
  background: var(--lime);
  box-shadow: 0 0 12px var(--lime);
  display: block;
}
.proc-rail__tick--1 { left: 12.5%; }
.proc-rail__tick--2 { left: 37.5%; }
.proc-rail__tick--3 { left: 62.5%; }
.proc-rail__tick--4 { left: 87.5%; }
.proc-rail__signal {
  position: absolute;
  top: 50%;
  left: 12.5%;
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--lime);
  box-shadow: 0 0 16px var(--lime), 0 0 30px color-mix(in srgb, var(--lime) 40%, transparent);
  transform: translate(-50%, -50%);
  animation: rail-signal 9s var(--ease) infinite;
}
@keyframes rail-signal {
  0%   { left: 12.5%; }
  25%  { left: 37.5%; }
  50%  { left: 62.5%; }
  75%  { left: 87.5%; }
  100% { left: 12.5%; }
}

/* ---- Step card ---- */
.proc-step {
  position: relative;
  padding: var(--s-5) var(--s-6) var(--s-6);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  background: linear-gradient(180deg, rgba(238, 245, 236, 0.02), rgba(238, 245, 236, 0.005));
  display: grid;
  grid-template-rows: auto auto auto 1fr auto;
  gap: var(--s-3);
  isolation: isolate;
  overflow: hidden;
  transition: border-color var(--t-base), transform var(--t-base), background var(--t-base);
}
.proc-step::before {
  /* hover radial glow */
  content: "";
  position: absolute;
  inset: -1px;
  border-radius: inherit;
  background: radial-gradient(600px 260px at 50% 0%, rgba(212, 255, 128, 0.12), transparent 60%);
  opacity: 0;
  transition: opacity var(--t-base);
  pointer-events: none;
  z-index: 0;
}
.proc-step::after {
  /* corner tick, top-right */
  content: "";
  position: absolute;
  top: 10px;
  inset-inline-end: 10px;
  width: 14px; height: 14px;
  background:
    linear-gradient(90deg, var(--lime) 6px, transparent 6px 8px, var(--lime) 8px) top / 100% 1px no-repeat,
    linear-gradient(180deg, var(--lime) 6px, transparent 6px 8px, var(--lime) 8px) right / 1px 100% no-repeat;
  opacity: 0.35;
  transition: opacity var(--t-base);
  pointer-events: none;
  z-index: 1;
}
.proc-step:hover {
  border-color: color-mix(in srgb, var(--lime) 35%, var(--line));
  transform: translateY(-3px);
}
.proc-step:hover::before { opacity: 1; }
.proc-step:hover::after { opacity: 0.85; }

.proc-step > * { position: relative; z-index: 1; }

.proc-step__top {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--s-3);
}
.proc-step__num {
  width: 40px; height: 40px;
  border-radius: 50%;
  background: var(--lime);
  color: var(--lime-ink);
  font-family: var(--f-display);
  font-weight: 700;
  font-size: 18px;
  display: grid;
  place-items: center;
  box-shadow: 0 0 0 4px rgba(12, 36, 25, 1), 0 0 20px color-mix(in srgb, var(--lime) 30%, transparent);
}
.proc-step__week {
  font-family: var(--f-mono);
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-muted);
  padding: 5px 10px;
  border-radius: var(--r-pill);
  border: 1px solid var(--line);
  background: rgba(238, 245, 236, 0.02);
}

/* --- Visual area: every icon rendered inside the SAME 140×76 box --- */
.proc-step__visual {
  height: 96px;
  display: grid;
  place-items: center;
  border-block: 1px solid var(--line);
  padding: 10px 0;
  margin-block: var(--s-2) var(--s-1);
  background:
    radial-gradient(160px 60px at 50% 50%, rgba(212, 255, 128, 0.06), transparent 70%);
}
/* Normalise every graphic to the same footprint */
.proc-step__visual > svg,
.proc-step__visual > .doc-frame,
.proc-step__visual > .launch-grid {
  width: 140px;
  height: 76px;
  max-width: 140px;
  max-height: 76px;
  overflow: visible;
}

/* Visual 2 — document scanning */
.doc-frame {
  position: relative;
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: 10px 12px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 6px;
  overflow: hidden;
  background: rgba(238, 245, 236, 0.02);
}
.doc-line {
  height: 3px;
  background: color-mix(in srgb, var(--ink-dim) 30%, transparent);
  border-radius: 2px;
}
.doc-line--hi { background: color-mix(in srgb, var(--lime) 70%, transparent); }
.doc-scan {
  position: absolute;
  inset-inline: 0;
  top: 0;
  height: 12px;
  background: linear-gradient(180deg, transparent, color-mix(in srgb, var(--lime) 50%, transparent), transparent);
  box-shadow: 0 0 12px color-mix(in srgb, var(--lime) 40%, transparent);
  animation: doc-scan 2.4s var(--ease) infinite;
}
@keyframes doc-scan {
  0%   { top: -12px; opacity: 0; }
  10%  { opacity: 1; }
  90%  { opacity: 1; }
  100% { top: 100%; opacity: 0; }
}

/* Visual 3 — launch grid (creatives going live) */
.launch-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  grid-template-rows: repeat(2, 1fr);
  gap: 5px;
  padding: 6px;
}
.launch-grid span {
  border-radius: 3px;
  background: rgba(238, 245, 236, 0.05);
  border: 1px solid var(--line);
  animation: launch-activate 4s var(--ease) infinite;
}
.launch-grid span:nth-child(1)  { animation-delay: 0.0s; }
.launch-grid span:nth-child(2)  { animation-delay: 0.15s; }
.launch-grid span:nth-child(3)  { animation-delay: 0.3s; }
.launch-grid span:nth-child(4)  { animation-delay: 0.45s; }
.launch-grid span:nth-child(5)  { animation-delay: 0.6s; }
.launch-grid span:nth-child(6)  { animation-delay: 0.75s; }
.launch-grid span:nth-child(7)  { animation-delay: 0.9s; }
.launch-grid span:nth-child(8)  { animation-delay: 1.05s; }
.launch-grid span:nth-child(9)  { animation-delay: 1.2s; }
.launch-grid span:nth-child(10) { animation-delay: 1.35s; }
.launch-grid span:nth-child(11) { animation-delay: 1.5s; }
.launch-grid span:nth-child(12) { animation-delay: 1.65s; }
@keyframes launch-activate {
  0%, 100% { background: rgba(238,245,236,0.05); border-color: var(--line); box-shadow: none; }
  20%      { background: var(--lime); border-color: var(--lime); box-shadow: 0 0 10px color-mix(in srgb, var(--lime) 50%, transparent); }
  60%      { background: color-mix(in srgb, var(--lime) 30%, transparent); border-color: color-mix(in srgb, var(--lime) 40%, var(--line)); }
}

/* Visual 4 — growth chart line */
.scale-line {
  animation: scale-flow 2.4s linear infinite;
}
@keyframes scale-flow {
  to { stroke-dashoffset: -64; }
}
.scale-ring {
  transform-origin: 120px 10px;
  transform-box: view-box;
  animation: scale-ring 2s var(--ease) infinite;
  stroke-width: 1.5;
}
@keyframes scale-ring {
  0%   { r: 4; opacity: 0.9; }
  100% { r: 14; opacity: 0; }
}

/* ---- Title + body ---- */
.proc-step__title {
  font-family: var(--f-display);
  font-weight: 600;
  font-size: clamp(18px, 1.4vw, 20px);
  letter-spacing: -0.01em;
  line-height: 1.15;
  text-transform: uppercase;
  color: var(--ink);
}
.proc-step__body {
  color: var(--ink-dim);
  font-size: 14px;
  line-height: 1.5;
}

/* ---- Deliverable chip (consistent across all 4 cards) ---- */
.proc-step__foot {
  display: flex;
  align-items: center;
  padding-block-start: var(--s-3);
  border-block-start: 1px solid var(--line);
}
.proc-step__chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 10px;
  border-radius: var(--r-pill);
  border: 1px solid color-mix(in srgb, var(--lime) 25%, var(--line));
  background: color-mix(in srgb, var(--lime) 8%, transparent);
  font-family: var(--f-mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--lime);
}

/* ---- Shared CTA row below grid ---- */
.proc-cta {
  margin-block-start: var(--s-7);
  display: flex;
  justify-content: center;
  align-items: center;
  gap: var(--s-5);
  flex-wrap: wrap;
}
.proc-cta__meta {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-muted);
}

/* -- Team (v3) ----------------------------------------------------------- */
.team-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--s-5);
  max-width: 900px;
  margin-inline: auto;
}
.team-member {
  border-radius: var(--r-lg);
  overflow: hidden;
  border: 1px solid var(--line);
  background: var(--bg-raised);
  transition: border-color var(--t-base);
}
.team-member:hover { border-color: var(--lime); }
.team-member__img { aspect-ratio: 1; overflow: hidden; background: var(--surface); }
.team-member__img img { width: 100%; height: 100%; object-fit: cover; filter: saturate(0.9); }
.team-member__body { padding: var(--s-5); text-align: center; }
.team-member__name { font-family: var(--f-display); font-size: 20px; font-weight: 600; letter-spacing: -0.01em; }
.team-member__role { font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--lime); margin-block-start: 6px; }

/* -- Booking block ------------------------------------------------------- */
.book {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--s-8);
  padding: clamp(48px, 6vw, 96px);
  border: 1px solid var(--line);
  border-radius: var(--r-xl);
  background:
    radial-gradient(600px 400px at 100% 0%, rgba(212,255,128,0.08), transparent 60%),
    var(--bg-raised);
}
.book h2 { font-family: var(--f-display); font-size: clamp(40px, 5vw, 72px); font-weight: 600; letter-spacing: -0.03em; line-height: 0.95; }
.book__list { display: grid; gap: var(--s-3); margin-block-start: var(--s-5); }
.book__list li { display: grid; grid-template-columns: 24px 1fr; gap: var(--s-3); color: var(--ink-dim); font-size: 15px; }
.book__list li::before {
  content: "";
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: var(--lime);
  color: var(--lime-ink);
  display: grid;
  place-items: center;
  font-family: var(--f-mono);
  font-size: 12px;
  font-weight: 700;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 16 14' fill='none'%3E%3Cpath d='M2 7.5L6 11.5L14 2.5' stroke='%230A1E11' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: center;
}

/* -- SEO / Prose block --------------------------------------------------- */
.prose {
  max-width: 70ch;
  margin-inline: auto;
}
.prose h2 {
  font-family: var(--f-display);
  font-size: clamp(32px, 4vw, 56px);
  font-weight: 600;
  letter-spacing: -0.03em;
  line-height: 1;
  text-align: center;
  margin-block-end: var(--s-7);
}
.prose p {
  font-size: 17px;
  line-height: 1.75;
  color: var(--ink-dim);
}
.prose p + p { margin-block-start: var(--s-5); }
.prose strong { color: var(--ink); font-weight: 500; }

/* -- FAQ (v3) ------------------------------------------------------------ */
.faq-v3 { max-width: 800px; margin-inline: auto; }
.faq-v3 .faq__q { font-family: var(--f-display); font-weight: 500; font-size: clamp(17px, 1.4vw, 21px); letter-spacing: -0.005em; }
.faq-v3 .faq__a > div { font-size: 15px; line-height: 1.6; }

/* -- Final CTA ----------------------------------------------------------- */
.final-cta {
  padding: clamp(64px, 8vw, 128px) clamp(32px, 5vw, 96px);
  text-align: center;
  border-radius: var(--r-xl);
  background: var(--lime);
  color: var(--lime-ink);
  position: relative;
  overflow: hidden;
}
.final-cta::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    radial-gradient(600px 400px at 15% 100%, rgba(10,30,17,0.2), transparent 60%),
    radial-gradient(500px 300px at 85% 0%, rgba(10,30,17,0.15), transparent 60%);
  pointer-events: none;
}
.final-cta h2 {
  font-family: var(--f-display);
  font-size: clamp(44px, 7vw, 112px);
  font-weight: 600;
  letter-spacing: -0.035em;
  line-height: 0.95;
  color: var(--lime-ink);
  max-width: 16ch;
  margin-inline: auto;
  position: relative;
}
.final-cta__kicker { color: rgba(10,30,17,0.65) !important; }
.final-cta__kicker::before { background: rgba(10,30,17,0.4); }
.final-cta .btn {
  background: var(--lime-ink);
  color: var(--lime);
  margin-block-start: var(--s-7);
  position: relative;
}
.final-cta .btn::after { background: #050d06; }

/* -- Section heading utility -------------------------------------------- */
.sec-head {
  text-align: center;
  max-width: 720px;
  margin-inline: auto;
  margin-block-end: var(--s-8);
}
.sec-head h2 {
  font-family: var(--f-display);
  font-weight: 600;
  font-size: clamp(36px, 5vw, 72px);
  letter-spacing: -0.03em;
  line-height: 1;
  color: var(--ink);
  margin-block-start: var(--s-4);
}
.sec-head h2 em { font-style: normal; color: var(--lime); }
.sec-head p {
  color: var(--ink-dim);
  font-size: clamp(16px, 1.3vw, 18px);
  line-height: 1.55;
  max-width: 58ch;
  margin: var(--s-5) auto 0;
}

/* -- ADMIN PORTAL (sign-in + dashboard) ---------------------------------- */
.signin-page {
  min-height: 100vh;
  display: grid;
  grid-template-columns: 1fr 1fr;
  background: var(--bg);
}
.signin-form-col {
  padding: clamp(40px, 6vw, 80px);
  display: flex;
  align-items: center;
  justify-content: center;
}
.signin-form {
  width: 100%;
  max-width: 420px;
}
.signin-form .brand { margin-block-end: var(--s-8); }
.signin-form h1 {
  font-family: var(--f-display);
  font-size: clamp(36px, 4vw, 52px);
  font-weight: 600;
  letter-spacing: -0.025em;
  line-height: 1;
  color: var(--ink);
}
.signin-form h1 em { font-style: normal; color: var(--lime); }
.signin-form p.lead { margin-block-start: var(--s-4); font-size: 15px; }
.signin-field { display: block; margin-block-start: var(--s-5); }
.signin-field__label {
  display: block;
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-muted);
  margin-block-end: 8px;
}
.signin-field__wrap {
  position: relative;
  border: 1px solid var(--line-strong);
  border-radius: var(--r-md);
  background: rgba(255,255,255,0.025);
  backdrop-filter: blur(6px);
  transition: border-color var(--t-fast), background var(--t-fast);
}
.signin-field__wrap:focus-within {
  border-color: var(--lime);
  background: rgba(212,255,128,0.05);
}
.signin-field__wrap input {
  width: 100%;
  background: transparent;
  border: 0;
  outline: 0;
  color: var(--ink);
  font-family: var(--f-body);
  font-size: 15px;
  padding: 16px;
}
.signin-field__wrap input::placeholder { color: var(--ink-muted); }
.signin-field__toggle {
  position: absolute;
  top: 50%;
  right: 12px;
  transform: translateY(-50%);
  width: 32px; height: 32px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  color: var(--ink-muted);
  transition: color var(--t-fast);
}
.signin-field__toggle:hover { color: var(--lime); }
.signin-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-block-start: var(--s-5);
  font-size: 14px;
}
.signin-row label {
  display: inline-flex;
  align-items: center;
  gap: var(--s-2);
  color: var(--ink-dim);
  cursor: pointer;
}
.signin-row input[type="checkbox"] {
  appearance: none;
  width: 16px; height: 16px;
  border-radius: 4px;
  border: 1px solid var(--line-strong);
  background: transparent;
  cursor: pointer;
  display: grid;
  place-items: center;
  transition: background var(--t-fast), border-color var(--t-fast);
}
.signin-row input[type="checkbox"]:checked {
  background: var(--lime);
  border-color: var(--lime);
}
.signin-row input[type="checkbox"]:checked::after {
  content: "";
  width: 10px; height: 10px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 16 14' fill='none'%3E%3Cpath d='M2 7.5L6 11.5L14 2.5' stroke='%230A1E11' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: center;
}
.signin-row a { color: var(--lime); }
.signin-submit {
  width: 100%;
  margin-block-start: var(--s-6);
  padding: 16px;
  border-radius: var(--r-md);
  background: var(--lime);
  color: var(--lime-ink);
  font-weight: 600;
  font-size: 15px;
  transition: background var(--t-fast);
}
.signin-submit:hover { background: var(--lime-hi); }
.signin-divider {
  display: flex;
  align-items: center;
  gap: var(--s-3);
  margin-block: var(--s-6);
  color: var(--ink-muted);
  font-family: var(--f-mono);
  font-size: 10px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
}
.signin-divider::before, .signin-divider::after {
  content: "";
  flex: 1;
  height: 1px;
  background: var(--line);
}
.signin-google {
  width: 100%;
  padding: 14px;
  border-radius: var(--r-md);
  border: 1px solid var(--line-strong);
  color: var(--ink);
  font-size: 15px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--s-3);
  background: rgba(255,255,255,0.02);
  transition: border-color var(--t-fast), background var(--t-fast);
}
.signin-google:hover { border-color: var(--line-strong); background: rgba(255,255,255,0.05); }
.signin-foot { margin-block-start: var(--s-5); text-align: center; color: var(--ink-muted); font-size: 14px; }
.signin-foot a { color: var(--lime); }
.signin-hero-col {
  position: relative;
  padding: var(--s-4);
  overflow: hidden;
}
.signin-hero {
  position: absolute;
  inset: var(--s-4);
  border-radius: var(--r-xl);
  background: var(--surface);
  background-size: cover;
  background-position: center;
  overflow: hidden;
}
.signin-hero::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(6,17,12,0.1), rgba(6,17,12,0.65));
}
.signin-hero__overlay {
  position: absolute;
  bottom: 32px;
  left: 32px;
  right: 32px;
  display: flex;
  gap: var(--s-4);
  z-index: 2;
  justify-content: center;
}
.signin-quote {
  padding: var(--s-5);
  border-radius: var(--r-lg);
  background: rgba(11,30,19,0.6);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border: 1px solid rgba(255,255,255,0.1);
  max-width: 280px;
  display: flex;
  gap: var(--s-3);
  align-items: flex-start;
}
.signin-quote img { width: 40px; height: 40px; border-radius: var(--r-md); flex-shrink: 0; object-fit: cover; }
.signin-quote__name { font-family: var(--f-display); font-size: 14px; font-weight: 500; color: var(--ink); }
.signin-quote__handle { font-family: var(--f-mono); font-size: 11px; color: var(--ink-muted); margin-block-start: 2px; }
.signin-quote__text { font-size: 13px; color: var(--ink-dim); margin-block-start: var(--s-3); line-height: 1.45; }

/* -- DASHBOARD ----------------------------------------------------------- */
.dash { display: grid; grid-template-columns: 260px 1fr; min-height: 100vh; }
.dash__side {
  border-inline-end: 1px solid var(--line);
  padding: var(--s-5);
  background: var(--bg-raised);
  display: flex;
  flex-direction: column;
  gap: var(--s-6);
}
.dash__nav { display: grid; gap: 2px; }
.dash__nav a {
  display: flex;
  align-items: center;
  gap: var(--s-3);
  padding: 10px 14px;
  border-radius: var(--r-sm);
  color: var(--ink-dim);
  font-size: 14px;
  transition: background var(--t-fast), color var(--t-fast);
}
.dash__nav a:hover { background: var(--surface); color: var(--ink); }
.dash__nav a.is-active { background: var(--surface); color: var(--lime); }
.dash__nav__label { font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--ink-muted); padding: 10px 14px; margin-block-start: var(--s-3); }
.dash__main { padding: var(--s-7); overflow-y: auto; }
.dash__head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-block-end: var(--s-7);
}
.dash__head h1 { font-family: var(--f-display); font-weight: 600; font-size: 32px; letter-spacing: -0.02em; }
.dash__kpis {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--s-4);
  margin-block-end: var(--s-6);
}
.kpi {
  padding: var(--s-5);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  background: var(--bg-raised);
}
.kpi__l { font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--ink-muted); }
.kpi__n { font-family: var(--f-display); font-size: 36px; font-weight: 600; letter-spacing: -0.02em; color: var(--ink); margin-block-start: var(--s-2); }
.kpi__delta { font-family: var(--f-mono); font-size: 12px; color: var(--lime); margin-block-start: 8px; }
.kpi__delta.down { color: var(--red); }
.dash__grid { display: grid; grid-template-columns: 2fr 1fr; gap: var(--s-5); }
.dash-card {
  padding: var(--s-5);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  background: var(--bg-raised);
}
.dash-card h3 { font-family: var(--f-display); font-weight: 500; font-size: 18px; letter-spacing: -0.01em; margin-block-end: var(--s-5); }
.dash-chart {
  height: 280px;
  position: relative;
  background:
    linear-gradient(to top, rgba(212,255,128,0.08), transparent),
    repeating-linear-gradient(90deg, var(--line) 0 1px, transparent 1px 64px),
    repeating-linear-gradient(0deg, var(--line) 0 1px, transparent 1px 48px);
  border-radius: var(--r-md);
  overflow: hidden;
}
.dash-chart svg { width: 100%; height: 100%; }

/* ==================================================================
   RESPONSIVE (v3)
   ================================================================== */
@media (max-width: 1024px) {
  .v3-hero, .why, .book, .signin-page { grid-template-columns: 1fr; }
  .svc-grid, .case-grid, .team-grid { grid-template-columns: 1fr 1fr; }
  .why__grid { grid-template-columns: 1fr; }
  .proc { grid-template-columns: 1fr 1fr; grid-auto-rows: auto; }
  .proc-rail { display: none; }
  .testi-wrap { grid-template-columns: 1fr 1fr; }
  .stats-row { grid-template-columns: 1fr; }
  .dash { grid-template-columns: 1fr; }
  .dash__side { display: none; }
  .dash__kpis { grid-template-columns: 1fr 1fr; }
  .dash__grid { grid-template-columns: 1fr; }
  .signin-hero-col { display: none; }
  .globe-wrap { max-width: 440px; }
}
@media (max-width: 720px) {
  .svc-grid, .case-grid, .team-grid, .proc, .testi-wrap { grid-template-columns: 1fr; }
  .testi-wrap { max-height: 560px; }
  .dash__kpis { grid-template-columns: 1fr; }
}

/* ============================================================================
   UGC MARQUEE  —  replaces the old brand strip under the hero/map. Floating
   phone-shaped cards with a mix of autoplay video and creator stills. The
   track duplicates itself for a seamless loop, mirroring the brand-strip
   animation pattern but with richer cards and a slower scroll speed.
   ============================================================================ */
.ugc-marquee {
  position: relative;
  margin-block-start: var(--s-6);
  padding-block: var(--s-5);
  overflow: hidden;
  border-radius: var(--r-xl);
  background:
    radial-gradient(ellipse 80% 50% at 50% 50%, rgba(212,255,128,0.05), transparent 70%),
    linear-gradient(180deg, rgba(238,245,236,0.02), rgba(238,245,236,0.005));
  border: 1px solid var(--line);
  contain: layout paint;
}
.ugc-marquee::before,
.ugc-marquee::after {
  content: "";
  position: absolute; inset-block: 0;
  width: 120px; z-index: 2; pointer-events: none;
}
.ugc-marquee::before { inset-inline-start: 0; background: linear-gradient(90deg, var(--bg) 0%, transparent 100%); }
.ugc-marquee::after  { inset-inline-end:   0; background: linear-gradient(270deg, var(--bg) 0%, transparent 100%); }
.ugc-marquee__track {
  display: flex;
  align-items: center;
  gap: clamp(16px, 2vw, 28px);
  width: max-content;
  animation: ugc-scroll 60s linear infinite;
  will-change: transform;
  transform: translate3d(0, 0, 0);
  backface-visibility: hidden;
}
.ugc-marquee:hover .ugc-marquee__track { animation-play-state: paused; }
@keyframes ugc-scroll {
  from { transform: translate3d(0, 0, 0); }
  to   { transform: translate3d(-50%, 0, 0); }
}
.ugc-card {
  position: relative;
  flex-shrink: 0;
  width: clamp(160px, 16vw, 220px);
  aspect-ratio: 9 / 16;
  border-radius: 22px;
  overflow: hidden;
  background: var(--surface);
  box-shadow:
    0 24px 48px -24px rgba(0, 0, 0, 0.55),
    0 0 0 1px rgba(238, 245, 236, 0.06);
  transform: translateY(0) rotate(0deg);
  transition: transform 0.6s cubic-bezier(0.16, 1, 0.3, 1);
}
/* Subtle varied rotations so it actually feels "floating", not a flat strip */
.ugc-marquee__track .ugc-card:nth-child(3n+1) { transform: translateY(-8px) rotate(-1.5deg); }
.ugc-marquee__track .ugc-card:nth-child(3n+2) { transform: translateY(6px)  rotate(1.2deg); }
.ugc-marquee__track .ugc-card:nth-child(3n+3) { transform: translateY(-3px) rotate(0.5deg); }
.ugc-card:hover { transform: translateY(-10px) rotate(0deg) scale(1.03); }
.ugc-card img,
.ugc-card video {
  width: 100%; height: 100%; object-fit: cover; display: block;
}
.ugc-card::after {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 55%, rgba(0, 0, 0, 0.5) 100%);
  pointer-events: none;
}
.ugc-card__tag {
  position: absolute;
  inset-inline-start: 12px; inset-block-end: 12px;
  z-index: 1;
  font-family: var(--f-mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink);
  background: rgba(6, 17, 12, 0.6);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  padding: 5px 10px;
  border-radius: var(--r-pill);
  border: 1px solid rgba(238, 245, 236, 0.1);
}
/* Ring highlight on video-bearing cards so they stand out in the reel */
.ugc-card--video {
  box-shadow:
    0 24px 48px -20px rgba(0, 0, 0, 0.6),
    0 0 0 1px rgba(212, 255, 128, 0.28),
    0 0 32px -6px rgba(212, 255, 128, 0.25);
}
.ugc-card--video .ugc-card__tag {
  color: var(--lime);
  border-color: rgba(212, 255, 128, 0.3);
}
/* LIVE dot on video cards */
.ugc-card--video::before {
  content: "";
  position: absolute;
  top: 12px; inset-inline-end: 12px;
  z-index: 1;
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--lime);
  box-shadow: 0 0 12px var(--lime);
  animation: pulse 1.8s var(--ease) infinite;
}

.ugc-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--s-4);
  margin-block-start: var(--s-6);
  padding-block: var(--s-4);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.ugc-stat {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  text-align: center;
}
.ugc-stat strong {
  font-family: var(--f-display);
  font-size: clamp(22px, 2.6vw, 36px);
  font-weight: 600;
  color: var(--ink);
  letter-spacing: -0.02em;
}
.ugc-stat span {
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-muted);
}
@media (max-width: 720px) {
  .ugc-card { width: 140px; border-radius: 18px; }
  .ugc-stats { grid-template-columns: repeat(2, 1fr); gap: var(--s-3); }
  .ugc-stat strong { font-size: 22px; }
  .ugc-marquee::before, .ugc-marquee::after { width: 60px; }
}

/* ============================================================================
   MOBILE OPTIMIZATION PASS  (appended, overrides earlier declarations)
   — Reduces nav height, tightens hero showcase, kills blur on low-end phones,
     collapses grids cleanly, enforces 16px inputs (kills iOS zoom), shrinks
     section padding, compresses FAQ / trust / hero typography, and makes the
     team-balls canvas + testimonials marquee behave at 320–430px viewports.
   ============================================================================ */

/* ===== Base tablet/mobile (≤1024px) ===== */
@media (max-width: 1024px) {
  :root {
    /* Section rhythm tightens on tablet */
    --s-9: 80px;
    --s-10: 96px;
  }
  .section         { padding-block: var(--s-8); }
  .section--sm     { padding-block: var(--s-6); }

  /* Hero showcase — keep floating cards from overlapping phone on iPads */
  .hero-showcase { aspect-ratio: 0.85; max-width: 480px; }

  /* Case studies intermediate (600px–1024px) — 3 cols feels richer than 2 */
  .case-mini-grid { grid-template-columns: repeat(3, 1fr); }

  /* Form inputs never below 16px on tablet — avoids iOS Safari auto-zoom */
  .c-field__input,
  .c-field__select,
  .c-field__textarea { font-size: 16px; }
}

/* ===== Phone (≤720px) — main mobile breakpoint ===== */
@media (max-width: 720px) {
  :root {
    /* Halve the nav so the giant 124px doesn't crush the hero */
    --nav-h: 88px;
    --gutter: 20px;
    --s-8: 56px;
    --s-9: 64px;
    --s-10: 72px;
  }

  /* === NAV — smaller logo, compact actions ================================= */
  .brand__logo        { height: 44px; }
  .brand__logo--lg    { height: 56px; }
  .nav__actions .btn  { padding: 10px 14px; font-size: 13px; }
  .nav__actions .lang { padding: 8px 10px; }

  /* Kill the cursor-follow glow effect on mobile (touch only, no cursor) */
  .cursor { display: none !important; }

  /* === HERO ==============================================================
     On phones we flip the stacking order so the visual showcase appears
     FIRST (above the fold) and the copy flows below it — more impact, no
     awkward wait to see what's happening. Also ditch the full-viewport
     min-height which was centring the stack and pushing the H1 into
     oversized whitespace. */
  .v3-hero {
    display: flex;
    flex-direction: column;
    padding-block: calc(var(--nav-h) + 24px) var(--s-7);
    min-height: auto;
    gap: var(--s-6);
    align-items: stretch;
  }
  .v3-hero > .hero-showcase { order: -1; }   /* visual first */
  .v3-hero > :first-child   { order: 1; }    /* copy block second */

  /* H1 — explicit styling so nothing in the cascade can hide it ============ */
  .v3-hero h1,
  .v3-hero__h1 {
    display: block;
    visibility: visible;
    opacity: 1;
    font-size: clamp(40px, 10.5vw, 72px);
    line-height: 1.02;
    letter-spacing: -0.025em;
    color: #EEF5EC;                /* explicit — same as --ink, belt & braces */
    margin: var(--s-4) 0 0;
    max-width: 20ch;
  }
  .v3-hero__kicker { margin-block-end: var(--s-3); }
  .v3-hero__lead   { font-size: 15px; margin-block-start: var(--s-4); }
  .v3-hero__cta    { gap: var(--s-2); margin-block-start: var(--s-5); }

  /* Hero showcase — the floating stat cards frame the phone cleanly instead of
     overlapping it on narrow screens. Card D (channels) already hidden above. */
  .hero-showcase {
    aspect-ratio: 0.9;
    max-width: 100%;
    margin-block-end: var(--s-3);
  }
  .showcase-card {
    width: clamp(140px, 42vw, 180px);
    padding: 10px 12px;
  }
  .showcase-card__k { font-size: 10px; }
  .showcase-card__v { font-size: clamp(18px, 5.5vw, 22px); }
  .showcase-card__d { font-size: 10px; }
  .showcase-card--a { left: -6px; top: 2%; }
  .showcase-card--b { right: -6px; bottom: 4%; }
  .showcase-card--c { display: none; }

  /* === TRUST ROW — stack vertically so badge gets room ==================== */
  .trust-row {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--s-4);
  }
  .trust-row__k::after { display: none; }
  .trust-row__marks    { gap: var(--s-4); flex-wrap: wrap; }
  .trust-badge         { width: 104px; height: 104px; }
  .trust-badge__img    { width: 86px; height: 86px; }
  .trust-badge__check  { width: 24px; height: 24px; }
  .trust-badge__check svg { width: 13px; height: 13px; }

  /* === SECTION HEADINGS ==================================================== */
  .sec-head h2, .section h2 { font-size: clamp(32px, 8vw, 48px); }
  .display.h2               { font-size: clamp(32px, 8vw, 52px); }

  /* === SERVICES (3 cards stack) ========================================== */
  .svc-grid { gap: var(--s-3); }
  .svc-card { min-height: auto; padding: var(--s-5); gap: var(--s-3); }

  /* === ABOUT / WHY — bento cards single-column ========================== */
  .why-item__visual { max-height: 180px; overflow: hidden; }

  /* === CASE STUDIES — single column stack =============================== */
  .case-mini-grid { grid-template-columns: 1fr; gap: var(--s-3); }
  .case-mini      { padding: var(--s-5); }
  .case-mini__hero-n { font-size: 44px; }

  /* === TESTIMONIALS — collapse 3-col marquee to 1 col, slower scroll ==== */
  .testi-wrap {
    grid-template-columns: 1fr !important;
    max-height: 520px;
  }
  .testi-col--2, .testi-col--3 { display: none; }
  .testi-col--1 { animation-duration: 50s; }
  .testi { padding: var(--s-5); }
  .testi__text { font-size: 14px; }

  /* === PROCESS — 4-step stack cleanly ==================================== */
  .proc { grid-template-columns: 1fr; gap: var(--s-4); }
  .proc-step { padding: var(--s-5); }

  /* === TEAM BALLS — smaller canvas, no hover affordance ================= */
  .team-balls { height: 320px; }
  .team-balls-wrap { border-radius: var(--r-lg); }

  /* === FAQ — tighter row heights ========================================= */
  .faq__q      { padding-block: var(--s-4); font-size: 15px; gap: var(--s-3); }
  .faq__q__icon { width: 32px; height: 32px; flex-shrink: 0; }
  .faq__a p    { font-size: 14px; line-height: 1.6; }

  /* === BOOK / FINAL CTA ================================================== */
  .book              { grid-template-columns: 1fr; gap: var(--s-6); }
  .final-cta h2      { font-size: clamp(32px, 9vw, 48px); }

  /* === FOOTER ============================================================ */
  .footer__top    { grid-template-columns: 1fr; gap: var(--s-6); }

  /* === MARQUEE / BRAND STRIP — tighter cells =========================== */
  .brand-strip__item { height: 40px; width: 120px; }

  /* === PERFORMANCE — cheaper backdrop-filter on low-end phones ========= */
  .nav,
  .showcase-card,
  .c-whatsapp__pulse,
  .showcase-screen__tag {
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
  }

  /* === TOUCH POLISH ===================================================== */
  a, button, .btn, .case-mini, .faq__q, .svc-card__link, .platform {
    -webkit-tap-highlight-color: transparent;
  }
  /* Ensure every interactive element hits the 44×44 WCAG touch target */
  .faq__q, .nav__links a, .footer__links a {
    min-height: 44px;
  }
}

/* ===== Very small phones (≤430px — iPhone SE, 13 mini) ================= */
@media (max-width: 430px) {
  :root {
    --nav-h: 80px;
    --gutter: 16px;
  }
  .brand__logo    { height: 40px; }
  .btn            { padding: 12px 18px; font-size: 13px; }
  .shell          { padding-inline: var(--gutter); }
  .v3-hero h1     { font-size: clamp(36px, 12vw, 56px); }
  .showcase-card  { width: clamp(128px, 46vw, 160px); padding: 8px 10px; }
  .showcase-card__v { font-size: clamp(16px, 6vw, 20px); }
  .case-mini__hero-n { font-size: 36px; }
  .team-balls     { height: 280px; }
  /* Ensure no horizontal overflow — catches any sneaky vw-width children */
  html, body      { overflow-x: hidden; }
}

/* ===== Touch devices ignore hover-only glow so team balls don't stutter */
@media (hover: none) {
  .trust-badge:hover .trust-badge__img { transform: none; }
}
