/* ═══════════════════════════════════════════════════════
   RCCG Winners' Place Aldershot — Shared Stylesheet
   All pages import this file as <link rel="stylesheet" href="/shared.css">
   (adjust path with ../ prefix for subdirectory pages)
═══════════════════════════════════════════════════════ */

/* ── TOKENS ── */
:root{
  --gold:#C9973A;--gold-lt:#E8C06B;--gold-dk:#A07828;
  --navy:#0D1B2A;--navy-md:#162438;--navy-lt:#1E3250;
  --cream:#FAF7F2;--warm:#FFFDF9;
  --text:#1A1A1A;--muted:#5E5E5E;
  --border:rgba(201,151,58,.22);
  --ff-d:'Cormorant Garamond',Georgia,serif;
  --ff-b:'DM Sans',sans-serif;
  --r:5px;--ease:cubic-bezier(.4,0,.2,1);
  --t:.3s var(--ease);
  --sh:0 2px 20px rgba(13,27,42,.10);
  --sh-lg:0 8px 48px rgba(13,27,42,.20);
}

/* ── RESET ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--ff-b);background:var(--cream);color:var(--text);line-height:1.72;overflow-x:hidden}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}
button{cursor:pointer;font:inherit;border:none;background:none}

/* ── SKIP LINK ── */
.skip{position:absolute;top:-100px;left:1rem;background:var(--gold);color:var(--navy);font-weight:600;padding:.5rem 1rem;border-radius:var(--r);z-index:9999;transition:top .2s}
.skip:focus{top:1rem}

/* ── HEADER ── */
.hdr{position:fixed;top:0;left:0;right:0;z-index:200;background:rgba(13,27,42,.97);backdrop-filter:blur(14px);border-bottom:1px solid rgba(201,151,58,.12);transition:box-shadow var(--t)}
.hdr.scrolled{box-shadow:0 4px 32px rgba(0,0,0,.4)}
.nav-inner{max-width:1180px;margin:0 auto;padding:0 1.5rem;display:flex;align-items:center;justify-content:space-between;height:70px}
.logo{display:flex;flex-direction:column;line-height:1.2}
.logo-top{font-family:var(--ff-d);font-size:1rem;font-weight:700;letter-spacing:.22em;color:var(--gold);text-transform:uppercase}
.logo-sub{font-family:var(--ff-d);font-size:.68rem;letter-spacing:.16em;color:rgba(255,255,255,.55);text-transform:uppercase}
.nav-links{display:flex;align-items:center;gap:.15rem}
.nav-item{position:relative}
.nav-links a{display:block;padding:.42rem .78rem;font-size:.78rem;font-weight:500;letter-spacing:.055em;text-transform:uppercase;color:rgba(255,255,255,.78);border-radius:4px;transition:color var(--t),background var(--t);white-space:nowrap}
.nav-links a:hover,.nav-links a:focus-visible,.nav-links a.active{color:var(--gold-lt);background:rgba(201,151,58,.1)}
.nav-item:hover>.dd,.nav-item:focus-within>.dd{opacity:1;pointer-events:auto;transform:translateX(-50%) translateY(0)}
.dd{position:absolute;top:calc(100% + 8px);left:50%;transform:translateX(-50%) translateY(-8px);background:var(--navy-md);border:1px solid var(--border);border-radius:7px;min-width:210px;padding:.35rem 0;box-shadow:var(--sh-lg);opacity:0;pointer-events:none;transition:opacity .22s ease,transform .22s ease}
.dd a{display:block;padding:.55rem 1.2rem;font-size:.8rem;font-weight:400;text-transform:none;letter-spacing:.02em;color:rgba(255,255,255,.72);border-radius:0}
.dd a:hover,.dd a.active{color:var(--gold-lt);background:rgba(201,151,58,.08)}
.arr{font-size:.62rem;opacity:.5;margin-left:.2rem}
.nav-give{font-size:.76rem!important;font-weight:600!important;background:var(--gold)!important;color:var(--navy)!important;padding:.44rem 1rem!important;border-radius:3px!important;letter-spacing:.08em!important}
.nav-give:hover{background:var(--gold-lt)!important;color:var(--navy)!important}

/* ── Dropdown hover-bridge fix ─────────────────────────────
   Adds an invisible pseudo-element that fills the gap between
   the trigger link and the dropdown panel so the mouse never
   "leaves" the nav-item when moving downward.               */
.nav-item>.dd{margin-top:0;top:calc(100% + 2px)}
.nav-item::after{
  content:'';
  position:absolute;
  left:0;right:0;
  top:100%;
  height:10px; /* covers the 8px gap + 2px safety */
  background:transparent;
}
.nav-item:hover::after,.nav-item:focus-within::after{display:block}
/* Re-declare open state to ensure specificity */
.nav-item:hover>.dd,
.nav-item:focus-within>.dd{
  opacity:1;
  pointer-events:auto;
  transform:translateX(-50%) translateY(0);
}

/* ── RCCG Crest logo ────────────────────────────────────── */
.rccg-crest{width:44px;height:auto;flex-shrink:0;max-height:56px;object-fit:contain}
.logo-wrap{display:flex;align-items:center;gap:.75rem}
.logo-text{display:flex;flex-direction:column;line-height:1.2}
.tog{display:none;flex-direction:column;gap:5px;padding:6px}
.tog span{display:block;width:26px;height:2px;background:var(--gold);border-radius:2px;transition:transform .3s ease,opacity .3s ease}
.tog[aria-expanded=true] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.tog[aria-expanded=true] span:nth-child(2){opacity:0}
.tog[aria-expanded=true] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.mob{display:none;position:fixed;top:70px;left:0;right:0;bottom:0;background:var(--navy);overflow-y:auto;padding:1.5rem 1.5rem 4rem;z-index:199;transform:translateX(101%);transition:transform .35s var(--ease)}
.mob.open{transform:translateX(0)}
.mob-lnk{display:block;padding:.88rem 0;font-family:var(--ff-d);font-size:1.15rem;color:rgba(255,255,255,.85);border-bottom:1px solid rgba(201,151,58,.1)}
.mob-lnk:hover{color:var(--gold-lt)}
.mob-sub .mob-lnk{padding:.65rem 0 .65rem 1.1rem;font-size:.95rem;color:rgba(255,255,255,.55)}
.mob-lbl{font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);padding:1.2rem 0 .4rem}
.mob-give{display:inline-block;margin-top:1.5rem;background:var(--gold);color:var(--navy);font-weight:700;font-size:.85rem;letter-spacing:.08em;text-transform:uppercase;padding:.85rem 2rem;border-radius:3px}

/* ── PAGE HERO (interior pages) ── */
.page-hero{padding:8rem 1.5rem 4rem;background:linear-gradient(170deg,var(--navy) 0%,var(--navy-md) 100%);text-align:center;position:relative;overflow:hidden}
.page-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 60% 50% at 50% 60%,rgba(201,151,58,.1) 0%,transparent 70%)}
.page-hero-cross{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:min(300px,60vw);height:min(300px,60vw);opacity:.04;pointer-events:none}
.page-hero-cross::before,.page-hero-cross::after{content:'';position:absolute;background:var(--gold);border-radius:2px}
.page-hero-cross::before{width:3px;height:100%;top:0;left:50%;transform:translateX(-50%)}
.page-hero-cross::after{height:3px;width:100%;top:30%;left:0}
.page-hero-eyebrow{display:inline-flex;align-items:center;gap:.6rem;font-size:.68rem;font-weight:600;letter-spacing:.28em;text-transform:uppercase;color:var(--gold);margin-bottom:1rem}
.page-hero-eyebrow::before,.page-hero-eyebrow::after{content:'';display:block;width:24px;height:1px;background:var(--gold);opacity:.55}
.page-hero h1{font-family:var(--ff-d);font-size:clamp(2.2rem,5vw,3.8rem);font-weight:300;color:#fff;line-height:1.1}
.page-hero h1 em{font-style:italic;color:var(--gold-lt);font-weight:600}
.page-hero p{font-family:var(--ff-d);font-size:clamp(.95rem,2vw,1.2rem);color:rgba(255,255,255,.55);font-style:italic;margin-top:.8rem;max-width:580px;margin-left:auto;margin-right:auto}
.breadcrumb{display:flex;align-items:center;justify-content:center;gap:.5rem;font-size:.75rem;color:rgba(255,255,255,.4);margin-top:1.5rem;flex-wrap:wrap}
.breadcrumb a{color:rgba(255,255,255,.55);transition:color .2s}
.breadcrumb a:hover{color:var(--gold)}
.breadcrumb-sep{opacity:.35}

/* ── SECTION SKELETON ── */
.page-body{padding:5rem 1.5rem}
.wrap{max-width:1100px;margin:0 auto}
.wrap-sm{max-width:780px;margin:0 auto}
.sec-lbl{font-size:.67rem;font-weight:600;letter-spacing:.26em;text-transform:uppercase;color:var(--gold);display:flex;align-items:center;gap:.55rem;margin-bottom:.9rem}
.sec-lbl::after{content:'';flex:0 0 50px;height:1px;background:var(--border)}
.sec-ttl{font-family:var(--ff-d);font-size:clamp(2rem,4.5vw,3rem);font-weight:600;line-height:1.14;color:var(--navy);margin-bottom:1.1rem}
.sec-ttl em{font-style:italic;color:var(--gold)}
.sec-body{font-size:1.02rem;color:#484848;line-height:1.82;max-width:660px}
.gold-bar{width:46px;height:3px;background:var(--gold);border-radius:2px;margin-bottom:1.8rem}
.dark-band{background:var(--navy)}
.dark-band .sec-ttl{color:#fff}
.dark-band .sec-body{color:rgba(255,255,255,.58)}
.dark-band .sec-lbl{color:var(--gold-lt)}
.dark-band .sec-lbl::after{background:rgba(201,151,58,.18)}

/* ── BUTTONS ── */
.btn-g{background:var(--gold);color:var(--navy);font-size:.82rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;padding:.9rem 2rem;border-radius:3px;transition:background var(--t),transform var(--t),box-shadow var(--t);display:inline-block}
.btn-g:hover{background:var(--gold-lt);transform:translateY(-2px);box-shadow:0 8px 24px rgba(201,151,58,.4)}
.btn-o{background:transparent;color:var(--navy);border:2px solid var(--gold);font-size:.82rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;padding:.88rem 2rem;border-radius:3px;transition:background var(--t),color var(--t);display:inline-block}
.btn-o:hover{background:var(--gold);color:var(--navy)}
.btn-o-light{border-color:rgba(255,255,255,.3);color:rgba(255,255,255,.8)}
.btn-o-light:hover{border-color:var(--gold);background:rgba(201,151,58,.15);color:var(--gold-lt)}

/* ── LIGHTBOX ── */
.lb{position:fixed;inset:0;background:rgba(0,0,0,.93);z-index:500;display:none;align-items:center;justify-content:center;padding:1rem}
.lb.open{display:flex}
.lb-inner{position:relative;max-width:90vw;max-height:90vh}
.lb-img{max-width:90vw;max-height:85vh;object-fit:contain;border-radius:6px;display:block}
.lb-close{position:absolute;top:-2.5rem;right:0;background:none;color:#fff;font-size:1.8rem;line-height:1;opacity:.8}
.lb-close:hover{opacity:1}
.lb-prev,.lb-next{position:fixed;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.1);color:#fff;font-size:2rem;padding:.5rem 1rem;border-radius:4px;transition:background .2s}
.lb-prev{left:1rem}.lb-next{right:1rem}
.lb-prev:hover,.lb-next:hover{background:rgba(201,151,58,.4)}
.lb-cap{position:absolute;bottom:-2rem;left:0;right:0;text-align:center;color:rgba(255,255,255,.6);font-size:.8rem}
.lb-counter{position:absolute;top:-2rem;left:0;font-size:.75rem;color:rgba(255,255,255,.45)}

/* ── GALLERY GRID ── */
.gal-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem;margin-top:2.5rem}
.gal-item{border-radius:8px;overflow:hidden;box-shadow:var(--sh);position:relative;cursor:pointer}
.gal-item img{width:100%;aspect-ratio:4/3;object-fit:cover;display:block;transition:transform .4s var(--ease)}
.gal-item:hover img{transform:scale(1.05)}
.gal-item-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(13,27,42,.6) 0%,transparent 55%);opacity:0;transition:opacity .3s;display:flex;align-items:flex-end;padding:1rem;pointer-events:none}
.gal-item:hover .gal-item-overlay{opacity:1}
.gal-item-overlay span{font-size:.78rem;color:rgba(255,255,255,.9);letter-spacing:.05em}

/* ── CARDS ── */
.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}
.card{background:var(--warm);border-radius:10px;overflow:hidden;box-shadow:var(--sh);transition:transform var(--t),box-shadow var(--t)}
.card:hover{transform:translateY(-4px);box-shadow:var(--sh-lg)}
.card img{width:100%;aspect-ratio:16/9;object-fit:cover}
.card-body{padding:1.5rem}
.card-body h3{font-family:var(--ff-d);font-size:1.2rem;font-weight:600;color:var(--navy);margin-bottom:.4rem}
.card-body p{font-size:.88rem;color:var(--muted);line-height:1.65}
.card-link{display:inline-flex;align-items:center;gap:.4rem;font-size:.8rem;font-weight:600;color:var(--gold-dk);text-transform:uppercase;letter-spacing:.08em;margin-top:1rem;transition:gap .2s}
.card-link:hover{gap:.7rem}

/* ── FOOTER ── */
.ftr{background:var(--navy);color:rgba(255,255,255,.52);padding:4rem 1.5rem 2rem;border-top:1px solid rgba(201,151,58,.12)}
.ftr-inner{max-width:1100px;margin:0 auto}
.ftr-top{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem;padding-bottom:3rem;border-bottom:1px solid rgba(255,255,255,.07);margin-bottom:2rem}
.ftr-brand p{margin-top:.9rem;font-size:.84rem;line-height:1.75;max-width:255px}
.soc{display:flex;gap:.65rem;margin-top:1.4rem}
.soc a{width:36px;height:36px;border-radius:50%;border:1px solid rgba(201,151,58,.28);display:flex;align-items:center;justify-content:center;transition:background var(--t),border-color var(--t)}
.soc a:hover{background:rgba(201,151,58,.14);border-color:var(--gold)}
.soc svg{width:15px;height:15px;stroke:var(--gold)}
.fc h4{font-size:.7rem;font-weight:600;letter-spacing:.17em;text-transform:uppercase;color:rgba(255,255,255,.78);margin-bottom:1rem}
.fc li{margin-bottom:.5rem}
.fc a{font-size:.84rem;transition:color .2s}
.fc a:hover{color:var(--gold-lt)}
.ftr-bot{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.5rem;font-size:.78rem}
.ftr-bot a{color:var(--gold);transition:color .2s}
.ftr-bot a:hover{color:var(--gold-lt)}

/* ── ANIMATIONS ── */
@keyframes fadeUp{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}
.rev{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s ease}
.rev.vis{opacity:1;transform:translateY(0)}

/* ── FOCUS ── */
*:focus-visible{outline:2px solid var(--gold);outline-offset:3px}

/* ── RESPONSIVE ── */
@media(max-width:960px){
  .nav-links{display:none}.tog{display:flex}.mob{display:block}
  .ftr-top{grid-template-columns:1fr 1fr;gap:2rem}
}
@media(max-width:600px){
  .page-body{padding:3.5rem 1.2rem}
  .ftr-top{grid-template-columns:1fr}
  .ftr-bot{flex-direction:column;text-align:center}
}
