/* =============================================
   BrandDid Digital – hero.css
   Hero section, animations, cards, statistics
   ============================================= */

/* ===== HERO ===== */
.hero {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  justify-content: center;
  position: relative;
  overflow: hidden;
  padding: 120px 0 80px;
}

.hero-bg-glow {
  position: absolute;
  border-radius: 50%;
  filter: blur(80px);
  pointer-events: none;
}
.hero-glow-1 {
  width: 600px; height: 600px;
  background: rgba(255,90,0,0.07);
  top: -100px; left: -100px;
  animation: glowPulse 8s ease-in-out infinite;
}
.hero-glow-2 {
  width: 500px; height: 500px;
  background: rgba(225,77,0,0.05);
  top: 50%; right: -50px;
  transform: translateY(-50%);
  animation: glowPulse 10s ease-in-out infinite reverse;
}
.hero-glow-3 {
  width: 400px; height: 400px;
  background: rgba(255,90,0,0.04);
  bottom: -100px; left: 40%;
  animation: glowPulse 12s ease-in-out infinite;
}

.hero-grid-lines {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,90,0,0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,90,0,0.04) 1px, transparent 1px);
  background-size: 80px 80px;
  mask-image: radial-gradient(ellipse at center, black 30%, transparent 80%);
}

.hero-container {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
  align-items: center;
  position: relative;
  z-index: 2;
}

.hero-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 18px;
  background: #fff3ee;
  border: 1px solid #ffd4bc;
  border-radius: 50px;
  font-family: var(--font-display);
  font-size: 0.82rem;
  font-weight: 600;
  color: #c94000;
  margin-bottom: 24px;
  width: fit-content;
}
.badge-dot {
  width: 8px; height: 8px;
  background: var(--primary);
  border-radius: 50%;
  box-shadow: 0 0 8px rgba(255,90,0,0.5);
  animation: blink 2s ease-in-out infinite;
}

.hero-title {
  font-family: var(--font-display);
  font-size: clamp(2.4rem, 5vw, 3.8rem);
  font-weight: 800;
  line-height: 1.18;
  letter-spacing: -0.025em;
  margin-bottom: 24px;
  color: var(--heading-color);
}

.hero-subtitle {
  font-size: 1.1rem;
  color: var(--gray);
  line-height: 1.75;
  margin-bottom: 36px;
  max-width: 520px;
}
.hero-subtitle strong { color: var(--heading-color); font-weight: 600; }

.hero-ctas {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
  margin-bottom: 36px;
}

.hero-features {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 20px;
}
.hero-feature {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.9rem;
  color: var(--heading-color);
  font-weight: 500;
}
.hero-feature svg {
  flex-shrink: 0;
  color: #22c55e;
  stroke: #22c55e;
}

/* Hero Visual */
.hero-visual {
  position: relative;
  height: 520px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.hero-illustration {
  position: relative;
  width: 240px;
  height: 240px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.illus-ring {
  position: absolute;
  border-radius: 50%;
  border: 1px solid rgba(255,90,0,0.12);
  animation: spinSlow linear infinite;
}
.illus-ring-1 { width: 200px; height: 200px; border-color: rgba(255,90,0,0.18); animation-duration: 20s; }
.illus-ring-2 { width: 280px; height: 280px; border-color: rgba(225,77,0,0.12); animation-duration: 30s; animation-direction: reverse; }
.illus-ring-3 { width: 360px; height: 360px; border-color: rgba(255,90,0,0.06); animation-duration: 45s; }

.illus-core {
  width: 100px; height: 100px;
  background: linear-gradient(135deg, rgba(255,90,0,0.10), rgba(225,77,0,0.10));
  border: 1.5px solid rgba(255,90,0,0.20);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 0 32px rgba(255,90,0,0.12);
}

.orbit-dot {
  position: absolute;
  width: 12px; height: 12px;
  border-radius: 50%;
  background: var(--primary);
  box-shadow: 0 0 12px var(--primary);
}
.od-1 { top: 10px; left: 50%; transform: translateX(-50%); background: var(--primary); }
.od-2 { bottom: 10px; right: 10px; background: var(--primary-dark); box-shadow: 0 0 12px var(--primary-dark); }
.od-3 { bottom: 30px; left: 5px; background: var(--primary-soft); box-shadow: 0 0 12px var(--primary-soft); }

.stat-card {
  position: absolute;
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 16px 20px;
  border-radius: var(--radius-sm);
  box-shadow: var(--shadow-card);
}
.stat-card-1 { top: 20px; right: -20px; }
.stat-card-2 { top: 180px; right: -40px; }
.stat-card-3 { bottom: 140px; left: -20px; }
.stat-card-4 { bottom: 40px; right: 20px; }

.stat-icon { font-size: 1.8rem; }
.stat-num {
  font-family: var(--font-display);
  font-size: 1.5rem;
  font-weight: 800;
  color: var(--primary);
  display: block;
}
.stat-label { font-size: 0.78rem; color: var(--gray); display: block; font-weight: 500; }

/* Scroll indicator */
.scroll-indicator {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  position: absolute;
  bottom: 32px;
  left: 50%;
  transform: translateX(-50%);
  color: var(--gray-dim);
  font-size: 0.75rem;
  z-index: 2;
}
.scroll-mouse {
  width: 22px; height: 34px;
  border: 2px solid #CBD5E1;
  border-radius: 11px;
  display: flex;
  justify-content: center;
  padding-top: 5px;
}
.scroll-wheel {
  width: 3px; height: 6px;
  background: var(--primary);
  border-radius: 3px;
  animation: scrollWheel 2s ease-in-out infinite;
}
