/* ========== HERO ========== */
.hero {
  position: relative;
  background: linear-gradient(135deg, var(--color-navy) 0%, var(--color-navy-light) 50%, #1e3a6e 100%);
  overflow: hidden;
  padding: var(--space-24) 0 var(--space-32);
}
.hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse at 70% 50%, rgba(45,108,186,0.25) 0%, transparent 60%),
    radial-gradient(ellipse at 20% 80%, rgba(201,168,76,0.08) 0%, transparent 50%);
}
.hero-grid {
  position: relative;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-16);
  align-items: center;
}
.hero-content { color: var(--color-white); }

.hero-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  background: rgba(201,168,76,0.15);
  border: 1px solid rgba(201,168,76,0.3);
  color: var(--color-gold-light);
  font-size: var(--font-size-sm);
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: var(--space-2) var(--space-4);
  border-radius: var(--radius-full);
  margin-bottom: var(--space-6);
}
.hero h1 { color: var(--color-white); margin-bottom: var(--space-6); }
.hero h1 span { color: var(--color-gold-light); }
.hero-subtitle {
  font-size: clamp(1rem, 2vw, var(--font-size-lg));
  color: rgba(255,255,255,0.8);
  line-height: var(--line-height-loose);
  margin-bottom: var(--space-8);
  max-width: 500px;
}
.hero-ctas { display: flex; gap: var(--space-4); flex-wrap: wrap; margin-bottom: var(--space-10); }

.hero-trust {
  display: flex;
  align-items: center;
  gap: var(--space-6);
  flex-wrap: wrap;
}
.trust-item {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--font-size-sm);
  color: rgba(255,255,255,0.7);
  font-weight: 600;
}
.trust-item svg { color: var(--color-gold); width: 18px; height: 18px; }

/* Hero visual */
.hero-visual { position: relative; display: flex; justify-content: center; }
.hero-profiles-stack {
  position: relative;
  width: 100%;
  max-width: 480px;
}
.profile-bubble {
  background: var(--color-white);
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: var(--shadow-xl);
}
.profile-bubble-main {
  width: 100%; aspect-ratio: 3/4;
  background: linear-gradient(160deg, #c8d4e0 0%, #8a9bb0 100%);
  display: flex; align-items: center; justify-content: center;
  position: relative;
  padding: var(--space-3);
}
.hero-profile-photo {
  width: min(380px, 94%);
  aspect-ratio: 5/6;
  object-fit: cover;
  border-radius: 999px;
  box-shadow: 0 18px 50px rgba(0,0,0,0.25);
  border: 5px solid rgba(255,255,255,0.88);
  transform: translateY(-4px);
}
.profile-bubble-info { padding: var(--space-4) var(--space-5); }
.profile-bubble-name { font-weight: 700; font-size: var(--font-size-lg); color: var(--color-navy); }
.profile-bubble-sub  { font-size: var(--font-size-sm); color: var(--color-text-muted); }

.floating-badge {
  position: absolute;
  background: var(--color-white);
  border-radius: var(--radius-lg);
  padding: var(--space-3) var(--space-4);
  box-shadow: var(--shadow-lg);
  display: flex;
  align-items: center;
  gap: var(--space-3);
  font-size: var(--font-size-sm);
  font-weight: 700;
  color: var(--color-navy);
  animation: float 3s ease-in-out infinite;
  white-space: nowrap;
}
.floating-badge.top-right { top: -20px; right: -20px; animation-delay: 0.5s; }
.floating-badge.bottom-left { bottom: 40px; left: -30px; animation-delay: 1s; }
.floating-badge .badge-dot { width: 10px; height: 10px; border-radius: 50%; background: var(--color-success); flex-shrink: 0; }
@keyframes float {
  0%, 100% { transform: translateY(0); }
  50%       { transform: translateY(-8px); }
}

/* ========== STATS ========== */
.stats-section {
  background: var(--color-navy);
  padding: var(--space-16) 0;
}
.stats-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: rgba(255,255,255,0.1); }
.stat-item {
  text-align: center;
  padding: var(--space-8);
  background: var(--color-navy);
}
.stat-item .stat-number {
  color: var(--color-gold-light);
  font-size: clamp(2.2rem, 4vw, 3.2rem);
  white-space: nowrap;
}
.stat-item .stat-label  { color: rgba(255,255,255,0.6); }

/* ========== HOW IT WORKS ========== */
.how-it-works { background: var(--color-silver-pale); }
.steps-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-8); position: relative; }
.steps-grid::after {
  content: '';
  position: absolute;
  top: 40px; left: 16.6%; right: 16.6%;
  height: 2px;
  background: linear-gradient(90deg, var(--color-trust-blue), var(--color-gold));
  z-index: 0;
}
.step-item {
  text-align: center;
  padding: var(--space-8) var(--space-6);
  position: relative;
  z-index: 1;
}
.step-number {
  width: 80px; height: 80px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--color-trust-blue), var(--color-navy));
  color: var(--color-white);
  font-family: var(--font-heading);
  font-size: var(--font-size-2xl);
  font-weight: 700;
  display: flex; align-items: center; justify-content: center;
  margin: 0 auto var(--space-6);
  box-shadow: var(--shadow-md);
  position: relative;
}
.step-item h3 { margin-bottom: var(--space-3); }
.step-item p  { font-size: var(--font-size-base); }

/* ========== TRUST SECTION ========== */
.trust-section { background: var(--color-white); }
.trust-badges-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-6); }
.trust-badge-card {
  text-align: center;
  padding: var(--space-8) var(--space-6);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  transition: box-shadow var(--transition-base);
}
.trust-badge-card:hover { box-shadow: var(--shadow-md); }
.trust-badge-icon { font-size: 2.5rem; margin-bottom: var(--space-4); }
.trust-badge-card h4 { font-size: var(--font-size-base); color: var(--color-navy); margin-bottom: var(--space-2); }
.trust-badge-card p  { font-size: var(--font-size-sm); color: var(--color-text-muted); margin: 0; }

/* ========== PROFILES PREVIEW ========== */
.profiles-section { background: var(--color-silver-pale); }
.profiles-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-6); }

/* ========== CTA SECTION ========== */
.cta-section {
  background: linear-gradient(135deg, var(--color-navy) 0%, var(--color-trust-blue) 100%);
  text-align: center;
  padding: var(--space-24) 0;
}
.cta-section h2 { color: var(--color-white); }
.cta-section p  { color: rgba(255,255,255,0.8); margin: var(--space-4) auto var(--space-8); max-width: 560px; }

/* RESPONSIVE */
@media (max-width: 1024px) {
  .hero-grid   { grid-template-columns: 1fr; text-align: center; }
  .hero-subtitle { margin-left: auto; margin-right: auto; }
  .hero-ctas   { justify-content: center; }
  .hero-trust  { justify-content: center; }
  .hero-visual { display: none; }
  .stats-grid  { grid-template-columns: repeat(2, 1fr); }
  .profiles-grid { grid-template-columns: repeat(2, 1fr); }
  .trust-badges-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 768px) {
  .steps-grid  { grid-template-columns: 1fr; }
  .steps-grid::after { display: none; }
  .stats-grid  { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 480px) {
  .stats-grid  { grid-template-columns: 1fr 1fr; }
  .profiles-grid { grid-template-columns: 1fr 1fr; }
}
