/* =========================================================================
   ACF Golf Classic — "Garden & Gold" Design System
   Merging:
     · Garden Oaks Roots (warm community, sage/terracotta, Caveat handwriting)
     · Championship Noir (premium dark, champagne gold, Bodoni Moda)
   Used by: home, register, sponsor, admin, roster, thanks
   ========================================================================= */

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,500;0,600;0,700;0,800;0,900;1,500;1,700;1,800&family=Caveat:wght@500;700&family=Inter:wght@400;500;600;700;800&family=JetBrains+Mono:wght@400;500;700&display=swap');

:root{
  /* DARK MODE PALETTE (championship anchor) */
  --bg-dark:#0c100c;
  --bg-dark-2:#161e16;
  --emerald:#14532d;
  --emerald-2:#1a6b3a;
  --gold:#b89436;
  --gold-light:#d4b87a;
  --gold-deep:#937715;
  --ivory:#f3ead7;
  --ash:#a0a8a0;

  /* WARM PALETTE (community heart) */
  --cream:#f5e9d3;
  --cream-2:#fbf3df;
  --paper:#fffaf0;
  --sage:#8aa982;
  --sage-2:#6c8a64;
  --terra:#c47148;
  --terra-2:#a85a36;
  --ink:#1f2622;
  --ink-soft:#4a5249;
  --line:#dfd6c3;
  --line-dark:#2a3127;

  /* SEMANTIC */
  --rose:#c4495a;
  --shadow-sm:0 2px 8px rgba(31,38,34,.08);
  --shadow-md:0 12px 32px rgba(31,38,34,.12);
  --shadow-lg:0 24px 64px rgba(31,38,34,.18);
}

/* RESET */
*{box-sizing:border-box;margin:0;padding:0}
html,body{
  background:var(--paper);
  color:var(--ink);
  font-family:"Inter",system-ui,-apple-system,sans-serif;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

/* TYPOGRAPHY */
h1,h2,h3,h4,h5{font-family:"Playfair Display",Georgia,serif;font-weight:500;line-height:1.05;letter-spacing:-.005em}
h1{font-size:clamp(48px,8vw,128px);font-weight:600}
h2{font-size:clamp(32px,5vw,72px);font-weight:500}
h3{font-size:clamp(22px,2.6vw,32px);font-weight:500}
h4{font-size:20px;font-weight:600}
h5{font-size:16px;font-weight:700}
.ital{font-style:italic;font-weight:500}
.script{font-family:"Caveat",cursive;font-weight:700;color:var(--terra);font-style:normal}
.mono{font-family:"JetBrains Mono",monospace;font-weight:500}
.lab{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--gold-deep);font-weight:600}
.lab.gold{color:var(--gold)}
.lab.terra{color:var(--terra)}
.lab.ash{color:var(--ash)}
a{color:inherit}
img,svg{display:block;max-width:100%}

/* LAYOUT */
.wrap{max-width:1320px;margin:0 auto;padding:0 32px}
.wrap-narrow{max-width:880px;margin:0 auto;padding:0 32px}
.gold-rule{height:1px;background:linear-gradient(90deg,transparent,var(--gold) 30%,var(--gold) 70%,transparent);margin:24px 0;width:100%}
.gold-rule-short{height:1px;background:var(--gold);width:80px;margin:14px 0}

/* BUTTONS */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:14px 26px;
  font-family:"Inter",sans-serif;font-size:13px;font-weight:700;
  letter-spacing:.16em;text-transform:uppercase;
  text-decoration:none;cursor:pointer;
  border:1.5px solid var(--ink);
  background:var(--ink);color:var(--paper);
  border-radius:0;
  transition:all .25s;
}
.btn:hover{background:var(--gold);border-color:var(--gold);color:var(--ink)}
.btn.gold{background:var(--gold);border-color:var(--gold);color:var(--ink)}
.btn.gold:hover{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.btn.outline{background:transparent;color:var(--ink)}
.btn.outline:hover{background:var(--ink);color:var(--paper)}
.btn.dark{background:transparent;border-color:var(--ivory);color:var(--ivory)}
.btn.dark:hover{background:var(--gold);border-color:var(--gold);color:var(--ink)}
.btn.terra{background:var(--terra);border-color:var(--terra);color:var(--paper)}
.btn.terra:hover{background:var(--terra-2);border-color:var(--terra-2)}
.btn.lg{padding:18px 32px;font-size:14px}
.btn.sm{padding:8px 14px;font-size:11px;letter-spacing:.14em}

/* BADGES */
.badge{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:.18em;text-transform:uppercase;font-weight:700;border:1px solid currentColor}
.badge.gold{color:var(--gold-deep);background:rgba(184,148,54,.08)}
.badge.emerald{color:var(--emerald);background:rgba(20,83,45,.08)}
.badge.terra{color:var(--terra-2);background:rgba(196,113,72,.1)}
.badge.dark{color:var(--ivory);background:rgba(243,234,215,.1);border-color:rgba(243,234,215,.3)}
.badge.paid{color:var(--emerald);background:rgba(20,83,45,.12);border-color:transparent}
.badge.due{color:var(--rose);background:rgba(196,73,90,.12);border-color:transparent}
.badge.atevent{color:var(--gold-deep);background:rgba(184,148,54,.16);border-color:transparent}
.badge.reserved{color:var(--ash);background:rgba(160,168,160,.16);border-color:transparent}

/* TOP NOTICE BAR */
.topbar{background:var(--bg-dark);color:var(--ivory);font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase}
.topbar .row{display:flex;justify-content:space-between;align-items:center;padding:12px 0;gap:24px;flex-wrap:wrap}
.topbar a{color:var(--gold-light);text-decoration:none}

/* NAV */
nav.main{position:sticky;top:0;z-index:30;background:rgba(255,250,240,.94);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
nav.main .row{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:32px;padding:18px 0}
nav.main .logo{display:flex;align-items:center;gap:12px;text-decoration:none;color:var(--ink)}
nav.main .logo .crest-svg{width:48px;height:48px;flex:none}
nav.main .logo .nm{font-family:"Playfair Display",serif;font-weight:600;font-size:20px;line-height:1}
nav.main .logo .sb{font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--gold-deep);font-weight:700;margin-top:4px}
nav.main .links{display:flex;gap:28px;justify-content:center;font-size:13px;font-weight:600;letter-spacing:.16em;text-transform:uppercase}
nav.main .links a{text-decoration:none;color:var(--ink);opacity:.78;transition:.2s}
nav.main .links a:hover{opacity:1;color:var(--gold-deep)}
nav.main .links a.active{opacity:1;color:var(--gold-deep);border-bottom:2px solid var(--gold);padding-bottom:2px}
nav.main .right{display:flex;justify-content:flex-end;gap:14px;align-items:center}

/* SECTIONS */
section{padding:96px 0;position:relative}
section.dark{background:var(--bg-dark);color:var(--ivory)}
section.dark .lab{color:var(--gold-light)}
section.dark h2{color:var(--ivory)}
section.dark .ital{color:var(--gold-light)}
section.warm{background:var(--cream)}
section.cream{background:var(--cream-2)}
section.sage{background:var(--sage);color:var(--paper)}
section.sage h2{color:var(--paper)}
section.sage .lab{color:var(--gold)}
section.emerald{background:var(--emerald);color:var(--paper)}
section.emerald h2{color:var(--paper)}
section.emerald .lab{color:var(--gold-light)}

.section-head{display:grid;grid-template-columns:auto 1fr;gap:48px;margin-bottom:56px;align-items:flex-end}
.section-head .num{font-family:"Playfair Display",serif;font-style:italic;font-weight:500;font-size:120px;line-height:.85;color:var(--gold);letter-spacing:-.02em}
section.dark .section-head .num{color:var(--gold-light)}
.section-head h2 .ital{color:var(--gold-deep)}
.section-head .lead{font-size:17px;line-height:1.65;opacity:.78;max-width:480px;margin-top:18px}
section.dark .section-head .lead{opacity:.85}
@media(max-width:780px){.section-head{grid-template-columns:1fr;gap:14px}.section-head .num{font-size:72px}}

/* HERO (DARK CHAMPIONSHIP) */
.hero{position:relative;background:var(--bg-dark);color:var(--ivory);overflow:hidden;padding:80px 0 120px;border-bottom:1px solid var(--line-dark)}
.hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;opacity:.55;pointer-events:none}
@media (prefers-reduced-motion: reduce){.hero-video{display:none}}
.hero::before{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;background:linear-gradient(135deg,rgba(12,16,12,.78),rgba(12,16,12,.42) 50%,rgba(12,16,12,.78)),radial-gradient(ellipse at 70% 40%,rgba(212,184,122,.22),transparent 55%),radial-gradient(ellipse at 20% 80%,rgba(20,83,45,.5),transparent 55%)}
.hero .wrap{position:relative;z-index:2}
.hero-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:64px;align-items:end}
.hero h1{margin-top:18px}
.hero h1 .ital{color:var(--gold-light)}
.hero h1 .small{display:block;font-size:.32em;font-style:italic;font-weight:400;color:var(--ash);letter-spacing:.05em;margin-top:18px;font-family:"Caveat",cursive}
.hero .lede{font-size:20px;color:var(--ivory);opacity:.82;max-width:540px;margin-top:32px;line-height:1.6}
.hero .ctas{display:flex;gap:14px;margin-top:36px;flex-wrap:wrap;align-items:center}
.hero .ctas .cta-pair{display:inline-flex;gap:14px;align-items:stretch;flex-wrap:wrap}
.hero .scribble{font-family:"Caveat",cursive;font-size:24px;color:var(--gold-light);transform:rotate(-2deg);display:inline-block}
.hero-art{position:absolute;right:-80px;top:80px;width:560px;opacity:.15;pointer-events:none}
.hero-meta{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:rgba(243,234,215,.15);border:1px solid rgba(243,234,215,.15)}
.hero-meta .m{background:var(--bg-dark);padding:24px;display:flex;flex-direction:column;gap:6px}
.hero-meta .m .lab{color:var(--gold-light)}
.hero-meta .m .v{font-family:"Playfair Display",serif;font-weight:600;font-size:32px;line-height:1;color:var(--ivory)}
.hero-meta .m .v small{font-size:14px;color:var(--ash);font-weight:400}
@media(max-width:980px){.hero-grid{grid-template-columns:1fr;gap:32px}.hero-art{display:none}}

/* CREST */
.crest-svg circle:nth-child(1){fill:var(--gold)}

/* COUNTDOWN */
.countdown{display:flex;gap:24px;margin-top:40px}
.cd{display:flex;flex-direction:column;align-items:flex-start}
.cd .num{font-family:"Playfair Display",serif;font-weight:600;font-size:54px;line-height:1;color:var(--gold-light);letter-spacing:-.02em}
.cd .lab{font-size:10px;letter-spacing:.28em;text-transform:uppercase;color:var(--ash);margin-top:6px}

/* SCHEDULE */
.sched-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.sched-cell{background:var(--paper);padding:32px 22px;display:flex;flex-direction:column;gap:10px;position:relative}
.sched-cell:hover{background:var(--cream-2)}
.sched-cell .time{font-family:"Playfair Display",serif;font-weight:600;font-size:54px;line-height:.85;color:var(--emerald);letter-spacing:-.02em}
.sched-cell .time small{font-size:26px;color:var(--ink-soft);font-weight:500}
.sched-cell .ttl{font-family:"Inter",sans-serif;font-size:12px;letter-spacing:.16em;text-transform:uppercase;font-weight:700;margin-top:14px;color:var(--ink)}
.sched-cell .desc{font-size:13.5px;color:var(--ink-soft);margin-top:10px;line-height:1.6}
.sched-cell .desc ul{color:var(--ink-soft)}
.sched-cell .desc li{margin-bottom:4px}
@media(max-width:1100px){.sched-grid{grid-template-columns:repeat(3,1fr)}.sched-cell:nth-child(4),.sched-cell:nth-child(5){grid-column:span 1}}
@media(max-width:900px){.sched-grid{grid-template-columns:1fr 1fr}.sched-cell:nth-child(4),.sched-cell:nth-child(5){grid-column:span 1}}

/* RAISED TRACKER */
.raise-card{background:var(--paper);border:1px solid var(--line);padding:48px;display:grid;grid-template-columns:1fr 1.5fr;gap:48px;align-items:center;position:relative;overflow:hidden}
.raise-card.dark{background:var(--bg-dark-2);border-color:var(--line-dark);color:var(--ivory)}
.raise-num{font-family:"Playfair Display",serif;font-size:120px;line-height:.85;font-weight:600;color:var(--emerald);letter-spacing:-.04em}
.raise-card.dark .raise-num{color:var(--gold-light)}
.raise-num small{font-size:36px;color:var(--terra);font-weight:500}
.raise-card.dark .raise-num small{color:var(--gold)}
.progress-line{height:18px;background:rgba(31,38,34,.08);overflow:hidden;position:relative;margin-top:18px}
.raise-card.dark .progress-line{background:rgba(243,234,215,.1);border:1px solid rgba(243,234,215,.15)}
.progress-line .fill{height:100%;background:linear-gradient(90deg,var(--gold),var(--terra));width:0;transition:width 1.5s ease}
.raise-card.dark .progress-line .fill{background:linear-gradient(90deg,var(--gold),var(--gold-light))}
.raise-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:32px;padding-top:24px;border-top:1px dashed var(--line)}
.raise-card.dark .raise-stats{border-top-color:var(--line-dark)}
.raise-stats .s{display:flex;flex-direction:column;gap:4px}
.raise-stats .s .v{font-family:"Playfair Display",serif;font-weight:600;font-size:36px;color:var(--ink)}
.raise-card.dark .raise-stats .s .v{color:var(--ivory)}
.raise-stats .s .v small{font-size:14px;color:var(--ink-soft);font-weight:400}
.raise-card.dark .raise-stats .s .v small{color:var(--ash)}
@media(max-width:900px){.raise-card{grid-template-columns:1fr;padding:32px;gap:24px}}

/* TICKETS */
.tickets-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:24px}
.ticket-feature{background:var(--paper);border:1px solid var(--line);padding:48px;position:relative;display:flex;flex-direction:column;gap:18px;overflow:hidden}
.ticket-feature.dark{background:var(--bg-dark-2);border-color:var(--gold);color:var(--ivory)}
.ticket-feature::before{content:"";position:absolute;top:0;left:0;width:100%;height:4px;background:var(--gold)}
.ticket-feature .ribbon{position:absolute;top:0;right:24px;background:var(--gold);color:var(--ink);padding:8px 16px;font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.22em;text-transform:uppercase;font-weight:700}
.ticket-feature .price{font-family:"Playfair Display",serif;font-size:120px;line-height:.85;font-weight:600;color:var(--emerald);letter-spacing:-.04em;margin-top:14px}
.ticket-feature.dark .price{color:var(--gold-light)}
.ticket-feature .price small{font-size:24px;color:var(--ink-soft);font-style:italic;font-weight:500}
.ticket-feature .price-sub{font-family:"Inter",sans-serif;font-size:14px;letter-spacing:.22em;text-transform:uppercase;color:var(--gold-deep);font-weight:700;margin-top:-6px;margin-bottom:8px}
.ticket-feature.dark .price-sub{color:var(--gold-light)}
.ticket-feature.dark .price small{color:var(--ash)}
.ticket-feature ul{list-style:none;padding:0;display:flex;flex-direction:column;gap:10px;font-size:15px}
.ticket-feature ul li{display:flex;gap:10px;align-items:flex-start}
.ticket-feature ul li::before{content:"✦";color:var(--gold);font-weight:700;flex:none}
.tk-side{display:flex;flex-direction:column;gap:16px}
.tk-mini{background:var(--paper);border:1px solid var(--line);padding:28px;display:flex;flex-direction:column;gap:8px;transition:.2s;flex:1}
.tk-mini:hover{border-color:var(--gold);transform:translateY(-2px);box-shadow:var(--shadow-md)}
.tk-mini h4{font-family:"Playfair Display",serif;font-size:24px;font-weight:600}
.tk-mini .pp{font-family:"Playfair Display",serif;font-size:42px;font-weight:600;color:var(--emerald);line-height:1}
.tk-mini p{font-size:13px;color:var(--ink-soft);line-height:1.5}
@media(max-width:900px){.tickets-grid{grid-template-columns:1fr}}

/* SPONSORSHIPS */
.spon-tier-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.spon-tier{background:var(--paper);border:1px solid var(--line);padding:40px 32px;position:relative;display:flex;flex-direction:column;gap:14px;transition:.25s;overflow:hidden}
.spon-tier:hover{transform:translateY(-4px);border-color:var(--gold);box-shadow:var(--shadow-md)}
.spon-tier::before{content:"";position:absolute;top:0;left:0;width:100%;height:3px;background:var(--gold)}
.spon-tier.featured{background:var(--bg-dark);color:var(--ivory);border-color:var(--gold)}
.spon-tier.featured::before{background:var(--gold-light)}
.spon-tier h3{font-family:"Playfair Display",serif;font-weight:600;font-size:42px}
.spon-tier .price-num{font-family:"Playfair Display",serif;font-size:80px;font-weight:600;color:var(--emerald);line-height:1;letter-spacing:-.02em}
.spon-tier.featured .price-num{color:var(--gold-light)}
.spon-tier ul{list-style:none;padding:0;display:flex;flex-direction:column;gap:8px;flex:1;font-size:14px}
.spon-tier ul li::before{content:"◇";color:var(--gold);margin-right:8px}
.spon-tier .avail{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--gold-deep);font-weight:700;border-top:1px dashed var(--line);padding-top:14px}
.spon-tier.featured .avail{color:var(--gold-light);border-top-color:var(--line-dark)}

.spon-table{width:100%;border-collapse:collapse;margin-top:32px;background:var(--paper);border:1px solid var(--line)}
.spon-table th{text-align:left;padding:18px;font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--gold-deep);font-weight:700;background:var(--cream);border-bottom:1px solid var(--line)}
.spon-table td{padding:20px 18px;border-bottom:1px solid var(--line);vertical-align:middle}
.spon-table tr:last-child td{border-bottom:none}
.spon-table tr:hover td{background:var(--cream-2)}
.spon-table .nm{font-family:"Playfair Display",serif;font-weight:600;font-size:22px;color:var(--ink)}
.spon-table .ds{color:var(--ink-soft);font-size:13px}
.spon-table .pr{font-family:"Playfair Display",serif;font-weight:600;font-size:28px;color:var(--emerald);text-align:right}
.spon-table .ct{text-align:right}
@media(max-width:900px){.spon-tier-grid{grid-template-columns:1fr}.spon-table .ds{display:none}}

/* FORM (TEAM REGISTRATION) */
.form-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:48px;align-items:start}
.player{background:var(--paper);border:1px solid var(--line);padding:32px;margin-bottom:18px;position:relative;transition:.2s}
.player:hover{border-color:var(--sage)}
.player.captain{background:linear-gradient(135deg,var(--bg-dark),var(--emerald));color:var(--ivory);border-color:var(--gold)}
.player.captain label{color:var(--gold-light)}
.player.captain input{background:rgba(243,234,215,.06);color:var(--ivory);border-color:rgba(243,234,215,.25)}
.player.captain input:focus{border-color:var(--gold-light);background:rgba(243,234,215,.1)}
.player .top{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}
.player h4{font-family:"Playfair Display",serif;font-weight:600;font-size:26px}
.player .pill{font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:.22em;text-transform:uppercase;font-weight:700;padding:6px 12px;border:1px solid currentColor}
.player .pill.req{color:var(--gold);border-color:var(--gold);background:rgba(184,148,54,.1)}
.player .pill.opt{color:var(--ink-soft);border-color:var(--line)}

.field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}
.field label{font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-soft);font-weight:700}
.field input,.field select,.field textarea{padding:14px 16px;border:1px solid var(--line);background:var(--paper);font-family:inherit;font-size:15px;color:var(--ink);transition:.15s}
.field input:focus,.field select:focus{outline:none;border-color:var(--gold);background:#fff}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.reserve-toggle{display:flex;align-items:center;gap:10px;font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft);font-weight:600;padding:12px;border:1px dashed var(--line);background:var(--cream-2)}
.reserve-toggle input{width:18px;height:18px;accent-color:var(--gold)}

/* SUMMARY CARD */
.summary-card{position:sticky;top:96px;background:var(--bg-dark);color:var(--ivory);padding:40px;border:1px solid var(--gold)}
.summary-card .lab{color:var(--gold-light)}
.summary-card h3{font-family:"Playfair Display",serif;font-size:32px;font-weight:600;color:var(--ivory);margin:8px 0 18px;border-bottom:1px solid rgba(243,234,215,.15);padding-bottom:14px}
.sum-line{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px dashed rgba(243,234,215,.15);font-size:14px}
.sum-line:last-of-type{border-bottom:none}
.sum-tot{display:flex;justify-content:space-between;align-items:baseline;font-family:"Playfair Display",serif;font-size:48px;font-weight:600;color:var(--gold-light);padding-top:18px;margin-top:8px;border-top:1px solid rgba(243,234,215,.2)}
.pay-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:14px}
.pay-tile{padding:14px;border:1px solid rgba(243,234,215,.3);background:transparent;text-align:center;font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase;font-weight:700;cursor:pointer;color:var(--ivory);transition:.2s}
.pay-tile.active,.pay-tile:hover{background:var(--gold);color:var(--ink);border-color:var(--gold)}
.summary-card .helper{font-family:"JetBrains Mono",monospace;font-size:11px;line-height:1.7;letter-spacing:.04em;margin-top:14px;opacity:.7}
@media(max-width:900px){.form-grid{grid-template-columns:1fr}.summary-card{position:static}}

/* POLAROID (Garden Oaks moment) */
.polaroid{background:var(--paper);padding:18px 18px 56px;box-shadow:var(--shadow-md);transform:rotate(-2deg);position:relative;display:inline-block}
.polaroid .pic{aspect-ratio:1;background:linear-gradient(135deg,var(--emerald),var(--sage));position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center}
.polaroid .cap{font-family:"Caveat",cursive;font-size:24px;color:var(--ink);text-align:center;margin-top:14px}
.polaroid.tilt-r{transform:rotate(2deg)}

/* DONOR WALL */
.wall-grid{column-count:4;column-gap:32px}
@media(max-width:1100px){.wall-grid{column-count:3}}
@media(max-width:780px){.wall-grid{column-count:2}}
.wall-row{break-inside:avoid;padding:14px 0;border-bottom:1px solid var(--line)}
.wall-row .nm{font-family:"Playfair Display",serif;font-weight:500;font-size:20px;color:var(--ink);line-height:1.15}
.wall-row .yr{font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-deep);margin-top:4px;display:block;font-weight:700}

/* MISSION (warm story) */
.mission-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:64px;align-items:center}
.mission-img{position:relative;aspect-ratio:4/5;background:linear-gradient(135deg,var(--terra),var(--gold));overflow:hidden}
.mission-img .stamp{position:absolute;top:24px;left:24px;font-family:"Caveat",cursive;font-size:36px;color:var(--paper);transform:rotate(-6deg)}
.pillars-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:24px}
.pillar{background:var(--paper);border-left:3px solid var(--gold);padding:24px;transition:.2s}
.pillar:hover{border-left-color:var(--terra);background:var(--cream-2)}
.pillar h4{font-family:"Playfair Display",serif;font-weight:600;font-size:22px;color:var(--emerald);margin-bottom:8px}
.pillar p{font-size:14px;color:var(--ink-soft);line-height:1.6}
@media(max-width:900px){.mission-grid{grid-template-columns:1fr}}

/* FAQ */
.faq-list{max-width:880px;margin:0 auto}
.faq-list details{border-bottom:1px solid var(--line);padding:28px 0}
.faq-list details summary{cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;font-family:"Playfair Display",serif;font-size:26px;font-weight:500;color:var(--ink);gap:14px}
.faq-list details summary::-webkit-details-marker{display:none}
.faq-list details summary::after{content:"+";color:var(--gold);font-size:32px;font-weight:300;transition:transform .3s;flex:none}
.faq-list details[open] summary::after{transform:rotate(45deg)}
.faq-list details p{margin-top:14px;font-size:15px;line-height:1.7;color:var(--ink-soft);max-width:720px}

/* CTA STRIP */
.cta-strip{background:var(--bg-dark);color:var(--ivory);padding:80px 0;text-align:center;background-image:radial-gradient(ellipse at center,rgba(184,148,54,.18),transparent 60%)}
.cta-strip h2{color:var(--ivory)}
.cta-strip h2 .ital{color:var(--gold-light)}

/* FOOTER */
footer{background:var(--bg-dark);color:var(--ivory);padding:80px 0 40px;border-top:1px solid var(--line-dark)}
footer .foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;margin-bottom:48px}
footer h5{font-family:"Playfair Display",serif;font-size:22px;font-weight:600;color:var(--gold-light);margin-bottom:14px}
footer a{display:block;color:var(--ivory);opacity:.7;text-decoration:none;font-size:14px;padding:4px 0;transition:.15s}
footer a:hover{opacity:1;color:var(--gold-light)}
footer .foot-bot{display:flex;justify-content:space-between;align-items:center;border-top:1px solid var(--line-dark);padding-top:24px;font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:rgba(243,234,215,.5);flex-wrap:wrap;gap:14px}
@media(max-width:900px){footer .foot-grid{grid-template-columns:1fr 1fr}}

/* PAGE-CHROME (for register/sponsor/admin standalone pages) */
.page-chrome{padding:32px 0;background:var(--cream);border-bottom:1px solid var(--line)}
.page-chrome .breadcrumb{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--gold-deep);font-weight:700;margin-bottom:14px}
.page-chrome h1{font-size:clamp(40px,6vw,72px)}
.page-chrome .lede{font-size:18px;color:var(--ink-soft);max-width:560px;margin-top:14px;line-height:1.6}

/* ADMIN-SPECIFIC (used by admin.html) */
.admin-app{display:grid;grid-template-columns:240px 1fr;min-height:100vh}
.admin-side{background:var(--bg-dark);color:var(--ivory);padding:32px 24px;position:sticky;top:0;height:100vh;overflow-y:auto;border-right:1px solid var(--line-dark)}
.admin-side .logo{display:flex;align-items:center;gap:12px;margin-bottom:32px;padding-bottom:24px;border-bottom:1px solid var(--line-dark)}
.admin-side .logo svg{width:40px;height:40px}
.admin-side .logo .nm{font-family:"Playfair Display",serif;font-weight:600;font-size:18px}
.admin-side .logo .sb{font-family:"JetBrains Mono",monospace;font-size:9px;letter-spacing:.22em;text-transform:uppercase;color:var(--gold-light);margin-top:2px;font-weight:700}
.admin-side .group{margin-bottom:24px}
.admin-side .group-label{font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:.22em;text-transform:uppercase;opacity:.5;margin-bottom:8px;padding:0 8px;font-weight:700}
.admin-side a.nav{display:flex;align-items:center;gap:10px;padding:10px;font-size:14px;color:rgba(243,234,215,.78);text-decoration:none;transition:.15s}
.admin-side a.nav:hover{background:rgba(243,234,215,.06);color:var(--ivory)}
.admin-side a.nav.active{background:rgba(184,148,54,.18);color:var(--gold-light);font-weight:600;border-left:2px solid var(--gold)}
.admin-side a.nav .ic{width:18px;text-align:center}
.admin-side .pill-count{margin-left:auto;font-family:"JetBrains Mono",monospace;font-size:10px;background:rgba(243,234,215,.1);padding:2px 6px;font-weight:700}
.admin-main{padding:32px 40px;background:var(--cream-2);min-height:100vh}
.admin-topbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px;flex-wrap:wrap;gap:16px}
.admin-topbar h1{font-size:36px}
.admin-topbar h1 .ital{color:var(--gold-deep)}
.search{padding:10px 16px;border:1px solid var(--line);background:var(--paper);font-family:inherit;font-size:14px;width:280px}
.kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:24px}
.kpi{background:var(--paper);border:1px solid var(--line);padding:24px;position:relative;overflow:hidden}
.kpi .lab{margin-bottom:8px}
.kpi .v{font-family:"Playfair Display",serif;font-style:italic;font-weight:500;font-size:48px;line-height:1;color:var(--ink)}
.kpi .v small{font-size:18px;color:var(--ink-soft);font-style:normal}
.kpi .delta{display:inline-flex;align-items:center;gap:4px;font-size:12px;color:var(--emerald);margin-top:8px;font-weight:600}
.kpi .delta.down{color:var(--rose)}
.kpi.gold{background:linear-gradient(135deg,var(--gold-light),var(--gold))}
.kpi.dark{background:var(--bg-dark);color:var(--ivory);border-color:var(--bg-dark)}
.kpi.dark .lab{color:var(--gold-light)}
.kpi.dark .v{color:var(--gold-light)}
.kpi.dark .delta{color:var(--gold-light)}

.panel{background:var(--paper);border:1px solid var(--line);margin-bottom:24px;overflow:hidden}
.panel-head{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--line);background:var(--cream)}
.panel-head h2{font-family:"Playfair Display",serif;font-size:24px;font-weight:600}
.panel-head .right{display:flex;gap:8px;align-items:center}
.panel-body{padding:0}
.tabs-row{display:flex;border-bottom:1px solid var(--line);background:var(--cream-2);padding:0 24px}
.tabs-row a{padding:14px 18px;font-size:13px;font-weight:600;color:var(--ink-soft);text-decoration:none;border-bottom:2px solid transparent;transition:.2s}
.tabs-row a.active{color:var(--ink);border-bottom-color:var(--gold)}
table.admin-table{width:100%;border-collapse:collapse;font-size:14px}
table.admin-table th{text-align:left;padding:14px 18px;font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-soft);background:var(--cream-2);border-bottom:1px solid var(--line);font-weight:700}
table.admin-table td{padding:14px 18px;border-bottom:1px solid var(--line);vertical-align:middle}
table.admin-table tr:hover td{background:var(--cream-2)}
table.admin-table .name{font-weight:600}
table.admin-table .sub{font-size:12px;color:var(--ink-soft);margin-top:2px}
table.admin-table .player-slots{display:flex;gap:4px;margin-top:4px}
table.admin-table .slot{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;background:var(--emerald);color:var(--paper);font-size:9px;font-weight:700}
table.admin-table .slot.empty{background:transparent;color:var(--ink-soft);border:1px dashed var(--ink-soft)}
table.admin-table .actions{display:flex;gap:6px;justify-content:flex-end}
@media(max-width:1100px){.admin-app{grid-template-columns:1fr}.admin-side{position:relative;height:auto}.kpi-row{grid-template-columns:1fr 1fr}}

/* ============================ APP-LAYER ============================ */
/* Logo upload zone (sponsor page) */
.logo-zone{
  border:2px dashed var(--line);
  background:var(--cream-2);
  padding:32px;
  text-align:center;
  transition:.2s;
  cursor:pointer;
  margin-top:14px;
}
.logo-zone:hover,.logo-zone.drag-over{border-color:var(--gold);background:rgba(184,148,54,.06)}
.logo-zone .ic{font-size:48px;color:var(--gold);line-height:1;margin-bottom:14px}
.logo-zone .ttl{font-family:"Playfair Display",serif;font-weight:600;font-size:22px;margin-bottom:6px}
.logo-zone .desc{font-size:14px;color:var(--ink-soft);line-height:1.5}
.logo-zone .desc strong{color:var(--gold-deep)}
.logo-zone input[type="file"]{display:none}
.logo-zone .browse{display:inline-block;margin-top:10px;color:var(--gold-deep);font-weight:700;border-bottom:2px solid var(--gold);padding-bottom:2px}
.logo-preview{margin-top:14px;padding:18px;background:var(--paper);border:1px solid var(--line)}
.logo-preview-row{display:flex;gap:18px;align-items:center}
.logo-preview-row img{max-width:120px;max-height:120px;background:#fff;padding:6px;border:1px solid var(--line);object-fit:contain}
.logo-err{padding:14px;background:rgba(196,73,90,.08);border:1px solid var(--rose);color:var(--rose);font-size:13px;font-weight:600}

/* Toast */
.acf-toast{
  position:fixed;left:50%;bottom:32px;transform:translate(-50%,80px);
  background:var(--ink);color:var(--ivory);padding:14px 24px;
  font-family:"JetBrains Mono",monospace;font-size:12px;letter-spacing:.16em;text-transform:uppercase;font-weight:700;
  border:1px solid var(--gold);box-shadow:var(--shadow-lg);
  z-index:200;opacity:0;transition:.3s;max-width:90vw;
}
.acf-toast.visible{transform:translate(-50%,0);opacity:1}
.acf-toast[data-kind="err"]{border-color:var(--rose);color:#ffd9df}

/* Gallery */
.gallery-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:14px;
  grid-auto-flow:dense;
}
.gallery-grid figure{margin:0;position:relative;overflow:hidden;background:var(--cream);aspect-ratio:1}
.gallery-grid figure.tall{grid-row:span 2;aspect-ratio:1/2}
.gallery-grid figure.wide{grid-column:span 2;aspect-ratio:2/1}
.gallery-grid figure.panorama{grid-column:span 4;aspect-ratio:3/1}
.gallery-grid figure img,.gallery-grid figure .ph{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s ease}
.gallery-grid figure:hover img{transform:scale(1.04)}
.gallery-grid figure .cap{
  position:absolute;left:0;right:0;bottom:0;padding:14px;
  background:linear-gradient(180deg,transparent,rgba(12,16,12,.85));
  color:var(--ivory);font-family:"Caveat",cursive;font-size:18px;
  opacity:0;transform:translateY(8px);transition:.3s;
}
.gallery-grid figure:hover .cap{opacity:1;transform:translateY(0)}
.gallery-grid figure .ph{
  background:linear-gradient(135deg,var(--emerald),var(--sage));
  display:flex;align-items:center;justify-content:center;
  color:var(--gold-light);font-family:"Playfair Display",serif;font-style:italic;font-size:24px;
  text-align:center;padding:24px;
}
@media(max-width:900px){.gallery-grid{grid-template-columns:1fr 1fr}.gallery-grid figure.panorama{grid-column:span 2;aspect-ratio:2/1}}
@media(max-width:520px){.gallery-grid{grid-template-columns:1fr}.gallery-grid figure.wide,.gallery-grid figure.tall,.gallery-grid figure.panorama{grid-column:span 1;grid-row:span 1;aspect-ratio:1}}

/* Polaroid with real photo (replaces SVG fallback) */
.polaroid .pic.has-image{background:none;padding:0}
.polaroid .pic.has-image img{width:100%;height:100%;object-fit:cover;display:block}

/* ============================ MOBILE TIGHTEN ============================ */
/* Tablet-down: tighten everything for <=900px (a lot already handled above) */
@media(max-width:900px){
  .hero-meta{grid-template-columns:1fr 1fr}
  .pillars-grid{grid-template-columns:1fr 1fr}
}

/* Phone: aggressive tightening for <=640px */
@media(max-width:640px){
  .wrap{padding:0 18px}
  .wrap-narrow{padding:0 18px}

  /* Nav — hide link list on phones; logo + Register stay */
  nav.main .row{grid-template-columns:auto 1fr;gap:14px;padding:12px 0}
  nav.main .links{display:none}
  nav.main .logo .nm{font-size:15px}
  nav.main .logo .sb{font-size:9px}
  nav.main .logo .crest-svg{width:40px;height:40px}
  .btn{padding:10px 16px;font-size:12px}
  .btn.lg{padding:13px 20px;font-size:13px}

  /* Topbar — stack info + link */
  .topbar .row{padding:8px 0;font-size:10px;letter-spacing:.14em}

  /* Hero — title scales aggressively */
  .hero{padding:32px 0 56px}
  .hero h1{font-size:clamp(34px,9vw,64px);line-height:1.02}
  .hero h1 .small{font-size:.5em;margin-top:14px}
  .hero .lede{font-size:16px;margin-top:22px}
  .hero .ctas{gap:10px;margin-top:24px}
  .hero .scribble{font-size:18px}
  .hero .countdown{gap:14px;margin-top:28px;flex-wrap:wrap}
  .cd .num{font-size:36px}
  .cd .lab{font-size:9px;letter-spacing:.22em}
  .hero-meta{grid-template-columns:1fr 1fr}
  .hero-meta .m{padding:14px}
  .hero-meta .m .v{font-size:18px}
  .hero-meta .m .v small{font-size:11px}

  /* Sections — reduce padding */
  section{padding:48px 0}
  .section-head{margin-bottom:28px;grid-template-columns:1fr;gap:12px}
  .section-head .num{font-size:48px}
  .section-head .lead{font-size:15px}

  /* Schedule — 1 column on phones */
  .sched-grid{grid-template-columns:1fr}
  .sched-cell{padding:20px 16px}
  .sched-cell .time{font-size:42px}
  .sched-cell .time small{font-size:22px}
  .sched-cell .ttl{font-size:12px}
  .sched-cell .desc{font-size:13px}

  /* Raise card */
  .raise-card{padding:24px;gap:18px}
  .raise-num{font-size:64px}
  .raise-num small{font-size:24px}
  .progress-line{height:12px}

  /* Tickets */
  .ticket-feature{padding:28px 22px}
  .ticket-feature h3{font-size:32px !important}
  .ticket-feature .price{font-size:80px}
  .ticket-feature .price small{font-size:16px}
  .tk-mini{padding:20px}
  .tk-mini h4{font-size:18px}
  .tk-mini .pp{font-size:32px}

  /* Sponsor tier */
  .spon-tier{padding:24px 20px}
  .spon-tier h3{font-size:28px}
  .spon-tier .price-num{font-size:54px}
  .spon-tier ul li{font-size:13px}

  /* Form */
  .form-grid{gap:24px}
  .summary-card{padding:24px}
  .summary-card h3{font-size:24px}
  .sum-tot{font-size:36px}
  .player{padding:20px}
  .player h4{font-size:20px}

  /* Mission */
  .mission-grid{gap:32px}
  .pillars-grid{grid-template-columns:1fr;gap:10px}
  .pillar{padding:18px}
  .pillar h4{font-size:18px}
  .polaroid{padding:12px 12px 36px;transform:rotate(-1.5deg)}
  .polaroid .cap{font-size:18px}

  /* Wall */
  .wall-row{padding:10px 0}
  .wall-row .nm{font-size:16px}

  /* FAQ */
  .faq-list details{padding:20px 0}
  .faq-list details summary{font-size:18px}
  .faq-list details summary::after{font-size:24px}

  /* CTA strip */
  .cta-strip{padding:48px 0}
  .cta-strip h2{font-size:42px !important}

  /* Footer */
  footer{padding:48px 0 24px}
  footer .foot-grid{grid-template-columns:1fr 1fr;gap:24px;margin-bottom:32px}
  footer .foot-bot{font-size:9px;letter-spacing:.14em;text-align:center;justify-content:center}
  footer h5{font-size:18px}

  /* Sponsor table — reduce */
  .spon-table th,.spon-table td{padding:12px 10px}
  .spon-table .nm{font-size:16px}
  .spon-table .pr{font-size:20px}

  /* Compare table — give it horizontal scroll inside its wrapper */
  .compare-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
  .compare-table{min-width:560px}

  /* Register page chrome */
  .page-chrome{padding:24px 0}
  .page-chrome h1{font-size:36px !important}
  .step-strip{flex-direction:column}
  .step{border-right:none;border-bottom:1px solid var(--line);justify-content:flex-start}

  /* Addons */
  .addon-strip{grid-template-columns:1fr !important}
  .addon{padding:16px}
}

/* Tiny phones <=380px */
@media(max-width:380px){
  .hero h1{font-size:32px}
  .section-head .num{font-size:40px}
  .raise-num{font-size:48px}
  .ticket-feature .price{font-size:64px}
  .spon-tier .price-num{font-size:44px}
  .hero-meta{grid-template-columns:1fr}
}

/* ========== PAGE-SPECIFIC MOBILE: register / sponsor / admin / roster / thanks ========== */
@media(max-width:640px){
  /* Register/Sponsor — tighten the form area */
  .page-chrome{padding:24px 0 14px}
  .page-chrome .breadcrumb{font-size:10px;letter-spacing:.18em}
  .page-chrome .lede{font-size:15px}
  .seg-control{width:100%;flex-wrap:wrap;padding:4px}
  .seg-control button{padding:8px 14px;font-size:12px;flex:1 1 45%}

  /* Sponsor — package picker grid */
  .pkg-grid{grid-template-columns:1fr 1fr !important;gap:6px !important}
  .pkg-opt{padding:10px;font-size:11px}
  .pkg-opt strong{font-size:15px}

  /* Sponsor — testimonial */
  .testimonial{padding:36px 24px}
  .testimonial blockquote{font-size:22px}
  .testimonial::before{font-size:120px;top:14px;left:24px}

  /* Sponsor — extra package table rows readable on phone */
  .spon-table .nm{font-size:14px}
  .spon-table .pr{font-size:18px}
  .spon-table td{padding:10px 8px}

  /* Roster page */
  .team-card{padding:24px}
  .team-card h1{font-size:32px !important}
  .team-card .meta-row{gap:14px}
  .team-card .meta-row .v{font-size:18px}
  .progress-roster{grid-template-columns:1fr 1fr;gap:6px}
  .slot-marker{font-size:24px}
  .share-strip{flex-direction:column;align-items:stretch;text-align:center}
  .share-strip code{display:block;word-break:break-all;font-size:11px}

  /* Thanks page */
  .thanks-shell{padding:32px 18px}
  .thanks-shell h1{font-size:38px !important}
  .thanks-shell .lede{font-size:15px}
  .thanks-mark{width:80px;height:80px;font-size:40px}
  .receipt{padding:20px;margin-top:32px}
  .receipt .row .v{font-size:13px}
  .receipt .total{font-size:24px}
  .next-steps{gap:10px}
  .next-step{padding:18px}
  .next-step .step-n{font-size:36px}

  /* Admin sidebar — already collapses but tighten */
  .admin-side{position:relative;height:auto;padding:18px}
  .admin-main{padding:18px}
  .admin-topbar h1{font-size:24px !important}
  .admin-topbar .search{width:100%}
  .kpi-row{grid-template-columns:1fr 1fr}
  .kpi .v{font-size:32px}

  /* Form summary card on mobile no longer sticky (stacks below form) */
  .summary-card{padding:24px}
  .summary-card h3{font-size:22px}
  .sum-tot{font-size:36px}

  /* Logo zone (sponsor logo uploader) */
  .logo-zone{padding:24px 18px}
  .logo-zone .ic{font-size:36px}
  .logo-zone .ttl{font-size:18px}

  /* CTA strip on sub-pages */
  .cta-strip{padding:48px 18px}
}

/* Tiny phones <=380px - extra reductions for sub-pages */
@media(max-width:380px){
  .pkg-grid{grid-template-columns:1fr !important}
  .progress-roster{grid-template-columns:repeat(4,1fr);gap:4px}
  .slot-marker{font-size:18px}
  .kpi-row{grid-template-columns:1fr}
}

/* ========== MOBILE NAV — VISIBLE LINKS ON A SECOND ROW (no hamburger) ========== */
/* Legacy hamburger artefacts hidden — JS still creates them harmlessly */
.nav-toggle,.nav-backdrop,.mobile-drawer{display:none !important}

@media(max-width:640px){
  /* Stack the nav: row 1 = logo, row 2 = links (inline horizontal, centered) */
  nav.main .row{
    display:grid !important;
    grid-template-columns:1fr;
    grid-template-rows:auto auto;
    gap:0;
    padding:10px 0 0;
    align-items:start;
  }
  nav.main .logo{justify-self:start}
  nav.main .right{display:none}
  nav.main .links{
    display:flex !important;
    flex-wrap:nowrap;
    justify-content:space-between;
    gap:6px;
    margin-top:8px;
    padding:10px 2px 4px;
    border-top:1px solid var(--line);
    font-size:10px;
    letter-spacing:.12em;
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:none;
  }
  nav.main .links::-webkit-scrollbar{display:none}
  nav.main .links a{white-space:nowrap;flex:0 0 auto;padding:2px 0}
  nav.main .links a.active{padding-bottom:0}
}

/* ========== HERO CTA EQUAL HEIGHT (mobile) ========== */
@media(max-width:640px){
  .hero .ctas{flex-direction:column;align-items:stretch;gap:10px}
  .hero .ctas .btn{width:100%;justify-content:center}
  /* Donate + Become a Sponsor go side-by-side, equal width + height */
  .hero .ctas .cta-pair{display:grid;grid-template-columns:1fr 1fr;gap:10px;width:100%}
  .hero .ctas .cta-pair .btn{width:100%;height:100%;padding:14px 12px;font-size:12px;letter-spacing:.12em}
  .hero .ctas .scribble{align-self:center;margin-top:4px}
}

/* ========== HERO DATE LINE — keep on one line on mobile ========== */
@media(max-width:640px){
  .hero .lede.date-line{
    font-size:clamp(11px,3.3vw,22px) !important;
    white-space:nowrap;
    letter-spacing:-.012em;
    line-height:1.25;
  }
}

/* ========== REGISTER PAGE — kill horizontal overflow on mobile ========== */
@media(max-width:640px){
  html,body{overflow-x:hidden}
  .row2{grid-template-columns:1fr;gap:10px}
  .row2 .field input,.row2 .field textarea,.field input,.field textarea{min-width:0;width:100%;max-width:100%;box-sizing:border-box}
  .field{min-width:0}
  .player{padding:18px;min-width:0}
  /* Register page info strip (After you register / Day-of / Refunds) */
  section .wrap > div[style*="repeat(3,1fr)"]{grid-template-columns:1fr !important;gap:24px !important}
  /* Secure row pay-logos — let it wrap cleanly */
  .secure-row{gap:12px;font-size:10px}
  .secure-row .pay-logos{font-size:11px;flex-wrap:wrap}
  /* Optional donation row — number input was overflowing */
  .addon{flex-wrap:wrap}
  .addon > div:first-child{flex:1 1 100%}
  /* Captain pill row */
  .player .top{flex-wrap:wrap;gap:8px}
  /* Step strip already stacks via inline rule but ensure nothing overflows */
  .step-strip{min-width:0}
  /* Reserve toggle label long text wrap */
  .reserve-toggle{flex-wrap:wrap}
}
