/* =========================
   Home page specific styles
   ========================= */

.site-header{
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(246,248,252,.78);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--border);
  transition: box-shadow .2s var(--ease), background .2s var(--ease);
}
.site-header.is-scrolled{
  background: rgba(255,255,255,.92);
  box-shadow: 0 10px 30px rgba(2,6,23,.10);
}
.nav-wrap{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding: 14px 0;
  gap: 16px;
}
.brand{
  display:flex;
  align-items:center;
  gap: 12px;
  min-width: 220px;
}
.brand-logo{
  width: 44px;
  height: 44px;
  object-fit: contain;
}
.brand-text{ display:flex; flex-direction:column; line-height:1.1; }
.brand-name{ font-weight: 950; font-size: 14px; letter-spacing: .01em; }
.brand-tag{ font-size: 12px; color: rgba(13,18,32,.62); }

.nav{
  display:flex;
  gap: 18px;
  align-items:center;
}
.nav-link{
  font-weight: 800;
  font-size: 14px;
  color: rgba(13,18,32,.78);
  position:relative;
}
.nav-link:hover{ color: rgba(30,78,216,.95); }
.nav-link.active::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:-10px;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--blue2), var(--purple), var(--gold));
}

.nav-actions{
  display:flex;
  gap: 10px;
  align-items:center;
}

/* Mobile menu */
.nav-toggle{
  display:none;
  width: 44px;
  height: 44px;
  border-radius: 14px;
  border: 1px solid var(--border);
  background: var(--white);
  align-items:center;
  justify-content:center;
  gap:4px;
}
.nav-toggle span{
  width: 18px;
  height: 2px;
  background: rgba(13,18,32,.78);
  border-radius: 999px;
  display:block;
}

.mobile-nav{
  display:none;
  border-top: 1px solid var(--border);
  background: rgba(255,255,255,.96);
}
.mobile-link{
  display:block;
  padding: 14px 16px;
  font-weight: 900;
  color: rgba(13,18,32,.82);
  border-bottom: 1px solid rgba(15,23,42,.06);
}
.mobile-ctas{
  display:flex;
  gap: 10px;
  padding: 14px 16px 18px;
}
@media (max-width: 980px){
  .nav{ display:none; }
  .nav-toggle{ display:inline-flex; }
  .mobile-nav.is-open{ display:block; }
}

/* Hero */
.hero{
  position: relative;
  padding: 72px 0 52px;
  overflow:hidden;
}
.hero-grid{
  display:grid;
  grid-template-columns: 1.15fr .85fr;
  gap: 34px;
  align-items:center;
}
.hero h1{
  margin: 10px 0 10px;
  font-size: clamp(30px, 4vw, 52px);
  line-height: 1.05;
  letter-spacing: -0.02em;
}
.lead{
  margin: 0;
  font-size: 16px;
  color: rgba(13,18,32,.78);
  max-width: 620px;
}
.hero-ctas{
  margin-top: 18px;
  display:flex;
  gap: 12px;
  flex-wrap:wrap;
}

/* Stats */
.hero-stats{
  margin-top: 20px;
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}
.stat{
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 14px;
  box-shadow: 0 18px 45px rgba(2,6,23,.06);
}
.stat-num{
  font-size: 24px;
  font-weight: 950;
  letter-spacing: -0.01em;
  background: linear-gradient(135deg, var(--blue2), var(--purple), var(--gold));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.stat-label{
  font-size: 12px;
  font-weight: 800;
  color: rgba(13,18,32,.65);
}

/* Hero media */
.hero-media .media-card{
  background: linear-gradient(135deg, rgba(30,78,216,.08), rgba(109,40,217,.06));
  border: 1px solid rgba(30,78,216,.14);
  border-radius: 22px;
  padding: 12px;
  box-shadow: var(--shadow);
  position: relative;
}
.hero-media img{
  border-radius: 18px;
  aspect-ratio: 4 / 3;
  object-fit: cover;
}
.media-badge{
  position:absolute;
  left: 18px;
  bottom: 18px;
  padding: 10px 12px;
  background: rgba(10,16,32,.78);
  color: rgba(255,255,255,.9);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 999px;
  font-weight: 800;
  font-size: 12px;
  backdrop-filter: blur(10px);
}

/* Background accent */
.hero-bg-accent{
  position:absolute;
  inset: -220px -200px auto auto;
  width: 520px;
  height: 520px;
  background: radial-gradient(circle at 30% 30%, rgba(30,78,216,.26), transparent 60%),
              radial-gradient(circle at 60% 60%, rgba(109,40,217,.22), transparent 62%),
              radial-gradient(circle at 40% 70%, rgba(212,175,55,.16), transparent 58%);
  filter: blur(10px);
  transform: rotate(18deg);
  pointer-events:none;
}

@media (max-width: 980px){
  .hero-grid{ grid-template-columns: 1fr; }
  .hero{ padding: 54px 0 42px; }
  .hero-stats{ grid-template-columns: 1fr; }
}

/* Trust */
.trust{
  padding: 22px 0 6px;
}
.trust-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 16px;
  flex-wrap: wrap;
}
.trust-title{
  margin:0;
  font-weight: 900;
  color: rgba(13,18,32,.78);
}
.trust-chips{
  display:flex;
  gap: 10px;
  flex-wrap:wrap;
}

/* Cards grid */
.cards-grid{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
}
@media (max-width: 1100px){
  .cards-grid{ grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 620px){
  .cards-grid{ grid-template-columns: 1fr; }
}

.section-cta{
  margin-top: 18px;
  display:flex;
  justify-content:center;
}

/* Feature panel */
.feature-panel{
  background: linear-gradient(135deg, rgba(255,255,255,.92), rgba(30,78,216,.05));
  border: 1px solid rgba(30,78,216,.14);
  border-radius: 22px;
  padding: 18px;
  box-shadow: var(--shadow);
}
.feature-panel h3{
  margin: 0 0 10px;
  font-size: 16px;
}
.steps{
  margin: 0;
  padding-left: 18px;
  display:grid;
  gap: 10px;
  color: rgba(13,18,32,.78);
}
.panel-note{
  margin-top: 14px;
  padding: 12px;
  border-radius: 16px;
  background: rgba(212,175,55,.12);
  border: 1px solid rgba(212,175,55,.20);
  font-weight: 800;
  color: rgba(13,18,32,.82);
}

/* Quotes */
.quote-grid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}
.quote-card{
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 22px;
  padding: 18px;
  box-shadow: 0 20px 60px rgba(2,6,23,.07);
}
.quote-card p{
  margin:0 0 12px;
  font-weight: 800;
  color: rgba(13,18,32,.82);
}
.quote-meta{
  font-weight: 900;
  font-size: 12px;
  color: rgba(13,18,32,.60);
}
@media (max-width: 980px){
  .quote-grid{ grid-template-columns: 1fr; }
}

/* CTA band */
.cta-band{
  padding: 68px 0;
  background: linear-gradient(135deg, rgba(30,78,216,.10), rgba(109,40,217,.08), rgba(212,175,55,.07));
  border-top: 1px solid var(--border);
}
.cta-inner{
  background: rgba(255,255,255,.92);
  border: 1px solid rgba(30,78,216,.14);
  border-radius: 26px;
  padding: 22px;
  box-shadow: var(--shadow);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 16px;
  flex-wrap:wrap;
}
.cta-inner h2{
  margin:0 0 6px;
  font-size: 22px;
}
.cta-inner p{ margin:0; color: rgba(13,18,32,.75); }
.cta-actions{ display:flex; gap: 10px; flex-wrap:wrap; }

/* Floating buttons */
.float-actions{
  position: fixed;
  right: 16px;
  bottom: 16px;
  display:flex;
  flex-direction:column;
  gap: 10px;
  z-index: 60;
}
.float-btn{
  width: 50px;
  height: 50px;
  border-radius: 18px;
  display:grid;
  place-items:center;
  background: linear-gradient(135deg, var(--blue2), var(--purple));
  color: white;
  border: 1px solid rgba(255,255,255,.18);
  box-shadow: 0 16px 40px rgba(2,6,23,.20);
  transition: transform .18s var(--ease);
}
.float-btn:hover{ transform: translateY(-2px); }
