/* ============================================================
   Lexington Blueberry Festival — Main Stylesheet
   Version: 1.0.0
   ============================================================ */

/* ── CSS Variables ─────────────────────────────────────────── */
:root {
  --navy:       #0037A7;
  --blue:       #0037A7;
  --sky:        #A9AEFF;
  --light-blue: #E8EAFF;
  --cream:      #fdf8f0;
  --white:      #ffffff;
  --green:      #007F00;
  --light-green:#90EE90;
  --accent:     #007F00;
  --text-dark:  #3A3A3A;
  --text-mid:   #7A7A7A;
  --text-light: #A0A0A0;
  --radius-sm:  8px;
  --radius:     16px;
  --radius-lg:  24px;
  --shadow:     0 8px 32px rgba(0,55,167,.13);
  --shadow-lg:  0 20px 60px rgba(0,55,167,.18);
  --transition: .25s ease;
}

/* ── Reset & Base ──────────────────────────────────────────── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }

html { scroll-behavior:smooth; font-size:16px; }

body {
  font-family:'Inter', sans-serif;
  color:var(--text-dark);
  background:var(--cream);
  line-height:1.6;
  overflow-x:hidden;
}

img { max-width:100%; height:auto; display:block; }
a   { color:var(--blue); text-decoration:none; transition:color var(--transition); }
a:hover { color:var(--navy); }
ul  { list-style:none; }

/* ── Accessibility ─────────────────────────────────────────── */
.skip-link {
  position:absolute;
  top:-100px;
  left:16px;
  z-index:9999;
  background:var(--accent);
  color:var(--navy);
  padding:10px 20px;
  border-radius:var(--radius-sm);
  font-weight:800;
  transition:top var(--transition);
}
.skip-link:focus { top:16px; }

:focus-visible {
  outline:3px solid var(--accent);
  outline-offset:3px;
  border-radius:4px;
}

.sr-only {
  position:absolute;
  width:1px;height:1px;
  padding:0;margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}

/* ── Container ─────────────────────────────────────────────── */
.bbf-container {
  max-width:1240px;
  margin:0 auto;
  padding:0 24px;
}

/* ── Navigation ────────────────────────────────────────────── */
#bbf-nav {
  position:fixed;
  top:0;left:0;right:0;
  z-index:1000;
  background:rgba(0,55,167,.97);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  border-bottom:2px solid rgba(107,163,214,.3);
  transition:box-shadow var(--transition);
}

#bbf-nav.scrolled { box-shadow:0 4px 24px rgba(0,0,0,.3); }

.nav-inner {
  max-width:1280px;
  margin:0 auto;
  padding:0 24px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  height:76px;
}

.nav-logo {
  display:flex;
  align-items:center;
  cursor:pointer;
  text-decoration:none;
  padding:6px 0;
}

.nav-logo-icon {
  width:44px;height:44px;
  border-radius:50%;
  background:linear-gradient(135deg,var(--sky),var(--blue));
  display:flex;align-items:center;justify-content:center;
  font-size:22px;
  box-shadow:0 4px 12px rgba(0,55,167,.4);
  flex-shrink:0;
}

.nav-logo-text {
  color:#fff;
  font-family:'DM Sans', sans-serif;
  font-size:16px;
  font-weight:700;
  line-height:1.2;
}

.nav-logo-text span {
  display:block;
  font-family:'Inter', sans-serif;
  font-size:10px;
  font-weight:800;
  color:var(--sky);
  letter-spacing:1.5px;
  text-transform:uppercase;
}

.nav-menu {
  display:flex;
  align-items:center;
  gap:2px;
}

.nav-menu li a {
  color:rgba(255,255,255,.85);
  font-size:14px;
  font-weight:700;
  padding:8px 13px;
  border-radius:var(--radius-sm);
  transition:all var(--transition);
  display:block;
}

.nav-menu li a:hover,
.nav-menu li.current-menu-item > a,
.nav-menu li.current-page-ancestor > a {
  color:#fff;
  background:rgba(107,163,214,.2);
}

.nav-menu li.menu-donate > a {
  background:var(--accent);
  color:#fff;
  border-radius:20px;
  padding:8px 18px;
}

.nav-menu li.menu-donate > a:hover {
  background:#1A9F1A;
  transform:translateY(-1px);
}

/* Hamburger */
.nav-toggle {
  display:none;
  background:none;
  border:none;
  cursor:pointer;
  padding:8px;
  flex-direction:column;
  gap:5px;
}

.nav-toggle span {
  display:block;
  width:24px;height:2px;
  background:#fff;
  border-radius:2px;
  transition:all .3s;
}

/* Mobile nav */
@media(max-width:900px) {
  .nav-toggle { display:flex; }

  .nav-menu {
    display:none;
    flex-direction:column;
    position:fixed;
    top:76px;left:0;right:0;
    background:rgba(0,55,167,.98);
    padding:16px;
    gap:4px;
    border-top:1px solid rgba(255,255,255,.1);
    max-height:calc(100vh - 68px);
    overflow-y:auto;
    align-items:flex-start;
  }

  .nav-menu.is-open { display:flex; }
  .nav-menu li { width:100%; }
  .nav-menu li a { padding:12px 16px; border-radius:var(--radius-sm); }
}

/* ── Buttons ───────────────────────────────────────────────── */
.bbf-btn {
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:14px 28px;
  border-radius:50px;
  font-family:'Inter', sans-serif;
  font-size:15px;
  font-weight:800;
  cursor:pointer;
  border:none;
  text-decoration:none;
  transition:all var(--transition);
  line-height:1;
}

.bbf-btn-primary { background:var(--accent);    color:#fff; box-shadow:0 8px 24px rgba(0,127,0,.4); }
.bbf-btn-primary:hover  { background:#1A9F1A;   color:#fff; transform:translateY(-3px); box-shadow:0 14px 32px rgba(0,127,0,.5); }

.bbf-btn-blue  { background:var(--blue);    color:#fff; box-shadow:0 8px 24px rgba(0,55,167,.3); }
.bbf-btn-blue:hover  { background:#1A57C7;  color:#fff; transform:translateY(-3px); }

.bbf-btn-navy  { background:var(--navy);    color:#fff; box-shadow:0 8px 24px rgba(0,55,167,.3); }
.bbf-btn-navy:hover  { background:#002E8C;  color:#fff; transform:translateY(-3px); }

.bbf-btn-green { background:var(--green);   color:#fff; box-shadow:0 8px 24px rgba(0,127,0,.3); }
.bbf-btn-green:hover { background:#1A9F1A;  color:#fff; transform:translateY(-3px); }

.bbf-btn-outline {
  background:rgba(255,255,255,.1);
  color:#fff;
  border:2px solid rgba(255,255,255,.4);
  backdrop-filter:blur(8px);
}
.bbf-btn-outline:hover {
  background:rgba(255,255,255,.2);
  color:#fff;
  border-color:#fff;
  transform:translateY(-3px);
}

.bbf-btn-sm { padding:10px 20px; font-size:14px; }
.bbf-btn-lg { padding:18px 36px; font-size:17px; }
.bbf-btn-full { width:100%; justify-content:center; }

/* ── Section Headings ──────────────────────────────────────── */
.section-label {
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-size:12px;
  font-weight:800;
  letter-spacing:3px;
  text-transform:uppercase;
  color:var(--blue);
  margin-bottom:12px;
}

.section-title {
  font-family:'DM Sans', sans-serif;
  font-size:clamp(30px,4vw,52px);
  font-weight:800;
  color:var(--navy);
  line-height:1.1;
  margin-bottom:16px;
}

.section-sub {
  font-size:17px;
  color:var(--text-mid);
  line-height:1.7;
  max-width:660px;
  margin-bottom:52px;
}

/* ── Page Header Banner ────────────────────────────────────── */
.bbf-page-header {
  background:linear-gradient(160deg,#001F6B 0%,var(--navy) 100%);
  padding:140px 24px 100px;
  text-align:center;
  position:relative;
  overflow:hidden;
  margin-top:68px;
}

.bbf-page-header::after {
  content:'';
  position:absolute;
  bottom:0;left:0;right:0;
  height:60px;
  background:var(--cream);
  clip-path:ellipse(55% 100% at 50% 100%);
}

.bbf-page-header h1 {
  font-family:'DM Sans', sans-serif;
  font-size:clamp(36px,5vw,68px);
  color:#fff;
  font-weight:800;
  margin-bottom:16px;
  position:relative;
  z-index:1;
}

.bbf-page-header p {
  color:rgba(255,255,255,.85);
  font-size:18px;
  max-width:620px;
  margin:0 auto;
  position:relative;
  z-index:1;
  line-height:1.6;
}

/* ── Hero Section ──────────────────────────────────────────── */
.bbf-hero {
  position:relative;
  min-height:100vh;
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
  padding-top:68px;
}

.hero-bg {
  position:absolute;
  inset:0;
  background:
    radial-gradient(ellipse at 20% 50%, rgba(0,55,167,.6) 0%, transparent 60%),
    radial-gradient(ellipse at 80% 20%, rgba(0,55,167,.8) 0%, transparent 50%),
    linear-gradient(160deg,#001F6B 0%,#002E8C 30%,#0037A7 70%,#003299 100%);
  z-index:0;
}

.hero-bg-img {
  position:absolute;
  inset:0;
  background-size:cover;
  background-position:center;
  z-index:0;
  opacity:.25;
}

.hero-pattern {
  position:absolute;
  inset:0;
  z-index:1;
  opacity:.05;
  background-image:radial-gradient(circle at 2px 2px,#fff 1px,transparent 0);
  background-size:40px 40px;
}

.hero-content {
  position:relative;
  z-index:3;
  text-align:center;
  max-width:860px;
  padding:60px 24px;
  animation:bbfFadeUp .9s ease both;
}

.hero-badge {
  display:inline-flex;
  align-items:center;
  gap:8px;
  background:rgba(0,127,0,.2);
  border:1px solid rgba(0,127,0,.5);
  color:var(--accent);
  padding:8px 20px;
  border-radius:30px;
  font-size:13px;
  font-weight:800;
  letter-spacing:2px;
  text-transform:uppercase;
  margin-bottom:28px;
}

.hero h1 {
  font-family:'DM Sans', sans-serif;
  font-size:clamp(44px,8vw,92px);
  font-weight:800;
  color:#fff;
  line-height:1.0;
  margin-bottom:14px;
  text-shadow:0 4px 24px rgba(0,0,0,.3);
}

.hero h1 em { font-style:normal; color:var(--accent); }

.hero-tagline {
  font-size:clamp(16px,2.5vw,22px);
  color:rgba(255,255,255,.88);
  margin-bottom:40px;
  font-weight:600;
}

/* Floating Berries */
.berry-float {
  position:absolute;
  border-radius:50%;
  background:radial-gradient(circle at 35% 35%,#A9AEFF,#0037A7,#0037A7);
  box-shadow:inset -3px -3px 8px rgba(0,0,0,.3),inset 3px 3px 8px rgba(255,255,255,.12);
  animation:bbfFloat 6s ease-in-out infinite;
  opacity:.65;
  z-index:2;
  pointer-events:none;
}

.berry-float::after {
  content:'';
  position:absolute;
  top:15%;left:18%;
  width:26%;height:20%;
  background:rgba(255,255,255,.28);
  border-radius:50%;
  transform:rotate(-30deg);
}

.bf-1 { width:80px;height:80px; top:14%;left:7%;  animation-delay:0s; }
.bf-2 { width:52px;height:52px; top:28%;left:86%; animation-delay:1.5s; }
.bf-3 { width:68px;height:68px; top:68%;left:91%; animation-delay:3s; }
.bf-4 { width:42px;height:42px; top:80%;left:5%;  animation-delay:2s; }
.bf-5 { width:58px;height:58px; top:50%;left:2%;  animation-delay:4s; }

/* Countdown */
.countdown {
  display:flex;
  justify-content:center;
  gap:14px;
  margin-bottom:48px;
  flex-wrap:wrap;
}

.countdown-unit {
  background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.2);
  backdrop-filter:blur(8px);
  border-radius:var(--radius);
  padding:16px 20px;
  min-width:82px;
  text-align:center;
}

.countdown-num {
  font-family:'DM Sans', sans-serif;
  font-size:42px;
  font-weight:700;
  color:#fff;
  line-height:1;
  display:block;
}

.countdown-label {
  font-size:11px;
  color:var(--sky);
  font-weight:800;
  letter-spacing:2px;
  text-transform:uppercase;
  margin-top:4px;
  display:block;
}

.hero-buttons {
  display:flex;
  gap:14px;
  justify-content:center;
  flex-wrap:wrap;
  margin-bottom:56px;
}

.quick-nav {
  display:flex;
  gap:10px;
  justify-content:center;
  flex-wrap:wrap;
}

.quick-nav-btn {
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.25);
  color:#fff;
  padding:10px 22px;
  border-radius:30px;
  font-family:'Inter', sans-serif;
  font-size:14px;
  font-weight:700;
  cursor:pointer;
  transition:all var(--transition);
  backdrop-filter:blur(8px);
  text-decoration:none;
  display:inline-block;
}

.quick-nav-btn:hover { background:rgba(255,255,255,.22); color:#fff; transform:translateY(-2px); }

.scroll-indicator {
  position:absolute;
  bottom:32px;left:50%;
  transform:translateX(-50%);
  color:rgba(255,255,255,.5);
  font-size:28px;
  z-index:3;
  animation:bbfBounce 2s infinite;
  cursor:pointer;
}

/* ── Welcome / Highlights ──────────────────────────────────── */
.bbf-welcome {
  background:linear-gradient(180deg,var(--cream) 0%,#eaf3fb 100%);
  padding:90px 24px;
}

.welcome-intro { text-align:center; max-width:780px; margin:0 auto 72px; }
.welcome-intro .section-sub { margin:0 auto 0; }

.highlights-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(265px,1fr));
  gap:24px;
}

.highlight-card {
  background:#fff;
  border-radius:var(--radius-lg);
  padding:32px 28px;
  box-shadow:var(--shadow);
  transition:all var(--transition);
  position:relative;
  overflow:hidden;
}

.highlight-card::before {
  content:'';
  position:absolute;
  top:0;left:0;right:0;
  height:4px;
  background:linear-gradient(90deg,var(--navy),var(--sky));
}

.highlight-card:hover { transform:translateY(-8px); box-shadow:var(--shadow-lg); }

.highlight-icon {
  width:60px;height:60px;
  border-radius:var(--radius-sm);
  display:flex;align-items:center;justify-content:center;
  font-size:28px;
  margin-bottom:20px;
  background:var(--light-blue);
}

.highlight-card h3 {
  font-family:'DM Sans', sans-serif;
  font-size:21px;
  color:var(--navy);
  margin-bottom:10px;
}

.highlight-card p { font-size:15px; color:var(--text-mid); line-height:1.65; }

/* ── CTA Strip ─────────────────────────────────────────────── */
.bbf-cta-strip {
  background:linear-gradient(135deg,#001F6B 0%,var(--navy) 100%);
  padding:80px 24px;
  position:relative;
  overflow:hidden;
}

.bbf-cta-strip::before {
  content:'🫐';
  position:absolute;
  font-size:220px;
  opacity:.05;
  right:-50px;top:-50px;
  pointer-events:none;
}

.cta-strip-inner {
  max-width:900px;
  margin:0 auto;
  text-align:center;
  position:relative;
  z-index:1;
}

.cta-strip-inner h2 {
  font-family:'DM Sans', sans-serif;
  font-size:clamp(28px,4vw,48px);
  color:#fff;
  margin-bottom:16px;
}

.cta-strip-inner p { color:rgba(255,255,255,.82); font-size:18px; margin-bottom:40px; }

.cta-buttons {
  display:flex;
  gap:16px;
  justify-content:center;
  flex-wrap:wrap;
}

/* ── Attractions ───────────────────────────────────────────── */
.bbf-attractions { padding:90px 24px; }

.attractions-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(330px,1fr));
  gap:28px;
}

.attraction-card {
  background:#fff;
  border-radius:var(--radius-lg);
  overflow:hidden;
  box-shadow:var(--shadow);
  transition:all var(--transition);
}

.attraction-card:hover { transform:translateY(-8px); box-shadow:var(--shadow-lg); }

.attraction-img {
  height:210px;
  display:flex;align-items:center;justify-content:center;
  font-size:72px;
  position:relative;
}

.attraction-img img {
  width:100%;height:100%;
  object-fit:cover;
  position:absolute;inset:0;
}

.attraction-img-1 { background:linear-gradient(135deg,#002E8C,#0037A7); }
.attraction-img-2 { background:linear-gradient(135deg,#006600,#33AA33); }
.attraction-img-3 { background:linear-gradient(135deg,#0037A7,#A9AEFF); }
.attraction-img-4 { background:linear-gradient(135deg,#8b5e3c,#c4885a); }
.attraction-img-5 { background:linear-gradient(135deg,#0037A7,#4466CC); }
.attraction-img-6 { background:linear-gradient(135deg,#005500,#007A00); }

.attraction-body { padding:28px; }

.attraction-tag {
  display:inline-block;
  background:var(--light-blue);
  color:var(--blue);
  font-size:11px;font-weight:800;
  letter-spacing:2px;text-transform:uppercase;
  padding:4px 12px;
  border-radius:20px;
  margin-bottom:12px;
}

.attraction-body h3 {
  font-family:'DM Sans', sans-serif;
  font-size:22px;color:var(--navy);
  margin-bottom:10px;
}

.attraction-body p { color:var(--text-mid); font-size:15px; line-height:1.65; }

/* ── Schedule ──────────────────────────────────────────────── */
.bbf-schedule { padding:90px 24px; }

.schedule-toolbar {
  display:flex;
  justify-content:space-between;
  align-items:center;
  flex-wrap:wrap;
  gap:20px;
  margin-bottom:48px;
}

.schedule-day { margin-bottom:52px; }

.schedule-day-header {
  background:linear-gradient(135deg,#001F6B,var(--navy));
  color:#fff;
  padding:20px 32px;
  border-radius:var(--radius) var(--radius) 0 0;
}

.schedule-day-header h2 {
  font-family:'DM Sans', sans-serif;
  font-size:26px;font-weight:700;
}

.schedule-day-header .day-date { font-size:14px; opacity:.8; font-weight:600; margin-top:2px; }

.schedule-list {
  background:#fff;
  border-radius:0 0 var(--radius) var(--radius);
  overflow:hidden;
  box-shadow:var(--shadow);
}

.schedule-item {
  display:grid;
  grid-template-columns:110px 1fr auto;
  align-items:center;
  padding:20px 32px;
  gap:20px;
  border-bottom:1px solid var(--light-blue);
  transition:background var(--transition);
}

.schedule-item:last-child { border-bottom:none; }
.schedule-item:hover { background:var(--light-blue); }

.schedule-item.is-featured {
  background:linear-gradient(90deg,rgba(0,55,167,.05),transparent);
  border-left:4px solid var(--accent);
}

.schedule-time { font-size:14px; font-weight:800; color:var(--blue); letter-spacing:.5px; }

.schedule-event-name { font-size:16px; font-weight:700; color:var(--navy); margin-bottom:4px; }

.schedule-location { font-size:13px; color:var(--text-light); font-weight:600; }

.schedule-badge {
  font-size:11px;font-weight:800;
  letter-spacing:1.5px;text-transform:uppercase;
  padding:5px 12px;border-radius:20px;
  white-space:nowrap;
}

.badge-featured { background:var(--accent); color:var(--navy); }
.badge-music    { background:#DDE0FF; color:#003399; }
.badge-kids     { background:#E8FFE8; color:#006600; }
.badge-free     { background:#D4F0D4; color:var(--green); }

.schedule-note {
  background:var(--light-blue);
  border-radius:var(--radius);
  padding:24px 32px;
  font-size:16px;
  color:var(--text-mid);
  text-align:center;
  margin-top:24px;
}

/* ── Pageant ───────────────────────────────────────────────── */
.bbf-pageant { padding:90px 24px; }

.pageant-hero-block {
  background:linear-gradient(135deg,#0037A7 0%,#0037A7 50%,#A9AEFF 100%);
  border-radius:var(--radius-lg);
  padding:64px 48px;
  color:#fff;
  text-align:center;
  margin-bottom:64px;
  position:relative;
  overflow:hidden;
}

.pageant-hero-block::before {
  content:'👑';
  position:absolute;
  font-size:180px;
  opacity:.07;
  right:-20px;bottom:-30px;
  pointer-events:none;
}

.pageant-hero-block .crown { font-size:64px; display:block; margin-bottom:16px; }

.pageant-hero-block h2 {
  font-family:'DM Sans', sans-serif;
  font-size:clamp(28px,4vw,44px);
  margin-bottom:16px;
}

.pageant-hero-block p {
  font-size:18px;opacity:.9;
  max-width:620px;margin:0 auto 32px;
  line-height:1.65;
}

.divisions-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(195px,1fr));
  gap:20px;
  margin-bottom:60px;
}

.division-card {
  background:#fff;
  border-radius:var(--radius-lg);
  padding:28px 20px;
  text-align:center;
  box-shadow:var(--shadow);
  transition:all var(--transition);
}

.division-card:hover { transform:translateY(-6px); box-shadow:var(--shadow-lg); }

.division-icon { font-size:40px; margin-bottom:12px; }

.division-card h3 {
  font-family:'DM Sans', sans-serif;
  font-size:18px;color:var(--navy);
  margin-bottom:6px;
}

.division-card p { font-size:14px; color:var(--text-light); font-weight:600; }

.rules-box {
  background:#fff;
  border-radius:var(--radius-lg);
  padding:44px;
  box-shadow:var(--shadow);
  margin-bottom:40px;
}

.rules-box h3 {
  font-family:'DM Sans', sans-serif;
  font-size:28px;color:var(--navy);
  margin-bottom:24px;
}

.rules-list { display:grid; gap:12px; }

.rules-list li {
  display:flex;gap:12px;
  align-items:flex-start;
  font-size:15px;color:var(--text-mid);
  line-height:1.55;
}

.rules-list li::before { content:'🫐'; flex-shrink:0; margin-top:2px; }

.deadline-banner {
  background:linear-gradient(135deg,#007F00,#005500);
  border-radius:var(--radius);
  padding:28px 36px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
  flex-wrap:wrap;
  margin-bottom:40px;
}

.deadline-banner h3 {
  font-family:'DM Sans', sans-serif;
  font-size:22px;color:#fff;
  margin-bottom:4px;
}

.deadline-banner p { color:#fff; opacity:.9; font-size:15px; }
.deadline-btns { display:flex; gap:12px; flex-wrap:wrap; }

/* ── Forms Page ────────────────────────────────────────────── */
.bbf-forms { padding:90px 24px; }

.forms-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(265px,1fr));
  gap:24px;
  margin-bottom:64px;
}

.form-card {
  background:#fff;
  border-radius:var(--radius-lg);
  padding:32px 28px;
  box-shadow:var(--shadow);
  text-align:center;
  transition:all var(--transition);
  border-top:4px solid var(--blue);
}

.form-card:hover { transform:translateY(-6px); box-shadow:var(--shadow-lg); }

.form-icon { font-size:46px; margin-bottom:16px; }

.form-card h3 {
  font-family:'DM Sans', sans-serif;
  font-size:20px;color:var(--navy);
  margin-bottom:10px;
}

.form-card p { font-size:14px; color:var(--text-mid); margin-bottom:20px; line-height:1.55; }

/* ── Shared Form Styles ─────────────────────────────────────── */
.bbf-form-box {
  background:#fff;
  border-radius:var(--radius-lg);
  padding:48px;
  box-shadow:var(--shadow);
}

.bbf-form-box h3 {
  font-family:'DM Sans', sans-serif;
  font-size:28px;color:var(--navy);
  margin-bottom:8px;
}

.bbf-form-box > p { color:var(--text-mid); margin-bottom:32px; font-size:16px; }

.form-group { margin-bottom:20px; }

.form-group label {
  display:block;
  font-size:14px;font-weight:700;
  color:var(--navy);
  margin-bottom:8px;
}

.form-group input,
.form-group select,
.form-group textarea {
  width:100%;
  padding:14px 18px;
  border:2px solid var(--light-blue);
  border-radius:var(--radius);
  font-family:'Inter', sans-serif;
  font-size:15px;
  color:var(--text-dark);
  background:var(--cream);
  transition:border-color var(--transition);
  outline:none;
}

.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
  border-color:var(--blue);
  background:#fff;
}

.form-group textarea { resize:vertical; min-height:130px; }

.form-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; }

.form-check {
  display:flex;align-items:center;gap:12px;
  margin-bottom:20px;cursor:pointer;
}

.form-check input[type="checkbox"] {
  width:18px;height:18px;cursor:pointer;
}

.form-check span { font-size:15px; color:var(--text-mid); }

.form-note {
  font-size:13px;color:var(--text-light);
  text-align:center;margin-top:12px;
  line-height:1.5;
}

/* ── Sponsors ──────────────────────────────────────────────── */
.bbf-sponsors { padding:90px 24px; }

.tier-section { margin-bottom:60px; }

.tier-header {
  display:flex;align-items:center;gap:16px;
  margin-bottom:28px;
  padding-bottom:16px;
  border-bottom:2px solid var(--light-blue);
}

.tier-badge {
  padding:8px 20px;border-radius:30px;
  font-size:12px;font-weight:800;
  letter-spacing:2px;text-transform:uppercase;
}

.tier-platinum { background:linear-gradient(135deg,#e8e8e8,#c0c0c0); color:#333; }
.tier-gold     { background:linear-gradient(135deg,#ffd700,#ffa500); color:#003300; }
.tier-silver   { background:linear-gradient(135deg,#d3d3d3,#a9a9a9); color:#333; }
.tier-community{ background:linear-gradient(135deg,#90EE90,#007F00); color:#fff; }

.tier-header h2 {
  font-family:'DM Sans', sans-serif;
  font-size:28px;color:var(--navy);
}

.sponsors-logo-grid {
  display:grid;gap:16px;
}

.sponsors-logo-grid.platinum  { grid-template-columns:repeat(auto-fill,minmax(220px,1fr)); }
.sponsors-logo-grid.gold      { grid-template-columns:repeat(auto-fill,minmax(185px,1fr)); }
.sponsors-logo-grid.silver    { grid-template-columns:repeat(auto-fill,minmax(155px,1fr)); }
.sponsors-logo-grid.community { grid-template-columns:repeat(auto-fill,minmax(130px,1fr)); }

.sponsor-logo {
  background:#fff;
  border-radius:var(--radius);
  display:flex;align-items:center;justify-content:center;
  box-shadow:var(--shadow);
  transition:all var(--transition);
  color:var(--text-mid);
  font-weight:700;font-size:14px;
  text-align:center;
  padding:12px;
  flex-direction:column;
  gap:6px;
}

.sponsor-logo img { object-fit:contain; max-height:80px; }

.sponsor-logo:hover { transform:translateY(-4px); box-shadow:var(--shadow-lg); color:var(--blue); }

.sponsor-logo.platinum  { height:100px; }
.sponsor-logo.gold      { height:80px; }
.sponsor-logo.silver    { height:65px; font-size:13px; }
.sponsor-logo.community { height:55px; font-size:12px; }

.sponsor-spotlight {
  background:linear-gradient(135deg,#001F6B,var(--navy));
  border-radius:var(--radius-lg);
  padding:48px;
  color:#fff;
  margin-bottom:60px;
  display:grid;
  grid-template-columns:240px 1fr;
  gap:48px;
  align-items:center;
}

.spotlight-logo-box {
  background:#fff;
  border-radius:var(--radius-lg);
  height:160px;
  display:flex;align-items:center;justify-content:center;
  font-size:52px;
}

.sponsor-spotlight p.tier-label {
  font-size:12px;font-weight:800;
  letter-spacing:3px;text-transform:uppercase;
  color:rgba(255,255,255,.6);
  margin-bottom:8px;
}

.sponsor-spotlight h3 {
  font-family:'DM Sans', sans-serif;
  font-size:30px;margin-bottom:12px;
}

.sponsor-spotlight p.desc { font-size:16px; opacity:.85; line-height:1.65; margin-bottom:24px; }

/* ── Donate ────────────────────────────────────────────────── */
.bbf-donate { padding:90px 24px; }

.donate-why {
  background:#fff;
  border-radius:var(--radius-lg);
  padding:48px;
  box-shadow:var(--shadow);
  margin-bottom:40px;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:48px;
  align-items:center;
}

.donate-why h3 {
  font-family:'DM Sans', sans-serif;
  font-size:32px;color:var(--navy);
  margin-bottom:16px;
}

.donate-why p { color:var(--text-mid); font-size:16px; line-height:1.7; margin-bottom:16px; }

.impact-list { display:grid; gap:12px; }

.impact-list li {
  display:flex;gap:12px;
  font-size:15px;color:var(--text-mid);
  font-weight:600;align-items:center;
}

.impact-list li span { font-size:20px; flex-shrink:0; }

.donate-progress {
  background:var(--light-blue);
  border-radius:var(--radius-lg);
  padding:28px;
  text-align:center;
}

.donate-total {
  font-family:'DM Sans', sans-serif;
  font-size:48px;font-weight:800;
  color:var(--navy);
}

.donate-goal-label { color:var(--text-mid); font-size:15px; font-weight:600; margin-bottom:12px; }

.progress-bar {
  background:#ddd;
  border-radius:8px;
  height:14px;
  overflow:hidden;
  margin-bottom:8px;
}

.progress-fill {
  background:linear-gradient(90deg,var(--navy),var(--sky));
  height:100%;
  border-radius:8px;
  transition:width 1.2s ease;
}

.progress-pct { font-size:13px; color:var(--text-light); font-weight:600; }

.donate-amounts {
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:12px;
  margin-bottom:24px;
}

.amount-btn {
  border:2px solid var(--light-blue);
  background:#fff;
  border-radius:var(--radius);
  padding:16px 12px;
  text-align:center;
  cursor:pointer;
  transition:all var(--transition);
  font-family:'Inter', sans-serif;
}

.amount-btn .amount {
  display:block;
  font-family:'DM Sans', sans-serif;
  font-size:26px;font-weight:700;
  color:var(--navy);
}

.amount-btn .impact-note {
  display:block;
  font-size:11px;color:var(--text-light);
  font-weight:600;margin-top:4px;
}

.amount-btn:hover,
.amount-btn.is-selected {
  border-color:var(--blue);
  background:var(--light-blue);
}

.payment-methods {
  display:flex;gap:12px;flex-wrap:wrap;
  margin-bottom:24px;
}

.payment-btn {
  flex:1;min-width:120px;
  padding:14px;border-radius:var(--radius);
  border:2px solid var(--light-blue);
  background:#fff;cursor:pointer;
  font-family:'Inter', sans-serif;
  font-size:15px;font-weight:700;
  transition:all var(--transition);
  display:flex;align-items:center;justify-content:center;gap:8px;
}

.payment-btn:hover,
.payment-btn.is-selected { border-color:var(--blue); background:var(--light-blue); }

/* ── Contact ───────────────────────────────────────────────── */
.bbf-contact { padding:90px 24px; }

.contact-grid {
  display:grid;
  grid-template-columns:1fr 1.4fr;
  gap:40px;
  align-items:start;
}

.contact-info {
  background:#fff;
  border-radius:var(--radius-lg);
  padding:40px;
  box-shadow:var(--shadow);
}

.contact-info h3 {
  font-family:'DM Sans', sans-serif;
  font-size:26px;color:var(--navy);
  margin-bottom:28px;
}

.contact-item {
  display:flex;gap:16px;
  align-items:flex-start;
  margin-bottom:24px;
  padding-bottom:24px;
  border-bottom:1px solid var(--light-blue);
}

.contact-item:last-child { border-bottom:none; margin-bottom:0; padding-bottom:0; }

.contact-item-icon {
  width:44px;height:44px;
  border-radius:var(--radius-sm);
  background:var(--light-blue);
  display:flex;align-items:center;justify-content:center;
  font-size:20px;flex-shrink:0;
}

.contact-item h4 {
  font-size:12px;font-weight:800;
  color:var(--text-light);
  letter-spacing:1px;text-transform:uppercase;
  margin-bottom:4px;
}

.contact-item p {
  font-size:15px;color:var(--text-mid);
  font-weight:600;line-height:1.55;
}

.social-links { display:flex;gap:10px;margin-top:24px;flex-wrap:wrap; }

.social-link {
  width:44px;height:44px;
  border-radius:var(--radius-sm);
  background:var(--navy);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-size:18px;text-decoration:none;
  transition:all var(--transition);
}

.social-link:hover { background:var(--blue); color:#fff; transform:translateY(-3px); }

.contact-map {
  margin-top:24px;
  border-radius:var(--radius);
  overflow:hidden;
  height:260px;
}

.contact-map iframe {
  width:100%;height:100%;border:none;
}

.contact-map-placeholder {
  width:100%;height:100%;
  background:linear-gradient(135deg,var(--light-blue),#c5dff0);
  display:flex;align-items:center;justify-content:center;
  flex-direction:column;gap:12px;
  font-size:16px;font-weight:700;color:var(--blue);
}

/* ── Newsletter ─────────────────────────────────────────────── */
.bbf-newsletter {
  background:linear-gradient(135deg,#007F00,#005500);
  padding:80px 24px;
}

.newsletter-inner { max-width:720px; margin:0 auto; text-align:center; }

.newsletter-inner h2 {
  font-family:'DM Sans', sans-serif;
  font-size:clamp(28px,4vw,40px);
  color:#fff;margin-bottom:12px;
}

.newsletter-inner p { color:rgba(255,255,255,.88); font-size:17px; margin-bottom:32px; }

.newsletter-form {
  display:flex;gap:12px;
  max-width:520px;margin:0 auto;
}

.newsletter-form input {
  flex:1;padding:16px 22px;
  border-radius:50px;border:none;
  font-family:'Inter', sans-serif;font-size:15px;
  outline:none;
  box-shadow:0 4px 16px rgba(0,0,0,.12);
}

.newsletter-msg {
  margin-top:12px;
  font-size:14px;color:rgba(255,255,255,.9);
  font-weight:600;min-height:20px;
}

/* ── Footer ────────────────────────────────────────────────── */
#bbf-footer {
  background:var(--navy);
  color:rgba(255,255,255,.75);
  padding:72px 24px 32px;
}

.footer-inner { max-width:1200px; margin:0 auto; }

.footer-top {
  display:grid;
  grid-template-columns:1.6fr 1fr 1fr 1fr;
  gap:48px;
  margin-bottom:56px;
}

.footer-brand .footer-logo {
  display:flex;align-items:center;gap:12px;margin-bottom:16px;
}

.footer-brand h3 {
  font-family:'DM Sans', sans-serif;
  font-size:20px;color:#fff;
}

.footer-brand p { font-size:14px; line-height:1.75; margin-bottom:20px; }

.footer-col h4 {
  font-size:12px;font-weight:800;
  letter-spacing:2px;text-transform:uppercase;
  color:var(--sky);margin-bottom:20px;
}

.footer-col ul { display:grid; gap:10px; }

.footer-col ul li a {
  color:rgba(255,255,255,.7);
  font-size:14px;font-weight:600;
  transition:color var(--transition);
}

.footer-col ul li a:hover { color:var(--sky); }

.footer-bottom {
  border-top:1px solid rgba(255,255,255,.1);
  padding-top:28px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  flex-wrap:wrap;gap:16px;
}

.footer-bottom p { font-size:13px; }

/* ── Alerts & Messages ─────────────────────────────────────── */
.bbf-alert {
  padding:16px 22px;border-radius:var(--radius);
  font-size:15px;font-weight:600;
  margin-top:16px;
  display:none;
}

.bbf-alert.success { background:#D4F0D4; color:var(--green); }
.bbf-alert.error   { background:#fde8e8; color:#c0392b; }
.bbf-alert.show    { display:block; }

/* ── Animations ─────────────────────────────────────────────── */
@keyframes bbfFadeUp  { from{opacity:0;transform:translateY(40px)} to{opacity:1;transform:translateY(0)} }
@keyframes bbfFloat   { 0%,100%{transform:translateY(0) rotate(0deg)} 33%{transform:translateY(-20px) rotate(5deg)} 66%{transform:translateY(10px) rotate(-3deg)} }
@keyframes bbfBounce  { 0%,100%{transform:translateX(-50%) translateY(0)} 50%{transform:translateX(-50%) translateY(12px)} }

.bbf-fade-in {
  opacity:0;transform:translateY(30px);
  transition:opacity .7s ease, transform .7s ease;
}
.bbf-fade-in.is-visible { opacity:1; transform:none; }


/* Hero logo */
.hero-logo-wrap img {
  max-width:420px;
  width:88%;
  height:auto;
  display:block;
  margin:0 auto;
  filter:drop-shadow(0 4px 24px rgba(0,0,0,.5)) drop-shadow(0 0 60px rgba(255,255,255,.12));
  animation:bbfFadeUp .9s ease both;
}

/* Footer logo */
.footer-logo-img {
  max-width:180px;
  height:auto;
  filter:brightness(0) invert(1);
  opacity:.9;
}
/* ── Responsive ────────────────────────────────────────────── */
@media(max-width:1024px) {
  .sponsor-spotlight { grid-template-columns:1fr; }
  .sponsor-spotlight .spotlight-logo-box { height:130px; }
  .donate-why { grid-template-columns:1fr; }
  .contact-grid { grid-template-columns:1fr; }
  .footer-top { grid-template-columns:1fr 1fr; }
}

@media(max-width:768px) {
  section, .bbf-welcome, .bbf-attractions, .bbf-schedule,
  .bbf-pageant, .bbf-forms, .bbf-sponsors, .bbf-donate,
  .bbf-contact, .bbf-cta-strip { padding:60px 20px; }

  .bbf-form-box { padding:28px; }
  .rules-box { padding:28px; }
  .donate-why { padding:28px; }
  .donate-amounts { grid-template-columns:repeat(2,1fr); }
  .form-row { grid-template-columns:1fr; }
  .pageant-hero-block { padding:40px 24px; }
  .schedule-item { grid-template-columns:90px 1fr; }
  .schedule-badge { display:none; }
  .newsletter-form { flex-direction:column; }
  .deadline-banner { flex-direction:column; align-items:flex-start; }
  .contact-info { padding:28px; }
}

@media(max-width:480px) {
  .footer-top { grid-template-columns:1fr; }
  .countdown { gap:10px; }
  .countdown-unit { min-width:68px; padding:12px 14px; }
  .countdown-num { font-size:32px; }
  .donate-amounts { grid-template-columns:repeat(2,1fr); }
}

/* ── WordPress Core Alignment ──────────────────────────────── */
.wp-block-image { margin-bottom:1.5em; }
.alignfull { margin-left:calc(-50vw + 50%); margin-right:calc(-50vw + 50%); }
.alignwide { margin-left:-24px; margin-right:-24px; }
figcaption { font-size:13px; color:var(--text-light); text-align:center; margin-top:8px; }
