/* =========================================================
   SPICA · Media Kit 2026 v2 — single landing
   ========================================================= */

:root{
  --bg:           #f6f5f1;
  --bg-2:         #ecebe6;
  --ink:          #0e0e0d;
  --ink-2:        #3a3833;
  --ink-3:        #8a857c;
  --rule:         rgba(14,14,13,.08);
  --rule-2:       rgba(14,14,13,.16);
  --invert:       #ffffff;
  --black:        #0a0a0a;
  --black-2:      #131312;

  --accent:       #D6D1C4;       /* warm neutral (was spica violet) */
  --accent-2:     #908B82;
  --accent-3:     #4A4843;
  --accent-glow:  rgba(17,17,16,.28);

  --sans:  'Geist', 'Nunito', system-ui, -apple-system, sans-serif;
  --mono:  'Geist Mono', ui-monospace, SFMono-Regular, Menlo, monospace;

  --ease:    cubic-bezier(.2,.65,.3,1);
  --ease-out: cubic-bezier(.16,1,.3,1);
  --ease-in:  cubic-bezier(.7,0,.84,0);

  --r-pill: 999px;
  --r-card: 18px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
html, body{margin:0;padding:0}
body{
  font-family:var(--sans);
  background:var(--bg);
  color:var(--ink);
  font-weight:400;
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}

img,svg{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;background:none;border:0;color:inherit;cursor:pointer;padding:0}

.container{max-width:1280px;margin:0 auto;padding:0 32px}

/* ---------- SCROLL PROGRESS ---------- */
.scroll-progress{
  position:fixed;
  top:0;left:0;
  height:2px;
  width:0%;
  background:linear-gradient(90deg,var(--accent),var(--accent-3));
  z-index:1000;
  transition:width .12s linear;
}

/* ---------- NAV ---------- */
.nav{
  position:fixed;
  top:0;left:0;right:0;
  z-index:200;
  padding:0 clamp(20px,3vw,48px);
  color:var(--invert);
  transition:top .5s var(--ease), padding .5s var(--ease), color .5s var(--ease);
  pointer-events:none;
}
.nav-inner{
  max-width:none;
  width:100%;
  margin:0 auto;
  display:flex;
  align-items:center;
  justify-content:space-between;
  flex-wrap:wrap;
  padding:16px 0;
  border-radius:999px;
  border:0;
  background:transparent;
  backdrop-filter:none;
  -webkit-backdrop-filter:none;
  transition:
    max-width .6s var(--ease),
    width .6s var(--ease),
    padding .55s var(--ease),
    background .45s var(--ease),
    border-color .45s var(--ease),
    box-shadow .5s var(--ease),
    backdrop-filter .45s var(--ease),
    -webkit-backdrop-filter .45s var(--ease);
  pointer-events:auto;
}

/* Brand — logo on left, matches Spica .navbar-brand */
.nav-brand{
  display:inline-flex;align-items:center;
  padding:0 14px;
  margin-right:16px;
}
.nav-logo{
  height:28px;width:auto;
  transition:filter .35s var(--ease);
}

/* Menu — centered between brand and right group via mx-auto, matches Spica .navbar-nav.mx-auto */
.nav-menu{
  list-style:none;padding:0;
  margin:0 auto;
  display:flex;gap:16px;align-items:center;
  font-family:var(--sans);
  font-size:14px;
  font-weight:400;
  line-height:1.5;
  letter-spacing:-0.005em;
  white-space:nowrap;
  color:rgba(255,255,255,.85);
}
.nav-menu a{
  position:relative;
  padding:0 8px;
  transition:color .42s cubic-bezier(.22,1,.36,1);
}
.nav-menu a:hover{color:var(--invert)}
.nav:not(.is-dark) .nav-menu{color:var(--ink-2)}
.nav:not(.is-dark) .nav-menu a:hover{color:var(--ink)}

/* Right group — CTA + lang, matches Spica .nav-btns */
.nav-right{
  display:flex;align-items:center;gap:10px;
}

.nav-cta-wrap{
  position:relative;
  display:inline-flex;align-items:center;
}
.nav-cta{
  font-family:var(--sans);
  font-size:13px;
  font-weight:400;
  letter-spacing:-0.005em;
  text-transform:none;
  white-space:nowrap;
  padding:7px 16px;
  margin-right:8px;
  color:rgba(255,255,255,.85);
  border:1px solid rgba(255,255,255,.35);
  border-radius:var(--r-pill);
  background:transparent;
  transition:background .3s var(--ease), color .3s var(--ease), border-color .3s var(--ease), transform .3s var(--ease);
}
.nav-cta:hover{
  background:var(--invert);
  color:var(--ink);
  border-color:var(--invert);
}
.nav:not(.is-dark) .nav-cta{
  color:var(--ink);
  border-color:rgba(14,14,13,.25);
}
.nav:not(.is-dark) .nav-cta:hover{
  background:var(--ink);
  color:var(--bg);
  border-color:var(--ink);
}

.nav-microcopy{
  position:absolute;
  top:calc(100% + 10px);
  left:50%;
  transform:translate(-50%,-2px);
  margin:0;
  font-family:var(--sans);
  font-size:12px;
  line-height:1.4;
  color:rgba(255,255,255,.55);
  width:max-content;
  max-width:30ch;
  text-align:center;
  opacity:0;
  pointer-events:none;
  transition:opacity 260ms var(--ease), transform 260ms var(--ease);
}
.nav:not(.is-dark) .nav-microcopy{color:rgba(14,14,13,.55)}
.nav-cta-wrap:hover .nav-microcopy,
.nav-cta:focus-visible ~ .nav-microcopy{
  opacity:1;
  transform:translate(-50%,0);
}

.lang{
  display:flex;gap:6px;align-items:center;
  margin-left:14px;
}
.lang-opt{
  cursor:pointer;
  font-family:var(--mono);
  font-size:11px;
  font-weight:500;
  letter-spacing:.08em;
  color:rgba(255,255,255,.55);
  transition:color .42s cubic-bezier(.22,1,.36,1);
}
.lang-opt.active{color:var(--invert)}
.lang-divider{
  font-size:11px;
  color:rgba(255,255,255,.35);
  transition:color .42s cubic-bezier(.22,1,.36,1);
}
.nav:not(.is-dark) .lang-opt{color:var(--ink-3)}
.nav:not(.is-dark) .lang-opt.active{color:var(--ink)}
.nav:not(.is-dark) .lang-divider{color:var(--ink-3)}

/* State B: floating glass pill (Apple liquid glass style) */
.nav.is-stuck{
  top:10px;
  padding:0 16px;
}
.nav.is-stuck .nav-inner{
  max-width:1080px;
  padding:8px 10px 8px 18px;
  background:rgba(10,10,10,.55);
  border:1px solid rgba(255,255,255,.10);
  backdrop-filter:blur(22px) saturate(180%);
  -webkit-backdrop-filter:blur(22px) saturate(180%);
  box-shadow:
    0 12px 40px -14px rgba(0,0,0,.5),
    inset 0 1px 0 rgba(255,255,255,.08),
    inset 0 -1px 0 rgba(255,255,255,.02);
}
.nav.is-stuck.is-dark .nav-inner{
  /* already styled for dark */
}
.nav.is-stuck:not(.is-dark) .nav-inner{
  background:rgba(246,245,241,.62);
  border:1px solid rgba(14,14,13,.08);
  backdrop-filter:blur(22px) saturate(180%);
  -webkit-backdrop-filter:blur(22px) saturate(180%);
  box-shadow:
    0 12px 40px -14px rgba(14,14,13,.14),
    inset 0 1px 0 rgba(255,255,255,.6),
    inset 0 -1px 0 rgba(14,14,13,.04);
}
.nav.is-stuck:not(.is-dark){ color:var(--ink); }
.nav.is-stuck:not(.is-dark) .nav-logo{filter:invert(1)}

/* microcopy collapses into the pill */
.nav.is-stuck .nav-microcopy{
  display:none;
}
.nav.is-stuck .nav-brand{padding:0;margin-right:0}
.nav.is-stuck .nav-right{gap:20px}
.nav.is-stuck .lang{margin-left:0}
.nav.is-stuck .nav-logo{height:22px}
.nav.is-stuck .nav-menu{color:inherit}
.nav.is-stuck .nav-menu a{color:inherit}
.nav.is-stuck .nav-menu a:hover{color:inherit}
.nav.is-stuck .nav-cta{
  padding:7px 14px;
  margin-right:0;
  color:inherit;
}

/* Responsive */
@media (max-width:1100px){
  .nav-menu{gap:20px;font-size:11px}
  .nav-microcopy{display:none}
}
@media (max-width:880px){
  .nav{padding:0 12px}
  .nav-inner{padding:10px 14px}
  .nav-menu{display:none}
  .nav-cta-wrap{display:none}
  .nav-brand{margin-right:0}
  .nav.is-stuck .nav-inner{padding:8px 12px}
}

/* ---------- HERO ---------- */
.hero{
  position:relative;
  min-height:100vh;
  background:#070707;
  color:var(--invert);
  overflow:hidden;
  display:flex;flex-direction:column;justify-content:center;
  padding:140px 32px 120px;
}
.hero-video{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;
  filter:grayscale(1) contrast(1.05);
  z-index:1;
}
.hero-overlay{
  position:absolute;inset:0;
  background:rgba(0,0,0,.62);
  z-index:2;
  pointer-events:none;
}
.hero::before{
  content:'';
  position:absolute;inset:auto 0 0 0;height:38%;
  background:linear-gradient(to bottom, transparent, #070707 88%);
  z-index:3;
  pointer-events:none;
}

.hero-content{
  position:relative;z-index:4;
  max-width:1280px;width:100%;
  margin:0 auto;
}

.hero-eyebrow{
  font-family:var(--mono);
  font-size:11px;letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--accent);
  margin:0 0 32px;
  display:inline-flex;align-items:center;gap:14px;
}
.hero-eyebrow::before{
  content:'';width:36px;height:1px;background:var(--accent);
  display:inline-block;
}

.hero-title{
  font-family:var(--sans);
  font-weight:600;
  font-size:clamp(46px, 8.4vw, 128px);
  line-height:1.02;
  letter-spacing:-0.04em;
  margin:0 0 36px;
  color:var(--invert);
}
.hero-title .line{
  display:block;
  padding:0.02em 0.06em 0.12em;
  margin:-0.02em -0.06em -0.12em;
}
.hero-title .word{
  display:inline-block;
  opacity:0;
  transform:translateY(28px);
  will-change:transform, opacity;
}
.hero-title .word.italic{
  font-family: 'Geist', serif;
  font-style:italic;
  font-weight:300;
  background:linear-gradient(120deg, var(--accent) 0%, #fff 60%, var(--accent) 100%);
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;
  background-size:200% 100%;
  animation:shimmer 6s linear infinite;
  padding-right:.22em;
  margin-right:-.12em;
}
@keyframes shimmer{
  0%{background-position:0% 50%}
  100%{background-position:200% 50%}
}

.hero-sub{
  max-width:640px;
  font-size:clamp(15px, 1.3vw, 19px);
  line-height:1.55;
  color:rgba(255,255,255,.7);
  margin:0 0 44px;
  font-weight:300;
}
.split-up{overflow:hidden;display:inline-block}

.hero-actions{display:flex;gap:16px;flex-wrap:wrap;align-items:center}

.btn-primary{
  display:inline-flex;align-items:center;gap:12px;
  padding:16px 26px;
  background:var(--accent);
  color:#0a0a0a;
  font-family:var(--mono);
  font-size:12px;letter-spacing:.14em;text-transform:uppercase;font-weight:500;
  border-radius:var(--r-pill);
  transition:transform .35s var(--ease), background .35s var(--ease), box-shadow .35s var(--ease);
  box-shadow:0 0 0 0 var(--accent-glow);
  position:relative;overflow:hidden;
}
.btn-primary::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(120px at var(--mx,50%) var(--my,50%), rgba(255,255,255,.4), transparent 60%);
  opacity:0;transition:opacity .35s var(--ease);
}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 18px 40px -12px var(--accent-glow)}
.btn-primary:hover::before{opacity:1}
.btn-primary svg{transition:transform .35s var(--ease)}
.btn-primary:hover svg{transform:translateX(4px)}
.btn-primary span{position:relative;z-index:1}
.btn-primary.big{padding:20px 32px;font-size:13px}

.btn-ghost{
  display:inline-flex;align-items:center;gap:10px;
  padding:16px 24px;
  font-family:var(--mono);
  font-size:12px;letter-spacing:.14em;text-transform:uppercase;
  color:rgba(255,255,255,.85);
  border:1px solid rgba(255,255,255,.18);
  border-radius:var(--r-pill);
  transition:border-color .3s, color .3s, background .3s;
}
.btn-ghost:hover{color:var(--invert);border-color:rgba(255,255,255,.5);background:rgba(255,255,255,.04)}

.hero-scroll{
  position:absolute;
  left:50%;bottom:36px;
  transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:10px;
  z-index:5;
  font-family:var(--mono);
  font-size:10px;letter-spacing:.28em;text-transform:uppercase;
  color:rgba(255,255,255,.6);
}
.hero-scroll-line{
  width:1px;height:46px;
  background:rgba(255,255,255,.18);
  position:relative;overflow:hidden;
}
.hero-scroll-line i{
  position:absolute;left:0;top:0;
  width:100%;height:50%;
  background:var(--accent);
  animation:scrollDot 1.6s var(--ease) infinite;
}
@keyframes scrollDot{
  0%{transform:translateY(-100%)}
  100%{transform:translateY(200%)}
}

.hero-meta{
  position:absolute;bottom:36px;
  z-index:5;
  display:flex;align-items:center;gap:10px;
  font-family:var(--mono);
  font-size:10px;letter-spacing:.18em;text-transform:uppercase;
  color:rgba(255,255,255,.55);
}
.hero-meta-l{left:32px}
.hero-meta-r{right:32px}
.hero-meta .dot{
  width:6px;height:6px;border-radius:50%;background:var(--accent);
  box-shadow:0 0 14px var(--accent);
  animation:pulse 2.4s ease-in-out infinite;
}
@keyframes pulse{
  0%,100%{opacity:.4;transform:scale(1)}
  50%{opacity:1;transform:scale(1.3)}
}
@media (max-width:740px){
  .hero-meta{display:none}
  .hero-scroll{display:none}
}

/* ---------- MARQUEE ---------- */
.marquee{
  background:#070707;
  color:rgba(255,255,255,.55);
  border-top:1px solid rgba(255,255,255,.05);
  border-bottom:1px solid rgba(255,255,255,.05);
  padding:22px 0;
  overflow:hidden;
  position:relative;
}
.marquee::before, .marquee::after{
  content:'';position:absolute;top:0;bottom:0;width:120px;z-index:2;pointer-events:none;
}
.marquee::before{left:0;background:linear-gradient(to right, #070707, transparent)}
.marquee::after{right:0;background:linear-gradient(to left, #070707, transparent)}

.marquee-track{
  display:flex;gap:36px;
  font-family:var(--sans);
  font-weight:500;
  font-size:18px;
  letter-spacing:-.01em;
  white-space:nowrap;
  animation:marquee 38s linear infinite;
  width:max-content;
}
.marquee-track span{display:inline-block}
.marquee-track span:nth-child(odd){color:rgba(255,255,255,.85)}
.marquee-track span:nth-child(even){color:var(--accent)}
@keyframes marquee{
  to{transform:translateX(-50%)}
}

/* ---------- STATEMENT ---------- */
.statement{
  background:var(--bg);
  padding:160px 0 140px;
  position:relative;
}
.statement-eyebrow{
  font-family:var(--mono);
  font-size:11px;letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--accent-3);
  margin:0 0 28px;
}
.statement-text{
  font-family:var(--sans);
  font-weight:600;
  font-size:clamp(34px, 5.4vw, 80px);
  line-height:1.14;
  letter-spacing:-.03em;
  margin:0;
  color:var(--ink);
}
.reveal-word{
  display:inline-block;
  margin-right:.22em;
  padding:.12em .14em .22em;
  margin-top:-.12em;
  margin-bottom:-.22em;
  opacity:0;
  transform:translateY(18px);
  transition:opacity .7s var(--ease), transform .7s var(--ease);
  will-change:transform, opacity;
  backface-visibility:hidden;
  -webkit-backface-visibility:hidden;
}
.reveal-word.is-in{opacity:1;transform:translateY(0)}
.reveal-word.accent,
.reveal-word.italic{
  font-style:italic;
  padding-right:.28em;
  margin-right:-.04em;
}
.reveal-word.accent{
  color:var(--accent-3);
  font-weight:500;
}

/* ---------- SECTION TYPOGRAPHY ---------- */
.eyebrow{
  font-family:var(--mono);
  font-size:11px;letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--accent-3);
  margin:0 0 22px;
  display:inline-flex;align-items:center;gap:14px;
}
.eyebrow::before{
  content:'';width:36px;height:1px;background:currentColor;
}
.eyebrow.center{justify-content:center}

.section-title{
  font-family:var(--sans);
  font-weight:600;
  font-size:clamp(34px, 5vw, 64px);
  line-height:1.04;
  letter-spacing:-.03em;
  margin:0 0 18px;
  color:inherit;
}
.section-sub{
  font-size:18px;
  line-height:1.6;
  color:var(--ink-2);
  max-width:640px;
  margin:0;
}
.reveal{
  opacity:0;
  transform:translateY(28px);
  transition:opacity .9s var(--ease), transform .9s var(--ease);
}
.reveal.is-in{opacity:1;transform:translateY(0)}

/* ---------- METHOD / PHASES ---------- */
.method{
  background:#eae8e0;
  padding:140px 32px 100px;
  position:relative;
}
.method::before{
  content:'';
  position:absolute;inset:0;
  background:
    radial-gradient(600px at 15% 10%, rgba(214,209,196,.05), transparent 60%),
    radial-gradient(700px at 85% 90%, rgba(74,72,67,.04), transparent 60%);
  pointer-events:none;
}
.method > *{position:relative;z-index:1}
.method-header{
  max-width:1280px;margin:0 auto 90px;
}
.method-header .section-sub{margin-top:18px}

.phases{
  max-width:1280px;margin:0 auto;
  display:flex;flex-direction:column;gap:28px;
}

.phase{
  position:relative;
  background:var(--invert);
  border:1px solid rgba(14,14,13,.06);
  border-radius:var(--r-card);
  padding:52px 56px 48px;
  display:block;
  overflow:hidden;
  box-shadow:
    0 1px 2px rgba(14,14,13,.05),
    0 20px 40px -20px rgba(14,14,13,.18),
    0 40px 80px -40px rgba(14,14,13,.12);
  transition:transform .6s var(--ease), box-shadow .6s var(--ease), border-color .6s var(--ease);
}
.phase-body{min-width:0}
.phase::before{
  content:'';
  position:absolute;
  inset:0;
  background:radial-gradient(420px at var(--mx,30%) var(--my,30%), rgba(214,209,196,.14), transparent 70%);
  opacity:0;
  transition:opacity .6s var(--ease);
  pointer-events:none;
}
.phase:hover{
  transform:translateY(-3px);
  box-shadow:
    0 1px 2px rgba(14,14,13,.05),
    0 30px 60px -30px rgba(14,14,13,.18);
  border-color:rgba(214,209,196,.30);
}
.phase:hover::before{opacity:1}

.phase-num{
  position:absolute;
  top:32px;
  right:40px;
  font-family:var(--sans);
  font-weight:600;
  font-size:84px;
  line-height:1;
  letter-spacing:-.06em;
  color:transparent;
  -webkit-text-stroke:1.4px rgba(14,14,13,.18);
  pointer-events:none;
  user-select:none;
  z-index:1;
}
.phase-num span{display:block}
.phase-body{position:relative;z-index:2}

.phase-tag{
  font-family:var(--mono);
  font-size:11px;letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--accent-3);
  margin:0 0 14px;
}
.phase-body h3{
  font-family:var(--sans);
  font-weight:600;
  font-size:clamp(28px, 3vw, 42px);
  line-height:1.05;
  letter-spacing:-.025em;
  margin:0 0 18px;
}
.phase-lead{
  font-size:17px;line-height:1.6;color:var(--ink-2);
  margin:0 0 24px;max-width:720px;
}

.phase-list{
  list-style:none;padding:0;margin:0;
  display:grid;gap:10px;
}
.phase-list li{
  position:relative;padding-left:24px;
  color:var(--ink-2);font-size:15px;line-height:1.55;
}
.phase-list li::before{
  content:'';
  position:absolute;left:0;top:.65em;
  width:10px;height:1px;background:var(--accent-3);
}

.routes{
  display:grid;grid-template-columns:repeat(2, minmax(0, 1fr));gap:18px;
  margin-top:8px;
}
.route{min-width:0}
.route{
  background:rgba(14,14,13,.035);
  border-radius:12px;
  padding:22px 22px;
  border:1px solid rgba(14,14,13,.05);
  transition:border-color .35s var(--ease), background .35s var(--ease), transform .35s var(--ease), box-shadow .35s var(--ease);
}
.route:hover{
  border-color:rgba(214,209,196,.35);
  background:var(--invert);
  transform:translateY(-2px);
  box-shadow:0 14px 28px -16px rgba(14,14,13,.12);
}
.route-tag{
  font-family:var(--mono);
  font-size:10px;letter-spacing:.2em;
  color:var(--accent-3);text-transform:uppercase;
}
.route h4{
  font-family:var(--sans);
  font-weight:600;
  font-size:20px;
  letter-spacing:-.01em;
  margin:8px 0 6px;
}
.route p{font-size:13px;color:var(--ink-2);margin:0;line-height:1.5}

.timeline{
  display:grid;grid-template-columns:repeat(4, minmax(0, 1fr));gap:14px;margin-top:8px;
  counter-reset:t;
}
.t-step{min-width:0}
.t-step{
  position:relative;
  padding:22px 22px 26px;
  border-radius:12px;
  background:rgba(14,14,13,.035);
  border:1px solid rgba(14,14,13,.05);
  transition:border-color .35s var(--ease), background .35s var(--ease), transform .35s var(--ease), box-shadow .35s var(--ease);
}
.t-step:hover{
  border-color:rgba(214,209,196,.35);
  background:var(--invert);
  transform:translateY(-2px);
  box-shadow:0 14px 28px -16px rgba(14,14,13,.12);
}
.t-step.accent{
  background:linear-gradient(135deg, var(--accent-3), #1c1b19);
  color:var(--invert);
}
.t-step.accent h5,.t-step.accent .t-week{color:var(--invert)}
.t-step.accent p{color:rgba(255,255,255,.78)}

.t-week{
  display:inline-block;
  font-family:var(--mono);font-size:10px;letter-spacing:.18em;
  color:var(--accent-3);text-transform:uppercase;margin-bottom:10px;
}
.t-step h5{
  font-family:var(--sans);font-weight:600;font-size:18px;
  margin:0 0 8px;letter-spacing:-.01em;
}
.t-step p{font-size:13px;color:var(--ink-2);margin:0;line-height:1.5}

@media (max-width:1080px){
  .phase{padding:44px 40px 40px}
  .phase-num{font-size:64px;top:24px;right:28px}
  .routes{grid-template-columns:repeat(2, minmax(0, 1fr))}
  .timeline{grid-template-columns:repeat(2, minmax(0, 1fr))}
}
@media (max-width:720px){
  .phase{padding:36px 26px 32px}
  .phase-num{font-size:52px;top:18px;right:20px}
  .routes{grid-template-columns:1fr}
  .timeline{grid-template-columns:1fr}
}
@media (max-width:420px){
  .phase-num{font-size:44px;top:14px;right:16px}
}

/* ---------- SERVICES (v3 — pills + 2-col card) ---------- */
.services{
  background:#0a0a0a;
  color:var(--invert);
  padding:140px 32px 140px;
  position:relative;
  overflow:hidden;
}
.services::before{
  content:'';position:absolute;inset:0;
  background:
    radial-gradient(800px at 80% 10%, rgba(144,139,130,.14), transparent 60%),
    radial-gradient(700px at 10% 90%, rgba(74,72,67,.10), transparent 60%);
  pointer-events:none;
}
.services-header{
  max-width:880px;margin:0 auto 56px;
  text-align:center;
  position:relative;z-index:2;
}
.services-header .eyebrow{color:var(--accent);justify-content:center;display:inline-flex}
.services-header .section-title{color:var(--invert)}
.services-header .section-sub{color:rgba(255,255,255,.65);margin:14px auto 0}

/* Pills */
.svc-pills{
  position:relative;z-index:3;
  max-width:1280px;margin:0 auto 36px;
  display:flex;justify-content:center;gap:8px;
  flex-wrap:wrap;
  padding:0 8px;
}
.svc-pill{
  display:inline-flex;align-items:center;gap:8px;
  padding:11px 18px 11px 14px;
  border-radius:var(--r-pill);
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  color:rgba(255,255,255,.72);
  font-family:var(--sans);font-weight:500;font-size:13.5px;
  letter-spacing:-.005em;
  cursor:pointer;
  transition:background .3s var(--ease), color .3s var(--ease), border-color .3s var(--ease), transform .3s var(--ease);
  -webkit-tap-highlight-color:transparent;
  white-space:nowrap;
}
.svc-pill:hover{background:rgba(255,255,255,.07);color:#fff;border-color:rgba(255,255,255,.18)}
@media (hover:hover){ .svc-pill:hover{transform:translateY(-1px)} }
.svc-pill.active{
  background:var(--accent);
  color:#0a0a0a;
  border-color:var(--accent);
  box-shadow:0 14px 34px -14px var(--accent-glow), 0 0 0 4px rgba(214,209,196,.14);
}
.svc-pill.active .svc-pill-num{
  background:rgba(10,10,10,.18);color:#0a0a0a;border-color:transparent;
}
.svc-pill-num{
  font-family:var(--mono);font-size:10.5px;font-weight:500;letter-spacing:.06em;
  display:inline-flex;align-items:center;justify-content:center;
  min-width:28px;height:22px;padding:0 6px;
  border-radius:var(--r-pill);
  border:1px solid rgba(255,255,255,.18);
  color:inherit;
  transition:background .3s var(--ease);
}
.svc-pill-flag{
  font-family:var(--mono);font-size:8.5px;letter-spacing:.16em;
  padding:2px 6px;background:#0a0a0a;color:var(--accent);
  border-radius:var(--r-pill);
}
.svc-pill.active .svc-pill-flag{background:rgba(10,10,10,.85);color:var(--accent)}
.svc-pill.flagship:not(.active){
  background:linear-gradient(135deg, rgba(214,209,196,.14), rgba(255,255,255,.03));
  border-color:rgba(214,209,196,.28);
  color:#fff;
}

/* Big card */
.svc-card-wrap{
  position:relative;z-index:2;
  max-width:1280px;margin:0 auto;
  min-height:560px;
}
.svc-card{
  position:absolute;inset:0;
  display:grid;grid-template-columns:1.05fr 1fr;
  gap:40px;
  padding:48px 52px;
  border-radius:24px;
  background:linear-gradient(160deg, rgba(255,255,255,.045) 0%, rgba(255,255,255,.015) 100%);
  border:1px solid rgba(255,255,255,.08);
  backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
  opacity:0;
  pointer-events:none;
  transform:translateY(14px) scale(.995);
  transition:opacity .5s var(--ease), transform .55s var(--ease);
}
.svc-card.active{
  opacity:1;
  pointer-events:auto;
  transform:translateY(0) scale(1);
}

.svc-card-text{display:flex;flex-direction:column;gap:14px;min-width:0}
.svc-card-icon{
  display:inline-flex;align-items:center;justify-content:center;
  width:48px;height:48px;border-radius:14px;
  background:rgba(214,209,196,.14);
  color:var(--accent);
  margin-bottom:6px;
}
.svc-card-num{
  font-family:var(--mono);font-size:11px;letter-spacing:.22em;
  color:var(--accent);text-transform:uppercase;
  margin:0;
}
.svc-card-num .hi{
  background:var(--accent);color:#0a0a0a;
  padding:2px 8px;border-radius:var(--r-pill);
  font-size:9px;letter-spacing:.18em;margin-left:4px;
}
.svc-card-title{
  font-family:var(--sans);font-weight:600;
  font-size:clamp(28px, 2.8vw, 38px);
  line-height:1.06;letter-spacing:-.022em;
  margin:0;color:var(--invert);
  max-width:520px;
}
.svc-card-lead{
  font-size:15.5px;line-height:1.6;
  color:rgba(255,255,255,.74);margin:0;
  max-width:540px;
}
.svc-card-bullets{
  list-style:none;padding:0;margin:8px 0 4px;
  display:grid;grid-template-columns:1fr 1fr;
  gap:10px 22px;
}
.svc-card-bullets li{
  position:relative;padding-left:22px;
  font-size:13.5px;line-height:1.5;
  color:rgba(255,255,255,.82);
}
.svc-card-bullets li::before{
  content:'';
  position:absolute;left:0;top:.45em;
  width:14px;height:14px;border-radius:50%;
  background:rgba(214,209,196,.18);
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23C9C2B0' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><polyline points='20 6 9 17 4 12'/></svg>");
  background-size:9px 9px;background-position:center;background-repeat:no-repeat;
}
.svc-card-cta{
  align-self:flex-start;
  margin-top:10px;
  display:inline-flex;align-items:center;gap:6px;
  padding:13px 22px;
  background:#fff;color:#0a0a0a;
  font-family:var(--mono);font-size:11.5px;letter-spacing:.12em;text-transform:uppercase;font-weight:500;
  border-radius:var(--r-pill);
  transition:background .3s var(--ease), color .3s var(--ease), transform .3s var(--ease), box-shadow .3s var(--ease);
}
.svc-card-cta:hover{
  background:var(--accent);color:#0a0a0a;
  transform:translateY(-1px);
  box-shadow:0 14px 30px -12px var(--accent-glow);
}

/* Visual side */
.svc-card-visual{
  position:relative;
  display:flex;align-items:center;justify-content:center;
  min-height:380px;
  border-radius:18px;
  background:radial-gradient(closest-side, rgba(214,209,196,.14), transparent 75%);
  overflow:hidden;
}
.svc-card-visual::before{
  content:'';position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.025) 1px, transparent 1px);
  background-size:32px 32px;
  mask-image:radial-gradient(closest-side, #000 60%, transparent 100%);
  -webkit-mask-image:radial-gradient(closest-side, #000 60%, transparent 100%);
  pointer-events:none;
}
.mock{
  position:relative;z-index:2;
  width:min(420px, 92%);
  border-radius:16px;
  background:rgba(20,18,32,.85);
  border:1px solid rgba(255,255,255,.10);
  box-shadow:0 30px 70px -30px rgba(0,0,0,.7), 0 0 0 1px rgba(214,209,196,.06);
  padding:18px;
  font-size:13px;
  color:#fff;
  display:flex;flex-direction:column;gap:12px;
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
}

/* MOCK · CHAT (S1) */
.mock-chat-header{
  display:flex;align-items:center;gap:10px;
  padding-bottom:10px;border-bottom:1px solid rgba(255,255,255,.08);
}
.mock-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);box-shadow:0 0 10px var(--accent)}
.mock-chat-title{font-family:var(--mono);font-size:11px;letter-spacing:.06em;color:#fff;flex:1}
.mock-status{
  display:inline-flex;align-items:center;gap:6px;
  font-family:var(--mono);font-size:10px;color:rgba(255,255,255,.6);
}
.mock-chat-chips{
  display:flex;gap:6px;overflow-x:auto;overflow-y:hidden;
  padding:2px 2px 10px;margin:-2px -4px 4px;
  border-bottom:1px solid rgba(255,255,255,.06);
  scrollbar-width:none;
  scroll-behavior:smooth;
}
.mock-chat-chips::-webkit-scrollbar{display:none}
.mock-chip{
  flex:0 0 auto;
  font-family:var(--mono);font-size:9.5px;letter-spacing:.14em;text-transform:uppercase;
  padding:6px 11px;border-radius:var(--r-pill);
  background:rgba(255,255,255,.04);
  color:rgba(255,255,255,.55);
  border:1px solid rgba(255,255,255,.08);
  cursor:pointer;user-select:none;white-space:nowrap;
  transition:color .25s var(--ease), background .25s var(--ease), border-color .25s var(--ease), transform .2s var(--ease);
}
.mock-chip:hover{color:#fff;border-color:rgba(214,209,196,.32);background:rgba(214,209,196,.08)}
.mock-chip.active{
  background:linear-gradient(135deg, rgba(214,209,196,.28), rgba(214,209,196,.14));
  color:#fff;
  border-color:rgba(214,209,196,.5);
  box-shadow:0 0 0 1px rgba(214,209,196,.18), 0 4px 14px -6px rgba(214,209,196,.4);
}
.mock-status i{
  width:6px;height:6px;border-radius:50%;background:#3ee08e;
  box-shadow:0 0 8px #3ee08e;
  animation:livePulse 1.6s ease-in-out infinite;
  display:inline-block;
}
@keyframes livePulse{ 0%,100%{opacity:.5} 50%{opacity:1} }
.mock-chat-body{
  display:flex;flex-direction:column;gap:8px;padding:6px 2px;
  min-height:320px;max-height:380px;
  overflow-y:auto;overflow-x:hidden;
  scroll-behavior:smooth;
  scrollbar-width:thin;
  scrollbar-color:rgba(255,255,255,.15) transparent;
  mask-image:linear-gradient(to bottom, transparent 0, #000 12px, #000 calc(100% - 12px), transparent 100%);
  -webkit-mask-image:linear-gradient(to bottom, transparent 0, #000 12px, #000 calc(100% - 12px), transparent 100%);
}
.mock-chat-body::-webkit-scrollbar{width:4px}
.mock-chat-body::-webkit-scrollbar-track{background:transparent}
.mock-chat-body::-webkit-scrollbar-thumb{background:rgba(255,255,255,.15);border-radius:2px}
.msg{
  max-width:78%;
  padding:9px 12px;border-radius:12px;
  font-size:12.5px;line-height:1.4;
  opacity:0;transform:translateY(6px);
  animation:msgIn .35s var(--ease) forwards;
}
@keyframes msgIn{ to{ opacity:1; transform:none; } }
.msg.typing{
  display:inline-flex;gap:4px;align-items:center;
  padding:11px 12px;
}
.msg.typing span{
  width:5px;height:5px;border-radius:50%;
  background:rgba(255,255,255,.55);
  display:inline-block;
  animation:typingDot 1.2s ease-in-out infinite;
}
.msg.out.typing span{background:rgba(14,14,13,.55)}
.msg.typing span:nth-child(2){animation-delay:.15s}
.msg.typing span:nth-child(3){animation-delay:.3s}
@keyframes typingDot{ 0%,60%,100%{transform:translateY(0);opacity:.35} 30%{transform:translateY(-3px);opacity:1} }
.msg.in{
  align-self:flex-start;
  background:rgba(255,255,255,.06);
  color:rgba(255,255,255,.92);
  border-bottom-left-radius:4px;
}
.msg.out{
  align-self:flex-end;
  background:var(--accent);
  color:#0a0a0a;
  border-bottom-right-radius:4px;
}
.msg.done{
  background:linear-gradient(135deg, var(--accent-3), var(--accent-2));
  color:#fff;font-weight:500;
}
.mock-chat-foot{
  display:flex;justify-content:space-between;align-items:center;gap:8px;
  padding-top:10px;border-top:1px solid rgba(255,255,255,.08);
}
.mock-pill{
  font-family:var(--mono);font-size:10px;letter-spacing:.06em;
  padding:5px 10px;border-radius:var(--r-pill);
  background:rgba(255,255,255,.06);color:#fff;
}
.mock-pill-go{background:var(--accent);color:#0a0a0a}

/* MOCK · BRAND (S2) */
.mock-brand{align-items:center;text-align:center;padding:24px 22px}
.mock-brand-aa{
  font-family:var(--sans);font-weight:600;
  font-size:78px;line-height:1;letter-spacing:-.04em;
  color:#fff;
  background:linear-gradient(135deg, var(--accent), #fff);
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;
}
.mock-brand-swatches{display:flex;gap:8px;justify-content:center}
.mock-brand-swatches span{width:32px;height:32px;border-radius:50%;background:var(--c)}
.mock-brand-tags{
  display:flex;justify-content:center;gap:6px;
  font-family:var(--mono);font-size:11px;color:rgba(255,255,255,.55);
}
.mock-brand-foot{
  display:flex;align-items:center;gap:14px;
  padding-top:14px;border-top:1px solid rgba(255,255,255,.08);
  width:100%;
}
.mock-brand-symbol{
  width:36px;height:36px;border-radius:8px;
  background:linear-gradient(135deg, var(--accent), var(--accent-3));
  flex-shrink:0;
  position:relative;
}
.mock-brand-symbol::after{
  content:'';position:absolute;inset:8px;
  border-radius:50%;
  border:2px solid #fff;
}
.mock-brand-meta{display:flex;flex-direction:column;gap:2px;text-align:left;flex:1;min-width:0}
.mock-brand-meta small{font-family:var(--mono);font-size:10px;color:rgba(255,255,255,.5)}
.mock-brand-meta strong{font-size:13px;font-weight:500;color:#fff}

/* MOCK · BROWSER (S3) */
.mock-browser{padding:0;overflow:hidden}
.mock-browser-bar{
  display:flex;align-items:center;gap:6px;
  padding:10px 14px;background:rgba(255,255,255,.04);
  border-bottom:1px solid rgba(255,255,255,.06);
}
.mock-circle{width:9px;height:9px;border-radius:50%;background:rgba(255,255,255,.18)}
.mock-circle:nth-child(1){background:#ff5f57}
.mock-circle:nth-child(2){background:#febc2e}
.mock-circle:nth-child(3){background:#28c840}
.mock-url{
  margin-left:8px;flex:1;
  background:rgba(255,255,255,.06);
  border-radius:6px;
  padding:5px 10px;
  font-family:var(--mono);font-size:11px;color:rgba(255,255,255,.75);
  text-align:center;
}
.mock-browser-body{padding:24px 22px;display:flex;flex-direction:column;gap:14px;align-items:center}
.mock-score{position:relative;width:120px;height:120px;display:flex;align-items:center;justify-content:center}
.mock-score-ring{width:120px;height:120px;transform:rotate(0deg)}
.mock-score-num{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  font-family:var(--sans);font-size:32px;font-weight:600;letter-spacing:-.02em;color:#fff;
}
.mock-score-num small{font-size:12px;color:rgba(255,255,255,.5);font-weight:400}
.mock-score-meta{display:flex;flex-direction:column;align-items:center;gap:2px;text-align:center}
.mock-score-meta span{font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.5)}
.mock-score-meta strong{font-size:13px;color:#fff;font-weight:500}
.mock-bars{
  display:flex;align-items:flex-end;gap:6px;height:42px;width:100%;justify-content:center;
  padding-top:8px;border-top:1px solid rgba(255,255,255,.08);
}
.mock-bars i{
  width:16px;
  height:var(--h);
  background:linear-gradient(to top, var(--accent-3), var(--accent));
  border-radius:3px 3px 0 0;
  display:inline-block;
}

/* MOCK · PHONE (S4) */
.mock-phone{padding:18px;background:rgba(20,18,32,.6);align-items:center}
.mock-phone-frame{
  width:200px;height:340px;
  border-radius:28px;
  background:#000;
  border:8px solid #1a1a1a;
  box-shadow:0 20px 50px -20px rgba(0,0,0,.8);
  position:relative;overflow:hidden;
}
.mock-phone-frame::before{
  content:'';position:absolute;top:6px;left:50%;transform:translateX(-50%);
  width:50px;height:6px;border-radius:3px;background:#1a1a1a;z-index:3;
}
.mock-phone-screen{
  position:relative;width:100%;height:100%;
  display:flex;flex-direction:column;
  background:linear-gradient(135deg, #1f1e1c, #0e0e0d);
}
.mock-reel{
  flex:1;
  background:linear-gradient(135deg, rgba(214,209,196,.4), rgba(74,72,67,.15));
  background-image:
    radial-gradient(at 30% 20%, rgba(255,255,255,.15), transparent 40%),
    radial-gradient(at 70% 80%, rgba(255,200,150,.15), transparent 40%);
  position:relative;
}
.mock-reel-overlay{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
}
.mock-play{
  width:48px;height:48px;border-radius:50%;
  background:rgba(255,255,255,.18);
  backdrop-filter:blur(8px);
  display:flex;align-items:center;justify-content:center;
  color:#fff;
  border:1px solid rgba(255,255,255,.3);
}
.mock-reel-stats{
  display:flex;justify-content:space-around;
  padding:10px 8px;
  background:rgba(0,0,0,.55);
  backdrop-filter:blur(8px);
}
.mock-reel-stats div{display:flex;flex-direction:column;align-items:center;gap:1px}
.mock-reel-stats b{font-size:13px;color:#fff;font-weight:600}
.mock-reel-stats span{font-size:9px;font-family:var(--mono);color:rgba(255,255,255,.55);letter-spacing:.04em}

/* MOCK · FLOW (S5) */
.mock-flow{padding:26px 22px;align-items:center}
.mock-flow-node{
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.10);
  border-radius:12px;
  padding:14px 18px;
  width:100%;
  display:flex;align-items:center;gap:12px;
  position:relative;
}
.mock-flow-node strong{font-size:14px;color:#fff;font-weight:500}
.mock-flow-node small{font-family:var(--mono);font-size:10px;color:rgba(255,255,255,.5);margin-left:auto}
.mock-flow-dot{
  width:10px;height:10px;border-radius:50%;
  background:rgba(255,255,255,.3);
}
.mock-flow-node.accent{
  background:linear-gradient(135deg, rgba(214,209,196,.18), rgba(74,72,67,.06));
  border-color:rgba(214,209,196,.45);
}
.mock-flow-node.accent .mock-flow-dot{
  background:var(--accent);
  box-shadow:0 0 12px var(--accent);
  animation:livePulse 1.6s ease-in-out infinite;
}
.mock-flow-arrow{
  font-family:var(--mono);font-size:18px;color:rgba(255,255,255,.35);
  line-height:1;transform:rotate(90deg);
}
.mock-flow-pulse{display:flex;gap:6px;margin-top:4px}
.mock-flow-pulse span{
  width:6px;height:6px;border-radius:50%;background:var(--accent);
  animation:flowPulse 1.4s ease-in-out infinite;
}
.mock-flow-pulse span:nth-child(2){animation-delay:.2s}
.mock-flow-pulse span:nth-child(3){animation-delay:.4s}
@keyframes flowPulse{ 0%,100%{opacity:.3;transform:scale(1)} 50%{opacity:1;transform:scale(1.3)} }

/* MOCK · SMS (S6) */
.mock-sms-header{
  display:flex;justify-content:space-between;align-items:center;gap:10px;
  padding-bottom:10px;border-bottom:1px solid rgba(255,255,255,.08);
}
.mock-sms-trigger{
  font-family:var(--mono);font-size:10px;letter-spacing:.06em;
  padding:4px 10px;border-radius:var(--r-pill);
  background:rgba(214,209,196,.18);color:var(--accent);
}
.mock-sms-time{font-family:var(--mono);font-size:10px;color:rgba(255,255,255,.5)}
.mock-sms-body{display:flex;flex-direction:column;gap:8px}
.sms{
  max-width:80%;
  padding:9px 12px;border-radius:14px;
  font-size:12px;line-height:1.4;
}
.sms.in{
  align-self:flex-start;
  background:rgba(255,255,255,.07);color:#fff;
  border-bottom-left-radius:4px;
}
.sms.out{
  align-self:flex-end;
  background:#3478f6;color:#fff;
  border-bottom-right-radius:4px;
}
.mock-sms-foot{
  display:flex;justify-content:space-between;align-items:center;gap:8px;
  padding-top:10px;border-top:1px solid rgba(255,255,255,.08);
}
.mock-sms-pill{
  font-family:var(--mono);font-size:10px;letter-spacing:.06em;
  padding:5px 10px;border-radius:var(--r-pill);
  background:rgba(255,255,255,.06);color:rgba(255,255,255,.7);
}
.mock-sms-pill-go{background:var(--accent);color:#0a0a0a}

/* MOCK · DASH (S7) */
.mock-dash{padding:20px}
.mock-dash-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:10px}
.mock-tile{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  border-radius:10px;
  padding:12px 14px;
  display:flex;flex-direction:column;gap:2px;
}
.mock-tile small{font-family:var(--mono);font-size:9px;letter-spacing:.18em;color:rgba(255,255,255,.5)}
.mock-tile b{font-size:22px;font-weight:600;color:#fff;letter-spacing:-.01em;line-height:1.1}
.mock-tile i{font-style:normal;font-family:var(--mono);font-size:10px;letter-spacing:.04em}
.mock-tile i.up{color:#3ee08e}
.mock-tile i.down{color:#ff7a8a}
.mock-dash-chart{
  margin-top:6px;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.06);
  border-radius:10px;
  padding:10px;
}
.mock-dash-chart svg{width:100%;height:60px;display:block}
.mock-dash-foot{
  display:flex;justify-content:space-between;align-items:center;
  padding-top:8px;
  font-family:var(--mono);font-size:10px;
}
.mock-dash-foot span{color:rgba(255,255,255,.5)}
.mock-dash-foot strong{color:#3ee08e;font-weight:500}

/* Responsive — tablet/mobile services */
@media (max-width:1100px){
  .services{padding:110px 24px 110px}
  .svc-card-wrap{min-height:auto}
  .svc-card{
    position:relative;
    grid-template-columns:1fr;
    padding:32px 28px;
    gap:28px;
  }
  .svc-card:not(.active){display:none}
  .svc-card-visual{order:-1;min-height:280px;padding:24px}
  .mock{width:min(360px,100%)}
  .svc-card-bullets{grid-template-columns:1fr}
}
@media (max-width:760px){
  .svc-pills{
    overflow-x:auto;
    flex-wrap:nowrap;
    justify-content:flex-start;
    padding:4px 24px 12px;
    margin:0 -32px 28px;
    scroll-snap-type:x mandatory;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:none;
  }
  .svc-pills::-webkit-scrollbar{display:none}
  .svc-pill{scroll-snap-align:start;font-size:13px;padding:10px 14px 10px 12px}
  .svc-pill-num{min-width:26px;height:20px;font-size:10px}
  .svc-card{padding:26px 22px;gap:22px}
  .svc-card-title{font-size:24px}
  .svc-card-lead{font-size:14.5px}
  .svc-card-visual{min-height:240px;padding:18px}
  .mock{padding:14px;font-size:12px}
  .mock-phone-frame{width:170px;height:290px}
}
@media (max-width:480px){
  .services{padding:90px 18px 90px}
}

/* ---------- CASES ---------- */
.cases{
  background:var(--bg);
  padding:160px 32px 100px;
}
.cases-header{
  max-width:1280px;margin:0 auto 80px;
}

.case{
  max-width:1280px;margin:0 auto 60px;
  background:var(--invert);
  border:1px solid var(--rule);
  border-radius:24px;
  padding:56px;
  display:grid;grid-template-columns:0.85fr 1.15fr;gap:48px;
  position:relative;overflow:hidden;
  transition:transform .8s var(--ease), box-shadow .8s var(--ease);
}
.case::after{
  content:'';
  position:absolute;
  bottom:-40%;right:-15%;
  width:520px;height:520px;
  border-radius:50%;
  background:radial-gradient(closest-side, rgba(214,209,196,.18), transparent 70%);
  pointer-events:none;
  opacity:0;transition:opacity .8s var(--ease);
}
.case:hover::after{opacity:1}
.case:hover{box-shadow:0 40px 80px -40px rgba(14,14,13,.2)}

.case-meta{display:flex;flex-direction:column;gap:14px;position:relative;z-index:2}
.case-logo-wrap{
  display:inline-flex;align-items:center;justify-content:center;
  height:76px;
  align-self:flex-start;
  padding:16px 26px;
  min-width:160px;
  border-radius:18px;
  margin-bottom:10px;
  transition:transform .4s var(--ease), box-shadow .4s var(--ease);
}
.case-logo-wrap--dark{
  background:linear-gradient(145deg, #1b1b1d, #0a0a0a);
  border:1px solid rgba(255,255,255,.08);
  box-shadow:0 10px 24px -14px rgba(0,0,0,.45), inset 0 1px 0 rgba(255,255,255,.05);
}
.case-logo-wrap--light{
  background:#fff;
  border:1px solid rgba(14,14,13,.08);
  box-shadow:0 8px 22px -12px rgba(14,14,13,.18);
}
.case-logo-wrap:hover{transform:translateY(-2px)}
.case-logo-wrap--dark:hover{box-shadow:0 18px 36px -14px rgba(0,0,0,.55), inset 0 1px 0 rgba(255,255,255,.08)}
.case-logo-wrap--light:hover{box-shadow:0 18px 36px -14px rgba(14,14,13,.25)}
.case-logo{
  height:44px;width:auto;
  max-width:210px;
  object-fit:contain;
  display:block;
}
.case-num{
  font-family:var(--mono);font-size:11px;letter-spacing:.22em;
  color:var(--accent-3);text-transform:uppercase;margin:0;
}
.case-name{
  font-family:var(--sans);font-weight:600;
  font-size:clamp(28px, 3vw, 42px);
  letter-spacing:-.025em;line-height:1.05;
  margin:0;
}
.case-tag{
  font-family:var(--mono);font-size:12px;letter-spacing:.04em;
  color:var(--ink-3);margin:0;
}
.case-service{font-size:14px;color:var(--ink-2);margin:0;font-weight:500}
.case-challenge{font-size:14px;color:var(--ink-2);line-height:1.55;margin:6px 0 0;border-left:2px solid var(--accent);padding-left:14px}

.case-ig{
  display:inline-flex;align-items:center;gap:8px;
  margin-top:12px;
  padding:10px 16px;
  background:var(--ink);color:var(--invert);
  border-radius:var(--r-pill);
  font-family:var(--mono);font-size:12px;letter-spacing:.06em;
  align-self:flex-start;
  transition:transform .35s var(--ease), background .35s var(--ease);
}
.case-ig:hover{transform:translateY(-2px) translateX(2px);background:var(--accent-3)}

.case-metrics{
  display:grid;grid-template-columns:1fr 1fr;gap:14px;
  position:relative;z-index:2;
}
.metric{
  background:var(--bg-2);border-radius:14px;padding:22px 22px;
  display:flex;flex-direction:column;gap:6px;
  transition:transform .35s var(--ease), background .35s var(--ease);
}
.metric:hover{background:var(--bg);transform:translateY(-2px)}
.metric.featured{
  background:linear-gradient(135deg, var(--accent-3), #1c1b19);color:var(--invert);
  grid-column:span 2;
}
.metric.featured .m-label{color:rgba(255,255,255,.7)}
.metric.featured .m-val{color:#fff}
.m-label{
  font-family:var(--mono);font-size:10px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--ink-3);
}
.m-val{
  font-family:var(--sans);font-weight:600;
  font-size:clamp(24px, 2.6vw, 36px);
  letter-spacing:-.02em;color:var(--ink);
  line-height:1;
}
.m-sub{font-size:11px;color:var(--ink-3);font-family:var(--mono);letter-spacing:.04em}
.metric.featured .m-sub{color:rgba(255,255,255,.65)}

.case-foot{
  grid-column:1 / -1;
  font-size:14px;line-height:1.6;
  color:var(--ink-2);
  margin:18px 0 0;
  padding-top:18px;
  border-top:1px solid var(--rule);
  position:relative;z-index:2;
}
.case-foot.accent{color:var(--accent-3);font-weight:500}

.case-metrics-king{grid-template-columns:repeat(3,1fr)}
.case-metrics-king .metric.featured{grid-column:auto}
.metric.viral{
  position:relative;text-decoration:none;color:inherit;cursor:pointer;
}
.metric.viral::after{
  content:'↗';position:absolute;top:14px;right:18px;
  font-size:16px;color:var(--ink-3);
  transition:transform .35s var(--ease), color .35s var(--ease);
}
.metric.viral:hover::after{transform:translate(2px,-2px);color:var(--accent-3)}
.metric.viral.featured::after{color:rgba(255,255,255,.6)}
.metric.viral.featured:hover::after{color:#fff}

@media (max-width:980px){
  .case{grid-template-columns:1fr;padding:36px;gap:30px}
  .case-metrics-king{grid-template-columns:1fr}
}
@media (max-width:520px){
  .case-metrics{grid-template-columns:1fr}
  .case-metrics .metric.featured{grid-column:auto}
}

/* ---------- IMPACT ---------- */
.impact{
  background:#070707;color:var(--invert);
  position:relative;overflow:hidden;
  padding:160px 32px;
  text-align:center;
}
.impact-bg{
  position:absolute;inset:0;
  background:
    radial-gradient(700px at 30% 20%, rgba(144,139,130,.18), transparent 60%),
    radial-gradient(900px at 75% 80%, rgba(74,72,67,.14), transparent 60%);
  pointer-events:none;
}
.impact .container{position:relative;z-index:2;max-width:1080px}
.impact-title{
  font-family:var(--sans);font-weight:600;
  font-size:clamp(38px, 6vw, 88px);
  line-height:1.12;letter-spacing:-.035em;
  margin:0 0 32px;
  color:var(--invert);
}
.impact-title .reveal-word.accent{color:var(--accent)}
.impact-sub{
  font-size:18px;line-height:1.6;
  color:rgba(255,255,255,.65);max-width:680px;margin:0 auto 36px;
}
.impact-claim{
  font-family:var(--sans);font-weight:400;
  font-size:clamp(18px, 1.8vw, 24px);
  color:rgba(255,255,255,.55);
  margin:0;
}
.impact-claim .hi{
  color:var(--accent);font-style:italic;font-weight:500;
  background:linear-gradient(120deg, var(--accent), #fff, var(--accent));
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;
  background-size:200% 100%;
  animation:shimmer 6s linear infinite;
}

/* ---------- CTA ---------- */
.cta{
  background:var(--bg);
  padding:160px 32px 120px;
  position:relative;overflow:hidden;
}
.cta-orb{
  position:absolute;
  top:-200px;right:-200px;
  width:600px;height:600px;
  border-radius:50%;
  background:radial-gradient(closest-side, var(--accent-glow), transparent 70%);
  filter:blur(20px);
  pointer-events:none;
  animation:orbFloat 18s ease-in-out infinite;
}
@keyframes orbFloat{
  0%,100%{transform:translate(0,0)}
  50%{transform:translate(-80px,80px)}
}
.cta .container{max-width:1100px;text-align:center;position:relative;z-index:2}
.cta .eyebrow{justify-content:center;display:inline-flex}
.cta-title{
  font-family:var(--sans);font-weight:600;
  font-size:clamp(40px, 6.5vw, 92px);
  line-height:1.14;letter-spacing:-.035em;
  margin:18px 0 24px;
  color:var(--ink);
}
.cta-title .reveal-word.italic{
  font-family:'Geist',serif;font-style:italic;font-weight:300;
  color:var(--accent-3);
}
.cta-sub{
  font-size:18px;line-height:1.6;color:var(--ink-2);
  max-width:720px;margin:0 auto 56px;
}

.cta-steps{
  display:grid;grid-template-columns:repeat(3, 1fr);
  gap:20px;margin:0 0 56px;text-align:left;
}
.cta-step{
  background:var(--invert);
  border:1px solid var(--rule);
  border-radius:18px;
  padding:32px 28px;
  position:relative;overflow:hidden;
  transition:transform .5s var(--ease), border-color .5s var(--ease);
}
.cta-step:hover{transform:translateY(-4px);border-color:var(--accent)}
.cta-step-num{
  font-family:var(--mono);font-size:11px;letter-spacing:.22em;
  color:var(--accent-3);
}
.cta-step h4{
  font-family:var(--sans);font-weight:600;font-size:22px;
  letter-spacing:-.015em;margin:8px 0 8px;
}
.cta-step p{font-size:14px;color:var(--ink-2);margin:0;line-height:1.55}

.cta-actions{
  display:flex;flex-direction:column;align-items:center;gap:16px;
}
.cta-note{
  font-family:var(--mono);font-size:12px;letter-spacing:.06em;
  color:var(--ink-3);margin:0;font-style:italic;
}
@media (max-width:780px){
  .cta-steps{grid-template-columns:1fr}
}

/* ---------- COMMUNICATION CHANNEL ---------- */
.contact{
  background:#0a0a0a;color:var(--invert);
  padding:140px 32px 130px;
  position:relative;overflow:hidden;
}
.contact::before{
  content:'';position:absolute;
  top:-180px;left:-180px;
  width:560px;height:560px;border-radius:50%;
  background:radial-gradient(closest-side, rgba(144,139,130,.18), transparent 70%);
  filter:blur(40px);
  pointer-events:none;
}
.contact::after{
  content:'';position:absolute;
  bottom:-200px;right:-180px;
  width:520px;height:520px;border-radius:50%;
  background:radial-gradient(closest-side, rgba(74,72,67,.14), transparent 70%);
  filter:blur(40px);
  pointer-events:none;
}
.contact-grid{
  max-width:1200px;margin:0 auto;
  display:grid;grid-template-columns:1fr 1.05fr;
  gap:80px;
  position:relative;z-index:2;
  align-items:center;
}
.contact-left{display:flex;flex-direction:column;gap:18px}
.contact-left .eyebrow{color:var(--accent)}
.contact-title{
  font-family:var(--sans);font-weight:600;
  font-size:clamp(32px, 4vw, 56px);
  line-height:1.04;letter-spacing:-.025em;
  margin:0;color:var(--invert);
}
.contact-sub{
  font-size:16.5px;line-height:1.6;
  color:rgba(255,255,255,.65);margin:0;
  max-width:440px;
}
.contact-right{display:flex;flex-direction:column;gap:14px}
.contact-h3{
  font-family:var(--mono);font-size:11px;letter-spacing:.22em;
  text-transform:uppercase;color:rgba(255,255,255,.5);
  margin:0 0 6px;
}
.channels{
  list-style:none;margin:0;padding:0;
  display:grid;gap:10px;
}
.channel{margin:0}
.channel-link{
  display:grid;
  grid-template-columns:auto 1fr auto auto;
  align-items:center;
  gap:18px;
  padding:18px 22px;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.07);
  border-radius:14px;
  color:#fff;
  text-decoration:none;
  transition:background .35s var(--ease), border-color .35s var(--ease), transform .35s var(--ease);
  -webkit-tap-highlight-color:transparent;
}
.channel-link:hover{
  background:rgba(214,209,196,.08);
  border-color:rgba(214,209,196,.35);
  transform:translateY(-2px);
}
.channel-icon{
  display:inline-flex;align-items:center;justify-content:center;
  width:42px;height:42px;border-radius:12px;
  background:rgba(214,209,196,.12);
  color:var(--accent);
  flex-shrink:0;
}
.channel-meta{display:flex;flex-direction:column;gap:3px;min-width:0}
.channel-label{
  font-family:var(--mono);font-size:10px;letter-spacing:.18em;
  color:rgba(255,255,255,.5);text-transform:uppercase;
}
.channel-value{
  font-family:var(--sans);font-weight:500;font-size:15.5px;
  letter-spacing:-.005em;
  color:#fff;
  word-break:break-all;
}
.channel-flag{font-size:18px;flex-shrink:0}
.channel-arrow{
  font-family:var(--mono);
  color:rgba(255,255,255,.4);
  transition:color .3s var(--ease), transform .3s var(--ease);
  flex-shrink:0;
}
.channel-link:hover .channel-arrow{color:var(--accent);transform:translate(2px,-2px)}

@media (max-width:900px){
  .contact{padding:90px 24px 90px}
  .contact-grid{grid-template-columns:1fr;gap:36px}
  .contact-sub{max-width:none}
  .channel-link{padding:16px 18px;gap:14px;grid-template-columns:auto 1fr auto}
  .channel-flag{display:none}
  .channel-icon{width:38px;height:38px;border-radius:10px}
  .channel-icon svg{width:18px;height:18px}
  .channel-value{font-size:14.5px}
}

/* ---------- FOOTER ---------- */
.foot{
  background:#070707;color:var(--invert);
  padding:80px 32px 56px;
}
.foot-grid{
  display:grid;
  grid-template-columns:1fr 1fr 1.6fr;
  gap:48px;
  align-items:start;
  max-width:1280px;
  margin:0 auto;
}
@media (max-width:991.98px){ .foot-grid{grid-template-columns:1fr 1fr; gap:40px 32px} }
@media (max-width:575.98px){ .foot-grid{grid-template-columns:1fr; gap:32px} }
.foot-heading{
  font-family:var(--mono);font-size:11px;font-weight:500;
  letter-spacing:.14em;text-transform:uppercase;
  color:rgba(255,255,255,.55);margin:0 0 18px;
}
.foot-links{
  list-style:none;padding:0;margin:0;
  display:flex;flex-direction:column;gap:10px;
}
.foot-links a{
  font-family:var(--mono);font-size:11px;font-weight:400;
  letter-spacing:.14em;text-transform:uppercase;
  color:rgba(255,255,255,.78);text-decoration:none;
  transition:color .2s var(--ease);
}
.foot-links a:hover{color:var(--invert)}
.foot-links a.foot-cta{color:var(--invert)}
.foot-links a.foot-cta:hover{color:rgba(255,255,255,.78)}
.foot-inner{
  display:flex;flex-direction:column;align-items:center;gap:16px;text-align:center;
  margin-top:64px;
  padding-top:40px;
  border-top:1px solid rgba(255,255,255,.12);
}
.foot-logo{height:24px;width:auto}
.foot-tag{
  font-family:var(--sans);font-size:14px;
  color:rgba(255,255,255,.7);margin:0;
}
.foot-copy{
  font-family:var(--mono);font-size:11px;letter-spacing:.12em;
  color:rgba(255,255,255,.4);margin:0;
}

/* ---------- ANIMATIONS / UTIL ---------- */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;transition-duration:.001ms!important}
}

/* ---------- CONTACT (formato uniforme con el sitio principal) ---------- */
.contact-logo{height:34px;width:auto}
.contact-title-simple{
  font-family:var(--sans);font-weight:600;
  font-size:clamp(22px,2.4vw,30px);
  letter-spacing:-.02em;
  margin:0 0 14px;color:var(--invert);
}
.channels-simple{display:flex;flex-direction:column;gap:14px}
.channels-simple .channel{border:0;padding:0;background:none}
.channels-simple .channel span{
  font-family:var(--sans);font-size:15.5px;color:rgba(255,255,255,.82);
}
.channels-simple .channel-link{
  font-family:var(--mono);font-size:14px;color:var(--invert);
  border-bottom:1px solid rgba(255,255,255,.35);
  padding-bottom:1px;
  transition:border-color .2s var(--ease);
}
.channels-simple .channel-link:hover{border-color:var(--invert)}
@media (max-width:767.98px){
  .contact-grid{grid-template-columns:1fr;gap:40px}
}


/* Reset duro del channel-link viejo (tarjeta grid) dentro del formato simple */
.contact-left{align-items:flex-start}
.contact-logo{align-self:flex-start}
.channels-simple .channel-link{
  display:inline;
  padding:0 0 1px;
  margin:0;
  background:none;
  border:0;
  border-bottom:1px solid rgba(255,255,255,.35);
  border-radius:0;
  box-shadow:none;
}
.channels-simple .channel-link:hover{
  background:none;
  transform:none;
  box-shadow:none;
  border-color:var(--invert);
}

