/* ==========================================================
   FOUNDER RUN page template
   Loaded only on pages using page-templates/founder-run.php
   ========================================================== */
.founder-run { padding-top: 0; }

/* HERO */
.fr-hero {
  position: relative;
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  padding: 9rem 1.5rem 6rem;
}
.fr-hero-bg { position: absolute; inset: 0; z-index: 0; }
.fr-hero-bg img { width: 100%; height: 100%; object-fit: cover; }
.fr-hero-bg::after {
  content: "";
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse at 70% 30%, rgba(217,154,43,0.55) 0%, transparent 55%),
    linear-gradient(135deg, rgba(43,31,18,0.78) 0%, rgba(77,107,58,0.55) 100%);
}

.fr-hero-content {
  position: relative; z-index: 1;
  max-width: 60rem;
  text-align: center;
  color: #fff;
}
.fr-hero-year {
  display: inline-block;
  font-family: var(--font-serif);
  font-size: 0.95rem;
  letter-spacing: 0.45em;
  color: rgba(255,255,255,0.85);
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.25);
  border-radius: 9999px;
  padding: 0.4rem 1.1rem 0.4rem 1.55rem;
  margin-bottom: 1.25rem;
}
.fr-hero-content .eyebrow {
  background: rgba(255,255,255,0.15);
  color: #fff;
  border: 1px solid rgba(255,255,255,0.2);
}
.fr-hero-content .eyebrow::before { background: #fff; box-shadow: 0 0 0 4px rgba(255,255,255,0.18); }

.fr-hero-content h1 {
  color: #fff;
  margin: 1rem 0 1.5rem;
  line-height: 1.05;
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}
.fr-hero-title-main {
  font-size: clamp(2rem, 5vw, 3.5rem);
  font-weight: 700;
}
.fr-hero-title-year {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 400;
  font-size: clamp(3.5rem, 9vw, 6.5rem);
  background: linear-gradient(135deg, #f4d35e 0%, #d99a2b 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  letter-spacing: 0.02em;
  line-height: 1;
}
.fr-hero-lead {
  font-size: clamp(1.05rem, 2vw, 1.25rem);
  color: rgba(255,255,255,0.92);
  max-width: 38rem;
  margin: 0 auto 2rem;
  line-height: 1.6;
}
.fr-hero-pills {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 0.65rem;
  justify-content: center;
}
.fr-pill {
  display: inline-block;
  padding: 0.55rem 1.4rem;
  border-radius: 9999px;
  background: rgba(255,255,255,0.12);
  border: 1px solid rgba(255,255,255,0.4);
  color: #fff;
  font-weight: 700;
  font-size: 1rem;
  letter-spacing: 0.1em;
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
}

/* ABOUT */
.fr-about { padding: 5rem 1.5rem; }
.fr-about-head { text-align: center; margin-bottom: 2rem; }
.fr-about-head h2 {
  font-size: clamp(1.75rem, 3.6vw, 2.4rem);
  margin: 0.75rem 0 0;
}
.fr-about .inner-content {
  font-size: 1.08rem;
  line-height: 1.85;
}
.fr-about .inner-content p { color: var(--muted-foreground); margin: 0 0 1.25rem; }
.fr-about .inner-content p:first-child::first-letter {
  font-family: var(--font-serif);
  font-size: 4rem;
  font-weight: 700;
  color: var(--primary);
  float: left;
  line-height: 0.9;
  margin: 0.35rem 0.6rem 0 0;
}

/* IMPACT BANNER */
.fr-impact {
  background: linear-gradient(135deg, var(--primary) 0%, #b07a1f 100%);
  color: #fff;
  padding: 3.5rem 1.5rem;
  position: relative;
  overflow: hidden;
}
.fr-impact::before,
.fr-impact::after {
  content: "";
  position: absolute;
  width: 280px; height: 280px;
  border-radius: 50%;
  background: rgba(255,255,255,0.07);
  pointer-events: none;
}
.fr-impact::before { top: -100px; left: -80px; }
.fr-impact::after { bottom: -120px; right: -60px; }
.fr-impact-inner {
  position: relative; z-index: 1;
  text-align: center;
}
.fr-impact-stat {
  display: inline-flex;
  align-items: baseline;
  justify-content: center;
  gap: 1rem;
  flex-wrap: wrap;
  margin-bottom: 1rem;
}
.fr-impact-num {
  font-family: var(--font-serif);
  font-size: clamp(2rem, 5vw, 3.25rem);
  font-weight: 700;
  letter-spacing: 0.02em;
  line-height: 1;
}
.fr-impact-eq {
  font-size: clamp(1.5rem, 3vw, 2.25rem);
  font-weight: 300;
  opacity: 0.7;
}
.fr-impact-line {
  font-size: clamp(1.5rem, 2vw, 1.2rem);
  margin: 0;
  max-width: 42rem;
  margin: 0 auto;
  line-height: 1.6;
  color: rgba(255,255,255,0.95);
}

/* GALLERY */
.fr-gallery-section { padding: 5rem 1.5rem; background: var(--card); border-top: 1px solid var(--border); }
.fr-section-head { margin-bottom: 2.5rem; }
.fr-section-head h2 {
  font-size: clamp(1.75rem, 3.6vw, 2.4rem);
  margin: 0.75rem 0 0.5rem;
}
.fr-section-sub {
  color: var(--muted-foreground);
  max-width: 38rem;
  margin: 0.5rem auto 0;
  line-height: 1.6;
}
.fr-gallery {
  /* Envira Gallery wrapper — keep neutral so plugin styles remain intact */
  margin: 0 auto;
  max-width: 1200px;
}
.fr-gallery img { border-radius: 10px; }

/* SPONSORS */
.fr-sponsors-section { padding: 5rem 1.5rem; }
.fr-sponsor-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1.25rem;
  max-width: 960px;
  margin: 0 auto;
}
@media (min-width: 640px) { .fr-sponsor-grid { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 1024px) { .fr-sponsor-grid { grid-template-columns: repeat(5, 1fr); } }

.fr-sponsor {
  background: #fff;
  border: 1px solid var(--card-border);
  border-radius: 14px;
  height: 130px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 5px 5px;
  box-shadow: 0 6px 18px -10px rgba(0,0,0,0.12);
  transition: transform 0.25s, box-shadow 0.25s;
}
.fr-sponsor:hover {
  transform: translateY(-3px);
  box-shadow: 0 14px 28px -14px rgba(0,0,0,0.2);
}
.fr-sponsor img {
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
  filter: grayscale(100%);
  opacity: 0.85;
  transition: filter 0.25s, opacity 0.25s;
}
.fr-sponsor:hover img { filter: none; opacity: 1; }
.fr-sponsor-placeholder {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 600;
  color: var(--muted-foreground);
  text-align: center;
  font-size: 1rem;
  letter-spacing: 0.02em;
}
.fr-countdown-section {
    padding: 3.5rem 1.5rem;
}
.fr-countdown-box {
    background: linear-gradient(135deg, #111827, #1f2937);
    border-radius: 24px;
    padding: 48px 24px;
    text-align: center;
    color: #fff;
    max-width: 1000px;
    margin: 0 auto;
}
.fr-countdown-box h2 {
    font-size: 2.4rem;
    margin-bottom: 12px;
    color: #fff;
}
.fr-countdown-text {
    opacity: 0.85;
    margin-bottom: 32px;
    font-size: 1.1rem;
}
.fr-countdown {
    display: flex;
    justify-content: center;
    gap: 20px;
    flex-wrap: wrap;
}
.fr-time {
    background: rgba(255,255,255,0.08);
    border-radius: 18px;
    padding: 20px;
    min-width: 120px;
}
.fr-time span {
    display: block;
    font-size: 2.5rem;
    font-weight: 700;
    line-height: 1;
    margin-bottom: 8px;
}
.fr-time small {
    font-size: 0.9rem;
    text-transform: uppercase;
    letter-spacing: 1px;
    opacity: 0.8;
}