*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --sf:'Space Grotesk',sans-serif;
  --bf:'Inter',sans-serif;
  --bg:#0a1628;
  --purple:#8b5cf6;
  --blue:#00adff;
  --mint:#00d9c0;
  --white:#ffffff;
  --gray300:#d1d5db;
  --gray400:#9ca3af;
  --gray500:#6b7280;
  --accent:#a78bfa;
  /* HubSpot dark theme (Cross-Page Spec §8.1) */
  --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,0.1);
  --hsf-field-input__border-color:rgba(255,255,255,0.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,0.8);
  --hsf-button__color:#ffffff;
  --hsf-button__border-color:rgba(139,92,246,0.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;
}
body{
  font-family:var(--bf);
  font-size:1rem;
  line-height:1.5;
  color:var(--gray300);
  background:linear-gradient(135deg,#0a1628 0%,#0d1a2d 50%,#0a1628 100%);
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}

/* ============================================================
   TAILWIND UTILITY CLASSES (Cross-Page Spec §0.2, §0.3)
   ============================================================ */
.text-5xl{font-size:3rem;line-height:1}
.text-4xl{font-size:2.25rem;line-height:2.5rem}
.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}
.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}
.relative{position:relative}
.z-10{z-index:10}
.py-12{padding-top:3rem;padding-bottom:3rem}
.py-16{padding-top:4rem;padding-bottom:4rem}
.py-20{padding-top:5rem;padding-bottom:5rem}
/*.pt-32{padding-top:10rem}
.pb-24{padding-bottom:6rem}*/
.px-6{padding-left:1.5rem;padding-right:1.5rem}
.max-w-7xl{max-width:80rem}
.max-w-4xl{max-width:56rem}
.mx-auto{margin-left:auto;margin-right:auto}
.text-center{text-align:center}
.block{display:block}
.h-full{height:100%}
.inline-flex{display:inline-flex}
.items-center{align-items:center}
.gap-2{gap:.5rem}
.gap-8{gap:2rem}
.rounded-lg{border-radius:.5rem}
.rounded-xl{border-radius:.75rem}
.overflow-hidden{overflow:hidden}
.transition-all{transition:all .3s}
.transition-colors{transition-property:color,background-color,border-color;transition-duration:.3s}
.pb-24 {
    height: 100vh;
    align-items: center;
    display: flex;
    }
/* ============================================================
   GRADIENT TEXT (Cross-Page Spec §2)
   ============================================================ */
.grad-text{
  color:#8b5cf6;
  background:linear-gradient(90deg,#8b5cf6,#00adff,#00d9c0);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
}

/* ============================================================
   SKIP LINK (Cross-Page Spec §9)
   ============================================================ */
.skip-link{
  position:absolute;top:-40px;left:0;
  background:#8b5cf6;color:#fff;padding:8px 16px;
  z-index:100;border-radius:0 0 8px 0;transition:top .3s;
  font-family:var(--bf);font-size:.875rem;text-decoration:none;
}
.skip-link:focus{top:0}

/* ============================================================
   FOCUS STATES (Cross-Page Spec §9)
   ============================================================ */
a:focus-visible,button:focus-visible,input:focus-visible{
  outline:2px solid #8b5cf6;outline-offset:2px;border-radius:4px;
}
input::placeholder{color:#9ca3af}

/* ============================================================
   REDUCED MOTION (Cross-Page Spec §9)
   ============================================================ */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:.01ms!important;
    animation-iteration-count:1!important;
    transition-duration:.01ms!important;
  }
}

/* ============================================================
   VISUALLY HIDDEN (accessibility)
   ============================================================ */
.visually-hidden{
  position:absolute;width:1px;height:1px;padding:0;margin:-1px;
  overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;
}

/* ============================================================
   AMBIENT BACKGROUND GLOW
   ============================================================ */
.ambient-glow{
  position:fixed;inset:0;pointer-events:none;z-index:0;
}

/* ============================================================
   PRIMARY BUTTON (System of Record §5.1)
   ============================================================ */
.btn{
  position:relative;overflow:hidden;
  padding:12px 24px;
  font-family:var(--bf);font-size:14px;font-weight:500;
  border-radius:8px;
  display:inline-flex;align-items:center;gap:8px;
  text-decoration:none;cursor:pointer;border:none;
  transition:all .3s;
  color:#fff;
}
.btn-primary{
  background:rgba(139,92,246,.8);
  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,.btn-primary:focus-visible{
  transform:translateY(-2px);
  box-shadow:0 8px 32px rgba(139,92,246,.3);
}
.btn-primary .btn-fill{
  position:absolute;inset:0;
  background:linear-gradient(90deg,#8b5cf6,#00adff);
  transform:translateX(-100%);
  transition:transform .5s;
}
.btn-primary:hover .btn-fill,.btn-primary:focus-visible .btn-fill{
  transform:translateX(0);
}
.btn-primary .btn-text,.btn-primary .btn-arrow{
  position:relative;z-index:1;
}
.btn-primary .btn-arrow{transition:transform .3s}
.btn-primary:hover .btn-arrow,.btn-primary:focus-visible .btn-arrow{
  transform:translateX(4px);
}

/* ============================================================
   SECONDARY BUTTON (Cross-Page Spec §0.10)
   ============================================================ */
.btn-secondary{
  position:relative;
  padding:12px 24px;
  font-family:var(--bf);font-size:14px;font-weight:500;
  border-radius:8px;
  display:inline-flex;align-items:center;gap:8px;
  text-decoration:none;cursor:pointer;border:none;
  color:#fff;
  background:rgba(255,255,255,.05);
  backdrop-filter:blur(10px);
  overflow:visible;
  transition:all .3s;
}
.btn-secondary:hover,.btn-secondary:focus-visible{
  background:rgba(255,255,255,.1);
  transform:translateY(-2px);
  box-shadow:0 0 20px rgba(139,92,246,.3);
}
.btn-secondary .btn-border-static{
  position:absolute;inset:0;border-radius:8px;
  border:1px solid rgba(255,255,255,.2);
  transition:opacity .3s;pointer-events:none;
}
.btn-secondary:hover .btn-border-static,
.btn-secondary:focus-visible .btn-border-static{opacity:0}
.btn-secondary .border-svg{
  position:absolute;inset:0;width:100%;height:100%;
  overflow:visible;pointer-events:none;
}
.btn-secondary .border-svg rect{
  stroke-dasharray:1000;stroke-dashoffset:1000;
  transition:stroke-dashoffset .6s ease-out;
}
.btn-secondary:hover .border-svg rect,
.btn-secondary:focus-visible .border-svg rect{stroke-dashoffset:0}
.btn-secondary .btn-text,.btn-secondary .btn-arrow{
  position:relative;z-index:1;
}
.btn-secondary .btn-arrow{transition:transform .3s}
.btn-secondary:hover .btn-arrow,.btn-secondary:focus-visible .btn-arrow{
  transform:translateX(4px);
}

/* ============================================================
   GLASSMORPHIC CARD (System of Record §5.2)
   ============================================================ */
.glass{
  background:rgba(255,255,255,.05);
  backdrop-filter:blur(20px);
  border:1px solid rgba(255,255,255,.1);
  border-radius:16px;
  padding:24px;
  box-shadow:0 8px 32px rgba(0,0,0,.3);
  transition:all .5s cubic-bezier(.4,0,.2,1);
  overflow:hidden;
  position:relative;
}
.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);
  backdrop-filter:blur(24px) saturate(1.1);
  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}

/* ============================================================
   HERO GRID
   ============================================================ */
.hero-grid{
  display:grid;grid-template-columns:2fr 3fr;
  gap:3rem;align-items:center;
}
@media(min-width:1200px){.px-6{padding-left:2.5rem;padding-right:2.5rem}}
@media(max-width:768px){
  .hero-grid{grid-template-columns:1fr;gap:2.5rem}
}
@media(max-width:500px){
  #hero-heading{font-size:2.25rem!important}
}

/* ============================================================
   SECTION HEADER
   ============================================================ */
.section-header{margin-bottom:32px}
.section-header .accent-bar{
  height:3px;width:60px;
  background:linear-gradient(90deg,#8b5cf6,#00adff,#00d9c0);
  border-radius:2px;margin-bottom:16px;
}
.section-header h2{
  font-family:var(--sf);font-size:2rem;font-weight:700;
  color:#fff;margin-bottom:8px;
}
.section-header p{color:#d1d5db;font-size:1.1rem}

/* ============================================================
   RESOURCE CARDS — Light Glass (Feature Card Spec)
   + title underneath + hover overlay
   ============================================================ */
.resource-card{
  position:relative;text-decoration:none;display:flex;flex-direction:column;
  border-radius:.75rem;outline-offset:4px;
  flex-shrink:0;
}
.resource-card:focus-visible{outline:2px solid #8b5cf6}

/* Light Glass card frame (Feature Card Spec §3) */
.resource-card .card-inner{
  position:relative;overflow:hidden;
  border-radius:.75rem;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.08);
  padding:16px;
  display:flex;align-items:center;justify-content:center;
  transition:all .5s cubic-bezier(.4,0,.2,1);
  transform:translateY(0);
  aspect-ratio:3/4;
}
/* Hover → materialise (Feature Card Spec §3.2) */
.resource-card:hover .card-inner{
  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);
}
/* Inner glow layer (Feature Card Spec §3.3) */
.resource-card .card-inner::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;
}
.resource-card:hover .card-inner::before{opacity:1}

/* Cover image — contained inside padded frame */
.resource-card .card-cover{
  width:100%;height:100%;
  object-fit:contain;object-position:center;
  display:block;border-radius:6px;
  position:relative;z-index:1;
}
/* Glow behind dark cover images — strong, extends beyond edges */
.resource-card .card-inner::after{
  content:'';position:absolute;
  inset:-15%;z-index:0;
  background:radial-gradient(ellipse at 50% 50%,rgba(139,92,246,.35) 0%,rgba(0,173,255,.25) 30%,rgba(139,92,246,.12) 50%,transparent 70%);
  border-radius:50%;
  pointer-events:none;
  transition:all .5s;
}
.resource-card:hover .card-inner::after{
  inset:-20%;
  background:radial-gradient(ellipse at 50% 50%,rgba(139,92,246,.45) 0%,rgba(0,173,255,.3) 30%,rgba(139,92,246,.15) 50%,transparent 70%);
}

/* Icon fallback container */
.resource-card .card-icon-wrap{
  width:100%;height:100%;
  display:flex;align-items:center;justify-content:center;flex-direction:column;gap:6px;
  position:relative;z-index:1;
}

/* Title text UNDERNEATH the card frame */
.resource-card .card-title{
  font-family:var(--sf);font-size:13px;font-weight:600;
  color:rgba(255,255,255,.85);line-height:1.35;
  padding:10px 4px 0;
  transition:color .3s;
}
.resource-card:hover .card-title{color:#fff}

/* Hover — subtle image zoom */
.resource-card .card-cover{transition:transform .5s cubic-bezier(.4,0,.2,1)}
.resource-card:hover .card-cover{transform:scale(1.03)}

/* Bottom peek bar — slides up on hover */
.resource-card .card-peek{
  position:absolute;bottom:0;left:0;right:0;z-index:2;
  background:rgba(10,22,40,.92);
  backdrop-filter:blur(8px);
  border-top:1px solid rgba(139,92,246,.25);
  padding:10px 14px;
  display:flex;align-items:center;gap:8px;
  transform:translateY(100%);
  transition:transform .4s cubic-bezier(.4,0,.2,1);
  border-radius:0 0 calc(.75rem - 1px) calc(.75rem - 1px);
}
.resource-card:hover .card-peek{transform:translateY(0)}

/* Download CTA inside peek bar */
.resource-card .download-link{
  display:inline-flex;align-items:center;gap:8px;
  font-size:13px;font-weight:500;
  color:#fff;text-decoration:none;
  padding:0;border:none;background:none;
}
.resource-card .download-link .dl-icon{
  width:20px;height:20px;border-radius:50%;
  background:rgba(139,92,246,.3);
  border:1px solid rgba(139,92,246,.5);
  display:flex;align-items:center;justify-content:center;
  font-size:11px;flex-shrink:0;
  transition:all .3s;
}
.resource-card:hover .download-link .dl-icon{
  background:rgba(139,92,246,.5);
  border-color:rgba(139,92,246,.7);
  box-shadow:0 0 10px rgba(139,92,246,.25);
}


/* Case study card: centre logo on gradient bg */
.resource-card .card-logo-wrap{
  width:100%;height:100%;
  display:flex;align-items:center;justify-content:center;
  position:relative;z-index:1;
}
.resource-card .card-logo-wrap img{
  width:70%;max-width:160px;height:auto;
  object-fit:contain;filter:drop-shadow(0 0 20px rgba(139,92,246,.3));
}

/* ============================================================
   PICKS GRID — Light Glass + coloured outer glow
   ============================================================ */
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}
@media(max-width:1024px){.grid-4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.grid-4{grid-template-columns:1fr}}
.grid-4 .resource-card .card-inner{aspect-ratio:3/4}
/* Picks get a subtle coloured box-shadow at rest to feel special */
.grid-4 .resource-card .card-inner{
  box-shadow:0 4px 24px rgba(139,92,246,.12),0 0 40px rgba(139,92,246,.06);
}
.grid-4 .resource-card:hover .card-inner{
  box-shadow:0 8px 32px rgba(0,0,0,.35),0 0 30px rgba(139,92,246,.15);
}

/* ============================================================
   SCROLL ROW — edge fades + count badge in header
   ============================================================ */
.scroll-row-wrap{position:relative}

/* The scrollable track */
.scroll-row{
  display:flex;gap:1.25rem;
  overflow-x:auto;overflow-y:visible;
  scroll-snap-type:x mandatory;
  scroll-behavior:smooth;
  -webkit-overflow-scrolling:touch;
  padding:8px 0 16px;
  scrollbar-width:none;
  -ms-overflow-style:none;
}
.scroll-row::-webkit-scrollbar{display:none}
.scroll-row:focus-visible{outline:2px solid #8b5cf6;outline-offset:4px;border-radius:8px}

/* Fixed card width inside scroll rows */
.scroll-row .resource-card{
  width:220px;min-width:220px;
  scroll-snap-align:start;
}

/* Right edge fade — clear signal there's more */
.scroll-row-wrap::after{
  content:'';position:absolute;top:0;bottom:16px;right:0;width:80px;
  z-index:3;pointer-events:none;transition:opacity .3s;
  background:linear-gradient(to left,rgba(10,22,40,.85) 0%,rgba(10,22,40,.4) 50%,transparent 100%);
}
.scroll-row-wrap.at-end::after{opacity:0}

/* Section header with count — flex row so badge sits right-aligned */
.section-header-row{
  display:flex;align-items:flex-end;justify-content:space-between;
  gap:1rem;margin-bottom:32px;
}
.section-header-row .section-header{margin-bottom:0}

/* Count badge — sits in the header row */
.scroll-count{
  font-size:12px;font-family:var(--sf);letter-spacing:.02em;
  color:rgba(255,255,255,.85);
  white-space:nowrap;
  padding-bottom:4px;
  flex-shrink:0;
  display:flex;align-items:center;gap:6px;
}
.scroll-count .count-num{
  color:rgba(139,92,246,.8);font-weight:600;
}
.hero-chevron {
    position: absolute;
    bottom: 2.5rem;
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.5rem;
    color: var(--gray-400);
    text-decoration: none;
    padding: 0.5rem 1rem;
    min-height: 44px;
    transition: color 0.3s;
    animation: chevron-float 2.5s ease-in-out infinite;
    background: transparent;
    border: 0;
}
.hero-chevron:hover { color: #ffffff; }
.hero-chevron-text {
  font-family: var(--sf); font-size: 0.8125rem; font-weight: 500;
  letter-spacing: 0.05em;
}
@keyframes chevron-float {
  0%, 100% { transform: translateX(-50%) translateY(0); }
  50% { transform: translateX(-50%) translateY(6px); }
}
.scroll-chevron-wrap { animation: chevronBounce 2s ease-in-out infinite; }
.scroll-chevron-btn {
  display: flex; flex-direction: column; align-items: center; gap: 4px;
  margin: 0 auto; background: none; border: none; cursor: pointer;
  padding-bottom: 2rem; transition: opacity 0.3s;
}
/* Directional chevron — disappears once user scrolls */
.scroll-count .count-chevron{
  display:inline-flex;align-items:center;
  color:rgba(255,255,255,.25);
  font-size:14px;
  transition:opacity .4s,transform .4s;
  animation:nudge 2s ease-in-out infinite;
}
@keyframes nudge{
  0%,100%{transform:translateX(0)}
  50%{transform:translateX(3px)}
}
.scroll-count.scrolled .count-chevron{
  opacity:0;transform:translateX(6px);pointer-events:none;
}

@media(max-width:768px){
  .scroll-row .resource-card{width:200px;min-width:200px}
  .scroll-count{font-size:11px}
  .section-header-row{flex-wrap:wrap}
}

/* ============================================================
   CTA CARD — Light Glass variant
   ============================================================ */
.cta-glass{
  position:relative;overflow:hidden;
  border-radius:.75rem;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.08);
  padding:2.5rem;
  transition:all .5s cubic-bezier(.4,0,.2,1);
}
.cta-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;
}
.cta-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);
}
.cta-glass:hover::before{opacity:1}
.cta-flex{
  display:flex;flex-direction:row;align-items:center;gap:40px;width:100%;
}
@media(max-width:768px){
  .cta-flex{flex-direction:column;align-items:flex-start;gap:24px}
}

/* ============================================================
   NEWSLETTER SECTION (Cross-Page Spec §7)
   ============================================================ */
.newsletter-card-wrap{
  padding:2px;border-radius:18px;
  background:linear-gradient(135deg,rgba(139,92,246,.4),rgba(0,173,255,.25),rgba(0,217,192,.4));
  transition:all .5s cubic-bezier(.4,0,.2,1);
}
.newsletter-card-wrap:hover{
  transform:translateY(-2px);
  box-shadow:0 8px 32px rgba(0,0,0,.35),0 0 20px rgba(139,92,246,.08);
}
.newsletter-card-wrap .glass{
  background:linear-gradient(rgba(255,255,255,.05),rgba(255,255,255,.05)),#0a1628;
  border:none;border-radius:16px;transform:none!important;
}
.newsletter-card-wrap .glass:hover{transform:none!important}
.newsletter-card-wrap .glass::before{display:none}
.newsletter-grid{
  display:grid;grid-template-columns:2fr 3fr;
  gap:2.5rem;align-items:stretch;
}
@media(max-width:768px){
  .newsletter-grid{grid-template-columns:1fr;text-align:center}
  .newsletter-img{margin:0 auto 1rem}
  .newsletter-img img{max-width:160px!important}
}
.newsletter-img{margin-bottom:1.5rem}
.newsletter-img img{padding:0!important}

/* Envelope glow animation */
.newsletter-img img{
  filter:drop-shadow(0 0 20px rgba(139,92,246,.15)) drop-shadow(0 0 40px rgba(0,173,255,.1));
  animation:envelope-glow 3s ease-in-out infinite;
}
@keyframes envelope-glow{
  0%,100%{filter:drop-shadow(0 0 20px rgba(139,92,246,.15)) drop-shadow(0 0 40px rgba(0,173,255,.1))}
  50%{filter:drop-shadow(0 0 30px rgba(139,92,246,.25)) drop-shadow(0 0 50px rgba(0,173,255,.2))}
}

/* ============================================================
   IMAGE PLACEHOLDER (for missing assets)
   ============================================================ */
.img-placeholder{
  background:linear-gradient(135deg,rgba(139,92,246,.2) 0%,rgba(0,173,255,.2) 100%);
  border:2px dashed rgba(139,92,246,.4);border-radius:12px;
  display:flex;align-items:center;justify-content:center;flex-direction:column;gap:8px;
}
.img-placeholder span{
  color:rgba(139,92,246,.8);font-size:14px;font-family:var(--sf);
}