/* ===== Universidade Enermac — Identidade Visual ===== */
:root{
  --azul:#1B3B6F;        /* azul-marinho institucional */
  --azul-2:#15315c;
  --azul-3:#0f2546;
  --laranja:#F47920;     /* laranja chama Enermac */
  --laranja-2:#ff8c3a;
  --azul-claro:#CFDDF2;
  --bg:#F2F5FB;
  --verde:#2B8659;
  --cinza:#5b6b82;
  --texto:#1f2937;
  --borda:#e3e9f3;
  --branco:#fff;
  --sombra:0 2px 12px rgba(27,59,111,.08);
  --sombra-2:0 8px 28px rgba(27,59,111,.16);
  --radius:14px;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{font-family:'Segoe UI',Calibri,system-ui,Arial,sans-serif;color:var(--texto);background:var(--bg);line-height:1.5;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none}
::selection{background:var(--laranja);color:#fff}

/* proteção de conteúdo */
.no-select{user-select:none;-webkit-user-select:none}

/* ===== LOGIN ===== */
.login-wrap{min-height:100vh;display:grid;grid-template-columns:1.1fr 1fr}
.login-hero{background:linear-gradient(135deg,var(--azul) 0%,var(--azul-3) 100%);position:relative;overflow:hidden;display:flex;flex-direction:column;justify-content:center;padding:64px;color:#fff}
.login-hero::after{content:"";position:absolute;right:-120px;top:-120px;width:420px;height:420px;background:radial-gradient(circle,rgba(244,121,32,.35),transparent 70%);border-radius:50%}
.login-hero::before{content:"";position:absolute;left:-80px;bottom:-80px;width:320px;height:320px;background:radial-gradient(circle,rgba(207,221,242,.18),transparent 70%);border-radius:50%}
.login-hero img{width:300px;margin-bottom:32px;position:relative;z-index:2}
.login-hero h1{font-size:34px;font-weight:800;line-height:1.15;position:relative;z-index:2;letter-spacing:-.5px}
.login-hero h1 span{color:var(--laranja-2)}
.login-hero p{margin-top:16px;color:var(--azul-claro);font-size:16px;max-width:440px;position:relative;z-index:2}
.login-form-side{display:flex;align-items:center;justify-content:center;padding:40px;background:var(--branco)}
.login-card{width:100%;max-width:380px}
.login-card h2{font-size:24px;color:var(--azul);margin-bottom:6px}
.login-card .sub{color:var(--cinza);margin-bottom:28px;font-size:14px}
.field{margin-bottom:16px}
.field label{display:block;font-size:13px;font-weight:600;color:var(--azul);margin-bottom:6px}
.field input{width:100%;padding:12px 14px;border:1.5px solid var(--borda);border-radius:10px;font-size:15px;transition:.15s;background:#fbfcfe}
.field input:focus{outline:none;border-color:var(--laranja);background:#fff;box-shadow:0 0 0 3px rgba(244,121,32,.12)}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 20px;border-radius:10px;font-weight:700;font-size:15px;transition:.15s;background:var(--laranja);color:#fff}
.btn:hover{background:var(--laranja-2);transform:translateY(-1px)}
.btn:active{transform:translateY(0)}
.btn-block{width:100%}
.btn-ghost{background:transparent;color:var(--azul);border:1.5px solid var(--borda)}
.btn-ghost:hover{background:var(--bg);transform:none}
.btn-azul{background:var(--azul)}.btn-azul:hover{background:var(--azul-2)}
.btn-sm{padding:7px 12px;font-size:13px;border-radius:8px}
.btn-danger{background:#e23b3b}.btn-danger:hover{background:#c92f2f}
.alert{padding:11px 14px;border-radius:9px;font-size:14px;margin-bottom:16px;display:none}
.alert.err{background:#fdeaea;color:#c0392b;display:block}
.alert.ok{background:#e8f6ee;color:var(--verde);display:block}
.login-hint{margin-top:20px;font-size:12px;color:var(--cinza);background:var(--bg);padding:12px;border-radius:8px;line-height:1.7}

/* ===== APP SHELL ===== */
.app{display:none;min-height:100vh;grid-template-columns:260px 1fr;grid-template-rows:auto 1fr}
.sidebar{grid-row:1/3;background:linear-gradient(180deg,var(--azul) 0%,var(--azul-3) 100%);color:#fff;padding:22px 16px;position:sticky;top:0;height:100vh;overflow-y:auto;transition:padding .2s}
.sidebar .logo{display:flex;align-items:center;justify-content:center;padding:6px 8px 22px;border-bottom:1px solid rgba(255,255,255,.12);margin-bottom:16px}
.sidebar .logo img.logo-full{width:160px}
.sidebar .logo img.logo-mini{width:42px;display:none}
.sidebar-collapse{position:absolute;top:24px;right:10px;width:26px;height:26px;border-radius:7px;background:rgba(255,255,255,.1);display:grid;place-items:center;cursor:pointer;font-size:15px;color:#cdd9ef;transition:.13s}
.sidebar-collapse:hover{background:var(--laranja);color:#fff}
.nav-item{display:flex;align-items:center;gap:11px;padding:11px 13px;border-radius:10px;color:#cdd9ef;font-weight:600;font-size:14.5px;margin-bottom:3px;transition:.13s;cursor:pointer;white-space:nowrap;overflow:hidden}
.nav-item .ic{font-size:18px;width:22px;text-align:center;flex-shrink:0}
.nav-item:hover{background:rgba(255,255,255,.08);color:#fff}
.nav-item.active{background:var(--laranja);color:#fff;box-shadow:0 4px 12px rgba(244,121,32,.4)}
.nav-sep{font-size:11px;text-transform:uppercase;letter-spacing:1px;color:#7e92b8;padding:14px 13px 6px;font-weight:700;white-space:nowrap;overflow:hidden}

/* menu recolhido */
.app.collapsed{grid-template-columns:78px 1fr}
.app.collapsed .sidebar{padding:22px 14px}
.app.collapsed .logo img.logo-full{display:none}
.app.collapsed .logo img.logo-mini{display:block}
.app.collapsed .nav-item{justify-content:center;padding:12px 0;gap:0}
.app.collapsed .nav-item .lbl{display:none}
.app.collapsed .nav-sep{text-align:center;font-size:0;padding:10px 0 4px}
.app.collapsed .nav-sep::after{content:"•••";font-size:11px;color:#7e92b8}
.app.collapsed .sidebar-collapse{right:50%;transform:translateX(50%)}
.app.collapsed .topbar,.app.collapsed .content{grid-column:2}

.topbar{grid-column:2;display:flex;align-items:center;justify-content:space-between;padding:14px 28px;background:#fff;border-bottom:1px solid var(--borda);position:sticky;top:0;z-index:30}
.topbar h1{font-size:19px;color:var(--azul);font-weight:700}
.topbar .right{display:flex;align-items:center;gap:14px}
.userchip{display:flex;align-items:center;gap:10px;padding:6px 10px;border-radius:30px;background:var(--bg)}
.avatar{width:34px;height:34px;border-radius:50%;background:var(--azul);color:#fff;display:grid;place-items:center;font-weight:700;font-size:14px}
.userchip .meta{font-size:13px}
.userchip .meta b{display:block;color:var(--azul)}
.userchip .meta span{color:var(--cinza);font-size:11.5px;text-transform:capitalize}

.bell{position:relative;width:40px;height:40px;border-radius:50%;background:var(--bg);display:grid;place-items:center;font-size:18px;cursor:pointer;transition:.13s}
.bell:hover{background:var(--azul-claro)}
.bell .badge{position:absolute;top:-2px;right:-2px;background:var(--laranja);color:#fff;font-size:10px;font-weight:700;min-width:18px;height:18px;border-radius:9px;display:grid;place-items:center;padding:0 4px}

.content{grid-column:2;padding:28px;max-width:1180px}

/* ===== CARDS / GRID ===== */
.grid{display:grid;gap:18px}
.grid-3{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}
.grid-4{grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}
.card{background:#fff;border:1px solid var(--borda);border-radius:var(--radius);padding:20px;box-shadow:var(--sombra)}
.card.click{cursor:pointer;transition:.16s}
.card.click:hover{transform:translateY(-3px);box-shadow:var(--sombra-2);border-color:var(--azul-claro)}

.module-card .mc-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.mc-code{font-size:12px;font-weight:800;color:var(--laranja);background:#fff3e9;padding:4px 10px;border-radius:20px}
.module-card h3{font-size:16.5px;color:var(--azul);margin-bottom:4px;line-height:1.3}
.module-card .mc-meta{font-size:12.5px;color:var(--cinza);margin-bottom:14px}
.progress-bar{height:8px;background:var(--bg);border-radius:6px;overflow:hidden}
.progress-bar > i{display:block;height:100%;background:linear-gradient(90deg,var(--laranja),var(--laranja-2));border-radius:6px;transition:width .4s}
.progress-bar.green > i{background:linear-gradient(90deg,var(--verde),#38a06d)}
.mc-foot{display:flex;justify-content:space-between;font-size:12px;margin-top:8px;color:var(--cinza)}

/* stat cards */
.stat{display:flex;flex-direction:column;gap:6px}
.stat .v{font-size:30px;font-weight:800;color:var(--azul);line-height:1}
.stat .l{font-size:13px;color:var(--cinza)}
.stat .ic{font-size:22px}

/* rank */
.rank-banner{background:linear-gradient(120deg,var(--azul),var(--azul-3));color:#fff;border-radius:var(--radius);padding:26px;display:flex;align-items:center;gap:24px;position:relative;overflow:hidden}
.rank-banner::after{content:"";position:absolute;right:-60px;top:-60px;width:220px;height:220px;background:radial-gradient(circle,rgba(244,121,32,.4),transparent 70%);border-radius:50%}
.rank-emoji{font-size:62px;position:relative;z-index:2}
.rank-info{position:relative;z-index:2;flex:1}
.rank-info .lbl{font-size:13px;color:var(--azul-claro);text-transform:uppercase;letter-spacing:1px}
.rank-info h2{font-size:26px;margin:2px 0 10px}
.rank-next{font-size:13px;color:var(--azul-claro)}
.rank-progress{margin-top:8px;height:10px;background:rgba(255,255,255,.18);border-radius:6px;overflow:hidden;max-width:340px}
.rank-progress > i{display:block;height:100%;background:var(--laranja);border-radius:6px}

/* content type pills */
.type-pill{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-weight:700;padding:3px 10px;border-radius:20px}
.tp-documento{background:#e8eefb;color:#2b5fb3}
.tp-apresentacao{background:#fff3e9;color:#d4691a}
.tp-pop{background:#eef7f1;color:var(--verde)}
.tp-infografico{background:#f3eafd;color:#7e3fc0}
.tp-video{background:#fdeaea;color:#c0392b}

/* content list */
.content-row{display:flex;align-items:center;gap:16px;padding:15px 18px;background:#fff;border:1px solid var(--borda);border-radius:12px;margin-bottom:10px;cursor:pointer;transition:.14s}
.content-row:hover{border-color:var(--azul-claro);box-shadow:var(--sombra);transform:translateX(2px)}
.content-row .cr-ic{width:46px;height:46px;border-radius:11px;display:grid;place-items:center;font-size:22px;flex-shrink:0}
.content-row .cr-main{flex:1;min-width:0}
.content-row .cr-main b{display:block;color:var(--azul);font-size:15px;margin-bottom:3px}
.content-row .cr-meta{font-size:12.5px;color:var(--cinza);display:flex;gap:12px;flex-wrap:wrap}
.content-row .cr-status{flex-shrink:0;font-size:24px}
.check-done{color:var(--verde)}
.check-todo{color:#cdd5e3}

/* table */
table{width:100%;border-collapse:collapse;background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--sombra)}
th,td{text-align:left;padding:12px 16px;font-size:14px;border-bottom:1px solid var(--borda)}
th{background:var(--azul);color:#fff;font-size:12.5px;text-transform:uppercase;letter-spacing:.5px;font-weight:700}
tr:last-child td{border-bottom:none}
tbody tr:hover{background:#fafbfe}
.badge-role{font-size:11px;font-weight:700;padding:3px 9px;border-radius:20px;text-transform:capitalize}
.role-diretor{background:#fff3e9;color:var(--laranja)}
.role-gerente{background:#e8eefb;color:var(--azul)}
.role-colaborador{background:#eef7f1;color:var(--verde)}

/* modal / viewer */
.overlay{position:fixed;inset:0;background:rgba(15,37,70,.78);backdrop-filter:blur(4px);z-index:100;display:none;align-items:center;justify-content:center;padding:24px}
.overlay.open{display:flex}
.modal{background:#fff;border-radius:16px;width:100%;max-width:520px;max-height:90vh;overflow:auto;box-shadow:var(--sombra-2)}
.modal.wide{max-width:1080px}
.modal-head{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--borda);position:sticky;top:0;background:#fff;z-index:5}
.modal-head h3{color:var(--azul);font-size:18px;flex:1}
.modal-x{width:34px;height:34px;border-radius:50%;background:var(--bg);display:grid;place-items:center;font-size:18px;cursor:pointer}
.modal-x:hover{background:#fdeaea;color:#c0392b}
.modal-body{padding:22px}

/* viewer specifics */
.viewer-head{display:flex;align-items:center;gap:14px;padding:16px 22px;border-bottom:1px solid var(--borda);background:var(--azul);color:#fff;position:sticky;top:0;z-index:6}
.viewer-head .vh-ic{font-size:26px}
.viewer-head h3{flex:1;font-size:17px}
.viewer-head .timer{font-size:13px;background:rgba(255,255,255,.15);padding:6px 12px;border-radius:20px;font-weight:600}
.viewer-head .timer.done{background:var(--verde)}
.viewer-body{padding:0;background:#fff;min-height:300px}
.doc-html{padding:38px 46px;max-width:820px;margin:0 auto;font-size:15.5px;line-height:1.75}
.doc-html h1,.doc-html h2,.doc-html h3{color:var(--azul);margin:18px 0 10px}
.doc-html h1{font-size:24px}.doc-html h2{font-size:20px}.doc-html h3{font-size:17px}
.doc-html p{margin-bottom:12px}
.doc-html ul,.doc-html ol{margin:0 0 12px 22px}
.doc-html li{margin-bottom:5px}
.doc-html table{box-shadow:none;border:1px solid var(--borda);margin:12px 0}
.doc-html th{background:var(--azul-claro);color:var(--azul)}
.doc-html strong{color:var(--azul-2)}
.viewer-img{display:flex;justify-content:center;padding:24px;background:#0f2546}
.viewer-img img{max-height:75vh;border-radius:8px;box-shadow:0 10px 40px rgba(0,0,0,.4)}
.viewer-video{background:#000;display:flex;justify-content:center}
.viewer-video video{max-height:78vh;width:100%}
.viewer-pptx{padding:30px;text-align:center;background:var(--bg)}
.viewer-pdf{background:#0f2546}
.viewer-pdf iframe{width:100%;height:78vh;border:0;display:block}

/* botão de tela cheia no cabeçalho do viewer */
.viewer-head .vh-btn{width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.15);display:grid;place-items:center;font-size:17px;cursor:pointer;color:#fff}
.viewer-head .vh-btn:hover{background:rgba(255,255,255,.28)}

/* visualizador de slides / PDF (apresentações e documentos de alta fidelidade) */
.slides-loading{padding:60px;text-align:center;color:var(--cinza);line-height:1.6}
.slides-wrap{background:#0f2546;display:flex;flex-direction:column}
.slide-stage{flex:1;display:flex;align-items:center;justify-content:center;padding:18px;min-height:64vh}
.slide-stage canvas{max-width:100%;max-height:100%;border-radius:8px;box-shadow:0 12px 44px rgba(0,0,0,.5);background:#fff}
.slide-nav{display:flex;align-items:center;justify-content:center;gap:22px;padding:14px;background:#0b1d3a}
.slide-btn{width:46px;height:46px;border-radius:50%;border:0;background:var(--laranja);color:#fff;font-size:26px;line-height:1;cursor:pointer;display:grid;place-items:center;transition:.13s}
.slide-btn:hover{filter:brightness(1.08)}
.slide-btn:disabled{background:#3a4a66;cursor:default;opacity:.5}
.slide-count{color:#fff;font-weight:700;font-size:15px;min-width:74px;text-align:center}

/* viewer em tela cheia */
#viewerModal:fullscreen{max-width:none;width:100vw;height:100vh;border-radius:0;display:flex;flex-direction:column}
#viewerModal:fullscreen .viewer-body{flex:1;overflow:auto}
#viewerModal:fullscreen .slides-wrap{height:100%}
#viewerModal:fullscreen .slide-stage{min-height:0;flex:1}
#viewerModal:fullscreen .viewer-video video,#viewerModal:fullscreen .viewer-pdf iframe{max-height:none;height:100%}
.pptx-note{background:#fff;border:1px dashed var(--azul-claro);border-radius:12px;padding:28px;color:var(--cinza)}

.studybar{padding:14px 22px;background:var(--bg);border-top:1px solid var(--borda);position:sticky;bottom:0}
.studybar .sb-info{font-size:13px;color:var(--cinza);margin-bottom:7px;display:flex;justify-content:space-between}
.studybar .sb-info b{color:var(--azul)}

/* comments */
.comment{background:#fff;border:1px solid var(--borda);border-radius:12px;padding:14px 16px;margin-bottom:10px}
.comment .c-head{display:flex;align-items:center;gap:10px;margin-bottom:7px}
.comment .c-head .av{width:30px;height:30px;border-radius:50%;background:var(--azul);color:#fff;display:grid;place-items:center;font-size:12px;font-weight:700}
.comment .c-head b{color:var(--azul);font-size:14px}
.comment .c-head .when{font-size:11.5px;color:var(--cinza);margin-left:auto}
.comment .c-body{font-size:14px;color:var(--texto)}
.comment .c-actions{margin-top:8px;display:flex;gap:10px}
.comment .c-actions button{font-size:12px;color:var(--azul);background:none;font-weight:600}
.comment.reply{margin-left:34px;background:#fafbfe}
.kind-tag{font-size:10.5px;font-weight:700;padding:2px 8px;border-radius:12px;text-transform:uppercase}
.kind-duvida{background:#fff3e9;color:var(--laranja)}
.kind-nota{background:#e8eefb;color:var(--azul)}
.resolved-tag{background:#eef7f1;color:var(--verde);font-size:10.5px;font-weight:700;padding:2px 8px;border-radius:12px}

textarea{width:100%;padding:12px 14px;border:1.5px solid var(--borda);border-radius:10px;font-family:inherit;font-size:14px;resize:vertical;min-height:80px}
textarea:focus{outline:none;border-color:var(--laranja);box-shadow:0 0 0 3px rgba(244,121,32,.1)}
select{padding:10px 12px;border:1.5px solid var(--borda);border-radius:9px;font-family:inherit;font-size:14px;background:#fff}
select:focus{outline:none;border-color:var(--laranja)}

/* notifications dropdown */
.notif-panel{position:absolute;top:54px;right:0;width:340px;background:#fff;border:1px solid var(--borda);border-radius:14px;box-shadow:var(--sombra-2);z-index:60;display:none;overflow:hidden}
.notif-panel.open{display:block}
.notif-panel .np-head{padding:14px 16px;border-bottom:1px solid var(--borda);display:flex;justify-content:space-between;align-items:center}
.notif-panel .np-head b{color:var(--azul)}
.notif-panel .np-head button{font-size:12px;color:var(--laranja);background:none;font-weight:600}
.notif-list{max-height:380px;overflow:auto}
.notif{padding:13px 16px;border-bottom:1px solid var(--borda);font-size:13.5px;display:flex;gap:10px}
.notif.unread{background:#fff8f2}
.notif .nt-dot{width:8px;height:8px;border-radius:50%;background:var(--laranja);margin-top:6px;flex-shrink:0}
.notif.read .nt-dot{background:transparent}
.notif .when{font-size:11px;color:var(--cinza);margin-top:3px}

.section-title{font-size:15px;color:var(--azul);font-weight:700;margin:26px 0 14px;display:flex;align-items:center;gap:8px}
.empty{text-align:center;padding:50px 20px;color:var(--cinza)}
.empty .ic{font-size:46px;margin-bottom:12px}

/* upload */
.dropzone{border:2.5px dashed var(--azul-claro);border-radius:16px;padding:44px;text-align:center;cursor:pointer;transition:.15s;background:#fbfcff}
.dropzone:hover,.dropzone.drag{border-color:var(--laranja);background:#fff8f2}
.dropzone .ic{font-size:50px;margin-bottom:12px}
.dropzone b{color:var(--azul);font-size:17px;display:block;margin-bottom:6px}
.dropzone span{color:var(--cinza);font-size:13.5px}
.upload-progress{margin-top:18px;display:none}
.upbar{height:24px;background:var(--bg);border-radius:14px;overflow:hidden;position:relative}
.upbar > i{display:block;height:100%;background:linear-gradient(90deg,var(--azul),var(--laranja));transition:width .3s;border-radius:14px}
.upbar .lbl{position:absolute;inset:0;display:grid;place-items:center;font-size:12px;font-weight:700;color:var(--azul)}

/* tour */
.tour-spot{position:fixed;z-index:200;border-radius:12px;box-shadow:0 0 0 4px var(--laranja),0 0 0 9999px rgba(15,37,70,.72);transition:.25s;pointer-events:none}
.tour-pop{position:fixed;z-index:201;background:#fff;border-radius:14px;padding:20px 22px;max-width:320px;box-shadow:var(--sombra-2)}
.tour-pop h4{color:var(--azul);font-size:16px;margin-bottom:6px}
.tour-pop p{font-size:13.5px;color:var(--cinza);margin-bottom:14px}
.tour-pop .tp-actions{display:flex;justify-content:space-between;align-items:center}
.tour-pop .tp-step{font-size:12px;color:var(--cinza)}
.tour-pop .tp-btns{display:flex;gap:8px}

.row{display:flex;gap:12px;align-items:center}
.row.wrap{flex-wrap:wrap}
.spacer{flex:1}
.mt{margin-top:16px}.mb{margin-bottom:16px}
.muted{color:var(--cinza);font-size:13px}
.center{text-align:center}
.hidden{display:none!important}

/* responsive */
@media(max-width:900px){
  .login-wrap{grid-template-columns:1fr}
  .login-hero{display:none}
  .app{grid-template-columns:1fr}
  .sidebar{position:fixed;left:-260px;width:260px;z-index:90;transition:.25s}
  .sidebar.open{left:0}
  .topbar,.content{grid-column:1}
  .menu-toggle{display:grid!important}
}
.menu-toggle{display:none;width:40px;height:40px;border-radius:9px;background:var(--bg);place-items:center;font-size:20px;cursor:pointer}

/* ===== pastas de cargo (audiência) expansíveis ===== */
.aud-folder{background:#fff;border:1px solid var(--borda);border-radius:14px;margin-bottom:14px;overflow:hidden;box-shadow:var(--sombra)}
.aud-head{display:flex;align-items:center;gap:14px;padding:16px 20px;cursor:pointer;transition:.13s}
.aud-head:hover{background:#fafbfe}
.aud-head .af-ic{width:44px;height:44px;border-radius:11px;display:grid;place-items:center;font-size:22px;flex-shrink:0}
.af-vendedor{background:#eef7f1;color:var(--verde)}
.af-gestor{background:#e8eefb;color:var(--azul)}
.af-todos{background:#fff3e9;color:var(--laranja)}
.aud-head .af-main{flex:1;min-width:0}
.aud-head .af-main b{display:block;color:var(--azul);font-size:15.5px}
.aud-head .af-main .af-sub{font-size:12.5px;color:var(--cinza)}
.aud-head .af-right{display:flex;align-items:center;gap:14px;flex-shrink:0}
.aud-head .af-pct{text-align:right;min-width:118px}
.aud-head .af-pct .pbar{height:7px;background:var(--bg);border-radius:5px;overflow:hidden;margin-top:5px}
.aud-head .af-pct .pbar>i{display:block;height:100%;background:linear-gradient(90deg,var(--laranja),var(--laranja-2));border-radius:5px;transition:width .4s}
.aud-head .af-pct .pbar.green>i{background:linear-gradient(90deg,var(--verde),#38a06d)}
.aud-head .af-chev{font-size:15px;color:var(--cinza);transition:transform .2s}
.aud-folder.open .af-chev{transform:rotate(90deg)}
.aud-body{display:none;padding:6px 16px 16px}
.aud-folder.open .aud-body{display:block}

/* ===== treinamentos / gestão (CRUD diretor) ===== */
.course-card{position:relative}
.course-card .cc-actions{position:absolute;top:14px;right:14px;display:flex;gap:6px;opacity:0;transition:.13s}
.course-card:hover .cc-actions{opacity:1}
.icon-btn{width:30px;height:30px;border-radius:8px;background:var(--bg);display:grid;place-items:center;font-size:14px;cursor:pointer;border:1px solid var(--borda)}
.icon-btn:hover{background:var(--azul-claro)}
.icon-btn.danger:hover{background:#fdeaea;color:#c0392b}

.struct-module{background:#fff;border:1px solid var(--borda);border-radius:14px;margin-bottom:12px;box-shadow:var(--sombra)}
.struct-mhead{display:flex;align-items:center;gap:12px;padding:15px 18px;cursor:pointer}
.struct-mhead:hover{background:#fafbfe}
.struct-mhead .sm-code{font-size:12px;font-weight:800;color:var(--laranja);background:#fff3e9;padding:4px 10px;border-radius:20px;flex-shrink:0}
.struct-mhead h4{flex:1;color:var(--azul);font-size:15.5px}
.struct-mhead .sm-chev{transition:transform .2s;color:var(--cinza)}
.struct-module.open .sm-chev{transform:rotate(90deg)}
.struct-body{display:none;padding:4px 18px 16px}
.struct-module.open .struct-body{display:block}
.struct-content{display:flex;align-items:center;gap:12px;padding:10px 12px;border:1px solid var(--borda);border-radius:10px;margin-bottom:8px;background:#fbfcfe}
.struct-content .sc-ic{width:36px;height:36px;border-radius:9px;display:grid;place-items:center;font-size:18px;flex-shrink:0}
.struct-content .sc-main{flex:1;min-width:0}
.struct-content .sc-main b{display:block;color:var(--azul);font-size:14px}
.struct-content .sc-meta{font-size:11.5px;color:var(--cinza)}
.struct-content .sc-actions{display:flex;gap:6px;flex-shrink:0}
.drag-handle{cursor:grab;color:#b8c2d4;font-size:16px;padding:0 4px}
.dragging{opacity:.4}
.drop-target{border-top:2px solid var(--laranja)!important}

/* ===== @menção autocomplete ===== */
.mention-box{position:relative}
.mention-list{position:absolute;bottom:100%;left:0;right:0;background:#fff;border:1px solid var(--borda);border-radius:10px;box-shadow:var(--sombra-2);max-height:200px;overflow:auto;z-index:120;display:none;margin-bottom:4px}
.mention-list.open{display:block}
.mention-item{display:flex;align-items:center;gap:10px;padding:10px 12px;cursor:pointer}
.mention-item:hover,.mention-item.active{background:var(--azul-claro)}
.mention-item .av{width:28px;height:28px;border-radius:50%;background:var(--azul);color:#fff;display:grid;place-items:center;font-size:11px;font-weight:700}
.mention-item .mi-name{font-size:13.5px;color:var(--azul);font-weight:600}
.mention-item .mi-role{font-size:11px;color:var(--cinza)}
.mention-chip{color:var(--laranja);font-weight:700}
.c-body .mention-chip{background:#fff3e9;padding:1px 5px;border-radius:5px}

/* chips de menção selecionada */
.mention-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:8px}
.mtag{display:inline-flex;align-items:center;gap:5px;background:#fff3e9;color:var(--laranja);font-size:12px;font-weight:600;padding:3px 8px;border-radius:14px}
.mtag b{cursor:pointer}
