/* ============================================================================
   SodaCity · app.css — sistema de diseño único de la web
   Fuente de verdad para tokens, layout, sidebar y componentes compartidos.
   Cada página solo añade su CSS específico. NO redefinir :root en las páginas.
   ============================================================================ */

/* ── Reset ── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

/* ── Tokens ──────────────────────────────────────────────────────────────── */
:root {
  /* Paleta de marca — synthwave rose / hot pink / peach */
  --mauve:  #D37B9C;
  --coral:  #FC8AB0;
  --peach:  #FCBE9E;
  --accent: var(--mauve);          /* alias semántico del acento */
  --purple: var(--mauve);          /* aliases heredados que usa el render viejo */
  --pink:   var(--coral);

  /* Estados (un único valor canónico, sin drift entre páginas) */
  --cyan:   #5ec9d6;
  --green:  #4ade80;
  --yellow: #fbbf24;
  --red:    #fb7185;

  /* Texto */
  --text:   #F6D7A8;
  --muted:  #E4A8D4;
  --faint:  #8D6079;

  /* Tipografía */
  --sans: 'Inter', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  --mono: 'JetBrains Mono', ui-monospace, SFMono-Regular, Menlo, monospace;

  /* Liquid Glass (con mesura: solo sidebar y cards principales) */
  --glass:        rgba(255,255,255,.055);
  --glass-strong: rgba(255,255,255,.09);
  --glass-border: rgba(255,255,255,.14);
  --glass-hi:     rgba(255,255,255,.18);
  --shadow:       0 18px 50px rgba(0,0,0,.45);

  /* Escala de radios / espaciado (consistencia => sensación "hecho a mano") */
  --radius:    22px;
  --radius-sm: 13px;
  --side-w:    244px;

  /* Alturas de chrome */
  --bottombar-h: 68px;
}

html { scroll-behavior: smooth; }

body {
  font-family: var(--sans);
  color: var(--text);
  min-height: 100vh;
  background: #000000;
  background-attachment: fixed;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

a { color: inherit; }
img { max-width: 100%; }
button { font-family: inherit; }

/* ── Imagen de fondo opcional (se activa con SITE_BG en .env) ───────────── */
body::before {
  content: '';
  position: fixed; inset: 0; z-index: -3;
  background-image: var(--bg-img, none);
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  opacity: var(--bg-opacity, 0);
  pointer-events: none;
}

/* ── Fondo: blobs difuminados (desactivados) ─────────────────────────────── */
.bg-blobs { display: none; }

/* ── Toques kawaii (sutiles, no compiten con el contenido) ──────────────── */
.kawaii-stars { position: fixed; inset: 0; z-index: -1; pointer-events: none; overflow: hidden; }
.kawaii-stars span {
  position: absolute; opacity: 0; user-select: none; line-height: 1;
  animation: twinkle 6s ease-in-out infinite;
}
@keyframes twinkle {
  0%, 100% { opacity: 0; transform: scale(.4) rotate(0deg); }
  50%      { opacity: .45; transform: scale(1) rotate(18deg); }
}
@media (prefers-reduced-motion: reduce) {
  .bg-blobs span, .kawaii-stars span { animation: none; }
}

/* ── Sidebar (desktop) ──────────────────────────────────────────────────── */
.sidebar {
  position: fixed; top: 0; left: 0; bottom: 0; width: var(--side-w);
  display: flex; flex-direction: column; gap: .35rem;
  padding: 1.4rem 1rem;
  background: rgba(22,15,34,.55);
  border-right: 1px solid var(--glass-border);
  backdrop-filter: blur(22px) saturate(140%); -webkit-backdrop-filter: blur(22px) saturate(140%);
  z-index: 50;
}
.side-brand { display: flex; align-items: center; gap: .7rem; padding: .2rem .5rem 1.1rem; min-width: 0; }
.side-brand img {
  width: 38px; height: 38px; border-radius: 50%; object-fit: cover;
  border: 2px solid var(--coral); box-shadow: 0 0 0 3px rgba(252,138,176,.18); flex-shrink: 0;
}
/* Marca en color sólido (sin degradado en texto) */
.side-brand span {
  font-weight: 800; font-size: 1.05rem; letter-spacing: .01em; color: var(--peach);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}

.side-nav { display: flex; flex-direction: column; gap: .25rem; }
.side-nav a {
  display: flex; align-items: center; gap: .75rem;
  padding: .65rem .8rem; border-radius: var(--radius-sm);
  color: var(--muted); text-decoration: none; font-weight: 500; font-size: .9rem;
  border: 1px solid transparent; transition: background .15s, color .15s, border-color .15s;
}
.side-nav a svg { width: 18px; height: 18px; flex-shrink: 0; }
.side-nav a:hover { background: var(--glass); color: var(--text); }
.side-nav a.active {
  color: #fff; border-color: var(--glass-border);
  background: linear-gradient(135deg, rgba(211,123,156,.32), rgba(252,138,176,.18));
  box-shadow: inset 0 1px 0 var(--glass-hi), 0 6px 18px rgba(252,138,176,.18);
}
.side-spacer { flex: 1; }
.side-user {
  padding: .7rem .8rem; border-radius: var(--radius-sm); background: var(--glass);
  border: 1px solid var(--glass-border); font-size: .78rem; color: var(--muted);
  display: flex; align-items: center; gap: .55rem; overflow: hidden;
}
.side-user .dot { width: 8px; height: 8px; border-radius: 50%; background: var(--green); flex-shrink: 0; box-shadow: 0 0 8px var(--green); }
.side-user span { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.side-logout { color: var(--red) !important; cursor: pointer; }
.side-nav a .lbl { white-space: nowrap; }

/* ── Main ───────────────────────────────────────────────────────────────── */
.main { margin-left: var(--side-w); padding: 1.6rem 1.8rem 4rem; max-width: 1080px; }

/* ── Card / grid / títulos ──────────────────────────────────────────────── */
.card {
  background: var(--glass);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius);
  padding: 1.3rem 1.5rem;
  backdrop-filter: blur(22px) saturate(140%); -webkit-backdrop-filter: blur(22px) saturate(140%);
  box-shadow: var(--shadow), inset 0 1px 0 var(--glass-hi);
  position: relative; overflow: hidden;
}
.grid    { display: grid; gap: 1.1rem; }
.grid-2  { grid-template-columns: 1fr 1fr; }
.grid-3  { grid-template-columns: repeat(3, 1fr); }

.section-title {
  font-size: .68rem; font-family: var(--mono);
  letter-spacing: .14em; text-transform: uppercase;
  color: var(--muted); margin-bottom: 1rem;
  display: flex; align-items: center; gap: .5rem;
}
.section-title::after { content: ''; flex: 1; height: 1px; background: var(--glass-border); }
.card-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: .9rem; gap: .75rem; }
.card-head .section-title { margin: 0; }

/* ── Botones ────────────────────────────────────────────────────────────── */
.mini-btn {
  font-family: var(--sans); font-size: .82rem; font-weight: 600; color: var(--text);
  background: var(--glass); border: 1px solid var(--glass-border);
  border-radius: 11px; padding: .45rem .9rem; cursor: pointer;
  transition: background .15s, border-color .15s, transform .12s;
}
.mini-btn:hover  { background: var(--glass-strong); border-color: var(--coral); }
.mini-btn:active { transform: scale(.96); }
.mini-btn.primary { background: linear-gradient(135deg, var(--mauve), var(--coral)); border: none; color: #fff; }
.group-select {
  font-family: var(--mono); font-size: .75rem; color: var(--text);
  background: rgba(0,0,0,.3); border: 1px solid var(--glass-border);
  border-radius: 9px; padding: .35rem .6rem; cursor: pointer; outline: none;
}

/* ── Badges de rol ──────────────────────────────────────────────────────── */
.badge {
  font-family: var(--mono); font-size: .64rem; font-weight: 600;
  padding: .22rem .55rem; border-radius: 7px; letter-spacing: .06em; text-transform: uppercase;
}
.badge-mod    { background: rgba(94,201,214,.15); color: var(--cyan);   border: 1px solid rgba(94,201,214,.32); }
.badge-helper { background: rgba(74,222,128,.13); color: var(--green);  border: 1px solid rgba(74,222,128,.30); }
.badge-owner  { background: rgba(251,191,36,.15); color: var(--yellow); border: 1px solid rgba(251,191,36,.32); }
.badge-coowner{ background: rgba(252,138,176,.16); color: var(--coral);  border: 1px solid rgba(252,138,176,.34); }
.badge-srmod  { background: rgba(211,123,156,.18); color: #FEA9BF;       border: 1px solid rgba(211,123,156,.36); }
.badge-admin  { background: rgba(248,177,149,.14); color: var(--peach);  border: 1px solid rgba(248,177,149,.30); }
.badge-user   { background: rgba(184,170,198,.12); color: var(--muted);  border: 1px solid rgba(184,170,198,.24); }

/* ── Estados de carga ───────────────────────────────────────────────────── */
.state-msg { text-align: center; padding: 4rem 1rem; color: var(--muted); font-size: .9rem; }
.spinner {
  width: 38px; height: 38px; border-radius: 50%;
  border: 3px solid var(--glass-border); border-top-color: var(--coral);
  animation: spin .7s linear infinite; margin: 0 auto 1rem;
}
@keyframes spin { to { transform: rotate(360deg); } }
.hidden { display: none !important; }

/* ── Overlay "sesión cerrada / kicked" (lo inyecta app.js) ──────────────── */
#kicked-overlay {
  display: none; position: fixed; inset: 0; z-index: 2000;
  background: rgba(0,0,0,.82); backdrop-filter: blur(5px);
  align-items: center; justify-content: center; padding: 1rem;
}
#kicked-overlay.show { display: flex; }
#kicked-box {
  background: rgba(30,21,44,.96); border: 1px solid rgba(251,113,133,.4);
  border-radius: 20px; padding: 2rem 2.5rem; text-align: center; max-width: 380px; width: 100%;
  box-shadow: var(--shadow);
}
#kicked-box .kicked-icon { font-size: 2.5rem; margin-bottom: .75rem; }
#kicked-box h3 { font-size: 1.05rem; font-weight: 700; margin-bottom: .5rem; color: var(--red); }
#kicked-box p { font-size: .83rem; color: var(--muted); margin-bottom: 1.4rem; line-height: 1.6; }
#kicked-count { font-family: var(--mono); font-size: 1.4rem; font-weight: 700; color: var(--coral); margin-bottom: 1.2rem; }
#kicked-btn {
  padding: .65rem 1.4rem; border-radius: 11px; border: none; color: #fff;
  font-weight: 600; font-size: .9rem; cursor: pointer;
  background: linear-gradient(135deg, var(--mauve), var(--coral));
}

/* ── Scrollbar / selección ──────────────────────────────────────────────── */
::selection { background: rgba(252,138,176,.4); color: #fff; }
::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: linear-gradient(180deg, var(--mauve), var(--coral)); border-radius: 99px; border: 2px solid transparent; background-clip: padding-box; }

/* ── Utilidades de color de texto ───────────────────────────────────────── */
.green  { color: var(--green); }
.coral  { color: var(--coral); }
.cyan   { color: var(--cyan); }
.purple, .mauve { color: var(--mauve); }
.yellow { color: var(--yellow); }
.red    { color: var(--red); }
.muted  { color: var(--muted); }
.mono   { font-family: var(--mono); }

/* ════════════════════════════════════════════════════════════════════════
   RESPONSIVE — celular y PC (definido UNA sola vez aquí)
   ════════════════════════════════════════════════════════════════════════ */

/* Tablet: estrechar paddings y grids de 3 a 2 columnas */
@media (max-width: 1080px) {
  .grid-3 { grid-template-columns: 1fr 1fr; }
}

/* Celular: la sidebar pasa a barra inferior fija de iconos */
@media (max-width: 900px) {
  .sidebar {
    top: auto; right: 0; bottom: 0; width: 100%; height: var(--bottombar-h);
    flex-direction: row; align-items: center; gap: 0;
    padding: .35rem .5rem;
    border-right: none; border-top: 1px solid var(--glass-border);
    background: rgba(22,15,34,.82);
  }
  .side-brand, .side-spacer, .side-user { display: none; }

  .side-nav {
    flex-direction: row; width: 100%; gap: .15rem;
    justify-content: space-around; align-items: stretch;
  }
  .side-nav a {
    flex-direction: column; gap: .15rem; flex: 1;
    padding: .4rem .2rem; border-radius: 11px;
    font-size: .6rem; text-align: center;
  }
  .side-nav a svg { width: 20px; height: 20px; }
  .side-nav a .lbl { font-size: .6rem; line-height: 1; }
  .side-nav a.active { box-shadow: inset 0 1px 0 var(--glass-hi); }

  .main { margin-left: 0; padding: 1.1rem 1rem calc(var(--bottombar-h) + 1.4rem); max-width: none; }

  .grid-2, .grid-3 { grid-template-columns: 1fr; }
  .card { padding: 1.1rem 1.15rem; border-radius: 18px; }
}

/* Celular pequeño: tipografía algo menor */
@media (max-width: 480px) {
  .section-title { font-size: .62rem; }
  .card { padding: 1rem; }
}
