/* JUNIP - Dashboard (no header/footer) */
:root{
  --azul:#0A3D91; --azul-700:#0B47AD; --azul-900:#062A66; --azul-50:#EAF1FB;
  --amarelo:#FFC107; --amarelo-600:#E0A800; --amarelo-50:#FFF7DC;
  --txt:#0F1A2B; --muted:#5A6B86; --bg:#F4F6FB; --branco:#fff; --borda:#E3E8F1;
  --ok:#16a34a; --erro:#dc2626; --warn:#f59e0b; --info:#0ea5e9;
  --shadow:0 4px 18px rgba(10,61,145,.07); --radius:14px;
  --sidebar-w:260px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;color:var(--txt);background:var(--bg)}
a{color:var(--azul);text-decoration:none}

/* App layout — sidebar fixed + main com margem */
.app{position:relative;min-height:100vh}
/* Pseudo-elemento removido — sidebar fixed já cobre a coluna inteira */
.app::before{display:none}
/* Sidebar — position:fixed com 3 zonas (header / menu rolável / footer fixo) */
.sidebar{
  position:fixed;
  top:0;
  left:0;
  width:var(--sidebar-w);
  height:100vh;
  background:linear-gradient(180deg,var(--azul-900) 0%,var(--azul) 100%);
  color:#fff;
  display:flex;
  flex-direction:column;
  overflow:hidden;
  z-index:100;
}
/* Main com margem esquerda equivalente à largura do sidebar */
.main{
  margin-left:var(--sidebar-w);
  min-height:100vh;
  min-width:0;
  display:flex;
  flex-direction:column;
}
.sidebar::-webkit-scrollbar{width:6px}
.sidebar::-webkit-scrollbar-thumb{background:rgba(255,255,255,.15);border-radius:3px}
.sidebar .brand{padding:22px 22px 18px;display:flex;align-items:center;gap:12px;border-bottom:1px solid rgba(255,255,255,.08);flex:0 0 auto}
.sidebar .brand .logo{width:40px;height:40px;border-radius:10px;background:var(--amarelo);color:var(--azul-900);display:grid;place-items:center;font-weight:900;box-shadow:0 4px 14px rgba(255,193,7,.35)}
.sidebar .brand .name{font-weight:800;font-size:18px;letter-spacing:.5px}
.sidebar .brand .name span{color:var(--amarelo)}
.sidebar .role{padding:14px 22px 10px;font-size:11px;text-transform:uppercase;letter-spacing:1.5px;color:var(--amarelo);font-weight:700;opacity:.9;flex:0 0 auto}
/* Menu central rolável — única área com scroll */
.sidebar nav{
  flex:1 1 auto;
  min-height:0;
  overflow-y:auto;
  overflow-x:hidden;
  padding:4px 12px 14px;
  scrollbar-width:thin;
  scrollbar-color:rgba(255,255,255,.15) transparent;
}
.sidebar nav::-webkit-scrollbar{width:4px}
.sidebar nav::-webkit-scrollbar-thumb{background:rgba(255,255,255,.12);border-radius:2px}
.sidebar nav::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,.25)}
.sidebar nav .group{margin-bottom:8px}
.sidebar nav .group:last-child{margin-bottom:0}
.sidebar nav .group-title{padding:10px 12px 6px;color:rgba(255,255,255,.45);font-size:10px;text-transform:uppercase;letter-spacing:1.5px;font-weight:700}
.sidebar nav a{display:flex;align-items:center;gap:12px;padding:10px 12px;color:#dde7fb;border-radius:9px;font-size:13.5px;margin-bottom:2px;transition:all .15s;cursor:pointer;text-decoration:none;border-left:3px solid transparent;position:relative}
.sidebar nav a:hover{background:rgba(255,255,255,.08);color:#fff;border-left-color:rgba(255,193,7,.4)}
.sidebar nav a.active{background:rgba(255,193,7,.15);color:#fff;font-weight:600;border-left-color:var(--amarelo)}
.sidebar nav a.active::before{content:"";position:absolute;left:-12px;top:50%;transform:translateY(-50%);width:3px;height:60%;background:var(--amarelo);border-radius:0 3px 3px 0;display:none}
.sidebar nav a .ico{width:20px;display:inline-grid;place-items:center;font-size:14px;color:rgba(255,255,255,.7);transition:color .15s}
.sidebar nav a:hover .ico, .sidebar nav a.active .ico{color:var(--amarelo)}
.sidebar nav a .badge{margin-left:auto;background:var(--amarelo);color:var(--azul-900);font-size:10.5px;padding:2px 7px;border-radius:10px;font-weight:800;line-height:1.2}
/* Footer fixo no rodapé do sidebar (sempre visível) */
.sidebar-foot{
  flex:0 0 auto;
  margin-top:auto;
  padding:14px 22px;
  border-top:1px solid rgba(255,255,255,.08);
  font-size:10.5px;
  color:rgba(255,255,255,.4);
  text-align:center;
  letter-spacing:.5px;
  background:rgba(0,0,0,.2);
}
.sidebar-foot b{color:var(--amarelo);font-weight:700}
/* User-card antigo do sidebar — removido */
.sidebar .user-card{display:none}

/* Main */
.main{min-width:0;display:flex;flex-direction:column}
.topbar{display:flex;align-items:center;gap:14px;padding:16px 28px;background:#fff;border-bottom:1px solid var(--borda);position:sticky;top:0;z-index:20}
.topbar .menu-btn{display:none;background:var(--azul-50);border:0;width:38px;height:38px;border-radius:10px;color:var(--azul);font-size:18px;cursor:pointer}
.topbar .crumb{flex:1;display:flex;align-items:center;gap:8px;color:var(--muted);font-size:13.5px}
.topbar .crumb b{color:var(--azul-900);font-weight:700}
.topbar .search{flex:0 1 320px;display:flex;align-items:center;background:var(--bg);border:1px solid var(--borda);border-radius:10px;padding:0 12px}
.topbar .search input{border:0;background:transparent;outline:none;width:100%;padding:9px 0;font-size:14px}
.topbar .actions{display:flex;align-items:center;gap:10px}
.icon-btn{position:relative;background:var(--bg);border:1px solid var(--borda);width:40px;height:40px;border-radius:10px;display:grid;place-items:center;cursor:pointer;color:var(--azul-900);font-size:16px;transition:background .15s;text-decoration:none}
.icon-btn:hover{background:var(--azul-50)}
.icon-btn .dot{position:absolute;top:7px;right:8px;width:9px;height:9px;border-radius:50%;background:var(--erro);border:2px solid #fff}

/* User menu no topbar (avatar + nome + dropdown) */
.user-menu{position:relative;margin-left:6px}
.user-trigger{display:flex;align-items:center;gap:10px;background:var(--bg);border:1px solid var(--borda);border-radius:999px;padding:5px 14px 5px 5px;cursor:pointer;transition:all .15s;font-family:inherit}
.user-trigger:hover{background:var(--azul-50);border-color:var(--azul-50)}
.user-menu.open .user-trigger{background:var(--azul-50);border-color:var(--azul);box-shadow:0 0 0 3px rgba(10,61,145,.08)}
.user-trigger .avatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--amarelo),var(--amarelo-600));color:var(--azul-900);display:grid;place-items:center;font-weight:800;font-size:12.5px;flex-shrink:0}
.user-trigger .meta{text-align:left;min-width:0}
.user-trigger .meta b{display:block;font-size:13px;color:var(--azul-900);font-weight:700;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:120px}
.user-trigger .meta small{font-size:10.5px;color:var(--muted);text-transform:uppercase;letter-spacing:.6px;font-weight:600}
.user-trigger .chev{font-size:11px;color:var(--muted);transition:transform .2s}
.user-menu.open .user-trigger .chev{transform:rotate(180deg);color:var(--azul)}

.user-drop{position:absolute;top:calc(100% + 8px);right:0;background:#fff;border:1px solid var(--borda);border-radius:14px;box-shadow:0 18px 50px rgba(10,61,145,.18);width:300px;max-width:calc(100vw - 30px);z-index:50;overflow:hidden;opacity:0;transform:translateY(-6px) scale(.98);transform-origin:top right;pointer-events:none;transition:opacity .18s,transform .18s}
.user-menu.open .user-drop{opacity:1;transform:translateY(0) scale(1);pointer-events:auto}
.user-drop-h{padding:18px 18px 14px;background:linear-gradient(135deg,var(--azul-900),var(--azul));color:#fff;display:flex;gap:12px;align-items:center}
.user-drop-h .avatar-lg{width:48px;height:48px;border-radius:50%;background:var(--amarelo);color:var(--azul-900);display:grid;place-items:center;font-weight:800;font-size:16px;flex-shrink:0;box-shadow:0 4px 14px rgba(255,193,7,.3)}
.user-drop-h b{display:block;font-size:14.5px;color:#fff;line-height:1.2}
.user-drop-h small{display:block;font-size:11.5px;color:rgba(255,255,255,.75);margin-top:2px;word-break:break-all}
.user-drop-h .papel-tag{display:inline-block;margin-top:6px;background:rgba(255,193,7,.2);color:var(--amarelo);border:1px solid rgba(255,193,7,.3);padding:2px 9px;border-radius:999px;font-size:10.5px;font-weight:700;letter-spacing:.5px;text-transform:uppercase}
.user-drop-info{padding:8px 18px;font-size:12.5px;color:var(--muted);background:var(--bg);border-bottom:1px solid var(--borda);display:flex;align-items:center;gap:8px}
.user-drop-info i{color:var(--azul)}
.user-drop-info:first-of-type{border-top:0}
.user-drop-item{display:flex;align-items:center;gap:11px;padding:11px 18px;color:var(--txt);text-decoration:none;font-size:13.5px;font-weight:500;transition:background .12s;border-top:1px solid var(--borda)}
.user-drop-item:first-child{border-top:0}
.user-drop-item:hover{background:var(--azul-50);color:var(--azul-900)}
.user-drop-item i{width:16px;text-align:center;color:var(--azul);font-size:13px}
.user-drop-item .badge-mini{margin-left:auto;background:var(--amarelo);color:var(--azul-900);font-size:10.5px;font-weight:800;padding:2px 7px;border-radius:999px}
.user-drop-item.logout{color:var(--erro);border-top:1px solid var(--borda);font-weight:600}
.user-drop-item.logout i{color:var(--erro)}
.user-drop-item.logout:hover{background:#fee2e2;color:#7f1d1d}

/* Mobile — esconde nome, mostra só avatar */
@media (max-width:560px){
  .user-trigger{padding:4px;border-radius:50%}
  .user-trigger .meta,.user-trigger .chev{display:none}
  .user-drop{width:280px}
}

.page{padding:28px}
.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:22px;flex-wrap:wrap}
.page-header h1{margin:0 0 4px;color:var(--azul-900);font-size:26px;font-weight:800}
.page-header p{margin:0;color:var(--muted);font-size:14px}
.page-header .actions{display:flex;gap:8px;flex-wrap:wrap}

/* KPI cards */
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-bottom:22px}
.kpi{background:#fff;border:1px solid var(--borda);border-radius:14px;padding:18px;box-shadow:var(--shadow);position:relative;overflow:hidden}
.kpi::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:linear-gradient(180deg,var(--azul),var(--amarelo))}
.kpi .lbl{display:flex;align-items:center;gap:8px;color:var(--muted);font-size:12.5px;text-transform:uppercase;letter-spacing:1px;font-weight:600}
.kpi .lbl .ico{width:30px;height:30px;border-radius:9px;background:var(--azul-50);color:var(--azul);display:grid;place-items:center;font-size:14px}
.kpi .val{font-size:30px;font-weight:800;color:var(--azul-900);margin:8px 0 4px}
.kpi .delta{font-size:12px;font-weight:700}
.kpi .delta.up{color:var(--ok)} .kpi .delta.down{color:var(--erro)}

/* Cards generic */
.panel{background:#fff;border:1px solid var(--borda);border-radius:14px;box-shadow:var(--shadow);padding:20px;margin-bottom:18px}
.panel-h{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;gap:10px;flex-wrap:wrap}
.panel-h h3{margin:0;color:var(--azul-900);font-size:17px;font-weight:700}
.panel-h .filter{display:flex;gap:6px;align-items:center}

.cols-2{display:grid;grid-template-columns:2fr 1fr;gap:18px}
.cols-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:18px}
.cols-eq-2{display:grid;grid-template-columns:1fr 1fr;gap:18px}

/* Tables */
.tbl{width:100%;border-collapse:collapse;font-size:14px}
.tbl th,.tbl td{padding:11px 12px;text-align:left;border-bottom:1px solid var(--borda)}
.tbl th{background:var(--bg);font-size:12px;text-transform:uppercase;letter-spacing:1px;color:var(--muted);font-weight:700}
.tbl tr:hover td{background:var(--azul-50)}
.tbl td .actions{display:flex;gap:6px}
.tbl-wrap{overflow-x:auto;border-radius:12px;border:1px solid var(--borda)}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:6px;padding:10px 16px;border-radius:10px;font-weight:600;border:0;cursor:pointer;font-size:14px;transition:transform .12s,background .15s,box-shadow .15s;font-family:inherit}
.btn:hover{transform:translateY(-1px)}
.btn-azul{background:var(--azul);color:#fff}
.btn-azul:hover{background:var(--azul-700)}
.btn-amarelo{background:var(--amarelo);color:var(--azul-900);box-shadow:0 4px 14px rgba(255,193,7,.35)}
.btn-amarelo:hover{background:var(--amarelo-600)}
.btn-outline{background:#fff;color:var(--azul);border:1px solid var(--azul-50)}
.btn-outline:hover{background:var(--azul-50)}
.btn-ghost{background:transparent;color:var(--azul)}
.btn-ghost:hover{background:var(--azul-50)}
.btn-danger{background:#fee2e2;color:var(--erro)}
.btn-danger:hover{background:#fecaca}
.btn-ok{background:#dcfce7;color:#14532d}
.btn-ok:hover{background:#bbf7d0}
.btn-sm{padding:6px 10px;font-size:12.5px;border-radius:8px}
.btn-icon{width:32px;height:32px;padding:0;justify-content:center;border-radius:8px}

/* Tags */
.tag{display:inline-block;padding:3px 10px;border-radius:999px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}
.tag-azul{background:var(--azul-50);color:var(--azul-900)}
.tag-amarelo{background:var(--amarelo-50);color:#7c5200}
.tag-ok{background:#dcfce7;color:#14532d}
.tag-erro{background:#fee2e2;color:#7f1d1d}
.tag-warn{background:#fef3c7;color:#78350f}
.tag-cinza{background:#eef2f7;color:#46556e}
.tag-info{background:#e0f2fe;color:#075985}

/* Modal */
.modal-bg{position:fixed;inset:0;background:rgba(6,42,102,.55);backdrop-filter:blur(4px);display:none;align-items:center;justify-content:center;z-index:100;padding:20px}
.modal-bg.open{display:flex}
.modal{background:#fff;border-radius:16px;width:100%;max-width:640px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 24px 70px rgba(0,0,0,.3);animation:popin .18s ease}
.modal.lg{max-width:900px}
@keyframes popin{from{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}
.modal-h{padding:18px 22px;border-bottom:1px solid var(--borda);display:flex;align-items:center;justify-content:space-between}
.modal-h h3{margin:0;color:var(--azul-900);font-size:18px}
.modal-h .close{background:none;border:0;font-size:22px;cursor:pointer;color:var(--muted);width:32px;height:32px;border-radius:8px}
.modal-h .close:hover{background:var(--bg);color:var(--erro)}
.modal-b{padding:22px;overflow-y:auto;flex:1}
.modal-f{padding:14px 22px;border-top:1px solid var(--borda);display:flex;justify-content:flex-end;gap:8px;background:var(--bg)}

/* Forms */
.field{margin-bottom:14px}
.field label{display:block;font-size:12.5px;font-weight:600;margin-bottom:6px;color:var(--azul-900)}
.field input,.field select,.field textarea{width:100%;padding:10px 12px;border:1px solid var(--borda);border-radius:9px;font-size:14px;font-family:inherit;background:#fff;outline:none;transition:border .15s,box-shadow .15s}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--azul);box-shadow:0 0 0 3px var(--azul-50)}
.field textarea{min-height:90px;resize:vertical}
.field .hint{font-size:11.5px;color:var(--muted);margin-top:4px}
.row-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}

/* Notifications dropdown */
.dropdown{position:absolute;top:calc(100% + 8px);right:0;background:#fff;border:1px solid var(--borda);border-radius:14px;box-shadow:0 18px 40px rgba(10,61,145,.15);width:360px;max-width:92vw;z-index:30;overflow:hidden;display:none}
.dropdown.open{display:block}
.dropdown .dh{padding:14px 16px;border-bottom:1px solid var(--borda);display:flex;justify-content:space-between;align-items:center}
.dropdown .dh b{color:var(--azul-900)}
.dropdown ul{list-style:none;margin:0;padding:6px;max-height:380px;overflow-y:auto}
.dropdown ul li{padding:10px 12px;border-radius:8px;cursor:pointer;display:flex;gap:10px}
.dropdown ul li:hover{background:var(--azul-50)}
.dropdown ul li .ico{width:34px;height:34px;border-radius:9px;background:var(--azul-50);color:var(--azul);display:grid;place-items:center;flex-shrink:0}
.dropdown ul li.unread{background:var(--amarelo-50)}
.dropdown ul li b{display:block;color:var(--azul-900);font-size:13.5px;margin-bottom:2px}
.dropdown ul li small{color:var(--muted);font-size:12px}

/* Toast */
.toasts{position:fixed;top:20px;right:20px;display:flex;flex-direction:column;gap:10px;z-index:1000}
.toast{background:#fff;border-left:4px solid var(--azul);border-radius:10px;padding:12px 16px;box-shadow:0 12px 30px rgba(0,0,0,.18);min-width:260px;max-width:380px;animation:slidein .25s ease;display:flex;gap:10px}
.toast.ok{border-color:var(--ok)} .toast.erro{border-color:var(--erro)} .toast.warn{border-color:var(--warn)}
.toast b{display:block;color:var(--azul-900);font-size:13.5px}
.toast small{color:var(--muted);font-size:12.5px}
@keyframes slidein{from{transform:translateX(20px);opacity:0}to{transform:translateX(0);opacity:1}}

/* Fluxograma */
.flow{display:flex;align-items:center;gap:0;flex-wrap:wrap}
.flow .node{flex:1;min-width:140px;background:#fff;border:2px solid var(--borda);border-radius:12px;padding:14px;text-align:center;position:relative;transition:all .2s}
.flow .node.done{border-color:var(--ok);background:#f0fdf4}
.flow .node.current{border-color:var(--amarelo);background:var(--amarelo-50);box-shadow:0 0 0 4px rgba(255,193,7,.2)}
.flow .node.pending{opacity:.6}
.flow .node b{display:block;color:var(--azul-900);font-size:13px;margin-bottom:4px}
.flow .node small{color:var(--muted);font-size:11.5px}
.flow .arrow{flex:0 0 24px;text-align:center;color:var(--muted);font-size:18px}

/* Kanban */
.kanban{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.kanban .col{background:var(--bg);border:1px solid var(--borda);border-radius:12px;padding:14px;min-height:300px}
.kanban .col h5{margin:0 0 12px;color:var(--azul-900);font-size:13.5px;display:flex;justify-content:space-between;align-items:center}
.kanban .col h5 .count{background:var(--azul);color:#fff;font-size:11px;padding:2px 8px;border-radius:10px}
.kanban .card-task{background:#fff;border-radius:10px;padding:12px;margin-bottom:10px;border:1px solid var(--borda);box-shadow:0 2px 6px rgba(10,61,145,.04);cursor:grab}
.kanban .card-task b{display:block;color:var(--azul-900);font-size:13.5px;margin-bottom:4px}
.kanban .card-task .meta{display:flex;justify-content:space-between;align-items:center;margin-top:8px;font-size:11.5px;color:var(--muted)}

/* Calendar */
.calendar{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}
.calendar .day{background:#fff;border:1px solid var(--borda);border-radius:8px;padding:8px;min-height:74px;font-size:12px;position:relative}
.calendar .day.head{background:var(--azul);color:#fff;text-align:center;font-weight:700;min-height:auto;padding:8px}
.calendar .day .num{font-weight:700;color:var(--azul-900)}
.calendar .day.other{opacity:.4}
.calendar .day.today{border-color:var(--amarelo);box-shadow:0 0 0 3px var(--amarelo-50)}
.calendar .day .ev{background:var(--amarelo-50);color:#7c5200;border-radius:6px;padding:2px 6px;margin-top:4px;font-size:10.5px;font-weight:600;cursor:pointer}

/* Reports */
.rep-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.rep-card{background:#fff;border:1px solid var(--borda);border-radius:12px;padding:18px;display:flex;gap:14px;align-items:flex-start;cursor:pointer;transition:all .15s}
.rep-card:hover{border-color:var(--azul);box-shadow:var(--shadow)}
.rep-card .ico{width:46px;height:46px;border-radius:11px;background:linear-gradient(135deg,var(--azul),var(--azul-700));color:var(--amarelo);display:grid;place-items:center;font-size:18px}
.rep-card b{display:block;color:var(--azul-900);font-size:14.5px;margin-bottom:4px}
.rep-card small{color:var(--muted);font-size:12.5px}

/* Signature */
.assin-canvas{border:2px dashed var(--azul-50);border-radius:10px;background:#fcfdff;height:160px;display:grid;place-items:center;color:var(--muted);cursor:crosshair}
.assin-canvas.signed{border-style:solid;border-color:var(--ok);background:#f0fdf4;color:var(--ok);font-weight:700}

/* Vote */
.vote-card{background:#fff;border:2px solid var(--borda);border-radius:14px;padding:18px;cursor:pointer;transition:all .15s}
.vote-card:hover{border-color:var(--azul)}
.vote-card.selected{border-color:var(--amarelo);background:var(--amarelo-50)}

/* Avatars list */
.avatars{display:flex}
.avatars .av{width:28px;height:28px;border-radius:50%;background:var(--azul);color:#fff;display:grid;place-items:center;font-size:11px;font-weight:700;border:2px solid #fff;margin-left:-8px}
.avatars .av:first-child{margin-left:0}

/* Empty state */
.empty{text-align:center;padding:48px 20px;color:var(--muted)}
.empty .ico{font-size:46px;color:var(--azul-50);margin-bottom:10px}
.empty p{margin:6px 0}

/* Login */
.login-bg{min-height:100vh;display:grid;grid-template-columns:1fr 1fr;background:#fff}
.login-bg .left{background:linear-gradient(135deg,var(--azul-900),var(--azul));color:#fff;padding:50px;display:flex;flex-direction:column;justify-content:space-between;position:relative;overflow:hidden}
.login-bg .left::before{content:"";position:absolute;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(255,193,7,.18),transparent 60%);top:-100px;right:-100px}
.login-bg .left .brand{display:flex;align-items:center;gap:14px;color:#fff;font-weight:800;font-size:22px;position:relative;z-index:1}
.login-bg .left .brand .logo{width:50px;height:50px;border-radius:14px;background:var(--amarelo);color:var(--azul-900);display:grid;place-items:center;font-weight:900;font-size:20px}
.login-bg .left .brand .name span{color:var(--amarelo)}
.login-bg .left .center{position:relative;z-index:1}
.login-bg .left .center h1{font-size:38px;margin:0 0 12px;line-height:1.1}
.login-bg .left .center h1 span{color:var(--amarelo)}
.login-bg .left .center p{opacity:.85;font-size:15px;max-width:380px;line-height:1.6}
.login-bg .left .foot{position:relative;z-index:1;font-size:13px;opacity:.7}
.login-bg .right{display:grid;place-items:center;padding:40px}
.login-form{width:100%;max-width:380px}
.login-form h2{margin:0 0 6px;color:var(--azul-900);font-size:24px}
.login-form p.sub{color:var(--muted);margin:0 0 24px;font-size:14px}
.login-form .roles{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:8px}
.login-form .role-pill{padding:10px 12px;border:1px solid var(--borda);border-radius:9px;text-align:center;font-size:13px;cursor:pointer;background:#fff}
.login-form .role-pill:hover{border-color:var(--azul);color:var(--azul)}

/* Mobile */
@media (max-width:1024px){
  .kpis{grid-template-columns:repeat(2,1fr)}
  .cols-2,.cols-3,.cols-eq-2{grid-template-columns:1fr}
  .kanban{grid-template-columns:repeat(2,1fr)}
  .rep-cards{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:768px){
  /* sidebar mobile já tratado mais abaixo (drawer) */
  .topbar .menu-btn{display:grid}
  .topbar .search{display:none}
  .login-bg{grid-template-columns:1fr}
  .login-bg .left{padding:30px;min-height:auto}
  .login-bg .left .center h1{font-size:28px}
  .kanban{grid-template-columns:1fr}
  .rep-cards{grid-template-columns:1fr}
  .calendar{font-size:10px}
  .row-2,.row-3{grid-template-columns:1fr}
  .page{padding:18px}
}
.backdrop{position:fixed;inset:0;background:rgba(0,0,0,.4);display:none;z-index:150}
.backdrop.open{display:block}

/* ===============================================================
   RESPONSIVIDADE COMPLETA — DASHBOARD
   =============================================================== */

/* Tablet médio (≤1100px) */
@media (max-width:1100px){
  :root{--sidebar-w:240px}
  .page-header h1{font-size:24px}
  .kpi .val{font-size:26px}
}

/* Tablet (≤900px) — KPIs e fluxo viram coluna */
@media (max-width:900px){
  .flow{flex-direction:column;align-items:stretch}
  .flow .node{min-width:auto;width:100%}
  .flow .arrow{transform:rotate(90deg);padding:4px 0}
}

/* Mobile (≤768px) — drawer */
@media (max-width:768px){
  .sidebar{width:280px;left:-300px;transition:left .25s}
  .sidebar.open{left:0}
  .main{margin-left:0}
  .topbar{padding:12px 16px;gap:10px}
  .topbar .crumb{font-size:13px}
  .topbar .crumb i{display:none}
  .icon-btn{width:38px;height:38px;font-size:14px}
  .page{padding:18px 16px}
  .page-header{flex-direction:column;align-items:stretch;gap:12px;margin-bottom:18px}
  .page-header h1{font-size:22px}
  .page-header p{font-size:13px}
  .page-header .actions{flex-wrap:wrap;gap:6px}
  .page-header .actions .btn{flex:1;min-width:fit-content;justify-content:center}
}

/* Mobile pequeno (≤560px) */
@media (max-width:560px){
  .kpis{grid-template-columns:1fr 1fr!important;gap:10px;margin-bottom:14px}
  .kpi{padding:14px}
  .kpi .val{font-size:22px}
  .kpi .lbl{font-size:11px}
  .kpi .lbl .ico{width:26px;height:26px;font-size:12px}
  .panel{padding:16px;margin-bottom:14px}
  .panel-h h3{font-size:15px}
  /* Tabelas com scroll lateral */
  .tbl-wrap{margin:0 -16px;border-radius:0;border-left:0;border-right:0}
  .tbl{font-size:12.5px;min-width:560px}
  .tbl th,.tbl td{padding:9px 10px}
  /* Botões */
  .btn{padding:9px 14px;font-size:13.5px}
  .btn-sm{padding:6px 10px;font-size:12px}
  /* Calendário compacto */
  .calendar{gap:3px;font-size:11px}
  .calendar .day{padding:4px;min-height:54px}
  .calendar .day .ev{font-size:9.5px;padding:1px 4px}
  /* Modal full-width */
  .modal{max-width:100%;margin:8px;max-height:calc(100vh - 16px)}
  .modal-h,.modal-b{padding:16px 18px}
  .modal-h h3{font-size:16px}
  .modal-f{padding:12px 18px;flex-wrap:wrap}
  .modal-f .btn{flex:1;justify-content:center;min-width:fit-content}
  /* Login responsivo */
  .login-bg .left{padding:28px}
  .login-bg .left .center h1{font-size:24px}
  .login-bg .left .center p{font-size:14px}
  .login-bg .right{padding:24px 18px}
  .login-form h2{font-size:20px}
  .login-form .roles{grid-template-columns:1fr}
  /* Forms — fonte 16px evita zoom iOS */
  .field input,.field select,.field textarea{font-size:16px}
  .field label{font-size:12px}
  /* Notificações dropdown */
  .dropdown{width:calc(100vw - 28px);right:-8px;max-width:none}
  /* Toasts */
  .toasts{left:14px;right:14px;top:14px}
  .toast{min-width:0;max-width:none}
  /* Empty state */
  .empty{padding:32px 16px}
  .empty .ico{font-size:38px}
  /* Kanban totalmente coluna */
  .kanban .col{min-height:auto}
}

/* Mobile muito pequeno (≤380px) */
@media (max-width:380px){
  .kpis{grid-template-columns:1fr!important}
  .page-header h1{font-size:19px}
  .topbar .crumb b{display:inline-block;max-width:140px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;vertical-align:bottom}
  .btn{padding:9px 12px;font-size:13px}
  .tag{font-size:10px;padding:2px 8px}
}

/* Print otimizado (relatórios/atas) */
@media print{
  .sidebar,.topbar,.toasts,.modal-bg,.page-header .actions{display:none!important}
  .app{grid-template-columns:1fr}
  .page{padding:0}
  .panel{box-shadow:none;border:1px solid #ccc;page-break-inside:avoid}
}

/* Suporte a notch (iPhone X+) */
@supports(padding:max(0px)){
  .topbar{padding-left:max(16px,env(safe-area-inset-left));padding-right:max(16px,env(safe-area-inset-right))}
  .page{padding-left:max(16px,env(safe-area-inset-left));padding-right:max(16px,env(safe-area-inset-right))}
}

/* Prevenir overflow horizontal */
html,body{overflow-x:hidden;max-width:100vw}
.main{min-width:0;overflow-x:hidden}
img,video,iframe{max-width:100%;height:auto}

/* ===========================================
   DASHBOARD ADMIN — componentes refinados
   =========================================== */

/* Boas-vindas de admin (banner topo) */
.admin-hero{background:linear-gradient(135deg,var(--azul-900),var(--azul));color:#fff;border-radius:18px;padding:26px 28px;margin-bottom:22px;position:relative;overflow:hidden;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:18px}
.admin-hero::before{content:"";position:absolute;width:280px;height:280px;border-radius:50%;background:radial-gradient(circle,rgba(255,193,7,.18),transparent 70%);top:-100px;right:-60px;pointer-events:none}
.admin-hero::after{content:"";position:absolute;width:160px;height:160px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.06),transparent 70%);bottom:-60px;left:30%;pointer-events:none}
.admin-hero .info{position:relative;z-index:1}
.admin-hero .badge-admin{display:inline-block;padding:5px 12px;background:rgba(255,193,7,.2);color:var(--amarelo);border-radius:999px;font-size:11px;font-weight:700;letter-spacing:1px;border:1px solid rgba(255,193,7,.3);margin-bottom:8px}
.admin-hero h1{margin:0 0 4px;font-size:24px;color:#fff}
.admin-hero p{margin:0;opacity:.85;font-size:14px}
.admin-hero .quick-time{position:relative;z-index:1;text-align:right;font-size:13px}
.admin-hero .quick-time .hora{font-size:32px;font-weight:800;color:var(--amarelo);line-height:1}
.admin-hero .quick-time small{opacity:.8;display:block;margin-top:4px;letter-spacing:1px;text-transform:uppercase;font-size:11px}

/* KPI admin com cores */
.kpi.kpi-admin{border-left-width:0;padding:16px 18px}
.kpi.kpi-admin::before{display:none}
.kpi.kpi-admin .top{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}
.kpi.kpi-admin .top .ico-bg{width:42px;height:42px;border-radius:11px;display:grid;place-items:center;font-size:17px;color:#fff}
.kpi.kpi-admin .top .change{font-size:11px;font-weight:700;padding:3px 8px;border-radius:999px;background:#dcfce7;color:#14532d}
.kpi.kpi-admin .top .change.warn{background:#fef3c7;color:#78350f}
.kpi.kpi-admin .top .change.erro{background:#fee2e2;color:#7f1d1d}
.kpi.kpi-admin .nome{font-size:13px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:1px;margin-bottom:6px}
.kpi.kpi-admin .num{font-size:28px;font-weight:800;color:var(--azul-900);line-height:1}
.kpi.kpi-admin .sub{font-size:12px;color:var(--muted);margin-top:6px}
.kpi.kpi-admin.k-azul .ico-bg{background:linear-gradient(135deg,#0A3D91,#0B47AD)}
.kpi.kpi-admin.k-amarelo .ico-bg{background:linear-gradient(135deg,#FFC107,#E0A800);color:var(--azul-900)}
.kpi.kpi-admin.k-verde .ico-bg{background:linear-gradient(135deg,#16a34a,#15803d)}
.kpi.kpi-admin.k-laranja .ico-bg{background:linear-gradient(135deg,#ea580c,#c2410c)}
.kpi.kpi-admin.k-roxo .ico-bg{background:linear-gradient(135deg,#9333ea,#7e22ce)}
.kpi.kpi-admin.k-vermelho .ico-bg{background:linear-gradient(135deg,#dc2626,#b91c1c)}

/* Atalhos rápidos (action tiles) */
.quick-actions{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:22px}
@media (max-width:900px){.quick-actions{grid-template-columns:repeat(2,1fr)}}
@media (max-width:480px){.quick-actions{grid-template-columns:1fr}}
.qa-card{background:#fff;border-radius:14px;padding:18px;border:1px solid var(--borda);text-decoration:none;color:inherit;transition:all .2s;display:flex;align-items:center;gap:14px;position:relative;overflow:hidden}
.qa-card:hover{transform:translateY(-3px);box-shadow:0 12px 28px rgba(10,61,145,.12);border-color:var(--azul-50)}
.qa-card::after{content:"\f061";font-family:"Font Awesome 6 Free";font-weight:900;position:absolute;right:14px;top:50%;transform:translateY(-50%);color:var(--borda);font-size:14px;transition:all .2s}
.qa-card:hover::after{color:var(--azul);right:10px}
.qa-card .qa-ico{width:48px;height:48px;border-radius:12px;display:grid;place-items:center;font-size:20px;color:#fff;flex-shrink:0}
.qa-card .qa-info{flex:1;min-width:0}
.qa-card .qa-info b{display:block;color:var(--azul-900);font-size:14.5px;margin-bottom:2px}
.qa-card .qa-info small{color:var(--muted);font-size:12.5px}

/* Status do sistema */
.system-status{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:6px}
@media (max-width:600px){.system-status{grid-template-columns:1fr}}
.status-row{display:flex;align-items:center;gap:12px;padding:11px 14px;background:var(--bg);border-radius:10px;border:1px solid var(--borda)}
.status-row .stat-ico{width:36px;height:36px;border-radius:9px;display:grid;place-items:center;font-size:14px;flex-shrink:0}
.status-row .stat-ico.ok{background:#dcfce7;color:#14532d}
.status-row .stat-ico.warn{background:#fef3c7;color:#78350f}
.status-row .stat-ico.erro{background:#fee2e2;color:#7f1d1d}
.status-row .stat-ico.info{background:var(--azul-50);color:var(--azul)}
.status-row .stat-info{flex:1;min-width:0}
.status-row .stat-info b{display:block;color:var(--azul-900);font-size:13px;font-weight:700}
.status-row .stat-info small{color:var(--muted);font-size:11.5px;display:block}
.status-row .stat-val{font-size:12px;font-weight:700;padding:3px 9px;border-radius:999px;flex-shrink:0}
.status-row .stat-val.ok{background:#dcfce7;color:#14532d}
.status-row .stat-val.warn{background:#fef3c7;color:#78350f}
.status-row .stat-val.erro{background:#fee2e2;color:#7f1d1d}
.status-row .stat-val.info{background:var(--azul-50);color:var(--azul)}

/* Pendências admin (resumo de aprovações) */
.pendencias-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
@media (max-width:760px){.pendencias-grid{grid-template-columns:1fr}}
.pend-card{background:#fff;border:1px solid var(--borda);border-left:4px solid var(--amarelo);border-radius:12px;padding:14px 16px;display:flex;align-items:center;gap:14px;transition:all .15s}
.pend-card:hover{box-shadow:var(--shadow);border-left-color:var(--azul)}
.pend-card .pn{width:42px;height:42px;border-radius:11px;background:var(--amarelo-50);color:#7c5200;display:grid;place-items:center;font-size:18px;flex-shrink:0}
.pend-card .pi{flex:1;min-width:0}
.pend-card .pi b{display:block;font-size:18px;color:var(--azul-900);font-weight:800;line-height:1}
.pend-card .pi small{color:var(--muted);font-size:12px;display:block;margin-top:2px}
.pend-card a{font-size:11.5px;color:var(--azul);font-weight:700;text-decoration:none}
.pend-card a:hover{text-decoration:underline}

/* ===========================================
   DASHBOARD COORD. CAMPUS — minimalista
   =========================================== */
.cc-hero{padding:32px 0 24px;border-bottom:1px solid var(--borda);margin-bottom:28px}
.cc-hero h1{margin:0 0 6px;font-size:30px;font-weight:300;color:var(--azul-900);letter-spacing:-.5px}
.cc-hero h1 b{font-weight:800}
.cc-hero p{margin:0;color:var(--muted);font-size:15px;display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.cc-hero p .pill{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;background:var(--azul-50);color:var(--azul);border-radius:999px;font-size:12.5px;font-weight:600}
.cc-hero p .pill i{font-size:11px}

/* Card destaque (foco principal) */
.cc-foco{background:#fff;border:1px solid var(--borda);border-radius:18px;padding:26px 28px;margin-bottom:24px;display:flex;align-items:center;gap:24px;position:relative;overflow:hidden}
.cc-foco.alerta{border-left:4px solid var(--amarelo);background:linear-gradient(90deg,#fffbeb,#fff 30%)}
.cc-foco.calmo{border-left:4px solid var(--ok);background:linear-gradient(90deg,#f0fdf4,#fff 30%)}
.cc-foco .num-grande{font-size:64px;font-weight:200;color:var(--azul-900);line-height:1;letter-spacing:-2px;flex-shrink:0}
.cc-foco.calmo .num-grande{color:var(--ok)}
.cc-foco .info{flex:1;min-width:0}
.cc-foco .info h2{margin:0 0 4px;font-size:18px;color:var(--azul-900);font-weight:700}
.cc-foco .info p{margin:0;color:var(--muted);font-size:14px;line-height:1.5}
.cc-foco .acao{flex-shrink:0}

/* KPIs minimalistas */
.cc-kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}
@media (max-width:900px){.cc-kpis{grid-template-columns:repeat(2,1fr)}}
@media (max-width:480px){.cc-kpis{grid-template-columns:1fr}}
.cc-kpi{background:#fff;border:1px solid var(--borda);border-radius:14px;padding:20px;transition:all .15s}
.cc-kpi:hover{border-color:var(--azul-50);transform:translateY(-2px)}
.cc-kpi .lbl-min{font-size:11.5px;color:var(--muted);text-transform:uppercase;letter-spacing:1.2px;font-weight:600;display:flex;align-items:center;gap:6px;margin-bottom:10px}
.cc-kpi .lbl-min i{color:var(--azul);font-size:11px}
.cc-kpi .val-min{font-size:32px;color:var(--azul-900);font-weight:800;line-height:1;margin-bottom:4px}
.cc-kpi .sub-min{font-size:12px;color:var(--muted);margin-top:8px}
.cc-kpi .sub-min b{color:var(--ok);font-weight:700}

/* Painel minimalista */
.cc-panel{background:#fff;border:1px solid var(--borda);border-radius:14px;margin-bottom:18px;overflow:hidden}
.cc-panel-h{padding:18px 22px;border-bottom:1px solid var(--borda);display:flex;align-items:center;justify-content:space-between}
.cc-panel-h h3{margin:0;font-size:15px;color:var(--azul-900);font-weight:700;display:flex;align-items:center;gap:10px}
.cc-panel-h h3 i{color:var(--azul);font-size:13px}
.cc-panel-h a{font-size:12.5px;color:var(--muted);text-decoration:none;font-weight:600;transition:color .15s}
.cc-panel-h a:hover{color:var(--azul)}
.cc-panel-body{padding:8px 22px}
.cc-panel-body.no-pad{padding:0}

/* Lista de aprovações pendentes */
.cc-aprov-list{list-style:none;margin:0;padding:0}
.cc-aprov-item{display:flex;align-items:center;gap:14px;padding:14px 22px;border-bottom:1px solid var(--borda);transition:background .12s;text-decoration:none;color:inherit}
.cc-aprov-item:last-child{border-bottom:0}
.cc-aprov-item:hover{background:var(--bg)}
.cc-aprov-item .tipo-min{width:36px;height:36px;border-radius:10px;display:grid;place-items:center;font-size:15px;flex-shrink:0}
.cc-aprov-item .tipo-min.proj{background:var(--azul-50);color:var(--azul)}
.cc-aprov-item .tipo-min.art{background:var(--amarelo-50);color:#7c5200}
.cc-aprov-item .tipo-min.cand{background:#dcfce7;color:#14532d}
.cc-aprov-item .info-aprov{flex:1;min-width:0}
.cc-aprov-item .info-aprov b{display:block;color:var(--azul-900);font-size:14px;font-weight:600;line-height:1.3;margin-bottom:2px}
.cc-aprov-item .info-aprov small{color:var(--muted);font-size:12px}
.cc-aprov-item .seta{color:var(--muted);font-size:14px;transition:all .15s}
.cc-aprov-item:hover .seta{color:var(--azul);transform:translateX(3px)}

/* Atalhos minimalistas */
.cc-atalhos{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:24px}
@media (max-width:900px){.cc-atalhos{grid-template-columns:repeat(2,1fr)}}
.cc-atalho{background:#fff;border:1px solid var(--borda);border-radius:12px;padding:16px;text-decoration:none;color:inherit;transition:all .15s;display:flex;align-items:center;gap:12px}
.cc-atalho:hover{border-color:var(--azul);transform:translateY(-2px);box-shadow:0 6px 18px rgba(10,61,145,.08)}
.cc-atalho i{width:32px;height:32px;border-radius:8px;background:var(--azul-50);color:var(--azul);display:grid;place-items:center;font-size:13px;flex-shrink:0}
.cc-atalho span{font-size:13.5px;color:var(--azul-900);font-weight:600}

/* Membros do campus (lista compacta) */
.cc-membros{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:8px;padding:14px 22px}
.cc-membro{display:flex;align-items:center;gap:10px;padding:8px;border-radius:8px;transition:background .12s}
.cc-membro:hover{background:var(--bg)}
.cc-membro .av-min{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--azul),var(--azul-700));color:var(--amarelo);display:grid;place-items:center;font-weight:700;font-size:11.5px;flex-shrink:0}
.cc-membro .nm{flex:1;min-width:0}
.cc-membro .nm b{display:block;font-size:13px;color:var(--azul-900);font-weight:600;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cc-membro .nm small{color:var(--muted);font-size:11px}

/* Eventos compactos do campus */
.cc-eventos{padding:8px 22px}
.cc-evento-row{display:flex;align-items:center;gap:14px;padding:11px 0;border-bottom:1px solid var(--borda)}
.cc-evento-row:last-child{border-bottom:0}
.cc-evento-row .data-min{text-align:center;flex-shrink:0;background:var(--azul-50);border-radius:8px;padding:6px 10px;min-width:50px}
.cc-evento-row .data-min b{display:block;font-size:18px;color:var(--azul-900);font-weight:800;line-height:1}
.cc-evento-row .data-min small{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}
.cc-evento-row .info-ev{flex:1;min-width:0}
.cc-evento-row .info-ev b{display:block;color:var(--azul-900);font-size:13.5px;font-weight:600}
.cc-evento-row .info-ev small{color:var(--muted);font-size:11.5px}

/* Empty state minimalista */
.cc-empty{text-align:center;padding:36px 20px;color:var(--muted)}
.cc-empty i{font-size:32px;color:var(--ok);margin-bottom:8px;opacity:.6}
.cc-empty b{display:block;color:var(--azul-900);font-size:14px;margin-bottom:2px;font-weight:600}
.cc-empty small{font-size:12.5px}

/* ===========================================
   PÁGINA MEU PERFIL
   =========================================== */
.perfil-header{background:linear-gradient(135deg,var(--azul-900),var(--azul) 60%,var(--azul-700));color:#fff;border-radius:18px;padding:28px;margin-bottom:18px;display:flex;gap:24px;align-items:center;position:relative;overflow:hidden}
.perfil-header::before{content:"";position:absolute;width:340px;height:340px;border-radius:50%;background:radial-gradient(circle,rgba(255,193,7,.18),transparent 70%);top:-120px;right:-80px;pointer-events:none}
.perfil-avatar{width:96px;height:96px;border-radius:50%;background:linear-gradient(135deg,var(--amarelo),var(--amarelo-600));color:var(--azul-900);display:grid;place-items:center;font-weight:900;font-size:32px;flex-shrink:0;box-shadow:0 10px 30px rgba(255,193,7,.4);border:4px solid rgba(255,255,255,.15);position:relative;z-index:1}
.perfil-info{flex:1;min-width:0;position:relative;z-index:1}
.perfil-info h2{margin:0 0 8px;font-size:26px;color:#fff;font-weight:800}
.perfil-meta{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px}
.papel-tag-grande{display:inline-flex;align-items:center;gap:6px;background:rgba(255,193,7,.2);color:var(--amarelo);border:1px solid rgba(255,193,7,.35);padding:5px 12px;border-radius:999px;font-size:12px;font-weight:700;letter-spacing:.5px;text-transform:uppercase}
.perfil-meta .meta-item{background:rgba(255,255,255,.1);color:rgba(255,255,255,.95);padding:5px 12px;border-radius:999px;font-size:12.5px;display:inline-flex;align-items:center;gap:6px}
.perfil-meta .meta-item i{opacity:.8;font-size:11px}
.perfil-data{display:flex;flex-wrap:wrap;gap:18px;font-size:13px;opacity:.92}
.perfil-data span{display:flex;align-items:center;gap:6px}
.perfil-data i{opacity:.7;font-size:12px}
.perfil-data code{background:var(--amarelo);color:var(--azul-900);padding:2px 8px;border-radius:5px;font-family:Monaco,monospace;font-size:11.5px;font-weight:700}

/* Stats pessoais */
.perfil-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:18px}
@media (max-width:760px){.perfil-stats{grid-template-columns:1fr}}
.ps-card{background:#fff;border:1px solid var(--borda);border-radius:14px;padding:18px;display:flex;align-items:center;gap:14px;transition:all .2s;position:relative}
.ps-card:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--azul-50)}
.ps-card .ps-ico{width:50px;height:50px;border-radius:13px;display:grid;place-items:center;font-size:20px;color:#fff;flex-shrink:0}
.ps-card>div:nth-child(2){flex:1;min-width:0}
.ps-card b{display:block;font-size:24px;font-weight:800;color:var(--azul-900);line-height:1}
.ps-card small{color:var(--muted);font-size:12.5px;font-weight:600}
.ps-card .ps-sub{font-size:11px;color:var(--ok);font-weight:700;background:#dcfce7;padding:3px 9px;border-radius:999px;text-transform:uppercase;letter-spacing:.5px}

/* Conta info — lista vertical */
.conta-info{margin-top:6px}
.ci-row{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--borda);font-size:13px}
.ci-row:last-child{border-bottom:0}
.ci-label{color:var(--muted);font-weight:500;display:flex;align-items:center;gap:8px}
.ci-label i{color:var(--azul);font-size:12px;width:14px;text-align:center}
.ci-val{color:var(--azul-900);font-weight:700}

/* Mobile do perfil */
@media (max-width:600px){
  .perfil-header{flex-direction:column;text-align:center;padding:24px 18px;gap:14px}
  .perfil-info h2{font-size:22px}
  .perfil-meta,.perfil-data{justify-content:center}
  .perfil-data{font-size:12px;gap:12px}
  .perfil-avatar{width:80px;height:80px;font-size:26px}
}

/* ===========================================
   DASHBOARD COORD. GERAL — minimalista & avançado
   =========================================== */

/* Cabeçalho elegante */
.cg-hero{display:flex;justify-content:space-between;align-items:flex-end;padding:24px 0 24px;border-bottom:1px solid var(--borda);margin-bottom:28px;flex-wrap:wrap;gap:16px}
.cg-hero .heading h1{margin:0 0 6px;font-size:30px;font-weight:300;color:var(--azul-900);letter-spacing:-.5px}
.cg-hero .heading h1 b{font-weight:800}
.cg-hero .heading p{margin:0;color:var(--muted);font-size:13.5px;display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.cg-hero .heading p .dot-sep::before{content:"•";margin-right:14px;color:var(--borda)}
.cg-hero .health-score{text-align:right;display:flex;flex-direction:column;align-items:flex-end;gap:4px}
.cg-hero .health-score .score{display:flex;align-items:baseline;gap:4px;color:var(--ok);font-weight:800}
.cg-hero .health-score .score b{font-size:32px;font-feature-settings:"tnum"}
.cg-hero .health-score .score span{font-size:13px;color:var(--muted);font-weight:600}
.cg-hero .health-score small{color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:1px;font-weight:600}

/* Tira de KPIs minimalistas */
.cg-kpis-strip{display:grid;grid-template-columns:repeat(5,1fr);gap:0;background:#fff;border:1px solid var(--borda);border-radius:14px;overflow:hidden;margin-bottom:24px}
@media (max-width:900px){.cg-kpis-strip{grid-template-columns:repeat(2,1fr)}}
@media (max-width:480px){.cg-kpis-strip{grid-template-columns:1fr}}
.cg-kpi-cell{padding:18px 22px;border-right:1px solid var(--borda);position:relative}
.cg-kpi-cell:last-child{border-right:0}
@media (max-width:900px){.cg-kpi-cell{border-right:0;border-bottom:1px solid var(--borda)}}
.cg-kpi-cell .lbl{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:1.2px;font-weight:600;margin-bottom:8px;display:flex;align-items:center;gap:6px}
.cg-kpi-cell .lbl i{font-size:10px;color:var(--azul);opacity:.7}
.cg-kpi-cell .val{font-size:28px;color:var(--azul-900);font-weight:800;line-height:1;font-feature-settings:"tnum"}
.cg-kpi-cell .trend{font-size:11.5px;margin-top:6px;font-weight:600;display:flex;align-items:center;gap:4px}
.cg-kpi-cell .trend.up{color:var(--ok)}
.cg-kpi-cell .trend.down{color:var(--erro)}
.cg-kpi-cell .trend.neutral{color:var(--muted)}
.cg-kpi-cell .alert{position:absolute;top:14px;right:14px;width:8px;height:8px;border-radius:50%;background:var(--erro);box-shadow:0 0 0 0 rgba(220,38,38,.5);animation:dotPulse 2s infinite}
@keyframes dotPulse{0%{box-shadow:0 0 0 0 rgba(220,38,38,.5)}70%{box-shadow:0 0 0 8px rgba(220,38,38,0)}100%{box-shadow:0 0 0 0 rgba(220,38,38,0)}}

/* Card de foco (alerta principal) */
.cg-foco{background:#fff;border:1px solid var(--borda);border-radius:14px;padding:20px 24px;margin-bottom:24px;display:flex;align-items:center;gap:18px}
.cg-foco.alerta{border-left:3px solid var(--amarelo);background:linear-gradient(90deg,rgba(255,247,220,.5),#fff 50%)}
.cg-foco.calmo{border-left:3px solid var(--ok);background:linear-gradient(90deg,rgba(220,252,231,.4),#fff 50%)}
.cg-foco .indi{font-size:42px;font-weight:200;color:var(--azul-900);line-height:1;letter-spacing:-2px;flex-shrink:0;min-width:60px;text-align:center}
.cg-foco .info{flex:1;min-width:0}
.cg-foco .info b{display:block;color:var(--azul-900);font-size:15px;font-weight:700;margin-bottom:2px}
.cg-foco .info span{color:var(--muted);font-size:13px}
.cg-foco .actions{display:flex;gap:8px;flex-wrap:wrap}

/* Grid layout 2/3 + 1/3 */
.cg-grid{display:grid;grid-template-columns:2fr 1fr;gap:18px;margin-bottom:18px}
@media (max-width:1024px){.cg-grid{grid-template-columns:1fr}}

/* Painel minimalista */
.cg-panel{background:#fff;border:1px solid var(--borda);border-radius:14px;overflow:hidden}
.cg-panel-h{padding:16px 22px;border-bottom:1px solid var(--borda);display:flex;align-items:center;justify-content:space-between}
.cg-panel-h h3{margin:0;font-size:14px;color:var(--azul-900);font-weight:700;display:flex;align-items:center;gap:8px;text-transform:uppercase;letter-spacing:.6px}
.cg-panel-h h3 i{color:var(--azul);font-size:11px}
.cg-panel-h a, .cg-panel-h .pill-h{font-size:11.5px;color:var(--muted);text-decoration:none;font-weight:600;text-transform:uppercase;letter-spacing:.5px}
.cg-panel-h a:hover{color:var(--azul)}
.cg-panel-h .pill-h{background:var(--azul-50);color:var(--azul);padding:3px 10px;border-radius:999px;text-transform:none;letter-spacing:0}

/* Tabela de campi avançada (com mini-charts) */
.cg-table{width:100%;border-collapse:collapse;font-size:13.5px}
.cg-table th{font-size:10.5px;color:var(--muted);text-transform:uppercase;letter-spacing:1px;font-weight:600;text-align:left;padding:12px 22px;background:var(--bg);border-bottom:1px solid var(--borda)}
.cg-table td{padding:14px 22px;border-bottom:1px solid var(--borda);vertical-align:middle}
.cg-table tr:last-child td{border-bottom:0}
.cg-table tr:hover td{background:var(--bg)}
.cg-table .campus-cell{display:flex;align-items:center;gap:10px}
.cg-table .campus-cell .ico{width:32px;height:32px;border-radius:9px;background:var(--azul-50);color:var(--azul);display:grid;place-items:center;font-size:13px;flex-shrink:0}
.cg-table .campus-cell b{display:block;color:var(--azul-900);font-size:13.5px;font-weight:700;line-height:1.2}
.cg-table .campus-cell small{color:var(--muted);font-size:11.5px}
.cg-table .num-cell{font-weight:800;color:var(--azul-900);font-size:15px;font-feature-settings:"tnum"}
.cg-table .health-bar{display:flex;align-items:center;gap:8px}
.cg-table .health-bar .bar{flex:1;height:6px;background:var(--bg);border-radius:3px;overflow:hidden;min-width:80px;max-width:120px}
.cg-table .health-bar .bar span{display:block;height:100%;border-radius:3px;transition:width .5s}
.cg-table .health-bar .pct{font-size:11.5px;color:var(--muted);font-weight:700;width:36px;text-align:right}
.cg-table .badge-min{font-size:10.5px;font-weight:700;padding:3px 9px;border-radius:999px;text-transform:uppercase;letter-spacing:.5px}
.cg-table .badge-min.ok{background:#dcfce7;color:#14532d}
.cg-table .badge-min.warn{background:#fef3c7;color:#78350f}
.cg-table .badge-min.erro{background:#fee2e2;color:#7f1d1d}

/* Lista de pendências compacta */
.cg-pend-list{list-style:none;margin:0;padding:0;max-height:340px;overflow-y:auto}
.cg-pend-item{display:flex;align-items:center;gap:12px;padding:13px 22px;border-bottom:1px solid var(--borda);text-decoration:none;color:inherit;transition:background .12s}
.cg-pend-item:last-child{border-bottom:0}
.cg-pend-item:hover{background:var(--bg)}
.cg-pend-item .pend-tipo{width:32px;height:32px;border-radius:9px;display:grid;place-items:center;font-size:12px;flex-shrink:0}
.cg-pend-item .pend-tipo.proj{background:var(--azul-50);color:var(--azul)}
.cg-pend-item .pend-tipo.art{background:var(--amarelo-50);color:#7c5200}
.cg-pend-item .pend-info{flex:1;min-width:0}
.cg-pend-item .pend-info b{display:block;color:var(--azul-900);font-size:13px;font-weight:600;line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cg-pend-item .pend-info small{color:var(--muted);font-size:11px}
.cg-pend-item .pend-tempo{font-size:10.5px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;font-weight:600;flex-shrink:0}

/* Painel de ações estratégicas */
.cg-acoes{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--borda);border:1px solid var(--borda);border-radius:14px;overflow:hidden}
.cg-acao{background:#fff;padding:18px;text-decoration:none;color:inherit;transition:background .15s;display:flex;align-items:center;gap:14px}
.cg-acao:hover{background:var(--bg)}
.cg-acao i{width:36px;height:36px;border-radius:10px;background:var(--azul-50);color:var(--azul);display:grid;place-items:center;font-size:14px;flex-shrink:0;transition:all .15s}
.cg-acao:hover i{background:var(--azul);color:#fff;transform:rotate(-5deg) scale(1.05)}
.cg-acao .acao-info{flex:1;min-width:0}
.cg-acao .acao-info b{display:block;color:var(--azul-900);font-size:13px;font-weight:700;margin-bottom:2px}
.cg-acao .acao-info small{color:var(--muted);font-size:11.5px}

/* Mini-gráfico (sparkline-like) */
.cg-spark{display:flex;align-items:flex-end;gap:2px;height:30px;width:80px}
.cg-spark span{flex:1;background:linear-gradient(180deg,var(--azul),var(--azul-700));border-radius:2px 2px 0 0;min-height:3px;opacity:.7;transition:opacity .15s}
.cg-spark:hover span{opacity:1}

/* Empty state minimalista */
.cg-empty{text-align:center;padding:30px 20px;color:var(--muted)}
.cg-empty i{font-size:28px;color:var(--ok);margin-bottom:6px;opacity:.5}
.cg-empty b{display:block;color:var(--azul-900);font-size:13px;margin-bottom:2px;font-weight:600}
.cg-empty small{font-size:12px}

/* Mini-doughnut wrapper */
.cg-mini-chart{padding:14px 22px}

/* Visão por campus (Coord. Geral) — mini-cards */
.campus-grid-mini{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:14px}
.campus-mini{background:#fff;border:1px solid var(--borda);border-radius:14px;padding:16px;transition:all .15s;position:relative;overflow:hidden}
.campus-mini::before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--azul),var(--amarelo))}
.campus-mini:hover{transform:translateY(-3px);box-shadow:0 12px 28px rgba(10,61,145,.12);border-color:var(--azul-50)}
.campus-mini-h{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.campus-mini-h .campus-icon{width:42px;height:42px;border-radius:11px;background:linear-gradient(135deg,var(--azul),var(--azul-700));color:var(--amarelo);display:grid;place-items:center;font-size:17px;flex-shrink:0}
.campus-mini-h .campus-tit{flex:1;min-width:0}
.campus-mini-h .campus-tit b{display:block;color:var(--azul-900);font-size:14.5px;font-weight:700;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.campus-mini-h .campus-tit small{color:var(--muted);font-size:11.5px}
.campus-mini-h .tag-sem-coord{background:var(--erro);color:#fff;width:24px;height:24px;border-radius:50%;display:grid;place-items:center;font-weight:900;font-size:13px;flex-shrink:0;animation:pulseAlert 2s ease-in-out infinite;cursor:help}
@keyframes pulseAlert{0%,100%{transform:scale(1);box-shadow:0 0 0 0 rgba(220,38,38,.4)}50%{transform:scale(1.08);box-shadow:0 0 0 6px rgba(220,38,38,0)}}
.campus-mini-stats{display:grid;grid-template-columns:1fr 1fr 1fr;gap:6px;text-align:center;margin-bottom:12px}
.campus-mini-stats div{background:var(--bg);padding:8px 6px;border-radius:8px}
.campus-mini-stats b{display:block;color:var(--azul-900);font-size:18px;font-weight:800;line-height:1}
.campus-mini-stats span{color:var(--muted);font-size:10px;text-transform:uppercase;letter-spacing:.5px;font-weight:600}
.campus-mini-coord{font-size:12px;color:var(--muted);padding-top:10px;border-top:1px dashed var(--borda);display:flex;align-items:center;gap:7px}
.campus-mini-coord i{color:var(--azul);font-size:11px}

/* Lista compacta (atividade, usuários, tickets) */
.list-compact{max-height:340px;overflow-y:auto}
.list-compact .item{display:flex;align-items:center;gap:12px;padding:11px 0;border-bottom:1px solid var(--borda)}
.list-compact .item:last-child{border-bottom:0}
.list-compact .item .av{width:36px;height:36px;border-radius:50%;background:var(--azul);color:#fff;display:grid;place-items:center;font-weight:700;font-size:11.5px;flex-shrink:0}
.list-compact .item .info{flex:1;min-width:0}
.list-compact .item .info b{display:block;color:var(--azul-900);font-size:13.5px;line-height:1.3;font-weight:600}
.list-compact .item .info small{color:var(--muted);font-size:11.5px}
.list-compact .item .stamp{font-size:11px;color:var(--muted);flex-shrink:0;text-align:right}

/* ===========================================
   CHATBOT INTERNO JUNIP — assistente flutuante
   =========================================== */
.chatbot-fab{position:fixed;bottom:24px;right:24px;width:60px;height:60px;border-radius:50%;background:linear-gradient(135deg,var(--azul),var(--azul-700));color:var(--amarelo);border:3px solid #fff;display:grid;place-items:center;font-size:24px;cursor:pointer;box-shadow:0 12px 30px rgba(10,61,145,.35);z-index:120;transition:all .2s}
.chatbot-fab:hover{transform:scale(1.08);box-shadow:0 16px 38px rgba(10,61,145,.45)}
.chatbot-fab .badge-new{position:absolute;top:-2px;right:-2px;background:var(--erro);color:#fff;font-size:10px;font-weight:800;width:20px;height:20px;border-radius:50%;display:grid;place-items:center;border:2px solid #fff;animation:pulseRing 2s ease-in-out infinite}
.chatbot-fab .pulse-ring{position:absolute;inset:-3px;border-radius:50%;border:3px solid var(--amarelo);opacity:0;animation:botPulse 2s ease-out infinite}
@keyframes botPulse{0%{transform:scale(1);opacity:.7}100%{transform:scale(1.4);opacity:0}}

.chatbot{position:fixed;bottom:96px;right:24px;width:380px;max-width:calc(100vw - 30px);height:560px;max-height:calc(100vh - 130px);background:#fff;border-radius:18px;box-shadow:0 24px 60px rgba(10,61,145,.28);z-index:121;display:flex;flex-direction:column;overflow:hidden;opacity:0;transform:translateY(20px) scale(.95);transform-origin:bottom right;pointer-events:none;transition:opacity .25s,transform .25s}
.chatbot.open{opacity:1;transform:translateY(0) scale(1);pointer-events:auto}

.chatbot-header{background:linear-gradient(135deg,var(--azul-900),var(--azul));color:#fff;padding:16px 18px;display:flex;align-items:center;gap:12px;flex-shrink:0;position:relative;overflow:hidden}
.chatbot-header::before{content:"";position:absolute;width:200px;height:200px;border-radius:50%;background:radial-gradient(circle,rgba(255,193,7,.18),transparent 70%);top:-80px;right:-50px;pointer-events:none}
.chatbot-header .bot-avatar{width:42px;height:42px;border-radius:12px;background:var(--amarelo);color:var(--azul-900);display:grid;place-items:center;font-size:20px;flex-shrink:0;position:relative;z-index:1}
.chatbot-header .bot-avatar::after{content:"";position:absolute;bottom:-2px;right:-2px;width:13px;height:13px;border-radius:50%;background:#22c55e;border:2px solid var(--azul-900)}
.chatbot-header .bot-info{flex:1;min-width:0;position:relative;z-index:1}
.chatbot-header .bot-info b{display:block;font-size:14.5px;color:#fff}
.chatbot-header .bot-info small{font-size:11.5px;color:rgba(255,255,255,.75);display:flex;align-items:center;gap:4px}
.chatbot-header .bot-info small::before{content:"";width:7px;height:7px;border-radius:50%;background:#22c55e;display:inline-block}
.chatbot-header .bot-close{background:rgba(255,255,255,.1);border:0;color:#fff;width:32px;height:32px;border-radius:9px;cursor:pointer;font-size:14px;transition:background .15s;position:relative;z-index:1}
.chatbot-header .bot-close:hover{background:rgba(255,255,255,.2)}

.chatbot-body{flex:1;overflow-y:auto;padding:16px;background:linear-gradient(180deg,#f8faff,var(--bg));scroll-behavior:smooth}
.chatbot-body::-webkit-scrollbar{width:6px}
.chatbot-body::-webkit-scrollbar-thumb{background:var(--borda);border-radius:3px}

.msg{display:flex;gap:8px;margin-bottom:14px;animation:msgIn .25s ease-out}
@keyframes msgIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.msg.bot{justify-content:flex-start}
.msg.user{justify-content:flex-end}
.msg .av{width:30px;height:30px;border-radius:50%;display:grid;place-items:center;font-size:13px;font-weight:700;flex-shrink:0}
.msg.bot .av{background:linear-gradient(135deg,var(--azul),var(--azul-700));color:var(--amarelo)}
.msg.user .av{background:linear-gradient(135deg,var(--amarelo),var(--amarelo-600));color:var(--azul-900);order:2}
.msg .bubble{max-width:78%;padding:10px 13px;border-radius:14px;font-size:13.5px;line-height:1.45;color:var(--txt)}
.msg.bot .bubble{background:#fff;border:1px solid var(--borda);border-top-left-radius:4px;box-shadow:0 2px 8px rgba(10,61,145,.04)}
.msg.user .bubble{background:linear-gradient(135deg,var(--azul),var(--azul-700));color:#fff;border-top-right-radius:4px}
.msg .bubble b{color:var(--azul-900)}
.msg.user .bubble b{color:#fff}
.msg .bubble a{color:var(--azul);text-decoration:underline;font-weight:600}
.msg.user .bubble a{color:var(--amarelo)}
.msg .bubble small{display:block;color:var(--muted);font-size:11px;margin-top:4px}
.msg.user .bubble small{color:rgba(255,255,255,.7)}

.quick-replies{display:flex;flex-wrap:wrap;gap:6px;margin:6px 0 14px 38px}
.quick-reply{background:#fff;border:1px solid var(--azul-50);color:var(--azul);padding:6px 12px;border-radius:999px;font-size:12.5px;font-weight:600;cursor:pointer;transition:all .15s;font-family:inherit}
.quick-reply:hover{background:var(--azul);color:#fff;border-color:var(--azul)}

.typing{display:flex;gap:8px;align-items:center;margin-bottom:14px}
.typing .av{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,var(--azul),var(--azul-700));color:var(--amarelo);display:grid;place-items:center;font-size:13px}
.typing .dots{background:#fff;border:1px solid var(--borda);padding:11px 14px;border-radius:14px;border-top-left-radius:4px;display:flex;gap:4px}
.typing .dots span{width:7px;height:7px;border-radius:50%;background:var(--muted);animation:bounce 1.2s infinite ease-in-out}
.typing .dots span:nth-child(2){animation-delay:.2s}
.typing .dots span:nth-child(3){animation-delay:.4s}
@keyframes bounce{0%,60%,100%{transform:translateY(0);opacity:.5}30%{transform:translateY(-6px);opacity:1}}

.chatbot-header .bot-close+.bot-close{margin-left:0}
.chatbot-suggestions{padding:0 12px;background:#fff;border-top:1px solid var(--borda);display:flex;gap:6px;flex-wrap:wrap;flex-shrink:0;max-height:90px;overflow-y:auto}
.chatbot-suggestions:empty{display:none}
.sugg-chip{background:var(--azul-50);color:var(--azul);border:0;padding:5px 10px;border-radius:999px;font-size:11.5px;font-weight:600;cursor:pointer;font-family:inherit;margin:6px 0 0;transition:all .12s}
.sugg-chip:hover{background:var(--azul);color:#fff}
.chatbot-footer code{background:rgba(255,193,7,.2);color:var(--amarelo);padding:1px 6px;border-radius:4px;font-family:Monaco,monospace;font-size:10px}
.msg .bubble code{background:var(--bg);color:var(--azul);padding:1px 6px;border-radius:4px;font-family:Monaco,monospace;font-size:12px}
.msg.user .bubble code{background:rgba(255,255,255,.2);color:#fff}
.chatbot-input{padding:12px;background:#fff;border-top:1px solid var(--borda);display:flex;gap:8px;flex-shrink:0}
.chatbot-input input{flex:1;border:1px solid var(--borda);border-radius:24px;padding:10px 16px;font-size:14px;font-family:inherit;outline:none;background:var(--bg);transition:all .15s}
.chatbot-input input:focus{border-color:var(--azul);background:#fff;box-shadow:0 0 0 3px var(--azul-50)}
.chatbot-input button{width:42px;height:42px;border-radius:50%;border:0;background:linear-gradient(135deg,var(--azul),var(--azul-700));color:#fff;cursor:pointer;font-size:14px;flex-shrink:0;transition:transform .12s}
.chatbot-input button:hover{transform:scale(1.05)}
.chatbot-input button:active{transform:scale(.95)}
.chatbot-input button.mic{background:var(--bg);color:var(--azul);border:1px solid var(--borda)}
.chatbot-input button.mic.listening{background:var(--erro);color:#fff;border-color:var(--erro);animation:micPulse 1.5s infinite}
@keyframes micPulse{0%,100%{box-shadow:0 0 0 0 rgba(220,38,38,.4)}50%{box-shadow:0 0 0 8px rgba(220,38,38,0)}}
.chatbot-input .powered{font-size:10px;color:var(--muted);text-align:center;width:100%;display:block;margin-top:4px}

/* Cards ricos dentro de mensagens */
.bot-cards{display:flex;flex-direction:column;gap:6px;margin:8px 0 14px 38px;max-width:calc(100% - 38px)}
.bot-card{background:#fff;border:1px solid var(--borda);border-radius:10px;padding:10px 12px;display:flex;align-items:center;gap:10px;transition:all .12s;text-decoration:none;color:inherit}
.bot-card:hover{border-color:var(--azul);background:var(--azul-50);transform:translateX(2px)}
.bot-card .ico{width:32px;height:32px;border-radius:8px;background:var(--azul-50);color:var(--azul);display:grid;place-items:center;font-size:13px;flex-shrink:0}
.bot-card .info{flex:1;min-width:0}
.bot-card .info b{display:block;font-size:13px;color:var(--azul-900);font-weight:700;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bot-card .info small{color:var(--muted);font-size:11px}
.bot-card .arrow{color:var(--muted);font-size:11px;flex-shrink:0}
.bot-card:hover .arrow{color:var(--azul);transform:translateX(3px)}

/* Wizard multi-etapa */
.bot-wizard{margin:6px 0 14px 38px;background:linear-gradient(135deg,#fff7dc,#fff);border:1px solid var(--amarelo);border-radius:10px;padding:14px;max-width:calc(100% - 38px)}
.bot-wizard .step-label{font-size:10.5px;color:#7c5200;text-transform:uppercase;letter-spacing:1px;font-weight:700;margin-bottom:8px}
.bot-wizard input,.bot-wizard select,.bot-wizard textarea{width:100%;padding:8px 10px;border:1px solid var(--borda);border-radius:7px;font-size:13px;font-family:inherit;outline:none;margin-bottom:8px}
.bot-wizard input:focus,.bot-wizard select:focus,.bot-wizard textarea:focus{border-color:var(--azul)}
.bot-wizard .acoes{display:flex;gap:6px;margin-top:6px}
.bot-wizard .btn-mini{font-size:12px;padding:6px 12px;border-radius:7px;cursor:pointer;font-family:inherit;font-weight:600;border:0}
.bot-wizard .btn-mini.primary{background:var(--amarelo);color:var(--azul-900)}
.bot-wizard .btn-mini.cancel{background:var(--bg);color:var(--muted)}

/* Header do chatbot — múltiplos botões */
.chatbot-header .bot-actions{display:flex;gap:4px;margin-left:auto}
.chatbot-header .bot-actions .bot-icon-btn{background:rgba(255,255,255,.1);border:0;color:#fff;width:30px;height:30px;border-radius:8px;cursor:pointer;font-size:13px}
.chatbot-header .bot-actions .bot-icon-btn:hover{background:rgba(255,255,255,.2)}

/* Indicador de voz "ouvindo" */
.voice-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(255,255,255,.95);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:10;border-radius:18px}
.voice-overlay .mic-circle{width:80px;height:80px;border-radius:50%;background:var(--erro);color:#fff;display:grid;place-items:center;font-size:30px;margin-bottom:14px;animation:micPulse 1.5s infinite}
.voice-overlay .voice-text{color:var(--azul-900);font-weight:600}
.voice-overlay .voice-status{font-size:12px;color:var(--muted);margin-top:6px}

.chatbot-footer{padding:8px 14px;background:var(--bg);border-top:1px solid var(--borda);font-size:10.5px;color:var(--muted);text-align:center;letter-spacing:.5px}
.chatbot-footer i{color:var(--amarelo)}

@media (max-width:560px){
  .chatbot{bottom:84px;right:12px;left:12px;width:auto;max-width:none;height:calc(100vh - 100px)}
  .chatbot-fab{bottom:14px;right:14px;width:54px;height:54px;font-size:21px}
}

/* === Refinos finos JUNIP === */
.kpi{transition:transform .18s,box-shadow .18s,border-color .18s}
.kpi:hover{transform:translateY(-2px);box-shadow:0 10px 28px rgba(10,61,145,.10);border-color:var(--azul-50)}
.panel{transition:box-shadow .18s}
.panel:hover{box-shadow:0 8px 24px rgba(10,61,145,.08)}
.tbl tbody tr{transition:background .12s}
.btn{letter-spacing:.2px}
.btn:active{transform:translateY(0)}

/* Avatar do user-card com iniciais melhor */
.sidebar .user-card .avatar{font-size:13px;letter-spacing:.5px}

/* Sidebar — destaque do item ativo mais elegante */
.sidebar nav a.active{background:linear-gradient(90deg,rgba(255,193,7,.20),rgba(255,193,7,.05));position:relative}
.sidebar nav a.active::after{content:"";position:absolute;right:8px;top:50%;transform:translateY(-50%);width:4px;height:4px;border-radius:50%;background:var(--amarelo)}

/* File input estilizado */
input[type=file]{cursor:pointer;width:100%;padding:10px 14px;border:2px dashed var(--borda);border-radius:9px;background:var(--bg);color:var(--muted);font-size:14px;transition:border-color .15s,background .15s}
input[type=file]:hover{border-color:var(--azul);background:var(--azul-50)}
input[type=file]::file-selector-button{background:var(--azul);color:#fff;border:0;padding:8px 14px;border-radius:8px;font-weight:600;cursor:pointer;margin-right:12px;font-family:inherit;font-size:13px}
input[type=file]::file-selector-button:hover{background:var(--azul-700)}

/* Topbar busca refinada */
.topbar .search{transition:box-shadow .15s,border-color .15s}
.topbar .search:focus-within{border-color:var(--azul);box-shadow:0 0 0 3px var(--azul-50)}

/* Crumb com sutilemente mais espaçamento */
.topbar .crumb{font-weight:500}

/* Badge animado para contadores */
.sidebar nav a .badge{animation:pulseBadge 2s ease-in-out infinite}
@keyframes pulseBadge{0%,100%{transform:scale(1)}50%{transform:scale(1.08)}}

/* Tabelas — última coluna de ações alinhada à direita */
.tbl td:last-child{text-align:right;white-space:nowrap}
.tbl th:last-child{text-align:right}

/* Print: oculta sidebar e topbar para imprimir relatórios/atas */
@media print{
  .sidebar, .topbar, .actions, .btn, .modal-bg, .toasts, .backdrop{display:none !important}
  .app{grid-template-columns:1fr}
  .page{padding:0}
  .panel{box-shadow:none;border:1px solid #ddd;page-break-inside:avoid}
}
