:root{--bg: #F7F5F2;--surface: #FFFFFF;--surface2: #F2F0ED;--surface3: #E7E3DC;--border: rgba(0, 0, 0, .08);--border2: rgba(0, 0, 0, .14);--text-1: #1A1814;--text-2: #6B6860;--text-3: #A8A59F;--accent: #C95D22;--accent-light: #E07040;--accent-hover: #B14E18;--accent-bg: #FAEFE7;--accent-bg-2: rgba(201, 93, 34, .06);--accent-bd: rgba(201, 93, 34, .22);--green: #2A7D5E;--green-bg: #ECF6F1;--amber: #B57614;--amber-bg: #FBF4E5;--red: #B0392A;--red-bg: #FBEEEA;--blue: #2A5FB0;--blue-bg: #ECF1FB;--sidebar-w: 244px;--sidebar-child-indent: .875rem;--topbar-h: 56px;--radius: 8px;--radius-lg: 14px;--radius-xl: 18px;--shadow-sm: 0 1px 2px rgba(26, 24, 20, .04);--shadow-md: 0 2px 12px rgba(26, 24, 20, .05);--shadow-lg: 0 8px 28px rgba(26, 24, 20, .08);--text: var(--text-1);--muted: var(--text-2);--caption: var(--text-3);--faint: var(--surface3);--teal: var(--accent);--teal-dim: var(--accent-bg);--teal-mid: var(--accent-bd);--ids-orange: var(--accent);--ids-orange-dim: var(--accent-bg);--ids-orange-border: var(--accent-bd);--ids-orange-hover: var(--accent-hover);--neutral: var(--text-2);--neutral-bg: var(--surface3);--display: "Syne", "Outfit", system-ui, sans-serif;--sans: "Instrument Sans", "Outfit", system-ui, sans-serif;--mono: "JetBrains Mono", "IBM Plex Mono", "Courier New", monospace;font-family:var(--sans);font-size:13.5px;color:var(--text-1);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;background:var(--bg);color:var(--text-1)}body{font-family:var(--sans);font-size:13px;line-height:1.45;overflow:hidden}a,.link{color:var(--accent);text-decoration:none}a:hover,.link:hover{text-decoration:underline}.shell{display:flex;height:100vh}.sidebar{width:var(--sidebar-w);min-width:var(--sidebar-w);background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden}.sidebar::-webkit-scrollbar{width:4px}.sidebar::-webkit-scrollbar-thumb{background:var(--surface3);border-radius:2px}.brand-block{padding:18px 18px 14px;border-bottom:1px solid var(--border);flex-shrink:0;display:flex;flex-direction:column;gap:12px}.brand-logo{display:block;width:130px;height:auto;margin-bottom:2px;-webkit-user-select:none;user-select:none;-webkit-user-drag:none}.brand-pill{display:inline-flex;align-items:center;gap:7px;background:var(--accent-bg);border:1px solid var(--accent-bd);color:var(--accent);padding:4px 11px;border-radius:99px;font-family:var(--mono);font-size:10.5px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;align-self:flex-start}.brand-dot{width:6px;height:6px;border-radius:50%;background:var(--accent);flex-shrink:0;box-shadow:0 0 #c95d2266;animation:brand-pulse 2.4s ease-in-out infinite}@keyframes brand-pulse{0%,to{box-shadow:0 0 #c95d2273}50%{box-shadow:0 0 0 5px #c95d2200}}.brand-info{padding:14px 18px 6px}.brand-info h1{font-family:var(--display);font-size:16px;font-weight:700;letter-spacing:-.015em;color:var(--text-1);line-height:1.25}.brand-info p{font-size:11.5px;color:var(--text-3);margin-top:4px;letter-spacing:.01em}.nav-block{padding:12px 12px 4px}.nav-label{font-family:var(--mono);font-size:10px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--text-3);padding:0 10px;margin-bottom:4px;display:block}.nav-section-desc{display:block;font-size:10.5px;font-weight:400;color:var(--text-3);padding:0 10px;margin-bottom:8px;line-height:1.4;opacity:.85}.sidebar-nav{display:flex;flex-direction:column;padding:6px 8px 4px;gap:1px}.nav-group{display:flex;flex-direction:column;border-radius:var(--radius)}.nav-group+.nav-group{margin-top:2px}.nav-group-header{display:flex;align-items:center;gap:8px;width:100%;padding:9px 10px;border:0;background:transparent;cursor:pointer;border-radius:var(--radius);font-family:var(--sans);font-size:12.5px;font-weight:600;letter-spacing:.005em;color:var(--text-1);text-align:left;transition:background .15s,color .15s;-webkit-user-select:none;user-select:none}.nav-group-header:hover{background:var(--surface2)}.nav-group.has-active .nav-group-header{color:var(--text-1)}.nav-group.has-active .nav-group-label:before{content:"";display:inline-block;width:5px;height:5px;border-radius:50%;background:var(--accent);margin-right:8px;vertical-align:middle;margin-bottom:1px}.nav-group-label{flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.nav-group-badge{font-family:var(--mono);font-size:10px;font-weight:500;background:var(--red-bg);color:var(--red);border-radius:4px;padding:1px 6px;flex-shrink:0}.nav-group-chevron{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;color:var(--text-3);transition:transform .2s ease,color .15s;flex-shrink:0}.nav-group-header:hover .nav-group-chevron{color:var(--text-1)}.nav-group.open .nav-group-chevron{transform:rotate(180deg);color:var(--text-2)}.nav-group-body{display:flex;flex-direction:column;gap:1px;margin:0 0 0 4px;border-left:1px solid var(--border);padding:2px 0 6px 8px}.nav-group-body[hidden]{display:none}.nav-group-body .nav-section-desc{font-size:10.5px;color:var(--text-3);padding:4px 8px 6px;margin:0;line-height:1.4}.nav-group-body .nav-item{padding:7px 10px;font-size:12.5px;min-height:30px}.nav-group-body .nav-item.active:before{left:-9px;top:6px;bottom:6px;width:2px}.nav-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--radius);cursor:pointer;color:var(--text-2);font-size:13px;transition:background .15s,color .15s;-webkit-user-select:none;user-select:none;border:0;background:none;text-align:left;width:100%;font-family:var(--sans);min-height:34px;position:relative}.nav-item:hover{background:var(--surface2);color:var(--text-1)}.nav-item.active{background:var(--accent-bg);color:var(--accent);font-weight:600}.nav-item.active:before{content:"";position:absolute;left:-12px;top:7px;bottom:7px;width:3px;border-radius:0 3px 3px 0;background:var(--accent)}.nav-item .n-dot,.nav-item .nav-dot{width:5px;height:5px;border-radius:50%;background:currentColor;flex-shrink:0;opacity:.55}.nav-item.active .n-dot,.nav-item.active .nav-dot{opacity:1}.badge-count{margin-left:auto;font-family:var(--mono);font-size:10px;background:var(--red-bg);color:var(--red);border-radius:4px;padding:1px 6px;font-weight:500}.divider{height:1px;background:var(--border);margin:4px 10px}.sidebar-foot,.sidebar-footer{margin-top:auto;padding:10px 16px 12px;border-top:1px solid var(--border);font-size:10px;color:var(--text-3);flex-shrink:0}.instance-tag{font-family:var(--mono);font-size:10px;color:var(--text-3);display:flex;align-items:center;gap:6px}.pulse{width:6px;height:6px;border-radius:50%;background:var(--accent);animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}.main{flex:1;display:flex;flex-direction:column;min-width:0;overflow:hidden;background:var(--bg)}.topbar{height:var(--topbar-h);flex-shrink:0;display:flex;align-items:center;justify-content:space-between;padding:0 24px;background:#ffffffd9;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-bottom:1px solid var(--border)}.topbar-title{font-family:var(--display);font-size:16px;font-weight:600;letter-spacing:-.01em;color:var(--text-1);display:flex;align-items:center;gap:8px;min-width:0}.topbar-title .crumb,.topbar-title span{color:var(--text-3);font-weight:400;font-family:var(--mono);font-size:11.5px;letter-spacing:.04em}.topbar-right{display:flex;align-items:center;gap:6px}.ts-text,.refresh-label{font-family:var(--mono);font-size:11px;color:var(--text-3);margin-right:10px;letter-spacing:.02em}.tab-btn,.filter-chip{padding:6px 13px;border-radius:var(--radius);font-size:12.5px;font-family:var(--sans);font-weight:500;border:1px solid var(--border2);background:transparent;cursor:pointer;color:var(--text-2);transition:background .15s,color .15s,border-color .15s;min-height:30px;letter-spacing:0}.tab-btn:hover,.filter-chip:hover{background:var(--surface2);color:var(--text-1);border-color:#0003}.tab-btn.active,.filter-chip.active{background:var(--accent-bg);color:var(--accent);border-color:var(--accent-bd);font-weight:600}.tab-btn-clear{margin-left:4px;color:var(--text-3);border-style:dashed}.tab-btn-clear:hover{color:var(--red);border-color:var(--red);background:var(--red-bg)}.sidebar-toggle{display:none;background:var(--surface);border:1px solid var(--border);color:var(--text-1);width:32px;height:32px;border-radius:var(--radius);cursor:pointer;align-items:center;justify-content:center}.content{flex:1;overflow-y:auto;padding:22px 26px 32px;scroll-behavior:smooth}.content::-webkit-scrollbar{width:5px}.content::-webkit-scrollbar-thumb{background:var(--surface3);border-radius:3px}.kpi-row,.kpi-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin-bottom:14px}.kpi-row-3{grid-template-columns:repeat(3,minmax(0,1fr))}.kpi-card-clickable{cursor:pointer}.kpi-card-clickable:hover{border-color:var(--accent);transform:translateY(-1px);box-shadow:0 4px 12px #0000000f}.kpi-card-clickable:hover:before{opacity:1}.kpi-card-clickable:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.kpi-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px 18px;position:relative;overflow:hidden;transition:box-shadow .2s,border-color .2s,transform .2s}.kpi-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--accent);opacity:0;transition:opacity .2s}.kpi-card:hover{box-shadow:var(--shadow-md);border-color:var(--border2)}.kpi-card:hover:before{opacity:1}.kpi-label{font-family:var(--mono);font-size:10px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--text-3);margin-bottom:10px}.kpi-value{font-family:var(--display);font-size:32px;font-weight:700;letter-spacing:-.02em;line-height:1;color:var(--text-1);margin-bottom:10px;min-height:32px}.kpi-value.orange{color:var(--accent)}.kpi-value.green{color:var(--green)}.kpi-value.amber{color:var(--amber)}.kpi-value.red{color:var(--red)}.kpi-sub,.kpi-meta{font-size:11px;color:var(--text-3);display:flex;align-items:center;gap:6px;flex-wrap:wrap;min-height:16px}.trend,.kpi-delta{display:inline-flex;align-items:center;gap:3px;font-size:10px;font-weight:600;padding:2px 6px;border-radius:4px;font-family:var(--sans)}.kpi-delta.up,.trend.up-good{background:var(--green-bg);color:var(--green)}.kpi-delta.down,.trend.down-bad{background:var(--accent-bg);color:var(--accent)}.trend.down-good{background:var(--green-bg);color:var(--green)}.panels-row{display:grid;grid-template-columns:1fr 300px;gap:12px;margin-bottom:12px}.panels-half,.grid2{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px}.grid3{display:grid;grid-template-columns:1fr 300px;gap:12px;margin-bottom:12px}.panel-right{display:flex;flex-direction:column;gap:12px}.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px 18px;overflow:hidden;transition:box-shadow .2s,border-color .2s}.panel:hover{box-shadow:var(--shadow-sm)}.panel-hdr,.panel-header{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:14px;padding:0;border:0}.panel-header.top-border{border-top:1px solid var(--border);margin-top:14px;padding-top:14px}.panel-title{font-family:var(--display);font-size:14px;font-weight:600;letter-spacing:-.005em;color:var(--text-1);display:inline-flex;align-items:baseline;gap:8px}.panel-sub,.panel-tag{font-family:var(--mono);font-size:10.5px;color:var(--text-3);margin-left:6px;letter-spacing:.02em;font-weight:400}.panel-action{font-size:11px;color:var(--accent);cursor:pointer;white-space:nowrap;background:none;border:0;padding:0;font-family:var(--sans)}.panel-action:hover{text-decoration:underline}.full-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px 20px;box-shadow:var(--shadow-sm)}.full-panel-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.full-panel-hdr-left{display:flex;align-items:baseline;gap:0}.full-panel-desc{font-size:13px;color:var(--text-2);line-height:1.6;margin:-4px 0 18px;max-width:880px}.tbl-title{font-family:var(--display);font-size:15px;font-weight:600;letter-spacing:-.01em;color:var(--text-1)}.tbl-badge{font-size:10px;color:var(--text-3);background:var(--surface2);border:1px solid var(--border);border-radius:4px;padding:2px 7px;margin-left:8px;font-family:var(--mono)}.refresh-link{font-size:11.5px;color:var(--accent);cursor:pointer;background:none;border:0;padding:0;font-family:var(--sans)}.refresh-link:hover{text-decoration:underline}.btn-primary{display:inline-flex;align-items:center;gap:6px;height:30px;padding:0 14px;border-radius:var(--radius);font-family:var(--sans);font-size:12.5px;font-weight:600;background:var(--accent);color:#fff;border:1px solid var(--accent);cursor:pointer;white-space:nowrap;transition:background .15s,border-color .15s,transform .15s,box-shadow .15s;letter-spacing:.005em}.btn-primary:hover:not(:disabled){background:var(--accent-hover);border-color:var(--accent-hover);transform:translateY(-1px);box-shadow:0 4px 10px #c95d223d}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-primary:focus-visible{outline:none;box-shadow:0 0 0 3px #c95d224d}.btn-primary:disabled{opacity:.55;cursor:not-allowed}.btn-ghost{display:inline-flex;align-items:center;gap:6px;height:30px;padding:0 14px;border-radius:var(--radius);font-family:var(--sans);font-size:12.5px;font-weight:500;background:var(--surface);color:var(--text-2);border:1px solid var(--border2);cursor:pointer;white-space:nowrap;transition:background .15s,border-color .15s,color .15s}.btn-ghost:hover:not(:disabled){background:var(--surface2);color:var(--text-1);border-color:#0003}.btn-ghost:focus-visible{outline:none;box-shadow:0 0 0 3px #c95d2233}.btn-ghost:disabled{opacity:.5;cursor:not-allowed}.btn-danger{display:inline-flex;align-items:center;gap:6px;height:30px;padding:0 14px;border-radius:var(--radius);font-family:var(--sans);font-size:12.5px;font-weight:600;background:var(--surface);color:var(--red);border:1px solid rgba(176,57,42,.3);cursor:pointer;white-space:nowrap;transition:background .15s,border-color .15s,color .15s}.btn-danger:hover:not(:disabled){background:var(--red-bg);border-color:#b0392a80}.btn-danger:focus-visible{outline:none;box-shadow:0 0 0 3px #b0392a33}.btn-danger:disabled{opacity:.5;cursor:not-allowed}.btn-danger-fill{display:inline-flex;align-items:center;gap:6px;height:30px;padding:0 14px;border-radius:var(--radius);font-family:var(--sans);font-size:12.5px;font-weight:600;background:var(--red);color:#fff;border:1px solid var(--red);cursor:pointer;white-space:nowrap;transition:background .15s,border-color .15s}.btn-danger-fill:hover:not(:disabled){background:#922e21;border-color:#922e21}.btn-danger-fill:focus-visible{outline:none;box-shadow:0 0 0 3px #b0392a47}.btn-danger-fill:disabled{opacity:.5;cursor:not-allowed}.panel-actions-group{display:inline-flex;align-items:center;gap:10px;flex-shrink:0}@media (max-width: 600px){.btn-primary,.btn-ghost,.btn-danger,.btn-danger-fill{height:34px;font-size:13px}}.table-toolbar{display:flex;align-items:center;gap:14px;margin-bottom:14px}.table-search{position:relative;flex:1;max-width:360px;display:flex;align-items:center}.table-search-icon{position:absolute;left:11px;top:50%;transform:translateY(-50%);color:var(--text-3);pointer-events:none;display:flex}.table-search-input{width:100%;height:36px;padding:0 32px;font-family:var(--sans);font-size:13px;color:var(--text-1);background:var(--surface);border:1px solid var(--border2);border-radius:var(--radius);transition:border-color .15s,box-shadow .15s,background .15s}.table-search-input::placeholder{color:var(--text-3)}.table-search-input::-webkit-search-cancel-button{display:none}.table-search-input:hover{border-color:#0003;background:var(--surface2)}.table-search-input:focus{outline:none;background:var(--surface);border-color:var(--accent);box-shadow:0 0 0 3px #c95d2229}.table-search-clear{position:absolute;right:8px;top:50%;transform:translateY(-50%);width:22px;height:22px;border-radius:6px;border:0;background:var(--surface2);color:var(--text-2);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .15s,color .15s}.table-search-clear:hover{background:var(--accent-bg);color:var(--accent)}.table-filter-meta{font-family:var(--mono);font-size:11px;color:var(--accent);background:var(--accent-bg);border:1px solid var(--accent-bd);padding:4px 10px;border-radius:99px;letter-spacing:.02em}.email-log-filter,.events-filter-group{display:inline-flex;align-items:center;gap:8px}.email-log-filter-label,.events-filter-label{font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.12em;color:var(--text-3)}.email-log-filter-select,.events-filter-select{font:inherit;font-size:13px;color:var(--text-1);background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:6px 28px 6px 10px;cursor:pointer;transition:border-color .15s,box-shadow .15s;-webkit-appearance:auto;-moz-appearance:auto;appearance:auto}.email-log-filter-select:focus-visible,.events-filter-select:focus-visible{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #c95d2229}.email-log-error{display:inline-block;max-width:320px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text-2);font-size:12px}.events-context{display:inline-block;max-width:360px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-family:var(--mono);font-size:11px;color:var(--text-3)}.event-legend{display:flex;flex-wrap:wrap;gap:14px 24px;align-items:center;padding:10px 14px;margin:0 0 10px;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);font-size:12px;color:var(--text-2)}.event-legend-item{display:inline-flex;align-items:center;gap:8px}.context-summary{display:inline-block;max-width:360px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;vertical-align:middle;font-size:12px;color:var(--text-2)}.context-toggle{display:inline-flex;align-items:center;gap:6px;background:transparent;border:1px solid transparent;border-radius:6px;padding:2px 8px 2px 6px;font:inherit;text-align:left;color:var(--text-1);cursor:pointer;transition:background .12s,border-color .12s;max-width:100%}.context-toggle:hover{background:var(--accent-bg-2);border-color:var(--accent-bd)}.context-toggle:focus-visible{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #c95d2229}.context-chevron{font-size:11px;color:var(--text-3);flex-shrink:0}.context-toggle[aria-expanded=true] .context-chevron{color:var(--accent)}.context-detail-row>td{background:var(--surface2);border-top:0;padding:10px 14px 14px}.context-detail-json{margin:0;padding:12px 14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);font-family:var(--mono);font-size:11.5px;line-height:1.5;color:var(--text-1);white-space:pre-wrap;word-break:break-word;max-height:400px;overflow:auto}.btn-csv-export{margin-left:auto;font:inherit;font-size:12px;padding:6px 12px;border-radius:8px;border:1px solid var(--border);background:var(--surface);color:var(--text-1);cursor:pointer;transition:border-color .15s,color .15s,background .15s}.btn-csv-export:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.btn-csv-export:disabled{opacity:.5;cursor:not-allowed}.data-table{width:100%;border-collapse:collapse}.data-table th{font-family:var(--mono);font-size:10px;font-weight:500;text-transform:uppercase;letter-spacing:.12em;color:var(--text-3);padding:0 10px 10px;text-align:left;border-bottom:1px solid var(--border);white-space:nowrap;background:transparent}.data-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.data-table th.sortable:hover{color:var(--accent)}.sort-arrow{color:var(--accent);margin-left:3px;font-size:10px}.data-table td{padding:8px;border-bottom:1px solid var(--border);vertical-align:middle;color:var(--text-1);font-size:12.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.data-table tr:last-child td{border-bottom:none}.data-table tr.row-clickable{cursor:pointer}.data-table tbody tr{transition:background .1s}.data-table tbody tr:hover td{background:var(--surface2)}.data-table td.empty-cell{text-align:center;color:var(--text-3);font-style:italic;padding:28px 16px;white-space:normal}.tbl-footer,.raw-foot{font-size:11px;color:var(--text-3);padding:9px 0 0;border-top:1px solid var(--border);margin-top:2px;display:flex;align-items:center;justify-content:space-between;gap:14px}.btn-load-more{font-size:11.5px;font-weight:500;color:var(--accent);background:var(--accent-bg);border:1px solid var(--accent-bd);border-radius:var(--radius);padding:6px 14px;cursor:pointer;font-family:var(--sans);transition:background .15s,transform .15s}.btn-load-more:hover{background:#c95d2224;transform:translateY(-1px)}.btn-load-more:disabled{opacity:.5;cursor:not-allowed;transform:none}.raw-info{color:var(--text-3);font-family:var(--sans)}.raw-scroll,.data-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}.raw-scroll::-webkit-scrollbar,.data-table-wrap::-webkit-scrollbar{height:4px}.raw-scroll::-webkit-scrollbar-thumb,.data-table-wrap::-webkit-scrollbar-thumb{background:#d4d4d8;border-radius:2px}.send-detail-row td{background:var(--surface2);border-bottom:1px solid var(--border);padding:14px 18px;white-space:normal}.detail-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:18px}@media (max-width: 640px){.detail-grid{grid-template-columns:1fr}}.kv{display:flex;flex-direction:column;gap:2px}.kv-k{font-family:var(--mono);font-size:9px;letter-spacing:.08em;color:var(--text-3);text-transform:uppercase}.kv-v{font-size:11px;color:var(--text-1);word-break:break-word}.badge,.status{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:99px;font-size:11px;font-weight:500;white-space:nowrap;font-family:var(--sans)}.badge:before{content:"";width:5px;height:5px;border-radius:50%;background:currentColor;flex-shrink:0}.status .status-dot{width:5px;height:5px;border-radius:50%;background:currentColor;flex-shrink:0}.b-sent,.status.sent{background:var(--green-bg);color:var(--green)}.b-pending,.status.pending{background:var(--amber-bg);color:var(--amber)}.b-bounced,.b-failed,.status.failed{background:var(--red-bg);color:var(--red)}.b-replied{background:var(--blue-bg);color:var(--blue)}.b-unknown,.status.duplicate{background:var(--surface3);color:var(--text-3)}.b-active{background:var(--green-bg);color:var(--green)}.b-warn{background:var(--amber-bg);color:var(--amber)}.b-paid,.b-yes{background:var(--green-bg);color:var(--green)}.b-no{background:var(--surface3);color:var(--text-3)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#1a181473;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;padding:max(24px,env(safe-area-inset-top)) max(24px,env(safe-area-inset-right)) max(24px,env(safe-area-inset-bottom)) max(24px,env(safe-area-inset-left));z-index:1000;animation:modal-fade .12s ease-out}@keyframes modal-fade{0%{opacity:0}to{opacity:1}}.modal-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:0 24px 60px -12px #00000040;width:100%;max-width:880px;max-height:calc(100vh - 48px);max-height:calc(100dvh - 48px);display:flex;flex-direction:column;overflow:hidden}.modal-head{display:flex;align-items:center;gap:12px;padding:14px 18px;border-bottom:1px solid var(--border);background:var(--surface2)}.modal-title{flex:1;display:flex;align-items:baseline;gap:10px;min-width:0}.modal-title-main{font-weight:600;font-size:14px;color:var(--text-1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.modal-title-id{font-size:11px;color:var(--text-3)}.modal-close{background:transparent;border:1px solid var(--border);border-radius:6px;width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;color:var(--text-1);cursor:pointer;transition:background 80ms ease}.modal-close:hover{background:var(--surface3)}.modal-form{display:flex;flex-direction:column;flex:1 1 auto;min-height:0;overflow:hidden}.modal-body{padding:18px;overflow-y:auto;-webkit-overflow-scrolling:touch;background:var(--surface);flex:1 1 auto;min-height:0}.modal-json{background:var(--surface2);border:1px solid var(--border);border-radius:6px;padding:8px 10px;font-size:11px;white-space:pre-wrap;word-break:break-word;max-height:240px;overflow:auto;margin:0}@media (max-width: 640px){.modal-backdrop{padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left)}.modal-card{max-height:100vh;max-height:100dvh;border-radius:0}}.modal-foot{display:flex;align-items:center;gap:8px;padding:12px 18px;border-top:1px solid var(--border);background:var(--surface2);flex-shrink:0}.modal-foot-spacer{flex:1}.delete-confirm-inline{display:flex;align-items:center;gap:10px;flex:1;flex-wrap:wrap}.delete-confirm-msg{font-size:12.5px;color:var(--red);font-weight:500}.delete-confirm-id{font-family:var(--mono);font-size:11px;color:var(--text-3)}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px 20px}.form-field{display:flex;flex-direction:column;gap:5px}.form-field.full-width{grid-column:1 / -1}.form-label{font-family:var(--sans);font-size:11px;font-weight:600;letter-spacing:.02em;color:var(--text-3)}.form-label .form-required,.form-required{color:var(--red);margin-left:3px}.form-section-group+.form-section-group{margin-top:4px}.form-section-title{grid-column:1 / -1;font-family:var(--sans);font-size:11.5px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-3);margin:18px 0 6px;padding-bottom:4px;border-bottom:1px solid var(--border)}.form-section-title--first{margin-top:4px}.form-help{font-size:11px;color:var(--text-3);line-height:1.45;margin-top:1px}.form-input,.form-select,.form-textarea{font-family:var(--sans);font-size:13px;color:var(--text-1);background:var(--surface);border:1px solid var(--border2);border-radius:var(--radius);padding:7px 10px;transition:border-color .15s,box-shadow .15s,background .15s;width:100%}.form-input::placeholder,.form-textarea::placeholder{color:var(--text-3)}.form-input:hover:not(:disabled),.form-select:hover:not(:disabled),.form-textarea:hover:not(:disabled){border-color:#00000038;background:var(--surface2)}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;background:var(--surface);border-color:var(--accent);box-shadow:0 0 0 3px #c95d2229}.form-input:disabled,.form-select:disabled,.form-textarea:disabled{opacity:.6;cursor:not-allowed;background:var(--surface2)}.form-textarea{resize:vertical;min-height:72px;line-height:1.5}.form-checkbox-row{display:flex;align-items:center;gap:9px;padding:8px 0 4px}.form-checkbox{width:16px;height:16px;accent-color:var(--accent);cursor:pointer;flex-shrink:0}.form-checkbox:disabled{opacity:.6;cursor:not-allowed}.form-checkbox-label{font-size:13px;color:var(--text-1);cursor:pointer}.form-field-error{font-size:11.5px;color:var(--red);margin-top:2px}.form-readonly-badge{display:inline-block;font-family:var(--mono);font-size:10px;background:var(--surface2);border:1px solid var(--border);border-radius:4px;padding:6px 10px;color:var(--text-3);letter-spacing:.02em;min-height:34px;line-height:1.4;word-break:break-all}.modal-error{display:flex;align-items:flex-start;gap:8px;background:var(--red-bg);border:1px solid rgba(176,57,42,.24);border-radius:var(--radius);padding:9px 12px;font-size:12.5px;color:var(--red);margin-top:4px;line-height:1.45}@media (max-width: 640px){.form-grid{grid-template-columns:1fr}.form-field.full-width{grid-column:1}.modal-foot{flex-wrap:wrap}.delete-confirm-inline{flex-direction:column;align-items:flex-start}}.tag,.tpl{display:inline-block;padding:2px 8px;border-radius:4px;font-size:10.5px;font-weight:600;letter-spacing:.03em;font-family:var(--sans)}.tag-fac,.tpl.fac{background:var(--accent-bg);color:var(--accent);border:1px solid var(--accent-bd)}.tag-rep,.tpl.rep{background:#d977061f;color:#b45309;border:1px solid rgba(217,119,6,.3)}.tag-oc{background:#3b82f61f;color:#1d4ed8;border:1px solid rgba(59,130,246,.3)}.tag-fpp{background:#8b5cf61f;color:#6d28d9;border:1px solid rgba(139,92,246,.3)}.tag-unknown{background:#94a3b81f;color:var(--text-2);border:1px solid rgba(148,163,184,.25)}.mono{font-family:var(--mono);font-size:11px;color:var(--text-2)}.mono.small{font-size:10px}.text-muted{color:var(--text-3)}.chart-wrap{display:flex;align-items:flex-end;gap:7px;height:72px;margin-top:6px}.bar-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;height:100%}.bar-area{flex:1;display:flex;align-items:flex-end;width:100%}.bar{width:100%;border-radius:3px 3px 0 0;min-height:3px;background:#e4e4e7}.bar.today{background:var(--green)}.bar.current{background:var(--accent)}.bar-day{font-size:9px;color:var(--text-3)}.bar-val{font-size:9px;color:var(--text-2);font-weight:500}.stat-row{display:flex;align-items:center;padding:5px 0;border-bottom:1px solid var(--border);gap:10px}.stat-row:last-child{border-bottom:none}.stat-label{font-size:11px;color:var(--text-2);min-width:62px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.stat-track{flex:1;height:4px;background:#e4e4e7;border-radius:2px;overflow:hidden}.stat-fill{height:100%;border-radius:2px;background:var(--text-3);transition:width .6s ease}.stat-num{font-size:11px;font-weight:500;min-width:16px;text-align:right;color:var(--text-1)}.bar-list{padding:6px 0 0;display:flex;flex-direction:column;gap:0}.bar-item{display:flex;align-items:center;padding:5px 0;border-bottom:1px solid var(--border);gap:10px}.bar-item:last-child{border-bottom:none}.bar-label{font-family:var(--sans);font-size:11px;color:var(--text-2);min-width:62px;text-align:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bar-track{flex:1;height:4px;background:#e4e4e7;border-radius:2px;overflow:hidden}.bar-fill{height:100%;border-radius:2px;transition:width .6s ease}.bar-val{font-family:var(--sans);font-size:11px;font-weight:500;min-width:16px;text-align:right;color:var(--text-1)}.supplier-name{font-weight:500;color:var(--text-1);font-size:12.5px}.supplier-sub{font-size:11px;color:var(--text-2);margin-top:1px;font-family:var(--mono)}.error-item{display:flex;align-items:flex-start;gap:10px;padding:10px 0;border-bottom:1px solid var(--border)}.error-item:last-child{border-bottom:none}.error-icon{width:24px;height:24px;border-radius:6px;background:var(--red-bg);border:1px solid rgba(220,38,38,.2);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px;color:var(--red)}.error-icon svg{width:12px;height:12px}.error-body{min-width:0;flex:1}.error-type{font-family:var(--mono);font-size:10px;color:var(--red);margin-bottom:2px;letter-spacing:.04em;font-weight:500}.error-detail{font-size:12px;color:var(--text-1);margin-bottom:2px;word-break:break-word}.error-meta{font-family:var(--mono);font-size:10px;color:var(--text-3)}.supplier-stat-item{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--border)}.supplier-stat-item:last-child{border-bottom:none}.avatar{width:28px;height:28px;border-radius:6px;background:var(--surface3);display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:10px;color:var(--text-2);flex-shrink:0;font-weight:500}.sstat-name{font-size:12px;font-weight:500;color:var(--text-1)}.sstat-count{font-family:var(--mono);font-size:11px;color:var(--text-3);margin-right:8px}.skeleton-row{height:12px;background:var(--surface3);border-radius:4px;margin:8px 0;animation:shimmer 1.4s infinite}@keyframes shimmer{0%,to{opacity:.4}50%{opacity:.8}}.error-banner{background:var(--red-bg);border:1px solid rgba(220,38,38,.2);border-radius:var(--radius);padding:10px 14px;color:var(--red);font-size:12.5px;margin:8px 0}.empty-state{text-align:center;padding:28px 16px;color:var(--text-3);font-size:12px}.table-stale-strip{display:flex;align-items:center;gap:10px;background:var(--red-bg);border:1px solid rgba(220,38,38,.18);border-radius:var(--radius);padding:6px 12px;color:var(--red);font-size:12px;margin-block-end:8px}.table-stale-strip-msg{flex:1}.table-stale-retry{background:none;border:1px solid rgba(220,38,38,.3);border-radius:var(--radius);color:var(--red);font-size:11.5px;font-family:var(--sans);padding:3px 10px;cursor:pointer;white-space:nowrap}.table-stale-retry:hover{background:#dc262614}.pwa-toast{position:fixed;right:20px;bottom:20px;z-index:50;max-width:360px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:14px 16px;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;gap:12px;animation:pwa-toast-in .25s ease-out}@keyframes pwa-toast-in{0%{transform:translateY(8px);opacity:0}to{transform:translateY(0);opacity:1}}.pwa-toast-body{display:flex;flex-direction:column;gap:4px}.pwa-toast-body strong{font-family:var(--display);font-size:14px;font-weight:600;letter-spacing:-.005em;color:var(--text-1)}.pwa-toast-body span{font-size:12.5px;color:var(--text-2);line-height:1.5}.pwa-toast-actions{display:flex;gap:8px}.pwa-toast-btn{flex:1;height:34px;border-radius:var(--radius);font-family:var(--sans);font-size:12.5px;font-weight:600;cursor:pointer;transition:background .15s,border-color .15s,transform .15s}.pwa-toast-btn.primary{background:var(--accent);color:#fff;border:1px solid var(--accent)}.pwa-toast-btn.primary:hover{background:var(--accent-hover);transform:translateY(-1px)}.pwa-toast-btn.ghost{background:var(--surface);color:var(--text-2);border:1px solid var(--border2)}.pwa-toast-btn.ghost:hover{color:var(--text-1);border-color:#00000038}@media (max-width: 480px){.pwa-toast{right:12px;left:12px;bottom:12px;max-width:none}}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--surface3);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#d4d4d8}.auth-shell{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;padding:32px 24px;color:var(--text-1);background:radial-gradient(900px 600px at 50% 12%,rgba(201,93,34,.06),transparent 65%),radial-gradient(700px 500px at 50% 110%,rgba(26,24,20,.04),transparent 70%),linear-gradient(180deg,#fff,#f7f5f2);padding-top:max(32px,env(safe-area-inset-top));padding-bottom:max(32px,env(safe-area-inset-bottom))}.auth-shell:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background-image:linear-gradient(to right,rgba(26,24,20,.035) 1px,transparent 1px),linear-gradient(to bottom,rgba(26,24,20,.035) 1px,transparent 1px);background-size:56px 56px;mask-image:radial-gradient(ellipse at 50% 50%,#000 25%,transparent 75%);-webkit-mask-image:radial-gradient(ellipse at 50% 50%,#000 25%,transparent 75%)}.auth-stage{position:relative;z-index:1;width:100%;max-width:480px;display:flex;flex-direction:column;align-items:center;gap:32px}.auth-logo{display:block;width:min(320px,78%);height:auto;filter:drop-shadow(0 4px 12px rgba(26,24,20,.08));-webkit-user-select:none;user-select:none;-webkit-user-drag:none}.auth-card{width:100%;background:#fff;border:1px solid rgba(26,24,20,.08);border-radius:14px;padding:44px 36px;box-shadow:0 18px 48px #1a18141a,0 2px 8px #1a18140a;display:flex;flex-direction:column;gap:18px}.auth-alert{display:flex;align-items:flex-start;gap:10px;border:1px solid rgba(220,38,38,.3);border-radius:8px;padding:10px 12px;font-size:13px}.auth-alert-error{background:var(--red-bg, #FEF2F2);color:var(--red, #B0392A)}.auth-alert svg{flex-shrink:0;margin-top:2px}.auth-submit{display:inline-flex;align-items:center;justify-content:center;gap:10px;width:100%;height:56px;border:0;background:var(--accent);color:#fff;border-radius:8px;font-size:17px;font-weight:700;letter-spacing:.01em;cursor:pointer;font-family:var(--sans);transition:background .15s,transform .15s,box-shadow .15s;box-shadow:0 6px 18px #c95d2247}.auth-submit:hover:not(:disabled){background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 10px 24px #c95d225c}.auth-submit:active:not(:disabled){transform:translateY(0)}.auth-submit:focus-visible{outline:none;box-shadow:0 0 0 3px #fff,0 0 0 5px var(--accent)}.auth-submit:disabled{opacity:.65;cursor:not-allowed;box-shadow:none}.auth-spinner{animation:auth-spin .9s linear infinite}@keyframes auth-spin{to{transform:rotate(360deg)}}.auth-footer-credit{margin:0;font-size:13px;text-align:center;color:var(--text-2);letter-spacing:.01em}.auth-footer-credit strong{color:var(--accent);font-weight:600}.auth-loading{display:flex;align-items:center;justify-content:center;height:100vh;background:var(--bg)}.auth-loading-spinner{width:24px;height:24px;border:2px solid var(--surface3);border-top-color:var(--accent);border-radius:50%;animation:auth-spin .9s linear infinite}.mfa-code-row{display:grid;grid-template-columns:repeat(6,1fr);gap:8px;margin:4px 0 6px}.mfa-cell{width:100%;min-width:0;height:56px;text-align:center;font-family:var(--mono);font-size:22px;font-weight:500;color:var(--text-1);background:var(--surface);border:1px solid var(--border2);border-radius:var(--radius);padding:0;caret-color:var(--accent);transition:border-color .15s,box-shadow .15s,background .15s}.mfa-cell:hover{border-color:#00000038;background:var(--surface2)}.mfa-cell:focus{outline:none;background:var(--surface);border-color:var(--accent);box-shadow:0 0 0 3px #c95d2229}.mfa-cell.has-error{border-color:var(--red)}.mfa-meta{display:flex;align-items:center;justify-content:space-between;gap:12px;font-family:var(--mono);font-size:11.5px;color:var(--text-3);margin-top:2px}.mfa-countdown{display:inline-flex;align-items:center;gap:8px;letter-spacing:.02em}.mfa-countdown-dot{width:6px;height:6px;border-radius:50%;background:var(--accent);animation:brand-pulse 2.4s ease-in-out infinite}.mfa-link{font-family:var(--sans);font-size:12px;font-weight:500;color:var(--accent);background:none;border:0;cursor:pointer;padding:0}.mfa-link:hover{text-decoration:underline}.mfa-setup{display:grid;grid-template-columns:1fr auto;gap:18px;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);padding:16px 18px;margin-top:4px}.mfa-setup h3{font-family:var(--display);font-size:14px;font-weight:600;margin-bottom:8px;color:var(--text-1)}.mfa-setup ol{padding-left:18px;font-size:12.5px;color:var(--text-2);margin-bottom:12px;line-height:1.55}.mfa-setup ol li{margin-bottom:4px}.mfa-secret{display:flex;flex-direction:column;gap:4px;background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:8px 10px}.mfa-secret-label{font-family:var(--mono);font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--text-3)}.mfa-secret code{font-family:var(--mono);font-size:12px;letter-spacing:.04em;color:var(--text-1);background:none;padding:0;word-break:break-all}.mfa-qr{width:144px;height:144px;background:var(--surface);border:1px solid var(--border);border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.mfa-qr img{width:132px;height:132px;display:block}.mfa-qr-placeholder{display:flex;align-items:center;gap:8px;font-family:var(--mono);font-size:11px;color:var(--text-3)}.auth-secondary{width:100%;height:38px;background:transparent;color:var(--text-2);border:0;border-radius:var(--radius);font-family:var(--sans);font-size:12.5px;font-weight:500;cursor:pointer;transition:color .15s,background .15s;margin-top:-2px}.auth-secondary:hover{color:var(--text-1);background:var(--surface2)}@media (max-width: 640px){.auth-shell{padding:24px 18px}.auth-stage{gap:26px}.auth-logo{width:min(260px,72%)}.auth-card{padding:32px 24px;border-radius:12px}.auth-submit{height:54px;font-size:16px}}@media (max-width: 480px){.auth-card{padding:26px 20px}.auth-submit{height:52px;font-size:16px}.mfa-cell{height:48px;font-size:18px}.mfa-setup{grid-template-columns:1fr}.mfa-qr{width:100%;height:auto;padding:10px}.mfa-qr img{width:160px;height:160px;margin:0 auto}}.sidebar-user{display:flex;align-items:center;gap:8px;margin-bottom:8px;padding-bottom:8px;border-bottom:1px solid var(--border)}.sidebar-user-info{flex:1;min-width:0}.sidebar-user-name{font-size:11.5px;font-weight:500;color:var(--text-1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-email{font-size:10px;color:var(--text-3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:1px}.role-badge{display:inline-block;margin-top:4px;padding:2px 7px;font-size:9.5px;font-weight:600;letter-spacing:.4px;text-transform:uppercase;border-radius:999px;border:1px solid transparent;line-height:1.3}.role-badge-superadmin{background:#a855f729;color:#c4b5fd;border-color:#a855f766}.role-badge-admin{background:#22c55e24;color:#86efac;border-color:#22c55e66}.sidebar-logout{width:26px;height:26px;border-radius:6px;border:1px solid var(--border2);background:var(--surface);color:var(--text-2);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .1s,color .1s;flex-shrink:0}.sidebar-logout:hover{background:var(--accent-bg);color:var(--accent);border-color:var(--accent-bd)}.sidebar-instance{font-family:var(--mono);font-size:10px;color:var(--text-3)}.sidebar-backdrop{display:none;position:fixed;top:0;right:0;bottom:0;left:0;z-index:15;background:#00000080;border:0;padding:0;margin:0;cursor:pointer;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);-webkit-appearance:none;-moz-appearance:none;appearance:none}.sidebar-close{display:none;position:absolute;top:12px;right:12px;width:36px;height:36px;border-radius:8px;border:1px solid var(--border);background:var(--surface);color:var(--text-2);align-items:center;justify-content:center;cursor:pointer;z-index:1;transition:background .15s,color .15s,border-color .15s}.sidebar-close:hover{background:var(--accent-bg);color:var(--accent);border-color:var(--accent-bd)}@media (max-width: 1024px){.panels-row,.grid3{grid-template-columns:1fr}}@media (max-width: 900px){.kpi-row,.kpi-grid{grid-template-columns:repeat(2,1fr)}.panels-half,.grid2{grid-template-columns:1fr}}@media (max-width: 768px){body{overflow:auto}html,body,#root{height:auto;min-height:100%}.shell{height:auto;min-height:100vh;padding-bottom:env(safe-area-inset-bottom)}.main{overflow:visible}.content{overflow:visible;padding:14px 14px calc(14px + env(safe-area-inset-bottom))}.sidebar{position:fixed;top:0;left:0;width:280px;max-width:86vw;height:100vh;z-index:20;transform:translate(-100%);transition:transform .25s ease;box-shadow:4px 0 24px #00000014;padding-top:env(safe-area-inset-top)}body.sidebar-open .sidebar{transform:translate(0)}.sidebar-toggle{display:inline-flex;width:40px;height:40px}.sidebar-close{display:inline-flex}.sidebar-backdrop{display:block}.topbar{padding:8px 12px calc(8px + env(safe-area-inset-top,0px));padding-top:max(8px,env(safe-area-inset-top,0px));flex-wrap:wrap;height:auto;gap:8px;position:sticky;top:0;z-index:10}.topbar-title{flex:1 1 100%;font-size:14px}.topbar-right{flex:1 1 100%;flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:4px}.topbar-right::-webkit-scrollbar{display:none}.topbar-right .ts-text{display:none}.tab-btn,.filter-chip{flex-shrink:0;min-height:44px;padding:10px 14px}}@media (max-width: 600px){body,input,select,textarea{font-size:16px}.kpi-row,.kpi-grid,.kpi-row-3{grid-template-columns:1fr;gap:8px}.kpi-card{padding:14px 16px}.kpi-label{font-size:13px}.kpi-value{font-size:22px}.kpi-meta,.kpi-sub{font-size:13px}.full-panel{border-radius:var(--radius)}.full-panel-hdr{flex-wrap:wrap;gap:8px}.full-panel-desc{font-size:13px;line-height:1.45}.table-toolbar{flex-direction:column;align-items:stretch;gap:10px}.table-search{max-width:none}.email-log-filter,.events-filter-group{width:100%}.email-log-filter-select,.events-filter-select{flex:1;min-height:38px}.btn-csv-export{margin-left:0;align-self:flex-start;min-height:36px}.table-filter-meta{align-self:flex-start}.data-table-wrap{margin:0 -14px;padding:0 14px}.data-table th,.data-table td{padding-left:8px;padding-right:8px}.data-table th{font-size:12px}.data-table td{font-size:13px}.tbl-footer{flex-direction:column;gap:8px;align-items:stretch}.btn-load-more{min-height:40px}.panel{padding:14px}}@media (hover: none) and (pointer: coarse){.nav-item,.tab-btn,.filter-chip,.btn-load-more,.btn-csv-export,.panel-action,.refresh-link,.sidebar-logout,.table-search-clear{min-height:40px}.nav-group-header,.data-table th.sortable{padding-top:12px;padding-bottom:12px}}#ids-bill-print{display:none}@media print{body>*{display:none!important}body{display:block!important;overflow:visible!important}.modal-backdrop,.modal-card,.modal-body{display:block!important}.modal-head,.modal-foot,.modal-close,.ids-print-btn,.detail-grid{display:none!important}#ids-bill-print{display:block!important;position:static!important;overflow:visible!important;max-height:none!important;width:100%!important;background:#fff!important;color:#000!important;font-family:"Source Sans 3",Instrument Sans,system-ui,sans-serif;font-size:11pt;line-height:1.5;padding:0!important;margin:0!important}#ids-bill-print table{width:100%;border-collapse:collapse}#ids-bill-print th,#ids-bill-print td{border:1px solid #ccc;padding:5px 8px;font-size:10pt}#ids-bill-print th{background:#f5f5f5;font-weight:700;text-align:left}#ids-bill-print .print-total-row td{font-weight:700;font-size:11pt;border-top:2px solid #000}#ids-bill-print .print-muted{color:#666}#ids-bill-print .print-header-meta{margin-bottom:16pt}#ids-bill-print .print-company{font-size:14pt;font-weight:700;margin-bottom:2pt}#ids-bill-print .print-section-title{font-size:9pt;text-transform:uppercase;letter-spacing:.06em;color:#666;border-bottom:1px solid #ccc;padding-bottom:3pt;margin:10pt 0 6pt}@page{margin:18mm 20mm;size:A4 portrait}}.pm-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#1a18148c;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:max(16px,env(safe-area-inset-top)) max(16px,env(safe-area-inset-right)) max(16px,env(safe-area-inset-bottom)) max(16px,env(safe-area-inset-left));z-index:1100;animation:pm-fade-in .22s ease-out both}@keyframes pm-fade-in{0%{opacity:0}to{opacity:1}}@media (prefers-reduced-motion: reduce){.pm-backdrop,.pm-card{animation:none}}.pm-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg),0 0 0 1px #0000000a;width:min(1240px,96vw);max-height:calc(100dvh - 32px);max-height:calc(100vh - 32px);display:flex;flex-direction:column;overflow:hidden;animation:pm-scale-in .22s ease-out both}@keyframes pm-scale-in{0%{opacity:0;transform:scale(.96) translateY(6px)}to{opacity:1;transform:scale(1) translateY(0)}}.pm-head{display:flex;align-items:flex-start;gap:12px;padding:14px 16px 12px;border-bottom:1px solid var(--border);background:var(--surface2);flex-shrink:0}.pm-head-text{flex:1;min-width:0}.pm-head-title{font-size:14px;font-weight:700;color:var(--text-1);line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pm-head-sub{font-size:12px;color:var(--text-3);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pm-close{background:transparent;border:1px solid var(--border);border-radius:6px;width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;color:var(--text-2);cursor:pointer;flex-shrink:0;transition:background 80ms ease,color 80ms ease}.pm-close:hover{background:var(--surface3);color:var(--text-1)}.pm-close:focus-visible{outline:none;box-shadow:0 0 0 3px #c95d2238}.pm-body{padding:14px 16px 18px;overflow-y:auto;-webkit-overflow-scrolling:touch;flex:1 1 auto;min-height:0}.pm-kpi-strip{display:flex;align-items:center;flex-wrap:wrap;gap:.25rem .75rem}.pm-kpi-item{display:inline-flex;align-items:baseline;gap:.3rem}.pm-kpi-label{font-size:10.5px;font-family:var(--mono);font-weight:500;text-transform:uppercase;letter-spacing:.07em;color:var(--text-3)}.pm-kpi-value{font-size:13.5px;font-weight:700;color:var(--text-1);font-family:var(--mono);letter-spacing:-.01em}.pm-kpi-value--accent{color:var(--accent)}.pm-kpi-sep{color:var(--border2);font-size:14px;font-weight:300;line-height:1;-webkit-user-select:none;user-select:none}.pm-kpi-comprobante{margin-inline-start:auto;display:flex;align-items:center;gap:.4rem}.pm-kpi-comprobante-label{font-size:11px;font-weight:600;color:var(--text-3);white-space:nowrap;letter-spacing:.01em}.pm-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;margin-bottom:16px}.pm-summary-cell{background:var(--surface2);padding:10px 12px;display:flex;flex-direction:column;gap:3px}.pm-summary-label{font-size:10px;font-family:var(--mono);font-weight:500;text-transform:uppercase;letter-spacing:.08em;color:var(--text-3)}.pm-summary-value{font-size:14px;font-weight:700;color:var(--text-1);font-family:var(--mono);letter-spacing:-.01em}.pm-summary-value.accent{color:var(--accent)}.pm-divider{height:1px;background:var(--border);margin:12px 0}.pm-field{display:flex;flex-direction:column;gap:5px;margin-bottom:12px}.pm-field:last-child{margin-bottom:0}.pm-label{font-size:11.5px;font-weight:600;color:var(--text-2);letter-spacing:.01em}.pm-required{color:var(--red);margin-left:2px}.pm-amount-wrap{position:relative;display:flex;align-items:center}.pm-amount-prefix{position:absolute;left:10px;font-size:12.5px;font-weight:600;color:var(--text-2);pointer-events:none;white-space:nowrap;-webkit-user-select:none;user-select:none;z-index:1}.pm-amount-input{width:100%;height:36px;padding:0 10px 0 60px;font-family:var(--mono);font-size:13.5px;font-weight:600;color:var(--text-1);background:var(--surface);border:1px solid var(--border2);border-radius:6px;transition:border-color .15s,box-shadow .15s;box-sizing:border-box}.pm-amount-input::placeholder{color:var(--text-3);font-weight:400}.pm-amount-input:hover{border-color:#00000038;background:var(--surface2)}.pm-amount-input:focus{outline:none;background:var(--surface);border-color:var(--accent);box-shadow:0 0 0 2.5px #c95d222e}.pm-amount-input:disabled{opacity:.55;cursor:not-allowed;background:var(--surface2)}.pm-input{width:100%;height:36px;padding:0 10px;font-family:var(--sans);font-size:13px;color:var(--text-1);background:var(--surface);border:1px solid var(--border2);border-radius:6px;transition:border-color .15s,box-shadow .15s,background .15s;box-sizing:border-box}.pm-input::placeholder{color:var(--text-3)}.pm-input:hover:not(:disabled){border-color:#00000038;background:var(--surface2)}.pm-input:focus{outline:none;background:var(--surface);border-color:var(--accent);box-shadow:0 0 0 2.5px #c95d222e}.pm-input:disabled{opacity:.55;cursor:not-allowed;background:var(--surface2)}.pm-foot{display:flex;align-items:center;gap:8px;padding:12px 16px;border-top:1px solid var(--border);background:var(--surface2);flex-shrink:0}.pm-foot-spacer{flex:1}.pm-error{display:flex;align-items:flex-start;gap:8px;background:var(--red-bg);border:1px solid rgba(176,57,42,.24);border-radius:var(--radius);padding:8px 12px;font-size:12px;color:var(--red);line-height:1.45;margin-top:4px}@media (max-width: 768px){.pm-card{width:100%;max-height:100dvh;max-height:100vh;border-radius:var(--radius-lg) var(--radius-lg) 0 0;margin-top:auto;align-self:flex-end}.pm-backdrop{padding:0;align-items:flex-end}.pm-body{padding:16px}.pm-kpi-strip{flex-wrap:wrap;gap:.4rem .5rem}.pm-kpi-comprobante{margin-inline-start:0}.pm-kpi-comprobante-label{display:none}.pm-summary{grid-template-columns:1fr;gap:0}}.am-card{width:min(520px,96vw)}.am-summary{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:14px}.am-summary-cell{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);padding:9px 12px;display:flex;flex-direction:column;gap:3px}.am-summary-label{font-size:10px;font-family:var(--mono);font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-3)}.am-summary-value{font-size:13.5px;font-weight:700;color:var(--text-1);font-family:var(--mono);letter-spacing:-.01em}.am-summary-value--accent{color:var(--accent)}.am-confirm-msg{font-size:12.5px;color:var(--text-2);line-height:1.5;margin:0}.am-btn-confirm{display:inline-flex;align-items:center;justify-content:center;gap:.35rem;padding:0 1.25rem;height:36px;border-radius:var(--radius);border:none;background:#c75b12;color:#fff;font-size:13px;font-weight:700;font-family:var(--font-heading, "Barlow Semi Condensed", sans-serif);letter-spacing:.01em;cursor:pointer;transition:background .12s ease,opacity .12s ease;white-space:nowrap}.am-btn-confirm:hover:not(:disabled){background:#a84a0f}.am-btn-confirm:focus-visible{outline:none;box-shadow:0 0 0 3px #c75b1252}.am-btn-confirm:disabled{opacity:.55;cursor:not-allowed}@media (max-width: 768px){.am-card{width:100%}.am-summary{grid-template-columns:1fr}.am-btn-confirm{width:100%}}.table-stale-strip{display:flex;align-items:center;gap:10px;background:var(--amber-bg);border:1px solid rgba(181,118,20,.28);border-radius:var(--radius);padding:7px 12px;margin-bottom:10px;font-size:12.5px}.table-stale-strip-msg{color:var(--amber);flex:1}.table-stale-retry{background:none;border:none;cursor:pointer;color:var(--accent);font-size:12.5px;font-weight:600;padding:0;font-family:var(--sans)}.table-stale-retry:hover{text-decoration:underline}.ipm-panel{margin-top:1.25rem;padding:1rem 1.125rem;border:1px solid rgba(199,91,18,.2);border-radius:var(--radius);background:var(--accent-bg)}.ipm-header{display:flex;align-items:baseline;justify-content:space-between;flex-wrap:wrap;gap:.25rem .75rem;margin-bottom:.875rem}.upload-page{min-height:100vh;background:var(--bg);display:flex;align-items:center;justify-content:center;padding:24px 16px}.upload-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);padding:32px 28px;width:100%;max-width:480px;display:flex;flex-direction:column;gap:20px}.upload-drop-zone{border:2px dashed var(--accent-bd);border-radius:var(--radius-lg);background:var(--accent-bg-2);padding:36px 24px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;text-align:center;cursor:pointer;transition:border-color .15s ease,background .15s ease;color:var(--text-2);font-size:13px;line-height:1.5}.upload-drop-zone:hover{border-color:var(--accent);border-style:solid;background:var(--accent-bg);color:var(--text-1)}.upload-drop-zone.dragging{border-color:var(--accent);border-style:solid;background:var(--accent-bg);color:var(--text-1);box-shadow:0 0 0 4px #c95d221a}.upload-btn-primary{display:flex;align-items:center;justify-content:center;gap:8px;height:56px;width:100%;border-radius:var(--radius-lg);background:var(--accent);color:#fff;border:none;font-family:var(--sans);font-size:15px;font-weight:700;letter-spacing:.01em;cursor:pointer;transition:background .15s ease,transform .15s ease,box-shadow .15s ease}.upload-btn-primary:hover:not(:disabled){background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 6px 18px #c95d2247}.upload-btn-primary:active:not(:disabled){transform:translateY(0)}.upload-btn-primary:focus-visible{outline:none;box-shadow:0 0 0 3px #c95d224d}.upload-btn-primary:disabled{opacity:.55;cursor:not-allowed}.upload-success{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;padding:40px 24px;text-align:center;color:var(--green)}.upload-success-icon{width:56px;height:56px;border-radius:50%;background:var(--green-bg);display:flex;align-items:center;justify-content:center;animation:uploadSuccessBounce .5s cubic-bezier(.34,1.56,.64,1) both}.bulk-drop-zone{min-height:240px;border:2px dashed var(--accent-bd);border-radius:var(--radius-lg);background:var(--accent-bg-2);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:40px 32px;text-align:center;cursor:pointer;transition:border-color .15s ease,background .15s ease,box-shadow .15s ease;color:var(--text-2);font-size:13.5px}.bulk-drop-zone:hover{border-color:var(--accent);border-style:solid;background:var(--accent-bg);color:var(--text-1)}.bulk-drop-zone.dragging{border-color:var(--accent);border-style:solid;background:var(--accent-bg);color:var(--text-1);box-shadow:0 0 0 5px #c95d221a}.bulk-processing-steps{display:flex;flex-direction:column;gap:8px;margin-top:8px}.bulk-step{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface);font-size:12.5px;color:var(--text-3);transition:border-color .15s ease,background .15s ease,color .15s ease}.bulk-step.active{border-color:var(--accent-bd);background:var(--accent-bg);color:var(--accent);font-weight:600}.bulk-step.done{border-color:#2a7d5e38;background:var(--green-bg);color:var(--green)}.section-label{font-family:var(--mono);font-size:10px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--text-3);display:block;margin-bottom:8px}.bill-row{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:12px 16px;cursor:pointer;transition:border-color .15s ease,box-shadow .15s ease,background .15s ease;margin-bottom:4px}.bill-row:hover{border-color:var(--border2);box-shadow:var(--shadow-sm)}.bill-row.expanded{border-color:var(--accent-bd);background:var(--accent-bg-2);box-shadow:var(--shadow-md)}.bill-row-timeline{display:flex;flex-direction:column;gap:0;margin-top:12px;padding-top:12px;border-top:1px solid var(--border);padding-left:8px;border-left:2px solid var(--accent-bd);margin-left:4px}.bill-timeline-item{display:flex;align-items:flex-start;gap:10px;padding:6px 0;font-size:12px;color:var(--text-2);line-height:1.4;position:relative}.bill-timeline-item+.bill-timeline-item{border-top:1px dashed var(--border)}.email-preview-wrapper{display:flex;flex-direction:column;gap:12px;width:100%}.email-preview-frame{width:100%;height:480px;border:1px solid var(--border);border-radius:var(--radius);background:#fff;transition:width .2s ease,height .2s ease;overflow:hidden}.email-preview-frame.mobile{width:375px;height:640px;margin:0 auto;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg)}.reminder-config-section{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px 18px;display:flex;flex-direction:column;gap:14px}.reminder-stepper{display:flex;align-items:center;gap:4px;border:1px solid var(--border2);border-radius:var(--radius);background:var(--surface);overflow:hidden;width:fit-content}.reminder-stepper button{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:none;border:none;cursor:pointer;color:var(--text-2);font-size:16px;font-family:var(--sans);transition:background .15s ease,color .15s ease}.reminder-stepper button:hover{background:var(--surface2);color:var(--accent)}.reminder-stepper button:active{background:var(--surface3)}@media print{.sidebar,.topbar,.no-print{display:none!important}.shell{display:block}.main{margin:0}.content{padding:0;overflow:visible}.data-table{font-size:11px}}@keyframes uploadSuccessBounce{0%{transform:scale(0)}60%{transform:scale(1.2)}to{transform:scale(1)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.ipm-header-left{display:flex;align-items:baseline;gap:.5rem;flex-wrap:wrap}.ipm-title{font-size:12px;font-weight:700;letter-spacing:.005em;color:var(--text-1);text-transform:uppercase;font-family:var(--mono)}.ipm-badge{display:inline-block;padding:.125rem .5rem;border-radius:99px;background:#c75b121f;border:1px solid var(--accent-bd);color:var(--accent);font-size:11px;font-weight:700;font-family:var(--mono);letter-spacing:-.005em}.ipm-hint{font-size:11.5px;color:var(--text-3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:260px}.rpf-row{display:flex;flex-wrap:wrap;gap:.625rem;align-items:flex-end}.rpf-label{display:block;font-size:11px;font-weight:600;color:var(--text-2);margin-bottom:4px;white-space:nowrap;letter-spacing:.01em}.rpf-cell{display:flex;flex-direction:column;min-width:0}.rpf-cell--monto{flex:0 0 130px;min-width:110px}.rpf-cell--fecha{flex:0 0 148px;min-width:120px}.rpf-cell--cuenta{flex:1 1 140px;min-width:120px}.rpf-cell--ref{flex:1 1 160px;min-width:120px}.rpf-cell--submit{flex:0 0 auto}.rpf-confirm-btn{display:inline-flex;align-items:center;gap:5px;padding:0 1rem;border-radius:6px;border:none;background:#c75b12;color:#fff;font-family:var(--sans);font-size:13px;font-weight:600;cursor:pointer;white-space:nowrap;letter-spacing:.005em;transition:background .14s,transform .13s,box-shadow .13s}.rpf-confirm-btn:hover:not(:disabled){background:#a84a0e;transform:translateY(-1px);box-shadow:0 3px 8px #c75b1247}.rpf-confirm-btn:active:not(:disabled){transform:translateY(0)}.rpf-confirm-btn:focus-visible{outline:none;box-shadow:0 0 0 3px #c75b1247}.rpf-confirm-btn:disabled{opacity:.55;cursor:not-allowed}@media (max-width: 768px){.rpf-row{flex-direction:column;gap:.5rem}.rpf-cell--monto,.rpf-cell--fecha,.rpf-cell--cuenta,.rpf-cell--ref,.rpf-cell--submit{flex:none;width:100%}.rpf-confirm-btn{width:100%;justify-content:center;height:40px}.ipm-hint{display:none}}@media (hover: none) and (pointer: coarse){.ids-iec-pencil{opacity:1!important}.ids-inline-edit-input{font-size:16px;min-height:44px}}@media (hover: none) and (pointer: coarse){[role=banner] button[type=button]{min-height:44px;padding-block:.5rem}}@media (max-width: 480px){[role=banner]>div:last-child{flex-wrap:wrap;gap:.5rem}[role=banner]>div:last-child>span,[role=banner]>div:last-child>button{flex:1 1 100%;justify-content:center}.tendencias-grid>*{min-width:0!important;flex:1 1 100%!important}.general-main-grid{grid-template-columns:1fr!important}}@media (max-width: 480px){input[type=search],input[type=text],input[type=email],input[type=number]{font-size:16px!important}}@media (max-width: 480px){[role=dialog][aria-modal=true]{width:100vw!important;max-width:100vw!important;border-radius:0!important}.bdm-actions{flex-direction:column}.bdm-actions>button,.bdm-actions>a{width:100%;justify-content:center;min-height:44px}}@media (hover: none) and (pointer: coarse){[role=dialog] button[type=button]{min-height:44px}}@media (hover: none) and (pointer: coarse){.ids-alert-row-actions button{min-height:44px;padding:.5rem .75rem}}@media (hover: none) and (pointer: coarse){section[aria-label="Verificaciones preventivas"] button[type=button]{min-height:44px}}@media (hover: none) and (pointer: coarse){.bill-pagination button,.non-responding-pagination button{min-height:44px;min-width:44px}}@media (max-width: 480px){.bill-filter-bar{flex-direction:column;align-items:stretch}.bill-search-wrap{width:100%}.bill-search-wrap input{width:100%;min-width:0!important}}@media (max-width: 480px){body,.content{overflow-x:hidden}}@media (prefers-reduced-motion: reduce){.ids-iec-pencil{transition:none}}.role-guard-denied{display:flex;align-items:center;justify-content:center;min-height:240px;padding:var(--space-4, 1rem)}.role-guard-denied__message{color:var(--text-2);font-size:.95rem;text-align:center}.empresa-shell{display:flex;height:100vh;overflow:hidden}.empresa-shell__main{flex:1;display:flex;flex-direction:column;overflow:hidden}.empresa-shell__topbar{display:flex;align-items:center;gap:12px;height:var(--topbar-h);padding-inline:16px;background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0}.empresa-shell__topbar-title{font-weight:600;font-size:.9rem;color:var(--text-1);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.empresa-shell__not-found{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;min-height:300px;padding:2rem;text-align:center}.empresa-shell__not-found h2{font-size:1.2rem;color:var(--text-1)}.empresa-shell__not-found p{color:var(--text-2);max-width:420px}.superadmin-shell{display:flex;height:100vh;overflow:hidden}.superadmin-shell__main{flex:1;display:flex;flex-direction:column;overflow:hidden}.superadmin-shell__topbar{display:flex;align-items:center;gap:12px;height:var(--topbar-h);padding-inline:16px;background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0}.superadmin-shell__topbar-title{font-weight:600;font-size:.9rem;color:var(--text-1)}.empresa-sidebar{width:var(--sidebar-w);min-width:var(--sidebar-w);background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden}.empresa-sidebar__header{padding:16px;border-bottom:1px solid var(--border);flex-shrink:0}.empresa-sidebar__back{background:none;border:none;cursor:pointer;color:var(--color-primary, var(--accent));font-size:.8rem;padding:0;margin-bottom:10px;display:block}.empresa-sidebar__back:hover{text-decoration:underline}.empresa-sidebar__empresa-name{font-weight:700;font-size:.88rem;color:var(--text-1);line-height:1.3;margin-bottom:4px}.empresa-sidebar__rfc{font-size:.75rem;color:var(--text-3)}.empresa-sidebar__nav{flex:1;padding:8px 0}.empresa-sidebar__list{list-style:none}.empresa-sidebar__item{margin:2px 8px}.empresa-sidebar__link{display:flex;align-items:center;gap:10px;width:100%;padding:8px 10px;border:none;background:none;cursor:pointer;border-radius:var(--radius);color:var(--text-2);font-size:.85rem;text-align:left;transition:background .15s,color .15s}.empresa-sidebar__link:hover{background:var(--surface2);color:var(--text-1)}.empresa-sidebar__link--active{background:color-mix(in srgb,var(--color-primary, var(--accent)) 10%,transparent);color:var(--color-primary, var(--accent));font-weight:600}.empresa-sidebar__icon{font-size:.9rem;flex-shrink:0}.empresa-sidebar__footer{padding:12px 16px;border-top:1px solid var(--border);flex-shrink:0}.empresa-sidebar__global-link{background:none;border:none;cursor:pointer;color:var(--text-3);font-size:.8rem;padding:0}.empresa-sidebar__global-link:hover{color:var(--text-2);text-decoration:underline}.superadmin-sidebar{width:var(--sidebar-w);min-width:var(--sidebar-w);background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden}.superadmin-sidebar__header{padding:16px;border-bottom:1px solid var(--border);flex-shrink:0}.superadmin-sidebar__title{font-weight:700;font-size:.9rem;color:var(--text-1);margin-bottom:4px}.superadmin-sidebar__subtitle{font-size:.75rem;color:var(--text-3)}.superadmin-sidebar__nav{flex:1;padding:8px 0}.superadmin-sidebar__list{list-style:none}.superadmin-sidebar__item{margin:2px 8px}.superadmin-sidebar__link{display:flex;align-items:center;gap:10px;width:100%;padding:8px 10px;border:none;background:none;cursor:pointer;border-radius:var(--radius);color:var(--text-2);font-size:.85rem;text-align:left;transition:background .15s,color .15s}.superadmin-sidebar__link:hover{background:var(--surface2);color:var(--text-1)}.superadmin-sidebar__link--active{background:var(--accent-bg);color:var(--accent);font-weight:600}.superadmin-sidebar__icon{font-size:.9rem;flex-shrink:0}.superadmin-sidebar__footer{padding:12px 16px;border-top:1px solid var(--border);flex-shrink:0}.superadmin-sidebar__global-link{background:none;border:none;cursor:pointer;color:var(--text-3);font-size:.8rem;padding:0}.superadmin-sidebar__global-link:hover{color:var(--text-2);text-decoration:underline}.empresa-switcher{padding:32px 24px;max-width:860px}.empresa-switcher__header{margin-bottom:24px}.empresa-switcher__title{font-size:1.4rem;font-weight:700;color:var(--text-1);margin-bottom:6px}.empresa-switcher__subtitle{color:var(--text-2);font-size:.9rem}.empresa-switcher__list{list-style:none;display:flex;flex-direction:column;gap:12px}.empresa-switcher__list-item{display:block}.empresa-switcher__empty{color:var(--text-2);padding:24px 0}.empresa-switcher__superadmin-notice{margin-top:32px;padding-top:16px;border-top:1px solid var(--border)}.empresa-card{display:flex;align-items:stretch;width:100%;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;text-align:left;overflow:hidden;transition:box-shadow .15s,border-color .15s;padding:0}.empresa-card:hover{box-shadow:var(--shadow-md);border-color:var(--color-primary, var(--accent))}.empresa-card__color-strip{width:6px;flex-shrink:0}.empresa-card__body{flex:1;padding:16px}.empresa-card__name{font-weight:700;font-size:.95rem;color:var(--text-1);margin-bottom:4px}.empresa-card__rfc{font-size:.78rem;color:var(--text-3);margin-bottom:4px}.empresa-card__depts{font-size:.78rem;color:var(--text-2)}.empresa-card__arrow{display:flex;align-items:center;padding-inline:16px;color:var(--text-3);font-size:1.1rem}.empresa-dashboard{padding:28px 24px;max-width:960px}.empresa-dashboard__header{margin-bottom:28px}.empresa-dashboard__title{font-size:1.3rem;font-weight:700;color:var(--text-1);margin-bottom:6px}.empresa-dashboard__rfc{font-size:.8rem;color:var(--text-3);margin-bottom:4px}.empresa-dashboard__depts{font-size:.82rem;color:var(--text-2)}.empresa-dashboard__kpis{margin-bottom:32px}.empresa-dashboard__kpi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px}.empresa-dashboard__section-title{font-size:1rem;font-weight:700;color:var(--text-1);margin-bottom:14px}.empresa-dashboard__module-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}.empresa-dashboard__quick-link{display:flex;flex-direction:column;align-items:flex-start;gap:6px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px 16px;cursor:pointer;text-align:left;transition:box-shadow .15s,border-color .15s}.empresa-dashboard__quick-link:hover{box-shadow:var(--shadow-md);border-color:var(--color-primary, var(--accent))}.empresa-dashboard__quick-link-label{font-weight:700;font-size:.9rem;color:var(--text-1)}.empresa-dashboard__quick-link-desc{font-size:.78rem;color:var(--text-2);line-height:1.4}.empresa-module{padding:28px 24px;max-width:1000px}.empresa-module__header{margin-bottom:20px}.empresa-module__title{font-size:1.15rem;font-weight:700;color:var(--text-1);margin-bottom:6px}.empresa-module__scope{font-size:.82rem;color:var(--text-2)}.empresa-module__empty{color:var(--text-2);padding:24px 0}.empresa-module__table-wrapper{overflow-x:auto;border:1px solid var(--border);border-radius:var(--radius)}.empresa-module__table{width:100%;border-collapse:collapse;font-size:.84rem}.empresa-module__table th,.empresa-module__table td{padding:10px 14px;text-align:left;border-bottom:1px solid var(--border)}.empresa-module__table th{font-weight:600;color:var(--text-2);background:var(--surface2)}.empresa-module__table tr:last-child td{border-bottom:none}.empresa-module__footer{margin-top:16px}.empresa-module__disclaimer{font-size:.75rem;color:var(--text-3)}.superadmin-monitor{padding:28px 24px;max-width:1100px}.superadmin-monitor__header{margin-bottom:28px}.superadmin-monitor__title{font-size:1.4rem;font-weight:700;color:var(--text-1);margin-bottom:8px}.superadmin-monitor__subtitle{color:var(--text-2);font-size:.9rem;margin-bottom:14px}.superadmin-monitor__summary-pills{display:flex;gap:8px;flex-wrap:wrap}.superadmin-monitor__pill{display:inline-flex;align-items:center;padding:4px 12px;border-radius:100px;background:var(--surface2);color:var(--text-2);font-size:.78rem;font-weight:600}.superadmin-monitor__pill--green{background:var(--green-bg);color:var(--green)}.superadmin-monitor__section{margin-bottom:40px}.superadmin-monitor__section-title{font-size:1rem;font-weight:700;color:var(--text-1);margin-bottom:6px}.superadmin-monitor__section-desc{font-size:.82rem;color:var(--text-2);margin-bottom:14px}.superadmin-monitor__table-wrapper{overflow-x:auto;border:1px solid var(--border);border-radius:var(--radius)}.superadmin-monitor__table-wrapper--scroll{overflow-x:scroll}.superadmin-monitor__table{width:100%;border-collapse:collapse;font-size:.84rem}.superadmin-monitor__table th,.superadmin-monitor__table td{padding:10px 14px;text-align:left;border-bottom:1px solid var(--border)}.superadmin-monitor__table th{font-weight:600;color:var(--text-2);background:var(--surface2)}.superadmin-monitor__table tr:last-child td{border-bottom:none}.superadmin-monitor__table--matrix td{text-align:center}.superadmin-monitor__empresa-dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-inline-end:8px;vertical-align:middle;flex-shrink:0}.superadmin-monitor__matrix-cell{text-align:center}.superadmin-monitor__matrix-check{font-size:1rem;font-weight:700}.superadmin-monitor__matrix-empty{color:var(--text-3)}.superadmin-monitor__footer{margin-top:8px}.superadmin-monitor__disclaimer{font-size:.75rem;color:var(--text-3)}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:var(--radius);border:none;cursor:pointer;font-size:.84rem;font-weight:600;transition:background .15s}.btn--primary{background:var(--accent);color:#fff}.btn--primary:hover{background:var(--accent-hover)}.btn--ghost{background:transparent;color:var(--text-2);border:1px solid var(--border2)}.btn--ghost:hover{background:var(--surface2);color:var(--text-1)}.btn--sm{padding:4px 10px;font-size:.78rem}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}@media (max-width: 768px){.empresa-sidebar,.superadmin-sidebar{position:fixed;inset-block:0;inset-inline-start:0;z-index:200;transform:translate(-100%);transition:transform .25s ease;box-shadow:var(--shadow-lg)}body.sidebar-open .empresa-sidebar,body.sidebar-open .superadmin-sidebar{transform:translate(0)}}.error-boundary-panel{display:flex;align-items:center;justify-content:center;min-height:240px;padding:32px}.error-boundary-panel__inner{background:var(--surface);border:1px solid var(--border2);border-radius:var(--radius-lg);padding:32px 40px;max-width:520px;text-align:center;box-shadow:var(--shadow-md)}.error-boundary-panel__title{font-family:var(--display);font-size:18px;font-weight:700;color:var(--text-1);margin-bottom:10px}.error-boundary-panel__message{font-size:13px;color:var(--text-2);margin-bottom:20px;line-height:1.55;font-family:var(--mono);background:var(--surface2);border-radius:var(--radius);padding:8px 12px}.department-shell{display:flex;height:100%;background:var(--bg)}.department-shell__main{flex:1;display:flex;flex-direction:column;min-width:0;overflow:hidden}.department-shell__topbar{display:flex;align-items:center;gap:12px;padding:0 20px;height:var(--topbar-h);background:#ffffffd9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid var(--border);flex-shrink:0}.department-shell__topbar-title{font-family:var(--display);font-size:15px;font-weight:600;color:var(--text-1)}.department-shell__not-found{padding:48px 32px;text-align:center;color:var(--text-2)}.department-shell__not-found h2{font-family:var(--display);font-size:18px;font-weight:700;color:var(--text-1);margin-bottom:10px}.department-shell__not-found p{margin-bottom:16px}.department-sidebar{width:var(--sidebar-w);min-width:var(--sidebar-w);background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden}.department-sidebar__header{padding:16px 16px 12px;border-bottom:1px solid var(--border);display:flex;flex-direction:column;gap:4px;flex-shrink:0}.department-sidebar__back{font-size:11.5px;color:var(--accent);background:none;border:none;cursor:pointer;text-align:left;padding:0;font-family:var(--sans);line-height:1.4}.department-sidebar__back:hover{text-decoration:underline}.department-sidebar__title{font-family:var(--display);font-size:14px;font-weight:700;color:var(--text-1);margin-top:4px}.department-sidebar__code{font-family:var(--mono);font-size:10px;color:var(--text-3);letter-spacing:.08em;text-transform:uppercase}.department-sidebar__nav{flex:1;padding:6px 8px}.department-sidebar__footer{margin-top:auto;padding:10px 14px 12px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:4px;flex-shrink:0}.department-sidebar__global-link{font-size:11.5px;color:var(--text-3);background:none;border:none;cursor:pointer;text-align:left;padding:4px 0;font-family:var(--sans)}.department-sidebar__global-link:hover{color:var(--accent);text-decoration:underline}.dept-switcher{padding:28px 28px 40px;max-width:900px}.dept-switcher__header{margin-bottom:24px}.dept-switcher__title{font-family:var(--display);font-size:22px;font-weight:700;color:var(--text-1);letter-spacing:-.015em;margin-bottom:6px}.dept-switcher__subtitle{font-size:13px;color:var(--text-2)}.dept-switcher__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px}.dept-switcher__card{display:flex;align-items:center;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;cursor:pointer;text-align:left;padding:0;transition:box-shadow .15s,border-color .15s,transform .1s;font-family:var(--sans);width:100%}.dept-switcher__card:hover{box-shadow:var(--shadow-md);border-color:var(--border2);transform:translateY(-1px)}.dept-switcher__card-strip{width:5px;min-height:72px;flex-shrink:0}.dept-switcher__card-body{flex:1;padding:14px 16px;min-width:0}.dept-switcher__card-name{font-size:14px;font-weight:600;color:var(--text-1);margin-bottom:2px}.dept-switcher__card-code{font-family:var(--mono);font-size:10.5px;color:var(--text-3);letter-spacing:.06em;text-transform:uppercase;margin-bottom:4px}.dept-switcher__card-stats{font-size:11.5px;color:var(--text-2)}.dept-switcher__card-arrow{padding:0 16px;font-size:16px;color:var(--text-3);flex-shrink:0}.dept-dashboard{padding:28px 28px 40px;max-width:1100px}.dept-dashboard__header{margin-bottom:24px}.dept-dashboard__title{font-family:var(--display);font-size:22px;font-weight:700;color:var(--text-1);letter-spacing:-.015em;margin-bottom:4px}.dept-dashboard__subtitle{font-size:13px;color:var(--text-2)}.dept-kpi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px;margin-bottom:32px}.dept-kpi-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px 20px;display:flex;flex-direction:column;gap:4px}.dept-kpi-card__value{font-family:var(--display);font-size:28px;font-weight:700;color:var(--text-1);line-height:1}.dept-kpi-card__label{font-size:12px;color:var(--text-2);font-weight:500}.dept-kpi-card__sublabel{font-size:11px;color:var(--text-3)}.dept-empresa-list__title{font-family:var(--display);font-size:15px;font-weight:600;color:var(--text-1);margin-bottom:12px}.dept-empresa-list__items{display:flex;flex-direction:column;gap:8px}.dept-empresa-row{display:flex;align-items:center;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;cursor:pointer;text-align:left;padding:0;transition:box-shadow .15s,border-color .15s;font-family:var(--sans);width:100%}.dept-empresa-row:hover{box-shadow:var(--shadow-sm);border-color:var(--border2)}.dept-empresa-row__color-strip{width:4px;min-height:52px;flex-shrink:0}.dept-empresa-row__body{flex:1;padding:12px 16px;display:flex;flex-direction:column;gap:2px}.dept-empresa-row__code{font-weight:600;font-size:13px;color:var(--text-1)}.dept-empresa-row__stats{font-size:11.5px;color:var(--text-2)}.dept-empresa-row__arrow{padding:0 16px;font-size:14px;color:var(--text-3);flex-shrink:0}.dept-empresa-dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:6px;vertical-align:middle}.dept-section-header{margin-bottom:24px}.dept-section-header__title{font-family:var(--display);font-size:20px;font-weight:700;color:var(--text-1);letter-spacing:-.01em;margin-bottom:4px}.dept-section-header__subtitle{font-size:13px;color:var(--text-2)}.dept-operaciones,.dept-xero{padding:28px 28px 40px;max-width:1100px}.dept-ops__tabs{display:flex;gap:6px;margin-bottom:16px;border-bottom:1px solid var(--border);padding-bottom:8px}.dept-ops__tab{padding:6px 14px;border-radius:var(--radius);font-family:var(--sans);font-size:12.5px;font-weight:500;border:1px solid transparent;background:none;cursor:pointer;color:var(--text-2);transition:background .12s,color .12s}.dept-ops__tab:hover{background:var(--surface2);color:var(--text-1)}.dept-ops__tab--active{background:var(--accent-bg);color:var(--accent);border-color:var(--accent-bd)}.dept-ops__table-wrap{overflow-x:auto}.dept-ops__table{width:100%;border-collapse:collapse;font-size:12.5px}.dept-ops__th{text-align:left;padding:8px 12px;background:var(--surface2);border-bottom:1px solid var(--border2);font-weight:600;color:var(--text-2);font-family:var(--mono);font-size:10.5px;letter-spacing:.05em;white-space:nowrap}.dept-ops__row{border-bottom:1px solid var(--border)}.dept-ops__row:last-child{border-bottom:0}.dept-ops__row--foot{background:var(--surface2)}.dept-ops__cell{padding:9px 12px;color:var(--text-1);vertical-align:middle}.dept-ops__cell--mono{font-family:var(--mono);font-size:12px}.dept-ops__cell--muted{color:var(--text-2)}.dept-ops__badge{display:inline-block;padding:2px 8px;border-radius:4px;font-family:var(--mono);font-size:10.5px;font-weight:500}.dept-ops__badge--ok{background:var(--green-bg);color:var(--green)}.dept-ops__badge--pending{background:var(--amber-bg);color:var(--amber)}.dept-ops__badge--neutral{background:var(--surface2);color:var(--text-2)}.dept-ops__badge--authorised{background:var(--green-bg);color:var(--green)}.dept-ops__badge--paid{background:var(--blue-bg);color:var(--blue)}.dept-ops__badge--draft{background:var(--surface3);color:var(--text-2)}.dept-ops__pagination{display:flex;align-items:center;gap:12px;padding:12px 0}.dept-ops__page-info{font-size:12px;color:var(--text-2)}.dept-reportes{padding:28px 28px 40px;max-width:900px}.dept-reportes__subtitle{font-family:var(--display);font-size:15px;font-weight:600;color:var(--text-1);margin-bottom:12px}.dept-reportes__pdf-banner{display:flex;align-items:flex-start;gap:24px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px 24px;margin-bottom:32px}.dept-reportes__pdf-info{flex:1}.dept-reportes__pdf-info strong{display:block;font-size:14px;font-weight:600;color:var(--text-1);margin-bottom:4px}.dept-reportes__pdf-info p{font-size:12.5px;color:var(--text-2);line-height:1.5}.dept-reportes__table-section{margin-top:8px}.dept-reportes__table-wrap{overflow-x:auto}.dept-empty-state{padding:40px 24px;text-align:center;color:var(--text-2);background:var(--surface2);border-radius:var(--radius-lg);font-size:13.5px;line-height:1.5}.dept-error-state{padding:16px 20px;background:var(--red-bg);color:var(--red);border-radius:var(--radius);font-size:13px;margin-bottom:16px}.empresa-sidebar__dept-link{font-size:11.5px;color:var(--accent);background:none;border:none;cursor:pointer;text-align:left;padding:4px 0;font-family:var(--sans);display:block;width:100%}.empresa-sidebar__dept-link:hover{text-decoration:underline}@media (max-width: 768px){.department-sidebar{position:fixed;inset-block:0;inset-inline-start:0;z-index:200;transform:translate(-100%);transition:transform .25s ease;box-shadow:var(--shadow-lg)}body.sidebar-open .department-sidebar{transform:translate(0)}}.global-nav-sidebar__nav{flex:1;overflow-y:auto;display:flex;flex-direction:column;padding:6px 8px 4px;gap:4px}.global-nav-sidebar__section{display:flex;flex-direction:column;gap:1px;margin-bottom:8px}.global-nav-sidebar__section-label{display:block;padding:0 10px;margin-bottom:2px}.global-nav-sidebar__dept{display:flex;flex-direction:column;border-radius:var(--radius)}.global-nav-sidebar__dept--active>.global-nav-sidebar__dept-toggle .global-nav-sidebar__dept-label{color:var(--text-1);font-weight:600}.global-nav-sidebar__dept-toggle{display:flex;align-items:center;gap:2px}.global-nav-sidebar__dept-chevron-btn{display:inline-flex;align-items:center;justify-content:center;width:24px;min-width:24px;height:30px;border:0;background:transparent;cursor:pointer;color:var(--text-3);border-radius:var(--radius);flex-shrink:0;transition:color .15s,background .15s}.global-nav-sidebar__dept-chevron-btn:hover{background:var(--surface2);color:var(--text-1)}.global-nav-sidebar__chevron-icon{display:block}.global-nav-sidebar__dept-label{flex:1;min-width:0;padding:7px 8px;border:0;background:transparent;cursor:pointer;text-align:left;font-family:var(--sans);font-size:12.5px;font-weight:500;color:var(--text-2);border-radius:var(--radius);transition:background .15s,color .15s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.global-nav-sidebar__dept-label:hover{background:var(--surface2);color:var(--text-1)}.global-nav-sidebar__dept-label--active{color:var(--color-primary, var(--accent));font-weight:600}.global-nav-sidebar__empresa-list{list-style:none;margin:2px 0 4px 26px;border-left:1px solid var(--border);padding:0 0 0 8px;display:flex;flex-direction:column;gap:1px}.global-nav-sidebar__empresa-item{display:flex}.global-nav-sidebar__empresa-btn{display:flex;align-items:center;gap:8px;width:100%;padding:6px 10px;border:0;background:transparent;cursor:pointer;text-align:left;font-family:var(--mono);font-size:11.5px;color:var(--text-2);border-radius:var(--radius);transition:background .15s,color .15s;min-height:30px}.global-nav-sidebar__empresa-btn:hover{background:var(--surface2);color:var(--text-1)}.global-nav-sidebar__empresa-btn--active{background:var(--accent-bg);color:var(--accent);font-weight:600}.global-nav-sidebar__dot{width:5px;height:5px;border-radius:50%;background:currentColor;flex-shrink:0;opacity:.45;display:inline-block}.global-nav-sidebar__dot--active{opacity:1}.global-nav-sidebar__skeleton-block{display:flex;flex-direction:column;gap:6px;padding:6px 10px}.global-nav-sidebar__skeleton-row{height:24px;border-radius:var(--radius);background:var(--surface3);animation:skeleton-pulse 1.4s ease-in-out infinite}@keyframes skeleton-pulse{0%,to{opacity:1}50%{opacity:.5}}.global-nav-sidebar__error{font-size:11.5px;color:var(--red);padding:6px 10px;line-height:1.4}.global-nav-sidebar__empty{font-size:11.5px;color:var(--text-3);padding:6px 10px;line-height:1.4}.empresa-shell__unavailable{display:flex;flex-direction:column;align-items:flex-start;gap:16px;padding:32px 24px;max-width:480px}.empresa-shell__unavailable p{font-size:.9rem;color:var(--text-2);line-height:1.5}@media (max-width: 768px){.global-nav-sidebar.sidebar{position:fixed;inset-block:0;inset-inline-start:0;z-index:200;transform:translate(-100%);transition:transform .25s ease;box-shadow:var(--shadow-lg)}body.sidebar-open .global-nav-sidebar.sidebar{transform:translate(0)}}.left-rail{display:flex;flex-direction:column;width:var(--sidebar-w);min-width:var(--sidebar-w);height:100vh;overflow:hidden;background:var(--surface);border-right:1px solid var(--border);flex-shrink:0}.left-rail .global-nav-sidebar.sidebar{width:100%;min-width:0;border-right:0;border-bottom:1px solid var(--border);max-height:45vh;overflow-y:auto;flex-shrink:0}.left-rail .sidebar:not(.global-nav-sidebar){width:100%;min-width:0;border-right:0;flex:1;overflow-y:auto;overflow-x:hidden}@media (max-width: 768px){.left-rail{position:fixed;top:0;left:0;width:280px;max-width:86vw;height:100vh;z-index:20;transform:translate(-100%);transition:transform .25s ease;box-shadow:4px 0 24px #00000014;padding-top:env(safe-area-inset-top)}body.sidebar-open .left-rail{transform:translate(0)}.left-rail .global-nav-sidebar.sidebar,.left-rail .sidebar:not(.global-nav-sidebar){position:static;transform:none;box-shadow:none;width:100%;max-width:100%;padding-top:0}.left-rail .global-nav-sidebar.sidebar{max-height:40vh}}.scoped-nav-sidebar--global{display:flex;flex-direction:column;width:var(--sidebar-w);min-width:var(--sidebar-w);height:100vh}.scoped-nav-sidebar--global .global-nav-sidebar.sidebar{width:100%;min-width:0;border-right:0;border-bottom:1px solid var(--border);max-height:45vh}.scoped-nav-sidebar--global .sidebar:not(.global-nav-sidebar){width:100%;min-width:0;border-right:0;flex:1;overflow-y:auto}@media (max-width: 768px){.scoped-nav-sidebar--global{position:fixed;top:0;left:0;width:280px;max-width:86vw;height:100vh;transform:translate(-100%);transition:transform .2s ease;z-index:1000}body.sidebar-open .scoped-nav-sidebar--global{transform:translate(0)}.scoped-nav-sidebar--global .global-nav-sidebar.sidebar,.scoped-nav-sidebar--global .sidebar:not(.global-nav-sidebar){position:static;width:100%;max-height:none;transform:none}}.dept-sub-nav{display:flex;flex-direction:column;width:var(--sidebar-w);min-width:var(--sidebar-w);height:100vh;overflow:hidden;background:var(--surface);border-right:1px solid var(--border);flex-shrink:0}.dept-sub-nav__brand-strip{height:4px;background:var(--color-primary, var(--accent));flex-shrink:0}.dept-sub-nav__header{padding:14px 18px 10px;border-bottom:1px solid var(--border);flex-shrink:0}.dept-sub-nav__label{font-family:var(--mono);font-size:9.5px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--color-primary, var(--accent));margin-bottom:4px}.dept-sub-nav__name{font-family:var(--display);font-size:15px;font-weight:700;letter-spacing:-.01em;color:var(--text-1);line-height:1.25}.dept-sub-nav__nav{display:flex;flex-direction:column;padding:8px 8px 4px;gap:0;overflow-y:auto;flex-shrink:0}.dept-sub-nav__section{display:flex;flex-direction:column;gap:1px;padding-bottom:6px}.dept-sub-nav__section-label{font-family:var(--mono);font-size:9.5px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--text-3);padding:6px 10px 3px;display:block}.dept-sub-nav__empresas-list{margin-top:auto;padding:8px 8px 4px;border-top:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;max-height:38vh;overflow:hidden}.dept-sub-nav__search{width:100%;padding:5px 10px;border:1px solid var(--border2);border-radius:var(--radius);font-family:var(--sans);font-size:12.5px;color:var(--text-1);background:var(--surface2);margin-bottom:4px;outline:none;transition:border-color .15s;flex-shrink:0}.dept-sub-nav__search:focus{border-color:var(--color-primary, var(--accent));background:var(--surface)}.dept-sub-nav__empresa-ul{list-style:none;overflow-y:auto;flex:1;min-height:0}.dept-sub-nav__empresa-ul::-webkit-scrollbar{width:4px}.dept-sub-nav__empresa-ul::-webkit-scrollbar-thumb{background:var(--surface3);border-radius:2px}.dept-sub-nav__empresa-item{display:flex}.dept-sub-nav__empresa-item--empty{font-size:11.5px;color:var(--text-3);padding:6px 10px}.dept-sub-nav__empresa-btn{display:flex;align-items:center;gap:8px;width:100%;padding:6px 10px;border:0;background:none;border-radius:var(--radius);font-family:var(--sans);font-size:12.5px;color:var(--text-2);cursor:pointer;text-align:left;transition:background .15s,color .15s;min-height:32px}.dept-sub-nav__empresa-btn:hover{background:var(--surface2);color:var(--text-1)}.dept-sub-nav__empresa-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0;opacity:.8}.dept-sub-nav__loading,.dept-sub-nav__empty{font-size:11.5px;color:var(--text-3);padding:6px 10px;line-height:1.4}.dept-sub-nav__footer{padding:8px 10px 10px;border-top:1px solid var(--border);flex-shrink:0}.dept-sub-nav__back-btn{display:flex;align-items:center;gap:6px;width:100%;padding:6px 10px;border:0;background:none;border-radius:var(--radius);font-family:var(--sans);font-size:12px;color:var(--text-3);cursor:pointer;text-align:left;transition:background .15s,color .15s;min-height:32px}.dept-sub-nav__back-btn:hover{background:var(--surface2);color:var(--text-1)}.empresa-sub-nav{display:flex;flex-direction:column;width:var(--sidebar-w);min-width:var(--sidebar-w);height:100vh;overflow:hidden;background:var(--surface);border-right:1px solid var(--border);flex-shrink:0}.empresa-sub-nav__brand-strip{height:4px;flex-shrink:0}.empresa-sub-nav__header{padding:14px 18px 10px;border-bottom:1px solid var(--border);flex-shrink:0}.empresa-sub-nav__label{font-family:var(--mono);font-size:9.5px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--color-primary, var(--accent));margin-bottom:4px}.empresa-sub-nav__code{font-family:var(--display);font-size:15px;font-weight:700;letter-spacing:-.01em;color:var(--text-1);line-height:1.25}.empresa-sub-nav__nav{display:flex;flex-direction:column;padding:8px 8px 4px;flex:1;overflow-y:auto}.empresa-sub-nav__section-label{font-family:var(--mono);font-size:9.5px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--text-3);padding:6px 10px 3px;display:block}.empresa-sub-nav__monitoring-section{display:flex;flex-direction:column;gap:1px}.empresa-sub-nav__footer{padding:8px 10px 10px;border-top:1px solid var(--border);flex-shrink:0;margin-top:auto}.empresa-sub-nav__back-btn{display:flex;align-items:center;gap:6px;width:100%;padding:6px 10px;border:0;background:none;border-radius:var(--radius);font-family:var(--sans);font-size:12px;color:var(--text-3);cursor:pointer;text-align:left;transition:background .15s,color .15s;min-height:32px}.empresa-sub-nav__back-btn:hover{background:var(--surface2);color:var(--text-1)}@media (max-width: 768px){.dept-sub-nav,.empresa-sub-nav{position:fixed;top:0;left:0;width:280px;max-width:86vw;height:100vh;z-index:20;transform:translate(-100%);transition:transform .25s ease;box-shadow:4px 0 24px #00000014;padding-top:env(safe-area-inset-top)}body.sidebar-open .dept-sub-nav,body.sidebar-open .empresa-sub-nav{transform:translate(0)}}.topbar-dept-picker{display:inline-flex;align-items:center;gap:6px;margin-right:8px;padding:4px 8px;border:1px solid var(--border);border-radius:6px;background:var(--surface, #fff);font-size:12px;cursor:pointer}.topbar-dept-picker__label{font-family:var(--mono, monospace);font-size:10px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--text-2, #666)}.topbar-dept-picker__select{border:0;background:transparent;font-size:12px;font-weight:500;color:var(--text-1, #111);cursor:pointer;padding:2px 4px;-webkit-appearance:auto;-moz-appearance:auto;appearance:auto}.topbar-dept-picker__select:focus{outline:2px solid var(--accent, #0066cc);outline-offset:1px;border-radius:4px}.topbar-dept-picker__empresa{font-family:var(--mono, monospace);font-size:11px;color:var(--accent, #0066cc);font-weight:600}.u-sidebar{display:flex;flex-direction:column;width:var(--sidebar-w, 240px);min-width:var(--sidebar-w, 240px);height:100vh;background:var(--surface, #fff);border-right:1px solid var(--border, #e4e4e7);font-size:13px;color:var(--text-1, #18181b);overflow:hidden;position:relative}.u-sidebar__brand{display:flex;align-items:center;justify-content:center;padding:14px 10px 12px;border-bottom:1px solid var(--border, #e4e4e7)}.u-sidebar__brand-logo{width:100%;max-width:140px;height:auto}.u-sidebar__scope{border-bottom:1px solid var(--border, #e4e4e7);background:var(--surface, #fff)}.u-sidebar__scope-tree{display:flex;flex-direction:column}.u-sidebar__scope-header{display:flex;align-items:center;gap:8px;width:100%;padding:10px 14px;background:transparent;border:0;cursor:pointer;font:inherit;text-align:left;transition:background .12s ease}.u-sidebar__scope-header:hover,.u-sidebar__scope-header.is-open{background:var(--surface-2, #f4f4f5)}.u-sidebar__scope-header-label{font-family:var(--mono, monospace);font-size:9px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--text-3, #71717a)}.u-sidebar__scope-header-summary{flex:1;font-size:13px;font-weight:600;color:var(--text-1, #18181b);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.u-sidebar__scope-header svg{color:var(--text-3, #71717a);flex-shrink:0}.u-sidebar__scope-list{list-style:none;margin:0;padding:4px 0 8px;overflow-y:auto;max-height:38vh;background:var(--surface, #fff);border-top:1px solid var(--border, #e4e4e7)}.u-sidebar__scope-option{display:flex;align-items:center;gap:8px;width:100%;padding:8px 12px;background:transparent;border:0;font:inherit;font-size:13px;text-align:left;cursor:pointer;color:var(--text-1, #18181b);transition:background .12s ease}.u-sidebar__scope-option:hover{background:var(--surface-2, #f4f4f5)}.u-sidebar__scope-option.is-active{background:var(--accent-bg, #eff6ff);color:var(--accent, #0066cc);font-weight:600}.u-sidebar__scope-option--global{font-weight:500;border-bottom:1px solid var(--border, #e4e4e7);margin-bottom:4px}.u-sidebar__scope-option-dot{width:6px;height:6px;border-radius:50%;background:var(--text-3, #a1a1aa);flex-shrink:0}.u-sidebar__scope-option.is-active .u-sidebar__scope-option-dot{background:var(--accent, #0066cc)}.u-sidebar__scope-option-code{margin-left:auto;font-family:var(--mono, monospace);font-size:10px;color:var(--text-3, #71717a);letter-spacing:.04em}.u-sidebar__scope-dept-row{display:flex;align-items:stretch}.u-sidebar__scope-dept-row .u-sidebar__scope-option--dept{flex:1}.u-sidebar__scope-expander{padding:0 12px;background:transparent;border:0;cursor:pointer;color:var(--text-3, #71717a);display:flex;align-items:center}.u-sidebar__scope-expander:hover{color:var(--accent, #0066cc);background:var(--surface-2, #f4f4f5)}.u-sidebar__scope-empresa-list{list-style:none;margin:0;padding:2px 0 6px}.u-sidebar__scope-empresa{display:block;width:calc(100% - 24px);margin:0 0 0 24px;padding:6px 12px;background:transparent;border:0;font:inherit;font-family:var(--mono, monospace);font-size:11.5px;text-align:left;cursor:pointer;color:var(--text-2, #52525b);border-radius:4px;transition:background .12s ease}.u-sidebar__scope-empresa:hover{background:var(--surface-2, #f4f4f5);color:var(--text-1, #18181b)}.u-sidebar__scope-empresa.is-active{background:var(--accent-bg, #eff6ff);color:var(--accent, #0066cc);font-weight:600}.u-sidebar__scope-empty{list-style:none;padding:16px 12px;font-size:12px;color:var(--text-3, #71717a);text-align:center}.u-sidebar__nav{flex:1;overflow-y:auto;padding:8px 0}.u-sidebar__nav-section{margin-bottom:12px}.u-sidebar__nav-section-label{padding:10px 16px 4px;font-family:var(--mono, monospace);font-size:9px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--text-3, #a1a1aa)}.u-sidebar__nav-section-items{display:flex;flex-direction:column;padding-inline-start:var(--sidebar-child-indent, .875rem)}.u-sidebar__nav-item{display:flex;align-items:center;gap:10px;width:100%;padding:7px 16px;background:transparent;border:0;border-left:2px solid transparent;font:inherit;font-size:13px;text-align:left;cursor:pointer;color:var(--text-1, #18181b);transition:background .12s ease,color .12s ease,border-color .12s ease}.u-sidebar__nav-item:hover{background:var(--surface-2, #f4f4f5)}.u-sidebar__nav-item.is-active{background:var(--accent-bg, #eff6ff);color:var(--accent, #0066cc);font-weight:600;border-left-color:var(--accent, #0066cc)}.u-sidebar__nav-item-label{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.u-sidebar__footer{display:flex;align-items:center;gap:8px;padding:10px 12px;border-top:1px solid var(--border, #e4e4e7);background:var(--surface, #fff)}.u-sidebar__user{flex:1;display:flex;flex-direction:column;min-width:0}.u-sidebar__user-name{font-size:12px;font-weight:600;color:var(--text-1, #18181b);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.u-sidebar__user-role{font-family:var(--mono, monospace);font-size:9.5px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--text-3, #71717a)}.u-sidebar__user-role--superadmin{color:#c2410c}.u-sidebar__user-role--admin{color:#0369a1}.u-sidebar__logout{padding:4px 10px;background:transparent;border:1px solid var(--border, #e4e4e7);border-radius:4px;font:inherit;font-size:11px;color:var(--text-2, #52525b);cursor:pointer;transition:all .12s ease}.u-sidebar__logout:hover{background:var(--surface-2, #f4f4f5);border-color:var(--text-3, #a1a1aa);color:var(--text-1, #18181b)}.u-sidebar__close-mobile{display:none;position:absolute;top:8px;right:8px;width:28px;height:28px;background:transparent;border:0;cursor:pointer;font-size:16px;color:var(--text-2, #52525b)}@media (max-width: 768px){.u-sidebar{position:fixed;top:0;left:0;z-index:200;transform:translate(-100%);transition:transform .25s ease;box-shadow:var(--shadow-lg, 0 10px 28px rgba(0,0,0,.12));width:280px;max-width:86vw}body.sidebar-open .u-sidebar{transform:translate(0)}.u-sidebar__close-mobile{display:block}}.fs-label-xs{font-size:.69rem}.fs-label-sm{font-size:.75rem}.fs-body-sm{font-size:.8125rem}@media (max-width: 640px){body,input,select,textarea{font-size:16px}.data-table-wrap>.data-table{min-width:600px}.nav-label,.nav-section-desc,.nav-group-body .nav-section-desc,.nav-group-badge{font-size:12px}.nav-group-body .nav-item{font-size:13px}.brand-tag{font-size:12px}.brand-info p{font-size:13px}.data-table th{font-size:12px}.data-table td{font-size:13px}.sort-arrow,.kv-k{font-size:12px}.kv-v,.badge,.status,.kpi-label,.kpi-meta,.kpi-sub{font-size:13px}.kpi-row,.kpi-grid,.kpi-row-3{grid-template-columns:1fr;gap:8px}.kpi-card{padding:14px 16px}.full-panel-desc{font-size:13px}.bar-day,.bar-val{font-size:11px}.mono.small,.supplier-sub,.error-meta,.empresa-sub-nav__label,.empresa-sub-nav__section-label,.u-sidebar__logout{font-size:12px}.topbar-title{font-size:15px}.btn--sm{font-size:13px}.fs-label-xs{font-size:12px}.fs-label-sm,.fs-body-sm{font-size:13px}}@keyframes ids-upload-node-pulse{0%,to{box-shadow:0 0 #c95d228c}50%{box-shadow:0 0 0 7px #c95d2200}}@keyframes ids-upload-indeterminate{0%{transform:translate(-100%)}to{transform:translate(400%)}}@keyframes ids-upload-check-draw{0%{stroke-dashoffset:28}to{stroke-dashoffset:0}}@keyframes ids-upload-check-pop{0%{transform:scale(.6);opacity:0}60%{transform:scale(1.12);opacity:1}to{transform:scale(1);opacity:1}}@media (prefers-reduced-motion: reduce){.ids-upload-node-active,.ids-upload-indeterminate-bar,.ids-upload-check-circle{animation:none!important}.ids-upload-check-path{animation:none!important;stroke-dashoffset:0!important}}
