*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}

:root{
  /* Brand palette */
  --deep:#0a1628;
  --purple:#8b5cf6;
  --blue:#00adff;
  --mint:#00d9c0;
  --w:#ffffff;
  --g3:#d1d5db;
  --g4:#9ca3af;
  --g5:#6b7280;

  /* Typography */
  --fh:'Space Grotesk',sans-serif;
  --fb:'Inter',sans-serif;

  /* ── HubSpot form dark‑theme tokens (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;
}

html{scroll-behavior:smooth}

body{
  font-family:var(--fb);
  font-size:1rem;
  line-height:1.5;
  background:var(--deep);
  color:var(--g3);
  min-height:100vh;
  overflow-x:hidden;
}

/* ============================================================
   ACCESSIBILITY
   ============================================================ */
a:focus-visible,
button:focus-visible,
input:focus-visible,
textarea:focus-visible,
select:focus-visible{
  outline:2px solid var(--purple);
  outline-offset:2px;
  border-radius:4px;
}

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

/* Skip link */
.ge-skip{
  position:absolute;top:-100px;left:16px;z-index:999;
  padding:12px 24px;background:var(--purple);color:#fff;
  border-radius:0 0 8px 8px;font-weight:600;
  text-decoration:none;font-size:14px;transition:top .2s;
}
.ge-skip:focus{top:0}

/* Visually hidden */
.ge-sr-only{
  position:absolute;width:1px;height:1px;padding:0;margin:-1px;
  overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;
}

/* ============================================================
   NEURAL CANVAS BACKGROUND
   ============================================================ */
canvas#ge-neural{
  position:fixed;top:0;left:0;width:100%;height:100%;
  z-index:0;pointer-events:none;
}

/* Ambient radial glows */
.ge-amb{position:fixed;inset:0;z-index:0;pointer-events:none}
.ge-amb::before{
  content:'';position:absolute;width:100%;height:100%;
  background:radial-gradient(ellipse 80% 50% at 70% 20%,rgba(139,92,246,.06) 0%,transparent 50%);
}
.ge-amb::after{
  content:'';position:absolute;width:100%;height:100%;
  background:radial-gradient(ellipse 60% 40% at 30% 70%,rgba(139,92,246,.04) 0%,transparent 50%);
}

/* ============================================================
   GRADIENT TEXT UTILITY (Cross‑Page Spec §2)
   ============================================================ */
.ge-grad{
  color:#8b5cf6; /* solid fallback */
  background:linear-gradient(90deg,#8b5cf6,#00adff 50%,#00d9c0);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
}

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

/* ============================================================
   HERO
   ============================================================ */
.ge-hero{
  position:relative;z-index:1;
  padding:160px 24px 40px;
  text-align:center;max-width:800px;margin:0 auto;
}
.ge-hero h1{
  font-family:var(--fh);
  font-size:clamp(1.75rem,4vw,2.5rem);
  line-height:1.2;
  font-weight:700;color:#fff;
  margin-bottom:16px;
}
.ge-hero p{
  font-size:1.125rem;line-height:1.7;
  color:var(--g3);max-width:750px;margin:0 auto;
}

/* ============================================================
   TRUST LOGOS (orb‑style from Image List)
   ============================================================ */
.ge-trust-wrap{
  position:relative;z-index:1;
  max-width:800px;margin:0 auto 48px;
  text-align:center;
}
.ge-trust-label{
  font-family:var(--fb);
  font-size:0.75rem;line-height:1;
  font-weight:500;
  letter-spacing:0.08em;
  color:var(--g4);
  margin-bottom:12px;
}
.ge-trust{
  display:flex;align-items:center;justify-content:center;
  gap:24px;flex-wrap:wrap;
  padding:0 24px;
}
.ge-trust img{
  height:56px;width:56px;object-fit:contain;
  opacity:.55;transition:opacity .3s;
}
.ge-trust img:hover{opacity:.85}

/* ============================================================
   MEETING SECTION — Glass card
   ============================================================ */
.ge-msec{
  position:relative;z-index:1;
  padding:20px 24px 80px;max-width:960px;margin:0 auto;
}
.ge-mcard{
  background:rgba(255,255,255,.05);
  backdrop-filter:blur(20px);
  border:1px solid rgba(255,255,255,.1);
  border-radius:16px;
  box-shadow:0 8px 32px rgba(0,0,0,.3);
  overflow:hidden;
  transition:all .5s cubic-bezier(.4,0,.2,1);
  position:relative;
}
.ge-mcard:hover{
  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);
}
.ge-mcard::before{
  content:'';position:absolute;inset:0;border-radius:16px;
  background:radial-gradient(ellipse at 50% 0%,rgba(139,92,246,.08),transparent 60%);
  pointer-events:none;opacity:0;transition:opacity .5s;
}
.ge-mcard:hover::before{opacity:1}

.ge-minn{
  background:rgba(10,22,40,.6);
  border-radius:14px;
  padding:32px 24px;
  display:flex;flex-direction:column;
  align-items:center;
}
.ge-minn h2{
  font-family:var(--fh);
  font-size:1.5rem;line-height:1.3;
  font-weight:700;
  display:flex;align-items:center;justify-content:center;gap:10px;
  margin-bottom:24px;text-align:center;
  color:#8b5cf6;
  background:linear-gradient(90deg,#8b5cf6,#00adff 50%,#00d9c0);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
}
.ge-h2-icon{
  display:inline-block;
  width:1.5rem;height:1.5rem;flex-shrink:0;
  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;
}

/* HubSpot Meetings embed — iframe sizing */
.ge-minn .meetings-iframe-container{
  width:100%;min-height:660px;
  border-radius:12px;
}
/* Target the HubSpot-generated iframe */
.ge-minn .meetings-iframe-container iframe{
  width:100%!important;
  min-height:660px;
  border:none;
  border-radius:12px;
}

/* ============================================================
   "WHAT TO EXPECT" — Feature cards
   ============================================================ */
.ge-feats{
  position:relative;z-index:1;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;max-width:920px;margin:0 auto;
  padding:0 24px 80px;
}
.ge-feats-head{
  text-align:center;margin-bottom:32px;
  grid-column:1 / -1;
}
.ge-feats-head h2{
  font-family:var(--fh);
  font-size:1.5rem;line-height:1.3;
  font-weight:700;color:#fff;
}

/* ── Feature Card (Light Glass) — per ge-feature-card-spec ── */
.ge-feat{
  background:rgba(255,255,255,0.03);
  border:1px solid rgba(255,255,255,0.08);
  border-radius:0.75rem;
  padding:0; /* padding on inner content wrapper */
  text-align:center;
  transition:all .5s cubic-bezier(.4,0,.2,1);
  position:relative;
  overflow:hidden;
}
.ge-feat:hover{
  background:rgba(255,255,255,0.07);
  border-color:rgba(139,92,246,0.2);
  transform:translateY(-2px);
  box-shadow:0 8px 32px rgba(0,0,0,.35),0 0 20px rgba(139,92,246,.08);
}

/* Inner glow layer (§3.3) */
.ge-feat .ge-card-glow{
  position:absolute;inset:0;
  background:radial-gradient(ellipse at 50% 0%,rgba(139,92,246,0.08) 0%,transparent 60%);
  opacity:0;transition:opacity .5s;
  pointer-events:none;
}
.ge-feat:hover .ge-card-glow{opacity:1}

/* Content wrapper sits above glow */
.ge-feat-inner{
  position:relative;z-index:1;
  padding:1.75rem 1.5rem;
}

/* Icon containers — 3rem with 2rem icon (Cross‑Page Spec §3.2 feature card tier) */
.ge-feat-icon{
  width:3rem;height:3rem;
  margin:0 auto 0.75rem;
  border-radius:0.5rem;
  background:linear-gradient(135deg,rgba(139,92,246,.2),rgba(0,173,255,.2));
  display:flex;align-items:center;justify-content:center;
  transition:all .3s;
}
.ge-feat:hover .ge-feat-icon{
  background:linear-gradient(135deg,rgba(139,92,246,.3),rgba(0,173,255,.3));
  box-shadow:0 0 20px rgba(139,92,246,.15);
}

/* CSS mask gradient for SVG icons (Cross‑Page Spec §3.1) */
.ge-icon-mask{
  display:block;width:2rem;height:2rem;
  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;
}

.ge-feat h3{
  font-family:var(--fh);
  font-size:1.1rem;line-height:1.4;
  font-weight:700;color:#fff;margin:0 0 10px;
}
.ge-feat p{
  font-size:.9rem;line-height:1.7;color:var(--g3);
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(min-width:1200px){
  .ge-hero{padding-left:2.5rem;padding-right:2.5rem}
  .ge-trust{padding-left:2.5rem;padding-right:2.5rem}
  .ge-msec{padding-left:2.5rem;padding-right:2.5rem}
  .ge-feats{padding-left:2.5rem;padding-right:2.5rem}
}
@media(max-width:900px){
  .ge-feats{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:768px){
  .ge-hero{padding-top:80px}
  .ge-trust{gap:16px}
  .ge-trust img{height:44px;width:44px}
  .ge-minn{padding:24px 16px}
  .ge-minn .meetings-iframe-container{min-height:580px}
  .ge-minn .meetings-iframe-container iframe{min-height:580px}
}
@media(max-width:500px){
  .ge-feats{grid-template-columns:1fr}
}