:root{
  --bg:#0f1720;
  --surface:#0f1b23;
  --muted:#9fb3c8;
  --accent:#00e5a8;
  --accent-2:#7b61ff;
  --accent-3:#ff6b8a;
  --glass: rgba(255,255,255,0.03);
  --radius:14px;
  color-scheme: dark;
}
*{box-sizing:border-box}
html,body{height:100%}
.body, body{
  margin:0;
  font-family:Inter,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
  background:linear-gradient(180deg,var(--bg),#061015 140%);
  color:#e6eef3;
  -webkit-font-smoothing:antialiased;
}
.container{max-width:1100px;margin:0 auto;padding:2rem}
.header-inner{display:flex;align-items:center;justify-content:space-between}
.brand{font-weight:700;color:var(--accent);text-decoration:none;font-size:1.125rem;display:inline-flex;align-items:center;gap:0.5rem}
.brand-icon{font-size:1.15rem;line-height:1;display:inline-block}
.nav{display:flex;gap:1rem;align-items:center}
.nav a{color:var(--muted);text-decoration:none;padding:0.35rem 0.5rem;border-radius:6px}
.nav a:hover{color:#fff;background:var(--glass)}
.nav-toggle{display:none;background:none;border:0;color:var(--muted);font-size:1.25rem}
.btn{display:inline-block;padding:0.6rem 1rem;border-radius:8px;text-decoration:none}
.btn-primary{background:linear-gradient(90deg,var(--accent),var(--accent-2));color:#061018}
.btn-ghost{border:1px solid rgba(255,255,255,0.04);color:var(--muted);background:transparent}
.hero{padding:5rem 0 4rem 0;position:relative;overflow:hidden}
.hero-inner{display:flex;gap:2rem;align-items:center}
.hero-copy{flex:1}
.hero-copy h1{margin:0 0 0.5rem;font-size:2.25rem}
.lead{color:var(--muted);margin:0 0 1rem}
.hero-visual{width:360px}
.visual-card{background:linear-gradient(180deg,rgba(123,97,255,0.06),rgba(0,229,168,0.02));padding:1.25rem;border-radius:14px;border:1px solid rgba(255,255,255,0.04)}
.hero:before{content:"";position:absolute;right:-40%;top:-30%;width:120%;height:240%;background:radial-gradient(circle at 20% 20%,rgba(123,97,255,0.12),transparent 30%),radial-gradient(circle at 80% 80%,rgba(0,229,168,0.10),transparent 30%);transform:rotate(25deg);filter:blur(30px);pointer-events:none}

/* bottom overlay to blend hero into divider so there is no abrupt seam */
.hero::after{
  content:"";
  position:absolute;
  left:0;right:0;bottom:0;
  height:0;
  background:none;
  pointer-events:none;
  z-index:1;
}
.section{padding:3.25rem 0}
.section--alt{background:transparent}
/* Keep content above subtle overlays */
.section{position:relative}
.container{position:relative;z-index:2}

/* subtle gradient overlay for alt sections that fades out so it doesn't create a solid band
   This sits behind content but above the page background, so the SVG divider remains the visual seam */
.section--alt::before{
  content:"";
  position:absolute;
  left:0;right:0;top:0;
  height:160px;
  background:linear-gradient(180deg, rgba(123,97,255,0.08) 0%, rgba(0,229,168,0.04) 40%, transparent 100%);
  pointer-events:none;
  z-index:1;
}
/* remove the overlay band specifically for the features section so the SVG divider is the visible seam */
.section.features.section--alt::before{height:0;background:none}
.section-title{margin:0 0 1rem}
.features-panel{padding:0;margin-bottom:0.75rem}
.features-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:2rem;align-items:stretch}
.feature{background:linear-gradient(180deg, rgba(255,255,255,0.01), rgba(255,255,255,0.005));padding:1.25rem;border-radius:12px;border:1px solid rgba(255,255,255,0.03);position:relative;overflow:visible;display:flex;align-items:flex-start;gap:1rem;min-height:120px;box-shadow:none;z-index:1;margin-bottom:0}
.feature:before{content:"";position:absolute;left:0;top:0;height:6px;width:100%;background:linear-gradient(90deg,var(--accent),var(--accent-2));transform:scaleX(0);transform-origin:left;transition:transform .35s}
.feature:hover:before{transform:scaleX(1)}
.feature-left{display:flex;align-items:center}
.feature-img{font-size:1.2rem;width:64px;height:64px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--accent-3),var(--accent-2));color:#031017;flex-shrink:0}
.feature-right{flex:1}
.feature-title{font-weight:700;color:#e8f6ff;font-size:1.02rem;margin-bottom:4px}
.feature-sub{font-size:0.85rem;color:var(--accent-2);margin-bottom:6px}
.feature p{margin:0;color:var(--muted);line-height:1.6}
.muted{color:var(--muted)}
.section.features{padding-bottom:3rem;background-color:var(--bg)}

/* Adjust spacing at smaller widths to prevent overlap visually */
@media (max-width:1200px){
  .section.features{padding-bottom:2.5rem}
}
@media (max-width:900px){
  .section.features{padding-bottom:2rem}
}
.features .muted{margin:0}
.steps{padding-left:1.25rem}
.site-footer{border-top:1px solid rgba(255,255,255,0.02);padding:1.5rem 0;margin-top:3rem}
.footer-inner{display:flex;justify-content:space-between;align-items:center}
.footer-nav a{color:var(--muted);text-decoration:none;margin-left:1rem}

/* Divider SVG */
.divider{width:100%;overflow:hidden;line-height:0;position:relative;z-index:0}
.divider svg{display:block;width:100%;height:110px}
.divider--flip svg{transform:scaleY(-1)}

/* How section */
.how-steps{display:flex !important;gap:1rem;margin-top:1.25rem;overflow-x:auto;padding-bottom:0.5rem;flex-wrap:nowrap !important;scroll-snap-type:x proximity;-webkit-overflow-scrolling:touch}
.how-steps .step{flex:0 0 260px;scroll-snap-align:start;min-width:0}

@media (min-width:1100px){
  .how-steps{overflow-x:visible;scroll-snap-type:none;display:grid !important;grid-template-columns:repeat(4,1fr);gap:2.5rem;justify-items:stretch}
  /* Make step sizing flexible under grid so each card fills its column */
  .how-steps .step{flex:0 0 auto;width:100%;min-width:0}
}

/* Widen how section container so steps can spread across more of the page */
.section.how .container{max-width:1400px;padding-left:3.5rem;padding-right:3.5rem}
.step{background:linear-gradient(180deg, rgba(255,255,255,0.01), rgba(255,255,255,0.005));padding:1rem;border-radius:12px;border:1px solid rgba(255,255,255,0.03);transition:transform .25s,box-shadow .25s}
.step-head{display:flex;align-items:flex-start;gap:0.75rem}
.step-icon{font-size:1.6rem;width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;color:#041017;background:linear-gradient(135deg, rgba(123,97,255,0.14), rgba(123,97,255,0.08) 40%, rgba(0,229,168,0.08) 100%);box-shadow:0 6px 18px rgba(2,8,12,0.35);align-self:flex-start}
.step h3{margin:0}
.step p{margin:0}
.step-toggle{margin-left:auto;background:none;border:0;color:var(--accent-2);cursor:pointer}
.step-details{margin-top:0.75rem;color:var(--muted);display:block;max-height:none;overflow:visible;transition:none;padding-top:0.5rem}
.step.open{transform:translateY(-6px);box-shadow:0 12px 30px rgba(16,24,40,0.6)}
.step.open .step-details{max-height:none}

/* subtle card hover */
.feature:hover{transform:translateY(-6px);box-shadow:none;outline:1px solid rgba(123,97,255,0.06);}

/* Responsive */
@media (max-width:1200px){
  .features-grid{grid-template-columns:repeat(3,1fr)}
  .how-steps{grid-auto-columns:minmax(200px,1fr)}
}
@media (max-width:900px){
  .features-grid{grid-template-columns:repeat(2,1fr)}
  .hero-inner{flex-direction:column;align-items:flex-start}
  .hero-visual{width:100%}
  .how-steps{grid-auto-columns:minmax(160px,1fr)}
}
@media (max-width:640px){
  .nav{display:none;position:absolute;top:64px;right:1rem;background:var(--surface);padding:1rem;border-radius:10px;box-shadow:0 6px 20px rgba(0,0,0,0.6)}
  .nav-toggle{display:block}
  .features-grid{grid-template-columns:1fr}
}


/* Responsive */
@media (max-width:900px){
  .features-grid{grid-template-columns:repeat(2,1fr)}
  .hero-inner{flex-direction:column;align-items:flex-start}
  .hero-visual{width:100%}
}
@media (max-width:640px){
  .nav{display:none;position:absolute;top:64px;right:1rem;background:var(--surface);padding:1rem;border-radius:10px;box-shadow:0 6px 20px rgba(0,0,0,0.6)}
  .nav-toggle{display:block}
  .features-grid{grid-template-columns:1fr}
}

/* Page-specific single gradient for privacy page */
/* Strong overrides to ensure the privacy page shows a single, uninterrupted gradient */
html.privacy-page, body.privacy-page{background:#0f1720 !important;min-height:100vh;background-image:none !important;background-repeat:repeat;background-attachment:initial}
/* Remove any overlay bands or section backgrounds on the privacy page */
.privacy-page .site-header, .privacy-page .site-footer, .privacy-page .section{background:transparent !important}
.privacy-page .container{background:none !important}
.privacy-page .section--alt::before{display:none !important;height:0 !important}
.privacy-page .hero::after{display:none !important;height:0 !important}
/* Disable decorative pseudo-elements that may create bands on this page */
.privacy-page *::before, .privacy-page *::after{background:none !important;background-image:none !important;display:none !important;height:0 !important}

/* Single solid background for terms page */
html.terms-page, body.terms-page{background:#0f1720 !important;min-height:100vh;background-image:none !important;background-repeat:repeat;background-attachment:initial}
/* Remove overlays and pseudo-elements that might create bands */
.terms-page .site-header, .terms-page .site-footer, .terms-page .section{background:transparent !important}
.terms-page .container{background:none !important}
.terms-page .section--alt::before{display:none !important;height:0 !important}
.terms-page .hero::after{display:none !important;height:0 !important}
.terms-page *::before, .terms-page *::after{background:none !important;background-image:none !important;display:none !important;height:0 !important}

/* Footer email icon styling */
.footer-nav a.contact-icon{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:6px;color:var(--muted);text-decoration:none}
.footer-nav a.contact-icon svg{width:20px;height:20px;stroke:var(--muted);fill:none;stroke-width:1.5;opacity:0.95}
.footer-nav a.contact-icon:hover svg{stroke:var(--accent-2);opacity:1}
