:root{--primary:#4f6ef7;--primary-dark:#3b5fe0;--primary-soft:#eff3ff;--primary-ring:#4f6ef72e;--surface:#fff;--background:#f4f6fa;--background-soft:#fafbfd;--sidebar-bg:#14152b;--sidebar-bg-2:#1a1b33;--sidebar-text:#8892a4;--sidebar-text-active:#fff;--topbar-bg:#0f1023;--border:#e4e8ef;--border-strong:#d5dbe4;--divider:#eef1f5;--text-1:#0f172a;--text-2:#475569;--text-3:#64748b;--text-muted:#94a3b8;--success:#16a34a;--success-bg:#dcfce7;--success-soft:#ecfdf5;--warning:#b45309;--warning-bg:#fef3c7;--warning-soft:#fffbeb;--danger:#dc2626;--danger-bg:#fee2e2;--danger-soft:#fef2f2;--info:#1d4ed8;--info-bg:#dbeafe;--info-soft:#eff6ff;--purple:#7e22ce;--purple-bg:#f3e8ff;--purple-soft:#faf5ff;--pink:#9d174d;--pink-bg:#fce7f3;--r-sm:4px;--r-md:6px;--r-lg:8px;--r-pill:999px;--shadow-sm:0 1px 2px #0f172a0a;--shadow-md:0 2px 8px #0f172a0f, 0 1px 2px #0f172a0a;--shadow-lg:0 12px 32px #0f172a1f, 0 4px 12px #0f172a0f;--s-1:4px;--s-2:8px;--s-3:12px;--s-4:16px;--s-5:20px;--s-6:24px;--s-7:28px;--s-8:32px;--s-9:40px;--sidebar-w:232px;--sidebar-w-collapsed:64px;--topbar-h:52px;--ff:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--ff-mono:"JetBrains Mono", "SF Mono", ui-monospace, Menlo, Consolas, monospace}*{box-sizing:border-box}html,body{margin:0;padding:0}body{font-family:var(--ff);background:var(--background);color:var(--text-1);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:14px;line-height:1.45}.skip-link{background:var(--primary);color:#fff;border-radius:var(--r-md);z-index:1000;padding:8px 14px;font-size:13px;font-weight:600;transition:transform .15s;position:absolute;top:8px;left:8px;transform:translateY(-200%)}.skip-link:focus{outline-offset:2px;outline:2px solid #fff;transform:translateY(0)}:focus-visible{outline:2px solid var(--primary);outline-offset:2px;border-radius:var(--r-sm)}.topbar{height:var(--topbar-h);background:var(--topbar-bg);z-index:50;border-bottom:1px solid #000;align-items:center;gap:16px;padding:0 20px;display:flex;position:fixed;top:0;left:0;right:0}.topbar-brand{color:#fff;letter-spacing:.2px;align-items:center;gap:10px;font-size:15px;font-weight:700;display:flex}.topbar-logo{background:var(--primary);color:#fff;border-radius:7px;place-items:center;width:26px;height:26px;font-size:13px;font-weight:800;display:grid;box-shadow:inset 0 0 0 1px #ffffff0f}.topbar-divider{background:#ffffff1f;width:1px;height:20px}.topbar-context{color:#b7bfcf;font-size:12.5px;font-weight:500}.topbar-context strong{color:#fff;font-weight:600}.topbar-actions{align-items:center;gap:10px;margin-left:auto;display:flex}.portal-toggle{border-radius:var(--r-md);background:#ffffff0f;border:1px solid #ffffff14;gap:0;padding:3px;display:flex}.portal-btn{color:#b7bfcf;cursor:pointer;background:0 0;border:0;border-radius:4px;padding:5px 12px;font-family:inherit;font-size:12.5px;font-weight:500;transition:all .12s}.portal-btn:hover{color:#fff}.portal-btn[aria-pressed=true]{background:var(--primary);color:#fff;box-shadow:0 1px 2px #0000002e}.topbar-iconbtn{border-radius:var(--r-md);color:#b7bfcf;cursor:pointer;background:0 0;border:1px solid #ffffff14;place-items:center;width:32px;height:32px;transition:all .12s;display:grid}.topbar-iconbtn:hover{color:#fff;background:#ffffff0f}.topbar-iconbtn .dot{background:var(--danger);border:1.5px solid var(--topbar-bg);border-radius:50%;width:7px;height:7px;position:absolute;transform:translate(8px,-8px)}.topbar-user{color:#fff;cursor:pointer;background:0 0;border:1px solid #ffffff14;border-radius:999px;align-items:center;gap:8px;padding:4px 10px 4px 4px;font-size:12.5px;display:flex}.topbar-user:hover{background:#ffffff0f}.topbar-user .avatar{color:#fff;background:linear-gradient(135deg,#6e84ff,#4f6ef7);border-radius:50%;place-items:center;width:24px;height:24px;font-size:11px;font-weight:700;display:grid}.menu-toggle{border-radius:var(--r-md);color:#fff;cursor:pointer;background:0 0;border:1px solid #ffffff14;justify-content:center;align-items:center;width:32px;height:32px;display:none}.sidebar{top:var(--topbar-h);width:var(--sidebar-w);background:var(--sidebar-bg);color:var(--sidebar-text);z-index:40;border-right:1px solid #ffffff0a;padding:12px 10px 24px;position:fixed;bottom:0;left:0;overflow-y:auto}.sidebar.light{color:var(--text-2);border-right:1px solid var(--border);background:#fff}.sidebar-co{border-bottom:1px solid #ffffff0f;align-items:center;gap:10px;margin-bottom:8px;padding:10px 12px 12px;display:flex}.sidebar.light .sidebar-co{border-bottom:1px solid var(--border)}.sidebar-co-logo{color:#fff;background:linear-gradient(135deg,#4f6ef7,#6e84ff);border-radius:8px;flex-shrink:0;place-items:center;width:32px;height:32px;font-size:13px;font-weight:800;display:grid}.sidebar-co-name{color:#fff;font-size:13.5px;font-weight:700;line-height:1.25}.sidebar.light .sidebar-co-name{color:var(--text-1)}.sidebar-co-sub{color:var(--sidebar-text);letter-spacing:.2px;margin-top:1px;font-size:11px;font-weight:500}.sidebar.light .sidebar-co-sub{color:var(--text-3)}.nav-section{color:#ffffff59;text-transform:uppercase;letter-spacing:.8px;padding:14px 14px 4px;font-size:10.5px;font-weight:700}.sidebar.light .nav-section{color:var(--text-muted)}.nav-item{border-radius:var(--r-md);cursor:pointer;color:var(--sidebar-text);text-align:left;background:0 0;border:0;align-items:center;gap:10px;width:100%;margin:1px 0;padding:7px 12px;font-family:inherit;font-size:13px;font-weight:500;text-decoration:none;transition:background .12s,color .12s;display:flex;position:relative}.nav-item .nav-ico{color:currentColor;opacity:.85;flex-shrink:0;width:16px;height:16px}.nav-item:hover{color:#fff;background:#ffffff0a}.sidebar.light .nav-item:hover{background:var(--background-soft);color:var(--text-1)}.nav-item[aria-current=page]{color:#fff;background:#4f6ef729;font-weight:600}.sidebar.light .nav-item[aria-current=page]{background:var(--primary-soft);color:var(--primary)}.sidebar.light .nav-item[aria-current=page]:before{content:"";background:var(--primary);border-radius:0 3px 3px 0;width:3px;position:absolute;top:6px;bottom:6px;left:-10px}.nav-item .badge-count{color:#fff;background:#ffffff14;border-radius:999px;margin-left:auto;padding:1px 7px;font-size:10.5px;font-weight:700}.nav-item[aria-current=page] .badge-count{background:var(--primary);color:#fff}.sidebar.light .nav-item .badge-count{background:var(--background);color:var(--text-2)}.sidebar.light .nav-item[aria-current=page] .badge-count{background:var(--primary);color:#fff}.nav-item .badge-count.danger{background:var(--danger);color:#fff}.nav-item .badge-count.warn{background:var(--warning);color:#fff}.main{margin-left:var(--sidebar-w);margin-top:var(--topbar-h);min-height:calc(100vh - var(--topbar-h));max-width:1600px;padding:28px 32px 64px}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:20px;margin-bottom:24px;display:flex}.page-header-left{min-width:0}.breadcrumb{color:var(--text-muted);align-items:center;gap:6px;margin-bottom:6px;font-size:12px;display:flex}.breadcrumb a{color:var(--text-3);border-radius:2px;font-weight:500;text-decoration:none}.breadcrumb a:hover{color:var(--primary)}.breadcrumb-sep{color:var(--text-muted)}.page-title{color:var(--text-1);letter-spacing:-.01em;flex-wrap:wrap;align-items:center;gap:10px;font-size:24px;font-weight:700;display:flex}.page-subtitle{color:var(--text-3);margin-top:5px;font-size:13.5px}.page-actions{flex-wrap:wrap;gap:8px;display:flex}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);overflow:hidden}.card+.card{margin-top:20px}.card-pad{padding:20px}.card-head{border-bottom:1px solid var(--divider);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:14px 20px;display:flex}.card-title{color:var(--text-1);align-items:center;gap:8px;font-size:14px;font-weight:600;display:flex}.card-title .field-note{font-weight:400}.card-sub{color:var(--text-3);margin-top:2px;font-size:12px}.card-body{padding:20px}.card-body.no-pad{padding:0}.kpi-grid{grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:14px;margin-bottom:24px;display:grid}.kpi{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);padding:16px 18px;position:relative;overflow:hidden}.kpi:before{content:"";background:var(--border);width:3px;position:absolute;top:0;bottom:0;left:0}.kpi.blue:before{background:var(--primary)}.kpi.green:before{background:var(--success)}.kpi.amber:before{background:var(--warning)}.kpi.red:before{background:var(--danger)}.kpi.purple:before{background:var(--purple)}.kpi-label{color:var(--text-3);align-items:center;gap:6px;margin-bottom:6px;font-size:12px;font-weight:500;display:flex}.kpi-value{color:var(--text-1);letter-spacing:-.02em;align-items:baseline;gap:6px;font-size:28px;font-weight:700;line-height:1.1;display:flex}.kpi-value .unit{color:var(--text-3);font-size:14px;font-weight:500}.kpi.blue .kpi-value{color:var(--primary)}.kpi.green .kpi-value{color:var(--success)}.kpi.amber .kpi-value{color:var(--warning)}.kpi.red .kpi-value{color:var(--danger)}.kpi.purple .kpi-value{color:var(--purple)}.kpi-sub{color:var(--text-muted);font-size:11px;font-family:var(--ff-mono);margin-top:4px}.kpi-trend{background:var(--success-bg);color:var(--success);border-radius:4px;align-items:center;gap:3px;padding:1px 6px;font-size:11.5px;font-weight:600;display:inline-flex}.kpi-trend.down{background:var(--danger-bg);color:var(--danger)}.kpi.pulse.red{animation:2.4s ease-in-out infinite pulse-red}@keyframes pulse-red{0%,to{box-shadow:var(--shadow-sm)}50%{box-shadow:0 0 0 4px #dc262614, var(--shadow-sm)}}.table-wrap{overflow-x:auto}.table{border-collapse:collapse;width:100%;font-size:13px}.table thead th{text-align:left;color:var(--text-3);text-transform:uppercase;letter-spacing:.5px;background:var(--background-soft);border-bottom:1px solid var(--border);white-space:nowrap;padding:10px 16px;font-size:11px;font-weight:700;position:sticky;top:0}.table thead th .field-note{font-weight:400}.table tbody td{border-bottom:1px solid var(--divider);color:var(--text-2);vertical-align:middle;padding:12px 16px}.table tbody tr:last-child td{border-bottom:0}.table tbody tr{transition:background 80ms}.table tbody tr:hover td{background:#fafbff}.table tbody tr.selected td{background:var(--primary-soft)}.table td .primary-text{color:var(--text-1);font-weight:500}.table td .mono{font-family:var(--ff-mono);color:var(--text-1);font-size:12.5px;font-weight:600}.table .col-actions{text-align:right;white-space:nowrap}.table .row-link{font:inherit;color:var(--primary);cursor:pointer;text-align:left;background:0 0;border:0;padding:0;font-weight:600;text-decoration:none}.table .row-link:hover{color:var(--primary-dark);text-decoration:underline}.field-note{font-family:var(--ff-mono);color:var(--text-muted);letter-spacing:0;text-transform:none;font-size:10.5px;font-style:normal;font-weight:400}.field-ref{font-family:var(--ff-mono);color:var(--text-muted);font-size:10.5px;font-weight:400}.row-empty td{text-align:center;color:var(--text-muted);padding:40px 16px}.table-foot{border-top:1px solid var(--divider);background:var(--background-soft);color:var(--text-3);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:12px 16px;font-size:12px;display:flex}.pager{align-items:center;gap:4px;display:flex}.pager button{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-sm);cursor:pointer;width:28px;height:28px;color:var(--text-2);place-items:center;font-family:inherit;display:grid}.pager button:hover:not(:disabled){background:var(--background);color:var(--text-1)}.pager button[aria-current=page]{background:var(--primary);color:#fff;border-color:var(--primary)}.pager button:disabled{opacity:.4;cursor:not-allowed}.badge{border-radius:var(--r-pill);white-space:nowrap;align-items:center;gap:5px;padding:2px 9px;font-size:11px;font-weight:600;line-height:1.5;display:inline-flex}.badge:before{content:"";background:currentColor;border-radius:50%;flex-shrink:0;width:5px;height:5px}.badge.no-dot:before{display:none}.badge.success,.badge.active,.badge.paid,.badge.online,.badge.completed,.badge.refunded,.badge.complete{background:var(--success-bg);color:var(--success)}.badge.warn,.badge.pending,.badge.issued,.badge.created,.badge.scheduled,.badge.on_leave,.badge.inactive{background:var(--warning-bg);color:var(--warning)}.badge.info,.badge.processing,.badge.inprogress,.badge.captive,.badge.running,.badge.maintenance{background:var(--info-bg);color:var(--info)}.badge.danger,.badge.failed,.badge.offline,.badge.rejected,.badge.cancelled,.badge.aborted,.badge.payout_failed,.badge.decommissioned{background:var(--danger-bg);color:var(--danger)}.badge.purple,.badge.queued,.badge.standby,.badge.queued_for_payout,.badge.commissioned{background:var(--purple-bg);color:var(--purple)}.badge.pink,.badge.suspended,.badge.faulty{background:var(--pink-bg);color:var(--pink)}.badge.open_to_all{background:var(--success-bg);color:var(--success)}.badge.large{padding:4px 12px;font-size:12px}.method-pill{font-size:10.5px;font-weight:700;font-family:var(--ff-mono);letter-spacing:.3px;border-radius:4px;padding:2px 7px;display:inline-block}.method-pill.post{background:var(--info-bg);color:var(--info)}.method-pill.get{background:var(--success-bg);color:var(--success)}.method-pill.put{background:var(--warning-bg);color:var(--warning)}.method-pill.delete{background:var(--danger-bg);color:var(--danger)}.entity-ref{font-family:var(--ff-mono);background:var(--background);border:1px solid var(--border);border-radius:var(--r-sm);color:var(--text-2);padding:1px 6px;font-size:11px;font-weight:500}.code-chip{font-family:var(--ff-mono);background:var(--background);border:1px solid var(--border);border-radius:var(--r-sm);color:var(--text-1);padding:1px 7px;font-size:11.5px;font-weight:600}.btn{border-radius:var(--r-md);cursor:pointer;white-space:nowrap;border:1px solid #0000;align-items:center;gap:6px;padding:7px 14px;font-family:inherit;font-size:13px;font-weight:500;line-height:1.4;transition:background .12s,border-color .12s,color .12s,box-shadow .12s;display:inline-flex}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff;box-shadow:inset 0 1px #ffffff1a,0 1px 2px #0f172a14}.btn-primary:hover:not(:disabled){background:var(--primary-dark)}.btn-secondary{background:var(--surface);color:var(--text-1);border-color:var(--border);box-shadow:var(--shadow-sm)}.btn-secondary:hover:not(:disabled){background:var(--background-soft);border-color:var(--border-strong)}.btn-ghost{color:var(--text-2);background:0 0;border-color:#0000}.btn-ghost:hover:not(:disabled){background:var(--background);color:var(--text-1)}.btn-success{background:var(--success);color:#fff}.btn-success:hover:not(:disabled){background:#15803d}.btn-success-soft{background:var(--success-bg);color:var(--success);border-color:#16a34a33}.btn-success-soft:hover:not(:disabled){background:#bbf7d0}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){background:#b91c1c}.btn-danger-soft{background:var(--danger-bg);color:var(--danger);border-color:#dc26262e}.btn-danger-soft:hover:not(:disabled){background:#fecaca}.btn-sm{gap:4px;padding:4px 10px;font-size:12px}.btn-xs{padding:2px 8px;font-size:11.5px}.btn-lg{padding:10px 18px;font-size:14px}.btn-block{justify-content:center;width:100%}.btn-group{flex-wrap:wrap;gap:8px;display:flex}.icon-btn{border-radius:var(--r-md);width:30px;height:30px;color:var(--text-3);cursor:pointer;background:0 0;border:1px solid #0000;place-items:center;padding:0;display:grid}.icon-btn:hover{background:var(--background);color:var(--text-1)}.form-grid{grid-template-columns:repeat(2,1fr);gap:16px 18px;display:grid}.form-grid-3{grid-template-columns:repeat(3,1fr);gap:16px 18px;display:grid}.form-group{flex-direction:column;gap:6px;min-width:0;display:flex}.form-group.full{grid-column:1/-1}.form-label{color:var(--text-1);flex-wrap:wrap;align-items:center;gap:8px;font-size:12px;font-weight:600;display:flex}.form-label .required{color:var(--danger)}.input,.select,.textarea{border:1px solid var(--border-strong);border-radius:var(--r-md);color:var(--text-1);background:var(--surface);width:100%;padding:8px 12px;font-family:inherit;font-size:13px;transition:border-color .12s,box-shadow .12s}.input::placeholder,.textarea::placeholder{color:var(--text-muted)}.input:focus,.select:focus,.textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-ring);outline:none}.input:disabled,.select:disabled,.textarea:disabled{background:var(--background);color:var(--text-3);cursor:not-allowed}.input.with-prefix{padding-left:32px}.input-wrap{position:relative}.input-prefix{color:var(--text-muted);pointer-events:none;place-items:center;display:grid;position:absolute;top:50%;left:10px;transform:translateY(-50%)}.textarea{resize:vertical;min-height:84px}.select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2364748B' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;padding-right:30px}.form-hint{color:var(--text-3);font-size:11.5px;line-height:1.4}.form-hint.error{color:var(--danger)}.checkbox-row{border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface);cursor:pointer;align-items:center;gap:10px;padding:10px 12px;font-size:13px;display:flex}.checkbox-row:hover{background:var(--background-soft)}.checkbox-row input[type=checkbox]{width:16px;height:16px;accent-color:var(--primary);flex-shrink:0}.checkbox-row .row-info{color:var(--text-3);margin-left:auto;font-size:11.5px}.radio-card-group{gap:10px;display:grid}.radio-card{border:1.5px solid var(--border);border-radius:var(--r-md);cursor:pointer;background:var(--surface);align-items:flex-start;gap:12px;padding:12px 14px;transition:border-color .12s,background .12s;display:flex}.radio-card:hover{border-color:var(--border-strong)}.radio-card.checked{border-color:var(--primary);background:var(--primary-soft)}.radio-card input[type=radio]{accent-color:var(--primary);flex-shrink:0;width:16px;height:16px;margin-top:2px}.radio-card-title{color:var(--text-1);font-size:13px;font-weight:600}.radio-card-desc{color:var(--text-3);margin-top:2px;font-size:12px}.tabs{border-bottom:1px solid var(--border);scrollbar-width:none;gap:2px;margin-bottom:20px;display:flex;overflow-x:auto}.tabs::-webkit-scrollbar{display:none}.tab{cursor:pointer;color:var(--text-3);white-space:nowrap;background:0 0;border:0;border-bottom:2px solid #0000;align-items:center;gap:7px;margin-bottom:-1px;padding:10px 16px;font-family:inherit;font-size:13px;font-weight:500;display:inline-flex}.tab:hover{color:var(--text-1)}.tab[aria-selected=true]{color:var(--primary);border-bottom-color:var(--primary);font-weight:600}.tab .tab-count{background:var(--background);color:var(--text-3);border-radius:999px;padding:1px 6px;font-size:10.5px;font-weight:600}.tab[aria-selected=true] .tab-count{background:var(--primary-soft);color:var(--primary)}.filter-bar{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:18px;display:flex}.filter-bar .input,.filter-bar .select{width:auto;min-width:160px}.filter-bar .search{min-width:240px}.filter-bar .spacer{flex:1}.detail-list{flex-direction:column;display:flex}.detail-row{border-bottom:1px solid var(--divider);grid-template-columns:140px 1fr;align-items:center;gap:16px;padding:9px 0;font-size:13px;display:grid}.detail-row:last-child{border-bottom:0}.detail-label{color:var(--text-3);align-items:center;gap:6px;font-size:12.5px;font-weight:500;display:flex}.detail-value{color:var(--text-1);font-weight:500}.detail-value.amount{letter-spacing:-.01em;font-size:22px;font-weight:700}.detail-value.mono{font-family:var(--ff-mono);font-size:12.5px}.two-col{grid-template-columns:1.5fr 1fr;gap:20px;display:grid}.two-col.eq{grid-template-columns:1fr 1fr}.two-col.invoice{grid-template-columns:1.5fr 1fr}.annotation{background:var(--warning-soft);border-radius:var(--r-md);color:#78350f;border:1px dashed #fcd34d;align-items:flex-start;gap:10px;padding:10px 14px;font-size:12.5px;display:flex}.annotation .annotation-icon{color:var(--warning);flex-shrink:0;margin-top:1px}.annotation strong{color:#78350f;font-weight:700}.annotation .entity-ref{color:#78350f;background:#b4530914;border-color:#b4530926}.annotation+.annotation{margin-top:10px}.banner{background:var(--info-soft);border-radius:var(--r-md);color:#1e3a8a;border:1px solid #bfdbfe;align-items:flex-start;gap:12px;margin-bottom:18px;padding:12px 16px;font-size:13px;display:flex}.banner .banner-icon{color:var(--info);flex-shrink:0;margin-top:1px}.banner strong{color:#1e3a8a;font-weight:700}.banner.success{background:var(--success-soft);color:#14532d;border-color:#bbf7d0}.banner.success .banner-icon,.banner.success strong{color:var(--success)}.banner.success strong{color:#14532d}.banner.danger{background:var(--danger-soft);color:#7f1d1d;border-color:#fecaca}.banner.danger .banner-icon,.banner.danger strong{color:var(--danger)}.banner.danger strong{color:#7f1d1d}.empty{text-align:center;color:var(--text-muted);padding:48px 24px}.empty h3{color:var(--text-2);margin:12px 0 4px;font-size:15px;font-weight:600}.empty p{margin:0;font-size:12.5px}.empty-icon{background:var(--background);width:48px;height:48px;color:var(--text-muted);border-radius:50%;place-items:center;margin:0 auto;display:grid}.modal-overlay{z-index:100;background:#0f172a73;place-items:center;padding:24px;animation:.15s ease-out fade-in;display:grid;position:fixed;inset:0}@keyframes fade-in{0%{opacity:0}}.modal{background:var(--surface);width:100%;max-width:520px;max-height:calc(100vh - 48px);box-shadow:var(--shadow-lg);border-radius:12px;flex-direction:column;animation:.18s ease-out modal-in;display:flex}@keyframes modal-in{0%{opacity:0;transform:translateY(8px)}}.modal-head{border-bottom:1px solid var(--divider);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.modal-title{color:var(--text-1);font-size:15px;font-weight:600}.modal-body{padding:20px;overflow-y:auto}.modal-foot{border-top:1px solid var(--divider);background:var(--background-soft);border-radius:0 0 12px 12px;justify-content:flex-end;gap:8px;padding:14px 20px;display:flex}.divider{background:var(--divider);height:1px;margin:16px 0}.mono{font-family:var(--ff-mono)}.muted{color:var(--text-3)}.muted-2{color:var(--text-muted)}.text-success{color:var(--success)}.text-danger{color:var(--danger)}.text-warning{color:var(--warning)}.text-info{color:var(--info)}.json-block{color:#c7d0e3;border-radius:var(--r-md);font-family:var(--ff-mono);white-space:pre;background:#0f1023;padding:14px 16px;font-size:12px;line-height:1.55;overflow-x:auto}.json-block .k{color:#93c5fd}.json-block .s{color:#86efac}.json-block .n{color:#fca5a5}.json-block .b{color:#fcd34d}.api-row-out td:first-child{box-shadow:inset 3px 0 0 var(--primary)}.api-row-in td:first-child{box-shadow:inset 3px 0 0 var(--success)}.api-row-fail td:first-child{box-shadow:inset 3px 0 0 var(--danger)}.direction-chip{align-items:center;gap:5px;font-size:11.5px;font-weight:600;display:inline-flex}.direction-chip.out{color:var(--primary)}.direction-chip.in{color:var(--success)}.amount-credit{color:var(--success);font-weight:600}.amount-debit{color:var(--danger);font-weight:600}.warranty-warn{color:var(--warning);font-weight:600}.warranty-expired{color:var(--danger);font-weight:600}.due-warn{color:var(--warning);align-items:center;gap:3px;font-size:11.5px;font-weight:600;display:inline-flex}.due-overdue{color:var(--danger);font-size:11.5px;font-weight:600}.checkbox-cell{width:16px;height:16px;accent-color:var(--primary);cursor:pointer}.toast-host{z-index:200;flex-direction:column;gap:10px;display:flex;position:fixed;bottom:24px;right:24px}.toast{background:var(--text-1);color:#fff;border-radius:var(--r-md);box-shadow:var(--shadow-lg);align-items:center;gap:10px;min-width:280px;max-width:420px;padding:12px 16px;font-size:13px;animation:.2s ease-out toast-in;display:flex}.toast.success{background:#14532d}.toast.success:before{content:"✓";color:#86efac;font-weight:700}.toast.error{background:#7f1d1d}.toast.error:before{content:"!";color:#fca5a5;font-weight:700}.toast.info:before{content:"i";color:#93c5fd;font-style:italic;font-weight:700}@keyframes toast-in{0%{opacity:0;transform:translateY(8px)}}.skeleton{background:linear-gradient(90deg, var(--background) 0%, #eceff4 50%, var(--background) 100%);border-radius:var(--r-sm);background-size:200% 100%;animation:1.4s ease-in-out infinite shimmer}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.health-indicator{align-items:center;gap:6px;display:inline-flex}.health-dot{background:var(--success);border-radius:50%;width:8px;height:8px;box-shadow:0 0 0 3px #16a34a2e}.health-dot.offline{background:var(--danger);box-shadow:0 0 0 3px #dc26262e}.timeline-stat{border-bottom:1px solid var(--divider);align-items:center;gap:12px;padding:12px 0;display:flex}.timeline-stat:last-child{border-bottom:0}.timeline-icon{background:var(--primary-soft);width:32px;height:32px;color:var(--primary);border-radius:50%;flex-shrink:0;place-items:center;display:grid}.timeline-icon.success{background:var(--success-bg);color:var(--success)}.timeline-icon.warn{background:var(--warning-bg);color:var(--warning)}.timeline-icon.danger{background:var(--danger-bg);color:var(--danger)}.timeline-stat-main{flex:1;min-width:0}.timeline-stat-title{color:var(--text-1);font-size:13px;font-weight:500}.timeline-stat-sub{color:var(--text-3);margin-top:1px;font-size:11.5px}.signal-bar{align-items:flex-end;gap:1.5px;height:12px;display:inline-flex}.signal-bar i{background:var(--border);border-radius:1px;width:3px}.signal-bar i:first-child{height:30%}.signal-bar i:nth-child(2){height:55%}.signal-bar i:nth-child(3){height:80%}.signal-bar i:nth-child(4){height:100%}.signal-bar.good i{background:var(--success)}.signal-bar.warn i:first-child,.signal-bar.warn i:nth-child(2){background:var(--warning)}.preview-chip{font-family:var(--ff-mono);color:var(--text-2);background:var(--background);border:1px dashed var(--border-strong);border-radius:var(--r-md);padding:6px 10px;font-size:12px;display:inline-block}.preview-chip .placeholder{color:var(--text-muted)}@media (width<=1024px){.main{padding:24px 22px 64px}.two-col,.two-col.eq,.two-col.invoice,.form-grid,.form-grid-3{grid-template-columns:1fr}.detail-row{grid-template-columns:130px 1fr}.menu-toggle{place-items:center;display:inline-grid}.sidebar{transition:transform .24s;transform:translate(-100%);box-shadow:0 0 0 100vmax #0f172a00}.sidebar.open{box-shadow:var(--shadow-lg), 0 0 0 100vmax #0f172a59;transform:translate(0)}.main{margin-left:0}.kpi-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}.topbar-context{display:none}}@media (width<=640px){.main{padding:20px 16px 48px}.page-title{font-size:20px}.filter-bar .input,.filter-bar .select,.filter-bar .search{min-width:100%}.kpi-grid{grid-template-columns:1fr 1fr;gap:10px}.kpi-value{font-size:22px}.detail-row{grid-template-columns:1fr;gap:2px;padding:8px 0}.portal-toggle{display:none}}@media print{.sidebar,.topbar,.page-actions,.filter-bar{display:none!important}.main{margin:0;padding:0}.card{box-shadow:none;border:1px solid #ccc}}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-family);font-size:var(--text-sm);color:var(--text-primary);background:var(--bg-base)}
