/* =========================================================
   Racha Fácil — Global Stylesheet
   ========================================================= */

/* ── Reset & Base ── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --green:        #00e87a;
  --cyan:         #00c8e8;
  --gold:         #fbbf24;
  --bg:           #081324;
  --bg2:          #0e1f35;
  --bg3:          #14263f;
  --glass:        rgba(255,255,255,0.07);
  --glass2:       rgba(255,255,255,0.11);
  --border:       rgba(255,255,255,0.18);
  --border2:      rgba(255,255,255,0.26);
  --text:         #eef6ff;
  --muted:        rgba(221,240,255,0.70);
  --dimmed:       rgba(221,240,255,0.48);
  --radius-sm:    9px;
  --radius-md:    12px;
  --radius-lg:    16px;
  --font-display: 'Barlow Condensed', sans-serif;
  --font-body:    'Outfit', sans-serif;
}

html, body {
  height: 100%;
  background: var(--bg);
  color: var(--text);
  font-family: var(--font-body);
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}

/* Cobre a safe-area do topo (status bar) no iOS PWA com a cor correta do tema.
   Usa elemento real (não pseudo-elemento) para que o JS possa
   forçar repaint ao trocar de tema — WebKit não repinta ::before fixo. */
#safe-top {
  position: fixed;
  top: 0; left: 0; right: 0;
  height: env(safe-area-inset-top, 0px);
  background: var(--bg);
  z-index: 9999;
  pointer-events: none;
}

::-webkit-scrollbar              { width: 3px; }
::-webkit-scrollbar-thumb        { background: rgba(0,232,122,0.25); border-radius: 2px; }

/* ── Animations ── */
@keyframes fadeUp     { from { opacity:0; transform:translateY(18px) } to { opacity:1; transform:translateY(0) } }
@keyframes fadeIn     { from { opacity:0 }                              to { opacity:1 } }
@keyframes slideIn    { from { opacity:0; transform:scale(0.96) }       to { opacity:1; transform:scale(1) } }
@keyframes bounce     { 0%,100% { transform:translateY(0) }             50% { transform:translateY(-12px) } }
@keyframes shimmer    { 0%,100% { opacity:0.5 }                         50% { opacity:1 } }
@keyframes toastPop   { from { opacity:0; transform:translate(-50%,10px) } to { opacity:1; transform:translate(-50%,0) } }

.fade-up  { animation: fadeUp  0.38s cubic-bezier(.22,1,.36,1) both; }
.slide-in { animation: slideIn 0.35s cubic-bezier(.22,1,.36,1) both; }

/* ── Background Mesh ── */
.bg-mesh { position:fixed; inset:0; pointer-events:none; z-index:0; overflow:hidden; }
.bg-mesh::before {
  content:''; position:absolute; width:700px; height:700px; border-radius:50%;
  background:radial-gradient(circle,rgba(0,232,122,0.07) 0%,transparent 65%);
  top:-250px; left:-250px;
}
.bg-mesh::after {
  content:''; position:absolute; width:600px; height:600px; border-radius:50%;
  background:radial-gradient(circle,rgba(0,200,232,0.06) 0%,transparent 65%);
  bottom:-200px; right:-200px;
}

/* ── App Layout ── */
#app {
  position: relative;
  z-index: 1;
  max-width: 480px;
  margin: 0 auto;
  padding: 0 14px calc(80px + env(safe-area-inset-bottom, 0px));
  min-height: 100vh;
}

.screen { /* wraps current step content */ }

/* ── Add player screen ── */
.add-player-screen {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.add-player-screen .card { width: 100%; }

.app-version { text-align: center; font-size: 11px; color: var(--dimmed); margin-top: 24px; }
.btn-link { background: none; border: none; padding: 0; color: var(--green); font-size: inherit; cursor: pointer; text-decoration: underline; }
.field-wrap { display: flex; flex-direction: column; gap: 8px; }
.field-caption {
  font-size: 12px;
  color: var(--dimmed);
  text-align: center;
  margin: 0;
  letter-spacing: .3px;
}
.field-caption strong { color: rgba(255,255,255,.7); }
.field-illustration {
  width: 100%;
  opacity: .13;
  pointer-events: none;
  user-select: none;
}
.field-illustration--interactive {
  opacity: 1;
}
.field-reserve-label {
  margin: 6px 0 0;
  font-size: 13px;
  font-weight: 500;
  color: var(--muted);
  letter-spacing: .3px;
}

/* ── Config screen bottom (field + weather) ── */
.config-bottom {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-top: 20px;
}

/* ── Weather widget ── */
.weather-widget {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 13px;
  padding: 14px 16px;
  display: flex;
  align-items: center;
  gap: 12px;
}
.weather-widget--idle {
  justify-content: center;
  padding: 10px;
}
.weather-widget--loading {
  justify-content: center;
  gap: 8px;
  opacity: .7;
}
.weather-widget--error {
  justify-content: center;
  opacity: .6;
  font-size: 13px;
}
.weather-widget__cta {
  background: none;
  border: 1px solid var(--border2);
  border-radius: 8px;
  color: var(--muted);
  font-size: 13px;
  padding: 7px 14px;
  cursor: pointer;
  transition: border-color .15s, color .15s;
}
.weather-widget__cta:hover {
  border-color: var(--green);
  color: var(--green);
}
.weather-widget__spinner {
  width: 14px; height: 14px;
  border: 2px solid var(--border2);
  border-top-color: var(--green);
  border-radius: 50%;
  animation: spin .7s linear infinite;
  flex-shrink: 0;
}
@keyframes spin { to { transform: rotate(360deg); } }
.weather-widget__label { font-size: 13px; color: var(--muted); }
.weather-widget--full { flex-direction: column; gap: 14px; }
.weather-widget__header {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 2px 10px;
}
.weather-widget__city {
  font-size: 11px;
  font-weight: 600;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  width: 100%;
  margin-bottom: 2px;
}
.weather-widget__temp {
  font-size: 32px;
  font-weight: 700;
  color: var(--text);
  line-height: 1;
}
.weather-widget__desc {
  font-size: 14px;
  color: var(--muted);
}
.weather-widget__stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 8px;
}
.weather-widget__stat {
  display: flex;
  flex-direction: column;
  gap: 4px;
  background: rgba(255,255,255,.04);
  border-radius: 8px;
  padding: 8px 6px;
  text-align: center;
}
.weather-widget__stat-label {
  font-size: 10px;
  color: var(--dimmed);
  letter-spacing: .5px;
  text-transform: uppercase;
}
.weather-widget__stat-val {
  font-size: 14px;
  font-weight: 600;
  color: var(--text);
}
.weather-widget__stat-val--rain { color: #60c8f0; }
.weather-widget__stat-val--ok   { color: var(--green); }
/* ── Weather scenes ── */
.wx-scene {
  width: 100%;
  height: 72px;
  position: relative;
  overflow: hidden;
  border-radius: 8px;
  margin-bottom: 2px;
}

/* Sunny */
.wx-scene--sunny { background: linear-gradient(135deg, #1a3a5c, #0d2340); }
.wx-sun {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: 34px; height: 34px;
  animation: wx-spin 12s linear infinite;
}
.wx-sun--small { width: 24px; height: 24px; top: 38%; left: 30%; animation-duration: 16s; }
.wx-sun__core {
  position: absolute; inset: 0;
  background: #ffd040;
  border-radius: 50%;
  box-shadow: 0 0 18px 6px rgba(255,208,64,.45);
}
.wx-sun__ray {
  position: absolute;
  top: 50%; left: 50%;
  width: 4px; height: 10px;
  margin-left: -2px;
  background: #ffd040;
  border-radius: 2px;
  opacity: .7;
  transform-origin: 50% calc(-17px + -50%);
  transform: rotate(calc(var(--i) * 45deg)) translateY(-26px);
  animation: wx-pulse 2.5s ease-in-out infinite;
  animation-delay: calc(var(--i) * 0.31s);
}
@keyframes wx-spin   { to { transform: translate(-50%,-50%) rotate(360deg); } }
@keyframes wx-pulse  { 0%,100% { opacity:.5; } 50% { opacity:1; } }

/* Night clear */
.wx-scene--night       { background: linear-gradient(135deg, #080e1a, #0d1628); }
.wx-scene--night-cloudy { background: linear-gradient(135deg, #0a1020, #0d1628); }

.wx-moon {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: 28px; height: 28px;
  background: #e8d88a;
  border-radius: 50%;
  box-shadow: 0 0 16px 4px rgba(232,216,138,.3);
  /* crescent via shadow overlay */
  filter: drop-shadow(6px -4px 0 #080e1a);
  animation: wx-float 6s ease-in-out infinite;
}
.wx-moon--small {
  width: 20px; height: 20px;
  top: 38%; left: 28%;
  filter: drop-shadow(5px -3px 0 #0a1020);
  animation-duration: 9s;
}
@keyframes wx-float { 0%,100% { margin-top:0; } 50% { margin-top:-4px; } }

.wx-star {
  position: absolute;
  width: 3px; height: 3px;
  background: #fff;
  border-radius: 50%;
  opacity: 0;
  top:  calc(10% + (var(--i) * 13%));
  left: calc(8%  + (var(--i) * 14%));
  animation: wx-twinkle 2.5s ease-in-out infinite;
  animation-delay: calc(var(--i) * 0.4s);
}
@keyframes wx-twinkle { 0%,100% { opacity:.15; transform:scale(1); } 50% { opacity:.9; transform:scale(1.4); } }

/* Partly cloudy */
.wx-scene--partly { background: linear-gradient(135deg, #1a3a5c, #0d2340); }
.wx-cloud--night  { background: rgba(160,175,200,.15); }
.wx-cloud--night::before, .wx-cloud--night::after { background: rgba(160,175,200,.15); }

/* Cloudy */
.wx-scene--cloudy { background: linear-gradient(135deg, #1e2a38, #111a24); }

/* Cloud shapes */
.wx-cloud {
  position: absolute;
  background: rgba(200,215,230,.18);
  border-radius: 50px;
}
.wx-cloud::before, .wx-cloud::after {
  content: '';
  position: absolute;
  background: inherit;
  border-radius: 50%;
}
.wx-cloud--front {
  width: 90px; height: 28px;
  bottom: 14px; left: 50%; transform: translateX(-50%);
  animation: wx-drift 7s ease-in-out infinite;
}
.wx-cloud--front::before {
  width: 40px; height: 34px;
  top: -18px; left: 14px;
}
.wx-cloud--front::after {
  width: 28px; height: 26px;
  top: -12px; left: 44px;
}
.wx-cloud--back {
  width: 70px; height: 22px;
  bottom: 20px; left: 20%;
  opacity: .5;
  animation: wx-drift 10s ease-in-out infinite reverse;
}
.wx-cloud--back::before {
  width: 32px; height: 28px;
  top: -14px; left: 10px;
}
.wx-cloud--back::after {
  width: 22px; height: 20px;
  top: -9px; left: 34px;
}
.wx-cloud--dark {
  width: 100px; height: 30px;
  bottom: 18px; left: 50%; transform: translateX(-50%);
  background: rgba(100,115,135,.35);
  animation: wx-drift 8s ease-in-out infinite;
}
.wx-cloud--dark::before {
  width: 44px; height: 38px;
  top: -20px; left: 12px;
  background: rgba(100,115,135,.35);
}
.wx-cloud--dark::after {
  width: 32px; height: 28px;
  top: -14px; left: 50px;
  background: rgba(100,115,135,.35);
}
@keyframes wx-drift { 0%,100% { margin-left:0; } 50% { margin-left:8px; } }

/* Rain drops */
.wx-scene--rain, .wx-scene--storm {
  background: linear-gradient(135deg, #111a26, #0a1018);
}
.wx-drop {
  position: absolute;
  width: 2px;
  height: 10px;
  background: linear-gradient(to bottom, transparent, #60c8f0);
  border-radius: 2px;
  bottom: 0;
  left: calc(12% + var(--i) * 12%);
  animation: wx-fall 1.1s linear infinite;
  animation-delay: calc(var(--i) * 0.17s);
  opacity: .7;
}
@keyframes wx-fall {
  0%   { transform: translateY(-60px); opacity: 0; }
  20%  { opacity: .7; }
  100% { transform: translateY(72px);  opacity: 0; }
}

/* Lightning */
.wx-lightning {
  position: absolute;
  bottom: 8px; left: 50%;
  width: 10px; height: 28px;
  margin-left: -5px;
  background: #ffe066;
  clip-path: polygon(60% 0%, 100% 0%, 40% 50%, 80% 50%, 0% 100%, 30% 50%, 0% 50%);
  animation: wx-bolt 3s ease-in-out infinite;
  filter: drop-shadow(0 0 4px #ffe066);
}
@keyframes wx-bolt {
  0%,85%,100% { opacity: 0; }
  87%,93%     { opacity: 1; }
  90%         { opacity: .3; }
}

.weather-widget--denied { gap: 10px; align-items: flex-start; }
.weather-widget__denied-icon { font-size: 18px; line-height: 1; margin-top: 1px; }
.weather-widget__denied-text { display: flex; flex-direction: column; gap: 3px; }
.weather-widget__denied-text span { font-size: 13px; color: var(--muted); }
.weather-widget__denied-text small { font-size: 11px; color: var(--dimmed); line-height: 1.4; }

.add-player-hint {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 16px;
  background: var(--card-bg);
  border-radius: 12px;
  border: 1px dashed rgba(255,255,255,.12);
}
.add-player-hint__icon { font-size: 22px; flex-shrink: 0; }
.add-player-hint__text { font-size: 13px; color: var(--dimmed); margin: 0; line-height: 1.4; }
.add-player-hint__text strong { color: var(--text); }

.add-player-stats {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 16px;
  background: var(--card-bg);
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.08);
  cursor: pointer;
  transition: background .15s;
}
.add-player-stats:hover { background: rgba(255,255,255,.06); }
.add-player-stats__info { display: flex; flex-direction: column; gap: 3px; }
.add-player-stats__count { font-size: 15px; font-weight: 700; color: var(--text); }
.add-player-stats__sub   { font-size: 12px; color: var(--dimmed); }
.add-player-stats__arrow { font-size: 13px; color: var(--green); font-weight: 600; white-space: nowrap; }

/* ── Header ── */
.header { padding:22px 0 14px; text-align:center; position:relative; }
.header--compact { padding:10px 0 8px; }
.header--compact .header__title { font-size:20px; letter-spacing:1px; }
.header__ball {
  font-size:28px; line-height:1; margin-bottom:4px;
  animation: bounce 2.5s ease-in-out infinite;
}
.header__title {
  font-family: var(--font-display);
  font-size:30px; font-weight:800; letter-spacing:1.5px; color:var(--text);
}
.header__subtitle {
  font-size:11px; color:var(--dimmed);
  letter-spacing:2.5px; text-transform:uppercase; margin-top:2px;
}
.theme-pill {
  position: absolute; top: 18px; right: 0;
  width: 34px; height: 34px; border-radius: 50%;
  border: 1px solid var(--border2); background: var(--glass2);
  cursor: pointer; display: flex; align-items: center; justify-content: center;
  transition: background 0.18s, transform 0.15s;
  -webkit-tap-highlight-color: transparent;
}
.theme-pill:hover  { background: var(--glass2); filter: brightness(1.15); }
.theme-pill:active { transform: scale(0.92); }
.theme-pill__icon  { font-size: 15px; line-height: 1; user-select: none; }

/* ── Tabs ── */
.tabs {
  display:flex; gap:3px; padding:4px;
  background:var(--glass); border:1px solid var(--border); border-radius:14px;
  margin-bottom:22px;
}
.tab {
  flex:1; padding:10px 4px; border-radius:10px; border:none; cursor:pointer;
  font-family:var(--font-body); font-size:13px; font-weight:600;
  transition:all 0.2s; color:var(--muted); background:transparent;
}
.tab--active {
  background: linear-gradient(135deg, var(--green), var(--cyan));
  color:#000; font-weight:700;
}
.tab:disabled { opacity:0.3; cursor:default; }

/* ── Card ── */
.card {
  background: var(--glass2);
  border: 1px solid var(--border2);
  border-radius: var(--radius-lg);
  padding: 20px;
}
.card__headline {
  font-family: var(--font-display);
  font-size:16px; font-weight:700; color:var(--green);
  letter-spacing:1px; margin-bottom:15px;
}

/* ── Field ── */
.field        { margin-bottom:13px; }
.field__label {
  display:block; font-size:10.5px; color:var(--dimmed);
  letter-spacing:1.8px; text-transform:uppercase; margin-bottom:7px;
}

/* ── Input ── */
.input {
  width:100%; padding:12px 15px;
  background:rgba(255,255,255,0.055);
  border:1px solid var(--border2); border-radius:11px;
  color:var(--text); font-size:15px; font-family:var(--font-body);
  outline:none; transition:border-color 0.2s;
}
.input:focus      { border-color:rgba(0,232,122,0.5); }
.input::placeholder { color:var(--dimmed); }

/* ── Position grid ── */
.pos-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:7px; }
.pos-btn {
  padding:10px 4px; border-radius:10px;
  border:1px solid var(--border); background:var(--glass);
  color:var(--muted); cursor:pointer;
  font-family:var(--font-body); font-size:11px; font-weight:600;
  text-align:center; transition:all 0.16s;
}
.pos-btn__emoji { font-size:18px; display:block; margin-bottom:3px; }
.pos-btn__label { display:block; }
.pos-btn--active {
  border-color:var(--green);
  background:rgba(0,232,122,0.12);
  color:var(--green);
}

/* ── Stars input ── */
.stars-input { display:flex; gap:5px; align-items:center; }
.star-btn {
  font-size:26px; cursor:pointer; line-height:1;
  color:rgba(221,240,255,0.40); transition:all 0.12s; user-select:none;
  min-width:44px; min-height:44px;
  display:inline-flex; align-items:center; justify-content:center;
}
.star-btn--lit  { color:var(--gold); }
.star-btn:hover { transform:scale(1.2); }

/* Stars display (read-only) */
.stars-row { display:inline-flex; gap:1px; }
.star       { color:rgba(221,240,255,0.38); }
.star--lit  { color:var(--gold); }

/* ── Buttons ── */
.btn-row { display:flex; gap:8px; }
.btn {
  padding:14px 20px; border-radius:var(--radius-md); border:none;
  cursor:pointer; font-family:var(--font-body); font-weight:700;
  font-size:15px; transition:all 0.2s;
}
.btn--primary {
  background: linear-gradient(135deg, var(--green), var(--cyan));
  color:#000; width:100%;
}
.btn--primary:hover   { filter:brightness(1.08); transform:translateY(-1px); }
.btn--primary:active  { transform:translateY(0); }
.btn--primary:disabled {
  background:rgba(255,255,255,0.1); color:var(--dimmed);
  cursor:default; transform:none; filter:none;
}
.btn--draw {
  font-family:var(--font-display);
  font-size:18px; letter-spacing:2px; padding:18px;
}
.btn--ghost {
  background:var(--glass); border:1px solid var(--border2); color:var(--muted);
}
.btn--ghost:hover { background:var(--glass2); }
.btn--sm   { padding:10px 13px; font-size:13px; font-weight:600; border-radius:10px; }
.btn--swap-active {
  border-color:var(--green) !important;
  color:var(--green) !important;
  background:rgba(0,232,122,0.1) !important;
}
.btn--whatsapp {
  border-color:rgba(37,211,102,0.35);
  color:#25d366;
  background:rgba(37,211,102,0.07);
}

/* ── Icon buttons ── */
.icon-btn {
  background:rgba(255,255,255,0.06);
  border:none; border-radius:7px;
  width:30px; height:30px; cursor:pointer;
  font-size:13px; display:flex; align-items:center; justify-content:center;
  flex-shrink:0;
}
.icon-btn--danger { background:rgba(239,68,68,0.1); }

/* ── Player row ── */
.player-row {
  display:flex; align-items:center;
  border-radius:11px; border:1px solid transparent; background:var(--glass);
  margin-bottom:7px; animation:fadeUp 0.3s ease both;
  position:relative; touch-action:pan-y;
}
.player-row:hover { background:var(--glass2); }
.player-row { padding-left:10px; }
.player-row__inner {
  display:flex; align-items:center; gap:11px;
  padding:12px 14px 12px 8px; flex:1; min-width:0;
  transition:transform 0.25s cubic-bezier(.22,1,.36,1);
}
.player-row__icon {
  width:38px; height:38px; border-radius:9px;
  background:rgba(0,232,122,0.09);
  display:flex; align-items:center; justify-content:center;
  font-size:18px; flex-shrink:0;
}
.player-row__info  { flex:1; min-width:0; }
.player-row__name  {
  display:block; font-weight:600; font-size:14.5px;
  margin-bottom:1px; white-space:nowrap;
  overflow:hidden; text-overflow:ellipsis; max-width:160px;
}
.player-row__pos   { display:block; font-size:11px; color:var(--dimmed); }

/* Swipe-to-action */
.player-row__swipe-clip {
  position:absolute; inset:0; overflow:hidden;
  border-radius:inherit; pointer-events:none;
}
.player-row__swipe-clip .swipe-action-btn { pointer-events:auto; }
.player-row__swipe-actions {
  position:absolute; right:0; top:0; bottom:0;
  display:flex; transform:translateX(100%);
  transition:transform 0.25s cubic-bezier(.22,1,.36,1);
}
.row--swiped .player-row__inner        { transform:translateX(-112px); }
.row--swiped .player-row__swipe-actions { transform:translateX(0); }

.swipe-action-btn {
  display:flex; align-items:center; justify-content:center; gap:5px;
  padding:0 14px; border:none; font-size:12px; font-weight:600;
  cursor:pointer; white-space:nowrap; width:56px;
}
.swipe-action-btn--edit {
  background:var(--glass2); color:var(--muted);
}
.swipe-action-btn--del {
  background:rgba(239,68,68,0.85); color:#fff;
}

/* Actions dropdown (details/summary) */
.actions-details { position:relative; }
.actions-details__trigger {
  list-style:none; cursor:pointer;
}
.actions-details__trigger::-webkit-details-marker { display:none; }
.actions-details__menu {
  position:absolute; right:0; top:calc(100% + 6px);
  background:var(--bg2); border:1px solid var(--border2);
  border-radius:10px; min-width:150px; overflow:hidden;
  box-shadow:0 8px 24px rgba(0,0,0,0.35); z-index:100;
  animation:fadeIn 0.15s ease;
}
.actions-details__item {
  display:block; width:100%; padding:10px 14px;
  background:transparent; border:none; text-align:left;
  font-family:var(--font-body); font-size:13px; font-weight:500;
  color:var(--muted); cursor:pointer;
}
.actions-details__item:hover { background:var(--glass2); color:var(--text); }

/* ── Empty state ── */
.empty-state { text-align:center; padding:38px 20px; color:var(--dimmed); }
.empty-state__icon { font-size:40px; margin-bottom:12px; display:block; }

/* ── Championship empty state ── */
.champ-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 48px 24px 32px;
  text-align: center;
}
.champ-empty__trophy {
  font-size: 64px;
  line-height: 1;
  margin-bottom: 16px;
  filter: drop-shadow(0 4px 16px rgba(255,200,0,.25));
}
.champ-empty__title {
  font-size: 1.35rem;
  font-weight: 700;
  letter-spacing: .04em;
  text-transform: uppercase;
  margin: 0 0 8px;
}
.champ-empty__sub {
  font-size: .9rem;
  color: var(--dimmed);
  margin: 0 0 28px;
  max-width: 260px;
  line-height: 1.5;
}
.champ-empty__formats {
  width: 100%;
  max-width: 320px;
  background: var(--glass);
  border: 1px solid var(--border2);
  border-radius: 16px;
  overflow: hidden;
  margin-bottom: 28px;
}
.champ-empty__format {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 18px;
  border-bottom: 1px solid var(--border2);
}
.champ-empty__format:last-child { border-bottom: none; }
.champ-empty__format-emoji { font-size: 22px; flex-shrink: 0; }
.champ-empty__format-name {
  display: block;
  font-size: .9rem;
  font-weight: 600;
}
.champ-empty__format-desc {
  display: block;
  font-size: .78rem;
  color: var(--dimmed);
  margin-top: 1px;
}
.champ-empty__cta { min-width: 200px; }

/* ── Badge ── */
.badge {
  background:rgba(0,232,122,0.13); color:var(--green);
  padding:4px 11px; border-radius:20px;
  font-size:13px; font-weight:700;
}

/* ── Section title ── */
.section-title {
  font-family:var(--font-display);
  font-size:14px; font-weight:700; letter-spacing:1.2px;
  color:var(--muted); text-transform:uppercase;
  margin-bottom:10px;
  display:flex; align-items:center; justify-content:space-between;
}

/* ── Counter (config) ── */
.counter-row    { display:flex; align-items:center; gap:16px; margin-bottom:18px; }
.counter-center { text-align:center; flex:1; }
.counter-btn {
  width:48px; height:48px; border-radius:12px;
  border:1px solid var(--border2); background:var(--glass);
  color:var(--text); font-size:24px; cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  font-weight:300; transition:all 0.15s;
}
.counter-btn:hover { background:var(--glass2); }
.counter-num {
  font-family:var(--font-display);
  font-size:64px; font-weight:800; color:var(--green); line-height:1;
}
.counter-label { font-size:11px; color:var(--dimmed); margin-top:2px; }

/* ── Presets ── */
.presets { display:flex; gap:7px; margin-top:14px; }
.preset-btn {
  flex:1; padding:9px 4px; border-radius:9px;
  border:1px solid var(--border); background:var(--glass);
  color:var(--dimmed); font-size:13px; font-weight:600;
  cursor:pointer; font-family:var(--font-body); transition:all 0.14s;
}
.preset-btn--active {
  border-color:var(--green);
  background:rgba(0,232,122,0.1);
  color:var(--green);
}

/* ── Preview box ── */
.preview-box {
  margin-top:20px; border-radius:13px; padding:16px;
  background:rgba(0,232,122,0.05); border:1px solid rgba(0,232,122,0.18);
}
.preview-box__label {
  font-size:10.5px; color:var(--green); letter-spacing:1.8px;
  text-transform:uppercase; font-weight:600; margin-bottom:14px;
}
.preview-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:10px; text-align:center; }
.preview-num  { display:block; font-family:var(--font-display); font-size:36px; font-weight:800; color:var(--text); }
.preview-sub  { display:block; font-size:11px; color:var(--dimmed); margin-top:2px; }
.warn-box {
  margin-top:12px; padding:9px 12px;
  background:rgba(239,68,68,0.12); border-radius:8px;
  color:#f87171; font-size:12.5px;
}

/* ── Drawing screen ── */
.drawing-screen { text-align:center; padding:60px 20px; }
.draw-ball {
  font-size:68px; display:inline-block; margin-bottom:22px;
  animation: bounce 0.45s ease-in-out infinite;
}
.draw-title {
  font-family:var(--font-display);
  font-size:34px; font-weight:800; letter-spacing:2px; margin-bottom:8px;
}
.draw-sub   { color:var(--dimmed); animation:shimmer 1.2s ease infinite; font-size:14px; }
.draw-icons {
  display:flex; gap:7px; margin-top:30px;
  justify-content:center; flex-wrap:wrap;
}
.draw-icon {
  width:40px; height:40px; border-radius:9px;
  background:rgba(0,232,122,0.09);
  display:flex; align-items:center; justify-content:center;
  font-size:19px; animation:bounce 0.6s ease-in-out infinite;
}

/* ── Balance bar ── */
.balance-bar {
  background:var(--glass); border:1px solid var(--border); border-radius:13px;
  padding:14px 18px; margin-bottom:14px;
  display:flex; align-items:center; gap:14px;
}
.balance-bar__info    { flex-shrink:0; }
.balance-bar__title   { display:block; font-size:10.5px; color:var(--dimmed); text-transform:uppercase; letter-spacing:1.5px; margin-bottom:3px; }
.balance-bar__val     { font-weight:700; font-size:15px; text-shadow: 0 0 0.5px rgba(0,0,0,0.4); }
.balance-bar__track   { flex:1; height:7px; border-radius:4px; background:rgba(255,255,255,0.07); overflow:hidden; }
.balance-bar__fill    { height:100%; border-radius:4px; transition:width 0.6s cubic-bezier(.22,1,.36,1); }
.balance-bar__icon    { font-size:18px; }

/* ── Actions row ── */
.actions-row { display:flex; gap:7px; margin-bottom:14px; }

/* ── Swap hint ── */
.swap-hint {
  padding:10px 14px; border-radius:10px;
  background:rgba(0,200,232,0.08); border:1px solid rgba(0,200,232,0.2);
  margin-bottom:13px; font-size:13px; color:#7dd3fc;
  animation:fadeIn 0.3s ease;
}

/* ── Team card ── */
.team-card {
  border-radius:var(--radius-lg); margin-bottom:15px;
  overflow:hidden; border:1px solid var(--border);
  animation:slideIn 0.35s ease both;
}
.team-card__header {
  padding:13px 16px;
  display:flex; align-items:center; justify-content:space-between;
  border-bottom:1px solid rgba(255,255,255,0.05);
}
.team-card__name-wrap { display:flex; align-items:center; }
.team-card__dot {
  width:9px; height:9px; border-radius:50%; flex-shrink:0;
}
.team-card__name {
  font-family:var(--font-display);
  font-size:19px; font-weight:800; letter-spacing:1px; color:var(--text); margin-left:9px;
}
.team-card__avg {
  padding:4px 11px; border-radius:20px;
  font-size:12.5px; font-weight:700;
}
.team-card__body { padding:6px 10px; }

/* ── Team player row ── */
.team-player {
  display:flex; align-items:center; gap:9px;
  padding:9px 8px; border-radius:9px;
  border:1px solid transparent; margin-bottom:3px;
  transition:all 0.15s; cursor:default;
}
.team-player--swappable { cursor:pointer; }
.team-player--swappable:hover { background:rgba(255,255,255,0.05); }
.team-player--selected  { border-color:var(--green); background:rgba(0,232,122,0.1); }
.team-player__icon      { font-size:17px; flex-shrink:0; }
.team-player__name      { flex:1; font-weight:500; font-size:14px; }
.team-player__pos       { font-size:11px; color:var(--dimmed); margin-right:4px; }

/* ── Reserves ── */
.reserves-card {
  background:var(--glass); border:1px solid var(--border);
  border-radius:14px; margin-bottom:14px; overflow:hidden;
}
.reserves-card__header {
  padding:13px 16px; border-bottom:1px solid var(--border);
  display:flex; justify-content:space-between; align-items:center;
}
.reserves-card__title { font-family:var(--font-display); font-size:17px; font-weight:700; color:var(--muted); }
.reserves-card__count { font-size:12px; color:var(--dimmed); }

.reserve-row {
  display:flex; align-items:center; gap:9px;
  padding:9px 14px; border-bottom:1px solid rgba(255,255,255,0.07);
  transition:all 0.15s;
}
.reserve-row:last-child    { border-bottom:none; }
.reserve-row--targetable   { cursor:pointer; }
.reserve-row--targetable:hover { background:rgba(255,255,255,0.05); }
.reserve-row__icon { font-size:17px; flex-shrink:0; }
.reserve-row__name { flex:1; font-size:14px; font-weight:500; }
.reserve-row__pos  { font-size:12px; color:var(--dimmed); margin-right:8px; }

/* ── PWA Install Banner ── */
@keyframes pwaSlideUp { from { transform:translateY(100%); opacity:0 } to { transform:translateY(0); opacity:1 } }

.pwa-install-banner {
  position: fixed;
  bottom: calc(64px + env(safe-area-inset-bottom, 0px) + 8px);
  left: 12px;
  right: 12px;
  z-index: 8000;
  background: var(--bg2);
  border: 1px solid rgba(0, 232, 122, 0.4);
  border-radius: 16px;
  padding: 12px 14px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  box-shadow: 0 4px 32px rgba(0,0,0,.6), 0 0 0 1px rgba(0,232,122,.08);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  animation: pwaSlideUp .35s ease;
}
.pwa-install-banner__content {
  display: flex;
  align-items: center;
  gap: 10px;
  flex: 1;
  min-width: 0;
}
.pwa-install-banner__icon {
  font-size: 1.6rem;
  flex-shrink: 0;
}
.pwa-install-banner__text {
  display: flex;
  flex-direction: column;
  font-size: .82rem;
  line-height: 1.35;
  min-width: 0;
}
.pwa-install-banner__text strong {
  font-size: .9rem;
  color: var(--text);
}
.pwa-install-banner__text span {
  color: var(--text);
  opacity: .8;
}
.pwa-ios-share {
  font-style: normal;
  font-size: .9rem;
}
.pwa-install-banner__actions {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-shrink: 0;
}
.pwa-install-banner__btn {
  background: var(--accent);
  color: #fff;
  border: none;
  border-radius: 20px;
  padding: 7px 16px;
  font-size: .82rem;
  font-weight: 700;
  cursor: pointer;
  white-space: nowrap;
}
.pwa-install-banner__close {
  background: none;
  border: none;
  color: var(--dimmed);
  font-size: 1rem;
  cursor: pointer;
  padding: 4px 6px;
  line-height: 1;
  flex-shrink: 0;
}

/* ── Toast ── */
.toast {
  position:fixed; top:18px; left:50%; transform:translate(-50%,0);
  z-index:9999; padding:11px 22px; border-radius:30px;
  font-size:13.5px; font-weight:600; animation:toastPop 0.3s ease;
  pointer-events:none; white-space:nowrap;
}
.toast--success { background:rgba(0,232,122,0.9); color:#000; }
.toast--error   { background:rgba(239,68,68,0.9);  color:#fff; }

/* ── Team name inline edit ── */
.team-card__name--editable {
  cursor: pointer;
  border-bottom: 1px dashed transparent;
  transition: border-color 0.15s;
}
.team-card__name--editable:hover {
  border-bottom-color: rgba(255,255,255,0.3);
}
.team-name-input {
  font-family: var(--font-display);
  font-size: 19px; font-weight: 800; letter-spacing: 1px; color: var(--text);
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.25); border-radius: 6px;
  padding: 2px 8px; outline: none; width: 140px;
}
.team-name-input:focus { border-color: rgba(0,232,122,0.6); }

/* ── History ── */
.hist-entry {
  background: var(--glass2);
  border: 1px solid var(--border2);
  border-radius: var(--radius-lg);
  padding: 16px;
  margin-bottom: 12px;
  animation: fadeUp 0.3s ease both;
}
.hist-entry__meta {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 12px; flex-wrap: wrap; gap: 4px;
}
.hist-entry__date {
  font-size: 12.5px; font-weight: 600; color: var(--text);
}
.hist-entry__info {
  font-size: 11px; color: var(--dimmed);
}
.hist-pills {
  display: flex; flex-wrap: wrap; gap: 7px; margin-bottom: 13px;
}
.hist-pill {
  display: flex; align-items: center; gap: 6px;
  padding: 5px 10px; border-radius: 20px; border: 1px solid transparent;
  flex-shrink: 0;
}
.hist-pill__dot {
  width: 7px; height: 7px; border-radius: 50%; flex-shrink: 0;
}
.hist-pill__name {
  font-family: var(--font-display);
  font-size: 13px; font-weight: 700; color: var(--text); letter-spacing: 0.5px;
}
.hist-pill__avg {
  font-size: 11px; font-weight: 600;
}
.hist-entry__actions {
  display: flex; gap: 8px; align-items: center;
}
.hist-entry__btn {
  flex: 1; text-align: center; justify-content: center;
}
.hist-entry__del {
  flex-shrink: 0; padding: 2px 6px; opacity: 0.45; font-size: 13px; margin-left: auto;
}
.hist-entry__del:hover { opacity: 1; }

/* ── Auth card ── */
.auth-card {
  background: var(--glass2);
  border: 1px solid var(--border2);
  border-radius: var(--radius-md);
  padding: 16px;
  margin-bottom: 16px;
}
.auth-card--signed {
  display: flex;
  align-items: center;
  gap: 12px;
}
.auth-avatar {
  width: 42px; height: 42px;
  border-radius: 50%; flex-shrink: 0;
  border: 2px solid var(--border2);
}
.auth-card__title  { font-size:14px; font-weight:600; color:var(--text); margin-bottom:4px; }
.auth-card__sub    { font-size:12px; color:var(--dimmed); line-height:1.4; }
.auth-card__user   { flex:1; min-width:0; }
.auth-card__name   { font-size:14px; font-weight:600; color:var(--text); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.auth-card__email  { font-size:11px; color:var(--dimmed); margin-top:2px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }

.btn-google {
  display: flex; align-items: center; justify-content: center; gap: 10px;
  width: 100%; margin-top: 12px; padding: 12px 16px;
  background: #fff; color: #3c4043;
  border: 1px solid #dadce0; border-radius: var(--radius-md);
  font-size: 14px; font-weight: 600; cursor: pointer;
  font-family: var(--font-body); transition: background 0.15s;
}
.btn-google:hover      { background: #f8f9fa; }
.btn-google:active     { background: #f1f3f4; }
.btn-google__icon {
  font-size: 17px; font-weight: 900; font-family: Arial, sans-serif;
  background: linear-gradient(135deg, #4285F4, #DB4437, #F4B400, #0F9D58);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
}

/* ── Bottom Nav ── */
.bottom-nav {
  position: fixed;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 100%;
  max-width: 480px;
  display: flex;
  background: rgba(12, 26, 46, 0.94);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-top: 1px solid var(--border);
  padding-bottom: env(safe-area-inset-bottom, 0px);
  z-index: 200;
}
.bnav-item {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 4px;
  padding: 12px 4px 14px;
  border: none;
  background: transparent;
  cursor: pointer;
  font-family: var(--font-body);
  color: var(--dimmed);
  transition: color 0.18s;
  -webkit-tap-highlight-color: transparent;
  overflow: visible;
}
.bnav-item--active  { color: var(--green); }
.bnav-item:disabled { opacity: 0.28; cursor: default; }
.bnav-item__icon  { width: 26px; height: 26px; display:flex; align-items:center; justify-content:center; overflow: visible; }
.bnav-item__icon svg { overflow: visible; }
.bnav-item__label { font-size: 11px; font-weight: 600; letter-spacing: 0.4px; }

/* ── FAB: adicionar/gerenciar jogadores ── */
.fab-backdrop {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 210;
  display: none;
  pointer-events: none;
}
.fab-backdrop--visible {
  display: block;
  pointer-events: auto;
}

.fab-container {
  position: fixed;
  bottom: calc(72px + env(safe-area-inset-bottom, 0px));
  right: max(20px, calc(50% - 220px));
  z-index: 220;
}
@media (min-width: 768px) {
  .fab-container {
    right: max(24px, calc(50% - 336px));
  }
}

@keyframes fab-bounce-in {
  0%   { transform: scale(0); opacity: 0; }
  65%  { transform: scale(1.15); opacity: 1; }
  100% { transform: scale(1); }
}
@keyframes fab-pulse {
  0%, 100% { box-shadow: 0 4px 12px rgba(0,0,0,.30), 0 0 0 0 rgba(0,232,122,.35); }
  50%       { box-shadow: 0 4px 12px rgba(0,0,0,.30), 0 0 0 9px rgba(0,232,122,0); }
}
/* morph: botão → lista */
@keyframes fabMenuMorphOpen {
  from { clip-path: inset(calc(100% - 56px) 0px 0px calc(100% - 56px) round 28px); }
  to   { clip-path: inset(0% 0% 0% 0% round 12px); }
}
/* morph: lista → botão */
@keyframes fabMenuMorphClose {
  from { clip-path: inset(0% 0% 0% 0% round 12px); }
  to   { clip-path: inset(calc(100% - 56px) 0px 0px calc(100% - 56px) round 28px); }
}
@keyframes fabItemIn {
  from { opacity: 0; transform: translateY(4px); }
  to   { opacity: 1; transform: translateY(0); }
}

.fab-add {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: rgba(0, 232, 122, 0.15);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border: 1.5px solid rgba(0, 232, 122, 0.70);
  color: #00e87a;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 12px rgba(0,0,0,.30);
  transition: opacity .18s ease, transform .18s ease, box-shadow .15s;
  animation: fab-bounce-in .38s cubic-bezier(.34,1.56,.64,1) forwards,
             fab-pulse 2.5s ease-in-out 0.5s infinite;
}
.fab-add:active { transform: scale(.93); box-shadow: 0 2px 8px rgba(0,0,0,.3); }
/* botão some enquanto o menu está aberto — o menu "é" o botão */
.fab-add--open { opacity: 0; transform: scale(0.5); pointer-events: none; animation: none; }

.fab-menu {
  position: absolute;
  bottom: calc(100% + 12px);
  right: 0;
  background: var(--bg2);
  border: 1px solid var(--border2);
  border-radius: 12px;
  box-shadow: 0 8px 32px rgba(0,0,0,.35);
  backdrop-filter: blur(12px);
  overflow: hidden;
  min-width: 200px;
  /* morph abre do canto inferior-direito (onde o botão está) */
  clip-path: inset(0% 0% 0% 0% round 12px);
  animation: fabMenuMorphOpen .32s cubic-bezier(.22,1,.36,1) forwards;
}
.fab-menu--closing {
  animation: fabMenuMorphClose .26s cubic-bezier(.55,0,1,.45) forwards;
}

/* stagger dos itens — aparecem enquanto o morph termina */
.fab-menu__item {
  display: block;
  width: 100%;
  padding: 12px 16px;
  background: none;
  border: none;
  text-align: left;
  color: var(--text);
  cursor: pointer;
  font-size: 14px;
  border-bottom: 1px solid var(--border2);
  transition: background .15s;
  opacity: 0;
  animation: fabItemIn .2s ease-out forwards;
}
.fab-menu__item:last-child { border-bottom: none; }
.fab-menu__item:active { background: var(--glass2); }
.fab-menu__item--active { color: var(--green); }

.fab-menu:not(.fab-menu--closing) .fab-menu__item:nth-child(1) { animation-delay: .12s; }
.fab-menu:not(.fab-menu--closing) .fab-menu__item:nth-child(2) { animation-delay: .17s; }
.fab-menu:not(.fab-menu--closing) .fab-menu__item:nth-child(3) { animation-delay: .22s; }
.fab-menu:not(.fab-menu--closing) .fab-menu__item:nth-child(4) { animation-delay: .27s; }
.fab-menu:not(.fab-menu--closing) .fab-menu__item:nth-child(5) { animation-delay: .32s; }

/* no fechamento os itens somem imediatamente (o morph os esconde) */
.fab-menu--closing .fab-menu__item { animation: none; opacity: 0; }

/* ── Profile ── */
.profile-hint {
  font-size: 11px; color: var(--dimmed);
  margin-top: 5px; line-height: 1.4;
}
.stats-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}
.stat-card {
  background: var(--glass2);
  border: 1px solid var(--border2);
  border-radius: var(--radius-md);
  padding: 18px 16px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.stat-card--wide {
  grid-column: 1 / -1;
  flex-direction: row;
  align-items: center;
  gap: 14px;
}
.stat-card__num {
  font-family: var(--font-display);
  font-size: 38px; font-weight: 800; color: var(--green); line-height: 1;
}
.stat-card--wide .stat-card__num { font-size: 30px; }
.stat-card__label { font-size: 12px; color: var(--dimmed); }

/* ── Share App Card ── */
.share-app-card { padding: 24px 20px; }
.share-app-card__emoji { font-size: 32px; margin-bottom: 8px; }
.share-app-card__title { font-size: 16px; font-weight: 700; color: var(--text); margin-bottom: 6px; }
.share-app-card__sub   { font-size: 13px; color: var(--dimmed); line-height: 1.5; margin-bottom: 16px; }

/* ── Tooltips ── */
[data-tooltip] { position: relative; }
[data-tooltip]::after {
  content: attr(data-tooltip);
  position: absolute;
  top: calc(100% + 7px);
  bottom: auto;
  left: 50%;
  transform: translateX(-50%);
  white-space: nowrap;
  background: rgba(8,18,36,0.97);
  border: 1px solid var(--border2);
  color: var(--text);
  font-size: 11px;
  font-family: var(--font-body);
  padding: 5px 10px;
  border-radius: var(--radius-sm);
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.18s;
  z-index: 400;
}
[data-tooltip]:hover::after { opacity: 1; }

/* Primeiro botão da actions-row: alinhar tooltip à esquerda para não sair da tela */
.actions-row > :first-child[data-tooltip]::after {
  left: 0;
  transform: none;
}

/* icon-btns ficam na borda direita: alinhar tooltip à direita */
.icon-btn[data-tooltip]::after {
  left: auto;
  right: 0;
  transform: none;
}

/* theme-pill fica na borda esquerda do header — tooltip à direita do botão */
.theme-pill[data-tooltip]::after {
  top: 50%;
  bottom: auto;
  left: calc(100% + 8px);
  right: auto;
  transform: translateY(-50%);
}

/* Nome do time (clique para renomear) fica na borda esquerda do card */
.team-card__name--editable[data-tooltip]::after {
  left: 0;
  transform: none;
}

/* Botões de ação do racha (renomear/excluir) ficam na borda direita */
.racha-card__item-actions [data-tooltip]::after {
  left: auto;
  right: 0;
  transform: none;
}

/* Últimos botões da actions-row (🔁, 🏠) ficam na borda direita */
.actions-row > :last-child[data-tooltip]::after,
.actions-row > :nth-last-child(2)[data-tooltip]::after {
  left: auto;
  right: 0;
  transform: none;
}

/* counter-btn: "−" na esquerda, "+" na direita */
.counter-row > :first-child[data-tooltip]::after {
  left: 0;
  transform: none;
}
.counter-row > :last-child[data-tooltip]::after {
  left: auto;
  right: 0;
  transform: none;
}

/* presence-btn fica na borda esquerda — tooltip alinhado à esquerda */
.presence-btn[data-tooltip]::after {
  left: 0;
  transform: none;
}

/* ── Presence ── */
.presence-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 8px 12px;
  background: var(--glass);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  margin-bottom: 10px;
}
.presence-bar__count { font-size: 13px; color: var(--muted); }
.presence-bar__toggle {
  font-size: 12px; font-weight: 700; letter-spacing: 0.5px;
  color: var(--green); background: transparent; border: none;
  cursor: pointer; padding: 4px 8px;
  border-radius: var(--radius-sm);
  transition: background 0.15s;
}
.presence-bar__toggle:hover { background: rgba(0,232,122,0.1); }

.sort-bar {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  margin-bottom: 10px;
}
.sort-btn {
  font-size: 12px; font-weight: 600; letter-spacing: 0.3px;
  color: var(--muted);
  background: var(--glass);
  border: 1px solid var(--border);
  border-radius: 20px;
  padding: 4px 12px;
  cursor: pointer;
  transition: background 0.15s, color 0.15s, border-color 0.15s;
}
.sort-btn:hover { color: var(--text); background: rgba(255,255,255,0.07); }
.sort-btn--active {
  color: var(--green);
  border-color: var(--green);
  background: rgba(0,232,122,0.08);
}

.presence-btn {
  width: 26px; height: 26px; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  font-size: 16px; line-height: 1;
  background: transparent; border: none; cursor: pointer;
  color: var(--dimmed);
  border-radius: 50%;
  transition: color 0.15s, background 0.15s;
  -webkit-tap-highlight-color: transparent;
}
.presence-btn--on { color: var(--green); }
.presence-btn:hover { background: rgba(255,255,255,0.06); }

.player-row--absent { opacity: 0.45; }
.player-row--absent .player-row__name { text-decoration: line-through; }

.player-row--seed { border-left: 3px solid var(--gold); }

.seed-btn { opacity: 0.45; transition: opacity 0.15s, color 0.15s; }
.seed-btn:hover { opacity: 0.7; }
.seed-btn--on { opacity: 1; color: #fbbf24; }

/* ── Modal ── */
@keyframes slideUp {
  from { transform: translateY(100%); opacity: 0; }
  to   { transform: translateY(0);    opacity: 1; }
}

.modal-backdrop {
  position: fixed; inset: 0;
  background: rgba(0, 0, 0, 0.65);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  z-index: 300;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  animation: fadeIn 0.2s ease;
}
.modal {
  background: var(--bg2);
  border: 1px solid var(--border2);
  border-top-left-radius: var(--radius-lg);
  border-top-right-radius: var(--radius-lg);
  padding: 20px;
  width: 100%;
  max-width: 480px;
  max-height: 85vh;
  overflow-y: auto;
  animation: slideUp 0.32s cubic-bezier(.22,1,.36,1);
}
.modal__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 16px;
}
.modal--sm {
  border-radius: var(--radius-lg);
  max-width: 340px;
  margin: auto;
  align-self: center;
}
.modal__title {
  font-family: var(--font-display);
  font-size: 19px; font-weight: 800; letter-spacing: 0.5px;
  color: var(--text); margin-bottom: 8px;
}
.modal__body {
  font-size: 14px; color: var(--muted); line-height: 1.5;
}
.btn--danger {
  background: linear-gradient(135deg, #ef4444, #dc2626);
  color: #fff;
}

/* ── Championship header ── */
.champ-header {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 16px; gap: 10px;
}
.champ-header__name {
  font-family: var(--font-display);
  font-size: 20px; font-weight: 800; color: var(--text); letter-spacing: 0.5px;
  flex: 1; min-width: 0;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}

/* ── Champion banner ── */
.champion-banner {
  text-align: center;
  background: linear-gradient(135deg, rgba(0,232,122,0.1), rgba(0,200,232,0.08));
  border: 1px solid rgba(0,232,122,0.3);
  border-radius: var(--radius-lg);
  padding: 28px 20px;
  margin-bottom: 20px;
}
.champion-banner__trophy { font-size: 52px; line-height: 1; margin-bottom: 8px; }
.champion-banner__label  {
  font-size: 11px; letter-spacing: 2.5px; text-transform: uppercase;
  color: var(--dimmed); margin-bottom: 6px;
}
.champion-banner__name {
  font-family: var(--font-display);
  font-size: 34px; font-weight: 800; letter-spacing: 1px; line-height: 1.1;
}
.champion-banner__sub { font-size: 12px; color: var(--dimmed); margin-top: 6px; }

/* ── Standings table ── */
.standings-table {
  width: 100%; border-collapse: collapse;
  font-size: 13px;
}
.standings-table thead tr { border-bottom: 1px solid var(--border); }
.standings-table th {
  padding: 9px 8px; text-align: center;
  font-size: 10px; letter-spacing: 1px; text-transform: uppercase;
  color: var(--dimmed); font-weight: 600;
}
.standings-th--team { text-align: left; padding-left: 14px; }
.standings-table td {
  padding: 10px 8px; text-align: center;
  border-bottom: 1px solid rgba(255,255,255,0.07);
}
.standings-table tbody tr:last-child td { border-bottom: none; }
.standings-table td:nth-child(2) { text-align: left; padding-left: 14px; }
.standings-row--qualify td:nth-child(2) { color: var(--green); }
.standings-pos { color: var(--dimmed); font-size: 12px; }
.standings-pts { font-weight: 700; color: var(--text); }
.standings-dot {
  display: inline-block;
  width: 8px; height: 8px; border-radius: 50%;
  margin-right: 6px; flex-shrink: 0; vertical-align: middle;
}
.standings-dot--sm { width: 6px; height: 6px; margin-right: 5px; }
.standings-qualify-note {
  font-size: 11px; color: var(--green);
  padding: 7px 14px; border-top: 1px solid var(--border);
  opacity: 0.75;
}

/* ── Match cards ── */
.match-card {
  border-radius: var(--radius-md);
  border: 1px solid var(--border);
  padding: 12px 14px;
  margin-bottom: 8px;
  font-size: 13.5px;
}
.match-card--pending {
  display: flex; align-items: center; gap: 8px;
  background: var(--glass);
}
.match-card--done {
  display: flex; align-items: center; gap: 6px;
  background: rgba(255,255,255,0.04);
  position: relative;
}
.match-card--waiting {
  display: flex; align-items: center; justify-content: space-between;
  background: transparent; border-style: dashed; opacity: 0.5;
}
.match-card--scoring {
  background: var(--glass2);
  border-color: rgba(0,232,122,0.3);
}
.match-team        { flex: 1; font-weight: 500; display: flex; align-items: center; }
.match-team--right { justify-content: flex-end; text-align: right; }
.match-team--winner { font-weight: 700; color: var(--green); }
.match-vs          { color: var(--dimmed); font-size: 12px; flex-shrink: 0; padding: 0 4px; }
.match-scoreline   {
  font-family: var(--font-display); font-size: 17px; font-weight: 800;
  color: var(--text); flex-shrink: 0; padding: 0 8px; letter-spacing: 1px;
}
.match-score-btn   { flex-shrink: 0; width: auto; }
.match-edit-btn    { margin-left: auto; flex-shrink: 0; padding: 6px 10px; font-size: 12px; }
.match-tbd         { color: var(--dimmed); flex: 1; }
.match-waiting-label { font-size: 11px; color: var(--dimmed); flex-shrink: 0; }

/* ── Score form (inline) ── */
.score-form {
  display: flex; align-items: center; gap: 8px;
  margin-bottom: 10px; flex-wrap: wrap;
}
.score-form__team  { flex: 1; font-size: 13px; font-weight: 500; min-width: 60px; }
.score-form__sep   { color: var(--dimmed); font-weight: 700; flex-shrink: 0; }
.score-input {
  width: 52px; padding: 8px 6px; text-align: center;
  background: rgba(255,255,255,0.11);
  border: 1px solid var(--border2); border-radius: 8px;
  color: #fff; font-size: 18px; font-family: var(--font-display); font-weight: 800;
  outline: none; flex-shrink: 0;
}
.score-input:focus { border-color: rgba(0,232,122,0.5); }
.score-form__actions { display: flex; gap: 8px; }
.score-form__actions .btn--primary { width: auto; }
.score-form__penalty-header {
  font-size: 12px; font-weight: 600; color: var(--green);
  text-align: center; margin-bottom: 10px; letter-spacing: 0.5px;
}
.match-penalties {
  display: block; font-size: 11px; font-weight: 500;
  color: var(--dimmed); letter-spacing: 0.3px;
}

/* ── GK section ── */
.gk-section {
  background: rgba(255,255,255,0.05);
  border: 1px solid var(--border2);
  border-radius: 14px;
  overflow: hidden;
  margin-bottom: 16px;
}
.gk-section__header {
  padding: 10px 16px 8px;
  border-bottom: 1px solid var(--border2);
}
.gk-section__title {
  font-size: 11px; font-weight: 700; letter-spacing: 1px;
  color: var(--dimmed); text-transform: uppercase;
}
.gk-row {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 16px;
  border-bottom: 1px solid var(--border2);
}
.gk-row:last-child { border-bottom: none; }
.gk-row__icon  { font-size: 16px; flex-shrink: 0; }
.gk-row__name  { font-size: 14px; font-weight: 600; flex: 1; }
.gk-row__assign {
  font-size: 12px; font-weight: 600;
  letter-spacing: 0.3px; flex-shrink: 0;
}
.gk-row__controls { display: flex; gap: 4px; flex-shrink: 0; }
.gk-ctrl-btn {
  width: 28px; height: 28px;
  background: rgba(255,255,255,0.06);
  border: 1px solid var(--border2);
  border-radius: 7px; color: #fff;
  font-size: 13px; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
}
.gk-ctrl-btn:disabled { opacity: 0.25; cursor: default; }

/* ── Championship CTA (on teams screen) ── */
.champ-cta { margin-top: 20px; text-align: center; }
.champ-cta__divider {
  font-size: 11px; color: var(--dimmed); letter-spacing: 1.5px;
  text-transform: uppercase; margin-bottom: 10px;
}
.champ-cta .btn--ghost { width: 100%; }

/* ── Format selection buttons ── */
.format-grid { display: flex; flex-direction: column; gap: 8px; }
.format-btn {
  display: flex; align-items: center; gap: 12px;
  padding: 13px 15px; border-radius: var(--radius-md);
  border: 1px solid var(--border2); background: var(--glass);
  color: var(--text); cursor: pointer; font-family: var(--font-body);
  text-align: left; transition: all 0.15s; width: 100%;
}
.format-btn:hover:not(:disabled) { background: var(--glass2); }
.format-btn--active {
  border-color: var(--green);
  background: rgba(0,232,122,0.1);
}
.format-btn--disabled { opacity: 0.4; cursor: default; }
.format-btn__emoji { font-size: 22px; flex-shrink: 0; }
.format-btn__label { font-weight: 700; font-size: 14px; display: block; }
.format-btn__sub   { font-size: 11.5px; color: var(--dimmed); display: block; margin-top: 1px; }

/* ── Sequential championship ── */
.current-match-card {
  background: var(--glass2);
  border: 1px solid var(--border2);
  border-radius: var(--radius-lg);
  padding: 20px;
  margin-bottom: 16px;
}
.current-match-label {
  font-size: 10px; letter-spacing: 2px; text-transform: uppercase;
  color: var(--green); margin-bottom: 14px; font-weight: 700;
}
.current-match-teams {
  display: flex; align-items: center; justify-content: space-between;
  gap: 8px; margin-bottom: 18px;
}
.current-match-team {
  display: flex; align-items: center; gap: 8px; flex: 1;
}
.current-match-team--right { justify-content: flex-end; }
.current-match-dot {
  width: 12px; height: 12px; border-radius: 50%; flex-shrink: 0;
}
.current-match-name {
  font-family: var(--font-display);
  font-size: 20px; font-weight: 800; color: var(--text); letter-spacing: 0.5px;
}
.current-match-vs {
  font-family: var(--font-display);
  font-size: 18px; font-weight: 800; color: var(--dimmed);
  flex-shrink: 0; padding: 0 4px;
}
.result-btns {
  display: grid; grid-template-columns: 1fr auto 1fr; gap: 8px;
}
.result-btn {
  display: flex; flex-direction: column; align-items: center; gap: 4px;
  padding: 12px 8px; border-radius: var(--radius-md);
  border: 1px solid var(--border2); background: var(--glass);
  cursor: pointer; font-family: var(--font-body);
  transition: all 0.15s; -webkit-tap-highlight-color: transparent;
}
.result-btn:hover { filter: brightness(1.12); }
.result-btn:active { transform: scale(0.97); }
.result-btn--win {
  border-color: color-mix(in srgb, var(--team-color) 40%, transparent);
  background: color-mix(in srgb, var(--team-color) 10%, transparent);
}
.result-btn--draw {
  border-color: var(--border2);
  background: var(--glass);
}
.result-btn__icon { font-size: 20px; line-height: 1; }
.result-btn__name {
  font-size: 11px; font-weight: 700; color: var(--text);
  letter-spacing: 0.3px; text-align: center;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 80px;
}

.seq-queue {
  display: flex; align-items: center; gap: 6px; flex-wrap: wrap;
  padding: 10px 14px; margin-bottom: 16px;
  background: var(--glass); border: 1px solid var(--border);
  border-radius: var(--radius-sm); font-size: 12px;
}
.seq-queue-label {
  font-size: 10px; letter-spacing: 1.5px; text-transform: uppercase;
  color: var(--dimmed); margin-right: 4px; flex-shrink: 0;
}
.seq-queue-team  { display: flex; align-items: center; gap: 4px; color: var(--text); }
.seq-queue-arrow { color: var(--dimmed); font-size: 10px; }
.seq-oncourt {
  font-size: 9px; letter-spacing: 1px; text-transform: uppercase;
  color: var(--green); background: rgba(0,232,122,0.1);
  border-radius: 4px; padding: 2px 5px; margin-left: 4px; vertical-align: middle;
}

.confirm-end {
  background: rgba(239,68,68,0.08); border: 1px solid rgba(239,68,68,0.25);
  border-radius: var(--radius-md); padding: 14px;
}
.confirm-end__text {
  font-size: 13px; color: var(--text); margin-bottom: 12px; text-align: center;
}

/* ── Timer ── */
@keyframes timerPulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(239,68,68,0); }
  50%       { box-shadow: 0 0 0 7px rgba(239,68,68,0.18); }
}

.timer-card {
  background: var(--glass2);
  border: 1px solid var(--border2);
  border-radius: var(--radius-lg);
  padding: 16px;
  margin-bottom: 16px;
}
.timer-card--finished {
  border-color: rgba(239,68,68,0.45);
  background: rgba(239,68,68,0.06);
  animation: timerPulse 1.2s ease-in-out infinite;
}
.timer-card__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 10px;
}
.timer-card__title {
  font-family: var(--font-display);
  font-size: 13px; font-weight: 700; letter-spacing: 1.2px;
  color: var(--muted);
}
.timer-duration-picker {
  display: flex; align-items: center; gap: 6px;
}
.timer-dur-btn {
  width: 28px; height: 28px; border-radius: 8px;
  border: 1px solid var(--border); background: var(--glass);
  color: var(--text); font-size: 16px; line-height: 1;
  cursor: pointer; display: flex; align-items: center; justify-content: center;
  transition: background 0.14s;
}
.timer-dur-btn:disabled { opacity: 0.3; cursor: default; }
.timer-dur-btn:not(:disabled):hover { background: var(--glass2); }
.timer-dur-val {
  font-family: var(--font-display); font-size: 15px; font-weight: 700;
  color: var(--text); min-width: 44px; text-align: center;
}
.timer-dur-unit { font-size: 11px; color: var(--dimmed); margin-left: 2px; font-family: var(--font-body); }
.timer-display {
  font-family: var(--font-display);
  font-size: 58px; font-weight: 800;
  text-align: center; letter-spacing: 3px; line-height: 1;
  margin: 4px 0 10px;
  transition: color 0.3s;
}
.timer-progress {
  height: 4px; background: rgba(255,255,255,0.08);
  border-radius: 2px; overflow: hidden; margin-bottom: 12px;
}
.timer-progress__fill {
  height: 100%; border-radius: 2px;
  transition: width 1s linear, background 0.3s;
}
.timer-controls { display: flex; gap: 8px; }
.timer-btn-main { flex: 1; }
.timer-btn-finished {
  flex: 1; padding: 10px 13px;
  background: rgba(239,68,68,0.15); border: 1px solid rgba(239,68,68,0.4);
  color: #ef4444; border-radius: 10px;
  font-size: 14px; font-weight: 700; text-align: center;
  font-family: var(--font-display); letter-spacing: 1px;
  animation: timerPulse 1.2s ease-in-out infinite;
  cursor: pointer;
}
.timer-blocking-msg {
  text-align: center; padding: 12px;
  font-size: 12px; color: var(--dimmed);
  border: 1px dashed var(--border2); border-radius: var(--radius-sm);
  margin-top: 4px;
}
.seq-undo-btn {
  width: 100%; margin-top: 8px;
  font-size: 12px; color: var(--dimmed);
}

/* ── Audit Log ── */
.audit-log {
  background: var(--glass); border: 1px solid var(--border);
  border-radius: var(--radius-md); overflow: hidden;
  margin-bottom: 4px;
}
.audit-row {
  display: flex; align-items: center; gap: 8px;
  padding: 9px 14px; border-bottom: 1px solid var(--border);
  font-size: 13px;
}
.audit-row:last-child { border-bottom: none; }
.audit-row--undo { opacity: 0.55; }
.audit-icon { font-size: 15px; flex-shrink: 0; }
.audit-desc { flex: 1; color: var(--text); line-height: 1.3; }
.audit-undo { color: var(--dimmed); font-style: italic; }
.audit-pts  { color: var(--green); font-weight: 700; font-size: 12px; margin-left: 4px; }
.audit-time { font-size: 11px; color: var(--dimmed); flex-shrink: 0; }
.match-score-btn:disabled {
  background: rgba(255,255,255,0.07) !important;
  color: var(--dimmed) !important;
  cursor: default; pointer-events: none;
}

/* ── Theme Toggle Control ── */
.theme-toggle {
  display: flex;
  gap: 0;
  background: var(--glass);
  border: 1px solid var(--border2);
  border-radius: var(--radius-sm);
  overflow: hidden;
  margin-top: 10px;
}
.theme-btn {
  flex: 1; padding: 10px 6px;
  border: none; background: transparent;
  color: var(--muted); font-size: 12px; font-weight: 600;
  font-family: var(--font-body); cursor: pointer;
  transition: all 0.15s; letter-spacing: 0.3px;
  display: flex; flex-direction: column; align-items: center; gap: 3px;
}
.theme-btn__icon { font-size: 16px; line-height: 1; }
.theme-btn + .theme-btn { border-left: 1px solid var(--border); }
.theme-btn--active {
  background: linear-gradient(135deg, var(--green), var(--cyan));
  color: #000;
}

/* ── Light Theme ──────────────────────────────────────────── */
:root[data-theme="light"] {
  --bg:     #f0f6ff;
  --bg2:    #e4edf9;
  --bg3:    #d9e6f5;
  --glass:  rgba(0,0,0,0.04);
  --glass2: rgba(0,0,0,0.07);
  --border:  rgba(0,0,0,0.13);
  --border2: rgba(0,0,0,0.20);
  --text:   #07101e;
  --muted:  rgba(7,16,30,0.65);
  --dimmed: rgba(7,16,30,0.60);
  --green:  #059657;
  --cyan:   #0094ad;
  --gold:   #d4a017;
}

/* bg-mesh — orbs mais visíveis no fundo claro */
:root[data-theme="light"] .bg-mesh::before {
  background: radial-gradient(circle, rgba(0,232,122,0.20) 0%, transparent 65%);
}
:root[data-theme="light"] .bg-mesh::after {
  background: radial-gradient(circle, rgba(0,200,232,0.15) 0%, transparent 65%);
}

/* Bottom nav — fundo claro */
:root[data-theme="light"] .bottom-nav {
  background: rgba(224, 237, 249, 0.94);
}

/* Cor do team-name-input — herdada de var(--text) mas precisa de reset explícito
   pois o elemento tem background/border próprios que podem confundir herança */
:root[data-theme="light"] .team-name-input { color: var(--text); }

:root[data-theme="light"] .field-caption strong { color: rgba(7,16,30,0.75); }

/* Backgrounds e bordas hardcoded rgba(255,255,255,...) → equivalentes escuros */
:root[data-theme="light"] .input {
  background: rgba(0,0,0,0.05);
}
:root[data-theme="light"] .icon-btn {
  background: rgba(0,0,0,0.06);
}
:root[data-theme="light"] .btn--primary:disabled {
  background: rgba(0,0,0,0.10);
}
:root[data-theme="light"] .balance-bar__track {
  background: rgba(0,0,0,0.08);
}
:root[data-theme="light"] .timer-progress {
  background: rgba(0,0,0,0.08);
}
:root[data-theme="light"] .weather-widget__stat {
  background: rgba(0,0,0,0.05);
}
:root[data-theme="light"] .team-card {
  background: #fff;
  border-color: rgba(0,0,0,0.10);
  box-shadow: 0 2px 8px rgba(0,0,0,0.06);
}
:root[data-theme="light"] .team-card__header {
  border-bottom-color: rgba(0,0,0,0.08);
}
:root[data-theme="light"] .team-player {
  border-bottom: 1px solid rgba(0,0,0,0.05);
  border-radius: 0;
  margin-bottom: 0;
}
:root[data-theme="light"] .team-player:last-child {
  border-bottom: none;
}
:root[data-theme="light"] .reserves-card {
  background: #fff;
  border-color: rgba(0,0,0,0.10);
  box-shadow: 0 2px 8px rgba(0,0,0,0.06);
}
:root[data-theme="light"] .reserve-row {
  border-bottom-color: rgba(0,0,0,0.06);
}
:root[data-theme="light"] .team-player--swappable:hover,
:root[data-theme="light"] .reserve-row--targetable:hover,
:root[data-theme="light"] .add-player-stats:hover {
  background: rgba(0,0,0,0.05);
}
:root[data-theme="light"] .add-player-hint {
  border-color: rgba(0,0,0,0.12);
}
:root[data-theme="light"] .add-player-stats {
  border-color: rgba(0,0,0,0.08);
}
:root[data-theme="light"] .match-score-btn:disabled {
  background: rgba(0,0,0,0.07) !important;
}
:root[data-theme="light"] .team-name-input {
  background: rgba(0,0,0,0.06);
  border-color: rgba(0,0,0,0.20);
}
:root[data-theme="light"] .team-card__name--editable:hover {
  border-bottom-color: rgba(0,0,0,0.3);
}

/* Estrelas — cor vazia cinza visível no fundo claro */
:root[data-theme="light"] .star         { color: #b0b8c4; }
:root[data-theme="light"] .star--lit    { color: var(--gold); }
:root[data-theme="light"] .star-btn     { color: #b0b8c4; }
:root[data-theme="light"] .star-btn--lit { color: var(--gold); }

/* Valor de chuva — ciano legível no fundo claro */
:root[data-theme="light"] .weather-widget__stat-val--rain { color: #0098b8; }

/* Tooltip — fundo claro */
:root[data-theme="light"] [data-tooltip]::after {
  background: rgba(224,237,249,0.97);
}

/* score-input e gk-ctrl-btn herdam cor via ancestral branco — forçar text */
:root[data-theme="light"] .score-input,
:root[data-theme="light"] .gk-ctrl-btn { color: var(--text); }

/* Backgrounds rgba(255,255,255,...) em hover, inputs e seções */
:root[data-theme="light"] .presence-btn:hover { background: rgba(0,0,0,0.06); }
:root[data-theme="light"] .match-card--done   { background: rgba(0,0,0,0.03); }
:root[data-theme="light"] .score-input        { background: rgba(0,0,0,0.06); }
:root[data-theme="light"] .gk-section         { background: rgba(0,0,0,0.03); }
:root[data-theme="light"] .gk-ctrl-btn        { background: rgba(0,0,0,0.06); }

/* Borda da tabela de classificação */
:root[data-theme="light"] .standings-table td { border-bottom-color: rgba(0,0,0,0.06); }

/* Campo SVG — linhas e marcadores brancos ficam invisíveis no fundo claro */
:root[data-theme="light"] .field-illustration--interactive {
  stroke: rgba(7,16,30,0.22);
}
:root[data-theme="light"] .field-illustration--interactive circle[stroke="none"] {
  fill: rgba(7,16,30,0.25);
}

/* Componentes Racha — backgrounds e bordas brancas invisíveis no fundo claro */
:root[data-theme="light"] .racha-card__body {
  border-top-color: rgba(0,0,0,0.08);
}
:root[data-theme="light"] .racha-card__item {
  border-color: rgba(0,0,0,0.10);
  background: rgba(0,0,0,0.03);
}
:root[data-theme="light"] .racha-card__item--active {
  border-color: rgba(0,175,90,0.45);
  background: rgba(0,175,90,0.07);
}
:root[data-theme="light"] .racha-item__rename-input {
  background: rgba(0,0,0,0.05);
}
:root[data-theme="light"] .racha-action-btn {
  border-color: rgba(0,0,0,0.15);
  background: rgba(0,0,0,0.05);
}
:root[data-theme="light"] .racha-action-btn:hover:not(:disabled) {
  background: rgba(0,0,0,0.09);
}
:root[data-theme="light"] .racha-create {
  border-top-color: rgba(0,0,0,0.08);
}
:root[data-theme="light"] .racha-create__input {
  background: rgba(0,0,0,0.05);
  border-color: rgba(0,0,0,0.15);
}
:root[data-theme="light"] .racha-details {
  border-top-color: rgba(0,0,0,0.08);
}

/* ── Responsive ── */
@media (max-width:360px) {
  .counter-num     { font-size:52px; }
  .team-card__name { font-size:17px; }
  .pos-grid        { grid-template-columns:repeat(2,1fr); }
  .bnav-item__label { font-size:10px; }
}


/* ── Racha badge (tela de adicionar) ── */
.racha-badge {
  font-size: 12px;
  color: var(--muted);
  margin-bottom: 10px;
  padding: 6px 12px;
  border-radius: 20px;
  background: rgba(0,232,122,0.07);
  border: 1px solid rgba(0,232,122,0.2);
  display: inline-block;
}
.racha-badge strong {
  color: var(--green);
  font-weight: 700;
}

/* ── Racha card (colapsável inline) ── */
.racha-card {
  border-radius: 14px;
  border: 1px solid rgba(0,232,122,0.25);
  background: rgba(0,232,122,0.06);
  margin-bottom: 12px;
  overflow: hidden;
  transition: border-color 0.2s;
}
.racha-card--open {
  border-color: rgba(0,232,122,0.45);
}

.racha-card__header {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 14px;
  background: none;
  border: none;
  cursor: pointer;
  gap: 8px;
}
.racha-card__header:hover { background: rgba(0,232,122,0.06); }

.racha-card__header-left {
  display: flex;
  align-items: center;
  gap: 8px;
  min-width: 0;
}
.racha-card__header-right {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
}

.racha-card__label {
  font-size: 10px;
  color: var(--muted);
  font-weight: 700;
  letter-spacing: 0.6px;
  text-transform: uppercase;
  flex-shrink: 0;
}
.racha-card__name {
  font-size: 14px;
  font-weight: 700;
  color: var(--green);
  font-family: var(--font-display);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.racha-card__count {
  font-size: 12px;
  color: var(--muted);
  font-weight: 600;
}
.racha-card__chevron {
  font-size: 11px;
  color: var(--green);
  line-height: 1;
}

.racha-card__body {
  padding: 0 12px 14px;
  border-top: 1px solid rgba(255,255,255,0.07);
}

.racha-card__list {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding-top: 12px;
}

.racha-card__item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 9px 10px;
  border-radius: 11px;
  border: 1px solid rgba(255,255,255,0.07);
  background: rgba(255,255,255,0.04);
  transition: border-color 0.15s, background 0.15s;
}
.racha-card__item--active {
  border-color: rgba(0,232,122,0.4);
  background: rgba(0,232,122,0.07);
}

.racha-card__item-select {
  flex: 1;
  display: flex;
  align-items: center;
  gap: 8px;
  background: none;
  border: none;
  cursor: pointer;
  padding: 0;
  text-align: left;
  min-width: 0;
}
.racha-card__item-name {
  font-size: 14px;
  font-weight: 600;
  color: var(--text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.racha-card__item--active .racha-card__item-name { color: var(--green); }

.racha-card__item-count {
  font-size: 11px;
  color: var(--muted);
  font-weight: 500;
  margin-left: 4px;
  flex-shrink: 0;
}

.racha-card__item-actions {
  display: flex;
  gap: 3px;
  flex-shrink: 0;
}

.racha-card__add-btn {
  width: 100%;
  margin-top: 12px;
  padding: 10px;
  border-radius: 11px;
  border: 1px dashed rgba(0,232,122,0.35);
  background: rgba(0,232,122,0.05);
  color: var(--green);
  font-size: 13px;
  font-weight: 700;
  font-family: var(--font-display);
  letter-spacing: 0.3px;
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s;
}
.racha-card__add-btn:hover {
  background: rgba(0,232,122,0.1);
  border-color: rgba(0,232,122,0.6);
}

/* ── Racha details (data, hora, local, vagas, pix) ── */
.racha-details {
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px solid rgba(255,255,255,0.07);
}
.racha-details__title {
  font-size: 10px;
  color: var(--muted);
  letter-spacing: 1.4px;
  text-transform: uppercase;
  margin: 0 0 10px;
}
.racha-details__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}
.racha-details__field {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.racha-details__field--full {
  grid-column: 1 / -1;
}
.racha-details__label {
  font-size: 10px;
  color: var(--dimmed);
  letter-spacing: 1.2px;
  text-transform: uppercase;
}
.racha-details__optional {
  font-size: 9px;
  opacity: 0.6;
  text-transform: none;
  letter-spacing: 0;
}
.input--sm {
  padding: 7px 10px;
  font-size: 13px;
}
:root[data-theme="light"] .racha-details {
  border-top-color: rgba(0,0,0,0.08);
}

/* ── Badge visitante (jogador temporário) ── */
.badge-temp {
  display: inline-block;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.8px;
  text-transform: uppercase;
  background: rgba(255, 180, 0, 0.18);
  color: #ffb400;
  border: 1px solid rgba(255, 180, 0, 0.35);
  border-radius: 4px;
  padding: 1px 5px;
  margin-left: 5px;
  vertical-align: middle;
  line-height: 1.5;
}

/* ── Modal atualizar lista ── */
.update-lista__preview {
  max-height: 45vh;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-top: 4px;
}
.update-lista__section {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.update-lista__label {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 1.2px;
  text-transform: uppercase;
  margin: 0 0 4px;
}
.update-lista__label--present { color: var(--green); }
.update-lista__label--absent  { color: var(--muted); }
.update-lista__label--unknown { color: #ffb400; }
.update-lista__name {
  font-size: 13px;
  padding: 2px 0;
}
.update-lista__name--muted { opacity: 0.5; }
.update-lista__unknown-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  padding: 4px 0;
}
.update-lista__actions {
  display: flex;
  gap: 4px;
  flex-shrink: 0;
}
.update-btn {
  font-size: 11px;
  padding: 3px 8px;
  border-radius: 6px;
  border: 1px solid var(--border);
  background: transparent;
  color: var(--muted);
  cursor: pointer;
  transition: background 0.15s, color 0.15s, border-color 0.15s;
}
.update-btn--active {
  background: rgba(255, 180, 0, 0.15);
  color: #ffb400;
  border-color: rgba(255, 180, 0, 0.4);
}

.racha-item__badge {
  background: rgba(0,232,122,0.2);
  color: var(--green);
  border-radius: 10px;
  padding: 1px 8px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.3px;
  white-space: nowrap;
}

.racha-item__rename-input {
  flex: 1;
  background: rgba(255,255,255,0.12);
  border: 1px solid var(--green);
  border-radius: 8px;
  padding: 7px 11px;
  color: var(--text);
  font-size: 14px;
  font-weight: 600;
  outline: none;
  min-width: 0;
}

.racha-action-btn {
  width: 30px;
  height: 30px;
  border-radius: 8px;
  border: 1px solid rgba(255,255,255,0.1);
  background: rgba(255,255,255,0.06);
  cursor: pointer;
  font-size: 13px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.15s;
}
.racha-action-btn:hover:not(:disabled) { background: rgba(255,255,255,0.12); }
.racha-action-btn:disabled { opacity: 0.25; cursor: default; }
.racha-action-btn--confirm { border-color: rgba(0,232,122,0.4); color: var(--green); }
.racha-action-btn--danger  { border-color: rgba(255,70,70,0.3); }

/* ── Racha create ── */
.racha-create {
  margin-top: 14px;
  padding-top: 12px;
  border-top: 1px solid rgba(255,255,255,0.07);
}
.racha-create__label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.6px;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 8px;
}
.racha-create__row {
  display: flex;
  gap: 8px;
  align-items: center;
}
.racha-create__input {
  flex: 1;
  min-width: 0;
  padding: 9px 12px;
  background: rgba(255,255,255,0.1);
  border: 1px solid rgba(255,255,255,0.15);
  border-radius: 10px;
  color: var(--text);
  font-size: 14px;
  font-family: var(--font-body);
  outline: none;
  transition: border-color 0.2s;
}
.racha-create__input:focus        { border-color: rgba(0,232,122,0.55); }
.racha-create__input::placeholder { color: var(--muted); }
.racha-create__btn { white-space: nowrap; }

/* ── What's New modal ── */
.whats-new-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 12px;
}
.whats-new-badge {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: var(--green);
  background: rgba(0, 232, 122, 0.12);
  border: 1px solid rgba(0, 232, 122, 0.3);
  border-radius: 20px;
  padding: 3px 10px;
}
.whats-new-version {
  font-size: 12px;
  color: var(--muted);
  font-family: var(--font-display);
  letter-spacing: 0.5px;
}
.whats-new-list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-top: 4px;
}
.whats-new-list li {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  font-size: 14px;
  color: var(--text);
  line-height: 1.4;
}
.whats-new-list li::before {
  content: '✓';
  flex-shrink: 0;
  color: var(--green);
  font-weight: 700;
  margin-top: 1px;
}

/* ── Light theme overrides ── */
:root[data-theme="light"] .racha-card {
  border-color: rgba(0,160,80,0.3);
  background: rgba(0,200,100,0.05);
}
:root[data-theme="light"] .racha-card--open { border-color: rgba(0,160,80,0.5); }
:root[data-theme="light"] .racha-card__body { border-top-color: rgba(0,0,0,0.08); }
:root[data-theme="light"] .racha-card__item {
  border-color: rgba(0,0,0,0.07);
  background: rgba(0,0,0,0.03);
}
:root[data-theme="light"] .racha-card__item--active {
  border-color: rgba(0,160,80,0.4);
  background: rgba(0,200,100,0.07);
}
:root[data-theme="light"] .racha-card__item-name { color: #07101e; }
:root[data-theme="light"] .racha-item__rename-input { background: rgba(0,0,0,0.06); color: #07101e; border-color: var(--green); }
:root[data-theme="light"] .racha-action-btn         { background: rgba(0,0,0,0.05); border-color: rgba(0,0,0,0.1); }
:root[data-theme="light"] .racha-action-btn:hover:not(:disabled) { background: rgba(0,0,0,0.1); }
:root[data-theme="light"] .racha-create__input      { background: rgba(0,0,0,0.06); border-color: rgba(0,0,0,0.15); color: #07101e; }
:root[data-theme="light"] .racha-create__input::placeholder { color: rgba(7,16,30,0.4); }
:root[data-theme="light"] .racha-create { border-top-color: rgba(0,0,0,0.08); }

/* ── Drag handle & sortable ── */
.drag-handle {
  display:inline-flex; align-items:center; justify-content:center;
  width:28px; height:44px; flex-shrink:0;
  color:var(--dimmed); cursor:grab; touch-action:none;
  -webkit-user-select:none; user-select:none;
  opacity:0.5;
}
.drag-handle:active { cursor:grabbing; opacity:1; }

/* Item while being dragged — invisible placeholder keeping the space */
.sort-dragging {
  opacity:0 !important;
  pointer-events:none;
}

/* ── New UX improvements – light theme overrides ── */
:root[data-theme="light"] .swipe-action-btn--edit { background: rgba(0,0,0,0.08); color: #333; }
:root[data-theme="light"] .actions-details__menu  { background: #fff; box-shadow: 0 8px 24px rgba(0,0,0,0.15); }
:root[data-theme="light"] .actions-details__item  { color: #444; }
:root[data-theme="light"] .actions-details__item:hover { background: rgba(0,0,0,0.05); color: #111; }
:root[data-theme="light"] .fab-add {
  background: rgba(5, 150, 87, 0.15);
  border: 1.5px solid rgba(5, 150, 87, 0.70);
  color: #059657;
  box-shadow: 0 4px 12px rgba(0,0,0,.15);
}

/* ── Time Picker (drum roller) ── */
.tp-backdrop { align-items: flex-end; }
.tp-modal { position: relative; padding-bottom: 24px; overflow: hidden; }
.tp-title { margin-bottom: 16px; }

.tp-wrapper {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0;
  position: relative;
  height: 220px;
}

.tp-col {
  width: 80px;
  height: 220px;
  overflow-y: scroll;
  scroll-snap-type: y mandatory;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  -ms-overflow-style: none;
  touch-action: pan-y;
  /* padding top/bottom para centralizar o item selecionado */
  padding: 88px 0;
  box-sizing: border-box;
  position: relative;
  z-index: 1;
}
.tp-col::-webkit-scrollbar { display: none; }

.tp-item {
  height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 22px;
  font-weight: 600;
  font-family: var(--font-display);
  color: var(--muted);
  scroll-snap-align: center;
  cursor: pointer;
  transition: color 0.15s, transform 0.15s;
  border-radius: 8px;
  user-select: none;
}
.tp-item--selected {
  color: var(--accent, #00e676);
  font-size: 26px;
}

.tp-sep {
  font-size: 28px;
  font-weight: 800;
  color: var(--accent, #00e676);
  padding: 0 4px;
  margin-bottom: 4px;
  pointer-events: none;
}

/* linha de seleção central — fica dentro do .tp-wrapper */
.tp-highlight-bar {
  position: absolute;
  top: 50%;
  left: 12px; right: 12px;
  height: 44px;
  transform: translateY(-50%);
  border-top: 1.5px solid var(--border2);
  border-bottom: 1.5px solid var(--border2);
  pointer-events: none;
  z-index: 0;
}

/* light theme */
:root[data-theme="light"] .tp-item--selected { color: #059657; }
:root[data-theme="light"] .tp-sep { color: #059657; }

/* ── Date Picker (calendar) ── */
.dp-backdrop { align-items: flex-end; }
.dp-modal { padding-bottom: 20px; }

.dp-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 12px;
}
.dp-month-label {
  font-family: var(--font-display);
  font-size: 18px;
  font-weight: 700;
  color: var(--text);
  letter-spacing: .5px;
}
.dp-nav {
  background: none;
  border: none;
  color: var(--muted);
  font-size: 28px;
  line-height: 1;
  cursor: pointer;
  padding: 0 8px;
  transition: color .15s;
}
.dp-nav:hover { color: var(--green); }

.dp-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 4px;
}
.dp-weekday {
  text-align: center;
  font-size: 11px;
  font-weight: 600;
  color: var(--muted);
  padding-bottom: 6px;
  text-transform: uppercase;
}
.dp-cell {
  aspect-ratio: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 8px;
  font-size: 14px;
  font-weight: 500;
  color: var(--text);
  cursor: pointer;
  transition: background .15s, color .15s;
}
.dp-cell:hover { background: var(--glass2); }
.dp-cell--empty { pointer-events: none; }
.dp-cell--today {
  color: var(--green);
  font-weight: 700;
}
.dp-cell--selected {
  background: var(--green);
  color: #07101e;
  font-weight: 700;
}
.dp-cell--selected:hover { background: var(--green); }

/* light theme */
:root[data-theme="light"] .dp-nav:hover { color: #059657; }
:root[data-theme="light"] .dp-cell--today { color: #059657; }
:root[data-theme="light"] .dp-cell--selected { background: #059657; color: #fff; }

/* ── Tablet (768px+) ── */
@media (min-width: 768px) {
  /* Layout container */
  #app {
    max-width: 720px;
    padding-left: 24px;
    padding-right: 24px;
    padding-bottom: calc(88px + env(safe-area-inset-bottom, 0px));
  }

  /* Bottom nav — full width */
  .bottom-nav {
    max-width: 100%;
  }
  .bnav-item {
    padding: 14px 8px 16px;
    gap: 5px;
  }
  .bnav-item__icon { width: 28px; height: 28px; }
  .bnav-item__label { font-size: 12px; }

  /* Header */
  .header { padding: 28px 0 18px; }
  .header__title { font-size: 36px; }
  .header__subtitle { font-size: 12px; }

  /* Cards */
  .card { padding: 24px; }

  /* Player rows — coluna única, só libera o max-width do nome */
  .add-player-screen { gap: 16px; }
  .player-row__name { max-width: none; }

  /* Team cards em 2 colunas */
  .teams-list {
    display: grid;
    grid-template-columns: 1fr 1fr;
    column-gap: 14px;
    align-items: start;
  }

  /* Stats grid 4 colunas no perfil */
  .stats-grid {
    grid-template-columns: repeat(4, 1fr);
  }
  .stat-card--wide {
    grid-column: 1 / -1;
  }

  /* Pos grid já tem 4 colunas — sem mudança necessária */

  /* Tabs mais espaçadas */
  .tabs { margin-bottom: 26px; }
  .tab { padding: 11px 8px; font-size: 14px; }

  /* Buttons */
  .btn-primary { font-size: 15px; padding: 14px 20px; }

  /* Weather widget: stats em 4 colunas já é o padrão, garantir */
  .weather-widget__stats { gap: 10px; }

  /* Champ empty formats */
  .champ-empty__formats {
    display: grid;
    grid-template-columns: 1fr 1fr;
  }
  .champ-empty__format:last-child { border-bottom: 1px solid var(--border); }
  .champ-empty__format:nth-last-child(-n+2) { border-bottom: none; }
}

/* ── iPad Pro / Desktop (1024px+) ── */
@media (min-width: 1024px) {
  #app        { max-width: 900px; }
  .bottom-nav { max-width: 100%; }
  .fab-container { right: max(24px, calc(50% - 426px)); }
}
