/*
Theme Name: WCFF
Theme URI: https://wcff.info
Description: World Cossack Fight Federation — sports federation theme (child of Twenty Twenty-Five)
Template: twentytwentyfive
Version: 1.1.0
Text Domain: wcff
*/

:root {
  --wcff-navy: #0a2540;
  --wcff-navy-deep: #061729;
  --wcff-navy-soft: #12304f;
  --wcff-gold: #f5a623;
  --wcff-gold-bright: #ffc107;
  --wcff-silver: #c0c0c0;
  --wcff-red: #c0392b;
  --wcff-border: rgba(10,37,64,.1);
}

body {
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  color: #1a2b42;
  background: #fff;
}
h1,h2,h3,h4 { font-family: 'Oswald', 'Inter', sans-serif; letter-spacing: -0.005em; }

/* ============== SITE HEADER ============== */

.wcff-site-header {
  background: #000;
  color: #fff;
  border-bottom: 0;
}

/* TOP BAR with cossack background */
.wcff-topbar {
  background: #000 url('cossack-bg.jpg') right center / auto 100% no-repeat;
  position: relative;
  min-height: 120px;
  display: flex;
  align-items: center;
  border-bottom: 1px solid rgba(255,255,255,.1);
}
.wcff-topbar::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, #000 0%, rgba(0,0,0,.75) 55%, rgba(0,0,0,.2) 80%, rgba(0,0,0,0) 100%);
  pointer-events: none;
}
.wcff-topbar-inner {
  max-width: 1200px;
  margin: 0 auto;
  width: 100%;
  padding: 1rem 1.5rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  position: relative;
  z-index: 1;
}
.wcff-topbar .wp-block-site-logo img,
.wcff-topbar .wcff-site-logo img {
  max-height: 88px !important;
  width: auto !important;
  height: auto !important;
  filter: drop-shadow(0 2px 12px rgba(0,0,0,0.6));
}

.wcff-topbar-right {
  display: flex;
  align-items: center;
  gap: 1rem;
}
.wcff-topbar .wcff-lang-switch { margin-left: 0; }

/* NAV BAR below */
.wcff-navbar {
  background: linear-gradient(180deg, var(--wcff-navy-deep) 0%, var(--wcff-navy) 100%);
  border-bottom: 3px solid var(--wcff-gold);
  box-shadow: 0 2px 0 rgba(0,0,0,.2);
}
.wcff-navbar-inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 1.5rem;
}
.wcff-navbar .wp-block-navigation {
  gap: 0 !important;
}
.wcff-navbar .wp-block-navigation a,
.wcff-navbar .wp-block-navigation-item__content {
  color: #fff !important;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-size: 12.5px;
  padding: 1rem 1.1rem !important;
  transition: all .18s;
  border-right: 1px solid rgba(255,255,255,.06);
  position: relative;
}
.wcff-navbar .wp-block-navigation-item:first-child a {
  border-left: 1px solid rgba(255,255,255,.06);
}
.wcff-navbar .wp-block-navigation a:hover {
  color: var(--wcff-gold) !important;
  background: rgba(245,166,35,.08);
}
.wcff-navbar .wp-block-navigation-item.current-menu-item > a,
.wcff-navbar .wp-block-navigation-item.current_page_item > a {
  color: var(--wcff-gold) !important;
  background: rgba(245,166,35,.12);
}

/* Mobile hamburger */
.wcff-site-header .wp-block-navigation__responsive-container-open,
.wcff-site-header .wp-block-navigation__responsive-container-close {
  color: #fff !important;
}
.wcff-site-header .wp-block-navigation__responsive-container.is-menu-open {
  background: var(--wcff-navy-deep);
  color: #fff;
  padding: 2rem 1.5rem;
}
.wcff-site-header .wp-block-navigation__responsive-container.is-menu-open a {
  color: #fff !important;
  font-size: 1.1rem;
  padding: .5rem 0 !important;
  border: 0 !important;
  background: none !important;
}
.wcff-site-header .wp-block-navigation__responsive-container.is-menu-open a:hover {
  color: var(--wcff-gold) !important;
}

.wcff-lang-switch { display: inline-flex; gap: .25rem; margin-left: 1rem; }
.wcff-lang-switch a {
  padding: 4px 10px;
  border: 1px solid rgba(255,255,255,.3);
  border-radius: 3px;
  color: #fff;
  text-decoration: none;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  transition: all .2s;
}
.wcff-lang-switch a:hover,
.wcff-lang-switch a.current {
  background: var(--wcff-gold);
  color: var(--wcff-navy-deep);
  border-color: var(--wcff-gold);
}
.wcff-lang-switch a.current { pointer-events: none; }
.wcff-lang-switch a.no-trans {
  opacity: .45;
  position: relative;
}
.wcff-lang-switch a.no-trans::after {
  content: "·";
  position: absolute;
  top: -2px;
  right: 2px;
  color: var(--wcff-gold);
  font-weight: 900;
  font-size: 14px;
  line-height: 1;
}
.wcff-lang-switch a.no-trans:hover { opacity: 1; }

/* ============== CINEMATIC UFC-STYLE HERO ============== */
.wcff-hero-cinema {
  position: relative;
  min-height: 78vh;
  max-height: 820px;
  background: #000;
  color: #fff;
  overflow: hidden;
  display: flex;
  align-items: flex-end;
  isolation: isolate;
}
.wcff-hero-bg-layer {
  position: absolute;
  inset: 0;
  background-image: var(--wcff-hero-bg);
  background-size: cover;
  background-position: 65% center;
  background-repeat: no-repeat;
  transform: scale(1.05);
  transition: transform 8s ease-out;
  filter: contrast(1.08) saturate(1.05);
  z-index: 1;
}
.wcff-hero-cinema:hover .wcff-hero-bg-layer { transform: scale(1.08); }

.wcff-hero-overlay {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(100deg, rgba(0,0,0,.95) 0%, rgba(6,23,41,.88) 22%, rgba(6,23,41,.55) 55%, rgba(6,23,41,.2) 80%, rgba(6,23,41,0) 100%),
    linear-gradient(180deg, rgba(0,0,0,.3) 0%, rgba(0,0,0,0) 40%, rgba(0,0,0,.6) 100%),
    radial-gradient(ellipse at 85% 50%, rgba(245,166,35,.08) 0%, transparent 55%);
  z-index: 2;
}

.wcff-hero-grain {
  position: absolute;
  inset: 0;
  background-image:
    repeating-linear-gradient(0deg, rgba(255,255,255,.015) 0px, rgba(255,255,255,.015) 1px, transparent 1px, transparent 3px);
  mix-blend-mode: overlay;
  pointer-events: none;
  z-index: 3;
}

.wcff-hero-accent-line {
  position: absolute;
  left: 0; bottom: 0;
  width: 40%; height: 4px;
  background: linear-gradient(90deg, var(--wcff-gold) 0%, rgba(245,166,35,.4) 70%, transparent 100%);
  z-index: 4;
}

.wcff-hero-content {
  position: relative;
  z-index: 5;
  max-width: 1200px;
  width: 100%;
  margin: 0 auto;
  padding: 4rem 2rem 5rem;
}

.wcff-hero-eyebrow-row {
  display: flex;
  align-items: center;
  gap: 1.25rem;
  margin-bottom: 1.5rem;
  flex-wrap: wrap;
}
.wcff-hero-chip-live {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  background: var(--wcff-gold);
  color: var(--wcff-navy-deep) !important;
  padding: 7px 14px;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  border-radius: 2px;
  text-decoration: none;
  font-family: 'Inter', sans-serif;
  position: relative;
  transition: transform .2s;
}
.wcff-hero-chip-live::before {
  content: "";
  width: 7px; height: 7px;
  background: #c0392b;
  border-radius: 50%;
  animation: wcffPulse 1.8s ease-in-out infinite;
}
.wcff-hero-chip-live:hover { transform: translateY(-1px); }
@keyframes wcffPulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(192,57,43,.6); }
  50%      { box-shadow: 0 0 0 6px rgba(192,57,43,0); }
}
.wcff-hero-date {
  font-size: 12px;
  color: rgba(255,255,255,.7);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  font-weight: 600;
}

.wcff-hero-headline {
  font-family: 'Oswald', 'Inter', sans-serif;
  font-size: clamp(2.4rem, 7.5vw, 6rem) !important;
  font-weight: 700;
  line-height: 0.95;
  letter-spacing: -0.02em;
  text-transform: uppercase;
  margin: 0 0 1.25rem !important;
  max-width: 900px;
  text-shadow: 0 4px 30px rgba(0,0,0,.4);
  color: #fff;
}
.wcff-hero-headline .year {
  color: var(--wcff-gold);
  display: inline-block;
  margin-left: 0.5rem;
}

.wcff-hero-sub {
  font-size: clamp(15px, 1.4vw, 17px);
  max-width: 620px;
  margin: 0 0 2rem !important;
  color: rgba(255,255,255,.82);
  line-height: 1.55;
  font-weight: 400;
}

.wcff-hero-meta-row {
  display: flex;
  gap: 2.5rem;
  margin-bottom: 2.5rem;
  flex-wrap: wrap;
  padding: 1rem 0;
  border-top: 1px solid rgba(255,255,255,.14);
  border-bottom: 1px solid rgba(255,255,255,.14);
  max-width: 720px;
}
.wcff-hero-meta-row .meta-cell {
  display: flex;
  flex-direction: column;
  gap: 3px;
}
.wcff-hero-meta-row .meta-cell .label {
  font-size: 10px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--wcff-gold);
  font-weight: 700;
}
.wcff-hero-meta-row .meta-cell .value {
  font-family: 'Oswald', sans-serif;
  font-size: clamp(15px, 1.3vw, 19px);
  font-weight: 600;
  color: #fff;
  letter-spacing: 0.01em;
}

.wcff-hero-actions {
  display: flex;
  gap: 1rem;
  align-items: center;
  flex-wrap: wrap;
}
.wcff-btn-hero {
  display: inline-flex;
  align-items: center;
  gap: .75rem;
  padding: 1rem 1.75rem;
  background: var(--wcff-gold);
  color: var(--wcff-navy-deep) !important;
  font-weight: 800;
  font-size: 13px;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  text-decoration: none !important;
  border-radius: 2px;
  transition: all .2s;
  border: 2px solid var(--wcff-gold);
  position: relative;
  overflow: hidden;
}
.wcff-btn-hero svg { transition: transform .3s; }
.wcff-btn-hero:hover {
  background: #fff;
  border-color: #fff;
  color: var(--wcff-navy-deep) !important;
  transform: translateY(-1px);
  box-shadow: 0 8px 20px rgba(245,166,35,.35);
}
.wcff-btn-hero:hover svg { transform: translateX(4px); }

.wcff-btn-hero-ghost {
  display: inline-flex;
  align-items: center;
  padding: 1rem 1.5rem;
  color: #fff !important;
  font-weight: 700;
  font-size: 12px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  text-decoration: none !important;
  border: 1px solid rgba(255,255,255,.3);
  border-radius: 2px;
  transition: all .2s;
  background: rgba(255,255,255,.04);
  backdrop-filter: blur(6px);
}
.wcff-btn-hero-ghost:hover {
  background: rgba(255,255,255,.12);
  border-color: var(--wcff-gold);
  color: var(--wcff-gold) !important;
}

.wcff-hero-mark {
  position: absolute;
  right: 2.5rem;
  bottom: 1.25rem;
  font-family: 'Oswald', sans-serif;
  font-size: 120px;
  font-weight: 700;
  color: rgba(255,255,255,.04);
  letter-spacing: -0.04em;
  line-height: 0.9;
  z-index: 1;
  pointer-events: none;
  user-select: none;
}

/* Responsive hero */
@media (max-width: 820px) {
  .wcff-hero-cinema { min-height: 68vh; max-height: 700px; }
  .wcff-hero-content { padding: 3rem 1.25rem 4rem; }
  .wcff-hero-mark { font-size: 80px; right: 1rem; bottom: .8rem; }
  .wcff-hero-meta-row { gap: 1.5rem; }
}
@media (max-width: 640px) {
  .wcff-hero-cinema { min-height: 70vh; max-height: 620px; }
  .wcff-hero-headline { font-size: clamp(2rem, 10vw, 3.5rem) !important; }
  .wcff-hero-content { padding: 2.5rem 1rem 3rem; }
  .wcff-hero-sub { font-size: 14.5px; }
  .wcff-hero-meta-row {
    gap: 1rem;
    flex-direction: column;
    padding: .85rem 0;
  }
  .wcff-hero-actions { width: 100%; }
  .wcff-btn-hero, .wcff-btn-hero-ghost { flex: 1; justify-content: center; padding: .9rem 1rem; }
  .wcff-hero-mark { display: none; }
  .wcff-hero-bg-layer { background-position: 75% center; }
  .wcff-hero-overlay {
    background:
      linear-gradient(180deg, rgba(0,0,0,.6) 0%, rgba(6,23,41,.85) 60%, rgba(0,0,0,.9) 100%),
      radial-gradient(ellipse at top, rgba(245,166,35,.06) 0%, transparent 60%);
  }
}

.wcff-btn {
  display: inline-block;
  padding: 0.8rem 1.6rem;
  background: var(--wcff-gold);
  color: var(--wcff-navy-deep);
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  font-size: 13px;
  border-radius: 3px;
  text-decoration: none;
  transition: all .2s;
  border: 2px solid var(--wcff-gold);
}
.wcff-btn:hover { background: transparent; color: var(--wcff-gold); }

/* ============== FEDERATION HUB (UFC-STYLE POSTER CARDS) ============== */
.wcff-hub {
  background: #060d19;
  background-image:
    radial-gradient(ellipse at 80% 20%, rgba(245,166,35,.05) 0%, transparent 40%),
    radial-gradient(ellipse at 10% 80%, rgba(6,23,41,.6) 0%, transparent 50%);
  padding: 5rem 1.5rem 6rem;
  position: relative;
  overflow: hidden;
}
.wcff-hub::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(245,166,35,.4), transparent);
}
.wcff-hub-inner {
  max-width: 1280px;
  margin: 0 auto;
  position: relative;
}
.wcff-hub-header {
  margin-bottom: 3rem;
  text-align: left;
}
.wcff-hub-eyebrow {
  display: inline-block;
  color: var(--wcff-gold);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  margin-bottom: .75rem;
  font-family: 'Inter', sans-serif;
}
.wcff-hub-heading {
  font-family: 'Oswald', sans-serif;
  font-size: clamp(2rem, 4vw, 3rem) !important;
  font-weight: 700;
  text-transform: uppercase;
  color: #fff;
  margin: 0 0 1rem !important;
  line-height: 1;
  letter-spacing: -0.01em;
  padding: 0 !important;
  border: 0 !important;
}
.wcff-hub-rule {
  width: 60px;
  height: 3px;
  background: var(--wcff-gold);
}

.wcff-hub-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
}
.wcff-hub-card {
  position: relative;
  aspect-ratio: 4 / 5;
  overflow: hidden;
  border-radius: 4px;
  text-decoration: none !important;
  color: #fff !important;
  isolation: isolate;
  box-shadow: 0 20px 50px rgba(0,0,0,.5);
  transform: translateZ(0);
  transition: transform .35s cubic-bezier(.2,.7,.2,1), box-shadow .35s;
}
.wcff-hub-card::before {
  content: attr(data-index);
  position: absolute;
  top: 1.25rem; right: 1.5rem;
  z-index: 5;
  font-family: 'Oswald', sans-serif;
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.15em;
  color: var(--wcff-gold);
  opacity: .85;
}
.wcff-hub-card::after {
  content: "";
  position: absolute;
  top: 1.25rem; right: 1.5rem;
  width: 28px; height: 2px;
  background: var(--wcff-gold);
  transform: translateX(42px);
  z-index: 4;
  opacity: .6;
}

.wcff-hub-bg {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  z-index: 1;
  transform: scale(1.05);
  transition: transform .8s cubic-bezier(.2,.7,.2,1), filter .35s;
  filter: contrast(1.05) saturate(1.1);
}
.wcff-hub-shade {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(0,0,0,.2) 0%, rgba(6,13,25,.4) 45%, rgba(6,13,25,.92) 85%, #060d19 100%),
    linear-gradient(70deg, rgba(6,13,25,.6) 0%, rgba(6,13,25,0) 50%);
  z-index: 2;
  transition: background .35s;
}

.wcff-hub-corner { display: none !important; }

.wcff-hub-body {
  position: absolute;
  inset: 0;
  z-index: 4;
  padding: 1.75rem 1.75rem 1.75rem;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}

.wcff-hub-tag {
  display: inline-flex;
  align-items: baseline;
  gap: 6px;
  margin-bottom: .75rem;
  color: var(--wcff-gold);
  font-family: 'Oswald', sans-serif;
}
.wcff-hub-count {
  font-size: 22px;
  font-weight: 700;
  line-height: 1;
  letter-spacing: -0.01em;
}
.wcff-hub-count-label {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  font-weight: 700;
  opacity: .85;
}

.wcff-hub-card-title {
  font-family: 'Oswald', sans-serif;
  font-size: clamp(1.8rem, 3vw, 2.6rem);
  font-weight: 700;
  text-transform: uppercase;
  line-height: 0.95;
  color: #fff;
  margin: 0 0 .5rem;
  letter-spacing: -0.01em;
  text-shadow: 0 2px 12px rgba(0,0,0,.6);
}

.wcff-hub-tagline {
  font-size: 13px;
  color: var(--wcff-gold);
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin-bottom: .65rem;
}

.wcff-hub-desc {
  font-size: 14px;
  line-height: 1.5;
  color: rgba(255,255,255,.78);
  margin: 0 0 1.25rem;
  max-height: 0;
  opacity: 0;
  transform: translateY(8px);
  overflow: hidden;
  transition: max-height .4s cubic-bezier(.2,.7,.2,1), opacity .3s, transform .35s;
}

.wcff-hub-enter {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--wcff-gold);
  padding: 10px 16px;
  border: 1px solid var(--wcff-gold);
  background: rgba(245,166,35,.08);
  align-self: flex-start;
  border-radius: 2px;
  transition: all .25s;
}
.wcff-hub-enter svg { transition: transform .3s; }

/* Hover state — expands content, brightens image */
.wcff-hub-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 30px 60px rgba(0,0,0,.6), 0 0 0 1px rgba(245,166,35,.3);
}
.wcff-hub-card:hover .wcff-hub-bg {
  transform: scale(1.12);
  filter: contrast(1.1) saturate(1.2);
}
.wcff-hub-card:hover .wcff-hub-shade {
  background:
    linear-gradient(180deg, rgba(0,0,0,.1) 0%, rgba(6,13,25,.5) 45%, rgba(6,13,25,.95) 88%, #060d19 100%),
    linear-gradient(70deg, rgba(6,13,25,.5) 0%, rgba(6,13,25,0) 50%);
}
.wcff-hub-card:hover .wcff-hub-desc {
  max-height: 80px;
  opacity: 1;
  transform: translateY(0);
}
.wcff-hub-card:hover .wcff-hub-enter {
  background: var(--wcff-gold);
  color: var(--wcff-navy-deep);
}
.wcff-hub-card:hover .wcff-hub-enter svg { transform: translateX(4px); }
.wcff-hub-card:hover::after { transform: translateX(0); opacity: 1; }

@media (max-width: 980px) {
  .wcff-hub-grid { grid-template-columns: repeat(2, 1fr); gap: 1rem; }
  .wcff-hub-card:nth-child(3) { grid-column: span 2; aspect-ratio: 16 / 9; }
  .wcff-hub { padding: 4rem 1.25rem 4.5rem; }
}
@media (max-width: 640px) {
  .wcff-hub-grid { grid-template-columns: 1fr; }
  .wcff-hub-card, .wcff-hub-card:nth-child(3) { aspect-ratio: 16 / 10; }
  .wcff-hub-body { padding: 1.25rem; }
  .wcff-hub-card-title { font-size: 1.8rem; }
  .wcff-hub-desc { max-height: 80px; opacity: 1; transform: none; }
}

/* Section (with posts grid) */
.wcff-section {
  padding: 4rem 0;
}
.wcff-section-inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 1rem;
}
.wcff-section.dark {
  background: var(--wcff-navy);
  color: #fff;
}
.wcff-section.dark h2,
.wcff-section.dark h3 a,
.wcff-section.dark .wcff-view-all { color: #fff; }

.wcff-section-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-bottom: 2px solid var(--wcff-gold);
  padding-bottom: .75rem;
  margin-bottom: 2rem;
}
.wcff-section-head h2 {
  margin: 0;
  font-size: clamp(1.5rem, 2.5vw, 2rem);
  text-transform: uppercase;
  font-weight: 700;
}
.wcff-view-all {
  color: var(--wcff-navy);
  font-weight: 700;
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  text-decoration: none;
  transition: color .2s;
}
.wcff-view-all:hover { color: var(--wcff-gold); }

.wcff-posts-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2rem;
}
.wcff-post-card {
  background: #fff;
  border: 1px solid var(--wcff-border);
  border-radius: 4px;
  overflow: hidden;
  transition: all .2s;
  display: flex;
  flex-direction: column;
}
.wcff-section.dark .wcff-post-card {
  background: var(--wcff-navy-soft);
  border-color: rgba(255,255,255,.08);
  color: #fff;
}
.wcff-post-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 10px 30px rgba(0,0,0,.14);
}
.wcff-section.dark .wcff-post-card:hover { box-shadow: 0 10px 30px rgba(0,0,0,.5); }
.wcff-post-media {
  display: block;
  aspect-ratio: 16/10;
  overflow: hidden;
  background: var(--wcff-navy-soft);
  position: relative;
}
.wcff-post-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .4s;
}
.wcff-post-card:hover .wcff-post-media img { transform: scale(1.04); }
.wcff-post-media .wcff-no-image {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: 'Oswald', sans-serif;
  font-size: 2rem;
  font-weight: 700;
  color: var(--wcff-gold);
  letter-spacing: 0.15em;
}
.wcff-post-body {
  padding: 1.25rem 1.25rem 1.5rem;
  flex: 1;
  display: flex;
  flex-direction: column;
}
.wcff-post-body .wcff-meta {
  font-size: 11px;
  opacity: .7;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-bottom: .5rem;
}
.wcff-post-body h3 {
  font-size: 1.15rem;
  line-height: 1.25;
  margin: 0 0 .5rem;
  font-weight: 700;
}
.wcff-post-body h3 a {
  color: inherit;
  text-decoration: none;
  transition: color .2s;
}
.wcff-post-body h3 a:hover { color: var(--wcff-gold); }
.wcff-post-body .wcff-post-ex {
  margin: 0;
  font-size: 14px;
  line-height: 1.55;
  opacity: .8;
}

/* Quicklinks */
.wcff-quicklinks {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1rem;
}
.wcff-quick {
  display: block;
  padding: 1.75rem 3rem 1.75rem 1.75rem;
  background: #fff;
  border: 1px solid var(--wcff-border);
  border-left: 4px solid var(--wcff-gold);
  border-radius: 3px;
  text-decoration: none;
  color: var(--wcff-navy);
  transition: all .2s;
  position: relative;
}
.wcff-quick:hover {
  background: var(--wcff-navy);
  color: #fff;
  transform: translateX(4px);
}
.wcff-quick-title {
  display: block;
  font-family: 'Oswald', sans-serif;
  font-size: 1.2rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.02em;
  margin-bottom: .5rem;
}
.wcff-quick-desc {
  display: block;
  font-size: 13px;
  line-height: 1.5;
  opacity: .75;
}
.wcff-quick-arrow {
  position: absolute;
  top: 1.75rem;
  right: 1.25rem;
  color: var(--wcff-gold);
  font-size: 1.2rem;
  transition: transform .2s;
}
.wcff-quick:hover .wcff-quick-arrow {
  transform: translateX(4px);
}

/* ============== PAGE / POST CONTENT ============== */

.wcff-page-hero {
  position: relative;
  background:
    radial-gradient(1200px 400px at 20% 0%, rgba(245,166,35,.08), transparent 60%),
    linear-gradient(135deg, var(--wcff-navy-deep) 0%, var(--wcff-navy) 60%, var(--wcff-navy-soft) 100%);
  color: #fff;
  padding: 3rem 1.5rem 3.5rem;
  overflow: hidden;
}
.wcff-page-hero::before {
  content: "";
  position: absolute;
  left: -120px; bottom: -120px;
  width: 420px; height: 420px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(245,166,35,.12) 0%, transparent 70%);
  pointer-events: none;
}
.wcff-page-hero::after {
  content: "";
  position: absolute;
  left: 0; right: 0; bottom: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--wcff-gold) 0%, transparent 40%);
}
.wcff-page-hero-inner {
  max-width: 1100px;
  margin: 0 auto;
  position: relative;
  z-index: 1;
}
.wcff-page-hero-bar {
  display: flex;
  align-items: center;
  gap: 1rem;
  margin-bottom: 1rem;
}
.wcff-hero-back {
  color: rgba(255,255,255,.7);
  text-decoration: none;
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: 600;
  transition: color .15s;
}
.wcff-hero-back:hover { color: var(--wcff-gold); }
.wcff-hero-chip {
  display: inline-block;
  background: var(--wcff-gold);
  color: var(--wcff-navy-deep);
  padding: 4px 12px;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  border-radius: 2px;
}
.wcff-page-hero .wp-block-post-title,
.wcff-page-hero-title {
  font-size: clamp(2rem, 5vw, 3.6rem);
  font-family: 'Oswald', sans-serif;
  font-weight: 700;
  text-transform: uppercase;
  color: #fff;
  margin: 0;
  line-height: 1.02;
  letter-spacing: -0.015em;
  max-width: 900px;
}
.wcff-hero-accent {
  width: 60px;
  height: 4px;
  background: var(--wcff-gold);
  margin-top: 1.25rem;
}

.wcff-page-body {
  padding: 4rem 1.5rem 5rem;
  background: #fafbfc;
}
.wcff-page-body-inner {
  max-width: 900px;
  margin: 0 auto;
}
.wcff-page-content {
  display: block;
  background: #fff;
  border-radius: 6px;
  padding: 3rem 3rem;
  box-shadow: 0 2px 20px rgba(10,37,64,.05);
  border: 1px solid var(--wcff-border);
}

.wcff-page-featured img {
  width: 100%;
  height: auto;
  border-radius: 4px;
  margin-bottom: 2rem;
}

.wcff-page-content p,
.wp-block-post-content p {
  font-size: 17px;
  line-height: 1.75;
  margin: 0 0 1.2rem;
  color: #223550;
}
.wcff-page-content strong,
.wp-block-post-content strong { color: var(--wcff-navy-deep); font-weight: 700; }

.wcff-page-content p.wcff-lead,
.wcff-lead {
  font-size: 19px;
  line-height: 1.65;
  color: var(--wcff-navy);
  font-weight: 500;
  margin-bottom: 2.5rem;
  padding-bottom: 2rem;
  border-bottom: 1px solid var(--wcff-border);
}

.wcff-page-content h2,
.wp-block-post-content h2 {
  font-family: 'Oswald', sans-serif;
  font-size: clamp(1.5rem, 2.5vw, 2rem);
  text-transform: uppercase;
  color: var(--wcff-navy-deep);
  margin: 3rem 0 1.25rem;
  padding-left: 14px;
  border-left: 4px solid var(--wcff-gold);
  line-height: 1.15;
  letter-spacing: -0.005em;
}
.wcff-page-content .wcff-section-block > h2:first-child,
.wcff-page-content > h2:first-child { margin-top: 0; }

.wcff-page-content h3,
.wp-block-post-content h3 {
  font-family: 'Oswald', sans-serif;
  font-size: 1.2rem;
  text-transform: uppercase;
  color: var(--wcff-navy);
  margin: 2rem 0 .75rem;
  letter-spacing: 0.01em;
}

.wcff-section-block { margin-bottom: 3rem; }
.wcff-section-block:last-child { margin-bottom: 0; }

.wcff-page-content a,
.wp-block-post-content a {
  color: var(--wcff-navy);
  text-decoration: underline;
  text-decoration-color: var(--wcff-gold);
  text-underline-offset: 3px;
  transition: color .15s;
}
.wcff-page-content a:hover,
.wp-block-post-content a:hover { color: var(--wcff-gold); }

/* Normalise legacy Arthemia inline images */
.wcff-page-content img,
.wp-block-post-content img {
  max-width: 100%;
  height: auto !important;
  width: auto !important;
  display: block;
  margin: 1.5rem auto;
  border-radius: 4px;
  box-shadow: 0 2px 12px rgba(10,37,64,.08);
}
.wcff-page-content .alignleft,
.wp-block-post-content .alignleft,
.wcff-page-content img.alignleft {
  float: left;
  margin: 0.3rem 1.5rem 1rem 0;
}
.wcff-page-content .alignright,
.wp-block-post-content .alignright,
.wcff-page-content img.alignright {
  float: right;
  margin: 0.3rem 0 1rem 1.5rem;
}
.wcff-page-content .aligncenter,
.wp-block-post-content .aligncenter,
.wcff-page-content img.aligncenter { margin: 1.5rem auto; }

/* Admin cards (Administration page) */
.wcff-admin-cards {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: 1.5rem;
  margin: 2rem 0;
}
.wcff-admin-card {
  background: #fff;
  border: 1px solid var(--wcff-border);
  border-left: 4px solid var(--wcff-gold);
  border-radius: 4px;
  overflow: hidden;
  display: flex;
  transition: transform .2s, box-shadow .2s;
}
.wcff-admin-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 10px 28px rgba(10,37,64,.12);
}
.wcff-admin-photo {
  flex: 0 0 160px !important;
  width: 160px !important;
  max-width: 160px !important;
  min-height: 180px;
  background: var(--wcff-navy-soft);
  overflow: hidden;
}
.wcff-admin-photo img {
  width: 100% !important;
  height: 100% !important;
  max-width: 100% !important;
  max-height: 100% !important;
  object-fit: cover;
  object-position: center top;
  margin: 0 !important;
  border-radius: 0 !important;
  display: block !important;
  box-shadow: none !important;
  min-height: 100%;
}
.wcff-admin-info {
  padding: 1.25rem 1.5rem;
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.wcff-admin-info h3 {
  margin: 0 0 .4rem;
  font-size: 1.25rem;
  font-family: 'Oswald', sans-serif;
  text-transform: uppercase;
  color: var(--wcff-navy);
  letter-spacing: 0.01em;
}
.wcff-admin-role {
  font-size: 14px;
  color: var(--wcff-navy-soft);
  opacity: .85;
  margin-bottom: .6rem;
}
.wcff-admin-email {
  font-size: 13px;
  color: var(--wcff-gold) !important;
  text-decoration: none !important;
  font-weight: 600;
  display: inline-block;
  margin-top: auto;
}
.wcff-admin-email:hover { color: var(--wcff-navy) !important; }

/* ============== DOC BUILDING BLOCKS ============== */

/* Styles grid (Rules — 9 fighting styles) */
.wcff-styles-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
  gap: 1rem;
  margin: 1.5rem 0;
}
.wcff-style {
  background: #fff;
  border: 1px solid var(--wcff-border);
  border-top: 3px solid var(--wcff-gold);
  border-radius: 4px;
  padding: 1.25rem 1.25rem 1.1rem;
  transition: transform .15s, box-shadow .15s;
}
.wcff-style:hover { transform: translateY(-2px); box-shadow: 0 8px 22px rgba(10,37,64,.1); }
.wcff-style-full { border-top-color: var(--wcff-red); }
.wcff-style-chip {
  display: inline-block;
  background: rgba(245,166,35,.14);
  color: var(--wcff-navy);
  padding: 2px 8px;
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  border-radius: 2px;
  font-weight: 700;
  margin-bottom: .5rem;
}
.wcff-style-full .wcff-style-chip { background: rgba(192,57,43,.12); color: var(--wcff-red); }
.wcff-style h3 {
  margin: 0 0 .3rem !important;
  font-size: 1.15rem !important;
  letter-spacing: 0.02em;
}
.wcff-style p {
  margin: 0 !important;
  font-size: 13px !important;
  color: #556680 !important;
  line-height: 1.5 !important;
}

/* Callout box */
.wcff-callout {
  background: linear-gradient(90deg, rgba(245,166,35,.08), rgba(245,166,35,0.02));
  border-left: 4px solid var(--wcff-gold);
  padding: 1rem 1.25rem;
  border-radius: 0 4px 4px 0;
  margin: 1.5rem 0;
  font-size: 15px;
  line-height: 1.6;
  color: var(--wcff-navy);
}
.wcff-callout strong { color: var(--wcff-navy-deep); }
.wcff-callout.warn {
  background: linear-gradient(90deg, rgba(192,57,43,.06), rgba(192,57,43,.01));
  border-left-color: var(--wcff-red);
}

/* Variant row (Z-1 / Z-2 etc) */
.wcff-variant-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
  margin: 1.25rem 0;
}
.wcff-variant {
  background: #f7f9fc;
  padding: 1rem 1.25rem;
  border-radius: 4px;
  border-left: 3px solid var(--wcff-gold);
}
.wcff-variant-tag {
  display: inline-block;
  background: var(--wcff-navy);
  color: #fff;
  padding: 3px 10px;
  font-family: 'Oswald', sans-serif;
  font-size: 13px;
  font-weight: 700;
  border-radius: 2px;
  margin-bottom: .4rem;
}
.wcff-variant p { margin: 0 !important; font-size: 14px !important; }

/* Clean lists */
.wcff-list {
  list-style: none !important;
  padding: 0 !important;
  margin: 1rem 0 !important;
}
.wcff-list li {
  position: relative;
  padding: .45rem 0 .45rem 1.5rem !important;
  border-bottom: 1px solid var(--wcff-border);
  font-size: 15px !important;
  line-height: 1.6 !important;
  color: #223550 !important;
  margin: 0 !important;
}
.wcff-list li:last-child { border-bottom: 0; }
.wcff-list li::before {
  content: "";
  position: absolute;
  left: 0; top: 1em;
  width: 6px; height: 6px;
  background: var(--wcff-gold);
  border-radius: 50%;
  transform: translateY(-50%);
}
.wcff-list-no li::before { background: var(--wcff-red); }

/* Weight categories */
.wcff-weight-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 1rem;
  margin: 1.25rem 0;
}
.wcff-weight-card {
  background: var(--wcff-navy);
  color: #fff;
  padding: 1.25rem 1.5rem;
  border-radius: 4px;
  border-top: 3px solid var(--wcff-gold);
}
.wcff-weight-card strong {
  display: block;
  font-family: 'Oswald', sans-serif;
  font-size: 1.1rem;
  text-transform: uppercase;
  color: var(--wcff-gold);
  margin-bottom: .4rem;
  letter-spacing: 0.05em;
}
.wcff-weight-card p {
  color: rgba(255,255,255,.9) !important;
  margin: 0 !important;
  font-size: 15px !important;
  line-height: 1.5 !important;
  font-variant-numeric: tabular-nums;
  letter-spacing: 0.02em;
}

/* Event list (Calendar) */
.wcff-year-block h2 {
  display: flex;
  align-items: baseline;
  gap: .75rem;
}
.wcff-year-current h2::after {
  content: "Current";
  font-size: 11px;
  background: var(--wcff-gold);
  color: var(--wcff-navy-deep);
  padding: 2px 8px;
  letter-spacing: 0.12em;
  border-radius: 2px;
  font-family: 'Inter', sans-serif;
  font-weight: 800;
}
.wcff-events-list {
  display: flex;
  flex-direction: column;
  gap: .5rem;
}
.wcff-event {
  display: grid;
  grid-template-columns: 150px 1fr;
  gap: 1.5rem;
  padding: 1rem 1.25rem;
  background: #fff;
  border: 1px solid var(--wcff-border);
  border-left: 4px solid var(--wcff-gold);
  border-radius: 4px;
  align-items: center;
  transition: transform .15s, box-shadow .15s;
}
.wcff-event:hover { transform: translateX(4px); box-shadow: 0 8px 22px rgba(10,37,64,.08); }
.wcff-event.past { opacity: .68; border-left-color: var(--wcff-silver); }
.wcff-event-date { display: flex; flex-direction: column; }
.wcff-event-date .day {
  font-family: 'Oswald', sans-serif;
  font-size: 1.1rem;
  color: var(--wcff-navy-deep);
  font-weight: 700;
  line-height: 1.1;
}
.wcff-event-date .month {
  font-size: 11px;
  color: var(--wcff-gold);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: 700;
  margin-top: 4px;
}
.wcff-event-body h3 {
  margin: 0 0 .2rem !important;
  font-size: 1.1rem !important;
}
.wcff-event-meta {
  font-size: 14px;
  color: #556680;
}

/* Contact cards */
.wcff-contact-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 1rem;
  margin: 2rem 0;
}
.wcff-contact-card {
  background: #fff;
  border: 1px solid var(--wcff-border);
  border-top: 3px solid var(--wcff-gold);
  border-radius: 4px;
  padding: 1.5rem;
}
.wcff-contact-card.primary {
  background: var(--wcff-navy);
  color: #fff;
  border: 0;
}
.wcff-contact-label {
  font-size: 11px;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--wcff-gold);
  font-weight: 700;
  margin-bottom: .5rem;
}
.wcff-contact-title {
  font-family: 'Oswald', sans-serif;
  font-size: 1.15rem;
  text-transform: uppercase;
  margin-bottom: .4rem;
  line-height: 1.2;
}
.wcff-contact-meta {
  font-size: 14px;
  color: #556680;
  line-height: 1.5;
}
.wcff-contact-card.primary .wcff-contact-meta { color: rgba(255,255,255,.75); }
.wcff-contact-link {
  display: inline-block;
  margin-top: .5rem;
  color: var(--wcff-navy) !important;
  font-weight: 600;
  text-decoration: none !important;
  font-size: 15px;
  border-bottom: 1px solid var(--wcff-gold);
  padding-bottom: 1px;
}
.wcff-contact-card.primary .wcff-contact-link { color: var(--wcff-gold) !important; border-bottom-color: var(--wcff-gold); }
.wcff-contact-link:hover { color: var(--wcff-gold) !important; }

/* ============== CONTACT FORM 7 (WCFF style) ============== */
.wpcf7 { margin: 1rem 0 0; }
.wpcf7 form .wcff-cf7-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem 1.5rem; }
.wpcf7 form .wcff-cf7-grid > p { margin: 0 0 .5rem; }
.wpcf7 form .wcff-cf7-grid > p:nth-child(3),
.wpcf7 form .wcff-cf7-grid > p:nth-child(4),
.wpcf7 form .wcff-cf7-quiz { grid-column: 1 / -1; }

.wpcf7 label {
  display: block;
  font-size: 12px !important;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--wcff-navy) !important;
  margin-bottom: .3rem;
}
.wpcf7 label .req { color: var(--wcff-red); }

.wpcf7 input[type="text"],
.wpcf7 input[type="email"],
.wpcf7 input[type="tel"],
.wpcf7 textarea {
  display: block;
  width: 100%;
  margin-top: .3rem;
  padding: 12px 14px;
  border: 1px solid var(--wcff-border);
  border-radius: 3px;
  background: #fff;
  font-family: 'Inter', sans-serif;
  font-size: 15px;
  font-weight: 400;
  color: var(--wcff-navy-deep);
  transition: border-color .15s, box-shadow .15s;
  text-transform: none;
  letter-spacing: 0;
  box-sizing: border-box;
}
.wpcf7 input:focus,
.wpcf7 textarea:focus {
  outline: 0;
  border-color: var(--wcff-gold);
  box-shadow: 0 0 0 3px rgba(245,166,35,.15);
}
.wpcf7 textarea { resize: vertical; min-height: 140px; }

.wpcf7 .wpcf7-quiz { font-size: 14px; font-weight: 500; }

.wpcf7 input[type="submit"],
.wpcf7 button[type="submit"] {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  padding: 0.9rem 2rem;
  background: var(--wcff-gold);
  color: var(--wcff-navy-deep) !important;
  font-weight: 800;
  font-size: 13px;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  border: 0;
  border-radius: 3px;
  cursor: pointer;
  transition: all .2s;
  font-family: 'Inter', sans-serif;
}
.wpcf7 input[type="submit"]:hover,
.wpcf7 button[type="submit"]:hover {
  background: var(--wcff-navy);
  color: #fff !important;
  transform: translateY(-1px);
  box-shadow: 0 6px 14px rgba(10,37,64,.2);
}
.wpcf7 .wpcf7-submit { margin-top: .5rem; }

/* Validation + response */
.wpcf7-not-valid-tip { color: var(--wcff-red); font-size: 12px; margin-top: 4px; font-weight: 600; }
.wpcf7 .wpcf7-not-valid { border-color: var(--wcff-red); }
.wpcf7-response-output {
  margin: 1.5rem 0 0 !important;
  padding: 1rem 1.25rem !important;
  border: 0 !important;
  border-left: 4px solid var(--wcff-gold) !important;
  background: rgba(245,166,35,.08);
  font-size: 14px;
  color: var(--wcff-navy-deep);
  border-radius: 0 3px 3px 0;
}
.wpcf7 form.invalid .wpcf7-response-output,
.wpcf7 form.unaccepted .wpcf7-response-output,
.wpcf7 form.spam .wpcf7-response-output {
  border-left-color: var(--wcff-red) !important;
  background: rgba(192,57,43,.07);
}
.wpcf7 form.sent .wpcf7-response-output {
  border-left-color: #28a745 !important;
  background: rgba(40,167,69,.08);
}

/* Hide honeypot field */
.wcff-cf7-honey { position: absolute !important; left: -9999px !important; top: -9999px !important; opacity: 0 !important; pointer-events: none !important; }

@media (max-width: 640px) {
  .wpcf7 form .wcff-cf7-grid { grid-template-columns: 1fr; gap: .75rem; }
}

/* Camp page hero */
.wcff-camp-hero {
  background: var(--wcff-navy);
  color: #fff;
  border-radius: 6px;
  overflow: hidden;
  margin: 0 0 2rem;
  border: 0 !important;
}
.wcff-camp-hero-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
}
.wcff-camp-hero-grid > div { padding: 2rem; }
.wcff-camp-hero-image { padding: 0 !important; }
.wcff-camp-hero-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  margin: 0 !important;
  border-radius: 0 !important;
  max-width: none !important;
  display: block;
  box-shadow: none !important;
}
.wcff-camp-meta { margin-bottom: 1.25rem; }
.wcff-meta-item {
  display: flex;
  justify-content: space-between;
  border-bottom: 1px solid rgba(255,255,255,.12);
  padding: .55rem 0;
  font-size: 14px;
}
.wcff-meta-item .label {
  color: rgba(255,255,255,.6);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-size: 11px;
  font-weight: 600;
}
.wcff-meta-item .value { font-weight: 500; text-align: right; }
.wcff-camp-hero a.wcff-btn { background: var(--wcff-gold); color: var(--wcff-navy-deep); }
.wcff-camp-hero a.wcff-btn:hover { background: #fff; color: var(--wcff-navy-deep); }

/* Gallery */
.wcff-gallery {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 1rem;
  margin: 1rem 0;
}
.wcff-gallery img {
  width: 100% !important;
  height: 200px !important;
  max-width: none !important;
  object-fit: cover;
  border-radius: 4px;
  margin: 0 !important;
  box-shadow: 0 2px 8px rgba(10,37,64,.08);
  transition: transform .2s;
  cursor: pointer;
}
.wcff-gallery img:hover { transform: scale(1.02); }

/* ============== EVENT SPEC CARD (single post structured) ============== */
.wcff-event-spec {
  background: linear-gradient(180deg, #0a2540 0%, #061729 100%);
  color: #fff;
  border-radius: 6px;
  padding: 2.5rem 2rem;
  margin: 2rem 0 2.5rem;
  border: 1px solid rgba(245,166,35,.2);
  position: relative;
  overflow: hidden;
}
.wcff-event-spec::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--wcff-gold) 0%, transparent 70%);
}
.wcff-event-spec-head {
  margin-bottom: 1.75rem;
  padding-bottom: 1.25rem;
  border-bottom: 1px solid rgba(255,255,255,.12);
}
.wcff-event-spec-head .eyebrow {
  display: block;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--wcff-gold);
  margin-bottom: .4rem;
  font-family: 'Inter', sans-serif;
}
.wcff-event-spec-head h2 {
  font-family: 'Oswald', sans-serif !important;
  font-size: 1.6rem !important;
  text-transform: uppercase;
  color: #fff !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  letter-spacing: 0.01em;
  line-height: 1.1;
}
.wcff-event-spec-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 1rem 2rem;
}
.wcff-spec-item {
  display: grid;
  grid-template-columns: 52px 1fr;
  gap: 1rem;
  padding: 1rem 0;
  border-top: 1px solid rgba(255,255,255,.08);
}
.wcff-spec-item:first-child,
.wcff-spec-item:nth-child(2) { border-top: 0; padding-top: .25rem; }
.wcff-spec-num {
  font-family: 'Oswald', sans-serif;
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--wcff-gold);
  line-height: 1;
  letter-spacing: -0.02em;
  padding-top: 4px;
  font-variant-numeric: tabular-nums;
}
.wcff-spec-label {
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--wcff-gold);
  margin-bottom: .35rem;
  font-family: 'Inter', sans-serif;
}
.wcff-spec-value {
  font-size: 15px;
  color: #fff;
  line-height: 1.5;
  font-weight: 500;
}
.wcff-spec-value a { color: var(--wcff-gold) !important; border-bottom: 1px solid rgba(245,166,35,.3); text-decoration: none !important; }
.wcff-spec-value a:hover { border-bottom-color: var(--wcff-gold); }

@media (max-width: 640px) {
  .wcff-event-spec { padding: 1.75rem 1.25rem; margin: 1.5rem -1rem; border-radius: 0; }
  .wcff-event-spec-grid { grid-template-columns: 1fr; gap: 0; }
  .wcff-spec-item { grid-template-columns: 40px 1fr; gap: .75rem; padding: .85rem 0; }
  .wcff-spec-item:nth-child(2) { border-top: 1px solid rgba(255,255,255,.08); padding-top: .85rem; }
  .wcff-spec-num { font-size: 1.2rem; }
}

/* ============== SINGLE POST CINEMATIC HERO ============== */
.wcff-post-hero {
  position: relative;
  min-height: 60vh;
  max-height: 620px;
  color: #fff;
  overflow: hidden;
  display: flex;
  align-items: flex-end;
  background: #060d19;
  isolation: isolate;
}
.wcff-post-hero-bg {
  position: absolute;
  inset: 0;
  background-image: var(--wcff-post-bg);
  background-size: cover;
  background-position: 60% center;
  transform: scale(1.06);
  filter: contrast(1.05) saturate(1.08);
  z-index: 1;
}
.wcff-post-hero-overlay {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(100deg, rgba(0,0,0,.92) 0%, rgba(6,23,41,.85) 25%, rgba(6,23,41,.5) 60%, rgba(6,23,41,.15) 100%),
    linear-gradient(180deg, rgba(0,0,0,.2) 0%, rgba(0,0,0,0) 50%, rgba(6,13,25,.7) 100%);
  z-index: 2;
}
.wcff-post-hero-content {
  position: relative;
  z-index: 3;
  max-width: 1200px;
  width: 100%;
  margin: 0 auto;
  padding: 3.5rem 2rem 3rem;
}
.wcff-post-hero-bar {
  display: flex;
  align-items: center;
  gap: 1.5rem;
  margin-bottom: 1.5rem;
  flex-wrap: wrap;
}
.wcff-post-hero-back {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  color: rgba(255,255,255,.7) !important;
  text-decoration: none !important;
  font-size: 11px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  font-weight: 700;
  padding: 6px 12px;
  border: 1px solid rgba(255,255,255,.2);
  border-radius: 2px;
  transition: all .2s;
}
.wcff-post-hero-back:hover {
  color: var(--wcff-gold) !important;
  border-color: var(--wcff-gold);
  background: rgba(245,166,35,.08);
}
.wcff-post-hero-date {
  font-size: 12px;
  color: rgba(255,255,255,.72);
  letter-spacing: 0.15em;
  text-transform: uppercase;
  font-weight: 600;
}

.wcff-post-hero-title {
  font-family: 'Oswald', sans-serif !important;
  font-size: clamp(2rem, 6vw, 4.5rem) !important;
  font-weight: 700;
  line-height: 0.98 !important;
  letter-spacing: -0.015em;
  text-transform: uppercase;
  margin: 0 0 1.5rem !important;
  max-width: 900px;
  text-shadow: 0 4px 30px rgba(0,0,0,.5);
}
.wcff-post-hero-title .year {
  color: var(--wcff-gold);
  margin-left: .25em;
}

.wcff-post-hero-chips {
  display: flex;
  gap: 2rem;
  padding: 1rem 0;
  border-top: 1px solid rgba(255,255,255,.15);
  max-width: 720px;
  flex-wrap: wrap;
}
.wcff-post-hero-chips .chip {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.wcff-post-hero-chips .chip-label {
  font-size: 10px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--wcff-gold);
  font-weight: 700;
}
.wcff-post-hero-chips .chip-value {
  font-family: 'Oswald', sans-serif;
  font-size: 17px;
  font-weight: 600;
  color: #fff;
}

@media (max-width: 820px) {
  .wcff-post-hero { min-height: 50vh; }
  .wcff-post-hero-content { padding: 2.5rem 1.25rem 2.5rem; }
  .wcff-post-hero-chips { gap: 1.25rem; }
}
@media (max-width: 640px) {
  .wcff-post-hero { min-height: 45vh; max-height: 480px; }
  .wcff-post-hero-title { font-size: clamp(1.7rem, 8vw, 2.8rem) !important; }
  .wcff-post-hero-bg { background-position: 70% center; }
  .wcff-post-hero-chips { flex-direction: column; gap: .75rem; }
}

.wcff-single-hero .wcff-hero-chip,
.wcff-single-hero .taxonomy-category {
  background: var(--wcff-gold);
  color: var(--wcff-navy-deep);
  padding: 4px 12px;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  border-radius: 2px;
  display: inline-block;
}
.wcff-single-hero .taxonomy-category a {
  color: var(--wcff-navy-deep) !important;
  text-decoration: none !important;
}
.wcff-single-meta {
  margin-top: 1rem;
  font-size: 13px;
  color: rgba(255,255,255,.7);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.wcff-single-meta .wp-block-post-date { margin: 0; }

.wcff-single-featured img {
  width: 100% !important;
  height: auto !important;
  border-radius: 6px;
  margin: 0 0 2rem !important;
  box-shadow: 0 8px 30px rgba(10,37,64,.15);
  max-width: 100% !important;
}
.wcff-single-featured.wp-block-post-featured-image { margin: 0 0 2rem; }

.wcff-single-footer {
  margin-top: 2.5rem;
  padding-top: 1.5rem;
  border-top: 1px solid var(--wcff-border);
}
.wcff-single-tags {
  font-size: 13px;
  color: #556680;
}
.wcff-single-tags a {
  color: var(--wcff-navy) !important;
  text-decoration: none !important;
  border-bottom: 1px solid var(--wcff-border);
  padding-bottom: 1px;
}
.wcff-single-tags a:hover { border-bottom-color: var(--wcff-gold); color: var(--wcff-gold) !important; }

/* ============== ARCHIVE (NEWS/CATEGORY) ============== */

.wcff-body-wide { max-width: 1200px !important; }

.wcff-archive-query .wp-block-post-template,
ul.wcff-archive-grid,
.wcff-archive-grid {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 1.5rem !important;
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
  max-width: 1200px;
  flex-direction: unset !important;
}
.wcff-archive-query .wp-block-post-template > li {
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
}

.wcff-archive-card {
  background: #fff;
  border: 1px solid var(--wcff-border);
  border-radius: 6px;
  overflow: hidden;
  display: flex !important;
  flex-direction: column;
  transition: transform .2s, box-shadow .2s;
  height: 100%;
}
.wcff-archive-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 12px 32px rgba(10,37,64,.12);
}
.wcff-archive-card .wcff-archive-media {
  aspect-ratio: 4/3;
  overflow: hidden;
  margin: 0 !important;
  background: var(--wcff-navy-soft);
}
.wcff-archive-card .wcff-archive-media img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover;
  transition: transform .4s;
  margin: 0 !important;
  max-width: none !important;
  border-radius: 0 !important;
}
.wcff-archive-card:hover .wcff-archive-media img { transform: scale(1.04); }
.wcff-archive-body {
  padding: 1.25rem 1.25rem 1.5rem;
  flex: 1;
  display: flex;
  flex-direction: column;
}
.wcff-archive-date {
  font-size: 11px !important;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--wcff-gold) !important;
  font-weight: 700;
  margin: 0 0 .5rem !important;
}
.wcff-archive-title {
  font-family: 'Oswald', sans-serif !important;
  font-size: 1.15rem !important;
  font-weight: 700 !important;
  line-height: 1.25 !important;
  margin: 0 0 .65rem !important;
  color: var(--wcff-navy-deep) !important;
}
.wcff-archive-title a {
  color: inherit !important;
  text-decoration: none !important;
}
.wcff-archive-title a:hover { color: var(--wcff-gold) !important; }
.wcff-archive-excerpt {
  font-size: 14px !important;
  line-height: 1.55;
  color: #556680 !important;
  margin: 0 !important;
  flex: 1;
}
.wcff-archive-excerpt .more-link {
  display: inline-block;
  margin-top: .75rem;
  color: var(--wcff-navy) !important;
  text-decoration: none !important;
  font-weight: 600;
  font-size: 13px;
  border-bottom: 1px solid var(--wcff-gold);
}

.wcff-pagination {
  margin-top: 2.5rem !important;
  padding-top: 2rem;
  border-top: 1px solid var(--wcff-border);
}
.wcff-pagination a, .wcff-pagination .page-numbers {
  padding: 8px 14px;
  border: 1px solid var(--wcff-border);
  border-radius: 3px;
  text-decoration: none !important;
  color: var(--wcff-navy) !important;
  font-weight: 600;
  font-size: 14px;
  background: #fff;
  margin: 0 4px;
}
.wcff-pagination .current,
.wcff-pagination a:hover {
  background: var(--wcff-navy);
  color: #fff !important;
  border-color: var(--wcff-navy);
}

/* ============== EVENT CARD + REGISTRATION FORM ============== */
.wcff-event-card {
  margin: 0 0 2rem;
  background: linear-gradient(135deg, var(--wcff-navy-deep) 0%, var(--wcff-navy) 100%);
  color: #fff;
  border-radius: 6px;
  padding: 2rem;
  border: 1px solid rgba(245,166,35,.2);
  position: relative;
  overflow: hidden;
}
.wcff-event-card::before {
  content:""; position:absolute; top:0; left:0; right:0; height:3px;
  background: linear-gradient(90deg, var(--wcff-gold), transparent 70%);
}
.wcff-event-card-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 1.25rem 2rem;
  padding-bottom: 1.25rem;
  margin-bottom: 1.5rem;
  border-bottom: 1px solid rgba(255,255,255,.12);
}
.wcff-evc-item { display:flex; flex-direction:column; gap:3px; }
.wcff-evc-item .label {
  font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--wcff-gold); font-weight: 700;
}
.wcff-evc-item .value {
  font-family: 'Oswald', sans-serif;
  font-size: 16px;
  font-weight: 600;
  color: #fff;
  letter-spacing: 0.01em;
}
.wcff-evc-cta { }

/* Registration form */
.wcff-reg-box {}
.wcff-reg-head { margin-bottom: 1.25rem; }
.wcff-reg-chip {
  display: inline-block;
  background: var(--wcff-gold);
  color: var(--wcff-navy-deep);
  padding: 4px 12px;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  border-radius: 2px;
  margin-bottom: .6rem;
}
.wcff-reg-head h3 {
  font-family: 'Oswald', sans-serif;
  font-size: 1.4rem;
  text-transform: uppercase;
  color: #fff;
  margin: 0 0 .4rem !important;
  line-height: 1.15;
}
.wcff-reg-sub { font-size: 13px; color: rgba(255,255,255,.75); margin: 0 0 1rem; }
.wcff-reg-sub strong { color: var(--wcff-gold); }

.wcff-reg-msg {
  padding: .85rem 1.1rem;
  border-left: 4px solid var(--wcff-gold);
  background: rgba(245,166,35,.1);
  margin-bottom: 1rem;
  border-radius: 0 3px 3px 0;
  font-size: 14px;
}
.wcff-reg-msg .ok  { color: #9bf39b; font-weight: 600; }
.wcff-reg-msg .err { color: #ff8f8f; font-weight: 600; }

.wcff-reg-form .grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: .75rem 1rem;
  margin-bottom: 1rem;
}
.wcff-reg-form .grid > p { margin: 0; }
.wcff-reg-form label {
  display: block;
  font-size: 11px !important;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--wcff-gold) !important;
  margin-bottom: .3rem;
}
.wcff-reg-form input[type="text"],
.wcff-reg-form input[type="email"],
.wcff-reg-form input[type="tel"],
.wcff-reg-form input[type="date"],
.wcff-reg-form input[type="number"],
.wcff-reg-form select {
  width: 100%;
  margin-top: 4px;
  padding: 10px 12px;
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(255,255,255,.06);
  color: #fff;
  font-family: 'Inter', sans-serif;
  font-size: 14px;
  border-radius: 3px;
  box-sizing: border-box;
  transition: all .15s;
}
.wcff-reg-form input:focus,
.wcff-reg-form select:focus {
  outline: 0;
  background: rgba(255,255,255,.1);
  border-color: var(--wcff-gold);
  box-shadow: 0 0 0 3px rgba(245,166,35,.15);
}
.wcff-reg-form select option { color: #1a2b42; background: #fff; }
.wcff-reg-form button {
  display: inline-flex; align-items: center; gap: .5rem;
  padding: .85rem 1.75rem;
  background: var(--wcff-gold);
  color: var(--wcff-navy-deep);
  border: 0;
  font-weight: 800;
  font-size: 13px;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  border-radius: 3px;
  cursor: pointer;
  transition: all .2s;
  font-family: 'Inter', sans-serif;
}
.wcff-reg-form button:hover { background: #fff; transform: translateY(-1px); box-shadow: 0 8px 20px rgba(245,166,35,.35); }

.wcff-reg-cta { margin-top: 1rem; }
.wcff-reg-closed {
  font-size: 13px;
  color: rgba(255,255,255,.65);
  padding: .75rem;
  background: rgba(255,255,255,.04);
  border-left: 3px solid rgba(245,166,35,.5);
  border-radius: 0 3px 3px 0;
}

@media (max-width: 640px) {
  .wcff-event-card { padding: 1.5rem 1.25rem; margin: 0 -1rem 1.5rem; border-radius: 0; }
  .wcff-reg-form .grid { grid-template-columns: 1fr; }
}

/* ============== PARTNERS BLOCK ============== */
.wcff-partners {
  background: #fafbfc;
  padding: 4rem 1.5rem;
  border-top: 1px solid var(--wcff-border);
}
.wcff-partners .wcff-section-head {
  max-width: 1200px;
  margin: 0 auto 2rem;
  padding: 0;
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  border-bottom: 2px solid var(--wcff-gold);
  padding-bottom: .75rem;
}
.wcff-partners .wcff-section-head h2 {
  font-family: 'Oswald', sans-serif !important;
  font-size: clamp(1.4rem, 2.5vw, 2rem) !important;
  text-transform: uppercase;
  color: var(--wcff-navy-deep);
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
}
.wcff-partners-grid {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 1rem;
}
.wcff-partner-card {
  display: block;
  padding: 1.5rem 1.5rem;
  background: #fff;
  border: 1px solid var(--wcff-border);
  border-left: 3px solid var(--wcff-gold);
  border-radius: 4px;
  text-decoration: none !important;
  color: var(--wcff-navy);
  transition: all .2s;
  position: relative;
}
.wcff-partner-card:hover {
  transform: translateY(-3px);
  border-left-color: var(--wcff-navy-deep);
  background: var(--wcff-navy-deep);
  color: #fff;
  box-shadow: 0 14px 30px rgba(10,37,64,.18);
}
.wcff-partner-role {
  font-size: 11px;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--wcff-gold);
  font-weight: 700;
  margin-bottom: .6rem;
}
.wcff-partner-name {
  font-family: 'Oswald', sans-serif;
  font-size: 1.6rem;
  font-weight: 700;
  letter-spacing: 0.01em;
  margin-bottom: .3rem;
  color: inherit;
}
.wcff-partner-full {
  font-size: 13px;
  line-height: 1.4;
  opacity: .8;
  margin-bottom: 1rem;
}
.wcff-partner-link {
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--wcff-gold);
  font-weight: 700;
}
.wcff-partner-card:hover .wcff-partner-link { color: var(--wcff-gold); }

@media (max-width: 640px) {
  .wcff-partners { padding: 3rem 1rem; }
  .wcff-partners-grid { grid-template-columns: 1fr; }
}

/* Footnote */
.wcff-footnote {
  margin-top: 3rem;
  padding-top: 1.5rem;
  border-top: 1px solid var(--wcff-border);
  font-size: 13px;
  color: #556680;
  text-align: center;
}
.wcff-footnote a { color: var(--wcff-navy); border-bottom: 1px solid var(--wcff-gold); text-decoration: none !important; }

/* Galleries-like wrapping after image */
.wcff-page-content br + br { display: none; }

/* Tables — clean, professional */
.wcff-page-content table,
.wp-block-post-content table {
  width: 100%;
  border-collapse: collapse;
  margin: 1.5rem 0;
  font-size: 14px;
  border: 0;
  background: #fff;
  border-radius: 6px;
  overflow: hidden;
  box-shadow: 0 1px 2px rgba(10,37,64,.04);
}
.wcff-page-content table th,
.wcff-page-content table td,
.wp-block-post-content table th,
.wp-block-post-content table td {
  padding: .7rem 1rem;
  border: 0;
  border-bottom: 1px solid var(--wcff-border);
  text-align: left;
  vertical-align: middle;
}
.wcff-page-content table td.num,
.wcff-page-content table th.num,
.wp-block-post-content table td.num { text-align: center; font-variant-numeric: tabular-nums; }
.wcff-page-content table tbody tr:hover,
.wp-block-post-content table tbody tr:hover { background: #f7f9fc; }
.wcff-page-content table thead th,
.wp-block-post-content table thead th {
  background: var(--wcff-navy);
  color: #fff;
  font-weight: 700;
  text-transform: uppercase;
  font-size: 11px;
  letter-spacing: 0.08em;
  border: 0;
}
.wcff-page-content table tr:last-child td,
.wp-block-post-content table tr:last-child td { border-bottom: 0; }

/* YouTube auto-embeds look decent */
.wcff-page-content iframe,
.wcff-page-content .wp-block-embed__wrapper iframe,
.wp-block-post-content iframe {
  max-width: 100%;
  aspect-ratio: 16/9;
  height: auto !important;
  border: 0;
  border-radius: 4px;
  margin: 1rem 0;
  display: block;
  width: 100%;
}
.wp-block-embed {
  margin: 1.5rem 0;
}

/* Bare YouTube URLs that didn't auto-embed — at least style as inline link */
.wcff-page-content p > a[href*="youtube.com"],
.wcff-page-content p > a[href*="youtu.be"] {
  display: inline-block;
  padding: .3rem .7rem;
  background: #ffefc7;
  border-radius: 3px;
  font-size: 13px;
  margin: .25rem 0;
}

/* Lists */
.wcff-page-content ul,
.wcff-page-content ol,
.wp-block-post-content ul,
.wp-block-post-content ol { padding-left: 1.25rem; margin: 1rem 0; }
.wcff-page-content li,
.wp-block-post-content li { margin-bottom: .35rem; line-height: 1.6; }

/* Clearfix after floats */
.wcff-page-content::after,
.wp-block-post-content::after { content:""; display: block; clear: both; }

/* Legacy centered-bold paragraphs (used as pseudo-headings/taglines) */
.wcff-page-content p[align="center"],
.wp-block-post-content p[align="center"],
.wcff-page-content p.has-text-align-center,
.wp-block-post-content p.has-text-align-center {
  text-align: center;
  font-size: 17px;
  margin: 1rem auto 1.25rem;
}
.wcff-page-content p[align="center"]:has(> b:only-child),
.wp-block-post-content p[align="center"]:has(> b:only-child) {
  font-family: 'Oswald', sans-serif;
  font-size: clamp(1.1rem, 1.6vw, 1.35rem);
  text-transform: uppercase;
  letter-spacing: 0.02em;
  color: var(--wcff-navy-deep);
  font-weight: 600;
  margin: 2rem auto 0.75rem;
  max-width: 780px;
  line-height: 1.3;
}
.wcff-page-content p[align="center"] > b,
.wp-block-post-content p[align="center"] > b { font-weight: 600; }

/* Sequential centered-bold paragraphs form a "banner" — tighten spacing */
.wcff-page-content p[align="center"] + p[align="center"],
.wp-block-post-content p[align="center"] + p[align="center"] {
  margin-top: 0.1rem !important;
  font-size: 14px;
  color: #334;
  text-transform: none;
  letter-spacing: 0;
  font-family: 'Inter', sans-serif;
  font-weight: 500;
}

/* Center-aligned blockwrap — wrap a banner */
.wcff-page-content p[align="center"]:first-child,
.wcff-page-content p[align="center"]:not(:has(+ p[align="center"])) + p[align="center"]:last-child {
  margin-bottom: 1rem;
}

/* Images inside links (legacy wrap): remove link underline, add subtle ring on hover */
.wcff-page-content a:has(> img),
.wp-block-post-content a:has(> img) {
  display: inline-block;
  border: 0 !important;
  text-decoration: none !important;
  transition: transform .2s, box-shadow .2s;
  border-radius: 4px;
  overflow: hidden;
  line-height: 0;
}
.wcff-page-content a:has(> img):hover,
.wp-block-post-content a:has(> img):hover {
  transform: translateY(-2px);
  box-shadow: 0 10px 28px rgba(10,37,64,.18);
}

/* Consecutive images → auto gallery */
.wcff-page-content p:has(> a > img) + p:has(> a > img),
.wp-block-post-content p:has(> a > img) + p:has(> a > img) {
  display: inline-block;
  margin-right: .5rem;
  margin-bottom: .5rem;
}

/* Blockquote-style for lone <strong> as section marker */
.wcff-page-content strong:first-child:not(:has(+ *)):only-child,
.wp-block-post-content strong:first-child {
  font-family: 'Oswald', sans-serif;
  letter-spacing: 0.01em;
}

/* Sequential bold labels → styled as chips row */
.wcff-page-content p > b:only-child,
.wp-block-post-content p > b:only-child {
  display: inline-block;
}

/* Underlined text decoration (legacy "underline") */
.wcff-page-content span[style*="text-decoration: underline"],
.wp-block-post-content span[style*="text-decoration: underline"] {
  text-decoration: none !important;
  border-bottom: 2px solid var(--wcff-gold);
  padding-bottom: 2px;
}

/* Video page: if content is just list of YouTube URLs, render each as embed */
.wcff-video-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(380px, 1fr));
  gap: 1.5rem;
  margin: 2rem 0;
}
.wcff-video-grid iframe { width: 100%; aspect-ratio: 16/9; height: auto !important; border: 0; border-radius: 4px; }

/* PDF download buttons (Arthemia had these) */
.wcff-page-content a[href$=".pdf"],
.wp-block-post-content a[href$=".pdf"] {
  display: inline-block;
  padding: .5rem 1rem;
  background: var(--wcff-gold);
  color: var(--wcff-navy-deep) !important;
  font-weight: 700;
  text-decoration: none !important;
  border-radius: 3px;
  margin: .3rem 0;
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}
.wcff-page-content a[href$=".pdf"]:hover,
.wp-block-post-content a[href$=".pdf"]:hover { background: var(--wcff-navy); color: #fff !important; }

/* ============== FOOTER ============== */
/* Footer */
.wcff-footer {
  background: var(--wcff-navy-deep);
  color: rgba(255,255,255,.8);
  padding: 3rem 1rem 1.5rem;
  border-top: 3px solid var(--wcff-gold);
}
.wcff-footer a { color: rgba(255,255,255,.9); text-decoration: none; }
.wcff-footer a:hover { color: var(--wcff-gold); }
.wcff-footer .cols {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 2rem;
  max-width: 1200px;
  margin: 0 auto 2rem;
}
.wcff-footer h4 {
  color: var(--wcff-gold);
  text-transform: uppercase;
  font-size: .85rem;
  letter-spacing: 0.1em;
  margin: 0 0 1rem;
}
.wcff-footer .copyright {
  text-align: center;
  border-top: 1px solid rgba(255,255,255,.1);
  padding-top: 1.5rem;
  max-width: 1200px;
  margin: 0 auto;
  font-size: .85rem;
  opacity: .7;
}

/* Responsive */
/* ============== RESPONSIVE ============== */

@media (max-width: 980px) {
  .wcff-posts-grid,
  .wcff-quicklinks,
  .wcff-archive-query .wp-block-post-template,
  .wcff-archive-grid { grid-template-columns: repeat(2, 1fr); }
  .wcff-catbar { grid-template-columns: 1fr; }
  .wcff-catbar-tile { border-right: 0; border-bottom: 1px solid rgba(255,255,255,.08); }
  .wcff-section.dark { padding-left: 1rem; padding-right: 1rem; }
  .wcff-footer .cols { grid-template-columns: repeat(2, 1fr); }
  .wcff-page-content { padding: 2rem 1.75rem; }
}

/* Tablet + small */
@media (max-width: 820px) {
  .wcff-header {
    padding: 0.6rem 1rem;
  }
  .wcff-header .wp-block-site-logo img { max-height: 48px; }
  .wcff-header .wp-block-navigation {
    font-size: 12px;
  }
  .wcff-lang-switch {
    margin-left: .5rem;
  }
  .wcff-lang-switch a { padding: 3px 7px; font-size: 10px; }
  .wcff-page-hero { padding: 2.25rem 1rem 2.5rem; }
  .wcff-page-body { padding: 2.5rem 1rem 3.5rem; }
}

/* Phones */
@media (max-width: 640px) {
  .wcff-headline {
    min-height: 380px;
    padding: 3rem 1rem 2rem;
    align-items: center;
  }
  .wcff-headline h1 { font-size: 1.8rem; }
  .wcff-headline .wcff-lead { font-size: 15px; max-width: 100%; margin-bottom: 1.2rem; }

  .wcff-posts-grid,
  .wcff-quicklinks,
  .wcff-archive-query .wp-block-post-template,
  .wcff-archive-grid { grid-template-columns: 1fr; gap: 1rem; }

  .wcff-footer .cols { grid-template-columns: 1fr; }

  .wcff-page-hero { padding: 2rem 1rem 2.25rem; }
  .wcff-page-hero-title,
  .wcff-page-hero .wp-block-post-title { font-size: 1.8rem; }
  .wcff-page-hero-bar { flex-wrap: wrap; gap: .5rem; }

  .wcff-page-body { padding: 1.75rem 0.75rem 2.5rem; background: #fff; }
  .wcff-page-content {
    padding: 1.5rem 1.25rem;
    box-shadow: none;
    border: 0;
    border-radius: 0;
  }
  .wcff-page-content h2 { font-size: 1.35rem; margin: 2rem 0 .75rem; }
  .wcff-page-content h3 { font-size: 1.05rem; }
  .wcff-page-content p { font-size: 15.5px; }
  .wcff-lead, .wcff-page-content p.wcff-lead { font-size: 16px; margin-bottom: 1.5rem; padding-bottom: 1.25rem; }

  /* Events: vertical */
  .wcff-event {
    grid-template-columns: 1fr;
    gap: .5rem;
    padding: 1rem;
  }
  .wcff-event-date { flex-direction: row; align-items: baseline; gap: .6rem; }
  .wcff-event-date .day { font-size: 1rem; }
  .wcff-event-date .month { margin-top: 0; }

  /* Admin cards: stack */
  .wcff-admin-card { flex-direction: column; }
  .wcff-admin-photo {
    flex: 0 0 auto;
    aspect-ratio: 4/3;
    width: 100%;
    max-height: 240px;
  }

  /* Camp hero: stack */
  .wcff-camp-hero-grid { grid-template-columns: 1fr; }
  .wcff-camp-hero-grid > div { padding: 1.25rem; }
  .wcff-camp-hero-image img { max-height: 220px; }

  /* Variants + weight: full width */
  .wcff-variant-row,
  .wcff-weight-grid,
  .wcff-contact-grid,
  .wcff-styles-grid { grid-template-columns: 1fr; }

  /* Tables on mobile — horizontally scrollable */
  .wcff-page-content { overflow-x: auto; }
  .wcff-page-content table { min-width: 500px; font-size: 13px; }
  .wcff-page-content table th,
  .wcff-page-content table td { padding: .55rem .6rem; }

  /* Single post featured image */
  .wcff-single-featured img { border-radius: 4px; }

  /* Gallery on phone: 2 cols */
  .wcff-gallery { grid-template-columns: repeat(2, 1fr); }
  .wcff-gallery img { height: 140px !important; }

  /* Video grid on phone */
  .wcff-video-grid { grid-template-columns: 1fr; }
}

/* Extra-small */
@media (max-width: 380px) {
  .wcff-header .wp-block-site-logo img { max-height: 40px; }
  .wcff-page-hero-title,
  .wcff-page-hero .wp-block-post-title { font-size: 1.5rem; }
  .wcff-gallery { grid-template-columns: 1fr; }
}
