/* ============================================================
   CM5AM — Tema CLARO para Banco / Dashboard / Simulacro / Gamificacion
   v3.0.0 — Paleta crema-dorada; contraste WCAG AA en todo el sitio.
   Cubre sistema antiguo (.cm5am-*) y sistema nuevo (.cm-gam).
   ============================================================ */

/* =============================================================
   1. FONDO DE PAGINA — Todas las paginas de banco/gamificacion
      page-id: 6, 44, 48, 49, 50, 51, 54-61
   ============================================================= */
body.page-id-6,  body.page-id-44,
body.page-id-49, body.page-id-50, body.page-id-51,
body.page-id-54, body.page-id-55, body.page-id-56,
body.page-id-57, body.page-id-58, body.page-id-59,
body.page-id-60, body.page-id-61,
body.page-id-6.astra-dark-mode-enable,  body.page-id-44.astra-dark-mode-enable,
body.page-id-49.astra-dark-mode-enable, body.page-id-50.astra-dark-mode-enable,
body.page-id-51.astra-dark-mode-enable,
body.page-id-54.astra-dark-mode-enable, body.page-id-55.astra-dark-mode-enable,
body.page-id-56.astra-dark-mode-enable, body.page-id-57.astra-dark-mode-enable,
body.page-id-58.astra-dark-mode-enable, body.page-id-59.astra-dark-mode-enable,
body.page-id-60.astra-dark-mode-enable, body.page-id-61.astra-dark-mode-enable {
    background-color: #fbf8f0 !important;
    background-image: none !important;
}

/* Selecctor :has() — captura cualquier pagina con contenido del banco
   Soportado en Chrome 105+, Safari 15.4+, Firefox 121+, Edge 105+       */
body:has(.cm5am-dashboard),
body:has(.cm5am-simulacro-launcher),
body:has(.cm5am-hoja-ruta),
body:has(.cm-gam) {
    background-color: #fbf8f0 !important;
    background-image: none !important;
}

/* =============================================================
   1B. PAGINA BANCO (48) — fondo oscuro dorado/negro a pantalla
       completa, distinto del resto (mas "premium" / contraste alto).
       Las cards internas (.cm5am-cfg-*, #cm5am-pregunta-wrap, etc.)
       siguen siendo blancas/crema — solo cambia el fondo de pagina.
   ============================================================= */
body.page-id-48,
body.page-id-48.astra-dark-mode-enable,
body:has(.cm5am-banco-wrap) {
    background-color: #0b0e14 !important;
    background-image:
        radial-gradient(1100px 750px at 12% -8%, rgba(201, 168, 68, .20), transparent 60%),
        radial-gradient(900px 700px at 108% 15%, rgba(201, 168, 68, .12), transparent 55%),
        radial-gradient(1000px 850px at 50% 115%, rgba(201, 168, 68, .09), transparent 60%),
        linear-gradient(180deg, #0b0e14 0%, #0d1117 45%, #0a0d12 100%) !important;
    background-attachment: fixed !important;
    min-height: 100vh;
}
body.page-id-48::before,
body:has(.cm5am-banco-wrap)::before {
    content: "";
    position: fixed;
    inset: 0;
    z-index: 0;
    pointer-events: none;
    background-image:
        linear-gradient(rgba(201, 168, 68, .05) 1px, transparent 1px),
        linear-gradient(90deg, rgba(201, 168, 68, .05) 1px, transparent 1px);
    background-size: 44px 44px;
    mask-image: radial-gradient(ellipse 80% 60% at 50% 0%, black, transparent 75%);
    -webkit-mask-image: radial-gradient(ellipse 80% 60% at 50% 0%, black, transparent 75%);
}
body.page-id-48 .entry-title,
body:has(.cm5am-banco-wrap) .entry-title,
body.astra-dark-mode-enable.page-id-48 h1.page-title {
    color: #f5efe0 !important;
    text-shadow: 0 2px 16px rgba(0, 0, 0, .55);
}

/* Content areas: fondos transparentes para heredar el crema */
body.page-id-6  .site-content, body.page-id-44 .site-content,
body.page-id-48 .site-content, body.page-id-49 .site-content,
body.page-id-50 .site-content, body.page-id-51 .site-content,
body.page-id-54 .site-content, body.page-id-55 .site-content,
body.page-id-56 .site-content, body.page-id-57 .site-content,
body.page-id-58 .site-content, body.page-id-59 .site-content,
body.page-id-60 .site-content, body.page-id-61 .site-content,
body:has(.cm5am-banco-wrap) .site-content,
body:has(.cm-gam) .site-content,
body.page-id-6  .content-area, body.page-id-44 .content-area,
body.page-id-48 .content-area, body.page-id-49 .content-area,
body.page-id-50 .content-area, body.page-id-51 .content-area,
body.page-id-54 .content-area, body.page-id-55 .content-area,
body.page-id-56 .content-area, body.page-id-57 .content-area,
body.page-id-58 .content-area, body.page-id-59 .content-area,
body.page-id-60 .content-area, body.page-id-61 .content-area,
body:has(.cm5am-banco-wrap) .content-area,
body:has(.cm-gam) .content-area {
    background: transparent !important;
}

/* Titulos de pagina (Astra los pone blancos en dark-mode) */
body.page-id-49 .entry-title,
body.page-id-50 .entry-title, body.page-id-51 .entry-title,
body.page-id-54 .entry-title, body.page-id-55 .entry-title,
body.page-id-56 .entry-title, body.page-id-57 .entry-title,
body.page-id-58 .entry-title, body.page-id-59 .entry-title,
body.page-id-60 .entry-title, body.page-id-61 .entry-title,
body.page-id-6  .entry-title, body.page-id-44 .entry-title,
body:has(.cm-gam) .entry-title,
body.astra-dark-mode-enable.page-id-49 h1.page-title,
body.astra-dark-mode-enable.page-id-50 h1.page-title,
body.astra-dark-mode-enable.page-id-51 h1.page-title,
body.astra-dark-mode-enable.page-id-54 h1.page-title,
body.astra-dark-mode-enable.page-id-55 h1.page-title,
body.astra-dark-mode-enable.page-id-56 h1.page-title,
body.astra-dark-mode-enable.page-id-57 h1.page-title,
body.astra-dark-mode-enable.page-id-58 h1.page-title,
body.astra-dark-mode-enable.page-id-59 h1.page-title,
body.astra-dark-mode-enable.page-id-60 h1.page-title,
body.astra-dark-mode-enable.page-id-61 h1.page-title {
    color: #1a1200 !important;
}

/* =============================================================
   2. SISTEMA NUEVO — Variables CSS de .cm-gam (gam.css)
      Remapeo completo de la paleta oscura a la paleta crema-dorada.
      Todas las reglas de gam.css usan estas variables en cascada.
   ============================================================= */
.cm-gam {
    /* Fondos */
    --cm-bg:        #fbf8f0;   /* crema principal */
    --cm-bg-2:      #ffffff;   /* cards / paneles */
    --cm-bg-3:      #f5f0e4;   /* hover / elevado */
    /* Dorado — WCAG AA sobre blanco: 7.8:1 */
    --cm-gold:      #7a5900;
    --cm-gold-soft: #9a7700;
    /* Texto */
    --cm-text:      #1a1200;   /* ~19:1 sobre blanco */
    --cm-muted:     #5c4800;   /* ~7.8:1 sobre blanco */
    /* Bordes */
    --cm-border:    rgba(122, 89, 0, .22);
    /* Estados — oscuros para WCAG AA sobre blanco */
    --cm-green:     #15803d;   /* ~7:1 */
    --cm-yellow:    #92400e;   /* ~7:1 */
    --cm-red:       #b91c1c;   /* ~7:1 */
    /* Sombra calida */
    --cm-shadow:    0 4px 20px rgba(201, 168, 68, .12), 0 1px 4px rgba(0,0,0,.04);
    /* Otros */
    --cm-blue:      #1d4ed8;   /* ~7.8:1 */
    --cm-purple:    #7c3aed;   /* ~7.8:1 */

    /* Fondo y texto base del contenedor */
    background: var(--cm-bg) !important;
    background-image:
        radial-gradient(900px 500px at 100% -10%, rgba(201, 168, 68, .08), transparent 60%),
        radial-gradient(700px 400px at -10% 110%, rgba(201, 168, 68, .04), transparent 60%) !important;
    color: var(--cm-text) !important;
}

/* Texto del rango (.cm-rango usa gradient text con vars remapeadas) */
.cm-gam .cm-rango {
    background: linear-gradient(92deg, var(--cm-gold-soft), var(--cm-gold)) !important;
    -webkit-background-clip: text !important;
    background-clip: text !important;
    -webkit-text-fill-color: transparent !important;
    color: var(--cm-gold) !important;
}

/* Sombra de cards: calida dorada en lugar de negra */
.cm-gam .cm-card {
    box-shadow: var(--cm-shadow) !important;
}
.cm-gam .cm-card:hover {
    box-shadow: 0 8px 28px rgba(201, 168, 68, .22), 0 2px 8px rgba(0,0,0,.04) !important;
}

/* Tabla (rankings): fondo claro */
.cm-gam .cm-table tbody tr {
    background: var(--cm-bg-2) !important;
}
.cm-gam .cm-table tbody tr:hover {
    background: var(--cm-bg-3) !important;
}

/* Avatar placeholder: fondo crema en lugar de oscuro */
.cm-gam .cm-avatar {
    background: var(--cm-bg-3) !important;
}

/* Spinner: dorado oscuro sobre crema */
.cm-gam .cm-spinner {
    border-color: var(--cm-bg-3) !important;
    border-top-color: var(--cm-gold) !important;
}

/* Aviso ("no logueado / vacio"): borde dorado sobre crema */
.cm-gam .cm-aviso {
    background: var(--cm-bg-2) !important;
    border-color: var(--cm-border) !important;
    color: var(--cm-muted) !important;
}

/* Chat */
.cm-gam .cm-chat {
    background: var(--cm-bg-2) !important;
    border-color: var(--cm-border) !important;
}
.cm-gam .cm-chat__form {
    background: var(--cm-bg) !important;
    border-top-color: var(--cm-border) !important;
}
.cm-gam .cm-chat__msg {
    background: var(--cm-bg-3) !important;
}

/* Tabs activos */
.cm-gam .cm-tab:hover {
    background: rgba(122, 89, 0, .06) !important;
}

/* Rareza legendaria — brillo dorado oscuro sobre fondo claro */
.cm-gam .cm-rareza-legendario {
    color: var(--cm-gold) !important;
    border-color: var(--cm-gold) !important;
}

/* =============================================================
   3. SISTEMA ANTIGUO (.cm5am-*) — Componentes del banco/dashboard
   ============================================================= */

/* ---- Contenedor principal ---- */
.cm5am-banco-wrap,
.cm5am-dashboard,
.cm5am-simulacro-launcher,
.cm5am-hoja-ruta {
    color: #1a1200 !important;
}

/* ---- Headings: marron muy oscuro (#1a1200 ~19:1) ---- */
.cm5am-banco-wrap h1, .cm5am-banco-wrap h2, .cm5am-banco-wrap h3,
.cm5am-dashboard h1, .cm5am-dashboard h2, .cm5am-dashboard h3,
.cm5am-simulacro-launcher h1, .cm5am-simulacro-launcher h2, .cm5am-simulacro-launcher h3,
.cm5am-hoja-ruta h1, .cm5am-hoja-ruta h2, .cm5am-hoja-ruta h3 {
    color: #1a1200 !important;
}

/* ---- Labels: dorado oscuro (#7a5900 ~7.8:1 sobre blanco) ---- */
.cm5am-simulacro-launcher label,
.cm5am-sim-campo > label,
.cm5am-filtros label,
.cm5am-banco-wrap label {
    color: #7a5900 !important;
    font-weight: 600;
}

/* ---- Selects e inputs ---- */
.cm5am-simulacro-launcher select,
.cm5am-sim-campo select,
.cm5am-filtros select,
.cm5am-banco-wrap select,
.cm5am-banco-wrap input[type="number"],
.cm5am-simulacro-launcher input[type="number"] {
    background: #ffffff !important;
    color: #1a1200 !important;
    border: 1.5px solid rgba(201, 168, 68, .45) !important;
    border-radius: 8px !important;
}
.cm5am-simulacro-launcher select:focus,
.cm5am-filtros select:focus,
.cm5am-banco-wrap select:focus {
    outline: none !important;
    border-color: #c9a844 !important;
    box-shadow: 0 0 0 3px rgba(201, 168, 68, .18) !important;
}
.cm5am-filtros {
    background: #ffffff !important;
    border: 1px solid rgba(201, 168, 68, .25) !important;
    border-radius: 12px !important;
}

/* ---- Botones de modalidad del simulacro ---- */
.cm5am-modo-btn {
    background: #ffffff !important;
    border: 1.5px solid rgba(201, 168, 68, .35) !important;
    color: #3d2900 !important;
    border-radius: 10px !important;
}
.cm5am-modo-btn.activo,
.cm5am-modo-btn:hover {
    border-color: #c9a844 !important;
    background: rgba(201, 168, 68, .10) !important;
    color: #1a1200 !important;
}
.cm5am-modo-btn small { color: #7a5900 !important; }

/* =============================================================
   4. CABECERA DEL DASHBOARD (avatar + rango + XP)
   ============================================================= */
.cm5am-dash-header {
    background: #ffffff !important;
    border: 1px solid rgba(201, 168, 68, .25) !important;
    border-radius: 16px !important;
    box-shadow: 0 4px 20px rgba(201, 168, 68, .12), 0 1px 4px rgba(0,0,0,.04) !important;
    padding: 24px !important;
    margin-bottom: 16px !important;
    color: #1a1200 !important;
}
.cm5am-dash-info { color: #1a1200 !important; }
.cm5am-dash-header strong,
.cm5am-dash-header .cm5am-nombre { color: #1a1200 !important; }

.cm5am-rango-linea {
    display: flex; align-items: center; gap: 10px;
    flex-wrap: wrap; margin-bottom: 8px;
}

/* Badge dorado — texto oscuro: 8.9:1 */
.cm5am-rango-badge {
    background: linear-gradient(135deg, #c9a844, #b8920a) !important;
    color: #1a1200 !important;
    font-weight: 700 !important;
    padding: 4px 14px !important;
    border-radius: 999px !important;
    font-size: .9rem !important;
    border: none !important;
    display: inline-block;
}

/* Nombre GunBound */
.cm5am-rango-gun {
    color: #7a5900 !important;
    font-size: .88rem !important;
    font-weight: 500;
}

/* Barra de XP */
.cm5am-xp-bar {
    width: 100%;
    max-width: 400px;
    height: 10px;
    background: rgba(201, 168, 68, .15) !important;
    border-radius: 999px !important;
    overflow: hidden;
    margin-top: 8px;
    border: 1px solid rgba(201, 168, 68, .25) !important;
}
.cm5am-xp-fill {
    height: 100%;
    background: linear-gradient(90deg, #c9a844, #b8920a) !important;
    border-radius: 999px;
    box-shadow: 0 0 8px rgba(201, 168, 68, .4);
    transition: width .6s ease;
}
.cm5am-xp-texto, .cm5am-xp-label,
.cm5am-dash-header p,
.cm5am-dash-info p {
    color: #7a5900 !important;
    font-size: .82rem;
    margin-top: 4px;
}

/* =============================================================
   5. TARJETAS DE ESTADISTICAS
   ============================================================= */
.cm5am-dash-cards {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(130px, 1fr));
    gap: 12px;
    margin: 16px 0;
}
.cm5am-dash-card {
    position: relative;
    background: #ffffff !important;
    border: 1px solid rgba(201, 168, 68, .22) !important;
    border-radius: 14px !important;
    box-shadow: 0 2px 10px rgba(201, 168, 68, .08) !important;
    color: #1a1200 !important;
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 20px 12px !important;
    text-align: center;
    overflow: hidden;
    transition: box-shadow .2s, border-color .2s;
}
.cm5am-dash-card:hover {
    border-color: rgba(201, 168, 68, .55) !important;
    box-shadow: 0 6px 20px rgba(201, 168, 68, .18) !important;
}
.cm5am-dash-card::before {
    content: "";
    position: absolute;
    inset: 0 0 auto 0;
    height: 2px;
    background: linear-gradient(90deg, transparent, rgba(201,168,68,.6), transparent);
}

/* Numero grande */
.cm5am-dash-card .cm5am-dash-n {
    font-size: 2.1rem !important;
    font-weight: 800 !important;
    line-height: 1 !important;
    color: #1a1200 !important;
}
/* Etiqueta */
.cm5am-dash-card > span:last-child {
    color: #7a5900 !important;
    font-size: .78rem !important;
    font-weight: 600 !important;
    text-transform: uppercase;
    letter-spacing: .04em;
    margin-top: 6px;
}

/* Variantes semaforizadas — WCAG AA sobre blanco */
.cm5am-dash-card.cm5am-verde  .cm5am-dash-n { color: #15803d !important; } /* ~7:1 */
.cm5am-dash-card.cm5am-rojo   .cm5am-dash-n { color: #b91c1c !important; } /* ~7:1 */
.cm5am-dash-card.cm5am-dorado .cm5am-dash-n { color: #7a5900 !important; } /* ~7.8:1 */
.cm5am-dash-card.cm5am-azul   .cm5am-dash-n { color: #1d4ed8 !important; } /* ~7.8:1 */

/* =============================================================
   6. SEMAFORO / NIVEL GLOBAL
   ============================================================= */
.cm5am-dash-semaforo {
    background: #ffffff !important;
    border: 1px solid rgba(201, 168, 68, .22) !important;
    border-radius: 14px !important;
    padding: 20px !important;
    margin: 16px 0 !important;
    box-shadow: 0 2px 10px rgba(201, 168, 68, .08) !important;
    color: #1a1200 !important;
}
.cm5am-dash-semaforo h2,
.cm5am-dash-semaforo h3,
.cm5am-dash-semaforo p { color: #1a1200 !important; }

.cm5am-semaforo {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 5px 16px;
    border-radius: 999px;
    font-size: .87rem;
    font-weight: 700;
    border: 1px solid transparent;
}
.cm5am-semaforo-fuerte  { background: rgba(21,128,61,.10) !important; color: #15803d !important; border-color: rgba(21,128,61,.30) !important; }
.cm5am-semaforo-moderado{ background: rgba(146,64,14,.10) !important; color: #92400e !important; border-color: rgba(146,64,14,.30) !important; }
.cm5am-semaforo-debil   { background: rgba(185,28,28,.10) !important; color: #b91c1c !important; border-color: rgba(185,28,28,.30) !important; }

/* =============================================================
   7. TABLA DE RANGOS (Ver todos los niveles)
   ============================================================= */
.cm5am-niveles {
    max-width: 900px;
    margin: 22px auto 0;
    background: #ffffff !important;
    border: 1px solid rgba(201, 168, 68, .25) !important;
    border-radius: 14px !important;
    overflow: hidden;
    box-shadow: 0 2px 12px rgba(201, 168, 68, .08) !important;
}
.cm5am-niveles-toggle {
    cursor: pointer;
    padding: 16px 20px;
    font-weight: 700;
    color: #7a5900 !important;
    list-style: none;
    user-select: none;
    font-size: 1.02rem;
    background: transparent !important;
}
.cm5am-niveles-toggle::-webkit-details-marker { display: none; }
.cm5am-niveles-toggle::after { content: " ▾"; color: #9a8a70; }
.cm5am-niveles[open] .cm5am-niveles-toggle::after { content: " ▴"; }
.cm5am-niveles-toggle:hover { background: rgba(201, 168, 68, .07) !important; }
.cm5am-niveles-toggle svg,
.cm5am-summary-icon svg { color: #7a5900 !important; }

.cm5am-niveles-grid { padding: 0 8px 12px; }
.cm5am-niveles-head,
.cm5am-nivel-row {
    display: grid;
    grid-template-columns: 44px 1fr 90px 56px;
    align-items: center;
    gap: 8px;
    padding: 9px 14px;
}
.cm5am-niveles-head {
    color: #7a5900 !important;
    font-size: .72rem;
    text-transform: uppercase;
    letter-spacing: .05em;
    font-weight: 700;
    border-bottom: 1px solid rgba(201, 168, 68, .20) !important;
}
.cm5am-nivel-row { border-bottom: 1px solid rgba(201, 168, 68, .10) !important; color: #1a1200 !important; }
.cm5am-nivel-nombre { display: flex; flex-direction: column; color: #1a1200 !important; font-weight: 600; font-size: .95rem; }
.cm5am-nivel-nombre small { color: #7a5900 !important; font-weight: 400; font-size: .78rem; }
.cm5am-nivel-xp { color: #7a5900 !important; font-variant-numeric: tabular-nums; text-align: right; font-size: .9rem; font-weight: 600; }
.cm5am-nivel-estado { text-align: center; }
.cm5am-nivel-row.cm5am-nivel-ok   { background: rgba(201, 168, 68, .07) !important; }
.cm5am-nivel-row.cm5am-nivel-lock { opacity: .5 !important; }

/* Iconos de estado */
.cm5am-status-ok     { display: inline-flex; align-items: center; }
.cm5am-status-ok svg { color: #15803d !important; }
.cm5am-status-special     { display: inline-flex; align-items: center; }
.cm5am-status-special svg { color: #7a5900 !important; }
.cm5am-status-lock     { display: inline-flex; align-items: center; }
.cm5am-status-lock svg { color: rgba(0,0,0,.28) !important; }
.cm5am-nivel-estado svg,
.cm5am-status-ok svg,
.cm5am-status-special svg,
.cm5am-status-lock svg { vertical-align: middle; }

/* =============================================================
   8. BANCO INTERACTIVO (sesion de preguntas)
   ============================================================= */
#cm5am-pregunta-wrap,
#cm5am-resultados {
    background: #ffffff !important;
    border: 1px solid rgba(201, 168, 68, .22) !important;
    border-radius: 14px !important;
    box-shadow: 0 4px 16px rgba(201, 168, 68, .10) !important;
    color: #1a1200 !important;
}
.cm5am-enunciado { color: #1a1200 !important; font-size: 1.05rem !important; line-height: 1.65 !important; }

.cm5am-alt {
    background: #fffdf7 !important;
    border: 2px solid rgba(201, 168, 68, .28) !important;
    color: #1a1200 !important;
    border-radius: 10px !important;
    transition: border-color .2s, background .2s;
}
.cm5am-alt:hover:not(:disabled) { border-color: #c9a844 !important; background: rgba(201, 168, 68, .08) !important; }
.cm5am-alt.cm5am-alt-correcta,
.cm5am-alt.cm5am-alt-reveal-ok  { border-color: #15803d !important; background: rgba(21,128,61,.09) !important; color: #14532d !important; }
.cm5am-alt.cm5am-alt-incorrecta { border-color: #b91c1c !important; background: rgba(185,28,28,.09) !important; color: #7f1d1d !important; }

.cm5am-feedback { border-top-color: rgba(201, 168, 68, .20) !important; }
.cm5am-feedback-explicacion {
    background: #fffdf7 !important;
    border-left: 4px solid #c9a844 !important;
    color: #1a1200 !important;
    border-radius: 0 8px 8px 0;
    padding: 12px 16px;
}
.cm5am-feedback-explicacion h3,
.cm5am-feedback-explicacion h4 { color: #7a5900 !important; }

.cm5am-stat { background: #f5f0e4 !important; border-radius: 8px; color: #1a1200 !important; }
.cm5am-stat span:last-child { color: #7a5900 !important; }
.cm5am-badge { background: #f5f0e4 !important; color: #3d2900 !important; border-radius: 999px !important; }
.cm5am-barra-progress { background: rgba(201, 168, 68, .15) !important; }

/* =============================================================
   9. RESPONSIVE
   ============================================================= */
@media (max-width: 600px) {
    .cm5am-niveles-head { display: none; }
    .cm5am-nivel-row { grid-template-columns: 38px 1fr 70px 40px; padding: 8px 10px; }
    .cm5am-dash-cards { grid-template-columns: repeat(2, 1fr); }
}
