/* ==========================================================================
   Nitro Simracing - Master Stylesheet
   ========================================================================== */

/* Legacy Core Import (Baseline styles) */

/* Nitro unified CSS entrypoint.
   Build with PostCSS to generate dist/css/nitro-bundle.css.
   Single source of truth: nitro-core.css. */

@layer sn.core {
:root {
  --sn-font-sans:
    "Poppins", "Inter", system-ui, -apple-system, BlinkMacSystemFont,
    "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, "Open Sans",
    "Helvetica Neue", Arial, sans-serif;
  --sn-font-mono: "JetBrains Mono", "Fira Code", monospace;
  --sn-color-bg: #0a0a0a;
  --sn-color-bg-alt: #141414;
  --sn-color-surface: #1a1a1a;
  --sn-color-surface-alt: #202020;
  --sn-color-border: #2a2a2a;
  --sn-color-border-light: #333;
  --sn-color-overlay: rgba(0, 0, 0, 0.85);
  --sn-color-text: #fff;
  --sn-color-text-soft: #fff;
  --sn-color-text-faint: #fff;
  --sn-theme-primary: #c90d05;
  --sn-theme-primary-accent: #790802;
  --sn-theme-primary-hover: #e01006;
  --sn-grad-theme: linear-gradient(
    135deg,
    var(--sn-theme-primary),
    var(--sn-theme-primary-accent)
  );
  --sn-color-accent: #8b0000;
  --sn-color-accent-hover: #a30f0f;
  --sn-primary: #c90d05;
  --sn-primary-accent: #c90d05;
  --sn-primary-soft: #1b5fa8;
  --sn-accent: #25d366;
  --sn-danger: #dc3545;
  --sn-danger-alt: #a33c1a;
  --sn-warning: #fbbf24;
  --sn-success: #28a745;
  --sn-info: #0ea5e9;
  --sn-muted: #4b5563;
  --sn-grad-primary: linear-gradient(
    180deg,
    var(--sn-primary),
    var(--sn-primary-accent)
  );
  --sn-grad-danger: linear-gradient(135deg, #7a2323, #3a1616);
  --sn-grad-warning: linear-gradient(135deg, #7a5c1c, #4d3a13);
  --sn-grad-success: linear-gradient(135deg, #23422d, #1a2c1d);
  --sn-grad-muted: linear-gradient(135deg, #444950, #23272b);
  --sn-font-scale: 1.1;
  --sn-font-size-xs-base: 0.65rem;
  --sn-font-size-sm-base: 0.75rem;
  --sn-font-size-base: 0.875rem;
  --sn-font-size-md-base: 0.95rem;
  --sn-font-size-lg-base: 1.05rem;
  --sn-font-size-xs: calc(var(--sn-font-size-xs-base) * var(--sn-font-scale));
  --sn-font-size-sm: calc(var(--sn-font-size-sm-base) * var(--sn-font-scale));
  --sn-font-size: calc(var(--sn-font-size-base) * var(--sn-font-scale));
  --sn-font-size-md: calc(var(--sn-font-size-md-base) * var(--sn-font-scale));
  --sn-font-size-lg: calc(var(--sn-font-size-lg-base) * var(--sn-font-scale));
  --sn-line-height: 1.35;
  --sn-space-1: 4px;
  --sn-space-2: 8px;
  --sn-space-3: 12px;
  --sn-space-4: 16px;
  --sn-space-5: 20px;
  --sn-space-6: 24px;
  --sn-radius-xs: 3px;
  --sn-radius-sm: 6px;
  --sn-radius: 8px;
  --sn-radius-lg: 12px;
  --sn-radius-pill: 999px;
  --sn-radius-btn: 10px;
  --sn-shadow-xs: 0 1px 2px rgba(0, 0, 0, 0.4);
  --sn-shadow-sm: 0 2px 6px rgba(0, 0, 0, 0.45);
  --sn-shadow: 0 4px 18px -2px rgba(0, 0, 0, 0.55);
  --sn-shadow-lg: 0 12px 40px -4px rgba(0, 0, 0, 0.6);
  --sn-z-dropdown: 4000;
  --sn-z-sticky: 4500;
  --sn-z-modal: 5000;
  --sn-z-toast: 5500;
  --sn-z-max: 9999;
}
html {
  box-sizing: border-box;
}
*,
*::before,
*::after {
  box-sizing: inherit;
}
body {
  font-family: var(--sn-font-sans);
  color: var(--sn-color-text);
  background: var(--sn-color-bg);
}
.sn-scroll-thin {
  scrollbar-width: thin;
  scrollbar-color: var(--sn-color-border-light) transparent;
}
.sn-scroll-thin::-webkit-scrollbar {
  width: 8px;
}
.sn-scroll-thin::-webkit-scrollbar-track {
  background: transparent;
}
.sn-scroll-thin::-webkit-scrollbar-thumb {
  background: var(--sn-color-border-light);
  border-radius: 4px;
}
.sn-flex {
  display: flex;
}
.sn-center {
  display: flex;
  align-items: center;
  justify-content: center;
}
.sn-gap-1 {
  gap: var(--sn-space-1);
}
.sn-gap-2 {
  gap: var(--sn-space-2);
}
.sn-gap-3 {
  gap: var(--sn-space-3);
}
.sn-hidden {
  display: none !important;
}
.sn-text-soft {
  color: var(--sn-color-text-soft) !important;
}
.sn-text-faint {
  color: var(--sn-color-text-faint) !important;
}
.sn-w-100 {
  width: 100% !important;
}
.sn-relative {
  position: relative;
}
.sn-pill {
  border-radius: var(--sn-radius-pill) !important;
}
.sn-d-none {
  display: none;
}
.sn-mt-1 {
  margin-top: 4px;
}
.sn-ml-1-5 {
  margin-left: 6px;
}
.sn-license-init-card {
  display: grid;
  gap: 12px;
  padding: 18px;
  border: 1px solid var(--sn-color-border);
  border-radius: var(--sn-radius-lg);
  background: linear-gradient(180deg, rgba(35, 39, 43, 0.98), rgba(22, 25, 29, 0.98));
  color: #f8f9fa;
  box-shadow: var(--sn-shadow-sm);
}
.sn-license-init-card > :last-child {
  margin-bottom: 0;
}
.sn-license-init-card code {
  padding: 2px 6px;
  border-radius: var(--sn-radius-xs);
  background: rgba(255, 255, 255, 0.08);
  color: #9cdcfe;
}
.sn-license-init-card p {
  margin: 0;
}
.sn-license-init-card--success {
  border-color: rgba(40, 167, 69, 0.45);
}
.sn-license-init-card--error {
  border-color: rgba(220, 53, 69, 0.45);
}
.sn-license-init-link {
  color: #0dcaf0;
  font-weight: 600;
  text-decoration: underline;
}
.sn-license-init-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: center;
}
.sn-license-init-form {
  display: grid;
  gap: 14px;
}
.sn-license-init-check {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  line-height: 1.5;
}
.sn-license-init-check input {
  margin-top: 4px;
}
.sn-license-init-modal {
  position: fixed;
  inset: 0;
  z-index: var(--sn-z-modal);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
  background: rgba(0, 0, 0, 0.92);
}
.sn-license-init-modal__dialog {
  position: relative;
  width: min(600px, 95vw);
  max-height: 80vh;
  overflow: auto;
  padding: 24px 24px 16px;
  border: 1px solid var(--sn-color-border);
  border-radius: 10px;
  background: #181a1b;
  color: #f8f9fa;
  box-shadow: 0 0 24px #000;
}
.sn-license-init-modal__close {
  position: absolute;
  top: 12px;
  right: 20px;
  border: 0;
  padding: 0;
  background: transparent;
  color: #aaa;
  font-size: 32px;
  font-weight: 700;
  line-height: 1;
  cursor: pointer;
}
.sn-license-init-modal__title {
  margin: 0 40px 16px 0;
  color: #0dcaf0;
}
.sn-license-init-modal__content {
  color: #f8f9fa;
}
.sn-license-init-modal__content .nsc-entry-guide,
.sn-license-init-modal__content .nsc-entry-guide *,
.sn-license-init-modal__content *[style*="background"],
.sn-license-init-modal__content *[style*="background-color"] {
  background: transparent !important;
  background-color: transparent !important;
  color: #f8f9fa !important;
  border: 0 !important;
  box-shadow: none !important;
  padding: 0 !important;
  border-radius: 0 !important;
  font-family: inherit !important;
}
.sn-license-init-modal__content .nsc-entry-guide {
  border-left: 0 !important;
}
.sn-license-init-modal__content code {
  background: #23272b !important;
  color: #0dcaf0 !important;
  border-radius: 4px !important;
}
.sn-license-init-modal__content a {
  color: #0dcaf0 !important;
  font-weight: 600;
  text-decoration: underline;
}
.sn-license-init-modal__content h1,
.sn-license-init-modal__content h2,
.sn-license-init-modal__content h3 {
  color: #0dcaf0 !important;
}
.sn-license-init-modal__content > :first-child {
  margin-top: 0;
}
.sn-license-init-modal__content > :last-child {
  margin-bottom: 0;
}
.sn-tor-skin {
  font-family: var(--sn-font-sans);
  line-height: var(--sn-line-height);
  color: var(--sn-color-text);
}
.sn-tor-skin a {
  color: inherit;
}
.sn-tor-skin img {
  max-width: 100%;
  height: auto;
}
.sn-btn {
  --_btn-bg: var(--sn-grad-theme);
  --_btn-bg-hover: linear-gradient(
    135deg,
    var(--sn-theme-primary-hover),
    var(--sn-theme-primary-accent)
  );
  --_btn-color: #fff;
  --_btn-border: var(--sn-theme-primary-accent);
  font: 600 var(--sn-font-size)/1 var(--sn-font-sans);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  cursor: pointer;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
  border: 1px solid var(--_btn-border);
  background: var(--_btn-bg);
  color: var(--_btn-color);
  padding: 10px 18px;
  border-radius: var(--sn-radius-btn);
  transition:
    background 0.18s,
    color 0.18s,
    box-shadow 0.18s,
    transform 0.18s;
  position: relative;
  text-decoration: none;
  box-shadow: 0 2px 6px rgba(201, 13, 5, 0.45);
}
.sn-btn:hover,
.sn-btn:focus {
  background: var(--_btn-bg-hover);
  outline: none;
  text-decoration: none;
  filter: brightness(1.05);
}
.sn-btn:active {
  transform: translateY(1px);
}
.sn-btn:disabled {
  opacity: 0.55;
  cursor: not-allowed;
  filter: grayscale(0.25);
}
.sn-btn--primary,
.sn-btn--danger,
.sn-btn--success,
.sn-btn--warning,
.sn-btn--muted,
.sn-btn--info,
.sn-btn--theme {
  --_btn-bg: var(--sn-grad-theme);
  --_btn-bg-hover: linear-gradient(
    135deg,
    var(--sn-theme-primary-hover),
    var(--sn-theme-primary-accent)
  );
  --_btn-border: var(--sn-theme-primary-accent);
  color: #fff;
}
.sn-btn--outline {
  background: transparent;
  --_btn-border: var(--sn-theme-primary);
  color: var(--sn-theme-primary);
  box-shadow: none;
}
.sn-btn--outline:hover {
  background: rgba(201, 13, 5, 0.08);
}
.sn-btn--ghost {
  background: transparent;
  border-color: transparent;
  box-shadow: none;
  color: var(--sn-theme-primary);
}
.sn-btn--ghost:hover {
  background: rgba(201, 13, 5, 0.08);
}
.sn-btn--sm {
  padding: 6px 12px;
  font-size: var(--sn-font-size-sm);
}
.sn-btn--xs {
  padding: 4px 10px;
  font-size: var(--sn-font-size-xs);
}
.sn-btn--lg {
  padding: 14px 24px;
  font-size: var(--sn-font-size-md);
}
.sn-btn-icon {
  width: 40px;
  height: 40px;
  padding: 0;
}
.sn-btn-icon.sn-btn--sm {
  width: 32px;
  height: 32px;
}
.sn-btn--icon {
  width: 40px;
  height: 40px;
  padding: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.sn-btn--icon.sn-btn--sm {
  width: 32px;
  height: 32px;
}
.sn-btn--block {
  width: 100%;
  display: inline-flex;
  justify-content: center;
}
.sn-btn--stretch {
  flex: 1 1 auto;
  width: auto;
}
.sn-btn--mini {
  padding: 4px 10px;
  font-size: var(--sn-font-size-xs);
  min-height: 24px;
  height: 24px;
  line-height: 1;
}
.sn-btn--micro {
  padding: 0 8px;
  font-size: 10px;
  min-height: 18px;
  height: 18px;
  line-height: 1;
  border-radius: var(--sn-radius-xs);
}
  @supports (color: var(--sn-primary)) {
.sn-btn-mini,
.sn-btn-info,
.sn-show-more {
    font: 600 var(--sn-font-size-xs)/1 var(--sn-font-sans);
}
  }
.sn-btn-mini,
.sn-btn-info {
  height: 24px;
  min-height: 24px;
  padding: 0 10px;
  border-radius: var(--sn-radius-xs);
}
.sn-btn-prac,
.sn-btn-pass {
  height: 18px;
  min-height: 18px;
  padding: 0 8px;
  font-size: 10px;
  border-radius: var(--sn-radius-xs);
}
.sn-btn-info,
.sn-btn-prac,
.sn-btn-pass,
.sn-show-more {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 600;
}
.sn-btn-info {
  background: var(--sn-grad-theme) !important;
  color: #fff !important;
  border: 1px solid var(--sn-theme-primary-accent) !important;
  position: relative;
  z-index: 1;
  box-shadow: 0 2px 6px rgba(201, 13, 5, 0.45);
  border-radius: var(--sn-radius-btn) !important;
}
.sn-btn-info:hover {
  filter: brightness(1.06);
}
.sn-btn--square {
  border-radius: var(--sn-radius) !important;
}
.sn-btn--pill {
  border-radius: var(--sn-radius-pill) !important;
}
.sn-btn-prac,
.sn-btn-pass,
.sn-show-more {
  background: var(--sn-grad-theme) !important;
  color: #fff !important;
  border: 1px solid var(--sn-theme-primary-accent) !important;
  box-shadow: 0 1px 4px rgba(201, 13, 5, 0.4);
}
.sn-btn-prac:hover,
.sn-btn-pass:hover,
.sn-show-more:hover {
  filter: brightness(1.06);
}
.chat-btn,
.chat-send-btn,
.sn-btn-primary,
.sn-open-badge.edit,
.sn-open-badge.new,
.sn-ins-badge.open,
.sn-open-badge {
  font: inherit;
  border: none;
}
.chat-btn,
.sn-btn-primary,
.sn-input,
.sn-form input:not([type="checkbox"]):not([type="radio"]),
.sn-form select,
.sn-form textarea,
.select2-container .select2-selection--single {
  background: var(--sn-color-surface);
  border: 1px solid var(--sn-color-border);
  border-radius: var(--sn-radius-pill);
  padding: 10px 16px;
  color: var(--sn-color-text);
  font: 500 var(--sn-font-size) var(--sn-font-sans);
  outline: none;
  width: 100%;
  min-height: 44px;
}
.sn-input:focus,
.sn-form input:focus,
.sn-form select:focus,
.sn-form textarea:focus,
.select2-container .select2-selection--single:focus {
  border-color: var(--sn-primary);
  box-shadow: 0 0 0 2px rgba(11, 99, 214, 0.35);
}
.sn-input--danger {
  border-color: var(--sn-danger) !important;
  box-shadow: 0 0 0 2px rgba(220, 53, 69, 0.25) !important;
}
.sn-input--success {
  border-color: var(--sn-success) !important;
  box-shadow: 0 0 0 2px rgba(40, 167, 69, 0.25) !important;
}
.sn-input--textarea,
.sn-form textarea {
  border-radius: var(--sn-radius-lg);
  min-height: 100px;
  resize: vertical;
}
.select2-container .select2-selection--single {
  display: flex !important;
  align-items: center;
  background: var(--sn-color-surface) !important;
}
.select2-container--default .select2-selection--multiple {
  background: var(--sn-color-surface) !important;
  border: 1px solid var(--sn-color-border) !important;
  border-radius: var(--sn-radius-pill) !important;
  min-height: 44px;
  padding: 4px 10px !important;
}
.select2-container--default
  .select2-selection--single
  .select2-selection__rendered {
  color: var(--sn-color-text) !important;
  padding-left: 0 !important;
}
.select2-container--default
  .select2-selection--multiple
  .select2-selection__rendered {
  color: var(--sn-color-text) !important;
  padding: 0 !important;
}
.select2-container--default
  .select2-selection--single
  .select2-selection__arrow
  b {
  border-color: var(--sn-color-text) transparent transparent transparent !important;
}
.select2-container--default .select2-dropdown {
  background: var(--sn-color-surface-alt) !important;
  border: 1px solid var(--sn-color-border) !important;
}
.select2-container--default .select2-results__option {
  color: var(--sn-color-text) !important;
}
.select2-container--default .select2-results__option--highlighted {
  background: var(--sn-primary-accent) !important;
}
.select2-search--dropdown .select2-search__field {
  background: var(--sn-color-surface) !important;
  border: 1px solid var(--sn-color-border) !important;
  color: var(--sn-color-text) !important;
  border-radius: calc(var(--sn-radius) - 2px) !important;
}
.sn-modal .select2-container,
.sn-modal__dialog .select2-container {
  z-index: calc(var(--sn-z-modal, 5000) + 20);
}
.select2-container--open {
  z-index: calc(var(--sn-z-modal, 5000) + 30);
}
.sn-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font: 600 var(--sn-font-size-sm)/1 var(--sn-font-sans);
  padding: 4px 10px;
  border-radius: 20px;
  background: var(--sn-color-surface-alt);
  color: var(--sn-color-text);
  border: 1px solid var(--sn-color-border);
  letter-spacing: 0.25px;
}
.sn-badge--pill {
  border-radius: var(--sn-radius-pill);
}
.sn-badge--xs {
  padding: 2px 8px;
  font-size: var(--sn-font-size-xs);
}
.sn-badge--lg {
  padding: 6px 14px;
  font-size: var(--sn-font-size);
}
.sn-badge--primary {
  background: var(--sn-grad-primary);
  border-color: var(--sn-primary-accent);
  color: #fff;
}
.sn-badge--danger {
  background: var(--sn-grad-danger);
  color: #fff;
  border-color: #5a2222;
}
.sn-badge--warning {
  background: var(--sn-grad-warning);
  color: #fff;
  border-color: #7a5c1c;
}
.sn-badge--success {
  background: var(--sn-grad-success);
  color: #fff;
  border-color: #23422d;
}
.sn-badge--muted {
  background: var(--sn-grad-muted);
  color: #eee;
  border-color: #444950;
}
.sn-badge--outline {
  background: transparent;
  color: var(--sn-color-text);
  border-color: var(--sn-color-border);
}
.sn-aux-table-wrap .sn-badge--ok {
  background: #0e6f2d;
  color: #d8ffe6;
  border-color: #134e21;
}
.sn-aux-table-wrap .sn-badge--ko {
  background: #7f1d1d;
  color: #ffd8d8;
  border-color: #5a1414;
}
.sn-aux-table-wrap .sn-cell-bool {
  text-align: center;
  white-space: nowrap;
}
.badge-principiante {
  background: #6c757d !important;
  border: 2px solid #5a6268 !important;
}
.badge-cobre {
  background: #b87333 !important;
  border: 2px solid #8c6239 !important;
}
.badge-bronce {
  background: #cd7f32 !important;
  border: 2px solid #a86e32 !important;
}
.badge-plata {
  background: #c0c0c0 !important;
  border: 2px solid #a0a0a0 !important;
  color: #333 !important;
}
.badge-oro {
  background: #ffd700 !important;
  border: 2px solid #d4af37 !important;
  color: #333 !important;
}
.badge-platino {
  background: #e5e4e2 !important;
  border: 2px solid #c0c0c0 !important;
  color: #333 !important;
}
.badge-diamante {
  background: #b9f2ff !important;
  border: 2px solid #89c5cc !important;
  color: #333 !important;
}
.badge-elite {
  background: #4b0082 !important;
  border: 2px solid #2e004d !important;
}
.sn-modal {
  position: fixed;
  inset: 0;
  z-index: var(--sn-z-modal);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--sn-space-4);
  background: var(--sn-color-overlay);
  backdrop-filter: blur(2px);
}
.sn-modal__dialog {
  background: var(--sn-color-surface);
  border: 1px solid var(--sn-color-border);
  border-radius: var(--sn-radius-lg);
  width: 100%;
  max-width: 820px;
  max-height: 90vh;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  box-shadow: var(--sn-shadow-lg);
}
.sn-modal__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sn-space-2);
  padding: var(--sn-space-3) var(--sn-space-4);
  background: var(--sn-color-surface-alt);
  border-bottom: 1px solid var(--sn-color-border);
}
.sn-modal__title {
  margin: 0;
  font: 600 var(--sn-font-size-md)/1 var(--sn-font-sans);
}
.sn-modal__close {
  background: transparent;
  border: none;
  color: var(--sn-color-text-soft);
  font-size: 1.2rem;
  cursor: pointer;
  padding: 0;
  border-radius: var(--sn-radius-sm);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  flex-shrink: 0;
  line-height: 1;
  position: relative;
}
.sn-modal__close:hover {
  background: rgba(255, 255, 255, 0.06);
  color: var(--sn-color-text);
}
.sn-modal__body {
  flex: 1;
  overflow: auto;
  padding: var(--sn-space-4);
  font-size: var(--sn-font-size);
  line-height: var(--sn-line-height);
}
.sn-modal__footer {
  display: flex;
  gap: var(--sn-space-2);
  justify-content: flex-end;
  padding: var(--sn-space-3) var(--sn-space-4);
  border-top: 1px solid var(--sn-color-border);
  background: var(--sn-color-surface-alt);
}
.mfp-bg {
  background: var(--sn-color-overlay, rgba(0, 0, 0, 0.85)) !important;
}
.mfp-wrap,
.mfp-container {
  z-index: var(--sn-z-modal, 5000) !important;
}
.mfp-content {
  width: min(560px, 96vw) !important;
  border-radius: var(--sn-radius-lg, 12px) !important;
  overflow: visible !important;
  background: transparent !important;
  box-shadow: var(--sn-shadow-lg, 0 30px 70px rgba(0, 0, 0, 0.75)) !important;
}
.mfp-close {
  position: absolute !important;
  top: 8px !important;
  right: 10px !important;
  font-size: 1.35rem !important;
  color: var(--sn-color-text-soft, #ccc) !important;
  opacity: 0.8 !important;
  line-height: 1 !important;
  background: transparent !important;
  border: none !important;
  width: 32px !important;
  height: 32px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
}
.mfp-close:hover {
  color: #fff !important;
  opacity: 1 !important;
}
.sn-conectar-modal {
  background: var(--sn-color-surface, #151515) !important;
  border: 1px solid var(--sn-color-border, #2a2a2a) !important;
  border-radius: var(--sn-radius-lg, 14px) !important;
  padding: var(--sn-space-4, 20px) !important;
  color: var(--sn-color-text, #f7f7f7) !important;
  box-shadow: var(--sn-shadow-lg, 0 30px 70px rgba(0, 0, 0, 0.75)) !important;
  display: flex;
  flex-direction: column;
  gap: var(--sn-space-3, 12px);
}
.sn-conectar-modal h2,
.sn-conectar-modal h3 {
  margin: 0;
  font-size: 1.1rem;
  font-weight: 600;
  color: #fff;
  background: var(--sn-grad-theme, linear-gradient(135deg, #c90d05, #850400));
  border-radius: var(--sn-radius, 12px);
  border: 1px solid var(--sn-theme-primary-accent, #6c0500);
  padding: 0.85rem 1rem;
  box-shadow: 0 10px 26px rgba(0, 0, 0, 0.35);
}
.sn-conectar-modal p,
.sn-conectar-modal ol,
.sn-conectar-modal ul {
  margin: 0;
  font-size: 0.95rem;
  color: var(--sn-color-text-soft, #d4d4d4);
  line-height: 1.45;
}
.sn-conectar-modal ol,
.sn-conectar-modal ul {
  padding-left: 1.25rem;
}
.sn-conectar-modal input[type="text"],
.sn-conectar-modal input[type="url"],
.sn-conectar-modal input[type="number"] {
  width: 100%;
  margin-top: var(--sn-space-2, 8px);
}
.sn-conectar-modal code {
  font-family: var(--sn-font-mono);
  background: rgba(255, 255, 255, 0.05);
  padding: 2px 4px;
  border-radius: 4px;
}
.sn-conectar-modal .sn-btn {
  margin-top: var(--sn-space-3, 12px);
}
.sn-conectar-modal .sn-btn + .sn-btn {
  margin-left: 0;
}
.sn-conectar-modal .sn-support-note {
  font-size: 0.85rem;
  color: var(--sn-color-text-soft, #bcc4d1);
}
.sn-conectar-results {
  margin-top: var(--sn-space-3, 12px);
  max-height: 300px;
  overflow-y: auto;
}
.sn-conectar-results .sn-table-wrap + h4,
.sn-conectar-results p + h4 {
  margin-top: var(--sn-space-4, 20px);
}
}

@layer sn.core {
@media (max-width: 640px) {
  .sn-conectar-modal h2,
  .sn-conectar-modal h3 {
    font-size: 1rem;
  }
}
}

@layer sn.core {
.sn-ins-modal,
.chat-modal {
  background: var(--sn-color-overlay) !important;
  backdrop-filter: blur(2px);
}
.sn-ins-modal .box,
.chat-modal-content {
  background: var(--sn-color-surface) !important;
  border: 1px solid var(--sn-color-border) !important;
  color: var(--sn-color-text) !important;
}
.sn-chip {
  display: inline-flex;
  align-items: center;
  padding: 4px 10px;
  font: 500 var(--sn-font-size-sm)/1 var(--sn-font-sans);
  background: var(--sn-color-surface-alt);
  border: 1px solid var(--sn-color-border);
  border-radius: var(--sn-radius-pill);
}
.sn-chip--success {
  background: var(--sn-success);
  color: #fff;
}
.sn-chip--danger {
  background: var(--sn-danger);
  color: #fff;
}
.sn-chip--info {
  background: var(--sn-info);
  color: #fff;
}
.sn-select2 {
  width: 100%;
}
.sn-tag {
  display: inline-block;
  padding: 2px 6px;
  font: 600 var(--sn-font-size-xs)/1 var(--sn-font-sans);
  border-radius: var(--sn-radius-xs);
  background: var(--sn-color-surface-alt);
  color: var(--sn-color-text);
}
.sn-tag--dlc {
  background: var(--sn-info);
  color: #fff;
}
.sn-tag--mod {
  background: var(--sn-danger);
  color: #fff;
}
.sn-tag--base {
  background: var(--sn-muted);
  color: #fff;
}
.sn-text-danger {
  color: var(--sn-danger) !important;
}
.sn-text-success {
  color: var(--sn-success) !important;
}
.sn-text-warning {
  color: var(--sn-warning) !important;
}
.sn-bg-danger {
  background: var(--sn-danger) !important;
}
.sn-bg-success {
  background: var(--sn-success) !important;
}
.sn-tabs {
  --sn-tabs-bg: rgba(7, 10, 18, 0.92);
  display: flex;
  flex-wrap: wrap;
  gap: var(--sn-space-2);
  padding: var(--sn-space-3);
  border-radius: var(--sn-radius-lg);
  background: var(--sn-tabs-bg);
  border: 1px solid rgba(255, 255, 255, 0.05);
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.02),
    0 16px 32px rgba(0, 0, 0, 0.35);
  backdrop-filter: blur(8px);
}
.sn-tab {
  padding: var(--sn-space-2) var(--sn-space-4);
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: var(--sn-radius-pill);
  cursor: pointer;
  font: 600 var(--sn-font-size-sm)/1 var(--sn-font-sans);
  color: rgba(255, 255, 255, 0.85);
  position: relative;
  transition:
    background 0.15s,
    box-shadow 0.15s,
    transform 0.15s;
}
.sn-tab:hover {
  background: rgba(255, 255, 255, 0.08);
}
.sn-tab.active {
  background: var(--sn-grad-primary);
  color: #fff;
  border-color: var(--sn-primary-accent);
  box-shadow: 0 10px 30px -6px rgba(7, 86, 184, 0.45);
}
.sn-tabpanel {
  display: none;
  padding: var(--sn-space-4);
  border: 1px solid var(--sn-color-border);
  border-radius: var(--sn-radius-lg);
  background: rgba(255, 255, 255, 0.012);
  margin-top: -1px;
}
.sn-tabpanel.active {
  display: block;
}
.sn-menu-perfil-pilotos {
  display: flex;
  flex-wrap: wrap;
}
.sn-menu-perfil-pilotos .sn-tab-content {
  display: none;
}
}

@layer sn.core {
@media (min-width: 769px) {
  .sn-menu-perfil-pilotos .sn-menu-wrap {
    flex: 0 0 200px;
    display: flex;
    flex-direction: column;
  }
  .sn-menu-perfil-pilotos .sn-tab-arrows {
    display: none;
  }
  .sn-menu-perfil-pilotos .sn-tabs {
    display: flex;
    flex-direction: column;
    margin: 0;
    padding: 0;
    list-style: none;
    border: none;
    background: transparent;
    box-shadow: none;
  }
  .sn-menu-perfil-pilotos .sn-tabs li {
    margin-bottom: 8px;
  }
  .sn-menu-perfil-pilotos .sn-tabs a {
    display: flex;
    align-items: center;
    padding: 12px 16px;
    background: #1b1b1b;
    color: #fff;
    text-decoration: none;
    border-radius: 8px;
    border: none;
    transition: background 0.2s, filter 0.2s, border-color 0.2s;
    font-weight: 600;
  }
  .sn-menu-perfil-pilotos .sn-tabs a i {
    margin-right: 8px;
    font-size: 1.1em;
  }
  .sn-menu-perfil-pilotos .sn-tabs a:hover:not(.active) {
    background: #2a2a2a;
    color: #fff;
  }
  .sn-menu-perfil-pilotos .sn-tab-contents {
    flex: 1 1 0;
    padding: 1em;
    margin-left: 16px;
    min-width: 0;
  }
}
}

@layer sn.core {
@media (max-width: 768px) {
  .sn-menu-perfil-pilotos {
    flex-direction: column;
  }
  .sn-menu-perfil-pilotos .sn-menu-wrap {
    order: 0;
    width: 100%;
  }
  .sn-menu-perfil-pilotos .sn-tab-arrows {
    display: none;
  }
  .sn-menu-perfil-pilotos .sn-tabs {
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
    scroll-behavior: smooth;
    gap: 8px;
    margin: 0;
    padding: 8px;
    border: none;
    background: transparent;
    box-shadow: none;
    scrollbar-width: none;
  }
  .sn-menu-perfil-pilotos .sn-tabs::-webkit-scrollbar {
    height: 0;
  }
  .sn-menu-perfil-pilotos .sn-tabs::-webkit-scrollbar-thumb,
  .sn-menu-perfil-pilotos .sn-tabs::-webkit-scrollbar-track {
    background: transparent;
  }
  .sn-menu-perfil-pilotos .sn-tabs li {
    flex: 0 0 auto;
    margin: 0;
    list-style: none;
  }
  .sn-menu-perfil-pilotos .sn-tabs a {
    display: flex;
    align-items: center;
    padding: 10px 14px;
    background: #1b1b1b;
    color: #fff;
    text-decoration: none;
    border-radius: 8px;
    border: none;
    white-space: nowrap;
    transition: background 0.2s, filter 0.2s, border-color 0.2s;
    font-weight: 600;
  }
  .sn-menu-perfil-pilotos .sn-tabs a i {
    margin-right: 8px;
    font-size: 1.1em;
  }
  .sn-menu-perfil-pilotos .sn-tabs a:hover:not(.active) {
    background: #2a2a2a;
    color: #fff;
  }
  .sn-menu-perfil-pilotos .sn-tab-contents {
    order: 1;
    width: 100%;
    padding: 0.5em;
    margin-top: 8px;
  }
}
}

@layer sn.core {
.chat-title--compact {
  font-size: 0.95em;
}
.sn-tabs--compact {
  gap: 4px;
  padding: var(--sn-space-2);
  border-radius: var(--sn-radius-pill);
}
.sn-tabs--compact .sn-tab {
  padding: 4px 12px;
  font-size: var(--sn-font-size-xs);
  border-radius: var(--sn-radius-pill);
  background: rgba(255, 255, 255, 0.05);
}
.sn-tabs--compact .sn-tab.active {
  box-shadow: none;
}
.sn-tabs-ses {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  list-style: none;
  margin: 0 0 8px;
  padding: 0;
}
.sn-tabs-ses li {
  cursor: pointer;
  background: var(--sn-color-surface-alt);
  border: 1px solid var(--sn-color-border);
  padding: 4px 10px;
  font: 600 var(--sn-font-size-xs)/1 var(--sn-font-sans);
  border-radius: var(--sn-radius-xs);
  display: flex;
  align-items: center;
  gap: 4px;
  transition: 0.18s;
}
.sn-tabs-ses li.on {
  background: var(--sn-grad-theme);
  border-color: var(--sn-theme-primary-accent);
  color: #fff;
  box-shadow: 0 2px 8px -2px rgba(201, 13, 5, 0.55);
}
.sn-tabs-ses li:not(.on):hover {
  background: var(--sn-color-surface);
}
.sn-tabs-ses li.on i {
  color: #fff !important;
}
.sn-table {
  width: 100%;
  border-collapse: collapse;
  font: 500 var(--sn-font-size-sm)/1.25 var(--sn-font-sans);
  color: var(--sn-color-text);
  background: var(--sn-color-surface);
}
.sn-table th,
.sn-table td {
  padding: 8px 10px;
  text-align: left;
  border: 1px solid var(--sn-color-border);
  vertical-align: middle;
}
.sn-table thead th {
  background: var(--sn-color-surface-alt);
  font-weight: 600;
  font-size: var(--sn-font-size-sm);
}
.sn-table--compact th,
.sn-table--compact td {
  padding: 4px 6px;
  font-size: var(--sn-font-size-xs);
}
.sn-table-dark {
  background: linear-gradient(
    180deg,
    rgba(17, 20, 29, 0.96),
    rgba(11, 14, 20, 0.98)
  );
}
.sn-table-dark thead th {
  background: linear-gradient(
    180deg,
    rgba(20, 29, 48, 0.96),
    rgba(14, 19, 32, 0.98)
  );
}
.sn-table--zebra tbody tr:nth-child(odd) {
  background: rgba(255, 255, 255, 0.02);
}
.sn-table--spaced tbody tr {
  border-radius: var(--sn-radius-sm);
  box-shadow: var(--sn-shadow-xs);
}
.sn-table--spaced {
  border-collapse: separate;
  border-spacing: 0 6px;
}
.sn-table--no-border th,
.sn-table--no-border td {
  border: none;
}
.sn-table-responsive {
  width: 100%;
  overflow-x: auto;
}
.sn-aux-table-wrap .sn-aux-title {
  margin: 0 0 var(--sn-space-2);
  font: 700 var(--sn-font-size-md)/1 var(--sn-font-sans);
}
.sn-aux-table-wrap .sn-aux-subtitle {
  margin: 0 0 var(--sn-space-3);
  color: var(--sn-color-text-soft);
}
.sn-aux-table-wrap .sn-aux-table-container {
  overflow-x: auto;
}
table.sn-det-tab,
.sn-table.sn-table-serie,
.sn-table.sn-horas {
  font: inherit;
}
table.sn-det-tab th,
table.sn-det-tab td {
  padding: 6px 8px;
  border: 1px solid var(--sn-color-border);
}
table.sn-det-tab th {
  background: var(--sn-color-surface-alt);
}
@keyframes sn-pulse {
  0%,
  100% {
    filter: brightness(1);
  }
  50% {
    filter: brightness(1.15);
  }
}
.sn-panel {
  --sn-panel-bg: var(--sn-color-surface);
  --sn-panel-border: var(--sn-color-border);
  --sn-panel-radius: var(--sn-radius);
  background: var(--sn-panel-bg);
  border: 1px solid var(--sn-panel-border);
  border-radius: var(--sn-panel-radius);
  padding: var(--sn-space-4);
  color: var(--sn-color-text);
  position: relative;
}
.sn-panel--alt {
  --sn-panel-bg: var(--sn-color-surface-alt);
}
.sn-panel--subtle {
  --sn-panel-bg: rgba(255, 255, 255, 0.02);
}
.sn-panel--outline {
  background: transparent;
}
.sn-panel__header {
  margin: 0 0 var(--sn-space-3);
  font: 600 var(--sn-font-size-md)/1 var(--sn-font-sans);
  display: flex;
  align-items: center;
  gap: var(--sn-space-2);
  color: var(--sn-color-text);
}
.sn-panel__section {
  margin: 0 0 var(--sn-space-4);
}
.sn-panel__section:last-child {
  margin-bottom: 0;
}
.sn-panel__meta {
  font: 500 var(--sn-font-size-xs)/1.2 var(--sn-font-sans);
  color: var(--sn-color-text-soft);
  display: flex;
  flex-wrap: wrap;
  gap: var(--sn-space-2);
}
.sn-panel--accent {
  --sn-panel-border: var(--sn-primary);
  box-shadow:
    0 0 0 1px var(--sn-primary) inset,
    0 4px 18px -4px rgba(11, 99, 214, 0.35);
}
.sn-panel--danger {
  --sn-panel-border: var(--sn-danger);
  box-shadow:
    0 0 0 1px var(--sn-danger) inset,
    0 4px 18px -4px rgba(220, 53, 69, 0.35);
}
.sn-shell {
  display: grid;
  gap: var(--sn-space-4);
  min-width: 0;
}
.sn-shell__header,
.sn-shell__toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sn-space-3);
  min-width: 0;
}
.sn-shell__title {
  margin: 0;
  font: 700 clamp(1rem, 1.8vw, 1.3rem)/1.15 var(--sn-font-sans);
  color: var(--sn-color-text);
}
.sn-shell__body {
  min-width: 0;
}
.sn-shell__section-title {
  margin: 0 0 var(--sn-space-3);
  font: 700 var(--sn-font-size-sm)/1.2 var(--sn-font-sans);
  color: var(--sn-color-text);
  letter-spacing: 0.01em;
}
.sn-shell__metric-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: var(--sn-space-3);
}
.sn-shell__metric,
.sn-surface-card {
  background: linear-gradient(
    180deg,
    rgba(255, 255, 255, 0.03),
    rgba(255, 255, 255, 0.015)
  );
  border: 1px solid var(--sn-color-border);
  border-radius: calc(var(--sn-radius) + 2px);
  padding: var(--sn-space-3);
  color: var(--sn-color-text);
  min-width: 0;
}
.sn-shell__metric {
  display: grid;
  gap: 4px;
}
.sn-shell__metric strong {
  font-size: clamp(1rem, 2vw, 1.25rem);
  line-height: 1.05;
}
.sn-shell__metric span {
  color: var(--sn-color-text-soft);
  font-size: var(--sn-font-size-sm);
}
.sn-table-wrap {
  width: 100%;
  max-width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
.sn-empty-state,
.sn-loading-state {
  display: grid;
  justify-items: center;
  gap: var(--sn-space-2);
  min-height: 96px;
  padding: clamp(16px, 3vw, 24px);
  text-align: center;
  border-radius: calc(var(--sn-radius) + 2px);
  border: 1px dashed rgba(255, 255, 255, 0.14);
  background: linear-gradient(
    180deg,
    rgba(255, 255, 255, 0.03),
    rgba(255, 255, 255, 0.015)
  );
  color: var(--sn-color-text-soft);
}
.sn-empty-state i,
.sn-loading-state i {
  font-size: 1.1rem;
  color: var(--sn-theme-primary, #c90d05);
}
.sn-empty-state strong,
.sn-loading-state strong {
  color: var(--sn-color-text);
}
.sn-empty-state--error {
  border-color: rgba(220, 53, 69, 0.35);
  background: linear-gradient(
    180deg,
    rgba(220, 53, 69, 0.13),
    rgba(255, 255, 255, 0.02)
  );
}
.sn-empty-state--warn {
  border-color: rgba(255, 193, 7, 0.35);
  background: linear-gradient(
    180deg,
    rgba(255, 193, 7, 0.12),
    rgba(255, 255, 255, 0.02)
  );
}
.sn-empty-state--compact,
.sn-loading-state--compact {
  min-height: 0;
  padding: var(--sn-space-3);
}
.sn-loading-state__spinner {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  border: 2px solid rgba(255, 255, 255, 0.14);
  border-top-color: var(--sn-theme-primary, #c90d05);
  animation: sn-spin 0.85s linear infinite;
}
.sn-inline-widget-state {
  display: inline-grid;
  justify-items: center;
  gap: 6px;
  min-width: 140px;
  min-height: 0;
  padding: 10px 12px;
  vertical-align: middle;
}
.sn-inline-widget-state.sn-empty-state,
.sn-inline-widget-state.sn-loading-state {
  border-radius: var(--sn-radius);
}
.sn-toast-container {
  position: fixed;
  top: 16px;
  right: 16px;
  z-index: 1000002;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.sn-toast {
  display: flex;
  align-items: center;
  gap: 8px;
  min-width: min(320px, calc(100vw - 32px));
  max-width: 420px;
  padding: 10px 14px;
  border-radius: 12px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(18, 22, 31, 0.96);
  color: var(--sn-color-text, #fff);
  box-shadow: 0 14px 34px rgba(0, 0, 0, 0.36);
  backdrop-filter: blur(10px);
  font: 500 0.92rem/1.25
    var(--sn-font-sans, system-ui, -apple-system, Segoe UI, Roboto, sans-serif);
}
.sn-toast--success {
  border-color: rgba(92, 184, 92, 0.28);
}
.sn-toast--error {
  border-color: rgba(220, 53, 69, 0.3);
}
.sn-toast .sn-toast-icon {
  color: #fc6;
}
.sn-toast--success .sn-toast-icon {
  color: #8fd8a4;
}
.sn-toast--error .sn-toast-icon {
  color: #ff9a9a;
}
.sn-toast .sn-toast-close {
  margin-left: auto;
  padding: 0;
  background: transparent;
  border: 0;
  color: rgba(255, 255, 255, 0.78);
  cursor: pointer;
}
@keyframes sn-spin {
  to {
    transform: rotate(360deg);
  }
}
.sn-guest-card {
  --sn-guest-bg:
    radial-gradient(
      circle at 8% 15%,
      rgba(255, 255, 255, 0.08),
      transparent 55%
    ),
    linear-gradient(135deg, rgba(12, 15, 24, 0.95), rgba(6, 9, 15, 0.98));
  display: flex;
  align-items: center;
  gap: var(--sn-space-3, 12px);
  padding: clamp(14px, 2vw, 20px);
  border-radius: 20px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: var(--sn-guest-bg);
  box-shadow: 0 25px 40px rgba(0, 0, 0, 0.45);
  width: 100%;
  color: #f5f7ff;
}
.sn-guest-card--inline {
  justify-content: space-between;
  flex-wrap: wrap;
}
.sn-guest-card--compact {
  padding: 14px 16px;
  border-radius: 16px;
}
.sn-guest-card__icon {
  width: 54px;
  height: 54px;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.08);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 1.35rem;
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.06);
}
.sn-guest-card__body {
  flex: 1 1 280px;
  min-width: 0;
}
.sn-guest-card__title {
  margin: 0 0 4px;
  font: 600 var(--sn-font-size-md, 1rem)/1.2 var(--sn-font-sans);
}
.sn-guest-card__text {
  margin: 0;
  color: rgba(255, 255, 255, 0.72);
  font-size: var(--sn-font-size);
}
.sn-guest-card .sn-btn {
  flex-shrink: 0;
  min-width: 150px;
}
.sn-welcome-banner {
  display: grid;
  grid-template-columns: 46px minmax(0, 1fr);
  align-items: center;
  gap: 14px;
  width: 100%;
  padding: 8px 16px;
  border-radius: 20px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background:
    linear-gradient(90deg, rgba(255, 255, 255, 0.04), transparent 26%),
    linear-gradient(115deg, #0b1326, #04070d 62%, #071226);
  box-shadow: 0 12px 26px rgba(0, 0, 0, 0.22);
  color: #f4f6ff;
}
.sn-welcome-banner__icon {
  width: 40px;
  height: 40px;
  border-radius: 14px;
  background: linear-gradient(180deg, #f01c12, #b80700);
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: 0.92rem;
  box-shadow:
    0 8px 18px rgba(200, 13, 5, 0.24),
    inset 0 0 0 1px rgba(255, 255, 255, 0.12);
}
.sn-welcome-banner__content {
  min-width: 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}
.sn-welcome-banner__title {
  margin: 0;
  color: #fff;
  font: 700 0.98rem/1.2 var(--sn-font-sans);
  letter-spacing: 0;
  white-space: nowrap;
  flex-shrink: 0;
}
.sn-welcome-banner__subtitle {
  margin: 0;
  color: rgba(255, 255, 255, 0.78);
  font-size: var(--sn-font-size);
}
.sn-welcome-banner__links {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
  min-width: 0;
}
.sn-welcome-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 36px;
  padding: 4px 12px 4px 6px;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.07);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.045), rgba(255, 255, 255, 0.02));
  color: #f7f8ff;
  text-decoration: none;
  font-size: 0.83rem;
  font-weight: 600;
  line-height: 1;
  transition: background-color 0.2s ease, border-color 0.2s ease,
    transform 0.2s ease;
  white-space: nowrap;
}
.sn-welcome-link i {
  width: 24px;
  height: 24px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(180deg, #f01c12, #b80700);
  color: #fff;
  font-size: 0.68rem;
  flex-shrink: 0;
  box-shadow: 0 5px 12px rgba(200, 13, 5, 0.22);
}
.sn-welcome-link:hover {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.04));
  border-color: rgba(240, 28, 18, 0.38);
  color: #fff;
  transform: translateY(-1px);
}
.sn-welcome-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 18px;
  height: 18px;
  padding: 0 5px;
  margin-left: 2px;
  border-radius: 999px;
  background: #c90d05;
  color: #fff;
  font-size: 0.7rem;
  font-weight: 800;
}
}

@layer sn.core {
@media (min-width: 901px) {
  .sn-welcome-banner__links {
    row-gap: 6px;
  }
}
}

@layer sn.core {
@media (max-width: 1100px) {
  .sn-welcome-banner {
    padding: 10px 12px;
  }
  .sn-welcome-banner__content {
    flex-direction: column;
    align-items: stretch;
    gap: 10px;
  }
  .sn-welcome-banner__links {
    justify-content: flex-start;
  }
}
}

@layer sn.core {
@media (max-width: 720px) {
  .sn-guest-card,
  .sn-welcome-banner {
    flex-direction: column;
    align-items: flex-start;
  }
  .sn-guest-card .sn-btn {
    width: 100%;
  }
  .sn-guest-card__icon,
  .sn-welcome-banner__icon {
    width: 28px;
    height: 28px;
    font-size: 0.9rem;
  }
  .sn-welcome-banner {
    display: flex;
    gap: 8px;
    padding: 10px 12px;
    border-radius: 18px;
  }
  .sn-welcome-banner__content {
    width: 100%;
    gap: 8px;
    align-items: stretch;
  }
  .sn-welcome-banner__title {
    font-size: 0.84rem;
    white-space: normal;
  }
  .sn-welcome-banner__links {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
    width: 100%;
  }
  .sn-welcome-link {
    min-width: 0;
    width: 100%;
    min-height: 40px;
    padding: 4px 10px 4px 6px;
    font-size: 0.76rem;
  }
  .sn-welcome-link i {
    width: 24px;
    height: 24px;
    font-size: 0.72rem;
  }
  .sn-welcome-link:last-child:nth-child(odd) {
    grid-column: 1 / -1;
  }
}
}

@layer sn.core {
.sn-timeline {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: var(--sn-space-3);
  padding-left: 18px;
}
.sn-timeline:before {
  content: "";
  position: absolute;
  left: 6px;
  top: 0;
  bottom: 0;
  width: 2px;
  background: var(--sn-color-border);
}
.sn-timeline-item {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.sn-timeline-item:before {
  content: "";
  position: absolute;
  left: -12px;
  top: 4px;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--sn-color-surface-alt);
  border: 2px solid var(--sn-color-border-light);
  box-shadow: 0 0 0 2px var(--sn-color-bg);
}
.sn-timeline-item--current:before {
  background: var(--sn-primary);
  border-color: var(--sn-primary-accent);
}
.sn-timeline-item--success:before {
  background: var(--sn-success);
  border-color: var(--sn-success);
}
.sn-timeline-item--danger:before {
  background: var(--sn-danger);
  border-color: var(--sn-danger);
}
.sn-timeline-item__title {
  font: 600 var(--sn-font-size-sm)/1.2 var(--sn-font-sans);
}
.sn-timeline-item__meta {
  font: 500 var(--sn-font-size-xs)/1.2 var(--sn-font-sans);
  color: var(--sn-color-text-faint);
}
.sn-flow-row {
  --sn-flow-bg: var(--sn-color-surface-alt);
  --sn-flow-border: var(--sn-color-border);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sn-space-2);
  padding: 6px 8px;
  background: var(--sn-flow-bg);
  border: 1px solid var(--sn-flow-border);
  border-radius: var(--sn-radius-sm);
  font: 500 var(--sn-font-size-sm)/1.2 var(--sn-font-sans);
}
.sn-flow-row--success {
  --sn-flow-bg: linear-gradient(135deg, #13271a, #1e3a28);
  --sn-flow-border: #2e5a3b;
}
.sn-flow-row--danger {
  --sn-flow-bg: linear-gradient(135deg, #2a1717, #3a1f1f);
  --sn-flow-border: #6a2a2a;
}
.sn-flow-row--pending {
  --sn-flow-bg: linear-gradient(135deg, #1f1a12, #2a2416);
  --sn-flow-border: #6a5a20;
}
.sn-flow-pos {
  font-variant-numeric: tabular-nums;
  font-weight: 600;
  color: var(--sn-color-text-soft);
}
.sn-flow-dest {
  color: var(--sn-color-text);
}
.sn-mini-pill {
  --sn-mini-pill-bg: var(--sn-color-surface-alt);
  --sn-mini-pill-border: var(--sn-color-border);
  --sn-mini-pill-fg: var(--sn-color-text-soft);
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 2px 8px;
  font: 600 var(--sn-font-size-xs)/1 var(--sn-font-sans);
  border: 1px solid var(--sn-mini-pill-border);
  background: var(--sn-mini-pill-bg);
  color: var(--sn-mini-pill-fg);
  border-radius: var(--sn-radius-pill);
}
.sn-mini-pill--success {
  --sn-mini-pill-bg: #13271a;
  --sn-mini-pill-border: #2e5a3b;
  --sn-mini-pill-fg: #d4f2dd;
}
.sn-mini-pill--danger {
  --sn-mini-pill-bg: #2a1717;
  --sn-mini-pill-border: #6a2a2a;
  --sn-mini-pill-fg: #f6d1d1;
}
.sn-mini-pill--warning {
  --sn-mini-pill-bg: #1f1a12;
  --sn-mini-pill-border: #6a5a20;
  --sn-mini-pill-fg: #f6e3b9;
}
.sn-stack-sm {
  display: flex;
  flex-direction: column;
  gap: var(--sn-space-2);
}
.sn-stack {
  display: flex;
  flex-direction: column;
  gap: var(--sn-space-3);
}
.sn-inline {
  display: inline-flex;
  align-items: center;
  gap: var(--sn-space-2);
}
.sn-font-scale-up {
  --sn-font-scale: 1.08;
}
.sn-font-scale-up2 {
  --sn-font-scale: 1.15;
}
.sn-visually-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  overflow: hidden;
  clip: rect(0 0 0 0);
  border: 0;
}
.sn-transition {
  transition:
    background 0.18s,
    color 0.18s,
    border-color 0.18s,
    box-shadow 0.18s;
}
.sn-anim-pulse {
  animation: sn-pulse 2s ease-in-out infinite;
}
.chat-header {
  background: var(--sn-theme-primary) !important;
}
.chat-send-btn:hover {
  filter: brightness(1.1);
}
}

@layer sn.core {
@media (max-width: 780px) {
  .sn-modal__dialog {
    max-width: 100%;
    border-radius: var(--sn-radius);
  }
  .sn-shell__header,
  .sn-shell__toolbar,
  .sn-modal__footer {
    flex-direction: column;
    align-items: stretch;
  }
  .sn-shell__header > *,
  .sn-shell__toolbar > *,
  .sn-modal__footer > * {
    width: 100%;
    min-width: 0;
  }
  .sn-modal__body {
    padding: var(--sn-space-3);
  }
  .sn-shell__metric-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .sn-tabs,
  .sn-tabs-ses {
    flex-wrap: nowrap;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: thin;
    padding-bottom: 4px;
  }
  .sn-tabs .sn-tab,
  .sn-tabs-ses li {
    flex: 0 0 auto;
    white-space: nowrap;
  }
  .sn-table-wrap {
    margin-inline: calc(var(--sn-space-3, 16px) * -0.35);
    padding-inline: calc(var(--sn-space-3, 16px) * 0.35);
  }
}
}

@layer sn.core {
@media (max-width: 480px) {
  .sn-btn {
    padding: 10px 14px;
  }
  .sn-shell__metric-grid {
    grid-template-columns: 1fr;
  }
  .sn-panel,
  .sn-shell__metric,
  .sn-surface-card {
    padding: var(--sn-space-3);
  }
  .sn-modal {
    padding: 10px;
    align-items: flex-end;
  }
  .sn-modal__dialog {
    max-height: min(88vh, 88dvh);
    border-radius: 18px 18px 12px 12px;
  }
}
}

@layer sn.core {
.sn-legacy-btn {
  border-radius: var(--sn-radius-pill) !important;
}
.sn-ins-badge.open,
.sn-open-badge {
  background: var(--sn-grad-success) !important;
  color: #e6ffe6 !important;
}
.sn-ins-badge.espera,
.sn-ins-badge.locked {
  background: linear-gradient(135deg, #22314a, #162032) !important;
  color: #e0e6ef !important;
}
.sn-ins-badge.full,
.sn-ins-badge.closed {
  background: var(--sn-grad-muted) !important;
  color: #ccc !important;
}
.sn-ins-badge.cancelled,
.sn-ins-badge.error {
  background: var(--sn-grad-danger) !important;
  color: #ffeaea !important;
}
.sn-ins-badge.limit,
.sn-ins-badge.competition_limit {
  background: var(--sn-grad-warning) !important;
  color: #ffe6b3 !important;
}
.sn-ins-badge.en_curso {
  background: linear-gradient(135deg, #3d2c4d, #241a2e) !important;
  color: #e6e0ff !important;
}
.chat-modal {
  z-index: var(--sn-z-modal) !important;
}
.chat-modal-content {
  z-index: calc(var(--sn-z-modal) + 1) !important;
}
:where(.tor-content, .tor-panel, .tor-sc-wrap) .sn-btn,
:where(.tor-content, .tor-panel, .tor-sc-wrap) .sn-btn-primary,
button.sn-btn,
.sn-btn.button,
.sn-btn.btn,
.sn-btn[type="submit"],
.sn-btn[type="button"],
.tor-btn,
.tor-actions .tor-btn,
.tor-panel-toggle,
.tor-panel .sn-btn,
.tor-panel-card .tor-btn,
.tor-cal-card .tor-btn {
  background: var(
    --sn-grad-theme,
    linear-gradient(135deg, #c90d05, #9e0a03)
  ) !important;
  border: 1px solid var(--sn-theme-primary-accent, #820600) !important;
  color: #fff !important;
  border-radius: var(--sn-radius-btn) !important;
  font: 600 var(--sn-font-size-sm)/1 var(--sn-font-sans) !important;
  line-height: 1.1 !important;
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 8px 16px !important;
  min-height: 38px;
  box-shadow: 0 2px 6px rgba(201, 13, 5, 0.42);
  transition:
    filter 0.18s ease,
    transform 0.18s ease;
}
:where(.tor-content, .tor-panel, .tor-sc-wrap) .sn-btn[style*="display:none"],
:where(.tor-content, .tor-panel, .tor-sc-wrap) .sn-btn[style*="display: none"],
.sn-btn[hidden],
.tor-btn[style*="display:none"],
.tor-btn[style*="display: none"] {
  display: none !important;
}
:where(.tor-content, .tor-panel, .tor-sc-wrap) .sn-btn:hover,
.tor-btn:hover,
.tor-panel .sn-btn:hover,
.tor-panel-card .tor-btn:hover {
  filter: brightness(1.08);
}
:where(.tor-content, .tor-panel, .tor-sc-wrap) .sn-btn:active,
.tor-btn:active,
.tor-panel .sn-btn:active,
.tor-panel-card .tor-btn:active {
  transform: translateY(1px);
}
.sn-chat-toggle {
  width: 52px !important;
  height: 52px !important;
  border-radius: var(--sn-radius-pill) !important;
  background: var(
    --sn-grad-theme,
    linear-gradient(135deg, #c90d05, #8f0700)
  ) !important;
  border: 1px solid var(--sn-theme-primary-accent, #820600) !important;
  color: #fff !important;
  box-shadow: 0 12px 28px rgba(0, 0, 0, 0.46);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition:
    transform 0.18s ease,
    filter 0.18s ease;
}
.sn-chat-toggle:hover {
  filter: brightness(1.08);
}
.sn-chat-toggle:active {
  transform: scale(0.95);
}
.sn-chat-close {
  background: transparent !important;
  border: none !important;
  border-radius: var(--sn-radius-sm) !important;
  color: var(--sn-color-text, #fff) !important;
  width: 32px !important;
  height: 32px !important;
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  transition:
    background 0.18s,
    color 0.18s;
}
.sn-chat-close:hover {
  background: rgba(255, 255, 255, 0.08) !important;
}
.sn-chat-mobile {
  position: fixed;
  bottom: calc(env(safe-area-inset-bottom, 0px) + 78px) !important;
  right: calc(env(safe-area-inset-right, 0px) + 22px) !important;
  z-index: calc(var(--sn-z-sticky, 4500) + 120);
}
.sn-chat-desktop {
  background: transparent;
  border-radius: var(--sn-radius-lg, 12px);
  margin-bottom: var(--sn-space-4, 1.5rem);
  overflow: hidden;
}
.sn-chat-desktop .sn-chat-item {
  width: 100%;
  position: relative;
}
.sn-chat-badge {
  position: absolute;
  top: -5px;
  right: -5px;
  background: #ff4757;
  color: #fff;
  border-radius: 50%;
  width: 20px;
  height: 20px;
  font-size: 12px;
  font-weight: 700;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  animation: sn-chat-pulse 2s infinite;
}
@keyframes sn-chat-pulse {
  50% {
    transform: scale(1.1);
  }
}
.sn-chat-header {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  position: relative;
  z-index: 3;
}
.sn-chat-container.keyboard-open {
  bottom: var(--sn-kb-offset, 0) !important;
}
.sn-chat-container.keyboard-open .chat-messages {
  padding-bottom: calc(8px + var(--sn-kb-offset, 0)) !important;
}
.sn-chat-toggle::after {
  content: "";
}
.sn-chat-toggle .sn-chat-toggle-icon {
  display: inline-flex;
}
}

@layer sn.core {
@media (max-width: 991px) {
  .sn-chat-container {
    position: fixed !important;
    left: 10px !important;
    right: 10px !important;
    bottom: 0 !important;
    top: auto !important;
    width: auto !important;
    max-width: calc(100% - 20px) !important;
    height: min(78vh, calc(100dvh - 120px)) !important;
    max-height: min(78vh, calc(100dvh - 120px)) !important;
    margin: 0 !important;
    background: var(--sn-color-surface, #101822) !important;
    border-radius: 18px !important;
    box-shadow: 0-2px 18px rgba(0, 0, 0, 0.45);
    display: flex !important;
    flex-direction: column !important;
    transform: translateY(105%);
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    overflow: hidden;
    transition:
      transform 0.28s ease,
      opacity 0.25s,
      visibility 0.25s;
    z-index: calc(var(--sn-z-sticky, 4500) + 200);
  }
  .sn-chat-container.open {
    transform: translateY(0);
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
  }
  .sn-chat-overlay {
    position: fixed;
    inset: 0;
    background: rgba(5, 7, 12, 0.55);
    backdrop-filter: blur(2px);
    z-index: calc(var(--sn-z-sticky, 4500) + 190);
    display: none;
  }
  .sn-chat-overlay.active {
    display: block;
  }
  .sn-chat-mobile-wrapper {
    flex: 1 1 auto;
    display: flex;
    flex-direction: column;
    min-height: 0;
    overflow: hidden;
  }
  .sn-chat-mobile-wrapper #nitro-chat-container {
    flex: 1 1 auto;
    display: flex;
    flex-direction: column;
    min-height: 0;
  }
  .sn-chat-desktop {
    display: none !important;
  }
  .sn-chat-mobile {
    display: block;
  }
}
}

@layer sn.core {
@media (max-width: 480px) {
  .sn-chat-mobile {
    bottom: calc(env(safe-area-inset-bottom, 0px) + 102px) !important;
    right: calc(env(safe-area-inset-right, 0px) + 12px) !important;
  }
  .sn-chat-toggle {
    width: 44px !important;
    height: 44px !important;
  }
}
}

@layer sn.core {
.chat-send-btn,
.send-message,
.sn-chat-mobile-wrapper .chat-send-btn {
  background: var(
    --sn-grad-theme,
    linear-gradient(135deg, #c90d05, #9e0a03)
  ) !important;
  border: 1px solid var(--sn-theme-primary-accent, #820600) !important;
  color: #fff !important;
  border-radius: var(--sn-radius-btn) !important;
  padding: 8px 16px !important;
  min-height: 40px;
  font: 600 var(--sn-font-size-sm)/1 var(--sn-font-sans) !important;
  box-shadow: 0 2px 6px rgba(201, 13, 5, 0.45);
}
.chat-send-btn:disabled,
.send-message:disabled {
  opacity: 0.55;
  cursor: not-allowed;
}
.sn-tor-badge {
  position: relative;
  isolation: isolate;
}
.sn-tor-badge:focus-visible {
  outline: 2px solid rgba(255, 255, 255, 0.3);
  outline-offset: 3px;
}
.pw-close,
.sn-tor-close {
  color: var(--sn-color-text-soft, #ccc) !important;
  border-radius: var(--sn-radius-sm) !important;
  background: transparent !important;
  border: none !important;
}
.pw-close:hover,
.sn-tor-close:hover {
  background: rgba(255, 255, 255, 0.08) !important;
  color: #fff !important;
}
.tor-content input[type="text"],
.tor-content input[type="email"],
.tor-content input[type="number"],
.tor-content textarea,
.tor-content select {
  border-radius: var(--sn-radius-pill) !important;
  background: var(--sn-color-surface, #1a1a1a) !important;
  color: var(--sn-color-text, #f5f5f5) !important;
  border: 1px solid var(--sn-color-border, #2a2a2a) !important;
  padding: 10px 14px !important;
}
:root {
  --sn-modal-max-width: 1100px;
}
.sn-modal-overlay,
.tor-res-overlay,
.tor-std-overlay,
.pw-overlay {
  position: fixed;
  inset: 0;
  display: none;
  align-items: center !important;
  justify-content: center !important;
  padding: 32px 20px !important;
  box-sizing: border-box;
}
.sn-np-modal {
  align-items: center !important;
  justify-content: center !important;
  box-sizing: border-box;
}
.sn-modal-overlay {
  z-index: var(--sn-z-modal);
  background: var(--sn-color-overlay);
}
.sn-modal-overlay.on,
.tor-res-overlay.on,
.tor-std-overlay.on,
.pw-open .pw-overlay {
  display: flex !important;
}
.sn-modal__dialog,
.sn-modal.sn-modal-denuncia,
.sn-modal.sn-modal-resolver,
.sn-modal.sn-modal-ver,
.sn-modal.sn-modal-historial,
.tor-res-modal,
.tor-std-modal,
.pw-modal,
.sn-np-modal-content {
  width: min(var(--sn-modal-max-width), 96vw) !important;
  max-width: var(--sn-modal-max-width) !important;
  margin: 0 auto !important;
  border-radius: var(--sn-radius-lg) !important;
}
.sn-tab.active,
.sn-tabs-ses li.on,
.tor-res-tab.on,
.tor-den-modal .den-tabs button.on,
.tor-standings .tor-std-tab.on,
.tor-reglamento-tab.on,
.sn-np-tab.active {
  background: var(
    --sn-grad-theme,
    linear-gradient(135deg, #c90d05, #9e0a03)
  ) !important;
  border-color: var(--sn-theme-primary-accent, #7d0803) !important;
  color: #fff !important;
  box-shadow: 0 8px 20px rgba(201, 13, 5, 0.32) !important;
}
select.sn-input,
.sn-input select,
select {
  background: #111 !important;
  color: #fff !important;
  border-color: #2a2a2a !important;
}
.sn-table thead th,
.tor-cal-table thead th,
.tor-std-table thead th,
.tor-res-table thead th,
.sn-np-table thead th {
  font-size: var(--sn-font-size-sm) !important;
  font-weight: 700 !important;
  letter-spacing: 0.01em;
  background: var(--sn-color-surface-alt, #202020) !important;
  color: #fff !important;
}
.estado,
.tor-estado-badge,
.sn-ins-badge,
.sn-open-badge {
  border-radius: var(--sn-radius-pill) !important;
  border: 1px solid transparent !important;
  font-weight: 600 !important;
}
.estado-programado,
.estado-programada,
.estado-pendiente,
.sn-ins-badge.espera,
.sn-ins-badge.locked {
  background: #1f2937 !important;
  color: #e5e7eb !important;
  border-color: #374151 !important;
}
.estado-curso,
.estado-en-curso,
.estado-activo,
.estado-activa,
.sn-ins-badge.en_curso {
  background: #78350f !important;
  color: #fde68a !important;
  border-color: #92400e !important;
}
.estado-completado,
.estado-completada,
.estado-finalizado,
.estado-finalizada,
.estado-cerrada,
.sn-ins-badge.closed,
.sn-ins-badge.full {
  background: #14532d !important;
  color: #bbf7d0 !important;
  border-color: #166534 !important;
}
.sn-profile-edit {
  max-width: 1100px;
  margin: 0 auto var(--sn-space-5);
  padding: clamp(20px, 3vw, 34px);
  gap: var(--sn-space-4);
}
.sn-profile-edit .sn-title {
  margin: 0;
  font-size: clamp(1.45rem, 2.8vw, 1.9rem);
  font-weight: 700;
  color: var(--sn-color-text);
}
.sn-profile-edit .sn-subtitle,
.sn-profile-edit .sn-subtext,
.sn-profile-edit .sn-note {
  color: var(--sn-color-text-soft);
}
.sn-profile-edit .sn-progress {
  position: relative;
  overflow: hidden;
  min-height: 28px;
  border-radius: var(--sn-radius-pill);
  border: 1px solid var(--sn-color-border);
  background: rgba(255, 255, 255, 0.05);
}
.sn-profile-edit .sn-bar {
  height: 100%;
  background: var(--sn-success);
}
.sn-profile-edit .sn-progress.error .sn-bar {
  background: var(--sn-danger);
}
.sn-profile-edit .sn-text {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 var(--sn-space-3);
  color: #fff;
  font-weight: 700;
  font-size: var(--sn-font-size-sm);
  text-align: center;
}
.sn-profile-edit .sn-row {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--sn-space-3);
  margin-bottom: var(--sn-space-3);
  padding: var(--sn-space-3);
  border: 1px solid var(--sn-color-border);
  border-radius: var(--sn-radius-lg);
  background: rgba(255, 255, 255, 0.02);
}
.sn-profile-edit .sn-form > .sn-row:nth-of-type(1),
.sn-profile-edit .sn-form > .sn-row:nth-of-type(3) {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
.sn-profile-edit .sn-full {
  grid-column: 1/-1;
}
.sn-profile-edit .sn-label,
.sn-profile-edit .sn-row label {
  display: flex;
  flex-direction: column;
  gap: 6px;
  color: var(--sn-color-text);
  font-weight: 600;
}
.sn-profile-edit .sn-row label[data-required="1"]::after {
  content: " *";
  color: var(--sn-danger);
}
.sn-profile-edit .sn-form :is(input, select, textarea) {
  width: 100%;
  background: #111;
  color: #fff;
  border: 1px solid var(--sn-color-border);
  border-radius: 14px;
  padding: 10px 14px;
}
.sn-profile-edit .sn-form textarea {
  min-height: 100px;
  resize: vertical;
}
.sn-profile-edit .sn-form h3 {
  margin: var(--sn-space-4) 0 var(--sn-space-2);
  padding-bottom: var(--sn-space-2);
  border-bottom: 1px solid rgba(201, 13, 5, 0.28);
  color: var(--sn-color-text);
  font-size: 1.05rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
.sn-profile-edit .sn-save-top,
.sn-profile-edit .sn-save-bottom {
  display: flex;
  justify-content: flex-end;
}
.sn-profile-edit .sn-profile-save {
  min-width: 180px;
}
.sn-profile-edit .edad-toggle {
  display: inline-flex;
  align-items: center;
  gap: 0.65rem;
  color: var(--sn-color-text);
  cursor: pointer;
}
.sn-profile-edit .edad-toggle input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}
.sn-profile-edit .edad-slider {
  position: relative;
  width: 50px;
  height: 24px;
  border-radius: 999px;
  background: var(--sn-color-border);
  transition: background 0.2s ease;
}
.sn-profile-edit .edad-slider::before {
  content: "";
  position: absolute;
  top: 3px;
  left: 3px;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: #fff;
  transition: transform 0.2s ease;
}
.sn-profile-edit .edad-toggle input:checked + .edad-slider {
  background: var(--sn-success);
}
.sn-profile-edit .edad-toggle input:checked + .edad-slider::before {
  transform: translateX(26px);
}
.sn-mensajes-panel {
  gap: var(--sn-space-4);
}
.sn-mensajes-panel .sn-form-grid {
  display: grid;
  grid-template-columns: 1fr 200px 1fr;
  gap: var(--sn-space-3);
  margin: 0;
}
.sn-mensajes-panel .sn-form-grid--compact {
  grid-template-columns: 1fr 200px;
  align-items: end;
}
.sn-mensajes-panel .sn-destino-row,
.sn-mensajes-panel .sn-destino-edit-row {
  display: grid;
  gap: var(--sn-space-2);
  align-items: center;
}
.sn-mensajes-panel .sn-destino-row {
  grid-template-columns: 220px 1fr 260px 160px;
}
.sn-mensajes-panel .sn-destino-edit-row {
  grid-template-columns: 140px 120px 1fr 110px 130px;
  margin-bottom: var(--sn-space-2);
}
.sn-mensajes-panel .sn-actions,
.sn-mensajes-panel .sn-row-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sn-space-2);
}
.sn-mensajes-panel .sn-result {
  min-height: 52px;
  padding: var(--sn-space-3);
  border-radius: var(--sn-radius);
  border: 1px solid var(--sn-color-border);
  background: rgba(255, 255, 255, 0.02);
  white-space: pre-wrap;
}
.sn-mensajes-panel .sn-table-wrap {
  max-height: 520px;
}
.sn-mensajes-panel #sn_tbl_coms {
  min-width: 920px;
}
.sn-mensajes-panel .sn-col-num,
.sn-mensajes-panel .sn-col-metric {
  text-align: right;
}
.sn-comisarios-wrap {
  gap: var(--sn-space-4);
}
.sn-comisarios-wrap .sn-topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: var(--sn-space-2);
}
.sn-comisarios-wrap .sn-tz-note {
  margin: 6px 0 10px;
}
.sn-comisarios-wrap .sn-role-section {
  position: relative;
  margin-bottom: var(--sn-space-4);
  padding: var(--sn-space-3);
  border: 1px solid var(--sn-color-border);
  border-radius: var(--sn-radius-lg);
  background: rgba(255, 255, 255, 0.02);
}
.sn-comisarios-wrap .sn-role-section::before {
  content: "";
  position: absolute;
  inset: 0;
  border-left: 3px solid var(--sn-color-border);
  border-radius: inherit;
  pointer-events: none;
}
.sn-comisarios-wrap .sn-role-section[data-role="6"]::before {
  border-color: var(--sn-primary);
}
.sn-comisarios-wrap .sn-role-section[data-role="7"]::before {
  border-color: #1f7fde;
}
.sn-comisarios-wrap .sn-role-section[data-role="8"]::before {
  border-color: #a855f7;
}
.sn-comisarios-wrap .sn-section-title {
  margin: 0 0 var(--sn-space-2);
  color: var(--sn-color-text);
  font-size: var(--sn-font-size-sm);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
.sn-comisarios-wrap table.sn-table td:last-child {
  width: 160px;
  white-space: nowrap;
}
.sn-comisarios-wrap .sn-com-item {
  padding: var(--sn-space-3);
  border: 1px solid var(--sn-color-border);
  border-radius: var(--sn-radius);
  background: rgba(255, 255, 255, 0.02);
}
.sn-comisarios-wrap .sn-com-head {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  margin-bottom: 4px;
  font-size: var(--sn-font-size-sm);
  font-weight: 600;
}
.sn-comisarios-wrap .sn-com-date {
  margin-left: auto;
  color: var(--sn-color-text-faint);
  font-size: var(--sn-font-size-xs);
}
.sn-comisarios-wrap .sn-com-text {
  margin: 0;
  white-space: pre-line;
  color: var(--sn-color-text-soft);
}
.sn-comisarios-wrap .sn-com-adj {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: var(--sn-space-2);
}
.sn-comisarios-wrap .sn-com-adj a {
  color: var(--sn-primary);
}
.sn-comisarios-wrap [data-sn="modal-tab-resolver"] .sn-grid.sn-grid-3 {
  grid-template-columns: repeat(3, minmax(0, 1fr)) auto;
  align-items: end;
}
.sn-comisarios-wrap .sn-modal__dialog {
  max-width: 1100px;
}
.sn-f1-ranking,
.sn-iracing-ranking {
  gap: var(--sn-space-4);
  font-family: var(--sn-font-sans);
}
.sn-f1-header,
.sn-iracing-heading {
  display: grid;
  gap: 8px;
  text-align: center;
}
.sn-f1-header h2,
.sn-iracing-title {
  margin: 0;
  color: var(--sn-color-text);
  font-size: clamp(1.35rem, 2.4vw, 1.75rem);
  font-weight: 700;
}
.sn-f1-header p,
.sn-iracing-subtitle,
.sn-f1-lastupdate {
  margin: 0;
  color: var(--sn-color-text-soft);
}
.sn-f1-ranking .sn-tabs,
.sn-iracing-ranking .sn-tabs {
  flex-wrap: nowrap;
  overflow-x: auto;
}
.sn-f1-sim-logo {
  width: 40px;
  height: 40px;
  -o-object-fit: contain;
     object-fit: contain;
}
.sn-f1-table,
.sn-f1-modal-table {
  min-width: 980px;
}
.sn-f1-table td .rec,
.sn-f1-table td .v2,
.sn-f1-table td .v3,
.sn-f1-modal-table td .v2,
.sn-f1-modal-table td .v3 {
  color: var(--sn-color-text-soft);
  font-size: var(--sn-font-size-xs);
}
.sn-f1-table td.best {
  background: rgba(201, 13, 5, 0.2);
  color: #fff;
}
.sn-f1-ranking .td-penas,
.sn-f1-modal-table .td-penas {
  color: #ffb27f;
}
.sn-f1-ranking .td-puntaje,
.sn-f1-modal-table .td-puntaje {
  color: #ffd166;
  font-weight: 700;
}
.sn-f1-ranking .td-pos,
.sn-f1-modal-table .td-pos {
  color: #9ad0ff;
}
.sn-f1-ranking .td-total,
.sn-f1-modal-table .td-total {
  color: #bbf7d0;
  font-weight: 700;
}
.sn-avatar {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  -o-object-fit: cover;
     object-fit: cover;
}
.sn-user-card {
  display: flex;
  align-items: stretch;
  justify-content: space-between;
  gap: var(--sn-space-3);
  padding: var(--sn-space-3);
  border: 1px solid var(--sn-color-border);
  border-radius: var(--sn-radius-lg);
  background: rgba(255, 255, 255, 0.02);
}
.sn-user-card-left {
  display: flex;
  gap: var(--sn-space-3);
  align-items: center;
  min-width: 0;
}
.sn-user-pos-badge {
  min-width: 48px;
  padding: 0.35rem 0.55rem;
  border-radius: var(--sn-radius);
  background: #ff8a00;
  color: #111;
  font-weight: 800;
  text-align: center;
}
.sn-user-name {
  font-size: 1rem;
  font-weight: 700;
  color: var(--sn-color-text);
}
.sn-user-sub {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem 0.8rem;
  color: var(--sn-color-text-soft);
  font-size: var(--sn-font-size-xs);
}
.sn-user-card-right {
  display: grid;
  grid-template-columns: repeat(5, minmax(90px, 1fr));
  gap: var(--sn-space-2);
  align-items: center;
}
.sn-user-stat {
  padding: 0.45rem 0.55rem;
  border: 1px solid var(--sn-color-border);
  border-radius: var(--sn-radius);
  background: rgba(255, 255, 255, 0.02);
  text-align: center;
}
.sn-user-stat-label {
  color: var(--sn-color-text-faint);
  font-size: 0.68rem;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}
.sn-user-stat-value {
  margin-top: 0.2rem;
  color: var(--sn-color-text);
  font-size: 0.95rem;
  font-weight: 700;
}
.sn-iracing-table {
  min-width: 850px;
}
.sn-row-toggle {
  display: none;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  margin-left: 0.35rem;
  padding: 0;
  border: 1px solid var(--sn-color-border);
  border-radius: var(--sn-radius-sm);
  background: rgba(255, 255, 255, 0.03);
  color: var(--sn-color-text);
}
.sn-iracing-row-details {
  display: none;
}
.sn-iracing-row.is-expanded + .sn-iracing-row-details {
  display: table-row;
}
.sn-row-details-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--sn-space-2) var(--sn-space-3);
}
.sn-row-details-item {
  display: flex;
  gap: 0.5rem;
  align-items: center;
}
.sn-col-irating {
  color: #55b6ff;
  font-weight: 700;
}
.sn-col-safety {
  color: #9bdc4d;
  font-weight: 700;
}
.sn-iracing-pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--sn-space-2);
}
.sn-pg-info {
  color: var(--sn-color-text-soft);
  font-size: var(--sn-font-size-xs);
}
.sn-eventos-simulador {
  gap: var(--sn-space-4);
}
.sn-torneo-sliders {
  margin-bottom: var(--sn-space-4);
}
.sn-eventos-simulador #sn-eventos-container {
  display: flex;
  flex-direction: column;
  gap: var(--sn-space-4);
  padding: 1rem;
  border: 1px solid rgba(255, 255, 255, 0.06);
  border-radius: 24px;
  background:
    radial-gradient(
      circle at top center,
      rgba(11, 31, 70, 0.42),
      transparent 48%
    ),
    linear-gradient(180deg, rgba(5, 9, 18, 0.96), rgba(6, 10, 17, 0.985));
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.02),
    0 22px 44px rgba(0, 0, 0, 0.28);
}
.sn-eventos-simulador .sn-view-horarios {
  display: none;
}
.sn-eventos-simulador .sn-view,
.sn-eventos-simulador .sn-view-series {
  display: block;
}
.sn-eventos-simulador .sn-toolbar,
.sn-eventos-simulador .sn-toggle,
.sn-eventos-simulador .sn-toggle-icons {
  display: flex;
  align-items: center;
  gap: var(--sn-space-2);
}
.sn-eventos-simulador .sn-toolbar {
  justify-content: space-between;
  padding: 0 var(--sn-space-1);
}
.sn-eventos-simulador .sn-toggle {
  margin-left: auto;
}
.sn-eventos-simulador .sn-toggle-btn {
  min-width: 44px;
  padding-inline: 0.85rem;
}
.sn-eventos-simulador .sn-toggle-grid,
.sn-eventos-simulador .sn-toggle-list {
  justify-content: center;
}
.sn-eventos-simulador .sn-toggle-btn.on,
.sn-eventos-simulador .sn-toggle-btn.active {
  background: var(--sn-grad-theme);
  border-color: var(--sn-theme-primary-accent);
  color: #fff;
  box-shadow: 0 8px 20px rgba(201, 13, 5, 0.28);
}
.sn-eventos-simulador .sn-serie,
.sn-eventos-simulador .sn-card {
  border-radius: 18px;
  color: #fff;
}
.sn-eventos-simulador .sn-serie {
  position: relative;
  margin-bottom: var(--sn-space-4);
  padding: 0.85rem 0.85rem 0;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.09);
  background-color: #14171d;
  background-image:
    radial-gradient(
      circle at top center,
      rgba(255, 255, 255, 0.05),
      transparent 44%
    ),
    radial-gradient(
      circle at top left,
      color-mix(in srgb, var(--sn-serie-accent, #2a2f38) 26%, transparent),
      transparent 36%
    ),
    linear-gradient(180deg, rgba(21, 24, 31, 0.96), rgba(12, 14, 18, 0.99) 55%);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.05),
    0 16px 36px rgba(0, 0, 0, 0.26);
}
.sn-eventos-simulador .sn-serie::before {
  content: "";
  position: absolute;
  inset: 0 0 auto;
  height: 4px;
  background: var(--sn-grad-theme);
}
.sn-eventos-simulador .sn-no-events {
  display: grid;
  justify-items: center;
  gap: var(--sn-space-2);
  padding: var(--sn-space-5);
  border-radius: 18px;
  border: 1px dashed rgba(255, 255, 255, 0.14);
  background: linear-gradient(
    180deg,
    rgba(11, 18, 28, 0.92),
    rgba(7, 10, 16, 0.98)
  );
}
.sn-eventos-simulador .sn-head {
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  gap: 1rem;
  padding: 1rem 1.1rem;
  margin-bottom: 0.5rem;
  border: 1px solid rgba(255, 255, 255, 0.06);
  border-bottom-color: rgba(255, 255, 255, 0.1);
  border-radius: 16px;
  background:
    linear-gradient(180deg, rgba(22, 24, 29, 0.97), rgba(14, 16, 20, 0.99)),
    linear-gradient(90deg, rgba(201, 13, 5, 0.08), transparent 34%);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04);
}
.sn-eventos-simulador .sn-head-left {
  display: flex;
  gap: var(--sn-space-3);
  flex: 1 1 auto;
  min-width: 0;
  align-items: center;
}
.sn-eventos-simulador .sn-head-right {
  display: flex;
  flex-direction: column;
  gap: 0.22rem;
  flex: 0 0 auto;
  min-width: 170px;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  color: rgba(255, 255, 255, 0.84);
  font-size: var(--sn-font-size-xs);
  box-shadow: none;
}
.sn-eventos-simulador .sn-head-img {
  width: 64px;
  height: 64px;
  border-radius: 10px;
  -o-object-fit: cover;
     object-fit: cover;
  background: rgba(255, 255, 255, 0.05);
  box-shadow: 0 8px 22px rgba(0, 0, 0, 0.35);
}
.sn-eventos-simulador .sn-head-title,
.sn-eventos-simulador .sn-card h4 {
  margin: 0;
  color: #fff;
}
.sn-eventos-simulador .sn-head-title {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.55rem;
  margin-bottom: 0.3rem;
  font: 700 clamp(1.05rem, 0.95rem + 0.32vw, 1.45rem)/1.12 var(--sn-font-sans);
}
.sn-eventos-simulador .sn-head-body {
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
}
.sn-eventos-simulador .sn-head-desc,
.sn-eventos-simulador .sn-head-event-name,
.sn-eventos-simulador .sn-nota-pista {
  margin: 0;
  color: rgba(255, 255, 255, 0.82);
  font-size: var(--sn-font-size-sm);
}
.sn-eventos-simulador .sn-head-event-flags,
.sn-eventos-simulador .sn-head-meta,
.sn-eventos-simulador .sn-practice {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
  align-items: center;
}
.sn-eventos-simulador .sn-head-event-name i,
.sn-eventos-simulador .sn-head-meta i,
.sn-eventos-simulador .sn-ses-res i,
.sn-eventos-simulador .sn-practice i {
  color: #ff5147;
}
.sn-eventos-simulador .sn-head-event-flags {
  row-gap: 0.4rem;
}
.sn-eventos-simulador .sn-head-meta {
  list-style: none;
  margin: 0.35rem 0 0;
  padding: 0;
}
.sn-eventos-simulador .sn-head-meta li {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  padding: 0.34rem 0.58rem;
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.05);
  color: rgba(255, 255, 255, 0.88);
  font-size: var(--sn-font-size-xs);
}
.sn-eventos-simulador .sn-ses-title {
  margin: 0;
  color: rgba(255, 255, 255, 0.72);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.sn-eventos-simulador .sn-ses-res {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
  align-items: center;
  line-height: 1.4;
  font-size: 0.88rem;
}
.sn-eventos-simulador .sn-practice {
  margin-top: 0.25rem;
}
.sn-eventos-simulador .sn-chip,
.sn-eventos-simulador .sn-badge {
  background: rgba(7, 10, 18, 0.72);
  border-color: rgba(255, 255, 255, 0.1);
  color: #fff;
}
.sn-eventos-simulador .sn-badge {
  box-shadow: 0 10px 24px rgba(0, 0, 0, 0.24);
}
.sn-eventos-simulador .sn-card {
  margin: 0.75rem 0 0;
  padding: 1rem 1.1rem;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: linear-gradient(
    180deg,
    rgba(10, 15, 24, 0.95),
    rgba(7, 10, 16, 0.98)
  );
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.03);
}
.sn-eventos-simulador .sn-card h4 {
  display: flex;
  align-items: center;
  gap: 0.55rem;
  margin-bottom: 0.9rem;
  font-size: var(--sn-font-size-md);
}
.sn-eventos-simulador .sn-detalle {
  margin-bottom: 0.2rem;
}
.sn-eventos-simulador table.sn-det-tab {
  background: rgba(9, 13, 20, 0.92);
  border-radius: 14px;
  overflow: hidden;
}
.sn-eventos-simulador table.sn-det-tab th {
  background: linear-gradient(
    180deg,
    rgba(201, 13, 5, 0.94),
    rgba(121, 8, 2, 0.94)
  );
  color: #fff;
  border-color: rgba(255, 255, 255, 0.08);
}
.sn-eventos-simulador table.sn-det-tab td {
  border-color: rgba(255, 255, 255, 0.08);
  background: rgba(255, 255, 255, 0.02);
}
.sn-eventos-simulador .sn-table.sn-table-serie {
  background: rgba(8, 11, 18, 0.82);
  margin-top: 0.55rem;
}
.sn-eventos-simulador .sn-table.sn-table-serie thead th {
  background: linear-gradient(
    180deg,
    rgba(7, 19, 43, 0.96),
    rgba(7, 14, 28, 0.98)
  );
}
.sn-eventos-simulador .sn-table.sn-table-serie tbody tr:nth-child(odd) {
  background: rgba(255, 255, 255, 0.02);
}
.sn-eventos-simulador .sn-table.sn-table-serie tbody tr:hover {
  background: rgba(201, 13, 5, 0.08);
}
.sn-eventos-simulador .sn-table.sn-table-serie th,
.sn-eventos-simulador .sn-table.sn-table-serie td {
  border-color: rgba(255, 255, 255, 0.08);
}
.sn-eventos-simulador .sn-btn-info.bottom {
  flex: 0 0 auto;
  align-self: center;
  margin-left: auto;
}
.sn-eventos-simulador .sn-serie > .sn-btn,
.sn-eventos-simulador .sn-show-more-wrap {
  padding: 0 0 0.85rem;
}
.sn-eventos-simulador .sn-show-more-wrap {
  text-align: center;
}
.sn-eventos-simulador .sn-show-more-wrap:empty {
  display: none;
}
.sn-eventos-simulador .sn-table.sn-table-serie td:nth-child(1) {
  width: 28%;
}
.sn-eventos-simulador .sn-table.sn-table-serie td:nth-child(2) {
  width: 46%;
}
.sn-eventos-simulador .sn-table.sn-table-serie td:nth-child(3) {
  width: 26%;
}
.sn-eventos-simulador .sn-table.sn-horas td:nth-child(1) {
  width: 6%;
}
.sn-eventos-simulador .sn-table.sn-horas td:nth-child(2) {
  width: 18%;
}
.sn-eventos-simulador .sn-table.sn-horas td:nth-child(3) {
  width: 16%;
}
.sn-eventos-simulador .sn-table.sn-horas td:nth-child(4) {
  width: 20%;
}
.sn-eventos-simulador .sn-table.sn-horas td:nth-child(5) {
  width: 24%;
}
.sn-eventos-simulador .sn-table.sn-horas td:nth-child(6) {
  width: 16%;
}
.sn-eventos-simulador .sn-table td.sn-accion,
.sn-eventos-simulador .sn-table th.sn-accion {
  text-align: center;
}
.sn-eventos-simulador .sn-info-caret {
  font-size: 0.68rem;
  opacity: 0.85;
  transition: transform 0.2s ease;
}
.sn-eventos-simulador .sn-btn-info.is-open .sn-info-caret {
  transform: rotate(180deg);
}
}

@layer sn.core {
@media (max-width: 1024px) {
  .sn-comisarios-wrap [data-sn="modal-tab-resolver"] .sn-grid.sn-grid-3 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
}

@layer sn.core {
@media (max-width: 900px) {
  .sn-mensajes-panel .sn-form-grid,
  .sn-mensajes-panel .sn-form-grid--compact,
  .sn-mensajes-panel .sn-destino-row,
  .sn-mensajes-panel .sn-destino-edit-row,
  .sn-user-card {
    grid-template-columns: 1fr;
  }
  .sn-user-card {
    flex-direction: column;
  }
}
}

@layer sn.core {
@media (max-width: 700px) {
  .sn-profile-edit .sn-row,
  .sn-profile-edit .sn-form > .sn-row:nth-of-type(1),
  .sn-profile-edit .sn-form > .sn-row:nth-of-type(3),
  .sn-comisarios-wrap [data-sn="modal-tab-resolver"] .sn-grid.sn-grid-3,
  .sn-row-details-grid,
  .sn-user-card-right {
    grid-template-columns: 1fr;
  }
  .sn-comisarios-wrap table.sn-table td:last-child {
    width: auto;
    white-space: normal;
  }
  .sn-f1-table,
  .sn-f1-modal-table,
  .sn-iracing-table {
    min-width: 720px;
  }
  .sn-row-toggle {
    display: inline-flex;
  }
  .sn-eventos-simulador .sn-toolbar,
  .sn-eventos-simulador .sn-head,
  .sn-eventos-simulador .sn-head-left {
    flex-direction: column;
    align-items: flex-start;
  }
  .sn-eventos-simulador .sn-head-right {
    width: 100%;
    min-width: 0;
  }
  .sn-eventos-simulador .sn-toggle {
    width: 100%;
    justify-content: space-between;
  }
  .sn-eventos-simulador .sn-btn-info.bottom {
    margin-left: 0;
    align-self: flex-start;
  }
}
}

@layer sn.core {
.sn-ins,
.sn-tor-ins {
  display: inline-flex;
  flex-direction: column;
  gap: 2px;
  font-family: var(--sn-font-sans);
}
.sn-ins-container.sn-layout,
.sn-tor-ins .sn-tor-layout {
  display: flex;
  gap: 8px;
  align-items: stretch;
  flex-wrap: wrap;
}
.sn-ins-badge,
.sn-open-badge,
.sn-tor-ins .sn-tor-badge {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-width: 160px;
  min-height: 48px;
  padding: 8px 12px;
  border-radius: var(--sn-radius-lg);
  border: 1px solid var(--sn-color-border);
  background: var(--sn-color-surface-alt);
  color: #fff;
  font: 600 var(--sn-font-size-xs)/1.15 var(--sn-font-sans);
  text-align: center;
  cursor: pointer;
  box-shadow: var(--sn-shadow-sm);
  transition:
    filter 0.18s ease,
    transform 0.18s ease,
    box-shadow 0.18s ease;
}
.sn-ins-badge:hover,
.sn-open-badge:hover,
.sn-tor-ins .sn-tor-badge:hover {
  filter: brightness(1.06);
}
.sn-ins-badge:disabled,
.sn-tor-ins .sn-tor-badge:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}
.sn-ins-badge.espera,
.sn-ins-badge.locked,
.sn-tor-ins .sn-tor-badge.st-locked,
.sn-tor-ins .sn-tor-badge.st-closed {
  background: #1f2937;
  border-color: #374151;
  color: #e5e7eb;
}
.sn-open-badge,
.sn-ins-badge.open,
.sn-tor-ins .sn-tor-badge.st-open {
  background: linear-gradient(135deg, #1a5e32, #238944 55%);
  border-color: #1c6d38;
  color: #e7ffe9;
}
.sn-open-badge.edit,
.sn-tor-ins .sn-tor-badge.st-inscribed {
  background: linear-gradient(135deg, #1d1d1d, #252525 60%);
  border-color: #343434;
  color: #dcdcdc;
}
.estado-iniciando,
.sn-ins-badge.estado-iniciando,
.sn-ins-badge.sala_asignada,
.sn-ins-badge.estado-curso,
.sn-tor-ins .sn-tor-badge.st-full,
.sn-tor-ins .sn-tor-badge.st-blocked-config {
  background: linear-gradient(135deg, #9c7626, #6b4f1a);
  border-color: #8a6318;
  color: #ffe6b3;
}
.sn-ins-badge.en_curso,
.sn-tor-ins .sn-tor-badge.st-blocked-ticket {
  background: linear-gradient(135deg, #604476, #332345);
  border-color: #4f3aa6;
  color: #efeaff;
}
.sn-ins-badge.closed,
.sn-ins-badge.full,
.sn-ins-badge.cancelled,
.sn-ins-badge.error,
.sn-tor-ins .sn-tor-badge.st-blocked-ban {
  background: linear-gradient(135deg, #5a2222, #a83232);
  border-color: #7d2929;
  color: #ffeaea;
}
.sn-tor-ins .sn-tor-badge.st-blocked-ban .sn-tor-top::before {
  content: "X";
  margin-right: 6px;
}
.sn-ins-badge.blocked,
.sn-ins-badge.blocked-profile,
.sn-ins-badge.blocked-accounts,
.sn-ins-badge.blocked-license {
  background: linear-gradient(135deg, #8a6326, #3c2c16);
  color: #ffe6b3;
}
.sn-ins-badge.blocked-profile::after,
.sn-ins-badge.blocked-accounts::after,
.sn-ins-badge.blocked-license::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  height: 3px;
  background: rgba(255, 255, 255, 0.3);
  border-radius: 0 0 8px 8px;
}
.sn-ins-badge.blocked-profile::after {
  width: 25%;
}
.sn-ins-badge.blocked-accounts::after {
  width: 50%;
}
.sn-ins-badge.blocked-license::after {
  width: 75%;
}
.sn-open-badge i,
.sn-ins-container.sn-layout .sn-side-btn i {
  margin-right: 4px;
  font-size: 14px;
}
.sn-open-badge small,
.sn-ins-container.sn-layout .sn-side-count,
.sn-tor-ins .sn-tor-side-count,
.sn-ct {
  font-size: 10px;
  font-weight: 600;
  opacity: 0.9;
}
.sn-ct {
  margin-top: 4px;
  font-family: monospace;
}
.sn-ins-container.sn-layout .sn-main-btn {
  flex: 1;
  max-width: 200px;
  word-break: break-word;
  white-space: normal;
}
.sn-ins-container.sn-layout .sn-main-top,
.sn-tor-ins .sn-tor-badge .sn-tor-top {
  display: flex;
  gap: 8px;
  align-items: center;
  justify-content: center;
  max-width: 180px;
  font-size: 0.9rem;
  line-height: 1.15;
  font-weight: 600;
  word-break: break-word;
  white-space: normal;
}
.sn-ins-container.sn-layout .sn-main-bottom,
.sn-tor-ins .sn-tor-badge .sn-tor-bottom {
  margin-top: 4px;
  font-size: 0.82rem;
  opacity: 0.85;
  text-align: center;
}
.sn-ins-container.sn-layout .sn-side-btn,
.sn-tor-ins .sn-tor-side {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-width: 52px;
  width: 56px;
  padding: 4px 0 6px;
  border-radius: var(--sn-radius-lg);
  border: 1px solid var(--sn-theme-primary-accent, #9e0a03);
  background: var(--sn-grad-theme, linear-gradient(135deg, #c90d05, #9e0a03));
  color: #fff;
  box-shadow: 0 2px 8px -2px rgba(201, 13, 5, 0.55);
}
.sn-ins-modal,
.sn-tor-modal-wrap {
  position: fixed;
  inset: 0;
  z-index: var(--sn-z-max, 999999);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
  background: var(--sn-color-overlay, rgba(0, 0, 0, 0.85));
}
.sn-ins-modal .box,
.sn-tor-modal {
  width: min(820px, 100%);
  max-height: 90vh;
  overflow: auto;
  border-radius: var(--sn-radius-lg);
  border: 1px solid var(--sn-color-border);
  background: var(--sn-color-surface);
  box-shadow: var(--sn-shadow-lg);
}
.sn-ins-modal .sn-modal-header,
.sn-tor-modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  padding: var(--sn-space-3) var(--sn-space-4);
  border-bottom: 1px solid var(--sn-color-border);
  background: var(--sn-color-surface-alt);
}
.sn-ins-modal .sn-modal-body,
.sn-tor-modal-body {
  padding: var(--sn-space-4);
}
.sn-tor-modal-footer {
  display: flex;
  justify-content: flex-end;
  gap: var(--sn-space-2);
  padding: var(--sn-space-3) var(--sn-space-4);
  border-top: 1px solid var(--sn-color-border);
  background: var(--sn-color-surface-alt);
}
.sn-ins-modal .sn-modal-close,
.sn-tor-close {
  background: transparent;
  border: 1px solid var(--sn-color-border);
  color: var(--sn-color-text-soft);
  padding: 6px 8px;
  border-radius: var(--sn-radius-sm);
}
.sn-ins-modal select,
.sn-tor-form .select2-container {
  width: 100% !important;
}
.sn-tor-save,
.sn-tor-delete {
  padding: 10px 18px;
  border-radius: 999px;
  min-height: 42px;
  color: #fff !important;
  font: 600 var(--sn-font-size-sm)/1 var(--sn-font-sans);
}
.sn-tor-save {
  background: var(
    --sn-grad-theme,
    linear-gradient(135deg, #c90d05, #e01006 55%)
  );
  border: 1px solid var(--sn-theme-primary-accent, #9e0a03);
}
.sn-tor-delete {
  background: var(--sn-grad-danger, linear-gradient(135deg, #a83232, #5a2222));
  border: 1px solid #592222;
}
.sn-ins-tabs,
.splits-tabs {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  padding: var(--sn-space-2);
  border: 1px solid var(--sn-color-border);
  border-radius: var(--sn-radius-lg);
  background: rgba(255, 255, 255, 0.02);
}
.sn-ins-tab,
.split-tab {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 12px;
  border-radius: var(--sn-radius-pill);
  border: 1px solid var(--sn-color-border);
  background: var(--sn-color-surface-alt);
  color: var(--sn-color-text);
  font: 600 var(--sn-font-size-xs)/1 var(--sn-font-sans);
  cursor: pointer;
}
.sn-ins-tab.active,
.split-tab.active {
  background: var(--sn-grad-theme, linear-gradient(135deg, #c90d05, #9e0a03));
  border-color: var(--sn-theme-primary-accent, #7d0803);
  color: #fff;
}
.split-content,
.sn-ins-content .sn-ins-div {
  display: none;
}
.split-content.active,
.sn-ins-content .sn-ins-div.active {
  display: block;
}
.split-content {
  padding: 14px;
  border: 1px solid var(--sn-color-border);
  border-radius: 0 12px 12px 12px;
  background: rgba(255, 255, 255, 0.01);
}
.split-info,
.inscritos-header .event-stats {
  padding: 8px 10px;
  border-radius: var(--sn-radius);
  border: 1px solid var(--sn-color-border);
  background: rgba(255, 255, 255, 0.02);
  color: var(--sn-color-text);
}
.sn-ins-table-wrap,
.pilotos-table {
  overflow: auto;
  border: 1px solid var(--sn-color-border);
  border-radius: var(--sn-radius);
}
.sn-ins-table,
.pilotos-table table {
  width: 100%;
  border-collapse: collapse;
}
.sn-ins-table thead th,
.pilotos-table th,
.pilotos-table td {
  white-space: nowrap;
}
.sn-ins-table thead th,
.pilotos-table th {
  position: sticky;
  top: 0;
  z-index: 1;
}
.sn-ins-table tbody td,
.pilotos-table td {
  border-top: 1px solid var(--sn-color-border);
}
.piloto-avatar img,
.marca-logo img {
  width: 32px !important;
  height: 32px !important;
  border-radius: 50% !important;
  -o-object-fit: cover !important;
     object-fit: cover !important;
}
.piloto-nombre,
.auto-nombre {
  color: #fff !important;
  font-weight: 700 !important;
}
.elo {
  color: #4fb3ff !important;
}
.sr {
  color: #6ce08b !important;
}
.sn-ins-loading,
.sn-ins-error,
.sn-ins-empty {
  padding: var(--sn-space-3);
  color: var(--sn-color-text-soft);
}
.sn-ins-controls {
  display: flex;
  gap: var(--sn-space-2);
  align-items: center;
  flex-wrap: wrap;
  margin-bottom: var(--sn-space-3);
}
.sn-ins-controls select {
  min-width: 220px;
}
}

@layer sn.core {
@media (max-width: 1200px) {
  .tor-inscripcion-mobile .sn-tor-ins,
  .tor-inscripcion-mobile .sn-tor-layout {
    width: 100%;
  }
  .tor-inscripcion-mobile .sn-tor-layout {
    flex-direction: column;
    flex-wrap: nowrap;
    align-items: stretch;
  }
}
}

@layer sn.core {
@media (max-width: 900px) {
  .split-tab,
  .sn-ins-tab {
    padding: 6px 10px;
    font-size: 0.88rem;
  }
}
}

@layer sn.core {
@media (max-width: 768px) {
  .splits-tabs,
  .sn-ins-tabs {
    flex-wrap: wrap;
  }
  .split-tab,
  .sn-ins-tab {
    flex: 1 1 100px;
    justify-content: center;
    text-align: center;
    font-size: 0.8rem;
  }
  .pilotos-table table,
  .sn-ins-table {
    min-width: 600px;
  }
  .piloto-avatar img,
  .marca-logo img {
    width: 28px !important;
    height: 28px !important;
  }
}
}

@layer sn.core {
@media (max-width: 480px) {
  .sn-ins-container.sn-layout,
  .sn-tor-ins .sn-tor-layout {
    flex-direction: column;
    width: 100%;
  }
  .sn-ins-container.sn-layout .sn-main-btn,
  .sn-ins-container.sn-layout .sn-side-btn,
  .sn-tor-ins .sn-tor-badge,
  .sn-tor-ins .sn-tor-side,
  .sn-tor-save {
    width: 100%;
    max-width: none;
  }
  .sn-ins-modal .box,
  .sn-tor-modal {
    max-width: 92vw;
  }
  .split-tab,
  .sn-ins-tab {
    font-size: 0.75rem;
    padding: 4px 8px;
  }
}
}

@layer sn.core {
#sn-ac-admin-container,
#sn-rf2-admin-container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 20px;
  color: var(--sn-color-text);
  font-family: var(--sn-font-sans);
}
#sn-ac-admin-container a,
#sn-rf2-admin-container a {
  color: var(--sn-primary);
  text-decoration: none;
}
#sn-ac-admin-container a:hover,
#sn-rf2-admin-container a:hover {
  text-decoration: underline;
}
.sn-ac-admin-header,
.sn-rf2-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sn-space-3);
  margin-bottom: var(--sn-space-4);
  padding: var(--sn-space-4);
  border: 1px solid var(--sn-color-border);
  border-radius: var(--sn-radius-lg);
  background: linear-gradient(
    135deg,
    rgba(201, 13, 5, 0.16),
    rgba(255, 255, 255, 0.03)
  );
  box-shadow: var(--sn-shadow-sm);
}
.sn-ac-admin-header h2,
.sn-rf2-header h2 {
  margin: 0;
  color: var(--sn-color-text);
  font-size: 1.35rem;
  font-weight: 700;
}
.sn-ac-admin-actions,
.sn-ac-admin-controls {
  display: flex;
  gap: var(--sn-space-2);
}
#sn-ac-servers-nav,
#sn-rf2-servers-nav,
.sn-ac-tabs-nav,
.sn-ac-server-subtabs {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 0 0 var(--sn-space-4);
  padding: 0;
  list-style: none;
}
.sn-ac-server-nav-tab,
.sn-rf2-server-nav-tab,
.sn-ac-subtab,
.sn-ac-rp-tab {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 14px;
  border-radius: var(--sn-radius-pill);
  border: 1px solid var(--sn-color-border);
  background: var(--sn-color-surface-alt);
  color: var(--sn-color-text);
  font: 600 12px/1 var(--sn-font-sans);
  cursor: pointer;
}
.sn-ac-server-nav-tab.active,
.sn-rf2-server-nav-tab.active,
.sn-ac-subtab.active,
.sn-ac-rp-tab.active {
  background: var(--sn-grad-theme, linear-gradient(135deg, #c90d05, #9e0a03));
  border-color: var(--sn-theme-primary-accent, #7d0803);
  color: #fff;
}
.sn-ac-server-tab,
.sn-rf2-server-tab {
  display: none;
  margin-bottom: var(--sn-space-4);
  padding: var(--sn-space-4);
  border: 1px solid var(--sn-color-border);
  border-radius: var(--sn-radius-lg);
  background: var(--sn-color-surface);
  box-shadow: var(--sn-shadow-sm);
}
.sn-ac-server-tab.active,
.sn-rf2-server-tab.active {
  display: block;
}
.sn-ac-server-tab-header,
.sn-rf2-server-tab-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sn-space-3);
  margin-bottom: var(--sn-space-4);
  padding-bottom: var(--sn-space-3);
  border-bottom: 1px solid var(--sn-color-border);
}
.sn-ac-server-tab-header h3,
.sn-rf2-server-tab-header h3 {
  margin: 0;
  color: var(--sn-color-text);
  font-size: 1.15rem;
  font-weight: 700;
}
.sn-ac-server-controls,
.sn-ac-entrylist-actions,
.sn-ac-schedule-actions,
.sn-ac-schedule-actions-item,
.sn-rf2-form-actions {
  display: flex;
  gap: var(--sn-space-2);
}
.sn-ac-server-power,
.sn-rf2-car-item button,
.sn-ac-available-cars .car-item button,
.sn-ac-selected-car button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 34px;
  padding: 8px 14px;
  border: 1px solid var(--sn-color-border);
  border-radius: var(--sn-radius);
  background: var(--sn-color-surface-alt);
  color: var(--sn-color-text);
  font: 600 12px/1 var(--sn-font-sans);
  cursor: pointer;
}
.sn-ac-server-power.start,
.sn-rf2-car-item button,
.sn-ac-available-cars .car-item button {
  background: #1a5e32;
  border-color: #1c6d38;
  color: #e7ffe9;
}
.sn-ac-server-power.stop {
  background: #7d2929;
  border-color: #7d2929;
  color: #ffeaea;
}
.sn-ac-config-section,
.sn-ac-entrylist-section,
.sn-ac-realpenalty-section,
.sn-ac-schedule-section,
.sn-ac-livetiming-section,
.sn-rf2-config-group {
  padding: var(--sn-space-4);
  border: 1px solid var(--sn-color-border);
  border-radius: var(--sn-radius-lg);
  background: rgba(255, 255, 255, 0.02);
}
.sn-ac-config-group {
  margin-bottom: var(--sn-space-4);
}
.sn-ac-config-group h5,
.sn-rf2-config-group h5 {
  margin: 0 0 var(--sn-space-3);
  padding-bottom: 6px;
  border-bottom: 2px solid var(--sn-primary);
  color: var(--sn-color-text);
  font-size: 1rem;
}
.sn-ac-form-row,
.sn-ac-form-row-wrap,
.sn-rf2-form-inline {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sn-space-3);
  align-items: flex-end;
}
.sn-ac-form-col,
.sn-rf2-grid label {
  flex: 1 1 200px;
  min-width: 180px;
}
.sn-ac-form-col-full {
  flex: 1 1 100%;
}
.sn-ac-form-col label,
.sn-rf2-form-inline label {
  display: flex;
  flex-direction: column;
  gap: 4px;
  color: var(--sn-color-text-soft);
  font-size: 12px;
}
.sn-ac-form-col :is(input, select),
.sn-rf2-form-inline :is(input, select),
.sn-ac-sendmsg-box textarea {
  width: 100%;
  background: #111;
  color: #fff;
  border: 1px solid var(--sn-color-border);
  border-radius: var(--sn-radius);
  padding: 10px 12px;
}
.sn-ac-form-col :is(input, select):focus,
.sn-rf2-form-inline :is(input, select):focus,
.sn-ac-sendmsg-box textarea:focus {
  outline: none;
  border-color: var(--sn-primary);
  box-shadow: 0 0 0 2px rgba(201, 13, 5, 0.25);
}
.sn-ac-cars-container,
.sn-rf2-available-cars,
.sn-ac-entrylist-container,
.sn-ac-available-cars {
  overflow: auto;
  border: 1px solid var(--sn-color-border);
  border-radius: var(--sn-radius);
  background: rgba(255, 255, 255, 0.02);
}
.sn-ac-cars-container,
.sn-rf2-available-cars,
.sn-ac-available-cars {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(170px, 1fr));
  gap: 8px;
  padding: 8px;
}
.sn-ac-entrylist-container {
  display: flex;
  flex-direction: column;
  gap: var(--sn-space-3);
  max-height: 600px;
}
.sn-ac-car-checkbox,
.sn-ac-driver-entry,
.sn-ac-schedule-item,
.sn-rf2-car-item,
.sn-ac-available-cars .car-item {
  padding: 10px 12px;
  border: 1px solid var(--sn-color-border);
  border-radius: var(--sn-radius);
  background: var(--sn-color-surface);
  color: var(--sn-color-text);
}
.sn-ac-schedule-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sn-space-3);
}
.sn-ac-selected-cars,
.sn-rf2-selected-cars {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.sn-ac-selected-car,
.sn-rf2-car-tag,
.sn-ac-badge,
.sn-rf2-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 8px;
  border-radius: var(--sn-radius-pill);
  border: 1px solid var(--sn-color-border);
  background: var(--sn-color-surface-alt);
  color: var(--sn-color-text);
  font: 600 11px/1 var(--sn-font-sans);
}
.sn-ac-badge.success,
.sn-rf2-badge.success,
.sn-ac-text-success,
.sn-rf2-text-success {
  color: #bbf7d0 !important;
}
.sn-ac-badge.danger,
.sn-rf2-badge.danger,
.sn-ac-text-danger,
.sn-rf2-text-danger {
  color: #ffeaea !important;
}
.sn-ac-badge.warning,
.sn-rf2-badge.warning,
.sn-ac-text-warning,
.sn-rf2-text-warning {
  color: #ffe6b3 !important;
}
.sn-ac-messages,
#sn-rf2-messages {
  display: grid;
  gap: var(--sn-space-2);
  margin-bottom: var(--sn-space-3);
}
.sn-ac-message,
.sn-rf2-message {
  padding: var(--sn-space-3);
  border: 1px solid var(--sn-color-border);
  border-radius: var(--sn-radius);
  background: rgba(255, 255, 255, 0.03);
  color: var(--sn-color-text);
}
.sn-ac-message.success {
  background: rgba(26, 94, 50, 0.22);
  border-color: #1c6d38;
}
.sn-ac-message.error,
.sn-rf2-message.error {
  background: rgba(125, 41, 41, 0.22);
  border-color: #7d2929;
  color: #ffeaea;
}
.sn-ac-message.info,
.sn-rf2-message.info {
  background: rgba(201, 13, 5, 0.16);
  border-color: var(--sn-primary);
}
.sn-ac-message.warning {
  background: rgba(156, 118, 38, 0.2);
  border-color: #8a6318;
  color: #ffe6b3;
}
.sn-ac-sendmsg-box {
  display: none;
  margin-top: 10px;
  padding: 12px;
  border: 1px solid var(--sn-color-border);
  border-radius: var(--sn-radius);
  background: rgba(255, 255, 255, 0.02);
}
.sn-ac-sendmsg-actions {
  display: flex;
  justify-content: flex-end;
  gap: var(--sn-space-2);
  margin-top: 8px;
}
.sn-editar-simuladores {
  max-width: 900px;
  margin: 0 auto;
}
.sn-simuladores-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: var(--sn-space-3);
  margin: var(--sn-space-3) 0;
}
.sn-simulador-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 0.75rem 1rem;
  border: 1px solid var(--sn-color-border);
  border-radius: var(--sn-radius);
  background: var(--sn-color-surface-alt);
  color: var(--sn-color-text);
}
.sn-simulador-logo-container {
  width: 40px;
  height: 40px;
  border: 1px solid var(--sn-color-border);
  border-radius: var(--sn-radius);
  background: var(--sn-color-surface);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}
.sn-simulador-logo-container .sn-simulador-logo {
  height: 80%;
  -o-object-fit: contain;
     object-fit: contain;
}
.sn-simulador-nombre {
  flex: 1;
  color: var(--sn-color-text);
  font-size: var(--sn-font-size-md);
  font-weight: 600;
}
.sn-toggle-slider {
  position: absolute;
  inset: 0;
  border-radius: 34px;
  background: var(--sn-color-border-light, #ccc);
  box-shadow: inset 0 0 0 1px var(--sn-color-border);
}
.sn-toggle-slider::before {
  content: "";
  position: absolute;
  left: 3px;
  bottom: 3px;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: #fff;
  transition: transform 0.3s ease;
}
.sn-toggle-input:checked + .sn-toggle-slider {
  background: var(--sn-success);
}
.sn-toggle-input:checked + .sn-toggle-slider::before {
  transform: translateX(26px);
}
.sn-btn-container {
  display: flex;
  justify-content: flex-end;
  gap: var(--sn-space-2);
  margin: 1rem 0;
}
.sn-btn-container .sn-btn {
  min-width: 160px;
}
.sn-gestion-equipos {
  padding: 14px;
  border: 1px solid var(--sn-color-border);
  border-radius: 16px;
  background: var(--sn-color-surface);
  color: var(--sn-color-text);
}
.sn-ge-header {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  margin-bottom: 0.6rem;
}
.sn-ge-header i {
  color: #ffda6b;
}
.sn-ge-loading,
.sn-ge-error {
  padding: var(--sn-space-3);
  border-radius: var(--sn-radius);
}
.sn-ge-error {
  background: rgba(125, 41, 41, 0.22);
  border: 1px solid #7d2929;
  color: #ffeaea;
}
.sn-ge-div,
.sn-team-card {
  margin: 0.6rem 0;
  padding: 0.8rem;
  border: 1px solid var(--sn-color-border);
  border-radius: 14px;
  background: var(--sn-color-surface);
}
.sn-ge-div-h,
.sn-ge-actions,
.sn-team-actions,
.sn-ge-gestion-equipos .sn-modal .sn-actions {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  flex-wrap: wrap;
}
.sn-ge-div-h {
  justify-content: space-between;
  border-bottom: 1px dashed var(--sn-color-border);
  padding-bottom: 0.6rem;
}
.sn-team-hz {
  display: grid;
  grid-template-columns: 160px 1fr 120px;
  gap: 24px;
  align-items: start;
  margin-bottom: 14px;
}
.sn-hz-logo,
.sn-team-logo {
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid var(--sn-color-border);
  border-radius: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}
.sn-hz-logo {
  width: 160px;
  height: 160px;
}
.sn-team-logo {
  width: 120px;
  height: 120px;
}
.sn-hz-logo img,
.sn-team-logo img,
.sn-hz-livery img,
.sn-avatar img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.sn-hz-main,
.sn-hz-actions {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.sn-team-title {
  display: inline-block;
  padding: 10px 14px;
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.03);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.06);
  font-size: 22px;
  font-weight: 700;
  line-height: 1.15;
}
.sn-team-meta {
  display: grid;
  grid-template-columns: 1fr 140px;
  gap: 12px;
  align-items: start;
}
.sn-team-actions {
  flex-direction: column;
  align-items: stretch;
}
.sn-team-members {
  display: grid;
  gap: 0.35rem;
  margin-top: 0.6rem;
}
.sn-avatar {
  width: 42px;
  height: 42px;
  border-radius: 50%;
  overflow: hidden;
  background: #222;
}
.sn-auto-cell,
.sn-auto-edit {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}
.sn-auto-brand-sm {
  width: 34px;
  height: 34px;
  padding: 2px;
  border: 1px solid var(--sn-color-border);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.02);
  -o-object-fit: contain;
     object-fit: contain;
}
.sn-preview {
  margin-bottom: 0.8rem;
  padding: 0.8rem;
  border: 1px dashed var(--sn-color-border);
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.02);
}
.sn-color-pair {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 0.5rem;
  align-items: center;
}
}

@layer sn.core {
@media (max-width: 1020px) {
  .sn-team-hz {
    grid-template-columns: 140px 1fr 110px;
  }
  .sn-hz-logo {
    width: 140px;
    height: 140px;
  }
  .sn-team-meta {
    grid-template-columns: 1fr 120px;
  }
}
}

@layer sn.core {
@media (max-width: 768px) {
  .sn-ac-admin-header,
  .sn-rf2-header,
  .sn-ac-server-tab-header,
  .sn-rf2-server-tab-header {
    flex-direction: column;
    align-items: flex-start;
  }
  .sn-ac-cars-container,
  .sn-rf2-available-cars,
  .sn-ac-available-cars,
  .sn-simuladores-grid {
    grid-template-columns: 1fr;
  }
}
}

@layer sn.core {
@media (max-width: 760px) {
  .sn-team-hz,
  .sn-team-head,
  .sn-team-meta {
    grid-template-columns: 1fr;
  }
  .sn-team-actions,
  .sn-hz-actions {
    flex-direction: row;
  }
}
}

@layer sn.core {
.sn-profile-edit,
.sn-cuentas-pilotos-wrapper,
.sn-torneos-listado,
.sn-equipos-endurance,
.sn-ac-live {
  width: 100%;
  max-width: 1100px;
  margin: 0 auto;
  min-width: 0;
}
.sn-profile-edit p,
.sn-cuentas-pilotos-wrapper p {
  margin: 0 0 var(--sn-space-4);
  color: var(--sn-color-text-soft);
}
.sn-profile-edit .sn-row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sn-space-2);
  align-items: center;
}
.sn-profile-edit .sn-select {
  flex: 1 1 220px;
  min-width: 0;
}
.sn-profile-edit .sn-btn {
  min-height: 44px;
}
.sn-profile-edit .sn-col-actions,
.sn-profile-edit .sn-td-actions {
  text-align: right;
  white-space: nowrap;
}
.sn-profile-edit .sn-td-actions {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
}
.sn-profile-edit .sn-td-actions .sn-btn {
  min-width: 0;
}
.sn-profile-edit .sn-td-img img,
.sn-cuentas-table img {
  width: 42px;
  height: 42px;
  -o-object-fit: contain;
     object-fit: contain;
  display: block;
  margin: 0 auto;
}
.sn-cuentas-icon-cell {
  text-align: center;
}
.sn-cuentas-discord-icon {
  font-size: 24px;
  color: var(--sn-theme-primary);
}
.sn-tl-heading {
  margin: 0 0 var(--sn-space-4);
  display: flex;
  align-items: center;
  gap: 0.6rem;
  color: var(--sn-theme-primary);
  font-size: 1.2rem;
  font-weight: 700;
}
.sn-tl-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--sn-space-4);
}
.sn-tl-grid.sn-count-1 {
  grid-template-columns: 1fr;
}
.sn-tl-grid.sn-count-2 {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
.sn-torneo-card {
  display: flex;
  flex-direction: column;
  min-width: 0;
  overflow: hidden;
  border: 1px solid var(--sn-color-border);
  border-radius: var(--sn-radius-lg);
  background: linear-gradient(
    180deg,
    rgba(255, 255, 255, 0.03),
    rgba(10, 10, 10, 0.96)
  );
  box-shadow: var(--sn-shadow-sm);
  transform: translateY(8px);
  opacity: 1;
  transition:
    transform 0.5s ease,
    opacity 0.5s ease,
    box-shadow 0.25s ease,
    border-color 0.25s ease;
}
.sn-torneo-card.is-visible {
  transform: translateY(0);
}
.sn-torneo-card:hover {
  border-color: rgba(201, 13, 5, 0.55);
  box-shadow: 0 16px 30px rgba(0, 0, 0, 0.42);
}
.sn-torneo-card.is-finalizado {
  opacity: 0.88;
}
.sn-card-media {
  position: relative;
  aspect-ratio: 1/1;
  overflow: hidden;
  background: var(--sn-color-surface-alt);
}
.sn-card-img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  display: block;
}
.sn-sim-logo {
  position: absolute;
  top: 0.75rem;
  right: 0.75rem;
  width: 48px;
  height: 48px;
  -o-object-fit: contain;
     object-fit: contain;
  border-radius: 12px;
  padding: 0.35rem;
  background: rgba(0, 0, 0, 0.55);
  border: 1px solid rgba(255, 255, 255, 0.08);
}
.sn-card-body {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  padding: var(--sn-space-4);
}
.sn-card-title {
  margin: 0;
  color: var(--sn-color-text);
  font-size: 1.05rem;
  font-weight: 700;
}
.sn-card-desc {
  color: var(--sn-color-text-soft);
  font-size: var(--sn-font-size);
  line-height: 1.45;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.sn-card-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}
.sn-card-cost {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  color: var(--sn-color-text);
  font-weight: 600;
}
.sn-card-actions {
  margin-top: auto;
  display: flex;
  justify-content: flex-end;
}
.sn-ac-live .sn-ac-live-framewrap {
  width: 100%;
  min-width: 100%;
  height: var(--sn-ac-live-height, 80vh);
  position: relative;
  background: var(--sn-color-surface-alt);
  border: 1px solid var(--sn-color-border);
  border-radius: var(--sn-radius-lg);
  overflow: hidden;
}
.sn-ac-live .sn-ac-iframe {
  width: 100%;
  min-width: 100%;
  height: 100%;
  border: 0;
  display: block;
  background: #000;
}
.sn-ac-live .sn-ac-iframe[aria-busy="true"] {
  filter: brightness(0.88);
}
.sn-endu-body {
  width: 100%;
}
.ee-categoria-titulo {
  margin: var(--sn-space-5) 0 var(--sn-space-3);
}
.ee-tabla {
  min-width: 760px;
}
.ee-tabla tbody tr.ee-row-pendiente td {
  background: rgba(125, 41, 41, 0.14);
}
.ee-tabla tbody tr.ee-row-aprobado td {
  background: rgba(26, 94, 50, 0.16);
}
.ee-num {
  width: 52px;
  text-align: center;
  font-weight: 700;
  color: var(--sn-color-text-soft);
}
.ee-num .ee-btn-livery {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-top: 4px;
  padding: 2px 8px;
  border: 1px solid var(--sn-color-border);
  border-radius: var(--sn-radius-sm);
  background: var(--sn-color-surface-alt);
  color: var(--sn-theme-primary);
  font-size: 10px;
  font-weight: 700;
  cursor: pointer;
}
.ee-img {
  width: 180px;
}
.ee-img-wrap {
  position: relative;
  width: 150px;
  height: 86px;
  border-radius: 12px;
  overflow: hidden;
  border: 1px solid var(--sn-color-border);
  background: var(--sn-color-surface-alt);
}
.ee-auto,
.ee-logo,
.ee-piloto-avatar,
.ee-red-icon img {
  display: block;
}
.ee-auto {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.ee-logo {
  position: absolute;
  top: 6px;
  left: 6px;
  width: 44px;
  height: 44px;
  border-radius: 10px;
  border: 1px solid var(--sn-color-border);
  background: rgba(0, 0, 0, 0.72);
  -o-object-fit: cover;
     object-fit: cover;
}
.ee-equipo-chip,
.ee-piloto,
.ee-status-msg,
.ee-notas-admin {
  border-radius: 12px;
  border: 1px solid var(--sn-color-border);
  background: rgba(255, 255, 255, 0.03);
}
.ee-equipo-chip {
  display: inline-flex;
  flex-direction: column;
  gap: 4px;
  padding: 10px 12px;
  min-width: 180px;
}
.ee-equipo-chip .ee-numero {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.4px;
}
.ee-equipo-chip .ee-nombre {
  font-size: 16px;
  font-weight: 700;
  line-height: 1.15;
}
.ee-livery-pend,
.ee-piloto-ir-badge,
.ee-piloto-lap-badge,
.ee-piloto-pending {
  display: inline-flex;
  align-items: center;
  align-self: flex-start;
  padding: 2px 6px;
  border-radius: var(--sn-radius-pill);
  font-size: 10px;
  font-weight: 700;
  border: 1px solid var(--sn-color-border);
}
.ee-livery-pend,
.ee-piloto-lap-badge,
.ee-piloto-pending {
  background: rgba(251, 191, 36, 0.16);
  color: #ffe6b3;
}
.ee-piloto-ir-badge {
  background: rgba(14, 165, 233, 0.16);
  color: #b9e8ff;
}
.ee-piloto-ir-badge.ee-ir-inactiva {
  background: rgba(107, 114, 128, 0.2);
  color: #d4d8df;
}
.ee-piloto-ir-badge.ee-ir-historico {
  background: rgba(34, 197, 94, 0.18);
  color: #d9ffe8;
}
.ee-piloto-ir-badge.ee-ir-nueva {
  background: rgba(201, 13, 5, 0.18);
  color: #ffd7d5;
}
.ee-notas-admin,
.ee-status-msg {
  padding: 8px 10px;
  color: var(--sn-color-text-soft);
}
.ee-pilotos-wrap {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.ee-piloto {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 8px;
}
.ee-piloto-avatar {
  width: 42px;
  height: 42px;
  border-radius: 50%;
  -o-object-fit: cover;
     object-fit: cover;
}
.ee-piloto-info {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.ee-piloto-nombre {
  font-size: 13px;
  font-weight: 600;
  color: var(--sn-color-text);
}
.ee-piloto-meta {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.ee-flag {
  width: 20px;
  border-radius: 2px;
}
.ee-redes {
  text-align: center;
}
.ee-red-icon {
  display: inline-flex;
  margin: 0 4px;
}
.ee-red-icon img {
  width: 22px;
  height: 22px;
  -o-object-fit: contain;
     object-fit: contain;
}
.ee-promedio {
  text-align: center;
  font-weight: 700;
}
#equipos-endurance-container {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
.ee-lightbox {
  position: fixed;
  inset: 0;
  display: none;
  z-index: var(--sn-z-max);
}
.ee-lightbox-open {
  display: block;
}
.ee-lightbox-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.8);
  backdrop-filter: blur(2px);
}
.ee-lightbox-content {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  max-width: 92vw;
  max-height: 90vh;
  overflow: hidden;
  border-radius: 12px;
  border: 1px solid var(--sn-color-border);
  background: var(--sn-color-surface-alt);
  box-shadow: var(--sn-shadow-lg);
}
.ee-lightbox-content img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}
}

@layer sn.core {
@media (min-width: 1025px) {
  .sn-tl-grid.sn-count-1 .sn-torneo-card {
    display: grid;
    grid-template-columns: 44% 56%;
    min-height: clamp(220px, 28vw, 340px);
  }
  .sn-tl-grid.sn-count-2 .sn-torneo-card {
    display: grid;
    grid-template-columns: 46% 54%;
    min-height: clamp(220px, 22vw, 300px);
  }
  .sn-tl-grid.sn-count-1 .sn-card-media,
  .sn-tl-grid.sn-count-2 .sn-card-media {
    aspect-ratio: auto;
    height: 100%;
  }
  .sn-tl-grid.sn-count-1 .sn-card-body,
  .sn-tl-grid.sn-count-2 .sn-card-body {
    justify-content: flex-start;
  }
}
}

@layer sn.core {
@media (max-width: 1024px) {
  .sn-tl-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
}

@layer sn.core {
@media (max-width: 768px) {
  .sn-profile-edit .sn-row > * {
    flex: 1 1 100%;
  }
  .sn-tl-grid {
    grid-template-columns: 1fr;
  }
  .ee-tabla {
    min-width: 680px;
  }
  .ee-img-wrap {
    width: 120px;
    height: 70px;
  }
  .ee-equipo-chip .ee-nombre {
    font-size: 15px;
  }
}
}

@layer sn.core {
.sn-encabezado-panel {
  margin-bottom: var(--sn-space-4);
  padding: 0;
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 18px;
  background:
    radial-gradient(
      circle at top right,
      rgba(201, 13, 5, 0.16),
      transparent 38%
    ),
    linear-gradient(180deg, rgba(8, 15, 28, 0.95), rgba(8, 10, 16, 0.98));
  box-shadow: 0 12px 34px rgba(0, 0, 0, 0.28);
  color: var(--sn-color-text);
  overflow: hidden;
}
.sn-encabezado-licencia {
  display: flex;
  justify-content: flex-end;
  align-items: stretch;
  flex-wrap: wrap;
  gap: var(--sn-space-3);
  padding: 1rem 1.15rem;
}
.sn-licencia-card {
  display: flex;
  align-items: center;
  gap: 14px;
  width: 100%;
  max-width: 640px;
  min-height: 78px;
  padding: 12px 18px;
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: 18px;
  background: linear-gradient(
    135deg,
    rgba(201, 13, 5, 0.92),
    rgba(121, 8, 2, 0.88) 34%,
    rgba(16, 19, 31, 0.96) 100%
  );
  color: #fff;
  box-shadow: 0 14px 34px rgba(0, 0, 0, 0.26);
}
.sn-licencia-card img {
  width: 48px;
  height: 48px;
  flex-shrink: 0;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: 50%;
  border: 2px solid rgba(255, 255, 255, 0.24);
  box-shadow: 0 8px 16px rgba(0, 0, 0, 0.2);
}
.sn-licencia-detalle {
  display: grid;
  grid-template-columns: auto auto auto;
  grid-template-rows: auto auto;
  gap: 5px 8px;
  align-items: center;
  width: 100%;
}
.sn-licencia-detalle .badge {
  grid-column: 1;
  grid-row: 1 / span 2;
  align-self: center;
}
.sn-licencia-detalle .sn-licencia-item {
  font-size: 0.84rem;
  color: rgba(255, 255, 255, 0.9);
}
.sn-licencia-detalle .sn-licencia-item strong {
  color: #fff;
}
.sn-licencia-detalle .sn-licencia-item:nth-child(2) {
  grid-column: 2;
  grid-row: 1;
}
.sn-licencia-detalle .sn-licencia-item:nth-child(3) {
  grid-column: 3;
  grid-row: 1;
}
.sn-licencia-detalle .sn-licencia-item:nth-child(4) {
  grid-column: 2;
  grid-row: 2;
}
.sn-licencia-detalle .sn-licencia-item:nth-child(5) {
  grid-column: 3;
  grid-row: 2;
  font-size: 0.7rem;
  color: rgba(255, 255, 255, 0.74);
}
.sn-licencia-cta {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 0.6rem 1.2rem;
  border-radius: var(--sn-radius-btn);
  background: var(--sn-grad-theme);
  color: #fff;
  text-decoration: none;
  font-weight: 600;
  box-shadow: 0 6px 16px rgba(201, 13, 5, 0.45);
}
.sn-licencia-cta:hover {
  color: #fff;
  filter: brightness(1.08);
}
}

@layer sn.core {
@media (min-width: 769px) {
  body.sn-has-menu > *:not(#sn-menu-lat) {
    margin-left: 240px !important;
  }
}
}

@layer sn.core {
#sn-menu-lat {
  position: fixed !important;
  top: 0;
  left: 0;
  bottom: 0 !important;
  width: 240px !important;
  background: #111 !important;
  border-right: 1px solid var(--sn-color-border) !important;
  overflow-y: auto !important;
  z-index: 9999 !important;
  transform: translateX(0);
  transition: transform 0.3s ease;
  font-family: var(--sn-font-sans);
}
.sn-ml-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 8px;
  padding: 0.8rem;
  border-bottom: 1px solid var(--sn-color-border);
  background: #111;
  position: sticky;
  top: 0;
  z-index: 10;
}
.sn-ml-title {
  margin: 0;
  color: var(--sn-color-text);
  font-size: 1rem;
  font-weight: 600;
}
#sn-ml-refresh {
  padding: 0.3rem 0.6rem;
}
.sn-ml-card {
  margin: 0.6rem;
  padding: 0.8rem;
  border: 1px solid var(--sn-color-border);
  border-radius: var(--sn-radius);
  background: var(--sn-color-surface-alt);
  color: var(--sn-color-text);
  font-size: 0.85rem;
  box-shadow: var(--sn-shadow-xs);
  transition:
    transform 0.2s,
    box-shadow 0.2s;
}
.sn-ml-card:hover {
  transform: translateY(-1px);
  box-shadow: var(--sn-shadow-sm);
}
.sn-ml-head,
.sn-ml-track,
.sn-ml-auto,
.sn-ml-body,
.sn-ml-meta {
  display: flex;
  align-items: center;
  gap: 0.4rem;
}
.sn-ml-head {
  margin-bottom: 0.5rem;
}
.sn-ml-head strong {
  font-size: 0.9rem;
  font-weight: 600;
}
.sn-ml-subhead {
  margin-bottom: 0.5rem;
}
.sn-ml-subhead small {
  color: var(--sn-color-text-soft);
  font-size: 0.75rem;
  font-style: italic;
}
.sn-ml-sim-icon {
  width: 28px;
  height: 28px;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: 4px;
  border: 1px solid var(--sn-color-border);
}
.sn-ml-track,
.sn-ml-auto,
.sn-ml-dates {
  margin: 0.4rem 0;
  font-size: 0.8rem;
}
.sn-ml-dl {
  margin-left: auto;
  cursor: pointer;
  color: var(--sn-theme-primary) !important;
}
.sn-ml-dates {
  padding: 0.3rem;
  border-radius: 4px;
  background: rgba(255, 255, 255, 0.05);
}
.sn-ml-count-label {
  margin: 0.5rem 0 0.2rem;
  font-size: 0.75rem;
  color: var(--sn-color-text-soft);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.sn-ml-countdown {
  font-weight: 700;
  color: var(--sn-theme-primary);
  font-family: var(--sn-font-mono);
  font-size: 0.9rem;
}
.sn-ml-chip {
  padding: 0.2rem 0.4rem;
  border-radius: 999px;
  background: var(--sn-theme-primary);
  color: #fff;
  font-size: 0.7rem;
  font-weight: 600;
}
.sn-ml-meta {
  margin: 0.5rem 0;
  font-size: 0.75rem;
  color: var(--sn-color-text-soft);
}
.sn-ml-actions {
  margin-top: 0.8rem;
  padding-top: 0.5rem;
  border-top: 1px solid var(--sn-color-border);
}
.sn-ml-btn-detalle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-left: 6px;
  padding: 2px 8px;
  border: 1px solid var(--sn-color-border);
  border-radius: var(--sn-radius-sm);
  background: var(--sn-color-surface);
  color: var(--sn-color-text);
  font-size: 12px;
  line-height: 1.2;
  cursor: pointer;
}
.sn-ins-menu-lateral {
  width: 100%;
}
.sn-ins-menu-lateral .sn-ins-badge,
.sn-ins-menu-lateral .sn-open-badge {
  width: 100% !important;
  min-width: auto !important;
  text-align: center;
  font-size: 0.75rem !important;
  padding: 0.4rem 0.6rem !important;
}
#sn-ml-toggle-mobile {
  position: fixed;
  top: 80px;
  right: 1rem;
  display: none;
  z-index: 10001;
  padding: 0.6rem 0.8rem;
  border-radius: 999px;
  box-shadow: var(--sn-shadow);
}
}

@layer sn.core {
@media (max-width: 768px) {
  #sn-ml-toggle-mobile {
    display: inline-flex;
  }
  body:not(.sn-menu-open) #sn-menu-lat {
    transform: translateX(-100%);
  }
  body.sn-menu-open #sn-menu-lat {
    transform: translateX(0);
  }
  body.sn-has-menu > *:not(#sn-menu-lat) {
    margin-left: 0 !important;
  }
  body.sn-menu-open::before {
    content: "";
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.5);
    z-index: 9998;
  }
  .sn-ml-card {
    margin: 0.4rem;
    padding: 0.6rem;
  }
  .sn-ml-header {
    padding: 0.6rem;
  }
}
}

@layer sn.core {
nav.menu-simuladores-nav {
  width: min(1600px, 96vw);
  margin: 10px auto 0;
  padding: 10px 16px;
  visibility: visible;
  background:
    radial-gradient(
      circle at 12% 20%,
      rgba(255, 255, 255, 0.05),
      transparent 55%
    ),
    linear-gradient(135deg, rgba(10, 14, 24, 0.95), rgba(4, 5, 9, 0.98));
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 999px;
  box-shadow: 0 16px 34px rgba(0, 0, 0, 0.38);
}
.whb-header-bottom .sn-menu-simuladores-host.wd-inline {
  display: block;
  width: 100%;
}
.whb-header-bottom .sn-menu-simuladores-host > nav.menu-simuladores-nav {
  max-width: 100%;
}
nav.menu-simuladores-nav .menu-simuladores-list {
  list-style: none;
  margin: 0;
  padding: 0;
}
nav.menu-simuladores-nav .menu-simuladores-item {
  position: relative;
  list-style: none;
}
nav.menu-simuladores-nav .menu-simuladores-item > a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
  text-decoration: none;
}
nav.menu-simuladores-nav .menu-simuladores-item picture {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  align-self: center;
  line-height: 0;
  overflow: hidden;
}
nav.menu-simuladores-nav .menu-simuladores-item picture img {
  display: block;
  width: auto;
  max-width: 100%;
  height: auto;
  margin: 0 auto;
  -o-object-fit: contain;
     object-fit: contain;
  -o-object-position: center;
     object-position: center;
}
nav.menu-simuladores-nav .menu-simuladores-item span.sim-nombre {
  display: none;
}
}

@layer sn.core {
@media (max-width: 767px) {
  .whb-row.whb-general-header.whb-sticky-row {
    position: relative;
    z-index: 30;
  }
  .whb-row.whb-general-header.whb-sticky-row .whb-mobile-left,
  .whb-row.whb-general-header.whb-sticky-row .whb-column_mobile2 {
    margin-bottom: 4px !important;
  }
  .whb-row.whb-header-bottom.whb-sticky-row {
    position: relative;
    z-index: 20;
    margin-top: 2px !important;
  }
  .whb-row.whb-header-bottom.whb-sticky-row .whb-flex-row.whb-header-bottom-inner,
  .whb-row.whb-header-bottom.whb-sticky-row .whb-column_mobile5,
  .whb-row.whb-header-bottom.whb-sticky-row .whb-column11 {
    padding-top: 0 !important;
    margin-top: 0 !important;
  }
  .whb-header-bottom,
  .whb-header-bottom .container,
  .whb-header-bottom .whb-flex-row,
  .whb-header-bottom .sn-menu-simuladores-column,
  .whb-header-bottom .sn-menu-simuladores-host,
  .whb-header-bottom .sn-menu-simuladores-host.wd-inline,
  nav.menu-simuladores-nav {
    overflow: visible;
  }
  .whb-general-header .wd-header-text.sn-menu-simuladores-stack {
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 8px;
    width: 100% !important;
    margin: 0 !important;
  }
  .whb-general-header .wd-header-text.sn-menu-simuladores-stack > * {
    width: 100% !important;
  }
  nav.menu-simuladores-nav {
    position: relative;
    width: calc(100vw - 20px);
    max-width: calc(100vw - 20px);
    margin: 0 auto 8px;
    padding: 0;
    border: 0;
    border-radius: 22px;
    background: transparent;
    box-shadow: none;
    isolation: isolate;
    z-index: 220;
  }
  nav.menu-simuladores-nav.mobile-open::before {
    content: "";
    position: fixed;
    inset: 0;
    background: rgba(5, 8, 15, 0.52);
    z-index: 10010;
  }
  nav.menu-simuladores-nav .mobile-trigger {
    display: flex !important;
    justify-content: center;
    align-items: center;
    width: 100%;
    min-height: 44px;
    padding: 0 42px 0 16px;
    font-size: 0.95rem;
    font-weight: 700;
    line-height: 1.1;
    color: #f5f7ff !important;
    text-align: center;
    background: linear-gradient(180deg, rgba(12, 20, 34, 0.98), rgba(5, 10, 18, 0.99));
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 18px !important;
    box-shadow: 0 12px 24px rgba(0, 0, 0, 0.26);
    cursor: pointer;
    opacity: 1 !important;
    pointer-events: auto !important;
    -moz-appearance: none;
         appearance: none;
    -webkit-appearance: none;
    -webkit-user-select: none;
       -moz-user-select: none;
            user-select: none;
    -webkit-tap-highlight-color: transparent;
    position: relative;
    z-index: 10030;
    overflow: hidden;
  }
  nav.menu-simuladores-nav .mobile-trigger .arrow-down {
    position: absolute;
    right: 16px;
    top: 50%;
    margin: 0;
    border: solid #fff;
    border-width: 0 2px 2px 0;
    padding: 3px;
    transform: translateY(-60%) rotate(45deg);
  }
  nav.menu-simuladores-nav.mobile-open .mobile-trigger .arrow-down {
    transform: translateY(-35%) rotate(225deg);
  }
  nav.menu-simuladores-nav .menu-simuladores-list {
    display: none !important;
    position: fixed;
    top: var(--sn-menu-mobile-top, 132px);
    left: 10px;
    right: 10px;
    width: auto;
    z-index: 10020;
    padding: 10px;
    list-style: none;
    border-radius: 20px;
    background: linear-gradient(180deg, rgba(10, 16, 28, 0.99), rgba(5, 10, 18, 0.99));
    border: 1px solid rgba(255, 255, 255, 0.08);
    box-shadow: 0 24px 42px rgba(0, 0, 0, 0.44);
    max-height: min(56vh, 420px);
    overflow-y: auto;
    gap: 8px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  nav.menu-simuladores-nav .menu-simuladores-item {
    width: 100%;
    padding: 0;
  }
  nav.menu-simuladores-nav .menu-simuladores-item > a {
    display: flex !important;
    align-items: center !important;
    gap: 8px;
    width: 100%;
    min-height: 42px;
    padding: 8px 10px;
    border: none !important;
    border-radius: 13px;
    background: rgba(255, 255, 255, 0.03);
  }
  nav.menu-simuladores-nav .menu-simuladores-item > a picture {
    width: 18px;
    max-width: 18px;
    flex: 0 0 18px;
    min-height: 18px;
    height: 18px;
  }
  nav.menu-simuladores-nav .menu-simuladores-item > a picture img {
    width: 18px;
    height: 18px;
    max-width: 18px;
    max-height: 18px;
  }
  nav.menu-simuladores-nav .menu-simuladores-item > a .sim-nombre {
    display: -webkit-box !important;
    flex: 1 1 auto;
    font-size: 0.8rem;
    font-weight: 600;
    color: var(--sn-color-text);
    line-height: 1.1;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
  }
  nav.menu-simuladores-nav .menu-simuladores-item.active {
    background: transparent !important;
    box-shadow: none !important;
  }
  nav.menu-simuladores-nav .menu-simuladores-item.active > a {
    background: linear-gradient(135deg, rgba(201, 13, 5, 0.98), rgba(145, 10, 4, 0.95)) !important;
    box-shadow:
      inset 0 0 0 1px rgba(255, 255, 255, 0.08),
      0 8px 16px rgba(201, 13, 5, 0.28) !important;
  }
  nav.menu-simuladores-nav .menu-simuladores-item.sim-edit {
    grid-column: 1 / -1;
  }
  nav.menu-simuladores-nav .menu-simuladores-item.sim-edit > a {
    justify-content: center;
    min-height: 40px;
    gap: 0;
  }
  nav.menu-simuladores-nav.mobile-open .menu-simuladores-list {
    display: grid !important;
    -webkit-overflow-scrolling: touch;
  }
}
}

@layer sn.core {
body.nsim-lock-scroll {
  overflow: hidden;
  touch-action: none;
}
.ntr-drawer {
  position: fixed;
  inset: 0;
  display: block;
  pointer-events: none;
  z-index: var(--sn-z-max);
}
.ntr-drawer.is-open {
  pointer-events: auto;
}
.ntr-drawer__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.45);
  opacity: 0;
  transition: opacity 0.25s;
}
.ntr-drawer.is-open .ntr-drawer__backdrop {
  opacity: 1;
}
.ntr-drawer__panel {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  max-height: 85vh;
  border-radius: 16px 16px 0 0;
  border: 1px solid var(--sn-color-border);
  background: var(--sn-color-surface);
  color: var(--sn-color-text);
  box-shadow: 0-10px 30px rgba(0, 0, 0, 0.4);
  transform: translateY(100%);
  transition: transform 0.28s ease;
}
.ntr-drawer.is-open .ntr-drawer__panel {
  transform: translateY(0);
}
.ntr-drawer__close {
  position: absolute;
  right: 10px;
  top: 10px;
  width: 32px;
  height: 32px;
  border: 0;
  background: transparent;
  color: var(--sn-color-text);
  font-size: 20px;
  line-height: 1;
  cursor: pointer;
}
.ntr-drawer__content {
  padding: 16px 14px 24px;
}
#sn-f1-container,
#sn-dr2-container,
#sn-gt7-container,
.sn-denuncias-endurance {
  width: 100%;
  max-width: 1100px;
  margin: 0 auto;
}
#sn-f1-container {
  margin: 1rem 0;
  padding: 1rem;
  border: 1px solid var(--sn-color-border);
  border-radius: var(--sn-radius-lg);
  background: linear-gradient(
    180deg,
    rgba(255, 255, 255, 0.03),
    rgba(10, 10, 10, 0.96)
  );
  color: var(--sn-color-text);
}
#sn-f1-status .error {
  color: var(--sn-danger);
  font-weight: 600;
}
#sn-f1-status .warning {
  color: var(--sn-warning);
  font-weight: 600;
}
#sn-f1-status .success {
  color: var(--sn-success);
  font-weight: 600;
}
#sn-modal-message {
  display: none;
  margin-top: 1rem;
  padding: 0.6rem 0.75rem;
  border-radius: var(--sn-radius);
  font-size: 0.85rem;
}
#sn-modal-message.success {
  background: rgba(40, 167, 69, 0.14);
  border: 1px solid rgba(40, 167, 69, 0.4);
  color: #d8ffe6;
}
#sn-modal-message.error {
  background: rgba(220, 53, 69, 0.14);
  border: 1px solid rgba(220, 53, 69, 0.4);
  color: #ffd8d8;
}
.sn-dr2-results,
#sn-resultados-racenet,
#sn-gt7-result {
  margin-top: 10px;
  max-height: 320px;
  overflow: auto;
  padding-right: 4px;
}
.sn-dr2-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 6px;
  padding: 8px 10px;
  border: 1px solid var(--sn-color-border);
  border-radius: var(--sn-radius);
  background: var(--sn-color-surface);
}
.sn-dr2-search {
  width: 100%;
  padding: 8px;
  border: 1px solid var(--sn-color-border);
  border-radius: var(--sn-radius-sm);
  background: var(--sn-color-bg-alt);
  color: var(--sn-color-text);
}
.sn-dr2-link {
  min-width: 96px;
  text-align: center;
}
.sn-dr2-item .sn-btn {
  padding: 6px 12px;
  border-radius: var(--sn-radius-sm);
  white-space: nowrap;
}
#sn-conectar-dr2-modal .sn-btn--ghost {
  background: #6a2bd9;
  border: 1px solid #5a22b8;
  color: #fff;
  text-decoration: none;
}
#sn-conectar-dr2-modal .sn-btn--ghost:hover {
  background: #7a3bf0;
  color: #fff;
}
#sn-gt7-modal .nitro-instructions {
  margin-bottom: 1rem;
}
#sn-gt7-modal .nitro-instructions ol {
  padding-left: 1.2rem;
}
#sn-gt7-modal input[type="text"],
#sn-conectar-f1-modal input[type="text"] {
  margin-bottom: 1rem;
}
#sn-gt7-error-message {
  margin-bottom: 0.5rem;
  color: var(--sn-danger);
  font-size: 0.9rem;
}
.gt7-table {
  width: 100%;
  margin: 0 0 1rem;
}
.gt7-table th,
.gt7-table td {
  padding: 0.35rem 0.55rem;
}
#sn-gt7-modal .nitro-support {
  font-size: 0.88rem;
  color: var(--sn-color-text-soft);
}
.sn-denuncias-endurance {
  padding: 20px;
}
.sn-denuncias-endurance.sn-shell {
  display: grid;
  gap: 16px;
}
.sn-denuncias-login-required {
  text-align: center;
  padding: 60px 20px;
}
.sn-denuncias-login-required.sn-empty-state {
  justify-items: center;
}
.sn-denuncias-header {
  display: flex;
  justify-content: flex-end;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 20px;
}
.sn-sanciones-tabla {
  width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
.sn-discord-link-block {
  margin: 10px 0 14px;
  display: flex;
  justify-content: flex-start;
}
.sn-discord-actions {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.sn-btn-discord-link {
  background: #5865f2;
  color: #fff;
  font-weight: 600;
  border: 0;
  border-radius: 10px;
  padding: 10px 14px;
  cursor: pointer;
  font-size: 14px;
  box-shadow: 0 8px 20px rgba(88, 101, 242, 0.28);
}
.sn-btn-discord-link:hover {
  filter: brightness(1.08);
}
.sn-btn-discord-link i {
  margin-right: 8px;
}
.sn-modal-denuncia .sn-form-group,
.sn-modal-resolver .sn-form-group {
  margin-bottom: 20px !important;
}
.sn-modal-denuncia .sn-form-group:last-of-type,
.sn-modal-resolver .sn-form-group:last-of-type {
  margin-bottom: 0 !important;
}
.sn-modal-denuncia .sn-form-group label,
.sn-modal-resolver .sn-form-group label {
  display: block !important;
  margin-bottom: 8px !important;
  font-weight: 600 !important;
  color: var(--sn-color-text) !important;
  font-size: 14px !important;
}
.sn-modal.sn-modal-denuncia .sn-form-group label::after,
.sn-modal.sn-modal-resolver .sn-form-group label::after {
  content: " *";
  color: var(--sn-danger);
  display: none;
}
.sn-modal.sn-modal-denuncia .sn-form-group label[for="selectDenunciado"]::after,
.sn-modal.sn-modal-denuncia .sn-form-group label[for="textDenuncia"]::after,
.sn-modal.sn-modal-resolver .sn-form-group label[for="selectEstado"]::after,
.sn-modal.sn-modal-resolver .sn-form-group label[for="textConcepto"]::after {
  display: inline;
}
.sn-modal-denuncia .sn-input,
.sn-modal-denuncia .sn-textarea,
.sn-modal-resolver .sn-input,
.sn-modal-resolver .sn-textarea {
  width: 100% !important;
}
.sn-modal-denuncia .sn-textarea,
.sn-modal-resolver .sn-textarea {
  min-height: 120px !important;
  line-height: 1.6 !important;
  resize: vertical !important;
}
.sn-modal-denuncia .select2-container,
.sn-modal-resolver .select2-container,
.sn-denuncias-endurance .select2-container {
  width: 100% !important;
}
.sn-denuncias-overlay .sn-modal-actions {
  display: flex;
  justify-content: flex-end;
  gap: 12px;
  margin-top: 24px;
  padding-top: 24px;
  border-top: 1px solid var(--sn-color-border);
}
.sn-denuncia-desc,
.sn-denuncia-concepto {
  margin-top: 8px;
  padding: 12px;
  border: 1px solid var(--sn-color-border);
  border-radius: var(--sn-radius);
  background: var(--sn-color-surface);
  white-space: pre-wrap;
  word-wrap: break-word;
  line-height: 1.6;
}
}

@layer sn.core {
@media (max-width: 768px) {
  #sn-f1-container {
    padding: 0.85rem;
  }
  .sn-denuncias-endurance {
    padding: 12px;
  }
  .sn-denuncias-header,
  .sn-denuncias-overlay .sn-modal-actions {
    flex-direction: column;
  }
  .sn-denuncias-endurance .sn-btn,
  .sn-denuncias-overlay .sn-modal-actions .sn-btn {
    width: 100%;
  }
}
}

@layer sn.core {
.nitro-chat-container,
#nitro-chat-container,
[id^="nitro-chat-container-"] {
  max-width: 600px;
  height: 500px;
  display: flex !important;
  flex-direction: column !important;
  position: relative;
  overflow: hidden;
  border: 1px solid var(--sn-color-border);
  border-radius: 18px;
  background:
    radial-gradient(
      circle at top right,
      rgba(201, 13, 5, 0.14),
      transparent 34%
    ),
    linear-gradient(180deg, rgba(17, 20, 30, 0.96), rgba(11, 12, 18, 0.98));
  color: var(--sn-color-text);
  box-shadow: 0 16px 40px rgba(0, 0, 0, 0.35);
  font-family: var(--sn-font-sans);
}
.chat-interface {
  display: flex !important;
  flex-direction: column !important;
  width: 100% !important;
  height: 100% !important;
}
.nitro-chat-container.sn-hidden,
[id^="nitro-chat-container-"].sn-hidden {
  display: none !important;
}
.chat-header {
  position: relative;
  z-index: 10;
  width: 100%;
  box-sizing: border-box;
  display: flex !important;
  justify-content: space-between;
  align-items: center;
  flex-shrink: 0 !important;
  min-height: 46px !important;
  max-height: 46px !important;
  padding: 10px 14px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
  background: linear-gradient(
    135deg,
    rgba(201, 13, 5, 0.98),
    rgba(121, 8, 2, 0.96)
  );
}
[id^="chat-interface-"] .chat-header {
  display: flex !important;
  visibility: visible !important;
  opacity: 1 !important;
}
.chat-header h4 {
  margin: 0;
  color: #fff;
  font-size: 14px;
  font-weight: 600;
  flex-shrink: 0;
}
.chat-users-count {
  font-size: 0.82rem;
  color: rgba(255, 231, 206, 0.92);
  white-space: nowrap;
  flex-shrink: 0;
}
.active-users-count {
  font-weight: 700;
  color: inherit;
}
.chat-controls {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
}
.chat-control-btn {
  padding: 0;
  border: none;
  background: transparent;
  color: #fff;
  font-size: 14px;
  cursor: pointer;
  box-shadow: none;
}
.chat-control-btn:hover {
  filter: brightness(1.1);
}
.chat-control-btn.muted {
  opacity: 0.6;
}
.chat-notification {
  position: absolute;
  top: 40px;
  left: 50%;
  transform: translateX(-50%);
  max-width: 80%;
  text-align: center;
  z-index: 1000;
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.3s ease;
  padding: 6px 12px;
  border-radius: 6px;
  background: var(--sn-success);
  color: #fff;
  font-size: 12px;
}
.chat-notification.show {
  opacity: 1;
}
.chat-notification.leave {
  background: var(--sn-danger);
}
.chat-messages,
[id^="chat-messages-"] {
  height: calc(100% - 46px - 72px) !important;
  flex: 1 1 auto !important;
  min-height: 300px;
  display: block !important;
  visibility: visible !important;
  overflow-y: auto !important;
  position: relative !important;
  padding: 12px !important;
  background: linear-gradient(
    180deg,
    rgba(10, 12, 18, 0.76),
    rgba(10, 12, 18, 0.88)
  ) !important;
}
[id^="chat-interface-"] {
  display: flex !important;
  flex-direction: column !important;
  height: 100% !important;
  width: 100% !important;
  position: relative !important;
}
.chat-message {
  display: flex;
  clear: both;
  align-items: flex-end;
  gap: 4px;
  max-width: 75%;
  margin-bottom: 4px;
  padding: 4px 6px;
  border-radius: 10px;
  word-wrap: break-word;
}
.chat-message.my-message {
  float: right;
  clear: both;
  margin-left: auto;
  margin-right: 8px;
  flex-direction: row-reverse;
  border-bottom-right-radius: 4px;
  background: var(--sn-primary);
  color: #fff;
}
.chat-message.other-message {
  float: left;
  clear: both;
  margin-left: 8px;
  margin-right: auto;
  border-bottom-left-radius: 4px;
  border-left: 3px solid var(--sn-accent);
  background: var(--sn-color-surface);
  color: var(--sn-color-text);
}
.message-avatar {
  width: 20px;
  height: 20px;
  flex-shrink: 0;
  align-self: flex-end;
}
.message-avatar img {
  width: 100%;
  height: 100%;
  display: block;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: 50%;
  border: 1px solid #3e4a56;
  background: #1f2937;
}
.my-message .message-avatar img {
  border-color: #00a884;
}
.message-content-wrapper {
  flex: 1;
  min-width: 0;
  overflow: hidden;
}
.message-header {
  display: flex;
  align-items: center;
  gap: 3px;
  margin-bottom: 0;
  font-size: 10px;
  line-height: 1.1;
}
.my-message .message-header {
  justify-content: flex-end;
}
.message-author {
  max-width: 80px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 10px;
  font-weight: 600;
}
.other-message .message-author {
  color: #00a884;
}
.my-message .message-author {
  color: #d1f4cc;
}
.moderator-badge {
  padding: 1px 3px;
  border-radius: 4px;
  background: #ff6b6b;
  color: #fff;
  font-size: 8px;
  font-weight: 700;
  text-transform: uppercase;
}
.message-content {
  margin: 0 0 1px;
  padding: 0;
  font-size: 12px;
  line-height: 1.15;
}
.message-time {
  margin: 0;
  color: #8696a0;
  font-size: 8px;
  text-align: right;
  line-height: 1;
}
.other-message .message-time {
  text-align: left;
}
.delete-message-btn {
  width: 18px !important;
  height: 18px !important;
  min-width: 18px !important;
  min-height: 18px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  vertical-align: middle;
  margin-left: 4px;
  padding: 0 !important;
  border: none;
  border-radius: 3px;
  background: rgba(255, 255, 255, 0.1);
  color: #8696a0;
  cursor: pointer;
  opacity: 0.7;
  transition: all 0.2s;
  font-size: 12px !important;
  line-height: 1 !important;
}
.delete-message-btn:hover {
  opacity: 1;
  background: rgba(255, 68, 68, 0.2);
  color: #f44;
}
.my-message .delete-message-btn {
  color: #d1f4cc;
}
.my-message .delete-message-btn:hover {
  background: rgba(255, 68, 68, 0.3);
  color: #faa;
}
.chat-message.system-message {
  float: none;
  clear: both;
  justify-content: center;
  max-width: 60%;
  margin: 8px auto;
  border: 1px solid #3e4a56;
  background: #182229;
  color: #8696a0;
  font-size: 12px;
  text-align: center;
  font-style: italic;
}
.chat-input-container {
  position: relative;
  flex-shrink: 0 !important;
  min-height: 72px;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  background: linear-gradient(
    180deg,
    rgba(24, 25, 32, 0.96),
    rgba(18, 20, 27, 0.98)
  );
}
.chat-emoji-picker {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding: 8px;
  border-bottom: 1px solid var(--sn-color-border);
  background: var(--sn-color-surface);
}
.emoji {
  cursor: pointer;
  padding: 4px;
  border-radius: 4px;
  transition: background 0.2s;
}
.emoji:hover {
  background: #4a5568;
}
.chat-input-row {
  display: flex;
  align-items: center;
  gap: 8px;
  height: 100%;
  box-sizing: border-box;
  padding: 12px;
}
.chat-emoji-btn {
  width: 36px;
  height: 36px;
  min-width: 36px;
  min-height: 36px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 4px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 12px;
  background: linear-gradient(
    135deg,
    rgba(201, 13, 5, 0.98),
    rgba(121, 8, 2, 0.96)
  ) !important;
  color: #fff;
  cursor: pointer;
  box-shadow: 0 8px 18px rgba(201, 13, 5, 0.24);
  font-size: 18px;
  transition: background 0.2s;
}
.chat-emoji-btn:hover {
  filter: brightness(1.06);
}
.emoji-toggle {
  line-height: 1;
}
.chat-emoji-btn:focus-visible {
  outline: 2px solid var(--sn-primary);
  outline-offset: 2px;
  background: rgba(255, 255, 255, 0.08);
}
#chat-message-input,
.chat-message-input {
  flex: 1 1 auto;
  background: #fff;
  border-color: rgba(255, 255, 255, 0.14);
  color: #111827;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.55);
}
.chat-send-btn,
.send-message {
  min-width: 90px;
}
.chat-loading,
.chat-error {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  height: 100%;
  padding: 20px;
  text-align: center;
}
.spinner {
  width: 40px;
  height: 40px;
  margin-bottom: 16px;
  border: 4px solid #2a2a2a;
  border-top: 4px solid #075e54;
  border-radius: 50%;
  animation: spin 1s linear infinite;
}
@keyframes spin {
  to {
    transform: rotate(360deg);
  }
}
.chat-error {
  color: #ef4444;
}
.chat-error-message {
  margin: 0 0 0.9rem;
}
.chat-login-required {
  padding: 20px;
  border-left: 4px solid #fbbf24;
  border-radius: 8px;
  background: #1f2937;
  color: #e0e0e0;
  text-align: center;
}
.chat-modal {
  position: fixed;
  inset: 0;
  z-index: 999999 !important;
  display: flex;
  justify-content: center;
  align-items: center;
  background: rgba(0, 0, 0, 0.8);
  pointer-events: auto !important;
}
.chat-modal-content {
  position: relative;
  z-index: 1000000 !important;
  max-width: 500px;
  max-height: 80vh;
  overflow-y: auto;
  margin: 20px;
  padding: 24px;
  border-radius: 18px;
  background: linear-gradient(
    180deg,
    rgba(13, 15, 22, 0.98),
    rgba(10, 12, 18, 0.99)
  );
  color: #e0e0e0;
  border: 1px solid rgba(255, 255, 255, 0.08);
  pointer-events: auto !important;
}
.chat-modal-content h3,
.terms-content h4 {
  color: #fff;
}
.chat-btn-primary,
.chat-btn-secondary,
.accept-terms,
.decline-terms,
.chat-retry {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.terms-content {
  margin: 16px 0;
  line-height: 1.6;
}
.terms-actions {
  position: relative;
  z-index: 1000001 !important;
  display: flex;
  justify-content: flex-end;
  gap: 12px;
  margin-top: 20px;
  pointer-events: auto !important;
}
.sn-chat-lock {
  overflow: hidden !important;
}
}

@layer sn.core {
@media (max-width: 991px) {
  .sn-chat-mobile-wrapper .nitro-chat-container,
  .sn-chat-mobile-wrapper #nitro-chat-container,
  .sn-chat-mobile-wrapper [id^="nitro-chat-container-"] {
    flex: 1 1 auto !important;
    min-height: 0 !important;
    display: flex !important;
    flex-direction: column !important;
    border-radius: 0 !important;
    background: var(--sn-color-surface-alt) !important;
  }
  .sn-chat-mobile-wrapper .chat-header,
  .sn-chat-mobile-wrapper [id^="chat-interface-"] .chat-header {
    display: none !important;
  }
  .sn-chat-mobile-wrapper .chat-messages,
  .sn-chat-mobile-wrapper [id^="chat-messages-"] {
    flex: 1 1 auto !important;
    min-height: 0 !important;
    height: auto !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch;
    padding: 8px 10px !important;
  }
  .sn-chat-mobile-wrapper .chat-input-container {
    flex: 0 0 auto !important;
    height: 60px !important;
    border-top: 1px solid #263544 !important;
    background: var(--sn-color-surface) !important;
  }
  .sn-chat-mobile-wrapper .chat-input-row {
    height: 100% !important;
    padding: 8px 10px !important;
  }
  .sn-chat-mobile-wrapper #chat-message-input {
    min-height: 36px !important;
    padding: 8px 12px !important;
    border: 1px solid #3b4a59 !important;
    border-radius: 16px !important;
    background: #243140 !important;
    color: #e3e8ec !important;
    font-size: 14px !important;
  }
  .sn-chat-mobile-wrapper .chat-send-btn,
  .sn-chat-mobile-wrapper .send-message {
    padding: 8px 14px !important;
    border-radius: 14px !important;
    font-size: 14px !important;
    box-shadow: 0 2px 6px rgba(201, 13, 5, 0.45) !important;
  }
  .sn-chat-container.fullscreen #nitro-chat-container,
  .sn-chat-container.sn-chat-fixed #nitro-chat-container {
    height: auto !important;
    max-height: none !important;
  }
}
}

@layer sn.core {
@media (max-width: 780px) {
  .chat-modal {
    align-items: flex-start;
    justify-content: center;
    padding: 10px;
  }
  .chat-modal-content {
    width: calc(100vw - 20px) !important;
    max-width: none !important;
    max-height: calc(100vh - 20px) !important;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    margin: 0 !important;
    padding: 16px !important;
    border-radius: 8px;
  }
  .chat-modal-content h3 {
    margin: 0 0 12px;
    flex-shrink: 0;
    font-size: 18px;
  }
  .terms-content {
    flex: 1 1 auto;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    margin: 8px 0 12px 0 !important;
    padding-right: 8px;
    font-size: 14px;
    line-height: 1.5;
  }
  .terms-actions {
    position: sticky;
    bottom: 0;
    z-index: 1000001 !important;
    flex-shrink: 0;
    gap: 8px;
    margin: 0;
    padding: 12px 0 0;
    border-top: 1px solid #374151;
    background: #1f2937;
  }
  .terms-actions .sn-btn {
    min-height: 44px;
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 12px 16px;
    font-size: 14px;
    z-index: 1000002 !important;
  }
}
}

@layer sn.core {
@media (max-width: 480px) {
  .chat-modal {
    padding: 5px;
  }
  .chat-modal-content {
    width: calc(100vw - 10px) !important;
    max-height: calc(100vh - 10px) !important;
    padding: 12px !important;
  }
  .chat-modal-content h3 {
    font-size: 16px;
  }
  .terms-content {
    font-size: 13px;
  }
  .terms-actions .sn-btn {
    min-height: 48px;
    padding: 14px 12px;
    font-size: 13px;
  }
  .delete-message-btn {
    width: 16px !important;
    height: 16px !important;
    min-width: 16px !important;
    min-height: 16px !important;
    font-size: 11px !important;
  }
}
}

@layer sn.core {
#tor-panel [id^="nitro-chat-container-"],
#tor-panel #nitro-chat-container {
  width: 100% !important;
  max-width: none !important;
}
#tor-panel [id^="nitro-chat-container-"] .chat-header,
#tor-panel #nitro-chat-container .chat-header {
  border-bottom: 1px solid #5f0a07 !important;
  background: var(--sn-grad-theme) !important;
}
#tor-panel [id^="nitro-chat-container-"] .chat-users-count,
#tor-panel #nitro-chat-container .chat-users-count {
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
}
#tor-panel [id^="nitro-chat-container-"] .chat-control-btn,
#tor-panel #nitro-chat-container .chat-control-btn {
  background: transparent !important;
  color: #fff !important;
}
#tor-panel [id^="nitro-chat-container-"] .chat-control-btn:hover,
#tor-panel #nitro-chat-container .chat-control-btn:hover {
  filter: brightness(1.08) !important;
}
.sn-chat-skin {
  font-family: var(--sn-font-sans);
  color: var(--sn-color-text);
}
.ronda-chip {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.32rem 0.72rem;
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.06);
  color: #fff;
  font-size: 0.72rem;
  font-weight: 700;
}
:root {
  --sn-left-w: 180px;
  --sn-right-w: 340px;
  --tor-panel-w: 360px;
}
html body #sn-root,
html body #sn-root * {
  box-sizing: border-box;
}
html body #sn-root {
  width: min(100%, 1620px);
  max-width: 1620px;
  margin: 0 auto;
  padding: 0 12px 24px;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  overflow-x: hidden;
  font-family: var(--sn-font-sans, system-ui, sans-serif);
  color: var(--sn-text, #e5e7eb);
}
html body #sn-root .sn-row-top,
html body #sn-root .sn-menu-sup,
html body #sn-root .sn-header-right,
html body #sn-root .sn-menu-izq,
html body #sn-root .sn-content,
html body #sn-root .sn-barra-lat-desktop > *,
html body #sn-root .sn-chat-desktop,
html body #sn-root .sn-header-bar-mobile,
html body #sn-root .sn-menu-izq-mobile {
  background: var(--sn-surface-1, #121418);
  border: 1px solid var(--sn-border-color, #2a2a2a);
  border-radius: var(--sn-radius-lg, 12px);
}
html body #sn-root .sn-row-top {
  display: grid;
  grid-template-columns: var(--sn-left-w) minmax(0, 1fr) minmax(260px, auto);
  gap: 1rem;
  align-items: stretch;
}
html body #sn-root .sn-logo {
  min-height: 60px;
  padding: 0.5rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.25rem;
  background: var(--sn-surface-2, #181b22);
  border: 1px solid var(--sn-border-color, #2a2a2a);
  border-radius: var(--sn-radius-lg, 12px);
}
html body #sn-root .sn-logo img {
  max-height: 32px;
  width: auto;
}
html body #sn-root .sn-sim-name {
  width: 100%;
  text-align: center;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  color: var(--sn-text-muted, #9ca3af);
  font-size: var(--sn-font-size-sm, 0.82rem);
}
html body #sn-root .sn-menu-sup,
html body #sn-root .sn-header-right {
  min-height: 60px;
  display: flex;
  align-items: center;
  gap: 0.65rem;
  padding: 0.75rem 1rem;
  min-width: 0;
}
html body #sn-root .sn-menu-sup {
  overflow-x: auto;
  white-space: nowrap;
}
html body #sn-root .sn-header-right {
  justify-content: flex-end;
  overflow: hidden;
}
html body #sn-root .sn-btn-top,
html body #sn-root .sn-btn-left {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  min-height: 40px;
  white-space: nowrap;
}
html body #sn-root .sn-btn-top svg,
html body #sn-root .sn-btn-left svg {
  width: 18px;
  height: 18px;
  fill: currentColor;
}
html body #sn-root .sn-menu-izq {
  width: var(--sn-left-w);
  display: flex;
  flex-direction: column;
  gap: 0.55rem;
  padding: 1rem 0.5rem;
}
html body #sn-root .sn-btn-left span {
  white-space: nowrap;
}
html body #sn-root .sn-main {
  display: grid;
  grid-template-columns: var(--sn-left-w) minmax(0, 1fr) var(--sn-right-w);
  gap: 1rem;
  align-items: start;
}
html body #sn-root .sn-main.no-left-menu {
  grid-template-columns: minmax(0, 1fr) var(--sn-right-w);
}
html body #sn-root .sn-content,
html body #sn-root .tor-sc-wrap {
  min-width: 0;
}
html body #sn-root .sn-content {
  min-height: 320px;
  padding: 1rem;
  overflow: hidden;
}
html body #sn-root .tor-sc-wrap,
html body #sn-root .sn-content .sn-table-wrap,
html body #sn-root .sn-content .sn-table-scroll {
  width: 100%;
  max-width: 100%;
  overflow-x: auto;
  overflow-y: visible;
  -webkit-overflow-scrolling: touch;
}
html body #sn-root .tor-sc-wrap > *,
html body #sn-root .sn-content img,
html body #sn-root .sn-content iframe,
html body #sn-root .sn-content video {
  max-width: 100%;
}
html body #sn-root .sn-content img,
html body #sn-root .sn-content video {
  height: auto;
}
html body #sn-root .sn-barra-lat-desktop,
html body #sn-root .sn-barra-lat-mobile {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
html body #sn-root .sn-header-mobile,
html body #sn-root .sn-menu-izq-mobile,
html body #sn-root .sn-barra-lat-mobile {
  display: none;
}
html body #sn-root .sn-header-bar-mobile {
  min-height: 48px;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.25rem 0.5rem;
}
html body #sn-root .sn-banner {
  min-width: 0;
}
html body #sn-root .sn-chat-close svg {
  width: 16px;
  height: 16px;
}
html body #tor-root,
html body #tor-root * {
  box-sizing: border-box;
}
html body #tor-root {
  width: min(100%, 1620px);
  max-width: 1620px;
  margin: 0 auto;
  padding: 0 12px 24px;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  overflow-x: hidden;
  font-family: var(--sn-font-sans, system-ui, sans-serif);
  color: var(--sn-text, #e5e7eb);
}
html body #tor-root .tor-header,
html body #tor-root .tor-content,
html body #tor-root .tor-panel,
html body #tor-root .tor-inscripcion-mobile {
  background: var(--sn-surface-1, #121418);
  border: 1px solid var(--sn-border-color, #2a2a2a);
  border-radius: var(--sn-radius-lg, 12px);
}
html body #tor-root .tor-header {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 1rem 1.25rem;
  min-height: 92px;
}
html body #tor-root .tor-logo,
html body #tor-root .tor-sponsors-header {
  width: 90px;
  height: 90px;
  flex: 0 0 90px;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  background: var(--sn-surface-2, #181b22);
  border: 1px solid var(--sn-border-color, #2a2a2a);
  border-radius: var(--sn-radius, 8px);
}
html body #tor-root .tor-logo img,
html body #tor-root .tor-sponsor-slide img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
html body #tor-root .tor-head-main {
  flex: 1 1 auto;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
}
html body #tor-root .tor-title {
  margin: 0;
  display: flex;
  align-items: center;
  gap: 0.6rem;
  flex-wrap: wrap;
  color: var(--sn-text-strong, #fff);
  font: 700 clamp(1.15rem, 2vw, 1.55rem)/1.15
    var(--sn-font-sans, system-ui, sans-serif);
}
html body #tor-root .tor-subdesc,
html body #tor-root .tor-sim-name {
  color: var(--sn-text-muted, #9ca3af);
  font-size: var(--sn-font-size-sm, 0.82rem);
}
html body #tor-root .tor-badges,
html body #tor-root .tor-actions {
  display: flex;
  gap: 0.5rem;
  flex-wrap: wrap;
}
html body #tor-root .tor-actions {
  flex-direction: column;
  align-items: flex-end;
  min-width: 160px;
}
html body #tor-root .tor-sim-info {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 0.25rem;
}
html body #tor-root .tor-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) var(--tor-panel-w);
  gap: 1rem;
  align-items: start;
}
html body #tor-root .tor-content-col {
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
html body #tor-root .tor-content {
  min-width: 0;
  min-height: 300px;
  padding: 1rem;
  overflow: hidden;
}
html body #tor-root .tor-content .tor-sc-wrap,
html body #tor-root .tor-content .sn-table-wrap,
html body #tor-root .tor-content .sn-table-wrap--tournament,
html body #tor-root .tor-content .sn-table-scroll {
  width: 100%;
  max-width: 100%;
  overflow-x: auto;
  overflow-y: visible;
  -webkit-overflow-scrolling: touch;
}
html body #tor-root .tor-content .tor-sc-wrap > *,
html body #tor-root .tor-content img,
html body #tor-root .tor-content iframe,
html body #tor-root .tor-content video {
  max-width: 100%;
}
html body #tor-root .tor-content img,
html body #tor-root .tor-content video {
  height: auto;
}
html body #tor-root .tor-panel {
  position: sticky;
  top: 70px;
  padding: 1rem;
  height: -moz-fit-content;
  height: fit-content;
}
html body #tor-root .tor-panel .sn-panel__section + .sn-panel__section {
  margin-top: 1rem;
}
html body #tor-root .tor-panel-header {
  display: none;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 1rem;
}
html body #tor-root .tor-panel-close {
  line-height: 1;
}
html body #tor-root .tor-panel-toggle,
html body #tor-root #tor-reglamento {
  display: none !important;
}
html body #tor-root .tor-panel-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.56);
  opacity: 0;
  visibility: hidden;
  transition:
    opacity 0.2s ease,
    visibility 0.2s ease;
  z-index: 4999;
}
html body #tor-root .tor-panel-overlay.active {
  opacity: 1;
  visibility: visible;
}
html body #tor-root .tor-sponsors-header {
  display: none;
}
html body #tor-root .tor-sponsors-desktop,
html body #tor-root .tor-sponsor-current,
html body #tor-root .tor-sponsor-slide {
  position: relative;
  width: 100%;
  height: 100%;
}
html body #tor-root .tor-sponsor-slide {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: opacity 0.3s ease;
}
html body #tor-root .tor-sponsor-slide.active {
  opacity: 1;
}
html body #tor-root .tor-sponsors-mobile-inline {
  display: none;
}
}

@layer sn.core {
@media (min-width: 769px) {
  html body #tor-root .tor-sponsors-header {
    display: flex;
  }
}
}

@layer sn.core {
@media (max-width: 1200px) {
  html body #sn-root,
  html body #tor-root {
    padding-left: 10px;
    padding-right: 10px;
  }
  html body #tor-root .tor-grid {
    grid-template-columns: 1fr;
  }
  html body #tor-root .tor-panel {
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    width: min(var(--tor-panel-w), 90vw);
    max-width: 90vw;
    transform: translateX(100%);
    transition: transform 0.25s ease;
    overflow-y: auto;
    border-radius: 0;
    z-index: 5000;
  }
  html body #tor-root .tor-panel.open {
    transform: translateX(0);
  }
  html body #tor-root .tor-panel-header,
  html body #tor-root .tor-panel-toggle {
    display: inline-flex !important;
  }
  html body #tor-root #tor-reglamento {
    display: none !important;
  }
  html body #tor-root .tor-header {
    flex-wrap: wrap;
    align-items: flex-start;
  }
  html body #tor-root .tor-actions {
    width: 100%;
    min-width: 0;
    flex-direction: row;
    align-items: center;
    justify-content: flex-start;
  }
  html body #sn-root .sn-barra-lat-desktop {
    display: none !important;
  }
  html body #sn-root .sn-barra-lat-mobile {
    display: flex;
  }
  html body #sn-root .sn-main,
  html body #sn-root .sn-main.no-left-menu {
    grid-template-columns: 1fr;
  }
  html body #sn-root .sn-chat-container.sn-has-terms {
    overflow: hidden !important;
    touch-action: none !important;
  }
  html body #sn-root .sn-terms-modal-fix {
    position: absolute !important;
    inset: 0 !important;
    display: flex !important;
    flex-direction: column !important;
    overflow: hidden !important;
    z-index: 12050 !important;
    background: var(--sn-surface-2, #181b22) !important;
    border-radius: 18px 18px 0 0;
  }
  html body #sn-root .sn-terms-modal-fix .sn-terms-scroll-area {
    flex: 1 1 auto;
    overflow-y: auto !important;
    padding: 18px 18px 160px;
  }
  html body #sn-root .sn-terms-modal-fix .sn-terms-float-bar {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    display: flex;
    gap: 10px;
    padding: 14px 16px calc(14px + env(safe-area-inset-bottom));
    background: linear-gradient(
      180deg,
      transparent 0%,
      rgba(16, 19, 24, 0.94) 30%,
      var(--sn-surface-2, #181b22) 100%
    );
    z-index: 12060;
  }
  html body #sn-root .sn-terms-lock-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.55);
    z-index: 12040 !important;
  }
  body.sn-no-scroll,
  body.sn-no-scroll-fixed {
    overflow: hidden !important;
    touch-action: none !important;
    width: 100% !important;
  }
}
}

@layer sn.core {
@media (max-width: 768px) {
  html body #tor-root {
    padding-left: 8px;
    padding-right: 8px;
  }
  html body #tor-root .tor-header {
    display: grid;
    grid-template-columns: 72px minmax(0, 1fr);
    grid-template-areas: "logo head" "actions actions";
    gap: 0.75rem;
    padding: 0.9rem;
  }
  html body #tor-root .tor-logo {
    grid-area: logo;
    width: 72px;
    height: 72px;
    flex-basis: 72px;
  }
  html body #tor-root .tor-head-main {
    grid-area: head;
  }
  html body #tor-root .tor-actions {
    grid-area: actions;
    justify-content: flex-start;
  }
  html body #tor-root .tor-sim-info {
    align-items: flex-start;
  }
  html body #tor-root .tor-sponsors-header {
    display: none !important;
  }
  html body #tor-root .tor-sponsors-mobile-inline {
    display: flex;
    align-items: center;
    gap: 8px;
    max-width: 140px;
    flex: 1 1 auto;
    justify-content: center;
  }
  html body #tor-root .tor-sponsors-mobile-inline .tor-sponsors-track {
    display: flex;
    align-items: center;
    gap: 10px;
    height: 32px;
  }
  html body #tor-root .tor-sponsors-mobile-inline .tor-sponsor-item {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 28px;
  }
  html body #tor-root .tor-sponsors-mobile-inline .tor-sponsor-item img {
    max-height: 40px;
    max-width: 60px;
    width: auto;
    height: auto;
    -o-object-fit: contain;
       object-fit: contain;
  }
}
}

@layer sn.core {
@media (max-width: 600px) {
  html body #sn-root {
    padding-left: 6px;
    padding-right: 6px;
  }
  html body #sn-root .sn-header-desktop,
  html body #sn-root .sn-menu-izq-desktop {
    display: none !important;
  }
  html body #sn-root .sn-header-mobile {
    display: block;
    width: 100%;
  }
  html body #sn-root .sn-row-top {
    grid-template-columns: 1fr;
    gap: 0;
    padding: 0;
    background: transparent;
    border: 0;
  }
  html body #sn-root .sn-logo {
    width: 44px;
    min-width: 44px;
    max-width: 44px;
    height: 44px;
    min-height: 44px;
    padding: 0;
  }
  html body #sn-root .sn-logo img {
    max-height: 26px;
  }
  html body #sn-root .sn-sim-name {
    display: none;
  }
  html body #sn-root .sn-header-right {
    padding: 0 0.2rem;
    gap: 0.3rem;
  }
  html body #sn-root .sn-menu-sup,
  html body #sn-root .sn-menu-izq-mobile {
    min-height: 44px;
    max-height: 44px;
    padding: 0 0.2rem;
    gap: 0.2rem;
    overflow-x: auto;
  }
  html body #sn-root .sn-menu-izq-mobile {
    display: flex;
    align-items: center;
  }
  html body #sn-root .sn-btn-top,
  html body #sn-root .sn-btn-left {
    min-height: 34px;
    padding-inline: 0.75rem;
  }
  html body #sn-root .sn-content {
    padding: 0.75rem;
  }
}
}

@layer sn.core {
@media (max-width: 520px) {
  html body #tor-root {
    padding-left: 6px;
    padding-right: 6px;
  }
  html body #tor-root .tor-header {
    grid-template-columns: 64px minmax(0, 1fr);
  }
  html body #tor-root .tor-logo {
    width: 64px;
    height: 64px;
    flex-basis: 64px;
  }
  html body #tor-root .tor-content {
    padding: 0.75rem;
  }
}
}

@layer sn.core {
.sn-inv-box-big {
  position: relative;
  margin: 12px 0 16px;
  border: 1px solid var(--sn-color-border);
  border-radius: 14px;
  overflow: hidden;
  background: linear-gradient(
    180deg,
    rgba(34, 34, 34, 0.9),
    rgba(18, 18, 18, 0.92)
  );
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.35);
}
.sn-inv-big-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 18px 16px 16px;
  flex-wrap: wrap;
}
.sn-inv-big-head {
  display: flex;
  align-items: center;
  gap: 12px;
}
.sn-inv-big-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 42px;
  height: 42px;
  border-radius: 10px;
  background: radial-gradient(100% 100%at 100%0, #2b8cff 0%, #1a6adf 100%);
  color: #fff;
  box-shadow: 0 3px 12px rgba(63, 169, 245, 0.35);
}
.sn-inv-big-ttl {
  margin: 0;
  font-size: 18px;
  font-weight: 700;
  line-height: 1.2;
}
.sn-inv-big-sub {
  margin-top: 2px;
  font-size: 13px;
  opacity: 0.9;
}
.sn-inv-big-team {
  font-size: 16px;
  opacity: 0.95;
}
.sn-inv-acts {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
.sn-inv-acts .sn-btn {
  font-size: 15px;
  padding: 10px 16px;
}
.sn-inv-box-big .sn-btn.pri,
.sn-inv-box-big .sn-btn.accent,
.sn-ticket-callout .sn-btn.pri {
  background: var(--sn-grad-theme);
  border-color: var(--sn-theme-primary-dark);
  color: #fff;
}
.sn-inv-box-big .sn-btn.pri:hover,
.sn-inv-box-big .sn-btn.accent:hover,
.sn-ticket-callout .sn-btn.pri:hover {
  filter: brightness(1.06);
}
.sn-reglamentos {
  margin: 0 0 1.25rem;
}
.sn-reg-title {
  margin: 0;
}
.sn-reg-tabs {
  justify-content: center;
  padding: 10px 12px 0;
}
.sn-reg-content {
  min-height: 60vh;
  padding: 12px;
}
.sn-reg-loading {
  min-height: 120px;
}
.sn-pdf-wrap,
.tor-pdf-wrap {
  position: relative;
  border: 1px solid rgba(255, 255, 255, 0.15);
  border-radius: 10px;
  overflow: hidden;
  background: #0f1218;
  min-height: 70vh;
}
.sn-pdf-frame,
.tor-pdf-frame {
  display: block;
  width: 100%;
  height: 78vh;
  border: 0;
  background: #0b0e14;
}
.sn-pdf-note,
.tor-pdf-note {
  margin: 0.75rem 0 0;
  color: #7e8895;
  font-size: 0.8em;
}
.sn-pdf-overlay,
.tor-pdf-overlay {
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
}
.tor-pdf-overlay {
  pointer-events: auto;
  background: transparent;
}
.tor-pdf-scroll-hole {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  width: 160px;
  z-index: 3;
  pointer-events: none;
}
.tor-pdf-scroll-hole-left {
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  width: 80px;
  z-index: 3;
  pointer-events: none;
}
.tor-noselect {
  -moz-user-select: none;
       user-select: none;
  -webkit-user-select: none;
  -ms-user-select: none;
}
}

@layer sn.core {
@media (max-width: 768px) {
  .sn-inv-big-inner {
    flex-direction: column;
    align-items: flex-start;
  }
  .sn-pdf-frame,
  .tor-pdf-frame {
    height: 70vh;
  }
}
}

@layer sn.core {
:root {
  --sn-ui-primary: #c90d05;
  --sn-ui-primary-dark: #9e0a03;
  --sn-ui-primary-soft: #ffebe9;
  --sn-ui-bg: #0b0f17;
  --sn-ui-surface: #111827;
  --sn-ui-surface-2: #151b24;
  --sn-ui-surface-3: #1b2430;
  --sn-ui-border: rgba(255, 255, 255, 0.14);
  --sn-ui-text: #fff;
  --sn-ui-text-muted: #cfd6df;
  --sn-ui-radius: 10px;
  --sn-ui-modal-max: 1100px;
  --sn-ui-table-head-size: 0.78rem;
}
.sn-tor-skin,
.sn-shell,
.sn-panel,
.sn-modal,
.sn-modal__dialog,
.sn-modal__body,
.sn-modal-body,
.sn-modal__header,
.sn-modal-header,
.tor-wrapper,
.tor-content,
.tor-panel,
.tor-sc-wrap,
.tor-res-modal,
.tor-std-modal,
.tor-res-body,
.tor-std-body,
.pw-modal,
.chat-modal-content,
.sn-f1-modal-content,
.sn-np-modal-content,
.select2-container {
  font-family: var(--sn-font-sans, system-ui, sans-serif) !important;
  color: var(--sn-ui-text) !important;
}
.sn-panel,
.sn-surface-card,
.sn-shell__metric,
.tor-panel-card,
.tor-cal-card,
.tor-den-card,
.pw-card,
.sn-pw-next,
.sn-guest-card,
.sn-ui-surface {
  background: var(--sn-ui-surface) !important;
  border-color: var(--sn-ui-border) !important;
  color: var(--sn-ui-text) !important;
}
.sn-shell__header,
.sn-shell__toolbar,
.tor-cal-card-head,
.tor-panel-card-header,
.pw-card-head,
.sn-ui-surface-alt {
  background: var(--sn-ui-surface-2) !important;
  border-color: var(--sn-ui-border) !important;
  color: var(--sn-ui-text) !important;
}
.tor-wrapper,
.tor-content,
.tor-panel,
.tor-sc-wrap,
.sn-tor-skin,
.sn-tab-content {
  max-width: 100%;
  overflow-x: clip;
}
.tor-wrapper .sn-table-wrap,
.tor-wrapper .table-responsive,
.tor-wrapper .sn-table-scroll,
.sn-tor-skin .sn-table-wrap,
.sn-tor-skin .table-responsive,
.sn-tor-skin .sn-table-scroll,
.tor-denuncias .sn-table-wrap,
.tor-denuncias .table-responsive,
.tor-denuncias .sn-table-scroll {
  max-width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
.sn-btn,
button.sn-btn,
a.sn-btn,
.sn-btn-primary,
.tor-btn,
.button.sn-btn {
  background: linear-gradient(
    135deg,
    var(--sn-ui-primary),
    var(--sn-ui-primary-dark)
  ) !important;
  color: var(--sn-ui-text) !important;
  border: 1px solid var(--sn-ui-primary-dark) !important;
  border-radius: var(--sn-ui-radius) !important;
  box-shadow: none !important;
  text-shadow: none !important;
}
.tor-btn[disabled],
.sn-btn[disabled] {
  opacity: 0.65;
  cursor: not-allowed;
}
.sn-btn:hover,
button.sn-btn:hover,
a.sn-btn:hover,
.sn-btn-primary:hover,
.tor-btn:hover {
  filter: brightness(1.06);
}
.sn-btn--outline,
.sn-btn--ghost,
.tor-btn--outline {
  background: transparent !important;
  color: var(--sn-ui-text) !important;
  border: 1px solid var(--sn-ui-border) !important;
}
.tor-btn--sm,
.sn-btn--sm {
  min-height: 32px !important;
  padding: 0.35rem 0.62rem !important;
  font-size: 0.74rem !important;
  border-radius: calc(var(--sn-ui-radius) - 2px) !important;
}
.tor-tab,
.tor-std-tab,
.tor-res-tab,
.tor-reglamento-tab,
.tor-den-modal .den-tabs button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.45rem;
  min-height: 38px;
  padding: 0.48rem 0.9rem;
  border-radius: 999px !important;
  border: 1px solid var(--sn-ui-border) !important;
  background: var(--sn-ui-surface-2) !important;
  color: var(--sn-ui-text) !important;
  font-size: 0.78rem !important;
  font-weight: 600 !important;
  line-height: 1 !important;
  white-space: nowrap;
}
.tor-tab i,
.tor-std-tab i,
.tor-res-tab i,
.tor-reglamento-tab i,
.tor-den-modal .den-tabs button i {
  font-size: 0.95em;
}
.sn-tabs .sn-tab.active,
.sn-tabs-ses li.on,
.sn-menu-perfil-pilotos .sn-tabs a.active,
.tor-tabs .tor-tab.is-active,
.tor-tabs .tor-tab.on,
.tor-tabs .tor-tab.active,
.tor-std-tab.on,
.tor-std-tab.active,
.tor-res-tab.on,
.tor-res-tab.active,
.tor-reglamento-tab.on,
.tor-reglamento-tab.active,
.tor-den-modal .den-tabs button.on,
.tor-den-modal .den-tabs button.active,
.sn-f1-ranking .sn-f1-tab.is-active,
.sn-f1-ranking .sn-f1-cat-tab.is-active {
  background: linear-gradient(
    135deg,
    var(--sn-ui-primary),
    var(--sn-ui-primary-dark)
  ) !important;
  color: var(--sn-ui-text) !important;
  border-color: var(--sn-ui-primary-dark) !important;
}
.sn-tabs .sn-tab:not(.active),
.sn-tabs-ses li:not(.on),
.sn-menu-perfil-pilotos .sn-tabs a:not(.active),
.tor-tabs .tor-tab:not(.is-active),
.tor-tabs .tor-tab:not(.on):not(.active),
.tor-std-tab:not(.on):not(.active),
.tor-res-tab:not(.on):not(.active),
.tor-reglamento-tab:not(.on):not(.active),
.tor-den-modal .den-tabs button:not(.on) {
  background: var(--sn-ui-surface-2) !important;
  color: var(--sn-ui-text) !important;
  border-color: var(--sn-ui-border) !important;
}
.sn-modal-overlay,
.sn-modal-mask,
.tor-res-overlay,
.tor-std-overlay,
.sn-denuncias-overlay,
.sn-f1-modal,
.chat-modal {
  position: fixed !important;
  inset: 0 !important;
  display: none;
  align-items: center !important;
  justify-content: center !important;
}
.sn-modal-overlay.on,
.sn-modal-mask.on,
.tor-res-overlay.on,
.tor-std-overlay.on,
.sn-denuncias-overlay.on,
.sn-f1-modal:not([hidden]),
.chat-modal[style*="display: block"] {
  display: flex !important;
}
#tor-denuncias-modal-global {
  display: none !important;
}
#tor-denuncias-modal-global.on {
  display: flex !important;
}
.sn-modal__dialog,
.sn-modal.sn-modal-denuncia,
.sn-modal.sn-modal-resolver,
.sn-modal.sn-modal-ver,
.sn-modal.sn-modal-historial,
.tor-res-modal,
.tor-std-modal,
.pw-modal,
.sn-np-modal-content,
.sn-f1-modal-content,
.chat-modal-content {
  width: min(var(--sn-ui-modal-max), 96vw) !important;
  max-width: var(--sn-ui-modal-max) !important;
  margin: 0 auto !important;
  left: auto !important;
  right: auto !important;
  top: auto !important;
  transform: none !important;
}
.sn-table thead th,
.sn-table.sn-table--legacy .sn-legacy-head-row > th,
.tor-table thead th,
.sn-f1-table thead th,
.sn-f1-modal-table thead th,
.tor-den-table thead th,
.sn-aux-table thead th {
  background: #1a202b !important;
  color: var(--sn-ui-text) !important;
  border-color: var(--sn-ui-border) !important;
  font-size: var(--sn-ui-table-head-size) !important;
  font-weight: 700 !important;
  line-height: 1.2 !important;
  vertical-align: middle !important;
  text-transform: uppercase;
  letter-spacing: 0.02em;
}
.sn-table thead th i,
.sn-table.sn-table--legacy .sn-legacy-head-row > th i,
.tor-table thead th i,
.sn-f1-table thead th i,
.sn-f1-modal-table thead th i,
.tor-den-table thead th i,
.sn-aux-table thead th i {
  color: var(--sn-ui-primary) !important;
}
table.sn-table--legacy {
  width: 100% !important;
  border-collapse: collapse !important;
  background: #10151e !important;
  color: var(--sn-ui-text) !important;
  border: 1px solid var(--sn-ui-border) !important;
  border-radius: 14px !important;
  overflow: hidden !important;
}
table.sn-table--legacy th,
table.sn-table--legacy td {
  border: 1px solid var(--sn-ui-border) !important;
  padding: 0.72rem 0.78rem !important;
  font-size: 0.9rem !important;
  vertical-align: middle !important;
}
table.sn-table--legacy tbody tr:nth-child(odd) {
  background: rgba(255, 255, 255, 0.015) !important;
}
table.sn-table--legacy tbody tr:nth-child(even) {
  background: rgba(255, 255, 255, 0.035) !important;
}
table.sn-table--legacy tbody tr:hover {
  background: rgba(201, 13, 5, 0.08) !important;
}
.sn-head-cell .sn-th-inner {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.sn-head-cell .sn-th-label {
  white-space: nowrap;
}
.sn-head-cell .sn-th-icon,
.sn-table thead th i,
.tor-table thead th i,
.sn-f1-table thead th i,
.sn-f1-modal-table thead th i,
.tor-den-table thead th i,
.sn-aux-table thead th i {
  font-size: 0.92em !important;
  opacity: 0.95;
  flex: 0 0 auto;
}
.sn-close-icon,
.sn-modal__close,
.sn-modal-x,
.sn-f1-modal-close,
.tor-res-close,
.tor-std-close,
.pw-close,
.sn-tor-close,
.sn-ins-close,
.tor-panel-close {
  width: 38px;
  height: 38px;
  min-width: 38px;
  min-height: 38px;
  padding: 0 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  border-radius: 999px !important;
  border: 1px solid rgba(255, 255, 255, 0.1) !important;
  background: rgba(255, 255, 255, 0.04) !important;
  color: var(--sn-ui-text-soft, #ccd3df) !important;
  box-shadow: none !important;
  line-height: 1 !important;
}
.sn-close-icon i,
.sn-modal__close i,
.sn-modal-x i,
.sn-f1-modal-close i,
.tor-res-close i,
.tor-std-close i,
.pw-close i,
.sn-tor-close i,
.sn-ins-close i,
.tor-panel-close i {
  font-size: 1rem !important;
  pointer-events: none;
}
.sn-close-icon:hover,
.sn-modal__close:hover,
.sn-modal-x:hover,
.sn-f1-modal-close:hover,
.tor-res-close:hover,
.tor-std-close:hover,
.pw-close:hover,
.sn-tor-close:hover,
.sn-ins-close:hover,
.tor-panel-close:hover {
  background: rgba(201, 13, 5, 0.16) !important;
  border-color: rgba(201, 13, 5, 0.42) !important;
  color: #fff !important;
}
.tor-badge,
.tor-estado-badge,
.sn-tor-badge,
.tor-pill,
.estado,
.sancion {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.35rem;
  min-height: 28px;
  padding: 0.3rem 0.7rem;
  border-radius: 999px !important;
  border: 1px solid rgba(255, 255, 255, 0.12) !important;
  background: rgba(255, 255, 255, 0.06) !important;
  color: var(--sn-ui-text) !important;
  font-size: 0.74rem !important;
  font-weight: 600 !important;
  line-height: 1.1 !important;
  white-space: nowrap;
  vertical-align: middle;
}
.tor-badge i,
.tor-estado-badge i,
.sn-tor-badge i,
.tor-pill i,
.estado i,
.sancion i {
  font-size: 0.92em !important;
}
.sn-status,
.sn-estado,
.tor-badge.estado-en-curso,
.tor-badge.estado-programado,
.tor-badge.estado-finalizado,
.tor-badge.estado-completado,
.sn-tag-estado {
  border-radius: 999px;
  border: 1px solid transparent;
}
.sn-status--en-curso,
.sn-estado.en-proceso,
.estado-en-curso,
.tor-badge.estado-en-curso,
.sn-tag-estado.estado-en-curso {
  background: rgba(201, 13, 5, 0.16) !important;
  color: #ffd7d3 !important;
  border-color: rgba(201, 13, 5, 0.4) !important;
}
.sn-status--programado,
.estado-programado,
.tor-badge.estado-programado,
.sn-estado.revision {
  background: rgba(26, 118, 255, 0.15) !important;
  color: #d7e6ff !important;
  border-color: rgba(26, 118, 255, 0.4) !important;
}
.sn-status--finalizado,
.sn-status--completado,
.sn-estado.resuelta,
.estado-finalizado,
.estado-completado,
.tor-badge.estado-finalizado,
.tor-badge.estado-completado {
  background: rgba(23, 163, 74, 0.16) !important;
  color: #d5ffe6 !important;
  border-color: rgba(23, 163, 74, 0.4) !important;
}
.sn-status--warn,
.sn-estado.pendiente,
.estado-cancelado,
.estado-cancelada,
.estado-suspendido,
.estado-suspendida,
.estado-aplazado,
.estado-aplazada {
  background: rgba(255, 193, 7, 0.16) !important;
  color: #ffe8a6 !important;
  border-color: rgba(255, 193, 7, 0.4) !important;
}
.sn-estado.rechazada {
  background: rgba(201, 13, 5, 0.16) !important;
  color: #ffd7d3 !important;
  border-color: rgba(201, 13, 5, 0.4) !important;
}
}

@layer sn.core {
@media (max-width: 768px) {
  .tor-denuncias .tor-den-table {
    table-layout: fixed !important;
  }
  .tor-denuncias .tor-den-table th,
  .tor-denuncias .tor-den-table td {
    padding: 0.38rem 0.28rem !important;
    vertical-align: top;
  }
  .tor-denuncias .tor-den-table th {
    font-size: 0.62rem !important;
    line-height: 1.15 !important;
    white-space: normal !important;
    word-break: break-word;
  }
  .tor-denuncias .tor-den-table td {
    font-size: 0.66rem !important;
    line-height: 1.2 !important;
    white-space: normal !important;
    word-break: break-word;
  }
  .tor-denuncias .tor-den-table th i {
    display: none !important;
  }
  .tor-denuncias .tor-den-table .tor-btn {
    font-size: 0.62rem !important;
    padding: 0.3rem 0.48rem !important;
    min-height: 30px;
  }
  .sn-table thead th,
  .sn-table.sn-table--legacy .sn-legacy-head-row > th,
  .tor-table thead th,
  .sn-f1-table thead th,
  .sn-f1-modal-table thead th,
  .tor-den-table thead th,
  .sn-aux-table thead th {
    font-size: 0.74rem !important;
    letter-spacing: 0.015em !important;
  }
  .sn-head-cell .sn-th-inner {
    gap: 6px;
  }
  table.sn-table--legacy th,
  table.sn-table--legacy td {
    padding: 0.58rem 0.56rem !important;
    font-size: 0.8rem !important;
  }
  .sn-modal__dialog,
  .tor-res-modal,
  .tor-std-modal,
  .pw-modal,
  .sn-np-modal-content,
  .sn-f1-modal-content,
  .chat-modal-content {
    width: min(100vw - 18px, 100%) !important;
    max-height: calc(100vh - 18px) !important;
  }
  .sn-close-icon,
  .sn-modal__close,
  .sn-modal-x,
  .sn-f1-modal-close,
  .tor-res-close,
  .tor-std-close,
  .pw-close,
  .sn-tor-close,
  .sn-ins-close,
  .tor-panel-close {
    width: 40px;
    height: 40px;
    min-width: 40px;
    min-height: 40px;
  }
  .sn-chat-mobile #sn-chat-container {
    height: min(78vh, calc(100dvh - 120px)) !important;
    max-height: min(78vh, calc(100dvh - 120px)) !important;
    border-radius: 14px !important;
  }
  .sn-chat-mobile #sn-chat-container .sn-chat-header {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    min-height: 38px !important;
    padding: 6px 10px !important;
    background: linear-gradient(
      135deg,
      var(--sn-ui-primary),
      var(--sn-ui-primary-dark)
    ) !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12) !important;
    z-index: 5 !important;
  }
  .sn-chat-mobile #sn-chat-close,
  .sn-chat-mobile .sn-chat-close {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 30px !important;
    height: 30px !important;
    border-radius: 8px !important;
    background: rgba(255, 255, 255, 0.12) !important;
    color: #fff !important;
    border: 1px solid rgba(255, 255, 255, 0.2) !important;
    visibility: visible !important;
    opacity: 1 !important;
  }
  .sn-chat-mobile #sn-chat-container .sn-chat-mobile-wrapper {
    min-height: 0 !important;
    overflow: hidden !important;
  }
  .sn-chat-mobile #sn-chat-container [id^="nitro-chat-container-"],
  .sn-chat-mobile #sn-chat-container #nitro-chat-container {
    min-height: 0 !important;
    height: 100% !important;
  }
  .sn-tabs,
  .tor-tabs,
  .sn-tabs-ses {
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
  }
}
}

@layer sn.core {
.sn-denuncias-endurance {
  background: var(--sn-ui-bg) !important;
  border: 1px solid var(--sn-ui-border) !important;
  border-radius: 12px !important;
  color: var(--sn-ui-text) !important;
}
.sn-denuncias-endurance .sn-denuncias-tab {
  background: var(--sn-ui-surface-2) !important;
  color: var(--sn-ui-text) !important;
  border: 1px solid var(--sn-ui-border) !important;
  border-radius: var(--sn-ui-radius) !important;
}
.sn-denuncias-endurance .sn-denuncias-tab.active {
  background: linear-gradient(
    135deg,
    var(--sn-ui-primary),
    var(--sn-ui-primary-dark)
  ) !important;
  color: #fff !important;
  border-color: var(--sn-ui-primary-dark) !important;
}
.sn-denuncias-endurance .sn-btn,
.sn-denuncias-endurance .sn-btn-sm {
  background: linear-gradient(
    135deg,
    var(--sn-ui-primary),
    var(--sn-ui-primary-dark)
  ) !important;
  color: #fff !important;
  border: 1px solid var(--sn-ui-primary-dark) !important;
  border-radius: var(--sn-ui-radius) !important;
  box-shadow: none !important;
}
.sn-denuncias-endurance .sn-denuncias-table,
.sn-denuncias-endurance .sn-sanciones-table,
.sn-denuncias-endurance .sn-puntos-table,
.sn-denuncias-endurance .sn-historial-table {
  background: #0f1218 !important;
  border: 1px solid var(--sn-ui-border) !important;
}
.sn-denuncias-endurance .sn-table-wrap {
  width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
.sn-denuncias-endurance .sn-denuncias-table thead th,
.sn-denuncias-endurance .sn-sanciones-table thead th,
.sn-denuncias-endurance .sn-puntos-table thead th,
.sn-denuncias-endurance .sn-historial-table thead th {
  background: #1a202b !important;
  color: #fff !important;
  font-size: var(--sn-ui-table-head-size) !important;
  border-bottom: 1px solid var(--sn-ui-border) !important;
}
.sn-denuncias-endurance .sn-estado.en-proceso {
  background: rgba(201, 13, 5, 0.16) !important;
  color: #ffd7d3 !important;
  border: 1px solid rgba(201, 13, 5, 0.4) !important;
}
.sn-denuncias-endurance .sn-estado.resuelta {
  background: rgba(23, 163, 74, 0.16) !important;
  color: #d5ffe6 !important;
  border: 1px solid rgba(23, 163, 74, 0.4) !important;
}
html body #tor-root .tor-content .sn-table-wrap--tournament,
html body #tor-root .tor-content .tor-cal-card-body,
html body #tor-root .tor-content .tor-res-table-wrap,
html body #tor-root .tor-content .tor-std-table-wrap,
html body #tor-root .tor-content .tor-rally-table-wrap,
html body #tor-root .tor-content .tor-res-body,
html body #tor-root .tor-content .tor-std-body,
html body #tor-root .tor-content .tor-std-detail-wrap,
html body #tor-root .tor-content .tor-std-detail-inner,
html body #tor-root .tor-content .tor-standings-content,
html body #tor-root .tor-content .tor-denuncias .sn-table-wrap {
  overflow-x: auto !important;
  -webkit-overflow-scrolling: touch !important;
  max-width: 100% !important;
}
html body #tor-root .tor-content .sn-table--tournament,
html body #tor-root .tor-content .sn-table--tournament-calendar,
html body #tor-root .tor-content .sn-table--tournament-rally,
html body #tor-root .tor-content .tor-cal-table,
html body #tor-root .tor-content .tor-std-table,
html body #tor-root .tor-content .tor-std-detail-table,
html body #tor-root .tor-content .tor-res-table,
html body #tor-root .tor-content .tor-puntos-table,
html body #tor-root .tor-content .tor-sanciones-table,
html body #tor-root .tor-content .tor-rally-table {
  width: 100% !important;
  min-width: 680px !important;
  table-layout: auto !important;
  border-collapse: collapse !important;
}
html body #tor-root .tor-content .sn-table--tournament thead th,
html body #tor-root .tor-content .sn-table--tournament tbody td,
html body #tor-root .tor-content .sn-table--tournament-calendar thead th,
html body #tor-root .tor-content .sn-table--tournament-calendar tbody td,
html body #tor-root .tor-content .sn-table--tournament-rally thead th,
html body #tor-root .tor-content .sn-table--tournament-rally tbody td,
html body #tor-root .tor-content .tor-cal-table thead th,
html body #tor-root .tor-content .tor-std-table thead th,
html body #tor-root .tor-content .tor-std-detail-table thead th,
html body #tor-root .tor-content .tor-res-table thead th,
html body #tor-root .tor-content .tor-puntos-table thead th,
html body #tor-root .tor-content .tor-sanciones-table thead th,
html body #tor-root .tor-content .tor-rally-table thead th,
html body #tor-root .tor-content .tor-cal-table tbody td,
html body #tor-root .tor-content .tor-std-table tbody td,
html body #tor-root .tor-content .tor-std-detail-table tbody td,
html body #tor-root .tor-content .tor-res-table tbody td,
html body #tor-root .tor-content .tor-puntos-table tbody td,
html body #tor-root .tor-content .tor-sanciones-table tbody td,
html body #tor-root .tor-content .tor-rally-table tbody td {
  white-space: nowrap !important;
  word-break: normal !important;
  overflow-wrap: normal !important;
  vertical-align: middle !important;
}
html body #tor-root .tor-content .sn-table--tournament thead th,
html body #tor-root .tor-content .sn-table--tournament-calendar thead th,
html body #tor-root .tor-content .sn-table--tournament-rally thead th,
html body #tor-root .tor-content .tor-cal-table thead th,
html body #tor-root .tor-content .tor-std-table thead th,
html body #tor-root .tor-content .tor-std-detail-table thead th,
html body #tor-root .tor-content .tor-res-table thead th,
html body #tor-root .tor-content .tor-puntos-table thead th,
html body #tor-root .tor-content .tor-sanciones-table thead th,
html body #tor-root .tor-content .tor-rally-table thead th {
  font-size: 0.78rem !important;
  line-height: 1.2 !important;
  padding: 0.68rem 0.62rem !important;
}
html body #tor-root .tor-content .sn-table--tournament tbody td,
html body #tor-root .tor-content .sn-table--tournament-calendar tbody td,
html body #tor-root .tor-content .sn-table--tournament-rally tbody td,
html body #tor-root .tor-content .tor-cal-table tbody td,
html body #tor-root .tor-content .tor-std-table tbody td,
html body #tor-root .tor-content .tor-std-detail-table tbody td,
html body #tor-root .tor-content .tor-res-table tbody td,
html body #tor-root .tor-content .tor-puntos-table tbody td,
html body #tor-root .tor-content .tor-sanciones-table tbody td,
html body #tor-root .tor-content .tor-rally-table tbody td {
  font-size: 0.8rem !important;
  line-height: 1.28 !important;
  padding: 0.66rem 0.62rem !important;
}
html body #tor-root .tor-content .tor-cal-table .col-no,
html body #tor-root .tor-content .tor-cal-table .col-formato,
html body #tor-root .tor-content .tor-cal-table .col-estado-ronda {
  display: table-cell !important;
}
html body #tor-root .tor-content .sn-table--tournament .tor-btn,
html body #tor-root .tor-content .sn-table--tournament .tor-badge,
html body #tor-root .tor-content .tor-cal-table .tor-btn,
html body #tor-root .tor-content .tor-std-table .tor-btn,
html body #tor-root .tor-content .tor-std-detail-table .tor-btn,
html body #tor-root .tor-content .tor-res-table .tor-btn,
html body #tor-root .tor-content .tor-puntos-table .tor-btn,
html body #tor-root .tor-content .tor-sanciones-table .tor-btn,
html body #tor-root .tor-content .tor-rally-table .tor-btn,
html body #tor-root .tor-content .tor-cal-table .tor-badge,
html body #tor-root .tor-content .tor-std-table .tor-badge,
html body #tor-root .tor-content .tor-std-detail-table .tor-badge,
html body #tor-root .tor-content .tor-res-table .tor-badge {
  font-size: 0.74rem !important;
  min-height: 30px !important;
}
}

@layer sn.core {
@media (max-width: 768px) {
  html body #tor-root .tor-content .sn-table--tournament,
  html body #tor-root .tor-content .sn-table--tournament-calendar,
  html body #tor-root .tor-content .sn-table--tournament-rally,
  html body #tor-root .tor-content .tor-cal-table,
  html body #tor-root .tor-content .tor-std-table,
  html body #tor-root .tor-content .tor-std-detail-table,
  html body #tor-root .tor-content .tor-res-table,
  html body #tor-root .tor-content .tor-puntos-table,
  html body #tor-root .tor-content .tor-sanciones-table,
  html body #tor-root .tor-content .tor-rally-table {
    min-width: 620px !important;
  }
  html body #tor-root .tor-content .sn-table--tournament thead th,
  html body #tor-root .tor-content .sn-table--tournament-calendar thead th,
  html body #tor-root .tor-content .sn-table--tournament-rally thead th,
  html body #tor-root .tor-content .tor-cal-table thead th,
  html body #tor-root .tor-content .tor-std-table thead th,
  html body #tor-root .tor-content .tor-std-detail-table thead th,
  html body #tor-root .tor-content .tor-res-table thead th,
  html body #tor-root .tor-content .tor-puntos-table thead th,
  html body #tor-root .tor-content .tor-sanciones-table thead th,
  html body #tor-root .tor-content .tor-rally-table thead th {
    font-size: 0.72rem !important;
    padding: 0.56rem 0.48rem !important;
  }
  html body #tor-root .tor-content .sn-table--tournament tbody td,
  html body #tor-root .tor-content .sn-table--tournament-calendar tbody td,
  html body #tor-root .tor-content .sn-table--tournament-rally tbody td,
  html body #tor-root .tor-content .tor-cal-table tbody td,
  html body #tor-root .tor-content .tor-std-table tbody td,
  html body #tor-root .tor-content .tor-std-detail-table tbody td,
  html body #tor-root .tor-content .tor-res-table tbody td,
  html body #tor-root .tor-content .tor-puntos-table tbody td,
  html body #tor-root .tor-content .tor-sanciones-table tbody td,
  html body #tor-root .tor-content .tor-rally-table tbody td {
    font-size: 0.74rem !important;
    padding: 0.54rem 0.48rem !important;
  }
}
}

@layer sn.core {
:root {
  --sn-gap: 1rem;
  --sn-left-w: 180px;
  --sn-left-mini: 48px;
  --sn-right-w: 340px;
  --sn-bg: #0e0e0e;
  --sn-btn-bg: #2b2b2b;
  --sn-btn-bg-h: #383838;
  --sn-btn-fg: #d1d1d1;
  --sn-btn-fg-on: #fff;
  --sn-primary: #c90d05;
  --sn-radius: 6px;
}
.sn-wrapper {
  display: flex;
  flex-direction: column;
  gap: var(--sn-gap);
  box-sizing: border-box;
}
.sn-row-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sn-gap);
  padding-left: 0;
  padding-right: var(--sn-gap);
  box-sizing: border-box;
}
.sn-logo {
  width: var(--sn-left-w);
  height: 60px;
  background: #0e0e0e !important;
  border-radius: var(--sn-radius);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 0.2rem 0;
  box-sizing: border-box;
}
.sn-logo img {
  max-height: 32px;
  width: auto;
}
.sn-sim-name {
  margin-top: 0.2rem;
  font-size: 0.75rem;
  color: var(--sn-btn-fg);
  text-align: center;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  width: 100%;
}
.sn-menu-sup {
  flex: 1 1 auto;
  height: 60px;
  background: #0e0e0e;
  border-radius: var(--sn-radius);
  display: flex;
  align-items: center;
  gap: var(--sn-gap);
  padding: 0 1rem;
  box-sizing: border-box;
  overflow-x: auto;
  white-space: nowrap;
}
.sn-header-right {
  flex: 1 1 auto;
  height: 60px;
  background: #0e0e0e;
  border-radius: var(--sn-radius);
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: var(--sn-gap);
  padding: 0 1rem;
  box-sizing: border-box;
  overflow: hidden;
}
.sn-btn-top,
.sn-btn-left {
  display: flex;
  align-items: center;
  gap: 0.55rem;
  padding: 0.45rem 0.9rem;
  border: none;
  border-radius: var(--sn-radius);
  background: var(--sn-btn-bg);
  color: var(--sn-btn-fg);
  cursor: pointer;
  transition: background 0.2s;
  white-space: nowrap;
  box-sizing: border-box;
}
.sn-btn-top {
  height: 36px;
}
.sn-btn-top:hover,
.sn-btn-left:hover {
  background: var(--sn-btn-bg-h);
}
.sn-btn-top.on,
.sn-btn-left.on {
  background: var(--sn-primary);
  color: var(--sn-btn-fg-on);
}
.sn-btn-top svg,
.sn-btn-left svg {
  width: 18px;
  height: 18px;
  fill: currentColor;
}
.sn-menu-izq {
  width: var(--sn-left-w);
  display: flex;
  flex-direction: column;
  gap: 0.55rem;
  padding: var(--sn-gap) 0.5rem;
  background: #0e0e0e;
  border-radius: var(--sn-radius);
  box-sizing: border-box;
}
.sn-btn-left span {
  white-space: nowrap;
}
.sn-main {
  display: grid;
  gap: var(--sn-gap);
  grid-template-columns: var(--sn-left-w) 1fr var(--sn-right-w);
  box-sizing: border-box;
}
.sn-barra-lat-desktop {
  display: flex;
  flex-direction: column;
  gap: var(--sn-gap);
  box-sizing: border-box;
}
.sn-barra-lat-mobile {
  display: none;
  flex-direction: column;
  gap: var(--sn-gap);
  margin-top: var(--sn-gap);
  box-sizing: border-box;
}
.sn-chat-desktop {
  background: var(--sn-bg);
  border-radius: var(--sn-radius);
  margin-bottom: var(--sn-gap);
  overflow: hidden;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}
.sn-chat-mobile {
  position: fixed;
  bottom: calc(env(safe-area-inset-bottom, 0px) + 88px);
  right: calc(env(safe-area-inset-right, 0px) + 20px);
  z-index: 9999;
}
.sn-chat-toggle {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: var(--sn-grad-theme, linear-gradient(135deg, #c90d05, #8f0700));
  border: 1px solid var(--sn-theme-primary-accent, #820600);
  color: #fff;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.25);
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  position: relative;
}
.sn-chat-toggle:hover {
  transform: scale(1.05);
  box-shadow: 0 6px 25px rgba(0, 0, 0, 0.3);
}
.sn-chat-badge {
  position: absolute;
  top: -5px;
  right: -5px;
  background: #ff4757;
  color: #fff;
  border-radius: 50%;
  width: 20px;
  height: 20px;
  font-size: 12px;
  font-weight: bold;
  display: flex;
  align-items: center;
  justify-content: center;
  animation: sn-chat-pulse 2s infinite;
}
}

@layer sn.core {
@media (max-width: 991px) {
  .sn-chat-container {
    position: fixed !important;
    left: 8px !important;
    right: 8px !important;
    bottom: 0 !important;
    top: auto !important;
    width: auto !important;
    max-width: calc(100% - 16px) !important;
    height: 80vh !important;
    max-height: 80vh !important;
    margin: 0 !important;
    background: #0f1620 !important;
    border-radius: 18px !important;
    box-shadow: 0-2px 18px rgba(0, 0, 0, 0.4);
    display: flex !important;
    flex-direction: column !important;
    transform: translateY(100%);
    opacity: 0;
    visibility: hidden;
    transition:
      transform 0.28s ease,
      opacity 0.25s,
      bottom 0.25s;
    z-index: 10000;
  }
  .sn-chat-container.open {
    transform: translateY(0);
    opacity: 1;
    visibility: visible;
  }
  .sn-chat-header {
    flex: 0 0 auto !important;
    background: linear-gradient(135deg, #213245, #162330) !important;
    border-bottom: 1px solid #263544 !important;
    padding: 10px 14px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 8px;
    position: relative;
    z-index: 3;
  }
  .sn-chat-header h4 {
    font-size: 14px !important;
    margin: 0;
    flex: 1;
    font-weight: 600;
  }
  .sn-chat-mobile-wrapper {
    flex: 1 1 auto !important;
    display: flex !important;
    flex-direction: column !important;
    min-height: 0 !important;
    overflow: hidden !important;
  }
  .sn-chat-mobile-wrapper #nitro-chat-container {
    flex: 1 1 auto !important;
    display: flex !important;
    flex-direction: column !important;
    min-height: 0 !important;
    background: #0d1421 !important;
    border-radius: 0 !important;
  }
  .sn-chat-mobile-wrapper #nitro-chat-container .chat-header,
  .sn-chat-mobile-wrapper [id^="nitro-chat-container-"] .chat-header {
    display: none !important;
  }
  .sn-chat-mobile-wrapper #nitro-chat-container .chat-messages,
  .sn-chat-mobile-wrapper [id^="nitro-chat-container-"] .chat-messages {
    flex: 1 1 auto !important;
    min-height: 0 !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch;
    padding: 8px 10px !important;
    background: #0d1421 !important;
  }
  .sn-chat-mobile-wrapper #nitro-chat-container .chat-input-container,
  .sn-chat-mobile-wrapper [id^="nitro-chat-container-"] .chat-input-container {
    flex: 0 0 auto !important;
    display: block !important;
    background: var(--sn-color-surface, #151a22) !important;
    border-top: 1px solid var(--sn-color-border, #263544) !important;
    padding: 0 !important;
  }
  .sn-chat-mobile-wrapper #nitro-chat-container .chat-input-row,
  .sn-chat-mobile-wrapper [id^="nitro-chat-container-"] .chat-input-row {
    display: flex !important;
    gap: 8px !important;
    padding: 8px 10px !important;
    align-items: center;
  }
  .sn-chat-mobile-wrapper #nitro-chat-container .chat-message-input,
  .sn-chat-mobile-wrapper #nitro-chat-container #chat-message-input,
  .sn-chat-mobile-wrapper #nitro-chat-container [id^="chat-message-input-"],
  .sn-chat-mobile-wrapper [id^="nitro-chat-container-"] .chat-message-input,
  .sn-chat-mobile-wrapper
    [id^="nitro-chat-container-"]
    [id^="chat-message-input-"] {
    flex: 1 1 auto !important;
    min-height: 36px !important;
    border-radius: 16px !important;
    background: var(--sn-color-surface-alt, #243140) !important;
    border: 1px solid var(--sn-color-border, #3b4a59) !important;
    padding: 8px 12px !important;
    font-size: 14px !important;
    color: #e3e8ec !important;
  }
  .sn-chat-mobile-wrapper #nitro-chat-container .chat-send-btn,
  .sn-chat-mobile-wrapper #nitro-chat-container .send-message,
  .sn-chat-mobile-wrapper [id^="nitro-chat-container-"] .chat-send-btn,
  .sn-chat-mobile-wrapper [id^="nitro-chat-container-"] .send-message {
    background: var(
      --sn-grad-theme,
      linear-gradient(135deg, #c90d05, #8f0700)
    ) !important;
    color: #fff !important;
    border: 1px solid var(--sn-theme-primary-accent, #820600) !important;
    border-radius: 16px !important;
    padding: 8px 14px !important;
    font-size: 14px !important;
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
  }
  .sn-chat-close {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 32px !important;
    height: 32px !important;
    color: #fff !important;
  }
  .sn-chat-overlay {
    position: fixed;
    inset: 0;
    background: rgba(10, 14, 20, 0.55);
    backdrop-filter: blur(2px);
    z-index: 9998;
    display: none;
  }
  body.sn-chat-lock {
    overflow: hidden !important;
    position: static !important;
    width: auto !important;
    -webkit-tap-highlight-color: transparent;
    touch-action: auto;
  }
  .sn-chat-toggle.chat-open {
    transform: scale(0.01) !important;
    opacity: 0 !important;
    pointer-events: none !important;
  }
  .sn-chat-container.keyboard-open {
    bottom: var(--sn-kb-offset, 0) !important;
  }
  .sn-chat-container.keyboard-open .chat-messages {
    padding-bottom: calc(8px + var(--sn-kb-offset, 0)) !important;
  }
  body.sn-chat-lock [role="dialog"],
  body.sn-chat-lock .modal,
  body.sn-chat-lock .terms-modal,
  body.sn-chat-lock .sn-terms-container,
  body.sn-chat-lock .woocommerce-terms-and-conditions,
  body.sn-chat-lock #sn-terms-container,
  body .sn-terms-container,
  [role="dialog"].sn-terms,
  .terms-modal.sn-terms {
    position: fixed !important;
    top: 6vh !important;
    left: 8px !important;
    right: 8px !important;
    bottom: 6vh !important;
    max-height: calc(100vh - 12vh) !important;
    overflow: auto !important;
    -webkit-overflow-scrolling: touch !important;
    z-index: 11000 !important;
    background: #0f1620 !important;
    border-radius: 12px !important;
    padding: 12px !important;
    box-sizing: border-box !important;
    touch-action: pan-y !important;
  }
  body.sn-chat-lock [role="dialog"] .accept,
  body.sn-chat-lock .modal .accept,
  body.sn-chat-lock .terms-accept,
  body.sn-chat-lock .sn-terms-accept,
  body.sn-chat-lock .woocommerce-terms-and-conditions .button,
  body.sn-chat-lock .accept-button,
  body.sn-chat-lock button[data-action="accept"],
  body.sn-chat-lock button[name="accept"],
  body.sn-chat-lock input[type="submit"],
  .sn-terms .accept,
  .sn-terms .accept-button {
    position: sticky !important;
    bottom: 0 !important;
    display: block !important;
    width: calc(100% - 24px) !important;
    margin: 8px 12px 0 12px !important;
    z-index: 11010 !important;
    border-radius: 10px !important;
    box-shadow: 0-6px 18px rgba(0, 0, 0, 0.35);
    background-color: var(--sn-primary) !important;
    color: var(--sn-btn-fg-on) !important;
  }
  body.sn-chat-lock [role="dialog"] .modal-content,
  body.sn-chat-lock .modal .modal-content,
  body.sn-chat-lock .sn-terms-container > * {
    padding-bottom: 92px !important;
  }
  body.sn-chat-lock [role="dialog"] .modal-header,
  body.sn-chat-lock .modal .modal-header {
    position: sticky !important;
    top: 0 !important;
    z-index: 11011 !important;
    background: inherit !important;
  }
  .sn-chat-overlay {
    z-index: 10000;
  }
}
}

@layer sn.core {
.sn-chat-toggle.chat-open {
  transform: translateY(60px) scale(0.8);
  opacity: 0.7;
}
.sn-chat-toggle.chat-open:hover {
  transform: translateY(60px) scale(0.85);
}
}

@layer sn.core {
@media (max-width: 991px) {
  .sn-chat-mobile {
    bottom: calc(env(safe-area-inset-bottom, 0px) + 88px);
    right: calc(env(safe-area-inset-right, 0px) + 18px);
  }
}
}

@layer sn.core {
@media (max-width: 480px) {
  .sn-chat-mobile {
    bottom: calc(env(safe-area-inset-bottom, 0px) + 104px);
    right: calc(env(safe-area-inset-right, 0px) + 10px);
  }
}
}

@layer sn.core {
@media (min-width: 992px) {
  .sn-chat-desktop {
    display: block !important;
  }
  .sn-chat-mobile {
    display: none !important;
  }
  .sn-barra-lat-desktop {
    display: flex;
  }
  .sn-barra-lat-mobile {
    display: none;
  }
}
}

@layer sn.core {
@media (max-width: 991px) {
  .sn-barra-lat-desktop {
    display: none;
  }
  .sn-barra-lat-mobile {
    display: flex;
  }
}
}

@layer sn.core {
.sn-header-mobile {
  display: none;
}
.sn-header-desktop,
.sn-menu-izq-desktop {
  display: flex;
}
.sn-menu-izq-mobile {
  display: none;
}
}

@layer sn.core {
@media (max-width: 600px) {
  .sn-header-desktop {
    display: none !important;
  }
  .sn-header-mobile {
    display: block;
    width: 100%;
  }
  .sn-row-top {
    flex-direction: column;
    align-items: stretch;
    gap: 0;
    padding: 0;
    background: none;
  }
  .sn-header-bar-mobile {
    display: flex;
    align-items: center;
    background: #0e0e0e;
    border-radius: var(--sn-radius);
    height: 48px;
    margin: 0 0 2px 0;
    padding: 0 0.3rem;
    width: 100%;
    box-sizing: border-box;
  }
  .sn-logo {
    width: 44px;
    min-width: 44px;
    max-width: 44px;
    height: 44px;
    background: none;
    border-radius: 0;
    margin: 0;
    padding: 0;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .sn-logo img {
    max-height: 26px;
  }
  .sn-sim-name {
    display: none;
  }
  .sn-header-right {
    flex: 1 1 auto;
    height: 44px;
    background: none;
    padding: 0 0.2rem;
    gap: 0.3rem;
    margin-left: 0.5rem;
  }
  .sn-menu-sup {
    height: 44px;
    padding: 0 0.2rem;
    background: #0e0e0e;
    gap: 0.2rem;
    overflow-x: auto;
  }
  .sn-menu-izq-desktop {
    display: none !important;
  }
  .sn-menu-izq-mobile {
    display: flex !important;
    flex-direction: row;
    width: 100%;
    height: 44px;
    padding: 0 0.2rem;
    background: #0e0e0e;
    border-radius: var(--sn-radius);
    align-items: center;
    gap: 0.2rem;
    overflow-x: auto;
    white-space: nowrap;
    position: relative;
    z-index: 2;
  }
  .sn-btn-left {
    justify-content: center;
    padding: 0.4rem 0.7rem;
    min-height: 34px;
    height: 34px;
    background: var(--sn-btn-bg);
  }
  .sn-btn-left.on {
    background: var(--sn-primary);
    color: var(--sn-btn-fg-on);
  }
  .sn-btn-left svg {
    width: 17px;
    height: 17px;
  }
  .sn-header-mobile,
  .sn-menu-sup,
  .sn-menu-izq-mobile,
  .sn-content,
  .sn-banner {
    margin-top: 0 !important;
    margin-bottom: 0 !important;
  }
  .sn-menu-sup,
  .sn-menu-izq-mobile {
    min-height: 44px !important;
    max-height: 44px !important;
    line-height: 44px !important;
  }
  .sn-content {
    padding-left: 0.1rem !important;
    padding-right: 0.1rem !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
  }
  .sn-wrapper {
    margin-left: 0.1rem !important;
    margin-right: 0.1rem !important;
    margin-top: 0 !important;
    padding: 0 !important;
  }
  .sn-main {
    grid-template-columns: 1fr;
    gap: 0.18rem;
  }
  .sn-barra-lat-desktop {
    display: none !important;
  }
  .sn-barra-lat-mobile {
    display: flex !important;
  }
}
}

@layer sn.core {
@media (max-width: 700px) {
  #sn-eventos-container,
  #sn-eventos-container .sn-wrapper {
    padding: 0 !important;
    margin: 0 !important;
    width: 100% !important;
    box-sizing: border-box !important;
    background: none !important;
  }
  #sn-eventos-container .sn-panel,
  #sn-eventos-container .sn-serie {
    padding: 0 !important;
    margin: 0 !important;
    width: 100% !important;
    box-sizing: border-box !important;
  }
}
}

@layer sn.core {
.sn-chat-close {
  background: none;
  border: none;
  color: #fff;
  cursor: pointer;
  padding: 2px;
  border-radius: 4px;
  transition: background-color 0.2s;
  width: 24px;
  height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.sn-chat-close svg {
  width: 16px;
  height: 16px;
}
.sn-chat-close:hover {
  background-color: rgba(255, 255, 255, 0.1);
}
}

@layer sn.core {
@media (max-width: 991px) {
  #sn-chat-container .chat-header {
    display: none !important;
  }
}
}

@layer sn.core {
@media (max-width: 991px) {
  .sn-chat-container.sn-has-terms {
    overflow: hidden !important;
    touch-action: none !important;
  }
  .sn-terms-modal-fix {
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    width: 100% !important;
    height: 100% !important;
    max-height: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    background: #0f1620 !important;
    z-index: 12050 !important;
    display: flex !important;
    flex-direction: column !important;
    overflow: hidden !important;
    border-radius: 18px 18px 0 0;
  }
  .sn-terms-modal-fix * {
    -webkit-overflow-scrolling: touch;
  }
  .sn-terms-modal-fix .sn-terms-scroll-area {
    flex: 1 1 auto;
    overflow-y: auto !important;
    overscroll-behavior: contain;
    padding: 18px 18px 160px;
    scrollbar-width: thin;
  }
  .sn-terms-modal-fix .sn-terms-float-bar {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    padding: 14px 16px calc(14px + env(safe-area-inset-bottom));
    background: linear-gradient(
      180deg,
      transparent 0%,
      rgba(15, 22, 32, 0.9) 25%,
      #0f1620 90%
    );
    display: flex;
    gap: 10px;
    z-index: 12060;
  }
  .sn-terms-modal-fix .sn-terms-float-bar button,
  .sn-terms-modal-fix .sn-terms-float-bar .accept,
  .sn-terms-modal-fix .sn-terms-float-bar .agree,
  .sn-terms-modal-fix .sn-terms-float-bar input[type="submit"] {
    flex: 1 1 auto;
    background: var(--sn-primary) !important;
    color: #fff !important;
    border: none;
    border-radius: 12px;
    padding: 0.9rem 1rem;
    font-weight: 600;
    font-size: 15px;
    line-height: 1.1;
    cursor: pointer;
  }
  .sn-terms-modal-fix .sn-terms-float-bar .sn-terms-secondary {
    background: #2d3a46 !important;
  }
  body.sn-no-scroll {
    overflow: hidden !important;
    touch-action: none !important;
  }
}
}

@layer sn.core {
@media (max-width: 991px) {
  .sn-terms-lock-overlay {
    position: fixed !important;
    inset: 0 !important;
    background: rgba(0, 0, 0, 0.55);
    backdrop-filter: blur(2px);
    z-index: 12040 !important;
    touch-action: none !important;
  }
  body.sn-no-scroll-fixed {
    position: fixed !important;
    width: 100% !important;
    overflow: hidden !important;
    overscroll-behavior: none !important;
    touch-action: none !important;
  }
}
}

@layer sn.core {
body.page-template-simulador {
  --sn-sim-max: 1620px;
  background: #090d15;
  color: #f3f5fb;
}
body.page-template-simulador .sn-wrapper {
  max-width: var(--sn-sim-max);
  margin: 24px auto 64px;
  padding: 30px 34px 46px;
  border-radius: 32px;
  background:
    radial-gradient(
      circle at 15% 20%,
      rgba(255, 255, 255, 0.05),
      transparent 55%
    ),
    radial-gradient(circle at 85% 0%, rgba(201, 13, 5, 0.15), transparent 55%),
    linear-gradient(145deg, #03060b, #101724 65%, #070a11);
  box-shadow: 0 25px 55px rgba(0, 0, 0, 0.65);
}
body.page-template-simulador .sn-row-top {
  background: linear-gradient(135deg, #0d121f, #05070d);
  border-radius: 22px;
  padding: 18px 20px;
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.04);
  gap: 1.2rem;
  flex-wrap: wrap;
}
body.page-template-simulador .sn-menu-sup,
body.page-template-simulador .sn-header-right {
  background:
    radial-gradient(
      circle at 5% 15%,
      rgba(255, 255, 255, 0.08),
      transparent 55%
    ),
    linear-gradient(135deg, rgba(15, 20, 32, 0.94), rgba(8, 11, 18, 0.98));
  border-radius: 18px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  padding: 0.4rem 0.9rem;
  min-height: 60px;
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.03),
    0 14px 30px rgba(0, 0, 0, 0.45);
}
body.page-template-simulador .sn-main {
  background: linear-gradient(
    145deg,
    rgba(7, 10, 17, 0.95),
    rgba(5, 7, 12, 0.96)
  );
  border-radius: 26px;
  padding: 26px;
  border: 1px solid rgba(255, 255, 255, 0.05);
  box-shadow: 0 20px 45px rgba(0, 0, 0, 0.6);
  grid-template-columns: clamp(170px, 13vw, 210px) minmax(0, 1fr) clamp(
      240px,
      18vw,
      300px
    );
  gap: 18px;
  align-items: flex-start;
}
body.page-template-simulador .sn-menu-izq,
body.page-template-simulador .sn-barra-lat-desktop > *,
body.page-template-simulador .sn-chat-desktop {
  background: linear-gradient(
    160deg,
    rgba(17, 23, 39, 0.95),
    rgba(6, 9, 16, 0.98)
  );
  border-radius: 18px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  box-shadow: 0 18px 38px rgba(0, 0, 0, 0.45);
}
body.page-template-simulador .sn-menu-izq {
  padding: 20px 14px;
  min-height: 100%;
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
}
body.page-template-simulador .sn-content {
  background: linear-gradient(
    135deg,
    rgba(15, 20, 32, 0.95),
    rgba(9, 12, 20, 0.98)
  );
  border-radius: 22px;
  border: 1px solid rgba(255, 255, 255, 0.07);
  padding: 22px 24px;
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.02),
    0 14px 32px rgba(0, 0, 0, 0.45);
  color: #f1f3ff;
  width: 100%;
  min-width: 0;
}
#sn-root .sn-content {
  width: 100%;
  min-width: 0;
}
body.page-template-simulador .sn-barra-lat-desktop {
  gap: 1rem;
}
body.page-template-simulador .sn-chat-desktop,
body.page-template-simulador #sn-chat-desktop {
  width: 100%;
  min-height: 520px;
  display: flex;
  flex-direction: column;
}
body.page-template-simulador #sn-chat-desktop .sn-chat-item {
  flex: 1 1 auto;
  padding: 0;
}
body.page-template-simulador .sn-chat-desktop .chat-header {
  background: #c90d05;
  color: #fff;
}
body.page-template-simulador .sn-chat-desktop .chat-send-btn {
  border-radius: 999px;
}
body.page-template-simulador .sn-btn-top,
body.page-template-simulador .sn-btn-left {
  border-radius: 999px;
  font-weight: 600;
  box-shadow: 0 8px 18px rgba(0, 0, 0, 0.35);
}
body.page-template-simulador .sn-btn-top.on,
body.page-template-simulador .sn-btn-left.on {
  box-shadow: 0 14px 30px rgba(201, 13, 5, 0.45);
}
body.page-template-simulador .sn-content .torneo-card {
  background: #0c101a;
  border-radius: 16px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.45);
  color: #f0f4ff;
}
body.page-template-simulador .sn-content .torneo-card-btn {
  background: var(--sn-grad-theme, linear-gradient(135deg, #c90d05, #8f0a05));
  color: #fff;
  padding: 0.45rem 1.4rem;
  border-radius: 999px;
  font-weight: 600;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
body.page-template-simulador .sn-content .torneo-card-btn:hover {
  filter: brightness(1.05);
}
body.page-template-simulador .sn-no-events,
body.page-template-simulador .sn-content .tor-slider-anon {
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.05);
  border-radius: 16px;
  color: #f6f8ff;
}
body.page-template-simulador .sn-torneo-sliders {
  margin-bottom: 18px;
}
body.page-template-simulador .sn-content .tor-sc-wrap,
body.page-template-simulador .sn-content .sn-eventos-simulador,
body.page-template-simulador .sn-content .torneo-slider-container,
body.page-template-simulador .sn-content .torneo-cards-wrapper {
  width: 100%;
  max-width: 100%;
}
body.page-template-simulador .sn-content .sn-msg,
body.page-template-simulador .sn-content .sn-login-required,
body.page-template-simulador .sn-content .chat-login-required,
body.page-template-simulador .sn-content .sn-menu-superior-piloto-logged-out {
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 18px;
  padding: 16px 20px;
  color: #f5f7ff;
  text-align: left;
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.02);
}
body.page-template-simulador .sn-content .sn-menu-superior-piloto-logged-out,
.sn-menu-superior-piloto-logged-out {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  -moz-column-gap: 12px;
       column-gap: 12px;
  row-gap: 0;
  flex-wrap: nowrap !important;
}
body.page-template-simulador
  .sn-content
  .sn-menu-superior-piloto-logged-out
  .sn-guest-card__icon,
.sn-menu-superior-piloto-logged-out .sn-guest-card__icon {
  width: 42px;
  height: 42px;
  border-radius: 12px;
  margin: 0;
  flex: 0 0 42px;
}
body.page-template-simulador
  .sn-content
  .sn-menu-superior-piloto-logged-out
  .sn-guest-card__body,
.sn-menu-superior-piloto-logged-out .sn-guest-card__body {
  min-width: 0;
  flex: none;
}
body.page-template-simulador
  .sn-content
  .sn-menu-superior-piloto-logged-out
  .sn-guest-card__title,
.sn-menu-superior-piloto-logged-out .sn-guest-card__title {
  margin: 0 0 2px;
  font-size: 0.95rem;
  line-height: 1.15;
}
body.page-template-simulador
  .sn-content
  .sn-menu-superior-piloto-logged-out
  .sn-guest-card__text,
.sn-menu-superior-piloto-logged-out .sn-guest-card__text {
  margin: 0;
  font-size: 0.8rem;
  line-height: 1.2;
  color: rgba(255, 255, 255, 0.78);
}
body.page-template-simulador
  .sn-content
  .sn-menu-superior-piloto-logged-out
  .sn-btn,
.sn-menu-superior-piloto-logged-out .sn-btn {
  min-width: 110px;
  width: auto;
  margin-left: auto;
  white-space: nowrap;
}
.whb-general-header .wd-header-text.reset-last-child,
.whb-general-header .wd-header-text.reset-last-child > p[style] {
  width: 100%;
  margin: 0;
}
.whb-general-header .wd-header-text .sn-menu-superior-piloto-logged-out {
  width: 100%;
  max-width: none;
  display: grid !important;
  grid-template-columns: 38px minmax(0, 1fr) auto;
  align-items: center;
  -moz-column-gap: 12px;
       column-gap: 12px;
  row-gap: 0;
  padding: 10px 14px;
  border-radius: 14px;
}
.whb-general-header
  .wd-header-text
  .sn-menu-superior-piloto-logged-out
  .sn-guest-card__icon {
  width: 38px;
  height: 38px;
  border-radius: 12px;
  font-size: 1rem;
}
.whb-general-header
  .wd-header-text
  .sn-menu-superior-piloto-logged-out
  .sn-guest-card__body {
  min-width: 0;
  display: block;
  overflow: hidden;
}
.whb-general-header
  .wd-header-text
  .sn-menu-superior-piloto-logged-out
  .sn-guest-card__message {
  display: block;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.whb-general-header
  .wd-header-text
  .sn-menu-superior-piloto-logged-out
  .sn-guest-card__title {
  display: inline;
  margin: 0;
  font-size: 0.9rem;
  line-height: 1.1;
  font-weight: 700;
}
.whb-general-header
  .wd-header-text
  .sn-menu-superior-piloto-logged-out
  .sn-guest-card__sep {
  display: inline-block;
  margin: 0 8px;
  color: rgba(255, 255, 255, 0.36);
}
.whb-general-header
  .wd-header-text
  .sn-menu-superior-piloto-logged-out
  .sn-guest-card__text {
  display: inline;
  margin: 0;
  font-size: 0.78rem;
  line-height: 1.15;
  color: rgba(255, 255, 255, 0.78);
}
.whb-general-header
  .wd-header-text
  .sn-menu-superior-piloto-logged-out
  .sn-btn {
  min-width: 100px;
  min-height: 38px;
  border-radius: 12px !important;
  box-shadow: 0 10px 22px rgba(201, 13, 5, 0.28);
}
}

@layer sn.core {
@media (max-width: 640px) {
  body.page-template-simulador .sn-content .sn-menu-superior-piloto-logged-out,
  .sn-menu-superior-piloto-logged-out {
    grid-template-columns: 36px minmax(0, 1fr) auto;
    -moz-column-gap: 10px;
         column-gap: 10px;
    padding: 12px 14px;
  }
  body.page-template-simulador
    .sn-content
    .sn-menu-superior-piloto-logged-out
    .sn-guest-card__icon,
  .sn-menu-superior-piloto-logged-out .sn-guest-card__icon {
    width: 36px;
    height: 36px;
    border-radius: 10px;
    flex-basis: 36px;
    font-size: 0.95rem;
  }
  body.page-template-simulador
    .sn-content
    .sn-menu-superior-piloto-logged-out
    .sn-guest-card__title,
  .sn-menu-superior-piloto-logged-out .sn-guest-card__title {
    font-size: 0.85rem;
  }
  body.page-template-simulador
    .sn-content
    .sn-menu-superior-piloto-logged-out
    .sn-guest-card__text,
  .sn-menu-superior-piloto-logged-out .sn-guest-card__text {
    font-size: 0.73rem;
  }
  body.page-template-simulador
    .sn-content
    .sn-menu-superior-piloto-logged-out
    .sn-btn,
  .sn-menu-superior-piloto-logged-out .sn-btn {
    min-width: 92px;
    padding-inline: 12px !important;
  }
  .whb-general-header .wd-header-text .sn-menu-superior-piloto-logged-out {
    grid-template-columns: 34px minmax(0, 1fr) auto;
    -moz-column-gap: 10px;
         column-gap: 10px;
    padding: 8px 10px;
  }
  .whb-general-header
    .wd-header-text
    .sn-menu-superior-piloto-logged-out
    .sn-guest-card__icon {
    width: 34px;
    height: 34px;
    border-radius: 10px;
  }
  .whb-general-header
    .wd-header-text
    .sn-menu-superior-piloto-logged-out
    .sn-guest-card__title {
    font-size: 0.82rem;
  }
  .whb-general-header
    .wd-header-text
    .sn-menu-superior-piloto-logged-out
    .sn-guest-card__sep {
    margin: 0 6px;
  }
  .whb-general-header
    .wd-header-text
    .sn-menu-superior-piloto-logged-out
    .sn-guest-card__text {
    font-size: 0.7rem;
  }
  .whb-general-header
    .wd-header-text
    .sn-menu-superior-piloto-logged-out
    .sn-btn {
    min-width: 84px;
    min-height: 34px;
    padding-inline: 10px !important;
  }
}
}

@layer sn.core {
body.page-template-simulador .sn-content .sn-msg a,
body.page-template-simulador .sn-content .sn-login-required a {
  color: #fff;
  font-weight: 600;
  text-decoration: underline;
}
body.page-template-simulador .sn-content .sn-msg.sn-err {
  background: linear-gradient(135deg, #4a1111, #1c0606);
  border-color: rgba(255, 86, 86, 0.45);
}
body.page-template-simulador .sn-content .sn-msg.sn-info {
  background: linear-gradient(135deg, #0d2338, #08121f);
  border-color: rgba(46, 140, 240, 0.45);
}
body.page-template-simulador .tor-tabs,
body.page-template-simulador #tor-tabs {
  background: rgba(8, 12, 21, 0.92);
  border-radius: 18px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  padding: 10px;
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.03),
    0 12px 26px rgba(0, 0, 0, 0.4);
}
body.page-template-simulador .tor-tabs .tor-tab {
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.07);
  border-radius: 999px;
  color: rgba(255, 255, 255, 0.85);
  font-weight: 600;
}
body.page-template-simulador .tor-tabs .tor-tab.on {
  background: var(--sn-grad-theme, linear-gradient(135deg, #c90d05, #8f0a05));
  color: #fff;
  border-color: rgba(255, 255, 255, 0.15);
  box-shadow: 0 6px 16px rgba(201, 13, 5, 0.35);
}
#sn-root.sn-wrapper {
  max-width: 1620px;
  margin: 24px auto 64px;
  padding: 30px 34px 46px;
  border-radius: 32px;
  background:
    radial-gradient(
      circle at 15% 20%,
      rgba(255, 255, 255, 0.05),
      transparent 55%
    ),
    radial-gradient(circle at 85% 0%, rgba(201, 13, 5, 0.15), transparent 55%),
    linear-gradient(145deg, #03060b, #101724 65%, #070a11);
  box-shadow: 0 25px 55px rgba(0, 0, 0, 0.65);
}
#sn-root .sn-row-top {
  background: linear-gradient(135deg, #0d121f, #05070d);
  border-radius: 22px;
  padding: 18px 20px;
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.04);
  gap: 1.2rem;
  flex-wrap: wrap;
}
#sn-root .sn-menu-sup,
#sn-root .sn-header-right {
  background:
    radial-gradient(
      circle at 5% 15%,
      rgba(255, 255, 255, 0.08),
      transparent 55%
    ),
    linear-gradient(135deg, rgba(15, 20, 32, 0.94), rgba(8, 11, 18, 0.98));
  border-radius: 18px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  padding: 0.4rem 0.9rem;
  min-height: 60px;
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.03),
    0 14px 30px rgba(0, 0, 0, 0.45);
}
#sn-root .sn-btn-top,
#sn-root .sn-btn-left {
  border-radius: 999px;
  font-weight: 600;
  box-shadow: 0 8px 18px rgba(0, 0, 0, 0.35);
}
#sn-root .sn-btn-top.on,
#sn-root .sn-btn-top.active,
#sn-root .sn-btn-left.on,
#sn-root .sn-btn-left.active {
  box-shadow: 0 14px 30px rgba(201, 13, 5, 0.45);
}
#sn-root .sn-main {
  background: linear-gradient(
    145deg,
    rgba(7, 10, 17, 0.95),
    rgba(5, 7, 12, 0.96)
  );
  border-radius: 26px;
  padding: 26px;
  border: 1px solid rgba(255, 255, 255, 0.05);
  box-shadow: 0 20px 45px rgba(0, 0, 0, 0.6);
  display: grid;
  gap: 18px;
  align-items: flex-start;
}
#sn-root .sn-menu-izq,
#sn-root .sn-barra-lat-desktop > *,
#sn-root .sn-chat-desktop {
  background: linear-gradient(
    160deg,
    rgba(13, 17, 27, 0.96),
    rgba(5, 7, 12, 0.98)
  );
  border-radius: 18px;
  border: 1px solid rgba(255, 255, 255, 0.06);
  box-shadow: 0 18px 38px rgba(0, 0, 0, 0.45);
}
#sn-root .sn-menu-izq {
  padding: 20px 14px;
  min-height: 100%;
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
}
#sn-root .sn-content {
  background: linear-gradient(
    135deg,
    rgba(15, 20, 32, 0.95),
    rgba(9, 12, 20, 0.98)
  );
  border-radius: 22px;
  border: 1px solid rgba(255, 255, 255, 0.07);
  padding: 22px 24px;
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.02),
    0 14px 32px rgba(0, 0, 0, 0.45);
  color: #f1f3ff;
}
#sn-root .sn-barra-lat-desktop {
  gap: 1rem;
}
#sn-root .sn-chat-desktop,
#sn-root #sn-chat-desktop {
  width: 100%;
  min-height: 520px;
  display: flex;
  flex-direction: column;
}
body.page-template-simulador .sn-main.no-left-menu {
  grid-template-columns: minmax(0, 1fr) clamp(240px, 18vw, 300px) !important;
}
#sn-root .sn-main.no-left-menu {
  grid-template-columns: minmax(0, 1fr) var(--sn-right-w, 300px) !important;
}
}

@layer sn.core {
@media (max-width: 991px) {
  body.page-template-simulador .sn-main,
  #sn-root .sn-main {
    grid-template-columns: 1fr;
    gap: 0.18rem;
  }
}
}

@layer sn.core {
#sn-root #sn-chat-desktop .sn-chat-item {
  flex: 1 1 auto;
  padding: 0;
}
#sn-root .sn-chat-desktop .chat-header {
  background: #c90d05;
  color: #fff;
}
#sn-root .sn-chat-desktop .chat-send-btn {
  border-radius: 999px;
}
#sn-root .torneo-slider {
  max-width: 100% !important;
}
:root {
  --tr-gap: 1rem;
  --tr-bg: #0e0e0e;
  --tr-bg2: #151515;
  --tr-fg: #d6d6d6;
  --tr-primary: #c90d05;
  --tr-r: 8px;
  --tr-font: 16px;
  --tor-panel-w: 360px;
  --tor-surface: #11151d;
  --tor-surface-alt: #191f28;
  --tor-panel-surface: #0c1016;
  --tor-border-soft: rgba(255, 255, 255, 0.05);
  --tor-border-strong: rgba(255, 255, 255, 0.12);
}
html:root {
  --tr-bg: var(--sn-surface-1, #0e0e0e);
  --tr-bg2: var(--sn-surface-2, #151515);
  --tr-fg: var(--sn-text, #d6d6d6);
  --tr-primary: var(--sn-theme-primary, #c90d05);
  --tr-r: var(--sn-radius-lg, 8px);
}
body .tor-wrapper {
  background:
    linear-gradient(135deg, rgba(11, 13, 17, 0.95), rgba(9, 10, 14, 0.98)),
    #090b0f;
  padding: 24px;
  border-radius: 18px;
  box-shadow: 0 18px 45px rgba(0, 0, 0, 0.55);
}
body .tor-header {
  background: linear-gradient(135deg, #10141c, #0c0f15);
  border: 1px solid var(--tor-border-strong);
  border-radius: 18px;
  padding: 16px 22px;
  min-height: 0;
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.03),
    0 12px 32px rgba(0, 0, 0, 0.45);
}
.tor-content {
  color: #e4e8f5;
}
.tor-content,
.sn-pitwall,
.tor-panel .sn-panel__section,
.tor-panel,
.sn-panel,
.tor-panel-card,
.sn-chat-desktop,
.sn-pw-next,
.pw-card,
.pw-card .pw-card-body,
.sn-pitwall .pw-card {
  background: var(--tor-surface);
  border-radius: 18px;
  border: 1px solid var(--tor-border-soft);
  box-shadow: 0 10px 35px rgba(0, 0, 0, 0.45);
}
.tor-panel {
  background: var(--tor-panel-surface);
  border: 1px solid rgba(201, 13, 5, 0.25);
  box-shadow: 0 15px 45px rgba(0, 0, 0, 0.5);
}
.tor-panel .sn-panel__section {
  border: 1px solid rgba(255, 255, 255, 0.02);
  background: rgba(255, 255, 255, 0.02);
  padding: 18px;
  border-radius: 14px;
  margin-bottom: 16px;
}
.tor-panel .sn-panel__section:last-child {
  margin-bottom: 0;
}
.tor-panel .sn-panel__header {
  font-weight: 700;
  letter-spacing: 0.03em;
  color: #f1f4ff;
}
.tor-panel .sn-panel__meta {
  color: rgba(255, 255, 255, 0.65);
  font-size: 0.75rem;
}
body .tor-badges {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px 12px;
  width: 100%;
  margin-top: 8px;
}
body .tor-badges .tor-badge {
  padding: 0.4rem 0.9rem;
  min-height: 0;
  border-radius: 999px;
  background: linear-gradient(
    145deg,
    rgba(27, 32, 45, 0.92),
    rgba(18, 22, 32, 0.92)
  );
  border: 1px solid rgba(255, 255, 255, 0.05);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.02);
  align-items: center;
  flex-direction: row;
  justify-content: flex-start;
  position: relative;
  overflow: hidden;
}
body .tor-badges .tor-badge strong {
  font-size: 0.68rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: rgba(255, 255, 255, 0.72);
  margin: 0;
}
body .tor-badges .tor-badge span,
body .tor-badges .tor-badge > div {
  font-size: 0.88rem;
  font-weight: 600;
  color: #f5f7fb;
}
.tor-badges .tor-badge i {
  color: rgba(255, 255, 255, 0.9);
  margin-right: 6px;
}
.tor-tabs {
  background: rgba(17, 23, 32, 0.85);
  border: 1px solid rgba(255, 255, 255, 0.04);
  border-radius: 14px;
  padding: 10px;
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.02);
}
.tor-tab,
.tor-tabs .sn-tab {
  background: var(--tor-surface-alt);
  border: 1px solid rgba(255, 255, 255, 0.04);
  color: #cad2ea;
}
.tor-tab.on,
.tor-tabs .sn-tab.active {
  background: linear-gradient(
    135deg,
    rgba(201, 13, 5, 0.95),
    rgba(121, 8, 2, 0.95)
  );
  border-color: rgba(255, 86, 78, 0.6);
  box-shadow: 0 12px 22px rgba(201, 13, 5, 0.35);
  color: #fff;
}
.tor-badge {
  background: rgba(25, 31, 40, 0.75);
  border-color: rgba(255, 255, 255, 0.07);
  color: #d7def0;
}
.tor-content table {
  background: rgba(9, 11, 17, 0.7);
  border: 1px solid rgba(255, 255, 255, 0.02);
}
.sn-pitwall .pw-card,
.sn-pitwall .pw-card-body,
.sn-pitwall .sn-pw-next {
  background: rgba(13, 18, 28, 0.9);
  border: 1px solid rgba(255, 255, 255, 0.03);
}
.sn-pw-greeting,
.sn-pw-next h3 {
  color: #f6f7fb;
}
.tor-panel .sn-panel__section .sn-panel__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.tor-btn,
.tor-actions .tor-btn,
.tor-panel-toggle,
.tor-panel-header button,
.tor-panel-card .tor-btn,
.tor-cal-card .tor-btn {
  background: var(
    --sn-grad-theme,
    linear-gradient(
      135deg,
      var(--sn-theme-primary, #c90d05),
      var(--sn-theme-primary-hover, #e01006) 55%
    )
  );
  color: #fff;
  border: 1px solid var(--sn-theme-primary-accent, #9e0a03);
  border-radius: 8px;
  padding: 0.55rem 0.95rem;
  font-size: 0.75rem;
  font-weight: 600;
  line-height: 1.1;
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  cursor: pointer;
  text-decoration: none !important;
  box-shadow:
    0 2px 4px rgba(0, 0, 0, 0.35),
    0 0 0 1px rgba(255, 255, 255, 0.05) inset;
  transition:
    filter 0.22s ease,
    transform 0.16s ease,
    box-shadow 0.25s ease;
}
.tor-panel-toggle,
#tor-reglamento,
.tor-panel-toggle {
  display: none !important;
}
}

@layer sn.core {
@media (min-width: 1201px) {
  .tor-panel-toggle,
  #tor-reglamento {
    display: none !important;
  }
}
}

@layer sn.core {
.tor-btn:hover,
.tor-actions .tor-btn:hover,
.tor-panel-toggle:hover,
.tor-panel-card .tor-btn:hover,
.tor-cal-card .tor-btn:hover {
  filter: brightness(1.12) saturate(1.05);
}
.tor-btn:active,
.tor-actions .tor-btn:active,
.tor-panel-toggle:active,
.tor-panel-card .tor-btn:active,
.tor-cal-card .tor-btn:active {
  transform: translateY(2px);
  box-shadow:
    0 1px 2px rgba(0, 0, 0, 0.4),
    0 0 0 1px rgba(255, 255, 255, 0.04) inset;
}
.tor-btn:focus-visible,
.tor-actions .tor-btn:focus-visible,
.tor-panel-toggle:focus-visible,
.tor-panel-card .tor-btn:focus-visible,
.tor-cal-card .tor-btn:focus-visible {
  outline: 2px solid #ff534b;
  outline-offset: 2px;
}
.tor-btn.tor-btn--sm {
  padding: 0.4rem 0.7rem;
  font-size: 0.68rem;
}
.estado-programado {
  background: rgba(0, 123, 255, 0.14);
  color: #4da3ff;
}
.estado-curso {
  background: rgba(255, 193, 7, 0.18);
  color: #ffd75a;
}
.estado-finalizado {
  background: rgba(220, 53, 69, 0.16);
  color: #ff7b85;
}
.tor-content,
.tor-panel,
.tor-panel-card,
.tor-panel-card-body,
.tor-panel-card-header,
.tor-panel-card-footer,
.tor-cal-card,
.pw-card,
.sn-pw-greeting,
.tfx-phase,
.tfx-division {
  background: var(--sn-surface-1, var(--tr-bg));
  border: 1px solid var(--sn-border-color, #2a2a2a);
  border-radius: var(--sn-radius-lg, var(--tr-r));
}
.tor-content {
  background: var(--sn-surface-2, var(--tr-bg2));
}
.tfx-flow.success {
  --tfx-surface-flow: #13271a;
  --tfx-flow-border: #2e5a3b;
  color: #cfe9d6;
}
.tfx-flow.danger {
  --tfx-surface-flow: #2a1717;
  --tfx-flow-border: #6a2a2a;
  color: #f2d3d3;
}
.tfx-flow.pending {
  --tfx-surface-flow: #1f1a12;
  --tfx-flow-border: #6a5a20;
  color: #f6e3b9;
}
.pw-modal {
  background: var(--sn-surface-2, #141414) !important;
  border: 1px solid var(--sn-border-color, #2a2a2a) !important;
  border-radius: var(--sn-radius-lg, 10px) !important;
  box-shadow:
    0 10px 34px -4px rgba(0, 0, 0, 0.55),
    0 0 0 1px rgba(255, 255, 255, 0.04) inset;
}
.pw-close:hover {
  background: #262626;
  border: 1px solid #3a3a3a;
}
html {
  font-size: var(--tr-font);
}
html,
body {
  max-width: 100%;
  overflow-x: hidden;
}
.tor-wrapper,
.tor-wrapper * {
  box-sizing: border-box;
}
.tor-wrapper {
  overflow-x: hidden;
  display: flex;
  flex-direction: column;
  gap: var(--tr-gap);
  margin: 0 auto;
  max-width: 1620px;
  padding: 0 12px;
}
.tor-header {
  display: flex;
  align-items: center;
  gap: 1rem;
  background: var(--tr-bg);
  border-radius: var(--tr-r);
  padding: 12px 16px;
  min-height: 92px;
}
.tor-logo {
  width: 90px;
  height: 90px;
  border-radius: 10px;
  overflow: hidden;
  flex: 0 0 90px;
  background: #1b1b1b;
  display: flex;
  align-items: center;
  justify-content: center;
}
.tor-logo img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.tor-head-main {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
  min-width: 0;
}
.tor-sim-info {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 0.25rem;
  margin-bottom: 0.35rem;
}
.tor-sim-logo {
  max-height: 34px;
  width: auto;
  display: block;
  filter: drop-shadow(0 0 4px rgba(0, 0, 0, 0.6));
}
.tor-sim-name {
  font-size: 0.65rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: #b5b5b5;
}
.tor-title {
  font-size: 1.55rem;
  font-weight: 600;
  color: #fff;
  line-height: 1.2;
  display: flex;
  align-items: center;
  gap: 0.6rem;
  flex-wrap: wrap;
}
.tor-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
}
.tor-header .tor-badge:not(.tor-free):not(.tor-cost) {
  background: var(
    --sn-color-surface-raised,
    rgba(255, 255, 255, 0.03)
  ) !important;
  border: 1px solid var(--sn-color-border, rgba(255, 255, 255, 0.08)) !important;
  color: var(--sn-color-text, #e0e0e0) !important;
  box-shadow: none;
}
.tor-header .tor-badge strong {
  font-weight: 700;
  margin-right: 4px;
}
.tor-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  background: #222;
  border: 1px solid #2c2c2c;
  color: var(--tr-fg);
  font-size: 0.72rem;
  font-weight: 500;
  padding: 0.35rem 0.55rem;
  border-radius: 30px;
  line-height: 1;
  white-space: nowrap;
}
.tor-badge svg {
  width: 14px;
  height: 14px;
  fill: currentColor;
}
.tor-actions {
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
  align-items: flex-end;
  min-width: 140px;
}
.tor-actions .tor-btn {
  background: #222;
  border: 1px solid #333;
  color: #eee;
  padding: 0.55rem 0.9rem;
  border-radius: 6px;
  font-size: 0.75rem;
  display: inline-flex;
  gap: 0.4rem;
  align-items: center;
  cursor: pointer;
}
.tor-actions .tor-btn:hover {
  background: #2d2d2d;
}
.tor-subdesc {
  font-size: 0.85rem;
  color: #aaa;
  margin-top: 0.15rem;
}
.tor-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) var(--tor-panel-w, 360px);
  gap: var(--tr-gap);
  align-items: start;
}
.tor-content-col {
  display: flex;
  flex-direction: column;
  gap: var(--tr-gap);
  min-width: 0;
}
.tor-tabs {
  display: flex;
  gap: 0.4rem;
  background: var(--tr-bg);
  padding: 6px 6px;
  border-radius: var(--tr-r);
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: thin;
  max-width: 100vw;
}
.tor-tab,
.tor-tabs .sn-tab {
  background: #1b1b1b;
  border: 0;
  color: #bfbfbf;
  padding: 0.5rem 0.85rem;
  border-radius: 6px;
  cursor: pointer;
  font-size: 0.78rem;
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  line-height: 1;
  white-space: nowrap;
  flex: 0 0 auto;
}
.tor-tab.on,
.tor-tabs .sn-tab.on,
.tor-tabs .sn-tab.active {
  background: var(
    --sn-grad-theme,
    linear-gradient(
      135deg,
      var(--sn-theme-primary, #c90d05),
      var(--sn-theme-primary-hover, #e01006) 55%
    )
  );
  color: #fff;
  border: 1px solid var(--sn-theme-primary-accent, #9e0a03);
  box-shadow:
    0 0 0 1px var(--sn-theme-primary-accent, #9e0a03),
    0 2px 6px rgba(0, 0, 0, 0.4);
}
.tor-tab:hover:not(.on),
.tor-tabs .sn-tab:hover:not(.on):not(.active) {
  background: #262626;
}
.tor-tab svg,
.tor-tabs .sn-tab svg {
  width: 16px;
  height: 16px;
  fill: currentColor;
}
.tor-panel {
  --sn-panel-bg: var(--tr-bg2);
  --sn-panel-border: rgba(255, 255, 255, 0.08);
  background: var(--sn-panel-bg);
  border: 1px solid var(--sn-panel-border);
  border-radius: var(--sn-radius-lg, var(--tr-r));
  padding: 1rem;
  position: sticky;
  top: 70px;
  height: -moz-fit-content;
  height: fit-content;
}
.tor-panel .sn-panel__section {
  margin-bottom: 1rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid rgba(255, 255, 255, 0.05);
}
.tor-panel .sn-panel__section:last-child {
  margin-bottom: 0;
  padding-bottom: 0;
  border-bottom: 0;
}
.sn-chat-desktop {
  background: transparent;
  border-radius: var(--sn-radius-lg, 12px);
  margin-bottom: var(--sn-space-4, 1.5rem);
}
.sn-chat-desktop .sn-chat-item {
  width: 100%;
}
.sn-chat-mobile {
  position: fixed;
  bottom: calc(env(safe-area-inset-bottom, 0px) + 82px);
  right: calc(env(safe-area-inset-right, 0px) + 16px);
  z-index: 5200;
}
.sn-chat-toggle {
  width: 52px;
  height: 52px;
  border-radius: var(--sn-radius-pill, 999px);
  background: var(--sn-grad-theme, linear-gradient(135deg, #c90d05, #8f0700));
  border: 1px solid var(--sn-theme-primary-accent, #820600);
  color: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 12px 28px rgba(0, 0, 0, 0.45);
  transition:
    transform 0.18s ease,
    filter 0.18s ease;
}
.sn-chat-close {
  background: transparent;
  border: none;
  border-radius: var(--sn-radius-sm, 6px);
  color: var(--sn-color-text, #fff);
  width: 32px;
  height: 32px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.sn-chat-close:hover {
  background: rgba(255, 255, 255, 0.08);
}
}

@layer sn.core {
@media (max-width: 991px) {
  .sn-chat-container {
    position: fixed !important;
    left: 10px !important;
    right: 10px !important;
    bottom: 0 !important;
    top: auto !important;
    width: auto !important;
    max-width: calc(100% - 20px) !important;
    height: 78vh !important;
    max-height: 78vh !important;
    margin: 0 !important;
    background: #101822 !important;
    border-radius: 18px !important;
    box-shadow: 0-2px 18px rgba(0, 0, 0, 0.45);
    display: flex !important;
    flex-direction: column !important;
    transform: translateY(105%);
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition:
      transform 0.28s ease,
      opacity 0.25s,
      visibility 0.25s;
    z-index: 6000;
  }
  .sn-chat-overlay {
    position: fixed;
    inset: 0;
    background: rgba(5, 7, 12, 0.55);
    backdrop-filter: blur(2px);
    z-index: 5900;
    display: none;
  }
  .sn-chat-mobile-wrapper #nitro-chat-container {
    flex: 1 1 auto;
    display: flex;
    flex-direction: column;
    min-height: 0;
    background: #0d1421 !important;
    border-radius: 0 !important;
  }
  .sn-chat-mobile-wrapper #nitro-chat-container .chat-messages,
  .sn-chat-mobile-wrapper [id^="nitro-chat-container-"] .chat-messages {
    flex: 1 1 auto !important;
    min-height: 0 !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch;
    padding: 8px 10px !important;
  }
  .sn-chat-mobile-wrapper #nitro-chat-container .chat-input-container,
  .sn-chat-mobile-wrapper [id^="nitro-chat-container-"] .chat-input-container {
    flex: 0 0 auto !important;
    background: #151a22 !important;
    border-top: 1px solid #263544 !important;
    padding: 8px 10px !important;
  }
}
}

@layer sn.core {
@media (max-width: 480px) {
  .sn-chat-mobile {
    bottom: calc(env(safe-area-inset-bottom, 0px) + 100px);
    right: calc(env(safe-area-inset-right, 0px) + 10px);
  }
  .sn-chat-toggle {
    width: 44px;
    height: 44px;
  }
}
}

@layer sn.core {
.tor-content {
  background: var(--tr-bg);
  border-radius: var(--tr-r);
  padding: 1.1rem;
  min-height: 300px;
  max-width: 100%;
  overflow-x: auto !important;
  box-sizing: border-box;
  min-width: 0;
}
.tor-free {
  background: #1e3d18;
  color: #b9f5a6;
  border: 1px solid #2d6b22;
}
.tor-cost {
  background: #262626;
  color: #e5e5e5;
}
.tor-loading {
  padding: 2rem;
  text-align: center;
  font-size: 0.9rem;
  color: #aaa;
}
.estado {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-weight: 600;
  padding: 4px 8px;
  border-radius: 4px;
  font-size: 0.9rem;
}
.estado-programado {
  background: rgba(0, 123, 255, 0.15);
  color: #4da3ff;
}
.estado-activo {
  background: rgba(40, 167, 69, 0.15);
  color: #5dd674;
}
.estado-curso {
  background: rgba(255, 193, 7, 0.15);
  color: #ffd75a;
}
.estado-finalizado {
  background: rgba(220, 53, 69, 0.15);
  color: #ff7b85;
}
}

@layer sn.core {
@media (max-width: 1200px) {
  .tor-wrapper {
    padding-left: 10px;
    padding-right: 10px;
    max-width: 100%;
  }
  .tor-grid {
    grid-template-columns: 1fr;
  }
  .tor-panel {
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    width: 320px;
    transform: translateX(100%);
    transition: transform 0.3s ease-in-out;
    background: var(--tr-bg2);
    z-index: 5000;
    overflow-y: auto;
    border-radius: 0;
    will-change: transform;
    visibility: visible;
    box-shadow: -4px 0 20px rgba(0, 0, 0, 0.3);
  }
  .tor-panel.open {
    transform: translateX(0);
  }
  .tor-panel-toggle {
    display: inline-flex !important;
    background: var(--tr-primary) !important;
    color: #fff !important;
    border: 1px solid var(--tr-primary) !important;
    font-weight: 600;
  }
  .tor-panel-toggle:hover {
    background: #a10b04 !important;
  }
  .tor-header .tor-panel-toggle {
    display: inline-flex !important;
    visibility: visible !important;
  }
  .tor-header {
    flex-wrap: wrap;
    align-items: flex-start;
  }
  .tor-actions {
    flex-direction: row;
    align-items: center;
  }
  .tor-tabs {
    margin-top: 0.2rem;
    padding: 4px 4px;
    gap: 0.3rem;
  }
  .tor-tab,
  .tor-tabs .sn-tab {
    padding: 0.45rem 0.7rem;
    font-size: 0.72rem;
  }
  .tor-header {
    padding: 10px 12px;
  }
  .tor-content {
    overflow-x: auto !important;
    max-width: calc(100vw - 24px) !important;
  }
  .tor-content * {
    max-width: 100% !important;
    box-sizing: border-box;
  }
  .tor-content table {
    width: 100% !important;
    table-layout: auto;
    overflow-x: auto;
  }
}
}

@layer sn.core {
@media (max-width: 768px) {
  .tor-wrapper {
    padding-left: 8px;
    padding-right: 8px;
  }
  .tor-header {
    display: grid;
    grid-template-columns: 72px 1fr;
    grid-template-areas: "logo head" "logo head" "actions actions";
    align-items: start;
    gap: 0.6rem;
    padding: 8px 0;
  }
  .tor-logo {
    grid-area: logo;
    width: 72px;
    height: 72px;
    flex: 0 0 72px;
  }
  .tor-head-main {
    grid-area: head;
    min-width: 0;
  }
  .tor-actions {
    grid-area: actions;
    min-width: auto;
    justify-content: flex-start;
    align-items: center;
    gap: 0.4rem;
    flex-wrap: wrap;
  }
  .tor-tabs {
    padding: 4px 12px;
  }
  .tor-content {
    padding: 12px 10px;
    overflow-x: auto !important;
    max-width: 100% !important;
  }
  .tor-sc-wrap {
    overflow-x: auto !important;
    max-width: 100% !important;
    box-sizing: border-box;
    padding: 0;
  }
  .tor-content .tor-sc-wrap > * {
    max-width: 100% !important;
    overflow-x: auto;
    box-sizing: border-box;
  }
}
}

@layer sn.core {
@media (max-width: 520px) {
  .tor-wrapper {
    padding-left: 6px;
    padding-right: 6px;
  }
  .tor-logo {
    width: 64px;
    height: 64px;
    flex: 0 0 64px;
  }
  .tor-logo img {
    -o-object-fit: cover;
       object-fit: cover;
  }
  .tor-title {
    font-size: 1.15rem;
    line-height: 1.05;
  }
  .tor-header {
    display: grid;
    grid-template-columns: 64px 1fr;
    grid-template-areas: "logo head" "logo head" "actions actions";
    align-items: start;
    gap: 0.6rem;
    padding: 8px 0;
  }
  .tor-logo {
    grid-area: logo;
  }
  .tor-sim-info {
    align-items: flex-start;
  }
  .tor-badges {
    gap: 0.3rem;
  }
  .tor-badge {
    font-size: 0.64rem;
    padding: 0.28rem 0.44rem;
    white-space: normal;
    max-width: calc(50vw);
    overflow: hidden;
    text-overflow: ellipsis;
    word-break: break-word;
  }
  .tor-panel {
    width: min(320px, 90vw);
    max-width: 90vw;
  }
  .tor-panel-toggle {
    background: var(--tr-primary) !important;
    color: #fff !important;
    border: 2px solid var(--tr-primary) !important;
    font-weight: 700 !important;
    font-size: 0.8rem !important;
    padding: 0.6rem 0.8rem !important;
  }
  .tor-tabs {
    padding: 4px 8px;
  }
  .tor-content {
    padding: 12px 6px;
  }
  .tor-sc-wrap {
    padding: 0;
  }
}
}

@layer sn.core {
.tor-panel-toggle {
  display: none !important;
  margin-left: auto;
  background: #222;
  border: 1px solid #2c2c2c;
  color: #eee;
  padding: 0.5rem 0.75rem;
  border-radius: 6px;
  font-size: 0.75rem;
  cursor: pointer;
}
.tor-panel-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.5);
  z-index: 4999;
  opacity: 0;
  visibility: hidden;
  transition:
    opacity 0.3s ease-in-out,
    visibility 0.3s ease-in-out;
}
.tor-panel-overlay.active {
  opacity: 1;
  visibility: visible;
}
.tor-panel-header {
  display: none;
  padding: 1rem;
  border-bottom: 1px solid #333;
  background: var(--tr-bg);
  justify-content: space-between;
  align-items: center;
}
.tor-panel-header h3 {
  color: #fff;
  margin: 0;
  font-size: 1rem;
}
.tor-panel-close {
  background: none;
  border: none;
  color: #fff;
  font-size: 1.5rem;
  cursor: pointer;
  padding: 0;
  line-height: 1;
}
}

@layer sn.core {
@media (max-width: 1200px) {
  .tor-panel-header {
    display: flex;
  }
  .tor-panel-overlay {
    display: block;
  }
}
}

@layer sn.core {
.tor-sc-wrap {
  overflow-x: auto !important;
  -webkit-overflow-scrolling: touch;
  max-width: 100% !important;
  box-sizing: border-box;
}
.tor-sc-wrap img,
.tor-sc-wrap iframe,
.tor-sc-wrap video {
  max-width: 100%;
  height: auto;
}
.tor-sc-wrap table {
  width: 100%;
  max-width: 100%;
  overflow-x: auto;
  display: table;
}
.tor-sc-wrap .sn-pitwall,
.tor-sc-wrap .tor-pitwall,
.tor-sc-wrap [data-sc*="torneo_pitwall"],
.tor-sc-wrap .pitwall {
  max-width: 100% !important;
  overflow: hidden;
}
.tor-sc-wrap .sn-pitwall *,
.tor-sc-wrap .tor-pitwall *,
.tor-sc-wrap .pitwall * {
  box-sizing: border-box;
  max-width: 100% !important;
}
.tor-sc-wrap .sn-msg,
.tor-sc-wrap .sn-message,
.tor-sc-wrap .sn-banner,
.tor-sc-wrap .sn-tor-msg,
.tor-sc-wrap .sn-tor-badge,
.tor-sc-wrap .sn-tor-top,
.tor-sc-wrap .sn-tor-bottom {
  white-space: normal !important;
  word-break: break-word;
  overflow-wrap: anywhere;
}
.tor-sc-wrap .sn-btn,
.tor-sc-wrap .sn-btn-primary,
.tor-sc-wrap .sn-tor-badge,
.tor-sc-wrap button,
.tor-sc-wrap a.button {
  max-width: 100% !important;
}
.tor-info-wrap,
.tor-info-wrap * {
  max-width: 100% !important;
  overflow-x: auto;
  word-break: break-word;
}
.tor-sc-wrap .tor-calendario,
.tor-sc-wrap .torneo-calendario,
.tor-sc-wrap .sn-torneo-calendario,
.tor-sc-wrap [data-sc*="torneos_calendario"],
.tor-sc-wrap [data-sc*="torneo_calendario"] {
  overflow-x: auto !important;
}
.tor-sc-wrap .tor-calendario table,
.tor-sc-wrap .torneo-calendario table,
.tor-sc-wrap .sn-torneo-calendario table {
  width: 100% !important;
  table-layout: auto !important;
}
.tor-sc-wrap .btn,
.tor-sc-wrap .button,
.tor-sc-wrap .sn-btn {
  white-space: nowrap;
}
.tor-sc-wrap .wp-block-image img,
.tor-sc-wrap .alignwide img,
.tor-sc-wrap .alignfull img {
  width: 100%;
  height: auto;
  max-width: 100%;
}
.tor-sponsors-header {
  display: none;
}
}

@layer sn.core {
@media (min-width: 769px) {
  .tor-sponsors-header {
    display: block;
    width: 90px;
    height: 90px;
    border-radius: 10px;
    overflow: hidden;
    background: #1b1b1b;
    flex: 0 0 90px;
  }
  .tor-sponsors-desktop {
    display: block;
    position: relative;
    width: 100%;
    height: 100%;
    overflow: hidden;
  }
  .tor-sponsor-current {
    position: relative;
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .tor-sponsor-slide {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transition: opacity 0.8s ease-in-out;
    cursor: pointer;
  }
  .tor-sponsor-slide.active {
    opacity: 1;
  }
  .tor-sponsor-slide img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover;
    filter: brightness(0.9);
    transition: all 0.3s ease;
  }
  .tor-sponsor-slide:hover img {
    filter: brightness(1.1);
    transform: scale(1.05);
  }
  .tor-sponsors-mobile {
    display: none;
  }
}
}

@layer sn.core {
@media (max-width: 768px) {
  .tor-sponsors-header {
    display: none !important;
  }
  .tor-actions {
    position: relative;
  }
  .tor-sponsors-mobile-inline {
    display: flex;
    align-items: center;
    gap: 8px;
    order: 1;
    flex: 1;
    justify-content: center;
    padding: 0 8px;
    max-width: 140px;
  }
  .tor-sponsors-mobile-inline .tor-sponsors-track {
    display: flex;
    align-items: center;
    gap: 10px;
    height: 32px;
  }
  .tor-sponsors-mobile-inline .tor-sponsor-item {
    flex: 0 0 auto;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    height: 28px;
  }
  .tor-sponsors-mobile-inline .tor-sponsor-item img {
    max-height: 40px;
    max-width: 60px;
    width: auto;
    height: auto;
    -o-object-fit: contain;
       object-fit: contain;
    filter: brightness(0.9);
    transition: all 0.3s ease;
  }
  .tor-sponsors-mobile-inline .tor-sponsor-item:hover img {
    filter: brightness(1.1);
    transform: scale(1.05);
  }
  .tor-actions {
    display: flex !important;
    align-items: center;
    gap: 0.4rem;
    flex-wrap: nowrap;
    justify-content: space-between;
  }
  .tor-actions .tor-sim-info {
    display: none;
  }
  .tor-actions #tor-share {
    order: 0;
  }
  .tor-actions #tor-panel-toggle {
    order: 2;
  }
}
}

@layer sn.core {
.tor-sponsor-placeholder {
  color: #ccc;
  font-size: 12px;
  font-weight: 500;
  padding: 8px;
  background: rgba(255, 255, 255, 0.1);
  border-radius: 4px;
  text-align: center;
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}
.tor-grid,
.tor-content-col,
.tor-content {
  min-height: 0 !important;
}
.tor-content,
.tor-sc-wrap {
  overflow-y: visible !important;
}
.tor-content .sn-pitwall,
.tor-content .torneo-fixture,
.tor-content .tor-reglamento,
.tor-content .tor-denuncias {
  max-height: none !important;
  overflow: visible !important;
}
}

@layer sn.core {
@media (max-width: 991px) {
  .tor-content,
  .tor-sc-wrap {
    max-height: none !important;
  }
}
}

@layer sn.core {
@media (max-width: 1200px) {
  .container,
  .container-fluid {
    padding-inline: 3px !important;
    padding-left: 3px !important;
    padding-right: 3px !important;
  }
  body .tor-wrapper,
  body .container .tor-wrapper,
  body .container-fluid .tor-wrapper {
    padding-left: 3px !important;
    padding-right: 3px !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    max-width: 100vw !important;
    overflow-x: hidden !important;
  }
  body .tor-content,
  body .tor-content *,
  body .sn-pitwall,
  body .sn-pitwall *,
  body .torneo-fixture,
  body .torneo-fixture *,
  body .tor-calendario,
  body .tor-calendario *,
  body .tor-reglamento,
  body .tor-reglamento *,
  body .tor-denuncias,
  body .tor-denuncias * {
    max-width: 100% !important;
    box-sizing: border-box !important;
  }
  body .tor-content table,
  body table[class*="tor-"],
  body table[class*="cal-"],
  body .tor-cal-table,
  body .tor-std-table,
  body .tor-res-table {
    width: 100% !important;
    max-width: 100% !important;
    table-layout: fixed !important;
    word-wrap: break-word !important;
  }
  body .tor-cal-card,
  body .tor-cal-card-body,
  body .tor-cal-section {
    overflow-x: auto !important;
    max-width: calc(100vw - 10px) !important;
    -webkit-overflow-scrolling: touch !important;
  }
}
}

@layer sn.core {
@media (max-width: 991px) {
  .sn-pitwall,
  .sn-pw-greeting,
  .pw-card,
  .pw-asistencia,
  .pw-confirmados,
  .pw-modal {
    max-width: 100% !important;
    box-sizing: border-box;
    overflow-wrap: break-word;
  }
  .pw-asistencia {
    flex-wrap: wrap !important;
  }
  .pw-meta {
    flex-wrap: wrap !important;
    gap: 8px !important;
  }
  .torneo-fixture-scroll {
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch;
    max-width: 100%;
  }
  .torneo-fixture-inner {
    min-width: -moz-max-content;
    min-width: max-content;
    grid-auto-columns: minmax(160px, 200px) !important;
    gap: 8px !important;
  }
  .tfx-phase,
  .tfx-division,
  .tfx-flow {
    max-width: 100%;
    box-sizing: border-box;
  }
  .tor-calendario,
  .tor-cal-section,
  .tor-cal-card,
  .tor-cal-card-body {
    max-width: 100% !important;
    overflow-x: auto !important;
    box-sizing: border-box;
  }
  .tor-cal-table {
    min-width: 500px !important;
    width: auto !important;
    table-layout: auto !important;
  }
  .tor-cal-card-head {
    grid-template-columns: auto 1fr auto !important;
    gap: 0.4rem !important;
    flex-wrap: wrap;
  }
  .tor-standings,
  .tor-standings-content {
    max-width: 100% !important;
    overflow-x: auto !important;
  }
  .tor-std-table,
  .tor-std-detail-table,
  .tor-res-table {
    min-width: 480px !important;
    width: auto !important;
    table-layout: auto !important;
  }
  .tor-reglamento,
  .tor-reglamento-content {
    max-width: 100% !important;
    box-sizing: border-box;
  }
  .tor-reglamento-tabs {
    flex-wrap: wrap !important;
    gap: 0.3rem !important;
  }
  .tor-denuncias,
  .tor-den-card,
  .tor-den-body {
    max-width: 100% !important;
    box-sizing: border-box;
    word-wrap: break-word;
    overflow-wrap: break-word;
  }
  .tor-den-head,
  .tor-den-meta {
    flex-wrap: wrap !important;
    gap: 0.4rem !important;
  }
  .tor-res-modal,
  .tor-std-modal {
    width: 95vw !important;
    max-height: 90vh !important;
    top: 5vh !important;
  }
  .tor-res-table-wrap,
  .tor-res-body,
  .tor-std-body {
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch;
  }
  .tor-content table,
  .tor-content .tor-cal-table,
  .tor-content .tor-std-table,
  .tor-content .tor-res-table,
  .tor-content .tor-puntos-table,
  .tor-content .tor-sanciones-table {
    width: 100% !important;
    max-width: 100% !important;
    table-layout: auto !important;
    overflow-x: auto !important;
    display: table !important;
  }
  .tor-badge,
  .tor-btn,
  .tor-std-detalle,
  .sesion-badge,
  .tor-countdown {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 100%;
    box-sizing: border-box;
  }
  .tor-den-actions,
  .tor-std-actions,
  .tor-cal-card-head {
    flex-wrap: wrap !important;
  }
  .tor-panel-card,
  .tor-panel-card-header,
  .tor-panel-card-body,
  .tor-panel-card-footer {
    max-width: 100% !important;
    box-sizing: border-box;
  }
  .tor-panel-card-meta,
  .tor-sesion-info,
  .tor-pista-info {
    flex-wrap: wrap !important;
    gap: 6px !important;
  }
  .tor-cal-table {
    font-size: 0.7rem !important;
  }
  .tor-std-table {
    font-size: 0.72rem !important;
  }
  .tor-res-table {
    font-size: 0.7rem !important;
  }
  .tor-sc-wrap,
  .tor-content > div,
  .tor-content > section {
    max-width: 100% !important;
    overflow-x: auto !important;
    box-sizing: border-box;
  }
}
}

@layer sn.core {
@media (max-width: 520px) {
  .tor-wrapper {
    padding-left: 6px !important;
    padding-right: 6px !important;
  }
  .tor-content {
    padding: 0.8rem !important;
  }
  .tor-res-modal,
  .tor-std-modal {
    width: 98vw !important;
    max-height: 95vh !important;
    top: 2.5vh !important;
    border-radius: 8px;
  }
  .tor-cal-table {
    min-width: 400px !important;
    font-size: 0.65rem !important;
  }
  .tor-std-table {
    min-width: 380px !important;
    font-size: 0.68rem !important;
  }
  .tor-cal-card-head {
    grid-template-columns: 1fr !important;
    grid-template-rows: auto auto auto;
    text-align: left;
  }
  .pw-meta {
    flex-direction: column !important;
    align-items: flex-start !important;
  }
  .tor-den-head {
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 0.3rem !important;
  }
}
}

@layer sn.core {
@media (max-width: 1200px) {
  html body .site-content .container .tor-wrapper,
  html body .site-content .container-fluid .tor-wrapper,
  html body .container .tor-wrapper,
  html body .container-fluid .tor-wrapper,
  html body .tor-wrapper {
    width: 100vw !important;
    max-width: 100vw !important;
    margin-left: -3px !important;
    margin-right: -3px !important;
    padding-left: 3px !important;
    padding-right: 3px !important;
    box-sizing: border-box !important;
    overflow-x: hidden !important;
  }
  html body .tor-content,
  html body .tor-sc-wrap {
    width: 100% !important;
    max-width: calc(100vw - 6px) !important;
    margin: 0 !important;
    padding-left: 8px !important;
    padding-right: 8px !important;
    box-sizing: border-box !important;
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch !important;
  }
  html body .sn-pitwall,
  html body .sn-pitwall .pw-card,
  html body .sn-pitwall .pw-asistencia,
  html body .sn-pitwall .pw-meta {
    width: 100% !important;
    max-width: 100% !important;
    flex-wrap: wrap !important;
    word-wrap: break-word !important;
    overflow-wrap: break-word !important;
    box-sizing: border-box !important;
  }
  html body .tor-calendario,
  html body .tor-cal-card,
  html body .tor-cal-card-body {
    width: 100% !important;
    max-width: 100% !important;
    overflow-x: auto !important;
    box-sizing: border-box !important;
  }
  html body .tor-cal-table {
    min-width: 500px !important;
    width: auto !important;
    margin: 0 !important;
    border-collapse: collapse !important;
  }
  html body .torneo-fixture,
  html body .torneo-fixture-scroll {
    width: 100% !important;
    max-width: 100% !important;
    overflow-x: auto !important;
    box-sizing: border-box !important;
  }
  html body .tor-reglamento,
  html body .tor-reglamento-content {
    width: 100% !important;
    max-width: 100% !important;
    word-wrap: break-word !important;
    overflow-wrap: anywhere !important;
    box-sizing: border-box !important;
  }
  html body .tor-denuncias,
  html body .tor-den-card,
  html body .tor-den-body {
    width: 100% !important;
    max-width: 100% !important;
    word-wrap: break-word !important;
    overflow-wrap: break-word !important;
    box-sizing: border-box !important;
  }
  html body table[class*="tor-"],
  html body .tor-content table,
  html body [class*="cal-"] table,
  html body [class*="std-"] table {
    width: 100% !important;
    max-width: 100% !important;
    table-layout: fixed !important;
    word-break: break-word !important;
    border-collapse: collapse !important;
    margin: 0 !important;
  }
  html body .tor-content button,
  html body .tor-content .tor-btn,
  html body .tor-content [class*="btn"] {
    max-width: 100% !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
  }
}
}

@layer sn.core {
@media (max-width: 1200px) {
  html body .tor-cal-table,
  html body .tor-cal-card-body table {
    display: none !important;
  }
  html body .tor-cal-card-body::after {
    content: "";
    display: block;
    clear: both;
  }
  html body .tor-cal-card {
    position: relative;
  }
  html body .tor-cal-card-body {
    padding: 0 !important;
  }
  html body .tor-cal-card::after {
    content: "ÃƒÂ°Ã…Â¸Ã¢â‚¬Å“Ã‚Â± Vista mÃƒÆ’Ã‚Â³vil optimizada del calendario";
    display: block;
    text-align: center;
    padding: 15px;
    background: #1a1a1a;
    color: #888;
    font-size: 0.8rem;
    border-top: 1px solid #333;
  }
}
}

@layer sn.core {
@media (max-width: 1200px) {
  html body .tor-cal-card::after {
    display: none !important;
  }
  html body .tor-cal-table,
  html body .tor-cal-card-body table {
    display: table !important;
    width: 100% !important;
    font-size: 0.6rem !important;
    table-layout: fixed !important;
  }
  html body .tor-cal-table thead th {
    padding: 4px 2px !important;
    font-size: 0.55rem !important;
    line-height: 1.1 !important;
    vertical-align: top !important;
    word-break: break-word !important;
    white-space: normal !important;
  }
  html body .tor-cal-table tbody td {
    padding: 4px 2px !important;
    font-size: 0.6rem !important;
    line-height: 1.2 !important;
    vertical-align: top !important;
    word-break: break-word !important;
    white-space: normal !important;
  }
  html body .tor-cal-table .col-no,
  html body .tor-cal-table .col-formato,
  html body .tor-cal-table .col-estado-ronda {
    display: none !important;
  }
  html
    body
    .tor-cal-table
    th:not(.col-no):not(.col-formato):not(.col-estado-ronda),
  html
    body
    .tor-cal-table
    td:not(.col-no):not(.col-formato):not(.col-estado-ronda) {
    width: 25% !important;
  }
  html body .tor-cal-table th:first-child,
  html body .tor-cal-table td:first-child {
    width: 20% !important;
    font-size: 0.55rem !important;
  }
  html body .tor-cal-table button,
  html body .tor-cal-table .tor-btn,
  html body .tor-cal-table .tor-badge {
    font-size: 0.5rem !important;
    padding: 2px 4px !important;
    white-space: nowrap !important;
    max-width: 100% !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
  }
  html body .tor-cal-table .tor-countdown {
    font-size: 0.45rem !important;
    padding: 1px 3px !important;
    gap: 2px !important;
  }
  html body .sn-pitwall .tor-cal-table {
    margin: 5px 0 !important;
  }
}
}

@layer sn.core {
@media (max-width: 520px) {
  html body .tor-cal-table {
    font-size: 0.5rem !important;
  }
  html body .tor-cal-table thead th {
    font-size: 0.45rem !important;
    padding: 2px 1px !important;
  }
  html body .tor-cal-table tbody td {
    font-size: 0.5rem !important;
    padding: 2px 1px !important;
  }
  html body .tor-cal-table td {
    line-height: 1.1 !important;
  }
  html body .tor-cal-table button {
    font-size: 0.45rem !important;
    padding: 1px 2px !important;
  }
}
}

@layer sn.core {
.tor-tab-titulo {
  margin: 0 0 0.75rem 0;
  padding: 0;
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 1.2;
  color: var(--tr-fg, #d6d6d6);
}
.tor-tab-subtitulo {
  margin: 0 0 1.25rem 0;
  padding: 0;
  font-size: 0.95rem;
  font-weight: 400;
  line-height: 1.4;
  color: var(--sn-text-muted, #999);
}
.tor-tab-titulo:empty,
.tor-tab-subtitulo:empty {
  display: none;
  margin: 0;
  padding: 0;
}
.tor-tab-titulo + .tor-tab-subtitulo {
  margin-top: -0.5rem;
}
.pw-close {
  width: 24px !important;
  height: 24px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 18px !important;
  line-height: 1 !important;
  border-radius: 4px !important;
  background: #2a2a2a !important;
  border: 1px solid #444 !important;
}
.pw-close:hover {
  background: #333 !important;
  border-color: #555 !important;
}
}

@layer sn.core {
@media (max-width: 1200px) {
  .pw-modal {
    width: min(980px, 95vw) !important;
    margin: 5vh auto !important;
    max-height: 90vh !important;
    overflow: hidden !important;
    display: flex !important;
    flex-direction: column !important;
  }
  .pw-modal-body {
    flex: 1 !important;
    overflow-y: auto !important;
    max-height: none !important;
  }
}
}

@layer sn.core {
@media (max-width: 520px) {
  .pw-modal {
    width: 98vw !important;
    margin: 2vh auto !important;
    max-height: 96vh !important;
  }
  .pw-close {
    width: 20px !important;
    height: 20px !important;
    font-size: 16px !important;
  }
}
}

@layer sn.core {
html body #tor-root .tor-actions #tor-tabs .tor-tab.sn-tab,
html body #tor-root .tor-actions #tor-tabs .tor-tab {
  border-radius: 999px !important;
  min-height: 40px !important;
  padding: 0.6rem 1rem !important;
  font-weight: 600 !important;
  text-transform: none !important;
}
html body #tor-root .tor-actions #tor-tabs .tor-tab.sn-tab.on,
html body #tor-root .tor-actions #tor-tabs .tor-tab.sn-tab.active,
html body #tor-root .tor-actions #tor-tabs .tor-tab.on,
html body #tor-root .tor-actions #tor-tabs .tor-tab.active {
  border-radius: 999px !important;
  background: var(
    --sn-grad-theme,
    linear-gradient(135deg, #c90d05, #9e0a03)
  ) !important;
  border-color: var(--sn-theme-primary-accent, #7d0803) !important;
  color: #fff !important;
  box-shadow: 0 10px 24px rgba(201, 13, 5, 0.35) !important;
}
html body #tor-root #tor-tabs .tor-tab.sn-tab.on,
html body #tor-root #tor-tabs .tor-tab.sn-tab.active,
html body #tor-root #tor-tabs .tor-tab.on,
html body #tor-root #tor-tabs .tor-tab.active {
  background: var(
    --sn-grad-theme,
    linear-gradient(135deg, #c90d05, #9e0a03)
  ) !important;
  border-color: var(--sn-theme-primary-accent, #7d0803) !important;
  color: #fff !important;
}
html body #tor-root .tor-content .tor-sc-wrap {
  overflow-x: hidden !important;
}
html body #tor-root .tor-content .tor-sc-wrap > * {
  max-width: 100% !important;
}
html body #tor-root .tor-content .tor-sc-wrap .torneo-fixture-scroll,
html body #tor-root .tor-content .tor-sc-wrap .tor-pos-table-wrap,
html body #tor-root .tor-content .tor-sc-wrap .tor-cal-card-body,
html body #tor-root .tor-content .tor-sc-wrap .den-san-table-wrap {
  overflow-x: auto !important;
  -webkit-overflow-scrolling: touch;
}
html body #tor-root .tor-content .tor-sc-wrap .sn-denuncias-wrap,
html body #tor-root .tor-content .tor-sc-wrap .tor-denuncias {
  overflow-x: hidden !important;
}
html body #tor-root .tor-content .tor-sc-wrap .sn-denuncias-wrap .tor-cal-table,
html body #tor-root .tor-content .tor-sc-wrap .tor-denuncias .tor-cal-table {
  width: 100% !important;
  max-width: 100% !important;
  table-layout: fixed !important;
}
html
  body
  #tor-root
  .tor-content
  .tor-sc-wrap
  .sn-denuncias-wrap
  .tor-cal-table
  th,
html
  body
  #tor-root
  .tor-content
  .tor-sc-wrap
  .sn-denuncias-wrap
  .tor-cal-table
  td,
html body #tor-root .tor-content .tor-sc-wrap .tor-denuncias .tor-cal-table th,
html body #tor-root .tor-content .tor-sc-wrap .tor-denuncias .tor-cal-table td {
  white-space: normal !important;
  word-break: break-word !important;
  overflow-wrap: anywhere !important;
}
.tor-inscripcion-mobile {
  display: none;
}
.tor-inscripcion-panel {
  margin: 0 0 12px 0;
}
.tor-panel-chat {
  margin: 8px 0 12px;
}
}

@layer sn.core {
@media (max-width: 1200px) {
  .tor-inscripcion-mobile {
    display: block;
    width: 100%;
    margin: 12px 0;
  }
  .tor-inscripcion-panel {
    display: none;
  }
}
}

@layer sn.core {
.sn-encabezado-panel {
  margin-bottom: var(--sn-space-4, 16px);
  background: linear-gradient(
    135deg,
    rgba(13, 17, 27, 0.95),
    rgba(5, 7, 12, 0.98)
  );
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: var(--sn-radius-lg, 20px);
  padding: var(--sn-space-4, 20px);
  box-shadow: 0 22px 40px rgba(0, 0, 0, 0.45);
  color: var(--sn-color-text, #f5f5f5);
}
.sn-encabezado-licencia {
  display: flex;
  justify-content: flex-end;
  align-items: stretch;
  flex-wrap: wrap;
  gap: var(--sn-space-3, 12px);
}
.sn-licencia-card {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 8px 16px;
  min-height: 66px;
  background:
    linear-gradient(
      135deg,
      rgba(201, 13, 5, 0.85) 0%,
      rgba(17, 19, 29, 0.92) 100%
    ),
    #0f131f;
  border-radius: var(--sn-radius, 16px);
  color: #fff;
  width: 100%;
  max-width: 560px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  box-shadow: 0 18px 40px rgba(0, 0, 0, 0.45);
}
.sn-licencia-card img {
  width: 42px;
  height: 42px;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: 50%;
  flex-shrink: 0;
  border: 2px solid rgba(255, 255, 255, 0.25);
}
.sn-licencia-detalle {
  display: grid;
  grid-template-columns: auto auto auto;
  grid-template-rows: auto auto;
  -moz-column-gap: 6px;
       column-gap: 6px;
  row-gap: 4px;
  align-items: center;
  width: 100%;
}
.sn-licencia-detalle .badge {
  grid-column: 1;
  grid-row: 1 / span 2;
  align-self: center;
  font-size: 0.78rem;
  padding: 2px 6px;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  border-radius: var(--sn-radius-pill, 999px);
  font-weight: 600;
}
.sn-licencia-detalle .sn-licencia-item {
  font-size: 0.78rem;
  color: rgba(255, 255, 255, 0.8);
  letter-spacing: 0.02em;
}
.sn-licencia-detalle .sn-licencia-item strong {
  font-weight: 600;
  color: #fff;
}
.sn-licencia-detalle .sn-licencia-item:nth-child(5) {
  grid-column: 3;
  grid-row: 2;
  font-size: 0.65rem;
  color: rgba(255, 255, 255, 0.65);
}
.sn-licencia-cta {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: var(--sn-grad-theme, linear-gradient(135deg, #c90d05, #840502));
  color: #fff;
  text-decoration: none;
  padding: 0.6rem 1.2rem;
  border-radius: var(--sn-radius-btn, 10px);
  font-weight: 600;
  transition: filter 0.15s ease-in-out;
  box-shadow: 0 6px 16px rgba(201, 13, 5, 0.45);
}
.sn-licencia-cta:hover {
  filter: brightness(1.08);
  text-decoration: none;
  color: #fff;
}
.sn-loading {
  padding: 0.5rem;
  color: var(--sn-color-text-soft, #c4cad6);
  font-style: italic;
}
.sn-error {
  padding: 0.5rem;
  color: var(--sn-danger, #e05f5f);
  font-weight: 600;
}
}

@layer sn.core {
@media (max-width: 768px) {
  .sn-encabezado-licencia {
    flex-direction: column;
    align-items: stretch;
  }
  .sn-licencia-card {
    flex-direction: column;
    align-items: flex-start;
    gap: 12px;
    max-width: 100%;
  }
  .sn-licencia-detalle {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    grid-template-rows: auto auto auto;
  }
  .sn-licencia-detalle .badge {
    grid-column: 1 / span 2;
    grid-row: 1;
    justify-self: flex-start;
  }
  .sn-licencia-detalle .sn-licencia-item:nth-child(2) {
    grid-column: 1;
    grid-row: 2;
  }
  .sn-licencia-detalle .sn-licencia-item:nth-child(3) {
    grid-column: 2;
    grid-row: 2;
  }
  .sn-licencia-detalle .sn-licencia-item:nth-child(4) {
    grid-column: 1;
    grid-row: 3;
  }
  .sn-licencia-detalle .sn-licencia-item:nth-child(5) {
    grid-column: 2;
    grid-row: 3;
  }
}
}

@layer sn.core {
:root {
  --badge-w: 140px;
  --badge-py: 6px;
  --badge-px: 12px;
  --font-sz: 12px;
  --font-fm: "Inter", sans-serif;
  --sn-ml-width: 240px !important;
  --sn-ml-bg: #111 !important;
  --sn-ml-card-bg: #222 !important;
  --sn-ml-card-border: #333 !important;
  --sn-ml-text: #eee !important;
  --sn-ml-meta: #aaa !important;
  --sn-ml-accent: #2aa524 !important;
  --sn-ml-badge-locked-start: #2196f3;
  --sn-ml-badge-locked-end: #0d47a1;
  --sn-ml-badge-open-start: #28a745;
  --sn-ml-badge-open-end: #218838;
  --sn-ml-badge-edit-start: #17a2b8;
  --sn-ml-badge-edit-end: #10707f;
  --sn-ml-badge-full-start: #6c757d;
  --sn-ml-badge-full-end: #343a40;
  --sn-ml-badge-iniciando-start: #725706;
  --sn-ml-badge-iniciando-end: #d39e00;
  --sn-ml-badge-en-curso-start: #6f42c1;
  --sn-ml-badge-en-curso-end: #4b2e83;
  --sn-ml-badge-cancelled-start: #dc3545;
  --sn-ml-badge-cancelled-end: #a71d2a;
  --sn-ml-badge-error-start: #ff5722;
  --sn-ml-badge-error-end: #c62828;
  --sn-ml-badge-limit-start: #ff9800;
  --sn-ml-badge-limit-end: #f57c00;
  --sn-ml-badge-unknown-start: #343a40;
  --sn-ml-badge-unknown-end: #23272b;
}
}

@layer sn.core {
@media (min-width: 769px) {
  body.sn-has-menu > *:not(#sn-menu-lat) {
    margin-left: var(--sn-ml-width) !important;
  }
}
}

@layer sn.core {
.sn-ins {
  display: inline-flex;
  flex-direction: column;
  gap: 2px;
  font-family: var(--font-fm);
}
.sn-ins-badge,
.sn-open-badge {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-width: var(--badge-w);
  padding: var(--badge-py) var(--badge-px);
  border-radius: 8px !important;
  font: 600 var(--font-sz)/1.15 var(--font-fm);
  color: #fff;
  white-space: nowrap;
  border: none;
  cursor: pointer;
  transition: filter 0.15s ease-in-out;
}
.sn-ins-menu-lateral .sn-ins-badge.espera,
.sn-ins-menu-lateral .sn-ins-badge.locked {
  background: linear-gradient(
    135deg,
    var(--sn-ml-badge-locked-start),
    var(--sn-ml-badge-locked-end)
  ) !important;
  color: #fff !important;
}
.sn-ins-menu-lateral .sn-open-badge,
.sn-ins-menu-lateral .sn-ins-badge.open {
  background: linear-gradient(
    135deg,
    var(--sn-ml-badge-open-start),
    var(--sn-ml-badge-open-end)
  ) !important;
  color: #fff !important;
}
.sn-open-badge:hover {
  filter: brightness(1.08) !important;
}
.sn-ins-menu-lateral .sn-open-badge.edit {
  background: linear-gradient(
    135deg,
    var(--sn-ml-badge-edit-start),
    var(--sn-ml-badge-edit-end)
  ) !important;
  color: #fff !important;
  border-radius: 8px !important;
}
.sn-open-badge.edit i,
.sn-open-badge.edit small,
.sn-open-badge.edit .sn-ct {
  color: #fff !important;
  opacity: 0.95;
}
.sn-ins-menu-lateral .sn-open-badge.new {
  color: #fff !important;
  border-radius: 8px !important;
}
.sn-open-badge.new i,
.sn-open-badge.new small,
.sn-open-badge.new .sn-ct {
  color: #fff !important;
  opacity: 0.95;
}
.sn-ins-menu-lateral .sn-ins-badge.full {
  background: linear-gradient(
    135deg,
    var(--sn-ml-badge-full-start),
    var(--sn-ml-badge-full-end)
  ) !important;
  color: #fff !important;
  cursor: not-allowed;
}
.sn-ins-menu-lateral .sn-ins-badge.closed {
  background: linear-gradient(
    135deg,
    var(--sn-ml-badge-full-start),
    var(--sn-ml-badge-full-end)
  ) !important;
  color: #fff !important;
}
.sn-ins-menu-lateral .estado-iniciando {
  background: linear-gradient(
    135deg,
    var(--sn-ml-badge-iniciando-start),
    var(--sn-ml-badge-iniciando-end)
  );
  color: #fff !important;
}
.sn-ins-menu-lateral .sn-ins-badge.estado-iniciando,
.sn-ins-menu-lateral .sn-ins-badge.sala_asignada,
.sn-ins-menu-lateral .sn-ins-badge.estado-curso {
  background: linear-gradient(
    135deg,
    var(--sn-ml-badge-iniciando-start),
    var(--sn-ml-badge-iniciando-end)
  ) !important;
  color: #fff !important;
}
.sn-ins-menu-lateral .sn-ins-badge.en_curso {
  background: linear-gradient(
    135deg,
    var(--sn-ml-badge-en-curso-start),
    var(--sn-ml-badge-en-curso-end)
  ) !important;
  color: #fff !important;
}
.sn-ins-menu-lateral .sn-ins-badge.cancelled {
  background: linear-gradient(
    135deg,
    var(--sn-ml-badge-cancelled-start),
    var(--sn-ml-badge-cancelled-end)
  ) !important;
  color: #fff !important;
}
.sn-ins-menu-lateral .sn-ins-badge.error {
  background: linear-gradient(
    135deg,
    var(--sn-ml-badge-error-start),
    var(--sn-ml-badge-error-end)
  ) !important;
  color: #fff !important;
}
.sn-ins-menu-lateral .sn-ins-badge.limit,
.sn-ins-menu-lateral .sn-ins-badge.competition_limit {
  background: linear-gradient(
    135deg,
    var(--sn-ml-badge-limit-start),
    var(--sn-ml-badge-limit-end)
  ) !important;
  color: #fff !important;
}
.sn-ins-menu-lateral .sn-ins-badge.full,
.sn-ins-menu-lateral .sn-ins-badge.closed {
  background: linear-gradient(
    135deg,
    var(--sn-ml-badge-full-start),
    var(--sn-ml-badge-full-end)
  ) !important;
  color: #fff !important;
}
.sn-ins-menu-lateral .sn-ins-badge.unknown {
  background: linear-gradient(
    135deg,
    var(--sn-ml-badge-unknown-start),
    var(--sn-ml-badge-unknown-end)
  ) !important;
  color: #fff !important;
}
.sn-open-badge i {
  margin-right: 4px;
  font-size: 14px;
}
.sn-open-badge small {
  font-size: 10px;
  font-weight: 400;
  margin-left: 4px;
  opacity: 0.8;
}
.sn-ct {
  font-weight: 700;
  font-size: var(--font-sz);
  margin-top: 4px;
  font-family: monospace;
}
@keyframes sn-blink {
  0% {
    filter: brightness(1);
  }
  50% {
    filter: brightness(1.35);
  }
  100% {
    filter: brightness(1);
  }
}
.sn-blink {
  animation: sn-blink 1s ease-in-out infinite;
}
.sn-loading {
  padding: 8px 16px;
  background: #2b2b2b;
  border-radius: 4px;
  font-size: 12px;
  color: #6c757d;
}
.sn-ml-btn-detalle {
  margin-left: 6px;
  display: inline-block;
  background: #1f1f1f;
  border: 1px solid #333;
  color: #fff;
  border-radius: 6px;
  padding: 2px 8px;
  font-size: 12px;
  line-height: 1.2;
  cursor: pointer;
}
.sn-modal__body {
  padding: 1rem;
  max-height: 65vh;
  overflow: auto;
}
}

@layer sn.core {
@media (max-width: 600px) {
  .sn-ins-modal .box {
    padding: 1rem;
    max-width: 98vw;
    width: 100%;
    font-size: 15px;
  }
  .sn-ins-modal h3,
  .sn-ins-modal label,
  .sn-ins-modal select,
  .sn-ins-modal .sn-btn {
    font-size: 1rem;
  }
  .sn-ins-modal .sn-btn {
    padding: 0.7rem 1.2rem;
  }
  .sn-ins-modal .box {
    border-radius: 4px;
  }
}
}

@layer sn.core {
.sn-ins-modal h3 {
  margin-top: 0;
  font-size: 1.1rem;
  color: #fff;
}
.sn-ins-modal .status {
  text-align: center;
  padding: 1rem 0;
}
.sn-ins-modal label {
  font-size: 0.85rem;
  margin-bottom: 0.25rem;
  display: block;
}
.sn-ins-modal select {
  width: 100%;
  margin-bottom: 0.75rem;
  padding: 0.4rem;
  background: #333;
  color: #fff;
  border: none;
  border-radius: 4px;
}
  @supports (color: var(--sn-success)) {
.sn-ins-modal .sn-btn {
    font: 600 var(--sn-font-size-sm)/1 var(--sn-font-sans);
}
  }
.sn-ins-modal hr {
  border: none;
  border-top: 1px solid #444;
  margin: 1rem 0;
}
.limits-info {
  background: #000;
  padding: 8px;
  border-radius: 4px;
  margin-bottom: 10px;
}
.limits-info small {
  color: #fff;
  font-size: 12px;
}
#sn-menu-lat {
  position: fixed !important;
  top: 0;
  left: 0;
  bottom: 0 !important;
  width: var(--sn-ml-width) !important;
  background: var(--sn-ml-bg) !important;
  border-right: 1px solid var(--sn-ml-card-border) !important;
  overflow-y: auto !important;
  z-index: 9999 !important;
  transform: translateX(0);
  transition: transform 0.3s ease;
  font-family:
    -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
}
.sn-ml-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0.8rem;
  border-bottom: 1px solid var(--sn-ml-card-border);
  background: var(--sn-ml-bg);
  position: sticky;
  top: 0;
  z-index: 10;
}
.sn-ml-title {
  margin: 0;
  color: var(--sn-ml-text);
  font-size: 1rem;
  font-weight: 600;
}
#sn-ml-refresh {
  background: var(--sn-ml-accent);
  color: #fff;
  border: none;
  padding: 0.3rem 0.6rem;
  border-radius: 4px;
  cursor: pointer;
  font-size: 0.75rem;
  transition: opacity 0.2s;
}
#sn-ml-refresh:hover {
  opacity: 0.9;
}
.sn-ml-card {
  background: var(--sn-ml-card-bg);
  border: 1px solid var(--sn-ml-card-border);
  border-radius: 8px;
  padding: 0.8rem;
  margin: 0.6rem;
  color: var(--sn-ml-text);
  font-size: 0.85rem;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
  transition:
    transform 0.2s,
    box-shadow 0.2s;
}
.sn-ml-card:hover {
  transform: translateY(-1px);
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.15);
}
.sn-ml-head {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: 0.5rem;
}
.sn-ml-sim-icon {
  width: 28px;
  height: 28px;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: 4px;
  border: 1px solid var(--sn-ml-card-border);
}
.sn-ml-head strong {
  font-size: 0.9rem;
  color: var(--sn-ml-text);
  font-weight: 600;
}
.sn-ml-subhead small {
  font-size: 0.75rem;
  color: var(--sn-ml-meta);
  font-style: italic;
}
.sn-ml-track {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  margin: 0.4rem 0;
  color: var(--sn-ml-text);
  font-size: 0.8rem;
}
.sn-ml-dl {
  margin-left: auto;
  cursor: pointer;
  color: var(--sn-ml-accent) !important;
  transition: color 0.2s;
}
.sn-ml-dl:hover {
  color: #fff !important;
}
.sn-ml-auto {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  margin: 0.4rem 0;
  color: var(--sn-ml-text);
  font-size: 0.8rem;
}
.sn-ml-auto i {
  color: var(--sn-ml-accent);
}
.sn-ml-dates {
  font-size: 0.8rem;
  color: var(--sn-ml-text);
  margin: 0.5rem 0;
  padding: 0.3rem;
  background: rgba(255, 255, 255, 0.05);
  border-radius: 4px;
}
.sn-ml-count-label {
  font-size: 0.75rem;
  color: var(--sn-ml-meta);
  margin: 0.5rem 0 0.2rem;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.sn-ml-body {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin: 0.4rem 0;
}
.sn-ml-countdown {
  font-weight: bold;
  color: var(--sn-ml-accent);
  font-family: "Courier New", monospace;
  font-size: 0.9rem;
}
.sn-ml-chip {
  background: var(--sn-ml-accent);
  color: #fff;
  padding: 0.2rem 0.4rem;
  border-radius: 12px;
  font-size: 0.7rem;
  font-weight: 500;
}
.sn-ml-meta {
  display: flex;
  align-items: center;
  gap: 0.3rem;
  font-size: 0.75rem;
  color: var(--sn-ml-meta);
  margin: 0.5rem 0;
}
.sn-ml-meta i {
  color: var(--sn-ml-accent);
}
.sn-ml-actions {
  margin-top: 0.8rem;
  padding-top: 0.5rem;
  border-top: 1px solid var(--sn-ml-card-border);
}
.sn-ins-menu-lateral .sn-ins-badge,
.sn-ins-menu-lateral .sn-open-badge {
  width: 100% !important;
  min-width: auto !important;
  text-align: center;
  font-size: 0.75rem !important;
  padding: 0.4rem 0.6rem !important;
  border-radius: 6px !important;
}
.sn-ins-menu-lateral .sn-loading {
  padding: 0.4rem;
  background: #333;
  border-radius: 4px;
  font-size: 0.75rem;
  color: var(--sn-ml-meta);
  text-align: center;
}
#sn-ml-toggle-mobile {
  position: fixed;
  top: 80px;
  right: 1rem;
  background: var(--sn-ml-accent);
  color: #fff;
  border: none;
  border-radius: 50px;
  padding: 0.6rem 0.8rem;
  font-size: 0.9rem;
  cursor: pointer;
  z-index: 10001;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
  display: none;
  font-weight: 600;
  transition: all 0.3s ease;
}
#sn-ml-toggle-mobile:hover {
  background: #228a1f;
  transform: scale(1.05);
}
}

@layer sn.core {
@media (max-width: 768px) {
  #sn-ml-toggle-mobile {
    display: block !important;
  }
  body.sn-menu-open::before {
    content: "";
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.5);
    z-index: 9998;
  }
}
}

@layer sn.core {
@keyframes pulse {
  0% {
    transform: scale(1);
  }
  50% {
    transform: scale(1.05);
  }
  100% {
    transform: scale(1);
  }
}
.sn-ml-countdown {
  animation: pulse 2s infinite;
}
#sn-menu-lat::-webkit-scrollbar {
  width: 6px;
}
#sn-menu-lat::-webkit-scrollbar-track {
  background: var(--sn-ml-bg);
}
#sn-menu-lat::-webkit-scrollbar-thumb {
  background: var(--sn-ml-card-border);
  border-radius: 3px;
}
#sn-menu-lat::-webkit-scrollbar-thumb:hover {
  background: var(--sn-ml-accent);
}
.sn-ses-box {
  display: none;
  animation: snFade 0.25s ease;
}
.sn-ses-box.on {
  display: block;
}
@keyframes snFade {
  from {
    opacity: 0;
    transform: translateY(4px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
table.sn-det-tab {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.72rem;
  margin: 0 0 10px;
  table-layout: fixed;
}
table.sn-det-tab th,
table.sn-det-tab td {
  padding: 4px 6px;
  border: 1px solid #333;
  text-align: left;
  word-break: break-word;
}
table.sn-det-tab th {
  background: #1f1f1f;
  font-weight: 600;
}
table.sn-det-tab tr:nth-child(even) td {
  background: #181818;
}
table.sn-det-tab tr:nth-child(odd) td {
  background: #151515;
}
}

@layer sn.core {
@media (max-width: 700px) {
  .sn-tabs-ses {
    gap: 4px;
  }
  .sn-tabs-ses li {
    flex: 1 1 auto;
    justify-content: center;
    padding: 5px 4px;
    font-size: 0.68rem;
  }
  table.sn-det-tab {
    font-size: 0.65rem;
  }
  table.sn-det-tab th,
  table.sn-det-tab td {
    padding: 3px 4px;
  }
}
}

@layer sn.core {
.sn-eventos-skin {
  font-family: var(--sn-font-sans, "Inter", Arial, sans-serif);
  color: var(--sn-color-text, #e0e0e0);
  --sn-gray-med: var(--sn-color-border, #2a2a2a);
  --sn-gray-light: var(--sn-color-surface, #161616);
  --sn-eventos-panel-bg: var(--sn-color-surface-alt, #0e0e0e);
}
.sn-tz-note {
  font-size: 0.75rem;
  color: rgba(255, 255, 255, 0.7);
  margin: 6px 0 10px;
}
.sn-eventos-skin .sn-panel {
  font-family: var(--sn-font-sans, "Inter", Arial, sans-serif) !important;
  color: var(--sn-color-text);
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
  overflow: hidden;
}
.sn-eventos-skin .sn-view {
  width: 100%;
}
.sn-eventos-skin .sn-view-horarios {
  display: none;
}
.sn-eventos-skin .sn-serie {
  margin-bottom: 2rem;
  padding: 1rem;
  border: 1px solid var(--sn-gray-med, var(--sn-color-border, #2a2a2a));
  border-radius: var(--sn-radius-lg, 12px);
  background: var(
    --sn-eventos-panel-bg,
    var(--sn-color-surface-alt, #0e0e0e)
  ) !important;
  box-shadow: var(--sn-shadow-sm, 0 4px 12px rgba(0, 0, 0, 0.35));
}
.sn-eventos-skin .sn-no-events {
  background: var(--sn-color-surface, #121212);
  color: var(--sn-color-text, #fff);
  padding: 1rem;
  text-align: center;
  border-radius: var(--sn-radius);
  font-size: 1rem;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
}
.sn-eventos-skin .sn-no-events i {
  font-size: 1.2rem;
}
.sn-eventos-skin .sn-nota-pista {
  display: block;
  font-size: 0.78em;
  color: #bcbcbc;
  margin-top: 2px;
  white-space: pre-line;
}
.sn-eventos-skin .sn-btn-detalle-nota {
  margin-left: 6px;
  display: inline-block;
  background: var(--sn-grad-theme, linear-gradient(135deg, #c90d05, #8f0700));
  border: 1px solid var(--sn-theme-primary-accent, #7a0500);
  color: #fff;
  border-radius: var(--sn-radius-sm, 6px);
  padding: 2px 8px;
  font-size: 12px;
  line-height: 1.2;
  cursor: pointer;
  transition: filter 0.18s ease;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.35);
}
.sn-eventos-skin .sn-btn-detalle-nota:hover {
  filter: brightness(1.08);
}
.sn-eventos-skin .sn-nota-contenido {
  color: var(--sn-text, #e0e0e0);
}
.sn-eventos-skin .sn-modal {
  position: fixed;
  inset: 0;
  z-index: 9999;
}
.sn-eventos-skin .sn-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.65);
}
.sn-eventos-skin .sn-modal__dialog {
  position: relative;
  width: min(720px, 92vw);
  margin: 8vh auto;
  background: #1e1e1e;
  color: #fff;
  border-radius: 8px;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.5);
  overflow: hidden;
}
.sn-eventos-skin .sn-modal__header,
.sn-eventos-skin .sn-modal__footer {
  padding: 0.75rem 1rem;
  border-bottom: 1px solid #333;
}
.sn-eventos-skin .sn-modal__footer {
  border-top: 1px solid #333;
  border-bottom: 0;
  text-align: right;
}
.sn-eventos-skin .sn-modal__title {
  margin: 0;
  font-size: 1.05rem;
}
.sn-eventos-skin .sn-modal__close {
  margin-left: auto;
  background: transparent;
  border: 0;
  color: #fff;
  font-size: 1.4rem;
  line-height: 1;
  cursor: pointer;
}
.sn-eventos-skin .sn-modal__close:hover {
  filter: brightness(1.2);
}
.sn-eventos-skin .sn-modal__body {
  padding: 1rem;
  max-height: 65vh;
  overflow: auto;
}
.sn-toggle {
  display: flex !important;
  justify-content: flex-end !important;
  align-items: center !important;
  margin-bottom: 0 !important;
  gap: 1.5rem !important;
  color: var(--sn-text);
}
.sn-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  margin: 0 0 1rem 0;
}
.sn-title {
  margin: 0;
  font-size: 1.4rem;
  line-height: 1.2;
}
.sn-toggle-icons {
  display: flex;
  gap: 0.5rem;
}
.sn-toggle-btn {
  background: #1f1f1f;
  border: 1px solid #2a2a2a;
  color: var(--sn-color-text-soft, #b5b5b5);
  font-size: 1.05rem;
  padding: 0.28rem 0.62rem;
  border-radius: var(--sn-radius-btn, 10px);
  cursor: pointer;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
  transition:
    background 0.18s,
    color 0.18s,
    box-shadow 0.18s,
    border-color 0.18s;
  position: relative;
}
.sn-toggle-btn:before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  box-shadow: 0 0 0 0 rgba(201, 13, 5, 0.4);
  transition: box-shadow 0.35s;
  pointer-events: none;
}
.sn-toggle-btn.on,
.sn-toggle-btn:hover {
  background: var(--sn-grad-theme, linear-gradient(135deg, #c90d05, #9e0a03));
  color: #fff;
  border-color: var(--sn-theme-primary-accent, #9e0a03);
  box-shadow: 0 2px 10px -2px rgba(201, 13, 5, 0.55);
}
.sn-toggle-btn.on:before {
  box-shadow: 0 0 0 4px rgba(201, 13, 5, 0.25);
}
.sn-toggle-btn:focus-visible {
  outline: 2px solid var(--sn-theme-primary, #c90d05);
  outline-offset: 2px;
}
.sn-table {
  width: 100% !important;
  border-collapse: separate !important;
  border-spacing: 0 0.65rem !important;
  table-layout: auto !important;
  color: var(--sn-text);
}
.sn-table thead {
  background: var(--sn-surface) !important;
}
.sn-table thead th {
  padding: 0.5rem 0.75rem !important;
  text-align: left !important;
  font-size: 0.85rem !important;
}
.sn-table tbody tr {
  background: var(--sn-gray-light) !important;
  border: 1px solid var(--sn-gray-med) !important;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.15);
  overflow: hidden;
}
.sn-table tbody tr td {
  padding: 0.65rem 0.75rem !important;
  vertical-align: middle !important;
  line-height: 1.35;
  white-space: normal;
  word-break: break-word;
}
.sn-table .sn-fecha {
  display: block;
  font-weight: 600;
  white-space: nowrap;
}
.sn-table .countdown {
  display: block;
  margin-top: 2px;
}
.sn-table.sn-table-serie td:nth-child(1) {
  width: 28%;
}
.sn-table.sn-table-serie td:nth-child(2) {
  width: 46%;
}
.sn-table.sn-table-serie td:nth-child(3) {
  width: 26%;
}
.sn-table.sn-horas td:nth-child(1) {
  width: 6%;
}
.sn-table.sn-horas td:nth-child(2) {
  width: 18%;
}
.sn-table.sn-horas td:nth-child(3) {
  width: 16%;
}
.sn-table.sn-horas td:nth-child(4) {
  width: 20%;
}
.sn-table.sn-horas td:nth-child(5) {
  width: 24%;
}
.sn-table.sn-horas td:nth-child(6) {
  width: 16%;
}
.sn-table td.sn-accion,
.sn-table th.sn-accion {
  text-align: center;
}
.sn-practice .sn-btn-mini {
  min-width: 55px;
  margin-right: 0.12rem;
  margin-bottom: 0.05rem;
  font-size: 0.72em;
  height: 18px;
  min-height: 18px;
  padding: 0 0.5em;
  border: none !important;
}
.sn-icon-dl,
.sn-dl-mini {
  color: var(--sn-blue) !important;
  font-size: 1em;
  cursor: pointer;
  margin-left: 0.3em;
}
.sn-inicia-label,
.sn-countdown-evento {
  font-size: 0.78em !important;
  color: var(--sn-text-soft);
  font-weight: 400;
  display: inline-block;
  vertical-align: middle;
}
.sn-tabs-ses {
  display: flex;
  gap: 0.2rem;
  flex-wrap: wrap;
  margin: 0 0 1rem;
  list-style: none;
  padding: 0;
  align-items: flex-start;
}
.sn-tabs-ses li {
  cursor: pointer;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
  background: var(--sn-surface);
  border: 1px solid var(--sn-gray-med);
  border-radius: 20px;
  padding: 0.22rem 0.7rem;
  font-size: 0.8rem;
  font-weight: 600;
  transition: 0.2s;
  display: flex;
  align-items: center;
  gap: 0.3rem;
  margin-bottom: 0 !important;
  min-height: 28px;
  line-height: 1.2;
  vertical-align: middle;
}
.sn-tabs-ses li.on {
  background: var(--sn-grad-theme, linear-gradient(135deg, #c90d05, #9e0a03));
  border-color: var(--sn-theme-primary-accent, #9e0a03);
  color: #fff;
  box-shadow: 0 2px 8px -2px rgba(201, 13, 5, 0.55);
}
.sn-tabs-ses li i {
  margin-right: 0.2rem;
  font-size: 1.1em;
  vertical-align: middle;
}
.sn-serie:nth-of-type(odd) {
  background: #232323 !important;
}
.sn-serie:nth-of-type(even) {
  background: #181818 !important;
}
.flag {
  width: 24px;
  height: 16px;
  -o-object-fit: cover;
     object-fit: cover;
  margin-right: 0.4rem;
  border-radius: 2px;
  vertical-align: middle;
}
.sn-img-serie {
  width: 32px;
  height: 32px;
  border-radius: 4px;
  -o-object-fit: cover;
     object-fit: cover;
}
.sn-head {
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
  background: var(--sn-gray-light, #1e1e1e);
  border: 1px solid var(--sn-gray-med, #3d3d3d);
  border-radius: 10px;
  padding: 1rem;
  color: var(--sn-text, #e0e0e0);
}
.sn-head-left {
  display: flex;
  gap: 1rem;
  flex: 1 1 280px;
  min-width: 0;
}
.sn-head-right {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
  font-size: 0.7rem;
  line-height: 1.25;
  min-width: 140px;
  color: var(--sn-text-soft, #bcbcbc);
}
.sn-head-img {
  width: 52px;
  height: 52px;
  border-radius: 6px;
  -o-object-fit: cover;
     object-fit: cover;
}
.sn-head-body {
  flex: 1;
}
.sn-head-title {
  margin: 0;
  font-size: 1.2rem;
}
.sn-head-desc {
  margin: 0.25rem 0 0.4rem;
  font-size: 0.85rem;
  color: var(--sn-text-soft);
}
.sn-head-event-name {
  margin: 0.2rem 0 0;
  font-size: 0.8rem;
  color: var(--sn-color-text-soft, #bdbdbd);
}
.sn-head-event-name i {
  margin-right: 0.3rem;
  color: #e74c3c;
}
.sn-head-event-flags {
  margin: 0.18rem 0 0.15rem;
  display: flex;
  gap: 0.4rem;
  align-items: center;
  flex-wrap: wrap;
}
.sn-head-event-flags .sn-chip {
  font-size: 0.72rem;
  padding: 0.16rem 0.5rem;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  background: rgba(255, 255, 255, 0.05);
}
.sn-head-event-flags .sn-chip-rank {
  color: #d8e7ff;
}
.sn-head-event-flags .sn-chip-elo {
  color: #ffe7b8;
}
.sn-head-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.6rem;
  margin: 0;
  padding: 0;
  list-style: none;
  font-size: 0.9rem;
  color: var(--sn-text-soft);
}
.sn-head-meta li i {
  margin-right: 0.3rem;
  color: var(--sn-blue);
}
.sn-practice {
  margin-top: 0.5rem;
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
  align-items: center;
}
.sn-practice strong {
  font-size: 0.85rem;
}
.sn-practice .sn-btn-mini,
.sn-practice .sn-btn-pass {
  height: 18px;
  font-size: 0.78rem;
  padding: 0 0.55rem;
}
.sn-table td.sn-accion,
.sn-table th.sn-accion {
  text-align: center !important;
}
.sn-btn-info,
.sn-horas .sn-btn-info {
  background: var(--sn-grad-danger, linear-gradient(135deg, #7a2323, #3a1616));
  font-size: 0.78rem;
  padding: 0.28rem 0.6rem;
  min-height: 30px;
  border-radius: 8px;
}
.sn-btn-info.bottom {
  min-height: 32px;
}
.sn-info-caret {
  font-size: 0.68rem;
  opacity: 0.85;
  display: inline-block;
  transition: transform 0.2s ease;
}
.sn-btn-info.is-open .sn-info-caret {
  transform: rotate(180deg);
}
.sn-show-more-wrap {
  text-align: center;
  margin-top: 0.1rem;
}
.sn-show-more-wrap:empty {
  display: none;
}
.sn-eventos-skin .sn-ins-container.sn-layout .sn-main-btn {
  min-height: 40px;
  padding: 5px 8px;
  font-size: 0.85rem;
}
.sn-eventos-skin .sn-ins-container.sn-layout .sn-main-top {
  font-size: 0.82rem;
  line-height: 1.05;
}
.sn-eventos-skin .sn-ins-container.sn-layout .sn-main-bottom {
  font-size: 0.76rem;
  margin-top: 3px;
}
.sn-eventos-skin .sn-ins-container.sn-layout .sn-side-btn {
  width: 46px;
  min-width: 42px;
  max-width: 52px;
  min-height: 40px;
  padding: 3px 0 5px;
}
.sn-eventos-skin .sn-ins-container.sn-layout .sn-side-btn i {
  font-size: 14px;
}
.sn-eventos-skin .sn-ins-container.sn-layout .sn-side-count {
  font-size: 0.68rem;
}
.sn-eventos-skin .sn-ins[data-id] {
  min-height: 42px;
}
.sn-eventos-skin .sn-ins-container.sn-layout .sn-main-btn,
.sn-eventos-skin .sn-ins-container.sn-layout .sn-side-btn {
  transition: none !important;
}
.sn-card {
  background: var(--sn-gray-light);
  border-radius: 8px;
  margin-bottom: 1.2rem;
  padding: 1rem 1.2rem 0.5rem;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.12);
  border: 1px solid var(--sn-gray-med);
  font-size: 1em;
}
.sn-card h4 {
  margin: 0 0 0.7rem;
  font-size: 1.1rem;
  color: var(--sn-text);
  font-weight: 700;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.sn-card h4 i {
  color: var(--sn-blue);
  font-size: 1.1rem;
}
.sn-det-tab {
  width: 100%;
  border-collapse: collapse;
  margin-bottom: 1rem;
  font-size: 0.92rem;
  background: transparent;
  border: 1px solid var(--sn-gray-med);
  border-radius: 6px;
}
.sn-det-tab th,
.sn-det-tab td {
  padding: 0.35rem 0.5rem;
  border-bottom: 1px solid var(--sn-gray-med);
  text-align: left;
  color: var(--sn-text);
}
.sn-det-tab th {
  background: var(--sn-surface);
  font-weight: 600;
}
.sn-det-tab tr:last-child td {
  border-bottom: none;
}
.sn-det-tab td:first-child {
  font-weight: 600;
}
.badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  border-radius: 20px;
  font-weight: bold;
  font-size: 10px;
  color: #fff;
}
.badge-principiante {
  background: #6c757d;
  border: 2px solid #5a6268;
}
.badge-cobre {
  background: #b87333;
  border: 2px solid #8c6239;
}
.badge-bronce {
  background: #cd7f32;
  border: 2px solid #a86e32;
}
.badge-plata {
  background: #c0c0c0;
  border: 2px solid #a0a0a0;
  color: #333;
}
.badge-oro {
  background: #ffd700;
  border: 2px solid #d4af37;
  color: #333;
}
.badge-platino {
  background: #e5e4e2;
  border: 2px solid #c0c0c0;
  color: #333;
}
.badge-diamante {
  background: #b9f2ff;
  border: 2px solid #89c5cc;
  color: #333;
}
.badge-elite {
  background: #4b0082;
  border: 2px solid #2e004d;
}
.sn-loading {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 2rem;
  color: var(--sn-text);
  font-size: 1rem;
}
.sn-msg {
  padding: 1rem;
  margin: 1rem 0;
  border-radius: 6px;
  text-align: center;
}
.sn-msg.sn-err {
  background: #dc3545;
  color: #fff;
  border: 1px solid #b02a37;
}
.sn-msg.sn-info {
  background: #17a2b8;
  color: #fff;
  border: 1px solid #138496;
}
.sn-btn {
  display: inline-block;
  padding: 0.5rem 1rem;
  margin-top: 0.5rem;
  background: var(--sn-red);
  color: #fff;
  text-decoration: none;
  border-radius: 4px;
  cursor: pointer;
  font-size: 0.9rem;
}
.sn-btn:hover {
  filter: brightness(1.1);
}
.extra-event {
  display: none;
}
}

@layer sn.core {
@media (max-width: 700px) {
  html {
    font-size: 91%;
  }
  #sn-eventos-container .sn-panel,
  #sn-eventos-container .sn-serie {
    padding: 0;
    margin: 0;
    width: 100%;
    max-width: 100vw;
    box-sizing: border-box;
  }
  .sn-panel {
    overflow-x: hidden;
    padding: 0.2rem 0.1rem;
    max-width: 100vw;
  }
  .sn-serie {
    background: #2a2a2a;
    margin-bottom: 0.8rem;
    border-radius: 10px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
    padding: 0.5rem 0.1rem 0.2rem;
    max-width: 99vw;
  }
  .sn-serie:nth-of-type(odd) {
    background: #232323 !important;
  }
  .sn-serie:nth-of-type(even) {
    background: #181818 !important;
  }
  .sn-table.sn-table-serie,
  .sn-table.sn-horas {
    width: 100%;
    min-width: 0;
    font-size: 0.93em;
    background: transparent;
    table-layout: fixed;
  }
  .sn-table.sn-table-serie thead,
  .sn-table.sn-horas thead {
    display: none;
  }
  .sn-table.sn-table-serie tbody,
  .sn-table.sn-horas tbody {
    display: block;
    width: 100%;
  }
  .sn-table.sn-table-serie tr,
  .sn-table.sn-horas tr {
    display: flex;
    flex-wrap: wrap;
    gap: 0.05rem;
    padding: 0.04rem 0;
    margin-bottom: 0.09rem;
    border: 1px solid var(--sn-gray-med);
    border-radius: 6px;
    background: var(--sn-gray-light);
    box-sizing: border-box;
    width: 100%;
    max-width: 100vw;
  }
  .sn-table.sn-table-serie td,
  .sn-table.sn-horas td {
    flex: 1 1 50%;
    min-width: 0;
    padding: 0.04rem 0.05rem;
    display: flex;
    align-items: center;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    font-size: 0.91em;
    border: none;
    background: transparent;
  }
  .sn-table.sn-table-serie td:before,
  .sn-table.sn-horas td:before {
    content: attr(data-label) ": ";
    font-weight: bold;
    margin-right: 0.13rem;
    color: var(--sn-blue);
    flex-shrink: 0;
    font-size: 0.91em;
  }
  .sn-table.sn-table-serie td,
  .sn-table.sn-horas td {
    flex: 1 1 50%;
    justify-content: space-between;
    text-align: right;
    font-size: 0.93em;
  }
  .sn-head {
    flex-direction: column;
    gap: 0.6rem;
  }
  .sn-head-left {
    flex-direction: row;
  }
  .sn-head-img {
    width: 44px;
    height: 44px;
  }
  .sn-head-title {
    font-size: 1.05rem;
  }
  .sn-head-desc {
    font-size: 0.9rem;
  }
  .sn-toggle {
    flex-wrap: wrap;
    gap: 0.15rem;
    padding: 0.2rem 0;
  }
  .sn-toggle-btn {
    flex: 1 1 auto;
    text-align: center;
    padding: 0.12rem 0.28rem;
    font-size: 0.95rem;
  }
  .sn-practice .sn-btn-mini,
  .sn-btn-prac,
  .sn-btn-pass {
    width: 100%;
    min-width: 0;
    margin-right: 0;
    font-size: 0.95em;
    height: 22px;
    min-height: 22px;
    padding: 0 0.5em;
  }
  .sn-show-more {
    width: 100%;
    max-width: 320px;
    margin: 0 auto;
    font-size: 0.95em;
    height: 22px;
    min-height: 22px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
  }
  .sn-card {
    padding: 0.5rem 0.3rem 0.3rem;
    margin-bottom: 0.5rem;
    font-size: 1em;
    border-radius: 8px;
    border: 1px solid var(--sn-gray-med);
    background: var(--sn-gray-light);
  }
  .sn-card h4 {
    font-size: 1em;
  }
  .sn-det-tab {
    font-size: 0.98em;
    border-radius: 6px;
    border: 1px solid var(--sn-gray-med);
    background: var(--sn-surface);
  }
  .sn-det-tab th,
  .sn-det-tab td {
    padding: 0.18rem 0.12rem;
    font-size: 0.98em;
    word-break: break-word;
  }
  .sn-det-tab .sn-icon-dl {
    font-size: 1.2rem;
  }
  .sn-icon-dl {
    color: var(--sn-blue) !important;
  }
  .sn-head {
    flex-direction: row;
    flex-wrap: wrap;
    gap: 0.6rem;
    align-items: flex-start;
  }
  .sn-head-left {
    flex: 1 1 60%;
    min-width: 0;
    flex-direction: column;
    gap: 0.2rem;
  }
  .sn-head-img {
    width: 44px;
    height: 44px;
    margin-bottom: 0.2rem;
  }
  .sn-head-body {
    width: 100%;
  }
  .sn-head-right {
    flex: 1 1 40%;
    min-width: 120px;
    align-items: flex-start;
    justify-content: flex-start;
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
    font-size: 0.8rem;
    text-align: center;
    margin-left: auto;
  }
  .sn-practice {
    width: 100%;
    flex-direction: column;
    align-items: flex-start;
    gap: 0.2rem;
    margin-top: 0.3rem;
  }
  .sn-practice .sn-btn-mini {
    width: 100%;
    min-width: 0;
    margin-right: 0;
    font-size: 0.95em;
    height: 28px;
    padding: 0.18rem 0.55rem;
  }
  .sn-table.sn-table-serie td,
  .sn-table.sn-horas td {
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
    text-align: left;
  }
  .sn-table.sn-table-serie td:before,
  .sn-table.sn-horas td:before {
    flex: 1 1 50%;
    text-align: left;
    margin-right: 0.5em;
    min-width: 80px;
  }
  .sn-table.sn-table-serie td,
  .sn-table.sn-horas td {
    flex: 1 1 50%;
    justify-content: space-between;
    text-align: right;
    font-size: 0.95em;
  }
  .sn-table.sn-table-serie tr.extra-event,
  .sn-table.sn-horas tr.extra-event {
    display: none !important;
  }
  .sn-table.sn-table-serie,
  .sn-table.sn-horas {
    max-width: 100vw;
    overflow-x: auto;
  }
  .sn-show-more {
    width: 100%;
    max-width: 320px;
    margin: 0 auto;
    font-size: 0.95em;
  }
  .sn-btn-info,
  .sn-horas .sn-btn-info {
    min-height: 28px;
    font-size: 0.74rem;
    padding: 0.2rem 0.48rem;
  }
  .sn-detalle-row td:before {
    content: "" !important;
    display: none !important;
  }
  .sn-detalle-row td {
    flex: 1 1 100% !important;
    text-align: left !important;
  }
}
}

@layer sn.core {
.sn-nitro-plus {
  --np-bg: #0b0f17;
  --np-surface: #101622;
  --np-surface-2: #151d2c;
  --np-border: rgba(255, 255, 255, 0.12);
  --np-text: #fff;
  --np-muted: rgba(255, 255, 255, 0.76);
  color: var(--np-text);
}
.sn-nitro-plus .sn-np-loading,
.sn-nitro-plus .sn-np-empty {
  padding: 14px 16px;
  background: var(--np-surface);
  border: 1px solid var(--np-border);
  border-radius: 12px;
}
.sn-nitro-plus .sn-np-header {
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
  gap: 14px;
  margin-bottom: 14px;
}
.sn-nitro-plus .sn-tz-note {
  font-size: 0.75rem;
  color: var(--np-muted);
  margin: 6px 0 12px;
}
.sn-nitro-plus .sn-np-profile {
  display: flex;
  align-items: center;
  gap: 12px;
  background: linear-gradient(160deg, #0f1628, #111a2d);
  border: 1px solid var(--np-border);
  padding: 12px 14px;
  border-radius: 12px;
  min-width: 280px;
}
.sn-nitro-plus .sn-np-avatar {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  -o-object-fit: cover;
     object-fit: cover;
  border: 1px solid rgba(255, 255, 255, 0.22);
}
.sn-nitro-plus .sn-np-name {
  font-size: 1.05rem;
  font-weight: 800;
  line-height: 1.1;
}
.sn-nitro-plus .sn-np-sub {
  opacity: 0.8;
  font-size: 0.82rem;
}
.sn-nitro-plus .sn-np-kpis {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(130px, 1fr));
  gap: 10px;
  flex: 1 1 360px;
}
.sn-nitro-plus .sn-np-kpi {
  background: var(--np-surface);
  border: 1px solid var(--np-border);
  border-radius: 12px;
  padding: 10px 12px;
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-height: 78px;
  cursor: pointer;
  transition:
    border-color 0.18s ease,
    transform 0.18s ease;
}
.sn-nitro-plus .sn-np-kpi:hover {
  border-color: rgba(201, 13, 5, 0.45);
  transform: translateY(-1px);
}
.sn-nitro-plus .sn-np-kpi strong {
  font-size: 1.1rem;
  line-height: 1.05;
}
.sn-nitro-plus .sn-np-layout {
  display: grid;
  grid-template-columns: 230px minmax(0, 1fr);
  gap: 16px;
  margin-top: 12px;
}
.sn-nitro-plus .sn-np-sidebar {
  position: sticky;
  top: 80px;
  height: -moz-fit-content;
  height: fit-content;
  background: var(--np-surface);
  border: 1px solid var(--np-border);
  border-radius: 12px;
  padding: 12px;
}
.sn-nitro-plus .sn-np-content {
  min-width: 0;
}
.sn-nitro-plus .sn-np-tabs {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.sn-nitro-plus .sn-np-tab {
  -webkit-appearance: none;
  -moz-appearance: none;
       appearance: none;
  background: var(--np-surface-2) !important;
  border: 1px solid var(--np-border) !important;
  color: #fff !important;
  padding: 10px 12px;
  border-radius: var(--sn-radius-btn, 10px);
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 8px;
  text-align: left;
  font-weight: 700;
}
.sn-nitro-plus .sn-np-tab.active {
  background: var(
    --sn-grad-theme,
    linear-gradient(135deg, #c90d05, #9e0a03)
  ) !important;
  border-color: var(--sn-theme-primary-accent, #7d0803) !important;
  color: #fff !important;
}
.sn-nitro-plus .sn-np-badge-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 18px;
  height: 18px;
  padding: 0 5px;
  border-radius: 999px;
  background: #fff;
  color: #111;
  font-size: 0.72rem;
  font-weight: 800;
}
.sn-nitro-plus .sn-np-section {
  margin: 18px 0;
  padding: 12px;
  border-radius: 12px;
  border: 1px solid var(--np-border);
  background: linear-gradient(180deg, #0c1322 0%, #0b101a 100%);
}
.sn-nitro-plus .sn-np-title {
  margin: 0 0 10px;
  font-size: 1.02rem;
}
.sn-nitro-plus .sn-np-section-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 8px;
}
.sn-nitro-plus .sn-np-cards {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 10px;
}
.sn-nitro-plus .sn-np-card {
  background: var(--np-surface);
  border: 1px solid var(--np-border);
  border-radius: 12px;
  padding: 10px;
}
.sn-nitro-plus .sn-np-card-head {
  display: flex;
  gap: 10px;
}
.sn-nitro-plus .sn-np-card-head img {
  width: 60px;
  height: 60px;
  border-radius: 8px;
  -o-object-fit: cover;
     object-fit: cover;
  background: #0b0b0b;
}
.sn-nitro-plus .sn-np-card-meta {
  margin-top: 6px;
  font-size: 0.85rem;
  opacity: 0.85;
}
.sn-nitro-plus .sn-np-card-actions {
  margin-top: 8px;
}
.sn-nitro-plus .sn-np-badge {
  display: inline-block;
  margin-top: 4px;
  padding: 2px 8px;
  border-radius: 999px;
  background: rgba(201, 13, 5, 0.18);
  color: #ffd7d3;
  border: 1px solid rgba(201, 13, 5, 0.45);
  font-size: 0.75rem;
}
.sn-nitro-plus .sn-np-licencias {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 10px;
}
.sn-nitro-plus .sn-np-lic-card {
  background: var(--np-surface);
  border: 1px solid var(--np-border);
  border-radius: 10px;
  padding: 10px;
}
.sn-nitro-plus .sn-np-lic-sim {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 6px;
}
.sn-nitro-plus .sn-np-lic-sim img {
  width: 22px;
  height: 22px;
  -o-object-fit: contain;
     object-fit: contain;
}
.sn-nitro-plus .sn-np-lic-meta {
  display: flex;
  gap: 10px;
  font-size: 0.85rem;
  opacity: 0.85;
}
.sn-nitro-plus .sn-np-table-wrap {
  width: 100%;
  max-width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
.sn-nitro-plus .sn-np-table {
  width: 100%;
  min-width: 680px;
  border-collapse: collapse;
  background: #0d1320;
  border: 1px solid var(--np-border);
  border-radius: 10px;
  overflow: hidden;
}
.sn-nitro-plus .sn-np-table th,
.sn-nitro-plus .sn-np-table td {
  padding: 10px 12px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
  text-align: left;
  font-size: var(--sn-font-size-sm, 0.82rem);
}
.sn-nitro-plus .sn-np-table thead th {
  font-weight: 700;
  font-size: 0.76rem;
  text-transform: uppercase;
  letter-spacing: 0.02em;
  background: #1a202b;
  color: #fff;
}
.sn-nitro-plus .sn-np-unread td {
  background: rgba(201, 13, 5, 0.08);
  border-bottom-color: rgba(201, 13, 5, 0.25);
  font-weight: 600;
}
.sn-nitro-plus .sn-np-read td {
  opacity: 0.92;
}
.sn-nitro-plus .sn-np-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  background: var(
    --sn-grad-theme,
    linear-gradient(135deg, #c90d05, #9e0a03)
  ) !important;
  border: 1px solid var(--sn-theme-primary-accent, #7d0803) !important;
  color: #fff !important;
  padding: 7px 12px;
  border-radius: var(--sn-radius-btn, 10px);
  cursor: pointer;
  box-shadow: 0 2px 6px rgba(201, 13, 5, 0.35);
}
.sn-nitro-plus .sn-np-btn[disabled] {
  opacity: 0.5;
  cursor: not-allowed;
}
.sn-nitro-plus .sn-np-btn-ghost {
  background: var(--np-surface-2) !important;
  border: 1px solid var(--np-border) !important;
  color: #fff !important;
  box-shadow: none !important;
}
.sn-nitro-plus .sn-np-btn-ghost.active {
  background: var(
    --sn-grad-theme,
    linear-gradient(135deg, #c90d05, #9e0a03)
  ) !important;
  border-color: var(--sn-theme-primary-accent, #7d0803) !important;
}
.sn-nitro-plus .sn-np-pager {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 10px;
}
.sn-nitro-plus .sn-np-select {
  width: 100%;
  max-width: 360px;
  margin-bottom: 10px;
  background: #0f1218;
  color: #fff;
  border: 1px solid var(--np-border);
  padding: 8px 10px;
  border-radius: 8px;
}
.sn-nitro-plus .sn-np-modal {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.72);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 99999;
  padding: 20px;
}
.sn-nitro-plus .sn-np-modal-content {
  background: var(--np-surface);
  border: 1px solid var(--np-border);
  border-radius: 12px;
  max-width: 900px;
  width: 100%;
  max-height: 80vh;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}
.sn-nitro-plus .sn-np-modal-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 10px 12px;
  border-bottom: 1px solid var(--np-border);
}
.sn-nitro-plus .sn-np-modal-body {
  padding: 12px;
  overflow: auto;
}
.sn-nitro-plus .sn-np-tab-label {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.sn-nitro-plus .sn-np-tab-label i {
  width: 16px;
  text-align: center;
}
.sn-nitro-plus .wd-tags-mb {
  margin-bottom: 0 !important;
}
}

@layer sn.core {
@media (max-width: 768px) {
  .sn-nitro-plus .sn-np-header {
    margin-bottom: 8px;
  }
  .sn-nitro-plus .sn-np-layout {
    display: flex;
    flex-direction: column;
    gap: 12px;
  }
  .sn-nitro-plus .sn-np-sidebar {
    position: static;
    order: 1;
    top: auto;
  }
  .sn-nitro-plus .sn-np-content {
    order: 2;
  }
  .sn-nitro-plus .sn-np-tabs {
    flex-direction: row;
    flex-wrap: nowrap;
    overflow-x: auto;
    padding-bottom: 6px;
    scrollbar-width: none;
  }
  .sn-nitro-plus .sn-np-tabs::-webkit-scrollbar {
    display: none;
  }
  .sn-nitro-plus .sn-np-tab {
    white-space: nowrap;
    min-width: -moz-fit-content;
    min-width: fit-content;
  }
  .sn-nitro-plus .sn-np-licencias {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .sn-nitro-plus .sn-np-cards {
    grid-template-columns: 1fr;
  }
  .sn-nitro-plus .sn-np-kpis {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
}

@layer sn.core {
@media (max-width: 600px) {
  .sn-nitro-plus .sn-np-kpi {
    min-height: 64px;
  }
}
}

@layer sn.core {
body .sn-wrapper {
  background: linear-gradient(
    135deg,
    rgba(13, 16, 24, 0.97),
    rgba(7, 10, 15, 0.98)
  );
  border: 1px solid rgba(255, 255, 255, 0.04);
  border-radius: 22px;
  padding: 28px 34px 40px;
  box-shadow: 0 20px 55px rgba(0, 0, 0, 0.55);
  max-width: 1100px;
  margin: 0 auto 42px;
}
.sn-title {
  margin: 0;
  font-size: 1.85rem;
  font-weight: 700;
  color: #f4f5ff;
}
.sn-subtitle {
  color: rgba(245, 247, 255, 0.75);
  font-size: 1rem;
  max-width: 720px;
}
.sn-progress {
  background: rgba(255, 255, 255, 0.05);
  height: 26px;
  border-radius: 999px;
  margin: 18px 0 0.75rem;
  position: relative;
  border: 1px solid rgba(255, 255, 255, 0.08);
  box-shadow: inset 0 0 0 1px rgba(0, 0, 0, 0.2);
}
.sn-progress.error .sn-bar {
  background: var(--sn-danger, #dc3545) !important;
}
.sn-progress.error .sn-text {
  color: var(--sn-color-text, #fff) !important;
  font-size: 1rem !important;
  font-weight: bold !important;
}
.sn-bar {
  background: var(--sn-success, #28a745);
  height: 100%;
  border-radius: 4px 0 0 4px;
  transition: width 0.3s ease;
}
.sn-text {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  color: var(--sn-color-text, #e0e0e0);
  font-weight: bold;
  line-height: 24px;
}
.sn-subtext {
  margin: 0 0 1rem;
  font-size: 0.9rem;
  color: var(--sn-color-text-soft, #ccc);
}
.sn-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1rem;
  margin-bottom: 1.2rem;
  background: rgba(255, 255, 255, 0.02);
  border-radius: 18px;
  border: 1px solid rgba(255, 255, 255, 0.02);
  padding: 18px;
  box-shadow: 0 12px 30px rgba(0, 0, 0, 0.35);
}
}

@layer sn.core {
@media (max-width: 768px) {
  .sn-row {
    grid-template-columns: 1fr;
  }
}
}

@layer sn.core {
.sn-full {
  grid-column: 1/-1;
}
.sn-form input,
.sn-form select,
.sn-form textarea,
.select2-container .select2-selection--single {
  width: 100% !important;
  height: 44px !important;
  background: rgba(15, 20, 30, 0.85) !important;
  border: 1px solid rgba(255, 255, 255, 0.08) !important;
  border-radius: 14px !important;
  padding: 10px 16px !important;
  color: #f5f7ff !important;
}
.sn-form textarea {
  height: auto !important;
  min-height: 100px;
  resize: vertical;
  border-radius: 12px !important;
}
.select2-container .select2-selection--single {
  display: flex !important;
  align-items: center !important;
}
.select2-container .select2-selection--single .select2-selection__rendered {
  padding: 0 !important;
  line-height: 1.4 !important;
}
.select2-container .select2-selection--single .select2-selection__arrow {
  height: 44px !important;
  right: 8px !important;
}
.sn-row label {
  display: flex;
  flex-direction: column;
  color: var(--sn-color-text, #e0e0e0);
}
.sn-note {
  margin-top: 0.5rem;
  font-size: 0.85rem;
  color: var(--sn-color-text-soft, #aaa);
  line-height: 1.4;
}
.sn-note a {
  color: var(--sn-primary, #c90d05);
  text-decoration: none;
}
.sn-note a:hover {
  text-decoration: underline;
}
.sn-form > .sn-row:nth-of-type(1),
.sn-form > .sn-row:nth-of-type(3) {
  grid-template-columns: repeat(2, 1fr);
}
.sn-form h3 {
  margin: 2rem 0 0.6rem;
  font-size: 1.2rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: #f6f7fc;
  position: relative;
}
.sn-form h3::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -8px;
  width: 90px;
  height: 3px;
  background: linear-gradient(90deg, #c90d05, transparent);
  border-radius: 999px;
}
.sn-save-top,
.sn-save-bottom {
  display: flex;
  justify-content: flex-end;
  margin: 12px 0 18px;
}
.sn-label {
  display: flex;
  flex-direction: column;
  gap: 6px;
  color: rgba(245, 247, 255, 0.85);
  font-weight: 600;
}
.sn-label[data-required="1"] {
  color: #ffb8b8;
}
.sn-save-top .sn-btn,
.sn-save-bottom .sn-btn {
  min-width: 180px;
  border-radius: 999px;
  font-size: 0.95rem;
  padding: 12px 24px;
  box-shadow: 0 12px 25px rgba(201, 13, 5, 0.35);
}
.sn-subtext {
  color: rgba(255, 255, 255, 0.65);
  margin-bottom: 0.85rem;
}
.sn-save-top,
.sn-save-bottom {
  display: flex;
  justify-content: flex-end;
  margin: 1rem 0;
}
.edad-toggle {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  cursor: pointer;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
  color: var(--sn-color-text, #e0e0e0);
  margin: 0.5rem 0 1rem;
  position: relative;
}
.edad-toggle input {
  opacity: 0;
  width: 0;
  height: 0;
  position: absolute;
}
.edad-slider {
  width: 50px;
  height: 24px;
  background: var(--sn-color-border, #555);
  border-radius: 24px;
  position: relative;
  transition: background 0.4s ease;
}
.edad-slider::before {
  content: "";
  position: absolute;
  width: 18px;
  height: 18px;
  background: var(--sn-color-text, #e0e0e0);
  border-radius: 50%;
  top: 3px;
  left: 3px;
  transition: transform 0.4s ease;
}
.edad-toggle input:checked + .edad-slider {
  background: var(--sn-success, #28a745);
}
.edad-toggle input:checked + .edad-slider::before {
  transform: translateX(26px);
}
.sn-form select,
.select2-container--default .select2-selection--single {
  background: var(--sn-color-surface-alt, #3a3a3a) !important;
  color: var(--sn-color-text, #e0e0e0) !important;
  border-color: var(--sn-color-border, #555) !important;
  border-radius: 24px !important;
}
.select2-container--default
  .select2-selection--single
  .select2-selection__rendered {
  color: #fff !important;
}
.select2-container--default
  .select2-selection--single
  .select2-selection__arrow
  b {
  border-color: #e0e0e0 transparent transparent transparent !important;
}
.select2-container--default .select2-dropdown {
  background: #3a3a3a !important;
  border-color: #555 !important;
  border-radius: 4px !important;
}
.select2-container--default .select2-results__option {
  color: var(--sn-color-text, #fff) !important;
  background: transparent !important;
}
.select2-container--default .select2-results__option--highlighted {
  background: var(--sn-color-border, #555) !important;
  color: var(--sn-color-text, #fff) !important;
}
.select2-container--default .select2-results__options {
  scrollbar-color: #555 #3a3a3a;
}
.select2-container--default .select2-results__options::-webkit-scrollbar {
  width: 6px;
}
.select2-container--default .select2-results__options::-webkit-scrollbar-thumb {
  background-color: #555;
  border-radius: 3px;
}
.select2-container--default .select2-results__options::-webkit-scrollbar-track {
  background: #3a3a3a;
}
.sn-wrapper .sn-select2-selection--dark.select2-selection--single {
  background: #2f2f2f !important;
  border-color: #565656 !important;
  color: #fff !important;
}
.sn-wrapper
  .sn-select2-selection--dark.select2-selection--single
  .select2-selection__rendered {
  color: #fff !important;
}
.sn-wrapper
  .sn-select2-selection--dark.select2-selection--single
  .select2-selection__placeholder {
  color: #cfcfcf !important;
}
.sn-wrapper
  .sn-select2-selection--dark.select2-selection--single
  .select2-selection__arrow
  b {
  border-color: #fff transparent transparent transparent !important;
}
.sn-wrapper .sn-select2-dropdown--dark.select2-dropdown {
  background: #2f2f2f !important;
  border-color: #565656 !important;
  color: #fff !important;
}
.sn-wrapper
  .sn-select2-dropdown--dark
  .select2-search--dropdown
  .select2-search__field {
  background: #262626 !important;
  color: #fff !important;
  border-color: #565656 !important;
  border-width: 1px !important;
  border-style: solid !important;
  border-radius: 24px !important;
}
.sn-wrapper .sn-select2-dropdown--dark .select2-search--dropdown {
  background: #2f2f2f !important;
  padding: 6px !important;
}
.sn-wrapper
  .sn-select2-dropdown--dark
  .select2-search--dropdown
  .select2-search__field::-moz-placeholder {
  color: #cfcfcf !important;
  opacity: 1 !important;
}
.sn-wrapper
  .sn-select2-dropdown--dark
  .select2-search--dropdown
  .select2-search__field::placeholder {
  color: #cfcfcf !important;
  opacity: 1 !important;
}
.sn-wrapper .sn-select2-dropdown--dark .select2-results__option,
.sn-wrapper
  .sn-select2-dropdown--dark
  .select2-results__option
  .select2-results__match {
  color: #fff !important;
}
.sn-wrapper .sn-select2-dropdown--dark .select2-results__option--highlighted,
.sn-wrapper .sn-select2-dropdown--dark .select2-results__option--selected {
  background: #444 !important;
  color: #fff !important;
}
.sn-wrapper
  .sn-select2-dropdown--dark
  .select2-results__option[aria-disabled="true"] {
  color: #9e9e9e !important;
}
.sn-wrapper .sn-select2-dropdown--dark .select2-results__group,
.sn-wrapper .sn-select2-selection--dark,
.sn-wrapper .sn-select2-selection--dark *,
.sn-wrapper .sn-select2-selection--dark .select2-selection__clear,
.sn-wrapper .sn-select2-dropdown--dark,
.sn-wrapper .sn-select2-dropdown--dark * {
  color: #fff !important;
}
.sn-form input.sn-empty,
.sn-form select.sn-empty,
.sn-empty + .select2-container .select2-selection--single {
  border-color: var(--sn-danger, #dc3545) !important;
  background: var(--sn-color-surface-alt, #3a3a3a) !important;
  color: var(--sn-color-text, #e0e0e0) !important;
  box-shadow: 0 0 0 2px rgba(220, 53, 69, 0.25) !important;
}
.sn-form input.sn-filled,
.sn-form select.sn-filled,
.sn-filled + .select2-container .select2-selection--single {
  border-color: var(--sn-success, #28a745) !important;
  background: var(--sn-color-surface-alt, #3a3a3a) !important;
  color: var(--sn-color-text, #e0e0e0) !important;
  box-shadow: 0 0 0 2px rgba(40, 167, 69, 0.25) !important;
}
.sn-row label[data-required="1"]::after {
  content: " *";
  color: var(--sn-danger, #dc3545);
  font-weight: bold;
}
.sn-cuentas-pilotos-wrapper {
  width: 100%;
  max-width: 1100px;
  margin: 0 auto;
  padding: var(--sn-space-5, 24px);
  background:
    radial-gradient(
      circle at 18% 20%,
      rgba(255, 255, 255, 0.05),
      transparent 55%
    ),
    linear-gradient(135deg, rgba(13, 18, 30, 0.96), rgba(5, 7, 12, 0.98));
  border-radius: var(--sn-radius-lg, 22px);
  border: 1px solid rgba(255, 255, 255, 0.08);
  box-shadow: 0 24px 48px rgba(0, 0, 0, 0.45);
  color: var(--sn-color-text, #f5f5f5);
}
.sn-cuentas-table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0 10px;
}
.sn-cuentas-table thead th {
  font-weight: 600;
  text-transform: uppercase;
  font-size: 0.78rem;
  letter-spacing: 0.04em;
}
.sn-cuentas-table th,
.sn-cuentas-table td {
  padding: 0.75rem;
  vertical-align: middle;
}
.sn-cuentas-table tbody tr {
  background: rgba(17, 20, 32, 0.95);
  border-radius: 16px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  box-shadow: 0 12px 26px rgba(0, 0, 0, 0.35);
}
.sn-cuentas-table tbody tr td:first-child {
  border-top-left-radius: 16px;
  border-bottom-left-radius: 16px;
}
.sn-cuentas-table tbody tr td:last-child {
  border-top-right-radius: 16px;
  border-bottom-right-radius: 16px;
}
.sn-cuentas-table th:nth-of-type(1),
.sn-cuentas-table td:nth-of-type(1),
.sn-cuentas-table th:nth-of-type(3),
.sn-cuentas-table td:nth-of-type(3),
.sn-cuentas-table th:nth-of-type(4),
.sn-cuentas-table td:nth-of-type(4) {
  text-align: center;
}
.sn-cuentas-table img {
  max-width: 48px;
  height: auto;
  display: block;
  margin: 0 auto;
  border-radius: 6px;
}
}

@layer sn.core {
@media (max-width: 768px) {
  .sn-cuentas-table {
    display: block;
    width: 100%;
    overflow-x: auto;
  }
  .sn-cuentas-table thead {
    display: none;
  }
  .sn-cuentas-table,
  .sn-cuentas-table tbody,
  .sn-cuentas-table tr,
  .sn-cuentas-table td {
    display: block;
  }
  .sn-cuentas-table tr {
    margin-bottom: 1rem;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 14px;
    overflow: hidden;
    background: rgba(15, 18, 28, 0.95);
    box-shadow: 0 10px 22px rgba(0, 0, 0, 0.35);
  }
  .sn-cuentas-table td {
    display: grid;
    grid-template-columns: 1fr 1fr;
    align-items: center;
    justify-items: center;
    padding: 0.75rem 0.5rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
    text-align: center;
  }
  .sn-cuentas-table td:last-child {
    border-bottom: none;
  }
  .sn-cuentas-table td::before {
    grid-column: 1;
    justify-self: flex-start;
    font-weight: 600;
    padding-left: 1rem;
    content: "";
    border-right: 1px solid rgba(255, 255, 255, 0.08);
  }
  .sn-cuentas-table td:nth-of-type(1)::before {
    content: "Imagen";
  }
  .sn-cuentas-table td:nth-of-type(2)::before {
    content: "Plataforma";
  }
  .sn-cuentas-table td:nth-of-type(3)::before {
    content: "Cupos";
  }
  .sn-cuentas-table td:nth-of-type(4)::before {
    content: "AcciÃƒÆ’Ã‚Â³n";
  }
}
}

@layer sn.core {
#sn-perifericos {
  width: 100%;
  max-width: 1100px;
  margin: 0 auto;
  padding: var(--sn-space-5, 24px);
  background:
    radial-gradient(
      circle at 16% 18%,
      rgba(255, 255, 255, 0.05),
      transparent 55%
    ),
    linear-gradient(135deg, rgba(14, 18, 30, 0.96), rgba(5, 7, 12, 0.98));
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: var(--sn-radius-lg, 22px);
  box-shadow: 0 24px 48px rgba(0, 0, 0, 0.45);
  color: var(--sn-color-text, #f5f5f5);
}
#sn-perifericos .sn-title {
  margin: 6px 0 12px;
  font-size: 1.4rem;
}
#sn-perifericos .sn-subtitle {
  margin: 16px 0 8px;
  font-size: 1.15rem;
  color: var(--sn-color-text-soft, #cfd4e6);
}
#sn-perifericos .sn-table {
  width: 100%;
  table-layout: fixed;
  background: transparent;
}
#sn-perifericos .sn-table thead th {
  padding: 10px 8px;
}
#sn-perifericos .sn-table tbody td {
  padding: 10px 8px;
  vertical-align: top;
}
#sn-perifericos .sn-table th:nth-child(1),
#sn-perifericos .sn-table td:nth-child(1),
#sn-perifericos .sn-table th:nth-child(2),
#sn-perifericos .sn-table td:nth-child(2) {
  width: 26%;
}
#sn-perifericos .sn-table th:nth-child(3),
#sn-perifericos .sn-table td:nth-child(3) {
  width: 42%;
}
#sn-perifericos .sn-table th:nth-child(4),
#sn-perifericos .sn-table td:nth-child(4) {
  width: 6%;
  text-align: right;
}
#sn-perifericos .sn-table td {
  word-wrap: break-word;
  overflow-wrap: anywhere;
}
#sn-perifericos .sn-col-actions,
#sn-perifericos .sn-td-actions {
  text-align: right;
  white-space: nowrap;
  display: flex;
  justify-content: flex-end;
  gap: 8px;
}
#sn-perifericos .sn-td-actions .sn-btn {
  min-width: 0;
}
#sn-perifericos .sn-td-actions .sn-btn-icon {
  width: 34px;
  height: 34px;
  padding: 0;
}
#sn-perifericos .sn-row {
  display: flex;
  gap: 10px;
  align-items: center;
  margin-top: 10px;
  flex-wrap: nowrap;
}
#sn-perifericos .sn-select {
  flex: 1 1 0;
  min-width: 0;
}
}

@layer sn.core {
@media (max-width: 768px) {
  #sn-perifericos .sn-table {
    display: block;
    width: 100%;
    overflow-x: auto;
    table-layout: auto;
  }
  #sn-perifericos .sn-table thead th,
  #sn-perifericos .sn-table tbody td {
    font-size: 14px;
  }
  #sn-perifericos .sn-row {
    flex-wrap: wrap;
  }
  #sn-perifericos .sn-select {
    flex: 1 1 calc(33.333% - 8px);
  }
}
}

@layer sn.core {
@media (max-width: 480px) {
  #sn-perifericos .sn-select {
    flex: 1 1 100%;
  }
  #sn-perifericos .sn-btn {
    width: 100%;
  }
}
}

@layer sn.core {
#sn-redes {
  width: 100%;
  max-width: 1100px;
  margin: 0 auto;
  padding: var(--sn-space-5, 24px);
  background:
    radial-gradient(
      circle at 20% 15%,
      rgba(255, 255, 255, 0.05),
      transparent 55%
    ),
    linear-gradient(140deg, rgba(13, 18, 30, 0.96), rgba(4, 6, 11, 0.98));
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: var(--sn-radius-lg, 22px);
  box-shadow: 0 24px 48px rgba(0, 0, 0, 0.45);
  color: var(--sn-color-text, #f5f5f5);
}
#sn-redes .sn-title {
  margin: 6px 0 12px;
  font-size: 1.4rem;
}
#sn-redes .sn-subtitle {
  margin: 16px 0 8px;
  font-size: 1.15rem;
  color: var(--sn-color-text-soft, #cfd4e6);
}
#sn-redes .sn-table {
  width: 100%;
  table-layout: fixed;
}
#sn-redes .sn-table thead th {
  padding: 10px 8px;
}
#sn-redes .sn-table tbody td {
  padding: 10px 8px;
  vertical-align: middle;
}
#sn-redes .sn-table th:nth-child(1),
#sn-redes .sn-table td:nth-child(1) {
  width: 14%;
}
#sn-redes .sn-table th:nth-child(2),
#sn-redes .sn-table td:nth-child(2) {
  width: 26%;
}
#sn-redes .sn-table th:nth-child(3),
#sn-redes .sn-table td:nth-child(3) {
  width: 44%;
}
#sn-redes .sn-table th:nth-child(4),
#sn-redes .sn-table td:nth-child(4) {
  width: 16%;
  text-align: right;
}
#sn-redes .sn-table td {
  word-wrap: break-word;
  overflow-wrap: anywhere;
}
#sn-redes .sn-td-img img {
  width: 36px;
  height: 36px;
  -o-object-fit: contain;
     object-fit: contain;
  display: block;
}
#sn-redes .sn-td-actions {
  text-align: right;
  white-space: nowrap;
  display: flex;
  justify-content: flex-end;
  gap: 8px;
}
#sn-redes .sn-td-actions .sn-btn {
  min-width: 0;
}
#sn-redes .sn-td-actions .sn-btn-icon {
  width: 34px;
  height: 34px;
  padding: 0;
}
#sn-redes .sn-row {
  display: flex;
  gap: 10px;
  align-items: center;
  margin-top: 10px;
  flex-wrap: nowrap;
}
#sn-redes .sn-select {
  flex: 1 1 0;
  min-width: 220px;
}
}

@layer sn.core {
@media (max-width: 768px) {
  #sn-redes .sn-table {
    display: block;
    width: 100%;
    overflow-x: auto;
    table-layout: auto;
  }
  #sn-redes .sn-table thead th,
  #sn-redes .sn-table tbody td {
    font-size: 14px;
  }
  #sn-redes .sn-row {
    flex-wrap: wrap;
  }
  #sn-redes .sn-select {
    flex: 1 1 100%;
    min-width: 0;
  }
  #sn-redes .sn-btn {
    width: 100%;
  }
  html,
  body {
    overflow-x: hidden;
  }
}
}

@layer sn.core {
:root {
  --badge-w: 140px;
  --badge-py: 6px;
  --badge-px: 12px;
  --font-sz: 12px;
  --font-fm: var(--sn-font-sans, "Inter", sans-serif);
}
.sn-eventos-skin .sn-ins,
.sn-ins {
  display: inline-flex;
  flex-direction: column;
  gap: 2px;
  font-family: var(--font-fm);
}
.sn-ins-badge,
.sn-open-badge {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-width: var(--badge-w);
  padding: var(--badge-py) var(--badge-px);
  border-radius: var(--sn-radius, 8px) !important;
  font: 600 var(--font-sz)/1.15 var(--font-fm);
  color: #fff;
  white-space: nowrap;
  border: none;
  cursor: pointer;
  transition: filter 0.15s ease-in-out;
  background: var(
    --sn-grad-theme,
    linear-gradient(135deg, #c90d05, #8f0700)
  ) !important;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.18);
  opacity: 1 !important;
  position: relative;
  z-index: 2;
}
.sn-ins-badge.espera,
.sn-ins-badge.locked {
  background: var(
    --sn-ins-wait,
    linear-gradient(135deg, #2e4a73, #1f3552)
  ) !important;
  color: #e0e6ef !important;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.22);
}
.sn-open-badge,
.sn-ins-badge.open {
  background: var(
    --sn-grad-success,
    linear-gradient(135deg, #2f5a3c, #22422a)
  ) !important;
  color: #e6ffe6 !important;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.22);
}
.sn-open-badge.edit {
  background: var(
    --sn-ins-edit,
    linear-gradient(135deg, #295262, #204252)
  ) !important;
  color: #e0f7fa !important;
}
.sn-open-badge.new {
  color: #e6ffe6 !important;
}
.sn-ins-badge.full,
.sn-ins-badge.closed {
  background: var(
    --sn-grad-muted,
    linear-gradient(135deg, #596270, #2e343a)
  ) !important;
  color: var(--sn-color-text-soft, #d6d6d6) !important;
  cursor: not-allowed;
}
.estado-iniciando,
.sn-ins-badge.estado-iniciando,
.sn-ins-badge.sala_asignada,
.sn-ins-badge.estado-curso {
  background: var(
    --sn-grad-warning,
    linear-gradient(135deg, #9c7626, #d6ae38)
  ) !important;
  color: #fff !important;
}
.sn-ins-badge.en_curso {
  background: linear-gradient(135deg, #604476, #332345) !important;
  color: #efeaff !important;
}
.sn-ins-badge.cancelled {
  background: var(
    --sn-grad-danger,
    linear-gradient(135deg, #a83232, #5a2222)
  ) !important;
  color: #ffeaea !important;
}
.sn-ins-badge.error {
  background: linear-gradient(135deg, #c14f2a, #6a261f) !important;
  color: #ffeaea !important;
}
.sn-ins-badge.limit,
.sn-ins-badge.competition_limit {
  background: linear-gradient(135deg, #9c7626, #6b4f1a) !important;
  color: #ffe6b3 !important;
}
.sn-ins-badge.unknown {
  background: linear-gradient(135deg, #3a4148, #23282d) !important;
  color: #f2f2f2 !important;
}
.sn-ins-badge.blocked,
.sn-ins-badge.blocked-profile,
.sn-ins-badge.blocked-accounts,
.sn-ins-badge.blocked-license {
  background: linear-gradient(135deg, #8a6326, #3c2c16) !important;
  color: #ffe6b3 !important;
  cursor: pointer;
  position: relative;
}
.sn-ins-badge.blocked-config {
  background: linear-gradient(135deg, #565656, #33393f) !important;
  color: #d6d6d6 !important;
  cursor: not-allowed;
  position: relative;
}
.sn-ins-badge.blocked-ban {
  background: var(
    --sn-grad-danger,
    linear-gradient(135deg, #a83232, #5a2222)
  ) !important;
  color: #ffeaea !important;
  cursor: not-allowed;
  position: relative;
}
.sn-ins-badge.blocked-ban::before {
  content: "ÃƒÂ¢Ã¢â‚¬ÂºÃ¢â‚¬Â";
  position: absolute;
  top: 6px;
  right: 8px;
  font-size: 14px;
  opacity: 0.95;
}
.sn-ins-badge.blocked-profile,
.sn-ins-badge.blocked-accounts,
.sn-ins-badge.blocked-license {
  animation: sn-pulse 2s ease-in-out infinite;
}
.sn-ins-badge.blocked-profile:hover,
.sn-ins-badge.blocked-accounts:hover,
.sn-ins-badge.blocked-license:hover {
  filter: brightness(1.2) !important;
  transform: scale(1.02);
  transition: all 0.2s ease;
}
.sn-ins-badge.blocked::after,
.sn-ins-badge.blocked-profile::after,
.sn-ins-badge.blocked-accounts::after,
.sn-ins-badge.blocked-license::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  height: 3px;
  background: rgba(255, 255, 255, 0.3);
  border-radius: 0 0 8px 8px;
  z-index: 1;
}
.sn-loading {
  padding: 8px 16px;
  background: var(--sn-color-surface, #2b2b2b);
  border-radius: var(--sn-radius-sm, 4px);
  font-size: 12px;
  color: var(--sn-color-text-soft, #6c757d);
}
.sn-ins-badge,
.sn-ins-badge * {
  color: #fff !important;
}
.sn-ins-container.sn-layout {
  display: flex;
  gap: 8px;
  align-items: stretch;
}
.sn-ins-container.sn-layout .sn-main-btn {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  padding: 6px 10px;
  min-height: 48px;
  max-width: 200px;
  line-height: 1.1;
  word-break: break-word;
  white-space: normal;
  font-size: 0.95rem;
}
.sn-ins-container.sn-layout .sn-main-top {
  max-width: 180px;
  word-break: break-word;
  white-space: normal;
  font-size: 0.9rem;
  line-height: 1.15;
}
.sn-ins[data-debug-estado="locked"] .sn-main-top span,
.sn-ins[data-debug-estado="espera"] .sn-main-top span {
  font-size: 0.84rem !important;
}
.sn-ins-container.sn-layout .sn-main-bottom {
  margin-top: 4px;
  font-size: 0.85rem;
  opacity: 0.85;
  text-align: center;
}
.sn-ins-container.sn-layout .sn-side-btn {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 56px;
  min-width: 48px;
  max-width: 64px;
  padding: 4px 0 6px;
  font-size: 0.78rem;
  background: var(--sn-grad-theme, linear-gradient(135deg, #c90d05, #9e0a03));
  border-radius: var(--sn-radius-btn, 10px) !important;
  border: 1px solid var(--sn-theme-primary-accent, #9e0a03);
  height: auto;
  box-shadow: 0 2px 8px -2px rgba(201, 13, 5, 0.55);
  transition:
    background 0.18s,
    transform 0.18s,
    box-shadow 0.18s,
    filter 0.18s;
  color: #fff;
  position: relative;
  cursor: pointer;
}
.sn-ins-container.sn-layout .sn-side-btn i {
  font-size: 18px;
  line-height: 1;
  margin-bottom: 2px;
  color: #fff !important;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.4);
}
.sn-ins-container.sn-layout .sn-side-count {
  margin-top: 2px;
  font-weight: 600;
  font-size: 0.75rem;
  color: #fff !important;
  letter-spacing: 0.5px;
  opacity: 0.95;
}
.sn-ins-container.sn-layout .sn-side-btn:hover {
  filter: brightness(1.08);
  box-shadow: 0 4px 14px -4px rgba(201, 13, 5, 0.65);
}
.sn-ins-container.sn-layout .sn-side-btn:active {
  transform: translateY(1px);
}
.sn-ins-container.sn-layout .sn-side-btn:focus-visible {
  outline: 2px solid #fff;
  outline-offset: 2px;
}
.sn-ins-container.sn-layout .sn-main-btn,
.sn-ins-container.sn-layout .sn-side-btn {
  min-height: 48px;
  height: 100%;
  box-sizing: border-box;
}
.sn-ins-modal {
  position: fixed;
  inset: 0;
  display: flex !important;
  align-items: center;
  justify-content: center;
  background: var(--sn-color-overlay, rgba(0, 0, 0, 0.85));
  z-index: var(--sn-z-max, 999999) !important;
  padding: 16px;
  visibility: visible;
  opacity: 1;
}
.sn-ins-modal select,
.sn-ins-modal .sn-form select,
.sn-ins-modal .sn-form .sn-input-select {
  background: var(--sn-color-surface, #0b0b0b) !important;
  color: var(--sn-color-text, #fff) !important;
  border: 1px solid var(--sn-color-border, #222) !important;
  border-radius: var(--sn-radius, 8px) !important;
  padding: 10px 14px !important;
  min-height: 42px;
  font: 500 var(--sn-font-size) var(--sn-font-sans);
}
.sn-ins-modal select:focus {
  outline: none !important;
  border-color: var(--sn-theme-primary, #c90d05) !important;
  box-shadow: 0 0 0 2px rgba(201, 13, 5, 0.35) !important;
}
.sn-ins-modal .select2-container .select2-selection--single {
  background: var(--sn-color-surface, #0b0b0b) !important;
  border: 1px solid var(--sn-color-border, #222) !important;
  border-radius: var(--sn-radius, 8px) !important;
  min-height: 42px;
  height: 42px;
  padding: 0 12px;
}
.sn-ins-modal
  .select2-container
  .select2-selection--single
  .select2-selection__rendered {
  color: #fff !important;
  line-height: 40px !important;
  padding-left: 0 !important;
}
.sn-ins-modal
  .select2-container
  .select2-selection--single
  .select2-selection__arrow
  b {
  border-color: #fff transparent transparent transparent !important;
}
.sn-ins-modal .select2-container--default .select2-dropdown {
  background: #0b0b0b !important;
  border: 1px solid #222 !important;
}
.sn-ins-modal .select2-container--default .select2-results__option {
  color: #f0f0f0 !important;
}
.sn-ins-modal
  .select2-container--default
  .select2-results__option--highlighted {
  background: #1d1d1d !important;
}
.sn-ins-modal .select2-search--dropdown .select2-search__field {
  background: #111 !important;
  border: 1px solid #222 !important;
  color: #fff !important;
}
.sn-ins-modal .select2-container .select2-selection__placeholder {
  color: #888 !important;
}
.sn-ins-modal .box {
  background: var(--sn-color-surface, #1e2732) !important;
  border: 1px solid var(--sn-color-border, #2f3b47) !important;
  color: var(--sn-color-text, #e6e6e6) !important;
  padding: 1rem !important;
  border-radius: 10px !important;
  width: 80% !important;
  max-width: 820px !important;
  max-height: 90vh;
  overflow: auto;
  box-shadow: var(--sn-shadow-lg, 0 28px 100px rgba(0, 0, 0, 0.78)) !important;
}
.sn-ins-modal .sn-modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 12px;
  padding: 8px 12px;
}
.sn-ins-modal .sn-modal-header h3 {
  margin: 0;
  flex: 1 1 auto;
  font-size: 0.98rem;
  color: var(--sn-color-text, #e6e6e6);
  font-weight: 600;
}
.sn-ins-modal .sn-modal-close {
  background: transparent;
  border: none;
  color: #cfcfcf;
  font-size: 1.2rem;
  font-weight: 700;
  cursor: pointer;
  padding: 6px 8px;
  line-height: 1;
}
.sn-modal-body {
  padding: 12px 0;
  color: var(--sn-color-text-soft, #dcdcdc);
  font-size: 0.95rem;
  line-height: 1.4;
}
}

@layer sn.core {
@media (max-width: 480px) {
  .sn-ins-modal.sn-confirm-modal .box {
    max-width: 92vw;
    padding: 1rem;
  }
  .sn-ins-modal.sn-confirm-modal h3 {
    font-size: 1rem;
    margin-bottom: 0.8rem;
  }
  .sn-ins-modal.sn-confirm-modal .sn-btn {
    width: 100%;
    margin: 0.3rem 0;
  }
}
}

@layer sn.core {
.splits-tabs {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  align-items: center;
  margin: 0 0 6px 0;
  padding: 10px;
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 12px;
}
.split-tab {
  padding: 8px 16px;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.18);
  cursor: pointer;
  font-weight: 700;
  border-radius: 12px 12px 0 0;
  transition:
    transform 0.12s ease,
    box-shadow 0.12s ease,
    background 0.12s ease,
    border-color 0.12s ease;
  font-size: 0.95rem;
  color: #e6eef6;
  box-shadow: 0 8px 26px rgba(0, 0, 0, 0.3);
  position: relative;
  z-index: 3;
  margin-bottom: -1px;
}
.split-tab:hover,
.split-tab:focus {
  background: rgba(255, 255, 255, 0.07);
  transform: translateY(-4px);
  outline: none;
  box-shadow: 0 18px 40px rgba(0, 0, 0, 0.4);
}
.split-tab.active {
  background: linear-gradient(180deg, #c90d05, #a80b04);
  color: #fff;
  border-radius: 6px;
  box-shadow: none;
  z-index: 4;
}
.split-content {
  display: none;
  padding: 14px;
  margin-top: 0;
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 0 12px 12px 12px;
  background: rgba(255, 255, 255, 0.01);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.02);
}
.split-content.active {
  display: block;
}
.split-info {
  background: #0c1112;
  padding: 4px 6px;
  border-radius: 6px;
  margin-bottom: 6px;
  font-weight: 600;
  border: 1px solid rgba(255, 255, 255, 0.04);
  color: #e6eef6;
  font-size: 0.84rem;
  line-height: 1.1;
}
.inscritos-header .event-stats {
  background: #0b0d0f;
  padding: 6px 8px;
  border-radius: 6px;
  margin-bottom: 6px;
  font-size: 0.85rem;
  border: 1px solid rgba(255, 255, 255, 0.04);
  line-height: 1.2;
}
.inscritos-header .event-stats p {
  margin: 0 0 6px 0;
  font-size: 0.85rem;
  color: #cfd8dc;
}
.piloto-avatar img,
.marca-logo img {
  width: 32px !important;
  height: 32px !important;
  border-radius: 50% !important;
  -o-object-fit: cover !important;
     object-fit: cover !important;
  display: inline-block;
  vertical-align: middle;
  border: 1px solid rgba(255, 255, 255, 0.06) !important;
}
.piloto-nombre {
  font-weight: 700 !important;
  color: #fff !important;
  line-height: 1.1;
}
.auto-nombre {
  color: #fff !important;
  font-size: 0.92rem;
  font-weight: 600 !important;
}
.pilotos-table th,
.pilotos-table td {
  vertical-align: middle !important;
  padding: 6px 8px !important;
  line-height: 1.05 !important;
  white-space: nowrap;
  font-size: 0.9rem;
}
.pilotos-table tbody tr {
  min-height: 40px;
}
.pilotos-table td .elo,
.pilotos-table td .sr,
.pilotos-table td.elo,
.pilotos-table td.sr {
  font-weight: 700 !important;
  font-size: 0.88rem !important;
  padding: 0 !important;
}
.badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  border-radius: 20px;
  font-weight: 700;
  font-size: 14px;
}
}

@layer sn.core {
@media (max-width: 1400px) {
  .sn-ins-modal .box {
    max-width: 96% !important;
  }
}
}

@layer sn.core {
@media (max-width: 900px) {
  .split-tab {
    padding: 6px 10px;
    font-size: 0.88rem;
  }
  .split-content {
    padding: 10px;
  }
}
}

@layer sn.core {
@media (max-width: 768px) {
  .splits-tabs {
    flex-wrap: wrap;
  }
  .split-tab {
    flex: 1;
    text-align: center;
    min-width: 100px;
    font-size: 0.8rem;
    padding: 6px 12px;
  }
  .pilotos-table {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
  .pilotos-table table {
    min-width: 600px;
  }
  .pilotos-table th,
  .pilotos-table td {
    padding: 5px 6px !important;
    font-size: 0.86rem !important;
  }
  .pilotos-table tbody tr {
    min-height: 36px;
  }
}
}

@layer sn.core {
@media (max-width: 480px) {
  .inscritos-header .event-stats {
    font-size: 0.8rem;
    padding: 8px;
  }
  .split-tab {
    font-size: 0.75rem;
    padding: 4px 8px;
  }
  .pilotos-table table {
    font-size: 0.8rem;
  }
  .pilotos-table th {
    font-size: 0.75rem;
  }
  .piloto-avatar img,
  .marca-logo img {
    width: 24px !important;
    height: 24px !important;
  }
  .licencia-badge {
    font-size: 0.7rem;
    padding: 2px 6px;
  }
  .pilotos-table th,
  .pilotos-table td {
    padding: 4px 6px !important;
    font-size: 0.84rem !important;
  }
  .pilotos-table tbody tr {
    min-height: 32px;
  }
}
}

@layer sn.core {
.sn-ins-btn:disabled {
  opacity: 0.6;
  cursor: not-allowed;
  filter: none !important;
}
.sn-tor-ins .sn-tor-layout {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  align-items: stretch;
}
}

@layer sn.core {
@media (max-width: 1200px) {
  .tor-inscripcion-mobile .sn-tor-badge,
  .tor-inscripcion-mobile .sn-tor-side {
    width: 100%;
    min-width: 0;
  }
}
}

@layer sn.core {
.sn-tor-ins .sn-tor-badge {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-width: 180px;
  padding: 10px 14px;
  border-radius: var(--sn-radius-lg);
  background: var(--sn-color-surface-alt);
  border: 1px solid var(--sn-color-border);
  font: 600 var(--sn-font-size-sm)/1.1 var(--sn-font-sans);
  cursor: pointer;
  transition:
    transform 0.18s,
    box-shadow 0.25s;
  text-align: center;
}
.sn-tor-ins .sn-tor-badge:hover {
  transform: translateY(-2px);
  box-shadow: var(--sn-shadow-sm);
}
.sn-tor-ins .sn-tor-badge:disabled {
  opacity: 0.55;
  cursor: not-allowed;
}
.sn-tor-ins .sn-tor-badge .sn-tor-top {
  display: flex;
  gap: 8px;
  align-items: center;
  font-weight: 600;
}
.sn-tor-ins .sn-tor-badge .sn-tor-bottom {
  margin-top: 6px;
  font-size: var(--sn-font-size-xs);
  opacity: 0.9;
}
.sn-tor-ins .sn-tor-badge .sn-tor-sub {
  display: block;
  color: var(--sn-color-text-faint);
  margin-bottom: 3px;
}
.sn-tor-ins .sn-tor-badge.st-open {
  background: linear-gradient(135deg, #1a5e32, #238944 55%);
  border-color: #1c6d38;
  color: #e7ffe9;
  box-shadow:
    0 2px 5px rgba(0, 0, 0, 0.45),
    0 0 0 1px rgba(255, 255, 255, 0.05) inset;
}
.sn-tor-ins .sn-tor-badge.st-inscribed {
  background: linear-gradient(135deg, #1d1d1d, #252525 60%);
  border-color: #343434;
  color: #dcdcdc;
  box-shadow:
    0 2px 4px rgba(0, 0, 0, 0.4),
    0 0 0 1px rgba(255, 255, 255, 0.04) inset;
}
.sn-tor-ins .sn-tor-badge.st-locked,
.sn-tor-ins .sn-tor-badge.st-closed {
  background: var(--sn-grad-muted);
}
.sn-tor-ins .sn-tor-badge.st-full {
  background: linear-gradient(135deg, #3b251f, #24120f);
  border-color: #5f2a12;
}
.sn-tor-ins .sn-tor-badge.st-blocked-config {
  background: linear-gradient(135deg, #3b2b0d, #2b1f07);
}
.sn-tor-ins .sn-tor-badge.st-blocked-ban {
  background: linear-gradient(135deg, #3b0d0d, #2b0707);
}
.sn-tor-ins .sn-tor-badge.st-blocked-ban .sn-tor-top:before {
  content: "ÃƒÂ¢Ã¢â‚¬ÂºÃ¢â‚¬Â";
  margin-right: 6px;
}
.sn-tor-ins .sn-tor-badge.st-blocked-ticket {
  background: linear-gradient(135deg, #2a1a3a, #3c2372 55%);
  border-color: #4f3aa6;
  color: #f0eaff;
  box-shadow:
    0 2px 6px rgba(0, 0, 0, 0.45),
    0 0 0 1px rgba(255, 255, 255, 0.05) inset;
  position: relative;
}
.sn-tor-ins .sn-tor-badge.st-blocked-ticket:after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  pointer-events: none;
  box-shadow: 0 0 0 0 rgba(136, 98, 255, 0.6);
  animation: snSoftPulse 2.2s ease-in-out infinite;
}
.sn-tor-ins .sn-tor-badge.st-blocked-ticket .sn-tor-top i {
  color: #fc6;
}
.sn-tor-ins .sn-tor-badge.st-blocked-ticket .sn-tor-sub {
  color: #d6ccff;
}
.sn-pill {
  display: inline-block;
  padding: 4px 8px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.12);
  border: 1px solid rgba(255, 255, 255, 0.15);
}
@keyframes snSoftPulse {
  0% {
    box-shadow: 0 0 0 0 rgba(136, 98, 255, 0.5);
  }
  70% {
    box-shadow: 0 0 0 8px rgba(136, 98, 255, 0);
  }
  100% {
    box-shadow: 0 0 0 0 rgba(136, 98, 255, 0);
  }
}
.sn-tor-ins .sn-tor-side {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 2px;
  padding: 6px 8px;
  border-radius: var(--sn-radius-lg, 8px);
  background: var(
    --sn-grad-theme,
    linear-gradient(
      135deg,
      var(--sn-theme-primary, #c90d05),
      var(--sn-theme-primary-hover, #e01006) 55%
    )
  );
  border: 1px solid var(--sn-theme-primary-accent, #9e0a03);
  font: 600 var(--sn-font-size-xs)/1 var(--sn-font-sans);
  color: #fff;
  cursor: pointer;
  box-shadow:
    0 2px 4px rgba(0, 0, 0, 0.35),
    0 0 0 1px rgba(255, 255, 255, 0.05) inset;
  transition:
    filter 0.22s ease,
    transform 0.16s ease,
    box-shadow 0.25s ease;
}
.sn-tor-ins .sn-tor-side:hover {
  filter: brightness(1.12) saturate(1.05);
  transform: translateY(-2px);
  box-shadow:
    0 4px 10px -1px rgba(0, 0, 0, 0.55),
    0 0 0 1px rgba(255, 255, 255, 0.05) inset;
}
.sn-tor-ins .sn-tor-side-count {
  font-size: var(--sn-font-size-xs);
  font-weight: 600;
  min-width: 46px;
  text-align: center;
}
.sn-blink {
  animation: snblink 0.9s infinite;
}
.sn-tor-inscrito {
  color: var(--sn-success);
  font-weight: 600;
}
@keyframes snblink {
  0%,
  100% {
    filter: brightness(1);
  }
  50% {
    filter: brightness(1.35);
  }
}
.sn-tor-save[disabled] {
  opacity: 0.55;
  cursor: not-allowed;
  filter: grayscale(0.2);
  box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.04) inset;
}
.sn-tor-save.is-loading {
  pointer-events: none;
  opacity: 0.85;
}
.sn-tor-save.is-loading:before {
  content: "";
  position: absolute;
  left: 12px;
  top: 50%;
  transform: translateY(-50%);
  width: 16px;
  height: 16px;
  border: 2px solid rgba(255, 255, 255, 0.35);
  border-top-color: #fff;
  border-radius: 50%;
  animation: snSpin 0.8s linear infinite;
}
@keyframes snSpin {
  to {
    transform: translateY(-50%) rotate(360deg);
  }
}
}

@layer sn.core {
@media (max-width: 480px) {
  .sn-tor-save {
    width: 100%;
    justify-content: center;
  }
}
}

@layer sn.core {
.sn-tor-modal-wrap {
  position: fixed;
  inset: 0;
  z-index: 999999;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 40px 24px;
  box-sizing: border-box;
}
.sn-tor-modal-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.55);
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
}
.sn-tor-modal {
  background: var(--sn-color-surface) !important;
  border: 1px solid var(--sn-color-border) !important;
  border-radius: var(--sn-radius-lg);
  position: relative;
  width: min(640px, 100%);
  max-height: 90vh;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  box-shadow:
    0 8px 28px rgba(0, 0, 0, 0.55),
    0 2px 6px rgba(0, 0, 0, 0.4);
}
.sn-tor-modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--sn-space-3) var(--sn-space-4);
  background: var(--sn-color-surface-alt);
  border-bottom: 1px solid var(--sn-color-border);
}
.sn-tor-modal-header h3 {
  margin: 0;
  font: 600 var(--sn-font-size-md)/1 var(--sn-font-sans);
}
.sn-tor-close {
  background: transparent;
  border: 1px solid var(--sn-color-border-light);
  color: var(--sn-color-text-soft);
  padding: 6px 10px;
  border-radius: var(--sn-radius-sm);
  cursor: pointer;
}
.sn-tor-close:hover {
  background: rgba(255, 255, 255, 0.06);
  color: var(--sn-color-text);
}
.sn-tor-modal-body {
  padding: var(--sn-space-4);
  max-height: 65vh;
  overflow: auto;
}
.sn-tor-modal-footer {
  display: flex;
  gap: var(--sn-space-2);
  justify-content: flex-end;
  padding: var(--sn-space-3) var(--sn-space-4);
  background: var(--sn-color-surface-alt);
  border-top: 1px solid var(--sn-color-border);
}
.sn-tor-save {
  --_btn-bg: var(
    --sn-grad-theme,
    linear-gradient(135deg, #c90d05, #e01006 55%)
  );
  --_btn-bg-hover: linear-gradient(
    135deg,
    var(--sn-theme-primary-hover, #e01006),
    var(--sn-theme-primary-accent, #9e0a03)
  );
  --_btn-border: var(--sn-theme-primary-accent, #9e0a03);
  background: var(--_btn-bg);
  border: 1px solid var(--_btn-border);
  color: #fff;
  padding: 10px 18px;
  border-radius: 999px;
  min-height: 42px;
  position: relative;
  font: 600 var(--sn-font-size-sm)/1 var(--sn-font-sans);
  cursor: pointer;
  line-height: 1.05;
  letter-spacing: 0.3px;
  box-shadow:
    0 2px 6px rgba(201, 13, 5, 0.45),
    0 0 0 1px rgba(255, 255, 255, 0.05) inset;
  transition:
    background 0.2s ease,
    filter 0.2s ease,
    transform 0.2s ease;
}
.sn-tor-save:hover,
.sn-tor-save:focus-visible {
  background: var(--_btn-bg-hover);
  filter: brightness(1.06);
  outline: none;
}
.sn-tor-save:active {
  transform: translateY(1px);
}
.sn-tor-save[disabled] {
  opacity: 0.55;
  cursor: not-allowed;
  filter: grayscale(0.2);
}
.sn-tor-delete {
  background: var(--sn-grad-danger);
  border: 1px solid #592222;
  color: #fff !important;
  padding: 8px 14px;
  border-radius: var(--sn-radius);
  font: 600 var(--sn-font-size-sm)/1 var(--sn-font-sans);
  cursor: pointer;
}
.sn-tor-save {
  color: #fff !important;
}
.sn-tor-form label {
  display: block;
  font-weight: 600;
  margin-bottom: 6px;
}
.sn-tor-form .fld-acepta label {
  font-weight: 400;
}
.sn-tor-modal .select2-container {
  width: 100% !important;
}
.sn-ins-modal .select2-container--open .select2-dropdown,
.sn-tor-modal-wrap .select2-container--open .select2-dropdown {
  z-index: 1000001;
}
body.sn-tor-modal-open {
  overflow: hidden;
  overscroll-behavior: contain;
}
.sn-ins-controls {
  display: flex;
  gap: var(--sn-space-2);
  align-items: center;
  margin-bottom: var(--sn-space-3);
  flex-wrap: wrap;
}
.sn-ins-tabs {
  display: flex;
  gap: 4px;
  flex-wrap: wrap;
  padding: var(--sn-space-2);
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid var(--sn-color-border);
  border-radius: var(--sn-radius-lg);
}
.sn-ins-tab {
  padding: 4px 10px;
  background: var(--sn-color-surface-alt);
  border: 1px solid var(--sn-color-border);
  border-radius: var(--sn-radius-pill);
  font: 600 var(--sn-font-size-xs)/1 var(--sn-font-sans);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.sn-ins-tab.active {
  background: var(--sn-grad-primary);
  color: #fff;
  border-color: var(--sn-primary-accent);
}
.sn-ins-content .sn-ins-div {
  display: none;
}
.sn-ins-content .sn-ins-div.active {
  display: block;
}
.sn-ins-cat-title {
  font-weight: 700;
  color: var(--sn-primary);
  margin: 10px 0 6px;
}
.sn-ins-table-wrap {
  overflow: auto;
  border: 1px solid var(--sn-color-border);
  border-radius: var(--sn-radius);
}
.sn-ins-table {
  width: 100%;
  border-collapse: collapse;
  font: 500 var(--sn-font-size-xs)/1.25 var(--sn-font-sans);
}
.sn-ins-table thead th {
  background: var(--sn-color-surface-alt);
  position: sticky;
  top: 0;
  z-index: 1;
  font-weight: 600;
  padding: 6px 8px;
}
.sn-ins-table tbody td {
  padding: 6px 8px;
  white-space: nowrap;
  border-top: 1px solid var(--sn-color-border);
}
.sn-ins-table tbody tr:nth-child(even) {
  background: rgba(255, 255, 255, 0.02);
}
.sn-toast-container {
  position: fixed;
  right: 16px;
  top: 16px;
  z-index: 1000002;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.sn-toast {
  background: rgba(28, 28, 28, 0.95);
  color: #fff;
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 10px;
  padding: 10px 14px;
  font: 500 14px/1.2
    var(--sn-font-sans, system-ui, -apple-system, Segoe UI, Roboto);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.35);
  display: flex;
  align-items: center;
  gap: 8px;
}
.sn-toast .sn-toast-close {
  margin-left: 8px;
  background: transparent;
  border: 0;
  color: rgba(255, 255, 255, 0.8);
  cursor: pointer;
}
.sn-f1-ranking {
  margin: 1.5rem 0;
  font-size: 14px;
}
.sn-f1-table-wrapper {
  overflow-x: auto;
}
.sn-f1-tabs,
.sn-f1-cat-tabs {
  display: flex;
  gap: 0.4rem;
  margin-bottom: 0.6rem;
  flex-wrap: nowrap;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
.sn-f1-tab,
.sn-f1-cat-tab {
  border: 1px solid #7a0a07;
  background: #b10b05;
  color: #fff;
  padding: 0.6rem 0.9rem;
  border-radius: 8px;
  cursor: pointer;
  font-size: 0.88rem;
  min-width: 120px;
  text-align: center;
  font-weight: 700;
  box-shadow: inset 0-2px 0 rgba(0, 0, 0, 0.2);
  transition:
    background 0.2s ease,
    box-shadow 0.2s ease;
  flex: 1 1 0;
  width: auto;
  white-space: nowrap;
}
.sn-f1-tab.is-active,
.sn-f1-cat-tab.is-active {
  background: #e51107;
  color: #fff;
  border-color: #ff3b30;
  box-shadow:
    0 0 0 2px #7a0a07 inset,
    0 2px 6px rgba(0, 0, 0, 0.45);
}
.sn-f1-tab:hover,
.sn-f1-cat-tab:hover {
  background: #c90d05;
}
.sn-f1-sim-logo {
  width: 44px;
  height: 44px;
  -o-object-fit: contain;
     object-fit: contain;
  vertical-align: middle;
  margin-right: 0.4rem;
}
.sn-f1-table {
  width: 100%;
  border-collapse: collapse;
  border-spacing: 0;
  font-size: 0.9rem;
  color: #ddd;
  min-width: 980px;
  border-radius: 10px;
  overflow: hidden;
}
.sn-f1-table thead th {
  background: #202020;
  color: #cfcfcf;
  border-bottom: 1px solid #2e2e2e;
  padding: 0.55rem 0.7rem;
  text-align: left;
  font-weight: 600;
  font-size: 0.72rem;
  letter-spacing: 0.5px;
  text-transform: uppercase;
  white-space: nowrap;
}
.sn-f1-table thead th i {
  color: #7fb3ff;
  margin-right: 0.35rem;
  font-size: 0.85rem;
}
.sn-f1-table tbody tr {
  background: #181818;
}
.sn-f1-table tbody tr:nth-child(odd) {
  background: #141414;
}
.sn-f1-table tbody tr:hover {
  background: #1e1e1e;
}
.sn-f1-table td {
  padding: 0.55rem 0.7rem;
  border-bottom: 1px solid #242424;
  font-variant-numeric: tabular-nums;
}
.sn-f1-table td .rec {
  margin-top: 2px;
  display: flex;
  align-items: center;
  gap: 0.35rem;
  font-size: 0.78rem;
  color: #a9a9a9;
}
.sn-f1-modal-title i {
  color: #7fb3ff;
}
.sn-f1-table td.num {
  text-align: right;
  font-variant-numeric: tabular-nums;
}
.sn-f1-table td.best {
  background: #4b2a77;
  color: #fff;
}
.sn-f1-table td .v1 {
  color: #cfcfcf;
  font-size: 1rem;
  line-height: 1.2;
}
.sn-f1-table td .v2 {
  color: #9fd39f;
  font-size: 0.82rem;
  line-height: 1.2;
}
.sn-f1-table td .v3 {
  color: #bcbcbc;
  font-size: 0.8rem;
  line-height: 1.2;
}
.flag,
.sn-flag img.flag {
  width: 20px;
  height: 14px;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: 2px;
}
.sn-loading,
.sn-empty,
.sn-error {
  padding: 0.65rem;
  background: #181818;
  color: #e0e0e0;
  border: 1px solid #2a2a2a;
  border-radius: 6px;
}
.sn-f1-header {
  margin-bottom: 0.7rem;
  text-align: center;
}
.sn-f1-header h2 {
  margin: 0 0 0.25rem 0;
  font-size: 1.75rem;
  color: #fff;
  letter-spacing: 0.3px;
}
.sn-f1-header p {
  margin: 0;
  font-size: 0.98rem;
  color: #c9c9c9;
}
.sn-f1-lastupdate {
  margin-top: 0.35rem;
  font-size: 0.85rem;
  color: #9aa8b4;
}
.sn-f1-modal {
  position: fixed;
  inset: 0;
  display: block;
  z-index: 9999;
}
.sn-f1-modal[hidden] {
  display: none;
}
.sn-f1-modal-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.7);
}
.sn-f1-modal-content {
  position: absolute;
  top: 6%;
  left: 50%;
  transform: translateX(-50%);
  width: min(1100px, 94%);
  background: #121212;
  color: #e9e9e9;
  border: 1px solid #2a2a2a;
  border-radius: 10px;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.6);
  overflow: hidden;
}
.sn-f1-modal-header {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.7rem 0.9rem;
  border-bottom: 1px solid #2a2a2a;
  background: linear-gradient(135deg, #1a1a1a, #2a0e0e);
  font-weight: 700;
}
.sn-f1-modal-title {
  font-size: 0.9rem;
  margin: 0;
}
.sn-f1-modal-body {
  max-height: 70vh;
  overflow: auto;
  padding: 0.8rem 0.9rem 1rem;
}
.sn-f1-modal-close {
  margin-left: auto;
  border: none;
  background: transparent;
  color: #fff;
  font-size: 1.6rem;
  cursor: pointer;
}
.sn-f1-modal-table {
  width: 100%;
  border-collapse: collapse;
  border-spacing: 0;
  font-size: 0.82rem;
}
.sn-f1-modal-table th,
.sn-f1-modal-table td {
  border-bottom: 1px solid #2e2e2e;
  padding: 0.5rem 0.6rem;
  font-variant-numeric: tabular-nums;
}
.sn-f1-modal-table thead th {
  background: #1b1b1b;
  color: #cfcfcf;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.4px;
  font-size: 0.72rem;
  white-space: nowrap;
}
.sn-f1-modal-table thead th i {
  color: #7fb3ff;
  margin-right: 0.35rem;
}
.sn-f1-modal-table tbody tr {
  background: #181818;
}
.sn-f1-modal-table tbody tr:nth-child(odd) {
  background: #141414;
}
.sn-f1-modal-table td.num {
  text-align: right;
  font-variant-numeric: tabular-nums;
}
.sn-f1-modal-table td .v1 {
  font-weight: 600;
  color: #e6e6e6;
  line-height: 1.2;
}
.sn-f1-modal-table td .v2 {
  color: #9fd39f;
  font-size: 0.8rem;
  line-height: 1.2;
}
.sn-f1-modal-table td .v3 {
  color: #bcbcbc;
  font-size: 0.8rem;
  line-height: 1.2;
}
.sn-avatar {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  -o-object-fit: cover;
     object-fit: cover;
}
.sn-btn.sn-btn-mini {
  font-size: 0.8rem;
  padding: 0.35rem 0.7rem;
  border-radius: 8px;
  background: #c90d05;
  color: #fff;
  border: 1px solid #7a0a07;
  box-shadow: inset 0-2px 0 rgba(0, 0, 0, 0.2);
}
.sn-btn.sn-btn-mini i {
  margin-right: 0.35rem;
  font-size: 0.9rem;
}
.td-penas {
  color: #ff9b76;
}
.td-puntaje {
  color: #ffd166;
}
.td-pos {
  color: #9ad0ff;
}
.td-total {
  color: #b5ffa8;
  font-weight: 700;
}
}

@layer sn.core {
@media (max-width: 700px) {
  .sn-f1-tabs,
  .sn-f1-cat-tabs {
    flex-wrap: nowrap;
    overflow-x: auto;
    gap: 0.5rem;
    padding-bottom: 0.2rem;
  }
  .sn-f1-tab,
  .sn-f1-cat-tab {
    flex: 0 0 auto;
    min-width: 120px;
    padding: 0.5rem 0.7rem;
    font-size: 0.8rem;
  }
  .sn-f1-sim-logo {
    width: 32px;
    height: 32px;
  }
  .sn-f1-header h2 {
    font-size: 1.35rem;
  }
  .sn-f1-header p {
    font-size: 0.9rem;
  }
  .sn-f1-table {
    border-spacing: 0;
    font-size: 0.9rem;
    min-width: 720px;
  }
  .sn-f1-table thead {
    display: table-header-group;
  }
  .sn-f1-table-wrapper {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    border-radius: 10px;
  }
  .sn-f1-table thead th {
    position: sticky;
    top: 0;
    z-index: 2;
  }
  .sn-f1-table td,
  .sn-f1-table th {
    white-space: nowrap;
  }
  .sn-btn.sn-btn-mini {
    font-size: 0.75rem;
    padding: 0.3rem 0.55rem;
  }
  .sn-f1-modal-content {
    top: 0;
    left: 0;
    transform: none;
    width: 100%;
    height: 100%;
    border-radius: 0;
    border: none;
  }
  .sn-f1-modal-header {
    position: sticky;
    top: 0;
    z-index: 3;
  }
  .sn-f1-modal-body {
    max-height: calc(100vh - 56px);
    padding: 0.6rem;
  }
  .sn-f1-modal-table {
    min-width: 760px;
  }
}
}

@layer sn.core {
.sn-iracing-ranking {
  margin: 1.5rem 0;
  font-size: 14px;
}
.sn-iracing-tabs {
  display: flex;
  width: 100%;
  margin: 0 0 1rem;
  gap: 0.5rem;
}
.sn-iracing-heading {
  margin: 0 0 1rem;
  text-align: center;
}
.sn-iracing-title {
  margin: 0 0 0.25rem;
  color: #fff;
  font-size: 1.6rem;
  line-height: 1.2;
  font-weight: 700;
  letter-spacing: 0.3px;
}
.sn-iracing-subtitle {
  color: #bbb;
  font-size: 0.9rem;
  font-weight: 500;
}
.sn-iracing-tab-btn {
  flex: 1 1 20%;
  background: #b10b05;
  color: #fff;
  border: 0;
  padding: 0.75rem 0.25rem;
  cursor: pointer;
  font-size: 0.85rem;
  font-weight: 600;
  text-align: center;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0.4rem;
  border-right: 0;
  transition: background 0.2s ease;
  border-radius: 6px;
  box-shadow: inset 0-2px 0 rgba(0, 0, 0, 0.15);
}
.sn-iracing-tab-btn:last-child {
  border-right: 0;
}
.sn-iracing-tab-btn:hover {
  background: #c90d05;
}
.sn-iracing-tab-btn.is-active {
  background: #e51107;
  box-shadow:
    0 0 0 2px #7a0a07 inset,
    0 2px 6px rgba(0, 0, 0, 0.45);
  border: 1px solid #ff3b30;
}
.sn-iracing-tab-btn:focus-visible {
  outline: 2px solid #ffb199;
  outline-offset: 2px;
}
.sn-iracing-tab {
  display: none;
}
.sn-iracing-tab.is-active {
  display: block;
}
.sn-iracing-user-pos {
  background: linear-gradient(135deg, #141414, #0f0f0f);
  color: #fff;
  padding: 1rem 1.1rem;
  border-radius: 10px;
  margin-bottom: 1rem;
  overflow: auto;
  border: 1px solid #242424;
  box-shadow: 0 6px 18px rgba(0, 0, 0, 0.35);
}
.sn-iracing-user-pos h4 {
  margin: 0 0 0.75rem;
  font-size: 1.05rem;
  font-weight: 700;
  letter-spacing: 0.2px;
}
.sn-user-card {
  display: flex;
  align-items: stretch;
  justify-content: space-between;
  gap: 1.2rem;
  background: #0f0f0f;
  border: 1px solid #2a2a2a;
  border-radius: 10px;
  padding: 0.9rem 1rem;
}
.sn-user-card-left {
  display: flex;
  align-items: center;
  gap: 0.9rem;
  min-width: 0;
}
.sn-user-pos-badge {
  background: #ff8a00;
  color: #000;
  font-weight: 800;
  border-radius: 8px;
  padding: 0.35rem 0.55rem;
  min-width: 48px;
  text-align: center;
  box-shadow: inset 0-2px 0 rgba(0, 0, 0, 0.2);
}
.sn-user-avatar img {
  width: 52px;
  height: 52px;
  border-radius: 50%;
  border: 2px solid #2f2f2f;
}
.sn-user-meta {
  min-width: 0;
}
.sn-user-name {
  font-size: 1rem;
  font-weight: 700;
  color: #fff;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.sn-user-sub {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem 0.8rem;
  font-size: 0.78rem;
  color: #bbb;
}
.sn-user-flag img {
  vertical-align: middle;
}
.sn-user-card-right {
  display: grid;
  grid-template-columns: repeat(5, minmax(90px, 1fr));
  gap: 0.5rem 0.8rem;
  align-items: center;
}
.sn-user-stat {
  background: #151515;
  border: 1px solid #262626;
  border-radius: 8px;
  padding: 0.45rem 0.55rem;
  text-align: center;
}
.sn-user-stat-label {
  font-size: 0.7rem;
  color: #999;
  text-transform: uppercase;
  letter-spacing: 0.4px;
}
.sn-user-stat-value {
  font-size: 0.95rem;
  font-weight: 700;
  color: #fff;
  margin-top: 0.2rem;
}
.sn-iracing-table-wrapper {
  overflow-x: auto;
}
.sn-iracing-table {
  width: 100%;
  border-collapse: collapse;
  min-width: 850px;
  border-radius: 10px;
  overflow: hidden;
}
.sn-iracing-table th {
  padding: 0.5rem 0.6rem;
  text-align: left;
}
.sn-iracing-pagination {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 1rem;
  margin: 1rem 0 0;
}
.sn-iracing-pagination button {
  background: #c90d05;
  color: #fff;
  border: 0;
  padding: 0.55rem 1.05rem;
  border-radius: 6px;
  font-size: 0.8rem;
  font-weight: 600;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.4);
  text-transform: uppercase;
  letter-spacing: 0.4px;
}
.sn-iracing-pagination button:hover:not([disabled]) {
  background: #e51107;
}
.sn-iracing-pagination button[disabled] {
  opacity: 0.4;
  cursor: default;
}
.sn-iracing-pagination .sn-pg-info {
  font-size: 0.75rem;
  color: #fff;
  font-weight: 500;
}
.sn-iracing-table td {
  padding: 0.5rem 0.6rem;
  text-align: left;
}
.sn-iracing-table thead th {
  position: sticky;
  top: 0;
  background: #202020;
  color: #fff;
  font-weight: 600;
  font-size: 0.72rem;
  letter-spacing: 0.5px;
  text-transform: uppercase;
  white-space: nowrap;
}
.sn-iracing-table thead th i {
  margin-right: 4px;
  opacity: 0.9;
}
.sn-iracing-table tbody tr:nth-child(even) {
  background: #181818;
}
.sn-iracing-table tbody tr:nth-child(odd) {
  background: #141414;
}
.sn-iracing-table tbody tr:hover {
  background: #1e1e1e;
}
.sn-iracing-row.highlight {
  outline: 2px solid #ffa500;
}
.sn-row-toggle {
  display: none;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  margin-left: 0.35rem;
  border-radius: 4px;
  border: 0;
  background: #2a2a2a;
  color: #fff;
  cursor: pointer;
}
.sn-row-toggle i {
  transition: transform 0.2s ease;
}
.sn-iracing-row.is-expanded .sn-row-toggle i {
  transform: rotate(180deg);
}
.sn-avatar {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  -o-object-fit: cover;
     object-fit: cover;
  display: block;
}
.sn-licencia-badge {
  display: inline-block;
  padding: 0.25rem 0.5rem;
  border-radius: 4px;
  color: #000;
  font-weight: 600;
  font-size: 0.75rem;
}
.sn-flag {
  width: 24px;
  height: 16px;
  display: inline-block;
  background-size: cover;
  background-position: center;
  border: 1px solid #555;
  border-radius: 2px;
}
.sn-flag-img {
  width: 24px;
  height: 16px;
  -o-object-fit: cover;
     object-fit: cover;
  border: 1px solid #555;
  border-radius: 2px;
  display: inline-block;
}
.sn-col-irating {
  font-weight: 600;
  color: #3fa9f5;
}
.sn-col-safety {
  font-weight: 600;
  color: #9bdc4d;
}
.sn-iracing-row.highlight td {
  box-shadow: inset 0 0 0 9999px rgba(255, 165, 0, 0.08);
}
.sn-iracing-pager {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin-top: 0.6rem;
}
.sn-pg-btn {
  background: #222;
  color: #fff;
  border: 0;
  padding: 0.45rem 0.8rem;
  border-radius: 4px;
  cursor: pointer;
  font-size: 0.75rem;
}
.sn-pg-btn[disabled] {
  opacity: 0.35;
  cursor: default;
}
.sn-pg-info {
  font-size: 0.75rem;
  color: #ccc;
}
}

@layer sn.core {
@media (max-width: 900px) {
  .sn-iracing-table {
    font-size: 12px;
  }
  .sn-iracing-table th,
  .sn-iracing-table td {
    padding: 0.4rem 0.5rem;
  }
  .sn-user-card-right {
    grid-template-columns: repeat(3, minmax(90px, 1fr));
  }
}
}

@layer sn.core {
@media (max-width: 680px) {
  .sn-iracing-tab-btn {
    flex: 1 1 calc(50% - 0.5rem);
    font-size: 0.75rem;
    padding: 0.5rem 0.4rem;
  }
  .sn-iracing-user-pos {
    font-size: 12px;
  }
  .sn-user-card {
    flex-direction: column;
    gap: 0.8rem;
  }
  .sn-user-card-left {
    width: 100%;
  }
  .sn-user-card-right {
    grid-template-columns: repeat(2, minmax(110px, 1fr));
  }
  .sn-user-pos-badge {
    min-width: 44px;
  }
  .sn-user-name {
    font-size: 0.95rem;
  }
  .sn-iracing-table {
    min-width: 0;
    table-layout: fixed;
  }
  .sn-iracing-table thead th {
    font-size: 0.7rem;
  }
  .sn-iracing-table thead th:nth-child(4),
  .sn-iracing-table thead th:nth-child(5),
  .sn-iracing-table thead th:nth-child(6),
  .sn-iracing-table thead th:nth-child(9),
  .sn-iracing-table thead th:nth-child(10),
  .sn-iracing-table thead th:nth-child(11),
  .sn-iracing-table tbody td:nth-child(4),
  .sn-iracing-table tbody td:nth-child(5),
  .sn-iracing-table tbody td:nth-child(6),
  .sn-iracing-table tbody td:nth-child(9),
  .sn-iracing-table tbody td:nth-child(10),
  .sn-iracing-table tbody td:nth-child(11) {
    display: none;
  }
  .sn-iracing-table thead th:nth-child(1),
  .sn-iracing-table tbody td:nth-child(1) {
    width: 44px;
  }
  .sn-iracing-table thead th:nth-child(2),
  .sn-iracing-table tbody td:nth-child(2) {
    width: 52px;
  }
  .sn-iracing-table thead th:nth-child(7),
  .sn-iracing-table tbody td:nth-child(7) {
    width: 80px;
  }
  .sn-iracing-table thead th:nth-child(8),
  .sn-iracing-table tbody td:nth-child(8) {
    width: 70px;
  }
  .sn-row-toggle {
    display: inline-flex;
  }
  .sn-iracing-row.is-expanded + .sn-iracing-row-details {
    display: table-row;
  }
  .sn-iracing-row-details td {
    padding: 0.6rem;
    background: #101010;
    border-top: 1px solid #262626;
  }
  .sn-row-details-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.5rem 1rem;
  }
  .sn-row-details-item {
    display: flex;
    gap: 0.5rem;
    align-items: center;
  }
}
}

@layer sn.core {
.sn-panel.sn-dark {
  background: #0f1115;
  color: #e6e6e6;
  border: 1px solid #1e232b;
  border-radius: 8px;
  padding: 16px;
  margin: 12px 0;
}
.sn-form-grid {
  display: grid;
  grid-template-columns: 1fr 200px 1fr;
  gap: 12px;
  margin: 10px 0 16px;
}
.sn-input,
.sn-textarea,
.sn-destino-row input[type="text"],
.sn-destino-row select {
  width: 100%;
  background: #141922;
  color: #e6e6e6;
  border: 1px solid #2a2f39;
  border-radius: 6px;
  padding: 8px;
}
.sn-textarea {
  min-height: 160px;
}
.sn-destino-row {
  display: grid;
  grid-template-columns: 220px 1fr 260px 160px;
  gap: 8px;
  align-items: center;
  margin-bottom: 8px;
}
.sn-actions {
  display: flex;
  gap: 10px;
  margin-top: 12px;
}
.sn-actions .button {
  background: #1a2332;
  border: 1px solid #2b364a;
  color: #d6dde7;
  padding: 8px 12px;
  border-radius: 6px;
}
.sn-actions .button.button-primary {
  background: #19301e;
  border-color: #295634;
  color: #d6e7d6;
}
.sn-actions .button:hover {
  filter: brightness(1.05);
}
.sn-result {
  margin-top: 14px;
  padding: 10px;
  background: #0c0f14;
  border: 1px solid #1e232b;
  border-radius: 6px;
  white-space: pre-wrap;
}
.sn-table-wrapper {
  overflow: auto;
  max-height: 520px;
  border: 1px solid #1e232b;
  border-radius: 6px;
}
.sn-table {
  width: 100%;
  border-collapse: collapse;
  table-layout: fixed;
  min-width: 920px;
  margin: 0;
  display: table !important;
}
.sn-table thead {
  display: table-header-group !important;
}
.sn-table tbody {
  display: table-row-group !important;
}
.sn-table tr {
  display: table-row !important;
  float: none !important;
}
.sn-table th,
.sn-table td {
  display: table-cell !important;
  float: none !important;
  clear: none !important;
}
.sn-table thead th,
.sn-table tbody td {
  border: 1px solid #222733;
  padding: 8px 10px;
  box-sizing: border-box;
  vertical-align: middle;
  white-space: nowrap;
}
.sn-table thead th {
  background: #0c111c;
  color: #a9b2c4;
  text-align: left;
}
.sn-table tbody tr:nth-child(odd) {
  background: #0d1017;
}
.sn-table tbody tr:nth-child(even) {
  background: #0b0f15;
}
.sn-table tbody tr:hover {
  background: #141b2a;
}
.sn-selected {
  outline: 2px solid #2b5d8a;
}
col.sn-col-id {
  width: 72px;
}
col.sn-col-asunto {
  width: 380px;
}
col.sn-col-tipo {
  width: 120px;
}
col.sn-col-sent {
  width: 92px;
}
col.sn-col-queued {
  width: 110px;
}
col.sn-col-failed,
col.sn-col-bounced {
  width: 92px;
}
col.sn-col-complained {
  width: 110px;
}
col.sn-col-unsub {
  width: 92px;
}
col.sn-col-actions {
  width: 320px;
}
.sn-table td:nth-child(1),
.sn-table th:nth-child(1),
.sn-table td:nth-child(4),
.sn-table th:nth-child(4),
.sn-table td:nth-child(5),
.sn-table th:nth-child(5),
.sn-table td:nth-child(6),
.sn-table th:nth-child(6),
.sn-table td:nth-child(7),
.sn-table th:nth-child(7),
.sn-table td:nth-child(8),
.sn-table th:nth-child(8),
.sn-table td:nth-child(9),
.sn-table th:nth-child(9) {
  text-align: right;
}
.sn-table td:nth-child(2),
.sn-table th:nth-child(2) {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  max-width: 380px;
}
.sn-row-actions {
  display: inline-flex;
  gap: 6px;
  white-space: nowrap;
}
.sn-row-actions .button {
  background: #1a2332;
  color: #d6dde7;
  border: 1px solid #2b364a;
  padding: 5px 8px;
  font-size: 12px;
  line-height: 1.15;
}
.sn-row-actions .button:hover {
  filter: brightness(1.08);
}
.sn-badge {
  display: inline-block;
  padding: 2px 6px;
  border-radius: 999px;
  font-size: 11px;
  margin-left: 6px;
  border: 1px solid transparent;
}
.sn-badge-green {
  background: #12261a;
  color: #6cd881;
  border-color: #2b5a3c;
}
.sn-badge-gray {
  background: #151a24;
  color: #9aa7b6;
  border-color: #2b3140;
}
.sn-pill {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 999px;
  font-size: 12px;
  background: #131a27;
  border: 1px solid #25314a;
  color: #cfd7e4;
  text-transform: capitalize;
}
.select2-container .select2-selection {
  background: #141922;
  color: #e6e6e6;
  border: 1px solid #2a2f39;
  border-radius: 6px;
}
.sn-comisarios-wrap {
  font-family: var(--sn-font-sans, "Inter", system-ui, sans-serif);
  color: var(--sn-color-text, #f5f5f5);
}
.sn-comisarios-wrap .sn-topbar {
  display: flex;
  justify-content: flex-end;
  gap: var(--sn-space-2, 8px);
  margin-bottom: var(--sn-space-3, 16px);
}
.sn-comisarios-wrap .sn-tz-note {
  font-size: 0.75rem;
  color: rgba(255, 255, 255, 0.7);
  margin: 6px 0 10px;
}
.sn-comisarios-wrap .sn-tabs,
.sn-comisarios-wrap [data-sn="modal-tabs"] {
  display: flex;
  gap: 6px;
  padding: 4px;
  margin: 0 0 var(--sn-space-3, 16px);
  list-style: none;
  border-radius: var(--sn-radius-pill, 999px);
  border: 1px solid var(--sn-color-border, #2a2a2a);
  background: rgba(255, 255, 255, 0.03);
}
.sn-comisarios-wrap .sn-tabs li,
.sn-comisarios-wrap [data-sn="modal-tabs"] li {
  padding: 6px 16px;
  border-radius: var(--sn-radius-pill, 999px);
  border: 1px solid transparent;
  color: var(--sn-color-text-soft, #cfcfcf);
  font-weight: 600;
  cursor: pointer;
  transition:
    background 0.15s,
    color 0.15s,
    border-color 0.15s;
}
.sn-comisarios-wrap .sn-tabs li.is-active,
.sn-comisarios-wrap [data-sn="modal-tabs"] li.is-active {
  background: var(--sn-grad-theme, linear-gradient(135deg, #c90d05, #870500));
  border-color: var(--sn-theme-primary-accent, #870500);
  color: #fff;
  box-shadow: 0 4px 12px rgba(201, 13, 5, 0.35);
}
.sn-comisarios-wrap .sn-tab-content {
  background: var(--sn-color-surface, #151515);
  border: 1px solid var(--sn-color-border, #2a2a2a);
  border-radius: var(--sn-radius-lg, 12px);
  padding: var(--sn-space-4, 18px);
  margin-bottom: var(--sn-space-4, 18px);
  box-shadow: var(--sn-shadow, 0 10px 30px rgba(0, 0, 0, 0.4));
}
.sn-comisarios-wrap .sn-role-section {
  margin-bottom: var(--sn-space-4, 18px);
  padding: var(--sn-space-3, 14px);
  border-radius: var(--sn-radius, 10px);
  border: 1px solid var(--sn-color-border, #2a2a2a);
  background: rgba(255, 255, 255, 0.01);
  position: relative;
  box-shadow: var(--sn-shadow-sm, 0 6px 18px rgba(0, 0, 0, 0.45));
}
.sn-comisarios-wrap .sn-role-section::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  border-left: 3px solid var(--sn-color-border, #2a2a2a);
  pointer-events: none;
}
.sn-comisarios-wrap .sn-role-section[data-role="6"]::before {
  border-color: var(--sn-primary, #c90d05);
}
.sn-comisarios-wrap .sn-section-title {
  margin: 0 0 var(--sn-space-2, 8px);
  font: 700 0.95rem var(--sn-font-sans, "Inter");
  color: var(--sn-color-text);
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.sn-comisarios-wrap table.sn-table {
  background: var(--sn-color-surface-alt, #101010);
  border-radius: var(--sn-radius, 10px);
  border: 1px solid var(--sn-color-border, #2a2a2a);
  overflow: hidden;
}
.sn-comisarios-wrap table.sn-table th {
  background: rgba(255, 255, 255, 0.03);
  font-size: 0.78rem;
  letter-spacing: 0.04em;
  color: var(--sn-color-text-soft, #b9c1d1);
}
.sn-comisarios-wrap table.sn-table td {
  font-size: 0.85rem;
  vertical-align: middle;
}
.sn-comisarios-wrap table.sn-table td:last-child {
  white-space: nowrap;
  width: 160px;
}
.sn-comisarios-wrap table.sn-table tbody tr:nth-child(even) td {
  background: rgba(255, 255, 255, 0.015);
}
.sn-comisarios-wrap .sn-table--compact th,
.sn-comisarios-wrap .sn-table--compact td {
  padding: 0.4rem 0.55rem;
}
.sn-comisarios-wrap table .sn-btn {
  margin-right: 6px;
}
.sn-comisarios-wrap table .sn-btn:last-child {
  margin-right: 0;
}
.sn-comisarios-wrap .sn-com-item {
  background: var(--sn-color-surface, #151515);
  border: 1px solid var(--sn-color-border, #2a2a2a);
  border-radius: var(--sn-radius, 10px);
  padding: var(--sn-space-3, 14px);
  margin-bottom: var(--sn-space-3, 14px);
  box-shadow: var(--sn-shadow-xs, 0 6px 16px rgba(0, 0, 0, 0.45));
}
.sn-comisarios-wrap .sn-com-head {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  font-size: 0.82rem;
  font-weight: 600;
  margin-bottom: 4px;
  color: var(--sn-color-text);
}
.sn-comisarios-wrap .sn-com-date {
  margin-left: auto;
  font-size: 0.75rem;
  color: var(--sn-color-text-faint, #9aa0a8);
}
.sn-comisarios-wrap .sn-com-text {
  margin: 0;
  line-height: 1.4;
  color: var(--sn-color-text-soft, #cfd4df);
  white-space: pre-line;
}
.sn-comisarios-wrap .sn-com-adj {
  margin-top: 8px;
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  font-size: 0.78rem;
}
.sn-comisarios-wrap .sn-com-adj a {
  color: var(--sn-primary, #c90d05);
  text-decoration: none;
}
.sn-comisarios-wrap .sn-com-adj a:hover {
  text-decoration: underline;
}
.sn-comisarios-wrap .sn-form label {
  font-weight: 600;
  color: var(--sn-color-text-soft, #c0c7d6);
}
.sn-comisarios-wrap .select2-container--default .select2-selection--single,
.sn-comisarios-wrap .select2-container--default .select2-selection--multiple {
  background: var(--sn-color-surface-alt, #121212) !important;
  border: 1px solid var(--sn-color-border, #2c2c2c) !important;
  color: var(--sn-color-text, #f3f3f3) !important;
  border-radius: var(--sn-radius-pill, 999px) !important;
  min-height: 44px;
}
.sn-comisarios-wrap
  .select2-container--default
  .select2-selection--single
  .select2-selection__rendered,
.sn-comisarios-wrap
  .select2-container--default
  .select2-selection--multiple
  .select2-selection__rendered {
  color: inherit !important;
  line-height: 42px !important;
  padding-left: 12px !important;
}
.sn-comisarios-wrap
  .select2-container--default
  .select2-selection--multiple
  .select2-selection__rendered {
  line-height: normal !important;
  padding: 6px 10px !important;
}
.sn-comisarios-wrap
  .select2-container--default
  .select2-selection--single
  .select2-selection__arrow
  b {
  border-color: var(--sn-color-text, #fff) transparent transparent transparent !important;
}
.sn-comisarios-wrap .select2-dropdown {
  background: var(--sn-color-surface, #151515) !important;
  border: 1px solid var(--sn-color-border, #2a2a2a) !important;
}
.sn-comisarios-wrap .select2-results__option {
  color: var(--sn-color-text, #fff) !important;
}
.sn-comisarios-wrap .select2-results__option--highlighted {
  background: var(--sn-theme-primary, #c90d05) !important;
}
.sn-comisarios-wrap .sn-modal .select2-container {
  z-index: calc(var(--sn-z-modal, 5000) + 20);
}
.sn-comisarios-wrap .select2-container--open {
  z-index: calc(var(--sn-z-modal, 5000) + 30);
}
.sn-comisarios-wrap [data-sn="modal-tab-resolver"] .sn-form .sn-grid.sn-grid-3 {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr)) auto;
  gap: var(--sn-space-2, 8px);
  align-items: end;
}
.sn-comisarios-wrap hr {
  border: 0;
  border-top: 1px solid rgba(255, 255, 255, 0.06);
  margin: var(--sn-space-4, 18px) 0;
}
.sn-comisarios-wrap .sn-modal__dialog {
  width: min(95vw, 1100px);
  max-height: 92vh;
  overflow: hidden;
}
}

@layer sn.core {
@media (max-width: 1024px) {
  .sn-comisarios-wrap
    [data-sn="modal-tab-resolver"]
    .sn-form
    .sn-grid.sn-grid-3 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
}

@layer sn.core {
@media (max-width: 680px) {
  .sn-comisarios-wrap .sn-tabs,
  .sn-comisarios-wrap [data-sn="modal-tabs"] {
    flex-wrap: wrap;
    border-radius: var(--sn-radius, 12px);
  }
  .sn-comisarios-wrap .sn-tabs li,
  .sn-comisarios-wrap [data-sn="modal-tabs"] li {
    flex: 1 1 45%;
    justify-content: center;
    text-align: center;
  }
  .sn-comisarios-wrap
    [data-sn="modal-tab-resolver"]
    .sn-form
    .sn-grid.sn-grid-3 {
    grid-template-columns: 1fr;
  }
  .sn-comisarios-wrap table.sn-table td:last-child {
    white-space: normal;
  }
  .sn-comisarios-wrap table .sn-btn {
    margin-bottom: 6px;
  }
}
}

@layer sn.core {
.sn-denuncias-endurance {
  background: #1a1a1a;
  border-radius: 8px;
  padding: 20px;
  color: #e0e0e0;
  max-width: 1400px;
  margin: 0 auto;
}
.sn-denuncias-message {
  background: #2a2a2a;
  border: 2px dashed #444;
  border-radius: 8px;
  padding: 40px;
  display: inline-block;
}
.sn-denuncias-message i {
  font-size: 48px;
  color: #666;
  margin-bottom: 20px;
}
.sn-denuncias-message p {
  font-size: 16px;
  margin: 0;
}
.sn-denuncias-message a {
  color: #4caf50;
  text-decoration: none;
  font-weight: 600;
}
.sn-denuncias-message a:hover {
  text-decoration: underline;
}
.sn-denuncias-tabs {
  display: flex;
  gap: 10px;
  margin-bottom: 20px;
  border-bottom: 2px solid #333;
}
.sn-denuncias-tab {
  background: #2a2a2a;
  color: #999;
  border: none;
  padding: 12px 24px;
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  border-radius: 6px 6px 0 0;
  transition: all 0.2s ease;
  display: flex;
  align-items: center;
  gap: 8px;
}
.sn-denuncias-tab:hover {
  background: #333;
  color: #fff;
}
.sn-denuncias-tab.active {
  background: #4caf50;
  color: #fff;
}
.sn-denuncias-tab i {
  font-size: 16px;
}
.sn-denuncias-panel {
  display: none;
}
.sn-denuncias-panel.active {
  display: block;
}
.sn-denuncias-header {
  display: flex;
  gap: 10px;
  margin-bottom: 20px;
  justify-content: flex-end;
}
.sn-denuncias-endurance .sn-btn {
  background: #4caf50;
  color: #fff;
  border: none;
  padding: 10px 20px;
  font-size: 14px;
  font-weight: 600;
  border-radius: 6px;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  transition: all 0.2s ease;
}
.sn-denuncias-endurance .sn-btn:hover {
  background: #45a049;
  transform: translateY(-2px);
}
.sn-denuncias-endurance .sn-btn-admin {
  background: #ff9800;
}
.sn-denuncias-endurance .sn-btn-admin:hover {
  background: #e68900;
}
.sn-denuncias-endurance .sn-btn-sm {
  padding: 6px 12px;
  font-size: 12px;
}
.sn-denuncias-table,
.sn-sanciones-table,
.sn-puntos-table,
.sn-historial-table {
  width: 100%;
  border-collapse: collapse;
  background: #2a2a2a;
  border-radius: 6px;
  overflow: hidden;
}
.sn-denuncias-table thead,
.sn-sanciones-table thead,
.sn-puntos-table thead,
.sn-historial-table thead {
  background: #333;
}
.sn-denuncias-table th,
.sn-sanciones-table th,
.sn-puntos-table th,
.sn-historial-table th {
  padding: 12px;
  text-align: left;
  font-weight: 600;
  color: #fff;
  border-bottom: 2px solid #444;
}
.sn-denuncias-table td,
.sn-sanciones-table td,
.sn-puntos-table td,
.sn-historial-table td {
  padding: 12px;
  border-bottom: 1px solid #333;
}
.sn-denuncias-table tbody tr:hover,
.sn-sanciones-table tbody tr:hover,
.sn-puntos-table tbody tr:hover,
.sn-historial-table tbody tr:hover {
  background: #333;
}
.sn-denuncias-endurance .sn-estado,
.sn-modal.sn-modal-denuncia .sn-estado,
.sn-modal.sn-modal-resolver .sn-estado,
.sn-modal.sn-modal-ver .sn-estado,
.sn-modal.sn-modal-historial .sn-estado {
  display: inline-block;
  padding: 4px 12px;
  border-radius: 12px;
  font-size: 12px;
  font-weight: 600;
  background: #444;
  color: #fff;
}
.sn-denuncias-endurance .sn-estado.en-proceso,
.sn-modal.sn-modal-denuncia .sn-estado.en-proceso,
.sn-modal.sn-modal-resolver .sn-estado.en-proceso,
.sn-modal.sn-modal-ver .sn-estado.en-proceso {
  background: #6a1b9a !important;
  color: #fff !important;
}
.sn-denuncias-endurance .sn-estado.resuelta,
.sn-modal.sn-modal-denuncia .sn-estado.resuelta,
.sn-modal.sn-modal-resolver .sn-estado.resuelta,
.sn-modal.sn-modal-ver .sn-estado.resuelta {
  background: #2e7d32 !important;
  color: #fff !important;
}
.sn-denuncias-endurance .sn-estado.pendiente,
.sn-modal.sn-modal-denuncia .sn-estado.pendiente,
.sn-modal.sn-modal-resolver .sn-estado.pendiente {
  background: #ffc107;
  color: #000;
}
.sn-denuncias-endurance .sn-estado.revision,
.sn-modal.sn-modal-denuncia .sn-estado.revision,
.sn-modal.sn-modal-resolver .sn-estado.revision {
  background: #2196f3;
}
.sn-denuncias-endurance .sn-estado.rechazada,
.sn-modal.sn-modal-denuncia .sn-estado.rechazada,
.sn-modal.sn-modal-resolver .sn-estado.rechazada {
  background: #f44336;
}
.sn-modal-overlay.sn-denuncias-overlay {
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  background: rgba(0, 0, 0, 0.85) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  z-index: 10000 !important;
  padding: 20px !important;
  backdrop-filter: blur(4px);
}
.sn-modal.sn-modal-denuncia,
.sn-modal.sn-modal-resolver,
.sn-modal.sn-modal-ver,
.sn-modal.sn-modal-historial {
  background: #1a1a1a !important;
  border: 1px solid #333 !important;
  border-radius: 12px !important;
  width: 90% !important;
  max-width: 550px !important;
  min-width: 320px !important;
  max-height: 90vh !important;
  overflow: hidden !important;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.8) !important;
  display: flex !important;
  flex-direction: column !important;
  position: relative !important;
  margin: 0 !important;
}
.sn-modal.sn-modal-denuncia .sn-modal-header,
.sn-modal.sn-modal-resolver .sn-modal-header,
.sn-modal.sn-modal-ver .sn-modal-header,
.sn-modal.sn-modal-historial .sn-modal-header {
  background: #2a2a2a !important;
  padding: 20px 24px !important;
  border-bottom: 2px solid #4caf50 !important;
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  flex-shrink: 0 !important;
  position: relative !important;
}
.sn-modal.sn-modal-denuncia .sn-modal-header h3,
.sn-modal.sn-modal-resolver .sn-modal-header h3,
.sn-modal.sn-modal-ver .sn-modal-header h3,
.sn-modal.sn-modal-historial .sn-modal-header h3 {
  margin: 0 !important;
  font-size: 20px !important;
  font-weight: 700 !important;
  color: #fff !important;
  letter-spacing: 0.5px !important;
}
.sn-denuncias-overlay .sn-modal-close {
  background: none;
  border: none;
  color: #999;
  font-size: 32px;
  cursor: pointer;
  padding: 0;
  width: 36px;
  height: 36px;
  line-height: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 4px;
  transition: all 0.2s ease;
}
.sn-denuncias-overlay .sn-modal-close:hover {
  color: #fff;
  background: rgba(255, 255, 255, 0.1);
  transform: rotate(90deg);
}
.sn-modal.sn-modal-denuncia .sn-modal-body,
.sn-modal.sn-modal-resolver .sn-modal-body,
.sn-modal.sn-modal-ver .sn-modal-body,
.sn-modal.sn-modal-historial .sn-modal-body {
  padding: 24px !important;
  overflow-y: auto !important;
  flex: 1 !important;
  min-height: 0 !important;
}
.sn-modal-denuncia .sn-form-group label,
.sn-modal-resolver .sn-form-group label {
  display: block !important;
  margin-bottom: 8px !important;
  font-weight: 600 !important;
  color: #e0e0e0 !important;
  font-size: 14px !important;
}
.sn-modal.sn-modal-denuncia .sn-form-group label::after,
.sn-modal.sn-modal-resolver .sn-form-group label::after {
  content: " *";
  color: #f44336;
  display: none;
}
.sn-modal-denuncia .sn-input,
.sn-modal-denuncia .sn-textarea,
.sn-modal-resolver .sn-input,
.sn-modal-resolver .sn-textarea {
  width: 100% !important;
  background: #2a2a2a !important;
  border: 2px solid #444 !important;
  color: #e0e0e0 !important;
  padding: 12px 14px !important;
  border-radius: 6px !important;
  font-size: 14px !important;
  font-family: inherit !important;
  transition: all 0.2s ease !important;
  box-sizing: border-box !important;
}
.sn-modal-denuncia .sn-input:focus,
.sn-modal-denuncia .sn-textarea:focus {
  outline: none !important;
  border-color: #4caf50 !important;
  background: #2d2d2d !important;
  box-shadow: 0 0 0 3px rgba(76, 175, 80, 0.1) !important;
}
.sn-modal-denuncia .sn-input::-moz-placeholder, .sn-modal-denuncia .sn-textarea::-moz-placeholder, .sn-modal-resolver .sn-input::-moz-placeholder, .sn-modal-resolver .sn-textarea::-moz-placeholder {
  color: #666 !important;
}
.sn-modal-denuncia .sn-input::placeholder,
.sn-modal-denuncia .sn-textarea::placeholder,
.sn-modal-resolver .sn-input::placeholder,
.sn-modal-resolver .sn-textarea::placeholder {
  color: #666 !important;
}
.sn-modal-denuncia .sn-textarea,
.sn-modal-resolver .sn-textarea {
  resize: vertical !important;
  min-height: 120px !important;
  line-height: 1.6 !important;
}
.sn-denuncias-endurance .select2-container--default .select2-selection--single,
.sn-modal-denuncia .select2-container--default .select2-selection--single,
.sn-modal-resolver .select2-container--default .select2-selection--single {
  background: #2a2a2a !important;
  border: 2px solid #444 !important;
  color: #e0e0e0 !important;
  height: 46px !important;
  border-radius: 6px !important;
  transition: all 0.2s ease !important;
  display: flex !important;
  align-items: center !important;
}
.sn-denuncias-endurance
  .select2-container--default
  .select2-selection--single
  .select2-selection__rendered,
.sn-modal-denuncia
  .select2-container--default
  .select2-selection--single
  .select2-selection__rendered,
.sn-modal-resolver
  .select2-container--default
  .select2-selection--single
  .select2-selection__rendered {
  color: #e0e0e0 !important;
  line-height: 46px !important;
  padding-left: 14px !important;
  padding-right: 40px !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  display: block !important;
}
.sn-denuncias-endurance
  .select2-container--default
  .select2-selection--single
  .select2-selection__arrow,
.sn-modal-denuncia
  .select2-container--default
  .select2-selection--single
  .select2-selection__arrow,
.sn-modal-resolver
  .select2-container--default
  .select2-selection--single
  .select2-selection__arrow {
  height: 46px !important;
  right: 10px !important;
  top: 0 !important;
}
.sn-denuncias-endurance
  .select2-container--default
  .select2-selection--single
  .select2-selection__arrow
  b,
.sn-modal-denuncia
  .select2-container--default
  .select2-selection--single
  .select2-selection__arrow
  b,
.sn-modal-resolver
  .select2-container--default
  .select2-selection--single
  .select2-selection__arrow
  b {
  border-color: #e0e0e0 transparent transparent transparent !important;
}
.sn-denuncias-endurance
  .select2-container--default
  .select2-selection--single
  .select2-selection__placeholder,
.sn-modal-denuncia
  .select2-container--default
  .select2-selection--single
  .select2-selection__placeholder,
.sn-modal-resolver
  .select2-container--default
  .select2-selection--single
  .select2-selection__placeholder {
  color: #666 !important;
}
.select2-dropdown {
  background: #2a2a2a !important;
  border: 2px solid #444 !important;
  border-radius: 6px !important;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.5) !important;
  z-index: 10001 !important;
}
.select2-container--default .select2-search--dropdown {
  padding: 8px !important;
}
.select2-container--default .select2-search--dropdown .select2-search__field {
  background: #1a1a1a !important;
  border: 2px solid #444 !important;
  color: #e0e0e0 !important;
  padding: 10px 12px !important;
  border-radius: 6px !important;
}
.select2-container--default .select2-results__option {
  color: #e0e0e0 !important;
  background: #2a2a2a !important;
  padding: 12px 16px !important;
  font-size: 14px !important;
}
.select2-container--default
  .select2-results__option--highlighted[aria-selected] {
  background: #4caf50 !important;
  color: #fff !important;
}
.select2-container--default .select2-results__option[aria-selected="true"] {
  background: #333 !important;
  color: #4caf50 !important;
  font-weight: 600 !important;
}
.sn-denuncias-endurance
  .select2-container--default.select2-container--focus
  .select2-selection--single,
.sn-modal-denuncia
  .select2-container--default.select2-container--focus
  .select2-selection--single,
.sn-modal-resolver
  .select2-container--default.select2-container--focus
  .select2-selection--single {
  border-color: #4caf50 !important;
  box-shadow: 0 0 0 3px rgba(76, 175, 80, 0.1) !important;
}
.sn-denuncias-overlay .sn-modal-actions {
  display: flex;
  gap: 12px;
  justify-content: flex-end;
  margin-top: 24px;
  padding-top: 24px;
  border-top: 2px solid #333;
}
.sn-denuncia-info p {
  margin: 8px 0;
  line-height: 1.6;
}
.sn-denuncia-info strong {
  color: #4caf50;
  margin-right: 6px;
}
.sn-denuncia-desc,
.sn-denuncia-concepto {
  background: #2a2a2a;
  padding: 12px;
  border-radius: 4px;
  margin-top: 8px;
  white-space: pre-wrap;
  word-wrap: break-word;
  line-height: 1.6;
}
.sn-loading {
  text-align: center;
  padding: 40px 20px;
  color: #999;
}
.sn-loading i {
  font-size: 32px;
  margin-bottom: 10px;
}
.sn-error {
  text-align: center;
  padding: 40px 20px;
  color: #f44336;
  background: rgba(244, 67, 54, 0.1);
  border-radius: 6px;
}
.sn-empty {
  text-align: center;
  padding: 40px 20px;
  color: #999;
  font-style: italic;
}
}

@layer sn.core {
@media (max-width: 768px) {
  .sn-denuncias-tabs {
    flex-wrap: wrap;
  }
  .sn-denuncias-tab {
    flex: 1;
    justify-content: center;
  }
  .sn-denuncias-header {
    flex-direction: column;
  }
  .sn-denuncias-endurance .sn-btn {
    width: 100%;
    justify-content: center;
  }
  .sn-denuncias-table,
  .sn-sanciones-table,
  .sn-puntos-table,
  .sn-historial-table {
    font-size: 12px;
  }
  .sn-denuncias-table th,
  .sn-denuncias-table td,
  .sn-sanciones-table th,
  .sn-sanciones-table td,
  .sn-puntos-table th,
  .sn-puntos-table td,
  .sn-historial-table th,
  .sn-historial-table td {
    padding: 8px 6px;
  }
  .sn-modal.sn-modal-denuncia,
  .sn-modal.sn-modal-resolver,
  .sn-modal.sn-modal-ver,
  .sn-modal.sn-modal-historial {
    max-width: 100%;
    margin: 10px;
  }
  .sn-denuncias-overlay .sn-modal-actions {
    flex-direction: column;
  }
  .sn-denuncias-overlay .sn-modal-actions .sn-btn {
    width: 100%;
  }
}
}

@layer sn.core {
.sn-endurance {
  background: #0e0f12;
  border: 1px solid #252738;
  border-radius: 16px;
  padding: 16px;
  color: #e8eaf1;
  font-family:
    system-ui,
    Segoe UI,
    Roboto,
    sans-serif;
}
.sn-endu-head {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 14px;
}
.sn-endu-head h3 {
  margin: 0;
  font-size: 20px;
  font-weight: 700;
}
.sn-loading {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 14px;
  opacity: 0.85;
}
.sn-endu-cat {
  margin: 24px 0 32px;
}
.sn-endu-cat-h {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 10px;
}
.sn-endu-cat-h h4 {
  margin: 0;
  font-size: 18px;
  font-weight: 600;
}
.sn-endu-table-wrap {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
.sn-endu-table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0 6px;
  min-width: 880px;
}
.sn-endu-table thead th {
  background: #151726;
  border: 1px solid #2a2f43;
  padding: 8px 10px;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.6px;
  color: #c8ccdd;
}
.sn-endu-table thead th:first-child {
  border-top-left-radius: 10px;
  border-bottom-left-radius: 10px;
}
.sn-endu-table thead th:last-child {
  border-top-right-radius: 10px;
  border-bottom-right-radius: 10px;
}
.sn-endu-table td {
  background: #121318;
  border-top: 1px solid #2a2f43;
  border-bottom: 1px solid #2a2f43;
  padding: 10px 12px;
  vertical-align: middle;
}
.sn-endu-table tr td:first-child {
  border-left: 1px solid #2a2f43;
  border-top-left-radius: 10px;
  border-bottom-left-radius: 10px;
}
.sn-endu-table tr td:last-child {
  border-right: 1px solid #2a2f43;
  border-top-right-radius: 10px;
  border-bottom-right-radius: 10px;
}
.sn-endu-logo-car {
  position: relative;
  width: 140px;
  height: 82px;
  border-radius: 12px;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #191c24;
  border: 1px solid #2a2f43;
}
.sn-endu-logo-car img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  display: block;
}
.sn-endu-logo-car .sn-team-logo-mini {
  position: absolute;
  top: 6px;
  left: 6px;
  width: 42px;
  height: 42px;
  border-radius: 10px;
  background: #111;
  border: 1px solid #2a2f43;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}
.sn-endu-logo-car .sn-team-logo-mini img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.sn-endu-title {
  font-size: 16px;
  font-weight: 700;
  line-height: 1.2;
  display: inline-block;
  padding: 6px 10px;
  border-radius: 10px;
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.06);
  max-width: 260px;
}
.sn-endu-pilotos {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.sn-endu-piloto {
  display: flex;
  align-items: center;
  gap: 8px;
  background: #1b1d25;
  padding: 6px 8px;
  border-radius: 10px;
  border: 1px solid #2a2f43;
}
.sn-endu-avatar {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  overflow: hidden;
  background: #222;
}
.sn-endu-avatar img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  display: block;
}
.sn-endu-pname {
  font-size: 13px;
  font-weight: 600;
}
.sn-endu-iracing {
  display: block;
  font-size: 10px;
  line-height: 1.1;
  color: #9aa0b2;
  margin-top: 2px;
}
.sn-endu-ir-col,
.sn-endu-prom-col {
  font-weight: 700;
  font-size: 14px;
  text-align: center;
  color: #3fa9f5;
}
}

@layer sn.core {
@media (max-width: 920px) {
  .sn-endu-table {
    min-width: 760px;
  }
  .sn-endu-logo-car {
    width: 120px;
    height: 70px;
  }
}
}

@layer sn.core {
@media (max-width: 680px) {
  .sn-endu-table {
    min-width: 680px;
  }
  .sn-endu-logo-car {
    width: 110px;
    height: 64px;
  }
  .sn-endu-title {
    font-size: 15px;
    padding: 5px 8px;
  }
}
}

@layer sn.core {
.ee-loading,
.ee-error {
  font-size: 14px;
  padding: 8px 10px;
}
.ee-categoria-titulo {
  margin: 28px 4px 10px;
  font-size: 18px;
  font-weight: 700;
  color: #cfd3e2;
}
table.ee-tabla {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0 6px;
  font-size: 14px;
  min-width: 760px;
}
table.ee-tabla thead th {
  background: #151726;
  border: 1px solid #2a2f43;
  padding: 8px 10px;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.6px;
  color: #c8ccdd;
}
table.ee-tabla thead th:first-child {
  border-top-left-radius: 10px;
  border-bottom-left-radius: 10px;
}
table.ee-tabla thead th:last-child {
  border-top-right-radius: 10px;
  border-bottom-right-radius: 10px;
}
table.ee-tabla tbody td {
  background: #121318;
  border-top: 1px solid #2a2f43;
  border-bottom: 1px solid #2a2f43;
  padding: 10px 12px;
  vertical-align: middle;
}
table.ee-tabla tbody tr.ee-row-pendiente td {
  background: #221314;
  border-color: #3d1f22;
}
table.ee-tabla tbody tr.ee-row-aprobado td {
  background: #132219;
  border-color: #1f3e2f;
}
table.ee-tabla tbody tr td:first-child {
  border-left: 1px solid #2a2f43;
  border-top-left-radius: 10px;
  border-bottom-left-radius: 10px;
}
table.ee-tabla tbody tr td:last-child {
  border-right: 1px solid #2a2f43;
  border-top-right-radius: 10px;
  border-bottom-right-radius: 10px;
}
.ee-num {
  width: 42px;
  text-align: center;
  font-weight: 700;
  font-size: 13px;
  color: #9fa7b9;
}
.ee-num .ee-btn-livery {
  display: inline-block;
  margin-top: 4px;
  background: #1b1d25;
  border: 1px solid #2a2f43;
  color: #3fa9f5;
  font-size: 11px;
  font-weight: 700;
  line-height: 1;
  padding: 4px 6px;
  border-radius: 6px;
  cursor: pointer;
}
.ee-num .ee-btn-livery:hover {
  background: #0d3452;
  border-color: #2d4f6b;
}
.ee-img {
  width: 160px;
}
.ee-img-wrap {
  position: relative;
  width: 150px;
  height: 86px;
  border-radius: 12px;
  overflow: hidden;
  background: #191c24;
  border: 1px solid #2a2f43;
  display: flex;
  align-items: center;
  justify-content: center;
}
img.ee-auto {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  display: block;
}
img.ee-logo {
  position: absolute;
  top: 6px;
  left: 6px;
  width: 46px;
  height: 46px;
  border-radius: 10px;
  background: #111;
  border: 1px solid #2a2f43;
  -o-object-fit: cover;
     object-fit: cover;
}
.ee-equipo-chip {
  display: inline-flex;
  flex-direction: column;
  gap: 4px;
  padding: 8px 12px;
  border-radius: 12px;
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.07);
  min-width: 180px;
  max-width: 240px;
}
.ee-equipo-chip .ee-numero {
  font-size: 11px;
  font-weight: 700;
  opacity: 0.85;
  letter-spacing: 0.5px;
}
.ee-livery-pend {
  margin-top: 4px;
  font-size: 11px;
  font-weight: 600;
  color: #f5c33f;
  background: #3d3008;
  padding: 4px 6px;
  border-radius: 6px;
  display: inline-block;
}
.ee-notas-admin {
  margin-top: 6px;
  font-size: 13px;
  line-height: 1.4;
  background: #1a1d27;
  border: 1px solid #2a3042;
  border-left: 4px solid #c90d05;
  padding: 10px 12px;
  border-radius: 12px;
  max-width: 360px;
}
.ee-pilotos-wrap {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.ee-status-msg {
  flex: 1 1 100%;
  font-size: 11px;
  font-weight: 600;
  margin-top: 6px;
  background: #1b1d25;
  border: 1px solid #2a2f43;
  color: #cfd3e2;
  padding: 6px 8px;
  border-radius: 8px;
}
.ee-piloto {
  display: flex;
  align-items: center;
  gap: 8px;
  background: #1b1d25;
  padding: 6px 8px;
  border-radius: 10px;
  border: 1px solid #2a2f43;
  position: relative;
}
img.ee-piloto-avatar {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  -o-object-fit: cover;
     object-fit: cover;
  background: #222;
  border: 1px solid #2a2f43;
}
.ee-piloto-info {
  display: flex;
  flex-direction: column;
  line-height: 1.1;
}
.ee-piloto-nombre {
  font-size: 13px;
  font-weight: 600;
  color: #e3e6ef;
  max-width: 120px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.ee-piloto-meta {
  margin-top: 3px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.ee-piloto-meta .ee-flag {
  width: 20px;
  height: auto;
  border-radius: 2px;
  border: 1px solid #2a2f43;
}
.ee-piloto-ir-badge {
  margin-top: 2px;
  align-self: flex-start;
  background: #0d3452;
  color: #3fa9f5;
  font-size: 10px;
  font-weight: 700;
  padding: 2px 5px;
  border-radius: 6px;
  letter-spacing: 0.3px;
  white-space: nowrap;
  position: relative;
  cursor: help;
}
.ee-piloto-lap-badge {
  margin-top: 2px;
  align-self: flex-start;
  background: #2a1f0a;
  color: #f5c33f;
  font-size: 10px;
  font-weight: 700;
  padding: 2px 6px;
  border-radius: 6px;
  letter-spacing: 0.3px;
  white-space: nowrap;
  cursor: help;
}
.ee-piloto-ir-badge.ee-ir-inactiva {
  background: #2a2a2a;
  color: #999;
  border: 1px solid #444;
}
.ee-piloto-ir-badge.ee-ir-historico {
  background: #0d4525;
  color: #5ecf98;
  border: 1px solid #145a35;
}
.ee-piloto-ir-badge.ee-ir-nueva {
  background: #3d1b5a;
  color: #c084fc;
  border: 1px solid #5b21b6;
}
.ee-piloto-pending {
  margin-top: 2px;
  align-self: flex-start;
  background: #4b3d05;
  color: #f5c33f;
  font-size: 10px;
  font-weight: 600;
  padding: 2px 6px;
  border-radius: 6px;
  letter-spacing: 0.3px;
}
td.ee-promedio {
  font-weight: 700;
  font-size: 14px;
  text-align: center;
  color: #3fa9f5;
}
td.ee-redes {
  padding: 8px 12px;
  text-align: center;
  vertical-align: middle;
}
a.ee-red-icon {
  display: inline-block;
  margin: 0 4px;
  transition:
    transform 0.2s ease,
    opacity 0.2s ease;
  opacity: 0.9;
}
a.ee-red-icon:hover {
  transform: scale(1.15);
  opacity: 1;
}
a.ee-red-icon img {
  width: 24px;
  height: 24px;
  -o-object-fit: contain;
     object-fit: contain;
  vertical-align: middle;
  display: block;
}
}

@layer sn.core {
@media (max-width: 900px) {
  .ee-img-wrap {
    width: 130px;
    height: 74px;
  }
  img.ee-logo {
    width: 40px;
    height: 40px;
  }
}
}

@layer sn.core {
@media (max-width: 700px) {
  table.ee-tabla thead th:first-child {
    width: 32px;
    padding-left: 6px;
    padding-right: 6px;
  }
  td.ee-num {
    width: 32px;
    padding-left: 6px !important;
    padding-right: 6px !important;
  }
  .ee-num .ee-pos {
    font-size: 12px;
  }
  .ee-num .ee-btn-livery {
    display: none;
  }
  .ee-equipo-chip .ee-nombre {
    font-size: 15px;
  }
  img.ee-piloto-avatar {
    width: 40px;
    height: 40px;
  }
}
}

@layer sn.core {
@media (max-width: 540px) {
  table.ee-tabla {
    min-width: 600px;
  }
  table.ee-tabla thead th:first-child,
  td.ee-num {
    width: 28px;
  }
  .ee-img {
    width: 120px;
  }
  .ee-img-wrap {
    width: 110px;
    height: 64px;
  }
  img.ee-logo {
    width: 36px;
    height: 36px;
  }
  .ee-equipo-chip {
    min-width: 150px;
    max-width: 200px;
    padding: 6px 8px;
  }
  .ee-equipo-chip .ee-nombre {
    font-size: 14px;
  }
  .ee-piloto-nombre {
    max-width: 90px;
    font-size: 12px;
  }
  .ee-piloto-info img.ee-flag {
    transform: scale(0.95);
  }
  .ee-pilotos-wrap {
    gap: 6px;
  }
  .ee-status-msg {
    font-size: 10px;
    padding: 5px 6px;
  }
  .ee-notas-admin {
    max-width: 100%;
    font-size: 12px;
  }
}
}

@layer sn.core {
.ee-lightbox {
  position: fixed;
  inset: 0;
  display: none;
  z-index: 9999;
}
.ee-lightbox-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.7);
  backdrop-filter: blur(2px);
}
.ee-lightbox-content {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  max-width: 92vw;
  max-height: 90vh;
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.5);
}
.ee-lightbox-content img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
  background: #0b0c10;
}
.sn-tl-heading {
  margin: 1.2rem 0 0.8rem;
  color: #fff;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 1.35rem;
}
}

@layer sn.core {
.sn-sim-logo {
  position: absolute;
  top: 0.5rem;
  right: 0.5rem;
  width: 48px;
  height: 48px;
  -o-object-fit: contain;
     object-fit: contain;
  background: rgba(0, 0, 0, 0.4);
  backdrop-filter: blur(2px);
  border-radius: 10px;
  padding: 0.25rem;
  border: 1px solid rgba(255, 255, 255, 0.08);
}
.sn-card-body {
  padding: 0.9rem;
}
.sn-card-title {
  color: #fff;
  font-size: 1.05rem;
  margin: 0 0 0.35rem;
}
.sn-card-desc {
  color: #cfcfcf;
  font-size: 0.9rem;
  line-height: 1.35em;
  max-height: 4.1em;
  overflow: hidden;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  line-clamp: 3;
  -webkit-box-orient: vertical;
  margin-bottom: 0.6rem;
}
.sn-card-tags {
  display: flex;
  gap: 0.5rem;
  flex-wrap: wrap;
  margin-bottom: 0.6rem;
}
.sn-tag {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  background: #191919;
  color: #e9e9e9;
  border: 1px solid #2a2a2a;
  border-radius: 999px;
  padding: 0.25rem 0.55rem;
  font-size: 0.78rem;
}
.sn-tag-estado {
  background: linear-gradient(135deg, #202020, #171717);
  border-color: #2a2a2a;
}
.sn-tag-estado.estado-activo {
  background: linear-gradient(135deg, #0f6, #0a4);
}
.sn-tag-estado.estado-en-curso {
  background: linear-gradient(135deg, #ffb703, #fb8500);
}
.sn-tag-estado.estado-suspendido {
  background: linear-gradient(135deg, #333, #111);
}
.sn-tag-estado.estado-finalizado {
  background: linear-gradient(135deg, #444, #222);
}
.sn-card-cost {
  color: #fff;
  border-top: 1px dashed #2a2a2a;
  padding-top: 0.55rem;
  margin-top: 0.2rem;
  margin-bottom: 0.6rem;
  display: flex;
  align-items: center;
  gap: 0.45rem;
  font-weight: 600;
}
.sn-card-actions {
  display: flex;
  justify-content: flex-end;
}
.sn-btn {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  border: 1px solid #333;
  background: #1b1b1b;
  color: #fff;
  padding: 0.5rem 0.9rem;
  border-radius: 10px;
  text-decoration: none;
  transition:
    transform 0.15s ease,
    background 0.2s ease,
    border-color 0.2s ease;
}
.sn-btn:hover {
  background: #232323;
  border-color: #3a3a3a;
}
.sn-btn:active {
  transform: scale(0.98);
}
:root {
  --sn-bg: #0e0f12;
  --sn-surface: #121318;
  --sn-surface-2: #161821;
  --sn-border: #252738;
  --sn-soft: #1a1c26;
  --sn-text: #e8eaf1;
  --sn-muted: #a7acc0;
  --sn-accent: #c90d05;
}
.sn-gestion-equipos {
  background: var(--sn-bg);
  border: 1px solid var(--sn-border);
  border-radius: 16px;
  padding: 14px;
  color: var(--sn-text);
}
.sn-ge-loading {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  color: #ddd;
}
.sn-ge-error {
  background: #2a1313;
  color: #ffd0d0;
  border: 1px solid #4a1b1b;
  padding: 0.7rem;
  border-radius: 10px;
}
.sn-ge-div {
  background: var(--sn-surface);
  border: 1px solid var(--sn-border);
  border-radius: 14px;
  margin: 0.6rem 0;
}
.sn-ge-div-h {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  justify-content: space-between;
  padding: 0.6rem 0.8rem;
  border-bottom: 1px dashed var(--sn-border);
}
.sn-ge-div-title h4 {
  margin: 0;
  font-size: 16px;
}
.sn-ge-div-title small {
  opacity: 0.85;
  font-weight: 500;
}
.sn-ge-div-b {
  padding: 0.8rem;
}
.sn-pill {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  background: #1b1d25;
  border: 1px solid #2a2f43;
  color: #e9ecf4;
  border-radius: 999px;
  padding: 0.18rem 0.55rem;
  font-size: 0.78rem;
}
.sn-pill.ok {
  background: #122418;
  border-color: #1f3e2f;
  color: #bfead4;
}
.sn-pill.sec {
  background: #171a22;
  border-color: #2a3048;
  color: #d8dcff;
}
.sn-ge-instr {
  color: #d7daf0;
  margin-bottom: 0.5rem;
}
.sn-ge-actions {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  flex-wrap: wrap;
}
.sn-ge-note {
  color: #cfd3e6;
}
.sn-btn {
  border: 1px solid #2a2f43;
  background: #1b1d25;
  color: var(--sn-text);
  padding: 0.5rem 0.8rem;
  border-radius: 10px;
  cursor: pointer;
  font-size: 13px;
  transition: 0.18s ease;
}
.sn-btn:hover {
  filter: brightness(1.06);
  transform: translateY(-1px);
}
.sn-btn.pri {
  background: #0f382d;
  border-color: #145a46;
  color: #d5f9ee;
}
.sn-btn.pri:hover {
  background: #14624f;
}
.sn-btn.sec {
  background: #1a1c26;
  border-color: #2a3048;
}
.sn-btn.sn-main-act {
  background: var(--sn-accent);
  border-color: #9f0b04;
  color: #fff;
}
.sn-btn.sn-main-act:hover {
  background: #e01109;
  border-color: #b50e07;
}
.sn-btn.xs {
  padding: 0.35rem 0.6rem;
  font-size: 12px;
}
.sn-btn:disabled {
  opacity: 0.55;
  cursor: not-allowed;
}
.sn-msg {
  color: #cfd3e6;
}
.sn-msg.ok {
  color: #5ecf98;
}
.sn-msg.err {
  color: #ff7b7b;
}
.sn-team-card {
  background: var(--sn-surface);
  border: 1px solid var(--sn-border);
  border-radius: 18px;
  padding: 22px;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.25);
}
.sn-hz-logo {
  width: 160px;
  height: 160px;
  background: var(--sn-soft);
  border: 1px solid var(--sn-border);
  border-radius: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}
.sn-hz-logo img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.sn-hz-main {
  display: flex;
  flex-direction: column;
  gap: 10px;
  min-width: 0;
}
.sn-hz-actions {
  display: flex;
  flex-direction: column;
  gap: 10px;
  align-items: stretch;
}
.sn-team-title {
  display: inline-block;
  padding: 10px 14px;
  border-radius: 12px;
  font-weight: 700;
  font-size: 22px;
  line-height: 1.15;
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.06);
}
.sn-team-averages {
  font-size: 12px;
  color: var(--sn-muted);
}
.sn-hz-auto-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  margin-top: 2px;
}
.sn-hz-auto-meta > * {
  background: var(--sn-soft);
  border: 1px solid var(--sn-border);
  border-radius: 10px;
  padding: 6px 10px;
  font-size: 12px;
}
.sn-hz-brand img {
  width: 42px;
  height: 42px;
  -o-object-fit: contain;
     object-fit: contain;
}
.sn-hz-livery {
  margin-top: 6px;
  width: 100%;
  max-width: 360px;
  border: 1px solid var(--sn-border);
  border-radius: 14px;
  overflow: hidden;
  background: var(--sn-soft);
}
.sn-hz-livery img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.sn-team-head {
  display: grid;
  grid-template-columns: 120px 1fr;
  gap: 20px;
  align-items: start;
  margin-bottom: 14px;
}
.sn-team-logo {
  width: 120px;
  height: 120px;
  background: var(--sn-soft);
  border: 1px solid var(--sn-border);
  border-radius: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}
.sn-team-logo img {
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}
.sn-team-meta .sn-team-title,
.sn-team-meta .sn-team-averages {
  grid-column: 1/2;
}
.sn-team-actions {
  grid-column: 2/3;
  display: flex;
  flex-direction: column;
  gap: 10px;
  align-items: stretch;
}
.sn-team-members {
  margin-top: 0.6rem;
  display: grid;
  gap: 0.35rem;
}
.sn-team-members-table {
  margin-top: 0.4rem;
}
.sn-table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0 6px;
  font-size: 13px;
}
.sn-table thead th {
  position: sticky;
  top: 0;
  background: linear-gradient(#151726, #121318);
  border: 1px solid var(--sn-border);
  border-bottom-color: #2b2f45;
  padding: 8px 10px;
  font-weight: 700;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.6px;
  color: #c8ccdd;
}
.sn-table thead th:first-child {
  border-top-left-radius: 10px;
  border-bottom-left-radius: 10px;
}
.sn-table thead th:last-child {
  border-top-right-radius: 10px;
  border-bottom-right-radius: 10px;
}
.sn-table td {
  background: var(--sn-surface-2);
  padding: 8px 10px;
  border-top: 1px solid var(--sn-border);
  border-bottom: 1px solid var(--sn-border);
}
.sn-table tr td:first-child {
  border-left: 1px solid var(--sn-border);
  border-top-left-radius: 10px;
  border-bottom-left-radius: 10px;
}
.sn-table tr td:last-child {
  border-right: 1px solid var(--sn-border);
  border-top-right-radius: 10px;
  border-bottom-right-radius: 10px;
}
.sn-avatar {
  width: 42px;
  height: 42px;
  border-radius: 50%;
  overflow: hidden;
  background: #222;
  display: flex;
  align-items: center;
  justify-content: center;
}
.sn-avatar img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  display: block;
}
.sn-auto-cell {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}
.sn-auto-brand-sm {
  width: 34px;
  height: 34px;
  -o-object-fit: contain;
     object-fit: contain;
  background: #181a24;
  border: 1px solid var(--sn-border);
  border-radius: 8px;
  padding: 2px;
}
.sn-auto-label {
  font-size: 12px;
  font-weight: 500;
}
.sn-auto-edit {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-top: 2px;
}
.sn-admin-name {
  color: #ffd479;
}
.sn-lic-badge {
  display: inline-block;
  padding: 2px 6px;
  border-radius: 6px;
  font-size: 11px;
  line-height: 1;
  font-weight: 700;
  color: #111;
}
.sn-modal-mask {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.72);
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding: 2rem 1rem;
  z-index: 9999;
  overflow: auto;
}
.sn-modal {
  width: min(1000px, 96vw);
  background: var(--sn-surface);
  border: 1px solid var(--sn-border);
  border-radius: 14px;
  box-shadow: 0 18px 55px -12px rgba(0, 0, 0, 0.85);
  overflow: hidden;
}
.sn-modal-h {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.9rem 1.1rem;
  border-bottom: 1px solid var(--sn-border);
  font-weight: 700;
}
.sn-modal-h .sn-modal-x {
  background: none;
  color: #c9cfe4;
  border: 0;
  border-radius: 8px;
  padding: 0.2rem 0.5rem;
  cursor: pointer;
}
.sn-modal-b {
  padding: 1rem;
  display: flex;
  flex-wrap: wrap;
  gap: 0;
}
.sn-preview {
  background: var(--sn-soft);
  border: 1px dashed var(--sn-border);
  border-radius: 10px;
  padding: 0.8rem;
  margin-bottom: 0.8rem;
}
.sn-preview .sn-team-title {
  font-size: 1.25rem;
}
.sn-modal .sn-grid label small {
  opacity: 0.8;
}
.sn-modal input[type="text"],
.sn-modal input[type="number"],
.sn-modal select {
  background: #131624;
  border: 1px solid var(--sn-border);
  color: #eef1fb;
  border-radius: 10px;
  padding: 0.6rem 0.8rem;
}
.sn-modal .sn-actions {
  display: flex;
  gap: 0.6rem;
  margin-top: 0.8rem;
}
.sn-color-pair .sn-hex {
  text-transform: uppercase;
}
}

@layer sn.core {
@media (max-width: 760px) {
  .sn-team-actions {
    grid-column: 1/2;
    flex-direction: row;
  }
}
}

@layer sn.core {
:root {
  --bg: #0f1115;
  --surface: #161a22;
  --panel: #1b2332;
  --muted-surface: #131a24;
  --border: #2a3443;
  --text: #e6e9ef;
  --text-muted: #a6b0c0;
  --accent: #ff6b35;
  --accent-2: #2dd4bf;
  --success: #28a745;
  --danger: #dc3545;
  --warning: #ffc107;
  --info: #17a2b8;
  --shadow: 0 6px 18px rgba(0, 0, 0, 0.35);
}
#sn-ac-admin-container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 20px;
  font-family: "Segoe UI", Tahoma, Geneva, Verdana, sans-serif;
  color: var(--text);
  background: var(--bg);
}
.sn-loading {
  text-align: center;
  padding: 40px;
  color: var(--text-muted);
}
.sn-loading i {
  font-size: 24px;
  margin-right: 10px;
}
.sn-ac-admin-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 30px;
  padding: 20px;
  background: linear-gradient(135deg, #0f1a2d, #182846);
  border-radius: 8px;
  color: var(--text);
  box-shadow: var(--shadow);
  border: 1px solid var(--border);
}
.sn-tz-note {
  font-size: 0.75rem;
  color: var(--text-muted);
  margin: 6px 0 12px;
}
.sn-ac-admin-header h2 {
  margin: 0;
  font-size: 24px;
  font-weight: 600;
}
.sn-ac-admin-header i {
  margin-right: 10px;
}
.sn-ac-admin-actions {
  display: flex;
  gap: 10px;
}
:where(.sn-btn),
:where(.sn-btn-primary),
:where(.sn-btn-success),
:where(.sn-btn-danger),
:where(.sn-btn-secondary),
:where(.sn-btn-danger-sm) {
  outline: none;
}
.sn-ac-tabs-nav {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin: 0 0 20px;
  padding: 0;
  list-style: none;
}
.sn-ac-server-nav-tab {
  padding: 8px 16px;
  background: var(--muted-surface);
  border: 1px solid var(--border);
  border-radius: var(--sn-radius-pill, 999px);
  cursor: pointer;
  font: 600 12px/1 var(--sn-font-sans, inherit);
  transition: 0.18s;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.sn-ac-server-nav-tab:hover {
  background: #1c2534;
}
.sn-ac-server-nav-tab.active {
  background: var(--accent);
  color: #0b0d12;
  border-color: var(--accent);
  box-shadow: 0 4px 18px -4px rgba(255, 107, 53, 0.35);
}
.sn-ac-server-status {
  margin-right: 8px;
}
.sn-ac-server-status.running {
  color: var(--success);
}
.sn-ac-server-status.stopped {
  color: var(--danger);
}
.sn-ac-server-status.partial {
  color: var(--warning);
}
.sn-ac-text-success {
  color: var(--success) !important;
}
.sn-ac-text-danger {
  color: var(--danger) !important;
}
.sn-ac-text-warning {
  color: var(--warning) !important;
}
.sn-ac-text-info {
  color: var(--info) !important;
}
.sn-ac-server-tab {
  display: none;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 20px;
  margin-bottom: 20px;
  box-shadow: var(--shadow);
}
.sn-ac-server-tab.active {
  display: block;
}
.sn-ac-server-tab-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 20px;
  padding-bottom: 15px;
  border-bottom: 1px solid var(--border);
}
.sn-ac-server-tab-header h3 {
  margin: 0;
  font-size: 20px;
  display: flex;
  align-items: center;
  color: var(--text);
}
.sn-ac-server-controls {
  display: flex;
  gap: 10px;
}
.sn-ac-server-power {
  padding: 8px 16px;
  border: 1px solid transparent;
  border-radius: 5px;
  cursor: pointer;
  font-weight: 600;
  transition:
    filter 0.2s ease,
    transform 0.2s ease;
}
.sn-ac-server-power.start {
  background: var(--success);
  color: #0b0d12;
}
.sn-ac-server-power.stop {
  background: var(--danger);
  color: #0b0d12;
}
.sn-ac-server-power:hover {
  filter: brightness(0.95);
  transform: translateY(-1px);
}
.sn-ac-server-power.sn-busy {
  opacity: 0.6;
  cursor: progress;
  position: relative;
}
.sn-ac-server-power.sn-busy::after {
  content: "...";
  margin-left: 6px;
  font-weight: 700;
}
.sn-ac-server-subtabs {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin: 0 0 16px;
  padding: 0;
  list-style: none;
}
.sn-ac-subtab {
  padding: 6px 12px;
  background: var(--muted-surface);
  border: 1px solid var(--border);
  border-radius: var(--sn-radius-sm, 4px);
  cursor: pointer;
  font: 600 11px/1 var(--sn-font-sans, inherit);
  transition: 0.18s;
  display: inline-flex;
  align-items: center;
}
.sn-ac-subtab:hover {
  background: #1c2534;
}
.sn-ac-subtab.active {
  background: var(--accent);
  color: #0b0d12;
  border-color: var(--accent);
}
.sn-ac-subtab i {
  margin-right: 5px;
}
.sn-ac-config-section {
  background: var(--panel);
  padding: 20px;
  border-radius: 8px;
  border: 1px solid var(--border);
}
.sn-ac-config-group {
  margin-bottom: 25px;
  background: var(--surface);
  padding: 20px;
  border-radius: 6px;
  border: 1px solid var(--border);
  box-shadow: var(--shadow);
}
.sn-ac-config-group h5 {
  margin: 0 0 15px 0;
  font-size: 16px;
  color: var(--text);
  border-bottom: 2px solid var(--accent);
  padding-bottom: 5px;
}
.sn-ac-form-row {
  display: flex;
  gap: 15px;
  margin-bottom: 15px;
  flex-wrap: wrap;
}
.sn-ac-form-row-wrap {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}
.sn-ac-form-col {
  flex: 1;
  min-width: 200px;
}
.sn-ac-form-col label {
  display: block;
  margin-bottom: 5px;
  font-weight: 500;
  color: var(--text-muted);
  font-size: 13px;
}
.sn-ac-form-col input,
.sn-ac-form-col select {
  width: 100%;
  padding: 10px 12px;
  border: 1px solid var(--border);
  border-radius: 4px;
  font-size: 14px;
  transition:
    border-color 0.18s,
    box-shadow 0.18s,
    background 0.18s;
  box-sizing: border-box;
  background: #111723;
  color: var(--text);
}
.sn-ac-form-col input::-moz-placeholder {
  color: #7f8a9a;
}
.sn-ac-form-col input::placeholder {
  color: #7f8a9a;
}
.sn-ac-form-col input:focus,
.sn-ac-form-col select:focus {
  border-color: var(--accent);
  outline: none;
  box-shadow: 0 0 0 2px rgba(255, 107, 53, 0.28);
  background: #0f1722;
}
.sn-ac-config-form input[type="number"],
.sn-ac-config-form input[type="text"] {
  text-align: left;
}
.sn-ac-form-actions {
  margin-top: 20px;
  padding-top: 20px;
  border-top: 1px solid var(--border);
  display: flex;
  gap: 10px;
  justify-content: flex-end;
}
.sn-ac-cars-container {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
  gap: 10px;
  max-height: 300px;
  overflow-y: auto;
  padding: 10px;
  border: 1px solid var(--border);
  border-radius: 4px;
  background: var(--muted-surface);
}
.sn-ac-car-checkbox {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 8px;
  border-radius: 4px;
  transition: background 0.15s ease;
  color: var(--text);
}
.sn-ac-car-checkbox:hover {
  background: #202a3b;
}
.sn-ac-car-checkbox input[type="checkbox"] {
  width: auto;
}
.sn-ac-entrylist-section {
  background: var(--panel);
  padding: 20px;
  border-radius: 8px;
  border: 1px solid var(--border);
}
.sn-ac-entrylist-actions {
  margin-bottom: 20px;
  display: flex;
  gap: 10px;
}
.sn-ac-entrylist-container {
  display: flex;
  flex-direction: column;
  gap: 15px;
  max-height: 600px;
  overflow-y: auto;
}
.sn-ac-driver-entry {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 15px;
  position: relative;
  box-shadow: var(--shadow);
}
.sn-ac-driver-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 15px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--border);
}
.sn-ac-driver-header h5 {
  margin: 0;
  color: var(--text);
}
.sn-ac-realpenalty-section {
  background: var(--panel);
  padding: 20px;
  border-radius: 8px;
  border: 1px solid var(--border);
}
.sn-ac-realpenalty-tabs {
  display: flex;
  gap: 5px;
  margin-bottom: 20px;
  border-bottom: 1px solid var(--border);
  padding-bottom: 10px;
}
.sn-ac-rp-tab {
  padding: 10px 15px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 4px 4px 0 0;
  cursor: pointer;
  transition:
    background 0.2s ease,
    color 0.2s ease,
    border-color 0.2s ease;
  color: var(--text);
}
.sn-ac-rp-tab:hover {
  background: #1d2636;
}
.sn-ac-rp-tab.active {
  background: var(--accent);
  color: #0b0d12;
  border-color: var(--accent);
}
.sn-ac-schedule-section {
  background: var(--panel);
  padding: 20px;
  border-radius: 8px;
  border: 1px solid var(--border);
}
.sn-ac-schedule-actions {
  margin-bottom: 20px;
}
.sn-ac-schedule-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.sn-ac-schedule-item {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 15px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  box-shadow: var(--shadow);
}
.sn-ac-schedule-info {
  flex: 1;
  color: var(--text);
}
.sn-ac-schedule-actions-item {
  display: flex;
  gap: 5px;
}
.sn-ac-livetiming-section {
  background: var(--panel);
  padding: 20px;
  border-radius: 8px;
  border: 1px solid var(--border);
}
.sn-ac-livetiming-placeholder {
  text-align: center;
  padding: 40px;
  color: var(--text-muted);
}
.sn-ac-livetiming-placeholder ul {
  text-align: left;
  display: inline-block;
  margin-top: 20px;
}
:where(.sn-modal-overlay),
:where(.sn-modal),
:where(.sn-modal-header),
:where(.sn-modal-body),
:where(.sn-modal-footer),
:where(.sn-modal-close) {
  outline: none;
}
.sn-ac-messages {
  position: fixed;
  top: 20px;
  right: 20px;
  z-index: 10000;
  max-width: 400px;
}
.sn-ac-message {
  padding: 15px;
  margin-bottom: 10px;
  border-radius: 6px;
  color: #0b0d12;
  font-weight: 600;
  box-shadow: var(--shadow);
  animation: slideIn 0.3s ease;
  border: 1px solid rgba(255, 255, 255, 0.06);
}
.sn-ac-message.success {
  background: var(--success);
}
.sn-ac-message.error {
  background: var(--danger);
}
.sn-ac-message.info {
  background: var(--info);
}
.sn-ac-message.warning {
  background: var(--warning);
  color: #1a1a1a;
}
@keyframes slideIn {
  from {
    transform: translateX(100%);
    opacity: 0;
  }
  to {
    transform: translateX(0);
    opacity: 1;
  }
}
#sn-ac-servers-nav {
  display: flex;
  gap: 6px;
  flex-wrap: nowrap;
  overflow-x: auto;
  padding-bottom: 8px;
  margin-bottom: 18px;
  border-bottom: 1px solid var(--border);
}
#sn-ac-servers-nav::-webkit-scrollbar {
  height: 8px;
}
#sn-ac-servers-nav::-webkit-scrollbar-thumb {
  background: #243043;
  border-radius: 4px;
}
.sn-ac-form-row-wrap.three-cols > .sn-ac-form-col {
  flex: 1 1 calc(33.33% - 12px);
  max-width: calc(33.33% - 12px);
}
.sn-help {
  margin-top: 4px;
  margin-bottom: 10px;
}
.sn-ac-rp-form.sn-ac-rp-grid-3
  .sn-ac-form-row-wrap.three-cols
  > .sn-ac-form-col {
  flex: 1 1 calc(33.33% - 12px);
}
.sn-ac-config-group h5 {
  margin-top: 4px;
}
}

@layer sn.core {
@media (max-width: 768px) {
  .sn-ac-admin-header {
    flex-direction: column;
    gap: 15px;
    text-align: center;
  }
  .sn-ac-form-row,
  .sn-ac-tabs-nav,
  .sn-ac-server-subtabs {
    flex-direction: column;
  }
  .sn-modal {
    max-width: 95%;
    margin: 10px;
  }
  .sn-ac-cars-container {
    grid-template-columns: 1fr;
  }
}
}

@layer sn.core {
.sn-ac-loading-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(8, 10, 14, 0.7);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 100;
}
.sn-ac-loading-spinner {
  border: 3px solid #2b3443;
  border-top: 3px solid var(--accent);
  border-radius: 50%;
  width: 30px;
  height: 30px;
  animation: spin 1s linear infinite;
}
@keyframes spin {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}
.sn-ac-form-col input.error,
.sn-ac-form-col select.error {
  border-color: var(--danger);
  box-shadow: 0 0 0 2px rgba(220, 53, 69, 0.25);
  background: #1b1214;
}
.sn-ac-form-col input.success,
.sn-ac-form-col select.success {
  border-color: var(--success);
  box-shadow: 0 0 0 2px rgba(40, 167, 69, 0.25);
}
.sn-ac-entrylist-container::-webkit-scrollbar,
.sn-ac-cars-container::-webkit-scrollbar,
.sn-modal-body::-webkit-scrollbar {
  width: 10px;
  height: 10px;
}
.sn-ac-entrylist-container::-webkit-scrollbar-thumb,
.sn-ac-cars-container::-webkit-scrollbar-thumb,
.sn-modal-body::-webkit-scrollbar-thumb {
  background: #243043;
  border-radius: 6px;
  border: 2px solid #0f1115;
}
.sn-ac-entrylist-container::-webkit-scrollbar-track,
.sn-ac-cars-container::-webkit-scrollbar-track,
.sn-modal-body::-webkit-scrollbar-track {
  background: #0f1115;
}
#sn-ac-admin-container a {
  color: var(--accent);
  text-decoration: none;
}
#sn-ac-admin-container a:hover {
  text-decoration: underline;
}
.sn-ac-selected-cars {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin: 0 0 10px 0;
}
.sn-ac-selected-car {
  background: var(--accent);
  color: #0b0d12;
  padding: 4px 8px;
  border-radius: 16px;
  font-size: 12px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.sn-ac-selected-car button {
  background: transparent;
  border: none;
  color: #0b0d12;
  cursor: pointer;
  font-weight: 700;
  line-height: 1;
  padding: 0 2px;
}
.sn-ac-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 2px 6px;
  border-radius: 12px;
  font: 600 11px/1 var(--sn-font-sans, inherit);
  background: var(--muted-surface);
  border: 1px solid var(--border);
  color: var(--text);
  letter-spacing: 0.3px;
}
.sn-ac-badge.success {
  background: var(--success);
  color: #111;
  border-color: var(--success);
}
.sn-ac-badge.danger {
  background: var(--danger);
  color: #111;
  border-color: var(--danger);
}
.sn-ac-badge.warning {
  background: var(--warning);
  color: #1a1a1a;
  border-color: var(--warning);
}
.sn-ac-badge.info {
  background: var(--info);
  color: #0b0d12;
  border-color: var(--info);
}
.sn-ac-available-cars {
  max-height: 220px;
  overflow: auto;
  border: 1px solid var(--border);
  padding: 8px;
  border-radius: 6px;
  background: var(--muted-surface);
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(170px, 1fr));
  gap: 6px;
}
.sn-ac-available-cars .car-item {
  background: #202a3b;
  padding: 4px 6px;
  border-radius: 4px;
  font-size: 12px;
  display: flex;
  align-items: center;
  gap: 6px;
}
.sn-ac-available-cars .car-item button {
  background: var(--accent);
  border: none;
  color: #0b0d12;
  width: 22px;
  height: 22px;
  border-radius: 4px;
  cursor: pointer;
  font-weight: 700;
  line-height: 1;
}
.sn-ac-available-cars .car-item button:disabled {
  opacity: 0.4;
  cursor: default;
}
.sn-ac-available-cars::-webkit-scrollbar {
  width: 8px;
}
.sn-ac-available-cars::-webkit-scrollbar-thumb {
  background: #243043;
  border-radius: 4px;
  border: 2px solid #0f1115;
}
.sn-i,
.sn-tip {
  display: none !important;
}
.sn-ac-sendmsg-toggle {
  margin-top: 8px;
}
.sn-ac-sendmsg-box {
  margin-top: 10px;
  background: var(--panel);
  border: 1px solid var(--border);
  padding: 12px;
  border-radius: 6px;
  display: none;
}
.sn-ac-sendmsg-box textarea {
  width: 100%;
  min-height: 70px;
  resize: vertical;
  background: #111723;
  border: 1px solid var(--border);
  color: var(--text);
  border-radius: 4px;
  padding: 8px;
  font-size: 13px;
  box-sizing: border-box;
}
.sn-ac-sendmsg-box textarea:focus {
  border-color: var(--accent);
  outline: none;
  box-shadow: 0 0 0 2px rgba(255, 107, 53, 0.28);
  background: #0f1722;
}
.sn-ac-sendmsg-actions {
  margin-top: 8px;
  display: flex;
  gap: 8px;
  justify-content: flex-end;
}
:root {
  --rf2-bg: #0f1115;
  --rf2-surface: #161a22;
  --rf2-panel: #1b2332;
  --rf2-muted: #131a24;
  --rf2-border: #2a3443;
  --rf2-text: #e6e9ef;
  --rf2-text-muted: #a6b0c0;
  --rf2-accent: #ff9340;
  --rf2-success: #28a745;
  --rf2-danger: #dc3545;
  --rf2-warning: #ffc107;
  --rf2-shadow: 0 6px 18px rgba(0, 0, 0, 0.35);
}
#sn-rf2-admin-container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 20px;
  font-family: "Segoe UI", Tahoma, sans-serif;
  color: var(--rf2-text);
  background: var(--rf2-bg);
}
#sn-rf2-loading {
  text-align: center;
  padding: 40px;
  color: var(--rf2-text-muted);
  font: 500 14px/1.4 var(--sn-font-sans, inherit);
}
#sn-rf2-servers-nav {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 0 0 18px;
  padding: 0;
  list-style: none;
}
.sn-rf2-server-nav-tab {
  padding: 8px 16px;
  background: var(--rf2-muted);
  border: 1px solid var(--rf2-border);
  border-radius: var(--sn-radius-pill, 999px);
  cursor: pointer;
  color: var(--rf2-text);
  font: 600 12px/1 var(--sn-font-sans, inherit);
  display: inline-flex;
  align-items: center;
  gap: 6px;
  transition: 0.18s;
}
.sn-rf2-server-nav-tab:hover {
  background: #1c2534;
}
.sn-rf2-server-nav-tab.active {
  background: var(--rf2-accent);
  color: #111;
  border-color: var(--rf2-accent);
  box-shadow: 0 4px 18px -4px rgba(255, 147, 64, 0.35);
}
.sn-rf2-server-status.running {
  color: var(--rf2-success);
}
.sn-rf2-server-status.stopped {
  color: var(--rf2-danger);
}
#sn-rf2-messages {
  margin-bottom: 15px;
}
.sn-rf2-message {
  background: var(--rf2-panel);
  border: 1px solid var(--rf2-border);
  padding: 8px 12px;
  border-radius: 6px;
  font: 500 13px/1.4 var(--sn-font-sans, inherit);
  margin: 0 0 6px;
  box-shadow: var(--rf2-shadow);
  display: flex;
  align-items: flex-start;
  gap: 8px;
}
.sn-rf2-message.error {
  border-color: var(--rf2-danger);
  background: color-mix(in srgb, var(--rf2-danger) 12%, var(--rf2-panel));
  color: var(--rf2-danger);
}
.sn-rf2-message.info {
  border-color: var(--rf2-accent);
  background: color-mix(in srgb, var(--rf2-accent) 18%, var(--rf2-panel));
}
.sn-rf2-server-tab {
  display: none;
  background: var(--rf2-surface);
  border: 1px solid var(--rf2-border);
  border-radius: 8px;
  padding: 20px;
  margin-bottom: 20px;
  box-shadow: var(--rf2-shadow);
}
.sn-rf2-server-tab.active {
  display: block;
}
.sn-rf2-server-tab-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 20px;
  padding-bottom: 15px;
  border-bottom: 1px solid var(--rf2-border);
}
.sn-rf2-server-tab-header h3 {
  margin: 0;
  font-size: 20px;
  display: flex;
  gap: 8px;
  align-items: center;
}
:where(.sn-btn),
:where(.sn-btn-primary),
:where(.sn-btn-secondary),
:where(.sn-rf2-server-power.start),
:where(.sn-rf2-server-power.stop),
:where(.sn-rf2-server-power.sn-busy) {
  outline: none;
}
.sn-rf2-config-section {
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.sn-rf2-config-group {
  background: var(--rf2-panel);
  padding: 18px 18px 14px;
  border: 1px solid var(--rf2-border);
  border-radius: 6px;
  box-shadow: var(--rf2-shadow);
}
.sn-rf2-config-group h5 {
  margin: 0 0 12px 0;
  font-size: 15px;
  border-bottom: 2px solid var(--rf2-accent);
  padding-bottom: 4px;
}
.sn-rf2-form-inline {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: flex-end;
}
.sn-rf2-form-inline input,
.sn-rf2-form-inline select {
  background: #111723;
  border: 1px solid var(--rf2-border);
  color: var(--rf2-text);
  padding: 8px 10px;
  border-radius: 4px;
  font-size: 13px;
  min-width: 160px;
  transition: 0.18s;
}
.sn-rf2-form-inline input:focus,
.sn-rf2-form-inline select:focus {
  border-color: var(--rf2-accent);
  outline: none;
  box-shadow: 0 0 0 2px rgba(255, 147, 64, 0.28);
  background: #0f1722;
}
.sn-rf2-form-inline label {
  display: flex;
  flex-direction: column;
  font-size: 12px;
  color: var(--rf2-text-muted);
  gap: 4px;
}
.sn-rf2-grid label {
  flex: 1 1 180px;
}
.sn-rf2-form-actions {
  margin-left: auto;
}
.sn-rf2-cars-wrapper {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.sn-rf2-selected-cars {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  min-height: 34px;
}
.sn-rf2-car-tag {
  background: var(--rf2-accent);
  color: #111;
  padding: 4px 8px;
  border-radius: var(--sn-radius-sm, 4px);
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font: 600 12px/1 var(--sn-font-sans, inherit);
}
.sn-rf2-car-tag button {
  background: transparent;
  border: 0;
  cursor: pointer;
  font-size: 14px;
  line-height: 1;
  color: #111;
}
.sn-rf2-available-cars {
  max-height: 240px;
  overflow-y: auto;
  border: 1px solid var(--rf2-border);
  background: var(--rf2-muted);
  padding: 8px;
  border-radius: 4px;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 6px;
}
.sn-rf2-car-item {
  background: var(--rf2-surface);
  border: 1px solid var(--rf2-border);
  padding: 6px 8px;
  border-radius: 4px;
  font-size: 12px;
  display: flex;
  align-items: center;
  gap: 6px;
}
.sn-rf2-car-item.no-name {
  opacity: 0.7;
}
.sn-rf2-car-item button {
  background: var(--rf2-success);
  color: #111;
  border: 0;
  padding: 0 6px;
  cursor: pointer;
  border-radius: 3px;
  font-weight: 600;
  font-size: 11px;
  box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.25);
}
.sn-rf2-car-item button:disabled {
  background: #444;
  cursor: not-allowed;
}
.sn-rf2-car-item .car-name {
  flex: 1;
}
.sn-rf2-text-success {
  color: var(--rf2-success) !important;
}
.sn-rf2-text-danger {
  color: var(--rf2-danger) !important;
}
.sn-rf2-text-warning {
  color: var(--rf2-warning) !important;
}
.sn-rf2-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 2px 6px;
  border-radius: 12px;
  font: 600 11px/1 var(--sn-font-sans, inherit);
  letter-spacing: 0.3px;
  background: var(--rf2-muted);
  border: 1px solid var(--rf2-border);
  color: var(--rf2-text);
}
.sn-rf2-badge.success {
  background: var(--rf2-success);
  color: #111;
  border-color: var(--rf2-success);
}
.sn-rf2-badge.danger {
  background: var(--rf2-danger);
  color: #111;
  border-color: var(--rf2-danger);
}
.sn-rf2-badge.warning {
  background: var(--rf2-warning);
  color: #1a1a1a;
  border-color: var(--rf2-warning);
}
.sn-rf2-available-cars::-webkit-scrollbar {
  width: 8px;
}
.sn-rf2-available-cars::-webkit-scrollbar-thumb {
  background: #243043;
  border-radius: 4px;
  border: 2px solid #0f1115;
}
.sn-rf2-msg {
  display: none;
}
}

@layer sn.core {
@media (max-width: 700px) {
  .sn-rf2-form-inline input,
  .sn-rf2-form-inline select {
    min-width: 130px;
  }
  .sn-rf2-server-tab-header {
    flex-direction: column;
    align-items: flex-start;
    gap: 10px;
  }
}
}

@layer sn.core {
.sn-simulador-item {
  display: flex;
  align-items: center;
  padding: 0.75rem 1rem;
  background: var(--sn-color-surface-alt, #333);
  border: 1px solid var(--sn-color-border, #444);
  border-radius: var(--sn-radius, 8px);
  color: var(--sn-color-text, #fff);
  gap: 12px;
  transition:
    background 0.18s,
    border-color 0.18s;
}
.sn-simulador-item:hover {
  background: var(--sn-color-surface, #2a2f35);
  border-color: var(--sn-color-border-light, #555);
}
.sn-simulador-logo-container {
  width: 40px;
  height: 40px;
  background: var(--sn-color-surface, #444);
  border: 1px solid var(--sn-color-border, #444);
  border-radius: var(--sn-radius, 8px);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}
.sn-simulador-nombre {
  flex: 1;
  font-size: var(--sn-font-size-md, 1rem);
  font-weight: 600;
  color: var(--sn-color-text, #fff);
}
.sn-simuladores-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: var(--sn-space-3, 1rem);
  margin: var(--sn-space-3, 1rem) 0;
}
.sn-toggle {
  position: relative;
  display: inline-block;
  width: 50px;
  height: 24px;
}
.sn-toggle-input {
  opacity: 0;
  width: 0;
  height: 0;
}
.sn-toggle-slider {
  position: absolute;
  inset: 0;
  background: var(--sn-color-border-light, #ccc);
  border-radius: 34px;
  cursor: pointer;
  transition: background 0.3s;
  box-shadow: inset 0 0 0 1px var(--sn-color-border, #444);
}
.sn-toggle-slider::before {
  content: "";
  position: absolute;
  height: 18px;
  width: 18px;
  left: 3px;
  bottom: 3px;
  background: var(--sn-color-surface, #fff);
  border-radius: 50%;
  transition:
    transform 0.3s,
    background 0.3s;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.4);
}
.sn-toggle-input:checked + .sn-toggle-slider {
  background: var(--sn-success, #28a745);
  box-shadow: inset 0 0 0 1px var(--sn-success, #28a745);
}
.sn-toggle-input:checked + .sn-toggle-slider::before {
  transform: translateX(26px);
  background: #fff;
}
.sn-toggle-input:focus + .sn-toggle-slider {
  box-shadow: 0 0 0 3px rgba(40, 167, 69, 0.35);
}
.sn-loading {
  grid-column: 1/-1;
  text-align: center;
  padding: 2rem;
  color: var(--sn-color-text, #fff);
  opacity: 0.85;
}
.sn-error {
  grid-column: 1/-1;
  text-align: center;
  padding: 2rem;
  color: var(--sn-danger, #dc3545);
  background: rgba(220, 53, 69, 0.08);
  border: 1px solid var(--sn-danger, #dc3545);
  border-radius: var(--sn-radius, 8px);
}
.sn-ac-live-tools {
  display: flex;
  justify-content: flex-end;
  margin: 0 0 8px;
}
.sn-ac-live-open {
  display: inline-flex;
  flex-direction: column;
  gap: 2px;
  padding: 6px 12px;
  border-radius: 6px;
  background: #1f1f1f;
  color: #fff;
  text-decoration: none;
  font-size: 0.85rem;
  border: 1px solid rgba(255, 255, 255, 0.1);
  transition:
    background 0.2s,
    border-color 0.2s;
}
.sn-ac-live-open:hover {
  background: #2a2a2a;
  border-color: rgba(255, 255, 255, 0.25);
}
.sn-ac-live-open-label {
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}
.sn-ac-live-open-hint {
  font-size: 0.7rem;
  opacity: 0.75;
}
#sn-conectar-ea-wrc-modal ol {
  margin-bottom: 1rem;
}
#sn-conectar-ea-wrc-modal ol li {
  margin-bottom: 0.4rem;
}
#sn-conectar-f1-modal ol {
  margin-bottom: 1.2rem;
}
#sn-conectar-f1-modal ol li {
  margin-bottom: 0.45rem;
}
#sn-conectar-f1-modal input[type="text"] {
  margin-bottom: 0.75rem;
}
#sn-modal-message {
  margin-top: 0.75rem;
  font-size: 0.9rem;
  color: var(--sn-color-text-soft, #cdd3de);
}
#sn-gt7-modal .nitro-instructions ol {
  padding: 0 0 0 1.2rem;
}
#sn-gt7-modal input[type="text"] {
  margin-bottom: 1rem;
}
#sn-gt7-error-message {
  color: var(--sn-danger, #e05959);
  font-size: 0.9rem;
  margin-bottom: 0.5rem;
}
.gt7-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.85rem;
  margin: 0 0 1rem;
}
#sn-gt7-modal .nitro-support {
  font-size: 0.88rem;
  color: var(--sn-color-text-soft, #c7ceda);
}
#sn-conectar-racenet-modal ol {
  margin-bottom: 1rem;
}
#sn-conectar-racenet-modal ol li {
  margin-bottom: 0.4rem;
}
#sn-conectar-racenet-modal input[type="text"] {
  margin-bottom: 1rem;
}
#sn-resultados-racenet {
  margin-top: 1rem;
  max-height: 300px;
  overflow-y: auto;
}
.nitrodb-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.85rem;
  margin: 0.5em 0 1rem;
}
.nitrodb-table th,
.nitrodb-table td {
  padding: 0.45rem 0.55rem;
}
#sn-iracing-modal .sn-modal-content > h2 {
  margin-bottom: 1rem;
}
#sn-iracing-modal .sn-modal-content ol {
  margin-bottom: 1rem;
  padding-left: 1.2rem;
}
#sn-iracing-modal .sn-modal-content input[type="text"] {
  margin-bottom: 1rem;
}
.sn-iracing-data {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.85rem;
  margin: 1rem 0;
}
.sn-iracing-data th,
.sn-iracing-data td {
  padding: 0.45rem 0.55rem;
}
.sn-menu-simuladores-host,
.sn-menu-simuladores-column {
  min-width: 0 !important;
}
.sn-menu-simuladores-host {
  display: block !important;
  width: 100% !important;
}
.whb-header-bottom .sn-menu-simuladores-column.whb-col-left,
.whb-header-bottom .sn-menu-simuladores-column.whb-col-mobile {
  flex: 1 1 100% !important;
  max-width: 100% !important;
}
.whb-header-bottom .sn-menu-simuladores-host.wd-inline {
  display: block !important;
  width: 100% !important;
}
}

@layer sn.core {
@media (max-width: 767px) {
  .whb-general-header
    .wd-header-text
    .sn-menu-superior-piloto-logged-out
    .sn-guest-card__sep,
  .whb-general-header
    .wd-header-text
    .sn-menu-superior-piloto-logged-out
    .sn-guest-card__text {
    display: none !important;
  }
  .whb-general-header
    .wd-header-text
    .sn-menu-superior-piloto-logged-out
    .sn-guest-card__message {
    text-overflow: clip;
  }
}
}

@layer sn.core {

/* Final isolated rules: shortcode menu simuladores.
   Keep inside the main CSS file and avoid reliance on theme styling. */
body nav.menu-simuladores-nav {
  --sn-sim-shell-py: 8px;
  --sn-sim-shell-px: 16px;
  --sn-sim-row-h: 30px;
  --sn-sim-logo-w: 150px;
  --sn-sim-logo-h: 22px;
  --sn-sim-gap: clamp(8px, 0.75vw, 12px);
}
}

@layer sn.core {

@media (min-width: 768px) {
  body nav.menu-simuladores-nav {
    width: min(1600px, 96vw) !important;
    margin: 0 auto 0 !important;
    padding: var(--sn-sim-shell-py) var(--sn-sim-shell-px) !important;
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
    position: relative !important;
  }

  body nav.menu-simuladores-nav .mobile-trigger {
    display: none !important;
  }

  body nav.menu-simuladores-nav .menu-simuladores-list {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    flex-wrap: nowrap !important;
    gap: var(--sn-sim-gap) !important;
    width: 100% !important;
    height: var(--sn-sim-row-h) !important;
    min-height: var(--sn-sim-row-h) !important;
    margin: 0 !important;
    padding: 0 !important;
    list-style: none !important;
  }

  body nav.menu-simuladores-nav .menu-simuladores-item {
    position: relative !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    flex: 0 0 auto !important;
    height: var(--sn-sim-row-h) !important;
    min-height: var(--sn-sim-row-h) !important;
    padding: 0 !important;
    list-style: none !important;
    background: transparent !important;
    box-shadow: none !important;
  }

  body nav.menu-simuladores-nav .menu-simuladores-item:not(:last-child)::after {
    content: "" !important;
    position: absolute !important;
    right: calc(var(--sn-sim-gap) * -0.5) !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    width: 1px !important;
    height: 24px !important;
    background: rgba(255, 255, 255, 0.12) !important;
  }

  body nav.menu-simuladores-nav .menu-simuladores-item > a {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    height: var(--sn-sim-row-h) !important;
    min-height: var(--sn-sim-row-h) !important;
    padding: 0 14px !important;
    border-radius: 999px !important;
    background: transparent !important;
    box-shadow: none !important;
    line-height: 1 !important;
    text-decoration: none !important;
  }

  body nav.menu-simuladores-nav .menu-simuladores-item picture {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    align-self: center !important;
    height: var(--sn-sim-row-h) !important;
    min-height: var(--sn-sim-row-h) !important;
    max-width: var(--sn-sim-logo-w) !important;
    overflow: hidden !important;
    line-height: 0 !important;
  }

  body nav.menu-simuladores-nav .menu-simuladores-item picture img {
    display: block !important;
    width: auto !important;
    height: auto !important;
    max-width: var(--sn-sim-logo-w) !important;
    max-height: var(--sn-sim-logo-h) !important;
    margin: 0 auto !important;
    -o-object-fit: contain !important;
       object-fit: contain !important;
    -o-object-position: center !important;
       object-position: center !important;
    opacity: 0.96 !important;
    transform: none !important;
    filter: none !important;
  }

  body nav.menu-simuladores-nav .menu-simuladores-item.active {
    background: transparent !important;
    box-shadow: none !important;
  }

  body nav.menu-simuladores-nav .menu-simuladores-item.active > a {
    background: linear-gradient(135deg, rgba(201, 13, 5, 0.98), rgba(145, 10, 4, 0.95)) !important;
    box-shadow:
      inset 0 0 0 1px rgba(255, 255, 255, 0.08),
      0 8px 18px rgba(201, 13, 5, 0.24) !important;
  }

  body nav.menu-simuladores-nav .menu-simuladores-item.active picture img,
  body nav.menu-simuladores-nav .menu-simuladores-item:hover picture img {
    opacity: 1 !important;
  }

  body nav.menu-simuladores-nav .menu-simuladores-item.active::before,
  body nav.menu-simuladores-nav .menu-simuladores-item.sim-edit::after {
    display: none !important;
  }

  body nav.menu-simuladores-nav .menu-simuladores-item.sim-edit {
    margin-left: 4px !important;
  }

  body nav.menu-simuladores-nav .menu-simuladores-item.sim-edit > a {
    width: 28px !important;
    height: 28px !important;
    min-height: 28px !important;
    padding: 0 !important;
    border: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    flex-direction: column !important;
    gap: 4px !important;
  }

  body nav.menu-simuladores-nav .menu-simuladores-item.sim-edit > a span {
    display: block !important;
    width: 18px !important;
    height: 2px !important;
    margin: 0 !important;
    border-radius: 999px !important;
    background: #fff !important;
  }
}
}

@layer sn.core {

@media (min-width: 768px) and (max-width: 1280px) {
  body nav.menu-simuladores-nav {
    --sn-sim-shell-px: 12px;
    --sn-sim-logo-w: 128px;
    --sn-sim-logo-h: 18px;
    --sn-sim-gap: 6px;
  }

  body nav.menu-simuladores-nav .menu-simuladores-list {
    justify-content: flex-start !important;
    overflow-x: auto !important;
    overflow-y: hidden !important;
    scrollbar-width: none !important;
  }

  body nav.menu-simuladores-nav .menu-simuladores-list::-webkit-scrollbar {
    display: none !important;
  }

  body nav.menu-simuladores-nav .menu-simuladores-item > a {
    padding: 0 12px !important;
  }
}
}

@layer sn.core {

@media (min-width: 768px) and (max-width: 980px) {
  body nav.menu-simuladores-nav {
    --sn-sim-logo-w: 116px;
    --sn-sim-logo-h: 17px;
  }
}
}

@layer sn.modules.torneos {
/* ===== Tabla de Posiciones (alineación consistente) ===== */
[data-sn-table="standings"],
[data-sn-table="standings-detail"],
[data-sn-table="rounds"],
.tor-std-table {
  width: 100%;
  border-collapse: collapse;
  border-spacing: 0;
  table-layout: fixed;
}
[data-sn-table="standings"] thead th,
[data-sn-table="standings"] td,
[data-sn-table="standings-detail"] thead th,
[data-sn-table="standings-detail"] td,
[data-sn-table="rounds"] thead th,
[data-sn-table="rounds"] td,
.tor-std-table thead th,
.tor-std-table td {
  padding: 0.5rem 0.6rem;
  vertical-align: middle;
  text-align: left;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
[data-sn-table="standings"] thead th,
[data-sn-table="standings-detail"] thead th,
[data-sn-table="rounds"] thead th,
.tor-std-table thead th {
  background: var(--sn-table-bg-head, #181818);
  color: #e0e0e0;
  font-weight: 600;
  text-align: center;
}
.tor-std-table thead th:nth-child(2) {
  text-align: left;
}
.tor-std-table thead th:last-child {
  text-align: right;
}
[data-sn-table="standings"] tbody tr,
[data-sn-table="standings-detail"] tbody tr,
[data-sn-table="rounds"] tbody tr,
.tor-std-table tbody tr {
  border-top: 1px solid var(--sn-color-border, #2a2a2a);
}
[data-sn-table="standings"] tbody tr:nth-child(even),
[data-sn-table="standings-detail"] tbody tr:nth-child(even),
[data-sn-table="rounds"] tbody tr:nth-child(even),
.tor-std-table tbody tr:nth-child(even) {
  background: var(--sn-table-bg-even, #151515);
}
[data-sn-table="standings"] .tor-td-num,
[data-sn-table="standings-detail"] .tor-td-num,
[data-sn-table="rounds"] .tor-td-num,
.tor-std-table .tor-td-num {
  text-align: right;
}
[data-sn-table="standings"] .tor-std-pos,
[data-sn-table="standings-detail"] .tor-std-pos,
[data-sn-table="rounds"] .tor-std-pos,
.tor-std-table .tor-std-pos {
  width: 52px;
  text-align: center;
}
[data-sn-table="standings"] .tor-std-actions,
[data-sn-table="standings-detail"] .tor-std-actions,
.tor-std-table .tor-std-actions {
  text-align: right;
  white-space: nowrap;
}
.tor-std-table .tor-td-num {
  text-align: center;
}
[data-sn-table="standings"] .tor-std-piloto,
[data-sn-table="standings-detail"] .tor-std-piloto,
[data-sn-table="rounds"] .tor-std-piloto,
.tor-std-table .tor-std-piloto {
  white-space: normal;
}
[data-sn-table="standings"] .tor-std-piloto span,
[data-sn-table="standings-detail"] .tor-std-piloto span,
[data-sn-table="rounds"] .tor-std-piloto span,
.tor-std-table .tor-std-piloto span {
  display: inline-block;
  max-width: 180px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* Celda piloto con avatar alineado */
[data-sn-table="standings"] .tor-std-piloto,
[data-sn-table="standings-detail"] .tor-std-piloto,
[data-sn-table="rounds"] .tor-std-piloto,
.tor-std-table .tor-std-piloto {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
[data-sn-table="standings"] .tor-std-avatar,
[data-sn-table="standings-detail"] .tor-std-avatar,
[data-sn-table="rounds"] .tor-std-avatar,
.tor-std-table .tor-std-avatar {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  -o-object-fit: cover;
     object-fit: cover;
  flex: 0 0 28px;
  display: inline-block;
}

/* Forzar display tabular si algún estilo global cambia a flex/grid */
[data-sn-table="standings"],
[data-sn-table="standings-detail"],
[data-sn-table="rounds"],
.tor-std-table {
  display: table;
}
[data-sn-table="standings"] thead,
[data-sn-table="standings-detail"] thead,
[data-sn-table="rounds"] thead,
.tor-std-table thead {
  display: table-header-group;
}
[data-sn-table="standings"] tbody,
[data-sn-table="standings-detail"] tbody,
[data-sn-table="rounds"] tbody,
.tor-std-table tbody {
  display: table-row-group;
}
[data-sn-table="standings"] tr,
[data-sn-table="standings-detail"] tr,
[data-sn-table="rounds"] tr,
.tor-std-table tr {
  display: table-row;
}
[data-sn-table="standings"] th,
[data-sn-table="standings"] td,
[data-sn-table="standings-detail"] th,
[data-sn-table="standings-detail"] td,
[data-sn-table="rounds"] th,
[data-sn-table="rounds"] td,
.tor-std-table th,
.tor-std-table td {
  display: table-cell;
}
/* === Fixture layout adjustments (no expand parent) === */
.torneo-fixture {
  min-width: 0;
}
.torneo-fixture-scroll {
  width: 100%;
  max-width: 100%;
}
.torneo-fixture-inner {
  flex-wrap: nowrap;
}

/* Zona horaria (nota informativa) */
.sn-tz-note {
  font-size: 0.75rem;
  color: rgba(255, 255, 255, 0.7);
  margin: 6px 0 10px;
}
/* Fijamos ancho base por columna para evitar que calcule sobre vw y empuje layout */
.tfx-phase {
  flex: 0 0 100px;
  min-width: 100px;
}
}

@layer sn.modules.torneos {
@media (max-width: 900px) {
  .tfx-phase {
    flex: 0 0 240px;
    min-width: 240px;
  }
}
}

@layer sn.modules.torneos {
@media (max-width: 600px) {
  .tfx-phase {
    flex: 0 0 220px;
    min-width: 220px;
  }
}
}

@layer sn.modules.torneos {
/* ===== Defaults seguros (no rompen nada si ya existen) ===== */
/*
 * Normalización root torneos -> tokens nitro-core.
 * Eliminamos variables locales duplicadas en favor de --sn-*.
 * Mantiene "--tr-*" como alias temporal por retrocompatibilidad JS/otros CSS.
 */
:root {
  /* Aliases (LEGACY) */
  --tr-primary: var(--sn-theme-primary, #c90d05);
  --tr-fg: var(--sn-color-text, #d6d6d6);
  /* Superficies locales apuntan a core (permiten override fino si se requiere) */
  --tor-color-surface-0: var(--sn-color-surface, #111);
  --tor-color-surface-1: var(--sn-color-surface-alt, #151515);
  --tor-color-surface-2: var(--sn-color-surface-raised, #1b1b1b);
  --tor-color-border: var(--sn-color-border, #2a2a2a);
  --tor-color-accent: var(--sn-theme-primary, #c90d05);
  --tor-color-pill-bg: var(--sn-color-surface-raised, #1b1b1b);
  --tor-color-pill-border: var(--sn-color-border, #2a2a2a);
  --tor-color-pill-fg: var(--sn-color-text, #d6d6d6);
  /* Paleta unificada de estados (igual que tarjetas de competencias) */
  --tor-state-active-bg: linear-gradient(135deg, #00c853, #019f45);
  --tor-state-active-border: rgba(0, 200, 83, 0.6);
  --tor-state-progress-bg: linear-gradient(135deg, #ffb703, #fb8500);
  --tor-state-progress-border: rgba(251, 133, 0, 0.6);
  --tor-state-final-bg: linear-gradient(135deg, #4a4a4a, #222);
  --tor-state-final-border: rgba(255, 255, 255, 0.16);
  --tor-state-suspend-bg: linear-gradient(135deg, #2f2f2f, #121212);
  --tor-state-suspend-border: rgba(255, 255, 255, 0.08);
}

/* ===== Denuncias (casos) ===== */
.tor-denuncias {
  margin-top: 0.6rem;
}

/* Notas pequeñas en formularios/modal */
.tor-note-sm {
  font-size: 0.72rem;
  color: #9a9a9a;
}

/* Espaciado sutil para iconos en títulos/labels */
.sn-modal__title i,
label i,
.tor-cal-card-head h4 i,
.tor-cal-table thead th i {
  margin-right: 0.45rem;
}

/* Selector tipo adjunto compacto */
.sn-adj-kind {
  background: var(--sn-color-surface-raised, #1b1b1b);
  border: 1px solid var(--sn-color-border, #2a2a2a);
  color: var(--sn-color-text, #e0e0e0);
  border-radius: 8px;
  padding: 0.25rem 0.5rem;
  height: 30px;
  font-size: 0.78rem;
}
.sn-input.sn-adj-kind {
  min-height: 30px;
  line-height: 1.1;
  padding: 0.2rem 0.5rem;
}

/* Botón de cierre pequeño dentro de chips de involucrados */
.sn-inv-chips .sn-badge button[data-sn="rm-inv"],
.sn-inv-chips .tor-badge button[data-sn="rm-inv"] {
  background: transparent;
  border: 0;
  color: #cfcfcf;
  padding: 0 0 0 0.35rem;
  margin: 0 0 0 0.15rem;
  font-size: 0.9em;
  line-height: 1;
  cursor: pointer;
}
.sn-inv-chips .sn-badge button[data-sn="rm-inv"]:hover,
.sn-inv-chips .tor-badge button[data-sn="rm-inv"]:hover {
  color: #fff;
}

.tor-den-card {
  border: 1px solid #222;
  background: #111;
  border-radius: 8px;
  padding: 0.6rem 0.8rem;
  margin-bottom: 0.6rem;
}
.tor-den-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.6rem;
  margin-bottom: 0.3rem;
}
.tor-den-meta {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.tor-den-date {
  color: #cfcfcf;
  font-size: 0.8rem;
}
.tor-den-body {
  color: #ddd;
  font-size: 0.9rem;
}
.tor-den-ppl {
  margin-top: 0.45rem;
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}
.tor-den-line {
  color: #e9e9e9;
}
.tor-den-actions {
  margin-top: 0.5rem;
  text-align: right;
}
.tor-den-modal [data-sn-tabs="denuncia-detail"] {
  display: flex;
  gap: 0.4rem;
  margin-bottom: 0.6rem;
}
.tor-denuncias .den-com-item,
.tor-den-modal .den-com-item {
  border-top: 1px solid #222;
  padding: 0.45rem 0;
}
.sn-tor-top {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid var(--sn-color-border, #2a2a2a);
  color: #f4f4f4;
  padding: 0.42rem 0.75rem;
  border-radius: 999px;
  font-weight: 800;
  letter-spacing: 0.2px;
  line-height: 1;
}
.sn-tor-top:hover {
  background: rgba(255, 255, 255, 0.07);
  border-color: #3a3a3a;
}
.sn-tor-top i {
  color: var(--sn-theme-primary, #c90d05);
  opacity: 0.95;
}
.sn-tor-top span {
  color: inherit;
}

.sn-tor-bottom {
  margin-top: 6px;
}
.sn-tor-sub {
  color: #cfd3da !important;
  font-weight: 700;
  letter-spacing: 0.25px;
  background: transparent;
  padding: 0;
  border-radius: 0;
  border: 0;
}
.tor-denuncias .den-adjuntos a,
.tor-den-modal .den-adjuntos a {
  display: inline-block;
  margin-right: 0.6rem;
  margin-top: 0.25rem;
  color: #9ecbff;
}
.tor-denuncias .den-ok,
.tor-den-modal .den-ok {
  color: #1ec970;
  font-weight: 900;
}
.tor-denuncias .den-no,
.tor-den-modal .den-no {
  color: #f05a5a;
  font-weight: 900;
}

/* ===== Nitro Torneos ? Reglamento (dark sobrio) ===== */
.tor-reglamento {
  background: #111;
  border: 1px solid #222;
  border-radius: 8px;
  padding: 1rem;
  font-size: 0.9rem;
  color: #ddd;
}
[data-sn-tabs="rules"],
[data-sn-tabs="rules-sub"] {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
  margin-bottom: 0.8rem;
}
.tor-reglamento-tab i {
  width: 1rem;
  height: 1rem;
  font-size: 0.95em;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.tor-reglamento-content {
  min-height: 160px;
}
.tor-reglamento-content .tor-loading {
  padding: 1.2rem;
  text-align: center;
  color: #8e8e8e;
}

/* ===== Puntos ===== */
[data-sn-table="points"],
.tor-puntos-table {
  width: 100%;
  margin-top: 0.6rem;
  font-size: 0.78rem;
}
[data-sn-table="points"],
.tor-puntos-table {
  --sn-table-bg-head: #181818;
  --sn-table-bg-even: #151515;
  --sn-table-border-color: #2a2a2a;
}
[data-sn-table="points"] thead th,
.tor-puntos-table thead th {
  background: var(--sn-table-bg-head);
  font-weight: 600;
  color: #e0e0e0;
}
[data-sn-table="points"] td,
[data-sn-table="points"] th,
.tor-puntos-table td,
.tor-puntos-table th {
  padding: 0.4rem 0.5rem;
  text-align: left;
}
[data-sn-table="points"].sn-table,
.tor-puntos-table.sn-table {
  border-collapse: collapse;
}

/* ===== Sanciones ===== */
[data-sn-table="sanctions"],
.tor-sanciones-table {
  width: 100%;
  margin-top: 0.8rem;
  font-size: 0.7rem;
  table-layout: fixed;
}
[data-sn-table="sanctions"],
.tor-sanciones-table {
  --sn-table-bg-head: #181818;
  --sn-table-bg-even: #151515;
  --sn-table-border-color: #2a2a2a;
}
[data-sn-table="sanctions"] th,
.tor-sanciones-table th {
  background: var(--sn-table-bg-head);
  font-weight: 600;
  font-size: 0.66rem;
  letter-spacing: 0.5px;
  text-transform: uppercase;
  color: #cfcfcf;
}
[data-sn-table="sanctions"] td,
[data-sn-table="sanctions"] th,
.tor-sanciones-table td,
.tor-sanciones-table th {
  padding: 0.45rem 0.55rem;
  vertical-align: top;
  word-break: break-word;
  white-space: normal;
}
[data-sn-table="sanctions"] td.tor-td-seccion,
.tor-sanciones-table td.tor-td-seccion {
  font-weight: 600;
  background: #161616;
}
[data-sn-table="sanctions"] td.tor-td-accion,
.tor-sanciones-table td.tor-td-accion {
  background: #141414;
}
[data-sn-table="sanctions"] td.tor-td-gravedad,
.tor-sanciones-table td.tor-td-gravedad {
  text-align: center;
}
[data-sn-table="sanctions"] td.tor-td-observaciones,
.tor-sanciones-table td.tor-td-observaciones {
  font-size: 0.62rem;
  line-height: 1.2;
}
[data-sn-table="sanctions"] td.tor-td-valor,
.tor-sanciones-table td.tor-td-valor {
  text-align: center !important;
  vertical-align: middle;
}
[data-sn-table="sanctions"].sn-table,
.tor-sanciones-table.sn-table {
  border-collapse: collapse;
}

/* Roles en denuncias (scope local para evitar fugas) */
.tor-denuncias .rol-denunciante,
.tor-den-modal .rol-denunciante {
  background: #1e2a3a;
  border-color: var(--sn-theme-primary, #c90d05);
  color: #d6e4ff;
}
.tor-denuncias .rol-denunciado,
.tor-den-modal .rol-denunciado {
  background: #2a1717;
  border-color: #6a2a2a;
  color: #ffd9d9;
}
.tor-denuncias .rol-involucrado,
.tor-den-modal .rol-involucrado {
  background: #1b1b1b;
  border-color: #2a2a2a;
  color: #e0e0e0;
}
.tor-denuncias .rol-apelante,
.tor-den-modal .rol-apelante {
  background: #1f1a12;
  border-color: #6a5a20;
  color: #fff3cc;
}
.tor-denuncias .rol-sistema,
.tor-den-modal .rol-sistema {
  background: #121a1d;
  border-color: #2a5a6a;
  color: #cbe4ea;
}
.tor-denuncias .rol-comisario-revisor,
.tor-den-modal .rol-comisario-revisor {
  background: #151c13;
  border-color: #2e5a3b;
  color: #d9f0d9;
}
.tor-denuncias .rol-comisario-lider,
.tor-den-modal .rol-comisario-lider {
  background: #191129;
  border-color: #3e427a;
  color: #d0d4f0;
}

/* ===== Estados de sanciones/casos (sobrios) ===== */
.tor-denuncias .estado-en-proceso,
.tor-den-modal .estado-en-proceso {
  background: #1a1f2b;
  border-color: var(--sn-theme-primary, #c90d05);
  color: #e6efff;
}
.tor-denuncias .estado-aplicado,
.tor-den-modal .estado-aplicado {
  background: #14251a;
  border-color: #2e5a3b;
  color: #e8ffe8;
}

[data-sn-table="sanctions"] .tor-accion-main,
.tor-sanciones-table .tor-accion-main {
  font-weight: 600;
}

[data-sn-table="sanctions"] .tor-accion-extra,
.tor-sanciones-table .tor-accion-extra {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-top: 6px;
}

[data-sn-table="sanctions"] .tor-pop-desc,
.tor-sanciones-table .tor-pop-desc {
  color: #cfd3da;
  font-size: 0.92em;
  line-height: 1.35;
  opacity: 0.95;
}

[data-sn-table="sanctions"] .tor-pop-art,
.tor-sanciones-table .tor-pop-art {
  display: inline-flex;
  align-items: center;
  gap: 0.35em;
  width: -moz-fit-content;
  width: fit-content;
  padding: 2px 8px;
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.07);
  color: #fff;
  font-size: 0.85em;
  font-weight: 600;
  letter-spacing: 0.01em;
}

[data-sn-table="sanctions"] .tor-grav-obs,
.tor-sanciones-table .tor-grav-obs {
  margin-top: 6px;
  font-size: 0.92em;
  color: #cfd3da;
  opacity: 0.95;
}

.pw-card.pw-card-msgs {
  margin-bottom: 18px;
}

.pw-msg-table {
  width: 100%;
  border-collapse: collapse;
}

.pw-msg-table th,
.pw-msg-table td {
  padding: 10px 12px;
}

.pw-msg-unread {
  background: rgba(255, 255, 255, 0.04);
  border-left: 3px solid #3aa0ff;
}

.pw-msg-read {
  opacity: 0.95;
}

.pw-msg-subject {
  font-weight: 600;
}

.pw-msg-state {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 10px;
  font-size: 12px;
}

.pw-msg-state.leido {
  background: rgba(46, 204, 113, 0.2);
  color: #2ecc71;
}

.pw-msg-state.noleido {
  background: rgba(241, 196, 15, 0.2);
  color: #f1c40f;
}

.pw-modal.pw-wide {
  max-width: 1120px;
  width: 96vw;
}

.pw-overlay,
.pw-overlay * {
  box-sizing: border-box;
}

.pw-open .pw-overlay {
  display: flex !important;
}

.pw-overlay .pw-modal {
  position: relative !important;
  left: auto !important;
  right: auto !important;
  transform: none !important;
  width: min(980px, calc(100vw - 24px - env(safe-area-inset-left) - env(safe-area-inset-right)));
  max-width: calc(100vw - 24px - env(safe-area-inset-left) - env(safe-area-inset-right));
  margin: 0 auto;
  overflow: hidden;
}

.pw-overlay .pw-modal-body {
  overflow: auto;
  overflow-x: auto;
  max-height: 78vh;
  max-width: 100%;
  -webkit-overflow-scrolling: touch;
}

.pw-overlay .pw-modal-body * {
  max-width: 100%;
}

.pw-overlay .pw-modal-body table {
  display: block;
  width: 100% !important;
  max-width: 100% !important;
  overflow-x: auto;
}

.pw-overlay .pw-modal-body td,
.pw-overlay .pw-modal-body th,
.pw-overlay .pw-modal-body a,
.pw-overlay .pw-modal-body code {
  word-break: break-word;
  overflow-wrap: anywhere;
}

.pw-overlay .pw-modal-body code {
  white-space: pre-wrap;
}

.pw-msg-table .td-actions {
  white-space: nowrap;
}

.pw-msg-table .td-actions .pw-msg-ver {
  min-height: 36px;
  padding: 8px 12px;
  font-size: 0.92rem;
}

.sn-pitwall .tor-cal-card .tor-cal-card-body {
  padding: 12px 14px;
}

.sn-pitwall .ronda-formato {
  margin-left: auto;
  font-size: 0.85rem;
  opacity: 0.9;
}

.sn-pitwall .sn-tz-note {
  margin: 6px 0 10px;
  font-size: 12px;
  opacity: 0.75;
}
}

@layer sn.modules.torneos {

@media (max-width: 600px) {
  .pw-msg-table th,
  .pw-msg-table td {
    padding: 10px;
  }

  .pw-msg-table .td-actions {
    min-width: 94px;
  }

  .pw-msg-table .td-actions .pw-msg-ver {
    width: 100%;
    min-height: 40px;
  }
}
}

@layer sn.modules.torneos {
.tor-denuncias .estado-rechazado,
.tor-den-modal .estado-rechazado {
  background: #2a1717;
  border-color: #6a2a2a;
  color: #ffd9d9;
}
.tor-denuncias .estado-sin-accion,
.tor-den-modal .estado-sin-accion {
  background: #1b1c1e;
  border-color: #2a2e31;
  color: #d6d6d6;
}
.tor-denuncias .estado-aplazado,
.tor-den-modal .estado-aplazado {
  background: #2a2416;
  border-color: #6a5a20;
  color: #fff2cc;
}

/* Botón inscripción (bloqueado) más visible en rojo */
.sn-tor-skin .sn-tor-badge.st-blocked-accounts,
.sn-tor-skin .sn-tor-badge.st-blocked-profile,
.sn-tor-skin .sn-tor-badge.st-blocked-license,
.sn-tor-skin .sn-tor-badge.st-blocked-config,
.sn-tor-skin .sn-tor-badge.st-blocked-membership {
  background: #7a150f !important;
  border-color: #c90d05 !important;
  color: #fff !important;
  box-shadow:
    0 0 0 1px rgba(201, 13, 5, 0.35),
    0 0 6px -1px rgba(201, 13, 5, 0.55);
}
.sn-tor-skin .sn-tor-badge.st-blocked-accounts:hover,
.sn-tor-skin .sn-tor-badge.st-blocked-profile:hover,
.sn-tor-skin .sn-tor-badge.st-blocked-license:hover,
.sn-tor-skin .sn-tor-badge.st-blocked-config:hover,
.sn-tor-skin .sn-tor-badge.st-blocked-membership:hover {
  background: #c90d05 !important;
  border-color: #ff4e42 !important;
  color: #fff !important;
}
.sn-tor-skin .sn-tor-badge.st-blocked-accounts i,
.sn-tor-skin .sn-tor-badge.st-blocked-profile i,
.sn-tor-skin .sn-tor-badge.st-blocked-license i,
.sn-tor-skin .sn-tor-badge.st-blocked-config i,
.sn-tor-skin .sn-tor-badge.st-blocked-membership i {
  color: #fff !important;
}

/* Variantes de estado (sobrias) */
.sn-tor-skin .sn-status,
.sn-tor-skin .tor-estado-badge {
  font-size: 0.74rem;
  font-weight: 600;
  padding: 2px 10px;
}
.sn-tor-skin .sn-badge.estado-programada,
.sn-tor-skin .sn-badge.estado-programado,
.sn-tor-skin .sn-badge.estado-pendiente,
.sn-tor-skin .sn-badge.estado-activa,
.sn-tor-skin .sn-badge.estado-activo,
.sn-tor-skin .sn-badge.estado-sala,
.sn-tor-skin .sn-status.estado-programada,
.sn-tor-skin .sn-status.estado-programado,
.sn-tor-skin .sn-status.estado-pendiente,
.sn-tor-skin .sn-status.estado-activa,
.sn-tor-skin .sn-status.estado-activo,
.sn-tor-skin .sn-status.estado-sala,
.sn-tor-skin .tor-badge.estado-programada,
.sn-tor-skin .tor-badge.estado-programado,
.sn-tor-skin .tor-badge.estado-pendiente,
.sn-tor-skin .tor-badge.estado-activa,
.sn-tor-skin .tor-badge.estado-activo,
.sn-tor-skin .tor-badge.estado-sala,
.sn-tor-skin .tor-estado-badge.estado-programada,
.sn-tor-skin .tor-estado-badge.estado-programado,
.sn-tor-skin .tor-estado-badge.estado-pendiente,
.sn-tor-skin .tor-estado-badge.estado-activa,
.sn-tor-skin .tor-estado-badge.estado-activo,
.sn-tor-skin .tor-estado-badge.estado-sala {
  background: var(--tor-state-active-bg);
  border-color: var(--tor-state-active-border);
  color: #f6fff6;
}
.sn-tor-skin .sn-badge.estado-curso,
.sn-tor-skin .sn-badge.estado-en-curso,
.sn-tor-skin .sn-badge.estado-asignando,
.sn-tor-skin .sn-badge.estado-progresando,
.sn-tor-skin .sn-status.estado-curso,
.sn-tor-skin .sn-status.estado-en-curso,
.sn-tor-skin .sn-status.estado-asignando,
.sn-tor-skin .sn-status.estado-progresando,
.sn-tor-skin .tor-badge.estado-curso,
.sn-tor-skin .tor-badge.estado-en-curso,
.sn-tor-skin .tor-badge.estado-asignando,
.sn-tor-skin .tor-badge.estado-progresando,
.sn-tor-skin .tor-estado-badge.estado-curso,
.sn-tor-skin .tor-estado-badge.estado-en-curso,
.sn-tor-skin .tor-estado-badge.estado-asignando,
.sn-tor-skin .tor-estado-badge.estado-progresando {
  background: var(--tor-state-progress-bg);
  border-color: var(--tor-state-progress-border);
  color: #2a1200;
}
.sn-tor-skin .sn-badge.estado-completada,
.sn-tor-skin .sn-badge.estado-finalizada,
.sn-tor-skin .sn-badge.estado-cerrada,
.sn-tor-skin .sn-status.estado-completada,
.sn-tor-skin .sn-status.estado-finalizada,
.sn-tor-skin .sn-status.estado-cerrada,
.sn-tor-skin .tor-badge.estado-completada,
.sn-tor-skin .tor-badge.estado-finalizada,
.sn-tor-skin .tor-badge.estado-cerrada,
.sn-tor-skin .tor-estado-badge.estado-completada,
.sn-tor-skin .tor-estado-badge.estado-finalizada,
.sn-tor-skin .tor-estado-badge.estado-cerrada {
  background: var(--tor-state-final-bg);
  border-color: var(--tor-state-final-border);
  color: #f5f5f5;
}
.sn-tor-skin .sn-badge.estado-cancelada,
.sn-tor-skin .sn-badge.estado-suspendida,
.sn-tor-skin .sn-badge.estado-aplazada,
.sn-tor-skin .sn-badge.estado-aplazado,
.sn-tor-skin .sn-status.estado-cancelada,
.sn-tor-skin .sn-status.estado-suspendida,
.sn-tor-skin .sn-status.estado-aplazada,
.sn-tor-skin .sn-status.estado-aplazado,
.sn-tor-skin .tor-badge.estado-cancelada,
.sn-tor-skin .tor-badge.estado-suspendida,
.sn-tor-skin .tor-badge.estado-aplazada,
.sn-tor-skin .tor-badge.estado-aplazado,
.sn-tor-skin .tor-estado-badge.estado-cancelada,
.sn-tor-skin .tor-estado-badge.estado-suspendida,
.sn-tor-skin .tor-estado-badge.estado-aplazada,
.sn-tor-skin .tor-estado-badge.estado-aplazado {
  background: var(--tor-state-suspend-bg);
  border-color: var(--tor-state-suspend-border);
  color: #f5f5f5;
}

/* Variantes de sanción */
.sancion-minima {
  background: #161616;
  border-color: #3a3a3a;
  color: #d9d9d9;
}

/* ===== Select2 dentro de modales torneos (denuncias) ===== */
.tor-den-modal .select2-container .select2-selection--multiple,
.sn-modal .select2-container .select2-selection--multiple {
  background: #1a1a1a;
  border: 1px solid #2a2a2a;
  min-height: 36px;
  padding: 2px 6px;
  border-radius: 8px;
  font-size: 0.86rem;
  color: #e0e0e0;
}
.tor-den-modal
  .select2-container--default
  .select2-selection--multiple
  .select2-selection__choice,
.sn-modal
  .select2-container--default
  .select2-selection--multiple
  .select2-selection__choice {
  background: #262626;
  border: 1px solid #333;
  color: #e7e7e7;
  border-radius: 6px;
  padding: 2px 6px;
  margin-top: 4px;
}
.select2-results__options {
  max-height: 260px;
  overflow-y: auto;
}
.select2-search__field::-moz-placeholder {
  color: #9a9a9a;
}
.select2-search__field::placeholder {
  color: #9a9a9a;
}
.sancion-leve {
  background: #1b190f;
  border-color: #6a5e2a;
  color: #eadfba;
}
.sancion-moderada {
  background: #1c1510;
  border-color: #6a4826;
  color: #f0d1b6;
}
.sancion-grave {
  background: #1c1313;
  border-color: #6a2a2a;
  color: #f0c7c7;
}
.sancion-dsq-carrera {
  background: #1a1212;
  border-color: #7a3131;
  color: #f2c1c6;
}
.sancion-dsq-torneo {
  background: #191118;
  border-color: #6a2f56;
  color: #f0c7de;
}
.sancion-expulsion {
  background: #1a1212;
  border-color: #733030;
  color: #f0bbbb;
  text-transform: uppercase;
  letter-spacing: 0.02em;
}
.sancion-tiempo {
  background: #121a1d;
  border-color: #2a5a6a;
  color: #cbe4ea;
}
.sancion-licencia {
  background: #131429;
  border-color: #3e427a;
  color: #d0d4f0;
}
.sancion-grid {
  background: #1c1510;
  border-color: #6a4826;
  color: #f0d1b6;
}
.sancion-puntos {
  background: #1c1313;
  border-color: #6a2a2a;
  color: #f0c7c7;
}
.sancion-semanas {
  background: #181120;
  border-color: #5a2a6a;
  color: #e0c7f0;
}

/* ===== Calendario Torneos ===== */
.tor-calendario {
  margin-top: 1rem;
}
.tor-cal-section {
  margin-bottom: 1.2rem;
}
.tor-cal-section-title {
  margin: 0.2rem 0 0.7rem 0;
  font-size: 0.92rem;
  font-weight: 900;
  letter-spacing: 0.6px;
  color: #fff;
  text-transform: uppercase;
  padding-left: 0.6rem;
  border-left: 4px solid #2a2a2a;
  text-shadow: none;
}
.tor-cal-section.programadas .tor-cal-section-title {
  border-left-color: var(--sn-theme-primary, #c90d05);
}
.tor-cal-section.completadas .tor-cal-section-title {
  border-left-color: #2e5a3b;
}
.tor-cal-division-wrapper {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.tor-cal-card {
  background: #121212;
  border: 1px solid #232323;
  border-radius: 12px;
  overflow: hidden;
}
.tor-cal-card-head {
  display: grid;
  grid-template-columns: auto 1fr auto auto;
  gap: 0.5rem 0.8rem;
  align-items: center;
  padding: 0.85rem 1rem;
  background: #151515;
  border-bottom: 1px solid #292929;
  position: relative;
}
.tor-cal-card-head h4 {
  margin: 0;
  font-size: 1rem;
  font-weight: 800;
  color: #f2f2f2;
}
.tor-cal-card-head:before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 4px;
  background: #2a2a2a;
  border-radius: 4px 0 0 4px;
}
.tor-cal-section.programadas .tor-cal-card-head {
  background: #121820;
}
.tor-cal-section.programadas .tor-cal-card-head:before {
  background: var(--sn-theme-primary, #c90d05);
}
.tor-cal-section.completadas .tor-cal-card-head {
  background: #111a14;
}
.tor-cal-section.completadas .tor-cal-card-head:before {
  background: #2e5a3b;
}

.tor-cal-card-body {
  overflow-x: auto;
}
/* Calendario table -> .sn-table variants */
[data-sn-table="calendar"],
.tor-cal-table {
  width: 100%;
  font-size: 0.75rem;
}
[data-sn-table="calendar"],
.tor-cal-table {
  --sn-table-bg-head: #151515;
  --sn-table-bg-even: #161616;
  --sn-table-bg-odd: #121212;
  --sn-table-border-color: #232323;
}
[data-sn-table="calendar"] thead th,
.tor-cal-table thead th {
  background: var(--sn-table-bg-head);
  color: #e3e3e3;
  font-weight: 700;
  padding: 0.45rem 0.55rem;
  text-align: left;
  border-bottom: 1px solid #232323;
}
[data-sn-table="calendar"] tbody td,
.tor-cal-table tbody td {
  padding: 0.5rem 0.55rem;
  border-bottom: 1px solid #1b1b1b;
  vertical-align: middle;
}
[data-sn-table="calendar"].sn-table,
.tor-cal-table.sn-table {
  border-collapse: separate;
  border-spacing: 0;
}
[data-sn-table="calendar"] tbody tr:hover,
.tor-cal-table tbody tr:hover {
  background: #1b1b1b;
}

/* Countdown */
.tor-countdown {
  --tor-pill-bg: #1a1a1a;
  --tor-pill-border: #2a2a2a;
  --tor-pill-fg: #d0d0d0;
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.26rem 0.55rem;
  border-radius: 8px;
  background: var(--tor-pill-bg);
  border: 1px solid var(--tor-pill-border);
  color: var(--tor-pill-fg);
}
.tor-countdown:not(.ended) {
  background: linear-gradient(135deg, #2a0b09, #3d0f0c 40%, #520f0a);
  border-color: #61100c;
  box-shadow:
    0 0 0 1px #130605,
    0 0 12px -3px rgba(201, 13, 5, 0.55);
  position: relative;
}
.tor-countdown:not(.ended):before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: radial-gradient(
    circle at 15% 25%,
    rgba(255, 90, 70, 0.15),
    transparent 60%
  );
  pointer-events: none;
}
.tor-countdown:not(.ended) .cd-time {
  font-variant-numeric: tabular-nums;
  letter-spacing: 0.5px;
  text-shadow: 0 0 6px rgba(184, 0, 201, 0.5);
}
.tor-countdown.pulse:not(.ended) {
  animation: torCountdownPulse 1.8s ease-in-out infinite;
}
@keyframes torCountdownPulse {
  0%,
  100% {
    box-shadow:
      0 0 0 1px #130605,
      0 0 10px -4px rgba(201, 13, 5, 0);
  }
  50% {
    box-shadow:
      0 0 0 1px #130605,
      0 0 18px -2px rgba(201, 13, 5, 0.65);
  }
}
.tor-countdown .cd-label {
  font-size: 0.62rem;
  font-weight: 800;
  color: var(--tor-pill-fg);
}
.tor-countdown .cd-time {
  font-family: monospace;
  font-weight: 900;
  color: #fff;
}
.tor-countdown.ended {
  opacity: 0.7;
}

/* Responsive calendario */
}

@layer sn.modules.torneos {
@media (max-width: 900px) {
  .tor-cal-card-head h4 {
    font-size: 0.85rem;
  }
  .tor-cal-card-head .ronda-formato {
    font-size: 0.66rem;
  }
  [data-sn-table="calendar"],
  .tor-cal-table {
    font-size: 0.7rem;
  }
  [data-sn-table="calendar"] .col-formato,
  [data-sn-table="calendar"] .col-estado-ronda,
  [data-sn-table="calendar"] .col-faltan,
  .tor-cal-table .col-formato,
  .tor-cal-table .col-estado-ronda,
  .tor-cal-table .col-faltan {
    display: none;
  }
}
}

@layer sn.modules.torneos {
@media (max-width: 680px) {
  .tor-cal-card-head {
    grid-template-columns: auto 1fr auto;
  }
  [data-sn-table="calendar"],
  .tor-cal-table {
    font-size: 0.66rem;
  }
  [data-sn-table="calendar"] .col-pista,
  [data-sn-table="calendar"] .col-hasta,
  [data-sn-table="calendar"] .col-estado-comp,
  .tor-cal-table .col-pista,
  .tor-cal-table .col-hasta,
  .tor-cal-table .col-estado-comp {
    display: none;
  }
  [data-sn-table="calendar"] th,
  [data-sn-table="calendar"] td,
  .tor-cal-table th,
  .tor-cal-table td {
    padding: 0.4rem 0.45rem;
  }
}
}

@layer sn.modules.torneos {
@media (max-width: 480px) {
  [data-sn-table="calendar"],
  .tor-cal-table {
    font-size: 0.62rem;
  }
  [data-sn-table="calendar"] .col-no,
  .tor-cal-table .col-no {
    display: none;
  }
}
}

@layer sn.modules.torneos {
/* Extra calendario safeguards for very small screens */
}

@layer sn.modules.torneos {
@media (max-width: 520px) {
  .tor-cal-card-body {
    overflow-x: auto;
  }
  .tor-cal-card-body [data-sn-table="calendar"],
  .tor-cal-card-body .tor-cal-table {
    min-width: 520px;
  }
}
}

@layer sn.modules.torneos {

/* === Torneos calendario helpers (flags + sesión) === */
.pista-cell {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
}
.tor-flag {
  display: inline-block;
  width: 24px;
  height: 18px;
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
  border: 1px solid #2a2a2a;
  border-radius: 2px;
}
.sesion-badge {
  --tor-pill-bg: #1f1f1f;
  --tor-pill-border: #2b2b2b;
  --tor-pill-fg: #e7e7e7;
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  background: var(--tor-pill-bg);
  border: 1px solid var(--tor-pill-border);
  padding: 0.26rem 0.52rem;
  border-radius: 999px;
  font-weight: 700;
  font-size: 0.68rem;
  color: var(--tor-pill-fg);
}
.sesion-badge:before {
  content: "";
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: var(--sesion-color, #555);
  box-shadow: 0 0 0 1px #000;
}
.sesion-badge i {
  font-size: 0.78rem;
}

/* ===== Modal de Resultados de Sesión ===== */
.tor-res-open {
  overflow: hidden;
}
.sn-modal-overlay[data-sn-modal="results"],
.tor-res-overlay {
  position: fixed;
  inset: 0;
  z-index: 9999;
  background: var(--sn-overlay-bg, rgba(0, 0, 0, 0.6));
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
  display: none;
  align-items: center; /* centrado vertical */
  justify-content: center;
  padding: 40px 20px; /* uniforme */
  box-sizing: border-box;
}
.sn-modal-overlay[data-sn-modal="results"] .sn-modal__dialog,
.tor-res-modal {
  position: relative;
  width: min(1100px, 96vw);
  max-height: 88vh;
  overflow: hidden;
  background: var(--sn-color-surface, #111);
  border: 1px solid var(--sn-color-border, #222);
  border-radius: var(--sn-radius-lg, 10px);
  box-shadow: var(--sn-shadow-xl, 0 10px 40px rgba(0, 0, 0, 0.6));
  display: flex;
  flex-direction: column;
  animation: snModalIn 0.4s cubic-bezier(0.4, 0.12, 0.2, 1);
  /* Defensive: ensure modal itself is not stretched full width causing visual left bias */
  margin: 0 auto;
}
.sn-modal-overlay[data-sn-modal="results"].force-center .sn-modal__dialog,
.sn-modal-overlay[data-sn-modal="results"] .sn-modal__dialog.force-center,
.tor-res-overlay.force-center .tor-res-modal,
.tor-res-modal.force-center {
  position: fixed !important;
  top: 50% !important;
  left: 50% !important;
  transform: translate(-50%, -50%) !important;
  margin: 0 !important;
}
.sn-modal-overlay[data-sn-modal="results"] .sn-modal__header,
.tor-res-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--sn-space-3, 0.8rem) var(--sn-space-4, 1rem);
  border-bottom: 1px solid var(--sn-color-border, #222);
  background: var(--sn-color-surface-alt, #151515);
}
.sn-modal-overlay[data-sn-modal="results"] .sn-modal__title,
.tor-res-head h4 {
  margin: 0;
  font-size: var(--sn-font-size-md, 1rem);
  color: var(--sn-color-text-strong, #fff);
  font-weight: 600;
}
.sn-modal-overlay[data-sn-modal="results"] .sn-modal__close,
.tor-res-close {
  background: var(--sn-color-surface-raised, #1f1f1f);
  border: 1px solid var(--sn-color-border, #333);
  color: var(--sn-color-text, #eee);
  border-radius: var(--sn-radius-sm, 6px);
  padding: 0.35rem 0.6rem;
  cursor: pointer;
  font: 500 var(--sn-font-size-xs, 0.7rem) / 1 var(--sn-font-sans, system-ui);
  transition:
    background 0.22s ease,
    filter 0.22s ease;
}
.sn-modal-overlay[data-sn-modal="results"] .sn-modal__close:hover,
.tor-res-close:hover {
  background: var(--sn-color-surface-alt, #262626);
  filter: brightness(1.1);
}
[data-sn-tabs="results"] {
  display: flex;
  gap: 0.4rem;
  padding: 0.5rem 0.8rem;
  border-bottom: 1px solid #222;
  background: #131313;
  overflow: auto;
}
.sn-modal-overlay[data-sn-modal="results"] .sn-modal__body,
.tor-res-body {
  padding: 0.8rem;
  overflow: auto;
}
.tor-res-dim {
  display: block;
}
.tor-res-group-head {
  margin: 0.4rem 0 0.4rem;
}
.tor-res-group-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  background: #1b1b1b;
  border: 1px solid #2a2a2a;
  color: #e3e3e3;
  padding: 0.35rem 0.6rem;
  border-radius: 8px;
  font-weight: 700;
  font-size: 0.8rem;
}
.tor-res-group-badge i {
  font-size: 0.9rem;
}

/* Resultados: wrapper + .sn-table */
.sn-table-wrap[data-sn-table-wrap="results"],
.tor-res-table-wrap {
  overflow: auto;
  border: 1px solid var(--tor-color-border, #222);
  border-radius: 8px;
}
[data-sn-table="results"],
.tor-res-table {
  width: 100%;
  font-size: 0.78rem;
}
[data-sn-table="results"].sn-table,
.tor-res-table.sn-table {
  --sn-table-font-size: 0.78rem;
  --sn-table-header-bg: #181818;
  --sn-table-header-fg: #e0e0e0;
  --sn-table-row-alt-bg: #141414;
  --sn-table-row-border: #1b1b1b;
  --sn-table-cell-padding: 0.45rem 0.55rem;
  --sn-table-header-border: #2a2a2a;
}
[data-sn-table="results"] thead th,
.tor-res-table thead th {
  position: sticky;
  top: 0;
  z-index: 2;
}
.tor-res-row-error {
  background: #2a1717 !important;
}
.tor-res-piloto {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
}
.tor-res-avatar {
  width: 24px;
  height: 24px;
  border-radius: 50%;
  -o-object-fit: cover;
     object-fit: cover;
  border: 1px solid #2a2a2a;
}
.tor-res-auto {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
}
.tor-res-brand {
  width: 22px;
  height: 22px;
  -o-object-fit: contain;
     object-fit: contain;
  filter: drop-shadow(0 1px 0 rgba(0, 0, 0, 0.3));
}
.tor-actions-col {
  display: flex;
  gap: 0.35rem;
  flex-wrap: wrap;
}
.tor-cal-act {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  background: var(
    --sn-grad-theme,
    linear-gradient(
      135deg,
      var(--sn-theme-primary, #c90d05),
      var(--sn-theme-primary-hover, #e01006) 55%
    )
  );
  border: 1px solid var(--sn-theme-primary-accent, #9e0a03);
  color: #fff;
  padding: 0.38rem 0.68rem;
  border-radius: 8px;
  font-size: 0.7rem;
  font-weight: 650;
  line-height: 1.1;
  cursor: pointer;
  box-shadow:
    0 2px 4px rgba(0, 0, 0, 0.35),
    0 0 0 1px rgba(255, 255, 255, 0.05) inset;
  transition:
    filter 0.22s ease,
    transform 0.16s ease;
}
.tor-cal-act i {
  font-size: 0.9em;
}
.tor-cal-act:hover {
  filter: brightness(1.12) saturate(1.05);
}
.tor-cal-act.tor-act-resultados {
  background: linear-gradient(135deg, #123047, #1a4769 55%);
  border-color: #215a86;
  color: #e4f4ff;
}
.tor-cal-act.tor-act-resultados:hover {
  filter: brightness(1.12) saturate(1.05);
}
.tor-cal-act.tor-act-info {
  /* Info ahora usa un rojo oscuro diferenciador en lugar de gris neutro */
  background: linear-gradient(135deg, #6a0803, #860a04 55%);
  border-color: #6e0903;
  color: #ffe2df;
}
.tor-cal-act.tor-act-info:hover {
  filter: brightness(1.12);
}
/* Pitwall specific action buttons (migrated from legacy pitwall css) */
.sn-pitwall .tor-cal-act.pw-msg-ver,
.sn-pitwall .tor-cal-act.pw-ver-confirmados,
.sn-pitwall .tor-cal-act[data-action="msg-ver"],
.sn-pitwall .tor-cal-act[data-action="ver-confirmados"] {
  /* Force primary theme visual to avoid flash of unstyled button */
  background: var(
    --sn-grad-theme,
    linear-gradient(
      135deg,
      var(--sn-theme-primary, #c90d05),
      var(--sn-theme-primary-hover, #e01006) 55%
    )
  );
  border: 1px solid var(--sn-theme-primary-accent, #9e0a03);
  color: #fff;
}
.sn-pitwall .tor-cal-act.pw-msg-ver:hover,
.sn-pitwall .tor-cal-act.pw-ver-confirmados:hover,
.sn-pitwall .tor-cal-act[data-action="msg-ver"]:hover,
.sn-pitwall .tor-cal-act[data-action="ver-confirmados"]:hover {
  filter: brightness(1.12) saturate(1.05);
}

/* Redondear cualquier botón dentro de pitwall que no tenga estilo explícito */
.sn-pitwall button,
.sn-pitwall .tor-cal-act,
.sn-pitwall .pw-asist-cell button,
.sn-pitwall .pw-modal button {
  border-radius: 8px !important;
}

/* Optional subtle differentiation if needed later (commented out)
.sn-pitwall .tor-cal-act.pw-ver-confirmados { filter: saturate(1.15); }
*/
.tor-res-table tbody tr:nth-child(odd) {
  background: #121212;
}
}

@layer sn.modules.torneos {
@media (max-width: 680px) {
  .tor-res-table {
    font-size: 0.7rem;
  }
  .tor-res-table.sn-table {
    --sn-table-font-size: 0.7rem;
  }
  .tor-res-modal {
    top: 3%;
    width: 96vw;
  }
}
}

@layer sn.modules.torneos {

/* ===== Tablas de Posiciones / Rondas (estilo común) ===== */
.tor-standings,
.tor-rondas {
  margin-top: 1rem;
}
.tor-std-table-wrap {
  overflow-x: auto;
}
.tor-std-dim-title {
  margin: 0.7rem 0 0.45rem;
  padding-bottom: 0.35rem;
  border-bottom: 1px solid #2a2a2a;
  font: 700 0.76rem/1.2 var(--sn-font-sans, system-ui);
  letter-spacing: 0.5px;
  text-transform: uppercase;
  color: #e6e6e6;
}
.tor-std-dim-title span {
  display: inline-block;
  padding: 0.15rem 0.4rem;
  border-radius: 6px;
  background: #1a1a1a;
  border: 1px solid #2a2a2a;
}
.tor-std-group-head {
  margin-top: 0.5rem;
}
.tor-standings-content,
.tor-rondas-content {
  margin-top: 0.6rem;
}

/* Tabs standings/rondas */
.tor-std-tab {
  margin-right: 0.4rem;
}

/* Standings / Rondas table -> .sn-table */
.tor-std-table {
  width: 100%;
  font-size: 0.78rem;
  border-collapse: collapse;
}
.tor-std-table {
  --sn-table-bg-head: #151515;
  --sn-table-border-color: #232323;
}
.tor-std-table thead th {
  background: var(--sn-table-bg-head);
  color: #e3e3e3;
  font-weight: 700;
  padding: 8px 10px;
  border-bottom: 1px solid #232323;
  text-align: center;
  position: sticky;
  top: 0;
}
.tor-std-table thead th i {
  margin-right: 6px;
  opacity: 0.9;
}
.tor-std-table td {
  padding: 8px 10px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
  text-align: center;
  vertical-align: middle;
}
.tor-std-table th,
.tor-std-table td {
  border-right: 1px solid rgba(255, 255, 255, 0.06);
}
.tor-std-table th:last-child,
.tor-std-table td:last-child {
  border-right: 0;
}
.tor-std-table tbody tr:nth-child(odd) {
  background: #121212;
}
.tor-std-table tbody tr:nth-child(even) {
  background: #151515;
}

.tor-td-num {
  font-variant-numeric: tabular-nums;
  text-align: center;
}
.tor-std-piloto {
  display: flex;
  align-items: center;
  gap: 8px;
  justify-content: flex-start;
}
.tor-std-avatar {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  -o-object-fit: cover;
     object-fit: cover;
}
.tor-std-penal {
  background: #3a0d0d;
  color: #ffd9d9;
}
.tor-std-total {
  background: #0d2242;
  color: #d7e7ff;
  font-weight: 700;
  font-size: 1.05em;
}
.tor-std-chase {
  background: #0d2242;
  color: #d7e7ff;
  font-weight: 700;
}

/* Rondas specific */
.tor-std-rondas thead th {
  font-size: 12px;
  text-align: center;
}
.tor-std-colcomp {
  width: 72px;
}

/* Emoji flag inline tweaks */
.tor-emoji-flag {
  display: inline-block;
  margin-right: 4px;
}

/* Responsive standings */
}

@layer sn.modules.torneos {
@media (max-width: 768px) {
  .tor-standings .tor-std-table {
    font-size: 0.68rem;
  }
  .tor-standings .tor-std-actions {
    display: none;
  }
}
}

@layer sn.modules.torneos {
@media (max-width: 520px) {
  .tor-standings .tor-std-table {
    font-size: 0.66rem;
  }
  .tor-standings .tor-std-avatar {
    width: 20px;
    height: 20px;
  }
}
}

@layer sn.modules.torneos {
/* Tablas apiladas (card-like) en móviles pequeños */
}

@layer sn.modules.torneos {
@media (max-width: 520px) {
  .tor-std-table.tor-std-cardable thead,
  .tor-std-detail-table.tor-std-cardable thead {
    display: none;
  }
  .tor-std-table.tor-std-cardable,
  .tor-std-table.tor-std-cardable tbody,
  .tor-std-table.tor-std-cardable tr,
  .tor-std-table.tor-std-cardable td,
  .tor-std-detail-table.tor-std-cardable,
  .tor-std-detail-table.tor-std-cardable tbody,
  .tor-std-detail-table.tor-std-cardable tr,
  .tor-std-detail-table.tor-std-cardable td {
    display: block;
    width: 100%;
  }
  .tor-std-table.tor-std-cardable tr,
  .tor-std-detail-table.tor-std-cardable tr {
    margin-bottom: 0.7rem;
    border: 1px solid #222;
    border-radius: 8px;
    overflow: hidden;
    background: #131313;
  }
  .tor-std-table.tor-std-cardable td,
  .tor-std-detail-table.tor-std-cardable td {
    text-align: right;
    padding: 0.5rem 0.6rem 0.5rem 48%;
    position: relative;
    border: 0;
    border-bottom: 1px solid #1c1c1c;
  }
  .tor-std-table.tor-std-cardable td:last-child,
  .tor-std-detail-table.tor-std-cardable td:last-child {
    border-bottom: 0;
  }
  .tor-std-table.tor-std-cardable td::before,
  .tor-std-detail-table.tor-std-cardable td::before {
    content: attr(data-label);
    position: absolute;
    left: 0;
    top: 0;
    height: 100%;
    width: 46%;
    padding: 0.5rem 0.6rem;
    text-align: left;
    color: #bfbfbf;
    font-weight: 700;
  }
  .tor-std-table.tor-std-cardable .tor-std-piloto,
  .tor-std-detail-table.tor-std-cardable .tor-std-piloto {
    justify-content: flex-end;
  }
  .tor-std-table.tor-std-cardable .tor-std-piloto span,
  .tor-std-detail-table.tor-std-cardable .tor-std-piloto span {
    white-space: normal;
    overflow: visible;
    text-overflow: clip;
  }
  .tor-std-table.tor-std-cardable .tor-std-actions,
  .tor-std-detail-table.tor-std-cardable .tor-std-actions {
    display: none;
  }
}
}

@layer sn.modules.torneos {
/* Rondas: ensure headers center even si global overrides */
.tor-std-rondas thead th.tor-std-colcomp {
  text-align: center;
}

/* ===== Modales detalle standings ===== */
.tor-std-overlay {
  position: fixed;
  inset: 0;
  z-index: 9999;
  background: var(--sn-overlay-bg, rgba(0, 0, 0, 0.6));
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
  display: none;
  align-items: center; /* centrado vertical */
  justify-content: center;
  padding: 40px 20px; /* uniforme */
  box-sizing: border-box;
}
.tor-std-modal {
  position: relative;
  width: min(1100px, 98vw);
  max-height: 86vh;
  overflow: hidden;
  background: var(--sn-color-surface, #111);
  border: 1px solid var(--sn-color-border, #222);
  border-radius: var(--sn-radius-lg, 10px);
  display: flex;
  flex-direction: column;
  box-shadow: var(--sn-shadow-xl, 0 10px 40px rgba(0, 0, 0, 0.6));
  animation: snModalIn 0.4s cubic-bezier(0.4, 0.12, 0.2, 1);
}
.tor-std-overlay.force-center .tor-std-modal,
.tor-std-modal.force-center {
  position: fixed !important;
  top: 50% !important;
  left: 50% !important;
  transform: translate(-50%, -50%) !important;
  margin: 0 !important;
}
.tor-std-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--sn-space-3, 0.7rem) var(--sn-space-4, 1rem);
  border-bottom: 1px solid var(--sn-color-border, #222);
  background: var(--sn-color-surface-alt, #151515);
}
.tor-std-head h4 {
  margin: 0;
  font-size: var(--sn-font-size-md, 1rem);
  color: var(--sn-color-text-strong, #fff);
  font-weight: 600;
}
.tor-std-sub {
  margin-top: 0.2rem;
  font-size: 0.78rem;
  color: var(--sn-color-text, #cfcfcf);
}
.tor-std-close {
  background: var(--sn-color-surface-raised, #1f1f1f);
  border: 1px solid var(--sn-color-border, #333);
  color: var(--sn-color-text, #eee);
  border-radius: var(--sn-radius-sm, 6px);
  padding: 0.35rem 0.6rem;
  cursor: pointer;
  font: 500 var(--sn-font-size-xs, 0.7rem) / 1 var(--sn-font-sans, system-ui);
  transition:
    background 0.22s ease,
    filter 0.22s ease;
}
.tor-std-close:hover {
  background: var(--sn-color-surface-alt, #262626);
  filter: brightness(1.1);
}
.tor-std-body {
  padding: 0.8rem;
  overflow-y: auto;
  overflow-x: hidden;
}
.tor-std-detail-inner {
  overflow-x: hidden;
}
.tor-std-detail-table {
  width: 100%;
  table-layout: fixed;
  font-size: 0.76rem;
}
.tor-std-detail-table thead th,
.tor-std-detail-table td {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: normal;
  vertical-align: middle;
  text-align: center !important;
  word-break: break-word;
}
.tor-std-detail-table thead th {
  text-align: center !important;
}
.tor-std-detail-table .col-puntos,
.tor-std-detail-table .col-fecha,
.tor-std-detail-table .col-nombre,
.tor-std-detail-table .col-sesion,
.tor-std-detail-table .col-competencia,
.tor-std-detail-table .col-ronda {
  text-align: center !important;
}
.tor-std-detail-table tfoot td {
  border-top: 1px solid #222;
  font-weight: 700;
}
/* Standings detail: wrapper + .sn-table */
.tor-std-detail-table.sn-table {
  --sn-table-font-size: 0.76rem;
  --sn-table-header-bg: #181818;
  --sn-table-header-fg: #e0e0e0;
  --sn-table-header-border: #2a2a2a;
  --sn-table-row-border: #1b1b1b;
  --sn-table-cell-padding: 0.45rem 0.55rem;
}
.tor-std-detail-table thead th {
  position: sticky;
  top: 0;
  z-index: 2;
}
.tor-std-bonus-note {
  margin-top: 0.25rem;
  font-size: 0.72rem;
  color: #c9c9c9;
  line-height: 1.2;
  text-align: left;
}
.tor-std-bonus-item {
  padding: 0.1rem 0;
  border-bottom: 1px dashed rgba(255,255,255,0.08);
}
.tor-std-bonus-item:last-child {
  border-bottom: 0;
}
/* Standings detail: wrapper + .sn-table */
.tor-std-detail-table {
  width: 100%;
  font-size: 0.76rem;
}
.tor-std-detail-table.sn-table {
  --sn-table-font-size: 0.76rem;
  --sn-table-header-bg: #181818;
  --sn-table-header-fg: #e0e0e0;
  --sn-table-header-border: #2a2a2a;
  --sn-table-row-border: #1b1b1b;
  --sn-table-cell-padding: 0.45rem 0.55rem;
}
.tor-std-detail-table thead th {
  position: sticky;
  top: 0;
  z-index: 2;
}
}

@layer sn.modules.torneos {
@media (max-width: 680px) {
  .tor-std-table {
    font-size: 0.7rem;
  }
  .tor-std-modal {
    width: 96vw;
  }
}
}

@layer sn.modules.torneos {
@media (max-width: 420px) {
  .tor-std-modal {
    width: 98vw;
    max-height: 96vh;
    border-radius: 6px;
  }
  .tor-std-body {
    padding: 0.6rem;
  }
  .tor-std-head {
    padding: 0.5rem;
  }
}
}

@layer sn.modules.torneos {

/* Allow tor-badge to wrap inside table cells on narrow screens */
.sn-tor-skin .tor-badge {
  white-space: normal;
}

/* === HARD OVERRIDES (final safeguard) === */
/* Forzar centrado vertical de cualquier overlay de resultados o standings aunque otro CSS anterior ponga flex-start/top */
.tor-res-overlay,
.tor-std-overlay {
  align-items: center !important;
  justify-content: center !important;
  padding: 40px 20px !important;
}
/* Catch-all: cualquier overlay cuyo class contenga 'res-overlay' o 'std-overlay' (futuros nombres) */
[class*="res-overlay"],
[class*="std-overlay"] {
  align-items: center !important;
  justify-content: center !important;
}

/* Nota: si por alguna razón el flex parent no existe o otro script mueve el modal fuera del overlay,
   se puede añadir via JS la clase 'force-center' al modal u overlay para aplicar el centrado absoluto:
   document.querySelectorAll('.tor-res-modal, .tor-std-modal').forEach(m=>m.classList.add('force-center')) */
/* Quitar restos de top/left aplicados por media queries antiguas */
/* Importante: NO anular transform/top/left globalmente porque la clase .force-center usa translate para centrar. */
.tor-res-modal.force-center,
.tor-std-modal.force-center,
.tor-res-overlay.force-center .tor-res-modal,
.tor-std-overlay.force-center .tor-std-modal {
  position: fixed !important;
  top: 50% !important;
  left: 50% !important;
  transform: translate(-50%, -50%) !important;
  margin: 0 !important;
}
/* Botón inscribir: asegurar texto blanco absoluto si algo lo pisa */
.sn-tor-save {
  color: #fff !important;
}
/* Bloque superior/inferior cuando requiere login (alto contraste) */
.sn-tor-top {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: linear-gradient(135deg, #1c1c1c, #242424 55%);
  border: 1px solid #343434;
  color: #ffffff;
  padding: 0.4rem 0.65rem;
  border-radius: 8px;
  font-weight: 800;
  letter-spacing: 0.2px;
}
.sn-tor-top i {
  color: #ffefe9;
  filter: drop-shadow(0 0 2px rgba(255, 255, 255, 0.12));
}
.sn-tor-top span {
  color: #ffffff;
  text-shadow: 0 1px 0 rgba(0, 0, 0, 0.55);
}

.sn-tor-bottom {
  margin-top: 6px;
}
.sn-tor-sub {
  color: #e5e5e5 !important;
  font-weight: 700;
  letter-spacing: 0.3px;
  background: rgba(0, 0, 0, 0.18);
  padding: 2px 6px;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.08);
}
/* Inscripción: cuando está deshabilitado/inscrito/cerrado el texto se veía gris.
   Evitamos bajar la opacidad y forzamos alto contraste. */
.sn-tor-save[disabled],
.sn-tor-save.is-inscribed,
.sn-tor-save.is-closed,
.tor-btn[disabled].sn-tor-save {
  opacity: 1 !important;
  color: #fff !important;
  background: linear-gradient(135deg, #3a3a3a, #4a4a4a 55%) !important;
  border-color: #565656 !important;
  text-shadow: 0 1px 0 rgba(0, 0, 0, 0.55);
  cursor: not-allowed !important;
}
/* ==== Modal Inscritos ? Tabs & Controles ==== */
.sn-ins-tabs {
  display: flex;
  gap: 6px;
  margin: 0 0 12px;
  flex-wrap: wrap;
}
.sn-ins-tab {
  --_bg: #1d1d1d;
  --_border: #2a2a2a;
  --_fg: #cfcfcf;
  position: relative;
  background: var(--_bg);
  color: var(--_fg);
  border: 1px solid var(--_border);
  padding: 0.45rem 0.85rem;
  font: 600 0.7rem/1 var(--sn-font-sans, system-ui);
  letter-spacing: 0.5px;
  border-radius: 999px;
  cursor: pointer;
  transition:
    background 0.25s ease,
    color 0.25s ease,
    border-color 0.25s ease,
    box-shadow 0.25s ease;
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
}
.sn-ins-tab:hover {
  background: #252525;
}
.sn-ins-tab.active {
  --_bg: linear-gradient(145deg, #7d0f0a, #c90d05 55%, #e52f25);
  --_fg: #fff;
  --_border: #c90d05;
  color: var(--_fg);
  border-color: var(--_border);
  background: var(--_bg);
  box-shadow:
    0 0 0 1px rgba(255, 255, 255, 0.05),
    0 4px 14px -4px rgba(201, 13, 5, 0.65);
}
.sn-ins-tab:focus-visible {
  outline: 2px solid #c90d05;
  outline-offset: 2px;
}

.sn-ins-controls {
  display: flex;
  align-items: center;
  gap: 8px;
  margin: 0 0 10px;
  flex-wrap: wrap;
}
.sn-ins-controls label {
  font-size: 0.62rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: #bbb;
}
.sn-ins-controls select {
  background: #181818;
  color: #eee;
  border: 1px solid #2a2a2a;
  border-radius: 6px;
  padding: 0.35rem 0.55rem;
  font-size: 0.68rem;
}
.sn-ins-controls select:focus {
  outline: 1px solid #c90d05;
}

.sn-ins-div {
  display: none;
}
.sn-ins-div.active {
  display: block;
  animation: fadeIn 0.35s ease;
}
@keyframes fadeIn {
  from {
    opacity: 0;
    transform: translateY(4px);
  }
  to {
    opacity: 1;
    transform: none;
  }
}

.sn-ins-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.68rem;
}
.sn-ins-table thead th {
  background: #181818;
  color: #ccc;
  font-weight: 700;
  padding: 0.45rem 0.55rem;
  text-align: left;
  border-bottom: 1px solid #272727;
}
.sn-ins-table tbody td {
  padding: 0.42rem 0.55rem;
  border-bottom: 1px solid #1f1f1f;
  color: #ddd;
}
.sn-ins-table tbody tr:hover {
  background: #1d1d1d;
}
.sn-ins-table-wrap {
  margin-bottom: 14px;
  overflow-x: auto;
}
.sn-ins-cat-title {
  font: 700 0.7rem/1.3 var(--sn-font-sans, system-ui);
  letter-spacing: 0.5px;
  color: #eee;
  margin: 10px 0 6px;
  text-transform: uppercase;
}
.sn-ins-empty,
.sn-ins-error {
  padding: 1.1rem;
  background: #191919;
  border: 1px solid #262626;
  border-radius: 10px;
  font-size: 0.72rem;
  color: #ccc;
}

/* Select2 dark adjust (if applied inside modal) */
.sn-ins-modal .select2-container--dark .select2-selection {
  background: #181818;
  border: 1px solid #2a2a2a;
  min-height: 32px;
}
.sn-ins-modal .select2-container--dark .select2-selection__rendered {
  color: #e0e0e0;
}
.sn-ins-modal .select2-container--dark .select2-results__option--highlighted {
  background: #c90d05;
}

/* ===== Tabs scrollables/snap en módulos ===== */
[data-sn-tabs="standings"],
[data-sn-tabs="rounds"],
[data-sn-tabs="calendar-divisions"],
[data-sn-tabs="calendar-status"],
[data-sn-tabs="rules"],
[data-sn-tabs="rules-sub"],
.tor-den-modal [data-sn-tabs="denuncia-detail"] {
  display: flex;
  gap: 0.4rem;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: thin;
  scroll-snap-type: x proximity;
  padding-bottom: 0.35rem;
  border-bottom: 1px solid #2a2a2a;
  margin-bottom: 0.6rem;
}
[data-sn-tabs="standings"] > *,
[data-sn-tabs="rounds"] > *,
[data-sn-tabs="calendar-divisions"] > *,
[data-sn-tabs="calendar-status"] > *,
[data-sn-tabs="rules"] > *,
[data-sn-tabs="rules-sub"] > *,
.tor-den-modal [data-sn-tabs="denuncia-detail"] > * {
  flex: 0 0 auto;
  scroll-snap-align: start;
}

/* Denuncias: tabla de sanciones con scroll horizontal en móviles */
}

@layer sn.modules.torneos {
@media (max-width: 520px) {
  .tor-denuncias .den-sanciones,
  .tor-den-modal .den-sanciones {
    overflow-x: auto;
  }
  .tor-denuncias .den-sanciones .den-san-table,
  .tor-den-modal .den-sanciones .den-san-table {
    min-width: 520px;
    font-size: 0.66rem;
  }
}
}

@layer sn.modules.torneos {

/* Wrappers genéricos */
.tor-denuncias .den-san-table-wrap,
.tor-den-modal .den-san-table-wrap {
  overflow-x: auto;
}
/* Forzar contención de overflow en módulos torneos */
.tor-reglamento,
.tor-calendario,
.tor-standings,
.tor-rondas,
.tor-denuncias {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  max-width: 100%;
  box-sizing: border-box;
}
.tor-reglamento > *,
.tor-calendario > *,
.tor-standings > *,
.tor-rondas > *,
.tor-denuncias > * {
  max-width: 100%;
  overflow-x: auto;
}

/* Tablas dentro de shortcodes siempre con scroll interno */
.tor-reglamento table,
.tor-calendario table,
.tor-standings table,
.tor-rondas table,
.tor-denuncias table {
  width: 100%;
  display: table;
  table-layout: auto;
}

/* Contenedores de tabla con scroll obligatorio en móvil */
}

@layer sn.modules.torneos {
@media (max-width: 768px) {
  .tor-reglamento,
  .tor-calendario,
  .tor-standings,
  .tor-rondas,
  .tor-denuncias {
    overflow-x: auto !important;
  }
}
}

@layer sn.modules.torneos {

/* ---------- Afinado de iconos en pills ---------- */
.sn-tor-skin .tor-badge i {
  width: 14px;
  height: 14px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 0.95em;
}

/* ===== Overrides: asegurar colores de roles/estados en pills de denuncias ===== */
/* Algunas reglas generales de .tor-badge pueden sobreescribir los colores; elevamos especificidad aquí */
.tor-denuncias .tor-badge.rol-denunciante {
  background: #1e2a3a !important;
  border-color: var(--sn-theme-primary, #c90d05) !important;
  color: #d6e4ff !important;
}
.tor-denuncias .tor-badge.rol-denunciado {
  background: #2a1717 !important;
  border-color: #6a2a2a !important;
  color: #ffd9d9 !important;
}
.tor-denuncias .tor-badge.rol-involucrado {
  background: #1b1b1b !important;
  border-color: #2a2a2a !important;
  color: #e0e0e0 !important;
}
.tor-denuncias .tor-badge.rol-apelante {
  background: #1f1a12 !important;
  border-color: #6a5a20 !important;
  color: #fff3cc !important;
}
.tor-denuncias .tor-badge.rol-sistema {
  background: #121a1d !important;
  border-color: #2a5a6a !important;
  color: #cbe4ea !important;
}
.tor-denuncias .tor-badge.rol-comisario-revisor {
  background: #151c13 !important;
  border-color: #2e5a3b !important;
  color: #d9f0d9 !important;
}
.tor-denuncias .tor-badge.rol-comisario-lider {
  background: #191129 !important;
  border-color: #3e427a !important;
  color: #d0d4f0 !important;
}

.tor-denuncias .tor-badge.estado-en-proceso {
  background: #1a1f2b !important;
  border-color: var(--sn-theme-primary, #c90d05) !important;
  color: #e6efff !important;
}
.tor-denuncias .tor-badge.estado-aplicado {
  background: #14251a !important;
  border-color: #2e5a3b !important;
  color: #e8ffe8 !important;
}
.tor-denuncias .tor-badge.estado-rechazado {
  background: #2a1717 !important;
  border-color: #6a2a2a !important;
  color: #ffd9d9 !important;
}
.tor-denuncias .tor-badge.estado-sin-accion {
  background: #1b1c1e !important;
  border-color: #2a2e31 !important;
  color: #d6d6d6 !important;
}
.tor-denuncias .tor-badge.estado-aplazado {
  background: #2a2416 !important;
  border-color: #6a5a20 !important;
  color: #fff2cc !important;
}

/* ===== Overrides también dentro del modal de detalle de denuncia ===== */
.tor-den-modal .tor-badge i {
  width: 14px;
  height: 14px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 0.95em;
}
.tor-den-modal .tor-badge.rol-denunciante {
  background: #1e2a3a !important;
  border-color: var(--sn-theme-primary, #c90d05) !important;
  color: #d6e4ff !important;
}
.tor-den-modal .tor-badge.rol-denunciado {
  background: #2a1717 !important;
  border-color: #6a2a2a !important;
  color: #ffd9d9 !important;
}
.tor-den-modal .tor-badge.rol-involucrado {
  background: #1b1b1b !important;
  border-color: #2a2a2a !important;
  color: #e0e0e0 !important;
}
.tor-den-modal .tor-badge.rol-apelante {
  background: #1f1a12 !important;
  border-color: #6a5a20 !important;
  color: #fff3cc !important;
}
.tor-den-modal .tor-badge.rol-sistema {
  background: #121a1d !important;
  border-color: #2a5a6a !important;
  color: #cbe4ea !important;
}
.tor-den-modal .tor-badge.rol-comisario-revisor {
  background: #151c13 !important;
  border-color: #2e5a3b !important;
  color: #d9f0d9 !important;
}
.tor-den-modal .tor-badge.rol-comisario-lider {
  background: #191129 !important;
  border-color: #3e427a !important;
  color: #d0d4f0 !important;
}

.tor-den-modal .tor-badge.estado-en-proceso {
  background: #1a1f2b !important;
  border-color: var(--sn-theme-primary, #c90d05) !important;
  color: #e6efff !important;
}
.tor-den-modal .tor-badge.estado-aplicado {
  background: #14251a !important;
  border-color: #2e5a3b !important;
  color: #e8ffe8 !important;
}
.tor-den-modal .tor-badge.estado-rechazado {
  background: #2a1717 !important;
  border-color: #6a2a2a !important;
  color: #ffd9d9 !important;
}
.tor-den-modal .tor-badge.estado-sin-accion {
  background: #1b1c1e !important;
  border-color: #2a2e31 !important;
  color: #d6d6d6 !important;
}
.tor-den-modal .tor-badge.estado-aplazado {
  background: #2a2416 !important;
  border-color: #6a5a20 !important;
  color: #fff2cc !important;
}

/* ===== Torneo Sliders ===== */
.torneo-slider {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto 1rem;
  position: relative;
}
.torneo-slider-loading,
.torneo-slider-error,
.torneo-slider-empty {
  text-align: center;
  padding: 0.5rem;
  color: #888;
  background: #111;
  border-radius: 8px;
  border: 1px solid #333;
  min-height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
}
}

@layer sn.modules.torneos {
@media (max-width: 768px) {
  .torneo-slider-loading,
  .torneo-slider-error,
  .torneo-slider-empty {
    min-height: 44px;
    padding: 0.4rem;
  }
}
}

@layer sn.modules.torneos {
.torneo-slider-error {
  color: #ff6b6b;
  border-color: #4a2626;
  background: #1a1111;
}
.torneo-cards-wrapper {
  overflow: hidden;
  border-radius: 8px;
}
.torneo-cards-track {
  display: flex;
  transition: transform 0.3s ease-in-out;
  gap: 1rem;
}
.torneo-card {
  flex: 0 0 100%;
  display: flex;
  background: #111;
  border: 1px solid #333;
  border-radius: 8px;
  height: 140px;
  overflow: hidden;
}
.torneo-card-image {
  flex: 0 0 120px;
  background: #222;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}
.torneo-card-image img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.torneo-card-placeholder {
  color: #666;
  font-size: 0.8rem;
  text-align: center;
  padding: 1rem;
}
.torneo-card-content {
  flex: 1;
  padding: 0.8rem;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  min-height: 0;
}
.torneo-card-title {
  font-size: 1rem;
  font-weight: 600;
  color: #fff;
  margin: 0 0 0.4rem 0;
  line-height: 1.2;
}
.torneo-card-description {
  font-size: 0.8rem;
  color: #bbb;
  line-height: 1.3;
  margin: 0;
  flex: 1;
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  line-clamp: 3;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
}
/* Contenedor para patrocinadores y botón en la misma línea */
.torneo-card-bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 0.5rem;
}
.torneo-card-sponsors {
  flex: 1;
  margin-right: 0.5rem;
}
.torneo-card-actions {
  flex-shrink: 0;
}
.torneo-card-btn {
  background: linear-gradient(135deg, #c90d05, #e01b12 55%);
  color: #fff;
  text-decoration: none;
  padding: 0.45rem 1.05rem;
  border-radius: 8px;
  font-size: 0.85rem;
  font-weight: 600;
  line-height: 1.1;
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  position: relative;
  isolation: isolate;
  box-shadow:
    0 2px 4px rgba(0, 0, 0, 0.35),
    0 0 0 1px rgba(255, 255, 255, 0.05) inset;
  transition:
    background 0.25s ease,
    transform 0.15s ease,
    box-shadow 0.25s ease,
    filter 0.25s ease;
}
.torneo-card-btn:hover {
  filter: brightness(1.12) saturate(1.05);
  text-decoration: none;
}
.torneo-card-btn:active {
  transform: translateY(2px);
  box-shadow:
    0 1px 2px rgba(0, 0, 0, 0.4),
    0 0 0 1px rgba(255, 255, 255, 0.04) inset;
}
.torneo-card-btn:focus-visible {
  outline: 2px solid #ff544c;
  outline-offset: 2px;
}
/* Controles del slider */
.torneo-slider-controls {
  /* Overlay sobre el slider para no empujar el contenido */
  display: none;
  position: absolute;
  inset: 0;
  z-index: 2;
  display: none;
  align-items: center;
  justify-content: space-between;
  pointer-events: none; /* permite clicks a través excepto en flechas */
  margin: 0;
  padding: 0;
}
.torneo-slider-prev,
.torneo-slider-next {
  background: #333;
  border: 1px solid #555;
  color: #fff;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.1rem;
  transition: all 0.2s ease;
  pointer-events: auto; /* reactivar interacción solo en flechas */
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
}
.torneo-slider-prev {
  left: 6px;
}
.torneo-slider-next {
  right: 6px;
}

.torneo-slider-prev:hover,
.torneo-slider-next:hover {
  background: #444;
  border-color: #666;
}
.torneo-slider-dots {
  display: none;
}
.torneo-slider-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #555;
  border: none;
  cursor: pointer;
  transition: background 0.2s ease;
}
.torneo-slider-dot.active {
  background: #4caf50;
}
.torneo-slider-dot:hover {
  background: #777;
}
.torneo-slider-dot.active:hover {
  background: #45a049;
}
.torneo-sponsors-container {
  overflow: hidden;
  height: 32px;
  display: flex;
  align-items: center;
}
.torneo-sponsors-track {
  display: flex;
  gap: 0.4rem;
  align-items: center;
  height: 100%;
}
.torneo-sponsor-item {
  flex: 0 0 auto;
  width: 32px;
  height: 32px;
  background: #222;
  border: 1px solid #444;
  border-radius: 4px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all 0.2s ease;
  overflow: hidden;
}
.torneo-sponsor-item:hover {
  border-color: #666;
  transform: scale(1.05);
}
.torneo-sponsor-item img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.torneo-sponsor-placeholder {
  font-size: 0.65rem;
  font-weight: 600;
  color: #888;
  text-transform: uppercase;
}
/* Responsive breakpoints */
}

@layer sn.modules.torneos {
@media (min-width: 768px) {
  .torneo-card {
    flex: 0 0 calc(50% - 0.5rem);
    height: 160px;
  }
  .torneo-card-image {
    flex: 0 0 100px;
  }
  .torneo-card-content {
    padding: 0.7rem;
  }
}
}

@layer sn.modules.torneos {
@media (min-width: 1200px) {
  .torneo-card {
    flex: 0 0 calc(33.333% - 0.67rem);
    height: 150px;
  }
  .torneo-card-content {
    padding: 0.6rem;
  }
  .torneo-card-title {
    font-size: 0.9rem;
  }
  .torneo-card-description {
    font-size: 0.7rem;
  }
}
}

@layer sn.modules.torneos {
/* Mobile-specific auto-advance indicator */
}

@layer sn.modules.torneos {
@media (max-width: 767px) {
  .torneo-slider-controls::after {
    content: "Auto-avance cada 10s";
    position: absolute;
    bottom: -1.5rem;
    left: 50%;
    transform: translateX(-50%);
    font-size: 0.7rem;
    color: #666;
    white-space: nowrap;
  }
}
}

@layer sn.modules.torneos {

/* ============================================================= */
/*  MODAL INSCRITOS (GENÉRICO)  sn-tor-modal / sn-ins-modal      */
/* ============================================================= */
.sn-tor-modal,
.sn-ins-modal {
  position: fixed;
  inset: 0;
  z-index: 11000;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 48px 20px 56px;
  background: var(--sn-overlay-bg, rgba(0, 0, 0, 0.55));
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
  box-sizing: border-box;
}
.pw-overlay {
  /* legacy pitwall overlay -> map to unified */
  position: fixed;
  inset: 0;
  z-index: 11000;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 48px 20px 56px;
  background: var(--sn-overlay-bg, rgba(0, 0, 0, 0.55));
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
  box-sizing: border-box;
}
.pw-overlay.on, /* por si en el futuro se usa la misma convención */
.pw-overlay[style*="display: block"],
.pw-overlay[style*="display:block"] {
  display: flex !important;
}
.sn-tor-modal.on,
.sn-ins-modal.on {
  display: flex;
}
/* Contenedor dialog */
.sn-ins-dialog,
.sn-tor-dialog {
  background: var(--sn-color-surface, #141414);
  border: 1px solid var(--sn-color-border, #262626);
  border-radius: var(--sn-radius-lg, 12px);
  width: min(1100px, 96vw);
  max-width: 1100px;
  max-height: 88vh;
  display: flex;
  flex-direction: column;
  padding: var(--sn-space-4, 16px) var(--sn-space-4, 18px)
    var(--sn-space-5, 18px);
  box-shadow: var(--sn-shadow-xl, 0 12px 42px -6px rgba(0, 0, 0, 0.65));
  position: relative;
  overflow: hidden;
  color: var(--sn-color-text, #e2e2e2);
  font-size: var(--sn-font-size-sm, 0.88rem);
  animation: snModalIn 0.42s cubic-bezier(0.4, 0.12, 0.2, 1);
}
.pw-modal {
  /* legacy pitwall modal -> estilizado como sn-dialog */
  background: var(--sn-color-surface, #141414);
  border: 1px solid var(--sn-color-border, #262626);
  border-radius: var(--sn-radius-lg, 12px);
  width: min(640px, 96vw);
  max-height: 88vh;
  display: flex;
  flex-direction: column;
  padding: var(--sn-space-4, 16px) var(--sn-space-4, 18px)
    var(--sn-space-5, 18px);
  box-shadow: var(--sn-shadow-xl, 0 12px 42px -6px rgba(0, 0, 0, 0.65));
  position: relative;
  overflow: hidden;
  color: var(--sn-color-text, #e2e2e2);
  font-size: var(--sn-font-size-sm, 0.88rem);
  animation: snModalIn 0.42s cubic-bezier(0.4, 0.12, 0.2, 1);
}
.pw-modal-head {
  /* map a header unificado */
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  gap: var(--sn-space-3, 12px);
  margin: 0 0 var(--sn-space-3, 12px) 0;
  padding-right: 34px;
  position: relative;
}
.pw-modal-head h4 {
  margin: 0;
  font-size: var(--sn-font-size-md, 1rem);
  line-height: 1.15;
  font-weight: 600;
  color: var(--sn-color-text-strong, #fff);
}
.pw-close {
  /* unificar botón cerrar */
  position: absolute;
  top: 8px;
  right: 8px;
  width: 28px;
  height: 28px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--sn-color-surface-raised, transparent);
  border: 1px solid var(--sn-color-border, #303030);
  color: var(--sn-color-text-soft, #cfcfcf);
  cursor: pointer;
  border-radius: var(--sn-radius-sm, 6px);
  font-size: 16px;
  line-height: 1;
  transition:
    background 0.22s ease,
    color 0.22s ease,
    filter 0.22s ease,
    box-shadow 0.22s ease;
}
.pw-close:hover,
.pw-close:focus-visible {
  background: var(--sn-color-surface-alt, #242424);
  color: var(--sn-color-text-strong, #fff);
  box-shadow:
    0 0 0 1px var(--sn-color-border-light, #383838),
    0 2px 4px rgba(0, 0, 0, 0.4);
}
.pw-modal-body {
  flex: 1;
  overflow-y: auto;
  overflow-x: hidden;
  scrollbar-gutter: stable both-edges;
  padding-right: 4px;
  align-items: center; /* centrado vertical */
  justify-content: center;
  padding: 40px 20px; /* uniforme */
  max-width: 1060px;
  width: min(1060px, 96vw);
}
}

@layer sn.modules.torneos {
@media (max-width: 600px) {
  .pw-modal {
    width: 96vw;
    max-height: 90vh;
    padding: 14px 14px 18px;
  }
  .pw-modal.pw-wide {
    width: 96vw;
  }
  .pw-close {
    width: 26px;
    height: 26px;
  }
}
}

@layer sn.modules.torneos {
/* Header */
.sn-ins-dialog-header,
.sn-tor-dialog-header {
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  gap: var(--sn-space-3, 12px);
  margin: 0 0 var(--sn-space-3, 12px) 0;
  padding-right: 34px;
  position: relative;
}
.sn-ins-dialog-header h4,
.sn-tor-dialog-header h4 {
  margin: 0;
  font-size: var(--sn-font-size-md, 1rem);
  line-height: 1.15;
  font-weight: 600;
  color: var(--sn-color-text-strong, #fff);
}
/* Botón cerrar */
.sn-ins-close,
.sn-tor-close {
  position: absolute;
  top: 8px;
  right: 8px;
  width: 28px;
  height: 28px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--sn-color-surface-raised, transparent);
  border: 1px solid var(--sn-color-border, #303030);
  color: var(--sn-color-text-soft, #cfcfcf);
  cursor: pointer;
  border-radius: var(--sn-radius-sm, 6px);
  font-size: 16px;
  line-height: 1;
  transition:
    background 0.22s ease,
    color 0.22s ease,
    filter 0.22s ease,
    box-shadow 0.22s ease;
}
.sn-ins-close:hover,
.sn-tor-close:hover,
.sn-ins-close:focus-visible,
.sn-tor-close:focus-visible {
  background: var(--sn-color-surface-alt, #242424);
  color: var(--sn-color-text-strong, #fff);
  box-shadow: 0 0 0 1px var(--sn-color-border-light, #383838);
  outline: none;
  filter: brightness(1.05);
}
/* Cuerpo scrollable */
.sn-ins-dialog-body,
.sn-tor-dialog-body {
  flex: 1;
  overflow-y: auto;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-gutter: stable both-edges;
  position: relative;
  padding-right: 4px;
}
.sn-ins-dialog-body::-webkit-scrollbar,
.sn-tor-dialog-body::-webkit-scrollbar {
  width: 8px;
  height: 8px;
}
.sn-ins-dialog-body::-webkit-scrollbar-track,
.sn-tor-dialog-body::-webkit-scrollbar-track {
  background: var(--sn-color-surface-alt, #181818);
}
.sn-ins-dialog-body::-webkit-scrollbar-thumb,
.sn-tor-dialog-body::-webkit-scrollbar-thumb {
  background: var(--sn-color-border, #333);
  border-radius: 4px;
}
.sn-ins-dialog-body::-webkit-scrollbar-thumb:hover,
.sn-tor-dialog-body::-webkit-scrollbar-thumb:hover {
  background: var(--sn-color-border-light, #444);
}
/* Tablas / lista de inscritos */
.sn-ins-dialog-body table,
.sn-tor-dialog-body table {
  width: 100%;
  border-collapse: collapse;
  table-layout: fixed;
  font-size: 0.78rem;
}
.sn-ins-dialog-body th,
.sn-ins-dialog-body td,
.sn-tor-dialog-body th,
.sn-tor-dialog-body td {
  padding: 6px 8px;
  border: 0;
  white-space: normal;
  word-break: break-word;
  vertical-align: middle;
}
.sn-ins-dialog-body thead th,
.sn-tor-dialog-body thead th {
  position: sticky;
  top: 0;
  z-index: 2;
  background: var(--sn-color-surface-alt, #181818);
  font-weight: 600;
  color: var(--sn-color-text, #e6e6e6);
  font-size: 0.7rem;
  letter-spacing: 0.5px;
  text-transform: uppercase;
}
.sn-ins-dialog-body tbody tr:nth-child(odd),
.sn-tor-dialog-body tbody tr:nth-child(odd) {
  background: var(--sn-color-surface-alt, #121212);
}
.sn-ins-dialog-body tbody tr:nth-child(even),
.sn-tor-dialog-body tbody tr:nth-child(even) {
  background: var(--sn-color-surface-raised, #161616);
}
.sn-ins-dialog-body tbody tr + tr td,
.sn-tor-dialog-body tbody tr + tr td {
  border-top: 1px solid var(--sn-color-border, #1f1f1f);
}
/* Filtros / controles dentro del modal */
.sn-ins-filters,
.sn-tor-filters {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 0 0 10px 0;
}
.sn-ins-filters select,
.sn-ins-filters input,
.sn-tor-filters select,
.sn-tor-filters input {
  background: #1c1c1c;
  border: 1px solid #2c2c2c;
  color: #e0e0e0;
  border-radius: 6px;
  padding: 6px 10px;
  font-size: 0.75rem;
  flex: 1 1 140px;
  min-width: 120px;
}
.sn-ins-filters select:focus,
.sn-ins-filters input:focus,
.sn-tor-filters select:focus,
.sn-tor-filters input:focus {
  outline: 1px solid #444;
  border-color: #444;
}
/* Estado vacío / carga */
.sn-ins-empty,
.sn-tor-empty,
.sn-ins-loading,
.sn-tor-loading {
  text-align: center;
  padding: 18px 10px;
  color: #a8a8a8;
  font-size: 0.8rem;
}
/* Etiquetas / badges dentro de la lista */
.sn-ins-badge,
.sn-tor-badge-small {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  background: #1f1f1f;
  border: 1px solid #2b2b2b;
  padding: 2px 6px;
  font-size: 0.6rem;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  border-radius: 6px;
  font-weight: 700;
  color: #dcdcdc;
}
/* Responsive refinements modal */
}

@layer sn.modules.torneos {
@media (max-width: 880px) {
  .sn-ins-dialog,
  .sn-tor-dialog {
    width: min(560px, 95vw);
  }
}
}

@layer sn.modules.torneos {
@media (max-width: 640px) {
  .sn-ins-dialog,
  .sn-tor-dialog {
    width: 96vw;
    padding: 14px 14px 16px;
  }
  .sn-ins-dialog-body table,
  .sn-tor-dialog-body table {
    font-size: 0.72rem;
  }
  .sn-ins-dialog-body th,
  .sn-ins-dialog-body td,
  .sn-tor-dialog-body th,
  .sn-tor-dialog-body td {
    padding: 5px 6px;
  }
}
}

@layer sn.modules.torneos {
@media (max-width: 480px) {
  .sn-ins-dialog,
  .sn-tor-dialog {
    width: 97vw;
    max-height: 90vh;
    padding: 12px 12px 14px;
    border-radius: 10px;
  }
  .sn-ins-dialog-header h4,
  .sn-tor-dialog-header h4 {
    font-size: 0.9rem;
  }
  .sn-ins-close,
  .sn-tor-close {
    width: 22px;
    height: 22px;
    font-size: 15px;
  }
  .sn-ins-dialog-body table,
  .sn-tor-dialog-body table {
    font-size: 0.68rem;
  }
  .sn-ins-dialog-body th,
  .sn-ins-dialog-body td,
  .sn-tor-dialog-body th,
  .sn-tor-dialog-body td {
    padding: 4px 4px;
  }
  .sn-ins-filters,
  .sn-tor-filters {
    gap: 6px;
  }
  .sn-ins-filters select,
  .sn-ins-filters input,
  .sn-tor-filters select,
  .sn-tor-filters input {
    font-size: 0.7rem;
    padding: 5px 8px;
  }
}
}

@layer sn.modules.torneos {
@media (max-width: 380px) {
  .sn-ins-dialog,
  .sn-tor-dialog {
    width: 98vw;
    padding: 10px 10px 12px;
  }
  .sn-ins-dialog-body table,
  .sn-tor-dialog-body table {
    font-size: 0.64rem;
  }
}
}

@layer sn.modules.torneos {
/* Helper para bloquear scroll background cuando modal abierto */
body.sn-ins-modal-open {
  overflow: hidden;
}

/* ===== CORRECCIÓN CONFLICTOS MOBILE SHORTCODES ===== */
}

@layer sn.modules.torneos {
@media (max-width: 768px) {
  .tor-content:not(.tor-reglamento):not(.tor-calendario):not(
      .tor-standings
    ):not(.tor-rondas):not(.tor-denuncias),
  .tor-sc-wrap {
    overflow-x: visible !important;
    padding-left: 12px !important;
    padding-right: 12px !important;
  }
  .sn-tabs[data-sn-tabs="calendar-divisions"],
  .sn-tabs[data-sn-tabs="calendar-status"],
  .sn-tabs[data-sn-tabs="standings"],
  .sn-tabs[data-sn-tabs="rounds"],
  .sn-tabs[data-sn-tabs="rules"],
  .sn-tabs[data-sn-tabs="rules-sub"] {
    padding-left: 12px !important;
    padding-right: 12px !important;
    padding-top: 4px !important;
    padding-bottom: 4px !important;
  }
}
}

@layer sn.modules.torneos {
@media (max-width: 520px) {
  .tor-content:not(.tor-reglamento):not(.tor-calendario):not(
      .tor-standings
    ):not(.tor-rondas):not(.tor-denuncias),
  .tor-sc-wrap {
    overflow-x: visible !important;
    padding-left: 8px !important;
    padding-right: 8px !important;
  }
  .sn-tabs[data-sn-tabs="calendar-divisions"],
  .sn-tabs[data-sn-tabs="calendar-status"],
  .sn-tabs[data-sn-tabs="standings"],
  .sn-tabs[data-sn-tabs="rounds"],
  .sn-tabs[data-sn-tabs="rules"],
  .sn-tabs[data-sn-tabs="rules-sub"] {
    padding-left: 8px !important;
    padding-right: 8px !important;
    padding-top: 4px !important;
    padding-bottom: 4px !important;
  }
}
}

@layer sn.modules.torneos {

/* ===== Mejoras no invasivas ===== */
/* 1) Focus visible accesible (solo al navegar con teclado) */
.tor-std-tab:focus-visible,
.tor-res-tab:focus-visible,
.tor-reglamento-tab:focus-visible,
.tor-cal-act:focus-visible,
.tor-std-detalle:focus-visible,
.tor-res-close:focus-visible,
.tor-std-close:focus-visible,
.tor-den-actions .tor-btn:focus-visible,
.torneo-slider-prev:focus-visible,
.torneo-slider-next:focus-visible,
.torneo-slider-dot:focus-visible,
.torneo-card-btn:focus-visible {
  outline: 2px solid var(--tr-primary);
  outline-offset: 2px;
}
/* 2) Respeto a reduced motion */
}

@layer sn.modules.torneos {
@media (prefers-reduced-motion: reduce) {
  * {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
  .torneo-cards-track {
    transition: none !important;
  }
}
}

@layer sn.modules.torneos {

/* ===== PANEL LATERAL SESIONES (shortcode) ===== */
.tor-ses-panel {
  --tor-ses-bg: #1a1a1a;
  --tor-ses-border: #333;
  --tor-ses-header-bg: #222;
  --tor-ses-radius: 8px;
  --tor-ses-scroll-track: #2a2a2a;
  --tor-ses-scroll-thumb: #555;
  background: var(--tor-ses-bg);
  border: 1px solid var(--tor-ses-border);
  border-radius: var(--tor-ses-radius);
  overflow: hidden;
}
.tor-ses-panel-header {
  background: var(--tor-ses-header-bg);
  padding: 12px 16px;
  border-bottom: 1px solid var(--tor-ses-border);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.tor-ses-panel-title {
  margin: 0;
  font-size: 0.9rem;
  font-weight: 600;
  color: #fff;
  display: flex;
  align-items: center;
  gap: 8px;
}
.tor-ses-panel-title i {
  color: var(--tor-ses-accent, #c90d05);
}
.tor-ses-panel-content {
  padding: 8px;
  max-height: 1200px;
  overflow-y: auto;
}
.tor-ses-panel-content::-webkit-scrollbar {
  width: 4px;
}
.tor-ses-panel-content::-webkit-scrollbar-track {
  background: var(--tor-ses-scroll-track);
}
.tor-ses-panel-content::-webkit-scrollbar-thumb {
  background: var(--tor-ses-scroll-thumb);
  border-radius: 2px;
}
.tor-ses-panel-content::-webkit-scrollbar-thumb:hover {
  background: #666;
}
.tor-loading-spinner {
  text-align: center;
  color: #999;
  padding: 20px;
  font-size: 0.9rem;
}
.tor-panel-error {
  text-align: center;
  color: #ff6b6b;
  padding: 20px;
  font-size: 0.9rem;
  font-weight: 600;
}
.tor-panel-empty {
  text-align: center;
  color: #999;
  padding: 30px 20px;
}
.tor-panel-empty i {
  font-size: 2rem;
  margin-bottom: 8px;
  display: block;
}
.tor-panel-empty p {
  margin: 0;
  font-size: 0.9rem;
}
.tor-panel-section {
  margin-bottom: 16px;
}
.tor-panel-section:last-child {
  margin-bottom: 0;
}
.tor-panel-section-title {
  font-size: 0.7rem;
  font-weight: 600;
  color: #fff;
  margin: 0 0 8px;
  padding: 0 8px;
  display: flex;
  align-items: center;
  gap: 6px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  opacity: 0.9;
}
.tor-panel-card {
  --tor-panel-card-bg: #2a2a2a;
  --tor-panel-card-border: #333;
  --tor-panel-card-hover-bg: #2d2d2d;
  --tor-panel-card-hover-border: #444;
  background: var(--tor-panel-card-bg);
  border: 1px solid var(--tor-panel-card-border);
  border-radius: 6px;
  margin-bottom: 8px;
  overflow: hidden;
  transition:
    background 0.2s ease,
    border-color 0.2s ease,
    box-shadow 0.2s ease;
}
.tor-panel-card:last-child {
  margin-bottom: 0;
}
.tor-panel-card:hover {
  border-color: var(--tor-panel-card-hover-border);
  background: var(--tor-panel-card-hover-bg);
}
.tor-panel-card.en-curso {
  --tor-panel-card-border: #28a745;
  border-color: var(--tor-panel-card-border);
  box-shadow:
    0 0 0 1px #28a74533,
    0 0 8px #28a74533;
}
.tor-panel-card-header {
  padding: 8px 12px;
  background: #333;
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 0.72rem;
  font-weight: 500;
}
.tor-panel-card-meta {
  display: flex;
  gap: 8px;
  align-items: center;
}
.tor-division {
  color: #aaa;
  font-weight: 500;
}
.tor-ronda-code {
  background: #c90d05;
  color: #fff;
  padding: 2px 6px;
  border-radius: 3px;
  font-weight: 600;
  font-size: 0.7rem;
}
.tor-tiempo-curso {
  --tor-tiempo-color: #28a745;
  color: var(--tor-tiempo-color);
  font-weight: 600;
  display: flex;
  align-items: center;
  gap: 4px;
}
.tor-tiempo-relativo {
  --tor-tiempo-rel-color: #ffc107;
  color: var(--tor-tiempo-rel-color);
  font-weight: 500;
}
.tor-pulse {
  animation: torPulse 2s infinite;
}
@keyframes torPulse {
  0% {
    opacity: 1;
  }
  50% {
    opacity: 0.5;
  }
  100% {
    opacity: 1;
  }
}
.tor-panel-card-body {
  padding: 12px;
}
.tor-sesion-info {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 8px;
}
.tor-sesion-icon {
  font-size: 1.2rem;
  width: 24px;
  text-align: center;
}
.tor-sesion-details {
  flex: 1;
}
.tor-sesion-name {
  font-weight: 600;
  color: #fff;
  font-size: 0.85rem;
  line-height: 1.2;
}
.tor-competencia-name {
  color: #ccc;
  font-size: 0.75rem;
  margin-top: 2px;
}
.tor-pista-info {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 8px;
  padding: 6px 8px;
  background: #222;
  border-radius: 4px;
}
.tor-flag-icon {
  width: 20px;
  height: 15px;
  border-radius: 2px;
}
.tor-pista-name {
  color: #ddd;
  font-size: 0.8rem;
  font-weight: 500;
}
.tor-panel-card-footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 8px;
}
.tor-fecha {
  color: #999;
  font-size: 0.75rem;
}
.tor-estado .tor-estado-badge {
  font-size: 0.7rem;
  padding: 2px 8px;
  border-radius: 999px;
  font-weight: 600;
  line-height: 1.1;
}

/* Botones detalle / sanciones (estandarizar mini CTA) */
.tor-std-detalle,
.tor-res-detalle,
.tor-sanciones-btn-desc {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  background: var(
    --sn-grad-theme,
    linear-gradient(
      135deg,
      var(--sn-theme-primary, #c90d05),
      var(--sn-theme-primary-hover, #e01006) 55%
    )
  );
  border: 1px solid var(--sn-theme-primary-accent, #9e0a03);
  color: #fff !important;
  padding: 0.34rem 0.6rem;
  border-radius: 8px;
  font-size: 0.65rem;
  font-weight: 600;
  text-decoration: none !important;
  cursor: pointer;
  box-shadow:
    0 2px 4px rgba(0, 0, 0, 0.35),
    0 0 0 1px rgba(255, 255, 255, 0.05) inset;
  transition:
    filter 0.22s ease,
    transform 0.16s ease;
}
.tor-std-detalle:hover,
.tor-res-detalle:hover,
.tor-sanciones-btn-desc:hover {
  filter: brightness(1.13) saturate(1.05);
}
.tor-std-detalle:active,
.tor-res-detalle:active,
.tor-sanciones-btn-desc:active {
  transform: translateY(2px);
}
.tor-std-detalle i,
.tor-res-detalle i,
.tor-sanciones-btn-desc i {
  font-size: 0.9em;
}
/* Responsive panel */
}

@layer sn.modules.torneos {
@media (max-width: 768px) {
  .tor-ses-panel {
    border-radius: 6px;
  }
  .tor-ses-panel-header {
    padding: 10px 14px;
  }
  .tor-ses-panel-title {
    font-size: 0.85rem;
  }
  .tor-ses-panel-content {
    max-height: 400px;
  }
  .tor-panel-card-header {
    padding: 6px 10px;
    font-size: 0.7rem;
  }
  .tor-ses-panel .tor-panel-card-body {
    padding: 10px;
  }
  .tor-sesion-name {
    font-size: 0.8rem;
  }
  .tor-competencia-name {
    font-size: 0.7rem;
  }
  .tor-pista-name {
    font-size: 0.75rem;
  }
}
}

@layer sn.modules.torneos {
@media (max-width: 520px) {
  .tor-panel-content {
    max-height: 350px;
  }
  .tor-panel-card-header {
    flex-direction: column;
    align-items: flex-start;
    gap: 4px;
  }
  .tor-panel-card-footer {
    flex-direction: column;
    align-items: flex-start;
    gap: 4px;
  }
}
}

@layer sn.modules.torneos {

/* ===== Banners Slider ===== */
.sn-banners {
  position: relative;
  padding: 5px;
  border-radius: 20px;
  background:
    radial-gradient(
      circle at 18% 20%,
      rgba(255, 255, 255, 0.05),
      transparent 60%
    ),
    linear-gradient(135deg, rgba(8, 10, 18, 0.96), rgba(3, 4, 8, 0.98));
  border: 1px solid rgba(255, 255, 255, 0.08);
  box-shadow: 0 18px 36px rgba(0, 0, 0, 0.45);
}
.sn-banners-viewport {
  overflow: hidden;
  width: 100%;
  aspect-ratio: var(--sn-banners-ratio, auto);
  border-radius: 16px;
  border: 1px solid rgba(255, 255, 255, 0.08);
}
.sn-banners-track {
  display: flex;
  transition: transform 500ms ease;
}
.sn-banner-card {
  position: relative;
  display: block;
  height: 100%;
}
.sn-banner-card img,
.sn-banner-ph {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  display: block;
}
.sn-banner-caption {
  position: absolute;
  left: 0.6rem;
  bottom: 0.6rem;
  background: rgba(0, 0, 0, 0.45);
  color: #fff;
  padding: 0.3rem 0.5rem;
  border-radius: 6px;
  font-size: 0.85rem;
  opacity: 0;
  pointer-events: none;
  transition: opacity 150ms ease;
}
.sn-banner-card:hover .sn-banner-caption,
.sn-banner-card:focus .sn-banner-caption {
  opacity: 1;
}
.sn-banners-nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 36px;
  height: 36px;
  border-radius: 50%;
  border: 1px solid #333;
  background: rgba(0, 0, 0, 0.55);
  color: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  z-index: 2;
}
.sn-banners-nav.prev {
  left: 8px;
}
.sn-banners-nav.next {
  right: 8px;
}
.sn-banners-nav:hover {
  background: rgba(0, 0, 0, 0.75);
}
.sn-banners-empty,
.sn-banners-error {
  text-align: center;
  padding: 0.8rem;
  color: #cfcfcf;
}

/* Torneo Fixture - layout por fases (columnas) y divisiones (filas) */
.torneo-fixture {
  color: #ddd;
}
.torneo-fixture-scroll {
  overflow-x: auto;
}
.torneo-fixture-inner {
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: minmax(220px, 1fr);
  gap: 12px;
  padding: 8px 0;
}
.torneo-fixture-loading {
  text-align: center;
  padding: 0.75rem;
  background: #151515;
  border: 1px solid #2a2a2a;
  border-radius: 8px;
}
.tfx-phase {
  background: #101010;
  border: 1px solid #2a2a2a;
  border-radius: 8px;
  padding: 8px;
  min-height: 100%;
}
.tfx-phase-title {
  margin: 0 0 6px 0;
  font-size: 1rem;
  color: #fff;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 2px;
}
.tfx-phase-range {
  font-size: 0.75rem;
  color: #9a9a9a;
}
.tfx-division {
  background: #161616;
  border: 1px solid #2a2a2a;
  border-radius: 6px;
  padding: 6px;
  margin-bottom: 8px;
}
.tfx-division-title {
  margin: 0 0 4px 0;
  font-weight: 600;
  font-size: 0.9rem;
  color: #eaeaea;
}
.tfx-division-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 4px;
}
.tfx-division-date {
  font-size: 0.8rem;
  color: #bdbdbd;
  margin: -2px 0 6px 0;
}
.tfx-division-date-inline {
  font-size: 0.8rem;
  color: #bdbdbd;
}
.tfx-flow {
  display: flex;
  flex-direction: column;
  gap: 4px;
  font-size: 0.85rem;
  background: #1a1a1a;
  border: 1px solid #2a2a2a;
  border-radius: 6px;
  padding: 6px 8px;
  margin-bottom: 6px;
}
.tfx-flow-top {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 6px;
}
.tfx-flow-meta {
  display: flex;
  align-items: center;
  gap: 6px;
  color: #cfcfcf;
  font-size: 0.8rem;
}
.tfx-flow-date {
  color: #9a9a9a;
}
.tfx-pos {
  color: #bdbdbd;
  font-weight: 600;
}
.tfx-arrow {
  color: #888;
  padding: 0 6px;
}
.tfx-sep {
  color: #666;
}
.tfx-dest {
  color: #cfcfcf;
}
.tfx-piloto {
  color: #9bd6ff;
  font-weight: 600;
  white-space: nowrap;
}
.tfx-piloto.empty {
  color: #777;
  font-weight: 400;
}
}

@layer sn.modules.torneos {
@media (max-width: 768px) {
  .torneo-fixture-inner {
    grid-auto-columns: minmax(180px, 1fr);
  }
}
}

@layer sn.modules.torneos {
/* Entrants (clasificados hacia esta división) */
.tfx-entrants {
  background: #121212;
  border: 1px dashed #2a2a2a;
  border-radius: 6px;
  padding: 6px 8px;
  margin-top: 6px;
}
.tfx-entrants-title {
  font-size: 0.8rem;
  color: #bdbdbd;
  margin-bottom: 4px;
}
.tfx-entrants-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 8px;
}
.tfx-entrant {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px;
  background: #1a1a1a;
  border: 1px solid #2a2a2a;
  border-radius: 6px;
}
.tfx-entrant-square {
  width: 12px;
  height: 12px;
  border-radius: 3px;
  background: #3a8ad6;
  flex: 0 0 12px;
}
.tfx-entrant-text {
  display: flex;
  flex-direction: column;
}
.tfx-entrant-name {
  color: #dfefff;
  font-weight: 600;
}
.tfx-entrant-from {
  color: #9a9a9a;
  font-size: 0.8rem;
}
.tfx-entrants.tfx-empty {
  color: #7d7d7d;
  font-style: italic;
  text-align: center;
}



/* Center main standings table headers and cells on desktop */
}

@layer sn.modules.torneos {
@media (min-width: 521px) {
  .tor-std-table thead th,
  .tor-std-table td {
    text-align: center !important;
  }
  .tor-std-table .tor-std-piloto {
    justify-content: center !important;
    text-align: center !important;
  }
  .tor-std-table .tor-std-piloto span {
    text-align: center !important;
  }
}
}

@layer sn.modules.torneos {

/* Mobile cardable: ensure values are visible */
}

@layer sn.modules.torneos {
@media (max-width: 520px) {
  .tor-std-table.tor-std-cardable td {
    color: #ffffff !important;
    text-align: right !important;
  }
  .tor-std-table.tor-std-cardable .tor-std-piloto {
    justify-content: flex-end !important;
    text-align: right !important;
  }
  .tor-std-table.tor-std-cardable .tor-std-piloto span {
    text-align: right !important;
  }
}
}

@layer sn.modules.torneos {

/* ===== Mobile standings: pattern inspired by live score apps ===== */
}

@layer sn.modules.torneos {
@media (max-width: 768px) {
  .tor-standings {
    border: 1px solid #1d2a36;
    border-radius: 14px;
    background: linear-gradient(180deg, #0f1821 0%, #0c141b 100%);
    padding: 10px 10px 8px;
  }

  .tor-standings-tabs {
    gap: 8px;
    padding-bottom: 2px;
    border-bottom: 0;
    margin-bottom: 10px;
  }

  .tor-standings .tor-std-tab {
    border-radius: 999px;
    border: 1px solid #244058;
    background: #122231;
    color: #c8d7e6;
    font-size: 0.72rem;
    font-weight: 600;
    padding: 0.34rem 0.74rem;
    margin-right: 0;
  }

  .tor-standings .tor-std-tab.on {
    background: linear-gradient(135deg, #1890ff, #1d6fe0);
    border-color: #1b78e6;
    color: #fff;
    box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.08) inset;
  }

  .tor-standings .tor-std-table-wrap {
    border: 1px solid #1f303f;
    border-radius: 12px;
    background: #0e161e;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }

  .tor-standings .tor-std-table {
    min-width: 760px;
    font-size: 0.72rem;
  }

  .tor-standings .tor-std-table thead th {
    position: sticky;
    top: 0;
    z-index: 4;
    background: #0f1b25;
    color: #c8d7e6;
  }

  .tor-standings .tor-std-table th,
  .tor-standings .tor-std-table td {
    white-space: nowrap;
  }

  .tor-standings .tor-std-table th:first-child,
  .tor-standings .tor-std-table td:first-child {
    position: sticky;
    left: 0;
    z-index: 3;
    background: #0f1720;
    min-width: 44px;
    max-width: 44px;
    text-align: center;
  }

  .tor-standings .tor-std-table th:nth-child(2),
  .tor-standings .tor-std-table td:nth-child(2) {
    position: sticky;
    left: 44px;
    z-index: 3;
    background: #0f1720;
    min-width: 180px;
    text-align: left;
  }

  .tor-standings .tor-std-table thead th:nth-child(2) {
    z-index: 5;
  }

  .tor-standings .tor-std-table tbody tr:nth-child(1) td:first-child {
    box-shadow: inset 3px 0 0 #f5c84c;
  }
  .tor-standings .tor-std-table tbody tr:nth-child(2) td:first-child {
    box-shadow: inset 3px 0 0 #41c1ff;
  }
  .tor-standings .tor-std-table tbody tr:nth-child(3) td:first-child {
    box-shadow: inset 3px 0 0 #d95cff;
  }
}
}

@layer sn.modules.torneos {

/* Keep standings as table on small mobile (avoid stacked cards for ranking view) */
}

@layer sn.modules.torneos {
@media (max-width: 520px) {
  .tor-standings .tor-std-table.tor-std-cardable thead {
    display: table-header-group !important;
  }
  .tor-standings .tor-std-table.tor-std-cardable,
  .tor-standings .tor-std-table.tor-std-cardable tbody,
  .tor-standings .tor-std-table.tor-std-cardable tr,
  .tor-standings .tor-std-table.tor-std-cardable td {
    width: auto !important;
  }
  .tor-standings .tor-std-table.tor-std-cardable {
    display: table !important;
  }
  .tor-standings .tor-std-table.tor-std-cardable tbody {
    display: table-row-group !important;
  }
  .tor-standings .tor-std-table.tor-std-cardable tr {
    display: table-row !important;
  }
  .tor-standings .tor-std-table.tor-std-cardable td {
    display: table-cell !important;
  }
  .tor-standings .tor-std-table.tor-std-cardable td {
    padding: 8px 10px !important;
  }
  .tor-standings .tor-std-table.tor-std-cardable td::before {
    content: none !important;
  }
}
}

@layer sn.modules.torneos {

/* ===== Unified Modals + Active Tabs (Tournament UI consistency) ===== */
html body .tor-res-modal,
html body .tor-std-modal,
html body .pw-modal {
  width: min(1120px, 96vw) !important;
  max-width: 1120px !important;
  border-radius: 14px !important;
}

html body .pw-modal.pw-wide {
  width: min(1120px, 96vw) !important;
  max-width: 1120px !important;
}

html body .tor-res-body,
html body .tor-std-body,
html body .pw-modal-body {
  overflow-y: auto !important;
  overflow-x: hidden !important;
}

/* torneos_denuncias: avoid horizontal slider in main table block */
html body .tor-denuncias .tor-std-table-wrap {
  overflow-x: hidden !important;
}

html body .tor-denuncias .tor-std-table {
  width: 100% !important;
  table-layout: fixed !important;
}

html body .tor-denuncias .tor-std-table th,
html body .tor-denuncias .tor-std-table td {
  white-space: normal !important;
  word-break: break-word !important;
  overflow-wrap: anywhere !important;
}
}

@layer sn.modules.torneos {
      .tor-cal-rally{background:linear-gradient(180deg,rgba(9,14,30,.88),rgba(6,10,24,.92));border:1px solid rgba(90,120,255,.22);border-radius:14px;padding:14px}
      .tor-cal-rally .tor-cal-rally-head{display:flex;flex-direction:column;gap:10px;margin-bottom:10px}
      .tor-cal-rally .tor-cal-rally-division-tabs,.tor-cal-rally .tor-cal-rally-event-tabs{display:flex;gap:8px;flex-wrap:wrap}
      .tor-cal-rally .tor-cal-rally-event-tabs{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));width:100%}
      .tor-cal-rally .tor-cal-rally-toolbar{display:flex;align-items:center;gap:8px;justify-content:space-between;margin-bottom:12px}
      .tor-cal-rally .tor-cal-rally-status{font-size:12px;opacity:.95;padding:6px 10px;border-radius:999px;background:rgba(22,30,56,.65);border:1px solid rgba(91,123,255,.28)}
      .tor-cal-rally .tor-rally-table-wrap{overflow:auto;border:1px solid rgba(91,123,255,.2);border-radius:12px;background:rgba(8,12,26,.78)}
      .tor-cal-rally .tor-rally-table{width:100%;min-width:860px;border-collapse:collapse}
      .tor-cal-rally .tor-rally-table thead th{background:rgba(24,36,72,.72);font-weight:700;letter-spacing:.02em}
      .tor-cal-rally .tor-rally-table th,.tor-cal-rally .tor-rally-table td{padding:9px 7px;border-bottom:1px solid rgba(255,255,255,.09);text-align:center;white-space:nowrap}
      .tor-cal-rally .tor-rally-table tbody tr:nth-child(even){background:rgba(255,255,255,.02)}
      .tor-cal-rally .tor-rally-pilot{display:flex;align-items:center;gap:8px;justify-content:flex-start;min-width:210px}
      .tor-cal-rally .tor-rally-pilot-meta{display:flex;flex-direction:column;align-items:flex-start;line-height:1.2}
      .tor-cal-rally .tor-rally-pilot-name{font-weight:600}
      .tor-cal-rally .tor-rally-pilot-car{font-size:11px;opacity:.75}
      .tor-cal-rally .tor-rally-avatar{width:26px;height:26px;border-radius:50%;-o-object-fit:cover;object-fit:cover;background:#0f1326;border:1px solid rgba(255,255,255,.18)}
      .tor-cal-rally .tor-rally-time{font-variant-numeric:tabular-nums;font-size:11px;opacity:.85}
      .tor-cal-rally .tor-rally-sub{display:block;font-size:10px;opacity:.65;margin-top:2px}
      .tor-cal-rally .tor-stage-head{display:flex;flex-direction:column;align-items:center;gap:4px}
      .tor-cal-rally .tor-stage-open{font-size:10px;padding:2px 6px;border-radius:999px;border:1px solid rgba(255,255,255,.2);background:rgba(255,255,255,.06);color:#dce6ff}
      .tor-cal-rally .tor-stage-cell{display:flex;flex-direction:column;align-items:center;line-height:1.1}
      .tor-cal-rally .tor-stage-cell .tor-pos{font-size:10px;font-weight:700}
      .tor-cal-rally .tor-stage-cell .tor-time{font-size:9px;opacity:.85}
      .tor-cal-rally .tor-stage-cell .tor-diff{font-size:9px;opacity:.7}
      .tor-cal-rally .tor-rally-toggle{display:flex;align-items:center;gap:8px;font-size:12px}
      .tor-cal-rally .tor-rally-toggle input{display:none}
      .tor-cal-rally .tor-rally-toggle-slider{position:relative;width:42px;height:22px;border-radius:999px;background:rgba(255,255,255,.2);border:1px solid rgba(255,255,255,.28)}
      .tor-cal-rally .tor-rally-toggle-slider:after{content:'';position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:#fff;transition:all .2s}
      .tor-cal-rally .tor-rally-mode-toggle:checked + .tor-rally-toggle-slider:after{left:22px}
      .tor-cal-rally .tor-rally-mode-toggle:checked + .tor-rally-toggle-slider{background:rgba(66,168,255,.45)}
      .tor-cal-rally .tor-stage-modal{position:fixed;inset:0;background:rgba(3,6,14,.7);display:none;align-items:center;justify-content:center;z-index:9999}
      .tor-cal-rally .tor-stage-modal.on{display:flex}
      .tor-cal-rally .tor-stage-modal-card{width:min(860px,94vw);max-height:84vh;overflow:auto;background:#0b1228;border:1px solid rgba(91,123,255,.35);border-radius:12px;padding:12px}
      .tor-cal-rally .tor-stage-modal-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
      .tor-cal-rally .tor-stage-modal-table{width:100%;border-collapse:collapse}
      .tor-cal-rally .tor-stage-modal-table th,.tor-cal-rally .tor-stage-modal-table td{padding:8px;border-bottom:1px solid rgba(255,255,255,.08);text-align:center}
      .tor-cal-rally .tor-stage-modal-table tr.tor-stage-row-finished{background:rgba(41,192,121,.06)}
      .tor-cal-rally .tor-stage-modal-table tr.tor-stage-row-running{background:rgba(77,163,255,.06)}
      .tor-cal-rally .tor-cal-rally-event-tabs .tor-reglamento-tab{border:1px solid rgba(255,255,255,.14)}
      .tor-cal-rally .tor-cal-rally-event-tabs .tor-reglamento-tab{width:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}
      .tor-cal-rally .tor-cal-rally-event-tabs .tor-rally-ev-title-wrap{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;width:100%}
      .tor-cal-rally .tor-cal-rally-event-tabs .tor-rally-ev-title{display:block;font-size:18px;font-weight:800;line-height:1.15}
      .tor-cal-rally .tor-cal-rally-event-tabs .tor-rally-ev-sub{display:block;font-size:11px;opacity:.88;margin-top:4px;line-height:1.1;min-height:14px}
      .tor-cal-rally .tor-cal-rally-event-tabs .tor-rally-ev-info{width:18px;height:18px;min-width:18px;border-radius:50%;border:1px solid rgba(255,255,255,.45);background:rgba(255,255,255,.12);color:#fff;font-size:11px;font-weight:700;line-height:1;display:inline-flex;align-items:center;justify-content:center}
      .tor-cal-rally .tor-rally-status-pill{display:inline-block;padding:2px 7px;border-radius:999px;font-size:11px;font-weight:700;margin-right:6px}
      .tor-cal-rally .tor-rally-status-encurso{background:rgba(29,189,112,.24);border:1px solid rgba(73,219,148,.46);color:#8cf4c0}
      .tor-cal-rally .tor-rally-status-proximo{background:rgba(50,108,255,.22);border:1px solid rgba(91,145,255,.46);color:#b9d0ff}
      .tor-cal-rally .tor-rally-status-finalizado{background:rgba(232,92,43,.24);border:1px solid rgba(255,145,97,.46);color:#ffc4aa}
      .tor-cal-rally .tor-cal-rally-event-tabs .tor-rally-ev--proximo{background:rgba(50,108,255,.16);border-color:rgba(91,145,255,.42)}
      .tor-cal-rally .tor-cal-rally-event-tabs .tor-rally-ev--encurso{background:rgba(29,189,112,.18);border-color:rgba(73,219,148,.46)}
      .tor-cal-rally .tor-cal-rally-event-tabs .tor-rally-ev--finalizado{background:rgba(232,92,43,.18);border-color:rgba(255,145,97,.46)}
      .tor-cal-rally .tor-cal-rally-event-tabs .tor-reglamento-tab.on{box-shadow:0 0 0 1px rgba(255,255,255,.22) inset}
      .tor-cal-rally .tor-stage-head{gap:1px}
      .tor-cal-rally .tor-stage-open{font-size:8px;padding:0 4px;line-height:1;margin-top:0;height:14px;min-height:14px;border-radius:9px;background:#c90d05;border-color:#c90d05;color:#fff}
      .tor-cal-rally .tor-pos-with-bar{display:inline-flex;align-items:center;gap:7px;font-weight:700}
      .tor-cal-rally .tor-pos-with-bar .tor-pos-bar{display:inline-block;width:4px;height:14px;border-radius:2px}
      .tor-cal-rally .tor-pos-with-bar.is-finished .tor-pos-bar{background:#29c079}
      .tor-cal-rally .tor-pos-with-bar.is-running .tor-pos-bar{background:#4da3ff}
      .tor-cal-rally .tor-pos-badge{display:inline-flex;align-items:center;gap:4px}
      .tor-cal-rally .tor-pos-badge.is-leader{color:#ffd24d;font-weight:800}
      .tor-cal-rally .tor-pos-crown{color:#ffd24d;font-size:10px;line-height:1}
      .tor-cal-rally .tor-stage-cell .tor-diff.is-plus{color:#69d7ff}
      .tor-cal-rally .tor-stage-cell .tor-diff.is-empty{color:rgba(255,255,255,.55)}
      .tor-cal-rally .tor-stage-modal-table td.is-plus{color:#69d7ff}
      .tor-cal-rally .tor-event-modal{position:fixed;inset:0;background:rgba(3,6,14,.7);display:none;align-items:center;justify-content:center;z-index:9999}
      .tor-cal-rally .tor-event-modal.on{display:flex}
      .tor-cal-rally .tor-event-modal-card{width:min(780px,94vw);max-height:84vh;overflow:auto;background:#0b1228;border:1px solid rgba(91,123,255,.35);border-radius:12px;padding:12px}
      .tor-cal-rally .tor-event-modal-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
      .tor-cal-rally .tor-event-meta{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:10px;font-size:13px}
      .tor-cal-rally .tor-event-stages-table{width:100%;border-collapse:collapse}
      .tor-cal-rally .tor-event-stages-table th,.tor-cal-rally .tor-event-stages-table td{padding:8px;border-bottom:1px solid rgba(255,255,255,.08);text-align:left}
      .tor-cal-rally .tor-rally-legend{display:flex;gap:12px;align-items:center;justify-content:flex-end;padding:8px 4px 2px;font-size:12px;opacity:.9}
}

@layer sn.modules.torneos {
      @media (max-width: 768px){
        .tor-cal-rally .tor-cal-rally-toolbar{flex-direction:column;align-items:flex-start}
        .tor-cal-rally .tor-rally-table{min-width:740px}
        .tor-cal-rally .tor-cal-rally-event-tabs .tor-rally-ev-title{font-size:14px}
      }
}

@layer sn.modules.cronovirtual {
.sn-cronovirtual {
  max-width: 960px;
  margin: 0 auto;
}
.sn-crono-banner {
  position: relative;
}
.sn-crono-banner img {
  width: 100%;
  height: auto;
  border-radius: 8px;
  display: block;
}
.sn-crono-operator {
  /* colocado debajo del banner */
  margin: 8px 0;
  display: flex;
  justify-content: center;
}
.sn-crono-col-index {
  width: 48px;
}
.sn-crono-header {
  text-align: center;
  margin: 8px 0 12px;
}
.sn-crono-title {
  margin: 8px 0 0;
  font-size: 20px;
}
.sn-crono-subtitle {
  margin: 4px 0 0;
  color: #fff;
  font-size: 14px;
  font-weight: 400;
}
.sn-crono-results {
  overflow-x: auto;
}
.sn-table {
  width: 100%;
  border-collapse: collapse;
}
.sn-table th,
.sn-table td {
  padding: 10px;
  border-bottom: 1px solid #eee;
  text-align: left;
}
.sn-table .sn-idx {
  width: 48px;
  text-align: right;
  color: #aaa;
}
.sn-table th {
  font-weight: 600;
}
.sn-loading,
.sn-empty,
.sn-error {
  text-align: center;
  color: #777;
  padding: 16px;
}
.sn-actions {
  white-space: nowrap;
}

/* Pager */
.sn-crono-pager {
  display: flex;
  gap: 8px;
  align-items: center;
  justify-content: center;
  padding: 10px 0;
}
.sn-page-indicator {
  color: #ccc;
  font-size: 12px;
}

/* Modal */
#sn-crono-modal .sn-modal__dialog {
  background: #121212;
  color: #f0f0f0;
  border-radius: 12px;
  width: min(520px, 92vw);
  max-height: 90vh;
}
#sn-crono-modal .sn-modal__header,
#sn-crono-modal .sn-modal__footer {
  border-color: #2a2a2a;
}
#sn-crono-modal .sn-modal__title {
  margin: 0;
  font-size: 18px;
  color: #fff;
}
#sn-crono-modal .sn-modal__body {
  padding: 12px 16px;
  color: #e0e0e0;
}
.sn-field {
  margin-bottom: 10px;
}
.sn-field label {
  display: block;
  margin-bottom: 4px;
  font-size: 13px;
  color: #ddd;
}
.sn-field input {
  width: 100%;
  padding: 10px;
  border: 1px solid #333;
  border-radius: 6px;
  background: #1e1e1e;
  color: #f5f5f5;
}
.sn-field input::-moz-placeholder {
  color: #9e9e9e;
}
.sn-field input::placeholder {
  color: #9e9e9e;
}
.sn-field input:focus {
  border-color: #c90d05;
  outline: none;
  box-shadow: 0 0 0 3px rgba(201, 13, 5, 0.2);
}
.sn-grid-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}
.sn-separator {
  text-align: center;
  color: #999;
  font-size: 12px;
  margin: 10px 0;
}
.sn-search-results {
  max-height: 160px;
  overflow: auto;
  border: 1px solid #2a2a2a;
  border-radius: 6px;
  background: #1a1a1a;
}
.sn-result-item {
  padding: 8px 10px;
  border-bottom: 1px solid #242424;
  cursor: pointer;
  color: #e0e0e0;
}
.sn-result-item.active {
  background: #263238;
}
.sn-r-name {
  font-weight: 600;
  color: #fff;
}
.sn-r-meta {
  color: #9e9e9e;
  font-size: 12px;
}
.sn-modal-footer {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  padding: 12px 16px;
  border-top: 1px solid #2a2a2a;
}
}

@layer sn.modules.cronovirtual {

@media (max-width: 480px) {
  .sn-crono-title {
    font-size: 18px;
  }
  .sn-crono-subtitle {
    font-size: 13px;
  }
  .sn-table th,
  .sn-table td {
    padding: 8px;
  }
}
}

/* 1. Base (Variables, Mixins, Resets, Typography) */

/* ==========================================================================
   Nitro Simracing - Base Variables
   ========================================================================== */

:root {
  /* Colors - Base */
  --sn-color-bg: #0a0c10;
  --sn-color-bg-alt: #13161c;
  --sn-color-surface: #1a1d24;
  --sn-color-surface-alt: #22262e;
  --sn-color-border: rgba(255, 255, 255, 0.08);
  --sn-color-border-light: rgba(255, 255, 255, 0.12);
  --sn-color-overlay: rgba(5, 7, 10, 0.85);

  /* Colors - Text */
  --sn-color-text: #ffffff;
  --sn-color-text-soft: #a0a5b0;
  --sn-color-text-faint: #6e737d;

  /* Colors - Brand (Premium Nitro) */
  --sn-theme-primary: #ff3b30;
  --sn-theme-primary-accent: #c90d05;
  --sn-theme-primary-hover: #ff5247;
  
  /* Gradientes */
  --sn-grad-theme: linear-gradient(135deg, var(--sn-theme-primary), var(--sn-theme-primary-accent));
  --sn-grad-surface: linear-gradient(180deg, var(--sn-color-surface), var(--sn-color-bg-alt));
  
  /* Colors - Status */
  --sn-success: #34c759;
  --sn-danger: #ff3b30;
  --sn-warning: #ff9f0a;
  --sn-info: #32ade6;
  --sn-muted: #6e737d;

  /* Typography */
  --sn-font-sans: 'Inter', system-ui, -apple-system, sans-serif;
  --sn-font-mono: 'JetBrains Mono', 'Fira Code', monospace;
  
  --sn-font-scale: 1;
  --sn-font-size-xs: calc(0.75rem * var(--sn-font-scale));
  --sn-font-size-sm: calc(0.875rem * var(--sn-font-scale));
  --sn-font-size: calc(1rem * var(--sn-font-scale));
  --sn-font-size-md: calc(1.125rem * var(--sn-font-scale));
  --sn-font-size-lg: calc(1.25rem * var(--sn-font-scale));
  --sn-font-size-xl: calc(1.5rem * var(--sn-font-scale));
  
  --sn-line-height: 1.5;

  /* Spacing (Mobile First) */
  --sn-space-1: 0.25rem; /* 4px */
  --sn-space-2: 0.5rem;  /* 8px */
  --sn-space-3: 0.75rem; /* 12px */
  --sn-space-4: 1rem;    /* 16px */
  --sn-space-5: 1.5rem;  /* 24px */
  --sn-space-6: 2rem;    /* 32px */
  --sn-space-8: 3rem;    /* 48px */
  
  /* Border Radius */
  --sn-radius-xs: 4px;
  --sn-radius-sm: 8px;
  --sn-radius: 12px;
  --sn-radius-lg: 16px;
  --sn-radius-xl: 24px;
  --sn-radius-pill: 9999px;
  --sn-radius-btn: 12px;
  
  /* Shadows (Premium Glass/Glow Effects) */
  --sn-shadow-sm: 0 2px 8px rgba(0, 0, 0, 0.4);
  --sn-shadow: 0 4px 16px rgba(0, 0, 0, 0.5);
  --sn-shadow-lg: 0 8px 32px rgba(0, 0, 0, 0.6);
  --sn-shadow-glow: 0 0 20px rgba(255, 59, 48, 0.4);
  
  /* Z-Index */
  --sn-z-dropdown: 4000;
  --sn-z-sticky: 4500;
  --sn-z-modal: 5000;
  --sn-z-toast: 5500;
  --sn-z-max: 9999;
  
  /* Glassmorphism helpers */
  --sn-glass-bg: rgba(26, 29, 36, 0.6);
  --sn-glass-border: rgba(255, 255, 255, 0.05);
}

/* Base resets relying on variables */

html {
  box-sizing: border-box;
}

*, *::before, *::after {
  box-sizing: inherit;
}

body {
  font-family: var(--sn-font-sans);
  color: var(--sn-color-text);
  background: var(--sn-color-bg);
  line-height: var(--sn-line-height);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* Utilities */

.sn-text-soft { color: var(--sn-color-text-soft) !important; }

.sn-text-faint { color: var(--sn-color-text-faint) !important; }

.sn-w-100 { width: 100% !important; }

.sn-hidden { display: none !important; }

.sn-relative { position: relative; }

.sn-pill { border-radius: var(--sn-radius-pill) !important; }

/* Custom Scrollbar */

.sn-scroll-thin {
  scrollbar-width: thin;
  scrollbar-color: var(--sn-color-border-light) transparent;
}

.sn-scroll-thin::-webkit-scrollbar {
  width: 6px;
  height: 6px;
}

.sn-scroll-thin::-webkit-scrollbar-track {
  background: transparent;
}

.sn-scroll-thin::-webkit-scrollbar-thumb {
  background: var(--sn-color-border-light);
  border-radius: var(--sn-radius-pill);
}

.sn-scroll-thin::-webkit-scrollbar-thumb:hover {
  background: var(--sn-color-text-soft);
}

/* ==========================================================================
   Nitro Simracing - Base Typography
   ========================================================================== */

h1, h2, h3, h4, h5, h6 {
  color: var(--sn-color-text);
  margin-top: 0;
  margin-bottom: var(--sn-space-4);
  font-weight: 700;
  line-height: 1.2;
}

h1 { font-size: var(--sn-font-size-xl); }

h2 { font-size: var(--sn-font-size-lg); }

h3 { font-size: var(--sn-font-size-md); }

h4 { font-size: var(--sn-font-size); }

h5 { font-size: var(--sn-font-size-sm); }

h6 { font-size: var(--sn-font-size-xs); }

p {
  margin-top: 0;
  margin-bottom: var(--sn-space-4);
}

a {
  color: var(--sn-theme-primary);
  text-decoration: none;
  transition: color 0.2s ease;
}

a:hover {
  color: var(--sn-theme-primary-hover);
  text-decoration: none;
}

code {
  font-family: var(--sn-font-mono);
  background: rgba(255, 255, 255, 0.08);
  padding: 0.2em 0.4em;
  border-radius: var(--sn-radius-xs);
  font-size: 0.875em;
  color: #9cdcfe;
}

/* ==========================================================================
   Nitro Simracing - Layout Utilities
   ========================================================================== */

.sn-flex {
  display: flex;
}

.sn-center {
  display: flex;
  align-items: center;
  justify-content: center;
}

.sn-gap-1 { gap: var(--sn-space-1); }

.sn-gap-2 { gap: var(--sn-space-2); }

.sn-gap-3 { gap: var(--sn-space-3); }

.sn-gap-4 { gap: var(--sn-space-4); }

.sn-mt-1 { margin-top: var(--sn-space-1); }

.sn-mt-2 { margin-top: var(--sn-space-2); }

.sn-mt-3 { margin-top: var(--sn-space-3); }

.sn-mt-4 { margin-top: var(--sn-space-4); }

.sn-mb-1 { margin-bottom: var(--sn-space-1); }

/* ==========================================================================
   Web App Mode Adjustments (Bypassing Woodmart Theme)
   ========================================================================== */

/* Remove any boxed padding/margin from body when in webapp mode */

body.sn-webapp-mode {
  background-color: var(--sn-color-bg) !important;
  color: var(--sn-color-text);
  overflow-x: hidden;
}

/* Make sure the main wrappers expand full width */

.sn-webapp-wrapper,
.sn-webapp-mode .sn-wrapper,
.sn-webapp-mode .tor-wrapper {
  max-width: 100% !important;
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
}

/* Ensure the top header covers the whole screen horizontally */

.sn-webapp-mode .sn-row-top,
.sn-webapp-mode .tor-header {
  max-width: 100% !important;
  border-radius: 0 !important;
  margin-top: 0 !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  border-left: none;
  border-right: none;
  border-top: none;
}

/* Main Content Area adjustments to give breathing room */

.sn-webapp-mode .sn-main,
.sn-webapp-mode .tor-grid {
  padding: var(--sn-space-4) var(--sn-space-4) !important;
  max-width: 1600px;
  margin: 0 auto;
}

@media (min-width: 1024px) {
  .sn-webapp-mode .sn-main,
  .sn-webapp-mode .tor-grid {
    padding: var(--sn-space-6) var(--sn-space-8) !important;
  }
}

/* Global Navbar Styling */

.sn-global-nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 var(--sn-space-5);
  height: 60px;
  background: rgba(10, 13, 18, 0.95);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-bottom: 1px solid rgba(255, 255, 255, 0.05);
  position: sticky;
  top: 0;
  z-index: 1000;
  box-shadow: var(--sn-shadow);
}

.sn-nav-brand a {
  display: flex;
  align-items: center;
  gap: var(--sn-space-3);
  font-weight: 900;
  font-size: 1.1rem;
  color: #fff;
  text-decoration: none;
  letter-spacing: 1px;
}

.sn-nav-brand i {
  color: var(--sn-theme-primary);
  font-size: 1.25rem;
}

.sn-nav-actions {
  display: flex;
  align-items: center;
  gap: var(--sn-space-3);
}

.sn-mb-2 { margin-bottom: var(--sn-space-2); }

.sn-mb-3 { margin-bottom: var(--sn-space-3); }

.sn-mb-4 { margin-bottom: var(--sn-space-4); }

/* Glassmorphism Surface Container */

.sn-surface {
  background: var(--sn-glass-bg);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid var(--sn-glass-border);
  border-radius: var(--sn-radius-lg);
  box-shadow: var(--sn-shadow);
}

/* 2. Components (Reusable UI elements) */

/* ==========================================================================
   Nitro Simracing - Button Components
   ========================================================================== */

.sn-btn {
  --_btn-bg: var(--sn-grad-theme);
  --_btn-bg-hover: linear-gradient(135deg, var(--sn-theme-primary-hover), var(--sn-theme-primary-accent));
  --_btn-color: #fff;
  --_btn-border: var(--sn-theme-primary-accent);
  
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--sn-space-2);
  
  font: 600 var(--sn-font-size)/1 var(--sn-font-sans);
  color: var(--_btn-color);
  background: var(--_btn-bg);
  border: 1px solid var(--_btn-border);
  border-radius: var(--sn-radius-btn);
  padding: 12px 20px;
  
  cursor: pointer;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
  text-decoration: none;
  
  box-shadow: 0 4px 12px rgba(201, 13, 5, 0.3);
  transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1);
  position: relative;
  overflow: hidden;
}

/* Glass Edge Highlight */

.sn-btn::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.4), transparent);
  opacity: 0.6;
}

.sn-btn:hover,
.sn-btn:focus {
  background: var(--_btn-bg-hover);
  transform: translateY(-2px);
  box-shadow: 0 6px 16px rgba(201, 13, 5, 0.5);
  outline: none;
}

.sn-btn:active {
  transform: translateY(1px);
  box-shadow: 0 2px 4px rgba(201, 13, 5, 0.3);
}

.sn-btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
  transform: none;
  box-shadow: none;
  filter: grayscale(0.5);
}

/* Button Variants */

.sn-btn--primary {
  /* Default handled by base btn class */
  color: #fff;
}

.sn-btn--outline {
  background: rgba(26, 29, 36, 0.6);
  backdrop-filter: blur(8px);
  --_btn-border: rgba(255, 59, 48, 0.5);
  color: var(--sn-theme-primary);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
}

.sn-btn--outline::after { display: none; }

.sn-btn--outline:hover {
  background: rgba(255, 59, 48, 0.1);
  border-color: var(--sn-theme-primary);
  box-shadow: 0 4px 12px rgba(255, 59, 48, 0.2);
}

.sn-btn--ghost {
  background: transparent;
  border-color: transparent;
  box-shadow: none;
  color: var(--sn-color-text-soft);
}

.sn-btn--ghost::after { display: none; }

.sn-btn--ghost:hover {
  background: rgba(255, 255, 255, 0.05);
  color: #fff;
  box-shadow: none;
}

/* Button Sizes */

.sn-btn--sm {
  padding: 8px 16px;
  font-size: var(--sn-font-size-sm);
  border-radius: var(--sn-radius-sm);
}

.sn-btn--xs {
  padding: 6px 12px;
  font-size: var(--sn-font-size-xs);
  border-radius: var(--sn-radius-xs);
}

.sn-btn--lg {
  padding: 16px 28px;
  font-size: var(--sn-font-size-md);
  border-radius: var(--sn-radius-lg);
}

/* Icon Buttons */

.sn-btn--icon {
  width: 44px;
  height: 44px;
  padding: 0;
  border-radius: var(--sn-radius-pill);
}

.sn-btn--icon.sn-btn--sm {
  width: 36px;
  height: 36px;
}

.sn-btn--icon svg {
  width: 20px;
  height: 20px;
}

.sn-btn--block {
  width: 100%;
}

/* ==========================================================================
   Nitro Simracing - Badge Components
   ========================================================================== */

.sn-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--sn-space-1);
  
  font: 600 var(--sn-font-size-sm)/1 var(--sn-font-sans);
  padding: 6px 12px;
  border-radius: var(--sn-radius-pill);
  
  background: rgba(255, 255, 255, 0.08);
  color: var(--sn-color-text);
  border: 1px solid rgba(255, 255, 255, 0.1);
  
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  
  letter-spacing: 0.02em;
  white-space: nowrap;
}

.sn-badge--xs {
  padding: 4px 8px;
  font-size: var(--sn-font-size-xs);
}

.sn-badge--lg {
  padding: 8px 16px;
  font-size: var(--sn-font-size);
}

/* Badge Variants */

.sn-badge--primary {
  background: rgba(255, 59, 48, 0.15);
  border-color: rgba(255, 59, 48, 0.3);
  color: #ff5247;
  text-shadow: 0 0 8px rgba(255, 59, 48, 0.4);
}

.sn-badge--success {
  background: rgba(52, 199, 89, 0.15);
  border-color: rgba(52, 199, 89, 0.3);
  color: #34c759;
}

.sn-badge--warning {
  background: rgba(255, 159, 10, 0.15);
  border-color: rgba(255, 159, 10, 0.3);
  color: #ff9f0a;
}

.sn-badge--danger {
  background: rgba(255, 69, 58, 0.15);
  border-color: rgba(255, 69, 58, 0.3);
  color: #ff453a;
}

.sn-badge--info {
  background: rgba(50, 173, 230, 0.15);
  border-color: rgba(50, 173, 230, 0.3);
  color: #32ade6;
}

/* Rank Badges */

.badge-principiante { background: rgba(108, 117, 125, 0.2); border-color: #6c757d; color: #ced4da; }

.badge-cobre { background: rgba(184, 115, 51, 0.2); border-color: #b87333; color: #ffc48c; }

.badge-bronce { background: rgba(205, 127, 50, 0.2); border-color: #cd7f32; color: #ffd1a3; }

.badge-plata { background: rgba(192, 192, 192, 0.2); border-color: #c0c0c0; color: #f8f9fa; }

.badge-oro { 
  background: rgba(255, 215, 0, 0.15); 
  border-color: rgba(255, 215, 0, 0.5); 
  color: #ffd700;
  text-shadow: 0 0 10px rgba(255, 215, 0, 0.4);
}

.badge-platino { 
  background: rgba(229, 228, 226, 0.15); 
  border-color: rgba(229, 228, 226, 0.5); 
  color: #e5e4e2;
  text-shadow: 0 0 10px rgba(229, 228, 226, 0.4);
}

.badge-diamante { 
  background: rgba(185, 242, 255, 0.15); 
  border-color: rgba(185, 242, 255, 0.5); 
  color: #b9f2ff;
  text-shadow: 0 0 10px rgba(185, 242, 255, 0.5);
}

.badge-elite { 
  background: rgba(75, 0, 130, 0.3); 
  border-color: #9d00ff; 
  color: #d896ff;
  text-shadow: 0 0 12px rgba(157, 0, 255, 0.6);
}

/* ==========================================================================
   Nitro Simracing - Form Input Components
   ========================================================================== */

.sn-input,
.sn-form input:not([type="checkbox"]):not([type="radio"]),
.sn-form select,
.sn-form textarea {
  background: rgba(0, 0, 0, 0.3);
  border: 1px solid var(--sn-color-border);
  border-radius: var(--sn-radius-sm);
  padding: 12px 16px;
  
  color: var(--sn-color-text);
  font: 400 var(--sn-font-size) var(--sn-font-sans);
  
  width: 100%;
  min-height: 48px;
  outline: none;
  
  transition: all 0.2s ease;
  box-shadow: inset 0 2px 4px rgba(0, 0, 0, 0.2);
}

.sn-input::-moz-placeholder, .sn-form input::-moz-placeholder, .sn-form textarea::-moz-placeholder {
  color: var(--sn-color-text-faint);
}

.sn-input::placeholder,
.sn-form input::placeholder,
.sn-form textarea::placeholder {
  color: var(--sn-color-text-faint);
}

.sn-input:focus,
.sn-form input:focus,
.sn-form select:focus,
.sn-form textarea:focus {
  background: rgba(0, 0, 0, 0.5);
  border-color: var(--sn-theme-primary);
  box-shadow: inset 0 2px 4px rgba(0, 0, 0, 0.2), 0 0 0 3px rgba(255, 59, 48, 0.15);
}

.sn-input:disabled,
.sn-form input:disabled,
.sn-form select:disabled,
.sn-form textarea:disabled {
  background: rgba(255, 255, 255, 0.02);
  color: var(--sn-color-text-faint);
  cursor: not-allowed;
  border-color: rgba(255, 255, 255, 0.05);
}

.sn-input--textarea,
.sn-form textarea {
  min-height: 120px;
  resize: vertical;
  line-height: 1.5;
}

/* Validation States */

.sn-form input:invalid:not(:-moz-placeholder) {
  border-color: var(--sn-danger);
}

.sn-input--error,
.sn-form input:invalid:not(:placeholder-shown) {
  border-color: var(--sn-danger);
}

.sn-form input:invalid:not(:-moz-placeholder):focus {
  box-shadow: inset 0 2px 4px rgba(0, 0, 0, 0.2), 0 0 0 3px rgba(255, 59, 48, 0.15);
}

.sn-input--error:focus,
.sn-form input:invalid:not(:placeholder-shown):focus {
  box-shadow: inset 0 2px 4px rgba(0, 0, 0, 0.2), 0 0 0 3px rgba(255, 59, 48, 0.15);
}

/* Select2 Customization overrides */

.select2-container .select2-selection--single {
  background: rgba(0, 0, 0, 0.3) !important;
  border: 1px solid var(--sn-color-border) !important;
  border-radius: var(--sn-radius-sm) !important;
  height: 48px !important;
  display: flex !important;
  align-items: center;
}

.select2-container--default .select2-selection--single .select2-selection__rendered {
  color: var(--sn-color-text) !important;
  padding-left: 16px !important;
  line-height: 46px !important;
}

.select2-container--default .select2-selection--single .select2-selection__arrow {
  height: 46px !important;
  right: 12px !important;
}

.select2-container--default .select2-selection--single .select2-selection__arrow b {
  border-color: var(--sn-color-text-soft) transparent transparent transparent !important;
}

.select2-container--default .select2-dropdown {
  background: var(--sn-color-surface-alt) !important;
  border: 1px solid var(--sn-color-border) !important;
  border-radius: var(--sn-radius-sm) !important;
  box-shadow: var(--sn-shadow-lg) !important;
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  overflow: hidden;
}

.select2-search--dropdown .select2-search__field {
  background: rgba(0, 0, 0, 0.3) !important;
  border: 1px solid var(--sn-color-border) !important;
  color: var(--sn-color-text) !important;
  border-radius: var(--sn-radius-sm) !important;
  padding: 8px 12px !important;
}

.select2-container--default .select2-results__option {
  color: var(--sn-color-text) !important;
  padding: 10px 16px !important;
}

.select2-container--default .select2-results__option--highlighted,
.select2-container--default .select2-results__option:hover {
  background: rgba(255, 59, 48, 0.15) !important;
  color: #fff !important;
}

.select2-container--default .select2-results__option[aria-selected=true] {
  background: rgba(255, 255, 255, 0.05) !important;
}

/* ==========================================================================
   Nitro Simracing - Modal Components
   ========================================================================== */

.sn-modal {
  position: fixed;
  inset: 0;
  z-index: var(--sn-z-modal);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--sn-space-4);
  
  background: var(--sn-color-overlay);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s ease;
}

.sn-modal.is-open {
  opacity: 1;
  pointer-events: auto;
}

.sn-modal__dialog {
  background: var(--sn-color-surface);
  border: 1px solid var(--sn-color-border);
  border-radius: var(--sn-radius-xl);
  
  width: 100%;
  max-width: 600px;
  max-height: 90vh;
  
  display: flex;
  flex-direction: column;
  overflow: hidden;
  
  box-shadow: var(--sn-shadow-lg);
  
  transform: scale(0.95) translateY(20px);
  opacity: 0;
  transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}

.sn-modal.is-open .sn-modal__dialog {
  transform: scale(1) translateY(0);
  opacity: 1;
}

.sn-modal__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--sn-space-4) var(--sn-space-5);
  background: rgba(255, 255, 255, 0.02);
  border-bottom: 1px solid var(--sn-color-border);
}

.sn-modal__title {
  margin: 0;
  font: 700 var(--sn-font-size-md)/1 var(--sn-font-sans);
  color: var(--sn-color-text);
  letter-spacing: -0.01em;
}

.sn-modal__close {
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid transparent;
  color: var(--sn-color-text-soft);
  
  width: 36px;
  height: 36px;
  border-radius: var(--sn-radius-pill);
  
  display: inline-flex;
  align-items: center;
  justify-content: center;
  
  font-size: 1.5rem;
  line-height: 1;
  cursor: pointer;
  transition: all 0.2s ease;
}

.sn-modal__close:hover {
  background: rgba(255, 59, 48, 0.15);
  color: #ff5247;
  border-color: rgba(255, 59, 48, 0.3);
  transform: rotate(90deg);
}

.sn-modal__body {
  flex: 1;
  overflow-y: auto;
  padding: var(--sn-space-5);
  
  font-size: var(--sn-font-size);
  color: var(--sn-color-text-soft);
  
  /* Use custom scrollbar from base */
  scrollbar-width: thin;
  scrollbar-color: var(--sn-color-border-light) transparent;
}

.sn-modal__body::-webkit-scrollbar { width: 6px; }

.sn-modal__body::-webkit-scrollbar-track { background: transparent; }

.sn-modal__body::-webkit-scrollbar-thumb { background: var(--sn-color-border-light); border-radius: var(--sn-radius-pill); }

.sn-modal__footer {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: var(--sn-space-3);
  padding: var(--sn-space-4) var(--sn-space-5);
  
  background: rgba(255, 255, 255, 0.02);
  border-top: 1px solid var(--sn-color-border);
}

/* Specific styling for the license modal (as seen in nitro-core.css) */

.sn-license-init-modal {
  background: rgba(5, 7, 10, 0.95);
  backdrop-filter: blur(16px);
}

.sn-license-init-modal__dialog {
  max-width: 640px;
  background: var(--sn-color-surface-alt);
  border: 1px solid rgba(255, 59, 48, 0.2);
  box-shadow: 0 0 40px rgba(201, 13, 5, 0.15);
}

/* Magnific Popup Overrides Native */

.mfp-bg {
  background: var(--sn-color-overlay) !important;
  backdrop-filter: blur(8px);
}

.mfp-content {
  width: min(600px, 92vw) !important;
  border-radius: var(--sn-radius-xl) !important;
  background: var(--sn-color-surface) !important;
  border: 1px solid var(--sn-color-border) !important;
  box-shadow: var(--sn-shadow-lg) !important;
  padding: 0 !important;
}

.mfp-close {
  top: 12px !important;
  right: 16px !important;
  width: 36px !important;
  height: 36px !important;
  background: rgba(255, 255, 255, 0.05) !important;
  border-radius: var(--sn-radius-pill) !important;
  color: var(--sn-color-text-soft) !important;
  opacity: 1 !important;
  transition: all 0.2s ease !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-family: var(--sn-font-sans) !important;
  font-size: 24px !important;
  line-height: 1 !important;
}

.mfp-close:hover {
  background: rgba(255, 59, 48, 0.15) !important;
  color: #ff5247 !important;
  transform: scale(1.05) !important;
}

/* 3. Modules (Complex widgets and specific layouts) */

/* ==========================================================================
   Nitro Simracing - Panel Modules
   ========================================================================== */

.sn-panel {
  background: var(--sn-glass-bg);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  
  border: 1px solid var(--sn-glass-border);
  border-radius: var(--sn-radius-xl);
  
  overflow: hidden;
  display: flex;
  flex-direction: column;
  
  box-shadow: var(--sn-shadow-lg);
  transition: all 0.3s ease;
}

.sn-panel:hover {
  border-color: rgba(255, 255, 255, 0.1);
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.7);
}

.sn-panel__header {
  padding: var(--sn-space-4) var(--sn-space-5);
  background: linear-gradient(180deg, rgba(255,255,255,0.03), transparent);
  border-bottom: 1px solid var(--sn-glass-border);
  
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sn-space-3);
}

.sn-panel__header h3 {
  margin: 0;
  font-size: var(--sn-font-size-md);
  color: var(--sn-color-text);
  font-weight: 600;
  letter-spacing: -0.01em;
}

.sn-panel__section {
  padding: var(--sn-space-5);
  border-bottom: 1px solid var(--sn-glass-border);
}

.sn-panel__section:last-child {
  border-bottom: none;
}

/* Sidebar Specific (tor-panel) */

.tor-panel {
  position: relative;
  z-index: 10;
}

@media (max-width: 991px) {
  .tor-panel {
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    width: 340px;
    max-width: 100vw;
    border-radius: 0;
    border-left: 1px solid var(--sn-glass-border);
    transform: translateX(100%);
    transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1);
    z-index: var(--sn-z-modal);
  }
  
  .tor-panel.is-open {
    transform: translateX(0);
  }
}

.tor-panel-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: var(--sn-color-overlay);
  backdrop-filter: blur(4px);
  z-index: calc(var(--sn-z-modal) - 1);
  opacity: 0;
  transition: opacity 0.3s ease;
}

.tor-panel-overlay.is-active {
  display: block;
  opacity: 1;
}

/* ==========================================================================
   Nitro Simracing - Card Modules
   ========================================================================== */

/* Modernized Woodmart product wrappers matching overall UI */

.products .product-wrapper,
.sn-card {
  background: linear-gradient(180deg, var(--sn-color-surface-alt) 0%, var(--sn-color-surface) 100%);
  border-radius: var(--sn-radius-xl);
  border: 1px solid var(--sn-glass-border);
  
  box-shadow: 
    0 0 0 1px rgba(255, 59, 48, 0.05),
    var(--sn-shadow);
    
  padding: var(--sn-space-4);
  transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1);
  position: relative;
  overflow: hidden;
  
  display: flex;
  flex-direction: column;
}

/* Base Neon Glow effect on hover */

.products .product-wrapper:hover,
.sn-card:hover {
  transform: translateY(-8px) scale(1.02);
  border-color: rgba(255, 59, 48, 0.3);
  box-shadow: 
    0 0 0 1px rgba(255, 59, 48, 0.5),
    0 20px 40px rgba(0, 0, 0, 0.8),
    0 0 30px rgba(255, 59, 48, 0.15);
  z-index: 2;
}

/* Subtle accent edge inside the card */

.products .product-wrapper::before,
.sn-card::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: calc(var(--sn-radius-xl) - 1px);
  background: linear-gradient(
    135deg,
    rgba(255, 255, 255, 0.08) 0%,
    transparent 40%,
    transparent 60%,
    rgba(255, 59, 48, 0.05) 100%
  );
  pointer-events: none;
  z-index: 1;
}

/* Images */

.products .product-image,
.sn-card__image {
  border-radius: var(--sn-radius-lg);
  overflow: hidden;
  background: #000;
  position: relative;
  margin-bottom: var(--sn-space-3);
  aspect-ratio: 16/9;
}

.products .product-image img,
.sn-card__image img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  transition: transform 0.6s cubic-bezier(0.16, 1, 0.3, 1);
}

.products .product-wrapper:hover .product-image img,
.sn-card:hover .sn-card__image img {
  transform: scale(1.08);
}

/* Typography internally */

.products .product-title a,
.sn-card__title {
  font-weight: 700;
  color: var(--sn-color-text);
  font-size: var(--sn-font-size-md);
  line-height: 1.3;
  margin-bottom: var(--sn-space-1);
  position: relative;
  z-index: 2;
  text-decoration: none;
}

.products .product-categories,
.sn-card__meta {
  color: var(--sn-theme-primary);
  font-size: var(--sn-font-size-xs);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-weight: 600;
  margin-bottom: var(--sn-space-2);
  position: relative;
  z-index: 2;
}

.products .price,
.sn-card__price {
  font-size: var(--sn-font-size-xl);
  font-weight: 800;
  color: #fff;
  margin-top: auto;
  position: relative;
  z-index: 2;
  display: flex;
  align-items: center;
  gap: 8px;
}

.products .price span.amount {
  color: var(--sn-theme-primary);
  text-shadow: 0 0 16px rgba(255, 59, 48, 0.6);
}

/* ==========================================================================
   Nitro Simracing - Menú Perfil Pilotos (Player Hub)
   ========================================================================== */

.sn-menu-perfil-pilotos {
  background: var(--sn-glass-bg);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid var(--sn-glass-border);
  border-radius: var(--sn-radius-xl);
  overflow: hidden;
  box-shadow: var(--sn-shadow-lg);
  margin-bottom: var(--sn-space-6);
}

.sn-menu-perfil-pilotos .sn-menu-wrap {
  position: relative;
  background: rgba(0, 0, 0, 0.4);
  border-bottom: 1px solid var(--sn-glass-border);
  display: flex;
  align-items: stretch;
}

/* Tabs Mobile First (Scrollable) */

.sn-menu-perfil-pilotos .sn-tabs {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  overflow-x: auto;
  overflow-y: hidden;
  scrollbar-width: none; /* Firefox */
  scroll-behavior: smooth;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  flex: 1;
}

.sn-menu-perfil-pilotos .sn-tabs::-webkit-scrollbar {
  display: none;
}

.sn-menu-perfil-pilotos .sn-tabs li {
  scroll-snap-align: start;
  flex: 0 0 auto;
}

.sn-menu-perfil-pilotos .sn-tabs a {
  display: flex;
  align-items: center;
  gap: var(--sn-space-2);
  padding: var(--sn-space-4) var(--sn-space-5);
  
  color: var(--sn-color-text-soft);
  font-weight: 600;
  font-size: var(--sn-font-size-md);
  text-decoration: none;
  
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  position: relative;
  white-space: nowrap;
  border-bottom: 2px solid transparent;
}

.sn-menu-perfil-pilotos .sn-tabs a i {
  font-size: 1.1em;
  color: var(--sn-color-text-faint);
  transition: color 0.3s;
}

/* Active & Hover States */

.sn-menu-perfil-pilotos .sn-tabs a:hover {
  color: var(--sn-color-text);
  background: rgba(255, 255, 255, 0.02);
}

.sn-menu-perfil-pilotos .sn-tabs a:hover i {
  color: var(--sn-theme-primary);
}

.sn-menu-perfil-pilotos .sn-tabs a.active {
  color: #fff;
  border-bottom-color: var(--sn-theme-primary);
  background: linear-gradient(0deg, rgba(201, 13, 5, 0.1) 0%, transparent 100%);
  text-shadow: 0 0 10px rgba(201, 13, 5, 0.5);
}

.sn-menu-perfil-pilotos .sn-tabs a.active i {
  color: var(--sn-theme-primary);
  filter: drop-shadow(0 0 8px rgba(201, 13, 5, 0.8));
}

/* Tab contents */

.sn-menu-perfil-pilotos .sn-tab-contents {
  padding: var(--sn-space-5) var(--sn-space-4);
}

.sn-menu-perfil-pilotos .sn-tab-content {
  display: none;
  animation: snFadeIn 0.3s ease-out;
}

@keyframes snFadeIn {
  from { opacity: 0; transform: translateY(5px); }
  to { opacity: 1; transform: translateY(0); }
}

/* Arrows para Desktop/Scroll largo */

.sn-menu-perfil-pilotos .sn-tab-arrows {
  display: none; /* Por defecto ocultas, habilitar vía JS si es necesario desborda, o mostrarlas en desktop */
  position: absolute;
  top: 0; 
  bottom: 0;
  left: 0; 
  right: 0;
  pointer-events: none;
  justify-content: space-between;
}

.sn-menu-perfil-pilotos .sn-tab-prev,
.sn-menu-perfil-pilotos .sn-tab-next {
  pointer-events: auto;
  border: none;
  background: var(--sn-glass-bg);
  color: var(--sn-color-text);
  width: 40px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.5rem;
  transition: background 0.2s, color 0.2s;
  z-index: 2;
  box-shadow: 0 0 15px rgba(0,0,0,0.5);
}

.sn-menu-perfil-pilotos .sn-tab-prev:hover,
.sn-menu-perfil-pilotos .sn-tab-next:hover {
  background: var(--sn-theme-primary);
  color: #fff;
}

@media (min-width: 992px) {
  .sn-menu-perfil-pilotos .sn-tab-prev,
  .sn-menu-perfil-pilotos .sn-tab-next {
    display: none; /* Rara vez es necesario en Desktop a menos que haya muchas pestañas */
  }
}

/* ==========================================================================
   Nitro Simracing - Menú Simuladores (Game Selector)
   ========================================================================== */

/* Modernizing the Simulator Menu List */

/* Hide the default Woodmart Header Text if it's placed in the same column */

.whb-general-header .wd-header-text.sn-menu-simuladores-stack > p {
  display: none !important;
}

/* Foolproof Reset: Strip ALL Woodmart inherited container styling */

.whb-general-header .wd-header-text.sn-menu-simuladores-stack,
.whb-general-header .wd-header-html:has(.menu-simuladores-nav),
.whb-general-header .wd-header-text:has(.menu-simuladores-nav),
.whb-column:has(.menu-simuladores-nav),
.wd-nav:has(.menu-simuladores-nav),
div:has(> .menu-simuladores-nav),
div:has(> div > .menu-simuladores-nav) {
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
}

.menu-simuladores-nav {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center !important;
  width: 100% !important;
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
}

/* Remove vertical dividers possibly injected by Woodmart pseudo-elements */

/* (User requested to keep these vertical lines, so this block is removed) */

.menu-simuladores-label {
  color: var(--sn-color-text-muted);
  font-size: 0.85rem;
  font-weight: 700;
  letter-spacing: 1px;
  text-transform: uppercase;
  flex-shrink: 0;
  margin-right: var(--sn-space-2);
}

.menu-simuladores-list {
  display: flex !important;
  flex-grow: 1;
  width: 100%;
  justify-content: center !important; /* Core centering parameter */
  align-items: center;
  list-style: none;
  margin: 0 auto !important;
  padding: 0;
  gap: 25px !important; /* Slightly more space between big logos */
}

/* Individual Game Items */

.menu-simuladores-item {
  position: relative;
  transition: all 0.3s cubic-bezier(0.16, 1, 0.3, 1);
  border-radius: var(--sn-radius);
  overflow: visible; 
  background: transparent !important;
  border: none !important;
  margin: 0 !important;
}

.menu-simuladores-item a {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  padding: 2px 10px !important;
  width: 100%;
  height: 100%;
  position: relative;
  z-index: 2;
  background: transparent !important;
  border: none !important;
}

.whb-general-header .menu-simuladores-nav .menu-simuladores-item picture,
.whb-general-header .menu-simuladores-nav .menu-simuladores-item img,
.menu-simuladores-item picture,
.menu-simuladores-item img {
  max-width: none !important; /* Completely remove max-width throttle to let height dictate scale */
  width: auto !important; 
  height: 30px !important; /* Lower height as requested */
  min-height: 30px !important; /* Force minimum */
  max-height: none !important; /* Unrestrict height limits from theme */
  display: block !important;
  -o-object-fit: contain !important;
     object-fit: contain !important; 
  transition: transform 0.4s ease, filter 0.4s ease;
  filter: none !important; /* PURE COLORS */
}

.menu-simuladores-item .sim-nombre {
  display: none; 
}

/* Hover & Active States - The "Game Selected" Effect */

.menu-simuladores-item:hover,
.menu-simuladores-item.active {
  border-color: rgba(255, 59, 48, 0.4) !important;
  background: linear-gradient(180deg, rgba(201, 13, 5, 0.05) 0%, rgba(201, 13, 5, 0.15) 100%) !important;
  box-shadow: 0 4px 16px rgba(255, 59, 48, 0.1);
  transform: translateY(-2px);
}

.menu-simuladores-item:hover picture,
.menu-simuladores-item.active picture,
.menu-simuladores-item:hover img,
.menu-simuladores-item.active img {
  filter: drop-shadow(0 0 8px rgba(255, 255, 255, 0.1)) !important;
  transform: scale(1.08); /* Bounce slightly on hover */
}

.menu-simuladores-item.active::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: var(--sn-theme-primary);
  box-shadow: 0 -2px 10px rgba(255, 59, 48, 0.6);
  z-index: 3;
}

/* Editor button (Filtrar) Dropdown */

.menu-simuladores-item.sim-edit-btn {
  background: transparent !important;
  border: none !important;
  border-radius: var(--sn-radius-md);
  position: absolute !important;
  right: 15px !important; /* Fix it hard to the right layer */
  top: 50% !important;
  transform: translateY(-50%) !important; /* Vertical center logic */
  z-index: 10;
  height: auto;
}

.sn-filter-dropdown-trigger {
  display: flex;
  height: 100%;
  align-items: center;
  justify-content: center;
  padding: 8px 16px;
  gap: 8px;
  color: #fff !important; /* Whiter, clearer text */
  font-size: 0.85rem;
  font-weight: 600;
  text-transform: uppercase;
  background: transparent !important;
  border: none !important;
  outline: none !important;
  box-shadow: none !important;
  cursor: pointer;
  transition: var(--sn-transition-fast);
}

.sn-filter-dropdown-trigger:hover,
.sn-filter-dropdown-trigger.active,
.sn-filter-dropdown-trigger:focus {
  background: rgba(255, 255, 255, 0.1) !important;
  color: #fff;
  border: none !important;
  outline: none !important;
  box-shadow: none !important;
}

/* Filtrar Dropdown Menu */

.sn-filter-dropdown-menu {
  position: absolute;
  top: calc(100% + var(--sn-space-2));
  right: 0;
  width: 280px;
  background: var(--sn-glass-bg);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid var(--sn-glass-border);
  border-radius: var(--sn-radius-lg);
  box-shadow: var(--sn-shadow-xl);
  opacity: 0;
  visibility: hidden;
  transform: translateY(10px);
  transition: all 0.3s cubic-bezier(0.16, 1, 0.3, 1);
  z-index: 9999; /* Very high to overlay everything below */
  overflow: hidden;
}

.sn-filter-dropdown-menu.active {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.sn-filter-header {
  padding: var(--sn-space-3);
  background: rgba(0, 0, 0, 0.3);
  border-bottom: 1px solid rgba(255, 255, 255, 0.05);
  text-align: center;
}

.sn-filter-header span {
  font-size: 0.75rem;
  font-weight: 700;
  color: var(--sn-color-text-muted);
  text-transform: uppercase;
  letter-spacing: 1px;
}

.sn-filter-list {
  max-height: 250px;
  overflow-y: auto;
  padding: var(--sn-space-2) 0;
}

/* Toggle Switches */

.sn-filter-toggle-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--sn-space-2) var(--sn-space-4);
  cursor: pointer;
  transition: background 0.2s;
}

.sn-filter-toggle-row:hover {
  background: rgba(255, 255, 255, 0.02);
}

.sn-filter-name {
  font-size: 0.9rem;
  font-weight: 500;
  color: var(--sn-color-text);
}

/* Switch UI */

.sn-toggle-switch {
  position: relative;
  display: inline-block;
  width: 36px;
  height: 20px;
}

.sn-toggle-switch input { 
  opacity: 0;
  width: 0;
  height: 0;
}

.sn-slider {
  position: absolute;
  cursor: pointer;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: rgba(255, 255, 255, 0.1);
  transition: .4s;
  border-radius: 20px;
}

.sn-slider:before {
  position: absolute;
  content: "";
  height: 16px;
  width: 16px;
  left: 2px;
  bottom: 2px;
  background-color: white;
  transition: .4s;
  border-radius: 50%;
}

input:checked + .sn-slider {
  background-color: var(--sn-theme-primary);
}

input:focus + .sn-slider {
  box-shadow: 0 0 1px var(--sn-theme-primary);
}

input:checked + .sn-slider:before {
  transform: translateX(16px);
}

input:disabled + .sn-slider {
  opacity: 0.5;
  cursor: not-allowed;
}

/* Footer link */

.sn-filter-footer {
  border-top: 1px solid rgba(255, 255, 255, 0.05);
  padding: 0;
}

.sn-filter-edit-link {
  display: block;
  text-align: center;
  padding: var(--sn-space-3);
  color: var(--sn-theme-primary);
  font-size: 0.85rem;
  font-weight: 600;
  text-decoration: none;
  background: rgba(0, 0, 0, 0.2);
  transition: background 0.2s, color 0.2s;
}

.sn-filter-edit-link:hover {
  background: rgba(201, 13, 5, 0.1);
  color: #fff;
}

/* Mobile Toggle Dropdown */

.menu-simuladores-nav .mobile-trigger {
  display: none;
}

@media (max-width: 991px) {
  .menu-simuladores-nav .mobile-trigger {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    padding: var(--sn-space-3) var(--sn-space-4);
    background: var(--sn-glass-bg);
    border: 1px solid var(--sn-glass-border);
    border-radius: var(--sn-radius-lg);
    color: var(--sn-color-text);
    font-weight: 600;
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    font-size: var(--sn-font-size-md);
  }

  .menu-simuladores-list {
    display: none; /* Hide by default on mobile, handled by JS normally */
    grid-template-columns: 1fr 1fr;
    gap: var(--sn-space-2);
    position: absolute;
    top: calc(100% + var(--sn-space-2));
    left: 0;
    right: 0;
    background: var(--sn-color-surface-alt);
    border: 1px solid var(--sn-color-border);
    border-radius: var(--sn-radius-lg);
    padding: var(--sn-space-2);
    box-shadow: var(--sn-shadow-lg);
  }
  
  .menu-simuladores-list.is-open {
    display: grid;
    animation: snSlideDown 0.3s cubic-bezier(0.16, 1, 0.3, 1);
  }

  .menu-simuladores-item {
    background: transparent;
    border: none;
  }
  
  /* Span the filter button across both columns */
  .menu-simuladores-item.sim-edit-btn {
    grid-column: 1 / -1; 
    margin-top: var(--sn-space-2);
    width: 100%;
    position: static;
    transform: none;
  }

  /* Make dropdown static in mobile list so it expands downwards */
  .sn-filter-dropdown-menu {
    position: static;
    width: 100%;
    box-shadow: none;
    border: none;
    background: rgba(0,0,0,0.2);
    margin-top: var(--sn-space-2);
    display: none;
  }
  
  .sn-filter-dropdown-menu.active {
    display: block;
    transform: none;
    opacity: 1;
    visibility: visible;
  }
}

@keyframes snSlideDown {
  from { opacity: 0; transform: translateY(-10px); }
  to { opacity: 1; transform: translateY(0); }
}

/* ==========================================================================
   Nitro Simracing - Banners Modulo
   ========================================================================== */

.sn-banners {
  position: relative;
  width: 100%;
  border-radius: var(--sn-radius-xl);
  overflow: hidden;
  margin-bottom: var(--sn-space-6); /* Spacing between banners */
  background: transparent;
  border: none;
  box-shadow: none;
}

@media (min-width: 1024px) {
  .sn-banners {
    margin-bottom: var(--sn-space-10);
  }
}

.sn-banners-viewport {
  width: 100%;
  height: auto; /* Let content dictate height */
  position: relative;
}

.sn-banners-track {
  display: flex;
  height: auto;
  width: 100%;
  transition: transform 0.6s cubic-bezier(0.25, 1, 0.5, 1);
}

.sn-banners-slide {
  flex: 0 0 100%;
  height: auto;
  position: relative;
}

.sn-banners-slide img {
  width: 100%;
  height: auto; /* Natural image height to avoid crop */
  -o-object-fit: cover;
     object-fit: cover;
  display: block;
}

/* Gradiente inferior para legibilidad de posible texto o indicadores */

.sn-banners-slide::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(0deg, rgba(0,0,0,0.6) 0%, transparent 40%);
  pointer-events: none;
}

/* Navigational Controls */

.sn-banners-nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  
  width: 48px;
  height: 48px;
  border-radius: 50%;
  
  background: rgba(10, 12, 16, 0.5);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border: 1px solid rgba(255, 255, 255, 0.1);
  color: #fff;
  
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.25rem;
  
  cursor: pointer;
  transition: all 0.3s ease;
  z-index: 10;
  
  opacity: 0; /* Hide by default, show on hover */
}

.sn-banners:hover .sn-banners-nav {
  opacity: 1;
}

.sn-banners-nav.prev {
  left: var(--sn-space-4);
}

.sn-banners-nav.next {
  right: var(--sn-space-4);
}

.sn-banners-nav:hover {
  background: rgba(255, 59, 48, 0.7);
  border-color: rgba(255, 59, 48, 0.9);
  box-shadow: 0 0 20px rgba(255, 59, 48, 0.4);
  transform: translateY(-50%) scale(1.1);
}

.sn-banners-nav:active {
  transform: translateY(-50%) scale(0.95);
}

/* Paginación (Puntos) si se agregan en el futuro */

.sn-banners-pagination {
  position: absolute;
  bottom: var(--sn-space-3);
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  gap: 8px;
  z-index: 10;
}

.sn-banners-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: rgba(255,255,255,0.3);
  cursor: pointer;
  transition: all 0.3s ease;
}

.sn-banners-dot.active {
  background: var(--sn-theme-primary);
  box-shadow: 0 0 8px rgba(255, 59, 48, 0.8);
  transform: scale(1.3);
}

/* ==========================================================================
   Nitro Simracing - Tournaments List & Grid
   ========================================================================== */

/* Layout & Typography */

.sn-torneos-listado {
  margin: var(--sn-space-4) 0;
  padding: 0 var(--sn-space-4); /* Lateral margin for mobile */
}

@media (min-width: 768px) {
  .sn-torneos-listado {
    padding: 0; /* Reset for desktop as parent container handles it */
  }
}

.sn-tl-heading {
  display: flex;
  align-items: center;
  gap: var(--sn-space-4);
  font-size: var(--sn-font-size-xl);
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  color: #fff;
  margin-bottom: var(--sn-space-7);
  padding: var(--sn-space-3) var(--sn-space-5);
  border-left: 4px solid var(--sn-theme-primary);
  background: linear-gradient(90deg, rgba(255, 59, 48, 0.12) 0%, transparent 100%);
  position: relative;
  overflow: hidden;
  box-shadow: -10px 0 30px rgba(255, 59, 48, 0.1);
}

.sn-tl-heading::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 1px;
  background: linear-gradient(90deg, rgba(255, 255, 255, 0.15) 0%, transparent 100%);
}

.sn-tl-heading i {
  color: #fff;
  filter: drop-shadow(0 0 8px rgba(255, 59, 48, 0.8));
  font-size: 1.25rem;
}

.sn-tl-heading.is-finalizados {
  border-color: #a0a5b0;
  background: linear-gradient(90deg, rgba(160, 165, 176, 0.12) 0%, transparent 100%);
  box-shadow: -10px 0 30px rgba(160, 165, 176, 0.05);
}

.sn-tl-heading.is-finalizados i {
  filter: drop-shadow(0 0 8px rgba(255, 255, 255, 0.3));
}

.sn-tl-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 400px), 1fr));
  gap: var(--sn-space-6);
  margin-bottom: var(--sn-space-10);
}

@media (min-width: 1400px) {
  .sn-tl-grid {
    grid-template-columns: repeat(auto-fit, minmax(450px, 1fr));
  }
}

/* Specific Card Layout for Tournaments */

.sn-torneo-card {
  display: flex !important;
  flex-direction: column !important; /* Stacked by default for mobile */
  background: linear-gradient(180deg, var(--sn-color-surface-alt) 0%, var(--sn-color-surface) 100%);
  border: 1px solid var(--sn-color-border);
  border-radius: var(--sn-radius-xl);
  overflow: hidden;
  position: relative;
  transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1);
  box-shadow: var(--sn-shadow);
  text-decoration: none;
  color: inherit;
  outline: none;
  min-height: 200px;
}

/* Horizontal layout for cards on larger screens */

@media (min-width: 768px) {
  .sn-tl-grid .sn-torneo-card,
  .sn-tl-slider .sn-torneo-card {
    display: grid !important;
    grid-template-columns: 42% 58% !important; /* Forces horizontal: Image left, Info right */
    align-items: stretch !important;
    min-height: 230px;
  }
}

/* Glow Effect En Fichas de Torneo */

.sn-torneo-card:hover,
.sn-torneo-card:focus-within {
  transform: translateY(-8px) scale(1.02);
  border-color: rgba(255, 59, 48, 0.4);
  box-shadow: 
    0 0 0 1px rgba(255, 59, 48, 0.5),
    0 24px 48px rgba(0, 0, 0, 0.9),
    0 0 30px rgba(255, 59, 48, 0.15);
  z-index: 2;
}

.sn-torneo-card::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: calc(var(--sn-radius-xl) - 1px);
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.08) 0%, transparent 40%, transparent 60%, rgba(255, 59, 48, 0.05) 100%);
  pointer-events: none;
  z-index: 1;
}

/* Ficha Imagen y Logo Superpuesto */

.sn-tl-grid .sn-card-media {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9; /* Mobile aspect ratio */
  background: #000;
  overflow: hidden;
  border-bottom: 1px solid rgba(255,255,255,0.05);
}

@media (min-width: 768px) {
  .sn-card-media {
    aspect-ratio: auto !important;
    height: 100% !important;
    border-bottom: none !important;
    border-right: 1px solid rgba(255,255,255,0.05) !important;
  }
}

.sn-card-img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  transition: transform 0.6s cubic-bezier(0.16, 1, 0.3, 1);
  filter: brightness(0.9);
}

.sn-torneo-card:hover .sn-card-img,
.sn-torneo-card:focus-within .sn-card-img {
  transform: scale(1.08); /* Cinematic Zoom */
  filter: brightness(1.1);
}

.sn-card-media::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(0deg, var(--sn-color-surface) 0%, transparent 60%);
  pointer-events: none;
}

@media (min-width: 768px) {
  .sn-card-media::after {
    background: linear-gradient(270deg, var(--sn-color-surface) 0%, transparent 60%);
  }
}

.sn-sim-logo {
  position: absolute;
  top: var(--sn-space-3);
  right: var(--sn-space-3);
  max-width: 100px;
  max-height: 40px;
  -o-object-fit: contain;
     object-fit: contain;
  filter: drop-shadow(0 2px 8px rgba(0, 0, 0, 0.8));
  z-index: 2;
}

/* Ficha Cuerpo y Contenido */

.sn-card-body {
  padding: var(--sn-space-4);
  display: flex;
  flex-direction: column;
  flex: 1;
  position: relative;
  z-index: 2;
}

.sn-card-title {
  font-size: var(--sn-font-size-md);
  font-weight: 800;
  color: #fff;
  margin: 0 0 var(--sn-space-2) 0;
  line-height: 1.3;
}

.sn-card-desc {
  color: var(--sn-color-text-soft);
  font-size: var(--sn-font-size-sm);
  line-height: 1.5;
  margin-bottom: var(--sn-space-4);
  
  display: -webkit-box;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.sn-card-tags {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sn-space-2);
  margin-bottom: var(--sn-space-4);
}

.sn-tag {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  border-radius: var(--sn-radius-sm);
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.5px;
  text-transform: uppercase;
}

.sn-tag-mod {
  background: rgba(255, 255, 255, 0.05);
  color: var(--sn-color-text-soft);
  border: 1px solid rgba(255,255,255,0.1);
}

.sn-tag-estado {
  background: rgba(52, 199, 89, 0.15); /* Verde por defecto para activos */
  color: #34c759;
  border: 1px solid rgba(52, 199, 89, 0.3);
}

/* Slider for Finished Tournaments */

.sn-tl-slider {
  position: relative;
  margin-bottom: var(--sn-space-8);
}

.wd-carousel-wrap {
  display: flex !important; /* Ensure it's always flex for swiper */
}

.sn-tl-slider .wd-carousel-item {
  height: auto;
  display: flex;
}

.sn-tl-slider .sn-torneo-card {
  width: 100% !important;
}

/* Arrows Navigation for Swiper */

.sn-tl-slider .wd-carousel-inner {
  position: static;
}

.sn-tl-slider .wd-btn-arrow {
  background-color: var(--sn-color-surface-alt);
  border: 1px solid var(--sn-color-border);
  color: #fff;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  transition: all 0.3s ease;
  z-index: 10;
}

.sn-tl-slider .wd-btn-arrow:hover {
  background-color: var(--sn-theme-primary);
  border-color: var(--sn-theme-primary);
  transform: scale(1.1);
  box-shadow: 0 0 15px rgba(255, 59, 48, 0.4);
}

/* Fichas finalizadas: Subtler grayscale */

.sn-torneo-card.is-finalizado {
  filter: grayscale(0.6);
  opacity: 0.9;
}

.sn-torneo-card.is-finalizado:hover {
  filter: grayscale(0.2);
  opacity: 1;
}

.sn-torneo-card.is-finalizado .sn-tag-estado {
  background: rgba(255, 255, 255, 0.1);
  color: #a0a5b0;
  border-color: rgba(255, 255, 255, 0.2);
}

.sn-card-cost {
  margin-top: auto;
  font-size: var(--sn-font-size);
  font-weight: 800;
  color: #fff;
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: var(--sn-space-4);
  padding-top: var(--sn-space-4);
  border-top: 1px solid rgba(255, 255, 255, 0.05);
}

.sn-card-cost i {
  color: var(--sn-theme-primary);
}

.sn-card-actions .sn-btn {
  width: 100%;
}

/* ==========================================================================
   User Profile Dropdown (Top Navbar)
   ========================================================================== */

.sn-user-dropdown-container {
  position: relative;
  display: inline-block;
  z-index: 9000 !important;
}

/* Trigger Button */

.sn-user-dropdown-trigger {
  display: flex;
  align-items: center;
  gap: var(--sn-space-2);
  background: transparent;
  border: none;
  color: var(--sn-color-text);
  cursor: pointer;
  padding: var(--sn-space-1) var(--sn-space-2);
  border-radius: var(--sn-radius-md);
  transition: var(--sn-transition-fast);
}

.sn-user-dropdown-trigger:hover,
.sn-user-dropdown-trigger.active {
  background: rgba(255, 255, 255, 0.05);
}

.sn-avatar-small {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  -o-object-fit: cover;
     object-fit: cover;
  border: 1px solid rgba(255, 255, 255, 0.1);
}

.sn-username {
  font-size: 0.95rem;
  font-weight: 500;
  color: var(--sn-color-text);
}

.sn-caret {
  font-size: 0.8rem;
  color: var(--sn-color-text-muted);
  transition: transform 0.2s ease;
}

.sn-user-dropdown-trigger.active .sn-caret {
  transform: rotate(180deg);
}

/* Dropdown Menu Box */

.sn-user-dropdown-menu {
  position: absolute;
  top: calc(100% + 15px);
  right: 0;
  width: 240px;
  background: var(--sn-color-surface); /* Very dark solid/glass mix */
  backdrop-filter: blur(15px);
  -webkit-backdrop-filter: blur(15px);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: var(--sn-radius-lg);
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.5);
  opacity: 0;
  visibility: hidden;
  transform: translateY(-10px);
  transition: all 0.3s cubic-bezier(0.2, 0.8, 0.2, 1);
  z-index: 99999 !important; /* Max out the dropdown itself */
  overflow: hidden;
}

.sn-user-dropdown-menu.active {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

/* Header Area (Large Avatar) */

.sn-user-menu-header {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.05) 0%, rgba(0, 0, 0, 0) 100%);
  padding: var(--sn-space-4) 0 var(--sn-space-2) 0;
  display: flex;
  justify-content: center;
  position: relative;
  border-bottom: 1px solid rgba(255, 255, 255, 0.02);
}

.sn-avatar-large-wrapper {
  position: relative;
  display: inline-block;
}

.sn-avatar-large {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  -o-object-fit: cover;
     object-fit: cover;
  border: 2px solid rgba(255, 255, 255, 0.1);
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.4);
}

.sn-initials-badge {
  position: absolute;
  bottom: 0;
  right: -5px;
  background: #333640;
  color: #fff;
  font-size: 0.7rem;
  font-weight: 700;
  padding: 2px 6px;
  border-radius: 12px;
  border: 2px solid var(--sn-color-surface);
  letter-spacing: 0.5px;
}

/* Links List */

.sn-user-links {
  list-style: none;
  padding: var(--sn-space-2) 0;
  margin: 0;
  display: flex;
  flex-direction: column;
}

.sn-user-links li {
  margin: 0;
  padding: 0;
}

.sn-user-links a {
  display: flex;
  align-items: center;
  gap: var(--sn-space-3);
  padding: var(--sn-space-2) var(--sn-space-4);
  color: var(--sn-color-text);
  font-size: 0.95rem;
  font-weight: 500;
  text-decoration: none;
  transition: var(--sn-transition-fast);
}

.sn-user-links a i {
  color: var(--sn-color-text-muted);
  font-size: 1rem;
  width: 20px;
  text-align: center;
  transition: var(--sn-transition-fast);
}

.sn-user-links a:hover {
  background: rgba(255, 255, 255, 0.04);
  color: #fff;
}

.sn-user-links a:hover i {
  color: var(--sn-theme-primary);
}

/* Divider */

.sn-user-menu-divider {
  height: 1px;
  background: rgba(255, 255, 255, 0.05);
  margin: var(--sn-space-2) 0;
}

/* Tabs Area */

.sn-user-menu-tabs {
  display: flex;
  background: rgba(0, 0, 0, 0.2);
  border-bottom: 1px solid rgba(255, 255, 255, 0.05);
}

.sn-user-tab-btn {
  flex: 1;
  background: transparent;
  border: none;
  color: var(--sn-color-text-muted);
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1px;
  padding: var(--sn-space-3) 0;
  cursor: pointer;
  transition: var(--sn-transition-fast);
  border-bottom: 2px solid transparent;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--sn-space-2);
}

.sn-user-tab-btn:hover {
  color: #fff;
  background: rgba(255, 255, 255, 0.02);
}

.sn-user-tab-btn.active {
  color: var(--sn-theme-primary);
  border-bottom-color: var(--sn-theme-primary);
  background: rgba(255, 255, 255, 0.05);
}

.sn-user-tab-content {
  display: none;
  animation: snFadeIn 0.2s ease forwards;
}

.sn-user-tab-content.active {
  display: block;
}

/* Animations */

@keyframes snFadeIn {
  from { opacity: 0; transform: translateY(-5px); }
  to { opacity: 1; transform: translateY(0); }
}

/* Footer Button */

.sn-user-menu-footer {
  border-top: 1px solid rgba(255, 255, 255, 0.05);
}

.sn-logout-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--sn-space-3);
  padding: var(--sn-space-3) var(--sn-space-4);
  color: var(--sn-color-text-muted);
  font-size: 0.95rem;
  font-weight: 500;
  text-decoration: none;
  transition: var(--sn-transition-fast);
  background: rgba(0, 0, 0, 0.2);
}

.sn-logout-btn:hover {
  background: rgba(229, 9, 20, 0.1); /* Subtle red for logout */
  color: #fff;
}

.sn-logout-btn i {
  font-size: 1rem;
}

.sn-sim-dashboard {
  --sn-sim-surface: linear-gradient(180deg, rgba(11, 15, 24, 0.94), rgba(6, 9, 16, 0.98));
  --sn-sim-border: rgba(255, 255, 255, 0.08);
  --sn-sim-border-strong: rgba(255, 255, 255, 0.14);
  --sn-sim-glow: rgba(201, 13, 5, 0.22);
  --sn-sim-shadow: 0 24px 60px rgba(0, 0, 0, 0.42);
  display: grid;
  gap: clamp(16px, 2vw, 28px);
  width: min(1440px, calc(100% - 24px));
  margin: 0 auto;
  padding: clamp(12px, 1.6vw, 24px) 0 clamp(30px, 3vw, 48px);
}

.sn-sim-selector-wrap {
  position: sticky;
  top: 0;
  z-index: 30;
  padding: 10px 0 0;
  background:
    linear-gradient(180deg, rgba(8, 11, 18, 0.96), rgba(8, 11, 18, 0.72) 70%, transparent);
  backdrop-filter: blur(16px);
}

.sn-sim-selector {
  display: flex;
  align-items: center;
  gap: 18px;
  overflow-x: auto;
  padding: 14px 18px;
  border: 1px solid var(--sn-sim-border);
  border-radius: 20px;
  background:
    linear-gradient(180deg, rgba(13, 17, 27, 0.96), rgba(8, 10, 18, 0.92));
  box-shadow: var(--sn-sim-shadow);
  scrollbar-width: none;
}

.sn-sim-selector::-webkit-scrollbar {
  display: none;
}

.sn-sim-logo-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 86px;
  min-height: 52px;
  padding: 10px 16px;
  border: 1px solid transparent;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.02);
  opacity: 0.58;
  filter: grayscale(1);
  transition:
    opacity 180ms ease,
    filter 180ms ease,
    border-color 180ms ease,
    background 180ms ease,
    transform 180ms ease;
}

.sn-sim-logo-btn:hover,
.sn-sim-logo-btn.active {
  opacity: 1;
  filter: grayscale(0);
  transform: translateY(-1px);
  border-color: rgba(255, 255, 255, 0.12);
  background: rgba(255, 255, 255, 0.06);
}

.sn-sim-logo-btn img {
  width: auto;
  height: 24px;
  -o-object-fit: contain;
     object-fit: contain;
}

.sn-sim-logo-btn span {
  color: #f6f8ff;
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.sn-sim-filter-btn {
  display: none;
}

.sn-sim-heading-bar {
  display: flex;
  align-items: center;
  min-height: 84px;
  padding: 18px 22px;
  border: 1px solid var(--sn-sim-border);
  border-radius: 22px;
  background:
    linear-gradient(180deg, rgba(10, 14, 24, 0.98), rgba(7, 10, 18, 0.96));
  box-shadow: var(--sn-sim-shadow);
}

.sn-sim-heading-bar__logo {
  width: auto;
  max-width: min(100%, 340px);
  max-height: 42px;
  -o-object-fit: contain;
     object-fit: contain;
}

.sn-sim-heading-bar__text {
  color: #f8f9ff;
  font-size: 1.1rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.sn-sim-hero {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  align-items: stretch;
  overflow: hidden;
  min-height: clamp(140px, 18vw, 210px);
  border: 1px solid var(--sn-sim-border-strong);
  border-radius: 28px;
  background:
    radial-gradient(circle at top right, rgba(201, 13, 5, 0.14), transparent 34%),
    radial-gradient(circle at left center, rgba(255, 255, 255, 0.03), transparent 42%),
    linear-gradient(135deg, rgba(7, 11, 18, 0.98), rgba(8, 12, 21, 0.94));
  box-shadow: var(--sn-sim-shadow);
  isolation: isolate;
}

.sn-sim-hero__content,
.sn-sim-hero__brand {
  position: relative;
  z-index: 1;
}

.sn-sim-hero__content {
  display: grid;
  align-content: center;
  gap: 10px;
  padding: clamp(18px, 2.4vw, 26px);
}

.sn-sim-hero__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  width: -moz-fit-content;
  width: fit-content;
  padding: 8px 12px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.05);
  color: rgba(255, 255, 255, 0.75);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.sn-sim-hero__title {
  margin: 0;
  color: #f7f8fc;
  font-family: "Oswald", "Bebas Neue", sans-serif;
  font-size: clamp(1.5rem, 3vw, 2.4rem);
  line-height: 0.98;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  text-wrap: balance;
}

.sn-sim-hero__title-logo {
  width: min(100%, 320px);
  max-height: 56px;
  -o-object-fit: contain;
     object-fit: contain;
  filter: drop-shadow(0 12px 24px rgba(0, 0, 0, 0.34));
}

.sn-sim-hero__name {
  margin: 0;
  color: #ffffff;
  font-size: 0.92rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.sn-sim-hero__summary {
  max-width: 62ch;
  margin: 0;
  color: rgba(241, 244, 252, 0.82);
  font-size: clamp(0.86rem, 1vw, 0.98rem);
  line-height: 1.45;
}

.sn-sim-hero__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.sn-sim-hero__pill {
  display: inline-flex;
  align-items: center;
  min-height: 40px;
  padding: 0 14px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 999px;
  background: rgba(8, 11, 18, 0.52);
  color: #eef2ff;
  font-size: 0.84rem;
  font-weight: 700;
}

.sn-dashboard-shell {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 340px);
  gap: clamp(18px, 2vw, 26px);
  align-items: start;
}

.sn-dashboard-primary {
  display: grid;
  gap: 16px;
  min-width: 0;
}

.sn-dashboard-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  padding: 10px;
  border: 1px solid var(--sn-sim-border);
  border-radius: 22px;
  background:
    linear-gradient(180deg, rgba(11, 15, 24, 0.95), rgba(7, 9, 17, 0.94));
  box-shadow: var(--sn-sim-shadow);
}

.sn-tab-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  min-height: 52px;
  padding: 0 18px;
  border: 1px solid transparent;
  border-radius: 15px;
  background: transparent;
  color: rgba(232, 237, 248, 0.72);
  font-size: 0.96rem;
  font-weight: 700;
  transition:
    color 180ms ease,
    border-color 180ms ease,
    background 180ms ease,
    transform 180ms ease;
}

.sn-tab-btn i,
.sn-tab-btn svg {
  font-size: 0.95em;
}

.sn-tab-btn:hover,
.sn-tab-btn.active {
  color: #fff;
  transform: translateY(-1px);
}

.sn-tab-btn.active {
  border-color: rgba(255, 255, 255, 0.1);
  background:
    linear-gradient(180deg, rgba(201, 13, 5, 0.9), rgba(127, 13, 9, 0.82));
  box-shadow: 0 14px 26px rgba(201, 13, 5, 0.22);
}

.sn-content {
  min-width: 0;
  padding: clamp(16px, 1.8vw, 24px);
  border: 1px solid var(--sn-sim-border);
  border-radius: 28px;
  background: var(--sn-sim-surface);
  box-shadow: var(--sn-sim-shadow);
}

.tor-sc-wrap {
  width: 100%;
}

.sn-content-placeholder {
  display: grid;
  place-items: center;
  min-height: 260px;
  padding: 32px 24px;
  border: 1px dashed rgba(255, 255, 255, 0.12);
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.02);
  text-align: center;
}

.sn-content-placeholder h3 {
  margin: 0 0 8px;
  color: #fff;
  font-size: 1.3rem;
}

.sn-content-placeholder p {
  margin: 0;
  color: rgba(255, 255, 255, 0.72);
}

.sn-dashboard-sidebar {
  position: sticky;
  top: 92px;
}

.sn-sim-chat-panel {
  display: grid;
  gap: 0;
  overflow: hidden;
  border: 1px solid var(--sn-sim-border);
  border-radius: 24px;
  background:
    radial-gradient(circle at top right, rgba(201, 13, 5, 0.16), transparent 26%),
    linear-gradient(180deg, rgba(13, 17, 27, 0.98), rgba(8, 11, 18, 0.98));
  box-shadow: var(--sn-sim-shadow);
}

.sn-sim-chat-panel__header {
  display: grid;
  gap: 8px;
  padding: 20px 20px 16px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.sn-sim-chat-panel__eyebrow {
  color: rgba(255, 255, 255, 0.56);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.sn-sim-chat-panel__header h2 {
  margin: 0;
  color: #fff;
  font-size: 1.35rem;
  line-height: 1.1;
}

.sn-sim-chat-panel__header p {
  margin: 0;
  color: rgba(255, 255, 255, 0.7);
  font-size: 0.92rem;
  line-height: 1.5;
}

.sn-sim-chat-panel__body {
  padding: 0 14px 14px;
}

.sn-chat-item {
  min-width: 0;
}

.sn-sim-chat-panel .sn-chat-item + .sn-chat-item {
  margin-top: 14px;
}

.sn-sim-chat-panel .sn-chat-panel-instance,
.sn-sim-chat-panel .nitro-chat-container {
  min-height: 540px;
  border: 0;
  border-radius: 18px;
  background:
    linear-gradient(180deg, rgba(8, 11, 18, 0.7), rgba(8, 11, 18, 0.96));
  box-shadow: none;
}

.sn-sim-chat-panel .chat-header {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 12px;
  padding: 14px 16px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.05), rgba(255, 255, 255, 0.02));
}

.sn-sim-chat-panel .chat-header__main {
  display: grid;
  gap: 4px;
  min-width: 0;
}

.sn-sim-chat-panel .chat-header h4 {
  color: #fff;
  font-size: 0.98rem;
  letter-spacing: 0;
  margin: 0;
}

.sn-sim-chat-panel .chat-header__status {
  color: rgba(255, 255, 255, 0.56);
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.sn-sim-chat-panel .chat-users-count {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 7px 11px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.04);
  color: rgba(255, 255, 255, 0.8);
  font-size: 0.74rem;
  font-weight: 700;
}

.sn-sim-chat-panel .chat-users-count::before {
  content: "";
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: #ff4d43;
  box-shadow: 0 0 12px rgba(255, 77, 67, 0.65);
}

.sn-sim-chat-panel .chat-control-btn {
  width: 36px;
  height: 36px;
  border-radius: 12px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(255, 255, 255, 0.04);
}

.sn-sim-chat-panel .chat-messages,
.sn-sim-chat-panel [id^="chat-messages-"] {
  padding: 12px;
  gap: 8px;
  background:
    linear-gradient(180deg, rgba(4, 6, 10, 0), rgba(4, 6, 10, 0.35));
}

.sn-sim-chat-panel .chat-message {
  gap: 10px;
  padding: 9px 10px;
  border-radius: 14px;
  border: 1px solid rgba(255, 255, 255, 0.06);
  background: rgba(255, 255, 255, 0.05);
}

.sn-sim-chat-panel .chat-message.my-message {
  background: linear-gradient(135deg, rgba(201, 13, 5, 0.32), rgba(144, 22, 17, 0.22));
  border-color: rgba(201, 13, 5, 0.28);
}

.sn-sim-chat-panel .message-avatar img {
  width: 38px;
  height: 38px;
  border: 1px solid rgba(255, 255, 255, 0.08);
}

.sn-sim-chat-panel .message-author {
  color: #fff;
  font-size: 0.84rem;
  font-weight: 700;
}

.sn-sim-chat-panel .message-content {
  color: rgba(245, 247, 252, 0.9);
  font-size: 0.84rem;
  line-height: 1.4;
}

.sn-sim-chat-panel .message-time {
  color: rgba(255, 255, 255, 0.52);
  font-size: 0.72rem;
}

.sn-sim-chat-panel .chat-input-container {
  padding: 12px;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(255, 255, 255, 0.03);
}

.sn-sim-chat-panel .chat-input-row {
  gap: 10px;
}

.sn-sim-chat-panel .chat-message-input,
.sn-sim-chat-panel [id^="chat-message-input-"] {
  min-height: 42px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 14px;
  background: rgba(6, 9, 15, 0.9);
  color: #fff;
}

.sn-sim-chat-panel .chat-message-input::-moz-placeholder, .sn-sim-chat-panel [id^="chat-message-input-"]::-moz-placeholder {
  color: rgba(255, 255, 255, 0.42);
}

.sn-sim-chat-panel .chat-message-input::placeholder,
.sn-sim-chat-panel [id^="chat-message-input-"]::placeholder {
  color: rgba(255, 255, 255, 0.42);
}

.sn-sim-chat-panel .emoji-toggle {
  width: 42px;
  min-width: 42px;
  height: 42px;
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.06);
}

.sn-sim-chat-panel .chat-send-btn,
.sn-sim-chat-panel .send-message {
  min-width: 92px;
  min-height: 42px;
  padding-inline: 18px;
  border-radius: 14px;
}

.sn-sim-sidebar-ad {
  display: grid;
  gap: 10px;
  margin-top: 16px;
  padding: 18px;
  border: 1px solid var(--sn-sim-border);
  border-radius: 22px;
  background:
    radial-gradient(circle at top right, rgba(201, 13, 5, 0.18), transparent 36%),
    linear-gradient(180deg, rgba(13, 17, 27, 0.98), rgba(8, 11, 18, 0.98));
  box-shadow: var(--sn-sim-shadow);
}

.sn-sim-sidebar-ad__eyebrow {
  color: rgba(255, 255, 255, 0.56);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.sn-sim-sidebar-ad h3 {
  margin: 0;
  color: #fff;
  font-size: 1.2rem;
}

.sn-sim-sidebar-ad p {
  margin: 0;
  color: rgba(255, 255, 255, 0.72);
  font-size: 0.9rem;
  line-height: 1.5;
}

.sn-sim-sidebar-ad .sn-btn {
  width: 100%;
  justify-content: center;
}

.sn-sim-bottom-banner[hidden] {
  display: none !important;
}

@media (max-width: 1180px) {
  .sn-dashboard-shell {
    grid-template-columns: minmax(0, 1fr) 320px;
  }
}

@media (max-width: 991px) {
  .sn-sim-dashboard {
    width: min(100%, calc(100% - 12px));
    padding-bottom: 92px;
  }

  .sn-sim-selector-wrap {
    top: 0;
    padding-top: 0;
  }

  .sn-sim-hero {
    min-height: 160px;
  }

  .sn-dashboard-shell {
    grid-template-columns: 1fr;
  }

  .sn-dashboard-sidebar {
    display: none;
  }

  .sn-dashboard-tabs {
    flex-wrap: nowrap;
    overflow-x: auto;
    scrollbar-width: none;
  }

  .sn-dashboard-tabs::-webkit-scrollbar {
    display: none;
  }
}

@media (max-width: 640px) {
  .sn-sim-heading-bar {
    min-height: 70px;
    padding: 14px 16px;
  }

  .sn-sim-heading-bar__logo {
    max-height: 34px;
  }

  .sn-sim-selector {
    padding: 10px 12px;
    gap: 12px;
  }

  .sn-sim-logo-btn {
    min-width: 76px;
    min-height: 46px;
    padding: 8px 12px;
  }

  .sn-sim-hero {
    border-radius: 22px;
  }

  .sn-sim-hero__content {
    padding: 18px 16px;
  }

  .sn-sim-hero__title-logo {
    max-height: 44px;
  }

  .sn-dashboard-tabs {
    padding: 8px;
    gap: 8px;
    border-radius: 18px;
  }

  .sn-tab-btn {
    min-height: 46px;
    padding: 0 14px;
    font-size: 0.88rem;
  }

  .sn-content {
    padding: 14px;
    border-radius: 22px;
  }
}
