:root,[data-theme=light]{--color-primary: #4f46e5;--color-primary-dark: #3730a3;--color-primary-hover: #4338ca;--color-primary-light: #eef2ff;--color-primary-rgb: 79, 70, 229;--color-success: #10b981;--color-success-dark: #059669;--color-success-bg: #ecfdf5;--color-success-border: #a7f3d0;--color-success-text: #065f46;--color-warning: #f59e0b;--color-warning-dark: #d97706;--color-warning-bg: #fffbeb;--color-warning-border: #fcd34d;--color-warning-text: #78350f;--color-danger: #ef4444;--color-danger-dark: #dc2626;--color-danger-bg: #fef2f2;--color-danger-border: #fca5a5;--color-danger-text: #7f1d1d;--color-info: #3b82f6;--color-info-bg: #eff6ff;--color-info-border: #93c5fd;--color-info-text: #1e3a8a;--surface-bg: #f8fafc;--surface-card: #ffffff;--surface-card-hover: #fafbff;--surface-elevated: #ffffff;--surface-overlay: rgba(15, 23, 42, .5);--surface-input: #f8fafc;--surface-input-focus: #ffffff;--surface-sidebar: #0f172a;--surface-glass: rgba(255, 255, 255, .8);--surface-glass-border: rgba(255, 255, 255, .95);--surface-subtle: #f1f5f9;--text-primary: #0f172a;--text-secondary: #334155;--text-muted: #64748b;--text-placeholder: #94a3b8;--text-on-primary: #ffffff;--text-on-dark: #f1f5f9;--border-base: #e2e8f0;--border-strong: #cbd5e1;--border-focus: rgba(79, 70, 229, .5);--border-subtle: #f1f5f9;--sidebar-bg: #ffffff;--sidebar-border: #e8edf5;--sidebar-text: #64748b;--sidebar-text-hover: #0f172a;--sidebar-active-bg: rgba(79, 70, 229, .08);--sidebar-active-text: #4f46e5;--sidebar-width: 256px;--sidebar-collapsed: 64px;--shadow-xs: 0 1px 2px rgba(0,0,0,.04);--shadow-sm: 0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 4px 8px -2px rgba(0,0,0,.08), 0 2px 4px -2px rgba(0,0,0,.04);--shadow-lg: 0 12px 24px -4px rgba(0,0,0,.1), 0 4px 8px -4px rgba(0,0,0,.05);--shadow-xl: 0 24px 48px -8px rgba(0,0,0,.12), 0 8px 16px -8px rgba(0,0,0,.06);--shadow-glow: 0 0 0 3px rgba(var(--color-primary-rgb), .18), 0 0 16px rgba(var(--color-primary-rgb), .08);--shadow-card: 0 0 0 1px rgba(0,0,0,.04), 0 1px 4px rgba(0,0,0,.05), 0 4px 16px rgba(0,0,0,.04);--shadow-card-hover: 0 0 0 1px rgba(var(--color-primary-rgb),.12), 0 8px 32px rgba(0,0,0,.09), 0 2px 8px rgba(0,0,0,.05);--shadow-primary: 0 4px 14px rgba(var(--color-primary-rgb), .32);--shadow-primary-lg: 0 8px 28px rgba(var(--color-primary-rgb), .38);--shadow-topbar: 0 1px 0 var(--border-base), 0 2px 12px rgba(0,0,0,.04)}[data-theme=dark]{--color-primary: #6366f1;--color-primary-dark: #4f46e5;--color-primary-hover: #818cf8;--color-primary-light: rgba(99, 102, 241, .14);--color-primary-rgb: 99, 102, 241;--color-success: #10b981;--color-success-dark: #059669;--color-success-bg: rgba(16, 185, 129, .1);--color-success-border: rgba(16, 185, 129, .22);--color-success-text: #6ee7b7;--color-warning: #f59e0b;--color-warning-dark: #d97706;--color-warning-bg: rgba(245, 158, 11, .1);--color-warning-border: rgba(245, 158, 11, .22);--color-warning-text: #fde68a;--color-danger: #ef4444;--color-danger-dark: #dc2626;--color-danger-bg: rgba(239, 68, 68, .1);--color-danger-border: rgba(239, 68, 68, .22);--color-danger-text: #fca5a5;--color-info: #3b82f6;--color-info-bg: rgba(59, 130, 246, .1);--color-info-border: rgba(59, 130, 246, .22);--color-info-text: #93c5fd;--surface-bg: #0f172a;--surface-card: #1e293b;--surface-card-hover: #233248;--surface-elevated: #263347;--surface-overlay: rgba(0, 0, 0, .7);--surface-input: #162032;--surface-input-focus: #1e293b;--surface-sidebar: #060d1a;--surface-glass: rgba(30, 41, 59, .85);--surface-glass-border: rgba(255, 255, 255, .06);--surface-subtle: #162032;--text-primary: #f1f5f9;--text-secondary: #94a3b8;--text-muted: #64748b;--text-placeholder: #4a5e78;--text-on-primary: #ffffff;--text-on-dark: #f1f5f9;--border-base: #1e3050;--border-strong: #263a58;--border-focus: rgba(99, 102, 241, .55);--border-subtle: #162032;--sidebar-bg: #060d1a;--sidebar-border: rgba(255, 255, 255, .04);--sidebar-text: #4e6282;--sidebar-text-hover: #e2e8f0;--sidebar-active-bg: rgba(99, 102, 241, .16);--sidebar-active-text: #a5b4fc;--shadow-xs: 0 1px 2px rgba(0,0,0,.4);--shadow-sm: 0 1px 3px rgba(0,0,0,.5), 0 1px 2px rgba(0,0,0,.3);--shadow-md: 0 4px 8px -2px rgba(0,0,0,.5), 0 2px 4px -2px rgba(0,0,0,.3);--shadow-lg: 0 12px 24px -4px rgba(0,0,0,.65), 0 4px 8px -4px rgba(0,0,0,.4);--shadow-xl: 0 24px 48px -8px rgba(0,0,0,.75), 0 8px 16px -8px rgba(0,0,0,.5);--shadow-glow: 0 0 0 3px rgba(var(--color-primary-rgb), .28), 0 0 20px rgba(var(--color-primary-rgb), .14);--shadow-card: 0 0 0 1px rgba(255,255,255,.04), 0 1px 4px rgba(0,0,0,.5), 0 4px 16px rgba(0,0,0,.4);--shadow-card-hover: 0 0 0 1px rgba(var(--color-primary-rgb),.2), 0 8px 32px rgba(0,0,0,.65);--shadow-primary: 0 4px 14px rgba(var(--color-primary-rgb), .4);--shadow-primary-lg: 0 8px 28px rgba(var(--color-primary-rgb), .5);--shadow-topbar: 0 1px 0 var(--border-base), 0 2px 12px rgba(0,0,0,.4)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:14px;-webkit-text-size-adjust:100%;tab-size:4;scroll-behavior:smooth}html,body{height:100%}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:var(--text-primary);background:var(--surface-bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.55;transition:background .3s ease,color .3s ease;font-feature-settings:"cv02","cv03","cv04","cv11";letter-spacing:-.005em}img,svg{display:block;max-width:100%}a{color:var(--color-primary);text-decoration:none;transition:color .12s ease}button,input,select,textarea{font-family:inherit;font-size:inherit}code{font-family:JetBrains Mono,Fira Code,Cascadia Code,Courier New,monospace}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:9999px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}*{scrollbar-width:thin;scrollbar-color:var(--border-strong) transparent}:root{--bs-font-sans-serif: Inter, -apple-system, BlinkMacSystemFont, Segoe UI, sans-serif;--bs-body-font-family: Inter, -apple-system, BlinkMacSystemFont, Segoe UI, sans-serif}.page__title{font-size:1.5rem;font-weight:800;color:var(--text-primary);letter-spacing:-.04em;line-height:1.15;margin:0}.page__subtitle{font-size:13px;color:var(--text-muted);margin-top:5px;line-height:1.65;font-weight:400;letter-spacing:0}.section-title{font-size:15px;font-weight:700;color:var(--text-primary);letter-spacing:-.02em;margin:0}.label-xs{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted)}.code-chip{font-family:JetBrains Mono,Fira Code,Cascadia Code,monospace;background:var(--color-primary-light);color:var(--color-primary);padding:2px 8px;border-radius:5px;font-size:12px;font-weight:600;letter-spacing:.02em;border:1px solid rgba(var(--color-primary-rgb),.2)}.amount-cell{font-variant-numeric:tabular-nums;font-weight:600;white-space:nowrap;letter-spacing:-.02em}.text-credit{color:var(--color-success)!important}.text-debit{color:var(--color-danger)!important}.text-muted-color{color:var(--text-muted)!important}.text-subtle{color:var(--text-secondary)!important}.font-mono{font-family:JetBrains Mono,monospace}.font-tabular{font-variant-numeric:tabular-nums}.credit{color:var(--color-success)!important}.debit{color:var(--color-danger)!important}.page{padding:32px 36px;max-width:1440px}@media(max-width:768px){.page{padding:20px 16px}}.page__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:32px;gap:16px;flex-wrap:wrap;align-items:flex-start}.card{background:var(--surface-card);border:1px solid var(--border-base);border-radius:14px;box-shadow:var(--shadow-card);padding:28px;margin-bottom:20px;transition:box-shadow .26s cubic-bezier(.16,1,.3,1),border-color .26s cubic-bezier(.16,1,.3,1)}.card:hover{box-shadow:var(--shadow-card-hover)}.card--no-padding{padding:0;overflow:hidden}.card--flat{box-shadow:none;border-color:var(--border-base)}.card--flat:hover{box-shadow:none}.card--accent-top{border-top:3px solid var(--color-primary)}.card--accent-left{border-left:3px solid var(--color-primary)}.card--glow{background:var(--surface-card);border:1px solid var(--border-base);border-radius:14px;box-shadow:var(--shadow-card);padding:28px;margin-bottom:20px;transition:box-shadow .26s cubic-bezier(.16,1,.3,1),border-color .26s cubic-bezier(.16,1,.3,1)}.card--glow:hover{box-shadow:var(--shadow-card-hover),0 0 28px rgba(var(--color-primary-rgb),.07);border-color:rgba(var(--color-primary-rgb),.2)}.card__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:22px;gap:12px;flex-wrap:wrap}.card__title{font-size:.9375rem;font-weight:700;color:var(--text-primary);margin:0 0 18px;letter-spacing:-.02em;line-height:1.3}.card__header .card__title{margin-bottom:0}.card__desc{font-size:13px;color:var(--text-muted);line-height:1.65;margin:-10px 0 18px}.section-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--border-base)}.two-col-layout{display:grid;grid-template-columns:1fr 1fr;gap:20px;align-items:start}@media(max-width:768px){.two-col-layout{grid-template-columns:1fr}}.sidebar-layout{display:grid;grid-template-columns:360px 1fr;gap:20px;align-items:start}@media(max-width:1024px){.sidebar-layout{grid-template-columns:1fr}}.auto-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:20px}.stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:28px}.stat-card{background:var(--surface-card);border:1px solid var(--border-base);border-radius:14px;box-shadow:var(--shadow-card);padding:22px 24px;display:flex;flex-direction:column;gap:6px;position:relative;overflow:hidden;transition:box-shadow .26s cubic-bezier(.16,1,.3,1),border-color .26s cubic-bezier(.16,1,.3,1),transform .26s cubic-bezier(.16,1,.3,1)}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--color-primary),rgba(var(--color-primary-rgb),.2));border-radius:14px 14px 0 0;opacity:.8}.stat-card:after{content:"";position:absolute;width:100px;height:100px;border-radius:50%;background:radial-gradient(circle,rgba(var(--color-primary-rgb),.06) 0%,transparent 70%);right:-20px;bottom:-20px;pointer-events:none}.stat-card:hover{box-shadow:var(--shadow-card-hover);transform:translateY(-2px);border-color:rgba(var(--color-primary-rgb),.1)}.stat-card__icon{width:36px;height:36px;border-radius:10px;background:var(--color-primary-light);color:var(--color-primary);display:flex;align-items:center;justify-content:center;margin-bottom:10px;flex-shrink:0}.stat-card__icon .material-symbols-rounded{font-size:18px;font-variation-settings:"FILL" 1,"wght" 500,"GRAD" 0,"opsz" 20}.stat-card__label{font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);margin-bottom:4px}.stat-card__value{font-size:1.75rem;font-weight:800;color:var(--text-primary);font-variant-numeric:tabular-nums;letter-spacing:-.045em;line-height:1.1}.stat-card__sub{font-size:12px;color:var(--text-muted);margin-top:3px;font-weight:500}.stat-card__delta{display:inline-flex;align-items:center;gap:3px;font-size:12px;font-weight:600;margin-top:4px}.stat-card__delta--up{color:var(--color-success)}.stat-card__delta--down{color:var(--color-danger)}.divider{height:1px;background:var(--border-base);margin:24px 0}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:64px 24px;color:var(--text-muted);font-size:14px;gap:12px;text-align:center}.empty-state__icon{font-size:40px;opacity:.3;line-height:1}.empty-state__title{font-size:15px;font-weight:600;color:var(--text-secondary)}.pagination{display:flex;align-items:center;justify-content:center;gap:12px;padding:20px 18px;border-top:1px solid var(--border-base)}.pagination__info{font-size:13px;color:var(--text-muted);font-weight:500;min-width:80px;text-align:center}.filter-bar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;padding:16px 24px;background:var(--surface-bg);border-bottom:1px solid var(--border-base)}.content-section{margin-bottom:32px}.form-row{display:flex;gap:14px;margin-bottom:18px;flex-wrap:wrap}.form-field{display:flex;flex-direction:column;gap:6px;flex:1;min-width:180px}.form-field--full{flex:0 0 100%;min-width:0}.form-field--sm{flex:0 0 120px;min-width:0}.form-group{display:flex;flex-direction:column;gap:6px;flex:1;min-width:160px}.form-group--sm{flex:0 0 110px;min-width:0}.form-group--check,.form-group--action{flex:0 0 auto}.form-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:14px;padding-top:6px}.form-label{font-size:12.5px;font-weight:600;color:var(--text-secondary);letter-spacing:.005em;margin:0}.required{color:var(--color-danger);margin-left:2px}.form-input{width:100%;height:40px;padding:0 13px;border:1.5px solid var(--border-base);border-radius:10px;font-size:13.5px;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:var(--text-primary);background:var(--surface-input);outline:none;-webkit-appearance:none;appearance:none;transition:border-color .18s ease,box-shadow .18s ease,background .18s ease}.form-input::placeholder{color:var(--text-placeholder)}.form-input:hover:not(:focus):not(:disabled){border-color:var(--border-strong);background:var(--surface-card)}.form-input:focus{outline:none;box-shadow:var(--shadow-glow);border-color:var(--color-primary)!important;background:var(--surface-input-focus)}.form-input:disabled{opacity:.4;cursor:not-allowed;background:var(--surface-subtle)}.form-select{width:100%;height:40px;padding:0 13px;border:1.5px solid var(--border-base);border-radius:10px;font-size:13.5px;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:var(--text-primary);background:var(--surface-input);outline:none;-webkit-appearance:none;appearance:none;transition:border-color .18s ease,box-shadow .18s ease,background .18s ease}.form-select::placeholder{color:var(--text-placeholder)}.form-select:hover:not(:focus):not(:disabled){border-color:var(--border-strong);background:var(--surface-card)}.form-select:focus{outline:none;box-shadow:var(--shadow-glow);border-color:var(--color-primary)!important;background:var(--surface-input-focus)}.form-select:disabled{opacity:.4;cursor:not-allowed;background:var(--surface-subtle)}.form-select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' 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/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px;cursor:pointer}.form-input--error,.form-input--error:focus{border-color:var(--color-danger)!important;box-shadow:0 0 0 3px #ef44441f!important;background:var(--color-danger-bg)!important}.form-input--compact{width:160px;flex:none}.form-select--compact{width:190px;flex:none}.form-input--sm{height:34px;font-size:13px;padding:0 9px}.form-input--inline{display:inline-block;width:80px}.form-input--textarea{height:auto;min-height:90px;padding:10px 13px;resize:vertical;line-height:1.5}.form-error{font-size:12px;color:var(--color-danger);font-weight:500;display:flex;align-items:center;gap:4px}.form-hint{font-size:12px;color:var(--color-info-text);font-weight:500}.field-error{font-size:12px;color:var(--color-danger);font-weight:500}.toggle{display:inline-flex;align-items:center;cursor:pointer;gap:8px}.toggle input{position:absolute;opacity:0;width:0;height:0}.toggle__track{width:40px;height:22px;background:var(--border-strong);border-radius:9999px;position:relative;transition:background .18s ease;flex-shrink:0}.toggle__track:after{content:"";position:absolute;top:3px;left:3px;width:16px;height:16px;background:#fff;border-radius:50%;transition:transform .26s cubic-bezier(.16,1,.3,1),background .18s ease;box-shadow:0 1px 3px #0003}.toggle input:checked+.toggle__track{background:var(--color-primary);box-shadow:0 0 8px rgba(var(--color-primary-rgb),.3)}.toggle input:checked+.toggle__track:after{transform:translate(18px);background:#fff}.toggle:hover .toggle__track{border:1.5px solid rgba(var(--color-primary-rgb),.5)}.perm-label{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text-secondary);cursor:pointer;white-space:nowrap;padding:4px 0}.perm-label input[type=checkbox]{width:15px;height:15px;cursor:pointer;accent-color:var(--color-primary)}.perm-label--sm{font-size:12px}.permissions-grid{display:flex;flex-wrap:wrap;gap:4px 16px;padding:12px;background:var(--surface-bg);border-radius:10px;border:1px solid var(--border-base);margin-top:4px}.permissions-grid--sm{gap:2px 10px;padding:8px}.search-input{width:100%;height:40px;padding:0 13px;border:1.5px solid var(--border-base);border-radius:10px;font-size:13.5px;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:var(--text-primary);background:var(--surface-input);outline:none;-webkit-appearance:none;appearance:none;transition:border-color .18s ease,box-shadow .18s ease,background .18s ease}.search-input::placeholder{color:var(--text-placeholder)}.search-input:hover:not(:focus):not(:disabled){border-color:var(--border-strong);background:var(--surface-card)}.search-input:focus{outline:none;box-shadow:var(--shadow-glow);border-color:var(--color-primary)!important;background:var(--surface-input-focus)}.search-input:disabled{opacity:.4;cursor:not-allowed;background:var(--surface-subtle)}.search-input{padding-left:38px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cline x1='21' y1='21' x2='16.65' y2='16.65'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:12px center}.pct-label{color:var(--text-muted);font-size:13px;margin-left:2px;font-weight:600}.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;border:none;border-radius:10px;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-weight:600;cursor:pointer;text-decoration:none;transition:all .18s ease;white-space:nowrap;letter-spacing:.01em;line-height:1}.btn:disabled{opacity:.45;cursor:not-allowed;pointer-events:none}.btn:focus-visible{outline:none;box-shadow:var(--shadow-glow);border-color:var(--color-primary)!important}.btn{height:38px;padding:0 18px;font-size:13.5px}.btn--primary{background:var(--color-primary);color:var(--text-on-primary);box-shadow:var(--shadow-primary);border:1px solid transparent}.btn--primary:hover:not(:disabled){background:var(--color-primary-hover);box-shadow:var(--shadow-primary-lg);transform:translateY(-1px)}.btn--primary:active:not(:disabled){transform:translateY(0);box-shadow:var(--shadow-primary)}.btn--danger{background:var(--color-danger);color:#fff;border:1px solid transparent;box-shadow:0 2px 8px #ef444447}.btn--danger:hover:not(:disabled){background:var(--color-danger-dark);box-shadow:0 6px 18px #ef444461;transform:translateY(-1px)}.btn--danger:active:not(:disabled){transform:translateY(0)}.btn--success{background:var(--color-success);color:#fff;border:1px solid transparent;box-shadow:0 2px 8px #10b98147}.btn--success:hover:not(:disabled){background:var(--color-success-dark);box-shadow:0 6px 18px #10b98161;transform:translateY(-1px)}.btn--warning{background:var(--color-warning);color:#fff;border:1px solid transparent;box-shadow:0 2px 8px #f59e0b47}.btn--warning:hover:not(:disabled){background:var(--color-warning-dark);box-shadow:0 6px 18px #f59e0b61;transform:translateY(-1px)}.btn--ghost{background:transparent;color:var(--text-secondary);border:1px solid var(--border-base)}.btn--ghost:hover:not(:disabled){background:var(--surface-subtle);border-color:var(--border-strong);color:var(--text-primary)}.btn--secondary{background:var(--surface-subtle);color:var(--text-secondary);border:1px solid var(--border-base)}.btn--secondary:hover:not(:disabled){background:var(--border-base);color:var(--text-primary);border-color:var(--border-strong)}.btn--soft-primary{background:var(--color-primary-light);color:var(--color-primary);border:1px solid rgba(var(--color-primary-rgb),.2)}.btn--soft-primary:hover:not(:disabled){background:var(--color-primary);color:#fff;box-shadow:var(--shadow-primary);border-color:transparent}.btn--sm{height:32px;padding:0 13px;font-size:12.5px;border-radius:6px}.btn--lg{height:44px;padding:0 24px;font-size:15px}.btn--xs{height:26px;padding:0 10px;font-size:11.5px;border-radius:6px}.btn--icon{width:38px;padding:0}.btn--icon.btn--sm{width:32px;padding:0}.alert{display:flex;align-items:flex-start;gap:10px;padding:13px 16px;border-radius:10px;font-size:13.5px;font-weight:500;margin-bottom:16px;line-height:1.55;border:1px solid transparent}.alert--success,.success-banner{background:var(--color-success-bg);border:1px solid var(--color-success-border);color:var(--color-success-text);border-left:3px solid var(--color-success)}.alert--error,.error-banner{background:var(--color-danger-bg);border:1px solid var(--color-danger-border);color:var(--color-danger-text);border-left:3px solid var(--color-danger)}.alert--warning,.warning-banner{background:var(--color-warning-bg);border:1px solid var(--color-warning-border);color:var(--color-warning-text);border-left:3px solid var(--color-warning)}.alert--info,.info-banner{background:var(--color-info-bg);border:1px solid var(--color-info-border);color:var(--color-info-text);border-left:3px solid var(--color-info)}.viewer-notice,.role-notice{display:flex;align-items:center;gap:10px;padding:11px 16px;background:var(--color-warning-bg);border:1px solid var(--color-warning-border);border-left:3px solid var(--color-warning);border-radius:10px;color:var(--color-warning-text);font-size:13px;font-weight:500;margin-bottom:16px}.allocation-banner{display:flex;align-items:center;gap:8px;padding:11px 16px;border-radius:10px;font-size:13.5px;font-weight:500;margin-bottom:18px}.allocation-banner--ok{background:var(--color-success-bg);border:1px solid var(--color-success-border);border-left:3px solid var(--color-success);color:var(--color-success-text)}.allocation-banner--warn{background:var(--color-warning-bg);border:1px solid var(--color-warning-border);border-left:3px solid var(--color-warning);color:var(--color-warning-text)}.allocation-label{opacity:.8}.allocation-value{font-weight:800;font-size:1.1rem}.allocation-hint{font-style:italic;opacity:.75;font-size:12.5px}.rate-panel{background:var(--surface-subtle);border:1px solid var(--border-base);border-radius:14px;padding:16px 20px;margin-bottom:16px}.rate-panel__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;gap:12px;flex-wrap:wrap}.rate-panel__label{font-size:13px;font-weight:600;color:var(--text-secondary)}.rate-panel__note{font-size:12px;color:var(--text-muted);margin-top:10px;font-style:italic}.rate-hint{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--color-info-bg);border:1px solid var(--color-info-border);border-radius:6px;color:var(--color-info-text);font-size:12.5px;font-weight:500;margin-bottom:4px}.rate-hint--stale{background:var(--color-warning-bg);border-color:var(--color-warning-border);color:var(--color-warning-text)}.pkr-preview{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;background:var(--color-primary-light);border:1px solid rgba(var(--color-primary-rgb),.2);border-radius:10px;font-size:13.5px;color:var(--color-primary);font-weight:500;margin-top:8px}.pkr-preview strong{font-weight:700;letter-spacing:-.02em}.foreign-amount{color:var(--text-muted);font-size:12.5px}.arrow{color:var(--text-muted);margin:0 4px;font-size:12px}.loading-text{color:var(--text-muted);font-size:13.5px;padding:12px 0}.table-filter-row{display:flex;align-items:center;gap:12px;padding:16px 20px;background:var(--surface-bg);border-bottom:1px solid var(--border-base);flex-wrap:wrap}.page__title{font-size:1.375rem;font-weight:700;color:var(--text-primary);letter-spacing:-.025em;margin:0 0 2px}.page__subtitle{font-size:13px;color:var(--text-muted);margin:0}.page__actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.tab-bar{display:flex;background:var(--surface-subtle);border:1px solid var(--border-base);border-radius:10px;padding:3px;gap:2px}.tab-bar__btn{display:flex;align-items:center;gap:6px;padding:6px 14px;border-radius:8px;border:none;background:transparent;color:var(--text-muted);font-size:13px;font-weight:500;font-family:inherit;cursor:pointer;transition:background .12s ease,color .12s ease,box-shadow .12s ease;white-space:nowrap}.tab-bar__btn .material-symbols-rounded{font-size:15px;font-variation-settings:"FILL" 0,"wght" 300,"GRAD" 0,"opsz" 20}.tab-bar__btn:hover{color:var(--text-primary)}.tab-bar__btn--active{background:var(--surface-card);color:var(--color-primary);box-shadow:var(--shadow-sm);font-weight:600}.tab-bar__btn--active .material-symbols-rounded{font-variation-settings:"FILL" 1,"wght" 400,"GRAD" 0,"opsz" 20}.toolbar{display:flex;align-items:center;gap:10px;margin-bottom:16px;flex-wrap:wrap}.toolbar__select{max-width:180px}.toolbar__month{max-width:160px}.search-wrap{position:relative;display:flex;align-items:center}.search-wrap__icon{position:absolute;left:10px;font-size:15px;color:var(--text-muted);pointer-events:none;font-variation-settings:"FILL" 0,"wght" 300,"GRAD" 0,"opsz" 20}.search-wrap__input{padding-left:34px!important;min-width:240px}.toggle-label{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:500;color:var(--text-secondary);cursor:pointer;-webkit-user-select:none;user-select:none}.toggle-label input[type=checkbox]{cursor:pointer;accent-color:var(--color-primary);width:14px;height:14px}.loading-row{display:flex;align-items:center;justify-content:center;gap:10px;padding:48px 24px;color:var(--text-muted);font-size:14px}.table-footer{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;border-top:1px solid var(--border-base);font-size:13px;color:var(--text-muted)}.row--inactive{opacity:.5}.row-matched{background:rgba(var(--color-primary-rgb),.04)!important}.row-reconciled{background:#10b9810d!important}.row-excluded{opacity:.4}.icon-btn{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border:none;border-radius:6px;background:transparent;color:var(--text-muted);cursor:pointer;transition:background .12s ease,color .12s ease,transform .12s ease;flex-shrink:0}.icon-btn .material-symbols-rounded{font-size:16px;font-variation-settings:"FILL" 0,"wght" 300,"GRAD" 0,"opsz" 20}.icon-btn:hover{background:var(--surface-subtle);color:var(--text-primary);transform:translateY(-1px)}.icon-btn:active{transform:translateY(0)}.icon-btn--primary:hover{background:var(--color-primary-light);color:var(--color-primary)}.icon-btn--success:hover{background:var(--color-success-bg);color:var(--color-success)}.icon-btn--danger:hover{background:var(--color-danger-bg);color:var(--color-danger)}.col-actions{display:flex;align-items:center;gap:2px;justify-content:flex-end;white-space:nowrap}.col-check{width:36px;padding-right:0!important}.col-check input[type=checkbox]{accent-color:var(--color-primary);cursor:pointer}.mono{font-family:JetBrains Mono,Fira Code,monospace;font-size:12.5px}.fw-medium{font-weight:500}.text-right{text-align:right}.text-primary{color:var(--text-primary)}.modal-overlay{position:fixed;inset:0;background:var(--surface-overlay);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);z-index:1050;animation:fade-in .18s ease both}.modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--surface-card);border:1px solid var(--border-base);border-radius:14px;width:640px;max-width:calc(100vw - 32px);max-height:calc(100vh - 48px);overflow-y:auto;z-index:1051;box-shadow:var(--shadow-xl);display:flex;flex-direction:column;animation:modal-in .28s cubic-bezier(.16,1,.3,1) both;scrollbar-width:thin}.modal--lg{width:800px}.modal--sm{width:440px}.modal__header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 18px;border-bottom:1px solid var(--border-base);flex-shrink:0}.modal__title{font-size:15px;font-weight:700;color:var(--text-primary);margin:0;letter-spacing:-.02em}.modal__body{padding:24px;flex:1;overflow-y:auto}.modal__footer{display:flex;justify-content:flex-end;gap:8px;padding:16px 24px;border-top:1px solid var(--border-base);flex-shrink:0;background:var(--surface-bg);border-radius:0 0 14px 14px}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes modal-in{0%{opacity:0;transform:translate(-50%,calc(-50% + 16px)) scale(.97)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.form-hint{font-size:12px;font-weight:500}.form-hint--error{color:var(--color-danger)}.form-hint--info{color:var(--text-muted)}.form-field--center{justify-content:center}.flex-1{flex:1}.flex-2{flex:2}.flex-3{flex:3}.form-actions{display:flex;justify-content:flex-end;gap:8px;padding-top:16px;border-top:1px solid var(--border-base);margin-top:16px}.form-actions--top{border-top:none;margin-top:12px;padding-top:0;justify-content:flex-start}.total-strip{display:flex;align-items:center;justify-content:flex-end;gap:16px;padding:14px 16px;background:var(--surface-subtle);border-radius:10px;border:1px solid var(--border-base);margin:12px 0 20px}.total-strip__label{font-size:13px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.total-strip__value{font-size:1.25rem;font-weight:800;color:var(--text-primary);letter-spacing:-.03em;font-variant-numeric:tabular-nums}.line-table{border:1px solid var(--border-base);border-radius:10px;overflow:hidden;margin-bottom:20px;background:var(--surface-card)}.line-table__head{display:grid;grid-template-columns:1fr 72px 100px 72px 140px 100px 32px;gap:0;padding:10px 12px;background:var(--surface-bg);border-bottom:1px solid var(--border-base);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);align-items:center}.line-table__row{display:grid;grid-template-columns:1fr 72px 100px 72px 140px 100px 32px;gap:0;padding:8px 12px;border-bottom:1px solid var(--border-base);align-items:center}.line-table__row:last-of-type{border-bottom:none}.line-table__row .form-input,.line-table__row .form-select{border-radius:6px;border-color:transparent;background:var(--surface-input);padding:6px 8px;font-size:13px;height:34px}.line-table__row .form-input:focus,.line-table__row .form-select:focus{border-color:var(--border-focus);background:var(--surface-card)}.bill-line-table__head,.bill-line-table__row{grid-template-columns:1fr 64px 90px 64px 130px 72px 90px 32px}.add-line-btn{margin:8px 12px;font-size:13px}.stat-card--info:before{background:linear-gradient(90deg,var(--color-info),rgba(59,130,246,.2))}.stat-card--info .stat-card__icon{background:var(--color-info-bg);color:var(--color-info)}.stat-card--danger:before{background:linear-gradient(90deg,var(--color-danger),rgba(239,68,68,.2))}.stat-card--danger .stat-card__icon{background:var(--color-danger-bg);color:var(--color-danger)}.stat-card--warning:before{background:linear-gradient(90deg,var(--color-warning),rgba(245,158,11,.2))}.stat-card--warning .stat-card__icon{background:var(--color-warning-bg);color:var(--color-warning)}.stat-card--success:before{background:linear-gradient(90deg,var(--color-success),rgba(16,185,129,.2))}.stat-card--success .stat-card__icon{background:var(--color-success-bg);color:var(--color-success)}.pwa-banner{position:fixed;bottom:20px;left:50%;transform:translate(-50%);z-index:8000;display:flex;align-items:center;gap:14px;padding:14px 18px;background:var(--surface-card);border:1px solid var(--border-base);border-top:3px solid var(--color-primary);border-radius:16px;box-shadow:0 12px 40px -8px #00000047,0 4px 12px -4px #0000001f;max-width:min(480px,100vw - 32px);width:100%;animation:pwa-banner-in .4s cubic-bezier(.16,1,.3,1) both}.pwa-banner__icon{flex-shrink:0;width:44px;height:44px;border-radius:12px;background:linear-gradient(135deg,#6366f1,#4f46e5 60%,#3730a3);display:flex;align-items:center;justify-content:center}.pwa-banner__icon .material-symbols-rounded{font-size:24px;color:#fff;font-variation-settings:"FILL" 1,"wght" 500,"GRAD" 0,"opsz" 24}.pwa-banner__content{flex:1;min-width:0}.pwa-banner__title{font-size:13.5px;font-weight:700;color:var(--text-primary);margin:0 0 2px;line-height:1.3}.pwa-banner__desc{font-size:12px;color:var(--text-muted);margin:0;line-height:1.4}.pwa-banner__actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.pwa-banner__install{padding:8px 18px;background:var(--color-primary);color:#fff;border:none;border-radius:10px;font-size:13px;font-weight:600;cursor:pointer;transition:background .15s,transform .12s;white-space:nowrap;min-width:72px}.pwa-banner__install:hover:not(:disabled){background:var(--color-primary-dark);transform:translateY(-1px)}.pwa-banner__install:disabled{opacity:.6;cursor:default;transform:none}.pwa-banner__dismiss{display:flex;align-items:center;justify-content:center;width:30px;height:30px;border:1px solid var(--border-base);border-radius:8px;background:transparent;color:var(--text-muted);cursor:pointer;transition:background .15s,color .15s}.pwa-banner__dismiss .material-symbols-rounded{font-size:16px}.pwa-banner__dismiss:hover{background:var(--surface-subtle);color:var(--text-primary)}@keyframes pwa-banner-in{0%{opacity:0;transform:translate(-50%) translateY(24px) scale(.95)}to{opacity:1;transform:translate(-50%) translateY(0) scale(1)}}@media(max-width:480px){.pwa-banner{bottom:0;border-radius:16px 16px 0 0;left:0;right:0;transform:none;max-width:100%}@keyframes pwa-banner-in{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}}.data-table{width:100%;border-collapse:collapse;font-size:13.5px}.data-table thead{position:sticky;top:0;z-index:10}.data-table thead tr{background:var(--surface-bg);border-bottom:1.5px solid var(--border-base)}.data-table th{padding:12px 18px;text-align:left;font-size:10.5px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;white-space:nowrap;-webkit-user-select:none;user-select:none;background:var(--surface-bg)}.data-table td{padding:14px 18px;border-bottom:1px solid var(--border-subtle);color:var(--text-secondary);vertical-align:middle;transition:background .12s ease}.data-table tbody tr{transition:background .12s ease}.data-table tbody tr:hover{background:rgba(var(--color-primary-rgb),.025)}.data-table tbody tr:hover td{color:var(--text-primary)}.data-table tbody tr:last-child td{border-bottom:none}.data-table .row--credit td:first-child{border-left:2.5px solid var(--color-success);padding-left:15px}.data-table .row--debit td:first-child{border-left:2.5px solid var(--color-danger);padding-left:15px}.data-table .row--inactive{opacity:.42}.data-table .actions{display:flex;gap:6px;align-items:center;flex-wrap:wrap}.data-table td:first-child,.data-table td strong{color:var(--text-primary)}.data-table--compact th{padding:9px 14px}.data-table--compact td{padding:10px 14px}.note-cell{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:12.5px;color:var(--text-muted)}.table-container{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:0 0 14px 14px}.card--no-padding .data-table thead tr{border-radius:0}.card--no-padding .data-table tr:last-child td:first-child{border-radius:0 0 0 14px}.card--no-padding .data-table tr:last-child td:last-child{border-radius:0 0 14px}.badge,.direction-badge,.status-badge,.badge--no,.badge-no,.badge--yes,.badge-yes,.badge--role,.badge-role,.badge--inactive,.badge-inactive,.badge--active,.badge-active,.badge--neutral,.badge-neutral,.status-badge--neutral,.badge--info,.badge-info,.status-badge--info,.badge--warning,.badge-warning,.status-badge--pending,.badge--error,.badge-error,.badge-danger,.status-badge--error,.badge--success,.badge-success,.status-badge--success{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:600;padding:3px 9px;border-radius:9999px;white-space:nowrap;line-height:1.4;letter-spacing:.015em}.badge--success,.badge-success,.status-badge--success{background:var(--color-success-bg);color:var(--color-success-text);border:1px solid var(--color-success-border)}.badge--error,.badge-error,.badge-danger,.status-badge--error{background:var(--color-danger-bg);color:var(--color-danger-text);border:1px solid var(--color-danger-border)}.badge--warning,.badge-warning,.status-badge--pending{background:var(--color-warning-bg);color:var(--color-warning-text);border:1px solid var(--color-warning-border)}.badge--info,.badge-info,.status-badge--info{background:var(--color-info-bg);color:var(--color-info-text);border:1px solid var(--color-info-border)}.badge--neutral,.badge-neutral,.status-badge--neutral{background:var(--surface-bg);color:var(--text-secondary);border:1px solid var(--border-base)}.badge--active,.badge-active{background:var(--color-success-bg);color:var(--color-success-text);border:1px solid var(--color-success-border)}.badge--inactive,.badge-inactive{background:var(--color-danger-bg);color:var(--color-danger-text);border:1px solid var(--color-danger-border)}.badge--role,.badge-role{background:var(--color-primary-light);color:var(--color-primary);border:1px solid rgba(var(--color-primary-rgb),.2)}.badge--yes,.badge-yes{background:var(--color-success-bg);color:var(--color-success-text);border:1px solid var(--color-success-border)}.badge--no,.badge-no{background:var(--surface-bg);color:var(--text-muted);border:1px solid var(--border-base)}.direction-badge{font-weight:700;letter-spacing:.04em}.direction-badge--credit{background:var(--color-success-bg);color:var(--color-success-text);border:1px solid var(--color-success-border)}.direction-badge--debit{background:var(--color-danger-bg);color:var(--color-danger-text);border:1px solid var(--color-danger-border)}.tag{display:inline-flex;align-items:center;font-size:11.5px;font-weight:500;padding:2px 9px;border-radius:6px;background:var(--surface-subtle);color:var(--text-secondary);border:1px solid var(--border-base)}.category-tag{display:inline-flex;align-items:center;font-size:11.5px;font-weight:600;padding:3px 10px;border-radius:9999px;background:var(--color-primary-light);color:var(--color-primary);border:1px solid rgba(var(--color-primary-rgb),.2)}.type-tag{display:inline-flex;align-items:center;font-size:11.5px;font-weight:600;padding:3px 10px;border-radius:9999px;background:var(--surface-bg);color:var(--text-secondary);border:1px solid var(--border-base)}.perm-tags{display:flex;flex-wrap:wrap;gap:4px}.perm-tag{display:inline-flex;align-items:center;background:var(--color-primary-light);color:var(--color-primary);border-radius:4px;padding:2px 6px;font-size:11px;font-weight:600;border:1px solid rgba(var(--color-primary-rgb),.15)}.stale-badge{display:inline-flex;align-items:center;background:var(--color-warning-bg);color:var(--color-warning-text);font-size:10.5px;font-weight:700;padding:2px 7px;border-radius:9999px;border:1px solid var(--color-warning-border)}.fresh-badge{display:inline-flex;align-items:center;background:var(--color-success-bg);color:var(--color-success-text);font-size:10.5px;font-weight:700;padding:2px 7px;border-radius:9999px;border:1px solid var(--color-success-border)}.app-modal-backdrop{position:fixed;inset:0;background:var(--surface-overlay);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:1050;display:flex;align-items:center;justify-content:center;padding:24px;animation:app-backdrop-in .2s ease both}@keyframes app-backdrop-in{0%{opacity:0}to{opacity:1}}.app-modal{background:var(--surface-card);border:1px solid var(--border-base);border-radius:14px;box-shadow:var(--shadow-card);width:100%;max-width:560px;max-height:calc(100vh - 64px);overflow-y:auto}.app-modal::-webkit-scrollbar{width:5px;height:5px}.app-modal::-webkit-scrollbar-track{background:transparent}.app-modal::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:9999px}.app-modal::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.app-modal{scrollbar-width:thin;scrollbar-color:var(--border-strong) transparent;animation:app-modal-in .32s cubic-bezier(.16,1,.3,1) both;position:relative;z-index:1051;box-shadow:var(--shadow-xl)}@keyframes app-modal-in{0%{opacity:0;transform:translateY(20px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.app-modal--sm{max-width:420px}.app-modal--lg{max-width:720px}.app-modal--xl{max-width:960px}.app-modal__header{display:flex;align-items:center;justify-content:space-between;padding:24px 26px 0;margin-bottom:20px;gap:12px}.app-modal__title{font-size:1.0625rem;font-weight:700;color:var(--text-primary);letter-spacing:-.025em;margin:0}.app-modal__close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:6px;background:transparent;border:1px solid var(--border-base);color:var(--text-muted);cursor:pointer;font-size:18px;transition:background .18s ease,color .18s ease,border-color .18s ease}.app-modal__close:hover{background:var(--surface-subtle);border-color:var(--border-strong);color:var(--text-primary)}.app-modal__body{padding:0 26px 26px}.app-modal__footer{display:flex;align-items:center;justify-content:space-between;padding:18px 26px;border-top:1px solid var(--border-base);gap:10px;background:var(--surface-subtle);border-radius:0 0 14px 14px}.app-modal__footer .app-modal__footer-actions{display:flex;gap:8px;margin-left:auto}.app-confirm-modal{max-width:420px}.app-confirm-modal__icon{width:52px;height:52px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 16px;font-size:24px}.app-confirm-modal__icon--danger{background:var(--color-danger-bg)}.app-confirm-modal__icon--warning{background:var(--color-warning-bg)}.app-confirm-modal__text{text-align:center;font-size:14px;color:var(--text-secondary);line-height:1.6;margin-bottom:24px}.modal-error{display:flex;align-items:flex-start;gap:10px;padding:11px 14px;border-radius:6px;background:var(--color-danger-bg);border:1px solid var(--color-danger-border);color:var(--color-danger-text);font-size:13px;line-height:1.5;margin-bottom:16px}.modal-error__icon{flex-shrink:0;font-size:17px;margin-top:1px;font-variation-settings:"FILL" 1,"wght" 400,"GRAD" 0,"opsz" 20}.modal-error__text{flex:1}.result-card{background:var(--color-success-bg);border:1.5px solid var(--color-success-border);border-radius:14px;padding:18px 20px;margin-top:18px}.result-card__title{color:var(--color-success-text);font-size:14px;font-weight:700;margin:0 0 14px;display:flex;align-items:center;gap:8px}.result-card__stat{display:flex;justify-content:space-between;align-items:center;font-size:13.5px;padding:6px 0;color:var(--text-secondary);border-bottom:1px solid var(--color-success-border)}.result-card__stat:last-child{border-bottom:none}.result-card__divider{height:1px;background:var(--color-success-border);margin:10px 0}.result-card__sub{font-size:11px;font-weight:700;color:var(--color-success-text);text-transform:uppercase;letter-spacing:.08em;margin:0 0 10px}.status-result{display:flex;align-items:center;gap:14px;margin-top:16px;padding:14px 18px;border-radius:14px;font-size:14px;font-weight:500}.status-result--closed{background:var(--color-warning-bg);border:1.5px solid var(--color-warning-border);color:var(--color-warning-text)}.status-result--open{background:var(--color-success-bg);border:1.5px solid var(--color-success-border);color:var(--color-success-text)}.status-result__icon{font-size:22px}.notif-bell-wrapper{position:relative;display:inline-flex;align-items:center}.notif-badge{position:absolute;top:-4px;right:-4px;min-width:17px;height:17px;padding:0 4px;border-radius:99px;background:var(--color-danger);color:#fff;font-size:10px;font-weight:700;line-height:17px;text-align:center;pointer-events:none;animation:badge-pop .2s cubic-bezier(.175,.885,.32,1.275) both}@keyframes badge-pop{0%{transform:scale(.4);opacity:0}to{transform:scale(1);opacity:1}}.notif-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:380px;max-width:calc(100vw - 24px);background:var(--surface-card);border:1px solid var(--border-base);border-radius:14px;box-shadow:var(--shadow-lg, 0 16px 48px rgba(0, 0, 0, .18));z-index:2000;overflow:hidden;animation:dropdown-in .16s cubic-bezier(.16,1,.3,1) both}@media(max-width:480px){.notif-dropdown{right:-60px;width:calc(100vw - 24px)}}@keyframes dropdown-in{0%{opacity:0;transform:translateY(-8px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.notif-dropdown__header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px 12px;border-bottom:1px solid var(--border-base)}.notif-dropdown__title{font-size:14px;font-weight:700;color:var(--text-primary)}.notif-dropdown__mark-all-btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;border:none;border-radius:10px;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-weight:600;cursor:pointer;text-decoration:none;transition:all .18s ease;white-space:nowrap;letter-spacing:.01em;line-height:1}.notif-dropdown__mark-all-btn:disabled{opacity:.45;cursor:not-allowed;pointer-events:none}.notif-dropdown__mark-all-btn:focus-visible{outline:none;box-shadow:var(--shadow-glow);border-color:var(--color-primary)!important}.notif-dropdown__mark-all-btn{height:26px;padding:0 10px;font-size:11.5px;font-weight:600;color:var(--color-primary);background:var(--color-primary-light);border:1px solid rgba(var(--color-primary-rgb),.2);border-radius:6px}.notif-dropdown__mark-all-btn:hover{background:var(--color-primary);color:#fff}.notif-dropdown__list{max-height:380px;overflow-y:auto;overscroll-behavior:contain}.notif-dropdown__list::-webkit-scrollbar{width:4px}.notif-dropdown__list::-webkit-scrollbar-track{background:transparent}.notif-dropdown__list::-webkit-scrollbar-thumb{background:var(--border-strong, #cbd5e1);border-radius:2px}.notif-dropdown__empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:40px 20px;color:var(--text-muted);font-size:13px;text-align:center}.notif-dropdown__empty-icon{font-size:40px;color:var(--text-placeholder)}.notif-dropdown__footer{border-top:1px solid var(--border-base);padding:10px 16px}.notif-dropdown__view-all{display:flex;align-items:center;justify-content:center;gap:6px;font-size:13px;font-weight:600;color:var(--color-primary);text-decoration:none;padding:6px;border-radius:6px}.notif-dropdown__view-all .material-symbols-rounded{font-size:16px}.notif-dropdown__view-all:hover{background:var(--color-primary-light);text-decoration:none}.notif-item{position:relative;display:flex;align-items:flex-start;gap:12px;padding:12px 16px;cursor:pointer;transition:background .12s;border-bottom:1px solid var(--border-base)}.notif-item:last-child{border-bottom:none}.notif-item:hover{background:var(--surface-subtle)}.notif-item:hover .notif-item__delete-btn{opacity:1}.notif-item--unread{background:rgba(var(--color-primary-rgb),.04)}.notif-item--unread .notif-item__title{color:var(--text-primary);font-weight:700}.notif-item__icon-wrap{flex-shrink:0;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-top:2px}.notif-item__icon{font-size:18px}.notif-item__body{flex:1;min-width:0}.notif-item__title{font-size:13px;font-weight:600;color:var(--text-secondary);margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.notif-item__message{font-size:12.5px;color:var(--text-muted);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.notif-item__time{font-size:11px;color:var(--text-placeholder);margin-top:4px}.notif-item__dot{flex-shrink:0;width:8px;height:8px;border-radius:50%;background:var(--color-primary);margin-top:6px;align-self:flex-start}.notif-item__delete-btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;border:none;border-radius:10px;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-weight:600;cursor:pointer;text-decoration:none;transition:all .18s ease;white-space:nowrap;letter-spacing:.01em;line-height:1}.notif-item__delete-btn:disabled{opacity:.45;cursor:not-allowed;pointer-events:none}.notif-item__delete-btn:focus-visible{outline:none;box-shadow:var(--shadow-glow);border-color:var(--color-primary)!important}.notif-item__delete-btn{width:26px;height:26px;padding:0;border-radius:6px;flex-shrink:0;opacity:0;transition:opacity .12s,background .12s;color:var(--text-muted);align-self:flex-start;margin-top:2px}.notif-item__delete-btn .material-symbols-rounded{font-size:15px}.notif-item__delete-btn:hover{background:var(--color-danger-bg);color:var(--color-danger)}.notif--success{background:var(--color-success-bg)}.notif--success .notif-item__icon{color:var(--color-success)}.notif--danger{background:var(--color-danger-bg)}.notif--danger .notif-item__icon{color:var(--color-danger)}.notif--warning{background:var(--color-warning-bg)}.notif--warning .notif-item__icon{color:var(--color-warning)}.notif--info{background:var(--color-info-bg)}.notif--info .notif-item__icon{color:var(--color-info)}.notif-list-card .notif-item{border-radius:0}.notif-list-card .notif-item:first-child{border-radius:14px 14px 0 0}.notif-list-card .notif-item:last-child{border-radius:0 0 14px 14px;border-bottom:none}.notif-list-loading,.notif-list-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:80px 20px;color:var(--text-muted);font-size:14px;text-align:center}.notif-list-loading h3,.notif-list-empty h3{font-size:16px;font-weight:600;color:var(--text-secondary);margin:0}.notif-list-loading p,.notif-list-empty p{font-size:13px;color:var(--text-muted);margin:0}.notif-list-loading__icon,.notif-list-empty__icon{font-size:52px;color:var(--text-placeholder)}.notif-list-pagination{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:24px;padding:4px 0}.notif-list-pagination__info{font-size:13px;color:var(--text-muted);font-weight:500}.toast-stack{position:fixed;top:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:12px;max-width:400px;width:calc(100vw - 40px);pointer-events:none}.toast{position:relative;display:flex;align-items:flex-start;gap:14px;padding:16px 18px 20px;border-radius:14px;background:var(--surface-card);border:1px solid var(--border-base);box-shadow:0 8px 32px -4px #0000002e,0 2px 8px -2px #0000001a;pointer-events:all;overflow:hidden;animation:toast-in .35s cubic-bezier(.16,1,.3,1) both}.toast__icon-wrap{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:10px;margin-top:1px}.toast__icon{font-size:22px;font-variation-settings:"FILL" 1,"wght" 500,"GRAD" 0,"opsz" 24}.toast__body{flex:1;min-width:0;padding-top:2px}.toast__title{font-size:13.5px;font-weight:700;color:var(--text-primary);line-height:1.4;margin-bottom:2px}.toast__message{font-size:12.5px;color:var(--text-secondary);margin-top:3px;line-height:1.55;word-break:break-word}.toast__close{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:26px;height:26px;border:none;border-radius:8px;background:transparent;color:var(--text-muted);cursor:pointer;transition:background .12s ease,color .12s ease;margin-top:-1px;margin-right:-2px}.toast__close .material-symbols-rounded{font-size:15px}.toast__close:hover{background:var(--surface-subtle);color:var(--text-primary)}.toast__progress{position:absolute;bottom:0;left:0;height:3px;border-radius:0 0 14px 14px;animation:toast-progress linear forwards;animation-duration:var(--toast-duration, 4s);transform-origin:left}.toast--success .toast__icon-wrap{background:#16a34a1f}.toast--success .toast__icon{color:var(--color-success)}.toast--success .toast__title{color:var(--color-success-text)}.toast--success .toast__progress{background:var(--color-success)}.toast--success{border-top:3px solid var(--color-success)}.toast--error .toast__icon-wrap{background:#dc26261f}.toast--error .toast__icon{color:var(--color-danger)}.toast--error .toast__title{color:var(--color-danger-text)}.toast--error .toast__progress{background:var(--color-danger)}.toast--error{border-top:3px solid var(--color-danger)}.toast--warning .toast__icon-wrap{background:#eab3081f}.toast--warning .toast__icon{color:var(--color-warning)}.toast--warning .toast__title{color:var(--color-warning-text)}.toast--warning .toast__progress{background:var(--color-warning)}.toast--warning{border-top:3px solid var(--color-warning)}.toast--info .toast__icon-wrap{background:#3b82f61f}.toast--info .toast__icon{color:var(--color-info)}.toast--info .toast__title{color:var(--color-info-text)}.toast--info .toast__progress{background:var(--color-info)}.toast--info{border-top:3px solid var(--color-info)}@keyframes toast-in{0%{opacity:0;transform:translate(calc(100% + 20px)) scale(.95)}to{opacity:1;transform:translate(0) scale(1)}}@keyframes toast-out{0%{opacity:1;transform:translate(0) scale(1);max-height:200px;margin-bottom:0}to{opacity:0;transform:translate(calc(100% + 20px)) scale(.95);max-height:0;margin-bottom:-12px}}@keyframes toast-progress{0%{width:100%}to{width:0%}}.btn-spinner{display:inline-flex;align-items:center;gap:7px}.btn-spinner .spin{animation:spin .7s linear infinite;font-size:15px;line-height:1;font-variation-settings:"FILL" 0,"wght" 300,"GRAD" 0,"opsz" 20}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}:root{--bs-font-sans-serif: Inter, -apple-system, BlinkMacSystemFont, Segoe UI, sans-serif;--bs-body-font-family: Inter, -apple-system, BlinkMacSystemFont, Segoe UI, sans-serif;--bs-body-bg: var(--surface-bg);--bs-body-color: var(--text-primary);--bs-border-color: var(--border-base);--bs-border-radius: 10px;--bs-border-radius-sm: 6px;--bs-border-radius-lg: 14px;--bs-primary-rgb: var(--color-primary-rgb);--page-transition: .22s cubic-bezier(.16, 1, .3, 1)}router-outlet+*{animation:page-in var(--page-transition) both}@keyframes page-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
