/* =====================================================================
   PROSPERITY SYNDICATE — Flagship Site
   Direction: Urban Luxury · Deep Navy + Lime on Light · Editorial calm
   Dominant: #27274B navy  ·  Accent: #CEFE5E lime  ·  Ground: white/bone
   Principle: white space is the luxury. Restraint over decoration.
   ===================================================================== */

:root{
  --lime:#CEFE5E;
  --navy:#27274B;
  --navy-mid:#3a3a6e;
  --navy-wash:rgba(39,39,75,0.05);
  --ink:#0b0b12;
  --white:#fff;
  --bone:#F6F5F0;        /* warm off-white ground */
  --bone-2:#EFEEE7;
  --grey:#73738A;        /* muted body text — passes AA on white */
  --grey-soft:#9A9AAC;
  --line:rgba(39,39,75,0.10);
  --line-strong:rgba(39,39,75,0.18);

  --f-display:'Anton',Impact,sans-serif;
  --f-section:'Josefin Sans',sans-serif;
  --f-body:'DM Sans',sans-serif;
  --f-cta:'Montserrat',sans-serif;

  --ease:cubic-bezier(0.16,1,0.3,1);
  --ease-out:cubic-bezier(0.22,0.61,0.36,1);

  --max:1320px;
  --pad:clamp(20px,6vw,120px);     /* generous, scales up on big screens */
  --gap-section:clamp(90px,14vh,220px); /* huge vertical rhythm = luxury */
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{
  background:var(--white);
  color:var(--ink);
  font-family:var(--f-body);
  font-size:16px;
  line-height:1.7;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
img{display:block;max-width:100%;}
a{color:inherit;text-decoration:none;}
::selection{background:var(--lime);color:var(--navy);}

/* skip link */
.skip{position:absolute;left:-999px;top:0;z-index:100000;background:var(--navy);color:#fff;padding:14px 22px;font-family:var(--f-cta);font-size:11px;letter-spacing:0.2em;text-transform:uppercase;}
.skip:focus{left:16px;top:16px;}

:focus-visible{outline:2px solid var(--lime);outline-offset:3px;}

/* scroll progress */
#progress{position:fixed;top:0;left:0;height:2px;width:0;background:var(--lime);z-index:2000;transition:width 0.1s linear;}

/* ===== TYPE SCALE ===== */
.t-hero{font-family:var(--f-display);font-size:clamp(52px,8.5vw,140px);line-height:0.88;letter-spacing:0.005em;text-transform:uppercase;}
.t-display{font-family:var(--f-display);font-size:clamp(38px,5.5vw,92px);line-height:0.9;text-transform:uppercase;}
.t-section{font-family:var(--f-section);font-size:clamp(26px,3.4vw,50px);font-weight:700;line-height:1.04;text-transform:uppercase;letter-spacing:-0.01em;}
.t-eye{font-family:var(--f-cta);font-size:10px;font-weight:700;letter-spacing:0.32em;text-transform:uppercase;color:var(--grey);display:inline-flex;align-items:center;gap:12px;}
.t-eye::before{content:'';width:26px;height:1px;background:currentColor;flex-shrink:0;}
.t-eye.center::after{content:'';width:26px;height:1px;background:currentColor;flex-shrink:0;}
.t-lede{font-size:clamp(17px,1.7vw,22px);line-height:1.65;color:var(--grey);max-width:60ch;}
.t-body{font-size:16px;line-height:1.85;color:var(--grey);}
.lime{color:var(--lime);} .navy{color:var(--navy);}
.outline{-webkit-text-stroke:1.5px var(--navy);color:transparent;}
.outline-lime{-webkit-text-stroke:1.5px var(--lime);color:transparent;}

/* ===== BUTTONS ===== */
.btn{font-family:var(--f-cta);font-weight:700;font-size:10.5px;letter-spacing:0.22em;text-transform:uppercase;padding:17px 32px;display:inline-flex;align-items:center;gap:9px;border:1.5px solid transparent;position:relative;transition:transform 0.35s var(--ease),box-shadow 0.35s var(--ease),background 0.3s,color 0.3s,border-color 0.3s;will-change:transform;}
.btn .arr{transition:transform 0.35s var(--ease);}
.btn:hover .arr{transform:translateX(5px);}
.btn-lime{background:var(--lime);color:var(--navy);}
.btn-lime:hover{box-shadow:0 14px 40px rgba(206,254,94,0.4);}
.btn-navy{background:var(--navy);color:#fff;}
.btn-navy:hover{box-shadow:0 14px 40px rgba(39,39,75,0.28);}
.btn-outline{background:transparent;color:var(--navy);border-color:var(--line-strong);}
.btn-outline:hover{border-color:var(--navy);background:var(--navy);color:#fff;}
.btn-black{background:var(--ink);color:#fff;border-color:var(--ink);}
.btn-black:hover{box-shadow:0 14px 40px rgba(11,11,18,0.34);}
.btn-ghost-white{background:transparent;color:#fff;border-color:rgba(255,255,255,0.32);}
.btn-ghost-white:hover{border-color:var(--lime);color:var(--lime);}

/* ===== LAYOUT ===== */
.inner{max-width:var(--max);margin:0 auto;}
.sect{padding:var(--gap-section) var(--pad);}
.sect-line{border-top:1px solid var(--line);}
.two{display:grid;grid-template-columns:1fr 1fr;gap:clamp(48px,7vw,120px);align-items:start;}
.two-wide{grid-template-columns:0.8fr 1.2fr;}
.head-row{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,100px);align-items:start;margin-bottom:clamp(56px,8vh,110px);}
.head-row>p{margin-top:clamp(28px,3vh,34px);}

/* ===== REVEAL ===== */
.rv{opacity:0;transform:translateY(38px);transition:opacity 0.9s var(--ease),transform 0.9s var(--ease);}
.rv.on{opacity:1;transform:none;}
.d1{transition-delay:0.09s;} .d2{transition-delay:0.18s;} .d3{transition-delay:0.27s;} .d4{transition-delay:0.36s;} .d5{transition-delay:0.45s;}

/* ===== NAV ===== */
nav{position:fixed;top:0;left:0;right:0;z-index:1000;padding:26px var(--pad);display:flex;align-items:center;justify-content:space-between;gap:32px;transition:background 0.45s var(--ease),border-color 0.45s,padding 0.35s,box-shadow 0.45s;border-bottom:1px solid transparent;}
nav.scrolled{background:rgba(255,255,255,0.9);backdrop-filter:blur(22px) saturate(1.2);-webkit-backdrop-filter:blur(22px) saturate(1.2);border-color:var(--line);padding-top:16px;padding-bottom:16px;}
.nav-logo{display:flex;align-items:center;gap:11px;font-family:var(--f-cta);font-weight:800;font-size:11px;letter-spacing:0.16em;text-transform:uppercase;color:#fff;transition:color 0.35s;}
nav.scrolled .nav-logo{color:var(--ink);}
.nav-mark{width:32px;height:32px;background:var(--lime);display:flex;align-items:center;justify-content:center;font-family:var(--f-display);font-size:14px;color:var(--navy);flex-shrink:0;}
.nav-links{display:flex;align-items:center;gap:36px;list-style:none;}
.nav-links a{font-family:var(--f-cta);font-size:10px;font-weight:600;letter-spacing:0.18em;text-transform:uppercase;color:rgba(255,255,255,0.75);transition:color 0.25s;position:relative;}
nav.scrolled .nav-links a{color:var(--grey);}
.nav-links a::after{content:'';position:absolute;bottom:-4px;left:0;right:100%;height:1px;background:var(--lime);transition:right 0.4s var(--ease);}
.nav-links a:hover::after{right:0;}
.nav-links a:hover,nav.scrolled .nav-links a:hover{color:var(--navy);}
.nav-cta{font-family:var(--f-cta);font-weight:700;font-size:9.5px;letter-spacing:0.2em;text-transform:uppercase;padding:13px 22px;background:var(--navy);color:#fff;border:1px solid rgba(255,255,255,0.7);transition:transform 0.3s var(--ease),box-shadow 0.3s;}
.nav-cta:hover{transform:translateY(-2px);box-shadow:0 10px 30px rgba(39,39,75,0.32);}
.ham{display:none;flex-direction:column;gap:5px;background:none;border:none;padding:6px;}
.ham span{width:24px;height:1.5px;background:#fff;display:block;transition:0.3s;}
nav.scrolled .ham span{background:var(--ink);}

/* ===== DRAWER ===== */
.drawer{position:fixed;top:0;right:-100%;width:min(360px,88vw);height:100dvh;background:var(--navy);z-index:9999;padding:96px 44px 44px;display:flex;flex-direction:column;gap:8px;transition:right 0.5s var(--ease);}
.drawer.open{right:0;}
.drawer a{font-family:var(--f-display);font-size:34px;text-transform:uppercase;color:#fff;padding:10px 0;transition:color 0.25s,padding 0.25s;}
.drawer a:hover{color:var(--lime);padding-left:8px;}
.drawer .drawer-foot{margin-top:auto;font-family:var(--f-cta);font-size:9px;letter-spacing:0.2em;text-transform:uppercase;color:rgba(255,255,255,0.4);}
.dov{display:none;position:fixed;inset:0;background:rgba(11,11,18,0.5);backdrop-filter:blur(4px);z-index:9998;}
.dov.on{display:block;}
.drawer-close{position:absolute;top:30px;right:32px;background:none;border:none;color:#fff;font-size:22px;cursor:pointer;line-height:1;}

/* ===== HERO ===== */
.hero{min-height:100svh;position:relative;overflow:hidden;display:flex;align-items:flex-end;padding:0 var(--pad) clamp(64px,11vh,130px);background:linear-gradient(120deg,#0d0d1c 0%,#06060d 60%);}
.hero-img{position:absolute;top:0;right:0;height:100%;width:52%;object-fit:cover;object-position:54% 3%;filter:grayscale(1) contrast(1.05) brightness(0.6);opacity:1;-webkit-mask-image:linear-gradient(to right,transparent 0%,rgba(0,0,0,0.5) 38%,#000 64%);mask-image:linear-gradient(to right,transparent 0%,rgba(0,0,0,0.5) 38%,#000 64%);}
.hero-veil{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(0,0,0,0.28) 0%,rgba(0,0,0,0) 30%,rgba(0,0,0,0) 66%,rgba(0,0,0,0.55) 100%);}
@media(max-width:900px){
  .hero-img{width:100%;-webkit-mask-image:none;mask-image:none;object-position:60% 8%;filter:grayscale(1) contrast(1.05) brightness(0.55);}
  .hero-veil{background:linear-gradient(to bottom,rgba(0,0,0,0.5) 0%,rgba(0,0,0,0.2) 34%,rgba(0,0,0,0.4) 68%,rgba(0,0,0,0.72) 100%);}
}
.hero-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,0.035) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,0.035) 1px,transparent 1px);background-size:84px 84px;mask-image:radial-gradient(ellipse 80% 80% at 30% 70%,#000,transparent);-webkit-mask-image:radial-gradient(ellipse 80% 80% at 30% 70%,#000,transparent);}
.hero-content{position:relative;z-index:2;width:100%;max-width:1040px;}
.hero-eyebrow{margin-bottom:34px;}
.hero-eyebrow .t-eye{color:rgba(255,255,255,0.82);font-weight:800;}
.hero-eyebrow .t-eye::before{background:var(--lime);width:40px;}
@media(max-width:600px){
  .hero-eyebrow .t-eye::before{display:none;}
  .hero-eyebrow .t-eye{gap:0;}
  .nav-cta{padding:10px 16px;letter-spacing:0.14em;white-space:nowrap;}
}
.hero h1{color:#fff;margin-bottom:clamp(36px,5vh,60px);}
.hero-h1{will-change:transform;line-height:0.94;}
.hero-sub{color:rgba(255,255,255,0.72);margin-bottom:52px;max-width:540px;font-size:clamp(17px,1.6vw,21px);line-height:1.6;}
.hero-btns{display:flex;gap:14px;flex-wrap:wrap;}
.scroll-hint{position:absolute;bottom:46px;right:var(--pad);display:flex;align-items:center;gap:14px;font-family:var(--f-cta);font-size:8px;letter-spacing:0.32em;text-transform:uppercase;color:rgba(255,255,255,0.35);writing-mode:vertical-rl;}
.scroll-hint::before{content:'';width:1px;height:46px;background:linear-gradient(var(--lime),transparent);animation:sh 2.6s ease-in-out infinite;}
@keyframes sh{0%,100%{opacity:1;transform:scaleY(1)}50%{opacity:0.2;transform:scaleY(0.5)}}

/* ===== MARQUEE ===== */
.marquee{overflow:hidden;background:var(--lime);padding:15px 0;border-top:1px solid rgba(39,39,75,0.12);border-bottom:1px solid rgba(39,39,75,0.12);}
.marquee-t{display:flex;width:max-content;animation:mq 38s linear infinite;}
.marquee:hover .marquee-t{animation-play-state:paused;}
.marquee-t span{font-family:var(--f-cta);font-size:10px;font-weight:700;letter-spacing:0.26em;text-transform:uppercase;color:var(--navy);padding:0 30px;white-space:nowrap;}
.marquee-t .dot{color:rgba(39,39,75,0.3);padding:0 2px;}
@keyframes mq{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ===== STATS ===== */
.stats{display:grid;grid-template-columns:repeat(4,1fr);}
.stat{padding:clamp(48px,7vh,88px) clamp(24px,3vw,48px);border-left:1px solid var(--line);}
.stat:first-child{border-left:none;}
.stat-n{font-family:var(--f-display);font-size:clamp(38px,4.8vw,66px);line-height:1;color:var(--navy);}
.stat-n .acc{color:var(--lime);background:var(--navy);padding:0 4px;}
.stat-l{font-family:var(--f-cta);font-size:9px;font-weight:700;letter-spacing:0.22em;text-transform:uppercase;color:var(--grey);margin-top:14px;}
.stats .stat{text-align:center;}

/* ===== ABOUT ===== */
.about-img-wrap{position:relative;aspect-ratio:3/4;overflow:hidden;background:var(--bone);}
.about-img-wrap img{width:100%;height:100%;object-fit:cover;filter:grayscale(1) contrast(1.06);transition:transform 1.2s var(--ease);}
.about-img-wrap:hover img{transform:scale(1.04);}
.about-accent{position:absolute;bottom:0;left:0;background:var(--lime);padding:16px 22px;font-family:var(--f-cta);font-size:9px;font-weight:700;letter-spacing:0.2em;text-transform:uppercase;color:var(--navy);}
.about-text{display:flex;flex-direction:column;gap:28px;}
.about-metrics{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line);margin-top:14px;border:1px solid var(--line);}
.about-metric{background:var(--white);padding:26px 22px;}
.am-num{font-family:var(--f-display);font-size:clamp(26px,2.6vw,40px);color:var(--navy);line-height:1;}
.am-num .acc{color:var(--lime);background:var(--navy);padding:0 3px;}
.am-l{font-family:var(--f-cta);font-size:9px;font-weight:700;letter-spacing:0.2em;text-transform:uppercase;color:var(--grey);margin-top:8px;}

/* ===== PROCESS ===== */
.process-sect{background:var(--bone);}
.process-grid{display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid var(--line-strong);margin-top:clamp(48px,7vh,90px);}
.p-item{padding:clamp(40px,4vw,60px) clamp(28px,2.5vw,44px) clamp(40px,4vw,60px) 0;border-right:1px solid var(--line);position:relative;}
.p-item:last-child{border-right:none;}
.p-item::after{content:'';position:absolute;top:0;left:0;width:0;height:2px;background:var(--lime);transition:width 0.6s var(--ease);}
.p-item:hover::after{width:100%;}
.p-icon{width:38px;height:38px;margin-bottom:26px;color:var(--navy);}
.p-num{font-family:var(--f-cta);font-size:10px;font-weight:700;letter-spacing:0.3em;color:var(--grey-soft);margin-bottom:14px;}
.p-title{font-family:var(--f-section);font-weight:700;font-size:20px;text-transform:uppercase;color:var(--navy);margin-bottom:14px;}
.p-body{font-size:14.5px;line-height:1.75;color:var(--grey);}

/* ===== PACKAGES ===== */
.pkg-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;background:var(--white);margin-top:clamp(56px,8vh,96px);border:1px solid var(--line-strong);}
.pkg{background:var(--white);padding:clamp(40px,3.4vw,56px) clamp(30px,2.6vw,44px);display:flex;flex-direction:column;position:relative;border-left:1px solid var(--line-strong);transition:background 0.4s var(--ease),box-shadow 0.4s var(--ease),transform 0.4s var(--ease);will-change:transform;}
.pkg:first-child{border-left:none;}
.pkg::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;}
.pkg.starter::before{background:var(--line-strong);}
.pkg.growth::before{background:var(--lime);}
.pkg.scale::before{background:var(--navy);}
.pkg:hover{box-shadow:0 30px 80px rgba(39,39,75,0.1);z-index:2;}
.pkg-icon{width:42px;height:42px;color:var(--navy);margin-bottom:26px;}
.pkg.growth .pkg-icon{color:var(--navy);}
.pkg-badge{font-family:var(--f-cta);font-size:8px;font-weight:800;letter-spacing:0.3em;text-transform:uppercase;padding:6px 12px;align-self:flex-start;margin-bottom:22px;}
.pkg.starter .pkg-badge{background:var(--ink);color:#fff;}
.pkg.growth .pkg-badge{background:var(--lime);color:var(--navy);}
.pkg.scale .pkg-badge{background:var(--navy);color:#fff;}
.pkg-pop{position:absolute;top:18px;right:18px;background:var(--lime);color:var(--navy);font-family:var(--f-cta);font-size:7.5px;font-weight:800;letter-spacing:0.18em;text-transform:uppercase;padding:5px 9px;}
.pkg-name{font-family:var(--f-display);font-size:clamp(34px,3.4vw,52px);text-transform:uppercase;line-height:0.94;color:var(--ink);margin-bottom:10px;}
.pkg-sub{font-style:italic;font-size:13px;color:var(--grey);margin-bottom:28px;}
.pkg-price{font-family:var(--f-display);font-size:clamp(26px,2.5vw,38px);line-height:1;color:var(--navy);}
.pkg-price .mo{font-family:var(--f-cta);font-size:0.34em;font-weight:700;letter-spacing:0.08em;}
.pkg-price-note{font-family:var(--f-cta);font-size:9px;letter-spacing:0.18em;text-transform:uppercase;color:var(--grey);margin-top:8px;margin-bottom:30px;}
.pkg-div{height:1px;background:var(--line);margin-bottom:26px;}
.pkg-features{list-style:none;flex:1;margin-bottom:34px;}
.pkg-features li{font-size:13.5px;line-height:1.55;color:var(--grey);padding:11px 0;border-bottom:1px solid var(--navy-wash);display:flex;gap:11px;align-items:flex-start;}
.pkg-features li::before{content:'';width:5px;height:5px;background:var(--lime);border-radius:50%;flex-shrink:0;margin-top:7px;}
.pkg.growth .pkg-features li::before,.pkg.scale .pkg-features li::before{background:var(--navy);}
.pkg .btn{justify-content:center;width:100%;}

/* ===== ADDONS ===== */
.addons{display:grid;grid-template-columns:repeat(3,1fr);gap:0;background:var(--white);margin-top:1px;border:1px solid var(--line-strong);border-top:none;}
.addon{background:var(--white);padding:clamp(34px,2.5vw,46px) clamp(26px,2vw,38px);display:flex;flex-direction:column;align-items:flex-start;transition:background 0.3s;border-left:1px solid var(--line-strong);}
.addon:first-child{border-left:none;}
.addon:hover{background:var(--bone);}
.addon-name{font-family:var(--f-display);font-size:clamp(22px,1.9vw,30px);text-transform:uppercase;line-height:0.95;color:var(--ink);margin:12px 0 14px;}
.addon-desc{font-size:13.5px;color:var(--grey);line-height:1.7;margin-bottom:26px;flex:1;}
.addon-price{font-family:var(--f-display);font-size:clamp(26px,2.3vw,38px);color:var(--navy);white-space:nowrap;text-align:left;}
.addon-price-note{font-family:var(--f-cta);font-size:9px;letter-spacing:0.16em;text-transform:uppercase;color:var(--grey);text-align:left;margin-top:6px;margin-bottom:22px;}
.addon .btn{margin-top:auto;}

/* ===== QUOTE ===== */
.quote-sect{background:var(--navy);padding:var(--gap-section) var(--pad);position:relative;overflow:hidden;}
.quote-inner{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:1.35fr 0.65fr;gap:clamp(48px,7vw,100px);align-items:center;position:relative;z-index:2;}
.big-quote{font-family:var(--f-display);font-size:clamp(38px,5.6vw,86px);line-height:0.94;text-transform:uppercase;color:#fff;}
.big-quote em{font-family:var(--f-section);font-style:italic;font-weight:300;color:var(--lime);text-transform:none;font-size:0.86em;}
.q-right{display:flex;flex-direction:column;gap:34px;}
.q-stat{border-left:2px solid var(--lime);padding-left:22px;}
.q-stat-n{font-family:var(--f-display);font-size:clamp(28px,3.4vw,46px);color:#fff;line-height:1;}
.q-stat-l{font-family:var(--f-cta);font-size:9px;font-weight:700;letter-spacing:0.22em;text-transform:uppercase;color:rgba(255,255,255,0.45);margin-top:7px;}

/* ===== SERVICES ===== */
.services-sect{background:var(--bone);}
.svc-list{border-top:1px solid var(--line-strong);margin-top:clamp(48px,7vh,90px);}
.svc-row{display:grid;grid-template-columns:80px 1.1fr 1.3fr auto;gap:32px;padding:clamp(28px,3vh,42px) 0;border-bottom:1px solid var(--line);align-items:center;transition:padding 0.4s var(--ease),background 0.3s;}
.svc-row:hover{padding-left:18px;padding-right:18px;background:var(--white);}
.svc-n{font-family:var(--f-display);font-size:clamp(30px,3vw,46px);color:rgba(39,39,75,0.13);line-height:1;}
.svc-name{font-family:var(--f-display);font-size:clamp(20px,1.9vw,30px);text-transform:uppercase;color:var(--ink);line-height:0.98;}
.svc-desc{font-size:14px;color:var(--grey);line-height:1.65;}
.svc-arrow{font-family:var(--f-cta);font-size:10px;font-weight:700;letter-spacing:0.2em;text-transform:uppercase;color:var(--navy);white-space:nowrap;display:flex;align-items:center;gap:7px;}
.svc-arrow .arr{transition:transform 0.35s var(--ease);}
.svc-row:hover .svc-arrow .arr{transform:translateX(7px);}

/* ===== ASSEMBLY ===== */
.assembly-sect{background:var(--white);}
.asm-inner{display:grid;grid-template-columns:1fr 1fr;gap:clamp(48px,7vw,100px);align-items:center;}
.asm-tag{display:inline-block;background:var(--lime);color:var(--navy);font-family:var(--f-cta);font-size:8px;font-weight:800;letter-spacing:0.18em;text-transform:uppercase;padding:6px 12px;margin:18px 0 24px;}
.asm-features{list-style:none;margin:0 0 32px;}
.asm-features li{font-size:14.5px;color:var(--grey);padding:13px 0;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:14px;}
.asm-features li::before{content:'';width:22px;height:1px;background:var(--navy);flex-shrink:0;}
.asm-mockup{border:1px solid var(--line);box-shadow:0 40px 100px rgba(39,39,75,0.12);background:var(--white);overflow:hidden;}
.asm-bar{background:var(--navy);padding:13px 16px;display:flex;align-items:center;gap:7px;}
.asm-dot{width:9px;height:9px;border-radius:50%;}
.asm-url{margin-left:auto;font-family:var(--f-cta);font-size:8px;letter-spacing:0.14em;color:rgba(255,255,255,0.4);}
.asm-logo{margin-bottom:18px;padding-bottom:14px;border-bottom:1px solid var(--line);}
.asm-logo img{width:24px;height:24px;display:block;}
.asm-body{display:flex;height:280px;}
.asm-side{width:150px;border-right:1px solid var(--line);padding:18px 14px;flex-shrink:0;}
.asm-s{font-family:var(--f-cta);font-size:9px;letter-spacing:0.12em;text-transform:uppercase;color:var(--grey);padding:9px 10px;margin-bottom:3px;border-radius:3px;}
.asm-s.a{background:var(--navy-wash);color:var(--navy);font-weight:700;}
.asm-content{flex:1;padding:18px;}
.asm-r{height:22px;background:var(--bone-2);margin-bottom:9px;border-radius:3px;animation:pulse 2.4s ease-in-out infinite;}
.asm-r:nth-child(2){width:72%;animation-delay:0.4s;}
.asm-r:nth-child(3){width:52%;animation-delay:0.8s;}
.asm-prog{height:54px;background:var(--navy-wash);border:1px solid var(--line-strong);border-radius:4px;margin-top:14px;position:relative;overflow:hidden;}
.asm-prog::after{content:'';position:absolute;left:0;top:0;bottom:0;width:68%;background:linear-gradient(90deg,var(--navy),var(--navy-mid));animation:prog 4s var(--ease) infinite;}
@keyframes pulse{0%,100%{opacity:0.55}50%{opacity:1}}
@keyframes prog{0%{width:12%}50%{width:78%}100%{width:12%}}

/* ===== RESOURCES ===== */
.resources-sect{background:var(--navy);}
.resources-sect .t-eye{color:rgba(255,255,255,0.5);}
.resources-sect .t-section{color:#fff;}
.resources-sect .t-lede{color:rgba(255,255,255,0.6);}
.resources-sect .t-lede a{color:var(--lime);text-decoration:underline;text-underline-offset:3px;}
.res-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:rgba(255,255,255,0.1);margin-top:clamp(48px,7vh,90px);border:1px solid rgba(255,255,255,0.1);}
.res-card{background:var(--navy);padding:clamp(34px,2.8vw,46px) clamp(28px,2.4vw,40px);cursor:pointer;transition:background 0.4s var(--ease);position:relative;overflow:hidden;display:flex;flex-direction:column;}
.res-card:hover{background:#2e2e58;}
.res-card::after{content:'';position:absolute;bottom:0;left:0;width:0;height:2px;background:var(--lime);transition:width 0.5s var(--ease);}
.res-card:hover::after{width:100%;}
.res-num{font-family:var(--f-display);font-size:38px;color:rgba(255,255,255,0.12);line-height:1;margin-bottom:20px;}
.res-title{font-family:var(--f-section);font-weight:700;font-size:17px;text-transform:uppercase;color:#fff;margin-bottom:12px;line-height:1.2;}
.res-desc{font-size:13.5px;color:rgba(255,255,255,0.6);line-height:1.65;margin-bottom:26px;flex:1;}
.res-unlock{display:flex;align-items:center;gap:9px;font-family:var(--f-cta);font-size:9px;font-weight:700;letter-spacing:0.2em;text-transform:uppercase;color:var(--lime);}
.res-unlock svg{width:13px;height:13px;}

/* ===== TESTIMONIALS ===== */
.test-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,2vw,28px);margin-top:clamp(48px,7vh,90px);}
.test-card{background:var(--bone);border:1px solid var(--line);padding:clamp(32px,2.6vw,44px);transition:border-color 0.35s,transform 0.45s var(--ease);}
.test-card:hover{border-color:var(--navy);transform:translateY(-6px);}
.test-mark{font-family:var(--f-display);font-size:58px;color:var(--lime);-webkit-text-stroke:1px var(--ink);line-height:0.7;display:block;margin-bottom:18px;}
.test-q{font-style:italic;font-size:16px;line-height:1.65;color:var(--ink);margin-bottom:26px;}
.test-meta{border-top:1px solid var(--line);padding-top:18px;min-height:66px;box-sizing:border-box;}
.test-name{font-family:var(--f-cta);font-size:10px;font-weight:800;letter-spacing:0.14em;text-transform:uppercase;color:var(--navy);margin-bottom:4px;}
.test-role{font-family:var(--f-cta);font-size:9px;letter-spacing:0.1em;text-transform:uppercase;color:var(--grey);}

/* ===== FAQ (AEO) ===== */
.faq-sect{background:var(--bone);}
.faq-list{margin-top:clamp(40px,6vh,72px);border-top:1px solid var(--line-strong);}
.faq{border-bottom:1px solid var(--line);}
.faq-q{width:100%;background:none;border:none;text-align:left;display:flex;align-items:center;justify-content:space-between;gap:24px;padding:clamp(24px,3vh,34px) 0;cursor:pointer;font-family:var(--f-section);font-weight:700;font-size:clamp(17px,1.7vw,23px);text-transform:uppercase;color:var(--navy);letter-spacing:-0.01em;}
.faq-icon{flex-shrink:0;width:22px;height:22px;position:relative;}
.faq-icon::before,.faq-icon::after{content:'';position:absolute;background:var(--navy);transition:transform 0.4s var(--ease);}
.faq-icon::before{top:50%;left:0;right:0;height:1.5px;transform:translateY(-50%);}
.faq-icon::after{left:50%;top:0;bottom:0;width:1.5px;transform:translateX(-50%);}
.faq.open .faq-icon::after{transform:translateX(-50%) scaleY(0);}
.faq-a{max-height:0;overflow:hidden;transition:max-height 0.5s var(--ease);}
.faq-a-inner{padding-bottom:clamp(24px,3vh,34px);font-size:15px;line-height:1.8;color:var(--grey);max-width:70ch;}

/* ===== CTA ===== */
.cta-sect{background:var(--navy);padding:clamp(110px,16vh,200px) var(--pad);position:relative;overflow:hidden;}
.cta-bg{position:absolute;right:-2%;bottom:-14%;font-family:var(--f-display);font-size:min(34vw,520px);color:rgba(255,255,255,0.03);line-height:1;pointer-events:none;user-select:none;}
.cta-inner{max-width:var(--max);margin:0 auto;position:relative;z-index:2;}
.cta-h{font-family:var(--f-display);font-size:clamp(48px,8.5vw,128px);line-height:0.9;text-transform:uppercase;color:#fff;margin:24px 0 30px;}
.cta-h span{color:var(--lime);}
.cta-sub{font-style:italic;font-size:clamp(16px,1.6vw,19px);color:rgba(255,255,255,0.62);max-width:500px;margin-bottom:50px;line-height:1.6;}
.cta-btns{display:flex;gap:14px;flex-wrap:wrap;}

/* ===== FOOTER ===== */
footer{background:var(--ink);padding:clamp(72px,10vh,110px) var(--pad) 44px;}
.footer-inner{max-width:var(--max);margin:0 auto;}
.footer-top{display:grid;grid-template-columns:1.7fr 1fr 1fr 1fr;gap:clamp(40px,5vw,64px);padding-bottom:clamp(48px,7vh,72px);border-bottom:1px solid rgba(255,255,255,0.07);}
.footer-brand{display:flex;align-items:center;gap:11px;margin-bottom:18px;}
.footer-mark{width:30px;height:30px;background:var(--lime);display:flex;align-items:center;justify-content:center;font-family:var(--f-display);font-size:13px;color:var(--navy);}
.footer-bn{font-family:var(--f-cta);font-size:11px;font-weight:800;letter-spacing:0.16em;text-transform:uppercase;color:#fff;}
.footer-tag{font-style:italic;font-size:13px;color:rgba(255,255,255,0.38);max-width:250px;margin-bottom:30px;line-height:1.6;}
.footer-social{display:flex;gap:12px;flex-wrap:wrap;}
.social-ico{width:42px;height:42px;border:1px solid rgba(255,255,255,0.18);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,0.7);transition:color 0.25s var(--ease),border-color 0.25s,background 0.25s,transform 0.25s var(--ease);}
.social-ico svg{width:18px;height:18px;}
.social-ico:hover{color:var(--navy);background:var(--lime);border-color:var(--lime);transform:translateY(-3px);}
.footer-col-h{font-family:var(--f-cta);font-size:11px;font-weight:800;letter-spacing:0.24em;text-transform:uppercase;color:rgba(255,255,255,0.5);margin-bottom:22px;}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:14px;}
.footer-col a{font-size:15px;font-weight:600;color:rgba(255,255,255,0.82);transition:color 0.25s;}
.footer-col a:hover{color:var(--lime);}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;gap:16px;padding-top:34px;flex-wrap:wrap;}
.footer-legal{font-family:var(--f-cta);font-size:11px;font-weight:600;letter-spacing:0.14em;text-transform:uppercase;color:rgba(255,255,255,0.5);}

/* ===== POPUPS ===== */
.modal{display:none;position:fixed;inset:0;background:rgba(11,11,18,0.65);z-index:9990;align-items:center;justify-content:center;padding:20px;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);}
.modal.on{display:flex;animation:fade 0.4s ease;}
@keyframes fade{from{opacity:0}to{opacity:1}}
.modal-box{position:relative;width:100%;animation:pop 0.55s var(--ease);}
@keyframes pop{from{opacity:0;transform:translateY(28px) scale(0.97)}to{opacity:1;transform:none}}
.nl-box{background:var(--white);max-width:560px;margin:0 auto;padding:clamp(40px,6vw,68px) clamp(28px,5vw,60px);border-top:3px solid var(--lime);}
.rg-box{background:var(--navy);max-width:500px;margin:0 auto;padding:clamp(40px,6vw,60px) clamp(28px,5vw,52px);border-top:3px solid var(--lime);}
.modal-close{position:absolute;top:20px;right:22px;background:none;border:none;font-size:20px;line-height:1;cursor:pointer;color:var(--grey);transition:color 0.2s,transform 0.2s;}
.modal-close:hover{transform:rotate(90deg);}
.rg-box .modal-close{color:rgba(255,255,255,0.5);}
.nl-title{font-family:var(--f-display);font-size:clamp(30px,4.4vw,50px);text-transform:uppercase;line-height:0.92;color:var(--ink);margin:16px 0;}
.nl-title span{color:var(--navy);}
.nl-body{font-size:14.5px;color:var(--grey);line-height:1.7;margin-bottom:30px;}
.rg-title{font-family:var(--f-display);font-size:clamp(28px,3.8vw,42px);text-transform:uppercase;line-height:0.94;color:#fff;margin:14px 0;}
.rg-title span{color:var(--lime);}
.rg-body{font-size:14px;color:rgba(255,255,255,0.62);line-height:1.65;margin-bottom:28px;}
.field{width:100%;background:transparent;border:none;border-bottom:1.5px solid var(--line-strong);color:var(--ink);font-family:var(--f-body);font-size:16px;padding:13px 0;outline:none;margin-bottom:14px;transition:border-color 0.25s;}
.field:focus{border-color:var(--navy);}
.rg-box .field{color:#fff;border-color:rgba(255,255,255,0.3);}
.rg-box .field:focus{border-color:var(--lime);}
.field::placeholder{color:var(--grey-soft);}
.rg-box .field::placeholder{color:rgba(255,255,255,0.35);}
.modal .btn{width:100%;justify-content:center;margin-top:6px;}
.modal-thanks{display:none;font-style:italic;font-size:18px;text-align:center;padding:28px 0;}
.nl-box .modal-thanks{color:var(--navy);}
.rg-box .modal-thanks{color:var(--lime);}
.nl-skip{display:block;text-align:center;font-family:var(--f-cta);font-size:9px;letter-spacing:0.16em;text-transform:uppercase;color:var(--grey-soft);margin-top:18px;background:none;border:none;width:100%;cursor:pointer;transition:color 0.2s;}
.nl-skip:hover{color:var(--grey);}
.nl-privacy{font-family:var(--f-cta);font-size:8.5px;letter-spacing:0.1em;text-transform:uppercase;color:var(--grey-soft);text-align:center;margin-top:16px;}

/* ===== RESPONSIVE ===== */
@media (max-width:1024px){
  .nav-links{display:none;}
  .ham{display:flex;}
  .two,.two-wide,.head-row{grid-template-columns:1fr;gap:48px;}
  .head-row{margin-bottom:56px;}
  .stats{grid-template-columns:repeat(2,1fr);}
  .stat:nth-child(3){border-left:none;}
  .stat:nth-child(3),.stat:nth-child(4){border-top:1px solid var(--line);}
  .process-grid{grid-template-columns:1fr;}
  .p-item{border-right:none;border-bottom:1px solid var(--line);padding:40px 0;}
  .p-item:last-child{border-bottom:none;}
  .pkg-grid{grid-template-columns:1fr;}
  .pkg{border-left:none;border-top:1px solid var(--line-strong);}
  .pkg:first-child{border-top:none;}
  .addons{grid-template-columns:1fr;}
  .addon{border-left:none;border-top:1px solid var(--line-strong);}
  .addon:first-child{border-top:none;}
  .quote-inner{grid-template-columns:1fr;gap:48px;}
  .svc-row{grid-template-columns:56px 1fr auto;gap:18px;}
  .svc-desc{display:none;}
  .asm-inner{grid-template-columns:1fr;}
  .res-grid{grid-template-columns:repeat(2,1fr);}
  .test-grid{grid-template-columns:1fr;}
  .footer-top{grid-template-columns:1fr 1fr;}
}
@media (max-width:600px){
  .stats{grid-template-columns:1fr 1fr;}
  .svc-row{grid-template-columns:44px 1fr auto;gap:14px;}
  .svc-arrow span:not(.arr){display:none;}
  .res-grid{grid-template-columns:1fr;}
  .footer-top{grid-template-columns:1fr;gap:36px;}
  .footer-bottom{flex-direction:column;align-items:flex-start;}
  .scroll-hint{display:none;}
  .hero{min-height:92svh;}
}

/* ===== REDUCED MOTION ===== */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:0.01ms!important;animation-iteration-count:1!important;transition-duration:0.01ms!important;scroll-behavior:auto!important;}
  .rv{opacity:1;transform:none;}
  .marquee-t{animation:none;}
}


/* ============================================================
   REFINEMENT PASS — tighter luxury rhythm, navy-forward.
   Less cavernous white; the dark anchors carry the room.
   ============================================================ */
:root{
  --gap-section:clamp(64px,8.5vh,124px);   /* was 90/14vh/220 — too cavernous */
  --pad:clamp(20px,5vw,104px);
}
.head-row{margin-bottom:clamp(38px,5.5vh,68px);}
.hero{min-height:94svh;}

/* Navy stat band anchors the top so the page does not open on a wall of white */
.stats{background:var(--navy);}
.stats .stat{border-left-color:rgba(255,255,255,0.13);}
.stats .stat-n{color:#fff;}
.stats .stat-n .acc{color:var(--navy);background:var(--lime);}
.stats .stat-l{color:rgba(255,255,255,0.5);}
@media(max-width:1024px){
  .stats .stat:nth-child(3),.stats .stat:nth-child(4){border-top-color:rgba(255,255,255,0.13);}
}

/* Warm the largest light section so it reads couture, not blank */
.about-sect{background:var(--bone);}

/* Trim the over-tall dark closers */
.cta-sect{padding:clamp(92px,13vh,156px) var(--pad);}
.quote-sect{padding:clamp(80px,11vh,140px) var(--pad);}
.nav-links a{white-space:nowrap;}
.nav-links{gap:30px;}


/* ============================================================
   CLIENT LOGO WALL + TESTIMONIAL CAROUSEL + PROCESS SPACING
   ============================================================ */
.clients-sect{background:var(--white);padding:clamp(48px,7vh,82px) 0;}
.clients-sect .inner{padding:0 var(--pad);}
.clients-eye{font-family:var(--f-cta);font-size:10px;font-weight:700;letter-spacing:0.3em;text-transform:uppercase;color:var(--grey);display:flex;align-items:center;justify-content:center;gap:16px;text-align:center;}
.clients-eye::before,.clients-eye::after{content:'';width:38px;height:1px;background:var(--line-strong);}
.logo-marquee{overflow:hidden;margin-top:clamp(34px,4.5vh,52px);-webkit-mask-image:linear-gradient(90deg,transparent,#000 10%,#000 90%,transparent);mask-image:linear-gradient(90deg,transparent,#000 10%,#000 90%,transparent);}
.logo-track{display:flex;width:max-content;align-items:center;gap:clamp(48px,6vw,88px);animation:logoMove 34s linear infinite;}
.logo-marquee:hover .logo-track{animation-play-state:paused;}
.logo-item{font-family:var(--f-section);font-weight:700;font-size:clamp(17px,2vw,27px);letter-spacing:0.05em;text-transform:uppercase;color:var(--navy);opacity:0.34;white-space:nowrap;transition:opacity 0.3s;}
.logo-item:hover{opacity:1;}
@keyframes logoMove{to{transform:translateX(-50%);}}

.test-marquee{overflow:hidden;margin-top:clamp(40px,6vh,72px);-webkit-mask-image:linear-gradient(90deg,transparent,#000 4%,#000 96%,transparent);mask-image:linear-gradient(90deg,transparent,#000 4%,#000 96%,transparent);}
.test-track{display:flex;width:max-content;align-items:stretch;gap:24px;padding:8px clamp(20px,5vw,104px);animation:testMove 56s linear infinite reverse;}
.test-marquee:hover .test-track{animation-play-state:paused;}
.test-track .test-card{width:clamp(290px,30vw,380px);flex:0 0 auto;display:flex;flex-direction:column;}
.test-track .test-q{flex:1;}
@keyframes testMove{to{transform:translateX(-50%);}}

/* Process: breathing room from the vertical dividers */
.p-item{padding-left:clamp(32px,3vw,48px);padding-right:clamp(32px,3vw,48px);}
.process-grid .p-item:first-child{padding-left:0;}
@media(max-width:1024px){
  .process-grid .p-item{padding-left:0;padding-right:0;}
}

@media (prefers-reduced-motion:reduce){
  .logo-track,.test-track{animation:none;}
  .logo-marquee,.test-marquee{overflow-x:auto;}
}


/* ============================================================
   STAT BAND DYNAMIC POLISH + TIGHTER FOUNDER / INVESTMENT
   ============================================================ */
.stats .stat-n .acc{color:var(--lime);background:transparent;padding:0 0 0 2px;}
@media (prefers-reduced-motion:no-preference){
  .stats .stat-n .acc{animation:accPulse 2.8s ease-in-out infinite;}
}
@keyframes accPulse{0%,100%{opacity:1}50%{opacity:0.5}}
.stats .stat{position:relative;}
.stats .stat-l{position:relative;display:inline-block;}
.stats .stat-l::before{content:'';position:absolute;left:50%;transform:translateX(-50%);top:-12px;width:0;height:2px;background:var(--lime);transition:width 0.8s var(--ease) 0.25s;}
.stats .stat.on .stat-l::before{width:28px;}

/* tighten the two-column header voids */
.head-row{gap:clamp(28px,4vw,60px);margin-bottom:clamp(32px,4.5vh,56px);}
.two{gap:clamp(40px,5vw,80px);}

/* Founder section: balance the portrait + text, kill dead space */
.about-sect .two-wide{align-items:center;gap:clamp(40px,5vw,76px);}
.about-text{gap:20px;}
.about-metrics{margin-top:14px;}

/* Investment cards: tighter internal rhythm */
.pkg{padding:clamp(34px,2.8vw,46px) clamp(28px,2.4vw,40px);}
.pkg-name{margin-bottom:8px;}
.pkg-sub{margin-bottom:22px;}
.pkg-price-note{margin-bottom:24px;}
.pkg-div{margin-bottom:22px;}
.pkg-features li{padding:9px 0;}
.pkg-features{margin-bottom:28px;}


/* Resource card numbers in white for legibility on navy */
.res-num{color:rgba(255,255,255,0.92);}

/* ============================================================
   HOW WE WORK — richer color: dark navy band, lime accents
   ============================================================ */
.process-sect{background:var(--navy);}
.process-sect .t-eye{color:rgba(255,255,255,0.5);}
.process-sect .t-eye::before{background:var(--lime);}
.process-sect .t-section{color:#fff;}
.process-sect .t-body{color:rgba(255,255,255,0.62);}
.process-grid{border-top-color:rgba(255,255,255,0.16);}
.process-sect .p-item{border-right-color:rgba(255,255,255,0.12);transition:background 0.4s var(--ease);}
.process-sect .p-item:hover{background:rgba(255,255,255,0.035);}
.process-sect .p-icon{color:var(--lime);}
.process-sect .p-num{color:var(--lime);}
.process-sect .p-title{color:#fff;}
.process-sect .p-body{color:rgba(255,255,255,0.62);}
@media(max-width:1024px){
  .process-sect .p-item{border-right-color:transparent;border-bottom:1px solid rgba(255,255,255,0.12);}
  .process-sect .p-item:last-child{border-bottom:none;}
}


/* ===== CLIENT LOGO BAND (real logos, whitened, navy ground) ===== */
.clients-band{background:var(--ink);padding:clamp(34px,5vh,58px) 0;overflow:hidden;}
.clients-band .clients-eye{color:rgba(255,255,255,0.5);}
.clients-band .clients-eye::before,.clients-band .clients-eye::after{background:rgba(255,255,255,0.22);}
.clients-band .logo-marquee{margin-top:clamp(26px,3.5vh,42px);}
.clients-band .logo-track{gap:clamp(44px,5vw,82px);align-items:center;}
.logo-img{height:clamp(32px,3.9vw,50px);width:auto;max-width:220px;object-fit:contain;opacity:0.72;filter:brightness(0) invert(1);transition:opacity 0.3s var(--ease);flex:0 0 auto;}
.logo-img:hover{opacity:1;}

/* ===== MORE BLACK + BIGGER BODY/STEP TYPE + DIAGNOSE ALIGN ===== */
.quote-sect{background:var(--ink);}
.cta-sect{background:var(--ink);}

.t-body{font-size:17.5px;line-height:1.8;}
.p-body{font-size:16.5px;line-height:1.78;}
.p-num{font-size:12px;letter-spacing:0.26em;margin-bottom:16px;}
.p-title{font-size:23px;}

/* Diagnose column aligns with the other two */
.process-grid .p-item:first-child{padding-left:clamp(32px,3vw,48px);}
@media(max-width:1024px){.process-grid .p-item:first-child{padding-left:0;}}
/* CTA headline: breathing room between the two lines */
.cta-h{line-height:1.04;}

/* About metric grid: cleaner + readable (no clipped box on the "+"), one lime accent */
.am-num .acc{color:var(--navy);background:transparent;padding:0;}
.about-metrics{border:1px solid var(--line);border-top:2px solid var(--lime);}
.am-num{font-size:clamp(30px,3vw,46px);letter-spacing:-0.01em;}
.about-metric{padding:26px 24px;}
.am-l{margin-top:10px;}

/* Eyebrow labels heavier */
.t-eye{font-weight:800;}
.quote-sect .t-eye{color:rgba(255,255,255,0.6)!important;}

/* Graffiti logo keeps its black outlines: sits on a white chip, no whitening */
.logo-img.logo-chip{filter:none;opacity:1;background:transparent;padding:0;height:clamp(54px,5.8vw,72px);max-width:240px;}
.logo-img.logo-chip:hover{opacity:1;}

/* Two-tone logos (white wordmark + grey mark): keep original, no whitening */
.logo-img.logo-keep{filter:none;opacity:0.95;}

/* Logos that read small at the shared size get a larger cap height */
.logo-img.logo-lg{height:clamp(46px,5.4vw,70px);max-width:280px;}

/* =====================================================================
   LEGAL PAGE
   ===================================================================== */
.legal-hero{background:var(--navy);color:#fff;padding:clamp(130px,18vh,200px) var(--pad) clamp(60px,8vh,90px);position:relative;overflow:hidden;}
.legal-hero .lh-eye{color:var(--lime);font-family:var(--f-cta);font-size:11px;letter-spacing:0.32em;text-transform:uppercase;font-weight:700;display:block;margin-bottom:22px;}
.legal-hero h1{font-family:var(--f-display);font-size:clamp(44px,7vw,96px);line-height:0.9;text-transform:uppercase;letter-spacing:0.01em;}
.legal-hero .lh-sub{color:rgba(255,255,255,0.62);max-width:560px;margin-top:24px;font-size:clamp(15px,1.5vw,18px);line-height:1.65;}
.legal-hero .lh-updated{margin-top:30px;font-family:var(--f-cta);font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:rgba(255,255,255,0.4);}
.legal-bg{position:absolute;right:-4%;top:50%;transform:translateY(-50%);font-family:var(--f-display);font-size:clamp(180px,30vw,460px);color:rgba(255,255,255,0.03);line-height:1;pointer-events:none;text-transform:uppercase;}

.legal-wrap{max-width:var(--max);margin:0 auto;padding:clamp(60px,9vh,120px) var(--pad);display:grid;grid-template-columns:minmax(190px,240px) 1fr;gap:clamp(40px,7vw,110px);align-items:start;}
.legal-toc{display:block;position:sticky;top:120px;padding:0;gap:0;justify-content:flex-start;align-items:stretch;z-index:auto;}
.legal-toc-h{font-family:var(--f-cta);font-size:10px;letter-spacing:0.26em;text-transform:uppercase;color:var(--grey-soft);margin-bottom:18px;}
.legal-toc a{display:block;font-family:var(--f-cta);font-size:13px;font-weight:500;color:var(--grey);padding:9px 0 9px 16px;border-left:2px solid var(--line);transition:all 0.25s var(--ease);}
.legal-toc a:hover,.legal-toc a.active{color:var(--navy);border-left-color:var(--lime);padding-left:22px;}

.legal-body{max-width:760px;}
.legal-block{margin-bottom:clamp(48px,7vh,80px);scroll-margin-top:120px;}
.legal-block:last-child{margin-bottom:0;}
.legal-block .lb-num{font-family:var(--f-cta);font-size:11px;font-weight:700;letter-spacing:0.2em;color:var(--lime);text-transform:uppercase;-webkit-text-stroke:0.4px var(--navy);}
.legal-block h2{font-family:var(--f-section);font-weight:700;font-size:clamp(26px,3.4vw,40px);line-height:1.1;color:var(--navy);margin:12px 0 22px;letter-spacing:-0.01em;}
.legal-block h3{font-family:var(--f-section);font-weight:600;font-size:clamp(17px,1.9vw,21px);color:var(--navy);margin:30px 0 10px;}
.legal-block p{color:var(--grey);font-size:16px;line-height:1.78;margin-bottom:16px;}
.legal-block ul{list-style:none;margin:8px 0 18px;}
.legal-block li{position:relative;padding-left:24px;color:var(--grey);font-size:16px;line-height:1.7;margin-bottom:10px;}
.legal-block li::before{content:"";position:absolute;left:2px;top:11px;width:7px;height:7px;background:var(--lime);border:1px solid var(--navy);transform:rotate(45deg);}
.legal-block a{color:var(--navy);font-weight:600;border-bottom:1px solid var(--lime);}
.legal-block a:hover{background:var(--lime);}
.legal-block strong{color:var(--navy);font-weight:600;}
.legal-divider{height:1px;background:var(--line);margin:clamp(48px,7vh,80px) 0;}

@media(max-width:860px){
  .legal-wrap{grid-template-columns:1fr;gap:0;}
  .legal-toc{position:static;margin-bottom:50px;padding-bottom:30px;border-bottom:1px solid var(--line);display:flex;flex-wrap:wrap;gap:8px;}
  .legal-toc-h{width:100%;}
  .legal-toc a{border-left:none;border:1px solid var(--line);border-radius:40px;padding:9px 16px;}
  .legal-toc a:hover,.legal-toc a.active{padding-left:16px;border-color:var(--lime);}
}

/* =====================================================================
   STATEMENT BAND — navy editorial positioning band before Services
   ===================================================================== */
.statement-sect{background:var(--navy);color:#fff;padding:clamp(100px,15vh,180px) var(--pad);position:relative;overflow:hidden;}
.statement-bg{position:absolute;left:-2%;top:-8%;width:min(44vw,540px);height:auto;opacity:0.05;pointer-events:none;user-select:none;}
.statement-wm{position:absolute;right:1%;top:7%;text-align:right;font-family:var(--f-display);font-size:min(17vw,230px);line-height:0.8;text-transform:uppercase;letter-spacing:-0.01em;color:rgba(255,255,255,0.05);pointer-events:none;user-select:none;z-index:1;}
@media(max-width:760px){.statement-wm{display:none;}}
.statement-inner{max-width:var(--max);margin:0 auto;position:relative;z-index:2;}
.statement-eye{color:var(--lime);font-family:var(--f-cta);font-size:11px;font-weight:700;letter-spacing:0.32em;text-transform:uppercase;display:block;margin-bottom:30px;}
.statement-h{font-family:var(--f-display);font-size:clamp(40px,6.4vw,104px);line-height:0.94;text-transform:uppercase;letter-spacing:0.005em;max-width:16ch;}
.statement-h span{color:var(--lime);}
.statement-body{color:rgba(255,255,255,0.66);font-size:clamp(17px,1.7vw,22px);line-height:1.62;max-width:680px;margin-top:clamp(34px,5vh,52px);}
.statement-accent{display:flex;flex-wrap:wrap;align-items:center;gap:18px;margin-top:clamp(34px,4.5vh,46px);font-family:var(--f-cta);font-size:12px;font-weight:700;letter-spacing:0.22em;text-transform:uppercase;color:#fff;}
.statement-accent .sa-dot{width:7px;height:7px;background:var(--lime);transform:rotate(45deg);}
.statement-accent .sa-tail{color:var(--lime);}
@media(max-width:640px){.statement-accent{gap:12px;font-size:10.5px;}}

/* Statement band — three value pillars */
.statement-pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:0;margin-top:clamp(60px,9vh,100px);border-top:1px solid rgba(255,255,255,0.16);}
.sp-item{padding:clamp(44px,4.5vw,62px) clamp(34px,2.8vw,48px) 0;border-right:1px solid rgba(255,255,255,0.12);}
.sp-item:first-child{padding-left:0;}
.sp-item:last-child{border-right:none;padding-right:0;}
.sp-h{display:flex;align-items:center;gap:11px;font-family:var(--f-section);font-weight:700;font-size:clamp(18px,1.9vw,23px);color:var(--lime);margin-bottom:14px;line-height:1.15;}
.sp-h svg{width:22px;height:22px;flex-shrink:0;stroke:var(--lime);fill:none;stroke-width:1.7;}
.sp-body{color:rgba(255,255,255,0.62);font-size:clamp(15px,1.5vw,17px);line-height:1.6;}
@media(max-width:860px){
  .statement-pillars{grid-template-columns:1fr;}
  .sp-item{border-right:none;border-bottom:1px solid rgba(255,255,255,0.12);padding:clamp(30px,5vw,40px) 0;}
  .sp-item:last-child{border-bottom:none;}
}

/* =====================================================================
   TWO PATHS — decision-framing comparison before the CTA
   ===================================================================== */
.paths-sect{background:var(--navy);color:#fff;padding:var(--gap-section) var(--pad);position:relative;overflow:hidden;}
.paths-inner{max-width:1120px;margin:0 auto;position:relative;z-index:2;}
.paths-head{text-align:center;max-width:760px;margin:0 auto clamp(56px,8vh,92px);}
.paths-head .t-eye{justify-content:center;display:flex;align-items:center;gap:14px;color:var(--lime);}
.paths-h{font-family:var(--f-display);font-size:clamp(40px,5.8vw,86px);line-height:0.94;text-transform:uppercase;color:#fff;margin-top:22px;letter-spacing:0.01em;}
.paths-h span{color:var(--lime);}
.paths-sub{color:rgba(255,255,255,0.62);font-size:clamp(16px,1.6vw,19px);line-height:1.65;margin-top:24px;max-width:600px;margin-left:auto;margin-right:auto;}
.paths-compare{display:grid;grid-template-columns:1fr 1fr;gap:clamp(16px,2.2vw,28px);align-items:stretch;max-width:1000px;margin:0 auto;}
.path-col{padding:clamp(30px,3.4vw,50px);display:flex;flex-direction:column;}
.path-col.alone{background:var(--ink);}
.path-col.with{background:#fff;border-top:3px solid var(--lime);}
.path-label{font-family:var(--f-cta);font-size:11px;font-weight:800;letter-spacing:0.24em;text-transform:uppercase;margin-bottom:12px;}
.path-col.alone .path-label{color:rgba(255,255,255,0.45);}
.path-col.with .path-label{color:var(--navy);}
.path-title{font-family:var(--f-section);font-weight:700;font-size:clamp(22px,2.5vw,32px);line-height:1.08;margin-bottom:clamp(26px,3vh,38px);}
.path-col.alone .path-title{color:#fff;}
.path-col.with .path-title{color:var(--ink);}
.path-list{list-style:none;display:flex;flex-direction:column;gap:18px;flex:1;}
.path-list li{display:flex;gap:14px;align-items:flex-start;font-size:clamp(15px,1.5vw,17px);line-height:1.5;}
.path-col.alone li{color:rgba(255,255,255,0.72);}
.path-col.with li{color:var(--ink);}
.path-ico{width:20px;height:20px;flex-shrink:0;margin-top:1px;fill:none;}
.path-col.alone .path-ico{stroke:rgba(255,255,255,0.4);stroke-width:1.8;}
.path-col.with .path-ico{stroke:var(--navy);stroke-width:2.4;}
.paths-foot{text-align:center;margin-top:clamp(52px,7vh,82px);}
.paths-foot p{font-family:var(--f-section);font-weight:600;font-size:clamp(20px,2.2vw,28px);color:#fff;line-height:1.35;margin-bottom:28px;}
.paths-foot p span{color:var(--lime);}
@media(max-width:760px){
  .paths-compare{grid-template-columns:1fr;}
}

/* Tall hairline lockups (e.g. Vetiver) need much larger cap height to read */
.logo-img.logo-xl{height:clamp(72px,8vw,104px);max-width:200px;opacity:0.95;}

/* ===== BRAND LOGO IMAGES ===== */
.nav-logo-img{height:clamp(52px,5.2vw,64px);width:auto;display:block;filter:brightness(0) invert(1);transition:filter 0.35s var(--ease);}
nav.scrolled .nav-logo-img{filter:none;}
.footer-logo-img{height:clamp(30px,3.4vw,44px);width:auto;display:block;}

/* Resources helper note (replaces old external button) */
.res-allnote{font-family:var(--f-body);font-size:clamp(14px,1.4vw,16px);color:rgba(255,255,255,0.6);max-width:520px;margin:0 auto;line-height:1.6;}

/* =====================================================================
   SECTION WATERMARKS — faded oversized display word (like the CTA 'APPLY')
   ===================================================================== */
.sect{position:relative;}
.sect .inner{position:relative;z-index:1;}
.sect-wm{position:absolute;right:-3%;bottom:6%;font-family:var(--f-display);font-size:min(26vw,380px);line-height:0.78;text-transform:uppercase;letter-spacing:-0.02em;color:rgba(39,39,75,0.045);pointer-events:none;user-select:none;white-space:nowrap;z-index:0;}
.process-sect .sect-wm,.resources-sect .sect-wm,.paths-sect .sect-wm{color:rgba(255,255,255,0.045);}
.services-sect,.process-sect,.resources-sect,.packages-sect,.assembly-sect,.insights-sect{overflow:hidden;}
@media(max-width:720px){.sect-wm{font-size:46vw;bottom:-4%;}}

/* =====================================================================
   INTAKE FORM (contact)
   ===================================================================== */
.cta-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,88px);align-items:center;max-width:var(--max);margin:0 auto;position:relative;z-index:2;}
.cta-grid .cta-h{font-size:clamp(38px,5vw,74px);}
.intake{background:#fff;padding:clamp(26px,3vw,42px);display:flex;flex-direction:column;gap:18px;box-shadow:0 50px 100px -50px rgba(0,0,0,0.6);}
.intake-head{font-family:var(--f-section);font-weight:700;font-size:clamp(19px,1.9vw,24px);color:var(--navy);margin-bottom:2px;}
.intake-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.intake-field{display:flex;flex-direction:column;gap:7px;min-width:0;}
.intake-field label{font-family:var(--f-cta);font-size:9px;font-weight:700;letter-spacing:0.18em;text-transform:uppercase;color:var(--grey);}
.intake-field input,.intake-field select{font-family:var(--f-body);font-size:15px;padding:13px 14px;border:1px solid var(--line-strong);background:var(--bone);color:var(--ink);width:100%;border-radius:0;-webkit-appearance:none;appearance:none;transition:border-color 0.2s,background 0.2s;}
.intake-field select{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='%2327274B' stroke-width='1.6' fill='none'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:34px;}
.intake-field input:focus,.intake-field select:focus{outline:none;border-color:var(--navy);background:#fff;}
.intake-field input::placeholder{color:var(--grey-soft);}
.intake .btn{width:100%;justify-content:center;margin-top:6px;}
.intake-thanks{display:none;background:#fff;padding:clamp(40px,5vw,64px) clamp(26px,3vw,42px);font-family:var(--f-section);font-size:clamp(18px,1.8vw,22px);font-weight:600;color:var(--navy);text-align:center;line-height:1.5;box-shadow:0 50px 100px -50px rgba(0,0,0,0.6);}
@media(max-width:900px){.cta-grid{grid-template-columns:1fr;gap:44px;}}
@media(min-width:901px){.cta-grid>div:last-child{margin-top:130px;}}
@media(max-width:520px){.intake-row{grid-template-columns:1fr;}}

/* =====================================================================
   INSIGHTS / BLOG
   ===================================================================== */
.insights-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,2vw,28px);margin-top:clamp(48px,7vh,90px);}
.insight-card{display:flex;flex-direction:column;background:var(--bone);border:1px solid var(--line);padding:clamp(28px,2.4vw,40px);text-decoration:none;color:inherit;transition:border-color .35s,transform .45s var(--ease);min-height:300px;}
.insight-card:hover{border-color:var(--navy);transform:translateY(-6px);}
.insight-cat{font-family:var(--f-cta);font-size:9px;font-weight:700;letter-spacing:0.2em;text-transform:uppercase;color:var(--grey);margin-bottom:18px;}
.insight-title{font-family:var(--f-section);font-weight:700;font-size:clamp(20px,1.8vw,25px);line-height:1.18;color:var(--navy);margin-bottom:14px;}
.insight-ex{font-size:14px;line-height:1.62;color:var(--grey);flex:1;}
.insight-more{margin-top:24px;font-family:var(--f-cta);font-size:9px;font-weight:700;letter-spacing:0.2em;text-transform:uppercase;color:var(--navy);display:flex;align-items:center;gap:8px;}
.insight-card:hover .insight-more{color:var(--lime-ink,var(--navy));}
.head-row .t-lede a{color:var(--navy);text-decoration:underline;text-underline-offset:3px;font-weight:500;}
/* Article reading page */
.article-hero{background:var(--navy);color:#fff;padding:clamp(120px,18vh,184px) var(--pad) clamp(46px,7vh,74px);position:relative;overflow:hidden;}
.article-hero .a-inner{max-width:820px;margin:0 auto;position:relative;z-index:2;}
.article-cat{font-family:var(--f-cta);font-size:11px;font-weight:700;letter-spacing:0.3em;text-transform:uppercase;color:var(--lime);}
.article-h1{font-family:var(--f-display);font-size:clamp(32px,5vw,60px);line-height:1.02;text-transform:uppercase;letter-spacing:0.005em;margin:22px 0 26px;}
.article-meta{font-family:var(--f-cta);font-size:10.5px;letter-spacing:0.12em;text-transform:uppercase;color:rgba(255,255,255,0.62);display:flex;flex-wrap:wrap;gap:8px 18px;}
.article-body{max-width:720px;margin:clamp(48px,7vh,80px) auto clamp(20px,4vh,40px);padding:0 var(--pad);}
.article-body p{font-size:17px;line-height:1.78;color:var(--ink);margin-bottom:22px;}
.article-body p.lede{font-size:21px;line-height:1.6;color:var(--navy);font-weight:500;margin-bottom:30px;}
.article-body h2{font-family:var(--f-section);font-weight:700;font-size:clamp(21px,2.2vw,28px);color:var(--navy);margin:46px 0 16px;line-height:1.2;}
.article-body ul{margin:0 0 24px;padding:0;list-style:none;display:flex;flex-direction:column;gap:13px;}
.article-body li{font-size:16.5px;line-height:1.62;color:var(--ink);padding-left:26px;position:relative;}
.article-body li::before{content:'';position:absolute;left:0;top:10px;width:6px;height:6px;background:var(--lime);border-radius:50%;}
.article-body blockquote{border-left:3px solid var(--lime);padding:4px 0 4px 26px;margin:32px 0;font-family:var(--f-section);font-size:clamp(20px,2vw,25px);font-weight:600;color:var(--navy);line-height:1.42;}
.article-back{display:inline-flex;font-family:var(--f-cta);font-size:10px;font-weight:700;letter-spacing:0.2em;text-transform:uppercase;color:var(--lime);text-decoration:none;margin-bottom:8px;}
.article-cta{background:var(--bone);border-top:1px solid var(--line);padding:clamp(50px,9vh,92px) var(--pad);text-align:center;margin-top:clamp(40px,6vh,70px);}
.article-cta h2{font-family:var(--f-display);font-size:clamp(28px,4vw,48px);text-transform:uppercase;color:var(--navy);line-height:1;margin-bottom:18px;}
.article-cta p{color:var(--grey);font-size:16px;max-width:520px;margin:0 auto 28px;line-height:1.6;}
@media(max-width:880px){.insights-grid{grid-template-columns:1fr;}}
