*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{--red:#d83030;--dark:#1a1a1a;--dark2:#292929;--white:#fafafa;--gray1:#5B5B5B;--gray2:#A0A0A0;--gray3:#DBDBDB;--pure:#fff}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:'Inter',sans-serif;color:var(--dark);background:var(--pure);-webkit-font-smoothing:antialiased;overflow-x:hidden}
h1,h2,h3,.logo-text,.stat-num,.big-num{font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:0.02em;font-weight:600}

/* ---- NAV ---- */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:0 clamp(24px,5vw,80px);height:72px;display:flex;align-items:center;justify-content:space-between;background:transparent;transition:background .4s,backdrop-filter .4s}
.nav.scrolled{background:rgba(26,26,26,0.97);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px)}
.logo{display:flex;align-items:center;gap:12px;text-decoration:none;color:var(--pure)}
.logo-mark{width:36px;height:36px;position:relative}
.logo-mark span{position:absolute;left:50%;height:2px;background:var(--red);transform-origin:left center;border-radius:1px}
.logo-text{font-size:0.95rem;font-weight:700;letter-spacing:.1em;line-height:1.1}
.nav-links{display:flex;align-items:center;gap:clamp(16px,2vw,32px);list-style:none}
.nav-links a{font-size:.75rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--gray2);text-decoration:none;transition:color .25s;position:relative}
.nav-links a::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:2px;background:var(--red);transition:width .3s}
.nav-links a:hover{color:var(--pure)}
.nav-links a:hover::after{width:100%}
.nav-links a.active{color:var(--pure)}
.nav-links a.active::after{width:100%}
.nav-book-btn{padding:10px 22px;border:1px solid rgba(216,48,48,.5);color:var(--red)!important;font-size:.75rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;text-decoration:none;transition:border-color .2s,color .2s,transform .2s}
.nav-book-btn:hover{border-color:var(--red);transform:translateY(-1px)}
.nav-book-btn::after{display:none!important}
.nav-cta-btn{padding:10px 28px;background:var(--red);color:var(--pure)!important;font-size:.75rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;text-decoration:none;transition:background .2s,transform .2s}
.nav-cta-btn:hover{background:#c22828;transform:translateY(-1px)}
.nav-cta-btn::after{display:none!important}
.nav-phone{color:var(--red)!important;font-size:.75rem;font-weight:700;letter-spacing:.08em}
.nav-phone::after{display:none!important}
.footer-phone{color:var(--pure)!important;font-size:1rem;font-weight:600}
.footer-social{display:flex;gap:14px;margin-top:18px}
.footer-social a{color:var(--gray1);transition:color .2s}
.footer-social a:hover{color:var(--red)}
.burger{display:none;background:none;border:none;cursor:pointer;padding:4px}
.burger i{display:block;width:22px;height:2px;background:var(--pure);margin:5px 0;transition:.3s}

/* ---- HERO ---- */
.hero{min-height:100vh;display:flex;align-items:flex-end;background:var(--dark);position:relative;overflow:hidden;padding-bottom:clamp(60px,10vh,120px)}

/* Animated diagonal lines background */
.hero-lines{position:absolute;inset:0;overflow:hidden;opacity:.07}
.hero-lines .line{position:absolute;width:1px;height:200%;background:var(--pure);transform:rotate(25deg);animation:lineDrift 10s linear infinite}
@keyframes lineDrift{0%{transform:rotate(25deg) translateY(-10%)}100%{transform:rotate(25deg) translateY(10%)}}

/* Floating red accent shapes */
.hero-accent{position:absolute;border-radius:50%;background:var(--red);filter:blur(80px);opacity:.15;animation:pulse 3s ease-in-out infinite alternate}
.hero-accent-1{width:400px;height:400px;top:-100px;right:-100px;animation-delay:0s}
.hero-accent-2{width:300px;height:300px;bottom:10%;left:5%;animation-delay:1s}
@keyframes pulse{0%{transform:scale(1);opacity:.12}100%{transform:scale(1.2);opacity:.2}}



.hero .container{position:relative;z-index:2;max-width:1280px;margin:0 auto;padding:0 clamp(24px,5vw,80px);padding-top:120px;width:100%}
.hero-grid{display:grid;grid-template-columns:1fr auto;gap:64px;align-items:end}
.hero-left{max-width:780px}

.hero-eyebrow{display:inline-flex;align-items:center;gap:10px;margin-bottom:28px;opacity:0;animation:fadeUp .4s .15s forwards}
.hero-eyebrow .dot{width:8px;height:8px;background:var(--red);border-radius:50%;animation:blink 1s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}
.hero-eyebrow span{font-size:.7rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--red)}

.hero h1{font-size:clamp(3.2rem,9vw,7.5rem);line-height:.9;color:var(--pure);margin-bottom:36px;overflow:hidden}
.hero h1 .word{display:inline-block;opacity:0;transform:translateY(100%);animation:wordReveal .35s forwards}
.hero h1 .word:nth-child(1){animation-delay:.2s}
.hero h1 .word:nth-child(2){animation-delay:.28s}
.hero h1 .word:nth-child(3){animation-delay:.36s}
.hero h1 .accent{color:var(--red)}
@keyframes wordReveal{to{opacity:1;transform:translateY(0)}}

.hero-body{font-size:clamp(1rem,1.4vw,1.15rem);line-height:1.75;color:var(--gray2);max-width:480px;margin-bottom:44px;opacity:0;animation:fadeUp .4s .45s forwards}

.hero-btns{display:flex;gap:16px;flex-wrap:wrap;opacity:0;animation:fadeUp .4s .55s forwards}

@keyframes fadeUp{to{opacity:1;transform:translateY(0)}from{opacity:0;transform:translateY(20px)}}

/* Hero right: vertical stat strip */
.hero-right{display:flex;flex-direction:column;gap:32px;padding-bottom:8px;opacity:0;animation:fadeUp .4s .6s forwards}
.hero-stat{text-align:right}
.hero-stat .num{font-family:'Oswald',sans-serif;font-size:3rem;font-weight:700;color:var(--pure);line-height:1}
.hero-stat .lab{font-size:.7rem;font-weight:600;letter-spacing:.15em;text-transform:uppercase;color:var(--gray1);margin-top:4px}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:10px;font-family:'Inter',sans-serif;font-size:.8rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:16px 40px;text-decoration:none;border:none;cursor:pointer;transition:all .25s;position:relative;overflow:hidden}
.btn-red{background:var(--red);color:var(--pure)}
.btn-red::before{content:'';position:absolute;inset:0;background:linear-gradient(120deg,transparent 40%,rgba(255,255,255,.15) 50%,transparent 60%);transform:translateX(-100%);transition:transform .3s}
.btn-red:hover::before{transform:translateX(100%)}
.btn-red:hover{background:#c22828;transform:translateY(-2px);box-shadow:0 8px 32px rgba(216,48,48,.3)}
.btn-ghost{background:transparent;color:var(--pure);border:1px solid var(--gray1)}
.btn-ghost:hover{border-color:var(--pure);transform:translateY(-2px)}
.btn svg{transition:transform .25s}
.btn:hover svg{transform:translate(3px,-3px)}
.arrow-icon{width:16px;height:16px}

/* ---- MARQUEE ---- */
.marquee{background:var(--red);padding:16px 0;overflow:hidden;white-space:nowrap}
.marquee-track{display:inline-flex;animation:scroll 15s linear infinite}
.marquee-track span{font-family:'Oswald',sans-serif;font-size:.85rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--pure);padding:0 48px;opacity:.8}
.marquee-track span::after{content:'';display:inline-block;width:6px;height:6px;background:var(--pure);border-radius:50%;margin-left:48px;vertical-align:middle;opacity:.5}
@keyframes scroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ---- SPLIT SECTION ---- */
.split{display:grid;grid-template-columns:1fr 1fr;min-height:70vh;background:#111}
.split-text{display:flex;flex-direction:column;justify-content:center;padding:clamp(40px,6vw,80px) clamp(32px,5vw,80px);color:var(--pure)}
.split-visual{position:relative;overflow:hidden;background:#1a1a1a}


.split-quote{position:absolute;bottom:clamp(32px,5vw,64px);left:clamp(32px,5vw,64px);right:clamp(32px,5vw,64px);z-index:2}
.split-quote p{font-family:'Oswald',sans-serif;font-size:clamp(1.6rem,3vw,2.4rem);text-transform:uppercase;color:var(--pure);line-height:1.1}
.split-quote .highlight{color:var(--red)}

/* ---- SERVICES ---- */
.services-section{background:var(--dark);padding:clamp(56px,7vw,96px) 0;color:var(--pure)}
.services-header{max-width:1280px;margin:0 auto;padding:0 clamp(24px,5vw,80px);margin-bottom:48px}
.services-header .tag{font-size:.7rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--red);margin-bottom:16px}
.services-header h2{font-size:clamp(2.2rem,4.5vw,3.8rem);line-height:1}
.services-header p{font-size:1rem;line-height:1.7;color:var(--gray2);max-width:480px;margin-top:20px}

.services-masonry{max-width:1280px;margin:0 auto;padding:0 clamp(24px,5vw,80px);display:grid;grid-template-columns:repeat(3,1fr);gap:2px}

.svc-card{background:#222;padding:clamp(36px,4vw,56px);position:relative;overflow:hidden}
.svc-card::before{content:'';position:absolute;top:0;left:0;width:3px;height:0;background:var(--red);transition:height .25s}
.svc-card:hover{background:#2a2a2a}
.svc-card:hover::before{height:100%}
.svc-card .svc-num{font-family:'Oswald',sans-serif;font-size:4rem;font-weight:700;color:rgba(255,255,255,.04);position:absolute;top:16px;right:20px;line-height:1;transition:color .2s}
.svc-card:hover .svc-num{color:rgba(216,48,48,.15)}
.svc-card h3{font-size:1.2rem;letter-spacing:.05em;margin-bottom:14px;position:relative}
.svc-card p{font-size:.88rem;line-height:1.65;color:var(--gray2);position:relative}

/* Big feature card */
.svc-card.big{grid-column:span 2;display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center}
.svc-card.big .svc-num{font-size:6rem}

/* ---- VALUES ---- */
.values-section{background:#111;padding:clamp(56px,7vw,96px) 0;color:var(--pure)}
.values-container{max-width:1280px;margin:0 auto;padding:0 clamp(24px,5vw,80px)}
.values-top{display:grid;grid-template-columns:1fr 1fr;gap:48px;margin-bottom:48px;align-items:end}
.values-top .tag{font-size:.7rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--red);margin-bottom:16px}
.values-top h2{font-size:clamp(2.2rem,4.5vw,3.8rem);line-height:1;color:var(--pure)}
.values-top p{font-size:1rem;line-height:1.7;color:var(--gray2)}

.values-row{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:1px solid rgba(255,255,255,.08)}
.val-item{padding:clamp(28px,3vw,48px) clamp(20px,2vw,32px);border-right:1px solid rgba(255,255,255,.08);border-bottom:1px solid rgba(255,255,255,.08);position:relative}
.val-item:last-child{border-right:none}
.val-item:hover{background:rgba(255,255,255,.03)}
.val-item::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--red);transform:scaleX(0);transform-origin:left;transition:transform .2s}
.val-item:hover::before{transform:scaleX(1)}
.val-item .big-num{font-size:3rem;font-weight:700;color:rgba(255,255,255,.1);line-height:1;margin-bottom:20px;transition:color .15s}
.val-item:hover .big-num{color:var(--red)}
.val-item h3{font-size:1.15rem;letter-spacing:.04em;margin-bottom:12px;color:var(--pure)}
.val-item p{font-size:.85rem;line-height:1.6;color:var(--gray2)}

/* ---- PROCESS (horizontal timeline) ---- */
.process-section{background:#1a1a1a;padding:clamp(56px,7vw,96px) 0;overflow:hidden;color:var(--pure)}
.process-container{max-width:1280px;margin:0 auto;padding:0 clamp(24px,5vw,80px)}
.process-header{margin-bottom:48px}
.process-header .tag{font-size:.7rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--red);margin-bottom:16px}
.process-header h2{font-size:clamp(2.2rem,4.5vw,3.8rem);line-height:1;color:var(--pure)}

.timeline{position:relative;display:grid;grid-template-columns:repeat(4,1fr);gap:0}
.timeline::before{content:'';position:absolute;top:28px;left:0;right:0;height:2px;background:rgba(255,255,255,.1)}
.tl-step{position:relative;padding-top:64px;padding-right:32px}
.tl-dot{position:absolute;top:20px;left:0;width:18px;height:18px;border-radius:50%;background:#1a1a1a;border:3px solid rgba(255,255,255,.15);transition:all .2s;z-index:2}
.tl-step:hover .tl-dot{border-color:var(--red);background:var(--red);box-shadow:0 0 0 6px rgba(216,48,48,.15)}
.tl-step h3{font-size:1.1rem;letter-spacing:.04em;margin-bottom:10px;color:var(--pure)}
.tl-step p{font-size:.85rem;line-height:1.6;color:var(--gray2)}
.tl-step .step-tag{font-family:'Oswald',sans-serif;font-size:.75rem;font-weight:600;letter-spacing:.15em;color:var(--red);margin-bottom:8px}

/* ---- CTA ---- */
.cta{position:relative;padding:clamp(72px,9vw,120px) 0;background:var(--dark);text-align:center;overflow:hidden}
.cta-bg{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;opacity:.03}
.cta-bg span{font-family:'Oswald',sans-serif;font-size:clamp(15rem,30vw,40rem);font-weight:700;color:var(--pure);white-space:nowrap;text-transform:uppercase}
.cta .container{position:relative;z-index:2;max-width:1280px;margin:0 auto;padding:0 clamp(24px,5vw,80px)}
.cta h2{font-size:clamp(2.6rem,6vw,5rem);line-height:.95;color:var(--pure);margin-bottom:24px}
.cta h2 .accent{color:var(--red)}
.cta p{font-size:1.05rem;line-height:1.65;color:var(--gray2);max-width:460px;margin:0 auto 40px}
.cta-line{width:48px;height:3px;background:var(--red);margin:0 auto 32px;animation:expandLine 1s ease-in-out infinite alternate}
@keyframes expandLine{0%{width:48px}100%{width:96px}}

/* ---- FOOTER ---- */
.footer{background:var(--dark);border-top:1px solid rgba(255,255,255,.06);padding:56px 0 28px;color:var(--gray2)}
.footer .container{max-width:1280px;margin:0 auto;padding:0 clamp(24px,5vw,80px)}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;margin-bottom:48px}
.footer-brand p{font-size:.85rem;line-height:1.6;margin-top:16px;color:var(--gray1);max-width:280px}
.footer h4{font-size:.68rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--pure);margin-bottom:16px}
.footer ul{list-style:none}
.footer ul li{margin-bottom:8px}
.footer ul a{font-size:.82rem;color:var(--gray2);text-decoration:none;transition:color .2s}
.footer ul a:hover{color:var(--pure)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.06);padding-top:20px;display:flex;justify-content:space-between;font-size:.75rem;color:var(--gray1)}

/* ---- REVEAL SYSTEM ---- */
.r{opacity:0;transform:translateY(44px);transition:opacity 1s cubic-bezier(.16,1,.3,1),transform 1.1s cubic-bezier(.16,1,.3,1)}
.r.v{opacity:1;transform:translateY(0)}
.r-left{opacity:0;transform:translateX(-44px);transition:opacity 1s cubic-bezier(.16,1,.3,1),transform 1.1s cubic-bezier(.16,1,.3,1)}
.r-left.v{opacity:1;transform:translateX(0)}
.r-right{opacity:0;transform:translateX(44px);transition:opacity 1s cubic-bezier(.16,1,.3,1),transform 1.1s cubic-bezier(.16,1,.3,1)}
.r-right.v{opacity:1;transform:translateX(0)}
.r-scale{opacity:0;transform:scale(.9);transition:opacity 1s cubic-bezier(.16,1,.3,1),transform 1.2s cubic-bezier(.16,1,.3,1)}
.r-scale.v{opacity:1;transform:scale(1)}

/* stagger children */
.stagger .r:nth-child(1){transition-delay:.03s}
.stagger .r:nth-child(2){transition-delay:.07s}
.stagger .r:nth-child(3){transition-delay:.11s}
.stagger .r:nth-child(4){transition-delay:.15s}
.stagger .r:nth-child(5){transition-delay:.19s}
.stagger .r:nth-child(6){transition-delay:.23s}

/* ---- PAGE LAYOUTS ---- */
.page-hero{background:var(--dark);padding:clamp(140px,16vw,200px) 0 clamp(56px,7vw,96px);color:var(--pure)}
.page-hero .container{max-width:1280px;margin:0 auto;padding:0 clamp(24px,5vw,80px)}
.page-hero .tag{font-size:.7rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--red);margin-bottom:16px}
.page-hero h1{font-size:clamp(2.6rem,6vw,5rem);line-height:.95;color:var(--pure)}

/* ---- BRAND PHOTOGRAPHY ---- */
.split-photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:grayscale(100%) contrast(1.05);display:block}
.split-overlay{position:absolute;inset:0;background:rgba(17,17,17,.4);z-index:1}
.split-quote{z-index:3!important}
.photo-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;background:var(--dark)}
.photo-strip-item{position:relative;overflow:hidden;aspect-ratio:4/3}
.photo-strip-item img{width:100%;height:100%;object-fit:cover;filter:grayscale(100%) contrast(1.05);display:block;transition:transform .5s ease,filter .5s ease}
.photo-strip-item:hover img{transform:scale(1.04);filter:grayscale(55%) contrast(1.05)}
.photo-strip-label{position:absolute;bottom:0;left:0;right:0;padding:20px 24px;background:linear-gradient(transparent,rgba(0,0,0,.82));color:var(--pure);font-family:'Oswald',sans-serif;font-size:.7rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;opacity:0;transform:translateY(8px);transition:opacity .3s,transform .3s;z-index:2}
.photo-strip-item:hover .photo-strip-label{opacity:1;transform:translateY(0)}

/* ---- RESPONSIVE ---- */
@media(max-width:1024px){
  .hero-grid{grid-template-columns:1fr;gap:40px}
  .hero-right{flex-direction:row;gap:40px}
  .hero-stat{text-align:left}
  .split{grid-template-columns:1fr}
  .split-visual{min-height:50vh}
  .services-masonry{grid-template-columns:repeat(2,1fr)}
  .svc-card.big{grid-column:span 2}
  .values-row{grid-template-columns:repeat(2,1fr)}
  .val-item:nth-child(2n){border-right:none!important}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:768px){
  .nav-links{display:none;position:fixed;top:72px;left:0;right:0;bottom:0;background:var(--dark);flex-direction:column;align-items:center;justify-content:center;gap:28px;overflow-y:auto}
  .nav-links.open{display:flex}
  /* Prevent nav entrance animation on mobile (it plays on open instead of page load) */
  .nav-links li{animation:none;opacity:1;transform:none}
  .burger{display:block}
  /* Hero stats: show as 2×2 compact grid instead of hiding */
  .hero-right{flex-direction:row;flex-wrap:wrap;gap:20px 32px;padding-top:20px;border-top:1px solid rgba(255,255,255,.08)}
  .hero-stat{text-align:left;min-width:calc(50% - 16px)}
  .hero-stat .num{font-size:2.2rem}
  .split{grid-template-columns:1fr}
  .services-masonry{grid-template-columns:1fr}
  .svc-card.big{grid-column:span 1;grid-template-columns:1fr}
  .values-top{grid-template-columns:1fr}
  .values-row{grid-template-columns:1fr}
  .val-item{border-right:none}
  .photo-strip{grid-template-columns:1fr}
  .timeline{grid-template-columns:1fr}
  .timeline::before{display:none}
  .tl-step{padding-left:36px;padding-right:0;padding-top:0;margin-bottom:36px}
  .tl-dot{top:4px;left:0}
  .footer-grid{grid-template-columns:1fr;gap:24px}
  .footer-bottom{flex-direction:column;gap:8px;text-align:center}
  .hero-btns{flex-direction:column}
  .btn{justify-content:center}
  /* Footer services list: 2-column on mobile */
  .footer-grid > div:nth-child(3) ul{display:grid;grid-template-columns:1fr 1fr;gap:0}
  /* founder bio responsive */
  #founder [style*="grid-template-columns:1fr 2fr"]{grid-template-columns:1fr!important;gap:32px!important}
  /* mobile CTA body padding — accounts for notched iPhone home indicator */
  body{padding-bottom:calc(60px + env(safe-area-inset-bottom))}
}

/* Disable hover lift/transform on touch devices */
@media(hover:none){
  .bl-card:hover{transform:none}
  .svc-card:hover{transform:none;box-shadow:none}
  .val-item:hover{transform:none;box-shadow:none}
  .cx-problem-card:hover,.cx-scenario-card:hover,.cx-not-item:hover,.cx-why-item:hover,.cx-proof-card:hover,.cx-ind-item:hover{transform:none;box-shadow:none}
  .btn-red:hover{transform:none;box-shadow:none}
  .btn-ghost:hover{transform:none}
}

/* ---- BLOG LISTING ---- */
.bl-hero{background:var(--dark);padding:clamp(140px,16vw,200px) 0 clamp(56px,7vw,80px);color:var(--pure)}
.bl-hero .container{max-width:1280px;margin:0 auto;padding:0 clamp(24px,5vw,80px)}
.bl-hero h1{font-size:clamp(3rem,7vw,5.5rem);line-height:.9;color:var(--pure);margin:16px 0 24px}
.bl-hero p{font-size:1rem;line-height:1.7;color:var(--gray2);max-width:500px}
.bl-listing{background:#0f0f0f;padding:clamp(48px,6vw,80px) 0}
.bl-listing .container{max-width:1280px;margin:0 auto;padding:0 clamp(24px,5vw,80px)}
.bl-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px}
.bl-card{background:#1a1a1a;padding:clamp(28px,3vw,44px);border-left:3px solid transparent;transition:border-color .25s,background .25s,transform .25s}
.bl-card:hover{background:#222;border-left-color:var(--red);transform:translateY(-4px)}
.bl-meta{font-size:.72rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--gray1);margin-bottom:16px;display:flex;align-items:center;gap:8px}
.bl-dot{color:var(--red)}
.bl-card h2{font-size:1.05rem;letter-spacing:.03em;color:var(--pure);margin-bottom:12px;line-height:1.2}
.bl-card h2 a{color:inherit;text-decoration:none;transition:color .2s}
.bl-card h2 a:hover{color:var(--red)}
.bl-card p{font-size:.84rem;line-height:1.65;color:var(--gray2);margin-bottom:20px}
.bl-read-more{display:inline-flex;align-items:center;gap:6px;font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--red);text-decoration:none;transition:gap .2s}
.bl-read-more:hover{gap:10px}
@media(max-width:1024px){.bl-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.bl-grid{grid-template-columns:1fr}}

/* ---- BLOG POST ---- */
.bp-hero{background:var(--dark);padding:clamp(120px,14vw,180px) 0 clamp(40px,5vw,64px);color:var(--pure)}
.bp-container{max-width:760px;margin:0 auto;padding:0 clamp(24px,5vw,48px)}
.bp-breadcrumb{display:flex;align-items:center;gap:8px;font-size:.72rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--gray1);margin-bottom:24px;flex-wrap:wrap}
.bp-breadcrumb a{color:var(--gray1);text-decoration:none;transition:color .2s}
.bp-breadcrumb a:hover{color:var(--pure)}
.bp-meta{display:flex;align-items:center;gap:8px;font-size:.72rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--gray1);margin-bottom:20px}
.bp-dot{color:var(--red)}
.bp-hero h1{font-size:clamp(2rem,4.5vw,3.4rem);line-height:1.05;color:var(--pure);margin-bottom:20px}
.bp-desc{font-size:1rem;line-height:1.65;color:var(--gray2)}
.bp-body{background:#0f0f0f;padding:clamp(48px,6vw,80px) 0}
.bp-content{color:var(--gray2);font-size:.97rem;line-height:1.85;margin-bottom:56px}
.bp-content h2{font-size:clamp(1.3rem,2.5vw,1.8rem);color:var(--pure);margin:44px 0 18px;letter-spacing:.02em;font-family:'Oswald',sans-serif;text-transform:uppercase}
.bp-content h3{font-size:1.1rem;color:var(--pure);margin:32px 0 12px}
.bp-content p{margin-bottom:18px}
.bp-content ul,.bp-content ol{margin:0 0 18px 20px}
.bp-content li{margin-bottom:8px}
.bp-content strong{color:var(--pure)}
.bp-content a{color:var(--red);text-decoration:none}
.bp-content a:hover{text-decoration:underline}
.bp-further{background:#1a1a1a;padding:24px 28px;margin-bottom:40px}
.bp-further-label{font-size:.65rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--red);margin-bottom:12px}
.bp-further-link{display:flex;align-items:center;gap:8px;font-size:.85rem;font-weight:600;color:var(--gray2);text-decoration:none;padding:8px 0;border-bottom:1px solid rgba(255,255,255,.05);transition:color .2s}
.bp-further-link:last-child{border-bottom:none}
.bp-further-link:hover{color:var(--pure)}
.bp-cta{background:var(--dark);padding:48px;text-align:center}
.bp-cta .cta-line{margin:0 auto 28px}
.bp-cta h2{font-size:clamp(1.5rem,3vw,2.2rem);color:var(--pure);margin-bottom:14px}
.bp-cta p{font-size:.9rem;line-height:1.65;color:var(--gray2);max-width:360px;margin:0 auto 24px}

/* ---- CX: SHARED ---- */
.cx-section{padding:clamp(80px,10vw,120px) 0}
.cx-container{max-width:1280px;margin:0 auto;padding:0 clamp(24px,5vw,80px)}
.cx-eyebrow{font-size:.7rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--red);margin-bottom:16px}
.cx-h2{font-size:clamp(2rem,4vw,3.2rem);line-height:1;color:var(--pure);margin-bottom:20px}
.cx-sub{font-size:.97rem;line-height:1.75;color:var(--gray2)}

/* ---- CX: PROBLEM ---- */
.cx-problem{background:#0f0f0f}
.cx-problem-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;margin-top:56px}
.cx-problem-card{background:#1a1a1a;padding:36px 32px;border-top:3px solid transparent}
.cx-problem-card:hover{border-top-color:var(--red)}
.cx-problem-card h3{font-size:1rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--pure);margin-bottom:12px}
.cx-problem-card p{font-size:.87rem;line-height:1.7;color:var(--gray2)}
@media(max-width:900px){.cx-problem-grid{grid-template-columns:1fr 1fr}}
@media(max-width:580px){.cx-problem-grid{grid-template-columns:1fr}}


/* ---- CX: INDUSTRIES ---- */
.cx-industries{background:#0f0f0f}
.cx-ind-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2px;margin-top:48px}
.cx-ind-item{padding:32px 28px;background:#141414;border-left:3px solid transparent}
.cx-ind-item:hover{background:#1e1e1e;border-left-color:var(--red)}
.cx-ind-label{font-size:.82rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--pure);margin-bottom:8px}
.cx-ind-item p{font-size:.82rem;line-height:1.6;color:var(--gray2)}
@media(max-width:900px){.cx-ind-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.cx-ind-grid{grid-template-columns:1fr}}

/* ---- CX: PROOF ---- */
.cx-proof{background:var(--dark)}
.cx-proof-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;margin-top:52px}
.cx-proof-card{background:#1a1a1a;padding:36px 32px}
.cx-proof-quote{font-size:1.05rem;line-height:1.7;color:var(--pure);margin-bottom:28px;font-style:italic}
.cx-proof-quote::before{content:'\201C';font-size:2.4rem;line-height:1;color:var(--red);display:block;margin-bottom:8px;font-style:normal}
.cx-proof-attr{font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--gray1)}
.cx-proof-attr span{color:var(--red)}
@media(max-width:900px){.cx-proof-grid{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.cx-proof-grid{grid-template-columns:1fr}}

/* ---- CX: STATS BAR ---- */
.cx-stats{background:var(--red);padding:clamp(40px,6vw,64px) 0}
.cx-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2px}
.cx-stat-item{text-align:center;padding:24px}
.cx-stat-num{font-size:clamp(2.2rem,4.5vw,3.6rem);font-weight:900;color:var(--pure);line-height:1}
.cx-stat-lab{font-size:.72rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:rgba(255,255,255,.75);margin-top:8px}
@media(max-width:700px){.cx-stats-grid{grid-template-columns:repeat(2,1fr)}}

/* ---- CX: FAQ ---- */
.cx-faq{background:#0f0f0f}
.cx-faq-list{margin-top:52px;max-width:820px}
.cx-faq-item{border-bottom:1px solid rgba(255,255,255,.07)}
.cx-faq-q{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:22px 0;cursor:pointer;user-select:none}
.cx-faq-q h3{font-size:.97rem;font-weight:700;letter-spacing:.03em;color:var(--pure);margin:0}
.cx-faq-icon{width:22px;height:22px;flex-shrink:0;border:1.5px solid rgba(255,255,255,.2);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:border-color .25s,transform .3s;position:relative}
.cx-faq-icon::before,.cx-faq-icon::after{content:'';position:absolute;background:var(--pure);transition:transform .3s,opacity .3s}
.cx-faq-icon::before{width:8px;height:1.5px}
.cx-faq-icon::after{width:1.5px;height:8px}
.cx-faq-item.open .cx-faq-icon{border-color:var(--red);transform:rotate(45deg)}
.cx-faq-a{overflow:hidden;max-height:0;transition:max-height .4s ease}
.cx-faq-a p{padding-bottom:22px;font-size:.9rem;line-height:1.75;color:var(--gray2);margin:0}
.cx-faq-item.open .cx-faq-a{max-height:500px}

/* ---- CX: MANIFESTO ---- */
.cx-manifesto{background:var(--dark);padding:clamp(80px,12vw,140px) 0;text-align:center}
.cx-manifesto blockquote{font-size:clamp(1.6rem,3.5vw,2.8rem);line-height:1.2;color:var(--pure);max-width:860px;margin:0 auto 32px;font-family:'Oswald',sans-serif;font-weight:600;text-transform:uppercase;letter-spacing:.04em}
.cx-manifesto blockquote em{color:var(--red);font-style:normal}
.cx-manifesto cite{font-size:.75rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--gray1)}

/* ---- CX: SCENARIO CARDS ---- */
.cx-scenarios{background:#0f0f0f}
.cx-scenario-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2px;margin-top:52px}
.cx-scenario-card{background:#141414;padding:40px 36px}
.cx-scenario-label{font-size:.65rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--red);margin-bottom:20px}
.cx-scenario-card h3{font-size:1.1rem;color:var(--pure);margin-bottom:16px;line-height:1.2}
.cx-scenario-card p{font-size:.87rem;line-height:1.72;color:var(--gray2)}
@media(max-width:700px){.cx-scenario-grid{grid-template-columns:1fr}}

/* ---- CX: NOT-LIST (About) ---- */
.cx-not-list{margin-top:48px;display:grid;grid-template-columns:repeat(3,1fr);gap:2px}
.cx-not-item{background:#1a1a1a;padding:36px 32px}
.cx-not-bad{font-size:.65rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--gray1);margin-bottom:4px;text-decoration:line-through;opacity:.55}
.cx-not-good{font-size:.65rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--red);margin-bottom:16px}
.cx-not-item h3{font-size:1rem;color:var(--pure);margin-bottom:12px}
.cx-not-item p{font-size:.85rem;line-height:1.68;color:var(--gray2)}
@media(max-width:800px){.cx-not-list{grid-template-columns:1fr 1fr}}
@media(max-width:540px){.cx-not-list{grid-template-columns:1fr}}

/* ---- CX: WHY GRID ---- */
.cx-why{background:var(--dark)}
.cx-why-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2px;margin-top:52px}
.cx-why-item{padding:36px 32px;border:1px solid rgba(255,255,255,.06);transition:border-color .25s}
.cx-why-item:hover{border-color:rgba(216,48,48,.4)}
.cx-why-num{font-size:3rem;font-weight:900;color:rgba(216,48,48,.15);line-height:1;margin-bottom:12px}
.cx-why-item h3{font-size:1rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--pure);margin-bottom:12px}
.cx-why-item p{font-size:.87rem;line-height:1.7;color:var(--gray2)}
@media(max-width:700px){.cx-why-grid{grid-template-columns:1fr}}

/* ---- CX: CONTACT FORM ---- */
.cx-contact-bg{background:var(--dark);padding:clamp(100px,12vw,140px) 0 clamp(60px,8vw,100px)}
.cx-contact-layout{display:grid;grid-template-columns:1fr 1.6fr;gap:80px;align-items:start}
.cx-contact-info h1{font-size:clamp(2.2rem,4vw,3.4rem);line-height:1;color:var(--pure);margin-bottom:24px}
.cx-contact-info p{font-size:.95rem;line-height:1.75;color:var(--gray2);margin-bottom:32px}
.cx-contact-detail{margin-bottom:20px}
.cx-contact-detail-label{font-size:.65rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--red);margin-bottom:4px}
.cx-contact-detail-val{font-size:.9rem;color:var(--gray2);line-height:1.5}
.cx-contact-detail-val a{color:var(--gray2);text-decoration:none;transition:color .2s}
.cx-contact-detail-val a:hover{color:var(--pure)}
.cx-trust-list{margin-top:40px;padding-top:32px;border-top:1px solid rgba(255,255,255,.07)}
.cx-trust-item{display:flex;align-items:flex-start;gap:10px;font-size:.82rem;color:var(--gray2);margin-bottom:12px;line-height:1.5}
.cx-trust-item::before{content:'✓';color:var(--red);font-weight:700;flex-shrink:0;margin-top:1px}
.cx-form{background:#111;padding:40px}
.cx-form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:0}
.cx-form-group{margin-bottom:20px}
.cx-form-group label{display:block;font-size:.65rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--gray1);margin-bottom:8px}
.cx-form-group input,.cx-form-group select,.cx-form-group textarea{width:100%;background:#1a1a1a;border:1px solid rgba(255,255,255,.1);color:var(--pure);font-family:inherit;font-size:.9rem;padding:14px 16px;transition:border-color .25s;outline:none;box-sizing:border-box}
.cx-form-group input:focus,.cx-form-group select:focus,.cx-form-group textarea:focus{border-color:var(--red)}
.cx-form-group select{appearance:none;cursor:pointer;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='%23666' stroke-width='1.5' fill='none'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center}
.cx-form-group textarea{resize:vertical;min-height:120px}
.cx-form-submit{width:100%;padding:18px;background:var(--red);color:var(--pure);font-family:'Oswald',sans-serif;font-weight:600;font-size:.9rem;letter-spacing:.12em;text-transform:uppercase;border:none;cursor:pointer;transition:background .25s}
.cx-form-submit:hover{background:#b82020}
@media(max-width:900px){.cx-contact-layout{grid-template-columns:1fr;gap:48px}}
@media(max-width:560px){.cx-form-row{grid-template-columns:1fr}.cx-form{padding:28px 24px}}


/* ---- CX: CITIES / LOCATIONS ---- */
.cx-locs{background:#0f0f0f}
.cx-cities-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:2px;margin-top:48px}
.cx-city-item{padding:24px 18px;background:#141414;text-align:center;transition:background .25s}
.cx-city-item:hover{background:#1e1e1e}
.cx-city-name{font-size:.82rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--pure)}
.cx-city-note{font-size:.72rem;color:var(--gray2);margin-top:4px;line-height:1.4}
.cx-locations-prose{max-width:860px;margin-top:48px}
.cx-locations-prose p{font-size:.9rem;line-height:1.8;color:var(--gray2);margin-bottom:16px}
.cx-locations-prose p strong{color:var(--pure)}
@media(max-width:1000px){.cx-cities-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:500px){.cx-cities-grid{grid-template-columns:repeat(2,1fr)}}

/* ---- CX: BLOG LINK CARDS ---- */
.cx-blog-links{background:var(--dark)}
.cx-blog-links-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;margin-top:52px}
.cx-blog-link-card{background:#111;padding:32px 28px;text-decoration:none;display:block;border-bottom:3px solid transparent;transition:border-color .25s,background .25s}
.cx-blog-link-card:hover{background:#1a1a1a;border-bottom-color:var(--red)}
.cx-blog-link-label{font-size:.65rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--red);margin-bottom:12px}
.cx-blog-link-card h3{font-size:.95rem;color:var(--pure);margin-bottom:10px;line-height:1.3;font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:.03em}
.cx-blog-link-card p{font-size:.82rem;line-height:1.6;color:var(--gray2)}
@media(max-width:900px){.cx-blog-links-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:580px){.cx-blog-links-grid{grid-template-columns:1fr}}

/* ---- CX: COST GUIDE ---- */
.cx-cost-guide{background:var(--dark)}
.cx-cost-factors{display:grid;grid-template-columns:repeat(2,1fr);gap:2px;margin-top:52px}
.cx-cost-factor{padding:36px 32px;background:#111}
.cx-cost-factor h3{font-size:1rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--pure);margin-bottom:12px}
.cx-cost-factor p{font-size:.87rem;line-height:1.72;color:var(--gray2)}
.cx-cost-ranges{display:grid;grid-template-columns:repeat(4,1fr);gap:2px;margin-top:2px}
.cx-cost-range{padding:28px 24px;background:#1a1a1a;border-top:3px solid transparent;transition:border-color .3s}
.cx-cost-range:hover{border-top-color:var(--red)}
.cx-cost-range-type{font-size:.65rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--red);margin-bottom:12px}
.cx-cost-range-val{font-size:1.25rem;font-weight:700;color:var(--pure);margin-bottom:8px;font-family:'Oswald',sans-serif}
.cx-cost-range-note{font-size:.78rem;line-height:1.6;color:var(--gray2)}
@media(max-width:900px){.cx-cost-factors{grid-template-columns:1fr}}
@media(max-width:760px){.cx-cost-ranges{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.cx-cost-ranges{grid-template-columns:1fr}}

/* ---- CX: GUARANTEE ---- */
.cx-guarantee{background:#111}
.cx-guarantee-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;margin-top:52px}
.cx-guarantee-item{padding:40px 36px;background:#141414;text-align:center;border-top:3px solid transparent;transition:border-top-color .3s}
.cx-guarantee-item:hover{border-top-color:var(--red)}
.cx-guarantee-num{font-size:2.8rem;font-weight:900;color:rgba(216,48,48,.2);line-height:1;margin-bottom:16px;font-family:'Oswald',sans-serif}
.cx-guarantee-item h3{font-size:.88rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--pure);margin-bottom:12px}
.cx-guarantee-item p{font-size:.85rem;line-height:1.7;color:var(--gray2)}
@media(max-width:760px){.cx-guarantee-grid{grid-template-columns:1fr 1fr}}
@media(max-width:500px){.cx-guarantee-grid{grid-template-columns:1fr}}

/* ---- CX: CREDENTIALS ---- */
.cx-creds{background:#0f0f0f}
.cx-creds-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2px;margin-top:48px}
.cx-cred-item{padding:32px 28px;background:#141414;border-left:3px solid var(--red)}
.cx-cred-title{font-size:.65rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--red);margin-bottom:10px}
.cx-cred-val{font-size:1.2rem;font-weight:700;color:var(--pure);margin-bottom:8px;font-family:'Oswald',sans-serif}
.cx-cred-note{font-size:.78rem;line-height:1.5;color:var(--gray2)}
@media(max-width:900px){.cx-creds-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:500px){.cx-creds-grid{grid-template-columns:1fr}}

/* ---- CX: TIMELINE TABLE ---- */
.cx-timeline-tbl{background:#0f0f0f}
.cx-tbl-wrap{overflow-x:auto;margin-top:52px}
.cx-tbl{width:100%;border-collapse:collapse;min-width:640px}
.cx-tbl th{font-size:.65rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--gray1);padding:14px 20px;text-align:left;border-bottom:1px solid rgba(255,255,255,.08)}
.cx-tbl td{padding:18px 20px;font-size:.87rem;color:var(--gray2);border-bottom:1px solid rgba(255,255,255,.05)}
.cx-tbl td.cx-tbl-type{font-weight:700;color:var(--pure);font-size:.85rem;text-transform:uppercase;letter-spacing:.03em}
.cx-tbl td.cx-tbl-dur{color:var(--red);font-weight:700}
.cx-tbl tr:hover td{background:rgba(255,255,255,.02)}

/* ---- CX: CONVERSION STRIP ---- */
.cx-conversion{background:var(--red);padding:clamp(48px,7vw,80px) 0}
.cx-conversion-inner{display:grid;grid-template-columns:1fr auto;gap:40px;align-items:center}
.cx-conversion h2{font-size:clamp(1.6rem,3vw,2.4rem);color:var(--pure);line-height:1}
.cx-conversion p{font-size:.9rem;color:rgba(255,255,255,.8);margin-top:12px;line-height:1.6}
.cx-conversion .btn{background:var(--pure);color:var(--dark)!important;font-family:'Oswald',sans-serif;white-space:nowrap;border:none}
.cx-conversion .btn:hover{background:var(--gray3)}
@media(max-width:700px){.cx-conversion-inner{grid-template-columns:1fr}}

/* ======================================================
   ELEVATED ANIMATIONS
   ====================================================== */

/* ---- SCROLL PROGRESS BAR ---- */
#cx-progress{position:fixed;top:0;left:0;height:2px;background:var(--red);z-index:1000;width:0%;pointer-events:none;will-change:width}

/* ---- CUSTOM CURSOR (desktop only) ---- */
.cx-cursor{position:fixed;top:0;left:0;pointer-events:none;z-index:9999;display:none}
@media(pointer:fine){.cx-cursor{display:block}}
.cx-cursor-ring{width:36px;height:36px;border:1.5px solid rgba(216,48,48,.5);border-radius:50%;position:absolute;transform:translate(-50%,-50%);transition:width .45s cubic-bezier(.16,1,.3,1),height .45s cubic-bezier(.16,1,.3,1),border-color .35s,opacity .3s}
body.cx-hovering .cx-cursor-ring{width:64px;height:64px;border-color:rgba(216,48,48,.8)}
body.cx-clicking .cx-cursor-ring{width:18px;height:18px;opacity:.7;border-color:var(--red)}
@media(pointer:fine){body{cursor:none}body a,body button{cursor:none}}

/* ---- MARQUEE PAUSE ON HOVER ---- */
.marquee:hover .marquee-track{animation-play-state:paused}


/* ---- EXTENDED STAGGER — up to 12 children ---- */
.stagger .r:nth-child(7){transition-delay:.33s}
.stagger .r:nth-child(8){transition-delay:.39s}
.stagger .r:nth-child(9){transition-delay:.45s}
.stagger .r:nth-child(10){transition-delay:.51s}
.stagger .r:nth-child(11){transition-delay:.57s}
.stagger .r:nth-child(12){transition-delay:.63s}

/* ---- BLUR-IN VARIANT ---- */
.cx-blur{opacity:0;filter:blur(8px);transform:translateY(14px);transition:opacity 1.1s cubic-bezier(.16,1,.3,1),filter 1.1s cubic-bezier(.16,1,.3,1),transform 1.1s cubic-bezier(.16,1,.3,1)}
.cx-blur.v{opacity:1;filter:blur(0);transform:translateY(0)}

/* ---- EYEBROW UNDERLINE DRAW ---- */
.cx-eyebrow{position:relative;display:inline-block}
.cx-eyebrow::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:1.5px;background:var(--red);transition:width .9s .25s cubic-bezier(.16,1,.3,1)}
.r.v .cx-eyebrow::after,.r-left.v .cx-eyebrow::after,.r-right.v .cx-eyebrow::after,.r-scale.v .cx-eyebrow::after{width:100%}

/* ---- CARD HOVER LIFT ---- */
.cx-problem-card,.cx-scenario-card,.cx-not-item,.cx-why-item,.cx-proof-card,.cx-ind-item{transition:transform .35s cubic-bezier(.16,1,.3,1),box-shadow .35s,border-color .35s,background .25s}
.cx-problem-card:hover,.cx-scenario-card:hover,.cx-not-item:hover,.cx-why-item:hover,.cx-proof-card:hover,.cx-ind-item:hover{transform:translateY(-6px);box-shadow:0 16px 48px rgba(0,0,0,.4)}
.cx-problem-card:hover,.cx-ind-item:hover{border-color:rgba(216,48,48,.35);box-shadow:0 8px 40px rgba(216,48,48,.08),0 2px 12px rgba(0,0,0,.4)}

/* ---- CTA AMBIENT GLOW ---- */
.cta{overflow:hidden}
.cta::after{content:'';position:absolute;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(216,48,48,.08) 0%,transparent 65%);top:50%;left:50%;transform:translate(-50%,-50%);pointer-events:none;animation:ctaGlow 5s ease-in-out infinite alternate}
@keyframes ctaGlow{0%{opacity:.6;transform:translate(-50%,-50%) scale(1)}100%{opacity:1;transform:translate(-50%,-50%) scale(1.5)}}

/* ---- SVC CARD LIFT ---- */
.svc-card{transition:transform .35s cubic-bezier(.16,1,.3,1),box-shadow .35s,border-color .3s,background .3s}
.svc-card:hover{transform:translateY(-5px);box-shadow:0 12px 40px rgba(0,0,0,.35)}

/* ---- VAL ITEM LIFT ---- */
.val-item{transition:transform .35s cubic-bezier(.16,1,.3,1),box-shadow .35s}
.val-item:hover{transform:translateY(-5px);box-shadow:0 12px 40px rgba(0,0,0,.25)}

/* ---- CTA LINE DRAW (pulsing replaced by a one-time draw on entering viewport) ---- */
.cta-line{width:0;animation:none;transition:width 1.2s .2s cubic-bezier(.16,1,.3,1)}
.r-scale.v .cta-line,.r.v .cta-line{width:48px}

/* ---- NAV LINK ENTRANCE ON LOAD ---- */
.nav-links li{opacity:0;transform:translateY(-8px);animation:navIn .4s forwards}
.nav-links li:nth-child(1){animation-delay:.1s}
.nav-links li:nth-child(2){animation-delay:.15s}
.nav-links li:nth-child(3){animation-delay:.2s}
.nav-links li:nth-child(4){animation-delay:.25s}
.nav-links li:nth-child(5){animation-delay:.3s}
.nav-links li:nth-child(6){animation-delay:.35s}
.nav-links li:nth-child(7){animation-delay:.4s}
.nav-links li:nth-child(8){animation-delay:.45s}
.nav-links li:nth-child(9){animation-delay:.5s}
@keyframes navIn{to{opacity:1;transform:translateY(0)}}

/* ---- VALUE SECTION NUMBERS SUBTLE PULSE ---- */
@keyframes numPulse{0%,100%{opacity:.12}60%{opacity:.22}}
.values-section .big-num{animation:numPulse 4s ease-in-out infinite}
.values-section .val-item:nth-child(2) .big-num{animation-delay:.8s}
.values-section .val-item:nth-child(3) .big-num{animation-delay:1.6s}
.values-section .val-item:nth-child(4) .big-num{animation-delay:2.4s}


/* ---- SPOTLIGHT MOUSE GLOW ---- */
.cx-spotlight{isolation:isolate;position:relative}
.cx-spotlight::before{content:'';position:absolute;inset:0;background:radial-gradient(700px circle at var(--mx,50%) var(--my,-20%),rgba(216,48,48,.07),transparent 65%);pointer-events:none;z-index:0;opacity:0;transition:opacity .5s}
.cx-spotlight:hover::before{opacity:1}
.cx-spotlight>.cx-container{position:relative;z-index:1}

/* ---- HERO EYEBROW DOT PULSE ---- */
@keyframes dotPulse{0%,100%{box-shadow:0 0 0 0 rgba(216,48,48,.5)}60%{box-shadow:0 0 0 7px rgba(216,48,48,0)}}
.hero .dot{animation:dotPulse 2.2s ease-in-out infinite}

/* ---- HERO STAT ENTRANCE ---- */
.hero-right{animation:fadeUp .6s .7s both}

/* ---- SECTION HEADER UNDERLINE FAST ---- */
.cx-h2{position:relative}


/* ---- PRIVACY / LEGAL PROSE ---- */
.cx-prose h2{font-size:1.1rem;color:var(--pure);margin:40px 0 12px;letter-spacing:.04em}
.cx-prose p{font-size:.92rem;line-height:1.78;color:var(--gray2);margin-bottom:16px}
.cx-prose ul{padding-left:20px;margin-bottom:16px}
.cx-prose li{font-size:.92rem;line-height:1.75;color:var(--gray2);margin-bottom:6px}
.cx-prose a{color:var(--red);text-decoration:none}
.cx-prose a:hover{text-decoration:underline}
.cx-prose strong{color:var(--pure)}

/* ---- WHATSAPP FLOATING BUTTON ---- */
.cx-whatsapp{position:fixed;bottom:88px;right:24px;z-index:90;width:52px;height:52px;background:#25d366;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(0,0,0,.35);transition:transform .2s,box-shadow .2s}
.cx-whatsapp:hover{transform:translateY(-3px);box-shadow:0 8px 24px rgba(0,0,0,.45)}
@media(min-width:769px){.cx-whatsapp{bottom:32px}}

/* ---- STICKY MOBILE CTA BAR ---- */
.cx-mobile-cta{display:none;position:fixed;bottom:0;left:0;right:0;z-index:95;height:60px;background:var(--dark2);border-top:1px solid rgba(255,255,255,.08);flex-direction:row;padding-bottom:env(safe-area-inset-bottom)}
.cx-mobile-cta-call{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;color:var(--pure);font-size:.78rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;text-decoration:none;border-right:1px solid rgba(255,255,255,.08)}
.cx-mobile-cta-quote{flex:2;display:flex;align-items:center;justify-content:center;background:var(--red);color:var(--pure);font-size:.78rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;text-decoration:none}
@media(max-width:768px){.cx-mobile-cta{display:flex}}

/* ---- BEFORE / AFTER SLIDER ---- */
.cx-ba-before{transition:width .05s linear}
.cx-ba-handle{transition:left .05s linear}
@media(max-width:600px){.cx-ba-wrap{max-width:100%!important}}

/* ---- DESKTOP STICKY PHONE TAB ---- */
.cx-phone-tab{display:none;position:fixed;left:-110px;top:50%;transform:translateY(-50%) rotate(-90deg);transform-origin:left center;z-index:87;background:var(--dark2);color:var(--gray2);text-decoration:none;padding:10px 20px;font-size:.7rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;border:1px solid rgba(255,255,255,.1);transition:left .4s cubic-bezier(.16,1,.3,1),color .2s;white-space:nowrap}
.cx-phone-tab:hover{color:var(--pure);left:-100px}
@media(min-width:1100px){.cx-phone-tab{display:block;left:0}}

/* ---- SCROLL-TRIGGERED QUOTE TAB ---- */
.cx-quote-tab{position:fixed;right:-120px;top:50%;transform:translateY(-50%) rotate(90deg);transform-origin:right center;z-index:88;background:var(--red);color:var(--pure);text-decoration:none;padding:10px 20px;font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;transition:right .4s cubic-bezier(.16,1,.3,1);display:flex;align-items:center;box-shadow:-4px 0 16px rgba(0,0,0,.4)}
.cx-quote-tab.visible{right:-8px}
.cx-quote-tab:hover{right:0}
@media(max-width:768px){.cx-quote-tab{display:none}}

/* ---- SKIP TO CONTENT ---- */
.cx-skip-link{position:absolute;top:-100px;left:16px;z-index:9999;background:var(--red);color:var(--pure);padding:10px 20px;font-size:.78rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;text-decoration:none;transition:top .2s}
.cx-skip-link:focus{top:16px}

/* ---- BACK TO TOP BUTTON ---- */
.cx-back-top{position:fixed;bottom:32px;left:24px;z-index:89;width:44px;height:44px;background:var(--dark2);border:1px solid rgba(255,255,255,.12);color:var(--gray2);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:0;transform:translateY(12px);transition:opacity .3s,transform .3s,background .2s,color .2s;pointer-events:none}
.cx-back-top.visible{opacity:1;transform:translateY(0);pointer-events:auto}
.cx-back-top:hover{background:var(--red);color:var(--pure);border-color:var(--red)}
@media(max-width:768px){.cx-back-top{bottom:72px;left:16px}}

/* ---- BLOG AUTHOR BYLINE ---- */
.bp-author{display:inline-flex;align-items:center;gap:8px;color:var(--pure);font-weight:600}
.bp-author-avatar{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;background:var(--red);color:var(--pure);font-size:.65rem;font-weight:700;letter-spacing:.04em;border-radius:50%;flex-shrink:0}

/* ---- BLOG TABLE OF CONTENTS ---- */
.bp-toc{background:rgba(255,255,255,.04);border-left:2px solid var(--red);padding:20px 24px;margin-bottom:40px;display:none}
.bp-toc.has-items{display:block}
.bp-toc-label{font-size:.65rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--red);margin-bottom:12px}
.bp-toc ol{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px}
.bp-toc ol li a{font-size:.82rem;color:var(--gray2);text-decoration:none;transition:color .2s;line-height:1.4}
.bp-toc ol li a:hover{color:var(--pure)}

/* ---- BLOG SOCIAL SHARE ---- */
.bp-share{display:flex;align-items:center;gap:10px;padding:28px 0;border-top:1px solid rgba(255,255,255,.07);margin-top:48px;flex-wrap:wrap}
.bp-share-label{font-size:.7rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--gray2);margin-right:4px}
.bp-share-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;font-size:.73rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;text-decoration:none;border:1px solid rgba(255,255,255,.12);color:var(--gray2);background:transparent;cursor:pointer;font-family:inherit;transition:background .2s,color .2s,border-color .2s}
.bp-share-btn:hover{color:var(--pure);border-color:rgba(255,255,255,.3)}
.bp-share-li:hover{background:#0077b5;border-color:#0077b5;color:#fff}
.bp-share-tw:hover{background:#000;border-color:#000;color:#fff}
.bp-share-copy:hover{background:var(--red);border-color:var(--red);color:#fff}
.bp-share-copy.copied{background:var(--red);border-color:var(--red);color:#fff}

/* ---- BLOG RSS LINK ---- */
.bl-rss{display:inline-flex;align-items:center;gap:6px;margin-top:16px;font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--gray2);text-decoration:none;transition:color .2s}
.bl-rss:hover{color:var(--red)}

/* ---- BLOG SHOW MORE ---- */
.bl-hidden{display:none}

/* ---- BLOG NEWSLETTER SIGNUP ---- */
.bp-newsletter{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);padding:32px;margin-top:48px}
.bp-newsletter-inner{display:grid;grid-template-columns:1fr 1fr;gap:32px;align-items:center}
@media(max-width:700px){.bp-newsletter-inner{grid-template-columns:1fr}}
.bp-newsletter h3{font-size:1.1rem;color:var(--pure);margin-bottom:8px}
.bp-newsletter p{font-size:.85rem;color:var(--gray2);line-height:1.65;margin-top:0}
.bp-nl-row{display:flex;gap:0}
.bp-nl-input{flex:1;padding:12px 16px;background:var(--dark);border:1px solid rgba(255,255,255,.12);border-right:none;color:var(--pure);font-size:.82rem;font-family:inherit;outline:none}
.bp-nl-input:focus{border-color:var(--red)}
.bp-nl-btn{padding:12px 20px;background:var(--red);color:var(--pure);border:none;font-size:.75rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;font-family:inherit;transition:background .2s;white-space:nowrap}
.bp-nl-btn:hover{background:#c22828}

/* ---- RELATED POSTS ---- */
.bp-related{background:var(--dark2);padding:64px 0}
.bp-related .bp-container{max-width:860px;margin:0 auto;padding:0 clamp(20px,5vw,80px)}
.bp-related-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:24px;margin-top:0}
.bp-related-card{background:var(--dark);border:1px solid rgba(255,255,255,.06);padding:24px;display:flex;flex-direction:column;gap:10px}
.bp-related-meta{font-size:.7rem;color:var(--gray2);letter-spacing:.06em}
.bp-related-card h3{font-size:.95rem;color:var(--pure);line-height:1.4}
.bp-related-card h3 a{color:inherit;text-decoration:none;transition:color .2s}
.bp-related-card h3 a:hover{color:var(--red)}
.bp-related-card p{font-size:.83rem;color:var(--gray2);line-height:1.6;flex:1}

/* ---- PROJECTS LIGHTBOX ---- */
.cx-proj-img-wrap{cursor:zoom-in;position:relative;overflow:hidden}
.cx-proj-img-wrap::after{content:'View';position:absolute;inset:0;background:rgba(0,0,0,0);color:transparent;display:flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;transition:background .2s,color .2s}
.cx-proj-img-wrap:hover::after{background:rgba(216,48,48,.5);color:#fff}
.cx-lightbox{position:fixed;inset:0;z-index:9000;background:rgba(0,0,0,.94);display:none;align-items:center;justify-content:center;padding:24px}
.cx-lightbox.open{display:flex}
.cx-lightbox img{max-width:100%;max-height:90vh;object-fit:contain;filter:grayscale(100%) contrast(1.05)}
.cx-lightbox-close{position:absolute;top:20px;right:24px;background:none;border:none;color:var(--pure);cursor:pointer;font-size:1.5rem;line-height:1;padding:8px;transition:color .2s}
.cx-lightbox-close:hover{color:var(--red)}
.cx-lightbox-caption{position:absolute;bottom:24px;left:50%;transform:translateX(-50%);color:var(--gray2);font-size:.78rem;letter-spacing:.08em;text-align:center;white-space:nowrap;max-width:90vw;overflow:hidden;text-overflow:ellipsis}

/* ---- FOCUS STYLES (keyboard navigation) ---- */
:focus{outline:none}
:focus-visible{outline:2px solid var(--red);outline-offset:3px}

/* ---- iOS FORM INPUT ZOOM FIX ---- */
/* iOS Safari zooms in when input font-size < 16px. Force 16px on mobile. */
@media(max-width:768px){
  .cx-form-group input,
  .cx-form-group select,
  .cx-form-group textarea,
  .bp-nl-input{font-size:1rem}
}

/* ---- FAQ TOUCH TARGET ---- */
/* The full .cx-faq-q row is the click target — enforce 44px min-height (WCAG 2.5.5) */
.cx-faq-q{min-height:44px}

/* ---- REDUCE MOTION RESPECT ---- */
@media(prefers-reduced-motion:reduce){
  .r,.r-left,.r-right,.r-scale{transition:none;opacity:1;transform:none}
  .cx-cursor,.cx-cursor-ring{display:none!important}
  #cx-progress{display:none}
  .cta::after{animation:none}
  .values-section .big-num{animation:none}
  .nav-links li{animation:none;opacity:1;transform:none}
  .cx-spotlight::before{display:none}
  .hero .dot{animation:none}
  .hero-right{animation:none}
}
