/*
Theme Name: HALO
Theme URI: https://halo-orienteering.uk
Author: Humberside & Lincolnshire Orienteers
Description: Starter theme for HALO — the approved homepage design (Humberside & Lincolnshire Orienteers). Static content for now; dynamic events, results and news to follow.
Version: 2.7
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
*/

  :root{
    --ink:#0a2c4a;          /* deep club-jersey blue — header / hero / footer */
    --ink-2:#071f36;
    --ink-soft:#16466e;
    --cyan:#1ca3d6;         /* HALO logo cyan */
    --gold:#f4b81f;         /* accent / results */
    --magenta:#b5237e;      /* orienteering control magenta */
    --paper:#eef1f4;        /* light section bg */
    --paper-2:#e3e8ee;
    --card:#ffffff;
    --line:#d7dde4;
    --text:#16242c;
    --muted:#5d6b75;
    --muted-light:#a9c2cf;
    --maxw:1200px;
    --r:4px;
  }
  *{box-sizing:border-box}
  html{scroll-behavior:smooth}
  body{
    margin:0;
    font-family:"Hanken Grotesk",sans-serif;
    color:var(--text);
    background:var(--paper);
    -webkit-font-smoothing:antialiased;
    line-height:1.55;
  }
  a{color:inherit;text-decoration:none}
  img,svg,video,iframe{max-width:100%}
  .wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
  .eyebrow{
    font-family:"Hanken Grotesk",sans-serif;
    text-transform:uppercase;
    letter-spacing:.13em;
    font-size:.74rem;
    font-weight:500;
    display:inline-flex;align-items:center;gap:.55em;
  }
  .tri{width:0;height:0;border-left:6px solid transparent;border-right:6px solid transparent;border-bottom:11px solid currentColor;display:inline-block;flex:none}

  /* ---------- HEADER ---------- */
  header.site{background:var(--ink);border-bottom:2px solid var(--gold);position:sticky;top:0;z-index:1100}
  .topbar{display:flex;align-items:center;gap:22px;padding:14px 28px;max-width:var(--maxw);margin:0 auto}
  .brand{display:flex;align-items:center;gap:16px;min-width:0}
  .brand .logo{height:54px;width:auto;flex:none}
  .brand .logo-fallback{font-family:"Hanken Grotesk";font-weight:900;color:#fff;font-size:1.5rem;letter-spacing:.04em;font-style:italic}
  .brand .names{min-width:0}
  .brand .club{font-weight:800;font-size:1.18rem;line-height:1.05;color:var(--gold)}
  .brand .region{font-family:"Hanken Grotesk",sans-serif;font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;color:#f3d27a;margin-top:3px}
  nav.main{margin-left:auto;display:flex;align-items:center;gap:4px}
  nav.main a{font-family:"Hanken Grotesk",sans-serif;font-size:.78rem;text-transform:uppercase;letter-spacing:.06em;padding:9px 13px;border-radius:var(--r);color:var(--gold);font-weight:500}
  nav.main a:hover{background:rgba(244,184,31,.15)}
  nav.main a.login{background:var(--gold);color:var(--ink);font-weight:600;margin-left:12px}
  nav.main a.login:hover{background:#ffc83d}
  nav.main ul.menu{display:flex;align-items:center;gap:2px;list-style:none;margin:0;padding:0}
  nav.main ul.menu li{position:relative;margin:0}
  nav.main ul.menu .sub-menu{display:none;position:absolute;top:100%;left:0;min-width:214px;flex-direction:column;background:var(--ink);border:1px solid rgba(244,184,31,.25);border-top:2px solid var(--gold);border-radius:0 0 7px 7px;padding:6px;box-shadow:0 18px 34px rgba(0,0,0,.32);z-index:60}
  nav.main ul.menu li:hover>.sub-menu{display:flex}
  nav.main ul.menu .sub-menu a{display:block;white-space:nowrap}
  nav.main .menu-item-has-children>a::after{content:"▾";margin-left:.35em;font-size:.8em;opacity:.85}
  .hsearch{display:flex;align-items:center;background:rgba(255,255,255,.08);border:1px solid rgba(244,184,31,.3);border-radius:5px;overflow:hidden;margin-left:8px}
  .hsearch input{background:transparent;border:0;color:#fff;padding:8px 6px 8px 11px;font-size:.85rem;width:120px;font-family:inherit}
  .hsearch input::placeholder{color:#a9c2cf}
  .hsearch input:focus{outline:none}
  .hsearch button{background:transparent;border:0;color:var(--gold);cursor:pointer;padding:7px 11px 7px 4px;font-size:1.1rem;line-height:1}
  .burger{display:none;margin-left:auto;width:46px;height:46px;border:1px solid rgba(244,184,31,.5);background:transparent;border-radius:var(--r);cursor:pointer;flex-direction:column;justify-content:center;gap:5px;align-items:center}
  .burger span{width:22px;height:2px;background:var(--gold);display:block}

  /* ---------- HERO ---------- */
  .hero{position:relative;color:#fff;overflow:hidden;
    background:
      linear-gradient(90deg, rgba(8,34,58,.90) 0%, rgba(8,34,58,.55) 48%, rgba(8,34,58,.32) 100%),
      linear-gradient(180deg, rgba(10,44,74,.55) 0%, rgba(10,44,74,.64) 55%, rgba(7,28,50,.88) 100%),
      url('halo_hero.png');
    background-size:cover;
    background-position:center 30%;
  }
  .hero .contours{position:absolute;inset:0;width:100%;height:100%;opacity:.30;pointer-events:none}

  .hero .wrap.hero-grid{display:grid;grid-template-columns:1fr 384px;gap:52px;align-items:start}
  .hero-main{min-width:0}
  .hero-side{position:relative;z-index:3;display:flex;flex-direction:column;gap:22px}
  .side-card{background:#fff;color:var(--text);border-radius:8px;border-top:5px solid var(--gold);box-shadow:0 26px 55px rgba(0,0,0,.40);overflow:hidden}
  .side-sec{padding:20px 24px 22px}
  .side-sec + .side-sec{border-top:1px solid var(--line)}
  .side-sec .shead{display:flex;align-items:baseline;justify-content:space-between;gap:12px}
  .side-sec .eyebrow{color:var(--magenta)}
  .side-sec h3{font-weight:900;font-size:1.18rem;color:var(--ink);margin:.45em 0 .2em}
  .frow{display:block;padding:11px 22px 11px 0;border-top:1px solid var(--line);position:relative}
  .frow:first-of-type{border-top:none;padding-top:6px}
  .frow::after{content:"→";position:absolute;right:2px;top:50%;transform:translateY(-50%);color:var(--magenta);font-weight:700;transition:right .15s ease}
  .frow:hover::after{right:-2px}
  .frow:hover .ft{color:var(--ink-soft)}
  .frow .fd{display:block;font-family:"Hanken Grotesk",sans-serif;font-size:.7rem;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-soft);font-weight:500}
  .frow .ft{display:block;font-weight:800;font-size:1.04rem;color:var(--text);line-height:1.1;margin:4px 0 7px}
  .ftag{display:inline-block;font-family:"Hanken Grotesk",sans-serif;font-size:.62rem;text-transform:uppercase;letter-spacing:.07em;font-weight:600;padding:3px 8px;border-radius:3px;border:1.4px solid currentColor}
  .ftag.league{color:var(--magenta)}
  .ftag.regional{color:#0a6e8c}
  .ftag.local{color:#7a6a12}
  .side-more{font-family:"Hanken Grotesk",sans-serif;font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;color:var(--magenta);font-weight:600;display:inline-block;margin-top:12px;border-bottom:2px solid currentColor;padding-bottom:2px}
  .nrow{display:block;padding:10px 0;border-top:1px solid var(--line)}
  .nrow:first-of-type{border-top:none;padding-top:4px}
  .nrow .nt{font-weight:700;font-size:.98rem;color:var(--text);line-height:1.2}
  .nrow .nw{font-family:"Hanken Grotesk",sans-serif;font-size:.64rem;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;margin-top:3px;display:block}
  .hero .wrap{position:relative;z-index:2;padding-top:78px;padding-bottom:64px}
  .hero .eyebrow{color:var(--gold)}
  .hero h1{
    font-weight:900;
    font-size:clamp(2.6rem,6vw,4.9rem);
    line-height:.98;
    letter-spacing:-.02em;
    margin:.5em 0 .55em;
    max-width:14ch;
  }
  .hero h1 .accent{color:var(--gold)}
  .hero p.lede{font-size:clamp(1.05rem,1.6vw,1.3rem);color:#cfe2ec;max-width:54ch;font-weight:400}
  .hero-cta{margin-top:30px;display:flex;gap:14px;flex-wrap:wrap}
  .btn-ghost{display:inline-block;border:1.5px solid rgba(255,255,255,.5);color:#fff;font-weight:700;text-transform:uppercase;letter-spacing:.06em;font-size:.82rem;padding:13px 24px;border-radius:4px}
  .btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,.1)}
  .covering{position:relative;z-index:2;border-top:1px solid rgba(255,255,255,.13);margin-top:46px;padding-top:26px;padding-bottom:8px}
  .covering .label{font-family:"Hanken Grotesk",sans-serif;font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted-light)}
  .covering .places{font-weight:800;font-size:clamp(1.3rem,2.6vw,2rem);line-height:1.12;margin-top:8px;color:#fff;max-width:24ch}

  /* ---------- FEATURE ROW (next event + results) ---------- */
  .feature{background:var(--paper);padding:34px 0 8px;border-top:2px solid var(--gold)}
  .feature .grid{display:grid;grid-template-columns:1fr 1fr;gap:26px}
  .panel{border-radius:6px;padding:30px 32px;position:relative}
  .panel .topbar-accent{position:absolute;left:0;right:0;top:0;height:6px;border-radius:6px 6px 0 0}
  .panel .eyebrow{margin-bottom:18px}
  .panel .date{font-family:"Hanken Grotesk",sans-serif;font-weight:500;letter-spacing:.08em;text-transform:uppercase;font-size:.82rem}
  .panel h2{font-weight:900;font-size:clamp(1.7rem,3vw,2.5rem);line-height:1.02;letter-spacing:-.01em;margin:.18em 0 .35em}
  .panel .sub{color:var(--muted);margin-bottom:22px;font-size:1.02rem}
  .arrow-link{font-family:"Hanken Grotesk",sans-serif;text-transform:uppercase;letter-spacing:.07em;font-size:.82rem;font-weight:600;display:inline-flex;align-items:center;gap:.5em;border-bottom:2px solid currentColor;padding-bottom:3px}
  .arrow-link:hover{gap:.9em}

  .panel.event{background:var(--card);border:1px solid var(--line)}
  .panel.event .topbar-accent{background:var(--magenta)}
  .panel.event .eyebrow,.panel.event .arrow-link{color:var(--magenta)}
  .panel.event .date{color:var(--ink-soft)}
  .panel.event h2{color:var(--text)}
  .pill{display:inline-block;font-family:"Hanken Grotesk",sans-serif;text-transform:uppercase;letter-spacing:.08em;font-size:.74rem;font-weight:600;border:1.5px solid var(--magenta);color:var(--magenta);padding:8px 14px;border-radius:3px;margin-bottom:24px}

  .panel.results{background:var(--ink);color:#fff;border:1px solid var(--ink)}
  .panel.results .topbar-accent{background:var(--gold)}
  .panel.results .eyebrow{color:var(--gold)}
  .panel.results .date{color:var(--muted-light)}
  .panel.results h2{color:#fff}
  .resbar{display:flex;align-items:center;gap:0;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.13);border-radius:4px;margin-bottom:22px;overflow:hidden}
  .resbar .view{background:var(--gold);color:var(--ink);font-family:"Hanken Grotesk",sans-serif;font-weight:600;text-transform:uppercase;letter-spacing:.06em;font-size:.78rem;padding:13px 18px}
  .resbar .what{padding:13px 16px;font-size:1rem}
  .results .links{display:flex;flex-wrap:wrap;gap:14px 28px;align-items:center}
  .panel.results .arrow-link{color:var(--gold)}
  .panel.results .arrow-link.live{color:#fff}
  .panel.results .arrow-link.live::before{content:"";width:9px;height:9px;border-radius:50%;background:#36d07a;box-shadow:0 0 0 4px rgba(54,208,122,.25);margin-right:.2em}

  /* ---------- UPCOMING + NEWS ---------- */
  .twocol{padding:48px 0;border-top:2px solid var(--gold)}
  .twocol .grid{display:grid;grid-template-columns:1.5fr 1fr;gap:48px}
  .sec-head{display:flex;align-items:baseline;justify-content:space-between;gap:16px;margin-bottom:8px}
  .sec-head .eyebrow{color:var(--magenta)}
  .sec-head h3{font-weight:900;font-size:1.9rem;letter-spacing:-.01em;color:var(--ink);margin:.25em 0 0}
  .sec-head .more{font-family:"Hanken Grotesk",sans-serif;font-size:.76rem;text-transform:uppercase;letter-spacing:.06em;color:var(--magenta);font-weight:600;white-space:nowrap}
  .ev{border-top:3px solid var(--magenta);padding:20px 0 22px;display:block}
  .ev:last-child{border-bottom:3px solid var(--magenta)}
  .ev .d{font-family:"Hanken Grotesk",sans-serif;font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);font-weight:500}
  .ev h4{font-weight:800;font-size:1.5rem;line-height:1.05;margin:.18em 0 .4em;color:var(--text)}
  .ev .meta{color:var(--muted);font-size:.96rem;margin-bottom:12px}
  .tag{display:inline-block;font-family:"Hanken Grotesk",sans-serif;font-size:.68rem;text-transform:uppercase;letter-spacing:.08em;font-weight:600;padding:5px 10px;border-radius:3px;border:1.5px solid currentColor}
  .tag.league{color:var(--magenta)}
  .tag.regional{color:#0a6e8c}
  .tag.local{color:#7a6a12}

  .news{background:var(--ink);color:#fff;border-radius:6px;padding:30px 30px 34px;align-self:start}
  .news .eyebrow{color:var(--gold)}
  .news h3{font-weight:900;font-size:1.55rem;margin:.4em 0 .2em;color:#fff}
  .news ul{list-style:none;margin:14px 0 0;padding:0}
  .news li{border-top:1px solid rgba(255,255,255,.12);padding:15px 0}
  .news li:first-of-type{border-top:none}
  .news li a{font-weight:700;font-size:1.08rem;color:#fff;display:flex;justify-content:space-between;gap:10px;align-items:center}
  .news li a:hover{color:var(--gold)}
  .news li .when{font-family:"Hanken Grotesk",sans-serif;font-size:.7rem;color:var(--muted-light);text-transform:uppercase;letter-spacing:.06em;margin-top:3px;display:block}
  .news .more{display:inline-flex;margin-top:18px}

  /* ---------- TAKE PART ANYTIME ---------- */
  .anytime{background:var(--paper-2);padding:52px 0 58px;border-top:2px solid var(--gold)}
  .anytime .lead h3{font-weight:900;font-size:clamp(1.8rem,3.4vw,2.6rem);letter-spacing:-.01em;color:var(--ink);margin:.3em 0 .2em;max-width:18ch}
  .anytime .lead .eyebrow{color:var(--magenta)}
  .anytime .lead p{color:var(--muted);max-width:60ch;margin:0 0 34px}
  .cards{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
  .ca{background:#fff;border:1px solid var(--line);border-top:5px solid var(--magenta);border-radius:5px;padding:26px 26px 28px;display:flex;flex-direction:column}
  .ca .ico{width:46px;height:46px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-weight:900;color:#fff;font-size:1.2rem;margin-bottom:16px;font-family:"Hanken Grotesk"}
  .ca .eyebrow{color:var(--muted)}
  .ca h4{font-weight:900;font-size:1.45rem;line-height:1.05;margin:.35em 0 .35em;color:var(--ink)}
  .ca p{color:var(--muted);font-size:.97rem;margin:0 0 22px}
  .ca .arrow-link{margin-top:auto;color:var(--magenta)}

  /* ---------- NEWS (club + British Orienteering) ---------- */
  .clubnews{padding:54px 0 58px;border-top:2px solid var(--gold);background:var(--paper)}
  .news-grid{display:grid;grid-template-columns:1fr 1fr;gap:26px}
  .ncard{border-radius:6px;padding:28px 32px 30px}
  .ncard.light{background:#fff;border:1px solid var(--line);border-top:5px solid var(--magenta)}
  .ncard.light .eyebrow{color:var(--magenta)}
  .ncard.dark{background:var(--ink);border-top:5px solid var(--gold);color:#fff}
  .ncard.dark .eyebrow{color:var(--gold)}
  .ncard h3{font-weight:900;font-size:1.55rem;color:var(--ink);margin:.45em 0 .5em}
  .ncard.dark h3{color:#fff}
  .ncard.dark .nrow{border-top-color:rgba(255,255,255,.14)}
  .ncard.dark .nt{color:#fff}
  .ncard.dark .nrow:hover .nt{color:var(--gold)}
  .ncard.dark .nw{color:var(--muted-light)}
  .ncard .side-more{margin-top:16px}
  .ncard.dark .chead{display:flex;align-items:center;justify-content:space-between;gap:16px}
  .bo-mark{height:42px;width:auto;flex:none;padding:8px 14px;box-sizing:content-box;background:#fff;border-radius:6px}

  /* ---------- CONTACT CTA ---------- */
  .contact-cta{background:var(--ink);color:#fff;border-top:2px solid var(--gold);padding:30px 0;text-align:center}
  .contact-cta .eyebrow{color:var(--gold);justify-content:center}
  .contact-cta h3{font-weight:900;font-size:clamp(1.5rem,2.6vw,2.1rem);color:#fff;letter-spacing:-.01em;margin:.4em 0 .7em}
  .contact-cta p{color:#cfe2ec;max-width:56ch;margin:0 auto 28px;font-size:1.05rem}
  .btn-primary{display:inline-block;background:var(--gold);color:var(--ink);font-weight:700;text-transform:uppercase;letter-spacing:.06em;font-size:.82rem;padding:15px 28px;border-radius:4px}
  .btn-primary:hover{background:#ffc83d}

  /* ---------- KIT + VIDEO ---------- */
  .kitvid{padding:54px 0 58px;border-top:2px solid var(--gold);background:var(--paper)}
  .kv-grid{display:grid;grid-template-columns:1fr 1fr;gap:26px;align-items:start}
  .kv-card{background:#fff;border:1px solid var(--line);border-top:5px solid var(--magenta);border-radius:6px;padding:28px 30px 30px;display:flex;flex-direction:column}
  .kv-card .eyebrow{color:var(--magenta)}
  .kv-card h3{font-weight:900;font-size:1.55rem;color:var(--ink);margin:.4em 0 .55em}
  .kv-card p{color:var(--muted);margin:18px 0 22px}
  .kv-card .btn-primary{align-self:flex-start;margin-top:auto}
  .kit-photo{aspect-ratio:16/10;border-radius:6px;background:linear-gradient(135deg,#10446e,#0a2c4a);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;border:1px solid rgba(255,255,255,.14);padding:18px}
  .tee{width:56%;max-width:220px;height:auto;filter:drop-shadow(0 12px 22px rgba(0,0,0,.42))}
  .kit-cap{color:#a9c2cf;font-weight:600;text-transform:uppercase;letter-spacing:.1em;font-size:.72rem}
  .video-embed{position:relative;width:100%;aspect-ratio:16/9;border-radius:6px;overflow:hidden;background:#08223a}
  .video-embed iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
  .vthumb{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;border:0}
  .video-ph{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;cursor:pointer;background:linear-gradient(rgba(8,34,58,.26),rgba(8,34,58,.46))}
  .play{width:78px;height:78px;border-radius:50%;background:#e3261b;display:flex;align-items:center;justify-content:center;box-shadow:0 10px 28px rgba(0,0,0,.45);transition:background .2s,transform .2s}
  .play::after{content:"";border-left:25px solid #fff;border-top:15px solid transparent;border-bottom:15px solid transparent;margin-left:6px}
  .video-ph:hover .play{background:#ff3a2d;transform:scale(1.06)}

  /* ---------- FOOTER ---------- */
  footer.site{background:var(--ink);color:#cfe2ec;border-top:2px solid var(--gold)}
  footer .wrap{padding:54px 28px 30px}
  .fgrid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:36px}
  footer h5{font-family:"Hanken Grotesk",sans-serif;font-size:.72rem;text-transform:uppercase;letter-spacing:.12em;color:var(--gold);margin:0 0 16px;font-weight:600}
  footer ul{list-style:none;margin:0;padding:0}
  footer li{margin:0 0 11px}
  footer li a{color:#cfe2ec;font-size:.96rem}
  footer li a:hover{color:#fff}
  .ext::after{content:"↗";font-size:.8em;margin-left:.35em;color:var(--gold)}
  .fbrand .club{font-weight:900;color:#fff;font-size:1.3rem;line-height:1.1}
  .fbrand p{font-size:.92rem;color:var(--muted-light);max-width:34ch;margin:14px 0 0}
  .bo-affil{display:inline-flex;flex-direction:column;gap:7px;margin-top:22px}
  .bo-affil-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.12em;color:var(--gold);font-weight:600}
  .bo-affil img{height:46px;width:auto;display:block;padding:9px 16px;box-sizing:content-box;background:#fff;border-radius:6px}
  .fbottom{border-top:1px solid rgba(255,255,255,.12);margin-top:42px;padding-top:22px;display:flex;flex-wrap:wrap;gap:8px 24px;justify-content:space-between;font-family:"Hanken Grotesk",sans-serif;font-size:.72rem;letter-spacing:.05em;color:var(--muted-light);text-transform:uppercase}
  .fbottom a:hover{color:#fff}

  /* ---------- INNER PAGES (title strip, prose, events, single event) ---------- */
  .page-hero{background:var(--ink);color:#fff;border-bottom:2px solid var(--gold);padding:52px 0 46px}
  .page-hero .eyebrow{color:var(--gold)}
  .page-hero h1{font-weight:900;font-size:clamp(2rem,4vw,3.1rem);letter-spacing:-.01em;color:#fff;margin:.35em 0 0;max-width:22ch}
  .page-hero p.sub{color:#cfe2ec;font-size:1.1rem;margin:.6em 0 0;max-width:62ch}
  .section{padding:48px 0 60px}
  .prose{max-width:760px}
  .prose>*:first-child{margin-top:0}
  .prose h2{font-weight:900;color:var(--ink);font-size:1.7rem;margin:1.5em 0 .4em}
  .prose h3{font-weight:800;color:var(--ink);font-size:1.3rem;margin:1.3em 0 .3em}
  .prose p{margin:0 0 1.1em;font-size:1.06rem;color:var(--text)}
  .prose a{color:var(--magenta);text-decoration:underline}
  .prose a.btn-primary{color:var(--ink);text-decoration:none}
  .prose a.btn-primary:hover{color:var(--ink)}
  .prose ul,.prose ol{margin:0 0 1.1em 1.25em}
  .prose li{margin:.3em 0}
  .prose img{max-width:100%;height:auto;border-radius:6px}
  .prose figure{margin:0 0 1.4em}
  .prose .wp-block-table,.prose figure.wp-block-table{overflow-x:auto}
  .prose table{width:100%;border-collapse:collapse;margin:0 0 1.4em;font-size:.98rem}
  .prose th{background:var(--ink);color:#fff;text-align:left;font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;padding:11px 12px;border-bottom:2px solid var(--gold);white-space:nowrap}
  .prose td{padding:11px 12px;border-bottom:1px solid var(--line)}
  .prose tbody tr:nth-child(even){background:#f6f8fa}
  .prose td:first-child{font-weight:700;color:var(--ink)}
  .results-table{overflow-x:auto;-webkit-overflow-scrolling:touch}
  .neighbours{overflow-x:auto;-webkit-overflow-scrolling:touch}
  .evlist .ev:first-child{border-top:3px solid var(--magenta)}
  .event-single{display:grid;grid-template-columns:1fr 300px;gap:40px;align-items:start}
  .event-facts{background:#fff;border:1px solid var(--line);border-top:5px solid var(--magenta);border-radius:6px;padding:22px 24px 26px}
  .event-facts h4{font-weight:900;color:var(--ink);font-size:1.1rem;margin:0 0 14px}
  .event-facts p{margin:0 0 13px;font-size:1rem;color:var(--text);line-height:1.35}
  .event-facts strong{display:block;font-size:.68rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-weight:600;margin-bottom:2px}
  .event-facts .btn-primary{margin-top:8px}
  .results-cta{background:#fff;border:1px solid var(--line);border-top:4px solid var(--gold);border-radius:8px;padding:26px 30px 28px;margin-bottom:24px}
  .results-cta h2{margin:0 0 6px;font-size:1.5rem;color:var(--ink);font-weight:900}
  .results-cta p{color:var(--muted);margin:0 0 20px}
  .results-cta .btn-primary{margin:0 10px 0 0}
  .btn-secondary{display:inline-block;border:1.5px solid var(--ink);color:var(--ink);font-weight:700;text-transform:uppercase;letter-spacing:.06em;font-size:.82rem;padding:13px 24px;border-radius:4px}
  .btn-secondary:hover{background:var(--ink);color:#fff}
  .event-detail{margin:0 0 1.6em;display:grid;grid-template-columns:175px 1fr}
  .event-detail dt{font-weight:700;color:var(--ink);padding:13px 16px 13px 0;border-top:1px solid var(--line)}
  .event-detail dd{margin:0;padding:13px 0;border-top:1px solid var(--line);color:var(--text)}
  .event-detail dt:first-of-type,.event-detail dd:first-of-type{border-top:none}
  .event-map-wrap{border:1px solid var(--line);border-radius:8px;overflow:hidden;margin:0 0 .8em;isolation:isolate;position:relative;z-index:0}
  #halo-event-map{height:360px;width:100%}

  /* ---------- EVENTS PAGE (map + calendar + fixtures) ---------- */
  .events-grid{display:grid;grid-template-columns:1.7fr 1fr;gap:28px;align-items:start}
  .map-wrap{border:1px solid var(--line);border-radius:8px;overflow:hidden;background:#dfe6ec;isolation:isolate;position:relative;z-index:0}
  #halo-map{height:430px;width:100%}
  .leaflet-container{font-family:"Hanken Grotesk",sans-serif}
  .map-empty{height:430px;display:flex;align-items:center;justify-content:center;color:var(--muted);text-align:center;padding:20px}
  .glance{border:1px solid var(--line);border-radius:8px;background:#fff;padding:18px 20px 22px}
  .glance-head{display:flex;align-items:baseline;justify-content:space-between;gap:10px}
  .glance-head .eyebrow{color:var(--gold)}
  .glance-sub{font-size:.66rem;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);font-weight:600}
  .cal{margin-top:16px}
  .cal-title{font-weight:800;color:var(--ink);font-size:1.05rem;margin-bottom:8px}
  .cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px;text-align:center}
  .cal-dow{font-size:.6rem;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;padding:4px 0;font-weight:600}
  .cal-day{font-size:.82rem;color:var(--text);padding:7px 0;border-radius:5px;background:#eef1f4}
  .cal-day.has-event{background:var(--ink);color:#fff;font-weight:700}
  .cal-day.is-today{outline:2px solid var(--gold);outline-offset:-2px;font-weight:800}

  .list-head{display:flex;align-items:baseline;justify-content:space-between;gap:16px;border-bottom:2px solid var(--ink);padding-bottom:12px;margin-bottom:2px}
  .list-head .eyebrow{color:var(--magenta)}
  .list-count{font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-weight:600}

  .fixlist .fixrow,.reslist .resrow{display:grid;grid-template-columns:78px 1fr auto;gap:22px;align-items:center;padding:20px 0;border-bottom:1px solid var(--line)}
  .reslist .resrow{grid-template-columns:78px 1fr auto auto}
  .fixrow{color:inherit}
  .fdate{line-height:1}
  .fdate .dnum{display:block;font-weight:900;font-size:2.1rem;color:var(--ink-soft)}
  .fdate .dmon{display:block;font-size:.66rem;letter-spacing:.08em;color:var(--muted);font-weight:600;margin-top:3px}
  .fdate .ddow{display:block;font-size:.64rem;letter-spacing:.08em;color:var(--muted);margin-top:1px}
  .finfo .ftitle{display:block;font-weight:800;font-size:1.35rem;color:var(--text);line-height:1.05}
  .fixrow:hover .ftitle{color:var(--ink-soft)}
  .finfo .fmeta{display:block;color:var(--muted);font-size:.95rem;margin-top:3px}
  .flevel{font-size:.78rem;text-transform:uppercase;letter-spacing:.06em;font-weight:600;white-space:nowrap}
  .flevel.local{color:#7a6a12}
  .flevel.regional,.flevel.league{color:var(--magenta)}
  .resbtn{background:var(--ink);color:#fff;font-weight:700;text-transform:uppercase;letter-spacing:.06em;font-size:.72rem;padding:11px 16px;border-radius:4px;white-space:nowrap}
  .resbtn:hover{background:var(--ink-soft)}

  .year{border-top:3px solid var(--magenta)}
  .year summary{list-style:none;cursor:pointer;display:flex;align-items:baseline;gap:14px;padding:16px 0}
  .year summary::-webkit-details-marker{display:none}
  .year .yr{font-weight:900;font-size:1.6rem;color:var(--ink-soft)}
  .year .yc{font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-weight:600}
  .year[open] summary .yr{color:var(--magenta)}

  .neighbours .ntable{width:100%;border-collapse:collapse;font-size:.96rem}
  .ntable thead th{background:var(--ink);color:#fff;text-align:left;font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;padding:12px 14px;font-weight:600;border-bottom:2px solid var(--gold)}
  .ntable tbody td{padding:13px 14px;border-bottom:1px solid var(--line)}
  .ntable tbody tr:nth-child(even){background:#f6f8fa}
  .ntable .club{display:inline-block;background:var(--ink);color:#fff;font-size:.64rem;font-weight:700;letter-spacing:.06em;padding:3px 8px;border-radius:3px}

  /* ---------- FORMS (Contact Form 7) ---------- */
  .prose .wpcf7{max-width:620px;margin-top:6px}
  .wpcf7-form p{margin:0 0 16px}
  .wpcf7-form label{display:block;font-weight:700;color:var(--ink);font-size:.95rem;margin-bottom:6px}
  .wpcf7-form input[type=text],.wpcf7-form input[type=email],.wpcf7-form input[type=tel],.wpcf7-form input[type=number],.wpcf7-form select,.wpcf7-form textarea{width:100%;padding:12px 14px;border:1px solid var(--line);border-radius:5px;font-family:inherit;font-size:1rem;background:#fff;color:var(--text);margin-top:2px}
  .wpcf7-form textarea{min-height:140px;resize:vertical}
  .wpcf7-form input:focus,.wpcf7-form textarea:focus,.wpcf7-form select:focus{outline:none;border-color:var(--ink-soft);box-shadow:0 0 0 3px rgba(28,163,214,.18)}
  .wpcf7-form .wpcf7-submit{display:inline-block;background:var(--gold);color:var(--ink);font-weight:700;text-transform:uppercase;letter-spacing:.06em;font-size:.82rem;padding:14px 28px;border:0;border-radius:4px;cursor:pointer;width:auto;margin-top:4px}
  .wpcf7-form .wpcf7-submit:hover{background:#ffc83d}
  .wpcf7 .wpcf7-response-output{border-radius:5px;margin:14px 0 0;padding:10px 14px;font-size:.95rem}
  .wpcf7-not-valid-tip{color:#c0392b;font-size:.85rem;font-weight:600}

  /* ---------- DOCUMENTS ---------- */
  .doc-cat{margin:0 0 28px;max-width:760px}
  .doc-cat h3{font-weight:900;color:var(--ink);font-size:1.3rem;margin:0 0 6px;border-bottom:2px solid var(--magenta);padding-bottom:8px}
  .doclist{list-style:none;margin:0;padding:0}
  .doc{border-bottom:1px solid var(--line)}
  .doc a{display:flex;justify-content:space-between;align-items:center;gap:14px;padding:14px 2px;color:var(--text)}
  .doc a:hover .doc-t{color:var(--ink-soft)}
  .doc-t{font-weight:700}
  .doc-badge{font-style:normal;font-size:.6rem;text-transform:uppercase;letter-spacing:.06em;color:var(--magenta);border:1px solid var(--magenta);border-radius:3px;padding:2px 6px;margin-left:8px;vertical-align:middle}
  .doc-dl{font-size:.76rem;text-transform:uppercase;letter-spacing:.06em;color:var(--magenta);font-weight:600;white-space:nowrap}
  .doc.locked{display:flex;justify-content:space-between;align-items:center;gap:14px;padding:14px 2px;color:var(--muted)}
  .doc.locked .doc-t{font-weight:700}
  .doc-lock{font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);font-weight:600;white-space:nowrap}

  /* ---------- MEMBERS GATE ---------- */
  .gate{padding:6px 0}
  .gate-inner{background:#fff;border:1px solid var(--line);border-top:5px solid var(--magenta);border-radius:8px;padding:32px 36px;max-width:560px}
  .gate-inner .eyebrow{color:var(--magenta);margin-bottom:12px}
  .gate-inner p{color:var(--text);font-size:1.05rem;margin:0 0 22px}

  /* reveal — content visible by default; only animates when JS is active */
  .rv{opacity:1;transform:none}
  .js .rv{opacity:0;transform:translateY(16px);transition:opacity .6s ease,transform .6s ease}
  .js .rv.in{opacity:1;transform:none}

  /* ---------- RESPONSIVE ---------- */
  @media(max-width:1080px){
    .cards{grid-template-columns:repeat(2,1fr)}
  }
  @media(max-width:880px){
    nav.main{display:none}
    .burger{display:flex}
    .hero .wrap.hero-grid,.feature .grid,.twocol .grid,.cards,.fgrid,.news-grid,.kv-grid,.event-single,.events-grid{grid-template-columns:1fr}
    .hero .wrap.hero-grid{gap:30px}
    .hero-side{width:100%}
    .fixlist .fixrow,.reslist .resrow{grid-template-columns:62px 1fr;gap:16px}
    .fixlist .fixrow .flevel,.reslist .resrow .flevel{grid-column:2}
    .reslist .resrow .resbtn{grid-column:2;justify-self:start}
    .fdate .dnum{font-size:1.7rem}
    .finfo .ftitle{font-size:1.15rem}
    .event-detail{grid-template-columns:1fr}
    .event-detail dd{border-top:none;padding-top:0;padding-bottom:13px}
    .cards{gap:16px}
    .brand .region{display:none}
    nav.main.open{display:flex;position:absolute;top:100%;left:0;right:0;background:var(--ink);flex-direction:column;align-items:stretch;gap:0;padding:8px;border-bottom:2px solid var(--gold);box-shadow:0 18px 30px rgba(0,0,0,.25)}
    nav.main.open a{padding:14px}
    nav.main.open ul.menu{flex-direction:column;width:100%;align-items:stretch;gap:0}
    nav.main.open ul.menu li{width:100%}
    nav.main.open ul.menu .sub-menu{display:flex;position:static;box-shadow:none;border:none;border-top:none;padding:0 0 6px 18px;background:transparent;min-width:0}
    nav.main.open .menu-item-has-children>a::after{content:""}
    nav.main.open .hsearch{width:100%;margin:8px 0 0;order:3}
    nav.main.open .hsearch input{width:100%;flex:1}
    nav.main.open ul.menu{order:2}
    /* Login sits at the very top of the opened menu as a clear full-width button */
    nav.main.open a.login{order:1;margin:2px 0 8px;text-align:center;padding:15px;font-size:.92rem;border-radius:5px}
  }

  /* ---------- PHONES ---------- */
  @media(max-width:560px){
    .wrap{padding:0 16px}
    .topbar{padding:11px 16px;gap:12px}
    .brand{gap:11px}
    .brand .logo{height:42px}
    .brand .club{font-size:1rem}

    .hero .wrap{padding-top:42px;padding-bottom:40px}
    .hero h1{margin:.4em 0 .5em}
    .hero-cta{flex-direction:column;align-items:stretch;gap:10px}
    .hero-cta .btn-primary,.hero-cta .btn-ghost{text-align:center;width:100%}
    .covering{margin-top:30px;padding-top:20px}

    .feature{padding:24px 0 4px}
    .panel{padding:24px 20px}
    .twocol{padding:34px 0}
    .twocol .grid{gap:30px}
    .anytime{padding:36px 0 40px}
    .clubnews,.kitvid{padding:36px 0 40px}
    .ncard,.news,.kv-card{padding:24px 20px}
    .contact-cta{padding:30px 0}
    .section{padding:34px 0}

    .sec-head{flex-wrap:wrap;gap:4px 16px}
    .sec-head h3{font-size:1.55rem}
    .ev h4{font-size:1.3rem}
    .cards{grid-template-columns:1fr}

    .resbar{flex-wrap:wrap}
    .resbar .view{width:100%}

    /* event + results lists: stack date above title, full-width buttons */
    .fixlist .fixrow,.reslist .resrow{grid-template-columns:1fr;gap:6px;padding:16px 0}
    .fixlist .fixrow .flevel,.reslist .resrow .flevel,
    .reslist .resrow .resbtn{grid-column:auto}
    .fdate{display:flex;align-items:baseline;gap:8px}
    .fdate .dnum{font-size:1.5rem}
    .fdate .dmon,.fdate .ddow{margin-top:0}
    .finfo .ftitle{font-size:1.18rem}
    .reslist .resrow .resbtn{justify-self:stretch;text-align:center;margin-top:6px}
    .year .yr{font-size:1.35rem}

    #halo-event-map{height:260px}
    #halo-map,.map-empty{height:300px}
    .cal-day{padding:5px 0;font-size:.76rem}

    .event-facts,.gate-inner,.results-cta{padding:22px 18px}
    .results-cta .btn-primary{display:block;margin:0 0 10px}
    .prose table,.ntable{font-size:.9rem}
    .prose th,.prose td,.ntable thead th,.ntable tbody td{padding:9px 10px}
  }

  /* keep sticky header below the WP admin bar when logged in */
  body.admin-bar header.site{top:32px}
  @media(max-width:782px){ body.admin-bar header.site{top:46px} }
