/* ═══════════════════════════════════════════════════════════════
   CULTIVATE COLLECTIVE · Design System  ·  MONO RESTRAINT
   Ink + Paper + Meridian Blue. Blue whispers.
   Light interior pages (default) · Dark home (body.home)
═══════════════════════════════════════════════════════════════ */

:root{
  /* LIGHT (interior pages, default) */
  --bg:        #F5F6F8;   /* apple gray page */
  --bg-2:      #FFFFFF;
  --card:      #FFFFFF;
  --line:      #E4E9EF;
  --line-soft: #EDF1F5;

  --ink:       #0C1722;   /* near-black text */
  --ink-2:     #33424F;
  --ink-mut:   #647483;
  --ink-dim:   #93A1AD;

  --blue:      #0096C7;   /* the one accent */
  --blue-ink:  #0A7AA6;   /* blue text on white (AA) */
  --blue-wash: #EAF6FB;

  --nav-bg:    #02080E;   /* dark nav bar, always */
  --dark:      #02080E;

  --font-disp: 'Bebas Neue', Impact, sans-serif;
  --font-ui:   'Space Grotesk', sans-serif;
  --font-mono: 'JetBrains Mono', monospace;
  --font-body: 'Inter', sans-serif;

  --ease: cubic-bezier(.16,1,.3,1);
  --maxw: 1320px;
  --pad: 52px;

  --shadow:      0 1px 2px rgba(12,23,34,.04), 0 8px 24px rgba(12,23,34,.06);
  --shadow-lift: 0 2px 4px rgba(12,23,34,.05), 0 18px 44px rgba(12,23,34,.12);

  --on-blue:   #FFFFFF;
}

/* DARK theme (home) */
body.home{
  --bg:        #02080E;
  --bg-2:      #061320;
  --card:      #0A1620;
  --line:      #0F2438;
  --line-soft: rgba(15,36,56,.6);
  --ink:       #E5F0F8;
  --ink-2:     #C3D2DE;
  --ink-mut:   rgba(229,240,248,.5);
  --ink-dim:   rgba(229,240,248,.34);
  --blue-ink:  #2BB6DE;   /* brighter blue text on dark */
  --blue-wash: rgba(0,150,199,.12);
  --shadow:      none;
  --shadow-lift: none;
}

/* ── RESET ───────────────────────────────────────────────────── */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
html{font-size:16px;scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{
  background:var(--bg);color:var(--ink);
  font-family:var(--font-body);line-height:1.6;overflow-x:hidden;
  -webkit-font-smoothing:antialiased;transition:background .3s;
}
a{text-decoration:none;color:inherit;}
img,video{display:block;max-width:100%;}
ul{list-style:none;}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit;}
::selection{background:var(--blue);color:#fff;}

/* ── UTILITY ─────────────────────────────────────────────────── */
.wrap{max-width:var(--maxw);margin:0 auto;}
.eyebrow{
  font-family:var(--font-mono);font-size:11px;font-weight:500;
  letter-spacing:.24em;text-transform:uppercase;color:var(--blue-ink);
  display:inline-flex;align-items:center;gap:10px;
}
.eyebrow .dot{width:5px;height:5px;border-radius:50%;background:var(--blue);flex-shrink:0;animation:blink 2.6s ease-in-out infinite;}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.2}}
.eyebrow .sep{opacity:.35;color:var(--ink-dim);}

.section-label{
  font-family:var(--font-mono);font-size:11px;font-weight:500;
  letter-spacing:.22em;text-transform:uppercase;color:var(--ink-dim);
  margin-bottom:40px;display:flex;align-items:center;gap:10px;
}
.section-label b{color:var(--blue-ink);font-weight:500;}

/* ── BUTTONS ─────────────────────────────────────────────────── */
.btn-primary{
  font-family:var(--font-mono);font-size:10px;font-weight:500;
  letter-spacing:.14em;text-transform:uppercase;
  padding:14px 34px;background:var(--blue);color:#fff;border-radius:6px;
  display:inline-block;transition:filter .2s,transform .15s,box-shadow .2s;
}
.btn-primary:hover{filter:brightness(1.08);transform:translateY(-1px);box-shadow:0 8px 22px rgba(0,150,199,.28);}
.btn-ghost{
  font-family:var(--font-mono);font-size:10px;font-weight:500;
  letter-spacing:.14em;text-transform:uppercase;
  padding:13px 34px;border:1px solid var(--line);color:var(--ink-mut);border-radius:6px;
  display:inline-block;transition:all .2s;
}
.btn-ghost:hover{border-color:var(--blue);color:var(--blue-ink);}
.btn-row{display:flex;gap:12px;flex-wrap:wrap;align-items:center;}

/* ── NAV (dark bar) ──────────────────────────────────────────── */
.nav{
  position:sticky;top:0;z-index:200;
  display:flex;align-items:center;justify-content:space-between;
  height:64px;padding:0 var(--pad);
  background:var(--nav-bg);border-bottom:1px solid rgba(255,255,255,.06);
  transition:background .3s;
}
.nav-logo{display:flex;align-items:center;flex-shrink:0;}
.nav-logo img{height:21px;width:auto;display:block;}
.nav-links{display:flex;gap:32px;}
.nav-links a{
  font-family:var(--font-ui);font-size:11px;font-weight:500;
  letter-spacing:.15em;text-transform:uppercase;color:rgba(255,255,255,.5);
  transition:color .2s;position:relative;padding:4px 0;
}
.nav-links a:hover{color:#fff;}
.nav-links a.active{color:#fff;}
.nav-links a.active::after{content:'';position:absolute;bottom:-2px;left:0;right:0;height:1px;background:var(--blue);}
.nav-cta{
  font-family:var(--font-mono);font-size:10px;letter-spacing:.12em;
  text-transform:uppercase;padding:9px 20px;background:var(--blue);color:#fff;
  border-radius:6px;transition:filter .2s;flex-shrink:0;
}
.nav-cta:hover{filter:brightness(1.1);}

/* HOME: transparent nav over video */
body.home .nav{
  position:sticky;background:rgba(2,8,14,.4);backdrop-filter:blur(16px);
  border-bottom:1px solid rgba(255,255,255,.06);
}
body.home .nav.scrolled{background:rgba(2,8,14,.9);}

/* mobile nav */
.nav-toggle{display:none;width:26px;height:18px;position:relative;flex-shrink:0;}
.nav-toggle span{position:absolute;left:0;right:0;height:1.5px;background:#fff;transition:.3s;}
.nav-toggle span:nth-child(1){top:0;}
.nav-toggle span:nth-child(2){top:8px;}
.nav-toggle span:nth-child(3){top:16px;}
.nav-toggle.open span:nth-child(1){top:8px;transform:rotate(45deg);}
.nav-toggle.open span:nth-child(2){opacity:0;}
.nav-toggle.open span:nth-child(3){top:8px;transform:rotate(-45deg);}
.mobile-menu{
  position:fixed;inset:0;z-index:190;background:rgba(2,8,14,.98);backdrop-filter:blur(20px);
  display:flex;flex-direction:column;justify-content:center;align-items:center;gap:6px;
  opacity:0;pointer-events:none;transition:opacity .35s;
}
.mobile-menu.open{opacity:1;pointer-events:auto;}
.mobile-menu a{font-family:var(--font-disp);font-size:42px;letter-spacing:.04em;color:rgba(255,255,255,.55);transition:color .2s;}
.mobile-menu a:hover,.mobile-menu a.active{color:#fff;}

/* ── HOME HERO (dark, video + rig) ───────────────────────────── */
#vid-wrap{position:fixed;inset:0;z-index:0;overflow:hidden;pointer-events:none;}
#vid-wrap video{width:100%;height:100%;object-fit:cover;object-position:center;opacity:.9;}
#vid-overlay{
  position:fixed;inset:0;z-index:0;pointer-events:none;
  background:
    linear-gradient(90deg,rgba(2,8,14,.86) 0%,rgba(2,8,14,.55) 46%,rgba(2,8,14,.18) 80%,rgba(2,8,14,.05) 100%),
    linear-gradient(0deg,rgba(2,8,14,.94) 0%,rgba(2,8,14,.5) 30%,rgba(2,8,14,.08) 56%,transparent 100%),
    linear-gradient(180deg,rgba(2,8,14,.6) 0%,transparent 26%);
}
#rig{position:fixed;top:0;left:0;width:100vw;height:100vh;z-index:1;pointer-events:none;}
.site{position:relative;z-index:2;}

.hero-home{
  min-height:calc(100vh - 64px);padding:0 var(--pad) 64px;
  display:flex;flex-direction:column;justify-content:flex-end;
  border-bottom:1px solid var(--line);position:relative;
}
.hero-home .eyebrow{margin-bottom:26px;}
/* hero sits over the dark video → force light content regardless of page theme */
.hero-home .eyebrow{color:#2BB6DE;}
.hero-home .eyebrow .sep{color:rgba(255,255,255,.4);}
.hero-home .hero-h1{color:#fff;}
.hero-home .hero-sub{color:rgba(255,255,255,.64);}
.hero-home .hero-caps{color:rgba(255,255,255,.42);}
.hero-home .hero-caps span{border-right-color:rgba(255,255,255,.14);}
.hero-home .btn-ghost{border-color:rgba(255,255,255,.28);color:rgba(255,255,255,.8);}
.hero-home .btn-ghost:hover{border-color:#fff;color:#fff;}
.hero-h1{
  font-family:var(--font-disp);font-size:clamp(44px,6.4vw,98px);
  line-height:.9;letter-spacing:.015em;color:var(--ink);margin-bottom:26px;max-width:20ch;
}
.hero-bottom{display:grid;grid-template-columns:1fr auto;gap:48px;align-items:flex-end;}
.hero-sub{font-family:var(--font-body);font-size:14px;line-height:1.82;color:var(--ink-mut);max-width:48ch;}
.hero-right{display:flex;flex-direction:column;align-items:flex-end;gap:18px;}
.hero-caps{display:flex;font-family:var(--font-mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-dim);}
.hero-caps span{padding:0 12px;border-right:1px solid var(--line);}
.hero-caps span:first-child{padding-left:0;}
.hero-caps span:last-child{border-right:none;}
.vid-tag{position:absolute;bottom:78px;right:var(--pad);text-align:right;z-index:2;}
.vid-tag .vn{font-family:var(--font-disp);font-size:20px;letter-spacing:.08em;color:var(--ink-mut);}
.vid-tag .vt{font-family:var(--font-mono);font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:var(--blue-ink);margin-top:3px;}

/* ── INTERIOR PAGE HERO (light) ──────────────────────────────── */
.hero-page{
  position:relative;padding:72px var(--pad) 44px;border-bottom:1px solid var(--line);
  background:var(--bg);overflow:hidden;
}
.hero-page .wrap{position:relative;z-index:1;}
.hero-page .eyebrow{margin-bottom:18px;}
.hero-page h1{
  font-family:var(--font-disp);font-size:clamp(50px,8vw,116px);
  line-height:.88;letter-spacing:.012em;color:var(--ink);max-width:16ch;
}
.hero-page .lead{font-family:var(--font-body);font-size:15px;line-height:1.78;color:var(--ink-mut);max-width:62ch;margin-top:24px;}

/* ── CREDITS STRIP ───────────────────────────────────────────── */
.credits{
  background:var(--nav-bg);padding:14px 0;overflow:hidden;position:relative;z-index:2;
  border-top:1px solid rgba(255,255,255,.05);border-bottom:1px solid rgba(255,255,255,.05);
}
.credits-track{display:flex;width:max-content;animation:scroll-x 55s linear infinite;}
.credits-track:hover{animation-play-state:paused;}
.credits .cl{font-family:var(--font-mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:rgba(43,182,222,.6);padding:0 22px;white-space:nowrap;}
.credits .cn{font-family:var(--font-disp);font-size:18px;letter-spacing:.1em;color:rgba(255,255,255,.55);padding:0 14px;white-space:nowrap;}
.credits .cd{color:rgba(0,150,199,.5);padding:0 4px;}
@keyframes scroll-x{from{transform:translateX(0);}to{transform:translateX(-50%);}}

/* ── STATS ───────────────────────────────────────────────────── */
.stats{display:grid;grid-template-columns:repeat(4,1fr);background:var(--bg-2);border-bottom:1px solid var(--line);position:relative;z-index:2;}
body.home .stats{background:rgba(2,8,14,.92);backdrop-filter:blur(12px);}
.stat{padding:30px 0 30px var(--pad);border-right:1px solid var(--line);transition:background .2s;}
.stat:last-child{border-right:none;}
.stat:hover{background:var(--blue-wash);}
.stat-n{font-family:var(--font-mono);font-size:clamp(28px,3.4vw,42px);font-weight:500;line-height:1;color:var(--blue-ink);margin-bottom:6px;}
.stat-l{font-family:var(--font-ui);font-size:11px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-dim);}

/* ── MARQUEE ─────────────────────────────────────────────────── */
.marquee{overflow:hidden;padding:13px 0;background:var(--bg-2);border-bottom:1px solid var(--line);position:relative;z-index:2;}
body.home .marquee{background:rgba(6,18,28,.85);}
.marquee-track{display:flex;width:max-content;animation:scroll-x 58s linear infinite;}
.marquee-track:hover{animation-play-state:paused;}
.marquee-track span{font-family:var(--font-mono);font-size:10px;letter-spacing:.26em;text-transform:uppercase;padding:0 20px;color:var(--ink-dim);}
.marquee-track .s{color:var(--blue-ink);opacity:.7;}

/* ── SECTIONS ────────────────────────────────────────────────── */
.section{padding:92px var(--pad);position:relative;z-index:2;background:var(--bg);border-bottom:1px solid var(--line);}
.section.alt{background:var(--bg-2);}
body.home .section.alt{background:var(--bg-2);}

.statement-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:80px;align-items:start;}
.statement-h{font-family:var(--font-disp);font-size:clamp(40px,5vw,68px);line-height:.92;letter-spacing:.01em;color:var(--ink);}
.statement-h em{color:var(--blue-ink);font-style:normal;}
.statement-b{font-family:var(--font-body);font-size:14px;line-height:1.9;color:var(--ink-mut);}
.statement-b strong{font-family:var(--font-ui);font-weight:600;color:var(--ink);}
.statement-b p+p{margin-top:18px;}

/* ── GRID UTILITY ────────────────────────────────────────────── */
.grid{display:grid;gap:18px;}
.grid.cols-4{grid-template-columns:repeat(4,1fr);}
.grid.cols-3{grid-template-columns:repeat(3,1fr);}
.grid.cols-2{grid-template-columns:repeat(2,1fr);}
@media(max-width:1024px){.grid.cols-4,.grid.cols-3{grid-template-columns:repeat(2,1fr);}}
@media(max-width:760px){.grid.cols-4,.grid.cols-3,.grid.cols-2{grid-template-columns:1fr;}}

/* ── SERVICES · REFINED PILLARS ──────────────────────────────── */
.pillars{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;}
.pillar{
  background:var(--card);border:1px solid var(--line);border-radius:14px;
  padding:30px 26px 26px;display:flex;flex-direction:column;
  box-shadow:var(--shadow);transition:transform .35s var(--ease),box-shadow .35s var(--ease),border-color .35s;
}
body.home .pillar{box-shadow:none;}
.pillar:hover{transform:translateY(-4px);box-shadow:var(--shadow-lift);border-color:var(--blue);}
.pillar-ico{width:42px;height:42px;border-radius:10px;background:var(--blue-wash);display:flex;align-items:center;justify-content:center;color:var(--blue-ink);margin-bottom:22px;transition:background .3s,color .3s;}
.pillar:hover .pillar-ico{background:var(--blue);color:#fff;}
.pillar-ico svg{width:21px;height:21px;}
.pillar-name{font-family:var(--font-ui);font-size:16px;font-weight:700;letter-spacing:-.01em;color:var(--ink);margin-bottom:10px;line-height:1.2;}
.pillar-desc{font-family:var(--font-body);font-size:12.5px;line-height:1.65;color:var(--ink-mut);margin-bottom:20px;flex:1;}
.pillar-caps{display:flex;flex-direction:column;border-top:1px solid var(--line-soft);}
.pillar-caps li{font-family:var(--font-ui);font-size:12px;font-weight:500;color:var(--ink-2);padding:9px 0;border-bottom:1px solid var(--line-soft);display:flex;align-items:center;gap:9px;}
.pillar-caps li:last-child{border-bottom:none;}
.pillar-caps li::before{content:'';width:5px;height:5px;border-radius:50%;background:var(--blue);flex-shrink:0;}

/* ── PIPELINE ────────────────────────────────────────────────── */
.pipeline{display:grid;grid-template-columns:repeat(6,1fr);border-top:1px solid var(--line);border-bottom:1px solid var(--line);position:relative;z-index:2;background:var(--bg);}
.pipe-step{padding:26px 28px;border-right:1px solid var(--line);transition:background .2s;}
.pipe-step:last-child{border-right:none;}
.pipe-step:hover{background:var(--blue-wash);}
.pipe-n{font-family:var(--font-mono);font-size:10px;font-weight:500;letter-spacing:.2em;color:var(--blue-ink);opacity:.7;margin-bottom:8px;}
.pipe-l{font-family:var(--font-ui);font-size:12px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--ink);}

/* ── IMAGE / PHOTO PLACEHOLDERS (mono-blue) ──────────────────── */
.ph{background:#0a1622;position:relative;overflow:hidden;display:flex;align-items:flex-end;}
.ph::before{content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 80% 60% at 50% 85%,rgba(0,150,199,.5),transparent 65%),
  radial-gradient(circle at 28% 26%,rgba(0,150,199,.22),transparent 55%),linear-gradient(160deg,#08141f,#0e2433);}
.ph::after{content:'';position:absolute;inset:0;background:linear-gradient(0deg,rgba(6,12,18,.92) 0%,rgba(6,12,18,.58) 24%,rgba(6,12,18,.14) 46%,transparent 64%);}
.ph.has-img::before{background:none;}
.rcard-img.has-img::before{background:none;}
.ph-cap{position:relative;z-index:2;padding:16px;width:100%;}
.ph-cap .pt{font-family:var(--font-mono);font-size:14px;letter-spacing:.14em;text-transform:uppercase;color:rgba(125,216,246,.96);display:block;margin-bottom:7px;text-shadow:0 1px 12px rgba(2,8,14,.75);}
.ph-cap .pn{font-family:var(--font-ui);font-size:24px;font-weight:600;letter-spacing:.01em;line-height:1.15;color:#fff;text-shadow:0 1px 14px rgba(2,8,14,.6);}

/* ── PROJECT CARD ────────────────────────────────────────────── */
.proj-card{position:relative;overflow:hidden;border-radius:14px;cursor:pointer;transition:transform .3s var(--ease),box-shadow .3s;box-shadow:var(--shadow);}
.proj-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lift);}
.proj-card .ph{aspect-ratio:4/3;border-radius:14px;}

/* ── FILTER BAR ──────────────────────────────────────────────── */
.filters{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:40px;}
.filter-btn{font-family:var(--font-mono);font-size:9px;letter-spacing:.12em;text-transform:uppercase;padding:9px 16px;border:1px solid var(--line);color:var(--ink-dim);border-radius:100px;transition:all .2s;background:var(--card);}
.filter-btn:hover{border-color:var(--blue);color:var(--blue-ink);}
.filter-btn.active{border-color:var(--blue);color:#fff;background:var(--blue);}

/* ── RENTAL IMAGE CARDS ──────────────────────────────────────── */
.rcat{margin-bottom:52px;}
.rcat:last-child{margin-bottom:0;}
.rcat-head{display:flex;align-items:center;gap:14px;margin:0 0 22px;}
.rcat-name{font-family:var(--font-disp);font-size:clamp(26px,3vw,40px);letter-spacing:.015em;color:var(--ink);}
.rcat-rule{flex:1;height:1px;background:var(--line);}
.rcat-meta{font-family:var(--font-mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-dim);}
.rgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;}
.rcard{background:var(--card);border:1px solid var(--line);border-radius:16px;overflow:hidden;box-shadow:var(--shadow);transition:transform .35s var(--ease),box-shadow .35s var(--ease);display:flex;flex-direction:column;}
.rcard:hover{transform:translateY(-4px);box-shadow:var(--shadow-lift);}
.rcard-img{aspect-ratio:4/3;position:relative;overflow:hidden;background:#0a1622;}
.rcard-img::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 50% 85%,rgba(0,150,199,.5),transparent 65%),radial-gradient(circle at 30% 28%,rgba(0,150,199,.24),transparent 55%),linear-gradient(160deg,#08141f,#0e2433);}
.rcard-img::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(8,16,24,.4));}
.rcard-imgtag{position:absolute;top:12px;left:12px;z-index:2;font-family:var(--font-mono);font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:#fff;background:rgba(2,8,14,.55);backdrop-filter:blur(6px);padding:5px 9px;border-radius:6px;}
.rcard-body{padding:18px 20px 20px;display:flex;flex-direction:column;flex:1;}
.rcard-name{font-family:var(--font-ui);font-size:15px;font-weight:600;letter-spacing:-.01em;color:var(--ink);margin-bottom:6px;}
.rcard-spec{font-family:var(--font-body);font-size:12px;line-height:1.55;color:var(--ink-mut);margin-bottom:16px;flex:1;}
.rcard-foot{display:flex;align-items:center;justify-content:space-between;padding-top:14px;border-top:1px solid var(--line-soft);}
.rcard-status{font-family:var(--font-mono);font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--blue-ink);display:flex;align-items:center;gap:6px;}
.rcard-status::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--blue);}
.rcard-quote{font-family:var(--font-mono);font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:var(--blue-ink);font-weight:500;display:inline-flex;align-items:center;gap:5px;transition:gap .2s;}
.rcard:hover .rcard-quote{gap:9px;}

/* ── TECH LIST ───────────────────────────────────────────────── */
.tech-list{display:flex;flex-direction:column;}
.tech-row{display:flex;align-items:center;justify-content:space-between;padding:16px 0;border-bottom:1px solid var(--line);}
.tech-row:last-child{border-bottom:none;}
.tech-name{font-family:var(--font-ui);font-size:14px;font-weight:600;color:var(--ink);}
.tech-cat{font-family:var(--font-mono);font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-dim);}
.tech-dot{width:5px;height:5px;border-radius:50%;background:var(--blue);flex-shrink:0;}

/* ── FAQ (answer-first, AEO) ─────────────────────────────────── */
.faq{display:grid;grid-template-columns:1fr 1fr;gap:14px 32px;}
.faq details{border:1px solid var(--line);border-radius:12px;background:var(--card);padding:0 22px;transition:border-color .2s,box-shadow .2s;}
.faq details[open]{border-color:var(--blue);box-shadow:var(--shadow);}
.faq summary{list-style:none;cursor:pointer;padding:20px 0;display:flex;align-items:center;justify-content:space-between;gap:16px;font-family:var(--font-ui);font-size:15px;font-weight:600;letter-spacing:-.01em;color:var(--ink);}
.faq summary::-webkit-details-marker{display:none;}
.faq summary::after{content:'+';font-family:var(--font-mono);font-size:18px;color:var(--blue-ink);flex-shrink:0;transition:transform .2s;}
.faq details[open] summary::after{transform:rotate(45deg);}
.faq-a{font-family:var(--font-body);font-size:13.5px;line-height:1.75;color:var(--ink-mut);padding:0 0 22px;max-width:60ch;}
@media(max-width:760px){.faq{grid-template-columns:1fr;}}

/* ── CTA ─────────────────────────────────────────────────────── */
.cta{padding:118px var(--pad);text-align:center;background:var(--bg-2);border-bottom:1px solid var(--line);position:relative;overflow:hidden;z-index:2;}
.cta::before{content:'';position:absolute;inset:0;pointer-events:none;background:radial-gradient(ellipse 56% 70% at 50% 50%,var(--blue-wash) 0%,transparent 65%);}
.cta-h{font-family:var(--font-disp);font-size:clamp(48px,7.5vw,104px);line-height:.9;letter-spacing:.02em;position:relative;z-index:1;color:var(--ink);}
.cta-h.dim{opacity:.28;margin-bottom:38px;}
.cta-sub{font-family:var(--font-body);font-size:14px;line-height:1.75;color:var(--ink-mut);max-width:54ch;margin:0 auto 36px;position:relative;z-index:1;}

/* ── FORM ────────────────────────────────────────────────────── */
.form{display:grid;grid-template-columns:1fr 1fr;gap:22px;}
.field{display:flex;flex-direction:column;gap:8px;}
.field.full{grid-column:1/-1;}
.field label{font-family:var(--font-mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-dim);}
.field label .req{color:var(--blue-ink);}
.field input,.field select,.field textarea{
  font-family:var(--font-body);font-size:14px;color:var(--ink);
  background:var(--bg);border:1px solid var(--line);padding:13px 14px;border-radius:8px;transition:border-color .2s;width:100%;
}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--blue);}
.field textarea{resize:vertical;min-height:120px;}
.field select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2393A1AD' fill='none' stroke-width='1.5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px;}
.field input::placeholder,.field textarea::placeholder{color:var(--ink-dim);}

/* tap-to-call button */
.call-btn{
  display:flex;align-items:center;gap:16px;
  background:var(--blue);color:#fff;border-radius:12px;
  padding:18px 22px;margin-bottom:6px;
  transition:filter .2s,transform .15s,box-shadow .2s;
}
.call-btn:hover{filter:brightness(1.08);transform:translateY(-1px);box-shadow:0 10px 26px rgba(0,150,199,.3);}
.call-ico{width:42px;height:42px;border-radius:10px;background:rgba(255,255,255,.16);display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.call-ico svg{width:20px;height:20px;}
.call-text{display:flex;flex-direction:column;gap:2px;}
.call-label{font-family:var(--font-mono);font-size:9px;letter-spacing:.2em;text-transform:uppercase;opacity:.8;}
.call-num{font-family:var(--font-ui);font-size:19px;font-weight:600;letter-spacing:.01em;}

/* Cal.com embed frame */
.cal-embed{
  width:100%;min-height:640px;border:1px solid var(--line);border-radius:16px;
  overflow:hidden;background:var(--card);box-shadow:var(--shadow);
}

/* contact two-path layout */
.contact-layout{display:grid;grid-template-columns:320px 1fr;gap:56px;align-items:start;}
.contact-aside{position:sticky;top:88px;}
.reply-note{font-family:var(--font-mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-dim);margin-top:22px;display:flex;align-items:center;gap:8px;}
.reply-note::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--blue);}
.contact-prompt{font-family:var(--font-disp);font-size:clamp(28px,3.4vw,44px);letter-spacing:.01em;color:var(--ink);margin:-28px 0 24px;}
.contact-toggle{display:inline-flex;gap:4px;padding:4px;border:1px solid var(--line);border-radius:11px;background:var(--bg-2);margin-bottom:24px;}
.ct-btn{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;padding:12px 22px;border-radius:8px;color:var(--ink-mut);transition:all .2s;}
.ct-btn:hover{color:var(--ink);}
.ct-btn.active{background:var(--blue);color:#fff;}
.contact-panel{display:none;}
.contact-panel.active{display:block;animation:panel-in .35s var(--ease);}
@keyframes panel-in{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:none;}}
.panel-hint{font-family:var(--font-body);font-size:13px;line-height:1.65;color:var(--ink-mut);margin-bottom:24px;max-width:58ch;}
@media(max-width:900px){
  .contact-layout{grid-template-columns:1fr;gap:36px;}
  .contact-aside{position:static;}
  .contact-prompt{margin-top:0;}
}

.contact-info{display:flex;flex-direction:column;gap:22px;}
.contact-block .ci-label{font-family:var(--font-mono);font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:var(--blue-ink);margin-bottom:8px;}
.contact-block .ci-value{font-family:var(--font-ui);font-size:16px;font-weight:500;color:var(--ink);}
.contact-block .ci-value a:hover{color:var(--blue-ink);}

/* ── FOOTER ──────────────────────────────────────────────────── */
.footer{background:var(--nav-bg);position:relative;z-index:2;}
.footer-main{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:48px;padding:72px var(--pad) 52px;}
.footer-brand img{height:23px;margin-bottom:20px;}
.footer-brand p{font-family:var(--font-body);font-size:13px;line-height:1.8;color:rgba(229,240,248,.5);max-width:34ch;}
.footer-col h4{font-family:var(--font-mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:rgba(43,182,222,.7);margin-bottom:18px;}
.footer-col ul{display:flex;flex-direction:column;gap:11px;}
.footer-col a{font-family:var(--font-ui);font-size:13px;color:rgba(229,240,248,.5);transition:color .2s;}
.footer-col a:hover{color:#fff;}
.footer-word{font-family:var(--font-disp);font-size:clamp(60px,16vw,260px);line-height:.8;letter-spacing:.02em;color:#fff;opacity:.05;text-align:center;padding:0 var(--pad);user-select:none;overflow:hidden;white-space:nowrap;}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;padding:24px var(--pad);border-top:1px solid rgba(255,255,255,.07);flex-wrap:wrap;gap:12px;}
.footer-bottom span{font-family:var(--font-mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:rgba(229,240,248,.35);}
.footer-bottom .fa{color:rgba(43,182,222,.7);}

/* ── REVEAL ──────────────────────────────────────────────────── */
.rv{opacity:0;transform:translateY(20px);transition:opacity .85s var(--ease),transform .85s var(--ease);}
.rv.d1{transition-delay:.08s;}.rv.d2{transition-delay:.16s;}.rv.d3{transition-delay:.24s;}.rv.d4{transition-delay:.32s;}
.rv.on{opacity:1;transform:none;}
@media(prefers-reduced-motion:reduce){
  .rv{opacity:1;transform:none;transition:none;}
  #rig{display:none;}
  .credits-track,.marquee-track{animation:none;}
  .eyebrow .dot{animation:none;}
  #vid-wrap video{display:none;}
}

/* ═══ RESPONSIVE ═══════════════════════════════════════════════ */
@media(max-width:1024px){
  :root{--pad:36px;}
  .pillars{grid-template-columns:repeat(2,1fr);}
  .rgrid{grid-template-columns:repeat(2,1fr);}
  .statement-grid{grid-template-columns:1fr;gap:36px;}
  .footer-main{grid-template-columns:1fr 1fr;gap:36px;}
}
@media(max-width:760px){
  :root{--pad:24px;}
  .nav-links,.nav .nav-cta{display:none;}
  .nav-toggle{display:block;}
  .hero-bottom{grid-template-columns:1fr;gap:28px;}
  .hero-right{align-items:flex-start;}
  .vid-tag{display:none;}
  .stats{grid-template-columns:repeat(2,1fr);}
  .stat:nth-child(2){border-right:none;}
  .stat:nth-child(1),.stat:nth-child(2){border-bottom:1px solid var(--line);}
  .pipeline{grid-template-columns:repeat(3,1fr);}
  .pipe-step:nth-child(3){border-right:none;}
  .pipe-step:nth-child(1),.pipe-step:nth-child(2),.pipe-step:nth-child(3){border-bottom:1px solid var(--line);}
  .pillars,.rgrid{grid-template-columns:1fr;}
  .form{grid-template-columns:1fr;}
  .footer-main{grid-template-columns:1fr;}
  .section{padding:64px var(--pad);}
  .hero-caps{flex-wrap:wrap;gap:6px 0;}
}
@media(max-width:520px){
  .pipeline{grid-template-columns:repeat(2,1fr);}
  .pipe-step{padding:22px 20px;min-width:0;border-right:1px solid var(--line);border-bottom:1px solid var(--line);}
  .pipe-step:nth-child(even){border-right:none;}
  .pipe-step:nth-child(5),.pipe-step:nth-child(6){border-bottom:none;}
}

/* ── PROJECT CARDS (real images) + LIGHTBOX ──────────────────── */
.proj-card{width:100%;text-align:left;display:block;background:none;border:none;padding:0;font:inherit;color:inherit;}
.ph.has-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;}
.proj-card.proj-static{cursor:default;}
.proj-card.proj-static:hover{transform:none;box-shadow:var(--shadow);}
.proj-card .play-ico{position:absolute;z-index:3;top:14px;right:14px;
  width:36px;height:36px;border-radius:50%;background:rgba(2,8,14,.5);backdrop-filter:blur(6px);
  border:1px solid rgba(255,255,255,.5);color:#fff;display:flex;align-items:center;justify-content:center;
  font-size:11px;padding-left:2px;transition:background .2s,transform .2s;}
.proj-card.is-video:hover .play-ico{background:var(--blue);transform:scale(1.1);}

.lightbox{position:fixed;inset:0;z-index:300;display:none;align-items:center;justify-content:center;padding:24px;}
.lightbox.open{display:flex;}
.lb-backdrop{position:absolute;inset:0;background:rgba(2,8,14,.82);backdrop-filter:blur(10px);}
.lb-card{position:relative;z-index:2;width:min(1100px,100%);max-height:92vh;display:flex;flex-direction:column;
  background:var(--bg-2);border:1px solid var(--line);border-radius:20px;overflow:hidden;
  box-shadow:0 30px 80px rgba(0,0,0,.5);animation:lbpop .35s var(--ease);}
@keyframes lbpop{from{opacity:0;transform:translateY(14px) scale(.985)}to{opacity:1;transform:none}}
.lb-head{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:18px 22px;border-bottom:1px solid var(--line);flex-shrink:0;}
.lb-cat{display:block;font-family:var(--font-mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--blue-ink);margin-bottom:5px;}
.lb-name{display:block;font-family:var(--font-disp);font-size:27px;letter-spacing:.02em;color:var(--ink);line-height:1;}
.lb-close{width:40px;height:40px;border-radius:50%;border:1px solid var(--line);color:var(--ink-mut);font-size:24px;line-height:1;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .2s;}
.lb-close:hover{background:var(--blue);color:#fff;border-color:var(--blue);}
.lb-stage{position:relative;flex:1;min-height:64vh;display:flex;align-items:center;justify-content:center;background:#0a1622;}
.lb-viewer{position:relative;width:100%;height:100%;}
.lb-media{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .4s var(--ease);}
.lb-media.show{opacity:1;}
.lb-viewer img{max-width:100%;max-height:62vh;object-fit:contain;display:block;}
.lb-vid{position:relative;border-radius:14px;overflow:hidden;max-width:100%;max-height:62vh;margin:auto;background:#000;}
.lb-vid.ar-portrait{aspect-ratio:9/16;height:62vh;}
.lb-vid.ar-landscape{aspect-ratio:16/9;width:100%;max-width:calc(62vh * 16 / 9);}
.lb-vid iframe{position:absolute;inset:0;width:100%;height:100%;border:0;}
.lb-vid-hit{position:absolute;inset:0;z-index:2;background:transparent;border:none;cursor:pointer;}
.lb-vidph{position:relative;display:flex;}
.lb-vidph img{max-height:62vh;}
.lb-vidbadge{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  background:transparent;color:#fff;}
.lb-vidbadge .pl{width:62px;height:62px;border-radius:50%;border:1px solid rgba(255,255,255,.6);
  display:flex;align-items:center;justify-content:center;font-size:20px;padding-left:4px;background:rgba(0,150,199,.55);}
.lb-nav{position:absolute;top:50%;transform:translateY(-50%);z-index:3;width:44px;height:44px;border-radius:50%;
  background:rgba(2,8,14,.55);backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.25);color:#fff;font-size:24px;line-height:1;
  display:flex;align-items:center;justify-content:center;transition:background .2s;}
.lb-nav:hover{background:var(--blue);}
.lb-prev{left:14px;} .lb-next{right:14px;}
.lightbox.single .lb-nav,.lightbox.single .lb-strip{display:none;}
.lb-strip{display:flex;justify-content:safe center;gap:8px;padding:14px 16px;overflow-x:auto;border-top:1px solid var(--line);background:var(--bg);flex-shrink:0;}
.lb-strip button{position:relative;flex:0 0 auto;width:86px;height:62px;border-radius:8px;overflow:hidden;
  border:2px solid transparent;opacity:.5;transition:opacity .2s,border-color .2s;padding:0;background:none;}
.lb-strip button.active{opacity:1;border-color:var(--blue);}
.lb-strip button:hover{opacity:.85;}
.lb-strip button img{width:100%;height:100%;object-fit:cover;}
.lb-strip button .vt{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:#fff;font-size:13px;background:rgba(2,8,14,.32);}
@media(max-width:760px){
  .lightbox{padding:0;}
  .lb-card{max-height:100vh;height:100%;width:100%;border-radius:0;}
  .lb-name{font-size:22px;}
  .lb-stage{min-height:54vh;}
  .lb-viewer img,.lb-vidph img{max-height:52vh;}
  .lb-viewer iframe{height:52vh;}
  .lb-vid{max-height:52vh;}
  .lb-vid.ar-portrait{height:52vh;}
  .lb-vid.ar-landscape{max-width:calc(52vh * 16 / 9);}
  .lb-nav{width:38px;height:38px;font-size:20px;}
}
