:root{
  --paper: #ded2ae;
  --paper-2: #d3c69c;
  --ink: #1b1b17;
  --ink-soft: #3a382f;
  --pitch: #1f4d3a;
  --pitch-2: #163a2b;
  --visa-red: #a5342b;
  --gold: #b8902e;
  --line: rgba(27,27,23,0.28);
  --line-soft: rgba(27,27,23,0.14);
  --paper-rgb: 222,210,174;
}
*{box-sizing:border-box;}
html,body{margin:0;padding:0;}
body{
  background:var(--paper);
  background-image:
    radial-gradient(rgba(27,27,23,0.035) 1px, transparent 1px);
  background-size: 3px 3px;
  color:var(--ink);
  font-family:'Inter',sans-serif;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,.display{
  font-family:'Fraunces',serif;
  font-weight:600;
  letter-spacing:-0.01em;
  margin:0;
}
.mono{font-family:'IBM Plex Mono',monospace;}
.wrap{max-width:920px;margin:0 auto;padding:0 24px;}
a{color:inherit;}
button{font-family:inherit;cursor:pointer;}

/* header */
header.topbar{
  background:var(--pitch);
  color:var(--paper);
  border-bottom:3px solid var(--pitch-2);
  position:sticky;top:0;z-index:100;
}
.topbar-inner{
  max-width:920px;margin:0 auto;padding:16px 24px;
  display:flex;align-items:center;justify-content:space-between;
}
.wordmark{
  display:flex;align-items:baseline;gap:8px;
  font-family:'Fraunces',serif;font-weight:700;font-size:20px;letter-spacing:0.01em;
}
.wordmark .mono{font-size:11px;color:var(--gold);letter-spacing:0.12em;text-transform:uppercase;}
nav.topnav{display:flex;gap:18px;font-family:'IBM Plex Mono',monospace;font-size:12px;letter-spacing:0.06em;text-transform:uppercase;}
nav.topnav span{cursor:pointer;opacity:0.82;border-bottom:1px solid transparent;padding-bottom:2px;}
nav.topnav span:hover{opacity:1;border-bottom:1px solid var(--gold);}

/* hero */
.hero{padding:72px 24px 56px;}
.eyebrow{
  font-family:'IBM Plex Mono',monospace;font-size:12px;letter-spacing:0.14em;text-transform:uppercase;
  color:var(--visa-red);margin-bottom:18px;display:flex;align-items:center;gap:10px;
}
.eyebrow::before{content:"";width:22px;height:1px;background:var(--visa-red);display:inline-block;}
.hero h1{font-size:clamp(34px,5.4vw,58px);line-height:1.04;max-width:11.5em;}
.hero p.lede{font-size:18px;line-height:1.6;max-width:34em;margin-top:22px;color:var(--ink-soft);}
.hero-actions{display:flex;gap:16px;margin-top:34px;flex-wrap:wrap;align-items:center;}
.btn{
  font-family:'IBM Plex Mono',monospace;font-size:13px;letter-spacing:0.05em;text-transform:uppercase;
  padding:14px 24px;border-radius:2px;border:1.5px solid var(--ink);background:var(--ink);color:var(--paper);
  transition:transform .12s ease;
}
.btn:hover{transform:translateY(-1px);}
.btn.secondary{background:transparent;color:var(--ink);border:1.5px solid var(--line);}
.btn.secondary:hover{border-color:var(--ink);}
.btn:disabled{opacity:0.4;cursor:not-allowed;}
.stat-strip{display:flex;gap:0;margin-top:56px;border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.stat-strip div{flex:1;padding:18px 4px;border-right:1px solid var(--line);}
.stat-strip div:last-child{border-right:none;}
.stat-strip .num{font-family:'Fraunces',serif;font-size:26px;font-weight:600;}
.stat-strip .lab{font-family:'IBM Plex Mono',monospace;font-size:11px;text-transform:uppercase;letter-spacing:0.08em;color:var(--ink-soft);margin-top:4px;}

/* stamp */
.stamp{
  display:inline-flex;flex-direction:column;align-items:center;justify-content:center;
  width:96px;height:96px;border-radius:50%;
  border:2px dashed var(--visa-red);color:var(--visa-red);
  transform:rotate(-9deg);
  font-family:'IBM Plex Mono',monospace;text-transform:uppercase;
}
.stamp .big{font-size:20px;font-weight:600;line-height:1;}
.stamp .small{font-size:8px;letter-spacing:0.08em;margin-top:2px;}

/* quiz */
.quiz-shell{padding:48px 24px 80px;}
.quiz-card{
  background:rgba(255,255,255,0.28);
  border:1px solid var(--line);
  padding:40px 36px;
  position:relative;
}
.page-marker{
  display:flex;justify-content:space-between;align-items:center;
  font-family:'IBM Plex Mono',monospace;font-size:11px;letter-spacing:0.1em;text-transform:uppercase;
  color:var(--ink-soft);margin-bottom:26px;
}
.stamp-row{display:flex;gap:6px;}
.mini-stamp{width:16px;height:16px;border-radius:50%;border:1.5px solid var(--line);}
.mini-stamp.filled{border-color:var(--pitch);background:var(--pitch);}
.quiz-card h2{font-size:clamp(22px,3.2vw,30px);line-height:1.2;max-width:18em;}
.quiz-card .qsub{color:var(--ink-soft);margin-top:8px;font-size:14px;}
.options{margin-top:28px;display:flex;flex-direction:column;gap:10px;}
.option{
  border:1.5px solid var(--line);padding:16px 18px;display:flex;gap:14px;align-items:flex-start;
  background:rgba(255,255,255,0.35);transition:border-color .12s, background .12s;
}
.option:hover{border-color:var(--ink);}
.option.selected{border-color:var(--visa-red);background:rgba(165,52,43,0.07);}
.option .letter{
  font-family:'IBM Plex Mono',monospace;font-size:12px;color:var(--ink-soft);
  border:1px solid var(--line);width:22px;height:22px;flex:none;
  display:flex;align-items:center;justify-content:center;border-radius:50%;margin-top:1px;
}
.option.selected .letter{border-color:var(--visa-red);color:var(--visa-red);}
.option .otext strong{display:block;font-size:15px;margin-bottom:3px;}
.option .otext span{font-size:13px;color:var(--ink-soft);line-height:1.4;}
.quiz-nav{display:flex;justify-content:space-between;margin-top:30px;align-items:center;}
.quiz-nav .step-count{font-family:'IBM Plex Mono',monospace;font-size:12px;color:var(--ink-soft);}

/* result */
.result-shell{padding:56px 24px 80px;}
.result-top{display:flex;gap:36px;align-items:center;flex-wrap:wrap;}
.crest{
  width:120px;height:120px;border-radius:50%;flex:none;
  display:flex;align-items:center;justify-content:center;
  font-family:'Fraunces',serif;font-weight:700;font-size:34px;color:#fff;
  border:3px solid rgba(0,0,0,0.15);
}
.result-meta .granted{
  font-family:'IBM Plex Mono',monospace;color:var(--visa-red);font-size:12px;letter-spacing:0.14em;text-transform:uppercase;
  display:flex;align-items:center;gap:8px;margin-bottom:8px;
}
.result-meta .granted::before{content:"";width:18px;height:1px;background:var(--visa-red);}
.result-meta h2{font-size:clamp(28px,4.4vw,42px);}
.result-meta .subline{color:var(--ink-soft);margin-top:6px;font-size:15px;}
.match-pct{font-family:'IBM Plex Mono',monospace;font-size:13px;margin-top:10px;color:var(--ink-soft);}
.match-pct b{color:var(--ink);font-size:15px;}
.why-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:22px;}
.why-chip{
  border:1px solid var(--line);padding:7px 13px;font-size:12.5px;
  font-family:'IBM Plex Mono',monospace;background:rgba(255,255,255,0.35);
}
.result-actions{display:flex;gap:14px;margin-top:30px;flex-wrap:wrap;}
.share-link-box{
  margin-top:20px;padding:14px 18px;border:1px dashed var(--line);
  font-family:'IBM Plex Mono',monospace;font-size:11px;color:var(--ink-soft);
  word-break:break-all;display:none;
}
.share-link-box.show{display:block;}
.share-link-box a{color:var(--visa-red);}
.runners{margin-top:56px;}
.runners h3{font-family:'IBM Plex Mono',monospace;font-size:12px;text-transform:uppercase;letter-spacing:0.1em;color:var(--ink-soft);margin-bottom:16px;}
.runner-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.runner-card{
  border:1px solid var(--line);padding:18px;display:flex;gap:14px;align-items:center;
  background:rgba(255,255,255,0.28);
}
.runner-card:hover{border-color:var(--ink);cursor:pointer;}
.runner-crest{width:52px;height:52px;border-radius:50%;flex:none;display:flex;align-items:center;justify-content:center;color:#fff;font-family:'Fraunces',serif;font-weight:700;font-size:16px;}
.runner-card .rname{font-weight:600;font-size:15px;}
.runner-card .rleague{font-family:'IBM Plex Mono',monospace;font-size:11px;color:var(--ink-soft);margin-top:2px;text-transform:uppercase;}

/* retake flow */
.retake-bar{
  margin-top:24px;padding:16px 18px;border:1px solid var(--line);background:rgba(255,255,255,0.28);
}
.retake-bar .rt-label{font-family:'IBM Plex Mono',monospace;font-size:11px;text-transform:uppercase;letter-spacing:0.08em;color:var(--ink-soft);margin-bottom:12px;}
.retake-chips{display:flex;flex-wrap:wrap;gap:8px;}
.retake-chip{
  border:1px solid var(--line);padding:6px 12px;font-size:12px;
  font-family:'IBM Plex Mono',monospace;background:rgba(255,255,255,0.35);
  cursor:pointer;transition:border-color .12s;
}
.retake-chip:hover{border-color:var(--ink);}
.retake-chip.active{border-color:var(--visa-red);background:rgba(165,52,43,0.07);}

/* dossier */
.dossier-band{color:#fff;padding:44px 24px 34px;}
.dossier-band .wrap{display:flex;gap:26px;align-items:center;flex-wrap:wrap;}
.dossier-crest{width:84px;height:84px;border-radius:50%;flex:none;display:flex;align-items:center;justify-content:center;font-family:'Fraunces',serif;font-weight:700;font-size:26px;color:#fff;border:2px solid rgba(255,255,255,0.4);}
.dossier-band .dname{font-size:clamp(24px,4vw,36px);}
.dossier-band .dmeta{font-family:'IBM Plex Mono',monospace;font-size:12px;letter-spacing:0.08em;text-transform:uppercase;opacity:0.88;margin-top:6px;}
.dossier-body{padding:44px 24px 80px;}
.field{border-top:1px solid var(--line);padding:22px 0;}
.field:last-child{border-bottom:1px solid var(--line);}
.field .flabel{font-family:'IBM Plex Mono',monospace;font-size:11px;text-transform:uppercase;letter-spacing:0.1em;color:var(--visa-red);margin-bottom:8px;}
.field .fval{font-size:15.5px;line-height:1.65;color:var(--ink);}
.field .fval.serif{font-family:'Fraunces',serif;font-size:18px;font-weight:500;line-height:1.5;}
.tagpills{display:flex;flex-wrap:wrap;gap:8px;}
.tagpills span{border:1px solid var(--line);padding:5px 11px;font-size:12px;font-family:'IBM Plex Mono',monospace;}
.back-link{font-family:'IBM Plex Mono',monospace;font-size:12px;text-transform:uppercase;letter-spacing:0.06em;color:var(--ink-soft);cursor:pointer;display:inline-block;margin-bottom:18px;}
.back-link:hover{color:var(--ink);}

/* browse */
.browse-shell{padding:48px 24px 80px;}
.league-group{margin-bottom:44px;}
.league-head{display:flex;align-items:baseline;gap:14px;border-bottom:2px solid var(--ink);padding-bottom:10px;margin-bottom:16px;}
.league-head h2{font-size:22px;}
.league-head .country{font-family:'IBM Plex Mono',monospace;font-size:11px;text-transform:uppercase;color:var(--ink-soft);letter-spacing:0.08em;}
.league-head .count{font-family:'IBM Plex Mono',monospace;font-size:11px;color:var(--ink-soft);margin-left:auto;}
.club-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:12px;}
.club-card{
  border:1px solid var(--line);padding:14px;display:flex;gap:12px;align-items:center;
  background:rgba(255,255,255,0.28);
}
.club-card:hover{border-color:var(--ink);cursor:pointer;}
.club-crest-sm{width:38px;height:38px;border-radius:50%;flex:none;display:flex;align-items:center;justify-content:center;color:#fff;font-family:'Fraunces',serif;font-weight:700;font-size:13px;}
.club-card .cname{font-size:13.5px;font-weight:600;line-height:1.25;}
.club-card .cid{font-family:'IBM Plex Mono',monospace;font-size:10px;color:var(--ink-soft);margin-top:2px;}

/* loading */
.loading{padding:80px 24px;text-align:center;font-family:'IBM Plex Mono',monospace;font-size:13px;color:var(--ink-soft);letter-spacing:0.06em;text-transform:uppercase;}
.loading .dots::after{content:"...";animation:dots 1.4s steps(4) infinite;}
@keyframes dots{0%{content:"."}25%{content:".."}50%{content:"..."}75%{content:""}}

footer{padding:30px 24px 50px;text-align:center;font-family:'IBM Plex Mono',monospace;font-size:11px;color:var(--ink-soft);letter-spacing:0.05em;}

/* ──── Responsive ──── */

/* Mobile baseline: 375px */
@media(max-width:640px){
  .wrap{padding:0 16px;}
  .topbar-inner{padding:12px 16px;gap:8px;}
  .wordmark{font-size:16px;}
  .wordmark .mono{font-size:9px;}
  nav.topnav{gap:12px;font-size:10px;}
  .hero{padding:40px 16px 36px;}
  .hero h1{font-size:clamp(28px,8vw,42px);}
  .hero p.lede{font-size:15px;margin-top:16px;}
  .hero-actions{gap:10px;margin-top:24px;}
  .btn{padding:12px 18px;font-size:12px;}
  .stat-strip{margin-top:36px;flex-direction:column;}
  .stat-strip div{border-right:none;border-bottom:1px solid var(--line);padding:14px 4px;}
  .stat-strip div:last-child{border-bottom:none;}
  .stat-strip .num{font-size:22px;}
  .quiz-shell{padding:24px 16px 60px;}
  .quiz-card{padding:24px 20px;}
  .quiz-card h2{font-size:clamp(18px,4vw,24px);}
  .quiz-card .qsub{font-size:13px;}
  .option{padding:14px 12px;gap:10px;}
  .option .letter{width:20px;height:20px;font-size:11px;}
  .option .otext strong{font-size:14px;}
  .option .otext span{font-size:12px;}
  .quiz-nav{flex-wrap:wrap;gap:10px;justify-content:space-between;}
  .quiz-nav .step-count{order:3;flex-basis:100%;text-align:center;}
  .result-shell{padding:32px 16px 60px;}
  .result-top{gap:20px;}
  .crest{width:80px;height:80px;font-size:24px;}
  .result-meta h2{font-size:clamp(22px,6vw,32px);}
  .why-chip{font-size:11px;padding:6px 10px;}
  .result-actions{gap:10px;}
  .result-actions .btn{flex:1 1 auto;text-align:center;}
  .runner-grid{grid-template-columns:1fr;}
  .runner-card{padding:14px;gap:12px;}
  .retake-chips{gap:6px;}
  .retake-chip{padding:5px 10px;font-size:11px;}
  .dossier-band{padding:28px 16px 24px;}
  .dossier-band .wrap{gap:16px;}
  .dossier-crest{width:60px;height:60px;font-size:20px;}
  .dossier-band .dname{font-size:clamp(20px,5vw,28px);}
  .dossier-band .dmeta{font-size:11px;}
  .dossier-body{padding:28px 16px 60px;}
  .field{padding:18px 0;}
  .field .fval{font-size:14.5px;}
  .field .fval.serif{font-size:16px;}
  .browse-shell{padding:32px 16px 60px;}
  .league-head h2{font-size:18px;}
  .club-grid{grid-template-columns:1fr;}
  .club-card{padding:12px;gap:10px;}
  .club-card .cname{font-size:13px;}
  footer{padding:24px 16px 36px;font-size:10px;}
}

/* Tablet: 768px */
@media(min-width:641px) and (max-width:900px){
  .wrap{padding:0 20px;}
  .topbar-inner{padding:14px 20px;}
  .hero{padding:56px 20px 44px;}
  .quiz-shell{padding:36px 20px 70px;}
  .quiz-card{padding:32px 28px;}
  .result-shell{padding:44px 20px 70px;}
  .dossier-band{padding:36px 20px 28px;}
  .dossier-body{padding:36px 20px 70px;}
  .browse-shell{padding:40px 20px 70px;}
  .club-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));}
}

/* Desktop: 901px+ */
@media(min-width:901px){
  .wrap{padding:0 24px;}
}

/* ============================================================
   v2 additions: NFL grid, floating share bar, toast
   ============================================================ */

/* ── NFL team selector grid ── */
.nfl-grid{
  margin-top:24px;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:20px;
}
.nfl-conference{
  /* each conference is a column */
}
.nfl-conf-header{
  font-family:'IBM Plex Mono',monospace;font-size:11px;text-transform:uppercase;
  letter-spacing:0.12em;color:var(--visa-red);margin-bottom:12px;
  border-bottom:1px solid var(--line);padding-bottom:6px;
}
.nfl-division-group{margin-bottom:16px;}
.nfl-div-header{
  font-family:'IBM Plex Mono',monospace;font-size:9px;text-transform:uppercase;
  letter-spacing:0.1em;color:var(--ink-soft);margin-bottom:8px;
}
.nfl-team{
  display:flex;align-items:center;gap:8px;
  padding:9px 12px;border:1.5px solid var(--line);
  background:rgba(255,255,255,0.35);cursor:pointer;
  transition:border-color .12s,background .12s;
  margin-bottom:6px;font-size:13px;
}
.nfl-team:hover{border-color:var(--ink);}
.nfl-team.selected{border-color:var(--visa-red);background:rgba(165,52,43,0.1);}
.nfl-team-conf{
  font-family:'IBM Plex Mono',monospace;font-size:9px;color:var(--ink-soft);
  text-transform:uppercase;letter-spacing:0.06em;flex:none;width:24px;
}
.nfl-team.selected .nfl-team-conf{color:var(--visa-red);}
.nfl-team-name{font-weight:500;}
.nfl-skip{
  margin-top:12px;padding:12px 16px;border:1.5px dashed var(--line);
  text-align:center;font-size:13px;color:var(--ink-soft);cursor:pointer;
  transition:border-color .12s,color .12s;
  grid-column:1 / -1;
}
.nfl-skip:hover{border-color:var(--ink);color:var(--ink);}
.nfl-skip.selected{border-color:var(--visa-red);color:var(--visa-red);border-style:solid;background:rgba(165,52,43,0.07);}

/* ── Floating share bar ── */
.share-bar{
  position:fixed;bottom:0;left:0;right:0;
  background:var(--ink);color:var(--paper);
  display:flex;align-items:center;gap:12px;
  padding:10px 16px;z-index:200;
  border-top:2px solid var(--gold);
  box-shadow:0 -4px 16px rgba(0,0,0,0.12);
}
.share-bar-crest{
  width:36px;height:36px;border-radius:50%;flex:none;
  display:flex;align-items:center;justify-content:center;
  font-family:'Fraunces',serif;font-weight:700;font-size:13px;color:#fff;
  border:2px solid rgba(255,255,255,0.3);
}
.share-bar-info{flex:1;min-width:0;overflow:hidden;}
.share-bar-name{
  font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.share-bar-pct{
  font-family:'IBM Plex Mono',monospace;font-size:10px;color:var(--gold);
  text-transform:uppercase;letter-spacing:0.06em;
}
.share-bar-btn{
  font-family:'IBM Plex Mono',monospace;font-size:11px;text-transform:uppercase;
  letter-spacing:0.06em;padding:8px 16px;border-radius:2px;
  border:1.5px solid var(--paper);background:var(--paper);color:var(--ink);
  cursor:pointer;flex:none;transition:transform .12s ease;
}
.share-bar-btn:hover{transform:translateY(-1px);}
.share-bar-x{
  background:none;border:none;color:var(--paper);font-size:20px;
  cursor:pointer;opacity:0.6;flex:none;padding:4px 8px;
}
.share-bar-x:hover{opacity:1;}

/* Desktop: bottom-right pill */
@media(min-width:769px){
  .share-bar{
    bottom:20px;right:20px;left:auto;
    border-radius:40px;padding:8px 12px 8px 16px;
    border:1.5px solid var(--gold);
    box-shadow:0 4px 20px rgba(0,0,0,0.2);
    max-width:380px;
  }
  .share-bar-crest{width:32px;height:32px;font-size:11px;}
  .share-bar-name{font-size:12px;}
  .share-bar-pct{font-size:9px;}
  .share-bar-btn{padding:6px 14px;font-size:10px;}
}

/* ── Toast notification ── */
.toast{
  position:fixed;bottom:80px;left:50%;transform:translateX(-50%) translateY(20px);
  background:var(--ink);color:var(--paper);
  padding:10px 20px;border-radius:4px;
  font-family:'IBM Plex Mono',monospace;font-size:12px;
  letter-spacing:0.06em;text-transform:uppercase;
  z-index:300;opacity:0;pointer-events:none;
  transition:opacity .2s ease,transform .2s ease;
  border:1px solid var(--gold);
}
.toast.show{
  opacity:1;transform:translateX(-50%) translateY(0);
}
@media(min-width:769px){
  .toast{bottom:80px;}
}

/* ── Shared link CTA ── */
.shared-cta{
  margin-top:32px;padding:24px;text-align:center;
  border:1.5px dashed var(--line);background:rgba(255,255,255,0.28);
}
.shared-cta .btn{margin:0 auto;}

/* ── NFL grid responsive ── */
@media(max-width:640px){
  .nfl-grid{grid-template-columns:1fr;gap:12px;}
  .nfl-team{padding:10px 12px;font-size:12px;}
  .nfl-conf-header{font-size:10px;margin-bottom:8px;}
  .nfl-div-header{font-size:8px;margin-bottom:6px;}
  .nfl-team-conf{width:20px;font-size:8px;}
  /* Share bar: full-width bottom on mobile */
  .share-bar{padding:8px 12px;}
  .share-bar-crest{width:32px;height:32px;font-size:11px;}
  .share-bar-name{font-size:12px;}
  .share-bar-pct{font-size:9px;}
  .share-bar-btn{padding:7px 12px;font-size:10px;}
  .share-bar-x{font-size:18px;padding:2px 6px;}
  .toast{bottom:72px;font-size:10px;padding:8px 16px;}
}

@media(min-width:641px) and (max-width:768px){
  .nfl-grid{grid-template-columns:1fr 1fr;gap:16px;}
}