*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --navy:#0F2342;--blue:#1B3A6B;--blue-m:#2E5FA3;--blue-l:#4A80C4;--accent:#3B82F6;
  --crit:#DC2626;--crit-bg:#FEF2F2;--crit-bd:#FECACA;
  --high:#EA580C;--high-bg:#FFF7ED;--high-bd:#FED7AA;
  --med:#CA8A04;--med-bg:#FEFCE8;--med-bd:#FDE68A;
  --low:#16A34A;--low-bg:#F0FDF4;--low-bd:#BBF7D0;
  --ok:#16A34A;--warn:#CA8A04;--bad:#DC2626;
  --bg:#F0F4F8;--card:#FFFFFF;--border:#D1DCE8;--text:#0F2342;--muted:#64748B;--light:#94A3B8;
  --sidebar:220px;--radius:8px;--shadow:0 1px 3px rgba(0,0,0,.08),0 4px 12px rgba(0,0,0,.05);
  --font:'IBM Plex Sans',sans-serif;--mono:'IBM Plex Mono',monospace;
}
html,body{height:100%;font-family:var(--font);font-size:15px;color:var(--text);background:var(--bg);line-height:1.6}
.app{display:flex;min-height:100vh}
.sidebar{width:var(--sidebar);background:var(--navy);color:#fff;flex-shrink:0;display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow-y:auto}
.main{flex:1;min-width:0;display:flex;flex-direction:column}
.topbar{background:var(--card);border-bottom:1px solid var(--border);padding:.75rem 1.5rem;display:flex;align-items:center;gap:1rem;position:sticky;top:0;z-index:10}
.content{padding:1.75rem;flex:1}
.sidebar-logo{padding:1.25rem 1.25rem .75rem;border-bottom:1px solid rgba(255,255,255,.1)}
.sidebar-logo h1{font-size:14px;font-weight:600;color:#fff;letter-spacing:.01em}
.sidebar-logo p{font-size:10px;color:rgba(255,255,255,.4);font-family:var(--mono);margin-top:2px}
.nav-section{padding:.625rem 0 .25rem}
.nav-label{font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.3);padding:.25rem 1.25rem}
.nav-item{display:flex;align-items:center;gap:.625rem;padding:.475rem 1.25rem;color:rgba(255,255,255,.65);text-decoration:none;font-size:13px;transition:all .15s;border-left:2px solid transparent}
.nav-item:hover{color:#fff;background:rgba(255,255,255,.06)}
.nav-item.active{color:#fff;background:rgba(59,130,246,.18);border-left-color:var(--accent)}
.sidebar-footer{margin-top:auto;padding:1rem 1.25rem;border-top:1px solid rgba(255,255,255,.08);font-size:11px;color:rgba(255,255,255,.3);font-family:var(--mono)}
.topbar-title{font-weight:600;font-size:15px;color:var(--navy)}
.topbar-actions{margin-left:auto;display:flex;gap:.5rem;align-items:center}
.user-chip{display:flex;align-items:center;gap:.5rem;font-size:13px;color:var(--muted)}
.avatar{width:30px;height:30px;border-radius:50%;background:var(--blue-m);color:#fff;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600}
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)}
.card-header{padding:.875rem 1.25rem;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.card-header h2{font-size:13.5px;font-weight:600;color:var(--navy)}
.btn{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .875rem;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;border:none;transition:all .15s;text-decoration:none;font-family:var(--font)}
.btn-primary{background:var(--blue-m);color:#fff}.btn-primary:hover{background:var(--blue)}
.btn-accent{background:var(--accent);color:#fff}.btn-accent:hover{background:#2563EB}
.btn-ghost{background:transparent;color:var(--muted);border:1px solid var(--border)}.btn-ghost:hover{background:var(--bg);color:var(--text)}
.btn-danger{background:var(--crit-bg);color:var(--crit);border:1px solid var(--crit-bd)}.btn-danger:hover{background:var(--crit-bd)}
.btn-sm{padding:.25rem .625rem;font-size:12px}
.btn-icon{padding:.3rem;border-radius:5px;background:transparent;border:1px solid var(--border);color:var(--muted);cursor:pointer;transition:all .15s}.btn-icon:hover{background:var(--bg)}
.form-group{margin-bottom:.875rem}
.form-label{display:block;font-size:11.5px;font-weight:500;color:var(--muted);margin-bottom:.3rem;letter-spacing:.02em}
.form-control{width:100%;padding:.45rem .75rem;border:1px solid var(--border);border-radius:6px;font-size:13.5px;font-family:var(--font);color:var(--text);background:#fff;transition:border .15s}
.form-control:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(59,130,246,.1)}
textarea.form-control{resize:vertical;min-height:72px}
.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem}
.table{width:100%;border-collapse:collapse;font-size:13.5px}
.table th{padding:.5rem 1rem;text-align:left;font-size:11px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--muted);border-bottom:2px solid var(--border);white-space:nowrap}
.table td{padding:.575rem 1rem;border-bottom:1px solid var(--border);vertical-align:middle}
.table tr:last-child td{border-bottom:none}
.table tbody tr:hover{background:#F8FAFC}
.badge{display:inline-flex;align-items:center;gap:.25rem;padding:.175rem .55rem;border-radius:20px;font-size:11px;font-weight:600;letter-spacing:.02em}
.badge-sim,.badge-ok{background:#DCFCE7;color:#15803D}
.badge-nao,.badge-bad{background:#FEE2E2;color:#B91C1C}
.badge-parcial,.badge-warn{background:#FEF3C7;color:#92400E}
.badge-nd{background:#F1F5F9;color:#64748B}
.badge-crit{background:var(--crit-bg);color:var(--crit);border:1px solid var(--crit-bd)}
.badge-high{background:var(--high-bg);color:var(--high);border:1px solid var(--high-bd)}
.badge-med{background:var(--med-bg);color:var(--med);border:1px solid var(--med-bd)}
.badge-low{background:var(--low-bg);color:var(--low);border:1px solid var(--low-bd)}
.badge-admin{background:#EDE9FE;color:#6D28D9}
.badge-auditor{background:#DBEAFE;color:#1D4ED8}
.badge-viewer{background:#F1F5F9;color:#475569}
.badge-essencial{background:#FEF3C7;color:#92400E}
.badge-importante{background:#DBEAFE;color:#1D4ED8}
.badge-conforme{background:#DCFCE7;color:#15803D}
.badge-progresso{background:#FEF3C7;color:#92400E}
.badge-naoconforme{background:#FEE2E2;color:#B91C1C}
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(155px,1fr));gap:1rem;margin-bottom:1.5rem}
.stat-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:1rem 1.25rem;box-shadow:var(--shadow)}
.stat-label{font-size:10.5px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--muted);margin-bottom:.3rem}
.stat-value{font-size:28px;font-weight:700;font-family:var(--mono);color:var(--navy);line-height:1}
.stat-sub{font-size:11px;color:var(--light);margin-top:.2rem}
.progress{height:7px;background:var(--border);border-radius:4px;overflow:hidden}
.progress-fill{height:100%;border-radius:4px;transition:width .4s}
.fill-ok{background:var(--ok)}.fill-warn{background:var(--warn)}.fill-bad{background:var(--bad)}
.section-block{margin-bottom:1.25rem;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.section-hdr{padding:.7rem 1.25rem;display:flex;align-items:center;justify-content:space-between;color:#fff;cursor:pointer;user-select:none}
.section-title{font-weight:600;font-size:13px}
.section-ref{font-size:10.5px;opacity:.65;font-family:var(--mono)}
.section-body{display:none}
.section-body.open{display:block}
.item-row{display:grid;grid-template-columns:1fr auto auto;gap:.75rem;align-items:start;padding:.8rem 1.25rem;border-bottom:1px solid var(--border);background:#fff;transition:background .1s}
.item-row:last-child{border-bottom:none}
.item-row:hover{background:#FAFBFC}
.item-text{font-size:13px;line-height:1.5}
.radio-group{display:flex;gap:.2rem}
.radio-btn{padding:.275rem .65rem;border-radius:5px;font-size:11.5px;font-weight:500;cursor:pointer;border:1.5px solid var(--border);background:#fff;transition:all .15s;white-space:nowrap;font-family:var(--font)}
.radio-btn:hover{border-color:var(--blue-l)}
.radio-btn.sel-sim{background:#DCFCE7;border-color:#16A34A;color:#15803D}
.radio-btn.sel-nao{background:#FEE2E2;border-color:#DC2626;color:#B91C1C}
.radio-btn.sel-parcial{background:#FEF3C7;border-color:#CA8A04;color:#92400E}
.item-notes-toggle{padding:.275rem .5rem;border:1.5px solid var(--border);background:#fff;border-radius:5px;cursor:pointer;font-size:11.5px;color:var(--muted);transition:all .15s}.item-notes-toggle:hover{background:var(--bg)}
.item-notes{padding:.75rem 1.25rem;background:#FAFCFF;border-bottom:1px solid var(--border);display:none}
.item-notes.open{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}
.flash{padding:.7rem 1.25rem;border-radius:var(--radius);font-size:13.5px;margin-bottom:1.25rem;border:1px solid}
.flash-success{background:#F0FDF4;color:#15803D;border-color:#BBF7D0}
.flash-error{background:#FEF2F2;color:#B91C1C;border-color:#FECACA}
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:100;align-items:center;justify-content:center;padding:1rem}
.modal-overlay.open{display:flex}
.modal{background:#fff;border-radius:10px;width:100%;max-width:520px;box-shadow:0 20px 60px rgba(0,0,0,.2);max-height:90vh;overflow-y:auto}
.modal-hdr{padding:1.1rem 1.5rem;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.modal-hdr h3{font-size:14.5px;font-weight:600}
.modal-body{padding:1.25rem 1.5rem}
.modal-footer{padding:.875rem 1.5rem;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:.5rem}
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--navy);background-image:radial-gradient(ellipse at 20% 50%,rgba(43,82,160,.4) 0%,transparent 60%)}
.login-card{background:#fff;border-radius:12px;width:100%;max-width:390px;box-shadow:0 25px 80px rgba(0,0,0,.3);overflow:hidden}
.login-top{background:var(--blue);padding:1.75rem;text-align:center;color:#fff}
.login-top h1{font-size:18px;font-weight:600;margin-bottom:.25rem}
.login-top p{font-size:11px;color:rgba(255,255,255,.55);font-family:var(--mono)}
.login-body{padding:1.75rem}
.report-domain{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:.875rem;overflow:hidden}
.report-domain-hdr{padding:.65rem 1.25rem;color:#fff;display:flex;align-items:center;justify-content:space-between}
.report-item{display:flex;align-items:center;gap:.75rem;padding:.55rem 1.25rem;border-bottom:1px solid var(--border);font-size:13px}
.report-item:last-child{border-bottom:none}
.page-title{font-size:19px;font-weight:700;color:var(--navy);margin-bottom:1.25rem}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:.875rem}
.flex{display:flex}.items-center{align-items:center}.gap-1{gap:.5rem}.gap-2{gap:1rem}
.ml-auto{margin-left:auto}.text-muted{color:var(--muted)}.text-sm{font-size:12px}.mono{font-family:var(--mono)}.bold{font-weight:600}
.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}
.empty{padding:2.5rem;text-align:center;color:var(--light);font-size:13px}
@media(max-width:768px){.sidebar{display:none}.form-row,.grid-2,.grid-4{grid-template-columns:1fr}}
@media print{.sidebar,.topbar,.btn,.modal-overlay{display:none!important}.content{padding:0}}
