/* ============================================================
   ESCOLAZ — Theme v2  (Duolingo-inspired · Azul Royal)
   Arquivo: theme.css
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Nunito:ital,wght@0,400;0,600;0,700;0,800;0,900;1,700&display=swap');

/* ── MODO CLARO ───────────────────────────────────────────── */
:root {
  --primaria:   #2B7FFF;
  --primaria-d: #1C5FCC;
  --primaria-p: #E0EDFF;

  --amarelo:   #FFD600; --amarelo-d: #CCB000; --amarelo-p: #FFF8CC;
  --verde:     #1DB87A; --verde-d:   #0F9A62; --verde-p:   #D4F7E8;
  --coral:     #FF4B4B; --coral-d:   #E33B3B; --coral-p:   #FFDDDD;
  --azul:      #1CB0F6; --azul-d:    #1899D6; --azul-p:    #DDF4FF;
  --roxo:      #CE82FF; --roxo-d:    #A560D8; --roxo-p:    #F1D8FF;
  --laranja:   #FF9600; --laranja-d: #E08700; --laranja-p: #FFE8B3;

  --sucesso: var(--verde);
  --erro:    var(--coral);
  --aviso:   var(--amarelo);
  --info:    var(--primaria);

  --branco:  #FFFFFF;
  --fundo:   #F5F7FF;
  --fundo-2: #EBF0FF;
  --borda:   #E5E5E5;
  --borda-d: #D0D0D0;

  --texto:   #3C3C3C;
  --texto-2: #777777;
  --texto-3: #AFAFAF;
  --titulo:  #1F1F1F;

  /* Aliases para compatibilidade com pages existentes */
  --creme:   #FFFFFF;
  --creme-2: #F5F7FF;
  --creme-3: #EBF0FF;

  --sidebar-bg:           #FFFFFF;
  --sidebar-borda:        #E5E5E5;
  --sidebar-texto:        #777777;
  --sidebar-ativo-bg:     #E0EDFF;
  --sidebar-ativo-cor:    #1C5FCC;
  --sidebar-ativo-borda:  #99BFFF;
  --sidebar-hover-bg:     #F7F7F7;

  --fonte-titulo: 'Nunito', system-ui, sans-serif;
  --fonte-corpo:  'Nunito', system-ui, sans-serif;

  --shadow-sm:       0 2px 0 var(--borda);
  --shadow-md:       0 4px 0 var(--borda);
  --shadow-lg:       0 6px 0 var(--borda-d);
  --shadow-primaria: 0 4px 0 var(--primaria-d);
  --shadow-verde:    0 4px 0 var(--verde-d);
  --shadow-coral:    0 4px 0 var(--coral-d);
  --shadow-card:     0 2px 0 var(--borda);

  --r-sm: 8px; --r-md: 12px; --r-lg: 16px;
  --r-xl: 20px; --r-2xl: 28px; --r-full: 999px;

  --sidebar-w: 256px;
  --topbar-h:  62px;
}

/* ── MODO ESCURO ──────────────────────────────────────────── */
body.dark {
  --branco:  #1F1F1F;
  --fundo:   #141414;
  --fundo-2: #1A1A1A;
  --borda:   #2E2E2E;
  --borda-d: #3A3A3A;
  --texto:   #E8E8E8;
  --texto-2: #999999;
  --texto-3: #555555;
  --titulo:  #F5F5F5;
  --creme:   #1F1F1F;
  --creme-2: #141414;
  --creme-3: #1A1A1A;

  --sidebar-bg:           #1A1A1A;
  --sidebar-borda:        #2E2E2E;
  --sidebar-texto:        #666666;
  --sidebar-ativo-bg:     rgba(43,127,255,.15);
  --sidebar-ativo-cor:    #6AABFF;
  --sidebar-ativo-borda:  rgba(43,127,255,.3);
  --sidebar-hover-bg:     rgba(255,255,255,.04);

  --shadow-sm:   0 2px 0 rgba(0,0,0,.35);
  --shadow-md:   0 4px 0 rgba(0,0,0,.45);
  --shadow-lg:   0 6px 0 rgba(0,0,0,.55);
  --shadow-card: 0 2px 0 rgba(0,0,0,.35);
}

/* ── RESET ────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { -webkit-text-size-adjust: 100%; }
body {
  font-family: var(--fonte-corpo);
  background: var(--fundo);
  color: var(--texto);
  min-height: 100vh;
  transition: background .3s, color .3s;
  -webkit-font-smoothing: antialiased;
}
a { color: inherit; text-decoration: none; }
::-webkit-scrollbar { width:6px; height:6px; }
::-webkit-scrollbar-track { background:transparent; }
::-webkit-scrollbar-thumb { background:var(--borda); border-radius:10px; }
::-webkit-scrollbar-thumb:hover { background:var(--borda-d); }
::selection { background:var(--primaria-p); color:var(--titulo); }
:focus-visible { outline:2px solid var(--primaria); outline-offset:2px; border-radius:var(--r-sm); }

/* ── BOTÕES ──────────────────────────────────────────────── */
.btn {
  display:inline-flex; align-items:center; justify-content:center; gap:7px;
  border:none; border-radius:var(--r-full);
  font-family:var(--fonte-corpo); font-size:14px; font-weight:800;
  cursor:pointer; transition:transform .1s, box-shadow .1s, background .15s;
  white-space:nowrap; line-height:1; padding:13px 22px;
  position:relative; top:0; text-decoration:none;
}
.btn:disabled { opacity:.5; cursor:not-allowed; pointer-events:none; }
.btn:hover    { top:2px; }
.btn:active   { top:4px; box-shadow:none !important; }

.btn-primario { background:var(--primaria); color:#fff; box-shadow:var(--shadow-primaria); }
.btn-primario:hover { background:var(--primaria-d); }
.btn-escuro   { background:var(--titulo); color:var(--branco); box-shadow:0 4px 0 rgba(0,0,0,.35); }
.btn-escuro:hover { background:#333; }
.btn-verde    { background:var(--verde); color:#fff; box-shadow:var(--shadow-verde); }
.btn-verde:hover { background:var(--verde-d); }
.btn-perigo   { background:var(--coral); color:#fff; box-shadow:var(--shadow-coral); }
.btn-perigo:hover { background:var(--coral-d); }
.btn-branco   { background:var(--branco); color:var(--titulo); border:2px solid var(--borda); box-shadow:var(--shadow-card); }
.btn-branco:hover { border-color:var(--borda-d); }
.btn-ghost    { background:transparent; color:var(--texto-2); border:2px solid var(--borda); box-shadow:none; }
.btn-ghost:hover  { border-color:var(--texto-2); color:var(--texto); top:0; }

.btn-sm { padding:9px 16px; font-size:13px; }
.btn-lg { padding:16px 32px; font-size:16px; }
.btn-xl { padding:18px 40px; font-size:18px; width:100%; max-width:360px; }

/* ── BADGES ──────────────────────────────────────────────── */
.badge {
  display:inline-flex; align-items:center; gap:5px;
  font-size:11px; font-weight:800; padding:4px 12px;
  border-radius:var(--r-full); border:2px solid transparent;
}
.badge-primario { background:var(--primaria-p); color:var(--primaria-d); border-color:#99BFFF; }
.badge-amarelo  { background:var(--amarelo-p);  color:var(--amarelo-d);  border-color:#FFE566; }
.badge-verde    { background:var(--verde-p);    color:var(--verde-d);    border-color:#8EEDC0; }
.badge-coral    { background:var(--coral-p);    color:var(--coral-d);    border-color:#FFAAAA; }
.badge-azul     { background:var(--azul-p);     color:var(--azul-d);     border-color:#9DE0F8; }
.badge-roxo     { background:var(--roxo-p);     color:var(--roxo-d);     border-color:#DDB3FF; }
.badge-laranja  { background:var(--laranja-p);  color:var(--laranja-d);  border-color:#FFD08A; }
.badge-cinza    { background:var(--fundo-2);    color:var(--texto-2);    border-color:var(--borda); }

/* ── CARDS ───────────────────────────────────────────────── */
.card {
  background:var(--branco); border:2px solid var(--borda);
  border-radius:var(--r-xl); box-shadow:var(--shadow-card);
  transition:transform .15s, box-shadow .15s;
  position:relative; top:0;
}
.card:hover { top:-3px; box-shadow:0 6px 0 var(--borda); }

/* ── INPUTS ──────────────────────────────────────────────── */
.input {
  padding:12px 16px; border:2px solid var(--borda);
  border-radius:var(--r-lg); font-family:var(--fonte-corpo);
  font-size:14px; font-weight:600; color:var(--titulo);
  background:var(--branco); outline:none;
  transition:border-color .15s, box-shadow .15s; width:100%;
}
.input:focus { border-color:var(--primaria); box-shadow:0 0 0 3px var(--primaria-p); }
.input.ok    { border-color:var(--verde); }
.input.erro  { border-color:var(--coral); box-shadow:0 0 0 3px var(--coral-p); }

/* ── PROGRESS ────────────────────────────────────────────── */
.progress-track {
  height:16px; background:var(--fundo-2);
  border-radius:var(--r-full); overflow:hidden;
  border:2px solid var(--borda);
}
.progress-fill {
  height:100%; border-radius:var(--r-full);
  background:var(--primaria);
  transition:width .6s cubic-bezier(.34,1.4,.64,1);
  position:relative;
}
.progress-fill::after {
  content:''; position:absolute; top:2px; left:6px; right:6px; height:4px;
  background:rgba(255,255,255,.4); border-radius:var(--r-full);
}

/* ── TOAST GLOBAL ────────────────────────────────────────── */
.toast-global {
  position:fixed; bottom:80px; left:50%;
  transform:translateX(-50%) translateY(20px);
  border-radius:var(--r-full); font-size:14px; font-weight:800;
  opacity:0; transition:all .3s cubic-bezier(.34,1.56,.64,1);
  z-index:9999; white-space:nowrap; pointer-events:none;
  display:flex; align-items:center; gap:10px;
  padding:12px 22px; border:2px solid transparent;
}
.toast-global.show { opacity:1; transform:translateX(-50%) translateY(0); }
.toast-ok   { background:var(--verde-p);    color:var(--verde-d);    border-color:#8EEDC0; }
.toast-err  { background:var(--coral-p);    color:var(--coral-d);    border-color:#FFAAAA; }
.toast-info { background:var(--primaria-p); color:var(--primaria-d); border-color:#99BFFF; }
.toast-win  { background:var(--amarelo-p);  color:var(--amarelo-d);  border-color:#FFE566; }

/* ── SKELETON ────────────────────────────────────────────── */
.skeleton {
  background:linear-gradient(90deg,var(--fundo-2) 25%,var(--borda) 50%,var(--fundo-2) 75%);
  background-size:200% 100%; animation:skeleton-shimmer 1.5s infinite;
  border-radius:var(--r-sm);
}
@keyframes skeleton-shimmer { 0%{background-position:200% 0} 100%{background-position:-200% 0} }
.sk-linha { height:12px; margin-bottom:8px; }

/* ── SPINNER ─────────────────────────────────────────────── */
.spinner {
  width:16px; height:16px; border:2.5px solid rgba(255,255,255,.3);
  border-top-color:#fff; border-radius:50%;
  animation:spin .7s linear infinite; display:inline-block;
}
@keyframes spin { to { transform:rotate(360deg); } }

/* ── SIDEBAR ─────────────────────────────────────────────── */
.sidebar {
  width:var(--sidebar-w); height:100vh; position:fixed; left:0; top:0;
  background:var(--sidebar-bg); border-right:2px solid var(--sidebar-borda);
  display:flex; flex-direction:column; z-index:200;
  transition:transform .3s cubic-bezier(.34,1.2,.64,1);
}
.sb-topo { padding:20px 16px 16px; border-bottom:2px solid var(--sidebar-borda); margin-bottom:8px; }
.sb-marca { display:flex; align-items:center; gap:10px; margin-bottom:12px; }
.sb-icone { width:40px; height:40px; background:var(--primaria); border-radius:var(--r-lg); display:flex; align-items:center; justify-content:center; font-size:22px; flex-shrink:0; overflow:hidden; }
.sb-icone img { width:100%; height:100%; object-fit:cover; }
.sb-nome { font-size:20px; font-weight:900; color:var(--titulo); }
.sb-nome em { font-style:normal; color:var(--primaria); }
.sb-escola { }
.sb-escola-label { font-size:10px; font-weight:800; text-transform:uppercase; letter-spacing:.08em; color:var(--texto-3); }
.sb-escola-nome { font-size:13px; font-weight:700; color:var(--texto-2); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }

.sb-nav { flex:1; padding:0 8px; overflow-y:auto; }
.sb-grupo { font-size:10px; font-weight:800; letter-spacing:.1em; text-transform:uppercase; color:var(--texto-3); padding:0 10px; margin:14px 0 4px; }
.sb-item {
  display:flex; align-items:center; gap:10px; padding:10px 12px;
  border-radius:var(--r-lg); color:var(--sidebar-texto);
  font-size:14px; font-weight:700; cursor:pointer;
  transition:all .15s; border:2px solid transparent;
  text-decoration:none; width:100%; font-family:var(--fonte-corpo);
  background:none; margin-bottom:2px; position:relative; top:0;
}
.sb-item i { font-size:17px; width:20px; text-align:center; flex-shrink:0; }
.sb-item:hover { background:var(--sidebar-hover-bg); color:var(--texto); border-color:var(--borda); }
.sb-item.ativo {
  background:var(--sidebar-ativo-bg); color:var(--sidebar-ativo-cor);
  border-color:var(--sidebar-ativo-borda);
  box-shadow:0 3px 0 var(--sidebar-ativo-borda); font-weight:800;
}
.sb-item.ativo:hover { top:1px; box-shadow:0 2px 0 var(--sidebar-ativo-borda); }

.sb-perfil {
  padding:12px 16px; border-top:2px solid var(--sidebar-borda);
  display:flex; align-items:center; gap:10px;
}
.sb-av { width:36px; height:36px; border-radius:var(--r-full); background:var(--primaria); color:#fff; font-size:13px; font-weight:800; display:flex; align-items:center; justify-content:center; flex-shrink:0; border:2px solid var(--primaria-d); }
.sb-info { flex:1; min-width:0; }
.sb-pnome { font-size:13px; font-weight:800; color:var(--titulo); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.sb-pcargo { font-size:11px; color:var(--texto-3); font-weight:700; text-transform:capitalize; }
.btn-sair { width:32px; height:32px; border-radius:var(--r-full); border:2px solid var(--borda); background:transparent; cursor:pointer; display:flex; align-items:center; justify-content:center; color:var(--texto-3); font-size:16px; transition:all .15s; flex-shrink:0; }
.btn-sair:hover { border-color:var(--coral); color:var(--coral); }

/* ── TOPBAR ──────────────────────────────────────────────── */
.topbar {
  height:var(--topbar-h); background:var(--branco);
  border-bottom:2px solid var(--borda);
  display:flex; align-items:center; justify-content:space-between;
  padding:0 28px; position:sticky; top:0; z-index:100;
}
.topbar h2 { font-family:var(--fonte-titulo); font-size:18px; font-weight:800; color:var(--titulo); display:flex; align-items:center; gap:8px; }
.topbar-dir { display:flex; align-items:center; gap:10px; }
.btn-icon {
  width:38px; height:38px; border-radius:var(--r-full);
  border:2px solid var(--borda); background:var(--branco);
  cursor:pointer; display:flex; align-items:center; justify-content:center;
  color:var(--texto-2); font-size:18px;
  transition:all .15s; box-shadow:var(--shadow-sm);
  position:relative; top:0;
}
.btn-icon:hover { border-color:var(--primaria); color:var(--primaria); top:1px; box-shadow:none; }
.btn-menu { display:none; }
.top-av { width:36px; height:36px; border-radius:var(--r-full); background:var(--primaria); color:#fff; font-size:13px; font-weight:800; display:flex; align-items:center; justify-content:center; border:2px solid var(--primaria-d); cursor:pointer; }

/* ── OVERLAY + MOBILE SIDEBAR ───────────────────────────── */
.overlay-sb { display:none; position:fixed; inset:0; background:rgba(0,0,0,.45); z-index:199; }
.overlay-sb.ativo { display:block; }

/* ── BOTTOM NAV ──────────────────────────────────────────── */
.bottom-nav { display:none; position:fixed; bottom:0; left:0; right:0; height:64px; background:var(--branco); border-top:2px solid var(--borda); z-index:200; box-shadow:0 -2px 0 var(--borda); }
.bottom-nav-inner { display:flex; height:100%; }
.bn-item { flex:1; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:2px; text-decoration:none; color:var(--texto-3); transition:all .15s; border:none; background:none; cursor:pointer; font-family:var(--fonte-corpo); position:relative; }
.bn-dot { width:5px; height:5px; border-radius:50%; background:var(--coral); position:absolute; top:8px; right:calc(50% - 14px); display:none; }
.bn-emoji { font-size:20px; line-height:1; }
.bn-label { font-size:10px; font-weight:800; text-transform:uppercase; letter-spacing:.04em; }
.bn-item.ativo { color:var(--primaria); }
.bn-item.ativo .bn-label { color:var(--primaria); }

/* ── MAIN ────────────────────────────────────────────────── */
.main { margin-left:var(--sidebar-w); min-height:100vh; background:var(--fundo); }
.page-body { padding:28px; }
.page { padding:28px; }

/* ── RESPONSIVO ──────────────────────────────────────────── */
@media (max-width:768px) {
  .sidebar { transform:translateX(-100%); }
  .sidebar.aberta { transform:translateX(0); box-shadow:4px 0 0 var(--borda); }
  .main { margin-left:0; }
  .topbar { padding:0 16px; }
  .btn-menu { display:flex !important; }
  .bottom-nav { display:block; }
  .page-body { padding:16px 16px 80px; }
  .page { padding:16px 16px 80px; }
}
