/* ════════════════════════════════════════════════════════════
   MATT6MEE PHOTOGRAPHY — Design System
   v1.1.0 — 2026 Bold Editorial Theme
   Aesthetic: Complex Minimalist · Bento Grid · Kinetic Type
   ════════════════════════════════════════════════════════════ */

/* ── 1. DESIGN TOKENS ────────────────────────────────────── */
:root {
  /* Palette — Dark mode (default) */
  --bg:            #121212;
  --bg-2:          #1A1A1A;
  --bg-3:          #222222;
  --bg-glass:      rgba(18, 18, 18, 0.75);
  --surface:       #1E1E1E;
  --surface-hover: #272727;
  --border:        rgba(255,255,255,0.08);
  --border-strong: rgba(255,255,255,0.16);

  --text-primary:   #F0EDE8;
  --text-secondary: #A8A49F;
  --text-muted:     #666462;

  --accent:       #C9A84C;   /* Gold */
  --accent-hover: #E2BF6A;
  --accent-dim:   rgba(201,168,76,0.15);
  --accent-glass: rgba(201,168,76,0.08);

  --danger:  #E05C5C;
  --success: #5CBA80;

  /* Score card surface — distinct from main bg so the card reads as a block */
  --score-card-bg:     #2E2C2C;
  --score-card-border: rgba(255,255,255,0.10);
  --score-card-text:   #FAFAFA;

  /* ── Typography ── */
  /* Display / headline font — Bebas Neue for all uppercase titles */
  --font-display: 'Bebas Neue', 'Impact', sans-serif;
  /* Body / prose copy */
  --font-body:    'DM Sans', 'Helvetica Neue', sans-serif;
  /* UI meta labels — venue, competition, league, upcoming details */
  --font-meta:    'Google Sans Flex', 'Google Sans', 'DM Sans', sans-serif;

  /* Fluid type scale */
  --fs-hero:   clamp(5rem, 14vw, 14rem);
  --fs-h1:     clamp(2.5rem, 6vw, 5rem);
  --fs-h2:     clamp(1.8rem, 3.5vw, 3rem);
  --fs-h3:     clamp(1.2rem, 2vw, 1.6rem);
  --fs-body:   1rem;
  --fs-small:  0.875rem;
  --fs-xs:     0.75rem;

  /* Line heights */
  --lh-tight:  1.05;
  --lh-normal: 1.55;
  --lh-loose:  1.75;

  /* Letter-spacing scale
     --ls-display  large display / headline titles
     --ls-caps     small uppercase labels, badges, section labels
     --ls-body     running body copy (near-zero, improves DM Sans legibility)
     --ls-mono     monospaced-feel numbers, scorelines                        */
  --ls-display: 0.02em;
  --ls-caps:    0.10em;
  --ls-body:    0.01em;
  --ls-mono:    0.08em;

  /* Spacing */
  --space-xs:   0.25rem;
  --space-sm:   0.5rem;
  --space-md:   1rem;
  --space-lg:   1.5rem;
  --space-xl:   2.5rem;
  --space-2xl:  4rem;
  --space-3xl:  7rem;
  --space-section: clamp(4rem, 8vw, 8rem);

  /* Layout */
  --max-w:     1440px;
  --gutter:    clamp(1.2rem, 4vw, 3rem);
  --radius-sm: 6px;
  --radius-md: 12px;
  --radius-lg: 20px;
  --radius-xl: 32px;

  /* Motion */
  --ease-out:    cubic-bezier(0.22, 1, 0.36, 1);
  --ease-spring: cubic-bezier(0.34, 1.56, 0.64, 1);
  --ease-in:     cubic-bezier(0.4, 0, 1, 1);
  --dur-fast:    150ms;
  --dur-normal:  300ms;
  --dur-slow:    600ms;
  --dur-reveal:  900ms;

  /* Shadows */
  --shadow-sm: 0 2px 8px rgba(0,0,0,0.3);
  --shadow-md: 0 8px 32px rgba(0,0,0,0.4);
  --shadow-lg: 0 24px 64px rgba(0,0,0,0.5);
  --glow-gold: 0 0 40px rgba(201,168,76,0.25);

  /* Header */
  --header-h: 64px;
}

/* ── LIGHT MODE ──────────────────────────────────────────── */
@media (prefers-color-scheme: light) {
  :root {
    --bg:            #F5F1EB;
    --bg-2:          #EDE9E3;
    --bg-3:          #E5E0D9;
    --bg-glass:      rgba(245,241,235,0.80);
    --surface:       #FFFFFF;
    --surface-hover: #F0EDE8;
    --border:        rgba(0,0,0,0.08);
    --border-strong: rgba(0,0,0,0.16);
    --text-primary:  #1A1714;
    --text-secondary:#5C5754;
    --text-muted:    #9C9490;
    --shadow-sm:     0 2px 8px rgba(0,0,0,0.08);
    --shadow-md:     0 8px 32px rgba(0,0,0,0.12);
    --shadow-lg:     0 24px 64px rgba(0,0,0,0.16);
    --glow-gold:     0 0 40px rgba(201,168,76,0.18);
    /* Score card in light mode uses the parchment swatch from the brand palette */
    --score-card-bg:     #C1BDBD;
    --score-card-border: rgba(0,0,0,0.10);
    --score-card-text:   #1A1714;
  }
}


/* ── 2. RESET & BASE ──────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html {
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
  hanging-punctuation: first last;
}

body {
  background-color: var(--bg);
  color: var(--text-primary);
  font-family: var(--font-body);
  font-size: var(--fs-body);
  line-height: var(--lh-normal);
  letter-spacing: var(--ls-body);
  font-weight: 300;
  min-height: 100dvh;
  overflow-x: hidden;
  transition: background-color var(--dur-slow) var(--ease-out),
              color var(--dur-slow) var(--ease-out);
}

img, video { display: block; max-width: 100%; height: auto; }

a { color: var(--accent); text-decoration: none; transition: color var(--dur-fast); }
a:hover { color: var(--accent-hover); }
a:focus-visible { outline: 2px solid var(--accent); outline-offset: 3px; border-radius: 2px; }

/* ── Headings: Bebas Neue, always uppercase ──────────────── */
h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-display);
  font-weight: 400;
  letter-spacing: var(--ls-display);
  line-height: var(--lh-tight);
  color: var(--text-primary);
  text-transform: uppercase;
}

p { color: var(--text-secondary); letter-spacing: var(--ls-body); }

::selection { background: var(--accent); color: #000; }


/* ── 3. HEADER ────────────────────────────────────────────── */
.site-header {
  position: fixed;
  top: 0; left: 0; right: 0;
  height: var(--header-h);
  z-index: 900;
  backdrop-filter: blur(20px) saturate(180%);
  -webkit-backdrop-filter: blur(20px) saturate(180%);
  background: var(--bg-glass);
  border-bottom: 1px solid var(--border);
  transition: box-shadow var(--dur-normal) var(--ease-out),
              background var(--dur-normal) var(--ease-out);
}
.site-header.scrolled {
  box-shadow: var(--shadow-md);
  background: var(--bg-glass);
}

.header-inner {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 0 var(--gutter);
  height: 100%;
  display: flex;
  align-items: center;
  gap: var(--space-xl);
}

/* Logo */
.site-logo { display: flex; align-items: center; gap: 10px; text-decoration: none; flex-shrink: 0; }
.site-logo img { height: 36px; width: auto; }
.logo-wordmark { display: flex; flex-direction: column; line-height: 1; gap: 1px; }
.logo-name {
  font-family: var(--font-display);
  font-size: 1.4rem;
  letter-spacing: var(--ls-caps);
  color: var(--text-primary);
  text-transform: uppercase;
}
.logo-sub {
  font-size: 0.6rem;
  font-weight: 500;
  letter-spacing: .25em;
  text-transform: uppercase;
  color: var(--accent);
}

/* Nav */
.primary-nav { flex: 1; }
.nav-list {
  list-style: none;
  display: flex;
  align-items: center;
  gap: clamp(1rem, 2vw, 2rem);
}
.nav-list a {
  font-size: var(--fs-small);
  font-weight: 400;
  letter-spacing: var(--ls-caps);
  text-transform: uppercase;
  color: var(--text-secondary);
  text-decoration: none;
  position: relative;
  padding-bottom: 2px;
  transition: color var(--dur-fast);
}
.nav-list a::after {
  content: '';
  position: absolute;
  bottom: -2px; left: 0;
  width: 0; height: 1px;
  background: var(--accent);
  transition: width var(--dur-normal) var(--ease-out);
}
.nav-list a:hover,
.nav-list .current-menu-item > a { color: var(--text-primary); }
.nav-list a:hover::after,
.nav-list .current-menu-item > a::after { width: 100%; }

/* Header actions */
.header-actions { display: flex; align-items: center; gap: var(--space-md); flex-shrink: 0; }

.btn-contact {
  display: none;
  padding: 8px 18px;
  border: 1px solid var(--accent);
  border-radius: 100px;
  font-size: var(--fs-xs);
  font-weight: 500;
  letter-spacing: var(--ls-caps);
  text-transform: uppercase;
  color: var(--accent);
  text-decoration: none;
  transition: background var(--dur-fast), color var(--dur-fast);
}
.btn-contact:hover { background: var(--accent); color: #000; }
@media (min-width: 900px) { .btn-contact { display: inline-flex; } }

.nav-toggle {
  display: flex;
  flex-direction: column;
  gap: 5px;
  padding: 8px;
  background: none;
  border: none;
  cursor: pointer;
  color: var(--text-primary);
  border-radius: var(--radius-sm);
  transition: background var(--dur-fast);
}
.nav-toggle:hover { background: var(--surface-hover); }
@media (min-width: 900px) { .nav-toggle { display: none; } }

.burger-line {
  display: block;
  width: 22px; height: 1.5px;
  background: currentColor;
  transition: transform var(--dur-normal) var(--ease-out), opacity var(--dur-fast);
  transform-origin: center;
}
.nav-toggle[aria-expanded="true"] .burger-line:nth-child(1) { transform: translateY(6.5px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] .burger-line:nth-child(2) { opacity: 0; }
.nav-toggle[aria-expanded="true"] .burger-line:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); }

/* Mobile overlay */
.mobile-nav-overlay {
  position: fixed;
  inset: 0;
  z-index: 800;
  background: var(--bg);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--dur-normal) var(--ease-out);
}
.mobile-nav-overlay.open { opacity: 1; pointer-events: all; }

.mobile-nav-list {
  list-style: none;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-lg);
}
.mobile-nav-list a {
  font-family: var(--font-display);
  font-size: clamp(2.5rem, 8vw, 4rem);
  letter-spacing: var(--ls-display);
  text-transform: uppercase;
  color: var(--text-primary);
  text-decoration: none;
  transition: color var(--dur-fast);
}
.mobile-nav-list a:hover { color: var(--accent); }

.mobile-nav-social { margin-top: var(--space-2xl); display: flex; gap: var(--space-lg); justify-content: center; }
.mobile-nav-social a { color: var(--text-secondary); transition: color var(--dur-fast); }
.mobile-nav-social a:hover { color: var(--accent); }


/* ── 4. MAIN CONTENT OFFSET ──────────────────────────────── */
.main-content, .hero { padding-top: var(--header-h); }
.hero { padding-top: 0; }


/* ── 5. HERO SECTION ─────────────────────────────────────── */
.hero {
  position: relative;
  min-height: 100dvh;
  display: flex;
  align-items: center;
  overflow: hidden;
}

.hero-bg {
  position: absolute;
  inset: 0;
  will-change: transform;
}
.hero-img {
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: center;
  transform: scale(1.05);
  transition: transform 8s linear;
}
.hero:hover .hero-img { transform: scale(1.0); }
.hero-placeholder { width: 100%; height: 100%; background: linear-gradient(135deg, #1A1A1A, #0A0A0A); }
.hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to bottom,
    rgba(12,12,12,0.3) 0%,
    rgba(12,12,12,0.55) 40%,
    rgba(12,12,12,0.85) 80%,
    rgba(12,12,12,0.98) 100%
  );
}

.hero-content {
  position: relative;
  z-index: 2;
  max-width: var(--max-w);
  width: 100%;
  margin: 0 auto;
  padding: calc(var(--header-h) + 3rem) var(--gutter) var(--space-3xl);
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--space-xl);
}

/*
 * Hero eyebrow — sentence-case (overrides the global heading uppercase rule).
 * The tagline reads as a descriptor, not a display headline.
 */
.hero-eyebrow {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  opacity: 0;
  transform: translateY(20px);
  animation: reveal var(--dur-reveal) var(--ease-out) .2s forwards;
}
.eyebrow-line { display: block; width: 40px; height: 1px; background: var(--accent); flex-shrink: 0; }
.eyebrow-text {
  font-family: var(--font-meta);
  font-size: var(--fs-xs);
  font-weight: 500;
  letter-spacing: var(--ls-caps);
  /* Regular capitalisation — not uppercase. The tagline is sentence-case copy. */
  text-transform: none;
  color: var(--accent);
}

.hero-headline {
  display: flex;
  flex-direction: column;
  font-size: var(--fs-hero);
  line-height: .9;
  letter-spacing: -.01em;
  color: var(--text-primary);
  pointer-events: none;
}
.headline-line {
  display: block;
  text-transform: uppercase;
  opacity: 0;
  transform: translateY(60px) skewY(2deg);
  animation: headline-reveal var(--dur-reveal) var(--ease-out) forwards;
}
.headline-line[data-reveal-delay="0"] { animation-delay: .35s; }
.headline-line[data-reveal-delay="1"] { animation-delay: .5s; color: transparent; -webkit-text-stroke: 2px var(--text-primary); }

/*
 * Hero subheading — sentence-case body copy sitting over the image.
 * Uses --font-meta (Google Sans Flex) at a light weight for legibility.
 * text-transform: none overrides the global h1-h6 uppercase rule.
 */
.hero-sub {
  font-family: var(--font-meta);
  font-size: clamp(1.65rem, 5vw, 3.25rem);
  font-weight: 300;
  letter-spacing: var(--ls-display);
  line-height: 1.15;
  color: #FAFAFA;
  max-width: 680px;
  /* Sentence-case — this is descriptive prose, not a display title. */
  text-transform: none;
  opacity: 0;
  transform: translateY(20px);
  animation: reveal var(--dur-reveal) var(--ease-out) .65s forwards;
}

.hero-actions {
  display: flex;
  gap: var(--space-md);
  flex-wrap: wrap;
  opacity: 0;
  transform: translateY(20px);
  animation: reveal var(--dur-reveal) var(--ease-out) .8s forwards;
}

/* Scroll hint */
.hero-scroll-hint {
  position: absolute;
  bottom: var(--space-xl);
  left: 50%;
  transform: translateX(-50%);
  z-index: 2;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-sm);
  animation: bob 2.5s ease-in-out infinite 2s;
}
.scroll-mouse {
  width: 22px; height: 34px;
  border: 1.5px solid rgba(255,255,255,0.3);
  border-radius: 100px;
  display: flex;
  justify-content: center;
  padding-top: 6px;
}
.scroll-wheel {
  width: 3px; height: 6px;
  background: var(--accent);
  border-radius: 100px;
  animation: scroll-wheel 1.8s ease-in-out infinite;
}


/* ── 6. BUTTONS ──────────────────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 14px 28px;
  font-family: var(--font-body);
  font-size: var(--fs-small);
  font-weight: 500;
  letter-spacing: var(--ls-caps);
  text-transform: uppercase;
  text-decoration: none;
  border: none;
  border-radius: 100px;
  cursor: pointer;
  transition: transform var(--dur-fast) var(--ease-spring),
              box-shadow var(--dur-fast),
              background var(--dur-fast),
              color var(--dur-fast);
  position: relative;
  overflow: hidden;
  white-space: nowrap;
}
.btn:active { transform: scale(0.97); }
.btn svg { flex-shrink: 0; transition: transform var(--dur-fast) var(--ease-out); }
.btn:hover svg { transform: translateX(3px); }

.btn-primary {
  background: var(--accent);
  color: #000;
  box-shadow: 0 4px 20px rgba(201,168,76,0.3);
}
.btn-primary:hover {
  background: var(--accent-hover);
  color: #000;
  box-shadow: 0 8px 32px rgba(201,168,76,0.45);
  transform: translateY(-2px);
}

.btn-ghost {
  background: transparent;
  color: var(--text-primary);
  border: 1px solid var(--border-strong);
}
.btn-ghost:hover {
  background: var(--surface-hover);
  color: var(--text-primary);
  border-color: var(--text-muted);
}

.btn-sm { padding: 9px 18px; font-size: var(--fs-xs); }
.btn-lg { padding: 18px 36px; font-size: var(--fs-body); }


/* ── 7. SECTION STRUCTURE ────────────────────────────────── */
.section-portfolio-bento,
.section-albums-teaser,
.section-about-strip,
.stats-strip {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: var(--space-section) var(--gutter);
}

.section-header {
  display: flex;
  align-items: flex-end;
  gap: var(--space-lg);
  margin-bottom: var(--space-2xl);
  flex-wrap: wrap;
}

/* Section label — small accent-coloured eyebrow above the title */
.section-label {
  font-family: var(--font-meta);
  font-size: var(--fs-xs);
  font-weight: 500;
  letter-spacing: var(--ls-caps);
  text-transform: uppercase;
  color: var(--accent);
  display: block;
  flex-shrink: 0;
  align-self: center;
}

/* Section title — Bebas Neue, uppercase, display scale */
.section-title {
  font-family: var(--font-display);
  font-size: var(--fs-h2);
  letter-spacing: var(--ls-display);
  text-transform: uppercase;
  flex: 1;
  min-width: 0;
}

.section-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: var(--fs-small);
  font-weight: 500;
  letter-spacing: var(--ls-caps);
  text-transform: uppercase;
  color: var(--text-secondary);
  text-decoration: none;
  flex-shrink: 0;
  transition: color var(--dur-fast);
}
.section-link:hover { color: var(--accent); }
.section-link svg { transition: transform var(--dur-fast) var(--ease-out); }
.section-link:hover svg { transform: translateX(3px); }


/* ── 8. BENTO GRID ───────────────────────────────────────── */
.bento-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-auto-rows: 260px;
  gap: 10px;
}
@media (max-width: 1024px) {
  .bento-grid { grid-template-columns: repeat(3, 1fr); grid-auto-rows: 220px; }
}
@media (max-width: 768px) {
  .bento-grid { grid-template-columns: repeat(2, 1fr); grid-auto-rows: 200px; }
}
@media (max-width: 480px) {
  .bento-grid { grid-template-columns: 1fr 1fr; grid-auto-rows: 160px; }
}

.bento-item {
  position: relative;
  overflow: hidden;
  border-radius: var(--radius-md);
  background: var(--bg-3);
  cursor: pointer;
  outline: none;
}
.bento-item:focus-visible { outline: 2px solid var(--accent); outline-offset: 3px; }

.bento-small { grid-column: span 1; grid-row: span 1; }
.bento-wide  { grid-column: span 2; grid-row: span 1; }
.bento-tall  { grid-column: span 1; grid-row: span 2; }
.bento-large { grid-column: span 2; grid-row: span 2; }

@media (max-width: 480px) {
  .bento-wide, .bento-large { grid-column: span 2; }
  .bento-tall { grid-column: span 1; grid-row: span 2; }
}

.bento-img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform var(--dur-slow) var(--ease-out);
}
.bento-item:hover .bento-img { transform: scale(1.06); }

.bento-placeholder { width: 100%; height: 100%; background: var(--bg-3); }

.bento-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(10,10,10,0.85) 0%, transparent 55%);
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: var(--space-lg);
  opacity: 0;
  transition: opacity var(--dur-normal) var(--ease-out);
}
.bento-item:hover .bento-overlay,
.bento-item:focus-visible .bento-overlay { opacity: 1; }

/* Category label inside bento — small uppercase, accent-coloured */
.bento-cat {
  font-family: var(--font-meta);
  font-size: var(--fs-xs);
  font-weight: 500;
  letter-spacing: var(--ls-caps);
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 4px;
}

/* Bento title — Bebas Neue, uppercase */
.bento-title {
  font-family: var(--font-display);
  font-size: clamp(1rem, 2vw, 1.4rem);
  letter-spacing: var(--ls-display);
  text-transform: uppercase;
  color: #fff;
  line-height: 1.1;
}

.bento-expand {
  position: absolute;
  top: var(--space-md);
  right: var(--space-md);
  width: 36px; height: 36px;
  background: rgba(255,255,255,0.12);
  backdrop-filter: blur(8px);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  transition: background var(--dur-fast), transform var(--dur-fast) var(--ease-spring);
}
.bento-item:hover .bento-expand { background: var(--accent); color: #000; transform: rotate(90deg); }

.bento-empty {
  text-align: center;
  padding: var(--space-3xl) var(--gutter);
  color: var(--text-muted);
}


/* ── 9. STATS STRIP ──────────────────────────────────────── */
.stats-strip {
  padding-top: 0;
  padding-bottom: 0;
}
.stats-inner {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: var(--border);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
}
@media (max-width: 640px) {
  .stats-inner { grid-template-columns: repeat(2, 1fr); }
}

.stat-item {
  background: var(--surface);
  padding: clamp(1.5rem, 4vw, 2.5rem);
  display: flex;
  flex-direction: column;
  gap: 6px;
  align-items: center;
  text-align: center;
}

/* Stat number — Bebas Neue, gold, display scale */
.stat-value {
  font-family: var(--font-display);
  font-size: clamp(2.5rem, 5vw, 4rem);
  letter-spacing: var(--ls-display);
  color: var(--accent);
  line-height: 1;
  text-decoration: none;
}

/* Stat label — small uppercase meta */
.stat-label {
  font-family: var(--font-meta);
  font-size: var(--fs-xs);
  font-weight: 500;
  letter-spacing: var(--ls-caps);
  text-transform: uppercase;
  color: var(--text-muted);
}


/* ── 10. ALBUM CARDS ─────────────────────────────────────── */
.albums-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: var(--space-lg);
}
.albums-grid--teaser {
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
}
@media (max-width: 640px) {
  .albums-grid { grid-template-columns: 1fr; }
}

.album-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  transition: transform var(--dur-normal) var(--ease-out),
              box-shadow var(--dur-normal) var(--ease-out),
              border-color var(--dur-normal);
  display: flex;
  flex-direction: column;
}
.album-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg);
  border-color: var(--border-strong);
}

.album-card-link { text-decoration: none; color: inherit; display: flex; flex-direction: column; flex: 1; }

.album-card-img-wrap {
  position: relative;
  aspect-ratio: 3/2;
  overflow: hidden;
  background: var(--bg-3);
}
.album-card-img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform var(--dur-slow) var(--ease-out);
}
.album-card:hover .album-card-img { transform: scale(1.06); }
.album-card-img-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(0,0,0,0.5) 0%, transparent 60%);
  pointer-events: none;
}
.album-no-img {
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--bg-3);
}
.album-sport-icon    { font-size: 3rem; }
.album-sport-icon-lg { font-size: 4rem; }
.album-no-img-inner  { display: flex; align-items: center; justify-content: center; width: 100%; height: 100%; }

/* Album type badge — pill, positioned over thumbnail */
.album-type-badge {
  position: absolute;
  top: var(--space-md);
  right: var(--space-md);
  padding: 4px 10px;
  border-radius: 100px;
  font-family: var(--font-display);
  font-size: var(--fs-xs);
  font-weight: 600;
  letter-spacing: var(--ls-caps);
  text-transform: uppercase;
  backdrop-filter: blur(10px);
}
.album-type-fixture     { background: rgba(201,168,76,0.2);  color: var(--accent); border: 1px solid rgba(201,168,76,0.4); }
.album-type-competition { background: rgba(92,186,128,0.2);  color: #5CBA80;        border: 1px solid rgba(92,186,128,0.4); }
.album-type-event       { background: rgba(160,92,224,0.2);  color: #A05CE0;        border: 1px solid rgba(160,92,224,0.4); }
/* Front-page type modifiers (cup / league / event) */
.album-type--cup    .album-type-badge { background: var(--accent-dim); color: var(--accent); border: 1px solid rgba(201,168,76,0.4); }
.album-type--league .album-type-badge { background: rgba(22,163,74,.18); color: #22c55e; border: 1px solid rgba(22,163,74,.4); }
.album-type--event  .album-type-badge { background: var(--surface); color: var(--text-muted); border: 1px solid var(--border); }

.album-card-body { padding: var(--space-lg); display: flex; flex-direction: column; gap: var(--space-sm); flex: 1; }
.album-card-top-meta { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 8px; }

/* Sport badge — small uppercase pill */
.album-sport-badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-family: var(--font-meta);
  font-size: var(--fs-xs);
  font-weight: 500;
  letter-spacing: var(--ls-caps);
  text-transform: uppercase;
  color: var(--text-secondary);
  background: var(--bg-3);
  padding: 3px 10px;
  border-radius: 100px;
  border: 1px solid var(--border);
}

.album-date {
  font-family: var(--font-meta);
  font-size: var(--fs-xs);
  letter-spacing: 0.02em;
  color: var(--text-muted);
  font-weight: 400;
  opacity: 0.85;
}

/* Album card title — Bebas Neue, uppercase, centred */
.album-card-title {
  font-family: var(--font-display);
  font-size: 1.15rem;
  font-weight: 300;
  letter-spacing: var(--ls-display);
  text-transform: uppercase;
  text-align: center;
  color: var(--text-primary);
  margin: 0;
}
.album-card-title a { color: inherit; text-decoration: none; }
.album-card-title a:hover { color: var(--accent); }

/* Competition / league labels — small uppercase meta */
.album-competition,
.album-league {
  font-family: var(--font-meta);
  font-size: var(--fs-xs);
  font-weight: 500;
  letter-spacing: var(--ls-caps);
  text-transform: uppercase;
  color: var(--text-muted);
}

/* Album meta type label (Cup / League / Event) */
.album-meta-league {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  font-family: var(--font-meta);
  font-size: var(--fs-xs);
  font-weight: 600;
  letter-spacing: var(--ls-caps);
  text-transform: uppercase;
  color: var(--text-muted);
  opacity: 0.75;
}
.album-meta-league svg { flex-shrink: 0; }
.album-type--cup    .album-meta-league { color: var(--accent); opacity: 1; }
.album-type--league .album-meta-league { color: #22c55e; opacity: 1; }

/* League name (below type label) */
.album-league-name {
  font-family: var(--font-meta);
  font-size: 0.55rem;
  font-weight: 400;
  letter-spacing: var(--ls-caps);
  text-transform: uppercase;
  color: var(--text-muted);
  opacity: 0.7;
}

/* ── Score card ─────────────────────────────────────────────
   Vertical centred layout: team name → scoreline → team name.
   All text uses --score-card-text (#FAFAFA dark / #1A1714 light).
   The scoreline badge keeps gold as the sole accent.
   ─────────────────────────────────────────────────────────── */
.album-score-display {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.2rem;
  margin-top: 0.5rem;
  padding: 0.75rem 1rem;
  text-align: center;
  background: var(--score-card-bg);
  border: 1px solid var(--score-card-border);
  border-radius: var(--radius-md);
}

/* Team names */
.album-team {
  font-family: var(--font-meta);
  font-size: 0.8rem;
  font-weight: 600;
  letter-spacing: var(--ls-caps);
  text-transform: uppercase;
  color: var(--score-card-text);
  line-height: 1.25;
}
/* Legacy horizontal-layout overrides (no-op in column layout, kept for safety) */
.album-team--home { text-align: center; }
.album-team--away { text-align: center; }

/* Scoreline — Bebas Neue, gold accent, mono-feel spacing */
.album-score-badge {
  font-family: var(--font-display);
  font-size: 1.85rem;
  font-weight: 500;
  letter-spacing: var(--ls-mono);
  color: var(--accent);
  line-height: 1;
  white-space: nowrap;
  /* Remove the filled-pill background used in older card styles */
  background: transparent;
  border: none;
  padding: 0;
  border-radius: 0;
}

/* 'vs' — shown when no scoreline is saved */
.album-score-vs {
  font-family: var(--font-display);
  font-size: 0.72rem;
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--score-card-text);
  opacity: 0.55;
  padding: 0.1rem 0;
}

/* Penalties note */
.album-score-penalties {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.35rem;
  font-family: var(--font-display);
  font-size: 0.5rem;
  font-weight: 200;
  letter-spacing: 0.05em;
  color: var(--score-card-text);
  opacity: 0.75;
  margin-top: 0.25rem;
}
.album-score-penalties svg { flex-shrink: 0; }

/* Competition / league label inside score card */
.album-score-league {
  font-family: var(--font-display);
  font-size: 0.68rem;
  font-weight: 300;
  letter-spacing: var(--ls-caps);
  text-transform: uppercase;
  color: var(--score-card-text);
  opacity: 0.65;
  margin-bottom: 0.15rem;
}

/* Venue — bottom of score card */
.album-score-venue {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.25rem;
  font-family: var(--font-meta);
  font-size: 0.50rem;
  font-weight: 400;
  letter-spacing: var(--ls-caps);
  text-transform: uppercase;
  color: var(--score-card-text);
  opacity: 0.55;
  margin-top: 0.3rem;
}
.album-score-venue svg { flex-shrink: 0; }

/* Legacy venue rule kept for single-album pages */
.album-venue {
  display: flex;
  align-items: center;
  gap: 5px;
  font-family: var(--font-meta);
  font-size: var(--fs-xs);
  letter-spacing: var(--ls-caps);
  color: var(--text-muted);
}

.album-excerpt     { font-size: var(--fs-small); color: var(--text-secondary); }
.album-card-arrow  { padding: var(--space-md) var(--space-lg); color: var(--text-muted); align-self: flex-end; transition: color var(--dur-fast), transform var(--dur-fast); }
.album-card:hover .album-card-arrow { color: var(--accent); transform: translateX(4px); }

.album-card-footer {
  padding: var(--space-md) var(--space-lg);
  border-top: 1px solid var(--border);
  display: flex;
  gap: var(--space-sm);
  flex-wrap: wrap;
  margin-top: auto;
}
.album-card--full { position: relative; }


/* ── 11. PAGE HEROES ─────────────────────────────────────── */
.page-hero {
  position: relative;
  padding: calc(var(--header-h) + 4rem) var(--gutter) var(--space-2xl);
  max-width: var(--max-w);
  margin: 0 auto;
  overflow: hidden;
}
.page-hero-content { position: relative; z-index: 1; }
/* Page title inherits h1 uppercase rule */
.page-title    { font-size: var(--fs-h1); letter-spacing: var(--ls-display); }
.page-subtitle {
  font-size: clamp(1rem, 2vw, 1.2rem);
  color: var(--text-secondary);
  max-width: 560px;
  margin-top: var(--space-md);
  letter-spacing: var(--ls-body);
  /* Subtitle is descriptive prose — sentence case */
  text-transform: none;
  font-family: var(--font-body);
}
.page-hero-bg {
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 60% 40% at 70% 50%, var(--accent-glass), transparent);
  pointer-events: none;
}


/* ── 12. PORTFOLIO FILTER ────────────────────────────────── */
.portfolio-filter {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 0 var(--gutter) var(--space-xl);
  display: flex;
  gap: var(--space-sm);
  flex-wrap: wrap;
  align-items: center;
}

.filter-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 7px 16px;
  border: 1px solid var(--border-strong);
  border-radius: 100px;
  font-family: var(--font-meta);
  font-size: var(--fs-xs);
  font-weight: 500;
  letter-spacing: var(--ls-caps);
  text-transform: uppercase;
  color: var(--text-secondary);
  text-decoration: none;
  background: transparent;
  cursor: pointer;
  transition: background var(--dur-fast), color var(--dur-fast), border-color var(--dur-fast);
}
.filter-pill:hover  { background: var(--surface-hover); color: var(--text-primary); }
.filter-pill.active { background: var(--accent); color: #000; border-color: var(--accent); font-weight: 600; }

.filter-count {
  font-size: 10px;
  background: var(--bg-3);
  color: var(--text-muted);
  border-radius: 100px;
  padding: 1px 6px;
  min-width: 20px;
  text-align: center;
}
.filter-pill.active .filter-count { background: rgba(0,0,0,0.2); color: #000; }

.albums-filters {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 0 var(--gutter) var(--space-xl);
  display: flex;
  gap: var(--space-xl);
  flex-wrap: wrap;
  align-items: flex-start;
}
.filter-group        { display: flex; flex-direction: column; gap: var(--space-sm); }
.filter-group-label {
  font-family: var(--font-meta);
  font-size: var(--fs-xs);
  font-weight: 600;
  letter-spacing: var(--ls-caps);
  text-transform: uppercase;
  color: var(--text-muted);
}
.filter-pills { display: flex; gap: 8px; flex-wrap: wrap; }

.results-count {
  max-width: var(--max-w);
  margin: 0 auto var(--space-xl);
  padding: 0 var(--gutter);
  font-size: var(--fs-small);
  color: var(--text-muted);
  letter-spacing: var(--ls-body);
}


/* ── 13. LIGHTBOX ────────────────────────────────────────── */
.lightbox {
  position: fixed;
  inset: 0;
  z-index: 9999;
  background: rgba(6,6,6,0.97);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: opacity var(--dur-normal) var(--ease-out);
}
.lightbox:not([hidden]) { opacity: 1; }
.lightbox[hidden]       { display: none; }

.lightbox-stage {
  position: relative;
  max-width: calc(100vw - 140px);
  max-height: calc(100dvh - 100px);
  display: flex;
  align-items: center;
  justify-content: center;
}
@media (max-width: 640px) { .lightbox-stage { max-width: calc(100vw - 40px); } }

.lightbox-img {
  max-width: 100%;
  max-height: calc(100dvh - 140px);
  object-fit: contain;
  border-radius: var(--radius-sm);
  user-select: none;
  transition: opacity var(--dur-fast), transform var(--dur-normal) var(--ease-out);
}

.lightbox-close {
  position: absolute;
  top: var(--space-lg); right: var(--space-lg);
  width: 48px; height: 48px;
  background: rgba(255,255,255,0.1);
  backdrop-filter: blur(10px);
  border: 1px solid rgba(255,255,255,0.15);
  border-radius: 50%;
  color: #fff;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background var(--dur-fast), transform var(--dur-fast) var(--ease-spring);
  z-index: 10;
}
.lightbox-close:hover { background: var(--accent); color: #000; transform: rotate(90deg) scale(1.1); }

.lightbox-prev,
.lightbox-next {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 56px; height: 56px;
  background: rgba(255,255,255,0.08);
  backdrop-filter: blur(10px);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 50%;
  color: #fff;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background var(--dur-fast), transform var(--dur-fast) var(--ease-spring);
  z-index: 10;
}
.lightbox-prev { left: var(--space-lg); }
.lightbox-next { right: var(--space-lg); }
.lightbox-prev:hover { background: var(--accent); color: #000; transform: translateY(-50%) scale(1.1); }
.lightbox-next:hover { background: var(--accent); color: #000; transform: translateY(-50%) scale(1.1); }
@media (max-width: 640px) { .lightbox-prev, .lightbox-next { display: none; } }

/* Lightbox caption — small uppercase label */
.lightbox-caption {
  position: absolute;
  bottom: -36px;
  left: 0; right: 0;
  text-align: center;
  font-family: var(--font-meta);
  font-size: var(--fs-xs);
  font-weight: 500;
  letter-spacing: var(--ls-caps);
  text-transform: uppercase;
  color: rgba(255,255,255,0.5);
}


/* ── 14. SINGLE ALBUM ────────────────────────────────────── */
.main-content--single {
  max-width: var(--max-w);
  margin: 0 auto;
  padding-top: var(--header-h);
}

.breadcrumb-row { padding: var(--space-xl) var(--gutter) 0; }
.back-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-meta);
  font-size: var(--fs-small);
  font-weight: 500;
  letter-spacing: var(--ls-caps);
  text-transform: uppercase;
  color: var(--text-muted);
  text-decoration: none;
  transition: color var(--dur-fast);
}
.back-link:hover { color: var(--text-primary); }
.back-link svg   { transition: transform var(--dur-fast); }
.back-link:hover svg { transform: translateX(-3px); }

.album-single { padding: var(--space-xl) var(--gutter) var(--space-3xl); }

.album-single-hero {
  position: relative;
  border-radius: var(--radius-xl);
  overflow: hidden;
  aspect-ratio: 16/7;
  margin-bottom: var(--space-2xl);
}
.album-single-hero-img { width: 100%; height: 100%; object-fit: cover; }
.album-single-hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, transparent 30%, rgba(0,0,0,0.8) 100%);
}
.album-single-hero-content {
  position: absolute;
  bottom: var(--space-2xl);
  left: var(--space-2xl);
  right: var(--space-2xl);
  z-index: 2;
}

.album-hero-score {
  display: flex;
  align-items: center;
  gap: var(--space-lg);
}
.score-home, .score-away {
  font-family: var(--font-display);
  font-size: clamp(1.2rem, 3vw, 2.5rem);
  letter-spacing: var(--ls-display);
  text-transform: uppercase;
  color: #fff;
}
.score-home { text-align: right; flex: 1; }
.score-away { text-align: left; flex: 1; }
.score-vs   { display: flex; flex-direction: column; align-items: center; gap: 2px; }
.score-number {
  font-family: var(--font-display);
  font-size: clamp(2rem, 5vw, 4rem);
  letter-spacing: var(--ls-mono);
  color: var(--accent);
  line-height: 1;
}

.album-single-header { max-width: 760px; margin-bottom: var(--space-xl); }
.album-meta-chips    { display: flex; gap: var(--space-sm); flex-wrap: wrap; margin-bottom: var(--space-md); }
.chip {
  padding: 5px 14px;
  border-radius: 100px;
  font-family: var(--font-meta);
  font-size: var(--fs-xs);
  font-weight: 600;
  letter-spacing: var(--ls-caps);
  text-transform: uppercase;
}
.chip-sport { background: var(--accent-dim); color: var(--accent); border: 1px solid rgba(201,168,76,0.3); }
.chip-type  { background: var(--bg-3);       color: var(--text-muted); border: 1px solid var(--border); }

/* Single-album title inherits h2 uppercase rule */
.album-single-title { font-size: var(--fs-h2); margin-bottom: var(--space-xl); }

.album-details-list { display: flex; flex-direction: column; gap: var(--space-sm); }
.detail-row         { display: flex; align-items: flex-start; gap: var(--space-lg); }
.detail-row dt {
  display: flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-meta);
  font-size: var(--fs-xs);
  font-weight: 600;
  letter-spacing: var(--ls-caps);
  text-transform: uppercase;
  color: var(--text-muted);
  min-width: 120px;
  flex-shrink: 0;
}
.detail-row dd {
  font-size: var(--fs-small);
  letter-spacing: var(--ls-body);
  color: var(--text-secondary);
}

.album-result-card {
  display: flex;
  align-items: center;
  gap: var(--space-xl);
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  padding: var(--space-2xl);
  margin: var(--space-xl) 0;
  text-align: center;
}
.result-team { flex: 1; }
.result-team-name {
  font-family: var(--font-display);
  font-size: clamp(1.3rem, 3vw, 2.2rem);
  letter-spacing: var(--ls-display);
  text-transform: uppercase;
  color: var(--text-primary);
  display: block;
}
.result-team-label {
  font-family: var(--font-meta);
  font-size: var(--fs-xs);
  font-weight: 500;
  letter-spacing: var(--ls-caps);
  text-transform: uppercase;
  color: var(--text-muted);
  display: block;
  margin-top: 4px;
}
.result-centre { display: flex; flex-direction: column; align-items: center; gap: 6px; flex-shrink: 0; }
.result-score {
  font-family: var(--font-display);
  font-size: clamp(3rem, 8vw, 5rem);
  letter-spacing: var(--ls-mono);
  color: var(--accent);
  line-height: 1;
}
.result-label {
  font-family: var(--font-meta);
  font-size: var(--fs-xs);
  font-weight: 500;
  letter-spacing: var(--ls-caps);
  text-transform: uppercase;
  color: var(--text-muted);
}

.album-content { max-width: 720px; margin-bottom: var(--space-2xl); }
.album-content p { margin-bottom: var(--space-md); line-height: var(--lh-loose); letter-spacing: var(--ls-body); color: var(--text-secondary); }

.album-cta-block {
  background: linear-gradient(135deg, var(--surface), var(--bg-3));
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  padding: var(--space-2xl);
  margin-bottom: var(--space-2xl);
}
.album-cta-inner { display: flex; align-items: center; gap: var(--space-xl); flex-wrap: wrap; }
.album-cta-text  { flex: 1; min-width: 200px; }
/* h3 inside CTA inherits uppercase — intentional */
.album-cta-text p { font-size: var(--fs-small); letter-spacing: var(--ls-body); color: var(--text-secondary); }


/* ── 15. POST NAVIGATION ─────────────────────────────────── */
.post-nav {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-md);
  margin-top: var(--space-2xl);
  border-top: 1px solid var(--border);
  padding-top: var(--space-xl);
}
.post-nav-item {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  padding: var(--space-lg);
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  text-decoration: none;
  transition: background var(--dur-fast), border-color var(--dur-fast);
}
.post-nav-item:hover { background: var(--surface-hover); border-color: var(--border-strong); }
.post-nav-next  { justify-content: flex-end; text-align: right; }
.post-nav-label {
  display: block;
  font-family: var(--font-meta);
  font-size: var(--fs-xs);
  letter-spacing: var(--ls-caps);
  text-transform: uppercase;
  color: var(--text-muted);
  margin-bottom: 2px;
}
.post-nav-title {
  display: block;
  font-size: var(--fs-small);
  font-weight: 500;
  letter-spacing: var(--ls-body);
  color: var(--text-primary);
}
.post-nav-item svg { flex-shrink: 0; color: var(--text-muted); }


/* ── 16. ABOUT PAGE ──────────────────────────────────────── */
.about-wrapper {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 var(--gutter) var(--space-3xl);
}
.about-intro {
  display: grid;
  grid-template-columns: 380px 1fr;
  gap: var(--space-3xl);
  margin-bottom: var(--space-3xl);
  align-items: start;
}
@media (max-width: 860px) { .about-intro { grid-template-columns: 1fr; } }

.about-portrait-wrap { position: relative; }
.about-portrait {
  width: 100%;
  aspect-ratio: 3/4;
  object-fit: cover;
  border-radius: var(--radius-xl);
  display: block;
}
.about-portrait-placeholder {
  aspect-ratio: 3/4;
  background: var(--bg-3);
  border-radius: var(--radius-xl);
  border: 2px dashed var(--border-strong);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--space-md);
  color: var(--text-muted);
  font-size: var(--fs-small);
  text-align: center;
  padding: var(--space-xl);
}
.about-portrait-accent {
  position: absolute;
  bottom: -16px; right: -16px;
  width: 60%;
  aspect-ratio: 1;
  background: var(--accent-dim);
  border-radius: var(--radius-xl);
  z-index: -1;
  border: 2px solid rgba(201,168,76,0.2);
}

/* Photographer name — Bebas Neue, uppercase (inherits h1 rule) */
.about-name { font-size: clamp(2.5rem, 5vw, 4rem); margin-bottom: var(--space-sm); }
.about-location {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-meta);
  font-size: var(--fs-small);
  letter-spacing: var(--ls-body);
  color: var(--text-muted);
  margin-bottom: var(--space-xl);
  /* Location is plain text, not a label — sentence case */
  text-transform: none;
}
.about-intro-text p {
  margin-bottom: var(--space-md);
  line-height: var(--lh-loose);
  letter-spacing: var(--ls-body);
}

/* About section titles inherit h3 uppercase rule */
.about-section-title { font-size: var(--fs-h3); margin-bottom: var(--space-xl); }
.about-sports, .about-testimonials { margin-bottom: var(--space-3xl); }

.sports-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: var(--space-md);
}
.sport-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: var(--space-xl);
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
  transition: border-color var(--dur-fast), transform var(--dur-fast) var(--ease-out);
}
.sport-card:hover { border-color: var(--accent); transform: translateY(-3px); }
.sport-card-icon  { font-size: 2rem; }
.sport-card-label {
  font-family: var(--font-display);
  font-size: 1.3rem;
  letter-spacing: var(--ls-display);
  text-transform: uppercase;
  color: var(--text-primary);
}
.sport-card-note  { font-size: var(--fs-small); letter-spacing: var(--ls-body); color: var(--text-secondary); line-height: var(--lh-normal); }

.testimonials-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: var(--space-lg); }
.testimonial-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-left: 3px solid var(--accent);
  border-radius: var(--radius-md);
  padding: var(--space-xl);
}
/* Testimonial copy is prose — sentence case, body font */
.testimonial-text {
  font-style: italic;
  letter-spacing: var(--ls-body);
  color: var(--text-secondary);
  line-height: var(--lh-loose);
  margin-bottom: var(--space-md);
  text-transform: none;
}
.testimonial-author {
  font-family: var(--font-meta);
  font-size: var(--fs-small);
  font-weight: 600;
  font-style: normal;
  letter-spacing: var(--ls-caps);
  text-transform: uppercase;
  color: var(--text-muted);
}

.about-cta { display: flex; align-items: center; gap: var(--space-xl); padding: var(--space-2xl); background: var(--surface); border-radius: var(--radius-xl); border: 1px solid var(--border); flex-wrap: wrap; }
/* CTA paragraph uses display font for visual weight — uppercase (inherits p override below) */
.about-cta p {
  font-family: var(--font-display);
  font-size: var(--fs-h3);
  letter-spacing: var(--ls-display);
  text-transform: uppercase;
  color: var(--text-primary);
  flex: 1;
}


/* ── 17. CONTACT PAGE ────────────────────────────────────── */
.contact-wrapper {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 var(--gutter) var(--space-3xl);
  display: grid;
  grid-template-columns: 1fr 360px;
  gap: var(--space-3xl);
  align-items: start;
}
@media (max-width: 860px) { .contact-wrapper { grid-template-columns: 1fr; } }

/* Column title inherits h3 uppercase rule */
.contact-col-title { font-size: var(--fs-h3); margin-bottom: var(--space-xl); }

.contact-form { display: flex; flex-direction: column; gap: var(--space-lg); }
.form-row     { display: flex; gap: var(--space-lg); }
.form-row--half > .form-field { flex: 1; min-width: 0; }
@media (max-width: 600px) { .form-row { flex-direction: column; } }

.form-field { display: flex; flex-direction: column; gap: 6px; }
.form-label {
  font-family: var(--font-meta);
  font-size: var(--fs-xs);
  font-weight: 600;
  letter-spacing: var(--ls-caps);
  text-transform: uppercase;
  color: var(--text-secondary);
}
.required { color: var(--accent); }

.form-input {
  background: var(--surface);
  border: 1px solid var(--border-strong);
  border-radius: var(--radius-md);
  padding: 14px 16px;
  font-family: var(--font-body);
  font-size: var(--fs-body);
  font-weight: 300;
  letter-spacing: var(--ls-body);
  color: var(--text-primary);
  outline: none;
  transition: border-color var(--dur-fast), box-shadow var(--dur-fast);
  width: 100%;
  -webkit-appearance: none;
}
.form-input::placeholder { color: var(--text-muted); }
.form-input:focus { border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-dim); }
.form-input.error { border-color: var(--danger); }
.form-select  { cursor: pointer; }
.form-textarea { resize: vertical; min-height: 140px; line-height: var(--lh-normal); }

.form-error { font-size: var(--fs-xs); color: var(--danger); min-height: 18px; }
.form-submit { align-self: flex-start; border: none; }
.spin        { animation: spin 1s linear infinite; }

.form-feedback {
  padding: var(--space-md) var(--space-lg);
  border-radius: var(--radius-md);
  font-size: var(--fs-small);
  font-weight: 500;
  display: none;
}
.form-feedback.success { background: rgba(92,186,128,0.15); color: var(--success); border: 1px solid rgba(92,186,128,0.3); display: block; }
.form-feedback.error   { background: rgba(224,92,92,0.15);  color: var(--danger); border: 1px solid rgba(224,92,92,0.3); display: block; }

.contact-info-items { display: flex; flex-direction: column; gap: var(--space-xl); }
.contact-info-item  { display: flex; align-items: flex-start; gap: var(--space-lg); }
.contact-info-icon {
  width: 44px; height: 44px;
  background: var(--accent-dim);
  border: 1px solid rgba(201,168,76,0.3);
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--accent);
  flex-shrink: 0;
}
.contact-info-item strong {
  display: block;
  font-family: var(--font-meta);
  font-size: var(--fs-small);
  font-weight: 600;
  letter-spacing: var(--ls-caps);
  text-transform: uppercase;
  color: var(--text-primary);
  margin-bottom: 2px;
}
.contact-info-item p {
  font-size: var(--fs-small);
  letter-spacing: var(--ls-body);
  color: var(--text-secondary);
  text-transform: none;
}


/* ── 18. ABOUT STRIP (HOMEPAGE) ──────────────────────────── */
.section-about-strip {
  background: var(--bg-2);
  border-radius: var(--radius-xl);
  overflow: hidden;
  border: 1px solid var(--border);
}
.about-strip-inner {
  display: grid;
  grid-template-columns: 1fr 300px;
  min-height: 360px;
}
@media (max-width: 768px) { .about-strip-inner { grid-template-columns: 1fr; } }

.about-strip-text {
  padding: var(--space-3xl);
  display: flex;
  flex-direction: column;
  gap: var(--space-lg);
}
.about-strip-text p {
  max-width: 480px;
  line-height: var(--lh-loose);
  letter-spacing: var(--ls-body);
}
.about-strip-visual { background: var(--bg-3); overflow: hidden; }
.about-strip-pattern {
  width: 100%; height: 100%;
  background-image:
    repeating-linear-gradient(45deg, var(--border) 0px, var(--border) 1px, transparent 1px, transparent 20px),
    repeating-linear-gradient(-45deg, var(--border) 0px, var(--border) 1px, transparent 1px, transparent 20px);
  opacity: .5;
}


/* ── 19. FOOTER ──────────────────────────────────────────── */
.site-footer {
  background: var(--bg-2);
  border-top: 1px solid var(--border);
  padding-bottom: 80px;
}
@media (min-width: 768px) { .site-footer { padding-bottom: 0; } }

.footer-inner {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: var(--space-3xl) var(--gutter) var(--space-2xl);
  display: grid;
  grid-template-columns: 2fr 1fr 1fr;
  gap: var(--space-3xl);
  align-items: start;
}
@media (max-width: 768px) {
  .footer-inner { grid-template-columns: 1fr 1fr; }
  .footer-brand { grid-column: 1/-1; }
}
@media (max-width: 480px) { .footer-inner { grid-template-columns: 1fr; } }

.footer-logo { display: flex; align-items: center; gap: 10px; text-decoration: none; margin-bottom: var(--space-md); }
.footer-tagline {
  font-size: var(--fs-small);
  letter-spacing: var(--ls-body);
  color: var(--text-muted);
  max-width: 300px;
  line-height: var(--lh-normal);
}

.footer-nav-list { list-style: none; display: flex; flex-direction: column; gap: var(--space-sm); }
.footer-nav-list a {
  font-size: var(--fs-small);
  letter-spacing: var(--ls-body);
  color: var(--text-secondary);
  text-decoration: none;
  transition: color var(--dur-fast);
}
.footer-nav-list a:hover { color: var(--text-primary); }

.footer-social { display: flex; gap: var(--space-md); flex-wrap: wrap; align-items: flex-start; }
.social-link {
  width: 40px; height: 40px;
  background: var(--bg-3);
  border: 1px solid var(--border);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-secondary);
  text-decoration: none;
  transition: background var(--dur-fast), color var(--dur-fast), border-color var(--dur-fast);
}
.social-link:hover { background: var(--accent-dim); color: var(--accent); border-color: var(--accent); }

.footer-base {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: var(--space-lg) var(--gutter);
  border-top: 1px solid var(--border);
}
.footer-copy {
  font-size: var(--fs-xs);
  letter-spacing: var(--ls-body);
  color: var(--text-muted);
  text-align: center;
}
.footer-copy a       { color: var(--text-muted); }
.footer-copy a:hover { color: var(--accent); }


/* ── 20. MOBILE BOTTOM NAV ───────────────────────────────── */
.mobile-bottom-nav {
  display: none;
  position: fixed;
  bottom: 0; left: 0; right: 0;
  height: 68px;
  background: var(--bg-glass);
  backdrop-filter: blur(20px) saturate(180%);
  -webkit-backdrop-filter: blur(20px) saturate(180%);
  border-top: 1px solid var(--border);
  z-index: 800;
  padding-bottom: env(safe-area-inset-bottom);
}
@media (max-width: 767px) { .mobile-bottom-nav { display: grid; grid-template-columns: repeat(5,1fr); } }

.mbn-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 3px;
  padding: 8px 4px;
  color: var(--text-muted);
  text-decoration: none;
  font-family: var(--font-meta);
  font-size: 9px;
  font-weight: 500;
  letter-spacing: var(--ls-caps);
  text-transform: uppercase;
  transition: color var(--dur-fast);
  position: relative;
}
.mbn-item.active { color: var(--accent); }
.mbn-item.active::before {
  content: '';
  position: absolute;
  top: 0; left: 20%; right: 20%;
  height: 2px;
  background: var(--accent);
  border-radius: 0 0 4px 4px;
}
.mbn-item span { line-height: 1; }


/* ── 21. PAGINATION ──────────────────────────────────────── */
.pagination {
  max-width: var(--max-w);
  margin: var(--space-3xl) auto 0;
  padding: 0 var(--gutter);
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}
.pagination .page-numbers {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 40px; height: 40px;
  padding: 0 12px;
  border: 1px solid var(--border-strong);
  border-radius: var(--radius-sm);
  font-family: var(--font-meta);
  font-size: var(--fs-small);
  font-weight: 500;
  letter-spacing: var(--ls-caps);
  text-transform: uppercase;
  color: var(--text-secondary);
  text-decoration: none;
  transition: background var(--dur-fast), color var(--dur-fast), border-color var(--dur-fast);
}
.pagination .page-numbers:hover   { background: var(--surface-hover); color: var(--text-primary); }
.pagination .page-numbers.current { background: var(--accent); color: #000; border-color: var(--accent); font-weight: 700; }
.pagination .page-numbers.dots    { border: none; background: none; }


/* ── 22. EMPTY STATES ────────────────────────────────────── */
.empty-state { color: var(--text-muted); font-size: var(--fs-small); text-align: center; padding: var(--space-3xl); }
.empty-state-block {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-lg);
  padding: var(--space-3xl) var(--gutter);
  text-align: center;
  color: var(--text-muted);
  max-width: var(--max-w);
  margin: 0 auto;
}


/* ── 23. UPCOMING SHOOTS ─────────────────────────────────── */
.section-upcoming {
  padding: var(--space-section) var(--gutter);
  max-width: var(--max-w);
  margin: 0 auto;
  background: var(--bg);
}

.section-upcoming .section-header,
.upcoming-list {
  max-width: var(--max-w);
  margin-left: auto;
  margin-right: auto;
}

.upcoming-list {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.upcoming-item {
  display: grid;
  grid-template-columns: 190px 36px 1fr auto;
  align-items: center;
  gap: 24px;
  padding: 24px 28px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.07);
  border-radius: var(--radius-sm);
  transition: background var(--dur-fast), border-color var(--dur-fast);
}
.upcoming-item:hover {
  background: rgba(255,255,255,0.07);
  border-color: rgba(255,255,255,0.14);
}

.upcoming-date-col {
  display: flex;
  flex-direction: column;
  gap: 5px;
  border-right: 1px solid rgba(255,255,255,0.08);
  padding-right: 24px;
}

/* Date string — Bebas Neue display, uppercase */
.upcoming-date-full {
  font-family: var(--font-display);
  font-size: 1rem;
  letter-spacing: var(--ls-display);
  text-transform: uppercase;
  color: var(--text-primary);
  line-height: 1.1;
}

/* Countdown — small accent-coloured label */
.upcoming-countdown {
  font-family: var(--font-meta);
  font-size: var(--fs-xs);
  font-weight: 500;
  letter-spacing: var(--ls-caps);
  text-transform: uppercase;
  color: var(--accent);
}

.upcoming-sport-icon {
  font-size: 1.25rem;
  line-height: 1;
  opacity: 0.6;
  text-align: center;
}

.upcoming-details {
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
}

/* Shoot / match title — Bebas Neue, uppercase */
.upcoming-title {
  font-family: var(--font-display);
  font-size: 1.15rem;
  letter-spacing: var(--ls-display);
  text-transform: uppercase;
  color: var(--text-primary);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Competition — small meta label */
.upcoming-competition {
  font-family: var(--font-meta);
  font-size: var(--fs-xs);
  font-weight: 500;
  letter-spacing: var(--ls-caps);
  text-transform: uppercase;
  color: var(--text-muted);
  opacity: 0.7;
}

/* Teams — body-weight prose, not a label */
.upcoming-teams {
  font-family: var(--font-body);
  font-size: var(--fs-xs);
  letter-spacing: var(--ls-body);
  color: var(--text-secondary);
  display: flex;
  align-items: center;
  gap: 7px;
}

/* 'v' separator — small gold Bebas Neue */
.upcoming-vs {
  font-family: var(--font-display);
  font-size: 0.65rem;
  letter-spacing: var(--ls-caps);
  text-transform: uppercase;
  color: var(--accent);
  opacity: 0.8;
}

/* Sport badge (right column) */
.upcoming-sport-badge {
  font-family: var(--font-meta);
  font-size: var(--fs-xs);
  font-weight: 500;
  letter-spacing: var(--ls-caps);
  text-transform: uppercase;
  color: var(--text-muted);
  opacity: 0.6;
  white-space: nowrap;
  border-left: 1px solid rgba(255,255,255,0.08);
  padding-left: 24px;
}

/* Responsive upcoming */
@media (max-width: 1024px) {
  .upcoming-item { padding: 20px 24px; }
}
@media (max-width: 768px) {
  .upcoming-item {
    grid-template-columns: 1fr auto;
    grid-template-rows: auto auto;
    row-gap: 6px;
    padding: 18px 20px;
  }
  .upcoming-sport-icon { display: none; }
  .upcoming-date-col {
    grid-column: 1; grid-row: 1;
    border-right: none; padding-right: 0;
    border-bottom: 1px solid rgba(255,255,255,0.07);
    padding-bottom: 10px; margin-bottom: 4px;
  }
  .upcoming-details  { grid-column: 1; grid-row: 2; }
  .upcoming-sport-badge {
    grid-column: 2; grid-row: 1 / 3;
    align-self: center;
  }
}
@media (max-width: 480px) {
  .upcoming-item  { grid-template-columns: 1fr; }
  .upcoming-sport-badge { display: none; }
  .upcoming-date-col { grid-column: 1; }
}


/* ── 24. ANIMATIONS & KEYFRAMES ──────────────────────────── */
@keyframes reveal {
  to { opacity: 1; transform: none; }
}
@keyframes headline-reveal {
  to { opacity: 1; transform: none; }
}
@keyframes bob {
  0%, 100% { transform: translateX(-50%) translateY(0); }
  50%       { transform: translateX(-50%) translateY(8px); }
}
@keyframes scroll-wheel {
  0%   { transform: translateY(0);   opacity: 1; }
  100% { transform: translateY(8px); opacity: 0; }
}
@keyframes spin     { to { transform: rotate(360deg); } }
@keyframes fade-in  { from { opacity: 0; transform: translateY(16px); } to { opacity: 1; transform: none; } }
@keyframes scale-in { from { opacity: 0; transform: scale(0.94); }     to { opacity: 1; transform: scale(1); } }

/* Scroll-reveal */
[data-scroll-reveal] {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity var(--dur-slow) var(--ease-out),
              transform var(--dur-slow) var(--ease-out);
}
[data-scroll-reveal].revealed         { opacity: 1; transform: none; }
[data-scroll-reveal][data-delay="1"]  { transition-delay: .1s; }
[data-scroll-reveal][data-delay="2"]  { transition-delay: .2s; }
[data-scroll-reveal][data-delay="3"]  { transition-delay: .3s; }

[data-kinetic] { will-change: transform; }


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


/* ── 26. PRINT ───────────────────────────────────────────── */
@media print {
  .site-header, .mobile-bottom-nav, .mobile-nav-overlay,
  .hero-scroll-hint, .lightbox { display: none !important; }
  body { background: #fff; color: #000; }
}