:root{color-scheme:light;--color-white: #ffffff;--color-black: #16181d;--color-gray-50: #f5f6f8;--color-gray-100: #eceef2;--color-gray-200: #e2e5ea;--color-gray-300: #d0d4da;--color-gray-400: #9aa0aa;--color-gray-500: #6b7280;--color-gray-600: #4b5563;--color-gray-700: #374151;--color-gray-800: #1f2937;--color-gray-900: #14161b;--accent: var(--color-black);--accent-contrast: #ffffff;--ring: rgba(20, 22, 27, .14);--color-success: #16a34a;--color-warning: #d97706;--color-error: #dc2626;--color-info: #2563eb;--spacing-1: .25rem;--spacing-2: .5rem;--spacing-3: .75rem;--spacing-4: 1rem;--spacing-5: 1.25rem;--spacing-6: 1.5rem;--spacing-8: 2rem;--spacing-10: 2.5rem;--spacing-12: 3rem;--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(16, 24, 40, .06), 0 1px 3px rgba(16, 24, 40, .05);--shadow-md: 0 4px 14px rgba(16, 24, 40, .08);--shadow-lg: 0 16px 40px rgba(16, 24, 40, .14);--transition-fast: .14s cubic-bezier(.4, 0, .2, 1);--transition-normal: .22s cubic-bezier(.4, 0, .2, 1)}[data-theme=dark]{color-scheme:dark;--color-white: #181b21;--color-black: #f4f5f7;--color-gray-50: #0e1014;--color-gray-100: #242833;--color-gray-200: #2b313b;--color-gray-300: #3a414d;--color-gray-400: #838b97;--color-gray-500: #9aa1ad;--color-gray-600: #b4bac4;--color-gray-700: #cdd2da;--color-gray-800: #e4e7ec;--color-gray-900: #f4f5f7;--accent: var(--color-black);--accent-contrast: #14161b;--ring: rgba(244, 245, 247, .18);--color-success: #34d399;--color-warning: #fbbf24;--color-error: #f87171;--color-info: #60a5fa;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .4);--shadow-md: 0 6px 20px rgba(0, 0, 0, .45);--shadow-lg: 0 18px 44px rgba(0, 0, 0, .6)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background-color:var(--color-gray-50);color:var(--color-gray-900);line-height:1.5;min-height:100vh;overflow-x:hidden}.main-content{min-width:0}.app{display:flex;min-height:100vh}.sidebar{width:240px;background:var(--color-white);border-right:1px solid var(--color-gray-200);padding:var(--spacing-5) var(--spacing-3);position:fixed;top:0;left:0;bottom:0;overflow:hidden;display:flex;flex-direction:column;transition:width var(--transition-fast),transform var(--transition-fast);z-index:90}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:0 var(--spacing-2);margin-bottom:var(--spacing-5)}.icon-btn{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border:none;background:transparent;color:var(--color-gray-400);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.icon-btn:hover{background:var(--color-gray-100);color:var(--color-gray-900)}.close-btn{display:none}.sidebar-footer{flex-shrink:0;padding-top:var(--spacing-3);margin-top:var(--spacing-2);border-top:1px solid var(--color-gray-200)}.sidebar-user{font-size:.8rem;color:var(--color-gray-500);padding:0 var(--spacing-2) var(--spacing-2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.footer-icons{display:flex;align-items:center;gap:var(--spacing-2);padding:0 var(--spacing-2)}.footer-icons .icon-btn.active{background:var(--color-gray-100);color:var(--color-gray-900)}.footer-alert{position:relative}.footer-alert-badge{position:absolute;top:-2px;right:-2px;min-width:16px;height:16px;padding:0 4px;background:var(--color-error);color:#fff;font-size:.625rem;font-weight:700;border-radius:var(--radius-full);display:inline-flex;align-items:center;justify-content:center;line-height:1}.theme-switch{position:relative;width:46px;height:24px;border-radius:var(--radius-full);border:1px solid var(--color-gray-200);background:var(--color-gray-100);cursor:pointer;flex-shrink:0;display:inline-flex;align-items:center;padding:0 4px;justify-content:space-between;color:var(--color-gray-400)}.theme-switch .ts-knob{position:absolute;top:2px;left:2px;width:18px;height:18px;border-radius:50%;background:var(--accent);transition:transform var(--transition-normal)}.theme-switch[data-on=true] .ts-knob{transform:translate(22px)}.theme-switch .ts-sun{opacity:1}.theme-switch .ts-moon,.theme-switch[data-on=true] .ts-sun{opacity:.5}.theme-switch[data-on=true] .ts-moon{opacity:1}.topbar,.sidebar-overlay,.bottom-nav{display:none}.bottom-nav-item{position:relative;flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:8px 0;background:none;border:none;cursor:pointer;color:var(--color-gray-500);font-size:.65rem;font-weight:600;text-decoration:none;transition:color var(--transition-fast)}.bottom-nav-item svg{color:var(--color-gray-400);transition:color var(--transition-fast)}.bottom-nav-item.active{color:var(--color-black)}.bottom-nav-item.active svg{color:var(--color-black)}.bottom-nav-item:active{opacity:.6}.bottom-nav-item svg{transition:transform var(--transition-fast)}.bottom-nav-item.active svg{transform:translateY(-2px) scale(1.1)}.bottom-nav-item.active:before{content:"";position:absolute;top:0;left:50%;width:26px;height:3px;transform:translate(-50%);background:var(--color-black);border-radius:0 0 999px 999px;animation:navTab .22s ease}@keyframes navTab{0%{width:0;opacity:0}to{width:26px;opacity:1}}.sheet-close{display:none}.app.collapsed .sidebar{width:72px;padding-left:var(--spacing-3);padding-right:var(--spacing-3)}.app.collapsed .nav-label,.app.collapsed .nav-section-title{display:none}.app.collapsed .nav-section{margin-bottom:var(--spacing-3)}.app.collapsed .sidebar-header{flex-direction:column;gap:var(--spacing-2);justify-content:center;padding:0}.app.collapsed .nav-link{justify-content:center;padding-left:0;padding-right:0}.app.collapsed .sidebar-user{display:none}.app.collapsed .footer-icons{flex-direction:column;align-items:center;gap:var(--spacing-2);padding:0}.app.collapsed .nav-section-title{display:none}.app.collapsed .main-content{margin-left:72px}.sidebar-logo{font-size:1.0625rem;font-weight:700;color:var(--color-black);display:flex;align-items:center;gap:var(--spacing-2);width:100%;background:none;border:none;cursor:pointer;padding:var(--spacing-1) var(--spacing-2);border-radius:var(--radius-md);transition:background var(--transition-fast)}.sidebar-logo:hover{background:var(--color-gray-100)}.sidebar-logo .sidebar-collapse-hint{margin-left:auto;color:var(--color-gray-400)}.app.collapsed .sidebar-logo{justify-content:center;padding-left:0;padding-right:0}.sidebar-nav{display:flex;flex-direction:column;gap:2px;flex:1 1 auto;overflow-y:auto;min-height:0;margin:0 calc(-1 * var(--spacing-1));padding:0 var(--spacing-1)}.sidebar-nav::-webkit-scrollbar{width:0;height:0;display:none}.sidebar-nav{scrollbar-width:none;-ms-overflow-style:none}.nav-section{margin-bottom:var(--spacing-4)}.nav-section-title{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-2);width:100%;font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--color-gray-400);padding:var(--spacing-2) var(--spacing-3);margin-bottom:2px;border:none;background:transparent;cursor:pointer;transition:color var(--transition-fast)}.nav-section-title:hover{color:var(--color-gray-600)}.section-chevron{transition:transform var(--transition-fast)}.section-chevron.closed{transform:rotate(-90deg)}.nav-link{display:flex;align-items:center;gap:var(--spacing-3);padding:.5rem var(--spacing-3);border-radius:var(--radius-md);color:var(--color-gray-500);text-decoration:none;font-size:.875rem;font-weight:500;line-height:1.2;transition:background var(--transition-fast),color var(--transition-fast)}.nav-link svg{flex-shrink:0;color:var(--color-gray-400);transition:color var(--transition-fast)}.nav-link:hover{background:var(--color-gray-50);color:var(--color-gray-900)}.nav-link:hover svg{color:var(--color-gray-700)}.nav-link.active{background:var(--color-gray-100);color:var(--color-black);font-weight:600}.nav-link.active svg{color:var(--color-black)}.main-content{flex:1;margin-left:240px;padding:var(--spacing-8);min-height:100vh}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-8)}.page-title{font-size:1.5rem;font-weight:700;letter-spacing:-.01em;color:var(--color-black)}.page-subtitle{color:var(--color-gray-500);margin-top:var(--spacing-1)}.card{background:var(--color-white);border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);padding:var(--spacing-6);box-shadow:var(--shadow-sm)}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-4)}.card-title{font-size:1rem;font-weight:600;color:var(--color-gray-900)}.card-value{font-size:1.75rem;font-weight:700;letter-spacing:-.01em;color:var(--color-black)}.card-label{font-size:.8125rem;font-weight:500;color:var(--color-gray-500);margin-bottom:2px}.grid{display:grid;gap:var(--spacing-6)}.grid-cols-2{grid-template-columns:repeat(2,1fr)}.grid-cols-4{grid-template-columns:repeat(4,1fr)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-2);padding:var(--spacing-3) var(--spacing-5);border-radius:var(--radius-md);font-weight:600;font-size:.875rem;line-height:1;cursor:pointer;transition:transform var(--transition-fast),background var(--transition-fast),box-shadow var(--transition-fast),border-color var(--transition-fast),opacity var(--transition-fast);border:1px solid transparent;text-decoration:none;white-space:nowrap}.btn:active{transform:translateY(1px) scale(.99)}.btn:focus-visible{outline:none;box-shadow:0 0 0 3px var(--ring)}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-primary{background:var(--accent);color:var(--accent-contrast)}.btn-primary:hover{box-shadow:var(--shadow-md);opacity:.92}.btn-secondary{background:var(--color-white);color:var(--color-gray-900);border-color:var(--color-gray-200)}.btn-secondary:hover{background:var(--color-gray-100);border-color:var(--color-gray-300)}.btn-danger{background:transparent;color:var(--color-error);border-color:var(--color-error)}.btn-danger:hover{background:var(--color-error);color:#fff}.btn-sm{padding:var(--spacing-2) var(--spacing-3);font-size:.813rem}.btn-icon{padding:var(--spacing-2);width:36px;height:36px}.form-group{margin-bottom:var(--spacing-4)}.form-label{display:block;font-size:.875rem;font-weight:500;color:var(--color-gray-700);margin-bottom:var(--spacing-2)}.form-input,.form-select,.form-textarea{width:100%;padding:var(--spacing-3) var(--spacing-4);border:1px solid var(--color-gray-200);border-radius:var(--radius-md);font-size:.875rem;font-family:inherit;color:var(--color-gray-900);background:var(--color-white);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--ring)}.form-input::placeholder,.form-textarea::placeholder{color:var(--color-gray-400)}.form-select{-moz-appearance:none;appearance:none;-webkit-appearance:none;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='%239aa0aa' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--spacing-3) center;padding-right:var(--spacing-8);cursor:pointer}.table-container{overflow-x:auto}.table{width:100%;border-collapse:collapse}.table th,.table td{padding:var(--spacing-4);text-align:left;border-bottom:1px solid var(--color-gray-200)}.table th{font-weight:600;color:var(--color-gray-600);font-size:.75rem;text-transform:uppercase;letter-spacing:.05em}.table tbody tr:hover{background:var(--color-gray-50)}.table tbody tr:last-child td{border-bottom:none}.badge{display:inline-flex;align-items:center;padding:var(--spacing-1) var(--spacing-3);border-radius:var(--radius-full);font-size:.75rem;font-weight:500}.badge-success{background:#dcfce7;color:#166534}.badge-warning{background:#fef3c7;color:#92400e}.badge-error{background:#fee2e2;color:#991b1b}.badge-info{background:#dbeafe;color:#1e40af}.badge-gray{background:var(--color-gray-100);color:var(--color-gray-700)}.progress{width:100%;height:8px;background:var(--color-gray-200);border-radius:var(--radius-full);overflow:hidden}.progress-bar{height:100%;background:var(--color-black);border-radius:var(--radius-full);transition:width var(--transition-normal)}.progress-bar.success{background:var(--color-success)}.progress-bar.warning{background:var(--color-warning)}.progress-bar.error{background:var(--color-error)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-4)}.modal{background:var(--color-white);border-radius:var(--radius-xl);width:100%;max-width:500px;max-height:90vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-6);border-bottom:1px solid var(--color-gray-200)}.modal-title{font-size:1.125rem;font-weight:600}.modal-close{background:none;border:none;cursor:pointer;padding:var(--spacing-2);color:var(--color-gray-500)}.modal-close:hover{color:var(--color-gray-900)}.modal-body{padding:var(--spacing-6)}.modal-footer{display:flex;justify-content:flex-end;gap:var(--spacing-3);padding:var(--spacing-6);border-top:1px solid var(--color-gray-200)}.toast-container{position:fixed;bottom:var(--spacing-6);right:var(--spacing-6);z-index:1100;display:flex;flex-direction:column;gap:var(--spacing-3)}.toast{background:var(--color-white);border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);padding:var(--spacing-4) var(--spacing-5);box-shadow:var(--shadow-md);display:flex;align-items:center;gap:var(--spacing-3);min-width:300px;animation:slideIn .2s ease}.toast.success{border-left:4px solid var(--color-success)}.toast.error{border-left:4px solid var(--color-error)}.toast.warning{border-left:4px solid var(--color-warning)}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.stat-card{display:flex;flex-direction:column;gap:var(--spacing-2)}.stat-value{font-size:1.5rem;font-weight:700;color:var(--color-black)}.stat-change{display:inline-flex;align-items:center;gap:var(--spacing-1);font-size:.875rem;font-weight:500}.stat-change.positive{color:var(--color-success)}.stat-change.negative{color:var(--color-error)}.empty-state{text-align:center;padding:var(--spacing-12);color:var(--color-gray-500)}.empty-state-icon{font-size:3rem;margin-bottom:var(--spacing-4);opacity:.5}.empty-state-title{font-size:1.125rem;font-weight:600;color:var(--color-gray-700);margin-bottom:var(--spacing-2)}.alert{padding:var(--spacing-4);border-radius:var(--radius-lg);display:flex;align-items:flex-start;gap:var(--spacing-3)}.alert-warning{background:#fffbeb;border:1px solid #fde68a}.alert-error{background:#fef2f2;border:1px solid #fecaca}.alert-success{background:#f0fdf4;border:1px solid #bbf7d0}.search-input{position:relative}.search-input input{padding-left:40px}.search-input .search-icon{position:absolute;left:var(--spacing-3);top:50%;transform:translateY(-50%);color:var(--color-gray-400)}.filters{display:flex;gap:var(--spacing-4);margin-bottom:var(--spacing-6);flex-wrap:wrap}.loading{display:flex;align-items:center;justify-content:center;padding:var(--spacing-12)}.spinner{width:40px;height:40px;border:3px solid var(--color-gray-200);border-top-color:var(--color-black);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.spin{animation:spin .8s linear infinite}.checkbox-row{display:flex;align-items:flex-start;gap:var(--spacing-2);font-size:.875rem;cursor:pointer;margin-top:var(--spacing-2)}.checkbox-row input{margin-top:3px;flex-shrink:0}.alert-row{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-2) var(--spacing-3);border-bottom:1px solid var(--color-gray-100);border-left:3px solid transparent;font-size:.875rem}.alert-row.alert-error{border-left-color:var(--color-error)}.alert-row.alert-warn{border-left-color:var(--color-warning)}.alert-msg{flex:1}.alert-ts{color:var(--color-gray-400);font-size:.75rem;white-space:nowrap}.nav-badge{margin-left:auto;background:var(--color-error);color:#fff;font-size:.6875rem;font-weight:700;min-width:18px;height:18px;padding:0 5px;border-radius:var(--radius-full);display:inline-flex;align-items:center;justify-content:center}.app.collapsed .nav-badge{display:none}.log-list{display:flex;flex-direction:column}.log-row{padding:var(--spacing-2) var(--spacing-3);border-bottom:1px solid var(--color-gray-100);border-left:3px solid transparent;cursor:pointer;font-size:.8125rem}.log-row:hover{background:var(--color-gray-50)}.log-row.log-error{border-left-color:var(--color-error);background:color-mix(in srgb,var(--color-error) 7%,transparent)}.log-row.log-warn{border-left-color:var(--color-warning)}.log-main{display:flex;align-items:center;gap:var(--spacing-3)}.log-icon{flex-shrink:0;display:inline-flex}.log-ts{color:var(--color-gray-400);white-space:nowrap;font-variant-numeric:tabular-nums}.log-cat{color:var(--color-gray-500);text-transform:uppercase;font-size:.6875rem;font-weight:600;min-width:64px}.log-error .log-msg{color:var(--color-error);font-weight:500}.log-warn .log-msg{color:var(--color-warning);font-weight:500}.log-detail{margin-top:var(--spacing-2);background:var(--color-gray-50);border:1px solid var(--color-gray-200);border-radius:var(--radius-md);padding:var(--spacing-3);font-size:.75rem;overflow-x:auto;white-space:pre-wrap;word-break:break-word}.login-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--color-gray-100);padding:var(--spacing-4)}.login-card{width:100%;max-width:380px;background:var(--color-white);border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);padding:var(--spacing-8);box-shadow:0 4px 24px #0000000f}.login-logo{display:flex;align-items:center;gap:var(--spacing-2);font-weight:700;font-size:1.25rem;margin-bottom:var(--spacing-6)}.login-title{font-size:1.5rem;font-weight:700}.login-subtitle{color:var(--color-gray-500);margin-bottom:var(--spacing-6)}@media(max-width:1024px){.grid-cols-4{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.sidebar{width:260px;transform:translate(-100%);z-index:100}.app.mobile-open .sidebar{transform:translate(0)}.app.collapsed .sidebar{width:260px;padding:var(--spacing-6)}.app.collapsed .nav-label,.app.collapsed .nav-section-title,.app.collapsed .sidebar-user{display:revert}.app.collapsed .main-content{margin-left:0}.collapse-btn{display:none}.close-btn{display:inline-flex}.topbar{display:flex;align-items:center;gap:var(--spacing-3);position:sticky;top:0;z-index:80;background:var(--color-white);border-bottom:1px solid var(--color-gray-200);padding:var(--spacing-3) var(--spacing-4)}.topbar-brand{display:flex;align-items:center;gap:var(--spacing-2);font-weight:700}.app.mobile-open .sidebar-overlay{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:95}.main-content{margin-left:0;padding:var(--spacing-4)}.grid-cols-2,.grid-cols-3,.grid-cols-4{grid-template-columns:1fr}.page-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-4)}.filters{flex-direction:column}}@media(min-width:769px){.topbar,.close-btn{display:none}}.text-center{text-align:center}.text-right{text-align:right}.font-bold{font-weight:700}.text-sm{font-size:.875rem}.text-xs{font-size:.75rem}.text-gray-500{color:var(--color-gray-500)}.text-success{color:var(--color-success)}.text-error{color:var(--color-error)}.mt-2{margin-top:var(--spacing-2)}.mt-4{margin-top:var(--spacing-4)}.mt-6{margin-top:var(--spacing-6)}.mb-2{margin-bottom:var(--spacing-2)}.mb-4{margin-bottom:var(--spacing-4)}.mb-6{margin-bottom:var(--spacing-6)}.ml-2{margin-left:var(--spacing-2)}.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:var(--spacing-2)}.gap-4{gap:var(--spacing-4)}.upload-section{margin-bottom:var(--spacing-4)}.form-row{display:flex;gap:var(--spacing-4);align-items:flex-end}.form-row .form-group{flex:1;margin-bottom:0}.uploading-text{color:var(--color-gray-500);font-size:.875rem;margin-top:var(--spacing-2)}.upload-mode-toggle{display:flex;gap:var(--spacing-2)}.upload-mode-toggle .btn{display:flex;align-items:center;gap:var(--spacing-1)}.bulk-upload-area{border:2px dashed var(--color-gray-300);border-radius:var(--radius-lg);padding:var(--spacing-8);text-align:center;background:var(--color-gray-50);transition:all var(--transition-fast)}.bulk-upload-area:hover{border-color:var(--color-gray-400);background:var(--color-gray-100)}.bulk-upload-area .bulk-icon{color:var(--color-gray-400);margin-bottom:var(--spacing-3)}.bulk-upload-area p{margin-bottom:var(--spacing-1);color:var(--color-gray-700)}.bulk-upload-area .text-muted{color:var(--color-gray-500)}.bulk-progress{margin-top:var(--spacing-4);padding:var(--spacing-4);background:var(--color-gray-50);border-radius:var(--radius-lg);border:1px solid var(--color-gray-200)}.bulk-progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-3);font-weight:500}.progress-bar{height:8px;background:var(--color-gray-200);border-radius:var(--radius-full);overflow:hidden;margin-bottom:var(--spacing-4)}.progress-fill{height:100%;background:var(--color-success);border-radius:var(--radius-full);transition:width var(--transition-normal)}.bulk-results{max-height:200px;overflow-y:auto;display:flex;flex-direction:column;gap:var(--spacing-2)}.bulk-result{display:flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-2) var(--spacing-3);border-radius:var(--radius-md);font-size:.875rem}.bulk-result.success{background:#dcfce7}.bulk-result.error{background:#fee2e2}.bulk-result .result-icon.success{color:var(--color-success)}.bulk-result .result-icon.error{color:var(--color-error)}.bulk-result .result-file{flex:1;font-weight:500}.bulk-result .result-error{color:var(--color-error);font-size:.75rem;max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.bulk-result .result-count{color:var(--color-gray-500);font-size:.75rem;margin-left:auto}.tag-badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:var(--radius-full);font-size:.7rem;font-weight:500;text-transform:capitalize;background:#ede9fe;color:#5b21b6}.pagination-controls{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-3) 0;border-bottom:1px solid var(--color-gray-200);margin-bottom:var(--spacing-3)}.pagination-controls.pagination-bottom{border-bottom:none;border-top:1px solid var(--color-gray-200);margin-top:var(--spacing-3);margin-bottom:0;justify-content:center}.pagination-info{font-size:.875rem;color:var(--color-gray-600)}.pagination-actions{display:flex;align-items:center;gap:var(--spacing-6)}.page-size-selector{display:flex;align-items:center;gap:var(--spacing-2);font-size:.875rem;color:var(--color-gray-600)}.page-size-selector select{padding:var(--spacing-1) var(--spacing-2);border:1px solid var(--color-gray-300);border-radius:var(--radius-md);font-size:.875rem;background:var(--color-white);cursor:pointer}.page-navigation{display:flex;align-items:center;gap:var(--spacing-2)}.page-indicator{font-size:.875rem;color:var(--color-gray-600);min-width:100px;text-align:center}.page-navigation .btn{display:flex;align-items:center;gap:var(--spacing-1)}.data-table{width:100%;border-collapse:collapse}.data-table th,.data-table td{padding:var(--spacing-3) var(--spacing-4);text-align:left;border-bottom:1px solid var(--color-gray-200)}.data-table th{font-weight:600;color:var(--color-gray-600);font-size:.75rem;text-transform:uppercase}.data-table tbody tr:hover{background:var(--color-gray-50)}.action-buttons{display:flex;gap:var(--spacing-2)}.badge-pending{background:var(--color-gray-100);color:var(--color-gray-700)}.badge-danger{background:#fee2e2;color:#991b1b}.card-header-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-4)}.credit-card-info{background:var(--color-gray-50);padding:var(--spacing-4);border-radius:var(--radius-lg);margin-bottom:var(--spacing-4);display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-4)}.transactions-preview{max-height:400px;overflow-y:auto}.more-transactions{text-align:center;color:var(--color-gray-500);padding:var(--spacing-4);font-size:.875rem}.amount-credit{color:var(--color-success);font-weight:600}.amount-debit{color:var(--color-error);font-weight:600}.alert{margin-bottom:var(--spacing-4)}.alert button{margin-left:auto;background:none;border:none;cursor:pointer;padding:var(--spacing-1)}.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-6);margin-bottom:var(--spacing-6)}.stat-card{background:var(--color-white);border:1px solid var(--color-gray-200);border-radius:var(--radius-xl);padding:var(--spacing-5);display:flex;align-items:center;gap:var(--spacing-4)}.stat-icon{width:48px;height:48px;background:var(--color-gray-100);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center}.stat-content{display:flex;flex-direction:column}.stat-label{font-size:.875rem;color:var(--color-gray-500)}.stat-value{font-size:1.5rem;font-weight:700}.dues-list{display:grid;gap:var(--spacing-4)}.due-card{border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);padding:var(--spacing-5)}.due-card.due-overdue{border-color:var(--color-error);background:#fef2f2}.due-card.due-upcoming{border-color:var(--color-warning);background:#fffbeb}.due-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-4)}.due-card-name{display:flex;align-items:center;gap:var(--spacing-2);font-weight:600;font-size:1.125rem}.due-status-badge{display:flex;align-items:center;gap:var(--spacing-1);font-size:.875rem;font-weight:500;padding:var(--spacing-1) var(--spacing-3);border-radius:var(--radius-full)}.status-overdue{background:#fee2e2;color:#991b1b}.status-upcoming{background:#fef3c7;color:#92400e}.status-safe{background:#dcfce7;color:#166534}.due-details{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-3);margin-bottom:var(--spacing-4)}.due-row{display:flex;justify-content:space-between}.due-label{color:var(--color-gray-500);font-size:.875rem}.due-value{font-weight:500}.due-date{color:var(--color-error)}.due-amount{font-size:1.125rem;font-weight:700}.btn-full{width:100%}@media(max-width:768px){.stats-grid{grid-template-columns:1fr}.form-row{flex-direction:column}.due-details,.credit-card-info{grid-template-columns:1fr}}.toast-container{position:fixed;top:var(--spacing-6);right:var(--spacing-6);z-index:1100;display:flex;flex-direction:column;gap:var(--spacing-3);max-width:400px}.toast{background:var(--color-white);border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);padding:var(--spacing-4);box-shadow:var(--shadow-md);display:flex;align-items:flex-start;gap:var(--spacing-3);animation:toastSlideIn .3s ease}.toast-success{border-left:4px solid var(--color-success)}.toast-success .toast-icon{color:var(--color-success)}.toast-error{border-left:4px solid var(--color-error)}.toast-error .toast-icon{color:var(--color-error)}.toast-warning{border-left:4px solid var(--color-warning)}.toast-warning .toast-icon{color:var(--color-warning)}.toast-info{border-left:4px solid var(--color-info)}.toast-info .toast-icon{color:var(--color-info)}.toast-icon{flex-shrink:0;margin-top:2px}.toast-message{flex:1;font-size:.875rem;color:var(--color-gray-700)}.toast-close{background:none;border:none;cursor:pointer;padding:0;color:var(--color-gray-400);flex-shrink:0}.toast-close:hover{color:var(--color-gray-600)}@keyframes toastSlideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.confirm-dialog{max-width:420px}.confirm-dialog-content{display:flex;gap:var(--spacing-4);padding:var(--spacing-6)}.confirm-dialog-icon{width:48px;height:48px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;flex-shrink:0}.confirm-dialog-icon.icon-warning{background:#fef3c7;color:#d97706}.confirm-dialog-icon.icon-danger{background:#fee2e2;color:#dc2626}.confirm-dialog-icon.icon-info{background:#dbeafe;color:#2563eb}.confirm-dialog-text{flex:1}.confirm-dialog-title{font-size:1.125rem;font-weight:600;color:var(--color-gray-900);margin-bottom:var(--spacing-2)}.confirm-dialog-message{font-size:.875rem;color:var(--color-gray-600);line-height:1.5}.confirm-input-wrapper{margin-top:var(--spacing-4)}.confirm-input-hint{font-size:.813rem;color:var(--color-gray-500);margin-bottom:var(--spacing-2)}.confirm-dialog-actions{display:flex;justify-content:flex-end;gap:var(--spacing-3);padding:var(--spacing-4) var(--spacing-6);background:var(--color-gray-50);border-top:1px solid var(--color-gray-200);border-radius:0 0 var(--radius-xl) var(--radius-xl)}.inline-category-editor{position:relative;display:inline-block}.category-dropdown{position:absolute;top:100%;left:0;z-index:1000;background:#fff;border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);box-shadow:0 10px 25px #00000026;min-width:220px;max-width:280px;animation:dropdown-fade .15s ease-out}@keyframes dropdown-fade{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.category-dropdown-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-2) var(--spacing-3);border-bottom:1px solid var(--color-gray-100)}.category-learn-option{display:flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-2) var(--spacing-3);background:var(--color-gray-50);border-bottom:1px solid var(--color-gray-100);cursor:pointer}.category-learn-option input{width:14px;height:14px;cursor:pointer}.category-list{max-height:240px;overflow-y:auto;padding:var(--spacing-1) 0}.category-item{display:flex;justify-content:space-between;align-items:center;width:100%;padding:var(--spacing-2) var(--spacing-3);background:none;border:none;text-align:left;font-size:.875rem;cursor:pointer;transition:background .1s}.category-item:hover{background:var(--color-gray-50)}.category-item.active{background:var(--color-primary);color:#fff}.category-group{margin:0}.category-group-header{padding:var(--spacing-1) var(--spacing-3);font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-gray-400);background:var(--color-gray-50)}.category-divider{height:1px;background:var(--color-gray-200);margin:var(--spacing-1) 0}.category-add-btn{display:flex;align-items:center;gap:var(--spacing-2);width:100%;padding:var(--spacing-2) var(--spacing-3);background:none;border:none;border-top:1px solid var(--color-gray-100);color:var(--color-primary);font-size:.875rem;cursor:pointer;transition:background .1s}.category-add-btn:hover{background:var(--color-gray-50)}.category-add-new{display:flex;gap:var(--spacing-2);padding:var(--spacing-2) var(--spacing-3);border-top:1px solid var(--color-gray-100)}.category-add-new .form-input-sm{flex:1;padding:var(--spacing-1) var(--spacing-2);font-size:.813rem}.btn-icon-sm{display:flex;align-items:center;justify-content:center;width:20px;height:20px;background:none;border:none;border-radius:var(--radius-sm);cursor:pointer;color:var(--color-gray-400);transition:all .15s}.btn-icon-sm:hover{background:var(--color-gray-100);color:var(--color-gray-600)}.learn-notification{display:flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-2) var(--spacing-3);background:#ecfdf5;border:1px solid #a7f3d0;border-radius:var(--radius-md);color:#065f46;font-size:.813rem;margin-top:var(--spacing-2);animation:fade-in .2s ease-out}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.grid-cols-3{grid-template-columns:repeat(3,1fr)}.badge.cursor-pointer{cursor:pointer}.badge.cursor-pointer:hover{opacity:.8}.expense-breakdown-list{display:flex;flex-direction:column;gap:var(--spacing-3);padding-top:var(--spacing-2)}.expense-bar-item{display:grid;grid-template-columns:1fr auto;gap:var(--spacing-1);align-items:center}.expense-bar-header{display:flex;justify-content:space-between;align-items:center;grid-column:1 / -1}.expense-bar-category{font-size:.875rem;font-weight:500;color:var(--color-gray-700)}.expense-bar-amount{font-size:.875rem;font-weight:600;color:var(--color-gray-900)}.expense-bar-track{height:8px;background:var(--color-gray-100);border-radius:var(--radius-full);overflow:hidden;flex:1}.expense-bar-fill{height:100%;border-radius:var(--radius-full);transition:width .3s ease}.expense-bar-percent{font-size:.75rem;color:var(--color-gray-500);min-width:40px;text-align:right}.budget-overview-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-4)}.budget-categories-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--spacing-4)}.budget-category-item{padding:var(--spacing-3);border-radius:var(--radius-md);background:var(--color-gray-50);transition:all var(--transition-fast)}.budget-category-item:hover{background:var(--color-gray-100)}.budget-category-item.over{background:#fef2f2;border-left:3px solid var(--color-error)}.budget-category-item.warning{background:#fffbeb;border-left:3px solid var(--color-warning)}.budget-category-item.ok{border-left:3px solid var(--color-success)}.budget-category-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-2)}.budget-category-name{font-weight:500;font-size:.875rem}.budget-category-percent{font-weight:600;font-size:.75rem}.budget-category-percent.over{color:var(--color-error)}.budget-category-percent.warning{color:var(--color-warning)}.budget-category-percent.ok{color:var(--color-success)}.budget-progress-track{height:6px;background:var(--color-gray-200);border-radius:var(--radius-full);overflow:visible;position:relative;margin-bottom:var(--spacing-2)}.budget-progress-fill{height:100%;border-radius:var(--radius-full);transition:width .3s ease}.budget-progress-fill.ok{background:var(--color-success)}.budget-progress-fill.warning{background:var(--color-warning)}.budget-progress-fill.over{background:var(--color-error)}.budget-progress-overflow{position:absolute;right:0;top:-2px;height:10px;background:var(--color-error);opacity:.3;border-radius:var(--radius-full)}.budget-category-amounts{display:flex;justify-content:space-between;font-size:.75rem}.budget-spent{font-weight:500}.budget-limit{color:var(--color-gray-500)}.badge{display:inline-flex;align-items:center;gap:var(--spacing-1);padding:var(--spacing-1) var(--spacing-2);border-radius:var(--radius-full);font-size:.75rem;font-weight:500}.badge-danger{background:#fef2f2;color:var(--color-error)}.badge-warning{background:#fffbeb;color:var(--color-warning)}.badge-success{background:#f0fdf4;color:var(--color-success)}body,.sidebar,.card,.topbar,.form-input,.form-select,.form-textarea,.modal,.btn{transition-property:background-color,border-color,color,box-shadow;transition-duration:var(--transition-normal);transition-timing-function:cubic-bezier(.4,0,.2,1)}.card{animation:rise .26s cubic-bezier(.4,0,.2,1) both;transition:box-shadow var(--transition-normal),transform var(--transition-fast),border-color var(--transition-normal),background-color var(--transition-normal)}.card:hover{box-shadow:var(--shadow-md)}.page-header{animation:rise .26s cubic-bezier(.4,0,.2,1) both}.table td,.card-value,.stat-value{font-variant-numeric:tabular-nums}input[type=checkbox],input[type=radio]{accent-color:var(--accent)}.form-textarea{resize:vertical;min-height:80px}.modal-overlay{animation:overlay-in .2s ease both}.modal{animation:modal-in .24s cubic-bezier(.16,1,.3,1) both}[data-theme=dark] .badge-success{background:#34d39924}[data-theme=dark] .badge-warning{background:#fbbf2424}[data-theme=dark] .badge-danger,[data-theme=dark] .badge-error{background:#f8717129}[data-theme=dark] .badge-info{background:#60a5fa29}[data-theme=dark] .badge-gray,[data-theme=dark] .badge{background:var(--color-gray-100);color:var(--color-gray-700)}[data-theme=dark] .tag-badge{background:#ffffff14;color:var(--color-gray-700)}.theme-toggle{display:flex;align-items:center;gap:var(--spacing-2);width:100%;padding:.5rem var(--spacing-3);margin-bottom:var(--spacing-1);border:none;background:transparent;color:var(--color-gray-500);border-radius:var(--radius-md);font-size:.875rem;font-weight:500;cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast)}.theme-toggle:hover{background:var(--color-gray-50);color:var(--color-gray-900)}.app.collapsed .theme-toggle{justify-content:center}@keyframes rise{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes overlay-in{0%{opacity:0}to{opacity:1}}@keyframes modal-in{0%{opacity:0;transform:translateY(12px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.tabs{display:flex;gap:var(--spacing-1);background:var(--color-gray-100);padding:4px;border-radius:var(--radius-lg);margin-bottom:var(--spacing-6)}.tab{flex:1;min-width:0;display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-2);padding:var(--spacing-2) var(--spacing-3);border:none;background:transparent;color:var(--color-gray-600);font-weight:600;font-size:.875rem;border-radius:var(--radius-md);cursor:pointer;white-space:nowrap;transition:background var(--transition-fast),color var(--transition-fast)}.tab:hover{color:var(--color-gray-900)}.tab.active{background:var(--color-white);color:var(--color-black);box-shadow:var(--shadow-sm)}.tab svg{flex-shrink:0}@media(max-width:768px){.app{flex-direction:column}.topbar{justify-content:center;padding:var(--spacing-3)}.topbar-brand{font-size:.95rem}.sidebar{width:auto;left:0;right:0;top:auto;bottom:0;height:auto;max-height:82vh;transform:translateY(105%);border-right:none;border-top:1px solid var(--color-gray-200);border-radius:20px 20px 0 0;box-shadow:0 -10px 40px #00000038;padding:var(--spacing-4) var(--spacing-4) calc(var(--spacing-5) + env(safe-area-inset-bottom,0px))}.app.mobile-open .sidebar,.app.collapsed.mobile-open .sidebar{transform:translateY(0)}.app.collapsed .sidebar{width:auto;padding:var(--spacing-4)}.sidebar-header{margin-bottom:var(--spacing-3)}.sidebar-collapse-hint{display:none}.sidebar-logo{cursor:default}.sidebar-logo:hover{background:none}.footer-icons{gap:var(--spacing-2)}.sheet-close{display:inline-flex;margin-left:auto;width:40px;height:40px;background:var(--color-gray-100);color:var(--color-gray-700)}.sheet-close:hover{background:var(--color-gray-200)}.sidebar:before{content:"";position:absolute;top:8px;left:50%;width:38px;height:4px;transform:translate(-50%);background:var(--color-gray-300);border-radius:var(--radius-full)}.mb-6{margin-bottom:var(--spacing-3)}.mb-4{margin-bottom:var(--spacing-2)}.card-header{margin-bottom:var(--spacing-3)}.stat-card{gap:var(--spacing-1)}.stat-value{font-size:1.25rem}.stat-label{font-size:.8rem}.empty-state{padding:var(--spacing-6)}.empty-state-icon{font-size:2rem}.table-container{overflow-x:visible}.table,.table tbody,.data-table,.data-table tbody{display:block;width:100%}.table thead,.data-table thead{display:none}.table tr,.data-table tr{display:block;padding:var(--spacing-3) 0;border-bottom:1px solid var(--color-gray-200)}.table tbody tr:last-child,.data-table tbody tr:last-child{border-bottom:none}.table tbody tr:hover,.data-table tbody tr:hover{background:none}.table td,.data-table td{display:flex;justify-content:space-between;align-items:center;gap:var(--spacing-4);padding:var(--spacing-1) 0;border:none;text-align:right;font-size:.85rem}.table td:before,.data-table td:before{content:attr(data-label);font-weight:600;color:var(--color-gray-500);text-transform:uppercase;font-size:.65rem;letter-spacing:.04em;text-align:left;white-space:nowrap;flex-shrink:0}.table td:last-child,.data-table td:last-child{justify-content:flex-end;padding-top:var(--spacing-2)}.stats-grid{grid-template-columns:repeat(2,1fr);gap:var(--spacing-3);margin-bottom:var(--spacing-4)}.header-actions{display:flex;flex-wrap:wrap;gap:var(--spacing-2);width:100%}.header-actions>*{flex:1 1 140px;justify-content:center}.main-content{overflow-x:hidden}.filters{flex-direction:row;flex-wrap:wrap;align-items:center;gap:var(--spacing-2);width:100%}.filters>*{width:auto!important;flex:1 1 28%;min-width:0}.tabs{width:100%}.tab{font-size:.8rem;padding-left:var(--spacing-2);padding-right:var(--spacing-2);overflow:hidden;text-overflow:ellipsis}.upload-mode-toggle{display:flex;width:100%}.upload-mode-toggle>*{flex:1}.form-input,.form-textarea{font-size:16px;padding:.5rem .65rem}.form-select{font-size:.9rem;padding:.45rem .6rem}.btn{min-height:38px;padding:.5rem .85rem;font-size:.85rem}.btn svg{width:15px;height:15px}.btn-sm{min-height:32px;padding:.35rem .6rem;font-size:.8rem}.page-title{font-size:1.1rem}.page-subtitle{font-size:.78rem;margin-top:1px}.card-title{font-size:.9rem}.card-value{font-size:1.15rem}.card-label{font-size:.72rem}.card{padding:var(--spacing-4)}.card.stat-card{padding:var(--spacing-3)}.stat-card{gap:1px}.stat-value{font-size:1.05rem}.stat-label{font-size:.72rem}.page-header{flex-direction:row;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:var(--spacing-2)}.page-header>div:first-child{flex:1 1 60%;min-width:0}.page-header h1{font-size:1.1rem;font-weight:700;letter-spacing:-.01em}.page-header>.btn{flex:0 0 auto;width:auto}.page-header .header-actions{flex:1 1 100%}.bottom-nav{display:flex;position:fixed;left:0;right:0;bottom:0;z-index:85;background:var(--color-white);border-top:1px solid var(--color-gray-200);padding-bottom:env(safe-area-inset-bottom,0px);box-shadow:0 -1px 6px #0000000a}.main-content{padding:var(--spacing-4) var(--spacing-3);padding-bottom:calc(64px + env(safe-area-inset-bottom,0px))}.page-header{margin-bottom:var(--spacing-3)}.grid{gap:var(--spacing-2)}.grid-cols-3,.grid-cols-4{grid-template-columns:repeat(2,1fr)}.grid-cols-2{grid-template-columns:1fr}.modal{max-width:100%}.modal-header,.modal-footer,.modal-body{padding:var(--spacing-4)}.nav-link{padding-top:var(--spacing-3);padding-bottom:var(--spacing-3)}.twofa-setup{flex-direction:column}.twofa-setup>*{width:100%}}@media(max-width:480px){.main-content{padding:var(--spacing-3) var(--spacing-2);padding-bottom:calc(64px + env(safe-area-inset-bottom,0px))}.card{padding:var(--spacing-3)}.card-value{font-size:1.1rem}.stat-value{font-size:1.05rem}.page-title{font-size:1.1rem}.grid-cols-3,.grid-cols-4{grid-template-columns:repeat(2,1fr)}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}}
