/*
Theme Name: ANBCC Pavilion
Theme URI: https://anbcc.co.uk
Author: Ampfield & North Baddesley Cricket Club
Description: Custom theme for Ampfield & North Baddesley Cricket Club — pavilion heritage design in club green, ball red and honours-board gold, built for Saturday, Border League midweek, Women's and junior cricket content.
Version: 1.1.0
Requires at least: 6.0
Requires PHP: 7.4
Text Domain: anbcc
*/

/* ==========================================================================
   ANBCC — Ampfield & North Baddesley Cricket Club
   Design system: pavilion heritage — scorebook cream, pitch green, ball red,
   honours-board gold. Fraunces (display) + Public Sans (body).
   ========================================================================== */

:root{
  --green:        #02551D;
  --green-dark:   #012C0F;
  --green-mid:    #0B6B2A;
  --red:          #D60000;
  --red-dark:     #A00000;
  --cream:        #F5EFDF;
  --cream-deep:   #EDE3C9;
  --card:         #FFFDF7;
  --ink:          #16241B;
  --ink-soft:     #3E4A40;
  --gold:         #AD8A4E;
  --gold-light:   #D9C08C;
  --line:         rgba(2,85,29,0.18);
  --shadow:       0 12px 30px rgba(1,44,15,0.14);
  --radius:       6px;
  --max:          1180px;
  --font-display: "Fraunces", Georgia, "Times New Roman", serif;
  --font-body:    "Public Sans", Arial, Helvetica, sans-serif;
}

*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--cream);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
ul{ margin:0; padding:0; list-style:none; }
h1,h2,h3,h4{
  font-family:var(--font-display);
  color:var(--green-dark);
  line-height:1.12;
  margin:0 0 .5em;
  font-weight:600;
}
h1{ font-size:clamp(2.4rem,5vw,4.2rem); font-weight:700; }
h2{ font-size:clamp(1.8rem,3.4vw,2.6rem); }
h3{ font-size:1.35rem; }
p{ margin:0 0 1em; }
.container{ max-width:var(--max); margin:0 auto; padding:0 24px; }
section{ padding:72px 0; }
.eyebrow{
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--font-body);
  font-size:.72rem; font-weight:700; letter-spacing:.16em; text-transform:uppercase;
  color:var(--red); margin-bottom:14px;
}
.eyebrow::before{ content:""; width:22px; height:2px; background:var(--red); display:inline-block; }
.lede{ font-size:1.15rem; color:var(--ink-soft); max-width:640px; }

/* Skip link */
.skip-link{
  position:absolute; left:-999px; top:0; background:var(--green); color:#fff;
  padding:10px 18px; z-index:1000; border-radius:0 0 6px 0;
}
.skip-link:focus{ left:0; }

/* Buttons */
.btn{
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--font-body); font-weight:700; font-size:.95rem;
  padding:13px 26px; border-radius:3px; border:2px solid transparent;
  cursor:pointer; transition:transform .15s ease, box-shadow .15s ease, background .15s ease;
}
.btn:focus-visible{ outline:3px solid var(--gold); outline-offset:2px; }
.btn-primary{ background:var(--red); color:#fff; }
.btn-primary:hover{ background:var(--red-dark); transform:translateY(-1px); }
.btn-ghost{ background:transparent; color:var(--cream); border-color:rgba(245,239,223,.5); }
.btn-ghost:hover{ background:rgba(245,239,223,.12); }
.btn-outline{ background:transparent; color:var(--green); border-color:var(--green); }
.btn-outline:hover{ background:var(--green); color:#fff; }

/* ===== Header / Nav ===== */
.site-header{
  position:sticky; top:0; z-index:500;
  background:var(--green-dark);
  border-bottom:3px solid var(--red);
}
.nav-wrap{
  max-width:var(--max); margin:0 auto; padding:0 24px;
  display:flex; align-items:center; justify-content:space-between; gap:24px;
  height:78px;
}
.brand{ display:flex; align-items:center; gap:12px; color:var(--cream); }
.brand-crest{ width:52px; height:52px; flex-shrink:0; background:#fff; border-radius:10px; padding:3px; box-shadow:0 2px 8px rgba(0,0,0,.28); object-fit:contain; }
.brand-text{ font-family:var(--font-display); line-height:1.05; }
.brand-text strong{ display:block; font-size:1.05rem; letter-spacing:.02em; color:#fff; }
.brand-text span{ display:block; font-size:.68rem; letter-spacing:.14em; text-transform:uppercase; color:var(--gold-light); font-family:var(--font-body); font-weight:700; margin-top:3px; }

.main-nav{ display:flex; align-items:center; gap:2px; }
.main-nav .nav-menu{ display:flex; align-items:center; gap:2px; list-style:none; margin:0; padding:0; }
.main-nav .nav-menu li{ list-style:none; }
.main-nav a{
  display:block; color:var(--cream); font-size:.87rem; font-weight:600; padding:10px 14px;
  border-radius:3px; white-space:nowrap;
}
.main-nav a:hover, .main-nav a[aria-current="page"]{ background:rgba(255,255,255,.1); color:#fff; }
.main-nav a[aria-current="page"]{ box-shadow:inset 0 -3px 0 var(--red); }
.main-nav .current-menu-item > a,
.main-nav .current_page_item > a{ background:rgba(255,255,255,.1); color:#fff; box-shadow:inset 0 -3px 0 var(--red); }
.brand-crest.custom-logo{ width:52px; height:52px; object-fit:contain; border-radius:10px; background:#fff; padding:3px; box-shadow:0 2px 8px rgba(0,0,0,.28); }
.nav-cta{ margin-left:8px; }
.nav-toggle{
  display:none; background:none; border:2px solid var(--cream); color:var(--cream);
  width:44px; height:40px; border-radius:3px; cursor:pointer; font-size:1.1rem;
}

@media (max-width:960px){
  .nav-toggle{ display:block; }
  .main-nav{
    position:absolute; top:78px; left:0; right:0; background:var(--green-dark);
    flex-direction:column; align-items:stretch; gap:0; padding:8px 24px 20px;
    border-bottom:3px solid var(--red); display:none;
  }
  .main-nav.open{ display:flex; }
  .main-nav .nav-menu{ flex-direction:column; align-items:stretch; width:100%; }
  .main-nav a{ padding:14px 6px; border-bottom:1px solid rgba(255,255,255,.08); border-radius:0; }
  .nav-cta{ margin:14px 0 0; }
}

/* ===== Hero ===== */
.hero{
  position:relative; overflow:hidden;
  background:
    linear-gradient(180deg, rgba(1,44,15,.78) 0%, rgba(1,44,15,.55) 55%, rgba(1,44,15,.85) 100%),
    repeating-linear-gradient(100deg, #0B6B2A 0 90px, #095E24 90px 180px);
  color:var(--cream);
  padding:96px 0 110px;
}
.hero::after{
  content:""; position:absolute; inset:0;
  background-image:radial-gradient(circle at 18% 20%, rgba(255,255,255,.05), transparent 40%),
                    radial-gradient(circle at 85% 75%, rgba(255,255,255,.05), transparent 45%);
  pointer-events:none;
}
.hero .container{ position:relative; }
.hero-inner{ max-width:720px; }
.hero h1{ color:#fff; }
.hero .lede{ color:var(--cream-deep); }
.hero-cta{ display:flex; flex-wrap:wrap; gap:14px; margin-top:30px; }
.hero-seam{
  position:absolute; right:-40px; top:50%; transform:translateY(-50%);
  width:420px; max-width:40vw; opacity:.09; pointer-events:none;
}
@media (max-width:760px){ .hero-seam{ display:none; } }

.page-hero{
  background:var(--green-dark); color:var(--cream); padding:64px 0 56px;
  border-bottom:3px solid var(--red);
}
.page-hero h1{ color:#fff; margin-bottom:.3em; }
.breadcrumb{ font-size:.8rem; letter-spacing:.06em; text-transform:uppercase; color:var(--gold-light); font-weight:700; margin-bottom:14px; }

/* ===== Honours board (signature component) ===== */
.honours{
  background:var(--green-dark);
  border-top:3px solid var(--gold); border-bottom:3px solid var(--gold);
  padding:56px 0;
}
.honours-grid{
  display:grid; grid-template-columns:repeat(4,1fr); gap:0;
}
.honours-item{
  text-align:center; padding:0 20px; border-right:1px solid rgba(217,192,140,.25);
}
.honours-item:last-child{ border-right:none; }
.honours-num{
  font-family:var(--font-display); font-size:clamp(2.2rem,4vw,3.1rem); font-weight:700;
  color:var(--gold-light); display:block; letter-spacing:.02em;
}
.honours-label{
  font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; font-weight:700;
  color:var(--cream-deep); margin-top:6px; display:block;
}
@media (max-width:760px){
  .honours-grid{ grid-template-columns:repeat(2,1fr); row-gap:28px; }
  .honours-item{ border-right:none; }
}

/* ===== Cards ===== */
.grid{ display:grid; gap:28px; }
.grid-3{ grid-template-columns:repeat(3,1fr); }
.grid-2{ grid-template-columns:repeat(2,1fr); }
@media (max-width:900px){ .grid-3{ grid-template-columns:1fr 1fr; } }
@media (max-width:640px){ .grid-3,.grid-2{ grid-template-columns:1fr; } }

.card{
  background:var(--card); border:1px solid var(--line); border-radius:var(--radius);
  padding:30px; box-shadow:var(--shadow);
  border-top:4px solid var(--green);
}
.card.accent-red{ border-top-color:var(--red); }
.card.accent-gold{ border-top-color:var(--gold); }
.card h3{ margin-bottom:.35em; }
.card .tag{
  display:inline-block; font-size:.7rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase;
  color:var(--red); margin-bottom:10px;
}

/* Team scoreboard tiles */
.scoretile{
  background:var(--green-dark); color:var(--cream); border-radius:var(--radius);
  padding:26px 26px 22px; position:relative; overflow:hidden;
  border-bottom:5px solid var(--red);
}
.scoretile::before{
  content:attr(data-code); position:absolute; right:14px; top:8px;
  font-family:var(--font-display); font-size:3.2rem; font-weight:700;
  color:rgba(255,255,255,.06); line-height:1;
}
.scoretile .league{
  font-size:.7rem; letter-spacing:.12em; text-transform:uppercase; font-weight:700; color:var(--gold-light);
}
.scoretile h3{ color:#fff; margin:.3em 0 .5em; }
.scoretile p{ color:var(--cream-deep); font-size:.94rem; margin-bottom:0; }

/* Section variants */
.section-alt{ background:var(--cream-deep); }
.section-dark{ background:var(--green-dark); color:var(--cream); }
.section-dark h2{ color:#fff; }
.section-dark p{ color:var(--cream-deep); }

.split{
  display:grid; grid-template-columns:1.1fr .9fr; gap:56px; align-items:center;
}
@media (max-width:860px){ .split{ grid-template-columns:1fr; gap:32px; } }

.photo-block{
  aspect-ratio:4/3; border-radius:var(--radius); overflow:hidden;
  background:
    linear-gradient(160deg, rgba(2,85,29,.9), rgba(1,44,15,.95)),
    repeating-linear-gradient(115deg, #0B6B2A 0 60px, #095E24 60px 120px);
  display:flex; align-items:center; justify-content:center;
  color:rgba(255,255,255,.55); font-size:.8rem; letter-spacing:.08em; text-transform:uppercase;
  text-align:center; padding:20px; border:1px solid var(--line);
}

/* Timeline (About/history) */
.timeline{ border-left:3px solid var(--green); margin-left:6px; padding-left:34px; }
.timeline-item{ position:relative; padding-bottom:34px; }
.timeline-item::before{
  content:""; position:absolute; left:-42px; top:4px; width:16px; height:16px;
  border-radius:50%; background:var(--red); border:3px solid var(--cream);
}
.timeline-item .year{ font-family:var(--font-display); font-weight:700; color:var(--green-dark); font-size:1.2rem; }

/* Fixtures table */
.table-wrap{ overflow-x:auto; border-radius:var(--radius); box-shadow:var(--shadow); }
table.fixtures{ width:100%; border-collapse:collapse; background:var(--card); min-width:640px; }
table.fixtures th{
  background:var(--green-dark); color:var(--cream); text-align:left; padding:14px 16px;
  font-size:.75rem; letter-spacing:.08em; text-transform:uppercase;
}
table.fixtures td{ padding:14px 16px; border-bottom:1px solid var(--line); font-size:.94rem; }
table.fixtures tr:last-child td{ border-bottom:none; }
.pill{ display:inline-block; font-size:.72rem; font-weight:700; padding:4px 10px; border-radius:20px; }
.pill-home{ background:rgba(2,85,29,.12); color:var(--green); }
.pill-away{ background:rgba(214,0,0,.1); color:var(--red); }
.result-w{ color:var(--green); font-weight:700; }
.result-l{ color:var(--red); font-weight:700; }

.filter-bar{ display:flex; flex-wrap:wrap; gap:10px; margin-bottom:28px; }
.filter-bar button{
  font-family:var(--font-body); font-size:.82rem; font-weight:700; padding:9px 18px;
  border-radius:20px; border:2px solid var(--green); background:transparent; color:var(--green); cursor:pointer;
}
.filter-bar button.active, .filter-bar button:hover{ background:var(--green); color:#fff; }

/* Forms */
.form-grid{ display:grid; grid-template-columns:1fr 1fr; gap:18px; }
@media (max-width:640px){ .form-grid{ grid-template-columns:1fr; } }
.field{ display:flex; flex-direction:column; gap:6px; }
.field.full{ grid-column:1 / -1; }
label{ font-size:.82rem; font-weight:700; color:var(--green-dark); }
input,select,textarea{
  font-family:var(--font-body); font-size:.96rem; padding:12px 14px; border:1.5px solid var(--line);
  border-radius:3px; background:#fff; color:var(--ink);
}
input:focus,select:focus,textarea:focus{ outline:2px solid var(--green); outline-offset:1px; }

/* Pricing */
.price-card{ text-align:center; }
.price-card .amount{ font-family:var(--font-display); font-size:2.6rem; color:var(--green-dark); font-weight:700; }
.price-card .amount span{ font-size:1rem; font-weight:400; color:var(--ink-soft); }
.price-card ul{ text-align:left; margin:18px 0; }
.price-card li{ padding:8px 0; border-bottom:1px solid var(--line); font-size:.92rem; }
.price-card li:last-child{ border-bottom:none; }

/* News */
.news-card .date{ font-size:.78rem; font-weight:700; letter-spacing:.06em; text-transform:uppercase; color:var(--ink-soft); }

/* Sponsor strip */
.sponsor-strip{ display:flex; flex-wrap:wrap; gap:18px; align-items:center; justify-content:center; }
.sponsor-slot{
  background:var(--card); border:1px dashed var(--line); border-radius:var(--radius);
  padding:22px 30px; font-size:.8rem; color:var(--ink-soft); letter-spacing:.04em; text-transform:uppercase; font-weight:700;
}

/* Map */
.map-frame{
  border-radius:var(--radius); overflow:hidden; border:1px solid var(--line); box-shadow:var(--shadow);
}
.map-frame iframe{ width:100%; height:100%; min-height:340px; border:0; }

/* CTA banner */
.cta-banner{
  background:var(--red); color:#fff; border-radius:var(--radius); padding:44px;
  display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between; gap:24px;
}
.cta-banner h2{ color:#fff; margin:0; }
.cta-banner p{ color:rgba(255,255,255,.88); margin:6px 0 0; }

/* Footer */
.site-footer{ background:var(--green-dark); color:var(--cream-deep); padding:64px 0 28px; }
.footer-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:36px; }
@media (max-width:800px){ .footer-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:480px){ .footer-grid{ grid-template-columns:1fr; } }
.footer-grid h4{ color:var(--gold-light); font-family:var(--font-body); font-size:.82rem; letter-spacing:.1em; text-transform:uppercase; margin-bottom:16px; }
.footer-grid ul li{ margin-bottom:10px; font-size:.92rem; }
.footer-grid a:hover{ color:#fff; text-decoration:underline; }
.footer-bottom{
  border-top:1px solid rgba(245,239,223,.15); margin-top:48px; padding-top:24px;
  display:flex; flex-wrap:wrap; justify-content:space-between; gap:12px; font-size:.8rem; color:rgba(245,239,223,.6);
}

.section-head{ max-width:680px; margin-bottom:44px; }
.section-head.center{ margin-left:auto; margin-right:auto; text-align:center; }

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

/* ==========================================================================
   Additions — dropdown submenus, editor placeholders, live/ticker embeds,
   committee table. Nothing above this line has been changed.
   ========================================================================== */

/* Dropdown submenus for nested pages (About > Our History, Teams > Saturday Cricket, etc.)
   Build these via Appearance > Menus by dragging child items under a parent. */
.main-nav .nav-menu li{ position:relative; }
.main-nav .nav-menu .sub-menu{
	list-style:none; margin:0; padding:8px 0; display:none;
	position:absolute; top:100%; left:0; min-width:220px; z-index:50;
	background:var(--green-dark); border:1px solid rgba(217,192,140,.25); border-top:3px solid var(--red);
	box-shadow:0 14px 30px rgba(1,44,15,.3);
}
.main-nav .nav-menu li:hover > .sub-menu,
.main-nav .nav-menu li:focus-within > .sub-menu{ display:block; }
.main-nav .nav-menu .sub-menu a{ display:block; padding:10px 18px; white-space:nowrap; }
.main-nav .nav-menu .sub-menu li{ border-bottom:0; }
@media (max-width:960px){
	.main-nav .nav-menu .sub-menu{ position:static; box-shadow:none; border:none; background:rgba(0,0,0,.15); display:block; padding-left:14px; }
}

/* Editor placeholders — italic grey notes marking content still to be filled in */
.editor-note{
	font-style:italic; color:#8a8f7f; background:rgba(2,85,29,.06);
	border:1px dashed rgba(2,85,29,.3); border-radius:6px; padding:12px 16px; font-size:.88rem;
}
.editor-note strong{ font-style:normal; color:var(--green-dark); }

/* Live scores / stream embeds */
.embed-frame{
	background:var(--green-dark); border-radius:var(--radius); border-bottom:5px solid var(--red);
	overflow:hidden; box-shadow:var(--shadow);
}
.embed-frame iframe{ width:100%; border:0; display:block; }
.embed-frame.ticker iframe{ height:90px; }
.embed-frame.stream{ position:relative; padding-top:56.25%; height:0; border-bottom:5px solid var(--gold); }
.embed-frame.stream iframe{ position:absolute; top:0; left:0; width:100%; height:100%; }
.embed-label{
	font-size:.72rem; font-weight:700; letter-spacing:.12em; text-transform:uppercase;
	color:var(--gold-light); background:var(--green-dark); padding:8px 16px; display:block;
}

/* Committee table reuses the fixtures table look */
table.committee th{ background:var(--green-dark); color:var(--cream); }
table.committee td{ vertical-align:top; }
