/* ── Reset ─────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
html.lenis,html.lenis body{height:auto}
.lenis.lenis-smooth{scroll-behavior:auto}
.lenis.lenis-smooth [data-lenis-prevent]{overscroll-behavior:contain}

:root{
  --canvas:#0a0a0a;
  --text:#f5f5f7;
  --text-secondary:rgba(255,255,255,0.5);
  --text-tertiary:rgba(255,255,255,0.3);
  --border:rgba(255,255,255,0.06);
  --glass:rgba(255,255,255,0.03);
  --glass-border:rgba(255,255,255,0.06);
  --neon:rgba(0,255,160,0.85);
  --radius:20px;
  --radius-sm:12px;
  --font:-apple-system,BlinkMacSystemFont,'SF Pro Display','Inter',system-ui,sans-serif;
  --ease:cubic-bezier(.22,.61,.36,1);
}

body{
  font-family:var(--font);
  background:var(--canvas);
  color:var(--text);
  line-height:1.6;
  overflow-x:hidden;
}

/* ── Ambient neon aurora (subtle, continuous) ─────── */
body::before{
  content:'';
  position:fixed;inset:0;
  z-index:0;
  pointer-events:none;
  background:
    radial-gradient(ellipse 1000px 900px at 8% 15%,rgba(0,255,160,0.09),transparent 60%),
    radial-gradient(ellipse 900px 800px at 92% 75%,rgba(80,180,255,0.09),transparent 60%),
    radial-gradient(ellipse 700px 600px at 50% 50%,rgba(0,200,255,0.05),transparent 55%),
    radial-gradient(ellipse 500px 500px at 75% 25%,rgba(0,255,200,0.05),transparent 50%);
  mask-image:linear-gradient(to bottom,transparent 0%,transparent 60vh,black 95vh);
  -webkit-mask-image:linear-gradient(to bottom,transparent 0%,transparent 60vh,black 95vh);
  /* Aurora is now static. The continuous 32s drift was causing
     a permanently composited full-viewport layer on every frame,
     which makes all other animations jankier. */
}
@keyframes auroraDrift{
  0%{transform:translate(0,0) scale(1)}
  50%{transform:translate(-20px,-15px) scale(1.03)}
  100%{transform:translate(20px,10px) scale(1.05)}
}
body>*{position:relative;z-index:1}

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

.container{width:100%;max-width:1200px;margin:0 auto;padding:0 40px}
.reveal{opacity:0}
.watermark{display:none}

/* ── Layout: full-bleed cinematic sections ─────────── */
.full-bleed{
  position:relative;
  width:calc(100% - 48px);
  margin-left:24px;
  margin-right:24px;
  border-radius:24px;
  overflow:hidden;
}
.full-bleed::before{
  content:'';position:absolute;inset:0;z-index:3;
  border-radius:24px;
  pointer-events:none;
}
.full-bleed-video{
  position:absolute;z-index:0;
  inset:0;
  width:100%;height:100%;
  object-fit:cover;
}
.full-bleed-overlay{
  position:absolute;inset:0;z-index:1;
}
.full-bleed-content{
  position:relative;z-index:2;
}


/* ── Layout: open canvas sections ──────────────────── */
.section-open{
  position:relative;
  max-width:1200px;
  margin:0 auto;
  padding:72px 56px;
}
.section-open>*{position:relative;z-index:1}

/* ── Spacing ───────────────────────────────────────── */
.gap-lg{margin-bottom:0}
.gap-md{margin-bottom:0}
.gap-sm{margin-bottom:0}

/* ── Focus-visible: neon outline for keyboard navigation ──
   Only shows for keyboard users (not mouse clicks). WCAG 2.4.7. */
:focus{outline:none}
:focus-visible{
  outline:2px solid rgba(0,255,170,0.85);
  outline-offset:3px;
  border-radius:6px;
  transition:outline-offset .15s ease;
}
.btn:focus-visible,
.nav-burger:focus-visible,
.faq-q:focus-visible,
.story-fcard:focus-visible,
.case-study-toggle:focus-visible,
.menu-link:focus-visible,
.theory-card:focus-visible{
  outline-offset:4px;
  border-radius:999px;
}
.faq-q:focus-visible,
.story-fcard:focus-visible,
.theory-card:focus-visible{
  border-radius:14px;
}

/* ── Buttons ───────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;gap:6px;
  padding:12px 28px;font-size:.85rem;font-weight:500;
  border-radius:50px;
  transition:opacity .3s var(--ease),transform .3s var(--ease);
  cursor:pointer;white-space:nowrap;
  letter-spacing:.01em;
}
.btn:hover{opacity:.9;transform:translateY(-1px)}
.btn--glass{
  background:rgba(255,255,255,0.08);
  border:1px solid rgba(255,255,255,0.12);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  color:var(--text);
}
.btn--glass:hover{
  background:rgba(255,255,255,0.14);
  border-color:rgba(255,255,255,0.2);
}
.btn--solid{
  background:var(--text);color:var(--canvas);
  border:1px solid var(--text);
  position:relative;
}
.btn--solid:hover{
  transform:translateY(-1px) translateX(1px);
  box-shadow:0 10px 30px -10px rgba(255,255,255,0.25);
}

/* ── Labels ────────────────────────────────────────── */
.label{
  display:inline-block;
  font-size:.7rem;font-weight:500;letter-spacing:.08em;
  text-transform:uppercase;color:var(--text-tertiary);
  margin-bottom:12px;
}

/* ── NAV ───────────────────────────────────────────── */
.nav{position:fixed;top:0;left:0;right:0;z-index:1000;pointer-events:none}
.nav-logo-fixed{
  position:fixed;top:20px;left:28px;z-index:1001;
  pointer-events:all;
  transition:transform .4s var(--ease),opacity .4s var(--ease);
}
.nav-logo-fixed.scrolled{transform:scale(0.85);opacity:0.7}
.nav-logo-img{
  width:72px;height:72px;object-fit:contain;
  filter:brightness(0) invert(1);
}

.nav-pill{
  position:fixed;top:24px;right:28px;
  z-index:1001;pointer-events:all;
  display:flex;align-items:center;
  padding:6px 10px;
  background:rgba(255,255,255,0.06);
  backdrop-filter:blur(20px) saturate(150%);
  -webkit-backdrop-filter:blur(20px) saturate(150%);
  border-radius:50px;
  border:1px solid rgba(255,255,255,0.08);
  transition:transform .4s var(--ease);
}
.nav-pill.scrolled{
  transform:scale(0.92);
  background:rgba(255,255,255,0.09);
  border-color:rgba(255,255,255,0.14);
}

.nav-burger{display:flex;flex-direction:column;gap:3px;padding:4px;cursor:pointer}
.nav-burger span{
  display:block;width:14px;height:1.2px;
  background:rgba(255,255,255,0.7);border-radius:1px;
  transition:all .3s var(--ease);
}
.nav-burger.open span:nth-child(1){transform:rotate(45deg) translate(3px,3px)}
.nav-burger.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.nav-burger.open span:nth-child(3){transform:rotate(-45deg) translate(3px,-3px)}

/* ── Menu Overlay ──────────────────────────────────── */
.menu-overlay{
  position:fixed;inset:0;z-index:999;
  background:rgba(10,10,10,0.96);
  backdrop-filter:blur(30px);-webkit-backdrop-filter:blur(30px);
  display:flex;align-items:center;justify-content:center;
  opacity:0;pointer-events:none;transition:opacity .4s var(--ease);
}
.menu-overlay.open{opacity:1;pointer-events:all}
.menu-inner{display:flex;flex-direction:column;align-items:center;gap:18px}
.menu-link{font-size:2rem;font-weight:500;color:var(--text-secondary);transition:color .3s}
.menu-link:hover{color:var(--text)}
.menu-link--cta{
  font-size:.9rem;margin-top:14px;padding:10px 26px;
  background:rgba(255,255,255,0.08);color:var(--text);
  border:1px solid rgba(255,255,255,0.12);border-radius:50px;
}

/* ═══════════════════════════════════════════════════════
   HERO
   ═══════════════════════════════════════════════════════ */
.hero{
  position:relative;height:100vh;min-height:600px;
  display:flex;flex-direction:column;
  overflow:hidden;
  z-index:2;
}
.hero::after{
  content:'';position:absolute;bottom:0;left:0;right:0;
  height:140px;z-index:2;
  background:linear-gradient(to bottom,transparent 0%,var(--canvas) 100%);
  pointer-events:none;
}
.hero-video{
  position:absolute;inset:0;z-index:0;
  width:100%;height:100%;object-fit:cover;
  transform:translateZ(0);
  backface-visibility:hidden;
}
.hero-content{
  position:relative;z-index:3;
  flex:1;display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  text-align:center;padding:120px 40px 80px;
}
.hero-title{
  font-size:clamp(2.4rem,6.5vw,5rem);
  font-weight:600;line-height:.96;
  color:var(--text);letter-spacing:-.03em;
  margin-bottom:16px;
}
.hero-sub{
  font-size:clamp(.85rem,1.3vw,1.05rem);
  font-weight:400;color:var(--text-secondary);
  letter-spacing:.01em;
}
.hero-ctas{
  display:flex;gap:12px;margin-top:28px;
  align-items:center;justify-content:center;flex-wrap:wrap;
}

/* ═══════════════════════════════════════════════════════
   ABOUT (full-bleed cinematic)
   ═══════════════════════════════════════════════════════ */
.about{padding:120px 0;margin-top:40px}
.about .full-bleed-video{opacity:1}
.about .full-bleed-content{
  max-width:900px;margin:0 auto;padding:0 40px;
  text-align:center;
}
.about-heading{
  font-size:clamp(1.5rem,3vw,2.4rem);
  font-weight:600;line-height:1.2;letter-spacing:-.02em;
  max-width:720px;margin:0 auto 20px;
}
.about-heading em{font-style:italic;font-weight:500}
.about-body{
  font-size:clamp(.9rem,1.3vw,1.05rem);
  line-height:1.65;color:var(--text-secondary);
  max-width:600px;margin:0 auto 16px;font-weight:400;
}
.about-cta{
  display:block;
  font-size:.85rem;font-weight:500;
  color:var(--text);
  margin-bottom:48px;
  opacity:0.6;transition:opacity .3s;
}
.about-cta:hover{opacity:1}

.about-stats{
  display:flex;align-items:center;justify-content:center;
  padding-top:32px;
  border-top:1px solid var(--border);
}
.about-stat{
  display:flex;flex-direction:column;align-items:center;
  padding:0 48px;
}
.about-stat-num{
  font-size:clamp(2rem,4vw,3.2rem);
  font-weight:200;letter-spacing:-.03em;line-height:1.1;
  display:inline-block;
  font-variant-numeric:tabular-nums;
  font-feature-settings:"tnum";
}
.about-stat-suffix{
  font-size:clamp(1.4rem,2.5vw,2rem);
  font-weight:200;letter-spacing:-.02em;
  color:var(--text-secondary);
}
.about-stat-label{
  font-size:.68rem;text-transform:uppercase;
  letter-spacing:.06em;color:var(--text-tertiary);margin-top:4px;
}
.about-stat-divider{
  width:1px;height:36px;background:var(--border);
}

/* ═══════════════════════════════════════════════════════
   STORY (premium centered)
   ═══════════════════════════════════════════════════════ */
.story{padding:120px 0 90px;position:relative;overflow:hidden}
.story-container{
  max-width:900px;margin:0 auto;padding:0 40px;
  position:relative;z-index:1;
}

/* ── Narrative ─────────────────────────────────────── */
.story-narrative{
  text-align:center;
  margin-bottom:56px;
}
.story-narrative .label{display:block;margin-bottom:20px}
.story-google-badge{
  display:inline-flex;align-items:center;
  margin-bottom:24px;
}
.story-google-icon{flex-shrink:0}
.story-heading{
  font-size:clamp(2rem,4vw,3.2rem);
  font-weight:600;line-height:1.1;letter-spacing:-.03em;
  margin-bottom:24px;
}
.story-google-text{
  background:linear-gradient(90deg,#4285F4,#34A853,#FBBC05,#EA4335);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
}
.story-body{
  font-size:clamp(.92rem,1.3vw,1.08rem);
  line-height:1.75;color:var(--text-secondary);
  font-weight:400;
  max-width:640px;margin:0 auto;
}

/* ── Divider ───────────────────────────────────────── */
.story-divider{
  display:flex;align-items:center;gap:20px;
  margin-bottom:48px;
}
.story-divider-line{
  flex:1;height:1px;
  background:linear-gradient(90deg,transparent,var(--border),transparent);
}
.story-divider-text{
  font-size:.6rem;font-weight:600;
  letter-spacing:.12em;text-transform:uppercase;
  color:var(--text-tertiary);
  white-space:nowrap;
}

/* ── Founder cards. Side-by-side editorial, compact. ──
   Two cards in a row. Ordinal top-right as a decorative
   anchor. Stacked display name, role, bio, link flow in
   a single column per card. Tight and clean. */
.story-founders{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:0;
  border-top:1px solid rgba(255,255,255,0.08);
  border-bottom:1px solid rgba(255,255,255,0.08);
}
.story-fcard{
  position:relative;
  display:flex;
  flex-direction:column;
  padding:44px 44px 40px;
  transition:background .5s var(--ease);
  min-height:0;
}
.story-fcard + .story-fcard{
  border-left:1px solid rgba(255,255,255,0.08);
}
.story-fcard:hover{
  background:rgba(255,255,255,0.015);
}

/* Decorative neon line that draws in along the top on hover */
.story-fcard::before{
  content:'';
  position:absolute;
  left:0;right:0;top:-1px;
  height:1px;
  background:linear-gradient(90deg,
    rgba(0,255,170,0) 0%,
    rgba(0,255,170,0.5) 50%,
    rgba(0,255,170,0) 100%);
  transform:scaleX(0);
  transform-origin:center;
  transition:transform 1s cubic-bezier(.22,.75,.22,1);
  pointer-events:none;
}
.story-fcard:hover::before{
  transform:scaleX(1);
}

/* Signet mark: a minimal SVG that draws in on entrance and
   holds a slow idle rotation. Unique per founder: targeting
   reticle for Yash, concentric rings for Satwik. */
.story-fcard-mark{
  position:absolute;
  top:34px;
  right:40px;
  width:52px;
  height:52px;
  color:rgba(255,255,255,0.32);
  pointer-events:none;
  z-index:0;
  transition:color .7s var(--ease),transform .8s var(--ease);
}
.story-fcard:hover .story-fcard-mark{
  color:rgba(0,255,170,0.82);
  transform:scale(1.08);
}
.story-fcard-mark-svg{
  width:100%;
  height:100%;
  display:block;
  overflow:visible;
}
.story-fcard-mark-ring,
.story-fcard-mark-ring-inner{
  transform-box:fill-box;
  transform-origin:center;
  stroke-dasharray:170;
  stroke-dashoffset:170;
  opacity:.9;
}
.story-fcard-mark-ring-inner{
  stroke-dasharray:98;
  stroke-dashoffset:98;
}
.story-fcard.is-in .story-fcard-mark-ring{
  animation:
    markDraw 1.5s cubic-bezier(.22,.72,.2,1) .35s forwards,
    markSpin 28s linear 2s infinite;
}
.story-fcard.is-in .story-fcard-mark-ring-inner{
  animation:
    markDrawInner 1.4s cubic-bezier(.22,.72,.2,1) .55s forwards,
    markSpinReverse 20s linear 2s infinite;
}
.story-fcard-mark-dot{
  transform-box:fill-box;
  transform-origin:center;
  transform:scale(0);
  opacity:0;
}
.story-fcard.is-in .story-fcard-mark-dot{
  animation:markDotPop .8s cubic-bezier(.2,1.2,.35,1) 1.15s forwards;
}
.story-fcard-mark-line{
  stroke-dasharray:34;
  stroke-dashoffset:34;
}
.story-fcard.is-in .story-fcard-mark-line{
  animation:markDraw .9s cubic-bezier(.22,.72,.2,1) .95s forwards;
}
@keyframes markDraw{
  to{stroke-dashoffset:0}
}
@keyframes markDrawInner{
  to{stroke-dashoffset:0}
}
@keyframes markDotPop{
  0%{transform:scale(0);opacity:0}
  60%{opacity:1}
  100%{transform:scale(1);opacity:1}
}
@keyframes markSpin{
  to{transform:rotate(360deg)}
}
@keyframes markSpinReverse{
  to{transform:rotate(-360deg)}
}

/* Name: each line sits inside a clipping window so the
   letters can slide up from below into view. */
.story-fcard-name{
  position:relative;
  z-index:1;
  font-size:clamp(1.8rem,2.9vw,2.5rem);
  font-weight:500;
  color:var(--text);
  letter-spacing:-.022em;
  line-height:.96;
  margin:0 0 14px;
  max-width:calc(100% - 60px);        /* leave room for mark */
}
.story-fcard-first,
.story-fcard-last{
  display:block;
}
.story-fcard-last{
  color:rgba(255,255,255,0.55);
  transition:color .5s var(--ease);
}
.story-fcard:hover .story-fcard-last{
  color:var(--text);
}

@media (prefers-reduced-motion: reduce){
  .story-fcard-mark-ring,
  .story-fcard-mark-ring-inner,
  .story-fcard-mark-line{stroke-dashoffset:0;animation:none !important}
  .story-fcard-mark-dot{transform:scale(1);opacity:1;animation:none !important}
}
.story-fcard-role{
  position:relative;
  z-index:1;
  font-size:.64rem;
  font-weight:500;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--text-tertiary);
  margin:14px 0 30px;
}
.story-fcard-bio{
  position:relative;
  z-index:1;
  font-size:.9rem;
  color:var(--text-secondary);
  line-height:1.65;
  font-weight:400;
  max-width:38ch;
  margin:0 0 32px;
  flex:1;
}
.story-fcard-hl{
  color:var(--text);
  font-weight:500;
}
.story-fcard-link{
  position:relative;
  z-index:1;
  align-self:flex-start;
  display:inline-flex;
  align-items:center;
  gap:10px;
  font-size:.66rem;
  font-weight:500;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--text);
  padding-bottom:5px;
  border-bottom:1px solid rgba(255,255,255,0.22);
  transition:border-color .5s var(--ease);
}
.story-fcard:hover .story-fcard-link{
  border-color:rgba(0,255,170,0.65);
}
.story-fcard-arrow{
  display:inline-block;
  transition:transform .4s var(--ease);
}
.story-fcard:hover .story-fcard-arrow{
  transform:translateX(5px);
}

/* ═══════════════════════════════════════════════════════
   SHARED: fixaplan-style big section (process, services, story)
   ═══════════════════════════════════════════════════════ */
.fx-intro{
  margin-bottom:72px;
  max-width:1100px;
}
.fx-eyebrow{
  font-size:.95rem;
  color:var(--text-secondary);
  line-height:1.5;
  max-width:480px;
  margin-bottom:24px;
  font-weight:400;
}
.fx-big-heading{
  font-size:clamp(2.6rem,7vw,6rem);
  font-weight:600;
  letter-spacing:-.04em;
  line-height:.95;
}
.fx-big-line-1{display:block;color:var(--text)}
.fx-big-line-2{display:block;color:rgba(255,255,255,0.35)}

.fx-card{
  position:relative;overflow:hidden;
  display:flex;flex-direction:column;justify-content:space-between;
  min-height:300px;
  padding:36px 30px;
  border-radius:22px;
  background:rgba(255,255,255,0.025);
  border:1px solid rgba(255,255,255,0.06);
  transition:border-color .5s var(--ease),transform .5s var(--ease),background .5s var(--ease);
}
.fx-card::before{
  content:'';
  position:absolute;inset:-1px;
  border-radius:22px;
  background:radial-gradient(circle at var(--mx,50%) var(--my,0%),rgba(0,255,160,0.12),transparent 60%);
  opacity:0;
  transition:opacity .5s var(--ease);
  pointer-events:none;
}
.fx-card:hover{
  border-color:rgba(0,255,160,0.25);
  background:rgba(255,255,255,0.04);
  transform:translateY(-4px);
}
.fx-card:hover::before{opacity:1}
.fx-card-icon{
  color:rgba(255,255,255,0.55);
  transition:color .5s var(--ease),transform .5s var(--ease);
  position:relative;z-index:1;
}
.fx-card:hover .fx-card-icon{
  color:var(--neon);
  transform:scale(1.08);
  filter:drop-shadow(0 0 12px rgba(0,255,160,0.4));
}
.fx-card-body{margin-top:auto;position:relative;z-index:1}
.fx-card-title{
  font-size:1.25rem;
  font-weight:500;
  letter-spacing:-.01em;
  color:var(--text);
  margin-bottom:10px;
}
.fx-card-desc{
  font-size:.85rem;
  color:var(--text-secondary);
  line-height:1.65;
  font-weight:400;
}

/* ═══════════════════════════════════════════════════════
   PROCESS
   ═══════════════════════════════════════════════════════ */
.process{
  position:relative;
  padding:120px 0;
  overflow:hidden;
}
.process-particle,
.neon-particle{
  position:absolute;
  width:4px;height:4px;
  border-radius:50%;
  background:rgba(0,255,160,0.45);
  box-shadow:0 0 8px rgba(0,255,160,0.55),0 0 18px rgba(0,255,160,0.25);
  pointer-events:none;
  z-index:0;
}
.neon-particle--sm{
  width:3px;height:3px;
  background:rgba(0,255,160,0.35);
  box-shadow:0 0 6px rgba(0,255,160,0.45),0 0 12px rgba(0,255,160,0.18);
}
.neon-particle--lg{
  width:5px;height:5px;
  background:rgba(0,255,160,0.55);
  box-shadow:0 0 12px rgba(0,255,160,0.7),0 0 28px rgba(0,255,160,0.3);
}
.neon-particle--blue{
  background:rgba(80,180,255,0.45);
  box-shadow:0 0 8px rgba(80,180,255,0.6),0 0 18px rgba(80,180,255,0.25);
}
.neon-particle--blue.neon-particle--sm{
  background:rgba(80,180,255,0.35);
  box-shadow:0 0 6px rgba(80,180,255,0.45),0 0 12px rgba(80,180,255,0.18);
}
.process-inner{
  position:relative;z-index:1;
  max-width:1200px;margin:0 auto;padding:0 40px;
}
.process-intro{
  margin:0 auto 56px;
  max-width:720px;
  text-align:center;
}
.process-eyebrow{
  font-size:.9rem;
  color:var(--text-secondary);
  line-height:1.5;
  max-width:520px;
  margin:0 auto 20px;
  font-weight:400;
}
.process-big-heading{
  font-size:clamp(2rem,4.5vw,3.6rem);
  font-weight:600;
  letter-spacing:-.025em;
  line-height:1.05;
}
.process-subtitle{
  font-size:.95rem;
  color:var(--text-secondary);
  line-height:1.55;
  max-width:480px;
  margin:18px auto 0;
  font-weight:400;
}
.process-divider{
  display:flex;align-items:center;gap:20px;
  max-width:800px;
  margin:72px auto 48px;
}
.process-divider-line{
  flex:1;height:1px;
  background:linear-gradient(90deg,transparent,rgba(0,255,160,0.25),transparent);
}
.process-divider-text{
  font-size:.65rem;font-weight:600;
  letter-spacing:.14em;text-transform:uppercase;
  color:rgba(0,255,160,0.6);
  white-space:nowrap;
}
.process-big-line-1{display:block;color:var(--text);overflow:hidden}
.process-big-line-2{display:block;color:rgba(255,255,255,0.5);overflow:hidden}
.process-word{display:inline-block}

/* ── Integrated method rail.4 steps on a single flowing line ─────
   Minimal text, Apple-style. A horizontal rail connects four nodes;
   when the section enters view, the rail draws in from left to right
   and the four step cards rise in sequence. One coordinated timeline,
   no mistimed underline animations. */
.method-rail{
  position:relative;
  max-width:960px;
  margin:30px auto 90px;
  padding:40px 40px 30px;
  z-index:1;
}
.method-rail-line{
  position:absolute;
  left:80px;right:80px;
  top:66px;            /* aligns with dot center */
  height:1px;
  background:linear-gradient(90deg,
    rgba(0,255,160,0) 0%,
    rgba(0,255,160,0.15) 8%,
    rgba(0,255,160,0.35) 50%,
    rgba(80,180,255,0.35) 92%,
    rgba(80,180,255,0) 100%);
  overflow:visible;
}
.method-rail-line-fill{
  position:absolute;inset:0;
  background:linear-gradient(90deg,
    rgba(0,255,160,0.9) 0%,
    rgba(60,220,220,0.85) 50%,
    rgba(80,180,255,0.9) 100%);
  transform:scaleX(0);
  transform-origin:left center;
  transition:transform 1.6s cubic-bezier(.22,.72,.2,1) .15s;
  box-shadow:0 0 18px rgba(0,255,160,0.25);
}
.method-rail.is-in .method-rail-line-fill{
  transform:scaleX(1);
}
.method-steps{
  position:relative;
  display:grid;
  grid-template-columns:repeat(4,1fr);
  list-style:none;
  padding:0;
  margin:0;
}
.method-step{
  position:relative;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:14px;
  padding:14px 12px 0;
  opacity:0;
  transform:translateY(14px);
  transition:
    opacity .9s cubic-bezier(.22,.75,.2,1),
    transform .9s cubic-bezier(.22,.75,.2,1);
  transition-delay:calc(var(--i) * 180ms + 650ms);
}
.method-rail.is-in .method-step{
  opacity:1;
  transform:translateY(0);
}
.method-dot{
  width:12px;height:12px;
  border-radius:50%;
  background:rgba(0,255,160,0.95);
  box-shadow:
    0 0 0 4px rgba(0,255,160,0.08),
    0 0 14px rgba(0,255,160,0.55);
  position:relative;
  z-index:2;
  transform:scale(.4);
  transition:transform .8s cubic-bezier(.2,1.4,.35,1);
  transition-delay:calc(var(--i) * 180ms + 750ms);
}
.method-rail.is-in .method-dot{
  transform:scale(1);
}
.method-step:nth-child(1) .method-dot{background:rgba(0,255,170,0.95)}
.method-step:nth-child(2) .method-dot{background:rgba(60,220,210,0.95)}
.method-step:nth-child(3) .method-dot{background:rgba(110,200,240,0.95)}
.method-step:nth-child(4) .method-dot{
  background:rgba(80,180,255,0.95);
  box-shadow:0 0 0 4px rgba(80,180,255,0.08),0 0 14px rgba(80,180,255,0.55);
}
.method-step-num{
  margin-top:6px;
  font-size:.66rem;
  font-weight:500;
  letter-spacing:.22em;
  color:rgba(255,255,255,0.32);
  text-transform:uppercase;
  font-variant-numeric:tabular-nums;
}
.method-step-name{
  font-size:clamp(1.05rem,1.7vw,1.35rem);
  font-weight:500;
  color:var(--text);
  letter-spacing:-.01em;
}
.method-step-verb{
  font-size:.72rem;
  font-weight:400;
  color:rgba(255,255,255,0.42);
  letter-spacing:.03em;
}

@media (prefers-reduced-motion: reduce){
  .method-rail-line-fill,
  .method-step,
  .method-dot{transition:none !important}
  .method-rail-line-fill{transform:scaleX(1)}
  .method-step{opacity:1;transform:none}
  .method-dot{transform:scale(1)}
}

/* Keep old process-cards class around for responsive but hide it */
.process-cards{display:none}
.process-card{
  position:relative;overflow:hidden;
  display:flex;flex-direction:column;justify-content:space-between;
  min-height:320px;
  padding:36px 30px;
  border-radius:22px;
  background:linear-gradient(145deg,rgba(255,255,255,0.04),rgba(255,255,255,0.015));
  border:1px solid rgba(255,255,255,0.06);
  transition:border-color .5s var(--ease),transform .5s var(--ease),background .5s var(--ease),box-shadow .5s var(--ease);
}
/* Neon sweep gradient on hover */
.process-card::before{
  content:'';
  position:absolute;inset:-1px;
  border-radius:22px;
  background:radial-gradient(circle at 50% 0%,rgba(0,255,160,0.18),transparent 60%);
  opacity:0;
  transition:opacity .5s var(--ease);
  pointer-events:none;
}
/* Animated gradient border on hover */
.process-card::after{
  content:'';
  position:absolute;inset:0;
  border-radius:22px;
  padding:1px;
  background:linear-gradient(135deg,rgba(0,255,160,0.4),rgba(80,180,255,0.35),rgba(0,255,160,0.4));
  background-size:200% 200%;
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;
  mask-composite:exclude;
  opacity:0;
  transition:opacity .6s var(--ease);
  animation:borderShift 6s linear infinite;
  pointer-events:none;
}
.process-card:hover{
  border-color:transparent;
  background:linear-gradient(145deg,rgba(255,255,255,0.06),rgba(0,255,160,0.02));
  transform:translateY(-6px);
  box-shadow:0 30px 60px rgba(0,0,0,0.35),0 0 40px rgba(0,255,160,0.12);
}
.process-card:hover::before{opacity:1}
.process-card:hover::after{opacity:1}
@keyframes borderShift{
  0%{background-position:0% 0%}
  100%{background-position:200% 200%}
}
.process-card-icon{
  position:relative;
  z-index:1;
  width:56px;height:56px;
  display:flex;align-items:center;justify-content:center;
  border-radius:14px;
  background:rgba(0,255,160,0.04);
  border:1px solid rgba(0,255,160,0.12);
  color:rgba(0,255,160,0.75);
  transition:all .5s var(--ease);
}
.process-card-icon svg{
  transition:transform .5s var(--ease);
}
.process-card:hover .process-card-icon{
  background:rgba(0,255,160,0.1);
  border-color:rgba(0,255,160,0.35);
  box-shadow:0 0 20px rgba(0,255,160,0.25),inset 0 0 12px rgba(0,255,160,0.1);
  color:var(--neon);
}
.process-card:hover .process-card-icon svg{
  transform:scale(1.1) rotate(-4deg);
}
/* Subtle floating number label */
.process-card-num{
  position:absolute;
  top:28px;right:28px;
  font-size:.68rem;
  font-weight:600;
  letter-spacing:.12em;
  color:rgba(0,255,160,0.35);
  font-variant-numeric:tabular-nums;
  z-index:1;
}
.process-card-body{margin-top:auto;position:relative;z-index:1}
.process-card-title{
  font-size:1.3rem;
  font-weight:500;
  letter-spacing:-.01em;
  color:var(--text);
  margin-bottom:10px;
  transition:color .4s var(--ease);
}
.process-card-desc{
  font-size:.85rem;
  color:var(--text-secondary);
  line-height:1.65;
  font-weight:400;
}
/* Inner glow accent line that slides in on hover */
.process-card-body::before{
  content:'';
  position:absolute;
  top:-16px;left:0;
  width:0;
  height:1px;
  background:linear-gradient(90deg,rgba(0,255,160,0.6),transparent);
  transition:width .6s var(--ease);
}
.process-card:hover .process-card-body::before{
  width:40%;
}

/* ═══════════════════════════════════════════════════════
   SERVICES: Apple bento with animated visuals
   ═══════════════════════════════════════════════════════ */
.services{padding:100px 0;position:relative;overflow:hidden}
.services-inner{max-width:1100px;margin:0 auto;padding:0 40px;position:relative;z-index:1}
.svc-header{text-align:center;margin-bottom:56px}
.svc-heading{
  font-size:clamp(1.6rem,3.2vw,2.6rem);
  font-weight:600;line-height:1.15;letter-spacing:-.02em;
  color:var(--text);
}

/* ── Bento layout ──────────────────────────────────── */
.svc-bento{
  display:grid;
  grid-template-columns:repeat(12,1fr);
  gap:14px;
  margin-bottom:48px;
}
.svc-tile{
  position:relative;
  border-radius:22px;
  border:1px solid rgba(255,255,255,0.06);
  background:rgba(255,255,255,0.025);
  overflow:hidden;
  display:flex;flex-direction:column;
  grid-column:span 6;
  transition:border-color .4s var(--ease),transform .4s var(--ease);
}
.svc-tile:hover{
  border-color:rgba(255,255,255,0.12);
  transform:translateY(-3px);
}
.svc-tile--wide{grid-column:span 7;min-height:340px}
.svc-tile--tall{grid-column:span 5;min-height:420px}

/* ── Tile content ──────────────────────────────────── */
.svc-tile-visual{
  flex:1;display:flex;align-items:center;justify-content:center;
  padding:32px 28px 16px;
  position:relative;overflow:hidden;
}
.svc-tile-info{padding:0 28px 28px}
.svc-tile-title{
  font-size:1.1rem;font-weight:600;
  margin-bottom:6px;color:var(--text);letter-spacing:-.01em;
}
.svc-tile-desc{
  font-size:.8rem;color:var(--text-secondary);
  line-height:1.55;font-weight:400;
}

/* ── Viz: Engagement bars ──────────────────────────── */
.svc-viz-engagement{
  display:flex;align-items:flex-end;gap:8px;
  height:140px;width:100%;
}
.svc-bar{
  flex:1;
  height:var(--h);
  border-radius:6px;
  background:rgba(255,255,255,0.06);
  position:relative;
  animation:barGrow .8s var(--ease) both;
  animation-delay:calc(var(--h, 50%) * 0.005s);
  display:flex;flex-direction:column;justify-content:flex-end;align-items:center;
}
.svc-bar span{
  font-size:.52rem;color:var(--text-tertiary);
  padding-top:6px;letter-spacing:.02em;
}
.svc-bar--accent{
  background:linear-gradient(180deg,rgba(0,255,160,0.35),rgba(0,255,160,0.12));
  box-shadow:0 0 12px rgba(0,255,160,0.25),0 0 30px rgba(0,255,160,0.1);
}
@keyframes barGrow{
  from{height:0;opacity:0}
  to{height:var(--h);opacity:1}
}

/* ── Viz: Orbit (brand) ────────────────────────────── */
.svc-viz-orbit{
  position:relative;width:180px;height:180px;
}
.svc-orbit-ring{
  position:absolute;border-radius:50%;
  border:1px solid rgba(255,255,255,0.06);
}
.svc-orbit-ring--1{inset:0}
.svc-orbit-ring--2{inset:25px}
.svc-orbit-ring--3{inset:50px}
.svc-orbit-core{
  position:absolute;
  top:50%;left:50%;
  width:16px;height:16px;
  margin:-8px 0 0 -8px;
  border-radius:50%;
  background:rgba(0,255,160,0.5);
  box-shadow:0 0 20px rgba(0,255,160,0.2);
}
.svc-orbit-dot{
  position:absolute;
  width:6px;height:6px;
  border-radius:50%;
  background:rgba(255,255,255,0.4);
}
.svc-orbit-dot--1{
  top:0;left:50%;margin-left:-3px;
  animation:orbitSpin 8s linear infinite;
  transform-origin:3px 90px;
}
.svc-orbit-dot--2{
  top:25px;left:50%;margin-left:-3px;
  animation:orbitSpin 6s linear infinite reverse;
  transform-origin:3px 65px;
}
.svc-orbit-dot--3{
  top:50px;left:50%;margin-left:-3px;
  animation:orbitSpin 4s linear infinite;
  transform-origin:3px 40px;
  background:rgba(0,255,160,0.6);
}
@keyframes orbitSpin{to{transform:rotate(360deg)}}

/* ── Viz: Graph (performance) ──────────────────────── */
.svc-viz-graph{
  width:100%;height:120px;
  position:relative;
}
.svc-graph-svg{
  width:100%;height:100%;
}
.svc-graph-line{
  stroke-dasharray:400;
  stroke-dashoffset:400;
  animation:drawLine 2s var(--ease) forwards;
  filter:drop-shadow(0 0 6px rgba(0,255,160,0.4)) drop-shadow(0 0 14px rgba(0,255,160,0.15));
}
.svc-graph-area{
  opacity:0;animation:fadeArea 1s .8s var(--ease) forwards;
}
@keyframes drawLine{to{stroke-dashoffset:0}}
@keyframes fadeArea{to{opacity:1}}
.svc-graph-label{
  position:absolute;top:32px;right:8px;
  text-align:right;
}
.svc-graph-val{
  display:block;font-size:1.6rem;font-weight:600;
  color:var(--neon);letter-spacing:-.02em;line-height:1;
  text-shadow:0 0 10px rgba(0,255,160,0.4),0 0 24px rgba(0,255,160,0.15);
}
.svc-graph-sub{
  font-size:.6rem;color:var(--text-tertiary);
  letter-spacing:.04em;text-transform:uppercase;
}

/* ── Viz: Funnel (e-commerce) ──────────────────────── */
.svc-viz-funnel{
  display:flex;flex-direction:column;gap:6px;
  width:100%;
}
.svc-funnel-step{
  width:var(--w);
  margin:0 auto;
  padding:8px 14px;
  border-radius:8px;
  background:rgba(255,255,255,0.04);
  font-size:.62rem;font-weight:500;
  color:var(--text-tertiary);
  letter-spacing:.02em;
  text-align:center;
  animation:funnelSlide .6s var(--ease) both;
  animation-delay:calc((100% - var(--w)) * 0.005s);
}
.svc-funnel-step span{display:block}
.svc-funnel-step--accent{
  background:rgba(0,255,160,0.1);
  border:1px solid rgba(0,255,160,0.12);
  color:var(--neon);
  box-shadow:0 0 12px rgba(0,255,160,0.2),0 0 28px rgba(0,255,160,0.08);
  text-shadow:0 0 8px rgba(0,255,160,0.3);
}
@keyframes funnelSlide{
  from{opacity:0;transform:translateY(10px)}
  to{opacity:1;transform:translateY(0)}
}

/* ═══════════════════════════════════════════════════════
   REEL
   ═══════════════════════════════════════════════════════ */
.reel{overflow:hidden;padding:90px 0;position:relative;display:flex;flex-direction:column;gap:14px}
.reel-track{
  display:flex;gap:14px;
  will-change:transform;
}
.reel-track img,.reel-track video{
  height:340px;aspect-ratio:3/4;
  border-radius:18px;object-fit:cover;
  flex-shrink:0;
}

/* Inline concept disclaimer directly under the image carousels. */
.reel-disclaimer{
  max-width:880px;
  margin:30px auto 10px;
  padding:0 40px;
  text-align:center;
  font-size:.66rem;
  line-height:1.7;
  color:rgba(255,255,255,0.35);
  font-weight:400;
  letter-spacing:.005em;
}
.reel-disclaimer strong{
  color:rgba(255,255,255,0.62);
  font-weight:500;
}
.reel-disclaimer-label{
  display:inline-block;
  margin-right:8px;
  padding:3px 8px;
  font-size:.56rem;
  font-weight:500;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:rgba(0,255,170,0.75);
  background:rgba(0,255,170,0.06);
  border:1px solid rgba(0,255,170,0.18);
  border-radius:50px;
  vertical-align:middle;
  position:relative;
  top:-1px;
}
@media(max-width:768px){
  .reel-disclaimer{padding:0 22px;font-size:.62rem;margin:22px auto 6px}
  .reel-disclaimer-label{font-size:.52rem;padding:2px 7px}
}

/* ═══════════════════════════════════════════════════════
   OUR WORK: visual showcase
   ═══════════════════════════════════════════════════════ */
.work{
  max-width:1200px;
  margin:0 auto;
  padding:70px 24px;
  position:relative;
  overflow:hidden;
}
.work-header{
  text-align:center;
  margin-bottom:64px;
}
.work-heading{
  font-size:clamp(1.6rem,3.2vw,2.6rem);
  font-weight:600;line-height:1.15;letter-spacing:-.02em;
  color:var(--text);margin-top:8px;
}

/* ── Showcase grid ─────────────────────────────────── */
.work-showcase{
  display:flex;flex-direction:column;
  gap:32px;
}
.mashreq-zoom{
  transform:scale(1.25);
  object-position:center center;
}
.work-project-label{
  font-size:.58rem;font-weight:600;
  letter-spacing:.1em;text-transform:uppercase;
  color:var(--text-tertiary);
  margin-bottom:12px;
}
.work-project-name{
  font-size:clamp(1.5rem,2.8vw,2.2rem);
  font-weight:600;line-height:1.1;letter-spacing:-.02em;
  color:var(--text);
  margin-bottom:10px;
}
.work-project-desc{
  font-size:.88rem;color:var(--text-secondary);
  font-weight:400;line-height:1.55;
  margin-bottom:12px;
}
.work-project-stat{
  display:inline-flex;align-self:flex-start;
  padding:5px 14px;
  font-size:.65rem;font-weight:600;
  letter-spacing:.03em;
  color:var(--neon);
  background:rgba(0,255,160,0.06);
  border:1px solid rgba(0,255,160,0.1);
  border-radius:50px;
}

/* ═══════════════════════════════════════════════════════
   DESIGN THEORY: website showcase
   ═══════════════════════════════════════════════════════ */
.theory{
  padding:120px 0;
  position:relative;
  overflow:hidden;
}
.theory-inner{
  max-width:1200px;
  margin:0 auto;
  padding:0 40px;
  position:relative;
  z-index:1;
}
.theory-header{
  text-align:center;
  margin-bottom:64px;
  max-width:720px;
  margin-left:auto;
  margin-right:auto;
}
.theory-heading{
  font-size:clamp(1.9rem,4vw,3.2rem);
  font-weight:600;
  line-height:1.08;
  letter-spacing:-.03em;
  color:var(--text);
  margin-top:12px;
  margin-bottom:16px;
}
.theory-sub{
  font-size:.95rem;
  color:var(--text-secondary);
  line-height:1.6;
  max-width:540px;
  margin:0 auto;
}
.theory-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
}
.theory-card{
  display:flex;
  flex-direction:column;
  gap:20px;
  text-decoration:none;
  color:inherit;
  transition:transform .5s var(--ease);
}
.theory-card:hover{
  transform:translateY(-6px);
}
.theory-browser{
  position:relative;
  border-radius:14px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,0.08);
  background:rgba(255,255,255,0.02);
  box-shadow:0 20px 40px rgba(0,0,0,0.4),0 0 0 1px rgba(255,255,255,0.02);
  transition:border-color .5s var(--ease),box-shadow .5s var(--ease);
}
.theory-card:hover .theory-browser{
  border-color:rgba(0,255,160,0.3);
  box-shadow:0 30px 60px rgba(0,0,0,0.5),0 0 30px rgba(0,255,160,0.15);
}
.theory-browser-bar{
  display:flex;
  align-items:center;
  gap:6px;
  padding:10px 14px;
  background:rgba(20,20,22,0.95);
  border-bottom:1px solid rgba(255,255,255,0.06);
  position:relative;
}
.theory-dot{
  width:10px;
  height:10px;
  border-radius:50%;
  background:rgba(255,255,255,0.15);
}
.theory-dot:nth-child(1){background:#ff5f57}
.theory-dot:nth-child(2){background:#febc2e}
.theory-dot:nth-child(3){background:#28c840}
.theory-url{
  position:absolute;
  left:50%;
  transform:translateX(-50%);
  font-size:.7rem;
  color:var(--text-tertiary);
  letter-spacing:.02em;
  font-weight:500;
  padding:3px 14px;
  background:rgba(255,255,255,0.04);
  border-radius:50px;
}
.theory-browser-viewport{
  position:relative;
  aspect-ratio:4/3;
  background:linear-gradient(135deg,rgba(255,255,255,0.04),rgba(255,255,255,0.01));
  overflow:hidden;
}
.theory-screenshot{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:top center;
  display:block;
  transition:transform .8s var(--ease);
}
.theory-screenshot--center{
  object-position:center center;
}
.theory-card:hover .theory-screenshot{
  transform:scale(1.03);
}
.theory-browser-overlay{
  position:absolute;
  inset:0;
  pointer-events:none;
  background:linear-gradient(180deg,transparent 60%,rgba(10,10,10,0.25));
}
.theory-meta{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:16px;
  padding:0 4px;
}
.theory-name{
  font-size:1.15rem;
  font-weight:500;
  letter-spacing:-.01em;
  color:var(--text);
  margin-bottom:4px;
}
.theory-desc{
  font-size:.8rem;
  color:var(--text-secondary);
  font-weight:400;
  line-height:1.5;
}
.theory-visit{
  display:inline-flex;
  align-items:center;
  gap:6px;
  font-size:.75rem;
  font-weight:500;
  color:var(--text-secondary);
  letter-spacing:.02em;
  white-space:nowrap;
  padding-top:4px;
  transition:color .3s var(--ease);
}
.theory-card:hover .theory-visit{
  color:var(--neon);
}

/* ═══════════════════════════════════════════════════════
   PERFORMANCE / IMPACT (full-bleed cinematic)
   ═══════════════════════════════════════════════════════ */
.perf{padding:120px 0}
.perf .full-bleed-video{opacity:1}
.perf .full-bleed-overlay{background:rgba(0,0,0,0.45)}
.perf .full-bleed-content{
  max-width:1100px;margin:0 auto;padding:0 40px;
}
.perf-label-top{
  text-align:center;
  font-size:.72rem;font-weight:500;
  letter-spacing:.1em;text-transform:uppercase;
  color:var(--text-tertiary);
  margin-bottom:48px;
}
.perf-grid{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:0;
}
.perf-item{
  text-align:center;padding:24px 0;
  border-right:1px solid var(--border);
  display:flex;flex-direction:column;align-items:center;
}
.perf-item:last-child{border-right:none}
.perf-ring{
  width:60px;height:60px;margin-bottom:16px;
  transform:rotate(-90deg);
}
.perf-ring-bg{
  fill:none;stroke:rgba(0,255,180,0.06);stroke-width:3;
}
.perf-ring-fill{
  fill:none;stroke:rgba(0,255,180,0.5);stroke-width:3;
  stroke-linecap:round;
}
.perf-num{
  font-size:clamp(2.4rem,4.5vw,3.8rem);
  font-weight:200;letter-spacing:-.03em;
  line-height:1;color:var(--text);
  font-variant-numeric:tabular-nums;
  font-feature-settings:"tnum";
  display:inline-block;
  min-width:2.5ch;
}
.perf-unit{
  font-size:clamp(1.2rem,2vw,1.8rem);
  font-weight:200;color:var(--text-secondary);margin-left:2px;
}
.perf-item-label{
  display:block;margin-top:8px;
  font-size:.68rem;font-weight:500;
  color:var(--text-tertiary);letter-spacing:.03em;
}

/* ═══════════════════════════════════════════════════════
   FAQ (open canvas, accent-left style)
   ═══════════════════════════════════════════════════════ */
.faq-section{padding:120px 0}
.faq-section .section-open{padding:80px 56px}
.faq-heading{
  text-align:center;
  font-size:clamp(1.3rem,2.5vw,2rem);
  font-weight:500;line-height:1.3;letter-spacing:-.01em;
  color:var(--text-secondary);
  margin-bottom:40px;
}
.faq-list{max-width:700px;margin:0 auto}
.faq-item{
  border-bottom:1px solid var(--border);
  border-left:2px solid transparent;
  padding-left:16px;
  transition:border-left-color .4s var(--ease);
}
.faq-item.open{
  border-left-color:rgba(0,255,170,0.55);
  box-shadow:-2px 0 12px -4px rgba(0,255,170,0.25);
}
.faq-q{
  width:100%;display:flex;align-items:center;justify-content:space-between;
  padding:22px 0;font-size:.92rem;font-weight:500;
  text-align:left;color:var(--text);gap:14px;
  transition:padding-left .3s var(--ease);
}
.faq-q:hover{padding-left:3px}
.faq-chevron{flex-shrink:0;transition:transform .35s var(--ease);color:var(--text-tertiary)}
.faq-item.open .faq-chevron{transform:rotate(180deg)}
.faq-a{
  max-height:0;overflow:hidden;
  transition:max-height .5s var(--ease),opacity .4s var(--ease);
  opacity:0;
}
.faq-item.open .faq-a{max-height:250px;opacity:1}
.faq-a p{padding:0 0 22px;font-size:.85rem;color:var(--text-secondary);line-height:1.6;font-weight:400}

/* ═══════════════════════════════════════════════════════
   CTA
   ═══════════════════════════════════════════════════════ */
.cta{
  min-height:80vh;
  display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,#14141c,#0a0a0a 60%,#1a1a22);
}
.cta .full-bleed-video{
  opacity:0;
  transition:opacity .8s var(--ease);
}
.cta .full-bleed-video.is-ready{
  opacity:1;
}
.cta-content{
  position:relative;z-index:2;
  text-align:center;padding:60px 40px;
  max-width:640px;
}
.cta-title{
  font-size:clamp(2rem,4.5vw,3.6rem);
  font-weight:600;line-height:1.05;letter-spacing:-.02em;
  margin-bottom:16px;
}
.cta-sub{
  font-size:clamp(.88rem,1.3vw,1.05rem);
  font-weight:400;color:var(--text-secondary);
  margin-bottom:28px;
}

/* ═══════════════════════════════════════════════════════
   FOOTER CTA.typography-first, Apple/Notion refined
   A single soft halo + a slow rotating arc behind the text.
   The motion lives in the wordmark itself, not in the backdrop.
   ═══════════════════════════════════════════════════════ */
.footer-cta-zone{
  position:relative;
  overflow:hidden;
  padding:0;
  isolation:isolate;
  background:#0a0a0a;
}

/* Static soft halo behind the wordmark. Pure atmosphere, no motion. */
.footer-cta-halo{
  position:absolute;
  left:50%;top:50%;
  width:min(1100px,95vw);
  height:min(1100px,95vw);
  max-width:1100px;max-height:1100px;
  border-radius:50%;
  background:radial-gradient(circle at 50% 50%,
    rgba(235,240,255,0.055) 0%,
    rgba(235,240,255,0.028) 20%,
    rgba(235,240,255,0.012) 40%,
    transparent 60%);
  transform:translate(-50%,-50%);
  pointer-events:none;
  z-index:0;
  filter:blur(20px);
}

/* Slow rotating arc. A single 60-degree stroke of a big thin ring.
   60s per rotation, barely perceptible unless you watch. Pure craft. */
.footer-cta-arc{
  position:absolute;
  left:50%;top:50%;
  width:min(920px,90vw);
  height:min(920px,90vw);
  max-width:920px;max-height:920px;
  transform:translate(-50%,-50%);
  pointer-events:none;
  z-index:1;
  opacity:.85;
  animation:ctaArcRotate 60s linear infinite;
}
@keyframes ctaArcRotate{
  from{transform:translate(-50%,-50%) rotate(0deg)}
  to  {transform:translate(-50%,-50%) rotate(360deg)}
}

@media (prefers-reduced-motion: reduce){
  .footer-cta-arc{animation:none}
}

.footer-cta-inner{
  position:relative;z-index:2;
  padding:160px 0 140px;
  text-align:center;
}

.footer-cta-title{
  display:flex;flex-direction:column;align-items:center;gap:10px;
  font-weight:600;line-height:.9;letter-spacing:-.03em;
}
.footer-cta-eyebrow{
  display:inline-block;
  font-size:clamp(.78rem,1.1vw,.95rem);
  font-weight:500;
  letter-spacing:.32em;
  text-transform:uppercase;
  color:var(--text-tertiary);
}

/* Wordmark: typography-first motion. Solid white letters with a very
   subtle text-shadow pulse. Apple-style restraint: the arc rotates
   behind, the word softly breathes. No background-clip gymnastics. */
.footer-cta-wordmark{
  position:relative;display:inline-flex;
  font-size:clamp(3.4rem,9.5vw,9rem);
  font-weight:600;
  letter-spacing:-.035em;
  line-height:.92;
  padding:0 .04em;
  color:var(--text);
  animation:ctaWordmarkBreathe 7s ease-in-out infinite;
}
@keyframes ctaWordmarkBreathe{
  0%,100%{text-shadow:0 0 0 transparent, 0 0 22px rgba(255,255,255,0.04)}
  50%    {text-shadow:0 0 0 transparent, 0 0 34px rgba(255,255,255,0.11)}
}
.footer-cta-letter{
  display:inline-block;
  opacity:0;
  transform:translateY(60%) rotateX(-55deg);
  transform-origin:50% 100%;
  color:inherit;
}
.footer-cta-wordmark.is-in .footer-cta-letter{
  animation:fortyLetterIn 1.1s cubic-bezier(.2,.75,.2,1) both;
  animation-delay:calc(var(--i) * 90ms + 120ms);
}
@keyframes fortyLetterIn{
  0%{opacity:0;transform:translateY(65%) rotateX(-60deg)}
  60%{opacity:1}
  100%{opacity:1;transform:translateY(0) rotateX(0)}
}

/* Clean thin rule under wordmark */
.footer-cta-rule{
  width:0;height:1px;
  margin:28px auto 0;
  background:linear-gradient(90deg,
    transparent 0%,
    rgba(255,255,255,0.25) 30%,
    rgba(255,255,255,0.4) 50%,
    rgba(255,255,255,0.25) 70%,
    transparent 100%);
  transition:width 1.4s cubic-bezier(.22,.75,.22,1) .9s;
}
.footer-cta-rule.is-in{
  width:min(280px, 60%);
}

@media (prefers-reduced-motion: reduce){
  .footer-cta-letter{opacity:1;transform:none;animation:none !important}
  .footer-cta-wordmark{animation:none !important;text-shadow:0 0 30px rgba(255,255,255,0.06)}
  .footer-cta-rule{width:min(280px, 60%);transition:none}
}

@media(max-width:768px){
  .footer-cta-inner{padding:110px 0 90px}
  .footer-cta-eyebrow{letter-spacing:.24em}
  .footer-cta-arc{opacity:.7}
}
@media(max-width:480px){
  .footer-cta-inner{padding:84px 0 70px}
  .footer-cta-arc{opacity:.55}
}

/* ═══════════════════════════════════════════════════════
   MOBILE TOUCH TARGETS + PERF HARDENING
   ═══════════════════════════════════════════════════════ */
@media(max-width:768px){
  /* Mobile nav: burger and logo should feel balanced. The pill's
     background + border + backdrop-filter make the burger container
     visually dominate a transparent-backdrop logo. Strip the pill
     chrome on mobile; the burger icon stands on its own, same
     presence as the logo. Tap target stays 44x44 via padding. */
  .nav-pill{
    top:16px;right:18px;
    padding:0;
    background:transparent;
    border-color:transparent;
    backdrop-filter:none;
    -webkit-backdrop-filter:none;
  }
  .nav-pill.scrolled{
    background:transparent;
    border-color:transparent;
  }
  .nav-burger{
    min-width:44px;min-height:44px;
    padding:15px 12px;gap:4px;
    justify-content:center;align-items:center;
  }
  .nav-burger span{width:20px;height:1.5px}

  .btn{
    min-height:44px;
    padding:13px 26px;
    font-size:.9rem;
  }
  .hero-ctas .btn{width:100%;justify-content:center}

  .menu-link{font-size:1.6rem;padding:6px 12px}
  .menu-link--cta{min-height:44px;display:inline-flex;align-items:center}

  /* Faq question rows: ensure comfortable tap height */
  .faq-q{padding:20px 4px;min-height:56px}

  /* Case study toggle */
  .case-study-toggle{min-height:40px;padding:10px 18px}

  /* Prevent horizontal overflow from wide elements */
  html,body{overflow-x:hidden;max-width:100vw}
  /* Only responsive-size images inside content; leave background videos
     (hero, full-bleed) alone so they keep object-fit:cover at full res. */
  img{max-width:100%;height:auto}

  /* Help browsers prioritize scroll + tap latency */
  .reel,.brands,.faq-list,.svc-bento{touch-action:pan-y}

  /* Reduce heavy backdrop blurs on mobile (cheap fallbacks) */
  .nav-pill{
    backdrop-filter:blur(14px) saturate(140%);
    -webkit-backdrop-filter:blur(14px) saturate(140%);
  }
  .menu-overlay{
    backdrop-filter:blur(18px);
    -webkit-backdrop-filter:blur(18px);
  }
  .btn--glass{
    backdrop-filter:blur(8px);
    -webkit-backdrop-filter:blur(8px);
  }

  /* Dampen the body::before aurora on mobile (heavy to composite) */
  body::before{
    animation:none;
    opacity:.7;
  }
}

@media(max-width:480px){
  .btn{padding:13px 22px}
  .nav-burger{min-width:44px;min-height:44px;padding:15px 12px}
  .menu-link{font-size:1.4rem}
}

/* ═══════════════════════════════════════════════════════
   FOOTER
   ═══════════════════════════════════════════════════════ */
.footer{padding:20px 0;border-top:1px solid var(--border)}
.footer-inner{
  display:flex;align-items:center;justify-content:space-between;
  max-width:1200px;margin:0 auto;padding:0 40px;
  gap:24px;
}
.footer-left{display:flex;align-items:center;gap:12px}
.footer-logo-img{
  width:24px;height:24px;object-fit:contain;
  filter:brightness(0) invert(1);
}
.footer-brand-name{font-size:.9rem;font-weight:600;letter-spacing:-.02em}
.footer-links{display:flex;align-items:center;gap:24px}
.footer-link{font-size:.78rem;color:var(--text-secondary);transition:color .2s;font-weight:400}
.footer-link:hover{color:var(--text)}
.footer-copy{font-size:.65rem;color:var(--text-tertiary);font-weight:400}

/* Legal: concept-work disclaimer + trademark attribution.
   Small, tertiary, readable but quiet. Own row under the
   main footer line. */
.footer-legal{
  max-width:1200px;
  margin:20px auto 0;
  padding:20px 40px 4px;
  border-top:1px solid rgba(255,255,255,0.04);
}
.footer-legal p{
  font-size:.62rem;
  line-height:1.65;
  color:rgba(255,255,255,0.28);
  font-weight:400;
  letter-spacing:.005em;
}
.footer-legal p + p{
  margin-top:10px;
}
.footer-legal strong{
  color:rgba(255,255,255,0.48);
  font-weight:500;
}
.footer-legal .footer-link{
  font-size:.62rem;
  color:rgba(255,255,255,0.38);
  text-decoration:underline;
  text-decoration-color:rgba(255,255,255,0.18);
  text-underline-offset:2px;
}
.footer-legal .footer-link:hover{
  color:rgba(255,255,255,0.7);
  text-decoration-color:rgba(255,255,255,0.4);
}
@media(max-width:768px){
  .footer-legal{padding:18px 22px 4px}
  .footer-legal p{font-size:.58rem;line-height:1.6}
}

/* ═══════════════════════════════════════════════════════
   CASE STUDIES
   ═══════════════════════════════════════════════════════ */
.case-study{
  border-radius:22px;
  border:1px solid rgba(255,255,255,0.06);
  background:rgba(255,255,255,0.02);
  overflow:hidden;
  transition:border-color .4s var(--ease);
}
.case-study:hover{
  border-color:rgba(255,255,255,0.1);
}
.case-study-header{
  display:grid;
  grid-template-columns:1.2fr 1fr;
  align-items:stretch;
}
.case-study-img{
  position:relative;
  overflow:hidden;
  aspect-ratio:16/10;
  background:rgba(255,255,255,0.02);
}
.case-study-media{
  display:block;
  width:100%;height:100%;
  object-fit:cover;
  transition:transform .7s var(--ease);
}
.case-study:hover .case-study-media{
  transform:scale(1.04);
}
.case-study:hover .mashreq-zoom{
  transform:scale(1.3);
}
.case-study-intro{
  display:flex;flex-direction:column;justify-content:center;
  padding:36px 36px 32px;
}
.case-study-name{
  font-size:clamp(1.5rem,2.8vw,2.2rem);
  font-weight:600;line-height:1.1;letter-spacing:-.02em;
  color:var(--text);
  margin-bottom:10px;
}
.case-study-tagline{
  font-size:.88rem;color:var(--text-secondary);
  font-weight:400;line-height:1.55;
  margin-bottom:16px;
}
.case-study-stats-row{
  display:flex;flex-wrap:wrap;gap:8px;
  margin-bottom:20px;
}
.case-study-toggle{
  display:inline-flex;align-items:center;gap:8px;
  align-self:flex-start;
  padding:8px 18px;
  font-size:.78rem;font-weight:500;
  color:var(--text-secondary);
  background:rgba(255,255,255,0.04);
  border:1px solid rgba(255,255,255,0.08);
  border-radius:50px;
  cursor:pointer;
  transition:all .3s var(--ease);
  letter-spacing:.02em;
}
.case-study-toggle:hover{
  background:rgba(255,255,255,0.08);
  color:var(--text);
}
.case-study-chevron{
  flex-shrink:0;
  transition:transform .35s var(--ease);
  color:var(--text-tertiary);
}
.case-study.open .case-study-chevron{
  transform:rotate(180deg);
}
.case-study-details{
  max-height:0;overflow:hidden;
  transition:max-height 1s cubic-bezier(.22,.61,.36,1),opacity .8s cubic-bezier(.22,.61,.36,1);
  opacity:0;
}
.case-study.open .case-study-details{
  max-height:2400px;
  opacity:1;
  transition:max-height 1.2s cubic-bezier(.22,.61,.36,1),opacity 1s cubic-bezier(.22,.61,.36,1) .15s;
}

/* Impact hero panel inside expanded case study */
.case-study-impact{
  padding:56px 36px 48px;
  border-top:1px solid rgba(255,255,255,0.06);
  background:linear-gradient(180deg,rgba(0,255,160,0.05),transparent 80%);
  text-align:center;
}
.case-study-impact-label{
  display:inline-block;
  font-size:.68rem;
  font-weight:600;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--neon);
  margin-bottom:32px;
  padding:6px 16px;
  border:1px solid rgba(0,255,160,0.2);
  border-radius:50px;
  background:rgba(0,255,160,0.04);
}
.case-study-impact-row{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:48px;
  max-width:900px;
  margin:0 auto;
}
.case-study-impact-item{
  display:flex;flex-direction:column;align-items:center;gap:14px;
}
.case-study-impact-num{
  font-size:clamp(3.2rem,7vw,6rem);
  font-weight:200;
  letter-spacing:-.04em;
  line-height:.9;
  background:linear-gradient(180deg,#ffffff 0%,rgba(255,255,255,0.45) 100%);
  -webkit-background-clip:text;
  background-clip:text;
  -webkit-text-fill-color:transparent;
  color:transparent;
  font-variant-numeric:tabular-nums;
  font-feature-settings:"tnum";
  min-width:4ch;
  display:inline-block;
}
.case-study-impact-desc{
  font-size:.7rem;
  font-weight:500;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--text-tertiary);
}
.case-study-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
  padding:0 36px 36px;
  border-top:1px solid var(--border);
  margin-top:0;
  padding-top:32px;
}
.case-study-block{
  padding:24px;
  border-radius:16px;
  background:rgba(255,255,255,0.02);
  border:1px solid rgba(255,255,255,0.04);
}
.case-study-block-title{
  font-size:.75rem;font-weight:600;
  letter-spacing:.08em;text-transform:uppercase;
  color:var(--neon);
  margin-bottom:14px;
}
.case-study-block p{
  font-size:.84rem;color:var(--text-secondary);
  line-height:1.65;font-weight:400;
  margin-bottom:10px;
}
.case-study-block p:last-child{margin-bottom:0}
.case-study-block ul{
  list-style:none;padding:0;margin:8px 0;
}
.case-study-block ul li{
  font-size:.82rem;color:var(--text-secondary);
  line-height:1.6;font-weight:400;
  padding-left:16px;position:relative;
  margin-bottom:8px;
}
.case-study-block ul li::before{
  content:'';position:absolute;left:0;top:8px;
  width:5px;height:5px;border-radius:50%;
  background:rgba(0,255,160,0.4);
}
.case-study-block ul li:last-child{margin-bottom:0}
.case-study-block ul li strong{
  color:var(--text);font-weight:500;
}
.case-study-results li{
  padding:10px 10px 10px 20px;
  margin-bottom:6px;
  border-left:2px solid rgba(0,255,160,0.25);
  border-radius:0 8px 8px 0;
  background:rgba(0,255,160,0.02);
}
.case-study-results li::before{
  display:none;
}
.case-study-results li strong{
  color:var(--neon);font-weight:600;
}

/* ═══════════════════════════════════════════════════════
   BRANDS (carousel)
   ═══════════════════════════════════════════════════════ */
.brands{padding:60px 0 40px;position:relative;overflow:hidden}
.brands .brands-header{
  text-align:center;margin-bottom:48px;
  padding:0 40px;
}
.brands-heading{
  font-size:clamp(1.3rem,2.5vw,2rem);
  font-weight:500;line-height:1.3;letter-spacing:-.01em;
  color:var(--text-secondary);
  margin-top:8px;
}
.brands-carousel{
  overflow:hidden;
  position:relative;
  mask-image:linear-gradient(90deg,transparent,black 8%,black 92%,transparent);
  -webkit-mask-image:linear-gradient(90deg,transparent,black 8%,black 92%,transparent);
}
.brands-track{
  display:flex;gap:16px;
  will-change:transform;
}
.brands-tile{
  flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  padding:20px 40px;
  min-width:200px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,0.06);
  background:rgba(255,255,255,0.025);
  transition:border-color .4s var(--ease);
}
.brands-tile:hover{
  border-color:rgba(255,255,255,0.12);
}
.brands-tile-name{
  font-size:.88rem;font-weight:500;
  color:var(--text-secondary);
  letter-spacing:.01em;
  white-space:nowrap;
}
.brands-logo{
  width:180px;height:60px;
  object-fit:contain;
  opacity:0.7;
  transition:opacity .3s var(--ease);
}
.brands-tile:hover .brands-logo{
  opacity:1;
}

/* ═══════════════════════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════════════════════ */
@media(max-width:960px){
  .svc-bento{grid-template-columns:repeat(6,1fr)}
  .svc-tile,.svc-tile--wide,.svc-tile--tall{grid-column:span 6;min-height:auto}
  .services{padding:80px 0}
  .perf-grid{grid-template-columns:repeat(2,1fr)}
  .perf-item:nth-child(2){border-right:none}
  .perf-item:nth-child(3),.perf-item:nth-child(4){border-top:1px solid var(--border)}
  .story{padding:80px 0 60px}
  .story-fcard{padding:36px 32px 32px}
  .story-fcard-ordinal{top:28px;right:32px;font-size:1.9rem}
  .story-fcard-name{font-size:clamp(1.7rem,3.2vw,2.3rem)}
  .method-rail{margin:20px auto 72px;padding:32px 20px 20px}
  .method-rail-line{left:60px;right:60px}
  .process{padding:80px 0}
  .process-intro{margin-bottom:48px}
  .process-big-heading{font-size:clamp(1.9rem,4.5vw,3rem)}
  .case-study-impact-row{gap:32px}
  .work-project{grid-template-columns:1fr 1fr;gap:32px}
  .work-showcase{gap:40px}
  .case-study-header{grid-template-columns:1fr 1fr;gap:0}
  .case-study-grid{grid-template-columns:1fr 1fr 1fr;gap:20px;padding:0 28px 28px;padding-top:24px}
  .brands-track{animation-duration:30s}
  .theory{padding:80px 0}
  .theory-grid{grid-template-columns:1fr 1fr;gap:20px}
}

@media(max-width:768px){
  .full-bleed{width:calc(100% - 32px);margin-left:16px;margin-right:16px;border-radius:18px}
  .full-bleed::before{border-radius:18px}
  .container{padding:0 22px}
  .section-open{padding:48px 22px}
  .about .full-bleed-content,
  .perf .full-bleed-content{padding:0 22px}
  .about{padding:60px 0}
  .story{padding:60px 0 40px}
  .story-container{padding:0 22px}
  /* Stack founder cards vertically on phone */
  .story-founders{grid-template-columns:1fr}
  .story-fcard{padding:40px 26px 36px}
  .story-fcard + .story-fcard{
    border-left:none;
    border-top:1px solid rgba(255,255,255,0.08);
  }
  .story-fcard-ordinal{top:24px;right:26px;font-size:1.8rem}
  .story-fcard-name{font-size:clamp(1.9rem,7vw,2.4rem)}
  .perf{padding:60px 0}
  .work{padding:50px 16px}
  .work-project{grid-template-columns:1fr;gap:20px}
  .work-project:nth-child(even){direction:ltr}
  .work-showcase{gap:36px}
  .case-study-header{grid-template-columns:1fr}
  .case-study-intro{padding:24px 22px 20px}
  .case-study-grid{grid-template-columns:1fr;gap:20px;padding:0 22px 24px;padding-top:20px}
  .case-study-name{font-size:1.3rem}
  .brands .brands-header{padding:0 22px}
  .brands{padding:40px 0 30px}
  .case-study-block{padding:20px}
  .hero-content{padding:80px 22px 22px}
  .hero-title{font-size:clamp(2rem,8vw,3rem)}
  .hero-ctas{flex-direction:column;gap:10px}
  .about-stats{flex-wrap:wrap;gap:16px}
  .about-stat{padding:0 24px}
  .about-stat-divider{display:none}
  .reel{padding:50px 0}
  .reel-track img,.reel-track video{height:240px}
  .services{padding:60px 0}
  .process{padding:60px 0}
  .process-intro{margin-bottom:32px}
  .process-big-heading{font-size:clamp(1.8rem,8vw,2.6rem)}
  /* Mobile method rail: stacks vertically with a left-side vertical rail */
  .method-rail{margin:14px auto 48px;padding:20px 12px 0}
  .method-rail-line{
    left:22px;right:auto;
    top:32px;bottom:22px;
    width:1px;height:auto;
    background:linear-gradient(180deg,
      rgba(0,255,160,0) 0%,
      rgba(0,255,160,0.35) 10%,
      rgba(80,180,255,0.35) 90%,
      rgba(80,180,255,0) 100%);
  }
  .method-rail-line-fill{
    background:linear-gradient(180deg,
      rgba(0,255,160,0.9) 0%,
      rgba(80,180,255,0.9) 100%);
    transform:scaleY(0);
    transform-origin:top center;
  }
  .method-rail.is-in .method-rail-line-fill{transform:scaleY(1)}
  .method-steps{
    grid-template-columns:1fr;
    gap:18px;
  }
  .method-step{
    flex-direction:row;
    align-items:center;
    justify-content:flex-start;
    gap:16px;
    padding:6px 0 6px 8px;
    text-align:left;
  }
  .method-step-num{margin-top:0;min-width:26px}
  .method-step-name{font-size:1.08rem}
  .method-step-verb{margin-left:auto;padding-right:8px}
  .case-study-impact{padding:40px 22px 32px}
  .case-study-impact-row{grid-template-columns:1fr;gap:32px}
  .case-study-impact-num{font-size:clamp(2.6rem,12vw,4rem)}
  .footer-inner{flex-direction:column;gap:12px;text-align:center}
  .footer-links{flex-wrap:wrap;justify-content:center}
  .nav-logo-fixed{top:14px;left:18px}
  .nav-logo-img{width:48px;height:48px}
  .services-inner{padding:0 22px}
  .svc-bento{grid-template-columns:1fr}
  .svc-tile,.svc-tile--wide,.svc-tile--tall{grid-column:1 / -1;min-height:auto}
  .perf-grid{grid-template-columns:repeat(2,1fr)}
  .work-project-name{font-size:1.3rem}
  .process-inner{padding:0 22px}
  .perf-ring{width:48px;height:48px}
  .faq-item{padding-left:12px}
  /* Speed up brands carousel on mobile */
  .brands-track{animation-duration:22s}
  .brands-tile{min-width:170px;padding:18px 32px}
  .theory{padding:60px 0}
  .theory-inner{padding:0 22px}
  .theory-header{margin-bottom:40px}
  .theory-grid{grid-template-columns:1fr;gap:28px}
}

@media(max-width:480px){
  .full-bleed{width:calc(100% - 24px);margin-left:12px;margin-right:12px;border-radius:14px}
  .full-bleed::before{border-radius:14px}
  .container{padding:0 16px}
  .section-open{padding:36px 16px}
  .work{padding:40px 12px}
  .work-showcase{gap:28px}
  .work-project-name{font-size:1.15rem}
  .case-study-intro{padding:20px 16px 16px}
  .case-study-grid{padding:0 16px 20px;padding-top:16px;gap:16px}
  .case-study-name{font-size:1.15rem}
  .brands .brands-header{padding:0 16px}
  .brands-tile{min-width:150px;padding:14px 26px}
  .brands-tile-name{font-size:.76rem}
  .brands-logo{width:140px;height:48px}
  .case-study-block{padding:16px}
  .nav-logo-fixed{top:12px;left:14px}
  .nav-logo-img{width:40px;height:40px}
  /* Align burger vertical center with the 40px logo center (y=32) */
  .nav-pill{top:10px;right:14px;padding:0}
  .perf-grid{grid-template-columns:1fr 1fr}
  .services-inner{padding:0 16px}
  .svc-tile-info{padding:0 20px 20px}
  .svc-tile-visual{padding:24px 20px 12px}
  .story-container{padding:0 16px}
  .story-heading{font-size:1.5rem}
  .story-fcard{padding:34px 20px 30px}
  .story-fcard-ordinal{top:22px;right:20px;font-size:1.6rem}
  .story-fcard-name{font-size:clamp(1.7rem,8vw,2.1rem)}
  .story-fcard-role{font-size:.6rem;margin:12px 0 22px}
  .story-fcard-bio{font-size:.86rem;line-height:1.55;margin-bottom:24px}
  .process-inner{padding:0 16px}
  .process-card{padding:24px 20px;min-height:200px}
  .perf-ring{width:40px;height:40px}
  .faq-item{padding-left:10px}
  /* Further speed up on small mobile */
  .brands-track{animation-duration:18s}
}
