/* ══════════════════════════════════════════
   Lancaster Archery Club — Shared Stylesheet
   All pages link to this file.
   ══════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,600;0,700;1,400;1,600&family=Source+Sans+3:wght@300;400;500;600&family=Oswald:wght@300;400;500;600&display=swap');

:root {
  --hunter: #1b3a1f;
  --bark:   #2e4a22;
  --fern:   #3d5c2e;
  --copper: #b5652a;
  --amber:  #d4891e;
  --cream:  #f5f0e8;
  --parch:  #ede5d4;
  --linen:  #e8dfc9;
  --stone:  #7a7267;
  --ink:    #1a1a18;
  --white:  #ffffff;
}

*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; font-size:16px; }
body { font-family:'Source Sans 3',sans-serif; background:var(--cream); color:var(--ink); overflow-x:hidden; }
img  { display:block; max-width:100%; }
a    { text-decoration:none; color:inherit; }

/* ─── NAVIGATION ─── */
#nav {
  position:fixed; top:0; left:0; right:0; z-index:999;
  height:68px;
  display:flex; align-items:center; justify-content:space-between;
  padding:0 3rem;
  background:rgba(27,58,31,0.97);
  backdrop-filter:blur(12px);
  border-bottom:2px solid var(--copper);
  transition:height .3s;
}
.nav-logo { display:flex; align-items:center; gap:.9rem; }
.nav-emblem { width:42px; height:42px; flex-shrink:0; }
.nav-name {
  font-family:'Playfair Display',serif;
  font-size:1.05rem; font-weight:600;
  color:var(--cream); line-height:1.15;
}
.nav-name small {
  display:block;
  font-family:'Oswald',sans-serif;
  font-weight:300; font-size:.62rem;
  letter-spacing:.22em; text-transform:uppercase;
  color:var(--amber); margin-top:1px;
}
.nav-menu { display:flex; align-items:center; gap:2rem; list-style:none; }
.nav-menu a {
  font-family:'Oswald',sans-serif;
  font-weight:400; font-size:.8rem;
  letter-spacing:.18em; text-transform:uppercase;
  color:rgba(245,240,232,.75);
  transition:color .2s;
}
.nav-menu a:hover,
.nav-menu a.active { color:var(--amber); }
.nav-join {
  background:var(--copper);
  color:var(--cream) !important;
  padding:.45rem 1.1rem;
  border-radius:1px;
  transition:background .2s !important;
}
.nav-join:hover { background:var(--amber); color:var(--ink) !important; }
.nav-hamburger { display:none; flex-direction:column; gap:5px; cursor:pointer; padding:4px; }
.nav-hamburger span { display:block; width:24px; height:2px; background:var(--cream); transition:.3s; }

/* ─── PAGE HEADER (interior pages) ─── */
.page-header {
  background:var(--hunter);
  padding:120px 5rem 4rem;
  border-bottom:3px solid var(--copper);
}
.page-header-inner { max-width:700px; }
.page-header .sec-tag { margin-bottom:.8rem; }
.page-header h1 {
  font-family:'Playfair Display',serif;
  font-weight:400; font-size:clamp(2.2rem,4vw,3.2rem);
  color:var(--cream); line-height:1.1;
  margin-bottom:1rem;
}
.page-header p {
  font-size:1rem; font-weight:300;
  color:rgba(245,240,232,.7); line-height:1.8;
}

/* ─── SECTION BASE ─── */
.section { padding:6rem 5rem; }
.sec-tag { display:flex; align-items:center; gap:.7rem; margin-bottom:.9rem; }
.sec-tag::before { content:''; display:block; width:28px; height:2px; background:var(--copper); }
.sec-tag span {
  font-family:'Oswald',sans-serif;
  font-size:.7rem; letter-spacing:.25em;
  text-transform:uppercase; color:var(--copper); font-weight:500;
}
h2.sec-title {
  font-family:'Playfair Display',serif;
  font-weight:400; font-size:clamp(1.9rem,3.5vw,2.8rem);
  line-height:1.15; margin-bottom:1.4rem;
}
.sec-body { font-size:1rem; font-weight:300; color:#444; line-height:1.85; }

/* ─── BUTTONS ─── */
.btn {
  display:inline-block;
  font-family:'Oswald',sans-serif;
  font-weight:500; font-size:.8rem;
  letter-spacing:.2em; text-transform:uppercase;
  padding:.85rem 2rem; border-radius:1px;
  transition:all .25s;
}
.btn-solid { background:var(--copper); color:var(--cream); }
.btn-solid-gold { background:var(--cream); color:var(--copper); }
.btn-solid:hover { background:var(--amber); transform:translateY(-2px); }
.btn-ghost { border:1px solid rgba(245,240,232,.45); color:var(--cream); }
.btn-ghost:hover { border-color:var(--amber); color:var(--amber); transform:translateY(-2px); }
.btn-outline-dark { border:1px solid var(--copper); color:var(--copper); }
.btn-outline-dark:hover { background:var(--copper); color:var(--cream); transform:translateY(-2px); }

/* ─── STATS RIBBON ─── */
.ribbon {
  background:var(--ink);
  border-top:2px solid var(--copper);
  display:grid; grid-template-columns:repeat(4,1fr);
}
.rib-item { padding:2rem 1.5rem; text-align:center; border-right:1px solid rgba(255,255,255,.07); }
.rib-item:last-child { border-right:none; }
.rib-num {
  font-family:'Playfair Display',serif;
  font-size:2.6rem; font-weight:600;
  color:var(--amber); line-height:1; margin-bottom:.35rem;
}
.rib-label {
  font-family:'Oswald',sans-serif;
  font-size:.68rem; letter-spacing:.2em;
  text-transform:uppercase; color:rgba(245,240,232,.45);
}

/* ─── ABOUT / STORY ─── */
.story { background:var(--cream); }
.story-grid { display:grid; grid-template-columns:1fr 1fr; gap:5rem; align-items:center; }
.story-img-wrap { position:relative; }
.story-photo {
  width:100%; aspect-ratio:4/3;
  object-fit:cover; object-position:center 20%;
  border-radius:2px;
  box-shadow:0 20px 60px rgba(0,0,0,.18);
}
.story-badge {
  position:absolute; bottom:-1.4rem; right:-1.4rem;
  width:96px; height:96px;
  background:var(--copper); border-radius:50%;
  border:4px solid var(--cream);
  display:flex; flex-direction:column;
  align-items:center; justify-content:center;
  box-shadow:0 8px 24px rgba(0,0,0,.2);
}
.badge-yr { font-family:'Playfair Display',serif; font-size:1.45rem; font-weight:700; color:var(--white); line-height:1; }
.badge-lbl { font-family:'Oswald',sans-serif; font-size:.55rem; letter-spacing:.12em; text-transform:uppercase; color:rgba(255,255,255,.8); }
.story-text p { font-size:1rem; font-weight:300; color:#3a3a38; line-height:1.85; margin-bottom:1.1rem; }
.story-highlights { display:grid; grid-template-columns:1fr 1fr; gap:.8rem; margin-top:1.8rem; }
.hi-card { background:var(--parch); border-left:3px solid var(--copper); padding:.9rem 1.1rem; border-radius:0 2px 2px 0; }
.hi-title { font-family:'Oswald',sans-serif; font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; font-weight:500; color:var(--hunter); margin-bottom:.3rem; }
.hi-desc { font-size:.85rem; color:var(--stone); line-height:1.5; font-weight:300; }

/* ─── FACILITY ─── */
.facility { background:var(--hunter); color:var(--cream); }
.facility h2.sec-title { color:var(--cream); }
.facility .sec-body { color:rgba(245,240,232,.7); max-width:600px; margin-bottom:3rem; }
.fac-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:2px; background:rgba(255,255,255,.06); }
.fac-card { background:rgba(27,58,31,.9); padding:2.2rem 1.8rem; border-bottom:3px solid transparent; transition:all .3s; }
.fac-card:hover { background:rgba(46,74,34,.95); border-bottom-color:var(--copper); }
.fac-icon { font-size:1.6rem; margin-bottom:1rem; display:inline-block; }
.fac-card h3 { font-family:'Playfair Display',serif; font-size:1.1rem; font-weight:600; color:var(--cream); margin-bottom:.6rem; }
.fac-card p { font-size:.88rem; font-weight:300; color:rgba(245,240,232,.58); line-height:1.7; }

/* ─── EVENTS ─── */
.events { background:var(--parch); }
.events-header { display:flex; justify-content:space-between; align-items:flex-end; margin-bottom:2.5rem; flex-wrap:wrap; gap:1.5rem; }
.events-list { display:flex; flex-direction:column; gap:2px; }
.ev-row { display:grid; grid-template-columns:72px 1fr auto; align-items:center; gap:2rem; padding:1.6rem 2rem; background:var(--cream); transition:background .2s; cursor:pointer; }
.ev-row:hover { background:var(--white); }
.ev-date { text-align:center; }
.ev-mon { font-family:'Oswald',sans-serif; font-size:.65rem; letter-spacing:.2em; text-transform:uppercase; color:var(--copper); font-weight:600; }
.ev-day { font-family:'Playfair Display',serif; font-size:2.2rem; font-weight:600; color:var(--hunter); line-height:1; }
.ev-info h4 { font-family:'Playfair Display',serif; font-size:1.1rem; font-weight:600; margin-bottom:.3rem; color:var(--ink); }
.ev-info p { font-size:.88rem; font-weight:300; color:var(--stone); }
.ev-badge { font-family:'Oswald',sans-serif; font-size:.65rem; letter-spacing:.15em; text-transform:uppercase; font-weight:500; padding:.3rem .8rem; border-radius:1px; background:rgba(61,92,46,.12); color:var(--bark); white-space:nowrap; }
.ev-badge.red { background:rgba(181,101,42,.12); color:var(--copper); }
a.ev-row {
  text-decoration: none;
  color: inherit;
  display: grid;
}
.ev-col1 {text-align: center; width: 5em;}

/* ─── MEMBERSHIP ─── */
.membership { background:var(--cream); }
.mem-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; margin-top:3rem; }
.mem-card { border:1px solid var(--linen); padding:2.2rem 1.8rem; border-radius:2px; position:relative; transition:transform .3s,box-shadow .3s; background:var(--white); }
.mem-card:hover { transform:translateY(-5px); box-shadow:0 16px 48px rgba(27,58,31,.1); }
.mem-card.featured { background:var(--hunter); border-color:var(--hunter); }
.mem-card.featured h3 { color:var(--cream); }
.mem-popular { position:absolute; top:1rem; right:1rem; font-family:'Oswald',sans-serif; font-size:.62rem; letter-spacing:.12em; text-transform:uppercase; color:var(--amber); background:rgba(212,137,30,.15); padding:.25rem .6rem; border-radius:1px; }
.mem-type { font-family:'Oswald',sans-serif; font-size:.7rem; letter-spacing:.2em; text-transform:uppercase; color:var(--copper); margin-bottom:.5rem; }
.mem-card h3 { font-family:'Playfair Display',serif; font-size:1.6rem; font-weight:600; margin-bottom:.4rem; color:var(--hunter); }
.mem-price { font-family:'Playfair Display',serif; font-size:2.2rem; font-weight:400; color:var(--copper); margin-bottom:1.6rem; line-height:1; }
.mem-card.featured .mem-price { color:var(--amber); }
.mem-price small { font-size:1rem; font-weight:300; color:var(--stone); }
.mem-card.featured .mem-price small { color:rgba(245,240,232,.5); }
.mem-list { list-style:none; margin-bottom:1.8rem; }
.mem-list li { font-size:.88rem; font-weight:300; color:#444; padding:.45rem 0; border-bottom:1px solid rgba(0,0,0,.06); display:flex; align-items:center; gap:.55rem; }
.mem-card.featured .mem-list li { color:rgba(245,240,232,.7); border-bottom-color:rgba(255,255,255,.08); }
.mem-list li::before { content:'✓'; color:var(--fern); font-weight:700; font-size:.8rem; flex-shrink:0; }
.mem-card.featured .mem-list li::before { color:var(--amber); }
.mem-note { font-size:.8rem; font-weight:300; color:var(--stone); text-align:center; margin-top:1.5rem; }

/* ─── CONTACT ─── */
.contact { background:var(--ink); color:var(--cream); display:grid; grid-template-columns:1fr 1fr; gap:5rem; padding:6rem 5rem; }
.contact h2.sec-title { color:var(--cream); }
.contact-details { display:flex; flex-direction:column; gap:1.8rem; margin-top:1.5rem; }
.cd-row { display:flex; gap:1.1rem; align-items:flex-start; }
.cd-icon { width:38px; height:38px; flex-shrink:0; background:rgba(181,101,42,.2); border:1px solid rgba(181,101,42,.3); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:.95rem; }
.cd-lbl { font-family:'Oswald',sans-serif; font-size:.68rem; letter-spacing:.2em; text-transform:uppercase; color:var(--amber); margin-bottom:.3rem; }
.cd-val { font-size:.9rem; font-weight:300; color:rgba(245,240,232,.75); line-height:1.65; }
.map-box { margin-top:2rem; height:220px; background:rgba(46,74,34,.5); border:1px solid rgba(255,255,255,.07); border-radius:2px; display:flex; align-items:center; justify-content:center; font-family:'Playfair Display',serif; font-style:italic; color:rgba(245,240,232,.25); font-size:.9rem; }
.cf-form { display:flex; flex-direction:column; gap:.9rem; margin-top:1.5rem; }
.cf-row { display:grid; grid-template-columns:1fr 1fr; gap:.9rem; }
.cf-group { display:flex; flex-direction:column; gap:.35rem; }
.cf-group label { font-family:'Oswald',sans-serif; font-size:.68rem; letter-spacing:.18em; text-transform:uppercase; color:rgba(245,240,232,.4); }
.cf-group input,.cf-group select,.cf-group textarea { background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.12); border-radius:1px; padding:.75rem .9rem; color:var(--cream); font-family:'Source Sans 3',sans-serif; font-weight:300; font-size:.9rem; outline:none; transition:border-color .2s; }
.cf-group input:focus,.cf-group select:focus,.cf-group textarea:focus { border-color:var(--copper); }
.cf-group select option { background:var(--ink); }
.cf-group textarea { resize:vertical; min-height:90px; }

/* ─── FOOTER ─── */
footer { background:#0e1510; padding:2.5rem 5rem; display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:1rem; border-top:1px solid rgba(255,255,255,.05); }
.ft-copy { font-size:.82rem; font-weight:300; color:rgba(245,240,232,.3); }
.ft-links { display:flex; gap:1.8rem; list-style:none; }
.ft-links a { font-family:'Oswald',sans-serif; font-size:.7rem; letter-spacing:.15em; text-transform:uppercase; color:rgba(245,240,232,.3); transition:color .2s; }
.ft-links a:hover { color:var(--amber); }
.ft-social a { display:inline-flex; align-items:center; justify-content:center; width:34px; height:34px; border:1px solid rgba(255,255,255,.12); border-radius:50%; color:rgba(245,240,232,.4); font-size:.85rem; transition:all .2s; }
.ft-social a:hover { border-color:var(--amber); color:var(--amber); }

/* ─── REVEAL ANIMATION ─── */
.reveal { opacity:0; transform:translateY(24px); transition:opacity .7s ease,transform .7s ease; }
.reveal.in { opacity:1; transform:none; }
.d1{transition-delay:.1s} .d2{transition-delay:.2s} .d3{transition-delay:.3s} .d4{transition-delay:.4s}

/* ─── RESPONSIVE ─── */
@media(max-width:960px){
  html, body { overflow-x:hidden; max-width:100%; }
  #nav { padding:0 1rem; }
  .nav-name small { display:none; }
  .nav-menu { display:none; }
  .nav-hamburger { display:flex; }
  .section,.story,.facility,.events,.membership,.contact { padding:4rem 1.5rem; }
  .page-header { padding:100px 1.5rem 3rem; }
  .story-grid { grid-template-columns:1fr; gap:3rem; }
  .story-badge { bottom:-.8rem; right:-.5rem; }
  .fac-grid { grid-template-columns:1fr; }
  .mem-grid { grid-template-columns:1fr; }
  .events-header { flex-direction:column; align-items:flex-start; }
  .ev-row { grid-template-columns:60px 1fr; gap:1rem; }
  .ev-badge { display:none; }
  .contact { grid-template-columns:1fr; gap:3rem; padding:4rem 1.5rem; }
  .cf-row { grid-template-columns:1fr; }
  .ribbon { grid-template-columns:1fr 1fr; }
  footer { flex-direction:column; text-align:center; padding:2rem 1.5rem; }
}
