/* Cemi Fútbol — shared theme: "matchday graphics package meets Persona menu".
   Tokens + components used by the hub and every game's DOM overlay.
   Palette: Stadium Black / Chalk White / Floodlit Grass / Cup Gold / Red Card. */

@import url('https://fonts.googleapis.com/css2?family=Anton&family=Archivo:ital,wght@0,400;0,600;0,800;1,700;1,900&display=swap');

:root {
  --black: #0b0f0c;
  --black-2: #131a15;
  --chalk: #f2f0e6;
  --chalk-dim: #b9b7ac;
  --grass: #12b76a;
  --grass-deep: #0b7a46;
  --gold: #ffc53d;
  --red: #e5484d;
  --display: 'Anton', 'Arial Narrow', sans-serif;
  --body: 'Archivo', system-ui, sans-serif;
  --mono: ui-monospace, 'Cascadia Mono', Consolas, monospace;
  --cut: polygon(0 0, 100% 3%, 98% 100%, 2% 97%);
  --cut-btn: polygon(6% 0, 100% 0, 94% 100%, 0 100%);
}

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

html, body {
  background: var(--black);
  color: var(--chalk);
  font-family: var(--body);
  -webkit-font-smoothing: antialiased;
  overscroll-behavior: none;
}

/* ---- chalk field-diagram motifs (the signature) --------------------------------- */
.chalk-arc {
  position: absolute;
  border: 2px solid rgba(242, 240, 230, .16);
  border-radius: 50%;
  pointer-events: none;
}

/* ---- shared components ----------------------------------------------------------- */
.cx-icon { display: inline-flex; width: 1.25em; height: 1.25em; vertical-align: -0.28em; }
.cx-icon svg { width: 100%; height: 100%; }

.cx-btn {
  display: inline-flex;
  align-items: center;
  gap: .55em;
  font-family: var(--display);
  font-size: 1.25rem;
  letter-spacing: .04em;
  color: var(--black);
  background: var(--chalk);
  border: none;
  padding: .65em 1.6em;
  clip-path: var(--cut-btn);
  cursor: pointer;
  transform: skewX(-6deg);
  transition: transform .12s ease, background .12s ease;
  text-decoration: none;
  text-transform: uppercase;
}
.cx-btn > * { transform: skewX(6deg); }
.cx-btn:hover, .cx-btn:focus-visible { background: var(--gold); transform: skewX(-6deg) scale(1.05) rotate(-1deg); }
.cx-btn:active { transform: skewX(-6deg) scale(.97); }
.cx-btn.grass { background: var(--grass); color: var(--black); }
.cx-btn.grass:hover { background: var(--gold); }
.cx-btn.ghost { background: transparent; color: var(--chalk); outline: 2px solid var(--chalk); outline-offset: -2px; }
.cx-btn.ghost:hover { background: var(--chalk); color: var(--black); }
.cx-btn:focus-visible { outline: 3px solid var(--gold); outline-offset: 3px; }

.cx-iconbtn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px; height: 44px;
  background: var(--black-2);
  color: var(--chalk);
  border: 2px solid rgba(242, 240, 230, .25);
  cursor: pointer;
  transform: rotate(-2deg);
  transition: transform .12s, border-color .12s, color .12s;
}
.cx-iconbtn svg { width: 22px; height: 22px; }
.cx-iconbtn:hover, .cx-iconbtn:focus-visible { color: var(--gold); border-color: var(--gold); transform: rotate(2deg) scale(1.08); }

.cx-chip {
  font-family: var(--display);
  text-transform: uppercase;
  letter-spacing: .06em;
  background: var(--chip, var(--gold));
  color: var(--black);
  padding: .3em .9em .25em;
  clip-path: var(--cut-btn);
  transform: skewX(-6deg) rotate(-1deg);
  display: inline-block;
}

.cx-langs { display: inline-flex; gap: 4px; }
.cx-lang {
  font-family: var(--mono);
  font-weight: 700;
  font-size: .78rem;
  color: var(--chalk-dim);
  background: transparent;
  border: 2px solid rgba(242, 240, 230, .22);
  padding: .35em .5em;
  cursor: pointer;
  transition: all .12s;
}
.cx-lang.on { color: var(--black); background: var(--grass); border-color: var(--grass); transform: rotate(-2deg) scale(1.1); }
.cx-lang:hover:not(.on) { color: var(--chalk); border-color: var(--chalk); }

.cx-topbar {
  position: fixed;
  top: 0; left: 0; right: 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 10px 12px;
  z-index: 40;
  pointer-events: none;
}
.cx-topbar > * { pointer-events: auto; }

.cx-toast {
  position: fixed;
  left: 50%;
  bottom: -80px;
  transform: translateX(-50%) skewX(-6deg);
  background: var(--gold);
  color: var(--black);
  font-family: var(--display);
  font-size: 1.05rem;
  letter-spacing: .04em;
  text-transform: uppercase;
  padding: .6em 1.4em;
  clip-path: var(--cut-btn);
  display: flex;
  gap: .5em;
  align-items: center;
  transition: bottom .3s cubic-bezier(.2, 1.4, .4, 1);
  z-index: 90;
}
.cx-toast.show { bottom: 26px; }

.cx-modal-back {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, .72);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 80;
  padding: 18px;
}
.cx-modal {
  width: min(420px, 100%);
  background: var(--black-2);
  border: 2px solid var(--chalk);
  clip-path: var(--cut);
  padding: 26px 26px 30px;
  transform: rotate(-.6deg);
}
.cx-modal-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-family: var(--display);
  font-size: 1.5rem;
  text-transform: uppercase;
  margin-bottom: 18px;
  color: var(--gold);
}
.cx-field { display: block; margin-bottom: 14px; font-size: .85rem; color: var(--chalk-dim); }
.cx-field input {
  width: 100%;
  margin-top: 5px;
  background: var(--black);
  border: 2px solid rgba(242, 240, 230, .25);
  color: var(--chalk);
  font-family: var(--body);
  font-size: 1rem;
  padding: .6em .8em;
}
.cx-field input:focus { outline: none; border-color: var(--grass); }

/* Full-page game menu overlays (each game reuses these) */
.cx-screen {
  position: fixed;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 14px;
  z-index: 30;
  background:
    radial-gradient(120% 90% at 50% 0%, rgba(18, 183, 106, .14), transparent 60%),
    rgba(11, 15, 12, .93);
  padding: 70px 18px 30px;
  text-align: center;
  overflow-y: auto;
}
.cx-screen h1 {
  font-family: var(--display);
  font-size: clamp(2.6rem, 9vw, 4.6rem);
  line-height: .95;
  text-transform: uppercase;
  transform: rotate(-2deg);
  color: var(--chalk);
  text-shadow: 4px 4px 0 var(--grass-deep);
}
.cx-screen h2 {
  font-family: var(--display);
  font-size: clamp(1.4rem, 5vw, 2.2rem);
  text-transform: uppercase;
  transform: rotate(-1deg);
  color: var(--gold);
}
.cx-screen .cx-note { color: var(--chalk-dim); max-width: 46ch; font-size: .95rem; }
.cx-menu { display: flex; flex-direction: column; gap: 12px; margin-top: 10px; width: min(320px, 86vw); }
.cx-menu .cx-btn { justify-content: center; font-size: 1.35rem; }

/* Nerd Corner: where the Nerd Engine speaks. Chalkboard energy. */
.cx-nerd {
  margin-top: 16px;
  max-width: 52ch;
  font-size: .92rem;
  color: var(--chalk);
  background: var(--black-2);
  border-left: 4px solid var(--gold);
  padding: 12px 16px;
  text-align: left;
  transform: rotate(-.5deg);
}
.cx-nerd b {
  display: block;
  font-family: var(--display);
  letter-spacing: .06em;
  color: var(--gold);
  font-size: .8rem;
  margin-bottom: 4px;
  text-transform: uppercase;
}

/* Flag canvas chips (drawn by nations.drawFlag) */
.cx-flag { display: inline-block; border: 2px solid rgba(242,240,230,.3); transform: rotate(-1.5deg); }

@media (prefers-reduced-motion: reduce) {
  * { animation: none !important; transition: none !important; }
}
