/* ==============================================
   JONDAVIDSON — HERO
   Red grid only on the hero intro section.
   Rest of page is plain white.
============================================== */

/* ── HERO SECTION RESET ── */
.hero {
  position: relative !important;
  display: block !important;
  min-height: unset !important;
  padding-top: 85px !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
  padding-bottom: 0 !important;
  max-width: 100% !important;
  margin: 0 !important;
  background: #ffffff !important;
  overflow: visible !important;
  grid-template-columns: unset !important;
  gap: unset !important;
}

/* Red grid only on the hero section */
.hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(158,4,3,0.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(158,4,3,0.06) 1px, transparent 1px);
  background-size: 48px 48px;
  pointer-events: none;
  z-index: 0;
}

.hero-bg,
.hero-bg::before,
.hero-bg::after { display: none !important; }
#hero-canvas { display: none !important; }

/* ── THREE-COLUMN GRID ── */
.hero-inner {
  position: relative !important;
  z-index: 2 !important;
  display: grid !important;
  grid-template-columns: 1fr 340px 340px !important;
  align-items: center !important;
  gap: 0 !important;
  max-width: 1300px !important;
  margin: 0 auto !important;
  padding: 2.5rem 3rem 3rem !important;
  min-height: unset !important;
  box-sizing: border-box !important;
}

/* ── COL 1: TEXT ── */
.hero-content {
  align-self: center !important;
  padding: 2rem 2.5rem 2rem 0 !important;
  position: relative !important;
}

.hero-content::after {
  content: '';
  position: absolute;
  right: 0;
  top: 8%;
  width: 2px;
  height: 84%;
  background: linear-gradient(
    to bottom,
    rgba(255,255,255,0) 0%,
    rgba(158,4,3,0.65) 45%,
    rgba(158,4,3,0.65) 55%,
    rgba(255,255,255,0) 100%
  );
  border-radius: 1px;
}

.hero-eyebrow {
  display: flex !important;
  align-items: center !important;
  gap: 0.5rem !important;
  color: var(--red) !important;
  letter-spacing: 0.15em !important;
  font-size: 0.72rem !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  margin-bottom: 1.5rem !important;
}
.hero-eyebrow .line {
  display: inline-block !important;
  width: 28px !important;
  height: 2px !important;
  background: var(--red) !important;
  flex-shrink: 0 !important;
}

.hero-title {
  font-family: var(--serif) !important;
  font-size: clamp(2.8rem, 4vw, 4.5rem) !important;
  font-weight: 900 !important;
  color: var(--text) !important;
  line-height: 1.04 !important;
  letter-spacing: -0.02em !important;
  margin-bottom: 1.25rem !important;
  text-shadow: none !important;
}
.hero-title em {
  color: var(--red) !important;
  font-style: italic !important;
}

.hero-sub {
  font-size: 0.9rem !important;
  color: var(--text-light) !important;
  line-height: 1.75 !important;
  max-width: 420px !important;
  margin-bottom: 2rem !important;
}

.hero-btns {
  display: flex !important;
  gap: 1rem !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
}

/* ── COL 2: PHOTO ── */
.hero-photo {
  position: relative !important;
  align-self: end !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-start !important;
  padding: 0 !important;
  background: transparent !important;
  overflow: visible !important;
}
.hero-photo::before,
.hero-photo::after { display: none !important; }
.hero-photo > img,
.hero-photo-img { display: none !important; }

.hero-photo-inner {
  width: 340px !important;
  height: 540px !important;
  overflow: hidden !important;
  clip-path: none !important;
  background: #ddd !important;
  display: block !important;
  flex-shrink: 0 !important;
}
.hero-photo-inner img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center 20% !important;
  display: block !important;
}

.hero-photo-badge {
  position: relative !important;
  margin-top: 0.75rem !important;
  background: #ffffff !important;
  border: 1px solid #e8e6e3 !important;
  border-radius: 10px !important;
  padding: 0.7rem 1rem !important;
  box-shadow: 0 6px 20px rgba(0,0,0,0.09) !important;
  display: flex !important;
  align-items: center !important;
  gap: 0.6rem !important;
  white-space: nowrap !important;
  width: fit-content !important;
  z-index: 4 !important;
}
.hero-photo-badge .badge-num {
  font-family: var(--serif) !important;
  font-size: 1.3rem !important;
  font-weight: 900 !important;
  color: var(--text) !important;
  line-height: 1 !important;
}
.hero-photo-badge .badge-num span { color: var(--red) !important; }
.hero-photo-badge .badge-label {
  font-size: 0.65rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  color: var(--gray) !important;
  line-height: 1.3 !important;
}

/* ── COL 3: STATS ── */
.hero-stats {
  display: flex !important;
  flex-direction: column !important;
  gap: 0.85rem !important;
  align-self: center !important;
  padding: 0 1rem 0 2.5rem !important;
}

.stat-card {
  background: #ffffff !important;
  border: 1px solid #e8e6e3 !important;
  border-radius: 8px !important;
  padding: 1.2rem 1.4rem !important;
  box-shadow: 0 2px 10px rgba(0,0,0,0.04) !important;
  transition: transform 0.2s, box-shadow 0.2s, border-color 0.2s !important;
  backdrop-filter: none !important;
}
.stat-card:hover {
  transform: translateY(-3px) !important;
  box-shadow: 0 8px 28px rgba(158,4,3,0.09) !important;
  border-color: rgba(158,4,3,0.2) !important;
}
.stat-num {
  font-family: var(--serif) !important;
  font-size: 2rem !important;
  font-weight: 900 !important;
  line-height: 1 !important;
  color: var(--text) !important;
}
.plus { color: var(--red) !important; }
.stat-label {
  font-size: 0.65rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.10em !important;
  text-transform: uppercase !important;
  color: var(--gray) !important;
  margin-top: 0.2rem !important;
}
.stat-large p {
  font-size: 0.80rem !important;
  color: var(--text-light) !important;
  line-height: 1.55 !important;
  margin-top: 0.4rem !important;
}
.stat-row {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 0.85rem !important;
}
.stat-accent {
  background: #1a1a1a !important;
  border-color: #1a1a1a !important;
  display: flex !important;
  align-items: center !important;
  gap: 0.7rem !important;
  box-shadow: none !important;
}
.stat-accent:hover { box-shadow: 0 8px 24px rgba(0,0,0,0.16) !important; }
.stat-accent .stat-num-sm {
  font-family: var(--serif) !important;
  font-size: 0.95rem !important;
  font-weight: 700 !important;
  color: #fff !important;
}
.stat-accent .stat-label { color: rgba(255,255,255,0.48) !important; }
.dot {
  width: 9px !important;
  height: 9px !important;
  border-radius: 50% !important;
  flex-shrink: 0 !important;
  background: var(--red) !important;
  box-shadow: 0 0 0 4px rgba(158,4,3,0.22) !important;
  animation: pulse 2s infinite !important;
}
@keyframes pulse {
  0%,100% { box-shadow: 0 0 0 4px rgba(158,4,3,0.22); }
  50%      { box-shadow: 0 0 0 7px rgba(158,4,3,0.08); }
}

/* ── RESPONSIVE ── */
@media (max-width: 1100px) {
  .hero-inner { grid-template-columns: 1fr 300px 300px !important; padding: 2rem 1.5rem 2rem !important; }
  .hero-photo-inner { width: 300px !important; height: 460px !important; }
  .hero-title { font-size: clamp(2.4rem, 3.5vw, 3.8rem) !important; }
}
@media (max-width: 860px) {
  .hero-inner {
    grid-template-columns: 1fr 260px !important;
    grid-template-rows: auto auto !important;
    gap: 1.5rem 1rem !important;
    min-height: auto !important;
    padding: 2rem 1.5rem 2rem !important;
  }
  .hero-content { grid-column: 1; grid-row: 1; padding-right: 1rem !important; }
  .hero-photo   { grid-column: 2; grid-row: 1 / 3; align-self: stretch !important; }
  .hero-photo-inner { width: 260px !important; height: 400px !important; }
  .hero-stats {
    grid-column: 1 !important; grid-row: 2 !important;
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    padding: 0 !important;
  }
  .stat-row   { display: contents !important; }
  .stat-large { grid-column: span 2 !important; }
  .stat-accent{ grid-column: span 2 !important; }
}
@media (max-width: 580px) {
  .hero-inner { grid-template-columns: 1fr !important; padding: 1.5rem 1.25rem 2rem !important; min-height: auto !important; }
  .hero-content { grid-column: 1 !important; grid-row: 1 !important; padding-right: 0 !important; }
  .hero-content::after { display: none !important; }
  .hero-photo   { grid-column: 1 !important; grid-row: 2 !important; align-self: auto !important; }
  .hero-photo-inner { width: 100% !important; max-width: 340px !important; height: 360px !important; }
  .hero-stats   { grid-column: 1 !important; grid-row: 3 !important; grid-template-columns: 1fr !important; padding: 0 !important; }
  .stat-large, .stat-accent { grid-column: span 1 !important; }
  .hero-btns { flex-wrap: wrap !important; }
  .hero-title { font-size: clamp(2rem, 8vw, 3rem) !important; }
}
