:root{
    --bg:#0f172a;
    --panel:#111827;
    --card:#ffffff;
    --muted:#64748b;
    --text:#0f172a;
    --primary:#f59e0b;
    --primary-dark:#b45309;
    --border:#e5e7eb;
    --soft:#f8fafc;
    --danger:#dc2626;
    --success:#16a34a;
}
*{box-sizing:border-box}
body{margin:0;font-family:Arial,Helvetica,sans-serif;background:#f1f5f9;color:var(--text)}
a{color:#0f67b1;text-decoration:none}a:hover{text-decoration:underline}
.app-shell{min-height:100vh;display:flex}.sidebar{width:260px;background:linear-gradient(180deg,#0f172a,#111827);color:#fff;padding:22px 18px;position:fixed;top:0;bottom:0;left:0}.brand{display:flex;align-items:center;gap:12px;margin-bottom:30px}.brand-mark{width:42px;height:42px;border-radius:12px;background:var(--primary);color:#111827;display:flex;align-items:center;justify-content:center;font-weight:800}.brand strong{display:block;letter-spacing:.08em}.brand span{display:block;font-size:11px;color:#cbd5e1;margin-top:3px}.nav{display:flex;flex-direction:column;gap:6px}.nav a{color:#dbeafe;padding:12px;border-radius:10px}.nav a:hover{background:rgba(255,255,255,.08);text-decoration:none}.main{margin-left:260px;width:calc(100% - 260px)}.topbar{height:86px;background:#fff;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 28px}.topbar h1{margin:0;font-size:23px}.topbar p{margin:4px 0 0;color:var(--muted);font-size:13px}.userbox{display:flex;align-items:center;gap:14px}.userbox span{font-weight:700}.userbox a{background:#111827;color:#fff;padding:9px 13px;border-radius:8px}.content{padding:28px}.card{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:22px;box-shadow:0 6px 18px rgba(15,23,42,.05);margin-bottom:18px}.grid{display:grid;gap:18px}.grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}.stat strong{font-size:30px;display:block}.stat span{color:var(--muted);font-size:14px}.alert{padding:14px 16px;border-radius:12px;margin-bottom:16px}.alert-warning{background:#fffbeb;border:1px solid #fde68a;color:#92400e}.alert-error{background:#fef2f2;border:1px solid #fecaca;color:#991b1b}.alert-success{background:#f0fdf4;border:1px solid #bbf7d0;color:#166534}.table{width:100%;border-collapse:collapse;background:#fff}.table th,.table td{padding:12px;border-bottom:1px solid var(--border);text-align:left;font-size:14px}.table th{background:#f8fafc;color:#334155}.actions{display:flex;gap:8px;align-items:center}.btn{border:0;border-radius:9px;padding:10px 13px;cursor:pointer;display:inline-block;font-weight:700}.btn-primary{background:var(--primary);color:#111827}.btn-dark{background:#111827;color:#fff}.btn-light{background:#e5e7eb;color:#111827}.btn-danger{background:var(--danger);color:#fff}.btn:hover{text-decoration:none;filter:brightness(.96)}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.form-group label{display:block;font-weight:700;margin-bottom:6px}.form-control{width:100%;border:1px solid #cbd5e1;border-radius:9px;padding:11px;font-size:15px}.form-control:focus{outline:2px solid rgba(245,158,11,.25);border-color:var(--primary)}.form-actions{margin-top:18px;display:flex;gap:10px}.login-page{min-height:100vh;background:radial-gradient(circle at top left,#f59e0b,#0f172a 38%,#020617);display:flex;align-items:center;justify-content:center;padding:24px}.login-card{width:100%;max-width:420px;background:#fff;border-radius:18px;padding:30px;box-shadow:0 24px 80px rgba(0,0,0,.28)}.login-card h1{margin:0 0 6px}.login-card p{margin:0 0 22px;color:var(--muted)}.badge{display:inline-block;border-radius:999px;padding:5px 9px;font-size:12px;font-weight:700}.badge-green{background:#dcfce7;color:#166534}.badge-gray{background:#e5e7eb;color:#374151}.toolbar{display:flex;justify-content:space-between;gap:12px;align-items:center;margin-bottom:16px}.search{display:flex;gap:8px}.search input{min-width:280px}.muted{color:var(--muted)}
@media(max-width:900px){.sidebar{position:static;width:100%}.app-shell{display:block}.main{margin-left:0;width:100%}.grid-4{grid-template-columns:repeat(2,minmax(0,1fr))}.form-grid{grid-template-columns:1fr}.topbar{height:auto;padding:18px;gap:14px;align-items:flex-start;flex-direction:column}.content{padding:18px}}
@media(max-width:520px){.grid-4{grid-template-columns:1fr}.toolbar{align-items:stretch;flex-direction:column}.search{flex-direction:column}.search input{min-width:0}.actions{flex-wrap:wrap}}

/* HOTFIX — Menu lateral com rolagem
   Permite acessar todos os módulos mesmo em telas com baixa altura. */
.sidebar{
    height:100vh;
    overflow:hidden;
    display:flex;
    flex-direction:column;
}
.sidebar .brand{
    flex:0 0 auto;
}
.sidebar .nav{
    flex:1 1 auto;
    overflow-y:auto;
    overflow-x:hidden;
    padding-right:6px;
    padding-bottom:28px;
    scrollbar-width:thin;
    scrollbar-color:rgba(245,158,11,.85) rgba(255,255,255,.08);
}
.sidebar .nav::-webkit-scrollbar{width:8px}
.sidebar .nav::-webkit-scrollbar-track{background:rgba(255,255,255,.08);border-radius:999px}
.sidebar .nav::-webkit-scrollbar-thumb{background:rgba(245,158,11,.85);border-radius:999px}
.sidebar .nav::-webkit-scrollbar-thumb:hover{background:#f59e0b}
.sidebar .nav a{flex:0 0 auto}

@media(max-width:900px){
    .sidebar{
        height:auto;
        max-height:none;
        overflow:visible;
        display:block;
    }
    .sidebar .nav{
        max-height:none;
        overflow:visible;
        padding-right:0;
        padding-bottom:0;
    }
}

/* HOTFIX V2 — Rolagem garantida do menu lateral
   Motivo: em alguns navegadores o item flex .nav não encolhe sem min-height:0,
   e a sidebar acaba cortando os últimos links. */
.sidebar{
    position:fixed !important;
    top:0 !important;
    bottom:0 !important;
    left:0 !important;
    height:100vh !important;
    max-height:100vh !important;
    overflow:hidden !important;
    display:flex !important;
    flex-direction:column !important;
}
.sidebar .brand{
    flex:0 0 auto !important;
    margin-bottom:16px !important;
}
.sidebar .nav{
    display:block !important;
    flex:1 1 auto !important;
    min-height:0 !important;
    max-height:calc(100vh - 112px) !important;
    overflow-y:scroll !important;
    overflow-x:hidden !important;
    padding-right:8px !important;
    padding-bottom:36px !important;
    -webkit-overflow-scrolling:touch;
}
.sidebar .nav a{
    display:block !important;
    width:100% !important;
    margin-bottom:6px !important;
}

@media(max-width:900px){
    .sidebar{
        position:static !important;
        height:auto !important;
        max-height:none !important;
        overflow:visible !important;
        display:block !important;
    }
    .sidebar .nav{
        max-height:none !important;
        overflow:visible !important;
        padding-right:0 !important;
        padding-bottom:0 !important;
    }
}

/* HOTFIX V3 — Barra de rolagem do menu mais discreta
   Remove destaque amarelo e usa tons escuros compatíveis com o fundo. */
.sidebar .nav{
    scrollbar-color:rgba(71,85,105,.65) rgba(15,23,42,.35) !important;
}
.sidebar .nav::-webkit-scrollbar{width:8px !important}
.sidebar .nav::-webkit-scrollbar-track{
    background:rgba(15,23,42,.35) !important;
    border-radius:999px !important;
}
.sidebar .nav::-webkit-scrollbar-thumb{
    background:rgba(71,85,105,.65) !important;
    border-radius:999px !important;
    border:2px solid rgba(15,23,42,.35) !important;
}
.sidebar .nav::-webkit-scrollbar-thumb:hover{
    background:rgba(100,116,139,.8) !important;
}

/* FASE 18 — Refinamento de UX dos Portais */
.nav a.active{
    background:rgba(255,255,255,.10) !important;
    color:#fff !important;
    font-weight:800;
    text-decoration:none;
    box-shadow:inset 3px 0 0 #f59e0b;
}
.nav a.active:hover{text-decoration:none}
.page-intro{margin-bottom:18px}.page-intro h2{margin:0 0 6px}.page-intro p{margin:0}
.empty-state{padding:18px;background:#f8fafc;border:1px dashed #cbd5e1;border-radius:12px}
.card{overflow-x:auto}
.table{min-width:760px}
.table.compact th,.table.compact td{padding:8px 10px;font-size:13px}
.quick-actions{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:18px}
.quick-actions .btn{white-space:nowrap}
.kpi-trend{font-size:12px;color:#64748b;margin-top:4px;display:block}
.search .form-control[type="date"]{min-width:150px}.search select.form-control{min-width:160px}
.topbar .userbox a:first-child{background:#f59e0b;color:#111827}
.result-list{display:grid;gap:12px}.result-item{border:1px solid #e5e7eb;border-radius:12px;padding:14px;background:#fff}.result-item strong{display:block;margin-bottom:4px}.result-meta{font-size:13px;color:#64748b}.result-type{display:inline-block;border-radius:999px;padding:4px 8px;background:#e5e7eb;color:#334155;font-size:12px;font-weight:700;margin-right:6px}
@media(max-width:900px){.table{min-width:680px}.topbar .userbox{flex-wrap:wrap}.quick-actions{flex-direction:column}.quick-actions .btn{width:100%;text-align:center}}

/* HOTFIX HOMOLOGAÇÃO 20.2 — Configurações, navegação e formulários */
.brand-img{width:42px;height:42px;border-radius:12px;object-fit:contain;background:rgba(255,255,255,.06);padding:4px;flex:0 0 auto}
.card .toolbar h2{font-size:28px;line-height:1.15;margin-bottom:4px}
.card h2{letter-spacing:-.02em}.detail-title{font-size:30px;font-weight:800;margin:0 0 4px}.detail-subtitle{color:#64748b;margin:0}.topbar .userbox a{white-space:nowrap}.topbar .userbox a[href="#"]{background:#334155;color:#fff}.form-grid hr{grid-column:1/-1;width:100%}
input[name*="senha"], input[type="password"]{font-family:Arial,Helvetica,sans-serif;letter-spacing:.02em}
