/* ============================================================
   East Lismore Bowling Club — Honour Boards kiosk
   Brand skin: navy + coral/orange + cream, Sora + Outfit
   (consistent with The Easty public website assets/site.css)
   Built to run portrait (interactive touch kiosk) or landscape
   (TV channel). Layout scales to the screen via vmin-based root.
   ============================================================ */
:root{
  --ink:#191d28; --ink-soft:#4a4f5c;
  --cream:#f5f2ea; --cream-2:#ece6d9; --paper:#fffdf8;
  --navy:#20366b; --navy-2:#172a55; --navy-3:#0e1d3f;
  --red:#e23b2e; --red-deep:#c42c20; --orange:#ee7a3c; --gold:#f0a35e; --gold-soft:#f7c98e;
  --line:rgba(25,29,40,.12); --line-light:rgba(255,255,255,.14);
  --shadow:0 18px 50px -22px rgba(20,28,50,.45);
  --shadow-sm:0 8px 26px -14px rgba(20,28,50,.4);
  --ease:cubic-bezier(.22,.61,.36,1);
  /* one knob that scales the whole UI to the screen size */
  font-size:clamp(13px, 1.7vmin, 27px);
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:"Outfit",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  color:var(--ink);
  background:var(--cream);
  -webkit-font-smoothing:antialiased;
  line-height:1.5;
  overflow:hidden;                 /* kiosk: no page scroll; panels scroll internally */
  -webkit-tap-highlight-color:transparent;
  user-select:none;
}
h1,h2,h3,h4{font-family:"Sora",system-ui,sans-serif;font-weight:700;line-height:1.05;letter-spacing:-.02em;margin:0}
img{max-width:100%;display:block}
button{font:inherit;color:inherit;cursor:pointer}

/* hide the cursor after inactivity (kiosk feel) — toggled by JS */
body.hide-cursor, body.hide-cursor *{cursor:none !important}

/* ============================================================ app shell */
#app{position:fixed;inset:0;display:flex;flex-direction:column;overflow:hidden}

/* top brand bar */
.topbar{
  flex:none;display:flex;align-items:center;gap:1rem;
  height:clamp(56px,8vmin,120px);
  padding:0 clamp(14px,2.2vmin,40px);
  background:linear-gradient(180deg,var(--navy) 0%,var(--navy-2) 100%);
  color:#fff;box-shadow:0 10px 30px -18px rgba(0,0,0,.6);
  z-index:20;position:relative;
}
.topbar .logo{height:clamp(34px,5vmin,74px);width:auto}
.topbar .tb-title{display:flex;flex-direction:column;line-height:1.1;min-width:0}
.topbar .tb-title b{font-family:"Sora",sans-serif;font-weight:700;font-size:1.18rem;letter-spacing:-.01em}
.topbar .tb-title span{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-soft);font-weight:600}
.topbar .spacer{flex:1}
.topbar .clock{font-family:"Sora",sans-serif;font-weight:600;font-size:1rem;color:rgba(255,255,255,.82);letter-spacing:.02em}

.btn-back{
  display:none;align-items:center;gap:.5em;
  background:rgba(255,255,255,.1);border:1px solid var(--line-light);
  color:#fff;border-radius:100px;padding:.55em 1.1em .55em .85em;
  font-weight:600;font-size:.92rem;transition:background .2s,transform .2s var(--ease);
}
.btn-back svg{width:1.1em;height:1.1em}
.btn-back:active{transform:scale(.96)}
.btn-back:hover{background:rgba(255,255,255,.18)}
body:not([data-view="home"]) .btn-back{display:inline-flex}
body[data-mode="tv"] .btn-back{display:none}

/* main stage */
.stage{flex:1;position:relative;overflow:hidden}
.view{position:absolute;inset:0;display:flex;flex-direction:column;opacity:0;visibility:hidden;
  transition:opacity .5s var(--ease);pointer-events:none}
.view.active{opacity:1;visibility:visible;pointer-events:auto}

/* ============================================================ HOME view */
/* a real club aerial sits behind the menu, held back by a cream veil so the
   navy heading + tiles stay legible — more present than the old watermark. */
#view-home{
  align-items:center;justify-content:center;overflow:auto;isolation:isolate;
  background-color:var(--cream);
  background-image:
    linear-gradient(180deg, rgba(245,242,234,.50) 0%, rgba(245,242,234,.60) 32%, rgba(245,242,234,.60) 70%, rgba(245,242,234,.74) 100%),
    url("../img/screensaver/aerial-greens-wide.webp");
  background-size:cover;
  background-position:center 34%;
  background-repeat:no-repeat;
}
.home-inner{position:relative;z-index:1;width:100%;max-width:1500px;margin:auto;padding:clamp(20px,4vmin,70px);text-align:center}
.home-badge{height:clamp(80px,16vmin,230px);width:auto;margin:0 auto clamp(14px,2.5vmin,40px);
  filter:drop-shadow(0 16px 30px rgba(20,28,50,.25))}
.home-eyebrow{
  display:inline-flex;align-items:center;gap:.6em;margin:0 0 1rem;
  font-weight:600;font-size:.78rem;letter-spacing:.2em;text-transform:uppercase;color:var(--red);
  background:rgba(238,122,60,.13);padding:.55em 1.1em;border-radius:100px;
}
.home-eyebrow::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--orange)}
.home-inner h1{font-size:clamp(2rem,6vmin,5rem);color:var(--navy)}
.home-inner h1 em{font-style:normal;color:var(--red)}
.home-sub{font-size:clamp(.95rem,2vmin,1.5rem);color:var(--ink-soft);margin:.8rem auto 0;max-width:46ch}

.cat-grid{display:grid;gap:clamp(12px,2vmin,28px);margin-top:clamp(24px,4vmin,60px)}
.cat-tile{
  position:relative;overflow:hidden;text-align:left;container-type:inline-size;
  background:linear-gradient(150deg,var(--navy) 0%,var(--navy-3) 100%);
  color:#fff;border:0;border-radius:clamp(14px,2vmin,26px);
  padding:clamp(18px,2.8vmin,40px);min-height:clamp(120px,18vmin,260px);
  display:flex;flex-direction:column;justify-content:flex-end;
  box-shadow:var(--shadow);transition:transform .3s var(--ease),box-shadow .3s;
}
.cat-tile::before{content:"";position:absolute;inset:0;
  background:radial-gradient(120% 90% at 85% 10%,rgba(238,122,60,.32),transparent 55%);opacity:.9}
.cat-tile::after{content:"";position:absolute;left:0;top:0;bottom:0;width:6px;background:linear-gradient(180deg,var(--orange),var(--red))}
.cat-tile:active{transform:scale(.985)}
.cat-tile:hover{transform:translateY(-4px);box-shadow:0 26px 60px -26px rgba(20,28,50,.6)}
.cat-tile .ct-kicker{position:relative;font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-soft);font-weight:700;margin-bottom:.4em}
/* sized off the tile WIDTH (cqi), not screen height — so the long single word
   "Championships" can never outgrow its tile and clip on a tall landscape screen */
.cat-tile .ct-name{position:relative;font-family:"Sora",sans-serif;font-weight:700;font-size:clamp(1.15rem,9cqi,2.5rem);letter-spacing:-.02em;overflow-wrap:break-word}
.cat-tile .ct-count{position:relative;margin-top:.5em;font-size:.92rem;color:rgba(255,255,255,.78)}
.cat-tile .ct-arrow{position:absolute;top:clamp(16px,2.6vmin,36px);right:clamp(16px,2.6vmin,36px);
  width:clamp(30px,4.4vmin,58px);height:clamp(30px,4.4vmin,58px);border-radius:50%;
  background:rgba(255,255,255,.12);display:grid;place-items:center;border:1px solid var(--line-light)}
.cat-tile .ct-arrow svg{width:50%;height:50%;stroke:#fff;fill:none;stroke-width:2.4}

/* secondary action row on the home screen — Find a name / Club legends / Our story / Photo gallery */
.home-actions{display:flex;flex-wrap:wrap;justify-content:center;gap:clamp(8px,1.4vmin,18px);margin-top:clamp(20px,3.4vmin,46px)}
.action-btn{
  display:inline-flex;align-items:center;gap:.55em;white-space:nowrap;
  background:var(--paper);border:1px solid var(--line);color:var(--navy);
  font-family:"Outfit",sans-serif;font-weight:600;font-size:clamp(.88rem,1.7vmin,1.3rem);
  padding:.75em 1.4em;border-radius:100px;box-shadow:var(--shadow-sm);
  transition:transform .2s var(--ease),box-shadow .2s,border-color .2s,color .2s;
}
.action-btn svg{width:1.25em;height:1.25em;stroke:var(--red);fill:none;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round}
.action-btn:hover{border-color:var(--red);color:var(--red);transform:translateY(-2px);box-shadow:var(--shadow)}
.action-btn:active{transform:scale(.97)}
.action-btn[hidden]{display:none}
/* these are normal browsable pages (any orientation); only the TV channel hides them */
body[data-mode="tv"] .home-actions{display:none}

/* ============================================================ BOARD view */
#view-board{padding:0}
.board-head{
  flex:none;display:flex;align-items:flex-end;gap:1rem;flex-wrap:wrap;
  padding:clamp(12px,2.2vmin,34px) clamp(14px,2.6vmin,46px) 0;
}
.board-head .bh-cat{font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;color:var(--red);font-weight:700}
.board-head h2{font-size:clamp(1.5rem,4.4vmin,4rem);color:var(--navy);margin-top:.1em}
.board-head .bh-years{margin-left:auto;font-family:"Sora",sans-serif;font-weight:600;
  color:var(--ink-soft);font-size:clamp(.9rem,2vmin,1.5rem);
  background:var(--paper);border:1px solid var(--line);border-radius:100px;padding:.35em 1em}

/* board chips (sibling boards in this category) */
.chips{flex:none;display:flex;gap:.55rem;flex-wrap:wrap;align-items:center;
  padding:clamp(10px,1.6vmin,22px) clamp(14px,2.6vmin,46px)}
.chip{
  background:var(--paper);border:1px solid var(--line);border-radius:100px;
  padding:.5em 1.15em;font-weight:600;font-size:clamp(.82rem,1.7vmin,1.25rem);color:var(--ink-soft);
  transition:background .2s,color .2s,border-color .2s,transform .15s var(--ease);white-space:nowrap;
}
.chip:active{transform:scale(.95)}
.chip.active{background:var(--navy);color:#fff;border-color:var(--navy)}
.chip:not(.active):hover{border-color:var(--red);color:var(--red)}

/* the scrolling board panel */
.board-scroll{flex:1;overflow:hidden;position:relative;
  padding:clamp(8px,1.4vmin,20px) clamp(14px,2.6vmin,46px) clamp(16px,2.6vmin,46px)}
.board-scroll-inner{height:100%;overflow:auto;scrollbar-width:none;border-radius:clamp(12px,1.8vmin,22px)}
.board-scroll-inner::-webkit-scrollbar{display:none}

.board-chunks{display:grid;gap:clamp(10px,1.8vmin,26px);align-items:start}

.btable{width:100%;border-collapse:collapse;background:var(--paper);
  border:1px solid var(--line);border-radius:clamp(12px,1.8vmin,22px);overflow:hidden;box-shadow:var(--shadow-sm)}
.btable thead th{
  position:sticky;top:0;z-index:2;
  background:linear-gradient(180deg,var(--navy) 0%,var(--navy-2) 100%);color:#fff;
  font-family:"Sora",sans-serif;font-weight:600;text-align:left;white-space:nowrap;
  font-size:clamp(.72rem,1.5vmin,1.15rem);letter-spacing:.06em;text-transform:uppercase;
  padding:clamp(.5em,1.1vmin,1em) clamp(.7em,1.4vmin,1.2em);
}
.btable thead th.col-year{width:1%;white-space:nowrap}
.btable tbody td{
  padding:clamp(.42em,.95vmin,.9em) clamp(.7em,1.4vmin,1.2em);
  font-size:clamp(.84rem,1.75vmin,1.4rem);
  border-top:1px solid var(--line);vertical-align:baseline;
}
.btable tbody tr:nth-child(odd) td{background:rgba(32,54,107,.035)}
.btable tbody tr:hover td{background:rgba(238,122,60,.08)}
.btable td.col-year{font-family:"Sora",sans-serif;font-weight:700;color:var(--navy);white-space:nowrap}
.btable td.col-name{font-weight:500}
.btable td.col-name.muted{color:var(--ink-soft)}
.btable td.col-team{font-weight:500}
.btable .empty{color:rgba(25,29,40,.25)}
/* coral accent under a winner-type first name column */
.btable td.col-win{font-weight:600}

/* gentle fade at the top/bottom of a scrolling board */
.board-scroll::before,.board-scroll::after{content:"";position:absolute;left:0;right:0;height:clamp(14px,2.4vmin,34px);pointer-events:none;z-index:3}
.board-scroll::before{top:clamp(8px,1.4vmin,20px);background:linear-gradient(180deg,var(--cream),transparent)}
.board-scroll::after{bottom:clamp(16px,2.6vmin,46px);background:linear-gradient(0deg,var(--cream),transparent)}

/* ============================================================ orientation */
/* PORTRAIT: tiles stack 2-wide, board is a single tall column */
@media (orientation:portrait){
  .cat-grid{grid-template-columns:repeat(2,1fr)}
}
/* LANDSCAPE: tiles in a row of 4, board may split into side-by-side chunks */
@media (orientation:landscape){
  .cat-grid{grid-template-columns:repeat(4,1fr)}
  .home-inner h1{font-size:clamp(2rem,5vmin,4.4rem)}
}
/* very wide split handled in JS by adding chunk columns */
.board-chunks[data-cols="2"]{grid-template-columns:1fr 1fr}
.board-chunks[data-cols="3"]{grid-template-columns:repeat(3,1fr)}

/* ============================================================ SCREENSAVER
   Portrait-only idle slideshow (historical archive photos).
   Cross-fades two layers; caption overlaid. */
.saver{position:fixed;inset:0;z-index:200;background:var(--navy-3);
  opacity:0;visibility:hidden;transition:opacity .9s var(--ease)}
.saver.on{opacity:1;visibility:visible}
.saver-slide{position:absolute;inset:0;background-size:cover;background-position:center;
  opacity:0;transition:opacity 1.6s var(--ease);transform:scale(1.06)}
.saver-slide.show{opacity:1;animation:kenburns 14s linear forwards}
@keyframes kenburns{from{transform:scale(1.04)}to{transform:scale(1.14)}}
.saver-scrim{position:absolute;inset:0;background:
  linear-gradient(180deg,rgba(10,18,40,.35) 0%,rgba(10,18,40,.05) 35%,rgba(10,18,40,.78) 100%)}
.saver-cap{position:absolute;left:0;right:0;bottom:0;padding:clamp(28px,6vmin,90px);text-align:center;color:#fff}
.saver-cap .logo{height:clamp(54px,9vmin,140px);margin:0 auto clamp(12px,2vmin,28px)}
.saver-cap .ttl{font-family:"Sora",sans-serif;font-weight:700;font-size:clamp(1.6rem,5vmin,4rem);letter-spacing:-.02em}
.saver-cap .sub{font-size:clamp(1rem,2.4vmin,1.8rem);color:var(--gold-soft);margin-top:.4em;font-weight:600}
.saver-tap{margin-top:clamp(16px,3vmin,40px);font-size:.9rem;letter-spacing:.22em;text-transform:uppercase;
  color:rgba(255,255,255,.7);animation:tappulse 2.4s ease-in-out infinite}
@keyframes tappulse{0%,100%{opacity:.45}50%{opacity:1}}
/* show the screensaver only in portrait; landscape (TV) never attracts to it */
@media (orientation:landscape){.saver{display:none}}

/* a small "live / auto" hint shown in TV mode */
.tv-tag{position:fixed;right:clamp(12px,2vmin,30px);bottom:clamp(12px,2vmin,30px);z-index:30;
  display:none;align-items:center;gap:.5em;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;
  font-weight:700;color:#fff;background:rgba(14,29,63,.6);border:1px solid var(--line-light);
  padding:.5em .9em;border-radius:100px;backdrop-filter:blur(6px)}
body[data-mode="tv"] .tv-tag{display:inline-flex}
.tv-tag .dot{width:8px;height:8px;border-radius:50%;background:#46d17f;box-shadow:0 0 0 0 rgba(70,209,127,.7);animation:pulse 2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(70,209,127,.6)}70%{box-shadow:0 0 0 .7em rgba(70,209,127,0)}100%{box-shadow:0 0 0 0 rgba(70,209,127,0)}}
body[data-mode="tv"] .btn-back,body[data-mode="tv"] .topbar .clock{}

/* ============================================================ PHOTO GALLERY */
.gallery-scroll{flex:1;overflow:auto;scrollbar-width:none;position:relative;
  padding:clamp(8px,1.4vmin,20px) clamp(14px,2.6vmin,46px) clamp(16px,2.6vmin,46px)}
.gallery-scroll::-webkit-scrollbar{display:none}
.gallery-grid{display:grid;align-items:start;gap:clamp(10px,1.8vmin,24px);grid-template-columns:1fr}
@media (orientation:landscape){.gallery-grid{grid-template-columns:repeat(2,1fr)}}
@media (orientation:landscape) and (min-width:1500px){.gallery-grid{grid-template-columns:repeat(3,1fr)}}
.gallery-grid figure{margin:0;position:relative;overflow:hidden;cursor:pointer;background:var(--navy);
  border-radius:clamp(12px,1.8vmin,20px);box-shadow:var(--shadow-sm);aspect-ratio:3/2}
.gallery-grid img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s var(--ease)}
.gallery-grid figure:hover img{transform:scale(1.045)}
.gallery-grid figcaption{position:absolute;left:0;right:0;bottom:0;color:#fff;font-weight:500;
  font-size:clamp(.82rem,1.6vmin,1.25rem);line-height:1.3;
  padding:clamp(20px,3.4vmin,40px) clamp(12px,1.8vmin,22px) clamp(10px,1.5vmin,18px);
  background:linear-gradient(0deg,rgba(10,18,40,.85),rgba(10,18,40,0))}

/* ---------- lightbox ---------- */
.lightbox{position:fixed;inset:0;z-index:300;display:none;align-items:center;justify-content:center;
  background:rgba(8,14,30,.94);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);
  padding:clamp(16px,3vmin,60px)}
.lightbox.on{display:flex}
.lb-figure{margin:0;display:flex;flex-direction:column;align-items:center;gap:clamp(10px,1.8vmin,22px);max-width:94vw}
.lb-img{max-width:92vw;max-height:80vh;width:auto;height:auto;object-fit:contain;
  border-radius:clamp(8px,1.2vmin,16px);box-shadow:0 30px 80px -30px rgba(0,0,0,.85)}
.lb-cap{color:#fff;font-size:clamp(.95rem,2vmin,1.5rem);font-weight:500;text-align:center;max-width:64ch;line-height:1.4}
.lb-btn{position:absolute;background:rgba(255,255,255,.12);border:1px solid var(--line-light);color:#fff;
  width:clamp(46px,7vmin,84px);height:clamp(46px,7vmin,84px);border-radius:50%;display:grid;place-items:center;
  font-size:clamp(1.5rem,3.4vmin,2.8rem);line-height:0;transition:background .2s,transform .2s var(--ease)}
.lb-btn:hover{background:rgba(255,255,255,.22)}
.lb-close{top:clamp(14px,3vmin,40px);right:clamp(14px,3vmin,40px)}
.lb-prev{left:clamp(10px,2.5vmin,40px);top:50%;transform:translateY(-50%)}
.lb-next{right:clamp(10px,2.5vmin,40px);top:50%;transform:translateY(-50%)}
.lb-prev:active{transform:translateY(-50%) scale(.92)}
.lb-next:active{transform:translateY(-50%) scale(.92)}
.lb-close:active{transform:scale(.92)}

/* ============================================================ FIND A NAME */
.search-bar{flex:none;display:flex;align-items:center;gap:.6em;margin:clamp(6px,1.2vmin,16px) clamp(14px,2.6vmin,46px) 0;
  background:var(--paper);border:1px solid var(--line);border-radius:100px;padding:clamp(.5em,1.1vmin,.9em) clamp(.9em,1.6vmin,1.4em);box-shadow:var(--shadow-sm)}
.search-bar svg{width:clamp(20px,2.4vmin,34px);height:clamp(20px,2.4vmin,34px);stroke:var(--red);fill:none;stroke-width:2;stroke-linecap:round;flex:none}
.search-bar input{flex:1;min-width:0;border:0;background:none;outline:none;color:var(--ink);font-family:"Sora",sans-serif;font-weight:600;
  font-size:clamp(1.05rem,2.4vmin,1.9rem);letter-spacing:-.01em}
.search-bar input::placeholder{color:var(--ink-soft);font-weight:500;opacity:.7}
.search-clear{flex:none;width:clamp(28px,3.2vmin,46px);height:clamp(28px,3.2vmin,46px);border-radius:50%;border:0;
  background:var(--cream-2);color:var(--ink-soft);font-size:clamp(1.1rem,2vmin,1.6rem);line-height:0;display:grid;place-items:center}
.search-clear:active{transform:scale(.92)}
.search-results{flex:1;overflow:auto;scrollbar-width:none;padding:clamp(8px,1.4vmin,18px) clamp(14px,2.6vmin,46px)}
.search-results::-webkit-scrollbar{display:none}
.search-hint{color:var(--ink-soft);font-size:clamp(.95rem,1.9vmin,1.4rem);text-align:center;margin:clamp(20px,4vmin,60px) auto;max-width:42ch}
.person{background:var(--paper);border:1px solid var(--line);border-radius:clamp(12px,1.6vmin,18px);margin-bottom:clamp(8px,1.4vmin,16px);overflow:hidden;box-shadow:var(--shadow-sm)}
.person-head{display:flex;align-items:baseline;justify-content:space-between;gap:1em;padding:clamp(.6em,1.2vmin,1em) clamp(.9em,1.6vmin,1.3em);background:rgba(32,54,107,.05);border-bottom:1px solid var(--line)}
.person-head b{font-family:"Sora",sans-serif;font-weight:700;color:var(--navy);font-size:clamp(1.05rem,2.1vmin,1.7rem)}
.person-head span{color:var(--ink-soft);font-weight:600;font-size:clamp(.78rem,1.5vmin,1.1rem);white-space:nowrap}
.person-rows{padding:clamp(.2em,.5vmin,.5em) 0}
.person-row{display:grid;grid-template-columns:clamp(48px,7vmin,92px) 1fr auto;gap:1em;align-items:baseline;
  padding:clamp(.3em,.7vmin,.6em) clamp(.9em,1.6vmin,1.3em);font-size:clamp(.86rem,1.7vmin,1.3rem);border-top:1px solid rgba(25,29,40,.06)}
.person-row:first-child{border-top:0}
.person-row .pr-year{font-family:"Sora",sans-serif;font-weight:700;color:var(--navy)}
.person-row .pr-role{color:var(--ink-soft);font-weight:600;white-space:nowrap}
.person-row.t .pr-role{color:var(--red)}

/* on-screen keyboard (touch kiosk) */
.keyboard{flex:none;background:var(--cream-2);border-top:1px solid var(--line);padding:clamp(8px,1.4vmin,18px) clamp(8px,1.4vmin,20px);
  display:flex;flex-direction:column;gap:clamp(6px,1vmin,12px)}
.kb-row{display:flex;justify-content:center;gap:clamp(4px,.8vmin,10px)}
.kb-key{flex:1;max-width:clamp(44px,6vmin,92px);min-height:clamp(40px,5.4vmin,76px);border:1px solid var(--line);background:var(--paper);
  border-radius:clamp(8px,1.2vmin,14px);font-family:"Sora",sans-serif;font-weight:600;color:var(--navy);
  font-size:clamp(.95rem,2vmin,1.5rem);box-shadow:0 2px 0 rgba(25,29,40,.08)}
.kb-key:active{transform:translateY(1px);box-shadow:none;background:var(--cream)}
.kb-key.kb-space{max-width:none;flex:3;text-transform:uppercase;letter-spacing:.1em;font-size:clamp(.7rem,1.4vmin,1rem);color:var(--ink-soft)}
.kb-key.kb-act{max-width:clamp(70px,10vmin,140px);background:var(--cream);color:var(--ink-soft);text-transform:uppercase;letter-spacing:.06em;font-size:clamp(.72rem,1.4vmin,1.05rem)}
@media (orientation:landscape){.kb-key{min-height:clamp(36px,4.6vmin,64px)}}

/* ============================================================ CLUB LEGENDS */
.legends-scroll{flex:1;overflow:auto;scrollbar-width:none;padding:clamp(8px,1.4vmin,20px) clamp(14px,2.6vmin,46px) clamp(16px,2.6vmin,46px)}
.legends-scroll::-webkit-scrollbar{display:none}
.legends-list{list-style:none;margin:0;padding:0;display:grid;gap:clamp(6px,1vmin,12px)}
@media (orientation:landscape){.legends-list{grid-template-columns:1fr 1fr;column-gap:clamp(14px,2.4vmin,36px)}}
.legend{display:flex;align-items:center;gap:clamp(10px,1.8vmin,22px);background:var(--paper);border:1px solid var(--line);
  border-radius:clamp(10px,1.5vmin,16px);padding:clamp(.5em,1vmin,.9em) clamp(.8em,1.5vmin,1.3em);box-shadow:var(--shadow-sm);cursor:pointer;
  transition:transform .15s var(--ease),border-color .2s}
.legend:hover{border-color:var(--red)}.legend:active{transform:scale(.99)}
.lg-rank{flex:none;width:clamp(28px,3.4vmin,50px);height:clamp(28px,3.4vmin,50px);border-radius:50%;display:grid;place-items:center;
  background:var(--navy);color:#fff;font-family:"Sora",sans-serif;font-weight:700;font-size:clamp(.82rem,1.6vmin,1.2rem)}
.legend:nth-child(1) .lg-rank{background:linear-gradient(150deg,var(--gold),var(--orange))}
.legend:nth-child(2) .lg-rank{background:linear-gradient(150deg,#c9ccd6,#9aa0ad)}
.legend:nth-child(3) .lg-rank{background:linear-gradient(150deg,#d9a36a,#b97e44)}
.lg-name{flex:1;font-family:"Sora",sans-serif;font-weight:600;color:var(--ink);font-size:clamp(1rem,2vmin,1.55rem)}
.lg-count{flex:none;display:flex;flex-direction:column;align-items:flex-end;line-height:1;font-family:"Sora",sans-serif;font-weight:700;color:var(--navy);font-size:clamp(1.1rem,2.2vmin,1.8rem)}
.lg-count small{font-family:"Outfit",sans-serif;font-weight:600;font-size:.5em;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);margin-top:.3em}
.legends-note{color:var(--ink-soft);font-size:clamp(.8rem,1.5vmin,1.1rem);line-height:1.5;max-width:72ch;margin:clamp(16px,2.4vmin,30px) auto 0;text-align:center}

/* ============================================================ OUR STORY */
.story-scroll{flex:1;overflow:auto;scrollbar-width:none;padding:clamp(10px,1.6vmin,24px) clamp(14px,2.6vmin,46px) clamp(20px,3vmin,56px)}
.story-scroll::-webkit-scrollbar{display:none}
.story-inner{max-width:80ch;margin:0 auto;color:var(--ink)}
.story-inner p{font-size:clamp(1rem,2vmin,1.5rem);line-height:1.65;margin:0 0 1em}
.story-inner .story-lead{font-size:clamp(1.1rem,2.3vmin,1.7rem);color:var(--ink-soft);font-weight:500}
.story-inner h3{font-family:"Sora",sans-serif;color:var(--navy);font-size:clamp(1.2rem,2.6vmin,2rem);margin:1.3em 0 .4em}
.story-inner figure{margin:clamp(14px,2.4vmin,30px) 0;border-radius:clamp(12px,1.8vmin,20px);overflow:hidden;box-shadow:var(--shadow-sm)}
.story-inner figure img{width:100%;display:block;aspect-ratio:16/9;object-fit:cover}
.story-inner figcaption{font-size:clamp(.78rem,1.5vmin,1.05rem);color:var(--ink-soft);padding:.6em .2em 0}
.story-note{font-size:clamp(.78rem,1.4vmin,1rem);color:var(--ink-soft);border-top:1px solid var(--line);margin-top:1.6em;padding-top:1em}
