/* ============================================================
   SIMULADO ALECE 2026 — Design System com Temas Diários
   Centro de Mediação do Ceará
   ============================================================ */

/* ── Tokens base ─────────────────────────────────────────── */
:root {
  --p:       #1565C0;
  --p-l:     #1976D2;
  --p-d:     #0D47A1;
  --p-bg:    #E3F2FD;
  --p-bg2:   #BBDEFB;
  --acerto:  #2E7D32;
  --erro:    #C62828;
  --aviso:   #E65100;
  --cinza:   #607D8B;
  --cinza-l: #ECEFF1;
  --cinza-d: #37474F;
  --texto:   #1A237E;
  --texto2:  #546E7A;
  --bg:      #F0F4FF;
  --card-bg: #FFFFFF;
  --sombra:  0 4px 24px rgba(21,101,192,.13);
  --sombra2: 0 2px 10px rgba(0,0,0,.08);
  --raio:    16px;
  --raio-sm: 10px;
  --trans:   all .22s cubic-bezier(.4,0,.2,1);
  --grad:    linear-gradient(135deg, var(--p-d) 0%, var(--p) 60%, var(--p-l) 100%);
}

/* ── Temas Diários ─────────────────────────────────────────
   Segunda (1): Azul Institucional (padrão ALECE)
   Terça   (2): Verde Esperança
   Quarta  (3): Roxo Inovação
   Quinta  (4): Laranja Energia
   Sexta   (5): Índigo Foco
   Sábado  (6): Teal Serenidade
   Domingo (0): Dourado Conquista
─────────────────────────────────────────────────────────── */

[data-tema="segunda"] {
  --p:#1565C0; --p-l:#1976D2; --p-d:#0D47A1; --p-bg:#E3F2FD; --p-bg2:#BBDEFB;
  --texto:#0D47A1; --bg:#F0F4FF;
  --grad:linear-gradient(135deg,#0D47A1 0%,#1565C0 60%,#42A5F5 100%);
  --tema-nome:"Segunda · Azul Institucional 🏛️";
  --tema-emoji:"🏛️";
}
[data-tema="terca"] {
  --p:#1B5E20; --p-l:#2E7D32; --p-d:#1A3E20; --p-bg:#E8F5E9; --p-bg2:#C8E6C9;
  --texto:#1B5E20; --bg:#F1F8E9;
  --grad:linear-gradient(135deg,#1B5E20 0%,#2E7D32 60%,#66BB6A 100%);
  --tema-nome:"Terça · Verde Esperança 🌿";
  --tema-emoji:"🌿";
}
[data-tema="quarta"] {
  --p:#4A148C; --p-l:#6A1B9A; --p-d:#2E0054; --p-bg:#F3E5F5; --p-bg2:#E1BEE7;
  --texto:#4A148C; --bg:#F8F0FF;
  --grad:linear-gradient(135deg,#2E0054 0%,#4A148C 60%,#AB47BC 100%);
  --tema-nome:"Quarta · Roxo Inovação 🔮";
  --tema-emoji:"🔮";
}
[data-tema="quinta"] {
  --p:#BF360C; --p-l:#D84315; --p-d:#870000; --p-bg:#FBE9E7; --p-bg2:#FFCCBC;
  --texto:#BF360C; --bg:#FFF8F5;
  --grad:linear-gradient(135deg,#870000 0%,#BF360C 60%,#FF7043 100%);
  --tema-nome:"Quinta · Laranja Energia 🔥";
  --tema-emoji:"🔥";
}
[data-tema="sexta"] {
  --p:#1A237E; --p-l:#283593; --p-d:#0D0D5E; --p-bg:#E8EAF6; --p-bg2:#C5CAE9;
  --texto:#1A237E; --bg:#EEF0FF;
  --grad:linear-gradient(135deg,#0D0D5E 0%,#1A237E 60%,#5C6BC0 100%);
  --tema-nome:"Sexta · Índigo Foco 🎯";
  --tema-emoji:"🎯";
}
[data-tema="sabado"] {
  --p:#004D40; --p-l:#00695C; --p-d:#001F1A; --p-bg:#E0F2F1; --p-bg2:#B2DFDB;
  --texto:#004D40; --bg:#F0FAFA;
  --grad:linear-gradient(135deg,#001F1A 0%,#004D40 60%,#26A69A 100%);
  --tema-nome:"Sábado · Teal Serenidade 🌊";
  --tema-emoji:"🌊";
}
[data-tema="domingo"] {
  --p:#827717; --p-l:#9E9D24; --p-d:#524C00; --p-bg:#FFFDE7; --p-bg2:#FFF9C4;
  --texto:#524C00; --bg:#FFFFF0;
  --grad:linear-gradient(135deg,#524C00 0%,#827717 60%,#D4E157 100%);
  --tema-nome:"Domingo · Dourado Conquista 🏆";
  --tema-emoji:"🏆";
}

/* ── Reset & Base ────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{
  font-family:'Segoe UI',system-ui,-apple-system,sans-serif;
  background:var(--bg);
  color:var(--texto);
  line-height:1.6;
  min-height:100vh;
  transition:background .4s ease,color .4s ease;
}
img{max-width:100%;height:auto}
a{color:var(--p);text-decoration:none}
button{font-family:inherit;cursor:pointer}

/* ── Tela / Roteamento ───────────────────────────────────── */
.tela{display:none!important}
.tela.ativa{display:block!important}

/* ── Cabeçalho ───────────────────────────────────────────── */
.cabecalho{
  background:var(--grad);
  color:#fff;
  position:sticky;top:0;z-index:100;
  box-shadow:0 2px 16px rgba(0,0,0,.25);
}
.cabecalho-inner{
  max-width:1100px;margin:0 auto;
  padding:10px 20px;
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  flex-wrap:wrap;
}
.cabecalho-logo{display:flex;align-items:center;gap:12px}
.cabecalho-logo-img{height:38px;width:auto;object-fit:contain;filter:brightness(0) invert(1) drop-shadow(0 1px 2px rgba(0,0,0,.3))}
.cabecalho-divisor{width:1px;height:36px;background:rgba(255,255,255,.35)}
.cabecalho-titulo{font-size:1rem;font-weight:700;letter-spacing:.3px}
.cabecalho-subtitulo{font-size:.72rem;opacity:.82}
.cabecalho-acoes{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.btn-icone{
  background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.3);
  color:#fff;border-radius:50px;padding:6px 13px;font-size:.78rem;
  display:flex;align-items:center;gap:5px;font-weight:600;
  transition:var(--trans);white-space:nowrap;
}
.btn-icone:hover{background:rgba(255,255,255,.32);transform:translateY(-1px)}
.streak-badge{
  background:linear-gradient(135deg,#FF6F00,#FFA000);
  border:none;color:#fff;border-radius:50px;padding:5px 12px;
  font-size:.78rem;font-weight:700;display:flex;align-items:center;gap:4px;
  box-shadow:0 2px 8px rgba(255,160,0,.5);
}

/* ── Banner de tema diário ───────────────────────────────── */
.banner-tema{
  background:var(--grad);
  color:rgba(255,255,255,.92);
  text-align:center;padding:6px 20px;font-size:.8rem;font-weight:600;
  letter-spacing:.5px;
  border-bottom:2px solid rgba(255,255,255,.2);
}

/* ── Banner de atualizações ──────────────────────────────── */
.banner-update{
  background:#0D47A1;color:#fff;
  padding:8px 20px;
  display:none;align-items:center;justify-content:space-between;
  gap:12px;font-size:.84rem;flex-wrap:wrap;
}
.banner-update.visivel{display:flex}
.banner-update-link{
  background:#fff;color:#0D47A1;
  padding:3px 13px;border-radius:20px;font-weight:700;font-size:.76rem;
}
.banner-update-fechar{background:none;border:none;color:#fff;font-size:1.1rem;padding:2px 6px}

/* ── Container principal ─────────────────────────────────── */
.container{max-width:1100px;margin:0 auto;padding:0 16px}

/* ── Hero / Tela inicial ─────────────────────────────────── */
.hero{
  background:var(--grad);
  border-radius:0 0 28px 28px;
  padding:36px 20px 40px;
  color:#fff;text-align:center;
  margin-bottom:28px;
  position:relative;overflow:hidden;
}
.hero::before{
  content:'';position:absolute;inset:0;
  background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.04'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
}
.hero-logo-wrap{margin-bottom:12px}
.hero-logo{height:56px;filter:brightness(0) invert(1) drop-shadow(0 2px 8px rgba(0,0,0,.3));position:relative}
.hero-ano-badge{
  display:inline-block;background:rgba(255,255,255,.22);
  border:1px solid rgba(255,255,255,.4);border-radius:50px;
  padding:4px 16px;font-size:.8rem;font-weight:700;
  letter-spacing:.8px;margin-bottom:14px;position:relative;
}
.hero h1{font-size:clamp(1.5rem,4vw,2.2rem);font-weight:800;margin-bottom:8px;position:relative}
.hero p{font-size:.95rem;opacity:.9;max-width:600px;margin:0 auto 20px;position:relative}
.hero-stats{
  display:flex;justify-content:center;gap:24px;flex-wrap:wrap;
  margin-top:24px;position:relative;
}
.hero-stat{
  background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.25);
  border-radius:14px;padding:10px 20px;min-width:80px;
  backdrop-filter:blur(6px);
}
.hero-stat-num{display:block;font-size:1.6rem;font-weight:800;line-height:1}
.hero-stat-label{font-size:.7rem;opacity:.82;font-weight:600;letter-spacing:.4px;text-transform:uppercase}

/* ── Questão do dia ──────────────────────────────────────── */
.questao-do-dia{
  background:var(--card-bg);border-radius:var(--raio);
  border-left:4px solid var(--p);
  padding:20px 22px;margin-bottom:24px;
  box-shadow:var(--sombra2);
  display:flex;align-items:flex-start;gap:16px;
  flex-wrap:wrap;
}
.qdd-badge{
  background:var(--p-bg);color:var(--p);
  font-size:.7rem;font-weight:800;letter-spacing:.5px;text-transform:uppercase;
  padding:3px 10px;border-radius:50px;white-space:nowrap;flex-shrink:0;
  margin-top:2px;
}
.qdd-texto{flex:1;min-width:200px}
.qdd-texto h3{font-size:.92rem;font-weight:700;color:var(--texto);margin-bottom:4px}
.qdd-texto p{font-size:.84rem;color:var(--texto2);line-height:1.5}
.qdd-btn{
  background:var(--p);color:#fff;border:none;
  border-radius:50px;padding:8px 18px;font-size:.82rem;font-weight:700;
  white-space:nowrap;flex-shrink:0;align-self:center;
  transition:var(--trans);
}
.qdd-btn:hover{background:var(--p-d);transform:translateY(-1px);box-shadow:0 4px 14px rgba(0,0,0,.2)}

/* ── Grid de features ────────────────────────────────────── */
.section-titulo{
  font-size:1.05rem;font-weight:700;color:var(--texto);
  margin-bottom:14px;display:flex;align-items:center;gap:8px;
}
.section-titulo::after{content:'';flex:1;height:1px;background:var(--p-bg2);margin-left:8px}
.features-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(160px,1fr));
  gap:14px;margin-bottom:28px;
}
.feature-card{
  background:var(--card-bg);border-radius:var(--raio);
  padding:20px 14px;text-align:center;cursor:pointer;
  box-shadow:var(--sombra2);border:2px solid transparent;
  transition:var(--trans);position:relative;overflow:hidden;
}
.feature-card:hover{
  border-color:var(--p);transform:translateY(-3px);
  box-shadow:0 8px 28px rgba(0,0,0,.12);
}
.feature-card.destaque{
  background:var(--p-bg);border-color:var(--p-bg2);
}
.feature-card-emoji{font-size:2rem;margin-bottom:8px;display:block}
.feature-card-titulo{font-size:.84rem;font-weight:700;color:var(--texto);margin-bottom:3px}
.feature-card-desc{font-size:.72rem;color:var(--texto2)}
.feature-novo{
  position:absolute;top:8px;right:8px;
  background:var(--p);color:#fff;
  font-size:.6rem;font-weight:800;padding:2px 7px;border-radius:50px;
  letter-spacing:.4px;text-transform:uppercase;
}

/* ── Painel de agentes ───────────────────────────────────── */
.agentes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px;margin-bottom:28px}
.agente-card{
  background:var(--card-bg);border-radius:var(--raio);
  padding:18px;box-shadow:var(--sombra2);
  border:1px solid var(--p-bg2);
  display:flex;flex-direction:column;gap:10px;
}
.agente-header{display:flex;align-items:center;gap:10px}
.agente-avatar{
  width:42px;height:42px;border-radius:50%;
  background:var(--p-bg);display:flex;align-items:center;justify-content:center;
  font-size:1.2rem;flex-shrink:0;
  border:2px solid var(--p-bg2);
}
.agente-info{flex:1}
.agente-nome{font-size:.88rem;font-weight:700;color:var(--texto)}
.agente-status{display:flex;align-items:center;gap:5px;font-size:.72rem;color:var(--texto2)}
.agente-pulse{
  width:7px;height:7px;border-radius:50%;background:#4CAF50;
  animation:pulse 2s ease-in-out infinite;
}
.agente-pulse.inativo{background:#9E9E9E;animation:none}
.agente-pulse.alerta{background:#FF9800}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.4)}}
.agente-msg{
  font-size:.78rem;color:var(--texto2);line-height:1.5;
  background:var(--p-bg);border-radius:8px;padding:8px 10px;
  border-left:3px solid var(--p);
}
.agente-tempo{font-size:.68rem;color:var(--cinza);text-align:right}

/* ── Seleção de nível ────────────────────────────────────── */
.nivel-select{display:flex;flex-direction:column;align-items:center;padding:32px 20px}
.nivel-select h2{font-size:1.4rem;font-weight:800;margin-bottom:6px;text-align:center}
.nivel-select p{color:var(--texto2);margin-bottom:28px;text-align:center}
.niveis-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:18px;width:100%;max-width:600px}
.card-nivel{
  background:var(--card-bg);border-radius:var(--raio);
  padding:28px 22px;cursor:pointer;text-align:center;
  box-shadow:var(--sombra);border:2px solid transparent;
  transition:var(--trans);
}
.card-nivel:hover{transform:translateY(-4px);box-shadow:0 10px 36px rgba(0,0,0,.15)}
.card-nivel.medio{border-color:#1565C0}
.card-nivel.superior{border-color:#2E7D32}
.card-nivel-icone{font-size:2.8rem;margin-bottom:12px;display:block}
.card-nivel h2{font-size:1.2rem;font-weight:800;margin-bottom:6px}
.card-nivel p{font-size:.84rem;color:var(--texto2);margin-bottom:16px}
.card-nivel-count{font-size:.78rem;font-weight:700;padding:4px 14px;border-radius:50px;background:var(--p-bg);color:var(--p)}
.tags-materias{display:flex;flex-wrap:wrap;gap:5px;justify-content:center;margin:10px 0}
.tag-materia{
  font-size:.68rem;font-weight:600;padding:3px 9px;border-radius:50px;
  background:var(--p-bg);color:var(--p);border:1px solid var(--p-bg2);
}

/* ── Tela de configuração ────────────────────────────────── */
.config-bloco{
  background:var(--card-bg);border-radius:var(--raio);
  padding:20px;margin-bottom:16px;box-shadow:var(--sombra2);
}
.config-bloco h3{font-size:.9rem;font-weight:700;margin-bottom:14px;color:var(--texto);display:flex;align-items:center;gap:6px}
.chips{display:flex;flex-wrap:wrap;gap:8px}
.chip{
  padding:7px 14px;border-radius:50px;font-size:.8rem;font-weight:600;cursor:pointer;
  border:2px solid var(--p-bg2);background:var(--card-bg);color:var(--texto2);
  transition:var(--trans);
}
.chip.ativo{background:var(--p);color:#fff;border-color:var(--p)}
.chip:hover:not(.ativo){border-color:var(--p);color:var(--p);background:var(--p-bg)}
.range-wrap{display:flex;align-items:center;gap:12px}
.range-val{
  min-width:48px;text-align:center;font-size:1.1rem;font-weight:800;
  color:var(--p);background:var(--p-bg);border-radius:8px;padding:4px 8px;
}
input[type=range]{
  flex:1;height:6px;border-radius:3px;accent-color:var(--p);cursor:pointer;
}

/* ── Tela de simulado ────────────────────────────────────── */
.simulado-header{
  background:var(--card-bg);border-bottom:1px solid var(--p-bg2);
  position:sticky;top:57px;z-index:50;
  padding:12px 16px;
}
.simulado-progresso{
  display:flex;align-items:center;gap:12px;max-width:1100px;margin:0 auto;
  flex-wrap:wrap;
}
.prog-bar-wrap{flex:1;background:var(--cinza-l);border-radius:50px;height:8px;min-width:80px;overflow:hidden}
.prog-bar{height:100%;background:var(--p);border-radius:50px;transition:width .4s ease}
.prog-texto{font-size:.78rem;font-weight:700;color:var(--texto2);white-space:nowrap}
.timer-badge{
  background:var(--p-bg);border:1px solid var(--p-bg2);
  color:var(--p);font-weight:800;padding:4px 12px;border-radius:50px;font-size:.82rem;
  white-space:nowrap;
}
.timer-badge.urgente{background:#FFEBEE;border-color:#EF9A9A;color:#C62828;animation:pisca 1s ease-in-out infinite}
@keyframes pisca{0%,100%{opacity:1}50%{opacity:.5}}

.questao-card{
  background:var(--card-bg);border-radius:var(--raio);
  padding:24px;margin:20px 0;box-shadow:var(--sombra);
}
.questao-meta{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:14px;align-items:center}
.badge-materia{
  font-size:.68rem;font-weight:800;text-transform:uppercase;letter-spacing:.4px;
  padding:3px 10px;border-radius:50px;background:var(--p-bg);color:var(--p);
  border:1px solid var(--p-bg2);
}
.badge-dif{padding:3px 10px;border-radius:50px;font-size:.68rem;font-weight:700}
.badge-dif.facil{background:#E8F5E9;color:#1B5E20}
.badge-dif.media{background:#FFF8E1;color:#F57F17}
.badge-dif.dificil{background:#FFEBEE;color:#B71C1C}
.badge-edital{background:#F3E5F5;color:#4A148C;padding:3px 10px;border-radius:50px;font-size:.68rem;font-weight:700}
.badge-ano{background:var(--cinza-l);color:var(--cinza-d);padding:3px 10px;border-radius:50px;font-size:.68rem;font-weight:600}
.questao-enunciado{
  font-size:.97rem;line-height:1.7;color:var(--texto);
  margin-bottom:20px;white-space:pre-line;
}
.alternativas{display:flex;flex-direction:column;gap:8px}
.alternativa{
  background:var(--bg);border:2px solid var(--cinza-l);
  border-radius:12px;padding:12px 16px;cursor:pointer;
  font-size:.88rem;line-height:1.5;color:var(--texto);
  transition:var(--trans);display:flex;align-items:flex-start;gap:10px;
}
.alternativa:hover:not(.desativada){background:var(--p-bg);border-color:var(--p-bg2)}
.alternativa.selecionada{background:var(--p-bg);border-color:var(--p)}
.alternativa.correta{background:#E8F5E9;border-color:#4CAF50;color:#1B5E20}
.alternativa.errada{background:#FFEBEE;border-color:#EF5350;color:#B71C1C}
.alternativa.gabarito-indicado{background:#E8F5E9;border-color:#4CAF50}
.alternativa.desativada{cursor:default;pointer-events:none}
.alt-letra{
  font-weight:800;font-size:.82rem;min-width:20px;padding-top:1px;
  color:var(--texto2);
}
.alternativa.correta .alt-letra{color:#1B5E20}
.alternativa.errada .alt-letra{color:#B71C1C}
.alt-icone{margin-left:auto;font-size:1rem}

.explicacao-box{
  background:var(--p-bg);border-left:4px solid var(--p);
  border-radius:0 12px 12px 0;padding:14px 16px;
  margin-top:14px;font-size:.84rem;line-height:1.6;color:var(--texto);
  display:none;
}
.explicacao-box.visivel{display:block}

/* ── Podcast player ──────────────────────────────────────── */
.podcast-btn{
  background:none;border:2px solid var(--p);
  color:var(--p);border-radius:50px;padding:6px 14px;
  font-size:.78rem;font-weight:700;display:flex;align-items:center;gap:6px;
  transition:var(--trans);
}
.podcast-btn:hover,.podcast-btn.ativo{background:var(--p);color:#fff}
.podcast-btn.ativo{animation:nenhuma 0s}

#podcast-flutuante{
  position:fixed;bottom:80px;right:16px;z-index:200;
  background:var(--card-bg);border-radius:20px;
  box-shadow:0 8px 32px rgba(0,0,0,.2);padding:14px 18px;
  min-width:240px;display:none;
  border:2px solid var(--p-bg2);
}
#podcast-flutuante.visivel{display:block}
.podcast-agora{font-size:.72rem;color:var(--texto2);margin-bottom:6px;font-weight:600;text-transform:uppercase;letter-spacing:.4px}
.podcast-titulo{font-size:.84rem;font-weight:700;color:var(--texto);margin-bottom:10px;line-height:1.4}
.podcast-controles{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.podcast-ctrl-btn{
  background:var(--p);color:#fff;border:none;border-radius:50px;
  padding:5px 12px;font-size:.75rem;font-weight:700;transition:var(--trans);
}
.podcast-ctrl-btn:hover{background:var(--p-d);transform:scale(1.05)}
.podcast-ctrl-btn.secundario{background:var(--p-bg);color:var(--p)}
.podcast-vel{
  font-size:.72rem;font-weight:700;color:var(--texto2);padding:4px 8px;
  background:var(--cinza-l);border-radius:50px;cursor:pointer;
}
.podcast-progress{
  height:4px;background:var(--cinza-l);border-radius:2px;margin-top:8px;overflow:hidden;
}
.podcast-progress-fill{height:100%;background:var(--p);width:0%;transition:width .5s linear}

/* ── Tela de resultados ──────────────────────────────────── */
.resultado-hero{
  background:var(--grad);border-radius:var(--raio);
  color:#fff;text-align:center;padding:32px 20px;margin-bottom:20px;
}
.resultado-nota{font-size:4rem;font-weight:900;line-height:1}
.resultado-msg{font-size:1rem;margin:8px 0 0;opacity:.9}
.resultado-stats{display:flex;justify-content:center;gap:20px;flex-wrap:wrap;margin-top:20px}
.resultado-stat{background:rgba(255,255,255,.15);border-radius:12px;padding:10px 18px;text-align:center}
.resultado-stat-val{font-size:1.4rem;font-weight:800;display:block}
.resultado-stat-label{font-size:.68rem;opacity:.8;text-transform:uppercase;letter-spacing:.4px}
.barras-materia{margin-bottom:28px}
.barra-item{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.barra-label{font-size:.8rem;width:160px;flex-shrink:0;font-weight:600;color:var(--texto2)}
.barra-wrap{flex:1;height:12px;background:var(--cinza-l);border-radius:6px;overflow:hidden}
.barra-fill{height:100%;border-radius:6px;background:var(--p);transition:width 1s ease}
.barra-val{font-size:.78rem;font-weight:700;width:40px;text-align:right;flex-shrink:0;color:var(--texto)}

/* ── Revisão / Gabarito ──────────────────────────────────── */
.revisao-item{
  background:var(--card-bg);border-radius:var(--raio);
  padding:20px;margin-bottom:14px;box-shadow:var(--sombra2);
  border-left:4px solid var(--cinza-l);
}
.revisao-item.acerto{border-left-color:#4CAF50}
.revisao-item.erro{border-left-color:#EF5350}
.revisao-item.nao-respondida{border-left-color:#FF9800}
.revisao-header{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:10px}
.revisao-num{font-size:.78rem;font-weight:700;color:var(--texto2)}
.revisao-icone{font-size:1.1rem}
.revisao-enunciado{font-size:.86rem;line-height:1.6;color:var(--texto);margin-bottom:10px}
.revisao-resposta{display:flex;gap:8px;flex-wrap:wrap;font-size:.8rem;font-weight:600}
.revisao-sua{background:#FFEBEE;color:#B71C1C;padding:3px 10px;border-radius:50px}
.revisao-sua.correto{background:#E8F5E9;color:#1B5E20}
.revisao-gabarito{background:#E8F5E9;color:#1B5E20;padding:3px 10px;border-radius:50px}

/* ── Flashcards ──────────────────────────────────────────── */
.flashcard-wrap{perspective:1000px;height:260px;margin:20px 0;cursor:pointer}
.flashcard{
  width:100%;height:100%;position:relative;
  transform-style:preserve-3d;transition:transform .6s cubic-bezier(.4,0,.2,1);
}
.flashcard.virado{transform:rotateY(180deg)}
.flashcard-frente,.flashcard-verso{
  position:absolute;inset:0;
  background:var(--card-bg);border-radius:var(--raio);
  box-shadow:var(--sombra);padding:28px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;backface-visibility:hidden;
}
.flashcard-verso{transform:rotateY(180deg);background:var(--p-bg)}
.flashcard-instrucao{font-size:.72rem;color:var(--texto2);margin-top:12px;text-transform:uppercase;letter-spacing:.5px}
.fc-pergunta{font-size:.95rem;line-height:1.6;color:var(--texto);font-weight:600}
.fc-resposta{font-size:.9rem;line-height:1.6;color:var(--p-d)}

/* ── Dashboard de agentes ────────────────────────────────── */
.agente-full-card{
  background:var(--card-bg);border-radius:var(--raio);
  padding:22px;margin-bottom:16px;box-shadow:var(--sombra2);
}
.agente-full-header{display:flex;align-items:center;gap:14px;margin-bottom:14px}
.agente-full-avatar{
  width:52px;height:52px;border-radius:50%;
  background:var(--grad);color:#fff;
  display:flex;align-items:center;justify-content:center;font-size:1.4rem;
  flex-shrink:0;
}
.agente-full-info h3{font-size:1rem;font-weight:800;margin-bottom:2px}
.agente-full-info p{font-size:.78rem;color:var(--texto2)}
.agente-logs{display:flex;flex-direction:column;gap:6px;max-height:200px;overflow-y:auto}
.agente-log{
  font-size:.78rem;padding:7px 10px;border-radius:8px;
  background:var(--bg);color:var(--texto2);line-height:1.4;
  border-left:3px solid var(--p-bg2);
}
.agente-log.destaque{border-left-color:var(--p);background:var(--p-bg);color:var(--texto)}

/* ── Histórico e feed de notícias ────────────────────────── */
.news-feed{display:flex;flex-direction:column;gap:10px;margin-bottom:24px}
.news-item{
  background:var(--card-bg);border-radius:var(--raio-sm);
  padding:14px;box-shadow:var(--sombra2);
  display:flex;align-items:flex-start;gap:12px;
}
.news-item-dot{
  width:10px;height:10px;border-radius:50%;background:var(--p);
  flex-shrink:0;margin-top:5px;
}
.news-item-dot.urgente{background:#F44336}
.news-item-titulo{font-size:.85rem;font-weight:700;color:var(--texto);margin-bottom:3px}
.news-item-meta{font-size:.72rem;color:var(--texto2)}
.news-item-fonte{font-size:.72rem;font-weight:600;color:var(--p)}

/* ── Historico simulados ─────────────────────────────────── */
.historico-lista{display:flex;flex-direction:column;gap:8px;margin-bottom:24px}
.historico-item{
  background:var(--card-bg);border-radius:var(--raio-sm);
  padding:12px 16px;box-shadow:var(--sombra2);
  display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;
}
.historico-info{flex:1}
.historico-info strong{font-size:.86rem;color:var(--texto);display:block}
.historico-info small{font-size:.72rem;color:var(--texto2)}
.historico-nota{
  font-size:1.2rem;font-weight:800;
  width:54px;height:54px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.historico-nota.otimo{background:#E8F5E9;color:#1B5E20}
.historico-nota.bom{background:#FFF8E1;color:#F57F17}
.historico-nota.ruim{background:#FFEBEE;color:#B71C1C}

/* ── Botões gerais ───────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:7px;
  padding:11px 24px;border-radius:50px;font-size:.88rem;font-weight:700;
  border:none;cursor:pointer;transition:var(--trans);text-decoration:none;white-space:nowrap;
}
.btn-primary{background:var(--p);color:#fff}
.btn-primary:hover{background:var(--p-d);transform:translateY(-2px);box-shadow:0 6px 20px rgba(0,0,0,.2)}
.btn-outline{background:transparent;color:var(--p);border:2px solid var(--p)}
.btn-outline:hover{background:var(--p-bg)}
.btn-danger{background:#C62828;color:#fff}
.btn-danger:hover{background:#B71C1C;transform:translateY(-1px)}
.btn-sm{padding:7px 16px;font-size:.78rem}
.btn-lg{padding:14px 32px;font-size:1rem}
.btn-block{width:100%;justify-content:center}

/* ── Navegação inferior de simulado ─────────────────────── */
.nav-questao{
  display:flex;justify-content:space-between;align-items:center;
  gap:10px;padding:16px 0;flex-wrap:wrap;
}

/* ── Toast ────────────────────────────────────────────────── */
#toast-wrap{position:fixed;bottom:16px;left:50%;transform:translateX(-50%);z-index:999;display:flex;flex-direction:column;gap:8px;align-items:center;pointer-events:none}
.toast{
  background:var(--cinza-d);color:#fff;
  padding:10px 20px;border-radius:50px;font-size:.82rem;font-weight:600;
  box-shadow:0 4px 20px rgba(0,0,0,.25);
  animation:toastIn .3s ease,toastOut .3s ease .7s both;
  pointer-events:none;white-space:nowrap;max-width:90vw;
}
.toast.sucesso{background:#1B5E20}
.toast.erro{background:#B71C1C}
@keyframes toastIn{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
@keyframes toastOut{from{opacity:1}to{opacity:0;transform:translateY(8px)}}

/* ── Gabarito / Filtros de revisão ──────────────────────── */
.filtros-revisao{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}
.filtro-btn{
  padding:6px 14px;border-radius:50px;font-size:.78rem;font-weight:700;
  border:2px solid var(--cinza-l);background:var(--card-bg);color:var(--texto2);
  cursor:pointer;transition:var(--trans);
}
.filtro-btn.ativo{background:var(--p);color:#fff;border-color:var(--p)}

/* ── Modo Podcast tela cheia ─────────────────────────────── */
.podcast-tela{
  background:var(--grad);min-height:100vh;
  padding:40px 20px;color:#fff;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;gap:24px;
}
.podcast-disco{
  width:160px;height:160px;border-radius:50%;
  background:rgba(255,255,255,.15);
  display:flex;align-items:center;justify-content:center;
  font-size:4rem;
  border:3px solid rgba(255,255,255,.3);
  animation:girar 8s linear infinite;
  box-shadow:0 0 0 12px rgba(255,255,255,.08),0 0 0 24px rgba(255,255,255,.04);
}
.podcast-disco.pausado{animation-play-state:paused}
@keyframes girar{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
.podcast-questao-numero{font-size:.85rem;opacity:.75;font-weight:700;letter-spacing:.6px;text-transform:uppercase}
.podcast-questao-texto{font-size:1rem;line-height:1.7;max-width:640px;background:rgba(255,255,255,.12);border-radius:16px;padding:20px}
.podcast-controls-main{display:flex;align-items:center;gap:16px;flex-wrap:wrap;justify-content:center}
.podcast-main-btn{
  width:58px;height:58px;border-radius:50%;border:none;cursor:pointer;
  font-size:1.3rem;display:flex;align-items:center;justify-content:center;
  transition:var(--trans);
}
.podcast-main-btn.play{background:#fff;color:var(--p-d);box-shadow:0 4px 20px rgba(0,0,0,.2)}
.podcast-main-btn.skip{background:rgba(255,255,255,.2);color:#fff}
.podcast-main-btn:hover{transform:scale(1.1)}
.podcast-vel-btns{display:flex;gap:6px;flex-wrap:wrap;justify-content:center}
.podcast-vel-btn{
  padding:5px 12px;border-radius:50px;border:1px solid rgba(255,255,255,.4);
  background:transparent;color:#fff;font-size:.75rem;font-weight:700;cursor:pointer;
  transition:var(--trans);
}
.podcast-vel-btn.ativo{background:#fff;color:var(--p-d)}

/* ── Utilitários ─────────────────────────────────────────── */
.text-center{text-align:center}
.mt-8{margin-top:8px}.mt-16{margin-top:16px}.mt-24{margin-top:24px}
.mb-8{margin-bottom:8px}.mb-16{margin-bottom:16px}.mb-24{margin-bottom:24px}
.gap-8{gap:8px}.flex{display:flex}.flex-center{display:flex;align-items:center;justify-content:center}
.spacer{flex:1}
.divider{height:1px;background:var(--p-bg2);margin:16px 0}
.empty-state{text-align:center;padding:40px 20px;color:var(--texto2);font-size:.88rem}
.empty-state-emoji{font-size:2.5rem;margin-bottom:8px;display:block}
.back-btn{
  display:inline-flex;align-items:center;gap:6px;
  color:var(--texto2);font-size:.84rem;font-weight:600;cursor:pointer;
  padding:8px 0;border:none;background:none;transition:var(--trans);
}
.back-btn:hover{color:var(--p)}

/* ── Animações de entrada ────────────────────────────────── */
.fade-in{animation:fadeIn .35s ease}
@keyframes fadeIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}

/* ── Responsivo ─────────────────────────────────────────── */
@media(max-width:600px){
  .hero{padding:24px 16px 30px;border-radius:0 0 20px 20px}
  .hero h1{font-size:1.4rem}
  .hero-stats{gap:10px}
  .hero-stat{padding:8px 12px;min-width:60px}
  .hero-stat-num{font-size:1.2rem}
  .features-grid{grid-template-columns:repeat(2,1fr)}
  .agentes-grid{grid-template-columns:1fr}
  .niveis-grid{grid-template-columns:1fr}
  .barra-label{width:110px;font-size:.72rem}
  .resultado-nota{font-size:3rem}
  .questao-card{padding:16px}
  .cabecalho-inner{padding:8px 12px}
  .btn-lg{padding:12px 24px;font-size:.9rem}
  #podcast-flutuante{right:8px;left:8px;min-width:auto}
  .podcast-disco{width:120px;height:120px;font-size:3rem}
}

@media(max-width:400px){
  .features-grid{grid-template-columns:1fr 1fr}
  .feature-card{padding:14px 10px}
  .feature-card-emoji{font-size:1.6rem}
}

/* ╔══════════════════════════════════════════════════════════╗
   ║   SIMULADO DARK PREMIUM — Redesign Claude-Style v2      ║
   ╚══════════════════════════════════════════════════════════╝ */

/* ── Dark base ──────────────────────────────────────────────── */
#tela-simulado {
  background: #080c16;
  min-height: 100vh;
}

/* ── Header sticky dark ─────────────────────────────────────── */
.simulado-header {
  background: rgba(10,14,26,.92);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-bottom: 1px solid rgba(255,255,255,.08);
  top: 0 !important;
  padding: 0 !important;
}
.simulado-progresso {
  padding: 12px 20px;
  gap: 14px;
}
.prog-bar-wrap {
  background: rgba(255,255,255,.08) !important;
  height: 5px !important;
  border-radius: 3px !important;
}
.prog-bar {
  background: linear-gradient(90deg, #1565c0, #42a5f5, #7c4dff) !important;
  box-shadow: 0 0 12px rgba(66,165,245,.5);
  transition: width .5s cubic-bezier(.4,0,.2,1) !important;
}
.prog-texto {
  color: rgba(255,255,255,.55) !important;
  font-size: .75rem !important;
}
.timer-badge {
  background: rgba(255,255,255,.07) !important;
  border-color: rgba(255,255,255,.12) !important;
  color: #e8edf5 !important;
}
.timer-badge.urgente {
  background: rgba(239,68,68,.15) !important;
  border-color: rgba(239,68,68,.4) !important;
  color: #f87171 !important;
}
.btn-icone {
  background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.1);
  color: rgba(255,255,255,.7);
  border-radius: 10px;
  padding: 6px 12px;
  font-size: .8rem;
  font-weight: 600;
  cursor: pointer;
  transition: all .2s;
}
.btn-icone:hover {
  background: rgba(255,255,255,.13);
  color: #fff;
}

/* ── Question card — glassmorphism ──────────────────────────── */
.questao-card {
  background: linear-gradient(145deg, rgba(18,24,42,.95) 0%, rgba(12,17,32,.98) 100%) !important;
  border: 1px solid rgba(255,255,255,.09) !important;
  border-radius: 20px !important;
  box-shadow:
    0 0 0 1px rgba(255,255,255,.04),
    0 24px 64px rgba(0,0,0,.5),
    inset 0 1px 0 rgba(255,255,255,.07) !important;
  padding: 28px !important;
  position: relative;
  overflow: hidden;
}
.questao-card::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at top left, rgba(21,101,192,.08) 0%, transparent 60%);
  pointer-events: none;
}

/* Question number pill */
.questao-num-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: linear-gradient(135deg, rgba(21,101,192,.25), rgba(124,77,255,.15));
  border: 1px solid rgba(21,101,192,.3);
  border-radius: 50px;
  padding: 4px 14px;
  font-size: .72rem;
  font-weight: 800;
  color: #90caf9;
  letter-spacing: .5px;
  text-transform: uppercase;
  margin-bottom: 12px;
  backdrop-filter: blur(4px);
}

/* Meta badges — dark style */
.questao-meta { margin-bottom: 16px !important; }
.badge-materia {
  background: rgba(21,101,192,.2) !important;
  color: #90caf9 !important;
  border-color: rgba(21,101,192,.35) !important;
}
.badge-dif.facil  { background: rgba(27,94,32,.2) !important; color: #86efac !important; }
.badge-dif.media  { background: rgba(245,127,23,.15) !important; color: #fcd34d !important; }
.badge-dif.dificil{ background: rgba(183,28,28,.2) !important; color: #f87171 !important; }
.badge-edital     { background: rgba(74,20,140,.2) !important; color: #d8b4fe !important; }
.badge-ano        { background: rgba(255,255,255,.06) !important; color: rgba(255,255,255,.45) !important; }

/* Enunciado */
.questao-enunciado {
  color: #dde4f0 !important;
  font-size: 1rem !important;
  line-height: 1.75 !important;
  font-weight: 400;
  letter-spacing: .01em;
}

/* ── Alternatives — new dark design ─────────────────────────── */
.alternativas { gap: 10px !important; }
.alternativa {
  background: rgba(255,255,255,.04) !important;
  border: 1.5px solid rgba(255,255,255,.09) !important;
  border-radius: 14px !important;
  padding: 14px 18px !important;
  cursor: pointer;
  color: #c8d5e8 !important;
  font-size: .9rem !important;
  line-height: 1.55 !important;
  transition: all .18s cubic-bezier(.4,0,.2,1) !important;
  display: flex;
  align-items: center;
  gap: 14px;
  position: relative;
  overflow: hidden;
}
.alternativa::after {
  content: '';
  position: absolute;
  inset: 0;
  opacity: 0;
  background: radial-gradient(ellipse at var(--rx,50%) var(--ry,50%), rgba(255,255,255,.08), transparent 70%);
  transition: opacity .3s;
  pointer-events: none;
}
.alternativa:hover:not(.desativada) {
  background: rgba(21,101,192,.12) !important;
  border-color: rgba(21,101,192,.4) !important;
  color: #e8edf5 !important;
  transform: translateX(4px);
  box-shadow: 0 0 0 1px rgba(21,101,192,.2), 0 4px 16px rgba(21,101,192,.15);
}
.alternativa:hover:not(.desativada)::after { opacity: 1; }

/* Letter badge inside alternative */
.alt-letra {
  width: 32px !important;
  height: 32px !important;
  min-width: 32px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  border-radius: 50% !important;
  background: rgba(255,255,255,.08) !important;
  border: 1.5px solid rgba(255,255,255,.12) !important;
  font-size: .8rem !important;
  font-weight: 800 !important;
  color: rgba(255,255,255,.6) !important;
  padding-top: 0 !important;
  transition: all .18s !important;
  flex-shrink: 0;
}
.alternativa:hover:not(.desativada) .alt-letra {
  background: rgba(21,101,192,.3) !important;
  border-color: rgba(21,101,192,.6) !important;
  color: #90caf9 !important;
}

/* Selecionada (antes de confirmar) */
.alternativa.selecionada {
  background: rgba(21,101,192,.15) !important;
  border-color: #1565c0 !important;
  color: #e8edf5 !important;
}
.alternativa.selecionada .alt-letra {
  background: #1565c0 !important;
  border-color: #1565c0 !important;
  color: #fff !important;
}

/* Correta */
.alternativa.correta {
  background: rgba(34,197,94,.1) !important;
  border-color: #22c55e !important;
  color: #bbf7d0 !important;
  animation: pulseCorrect .5s ease;
}
.alternativa.correta .alt-letra {
  background: #16a34a !important;
  border-color: #22c55e !important;
  color: #fff !important;
}
@keyframes pulseCorrect {
  0%   { box-shadow: 0 0 0 0 rgba(34,197,94,.5); }
  50%  { box-shadow: 0 0 0 10px rgba(34,197,94,.1); }
  100% { box-shadow: 0 0 0 0 rgba(34,197,94,0); }
}

/* Errada */
.alternativa.errada {
  background: rgba(239,68,68,.1) !important;
  border-color: #ef4444 !important;
  color: #fca5a5 !important;
  animation: shakeAlt .4s cubic-bezier(.36,.07,.19,.97) both;
}
.alternativa.errada .alt-letra {
  background: #dc2626 !important;
  border-color: #ef4444 !important;
  color: #fff !important;
}
@keyframes shakeAlt {
  10%, 90%  { transform: translateX(-3px); }
  20%, 80%  { transform: translateX(4px); }
  30%, 50%, 70% { transform: translateX(-5px); }
  40%, 60%  { transform: translateX(5px); }
}

/* Alt text — fills remaining space */
.alt-texto { flex: 1; }

/* Alt icone check/x */
.alt-icone {
  margin-left: auto;
  width: 24px;
  height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  font-size: .9rem;
  flex-shrink: 0;
}
.alternativa.correta .alt-icone { background: rgba(34,197,94,.2); }
.alternativa.errada  .alt-icone { background: rgba(239,68,68,.2); }

/* ── Feedback panel ─────────────────────────────────────────── */
.feedback-panel {
  margin-top: 20px;
  border-radius: 16px;
  overflow: hidden;
  animation: feedbackSlideUp .35s cubic-bezier(.4,0,.2,1);
}
@keyframes feedbackSlideUp {
  from { opacity: 0; transform: translateY(20px) scale(.98); }
  to   { opacity: 1; transform: none; }
}

/* Status bar (green/red) */
.feedback-status-bar {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 16px 20px;
  font-weight: 800;
  font-size: 1rem;
}
.feedback-status-bar.correto {
  background: linear-gradient(135deg, rgba(22,163,74,.3), rgba(34,197,94,.2));
  border-top: 2px solid #22c55e;
  color: #86efac;
}
.feedback-status-bar.errado {
  background: linear-gradient(135deg, rgba(220,38,38,.3), rgba(239,68,68,.2));
  border-top: 2px solid #ef4444;
  color: #fca5a5;
}
.feedback-status-icon {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.2rem;
  flex-shrink: 0;
}
.feedback-status-bar.correto .feedback-status-icon { background: rgba(34,197,94,.25); }
.feedback-status-bar.errado  .feedback-status-icon { background: rgba(239,68,68,.25); }

/* Gabarito (quando errou) */
.feedback-gabarito-box {
  padding: 12px 20px;
  background: rgba(34,197,94,.07);
  border-bottom: 1px solid rgba(34,197,94,.15);
  font-size: .85rem;
  color: #86efac;
}
.feedback-gabarito-box strong { color: #4ade80; }

/* Explanation area */
.feedback-exp-box {
  padding: 18px 20px;
  background: rgba(255,255,255,.03);
  border-top: 1px solid rgba(255,255,255,.06);
}
.feedback-exp-titulo {
  font-size: .72rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .6px;
  color: rgba(255,255,255,.4);
  margin-bottom: 8px;
}
.feedback-exp-texto {
  font-size: .88rem;
  line-height: 1.7;
  color: #c8d5e8;
}

/* Feedback actions */
.feedback-actions-bar {
  display: flex;
  gap: 10px;
  padding: 14px 20px;
  background: rgba(255,255,255,.03);
  border-top: 1px solid rgba(255,255,255,.06);
  flex-wrap: wrap;
}
.btn-feedback-audio {
  flex: 1;
  min-width: 140px;
  padding: 10px 16px;
  border-radius: 12px;
  border: 1.5px solid rgba(255,255,255,.15);
  background: transparent;
  color: rgba(255,255,255,.7);
  font-size: .82rem;
  font-weight: 700;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  transition: all .2s;
}
.btn-feedback-audio:hover {
  background: rgba(255,255,255,.07);
  border-color: rgba(255,255,255,.25);
  color: #fff;
}
.btn-feedback-next {
  flex: 2;
  min-width: 160px;
  padding: 12px 24px;
  border-radius: 12px;
  border: none;
  background: linear-gradient(135deg, #1565c0, #1976d2);
  color: #fff;
  font-size: .9rem;
  font-weight: 800;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  transition: all .2s;
  box-shadow: 0 4px 20px rgba(21,101,192,.4);
}
.btn-feedback-next:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 28px rgba(21,101,192,.5);
}
.btn-feedback-next.finalizar {
  background: linear-gradient(135deg, #c62828, #ef4444);
  box-shadow: 0 4px 20px rgba(239,68,68,.4);
}
.btn-feedback-next.finalizar:hover {
  box-shadow: 0 8px 28px rgba(239,68,68,.5);
}

/* Explicação-box (modo estudo legado) — ocultar, feedback-panel substitui */
.explicacao-box { display: none !important; }

/* ── Bottom nav dark ────────────────────────────────────────── */
.nav-questao {
  padding: 20px 0 !important;
}
.nav-questao .btn {
  background: rgba(255,255,255,.07) !important;
  border-color: rgba(255,255,255,.12) !important;
  color: rgba(255,255,255,.7) !important;
  border-radius: 12px !important;
}
.nav-questao .btn:hover {
  background: rgba(255,255,255,.12) !important;
  color: #fff !important;
}
.nav-questao .btn-primary {
  background: linear-gradient(135deg, #1565c0, #1976d2) !important;
  border-color: transparent !important;
  color: #fff !important;
  box-shadow: 0 4px 16px rgba(21,101,192,.35) !important;
}
.nav-questao .btn-primary:hover {
  transform: translateY(-2px) !important;
  box-shadow: 0 8px 24px rgba(21,101,192,.5) !important;
}
.podcast-btn {
  background: rgba(255,255,255,.06) !important;
  border-color: rgba(255,255,255,.14) !important;
  color: rgba(255,255,255,.65) !important;
  border-radius: 12px !important;
}
.podcast-btn:hover, .podcast-btn.ativo {
  background: rgba(21,101,192,.2) !important;
  border-color: rgba(21,101,192,.5) !important;
  color: #90caf9 !important;
}

/* Mapa de questões */
#mapaGrid .mapa-btn {
  width: 36px; height: 36px;
  border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  font-size: .75rem; font-weight: 700;
  border: 1.5px solid rgba(255,255,255,.1);
  background: rgba(255,255,255,.05);
  color: rgba(255,255,255,.5);
  cursor: pointer;
  transition: all .15s;
}
#mapaGrid .mapa-btn.acerto { background: rgba(34,197,94,.15); border-color: #22c55e; color: #86efac; }
#mapaGrid .mapa-btn.erro   { background: rgba(239,68,68,.15);  border-color: #ef4444; color: #fca5a5; }
#mapaGrid .mapa-btn.atual  { background: rgba(21,101,192,.3);  border-color: #1565c0; color: #90caf9; box-shadow: 0 0 0 3px rgba(21,101,192,.3); }
.section-titulo { color: rgba(255,255,255,.5) !important; }

/* ── Card entry animation ───────────────────────────────────── */
@keyframes qCardEnter {
  from { opacity: 0; transform: translateY(24px) scale(.97); }
  to   { opacity: 1; transform: none; }
}
.questao-card.fade-in {
  animation: qCardEnter .38s cubic-bezier(.4,0,.2,1) !important;
}

/* ── Responsive dark ────────────────────────────────────────── */
@media(max-width:600px) {
  .questao-card  { padding: 18px !important; border-radius: 16px !important; }
  .alternativa   { padding: 11px 14px !important; }
  .alt-letra     { width: 28px !important; height: 28px !important; min-width: 28px !important; }
  .feedback-actions-bar { flex-direction: column; }
  .btn-feedback-audio, .btn-feedback-next { flex: none; width: 100%; }
  .questao-enunciado { font-size: .93rem !important; }
}

/* ═══════════════════════════════════════════════════════════
   PAINEL ADMIN
═══════════════════════════════════════════════════════════ */

.btn-admin-header {
  background: rgba(99,102,241,.18);
  border: 1px solid rgba(99,102,241,.35);
  color: #a5b4fc;
}
.btn-admin-header:hover { background: rgba(99,102,241,.35); }

/* Tabs */
.admin-tabs {
  display: flex; gap: 8px; margin-bottom: 20px;
  border-bottom: 1px solid rgba(255,255,255,.08);
  padding-bottom: 0;
}
.admin-tab {
  padding: 10px 22px; border: none; border-radius: 10px 10px 0 0;
  background: transparent; color: #8b96a8; font-size: .87rem; font-weight: 600;
  cursor: pointer; transition: all .2s; border-bottom: 2px solid transparent;
  margin-bottom: -1px;
}
.admin-tab:hover { color: #e8edf5; background: rgba(255,255,255,.05); }
.admin-tab.ativo { color: #818cf8; border-bottom-color: #818cf8; background: rgba(99,102,241,.08); }

/* Painéis */
.admin-painel { animation: qCardEnter .3s ease; }

.admin-section {
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.07);
  border-radius: 14px; padding: 20px; margin-bottom: 16px;
}
.admin-section-titulo {
  font-size: .9rem; font-weight: 700; color: #e8edf5; margin-bottom: 14px;
}

.admin-loading {
  text-align: center; color: #8b96a8; padding: 20px; font-size: .85rem;
}

/* User list */
.admin-user-list { display: flex; flex-direction: column; gap: 8px; }
.admin-user-row {
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
  background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.07);
  border-radius: 10px; padding: 12px 14px;
}
.admin-user-nome  { font-size: .9rem; font-weight: 600; color: #e8edf5; }
.admin-user-email { font-size: .78rem; color: #8b96a8; display: flex; align-items: center; gap: 6px; margin-top: 2px; }
.admin-badge-role {
  font-size: .7rem; font-weight: 700; padding: 2px 8px; border-radius: 20px; text-transform: uppercase;
}
.admin-badge-role.admin  { background: rgba(239,68,68,.2);  color: #f87171; }
.admin-badge-role.aluno  { background: rgba(34,197,94,.15); color: #4ade80; }

.btn-admin-remove {
  background: rgba(239,68,68,.15); border: 1px solid rgba(239,68,68,.3);
  color: #f87171; padding: 6px 12px; border-radius: 8px; font-size: .82rem;
  cursor: pointer; transition: all .2s; white-space: nowrap; flex-shrink: 0;
}
.btn-admin-remove:hover { background: rgba(239,68,68,.3); }

/* Add form */
.admin-form { display: flex; flex-direction: column; gap: 10px; }
.admin-input {
  width: 100%; padding: 11px 14px; border-radius: 10px;
  border: 1px solid rgba(255,255,255,.1); background: rgba(0,0,0,.25);
  color: #e8edf5; font-size: .88rem; outline: none; box-sizing: border-box;
  transition: border-color .2s;
}
.admin-input:focus { border-color: #818cf8; }
.admin-input option { background: #1a2035; }

.btn-admin-add {
  padding: 12px; border-radius: 10px; border: none;
  background: linear-gradient(135deg, #4f46e5, #6366f1);
  color: #fff; font-size: .9rem; font-weight: 700; cursor: pointer;
  transition: all .2s;
}
.btn-admin-add:hover { transform: translateY(-1px); box-shadow: 0 4px 16px rgba(79,70,229,.4); }

/* Messages */
.admin-msg { font-size: .82rem; min-height: 18px; margin-top: 8px; font-weight: 600; }
.admin-msg.sucesso { color: #4ade80; }
.admin-msg.erro    { color: #f87171; }

/* Toggles */
.admin-toggles { display: flex; flex-direction: column; gap: 2px; margin-bottom: 16px; }
.admin-toggle-row {
  display: flex; align-items: center; justify-content: space-between; gap: 16px;
  padding: 12px 0; border-bottom: 1px solid rgba(255,255,255,.05);
}
.admin-toggle-row:last-child { border-bottom: none; }
.admin-toggle-label { font-size: .9rem; font-weight: 600; color: #e8edf5; }
.admin-toggle-desc  { font-size: .76rem; color: #8b96a8; margin-top: 2px; }

/* Toggle switch */
.admin-switch { position: relative; display: inline-block; width: 44px; height: 24px; flex-shrink: 0; }
.admin-switch input { opacity: 0; width: 0; height: 0; }
.admin-slider {
  position: absolute; inset: 0; cursor: pointer; border-radius: 24px;
  background: rgba(255,255,255,.12); transition: .25s;
}
.admin-slider::before {
  content: ''; position: absolute; height: 18px; width: 18px; border-radius: 50%;
  left: 3px; bottom: 3px; background: #fff; transition: .25s;
}
.admin-switch input:checked + .admin-slider { background: #4f46e5; }
.admin-switch input:checked + .admin-slider::before { transform: translateX(20px); }

.btn-admin-save {
  width: 100%; padding: 13px; border-radius: 10px; border: none;
  background: linear-gradient(135deg, #059669, #10b981);
  color: #fff; font-size: .9rem; font-weight: 700; cursor: pointer;
  transition: all .2s;
}
.btn-admin-save:hover { transform: translateY(-1px); box-shadow: 0 4px 16px rgba(16,185,129,.4); }

/* ── Admin Hero ──────────────────────────────── */
.admin-hero {
  display: flex; align-items: center; justify-content: space-between;
  flex-wrap: wrap; gap: 16px;
  background: linear-gradient(135deg, rgba(79,70,229,.18), rgba(99,102,241,.08));
  border: 1px solid rgba(99,102,241,.25); border-radius: 18px;
  padding: 22px 24px; margin-bottom: 20px;
}
.admin-hero-left { display: flex; align-items: center; gap: 16px; }
.admin-hero-icon {
  width: 52px; height: 52px; border-radius: 14px; font-size: 1.6rem;
  background: rgba(99,102,241,.2); display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.admin-hero-titulo { font-size: 1.1rem; font-weight: 800; color: #e8edf5; }
.admin-hero-sub    { font-size: .78rem; color: #a5b4fc; margin-top: 3px; }
.admin-hero-chips  { display: flex; gap: 10px; flex-wrap: wrap; }
.admin-stat-chip {
  padding: 8px 16px; border-radius: 30px; font-size: .82rem; font-weight: 700;
  display: flex; align-items: center; gap: 6px;
}
.admin-stat-chip.users   { background: rgba(99,102,241,.18); color: #a5b4fc; border: 1px solid rgba(99,102,241,.3); }
.admin-stat-chip.modules { background: rgba(16,185,129,.12); color: #6ee7b7; border: 1px solid rgba(16,185,129,.25); }

/* ── Admin Tabs (pill style) ─────────────────── */
.admin-tabs-pill {
  display: flex; gap: 8px; margin-bottom: 20px;
  background: rgba(0,0,0,.2); border-radius: 14px; padding: 6px;
}
.admin-tab-pill {
  flex: 1; padding: 10px 18px; border: none; border-radius: 10px;
  background: transparent; color: #8b96a8; font-size: .87rem; font-weight: 600;
  cursor: pointer; transition: all .2s; display: flex; align-items: center;
  justify-content: center; gap: 6px;
}
.admin-tab-pill:hover  { color: #e8edf5; background: rgba(255,255,255,.06); }
.admin-tab-pill.ativo  { background: rgba(99,102,241,.22); color: #a5b4fc; box-shadow: 0 2px 8px rgba(0,0,0,.3); }

/* ── Admin Cards ─────────────────────────────── */
.admin-card {
  background: rgba(255,255,255,.03); border: 1px solid rgba(255,255,255,.08);
  border-radius: 16px; padding: 22px; margin-bottom: 16px;
}
.admin-card-header { margin-bottom: 16px; }
.admin-card-titulo { font-size: .95rem; font-weight: 700; color: #e8edf5; }
.admin-card-sub    { font-size: .78rem; color: #8b96a8; margin-top: 4px; }

/* ── Admin Form Grid ─────────────────────────── */
.admin-form-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-bottom: 14px;
}
@media(max-width:560px) { .admin-form-grid { grid-template-columns: 1fr; } }
.admin-form-field { display: flex; flex-direction: column; gap: 6px; }
.admin-label { font-size: .77rem; font-weight: 700; color: #a5b4fc; text-transform: uppercase; letter-spacing: .05em; }

/* ── Empty State ─────────────────────────────── */
.admin-empty-state {
  text-align: center; color: #8b96a8; padding: 28px 16px;
  font-size: .85rem; font-style: italic;
}

/* ── User Avatar ─────────────────────────────── */
.admin-user-avatar {
  width: 36px; height: 36px; border-radius: 50%; flex-shrink: 0;
  background: linear-gradient(135deg, #4f46e5, #7c3aed);
  display: flex; align-items: center; justify-content: center;
  font-size: .8rem; font-weight: 800; color: #fff; text-transform: uppercase;
}
.admin-user-info { display: flex; align-items: center; gap: 12px; flex: 1; min-width: 0; }
.admin-user-details { min-width: 0; }
.admin-user-nome  { font-size: .9rem; font-weight: 600; color: #e8edf5; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.admin-user-email { font-size: .75rem; color: #8b96a8; display: flex; align-items: center; gap: 6px; margin-top: 2px; flex-wrap: wrap; }

/* ══════════════════════════════════════════════
   TELA PROVAS POR CARGO
══════════════════════════════════════════════ */
.provas-cargos-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 16px;
}
.prova-cargo-card {
  background: rgba(255,255,255,.03); border: 1px solid rgba(255,255,255,.09);
  border-radius: 18px; padding: 22px 20px; cursor: pointer;
  transition: all .2s; position: relative; overflow: hidden;
}
.prova-cargo-card::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: var(--cargo-cor, linear-gradient(90deg,#6366f1,#8b5cf6));
}
.prova-cargo-card:hover { transform: translateY(-3px); border-color: rgba(255,255,255,.18); box-shadow: 0 8px 24px rgba(0,0,0,.35); }
.prova-cargo-badge {
  display: inline-flex; align-items: center; gap: 5px; padding: 4px 10px;
  border-radius: 20px; font-size: .7rem; font-weight: 700; margin-bottom: 12px;
  background: rgba(99,102,241,.2); color: #a5b4fc; border: 1px solid rgba(99,102,241,.3);
}
.prova-cargo-titulo { font-size: 1rem; font-weight: 800; color: #e8edf5; margin-bottom: 6px; }
.prova-cargo-sub    { font-size: .78rem; color: #8b96a8; line-height: 1.4; }
.prova-cargo-footer {
  display: flex; align-items: center; justify-content: space-between;
  margin-top: 16px; padding-top: 14px; border-top: 1px solid rgba(255,255,255,.07);
}
.prova-cargo-qtd  { font-size: .82rem; color: #8b96a8; }
.prova-cargo-btn  {
  padding: 8px 16px; border-radius: 10px; border: none; font-size: .82rem; font-weight: 700;
  cursor: pointer; transition: all .2s;
  background: var(--cargo-cor, linear-gradient(135deg,#4f46e5,#6366f1)); color: #fff;
}
.prova-cargo-btn:hover { transform: scale(1.04); }
.prova-cargo-em-breve { opacity: .45; cursor: default; pointer-events: none; }
.prova-cargo-em-breve .prova-cargo-btn { background: rgba(255,255,255,.1); }
