/*
Theme Name: Full Blooded Ìjẹ̀bú
Theme URI: https://fullbloodedijebu.com
Author: Timi Adegunwa / The Heritage Gateway
Description: Production WordPress theme for Full Blooded Ìjẹ̀bú — The only dedicated Ìjẹ̀bú heritage platform. Anton + DM Sans. Heritage Cream, Forest, Gold.
Version: 3.0.0
Requires at least: 6.2
Tested up to: 6.5
Requires PHP: 8.1
License: GNU General Public License v2 or later
Text Domain: fbi
Tags: custom-colors, custom-logo, featured-images, full-width-template, translation-ready
*/

/* ============================================================
   GOOGLE FONTS — Anton + DM Sans
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Anton&family=DM+Sans:ital,opsz,wght@0,9..40,200;0,9..40,300;0,9..40,400;0,9..40,500;1,9..40,300;1,9..40,400&display=swap');

/* ============================================================
   DESIGN TOKENS
   ============================================================ */
:root {
  --cream:        #F5EFE0;
  --cream-dark:   #EDE5CE;
  --cream-darker: #E0D6BC;
  --forest:       #0F2A1C;
  --forest-mid:   #1A3D29;
  --forest-lt:    #2A5A3C;
  --gold:         #BF8A20;
  --gold-lt:      #D4A83A;
  --gold-pale:    #EED898;
  --near-black:   #0A0A0A;
  --black:        #060606;
  --white:        #FFFFFF;
  --grey:         #7A7268;
  --grey-lt:      #B8B0A0;
  --grey-rule:    #D8D0BC;
  --font-display: 'Anton', 'Impact', sans-serif;
  --font-body:    'DM Sans', 'Helvetica Neue', Arial, sans-serif;
  --ease-out:     cubic-bezier(0.16, 1, 0.3, 1);
  --duration:     0.45s;
  --radius:       4px;
}

/* ============================================================
   RESET
   ============================================================ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { font-size: 16px; scroll-behavior: smooth; -webkit-font-smoothing: antialiased; }
body { font-family: var(--font-body); font-weight: 300; font-size: 1rem; line-height: 1.75; color: var(--forest); background: var(--cream); overflow-x: hidden; }
img, video { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; transition: color var(--duration) var(--ease-out); }
button, input, textarea, select { font-family: var(--font-body); }

/* ============================================================
   TYPOGRAPHY
   ============================================================ */
.t-display { font-family: var(--font-display); text-transform: uppercase; letter-spacing: 0.01em; line-height: 0.95; }
.t-display--xl  { font-size: clamp(56px, 7vw, 88px); }
.t-display--lg  { font-size: clamp(40px, 5vw, 64px); }
.t-display--md  { font-size: clamp(28px, 3.5vw, 44px); }
.t-display--sm  { font-size: clamp(20px, 2.5vw, 30px); }
.t-display--xs  { font-size: clamp(16px, 1.8vw, 22px); }
.t-label { font-family: var(--font-body); font-size: 0.6875rem; font-weight: 400; letter-spacing: 0.22em; text-transform: uppercase; line-height: 1; }
.t-body-lg { font-size: 1.0625rem; font-weight: 300; line-height: 1.82; }
.t-body    { font-size: 0.9375rem; font-weight: 300; line-height: 1.78; }
.t-body-sm { font-size: 0.8125rem; font-weight: 300; line-height: 1.72; }

/* ============================================================
   COLOURS
   ============================================================ */
.c-gold    { color: var(--gold); }
.c-forest  { color: var(--forest); }
.c-white   { color: var(--white); }
.c-grey    { color: var(--grey); }
.c-cream   { color: var(--cream); }
.bg-cream  { background: var(--cream); }
.bg-forest { background: var(--forest); }
.bg-black  { background: var(--near-black); }

/* ============================================================
   LAYOUT
   ============================================================ */
.container        { max-width: 1400px; margin: 0 auto; padding: 0 clamp(20px, 4vw, 80px); }
.container--narrow{ max-width: 860px;  margin: 0 auto; padding: 0 clamp(20px, 4vw, 80px); }
.section          { padding: clamp(60px, 8vw, 110px) 0; }
.section--sm      { padding: clamp(40px, 5vw, 70px) 0; }

/* ============================================================
   GOLD RULE
   ============================================================ */
.gold-rule { display: block; width: 48px; height: 2px; background: var(--gold); border: none; margin: 1.25rem 0; }
.gold-rule--center { margin-left: auto; margin-right: auto; }

/* ============================================================
   BUTTONS
   ============================================================ */
.btn {
  display: inline-flex; align-items: center; gap: 0.625rem;
  font-family: var(--font-body); font-size: 0.6875rem; font-weight: 500;
  letter-spacing: 0.18em; text-transform: uppercase;
  padding: 1rem 2rem; cursor: pointer; border: none;
  transition: all var(--duration) var(--ease-out);
  white-space: nowrap;
}
.btn--primary   { background: var(--forest); color: var(--gold); }
.btn--primary:hover { background: var(--forest-mid); transform: translateY(-2px); }
.btn--outline   { background: transparent; color: var(--forest); border: 1px solid var(--forest); }
.btn--outline:hover { background: var(--forest); color: var(--gold); }
.btn--gold      { background: var(--gold); color: var(--forest); }
.btn--gold:hover { background: var(--gold-lt); transform: translateY(-2px); }
.btn--ghost-cream { background: transparent; color: var(--cream); border: 1px solid rgba(245,239,224,0.4); }
.btn--ghost-cream:hover { border-color: var(--cream); background: rgba(245,239,224,0.06); }

/* ============================================================
   TOP BAR
   ============================================================ */
.top-bar { background: var(--forest); border-bottom: 1px solid rgba(191,138,32,0.2); height: 36px; display: flex; align-items: center; justify-content: space-between; padding: 0 clamp(20px,4vw,80px); }
.top-bar__left { font-family: var(--font-body); font-size: 0.625rem; letter-spacing: 0.16em; text-transform: uppercase; color: rgba(245,239,224,0.35); }
.top-bar__social-links { display: flex; gap: 1.25rem; }
.top-bar__social-link { font-family: var(--font-body); font-size: 0.625rem; letter-spacing: 0.12em; text-transform: uppercase; color: rgba(245,239,224,0.35); transition: color 0.3s; }
.top-bar__social-link:hover { color: var(--gold); }
@media (max-width: 600px) { .top-bar__left { display: none; } }

/* ============================================================
   NAVIGATION
   ============================================================ */
#masthead { background: var(--cream); border-bottom: 1px solid var(--grey-rule); position: sticky; top: 0; z-index: 900; transition: box-shadow 0.4s var(--ease-out), background 0.4s; }
#masthead.scrolled { background: rgba(245,239,224,0.96); backdrop-filter: blur(12px); box-shadow: 0 1px 28px rgba(15,42,28,0.08); }
.nav-inner { display: flex; align-items: center; justify-content: space-between; height: 72px; max-width: 1600px; margin: 0 auto; padding: 0 clamp(20px,4vw,80px); }

/* Logo */
.site-branding { display: flex; align-items: center; gap: 12px; flex-shrink: 0; }
.logo-mark { width: 40px; height: 40px; border: 1.5px solid var(--forest); border-radius: 50%; display: flex; align-items: center; justify-content: center; transition: border-color 0.3s; flex-shrink: 0; }
.logo-mark svg { width: 16px; height: 16px; }
.site-branding:hover .logo-mark { border-color: var(--gold); }
.site-name { font-family: var(--font-display); font-size: 17px; color: var(--forest); letter-spacing: 0.04em; text-transform: uppercase; display: block; line-height: 1.1; }
.site-tagline { font-family: var(--font-body); font-size: 0.5625rem; letter-spacing: 0.22em; text-transform: uppercase; color: var(--gold); font-weight: 400; display: block; }
.site-branding a { display: flex; align-items: center; gap: 12px; }

/* Primary menu */
#primary-nav { display: flex; align-items: center; }
#primary-menu { display: flex; list-style: none; margin: 0; padding: 0; gap: 0; }
#primary-menu > li { position: relative; }
#primary-menu > li > a { display: flex; align-items: center; height: 72px; padding: 0 11px; font-family: var(--font-body); font-size: 0.75rem; font-weight: 400; letter-spacing: 0.06em; color: var(--forest); position: relative; transition: color 0.3s; }
#primary-menu > li > a::after { content: ''; position: absolute; bottom: 0; left: 11px; right: 11px; height: 2px; background: var(--gold); transform: scaleX(0); transform-origin: left; transition: transform 0.3s var(--ease-out); }
#primary-menu > li > a:hover,
#primary-menu > li.current-menu-item > a { color: var(--forest); }
#primary-menu > li > a:hover::after,
#primary-menu > li.current-menu-item > a::after { transform: scaleX(1); }

/* Dropdown */
#primary-menu .sub-menu { display: none; position: absolute; top: 100%; left: 0; min-width: 220px; background: var(--cream); border-top: 2px solid var(--gold); border: 1px solid var(--grey-rule); border-top: 2px solid var(--gold); list-style: none; z-index: 999; }
#primary-menu li:hover > .sub-menu { display: block; }
#primary-menu .sub-menu li a { display: block; padding: 0.7rem 1.25rem; font-family: var(--font-body); font-size: 0.8125rem; font-weight: 300; color: var(--forest); border-bottom: 1px solid rgba(216,208,188,0.4); transition: background 0.2s, padding-left 0.25s; }
#primary-menu .sub-menu li:last-child a { border-bottom: none; }
#primary-menu .sub-menu li a:hover { background: var(--cream-dark); padding-left: 1.75rem; color: var(--gold); }

/* Mobile toggle */
.menu-toggle { display: none; background: none; border: 1px solid var(--forest); color: var(--forest); padding: 0.45rem 0.8rem; cursor: pointer; font-family: var(--font-body); font-size: 0.75rem; letter-spacing: 0.08em; transition: all 0.3s; }
.menu-toggle:hover { background: var(--forest); color: var(--gold); }

/* ============================================================
   HERO — SPLIT LAYOUT
   ============================================================ */
.hero { display: grid; grid-template-columns: 1fr 400px; min-height: calc(100vh - 108px); }

/* Left — cream editorial zone */
.hero__left { background: var(--cream); display: flex; align-items: center; padding: clamp(48px,7vw,100px) clamp(24px,5vw,80px); position: relative; overflow: hidden; }
.hero__left::before { content: ''; position: absolute; inset: 0; background-image: linear-gradient(45deg, rgba(15,42,28,0.025) 1px, transparent 1px), linear-gradient(-45deg, rgba(15,42,28,0.025) 1px, transparent 1px); background-size: 48px 48px; pointer-events: none; }
.hero__content { position: relative; z-index: 1; max-width: 600px; }
.hero__eyebrow { display: flex; align-items: center; gap: 1rem; margin-bottom: 2rem; }
.hero__eyebrow-line { display: block; width: 38px; height: 2px; background: var(--gold); flex-shrink: 0; }
.hero__headline { margin-bottom: 1.75rem; line-height: 0.94; }
.hero__headline-line { display: block; }
.hero__headline-outline { -webkit-text-stroke: 2px var(--forest); color: transparent; }
.hero__headline-gold { color: var(--gold); }
.hero__desc { font-size: 0.9375rem; font-weight: 300; color: var(--grey); line-height: 1.82; max-width: 480px; margin-bottom: 2.5rem; }
.hero__cta { display: flex; gap: 1rem; flex-wrap: wrap; }
.hero__scroll { position: absolute; bottom: 1.75rem; left: 50%; transform: translateX(-50%); display: flex; flex-direction: column; align-items: center; gap: 0.4rem; z-index: 2; }
.hero__scroll-line { width: 1px; height: 52px; background: linear-gradient(to bottom, var(--gold), transparent); animation: scrollPulse 2.2s ease-in-out infinite; }
@keyframes scrollPulse { 0%,100%{opacity:1;transform:scaleY(1)} 50%{opacity:0.3;transform:scaleY(0.6)} }

/* Right — forest green portrait zone */
.hero__right { background: var(--forest); position: relative; overflow: hidden; display: flex; flex-direction: column; }
.hero__photo { flex: 1; position: relative; overflow: hidden; min-height: 400px; }
.hero__photo img { width: 100%; height: 100%; object-fit: cover; object-position: top center; }
.hero__photo-pattern { position: absolute; inset: 0; background-image: repeating-linear-gradient(0deg, rgba(245,239,224,0.03) 0, rgba(245,239,224,0.03) 1px, transparent 1px, transparent 48px), repeating-linear-gradient(90deg, rgba(245,239,224,0.03) 0, rgba(245,239,224,0.03) 1px, transparent 1px, transparent 48px); }
.hero__photo-overlay { position: absolute; inset: 0; background: linear-gradient(to bottom, rgba(15,42,28,0) 35%, rgba(15,42,28,0.88) 100%); }
.hero__glow { position: absolute; top: 0; right: 0; width: 65%; height: 55%; background: radial-gradient(ellipse at 70% 30%, rgba(191,138,32,0.14) 0%, transparent 70%); pointer-events: none; }

/* Issue panel */
.hero__issue-panel { background: var(--near-black); border-top: 2px solid var(--gold); padding: 1.375rem 1.75rem; position: relative; z-index: 2; }
.hero__issue-label { font-family: var(--font-body); font-size: 0.5625rem; letter-spacing: 0.22em; text-transform: uppercase; color: var(--gold); font-weight: 400; margin-bottom: 0.5rem; }
.hero__issue-name { font-family: var(--font-display); font-size: 17px; color: var(--white); text-transform: uppercase; letter-spacing: 0.02em; line-height: 1.2; margin-bottom: 0.3rem; }
.hero__issue-role { font-family: var(--font-body); font-size: 0.75rem; font-weight: 300; color: rgba(255,255,255,0.42); letter-spacing: 0.05em; margin-bottom: 0.875rem; }
.hero__issue-link { display: inline-flex; align-items: center; gap: 0.7rem; font-family: var(--font-body); font-size: 0.5625rem; font-weight: 500; letter-spacing: 0.2em; text-transform: uppercase; color: var(--gold); transition: gap 0.3s var(--ease-out); }
.hero__issue-link::after { content: ''; display: block; width: 22px; height: 1px; background: var(--gold); transition: width 0.3s var(--ease-out); }
.hero__issue-link:hover { gap: 1rem; }
.hero__issue-link:hover::after { width: 36px; }

/* ============================================================
   DATA STRIP
   ============================================================ */
.data-strip { background: var(--forest); border-top: 2px solid var(--gold); border-bottom: 1px solid rgba(191,138,32,0.15); padding: 3rem 0; }
.data-strip__grid { display: grid; grid-template-columns: repeat(3,1fr); }
.data-item { text-align: center; padding: 0 2rem; position: relative; }
.data-item + .data-item::before { content: ''; position: absolute; left: 0; top: 15%; bottom: 15%; width: 1px; background: rgba(191,138,32,0.2); }
.data-item__number { font-family: var(--font-display); font-size: clamp(28px, 4vw, 50px); color: var(--gold); line-height: 1; display: block; margin-bottom: 0.5rem; text-transform: uppercase; letter-spacing: 0.02em; }
.data-item__label { font-family: var(--font-body); font-size: 0.5875rem; letter-spacing: 0.18em; text-transform: uppercase; color: rgba(245,239,224,0.38); font-weight: 400; line-height: 1.5; display: block; }

/* ============================================================
   3-COLUMN EDITORIAL GRID
   (Heritage Elegance + Sponsor + Ojúde Ọba / Sponsor)
   ============================================================ */
.editorial-grid-section { background: var(--cream); padding: clamp(60px,8vw,100px) 0; }
.editorial-grid-section__header { margin-bottom: 2.5rem; }
.editorial-grid-section__intro { font-size: 0.9375rem; font-weight: 300; color: var(--grey); max-width: 600px; margin-top: 0.75rem; }
.editorial-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 2px; }
.editorial-grid__view-all { display: flex; align-items: center; gap: 1.5rem; margin-top: 2.5rem; }
.editorial-grid__view-all-line { flex: 1; height: 1px; background: var(--grey-rule); }

/* HES Card */
.hes-card { position: relative; overflow: hidden; background: var(--forest); display: flex; flex-direction: column; min-height: 520px; }
.hes-card__photo { position: relative; overflow: hidden; flex: 1; }
.hes-card__photo img { width: 100%; height: 100%; object-fit: cover; object-position: top; transition: transform 0.8s var(--ease-out); }
.hes-card:hover .hes-card__photo img { transform: scale(1.04); }
.hes-card__photo-bg { width: 100%; height: 100%; min-height: 360px; background: linear-gradient(160deg, var(--forest-mid), var(--forest)); }
.hes-card__overlay { position: absolute; inset: 0; background: linear-gradient(to top, rgba(8,8,8,0.94) 0%, rgba(8,8,8,0.35) 45%, rgba(8,8,8,0) 70%); }
.hes-card__top-rule { position: absolute; top: 0; left: 0; right: 0; height: 3px; background: var(--gold); }
.hes-card__meta { position: absolute; bottom: 0; left: 0; right: 0; padding: 1.75rem; z-index: 2; }
.hes-card__issue { display: inline-flex; align-items: center; gap: 0.7rem; font-family: var(--font-body); font-size: 0.5625rem; letter-spacing: 0.22em; text-transform: uppercase; color: var(--gold); font-weight: 400; margin-bottom: 0.625rem; }
.hes-card__issue::before { content: ''; display: block; width: 22px; height: 1.5px; background: var(--gold); }
.hes-card__name { font-family: var(--font-display); font-size: clamp(16px,2vw,24px); color: var(--white); text-transform: uppercase; letter-spacing: 0.02em; line-height: 1.1; margin-bottom: 0.4rem; }
.hes-card__role { font-family: var(--font-body); font-size: 0.75rem; font-weight: 300; color: rgba(255,255,255,0.42); letter-spacing: 0.05em; margin-bottom: 1.1rem; }
.hes-card__read { display: inline-flex; align-items: center; gap: 0.7rem; font-family: var(--font-body); font-size: 0.5625rem; font-weight: 500; letter-spacing: 0.2em; text-transform: uppercase; color: var(--gold); transition: gap 0.3s var(--ease-out); }
.hes-card__read::after { content: ''; display: block; width: 22px; height: 1px; background: var(--gold); transition: width 0.3s var(--ease-out); }
.hes-card:hover .hes-card__read { gap: 1rem; }
.hes-card:hover .hes-card__read::after { width: 36px; }

/* Sponsor Panel */
.sponsor-panel { position: relative; overflow: hidden; background: var(--forest); min-height: 520px; display: flex; flex-direction: column; align-items: center; justify-content: center; border-top: 3px solid var(--gold); }
.sponsor-panel::before { content: ''; position: absolute; inset: 0; background-image: repeating-linear-gradient(45deg, rgba(191,138,32,0.06) 0, rgba(191,138,32,0.06) 1px, transparent 1px, transparent 32px); pointer-events: none; }
.sponsor-panel__bg { position: absolute; inset: 0; background: linear-gradient(160deg, var(--forest-mid) 0%, var(--forest) 100%); }
.sponsor-panel__corner { position: absolute; width: 24px; height: 24px; }
.sponsor-panel__corner--tl { top: 18px; left: 18px; border-top: 1px solid rgba(191,138,32,0.45); border-left: 1px solid rgba(191,138,32,0.45); }
.sponsor-panel__corner--tr { top: 18px; right: 18px; border-top: 1px solid rgba(191,138,32,0.45); border-right: 1px solid rgba(191,138,32,0.45); }
.sponsor-panel__corner--bl { bottom: 18px; left: 18px; border-bottom: 1px solid rgba(191,138,32,0.45); border-left: 1px solid rgba(191,138,32,0.45); }
.sponsor-panel__corner--br { bottom: 18px; right: 18px; border-bottom: 1px solid rgba(191,138,32,0.45); border-right: 1px solid rgba(191,138,32,0.45); }
.sponsor-panel__inner { position: relative; z-index: 2; text-align: center; padding: 2.5rem; }
.sponsor-panel__circle { width: 80px; height: 80px; border: 1px solid rgba(191,138,32,0.25); border-radius: 50%; margin: 0 auto 1.75rem; display: flex; align-items: center; justify-content: center; }
.sponsor-panel__circle-inner { width: 54px; height: 54px; border: 1px solid rgba(191,138,32,0.4); border-radius: 50%; }
.sponsor-panel__label { font-family: var(--font-body); font-size: 0.5625rem; letter-spacing: 0.26em; text-transform: uppercase; color: var(--gold); font-weight: 400; margin-bottom: 0.875rem; display: block; }
.sponsor-panel__rule { width: 40px; height: 1px; background: rgba(191,138,32,0.4); margin: 0 auto 1rem; }
.sponsor-panel__title { font-family: var(--font-display); font-size: clamp(16px,2vw,22px); color: rgba(255,255,255,0.85); text-transform: uppercase; letter-spacing: 0.02em; line-height: 1.2; margin-bottom: 1rem; }
.sponsor-panel__micro { font-family: var(--font-body); font-size: 0.75rem; font-weight: 300; color: rgba(255,255,255,0.38); line-height: 1.7; max-width: 240px; margin: 0 auto 1.5rem; }
.sponsor-panel__cta { font-family: var(--font-body); font-size: 0.5625rem; font-weight: 500; letter-spacing: 0.2em; text-transform: uppercase; color: var(--gold); }
/* Sponsor logo when filled */
.sponsor-panel__logo { max-width: 180px; max-height: 80px; margin: 0 auto; filter: brightness(0) invert(1); opacity: 0.9; }

/* Ojúde Ọba card in grid */
.ojude-card { position: relative; overflow: hidden; background: var(--forest-lt); min-height: 520px; display: flex; flex-direction: column; border-top: 3px solid var(--gold); cursor: pointer; transition: transform 0.4s var(--ease-out); }
.ojude-card:hover { transform: translateY(-3px); }
.ojude-card__bg { position: absolute; inset: 0; background: linear-gradient(160deg, var(--forest-lt) 0%, var(--forest) 100%); }
.ojude-card__pattern { position: absolute; inset: 0; background-image: repeating-linear-gradient(45deg, rgba(191,138,32,0.07) 0, rgba(191,138,32,0.07) 1px, transparent 1px, transparent 28px); }
.ojude-card__glow { position: absolute; top: 20%; left: 50%; transform: translateX(-50%); width: 200px; height: 200px; background: radial-gradient(ellipse, rgba(191,138,32,0.2) 0%, transparent 70%); }
.ojude-card__crown { position: absolute; top: 50%; left: 50%; transform: translate(-50%,-70%); opacity: 0.35; }
.ojude-card__overlay { position: absolute; inset: 0; background: linear-gradient(to top, rgba(8,8,8,0.95) 0%, rgba(8,8,8,0.3) 55%, rgba(8,8,8,0) 75%); }
.ojude-card__meta { position: absolute; bottom: 0; left: 0; right: 0; padding: 1.75rem; z-index: 2; }
.ojude-card__label { font-family: var(--font-body); font-size: 0.5625rem; letter-spacing: 0.22em; text-transform: uppercase; color: var(--gold); font-weight: 400; margin-bottom: 0.5rem; display: flex; align-items: center; gap: 0.7rem; }
.ojude-card__label::before { content: ''; display: block; width: 22px; height: 1.5px; background: var(--gold); }
.ojude-card__divider { height: 1px; background: rgba(191,138,32,0.3); margin-bottom: 1rem; }
.ojude-card__title { font-family: var(--font-display); font-size: clamp(18px,2.2vw,26px); color: var(--white); text-transform: uppercase; letter-spacing: 0.02em; line-height: 1.1; margin-bottom: 0.5rem; }
.ojude-card__location { font-family: var(--font-body); font-size: 0.75rem; font-weight: 300; color: rgba(255,255,255,0.45); margin-bottom: 1.1rem; }
.ojude-card__link { display: inline-flex; align-items: center; gap: 0.7rem; font-family: var(--font-body); font-size: 0.5625rem; font-weight: 500; letter-spacing: 0.2em; text-transform: uppercase; color: var(--gold); transition: gap 0.3s; }
.ojude-card__link::after { content: ''; display: block; width: 22px; height: 1px; background: var(--gold); transition: width 0.3s; }
.ojude-card:hover .ojude-card__link { gap: 1rem; }
.ojude-card:hover .ojude-card__link::after { width: 36px; }

/* ============================================================
   WHY FBI — 2-column
   ============================================================ */
.why-fbi { background: var(--cream-dark); border-top: 1px solid var(--grey-rule); border-bottom: 1px solid var(--grey-rule); padding: clamp(60px,8vw,100px) 0; }
.why-fbi__inner { display: grid; grid-template-columns: 1fr 1fr; gap: 5rem; align-items: start; }
.why-fbi__body { font-size: 0.9375rem; font-weight: 300; color: var(--grey); line-height: 1.85; margin-bottom: 1rem; }
.why-fbi__pillars { display: grid; grid-template-columns: 1fr 1fr; gap: 0; border-top: 1px solid var(--grey-rule); border-left: 1px solid var(--grey-rule); margin-top: 2rem; }
.why-fbi__pillar { padding: 1.5rem; border-right: 1px solid var(--grey-rule); border-bottom: 1px solid var(--grey-rule); position: relative; overflow: hidden; transition: background 0.35s; }
.why-fbi__pillar::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px; background: var(--gold); transform: scaleX(0); transform-origin: left; transition: transform 0.4s var(--ease-out); }
.why-fbi__pillar:hover { background: var(--cream); }
.why-fbi__pillar:hover::before { transform: scaleX(1); }
.why-fbi__pillar-title { font-family: var(--font-body); font-size: 0.875rem; font-weight: 500; color: var(--forest); margin-bottom: 0.5rem; letter-spacing: 0.02em; }
.why-fbi__pillar-body { font-family: var(--font-body); font-size: 0.8125rem; font-weight: 300; color: var(--grey); line-height: 1.7; margin: 0; }

/* Why FBI right sponsor panel */
.why-fbi__sponsor { position: relative; }

/* ============================================================
   PARTNER WITH US
   ============================================================ */
.partner-section { background: var(--cream); padding: clamp(60px,8vw,100px) 0; }
.partner-section__intro { font-size: 0.9375rem; font-weight: 300; color: var(--grey); max-width: 640px; margin-top: 0.75rem; line-height: 1.82; }
.partner-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 0; border-top: 1px solid var(--grey-rule); border-left: 1px solid var(--grey-rule); margin-top: 3rem; }
.partner-card { padding: 2.5rem 2rem; border-right: 1px solid var(--grey-rule); border-bottom: 1px solid var(--grey-rule); position: relative; overflow: hidden; transition: background 0.35s; }
.partner-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px; background: var(--gold); transform: scaleX(0); transform-origin: left; transition: transform 0.45s var(--ease-out); }
.partner-card:hover { background: var(--cream-dark); }
.partner-card:hover::before { transform: scaleX(1); }
.partner-card__number { font-family: var(--font-display); font-size: 54px; color: rgba(15,42,28,0.07); line-height: 1; margin-bottom: 1.25rem; display: block; }
.partner-card__rule { display: block; width: 32px; height: 2px; background: var(--gold); margin-bottom: 1rem; }
.partner-card__title { font-family: var(--font-body); font-size: 0.9375rem; font-weight: 500; color: var(--forest); margin-bottom: 0.625rem; line-height: 1.4; letter-spacing: 0.02em; }
.partner-card__desc { font-family: var(--font-body); font-size: 0.8125rem; font-weight: 300; color: var(--grey); line-height: 1.78; margin-bottom: 1.5rem; }
.partner-card__link { display: inline-flex; align-items: center; gap: 0.625rem; font-family: var(--font-body); font-size: 0.5625rem; font-weight: 500; letter-spacing: 0.2em; text-transform: uppercase; color: var(--gold); transition: gap 0.3s; }
.partner-card__link::after { content: ''; display: block; width: 18px; height: 1px; background: var(--gold); transition: width 0.3s; }
.partner-card:hover .partner-card__link { gap: 0.875rem; }
.partner-card:hover .partner-card__link::after { width: 28px; }

/* ============================================================
   FULL BLOODED LIVE
   ============================================================ */
.fbl-section { background: var(--near-black); border-top: 2px solid var(--gold); padding: clamp(60px,8vw,100px) 0; }
.fbl-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 2px; margin-top: 3rem; }
.fbl-card { position: relative; overflow: hidden; background: var(--forest); cursor: pointer; }
.fbl-card__thumb { position: relative; overflow: hidden; aspect-ratio: 16/9; }
.fbl-card__thumb img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.7s var(--ease-out); opacity: 0.7; }
.fbl-card:hover .fbl-card__thumb img { transform: scale(1.05); opacity: 0.88; }
.fbl-card__thumb-bg { width: 100%; height: 100%; background: linear-gradient(150deg, var(--forest-mid), var(--forest)); }
.fbl-card__overlay { position: absolute; inset: 0; background: rgba(0,0,0,0.32); transition: background 0.35s; }
.fbl-card:hover .fbl-card__overlay { background: rgba(0,0,0,0.16); }
.fbl-card__play { position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%) scale(0.9); width: 50px; height: 50px; border: 1.5px solid var(--gold); border-radius: 50%; display: flex; align-items: center; justify-content: center; transition: transform 0.35s var(--ease-out), background 0.35s; z-index: 2; }
.fbl-card__play-icon { width: 0; height: 0; border-top: 9px solid transparent; border-bottom: 9px solid transparent; border-left: 15px solid var(--gold); margin-left: 4px; }
.fbl-card:hover .fbl-card__play { transform: translate(-50%,-50%) scale(1.06); background: rgba(191,138,32,0.14); }
.fbl-card__duration { position: absolute; bottom: 9px; right: 12px; font-family: var(--font-body); font-size: 0.6875rem; color: rgba(255,255,255,0.5); z-index: 2; }
.fbl-card__body { padding: 1.375rem; border-top: 2px solid var(--gold); }
.fbl-card__tag { font-family: var(--font-body); font-size: 0.5625rem; letter-spacing: 0.22em; text-transform: uppercase; color: var(--gold); font-weight: 400; margin-bottom: 0.45rem; }
.fbl-card__title { font-family: var(--font-body); font-size: 0.9375rem; font-weight: 400; color: var(--white); line-height: 1.5; margin-bottom: 0.3rem; }
.fbl-card__meta { font-family: var(--font-body); font-size: 0.75rem; font-weight: 300; color: rgba(255,255,255,0.28); }

/* ============================================================
   EQUESTRIAN & ROYAL
   ============================================================ */
.equestrian { display: grid; grid-template-columns: 1fr 1fr; }
.equestrian__photo { position: relative; overflow: hidden; background: var(--forest); min-height: 520px; }
.equestrian__photo img { width: 100%; height: 100%; object-fit: cover; object-position: center; transition: transform 0.8s var(--ease-out); }
.equestrian:hover .equestrian__photo img { transform: scale(1.03); }
.equestrian__photo-placeholder { width: 100%; height: 100%; min-height: 520px; background: linear-gradient(160deg, var(--forest-mid), var(--forest)); display: flex; align-items: center; justify-content: center; }
.equestrian__photo-placeholder-inner { text-align: center; }
.equestrian__photo-placeholder-frame { width: 180px; height: 140px; border: 1px solid rgba(191,138,32,0.3); margin: 0 auto 1rem; position: relative; display: flex; align-items: center; justify-content: center; }
.equestrian__photo-placeholder-frame::before,
.equestrian__photo-placeholder-frame::after { content: ''; position: absolute; width: 20px; height: 20px; }
.equestrian__photo-placeholder-frame::before { top: -1px; left: -1px; border-top: 2px solid rgba(191,138,32,0.6); border-left: 2px solid rgba(191,138,32,0.6); }
.equestrian__photo-placeholder-frame::after { bottom: -1px; right: -1px; border-bottom: 2px solid rgba(191,138,32,0.6); border-right: 2px solid rgba(191,138,32,0.6); }
.equestrian__placeholder-icon { color: rgba(191,138,32,0.5); font-size: 2rem; margin-bottom: 0.5rem; }
.equestrian__placeholder-label { font-family: var(--font-body); font-size: 0.5625rem; letter-spacing: 0.22em; text-transform: uppercase; color: rgba(191,138,32,0.5); font-weight: 400; }
.equestrian__placeholder-note { font-family: var(--font-body); font-size: 0.5625rem; letter-spacing: 0.14em; text-transform: uppercase; color: rgba(191,138,32,0.3); font-weight: 400; margin-top: 0.75rem; }
.equestrian__text { padding: clamp(48px,6vw,88px); display: flex; flex-direction: column; justify-content: center; background: var(--cream); }
.equestrian__subtitle { font-family: var(--font-body); font-size: 0.9375rem; font-style: italic; font-weight: 300; color: var(--grey-lt); margin-bottom: 1.5rem; margin-top: 0.25rem; }
.equestrian__body { font-size: 0.9375rem; font-weight: 300; color: var(--grey); line-height: 1.85; margin-bottom: 1.75rem; }
.equestrian__list { list-style: none; margin-bottom: 2.25rem; }
.equestrian__list li { display: flex; align-items: flex-start; gap: 0.75rem; padding: 0.55rem 0; border-bottom: 1px solid var(--grey-rule); font-family: var(--font-body); font-size: 0.875rem; font-weight: 300; color: var(--grey); line-height: 1.5; }
.equestrian__list li::before { content: '◆'; color: var(--gold); font-size: 0.4375rem; margin-top: 0.45rem; flex-shrink: 0; }

/* ============================================================
   INSTAGRAM FEED STRIP
   ============================================================ */
.instagram-strip { background: var(--cream-dark); border-top: 1px solid var(--grey-rule); border-bottom: 1px solid var(--grey-rule); padding: clamp(48px,6vw,80px) 0; }
.instagram-grid { display: grid; grid-template-columns: repeat(6,1fr); gap: 3px; margin-top: 2.5rem; }
.instagram-tile { position: relative; overflow: hidden; aspect-ratio: 1/1; background: var(--forest); }
.instagram-tile img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.5s var(--ease-out), opacity 0.35s; opacity: 0.85; }
.instagram-tile:hover img { transform: scale(1.06); opacity: 1; }
.instagram-tile__overlay { position: absolute; inset: 0; background: rgba(15,42,28,0.3); transition: background 0.35s; }
.instagram-tile:hover .instagram-tile__overlay { background: rgba(15,42,28,0.1); }
.instagram-tile__placeholder { width: 100%; height: 100%; background: linear-gradient(150deg, var(--forest-mid), var(--forest)); display: flex; align-items: center; justify-content: center; }
.instagram-tile__placeholder-icon { color: rgba(191,138,32,0.3); font-size: 1.25rem; }
.instagram-strip__footer { display: flex; justify-content: flex-end; margin-top: 1rem; }

/* ============================================================
   NEWSLETTER
   ============================================================ */
.newsletter { background: var(--forest-mid); border-top: 2px solid var(--gold); padding: clamp(48px,6vw,80px) 0; }
.newsletter__inner { display: grid; grid-template-columns: 1fr 1fr; gap: 5rem; align-items: center; }
.newsletter__title { color: var(--white); margin: 1rem 0 0.4rem; }
.newsletter__body { font-size: 0.9375rem; font-weight: 300; color: rgba(245,239,224,0.42); line-height: 1.82; }
.newsletter-form { display: flex; flex-direction: column; gap: 0.875rem; }
.newsletter-form__row { display: flex; }
.newsletter-form__input { flex: 1; background: rgba(245,239,224,0.05); border: 1px solid rgba(191,138,32,0.22); border-right: none; color: var(--cream); font-family: var(--font-body); font-size: 0.875rem; font-weight: 300; padding: 0.95rem 1.125rem; outline: none; transition: border-color 0.3s; }
.newsletter-form__input::placeholder { color: rgba(245,239,224,0.28); }
.newsletter-form__input:focus { border-color: rgba(191,138,32,0.55); }
.newsletter-form__btn { background: var(--gold); color: var(--forest); border: none; padding: 0.95rem 1.625rem; font-family: var(--font-body); font-size: 0.5875rem; font-weight: 500; letter-spacing: 0.18em; text-transform: uppercase; cursor: pointer; transition: background 0.3s; white-space: nowrap; }
.newsletter-form__btn:hover { background: var(--gold-lt); }
.newsletter-form__note { font-family: var(--font-body); font-size: 0.6875rem; font-weight: 300; color: rgba(245,239,224,0.22); }

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer { background: var(--black); border-top: 2px solid var(--gold); }
.footer__upper { padding: clamp(48px,6vw,72px) 0 clamp(36px,5vw,56px); }
.footer__grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 3.5rem; }
.footer__brand-name { font-family: var(--font-display); font-size: 20px; color: var(--white); text-transform: uppercase; letter-spacing: 0.04em; display: block; margin-bottom: 3px; }
.footer__brand-tagline { font-family: var(--font-body); font-size: 0.5625rem; letter-spacing: 0.22em; text-transform: uppercase; color: var(--gold); font-weight: 400; margin-bottom: 1rem; display: block; }
.footer__brand-about { font-family: var(--font-body); font-size: 0.8125rem; font-weight: 300; color: rgba(245,239,224,0.28); line-height: 1.8; margin-bottom: 1.5rem; }
.footer__social { display: flex; gap: 0.75rem; }
.footer__social-link { width: 30px; height: 30px; border: 1px solid rgba(191,138,32,0.2); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-family: var(--font-body); font-size: 0.5875rem; color: rgba(245,239,224,0.32); transition: border-color 0.3s, color 0.3s; }
.footer__social-link:hover { border-color: var(--gold); color: var(--gold); }
.footer__col-title { font-family: var(--font-body); font-size: 0.6875rem; font-weight: 500; letter-spacing: 0.14em; text-transform: uppercase; color: rgba(245,239,224,0.45); margin-bottom: 1.125rem; padding-bottom: 0.7rem; border-bottom: 1px solid rgba(191,138,32,0.14); display: block; }
.footer__menu { list-style: none; }
.footer__menu li { margin-bottom: 0.55rem; }
.footer__menu a { font-family: var(--font-body); font-size: 0.8125rem; font-weight: 300; color: rgba(245,239,224,0.28); transition: color 0.3s, padding-left 0.3s var(--ease-out); display: block; }
.footer__menu a:hover { color: var(--gold); padding-left: 5px; }
.footer__lower { border-top: 1px solid rgba(255,255,255,0.05); padding: 1.375rem 0; display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 0.75rem; }
.footer__closing { width: 100%; text-align: center; font-family: var(--font-body); font-size: 0.6875rem; letter-spacing: 0.12em; color: rgba(191,138,32,0.45); padding-bottom: 1rem; border-bottom: 1px solid rgba(255,255,255,0.04); margin-bottom: 0.75rem; }
.footer__copy { font-family: var(--font-body); font-size: 0.6875rem; font-weight: 300; color: rgba(245,239,224,0.18); }
.footer__trademark { font-family: var(--font-body); font-size: 0.625rem; font-weight: 300; color: rgba(191,138,32,0.32); letter-spacing: 0.06em; }

/* ============================================================
   PAGE HERO (interior pages)
   ============================================================ */
.page-hero { background: var(--forest); padding: clamp(48px,7vw,88px) 0 clamp(36px,5vw,64px); border-bottom: 2px solid var(--gold); }
.page-hero__eyebrow { margin-bottom: 0.875rem; }
.page-hero__title { color: var(--white); margin-bottom: 0.875rem; }
.page-hero__desc { font-family: var(--font-body); font-size: 1rem; font-weight: 300; color: rgba(245,239,224,0.48); max-width: 580px; line-height: 1.82; }

/* ============================================================
   BREADCRUMB
   ============================================================ */
.breadcrumb-bar { background: var(--cream-dark); padding: 0.8rem 0; border-bottom: 1px solid var(--grey-rule); }
.breadcrumb { display: flex; align-items: center; gap: 0.45rem; font-family: var(--font-body); font-size: 0.75rem; font-weight: 300; color: var(--grey-lt); flex-wrap: wrap; }
.breadcrumb a { color: var(--gold); transition: color 0.3s; }
.breadcrumb a:hover { color: var(--gold-lt); }
.breadcrumb__sep { color: var(--grey-rule); }

/* ============================================================
   OJÚDE ỌBA PAGE
   ============================================================ */
.ojude-hero { position: relative; min-height: 88vh; display: flex; align-items: flex-end; overflow: hidden; background: var(--forest); }
.ojude-hero__photo { position: absolute; inset: 0; }
.ojude-hero__photo img { width: 100%; height: 100%; object-fit: cover; object-position: center; }
.ojude-hero__overlay { position: absolute; inset: 0; background: linear-gradient(to top, rgba(8,8,8,0.96) 0%, rgba(8,8,8,0.5) 45%, rgba(8,8,8,0.15) 100%); }
.ojude-hero__pattern { position: absolute; inset: 0; background-image: repeating-linear-gradient(45deg, rgba(191,138,32,0.04) 0, rgba(191,138,32,0.04) 1px, transparent 1px, transparent 48px); }
.ojude-hero__content { position: relative; z-index: 2; padding: 0 clamp(20px,4vw,80px) clamp(56px,8vw,96px); max-width: 1400px; width: 100%; }
.ojude-hero__eyebrow { display: flex; align-items: center; gap: 1rem; margin-bottom: 1.75rem; }
.ojude-hero__eyebrow-line { display: block; width: 36px; height: 2px; background: var(--gold); }
.ojude-hero__title { color: var(--white); margin-bottom: 1rem; line-height: 0.9; }
.ojude-hero__sub { font-family: var(--font-body); font-size: 1rem; font-weight: 300; color: rgba(245,239,224,0.6); max-width: 560px; line-height: 1.82; margin-bottom: 1.75rem; }
.ojude-hero__date { display: flex; align-items: center; gap: 1rem; margin-bottom: 2rem; }
.ojude-hero__date-badge { background: var(--gold); color: var(--forest); font-family: var(--font-display); font-size: 14px; padding: 0.5rem 1.125rem; text-transform: uppercase; letter-spacing: 0.04em; }
.ojude-hero__date-text { font-family: var(--font-body); font-size: 0.875rem; font-weight: 300; color: rgba(245,239,224,0.55); letter-spacing: 0.06em; }
.ojude-hero__cta { display: flex; gap: 1rem; flex-wrap: wrap; }

/* Countdown */
.countdown { background: var(--forest); border-bottom: 1px solid rgba(191,138,32,0.2); padding: 2.5rem 0; }
.countdown__inner { display: flex; align-items: center; justify-content: center; gap: 0; }
.countdown__block { text-align: center; padding: 0 3rem; position: relative; }
.countdown__block + .countdown__block::before { content: ''; position: absolute; left: 0; top: 15%; bottom: 15%; width: 1px; background: rgba(191,138,32,0.2); }
.countdown__number { font-family: var(--font-display); font-size: clamp(36px,5vw,60px); color: var(--gold); line-height: 1; display: block; }
.countdown__label { font-family: var(--font-body); font-size: 0.5625rem; letter-spacing: 0.22em; text-transform: uppercase; color: rgba(245,239,224,0.35); margin-top: 0.4rem; display: block; }

/* Festival content sections */
.festival-section { padding: clamp(56px,7vw,96px) 0; }
.festival-two-col { display: grid; grid-template-columns: 1fr 1fr; gap: 5rem; align-items: center; }
.festival-photo { position: relative; overflow: hidden; aspect-ratio: 4/5; background: var(--forest); }
.festival-photo img { width: 100%; height: 100%; object-fit: cover; }
.festival-body { font-size: 0.9375rem; font-weight: 300; color: var(--grey); line-height: 1.9; margin-bottom: 1.1rem; }
.festival-info-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 2px; margin-top: 3rem; }
.festival-info-card { background: var(--cream-dark); padding: 2rem 1.75rem; border-top: 2px solid var(--gold); }
.festival-info-card__label { font-family: var(--font-body); font-size: 0.5625rem; letter-spacing: 0.22em; text-transform: uppercase; color: var(--gold); font-weight: 400; margin-bottom: 0.625rem; display: block; }
.festival-info-card__value { font-family: var(--font-display); font-size: clamp(18px,2.5vw,28px); color: var(--forest); text-transform: uppercase; letter-spacing: 0.02em; line-height: 1.15; }

/* Gallery */
.festival-gallery { display: grid; grid-template-columns: repeat(3,1fr); gap: 3px; }
.festival-gallery__item { position: relative; overflow: hidden; aspect-ratio: 4/3; background: var(--forest); cursor: pointer; }
.festival-gallery__item img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.6s var(--ease-out); }
.festival-gallery__item:hover img { transform: scale(1.05); }
.festival-gallery__item--wide { grid-column: span 2; aspect-ratio: 8/3; }

/* Regberegbe families */
.regberegbe-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 2px; margin-top: 3rem; }
.regberegbe-card { background: var(--cream-dark); border-top: 2px solid var(--gold); padding: 2rem 1.75rem; }
.regberegbe-card__name { font-family: var(--font-display); font-size: clamp(16px,2vw,22px); color: var(--forest); text-transform: uppercase; margin-bottom: 0.4rem; }
.regberegbe-card__desc { font-family: var(--font-body); font-size: 0.8125rem; font-weight: 300; color: var(--grey); line-height: 1.7; }

/* Festival sponsorship CTA */
.festival-sponsor-cta { background: var(--forest); border-top: 2px solid var(--gold); padding: clamp(56px,7vw,96px) 0; }
.festival-sponsor-cta__inner { max-width: 720px; margin: 0 auto; text-align: center; }
.festival-sponsor-cta__title { color: var(--white); margin-bottom: 1rem; }
.festival-sponsor-cta__body { font-size: 0.9375rem; font-weight: 300; color: rgba(245,239,224,0.45); line-height: 1.85; margin-bottom: 2.5rem; }
.festival-sponsor-cta__cta { display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap; }

/* ============================================================
   SINGLE CONTENT PAGES
   ============================================================ */
.entry-layout { display: grid; grid-template-columns: 1fr 300px; gap: 4rem; align-items: start; }
.entry-content { font-size: 1.0625rem; font-weight: 300; line-height: 1.88; color: #2a2a28; }
.entry-content h2 { font-family: var(--font-display); color: var(--forest); margin: 2.5rem 0 1rem; text-transform: uppercase; font-size: clamp(22px,3vw,36px); }
.entry-content h3 { font-family: var(--font-display); color: var(--forest); margin: 2rem 0 0.875rem; text-transform: uppercase; font-size: clamp(18px,2.2vw,26px); }
.entry-content p { margin-bottom: 1.375rem; }
.entry-content blockquote { border-left: 2px solid var(--gold); padding: 1.125rem 1.625rem; background: var(--cream-dark); margin: 2.25rem 0; font-size: 1.0625rem; font-weight: 300; font-style: italic; color: var(--forest); line-height: 1.7; }
.sidebar { padding-top: 0.5rem; }
.widget { background: var(--cream-dark); padding: 1.625rem; margin-bottom: 1.75rem; border-top: 2px solid var(--gold); }
.widget-title { font-family: var(--font-display); font-size: 18px; color: var(--forest); text-transform: uppercase; letter-spacing: 0.03em; margin-bottom: 1.125rem; }

/* HES Single */
.hes-single-header { background: var(--forest); padding: clamp(48px,7vw,88px) 0 clamp(36px,5vw,56px); border-bottom: 2px solid var(--gold); }
.hes-issue-badge { display: inline-flex; align-items: center; gap: 0.75rem; font-family: var(--font-body); font-size: 0.5625rem; letter-spacing: 0.24em; text-transform: uppercase; color: var(--gold); font-weight: 400; margin-bottom: 1.125rem; }
.hes-issue-badge::before { content: ''; display: block; width: 30px; height: 1.5px; background: var(--gold); }
.hes-single-body { display: grid; grid-template-columns: 340px 1fr; gap: 5rem; padding: clamp(48px,6vw,88px) 0; }
.hes-profile-photo { position: sticky; top: 90px; }
.hes-profile-photo img { width: 100%; aspect-ratio: 3/4; object-fit: cover; object-position: top; border-top: 3px solid var(--gold); }

/* Archive grids */
.blog-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 2px; }
.blog-card { background: var(--cream); overflow: hidden; transition: transform 0.4s var(--ease-out); }
.blog-card:hover { transform: translateY(-4px); }
.blog-card__photo { position: relative; overflow: hidden; aspect-ratio: 3/2; background: var(--forest-mid); }
.blog-card__photo img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.6s var(--ease-out); }
.blog-card:hover .blog-card__photo img { transform: scale(1.05); }
.blog-card__body { padding: 1.5rem; border-top: 2px solid var(--gold); }
.blog-card__cat { font-family: var(--font-body); font-size: 0.5625rem; letter-spacing: 0.22em; text-transform: uppercase; color: var(--gold); font-weight: 400; margin-bottom: 0.5rem; }
.blog-card__title { font-family: var(--font-body); font-size: 0.9375rem; font-weight: 400; color: var(--forest); line-height: 1.5; margin-bottom: 0.625rem; }
.blog-card__excerpt { font-family: var(--font-body); font-size: 0.8125rem; font-weight: 300; color: var(--grey); line-height: 1.72; margin-bottom: 1rem; }
.blog-card__meta { font-family: var(--font-body); font-size: 0.6875rem; font-weight: 300; color: var(--grey-lt); }

/* Contact */
.contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 6rem; padding: clamp(56px,7vw,96px) 0; }
.contact-detail { display: flex; gap: 1.125rem; padding: 1.125rem 0; border-bottom: 1px solid rgba(245,239,224,0.07); }
.contact-detail__icon { color: var(--gold); font-size: 1rem; margin-top: 0.1rem; flex-shrink: 0; }
.contact-detail__label { font-family: var(--font-body); font-size: 0.5625rem; letter-spacing: 0.18em; text-transform: uppercase; color: rgba(245,239,224,0.28); font-weight: 400; margin-bottom: 0.15rem; }
.contact-detail__value { font-family: var(--font-body); font-size: 0.9rem; font-weight: 300; color: var(--cream); }
.contact-form input, .contact-form textarea,
.wpcf7-form input, .wpcf7-form textarea { width: 100%; background: transparent; border: none; border-bottom: 1px solid rgba(191,138,32,0.25); color: var(--cream); font-family: var(--font-body); font-size: 0.9rem; font-weight: 300; padding: 0.875rem 0; margin-bottom: 1.375rem; outline: none; transition: border-color 0.3s; }
.contact-form input:focus, .contact-form textarea:focus,
.wpcf7-form input:focus, .wpcf7-form textarea:focus { border-bottom-color: var(--gold); }
.contact-form input::placeholder, .contact-form textarea::placeholder,
.wpcf7-form input::placeholder, .wpcf7-form textarea::placeholder { color: rgba(245,239,224,0.22); letter-spacing: 0.04em; }
.contact-form textarea, .wpcf7-form textarea { min-height: 120px; resize: vertical; }

/* 404 */
.error-404 { min-height: 72vh; background: var(--forest); display: flex; align-items: center; justify-content: center; text-align: center; padding: 4rem 1.5rem; }
.error-404__number { font-family: var(--font-display); font-size: clamp(100px,16vw,200px); color: rgba(191,138,32,0.1); line-height: 1; display: block; }
.error-404__title { color: var(--white); margin-bottom: 0.875rem; }
.error-404__desc { font-family: var(--font-body); font-size: 0.9375rem; font-weight: 300; color: rgba(245,239,224,0.42); max-width: 400px; margin: 0 auto 2.25rem; line-height: 1.82; }

/* Pagination */
.pagination { display: flex; justify-content: center; gap: 0.4rem; margin: 3.5rem 0; }
.page-numbers { display: inline-flex; align-items: center; justify-content: center; width: 42px; height: 42px; border: 1px solid var(--grey-rule); font-family: var(--font-body); font-size: 0.875rem; font-weight: 300; color: var(--forest); transition: all 0.3s; }
.page-numbers:hover, .page-numbers.current { background: var(--forest); border-color: var(--forest); color: var(--gold); }

/* Search form */
.search-form { display: flex; border-bottom: 1px solid var(--forest); }
.search-field { flex: 1; background: transparent; border: none; outline: none; font-family: var(--font-body); font-size: 0.9rem; font-weight: 300; color: var(--forest); padding: 0.7rem 0; }
.search-field::placeholder { color: var(--grey-lt); }
.search-submit { background: none; border: none; color: var(--gold); cursor: pointer; font-family: var(--font-body); font-size: 0.5875rem; font-weight: 500; letter-spacing: 0.16em; text-transform: uppercase; padding: 0.7rem 0 0.7rem 1rem; transition: color 0.3s; }
.search-submit:hover { color: var(--gold-lt); }

/* Reveal animations */
.reveal { opacity: 0; transform: translateY(26px); transition: opacity 0.8s var(--ease-out), transform 0.8s var(--ease-out); }
.reveal.revealed { opacity: 1; transform: translateY(0); }
.reveal-delay-1 { transition-delay: 0.1s; }
.reveal-delay-2 { transition-delay: 0.2s; }
.reveal-delay-3 { transition-delay: 0.3s; }
.reveal-delay-4 { transition-delay: 0.4s; }

/* Accessibility */
.screen-reader-text { clip: rect(1px,1px,1px,1px); height: 1px; overflow: hidden; position: absolute; white-space: nowrap; width: 1px; }
.screen-reader-text:focus { clip: auto; height: auto; left: 6px; top: 7px; width: auto; z-index: 100000; background: var(--cream); padding: 1rem; font-size: 0.875rem; color: var(--forest); }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1100px) {
  .hero { grid-template-columns: 1fr 340px; }
  .footer__grid { grid-template-columns: 1fr 1fr; gap: 2.5rem; }
  .editorial-grid { grid-template-columns: 1fr 1fr; }
  .editorial-grid .editorial-grid__item:last-child { display: none; }
  .instagram-grid { grid-template-columns: repeat(4,1fr); }
  .instagram-grid .instagram-tile:nth-child(n+5) { display: none; }
}

@media (max-width: 900px) {
  .hero { grid-template-columns: 1fr; }
  .hero__right { min-height: 380px; }
  .equestrian { grid-template-columns: 1fr; }
  .equestrian__photo { min-height: 380px; }
  .why-fbi__inner { grid-template-columns: 1fr; gap: 3rem; }
  .newsletter__inner { grid-template-columns: 1fr; gap: 3rem; }
  .contact-grid { grid-template-columns: 1fr; gap: 3rem; }
  .festival-two-col { grid-template-columns: 1fr; gap: 3rem; }
  .hes-single-body { grid-template-columns: 1fr; }
  .entry-layout { grid-template-columns: 1fr; }
  .fbl-grid { grid-template-columns: 1fr 1fr; }
  .partner-grid { grid-template-columns: 1fr 1fr; }
  .regberegbe-grid { grid-template-columns: 1fr 1fr; }
  .festival-info-grid { grid-template-columns: 1fr; }
  .festival-gallery { grid-template-columns: 1fr 1fr; }
  .festival-gallery__item--wide { grid-column: span 1; aspect-ratio: 4/3; }
  .data-strip__grid { grid-template-columns: 1fr; gap: 2rem; }
  .data-item + .data-item::before { display: none; }
  .countdown__inner { flex-wrap: wrap; gap: 1rem; }
  .countdown__block { padding: 0 1.5rem; }
}

@media (max-width: 768px) {
  #primary-nav { display: none; }
  #primary-nav.is-open { display: flex; flex-direction: column; position: fixed; inset: 108px 0 0; background: var(--cream); z-index: 800; overflow-y: auto; padding: 1.5rem clamp(20px,4vw,80px); }
  #primary-nav.is-open #primary-menu { flex-direction: column; }
  #primary-nav.is-open #primary-menu > li > a { height: auto; padding: 0.875rem 0; border-bottom: 1px solid var(--grey-rule); font-size: 0.875rem; }
  .menu-toggle { display: block; }
  .editorial-grid { grid-template-columns: 1fr; }
  .blog-grid { grid-template-columns: 1fr; }
  .fbl-grid { grid-template-columns: 1fr; }
  .partner-grid { grid-template-columns: 1fr; }
  .footer__grid { grid-template-columns: 1fr; }
  .regberegbe-grid { grid-template-columns: 1fr; }
  .why-fbi__pillars { grid-template-columns: 1fr; }
  .instagram-grid { grid-template-columns: repeat(3,1fr); }
  .instagram-grid .instagram-tile:nth-child(n+4) { display: none; }
  .hero__cta { flex-direction: column; }
  .hero__cta .btn { width: 100%; justify-content: center; }
  .ojude-hero__cta { flex-direction: column; }
}

@media (max-width: 480px) {
  .instagram-grid { grid-template-columns: repeat(2,1fr); }
  .instagram-grid .instagram-tile:nth-child(n+3) { display: none; }
  .data-strip { padding: 2rem 0; }
}

@media print {
  .top-bar, #masthead, .newsletter, .site-footer, .ojude-hero__cta { display: none; }
  body { font-size: 12pt; background: white; color: black; }
}
