/* ==========================================================================
   Discover Highworth — site stylesheet
   Built to the Highworth Town Council Brand Guidelines v1.0 (June 2026):
   Highworth Navy, Charter Gold, Common Green, Market Red, Cotswold Cream,
   Bitter for headings, Source Sans 3 for body. WCAG 2.2 AA combinations only.
   ========================================================================== */

:root{
  --navy:#1B3A5C;
  --navy-80:#496181;
  --navy-20:#D1D8E0;
  --navy-10:#E8EBEF;
  --gold:#C9A227;
  --green:#3F6F4F;
  --green-20:#D9E2DC;
  --red:#9E3B2B;
  --cream:#F7F2E7;
  --stone:#EFE8D8;
  --sarsen:#565B5E;
  --ink:#20262B;
  --white:#FFFFFF;
  --serif:'Bitter', Georgia, 'Times New Roman', serif;
  --sans:'Source Sans 3', 'Segoe UI', Arial, sans-serif;
  --maxw:1120px;
  --radius:14px;
  --shadow:0 1px 2px rgba(32,38,43,.06), 0 8px 28px rgba(32,38,43,.07);
}

*{box-sizing:border-box; margin:0; padding:0;}
html{scroll-behavior:smooth;}
body{
  font-family:var(--sans);
  font-size:17px; line-height:1.65;
  color:var(--ink);
  background:var(--cream);
}
::selection{background:var(--gold); color:var(--navy);}

img{max-width:100%; display:block;}
a{color:var(--navy); text-decoration-color:rgba(201,162,39,.7); text-underline-offset:2px;}
a:hover{color:#142C46;}

.wrap{max-width:var(--maxw); margin:0 auto; padding:0 28px;}
@media (max-width:860px){ .wrap{padding:0 18px;} }

.skip{
  position:absolute; left:-9999px; top:0; z-index:100;
  background:var(--navy); color:#fff; padding:10px 18px; border-radius:0 0 10px 0; font-weight:700;
}
.skip:focus{left:0;}

/* ---------- type ---------- */
h1,h2,h3,h4{font-family:var(--serif); color:var(--navy); line-height:1.18; font-weight:700;}
h1{font-size:clamp(34px,5vw,52px);}
h2{font-size:clamp(26px,3.5vw,34px); margin:34px 0 12px;}
h3{font-size:21px; margin:26px 0 8px;}
h4{font-size:17px; margin:16px 0 6px;}
p{margin:10px 0;}
ul,ol{margin:10px 0 10px 24px;}
li{margin:4px 0;}
.lede{font-size:20px; color:var(--sarsen); max-width:66ch;}
.small{font-size:14px; color:var(--sarsen);}
.kicker{font-weight:700; color:var(--navy);}

.eyebrow{
  font-weight:700; font-size:13px;
  letter-spacing:.22em; text-transform:uppercase; color:var(--gold);
  display:flex; align-items:center; gap:14px; margin:0 0 14px;
}
.eyebrow::after{content:""; height:1px; flex:0 0 64px; background:var(--gold); opacity:.6;}

table{width:100%; border-collapse:collapse; margin:14px 0; background:var(--white); font-size:15.5px;}
th,td{text-align:left; padding:10px 14px; border-bottom:1px solid rgba(27,58,92,.12); vertical-align:top;}
th{font-family:var(--sans); font-size:12.5px; letter-spacing:.12em; text-transform:uppercase; color:var(--sarsen); border-bottom:2px solid var(--navy);}
@media (max-width:700px){
  .table-scroll{overflow-x:auto;}
  .table-scroll table{min-width:560px;}
}

/* ---------- header ---------- */
.topbar{
  position:sticky; top:0; z-index:50;
  background:rgba(255,255,255,.96); backdrop-filter:blur(8px);
  border-bottom:1px solid rgba(27,58,92,.12);
}
.topbar .wrap{display:flex; align-items:center; gap:16px; min-height:64px; flex-wrap:wrap; padding-top:6px; padding-bottom:6px;}
.brand{display:inline-flex; align-items:center; gap:12px; text-decoration:none; color:var(--navy);}
.brand .mark{height:40px; width:40px; color:var(--navy); flex:0 0 auto;}
.brand .l1{font-family:var(--serif); font-weight:700; font-size:19px; letter-spacing:.045em; line-height:1; display:block;}
.brand .l2{font-weight:600; font-size:10px; letter-spacing:.4em; text-transform:uppercase; color:var(--sarsen); display:block; margin-top:4px;}

.nav-toggle{
  margin-left:auto; display:none;
  background:var(--navy); color:#fff; border:none; border-radius:9px;
  font:700 14px var(--sans); padding:9px 14px; cursor:pointer;
}

nav.mainnav{margin-left:auto; display:flex; align-items:center; gap:2px;}
nav.mainnav > a, .navgroup > button{
  font:600 15px var(--sans); color:var(--ink); text-decoration:none; background:none; border:none;
  padding:9px 13px; border-radius:9px; cursor:pointer; white-space:nowrap;
}
nav.mainnav > a:hover, .navgroup > button:hover{background:var(--cream); color:var(--navy);}
nav.mainnav > a.active{background:var(--stone); color:var(--navy);}
.navgroup{position:relative;}
.navgroup > button::after{content:" ▾"; font-size:11px; color:var(--gold);}
.navgroup .dropdown{
  display:none; position:absolute; top:calc(100% + 6px); left:0; min-width:230px;
  background:var(--white); border:1px solid rgba(27,58,92,.14); border-radius:12px;
  box-shadow:var(--shadow); padding:8px; z-index:60;
}
.navgroup.open .dropdown{display:block;}
.navgroup .dropdown a{
  display:block; padding:9px 12px; border-radius:8px; text-decoration:none;
  font-weight:600; font-size:14.5px; color:var(--ink);
}
.navgroup .dropdown a:hover{background:var(--cream); color:var(--navy);}
.navgroup .dropdown a.active{background:var(--stone); color:var(--navy);}
.navgroup .dropdown a.active::before{content:"› "; color:var(--gold); font-weight:700;}

@media (max-width:980px){
  .nav-toggle{display:block;}
  nav.mainnav{
    display:none; flex-direction:column; align-items:stretch; gap:0;
    flex-basis:100%; padding:8px 0 14px;
  }
  nav.mainnav.open{display:flex;}
  .navgroup .dropdown{position:static; display:block; border:none; box-shadow:none; padding:0 0 4px 18px; min-width:0;}
  .navgroup > button{width:100%; text-align:left;}
  .navgroup > button::after{content:"";}
}

/* ---------- hero ---------- */
.hero{background:var(--navy); color:var(--white); position:relative; overflow:hidden;}
.hero .wrap{padding-top:58px; padding-bottom:30px; position:relative; z-index:2;}
.hero .eyebrow{margin-bottom:10px;}
.hero h1{color:var(--white);}
.hero h1 .dot{color:var(--gold);}
.hero .lede{color:#C7D2DF; margin-top:12px;}
.hero .skyband{display:block; width:100%; color:rgba(247,242,231,.14); position:relative; z-index:1;}
.hero--home .wrap{padding-top:74px; padding-bottom:44px;}
.hero .crumbs{font-size:13px; letter-spacing:.06em; margin-bottom:22px;}
.hero .crumbs a{color:#C7D2DF; text-decoration:none;}
.hero .crumbs a:hover{color:var(--gold);}
.hero .crumbs span{color:#8FA2B6;}

/* ---------- layout / panels ---------- */
main{padding:14px 0 30px;}
section.block{padding:28px 0 6px;}
.panel{
  background:var(--white); border:1px solid rgba(27,58,92,.10);
  border-radius:var(--radius); box-shadow:var(--shadow);
  padding:28px; margin:22px 0;
}
.panel.tinted{background:var(--stone);}
.panel.green{background:#EFF4F0; border-color:rgba(63,111,79,.25);}
.panel > :first-child{margin-top:0;}
.grid{display:grid; gap:20px; margin:20px 0;}
.g2{grid-template-columns:repeat(2,1fr);}
.g3{grid-template-columns:repeat(3,1fr);}
.g4{grid-template-columns:repeat(4,1fr);}
@media (max-width:980px){ .g4{grid-template-columns:repeat(2,1fr);} }
@media (max-width:760px){ .g2,.g3,.g4{grid-template-columns:1fr;} .panel{padding:20px;} }

/* ---------- cards ---------- */
.card{
  background:var(--white); border:1px solid rgba(27,58,92,.10); border-radius:var(--radius);
  box-shadow:var(--shadow); overflow:hidden; display:flex; flex-direction:column;
}
.card .card-media{height:170px; position:relative; overflow:hidden;}
.card .card-media img{width:100%; height:100%; object-fit:cover;}
.card .card-body{padding:18px 20px 20px; display:flex; flex-direction:column; flex:1;}
.card h3{margin:0 0 6px; font-size:19px;}
.card p{margin:6px 0; font-size:15.5px;}
.card .card-link{margin-top:auto; padding-top:10px; font-weight:700; text-decoration:none; color:var(--navy);}
.card .card-link::after{content:" →"; color:var(--gold);}
a.card-wrap{text-decoration:none; color:inherit;}
a.card-wrap:hover .card, .card:hover{border-color:rgba(201,162,39,.55);}

/* Branded placeholder art when no photo is available */
.ph{
  height:100%; min-height:170px; display:flex; align-items:flex-end; padding:14px;
  color:rgba(255,255,255,.92); font-weight:600; font-size:14px; letter-spacing:.02em; position:relative;
}
.ph svg{position:absolute; left:0; right:0; bottom:-2px; width:100%; color:rgba(247,242,231,.22);}
.ph.navy{background:linear-gradient(160deg,#2C4E74,#1B3A5C 55%,#142C46);}
.ph.gold{background:linear-gradient(160deg,#D9B64A,#C9A227 55%,#A98718);}
.ph.green{background:linear-gradient(160deg,#5C8F6D,#3F6F4F 55%,#2F543C);}

/* ---------- figures & image credits ---------- */
figure.photo{margin:22px 0; background:var(--white); border:1px solid rgba(27,58,92,.10); border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow);}
figure.photo img{width:100%; max-height:460px; object-fit:cover;}
figure.photo figcaption{padding:10px 16px 12px; font-size:13.5px; color:var(--sarsen);}
figure.photo figcaption .credit{display:block; font-size:12.5px; opacity:.9;}
figure.photo figcaption a{color:var(--sarsen);}

/* ---------- venue / listing rows ---------- */
.venue{
  background:var(--white); border:1px solid rgba(27,58,92,.10); border-radius:var(--radius);
  box-shadow:var(--shadow); padding:20px 24px; margin:16px 0;
}
.venue-head{display:flex; align-items:baseline; gap:12px; flex-wrap:wrap;}
.venue-head h3{margin:0; font-size:20px;}
.venue-meta{font-size:14.5px; color:var(--sarsen); margin:6px 0 8px;}
.venue-meta a{color:var(--navy); font-weight:600;}
.venue-meta .sep{color:var(--gold); padding:0 6px;}
.venue p{margin:8px 0 0; font-size:16px;}

.pill{
  display:inline-block; font-size:12px; font-weight:700; letter-spacing:.06em;
  padding:2px 10px; border-radius:99px; text-transform:uppercase;
  background:var(--navy-10); color:var(--navy); vertical-align:middle;
}
.pill.green{background:var(--green-20); color:#2C5A3B;}
.pill.gold{background:#F3E9C8; color:#7A6210;}
.pill.red{background:#F6E4E0; color:var(--red);}

/* ---------- buttons ---------- */
.btn{
  display:inline-block; background:var(--navy); color:#fff; font:700 15px var(--sans);
  padding:11px 20px; border-radius:10px; text-decoration:none; border:none; cursor:pointer;
}
.btn:hover{background:#142C46; color:#fff;}
.btn.gold{background:var(--gold); color:var(--navy);}
.btn.gold:hover{background:#B89220;}
.btn.ghost{background:transparent; color:var(--navy); border:2px solid var(--navy); padding:9px 18px;}
.btn.ghost:hover{background:var(--navy-10);}
.btn-row{display:flex; gap:12px; flex-wrap:wrap; margin:16px 0;}

/* ---------- info boxes ---------- */
.note{
  background:var(--stone); border-left:4px solid var(--gold); border-radius:0 10px 10px 0;
  padding:14px 18px; margin:18px 0; font-size:15.5px;
}
.alert{
  background:#FBF1EF; border-left:4px solid var(--red); border-radius:0 10px 10px 0;
  padding:14px 18px; margin:18px 0; font-size:15.5px;
}
.alert .kicker{color:var(--red);}
.note > :first-child, .alert > :first-child{margin-top:0;}
.note > :last-child, .alert > :last-child{margin-bottom:0;}

/* ---------- quick facts strip ---------- */
.facts{display:grid; grid-template-columns:repeat(auto-fit,minmax(170px,1fr)); gap:14px; margin:22px 0;}
.fact{
  background:var(--white); border:1px solid rgba(27,58,92,.10); border-radius:12px;
  padding:14px 16px; box-shadow:var(--shadow);
}
.fact .f-label{font-size:11.5px; letter-spacing:.14em; text-transform:uppercase; color:var(--sarsen); font-weight:700;}
.fact .f-value{font-family:var(--serif); font-weight:700; color:var(--navy); font-size:19px; line-height:1.3; margin-top:3px;}
.fact .f-sub{font-size:13px; color:var(--sarsen);}

/* ---------- timeline (history pages) ---------- */
.timeline{list-style:none; margin:26px 0; padding:0; position:relative;}
.timeline::before{content:""; position:absolute; left:9px; top:6px; bottom:6px; width:2px; background:var(--gold); opacity:.55;}
.timeline li{position:relative; padding:0 0 22px 38px; margin:0;}
.timeline li::before{
  content:""; position:absolute; left:2px; top:7px; width:16px; height:16px; border-radius:50%;
  background:var(--gold); border:3px solid var(--cream); box-shadow:0 0 0 1px rgba(27,58,92,.3);
}
.timeline .tl-year{font-family:var(--serif); font-weight:700; color:var(--navy); font-size:19px; display:block;}
.timeline p{margin:4px 0 0; font-size:16px;}

/* ---------- section heads ---------- */
.section-head{margin:36px 0 6px;}
.section-head .eyebrow{margin-bottom:8px;}
.section-head h2{margin:0 0 8px;}
.section-head .lede{font-size:18px;}

/* ---------- sources / credits ---------- */
.sources{margin:40px 0 10px; font-size:13.5px; color:var(--sarsen);}
.sources summary{font-weight:700; cursor:pointer; color:var(--navy); font-size:14.5px;}
.sources ul{margin:10px 0 6px 22px;}
.sources li{margin:3px 0;}
.sources a{color:var(--sarsen); overflow-wrap:anywhere;}

/* ---------- footer ---------- */
.endcap{background:var(--navy); color:#C7D2DF; margin-top:64px;}
.endcap .skyband{display:block; width:100%; color:var(--gold); opacity:.9;}
.endcap .wrap{padding:46px 28px 26px;}
.endcap h3{color:var(--white); margin-top:0; font-size:19px;}
.endcap a{color:#E8DCAE; text-decoration:none;}
.endcap a:hover{color:var(--gold); text-decoration:underline;}
.endcap .cols{display:grid; grid-template-columns:1.2fr 1fr 1fr 1fr; gap:30px;}
@media (max-width:860px){ .endcap .cols{grid-template-columns:1fr 1fr;} }
@media (max-width:560px){ .endcap .cols{grid-template-columns:1fr;} }
.endcap ul{list-style:none; margin:0; padding:0;}
.endcap li{margin:7px 0; font-size:14.5px;}
.endcap p{font-size:14.5px;}
.endcap .fine{
  font-size:12.5px; color:#8FA2B6; margin-top:30px;
  border-top:1px solid rgba(255,255,255,.14); padding-top:16px;
}
.endcap .fine a{color:#8FA2B6; text-decoration:underline;}
.endcap .foot-lockup{display:flex; align-items:center; gap:12px; color:var(--gold); margin-bottom:12px;}
.endcap .foot-lockup svg{width:46px; height:46px;}
.endcap .foot-lockup .l1{font-family:var(--serif); font-weight:700; font-size:18px; letter-spacing:.05em; color:var(--white);}
.endcap .foot-lockup .l2{font-size:9.5px; letter-spacing:.38em; text-transform:uppercase; color:var(--gold);}

/* ---------- home page extras ---------- */
.tile-band{padding:10px 0 4px;}
.welcome-grid{display:grid; grid-template-columns:1.15fr .85fr; gap:26px; align-items:start;}
@media (max-width:860px){ .welcome-grid{grid-template-columns:1fr;} }

@media print{
  .topbar,.nav-toggle,.skip{display:none;}
  body{background:#fff;}
  .hero{background:#fff; color:var(--ink);}
  .hero h1{color:var(--navy);}
  .panel,.card,.venue{box-shadow:none;}
  .endcap{background:#fff; color:var(--ink);}
}
