:root,:host{--fa-font-solid:normal 900 1em/1 "Font Awesome 7 Free";--fa-font-regular:normal 400 1em/1 "Font Awesome 7 Free";--fa-font-light:normal 300 1em/1 "Font Awesome 7 Pro";--fa-font-thin:normal 100 1em/1 "Font Awesome 7 Pro";--fa-font-duotone:normal 900 1em/1 "Font Awesome 7 Duotone";--fa-font-duotone-regular:normal 400 1em/1 "Font Awesome 7 Duotone";--fa-font-duotone-light:normal 300 1em/1 "Font Awesome 7 Duotone";--fa-font-duotone-thin:normal 100 1em/1 "Font Awesome 7 Duotone";--fa-font-brands:normal 400 1em/1 "Font Awesome 7 Brands";--fa-font-sharp-solid:normal 900 1em/1 "Font Awesome 7 Sharp";--fa-font-sharp-regular:normal 400 1em/1 "Font Awesome 7 Sharp";--fa-font-sharp-light:normal 300 1em/1 "Font Awesome 7 Sharp";--fa-font-sharp-thin:normal 100 1em/1 "Font Awesome 7 Sharp";--fa-font-sharp-duotone-solid:normal 900 1em/1 "Font Awesome 7 Sharp Duotone";--fa-font-sharp-duotone-regular:normal 400 1em/1 "Font Awesome 7 Sharp Duotone";--fa-font-sharp-duotone-light:normal 300 1em/1 "Font Awesome 7 Sharp Duotone";--fa-font-sharp-duotone-thin:normal 100 1em/1 "Font Awesome 7 Sharp Duotone";--fa-font-slab-regular:normal 400 1em/1 "Font Awesome 7 Slab";--fa-font-slab-press-regular:normal 400 1em/1 "Font Awesome 7 Slab Press";--fa-font-whiteboard-semibold:normal 600 1em/1 "Font Awesome 7 Whiteboard";--fa-font-thumbprint-light:normal 300 1em/1 "Font Awesome 7 Thumbprint";--fa-font-notdog-solid:normal 900 1em/1 "Font Awesome 7 Notdog";--fa-font-notdog-duo-solid:normal 900 1em/1 "Font Awesome 7 Notdog Duo";--fa-font-etch-solid:normal 900 1em/1 "Font Awesome 7 Etch";--fa-font-graphite-thin:normal 100 1em/1 "Font Awesome 7 Graphite";--fa-font-jelly-regular:normal 400 1em/1 "Font Awesome 7 Jelly";--fa-font-jelly-fill-regular:normal 400 1em/1 "Font Awesome 7 Jelly Fill";--fa-font-jelly-duo-regular:normal 400 1em/1 "Font Awesome 7 Jelly Duo";--fa-font-chisel-regular:normal 400 1em/1 "Font Awesome 7 Chisel";--fa-font-utility-semibold:normal 600 1em/1 "Font Awesome 7 Utility";--fa-font-utility-duo-semibold:normal 600 1em/1 "Font Awesome 7 Utility Duo";--fa-font-utility-fill-semibold:normal 600 1em/1 "Font Awesome 7 Utility Fill"}.svg-inline--fa{box-sizing:content-box;display:var(--fa-display,inline-block);vertical-align:-.125em;height:1em;width:var(--fa-width,1.25em);overflow:visible}.svg-inline--fa.fa-2xs{vertical-align:.1em}.svg-inline--fa.fa-xs{vertical-align:0}.svg-inline--fa.fa-sm{vertical-align:-.0714286em}.svg-inline--fa.fa-lg{vertical-align:-.2em}.svg-inline--fa.fa-xl{vertical-align:-.25em}.svg-inline--fa.fa-2xl{vertical-align:-.3125em}.svg-inline--fa.fa-pull-left,.svg-inline--fa .fa-pull-start{float:inline-start;margin-inline-end:var(--fa-pull-margin,.3em)}.svg-inline--fa.fa-pull-right,.svg-inline--fa .fa-pull-end{float:inline-end;margin-inline-start:var(--fa-pull-margin,.3em)}.svg-inline--fa.fa-li{width:var(--fa-li-width,2em);inset-block-start:.25em;inset-inline-start:calc(-1 * var(--fa-li-width,2em))}.fa-layers-counter,.fa-layers-text{text-align:center;display:inline-block;position:absolute}.fa-layers{text-align:center;vertical-align:-.125em;height:1em;width:var(--fa-width,1.25em);display:inline-block;position:relative}.fa-layers .svg-inline--fa{transform-origin:50%;margin:auto;position:absolute;inset:0}.fa-layers-text{transform-origin:50%;top:50%;left:50%;transform:translate(-50%,-50%)}.fa-layers-counter{background-color:var(--fa-counter-background-color,#ff253a);border-radius:var(--fa-counter-border-radius,1em);box-sizing:border-box;color:var(--fa-inverse,#fff);line-height:var(--fa-counter-line-height,1);max-width:var(--fa-counter-max-width,5em);min-width:var(--fa-counter-min-width,1.5em);padding:var(--fa-counter-padding,.25em .5em);right:var(--fa-right,0);text-overflow:ellipsis;top:var(--fa-top,0);transform:scale(var(--fa-counter-scale,.25));transform-origin:100% 0;overflow:hidden}.fa-layers-bottom-right{bottom:var(--fa-bottom,0);right:var(--fa-right,0);transform:scale(var(--fa-layers-scale,.25));transform-origin:100% 100%;top:auto}.fa-layers-bottom-left{bottom:var(--fa-bottom,0);left:var(--fa-left,0);transform:scale(var(--fa-layers-scale,.25));transform-origin:0 100%;top:auto;right:auto}.fa-layers-top-right{top:var(--fa-top,0);right:var(--fa-right,0);transform:scale(var(--fa-layers-scale,.25));transform-origin:100% 0}.fa-layers-top-left{left:var(--fa-left,0);right:auto;top:var(--fa-top,0);transform:scale(var(--fa-layers-scale,.25));transform-origin:0 0}.fa-1x{font-size:1em}.fa-2x{font-size:2em}.fa-3x{font-size:3em}.fa-4x{font-size:4em}.fa-5x{font-size:5em}.fa-6x{font-size:6em}.fa-7x{font-size:7em}.fa-8x{font-size:8em}.fa-9x{font-size:9em}.fa-10x{font-size:10em}.fa-2xs{vertical-align:.225em;font-size:.625em;line-height:.1em}.fa-xs{vertical-align:.125em;font-size:.75em;line-height:.0833333em}.fa-sm{vertical-align:.0535715em;font-size:.875em;line-height:.0714286em}.fa-lg{vertical-align:-.075em;font-size:1.25em;line-height:.05em}.fa-xl{vertical-align:-.125em;font-size:1.5em;line-height:.0416667em}.fa-2xl{vertical-align:-.1875em;font-size:2em;line-height:.03125em}.fa-width-auto{--fa-width:auto}.fa-fw,.fa-width-fixed{--fa-width:1.25em}.fa-ul{margin-inline-start:var(--fa-li-margin,2.5em);padding-inline-start:0;list-style-type:none}.fa-ul>li{position:relative}.fa-li{text-align:center;width:var(--fa-li-width,2em);line-height:inherit;position:absolute;inset-inline-start:calc(-1 * var(--fa-li-width,2em))}.fa-border{border-color:var(--fa-border-color,#eee);border-radius:var(--fa-border-radius,.1em);border-style:var(--fa-border-style,solid);border-width:var(--fa-border-width,.0625em);box-sizing:var(--fa-border-box-sizing,content-box);padding:var(--fa-border-padding,.1875em .25em)}.fa-pull-left,.fa-pull-start{float:inline-start;margin-inline-end:var(--fa-pull-margin,.3em)}.fa-pull-right,.fa-pull-end{float:inline-end;margin-inline-start:var(--fa-pull-margin,.3em)}.fa-beat{animation-name:fa-beat;animation-delay:var(--fa-animation-delay,0s);animation-direction:var(--fa-animation-direction,normal);animation-duration:var(--fa-animation-duration,1s);animation-iteration-count:var(--fa-animation-iteration-count,infinite);animation-timing-function:var(--fa-animation-timing,ease-in-out)}.fa-bounce{animation-name:fa-bounce;animation-delay:var(--fa-animation-delay,0s);animation-direction:var(--fa-animation-direction,normal);animation-duration:var(--fa-animation-duration,1s);animation-iteration-count:var(--fa-animation-iteration-count,infinite);animation-timing-function:var(--fa-animation-timing,cubic-bezier(.28, .84, .42, 1))}.fa-fade{animation-name:fa-fade;animation-delay:var(--fa-animation-delay,0s);animation-direction:var(--fa-animation-direction,normal);animation-duration:var(--fa-animation-duration,1s);animation-iteration-count:var(--fa-animation-iteration-count,infinite);animation-timing-function:var(--fa-animation-timing,cubic-bezier(.4, 0, .6, 1))}.fa-beat-fade{animation-name:fa-beat-fade;animation-delay:var(--fa-animation-delay,0s);animation-direction:var(--fa-animation-direction,normal);animation-duration:var(--fa-animation-duration,1s);animation-iteration-count:var(--fa-animation-iteration-count,infinite);animation-timing-function:var(--fa-animation-timing,cubic-bezier(.4, 0, .6, 1))}.fa-flip{animation-name:fa-flip;animation-delay:var(--fa-animation-delay,0s);animation-direction:var(--fa-animation-direction,normal);animation-duration:var(--fa-animation-duration,1s);animation-iteration-count:var(--fa-animation-iteration-count,infinite);animation-timing-function:var(--fa-animation-timing,ease-in-out)}.fa-shake{animation-name:fa-shake;animation-delay:var(--fa-animation-delay,0s);animation-direction:var(--fa-animation-direction,normal);animation-duration:var(--fa-animation-duration,1s);animation-iteration-count:var(--fa-animation-iteration-count,infinite);animation-timing-function:var(--fa-animation-timing,linear)}.fa-spin{animation-name:fa-spin;animation-delay:var(--fa-animation-delay,0s);animation-direction:var(--fa-animation-direction,normal);animation-duration:var(--fa-animation-duration,2s);animation-iteration-count:var(--fa-animation-iteration-count,infinite);animation-timing-function:var(--fa-animation-timing,linear)}.fa-spin-reverse{--fa-animation-direction:reverse}.fa-pulse,.fa-spin-pulse{animation-name:fa-spin;animation-direction:var(--fa-animation-direction,normal);animation-duration:var(--fa-animation-duration,1s);animation-iteration-count:var(--fa-animation-iteration-count,infinite);animation-timing-function:var(--fa-animation-timing,steps(8))}@media (prefers-reduced-motion:reduce){.fa-beat,.fa-bounce,.fa-fade,.fa-beat-fade,.fa-flip,.fa-pulse,.fa-shake,.fa-spin,.fa-spin-pulse{transition:none!important;animation:none!important}}@keyframes fa-beat{0%,90%{transform:scale(1)}45%{transform:scale(var(--fa-beat-scale,1.25))}}@keyframes fa-bounce{0%{transform:scale(1)translateY(0)}10%{transform:scale(var(--fa-bounce-start-scale-x,1.1), var(--fa-bounce-start-scale-y,.9)) translateY(0)}30%{transform:scale(var(--fa-bounce-jump-scale-x,.9), var(--fa-bounce-jump-scale-y,1.1)) translateY(var(--fa-bounce-height,-.5em))}50%{transform:scale(var(--fa-bounce-land-scale-x,1.05), var(--fa-bounce-land-scale-y,.95)) translateY(0)}57%{transform:scale(1, 1) translateY(var(--fa-bounce-rebound,-.125em))}64%{transform:scale(1)translateY(0)}to{transform:scale(1)translateY(0)}}@keyframes fa-fade{50%{opacity:var(--fa-fade-opacity,.4)}}@keyframes fa-beat-fade{0%,to{opacity:var(--fa-beat-fade-opacity,.4);transform:scale(1)}50%{opacity:1;transform:scale(var(--fa-beat-fade-scale,1.125))}}@keyframes fa-flip{50%{transform:rotate3d(var(--fa-flip-x,0), var(--fa-flip-y,1), var(--fa-flip-z,0), var(--fa-flip-angle,-180deg))}}@keyframes fa-shake{0%{transform:rotate(-15deg)}4%{transform:rotate(15deg)}8%,24%{transform:rotate(-18deg)}12%,28%{transform:rotate(18deg)}16%{transform:rotate(-22deg)}20%{transform:rotate(22deg)}32%{transform:rotate(-12deg)}36%{transform:rotate(12deg)}40%,to{transform:rotate(0)}}@keyframes fa-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.fa-rotate-90{transform:rotate(90deg)}.fa-rotate-180{transform:rotate(180deg)}.fa-rotate-270{transform:rotate(270deg)}.fa-flip-horizontal{transform:scaleX(-1)}.fa-flip-vertical{transform:scaleY(-1)}.fa-flip-both,.fa-flip-horizontal.fa-flip-vertical{transform:scale(-1)}.fa-rotate-by{transform:rotate(var(--fa-rotate-angle,0))}.svg-inline--fa .fa-primary{fill:var(--fa-primary-color,currentColor);opacity:var(--fa-primary-opacity,1)}.svg-inline--fa .fa-secondary{fill:var(--fa-secondary-color,currentColor);opacity:var(--fa-secondary-opacity,.4)}.svg-inline--fa.fa-swap-opacity .fa-primary{opacity:var(--fa-secondary-opacity,.4)}.svg-inline--fa.fa-swap-opacity .fa-secondary{opacity:var(--fa-primary-opacity,1)}.svg-inline--fa mask .fa-primary,.svg-inline--fa mask .fa-secondary{fill:#000}.svg-inline--fa.fa-inverse{fill:var(--fa-inverse,#fff)}.fa-stack{vertical-align:middle;width:2.5em;height:2em;line-height:2em;display:inline-block;position:relative}.fa-inverse{color:var(--fa-inverse,#fff)}.svg-inline--fa.fa-stack-1x{--fa-width:1.25em;height:1em;width:var(--fa-width)}.svg-inline--fa.fa-stack-2x{--fa-width:2.5em;height:2em;width:var(--fa-width)}.fa-stack-1x,.fa-stack-2x{z-index:var(--fa-stack-z-index,auto);margin:auto;position:absolute;inset:0}@font-face{font-family:Inter;src:url(fonts/inter-400.woff2)format("woff2");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:Inter;src:url(fonts/inter-600.woff2)format("woff2");font-weight:600;font-style:normal;font-display:swap}@font-face{font-family:Inter;src:url(fonts/inter-700.woff2)format("woff2");font-weight:700;font-style:normal;font-display:swap}:root{--sidebar-width:240px;--sidebar-collapsed-width:56px;--header-height:0px;--radius:6px;--radius-lg:10px;--shadow:0 1px 3px #0000001f, 0 1px 2px #00000014;--shadow-lg:0 4px 12px #00000026;--transition:.2s ease;--font-sans:"Inter", system-ui, -apple-system, "Segoe UI", sans-serif;--font-mono:"SFMono-Regular", Consolas, "Liberation Mono", monospace;--font-size-xs:.6875rem;--font-size-sm:.75rem;--font-size-base:.875rem;--font-size-lg:1rem;--bg-primary:#f8f9fa;--bg-secondary:#fff;--bg-tertiary:#e9ecef;--bg-hover:#f1f3f5;--bg-alt:#f0f2f5;--text-primary:#212529;--text-secondary:#495057;--text-muted:#868e96;--border:#dee2e6;--border-light:#e9ecef;--accent:#3b82f6;--accent-hover:#2563eb;--accent-light:#eff6ff;--accent-text:#1e40af;--danger:#ef4444;--danger-hover:#dc2626;--danger-light:#fef2f2;--success:#22c55e;--success-light:#f0fdf4;--warning:#f59e0b;--warning-light:#fffbeb;--sidebar-bg:#1e293b;--sidebar-text:#cbd5e1;--sidebar-hover:#334155;--sidebar-active:#3b82f6;--sidebar-active-bg:#1d4ed8;--sidebar-text-hover:#f1f5f9}[data-theme=dark]{--bg-primary:#0f172a;--bg-secondary:#1e293b;--bg-tertiary:#334155;--bg-hover:#293548;--bg-alt:#1a2537;--text-primary:#f1f5f9;--text-secondary:#cbd5e1;--text-muted:#64748b;--border:#334155;--border-light:#1e293b;--accent:#60a5fa;--accent-hover:#3b82f6;--accent-light:#1e3a5f;--accent-text:#93c5fd;--danger:#f87171;--danger-hover:#ef4444;--danger-light:#2d1515;--success:#4ade80;--success-light:#0f2d1a;--warning:#fbbf24;--warning-light:#2d1f00;--sidebar-bg:#0f172a;--sidebar-text:#94a3b8;--sidebar-hover:#1e293b;--sidebar-active:#60a5fa;--sidebar-active-bg:#1e3a5f}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{font-size:var(--font-size-base)}body{font-family:var(--font-sans);background:var(--bg-primary);color:var(--text-primary);min-height:100vh;line-height:1.5;display:flex}a{color:var(--accent);text-decoration:none}a:hover{color:var(--accent-hover);text-decoration:underline}#sidebar{width:var(--sidebar-width);background:var(--sidebar-bg);min-height:100vh;color:var(--sidebar-text);transition:width var(--transition);z-index:100;flex-direction:column;flex-shrink:0;display:flex;position:fixed;top:0;bottom:0;left:0;overflow-x:hidden}#sidebar.collapsed{width:var(--sidebar-collapsed-width)}#main-content{margin-left:var(--sidebar-width);min-height:100vh;transition:margin-left var(--transition);flex-direction:column;flex:1;display:flex}#sidebar.collapsed~#main-content{margin-left:var(--sidebar-collapsed-width)}#app-content{padding:24px;flex:1;padding-bottom:88px}.sidebar-header{border-bottom:1px solid #ffffff14;flex-shrink:0;justify-content:space-between;align-items:center;height:52px;padding:0 12px;display:flex}.sidebar-logo{font-size:var(--font-size-lg);color:var(--sidebar-text-hover);white-space:nowrap;font-weight:700;overflow:hidden}#sidebar.collapsed .sidebar-logo{display:none}.sidebar-logo-icon{color:#3b82f6;margin-right:6px}.sidebar-toggle{color:var(--sidebar-text);cursor:pointer;border-radius:var(--radius);background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;padding:4px;display:flex}.sidebar-toggle:hover{background:var(--sidebar-hover)}#sidebar.collapsed .sidebar-header{padding:0}#sidebar.collapsed .sidebar-toggle{justify-content:flex-start;width:calc(100% - 16px);margin:1px 8px;padding:8px 12px}#sidebar.collapsed .sidebar-toggle svg{flex-shrink:0;width:18px;height:18px}.plan-selector-wrap{border-bottom:1px solid #ffffff14;padding:12px}.plan-input-group{align-items:stretch;display:flex}.plan-input{background:var(--sidebar-hover);min-width:0;color:var(--sidebar-text);border-radius:var(--radius) 0 0 var(--radius);font-size:var(--font-size-sm);cursor:default;text-overflow:ellipsis;white-space:nowrap;border:1px solid #ffffff1f;border-right:none;flex:1;padding:8px;overflow:hidden}.plan-input:focus{outline:none}.plan-input-btn{background:var(--sidebar-hover);color:var(--sidebar-text);border-radius:0 var(--radius) var(--radius) 0;cursor:pointer;transition:background var(--transition), color var(--transition);border:1px solid #ffffff1f;flex-shrink:0;align-items:center;padding:0 10px;display:flex}.plan-input-btn:hover{background:var(--sidebar-active-bg);color:var(--sidebar-text-hover)}.plan-input-btn svg{width:14px;height:14px}#sidebar.collapsed .plan-selector-wrap,.plan-collapsed-wrap{display:none}#sidebar.collapsed .plan-collapsed-wrap{border-bottom:1px solid #ffffff14;justify-content:center;padding:8px 0;display:flex}.plan-collapsed-btn{color:var(--sidebar-text);cursor:pointer;border-radius:var(--radius);width:36px;height:36px;transition:background var(--transition), color var(--transition);background:0 0;border:none;justify-content:center;align-items:center;display:flex}.plan-collapsed-btn:hover{background:var(--sidebar-hover);color:var(--sidebar-text-hover)}.plan-collapsed-btn svg{width:16px;height:16px}.sidebar-nav{flex:1;padding:8px 0;overflow-y:auto}.nav-divider{border-top:1px solid #ffffff14;margin:8px 0}#sidebar.collapsed .nav-divider{opacity:0}.nav-item{color:var(--sidebar-text);cursor:pointer;border-radius:var(--radius);font-size:var(--font-size-base);white-space:nowrap;transition:background var(--transition), color var(--transition);user-select:none;align-items:center;gap:10px;margin:1px 8px;padding:8px 12px;display:flex}.nav-item:hover{background:var(--sidebar-hover);color:var(--sidebar-text-hover);text-decoration:none}.nav-item.active{background:var(--sidebar-active-bg);color:#fff}.nav-item svg{flex-shrink:0;width:18px;height:18px}.nav-item-label{overflow:hidden}#sidebar.collapsed .nav-item-label{display:none}.nav-item-arrow{transition:transform var(--transition);flex-shrink:0;margin-left:auto}.nav-item.open>.nav-item-arrow{transform:rotate(90deg)}#sidebar.collapsed .nav-item-arrow{display:none}.nav-subitems{padding-left:8px;display:none}.nav-subitems.open{display:block}.nav-subitem{color:var(--sidebar-text);cursor:pointer;border-radius:var(--radius);font-size:var(--font-size-base);white-space:nowrap;transition:background var(--transition), color var(--transition);align-items:center;gap:8px;margin:1px 8px;padding:6px 12px 6px 18px;display:flex}.nav-subitem:hover{background:var(--sidebar-hover);color:var(--sidebar-text-hover)}.nav-subitem.active{color:var(--sidebar-active)}.nav-subitem svg{flex-shrink:0;width:14px;height:14px}#sidebar.collapsed .nav-subitems{display:none}.nav-flyout{left:var(--sidebar-collapsed-width);z-index:200;background:var(--sidebar-bg);border-radius:0 var(--radius) var(--radius) 0;min-width:160px;padding:4px 0;display:none;position:fixed;box-shadow:4px 4px 16px #00000059}.nav-flyout.open{display:block}.nav-flyout-title{font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.06em;color:var(--sidebar-text);opacity:.5;white-space:nowrap;padding:6px 14px 2px}.nav-flyout-item{color:var(--sidebar-text);cursor:pointer;font-size:var(--font-size-base);white-space:nowrap;transition:background var(--transition), color var(--transition);align-items:center;gap:8px;padding:8px 16px;display:flex}.nav-flyout-item:hover{background:var(--sidebar-hover);color:var(--sidebar-text-hover)}.nav-flyout-item.active{color:var(--sidebar-active)}.nav-flyout-item svg{flex-shrink:0;width:14px;height:14px}.sidebar-footer{font-size:var(--font-size-sm);color:var(--text-muted);border-top:1px solid #ffffff14;padding:8px 0 0}button.nav-item{text-align:left;background:0 0;border:none;width:100%}#sidebar.collapsed .sidebar-footer{display:none}.sidebar-footer-info{font-size:var(--font-size-xs);opacity:.9;white-space:nowrap;justify-content:space-between;padding:6px 14px 8px;display:flex;overflow:hidden}#top-bar{background:var(--bg-secondary);border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;gap:12px;height:52px;padding:0 24px;display:flex}.top-bar-title{font-size:var(--font-size-lg);color:var(--text-primary);font-weight:600}#mobile-menu-btn{flex-shrink:0;display:none}.top-bar-actions{align-items:center;gap:8px;margin-left:auto;display:flex}.btn{border-radius:var(--radius);font-size:var(--font-size-base);font-family:var(--font-sans);cursor:pointer;transition:background var(--transition), color var(--transition), border-color var(--transition);white-space:nowrap;border:1px solid #0000;align-items:center;gap:6px;padding:6px 14px;font-weight:500;line-height:1.4;display:inline-flex}.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}.btn-primary:hover{background:var(--accent-hover);border-color:var(--accent-hover)}.btn-secondary{background:var(--bg-secondary);color:var(--text-primary);border-color:var(--border)}.btn-secondary:hover{background:var(--bg-hover)}.btn-danger{background:var(--danger);color:#fff;border-color:var(--danger)}.btn-danger:hover{background:var(--danger-hover);border-color:var(--danger-hover)}.btn-icon-danger{color:var(--danger);min-height:calc(1.4 * var(--font-size-base) + 14px);background:0 0;border-color:#0000;justify-content:center;align-items:center;padding:6px;display:inline-flex}.btn-icon-danger:hover{color:var(--danger-hover);background:var(--bg-hover)}.btn-ghost{color:var(--text-secondary);background:0 0;border-color:#0000}@media (hover:hover){.btn-ghost:hover{background:var(--bg-hover)}}.btn-sm{font-size:var(--font-size-sm);padding:4px 10px}.btn-icon{padding:6px}.btn:disabled{opacity:.5;cursor:not-allowed}.card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow);overflow:hidden}.card-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:12px;padding:16px 20px;font-weight:600;display:flex}.card-body{padding:20px}.card-footer{border-top:1px solid var(--border);background:var(--bg-primary);padding:12px 20px}.table-wrap{overflow-x:auto}table.data-table{border-collapse:collapse;width:100%;font-size:var(--font-size-base)}.data-table th{text-align:left;background:var(--bg-primary);color:var(--text-secondary);font-weight:600;font-size:var(--font-size-sm);text-transform:uppercase;letter-spacing:.04em;border-bottom:2px solid var(--border);white-space:nowrap;padding:10px 12px}.data-table th.text-end,.data-table th.text-right{text-align:right}.data-table td{border-bottom:1px solid var(--border-light);color:var(--text-primary);vertical-align:middle;padding:10px 12px}.data-table tbody tr:hover{background:var(--bg-hover)}.data-table tbody tr:last-child td{border-bottom:none}.form-group{flex-direction:column;gap:4px;margin-bottom:16px;display:flex}.form-label{font-size:var(--font-size-base);color:var(--text-secondary);font-weight:600}.form-control{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border);border-radius:var(--radius);font-size:var(--font-size-base);font-family:var(--font-sans);transition:border-color var(--transition), box-shadow var(--transition);color-scheme:light;width:100%;padding:8px 12px}[data-theme=dark] .form-control{color-scheme:dark}.form-control:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 3px #3b82f633}.form-control.is-invalid{border-color:var(--danger);box-shadow:0 0 0 3px #ef444426}.form-error{font-size:var(--font-size-sm);color:var(--danger)}.form-hint{font-size:var(--font-size-sm);color:var(--text-muted)}.form-info-icon{color:var(--text-muted);cursor:pointer;vertical-align:-.1em;background:0 0;border:none;align-items:center;padding:0 0 0 4px;display:inline-flex}.form-info-icon:hover{color:var(--primary)}#field-tooltip{z-index:1100;background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border);border-radius:6px;max-width:280px;padding:10px 14px;font-size:.82rem;position:fixed;box-shadow:0 4px 16px #0000002e}#field-tooltip strong{margin-bottom:6px;display:block}#field-tooltip ul{margin:0;padding-left:16px}#field-tooltip li{margin-bottom:2px}.form-toggle{cursor:pointer;user-select:none;align-items:center;gap:10px;display:inline-flex}.form-toggle-input{opacity:0;width:0;height:0;position:absolute}.form-toggle-track{background:var(--border);width:40px;height:22px;transition:background var(--transition);border-radius:11px;flex-shrink:0;position:relative}.form-toggle-input:checked~.form-toggle-track{background:var(--accent)}.form-toggle-thumb{width:16px;height:16px;transition:transform var(--transition);background:#fff;border-radius:50%;position:absolute;top:3px;left:3px;box-shadow:0 1px 3px #00000040}.form-toggle-input:checked~.form-toggle-track .form-toggle-thumb{transform:translate(18px)}.form-toggle:focus-within .form-toggle-track{box-shadow:0 0 0 3px #3b82f633}.form-toggle-label{font-size:var(--font-size-base);color:var(--text-primary)}.modal-backdrop{z-index:200;background:#00000080;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.modal{background:var(--bg-secondary);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);flex-direction:column;width:100%;max-width:520px;max-height:90vh;display:flex;overflow:hidden}.modal>form{flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}.modal-header{border-bottom:1px solid var(--border);font-weight:600;font-size:var(--font-size-lg);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.modal-body{overscroll-behavior-y:contain;flex:1;min-height:0;padding:20px;overflow-y:auto}.modal-footer{border-top:1px solid var(--border);justify-content:space-between;align-items:center;gap:8px;padding:12px 20px;display:flex}.modal-footer-right{gap:8px;margin-left:auto;display:flex}#toast-container{z-index:300;flex-direction:column;align-items:flex-end;gap:8px;display:flex;position:fixed;bottom:24px;right:24px}.toast{border-radius:var(--radius);box-shadow:var(--shadow-lg);background:var(--bg-secondary);border-left:4px solid var(--accent);min-width:260px;max-width:380px;font-size:var(--font-size-sm);align-items:flex-start;gap:10px;padding:12px 16px;animation:.2s slide-in;display:flex}.toast.success{border-left-color:var(--success)}.toast.error{border-left-color:var(--danger)}.toast.warning{border-left-color:var(--warning)}.toast-message{color:var(--text-primary);flex:1}.toast-close{cursor:pointer;color:var(--text-muted);font-size:var(--font-size-lg);background:0 0;border:none;padding:0 2px;line-height:1}.toast-close:hover{color:var(--text-primary)}@keyframes slide-in{0%{opacity:0;transform:translate(30px)}to{opacity:1;transform:translate(0)}}#undo-badge{bottom:24px;left:calc(var(--sidebar-width) + 24px);z-index:150;background:var(--bg-secondary);border:1px solid var(--border);box-shadow:var(--shadow-lg);font-size:var(--font-size-sm);color:var(--text-secondary);transition:left var(--transition);pointer-events:none;visibility:hidden;border-radius:20px;align-items:center;gap:8px;padding:6px 14px;display:flex;position:fixed;transform:translateY(calc(100% + 48px))}#undo-badge.visible{pointer-events:auto;visibility:visible;transform:translateY(0)}.badge{font-size:var(--font-size-xs);white-space:nowrap;border-radius:12px;align-items:center;padding:2px 8px;font-weight:600;display:inline-flex}.badge-primary{background:var(--accent-light);color:var(--accent-text)}.badge-success{background:var(--success-light);color:var(--success)}.badge-danger{background:var(--danger-light);color:var(--danger)}.badge-warning{background:var(--warning-light);color:var(--warning)}.badge-neutral{background:var(--bg-tertiary);color:var(--text-secondary)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:8px}.gap-4{gap:16px}.mt-4{margin-top:16px}.mb-4{margin-bottom:16px}.text-muted{color:var(--text-muted)}.data-table tr.report-row-weekend td{background:var(--bg-hover)}.data-table tr.report-row-today td{background:var(--success-light)}.data-table td.report-col-in,.data-table td.report-balance-pos{color:var(--success)}.data-table td.report-balance-neg{color:var(--danger)}.text-sm{font-size:var(--font-size-sm)}.text-right,.text-end{text-align:right}.font-bold{font-weight:700}.w-full{width:100%}.hidden{display:none!important}.report-row-clickable{cursor:pointer}.report-empty-cell{text-align:center;padding:16px}.report-empty-msg{padding:12px 0}.settings-card{max-width:480px}.amount-positive{color:inherit}.amount-negative{color:var(--success)}.amount-negative-income{color:var(--danger)}.amount-positive-income{color:var(--success)}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:24px;display:flex}.page-title{color:var(--text-primary);font-size:1.375rem;font-weight:700}.page-desc{font-size:var(--font-size-sm);color:var(--text-muted);margin-top:4px}.empty-state{text-align:center;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:64px 24px;display:flex}.empty-state svg{opacity:.35}.empty-state-title{font-size:var(--font-size-lg);color:var(--text-secondary);font-weight:600}.empty-state-desc{font-size:var(--font-size-sm)}.spinner{border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:20px;height:20px;animation:.6s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.loading-overlay{color:var(--text-muted);justify-content:center;align-items:center;gap:12px;padding:48px;display:flex}.tx-summary{font-size:var(--font-size-lg);align-items:baseline;gap:8px;padding:8px 0 12px;display:flex}.tx-summary-label{color:var(--text-secondary)}.tx-summary-amount{font-weight:600;font-size:var(--font-size-lg)}.tx-filters{border-bottom:1px solid var(--border);flex-wrap:wrap;align-items:center;gap:8px;padding:12px 16px;display:flex}.tx-search-wrap{flex:160px;display:flex}.tx-search-input-wrap{flex:1;min-width:0;position:relative}.tx-search-input-wrap .form-control{border-top-right-radius:0;border-bottom-right-radius:0;width:100%;padding-right:30px}.tx-search-clear{background:var(--bg-secondary);border:1px solid var(--border);border-radius:0 var(--radius) var(--radius) 0;cursor:pointer;color:var(--text-muted);font-size:var(--font-size-base);white-space:nowrap;border-left:none;flex-shrink:0;justify-content:center;align-items:center;padding:0 12px;display:flex}.tx-search-clear:hover{background:var(--bg-hover);color:var(--text)}.tx-search-info{cursor:pointer;color:var(--text-muted);background:0 0;border:none;justify-content:center;align-items:center;padding:2px;line-height:1;display:flex;position:absolute;top:50%;right:8px;transform:translateY(-50%)}.tx-search-info:hover{color:var(--accent)}.tx-relation-field-wrap{align-items:stretch;display:flex}.tx-relation-field-wrap .form-control{flex:1;min-width:0}.tx-relation-field-wrap.has-qf-btn .form-control{border-top-right-radius:0;border-bottom-right-radius:0}.tx-qf-trigger{border:1px solid var(--border);background:var(--bg-primary);border-radius:0 var(--radius) var(--radius) 0;width:40px;height:40px;color:var(--text-muted);cursor:pointer;border-left:none;flex-shrink:0;justify-content:center;align-items:center;padding:0;display:flex}.tx-qf-trigger:hover{background:var(--bg-hover);color:var(--accent)}.qf-backdrop{z-index:250;background:#00000040;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.qf-modal{background:var(--bg-secondary);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);flex-direction:column;width:100%;max-width:400px;display:flex;overflow:hidden}.qf-modal-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:14px 16px;display:flex}.qf-modal-title{font-weight:600;font-size:var(--font-size-base)}.qf-modal-close{cursor:pointer;color:var(--text-muted);border-radius:var(--radius-sm);background:0 0;border:none;justify-content:center;align-items:center;width:28px;height:28px;display:flex}.qf-modal-close:hover{background:var(--bg-hover);color:var(--text)}.qf-modal-body{flex-direction:column;max-height:320px;display:flex;overflow-y:auto}.qf-option{border:none;border-bottom:1px solid var(--border);cursor:pointer;text-align:left;font-size:var(--font-size-base);color:var(--text);background:0 0;justify-content:space-between;align-items:center;gap:12px;width:100%;padding:10px 16px;display:flex}.qf-option:last-child{border-bottom:none}.qf-option:hover{background:var(--bg-hover)}.qf-option-combo{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.qf-option-amount{white-space:nowrap;flex-shrink:0}.page-header-title{flex:1;justify-content:space-between;align-items:center;gap:12px;display:flex}.page-header-actions{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.tx-show-filter{align-items:center;gap:8px;display:flex}.tx-show-filter-label{font-size:var(--font-size-sm);color:var(--text-secondary);white-space:nowrap}.tx-show-filter .form-control{width:auto;min-width:150px}.data-table tbody tr[data-id]{cursor:pointer}.pagination{border-top:1px solid var(--border);font-size:var(--font-size-sm);color:var(--text-secondary);justify-content:space-between;align-items:center;padding:10px 16px;display:flex}.pagination-nav{align-items:center;gap:4px;display:flex}.pagination-of{margin-left:4px}.pagination-page-input{text-align:center;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-primary);width:44px;color:var(--text-primary);font-size:var(--font-size-sm);-moz-appearance:textfield;appearance:textfield;padding:3px 6px}.pagination-page-input::-webkit-outer-spin-button,.pagination-page-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.pagination-sizes{align-items:center;gap:2px;display:flex}.pagination-sizes-label{margin-right:6px}.pagination-size-btn.active{background:var(--accent);color:#fff}.tx-card-list,.bgt-card-list,.upx-card-list,.irr-card-list,.inout-card-list,.sum-card-list,.sum-dt-card-list,.mly-card-list{display:none}.tx-date-group{background:var(--bg-primary);color:var(--text-secondary);font-weight:600;font-size:var(--font-size-sm);text-transform:uppercase;letter-spacing:.04em;border-bottom:2px solid var(--border);border-top:1px solid var(--border);padding:10px 16px}.tx-date-group:first-child{border-top:none}.tx-card{border-bottom:1px solid var(--border);cursor:pointer;transition:background var(--transition);flex-direction:column;gap:4px;padding:10px 16px;display:flex}.tx-card:active{background:var(--bg-hover)}.tx-card-main{align-items:baseline;gap:8px;display:flex}.tx-card-relation{white-space:nowrap;text-overflow:ellipsis;flex:1;min-width:0;font-weight:500;overflow:hidden}.tx-card-amount{flex-shrink:0;font-weight:600}.tx-card-pills{flex-wrap:wrap;gap:4px;display:flex}.tx-card-pill{font-size:var(--font-size-xs);border:1px solid var(--border);color:var(--text-secondary);white-space:nowrap;border-radius:999px;padding:3px 8px;font-weight:500;line-height:1}#sidebar-backdrop{z-index:99;background:#0006;display:none;position:fixed;inset:0}#sidebar-backdrop.visible{display:block}@media (width<=768px){#sidebar{transition:transform var(--transition);width:var(--sidebar-width);z-index:200;overscroll-behavior-y:contain;overflow-y:auto;transform:translate(-100%)}#sidebar.collapsed{width:var(--sidebar-width)}#sidebar.mobile-open{transform:translate(0)}.nav-flyout{width:var(--sidebar-width)}#main-content,#sidebar.collapsed~#main-content{min-width:0;margin-left:0}#mobile-menu-btn{display:flex}#top-bar{z-index:100;position:fixed;top:0;left:0;right:0}#app-content{padding-top:76px;padding-bottom:64px}#undo-badge{border-radius:var(--radius-lg) var(--radius-lg) 0 0;justify-content:center;bottom:0;left:0;right:0;transform:translateY(100%)}#toast-container{bottom:52px;right:12px}.pagination-of,.pagination-sizes-label{display:none}.modal-backdrop{justify-content:flex-start;align-items:flex-start;width:100vw;padding:0}.modal{border-radius:0;flex-shrink:0;width:100vw;max-width:100vw;height:100dvh;max-height:100dvh}.form-control{font-size:var(--font-size-lg)}.page-header-actions{margin-left:auto}html,body{overflow-x:hidden}.tx-card-list{display:block}.js-table-wrap:has(.tx-card-list) .data-table{display:none}.bgt-card-list{display:block}.js-table-wrap:has(.bgt-card-list) .data-table{display:none}.upx-card-list{display:block}.table-wrap:has(.upx-card-list) .data-table{display:none}.irr-card-list{display:block}.table-wrap:has(.irr-card-list) .data-table{display:none}.inout-card-list{display:block}.table-wrap:has(.inout-card-list) .data-table{display:none}.sum-card-list{display:block}.table-wrap:has(.sum-card-list) .data-table{display:none}.sum-dt-card-list{display:block}.table-wrap:has(.sum-dt-card-list) .data-table{display:none}.mly-card-list{display:block}.table-wrap:has(.mly-card-list) .data-table{display:none}.bgt-summary{flex-direction:column;gap:2px}.bgt-summary-row{justify-content:space-between}.bgt-summary-sep{display:none}}.tab-bar{border-bottom:1px solid var(--border);gap:0;margin-bottom:20px;display:flex}.tab-btn{border-top-left-radius:var(--radius);border-top-right-radius:var(--radius);color:var(--text-secondary);cursor:pointer;font-size:var(--font-size-base);transition:background var(--transition), color var(--transition), border-color var(--transition);background:0 0;border:1px solid #0000;border-bottom:none;margin-bottom:-1px;padding:10px 20px;font-weight:500}.tab-btn:hover{isolation:isolate;color:var(--text-primary);border-color:var(--bg-tertiary) var(--bg-tertiary) var(--border);background:var(--bg-hover)}.tab-btn.active{background:var(--bg-secondary);color:var(--text-primary);border-color:var(--border) var(--border) var(--bg-secondary);font-weight:600}.categories-add-form{border-bottom:1px solid var(--border-light);align-items:center;gap:8px;padding:12px 16px;display:flex}.categories-add-inputs{flex:1;gap:8px;display:flex}.categories-add-inputs .form-control{flex:1;min-width:0}.data-table td.is-inactive{opacity:.45;font-style:italic}.cat-grouped-table tbody tr:hover{background:0 0}.data-table td.js-cat-cell,.data-table td.js-subcat-cell{cursor:pointer}.data-table td.js-cat-cell,.data-table td.js-subcat-first{border-top:2px solid var(--border)}.data-table td.js-cat-cell{vertical-align:top;padding-top:12px}.data-table td.js-subcat-last{border-bottom:2px solid var(--border)}.data-table td.js-cat-cell:hover,.data-table td.js-subcat-cell:hover{background-color:var(--bg-hover)}#dl-polyfill-dropdown{border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-secondary);box-shadow:var(--shadow-lg);margin:0;padding:0;list-style:none}#dl-polyfill-dropdown .dl-item{background:var(--bg-secondary);color:var(--text-primary);border:none;border-bottom:1px solid var(--border);font-size:var(--font-size-sm);cursor:pointer;padding:10px;display:block}#dl-polyfill-dropdown .dl-item:last-child{border-bottom:none}#dl-polyfill-dropdown .dl-item:hover,#dl-polyfill-dropdown .dl-item:focus{background:var(--bg-hover);outline:none}#theme-toggle-btn .icon-sun{display:none}#theme-toggle-btn .icon-moon,[data-theme=dark] #theme-toggle-btn .icon-sun{display:block}[data-theme=dark] #theme-toggle-btn .icon-moon{display:none}.lang-switcher{position:relative}.lang-flyout{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-md);z-index:200;min-width:130px;padding:4px 0;position:absolute;top:calc(100% + 4px);right:0}.lang-flyout-item{text-align:left;cursor:pointer;width:100%;font-size:var(--font-size-base);color:var(--text-primary);font-family:var(--font-sans);background:0 0;border:none;padding:8px 14px;display:block}.lang-flyout-item:hover{background:var(--bg-hover)}.lang-flyout-item.is-active{color:var(--accent);font-weight:600}.bgt-summary-row{align-items:baseline;gap:8px;display:flex}.bgt-summary-sep{color:var(--text-secondary)}.data-table tr.bgt-group-header td{background:var(--bg-primary);border-top:2px solid var(--border);padding-top:10px;padding-bottom:10px;font-weight:700}.data-table tr.bgt-group-header td.bgt-cat-name{color:var(--text-primary)}.data-table tr.bgt-group-header td:not(.bgt-cat-name){color:var(--text-secondary)}.data-table tr.bgt-group-first td{border-top:1px solid var(--border-light)}.bgt-cat-group{background:var(--bg-primary);color:var(--text-secondary);font-weight:600;font-size:var(--font-size-sm);text-transform:uppercase;letter-spacing:.04em;border-bottom:2px solid var(--border);border-top:1px solid var(--border);justify-content:space-between;align-items:baseline;gap:8px;padding:10px 16px;display:flex}.bgt-cat-group:first-child{border-top:none}.bgt-cat-group-name{color:var(--text-primary)}.bgt-cat-group-total{flex-shrink:0}.bgt-card{border-bottom:1px solid var(--border);cursor:pointer;transition:background var(--transition);flex-direction:column;gap:3px;padding:10px 16px;display:flex}.bgt-card:active{background:var(--bg-hover)}.bgt-card-main{align-items:baseline;gap:8px;display:flex}.bgt-card-desc{white-space:nowrap;text-overflow:ellipsis;flex:1;min-width:0;font-weight:500;overflow:hidden}.bgt-card-total{flex-shrink:0;font-weight:600}.bgt-card-meta{font-size:var(--font-size-sm);color:var(--text-secondary)}.bgt-terms-section{border-top:1px solid var(--border);margin-top:16px;padding-top:16px}.bgt-terms-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.bgt-terms-title{font-size:var(--font-size-base);text-transform:uppercase;letter-spacing:.04em;color:var(--text-secondary);font-weight:600}.bgt-terms-scroll{margin-bottom:4px;overflow-x:auto}.bgt-terms-table{border-collapse:collapse;width:100%;min-width:400px}.bgt-terms-table th{font-size:var(--font-size-base);color:var(--text-secondary);text-align:left;white-space:nowrap;padding:2px 6px 6px;font-weight:600}.bgt-terms-table td{vertical-align:middle;padding:4px}.bgt-term-num{font-size:var(--font-size-base);color:var(--text-secondary);text-align:right;width:26px;padding-right:8px!important}.bgt-term-subtotal{font-size:var(--font-size-base);text-align:right;white-space:nowrap;width:90px;padding:0 10px!important}.bgt-terms-table .bgt-term-del-col{width:36px}.bgt-terms-table .form-control{width:100%;height:auto}.bgt-terms-total{font-size:var(--font-size-base);color:var(--text-secondary);text-align:right;margin-top:6px;padding-right:4px}.upx-card{border-bottom:1px solid var(--border);background:var(--bg-card);transition:background var(--transition);flex-direction:column;padding:10px 16px;display:flex}.upx-card.report-row-today{background:var(--success-light)}.upx-card.report-row-weekend{background:var(--bg-hover)}.upx-card-main{align-items:baseline;gap:8px;display:flex}.upx-card-cat{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-weight:500;overflow:hidden}.upx-card-amount{flex-shrink:0;font-weight:600}.upx-card-detail{font-size:var(--font-size-sm);color:var(--text-secondary);text-overflow:ellipsis;white-space:nowrap;margin-top:2px;overflow:hidden}.irr-card{border-bottom:1px solid var(--border);background:var(--bg-card);transition:background var(--transition);flex-direction:column;padding:10px 16px;display:flex}.irr-card.report-row-today{background:var(--success-light)}.irr-card.report-row-weekend{background:var(--bg-hover)}.irr-card-main{align-items:baseline;gap:8px;display:flex}.irr-card-cat{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-weight:500;overflow:hidden}.irr-card-amount{flex-shrink:0;font-weight:600}.irr-card-detail{font-size:var(--font-size-sm);color:var(--text-secondary);text-overflow:ellipsis;white-space:nowrap;margin-top:2px;overflow:hidden}.inout-card{border-top:1px solid var(--border)}.inout-card:first-child{border-top:none}.inout-card-header{background:var(--bg-primary);border-bottom:1px solid var(--border);align-items:baseline;gap:8px;padding:8px 16px;display:flex}.inout-card.report-row-today .inout-card-header{background:var(--success-light)}.inout-card.report-row-weekend .inout-card-header{background:var(--bg-hover)}.inout-card-date{min-width:0;font-size:var(--font-size-sm);text-transform:uppercase;letter-spacing:.04em;color:var(--text-secondary);flex:1;font-weight:600}.inout-card-balance{font-size:var(--font-size-lg);flex-shrink:0;font-weight:600}.inout-card-balance.report-balance-pos{color:var(--success)}.inout-card-balance.report-balance-neg{color:var(--danger)}.inout-card-data{font-size:var(--font-size-sm);background:var(--bg-card);grid-template-columns:auto auto 1fr auto;align-items:baseline;gap:3px 6px;padding:8px 16px;display:grid}.inout-row-amt{text-align:right;font-variant-numeric:tabular-nums}.inout-out-label{border-left:1px solid var(--border);padding-left:6px}.report-filter-bar{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:16px;display:flex}.report-filter-field{align-items:center;gap:8px;display:flex}.report-filter-field label{font-size:var(--font-size-sm);color:var(--text-secondary);white-space:nowrap}.report-filter-field select{max-width:200px}.report-summary-total td,.report-summary-total th{border-top:2px solid var(--border)}.sum-card{border-top:1px solid var(--border);cursor:pointer;flex-direction:column;padding:10px 16px;display:flex}.sum-card:first-child{border-top:none}.sum-card-header{justify-content:space-between;align-items:baseline;gap:8px;display:flex}.sum-card-name{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-weight:600;overflow:hidden}.sum-card-remaining{font-variant-numeric:tabular-nums;flex-shrink:0;font-weight:600}.sum-card-remaining--neg{color:var(--danger)}.sum-card-remaining--pos,.data-table td.report-remaining-pos,.report-remaining-pos{color:var(--success)}.data-table td.report-remaining-neg,.report-remaining-neg{color:var(--danger)}.sum-card-detail{font-size:var(--font-size-sm);color:var(--text-secondary);gap:16px;margin-top:2px;display:flex}.sum-card-pct{font-variant-numeric:tabular-nums;margin-left:auto}.sum-card-total-bar{font-size:var(--font-size-lg);color:var(--text-secondary);border-bottom:1px solid var(--border);font-variant-numeric:tabular-nums;padding:8px 16px}.sum-card-total-bar span{font-weight:600;font-size:var(--font-size-lg)}.report-monthly-cat-header td{background:var(--bg-alt);border-top:2px solid var(--border)}.report-monthly-cat-header:first-child td{border-top:none}.report-monthly-subcat-cell{color:var(--text-secondary);padding-left:28px!important}.mly-cat-group{background:var(--bg-primary);border-top:1px solid var(--border);border-bottom:2px solid var(--border);justify-content:space-between;align-items:baseline;gap:8px;padding:10px 16px;display:flex}.mly-cat-group:first-child{border-top:none}.mly-cat-group-name{font-weight:600;font-size:var(--font-size-sm);text-transform:uppercase;letter-spacing:.04em;color:var(--text-secondary)}.mly-cat-group-remaining{font-variant-numeric:tabular-nums;font-weight:600;font-size:var(--font-size-sm);flex-shrink:0}.mly-cat-remaining--neg{color:var(--danger)}.mly-card{border-top:1px solid var(--border);flex-direction:column;padding:10px 16px;display:flex}.mly-card-header{justify-content:space-between;align-items:baseline;gap:8px;display:flex}.mly-card-name{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-weight:500;overflow:hidden}.mly-card-remaining{font-variant-numeric:tabular-nums;flex-shrink:0}.mly-card-remaining--neg{color:var(--danger)}.mly-card-detail{font-size:var(--font-size-sm);color:var(--text-secondary);gap:16px;margin-top:2px;display:flex}body{background:var(--bg-primary);justify-content:center;align-items:center;min-height:100vh;display:flex;overflow-y:auto}.login-wrap{width:100%;max-width:360px;padding:16px}.login-logo{align-items:center;gap:14px;margin-bottom:32px;padding-left:32px;display:flex}.login-logo-icon{color:#3b82f6;flex-shrink:0;font-size:42px;line-height:1}.login-logo-title{color:var(--text-primary);letter-spacing:-.5px;font-size:26px;font-weight:700}.login-logo-sub{font-size:var(--font-size-lg);color:var(--text-muted);margin-top:4px}.login-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:32px}.login-card .form-group{margin-bottom:20px}.login-actions{flex-direction:column;gap:12px;margin-top:24px;display:flex}.login-error{background:var(--danger-light);color:var(--danger);border:1px solid var(--danger);border-radius:var(--radius);font-size:var(--font-size-sm);margin-bottom:16px;padding:10px 14px;display:none}.remember-row{font-size:var(--font-size-sm);color:var(--text-secondary);align-items:center;gap:8px;display:flex}.login-top-actions{align-items:center;gap:4px;display:flex;position:fixed;top:16px;right:16px}