

:root {
  --bg: #fbfbfb;
  --bg-2: #f3f3f3;
  --bg-3: #eaeaea;
  --bg-4: #e0e0e0;
  --fg: #0a0a0a;
  --fg-2: #4a4a4a;
  --fg-3: #8a8a8a;
  --fg-4: #b0b0b0;
  --border: #ececec;
  --border-fuerte: #d8d8d8;
  --accent: #0a0a0a;
  --accent-fg: #ffffff;
  --acento-suave: #1a1a1a;
  --danger: #8a1f1f;
  --ok: #1f6b3a;
  --pendiente: #846a00;
  --radio: 10px;
  --radio-pequeno: 6px;
  --radio-grande: 14px;
  --shadow-1: 0 1px 2px rgba(10,10,10,.04), 0 1px 1px rgba(10,10,10,.02);
  --shadow-2: 0 4px 14px rgba(10,10,10,.06), 0 2px 4px rgba(10,10,10,.04);
  --shadow-3: 0 10px 32px rgba(10,10,10,.08), 0 4px 12px rgba(10,10,10,.05);
  --shadow-glow: 0 0 0 4px rgba(10,10,10,.05);
  --max: 1180px;
  --gap: 16px;
  --t-rapido: .12s ease;
  --t: .18s ease;
  --t-largo: .3s cubic-bezier(.2,.8,.2,1);
  --bg-glass: rgba(255,255,255,.65);
  --backdrop: blur(20px) saturate(160%);
}

[data-tema="oscuro"] {
  --bg: #0a0a0a;
  --bg-2: #141414;
  --bg-3: #1c1c1c;
  --bg-4: #262626;
  --fg: #fafafa;
  --fg-2: #b8b8b8;
  --fg-3: #7a7a7a;
  --fg-4: #555555;
  --border: #1f1f1f;
  --border-fuerte: #303030;
  --accent: #fafafa;
  --accent-fg: #0a0a0a;
  --acento-suave: #e0e0e0;
  --danger: #e08585;
  --ok: #7ec99a;
  --pendiente: #d6b94a;
  --bg-glass: rgba(15,15,15,.65);
  --shadow-1: 0 1px 2px rgba(0,0,0,.5), 0 1px 1px rgba(0,0,0,.3);
  --shadow-2: 0 4px 14px rgba(0,0,0,.5), 0 2px 4px rgba(0,0,0,.3);
  --shadow-3: 0 10px 32px rgba(0,0,0,.6), 0 4px 12px rgba(0,0,0,.4);
  --shadow-glow: 0 0 0 4px rgba(255,255,255,.06);
}

@media (prefers-color-scheme: dark) {
  [data-tema="sistema"] {
    --bg: #0a0a0a;
    --bg-2: #141414;
    --bg-3: #1c1c1c;
    --bg-4: #262626;
    --fg: #fafafa;
    --fg-2: #b8b8b8;
    --fg-3: #7a7a7a;
    --fg-4: #555555;
    --border: #1f1f1f;
    --border-fuerte: #303030;
    --accent: #fafafa;
    --accent-fg: #0a0a0a;
    --acento-suave: #e0e0e0;
    --danger: #e08585;
    --ok: #7ec99a;
    --pendiente: #d6b94a;
    --bg-glass: rgba(15,15,15,.65);
    --shadow-1: 0 1px 2px rgba(0,0,0,.5), 0 1px 1px rgba(0,0,0,.3);
    --shadow-2: 0 4px 14px rgba(0,0,0,.5), 0 2px 4px rgba(0,0,0,.3);
    --shadow-3: 0 10px 32px rgba(0,0,0,.6), 0 4px 12px rgba(0,0,0,.4);
    --shadow-glow: 0 0 0 4px rgba(255,255,255,.06);
  }
}

[data-tema="transparencia"] {
  --bg: rgba(255,255,255,.5);
  --bg-2: rgba(255,255,255,.6);
  --bg-3: rgba(255,255,255,.7);
  --fg: #0a0a0a;
  --fg-2: #3a3a3a;
  --fg-3: #6a6a6a;
  --border: rgba(0,0,0,.08);
  --border-fuerte: rgba(0,0,0,.18);
  --bg-glass: rgba(255,255,255,.7);
}

[data-tema="transparencia"] body {
  background:
    radial-gradient(1400px 900px at 5% -5%, #d4dde9, transparent 65%),
    radial-gradient(1100px 800px at 110% 5%, #ead8d8, transparent 65%),
    radial-gradient(900px 700px at 50% 110%, #d8e6da, transparent 70%),
    linear-gradient(180deg, #f5f5f7, #ececef);
  background-attachment: fixed;
}

@media (prefers-color-scheme: dark) {
  [data-tema="transparencia"] {
    --bg: rgba(20,20,20,.55);
    --bg-2: rgba(28,28,28,.65);
    --bg-3: rgba(38,38,38,.7);
    --fg: #fafafa;
    --fg-2: #c8c8c8;
    --fg-3: #888888;
    --border: rgba(255,255,255,.08);
    --border-fuerte: rgba(255,255,255,.18);
    --bg-glass: rgba(20,20,20,.7);
  }
  [data-tema="transparencia"] body {
    background:
      radial-gradient(1400px 900px at 5% -5%, #1a2535, transparent 65%),
      radial-gradient(1100px 800px at 110% 5%, #2a1f1f, transparent 65%),
      radial-gradient(900px 700px at 50% 110%, #1a2a1f, transparent 70%),
      #060608;
    background-attachment: fixed;
  }
}

* { box-sizing: border-box; }
html, body { height: 100%; }
body {
  margin: 0;
  font-family: "Plus Jakarta Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  font-size: 15px;
  line-height: 1.55;
  color: var(--fg);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  display: flex;
  flex-direction: column;
  font-feature-settings: "ss01", "cv11";
}

a { color: var(--fg); text-decoration: none; transition: color var(--t-rapido); }
a:hover { color: var(--fg-2); }
.enlace-tenue { color: var(--fg-3); }
.enlace-tenue:hover { color: var(--fg); }

h1, h2, h3, h4 { margin: 0 0 14px; font-weight: 600; letter-spacing: -.02em; line-height: 1.2; }
h1 { font-size: 32px; letter-spacing: -.03em; }
h2 { font-size: 22px; letter-spacing: -.02em; }
h3 { font-size: 17px; }
h4 { font-size: 15px; }

p { margin: 0 0 12px; }
::selection { background: var(--fg); color: var(--bg); }

hr { border: 0; border-top: 1px solid var(--border); margin: 24px 0; }


.cabecera {
  position: sticky;
  top: 0;
  z-index: 50;
  background: color-mix(in srgb, var(--bg) 92%, transparent);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--border);
}
[data-tema="transparencia"] .cabecera {
  background: var(--bg-glass);
  backdrop-filter: var(--backdrop);
  -webkit-backdrop-filter: var(--backdrop);
}
.cabecera-cont {
  max-width: var(--max);
  margin: 0 auto;
  padding: 12px 20px;
  display: flex;
  gap: 12px;
  align-items: center;
  flex-wrap: wrap;
}
.marca {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-weight: 600;
  font-size: 16px;
  letter-spacing: -.01em;
}
.marca-svg {
  display: inline-flex;
  width: 32px; height: 32px;
  align-items: center; justify-content: center;
  background: var(--fg);
  color: var(--bg);
  border-radius: 8px;
}
.marca-svg svg { width: 16px; height: 16px; }
.marca-txt { font-weight: 600; }

.nav-principal {
  display: flex;
  gap: 2px;
}
.nav-item {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 8px 14px;
  border-radius: var(--radio-pequeno);
  color: var(--fg-2);
  font-size: 14px;
  font-weight: 500;
  transition: background var(--t-rapido), color var(--t-rapido);
}
.nav-item:hover { background: var(--bg-2); color: var(--fg); }
.nav-item.activo { background: var(--bg-3); color: var(--fg); }
.nav-item .ico { display: inline-flex; opacity: .7; }
.nav-item.activo .ico, .nav-item:hover .ico { opacity: 1; }

.cabecera-acciones { display: flex; gap: 8px; align-items: center; }


.menu-usuario { position: relative; }
.btn-usuario {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: transparent;
  border: 1px solid var(--border);
  border-radius: 999px;
  padding: 4px 14px 4px 4px;
  cursor: pointer;
  font: inherit;
  color: var(--fg);
  transition: background var(--t-rapido), border-color var(--t-rapido);
}
.btn-usuario:hover { background: var(--bg-2); border-color: var(--border-fuerte); }
.avatar-mini {
  width: 28px; height: 28px; border-radius: 50%;
  background: linear-gradient(135deg, var(--bg-3), var(--bg-4));
  display: inline-flex;
  align-items: center; justify-content: center;
  font-size: 13px; font-weight: 600; color: var(--fg);
  overflow: hidden;
}
.usuario-nombre { font-size: 13px; font-weight: 500; }

.menu-flotante {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  min-width: 220px;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: var(--radio);
  box-shadow: var(--shadow-3);
  padding: 6px;
  animation: aparecer var(--t-largo);
}
@keyframes aparecer {
  from { opacity: 0; transform: translateY(-4px); }
  to { opacity: 1; transform: translateY(0); }
}
[data-tema="transparencia"] .menu-flotante {
  background: var(--bg-glass);
  backdrop-filter: var(--backdrop);
  -webkit-backdrop-filter: var(--backdrop);
}
.menu-item {
  display: flex; align-items: center; gap: 10px;
  padding: 9px 11px; border-radius: var(--radio-pequeno);
  font-size: 13px; color: var(--fg);
  background: transparent; border: 0; width: 100%;
  text-align: left; cursor: pointer; font: inherit; font-weight: 500;
  transition: background var(--t-rapido);
}
.menu-item:hover { background: var(--bg-2); }
.menu-item svg { opacity: .6; }
.menu-item:hover svg { opacity: 1; }
.menu-form { margin: 0; }


.btn {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 9px 16px;
  border-radius: var(--radio-pequeno);
  border: 1px solid var(--border-fuerte);
  background: var(--bg);
  color: var(--fg);
  font: inherit;
  font-size: 14px;
  font-weight: 500;
  cursor: pointer;
  transition: background var(--t-rapido), border-color var(--t-rapido), transform var(--t-rapido), box-shadow var(--t-rapido);
  letter-spacing: -.005em;
}
.btn:hover { background: var(--bg-2); border-color: var(--fg-3); }
.btn:active { transform: translateY(1px); }
.btn:focus-visible { outline: none; box-shadow: var(--shadow-glow); }
.btn-primario {
  background: var(--accent);
  color: var(--accent-fg);
  border-color: var(--accent);
  box-shadow: var(--shadow-1);
}
.btn-primario:hover { background: var(--acento-suave); border-color: var(--acento-suave); color: var(--accent-fg); box-shadow: var(--shadow-2); }
.btn-suave { background: transparent; border-color: var(--border); }
.btn-peligro { color: var(--danger); border-color: var(--border-fuerte); background: var(--bg); }
.btn-peligro:hover { background: var(--bg-2); border-color: var(--danger); }
.btn-pequeno { padding: 5px 12px; font-size: 13px; gap: 5px; }
.btn-icono { padding: 7px 9px; }
.btn svg { flex-shrink: 0; }


main {
  max-width: var(--max);
  width: 100%;
  margin: 0 auto;
  padding: 36px 24px;
  flex: 1;
}
.encabezado-pagina {
  display: flex; align-items: flex-end; justify-content: space-between;
  gap: 18px; margin-bottom: 26px;
}
.subtitulo { color: var(--fg-2); margin-top: 6px; margin-bottom: 0; font-size: 15px; }


.hero {
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
  padding: 42px 36px;
  margin-bottom: 28px;
  border: 1px solid var(--border);
  border-radius: var(--radio-grande);
  background:
    radial-gradient(800px 400px at 100% 0%, color-mix(in srgb, var(--fg) 4%, transparent), transparent 60%),
    radial-gradient(600px 300px at 0% 100%, color-mix(in srgb, var(--fg) 3%, transparent), transparent 60%),
    var(--bg);
  box-shadow: var(--shadow-1);
  overflow: hidden;
  position: relative;
}
.hero h1 {
  font-size: 44px;
  letter-spacing: -.035em;
  margin: 0 0 14px;
  max-width: 720px;
}
.hero p {
  color: var(--fg-2);
  font-size: 17px;
  max-width: 580px;
  margin: 0 0 22px;
}
.hero-acciones { display: flex; gap: 10px; flex-wrap: wrap; }
.hero::after {
  content: '';
  position: absolute;
  top: 0; right: 0; bottom: 0; width: 1px;
  background: linear-gradient(180deg, transparent, var(--border), transparent);
  opacity: .4;
}

@media (max-width: 700px) {
  .hero { padding: 28px 22px; }
  .hero h1 { font-size: 32px; }
  .hero p { font-size: 15px; }
}


.tarjeta {
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: var(--radio);
  padding: 22px 24px;
  box-shadow: var(--shadow-1);
}
[data-tema="transparencia"] .tarjeta {
  background: var(--bg-glass);
  backdrop-filter: var(--backdrop);
  -webkit-backdrop-filter: var(--backdrop);
}
.tarjeta + .tarjeta { margin-top: 14px; }
.tarjeta-cab {
  display: flex; align-items: center; justify-content: space-between;
  gap: 12px; margin-bottom: 16px;
}
.tarjeta-cab h2 { margin: 0; }

.titulo-icon {
  display: inline-flex; gap: 10px; align-items: center;
}
.titulo-icon svg { color: var(--fg-2); }


.lista-categorias { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 12px; }
.cat-row {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 16px;
  padding: 18px 20px;
  border: 1px solid var(--border);
  border-radius: var(--radio);
  background: var(--bg);
  transition: border-color var(--t), box-shadow var(--t), transform var(--t);
  position: relative;
  overflow: hidden;
}
[data-tema="transparencia"] .cat-row { background: var(--bg-glass); backdrop-filter: var(--backdrop); }
.cat-row::before {
  content: '';
  position: absolute;
  top: 0; left: 0; bottom: 0; width: 3px;
  background: var(--fg);
  opacity: 0;
  transition: opacity var(--t);
}
.cat-row:hover { border-color: var(--border-fuerte); box-shadow: var(--shadow-2); transform: translateY(-1px); }
.cat-row:hover::before { opacity: 1; }
.cat-row .cat-icono {
  width: 42px; height: 42px;
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--bg-2);
  border-radius: var(--radio-pequeno);
  color: var(--fg-2);
  flex-shrink: 0;
  transition: background var(--t), color var(--t);
}
.cat-row:hover .cat-icono { background: var(--fg); color: var(--bg); }
.cat-row .nombre { font-weight: 600; font-size: 15px; letter-spacing: -.01em; }
.cat-row .desc { color: var(--fg-3); font-size: 13px; margin-top: 2px; line-height: 1.4; }
.cat-row .meta { color: var(--fg-3); font-size: 12px; text-align: right; white-space: nowrap; font-variant-numeric: tabular-nums; }
.cat-row .meta-num { font-weight: 600; color: var(--fg-2); font-size: 14px; }


.lista-hilos { border: 1px solid var(--border); border-radius: var(--radio); overflow: hidden; background: var(--bg); box-shadow: var(--shadow-1); }
[data-tema="transparencia"] .lista-hilos { background: var(--bg-glass); backdrop-filter: var(--backdrop); }
.hilo-row {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 14px;
  padding: 14px 18px;
  border-bottom: 1px solid var(--border);
  background: transparent;
  transition: background var(--t-rapido);
}
.hilo-row:last-child { border-bottom: 0; }
.hilo-row:hover { background: var(--bg-2); }
.hilo-row .titulo { font-weight: 500; color: var(--fg); font-size: 15px; }
.hilo-row .titulo:hover { color: var(--fg-2); }
.hilo-row .info { color: var(--fg-3); font-size: 13px; margin-top: 2px; }
.hilo-row .stats { color: var(--fg-3); font-size: 13px; display: flex; gap: 14px; align-items: center; font-variant-numeric: tabular-nums; }
.hilo-row .stat { display: inline-flex; gap: 5px; align-items: center; }
.hilo-row .badge { display: inline-flex; align-items: center; gap: 4px; color: var(--fg-3); }


.post {
  display: grid;
  grid-template-columns: 200px 1fr;
  gap: 22px;
  border: 1px solid var(--border);
  border-radius: var(--radio);
  padding: 22px;
  background: var(--bg);
  margin-bottom: 14px;
  box-shadow: var(--shadow-1);
}
[data-tema="transparencia"] .post { background: var(--bg-glass); backdrop-filter: var(--backdrop); }
.post-autor {
  display: flex; flex-direction: column; align-items: center;
  text-align: center; gap: 8px;
  padding-right: 22px;
  border-right: 1px solid var(--border);
}
.avatar-grande {
  width: 76px; height: 76px; border-radius: 50%;
  background: linear-gradient(135deg, var(--bg-3), var(--bg-4));
  display: inline-flex;
  align-items: center; justify-content: center;
  font-weight: 600; font-size: 28px; color: var(--fg);
  overflow: hidden;
  box-shadow: var(--shadow-1);
}
.post-autor .nombre { font-weight: 600; }
.post-autor .rango { font-size: 11px; padding: 3px 10px; border-radius: 999px; background: var(--bg-2); border: 1px solid var(--border); font-weight: 500; }
.post-autor .puntos { font-size: 12px; color: var(--fg-3); font-variant-numeric: tabular-nums; }
.post-cuerpo .post-cab {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 12px; color: var(--fg-3); font-size: 13px;
}
.post-contenido { color: var(--fg); white-space: pre-wrap; word-wrap: break-word; line-height: 1.65; }
.post-pie { margin-top: 14px; display: flex; justify-content: space-between; align-items: center; gap: 12px; }
.post-acciones { display: flex; gap: 6px; }

@media (max-width: 700px) {
  .post { grid-template-columns: 1fr; padding: 18px; }
  .post-autor { flex-direction: row; border-right: 0; border-bottom: 1px solid var(--border); padding: 0 0 14px; justify-content: flex-start; }
  .avatar-grande { width: 56px; height: 56px; font-size: 22px; }
}


.voto {
  display: inline-flex; align-items: center;
  background: var(--bg-2);
  border: 1px solid var(--border);
  border-radius: 999px;
  margin-top: 4px;
  overflow: hidden;
}
.voto-btn {
  background: transparent; border: 0;
  padding: 6px 12px;
  cursor: pointer; color: var(--fg-2);
  display: inline-flex; align-items: center; gap: 6px;
  font: inherit; font-size: 13px;
  font-variant-numeric: tabular-nums;
  transition: color var(--t-rapido), background var(--t-rapido);
}
.voto-btn:hover { color: var(--fg); background: var(--bg-3); }
.voto-btn .voto-ico { display: inline-flex; }
.voto-btn .voto-ico svg { width: 16px; height: 16px; }
.voto-btn .voto-num { min-width: 0; font-weight: 600; }
.voto-btn .voto-num:empty { display: none; }
.voto-sep {
  width: 1px; height: 18px;
  background: var(--border);
  flex-shrink: 0;
}
.voto-btn.activo-up { color: var(--ok); }
.voto-btn.activo-up .voto-ico svg { fill: currentColor; stroke: currentColor; }
.voto-btn.activo-down { color: var(--danger); }
.voto-btn.activo-down .voto-ico svg { fill: currentColor; stroke: currentColor; }


.formulario { display: flex; flex-direction: column; gap: 16px; max-width: 580px; }
.formulario.ancho { max-width: 100%; }
.campo { display: flex; flex-direction: column; gap: 7px; }
.campo label { font-size: 13px; color: var(--fg-2); font-weight: 500; letter-spacing: -.005em; }
.campo input[type="text"],
.campo input[type="email"],
.campo input[type="password"],
.campo input[type="url"],
.campo input[type="number"],
.campo select,
.campo textarea {
  width: 100%;
  padding: 11px 13px;
  border-radius: var(--radio-pequeno);
  border: 1px solid var(--border-fuerte);
  background: var(--bg);
  color: var(--fg);
  font: inherit;
  font-size: 14px;
  transition: border-color var(--t-rapido), box-shadow var(--t-rapido), background var(--t-rapido);
}
[data-tema="transparencia"] .campo input,
[data-tema="transparencia"] .campo select,
[data-tema="transparencia"] .campo textarea { background: var(--bg-glass); }
.campo input:hover, .campo select:hover, .campo textarea:hover { border-color: var(--fg-3); }
.campo input:focus, .campo select:focus, .campo textarea:focus {
  outline: none;
  border-color: var(--fg);
  box-shadow: var(--shadow-glow);
}
.campo textarea { min-height: 160px; resize: vertical; line-height: 1.6; }
.campo input[type="file"] { padding: 10px 0; cursor: pointer; }
.campo input[type="file"]::file-selector-button {
  margin-right: 12px;
  padding: 7px 14px;
  border: 1px solid var(--border-fuerte);
  background: var(--bg);
  color: var(--fg);
  border-radius: var(--radio-pequeno);
  font: inherit;
  font-size: 13px;
  cursor: pointer;
  transition: background var(--t-rapido);
}
.campo input[type="file"]::file-selector-button:hover { background: var(--bg-2); }
.campo .ayuda { color: var(--fg-3); font-size: 12px; }
.campo-fila { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }

.acciones-form { display: flex; gap: 8px; margin-top: 6px; }


.flash {
  max-width: var(--max);
  margin: 14px auto 0;
  padding: 12px 16px;
  border-radius: var(--radio);
  display: flex; align-items: center; gap: 12px;
  font-size: 14px;
  border: 1px solid;
  animation: aparecer var(--t-largo);
}
.flash-ico { display: inline-flex; }
.flash-ok { background: color-mix(in srgb, var(--ok) 8%, var(--bg)); color: var(--ok); border-color: color-mix(in srgb, var(--ok) 30%, transparent); }
.flash-error { background: color-mix(in srgb, var(--danger) 8%, var(--bg)); color: var(--danger); border-color: color-mix(in srgb, var(--danger) 30%, transparent); }
.flash-info { background: var(--bg-2); color: var(--fg-2); border-color: var(--border); }


.estado {
  display: inline-flex; align-items: center; padding: 3px 10px; border-radius: 999px;
  font-size: 12px; border: 1px solid var(--border); font-weight: 500;
}
.estado-aprobado { color: var(--ok); border-color: color-mix(in srgb, var(--ok) 30%, transparent); background: color-mix(in srgb, var(--ok) 6%, transparent); }
.estado-pendiente { color: var(--pendiente); border-color: color-mix(in srgb, var(--pendiente) 30%, transparent); background: color-mix(in srgb, var(--pendiente) 6%, transparent); }
.estado-rechazado { color: var(--danger); border-color: color-mix(in srgb, var(--danger) 30%, transparent); background: color-mix(in srgb, var(--danger) 6%, transparent); }


.grid-tarjetas {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 16px;
}
.tarjeta-item {
  display: flex; flex-direction: column;
  border: 1px solid var(--border); border-radius: var(--radio);
  background: var(--bg); overflow: hidden;
  transition: border-color var(--t), transform var(--t), box-shadow var(--t);
  box-shadow: var(--shadow-1);
}
[data-tema="transparencia"] .tarjeta-item { background: var(--bg-glass); backdrop-filter: var(--backdrop); }
.tarjeta-item:hover { border-color: var(--border-fuerte); transform: translateY(-2px); box-shadow: var(--shadow-3); }
.tarjeta-banner {
  aspect-ratio: 16 / 10;
  background:
    linear-gradient(135deg, var(--bg-2), var(--bg-3));
  background-size: cover; background-position: center;
  display: flex; align-items: center; justify-content: center;
  color: var(--fg-4); font-size: 12px;
  position: relative;
  overflow: hidden;
}
.tarjeta-banner.con-imagen {
  background-color: var(--bg-3);
}
.tarjeta-banner::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 60%, rgba(0,0,0,.15));
  opacity: 0;
  transition: opacity var(--t);
}
.tarjeta-item:hover .tarjeta-banner::after { opacity: 1; }
.tarjeta-banner-vacio {
  display: flex; flex-direction: column; align-items: center; gap: 4px;
  color: var(--fg-4);
}
.tarjeta-banner-vacio svg { opacity: .4; width: 24px; height: 24px; }
.tarjeta-cuerpo { padding: 14px 16px; }
.tarjeta-titulo { font-weight: 600; font-size: 14px; margin-bottom: 6px; letter-spacing: -.01em; }
.tarjeta-meta { color: var(--fg-3); font-size: 12px; display: flex; flex-wrap: wrap; gap: 8px; align-items: center; }
.tarjeta-meta > span { display: inline-flex; align-items: center; gap: 4px; }


.pie {
  border-top: 1px solid var(--border);
  margin-top: 56px;
  background: var(--bg);
}
.pie-cont {
  max-width: var(--max);
  margin: 0 auto;
  padding: 18px 24px;
  display: flex; justify-content: space-between; align-items: center;
  color: var(--fg-3); font-size: 13px;
}


.paginacion { display: flex; gap: 6px; margin-top: 24px; justify-content: center; }
.paginacion a, .paginacion span {
  padding: 7px 13px; border-radius: var(--radio-pequeno);
  border: 1px solid var(--border); color: var(--fg-2); font-size: 13px;
  font-variant-numeric: tabular-nums;
  transition: background var(--t-rapido), border-color var(--t-rapido);
}
.paginacion a:hover { background: var(--bg-2); border-color: var(--fg-3); }
.paginacion .activa { background: var(--accent); color: var(--accent-fg); border-color: var(--accent); }


.layout-sidebar { display: grid; grid-template-columns: 240px 1fr; gap: 32px; }
.sidebar-nav {
  border: 1px solid var(--border); border-radius: var(--radio);
  background: var(--bg); padding: 8px;
  display: flex; flex-direction: column; gap: 1px;
  align-self: start; position: sticky; top: 84px;
  box-shadow: var(--shadow-1);
}
[data-tema="transparencia"] .sidebar-nav { background: var(--bg-glass); backdrop-filter: var(--backdrop); }
.sidebar-nav a {
  padding: 9px 12px; border-radius: var(--radio-pequeno); color: var(--fg-2); font-size: 14px;
  display: flex; align-items: center; gap: 10px;
  transition: background var(--t-rapido), color var(--t-rapido);
  font-weight: 500;
}
.sidebar-nav a:hover { background: var(--bg-2); color: var(--fg); }
.sidebar-nav a.activo { background: var(--bg-3); color: var(--fg); }
.sidebar-nav a svg { opacity: .6; flex-shrink: 0; }
.sidebar-nav a.activo svg, .sidebar-nav a:hover svg { opacity: 1; }
.sidebar-nav .titulo { padding: 12px 12px 6px; color: var(--fg-3); font-size: 11px; text-transform: uppercase; letter-spacing: .1em; font-weight: 600; }

@media (max-width: 800px) {
  .layout-sidebar { grid-template-columns: 1fr; }
  .sidebar-nav { position: static; }
  .nav-principal .nav-item span:not(.ico) { display: none; }
  .nav-principal { gap: 0; }
  .nav-item { padding: 8px 10px; }
  .cabecera-cont { padding: 10px 16px; gap: 8px; justify-content: space-between; }
  .marca-txt { font-size: 14px; }
  main { padding: 20px 16px; }
  h1 { font-size: 24px; }
  .hero { padding: 24px 20px; }
  .hero h1 { font-size: 26px; }
  .grid-tarjetas { grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); }
}


.tabla {
  width: 100%; border-collapse: collapse; font-size: 14px;
  border: 1px solid var(--border); border-radius: var(--radio); overflow: hidden;
  background: var(--bg);
}
.tabla th, .tabla td { padding: 12px 14px; text-align: left; border-bottom: 1px solid var(--border); }
.tabla th { background: var(--bg-2); font-weight: 600; font-size: 12px; color: var(--fg-3); text-transform: uppercase; letter-spacing: .05em; }
.tabla tr:last-child td { border-bottom: 0; }
.tabla tbody tr { transition: background var(--t-rapido); }
.tabla tbody tr:hover { background: var(--bg-2); }
.tabla .acciones { display: flex; gap: 6px; }


.tag {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 3px 9px; border-radius: 999px; font-size: 12px;
  background: var(--bg-2); color: var(--fg-2);
  font-weight: 500; border: 1px solid var(--border);
  font-variant-numeric: tabular-nums;
}
.tag-acento { background: var(--fg); color: var(--bg); border-color: var(--fg); }


.alerta-overlay {
  position: fixed; inset: 0;
  background: rgba(0,0,0,.5);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  display: none; align-items: center; justify-content: center; z-index: 100;
  animation: aparecer var(--t-largo);
}
.alerta-overlay.activo { display: flex; }
.alerta-caja {
  background: var(--bg); border: 1px solid var(--border);
  border-radius: var(--radio); padding: 24px;
  min-width: 340px; max-width: 440px;
  box-shadow: var(--shadow-3);
  animation: aparecer var(--t-largo);
}
[data-tema="transparencia"] .alerta-caja { background: var(--bg-glass); backdrop-filter: var(--backdrop); }
.alerta-titulo { font-size: 16px; font-weight: 600; margin-bottom: 8px; display: flex; gap: 8px; align-items: center; letter-spacing: -.01em; }
.alerta-msg { color: var(--fg-2); font-size: 14px; margin-bottom: 18px; line-height: 1.5; }
.alerta-acciones { display: flex; justify-content: flex-end; gap: 8px; }


.contenido-md p { margin: 0 0 12px; }
.contenido-md a { color: var(--fg); text-decoration: underline; text-underline-offset: 3px; text-decoration-color: var(--fg-3); transition: text-decoration-color var(--t-rapido); }
.contenido-md a:hover { text-decoration-color: var(--fg); }
.contenido-md code { background: var(--bg-3); padding: 2px 7px; border-radius: 4px; font-size: 13px; font-family: "JetBrains Mono", "SF Mono", Monaco, Consolas, monospace; }
.contenido-md pre { background: var(--bg-2); padding: 14px 16px; border-radius: var(--radio-pequeno); overflow: auto; font-size: 13px; border: 1px solid var(--border); }
.contenido-md pre code { background: transparent; padding: 0; }
.contenido-md ul, .contenido-md ol { margin: 0 0 12px; padding-left: 24px; }
.contenido-md li { margin: 3px 0; }
.contenido-md blockquote {
  border-left: 3px solid var(--border-fuerte);
  margin: 0 0 12px; padding: 4px 14px; color: var(--fg-2);
  font-style: italic;
}
.contenido-md img { max-width: 100%; border-radius: var(--radio-pequeno); margin: 8px 0; }
.contenido-md h2, .contenido-md h3, .contenido-md h4 { margin-top: 22px; }


.vacio {
  text-align: center; color: var(--fg-3);
  padding: 48px 24px; border: 1px dashed var(--border);
  border-radius: var(--radio); font-size: 14px;
  background: color-mix(in srgb, var(--bg-2) 30%, transparent);
}


.avatar-iniciales[data-color="0"] { background: linear-gradient(135deg, #e8e8e8, #d2d2d2); }
.avatar-iniciales[data-color="1"] { background: linear-gradient(135deg, #d4dde9, #b8c5d8); }
.avatar-iniciales[data-color="2"] { background: linear-gradient(135deg, #ead8d8, #d8b8b8); }
.avatar-iniciales[data-color="3"] { background: linear-gradient(135deg, #d8e6da, #b8d2bc); }
.avatar-iniciales[data-color="4"] { background: linear-gradient(135deg, #e6e0d2, #d2c8a8); }
.avatar-iniciales[data-color="5"] { background: linear-gradient(135deg, #dcd4e6, #b8a8d2); }
[data-tema="oscuro"] .avatar-iniciales,
[data-tema="sistema"] .avatar-iniciales {
  filter: brightness(.85) contrast(1.1);
}


.stat-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)); gap: 16px; }
.stat-item {
  padding: 16px; border: 1px solid var(--border);
  border-radius: var(--radio-pequeno); background: var(--bg-2);
  transition: border-color var(--t), transform var(--t);
}
.stat-item:hover { border-color: var(--border-fuerte); transform: translateY(-1px); }
.stat-num { font-size: 28px; font-weight: 600; letter-spacing: -.02em; font-variant-numeric: tabular-nums; }
.stat-label { color: var(--fg-3); font-size: 12px; text-transform: uppercase; letter-spacing: .05em; font-weight: 500; }


.detalle-banner {
  width: 100%;
  aspect-ratio: 21 / 9;
  border-radius: var(--radio);
  background:
    linear-gradient(135deg, var(--bg-2), var(--bg-3));
  background-size: cover; background-position: center;
  margin-bottom: 24px;
  border: 1px solid var(--border);
  position: relative;
  overflow: hidden;
}
.detalle-banner-vacio {
  display: flex; align-items: center; justify-content: center;
  color: var(--fg-4); font-size: 14px;
  width: 100%; height: 100%;
}


.fila-meta { display: flex; flex-wrap: wrap; gap: 10px; align-items: center; color: var(--fg-3); font-size: 13px; }
.fila-meta .sep { color: var(--fg-4); }


.usuario-nombre-completo {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  vertical-align: middle;
}
.badge-verif {
  display: inline-flex;
  align-items: center;
  color: #1d9bf0;
  flex-shrink: 0;
}
.badge-verif svg { width: 16px; height: 16px; display: block; }


.rango-tag {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 3px 10px; border-radius: 999px;
  font-size: 12px; font-weight: 600;
  letter-spacing: -.005em;
  white-space: nowrap;
  line-height: 1.4;
}
.rango-tag .rango-icono {
  display: inline-flex; align-items: center;
  width: 12px; height: 12px;
}
.rango-tag .rango-icono svg { width: 12px; height: 12px; }
.lista-rangos { display: flex; flex-wrap: wrap; gap: 6px; }


.selector-iconos {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(44px, 1fr));
  gap: 6px;
  padding: 8px;
  border: 1px solid var(--border);
  border-radius: var(--radio-pequeno);
  background: var(--bg-2);
}
.selector-icono { position: relative; cursor: pointer; }
.selector-icono input { position: absolute; opacity: 0; pointer-events: none; }
.selector-icono-cuerpo {
  display: flex; align-items: center; justify-content: center;
  width: 100%; aspect-ratio: 1;
  background: var(--bg);
  border: 1px solid var(--border-fuerte);
  border-radius: var(--radio-pequeno);
  color: var(--fg-2);
  transition: all var(--t-rapido);
}
.selector-icono-cuerpo svg { width: 18px; height: 18px; }
.selector-icono:hover .selector-icono-cuerpo { border-color: var(--fg-3); color: var(--fg); }
.selector-icono input:checked + .selector-icono-cuerpo {
  background: var(--fg);
  color: var(--bg);
  border-color: var(--fg);
  box-shadow: var(--shadow-2);
}


.grid-checks {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 8px;
}
.check-item {
  display: flex; align-items: center; gap: 8px;
  padding: 8px 12px;
  font-size: 13px; color: var(--fg-2);
  background: var(--bg-2);
  border: 1px solid var(--border);
  border-radius: var(--radio-pequeno);
  cursor: pointer;
  transition: background var(--t-rapido), border-color var(--t-rapido);
}
.check-item:hover { background: var(--bg-3); border-color: var(--border-fuerte); }
.check-item:has(input:checked) { background: var(--fg); color: var(--bg); border-color: var(--fg); }
.check-item input[type="checkbox"] { accent-color: var(--fg); cursor: pointer; }
.check-item:has(input:disabled) { opacity: .7; cursor: default; }


.buscador {
  position: relative;
  margin-left: auto;
}
.buscador input {
  padding: 7px 12px 7px 32px;
  border-radius: var(--radio-pequeno);
  border: 1px solid var(--border);
  background: var(--bg-2);
  color: var(--fg);
  font: inherit; font-size: 13px;
  width: 220px;
  transition: width var(--t), background var(--t-rapido), border-color var(--t-rapido);
}
.buscador input:focus { outline: none; width: 280px; background: var(--bg); border-color: var(--fg-3); box-shadow: var(--shadow-glow); }
.buscador-icono {
  position: absolute; left: 9px; top: 50%; transform: translateY(-50%);
  color: var(--fg-3); pointer-events: none;
  display: inline-flex;
}
@media (max-width: 800px) {
  .buscador { display: none; }
}


.cropper-cont { display: flex; flex-direction: column; gap: 12px; align-items: flex-start; }
.cropper-area {
  position: relative;
  width: 320px; height: 320px;
}
.cropper-canvas-wrap {
  position: relative;
  width: 320px; height: 320px;
  border-radius: 50%;
  overflow: hidden;
  background: var(--bg-2);
  border: 1px solid var(--border);
  cursor: grab;
}
.cropper-canvas-wrap:active { cursor: grabbing; }
.cropper-placeholder {
  position: absolute; inset: 0;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  color: var(--fg-3); font-size: 13px; text-align: center;
  pointer-events: none;
}
.cropper-placeholder svg { width: 32px; height: 32px; opacity: .5; margin-bottom: 8px; }
.cropper-controles {
  display: flex; gap: 10px; align-items: center;
  width: 320px;
}
.cropper-zoom {
  flex: 1;
  -webkit-appearance: none; appearance: none;
  height: 4px; border-radius: 999px; background: var(--border-fuerte);
  outline: none;
}
.cropper-zoom::-webkit-slider-thumb {
  -webkit-appearance: none; appearance: none;
  width: 16px; height: 16px; border-radius: 50%;
  background: var(--fg); cursor: pointer;
}
.cropper-zoom::-moz-range-thumb {
  width: 16px; height: 16px; border-radius: 50%;
  background: var(--fg); cursor: pointer; border: 0;
}
.cropper-acciones { display: flex; gap: 8px; }


.separador-o {
  display: flex; align-items: center;
  gap: 12px; color: var(--fg-3); font-size: 12px;
  margin: 16px 0;
  text-transform: uppercase;
  letter-spacing: .1em;
}
.separador-o::before, .separador-o::after {
  content: ''; flex: 1; height: 1px; background: var(--border);
}


.aviso-banner {
  max-width: var(--max);
  margin: 12px auto 0;
  padding: 12px 16px;
  border-radius: var(--radio);
  background: color-mix(in srgb, var(--pendiente) 8%, var(--bg));
  border: 1px solid color-mix(in srgb, var(--pendiente) 30%, transparent);
  color: var(--pendiente);
  font-size: 14px;
  display: flex; align-items: center; gap: 12px; justify-content: space-between;
}
.aviso-banner-cuerpo { display: flex; align-items: center; gap: 10px; }


.autor-nivel {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 6px 10px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--nivel-color) 10%, var(--bg-2));
  border: 1px solid color-mix(in srgb, var(--nivel-color) 30%, var(--border));
  margin-top: 4px;
  max-width: 100%;
}
.autor-nivel-ico {
  display: inline-flex; align-items: center; justify-content: center;
  width: 22px; height: 22px;
  border-radius: 50%;
  background: color-mix(in srgb, var(--nivel-color) 25%, var(--bg));
  color: var(--nivel-color);
  flex-shrink: 0;
}
.autor-nivel-ico svg { width: 13px; height: 13px; }
.autor-nivel-txt { display: flex; flex-direction: column; line-height: 1.1; }
.autor-nivel-nombre { font-size: 12px; font-weight: 700; color: var(--nivel-color); }
.autor-nivel-pts { font-size: 10px; color: var(--fg-3); font-variant-numeric: tabular-nums; }


.nivel-banner {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 20px;
  padding: 22px 24px;
  margin: 18px 0 12px;
  border: 1px solid var(--border);
  border-radius: var(--radio-grande);
  background:
    radial-gradient(600px 200px at 0% 0%, color-mix(in srgb, var(--nivel-color, var(--fg)) 18%, transparent), transparent 70%),
    var(--bg);
  position: relative;
  overflow: hidden;
  box-shadow: var(--shadow-1);
  align-items: center;
}
[data-tema="transparencia"] .nivel-banner { background: var(--bg-glass); backdrop-filter: var(--backdrop); }
.nivel-banner::after {
  content: ''; position: absolute; top: 0; right: 0; width: 4px; height: 100%;
  background: var(--nivel-color, var(--fg));
}
.nivel-banner-icono {
  width: 64px; height: 64px;
  border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  background: color-mix(in srgb, var(--nivel-color, var(--fg)) 16%, var(--bg-2));
  color: var(--nivel-color, var(--fg));
  flex-shrink: 0;
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--nivel-color, var(--fg)) 10%, transparent);
}
.nivel-banner-icono svg { width: 30px; height: 30px; }
.nivel-banner-cab {
  display: flex; align-items: baseline; justify-content: space-between;
  margin-bottom: 8px; gap: 12px;
}
.nivel-banner-titulo {
  font-size: 22px; font-weight: 700;
  letter-spacing: -.02em;
  color: var(--nivel-color, var(--fg));
}
.nivel-banner-puntos {
  font-size: 13px; font-weight: 600;
  color: var(--fg-3);
  font-variant-numeric: tabular-nums;
}
.nivel-progreso {
  height: 8px;
  background: var(--bg-2);
  border-radius: 999px;
  overflow: hidden;
  margin-bottom: 6px;
}
.nivel-progreso-barra {
  height: 100%;
  background: linear-gradient(90deg, var(--nivel-color, var(--fg)), color-mix(in srgb, var(--nivel-color, var(--fg)) 70%, white));
  border-radius: 999px;
  transition: width var(--t-largo);
}
.nivel-progreso-texto {
  display: flex; justify-content: space-between;
  font-size: 12px; color: var(--fg-3);
}
.nivel-progreso-falta { font-weight: 600; color: var(--fg-2); font-variant-numeric: tabular-nums; }


.niveles-tira {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 6px;
  padding: 12px;
  border: 1px solid var(--border);
  border-radius: var(--radio);
  background: var(--bg);
  margin-bottom: 12px;
  box-shadow: var(--shadow-1);
}
[data-tema="transparencia"] .niveles-tira { background: var(--bg-glass); backdrop-filter: var(--backdrop); }
.nivel-mini {
  display: flex; flex-direction: column; align-items: center; gap: 6px;
  padding: 10px 6px;
  border-radius: var(--radio-pequeno);
  text-align: center;
  opacity: .35;
  transition: opacity var(--t), transform var(--t);
}
.nivel-mini.pasado { opacity: .85; }
.nivel-mini.activo {
  opacity: 1;
  background: color-mix(in srgb, var(--nivel-color, var(--fg)) 10%, transparent);
  transform: scale(1.05);
}
.nivel-mini-icono {
  width: 36px; height: 36px;
  display: inline-flex; align-items: center; justify-content: center;
  border-radius: 50%;
  background: color-mix(in srgb, var(--nivel-color, var(--fg)) 18%, var(--bg-2));
  color: var(--nivel-color, var(--fg));
}
.nivel-mini-icono svg { width: 18px; height: 18px; }
.nivel-mini-nombre { font-size: 11px; font-weight: 600; color: var(--fg-2); }
.nivel-mini.activo .nivel-mini-nombre { color: var(--nivel-color, var(--fg)); }

@media (max-width: 720px) {
  .niveles-tira { grid-template-columns: repeat(3, 1fr); }
}


.niveles-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 10px;
}
.nivel-card {
  text-align: center;
  padding: 16px 12px;
  border: 1px solid color-mix(in srgb, var(--nivel-color, var(--fg)) 30%, var(--border));
  border-radius: var(--radio);
  background: color-mix(in srgb, var(--nivel-color, var(--fg)) 5%, var(--bg));
}
.nivel-icono {
  width: 44px; height: 44px;
  margin: 0 auto 8px;
  border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  background: color-mix(in srgb, var(--nivel-color, var(--fg)) 18%, var(--bg-2));
  color: var(--nivel-color, var(--fg));
}
.nivel-icono svg { width: 22px; height: 22px; }
.nivel-nombre { font-size: 14px; font-weight: 700; color: var(--nivel-color, var(--fg)); }
.nivel-desde { font-size: 12px; color: var(--fg-3); margin-top: 2px; font-variant-numeric: tabular-nums; }


.lista-mensajes { border: 1px solid var(--border); border-radius: var(--radio); overflow: hidden; background: var(--bg); box-shadow: var(--shadow-1); }
.conv-row { display: grid; grid-template-columns: auto 1fr auto; gap: 14px; padding: 14px 16px; border-bottom: 1px solid var(--border); align-items: center; transition: background var(--t-rapido); }
.conv-row:last-child { border-bottom: 0; }
.conv-row:hover { background: var(--bg-2); }
.conv-row.no-leida { background: color-mix(in srgb, var(--fg) 4%, transparent); }
.conv-cuerpo { min-width: 0; }
.conv-cab { display: flex; justify-content: space-between; align-items: center; gap: 8px; }
.conv-nombre { font-weight: 600; font-size: 14px; }
.conv-fecha { color: var(--fg-3); font-size: 12px; white-space: nowrap; }
.conv-preview { color: var(--fg-3); font-size: 13px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; margin-top: 3px; }
.conv-badge { background: var(--danger); color: #fff; font-size: 11px; font-weight: 700; min-width: 20px; height: 20px; padding: 0 6px; border-radius: 999px; display: inline-flex; align-items: center; justify-content: center; }

.conv-mensajes { display: flex; flex-direction: column; gap: 10px; padding: 8px 0; }
.msg { display: flex; flex-direction: column; max-width: 70%; }
.msg-mio { align-self: flex-end; align-items: flex-end; }
.msg-otro { align-self: flex-start; }
.msg-burbuja {
  padding: 10px 14px; border-radius: 14px;
  background: var(--bg-2); border: 1px solid var(--border);
  font-size: 14px; line-height: 1.5;
  word-wrap: break-word;
}
.msg-mio .msg-burbuja { background: var(--fg); color: var(--bg); border-color: var(--fg); }
.msg-mio .msg-burbuja a { color: var(--bg); }
.msg-fecha { color: var(--fg-3); font-size: 11px; margin-top: 3px; padding: 0 6px; }


.md-uploader-btn { margin-bottom: 6px; align-self: flex-start; }


.fav-activo { background: color-mix(in srgb, var(--pendiente) 12%, var(--bg)); border-color: var(--pendiente); color: var(--pendiente); }
.fav-activo .fav-ico svg { fill: currentColor; }


.btn-campana {
  position: relative;
  background: transparent;
  border: 1px solid var(--border);
  border-radius: 999px;
  padding: 7px 9px;
  cursor: pointer;
  color: var(--fg-2);
  display: inline-flex; align-items: center;
  transition: background var(--t-rapido), border-color var(--t-rapido), color var(--t-rapido);
}
.btn-campana:hover { background: var(--bg-2); border-color: var(--border-fuerte); color: var(--fg); }
.campana-badge {
  position: absolute;
  top: -2px; right: -2px;
  background: var(--danger);
  color: #fff;
  font-size: 10px;
  font-weight: 700;
  min-width: 16px; height: 16px;
  padding: 0 4px;
  border-radius: 999px;
  display: inline-flex; align-items: center; justify-content: center;
  border: 2px solid var(--bg);
  box-sizing: content-box;
}
.menu-flotante-ancho { min-width: 320px; max-width: 360px; padding: 0; }
.notif-item, .notif-row {
  display: block;
  padding: 10px 14px;
  border-bottom: 1px solid var(--border);
  font-size: 13px;
  color: var(--fg);
  transition: background var(--t-rapido);
}
.notif-item:last-of-type, .notif-row:last-child { border-bottom: 0; }
.notif-item:hover, .notif-row:hover { background: var(--bg-2); }
.notif-item.no-leida, .notif-row.no-leida {
  background: color-mix(in srgb, var(--fg) 4%, transparent);
  border-left: 3px solid var(--fg);
  padding-left: 11px;
}
.notif-titulo { font-weight: 500; line-height: 1.4; margin-bottom: 4px; }
.notif-fecha { color: var(--fg-3); font-size: 12px; }
.lista-notificaciones {
  border: 1px solid var(--border);
  border-radius: var(--radio);
  background: var(--bg);
  overflow: hidden;
  box-shadow: var(--shadow-1);
}
[data-tema="transparencia"] .lista-notificaciones { background: var(--bg-glass); backdrop-filter: var(--backdrop); }
.lista-notificaciones .notif-row { padding: 14px 18px; }


.moneti-radio {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 10px;
  margin-bottom: 14px;
}
.moneti-card {
  display: flex; flex-direction: column; gap: 6px;
  padding: 14px 16px;
  border: 1px solid var(--border);
  border-radius: var(--radio);
  cursor: pointer;
  background: var(--bg);
  transition: border-color var(--t-rapido), background var(--t-rapido);
}
.moneti-card:hover { border-color: var(--fg-3); }
.moneti-card.activo { border-color: var(--fg); background: var(--bg-2); box-shadow: var(--shadow-glow); }
.moneti-card input { display: none; }
.moneti-card-titulo { font-weight: 700; font-size: 15px; }
.moneti-card-desc { color: var(--fg-3); font-size: 12px; }


.planes-admin-lista { display: flex; flex-direction: column; gap: 8px; }
.plan-item {
  border: 1px solid var(--border);
  border-radius: var(--radio);
  background: var(--bg);
}
.plan-item summary {
  cursor: pointer;
  padding: 14px 16px;
  list-style: none;
}
.plan-item summary::marker { display: none; }
.plan-item summary::-webkit-details-marker { display: none; }
.plan-item[open] summary { border-bottom: 1px solid var(--border); }
.plan-resumen { display: inline-flex; gap: 8px; align-items: center; flex-wrap: wrap; }


.planes-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 14px;
}
.plan-card {
  display: flex; flex-direction: column;
  padding: 22px 22px 18px;
  border: 1px solid var(--border);
  border-radius: var(--radio-grande);
  background: var(--bg);
  transition: transform var(--t), border-color var(--t), box-shadow var(--t);
  position: relative;
  overflow: hidden;
}
[data-tema="transparencia"] .plan-card { background: var(--bg-glass); backdrop-filter: var(--backdrop); }
.plan-card:hover { transform: translateY(-2px); border-color: var(--fg-3); box-shadow: var(--shadow-3); }
.plan-card::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 4px;
  background: linear-gradient(90deg, var(--fg), color-mix(in srgb, var(--fg) 60%, transparent));
}
.plan-card-cab { display: flex; justify-content: space-between; align-items: flex-start; gap: 12px; margin-bottom: 10px; }
.plan-card-cab h3 { margin: 0; font-size: 17px; }
.plan-precio { font-size: 28px; font-weight: 700; letter-spacing: -.02em; line-height: 1; }
.plan-moneda { font-size: 13px; color: var(--fg-3); font-weight: 500; margin-left: 2px; }
.plan-card-meta { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 12px; }
.plan-card-desc { color: var(--fg-2); font-size: 14px; margin-bottom: 14px; }
.plan-card-ventajas { list-style: none; padding: 0; margin: 0 0 14px; display: flex; flex-direction: column; gap: 6px; }
.plan-card-ventajas li { display: flex; gap: 8px; align-items: flex-start; font-size: 13px; color: var(--fg-2); }
.plan-card-ventajas li svg { flex-shrink: 0; color: var(--ok); margin-top: 2px; }
.plan-card-btn { margin-top: auto; justify-content: center; }


.comprar-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
  align-items: start;
}
@media (max-width: 800px) {
  .comprar-grid { grid-template-columns: 1fr; }
}
.comprar-precio {
  display: flex; justify-content: space-between; align-items: center;
  padding: 14px 16px;
  background: var(--bg-2);
  border-radius: var(--radio);
  margin-bottom: 14px;
}
.comprar-precio-label { font-size: 12px; color: var(--fg-3); text-transform: uppercase; letter-spacing: .05em; font-weight: 600; }
.comprar-precio-valor { font-size: 32px; font-weight: 700; letter-spacing: -.02em; }
.comprar-precio-moneda { font-size: 14px; color: var(--fg-3); font-weight: 500; }
.dato-pago { padding: 8px 0; border-bottom: 1px dashed var(--border); font-size: 14px; color: var(--fg-2); }
.dato-pago:last-of-type { border-bottom: 0; }
.dato-pago code { background: var(--bg-2); padding: 2px 8px; border-radius: 4px; font-family: monospace; font-size: 13px; }
.terminos-caja {
  border: 1px solid color-mix(in srgb, var(--pendiente) 30%, var(--border));
  background: color-mix(in srgb, var(--pendiente) 6%, var(--bg));
  border-radius: var(--radio);
  padding: 12px 14px;
  margin: 8px 0;
  font-size: 13px;
}
.terminos-cab { display: flex; align-items: center; gap: 8px; color: var(--pendiente); margin-bottom: 8px; }
.terminos-cuerpo { color: var(--fg-2); white-space: pre-wrap; line-height: 1.5; max-height: 200px; overflow-y: auto; }


.aviso-tipo-info { background: color-mix(in srgb, var(--fg) 4%, var(--bg)); border-color: var(--border); color: var(--fg); }
.aviso-tipo-ok { background: color-mix(in srgb, var(--ok) 8%, var(--bg)); border-color: color-mix(in srgb, var(--ok) 30%, transparent); color: var(--ok); }
.aviso-tipo-aviso { background: color-mix(in srgb, var(--pendiente) 8%, var(--bg)); border-color: color-mix(in srgb, var(--pendiente) 30%, transparent); color: var(--pendiente); }


.bloque-soporte {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 18px;
  padding: 22px 24px;
  margin-top: 22px;
  border: 1px solid var(--border);
  border-radius: var(--radio);
  background: var(--bg);
  box-shadow: var(--shadow-1);
  align-items: center;
}
[data-tema="transparencia"] .bloque-soporte { background: var(--bg-glass); backdrop-filter: var(--backdrop); }
.bloque-soporte-icono {
  width: 44px; height: 44px;
  display: inline-flex; align-items: center; justify-content: center;
  border-radius: 50%;
  background: var(--bg-2);
  color: var(--fg-2);
  flex-shrink: 0;
}
.bloque-soporte-icono svg { width: 22px; height: 22px; }
.bloque-soporte-cuerpo h3 { margin: 0 0 6px; font-size: 16px; }
.bloque-soporte-cuerpo p { margin: 0 0 12px; color: var(--fg-2); font-size: 14px; line-height: 1.55; }


.tabs {
  display: flex;
  gap: 4px;
  border-bottom: 1px solid var(--border);
  margin-bottom: 18px;
}
.tab {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 9px 14px;
  color: var(--fg-3);
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  font-size: 14px; font-weight: 500;
  transition: color var(--t-rapido), border-color var(--t-rapido);
}
.tab:hover { color: var(--fg-2); }
.tab.activo { color: var(--fg); border-color: var(--fg); }
.tab svg { opacity: .6; }
.tab.activo svg { opacity: 1; }


.bloque-tickets-titulo {
  display: flex; align-items: center; gap: 10px;
  font-size: 16px; margin-bottom: 12px;
}
.bloque-tickets-num {
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--bg-3); color: var(--fg-2);
  padding: 1px 10px; border-radius: 999px;
  font-size: 12px; font-weight: 600;
  margin-left: 4px;
}
.punto-estado {
  width: 8px; height: 8px; border-radius: 50%;
  display: inline-block;
}
.punto-activo { background: var(--ok); box-shadow: 0 0 0 4px color-mix(in srgb, var(--ok) 18%, transparent); }
.punto-cerrado { background: var(--fg-4); }
.ticket-cerrado .titulo { color: var(--fg-3); }


.lista-tickets { border: 1px solid var(--border); border-radius: var(--radio); overflow: hidden; background: var(--bg); box-shadow: var(--shadow-1); }
.ticket-row {
  display: grid;
  grid-template-columns: 100px 1fr auto;
  gap: 14px;
  align-items: center;
  padding: 14px 18px;
  border-bottom: 1px solid var(--border);
  transition: background var(--t-rapido);
}
.ticket-row:last-child { border-bottom: 0; }
.ticket-row:hover { background: var(--bg-2); }
.ticket-row .titulo { font-weight: 500; color: var(--fg); }
.ticket-row .info { color: var(--fg-3); font-size: 13px; margin-top: 4px; display: flex; flex-wrap: wrap; gap: 6px; align-items: center; }
.ticket-row .info .tag { font-size: 11px; padding: 2px 8px; }
.ticket-row .stats { color: var(--fg-3); font-size: 13px; display: flex; gap: 12px; align-items: center; }
.ticket-row .stat { display: inline-flex; gap: 4px; align-items: center; }

.ticket-estado {
  text-align: center;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .05em;
  font-weight: 600;
  padding: 4px 10px;
  border-radius: 999px;
  white-space: nowrap;
}
.estado-ticket { display: inline-flex; padding: 3px 10px; border-radius: 999px; font-size: 12px; font-weight: 500; text-transform: capitalize; border: 1px solid; }
.estado-ticket-abierto { color: var(--ok); border-color: color-mix(in srgb, var(--ok) 30%, transparent); background: color-mix(in srgb, var(--ok) 8%, transparent); }
.estado-ticket-en_proceso { color: var(--pendiente); border-color: color-mix(in srgb, var(--pendiente) 30%, transparent); background: color-mix(in srgb, var(--pendiente) 8%, transparent); }
.estado-ticket-cerrado { color: var(--fg-3); border-color: var(--border-fuerte); background: var(--bg-2); }


.cat-fila {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 0;
  border-bottom: 1px solid var(--border);
}
.cat-fila:last-child { border-bottom: 0; }
.cat-form-editar {
  display: flex;
  flex: 1;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  margin: 0;
}
.cat-form-borrar { margin: 0; flex-shrink: 0; }
.cat-input {
  padding: 7px 10px;
  border: 1px solid var(--border-fuerte);
  border-radius: var(--radio-pequeno);
  background: var(--bg);
  color: var(--fg);
  font: inherit;
  font-size: 13px;
  transition: border-color var(--t-rapido);
}
.cat-input:hover { border-color: var(--fg-3); }
.cat-input:focus { outline: none; border-color: var(--fg); box-shadow: var(--shadow-glow); }


.resultado-grupo { margin-bottom: 22px; }
.resultado-grupo h3 { color: var(--fg-3); font-size: 12px; text-transform: uppercase; letter-spacing: .08em; margin-bottom: 10px; font-weight: 600; }
.resultado-row {
  display: grid; grid-template-columns: 1fr auto;
  align-items: center; gap: 14px;
  padding: 12px 16px;
  border: 1px solid var(--border); border-radius: var(--radio-pequeno);
  background: var(--bg);
  transition: border-color var(--t-rapido), background var(--t-rapido);
  margin-bottom: 6px;
}
.resultado-row:hover { background: var(--bg-2); border-color: var(--border-fuerte); }
.resultado-row .titulo { font-weight: 500; color: var(--fg); }
.resultado-row .meta { color: var(--fg-3); font-size: 12px; }
