@import "https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@500;600;700&family=Sora:wght@300;400;500;600&display=swap";*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--sidebar-w:256px;--sidebar-bg:#111318;--sidebar-border:#1e2028;--sidebar-text:#7a8090;--sidebar-hover:#1a1d26;--sidebar-active-bg:#eba9421f;--sidebar-active:#eba942;--bg:#f6f4ef;--surface:#fff;--surface-2:#f9f8f5;--border:#e8e4dc;--border-h:#d0c9bb;--text:#1a1714;--muted:#7a746a;--light:#a89e94;--primary:#d4891e;--primary-l:#eba942;--primary-bg:#fef3e2;--primary-hover:#b97318;--success:#2d9e6b;--success-bg:#e8f8f2;--danger:#d94f3c;--danger-bg:#fef0ee;--info:#3b7dd8;--info-bg:#eef4fd;--r:10px;--r-lg:16px;--r-xl:20px;--shadow-sm:0 1px 3px #0000000f,0 1px 2px #0000000a;--shadow:0 4px 12px #00000014,0 1px 3px #0000000d;--shadow-lg:0 16px 40px #0000001f,0 4px 12px #0000000f;--t:.16s ease;--font-head:"Cormorant Garamond", Georgia, serif;--font-body:"Sora", -apple-system, sans-serif;--topbar-h:58px}html{-webkit-text-size-adjust:100%;font-size:15px}body{font-family:var(--font-body);background:var(--bg);color:var(--text);min-height:100vh;line-height:1.6}a{color:var(--primary);text-decoration:none}button{cursor:pointer;font-family:var(--font-body)}input,select,textarea{font-family:var(--font-body)}#root{flex-direction:column;min-height:100vh;display:flex}.app-layout{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-w);background:var(--sidebar-bg);z-index:100;border-right:1px solid var(--sidebar-border);transition:transform var(--t);flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0;overflow-y:auto}.sidebar-brand{border-bottom:1px solid var(--sidebar-border);flex-shrink:0;padding:22px 18px 16px}.brand-row{align-items:center;gap:10px;display:flex}.brand-icon{background:linear-gradient(135deg,var(--primary-l),var(--primary));border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:17px;display:flex}.brand-name{font-family:var(--font-head);color:#f0ede8;letter-spacing:-.02em;font-size:1.3rem;font-weight:600;line-height:1}.brand-sub{color:var(--sidebar-text);letter-spacing:.05em;text-transform:uppercase;margin-top:2px;font-size:.66rem}.sidebar-user{border-bottom:1px solid var(--sidebar-border);flex-shrink:0;align-items:center;gap:9px;padding:12px 18px;display:flex}.user-avatar{color:#fff;text-transform:uppercase;background:linear-gradient(135deg,#3b82f6,#8b5cf6);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:12px;font-weight:600;display:flex}.user-name{color:#ccc8c2;white-space:nowrap;text-overflow:ellipsis;font-size:.8rem;font-weight:500;overflow:hidden}.user-role{color:var(--sidebar-text);text-transform:uppercase;letter-spacing:.04em;font-size:.66rem}.sidebar-nav{flex:1;padding:8px 0}.nav-label{letter-spacing:.1em;text-transform:uppercase;color:#424752;padding:12px 18px 4px;font-size:.63rem;font-weight:500}.nav-item{color:var(--sidebar-text);transition:all var(--t);cursor:pointer;text-align:left;background:0 0;border:none;border-left:3px solid #0000;align-items:center;gap:9px;width:100%;min-height:44px;padding:9px 18px;font-size:.82rem;font-weight:400;display:flex}.nav-item:hover{background:var(--sidebar-hover);color:#c0bcb5}.nav-item.active{background:var(--sidebar-active-bg);color:var(--sidebar-active);border-left-color:var(--sidebar-active);font-weight:500}.nav-icon{text-align:center;flex-shrink:0;width:18px;font-size:.95rem}.sidebar-footer{border-top:1px solid var(--sidebar-border);flex-shrink:0;padding:12px 18px}.logout-btn{color:var(--sidebar-text);width:100%;transition:color var(--t);cursor:pointer;background:0 0;border:none;align-items:center;gap:8px;min-height:44px;padding:8px 0;font-size:.8rem;display:flex}.logout-btn:hover{color:#e87b6e}.main-content{margin-left:var(--sidebar-w);flex-direction:column;flex:1;min-width:0;min-height:100vh;display:flex}.topbar{background:var(--surface);border-bottom:1px solid var(--border);height:var(--topbar-h);z-index:50;justify-content:space-between;align-items:center;gap:12px;padding:0 24px;display:flex;position:sticky;top:0}.topbar-title{font-family:var(--font-head);letter-spacing:-.02em;white-space:nowrap;text-overflow:ellipsis;font-size:1.35rem;font-weight:600;overflow:hidden}.topbar-left{flex:1;align-items:center;gap:10px;min-width:0;display:flex}.topbar-actions{flex-shrink:0;align-items:center;gap:8px;display:flex}.menu-toggle{color:var(--text);cursor:pointer;background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;min-width:36px;min-height:36px;padding:4px;font-size:1.35rem;display:none}.page-content{flex:1;min-width:0;padding:20px 24px}.overlay{z-index:90;background:#0006;display:none;position:fixed;inset:0}.overlay.open{display:block}.alert{border-radius:var(--r);align-items:flex-start;gap:8px;margin-bottom:16px;padding:10px 14px;font-size:.82rem;display:flex}.alert-success{background:var(--success-bg);color:#1a7a52;border:1px solid #b7e5d4}.alert-error{background:var(--danger-bg);color:#b63325;border:1px solid #f4c5c0}.alert-info{background:var(--info-bg);color:#2660b0;border:1px solid #c3d9f8}.btn{font-family:var(--font-body);border-radius:var(--r);cursor:pointer;transition:all var(--t);white-space:nowrap;touch-action:manipulation;border:1px solid #0000;justify-content:center;align-items:center;gap:6px;min-height:36px;padding:8px 15px;font-size:.81rem;font-weight:500;line-height:1;display:inline-flex}.btn-sm{min-height:30px;padding:5px 11px;font-size:.76rem}.btn-lg{min-height:44px;padding:11px 22px;font-size:.9rem}.btn-full{width:100%}.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary);box-shadow:0 1px 3px #d4891e4d}.btn-primary:hover{background:var(--primary-hover);border-color:var(--primary-hover)}.btn-primary:active{transform:scale(.98)}.btn-secondary{background:var(--surface);color:var(--text);border-color:var(--border-h)}.btn-secondary:hover{background:var(--surface-2);border-color:#b8b0a4}.btn-danger{background:var(--danger);color:#fff;border-color:var(--danger)}.btn-danger:hover{background:#c0372a}.btn-ghost{color:var(--muted);background:0 0;border-color:#0000;border-radius:6px;min-width:34px;min-height:34px;padding:6px}.btn-ghost:hover{background:var(--surface-2);color:var(--text)}.card{background:var(--surface);border-radius:var(--r-lg);border:1px solid var(--border);box-shadow:var(--shadow-sm)}.card-header{border-bottom:1px solid var(--border);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:14px 20px;display:flex}.card-title{font-family:var(--font-head);letter-spacing:-.01em;font-size:1.05rem;font-weight:600}.card-body{padding:16px 20px}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;margin-bottom:20px;display:grid}.stat-card{background:var(--surface);border-radius:var(--r-lg);border:1px solid var(--border);box-shadow:var(--shadow-sm);transition:box-shadow var(--t), transform var(--t);flex-direction:column;gap:3px;padding:16px 18px;display:flex}.stat-card:hover{box-shadow:var(--shadow);transform:translateY(-1px)}.stat-icon{margin-bottom:4px;font-size:1.3rem}.stat-label{letter-spacing:.06em;text-transform:uppercase;color:var(--muted);font-size:.68rem;font-weight:500}.stat-value{font-family:var(--font-head);color:var(--text);letter-spacing:-.03em;font-size:1.65rem;font-weight:700;line-height:1}.stat-sub{color:var(--light);font-size:.71rem}.filter-bar{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);grid-template-columns:repeat(auto-fill,minmax(140px,1fr));align-items:end;gap:10px;margin-bottom:16px;padding:14px 16px;display:grid}.filter-group{flex-direction:column;gap:3px;display:flex}.filter-label{color:var(--muted);letter-spacing:.04em;text-transform:uppercase;font-size:.67rem;font-weight:500}.filter-input{border:1px solid var(--border);height:36px;color:var(--text);background:var(--bg);width:100%;transition:border-color var(--t), box-shadow var(--t);appearance:none;border-radius:6px;padding:0 10px;font-size:.82rem}.filter-input:focus{border-color:var(--primary-l);outline:none;box-shadow:0 0 0 3px #eba9421f}.filter-actions{align-items:flex-end;gap:6px;display:flex}.table-wrap{border-radius:var(--r-lg);border:1px solid var(--border);background:var(--surface);box-shadow:var(--shadow-sm);-webkit-overflow-scrolling:touch;overflow-x:auto}table{border-collapse:collapse;width:100%;font-size:.83rem}thead th{background:var(--surface-2);text-align:left;letter-spacing:.07em;text-transform:uppercase;color:var(--muted);border-bottom:1px solid var(--border);white-space:nowrap;cursor:pointer;-webkit-user-select:none;user-select:none;padding:10px 14px;font-size:.67rem;font-weight:600}thead th:hover{color:var(--primary)}tbody tr{border-bottom:1px solid var(--border);transition:background var(--t)}tbody tr:last-child{border-bottom:none}tbody tr:hover{background:var(--surface-2)}tbody td{vertical-align:middle;padding:10px 14px}.amount-cell{font-family:var(--font-head);white-space:nowrap;font-size:.98rem;font-weight:600}.date-cell{color:var(--muted);white-space:nowrap;font-size:.8rem}.vendor-cell{color:var(--muted);text-overflow:ellipsis;white-space:nowrap;max-width:140px;font-size:.81rem;overflow:hidden}.notes-cell{color:var(--light);text-overflow:ellipsis;white-space:nowrap;max-width:140px;font-size:.78rem;overflow:hidden}@media (width<=640px){.table-card-view table,.table-card-view thead,.table-card-view tbody,.table-card-view th,.table-card-view td,.table-card-view tr{display:block}.table-card-view thead{display:none}.table-card-view tbody tr{border:1px solid var(--border);border-radius:var(--r);background:var(--surface);box-shadow:var(--shadow-sm);margin:0 0 10px;padding:12px 14px;position:relative}.table-card-view tbody tr:last-child{border-bottom:1px solid var(--border)}.table-card-view tbody tr:hover{background:var(--surface)}.table-card-view tbody td{white-space:normal;border:none;align-items:baseline;gap:8px;max-width:100%;padding:4px 0;font-size:.82rem;display:flex}.table-card-view tbody td:before{content:attr(data-label);letter-spacing:.06em;text-transform:uppercase;color:var(--light);flex-shrink:0;min-width:68px;font-size:.65rem;font-weight:600}.table-card-view tbody td.td-actions{flex-direction:row;gap:2px;padding:0;position:absolute;top:10px;right:12px}.table-card-view tbody td.td-actions:before{display:none}.table-card-view tbody td.td-amount{font-family:var(--font-head);letter-spacing:-.02em;border-bottom:1px solid var(--border);margin-bottom:4px;padding-bottom:6px;font-size:1.2rem;font-weight:700}.table-card-view tbody td.td-amount:before{display:none}.table-card-view .amount-cell,.table-card-view .date-cell,.table-card-view .vendor-cell,.table-card-view .notes-cell{white-space:normal;max-width:none;color:var(--text);font-size:.82rem}.table-wrap.table-card-view{box-shadow:none;background:0 0;border:none;border-radius:0;overflow-x:visible}.table-card-view .table-info{border-radius:var(--r);border:1px solid var(--border);background:var(--surface);margin-bottom:10px}}.badge{letter-spacing:.04em;text-transform:uppercase;border-radius:20px;align-items:center;padding:2px 8px;font-size:.68rem;font-weight:600;display:inline-flex}.badge-admin{color:#5b21b6;background:#ede9fe}.badge-user{color:#075985;background:#e0f2fe}.badge-active{background:var(--success-bg);color:var(--success)}.badge-inactive{color:#6b7280;background:#f3f4f6}.cat-badge{border-radius:20px;flex-shrink:0;align-items:center;gap:5px;padding:3px 9px;font-size:.71rem;font-weight:500;display:inline-flex}.form-grid{grid-template-columns:1fr 1fr;gap:14px;display:grid}.form-full{grid-column:1/-1}.form-group{flex-direction:column;gap:4px;display:flex}.form-label{color:var(--muted);font-size:.76rem;font-weight:500}.form-input{border:1px solid var(--border);color:var(--text);background:var(--bg);width:100%;min-height:38px;transition:border-color var(--t), box-shadow var(--t);appearance:none;border-radius:6px;padding:9px 11px;font-size:.84rem}.form-input:focus{border-color:var(--primary-l);background:var(--surface);outline:none;box-shadow:0 0 0 3px #eba9421f}textarea.form-input{resize:vertical;min-height:68px}.modal-overlay{z-index:200;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000080;justify-content:center;align-items:flex-end;padding:0;display:none;position:fixed;inset:0}.modal-overlay.open{display:flex}.modal{background:var(--surface);border-radius:var(--r-xl) var(--r-xl) 0 0;box-shadow:var(--shadow-lg);-webkit-overflow-scrolling:touch;width:100%;max-height:92dvh;animation:.2s mIn;overflow-y:auto}.modal:before{content:"";background:var(--border-h);border-radius:2px;width:36px;height:4px;margin:10px auto 0;display:block}@keyframes mIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:14px 20px 12px;display:flex}.modal-title{font-family:var(--font-head);font-size:1.2rem;font-weight:600}.modal-close{color:var(--muted);cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;min-width:36px;min-height:36px;padding:4px 8px;font-size:1.3rem;line-height:1;display:flex}.modal-close:hover{background:var(--surface-2);color:var(--text)}.modal-body{padding:16px 20px}.modal-footer{border-top:1px solid var(--border);justify-content:flex-end;gap:10px;padding:12px 20px 20px;display:flex}.modal-footer .btn{min-height:42px}.tabs{background:var(--bg);border-radius:var(--r);border:1px solid var(--border);-webkit-overflow-scrolling:touch;gap:3px;width:fit-content;max-width:100%;margin-bottom:16px;padding:3px;display:flex;overflow-x:auto}.tab-btn{border-radius:calc(var(--r) - 2px);color:var(--muted);cursor:pointer;transition:all var(--t);white-space:nowrap;touch-action:manipulation;background:0 0;border:none;align-items:center;gap:5px;min-height:36px;padding:7px 16px;font-size:.8rem;font-weight:500;display:flex}.tab-btn:hover{color:var(--text);background:var(--border)}.tab-btn.active{background:var(--surface);color:var(--text);box-shadow:var(--shadow-sm)}.pagination{flex-wrap:wrap;justify-content:center;align-items:center;gap:4px;padding:14px 10px;display:flex}.page-link{width:34px;height:34px;color:var(--muted);border:1px solid var(--border);cursor:pointer;transition:all var(--t);touch-action:manipulation;background:0 0;border-radius:6px;justify-content:center;align-items:center;font-size:.78rem;font-weight:500;display:flex}.page-link:hover{background:var(--primary-bg);border-color:var(--primary-l);color:var(--primary)}.page-link.current{background:var(--primary);border-color:var(--primary);color:#fff}.charts-grid{grid-template-columns:1fr 1fr;gap:16px;margin-bottom:20px;display:grid}.chart-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);padding:16px 20px}.chart-title{font-family:var(--font-head);margin-bottom:12px;font-size:1rem;font-weight:600}.login-page{background:var(--sidebar-bg);background-image:radial-gradient(at 20%,#d4891e14 0%,#0000 60%),radial-gradient(at 80% 20%,#6366f114 0%,#0000 60%);justify-content:center;align-items:center;min-height:100dvh;padding:16px;display:flex}.login-box{width:100%;max-width:380px}.login-brand{text-align:center;margin-bottom:28px}.login-brand-icon{background:linear-gradient(135deg,var(--primary-l),var(--primary));border-radius:14px;justify-content:center;align-items:center;width:52px;height:52px;margin:0 auto 12px;font-size:23px;display:flex;box-shadow:0 8px 24px #d4891e59}.login-brand h1{font-family:var(--font-head);color:#f0ede8;letter-spacing:-.03em;font-size:1.9rem;font-weight:600}.login-brand p{color:#4a5060;margin-top:3px;font-size:.8rem}.login-form{border-radius:var(--r-xl);background:#1a1d26;border:1px solid #252830;flex-direction:column;gap:14px;padding:24px;display:flex;box-shadow:0 24px 48px #0006}.login-form .form-label{color:#7a8090}.login-form .form-input{color:#d0ccc5;background:#111318;border-color:#252830;min-height:44px}.login-form .form-input:focus{color:#f0ede8;background:#111318}.login-form .form-input::placeholder{color:#3a3f50}.login-hint{text-align:center;color:#3a3f50;margin-top:12px;font-size:.71rem}.empty-state{text-align:center;color:var(--muted);padding:48px 20px}.empty-icon{opacity:.4;margin-bottom:10px;font-size:2.2rem}.empty-state h3{font-family:var(--font-head);color:var(--light);margin-bottom:5px;font-size:1.1rem}.empty-state p{font-size:.82rem}.table-info{border-bottom:1px solid var(--border);color:var(--muted);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;padding:10px 16px;font-size:.79rem;display:flex}.range-chips{flex-wrap:wrap;gap:5px;margin-bottom:16px;display:flex}.range-chip{border:1px solid var(--border);background:var(--surface);color:var(--muted);cursor:pointer;transition:all var(--t);touch-action:manipulation;border-radius:20px;align-items:center;min-height:34px;padding:6px 12px;font-size:.76rem;font-weight:500;display:inline-flex}.range-chip:hover{border-color:var(--primary-l);color:var(--primary);background:var(--primary-bg)}.range-chip.active{background:var(--primary);border-color:var(--primary);color:#fff}.color-row{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.color-row input[type=color]{border:1px solid var(--border);cursor:pointer;background:0 0;border-radius:6px;width:40px;height:40px;padding:3px}.flex{display:flex}.flex-col{flex-direction:column}.gap-2{gap:8px}.gap-3{gap:12px}.items-center{align-items:center}.justify-between{justify-content:space-between}.flex-wrap{flex-wrap:wrap}.text-right{text-align:right}.text-center{text-align:center}.mt-3{margin-top:12px}.mb-4{margin-bottom:16px}.fw-500{font-weight:500}.text-muted{color:var(--muted)}.text-sm{font-size:.8rem}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.section-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px;display:flex}.section-title{font-family:var(--font-head);font-size:1.2rem;font-weight:600}.section-sub{color:var(--muted);margin-top:1px;font-size:.8rem}@media (width<=900px){.charts-grid{grid-template-columns:1fr}}@media (width<=768px){.sidebar{transform:translateX(calc(-1 * var(--sidebar-w)));box-shadow:none}.sidebar.open{box-shadow:var(--shadow-lg);transform:translate(0)}.main-content{margin-left:0}.menu-toggle{display:inline-flex}.page-content{padding:14px 14px 24px}.topbar{padding:0 14px}.filter-bar{grid-template-columns:1fr 1fr}.form-grid{grid-template-columns:1fr}.form-full{grid-column:1}.modal{border-radius:var(--r-xl) var(--r-xl) 0 0;max-height:90dvh}.charts-grid{gap:12px}.stats-grid{grid-template-columns:1fr 1fr;gap:10px}.section-header{gap:8px}}@media (width<=480px){:root{--topbar-h:52px}.stats-grid{grid-template-columns:1fr 1fr}.filter-bar{grid-template-columns:1fr;gap:8px;padding:12px}.modal{border-radius:var(--r-xl) var(--r-xl) 0 0}.modal-footer{flex-direction:column-reverse}.modal-footer .btn{width:100%}.topbar-title{font-size:1.15rem}.page-content{padding:12px 12px 24px}.range-chips{gap:4px}.range-chip{padding:5px 10px;font-size:.72rem}.table-wrap{border-radius:var(--r)}}@media (width<=360px){.stats-grid{grid-template-columns:1fr}.stat-value{font-size:1.45rem}}
