/* ═══════════════════════════════════════════════════
   TDA — Premium Websites for Perth Businesses
   v2.0 · Cinematic / Studio Freight rebuild
═══════════════════════════════════════════════════ */

/* ════════════ TOKENS ════════════ */
:root{
  /* Surfaces */
  --bg:        #0A0A0B;
  --bg-2:      #060607;
  --s1:        #111113;
  --s2:        #18181B;
  --s3:        #222226;
  --s4:        #2C2C31;

  /* Borders */
  --b:         rgba(255,255,255,.06);
  --bh:        rgba(255,255,255,.12);
  --bb:        rgba(255,255,255,.20);

  /* Text */
  --txt:       #F0EEE9;
  --txt-2:     #A8A8B0;
  --txt-3:     #6E6E76;
  --txt-4:     #44444A;

  /* Accents */
  --acc:       #4F8EF7;
  --acc-2:     #7DB3FF;
  --acc-dim:   rgba(79,142,247,.18);
  --acc-glow:  rgba(79,142,247,.30);
  --gold:      #C9A96E;
  --warm:      #E8DCC4;

  /* Typography */
  --f-h:       'Bricolage Grotesque', sans-serif;
  --f-b:       'DM Sans', sans-serif;
  --f-m:       'JetBrains Mono', monospace;
  --f-s:       'Instrument Serif', serif;

  /* Layout */
  --nav-h:     76px;
  --pad-x:     clamp(24px, 5vw, 80px);
  --pad-y:     clamp(96px, 14vh, 180px);
  --max-w:     1440px;

  /* Easing */
  --ease-out:  cubic-bezier(.16,1,.3,1);
  --ease-in:   cubic-bezier(.7,0,.84,0);
  --ease-io:   cubic-bezier(.83,0,.17,1);
}

/* ════════════ RESET ════════════ */
*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:auto; -webkit-text-size-adjust:100%; }
html.lenis,html.lenis body{ height:auto; }
.lenis.lenis-smooth{ scroll-behavior:auto!important; }
.lenis.lenis-smooth [data-lenis-prevent]{ overscroll-behavior:contain; }
.lenis.lenis-stopped{ overflow:hidden; }

body{
  background:var(--bg);
  color:var(--txt);
  font-family:var(--f-b);
  font-size:15px;
  font-weight:400;
  line-height:1.6;
  overflow-x:hidden;
  min-height:100vh;
  cursor:none;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
}

img,svg{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ background:none; border:none; color:inherit; font:inherit; cursor:none; }
ul{ list-style:none; }
input,textarea,select{ font:inherit; color:inherit; background:transparent; border:none; outline:none; cursor:none; }
sup{ font-size:.55em; vertical-align:super; letter-spacing:0; }

::selection{ background:var(--acc); color:var(--bg); }

/* Hide cursor on touch */
@media (hover:none){
  body,a,button,input,textarea{ cursor:auto; }
  .cur-dot,.cur-ring{ display:none!important; }
}

/* ════════════ GLOBAL UTIL ════════════ */
.mono{ font-family:var(--f-m); font-variant-numeric:tabular-nums; }
.skip{
  position:fixed; left:-9999px; top:0; padding:12px 18px;
  background:var(--acc); color:var(--bg); z-index:9999; font-weight:600;
}
.skip:focus{ left:12px; top:12px; }

em{ font-family:var(--f-s); font-style:italic; font-weight:400; color:var(--warm); letter-spacing:-.01em; }

/* ════════════ GRAIN ════════════ */
.grain{
  position:fixed; inset:-5%;
  width:110%; height:110%;
  pointer-events:none;
  z-index:9000;
  opacity:.045;
  background-image:url("data:image/svg+xml;utf8,<svg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.95' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1  0 0 0 0 1  0 0 0 0 1  0 0 0 1 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  background-size:200px 200px;
  will-change:transform;
  transform:translate3d(0,0,0);
  backface-visibility:hidden;
  animation:grain 8s steps(6) infinite;
}
@keyframes grain{
  0%{ transform:translate3d(0,0,0); }
  10%{ transform:translate3d(-5%,-5%,0); }
  20%{ transform:translate3d(-10%,5%,0); }
  30%{ transform:translate3d(5%,-10%,0); }
  40%{ transform:translate3d(-5%,15%,0); }
  50%{ transform:translate3d(-10%,5%,0); }
  60%{ transform:translate3d(15%,0,0); }
  70%{ transform:translate3d(0,10%,0); }
  80%{ transform:translate3d(-15%,0,0); }
  90%{ transform:translate3d(10%,5%,0); }
  100%{ transform:translate3d(0,0,0); }
}

/* ════════════ CURSOR ════════════ */
.cur-dot,.cur-ring{
  position:fixed; top:0; left:0;
  pointer-events:none; z-index:9999;
  opacity:0;
}
.cur-dot{
  width:6px; height:6px; border-radius:50%;
  background:var(--acc-2);
}
.cur-ring{
  width:36px; height:36px; border-radius:50%;
  border:1px solid rgba(240,238,233,.5);
  transition:width .25s var(--ease-out), height .25s var(--ease-out), background .25s var(--ease-out), border-color .25s var(--ease-out);
}
.cur-ring.hov{
  width:64px; height:64px;
  background:rgba(240,238,233,.06);
  border-color:rgba(240,238,233,.9);
}
.cur-ring.cta{
  width:78px; height:78px;
  background:var(--acc);
  border-color:var(--acc);
  mix-blend-mode:normal;
}

/* ════════════ LOADER ════════════ */
.loader{
  position:fixed; inset:0; z-index:10000;
  background:var(--bg);
  display:flex; align-items:center; justify-content:center;
  overflow:hidden;
}
.loader-grid{
  position:absolute; inset:0;
  background-image:
    linear-gradient(to right, var(--b) 1px, transparent 1px),
    linear-gradient(to bottom, var(--b) 1px, transparent 1px);
  background-size:80px 80px;
  opacity:.4;
}
.loader-inner{
  position:relative;
  width:min(90vw, 720px);
  display:flex; flex-direction:column;
  gap:48px;
  z-index:2;
}
.loader-top{
  display:flex; justify-content:space-between; align-items:center;
  font-family:var(--f-m); font-size:11px;
  text-transform:uppercase; letter-spacing:.2em;
  color:var(--txt-3);
  border-bottom:1px solid var(--b);
  padding-bottom:14px;
}
.loader-count{ color:var(--txt); font-weight:500; }
.loader-mark{
  font-family:var(--f-h); font-weight:800;
  font-size:clamp(96px, 18vw, 220px);
  line-height:.85;
  letter-spacing:-.06em;
  display:flex;
  color:var(--txt);
  overflow:hidden;
}
.lm-t,.lm-d,.lm-a{
  display:inline-block;
  transform:translateY(100%);
  opacity:0;
}
.loader-bar{
  height:1px; width:100%;
  background:var(--b);
  position:relative;
  overflow:hidden;
}
.loader-bar-fill{
  position:absolute; top:0; left:0; bottom:0;
  width:0%;
  background:linear-gradient(90deg, var(--acc), var(--acc-2));
  box-shadow:0 0 12px var(--acc-glow);
}
.loader-meta{
  display:flex; justify-content:space-between;
  font-family:var(--f-m); font-size:11px;
  text-transform:uppercase; letter-spacing:.2em;
  color:var(--txt-3);
}
.loader-curtain{
  position:absolute; left:0; right:0;
  height:50vh;
  background:var(--bg);
  z-index:3;
  transform:translateY(0);
}
.l-curtain-1{ top:0; }
.l-curtain-2{ bottom:0; }

/* ════════════ NAVIGATION ════════════ */
.nav{
  position:fixed; top:0; left:0; right:0;
  z-index:1000;
  padding:18px var(--pad-x);
  transition:background .4s var(--ease-out), backdrop-filter .4s var(--ease-out), border-color .4s var(--ease-out);
  border-bottom:1px solid transparent;
}
.nav.is-scrolled{
  background:rgba(10,10,11,.72);
  backdrop-filter:blur(12px) saturate(130%);
  -webkit-backdrop-filter:blur(12px) saturate(130%);
  border-bottom-color:var(--b);
  padding:14px var(--pad-x);
}
.nav-wrap{
  max-width:var(--max-w);
  margin:0 auto;
  display:flex; align-items:center; justify-content:space-between;
  gap:32px;
}
.nav-logo{
  display:flex; align-items:center; gap:10px;
  font-family:var(--f-h); font-weight:800;
  font-size:18px; letter-spacing:-.02em;
  color:var(--txt);
}
.nav-logo-mark{
  width:32px; height:32px;
  display:flex; align-items:center; justify-content:center;
  color:var(--txt);
  transition:transform .6s var(--ease-out), color .3s;
}
.nav-logo:hover .nav-logo-mark{
  transform:rotate(180deg);
  color:var(--acc-2);
}
.nav-logo-text sup{ color:var(--txt-3); font-weight:500; }

.nav-links{
  display:flex; gap:6px; align-items:center;
}
.nav-link{
  position:relative;
  padding:8px 14px; border-radius:999px;
  font-family:var(--f-m); font-size:11px;
  text-transform:uppercase; letter-spacing:.16em;
  color:var(--txt-2);
  transition:color .3s var(--ease-out);
  overflow:hidden;
}
.nav-link span{ position:relative; z-index:1; }
.nav-link::before{
  content:""; position:absolute; inset:0;
  background:var(--s2);
  border-radius:inherit;
  transform:scale(.7);
  opacity:0;
  transition:transform .35s var(--ease-out), opacity .35s var(--ease-out);
}
.nav-link:hover{ color:var(--txt); }
.nav-link:hover::before,
.nav-link.active::before{
  transform:scale(1); opacity:1;
}
.nav-link.active{ color:var(--txt); }

.nav-cta{
  display:inline-flex; align-items:center; gap:10px;
  padding:11px 18px 11px 20px;
  background:var(--txt);
  color:var(--bg);
  border-radius:999px;
  font-family:var(--f-m); font-size:11px; font-weight:500;
  text-transform:uppercase; letter-spacing:.14em;
  transition:background .3s var(--ease-out), color .3s, transform .4s var(--ease-out);
  position:relative;
  overflow:hidden;
}
.nav-cta::before{
  content:""; position:absolute; inset:0;
  background:var(--acc);
  transform:translateY(100%);
  transition:transform .5s var(--ease-out);
  z-index:0;
}
.nav-cta-text,.nav-cta-arrow{ position:relative; z-index:1; }
.nav-cta-arrow{
  width:14px; height:14px;
  display:flex; align-items:center; justify-content:center;
  transition:transform .4s var(--ease-out);
}
.nav-cta:hover{ color:var(--txt); }
.nav-cta:hover::before{ transform:translateY(0); }
.nav-cta:hover .nav-cta-arrow{ transform:translateX(4px); }

.nav-burger{
  display:none;
  width:44px; height:44px;
  align-items:center; justify-content:center;
  flex-direction:column; gap:5px;
}
.nav-burger span{
  display:block; width:22px; height:1.5px;
  background:var(--txt);
  transition:transform .4s var(--ease-out), opacity .3s;
}
.nav-burger.open span:nth-child(1){ transform:translateY(3.5px) rotate(45deg); }
.nav-burger.open span:nth-child(2){ transform:translateY(-3px) rotate(-45deg); }

/* Mobile menu */
.mob-menu{
  position:fixed; inset:0;
  background:var(--bg);
  z-index:999;
  padding:var(--nav-h) var(--pad-x) 40px;
  display:flex; flex-direction:column;
  transform:translateY(-100%);
  transition:transform .6s var(--ease-io);
}
.mob-menu.open{ transform:translateY(0); }
.mob-menu-inner{
  flex:1;
  display:flex; flex-direction:column; justify-content:center;
  gap:8px;
  border-top:1px solid var(--b);
  padding-top:32px;
}
.mob-link{
  font-family:var(--f-h); font-weight:700;
  font-size:clamp(28px, 7vw, 44px);
  letter-spacing:-.03em;
  color:var(--txt);
  padding:14px 0;
  display:flex; align-items:baseline; gap:18px;
  border-bottom:1px solid var(--b);
  transition:color .3s, padding .3s;
}
.mob-link:hover{ color:var(--acc-2); padding-left:12px; }
.mob-num{
  font-family:var(--f-m); font-weight:400;
  font-size:12px; letter-spacing:.2em;
  color:var(--txt-3);
}
.mob-foot{
  margin-top:40px;
  padding-top:24px;
  border-top:1px solid var(--b);
  display:flex; flex-direction:column; gap:6px;
  font-family:var(--f-m); font-size:13px;
  color:var(--txt-2);
}

/* ════════════ BUTTONS ════════════ */
.btn{
  position:relative;
  display:inline-flex; align-items:center; gap:12px;
  padding:16px 26px 16px 28px;
  border-radius:999px;
  font-family:var(--f-m); font-size:12px; font-weight:500;
  text-transform:uppercase; letter-spacing:.15em;
  transition:transform .5s var(--ease-out), color .35s;
  overflow:hidden;
  white-space:nowrap;
}
.btn-text,.btn-arrow{ position:relative; z-index:2; }
.btn-arrow{
  width:16px; height:16px;
  display:flex; align-items:center; justify-content:center;
  transition:transform .4s var(--ease-out);
}
.btn:hover .btn-arrow{ transform:translateX(5px); }

.btn-primary{
  background:var(--txt);
  color:var(--bg);
}
.btn-primary::before{
  content:""; position:absolute; inset:0;
  background:var(--acc);
  transform:translateY(101%);
  transition:transform .55s var(--ease-out);
  z-index:1;
}
.btn-primary:hover{ color:var(--txt); }
.btn-primary:hover::before{ transform:translateY(0); }

.btn-ghost{
  color:var(--txt);
  border:1px solid var(--bh);
  background:transparent;
}
.btn-ghost::before{
  content:""; position:absolute; inset:0;
  background:var(--s2);
  transform:translateY(101%);
  transition:transform .55s var(--ease-out);
  z-index:1;
}
.btn-ghost:hover{ border-color:var(--bb); }
.btn-ghost:hover::before{ transform:translateY(0); }

.btn-lg{
  padding:20px 32px 20px 34px;
  font-size:13px;
  gap:14px;
}

/* ════════════ SECTION HEAD (eyebrow) ════════════ */
.section-head{
  display:flex; align-items:center; gap:16px;
  margin-bottom:32px;
  font-family:var(--f-m); font-size:11px;
  text-transform:uppercase; letter-spacing:.22em;
  color:var(--txt-2);
}
.sh-num{ color:var(--txt-3); }
.sh-label::before{
  content:""; display:inline-block;
  width:32px; height:1px;
  background:var(--bh);
  vertical-align:middle;
  margin-right:14px;
}

/* ════════════════════════════════════════════════
   HERO
═════════════════════════════════════════════════ */
.hero{
  position:relative;
  min-height:100vh;
  padding:calc(var(--nav-h) + 40px) var(--pad-x) 48px;
  display:flex; flex-direction:column; justify-content:flex-end;
  overflow:hidden;
  background:radial-gradient(ellipse at 50% 30%, #15151A 0%, var(--bg) 60%);
}
.hero-canvas{
  position:absolute; inset:0;
  width:100%; height:100%;
  z-index:0;
  pointer-events:none;
}
.hero-grid{
  position:absolute; inset:0;
  background-image:
    linear-gradient(to right, var(--b) 1px, transparent 1px),
    linear-gradient(to bottom, var(--b) 1px, transparent 1px);
  background-size:80px 80px;
  mask-image:radial-gradient(ellipse at center, black 30%, transparent 75%);
  -webkit-mask-image:radial-gradient(ellipse at center, black 30%, transparent 75%);
  opacity:.5;
  pointer-events:none;
  z-index:1;
}
.hero-edge{
  position:absolute; top:0; bottom:0;
  width:120px;
  pointer-events:none; z-index:2;
}
.hero-edge-l{ left:0; background:linear-gradient(to right, var(--bg) 0%, transparent 100%); }
.hero-edge-r{ right:0; background:linear-gradient(to left, var(--bg) 0%, transparent 100%); }

.hero-inner{
  position:relative;
  z-index:3;
  max-width:var(--max-w);
  margin:0 auto;
  width:100%;
  display:flex; flex-direction:column;
  gap:clamp(28px, 5vh, 56px);
}

.hero-meta{
  display:flex; justify-content:space-between; align-items:center;
  font-family:var(--f-m); font-size:11px;
  text-transform:uppercase; letter-spacing:.18em;
  color:var(--txt-2);
}
.hero-meta-l{ display:flex; align-items:center; gap:10px; }
.hero-meta-r{ display:flex; gap:14px; color:var(--txt-3); }
.hero-meta-dot{
  width:8px; height:8px; border-radius:50%;
  background:#5ec45e;
  box-shadow:0 0 0 4px rgba(94,196,94,.18);
  animation:pulse-dot 2.4s ease-in-out infinite;
}
@keyframes pulse-dot{ 0%,100%{ opacity:1; } 50%{ opacity:.4; } }

.hero-h{
  font-family:var(--f-h); font-weight:800;
  color:var(--txt);
  margin:0;
}
.hero-mark{
  display:flex;
  align-items:flex-start;
  gap:clamp(8px, 1.4vw, 24px);
  line-height:.78;
  font-size:clamp(96px, 20vw, 320px);
  letter-spacing:-.06em;
  position:relative;
}
.hm-letter{
  display:inline-block;
  overflow:hidden;
  line-height:.78;
}
.hm-l{
  display:inline-block;
  transform:translateY(110%);
  opacity:0;
  will-change:transform;
}
.hm-reg{
  font-family:var(--f-s);
  font-size:.15em;
  color:var(--txt-3);
  margin-top:.3em;
  margin-left:.05em;
  font-weight:400;
  opacity:0;
  transform:translateY(20px);
}

.hero-divider{
  display:flex; align-items:center; gap:18px;
  font-family:var(--f-m); font-size:11px;
  text-transform:uppercase; letter-spacing:.2em;
  color:var(--txt-3);
  opacity:0;
}
.hero-divider .hd-l{ color:var(--txt-2); }
.hero-divider .hd-r{ color:var(--txt-3); }
.hd-line{
  flex:1; height:1px;
  background:var(--bh);
  max-width:140px;
}

.hero-tagline{
  font-family:var(--f-h); font-weight:500;
  font-size:clamp(16px, 1.8vw, 25px);
  line-height:1.15;
  letter-spacing:-.02em;
  color:var(--txt-2);
  max-width:1100px;
}
.ht-w{
  display:inline-block;
  opacity:0;
  transform:translateY(20px);
  color:var(--txt);
}
.ht-i{ font-family:var(--f-s); font-weight:400; font-style:italic; color:var(--warm); padding-right:.06em; }
.ht-accent{ color:var(--acc-2); }

.hero-bottom{
  display:grid; grid-template-columns:1fr 1fr;
  gap:60px;
  align-items:end;
  padding-top:32px;
  border-top:1px solid var(--b);
}
.hero-sub{
  max-width:480px;
  font-size:15px; line-height:1.6;
  color:var(--txt-2);
}
.hero-ctas{
  display:flex; gap:12px; justify-content:flex-end; flex-wrap:wrap;
}

.hero-scroll{
  position:absolute;
  left:var(--pad-x); bottom:32px;
  display:flex; flex-direction:column; align-items:center;
  gap:10px;
  font-family:var(--f-m); font-size:10px;
  text-transform:uppercase; letter-spacing:.24em;
  color:var(--txt-3);
  z-index:3;
}
.hero-scroll-line{
  width:1px; height:48px;
  background:linear-gradient(to bottom, var(--bh), transparent);
  position:relative;
}
.hero-scroll-line::after{
  content:""; position:absolute; top:0; left:0; right:0;
  height:14px;
  background:var(--txt);
  animation:scroll-line 2s ease-in-out infinite;
}
@keyframes scroll-line{
  0%{ transform:translateY(-100%); opacity:0; }
  20%{ opacity:1; }
  100%{ transform:translateY(48px); opacity:0; }
}

/* Floating hero cards */
.hero-float{
  position:absolute;
  right:var(--pad-x);
  top:50%;
  transform:translateY(-50%);
  z-index:3;
  display:flex; flex-direction:column;
  gap:18px;
  width:min(320px, 30vw);
  pointer-events:none;
}
.hfloat{
  background:linear-gradient(160deg, rgba(24,24,27,.72), rgba(10,10,11,.6));
  border:1px solid var(--bh);
  border-radius:16px;
  padding:20px 22px;
  display:flex; flex-direction:column;
  gap:10px;
  box-shadow:0 30px 60px -30px rgba(0,0,0,.8);
  opacity:0;
  will-change:transform;
}
.hfloat-1{ transform:translateX(40px); }
.hfloat-2{ margin-left:36px; transform:translateX(40px); }
.hfloat-3{ transform:translateX(40px); }
.hf-top{ display:flex; align-items:center; justify-content:space-between; }
.hf-num{
  font-family:var(--f-h); font-weight:800;
  font-size:42px; letter-spacing:-.04em; line-height:1;
  color:var(--txt);
}
.hf-num sup{ color:var(--acc-2); font-size:.4em; font-weight:500; }
.hf-badge{
  font-family:var(--f-m); font-size:10px;
  text-transform:uppercase; letter-spacing:.16em;
  color:var(--bg);
  background:var(--acc-2);
  padding:4px 10px; border-radius:999px;
}
.hf-label{
  font-family:var(--f-m); font-size:11px;
  text-transform:uppercase; letter-spacing:.12em;
  color:var(--txt-2);
}
.hf-stars svg{ width:84px; height:16px; }
.hf-row{
  display:flex; align-items:center; gap:9px;
  font-size:13px; color:var(--txt);
}
.hf-row-muted{ color:var(--txt-2); font-size:12px; }
.hf-dot{ width:8px; height:8px; border-radius:50%; background:#5ec45e; box-shadow:0 0 0 3px rgba(94,196,94,.18); flex:0 0 8px; }
.hf-pin{ width:8px; height:8px; border-radius:50% 50% 50% 0; transform:rotate(-45deg); background:var(--acc-2); flex:0 0 8px; }

/* ════════════════════════════════════════════════
   MARQUEE
═════════════════════════════════════════════════ */
.marquee{
  padding:32px 0;
  border-top:1px solid var(--b);
  border-bottom:1px solid var(--b);
  overflow:hidden;
  background:var(--bg);
  position:relative;
}
.marquee::before,.marquee::after{
  content:""; position:absolute; top:0; bottom:0; width:120px;
  z-index:2; pointer-events:none;
}
.marquee::before{ left:0; background:linear-gradient(to right, var(--bg), transparent); }
.marquee::after{ right:0; background:linear-gradient(to left, var(--bg), transparent); }
.marquee-track{
  display:flex; width:max-content;
  gap:48px;
  will-change:transform;
}
.marquee-set{
  display:flex; align-items:center; gap:48px;
  font-family:var(--f-h); font-weight:700;
  font-size:clamp(20px, 2.8vw, 34px);
  letter-spacing:-.02em;
  color:var(--txt);
  white-space:nowrap;
}
.m-dot{ color:var(--acc); font-size:.6em; font-weight:400; }
@keyframes marq{
  0%{ transform:translateX(0); }
  100%{ transform:translateX(-50%); }
}

/* ════════════════════════════════════════════════
   MANIFESTO
═════════════════════════════════════════════════ */
.manifesto{
  padding:var(--pad-y) var(--pad-x);
  background:var(--bg);
}
.manifesto-inner{
  max-width:var(--max-w); margin:0 auto;
}
.manifesto-h{
  font-family:var(--f-h); font-weight:500;
  font-size:clamp(22px, 3.1vw, 42px);
  line-height:1.12;
  letter-spacing:-.025em;
  color:var(--txt-2);
  max-width:1180px;
}
.manifesto-h .reveal-w{
  display:inline-block;
  opacity:1;
  transform:translateY(0);
  color:var(--txt-3);
  transition:color .8s var(--ease-out), opacity .8s var(--ease-out), transform .8s var(--ease-out);
}
.manifesto-h.js-hide .reveal-w{ opacity:0; transform:translateY(20px); }
.manifesto-h .reveal-w.is-on{ color:var(--txt); }

.manifesto-foot{
  margin-top:96px;
  padding-top:32px;
  border-top:1px solid var(--b);
  display:grid; grid-template-columns:repeat(4, 1fr);
  gap:32px;
}
.mf-col{ display:flex; flex-direction:column; gap:6px; }
.mf-num{
  font-family:var(--f-h); font-weight:800;
  font-size:clamp(36px, 4vw, 56px);
  letter-spacing:-.04em;
  line-height:1;
  color:var(--txt);
}
.mf-num sup{ color:var(--acc-2); font-size:.45em; font-weight:500; }
.mf-label{
  font-family:var(--f-m); font-size:11px;
  text-transform:uppercase; letter-spacing:.18em;
  color:var(--txt-3);
}

/* ════════════════════════════════════════════════
   SHOWCASE — BEFORE / AFTER
═════════════════════════════════════════════════ */
.showcase{
  position:relative;
  padding:var(--pad-y) var(--pad-x);
  background:var(--bg);
}
.showcase-inner{
  max-width:var(--max-w); margin:0 auto;
}
.showcase-grid{
  display:grid; grid-template-columns:1fr 1fr;
  gap:64px;
  align-items:center;
}
.showcase-text{
  display:flex; flex-direction:column;
  gap:28px;
  align-items:flex-start;
}
.showcase-h{
  font-family:var(--f-h); font-weight:800;
  font-size:clamp(28px, 3.2vw, 50px);
  letter-spacing:-.04em;
  line-height:.96;
  color:var(--txt);
}
.showcase-h .sh-line{ display:block; overflow:hidden; }
.showcase-h .sh-line > span{ display:inline-block; }
.showcase-p{
  color:var(--txt-2);
  font-size:15px;
  line-height:1.55;
  max-width:480px;
}

/* Stats — 2x2 on left */
.showcase-stats{
  display:grid; grid-template-columns:1fr 1fr;
  gap:20px 32px;
  width:100%;
  max-width:440px;
  padding:28px 0;
  border-top:1px solid var(--b);
  border-bottom:1px solid var(--b);
}
.showcase-stats > div{ display:flex; flex-direction:column; gap:4px; }
.ss-n{
  font-family:var(--f-h); font-weight:800;
  font-size:clamp(26px, 2.8vw, 38px);
  letter-spacing:-.04em;
  color:var(--txt);
  font-variant-numeric:tabular-nums;
  line-height:1;
}
.ss-n::after{ content:"%"; color:var(--acc); font-size:.45em; vertical-align:super; margin-left:2px; }
.ss-n[data-count="48"]::after{ content:"hr"; font-family:var(--f-m); font-size:.32em; letter-spacing:.1em; }
.ss-n[data-count="0"]::after{ content:""; }
.ss-n[data-count="0"]::before{ content:"$"; color:var(--acc); }
.ss-l{
  font-family:var(--f-m); font-size:10px;
  text-transform:uppercase; letter-spacing:.18em;
  color:var(--txt-3);
}

/* Before/After wrap — smaller, portrait */
.ba-wrap{
  position:relative;
  width:100%;
  max-width:520px;
  aspect-ratio:5/6;
  border-radius:16px;
  overflow:hidden;
  border:1px solid var(--b);
  background:#b8b6ae;
  cursor:none;
  isolation:isolate;
  box-shadow:0 50px 100px -40px rgba(0,0,0,.7);
  justify-self:end;
  contain:layout paint style;
}
.ba-side{
  position:absolute; inset:0;
  display:flex; flex-direction:column;
  overflow:hidden;
}
.ba-tag{
  position:absolute;
  top:14px; left:14px;
  z-index:5;
  padding:6px 12px;
  font-family:var(--f-m); font-size:9px;
  text-transform:uppercase; letter-spacing:.18em;
  border-radius:999px;
  border:1px solid;
  pointer-events:none;
}
.ba-tag-before{
  background:rgba(40,40,40,.78);
  border-color:rgba(255,255,255,.18);
  color:#e8e8e8;
}
.ba-tag-after{
  background:rgba(10,15,28,.88);
  border-color:rgba(79,142,247,.4);
  color:#9CC6FF;
  left:auto; right:14px;
}

/* ───── BEFORE — muted, dated ───── */
.ba-mock{ flex:1; display:flex; flex-direction:column; }
.ba-mock-before{
  background:#b8b6ae;
  padding:16px 18px;
  font-family:Georgia, serif;
  color:#3a3a38;
  position:relative;
  gap:14px;
}
.ba-mock-before::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,.04), rgba(0,0,0,.12));
  pointer-events:none;
}
.bm-nav{
  display:flex; justify-content:space-between; align-items:center;
  padding-bottom:12px; margin-bottom:14px;
  border-bottom:1px solid #9c9a92;
}
.bm-logo-before{
  font-family:'Times New Roman', serif;
  font-size:16px; font-weight:700;
  color:#2a4258;
  letter-spacing:.02em;
}
.bm-nav-l{ display:flex; gap:10px; }
.bm-nav-l span{ width:30px; height:5px; background:#807e76; border-radius:0; }
.bm-hero-before{
  display:grid; grid-template-columns:1fr 1.1fr;
  gap:16px;
  align-items:center;
  margin-bottom:14px;
  padding:12px;
  background:#c8c6be;
  border:1px solid #9c9a92;
}
.bm-noimg{
  aspect-ratio:1.4/1;
  background:#aeaca4;
  border:1px dashed #6e6c64;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:5px;
  color:#6e6c64;
  font-family:Arial, sans-serif;
  font-size:8px;
  letter-spacing:.1em;
}
.bm-noimg svg{ width:26px; height:26px; }
.bm-hero-txt h3{
  font-family:'Times New Roman', serif;
  font-size:15px; font-weight:700;
  color:#2a4258;
  margin-bottom:6px;
}
.bm-hero-txt p{
  font-family:Georgia, serif;
  font-size:11px;
  color:#55534c;
  margin-bottom:10px;
  line-height:1.4;
}
.bm-btn-before{
  background:#5a7fa0;
  color:#e8e8e8;
  border:none;
  padding:7px 14px;
  font-family:Arial, sans-serif;
  font-size:10px;
  font-weight:bold;
  letter-spacing:.05em;
  border-radius:2px;
  cursor:inherit;
}
.bm-rows{ display:flex; flex-direction:column; gap:6px; }
.bm-row{
  display:grid; grid-template-columns:repeat(3, 1fr);
  gap:10px;
  padding:8px;
  background:#c2c0b8;
  border:1px solid #9c9a92;
}
.bm-row span{ height:7px; background:#a4a29a; }
.bm-foot-before{
  margin-top:auto;
  padding-top:12px;
  font-family:Arial, sans-serif;
  font-size:8px;
  color:#6e6c64;
  letter-spacing:.04em;
}

/* ───── AFTER — rich TDA build ───── */
.ba-after{
  background:linear-gradient(165deg, #0a1426 0%, #0a0e1c 55%, #050810 100%);
  clip-path:circle(0% at 50% 50%);
  will-change:clip-path;
  transform:translateZ(0);
  backface-visibility:hidden;
}
/* Transform-lens reveal (GPU composited, no repaint) */
.ba-lens{
  position:absolute; top:0; left:0;
  border-radius:50%;
  overflow:hidden;
  opacity:0;
  z-index:2;
  pointer-events:none;
  will-change:transform, opacity;
  box-shadow:0 0 0 1px rgba(255,255,255,.10), 0 24px 70px -12px rgba(0,0,0,.55);
}
.ba-lens-content{
  position:absolute; top:0; left:0;
  display:flex; flex-direction:column;
  background:linear-gradient(165deg, #0a1426 0%, #0a0e1c 55%, #050810 100%);
  will-change:transform;
}
.ba-mock-after{
  padding:14px 16px;
  color:var(--txt);
  display:flex; flex-direction:column;
  gap:12px;
  height:100%;
  position:relative;
  overflow:hidden;
}
.ba-mock-after::before{
  content:""; position:absolute; inset:0;
  background:
    radial-gradient(ellipse at 75% 12%, rgba(79,142,247,.18), transparent 50%),
    radial-gradient(ellipse at 15% 85%, rgba(201,169,110,.07), transparent 45%);
  pointer-events:none;
}
.am-nav{
  display:flex; justify-content:space-between; align-items:center;
  padding-bottom:11px;
  border-bottom:1px solid rgba(255,255,255,.08);
  position:relative;
}
.am-logo{
  font-family:var(--f-h); font-weight:800;
  font-size:13px;
  letter-spacing:-.02em;
  color:#9CC6FF;
}
.am-logo sup{ color:var(--acc); font-size:.5em; }
.am-nav-l{ display:flex; gap:12px; font-family:var(--f-m); font-size:8px; letter-spacing:.14em; text-transform:uppercase; color:rgba(255,255,255,.7); }
.am-cta{
  padding:5px 11px;
  background:var(--acc);
  color:#fff;
  font-family:var(--f-m); font-size:8px;
  text-transform:uppercase; letter-spacing:.12em;
  font-weight:500;
  border-radius:4px;
}
.am-hero{
  display:grid; grid-template-columns:1.5fr 1fr;
  gap:12px;
  align-items:center;
  position:relative;
}
.am-hero-txt{ display:flex; flex-direction:column; gap:7px; }
.am-eyebrow{
  font-family:var(--f-m); font-size:8px;
  text-transform:uppercase; letter-spacing:.2em;
  color:#9CC6FF;
}
.am-h{
  font-family:var(--f-h); font-weight:800;
  font-size:clamp(16px, 1.7vw, 22px);
  letter-spacing:-.025em;
  line-height:1.04;
  color:#fff;
}
.am-h em{ font-family:var(--f-s); font-weight:400; font-style:italic; color:var(--warm); }
.am-rating{ display:flex; align-items:center; gap:8px; }
.am-stars svg{ width:48px; height:10px; }
.am-revs{ font-family:var(--f-m); font-size:9px; color:rgba(255,255,255,.7); letter-spacing:.08em; }
.am-cta-row{ display:flex; gap:6px; margin-top:2px; }
.am-btn{
  font-family:var(--f-m); font-size:8px;
  font-weight:500;
  text-transform:uppercase; letter-spacing:.1em;
  padding:8px 11px;
  border-radius:5px;
}
.am-btn-1{
  background:linear-gradient(90deg, var(--acc), var(--acc-2));
  color:#fff;
  box-shadow:0 5px 16px rgba(79,142,247,.35);
}
.am-btn-2{ border:1px solid rgba(255,255,255,.18); color:rgba(255,255,255,.85); }
.am-hero-img{
  aspect-ratio:1/1;
  border-radius:8px;
  background:linear-gradient(140deg, rgba(79,142,247,.25), rgba(125,179,255,.06));
  border:1px solid rgba(255,255,255,.08);
  display:flex; align-items:center; justify-content:center;
  color:rgba(156,198,255,.7);
}
.am-hero-img svg{ width:50%; height:50%; }

.am-statbar{
  display:grid; grid-template-columns:repeat(4, 1fr);
  gap:8px;
  padding:10px 12px;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.07);
  border-radius:8px;
  position:relative;
}
.am-statbar > div{ display:flex; flex-direction:column; gap:2px; text-align:center; }
.am-statbar b{ font-family:var(--f-h); font-weight:800; font-size:14px; color:#fff; letter-spacing:-.02em; }
.am-statbar span{ font-family:var(--f-m); font-size:7px; text-transform:uppercase; letter-spacing:.12em; color:rgba(255,255,255,.55); }

.am-cards{
  display:grid; grid-template-columns:repeat(4, 1fr);
  gap:7px;
  position:relative;
}
.am-card{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  border-radius:6px;
  padding:9px 7px;
  display:flex; flex-direction:column;
  gap:6px;
  font-family:var(--f-m); font-size:7.5px;
  text-transform:uppercase; letter-spacing:.08em;
  color:rgba(255,255,255,.8);
}
.am-ci{
  width:16px; height:16px;
  border-radius:4px;
  background:linear-gradient(135deg, rgba(79,142,247,.45), rgba(125,179,255,.15));
}
.am-quote{
  position:relative;
  padding:12px 14px;
  background:linear-gradient(100deg, rgba(79,142,247,.10), rgba(79,142,247,.02));
  border:1px solid rgba(79,142,247,.18);
  border-radius:8px;
}
.am-quote-mark{
  font-family:var(--f-s); font-size:28px; font-style:italic;
  color:rgba(156,198,255,.5);
  position:absolute; top:2px; left:8px;
  line-height:1;
}
.am-quote p{
  font-size:10px; line-height:1.4;
  color:rgba(255,255,255,.9);
  padding-left:16px;
  margin-bottom:4px;
}
.am-quote-by{
  font-family:var(--f-m); font-size:8px;
  color:#9CC6FF;
  padding-left:16px;
  letter-spacing:.06em;
}
.am-trust{
  display:flex; gap:14px; flex-wrap:wrap;
  padding:8px 0;
  border-top:1px solid rgba(255,255,255,.06);
  border-bottom:1px solid rgba(255,255,255,.06);
  position:relative;
}
.am-trust span{
  display:flex; align-items:center; gap:5px;
  font-family:var(--f-m); font-size:8px;
  text-transform:uppercase; letter-spacing:.1em;
  color:rgba(255,255,255,.7);
}
.am-trust svg{ width:10px; height:10px; color:var(--acc-2); }
.am-foot{
  margin-top:auto;
  display:flex; justify-content:space-between; align-items:center;
  position:relative;
}
.am-foot-logo{ font-family:var(--f-h); font-weight:800; font-size:10px; color:#9CC6FF; }
.am-foot-meta{ font-family:var(--f-m); font-size:7px; color:rgba(255,255,255,.5); letter-spacing:.08em; }

/* Hover hint */
.ba-hint{
  position:absolute;
  top:50%; left:50%;
  transform:translate(-50%,-50%);
  z-index:6;
  display:flex; flex-direction:column;
  align-items:center; gap:12px;
  pointer-events:none;
  transition:opacity .4s var(--ease-out), transform .6s var(--ease-out);
}
.ba-hint-circle{
  width:56px; height:56px;
  border-radius:50%;
  background:rgba(20,20,24,.92);
  border:1px solid rgba(255,255,255,.16);
  display:flex; align-items:center; justify-content:center;
  color:var(--warm);
  box-shadow:0 10px 40px rgba(0,0,0,.4);
}
.ba-hint-circle svg{ width:22px; height:22px; }
.ba-hint-text{
  font-family:var(--f-m); font-size:10px;
  text-transform:uppercase; letter-spacing:.2em;
  color:var(--txt);
  padding:6px 13px;
  background:rgba(20,20,24,.92);
  border:1px solid rgba(255,255,255,.16);
  border-radius:999px;
}
.ba-wrap.is-active .ba-hint{ opacity:0; transform:translate(-50%,-50%) scale(.85); }

/* ════════════════════════════════════════════════
   HORIZONTAL SCROLL — SERVICES
═════════════════════════════════════════════════ */
.hscroll{
  position:relative;
  background:var(--bg);
  border-top:1px solid var(--b);
  border-bottom:1px solid var(--b);
}
.hscroll-pin{
  height:100vh;
  min-height:680px;
  display:flex; flex-direction:column;
  overflow:hidden;
  padding:var(--nav-h) 0 0;
}
.hscroll-head{
  padding:60px var(--pad-x) 40px;
  max-width:var(--max-w); margin:0 auto;
  width:100%;
  display:flex; align-items:flex-end; justify-content:space-between; gap:40px;
}
.hscroll-sub{
  max-width:380px;
  color:var(--txt-2);
  font-size:15px;
}
.hscroll-track{
  display:flex;
  gap:24px;
  padding:0 var(--pad-x);
  height:100%;
  align-items:center;
  will-change:transform;
}
.hs-card{
  flex:0 0 clamp(320px, 30vw, 420px);
  height:clamp(420px, 60vh, 560px);
  background:linear-gradient(180deg, var(--s1) 0%, var(--s2) 100%);
  border:1px solid var(--b);
  border-radius:18px;
  padding:32px 28px;
  display:flex; flex-direction:column;
  gap:16px;
  position:relative;
  overflow:hidden;
  transition:border-color .4s, transform .5s var(--ease-out);
}
.hs-card::before{
  content:""; position:absolute; inset:0;
  background:radial-gradient(ellipse at top right, rgba(79,142,247,.08), transparent 60%);
  opacity:0;
  transition:opacity .5s;
  pointer-events:none;
}
.hs-card:hover{ border-color:var(--bh); transform:translateY(-6px); }
.hs-card:hover::before{ opacity:1; }
.hs-card-num{
  font-family:var(--f-m); font-size:11px;
  letter-spacing:.18em;
  color:var(--txt-3);
}
.hs-card-art{
  width:100%;
  aspect-ratio:1.6/1;
  border-radius:10px;
  background:linear-gradient(140deg, rgba(79,142,247,.12), rgba(79,142,247,.02));
  border:1px solid var(--b);
  display:flex; align-items:center; justify-content:center;
  color:var(--acc-2);
  margin-bottom:8px;
  position:relative;
  overflow:hidden;
}
.hs-card-art svg{ width:62%; height:62%; }
.hs-art-1{ background:linear-gradient(140deg, rgba(79,142,247,.14), rgba(79,142,247,.02)); }
.hs-art-2{ background:linear-gradient(140deg, rgba(201,169,110,.10), rgba(201,169,110,.02)); color:var(--gold); }
.hs-art-3{ background:linear-gradient(140deg, rgba(125,179,255,.12), rgba(125,179,255,.02)); }
.hs-art-4{ background:linear-gradient(140deg, rgba(240,238,233,.06), rgba(240,238,233,.01)); color:var(--warm); }

.hs-card-h{
  font-family:var(--f-h); font-weight:700;
  font-size:26px; letter-spacing:-.025em;
  color:var(--txt);
  line-height:1.05;
}
.hs-card-p{
  font-size:14px; line-height:1.55;
  color:var(--txt-2);
}
.hs-card-list{
  margin-top:auto;
  display:flex; flex-direction:column; gap:6px;
  border-top:1px solid var(--b);
  padding-top:14px;
  font-family:var(--f-m); font-size:11px;
  text-transform:uppercase; letter-spacing:.14em;
  color:var(--txt-3);
}
.hs-card-list li::before{
  content:"+ "; color:var(--acc);
}

.hs-card-end{
  background:linear-gradient(140deg, var(--acc-dim), rgba(79,142,247,.02));
  border-color:rgba(79,142,247,.25);
  text-align:center;
  align-items:center; justify-content:center;
}
.hs-card-end .hs-card-num{ font-size:28px; color:var(--acc-2); }
.hs-card-h-end{ font-size:30px; max-width:280px; }
.hs-card-end .hs-card-p{ max-width:240px; }
.hs-card-end .btn{ margin-top:12px; }

.hscroll-progress{
  position:absolute;
  bottom:0; left:0; right:0;
  height:2px;
  background:var(--b);
}
.hscroll-progress-fill{
  display:block;
  height:100%; width:0%;
  background:var(--acc);
  box-shadow:0 0 12px var(--acc-glow);
}

/* ════════════════════════════════════════════════
   PROCESS — TIMELINE
═════════════════════════════════════════════════ */
.process{
  padding:var(--pad-y) var(--pad-x);
  background:linear-gradient(180deg, var(--bg) 0%, #0c0c0e 50%, var(--bg) 100%);
}
.process-inner{
  max-width:var(--max-w); margin:0 auto;
}
.process-h{
  font-family:var(--f-h); font-weight:500;
  font-size:clamp(22px, 3.1vw, 42px);
  line-height:1.12;
  letter-spacing:-.025em;
  color:var(--txt-2);
  max-width:1100px;
  margin-bottom:96px;
}
.process-h .reveal-w{
  display:inline-block;
  opacity:1; transform:translateY(0);
  color:var(--txt-3);
  transition:color .8s var(--ease-out), opacity .8s var(--ease-out), transform .8s var(--ease-out);
}
.process-h.js-hide .reveal-w{ opacity:0; transform:translateY(20px); }
.process-h .reveal-w.is-on{ color:var(--txt); }

.timeline{
  position:relative;
  display:flex; flex-direction:column;
  gap:60px;
  padding-left:60px;
}
.tl-line{
  position:absolute;
  left:14px; top:8px; bottom:8px;
  width:1px;
  background:var(--b);
  overflow:hidden;
}
.tl-line-fill{
  display:block;
  width:100%;
  height:0%;
  background:linear-gradient(to bottom, var(--acc), var(--acc-2));
  box-shadow:0 0 14px var(--acc-glow);
}
.tl-step{
  position:relative;
  display:grid; grid-template-columns:120px 1fr 1fr;
  gap:40px;
  align-items:start;
}
.tl-dot{
  position:absolute;
  left:-50px; top:6px;
  width:14px; height:14px; border-radius:50%;
  background:var(--s2);
  border:1px solid var(--bh);
  transition:background .4s, border-color .4s, transform .4s;
}
.tl-step.is-on .tl-dot{
  background:var(--acc);
  border-color:var(--acc);
  transform:scale(1.2);
  box-shadow:0 0 0 4px rgba(79,142,247,.18);
}
.tl-content{
  grid-column:1 / -1;
  display:grid; grid-template-columns:160px 1fr;
  gap:60px;
  align-items:start;
}
.tl-top{
  display:flex; flex-direction:column; gap:6px;
  font-family:var(--f-m); font-size:11px;
  text-transform:uppercase; letter-spacing:.18em;
}
.tl-num{
  font-family:var(--f-h); font-weight:800;
  font-size:40px; letter-spacing:-.03em;
  color:var(--txt);
  line-height:1;
}
.tl-day{ color:var(--txt-3); }
.tl-content h3{
  font-family:var(--f-h); font-weight:700;
  font-size:clamp(19px, 2.1vw, 27px);
  letter-spacing:-.02em;
  color:var(--txt);
  margin-bottom:12px;
  max-width:540px;
}
.tl-content p{
  font-size:15px; line-height:1.6;
  color:var(--txt-2);
  max-width:540px;
}

/* ════════════════════════════════════════════════
   PRICING
═════════════════════════════════════════════════ */
.pricing{
  position:relative;
  padding:var(--pad-y) var(--pad-x);
  background:var(--bg-2);
  overflow:hidden;
  border-top:1px solid var(--b);
}
.pricing-bg{
  position:absolute;
  top:48%; left:50%;
  transform:translate(-50%,-50%);
  font-family:var(--f-h); font-weight:800;
  font-size:clamp(180px, 30vw, 480px);
  letter-spacing:-.06em;
  color:rgba(255,255,255,.02);
  pointer-events:none;
  white-space:nowrap;
  z-index:0;
}
.pricing-inner{
  position:relative; z-index:1;
  max-width:var(--max-w); margin:0 auto;
}
.pricing-h{
  font-family:var(--f-h); font-weight:800;
  font-size:clamp(27px, 3.4vw, 48px);
  line-height:1.02;
  letter-spacing:-.035em;
  color:var(--txt);
  margin-bottom:72px;
  max-width:900px;
}

.price-grid{
  display:grid; grid-template-columns:repeat(3, 1fr);
  gap:18px;
  margin-bottom:60px;
}
.price-card{
  position:relative;
  background:linear-gradient(180deg, var(--s1) 0%, var(--bg-2) 100%);
  border:1px solid var(--b);
  border-radius:20px;
  padding:36px 30px;
  display:flex; flex-direction:column;
  gap:18px;
  transition:border-color .4s, transform .5s var(--ease-out);
  transform-style:preserve-3d;
  will-change:transform;
}
.price-card:hover{ border-color:var(--bh); }

.price-card-feat{
  background:linear-gradient(180deg, rgba(79,142,247,.06) 0%, var(--bg-2) 100%);
  border-color:rgba(79,142,247,.35);
  box-shadow:0 0 0 1px rgba(79,142,247,.08), 0 30px 60px -20px rgba(79,142,247,.15);
}
.price-card-feat::before{
  content:""; position:absolute; inset:0;
  border-radius:inherit;
  background:linear-gradient(180deg, rgba(79,142,247,.08), transparent 50%);
  pointer-events:none;
  opacity:.5;
}

.pc-head{
  display:flex; align-items:center; justify-content:space-between;
}
.pc-tag{
  font-family:var(--f-m); font-size:11px;
  text-transform:uppercase; letter-spacing:.2em;
  color:var(--txt-2);
  padding:5px 12px;
  background:var(--s2);
  border:1px solid var(--b);
  border-radius:999px;
}
.price-card-feat .pc-tag{ background:var(--acc); color:var(--bg); border-color:var(--acc); }
.pc-pop{
  font-family:var(--f-m); font-size:10px;
  text-transform:uppercase; letter-spacing:.18em;
  color:var(--acc-2);
}
.pc-price{
  display:flex; align-items:baseline; gap:10px;
  flex-wrap:wrap;
  margin:8px 0 4px;
}
.pc-from{
  font-family:var(--f-m); font-size:11px;
  text-transform:uppercase; letter-spacing:.18em;
  color:var(--txt-3);
}
.pc-num{
  font-family:var(--f-h); font-weight:800;
  font-size:52px; letter-spacing:-.04em;
  line-height:1;
  color:var(--txt);
}
.pc-once{
  font-family:var(--f-m); font-size:11px;
  text-transform:uppercase; letter-spacing:.16em;
  color:var(--txt-3);
}
.pc-desc{
  color:var(--txt-2);
  font-size:14px;
  line-height:1.55;
}
.pc-divider{
  height:1px; background:var(--b);
  margin:4px 0;
}
.pc-features{
  display:flex; flex-direction:column; gap:10px;
  flex:1;
}
.pc-features li{
  display:flex; align-items:flex-start; gap:10px;
  font-size:14px;
  color:var(--txt);
  line-height:1.4;
}
.pc-tick{
  flex:0 0 18px; width:18px; height:18px;
  border-radius:50%;
  background:var(--s3);
  border:1px solid var(--b);
  display:flex; align-items:center; justify-content:center;
  color:var(--acc-2);
  margin-top:1px;
}
.pc-tick svg{ width:10px; height:10px; }
.price-card-feat .pc-tick{ background:var(--acc-dim); border-color:var(--acc); color:var(--txt); }

.pc-cta{
  display:flex; align-items:center; justify-content:space-between;
  margin-top:12px;
  padding:14px 18px;
  border:1px solid var(--bh);
  border-radius:12px;
  font-family:var(--f-m); font-size:12px; font-weight:500;
  text-transform:uppercase; letter-spacing:.14em;
  color:var(--txt);
  transition:background .35s, border-color .35s, color .35s;
}
.pc-cta svg{ width:14px; height:14px; transition:transform .4s var(--ease-out); }
.pc-cta:hover{ background:var(--s2); border-color:var(--bb); }
.pc-cta:hover svg{ transform:translateX(4px); }
.pc-cta-feat{
  background:var(--acc);
  color:var(--bg);
  border-color:var(--acc);
}
.pc-cta-feat:hover{ background:var(--acc-2); border-color:var(--acc-2); color:var(--bg); }

/* Maintenance card */
.maint{
  display:flex; align-items:center; justify-content:space-between;
  gap:32px;
  padding:32px 40px;
  background:var(--s1);
  border:1px solid var(--b);
  border-radius:18px;
}
.maint-l{ flex:1; }
.maint-tag{
  display:inline-block;
  font-family:var(--f-m); font-size:11px;
  text-transform:uppercase; letter-spacing:.18em;
  color:var(--gold);
  margin-bottom:10px;
}
.maint-h{
  font-family:var(--f-h); font-weight:800;
  font-size:clamp(20px, 2.1vw, 29px);
  letter-spacing:-.02em;
  color:var(--txt);
  margin-bottom:8px;
}
.maint-mo{ font-size:.5em; color:var(--txt-3); font-weight:500; }
.maint-p{
  color:var(--txt-2); font-size:14px;
  max-width:560px;
}
.maint-em{ color:var(--warm); }

/* ════════════════════════════════════════════════
   CTA BAND
═════════════════════════════════════════════════ */
.cta-band{
  position:relative;
  padding:clamp(80px, 12vh, 140px) var(--pad-x);
  overflow:hidden;
  border-top:1px solid var(--b);
  border-bottom:1px solid var(--b);
  background:var(--bg);
}
.cta-band-bg{
  position:absolute; inset:0;
  background:
    radial-gradient(ellipse at 20% 30%, rgba(79,142,247,.08), transparent 40%),
    radial-gradient(ellipse at 80% 70%, rgba(201,169,110,.05), transparent 40%);
  pointer-events:none;
}
.cta-band-inner{
  position:relative; z-index:1;
  max-width:var(--max-w); margin:0 auto;
  text-align:center;
  display:flex; flex-direction:column;
  align-items:center; gap:32px;
}
.ctab-eyebrow{
  font-family:var(--f-m); font-size:11px;
  text-transform:uppercase; letter-spacing:.22em;
  color:var(--acc-2);
}
.ctab-h{
  font-family:var(--f-h); font-weight:800;
  font-size:clamp(30px, 4.2vw, 62px);
  line-height:1.02;
  letter-spacing:-.04em;
  color:var(--txt);
  max-width:1100px;
}
.ctab-h .reveal-w{
  display:inline-block;
  /* Default visible — JS sets initial hidden state if it loads */
  opacity:1;
  transform:translateY(0);
  transition:opacity .8s var(--ease-out), transform .8s var(--ease-out);
}
.ctab-h.js-hide .reveal-w{ opacity:0; transform:translateY(20px); }
.ctab-h .reveal-w.is-on{ opacity:1; transform:translateY(0); }
.ctab-ctas{
  display:flex; gap:14px; flex-wrap:wrap; justify-content:center;
  margin-top:16px;
}

/* ════════════════════════════════════════════════
   CONTACT
═════════════════════════════════════════════════ */
.contact{
  padding:var(--pad-y) var(--pad-x) clamp(64px, 8vh, 96px);
  background:var(--bg);
}
.contact-inner{
  max-width:var(--max-w); margin:0 auto;
  display:grid; grid-template-columns:1fr 1.15fr;
  gap:64px;
  align-items:start;
}
.contact-h{
  font-family:var(--f-h); font-weight:800;
  font-size:clamp(27px, 3.3vw, 46px);
  letter-spacing:-.04em;
  line-height:1;
  color:var(--txt);
  margin:8px 0 20px;
}
.contact-h span{ display:block; }
.contact-p{
  color:var(--txt-2);
  font-size:15px;
  max-width:420px;
  margin-bottom:36px;
}
.contact-info{
  border-top:1px solid var(--b);
}
.ci-row{
  display:flex; align-items:center; justify-content:space-between;
  padding:18px 0;
  border-bottom:1px solid var(--b);
  font-size:15px;
  transition:color .3s, padding-left .3s;
}
.ci-row:not(.ci-row-static):hover{
  color:var(--acc-2);
  padding-left:8px;
}
.ci-l{
  font-family:var(--f-m); font-size:11px;
  text-transform:uppercase; letter-spacing:.18em;
  color:var(--txt-3);
}
.ci-v{ color:inherit; font-weight:500; }

/* What happens next — full width row */
.whn{
  max-width:var(--max-w); margin:64px auto 0;
  padding:40px 0 0;
  border-top:1px solid var(--b);
}
.whn-tag{
  display:block;
  font-family:var(--f-m); font-size:11px;
  text-transform:uppercase; letter-spacing:.22em;
  color:var(--acc-2);
  margin-bottom:32px;
}
.whn-steps{
  display:grid; grid-template-columns:repeat(3, 1fr);
  gap:32px;
}
.whn-step{
  display:grid; grid-template-columns:56px 1fr;
  gap:18px;
  align-items:flex-start;
  padding:24px;
  background:var(--s1);
  border:1px solid var(--b);
  border-radius:16px;
  transition:border-color .4s var(--ease-out), transform .5s var(--ease-out);
}
.whn-step:hover{ border-color:var(--bh); transform:translateY(-4px); }
.whn-n{
  font-family:var(--f-h); font-weight:800;
  font-size:38px;
  letter-spacing:-.04em;
  line-height:.85;
  background:linear-gradient(180deg, var(--txt) 0%, var(--txt-3) 100%);
  -webkit-background-clip:text;
  background-clip:text;
  -webkit-text-fill-color:transparent;
}
.whn-step:hover .whn-n{
  background:linear-gradient(180deg, var(--acc-2) 0%, var(--acc) 100%);
  -webkit-background-clip:text;
  background-clip:text;
  -webkit-text-fill-color:transparent;
}
.whn-c h4{
  font-family:var(--f-h); font-weight:700;
  font-size:18px; letter-spacing:-.015em;
  color:var(--txt);
  margin-bottom:6px;
}
.whn-c p{
  font-size:14px; line-height:1.5;
  color:var(--txt-2);
}

/* Form */
.form{
  background:var(--s1);
  border:1px solid var(--b);
  border-radius:20px;
  padding:36px 32px;
  display:flex; flex-direction:column;
  gap:24px;
  position:relative;
}
.form-row{ display:grid; grid-template-columns:1fr 1fr; gap:24px; }
.field{
  position:relative;
  display:flex; flex-direction:column;
  gap:8px;
}
.field-l{
  font-family:var(--f-m); font-size:10px;
  text-transform:uppercase; letter-spacing:.18em;
  color:var(--txt-3);
  transition:color .3s;
}
.field input,.field textarea{
  background:transparent;
  border:none;
  border-bottom:1px solid var(--b);
  padding:8px 0 10px;
  color:var(--txt);
  font-size:15px;
  font-family:var(--f-b);
  resize:none;
  width:100%;
}
.field input::placeholder,.field textarea::placeholder{ color:var(--txt-4); }
.field-line{
  position:absolute;
  bottom:0; left:0;
  height:1px; width:0%;
  background:var(--acc);
  transition:width .5s var(--ease-out);
}
.field input:focus ~ .field-line,
.field textarea:focus ~ .field-line{ width:100%; }
.field:focus-within .field-l{ color:var(--acc-2); }

.form-submit{
  margin-top:8px;
  display:flex; align-items:center; justify-content:space-between;
  padding:18px 26px;
  background:var(--txt); color:var(--bg);
  border-radius:14px;
  font-family:var(--f-m); font-size:12px; font-weight:500;
  text-transform:uppercase; letter-spacing:.14em;
  position:relative;
  overflow:hidden;
  transition:color .4s;
}
.form-submit::before{
  content:""; position:absolute; inset:0;
  background:var(--acc);
  transform:translateY(101%);
  transition:transform .55s var(--ease-out);
  z-index:0;
}
.fs-text,.fs-arrow{ position:relative; z-index:1; }
.fs-arrow{ width:18px; height:18px; transition:transform .4s var(--ease-out); }
.form-submit:hover{ color:var(--txt); }
.form-submit:hover::before{ transform:translateY(0); }
.form-submit:hover .fs-arrow{ transform:translateX(4px); }

.form-err{
  margin-top:6px;
  font-size:13px;
  line-height:1.45;
  color:#ff8a8a;
  opacity:0;
  max-height:0;
  overflow:hidden;
  transition:opacity .3s var(--ease-out), max-height .3s var(--ease-out);
}
.form-err.show{
  opacity:1;
  max-height:80px;
}
.form-success{
  position:absolute; inset:0;
  background:var(--s1);
  border-radius:20px;
  display:flex; flex-direction:column;
  align-items:center; justify-content:center;
  gap:14px;
  text-align:center;
  opacity:0; pointer-events:none;
  transition:opacity .5s var(--ease-out);
  padding:40px;
}
.form-success.show{ opacity:1; pointer-events:auto; }
.fsx-icon{
  width:56px; height:56px;
  border-radius:50%;
  background:var(--acc-dim);
  border:1px solid var(--acc);
  display:flex; align-items:center; justify-content:center;
  color:var(--acc-2);
  margin-bottom:8px;
}
.fsx-icon svg{ width:30px; height:30px; }
.form-success h3{
  font-family:var(--f-h); font-weight:700;
  font-size:28px; letter-spacing:-.02em;
  color:var(--txt);
}
.form-success p{ color:var(--txt-2); font-size:15px; max-width:340px; }

/* ════════════════════════════════════════════════
   FOOTER
═════════════════════════════════════════════════ */
.footer{
  position:relative;
  background:var(--bg);
  border-top:1px solid var(--b);
  padding:80px var(--pad-x) 28px;
  overflow:hidden;
}
.footer-huge{
  position:absolute;
  bottom:-2.5vw;
  left:50%; transform:translateX(-50%);
  font-family:var(--f-h); font-weight:800;
  font-size:clamp(180px, 32vw, 540px);
  letter-spacing:-.06em;
  line-height:.85;
  color:rgba(255,255,255,.03);
  pointer-events:none;
  z-index:0;
  white-space:nowrap;
}
.footer-inner{
  position:relative; z-index:1;
  max-width:var(--max-w); margin:0 auto;
  display:grid; grid-template-columns:1.4fr 1fr 1fr 1.2fr;
  gap:48px;
  padding-bottom:60px;
  border-bottom:1px solid var(--b);
}
.ft-col{ display:flex; flex-direction:column; gap:12px; }
.ft-col-brand p{ color:var(--txt-2); font-size:14px; max-width:280px; line-height:1.55; }
.ft-logo{
  font-family:var(--f-h); font-weight:800;
  font-size:22px; letter-spacing:-.02em;
  color:var(--txt);
  margin-bottom:6px;
}
.ft-logo sup{ color:var(--txt-3); font-size:.5em; }
.ft-col h4{
  font-family:var(--f-m); font-size:11px;
  text-transform:uppercase; letter-spacing:.18em;
  color:var(--txt-3);
  font-weight:500;
  margin-bottom:6px;
}
.ft-col a,.ft-col span{
  color:var(--txt);
  font-size:14px;
  transition:color .3s, padding-left .3s;
}
.ft-col a:hover{ color:var(--acc-2); padding-left:6px; }
.footer-base{
  position:relative; z-index:1;
  max-width:var(--max-w); margin:0 auto;
  padding-top:24px;
  display:flex; justify-content:space-between; align-items:center;
  font-family:var(--f-m); font-size:11px;
  text-transform:uppercase; letter-spacing:.16em;
  color:var(--txt-3);
}
.ft-base-r{ display:flex; align-items:center; gap:8px; color:var(--txt-2); }
.ft-pulse{
  width:7px; height:7px; border-radius:50%;
  background:#5ec45e;
  box-shadow:0 0 0 3px rgba(94,196,94,.18);
  animation:pulse-dot 2s ease-in-out infinite;
}

/* ════════════════════════════════════════════════
   RESPONSIVE
═════════════════════════════════════════════════ */
@media (max-width: 1100px){
  .hero-float{ display:none; }
  .showcase-grid{ grid-template-columns:1fr; gap:48px; }
  .ba-wrap{ justify-self:stretch; max-width:540px; margin:0 auto; aspect-ratio:4/5; }
  .hero-bottom{ grid-template-columns:1fr; gap:32px; }
  .hero-ctas{ justify-content:flex-start; }
  .contact-inner{ grid-template-columns:1fr; gap:48px; }
  .price-grid{ grid-template-columns:1fr; }
  .footer-inner{ grid-template-columns:1fr 1fr; }
  .tl-content{ grid-template-columns:1fr; gap:14px; }
  .tl-num{ font-size:32px; }
  .maint{ flex-direction:column; align-items:flex-start; gap:18px; padding:28px; }
  .whn-steps{ grid-template-columns:1fr; gap:16px; }
}

@media (max-width: 768px){
  :root{ --nav-h:64px; --pad-y:80px; }
  .nav-links,.nav-cta{ display:none; }
  .nav-burger{ display:flex; }
  .nav{ padding:14px var(--pad-x); }
  .hero{ padding:calc(var(--nav-h) + 24px) var(--pad-x) 80px; min-height:calc(100vh - 0px); }
  .hero-inner{ gap:32px; }
  .hero-meta{ flex-direction:column; align-items:flex-start; gap:10px; }
  .hero-meta-r{ flex-wrap:wrap; }
  .hero-scroll{ display:none; }
  .hero-mark{ font-size:clamp(68px, 26vw, 190px); gap:6px; }
  .hero-divider{ flex-wrap:wrap; gap:10px; }
  .hd-line{ display:none; }
  .hero-tagline{ font-size:clamp(16px, 4.2vw, 21px); }
  .marquee-set{ font-size:32px; gap:24px; }
  .showcase-stats{ grid-template-columns:1fr 1fr; }
  .timeline{ padding-left:32px; }
  .tl-dot{ left:-28px; }
  .tl-line{ left:6px; }
  .form-row{ grid-template-columns:1fr; gap:24px; }
  .footer-inner{ grid-template-columns:1fr; gap:32px; }
  .footer-base{ flex-direction:column; gap:8px; }
  .hs-card{ flex:0 0 78vw; height:auto; min-height:420px; }
  .hscroll-pin{ height:auto; min-height:0; padding:80px 0; }
  .hscroll-head{ flex-direction:column; align-items:flex-start; gap:16px; }
  .hscroll-track{
    overflow-x:auto;
    transform:none!important;
    scroll-snap-type:x mandatory;
    padding-bottom:24px;
  }
  .hs-card{ scroll-snap-align:start; }
  .hscroll-progress{ display:none; }
  .ba-wrap{ aspect-ratio:3/4; max-width:none; }
  .am-h{ font-size:15px; }
  .bm-hero-before{ grid-template-columns:1fr; }
  .am-hero{ grid-template-columns:1fr; }
  .am-hero-img{ display:none; }
  .am-cards{ grid-template-columns:repeat(2,1fr); }
  .whn-steps{ grid-template-columns:1fr; gap:16px; }
}

@media (max-width: 480px){
  .pc-num{ font-size:42px; }
  .form{ padding:24px 20px; }
  .ctab-ctas{ flex-direction:column; width:100%; }
  .ctab-ctas .btn{ width:100%; justify-content:center; }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{
    animation-duration:.01ms!important;
    animation-iteration-count:1!important;
    transition-duration:.01ms!important;
  }
  .marquee-track{ animation:none; }
  .grain{ animation:none; }
}
