﻿@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap');

*{margin:0;padding:0;box-sizing:border-box}
:root{
  --azul:#1A56A0;
  --azul-escuro:#0F3D7A;
  --azul-profundo:#092B5A;
  --azul-claro:#EBF2FB;
  --azul-medio:#C8DEFA;
  --ambar:#D97706;
  --ambar-claro:#FEF3C7;
  --branco:#FFFFFF;
  --fundo:#F7F9FC;
  --cinza-borda:#E2E8F0;
  --cinza-claro:#F1F5F9;
  --cinza:#64748B;
  --grafite:#334155;
  --preto:#0F172A;
  --ok:#059669;
  --ok-claro:#D1FAE5;
  --alerta:#DC2626;
  /* legados */
  --verde:#1A56A0;
  --verde-claro:#EBF2FB;
  --verde-medio:#C8DEFA;
  --amarelo:#D97706;
  --amarelo-claro:#FEF3C7;
  --marrom:#0F3D7A;
  --creme:#F7F9FC;
}
html{scroll-behavior:smooth}
body{font-family:'Inter',sans-serif;background:var(--fundo);color:var(--grafite);min-height:100vh;font-size:15px;line-height:1.6}

/* LAYOUT */
.layout{display:flex;min-height:100vh}
.sidebar{width:220px;background:#0C1A2E;display:flex;flex-direction:column;flex-shrink:0;position:fixed;top:0;left:0;bottom:0;z-index:100;overflow-y:auto}
.main{margin-left:220px;flex:1;min-height:100vh;display:flex;flex-direction:column}

/* SIDEBAR */
.sb-logo{padding:20px 16px;border-bottom:1px solid rgba(255,255,255,.06)}
.sb-logo img{height:38px;mix-blend-mode:screen;display:block;margin-bottom:8px}
.sb-logo strong{display:block;color:#fff;font-size:13px;font-weight:800}
.sb-logo span{font-size:10px;color:rgba(255,255,255,.3)}
.sb-unidade{padding:10px 16px;background:rgba(255,208,0,.08);border-bottom:1px solid rgba(255,255,255,.05)}
.sb-unidade span{font-size:11px;font-weight:600;color:var(--amarelo)}
nav{flex:1;padding:10px 0}
.nav-label{font-size:9px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,.2);padding:10px 16px 4px}
.nav-item{display:flex;align-items:center;gap:10px;padding:10px 16px;color:rgba(255,255,255,.5);text-decoration:none;font-size:13px;font-weight:500;transition:all .2s;border-left:3px solid transparent}
.nav-item:hover,.nav-item.ativo{background:rgba(26,86,160,.25);color:#fff;border-left-color:#93C5FD}
.nav-icon{font-size:16px;width:20px;text-align:center;flex-shrink:0}
.sb-bottom{padding:12px 16px;border-top:1px solid rgba(255,255,255,.06)}
.sb-bottom a{color:rgba(255,255,255,.3);font-size:12px;text-decoration:none;transition:color .2s}
.sb-bottom a:hover{color:#fff}

/* TOPBAR */
.topbar{background:var(--branco);border-bottom:1px solid var(--cinza-borda);padding:0 28px;height:56px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:50}
.topbar h2{font-size:15px;font-weight:700;color:var(--preto)}
.topbar p{font-size:11px;color:var(--cinza)}

/* CONTEÚDO */
.content{padding:24px 28px;flex:1}

/* BOTÕES */
.btn{display:inline-flex;align-items:center;gap:7px;padding:10px 20px;border-radius:9px;font-size:13px;font-weight:600;font-family:'Inter',sans-serif;border:none;cursor:pointer;transition:all .2s;text-decoration:none}
.btn-primary{background:var(--azul);color:#fff}
.btn-primary:hover{background:#0d3b6e;transform:translateY(-1px)}
.btn-secondary{background:var(--cinza-claro);color:var(--grafite);border:1.5px solid #e0dbd0}
.btn-secondary:hover{background:#ece8de}
.btn-danger{background:#fef2f2;color:var(--alerta);border:1.5px solid #fecaca}
.btn-danger:hover{background:#fee2e2}
.btn-sm{padding:7px 14px;font-size:12px}
.btn-icon{padding:7px;border-radius:8px;font-size:14px;line-height:1;min-width:32px;justify-content:center}

/* BLOCO */
.bloco{background:var(--branco);border-radius:14px;padding:22px;box-shadow:0 2px 12px rgba(0,0,0,.05)}
.bloco-h{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;flex-wrap:wrap;gap:10px}
.bloco-titulo{font-size:14px;font-weight:700;color:var(--preto)}

/* TOOLBAR */
.toolbar{display:flex;gap:10px;margin-bottom:14px;flex-wrap:wrap}
.search{position:relative;flex:1;min-width:180px}
.search input{width:100%;padding:9px 13px 9px 34px;border:1.5px solid #e0dbd0;border-radius:9px;font-size:13px;font-family:'Inter',sans-serif;outline:none;background:var(--branco);transition:border-color .2s}
.search input:focus{border-color:var(--azul)}
.search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);font-size:14px;color:var(--cinza)}
.fselect{padding:9px 13px;border:1.5px solid #e0dbd0;border-radius:9px;font-size:13px;font-family:'Inter',sans-serif;outline:none;background:var(--branco);color:var(--grafite);cursor:pointer;transition:border-color .2s}
.fselect:focus{border-color:var(--azul)}

/* TABELA */
.tabela-wrap{overflow-x:auto;border-radius:10px;border:1px solid #ece8de}
table{width:100%;border-collapse:collapse;font-size:13px}
thead{background:var(--azul-claro)}
th{padding:10px 14px;text-align:left;font-size:10px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;color:var(--azul-escuro);white-space:nowrap}
td{padding:11px 14px;border-bottom:1px solid #f5f0e8;color:var(--grafite);vertical-align:middle}
tr:last-child td{border-bottom:none}
tr:hover td{background:#fafaf7}
.td-acoes{display:flex;gap:5px;justify-content:flex-end}

/* BADGES */
.badge{display:inline-flex;align-items:center;font-size:11px;font-weight:600;padding:3px 10px;border-radius:20px;white-space:nowrap}
.b-verde{background:var(--verde-claro);color:var(--verde)}
.b-amarelo{background:#fff3c4;color:var(--marrom)}
.b-ok{background:#d1fae5;color:#065f46}
.b-alerta{background:#fee2e2;color:#991b1b}
.b-atencao{background:#fff3cd;color:#856404}
.b-cinza{background:#f3f4f6;color:#6b7280}

/* MODAL */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:500;align-items:center;justify-content:center;padding:16px}
.modal-overlay.on{display:flex}
.modal{background:var(--branco);border-radius:16px;width:100%;max-width:560px;max-height:92vh;overflow-y:auto;box-shadow:0 20px 60px rgba(0,0,0,.2);animation:popIn .22s ease}
@keyframes popIn{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
.modal-h{padding:20px 24px 16px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid #f0ece4}
.modal-h h3{font-size:16px;font-weight:700;color:var(--preto)}
.modal-close{background:none;border:none;font-size:20px;cursor:pointer;color:var(--cinza);padding:2px 6px;border-radius:6px;transition:all .15s}
.modal-close:hover{background:var(--cinza-claro)}
.modal-body{padding:20px 24px}
.modal-footer{padding:0 24px 20px;display:flex;gap:10px;justify-content:flex-end;border-top:1px solid #f5f0e8;padding-top:16px}

/* FORMULÁRIO */
.fg{display:flex;flex-direction:column;gap:5px;margin-bottom:14px}
.fg label{font-size:12px;font-weight:600;color:var(--grafite)}
.fg label .req{color:var(--alerta)}
.fg input,.fg select,.fg textarea{padding:10px 13px;border:1.5px solid #e0dbd0;border-radius:8px;font-size:13px;font-family:'Inter',sans-serif;color:var(--grafite);background:var(--fundo);outline:none;transition:all .2s;width:100%}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--azul);background:var(--branco);box-shadow:0 0 0 3px rgba(26,86,160,.1)}
.fg textarea{resize:vertical;min-height:80px;line-height:1.5}
.fg .hint{font-size:11px;color:var(--cinza)}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.bloco-form{margin-bottom:18px;padding-bottom:16px;border-bottom:1px solid #f0ece4}
.bloco-form:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}
.bloco-form-titulo{font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--verde);margin-bottom:12px}

/* VAZIO */
.vazio{text-align:center;padding:44px 20px;color:var(--cinza)}
.vazio .vi{font-size:44px;margin-bottom:12px}
.vazio h4{font-size:15px;font-weight:600;color:var(--preto);margin-bottom:6px}
.vazio p{font-size:13px}

/* AVISO */
.aviso{display:flex;align-items:flex-start;gap:12px;padding:14px 18px;border-radius:10px;margin-bottom:18px}
.aviso.info{background:#fff8e0;border-left:4px solid var(--amarelo)}
.aviso.verde{background:var(--verde-claro);border-left:4px solid var(--verde)}
.aviso-ico{font-size:18px;flex-shrink:0;margin-top:1px}
.aviso strong{display:block;font-size:13px;color:var(--preto);margin-bottom:2px}
.aviso p{font-size:12px;color:var(--cinza);line-height:1.5}

/* MOBILE */
.mob-toggle{display:none;position:fixed;top:10px;left:10px;z-index:200;background:var(--preto);color:var(--amarelo);border:none;border-radius:8px;padding:8px 10px;font-size:18px;cursor:pointer}
@media(max-width:900px){
  .sidebar{transform:translateX(-100%);transition:transform .3s}
  .sidebar.open{transform:translateX(0)}
  .main{margin-left:0}
  .mob-toggle{display:block}
  .row2{grid-template-columns:1fr}
  .content{padding:16px}
  .topbar{padding:0 16px}
}
