:root{
  /* Paleta Sábio — DNA do Herdeiro / Mapa do Herdeiro (tema claro) */
  --cream:#FAFAF7; --paper:#FFFFFF; --ink:#1F1D1A; --muted:#6B6358;
  --bronze:#D4AF37; --bronzeD:#A8892A; --line:#E5DFD5; --box:#F3EDE3; --boxb:#E0D8C9;
  --side:#1B4332; --sideText:#DCE6DE; --sideMut:#8AA597; --ok:#2D6A4F;
  --serif:Georgia,"Times New Roman",serif;
  --sans:'Inter',-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --display:'Cinzel',Georgia,serif;
}
.brand .bn,.lg-title,.hero h1,.courseCard h3,.modulo-titulo{font-family:var(--display);letter-spacing:.01em}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{background:var(--cream);color:var(--ink);font-family:var(--serif);line-height:1.65;}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}

/* ---- layout ---- */
#app{display:flex;min-height:100vh}
.sidebar{
  width:248px;flex:0 0 248px;background:var(--side);color:var(--sideText);
  position:sticky;top:0;height:100vh;display:flex;flex-direction:column;padding:22px 0;
}
.brand{display:flex;align-items:center;gap:10px;padding:0 22px 18px;border-bottom:1px solid #3a342c;margin-bottom:14px}
.brand .crest{width:38px;height:38px;border-radius:9px;background:var(--bronze);display:flex;align-items:center;justify-content:center;color:#1c1812;font-weight:700;font-family:var(--serif);font-size:1.2rem}
.brand .bn{font-family:var(--serif);font-size:1.18rem;line-height:1.1}
.brand .bn small{display:block;font-family:var(--sans);font-size:.62rem;letter-spacing:.18em;color:var(--sideMut);text-transform:uppercase;margin-top:3px}
.nav{display:flex;flex-direction:column;gap:2px;padding:0 12px;font-family:var(--sans);font-size:.92rem}
.nav a{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:9px;color:var(--sideText);transition:.15s}
.nav a:hover{background:#322c24}
.nav a.active{background:var(--bronze);color:#1c1812;font-weight:600}
.nav a .ic{width:18px;text-align:center;opacity:.9}
.side-prog{margin-top:auto;padding:16px 22px 4px;font-family:var(--sans)}
.side-prog .lbl{font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--sideMut)}
.side-prog .bar{height:7px;border-radius:6px;background:#3a342c;margin:8px 0 6px;overflow:hidden}
.side-prog .bar i{display:block;height:100%;background:var(--bronze)}
.side-prog .pct{font-size:.8rem;color:var(--sideText)}
.side-foot{padding:14px 22px 0;font-family:var(--sans);font-size:.66rem;color:var(--sideMut);letter-spacing:.04em}

/* ---- main ---- */
.main{flex:1;min-width:0}
.topbar{height:60px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;padding:0 30px;background:var(--cream);position:sticky;top:0;z-index:5}
.topbar .crumb{font-family:var(--sans);font-size:.86rem;color:var(--muted)}
.topbar .crumb a:hover{color:var(--bronzeD)}
.backBtn{border:1.5px solid var(--bronze);background:var(--paper);color:var(--bronzeD);font-family:var(--sans);font-weight:700;font-size:.9rem;border-radius:10px;padding:8px 14px;cursor:pointer;white-space:nowrap;touch-action:manipulation}
.backBtn:hover{background:var(--bronze);color:#1c1812}
/* visualizador de material */
.matNav{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin:6px 0 16px}
.matBack{font-family:var(--sans);font-weight:700;color:var(--bronzeD);font-size:.95rem}
.matBack:hover{text-decoration:underline}
.matTitle{font-family:var(--display);font-size:1.25rem;color:var(--ink)}
.matBody{min-height:200px}
.matLoading,.matEmpty{font-family:var(--sans);color:var(--muted);text-align:center;padding:40px 20px;background:var(--paper);border:1px solid var(--line);border-radius:14px}
.matEmpty b{color:var(--bronzeD)}
.matVideo{position:relative;width:100%;aspect-ratio:16/9;border-radius:14px;overflow:hidden;background:#000;box-shadow:0 8px 30px rgba(27,67,50,.12)}
.matVideo iframe,.matVideo video{position:absolute;inset:0;width:100%;height:100%;border:0}
.matAudio{background:var(--paper);border:1px solid var(--line);border-radius:14px;padding:26px 22px;text-align:center}
.matAudioIc{font-size:2.4rem;margin-bottom:14px}
.matImg{text-align:center}
.matImg img{max-width:100%;border-radius:14px;border:1px solid var(--line);box-shadow:0 8px 30px rgba(27,67,50,.10)}
.matImg .btn{margin-top:14px}
.matFoot{margin:26px 0 10px}
.ativo.off{opacity:.7}
/* lista de aulas do aluno */
.aulasList{display:flex;flex-direction:column;gap:12px}
.aulaCard{display:flex;align-items:center;gap:14px;background:var(--paper);border:1px solid var(--line);border-radius:14px;padding:16px 18px;transition:.15s}
.aulaCard:hover{border-color:var(--bronze);box-shadow:0 8px 24px rgba(27,67,50,.08);transform:translateY(-1px)}
.aulaCard .ac-ic{font-size:1.6rem;flex:none}
.aulaCard .ac-tx{flex:1;min-width:0}
.aulaCard .ac-t{font-family:var(--display);font-size:1.12rem;color:var(--ink);line-height:1.2}
.aulaCard .ac-s{font-family:var(--sans);font-size:.85rem;color:var(--muted);margin-top:2px}
.aulaCard .ac-meta{display:flex;align-items:center;gap:10px;flex:none}
.aulaCard .chev{color:var(--bronze);font-size:1.2rem}
/* página da aula */
.aulaHead{margin-bottom:18px}
.aulaHead h1{font-family:var(--display);font-size:1.7rem;margin:0 0 4px;line-height:1.15}
.aulaDate{font-family:var(--sans);color:var(--muted);font-size:.9rem}
.amCard{background:var(--paper);border:1px solid var(--line);border-radius:14px;padding:16px 18px;margin-bottom:14px}
.amCard.off{opacity:.65}
.am-h{display:flex;align-items:center;gap:10px;margin-bottom:0}
.amCard .am-b{margin-top:14px}
.am-ic{font-size:1.3rem}
.am-t{font-family:var(--sans);font-weight:700;color:var(--ink);flex:1}
.am-b audio{width:100%}
/* blocos manhã / tarde / atividades */
.turnoSec{margin:0 0 22px;padding:16px 16px 6px;border:1px solid var(--line);border-radius:16px;background:linear-gradient(180deg,rgba(212,175,55,.05),transparent 60%)}
.turnoH{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin:0 2px 14px}
.turnoBadge{font-family:var(--display);font-size:1.15rem;color:var(--side);font-weight:700}
.turnoNote{font-family:var(--sans);font-size:.82rem;color:var(--muted)}
.atvSec{background:linear-gradient(180deg,rgba(45,106,79,.07),transparent 60%)}
.atvCard{display:block;text-decoration:none}
.atvCard .chev{color:var(--bronze);font-size:1.2rem;margin-left:auto}
.atvCard:hover{border-color:var(--bronze)}
.matSlides{position:relative;width:100%;height:62vh;min-height:340px;border-radius:14px;overflow:hidden;border:1px solid var(--line);background:#fff;margin-top:12px}
.matSlides iframe{width:100%;height:100%;border:0}
.slidesBtn{display:block;text-align:center;font-size:1rem}
/* no celular o iframe de PDF não renderiza — mostramos só o botão */
@media(max-width:680px){.matSlides{display:none}}
/* questão aberta: texto + gravador */
.ptag{display:inline-block;background:var(--side);color:#fff;font-family:var(--sans);font-size:.72rem;font-weight:700;border-radius:20px;padding:3px 11px;vertical-align:middle;margin-left:8px}
.roteiro{background:linear-gradient(180deg,rgba(212,175,55,.10),rgba(212,175,55,.02));border:1px solid var(--boxb);border-radius:14px;padding:16px 18px;margin:14px 0}
.rot-h{font-family:var(--sans);font-weight:700;color:var(--bronzeD);margin-bottom:8px}
.rot-list{margin:0;padding-left:1.3em;font-family:var(--sans);color:var(--ink);line-height:1.7;font-size:.95rem}
.rot-list b{color:var(--side)}
.rot-tip{margin-top:10px;font-family:var(--sans);font-size:.85rem;color:var(--muted);font-style:italic}
.consentRow{display:flex;align-items:flex-start;gap:10px;margin:14px 0 4px;font-family:var(--sans);font-size:.88rem;color:var(--ink);line-height:1.45;cursor:pointer;background:var(--box);border:1px solid var(--boxb);border-radius:12px;padding:12px 14px}
.consentRow input{margin-top:3px;width:18px;height:18px;flex:none;accent-color:var(--side)}
.abertaTexto{width:100%;box-sizing:border-box;border:1.5px solid var(--line);border-radius:12px;padding:14px 16px;font-family:var(--sans);font-size:1rem;color:var(--ink);background:var(--paper);resize:vertical;min-height:120px;line-height:1.5}
.abertaTexto:focus{outline:none;border-color:var(--bronze)}
.abertaOu{text-align:center;color:var(--muted);font-family:var(--sans);font-size:.82rem;margin:14px 0 10px}
.audioRow{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
#recBtn.recing{background:#B23B3B;border-color:#B23B3B;animation:recpulse 1.1s infinite}
@keyframes recpulse{0%,100%{opacity:1}50%{opacity:.65}}
@media(max-width:680px){
  .topbar{padding:0 14px;height:56px}
  .matTitle{font-size:1.05rem}
  .backBtn{padding:7px 12px;font-size:.88rem}
}
.topbar .userbox{display:flex;align-items:center;gap:11px}
.topbar .userbox .uname{font-family:var(--sans);font-size:.88rem;font-weight:600;color:var(--ink);max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.topbar .avatar{width:36px;height:36px;border-radius:50%;background:var(--bronze);color:#1c1812;display:flex;align-items:center;justify-content:center;font-family:var(--sans);font-weight:700;font-size:.82rem;box-shadow:0 1px 4px rgba(124,74,2,.25);flex:0 0 auto}
.topbar .userbox .matlink{display:inline-flex;align-items:center;gap:6px;text-decoration:none;font-family:var(--sans);font-size:.8rem;font-weight:600;color:var(--sage,#1B4332);background:#1b43320d;border:1px solid #1b433222;padding:7px 12px;border-radius:9px;white-space:nowrap}
.topbar .userbox .matlink:hover{background:#1b43321a}
@media(max-width:560px){.topbar .userbox .uname{display:none} .topbar .userbox .matlink span{display:none} .topbar .userbox .matlink{padding:7px 9px}}
.wrap{max-width:780px;margin:0 auto;padding:34px 30px 80px}

/* ---- course hero ---- */
.kicker{font-family:var(--sans);font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--bronze);font-weight:700}
.hero h1{font-size:2.3rem;line-height:1.12;margin:.18em 0 .1em}
.hero .apostila{font-family:var(--sans);font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}
.hero .sub{font-style:italic;color:var(--muted);font-size:1.06rem;margin:0 0 6px}
.hero .autor{font-family:var(--sans);font-size:.85rem;color:var(--muted)}
.progress{margin:24px 0 6px;background:var(--paper);border:1px solid var(--line);border-radius:12px;padding:16px 18px}
.progress .row{display:flex;justify-content:space-between;align-items:center;font-family:var(--sans);font-size:.85rem;color:var(--muted)}
.progress .bar{height:9px;border-radius:6px;background:var(--box);margin-top:10px;overflow:hidden}
.progress .bar i{display:block;height:100%;background:linear-gradient(90deg,var(--bronzeD),var(--bronze));transition:.4s}

/* ---- modules + lesson cards ---- */
.modhead{display:flex;align-items:baseline;gap:10px;margin:30px 0 12px}
.modhead .mn{font-family:var(--sans);font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--bronze);font-weight:700}
.modhead .mt{font-size:1.18rem}
.card{display:flex;align-items:center;gap:16px;background:var(--paper);border:1px solid var(--line);border-radius:13px;padding:14px 16px;margin-bottom:10px;transition:.15s;cursor:pointer}
.card:hover{border-color:var(--boxb);box-shadow:0 4px 16px rgba(124,74,2,.07);transform:translateY(-1px)}
.card .num{flex:0 0 56px;height:56px;border-radius:10px;background:linear-gradient(135deg,#efe7d6,#f6f1e7);border:1px solid var(--boxb);display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:1.5rem;color:var(--bronzeD);position:relative}
.card .num .done{position:absolute;right:-6px;top:-6px;width:20px;height:20px;border-radius:50%;background:var(--ok);color:#fff;font-size:.7rem;display:flex;align-items:center;justify-content:center;font-family:var(--sans)}
.card .body{flex:1;min-width:0}
.card .body .t{font-size:1.06rem;font-weight:600;line-height:1.25}
.card .body .s{font-family:var(--sans);font-size:.84rem;color:var(--muted);margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.card .meta{flex:0 0 auto;display:flex;align-items:center;gap:14px;font-family:var(--sans);font-size:.8rem;color:var(--muted)}
.card .chev{color:var(--boxb);font-size:1.3rem}
.card.quiz .num{background:linear-gradient(135deg,#7c4a02,#b5740f);color:#fff;border:none}

/* ---- lesson view ---- */
.lessNav{display:flex;align-items:center;justify-content:space-between;font-family:var(--sans);font-size:.85rem;color:var(--muted);margin-bottom:18px}
.lessNav a.back:hover{color:var(--bronzeD)}
.lessNav .count{background:var(--box);border:1px solid var(--boxb);border-radius:20px;padding:3px 12px;font-size:.78rem}
.lesson h1{font-size:2rem;line-height:1.14;margin:.1em 0 .12em}
.lesson .sub{font-style:italic;color:var(--muted);font-size:1.05rem;margin:0 0 20px}
.lesson .content{font-size:1.04rem}
.lesson .content p{margin:.7em 0;text-indent:1.1em;text-align:justify}
.lesson .content h1+p,.lesson .content h2+p,.lesson .content h3+p,.lesson .content .versiculo+p,.lesson .content .objetivos+p,.lesson .content .nota+p,.lesson .content table+p,.lesson .content ul+p,.lesson .content ol+p{text-indent:0}
.lesson .content h2{font-size:1.32rem;border-top:2px solid var(--line);padding-top:.5em;margin:1.7em 0 .4em}
.lesson .content h3{font-size:1.08rem;color:var(--bronzeD);font-family:var(--sans);margin:1.3em 0 .3em}
.versiculo{border-left:4px solid var(--bronze);background:var(--paper);margin:1.1em 0;padding:13px 18px;font-style:italic;color:#3a3a3a;border-radius:0 8px 8px 0}
.objetivos,.caixa{background:var(--box);border:1px solid var(--boxb);border-radius:11px;padding:16px 20px;margin:1.4em 0}
.objetivos h4,.caixa h4{margin:.1em 0 .5em;font-family:var(--sans);font-size:.86rem;text-transform:uppercase;letter-spacing:.07em;color:var(--bronzeD)}
.nota{background:var(--paper);border:1px dashed var(--boxb);border-radius:9px;padding:12px 18px;margin:1.2em 0;font-size:.98rem;color:var(--muted)}
.nota strong{color:var(--bronzeD)}
.lesson .content table{border-collapse:collapse;width:100%;margin:1.3em 0;font-family:var(--sans);font-size:.95rem;background:var(--paper)}
.lesson .content th,.lesson .content td{border:1px solid var(--line);padding:9px 13px;text-align:left;vertical-align:top}
.lesson .content th{background:var(--box)}
.lesson .content td:first-child{font-weight:600;color:var(--muted)}
.lesson .content ul,.lesson .content ol{padding-left:1.3em}
.lessFoot{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:34px;border-top:1px solid var(--line);padding-top:20px}
.btn{font-family:var(--sans);font-weight:600;font-size:.9rem;border-radius:10px;padding:11px 18px;border:1px solid var(--boxb);background:var(--paper);color:var(--ink);transition:.15s}
.btn:hover{border-color:var(--bronze)}
.btn.primary{background:var(--bronze);border-color:var(--bronze);color:#1c1812}
.btn.primary:hover{background:var(--bronzeD);color:#fff}
.btn.ghost{background:transparent;border-color:transparent;color:var(--muted)}
.btn[disabled]{opacity:.4;cursor:default}

/* ---- quiz ---- */
.quizIntro{background:var(--box);border:1px solid var(--boxb);border-radius:12px;padding:18px 20px;margin:14px 0 24px;font-family:var(--sans);font-size:.92rem;color:var(--muted)}
.scorebar{position:sticky;top:60px;background:var(--cream);padding:10px 0;border-bottom:1px solid var(--line);font-family:var(--sans);font-size:.86rem;color:var(--muted);display:flex;justify-content:space-between;align-items:center;z-index:4}
.scorebar b{color:var(--bronzeD)}
.q{background:var(--paper);border:1px solid var(--line);border-radius:13px;padding:16px 18px;margin-bottom:12px}
.q .qt{font-size:1.04rem;line-height:1.4}
.q .qt .n{font-family:var(--sans);font-weight:700;color:var(--bronzeD);margin-right:6px}
.q .opts{display:flex;gap:10px;margin-top:12px}
.q .opts button{font-family:var(--sans);font-weight:700;font-size:.9rem;border-radius:9px;padding:9px 22px;border:1.5px solid var(--boxb);background:var(--paper);color:var(--ink)}
.q .opts button:hover{border-color:var(--bronze)}
.q .opts button.sel{background:var(--ink);color:#fff;border-color:var(--ink)}
.q.answered .opts button{cursor:default}
.q.answered .opts button.correct{background:var(--ok);border-color:var(--ok);color:#fff}
.q.answered .opts button.wrong{background:#b13b3b;border-color:#b13b3b;color:#fff}
.q .fb{margin-top:12px;font-family:var(--sans);font-size:.88rem;border-radius:9px;padding:10px 14px;display:none}
.q.answered .fb{display:block}
.q.right .fb{background:#eaf5ee;color:#225c3a;border:1px solid #bfe0cb}
.q.miss .fb{background:#fbecec;color:#8a2b2b;border:1px solid #e8c4c4}
.q .fb .tag{font-weight:700;text-transform:uppercase;letter-spacing:.06em;font-size:.72rem;margin-right:6px}
.result{background:linear-gradient(135deg,#f6f1e7,#efe7d6);border:1px solid var(--boxb);border-radius:14px;padding:24px;text-align:center;margin:24px 0}
.result .big{font-size:2.4rem;font-family:var(--serif);color:var(--bronzeD)}
.result .lbl{font-family:var(--sans);color:var(--muted);font-size:.9rem}

@media(max-width:860px){
  .sidebar{position:fixed;left:-248px;z-index:30;transition:.2s;box-shadow:0 0 40px rgba(0,0,0,.3)}
  .sidebar.open{left:0}
  .main{width:100%}
  .menuToggle{display:inline-flex!important}
  .scrim{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:20;display:none}
  .scrim.show{display:block}
}
.menuToggle{display:none;align-items:center;justify-content:center;width:38px;height:38px;border-radius:9px;border:1px solid var(--line);background:var(--paper);font-size:1.1rem}

/* ---- sidebar course label ---- */
.navlabel{font-family:var(--sans);font-size:.64rem;letter-spacing:.16em;text-transform:uppercase;color:var(--sideMut);padding:14px 14px 4px}

/* ---- biblioteca ---- */
.biblioteca{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:26px}
@media(max-width:680px){.biblioteca{grid-template-columns:1fr}}
.courseCard{display:block;background:var(--paper);border:1px solid var(--line);border-radius:16px;padding:22px;transition:.15s;position:relative;overflow:hidden}
.courseCard:hover{border-color:var(--boxb);box-shadow:0 8px 24px rgba(124,74,2,.09);transform:translateY(-2px)}
.courseCard::before{content:"";position:absolute;left:0;top:0;bottom:0;width:5px;background:linear-gradient(var(--bronzeD),var(--bronze))}
.courseCard .cc-top{display:flex;gap:8px;margin-bottom:14px}
.courseCard .badge{font-family:var(--sans);font-size:.68rem;letter-spacing:.04em;background:var(--box);border:1px solid var(--boxb);color:var(--bronzeD);border-radius:20px;padding:3px 11px;font-weight:600}
.courseCard .badge.alt{background:transparent;color:var(--muted)}
.courseCard .cc-kicker{font-family:var(--sans);font-size:.72rem;letter-spacing:.13em;text-transform:uppercase;color:var(--muted)}
.courseCard h3{font-size:1.5rem;line-height:1.15;margin:4px 0 8px}
.courseCard .cc-sub{font-style:italic;color:var(--muted);font-size:.95rem;margin:0 0 16px;min-height:2.6em}
.courseCard .cc-prog{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.courseCard .cc-prog .bar{flex:1;height:8px;border-radius:6px;background:var(--box);overflow:hidden}
.courseCard .cc-prog .bar i{display:block;height:100%;background:linear-gradient(90deg,var(--bronzeD),var(--bronze))}
.courseCard .cc-prog span{font-family:var(--sans);font-size:.78rem;color:var(--muted)}
.courseCard .cc-go{font-family:var(--sans);font-weight:600;font-size:.9rem;color:var(--bronzeD)}

/* ---- banner proxima aula / confirmar presenca ---- */
.aulaCard{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;background:var(--side);color:var(--sideText);border-radius:14px;padding:16px 20px;margin:20px 0 6px}
.aulaCard.conf{background:var(--box);color:var(--ink);border:1px solid var(--boxb)}
.aulaCard .ac-k{font-family:var(--sans);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--bronze);font-weight:700}
.aulaCard.conf .ac-k{color:var(--bronzeD)}
.aulaCard .ac-t{font-family:var(--display);font-size:1.2rem;margin:2px 0}
.aulaCard .ac-d{font-family:var(--sans);font-size:.85rem;opacity:.85}
.aulaCard .ac-ok{font-family:var(--sans);font-weight:700;color:var(--ok);background:#fff;border-radius:20px;padding:7px 16px;font-size:.88rem}
.aulaCard .ac-btns{display:flex;gap:10px;flex-wrap:wrap}
.aulaCard .ac-confwrap{display:flex;flex-direction:column;align-items:flex-end;gap:10px}
.aulaCard .ac-links{display:flex;gap:8px;flex-wrap:wrap}
.aulaCard .ac-links .btn{padding:8px 14px;font-size:.82rem}

/* ---- sidebar foot (aluno + sair) ---- */
.side-foot{padding:14px 22px 0;font-family:var(--sans);font-size:.74rem;color:var(--sideMut);display:flex;align-items:center;justify-content:space-between;gap:8px}
.side-foot .who{color:var(--sideText);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.side-foot .logout{background:transparent;border:1px solid #3a342c;color:var(--sideMut);border-radius:8px;padding:5px 12px;font-size:.74rem;font-family:var(--sans)}
.side-foot .logout:hover{border-color:var(--bronze);color:var(--bronze)}

/* ---- login ---- */
.loginWrap{min-height:100vh;width:100%;display:flex;align-items:center;justify-content:center;background:var(--cream);padding:24px}
.loginCard{background:var(--paper);border:1px solid var(--line);border-radius:18px;padding:38px 34px;width:100%;max-width:380px;text-align:center;box-shadow:0 14px 40px rgba(124,74,2,.08)}
.crest.big{width:60px;height:60px;border-radius:14px;font-size:1.9rem;margin:0 auto 14px}
.crest{background:var(--bronze);display:flex;align-items:center;justify-content:center;color:#1c1812;font-family:var(--serif)}
.lg-title{font-family:var(--serif);font-size:1.7rem;color:var(--ink)}
.lg-sub{font-family:var(--sans);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:22px}
.loginCard label{display:block;text-align:left;font-family:var(--sans);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin:14px 0 6px}
.loginCard input{width:100%;border:1px solid var(--boxb);background:#fbf9f4;border-radius:10px;padding:12px 14px;font-family:var(--sans);font-size:1rem;color:var(--ink)}
.loginCard input:focus{outline:none;border-color:var(--bronze)}
.lg-btn{width:100%;margin-top:22px;background:var(--bronze);border:none;color:#1c1812;font-family:var(--sans);font-weight:700;letter-spacing:.05em;border-radius:10px;padding:13px;font-size:.95rem}
.lg-btn:hover{background:var(--bronzeD);color:#fff}
.lg-err{margin-top:14px;background:#fbecec;border:1px solid #e8c4c4;color:#8a2b2b;border-radius:9px;padding:9px 12px;font-family:var(--sans);font-size:.84rem}
.lg-hint{margin-top:16px;font-family:var(--sans);font-size:.78rem;color:var(--muted)}

/* ---- financeiro (extrato do aluno) ---- */
.btn.sm{padding:7px 12px;font-size:.8rem;border-radius:8px}
.finwrap{margin-top:26px;border-top:1px solid var(--line);padding-top:18px}
.finhead{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px;margin-bottom:14px}
.finhead h3{font-family:var(--display,'Cinzel',serif);font-size:1.05rem;color:var(--sage,#1B4332);margin:0}
.finacts{display:flex;gap:8px;flex-wrap:wrap}
.finsummary{display:grid;grid-template-columns:1fr 1fr 1.2fr;gap:12px;margin-bottom:16px}
.fsum{background:var(--paper,#fff);border:1px solid var(--line);border-radius:12px;padding:12px 14px;text-align:center}
.fsum span{display:block;font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-weight:700;margin-bottom:4px}
.fsum b{font-size:1.1rem;font-family:var(--sans)}
.fsum.big{padding:14px}.fsum.big b{font-size:1.4rem}
.fsum.neg b{color:#B23B3B}.fsum.ok b{color:var(--ok)}.fsum b.pos{color:var(--ok)}
.fintable table{width:100%;border-collapse:collapse}
.fintable th{font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);text-align:left;padding:8px 10px;border-bottom:2px solid var(--line)}
.fintable td{padding:9px 10px;border-bottom:1px solid var(--line);font-size:.9rem}
.fintable tr.cred td{background:#2d6a4f08}
.fintable .fdesc{color:var(--ink)}
.fintable .vmoney{font-family:var(--sans);font-weight:700;white-space:nowrap}
.fintable .vmoney.pos{color:var(--ok)}.fintable .vmoney.neg{color:#B23B3B}.fintable .vmoney.ok{color:var(--ink)}
.fintable .fmet{display:inline-block;font-size:.66rem;text-transform:uppercase;letter-spacing:.05em;background:#0000000a;color:var(--muted);padding:2px 6px;border-radius:5px;margin-left:6px}
.findel{border:none;background:transparent;color:#c98;cursor:pointer;font-size:1.05rem;line-height:1;padding:2px 6px;border-radius:6px}
.findel:hover{background:#B23B3B14;color:#B23B3B}
@media(max-width:560px){.finsummary{grid-template-columns:1fr 1fr}.fsum.big{grid-column:1/-1}}

/* ---- modal de formulário (financeiro) ---- */
.modal-ov{position:fixed;inset:0;background:rgba(20,16,10,.45);display:flex;align-items:center;justify-content:center;z-index:100;padding:18px;backdrop-filter:blur(2px)}
.modal-card{background:var(--paper,#fff);border:1px solid var(--line);border-radius:16px;padding:22px;width:100%;max-width:420px;box-shadow:0 20px 60px rgba(0,0,0,.3)}
.modal-card h3{font-family:var(--display,'Cinzel',serif);font-size:1.15rem;color:var(--side,#1B4332);margin:0 0 16px}
.modal-body{display:flex;flex-direction:column;gap:12px}
.mf{display:flex;flex-direction:column;gap:5px}
.mf span{font-family:var(--sans);font-size:.76rem;font-weight:600;color:var(--muted)}
.mf input,.mf select{font-family:var(--sans);font-size:1rem;padding:11px 12px;border:1px solid var(--line);border-radius:10px;background:#fff;color:var(--ink);width:100%}
.mf input:focus,.mf select:focus{outline:none;border-color:var(--side,#1B4332);box-shadow:0 0 0 3px #1b433222}
.mf-err{border-color:#B23B3B!important;box-shadow:0 0 0 3px #b23b3b22!important}
.modal-acts{display:flex;justify-content:flex-end;gap:10px;margin-top:20px}

/* ---- recibo modal ---- */
.modal-card.recibo{max-width:480px}
.rec-sub{font-family:var(--sans);font-size:.82rem;color:var(--muted);margin:0 0 12px;line-height:1.5}
.rec-box{font-family:var(--sans);font-size:.82rem;white-space:pre-wrap;background:var(--box,#F3EDE3);border:1px solid var(--line);border-radius:10px;padding:14px;margin:0 0 14px;max-height:280px;overflow:auto;line-height:1.55;color:var(--ink)}
.frecibo{border:none;background:transparent;cursor:pointer;font-size:1rem;line-height:1;padding:2px 5px;border-radius:6px}
.frecibo:hover{background:#2d6a4f1a}
td.nowrap{white-space:nowrap}

/* ---- avaliação 100 pts ---- */
.avalbar{display:grid;grid-template-columns:repeat(5,1fr);gap:8px;margin:14px 0 8px}
.avalbar .ab{background:var(--paper);border:1px solid var(--line);border-radius:11px;padding:9px 6px;text-align:center}
.avalbar .ab span{display:block;font-family:var(--sans);font-size:.62rem;text-transform:uppercase;letter-spacing:.05em;color:var(--muted)}
.avalbar .ab b{font-family:var(--sans);font-size:1.02rem;color:var(--ink)}
.avalbar .ab small{display:block;font-family:var(--sans);font-size:.6rem;color:var(--muted)}
.avalbar .ab.big{background:linear-gradient(135deg,#f6f1e7,#efe7d6);border-color:var(--boxb)}
.avalbar .ab.big b{color:var(--bronzeD)}
@media(max-width:560px){.avalbar{grid-template-columns:repeat(3,1fr)}.avalbar .ab.big{grid-column:span 3}}
.avalsec{font-family:var(--serif);font-size:1.25rem;color:var(--side);margin:28px 0 12px;border-top:2px solid var(--line);padding-top:18px}
.avalsec small{font-family:var(--sans);font-size:.78rem;color:var(--muted);font-weight:400;margin-left:8px}
.q .opts.col{flex-direction:column;gap:8px}
.q .opts.col button{text-align:left;width:100%;padding:11px 14px;line-height:1.35}
.q .opts.col button b{color:var(--bronzeD);margin-right:8px}
.q.answered .opts.col button.correct b,.q.answered .opts.col button.wrong b{color:#fff}
.abertaBox{background:var(--paper);border:1px solid var(--line);border-radius:13px;padding:16px 18px}
.abertaBox .qt{font-size:1.02rem;line-height:1.45;margin-bottom:14px}
.audioRow{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.audioRow #audioName{font-family:var(--sans);font-size:.85rem;color:var(--muted)}
.abertaHint{font-family:var(--sans);font-size:.78rem;color:var(--muted);margin-top:10px}
.enviaRow{display:flex;gap:10px;align-items:center;margin:24px 0;flex-wrap:wrap}
.btn.big{padding:14px 26px;font-size:1rem}
.parabens{background:linear-gradient(135deg,#eaf5ee,#dff0e6);border:1px solid #bfe0cb;border-radius:16px;padding:24px;margin:20px 0;text-align:center;font-family:var(--sans)}
.parabens.no{background:linear-gradient(135deg,#fbecec,#f7dede);border-color:#e8c4c4}
.parabens .pb-big{font-size:1.8rem;font-weight:800;color:var(--side);margin-bottom:8px}
.parabens.no .pb-big{color:#8a2b2b}
.parabens p{color:var(--ink);font-size:.92rem;margin:8px 0}
.pb-grid{display:grid;grid-template-columns:1fr auto;gap:6px 18px;max-width:360px;margin:16px auto;text-align:left;font-size:.92rem}
.pb-grid span{color:var(--muted)} .pb-grid b{text-align:right;color:var(--side)}
.pb-note{font-size:.84rem!important;color:var(--muted)!important;max-width:460px;margin:12px auto 0!important}
.fintable .frecibo.btn{padding:6px 12px;font-size:.78rem;background:#2d6a4f;border-color:#2d6a4f;color:#fff;margin-right:6px}
.fintable .frecibo.btn:hover{background:#235038}

/* ---- bolsista + caixa ---- */
.bolsbadge{display:inline-block;font-family:var(--sans);font-size:.7rem;font-weight:700;background:#1b43321a;color:var(--side,#1B4332);padding:3px 9px;border-radius:20px;margin-left:8px;vertical-align:middle}
.caixa-met{font-family:var(--sans);font-size:.82rem;color:var(--ink)}

/* ---- lista de alunos imprimível ---- */
.printonly{display:none}
.lista-group{margin-bottom:20px;break-inside:avoid}
.lista-h{font-family:var(--display,'Cinzel',serif);font-size:1.12rem;border-bottom:2px solid;padding-bottom:6px;margin:20px 0 10px}
.lista-h span{font-family:var(--sans);font-size:.85rem;font-weight:600}
.lista-tab{width:100%;border-collapse:collapse;font-family:var(--sans);font-size:.9rem}
.lista-tab th{text-align:left;font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);padding:7px 10px;border-bottom:1px solid var(--line)}
.lista-tab td{padding:8px 10px;border-bottom:1px solid var(--line)}
.lista-tab td.nm{font-weight:600}
.lista-tab th.center,.lista-tab td.center{text-align:center;width:40px}
.sitsel{font-family:var(--sans);font-size:.82rem;padding:5px 8px;border:1px solid var(--line);border-radius:7px;background:#fff}
.listahead h1{font-family:var(--display,'Cinzel',serif);margin:0;font-size:1.4rem}
.lh-sub{font-family:var(--sans);font-size:.85rem;color:var(--muted);margin-top:2px;margin-bottom:8px}
@media print{
  .sidebar,.topbar,.noprint{display:none!important}
  .printonly{display:block!important}
  .profwrap{max-width:100%;padding:0;margin:0}
  body{background:#fff;color:#000}
  .lista-tab td,.lista-tab th{padding:5px 8px}
  @page{margin:14mm}
}

/* ===== Área de membros — hub estilo Netflix ===== */
.memberHero{background:linear-gradient(120deg,#14342a 0%,#1B4332 48%,#2D6A4F 100%);color:#fff;padding:46px 30px 52px;position:relative;overflow:hidden}
.memberHero::after{content:"";position:absolute;right:-50px;top:-50px;width:300px;height:300px;border-radius:50%;background:radial-gradient(circle,#D4AF3730,transparent 70%)}
.memberHero::before{content:"ב";position:absolute;right:34px;bottom:-26px;font-family:var(--display);font-size:11rem;color:#ffffff0d;line-height:1}
.mh-inner{max-width:780px;margin:0 auto;position:relative;z-index:1}
.mh-kicker{font-family:var(--sans);font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:#E6C66B;font-weight:700}
.mh-title{font-family:var(--display);font-size:2.1rem;margin:.18em 0 .12em;line-height:1.1}
.mh-sub{font-family:var(--sans);color:#DCE7E0;font-size:1rem;margin:0 0 18px}
.mh-stats{display:flex;gap:24px;font-family:var(--sans);font-size:.84rem;color:#BCCFC5;flex-wrap:wrap}
.mh-stats b{color:#fff;font-size:1.05rem}
.memberSec{font-family:var(--display);font-size:1.32rem;color:var(--ink);margin:30px 0 16px}
.memberGrid{display:grid;grid-template-columns:1fr 1fr;gap:22px}
@media(max-width:680px){.memberGrid{grid-template-columns:1fr}.mh-title{font-size:1.7rem}}
.memberCard{display:block;background:var(--paper);border:1px solid var(--line);border-radius:16px;overflow:hidden;transition:.18s;box-shadow:0 2px 10px rgba(40,30,10,.05)}
.memberCard:hover{transform:translateY(-3px);box-shadow:0 14px 32px rgba(27,67,50,.18);border-color:var(--boxb)}
.mc-cover{position:relative;height:158px;padding:20px 22px;display:flex;flex-direction:column;justify-content:flex-end;color:#fff;overflow:hidden}
.mc-cover.cover-a{background:linear-gradient(135deg,#1B4332,#2D6A4F)}
.mc-cover.cover-b{background:linear-gradient(135deg,#14342a,#43330f)}
.mc-cover-mark{position:absolute;right:12px;top:-12px;font-size:6rem;font-family:var(--display);color:#ffffff16;line-height:1;pointer-events:none}
.mc-cover-kicker{font-family:var(--sans);font-size:.64rem;letter-spacing:.16em;text-transform:uppercase;color:#E6C66B;font-weight:700;position:relative}
.mc-cover-title{font-family:var(--display);font-size:1.42rem;line-height:1.14;margin-top:5px;position:relative;text-shadow:0 1px 8px rgba(0,0,0,.25)}
.mc-body{padding:16px 20px 18px}
.mc-meta{display:flex;gap:8px;margin-bottom:10px;flex-wrap:wrap}
.mc-badge{font-family:var(--sans);font-size:.66rem;font-weight:700;background:var(--box);border:1px solid var(--boxb);color:var(--bronzeD);padding:3px 9px;border-radius:20px}
.mc-badge.alt{background:#1b43320d;border-color:#1b433222;color:var(--side)}
.mc-sub{font-style:italic;color:var(--muted);font-size:.95rem;margin:0 0 14px;line-height:1.4}
.mc-prog{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.mc-prog .bar{flex:1;height:8px;border-radius:6px;background:var(--box);overflow:hidden}
.mc-prog .bar i{display:block;height:100%;background:linear-gradient(90deg,var(--bronzeD),var(--bronze))}
.mc-prog span{font-family:var(--sans);font-size:.78rem;color:var(--muted);font-weight:600}
.mc-cta{font-family:var(--sans);font-weight:700;font-size:.9rem;color:var(--side)}
.memberCard:hover .mc-cta{color:var(--bronzeD)}

/* ===== Central de materiais (ativos do curso) ===== */
.ativoGrid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:8px}
@media(max-width:680px){.ativoGrid{grid-template-columns:1fr}}
.ativo{display:flex;align-items:center;gap:14px;background:var(--paper);border:1px solid var(--line);border-radius:14px;padding:15px 16px;transition:.15s;opacity:.62;cursor:default}
.ativo.on{opacity:1;cursor:pointer}
.ativo.on:hover{border-color:var(--bronze);transform:translateY(-2px);box-shadow:0 8px 22px rgba(124,74,2,.1)}
.ativo .at-ic{font-size:1.7rem;width:46px;height:46px;flex:none;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#efe7d6,#f6f1e7);border:1px solid var(--boxb);border-radius:11px}
.ativo.on .at-ic{background:linear-gradient(135deg,#1B4332,#2D6A4F);filter:none}
.ativo .at-tx{flex:1;min-width:0}
.ativo .at-t{font-family:var(--sans);font-weight:700;font-size:.95rem;color:var(--ink)}
.ativo .at-s{font-family:var(--sans);font-size:.8rem;color:var(--muted);margin-top:1px}
.ativo .at-tag{font-family:var(--sans);font-size:.64rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);background:var(--box);border:1px solid var(--boxb);padding:3px 8px;border-radius:20px;white-space:nowrap}
.ativo .at-tag.ok{color:#fff;background:var(--ok);border-color:var(--ok)}

/* ===== navegação da aula sempre visível (mobile) ===== */
.lessNav{position:sticky;top:59px;z-index:6;background:var(--cream);padding:10px 0;gap:10px;flex-wrap:wrap;border-bottom:1px solid var(--line)}
.lessNav .back{font-weight:700;color:var(--side);background:var(--box);border:1px solid var(--boxb);border-radius:9px;padding:7px 13px;text-decoration:none}
.lessNav .back:hover{border-color:var(--bronze)}
.ln-arrows{display:flex;gap:8px;margin-left:auto}
.ln-arrows button{font-family:var(--sans);font-weight:700;font-size:.82rem;border:1px solid var(--boxb);background:var(--paper);color:var(--side);border-radius:9px;padding:7px 13px;cursor:pointer}
.ln-arrows button:last-child{background:var(--bronze);border-color:var(--bronze);color:#1c1812}
.ln-arrows button[disabled]{opacity:.4;cursor:default}
.topbar .menuToggle{font-size:1.25rem;font-weight:700}

/* ===== alerta de correção pendente (notificação) ===== */
.pendalert{background:linear-gradient(135deg,#fff6e6,#fdeccb);border:1px solid #e8c98a;border-radius:12px;padding:14px 18px;margin-bottom:18px;font-family:var(--sans);font-size:.9rem;color:#7a5610;line-height:1.5}
