/* =========================================================
   WORLD CUP AI 2026 - NEON MUNDIAL
   Retrofuturistic synthwave UI
   ========================================================= */
@import url('https://fonts.googleapis.com/css2?family=Orbitron:wght@500;700;900&display=swap');

:root {
  --pink: #ff2d78;
  --cyan: #7df9ff;
  --gold: #ffe14d;
  --green: #9dff57;
  --purple: #b08bff;
  --bg0: #0d0221;
  --bg1: #190b33;
}

* { margin: 0; padding: 0; box-sizing: border-box; }

html, body { height: 100%; }
body {
  background: var(--bg0);
  color: #fff;
  font-family: 'Orbitron', 'Segoe UI', Arial, sans-serif;
  overflow: hidden;
  user-select: none;
}

/* ---------- atmosphere layers ---------- */
#bg-grad {
  position: fixed; inset: 0; z-index: 0;
  background: linear-gradient(180deg, #0d0221 0%, #1c0b3a 55%, #3d1163 100%);
}
#bg-sun {
  position: fixed; left: 50%; top: 64%; transform: translate(-50%, -50%);
  width: 480px; height: 480px; border-radius: 50%; z-index: 0;
  background: linear-gradient(180deg, #ffe14d 0%, #ff7b2d 45%, #ff2d78 100%);
  opacity: 0.16; filter: blur(2px);
  -webkit-mask-image: repeating-linear-gradient(180deg, #000 0 26px, transparent 26px 38px);
  mask-image: repeating-linear-gradient(180deg, #000 0 26px, transparent 26px 38px);
}
#bg-grid {
  position: fixed; left: -50%; right: -50%; bottom: -10%; height: 55%; z-index: 0;
  background:
    repeating-linear-gradient(90deg, rgba(125,249,255,0.16) 0 2px, transparent 2px 80px),
    repeating-linear-gradient(0deg, rgba(125,249,255,0.16) 0 2px, transparent 2px 60px);
  transform: perspective(420px) rotateX(62deg);
  transform-origin: center top;
  animation: gridmove 3.2s linear infinite;
}
@keyframes gridmove { from { background-position: 0 0, 0 0; } to { background-position: 0 0, 0 60px; } }

#scanlines {
  position: fixed; inset: 0; z-index: 50; pointer-events: none;
  background: repeating-linear-gradient(180deg, rgba(0,0,0,0.16) 0 2px, transparent 2px 4px);
  mix-blend-mode: multiply;
}
#vignette {
  position: fixed; inset: 0; z-index: 51; pointer-events: none;
  background: radial-gradient(ellipse at center, transparent 55%, rgba(5,0,15,0.75) 100%);
}
#confetti { position: fixed; inset: 0; z-index: 60; pointer-events: none; }

/* VHS glitch when a goal lands */
body.glitching #app { animation: glitch 0.12s steps(2) 7; }
@keyframes glitch {
  0%   { transform: translate(0); filter: none; }
  25%  { transform: translate(-6px, 2px) skewX(2deg); filter: hue-rotate(60deg) saturate(2); }
  50%  { transform: translate(5px, -3px); filter: hue-rotate(-40deg); }
  75%  { transform: translate(-3px, 1px) skewX(-3deg); filter: saturate(3); }
  100% { transform: translate(0); filter: none; }
}

/* ---------- app & screens ---------- */
#app { position: relative; z-index: 10; height: 100vh; display: flex; flex-direction: column; }
.screen {
  display: none; flex: 1; min-height: 0;
  flex-direction: column; align-items: center; justify-content: flex-start;
  padding: 28px 36px; overflow-y: auto;
}
.screen.active { display: flex; }
.screen::-webkit-scrollbar { width: 10px; }
.screen::-webkit-scrollbar-thumb { background: rgba(125,249,255,0.3); border-radius: 5px; }

/* ---------- typography ---------- */
.chrome {
  font-weight: 900;
  background: linear-gradient(180deg, #fdfcfb 0%, #c9d6ff 38%, #5b6bbf 50%, #e6e9f0 52%, #8fa4ff 75%, #fdfcfb 100%);
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent; color: transparent;
  filter: drop-shadow(0 2px 0 rgba(255,45,120,0.85)) drop-shadow(0 0 22px rgba(125,249,255,0.45));
  letter-spacing: 0.06em;
}
.neon-pink { color: var(--pink); text-shadow: 0 0 18px var(--pink); }
.neon-cyan { color: var(--cyan); text-shadow: 0 0 18px var(--cyan); }
.neon-gold { color: var(--gold); text-shadow: 0 0 18px var(--gold); }

h1.title-main { font-size: clamp(40px, 7vw, 86px); text-align: center; line-height: 1.05; }
.title-sub {
  margin-top: 10px; font-size: clamp(14px, 2vw, 22px); letter-spacing: 0.55em;
  color: var(--cyan); text-shadow: 0 0 14px var(--cyan); text-align: center;
}
.title-stars { margin-top: 26px; font-size: clamp(13px, 1.6vw, 18px); color: var(--gold); text-shadow: 0 0 12px var(--gold); text-align:center; }
.press-start { margin-top: 60px; font-size: 18px; color: #fff; animation: blink 1.1s steps(2) infinite; letter-spacing: 0.2em; }
@keyframes blink { 50% { opacity: 0.15; } }

h2.screen-title { font-size: clamp(24px, 3.4vw, 40px); margin-bottom: 18px; letter-spacing: 0.12em; }

/* ---------- buttons ---------- */
.btn {
  font-family: inherit; font-weight: 700; letter-spacing: 0.14em;
  background: rgba(13,2,33,0.7); color: var(--cyan);
  border: 2px solid var(--cyan); border-radius: 4px;
  padding: 14px 34px; margin: 8px; font-size: 17px; cursor: pointer;
  text-shadow: 0 0 10px var(--cyan);
  box-shadow: 0 0 14px rgba(125,249,255,0.25), inset 0 0 14px rgba(125,249,255,0.08);
  transition: transform 0.08s, box-shadow 0.15s;
}
.btn:hover { transform: translateY(-2px) scale(1.02); box-shadow: 0 0 26px rgba(125,249,255,0.6); }
.btn:focus {
  outline: none;
  border-color: var(--gold); color: var(--gold);
  text-shadow: 0 0 10px var(--gold);
  box-shadow: 0 0 26px rgba(255,225,77,0.6), inset 0 0 16px rgba(255,225,77,0.12);
  background: rgba(255,225,77,0.08);
}
.btn.primary { color: var(--pink); border-color: var(--pink); text-shadow: 0 0 10px var(--pink); box-shadow: 0 0 14px rgba(255,45,120,0.35); }
.btn.primary:hover { box-shadow: 0 0 30px rgba(255,45,120,0.75); }
.btn.ghost { opacity: 0.65; font-size: 14px; padding: 10px 22px; }
.menu-col { display: flex; flex-direction: column; align-items: stretch; margin-top: 34px; min-width: 380px; }
.menu-col .btn { font-size: 20px; padding: 18px 40px; }

.topbar {
  position: fixed; top: 14px; right: 18px; z-index: 40; display: flex; gap: 8px;
}
.topbar button {
  background: rgba(13,2,33,0.7); border: 1px solid rgba(125,249,255,0.45); color: #fff;
  border-radius: 4px; font-size: 18px; padding: 6px 12px; cursor: pointer;
}

/* ---------- team select ---------- */
#teams-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(210px, 1fr));
  gap: 10px; width: min(1240px, 96vw);
}
.group-head {
  grid-column: 1 / -1; margin-top: 14px;
  color: var(--gold); text-shadow: 0 0 12px var(--gold);
  font-weight: 900; letter-spacing: 0.3em; font-size: 15px;
  border-bottom: 1px solid rgba(255,225,77,0.35); padding-bottom: 4px;
}
.team-card {
  display: flex; gap: 12px; align-items: center; text-align: left;
  background: rgba(20,8,52,0.75); border: 1.5px solid rgba(125,249,255,0.35);
  border-radius: 6px; padding: 10px 12px; cursor: pointer; color: #fff;
  font-family: inherit; transition: transform 0.08s, border-color 0.12s, box-shadow 0.12s;
}
.team-card:hover { transform: translateY(-2px); border-color: var(--pink); box-shadow: 0 0 18px rgba(255,45,120,0.45); }
.team-card.icon-team { border-color: var(--gold); box-shadow: 0 0 16px rgba(255,225,77,0.35); }
.flag { border-radius: 3px; box-shadow: 0 0 8px rgba(0,0,0,0.6), 0 0 10px rgba(125,249,255,0.25); flex-shrink: 0; }
.tc-info { min-width: 0; }
/* break-word wraps multi-word names at spaces first (only splits a single long
   word when it truly can't fit), nicer than anywhere's mid-word breaks */
.tc-name { font-weight: 700; font-size: 14px; overflow-wrap: break-word; }
.tc-name .badge { color: var(--gold); font-size: 11px; text-shadow: 0 0 8px var(--gold); }
.tc-stars { color: var(--gold); font-size: 12px; }
.tc-coach { color: rgba(255,255,255,0.6); font-size: 10.5px; margin-top: 2px; }
.tc-star { color: var(--cyan); font-size: 11px; }

/* ---------- hub ---------- */
.hub-wrap { display: flex; gap: 40px; align-items: flex-start; flex-wrap: wrap; justify-content: center; }
#hub-table {
  border-collapse: collapse; background: rgba(20,8,52,0.75);
  border: 1.5px solid rgba(125,249,255,0.35); border-radius: 6px; overflow: hidden;
}
#hub-table th, #hub-table td { padding: 9px 13px; font-size: 14px; text-align: center; }
#hub-table th { color: var(--cyan); font-size: 11px; letter-spacing: 0.15em; border-bottom: 1px solid rgba(125,249,255,0.35); }
#hub-table .tname { display: flex; align-items: center; gap: 8px; text-align: left; }
#hub-table tr.me { background: rgba(255,45,120,0.16); box-shadow: inset 3px 0 0 var(--pink); }
#hub-table .pts { color: var(--gold); font-weight: 900; }
#hub-fixtures { display: flex; flex-direction: column; gap: 8px; min-width: 270px; }
.fixture {
  display: flex; justify-content: space-between; gap: 20px;
  background: rgba(20,8,52,0.75); border: 1px solid rgba(125,249,255,0.25);
  padding: 10px 16px; border-radius: 5px; font-size: 14px;
}
.fixture.next { border-color: var(--pink); box-shadow: 0 0 14px rgba(255,45,120,0.4); }
.fixture.done { opacity: 0.65; }
#hub-ticker {
  margin-top: 22px; max-width: 90vw; white-space: nowrap; overflow: hidden;
  color: var(--green); font-size: 13px; letter-spacing: 0.1em;
  border-top: 1px solid rgba(157,255,87,0.3); border-bottom: 1px solid rgba(157,255,87,0.3);
  padding: 7px 0; text-shadow: 0 0 8px rgba(157,255,87,0.7);
}

/* ---------- bracket ---------- */
#bracket-box { display: flex; gap: 18px; align-items: center; max-width: 96vw; overflow-x: auto; padding: 10px; }
.br-col { display: flex; flex-direction: column; gap: 7px; }
.br-col h3 { color: var(--cyan); font-size: 11px; letter-spacing: 0.2em; text-align: center; margin-bottom: 6px; }
.br-match {
  background: rgba(20,8,52,0.8); border: 1px solid rgba(125,249,255,0.3);
  border-radius: 4px; padding: 6px 10px; font-size: 12.5px; white-space: nowrap;
  display: flex; gap: 8px; justify-content: space-between; min-width: 150px;
}
.br-match i { color: rgba(255,255,255,0.55); font-style: normal; font-size: 11px; }
.br-match .w { color: var(--green); text-shadow: 0 0 8px rgba(157,255,87,0.8); font-weight: 900; }
.br-match.mine { border-color: var(--pink); box-shadow: 0 0 14px rgba(255,45,120,0.45); }

/* ---------- match intro ---------- */
.intro-vs { display: flex; align-items: center; gap: 60px; margin-top: 30px; flex-wrap: wrap; justify-content: center; }
.intro-team { text-align: center; display: flex; flex-direction: column; align-items: center; gap: 8px; max-width: 360px; }
.intro-team h2 { font-size: 30px; letter-spacing: 0.1em; }
.intro-team .stars { color: var(--gold); }
.intro-team .coach { color: rgba(255,255,255,0.65); font-size: 12px; letter-spacing: 0.15em; }
.intro-team .hero { color: var(--cyan); font-size: 14px; text-shadow: 0 0 10px var(--cyan); }
.vs-flash { font-size: 70px; font-weight: 900; color: var(--pink); text-shadow: 0 0 30px var(--pink); animation: vspulse 0.8s ease-in-out infinite alternate; }
.lineup {
  list-style: none; margin-top: 12px; width: 100%; max-width: 320px;
  background: rgba(13,2,33,0.7); border: 1px solid rgba(125,249,255,0.3);
  border-radius: 6px; padding: 10px 14px; text-align: left;
}
.lineup li { display: flex; align-items: center; gap: 8px; font-size: 12.5px; padding: 3px 0; }
.lineup .lu-pos { color: var(--cyan); width: 26px; font-size: 10.5px; flex-shrink: 0; }
.lineup .lu-name { flex: 1; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.lineup .lu-skill { color: var(--gold); font-weight: 700; }
.lineup .lu-sig { font-size: 11px; }
.lineup li.sub { opacity: 0.5; }
.lineup li.lu-legend .lu-name { color: var(--gold); text-shadow: 0 0 8px rgba(255,225,77,0.7); }
.lineup .lu-bench {
  color: rgba(255,255,255,0.45); font-size: 10px; letter-spacing: 0.25em;
  border-top: 1px solid rgba(125,249,255,0.2); margin-top: 5px; padding-top: 7px;
}

/* tactics editor */
.lineup.editable button {
  display: flex; align-items: center; gap: 8px; width: 100%;
  background: transparent; border: 1px solid transparent; border-radius: 4px;
  color: #fff; font-family: inherit; font-size: 12.5px; padding: 4px 6px;
  cursor: pointer; text-align: left;
}
.lineup.editable button:hover { border-color: rgba(125,249,255,0.5); background: rgba(125,249,255,0.07); }
.lineup.editable button.lu-sel {
  border-color: var(--gold); background: rgba(255,225,77,0.12);
  box-shadow: 0 0 12px rgba(255,225,77,0.45);
}
.lineup.editable button.sub { opacity: 0.55; }
.form-row { display: flex; gap: 6px; margin-top: 10px; }
.form-btn {
  font-family: inherit; font-size: 10.5px; font-weight: 700; letter-spacing: 0.08em;
  background: rgba(13,2,33,0.7); color: rgba(255,255,255,0.6);
  border: 1px solid rgba(125,249,255,0.35); border-radius: 4px;
  padding: 6px 10px; cursor: pointer;
}
.form-btn.on {
  color: var(--gold); border-color: var(--gold);
  box-shadow: 0 0 12px rgba(255,225,77,0.4); text-shadow: 0 0 8px rgba(255,225,77,0.7);
}

/* commentary ticker */
#commentary {
  min-height: 26px; margin-top: 8px; max-width: 92vw; text-align: center;
  font-size: 16px; font-weight: 700; letter-spacing: 0.08em;
  color: var(--gold); text-shadow: 0 0 12px rgba(255,225,77,0.7);
  opacity: 0; transition: opacity 0.25s;
}
#commentary.show { opacity: 1; animation: commentpop 0.3s cubic-bezier(0.2, 1.8, 0.4, 1); }
@keyframes commentpop { from { transform: scale(0.85); } to { transform: scale(1); } }

/* controls remapping */
#controls-list { display: flex; flex-direction: column; gap: 8px; width: min(460px, 94vw); }
.ctl-row {
  display: flex; justify-content: space-between; align-items: center; gap: 16px;
  background: rgba(20,8,52,0.75); border: 1px solid rgba(125,249,255,0.25);
  border-radius: 5px; padding: 10px 16px;
}
.ctl-row.fixed { opacity: 0.55; }
.ctl-label { font-size: 13.5px; letter-spacing: 0.1em; flex: 1; min-width: 0; text-align: left; overflow-wrap: anywhere; }
.ctl-key { flex-shrink: 0; }
.ctl-key {
  font-family: inherit; font-weight: 900; font-size: 14px; letter-spacing: 0.08em;
  background: rgba(13,2,33,0.8); color: var(--cyan);
  border: 1.5px solid var(--cyan); border-radius: 4px;
  min-width: 64px; padding: 7px 14px; cursor: pointer;
  text-shadow: 0 0 8px rgba(125,249,255,0.7);
}
.ctl-key:hover { border-color: var(--gold); color: var(--gold); }
.ctl-key.waiting {
  border-color: var(--pink); color: var(--pink);
  animation: blink 0.7s steps(2) infinite;
}
.ctl-key.static { border-style: dashed; cursor: default; }

/* difficulty picker */
#difficulty-content { display: flex; flex-direction: column; align-items: center; gap: 18px; }
.diff-row { display: flex; gap: 20px; flex-wrap: wrap; justify-content: center; }
.diff-card {
  --dc: #7df9ff;
  width: 230px; padding: 24px 18px; border-radius: 8px; cursor: pointer;
  background: rgba(16,6,38,0.85); color: #fff; font-family: inherit;
  border: 2px solid rgba(255,255,255,0.2); transition: transform 0.1s, box-shadow 0.15s;
}
.diff-card h3 { font-size: 24px; letter-spacing: 0.14em; color: var(--dc); text-shadow: 0 0 12px var(--dc); }
.diff-card p { margin-top: 8px; font-size: 12px; color: rgba(255,255,255,0.65); line-height: 1.5; }
.diff-card.on { border-color: var(--dc); box-shadow: 0 0 26px var(--dc); transform: scale(1.05); }
.btn.chaos-on { color: var(--green); border-color: var(--green); text-shadow: 0 0 10px var(--green); box-shadow: 0 0 18px rgba(157,255,87,0.5); opacity: 1; }

/* awards */
#awards-content { display: flex; flex-direction: column; align-items: center; gap: 18px; max-width: 1100px; }
.aw-champ {
  display: flex; align-items: center; gap: 18px;
  background: linear-gradient(160deg, rgba(80,52,10,0.85), rgba(40,20,60,0.9));
  border: 2px solid var(--gold); border-radius: 10px; padding: 16px 30px;
  box-shadow: 0 0 26px rgba(255,225,77,0.45);
}
.aw-champ h3 { color: var(--gold); font-size: 14px; letter-spacing: 0.25em; text-shadow: 0 0 10px var(--gold); }
.aw-champ p { font-size: 24px; font-weight: 900; margin-top: 4px; }
.aw-row { display: flex; gap: 14px; flex-wrap: wrap; justify-content: center; }
.aw-card {
  display: flex; flex-direction: column; align-items: center; gap: 6px;
  background: rgba(20,8,52,0.8); border: 1.5px solid rgba(125,249,255,0.35);
  border-radius: 8px; padding: 14px 18px; min-width: 180px;
}
.aw-card.gold { border-color: var(--gold); box-shadow: 0 0 20px rgba(255,225,77,0.45); }
.aw-card.mini { min-width: 130px; padding: 10px 12px; }
.aw-medal { font-size: 13px; font-weight: 900; letter-spacing: 0.1em; color: var(--gold); }
.aw-name { font-weight: 700; font-size: 14px; }
.aw-sub { font-size: 11px; color: rgba(255,255,255,0.6); }
.aw-h { font-size: 16px; letter-spacing: 0.2em; margin-top: 8px; }

/* icon showdown */
#showdown-pick { display: flex; gap: 40px; flex-wrap: wrap; justify-content: center; }
.icon-pick {
  position: relative; width: 280px; padding: 30px 22px 26px;
  display: flex; flex-direction: column; align-items: center; gap: 12px;
  background: linear-gradient(165deg, rgba(60,40,8,0.85), rgba(30,16,50,0.92) 60%);
  border: 2px solid var(--gold); border-radius: 10px;
  color: #fff; font-family: inherit; cursor: pointer;
  box-shadow: 0 0 24px rgba(255,225,77,0.3);
  transition: transform 0.1s, box-shadow 0.15s;
}
.icon-pick:hover { transform: translateY(-4px) scale(1.03); box-shadow: 0 0 44px rgba(255,225,77,0.7); }
.icon-pick h3 { font-size: 19px; letter-spacing: 0.08em; color: var(--gold); text-shadow: 0 0 10px rgba(255,225,77,0.7); }
.icon-pick p { font-size: 11.5px; color: rgba(255,255,255,0.7); letter-spacing: 0.12em; }
.ip-badge { font-size: 44px; filter: drop-shadow(0 0 14px rgba(255,225,77,0.8)); }
.btn.gold { color: var(--gold); border-color: var(--gold); text-shadow: 0 0 10px var(--gold); box-shadow: 0 0 14px rgba(255,225,77,0.3); }
.btn.gold:hover { box-shadow: 0 0 28px rgba(255,225,77,0.7); }
@keyframes vspulse { from { transform: scale(1); } to { transform: scale(1.18); } }

/* ---------- match screen ---------- */
#scr-match { padding: 8px; justify-content: center; align-items: center; }
#game {
  width: min(96vw, calc(92vh * 1.594));
  max-height: 92vh;
  border: 2px solid rgba(125,249,255,0.4);
  border-radius: 6px;
  box-shadow: 0 0 40px rgba(125,249,255,0.25);
  background: #0d0221;
}
#match-hint { margin-top: 6px; font-size: 11.5px; color: rgba(255,255,255,0.55); letter-spacing: 0.12em; }

/* ---------- result ---------- */
#result-head { font-size: 64px; font-weight: 900; letter-spacing: 0.1em; }
#result-score { font-size: 38px; margin: 16px 0 4px; color: #fff; text-shadow: 0 0 14px rgba(255,255,255,0.6); }
#result-label { color: rgba(255,255,255,0.6); letter-spacing: 0.2em; font-size: 13px; margin-bottom: 14px; }
#result-scorers { list-style: none; color: var(--cyan); font-size: 14px; line-height: 1.9; text-align: center; }

/* ---------- legends ---------- */
#album-grid, #voices-grid, .draft-row {
  display: flex; flex-wrap: wrap; gap: 16px; justify-content: center; max-width: 1200px;
}
.voices-section { flex-basis: 100%; text-align: center; font-weight: 900; letter-spacing: 0.16em;
  font-size: 13px; color: var(--cyan); text-shadow: 0 0 10px rgba(125,249,255,0.7); margin: 8px 0 2px; }
.voice-tag { font-size: 11px; letter-spacing: 0.08em; color: rgba(255,255,255,0.8); }
.voice-play { margin-top: 8px; font-size: 12px; padding: 7px 14px; }
#voices-count { margin-top: 16px; color: var(--cyan); letter-spacing: 0.12em; font-size: 12px; text-align: center; }
.legend-card {
  width: 200px; min-height: 230px; border-radius: 8px; padding: 16px 12px;
  display: flex; flex-direction: column; align-items: center; gap: 7px; text-align: center;
  font-family: inherit; color: #fff; cursor: default;
}
.legend-card.small { width: 170px; min-height: 200px; cursor: pointer; }
.legend-card.unlocked {
  background: linear-gradient(160deg, rgba(80,52,10,0.85), rgba(40,20,60,0.9) 55%, rgba(120,80,15,0.7));
  border: 2px solid var(--gold);
  box-shadow: 0 0 22px rgba(255,225,77,0.4), inset 0 0 30px rgba(255,225,77,0.12);
  position: relative; overflow: hidden;
}
.legend-card.unlocked::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(115deg, transparent 30%, rgba(255,255,255,0.22) 48%, transparent 60%);
  animation: holo 3.2s linear infinite;
}
@keyframes holo { from { transform: translateX(-100%); } to { transform: translateX(100%); } }
.legend-card.locked {
  background: rgba(12,5,28,0.85); border: 2px dashed rgba(125,249,255,0.25);
  color: rgba(255,255,255,0.45);
}
.legend-card.picked { outline: 3px solid var(--green); box-shadow: 0 0 26px rgba(157,255,87,0.6); }
.legend-card.pop { animation: pop 0.5s cubic-bezier(0.2, 2.4, 0.4, 1); }
@keyframes pop { from { transform: scale(0.2) rotate(-6deg); } to { transform: scale(1); } }
.lg-mystery { font-size: 64px; font-weight: 900; color: rgba(125,249,255,0.4); text-shadow: 0 0 16px rgba(125,249,255,0.4); }
.lg-name { font-weight: 900; font-size: 16px; color: var(--gold); text-shadow: 0 0 10px rgba(255,225,77,0.7); }
.legend-card.locked .lg-name { color: rgba(255,255,255,0.5); text-shadow: none; }
.lg-country, .lg-pos { font-size: 11px; color: rgba(255,255,255,0.75); }
.lg-sig { font-size: 12px; color: var(--cyan); text-shadow: 0 0 8px rgba(125,249,255,0.7); }
.lg-quote { font-size: 12px; color: var(--cyan); font-style: italic; line-height: 1.5; text-shadow: 0 0 12px rgba(125,249,255,0.9), 0 0 4px rgba(125,249,255,0.9); }
.lg-open { margin-top: 8px; font-size: 10px; letter-spacing: 0.14em; color: var(--gold); opacity: 0.85; }
/* legend detail screen */
#legend-detail { display: flex; flex-direction: column; align-items: center; text-align: center; width: min(94vw, 620px); margin: 0 auto; }
#legend-detail .face-portrait { width: 140px; height: 140px; margin: 10px auto 4px; }
.lgd-name { font-size: clamp(26px, 5vw, 42px); letter-spacing: 0.1em; margin: 6px 0 2px; }
.lgd-meta { color: var(--cyan); letter-spacing: 0.1em; font-size: 14px; text-shadow: 0 0 8px rgba(125,249,255,0.6); margin-bottom: 14px; }
.lgd-honours { background: rgba(255,225,77,0.08); border: 1px solid rgba(255,225,77,0.4); border-radius: 10px; padding: 12px 18px; margin: 0 auto 14px; max-width: 460px; }
.lgd-h-title { color: var(--gold); letter-spacing: 0.16em; font-size: 12px; margin-bottom: 6px; text-shadow: 0 0 8px rgba(255,225,77,0.6); }
.lgd-h { color: #fff; font-size: 13.5px; line-height: 1.7; }
.lgd-bio { color: rgba(255,255,255,0.86); font-size: 14px; line-height: 1.6; max-width: 520px; margin: 0 auto 12px; }
.lgd-funny { color: var(--gold); font-size: 13.5px; line-height: 1.5; max-width: 520px; margin: 0 auto 16px; }
.lgd-quote { font-size: clamp(18px, 3vw, 24px); font-style: italic; color: var(--cyan); max-width: 540px; margin: 0 auto;
  text-shadow: 0 0 18px rgba(125,249,255,0.9), 0 0 6px rgba(125,249,255,0.9); animation: quotePop 0.5s cubic-bezier(0.2,1.7,0.4,1) both; }
/* the unlock modal quote pops in, bigger + glowing */
#modal-inner .lg-quote { font-size: 15px; color: var(--cyan); text-shadow: 0 0 16px rgba(125,249,255,0.85); animation: quotePop 0.5s cubic-bezier(0.2,1.7,0.4,1) both; }
@keyframes quotePop { 0% { opacity: 0; transform: scale(0.7); } 100% { opacity: 1; transform: scale(1); } }
.lg-hint { font-size: 11.5px; color: var(--pink); text-shadow: 0 0 8px rgba(255,45,120,0.6); line-height: 1.5; }
.legend-card .lg-add { margin-top: 12px; font-size: 12px; padding: 8px 14px; letter-spacing: 0.08em; }
.legend-card .lg-add.added { color: var(--green); border-color: var(--green); text-shadow: 0 0 10px var(--green); box-shadow: 0 0 14px rgba(157,255,87,0.4); }
.legend-card .lg-add:disabled { opacity: 0.55; cursor: default; }
.modal-hint { color: rgba(255,255,255,0.62); font-size: 12.5px; letter-spacing: 0.06em; margin: 4px auto 2px; max-width: 540px; line-height: 1.5; }
#album-count { margin-top: 18px; color: var(--gold); letter-spacing: 0.18em; font-size: 14px; }
.album-hint { color: rgba(125,249,255,0.7); font-size: 12px; letter-spacing: 0.08em; margin: -6px 0 10px; }

.draft-head { display: flex; gap: 18px; align-items: center; margin-bottom: 22px; }
.draft-head p { color: rgba(255,255,255,0.65); font-size: 13px; margin-top: 6px; }

/* ---------- trophies ---------- */
#trophy-cups { font-size: 54px; margin: 12px 0 20px; min-height: 70px; }
#trophy-stats, #trophy-history { list-style: none; font-size: 16px; line-height: 2.1; text-align: center; }
#trophy-stats b { color: var(--gold); }
#trophy-history { margin-top: 14px; color: rgba(255,255,255,0.7); font-size: 13px; }

/* ---------- help ---------- */
.help-grid { display: grid; grid-template-columns: auto auto; gap: 10px 30px; font-size: 15px; margin-top: 10px; }
.help-grid b { color: var(--cyan); text-shadow: 0 0 8px rgba(125,249,255,0.6); }
.help-note { margin-top: 26px; max-width: 640px; text-align: center; color: rgba(255,255,255,0.65); font-size: 13px; line-height: 1.8; }

/* how-to overlay grid (first-run, inside #modal) */
.howto-grid { display: grid; grid-template-columns: auto 1fr; gap: 9px 18px; align-items: center; text-align: left; max-width: 460px; }
.howto-grid b { justify-self: start; color: var(--gold); font-size: 13px; letter-spacing: 0.06em; padding: 4px 10px; white-space: nowrap;
  background: rgba(255,225,77,0.1); border: 1px solid rgba(255,225,77,0.45); border-radius: 6px; }
.howto-grid span { color: rgba(255,255,255,0.85); font-size: 13.5px; letter-spacing: 0.03em; }

/* ---------- modal ---------- */
/* z-index must sit ABOVE the touch HUD (#touchpad z-80) so in-match overlays
   (e.g. the first-run how-to) aren't covered by on-screen buttons on phones */
#modal {
  position: fixed; inset: 0; z-index: 90; display: none;
  align-items: center; justify-content: center;
  background: rgba(5,0,16,0.85); backdrop-filter: blur(3px);
}
#modal.open { display: flex; }
#modal-inner {
  background: rgba(18,6,40,0.95); border: 2px solid var(--gold);
  box-shadow: 0 0 50px rgba(255,225,77,0.4);
  border-radius: 10px; padding: 34px 44px; text-align: center;
  display: flex; flex-direction: column; align-items: center; gap: 20px;
  max-width: 90vw; max-height: 90vh; overflow-y: auto;
}
#modal-inner h2 { font-size: 34px; letter-spacing: 0.14em; }

/* ---------- elimination / champion ---------- */
#scr-elim, #scr-champion { justify-content: center; }
#elim-text { font-size: 40px; color: var(--pink); text-shadow: 0 0 22px var(--pink); text-align: center; }
#elim-team { color: rgba(255,255,255,0.7); letter-spacing: 0.3em; margin-top: 12px; }
#champ-team { display: flex; flex-direction: column; align-items: center; gap: 14px; text-align: center; }
#champ-team h2 { font-size: 46px; }
#champ-team p { color: var(--gold); letter-spacing: 0.2em; font-size: 14px; text-shadow: 0 0 12px var(--gold); }
.champ-cup { font-size: 110px; filter: drop-shadow(0 0 30px rgba(255,225,77,0.8)); animation: cupfloat 2.4s ease-in-out infinite alternate; }
@keyframes cupfloat { from { transform: translateY(0) rotate(-2deg); } to { transform: translateY(-16px) rotate(2deg); } }

/* champion pitch celebration: hero parades the cup, goat runs, Messi/Ronaldo gag */
#champ-celebration { position: relative; width: min(96vw, 640px); height: 220px; margin: 16px auto; overflow: hidden;
  border: 2px solid rgba(125,249,255,0.35); border-radius: 14px; pointer-events: none;
  background:
    radial-gradient(circle at 50% 66%, transparent 30px, rgba(125,249,255,0.10) 31px, transparent 33px),
    linear-gradient(180deg, rgba(13,40,20,0.55), rgba(8,24,14,0.75));
  box-shadow: inset 0 0 30px rgba(0,0,0,0.5); }
#champ-celebration::before { content: ""; position: absolute; left: 50%; top: 38%; bottom: 8%; width: 2px; transform: translateX(-50%); background: rgba(125,249,255,0.25); }
.cel-char { position: absolute; left: 0; top: 0; width: 46px; height: 46px; will-change: transform; }
.cel-face { width: 46px; height: 46px; border-radius: 50%; object-fit: cover; border: 2px solid var(--cyan); box-shadow: 0 0 12px rgba(125,249,255,0.6); background: #0d0221; }
.cel-emoji { font-size: 34px; line-height: 46px; display: block; text-align: center; filter: drop-shadow(0 0 6px rgba(255,255,255,0.4)); }
.cel-cup { position: absolute; top: -16px; left: 50%; transform: translateX(-50%); font-size: 24px; filter: drop-shadow(0 0 8px rgba(255,225,77,0.9)); }
.cel-leash { position: absolute; left: 0; top: 0; width: 100%; height: 100%; pointer-events: none; filter: drop-shadow(0 0 4px rgba(125,249,255,0.7)); }
/* pinned top-center + wraps, so long lines stay readable and never spill off the box */
.cel-bubble { position: absolute; left: 50%; top: 10px; transform: translateX(-50%); max-width: calc(100% - 28px); width: max-content;
  padding: 6px 12px; font-size: 13px; font-weight: 800; line-height: 1.3; text-align: center; white-space: normal;
  color: var(--gold); background: rgba(11,2,28,0.94); border: 1.5px solid var(--gold); border-radius: 10px;
  text-shadow: 0 0 8px rgba(255,225,77,0.7); box-shadow: 0 0 16px rgba(255,225,77,0.4); z-index: 500; }

.center { justify-content: center; }

/* ========== touch controls (mobile) ========== */
html.touch body { overscroll-behavior: none; }
html.touch #match-hint { display: none; }              /* keyboard hint is irrelevant on touch */
#touchpad { position: fixed; inset: 0; z-index: 80; pointer-events: none; display: none; }
#touchpad.show { display: block; }
#touchpad > *, #touchpad button { pointer-events: auto; }
#touchpad button { -webkit-tap-highlight-color: transparent; touch-action: none; user-select: none; -webkit-user-select: none; }

#tp-stick { position: absolute; left: max(22px, env(safe-area-inset-left)); bottom: 26px; width: 156px; height: 156px; touch-action: none; }
#tp-base { position: absolute; inset: 0; border-radius: 50%; border: 2px solid rgba(125,249,255,0.45);
  background: rgba(13,2,33,0.4); box-shadow: inset 0 0 26px rgba(125,249,255,0.18); }
#tp-thumb { position: absolute; left: 50%; top: 50%; width: 66px; height: 66px; border-radius: 50%;
  transform: translate(-50%,-50%); background: rgba(125,249,255,0.22); border: 2px solid var(--cyan);
  box-shadow: 0 0 18px rgba(125,249,255,0.6); }

#tp-actions { position: absolute; right: max(16px, env(safe-area-inset-right)); bottom: 26px; width: 212px; height: 212px; }
.tp-btn { position: absolute; font-family: inherit; font-weight: 800; font-size: 15px; letter-spacing: 0.05em;
  color: #fff; border-radius: 50%; border: 2px solid var(--cyan); background: rgba(13,2,33,0.5);
  text-shadow: 0 0 8px rgba(0,0,0,0.6); box-shadow: 0 0 16px rgba(125,249,255,0.25); }
.tp-btn.down { transform: scale(0.92); filter: brightness(1.5); }
.act-shoot  { width: 86px; height: 86px; right: 64px; bottom: 0;  border-color: var(--pink);  color: var(--pink);  box-shadow: 0 0 20px rgba(255,45,120,0.4); }
.act-pass   { width: 74px; height: 74px; left: 0;     bottom: 66px; border-color: var(--cyan);  color: var(--cyan); }
.act-tackle { width: 74px; height: 74px; right: 0;    bottom: 70px; border-color: var(--gold);  color: var(--gold); }
.act-sig    { width: 72px; height: 72px; right: 66px; top: 0;     border-color: var(--green);  color: var(--green); }
.act-sprint { position: absolute; width: 96px; height: 52px; border-radius: 26px; left: max(24px, env(safe-area-inset-left)); bottom: 196px;
  border-color: var(--purple); color: var(--purple); font-size: 14px; }

#tp-top { position: absolute; top: max(10px, env(safe-area-inset-top)); right: max(12px, env(safe-area-inset-right)); display: flex; gap: 10px; }
.tp-mini { width: 46px; height: 46px; border-radius: 10px; font-weight: 900; font-size: 16px; color: var(--cyan);
  border: 2px solid rgba(125,249,255,0.5); background: rgba(13,2,33,0.6); }

/* ========== responsive / small screens ========== */
@media (pointer: coarse) {
  .btn { padding: 16px 30px; font-size: 16px; }       /* fatter tap targets */
  .team-card { min-height: 56px; }
  /* bump small interactive controls to a ~44px touch target */
  .ctl-key { min-height: 44px; display: inline-flex; align-items: center; justify-content: center; }
  .form-btn { min-height: 44px; padding: 8px 14px; display: inline-flex; align-items: center; }
  .lineup.editable button { min-height: 44px; padding: 8px 8px; }
}
@media (max-width: 760px) {
  h1.title-main { font-size: clamp(34px, 12vw, 64px); }
  .menu-col { width: min(92vw, 460px); }
  .btn { width: 100%; margin: 6px 0; }
  /* reflow the 48-team grid so it never scrolls sideways on a phone */
  #teams-grid { gap: 8px; grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); width: 96vw; }
  .screen { padding: 18px 14px; }
  /* group-standings table: tighten cells so all 8 columns fit a phone width */
  #hub-table th, #hub-table td { padding: 7px 5px; font-size: 12px; }
  #hub-table th { font-size: 10px; letter-spacing: 0.06em; }
  #hub-table .tname { gap: 5px; }
  #hub-table .tname .flag { width: 20px !important; height: auto !important; }
}
/* landscape gives the most room for the pitch + thumbs */
@media (pointer: coarse) and (orientation: portrait) {
  #scr-match::after {
    content: "↻ Rotate to landscape for the best view";
    position: absolute; top: 8px; left: 0; right: 0; text-align: center;
    font-size: 12px; letter-spacing: 0.12em; color: var(--gold); text-shadow: 0 0 10px var(--gold);
    pointer-events: none;
  }
}
/* extra touch button: manual player switch (small pill above sprint) */
.act-switch { position: absolute; width: 70px; height: 44px; border-radius: 22px; left: max(38px, env(safe-area-inset-left)); bottom: 258px;
  border: 2px solid var(--gold); color: var(--gold); font-size: 13px; background: rgba(13,2,33,0.5); }

/* ========== settings screen ========== */
html.no-scanlines #scanlines { display: none; }
#settings-content { width: min(92vw, 470px); display: flex; flex-direction: column; gap: 14px; margin: 0 auto; }
.set-row { display: flex; align-items: center; gap: 14px; }
.set-label { flex: 0 0 116px; text-align: left; font-size: 14px; letter-spacing: 0.1em; color: var(--cyan); text-shadow: 0 0 8px rgba(125,249,255,0.5); }
.set-slider { flex: 1; accent-color: var(--pink); height: 6px; }
.set-val { flex: 0 0 50px; text-align: right; font-size: 13px; color: rgba(255,255,255,0.8); }
.set-toggle { margin: 4px 0 !important; width: 100%; }
.set-toggle.on { color: var(--green); border-color: var(--green); text-shadow: 0 0 10px var(--green); box-shadow: 0 0 16px rgba(157,255,87,0.4); }
.set-note { font-size: 11px; color: #9fb3c8; opacity: 0.85; text-align: center; margin: 2px auto 10px; max-width: min(92vw, 420px); line-height: 1.4; }
.cheat-btn { margin: 8px auto !important; display: block; color: var(--green); border-color: var(--green); text-shadow: 0 0 8px var(--green); }
.intro-susp { font-size: 12px; color: #ff2d78; letter-spacing: 0.08em; margin-top: 6px; text-shadow: 0 0 8px rgba(255,45,120,0.6); }
/* ball-trail picker */
.trail-row { display: flex; flex-wrap: wrap; gap: 10px; justify-content: center; }
.trail-sw { width: 42px; height: 42px; border-radius: 50%; border: 2px solid rgba(255,255,255,0.3); cursor: pointer; font-size: 15px; }
.trail-sw.on { border-color: #fff; box-shadow: 0 0 14px rgba(255,255,255,0.85); transform: scale(1.12); }
.trail-sw.locked { filter: grayscale(0.6) brightness(0.55); cursor: default; }
/* challenges in the trophy room */
.ch-head { margin-top: 12px; color: var(--gold); }
.ch-item { opacity: 0.5; font-size: 13px; line-height: 1.6; }
.ch-item.done { opacity: 1; color: var(--green); }
/* daily challenge */
.daily-date { color: rgba(255,255,255,0.6); letter-spacing: 0.2em; font-size: 13px; margin-bottom: 16px; text-align: center; }
.daily-vs { display: flex; align-items: center; justify-content: center; gap: 30px; }
.daily-team { display: flex; flex-direction: column; align-items: center; gap: 8px; }
.daily-name { font-weight: 700; letter-spacing: 0.06em; }
.daily-meta { margin-top: 18px; color: var(--cyan); letter-spacing: 0.12em; font-size: 14px; text-align: center; }
.daily-stats { margin: 10px 0 22px; color: var(--gold); letter-spacing: 0.1em; font-size: 15px; text-align: center; }
/* career hub */
.career-team { margin: 14px 0 6px; letter-spacing: 0.08em; }
.career-stats { color: var(--cyan); letter-spacing: 0.08em; font-size: 14px; text-align: center; }
.career-diff { color: var(--gold); letter-spacing: 0.12em; font-size: 13px; margin: 6px 0 8px; text-align: center; }
.career-obj { color: var(--pink); letter-spacing: 0.08em; font-size: 13px; margin: 2px 0 8px; text-align: center; }
.career-award { color: var(--green); font-size: 13px; margin: 2px 0 10px; text-align: center; }
.career-squad { display: grid; grid-template-columns: 1fr 1fr; gap: 1px 20px; max-width: 580px; margin: 6px auto 12px; }
.cs-row { display: flex; justify-content: space-between; font-size: 12.5px; padding: 2px 0; border-bottom: 1px solid rgba(125,249,255,0.08); }
.cs-name { color: #fff; } .cs-meta { color: rgba(255,255,255,0.6); white-space: nowrap; }
.career-history { max-width: 580px; margin: 0 auto 14px; }
.ch-line { font-size: 12px; letter-spacing: 0.04em; padding: 2px 0; text-align: center; }
.ch-line.good { color: var(--green); } .ch-line.bad { color: #ff7d7d; }
/* daily global board */
.daily-name-row { margin: 4px 0 12px; }
.daily-input { font-family: inherit; font-size: 14px; padding: 9px 12px; width: min(82vw, 320px); text-align: center;
  background: rgba(13,2,33,0.7); border: 2px solid var(--cyan); border-radius: 6px; color: #fff; letter-spacing: 0.08em; }
.daily-board { margin: 16px auto 0; max-width: 360px; }
.db-head { color: var(--cyan); letter-spacing: 0.16em; font-size: 13px; margin-bottom: 6px; text-shadow: 0 0 10px var(--cyan); }
.db-row { display: flex; justify-content: space-between; font-size: 13px; padding: 2px 4px; color: rgba(255,255,255,0.85); }
.db-load { color: rgba(255,255,255,0.5); font-size: 12.5px; letter-spacing: 0.08em; }

/* real-fixtures list (daily challenge) */
.fx-list { margin: 14px auto 4px; max-width: 460px; display: flex; flex-direction: column; gap: 8px; }
.fx-row { display: flex; align-items: center; justify-content: space-between; gap: 10px; padding: 9px 12px;
  background: rgba(13,2,33,0.6); border: 1px solid rgba(125,249,255,0.28); border-radius: 8px; }
.fx-row.done { opacity: 0.55; border-color: rgba(125,249,255,0.12); }
.fx-teams { font-size: 13.5px; letter-spacing: 0.04em; color: #fff; text-align: left; }
.fx-teams em { color: var(--cyan); font-style: normal; padding: 0 4px; }
.fx-play { font-size: 12px; padding: 6px 12px; white-space: nowrap; }
.fx-play:disabled { cursor: default; opacity: 0.7; }

/* face portraits on cards */
.face-portrait { border-radius: 50%; object-fit: cover; border: 2px solid var(--cyan); box-shadow: 0 0 12px rgba(125,249,255,0.4); display: block; margin: 4px auto; background: #0d0221; }
.legend-card .face-portrait, .icon-pick .face-portrait { border-color: var(--gold); }

/* menu: 2-column grid + compact secondary row (less vertical) */
.menu-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px; width: min(94vw, 640px); margin: 0 auto; }
.menu-grid .btn { width: 100%; margin: 0; }
#btn-play { grid-column: 1 / -1; }
#btn-arcade { grid-column: 1 / -1; }

/* arcade hub */
.arcade-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; width: min(94vw, 640px); margin: 10px auto 0; }
.arcade-card { display: flex; flex-direction: column; gap: 8px; text-align: left; padding: 18px 20px; cursor: pointer; color: #fff; font-family: inherit;
  background: rgba(13,2,33,0.6); border: 2px solid rgba(255,225,77,0.4); border-radius: 12px; transition: border-color 0.15s, box-shadow 0.15s, transform 0.1s; }
.arcade-card b { color: var(--gold); font-size: 17px; letter-spacing: 0.08em; }
.arcade-card span { color: rgba(255,255,255,0.72); font-size: 12.5px; line-height: 1.45; }
.arcade-card:hover, .arcade-card:focus { border-color: var(--gold); box-shadow: 0 0 18px rgba(255,225,77,0.3); transform: translateY(-2px); outline: none; }
@media (max-width: 760px) { .arcade-grid { grid-template-columns: 1fr; } }
#modehub-content { width: min(94vw, 560px); margin: 0 auto; display: flex; flex-direction: column; align-items: center; text-align: center; }
.hub-intro { max-width: 460px; margin: 0 auto 6px; color: rgba(255,255,255,0.8); font-size: 14px; line-height: 1.5; text-align: center; }
.hub-stat { color: var(--gold); letter-spacing: 0.08em; font-size: 15px; margin: 6px auto 14px; text-align: center; }
.wk-teams { display: flex; flex-wrap: wrap; gap: 6px; justify-content: center; max-width: 420px; margin: 0 auto 14px; }
.wk-chip { font-size: 12px; letter-spacing: 0.08em; padding: 4px 9px; border-radius: 5px; color: var(--cyan);
  background: rgba(125,249,255,0.08); border: 1px solid rgba(125,249,255,0.3); }

/* dream team builder */
.dream-xi { display: flex; gap: 8px; justify-content: center; flex-wrap: wrap; margin: 6px auto 4px; }
.dream-slot { width: 88px; min-height: 96px; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 2px;
  background: rgba(13,2,33,0.6); border: 2px dashed rgba(125,249,255,0.3); border-radius: 10px; padding: 8px 4px; cursor: pointer; }
.dream-slot.filled { border-style: solid; border-color: var(--cyan); }
.dream-slot span { font-size: 10.5px; color: #fff; text-align: center; line-height: 1.1; overflow: hidden; max-width: 80px; }
.dream-slot em { font-size: 10px; color: var(--gold); font-style: normal; }
.dream-plus { font-size: 30px; color: rgba(125,249,255,0.4); }
#dream-content { width: min(94vw, 820px); margin: 0 auto; display: flex; flex-direction: column; align-items: center; text-align: center; }
.dream-status { color: rgba(255,255,255,0.75); font-size: 13px; letter-spacing: 0.06em; margin: 8px 0; text-align: center; }
.dream-pool { display: grid; grid-template-columns: repeat(auto-fill, minmax(120px, 1fr)); gap: 8px; width: min(94vw, 760px); margin: 14px auto 0; max-height: 42vh; overflow-y: auto; }
.dream-card { display: flex; align-items: center; gap: 8px; text-align: left; padding: 7px 10px; cursor: pointer; color: #fff; font-family: inherit;
  background: rgba(13,2,33,0.55); border: 1px solid rgba(125,249,255,0.22); border-radius: 8px; }
.dream-card span { font-size: 11.5px; line-height: 1.1; flex: 1; overflow: hidden; }
.dream-card em { display: block; font-size: 10px; color: var(--gold); font-style: normal; }
.dream-card.picked { opacity: 0.45; border-color: var(--gold); }
.dream-card:disabled { cursor: default; }
.dream-card:not(:disabled):hover { border-color: var(--cyan); }
#btn-continue { display: block; width: min(94vw, 640px); margin: 0 auto 10px; }
.menu-sub { display: flex; flex-wrap: wrap; gap: 8px; justify-content: center; width: min(94vw, 640px); margin: 14px auto 0; }
.menu-sub .btn { width: auto; margin: 0; padding: 10px 16px; font-size: 13px; letter-spacing: 0.1em; }

/* corner quote / gag bubble (kept clear of the pitch) */
#quote-bubble { position: fixed; left: max(14px, env(safe-area-inset-left)); bottom: 16px; z-index: 45; max-width: min(82vw, 400px);
  padding: 13px 18px; background: rgba(11,2,28,0.92); border: 2.5px solid var(--cyan); border-radius: 14px 14px 14px 3px;
  color: var(--cyan); font-size: 17px; font-weight: 800; line-height: 1.32; letter-spacing: 0.03em;
  text-shadow: 0 0 8px rgba(125,249,255,0.95), 0 0 18px rgba(125,249,255,0.7); box-shadow: 0 0 36px rgba(125,249,255,0.55), inset 0 0 12px rgba(125,249,255,0.12);
  opacity: 0; transform: translateY(8px) scale(0.96); transition: opacity 0.25s, transform 0.25s; pointer-events: none; }
@keyframes quotePop {
  0%   { opacity: 0; transform: translateY(14px) scale(0.5); }
  55%  { opacity: 1; transform: translateY(-4px) scale(1.08); }
  78%  { transform: translateY(0) scale(0.97); }
  100% { opacity: 1; transform: translateY(0) scale(1); }
}
#quote-bubble.show { opacity: 1; transform: none; animation: quotePop 0.42s cubic-bezier(.2,.9,.25,1.2) both; }
#quote-bubble .qb-who { display: block; font-size: 12px; color: #b8fbff; letter-spacing: 0.16em; margin-top: 5px; text-transform: uppercase; opacity: 0.95; }
#quote-bubble.gag { border-color: var(--gold); color: var(--gold); font-weight: 900; font-size: 22px; text-shadow: 0 0 10px var(--gold), 0 0 22px rgba(255,225,77,0.7); box-shadow: 0 0 40px rgba(255,225,77,0.55); border-radius: 14px; }

/* menu: keep the whole block centered */
.menu-col { display: flex; flex-direction: column; align-items: center; }

/* hall of fame / rankings */
.hof-share { display: block; margin: 12px auto 6px; max-width: min(92vw, 440px); }
#trophy-stats .tr-rank { color: var(--gold); text-shadow: 0 0 8px rgba(255,225,77,0.45); margin-bottom: 6px; list-style: none; }
#trophy-stats .tr-head { list-style: none; color: var(--cyan); letter-spacing: 0.12em; font-size: 12px; margin: 12px 0 4px; text-transform: uppercase; opacity: 0.85; }
.hof-toggle { display: flex; gap: 8px; justify-content: center; margin: 0 auto 12px; }
.hof-tab { background: rgba(125,249,255,0.08); border: 1.5px solid rgba(125,249,255,0.3); color: var(--cyan); font-family: inherit; font-weight: 700; font-size: 12px; letter-spacing: 0.1em; padding: 7px 16px; border-radius: 8px; cursor: pointer; }
.hof-tab.on { background: rgba(125,249,255,0.18); border-color: var(--cyan); color: #fff; box-shadow: 0 0 14px rgba(125,249,255,0.4); }
.whatsnew-list { list-style: none; padding: 0; margin: 6px auto 16px; max-width: min(90vw, 460px); text-align: left; }
.whatsnew-list li { color: #dfe9ff; font-size: 14px; line-height: 1.4; padding: 7px 0; border-bottom: 1px solid rgba(125,249,255,0.12); }
#changelog-content { width: min(94vw, 520px); margin: 0 auto; max-height: 66vh; overflow-y: auto; text-align: left; }
.cl-block { margin-bottom: 18px; }
.cl-date { color: var(--gold); font-weight: 800; letter-spacing: 0.08em; font-size: 14px; margin-bottom: 6px; text-shadow: 0 0 8px rgba(255,225,77,0.4); }
.cl-list { list-style: none; padding: 0; margin: 0; }
.cl-list li { color: #dfe9ff; font-size: 13.5px; line-height: 1.4; padding: 6px 0; border-bottom: 1px solid rgba(125,249,255,0.1); }
.players-count { color: var(--gold); letter-spacing: 0.1em; font-size: 15px; text-align: center; margin-bottom: 4px; }
.players-sub { color: var(--cyan); opacity: 0.75; letter-spacing: 0.06em; font-size: 11px; text-align: center; margin: 0 0 12px; text-transform: uppercase; }
.players-online { color: var(--green); letter-spacing: 0.08em; font-size: 12.5px; text-align: center; margin: 0 0 6px; text-shadow: 0 0 10px rgba(157,255,87,0.6); }
.players-online .online-names { color: rgba(255,255,255,0.7); font-size: 11.5px; text-shadow: none; }
/* how-it-works mechanics guide */
#guide-content { width: min(94vw, 680px); margin: 0 auto; display: flex; flex-direction: column; gap: 12px; text-align: left; }
.guide-card { background: rgba(12,5,28,0.7); border: 1px solid rgba(125,249,255,0.28); border-radius: 9px; padding: 12px 14px; }
.guide-h { font-weight: 900; font-size: 14px; letter-spacing: 0.06em; color: var(--cyan); text-shadow: 0 0 10px rgba(125,249,255,0.55); margin-bottom: 5px; }
.guide-b { font-size: 12.5px; line-height: 1.55; color: rgba(255,255,255,0.85); }
.guide-b b { color: var(--gold); }
.guide-sub { display: grid; grid-template-columns: 1fr 1fr; gap: 9px; }
.guide-sub .guide-card { background: rgba(125,249,255,0.05); padding: 9px 11px; }
.guide-sub .guide-h { font-size: 12.5px; margin-bottom: 3px; }
.guide-sub .guide-b { font-size: 11.5px; line-height: 1.45; }
.guide-foot { width: min(94vw, 680px); margin: 4px auto 0; font-size: 12px; color: rgba(255,255,255,0.7); text-align: center; }
.guide-foot b { color: var(--gold); }
@media (max-width: 560px) { .guide-sub { grid-template-columns: 1fr; } }
/* my goals highlight reel */
#goals-content { width: min(94vw, 900px); margin: 0 auto; display: flex; flex-wrap: wrap; gap: 16px; justify-content: center; }
.goal-card { width: 260px; background: rgba(12,5,28,0.7); border: 1px solid rgba(255,225,77,0.3); border-radius: 9px; padding: 10px; display: flex; flex-direction: column; gap: 8px; }
.goal-vid { width: 100%; border-radius: 6px; background: #000; aspect-ratio: 16/10; object-fit: cover; }
.goal-lab { font-weight: 800; font-size: 12.5px; color: var(--gold); text-shadow: 0 0 8px rgba(255,225,77,0.5); text-align: center; }
.goal-actions { display: flex; gap: 6px; justify-content: center; }
.goal-actions .btn { font-size: 11px; padding: 6px 10px; }
/* streak-at-risk menu nudge */
.menu-nudge { display: block; margin: 0 auto 10px; padding: 8px 16px; border-radius: 20px; cursor: pointer;
  background: rgba(255,45,120,0.14); border: 1px solid rgba(255,45,120,0.55); color: #ffd0e0;
  font-family: inherit; font-size: 12.5px; letter-spacing: 0.04em; font-weight: 700;
  text-shadow: 0 0 8px rgba(255,45,120,0.5); animation: nudgePulse 2.2s ease-in-out infinite; }
.menu-nudge:hover { background: rgba(255,45,120,0.24); }
@keyframes nudgePulse { 0%,100% { box-shadow: 0 0 10px rgba(255,45,120,0.3); } 50% { box-shadow: 0 0 20px rgba(255,45,120,0.6); } }
.players-note { color: #9fb3c8; opacity: 0.85; font-size: 11px; text-align: center; margin: 0 auto 10px; max-width: min(92vw, 440px); line-height: 1.4; }
.players-list { width: min(92vw, 440px); margin: 0 auto; max-height: 60vh; overflow-y: auto; }
.pl-row { display: grid; grid-template-columns: 30px 1fr auto; gap: 10px; align-items: center; font-size: 14px; padding: 5px 6px; border-bottom: 1px solid rgba(125,249,255,0.1); }
.pl-rank { color: var(--cyan); text-align: right; font-weight: 700; }
.pl-name { color: #fff; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; letter-spacing: 0.04em; }
.pl-title { display: block; font-size: 10px; letter-spacing: 0.1em; color: var(--cyan); opacity: 0.7; text-transform: uppercase; margin-top: 1px; }
.pl-me .pl-title { color: var(--gold); opacity: 0.85; }
.pl-score { color: var(--gold); font-weight: 700; }
.pl-me { background: rgba(255,225,77,0.12); border-radius: 6px; }
.pl-me .pl-name, .pl-me .pl-rank { color: var(--gold); }
.pl-me em { font-style: normal; color: var(--gold); font-size: 11px; letter-spacing: 0.1em; }
.pl-me-off { margin-top: 8px; border-top: 1px dashed rgba(255,225,77,0.4); }
.db-me { color: var(--gold); font-weight: 700; }
.credits-link { margin-top: 16px; text-align: center; font-size: 11.5px; letter-spacing: 0.06em; }
.credits-link a { color: rgba(125,249,255,0.65); text-decoration: none; border-bottom: 1px dotted rgba(125,249,255,0.4); }
.credits-link a:hover { color: var(--cyan); }
