/* ═══════════════════════════════════════════════════════════
   TOKENS — 2026 PRECISION SYSTEM
   ═══════════════════════════════════════════════════════════ */
:root {
  /* Palette — near-white canvas, surgical blues */
  --ink:        #09090b;
  --ink-60:     rgba(9,9,11,.6);
  --ink-35:     rgba(9,9,11,.35);
  --ink-15:     rgba(9,9,11,.15);
  --ink-06:     rgba(9,9,11,.06);
  --canvas:     #fafafa;
  --surface:    #ffffff;
  --surface-2:  #f4f4f5;
  --blue:       #1d6bf3;
  --blue-dim:   rgba(29,107,243,.1);
  --blue-mid:   rgba(29,107,243,.18);
  --teal:       #06b6d4;
  --teal-dim:   rgba(6,182,212,.08);
  --amber:      #f59e0b;
  --green:      #10b981;

  /* Typography */
  --f-display: 'Bricolage Grotesque', sans-serif;
  --f-mono:    'Geist Mono', monospace;

  /* Spacing scale */
  --s1: .25rem; --s2: .5rem; --s3: .75rem; --s4: 1rem;
  --s5: 1.25rem; --s6: 1.5rem; --s8: 2rem; --s10: 2.5rem;
  --s12: 3rem; --s16: 4rem; --s20: 5rem; --s24: 6rem;

  /* Radii */
  --r-sm: 8px; --r-md: 14px; --r-lg: 22px; --r-xl: 32px;

  /* Shadows */
  --shadow-sm: 0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);
  --shadow-md: 0 4px 16px rgba(0,0,0,.08), 0 2px 6px rgba(0,0,0,.04);
  --shadow-lg: 0 20px 60px rgba(0,0,0,.10), 0 8px 24px rgba(0,0,0,.05);
  --shadow-xl: 0 40px 100px rgba(0,0,0,.12), 0 16px 40px rgba(0,0,0,.06);
  --shadow-blue: 0 12px 40px rgba(29,107,243,.22);

  /* Easing */
  --ease: cubic-bezier(.16,1,.3,1);
  --ease-in: cubic-bezier(.4,0,1,1);
}

/* ── RESET ───────────────────────────────────────────────── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; font-size:16px; }
body {
  font-family: var(--f-display);
  background: var(--canvas);
  color: var(--ink);
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}
a { text-decoration:none; color:inherit; }
img { max-width:100%; display:block; }
button { cursor:pointer; border:none; background:none; font-family:inherit; }

::-webkit-scrollbar { width:4px; }
::-webkit-scrollbar-track { background:var(--canvas); }
::-webkit-scrollbar-thumb { background:var(--ink-15); border-radius:2px; }

/* ── CURSOR ──────────────────────────────────────────────── */
.cursor {
  position:fixed; z-index:9999; pointer-events:none;
  width:10px; height:10px;
  background:var(--blue); border-radius:50%;
  transform:translate(-50%,-50%);
  transition:transform .1s, width .3s var(--ease), height .3s var(--ease), opacity .3s;
  mix-blend-mode: multiply;
}
.cursor-ring {
  position:fixed; z-index:9998; pointer-events:none;
  width:36px; height:36px;
  border:1.5px solid var(--blue);
  border-radius:50%;
  transform:translate(-50%,-50%);
  transition:transform .18s var(--ease), width .4s var(--ease), height .4s var(--ease), opacity .3s, border-color .3s;
  opacity:.45;
}
body:has(a:hover) .cursor { width:18px; height:18px; opacity:.7; }
body:has(a:hover) .cursor-ring { width:52px; height:52px; opacity:.25; }
@media(pointer:coarse){.cursor,.cursor-ring{display:none;}}

/* ═══════════════════════════════════════════════════════════
   NAVIGATION
   ═══════════════════════════════════════════════════════════ */
.nav {
  position:fixed; top:0; left:0; right:0; z-index:900;
  padding:0 var(--s10);
  height:68px;
  display:flex; align-items:center; justify-content:space-between;
  background:rgba(250,250,250,.82);
  backdrop-filter:blur(24px) saturate(1.5);
  -webkit-backdrop-filter:blur(24px) saturate(1.5);
  border-bottom:1px solid var(--ink-06);
  transition:box-shadow .3s;
}
.nav.scrolled { box-shadow: var(--shadow-sm); }

/* Logo */
.logo { display:flex; align-items:center; gap:10px; }
.logo-mark {
  width:32px; height:32px;
  background:var(--ink);
  border-radius:9px;
  display:flex; align-items:center; justify-content:center;
  position:relative; overflow:hidden;
  transition:transform .3s var(--ease);
}
.logo-mark::before {
  content:'';
  position:absolute; inset:0;
  background:linear-gradient(135deg, var(--blue) 0%, var(--teal) 100%);
  opacity:0; transition:opacity .3s;
}
.logo:hover .logo-mark { transform:rotate(-8deg) scale(1.05); }
.logo:hover .logo-mark::before { opacity:1; }
.logo-mark svg { width:18px; height:18px; position:relative; z-index:1; }
.logo-name {
  font-size:1.2rem; font-weight:700;
  letter-spacing:-.03em; color:var(--ink);
}
.logo-name sup {
  font-family:var(--f-mono);
  font-size:.55rem; font-weight:400;
  color:var(--blue); letter-spacing:.02em;
  margin-left:1px; vertical-align:super;
}

/* Nav links */
.nav-menu { display:flex; align-items:center; gap:var(--s1); list-style:none; }
.nav-menu a {
  padding:6px 14px; border-radius:8px;
  font-size:.875rem; font-weight:500;
  color:var(--ink-60);
  transition:color .2s, background .2s;
}
.nav-menu a:hover, .nav-menu a.active {
  color:var(--ink); background:var(--ink-06);
}
.nav-menu a.active {
  color:var(--blue); background:var(--blue-dim);
}

/* Nav Dropdown */
.nav-item { position:relative; }
.nav-item:hover .nav-drop { opacity:1; pointer-events:all; transform:translateX(-50%) translateY(0); }
.nav-drop {
  position:absolute; top:100%; left:50%;
  transform:translateX(-50%) translateY(-8px);
  background:var(--surface); border:1px solid var(--ink-06);
  border-radius:var(--r-lg); padding:var(--s3); padding-top:calc(var(--s3) + 10px);
  min-width:220px; box-shadow:var(--shadow-lg);
  opacity:0; pointer-events:none;
  transition:opacity .25s var(--ease), transform .25s var(--ease);
}
.nav-drop a {
  display:flex; align-items:center; gap:var(--s3);
  padding:var(--s3) var(--s4); border-radius:var(--r-md);
  font-size:.85rem; font-weight:500; color:var(--ink-60);
  transition:background .15s, color .15s; white-space:nowrap;
}
.nav-drop a:hover { background:var(--ink-06); color:var(--ink); }
.nav-drop a svg { width:16px; height:16px; flex-shrink:0; }
.nav-drop-divider { height:1px; background:var(--ink-06); margin:var(--s2) 0; }

/* Nav CTA */
.nav-cta {
  display:flex; align-items:center; gap:var(--s4);
}
.btn-ghost {
  padding:8px 18px; border-radius:9px;
  border:1.5px solid var(--ink-15);
  font-size:.85rem; font-weight:600; color:var(--ink);
  transition:border-color .2s, background .2s;
}
.btn-ghost:hover { border-color:var(--ink-35); background:var(--ink-06); }

.btn-solid {
  padding:9px 20px; border-radius:9px;
  background:var(--ink);
  font-size:.85rem; font-weight:600; color:#fff;
  display:flex; align-items:center; gap:8px;
  transition:background .2s, transform .2s, box-shadow .2s;
  position:relative; overflow:hidden;
}
.btn-solid::before {
  content:''; position:absolute; inset:0;
  background:linear-gradient(135deg, var(--blue), var(--teal));
  opacity:0; transition:opacity .3s;
}
.btn-solid:hover { transform:translateY(-1px); box-shadow:var(--shadow-blue); }
.btn-solid:hover::before { opacity:1; }
.btn-solid span, .btn-solid svg { position:relative; z-index:1; }

.btn-whatsapp {
  display:inline-flex; align-items:center; gap:7px;
  padding:9px 18px; border-radius:9px;
  background:#25d366; color:#fff;
  font-size:.85rem; font-weight:600;
  transition:background .2s, transform .2s, box-shadow .2s;
}
.btn-whatsapp:hover {
  background:#1ebe5d;
  transform:translateY(-1px);
  box-shadow:0 6px 20px rgba(37,211,102,.35);
}

/* ═══════════════════════════════════════════════════════════
   MOBILE MENU
   ═══════════════════════════════════════════════════════════ */
.nav-ham {
  display:none; flex-direction:column; justify-content:center; gap:5px;
  width:40px; height:40px; background:none; border:none;
  cursor:pointer; padding:8px; border-radius:8px;
  transition:background .2s;
}
.nav-ham:hover { background:var(--ink-06); }
.nav-ham span {
  display:block; width:22px; height:2px;
  background:var(--ink); border-radius:2px;
  transition:transform .3s, opacity .3s, width .3s;
}
.nav-ham.open span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.nav-ham.open span:nth-child(2) { opacity:0; width:0; }
.nav-ham.open span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }

.mob-overlay {
  display:none; position:fixed; inset:0; z-index:998;
  background:rgba(0,0,0,.45); backdrop-filter:blur(4px);
}
.mob-overlay.open { display:block; }

.mob-menu {
  position:fixed; top:0; right:-100%; z-index:999;
  width:min(320px,85vw); height:100dvh;
  background:var(--surface); box-shadow:-4px 0 32px rgba(0,0,0,.15);
  transition:right .32s cubic-bezier(.4,0,.2,1);
  display:flex; flex-direction:column; overflow-y:auto;
}
.mob-menu.open { right:0; }

.mob-head {
  display:flex; align-items:center; justify-content:space-between;
  padding:16px 20px; border-bottom:1px solid var(--ink-06);
  position:sticky; top:0; background:var(--surface); z-index:1;
}
.mob-close {
  width:36px; height:36px; background:var(--ink-06);
  border:none; border-radius:50%; font-size:1.3rem;
  cursor:pointer; display:flex; align-items:center; justify-content:center;
  color:var(--ink); line-height:1; transition:background .2s;
}
.mob-close:hover { background:var(--ink-15); }

.mob-nav { flex:1; padding:12px 16px; display:flex; flex-direction:column; gap:2px; }

.mob-link {
  display:flex; align-items:center; justify-content:space-between;
  padding:12px 16px; border-radius:10px;
  font-size:.95rem; font-weight:500; color:var(--ink-60);
  text-decoration:none; background:none; border:none;
  cursor:pointer; width:100%; text-align:left;
  transition:background .15s, color .15s;
}
.mob-link:hover { background:var(--ink-06); color:var(--ink); }
.mob-link.active { color:var(--blue); background:var(--blue-dim); }

.mob-arrow { font-style:normal; transition:transform .3s; display:inline-block; }
.mob-drop-toggle.open .mob-arrow { transform:rotate(180deg); }

.mob-drop-list {
  max-height:0; overflow:hidden;
  transition:max-height .3s ease;
  padding-left:8px;
}
.mob-drop-list.open { max-height:200px; }

.mob-sub-link {
  display:flex; align-items:center; gap:8px;
  padding:10px 16px; border-radius:8px;
  font-size:.88rem; color:var(--ink-60); text-decoration:none;
  transition:background .15s, color .15s;
}
.mob-sub-link:hover { background:var(--ink-06); color:var(--ink); }
.mob-sub-link svg { width:14px; height:14px; flex-shrink:0; }

.mob-footer {
  padding:16px 20px; border-top:1px solid var(--ink-06);
}
.mob-footer .btn-whatsapp { width:100%; justify-content:center; }

.mob-divider { height:1px; background:var(--ink-06); margin:8px 0; }

@media(max-width:768px) {
  .nav-ham { display:flex; }
  .nav-cta { display:none !important; }
}


/* ═══════════════════════════════════════════════════════════
   HERO SLIDER — FULL SCREEN
   ═══════════════════════════════════════════════════════════ */
.hero-slider {
  position:relative;
  width:100%; height:100svh;
  overflow:hidden;
  background:#000;
}

/* Slides */
.slide {
  position:absolute; inset:0;
  opacity:0;
  transition:opacity .9s ease;
  pointer-events:none;
}
.slide.active {
  opacity:1;
  pointer-events:auto;
}
.slide-bg {
  position:absolute; inset:0;
  background-size:cover;
  background-position:center;
  transform:scale(1.04);
  transition:transform 6s ease;
}
.slide.active .slide-bg {
  transform:scale(1);
}

/* Content */
.slide-content {
  position:absolute; inset:0;
  display:flex; flex-direction:column; justify-content:center;
  padding: 0 8% 80px;
  max-width:720px;
}
.slide-eyebrow {
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--f-mono);
  font-size:.72rem; font-weight:400; letter-spacing:.1em;
  color:#60a5fa; text-transform:uppercase;
  margin-bottom:24px;
  padding:5px 14px;
  border:1px solid rgba(96,165,250,.3);
  border-radius:100px;
  background:rgba(96,165,250,.08);
  width:fit-content;
}
.slide-eyebrow::before {
  content:''; width:6px; height:6px; border-radius:50%;
  background:#60a5fa;
  animation:blink 2s ease-in-out infinite;
}
.slide-h1 {
  font-size:clamp(2.8rem,6vw,5.5rem);
  font-weight:800; line-height:1;
  letter-spacing:-.03em;
  color:#fff;
  margin-bottom:20px;
}
.slide-h1 em {
  font-style:normal;
  background:linear-gradient(90deg,#1d6bf3,#60a5fa);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent;
}
.slide-sub {
  font-size:1.05rem; line-height:1.6;
  color:rgba(255,255,255,.65);
  max-width:520px;
  margin-bottom:36px;
}
.btn-slide {
  display:inline-flex; align-items:center; gap:10px;
  background:#1d6bf3;
  color:#fff; font-weight:600; font-size:.95rem;
  padding:14px 28px; border-radius:8px;
  text-decoration:none;
  width:fit-content;
  transition:background .2s, transform .2s, box-shadow .2s;
}
.btn-slide:hover {
  background:#1558d6;
  transform:translateY(-2px);
  box-shadow:0 12px 32px rgba(29,107,243,.4);
}

/* Bottom bar */
.slider-bar {
  position:absolute; bottom:36px; left:8%;
  display:flex; align-items:center; gap:20px;
  z-index:10;
}
.slider-counter {
  font-family:var(--f-mono);
  font-size:.85rem; font-weight:600;
  color:#fff;
  min-width:50px;
}
.slide-total { color:rgba(255,255,255,.4); }
.slider-progress-wrap {
  width:120px; height:2px;
  background:rgba(255,255,255,.2);
  border-radius:2px;
  overflow:hidden;
}
.slider-progress-fill {
  height:100%; width:0%;
  background:#1d6bf3;
  border-radius:2px;
  transition:width linear;
}
.slider-dots {
  display:flex; align-items:center; gap:8px;
}
.sdot {
  width:8px; height:8px; border-radius:50%;
  background:rgba(255,255,255,.3);
  border:none; cursor:pointer; padding:0;
  transition:background .2s, transform .2s;
}
.sdot.active {
  background:#1d6bf3;
  transform:scale(1.3);
}

/* Arrows */
.slider-arrow {
  position:absolute; top:50%; transform:translateY(-50%);
  width:48px; height:48px;
  background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.2);
  border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  cursor:pointer; z-index:10;
  transition:background .2s, border-color .2s;
  backdrop-filter:blur(8px);
}
.slider-arrow:hover { background:rgba(29,107,243,.5); border-color:#1d6bf3; }
.slider-prev { left:32px; }
.slider-next { right:32px; }

@media(max-width:640px) {
  .slider-prev, .slider-next { display:none; }
  .slide-content { padding:0 6% 90px; }
  .slider-bar { left:6%; }
}

/* ═══════════════════════════════════════════════════════════
   HERO — FULL VIEWPORT, ASYMMETRIC (legacy, kept for ref)
   ═══════════════════════════════════════════════════════════ */
.hero {
  min-height:100svh; padding-top:68px;
  display:grid;
  grid-template-columns:1fr 1fr;
  position:relative; overflow:hidden;
}

/* Left panel */
.hero-left {
  display:flex; flex-direction:column; justify-content:center;
  padding: var(--s24) var(--s16) var(--s24) var(--s10);
  position:relative; z-index:2;
}
.hero-eyebrow {
  display:inline-flex; align-items:center; gap:var(--s3);
  font-family:var(--f-mono);
  font-size:.72rem; font-weight:400; letter-spacing:.08em;
  color:var(--blue); text-transform:uppercase;
  margin-bottom:var(--s6);
  padding:5px 12px;
  border:1px solid rgba(29,107,243,.25);
  border-radius:100px;
  background:var(--blue-dim);
  width:fit-content;
}
.hero-eyebrow::before {
  content:''; width:6px; height:6px; border-radius:50%;
  background:var(--blue);
  animation:blink 2s ease-in-out infinite;
}
@keyframes blink { 0%,100%{opacity:1} 50%{opacity:.3} }

.hero-h1 {
  font-size:clamp(3.5rem,6.5vw,7rem);
  font-weight:800; line-height:.95;
  letter-spacing:-.05em;
  color:var(--ink);
  margin-bottom:var(--s8);
}
.hero-h1 .word { display:inline-block; overflow:hidden; }
.hero-h1 .char {
  display:inline-block;
  transform:translateY(110%);
  animation:charUp .7s var(--ease) forwards;
}
.hero-h1 em {
  font-style:normal;
  background:linear-gradient(90deg, var(--blue) 0%, var(--teal) 100%);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent;
  background-clip:text;
}
@keyframes charUp { to { transform:translateY(0); } }

.hero-sub {
  font-size:1.1rem; line-height:1.72;
  color:var(--ink-60); max-width:440px;
  font-weight:400; margin-bottom:var(--s10);
}
.hero-actions {
  display:flex; align-items:center; gap:var(--s4); flex-wrap:wrap;
}
.btn-hero-primary {
  display:inline-flex; align-items:center; gap:10px;
  padding:14px 28px; border-radius:12px;
  background:var(--ink); color:#fff;
  font-size:.95rem; font-weight:700;
  transition:transform .2s var(--ease), box-shadow .2s;
  position:relative; overflow:hidden;
}
.btn-hero-primary::before {
  content:''; position:absolute; inset:0;
  background:linear-gradient(135deg, var(--blue) 0%, #1251c4 100%);
  opacity:0; transition:opacity .3s;
}
.btn-hero-primary:hover { transform:translateY(-2px); box-shadow:0 16px 48px rgba(29,107,243,.3); }
.btn-hero-primary:hover::before { opacity:1; }
.btn-hero-primary span, .btn-hero-primary svg { position:relative; z-index:1; }

.btn-hero-ghost {
  display:inline-flex; align-items:center; gap:8px;
  padding:14px 24px; border-radius:12px;
  border:1.5px solid var(--ink-15);
  font-size:.9rem; font-weight:600; color:var(--ink-60);
  transition:border-color .2s, color .2s, background .2s;
}
.btn-hero-ghost:hover { border-color:var(--ink-35); color:var(--ink); background:var(--ink-06); }

/* Hero trust row */
.hero-trust {
  margin-top:var(--s12);
  display:flex; align-items:center; gap:var(--s6);
}
.trust-divider {
  width:1px; height:36px; background:var(--ink-15);
}
.trust-stat {}
.trust-num {
  font-family:var(--f-display);
  font-size:1.5rem; font-weight:800;
  letter-spacing:-.04em; color:var(--ink);
  line-height:1;
}
.trust-num span { color:var(--blue); }
.trust-label {
  font-size:.72rem; font-weight:500;
  color:var(--ink-35); letter-spacing:.02em;
  margin-top:3px;
}

/* Hero right — visual stage */
.hero-right {
  position:relative; overflow:hidden;
  background:var(--surface-2);
  border-left:1px solid var(--ink-06);
}
.hero-right-inner {
  position:absolute; inset:0;
  display:flex; align-items:center; justify-content:center;
  padding:var(--s10);
}

/* Floating cards in hero */
.hero-cards-stage {
  position:relative; width:100%; height:100%;
  display:flex; align-items:center; justify-content:center;
}
.hf-card {
  position:absolute;
  background:var(--surface);
  border:1px solid var(--ink-06);
  border-radius:var(--r-lg);
  padding:var(--s6) var(--s6);
  box-shadow:var(--shadow-lg);
  backdrop-filter:blur(10px);
  transition:transform .4s var(--ease);
}
.hf-card:hover { transform:translateY(-4px) scale(1.02); }

/* Main card */
.hf-main {
  width:300px; left:50%; top:50%;
  transform:translate(-50%,-50%);
  z-index:3;
}
.hf-main-icon {
  width:52px; height:52px; border-radius:14px;
  display:flex; align-items:center; justify-content:center;
  margin-bottom:var(--s4);
}
.hf-main-title { font-size:1rem; font-weight:700; color:var(--ink); margin-bottom:4px; }
.hf-main-sub { font-size:.78rem; color:var(--ink-35); margin-bottom:var(--s5); }
.hf-chart {
  height:64px; display:flex; align-items:flex-end; gap:4px;
}
.hf-bar {
  flex:1; border-radius:4px 4px 0 0;
  background:linear-gradient(180deg, var(--blue) 0%, rgba(29,107,243,.3) 100%);
  transition:height .3s;
}

/* Smaller float cards */
.hf-sm {
  padding:var(--s4) var(--s5);
  display:flex; align-items:center; gap:var(--s3);
}
.hf-sm-icon {
  width:36px; height:36px; border-radius:10px;
  display:flex; align-items:center; justify-content:center; flex-shrink:0;
}
.hf-sm-label { font-size:.78rem; font-weight:700; color:var(--ink); }
.hf-sm-val { font-family:var(--f-mono); font-size:.7rem; color:var(--ink-35); }

.hf-top-left { left:8%; top:15%; z-index:2; animation:floatA 6s ease-in-out infinite; }
.hf-top-right { right:5%; top:12%; z-index:2; animation:floatB 7s ease-in-out infinite; }
.hf-bot-left { left:4%; bottom:18%; z-index:2; animation:floatC 5.5s ease-in-out infinite; }
.hf-bot-right { right:6%; bottom:15%; z-index:2; animation:floatA 8s ease-in-out 1s infinite; }

@keyframes floatA { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-10px)} }
@keyframes floatB { 0%,100%{transform:translateY(-6px)} 50%{transform:translateY(4px)} }
@keyframes floatC { 0%,100%{transform:translateY(-4px)} 50%{transform:translateY(8px)} }

/* Grid texture */
.hero-grid-bg {
  position:absolute; inset:0;
  background-image:
    linear-gradient(var(--ink-06) 1px, transparent 1px),
    linear-gradient(90deg, var(--ink-06) 1px, transparent 1px);
  background-size:40px 40px;
  mask-image:radial-gradient(ellipse at center, black 30%, transparent 80%);
}

/* Gradient orb */
.hero-orb {
  position:absolute; width:600px; height:600px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(29,107,243,.12) 0%, rgba(6,182,212,.06) 40%, transparent 70%);
  top:50%; left:50%; transform:translate(-50%,-50%);
  pointer-events:none;
}

/* Scroll indicator */
.scroll-hint {
  position:absolute; bottom:var(--s8); left:50%; transform:translateX(-50%);
  display:flex; flex-direction:column; align-items:center; gap:var(--s2);
  z-index:5;
}
.scroll-hint-text {
  font-family:var(--f-mono); font-size:.65rem; letter-spacing:.1em;
  color:var(--ink-35); text-transform:uppercase;
}
.scroll-hint-line {
  width:1px; height:40px;
  background:linear-gradient(180deg, var(--ink-35) 0%, transparent 100%);
  animation:scrollPulse 2s ease-in-out infinite;
}
@keyframes scrollPulse { 0%,100%{opacity:1;transform:scaleY(1)} 50%{opacity:.3;transform:scaleY(.6)} }

/* ═══════════════════════════════════════════════════════════
   SECTION: TICKER / MARQUEE
   ═══════════════════════════════════════════════════════════ */
.ticker {
  border-top:1px solid var(--ink-06);
  border-bottom:1px solid var(--ink-06);
  padding:14px 0;
  overflow:hidden;
  background:var(--surface);
}
.ticker-track {
  display:flex; gap:var(--s10);
  animation:ticker 28s linear infinite;
  width:max-content;
}
.ticker-track:hover { animation-play-state:paused; }
@keyframes ticker { from{transform:translateX(0)} to{transform:translateX(-50%)} }
.ticker-item {
  display:flex; align-items:center; gap:var(--s3);
  font-family:var(--f-mono); font-size:.75rem;
  color:var(--ink-35); letter-spacing:.04em; white-space:nowrap;
}
.ticker-item .dot {
  width:4px; height:4px; border-radius:50%;
  background:var(--blue); opacity:.5;
}
.ticker-item strong { color:var(--ink-60); font-weight:500; }

/* ═══════════════════════════════════════════════════════════
   SECTION: SERVICES — ASYMMETRIC FEATURE LIST
   ═══════════════════════════════════════════════════════════ */
.section { padding:var(--s24) var(--s10); }
.section-sm { padding:var(--s16) var(--s10); }
.section-inner { max-width:1280px; margin:0 auto; }

.chip {
  display:inline-flex; align-items:center; gap:var(--s2);
  font-family:var(--f-mono); font-size:.68rem; font-weight:500;
  letter-spacing:.08em; text-transform:uppercase;
  padding:4px 12px; border-radius:100px;
  border:1px solid var(--ink-15);
  color:var(--ink-60); margin-bottom:var(--s5);
}
.chip.blue { border-color:rgba(29,107,243,.3); color:var(--blue); background:var(--blue-dim); }

.display {
  font-size:clamp(2.4rem,4.5vw,5rem);
  font-weight:800; line-height:1.0;
  letter-spacing:-.04em; color:var(--ink);
}
.display em {
  font-style:normal;
  background:linear-gradient(90deg,var(--blue),var(--teal));
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}

.body-lg { font-size:1.05rem; line-height:1.75; color:var(--ink-60); }

/* Services feature list */
.services-layout {
  display:grid; grid-template-columns:420px 1fr;
  gap:var(--s16); align-items:start; margin-top:var(--s16);
}
.services-sticky {
  position:sticky; top:100px;
}
.services-list { display:flex; flex-direction:column; gap:var(--s2); }

.svc-row {
  padding:var(--s5) var(--s6);
  border-radius:var(--r-md);
  border:1px solid transparent;
  cursor:pointer;
  transition:background .25s, border-color .25s, transform .25s var(--ease);
  position:relative; overflow:hidden;
}
.svc-row::before {
  content:''; position:absolute; left:0; top:0; bottom:0; width:3px;
  background:linear-gradient(180deg,var(--blue),var(--teal));
  transform:scaleY(0); transform-origin:top; transition:transform .3s var(--ease);
  border-radius:0 2px 2px 0;
}
.svc-row:hover, .svc-row.active {
  background:var(--surface);
  border-color:var(--ink-06);
  box-shadow:var(--shadow-sm);
  transform:translateX(4px);
}
.svc-row.active::before { transform:scaleY(1); }
.svc-row-header { display:flex; align-items:center; gap:var(--s4); }
.svc-row-icon {
  width:38px; height:38px; border-radius:10px; flex-shrink:0;
  display:flex; align-items:center; justify-content:center;
  transition:transform .3s var(--ease);
}
.svc-row:hover .svc-row-icon, .svc-row.active .svc-row-icon { transform:scale(1.1); }
.svc-row-name { font-size:.95rem; font-weight:700; color:var(--ink); }
.svc-row-count { margin-left:auto; font-family:var(--f-mono); font-size:.68rem; color:var(--ink-35); }
.svc-row-desc {
  font-size:.85rem; line-height:1.65; color:var(--ink-60);
  margin-top:var(--s3); padding-left:calc(38px + var(--s4));
  max-height:0; overflow:hidden;
  transition:max-height .4s var(--ease), opacity .3s;
  opacity:0;
}
.svc-row.active .svc-row-desc { max-height:200px; opacity:1; }

/* Service detail panel */
.svc-detail { position:sticky; top:100px; }
.svc-panel {
  background:var(--surface);
  border:1px solid var(--ink-06);
  border-radius:var(--r-xl);
  overflow:hidden;
  box-shadow:var(--shadow-lg);
  display:none;
}
.svc-panel.visible { display:block; animation:panelIn .4s var(--ease); }
@keyframes panelIn { from{opacity:0;transform:translateY(16px)} to{opacity:1;transform:translateY(0)} }
.svc-panel-head {
  padding:var(--s8) var(--s8) var(--s6);
  border-bottom:1px solid var(--ink-06);
  position:relative; overflow:hidden;
}
.svc-panel-head-bg {
  position:absolute; inset:0; pointer-events:none;
}
.svc-panel-icon {
  width:56px; height:56px; border-radius:16px;
  display:flex; align-items:center; justify-content:center;
  margin-bottom:var(--s5); position:relative; z-index:1;
}
.svc-panel-title {
  font-size:1.6rem; font-weight:800; letter-spacing:-.03em;
  color:var(--ink); margin-bottom:var(--s3); position:relative; z-index:1;
}
.svc-panel-sub { font-size:.875rem; color:var(--ink-60); line-height:1.6; position:relative; z-index:1; }
.svc-panel-body { padding:var(--s8); }
.svc-items { display:flex; flex-direction:column; gap:var(--s3); }
.svc-item {
  padding:var(--s4) var(--s5);
  background:var(--surface-2);
  border-radius:var(--r-sm);
  display:flex; align-items:flex-start; gap:var(--s4);
  transition:background .2s, transform .2s;
}
.svc-item:hover { background:var(--blue-dim); transform:translateX(3px); }
.svc-item-dot {
  width:8px; height:8px; border-radius:50%;
  background:var(--blue); flex-shrink:0; margin-top:6px;
}
.svc-item-name { font-size:.88rem; font-weight:600; color:var(--ink); }
.svc-item-note { font-size:.78rem; color:var(--ink-35); margin-top:2px; }
.svc-panel-footer {
  padding:var(--s5) var(--s8) var(--s8);
}
.svc-panel-link {
  display:inline-flex; align-items:center; gap:8px;
  padding:11px 22px; border-radius:10px;
  background:var(--ink); color:#fff;
  font-size:.85rem; font-weight:700;
  transition:background .2s, transform .2s, box-shadow .2s;
  position:relative; overflow:hidden;
}
.svc-panel-link::before {
  content:''; position:absolute; inset:0;
  background:linear-gradient(135deg,var(--blue),var(--teal));
  opacity:0; transition:opacity .3s;
}
.svc-panel-link:hover { transform:translateY(-1px); box-shadow:var(--shadow-blue); }
.svc-panel-link:hover::before { opacity:1; }
.svc-panel-link span, .svc-panel-link svg { position:relative; z-index:1; }

/* ═══════════════════════════════════════════════════════════
   SECTION: BENTO GRID — COMPANY DNA
   ═══════════════════════════════════════════════════════════ */
.bento { padding:var(--s24) var(--s10); background:var(--surface); }
.bento-grid {
  display:grid;
  grid-template-columns:repeat(12, 1fr);
  grid-template-rows:auto;
  gap:var(--s3);
  max-width:1280px; margin:var(--s12) auto 0;
}
.bento-cell {
  background:var(--canvas);
  border:1px solid var(--ink-06);
  border-radius:var(--r-lg);
  overflow:hidden;
  transition:transform .3s var(--ease), box-shadow .3s, border-color .3s;
}
.bento-cell:hover { transform:translateY(-3px); box-shadow:var(--shadow-md); border-color:var(--ink-15); }
.bento-pad { padding:var(--s8); }

/* Grid placement */
.bc-1 { grid-column:span 5; grid-row:span 2; }
.bc-2 { grid-column:span 4; }
.bc-3 { grid-column:span 3; }
.bc-4 { grid-column:span 4; }
.bc-5 { grid-column:span 3; }
.bc-6 { grid-column:span 7; }
.bc-7 { grid-column:span 5; }

.bento-label {
  font-family:var(--f-mono); font-size:.68rem; letter-spacing:.1em;
  text-transform:uppercase; color:var(--ink-35); margin-bottom:var(--s3);
}
.bento-num {
  font-size:clamp(3rem,5vw,5.5rem); font-weight:800;
  letter-spacing:-.06em; line-height:1;
  color:var(--ink); margin-bottom:var(--s2);
}
.bento-num small { font-size:.45em; color:var(--blue); }
.bento-text { font-size:.85rem; color:var(--ink-60); line-height:1.6; }
.bento-title { font-size:1.2rem; font-weight:700; color:var(--ink); margin-bottom:var(--s3); letter-spacing:-.02em; }

/* Radial gauge */
.gauge-wrap { display:flex; align-items:center; justify-content:center; padding:var(--s5) 0; }
.gauge { position:relative; width:120px; height:120px; }
.gauge svg { transform:rotate(-90deg); }
.gauge-val {
  position:absolute; inset:0;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
}
.gauge-pct { font-size:1.6rem; font-weight:800; letter-spacing:-.04em; color:var(--ink); }
.gauge-lbl { font-family:var(--f-mono); font-size:.58rem; color:var(--ink-35); letter-spacing:.08em; }

/* Mini bar chart */
.mini-bars { display:flex; align-items:flex-end; gap:4px; height:60px; margin-top:var(--s5); }
.mini-bar { flex:1; border-radius:4px 4px 0 0; background:var(--blue-dim); position:relative; overflow:hidden; }
.mini-bar-fill {
  position:absolute; bottom:0; left:0; right:0;
  background:linear-gradient(180deg,var(--blue),rgba(29,107,243,.5));
  border-radius:4px 4px 0 0;
  animation:barGrow .8s var(--ease) forwards;
  transform-origin:bottom;
}
@keyframes barGrow { from{height:0} to{height:var(--h)} }

/* Timeline mini */
.tl-mini { display:flex; flex-direction:column; gap:var(--s3); }
.tl-mini-item { display:flex; gap:var(--s4); align-items:flex-start; }
.tl-mini-year {
  font-family:var(--f-mono); font-size:.68rem; font-weight:500;
  color:var(--blue); min-width:36px; padding-top:2px;
}
.tl-mini-line { display:flex; flex-direction:column; align-items:center; gap:0; }
.tl-mini-dot { width:8px; height:8px; border-radius:50%; background:var(--blue); flex-shrink:0; }
.tl-mini-dash { width:1px; flex:1; min-height:20px; background:var(--ink-06); }
.tl-mini-text { font-size:.82rem; color:var(--ink-60); line-height:1.5; }
.tl-mini-text strong { color:var(--ink); font-weight:700; }

/* Tech stack logos */
.tech-pills { display:flex; flex-wrap:wrap; gap:var(--s2); margin-top:var(--s4); }
.tech-pill {
  padding:5px 12px; border-radius:8px;
  background:var(--surface); border:1px solid var(--ink-06);
  font-family:var(--f-mono); font-size:.7rem; font-weight:500;
  color:var(--ink-60);
  transition:border-color .2s, color .2s, background .2s;
}
.tech-pill:hover { border-color:var(--blue); color:var(--blue); background:var(--blue-dim); }

/* Certification badges */
.cert-grid { display:grid; grid-template-columns:1fr 1fr; gap:var(--s3); margin-top:var(--s4); }
.cert-badge {
  padding:var(--s4); border-radius:var(--r-sm);
  background:var(--surface); border:1px solid var(--ink-06);
  text-align:center; transition:border-color .2s;
}
.cert-badge:hover { border-color:var(--blue); }
.cert-icon { font-size:1.5rem; margin-bottom:4px; }
.cert-name { font-size:.72rem; font-weight:700; color:var(--ink); }
.cert-sub { font-family:var(--f-mono); font-size:.6rem; color:var(--ink-35); }

/* ═══════════════════════════════════════════════════════════
   SECTION: PROCESS — HORIZONTAL SCROLL CARDS
   ═══════════════════════════════════════════════════════════ */
.process { padding:var(--s24) 0; background:var(--canvas); overflow:hidden; }
.process-header { padding:0 var(--s10); max-width:1280px; margin:0 auto var(--s12); }
.process-scroll-wrap { overflow-x:auto; padding:var(--s4) var(--s10) var(--s8); scrollbar-width:none; }
.process-scroll-wrap::-webkit-scrollbar { display:none; }
.process-track { display:flex; gap:var(--s5); width:max-content; }

.process-card {
  width:280px; flex-shrink:0;
  background:var(--surface);
  border:1px solid var(--ink-06);
  border-radius:var(--r-xl);
  padding:var(--s8) var(--s6);
  transition:transform .3s var(--ease), box-shadow .3s, border-color .3s;
}
.process-card:hover { transform:translateY(-6px); box-shadow:var(--shadow-lg); border-color:var(--ink-15); }
.process-step {
  font-family:var(--f-mono); font-size:.65rem; letter-spacing:.1em;
  text-transform:uppercase; color:var(--ink-35); margin-bottom:var(--s5);
}
.process-icon {
  width:52px; height:52px; border-radius:14px;
  display:flex; align-items:center; justify-content:center;
  margin-bottom:var(--s5);
}
.process-name { font-size:1.05rem; font-weight:700; color:var(--ink); margin-bottom:var(--s3); letter-spacing:-.02em; }
.process-desc { font-size:.82rem; line-height:1.65; color:var(--ink-60); }
.process-connector {
  flex-shrink:0; display:flex; align-items:center;
  padding-top:var(--s16);
}
.process-arrow {
  width:36px; height:1px; background:var(--ink-15);
  position:relative;
}
.process-arrow::after {
  content:''; position:absolute; right:-1px; top:-3px;
  border:4px solid transparent; border-left:6px solid var(--ink-15);
}

/* ═══════════════════════════════════════════════════════════
   SECTION: TESTIMONIALS
   ═══════════════════════════════════════════════════════════ */
.testimonials { padding:var(--s24) var(--s10); background:var(--ink); position:relative; overflow:hidden; }
.testimonials::before {
  content:''; position:absolute; top:-40%; right:-10%;
  width:800px; height:800px; border-radius:50%;
  background:radial-gradient(circle, rgba(29,107,243,.18) 0%, transparent 65%);
  pointer-events:none;
}
.testimonials::after {
  content:''; position:absolute; bottom:-30%; left:-5%;
  width:600px; height:600px; border-radius:50%;
  background:radial-gradient(circle, rgba(6,182,212,.08) 0%, transparent 65%);
  pointer-events:none;
}
.testimonials-inner { max-width:1280px; margin:0 auto; position:relative; z-index:1; }
.testimonials-inner .chip.light { border-color:rgba(255,255,255,.15); color:rgba(255,255,255,.5); }
.testimonials-inner .display { color:#fff; }

.testi-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:var(--s5); margin-top:var(--s12); }
.testi-card {
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.08);
  border-radius:var(--r-lg); padding:var(--s8);
  transition:background .3s, border-color .3s, transform .3s var(--ease);
}
.testi-card:hover { background:rgba(255,255,255,.08); border-color:rgba(29,107,243,.3); transform:translateY(-4px); }
.testi-stars { display:flex; gap:3px; margin-bottom:var(--s5); }
.testi-star { font-size:.85rem; }
.testi-quote { font-size:.9rem; line-height:1.72; color:rgba(255,255,255,.65); margin-bottom:var(--s6); }
.testi-author { display:flex; align-items:center; gap:var(--s4); }
.testi-avatar {
  width:40px; height:40px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-size:.9rem; font-weight:700; color:#fff; flex-shrink:0;
}
.testi-name { font-size:.875rem; font-weight:700; color:#fff; }
.testi-role { font-size:.75rem; color:rgba(255,255,255,.38); margin-top:2px; }

/* ═══════════════════════════════════════════════════════════
   SECTION: CTA — DARK FLOATING CARD
   ═══════════════════════════════════════════════════════════ */
.cta-section { padding:var(--s24) var(--s10); background:var(--canvas); }
.cta-card {
  max-width:1280px; margin:0 auto;
  background:var(--ink);
  border-radius:var(--r-xl); padding:var(--s16) var(--s16);
  display:grid; grid-template-columns:1fr auto;
  gap:var(--s12); align-items:center;
  position:relative; overflow:hidden;
}
.cta-card::before {
  content:''; position:absolute;
  top:-60%; left:-10%; width:700px; height:700px; border-radius:50%;
  background:radial-gradient(circle, rgba(29,107,243,.2) 0%, transparent 65%);
  pointer-events:none;
}
.cta-card::after {
  content:''; position:absolute;
  bottom:-50%; right:-5%; width:500px; height:500px; border-radius:50%;
  background:radial-gradient(circle, rgba(6,182,212,.1) 0%, transparent 65%);
  pointer-events:none;
}
.cta-left { position:relative; z-index:1; }
.cta-eyebrow {
  font-family:var(--f-mono); font-size:.68rem; letter-spacing:.12em;
  text-transform:uppercase; color:rgba(255,255,255,.35);
  margin-bottom:var(--s4);
}
.cta-headline {
  font-size:clamp(2rem,3.5vw,3.5rem); font-weight:800;
  letter-spacing:-.04em; color:#fff; line-height:1.0;
  margin-bottom:var(--s5);
}
.cta-headline em {
  font-style:normal;
  background:linear-gradient(90deg,var(--blue),var(--teal));
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.cta-sub { font-size:.95rem; color:rgba(255,255,255,.45); line-height:1.7; max-width:480px; }
.cta-right { display:flex; flex-direction:column; gap:var(--s4); align-items:flex-end; position:relative; z-index:1; }
.btn-cta-primary {
  padding:15px 30px; border-radius:12px;
  background:linear-gradient(135deg, var(--blue) 0%, #1251c4 100%);
  color:#fff; font-size:.95rem; font-weight:700;
  display:flex; align-items:center; gap:10px;
  transition:transform .2s var(--ease), box-shadow .2s;
  white-space:nowrap;
}
.btn-cta-primary:hover { transform:translateY(-2px); box-shadow:0 16px 48px rgba(29,107,243,.4); }
.btn-cta-secondary {
  padding:14px 28px; border-radius:12px;
  border:1.5px solid rgba(255,255,255,.15);
  color:rgba(255,255,255,.7); font-size:.9rem; font-weight:600;
  display:flex; align-items:center; gap:8px;
  transition:border-color .2s, color .2s, background .2s;
  white-space:nowrap;
}
.btn-cta-secondary:hover { border-color:rgba(255,255,255,.35); color:#fff; background:rgba(255,255,255,.06); }
.cta-contact-info {
  text-align:right;
  font-family:var(--f-mono); font-size:.7rem;
  color:rgba(255,255,255,.25); letter-spacing:.04em;
  line-height:1.8;
}

/* ═══════════════════════════════════════════════════════════
   FOOTER
   ═══════════════════════════════════════════════════════════ */
footer {
  background:var(--ink); border-top:1px solid rgba(255,255,255,.06);
  padding:var(--s16) var(--s10) var(--s8);
}
.footer-grid {
  max-width:1280px; margin:0 auto;
  display:grid; grid-template-columns:2fr 1fr 1.4fr;
  gap:var(--s12); padding-bottom:var(--s12);
  border-bottom:1px solid rgba(255,255,255,.06);
}

/* Footer location card */
/* Footer map card */
.footer-location-card {
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.09);
  border-radius: 16px;
  padding: 16px;
  display: flex; flex-direction: column; gap: 12px;
}
.flc-label {
  font-family: var(--f-mono); font-size: .65rem;
  letter-spacing: .13em; text-transform: uppercase;
  color: rgba(255,255,255,.35); padding: 0 2px;
}
.flc-map-wrap {
  width: 100%; height: 190px;
  border-radius: 10px; overflow: hidden;
  border: 1px solid rgba(255,255,255,.08);
  flex-shrink: 0;
}
.flc-map-wrap iframe { display: block; }
.flc-bottom {
  display: flex; align-items: center;
  justify-content: space-between; gap: 10px;
}
.flc-addr-row {
  display: flex; align-items: center; gap: 6px; flex: 1; min-width: 0;
}
.flc-addr-row svg { flex-shrink: 0; }
.flc-addr-text {
  font-size: .78rem; color: rgba(255,255,255,.45);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.flc-open-btn {
  display: flex; align-items: center; gap: 5px; flex-shrink: 0;
  padding: 7px 13px; border-radius: 8px;
  background: var(--blue); color: #fff;
  font-size: .78rem; font-weight: 700;
  transition: background .2s, transform .2s;
}
.flc-open-btn:hover { background: #1251c4; transform: translateY(-1px); }
.footer-brand-desc { font-size:.85rem; line-height:1.7; color:rgba(255,255,255,.35); max-width:260px; margin:var(--s5) 0 var(--s6); }
.footer-socials { display:flex; gap:var(--s2); }
.fsoc {
  width:36px; height:36px; border-radius:9px;
  background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.08);
  display:flex; align-items:center; justify-content:center;
  transition:background .2s, border-color .2s, transform .2s;
}
.fsoc:hover { background:rgba(29,107,243,.2); border-color:rgba(29,107,243,.3); transform:translateY(-2px); }
.fsoc svg { width:16px; height:16px; }
.footer-col-h { font-family:var(--f-mono); font-size:.68rem; font-weight:500; letter-spacing:.1em; text-transform:uppercase; color:rgba(255,255,255,.25); margin-bottom:var(--s5); }
.footer-links { list-style:none; display:flex; flex-direction:column; gap:var(--s3); }
.footer-links a { font-size:.875rem; color:rgba(255,255,255,.45); transition:color .2s; }
.footer-links a:hover { color:#fff; }
.footer-bottom {
  max-width:1280px; margin:var(--s6) auto 0;
  display:flex; align-items:center; justify-content:space-between;
  gap:var(--s4); flex-wrap:wrap;
}
.footer-copy { font-family:var(--f-mono); font-size:.7rem; color:rgba(255,255,255,.22); }
.footer-legal { display:flex; gap:var(--s6); }
.footer-legal a { font-size:.78rem; color:rgba(255,255,255,.25); transition:color .2s; }
.footer-legal a:hover { color:rgba(255,255,255,.6); }

/* ═══════════════════════════════════════════════════════════
   REVEAL SYSTEM
   ═══════════════════════════════════════════════════════════ */
.rv  { opacity:0; transform:translateY(28px); transition:opacity .65s var(--ease), transform .65s var(--ease); }
.rvl { opacity:0; transform:translateX(-28px); transition:opacity .65s var(--ease), transform .65s var(--ease); }
.rvr { opacity:0; transform:translateX(28px); transition:opacity .65s var(--ease), transform .65s var(--ease); }
.rv.on, .rvl.on, .rvr.on { opacity:1; transform:none; }
.d1{transition-delay:.1s} .d2{transition-delay:.2s} .d3{transition-delay:.3s}
.d4{transition-delay:.4s} .d5{transition-delay:.5s}

/* ═══════════════════════════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════════════════════════ */
@media(max-width:1100px) {
  .hero { grid-template-columns:1fr; min-height:auto; }
  .hero-right { display:none; }
  .services-layout { grid-template-columns:1fr; }
  .services-sticky, .svc-detail { position:static; }
  .testi-grid { grid-template-columns:1fr; }
  .bento-grid { grid-template-columns:repeat(6,1fr); }
  .bc-1,.bc-2,.bc-3,.bc-4,.bc-5,.bc-6,.bc-7 { grid-column:span 3; }
  .cta-card { grid-template-columns:1fr; }
  .cta-right { align-items:flex-start; }
  .footer-grid { grid-template-columns:1fr 1fr; }
  .footer-location-card { grid-column:span 2; }
}
@media(max-width:768px) {
  .nav { padding:0 var(--s6); }
  .nav-menu { display:none; }
  .section, .bento, .cta-section { padding:var(--s16) var(--s6); }
  .testimonials { padding:var(--s16) var(--s6); }
  .process-scroll-wrap { padding-left:var(--s6); }
  .hero-left { padding:var(--s16) var(--s6); }
  .bento-grid { grid-template-columns:1fr; }
  .bc-1,.bc-2,.bc-3,.bc-4,.bc-5,.bc-6,.bc-7 { grid-column:span 1; }
  .footer-grid { grid-template-columns:1fr; gap:var(--s8); }
  .footer { padding:var(--s12) var(--s6) var(--s6); }
}
