﻿:root[data-theme] {
  --bs-body-bg: var(--bg-body);
  --bs-body-color: var(--text-primary);
  --bs-body-font-family: var(--font-family-primary);
  --bs-border-color: var(--border-light);
  --bs-primary: var(--color-brand-primary);
  --bs-secondary: var(--color-brand-secondary);
  --bs-success: var(--success);
  --bs-warning: var(--warning);
  --bs-danger: var(--danger);
  --bs-info: var(--info);
  --bs-link-color: var(--text-link);
  --bs-link-hover-color: var(--text-link-hover);

  --app-accent: var(--color-brand-primary);
  --app-accent-dark: var(--btn-primary-hover-bg);
  --app-accent-soft: var(--info-bg);
  --app-teal: var(--color-brand-accent);
  --app-green: var(--success);
  --app-bg: var(--bg-body);
  --app-bg-elevated: var(--bg-page);
  --app-bg-muted: var(--bg-surface-2);
  --app-surface: var(--bg-surface-1);
  --app-surface-raised: var(--bg-card);
  --app-surface-muted: var(--bg-surface-2);
  --app-border: var(--border-light);
  --app-border-strong: var(--border-normal);
  --app-text: var(--text-primary);
  --app-muted: var(--text-muted);
  --app-muted-strong: var(--text-secondary);
  --app-on-accent: var(--btn-primary-text);
  --app-warning: var(--warning);
  --app-danger: var(--danger);
  --app-success: var(--success);
  --app-shadow: var(--shadow-lg);
  --app-shadow-soft: var(--shadow-md);
  --app-focus: var(--glow-focus);
  --app-motion-fast: var(--motion-duration-fast) var(--motion-ease-standard);
  --app-motion: var(--motion-duration-normal) var(--motion-ease-standard);
}

html[data-theme],
html[data-theme] body {
  background: var(--bg-body);
  color: var(--text-primary);
  font-family: var(--font-family-primary);
}

html[data-theme] a {
  color: var(--text-link);
}

html[data-theme] a:hover,
html[data-theme] a:focus-visible {
  color: var(--text-link-hover);
}

html[data-theme] a.app-button-primary,
html[data-theme] a.game-primary-cta,
html[data-theme] a.home-quinielas-link,
html[data-theme] a.team-save,
html[data-theme] a.btn-primary,
html[data-theme] a.auth-button {
  color: var(--btn-primary-text);
  text-decoration: none;
}

html[data-theme] a.app-button-primary:hover,
html[data-theme] a.app-button-primary:focus-visible,
html[data-theme] a.game-primary-cta:hover,
html[data-theme] a.game-primary-cta:focus-visible,
html[data-theme] a.home-quinielas-link:hover,
html[data-theme] a.home-quinielas-link:focus-visible,
html[data-theme] a.team-save:hover,
html[data-theme] a.team-save:focus-visible,
html[data-theme] a.btn-primary:hover,
html[data-theme] a.btn-primary:focus-visible,
html[data-theme] a.auth-button:hover,
html[data-theme] a.auth-button:focus-visible {
  color: var(--btn-primary-hover-text);
  text-decoration: none;
}

html[data-theme] a.app-button-secondary,
html[data-theme] a.btn-secondary,
html[data-theme] a.auth-button-secondary {
  color: var(--btn-secondary-text);
  text-decoration: none;
}

html[data-theme] a.app-button-secondary:hover,
html[data-theme] a.app-button-secondary:focus-visible,
html[data-theme] a.btn-secondary:hover,
html[data-theme] a.btn-secondary:focus-visible,
html[data-theme] a.auth-button-secondary:hover,
html[data-theme] a.auth-button-secondary:focus-visible {
  color: var(--btn-secondary-hover-text);
  text-decoration: none;
}

html[data-theme] a.auth-button:not(.auth-button-secondary),
html[data-theme] a.auth-button:not(.auth-button-secondary):hover,
html[data-theme] a.auth-button:not(.auth-button-secondary):focus-visible {
  color: var(--btn-gold-text);
}

.app-shell,
.login-page {
  background: var(--bg-body);
  color: var(--text-primary);
  font-family: var(--font-family-primary);
}

.app-navbar {
  background: var(--navbar-bg);
  color: var(--navbar-text);
  border-bottom: var(--border-width-normal) solid var(--navbar-border);
  backdrop-filter: blur(var(--navbar-backdrop-blur));
}

.app-sidebar {
  background: var(--sidebar-bg);
  color: var(--sidebar-text);
  border-right: var(--border-width-normal) solid var(--sidebar-border);
}

.app-card,
.settings-card,
.quiniela-card,
.tabla-modern-card,
.tabla-modern-table-card,
.tabla-audit-card,
.mis-quiniela-card {
  background: var(--card-bg);
  border: var(--border-width-normal) solid var(--card-border);
  box-shadow: var(--card-shadow);
  border-radius: var(--radius-xl);
  color: var(--text-primary);
  transition: var(--transition-default);
}

.app-card:hover,
.mis-quiniela-card:hover {
  transform: var(--card-hover-transform);
  box-shadow: var(--card-hover-shadow);
}

.app-button-primary,
.settings-button,
.home-quinielas-link,
.team-save,
.btn-primary {
  background: var(--btn-primary-bg);
  color: var(--btn-primary-text);
  border: var(--border-width-normal) solid var(--btn-primary-border);
  border-radius: var(--radius-lg);
  transition: var(--transition-default);
}

.app-button-primary:hover,
.app-button-primary:focus-visible,
.settings-button:hover,
.settings-button:focus-visible,
.home-quinielas-link:hover,
.home-quinielas-link:focus-visible,
.team-save:hover,
.team-save:focus-visible,
.btn-primary:hover,
.btn-primary:focus-visible {
  background: var(--btn-primary-hover-bg);
  color: var(--btn-primary-hover-text);
  border-color: var(--btn-primary-hover-border);
  box-shadow: var(--btn-primary-focus-shadow);
  transform: scale(var(--hover-scale));
}

.app-button-primary:active,
.settings-button:active,
.home-quinielas-link:active,
.team-save:active,
.btn-primary:active {
  background: var(--btn-primary-active-bg);
  color: var(--btn-primary-active-text);
  border-color: var(--btn-primary-active-border);
  transform: scale(var(--active-scale));
}

.app-button-danger,
.btn-danger {
  background: var(--btn-danger-bg);
  color: var(--btn-danger-text);
  border: var(--border-width-normal) solid var(--btn-danger-border);
  border-radius: var(--radius-lg);
  transition: var(--transition-default);
}

.app-button-danger:hover,
.app-button-danger:focus-visible,
.btn-danger:hover,
.btn-danger:focus-visible {
  background: var(--btn-danger-hover-bg);
  color: var(--btn-danger-hover-text);
  border-color: var(--btn-danger-hover-border);
  box-shadow: var(--btn-danger-focus-shadow);
  transform: scale(var(--hover-scale));
}

.app-button-danger:active,
.btn-danger:active {
  background: var(--btn-danger-active-bg);
  color: var(--btn-danger-active-text);
  border-color: var(--btn-danger-active-border);
  transform: scale(var(--active-scale));
}

.app-button-secondary,
.team-save.ghost,
.btn-secondary {
  background: var(--btn-secondary-bg);
  color: var(--btn-secondary-text);
  border: var(--border-width-normal) solid var(--btn-secondary-border);
  border-radius: var(--radius-lg);
  transition: var(--transition-default);
}

.app-button-secondary:hover,
.app-button-secondary:focus-visible,
.team-save.ghost:hover,
.team-save.ghost:focus-visible,
.btn-secondary:hover,
.btn-secondary:focus-visible {
  background: var(--btn-secondary-hover-bg);
  color: var(--btn-secondary-hover-text);
  border-color: var(--btn-secondary-hover-border);
  box-shadow: var(--btn-secondary-focus-shadow);
  transform: scale(var(--hover-scale));
}

.app-button-secondary:active,
.team-save.ghost:active,
.btn-secondary:active {
  background: var(--btn-secondary-active-bg);
  color: var(--btn-secondary-active-text);
  border-color: var(--btn-secondary-active-border);
  transform: scale(var(--active-scale));
}

.app-button-primary:disabled,
.settings-button:disabled,
.home-quinielas-link:disabled,
.team-save:disabled,
.btn-primary:disabled {
  background: var(--btn-secondary-disabled-bg);
  color: var(--btn-secondary-disabled-text);
  border-color: var(--btn-secondary-disabled-border);
  box-shadow: none;
  cursor: not-allowed;
  transform: none;
}

.app-button-secondary:disabled,
.team-save.ghost:disabled,
.btn-secondary:disabled {
  background: var(--btn-secondary-disabled-bg);
  color: var(--btn-secondary-disabled-text);
  border-color: var(--btn-secondary-disabled-border);
  box-shadow: none;
  cursor: not-allowed;
  transform: none;
}

.app-button-danger:disabled,
.btn-danger:disabled {
  background: var(--btn-danger-disabled-bg);
  color: var(--btn-danger-disabled-text);
  border-color: var(--btn-danger-disabled-border);
  box-shadow: none;
  cursor: not-allowed;
  transform: none;
}

.app-button-neutral,
.btn-neutral {
  background: var(--btn-neutral-bg);
  color: var(--btn-neutral-text);
  border: var(--border-width-normal) solid var(--btn-neutral-border);
  border-radius: var(--radius-lg);
  transition: var(--transition-default);
}

.app-button-neutral:hover,
.app-button-neutral:focus-visible,
.btn-neutral:hover,
.btn-neutral:focus-visible {
  background: var(--btn-neutral-hover-bg);
  color: var(--btn-neutral-hover-text);
  border-color: var(--btn-neutral-hover-border);
  box-shadow: var(--btn-neutral-focus-shadow);
  transform: scale(var(--hover-scale));
}

.app-button-neutral:active,
.btn-neutral:active {
  background: var(--btn-neutral-active-bg);
  color: var(--btn-neutral-active-text);
  border-color: var(--btn-neutral-active-border);
  transform: scale(var(--active-scale));
}

.app-button-gold {
  background: var(--btn-gold-bg);
  color: var(--btn-gold-text);
  border: var(--border-width-normal) solid var(--btn-gold-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--glow-gold);
  transition: var(--transition-default);
}

.app-button-gold:hover,
.app-button-gold:focus-visible {
  background: var(--btn-gold-hover-bg);
  color: var(--btn-gold-text);
  transform: scale(var(--hover-scale));
}

.app-input,
.form-control,
.form-select {
  background: var(--input-bg);
  color: var(--input-text);
  border: var(--border-width-normal) solid var(--input-border);
  border-radius: var(--radius-lg);
  transition: var(--transition-default);
}

.app-input::placeholder,
.form-control::placeholder {
  color: var(--input-placeholder);
}

.app-input:focus,
.form-control:focus,
.form-select:focus {
  background: var(--input-bg);
  color: var(--input-text);
  border-color: var(--input-border-focus);
  box-shadow: var(--input-focus-shadow);
  outline: none;
}

.app-table,
.table,
.standings-table,
.tabla-modern-table,
.tabla-audit-table {
  background: var(--table-bg);
  color: var(--table-cell-text);
  border-color: var(--table-border);
}

.app-table thead,
.table thead,
.standings-table thead,
.tabla-modern-table thead,
.tabla-audit-table thead {
  background: var(--table-header-bg);
  color: var(--table-header-text);
}

.app-table tbody tr:hover,
.table tbody tr:hover,
.standings-table tbody tr:hover,
.tabla-modern-table tbody tr:hover,
.tabla-audit-table tbody tr:hover {
  background: var(--table-row-hover-bg);
}

.app-topbar {
  background: var(--navbar-bg);
  color: var(--navbar-text);
  border-bottom: var(--border-width-normal) solid var(--navbar-border);
  box-shadow: var(--shadow-sm);
  backdrop-filter: blur(var(--navbar-backdrop-blur));
}

.app-brand,
.app-user-profile,
.app-user-profile:hover,
.app-user-profile:focus-visible {
  color: var(--navbar-text);
}

.app-bottom-nav {
  background: var(--navbar-bg);
  border-color: var(--navbar-border);
  box-shadow: var(--shadow-lg);
  backdrop-filter: blur(var(--navbar-backdrop-blur));
}

.app-bottom-nav a,
.app-bottom-nav button {
  color: var(--nav-item-text);
  border-color: var(--nav-item-border);
  background: var(--nav-item-bg);
  border-radius: var(--radius-lg);
  transition: var(--transition-default);
}

.app-bottom-nav a:hover,
.app-bottom-nav a:focus-visible,
.app-bottom-nav button:hover,
.app-bottom-nav button:focus-visible {
  color: var(--nav-item-active-text);
  background: var(--nav-item-hover-bg);
  text-decoration: none;
}

.app-bottom-nav a.active,
.app-bottom-nav button.active {
  color: var(--nav-item-active-text);
  background: var(--nav-item-active-bg);
  border-color: var(--nav-item-active-border);
}

.app-bottom-nav .app-nav-icon {
  color: var(--nav-icon);
}

.app-bottom-nav .active .app-nav-icon {
  color: var(--nav-icon-active);
}

.settings-alert.success,
.alert-success {
  background: var(--alert-success-bg);
  color: var(--alert-success-text);
  border-color: var(--alert-success-border);
}

.settings-alert.danger,
.alert-danger {
  background: var(--alert-danger-bg);
  color: var(--alert-danger-text);
  border-color: var(--alert-danger-border);
}

.settings-alert.success[data-auto-dismiss],
.app-toast-message.success,
.tournament-floating-message.success,
.juegos-floating-message.success,
.match-toast.success,
.alert-success[data-auto-dismiss] {
  background: #e2f2e3;
  color: #285b2a;
  border-color: #5ab55e;
}

.settings-alert.danger[data-auto-dismiss],
.app-toast-message.danger,
.tournament-floating-message.danger,
.juegos-floating-message.danger,
.match-toast.danger,
.alert-danger[data-auto-dismiss] {
  background: #fde1df;
  color: #7f231c;
  border-color: #f55246;
}

.badge,
.diff-badge {
  background: var(--badge-bg);
  color: var(--badge-text);
  border: var(--border-width-normal) solid var(--badge-border);
  border-radius: var(--radius-pill);
}

.score-box {
  background: var(--score-draw);
  color: var(--text-inverse);
  border-radius: var(--radius-lg);
}

.score-box.green {
  background: var(--score-leading);
}

.score-box.coral {
  background: var(--score-trailing);
}

.score-box.gold {
  background: var(--ranking-top-bg);
  color: var(--text-primary);
}

.current-user-row {
  background: var(--ranking-user-bg);
}

.match-card {
  background: var(--match-card-bg);
  border: var(--border-width-normal) solid var(--match-card-border);
  border-radius: var(--radius-xl);
  box-shadow: var(--card-shadow);
  transition: var(--transition-default);
}

.match-card:hover,
.match-card:focus-within {
  background: var(--match-card-hover-bg);
  transform: var(--card-hover-transform);
  box-shadow: var(--card-hover-shadow);
}

.match-card.locked {
  background: var(--bg-surface-2);
  border-color: var(--border-normal);
}

.match-meta,
.match-state,
.team-side,
.score-editor,
.pronostico-live-row,
.jornada-header span {
  color: var(--text-secondary);
}

.team-side strong,
.match-state strong {
  color: var(--text-primary);
}

.score-input,
.score-label {
  background: var(--prediction-input-bg);
  color: var(--input-text);
  border: var(--border-width-normal) solid var(--prediction-input-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  transition: var(--transition-default);
}

.score-input:focus {
  border-color: var(--input-border-focus);
  box-shadow: var(--prediction-input-focus);
  outline: none;
}

.score-label {
  background: var(--badge-bg);
  color: var(--badge-text);
  border-color: var(--badge-border);
}

.random-score-button {
  transition: var(--transition-default);
}

.random-score-button:hover,
.random-score-button:focus-visible {
  box-shadow: var(--glow-gold);
  transform: scale(var(--hover-scale));
}

.match-toast {
  border-radius: var(--radius-lg);
  border: var(--border-width-normal) solid var(--alert-info-border);
  background: var(--alert-info-bg);
  color: var(--alert-info-text);
  box-shadow: var(--shadow-md);
}

.match-toast.success {
  border-color: var(--alert-success-border);
  background: var(--alert-success-bg);
  color: var(--alert-success-text);
}

.match-toast.danger {
  border-color: var(--alert-danger-border);
  background: var(--alert-danger-bg);
  color: var(--alert-danger-text);
}

.match-live-badge {
  background: var(--live-badge-bg);
  color: var(--live-badge-text);
  border: var(--border-width-normal) solid var(--live-border);
  box-shadow: var(--live-score-glow);
  border-radius: var(--radius-pill);
}

.match-card.live,
.live-match-card {
  background: var(--live-card-bg);
  border-color: var(--live-card-border);
}

.live-dot {
  background: var(--live-dot-bg);
  box-shadow: var(--live-score-glow);
}

.prediction-chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: fit-content;
  max-width: 100%;
  min-height: 28px;
  padding: var(--space-1) var(--space-3);
  background: var(--prediction-bg);
  color: var(--prediction-text);
  border: var(--border-width-normal) solid var(--prediction-border);
  border-radius: var(--radius-pill);
  font-size: var(--font-size-caption);
  font-weight: var(--font-weight-bold);
  line-height: 1;
  letter-spacing: 0;
  white-space: nowrap;
}

.prediction-chip.correct,
.prediction-state.correct {
  background: var(--prediction-correct-bg);
  color: var(--prediction-correct-text);
  border-color: var(--prediction-correct-border);
}

.prediction-chip.wrong,
.prediction-state.wrong {
  background: var(--prediction-wrong-bg);
  color: var(--prediction-wrong-text);
  border-color: var(--prediction-wrong-border);
}

.prediction-chip.pending,
.prediction-state.pending {
  background: var(--prediction-pending-bg);
  color: var(--prediction-pending-text);
  border-color: var(--prediction-pending-border);
}

.team-logo {
  background: var(--team-logo-bg);
  border: var(--border-width-normal) solid var(--team-logo-border);
  box-shadow: var(--team-logo-shadow);
}

.team-name {
  color: var(--team-name-text);
}

.team-meta {
  color: var(--team-meta-text);
}

.sports-stat-card {
  background: var(--stat-card-bg);
  border: var(--border-width-normal) solid var(--stat-card-border);
  border-radius: var(--radius-xl);
}

.stat-positive {
  color: var(--stat-positive);
}

.stat-negative {
  color: var(--stat-negative);
}

.stat-neutral {
  color: var(--stat-neutral);
}

.stat-highlight {
  color: var(--stat-highlight);
}

.ranking-top {
  background: var(--ranking-top-bg);
  border-color: var(--ranking-top-border);
}

.ranking-current-user {
  background: var(--ranking-user-bg);
  border-color: var(--ranking-user-border);
}

.login-panel,
.auth-card {
  background: var(--login-panel-bg);
  border: var(--border-width-normal) solid var(--login-panel-border);
  box-shadow: var(--login-panel-shadow, var(--shadow-xl));
  backdrop-filter: blur(var(--glass-blur));
  border-radius: var(--radius-2xl);
}

.progress,
.app-progress {
  background: var(--progress-track-bg);
  border-radius: var(--progress-radius);
}

.progress-bar,
.app-progress-bar {
  background: var(--progress-fill-bg);
}

.app-body,
.app-main {
  background: var(--bg-body);
  color: var(--text-primary);
  font-family: var(--font-family-primary);
}

.app-main {
  max-width: var(--container-max-width);
}

.app-nav {
  min-height: var(--navbar-height);
}

.app-brand-text,
.app-user-text strong {
  color: var(--navbar-text-active);
}

.app-user-text span,
.section-kicker,
.settings-hint,
.settings-header p,
.quiniela-empty,
.notification-content p,
.notification-content small,
.notification-title-row time,
.notification-drawer-header p,
.notification-drawer-header small {
  color: var(--text-muted);
}

.app-logout {
  background: var(--btn-secondary-bg);
  color: var(--btn-secondary-text);
  border: var(--border-width-normal) solid var(--btn-secondary-border);
  border-radius: var(--radius-lg);
  transition: var(--transition-default);
}

.app-logout:hover,
.app-logout:focus-visible {
  background: var(--btn-secondary-hover-bg);
  color: var(--btn-secondary-text);
  box-shadow: var(--glow-hover);
}

.app-notification-button {
  background: var(--chip-bg);
  color: var(--navbar-text-active);
  border: var(--border-width-normal) solid var(--chip-border);
  border-radius: var(--radius-pill);
  transition: var(--transition-default);
}

.app-notification-button:hover,
.app-notification-button:focus-visible {
  background: var(--chip-hover-bg);
  box-shadow: var(--glow-hover);
}

.notification-badge {
  background: var(--danger);
  color: var(--text-inverse);
  border: var(--border-width-normal) solid var(--navbar-border);
  border-radius: var(--radius-pill);
}

.app-toast-message {
  background: var(--info-bg);
  color: var(--alert-info-text);
  border: var(--border-width-normal) solid var(--alert-info-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
  transition: opacity var(--motion-duration-normal) var(--motion-ease-standard), transform var(--motion-duration-normal) var(--motion-ease-standard);
}

.app-toast-message.is-hiding {
  opacity: 0;
  transform: translate(-50%, -0.35rem);
}

.app-toast-message.success {
  background: var(--alert-success-bg);
  color: var(--alert-success-text);
  border-color: var(--alert-success-border);
}

.app-toast-message.danger {
  background: var(--alert-danger-bg);
  color: var(--alert-danger-text);
  border-color: var(--alert-danger-border);
}

.notification-backdrop {
  background: var(--modal-overlay-bg);
  backdrop-filter: blur(var(--glass-blur));
}

.notification-drawer,
.notification-drawer-header,
.notification-item,
.notification-drawer-actions,
.notification-empty,
.notification-settings-card,
.notification-preference-row {
  background: var(--card-bg);
  color: var(--text-primary);
  border-color: var(--card-border);
  box-shadow: var(--card-shadow);
}

.notification-drawer {
  border-right: var(--border-width-normal) solid var(--sidebar-border);
  transition: var(--transition-default);
}

.notification-drawer-header {
  border-bottom: var(--border-width-normal) solid var(--card-border);
}

.notification-close,
.notification-preferences-link,
.notification-drawer-actions button,
.notification-drawer-actions a,
.notification-read-form button {
  background: var(--btn-ghost-bg);
  color: var(--btn-ghost-text);
  border: var(--border-width-normal) solid var(--btn-secondary-border);
  border-radius: var(--radius-lg);
  transition: var(--transition-default);
}

.notification-close:hover,
.notification-close:focus-visible,
.notification-preferences-link:hover,
.notification-preferences-link:focus-visible,
.notification-drawer-actions button:hover,
.notification-drawer-actions button:focus-visible,
.notification-drawer-actions a:hover,
.notification-drawer-actions a:focus-visible,
.notification-read-form button:hover,
.notification-read-form button:focus-visible {
  background: var(--btn-ghost-hover-bg);
  color: var(--text-link-hover);
}

.notification-item.unread {
  background: var(--info-bg);
}

.notification-type,
.notification-type.upcoming,
.notification-type.started,
.notification-type.score,
.notification-type.random,
.notification-type.general {
  background: var(--badge-bg);
  border: var(--border-width-normal) solid var(--badge-border);
}

.notification-type::before {
  background: var(--badge-text);
}

.notification-type {
  position: relative;
  overflow: hidden;
  border-radius: var(--radius-pill);
  border: 1px solid color-mix(in srgb, var(--border-inverse, #ffffff) 52%, transparent);
  background:
    radial-gradient(circle at 30% 22%, color-mix(in srgb, #ffffff 72%, transparent) 0 16%, transparent 17%),
    linear-gradient(145deg, var(--app-accent), color-mix(in srgb, var(--app-accent) 55%, #002b40 45%));
  box-shadow:
    0 0.55rem 1.1rem color-mix(in srgb, var(--app-accent) 26%, transparent),
    inset 0 1px 0 color-mix(in srgb, #ffffff 62%, transparent),
    inset 0 -0.35rem 0.55rem rgba(0, 0, 0, 0.16);
}

.notification-type::before {
  position: relative;
  z-index: 1;
  display: grid;
  place-items: center;
  width: 1.42rem;
  height: 1.42rem;
  border-radius: var(--radius-pill);
  background: color-mix(in srgb, #ffffff 18%, transparent);
  color: #fff;
  font-size: 0.82rem;
  font-weight: var(--font-weight-extrabold);
  line-height: 1;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.24);
}

.notification-type::after {
  content: "";
  position: absolute;
  inset: 0.16rem;
  border-radius: inherit;
  border: 1px solid color-mix(in srgb, #ffffff 42%, transparent);
  pointer-events: none;
}

.notification-type.upcoming {
  background:
    radial-gradient(circle at 30% 22%, color-mix(in srgb, #ffffff 72%, transparent) 0 16%, transparent 17%),
    linear-gradient(145deg, #f6d75f, #a97408);
  box-shadow: 0 0.55rem 1.1rem rgba(169, 116, 8, 0.24), inset 0 1px 0 rgba(255,255,255,0.62), inset 0 -0.35rem 0.55rem rgba(0,0,0,0.14);
}

.notification-type.upcoming::before {
  content: "⌚";
}

.notification-type.started {
  background:
    radial-gradient(circle at 30% 22%, color-mix(in srgb, #ffffff 72%, transparent) 0 16%, transparent 17%),
    linear-gradient(145deg, #ff6b5f, #b61f1a);
}

.notification-type.started::before {
  content: "▶";
}

.notification-type.score {
  background:
    radial-gradient(circle at 30% 22%, color-mix(in srgb, #ffffff 72%, transparent) 0 16%, transparent 17%),
    linear-gradient(145deg, #4de7ff, #007e91);
}

.notification-type.score::before {
  content: "⚽";
  font-size: 0.88rem;
}

.notification-type.random {
  background:
    radial-gradient(circle at 30% 22%, color-mix(in srgb, #ffffff 72%, transparent) 0 16%, transparent 17%),
    linear-gradient(145deg, #7bf0a5, #058341);
}

.notification-type.random::before {
  content: "◆";
}

.notification-type.general::before {
  content: "Q";
}

.notification-type.movement {
  background:
    radial-gradient(circle at 30% 22%, color-mix(in srgb, #ffffff 72%, transparent) 0 16%, transparent 17%),
    linear-gradient(145deg, #31d3e6, #047888);
}

.notification-type.movement::before {
  content: "↕";
}

.notification-type.movement-up {
  background:
    radial-gradient(circle at 30% 22%, color-mix(in srgb, #ffffff 74%, transparent) 0 16%, transparent 17%),
    linear-gradient(145deg, #42f08f, #0b9f52 55%, #036b38);
  box-shadow:
    0 0.6rem 1.2rem rgba(11, 159, 82, 0.28),
    inset 0 1px 0 rgba(255,255,255,0.68),
    inset 0 -0.35rem 0.55rem rgba(0,0,0,0.16);
}

.notification-type.movement-up::before {
  content: "▲";
  font-size: 0.9rem;
}

.notification-type.movement-down {
  background:
    radial-gradient(circle at 30% 22%, color-mix(in srgb, #ffffff 74%, transparent) 0 16%, transparent 17%),
    linear-gradient(145deg, #ff7568, #d52f2b 55%, #8f1717);
  box-shadow:
    0 0.6rem 1.2rem rgba(213, 47, 43, 0.28),
    inset 0 1px 0 rgba(255,255,255,0.68),
    inset 0 -0.35rem 0.55rem rgba(0,0,0,0.16);
}

.notification-type.movement-down::before {
  content: "▼";
  font-size: 0.9rem;
}

.notification-type.leader {
  background:
    radial-gradient(circle at 30% 22%, color-mix(in srgb, #ffffff 76%, transparent) 0 16%, transparent 17%),
    linear-gradient(145deg, #ffc747, #f59d00 58%, #9b5a00);
}

.notification-type.leader::before {
  content: "★";
  font-size: 0.92rem;
}

.notification-type.correction {
  background:
    radial-gradient(circle at 30% 22%, color-mix(in srgb, #ffffff 72%, transparent) 0 16%, transparent 17%),
    linear-gradient(145deg, #ff8d72, #c83327 58%, #84231e);
}

.notification-type.correction::before {
  content: "↺";
  font-size: 0.94rem;
}

.notification-title-row strong,
.notification-content h3,
.notification-empty strong,
.settings-header h1,
.settings-card h2,
.quiniela-card-header h1,
.quiniela-card-header h2,
.tabla-modern-heading,
.tabla-modern-section-title,
.tabla-modern-journey-header,
.mis-quinielas-header {
  color: var(--card-title);
}

.quiniela-section,
.account-settings {
  color: var(--text-primary);
}

.quiniela-card-header,
.settings-header {
  border-bottom: var(--border-width-normal) solid var(--card-border);
}

.settings-header {
  background: var(--card-bg);
  border: var(--border-width-normal) solid var(--card-border);
  border-radius: var(--radius-xl);
  box-shadow: var(--card-shadow);
}

.theme-profile-option,
.settings-state,
.settings-readonly-value,
.quiniela-select-card,
.home-prediction-row,
.home-prediction-player,
.home-prediction-match {
  background: var(--glass-bg);
  color: var(--text-primary);
  border: var(--border-width-normal) solid var(--glass-border);
  border-radius: var(--radius-lg);
  transition: var(--transition-default);
}

.theme-profile-options {
  display: grid;
  gap: 0.75rem;
}

.theme-profile-option {
  position: relative;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: start;
  padding: 0.9rem;
  overflow: hidden;
  background: var(--player-card-bg);
  border-color: var(--player-card-border);
  box-shadow: var(--player-card-shadow);
  cursor: pointer;
}

.theme-profile-option:has(input:checked) {
  background: var(--ranking-current-user-bg);
  border-color: var(--ranking-user-border);
  box-shadow: var(--glow-hover);
}

.theme-profile-option:hover,
.theme-profile-option:focus-within,
.quiniela-select-card:hover,
.quiniela-select-card:focus-visible,
.home-prediction-row:hover,
.home-prediction-row:focus-within {
  box-shadow: var(--glow-hover);
  transform: var(--card-hover-transform);
}

.theme-profile-option strong,
.home-prediction-player strong,
.home-prediction-team span {
  color: var(--text-primary);
}

.theme-profile-option small,
.home-prediction-score small {
  color: var(--text-muted);
}

.theme-profile-option input {
  width: 1.1rem;
  height: 1.1rem;
  margin-top: 0.2rem;
  accent-color: var(--color-brand-primary);
}

.player-profile-shell {
  align-content: start;
}

.player-profile-hero {
  grid-template-columns: minmax(0, 1.08fr) minmax(280px, 0.92fr);
}

.player-profile-card {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: var(--space-4);
  align-items: center;
  min-width: 0;
  padding: var(--space-4);
  background: var(--player-card-bg);
  border: var(--border-width-normal) solid var(--player-card-border);
  border-radius: var(--radius-xl);
  box-shadow: var(--player-card-shadow);
}

.player-profile-card > div:not(.player-summary) {
  display: grid;
  gap: var(--space-1);
  min-width: 0;
}

.player-profile-card strong {
  color: var(--text-primary);
  font-family: var(--font-family-secondary);
  font-size: var(--font-size-h3);
  line-height: var(--line-height-tight);
  overflow-wrap: anywhere;
  white-space: normal;
}

.player-profile-card small {
  color: var(--text-muted);
  overflow-wrap: anywhere;
  white-space: normal;
}

.player-profile-card .settings-avatar.large {
  width: calc(var(--space-12) + var(--space-8));
  height: calc(var(--space-12) + var(--space-8));
  margin: 0;
  border: var(--border-width-normal) solid var(--player-card-border);
  box-shadow: var(--shadow-lg);
}

.player-summary.compact {
  grid-column: 1 / -1;
}

.player-summary.compact .player-stat-card {
  padding: var(--space-3);
}

.player-summary.compact .player-stat-card strong {
  font-size: var(--font-size-h4);
}

.avatar-uploader {
  background: var(--glass-bg);
  border: var(--border-width-normal) solid var(--glass-border);
  border-radius: var(--radius-xl);
}

.field-validation-error,
.validation-summary-errors,
[data-valmsg-for] {
  color: var(--alert-danger-text);
}

.input-validation-error {
  border-color: var(--input-error-border);
  box-shadow: var(--glow-danger);
}

.champion-game-card,
.champion-field,
.champion-team-preview {
  background: var(--match-card-bg);
  border: var(--border-width-normal) solid var(--match-card-border);
  border-radius: var(--radius-xl);
  box-shadow: var(--card-shadow);
  color: var(--text-primary);
}

.champion-game-header p,
.champion-team-preview span,
.champion-field span {
  color: var(--text-muted);
}

.champion-team-preview strong {
  color: var(--text-primary);
}

.champion-lock.open {
  background: var(--success-bg);
  color: var(--alert-success-text);
  border-color: var(--alert-success-border);
}

.champion-lock.locked {
  background: var(--danger-bg);
  color: var(--alert-danger-text);
  border-color: var(--alert-danger-border);
}

.juegos-floating-message {
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
}

.juegos-score-table {
  background: var(--table-bg);
  color: var(--table-cell-text);
  border-color: var(--table-border);
}

.juegos-score-table th,
.juegos-score-table td {
  border-color: var(--table-border);
}

.juegos-score-table .points-cell {
  background: var(--badge-bg);
  color: var(--badge-text);
  border-color: var(--badge-border);
}

.juegos-score-table .points-cell.total {
  background: var(--ranking-top-bg);
  color: var(--prediction-text);
  border-color: var(--ranking-top-border);
}

.juegos-score-table tr.current-row,
.juegos-score-table tr.ranking-current-user {
  background: var(--ranking-user-bg);
}

.juegos-score-table tr.current-row .player-name,
.juegos-score-table tr.ranking-current-user .player-name {
  color: var(--text-link-hover);
}

.tabla-premium-shell,
.tabla-audit-shell {
  color: var(--text-primary);
}

.tabla-premium-shell .tabla-audit-header,
.tabla-premium-shell .tabla-audit-panel,
.tabla-premium-shell .tabla-audit-card {
  background: var(--card-bg);
  color: var(--text-primary);
  border-color: var(--card-border);
  box-shadow: var(--card-shadow);
}

.tabla-premium-shell .tabla-audit-header > span,
.tabla-premium-shell .quiniela-card-header span,
.tabla-premium-shell .section-kicker {
  color: var(--text-muted);
}

.tabla-premium-shell .tabla-audit-header h1,
.tabla-premium-shell .quiniela-card-header h2 {
  color: var(--card-title);
}

.tabla-premium-shell .quiniela-card-header {
  background: var(--glass-bg);
  border-color: var(--glass-border);
  backdrop-filter: blur(var(--glass-blur));
}

.tabla-premium-shell .tabla-audit-scroll {
  background: var(--table-bg);
  border: var(--border-width-normal) solid var(--table-border);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-sm);
}

.tabla-premium-shell .tabla-audit-table {
  background: var(--table-bg);
  color: var(--table-cell-text);
  border-color: var(--table-border);
}

.tabla-premium-shell .tabla-audit-table thead,
.tabla-premium-shell .tabla-audit-table thead th {
  background: var(--table-header-bg);
  color: var(--table-header-text);
  border-color: var(--table-border);
}

.tabla-premium-shell .tabla-audit-table tbody tr {
  background: var(--table-row-bg);
  color: var(--table-cell-text);
}

.tabla-premium-shell .tabla-audit-table tbody tr:nth-child(even) {
  background: var(--table-row-alt-bg);
}

.tabla-premium-shell .tabla-audit-table tbody tr:hover {
  background: var(--table-row-hover-bg);
}

.tabla-premium-shell .tabla-audit-table tbody tr:first-child:not(.ranking-current-user) {
  background: var(--ranking-top-bg);
}

.tabla-premium-shell .tabla-audit-table tr.ranking-current-user,
.tabla-premium-shell .tabla-audit-table tbody tr:has(.player-name.current) {
  background: var(--ranking-user-bg);
}

.tabla-premium-shell .tabla-audit-table tr.ranking-current-user td,
.tabla-premium-shell .tabla-audit-table tbody tr:has(.player-name.current) td {
  border-color: var(--ranking-user-border);
}

.tabla-premium-shell .tabla-audit-table .player-name,
.tabla-premium-shell .tabla-audit-table .player-name.current {
  color: var(--text-primary);
}

.tabla-premium-shell .tabla-audit-table .result-state {
  background: var(--info-bg);
  color: var(--alert-info-text);
  border-color: var(--alert-info-border);
}

.tabla-premium-shell .tabla-audit-table .result-state.final {
  background: var(--success-bg);
  color: var(--alert-success-text);
  border-color: var(--alert-success-border);
}

.tabla-premium-shell .tabla-audit-table .result-state.partial {
  background: var(--warning-bg);
  color: var(--alert-warning-text);
  border-color: var(--alert-warning-border);
}

.tabla-premium-shell .tabla-audit-table .team-logo {
  background: var(--bg-surface-2);
  border-color: var(--table-border);
}

.tabla-premium-shell .tabla-audit-table .team-logo.favorite,
.tabla-premium-shell .tabla-audit-table .score-result.favorite {
  background: var(--prediction-bg);
  color: var(--prediction-text);
  border-color: var(--prediction-border);
  box-shadow: var(--glow-gold);
}

.tabla-premium-shell .tabla-audit-table .score-result {
  background: var(--badge-bg);
  color: var(--badge-text);
  border-color: var(--badge-border);
}

.tabla-premium-shell .tabla-audit-table .points-divider,
.tabla-premium-shell .tabla-audit-table .points-cell {
  background: var(--ranking-top-bg);
  color: var(--prediction-text);
  border-color: var(--ranking-top-border);
}

.resultados-shell {
  color: var(--text-primary);
}

.resultados-shell .jornada-card,
.resultados-shell .pronosticos-toolbar,
.resultados-shell .result-admin-card {
  background: var(--card-bg);
  color: var(--text-primary);
  border-color: var(--danger);
  box-shadow: var(--card-shadow);
}

.resultados-shell .pronosticos-toolbar {
  box-shadow: var(--card-shadow), var(--glow-danger);
}

.resultados-shell .game-hero {
  border-color: var(--alert-warning-border);
  box-shadow: var(--card-shadow), var(--btn-warning-focus-shadow);
}

.resultados-shell .game-hero .player-stat-card.primary {
  border-color: var(--alert-warning-border);
}

.result-admin-header {
  align-items: flex-start;
  flex-wrap: wrap;
}

.result-admin-header .prediction-status-chip {
  text-transform: none;
}

.resultados-shell .jornada-header {
  flex-wrap: wrap;
}

.resultados-shell .jornada-header > div {
  min-width: 0;
}

.resultados-shell .jornada-header form {
  display: flex;
  flex: 0 1 auto;
  justify-content: flex-end;
  min-width: min(100%, 12rem);
  margin-left: auto;
}

.resultados-shell .jornada-header button {
  max-width: 100%;
  white-space: normal;
  overflow-wrap: anywhere;
  text-align: center;
}

.resultados-shell .jornada-card > .matches-grid,
.resultados-shell .matches-grid-list {
  background: color-mix(in srgb, var(--bg-surface-overlay) 34%, transparent);
  border: var(--border-width-normal) solid var(--glass-border);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-sm);
  backdrop-filter: blur(var(--glass-blur));
}

.resultados-shell .view-switch a,
.resultados-shell .resultados-view-toolbar .quiniela-tab {
  background: var(--btn-ghost-bg);
  color: var(--btn-ghost-text);
  border-color: var(--btn-secondary-border);
}

.resultados-shell .view-switch a.active,
.resultados-shell .resultados-view-toolbar .quiniela-tab.active {
  background: var(--btn-danger-bg);
  color: var(--btn-danger-text);
  border-color: var(--btn-danger-bg);
  box-shadow: var(--glow-danger);
}

.resultados-shell .pronosticos-jornada-strip .quiniela-tab {
  background: var(--danger-bg);
  color: var(--alert-danger-text);
  border-color: var(--alert-danger-border);
  box-shadow: var(--shadow-sm);
}

.resultados-shell .pronosticos-jornada-strip .quiniela-tab:hover,
.resultados-shell .pronosticos-jornada-strip .quiniela-tab:focus-visible {
  background: var(--btn-danger-bg);
  color: var(--btn-danger-text);
  box-shadow: var(--glow-danger);
}

.resultados-shell .result-admin-card .score-label,
.resultados-shell .result-admin-card .score-input {
  color: var(--danger);
  font-family: var(--font-family-secondary);
  font-size: var(--font-size-display-lg);
  border-color: var(--input-border);
}

.resultados-shell .result-admin-card .score-editor {
  border-color: var(--alert-warning-border);
}

.resultados-shell .result-admin-card .score-label {
  background: var(--danger-bg);
  color: var(--alert-danger-text);
  border-color: var(--alert-danger-border);
}

.resultados-shell .result-admin-card .score-input:focus {
  border-color: var(--input-border-focus);
  box-shadow: var(--input-focus-shadow);
}

.resultados-shell .match-state {
  background: var(--danger-bg);
  color: var(--alert-danger-text);
  border: var(--border-width-normal) solid var(--alert-danger-border);
  border-radius: var(--radius-lg);
}

.resultados-shell .match-state strong {
  color: var(--alert-danger-text);
}

.admin-page {
  color: var(--text-primary);
}

.users-community-shell {
  align-content: start;
}

.users-community-hero .player-stat-card strong {
  font-size: clamp(var(--font-size-h4), 3vw, var(--font-size-h2));
}

.users-roster-strip {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
}

.users-roster-chip {
  align-items: center;
  gap: var(--space-2);
  min-height: 42px;
}

.users-roster-chip strong {
  color: var(--achievement-title);
  font-family: var(--font-family-secondary);
}

.users-roster-card .section-header.compact {
  border-radius: var(--radius-xl) var(--radius-xl) 0 0;
}

.users-roster-card .section-kicker {
  display: block;
  margin-bottom: var(--space-1);
}

.admin-hero,
.content-card,
.admin-page .modal-content {
  background: var(--card-bg);
  color: var(--text-primary);
  border: var(--border-width-normal) solid var(--card-border);
  border-radius: var(--radius-xl);
  box-shadow: var(--card-shadow);
}

.admin-hero p,
.section-header span,
.admin-search-field span,
.admin-user-table td:first-child span,
.admin-user-table td:first-child small {
  color: var(--text-muted);
}

.section-header.compact,
.admin-filter-bar,
.admin-page .modal-header,
.admin-page .modal-footer {
  background: var(--bg-surface-1);
  border-color: var(--card-border);
}

.admin-filter-bar {
  border-bottom: var(--border-width-normal) solid var(--card-border);
}

.admin-table-wrap {
  background: var(--table-bg);
  border: var(--border-width-normal) solid var(--table-border);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-sm);
}

.admin-user-table {
  background: var(--table-bg);
  color: var(--table-cell-text);
  border-color: var(--table-border);
}

.admin-user-table th {
  background: var(--table-header-bg);
  color: var(--table-header-text);
  border-color: var(--table-border);
}

.admin-user-table td {
  border-color: var(--table-border);
}

.admin-user-table tbody tr {
  background: var(--table-row-bg);
  transition: var(--transition-default);
}

.admin-user-table tbody tr:nth-child(even) {
  background: var(--table-row-alt-bg);
}

.admin-user-table tbody tr:hover {
  background: var(--table-row-hover-bg);
}

.admin-pill,
.admin-link-button {
  background: var(--badge-bg);
  color: var(--badge-text);
  border: var(--border-width-normal) solid var(--badge-border);
  border-radius: var(--radius-pill);
  transition: var(--transition-default);
}

.admin-pill:hover,
.admin-pill:focus-visible,
.admin-link-button:hover,
.admin-link-button:focus-visible {
  box-shadow: var(--glow-hover);
  transform: scale(var(--hover-scale));
}

.admin-pill.on,
.admin-pill.member {
  background: var(--success-bg);
  color: var(--alert-success-text);
  border-color: var(--alert-success-border);
}

.admin-pill.pending {
  background: var(--warning-bg);
  color: var(--alert-warning-text);
  border-color: var(--alert-warning-border);
}

.admin-pill.processing {
  background: var(--info-bg);
  color: var(--alert-info-text);
  border-color: var(--alert-info-border);
}

.admin-pill.mail-pending {
  background: var(--warning-bg);
  color: var(--alert-warning-text);
  border-color: var(--alert-warning-border);
}

.admin-pill.rejected {
  background: var(--danger-bg);
  color: var(--alert-danger-text);
  border-color: var(--alert-danger-border);
}

.admin-pill.invite {
  background: var(--info-bg);
  color: var(--alert-info-text);
  border-color: var(--alert-info-border);
}

.admin-link-button.danger {
  background: var(--btn-danger-bg);
  color: var(--btn-danger-text);
  border-color: var(--btn-danger-bg);
}

.modal-inline-alert {
  border-radius: var(--radius-lg);
}

.modal-inline-alert.danger {
  background: var(--alert-danger-bg);
  color: var(--alert-danger-text);
  border: var(--border-width-normal) solid var(--alert-danger-border);
}

.admin-page .btn-close {
  filter: none;
}

.mis-quinielas-shell {
  color: var(--text-primary);
}

.mis-quinielas-header p,
.mis-quiniela-card span,
.mis-quiniela-card small,
.member-option small,
.invitation-modal-note,
.random-settings-summary span {
  color: var(--text-muted);
}

.quiniela-segmented-actions,
.tournament-sticky-actions-inner {
  background: var(--glass-bg);
  border: var(--border-width-normal) solid var(--glass-border);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-sm);
  backdrop-filter: blur(var(--glass-blur));
}

.mis-quiniela-card,
.member-option,
.random-settings-summary {
  background: var(--card-bg);
  color: var(--text-primary);
  border: var(--border-width-normal) solid var(--card-border);
  border-radius: var(--radius-xl);
  box-shadow: var(--card-shadow);
  transition: var(--transition-default);
}

button.mis-quiniela-card:hover,
button.mis-quiniela-card:focus-visible,
.mis-quiniela-card.invitation:hover,
.member-option:hover,
.member-option:focus-within {
  background: var(--match-card-hover-bg);
  box-shadow: var(--card-hover-shadow);
  transform: var(--card-hover-transform);
}

.mis-quiniela-card.active,
.mis-quiniela-card.ranking-current-user {
  background: var(--ranking-user-bg);
  color: var(--text-primary);
  border-color: var(--ranking-user-border);
  box-shadow: var(--card-hover-shadow);
}

.mis-quiniela-card.finished {
  background: var(--bg-surface-2);
  border-color: var(--border-light);
}

.mis-quiniela-card strong,
.member-option strong,
.random-settings-summary strong {
  color: var(--text-primary);
}

.mis-quiniela-card img {
  filter: drop-shadow(var(--shadow-sm));
}

.mis-quinielas-hero .game-hero-copy p strong {
  color: var(--game-hero-title);
}

.mis-quinielas-hero .player-stat-card strong {
  font-size: clamp(var(--font-size-h4), 3vw, var(--font-size-h2));
}

.quiniela-status.active {
  background: var(--prediction-saved-bg);
  color: var(--alert-success-text);
  border-color: var(--alert-success-border);
  box-shadow: inset 0 0 0 var(--border-width-normal) color-mix(in srgb, var(--alert-success-border) 55%, transparent);
}

.quiniela-status.finished {
  background: var(--prediction-closed-bg);
  color: var(--prediction-closed-text);
  border-color: var(--badge-border);
  box-shadow: inset 0 0 0 var(--border-width-normal) color-mix(in srgb, var(--badge-border) 55%, transparent);
}

.invitation-actions .team-save,
.invitation-actions .danger-action {
  min-width: calc(var(--space-12) + var(--space-12));
}

.danger-action {
  background: var(--btn-danger-bg);
  color: var(--btn-danger-text);
  border: var(--border-width-normal) solid var(--btn-danger-bg);
  border-radius: var(--radius-lg);
  transition: var(--transition-default);
}

.danger-action:hover,
.danger-action:focus-visible {
  background: var(--btn-danger-hover-bg);
  color: var(--btn-danger-text);
  box-shadow: var(--glow-danger);
  transform: scale(var(--hover-scale));
}

.invitation-focus-modal .modal-content,
.tournament-modal .modal-content {
  background: var(--modal-bg);
  color: var(--text-primary);
  border: var(--border-width-normal) solid var(--modal-border);
  border-radius: var(--radius-2xl);
  box-shadow: var(--modal-shadow);
}

.invitation-focus-modal .modal-header,
.tournament-modal .modal-header {
  background: var(--modal-header-bg);
  border-color: var(--modal-border);
}

.tournament-modal .modal-footer {
  background: var(--modal-footer-bg);
  border-color: var(--modal-border);
}

.tournament-admin {
  color: var(--text-primary);
}

.tournament-list,
.tournament-journey-card,
.tournament-matches-card,
.tournament-logo-preview,
.tournament-match-row,
.tournament-phase-row label {
  background: var(--card-bg);
  color: var(--text-primary);
  border-color: var(--card-border);
  box-shadow: var(--card-shadow);
}

.tournament-card-header,
.tournament-header-actions,
.tournament-sticky-actions-inner,
.tournament-journey-strip,
.tournament-match-list {
  background: var(--glass-bg);
  color: var(--text-primary);
  border-color: var(--glass-border);
  box-shadow: var(--shadow-sm);
  backdrop-filter: blur(var(--glass-blur));
}

.tournament-section-title span,
.tournament-journey-strip span,
.tournament-match-sequence span,
.tournament-match-time span,
.tournament-logo-preview span {
  color: var(--text-muted);
}

.tournament-section-title h2,
.tournament-match-sequence strong,
.tournament-versus strong,
.tournament-match-time strong {
  color: var(--card-title);
}

.tournament-row.active button,
.tournament-row button[aria-current="true"] {
  background: var(--ranking-user-bg);
  color: var(--text-primary);
  border-color: var(--ranking-user-border);
  box-shadow: var(--card-hover-shadow);
}

.tournament-row.active strong,
.tournament-row button[aria-current="true"] strong {
  color: var(--text-link-hover);
}

.tournament-journey-strip button {
  background: var(--btn-secondary-bg);
  color: var(--btn-secondary-text);
  border-color: var(--btn-secondary-border);
  border-radius: var(--radius-lg);
  transition: var(--transition-default);
}

.tournament-journey-strip button:hover,
.tournament-journey-strip button:focus-visible {
  background: var(--btn-secondary-hover-bg);
  color: var(--btn-secondary-text);
  box-shadow: var(--glow-hover);
  transform: scale(var(--hover-scale));
}

.tournament-journey-strip button.active {
  background: var(--btn-primary-bg);
  color: var(--btn-primary-text);
  border-color: var(--btn-primary-border);
  box-shadow: var(--glow-hover);
}

.tournament-journey-strip button.active span,
.tournament-journey-strip button.active strong {
  color: var(--btn-primary-text);
}

.tournament-match-sequence strong {
  background: var(--badge-bg);
  color: var(--badge-text);
  border: var(--border-width-normal) solid var(--badge-border);
  border-radius: var(--radius-lg);
}

.tournament-match-row:hover,
.tournament-match-row:focus-within {
  background: var(--match-card-hover-bg);
  border-color: var(--border-focus);
  box-shadow: var(--card-hover-shadow);
}

.tournament-versus img,
.tournament-logo-preview img {
  background: var(--bg-surface-2);
  border: var(--border-width-normal) solid var(--border-light);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
}

.tournament-match-actions button {
  background: var(--btn-primary-bg);
  color: var(--btn-primary-text);
  border: var(--border-width-normal) solid var(--btn-primary-border);
  border-radius: var(--radius-lg);
  transition: var(--transition-default);
}

.tournament-match-actions button:hover,
.tournament-match-actions button:focus-visible {
  background: var(--btn-primary-hover-bg);
  color: var(--btn-primary-text);
  box-shadow: var(--glow-hover);
  transform: scale(var(--hover-scale));
}

.tournament-match-actions button.danger {
  background: var(--btn-danger-bg);
  color: var(--btn-danger-text);
  border-color: var(--btn-danger-bg);
}

.tournament-match-actions button.danger:hover,
.tournament-match-actions button.danger:focus-visible {
  background: var(--btn-danger-hover-bg);
  color: var(--btn-danger-text);
  box-shadow: var(--glow-danger);
}

.tournament-phase-row input {
  accent-color: var(--color-brand-primary);
}

.team-save.secondary {
  background: var(--btn-secondary-bg);
  color: var(--btn-secondary-text);
  border-color: var(--btn-secondary-border);
}

.team-save.secondary:hover,
.team-save.secondary:focus-visible {
  background: var(--btn-secondary-hover-bg);
  color: var(--btn-secondary-text);
}

.team-field span,
.member-picker-header strong {
  color: var(--text-secondary);
}

.member-picker {
  background: var(--bg-surface-2);
  border: var(--border-width-normal) solid var(--border-light);
  border-radius: var(--radius-xl);
}

.member-picker-header button {
  background: var(--btn-secondary-bg);
  color: var(--btn-secondary-text);
  border: var(--border-width-normal) solid var(--btn-secondary-border);
  border-radius: var(--radius-lg);
  transition: var(--transition-default);
}

.member-picker-header button:hover,
.member-picker-header button:focus-visible {
  background: var(--btn-secondary-hover-bg);
  box-shadow: var(--glow-hover);
}

.member-option input {
  accent-color: var(--color-brand-primary);
}

.settings-quiniela-shell {
  color: var(--text-primary);
}

.settings-quiniela-shell .tournament-card-header p,
.random-settings-summary span,
.settings-quiniela-shell .team-field > span:first-child {
  color: var(--text-muted);
}

.random-mode-hero .player-stat-card strong {
  font-size: clamp(var(--font-size-h4), 3vw, var(--font-size-h2));
}

.random-mode-hero .game-primary-cta.settings-state {
  border: var(--border-width-normal) solid var(--badge-border);
}

.random-mode-hero .game-primary-cta.settings-state.active {
  border-color: var(--alert-success-border);
}

.settings-state {
  background: var(--badge-bg);
  color: var(--badge-text);
  border: var(--border-width-normal) solid var(--badge-border);
  border-radius: var(--radius-pill);
  transition: var(--transition-default);
}

.settings-state.active {
  background: var(--success-bg);
  color: var(--alert-success-text);
  border-color: var(--alert-success-border);
}

.settings-state.as-button:hover,
.settings-state.as-button:focus-visible {
  box-shadow: var(--glow-hover);
  transform: scale(var(--hover-scale));
}

.random-settings-card,
.random-settings-summary,
.random-range-panel {
  background: var(--card-bg);
  color: var(--text-primary);
  border-color: var(--card-border);
  box-shadow: var(--card-shadow);
}

.random-settings-summary {
  border: var(--border-width-normal) solid var(--card-border);
  background: var(--player-card-bg);
}

.random-range-panel h2 {
  color: var(--card-title);
}

.settings-readonly-value {
  background: var(--prediction-bg);
  color: var(--prediction-text);
  border: var(--border-width-normal) solid var(--prediction-border);
  border-radius: var(--radius-lg);
}

.settings-alert.warning,
.alert-warning {
  background: var(--alert-warning-bg);
  color: var(--alert-warning-text);
  border-color: var(--alert-warning-border);
}

.notification-settings-shell {
  color: var(--text-primary);
}

.notification-hub-hero .player-stat-card strong {
  font-size: clamp(var(--font-size-h4), 3vw, var(--font-size-h2));
}

.notification-settings-shell .tournament-card-header p,
.notification-preference-row > div > span {
  color: var(--text-muted);
}

.notification-settings-card {
  background: var(--card-bg);
  border-color: var(--card-border);
  box-shadow: var(--card-shadow);
}

.notification-preference-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: var(--space-4);
  align-items: center;
  background: var(--card-bg);
  color: var(--text-primary);
  border: var(--border-width-normal) solid var(--card-border);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-sm);
  transition: var(--transition-default);
}

.notification-preference-row > div {
  display: grid;
  gap: var(--space-2);
  min-width: 0;
}

.notification-preference-row > div > .section-kicker {
  margin: 0;
}

.notification-preference-row:hover,
.notification-preference-row:focus-within {
  background: var(--match-card-hover-bg);
  box-shadow: var(--card-hover-shadow);
  transform: var(--card-hover-transform);
}

.notification-preference-row.enabled {
  background: var(--ranking-user-bg);
  border-color: var(--ranking-user-border);
}

.notification-preference-row strong {
  color: var(--text-primary);
  font-family: var(--font-family-secondary);
  font-size: var(--font-size-h4);
  line-height: var(--line-height-tight);
  overflow-wrap: anywhere;
  white-space: normal;
}

.notification-toggle {
  background: var(--badge-bg);
  border: var(--border-width-normal) solid var(--badge-border);
  border-radius: var(--radius-pill);
  transition: var(--transition-default);
}

.notification-toggle span {
  background: var(--bg-card);
  box-shadow: var(--shadow-sm);
  transition: var(--transition-default);
}

.notification-preference-row.enabled .notification-toggle {
  background: var(--success);
  border-color: var(--alert-success-border);
  box-shadow: var(--glow-hover);
}

.team-admin,
.email-admin {
  color: var(--text-primary);
}

.email-ops-hero .email-status {
  justify-self: start;
}

.email-ops-hero .player-stat-card strong {
  font-size: clamp(var(--font-size-body-lg), 2.6vw, var(--font-size-h3));
}

.email-console-card {
  overflow: hidden;
}

.email-console-card .email-settings-form {
  gap: var(--space-4);
}

.email-console-card .team-two-cols {
  gap: var(--space-4);
}

.sports-studio-hero .player-stat-card strong,
.team-catalog-hero .player-stat-card strong {
  font-size: clamp(var(--font-size-h4), 3vw, var(--font-size-h2));
}

.sports-studio-search {
  width: min(100%, 34rem);
  margin-top: var(--space-2);
}

.sports-studio-search input {
  min-width: 0;
}

.team-admin-hero,
.team-editor,
.team-list,
.team-image-preview,
.team-row button,
.email-admin .content-card,
.email-toggle,
.email-security-note {
  background: var(--card-bg);
  color: var(--text-primary);
  border: var(--border-width-normal) solid var(--card-border);
  border-radius: var(--radius-xl);
  box-shadow: var(--card-shadow);
}

.team-admin-hero p,
.team-field,
.team-field small,
.team-list-header span,
.team-row small,
.team-image-preview span,
.email-toggle small,
.email-security-note span,
.email-form-footer small,
.email-admin .team-field small {
  color: var(--text-muted);
}

.team-admin-kicker {
  color: var(--color-brand-highlight);
}

.team-admin-hero h1,
.team-editor h2,
.team-list h2,
.team-row strong {
  color: var(--card-title);
}

.team-search input,
.team-field input,
.team-field select {
  background: var(--input-bg);
  color: var(--input-text);
  border-color: var(--input-border);
  border-radius: var(--radius-lg);
  transition: var(--transition-default);
}

.team-search input::placeholder,
.team-field input::placeholder {
  color: var(--input-placeholder);
}

.team-search input:focus,
.team-field input:focus,
.team-field select:focus {
  background: var(--input-bg);
  color: var(--input-text);
  border-color: var(--input-border-focus);
  box-shadow: var(--input-focus-shadow);
  outline: none;
}

.team-search button {
  background: var(--btn-primary-bg);
  color: var(--btn-primary-text);
  border: var(--border-width-normal) solid var(--btn-primary-border);
  border-radius: var(--radius-lg);
  transition: var(--transition-default);
}

.team-search button:hover,
.team-search button:focus-visible {
  background: var(--btn-primary-hover-bg);
  color: var(--btn-primary-text);
  box-shadow: var(--glow-hover);
  transform: scale(var(--hover-scale));
}

.team-image-preview {
  background: var(--bg-surface-2);
  border-color: var(--border-light);
}

.team-image-preview.flag {
  border-color: var(--prediction-border);
  box-shadow: var(--glow-gold);
}

.team-row button:hover,
.team-row button:focus-visible {
  background: var(--match-card-hover-bg);
  border-color: var(--border-focus);
  box-shadow: var(--card-hover-shadow);
  transform: var(--card-hover-transform);
}

.team-row img {
  background: var(--bg-surface-2);
  border: var(--border-width-normal) solid var(--border-light);
  border-radius: var(--radius-lg);
}

.email-status {
  background: var(--badge-bg);
  color: var(--badge-text);
  border: var(--border-width-normal) solid var(--badge-border);
  border-radius: var(--radius-pill);
}

.email-status.enabled {
  background: var(--success-bg);
  color: var(--alert-success-text);
  border-color: var(--alert-success-border);
}

.email-status.disabled {
  background: var(--badge-bg);
  color: var(--badge-text);
  border-color: var(--badge-border);
}

.email-toggle {
  transition: var(--transition-default);
}

.email-toggle:hover,
.email-toggle:focus-within {
  box-shadow: var(--card-hover-shadow);
  transform: var(--card-hover-transform);
}

.email-toggle input {
  accent-color: var(--color-brand-primary);
}

.email-security-note {
  background: var(--info-bg);
  border-color: var(--alert-info-border);
}

.email-security-note strong {
  color: var(--alert-info-text);
}

.email-form-footer {
  border-top: var(--border-width-normal) solid var(--card-border);
}

.quiniela-toolbar,
.tabla-audit-tabs,
.tabla-modern-switch,
.tabla-journey-tabs {
  background: var(--glass-bg);
  border: var(--border-width-normal) solid var(--glass-border);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-lg);
  backdrop-filter: blur(var(--glass-blur));
}

.quiniela-tab,
.tabla-audit-tabs button,
.tabla-modern-switch button,
.tabla-journey-tabs button {
  background: var(--btn-ghost-bg);
  color: var(--btn-ghost-text);
  border: var(--border-width-normal) solid var(--btn-secondary-border);
  border-radius: var(--radius-pill);
  transition: var(--transition-default);
}

.quiniela-tab:hover,
.quiniela-tab:focus-visible,
.tabla-audit-tabs button:hover,
.tabla-audit-tabs button:focus-visible,
.tabla-modern-switch button:hover,
.tabla-modern-switch button:focus-visible,
.tabla-journey-tabs button:hover,
.tabla-journey-tabs button:focus-visible {
  background: var(--btn-ghost-hover-bg);
  color: var(--btn-ghost-hover-text);
  text-decoration: none;
}

.quiniela-tab.active,
.tabla-audit-tabs button.active,
.tabla-modern-switch button.active,
.tabla-journey-tabs button.active {
  background: var(--btn-gold-bg);
  color: var(--btn-gold-text);
  border-color: var(--btn-gold-border);
  box-shadow: var(--glow-gold);
  text-decoration: none;
}

.quiniela-tab.active *,
.tabla-audit-tabs button.active *,
.tabla-modern-switch button.active *,
.tabla-journey-tabs button.active * {
  color: inherit;
}

.standings-table-wrap,
.table-responsive {
  background: var(--table-bg);
  border: var(--border-width-normal) solid var(--table-border);
  border-radius: var(--radius-xl);
}

.standings-table th,
.standings-table td,
.tabla-modern-table th,
.tabla-modern-table td,
.tabla-audit-table th,
.tabla-audit-table td {
  border-bottom: var(--border-width-normal) solid var(--table-border);
}

.standings-table th,
.tabla-modern-table th,
.tabla-audit-table th {
  background: var(--table-header-bg);
  color: var(--table-header-text);
}

.standings-table tbody tr,
.tabla-modern-table tbody tr,
.tabla-audit-table tbody tr {
  background: var(--table-row-bg);
}

.standings-table tbody tr:nth-child(even),
.tabla-modern-table tbody tr:nth-child(even),
.tabla-audit-table tbody tr:nth-child(even) {
  background: var(--table-row-alt-bg);
}

.tabla-player-focus-card,
.juegos-player-focus-card {
  background: var(--glass-bg);
  border-color: var(--glass-border);
  box-shadow: var(--shadow-sm);
  backdrop-filter: none;
}

.tabla-audit-table.general tbody td.diff-value {
  color: var(--stat-neutral);
  font-weight: 800;
}

.tabla-audit-table.general tbody td.diff-value.stat-negative {
  color: var(--stat-negative);
  background: var(--prediction-wrong-bg);
}

.tabla-audit-table.general tbody td.diff-value.stat-positive {
  color: var(--stat-positive);
}

.position-badge {
  background: var(--badge-bg);
  color: var(--badge-text);
  border: var(--border-width-normal) solid var(--badge-border);
  border-radius: var(--radius-lg);
}

.diff-badge {
  background: var(--prediction-bg);
  color: var(--prediction-text);
  border-color: var(--prediction-border);
}

.diff-badge.stat-positive {
  color: var(--stat-positive);
  border-color: var(--stat-positive);
}

.diff-badge.stat-negative {
  background: var(--prediction-wrong-bg);
  color: var(--stat-negative);
  border-color: var(--stat-negative);
  font-weight: 800;
}

.diff-badge.stat-neutral {
  background: var(--prediction-bg);
  color: var(--stat-neutral);
}

.score-box {
  border: var(--border-width-normal) solid var(--badge-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
}

.score-box.green {
  background: var(--ranking-first-bg);
  color: var(--player-level-text);
  border-color: var(--ranking-podium-border);
}

.score-box.gold {
  background: var(--ranking-second-bg);
  color: var(--text-primary);
  border-color: var(--ranking-podium-border);
}

.score-box.coral {
  background: var(--ranking-third-bg);
  color: var(--player-level-text);
  border-color: var(--ranking-podium-border);
}

.home-prediction-score {
  background: var(--prediction-bg);
  color: var(--prediction-text);
  border: var(--border-width-normal) solid var(--prediction-border);
  border-radius: var(--radius-lg);
}

.app-avatar,
.settings-avatar {
  background: var(--bg-surface-2);
  border: var(--border-width-normal) solid var(--border-light);
  box-shadow: var(--shadow-sm);
}

*:focus-visible {
  outline: var(--focus-ring-width, var(--border-width-normal)) solid var(--focus-ring-color, var(--border-focus));
  outline-offset: var(--focus-ring-offset, var(--space-1));
}

@media (max-width: 768px) {
  .app-sidebar {
    width: var(--mobile-sidebar-width);
  }

  .app-card,
  .settings-card,
  .quiniela-card,
  .settings-header,
  .match-card {
    border-radius: var(--radius-lg);
  }

  .app-table,
  .table {
    display: block;
    overflow-x: auto;
  }
}

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

/* ========================= GAME EXPERIENCE COMPONENTS ========================= */
.game-shell {
  display: grid;
  gap: var(--space-5);
}

.game-shell > * {
  min-width: 0;
}

.game-hub {
  align-content: start;
}

.game-hero {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1.35fr) minmax(280px, 0.9fr);
  gap: var(--space-5);
  align-items: stretch;
  padding: var(--space-6);
  background: var(--game-hero-bg);
  border: var(--border-width-normal) solid var(--game-hero-border);
  border-radius: var(--radius-2xl);
  box-shadow: var(--game-hero-shadow);
  color: var(--game-hero-title);
  overflow: hidden;
  box-sizing: border-box;
}

.game-hero-copy {
  display: grid;
  align-content: center;
  gap: var(--space-3);
  min-width: 0;
}

.game-hero h1,
.game-hero h2 {
  margin: 0;
  color: var(--game-hero-title);
  font-family: var(--font-family-secondary);
  font-size: clamp(var(--font-size-h2), 5vw, var(--font-size-display-lg));
  line-height: var(--line-height-tight);
}

.game-hero p {
  max-width: 64ch;
  margin: 0;
  color: var(--game-hero-subtitle);
  font-size: var(--font-size-body);
}

.game-hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  margin-top: var(--space-2);
}

.game-primary-cta {
  min-height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding-inline: var(--space-5);
  color: var(--btn-primary-text);
  text-decoration: none;
}

.game-hero .app-button-primary,
.game-hero .app-button-secondary {
  min-height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding-inline: var(--space-5);
  text-decoration: none;
}

.game-hero .app-button-primary,
.game-hero .app-button-primary:hover,
.game-hero .app-button-primary:focus-visible,
.game-hero .game-primary-cta,
.game-hero .game-primary-cta:hover,
.game-hero .game-primary-cta:focus-visible {
  color: var(--btn-primary-text);
}

.game-hero .app-button-secondary,
.game-hero .app-button-secondary:hover,
.game-hero .app-button-secondary:focus-visible {
  color: var(--btn-secondary-text);
  text-decoration: none;
}

.game-hero .game-ranking-cta {
  min-height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding-inline: var(--space-5);
  background: var(--btn-secondary-bg);
  border: var(--border-width-normal) solid var(--btn-secondary-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  font-weight: 800;
}

.game-hero .game-ranking-cta:hover,
.game-hero .game-ranking-cta:focus-visible {
  background: var(--btn-secondary-hover-bg);
  color: var(--btn-secondary-hover-text);
  border-color: var(--btn-secondary-hover-border);
  box-shadow: var(--btn-secondary-focus-shadow);
}

.game-primary-cta:hover,
.game-primary-cta:focus-visible,
.game-hero-actions a,
.view-switch a,
.pronosticos-jornada-strip a,
.quiniela-tab {
  text-decoration: none;
}

.player-summary {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-3);
}

.player-stat-card {
  display: grid;
  gap: var(--space-2);
  min-width: 0;
  padding: var(--space-4);
  background: var(--player-card-bg);
  border: var(--border-width-normal) solid var(--player-card-border);
  border-radius: var(--radius-xl);
  box-shadow: var(--player-card-shadow);
}

a.player-stat-card,
button.player-stat-card {
  color: var(--text-primary);
  text-decoration: none;
  transition: var(--transition-default);
}

a.player-stat-card:hover,
button.player-stat-card:hover,
a.player-stat-card:focus-visible,
button.player-stat-card:focus-visible {
  color: var(--text-primary);
  box-shadow: var(--card-hover-shadow);
  transform: var(--card-hover-transform);
}

button.player-stat-card {
  width: 100%;
  border: var(--border-width-normal) solid var(--player-card-border);
  text-align: left;
}

.player-stat-card.disabled {
  opacity: 0.72;
}

.player-stat-card span,
.player-stat-card small,
.ranking-user-card small,
.ranking-podium-card small {
  color: var(--text-muted);
}

.player-stat-card strong {
  min-width: 0;
  color: var(--text-primary);
  font-family: var(--font-family-secondary);
  font-size: var(--font-size-h2);
  line-height: var(--line-height-tight);
  overflow-wrap: anywhere;
  white-space: normal;
}

.player-stat-card strong.stat-positive,
.ranking-user-metrics strong.stat-positive {
  color: var(--stat-positive);
}

.player-stat-card strong.stat-negative,
.ranking-user-metrics strong.stat-negative {
  color: var(--stat-negative);
}

.player-stat-card strong.stat-neutral,
.ranking-user-metrics strong.stat-neutral {
  color: var(--stat-neutral);
}

.player-stat-card.primary {
  background: var(--ranking-current-user-bg);
  border-color: var(--ranking-podium-border);
}

.prediction-progress {
  display: grid;
  gap: var(--space-2);
  width: min(100%, 34rem);
  margin-top: var(--space-2);
  padding: var(--space-3);
  background: var(--player-card-bg);
  border: var(--border-width-normal) solid var(--player-card-border);
  border-radius: var(--radius-xl);
  box-shadow: var(--player-card-shadow);
}

.pronosticos-toolbar {
  grid-template-columns: minmax(0, 1fr) minmax(320px, 1.08fr);
}

.pronosticos-toolbar .pronosticos-hero-side {
  align-content: stretch;
}

.prediction-progress-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  color: var(--text-secondary);
  font-size: var(--font-size-body-sm);
  font-weight: var(--font-weight-bold);
}

.prediction-progress-header strong {
  color: var(--text-primary);
  font-family: var(--font-family-secondary);
}

.prediction-progress-track {
  height: 10px;
  overflow: hidden;
  background: var(--score-editor-bg);
  border: var(--border-width-normal) solid var(--score-editor-border);
  border-radius: var(--radius-pill);
}

.prediction-progress-track span {
  display: block;
  width: var(--progress, 0%);
  height: 100%;
  background: var(--game-mode-cta-bg);
  border-radius: inherit;
  transition: width var(--motion-duration-ranking-change) var(--motion-ease-decelerate);
}

.prediction-progress small {
  color: var(--text-muted);
}

.pronosticos-hero-side,
.prediction-quick-stats {
  display: grid;
  gap: var(--space-3);
  min-width: 0;
}

.prediction-quick-stats {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.prediction-progress.hero-progress {
  grid-column: 1 / -1;
  width: 100%;
  margin-top: 0;
}

.prediction-quick-stats .player-stat-card {
  padding: var(--space-3);
}

.prediction-quick-stats .player-stat-card strong {
  font-size: var(--font-size-h3);
}

.game-action-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: var(--space-4);
}

.game-action-card {
  display: grid;
  align-content: start;
  gap: var(--space-3);
  min-width: 0;
  padding: var(--space-4);
  background: var(--player-card-bg);
  border: var(--border-width-normal) solid var(--player-card-border);
  border-radius: var(--radius-xl);
  box-shadow: var(--player-card-shadow);
  color: var(--text-primary);
  text-decoration: none;
  transition: var(--transition-default);
}

.game-action-card:hover,
.game-action-card:focus-visible {
  color: var(--text-primary);
  box-shadow: var(--game-mode-shadow);
  transform: var(--card-hover-transform);
}

.game-action-card.primary {
  border-color: var(--ranking-user-border);
  background: var(--ranking-current-user-bg);
}

.game-action-card strong {
  min-width: 0;
  color: var(--text-primary);
  font-family: var(--font-family-secondary);
  font-size: var(--font-size-h3);
  line-height: var(--line-height-tight);
}

.game-action-card small {
  color: var(--text-secondary);
}

.graficos-shell {
  display: grid;
  gap: var(--space-5);
}

.graficos-hero .player-summary.compact {
  align-content: start;
}

.ranking-graph-card {
  overflow: hidden;
}

.competition-chart-card {
  scroll-margin-top: calc(var(--topbar-height, 76px) + 5rem);
}

.graficos-mode-tabs .quiniela-tab {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 3rem;
  border: var(--border-width-normal) solid var(--btn-secondary-border);
  border-radius: var(--radius-pill);
  background: var(--btn-secondary-bg);
  color: var(--tab-text);
  text-decoration: none;
}

.graficos-mode-tabs .quiniela-tab.active {
  background: var(--btn-gold-bg);
  border-color: var(--btn-gold-border);
  color: var(--btn-gold-text);
  box-shadow: var(--glow-gold);
}

.ranking-chart-wrap {
  padding: var(--space-4);
  overflow-x: auto;
  scrollbar-width: thin;
}

.ranking-chart {
  width: 100%;
  min-width: 760px;
  min-height: 320px;
}

.ranking-chart-axis,
.ranking-chart-gridline,
.ranking-chart-line,
.ranking-chart-point {
  vector-effect: non-scaling-stroke;
}

.ranking-chart-axis {
  stroke: var(--table-border);
  stroke-width: 3;
}

.ranking-chart-gridline {
  stroke: var(--table-border);
  stroke-width: 1;
  stroke-dasharray: 5 8;
  opacity: 0.55;
}

.ranking-chart-line {
  fill: none;
  stroke: var(--stat-highlight);
  stroke-width: 5;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-dasharray: 12 12;
}

.ranking-chart-point {
  fill: var(--game-mode-cta-bg);
  stroke: var(--game-mode-cta-text);
  stroke-width: 4;
}

.ranking-chart-point.best {
  fill: var(--stat-positive);
}

.ranking-chart-label,
.ranking-chart-position {
  fill: var(--text-secondary);
  font-family: var(--font-family-primary);
  font-size: var(--font-size-caption);
  font-weight: var(--font-weight-bold);
}

.ranking-chart-position {
  fill: var(--text-primary);
  text-anchor: middle;
}

.ranking-chart-x-label {
  text-anchor: end;
  dominant-baseline: middle;
}

.ranking-insight-strip {
  display: flex;
  gap: var(--space-3);
  padding: var(--space-4);
  border-top: var(--border-width-normal) solid var(--card-border);
  overflow-x: auto;
  overflow-y: hidden;
  scroll-snap-type: x proximity;
  scrollbar-width: thin;
  scrollbar-color: var(--scrollbar-thumb) transparent;
}

.ranking-insight-pill {
  flex: 0 0 clamp(10rem, 16vw, 13.5rem);
  display: grid;
  gap: var(--space-1);
  min-width: 0;
  padding: var(--space-3);
  background: var(--player-card-bg);
  border: var(--border-width-normal) solid var(--player-card-border);
  border-radius: var(--radius-lg);
  scroll-snap-align: start;
}

.ranking-insight-strip::-webkit-scrollbar {
  height: 0.45rem;
}

.ranking-insight-strip::-webkit-scrollbar-thumb {
  background: var(--scrollbar-thumb);
  border-radius: var(--radius-pill);
}

.ranking-insight-pill span,
.ranking-insight-pill small {
  color: var(--text-secondary);
}

.ranking-insight-pill strong {
  color: currentColor;
  font-family: var(--font-family-secondary);
  font-size: var(--font-size-h3);
}

.competition-center-shell {
  gap: var(--space-4);
}

.competition-hero {
  align-items: stretch;
}

.competition-hero-stats .player-stat-card strong {
  font-size: clamp(var(--font-size-h3), 3.2vw, var(--font-size-h2));
  line-height: var(--line-height-tight);
}

.competition-grid,
.competition-lanes {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--space-4);
  width: 100%;
}

.competition-lanes {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.competition-lanes-three {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.competition-feature-card,
.competition-lane,
.competition-events-panel {
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  gap: var(--space-3);
  min-width: 0;
  padding: var(--space-4);
  background: var(--player-card-bg);
  border: var(--border-width-normal) solid var(--player-card-border);
  border-radius: var(--radius-2xl);
  box-shadow: var(--player-card-shadow);
  color: var(--text-primary);
  backdrop-filter: none;
  scroll-margin-top: calc(var(--topbar-height, 76px) + 5rem);
}

.competition-feature-card h2,
.competition-lane h2,
.competition-events-panel h2 {
  margin: 0;
  color: var(--text-primary);
  font-size: var(--font-size-h3);
  line-height: var(--line-height-tight);
}

.competition-feature-card p,
.competition-feature-card small,
.competition-empty,
.competition-event-row small,
.competition-movement-card small {
  margin: 0;
  color: var(--text-secondary);
}

.competition-duel-meter {
  display: grid;
  gap: var(--space-1);
  padding: var(--space-3);
  background: var(--player-card-bg);
  border: var(--border-width-normal) solid var(--player-card-border);
  border-radius: var(--radius-xl);
}

.competition-duel-meter span {
  color: var(--text-secondary);
  font-size: var(--font-size-caption);
  font-weight: var(--font-weight-bold);
  text-transform: uppercase;
}

.competition-duel-meter strong {
  color: var(--stat-highlight);
  font-family: var(--font-family-secondary);
  font-size: var(--font-size-h2);
}

.competition-pulse-bars {
  display: grid;
  gap: var(--space-2);
}

.competition-pulse-bars span {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
  min-height: 3rem;
  padding: var(--space-2) var(--space-3);
  overflow: hidden;
  background: var(--player-card-bg);
  border: var(--border-width-normal) solid var(--stat-positive);
  border-radius: var(--radius-pill);
  color: var(--text-primary);
  font-weight: var(--font-weight-bold);
}

.competition-pulse-bars span::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: var(--pulse-size, 10%);
  background: color-mix(in srgb, var(--stat-positive) 24%, transparent);
  pointer-events: none;
}

.competition-pulse-bars span.danger {
  border-color: var(--stat-negative);
}

.competition-pulse-bars span.danger::before {
  background: color-mix(in srgb, var(--stat-negative) 22%, transparent);
}

.competition-pulse-bars strong {
  position: relative;
  z-index: 1;
  font-family: var(--font-family-secondary);
}

.competition-leader-list,
.competition-movement-list,
.competition-event-list,
.competition-race-list,
.competition-volatility-list {
  display: grid;
  gap: var(--space-2);
}

.competition-scroll-list {
  max-height: 100%;
  overflow-y: auto;
  padding-right: var(--space-1);
  scrollbar-width: thin;
  scrollbar-color: var(--scrollbar-thumb) transparent;
}

.competition-lane > .competition-movement-list,
.competition-lane > .competition-event-list,
.competition-lane > .competition-race-list,
.competition-lane > .competition-volatility-list,
.competition-feature-card > .competition-stat-grid,
.competition-feature-card > .competition-duel-meter {
  min-height: 0;
  overflow-y: auto;
  padding-right: var(--space-1);
  scrollbar-width: thin;
  scrollbar-color: var(--scrollbar-thumb) transparent;
}

.competition-scroll-list::-webkit-scrollbar {
  width: 0.45rem;
}

.competition-scroll-list::-webkit-scrollbar-thumb {
  background: var(--scrollbar-thumb);
  border-radius: var(--radius-pill);
}

.competition-leader-row,
.competition-movement-card,
.competition-event-row,
.competition-race-row,
.competition-roller-row,
.competition-volatility-row {
  display: grid;
  gap: var(--space-2);
  min-width: 0;
  padding: var(--space-3);
  background: var(--player-card-bg);
  border: var(--border-width-normal) solid var(--player-card-border);
  border-radius: var(--radius-xl);
}

.competition-leader-row {
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
}

.competition-leader-row.current {
  border-color: var(--border-focus);
  box-shadow: var(--glow-focus);
}

.competition-leader-row span,
.movement-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.25rem;
  height: 2.25rem;
  border-radius: var(--radius-pill);
  background: var(--player-level-bg);
  color: var(--player-level-text);
  font-family: var(--font-family-secondary);
  font-weight: var(--font-weight-extrabold);
}

.competition-leader-row strong,
.competition-movement-card strong {
  overflow-wrap: anywhere;
}

.competition-movement-card {
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
}

.competition-movement-card.up {
  border-color: color-mix(in srgb, var(--stat-positive) 54%, var(--player-card-border));
}

.competition-movement-card.down {
  border-color: color-mix(in srgb, var(--stat-negative) 54%, var(--player-card-border));
}

.competition-movement-card.up .movement-badge {
  background: var(--stat-positive);
}

.competition-movement-card.down .movement-badge {
  background: var(--stat-negative);
}

.competition-movement-card b,
.competition-event-row span {
  color: var(--text-primary);
  font-family: var(--font-family-secondary);
  white-space: nowrap;
}

.competition-chart-card .quiniela-card-header p {
  margin: var(--space-1) 0 0;
  color: var(--text-secondary);
}

.competition-events-panel {
  width: 100%;
}

.competition-event-row {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
}

.competition-event-row > small {
  grid-column: 1 / -1;
}

.competition-stat-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-2);
}

.competition-stat-grid span {
  display: grid;
  gap: var(--space-1);
  min-width: 0;
  padding: var(--space-3);
  background: var(--player-card-bg);
  border: var(--border-width-normal) solid var(--player-card-border);
  border-radius: var(--radius-xl);
  color: var(--text-secondary);
  font-size: var(--font-size-caption);
  font-weight: var(--font-weight-bold);
  text-transform: uppercase;
}

.competition-stat-grid strong {
  color: var(--text-primary);
  font-family: var(--font-family-secondary);
  font-size: var(--font-size-h2);
  line-height: 1;
}

.competition-race-row strong,
.competition-roller-row strong,
.competition-volatility-row strong {
  overflow-wrap: anywhere;
}

.competition-race-row > span {
  display: block;
  padding: var(--space-2) var(--space-3);
  overflow-x: auto;
  background: color-mix(in srgb, var(--stat-highlight) 12%, var(--player-card-bg));
  border: var(--border-width-normal) solid var(--player-card-border);
  border-radius: var(--radius-pill);
  color: var(--text-primary);
  font-family: var(--font-family-secondary);
  font-weight: var(--font-weight-bold);
  white-space: nowrap;
  scrollbar-width: thin;
}

.competition-roller-row {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  align-items: center;
}

.competition-roller-row strong,
.competition-roller-row small {
  grid-column: 1 / -1;
}

.competition-roller-row span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2.35rem;
  padding: var(--space-1) var(--space-2);
  background: var(--player-level-bg);
  border-radius: var(--radius-pill);
  color: var(--player-level-text);
  font-weight: var(--font-weight-bold);
  text-align: center;
}

.competition-volatility-row {
  position: relative;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  overflow: hidden;
}

.competition-volatility-row::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: var(--volatility-size, 10%);
  background: color-mix(in srgb, var(--stat-highlight) 20%, transparent);
  pointer-events: none;
}

.competition-volatility-row > * {
  position: relative;
  z-index: 1;
}

.competition-volatility-row span {
  color: var(--text-primary);
  font-family: var(--font-family-secondary);
  font-size: var(--font-size-h3);
  font-weight: var(--font-weight-extrabold);
}

.competition-empty {
  padding: var(--space-3);
  background: var(--player-card-bg);
  border: var(--border-width-normal) dashed var(--player-card-border);
  border-radius: var(--radius-xl);
}

.live-status-chip,
.countdown-chip,
.prediction-status-chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: fit-content;
  max-width: 100%;
  min-height: 30px;
  padding: var(--space-1) var(--space-3);
  border-radius: var(--radius-pill);
  font-size: var(--font-size-caption);
  font-weight: var(--font-weight-bold);
  text-transform: uppercase;
  letter-spacing: 0;
  white-space: nowrap;
}

.live-status-chip,
.countdown-chip {
  background: var(--match-date-chip-bg);
  color: var(--match-date-chip-text);
  border: var(--border-width-normal) solid var(--match-card-border);
}

.live-status-chip.finished {
  background: var(--prediction-closed-bg);
  color: var(--prediction-closed-text);
  border-color: var(--badge-border);
}

.prediction-status-chip.available {
  background: var(--prediction-available-bg);
  color: var(--prediction-available-text);
}

.prediction-status-chip.saved {
  background: var(--prediction-saved-bg);
  color: var(--prediction-saved-text);
}

.prediction-status-chip.closed {
  background: var(--prediction-closed-bg);
  color: var(--prediction-closed-text);
}

.prediction-status-chip.correct {
  background: var(--prediction-correct-bg);
  color: var(--prediction-correct-text);
}

.prediction-status-chip.wrong {
  background: var(--prediction-wrong-bg);
  color: var(--prediction-wrong-text);
}

.match-prediction-card {
  background: var(--match-card-bg);
  border: var(--border-width-normal) solid var(--match-card-border);
  border-radius: var(--radius-2xl);
  box-shadow: var(--match-card-shadow);
  color: var(--text-primary);
  overflow: hidden;
  transition: var(--transition-default);
}

.match-prediction-card:hover,
.match-prediction-card:focus-within {
  box-shadow: var(--match-card-hover-shadow);
  transform: var(--card-hover-transform);
}

.match-prediction-card .match-form {
  display: grid;
  gap: var(--space-4);
  height: 100%;
}

.match-prediction-header,
.match-prediction-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
}

.match-prediction-header {
  padding: var(--space-4) var(--space-4) 0;
}

.match-prediction-body {
  display: grid;
  grid-template-columns: minmax(5.4rem, 1fr) 7.25rem minmax(5.4rem, 1fr);
  align-items: start;
  gap: var(--space-3);
  padding: var(--space-1) var(--space-4) 0;
}

.pronosticos-shell .match-prediction-body {
  grid-template-columns: minmax(5.4rem, 1fr) 7.25rem minmax(5.4rem, 1fr);
}

.match-prediction-card .team-side {
  width: 100%;
  min-width: 0;
  display: grid;
  grid-template-rows: var(--team-flag-size, 4.15rem) minmax(2.1rem, auto);
  justify-items: center;
  align-content: center;
  gap: var(--space-2);
  text-align: center;
}

.match-prediction-card .team-flag-frame {
  display: grid;
  place-items: center;
  width: var(--team-flag-size, 4.15rem);
  height: var(--team-flag-size, 4.15rem);
  overflow: visible;
}

.match-prediction-card .team-side img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  background: var(--bg-surface-2);
  border: var(--border-width-normal) solid var(--border-light);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  filter: var(--image-filter, none);
}

.match-prediction-card .team-side strong {
  width: 100%;
  max-width: 5.8rem;
  min-height: 2.1rem;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  overflow-wrap: anywhere;
  white-space: normal;
  color: var(--text-primary);
  font-size: var(--font-size-body-sm);
  font-weight: var(--font-weight-extrabold);
  line-height: var(--line-height-tight);
}

.match-prediction-card .score-editor {
  display: grid;
  grid-template-columns: repeat(2, 3.15rem);
  align-items: center;
  align-self: start;
  justify-content: center;
  gap: var(--space-1);
  width: 7.25rem;
  min-width: 0;
  max-width: 100%;
  padding: var(--space-2);
  background: var(--score-editor-bg);
  border: var(--border-width-normal) solid var(--score-editor-border);
  border-radius: var(--radius-xl);
  box-shadow: var(--score-editor-shadow);
}

.pronosticos-shell .match-prediction-card .score-editor {
  grid-template-columns: repeat(2, 3.15rem);
  min-height: auto;
}

.match-prediction-card .score-editor::before {
  content: none;
}

.match-prediction-card .score-input,
.match-prediction-card .score-label {
  width: 3.15rem;
  height: clamp(3.35rem, 6vw, 3.75rem);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  background: var(--score-input-bg);
  color: var(--score-input-text);
  border: var(--border-width-normal) solid var(--score-input-border);
  border-radius: var(--radius-lg);
  font-family: var(--font-family-secondary);
  font-size: var(--font-size-h2);
  font-weight: var(--font-weight-extrabold);
  line-height: 1;
  text-align: center;
}

.pronosticos-shell .match-prediction-card .score-input,
.pronosticos-shell .match-prediction-card .score-label {
  width: 3.15rem;
  height: clamp(3.35rem, 6vw, 3.75rem);
  border-radius: var(--radius-lg);
  font-size: var(--font-size-h2);
}

.match-prediction-card .score-input:focus {
  border-color: var(--score-input-focus);
  box-shadow: var(--glow-focus);
}

.match-prediction-card .random-score-button {
  width: 44px;
  height: 44px;
  padding: var(--space-2);
}

.pronosticos-shell .match-prediction-card.locked .score-editor.closed-score-display {
  grid-template-columns: repeat(2, clamp(3.35rem, 10vw, 4.85rem));
  width: fit-content;
  height: auto;
  max-width: 100%;
  padding: clamp(0.35rem, 1vw, 0.55rem);
  gap: clamp(0.35rem, 1vw, 0.55rem);
  background: color-mix(in srgb, var(--danger-bg) 58%, var(--score-editor-bg) 42%);
  border: var(--border-width-normal) solid var(--alert-danger-border);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-sm);
}

.pronosticos-shell .match-prediction-card.locked .score-editor.closed-score-display .score-label-locked {
  width: 100%;
  height: clamp(4.15rem, 12vw, 5.45rem);
  min-width: 0;
  padding: 0;
  background: color-mix(in srgb, var(--danger-bg) 38%, var(--score-input-bg) 62%);
  border: var(--border-width-normal) solid var(--alert-danger-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--score-editor-shadow);
  color: var(--danger);
  font-size: clamp(2.75rem, 9vw, 4rem);
  font-weight: var(--font-weight-extrabold);
  line-height: 1;
}

.resultados-shell .result-admin-card .result-score-editor.closed-score-display {
  grid-template-columns: repeat(2, clamp(3.35rem, 10vw, 4.85rem));
  width: fit-content;
  height: auto;
  max-width: 100%;
  padding: clamp(0.35rem, 1vw, 0.55rem);
  gap: clamp(0.35rem, 1vw, 0.55rem);
  align-content: center;
  background: color-mix(in srgb, var(--danger-bg) 58%, var(--score-editor-bg) 42%);
  border: var(--border-width-normal) solid var(--alert-danger-border);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-sm);
}

.resultados-shell .result-admin-card .result-score-editor.closed-score-display .score-label-locked {
  width: 100%;
  height: clamp(4.15rem, 12vw, 5.45rem);
  min-width: 0;
  padding: 0;
  background: color-mix(in srgb, var(--danger-bg) 38%, var(--score-input-bg) 62%);
  border: var(--border-width-normal) solid var(--alert-danger-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--score-editor-shadow);
  color: var(--danger);
  font-size: clamp(2.75rem, 9vw, 4rem);
  font-weight: var(--font-weight-extrabold);
  line-height: 1;
}

.pronosticos-shell .match-prediction-card.locked .match-prediction-footer,
.resultados-shell .result-admin-card.locked .match-prediction-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  margin: 0 var(--space-4) var(--space-4);
  padding: var(--space-3) var(--space-4);
  background: color-mix(in srgb, var(--danger-bg) 52%, var(--card-bg) 48%);
  border: var(--border-width-normal) solid var(--alert-danger-border);
  border-radius: var(--radius-xl);
  color: var(--danger);
}

.pronosticos-shell .match-prediction-card.locked .match-prediction-footer strong,
.resultados-shell .result-admin-card.locked .match-prediction-footer strong {
  color: var(--danger);
}

.match-prediction-footer {
  margin: 0;
  padding: var(--space-3) var(--space-4) var(--space-4);
  color: var(--text-muted);
  border-top: var(--border-width-normal) solid var(--match-card-border);
}

.match-prediction-footer strong {
  color: var(--text-primary);
}

.ranking-user-card,
.ranking-podium,
.game-mode-card {
  background: var(--ranking-podium-bg);
  border: var(--border-width-normal) solid var(--ranking-podium-border);
  border-radius: var(--radius-2xl);
  box-shadow: var(--card-shadow);
  color: var(--text-primary);
}

.ranking-user-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  padding: var(--space-4);
  background: var(--ranking-current-user-bg);
}

.tabla-premium-shell .tabla-player-focus-card,
.juegos-shell > .juegos-player-focus-card {
  background: var(--ranking-podium-bg);
  border-color: var(--ranking-podium-border);
  box-shadow: var(--card-shadow);
  backdrop-filter: blur(var(--glass-blur));
}

.game-hub .ranking-user-card,
.tabla-premium-shell .tabla-player-focus-card {
  background: var(--glass-bg);
  border-color: var(--glass-border);
  color: var(--text-primary);
  box-shadow: var(--shadow-sm);
  backdrop-filter: blur(var(--glass-blur));
}

.pronosticos-shell .jornada-card.game-round-card {
  background: color-mix(in srgb, var(--glass-bg) 54%, transparent);
  border-color: var(--glass-border);
  box-shadow: var(--card-shadow);
  backdrop-filter: blur(var(--glass-blur));
}

.pronosticos-shell .jornada-card.game-round-card > .quiniela-card-header {
  background: color-mix(in srgb, var(--glass-bg) 62%, transparent);
  border-bottom-color: var(--glass-border);
  backdrop-filter: blur(var(--glass-blur));
}

.pronosticos-shell .jornada-card.game-round-card > .matches-grid {
  background: color-mix(in srgb, var(--bg-surface-overlay) 34%, transparent);
}

.ranking-user-profile,
.ranking-user-metrics {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  min-width: 0;
}

.ranking-user-profile h2 {
  margin: 0;
  color: var(--text-muted);
  font-size: var(--font-size-caption);
  text-transform: uppercase;
}

.ranking-user-profile strong {
  display: block;
  max-width: 42vw;
  overflow-wrap: anywhere;
  white-space: normal;
}

.ranking-user-metrics {
  flex-wrap: wrap;
  justify-content: flex-end;
}

.ranking-user-metrics span {
  display: inline-flex;
  align-items: baseline;
  gap: var(--space-1);
  padding: var(--space-2) var(--space-3);
  background: var(--player-card-bg);
  border: var(--border-width-normal) solid var(--player-card-border);
  border-radius: var(--radius-pill);
  color: var(--text-secondary);
}

.ranking-user-metrics strong {
  color: var(--text-primary);
  font-family: var(--font-family-secondary);
}

.ranking-user-metrics strong.stat-positive {
  color: var(--stat-positive);
}

.ranking-user-metrics strong.stat-negative {
  color: var(--stat-negative);
}

.ranking-user-metrics strong.stat-neutral {
  color: var(--stat-neutral);
}

.ranking-podium {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--space-3);
  padding: var(--space-4);
  margin-bottom: var(--space-4);
  width: 100%;
  min-width: 0;
  box-sizing: border-box;
}

.ranking-podium-card {
  display: grid;
  justify-items: center;
  gap: var(--space-2);
  min-width: 0;
  padding: var(--space-4);
  background: var(--player-card-bg);
  border: var(--border-width-normal) solid var(--player-card-border);
  border-radius: var(--radius-xl);
  text-align: center;
  box-sizing: border-box;
}

.tabla-premium-shell .tabla-audit-header.game-hero {
  width: 100%;
  max-width: 78rem;
  background: var(--game-hero-bg);
  border-color: var(--game-hero-border);
  border-radius: var(--radius-2xl);
  box-shadow: var(--game-hero-shadow);
  color: var(--game-hero-title);
  text-align: left;
}

.tabla-premium-shell .tabla-audit-header.game-hero h1 {
  color: var(--game-hero-title);
  font-size: clamp(var(--font-size-h2), 5vw, var(--font-size-display-lg));
  line-height: var(--line-height-tight);
}

.tabla-premium-shell .tabla-audit-header.game-hero p {
  color: var(--game-hero-subtitle);
}

.tabla-premium-shell .tabla-audit-header.game-hero > span {
  width: fit-content;
  max-width: 100%;
  justify-self: end;
  border: 0;
  background: transparent;
  color: inherit;
  padding: 0;
}

.juegos-shell .tabla-audit-header.game-hero > span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 36px;
  padding: 0 var(--space-4);
  background: var(--prediction-available-bg);
  color: var(--prediction-available-text);
  border: var(--border-width-normal) solid var(--match-card-border);
  border-radius: var(--radius-pill);
  font-size: var(--font-size-caption);
  font-weight: 800;
  text-transform: uppercase;
  box-shadow: var(--shadow-sm);
}

.tabla-premium-shell .tabla-audit-card {
  width: 100%;
  min-width: 0;
  overflow: hidden;
}

.ranking-podium-card.place-1 {
  background: var(--ranking-first-bg);
  color: var(--player-level-text);
  transform: translateY(calc(var(--space-2) * -1));
}

.ranking-podium-card.place-1 small,
.ranking-podium-card.place-1 strong {
  color: var(--player-level-text);
}

.ranking-podium-card.place-2 {
  background: var(--ranking-second-bg);
}

.ranking-podium-card.place-3 {
  background: var(--ranking-third-bg);
}

.ranking-podium-card.current {
  outline: var(--border-width-normal) solid var(--border-focus);
  box-shadow: var(--glow-focus);
}

.ranking-podium-card strong {
  width: 100%;
  overflow-wrap: anywhere;
  white-space: normal;
}

.ranking-medal {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 58px;
  min-height: 42px;
  padding-inline: var(--space-3);
  border-radius: var(--radius-pill);
  background: var(--player-level-bg);
  color: var(--player-level-text);
  font-family: var(--font-family-secondary);
  font-weight: var(--font-weight-extrabold);
}

.game-mode-card {
  display: grid;
  gap: var(--space-4);
  padding: var(--space-4);
  background: var(--game-mode-bg);
  border-color: var(--game-mode-border);
  box-shadow: var(--game-mode-shadow);
}

.juegos-shell .empty-mode-card {
  background: color-mix(in srgb, var(--bg-surface-1) 70%, transparent 30%);
  border-color: var(--glass-border);
  color: var(--text-primary);
  box-shadow: var(--shadow-sm);
  backdrop-filter: none;
}

.juegos-shell .empty-mode-card h2,
.juegos-shell .empty-mode-card p {
  color: var(--text-primary);
}

.champion-game-card {
  background: color-mix(in srgb, var(--card-bg) 82%, transparent 18%);
}

.game-mode-card.champion-game-card.game-mode-tile {
  background: var(--player-card-bg);
  border: var(--border-width-normal) solid var(--player-card-border);
  box-shadow: none;
  gap: var(--space-2);
  padding: var(--space-3);
}

.champion-intro-panel,
.champion-side-panel > .champion-form,
.champion-side-panel > .champion-locked-grid {
  background: color-mix(in srgb, var(--player-card-bg) 86%, transparent 14%);
  border: var(--border-width-normal) solid var(--player-card-border);
  border-radius: var(--radius-xl);
  box-shadow: var(--player-card-shadow);
}

.champion-intro-panel {
  padding: var(--space-4);
}

.champion-intro-panel .champion-status-stats {
  background: transparent;
  border: 0;
  box-shadow: none;
}

.champion-section {
  background: var(--card-bg);
  border: var(--border-width-normal) solid var(--card-border);
  border-radius: var(--radius-xl);
  box-shadow: var(--card-shadow);
  overflow: hidden;
}

.juegos-shell .champion-section {
  background: transparent;
  border: 0;
  box-shadow: none;
  overflow: visible;
}

.champion-section-heading h2 {
  color: var(--text-primary);
  font-family: var(--font-family-secondary);
}

.champion-section .champion-game-card {
  border: 0;
  box-shadow: none;
}

.juegos-shell .champion-section .champion-game-card {
  border: 0;
  box-shadow: none;
}

.champion-arena {
  max-width: 58rem;
  margin-inline: auto;
}

.game-mode-card-header {
  display: flex;
  justify-content: space-between;
  gap: var(--space-4);
  align-items: flex-start;
}

.game-mode-card h2 {
  margin: var(--space-2) 0;
  color: var(--text-primary);
  font-family: var(--font-family-secondary);
  font-size: var(--font-size-h1);
}

.game-mode-card p {
  margin: 0;
  color: var(--text-secondary);
}

.game-mode-stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--space-3);
}

.game-mode-stats.champion-status-stats {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  padding: var(--space-3);
}

.game-mode-stats .player-stat-card {
  padding: var(--space-3);
}

.game-mode-stats .player-stat-card strong {
  font-size: var(--font-size-h3);
}

.achievement-card {
  display: inline-flex;
  width: fit-content;
  padding: var(--space-1) var(--space-3);
  background: var(--achievement-bg);
  color: var(--achievement-title);
  border: var(--border-width-normal) solid var(--achievement-border);
  border-radius: var(--radius-pill);
  font-size: var(--font-size-caption);
  font-weight: var(--font-weight-bold);
}

.game-mode-card .champion-field,
.game-mode-card .champion-team-preview {
  background: var(--player-card-bg);
  border: var(--border-width-normal) solid var(--player-card-border);
  border-radius: var(--radius-lg);
  box-shadow: none;
}

.game-mode-card .champion-team-preview {
  padding: var(--space-4);
  display: grid;
  justify-items: center;
  gap: var(--space-3);
  text-align: center;
  transition: var(--transition-default);
}

.game-mode-card .champion-team-preview img {
  width: min(8.5rem, 100%);
  height: clamp(66px, 8vw, 84px);
  object-fit: contain;
}

.game-mode-card .champion-team-preview strong {
  max-width: 100%;
  color: var(--text-primary);
  font-family: var(--font-family-secondary);
  font-size: clamp(1.55rem, 2.8vw, var(--font-size-h2));
  line-height: var(--line-height-tight);
  overflow-wrap: anywhere;
  white-space: normal;
}

.game-mode-card .champion-team-preview small {
  color: var(--achievement-text);
}

.game-mode-card .champion-selected {
  border-color: var(--ranking-podium-border);
  background: var(--ranking-current-user-bg);
  box-shadow: var(--game-mode-shadow);
}

.game-mode-card .champion-field {
  display: grid;
  gap: var(--space-2);
  width: 100%;
  padding: var(--space-3);
}

.game-mode-card .champion-form {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 0;
  align-items: start;
  justify-items: center;
  padding: var(--space-3);
}

.game-mode-card .season-prediction-body .champion-form {
  padding: 0;
  background: transparent;
  border: 0;
  box-shadow: none;
}

.game-mode-card .champion-pick-grid,
.game-mode-card .champion-preview-grid {
  display: grid;
  min-width: 0;
  width: 100%;
}

.game-mode-card .champion-pick-grid {
  z-index: 1;
  margin-block-end: calc(-1 * var(--space-4));
}

.game-mode-card .champion-preview-grid {
  padding-block-start: var(--space-4);
}

.game-mode-card .champion-field span,
.game-mode-card .champion-team-preview span {
  color: var(--text-muted);
  font-size: var(--font-size-caption);
  font-weight: var(--font-weight-bold);
  text-transform: uppercase;
}

.compact-audit-card {
  display: none;
}

@media (max-width: 900px) {
  .game-hero {
    grid-template-columns: minmax(0, 1fr);
  }

  .ranking-user-card {
    align-items: stretch;
    flex-direction: column;
  }

  .ranking-user-metrics {
    justify-content: flex-start;
  }
}

@media (max-width: 640px) {
  .pronosticos-shell,
  .resultados-shell {
    width: 100%;
    max-width: 100%;
    min-width: 0;
    overflow-x: clip;
  }

  .game-shell {
    gap: var(--dashboard-mobile-spacing);
  }

  .juegos-shell.game-shell {
    margin: 0;
    padding-inline: 0;
  }

  .game-hero {
    width: 100%;
    max-width: none;
    min-width: 0;
    grid-template-columns: minmax(0, 1fr);
    padding: var(--space-4);
    border-radius: var(--radius-xl);
    overflow: hidden;
  }

  .game-hero-copy,
  .game-hero > *,
  .pronosticos-toolbar > *,
  .resultados-toolbar > * {
    min-width: 0;
  }

  .pronosticos-toolbar,
  .resultados-toolbar {
    width: 100%;
    max-width: 100%;
    min-width: 0;
    grid-template-columns: minmax(0, 1fr);
    margin-inline: 0;
    box-sizing: border-box;
  }

  .pronosticos-shell .game-hero,
  .resultados-shell .game-hero,
  .pronosticos-sticky-stack,
  .resultados-sticky-stack,
  .pronosticos-shell .jornada-card,
  .resultados-shell .jornada-card,
  .pronosticos-shell .matches-grid,
  .resultados-shell .matches-grid,
  .pronosticos-shell .match-prediction-card,
  .resultados-shell .match-prediction-card {
    width: 100%;
    max-width: 100%;
    min-width: 0;
    box-sizing: border-box;
  }

  .pronosticos-hero-side,
  .prediction-quick-stats,
  .prediction-progress,
  .prediction-progress.hero-progress {
    width: 100%;
    max-width: 100%;
    min-width: 0;
  }

  .pronosticos-view-toolbar,
  .pronosticos-jornada-strip,
  .resultados-view-toolbar,
  .resultados-jornada-strip {
    width: 100%;
    max-width: 100%;
    min-width: 0;
    box-sizing: border-box;
    justify-content: flex-start;
  }

  .game-hero .quiniela-card-header,
  .pronosticos-toolbar .quiniela-card-header {
    min-width: 0;
  }

  .view-switch {
    width: 100%;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .view-switch a {
    min-width: 0;
    padding-inline: var(--space-2);
  }

  .pronosticos-jornada-strip {
    padding-inline: 0;
  }

  .ranking-podium {
    grid-template-columns: 1fr;
  }

  .player-summary {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: var(--space-2);
  }

  .game-action-grid {
    grid-template-columns: 1fr;
  }

  .prediction-quick-stats {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .game-mode-stats {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: var(--space-2);
  }

  .game-mode-stats .player-stat-card {
    padding: var(--space-2);
  }

  .game-mode-stats .player-stat-card strong {
    font-size: var(--font-size-body-lg);
    overflow: visible;
    text-overflow: clip;
    white-space: normal;
  }

  .game-mode-stats .player-stat-card small {
    font-size: var(--font-size-caption);
  }

  .competition-grid,
  .competition-lanes,
  .competition-lanes-three {
    grid-template-columns: 1fr;
  }

  .competition-feature-card,
  .competition-lane,
  .competition-events-panel {
    padding: var(--space-3);
    border-radius: var(--radius-xl);
  }

  .competition-movement-card,
  .competition-event-row {
    grid-template-columns: auto minmax(0, 1fr);
  }

  .competition-movement-card b,
  .competition-event-row span {
    grid-column: 2;
    justify-self: start;
  }

  .competition-event-row > small {
    grid-column: 1 / -1;
  }

  .competition-stat-grid,
  .competition-roller-row {
    grid-template-columns: 1fr;
  }

  .game-mode-card .champion-form {
    grid-template-columns: 1fr;
  }

  .prediction-progress {
    width: 100%;
  }

  .player-stat-card {
    padding: var(--space-3);
    border-radius: var(--radius-lg);
  }

  .player-stat-card strong {
    font-size: var(--font-size-h3);
  }

  .ranking-podium-card.place-1 {
    transform: none;
  }

  .pronosticos-shell .pronostico-live-row {
    grid-template-columns: minmax(0, 1fr);
  }

  .match-prediction-body,
  .pronosticos-shell .match-prediction-body {
    --mobile-flag-unit: clamp(68px, 21vw, 76px);
    --mobile-score-unit: clamp(96px, 30vw, 112px);
    grid-template-columns: var(--mobile-flag-unit) var(--mobile-score-unit) var(--mobile-flag-unit);
    justify-content: center;
    align-items: start;
    gap: clamp(0.6rem, 2.5vw, 0.95rem);
  }

  .match-prediction-card .team-side {
    grid-template-columns: minmax(0, 1fr);
    grid-template-rows: auto auto;
    justify-items: center;
    align-items: start;
    width: var(--mobile-flag-unit);
    text-align: center;
  }

  .match-prediction-card .team-side.right {
    direction: ltr;
  }

  .match-prediction-card .team-side.right strong {
    direction: ltr;
    text-align: center;
  }

  .match-prediction-card .team-flag-frame {
    width: var(--mobile-flag-unit);
    height: var(--mobile-flag-unit);
  }

  .match-prediction-card .team-side img {
    width: 100%;
    height: 100%;
  }

  .match-prediction-card .score-editor,
  .pronosticos-shell .match-prediction-card .score-editor {
    justify-self: center;
    grid-template-columns: repeat(2, minmax(0, calc((var(--mobile-score-unit) - 0.95rem) / 2)));
    align-content: center;
    align-self: start;
    min-width: 0;
    width: var(--mobile-score-unit);
    height: var(--mobile-flag-unit);
    max-width: var(--mobile-score-unit);
    margin-inline: auto;
  }

  .pronosticos-shell .match-prediction-card:not(.locked) .score-editor {
    grid-template-rows: auto auto;
    height: auto;
    min-height: var(--mobile-flag-unit);
    row-gap: var(--space-1);
  }

  .pronosticos-shell .match-prediction-card:not(.locked) .random-score-button {
    grid-column: 1 / -1;
    justify-self: center;
    width: clamp(2.25rem, 10vw, 2.65rem);
    height: clamp(2.25rem, 10vw, 2.65rem);
    min-height: 0;
    padding: var(--space-1);
    border-radius: var(--radius-pill);
  }

  .pronosticos-shell .match-prediction-card .score-input,
  .pronosticos-shell .match-prediction-card .score-label {
    width: calc((var(--mobile-score-unit) - 0.95rem) / 2);
    height: calc(var(--mobile-flag-unit) - 0.7rem);
  }

  .match-prediction-header,
  .match-prediction-footer,
  .game-mode-card-header {
    align-items: flex-start;
    flex-direction: column;
  }
}

@media (max-width: 380px) {
  .match-prediction-body,
  .pronosticos-shell .match-prediction-body {
    --mobile-flag-unit: clamp(68px, 19vw, 72px);
    --mobile-score-unit: clamp(104px, 30vw, 112px);
    grid-template-columns: var(--mobile-flag-unit) var(--mobile-score-unit) var(--mobile-flag-unit);
    gap: var(--space-1);
  }

  .match-prediction-card .score-editor,
  .pronosticos-shell .match-prediction-card .score-editor {
    width: var(--mobile-score-unit);
    height: var(--mobile-flag-unit);
    max-width: var(--mobile-score-unit);
    grid-template-columns: repeat(2, minmax(0, calc((var(--mobile-score-unit) - 0.95rem) / 2)));
  }

  .pronosticos-shell .match-prediction-card:not(.locked) .score-editor {
    height: auto;
    min-height: var(--mobile-flag-unit);
  }

  .pronosticos-shell .match-prediction-card .score-input,
  .pronosticos-shell .match-prediction-card .score-label {
    width: calc((var(--mobile-score-unit) - 0.95rem) / 2);
    height: calc(var(--mobile-flag-unit) - 0.7rem);
    font-size: 1.35rem;
  }

  .match-prediction-card .team-side strong {
    font-size: 0.78rem;
  }
}

.pronosticos-shell:not(.resultados-shell) .match-prediction-card.locked .score-editor.closed-score-display {
  grid-template-columns: repeat(2, 3.15rem) !important;
  width: fit-content !important;
  max-width: none;
  min-height: 0;
  padding: 0.35rem;
  gap: 0.35rem;
}

.pronosticos-shell:not(.resultados-shell) .match-prediction-card.locked .score-editor.closed-score-display .score-label-locked {
  width: 3.15rem !important;
  height: 3.45rem !important;
  min-width: 0;
  min-height: 0;
  font-size: var(--font-size-h2) !important;
  line-height: 1;
}

.resultados-shell .result-admin-card .result-score-editor.closed-score-display {
  grid-template-columns: repeat(2, 3.15rem) !important;
  width: fit-content !important;
  max-width: none;
  min-height: 0;
  padding: 0.35rem;
  gap: 0.35rem;
}

.resultados-shell .result-admin-card .result-score-editor.closed-score-display .score-label-locked {
  width: 3.15rem !important;
  height: 3.45rem !important;
  min-width: 0;
  min-height: 0;
  font-size: var(--font-size-h2) !important;
  line-height: 1;
}

.resultados-shell .result-admin-card.pending-open .result-score-editor.pending-score-display {
  grid-template-columns: repeat(2, 3.15rem);
  width: fit-content;
  max-width: none;
  padding: 0.35rem;
  gap: 0.35rem;
  background: color-mix(in srgb, var(--danger-bg) 18%, var(--score-editor-bg) 82%);
  border-color: var(--alert-danger-border);
}

.resultados-shell .result-admin-card.pending-open .result-score-placeholder {
  width: 3.15rem;
  height: 3.45rem;
  background: transparent;
  color: var(--danger);
  border-color: var(--alert-danger-border);
  box-shadow: none;
}

html[data-theme] {
  --hover-scale: 1;
  --active-scale: 1;
  --card-hover-transform: none;
}

html[data-theme] :where(
  .app-card,
  .mis-quiniela-card,
  .match-card,
  .match-prediction-card,
  .game-action-card,
  .player-stat-card,
  .game-mode-card,
  .ranking-podium,
  .achievement-card,
  .quiniela-select-card,
  .home-prediction-row,
  .theme-profile-option,
  .notification-preference-row,
  .theme-summary-panel,
  .team-row button,
  .email-toggle,
  .admin-pill,
  .admin-link-button,
  .random-score-button,
  .app-button-primary,
  .app-button-secondary,
  .app-button-danger,
  .app-button-neutral,
  .app-button-gold
):where(:hover, :active, :focus-visible) {
  transform: none;
}
