/* ══════════════════════════════════════════════════════════
   QUINIELA 2026 — Design System v2
   Apple · Stripe · Linear · Notion
   Loaded last — overrides estilo.css & wc-premium.css
   ══════════════════════════════════════════════════════════ */

/* ─── DESIGN TOKENS ────────────────────────────────────── */
:root {
  --ds-bg:        #05050b;
  --ds-surface:   #0d0d1a;
  --ds-s2:        #111120;
  --ds-border:    rgba(255, 255, 255, 0.07);
  --ds-border-h:  rgba(34, 197, 94, 0.28);
  --ds-text:      #f0f0f5;
  --ds-muted:     #6b7280;
  --ds-subtle:    #374151;
  --ds-green:     #22c55e;
  --ds-green-d:   rgba(34, 197, 94, 0.12);
  --ds-green-g:   rgba(34, 197, 94, 0.22);
  --ds-gold:      #f59e0b;
  --ds-nav-h:     60px;
  --ds-bn-h:      76px;
  --ds-max:       1200px;
  --ds-pad:       clamp(1rem, 4vw, 2rem);
  --ds-r:         12px;
  --ds-rl:        18px;
}

/* ─── CONTENT OFFSET (solo páginas app autenticadas) ───── */
.wc-page--app .wc-content,
.wc-page--unified .wc-content {
  position: relative;
  z-index: 1;
  padding-top: var(--ds-nav-h);
}
@media (max-width: 768px) {
  .wc-page--app .wc-content,
  .wc-page--unified .wc-content {
    padding-bottom: var(--ds-bn-h);
  }
}

/* ══════════════════════════════════════════════════════════
   APP NAV — Top bar
   ══════════════════════════════════════════════════════════ */
.app-nav {
  position: fixed;
  top: 0; left: 0; right: 0;
  height: var(--ds-nav-h);
  z-index: 1000;
  background: rgba(5, 5, 11, 0.78);
  backdrop-filter: blur(22px) saturate(1.6);
  -webkit-backdrop-filter: blur(22px) saturate(1.6);
  border-bottom: 1px solid var(--ds-border);
}
.app-nav__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  height: 100%;
  max-width: var(--ds-max);
  margin: 0 auto;
  padding: 0 var(--ds-pad);
}

/* Brand */
.app-nav__brand {
  display: flex;
  align-items: center;
  gap: 0.55rem;
  text-decoration: none;
  flex-shrink: 0;
}
.app-nav__brand img {
  height: 30px;
  width: auto;
  object-fit: contain;
  filter: drop-shadow(0 0 8px var(--ds-green-g));
  transition: filter 0.2s;
}
.app-nav__brand:hover img {
  filter: drop-shadow(0 0 16px rgba(34,197,94,.4));
}
.app-nav__brand-name {
  font-family: 'Anybody', sans-serif;
  font-style: italic;
  font-weight: 800;
  font-size: 0.92rem;
  letter-spacing: -0.01em;
  text-transform: uppercase;
  color: var(--ds-text);
  white-space: nowrap;
}

/* Desktop nav links */
.app-nav__links {
  display: flex;
  align-items: center;
  gap: 0.15rem;
  flex: 1;
  justify-content: center;
}
@media (max-width: 768px) { .app-nav__links { display: none; } }

.app-nav__link {
  display: inline-flex;
  align-items: center;
  padding: 0.4rem 0.85rem;
  border-radius: 7px;
  font-family: 'Hanken Grotesk', sans-serif;
  font-size: 0.85rem;
  font-weight: 500;
  color: var(--ds-muted);
  text-decoration: none;
  white-space: nowrap;
  transition: color 0.15s, background 0.15s;
}
.app-nav__link:hover {
  color: var(--ds-text);
  background: rgba(255,255,255,.05);
}
.app-nav__link--active {
  color: var(--ds-green) !important;
  background: var(--ds-green-d) !important;
}
.app-nav__link--active:hover {
  background: rgba(34,197,94,.18) !important;
}

/* Right side */
.app-nav__right {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  flex-shrink: 0;
}
.app-nav__pts {
  display: flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.32rem 0.7rem;
  border-radius: 7px;
  background: var(--ds-green-d);
  border: 1px solid rgba(34,197,94,.15);
  font-family: 'Anybody', sans-serif;
  font-style: italic;
  font-weight: 800;
  font-size: 0.82rem;
  color: var(--ds-green);
  white-space: nowrap;
  transition: background 0.2s, border-color 0.2s;
}
.app-nav__pts:hover {
  background: rgba(34,197,94,.18);
  border-color: rgba(34,197,94,.28);
}
.app-nav__pts .material-symbols-outlined { font-size: 14px; }
@media (max-width: 500px) {
  .app-nav__pts { font-size: 0.72rem; padding: 0.25rem 0.45rem; gap: 0.25rem; }
}

.app-nav__avatar {
  width: 33px; height: 33px;
  border-radius: 50%;
  background: rgba(34,197,94,.1);
  border: 1.5px solid rgba(34,197,94,.28);
  display: flex; align-items: center; justify-content: center;
  font-family: 'Hanken Grotesk', sans-serif;
  font-weight: 700; font-size: 0.72rem;
  color: var(--ds-green);
  cursor: default;
  user-select: none;
  transition: border-color 0.2s, box-shadow 0.2s;
  flex-shrink: 0;
}
.app-nav__avatar:hover {
  border-color: var(--ds-green);
  box-shadow: 0 0 14px var(--ds-green-g);
}

.app-nav__logout {
  font-family: 'Hanken Grotesk', sans-serif;
  font-size: 0.8rem;
  color: var(--ds-muted);
  text-decoration: none;
  padding: 0.3rem 0.5rem;
  border-radius: 6px;
  transition: color 0.15s, background 0.15s;
  white-space: nowrap;
}
.app-nav__logout:hover {
  color: var(--ds-text);
  background: rgba(255,255,255,.05);
}
@media (max-width: 480px) {
  .app-nav__logout { font-size: 0.72rem; padding: 0.25rem 0.4rem; }
  .app-nav__right { gap: 0.35rem; }
}
@media (max-width: 390px) {
  .app-nav__brand-name { display: none; }
}

/* Screen-reader only */
.app-sr-only {
  position: absolute;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden;
  clip: rect(0,0,0,0);
  white-space: nowrap;
  border: 0;
}

/* ══════════════════════════════════════════════════════════
   BOTTOM NAV — Mobile
   ══════════════════════════════════════════════════════════ */
.app-bn {
  position: fixed;
  bottom: 0; left: 0; right: 0;
  z-index: 1000;
  background: rgba(5, 5, 11, 0.9);
  backdrop-filter: blur(24px) saturate(1.5);
  -webkit-backdrop-filter: blur(24px) saturate(1.5);
  border-top: 1px solid var(--ds-border);
  padding-bottom: env(safe-area-inset-bottom, 0px);
  display: none;
}
@media (max-width: 768px) { .app-bn { display: block; } }

.app-bn__inner {
  display: flex;
  align-items: stretch;
  justify-content: space-around;
  height: 58px;
  padding: 0 0.25rem;
}
.app-bn__item {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.18rem;
  flex: 1;
  padding: 0.4rem 0.25rem 0.3rem;
  text-decoration: none;
  color: var(--ds-muted);
  transition: color 0.15s;
  position: relative;
  -webkit-tap-highlight-color: transparent;
}
.app-bn__item:active { transform: scale(0.9); }
.app-bn__item--active { color: var(--ds-green); }

.app-bn__dot {
  position: absolute;
  top: 0; left: 50%;
  transform: translateX(-50%);
  width: 22px; height: 2px;
  border-radius: 0 0 2px 2px;
  background: var(--ds-green);
  box-shadow: 0 0 8px var(--ds-green-g);
  opacity: 0;
  transition: opacity 0.2s;
}
.app-bn__item--active .app-bn__dot { opacity: 1; }

.app-bn__icon {
  font-size: 1.3rem;
  line-height: 1;
  transition: transform 0.2s;
}
.app-bn__item--active .app-bn__icon { transform: scale(1.15); }

.app-bn__label {
  font-family: 'Hanken Grotesk', sans-serif;
  font-size: 0.58rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  line-height: 1;
}

/* ══════════════════════════════════════════════════════════
   GLOBAL CARD REFRESH
   ══════════════════════════════════════════════════════════ */
.bento-card {
  background: rgba(13, 13, 26, 0.82) !important;
  border: 1px solid var(--ds-border) !important;
  border-radius: 14px !important;
  backdrop-filter: blur(14px);
  transition: border-color 0.2s, box-shadow 0.2s, transform 0.2s !important;
}
.bento-card:hover {
  border-color: var(--ds-border-h) !important;
  box-shadow: 0 0 0 1px rgba(34,197,94,.1) !important;
}

/* ── Input fields — global consistency ── */
input[type="text"]:not(.no-ds),
input[type="password"]:not(.no-ds),
input[type="number"]:not(.no-ds),
select:not(.no-ds) {
  background: rgba(255,255,255,.04) !important;
  border-color: rgba(255,255,255,.09) !important;
  color: var(--ds-text) !important;
  transition: border-color 0.2s, box-shadow 0.2s !important;
}
input[type="text"]:focus:not(.no-ds),
input[type="password"]:focus:not(.no-ds),
input[type="number"]:focus:not(.no-ds),
select:focus:not(.no-ds) {
  border-color: rgba(34,197,94,.4) !important;
  box-shadow: 0 0 0 3px rgba(34,197,94,.1) !important;
  outline: none !important;
}

/* ── Buttons — primary green ── */
.quin-btn-primary,
button[class*="bg-primary"]:not(.no-ds) {
  box-shadow: 0 0 20px rgba(34,197,94,.2) !important;
  transition: transform 0.15s, box-shadow 0.15s, filter 0.15s !important;
}
.quin-btn-primary:hover,
button[class*="bg-primary"]:hover:not(.no-ds) {
  box-shadow: 0 0 32px rgba(34,197,94,.35) !important;
  filter: brightness(1.06) !important;
}
.quin-btn-primary:active,
button[class*="bg-primary"]:active:not(.no-ds) {
  transform: scale(0.97) !important;
}

/* ══════════════════════════════════════════════════════════
   SCROLL ANIMATIONS — Fluidas
   ══════════════════════════════════════════════════════════ */

/* Spring easing tokens */
:root {
  --ease-spring:  cubic-bezier(0.16, 1, 0.3, 1);    /* ease-out expo */
  --ease-back:    cubic-bezier(0.34, 1.56, 0.64, 1); /* spring ligero */
  --ease-smooth:  cubic-bezier(0.25, 0.46, 0.45, 0.94);
  --dur-fast:     0.45s;
  --dur-base:     0.65s;
  --dur-slow:     0.9s;
}

@media (prefers-reduced-motion: no-preference) {

  /* ── Base: fade + slide up + blur ── */
  [data-reveal] {
    opacity: 0;
    transform: translateY(28px);
    filter: blur(4px);
    will-change: opacity, transform, filter;
    transition:
      opacity   var(--dur-base)   var(--ease-spring),
      transform var(--dur-base)   var(--ease-spring),
      filter    var(--dur-fast)   var(--ease-smooth);
  }

  /* Directions */
  [data-reveal="left"]  { transform: translateX(36px); }
  [data-reveal="right"] { transform: translateX(-36px); }
  [data-reveal="down"]  { transform: translateY(-24px); }
  [data-reveal="scale"] { transform: scale(0.86); filter: blur(6px); }
  [data-reveal="pop"]   { transform: scale(0.9) translateY(16px); filter: blur(3px); }
  [data-reveal="flip"]  {
    transform: perspective(700px) rotateX(12deg) translateY(24px);
    filter: blur(3px);
  }

  /* ── Visible ── */
  [data-reveal].ds-visible {
    opacity: 1;
    transform: none;
    filter: none;
  }

  /* ── Duration variants ── */
  [data-reveal-dur="fast"] {
    transition-duration: var(--dur-fast), var(--dur-fast), 0.3s;
  }
  [data-reveal-dur="slow"] {
    transition-duration: var(--dur-slow), var(--dur-slow), 0.5s;
  }

  /* ── Delay variants (1–6) ── */
  [data-reveal-d="1"] { transition-delay: 0.07s; }
  [data-reveal-d="2"] { transition-delay: 0.14s; }
  [data-reveal-d="3"] { transition-delay: 0.22s; }
  [data-reveal-d="4"] { transition-delay: 0.30s; }
  [data-reveal-d="5"] { transition-delay: 0.40s; }
  [data-reveal-d="6"] { transition-delay: 0.52s; }

  /* ── Stagger parent ── */
  [data-stagger] > * {
    opacity: 0;
    transform: translateY(20px);
    filter: blur(3px);
    will-change: opacity, transform, filter;
    transition:
      opacity   0.55s var(--ease-spring),
      transform 0.55s var(--ease-spring),
      filter    0.35s var(--ease-smooth);
  }
  [data-stagger].ds-visible > *:nth-child(1)  { transition-delay: 0.04s; }
  [data-stagger].ds-visible > *:nth-child(2)  { transition-delay: 0.10s; }
  [data-stagger].ds-visible > *:nth-child(3)  { transition-delay: 0.17s; }
  [data-stagger].ds-visible > *:nth-child(4)  { transition-delay: 0.24s; }
  [data-stagger].ds-visible > *:nth-child(5)  { transition-delay: 0.31s; }
  [data-stagger].ds-visible > *:nth-child(6)  { transition-delay: 0.38s; }
  [data-stagger].ds-visible > *:nth-child(n+7){ transition-delay: 0.46s; }
  [data-stagger].ds-visible > * {
    opacity: 1;
    transform: none;
    filter: none;
  }

  /* ── Parallax containers ── */
  [data-parallax] {
    will-change: transform;
    transition: transform 0.1s linear;
  }

  /* ── Line draw (border-bottom animate) ── */
  [data-line] {
    position: relative;
    overflow: hidden;
  }
  [data-line]::after {
    content: '';
    position: absolute;
    bottom: 0; left: 0;
    height: 1px;
    width: 100%;
    background: var(--ds-green);
    transform: scaleX(0);
    transform-origin: left;
    transition: transform 0.7s var(--ease-spring);
  }
  [data-line].ds-visible::after { transform: scaleX(1); }

  /* ── Number counter ── */
  [data-count] {
    transition: color 0.3s;
  }

}

/* Reduced motion fallback — snap to visible instantly */
@media (prefers-reduced-motion: reduce) {
  [data-reveal], [data-stagger] > * {
    opacity: 1 !important;
    transform: none !important;
    filter: none !important;
    transition: none !important;
  }
}

/* ══════════════════════════════════════════════════════════
   POLISH
   ══════════════════════════════════════════════════════════ */
::-webkit-scrollbar { width: 5px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb {
  background: rgba(255,255,255,.09);
  border-radius: 3px;
}
::-webkit-scrollbar-thumb:hover { background: rgba(34,197,94,.28); }

::selection { background: rgba(34,197,94,.22); color: var(--ds-text); }

:focus-visible {
  outline: 2px solid var(--ds-green);
  outline-offset: 3px;
  border-radius: 4px;
}

/* ══════════════════════════════════════════════════════════
   RANKING TABLE — columnas siempre (sin conflicto Tailwind)
   ══════════════════════════════════════════════════════════ */
.rk-col-pos { padding-inline: 1rem; }   /* desktop default */
.rk-col-name { padding-inline: 1rem; }
.rk-col-pts  { padding-inline: 1rem; }

@media (max-width: 640px) {
  /* Pos: compacto, sin padding-inline de Tailwind */
  .rk-col-pos {
    padding-inline: 0.65rem 0.25rem;
    width: 1%;
    white-space: nowrap;
  }

  /* Nombre: espacio libre, gap reducido */
  .rk-col-name {
    padding-inline: 0.25rem 0.4rem;
  }

  /* Puntos: compacto a la derecha */
  .rk-col-pts {
    padding-inline: 0.15rem 0.65rem;
    width: 1%;
    white-space: nowrap;
    font-size: 0.82rem;
  }

  /* Avatar: oculto en móvil (ahorra ~52px entre pos y nombre) */
  .rk-avatar { display: none; }

  /* Flex container del nombre: sin gap extra */
  .rk-col-name > div {
    gap: 0.3rem;
    min-width: 0;
  }

  /* Nombre: truncado */
  .quin-rank-name {
    display: block;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: calc(100vw - 130px);
    font-size: 0.85rem;
  }

  /* Badge "Tú" */
  .quin-rank-badge {
    flex-shrink: 0;
    font-size: 9px;
    padding: 0.1rem 0.35rem;
  }
}
