/* ============================================================
   BDB WEB COLLECTIVE — design system
   Architectural navy · single electric blue · warm cream
   Type: Archivo (display) · Hanken Grotesk (body) · DM Mono (labels)
   ============================================================ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  /* ink (navy-anchored darks) */
  --ink-900:#080b12;
  --ink-850:#0b0f18;
  --ink-800:#0e131f;
  --ink-750:#11182610;
  --panel:#0e1320;
  --card:#121a29;
  --card-2:#16203200;
  --line:#1d2738;
  --line-2:#2a3850;
  /* greys */
  --fog:#5d6a82;
  --mist:#8e9bb2;
  --silver:#c2cbdb;
  --cloud:#e4eaf3;
  --white:#f4f7fd;
  /* blue (single accent family from the logo gradient) */
  --blue:#2e63e8;
  --blue-bright:#5384ff;
  --blue-deep:#1a3aa0;
  --blue-ink:#0c1c4d;
  --blue-tint:rgba(46,99,232,.13);
  --blue-glow:rgba(46,99,232,.32);
  /* cream (the wall the logo lives on) */
  --cream:#ece7dc;
  --cream-2:#e3ddcf;
  --cream-3:#d9d2c1;
  --cream-line:#cdc4b1;
  --cream-ink:#13161d;
  --cream-fog:#6c6555;
  --cream-blue:#22409a;
  /* type */
  --f-disp:'Archivo',system-ui,sans-serif;
  --f-body:'Hanken Grotesk',system-ui,sans-serif;
  --f-mono:'DM Mono','SFMono-Regular',monospace;
  /* motion */
  --ease:cubic-bezier(.22,.61,.36,1);
  --ease-out:cubic-bezier(.16,1,.3,1);
  /* layout */
  --pad:clamp(20px,5vw,84px);
}

html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--f-body);
  background:var(--ink-900);
  color:var(--silver);
  overflow-x:hidden;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
::selection{background:var(--blue);color:#fff}
img{max-width:100%;display:block}
button{font-family:inherit;cursor:pointer}
a{color:inherit;text-decoration:none}

/* faint film grain on the dark canvas */
body::after{
  content:'';position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.02;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 160 160' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ---- type primitives ---------------------------------------- */
.eyebrow{
  font-family:var(--f-mono);font-size:11px;letter-spacing:.34em;text-transform:uppercase;
  color:var(--blue-bright);display:inline-flex;align-items:center;gap:12px;
}
.eyebrow::before{content:'';width:26px;height:1px;background:var(--blue);display:inline-block}
.eyebrow.no-bar::before{display:none}
.cream .eyebrow{color:var(--cream-blue)}
.cream .eyebrow::before{background:var(--cream-blue)}

.display{
  font-family:var(--f-disp);font-weight:800;line-height:.94;letter-spacing:-.02em;
  color:var(--white);text-transform:uppercase;
}
.cream .display{color:var(--cream-ink)}
.dim{color:var(--fog)}
.cream .dim{color:var(--cream-3)}
.accent{color:var(--blue-bright)}
.cream .accent{color:var(--cream-blue)}

/* ---- logo lockup (CSS, theme-adaptive) ---------------------- */
.logo{display:inline-flex;align-items:center;gap:13px;color:var(--white)}
.cream .logo,.logo.on-cream{color:var(--cream-ink)}
.logo-box{
  font-family:var(--f-disp);font-weight:800;font-size:18px;letter-spacing:.02em;
  border:1.5px solid currentColor;padding:7px 10px 6px;line-height:1;position:relative;
}
.logo-box::after{content:'';position:absolute;left:-1.5px;right:-1.5px;bottom:-1.5px;height:1.5px;
  background:linear-gradient(90deg,transparent,var(--blue-bright) 60%,var(--blue));}
.logo-div{width:1px;height:34px;background:currentColor;opacity:.35}
.logo-words{font-family:var(--f-disp);font-weight:700;font-size:11px;letter-spacing:.26em;line-height:1.28;text-transform:uppercase}
.logo-sm .logo-box{font-size:15px;padding:5px 8px 4px}
.logo-sm .logo-div{height:28px}
.logo-sm .logo-words{font-size:9.5px}

/* ---- buttons ------------------------------------------------ */
.btn{
  display:inline-flex;align-items:center;gap:11px;padding:15px 26px;
  font-family:var(--f-mono);font-size:12px;letter-spacing:.16em;text-transform:uppercase;
  border:1px solid transparent;position:relative;transition:.35s var(--ease);
  background:none;color:var(--white);
}
.btn .ar{transition:transform .35s var(--ease)}
.btn:hover .ar{transform:translate(4px,-4px)}
.btn-fill{background:var(--blue);color:#fff;border-color:var(--blue)}
.btn-fill:hover{background:var(--blue-bright);border-color:var(--blue-bright);box-shadow:0 14px 38px -12px var(--blue-glow)}
.btn-line{border-color:var(--line-2);color:var(--cloud)}
.btn-line:hover{border-color:var(--blue-bright);color:var(--white);background:var(--blue-tint)}
.cream .btn-line{border-color:var(--cream-3);color:var(--cream-ink)}
.cream .btn-line:hover{border-color:var(--cream-blue);background:rgba(34,64,154,.07)}
.cream .btn-fill{background:var(--cream-ink);border-color:var(--cream-ink);color:var(--cream)}
.cream .btn-fill:hover{background:var(--cream-blue);border-color:var(--cream-blue);box-shadow:none}

/* ---- nav ---------------------------------------------------- */
#nav{
  position:fixed;top:0;left:0;right:0;z-index:600;display:flex;align-items:center;
  justify-content:space-between;padding:20px var(--pad);
  background:rgba(8,11,18,.72);backdrop-filter:blur(18px) saturate(1.3);
  border-bottom:1px solid var(--line);transition:padding .35s var(--ease),background .35s;
}
#nav.scrolled{padding:13px var(--pad);background:rgba(8,11,18,.92)}
.nav-links{display:flex;align-items:center;gap:2px;list-style:none}
.nav-links a{
  font-family:var(--f-mono);font-size:11px;letter-spacing:.13em;text-transform:uppercase;
  color:var(--mist);padding:9px 15px;position:relative;transition:color .25s;white-space:nowrap;
}
.nav-links a::after{content:'';position:absolute;left:15px;right:15px;bottom:4px;height:1px;
  background:var(--blue-bright);transform:scaleX(0);transform-origin:left;transition:transform .3s var(--ease)}
.nav-links a:hover{color:var(--white)}
.nav-links a:hover::after,.nav-links a.active::after{transform:scaleX(1)}
.nav-links a.active{color:var(--white)}
.nav-links a.nav-cta{
  margin-left:10px;background:var(--blue);color:#fff;padding:11px 20px;
  border:1px solid var(--blue);transition:.3s var(--ease);
}
.nav-links a.nav-cta::after{display:none}
.nav-links a.nav-cta:hover{background:var(--blue-bright);border-color:var(--blue-bright);box-shadow:0 12px 30px -12px var(--blue-glow)}
.hamburger{display:none;flex-direction:column;gap:5px;padding:6px;background:none;border:none;z-index:620}
.hamburger span{width:24px;height:1.6px;background:var(--cloud);transition:.3s var(--ease)}
.hamburger.open span:nth-child(1){transform:translateY(6.6px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-6.6px) rotate(-45deg)}

/* ---- pages -------------------------------------------------- */
.page{display:none}
.page.active{display:block}

/* ---- section scaffold --------------------------------------- */
.sec{padding:clamp(72px,11vh,128px) var(--pad);position:relative}
.sec.cream{background:var(--cream);color:var(--cream-ink)}
.sec.panel{background:var(--ink-850)}
.sec-head{display:flex;flex-direction:column;gap:16px;margin-bottom:54px}
.sec-title{font-family:var(--f-disp);font-weight:800;text-transform:uppercase;line-height:.92;
  letter-spacing:-.02em;color:var(--white);font-size:clamp(40px,6.4vw,88px)}
.cream .sec-title{color:var(--cream-ink)}
.lead{font-size:clamp(15px,1.5vw,17px);line-height:1.75;color:var(--mist);max-width:54ch}
.cream .lead{color:var(--cream-fog)}

/* reveal on scroll */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .8s var(--ease-out),transform .8s var(--ease-out)}
.reveal.in{opacity:1;transform:none}
.d1{transition-delay:.08s}.d2{transition-delay:.16s}.d3{transition-delay:.24s}
.d4{transition-delay:.32s}.d5{transition-delay:.4s}.d6{transition-delay:.48s}

/* hairline framed box motif */
.frame{border:1px solid var(--line)}
.cream .frame{border-color:var(--cream-line)}

/* striped image placeholder */
.shot{position:relative;overflow:hidden;background:
  repeating-linear-gradient(135deg,var(--ink-800) 0 11px,var(--panel) 11px 22px);
  border:1px solid var(--line);display:flex;align-items:flex-end;padding:18px}
.shot span{font-family:var(--f-mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--fog)}
.cream .shot{background:repeating-linear-gradient(135deg,var(--cream-2) 0 11px,var(--cream-3) 11px 22px);border-color:var(--cream-line)}
.cream .shot span{color:var(--cream-fog)}

/* ============================================================
   MARQUEE
   ============================================================ */
.marquee{overflow:hidden;white-space:nowrap;display:flex;border-block:1px solid var(--line);
  background:var(--ink-850);padding:18px 0}
.marquee.invert{background:var(--blue-ink);border-color:var(--blue-deep)}
.marquee-row{display:inline-flex;align-items:center;gap:34px;padding-right:34px;animation:slide 34s linear infinite;will-change:transform}
.marquee:hover .marquee-row{animation-play-state:paused}
.mq-item{font-family:var(--f-disp);font-weight:800;font-size:clamp(20px,2.5vw,30px);text-transform:uppercase;
  letter-spacing:.01em;color:var(--white);display:inline-flex;align-items:center;gap:34px}
.marquee.invert .mq-item{color:var(--cloud)}
.mq-item .dot{width:9px;height:9px;background:var(--blue-bright);display:inline-block;transform:rotate(45deg);flex:none}
.mq-item.ghost{color:transparent;-webkit-text-stroke:1px var(--line-2)}
.marquee.invert .mq-item.ghost{-webkit-text-stroke:1px var(--blue-deep)}
@keyframes slide{to{transform:translateX(-50%)}}

/* ============================================================
   HOME — hero
   ============================================================ */
#page-home{position:relative}
.hero{position:relative;padding:clamp(130px,17vh,190px) var(--pad) clamp(40px,7vh,70px);overflow:hidden}
.hero-rule{position:absolute;inset:0;pointer-events:none;
  background-image:linear-gradient(var(--line) 1px,transparent 1px);
  background-size:100% clamp(110px,15vh,150px);background-position:0 80px;
  mask-image:linear-gradient(180deg,transparent,#000 24%,#000 70%,transparent);opacity:.5}
.hero-grid{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:48px;align-items:end;position:relative;z-index:2}
.hero-eyebrow{margin-bottom:30px}
.hero-h1{font-family:var(--f-disp);font-weight:800;text-transform:uppercase;line-height:.9;
  letter-spacing:-.025em;color:var(--white);font-size:clamp(58px,12vw,176px)}
.hero-h1 .ln{display:block;overflow:hidden}
.hero-h1 .ln>span{display:block;transform:translateY(108%);transition:transform .9s var(--ease-out)}
.hero-h1 .ln.in>span{transform:none}
.hero-h1 .ln:nth-child(2).in>span{transition-delay:.1s}
.hero-h1 .ln:nth-child(3).in>span{transition-delay:.2s}
.hero-h1 .ln:nth-child(4).in>span{transition-delay:.3s}
.hero-h1 .stroke{color:transparent;-webkit-text-stroke:1.6px var(--blue-bright)}
.hero-h1 em{font-style:normal;color:var(--blue-bright)}
.hero-side{display:flex;flex-direction:column;align-items:flex-end;gap:26px;padding-bottom:10px;max-width:340px}
.hero-sub{font-size:15.5px;line-height:1.7;color:var(--mist);text-align:right}
.hero-cta{display:flex;gap:12px;flex-wrap:wrap;justify-content:flex-end}
.hero-bottom{display:flex;justify-content:space-between;align-items:flex-end;gap:32px;margin-top:clamp(44px,7vh,72px);
  padding-top:30px;border-top:1px solid var(--line);position:relative;z-index:2}
.hero-stats{display:flex;gap:clamp(28px,4vw,60px)}
.hstat-n{font-family:var(--f-disp);font-weight:800;font-size:clamp(34px,4vw,52px);color:var(--white);line-height:1}
.hstat-n em{font-style:normal;color:var(--blue-bright)}
.hstat-l{font-family:var(--f-mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--fog);margin-top:8px}
.hero-scroll{font-family:var(--f-mono);font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:var(--fog);
  display:flex;align-items:center;gap:12px}
.hero-scroll .bar{width:42px;height:1px;background:var(--line-2);position:relative;overflow:hidden}
.hero-scroll .bar::after{content:'';position:absolute;inset:0;width:40%;background:var(--blue-bright);animation:scan 1.8s var(--ease) infinite}
@keyframes scan{0%{transform:translateX(-100%)}100%{transform:translateX(280%)}}

/* ---- mission (cream) ---------------------------------------- */
.mission-head{max-width:18ch}
.mission-title{font-family:var(--f-disp);font-weight:800;text-transform:uppercase;line-height:.96;
  letter-spacing:-.02em;color:var(--cream-ink);font-size:clamp(34px,5vw,68px)}
.mission-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:clamp(32px,5vw,72px);align-items:start}
.mission-body{font-size:16px;line-height:1.8;color:var(--cream-fog);max-width:46ch}
.pillars{display:grid;grid-template-columns:1fr 1fr;margin-top:46px;border-top:1px solid var(--cream-line);border-left:1px solid var(--cream-line)}
.pillar{padding:28px 26px;border-right:1px solid var(--cream-line);border-bottom:1px solid var(--cream-line);transition:background .3s}
.pillar:hover{background:var(--cream-2)}
.pillar-ic{font-size:24px;margin-bottom:14px;display:block}
.pillar-t{font-family:var(--f-disp);font-weight:700;font-size:15px;text-transform:uppercase;letter-spacing:.02em;color:var(--cream-ink);margin-bottom:8px}
.pillar-x{font-size:13px;line-height:1.6;color:var(--cream-fog)}

/* ---- why-us ------------------------------------------------- */
.why-grid{display:grid;grid-template-columns:repeat(2,1fr);border-top:1px solid var(--line);border-left:1px solid var(--line)}
.why-card{padding:clamp(30px,3.4vw,48px);border-right:1px solid var(--line);border-bottom:1px solid var(--line);
  position:relative;overflow:hidden;transition:background .35s}
.why-card:hover{background:var(--panel)}
.why-n{position:absolute;right:18px;top:14px;font-family:var(--f-disp);font-weight:800;font-size:74px;color:var(--white);opacity:.04;line-height:1}
.why-ic{font-size:26px;margin-bottom:18px;display:block}
.why-t{font-family:var(--f-disp);font-weight:700;font-size:clamp(18px,1.8vw,22px);text-transform:uppercase;
  letter-spacing:.01em;color:var(--white);margin-bottom:11px;max-width:18ch}
.why-x{font-size:14px;line-height:1.7;color:var(--mist);max-width:42ch}

/* ============================================================
   FOOTER
   ============================================================ */
footer{background:var(--ink-900);border-top:1px solid var(--line);padding:clamp(56px,8vh,88px) var(--pad) 36px}
.foot-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px;padding-bottom:48px;border-bottom:1px solid var(--line)}
.foot-cta-h{font-family:var(--f-disp);font-weight:800;font-size:clamp(28px,3.6vw,46px);text-transform:uppercase;
  line-height:.96;letter-spacing:-.02em;color:var(--white);margin:22px 0 24px;max-width:14ch}
.foot-col h4{font-family:var(--f-mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--fog);margin-bottom:18px}
.foot-col ul{list-style:none;display:flex;flex-direction:column;gap:11px}
.foot-col a{font-size:14px;color:var(--mist);transition:color .25s,padding-left .25s}
.foot-col a:hover{color:var(--white);padding-left:5px}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;padding-top:26px}
.foot-copy{font-family:var(--f-mono);font-size:11px;color:var(--fog)}
.foot-copy b{color:var(--blue-bright);font-weight:400}
.foot-legal{display:flex;gap:22px}
.foot-legal a{font-family:var(--f-mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--fog);transition:color .25s}
.foot-legal a:hover{color:var(--silver)}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:1040px){
  .foot-top{grid-template-columns:1fr 1fr}
  .hero-grid{grid-template-columns:1fr;gap:30px}
  .hero-side{align-items:flex-start;max-width:none}
  .hero-sub,.hero-cta{text-align:left;justify-content:flex-start}
}
@media(max-width:820px){
  .nav-links{position:fixed;inset:0;flex-direction:column;justify-content:center;gap:8px;
    background:rgba(8,11,18,.98);backdrop-filter:blur(20px);transform:translateX(100%);transition:transform .4s var(--ease);z-index:610}
  .nav-links.open{transform:none}
  .nav-links a{font-size:15px;padding:13px}
  .nav-links a::after{display:none}
  .hamburger{display:flex}
  .mission-grid{grid-template-columns:1fr;gap:32px}
  .why-grid{grid-template-columns:1fr}
  .hero-bottom{flex-direction:column;align-items:flex-start}
  .hero-scroll{display:none}
}
@media(max-width:560px){
  .pillars{grid-template-columns:1fr}
  .logo-words{font-size:9.5px}
}
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}
  .hero-h1 .ln>span{transform:none}
  .reveal{opacity:1;transform:none}
}

/* ============================================================
   INNER PAGE SCAFFOLD
   ============================================================ */
.page-top{padding-top:clamp(132px,17vh,196px)}
.intro{display:grid;grid-template-columns:1fr minmax(0,auto);gap:40px;align-items:end;margin-bottom:clamp(46px,7vh,78px)}
.intro .lead{justify-self:end;max-width:40ch}
.cols3{display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid var(--line);border-left:1px solid var(--line)}
.cell{padding:clamp(28px,3vw,40px);border-right:1px solid var(--line);border-bottom:1px solid var(--line)}
.cream .cols3{border-color:var(--cream-line)}.cream .cell{border-color:var(--cream-line)}
.cell-k{font-family:var(--f-mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--blue-bright);margin-bottom:16px}
.cream .cell-k{color:var(--cream-blue)}
.cell-ic{font-size:26px;margin-bottom:16px;display:block}
.cell-t{font-family:var(--f-disp);font-weight:700;font-size:clamp(16px,1.6vw,19px);text-transform:uppercase;letter-spacing:.01em;color:var(--white);margin-bottom:10px}
.cream .cell-t{color:var(--cream-ink)}
.cell-x{font-size:13.5px;line-height:1.7;color:var(--mist)}
.cream .cell-x{color:var(--cream-fog)}
.cell-list{list-style:none;display:flex;flex-direction:column;gap:11px;margin-top:6px}
.cell-list li{display:flex;gap:10px;font-size:13.5px;color:var(--mist);line-height:1.45}
.cell-list li::before{content:'✦';color:var(--blue-bright);font-size:10px;margin-top:3px;flex:none}
.cream .cell-list li{color:var(--cream-fog)}.cream .cell-list li::before{color:var(--cream-blue)}
.page-cta{text-align:center;margin-top:clamp(48px,7vh,72px);display:flex;flex-direction:column;align-items:center;gap:18px}
.page-cta p{font-size:15px;color:var(--mist);max-width:48ch}
.cream .page-cta p{color:var(--cream-fog)}
.cta-row{display:flex;gap:13px;flex-wrap:wrap;justify-content:center}

/* ---- services ---------------------------------------------- */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid var(--line);border-left:1px solid var(--line)}
.svc-card{padding:clamp(30px,3vw,46px);border-right:1px solid var(--line);border-bottom:1px solid var(--line);
  position:relative;display:flex;flex-direction:column;min-height:312px;overflow:hidden;transition:background .35s}
.svc-card:hover{background:var(--panel)}
.svc-card::before{content:'';position:absolute;left:0;right:0;top:0;height:2px;
  background:linear-gradient(90deg,var(--blue),var(--blue-bright));transform:scaleX(0);transform-origin:left;transition:transform .45s var(--ease)}
.svc-card:hover::before{transform:scaleX(1)}
.svc-num{font-family:var(--f-mono);font-size:11px;letter-spacing:.2em;color:var(--fog)}
.svc-ic{font-size:30px;margin:22px 0 16px}
.svc-name{font-family:var(--f-disp);font-weight:700;font-size:clamp(17px,1.7vw,21px);text-transform:uppercase;
  letter-spacing:.01em;color:var(--white);margin-bottom:11px;line-height:1.08}
.svc-x{font-size:13.5px;line-height:1.7;color:var(--mist)}
.svc-arr{margin-top:auto;align-self:flex-start;width:42px;height:42px;border:1px solid var(--line-2);
  display:flex;align-items:center;justify-content:center;color:var(--mist);font-size:16px;transition:.35s var(--ease)}
.svc-card:hover .svc-arr{border-color:var(--blue);color:var(--blue-bright);transform:rotate(-45deg)}

/* ---- pricing ----------------------------------------------- */
.tabs{display:inline-flex;gap:4px;border:1px solid var(--line);padding:4px;margin-bottom:46px;background:var(--ink-850)}
.tab{padding:11px 26px;font-family:var(--f-mono);font-size:11px;letter-spacing:.13em;text-transform:uppercase;
  color:var(--mist);background:none;border:none;transition:.25s}
.tab.active{background:var(--blue);color:#fff}
.psec{display:none}.psec.active{display:block;animation:fadeSoft .4s var(--ease)}
@keyframes fadeSoft{from{opacity:.4}}
.price-grid{display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid var(--line);border-left:1px solid var(--line)}
.pcard{padding:clamp(30px,3vw,44px);border-right:1px solid var(--line);border-bottom:1px solid var(--line);
  display:flex;flex-direction:column;position:relative;transition:background .35s}
.pcard:hover{background:var(--panel)}
.pcard.feat{background:#0c1626}
.pcard.feat::before{content:'';position:absolute;left:0;right:0;top:0;height:3px;background:linear-gradient(90deg,var(--blue),var(--blue-bright))}
.pbadge{display:inline-block;align-self:flex-start;padding:4px 12px;background:var(--blue-tint);border:1px solid var(--blue-deep);
  font-family:var(--f-mono);font-size:9px;letter-spacing:.16em;text-transform:uppercase;color:var(--blue-bright);margin-bottom:20px}
.pplan{font-family:var(--f-mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--mist);margin-bottom:14px}
.pprice{display:flex;align-items:flex-start;gap:3px;line-height:1;margin-bottom:6px}
.pprice .cur{font-family:var(--f-disp);font-weight:600;font-size:20px;color:var(--silver);margin-top:10px}
.pprice .num{font-family:var(--f-disp);font-weight:800;font-size:clamp(48px,5vw,66px);color:var(--white);letter-spacing:-.02em}
.pprice .per{font-family:var(--f-mono);font-size:11px;color:var(--fog);align-self:flex-end;margin-bottom:8px;margin-left:2px}
.pnote{font-family:var(--f-mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--fog);margin-bottom:20px}
.pdesc{font-size:13px;line-height:1.7;color:var(--mist);padding-bottom:24px;margin-bottom:24px;border-bottom:1px solid var(--line)}
.pfeat{list-style:none;display:flex;flex-direction:column;gap:12px;margin-bottom:30px}
.pfeat li{display:flex;gap:10px;font-size:13.5px;color:var(--silver);line-height:1.4}
.pfeat li::before{content:'✦';color:var(--blue-bright);font-size:10px;margin-top:3px;flex:none}
.pfeat li.off{opacity:.32}.pfeat li.off::before{color:var(--fog)}
.pbtn{margin-top:auto;display:block;text-align:center;padding:14px;border:1px solid var(--line-2);
  font-family:var(--f-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--cloud);transition:.25s}
.pbtn:hover{border-color:var(--blue-bright);color:#fff;background:var(--blue-tint)}
.pbtn.feat{background:var(--blue);border-color:var(--blue);color:#fff}
.pbtn.feat:hover{background:var(--blue-bright);border-color:var(--blue-bright)}
.addon-grid{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid var(--line);border-left:1px solid var(--line)}
.addon{padding:28px 24px;border-right:1px solid var(--line);border-bottom:1px solid var(--line);transition:background .3s}
.addon:hover{background:var(--panel)}
.addon-n{font-family:var(--f-disp);font-weight:700;font-size:15px;text-transform:uppercase;color:var(--white);margin-bottom:8px}
.addon-p{font-family:var(--f-disp);font-weight:800;font-size:32px;color:var(--blue-bright);line-height:1;margin-bottom:10px}
.addon-p small{font-size:15px;color:var(--fog);font-weight:500}
.addon-x{font-size:12.5px;line-height:1.6;color:var(--mist)}

/* ---- process ----------------------------------------------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);position:relative;margin-top:8px}
.steps::before{content:'';position:absolute;top:31px;left:7%;right:7%;height:1px;background:linear-gradient(90deg,transparent,var(--line-2) 12%,var(--line-2) 88%,transparent)}
.step{padding:0 26px 10px}
.step-dot{width:64px;height:64px;border:1px solid var(--line-2);background:var(--ink-900);display:flex;align-items:center;justify-content:center;
  margin-bottom:26px;font-family:var(--f-disp);font-weight:800;font-size:24px;color:var(--blue-bright);position:relative;z-index:1;transition:.35s var(--ease)}
.step:hover .step-dot{background:var(--blue);color:#fff;border-color:var(--blue);box-shadow:0 12px 30px -12px var(--blue-glow)}
.step-t{font-family:var(--f-disp);font-weight:700;font-size:clamp(16px,1.6vw,19px);text-transform:uppercase;color:var(--white);margin-bottom:11px}
.step-x{font-size:13.5px;line-height:1.7;color:var(--mist)}

/* ---- about / team ------------------------------------------ */
.about{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,5vw,76px);align-items:start}
.pull{font-family:var(--f-disp);font-weight:600;font-size:clamp(20px,2.3vw,28px);line-height:1.26;color:var(--cream-ink);
  border-left:3px solid var(--cream-blue);padding-left:22px;margin-bottom:26px}
.about-body p{font-size:15px;line-height:1.85;color:var(--cream-fog);margin-bottom:16px}
.team{display:flex;flex-direction:column;border-top:1px solid var(--cream-line)}
.tmember{padding:24px 6px;display:flex;gap:20px;align-items:center;border-bottom:1px solid var(--cream-line);transition:padding-left .3s var(--ease)}
.tmember:hover{padding-left:14px;background:var(--cream-2)}
.tav{width:62px;height:62px;flex:none;border:1px solid var(--cream-blue);background:var(--cream-2);
  display:flex;align-items:center;justify-content:center;font-family:var(--f-disp);font-weight:800;font-size:21px;color:var(--cream-blue)}
.tname{font-family:var(--f-disp);font-weight:700;font-size:17px;text-transform:uppercase;color:var(--cream-ink);margin-bottom:3px}
.trole{font-family:var(--f-mono);font-size:9.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--cream-blue);margin-bottom:6px}
.tbio{font-size:12.5px;line-height:1.55;color:var(--cream-fog)}

/* ---- connect ----------------------------------------------- */
.connect{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,5vw,76px);align-items:start}
.ci-list{display:flex;flex-direction:column;border-top:1px solid var(--line);margin-bottom:28px}
.ci{display:flex;align-items:center;gap:18px;padding:20px 4px;border-bottom:1px solid var(--line)}
.ci-ic{width:46px;height:46px;flex:none;border:1px solid var(--line-2);display:flex;align-items:center;justify-content:center;font-size:17px;color:var(--blue-bright)}
.ci-k{font-family:var(--f-mono);font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:var(--fog);margin-bottom:4px}
.ci-v{font-family:var(--f-mono);font-size:13.5px;color:var(--silver)}
.ci-v:hover{color:var(--blue-bright)}
.socials{display:flex;gap:10px;flex-wrap:wrap}
.social{padding:12px 18px;border:1px solid var(--line);font-family:var(--f-mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--mist);transition:.25s}
.social:hover{border-color:var(--blue-bright);color:#fff;background:var(--blue-tint)}
.connect-panel{border:1px solid var(--line);background:var(--ink-850);padding:clamp(28px,3vw,40px)}
.cp-k{font-family:var(--f-mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--blue-bright);margin-bottom:20px}
.cp-h{font-family:var(--f-disp);font-weight:700;font-size:clamp(22px,2.4vw,30px);text-transform:uppercase;color:var(--white);line-height:1.05;margin-bottom:18px}
.cp-row{display:flex;justify-content:space-between;padding:14px 0;border-top:1px solid var(--line);font-size:13.5px}
.cp-row span:first-child{color:var(--mist)}.cp-row span:last-child{color:var(--white);font-family:var(--f-mono);font-size:12px}

/* ---- forms ------------------------------------------------- */
.form{display:flex;flex-direction:column;gap:16px}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.fg{display:flex;flex-direction:column;gap:8px}
.fg label{font-family:var(--f-mono);font-size:9.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--fog)}
.fg label .req{color:var(--blue-bright)}
.fg input,.fg select,.fg textarea{background:var(--ink-850);border:1px solid var(--line);padding:14px 15px;
  font-family:var(--f-body);font-size:14px;color:var(--white);outline:none;transition:border-color .2s,box-shadow .2s}
.fg input::placeholder,.fg textarea::placeholder{color:var(--fog)}
.fg select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%238e9bb2' stroke-width='1.5' fill='none'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 15px center}
.fg select option{background:var(--ink-850)}
.fg textarea{resize:vertical;min-height:118px}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-tint)}
.fg.bad input,.fg.bad select,.fg.bad textarea{border-color:#e0556b}
.fg .msg{font-family:var(--f-mono);font-size:9.5px;letter-spacing:.06em;color:#e0556b;display:none}
.fg.bad .msg{display:block}
.form-ok{display:none;border:1px solid var(--blue-deep);background:var(--blue-tint);padding:28px;text-align:center;flex-direction:column;gap:10px;align-items:center}
.form-ok.show{display:flex;animation:fadeSoft .5s var(--ease)}
.form-ok .ok-ic{width:48px;height:48px;border:1px solid var(--blue);display:flex;align-items:center;justify-content:center;color:var(--blue-bright);font-size:22px}
.form-ok h4{font-family:var(--f-disp);font-weight:700;font-size:20px;text-transform:uppercase;color:var(--white)}
.form-ok p{font-size:13.5px;color:var(--mist);max-width:36ch}
.steps-v{display:flex;flex-direction:column;gap:22px;margin-top:30px}
.stepv{display:flex;gap:16px;align-items:flex-start}
.stepv-n{width:38px;height:38px;flex:none;border:1px solid var(--line-2);background:var(--ink-850);display:flex;align-items:center;justify-content:center;
  font-family:var(--f-disp);font-weight:800;font-size:16px;color:var(--blue-bright)}
.stepv-b strong{display:block;font-family:var(--f-disp);font-weight:700;font-size:14px;text-transform:uppercase;color:var(--white);margin-bottom:4px}
.stepv-b p{font-size:13px;color:var(--mist);line-height:1.6}

/* ---- inner-page responsive --------------------------------- */
@media(max-width:1040px){
  .svc-grid,.price-grid{grid-template-columns:1fr 1fr}
  .addon-grid{grid-template-columns:1fr 1fr}
  .steps{grid-template-columns:1fr 1fr;gap:36px 0}.steps::before{display:none}
  .cols3{grid-template-columns:1fr}
  .about,.connect{grid-template-columns:1fr;gap:40px}
  .intro{grid-template-columns:1fr}.intro .lead{justify-self:start}
}
@media(max-width:680px){
  .svc-grid,.price-grid,.addon-grid{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr}
  .frow{grid-template-columns:1fr}
  .tabs{width:100%}.tab{flex:1;text-align:center;padding:11px 8px}
}

/* ============================================================
   ICONS (framed-box motif)
   ============================================================ */
.ic{width:48px;height:48px;flex:none;border:1px solid var(--line-2);display:inline-flex;align-items:center;justify-content:center;
  color:var(--blue-bright);margin-bottom:18px;transition:border-color .35s var(--ease),background .35s,color .35s}
.ic svg{width:23px;height:23px;display:block}
.cream .ic{border-color:var(--cream-line);color:var(--cream-blue)}
.svc-card:hover .ic,.why-card:hover .ic{border-color:var(--blue);background:var(--blue-tint)}
.m2-cell:hover .ic{border-color:var(--cream-blue)}
.svc-ic.ic{margin:24px 0 22px}
.why-ic.ic{margin-bottom:18px}
.ci-ic{color:var(--blue-bright)}.ci-ic svg{width:21px;height:21px}

/* ============================================================
   MISSION (redesigned)
   ============================================================ */
.mission2{max-width:1180px}
.m2-statement{font-family:var(--f-disp);font-weight:800;text-transform:uppercase;line-height:.99;letter-spacing:-.02em;
  color:var(--cream-ink);font-size:clamp(34px,5.4vw,76px);max-width:17ch;margin:26px 0 24px}
.m2-statement em{font-style:normal;color:var(--cream-blue)}
.m2-sub{font-size:16px;line-height:1.85;color:var(--cream-fog);max-width:60ch;margin-bottom:clamp(40px,6vh,66px)}
.m2-grid{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid var(--cream-line);border-left:1px solid var(--cream-line)}
.m2-cell{padding:32px 26px;border-right:1px solid var(--cream-line);border-bottom:1px solid var(--cream-line);
  transition:background .35s var(--ease),transform .35s var(--ease)}
.m2-cell:hover{background:var(--cream-2);transform:translateY(-5px)}
.m2-n{font-family:var(--f-mono);font-size:10px;letter-spacing:.2em;color:var(--cream-blue);margin-bottom:18px;display:block}
.m2-t{font-family:var(--f-disp);font-weight:700;font-size:15.5px;text-transform:uppercase;letter-spacing:.01em;color:var(--cream-ink);margin-bottom:9px}
.m2-x{font-size:13px;line-height:1.62;color:var(--cream-fog)}

/* ============================================================
   CONTRAST FIXES (cream)
   ============================================================ */
.cream .dim{color:#a99f88}                 /* was washing out on cream */
.tav{background:var(--cream-ink);border-color:var(--cream-ink);color:var(--cream)}  /* dark avatar pops on cream */
.tmember:hover .tav{background:var(--cream-blue);border-color:var(--cream-blue)}
.trole{color:#2a4fb0}

/* ============================================================
   SCROLL PROGRESS
   ============================================================ */
#scrollbar{position:fixed;top:0;left:0;height:2px;width:0;z-index:700;
  background:linear-gradient(90deg,var(--blue),var(--blue-bright));box-shadow:0 0 12px var(--blue-glow);transition:width .1s linear}

/* ============================================================
   CUSTOM CURSOR (desktop pointers only)
   ============================================================ */
#cursor,#cursor-dot{position:fixed;top:0;left:0;pointer-events:none;z-index:9999;border-radius:50%;
  transform:translate(-50%,-50%);opacity:0;mix-blend-mode:difference}
#cursor{width:34px;height:34px;border:1.5px solid #6f9bff;transition:width .25s var(--ease),height .25s var(--ease),opacity .3s,background .25s}
#cursor-dot{width:6px;height:6px;background:#fff;transition:opacity .3s}
body.cursor-live #cursor,body.cursor-live #cursor-dot{opacity:1}
body.cursor-hot #cursor{width:54px;height:54px;background:rgba(83,132,255,.18)}
@media(hover:hover) and (pointer:fine){body.cursor-on{cursor:none}body.cursor-on a,body.cursor-on button,body.cursor-on input,body.cursor-on select,body.cursor-on textarea{cursor:none}}
@media(hover:none),(pointer:coarse){#cursor,#cursor-dot{display:none}}

/* magnetic buttons keep transition smooth */
.btn{will-change:transform}

/* ============================================================
   REVEAL — word rise (high-level headings)
   ============================================================ */
.reveal-words{--wd:0ms}
.reveal-words .w{display:inline-block;overflow:hidden;vertical-align:top;margin-right:.26em}
.reveal-words .w>span{display:inline-block;transform:translateY(112%);transition:transform .8s var(--ease-out)}
.reveal-words.in .w>span{transform:none}

/* richer card reveal */
.reveal{opacity:0;transform:translateY(30px)}
@media(max-width:680px){
  .m2-grid{grid-template-columns:1fr 1fr}
  .hero-h1{font-size:clamp(52px,15vw,96px)}
}
@media(max-width:440px){
  .m2-grid{grid-template-columns:1fr}
}

/* ============================================================
   WOW LAYER — loader, hero fx, tilt, shine
   ============================================================ */
/* services now 2-up (4 cards) */
.svc-grid{grid-template-columns:repeat(2,1fr)}
.svc-card{min-height:336px}
@media(max-width:680px){.svc-grid{grid-template-columns:1fr}}

/* intro loader */
#loader{position:fixed;inset:0;z-index:1000;background:var(--ink-900);display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:30px;transition:transform .85s var(--ease-out)}
#loader.hide{transform:translateY(-101%)}
#loader .ld-logo{transform:scale(1.5);color:var(--white)}
#loader .ld-bar{width:210px;height:2px;background:var(--line);overflow:hidden}
#loader .ld-bar i{display:block;height:100%;width:6%;background:linear-gradient(90deg,var(--blue),var(--blue-bright));transition:width 1.05s var(--ease)}
#loader.fill .ld-bar i{width:100%}
#loader .ld-k{font-family:var(--f-mono);font-size:10px;letter-spacing:.3em;color:var(--fog);text-transform:uppercase}

/* hero living backdrop */
.hero-fx{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.fx-glow{position:absolute;width:540px;height:540px;right:-6%;top:0;
  background:radial-gradient(circle,var(--blue-tint),transparent 64%);filter:blur(26px)}
.fx-frame{position:absolute;border:1px solid var(--line-2);opacity:.55}
.fx-frame.f1{width:330px;height:330px;right:9%;top:15%;animation:drift1 17s var(--ease) infinite}
.fx-frame.f2{width:170px;height:170px;right:27%;top:48%;border-color:var(--blue-deep);animation:drift2 13s var(--ease) infinite}
.fx-frame.f3{width:116px;height:116px;right:7%;bottom:16%;animation:drift1 21s var(--ease) infinite reverse}
@keyframes drift1{0%,100%{transform:translateY(0) rotate(0)}50%{transform:translateY(-28px) rotate(7deg)}}
@keyframes drift2{0%,100%{transform:translateY(0) rotate(45deg)}50%{transform:translateY(26px) rotate(53deg)}}
@media(max-width:1040px){.hero-fx{opacity:.5}}
@media(max-width:680px){.fx-frame{display:none}}

/* 3D tilt smoothing */
.svc-card,.why-card,.m2-cell,.pcard,.cell,.addon,.connect-panel{transform-style:preserve-3d}

/* button shine sweep */
.btn-fill{position:relative;overflow:hidden;isolation:isolate}
.btn-fill::after{content:'';position:absolute;top:0;left:0;width:100%;height:100%;z-index:-1;
  background:linear-gradient(100deg,transparent 32%,rgba(255,255,255,.24),transparent 68%);
  transform:translateX(-130%);transition:transform .7s var(--ease)}
.btn-fill:hover::after{transform:translateX(130%)}
.cream .btn-fill::after{background:linear-gradient(100deg,transparent 32%,rgba(255,255,255,.16),transparent 68%)}

/* nav-cta + pbtn-feat get a subtle glow pulse cue (no layout) */
.nav-cta{position:relative;overflow:hidden;isolation:isolate}
.nav-cta::after{content:'';position:absolute;inset:0;z-index:-1;background:linear-gradient(100deg,transparent 32%,rgba(255,255,255,.22),transparent 68%);transform:translateX(-130%);transition:transform .7s var(--ease)}
.nav-cta:hover::after{transform:translateX(130%)}

/* ============================================================
   NAV ACTIONS + CART BUTTON
   ============================================================ */
.nav-actions{display:flex;align-items:center;gap:14px}
.nav-cart{position:relative;width:42px;height:42px;border:1px solid var(--line-2);background:none;color:var(--cloud);
  display:flex;align-items:center;justify-content:center;transition:.25s var(--ease)}
.nav-cart svg{width:20px;height:20px}
.nav-cart:hover{border-color:var(--blue-bright);color:#fff;background:var(--blue-tint)}
.cart-badge{position:absolute;top:-7px;right:-7px;min-width:18px;height:18px;padding:0 4px;border-radius:9px;
  background:var(--blue);color:#fff;font-family:var(--f-mono);font-size:10px;display:flex;align-items:center;justify-content:center;
  box-shadow:0 0 0 2px var(--ink-900);animation:badgePop .3s var(--ease)}
.cart-badge[hidden]{display:none}
@keyframes badgePop{0%{transform:scale(0)}60%{transform:scale(1.25)}100%{transform:scale(1)}}

/* ============================================================
   CART DRAWER
   ============================================================ */
.cart-overlay{position:fixed;inset:0;z-index:790;background:rgba(4,6,11,.62);backdrop-filter:blur(3px);
  opacity:0;pointer-events:none;transition:opacity .4s var(--ease)}
.cart-overlay.open{opacity:1;pointer-events:auto}
.cart-drawer{position:fixed;top:0;right:0;bottom:0;width:min(420px,100%);z-index:800;background:var(--ink-850);
  border-left:1px solid var(--line);display:flex;flex-direction:column;transform:translateX(101%);transition:transform .45s var(--ease-out)}
.cart-drawer.open{transform:none}
.cart-head{display:flex;align-items:flex-start;justify-content:space-between;padding:24px 26px;border-bottom:1px solid var(--line)}
.cart-k{font-family:var(--f-mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--blue-bright);margin-bottom:6px}
.cart-h{font-family:var(--f-disp);font-weight:700;font-size:22px;text-transform:uppercase;color:var(--white)}
.cart-x{width:34px;height:34px;border:1px solid var(--line);background:none;color:var(--mist);font-size:15px;transition:.25s}
.cart-x:hover{border-color:var(--blue-bright);color:#fff}
.cart-body{flex:1;overflow-y:auto;padding:8px 26px}
.cart-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;height:100%;text-align:center;padding:40px 0}
.cart-empty svg{width:46px;height:46px;color:var(--line-2)}
.cart-empty p{font-size:14px;color:var(--mist);max-width:24ch}
.cart-empty .btn{margin-top:4px}
.cart-item{display:grid;grid-template-columns:1fr auto;gap:6px 14px;padding:20px 0;border-bottom:1px solid var(--line)}
.ci-name{font-family:var(--f-disp);font-weight:700;font-size:15px;text-transform:uppercase;color:var(--white)}
.ci-meta{font-family:var(--f-mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--fog);margin-top:4px}
.ci-price{font-family:var(--f-disp);font-weight:700;font-size:16px;color:var(--white);text-align:right;white-space:nowrap}
.ci-price .per{font-family:var(--f-mono);font-size:10px;color:var(--fog)}
.ci-remove{grid-column:1;justify-self:start;margin-top:2px;background:none;border:none;color:var(--fog);
  font-family:var(--f-mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;padding:0;transition:color .2s}
.ci-remove:hover{color:#e0556b}
.cart-foot{padding:22px 26px;border-top:1px solid var(--line);display:flex;flex-direction:column;gap:14px}
.cart-sub{display:flex;justify-content:space-between;align-items:baseline}
.cart-sub span:first-child{font-family:var(--f-mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--mist)}
.cart-sub span:last-child{font-family:var(--f-disp);font-weight:800;font-size:28px;color:var(--white)}
.cart-checkout{justify-content:center;width:100%}
.cart-checkout[disabled]{opacity:.4;pointer-events:none}
.cart-secure{display:flex;align-items:center;justify-content:center;gap:8px;font-family:var(--f-mono);font-size:10px;
  letter-spacing:.08em;color:var(--fog)}
.cart-secure svg{width:14px;height:14px}
.cart-secure b{color:var(--mist);font-weight:400}

/* ============================================================
   MISSION ACCORDION
   ============================================================ */
.mission-split{display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(36px,5vw,80px);align-items:start;margin-top:34px}
.m2-sub{font-size:16px;line-height:1.85;color:var(--cream-fog);max-width:46ch;margin:0}
.acc{border-top:1px solid var(--cream-line)}
.acc-item{border-bottom:1px solid var(--cream-line)}
.acc-head{display:flex;align-items:center;gap:18px;width:100%;background:none;border:none;text-align:left;
  padding:22px 4px;color:var(--cream-ink);transition:padding-left .35s var(--ease)}
.acc-head:hover{padding-left:12px}
.acc-n{font-family:var(--f-mono);font-size:11px;letter-spacing:.16em;color:var(--cream-blue);flex:none}
.acc-t{font-family:var(--f-disp);font-weight:700;font-size:clamp(18px,2vw,24px);text-transform:uppercase;letter-spacing:.01em;flex:1;line-height:1.05}
.acc-sign{position:relative;width:16px;height:16px;flex:none}
.acc-sign::before,.acc-sign::after{content:'';position:absolute;background:var(--cream-blue);transition:transform .4s var(--ease),opacity .3s}
.acc-sign::before{top:50%;left:0;width:100%;height:1.5px;transform:translateY(-50%)}
.acc-sign::after{left:50%;top:0;width:1.5px;height:100%;transform:translateX(-50%)}
.acc-item.open .acc-sign::after{transform:translateX(-50%) scaleY(0);opacity:0}
.acc-item.open .acc-t{color:var(--cream-blue)}
.acc-panel{display:grid;grid-template-rows:0fr;transition:grid-template-rows .45s var(--ease-out)}
.acc-item.open .acc-panel{grid-template-rows:1fr}
.acc-panel>.acc-inner{overflow:hidden;min-height:0}
.acc-inner{display:flex;gap:18px;align-items:flex-start;padding:0 4px 26px}
.acc-inner .ic{margin:0;width:42px;height:42px}
.acc-inner .ic svg{width:20px;height:20px}
.acc-inner p{font-size:14.5px;line-height:1.75;color:var(--cream-fog);max-width:46ch}

/* ============================================================
   WHY-US INTERACTIVE SHOWCASE
   ============================================================ */
.show{display:grid;grid-template-columns:.85fr 1.15fr;gap:1px;background:var(--line);border:1px solid var(--line)}
.show-list{display:flex;flex-direction:column;background:var(--ink-900)}
.show-tab{position:relative;display:flex;align-items:center;gap:16px;background:none;border:none;text-align:left;
  padding:26px 28px;color:var(--mist);border-bottom:1px solid var(--line);flex:1;transition:background .3s,color .3s}
.show-tab:last-child{border-bottom:none}
.show-tab:hover{background:var(--panel);color:var(--silver)}
.show-tab.active{background:var(--panel);color:var(--white)}
.show-tn{font-family:var(--f-mono);font-size:11px;letter-spacing:.16em;color:var(--fog);flex:none}
.show-tab.active .show-tn{color:var(--blue-bright)}
.show-tt{font-family:var(--f-disp);font-weight:700;font-size:clamp(15px,1.5vw,18px);text-transform:uppercase;letter-spacing:.01em;line-height:1.1}
.show-bar{position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--blue-bright);transform:scaleY(0);transform-origin:top;transition:transform .35s var(--ease)}
.show-tab.active .show-bar{transform:scaleY(1)}
.show-stage{position:relative;background:var(--panel);overflow:hidden;min-height:340px}
.show-card{position:absolute;inset:0;padding:clamp(34px,3.6vw,52px);display:flex;flex-direction:column;
  opacity:0;transform:translateY(16px);pointer-events:none;transition:opacity .5s var(--ease),transform .5s var(--ease)}
.show-card.active{opacity:1;transform:none;pointer-events:auto;position:relative}
.show-wm{position:absolute;right:18px;top:8px;font-family:var(--f-disp);font-weight:800;font-size:140px;line-height:1;color:var(--white);opacity:.035}
.show-card .ic{margin-bottom:24px;width:54px;height:54px}
.show-card .ic svg{width:26px;height:26px}
.show-h{font-family:var(--f-disp);font-weight:800;font-size:clamp(22px,2.6vw,32px);text-transform:uppercase;letter-spacing:-.01em;color:var(--white);margin-bottom:14px;max-width:18ch;line-height:1.04}
.show-x{font-size:15px;line-height:1.8;color:var(--mist);max-width:48ch}
.show-proof{margin-top:auto;padding-top:22px;font-family:var(--f-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--blue-bright);display:flex;align-items:center;gap:10px}
.show-proof::before{content:'';width:22px;height:1px;background:var(--blue)}

/* ============================================================
   CO-FOUNDER TEAM (about)
   ============================================================ */
.cofound{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--cream-line);border:1px solid var(--cream-line);margin-top:8px}
.cof{background:var(--cream);padding:30px 26px;display:flex;flex-direction:column;transition:background .35s,transform .35s var(--ease)}
.cof:hover{background:var(--cream-2);transform:translateY(-5px)}
.cof-av{width:72px;height:72px;border:1px solid var(--cream-ink);background:var(--cream-ink);color:var(--cream);
  display:flex;align-items:center;justify-content:center;font-family:var(--f-disp);font-weight:800;font-size:25px;margin-bottom:22px;transition:background .35s}
.cof:hover .cof-av{background:var(--cream-blue);border-color:var(--cream-blue)}
.cof-badge{font-family:var(--f-mono);font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:var(--cream-blue);margin-bottom:8px}
.cof-name{font-family:var(--f-disp);font-weight:800;font-size:21px;text-transform:uppercase;color:var(--cream-ink);line-height:1;margin-bottom:7px}
.cof-role{font-family:var(--f-mono);font-size:11px;letter-spacing:.04em;color:var(--cream-fog);margin-bottom:16px;min-height:2.6em}
.cof-bio{font-size:13px;line-height:1.66;color:var(--cream-fog);padding-top:16px;border-top:1px solid var(--cream-line)}
/* capabilities / wider-team strip */
.caps{display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid var(--line);border-left:1px solid var(--line);margin-top:8px}
.cap{padding:28px 26px;border-right:1px solid var(--line);border-bottom:1px solid var(--line);transition:background .3s}
.cap:hover{background:var(--panel)}
.cap .ic{margin-bottom:16px;width:44px;height:44px}
.cap .ic svg{width:21px;height:21px}
.cap-t{font-family:var(--f-disp);font-weight:700;font-size:16px;text-transform:uppercase;color:var(--white);margin-bottom:8px}
.cap-x{font-size:13px;line-height:1.65;color:var(--mist)}

/* ============================================================
   CHECKOUT
   ============================================================ */
.checkout{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(32px,4vw,64px);align-items:start;margin-top:8px}
.co-panel{border:1px solid var(--line);background:var(--ink-850);padding:clamp(26px,3vw,38px)}
.co-k{font-family:var(--f-mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--blue-bright);margin-bottom:18px;display:flex;align-items:center;gap:10px}
.co-k .step-i{width:20px;height:20px;border:1px solid var(--blue);color:var(--blue-bright);display:flex;align-items:center;justify-content:center;font-size:10px;border-radius:50%}
.co-summary{border:1px solid var(--line);background:var(--ink-850);padding:clamp(24px,3vw,34px);position:sticky;top:96px}
.co-line{display:flex;justify-content:space-between;gap:14px;padding:16px 0;border-bottom:1px solid var(--line)}
.co-line .l-name{font-family:var(--f-disp);font-weight:700;font-size:14.5px;text-transform:uppercase;color:var(--white)}
.co-line .l-meta{font-family:var(--f-mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--fog);margin-top:3px}
.co-line .l-price{font-family:var(--f-disp);font-weight:700;font-size:15px;color:var(--white);white-space:nowrap}
.co-line .l-rm{display:block;background:none;border:none;color:var(--fog);font-family:var(--f-mono);font-size:9px;letter-spacing:.1em;text-transform:uppercase;padding:0;margin-top:6px;transition:color .2s}
.co-line .l-rm:hover{color:#e0556b}
.co-totals{padding-top:18px;display:flex;flex-direction:column;gap:10px}
.co-trow{display:flex;justify-content:space-between;font-size:13px;color:var(--mist)}
.co-trow.grand{padding-top:14px;border-top:1px solid var(--line);margin-top:6px}
.co-trow.grand span:first-child{font-family:var(--f-mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--silver)}
.co-trow.grand span:last-child{font-family:var(--f-disp);font-weight:800;font-size:30px;color:var(--white)}
.pay-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.card-field{position:relative}
.card-field .brand{position:absolute;right:14px;top:50%;transform:translateY(-50%);font-family:var(--f-mono);font-size:9px;letter-spacing:.1em;color:var(--fog)}
.co-badges{display:flex;align-items:center;gap:14px;margin-top:4px;flex-wrap:wrap}
.co-badges span{font-family:var(--f-mono);font-size:10px;letter-spacing:.06em;color:var(--fog);display:flex;align-items:center;gap:7px}
.co-badges svg{width:14px;height:14px;color:var(--blue-bright)}
.co-demo-note{font-family:var(--f-mono);font-size:10px;line-height:1.6;letter-spacing:.02em;color:var(--fog);
  border:1px dashed var(--line-2);padding:12px 14px;margin-top:4px}
.co-demo-note b{color:var(--blue-bright);font-weight:400}
.co-stripe-copy{font-size:13px;line-height:1.6;color:var(--mist);margin:2px 0 4px}
.pay-error{display:none;font-family:var(--f-mono);font-size:11px;line-height:1.5;letter-spacing:.02em;
  color:#e0556b;border:1px solid rgba(224,85,107,.4);background:rgba(224,85,107,.07);padding:11px 13px;margin-top:10px}
.co-empty{text-align:center;padding:60px 0;display:flex;flex-direction:column;align-items:center;gap:18px}
.co-empty svg{width:50px;height:50px;color:var(--line-2)}
.co-empty p{font-size:15px;color:var(--mist)}

/* ============================================================
   MOBILE — new components
   ============================================================ */
@media(max-width:920px){
  .mission-split{grid-template-columns:1fr;gap:30px}
  .show{grid-template-columns:1fr}
  .show-list{flex-direction:row;overflow-x:auto;scrollbar-width:none}
  .show-list::-webkit-scrollbar{display:none}
  .show-tab{border-bottom:none;border-right:1px solid var(--line);min-width:200px;padding:18px 20px}
  .show-bar{top:auto;bottom:0;left:0;right:0;width:auto;height:3px;transform:scaleX(0);transform-origin:left}
  .show-tab.active .show-bar{transform:scaleX(1)}
  .show-stage{min-height:300px}
  .cofound{grid-template-columns:1fr}
  .caps{grid-template-columns:1fr}
  .checkout{grid-template-columns:1fr;gap:28px}
  .co-summary{position:static;order:-1}
}
@media(max-width:560px){
  .pay-row{grid-template-columns:1fr}
  .show-wm{font-size:96px}
  .cart-drawer{width:100%}
}

/* pricing button (now <button>) + add-on add button */
.pbtn{width:100%;background:none;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:9px}
.pbtn .ar{font-family:var(--f-body);transition:transform .3s var(--ease)}
.pbtn:hover .ar{transform:translateY(-2px) scale(1.1)}
.addon{position:relative;display:flex;flex-direction:column}
.addon-x{margin-bottom:18px}
.addon-add{margin-top:auto;align-self:flex-start;display:inline-flex;align-items:center;gap:8px;
  padding:9px 16px;border:1px solid var(--line-2);background:none;color:var(--cloud);
  font-family:var(--f-mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;transition:.25s var(--ease)}
.addon-add:hover{border-color:var(--blue-bright);color:#fff;background:var(--blue-tint)}
.addon-add .ar{font-size:14px}

/* ============================================================
   TYPE SCALE BOOST — larger, more readable body copy
   Appended last so it overrides the base sizes above.
   ============================================================ */
/* nav + buttons */
.nav-links a{font-size:12.5px}
.btn{font-size:13px}
/* home: mission + why-us */
.mission-body{font-size:17.5px}
.pillar-t{font-size:16px}
.pillar-x{font-size:14.5px}
.why-x{font-size:15.5px}
/* services */
.svc-x{font-size:15px}
.svc-num{font-size:12px}
/* pricing */
.pplan{font-size:12px}
.pdesc{font-size:14.5px}
.pfeat li{font-size:15px}
.pbtn{font-size:12px}
.pnote{font-size:11px}
.addon-n{font-size:16.5px}
.addon-x{font-size:14px}
/* process / timeline */
.cell-k{font-size:11px}
.cell-list li{font-size:15px}
.stepv-b strong{font-size:15.5px}
.stepv-b p{font-size:14.5px}
/* about / team */
.about-body p{font-size:16.5px}
.about-body .pull,.pull{font-size:clamp(22px,2.4vw,30px)}
.cof-bio{font-size:15px}
.cof-role{font-size:12.5px}
.cof-badge{font-size:10px}
.tname{font-size:18.5px}
.trole{font-size:10.5px}
.tbio{font-size:14px}
/* connect / forms / checkout */
.ci-v{font-size:15px}
.ci-k{font-size:10.5px}
.cp-row{font-size:15px}
.cp-row span:last-child{font-size:13.5px}
.fg label{font-size:11px}
.fg input,.fg select,.fg textarea{font-size:15.5px}
/* shared CTAs + footer */
.page-cta p{font-size:16.5px}
.foot-col a{font-size:15px}

/* ============================================================
   MOBILE POLISH — small-screen refinements (≤480px)
   Ensures clean layout & comfortable type down to 320px.
   ============================================================ */
@media(max-width:600px){
  .foot-top{grid-template-columns:1fr;gap:30px}
  .hero-stats{flex-wrap:wrap;gap:22px 32px}
}
@media(max-width:480px){
  /* hero: keep the headline bold but never overflow */
  .hero-h1{font-size:clamp(44px,13.5vw,84px)}
  .hero-sub{font-size:15px}
  /* stack hero stats two-up so numbers stay legible */
  .hero-stats{gap:18px 28px}
  .hstat-n{font-size:32px}
  /* roomier tap targets + comfortable reading on phones */
  .btn{padding:14px 22px}
  .nav-links a{font-size:16px}
  /* timeline / value cards: a touch more breathing room */
  .cell{padding:26px 22px}
  /* footer bottom row stacks cleanly */
  .foot-bottom{flex-direction:column;align-items:flex-start;gap:12px}
  .foot-legal{gap:18px}
  /* checkout summary + panels fill width comfortably */
  .co-panel,.co-summary{padding:24px 20px}
  /* showcase tabs keep a sensible min width when scrolling */
  .show-tab{min-width:168px}
}
@media(max-width:360px){
  .hero-stats{flex-direction:column;gap:16px}
  .display{font-size:clamp(34px,12vw,56px)}
}
