:root{
  --bg:#f3f6fa;
  --bg-2:#eef2f7;
  --card:#ffffff;
  --text:#142033;
  --muted:#667085;
  --line:#e3e8ef;
  --line-strong:#d3dbe7;
  --blue:#1f5eff;
  --blue-dark:#173b73;
  --nav:#0f172a;
  --nav-2:#101b31;
  --nav-3:#13203b;
  --success:#15803d;
  --danger:#dc2626;
  --warning:#d97706;
  --purple:#7c3aed;
  --shadow:0 18px 40px rgba(15,23,42,.08);
  --shadow-soft:0 8px 24px rgba(15,23,42,.06);
  --radius-xl:24px;
  --radius-lg:18px;
  --radius-md:14px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Inter,Arial,sans-serif;background:linear-gradient(180deg,#f8fafc 0%,#f2f5f9 100%);color:var(--text);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
a{text-decoration:none;color:inherit}
.shadow-soft{box-shadow:var(--shadow-soft)}
.layout-shell{display:flex;min-height:100vh;position:relative}
.sidebar-overlay{display:none}
.sidebar{width:250px;background:linear-gradient(180deg,var(--nav) 0%,var(--nav-2) 60%,var(--nav-3) 100%);color:#fff;padding:16px 14px 16px;display:flex;flex-direction:column;gap:18px;position:sticky;top:0;height:100vh;border-right:1px solid rgba(255,255,255,.05);transition:width .25s ease,transform .25s ease,padding .25s ease;z-index:50;overflow:hidden}
.sidebar-topbar{display:flex;align-items:center;justify-content:space-between;gap:8px}
.brand-box{display:flex;gap:10px;align-items:center;min-width:0;padding:6px 8px;border-radius:16px}
.brand-copy{min-width:0}
.brand-mark{width:38px;height:38px;border-radius:13px;background:linear-gradient(135deg,#4a78aa,#234a78);display:grid;place-items:center;font-size:18px;font-weight:800;box-shadow:0 8px 18px rgba(35,74,120,.22);flex:0 0 auto}
.brand-box h1{font-size:13px;line-height:1.15;margin:0;font-weight:700;letter-spacing:.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.brand-box small{display:block;margin-top:3px;color:#95a3b8;font-size:10px;letter-spacing:.04em;text-transform:uppercase}
.sidebar-toggle{width:38px;height:38px;border-radius:12px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.045);color:#d8e3f1;display:inline-flex;align-items:center;justify-content:center;transition:.2s;position:relative}
.sidebar-toggle:hover{background:rgba(255,255,255,.09);color:#fff}
.menu-nav{display:grid;gap:8px;margin-top:8px}
.menu-link{position:relative;display:flex;align-items:center;gap:12px;padding:11px 13px;border-radius:14px;color:#c8d2e0;font-weight:600;font-size:12.5px;letter-spacing:.01em;border:1px solid transparent;background:transparent;transition:all .2s ease;white-space:nowrap}
.menu-link .menu-icon{width:30px;height:30px;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06);flex:0 0 30px;transition:.2s}
.menu-link i{font-size:18px;opacity:.96;line-height:1}
.menu-link.active,.menu-link:hover{background:rgba(255,255,255,.06);color:#fff;border-color:rgba(255,255,255,.06)}
.menu-link.active .menu-icon,.menu-link:hover .menu-icon{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.1);transform:translateY(-1px)}
.sidebar-user{margin-top:auto;padding:12px;border-radius:16px;background:rgba(255,255,255,.045);border:1px solid rgba(255,255,255,.05);transition:.25s}
.sidebar-user .fw-semibold{font-size:12.5px;line-height:1.3}.sidebar-user .small,.sidebar-user .text-muted{font-size:10.5px!important;color:#92a3b8!important}.sidebar-user .badge{font-size:9px;letter-spacing:.05em;padding:5px 8px;border-radius:999px;background:#234a78!important}.sidebar-user .btn{border-radius:10px;font-size:12px;padding:7px 11px}
body.sidebar-collapsed .sidebar{width:88px;padding-inline:10px}
body.sidebar-collapsed .brand-copy,body.sidebar-collapsed .menu-link .menu-label,body.sidebar-collapsed .sidebar-user .fw-semibold,body.sidebar-collapsed .sidebar-user .text-muted,body.sidebar-collapsed .sidebar-user .badge,body.sidebar-collapsed .sidebar-user .btn{display:none!important}
body.sidebar-collapsed .brand-box{justify-content:center;padding-inline:0}
body.sidebar-collapsed .sidebar-toggle{margin-inline:auto}
body.sidebar-collapsed .menu-link{justify-content:center;padding-inline:0}
body.sidebar-collapsed .menu-link i{width:auto;font-size:16px}
body.sidebar-collapsed .sidebar-user{padding:10px 6px;min-height:20px;background:transparent;border-color:transparent}
.main-content{flex:1;padding:24px 28px 34px;min-width:0;transition:padding .2s ease}
.page-head{display:flex;justify-content:space-between;gap:18px;align-items:flex-start;margin-bottom:18px}.page-head h2{margin:0 0 4px;font-size:20px;font-weight:700;letter-spacing:-.03em}.page-head p{max-width:760px;font-size:14px;color:var(--muted)!important}.eyebrow{text-transform:uppercase;letter-spacing:.18em;font-size:10px;font-weight:700;color:#325ca8}
.header-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.btn{border-radius:14px;font-weight:600;box-shadow:none!important}.btn-icon{width:44px;height:44px;padding:0;display:inline-flex;align-items:center;justify-content:center}
.panel{background:rgba(255,255,255,.94);backdrop-filter:blur(8px);border:1px solid var(--line);border-radius:24px;padding:20px;box-shadow:var(--shadow-soft)}
.panel-title{font-size:14px;font-weight:700;margin-bottom:10px;letter-spacing:-.01em}.panel-head{display:flex;align-items:center;justify-content:space-between;gap:16px}.filter-panel{margin-bottom:18px}
.kpi-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-bottom:18px}
.kpi-card{position:relative;overflow:hidden;border-radius:24px;padding:18px;background:linear-gradient(180deg,#fff 0%,#fcfdff 100%);border:1px solid rgba(15,23,42,.06);box-shadow:0 12px 32px rgba(15,23,42,.06);display:flex;flex-direction:column;gap:16px;min-height:184px;transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease}
.kpi-card:hover{transform:translateY(-2px);box-shadow:0 18px 38px rgba(15,23,42,.09)}
.kpi-card::before,.kpi-card::after{content:"";position:absolute;border-radius:50%;pointer-events:none;transition:background .25s ease, opacity .25s ease}
.kpi-card::before{right:-30px;top:-26px;width:110px;height:110px;background:rgba(255,255,255,.24)}
.kpi-card::after{left:-34px;bottom:-42px;width:130px;height:130px;background:rgba(255,255,255,.12)}
.kpi-card.total{--accent:#2f6fed;--accent-soft:rgba(47,111,237,.18);--accent-soft-2:rgba(47,111,237,.08);background:linear-gradient(135deg,#eff5ff 0%,#dce9ff 100%);border-color:rgba(47,111,237,.2)}
.kpi-card.pending{--accent:#f08c00;--accent-soft:rgba(240,140,0,.18);--accent-soft-2:rgba(240,140,0,.08);background:linear-gradient(135deg,#fff6e8 0%,#ffe3b4 100%);border-color:rgba(240,140,0,.2)}
.kpi-card.done{--accent:#16a34a;--accent-soft:rgba(22,163,74,.18);--accent-soft-2:rgba(22,163,74,.08);background:linear-gradient(135deg,#edfdf3 0%,#d2f5df 100%);border-color:rgba(22,163,74,.18)}
.kpi-card.risk{--accent:#ef4444;--accent-soft:rgba(239,68,68,.18);--accent-soft-2:rgba(239,68,68,.08);background:linear-gradient(135deg,#fff1f2 0%,#ffd8db 100%);border-color:rgba(239,68,68,.18)}
.kpi-card.state-good{background:linear-gradient(135deg,#edfdf3 0%,#d2f5df 100%);border-color:rgba(22,163,74,.2);--accent:#16a34a;--accent-soft:rgba(22,163,74,.18);--accent-soft-2:rgba(22,163,74,.08)}
.kpi-card.state-watch{background:linear-gradient(135deg,#fff7e8 0%,#ffe5bc 100%);border-color:rgba(217,119,6,.2);--accent:#d97706;--accent-soft:rgba(217,119,6,.18);--accent-soft-2:rgba(217,119,6,.08)}
.kpi-card.state-alert{background:linear-gradient(135deg,#fff1f2 0%,#ffd6d9 100%);border-color:rgba(220,38,38,.2);--accent:#dc2626;--accent-soft:rgba(220,38,38,.18);--accent-soft-2:rgba(220,38,38,.08)}
.kpi-card.state-neutral{background:linear-gradient(135deg,#f8fafc 0%,#eef2f6 100%);border-color:#e4e7ec;--accent:#64748b;--accent-soft:rgba(100,116,139,.16);--accent-soft-2:rgba(100,116,139,.08)}
.kpi-top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;position:relative;z-index:1}.kpi-label{font-size:12.5px;font-weight:700;color:#243245;letter-spacing:.01em}.kpi-subtitle{font-size:11px;line-height:1.5;color:#536274;max-width:220px;margin-top:4px}.kpi-icon{width:44px;height:44px;border-radius:15px;display:grid;place-items:center;font-size:18px;background:var(--accent-soft);color:var(--accent);border:1px solid rgba(255,255,255,.35);font-weight:700}
.kpi-value-row{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;position:relative;z-index:1}.kpi-value{font-size:48px;line-height:.9;font-weight:800;letter-spacing:-.06em;color:#101828}.kpi-meta{text-align:right;font-size:10.5px;line-height:1.45;color:#536274}.kpi-meta strong{color:#233247}
.kpi-progress{height:7px;border-radius:999px;background:rgba(255,255,255,.42);overflow:hidden;position:relative;z-index:1;border:1px solid rgba(255,255,255,.2)}.kpi-progress-bar{height:100%;border-radius:999px;width:0;transition:width .45s ease;background:var(--accent)}
.kpi-footer{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-top:auto;font-size:10.5px;color:#536274;line-height:1.4;position:relative;z-index:1}.kpi-chip{display:inline-flex;align-items:center;padding:5px 10px;border-radius:999px;background:rgba(255,255,255,.42);color:#233247;font-weight:700}
.charts-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.charts-grid .panel:first-child{grid-column:span 2}.chart-panel{overflow:hidden}.chart-wrap{position:relative;height:300px}.chart-wrap-sm{height:290px}.chart-wrap-wide{height:330px}.chart-wrap-bar{height:340px}.chart-wrap canvas{width:100%!important;height:100%!important;max-width:100%!important}.chart-panel .panel-title{margin-bottom:12px}
.table-modern{margin-bottom:0}.table-modern thead th{background:#f8fafc;color:#667085;border-bottom:1px solid var(--line);font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;white-space:nowrap}.table-modern td,.table-modern th{vertical-align:middle;padding:.9rem .8rem}.table-modern tbody tr:hover{background:#fafcff}
.badge-soft{display:inline-flex;padding:6px 10px;border-radius:999px;font-size:11px;font-weight:700}.b-pendente{background:#fff4e5;color:#9a6700}.b-andamento{background:#eaf3ff;color:#1849a9}.b-concluido{background:#eaf7ef;color:#027a48}
.risk{font-weight:700}.risk.Baixo{color:#027a48}.risk.Médio,.risk.Medio{color:#6941c6}.risk.Alto{color:#b42318}.table-footer{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-top:12px;flex-wrap:wrap}.pagination-wrap{display:flex;gap:8px;flex-wrap:wrap}.page-btn{border:1px solid var(--line);background:#fff;border-radius:10px;padding:8px 12px;font-size:12px}.page-btn.active{background:var(--blue);color:#fff;border-color:var(--blue)}
.login-page{min-height:100vh;display:grid;place-items:center;padding:24px}.login-card{width:min(500px,100%);background:#fff;border:1px solid var(--line);border-radius:24px;padding:30px;box-shadow:var(--shadow)}.demo-box{padding:16px;border:1px dashed #d0d5dd;border-radius:14px;background:#f8fafc;color:#475467}
.paper-form{background:#fff;border:1px solid var(--line);border-radius:24px;padding:22px;box-shadow:0 10px 24px rgba(16,24,40,.04)}.paper-section-title{position:relative;margin:14px 0 12px;padding:10px 16px;background:linear-gradient(90deg,#eff5fb,#e6edf6);color:#1d3557;font-weight:700;font-size:14px;border:1px solid #d8e3ef;border-radius:12px;display:inline-flex;align-items:center;min-width:280px}.paper-box{border:1px solid #dbe5ef;border-radius:18px;padding:18px 18px 16px;margin-bottom:16px;background:#fff;box-shadow:0 6px 16px rgba(16,24,40,.03)}.paper-box.no-padding{padding:0;overflow:hidden}
.grid-2,.grid-3{display:grid;gap:14px}.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}.line-group{display:flex;align-items:end;gap:10px}.line-group label{min-width:max-content;font-size:13px;color:#344054}.line-group input,.line-group select{border:0;border-bottom:1px solid #98a2b3;border-radius:0;box-shadow:none!important;padding:.38rem .2rem;background:transparent}.paper-box textarea{border:1px solid #d0d9e5;border-radius:14px;resize:vertical;min-height:110px;box-shadow:none!important;background:#fbfdff}.choice-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px 24px}.table-pilares{width:100%;border-collapse:collapse}.table-pilares th,.table-pilares td{border:1px solid #dbe5ef;padding:10px 12px;vertical-align:top}.table-pilares th{background:#f8fbff;font-size:12px}.radio-stack label{display:block;margin-bottom:6px;font-size:13px}.alert-ajax{border-radius:16px;border:1px solid var(--line);padding:13px 15px}
.print-shell{padding:24px;font-family:Inter,Arial,sans-serif}.print-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}.print-table{width:100%;border-collapse:collapse}.print-table th,.print-table td{border:1px solid #d0d5dd;padding:8px 10px;font-size:12px}.print-table th{background:#f2f4f7}
@media (max-width:1200px){.kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.choice-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width:991.98px){body{overflow-x:hidden}.sidebar-overlay{display:block;position:fixed;inset:0;background:rgba(2,6,23,.46);opacity:0;pointer-events:none;transition:.25s;z-index:45}.sidebar{position:fixed;left:0;transform:translateX(-100%);width:270px;box-shadow:var(--shadow)}body.sidebar-mobile-open .sidebar{transform:translateX(0)}body.sidebar-mobile-open .sidebar-overlay{opacity:1;pointer-events:auto}.main-content{padding:20px 16px 28px}.page-head{flex-direction:column;align-items:stretch}.header-actions{justify-content:space-between}.kpi-grid,.charts-grid,.grid-2,.grid-3,.choice-grid{grid-template-columns:1fr}.charts-grid .panel:first-child{grid-column:auto}.panel,.paper-form{padding:16px;border-radius:20px}.paper-section-title{width:100%;min-width:0}.table-footer{align-items:flex-start}}
@media (max-width:767.98px){.brand-box h1{font-size:12px}.page-head h2{font-size:18px}.panel-title{font-size:13px}.kpi-card{min-height:auto;padding:16px}.kpi-value{font-size:38px}.kpi-footer{flex-direction:column;align-items:flex-start}.line-group{display:block}.line-group > label{display:block;margin-bottom:6px}.line-group input,.line-group select{width:100%}.table-pilares th,.table-pilares td{padding:8px}.header-actions .btn:not(.btn-icon){width:100%}.header-actions{display:grid;grid-template-columns:1fr}.sidebar{width:86vw;max-width:320px}}


/* --- Colored sidebar icons --- */
.menu-link .menu-icon{width:38px;height:38px;border-radius:12px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);box-shadow:inset 0 1px 0 rgba(255,255,255,.03)}
.menu-link .menu-label{display:inline-flex;align-items:center}
.menu-link .menu-icon-dashboard{background:linear-gradient(135deg,rgba(59,130,246,.18),rgba(37,99,235,.08));border-color:rgba(96,165,250,.22)}
.menu-link .menu-icon-formulario{background:linear-gradient(135deg,rgba(16,185,129,.18),rgba(5,150,105,.08));border-color:rgba(52,211,153,.2)}
.menu-link .menu-icon-dashboard i{color:#60a5fa;text-shadow:0 0 14px rgba(96,165,250,.12)}
.menu-link .menu-icon-formulario i{color:#34d399;text-shadow:0 0 14px rgba(52,211,153,.12)}
.menu-link i{font-size:20px;opacity:1;line-height:1}
.menu-link:hover .menu-icon-dashboard,.menu-link.active .menu-icon-dashboard{background:linear-gradient(135deg,rgba(59,130,246,.26),rgba(37,99,235,.12));border-color:rgba(96,165,250,.35)}
.menu-link:hover .menu-icon-formulario,.menu-link.active .menu-icon-formulario{background:linear-gradient(135deg,rgba(16,185,129,.24),rgba(5,150,105,.12));border-color:rgba(52,211,153,.32)}
body.sidebar-collapsed .menu-link .menu-icon{width:46px;height:46px;border-radius:14px}
body.sidebar-collapsed .menu-link i{font-size:22px}


/* --- Sidebar collapse/mobile fixes --- */
body.sidebar-collapsed .sidebar{width:88px;padding-inline:10px}
body.sidebar-collapsed .brand-copy,
body.sidebar-collapsed .menu-link .menu-label,
body.sidebar-collapsed .sidebar-user .text-muted,
body.sidebar-collapsed .sidebar-user .badge,
body.sidebar-collapsed .sidebar-user .fw-semibold{display:none}
body.sidebar-collapsed .brand-box{justify-content:center;padding-inline:0}
body.sidebar-collapsed .menu-link{justify-content:center;padding:10px 0}
body.sidebar-collapsed .menu-link .menu-icon{width:44px;height:44px;border-radius:14px}
body.sidebar-collapsed .menu-link i{margin:0;font-size:20px}
body.sidebar-collapsed .menu-link::after,body.sidebar-collapsed .sidebar-toggle[data-tooltip]::after{content:attr(data-tooltip);position:absolute;left:calc(100% + 14px);top:50%;transform:translateY(-50%) translateX(-6px);background:#0f172a;color:#fff;padding:8px 11px;border-radius:10px;font-size:12px;font-weight:600;letter-spacing:.01em;white-space:nowrap;box-shadow:0 14px 28px rgba(2,6,23,.18);opacity:0;pointer-events:none;transition:opacity .18s ease,transform .18s ease;z-index:90}
body.sidebar-collapsed .menu-link::before,body.sidebar-collapsed .sidebar-toggle[data-tooltip]::before{content:'';position:absolute;left:calc(100% + 8px);top:50%;transform:translateY(-50%);border:6px solid transparent;border-right-color:#0f172a;opacity:0;transition:opacity .18s ease;z-index:90}
body.sidebar-collapsed .menu-link:hover::after,body.sidebar-collapsed .menu-link:hover::before,body.sidebar-collapsed .sidebar-toggle[data-tooltip]:hover::after,body.sidebar-collapsed .sidebar-toggle[data-tooltip]:hover::before{opacity:1;transform:translateY(-50%) translateX(0)}
body.sidebar-collapsed .sidebar-user{padding:12px 8px}
body.sidebar-collapsed .sidebar-user .btn{padding-inline:0;font-size:0;position:relative}
body.sidebar-collapsed .sidebar-user .btn::before{content:'Sair';font-size:12px}
.main-content{flex:1;min-width:0;padding:28px 28px 40px;transition:padding .25s ease}
.sidebar-user{margin-top:auto;padding:14px 12px;border-radius:18px;background:linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.03));border:1px solid rgba(255,255,255,.08)}

/* --- Restore previous form visual --- */
.paper-form{background:#fff;border:1px solid var(--line);border-radius:28px;padding:24px}
.paper-section-title{position:relative;margin:14px 0 10px;padding:10px 18px;background:linear-gradient(90deg,#4cb5e8,#60c4ee);color:#062036;font-weight:800;border-radius:10px;display:inline-block;min-width:320px;border:none;box-shadow:none}
.paper-box{border:2px solid #40b5eb;border-radius:18px;padding:18px 18px 16px;margin-bottom:16px;background:#fff;box-shadow:none}
.paper-box.no-padding{padding:0;overflow:hidden}
.grid-2,.grid-3{display:grid;gap:14px}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.line-group{display:flex;align-items:end;gap:10px}
.line-group > label{min-width:max-content;font-size:15px;color:var(--text)}
.line-group input,.line-group select{border:none;border-bottom:2px solid #8ba1b7;border-radius:0;padding:8px 4px;background:transparent;width:100%;outline:none;box-shadow:none!important}
.option-line,.option-grid{display:flex;gap:18px;flex-wrap:wrap}
.option-grid label,.option-line label{font-size:15px}
.field-label{display:block;font-size:15px;margin-bottom:8px;color:var(--text)}
.paper-area,.plan-area{width:100%;resize:vertical;border:1px solid #cfe0f1;border-radius:14px;padding:14px 16px;background:#fbfdff;line-height:1.6em;min-height:110px;outline:none;transition:border-color .2s ease, box-shadow .2s ease}
.paper-area:focus,.plan-area:focus{border-color:#4db9ec;box-shadow:0 0 0 4px rgba(77,185,236,.12)}
.plan-area{min-height:140px}
.pillars-table{display:grid;grid-template-columns:1.1fr 1fr 1.4fr;border-radius:inherit;overflow:hidden;background:#fff}
.pillars-col{border-right:1px solid #b6ccde}
.pillars-col:last-child{border-right:0}
.pillars-head{padding:12px 14px;background:#edf5fc;text-transform:uppercase;font-weight:800;text-align:center;border-bottom:1px solid #b6ccde;box-shadow:inset 0 1px 0 rgba(255,255,255,.7)}
.pillars-body{padding:14px;min-height:220px}
.compact-lines .line-group{margin-bottom:10px}
.risk-low{color:#199b59;font-weight:800}.risk-medium{color:#8e4bdd;font-weight:800}.risk-high{color:#d64a4a;font-weight:800}
.causes-grid label{min-width:260px}.actions-grid label{min-width:220px}
.form-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:18px}

@media (max-width:1200px){
  .grid-3,.pillars-table{grid-template-columns:1fr}
  .pillars-table{display:block}
  .pillars-col{border-right:0;border-bottom:1px solid #b6ccde}
  .pillars-col:last-child{border-bottom:0}
}

@media (max-width:991.98px){
  body{overflow-x:hidden}
  .sidebar-overlay{display:block;position:fixed;inset:0;background:rgba(2,6,23,.46);opacity:0;pointer-events:none;transition:.25s;z-index:45}
  .sidebar{position:fixed;left:0;transform:translateX(-100%);width:270px;box-shadow:var(--shadow)}
  body.sidebar-mobile-open .sidebar{transform:translateX(0)}
  body.sidebar-mobile-open .sidebar-overlay{opacity:1;pointer-events:auto}
  .main-content{padding:20px 16px 28px}
  .page-head{flex-direction:column;align-items:stretch}
  .header-actions{justify-content:space-between}
  .kpi-grid,.charts-grid,.grid-2,.grid-3,.choice-grid{grid-template-columns:1fr}
  .charts-grid .panel:first-child{grid-column:auto}
  .panel,.paper-form{padding:16px;border-radius:20px}
  .paper-section-title{width:100%;min-width:0}
  .table-footer{align-items:flex-start}
}

@media (max-width:767.98px){
  .brand-box h1{font-size:12px}.page-head h2{font-size:18px}.panel-title{font-size:13px}.kpi-card{min-height:auto;padding:16px}.kpi-value{font-size:38px}.kpi-footer{flex-direction:column;align-items:flex-start}
  .line-group{display:block}.line-group > label{display:block;margin-bottom:6px}.line-group input,.line-group select{width:100%}
  .header-actions .btn:not(.btn-icon){width:100%}.header-actions{display:grid;grid-template-columns:1fr}.sidebar{width:86vw;max-width:320px}
}


.tooltip .tooltip-inner{background:#0f172a;color:#fff;border-radius:10px;padding:8px 11px;font-size:12px;font-weight:600;box-shadow:0 14px 28px rgba(2,6,23,.18)}
.bs-tooltip-end .tooltip-arrow::before{border-right-color:#0f172a!important}
.bs-tooltip-start .tooltip-arrow::before{border-left-color:#0f172a!important}
.bs-tooltip-top .tooltip-arrow::before{border-top-color:#0f172a!important}
.bs-tooltip-bottom .tooltip-arrow::before{border-bottom-color:#0f172a!important}

.menu-link .menu-icon-usuarios{background:linear-gradient(135deg,rgba(168,85,247,.18),rgba(124,58,237,.08));border-color:rgba(196,181,253,.22)}
.menu-link .menu-icon-usuarios i{color:#c4b5fd;text-shadow:0 0 14px rgba(196,181,253,.12)}
.menu-link:hover .menu-icon-usuarios,.menu-link.active .menu-icon-usuarios{background:linear-gradient(135deg,rgba(168,85,247,.26),rgba(124,58,237,.12));border-color:rgba(196,181,253,.35)}
.user-layout{display:grid;grid-template-columns:minmax(320px,420px) minmax(0,1fr);gap:18px}
.profile-badge{display:inline-flex;align-items:center;justify-content:center;padding:6px 10px;border-radius:999px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;background:#eef2ff;color:#4338ca}
.profile-admin{background:#fee2e2;color:#b91c1c}.profile-gestor{background:#e0f2fe;color:#075985}.profile-supervisor{background:#ede9fe;color:#6d28d9}.profile-operador{background:#dcfce7;color:#166534}.profile-visualizador{background:#f3f4f6;color:#374151}
@media (max-width: 1199.98px){.user-layout{grid-template-columns:1fr}}

/* --- Compact UI refinement: smaller typography, calmer density --- */
body{font-size:14px;line-height:1.45}
.main-content{padding:22px 24px 30px}
.page-head{margin-bottom:14px;gap:14px}
.page-head h2{font-size:16px;font-weight:700;letter-spacing:-.02em}
.page-head p{font-size:12.5px;max-width:680px}
.eyebrow{font-size:9px;letter-spacing:.16em}
.panel{padding:16px 17px;border-radius:20px}
.panel-title{font-size:12.5px}
.panel-head small,.text-muted.small,small.text-muted{font-size:11px!important}
.form-label{font-size:12px;font-weight:600;color:#344054;margin-bottom:6px}
.form-control,.form-select{min-height:40px;padding:8px 12px;font-size:13px;border-radius:12px}
.btn{font-size:12.5px;padding:9px 14px;border-radius:12px}
.btn-sm{font-size:11.5px;padding:7px 11px}
.btn-icon{width:40px;height:40px}
.table-modern thead th{font-size:9.5px;padding:.7rem .65rem}
.table-modern td{font-size:12.5px;padding:.75rem .65rem}
.profile-badge,.badge{font-size:10px}
.sidebar{width:236px;padding:14px 12px 14px}
.brand-mark{width:34px;height:34px;font-size:16px;border-radius:12px}
.brand-box h1{font-size:12px}
.brand-box small{font-size:9.5px}
.menu-nav{gap:6px}
.menu-link{padding:9px 11px;font-size:12px;gap:10px;border-radius:13px}
.menu-link .menu-icon{width:36px;height:36px;border-radius:11px;flex:0 0 36px}
.menu-link i{font-size:19px}
.sidebar-user{padding:11px}
.sidebar-user .fw-semibold{font-size:12px}
.sidebar-user .small,.sidebar-user .text-muted{font-size:10px!important}
.kpi-grid{gap:12px}
.kpi-card{padding:15px;border-radius:20px;min-height:160px;gap:12px}
.kpi-label{font-size:11.5px}
.kpi-subtitle{font-size:10.5px;max-width:200px}
.kpi-icon{width:40px;height:40px;font-size:17px;border-radius:14px}
.kpi-value{font-size:40px}
.kpi-meta,.kpi-footer{font-size:10px}
.kpi-chip{padding:4px 9px;font-size:10px}
.paper-form{padding:20px;border-radius:24px}
.paper-section-title{font-size:12px;padding:9px 16px;min-width:290px}
.paper-box{padding:16px 16px 14px;border-radius:16px}
.line-group label,.field-label,.option-grid label,.option-line label{font-size:13px}
.paper-area,.plan-area{font-size:13px;padding:12px 14px}
.pillars-head{font-size:11px;padding:10px 12px}
.pillars-body{padding:12px;min-height:200px}

/* Users management page */
.user-layout{grid-template-columns:minmax(300px,360px) minmax(0,1fr);gap:16px;align-items:start}
#userForm .col-md-6,#userFilters .col-md-8,#userFilters .col-md-4{margin-bottom:0}
#userForm .form-control,#userForm .form-select,#userFilters .form-control,#userFilters .form-select{min-height:38px;font-size:12.75px}
#userForm .btn,#userFilters .btn{padding:8px 13px}
#usersTableBody .btn{padding:6px 10px;font-size:11.5px;border-radius:999px}
#usersTableInfo{font-size:11px}
.pagination-wrap .btn,.pagination-wrap button{font-size:11px;padding:6px 10px}

@media (max-width:1199.98px){
  .user-layout{grid-template-columns:1fr;gap:14px}
}
@media (max-width:991.98px){
  .main-content{padding:18px 14px 24px}
  .page-head h2{font-size:15px}
  .panel{padding:14px}
  .sidebar{width:82vw;max-width:300px}
}
@media (max-width:767.98px){
  body{font-size:13px}
  .page-head p{font-size:12px}
  .kpi-card{min-height:auto}
  .paper-section-title{min-width:0;width:100%}
  .table-modern td{font-size:12px}
}

/* --- Users page premium refresh --- */
.users-page-head{align-items:center}
.users-shell{display:block}
.users-toolbar-panel{padding:18px 18px 16px;border-radius:24px;background:linear-gradient(180deg,rgba(255,255,255,.96),rgba(250,252,255,.96));border:1px solid rgba(208,217,232,.7)}
.users-toolbar-top{display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap}
.users-stat-chip{display:inline-flex;align-items:center;gap:8px;padding:10px 12px;border-radius:999px;background:linear-gradient(135deg,#eef4ff,#f8fbff);border:1px solid #d9e5ff;color:#34518d;font-size:12px;font-weight:600}
.users-stat-chip i{font-size:14px;color:#1f5eff}
.users-filters-row{display:grid;grid-template-columns:minmax(0,1.6fr) 220px auto;gap:14px;align-items:end}
.search-input-wrap{position:relative}
.search-input-wrap i{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:#7b8ba3;font-size:14px;pointer-events:none}
.search-input-wrap .form-control{padding-left:38px}
.users-filter-actions{display:flex;gap:10px;flex-wrap:wrap}
.users-table-card{border:1px solid #e6edf6;border-radius:22px;overflow:hidden;background:linear-gradient(180deg,#fff,#fbfcff)}
.users-table-responsive{min-height:260px}
.users-table thead th{background:#f7f9fc;font-size:10px;letter-spacing:.1em}
.users-table tbody td{padding-top:.95rem;padding-bottom:.95rem}
.user-main{display:flex;flex-direction:column;gap:4px}
.user-main-name{font-size:13px;font-weight:700;color:#142033}
.user-main-email{font-size:11px;color:#748196}
.users-actions{display:flex;justify-content:flex-end;gap:8px}
.icon-action-btn{width:34px;height:34px;border-radius:12px;border:1px solid #d8e2ee;background:#fff;display:inline-flex;align-items:center;justify-content:center;transition:all .18s ease;box-shadow:0 6px 14px rgba(15,23,42,.04)}
.icon-action-btn i{font-size:15px}
.icon-action-btn.edit{color:#1f5eff}
.icon-action-btn.delete{color:#dc2626}
.icon-action-btn:hover{transform:translateY(-1px);box-shadow:0 12px 20px rgba(15,23,42,.08)}
.icon-action-btn.edit:hover{background:#edf4ff;border-color:#cfe0ff}
.icon-action-btn.delete:hover{background:#fff1f2;border-color:#ffc9cf}
.users-table-footer{padding:12px 16px 14px;border-top:1px solid #eef2f7;background:#fcfdff}
.users-modal .modal-dialog{max-width:760px}
.users-modal .modal-content{border:none;border-radius:28px;box-shadow:0 28px 70px rgba(15,23,42,.18);overflow:hidden;background:linear-gradient(180deg,#ffffff,#fafcff)}
.users-modal .modal-header,.users-modal .modal-footer{padding-left:22px;padding-right:22px}
.users-modal .modal-body{padding:18px 22px 8px}
.users-modal-title{margin:2px 0 0;font-size:20px;font-weight:800;letter-spacing:-.03em;color:#162238}
.users-modal-subtitle{font-size:12.5px}
.users-modal .form-control,.users-modal .form-select{min-height:44px;border-radius:14px;border:1px solid #dce6f3;background:#fbfdff}
.users-modal .form-control:focus,.users-modal .form-select:focus{border-color:#8fb7ff;box-shadow:0 0 0 4px rgba(31,94,255,.12)!important;background:#fff}
.users-password-row{margin-top:0}.users-password-row .form-label{margin-bottom:6px}
.users-modal-tips{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:2px}
.users-tip-card{display:flex;align-items:flex-start;gap:10px;padding:12px 14px;border-radius:16px;background:linear-gradient(135deg,#f6f9ff,#fcfdff);border:1px solid #e2ebf8;color:#4b5a70;font-size:12px;line-height:1.45}
.users-tip-card i{font-size:15px;color:#1f5eff;margin-top:1px}
.profile-badge{padding:5px 9px;font-size:10px;border-radius:999px}

@media (max-width:991.98px){
  .users-filters-row{grid-template-columns:1fr 1fr;}
  .users-filter-actions{grid-column:1 / -1}
}
@media (max-width:767.98px){
  .users-toolbar-panel{padding:14px}
  .users-filters-row{grid-template-columns:1fr}
  .users-profile-filter,.users-search-wrap,.users-filter-actions{grid-column:auto}
  .users-filter-actions .btn{flex:1}
  .users-modal .modal-header,.users-modal .modal-footer,.users-modal .modal-body{padding-left:16px;padding-right:16px}
  .users-modal-tips{grid-template-columns:1fr}
  .users-modal-title{font-size:18px}
}


.menu-link .menu-icon-equipes{background:linear-gradient(135deg,rgba(16,185,129,.18),rgba(5,150,105,.08));border-color:rgba(110,231,183,.22)}
.menu-link .menu-icon-equipes i{color:#6ee7b7;text-shadow:0 0 14px rgba(110,231,183,.10)}
.menu-link:hover .menu-icon-equipes,.menu-link.active .menu-icon-equipes{background:linear-gradient(135deg,rgba(16,185,129,.26),rgba(5,150,105,.12));border-color:rgba(110,231,183,.35)}
.material-free-wrap{display:flex;flex-direction:column;gap:8px}
.material-free-wrap label{font-size:15px;color:var(--text);font-weight:500}
.material-free-area{width:100%;min-height:96px;border:1px solid #cfe0f1;border-radius:14px;padding:12px 14px;background:#fbfdff;resize:vertical;outline:none;transition:border-color .2s ease, box-shadow .2s ease;line-height:1.55}
.material-free-area:focus{border-color:#4db9ec;box-shadow:0 0 0 4px rgba(77,185,236,.12)}
.supervisor-wrap input[readonly]{background:rgba(248,250,252,.9)}


/* --- SisCore logo branding --- */
.brand-box-logo{align-items:center;gap:10px;padding:6px 8px}
.brand-logo,.sidebar .brand-logo{width:142px !important;height:142px !important;max-width:142px;max-height:142px;object-fit:contain;display:block;filter:none;background:transparent;border-radius:0;padding:0;flex:0 0 142px}
.login-branding{display:flex;align-items:center;gap:14px}
.login-logo,img.login-logo{
   width:220px !important;
   height:auto !important;
   max-width:220px;
   max-height:186px;
   object-fit:contain;
   display:block;
   filter:none;
   background:transparent;
   border:none;
   border-radius:0;
   padding:0}

body.sidebar-collapsed .brand-logo{width:34px !important;height:34px !important;max-width:34px;max-height:34px;padding:0;border-radius:0}
body.sidebar-collapsed .brand-box-logo{justify-content:center;padding-inline:0}
@media (max-width:767.98px){
  .login-branding{flex-direction:column;align-items:flex-start;gap:10px}
  .login-logo,img.login-logo{width:96px !important;max-width:96px;max-height:72px}
  .brand-logo,.sidebar .brand-logo{width:38px !important;height:38px !important;max-width:38px;max-height:38px}
}


/* --- Logo centralizado no login e sidebar --- */
.login-branding{
  display:flex;
  justify-content:center;
  align-items:center;
  text-align:center;
  gap:0;
}
.login-logo,img.login-logo{
  width:192px !important;
  max-width:192px;
  max-height:168px;
  margin-inline:auto;
}
.brand-box-logo{
  width:100%;
  justify-content:center;
  align-items:center;
  padding:4px 0 8px;
}
.brand-logo,.sidebar .brand-logo{
  width:154px !important;
  height:auto !important;
  max-width:154px;
  max-height:154px;
  margin-inline:auto;
  flex:0 0 auto;
}
body.sidebar-collapsed .brand-box-logo{
  width:100%;
  justify-content:center;
  padding:2px 0 6px;
}
body.sidebar-collapsed .brand-logo{
  width:142px !important;
  max-width:142px;
  max-height:142px;
}
@media (max-width: 767.98px){
  .login-logo,img.login-logo{width:84px !important;max-width:84px;max-height:62px;}
  .brand-logo,.sidebar .brand-logo{width:48px !important;max-width:48px;max-height:48px;}
}


/* login adjustments */
.login-card{max-width:540px;padding:34px 32px}
.login-branding{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:8px;margin-bottom:20px}
.login-logo,img.login-logo{width:200px !important;max-width:200px;max-height:170px;margin:0 auto;display:block}
.login-credit{font-size:14px;color:#667085;margin-top:0}
.login-credit a{font-weight:700;color:#1d4ed8;text-decoration:none}
.login-credit a:hover{text-decoration:underline}
.btn-login{min-width:194px;padding:.8rem 1.8rem;border-radius:16px;font-size:1.05rem;font-weight:700}
@media (max-width:767.98px){
  .login-card{padding:26px 20px}
  .login-logo,img.login-logo{width:156px !important;max-width:156px;max-height:132px}
  .btn-login{width:100%;min-width:0}
}

/* --- Modern login inspired by provided reference --- */
body:has(.login-page-modern){background:radial-gradient(circle at top,#031033 0%,#02091f 50%,#010616 100%)}
.login-page-modern{min-height:100vh;display:grid;place-items:center;padding:32px 20px;background:transparent}
.login-card-modern{width:min(100%,520px);background:#f8fafc;border:1px solid rgba(148,163,184,.22);border-radius:24px;padding:36px 32px 28px;box-shadow:0 24px 60px rgba(0,0,0,.28)}
.login-branding-modern{display:flex;flex-direction:column;align-items:center;text-align:center;gap:10px;margin-bottom:26px}
.login-logo-modern{width:180px;max-width:68%;height:auto;display:block}
.login-subtitle{margin:0;color:#111827;font-size:15px;line-height:1.45}
.login-form-modern{display:grid;gap:18px}
.login-field{display:grid;gap:8px}
.login-field .form-label{margin:0;font-size:15px;font-weight:800;color:#111827}
.input-icon-wrap{position:relative}
.input-icon{position:absolute;left:18px;top:50%;transform:translateY(-50%);color:#111827;font-size:20px;line-height:1;z-index:2}
.login-input{min-height:56px;border-radius:12px!important;border:1px solid #cbd5e1!important;background:#dfe8f7!important;padding:14px 48px 14px 54px!important;font-size:15px!important;color:#111827!important;box-shadow:none!important}
.login-input::placeholder{color:#526173}
.login-input:focus{border-color:#9bb4e7!important;background:#dfe8f7!important}
.input-icon-wrap-password .login-input{padding-right:54px!important}
.password-toggle{position:absolute;right:14px;top:50%;transform:translateY(-50%);border:0;background:transparent;color:#64748b;width:32px;height:32px;border-radius:8px;display:grid;place-items:center;z-index:2}
.password-toggle:hover{background:rgba(100,116,139,.12);color:#334155}
.login-help-row{display:flex;justify-content:flex-start}
.login-help-link{font-size:13px;color:#2563eb;text-decoration:underline}
.btn-login-modern{min-height:58px;border:none!important;border-radius:14px!important;background:linear-gradient(180deg,#2f63f6 0%,#2148d8 100%)!important;color:#fff!important;font-size:18px!important;font-weight:800!important;display:flex!important;align-items:center;justify-content:center;gap:12px;box-shadow:0 12px 24px rgba(37,99,235,.26)!important;margin-top:2px}
.btn-login-modern:hover{filter:brightness(1.03)}
.login-divider{height:1px;background:#d1d9e6;margin:26px 0}
.login-secondary-action{min-height:44px;border:1.5px solid #9db8ec;border-radius:999px;display:flex;align-items:center;justify-content:center;gap:10px;padding:10px 18px;color:#1d4ed8;background:#f5f8ff;font-size:15px;font-weight:700}
.login-secondary-action:hover{background:#edf4ff;color:#1e40af}
.login-footer-modern{display:flex;justify-content:space-between;align-items:flex-end;gap:12px;margin-top:22px;color:#6b7280}
.login-credit{font-size:13px;line-height:1.4}
.login-credit a{font-weight:800;text-decoration:underline;color:#1f2937}
.login-version{font-size:12px;color:#9ca3af;white-space:nowrap}
#loginAlert .alert-ajax{margin-bottom:16px}

@media (max-width:575.98px){
  .login-card-modern{padding:28px 20px 22px;border-radius:20px}
  .login-logo-modern{width:150px;max-width:72%}
  .login-subtitle{font-size:14px}
  .login-input{min-height:52px;font-size:14px!important}
  .btn-login-modern{min-height:54px;font-size:17px!important}
  .login-secondary-action{font-size:14px;padding-inline:14px}
  .login-footer-modern{flex-direction:column;align-items:flex-start}
}


.multi-select-wrap{display:flex;flex-direction:column;gap:6px}
.multi-dropdown{position:relative;width:100%;z-index:5}
.multi-dropdown-trigger{width:100%;min-height:46px;border:1px solid #bcd7ea;border-radius:14px;padding:10px 14px;background:linear-gradient(180deg,#ffffff 0%,#f7fbff 100%);outline:none;transition:border-color .2s ease, box-shadow .2s ease, background .2s ease;display:flex;align-items:center;justify-content:space-between;gap:10px;color:#0f172a;text-align:left;font:inherit;font-size:14px;font-weight:500}
.multi-dropdown-trigger:hover,.multi-dropdown.open .multi-dropdown-trigger{border-color:#4db9ec;box-shadow:0 0 0 4px rgba(77,185,236,.10);background:#fff}
.multi-dropdown-summary{display:block;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.multi-dropdown-summary-muted{color:#64748b;font-weight:500}
.multi-dropdown-arrow{font-size:11px;color:#64748b;transition:transform .2s ease;flex:0 0 auto}
.multi-dropdown.open .multi-dropdown-arrow{transform:rotate(180deg)}
.multi-dropdown-panel{position:absolute;top:calc(100% + 6px);left:0;right:0;background:#fff;border:1px solid #cfe0f1;border-radius:14px;box-shadow:0 18px 42px rgba(15,23,42,.16);z-index:90;overflow:hidden}
.multi-dropdown-search-wrap{padding:8px 10px;border-bottom:1px solid #e2e8f0;background:#f8fbff}
.multi-dropdown-search{width:100%;min-height:34px;border:0;border-bottom:2px solid #4db9ec;border-radius:0;padding:6px 4px;background:transparent;outline:none;font-size:12px;box-shadow:none!important}
.multi-dropdown-search:focus{border-color:#1d9bf0;box-shadow:none!important}
.multi-dropdown-options{max-height:180px;overflow-y:auto;overflow-x:hidden;padding:4px 6px;scrollbar-width:thin;scrollbar-color:#9fbad3 #eef5fb}
.multi-dropdown-options::-webkit-scrollbar{width:8px}.multi-dropdown-options::-webkit-scrollbar-track{background:#eef5fb;border-radius:999px}.multi-dropdown-options::-webkit-scrollbar-thumb{background:#9fbad3;border-radius:999px}
.multi-dropdown-option{display:flex;align-items:center;gap:8px;padding:4px 8px;margin:0 0 2px;border-radius:8px;cursor:pointer;transition:background .15s ease,color .15s ease;border:1px solid transparent;color:#111827;min-width:0;line-height:1.05;min-height:30px}
.multi-dropdown-option:hover{background:#f8fbff;border-color:#e3eef8}
.multi-dropdown-option input{appearance:none;-webkit-appearance:none;width:13px;height:13px;border:1.5px solid #a9bfd2;border-radius:3px;background:#fff;display:grid;place-items:center;flex:0 0 13px;margin:0}
.multi-dropdown-option input::before{content:'';width:7px;height:7px;transform:scale(0);transition:transform .12s ease-in-out;box-shadow:inset 1em 1em #fff;clip-path:polygon(14% 44%,0 65%,50% 100%,100% 16%,80% 0,43% 62%)}
.multi-dropdown-option input:checked{background:#1f7ae0;border-color:#1f7ae0}
.multi-dropdown-option input:checked::before{transform:scale(1)}
.multi-dropdown-option:has(input:checked){background:#eef7ff;border-color:#cfe6ff}
.multi-dropdown-option-text{display:block;min-width:0;line-height:1.05;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:11px;letter-spacing:.01em}
.multi-dropdown-empty{padding:10px 12px;color:#64748b;font-size:12px}
.helper-text{font-size:12px;color:#64748b}
.pillars-overflow-visible,.pillars-overflow-visible .pillars-table,.pillars-overflow-visible .pillars-col,.pillars-overflow-visible .pillars-body{overflow:visible!important}
@media (max-width:767.98px){.multi-dropdown-panel{position:relative;top:6px}.multi-dropdown-option-text{white-space:normal}}
.evidencias-list{display:flex;flex-wrap:wrap;gap:10px}
.evidencia-chip{display:inline-flex;align-items:center;gap:8px;padding:6px 8px;border-radius:12px;border:1px solid #d6e5f3;background:#f8fbff;max-width:100%}
.evidencia-chip-link{display:inline-flex;align-items:center;gap:8px;color:#1d4ed8;text-decoration:none;min-width:0}
.evidencia-chip-link span{max-width:240px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.evidencia-chip-link small{padding:2px 8px;border-radius:999px;background:#e0ecff;color:#1e40af;font-weight:700}
.evidencia-remove{border:0;background:#fee2e2;color:#b91c1c;width:26px;height:26px;border-radius:999px;display:grid;place-items:center;font-size:18px;line-height:1;cursor:pointer;flex:0 0 auto}
.evidencia-remove:hover{background:#fecaca;color:#991b1b}

.menu-icon-relatorios{background:linear-gradient(135deg,#f59e0b,#f97316)}
.table-actions{display:flex;justify-content:flex-end;align-items:center;gap:.45rem;flex-wrap:nowrap;white-space:nowrap}.table-actions .btn{flex:0 0 auto}
.reports-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:1.2rem}
.report-card-item{position:relative;overflow:hidden;border:1px solid #e7edf5;border-radius:24px;padding:1.15rem;background:linear-gradient(180deg,#ffffff 0%,#fbfcfe 100%);display:flex;flex-direction:column;gap:1rem;box-shadow:0 14px 34px rgba(15,23,42,.06);transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}
.report-card-item::before{content:"";position:absolute;left:0;top:0;width:100%;height:4px;background:linear-gradient(90deg,#dbeafe,#bfdbfe)}
.report-card-item.status-concluido::before{background:linear-gradient(90deg,#22c55e,#86efac)}
.report-card-item.status-pendente::before{background:linear-gradient(90deg,#f59e0b,#fde68a)}
.report-card-item.status-andamento::before{background:linear-gradient(90deg,#2563eb,#93c5fd)}
.report-card-item:hover{transform:translateY(-4px);box-shadow:0 22px 42px rgba(15,23,42,.10);border-color:#d7e3f4}
.report-card-top{display:flex;justify-content:space-between;gap:1rem;align-items:flex-start}
.report-os{font-size:1.9rem;font-weight:800;letter-spacing:-.03em;color:#0f172a;line-height:1.02}
.report-meta-line{font-size:.86rem;color:#64748b;margin-top:.35rem;font-weight:500}
.report-status-badge{display:inline-flex;align-items:center;gap:.42rem;padding:.42rem .82rem;border-radius:999px;font-size:.77rem;font-weight:800;white-space:nowrap;border:1px solid transparent;line-height:1}
.report-status-badge i{font-size:.54rem;opacity:.85}
.report-status-badge.concluido{background:#eaf8ef;color:#15803d;border-color:#d7f0df}
.report-status-badge.pendente{background:#fff6e8;color:#b45309;border-color:#fde6b8}
.report-status-badge.andamento{background:#eaf2ff;color:#2563eb;border-color:#d8e6ff}
.report-card-body.premium-grid{display:grid;grid-template-columns:1fr 1fr;gap:.85rem .95rem}
.report-kv.card-mini{background:#ffffff;border:1px solid #edf2f7;border-radius:16px;padding:.82rem .9rem;min-height:84px;box-shadow:inset 0 1px 0 rgba(255,255,255,.65)}
.report-kv{display:flex;flex-direction:column;gap:.18rem}
.report-kv.full{grid-column:1/-1}
.report-kv span{font-size:.69rem;text-transform:uppercase;letter-spacing:.08em;color:#94a3b8;font-weight:800;margin-bottom:.1rem}
.report-kv strong{font-size:1rem;color:#0f172a;line-height:1.38;font-weight:800}
.report-kv.card-mini strong{display:block}
.cause-box{background:#f8fafc;border-color:#e7edf5;min-height:auto}
.cause-box strong{font-size:1.02rem}
.risk-pill{display:inline-flex;align-items:center;padding:.38rem .68rem;border-radius:999px;font-size:.78rem;font-weight:900;letter-spacing:.01em}
.risk-pill.alto{background:#fdecec;color:#c62828}
.risk-pill.medio{background:#f3e8ff;color:#7c3aed}
.risk-pill.baixo{background:#eafaf0;color:#15803d}
.risk-pill.neutro{background:#eef2f7;color:#475569}
.report-card-actions.premium-actions{display:flex;gap:.55rem;flex-wrap:wrap;margin-top:auto;padding-top:.15rem}
.premium-btn{height:38px;border-radius:12px;padding:0 .92rem;font-size:.8rem;font-weight:800;display:inline-flex;align-items:center;justify-content:center;border-width:1px}
.premium-btn-primary{background:linear-gradient(135deg,#2563eb,#1d4ed8);border:none;box-shadow:0 10px 18px rgba(37,99,235,.18)}
.premium-btn-primary:hover{transform:translateY(-1px)}
.premium-btn-soft{background:#fff;border-color:#dbe3ef;color:#334155}
.premium-btn-soft:hover{background:#f8fbff;border-color:#bfd0e8;color:#0f172a}
.report-shell{background:#fff;border-radius:28px;padding:1.5rem 1.5rem 1.25rem;border:1px solid rgba(148,163,184,.18)}
.report-header-block{display:flex;justify-content:space-between;gap:1rem;align-items:flex-start;padding-bottom:1rem;border-bottom:1px solid rgba(148,163,184,.18);margin-bottom:1rem}
.report-header-block h1{font-size:1.7rem;font-weight:800;color:#0f172a;margin:.15rem 0 .35rem}
.report-header-status{display:flex;align-items:flex-start}
.report-section-block{padding:1rem 0;border-bottom:1px solid rgba(226,232,240,.9)}
.report-section-block:last-of-type{border-bottom:none}
.report-section-block h3{font-size:1rem;font-weight:800;color:#0f172a;margin-bottom:.95rem}
.report-detail-grid{display:grid;gap:.9rem 1rem}
.report-detail-grid.cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.report-detail-grid.cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.report-detail-grid.cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}
.report-detail-grid>div,.report-text-block{background:#f8fafc;border:1px solid rgba(148,163,184,.18);border-radius:18px;padding:.9rem 1rem}
.report-detail-grid span,.report-text-block span{display:block;font-size:.75rem;text-transform:uppercase;letter-spacing:.06em;color:#64748b;font-weight:700;margin-bottom:.35rem}
.report-detail-grid strong{display:block;color:#0f172a;font-size:.98rem;font-weight:700}
.report-text-block p{margin:0;color:#1e293b;line-height:1.6}
.evidencias-report-grid{display:flex;flex-wrap:wrap;gap:.65rem}
.evidence-chip{display:inline-flex;align-items:center;gap:.45rem;padding:.7rem .95rem;border-radius:999px;border:1px solid rgba(59,130,246,.22);background:#eff6ff;color:#1d4ed8;text-decoration:none;font-weight:600}
.evidence-chip:hover{background:#dbeafe;color:#1e40af}
.report-footer-note{display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;padding-top:1rem;color:#475569;font-size:.92rem}
@media (max-width: 991px){.report-detail-grid.cols-4,.report-detail-grid.cols-3,.report-detail-grid.cols-2{grid-template-columns:1fr}.report-card-body.premium-grid{grid-template-columns:1fr}.report-header-block{flex-direction:column}.report-os{font-size:1.55rem}}
@media print{body.sidebar-expanded .sidebar,body .sidebar,.sidebar-overlay,.page-head,.header-actions,.sidebar-user,.sidebar-topbar,.menu-nav,.d-print-none{display:none !important}.main-content{margin:0 !important;padding:0 !important}.report-shell{box-shadow:none;border:none;padding:0}.report-section-block{break-inside:avoid-page}.layout-shell,.main-content{display:block !important}}

/* linhas por risco no dashboard */
.table-modern tbody tr.risk-row > td {
  transition: background-color .18s ease;
}
.table-modern tbody tr.risk-row-low > td {
  background: #eef8f1;
}
.table-modern tbody tr.risk-row-medium > td {
  background: #f4efff;
}
.table-modern tbody tr.risk-row-high > td {
  background: #fff0f0;
}
.table-modern tbody tr.risk-row-low:hover > td {
  background: #e4f3e8;
}
.table-modern tbody tr.risk-row-medium:hover > td {
  background: #ece3ff;
}
.table-modern tbody tr.risk-row-high:hover > td {
  background: #ffe6e6;
}
.table-modern tbody tr.risk-row > td:first-child {
  position: relative;
}
.table-modern tbody tr.risk-row-low > td:first-child {
  box-shadow: inset 4px 0 0 #8fd3a2;
}
.table-modern tbody tr.risk-row-medium > td:first-child {
  box-shadow: inset 4px 0 0 #b8a1ef;
}
.table-modern tbody tr.risk-row-high > td:first-child {
  box-shadow: inset 4px 0 0 #f0a2a2;
}


.conditional-panel{margin-top:16px;padding:16px 18px;border:1px dashed #9fd4ef;border-radius:16px;background:#f7fcff}
.conditional-panel-head{font-size:13px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;color:#1d4b6e;margin-bottom:4px}
.conditional-panel[hidden]{display:none!important}


.toast-container {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 12px;
  pointer-events: none;
  padding: 16px;
}

.floating-toast {
  min-width: 320px;
  max-width: min(420px, calc(100vw - 32px));
  border-radius: 16px;
  padding: 14px 16px;
  box-shadow: 0 18px 40px rgba(15, 23, 42, 0.18);
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
  color: #0f172a;
  background: #ffffff;
  border: 1px solid rgba(148, 163, 184, 0.28);
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  animation: toast-slide-in .22s ease;
  pointer-events: auto;
}

.floating-toast-content {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  flex: 1;
}

.floating-toast-icon {
  width: 24px;
  height: 24px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 800;
  font-size: 0.9rem;
  flex-shrink: 0;
}

.floating-toast-message {
  font-weight: 600;
  line-height: 1.4;
}

.floating-toast-close {
  border: 0;
  background: transparent;
  color: inherit;
  font-size: 1.2rem;
  line-height: 1;
  padding: 0;
  opacity: 0.7;
}

.floating-toast-close:hover {
  opacity: 1;
}

.floating-toast.toast-success {
  background: #ecfdf3;
  border-color: #86efac;
  color: #166534;
}
.floating-toast.toast-success .floating-toast-icon {
  background: #22c55e;
  color: #fff;
}

.floating-toast.toast-error {
  background: #fef2f2;
  border-color: #fca5a5;
  color: #b91c1c;
}
.floating-toast.toast-error .floating-toast-icon {
  background: #ef4444;
  color: #fff;
}

.floating-toast.toast-info,
.floating-toast.toast-warning {
  background: #eff6ff;
  border-color: #93c5fd;
  color: #1d4ed8;
}
.floating-toast.toast-info .floating-toast-icon,
.floating-toast.toast-warning .floating-toast-icon {
  background: #2563eb;
  color: #fff;
}

.floating-toast.is-leaving {
  animation: toast-slide-out .22s ease forwards;
}

@keyframes toast-slide-in {
  from { opacity: 0; transform: translate(-50%, -50%) scale(.96); }
  to { opacity: 1; transform: translate(-50%, -50%) scale(1); }
}

@keyframes toast-slide-out {
  from { opacity: 1; transform: translate(-50%, -50%) scale(1); }
  to { opacity: 0; transform: translate(-50%, -50%) scale(.96); }
}

@media (max-width: 640px) {
  .floating-toast {
    min-width: 0;
    max-width: min(100%, 420px);
  }
}

.material-action-wrap{display:flex;flex-direction:column;gap:10px}
.material-action-toolbar{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.material-summary-card{border:1px solid #d8e6f3;border-radius:16px;padding:12px 14px;font-size:13px;line-height:1.55}
.material-summary-empty{background:#f8fbff;color:#64748b}
.material-summary-filled{background:#fff;color:#0f172a;white-space:pre-wrap}
.material-modal-content{border-radius:22px;border:1px solid #dbe6f2}
.material-modal-textarea{width:100%;min-height:200px;border:1px solid #d4e2ef;border-radius:16px;padding:14px 16px;resize:vertical;outline:none;font-size:14px;line-height:1.6;background:#f8fbff}
.material-modal-textarea:focus{border-color:#4db9ec;box-shadow:0 0 0 4px rgba(77,185,236,.12);background:#fff}
.material-summary-chip{display:inline-flex;align-items:center;gap:8px;padding:6px 10px;border-radius:999px;background:#e8f3ff;color:#1d4ed8;font-weight:700;font-size:12px}


/* --- Cadastros submenu --- */
.menu-icon-cadastros{background:linear-gradient(135deg,rgba(245,158,11,.18),rgba(217,119,6,.08));border-color:rgba(251,191,36,.2)}
.menu-icon-cadastros i{color:#fbbf24;text-shadow:0 0 14px rgba(251,191,36,.12)}
.menu-link:hover .menu-icon-cadastros,.menu-link.active .menu-icon-cadastros,.menu-group.active .menu-icon-cadastros{background:linear-gradient(135deg,rgba(245,158,11,.26),rgba(217,119,6,.12));border-color:rgba(251,191,36,.3)}
.menu-group{display:grid;gap:6px}
.menu-group-toggle{width:100%;justify-content:space-between}
.menu-group-main{display:flex;align-items:center;gap:12px;min-width:0}
.menu-caret{display:inline-flex;align-items:center;justify-content:center;width:18px;color:#94a3b8;transition:transform .2s ease,color .2s ease}
.menu-group.open .menu-caret{transform:rotate(180deg);color:#fff}
.menu-subnav{display:grid;gap:6px;padding-left:50px;max-height:0;overflow:hidden;opacity:0;transition:max-height .25s ease,opacity .2s ease,padding-top .2s ease}
.menu-group.open .menu-subnav{max-height:220px;opacity:1;padding-top:2px}
.menu-sublink{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:12px;color:#aebcd0;font-size:12px;font-weight:600;border:1px solid transparent;transition:all .2s ease}
.menu-sublink i{font-size:14px;color:#7dd3fc}
.menu-sublink:hover,.menu-sublink.active{background:rgba(255,255,255,.06);color:#fff;border-color:rgba(255,255,255,.06)}
.menu-sublink.active{box-shadow:inset 3px 0 0 rgba(125,211,252,.85)}
body.sidebar-collapsed .menu-group{position:relative}
body.sidebar-collapsed .menu-group-toggle{justify-content:center;padding:10px 0}
body.sidebar-collapsed .menu-group-main{justify-content:center;gap:0}
body.sidebar-collapsed .menu-group .menu-caret,body.sidebar-collapsed .menu-subnav{display:none !important}
body.sidebar-collapsed .menu-group-toggle::after{content:attr(data-tooltip);position:absolute;left:calc(100% + 14px);top:50%;transform:translateY(-50%) translateX(-6px);background:#0f172a;color:#fff;padding:8px 11px;border-radius:10px;font-size:12px;font-weight:600;letter-spacing:.01em;white-space:nowrap;box-shadow:0 14px 28px rgba(2,6,23,.18);opacity:0;pointer-events:none;transition:opacity .18s ease,transform .18s ease;z-index:90}
body.sidebar-collapsed .menu-group-toggle::before{content:'';position:absolute;left:calc(100% + 8px);top:50%;transform:translateY(-50%);border:6px solid transparent;border-right-color:#0f172a;opacity:0;transition:opacity .18s ease;z-index:90}
body.sidebar-collapsed .menu-group-toggle:hover::after,body.sidebar-collapsed .menu-group-toggle:hover::before{opacity:1;transform:translateY(-50%) translateX(0)}
@media (max-width:767.98px){.menu-subnav{padding-left:44px}.menu-sublink{font-size:11.5px;padding:8px 10px}}


/* Premium reports page upgrades */
.filter-panel.premium-filter-panel{
  position:relative;
  overflow:hidden;
  border:1px solid #e6eef8;
  background:linear-gradient(180deg,#ffffff 0%,#f9fbff 100%);
  box-shadow:0 16px 34px rgba(15,23,42,.05);
}
.filter-panel.premium-filter-panel::before{
  content:"";
  position:absolute;
  inset:0 auto auto 0;
  width:100%;
  height:4px;
  background:linear-gradient(90deg,#2563eb,#60a5fa 40%,#93c5fd);
}
.reports-filter-form{position:relative;z-index:1}
.filter-intro{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1rem;flex-wrap:wrap}
.filter-copy h3{margin:0;font-size:1rem;font-weight:800;color:#0f172a}
.filter-copy p{margin:.25rem 0 0;font-size:.86rem;color:#64748b}
.filter-chip-group{display:flex;gap:.55rem;flex-wrap:wrap}
.filter-chip{
  display:inline-flex;align-items:center;gap:.45rem;padding:.48rem .8rem;border-radius:999px;
  border:1px solid #dbe7f4;background:#fff;font-size:.76rem;font-weight:700;color:#334155;
  box-shadow:0 6px 14px rgba(15,23,42,.04)
}
.filter-chip i{color:#2563eb}
.premium-filter-panel .form-label{font-size:.76rem;font-weight:800;letter-spacing:.03em;color:#64748b;text-transform:uppercase;margin-bottom:.4rem}
.premium-filter-panel .form-control,
.premium-filter-panel .form-select{
  min-height:48px;border-radius:15px;border:1px solid #d9e6f2;background:#fff;
  box-shadow:inset 0 1px 2px rgba(15,23,42,.03);font-size:.93rem
}
.premium-filter-panel .form-control:focus,
.premium-filter-panel .form-select:focus{
  border-color:#8db6f7;box-shadow:0 0 0 .2rem rgba(37,99,235,.08)
}
.filter-actions-row{display:flex;justify-content:space-between;align-items:center;gap:.9rem;flex-wrap:wrap;margin-top:.2rem}
.filter-results-meta{display:flex;gap:.55rem;flex-wrap:wrap;align-items:center}
.results-pill{
  display:inline-flex;align-items:center;gap:.42rem;padding:.42rem .78rem;border-radius:999px;
  background:#eef4ff;color:#1d4ed8;font-size:.77rem;font-weight:800
}
.results-pill.neutral{background:#f3f6fb;color:#475569}
.reports-grid{align-items:stretch}
.report-card-item{
  min-height:100%;
  animation:cardRise .42s ease both;
}
.report-card-item:nth-child(2){animation-delay:.04s}
.report-card-item:nth-child(3){animation-delay:.08s}
.report-card-item:nth-child(4){animation-delay:.12s}
.report-card-item:nth-child(5){animation-delay:.16s}
.report-card-item:nth-child(6){animation-delay:.2s}
@keyframes cardRise{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.report-card-item::after{
  content:"";position:absolute;right:-48px;bottom:-48px;width:138px;height:138px;border-radius:999px;
  background:radial-gradient(circle,rgba(37,99,235,.08) 0%,rgba(37,99,235,0) 70%);pointer-events:none
}
.report-card-top{padding-bottom:.2rem;border-bottom:1px solid rgba(226,232,240,.72)}
.report-status-badge{box-shadow:0 6px 14px rgba(15,23,42,.05)}
.report-kv.card-mini{background:linear-gradient(180deg,#ffffff 0%,#fdfefe 100%)}
.report-card-actions.premium-actions{padding-top:.65rem;border-top:1px solid rgba(226,232,240,.72)}
.empty-reports-state{
  display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;
  padding:3rem 1.25rem;border:1px dashed #d8e4f1;border-radius:24px;background:linear-gradient(180deg,#fbfdff 0%,#f7faff 100%);
}
.empty-reports-state i{font-size:2rem;color:#94a3b8;margin-bottom:.8rem}
.empty-reports-state h3{margin:0 0 .35rem;font-size:1.1rem;font-weight:800;color:#0f172a}
.empty-reports-state p{margin:0;color:#64748b;max-width:440px}
.pagination-wrap.premium-pagination{justify-content:center;gap:.55rem;padding-top:1.1rem;border-top:1px solid rgba(226,232,240,.82)}
.page-btn{
  min-width:42px;height:42px;display:inline-flex;align-items:center;justify-content:center;border-radius:14px;
  border:1px solid #dbe5f0;background:#fff;font-size:.85rem;font-weight:800;color:#334155;
  box-shadow:0 6px 16px rgba(15,23,42,.04);transition:all .18s ease;text-decoration:none
}
.page-btn:hover{transform:translateY(-1px);border-color:#bfdbfe;color:#1d4ed8;background:#f8fbff}
.page-btn.active{background:linear-gradient(135deg,#2563eb,#1d4ed8);border-color:#1d4ed8;color:#fff;box-shadow:0 12px 20px rgba(37,99,235,.2)}
@media (max-width:991px){
  .filter-intro{flex-direction:column;align-items:flex-start}
}
@media (max-width:767.98px){
  .filter-chip-group,.filter-results-meta{width:100%}
  .filter-actions-row{align-items:stretch}
  .results-pill{justify-content:center}
  .page-btn{min-width:38px;height:38px;border-radius:12px}
}
