:root{
  --bg:#f8fafc;--bg2:#ffffff;--card:#ffffff;--card2:#f1f5f9;--text:#0f172a;--muted:#64748b;--primary:#2563eb;--primary-2:#1d4ed8;--border:rgba(15,23,42,.12);--danger:#ef4444;--success:#10b981;--warning:#f59e0b;--info:#06b6d4;--sidebar:#0f172a;--sidebar-hover:#1e293b;
  --accent1:var(--primary);--accent2:var(--info);--accent3:var(--danger);--accent4:var(--warning);--accent5:#7c3aed;--radius:18px;--font-body:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;--font-display:Syne,Inter,system-ui,sans-serif;--font-mono:'JetBrains Mono',Consolas,monospace;
}
*{box-sizing:border-box}html{min-height:100%;background:var(--bg)}body{margin:0;min-height:100vh;background:var(--bg);color:var(--text);font-family:var(--font-body);font-size:14px;transition:background .18s,color .18s}a{color:var(--primary);text-decoration:none}a:hover{text-decoration:none;filter:brightness(.96)}
body:before{content:"";position:fixed;inset:0;pointer-events:none;z-index:0;background:radial-gradient(circle at top left,color-mix(in srgb,var(--primary) 12%,transparent),transparent 34%),radial-gradient(circle at bottom right,color-mix(in srgb,var(--info) 10%,transparent),transparent 30%)}
button,input,select,textarea,.btn{font-family:inherit}.hidden{display:none!important}.muted{color:var(--muted)}

/* Login padrão GEMM adaptado para o NIP */
.login-page{min-height:100vh;display:grid;grid-template-columns:1.1fr .9fr;position:relative;z-index:1}.login-hero{padding:56px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--sidebar),var(--primary-2));color:#fff;position:relative;overflow:hidden}.login-hero:before{content:"";position:absolute;inset:-20%;background:radial-gradient(circle at 20% 20%,rgba(255,255,255,.18),transparent 28%),radial-gradient(circle at 80% 70%,rgba(20,184,166,.22),transparent 32%)}.login-hero-panel{position:relative;max-width:720px}.hero-kicker{display:inline-flex;border:1px solid rgba(255,255,255,.25);background:rgba(255,255,255,.12);border-radius:999px;padding:7px 12px;font-weight:900;letter-spacing:.08em;text-transform:uppercase;font-size:12px;margin-bottom:18px}.login-hero h1{font-family:var(--font-display);font-size:clamp(34px,4vw,58px);line-height:1.02;margin:0 0 18px;letter-spacing:-.03em}.login-hero p{font-size:18px;line-height:1.6;opacity:.92;max-width:680px}.hero-stats{display:flex;gap:10px;flex-wrap:wrap;margin-top:24px}.hero-stats span{background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.20);padding:10px 12px;border-radius:14px;font-weight:800}.login-card-wrap{display:flex;align-items:center;justify-content:center;padding:28px;background:var(--bg)}.card,.panel,.chart-card,.kpi-card,.filters-card{background:var(--card);border:1px solid var(--border);border-radius:18px;box-shadow:0 12px 30px rgba(15,23,42,.06)}.login-card{width:min(440px,100%);padding:32px}.login-brand-block{margin-bottom:22px}.login-logo-text{font-family:var(--font-display);font-weight:900;font-size:30px;letter-spacing:-.04em}.login-logo-text span{display:inline-flex;background:var(--primary);color:#fff;border-radius:12px;padding:3px 8px;margin-right:4px}.login-logo-sub{color:var(--muted);font-size:13px;margin-top:6px}.login-card h2{font-size:26px;margin:0 0 6px}.login-subtitle{margin:0 0 20px;line-height:1.5}.form-row{display:grid;gap:8px;margin-bottom:14px}label{font-size:13px;font-weight:800;color:var(--text)}input,select,textarea{width:100%;border:1px solid var(--border);border-radius:12px;padding:11px 12px;font:inherit;background:var(--card);color:var(--text);outline:none}input:focus,select:focus,textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px color-mix(in srgb,var(--primary) 16%,transparent)}textarea{min-height:110px;resize:vertical}.password-wrap{position:relative}.password-wrap input{padding-right:46px}.password-toggle{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:transparent!important;border:0;color:var(--muted)!important;padding:4px;font-size:16px;cursor:pointer}.login-submit{width:100%;min-height:46px}.login-note{font-size:12px;color:var(--muted);text-align:center;margin-top:14px}.msg{padding:12px 14px;border-radius:14px;background:color-mix(in srgb,var(--success) 12%,transparent);color:var(--success);border:1px solid color-mix(in srgb,var(--success) 28%,transparent);margin-bottom:14px;font-weight:800}.err{background:color-mix(in srgb,var(--danger) 10%,transparent);color:var(--danger);border-color:color-mix(in srgb,var(--danger) 25%,transparent)}

/* Shell interno padrão GEMM */
.app{position:relative;z-index:1;display:flex;min-height:100vh}.sidebar{width:280px;background:var(--sidebar);color:#cbd5e1;position:fixed;inset:0 auto 0 0;padding:18px;overflow:auto;z-index:40}.brand{color:#fff;font-weight:900;font-size:19px;margin-bottom:22px;display:flex;align-items:center;gap:12px}.brand-mark{display:inline-flex;align-items:center;justify-content:center;width:54px;height:42px;border-radius:16px;background:linear-gradient(135deg,var(--primary),var(--info));font-family:var(--font-display);font-weight:900;color:#fff;box-shadow:0 14px 32px rgba(0,0,0,.18)}.brand small{display:block;color:#94a3b8;font-size:11px;margin-top:2px}.brand-dot{width:13px;height:13px;border-radius:99px;background:var(--primary);box-shadow:0 0 0 6px color-mix(in srgb,var(--primary) 18%,transparent)}.nav{display:grid;gap:6px}.nav a{padding:11px 12px;border-radius:12px;font-weight:800;color:#cbd5e1;display:flex;align-items:center;gap:10px;position:relative}.nav a:hover,.nav a.active{background:var(--sidebar-hover);color:#fff;filter:none}.nav-ico{width:24px;height:24px;display:inline-flex;align-items:center;justify-content:center;border-radius:8px;background:rgba(255,255,255,.08);font-size:13px}.nav a.active .nav-ico{background:color-mix(in srgb,var(--primary) 35%,transparent)}.sidebar-footer{margin-top:24px;border-top:1px solid rgba(255,255,255,.08);padding-top:16px;font-size:12px;color:#94a3b8;display:grid;gap:9px}.role-pill{display:inline-flex;justify-self:start;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.06);border-radius:999px;padding:5px 9px;color:#e2e8f0;font-weight:800}.sidebar-close{display:none}.main{margin-left:280px;width:calc(100% - 280px);padding:24px;position:relative;z-index:1}.topbar{display:flex;justify-content:space-between;align-items:center;gap:14px;margin-bottom:18px}.topbar h1{font-size:28px;margin:0;letter-spacing:-.03em}.topbar p{margin:5px 0 0}.user-pill{background:var(--card);border:1px solid var(--border);border-radius:999px;padding:9px 13px;font-size:13px;color:var(--muted);box-shadow:0 8px 24px rgba(15,23,42,.05);display:flex;gap:8px;align-items:center}.user-pill b{color:var(--text)}.user-pill span{border-left:1px solid var(--border);padding-left:8px;text-transform:capitalize}.page-content{display:grid;gap:18px}.app-footer{display:none}.app-mobile-header{display:none}.sidebar-backdrop{display:none}.app-bottom-nav{display:none}

/* Componentes do NIP */
.section-title{font-size:12px;font-weight:900;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);display:flex;align-items:center;gap:10px;margin:8px 0 14px}.section-title:after{content:"";height:1px;background:var(--border);flex:1}.tag,.badge{display:inline-flex;align-items:center;border-radius:999px;padding:4px 9px;font-size:11px;font-weight:900;background:color-mix(in srgb,var(--primary) 12%,transparent);color:var(--primary)}.badge.red{background:color-mix(in srgb,var(--danger) 12%,transparent);color:var(--danger)}.badge.green{background:color-mix(in srgb,var(--success) 12%,transparent);color:var(--success)}.panel,.chart-card,.kpi-card{padding:18px}.panel h2,.panel h3,.chart-title{margin:0 0 12px;font-size:18px;letter-spacing:-.02em}.grid-2,.grid-3,.grid-4,.kpi-grid{display:grid;gap:16px}.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-4{grid-template-columns:3fr 2fr}.kpi-grid{grid-template-columns:repeat(5,minmax(0,1fr))}.kpi-card{position:relative;overflow:hidden}.kpi-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--primary)}.kpi-label{font-size:11px;color:var(--muted);font-weight:900;letter-spacing:.10em;text-transform:uppercase}.kpi-value{font-size:36px;font-weight:900;margin-top:8px}.kpi-sub,.chart-insight,.smallnote{font-size:13px;color:var(--muted);line-height:1.5}.filters{display:flex;gap:12px;flex-wrap:wrap;align-items:end}.field{display:flex;flex-direction:column;gap:7px;min-width:150px}.field label{color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.08em}.btn,button.btn{border:0;border-radius:12px;padding:11px 14px;font-weight:900;cursor:pointer;background:var(--primary);color:#fff;display:inline-flex;gap:8px;align-items:center;justify-content:center;text-decoration:none}.btn:hover{background:var(--primary-2);filter:none}.btn.secondary{background:var(--card2);color:var(--text);border:1px solid var(--border)}.btn.danger,.btn.red{background:var(--danger);color:#fff}.btn.success{background:var(--success);color:#fff}.btn.small{padding:8px 10px;border-radius:10px;font-size:12px}.table-wrap{overflow:auto;max-height:680px;border-radius:14px;border:1px solid var(--border);background:var(--card)}table,.table,.data-table{width:100%;border-collapse:collapse;background:var(--card);color:var(--text);font-size:13px}th,.table th,.data-table th{position:sticky;top:0;z-index:2;background:var(--card2);color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.06em;text-align:left;padding:12px;border-bottom:1px solid var(--border);white-space:nowrap}td,.table td,.data-table td{padding:11px 12px;border-bottom:1px solid var(--border);vertical-align:top}tr:hover{background:color-mix(in srgb,var(--primary) 4%,transparent)}.total-col,.total-row{background:color-mix(in srgb,var(--primary) 6%,transparent)}.bar-list{display:grid;gap:12px}.bar-row{display:grid;grid-template-columns:1fr auto;gap:8px;align-items:center}.bar-track,.bar{grid-column:1/-1;height:8px;background:color-mix(in srgb,var(--text) 8%,transparent);border-radius:999px;overflow:hidden}.bar-fill,.bar span{display:block;height:100%;background:linear-gradient(90deg,var(--primary),var(--info));border-radius:999px}.chart-wrap{height:320px}.pivot-chart-wrap{height:360px;margin-top:10px}.chart-empty,.empty{color:var(--muted);padding:18px}.clickable{cursor:pointer}.c1 .kpi-value{color:var(--accent1)}.c2 .kpi-value{color:var(--accent2)}.c3 .kpi-value{color:var(--accent3)}.c4 .kpi-value{color:var(--accent4)}.c5 .kpi-value{color:var(--accent5)}
input[type="date"]{cursor:pointer;min-height:42px;color-scheme:light}input[type="date"]::-webkit-calendar-picker-indicator{cursor:pointer;opacity:1;width:20px;height:20px}

/* Seletor de temas estilo GEMM/TweakCN */
#ts-trigger{position:fixed;left:24px;bottom:24px;z-index:1000;width:50px;height:50px;border-radius:50%;border:1px solid var(--border);background:var(--card2);color:var(--text);box-shadow:0 12px 30px rgba(0,0,0,.22);font-size:22px;cursor:pointer}#ts-panel{position:fixed;left:24px;bottom:86px;z-index:999;width:360px;max-height:75vh;overflow:auto;background:var(--card);border:1px solid var(--border);border-radius:18px;box-shadow:0 18px 50px rgba(0,0,0,.35);display:none}#ts-panel.open{display:block}.ts-header{position:sticky;top:0;background:var(--card);z-index:2;display:flex;justify-content:space-between;align-items:center;font-size:12px;font-weight:900;text-transform:uppercase;color:var(--muted);padding:14px 16px;border-bottom:1px solid var(--border)}.ts-header button{border:0;background:transparent;color:var(--muted);font-size:20px;cursor:pointer}.ts-current{font-size:12px;color:var(--muted);padding:12px 16px 0}.ts-search{width:calc(100% - 32px);margin:12px 16px;padding:12px 14px;border-radius:12px}.ts-grid{display:grid;grid-template-columns:1fr;gap:0;padding:0 8px 12px}.ts-card{display:grid;grid-template-columns:72px 1fr;align-items:center;gap:10px;padding:8px;border-radius:12px;background:transparent;border:0;text-align:left;color:var(--text);cursor:pointer}.ts-card:hover{background:var(--card2)}.ts-card.ts-active{background:color-mix(in srgb,var(--primary) 14%,var(--card2))}.ts-preview{height:28px;display:flex;gap:4px}.ts-preview i{flex:1;height:18px;margin-top:5px;border-radius:5px;border:1px solid rgba(0,0,0,.06)}.ts-label{font-size:14px;font-weight:900;color:var(--text)}.ts-note{font-size:11px;color:var(--muted);padding:0 16px 16px}

/* Ajustes específicos para páginas herdadas */
.bi-page{max-width:1680px!important;margin:0 auto}.filters-card,.card{background:var(--card)!important;color:var(--text)!important;border-color:var(--border)!important}.data-table th,.data-table td{border-color:var(--border)!important}.rank-row .num{color:var(--primary)!important}.nav .active,.nav-item.active{background:var(--sidebar-hover)!important;color:#fff!important;box-shadow:none!important}.btn.secondary[formaction],button.secondary{background:var(--card2);color:var(--text);border:1px solid var(--border)}

@media(max-width:1100px){.grid-2,.grid-3,.grid-4,.kpi-grid{grid-template-columns:1fr}.chart-wrap{height:280px}}
@media(max-width:980px){body{padding-bottom:76px}.login-page{grid-template-columns:1fr}.login-hero{display:none}.login-card-wrap{min-height:100vh}.app{display:block}.app-mobile-header{display:flex;position:sticky;top:0;z-index:35;height:62px;background:var(--card);border-bottom:1px solid var(--border);align-items:center;justify-content:space-between;padding:0 14px}.mobile-menu-btn,.app-logout-mini{width:42px;height:42px;border-radius:12px;border:1px solid var(--border);background:var(--card2);color:var(--text);display:inline-flex;align-items:center;justify-content:center;font-size:20px}.mobile-brand{display:flex;align-items:center;gap:10px;font-weight:900}.sidebar{transform:translateX(-104%);transition:transform .18s ease;box-shadow:18px 0 50px rgba(0,0,0,.28)}.mobile-menu-open .sidebar{transform:translateX(0)}.sidebar-close{display:inline-flex;margin-left:auto;width:36px;height:36px;border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.08);color:#fff;border-radius:10px;align-items:center;justify-content:center;font-size:22px}.sidebar-backdrop{display:none;position:fixed;inset:0;background:rgba(15,23,42,.55);z-index:38}.mobile-menu-open .sidebar-backdrop{display:block}.main{margin-left:0;width:100%;padding:16px 12px}.topbar{align-items:flex-start;flex-direction:column}.topbar h1{font-size:24px}.user-pill{display:none}.app-bottom-nav{position:fixed;left:0;right:0;bottom:0;z-index:50;height:68px;background:var(--card);border-top:1px solid var(--border);display:grid;grid-template-columns:repeat(5,1fr);padding:5px max(8px,env(safe-area-inset-left)) calc(5px + env(safe-area-inset-bottom))}.app-bottom-nav a{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;color:var(--muted);font-size:11px;font-weight:800;border-radius:14px}.app-bottom-nav a span{font-size:18px}.app-bottom-nav a em{font-style:normal;white-space:nowrap}.app-bottom-nav a.active{color:var(--primary);background:color-mix(in srgb,var(--primary) 10%,transparent)}#ts-trigger{left:14px;bottom:82px;width:46px;height:46px}#ts-panel{left:12px;right:12px;bottom:136px;width:auto}.filters .field{min-width:100%;}.filters .btn{width:100%;}.table-wrap{max-height:70vh}}
@media(max-width:640px){.login-card{padding:24px 18px;border-radius:28px}.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}.panel{padding:14px}.section-title{letter-spacing:.08em}.kpi-value{font-size:30px}}
@media print{.sidebar,.app-mobile-header,.app-bottom-nav,#ts-trigger,#ts-panel,.topbar,.filters,.no-print,.app-footer{display:none!important}.main{margin:0!important;width:100%!important;padding:0!important}body{background:#fff!important;color:#000!important}.panel,.card,.chart-card,.kpi-card{box-shadow:none!important;border:1px solid #ccc!important}}

/* CRUD com filtros multi-seleção e escolha de colunas */
.crud-filters{align-items:flex-start}
.crud-filters .search-field{min-width:250px;flex:1 1 260px}
.multi-field{min-width:230px;flex:1 1 230px}.columns-field{min-width:260px;flex:1 1 320px}
.multi-select-box{position:relative;width:100%}.multi-select-box summary{position:relative;list-style:none;min-height:46px;border:1px solid var(--border);border-radius:12px;padding:12px 38px 12px 12px;background:var(--card);color:var(--text);cursor:pointer;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.multi-select-box summary::-webkit-details-marker{display:none}.multi-select-box summary:after{content:"⌄";position:absolute;right:14px;top:50%;transform:translateY(-50%);color:var(--muted);font-weight:900}.multi-select-box[open] summary{border-color:var(--primary);box-shadow:0 0 0 3px color-mix(in srgb,var(--primary) 16%,transparent)}.multi-options{position:absolute;left:0;top:calc(100% + 6px);z-index:20;width:min(420px,92vw);max-height:330px;overflow:auto;background:var(--card);border:1px solid var(--border);border-radius:14px;box-shadow:0 18px 42px rgba(15,23,42,.20);padding:8px}.columns-select .multi-options{width:min(560px,92vw);max-height:420px}.check-row{display:flex;align-items:flex-start;gap:9px;padding:8px 9px;border-radius:10px;color:var(--text);font-size:13px;text-transform:none;letter-spacing:0;cursor:pointer}.check-row:hover{background:var(--card2)}.check-row input{width:auto;min-width:16px;margin-top:1px}.check-row span{line-height:1.3}.clear-mini{display:inline-flex;margin:2px 4px 8px;padding:6px 8px;border-radius:9px;background:var(--card2);color:var(--primary);font-weight:900;font-size:12px}.multi-hint{font-size:12px;color:var(--muted);padding:6px 8px 10px;line-height:1.4}.filter-actions{display:flex;gap:12px;flex-wrap:wrap;align-items:end;flex:1 1 100%}.crud-table-wrap{max-height:72vh}.crud-table-wrap td{min-width:130px}.crud-table-wrap th:first-child,.crud-table-wrap td:first-child{position:sticky;left:0;z-index:3;background:var(--card2);min-width:96px}.crud-table-wrap td:first-child{background:var(--card)}.actions-cell{white-space:nowrap}.pagination-line{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
@media(max-width:980px){.multi-field,.columns-field,.crud-filters .search-field{min-width:100%;flex-basis:100%}.filter-actions{display:grid;grid-template-columns:1fr;gap:8px}.multi-options,.columns-select .multi-options{position:static;width:100%;max-height:260px;margin-top:6px;box-shadow:none}.multi-select-box summary:after{top:50%;right:14px}}
.field .check-row{color:var(--text);font-size:13px;text-transform:none;letter-spacing:0;font-weight:700}
.field .check-row span{font-weight:700}

/* ComboBox multi-seleção — substitui o details aberto que expandia a página */
.combo-multi{position:relative;width:100%}
.combo-trigger{width:100%;min-height:46px;border:1px solid var(--border);border-radius:12px;padding:11px 38px 11px 12px;background:var(--card);color:var(--text);display:flex;align-items:center;justify-content:space-between;gap:10px;text-align:left;font-weight:800;cursor:pointer;box-shadow:none;position:relative}
.combo-trigger:hover{border-color:color-mix(in srgb,var(--primary) 45%,var(--border));background:var(--card)}
.combo-trigger[aria-expanded="true"]{border-color:var(--primary);box-shadow:0 0 0 3px color-mix(in srgb,var(--primary) 16%,transparent)}
.combo-text{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}
.combo-arrow{position:absolute;right:13px;top:50%;transform:translateY(-50%);color:var(--muted);font-weight:900;line-height:1}
.combo-multi.open .combo-arrow{transform:translateY(-50%) rotate(180deg)}
.combo-panel{display:none;position:absolute;left:0;top:calc(100% + 8px);z-index:250;width:min(430px,92vw);max-height:360px;overflow:hidden;background:var(--card);border:1px solid var(--border);border-radius:16px;box-shadow:0 22px 55px rgba(15,23,42,.26)}
.combo-multi.open .combo-panel{display:block}
.columns-combo .combo-panel{width:min(590px,92vw);max-height:440px}
.combo-panel-head{position:sticky;top:0;z-index:2;display:grid;grid-template-columns:1fr auto;gap:8px;align-items:center;padding:10px;border-bottom:1px solid var(--border);background:var(--card)}
.combo-search{min-height:38px;padding:9px 10px;border-radius:10px;background:var(--card2)}
.combo-clear{border:1px solid var(--border);border-radius:10px;background:var(--card2);color:var(--text);font-weight:900;padding:9px 10px;cursor:pointer;white-space:nowrap}
.combo-clear:hover{border-color:var(--primary);color:var(--primary)}
.combo-options{max-height:292px;overflow:auto;padding:6px}
.columns-combo .combo-options{max-height:330px}
.combo-option{display:flex!important;align-items:flex-start;gap:10px;padding:9px 10px;border-radius:11px;color:var(--text)!important;font-size:13px!important;line-height:1.35;text-transform:none!important;letter-spacing:0!important;font-weight:800!important;cursor:pointer;min-width:0}
.combo-option:hover{background:var(--card2)}
.combo-option input[type="checkbox"]{appearance:auto!important;width:16px!important;min-width:16px!important;height:16px!important;margin:1px 0 0!important;padding:0!important;border-radius:4px!important;box-shadow:none!important;accent-color:var(--primary)}
.combo-option span{display:block;min-width:0;overflow-wrap:anywhere;font-weight:800!important;color:var(--text)}
.combo-empty{padding:14px 12px;color:var(--muted);font-size:13px}
.combo-panel .multi-hint{padding:10px 12px 4px;color:var(--muted);font-size:12px;line-height:1.45}
.crud-filters{overflow:visible}.panel{overflow:visible}.field.multi-field{overflow:visible}
@media(max-width:980px){.combo-panel,.columns-combo .combo-panel{position:fixed;left:12px;right:12px;top:auto;bottom:82px;width:auto;max-height:min(460px,70vh)}.combo-options,.columns-combo .combo-options{max-height:min(330px,52vh)}}
.combo-actions{display:flex;gap:8px;flex-wrap:wrap;padding:10px 10px 0;background:var(--card)}
.combo-save,.combo-reset{border:1px solid var(--border);border-radius:10px;padding:9px 10px;font-weight:900;cursor:pointer;background:var(--card2);color:var(--text);font-size:12px}
.combo-save{background:var(--primary);border-color:var(--primary);color:#fff}
.combo-save:hover{background:var(--primary-2);border-color:var(--primary-2)}
.combo-reset:hover{border-color:var(--danger);color:var(--danger)}
.columns-panel-head{border-bottom:0}
.filters-combo .combo-panel{width:min(540px,92vw);max-height:440px}
.filters-combo .combo-options{max-height:330px}
@media(max-width:980px){.filters-combo .combo-panel{position:fixed;left:12px;right:12px;top:auto;bottom:82px;width:auto;max-height:min(460px,70vh)}}

.custom-filter-panel{margin-bottom:22px;align-items:flex-start;overflow:visible}
.custom-filter-panel .field{flex:1 1 190px}
.custom-filter-panel .filter-actions{flex:0 1 auto;align-self:flex-end}
.custom-filter-panel .filters-field{flex:1 1 260px}
@media(max-width:980px){.custom-filter-panel .field,.custom-filter-panel .filter-actions{min-width:100%;flex-basis:100%}.custom-filter-panel .filter-actions{display:grid;grid-template-columns:1fr;gap:8px}}


/* Hotfix 2026-05-05: melhora a rolagem dos combos customizados de filtros.
   Antes alguns combos grandes ficavam com rolagem difícil/oculta. Agora o painel inteiro rola,
   cabe na altura da tela e pode abrir para cima/alinhado à direita quando necessário. */
.combo-panel{
  max-height:min(520px, calc(100vh - 140px));
  overflow:auto;
  overscroll-behavior:contain;
  scrollbar-width:thin;
}
.combo-options,
.columns-combo .combo-options,
.filters-combo .combo-options{
  max-height:none;
  overflow:visible;
}
.combo-panel-head{
  position:sticky;
  top:0;
  z-index:5;
}
.combo-actions{
  position:sticky;
  top:59px;
  z-index:4;
  border-bottom:1px solid var(--border);
  padding-bottom:10px;
}
.combo-multi.open-up .combo-panel{
  top:auto;
  bottom:calc(100% + 8px);
}
.combo-multi.align-right .combo-panel{
  left:auto;
  right:0;
}
.combo-multi.align-left .combo-panel{
  left:0;
  right:auto;
}
.filters-combo .combo-panel{
  max-height:min(520px, calc(100vh - 150px));
}
@media(max-width:980px){
  .combo-panel,
  .columns-combo .combo-panel,
  .filters-combo .combo-panel{
    position:fixed;
    left:12px;
    right:12px;
    top:auto;
    bottom:82px;
    width:auto;
    max-height:min(560px, 72vh);
    overflow:auto;
  }
  .combo-multi.open-up .combo-panel,
  .combo-multi.align-right .combo-panel,
  .combo-multi.align-left .combo-panel{
    left:12px;
    right:12px;
    top:auto;
    bottom:82px;
  }
}


/* Hotfix 2026-05-05 v3: transforma o seletor "Filtros da tela" em painel fixo.
   Assim a rolagem acontece dentro do painel, sem depender da rolagem da página. */
body.combo-modal-open{
  overflow:hidden !important;
}
.filters-combo.open .combo-panel{
  position:fixed !important;
  top:96px !important;
  right:24px !important;
  bottom:24px !important;
  left:auto !important;
  width:min(560px, calc(100vw - 330px)) !important;
  min-width:420px !important;
  height:auto !important;
  max-height:none !important;
  display:block !important;
  overflow-y:auto !important;
  overflow-x:hidden !important;
  overscroll-behavior:contain !important;
  z-index:5000 !important;
  box-shadow:0 28px 70px rgba(15,23,42,.34) !important;
}
.filters-combo.open .combo-options{
  max-height:none !important;
  overflow:visible !important;
  padding-bottom:18px !important;
}
.filters-combo.open .combo-panel-head{
  position:sticky !important;
  top:0 !important;
  z-index:8 !important;
}
.filters-combo.open .combo-actions{
  position:sticky !important;
  top:59px !important;
  z-index:7 !important;
  border-bottom:1px solid var(--border) !important;
  padding-bottom:10px !important;
}
.filters-combo.open .combo-option{
  min-height:36px !important;
}
@media(max-width:980px){
  .filters-combo.open .combo-panel{
    left:12px !important;
    right:12px !important;
    top:76px !important;
    bottom:82px !important;
    width:auto !important;
    min-width:0 !important;
    max-height:none !important;
  }
}


/* Hotfix 2026-05-05: resumo visual dos filtros aplicados abaixo da caixa de filtros. */
.active-filter-summary{
  margin:-10px 0 22px;
  padding:14px 16px;
  border:1px solid var(--border);
  border-radius:18px;
  background:color-mix(in srgb, var(--card) 86%, transparent);
  box-shadow:0 12px 32px rgba(15,23,42,.06);
  display:flex;
  align-items:flex-start;
  gap:12px;
  flex-wrap:wrap;
}
.active-filter-title{
  display:flex;
  align-items:center;
  min-height:30px;
  color:var(--muted);
  font-size:11px;
  font-weight:900;
  letter-spacing:2.4px;
  text-transform:uppercase;
  white-space:nowrap;
}
.active-filter-title:before{
  content:"";
  width:8px;
  height:8px;
  border-radius:999px;
  background:var(--accent1);
  box-shadow:0 0 0 4px color-mix(in srgb, var(--accent1) 16%, transparent);
  margin-right:10px;
}
.active-filter-chips{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  flex:1 1 360px;
}
.active-filter-chip{
  display:inline-flex;
  align-items:center;
  max-width:100%;
  min-height:30px;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid color-mix(in srgb, var(--accent1) 28%, var(--border));
  background:color-mix(in srgb, var(--accent1) 10%, var(--card));
  color:var(--text);
  font-size:12px;
  line-height:1.25;
  word-break:break-word;
}
.active-filter-chip b{
  color:var(--accent1);
  margin-right:4px;
}
.active-filter-empty{
  display:inline-flex;
  align-items:center;
  min-height:30px;
  color:var(--muted);
  font-size:13px;
}
@media(max-width:760px){
  .active-filter-summary{margin:-6px 0 18px;padding:12px;gap:10px}
  .active-filter-title{width:100%}
  .active-filter-chips{flex-basis:100%}
  .active-filter-chip{border-radius:12px;align-items:flex-start}
}

/* Hotfix: pesquisa dentro dos comboboxes deve esconder as opções não encontradas. */
.combo-option[hidden], .combo-empty-search[hidden]{display:none!important}
