
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Inter',sans-serif;font-size:1rem;line-height:1.5;color:#d1d5db;background:linear-gradient(135deg,#0a1628 0%,#0d1a2d 50%,#0a1628 100%);overflow-x:hidden;-webkit-font-smoothing:antialiased}

/* Tailwind utilities */
.hero-impact{min-height:100vh;display:flex;align-items:center;justify-content:center;padding-top:5rem;padding-bottom:5rem;position:relative;z-index:10}
.text-5xl{font-size:3rem;line-height:1}.text-4xl{font-size:2.25rem;line-height:2.5rem}.text-3xl{font-size:1.875rem;line-height:2.25rem}.text-2xl{font-size:1.5rem;line-height:2rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-base{font-size:1rem;line-height:1.5rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xs{font-size:.75rem;line-height:1rem}
.font-bold{font-weight:700}.font-semibold{font-weight:600}.font-medium{font-weight:500}
.text-white{color:#fff}.text-gray-300{color:#d1d5db}.text-gray-400{color:#9ca3af}
.text-center{text-align:center}
.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.mb-12{margin-bottom:3rem}.mb-16{margin-bottom:4rem}
.mt-2{margin-top:.5rem}.mt-8{margin-top:2rem}
.mr-2{margin-right:.5rem}
.p-4{padding:1rem}.p-5{padding:1.25rem}.p-6{padding:1.5rem}.p-8{padding:2rem}
.px-6{padding-left:1.5rem;padding-right:1.5rem}
.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-5{padding-top:1.25rem;padding-bottom:1.25rem}.py-20{padding-top:5rem;padding-bottom:5rem}
.pt-20{padding-top:5rem}.pb-12{padding-bottom:3rem}
.rounded-lg{border-radius:.5rem}.rounded-xl{border-radius:.75rem}.rounded-2xl{border-radius:1rem}.rounded-3xl{border-radius:1.5rem}.rounded-full{border-radius:9999px}
.inline-flex{display:inline-flex}.flex{display:flex}.hidden{display:none}
.items-center{align-items:center}.items-start{align-items:start}
.justify-between{justify-content:space-between}.justify-center{justify-content:center}
.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-8{gap:2rem}
.flex-wrap{flex-wrap:wrap}.flex-col{flex-direction:column}.flex-grow{flex-grow:1}.flex-shrink-0{flex-shrink:0}
.space-y-4>*+*{margin-top:1rem}
.w-full{width:100%}.w-8{width:2rem}.w-10{width:2.5rem}.h-8{height:2rem}.h-10{height:2.5rem}
.min-h-screen{min-height:100vh}
.relative{position:relative}.absolute{position:absolute}.fixed{position:fixed}
.inset-0{inset:0}.top-0{top:0}.left-0{left:0}.right-0{right:0}
.z-10{z-index:10}.z-50{z-index:50}
.pointer-events-none{pointer-events:none}
.overflow-hidden{overflow:hidden}
.transition-colors{transition:color .3s}.transition-transform{transition:transform .3s}
.leading-relaxed{line-height:1.625}
.uppercase{text-transform:uppercase}.tracking-wider{letter-spacing:.05em}

/* =============================================
   1. SKIP LINK (WCAG)
   ============================================= */
.skip-link{position:absolute;top:-100%;left:50%;transform:translateX(-50%);z-index:9999;background:#8b5cf6;color:#fff;padding:12px 24px;border-radius:0 0 8px 8px;font-weight:600;text-decoration:none}
.skip-link:focus{top:0}

/* =============================================
   2. FOCUS STATES (WCAG)
   ============================================= */
a:focus-visible,button:focus-visible{outline:2px solid #8b5cf6;outline-offset:2px;border-radius:4px}

/* =============================================
   3. REDUCED MOTION (WCAG)
   ============================================= */
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important}}

/* =============================================
   4. LAYOUT
   ============================================= */
.container{max-width:80rem;margin:0 auto;padding:0 1.5rem}
.container-sm{max-width:48rem;margin:0 auto;padding:0 1.5rem}
section{position:relative;z-index:10}

/* =============================================
   5. AMBIENT BACKGROUNDS
   ============================================= */
.ambient-glow-tr{position:fixed;inset:0;background:radial-gradient(ellipse 80% 50% at 70% 20%,rgba(139,92,246,.06) 0%,transparent 50%);pointer-events:none;z-index:0}
.ambient-glow-bl{position:fixed;inset:0;background:radial-gradient(ellipse 60% 40% at 30% 70%,rgba(139,92,246,.04) 0%,transparent 50%);pointer-events:none;z-index:0}

/* =============================================
   7. BUTTONS
   ============================================= */
.btn{position:relative;display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:.5rem;font-family:'Inter',sans-serif;font-size:.875rem;line-height:1.25rem;font-weight:500;text-decoration:none;transition:all .3s;cursor:pointer;border:none;overflow:hidden}
.btn .arrow{transition:transform .3s}
.btn:hover .arrow{transform:translateX(4px)}

/* Primary */
.btn-primary{background:rgba(139,92,246,.8);color:#fff;border:1px solid rgba(139,92,246,.5);backdrop-filter:blur(10px);box-shadow:0 4px 16px rgba(0,0,0,.2)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 32px rgba(139,92,246,.3)}
.btn-primary .liquid-fill{position:absolute;inset:0;background:linear-gradient(90deg,#8b5cf6,#00adff);transform:translateX(-100%);transition:transform .5s}
.btn-primary:hover .liquid-fill{transform:translateX(0)}
.btn-primary span{position:relative;z-index:1}

/* Secondary */
.btn-secondary{background:rgba(255,255,255,.05);color:#fff;backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2)}
.btn-secondary:hover{background:rgba(255,255,255,.1);transform:translateY(-2px);border-color:transparent;box-shadow:0 0 20px rgba(139,92,246,.3)}
.btn-secondary svg.border-svg{position:absolute;inset:0;width:100%;height:100%;pointer-events:none}
.btn-secondary svg.border-svg rect{fill:none;stroke-width:1.5;stroke-dasharray:1000;stroke-dashoffset:1000;transition:stroke-dashoffset .6s ease-out}
.btn-secondary:hover svg.border-svg rect{stroke-dashoffset:0}
.btn-secondary:hover>.static-border{opacity:0}
.btn-secondary .static-border{position:absolute;inset:0;border-radius:.5rem;border:1px solid rgba(255,255,255,.2);transition:opacity .3s}

/* =============================================
   8. GLASSMORPHIC CARDS
   ============================================= */
.glass{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.08);border-radius:.75rem;padding:1.75rem 1.5rem;transition:all .5s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}
.glass::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 50% 0%,rgba(139,92,246,.08) 0%,transparent 60%);opacity:0;transition:opacity .5s;pointer-events:none}
.glass:hover{background:rgba(255,255,255,.07);border-color:rgba(139,92,246,.2);box-shadow:0 8px 32px rgba(0,0,0,.35),0 0 20px rgba(139,92,246,.08);transform:translateY(-2px)}
.glass:hover::before{opacity:1}
.glass img{padding:1rem 0}

/* =============================================
   9. GRADIENT TEXT
   ============================================= */
.gradient-text{color:#8b5cf6;background:linear-gradient(90deg,#8b5cf6 0%,#00adff 50%,#00d9c0 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.gradient-text-purple{color:#8b5cf6;background:linear-gradient(90deg,#8b5cf6,#00adff,#00d9c0);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}

/* =============================================
   10. ICON MASK (Cross-page spec §3)
   ============================================= */
.icon-mask{display:inline-block;width:2.5rem;height:2.5rem;background:linear-gradient(135deg,#8b5cf6,#00adff,#00d9c0);-webkit-mask-size:contain;-webkit-mask-repeat:no-repeat;-webkit-mask-position:center;mask-size:contain;mask-repeat:no-repeat;mask-position:center}
.icon-mask-sm{width:2rem;height:2rem}

/* =============================================
   11. PRODUCT CARDS
   ============================================= */
.product-card{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.08);border-radius:.75rem;padding:1.75rem 1.5rem;transition:all .5s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;display:flex;flex-direction:column;height:100%}
.product-card::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 50% 0%,rgba(139,92,246,.1) 0%,transparent 60%);opacity:0;transition:opacity .5s;pointer-events:none}
.product-card:hover{background:rgba(255,255,255,.07);box-shadow:0 8px 32px rgba(0,0,0,.35),0 0 20px rgba(var(--glow),.1);transform:translateY(-2px)}
.product-card:hover::before{opacity:1}
.product-card[data-color="blue"]{--glow:0,173,255}.product-card[data-color="blue"]:hover{border-color:rgba(0,173,255,.25)}
.product-card[data-color="mint"]{--glow:0,217,192}.product-card[data-color="mint"]:hover{border-color:rgba(0,217,192,.25)}
.product-card[data-color="purple"]{--glow:139,92,246}.product-card[data-color="purple"]:hover{border-color:rgba(139,92,246,.25)}
.product-card[data-color="gradient"]{--glow:139,92,246}.product-card[data-color="gradient"]:hover{border-color:rgba(139,92,246,.25)}
.product-card .learn-more{font-size:.875rem;line-height:1.25rem;font-weight:500;display:inline-flex;align-items:center;text-decoration:none;position:relative}
.product-card .learn-more .underline-anim{position:absolute;bottom:0;left:0;width:100%;height:1px;transform:scaleX(0);transform-origin:left;transition:transform .3s}
.product-card:hover .learn-more .underline-anim{transform:scaleX(1)}
.product-card .learn-more .lm-arrow{margin-left:4px;transition:transform .3s}
.product-card:hover .learn-more .lm-arrow{transform:translateX(4px)}

/* =============================================
   12. FEATURE CARDS
   ============================================= */
.feature-card{padding:1.75rem 1.5rem;border-radius:.75rem;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.08);transition:all .5s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}
.feature-card::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 50% 0%,rgba(139,92,246,.08) 0%,transparent 60%);opacity:0;transition:opacity .5s;pointer-events:none}
.feature-card:hover{background:rgba(255,255,255,.07);border-color:rgba(139,92,246,.2);box-shadow:0 8px 32px rgba(0,0,0,.35),0 0 20px rgba(139,92,246,.08);transform:translateY(-2px)}
.feature-card:hover::before{opacity:1}
.feature-icon{width:3rem;height:3rem;border-radius:.5rem;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,rgba(139,92,246,.2),rgba(0,173,255,.2));margin-bottom:.75rem}

/* =============================================
   13. STAT COUNTERS
   ============================================= */
.stat-number{font-family:'Space Grotesk',sans-serif;font-size:3rem;line-height:1;font-weight:700;background:linear-gradient(135deg,#8b5cf6 0%,#8b5cf6 30%,#00adff 60%,#00d9c0 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;filter:drop-shadow(0 0 12px rgba(139,92,246,.6)) drop-shadow(0 0 24px rgba(139,92,246,.4))}

@media(min-width:769px){.stat-number{font-size:3rem}}

/* =============================================
   14. FAQ
   ============================================= */
.faq-item{border-bottom:1px solid rgba(255,255,255,.1)}
.faq-btn{width:100%;padding:1.25rem 0;display:flex;align-items:center;justify-content:space-between;text-align:left;background:transparent;border:none;color:inherit;cursor:pointer;font-family:'Space Grotesk',sans-serif}
.faq-btn .faq-q{color:#fff;font-weight:600;padding-right:1rem;font-size:1rem;line-height:1.5rem}
.faq-btn .faq-icon{color:#8b5cf6;font-size:1.5rem;transition:transform .3s;flex-shrink:0}
.faq-item.open .faq-icon{transform:rotate(45deg)}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .4s ease}
.faq-item.open .faq-answer{max-height:500px}
.faq-answer p{color:#d1d5db;padding-bottom:1.25rem;font-size:.875rem;line-height:1.625}

/* =============================================
   15. PRODUCT SUITE BORDER
   ============================================= */
.suite-container{position:relative;border-radius:1.5rem;padding:1.5rem;background:rgba(10,22,40,.95);backdrop-filter:blur(20px)}
.suite-container svg.suite-border{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;overflow:visible;border-radius:1.5rem}
@keyframes travelBorder{0%{left:0%;top:0}25%{left:100%;top:0}50%{left:100%;top:100%}75%{left:0%;top:100%}100%{left:0%;top:0}}
.suite-orb{position:absolute;width:6px;height:6px;border-radius:50%;background:linear-gradient(135deg,#8b5cf6,#00adff,#00d9c0);box-shadow:0 0 8px rgba(139,92,246,.8),0 0 16px rgba(0,173,255,.5);animation:travelBorder 16s linear infinite;transform:translate(-50%,-50%);z-index:10;pointer-events:none}

/* =============================================
   16. CASE STUDY FRAME
   ============================================= */
.case-study-frame{position:relative;border-radius:1rem;padding:2rem;background:rgba(13,26,45,.8);backdrop-filter:blur(20px)}
.case-study-border{position:absolute;inset:0;border-radius:1rem;padding:1px;background:linear-gradient(135deg,#8b5cf6 0%,#00adff 50%,#00d9c0 100%);opacity:.6;pointer-events:none}
.case-study-border-inner{width:100%;height:100%;border-radius:calc(1rem - 1px);background:rgba(13,26,45,.95)}

/* =============================================
   17. GRIDS
   ============================================= */
.grid-4{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.grid-3-gap{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}
.grid-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}

@media(max-width:900px){.grid-3,.grid-3-gap{grid-template-columns:repeat(2,1fr)!important}}
@media(max-width:768px){
    .scroll-chevron{bottom:0rem;}
    .hero-impact{min-height:80vh;padding-top:1rem;padding-bottom:1rem;}
    .py-20 {
    padding-top: 1rem;
    padding-bottom: 1rem;
}.grid-2{grid-template-columns:1fr!important}.grid-stats{grid-template-columns:repeat(2,1fr)!important}.case-study-inner{grid-template-columns:1fr!important}}
@media(max-width:500px){.grid-3,.grid-3-gap,.grid-stats{grid-template-columns:1fr!important}}

@media(min-width:769px){.md-flex{display:flex}}

/* =============================================
   18. HERO — STACKED CENTRED LAYOUT (hero-section-spec)
   ============================================= */
.hero-stacked{display:flex;flex-direction:column;align-items:center;text-align:center;transform:translateY(-0.5rem)}
.hero-h1{white-space:nowrap}
.hero-bottom{max-width:42rem;margin-left:auto;margin-right:auto}
.hero-img-full{max-width:50rem;margin:0 auto;overflow:visible;padding-top:20px;padding-bottom:40px;position:relative}
.hero-img-full::before{content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:90%;height:80%;border-radius:50%;background:radial-gradient(ellipse at center,rgba(139,92,246,.45) 0%,rgba(139,92,246,.25) 25%,rgba(0,173,255,.12) 50%,rgba(0,217,192,.04) 70%,transparent 85%);filter:blur(60px);z-index:0;pointer-events:none}
.hero-img-full img{width:100%;object-fit:contain;position:relative;z-index:1}

/* =============================================
   18a. HERO PARTICLES (particle-spec — copy verbatim)
   ============================================= */
.hero-particle{position:absolute;border-radius:50%;pointer-events:none;z-index:2}
.hero-particle-1{width:5px;height:5px;background:#8b5cf6;box-shadow:0 0 10px rgba(139,92,246,.8),0 0 20px rgba(139,92,246,.4);top:20%;left:5%;animation:heroOrbit1 20s linear infinite}
.hero-particle-2{width:4px;height:4px;background:#00adff;box-shadow:0 0 8px rgba(0,173,255,.8),0 0 16px rgba(0,173,255,.4);bottom:25%;right:4%;animation:heroOrbit2 25s linear infinite}
.hero-particle-3{width:3px;height:3px;background:#00d9c0;box-shadow:0 0 6px rgba(0,217,192,.7),0 0 14px rgba(0,217,192,.3);top:55%;left:3%;animation:heroOrbit3 30s linear infinite}
.hero-particle-4{width:4px;height:4px;background:#8b5cf6;box-shadow:0 0 8px rgba(139,92,246,.7),0 0 16px rgba(139,92,246,.3);top:15%;right:8%;animation:heroOrbit4 22s linear infinite}
.hero-particle-5{width:3px;height:3px;background:#00adff;box-shadow:0 0 6px rgba(0,173,255,.7),0 0 12px rgba(0,173,255,.3);bottom:18%;left:8%;animation:heroOrbit5 28s linear infinite}

@keyframes heroOrbit1{0%{transform:translate(0,0)}25%{transform:translate(680px,30px)}50%{transform:translate(700px,180px)}75%{transform:translate(40px,160px)}100%{transform:translate(0,0)}}
@keyframes heroOrbit2{0%{transform:translate(0,0)}25%{transform:translate(-620px,-20px)}50%{transform:translate(-660px,-150px)}75%{transform:translate(-30px,-140px)}100%{transform:translate(0,0)}}
@keyframes heroOrbit3{0%{transform:translate(0,0)}25%{transform:translate(340px,-100px)}50%{transform:translate(700px,-40px)}75%{transform:translate(360px,80px)}100%{transform:translate(0,0)}}
@keyframes heroOrbit4{0%{transform:translate(0,0)}25%{transform:translate(-300px,100px)}50%{transform:translate(-580px,60px)}75%{transform:translate(-280px,-40px)}100%{transform:translate(0,0)}}
@keyframes heroOrbit5{0%{transform:translate(0,0)}25%{transform:translate(400px,-60px)}50%{transform:translate(580px,80px)}75%{transform:translate(200px,120px)}100%{transform:translate(0,0)}}

/* =============================================
   18b. SCROLL CHEVRON (hero-section-spec §10)
   ============================================= */
.scroll-chevron{position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:6px;text-decoration:none;color:rgba(255,255,255,.5);transition:opacity .4s}
.scroll-chevron-text{font-family:'Inter',sans-serif;font-size:.75rem;line-height:1rem;color:rgba(255,255,255,.85);letter-spacing:.1em}
.scroll-chevron:hover{color:rgba(255,255,255,.8)}
.scroll-chevron svg{animation:chevronBob 2s ease-in-out infinite}
.scroll-chevron.hidden{opacity:0;pointer-events:none}
@keyframes chevronBob{0%,100%{transform:translateY(0)}50%{transform:translateY(6px)}}

/* =============================================
   18c. HERO RESPONSIVE (hero-section-spec §11)
   ============================================= */
@media(max-width:480px){.hero-h1{font-size:2.25rem;line-height:2.5rem;white-space:normal}}


/* =============================================
   20. HUBSPOT FORM DARK THEME (Cross-page spec §8)
   ============================================= */
:root{
--hsf-global__font-family:'Inter',sans-serif;--hsf-global__font-size:14px;--hsf-global__color:#d1d5db;--hsf-global-error__color:#f87171;
--hsf-background__background-color:transparent;--hsf-background__border-color:transparent;--hsf-background__border-radius:0px;--hsf-background__padding:0px;
--hsf-field-input__background-color:rgba(255,255,255,.1);--hsf-field-input__border-color:rgba(255,255,255,.2);--hsf-field-input__border-radius:8px;--hsf-field-input__color:#ffffff;--hsf-field-input__font-size:16px;--hsf-field-input__placeholder-color:#9ca3af;
--hsf-field-label__color:#d1d5db;--hsf-field-label__font-size:14px;
--hsf-button__background-color:rgba(139,92,246,.8);--hsf-button__color:#ffffff;--hsf-button__border-color:rgba(139,92,246,.5);--hsf-button__border-radius:8px;--hsf-button__font-family:'Inter',sans-serif;--hsf-button__font-size:14px;--hsf-button__font-weight:500;
--hsf-button--hover__background-color:#8b5cf6;--hsf-button--hover__color:#ffffff;--hsf-button--hover__border-color:#8b5cf6;
--hsf-legal-consent__color:#9ca3af;--hsf-legal-consent__font-size:12px;--hsf-rich-text__color:#9ca3af;--hsf-rich-text__font-size:12px;
--hsf-row__vertical-spacing:16px;--hsf-module__vertical-spacing:12px;
}

/* =============================================
   21. NEURAL BACKGROUND CANVAS
   ============================================= */
#neuralCanvas{position:fixed;inset:0;pointer-events:none;z-index:0}

/* =============================================
   22. ACCENT TEXT (Cross-page spec §1)
   ============================================= */
.accent-text{color:#a78bfa}

/* =============================================
   23. NEWSLETTER SECTION (Cross-page spec §7)
   ============================================= */
/* Newsletter section CSS — kept for cross-page reuse if needed
.newsletter-card{padding:2.5rem 2rem}
.newsletter-grid{display:grid;grid-template-columns:200px 1fr;gap:2rem;align-items:start}
.newsletter-img img{padding:0!important}
@media(max-width:768px){.newsletter-grid{grid-template-columns:1fr!important;text-align:center}.newsletter-img{display:flex;justify-content:center}.newsletter-img img{max-width:160px}}
*/