@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";:root{--sidebar-width:260px;--topbar-height:56px;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--font:"Inter", -apple-system, BlinkMacSystemFont, sans-serif;--transition:.18s ease}[data-theme=dark]{--bg-base:#0e0e0f;--bg-surface:#16161a;--bg-card:#1c1c21;--bg-hover:#22222a;--bg-input:#111118;--border:#2e2e38;--border-subtle:#222230;--text-1:#ececf1;--text-2:#9191a4;--text-3:#55556a;--accent:#7c6dfa;--accent-hover:#9585ff;--accent-bg:#7c6dfa1f;--accent-border:#7c6dfa4d;--success:#22c55e;--success-bg:#22c55e1f;--warning:#f59e0b;--warning-bg:#f59e0b1f;--danger:#ef4444;--danger-bg:#ef44441f;--shadow-sm:0 2px 8px #00000059;--shadow-md:0 8px 24px #00000073;--shadow-lg:0 20px 60px #000000a6}[data-theme=light]{--bg-base:#f0f2f8;--bg-surface:#fff;--bg-card:#fff;--bg-hover:#f4f5fd;--bg-input:#f8f8fd;--border:#e4e4ef;--border-subtle:#ededf7;--text-1:#0f0f1a;--text-2:#4a4a65;--text-3:#9090b0;--accent:#6c63ff;--accent-hover:#5b54ef;--accent-bg:#6c63ff14;--accent-border:#6c63ff40;--success:#16a34a;--success-bg:#16a34a14;--warning:#d97706;--warning-bg:#d9770614;--danger:#dc2626;--danger-bg:#dc262614;--shadow-sm:0 2px 8px #0000000f;--shadow-md:0 8px 24px #00000017;--shadow-lg:0 20px 60px #00000024}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{height:100%}body{font-family:var(--font);background:var(--bg-base);color:var(--text-1);-webkit-font-smoothing:antialiased;min-height:100vh;transition:background var(--transition), color var(--transition)}#root{height:100%}a{color:inherit;text-decoration:none}button{font-family:var(--font)}.app-layout{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-width);background:var(--bg-surface);border-right:1px solid var(--border);z-index:100;height:100vh;transition:transform var(--transition);flex-direction:column;display:flex;position:fixed;top:0;left:0;overflow-y:auto}.sidebar-header{border-bottom:1px solid var(--border);padding:18px 16px}.sidebar-logo{align-items:center;gap:10px;display:flex}.logo-icon{font-size:22px}.logo-text{color:var(--text-1);letter-spacing:-.5px;font-size:18px;font-weight:800}.sidebar-nav{flex:1;padding:10px 8px;overflow-y:auto}.nav-group{margin-bottom:6px}.nav-group-label{letter-spacing:1px;color:var(--text-3);text-transform:uppercase;padding:8px 8px 4px;font-size:10px;font-weight:700;display:block}.nav-item{border-radius:var(--radius-sm);color:var(--text-2);transition:background var(--transition), color var(--transition);cursor:pointer;align-items:center;gap:10px;margin-bottom:1px;padding:7px 10px;font-size:13.5px;font-weight:450;display:flex}.nav-item:hover{background:var(--bg-hover);color:var(--text-1)}.nav-item.active{background:var(--accent-bg);color:var(--accent);box-shadow:inset 3px 0 0 var(--accent);font-weight:600}.nav-icon{text-align:center;width:20px;font-size:15px}.sidebar-footer{border-top:1px solid var(--border);justify-content:space-between;align-items:center;padding:12px 14px;display:flex}.user-info{align-items:center;gap:8px;display:flex}.user-avatar{object-fit:cover;border-radius:50%;width:28px;height:28px}.user-name{color:var(--text-2);text-overflow:ellipsis;white-space:nowrap;max-width:130px;font-size:13px;font-weight:500;overflow:hidden}.logout-btn{cursor:pointer;color:var(--text-3);border-radius:var(--radius-sm);transition:color var(--transition);background:0 0;border:none;padding:4px;font-size:16px}.logout-btn:hover{color:var(--danger)}.main-content{margin-left:var(--sidebar-width);flex-direction:column;flex:1;min-height:100vh;display:flex}.topbar{height:var(--topbar-height);background:var(--bg-surface);border-bottom:1px solid var(--border);z-index:50;justify-content:space-between;align-items:center;padding:0 28px;display:flex;position:sticky;top:0}.menu-btn{cursor:pointer;color:var(--text-2);background:0 0;border:none;font-size:20px;display:none}.topbar-right{align-items:center;gap:8px;display:flex}.theme-toggle{background:var(--bg-hover);border:1px solid var(--border);cursor:pointer;border-radius:var(--radius-sm);width:34px;height:34px;transition:background var(--transition);justify-content:center;align-items:center;font-size:15px;display:flex}.theme-toggle:hover{background:var(--bg-card)}.page-content{flex:1;padding:28px 32px}.page-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.page-title{color:var(--text-1);letter-spacing:-.4px;font-size:22px;font-weight:700}.page-title span{color:var(--text-3);margin-left:8px;font-size:14px;font-weight:400}.section-tools{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:20px;display:flex}.search-input{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);min-width:200px;color:var(--text-1);font-size:13.5px;font-family:var(--font);transition:border-color var(--transition);flex:1;padding:8px 13px}.search-input:focus{border-color:var(--accent);outline:none}.search-input::placeholder{color:var(--text-3)}.filter-select{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-1);font-size:13.5px;font-family:var(--font);cursor:pointer;transition:border-color var(--transition);padding:8px 13px}.filter-select:focus{border-color:var(--accent);outline:none}.grid{gap:14px;display:grid}.grid-1{grid-template-columns:1fr}.grid-2{grid-template-columns:repeat(auto-fill,minmax(340px,1fr))}.grid-3{grid-template-columns:repeat(auto-fill,minmax(270px,1fr))}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);transition:box-shadow var(--transition), border-color var(--transition), transform var(--transition);padding:16px}.card:hover{border-color:var(--accent-border);box-shadow:var(--shadow-md);transform:translateY(-1px)}.card-header{justify-content:space-between;align-items:flex-start;margin-bottom:12px;display:flex}.card-title{color:var(--text-1);font-size:14.5px;font-weight:600}.card-subtitle{color:var(--text-3);margin-top:2px;font-size:12px}.card-actions{flex-shrink:0;gap:4px;margin-left:8px;display:flex}.card-field{flex-direction:column;margin-bottom:8px;display:flex}.card-field:last-child{margin-bottom:0}.field-label{color:var(--text-3);text-transform:uppercase;letter-spacing:.6px;margin-bottom:3px;font-size:10.5px}.field-value{color:var(--text-2);font-family:SF Mono,Fira Code,Consolas,monospace;font-size:13px}.field-row{gap:16px;display:flex}.field-row .card-field{flex:1}.btn{border-radius:var(--radius-sm);font-size:13.5px;font-weight:500;font-family:var(--font);cursor:pointer;transition:background var(--transition), opacity var(--transition);white-space:nowrap;border:none;align-items:center;gap:6px;padding:8px 16px;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}.btn-secondary{background:var(--bg-hover);color:var(--text-1);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:var(--bg-card)}.btn-danger{background:var(--danger-bg);color:var(--danger);border:1px solid #0000}.btn-danger:hover:not(:disabled){background:var(--danger);color:#fff}.btn-sm{padding:5px 10px;font-size:12px}.btn-icon{cursor:pointer;border-radius:var(--radius-sm);color:var(--text-3);transition:background var(--transition), color var(--transition);background:0 0;border:none;padding:5px;font-size:14px}.btn-icon:hover{background:var(--bg-hover);color:var(--text-1)}.btn-icon.danger:hover{background:var(--danger-bg);color:var(--danger)}.badge{white-space:nowrap;border-radius:20px;align-items:center;padding:2px 8px;font-size:11px;font-weight:600;display:inline-flex}.badge-default{background:var(--bg-hover);color:var(--text-2)}.badge-success{background:var(--success-bg);color:var(--success)}.badge-warning{background:var(--warning-bg);color:var(--warning)}.badge-danger{background:var(--danger-bg);color:var(--danger)}.badge-accent{background:var(--accent-bg);color:var(--accent)}.copy-btn{border-radius:var(--radius-sm);font-size:11px;font-weight:500;font-family:var(--font);cursor:pointer;border:1px solid var(--border);color:var(--text-3);transition:all var(--transition);background:0 0;align-items:center;gap:3px;padding:2px 8px;display:inline-flex}.copy-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-bg)}.copy-btn.copied{background:var(--success-bg);color:var(--success);border-color:#0000}.modal-overlay{z-index:200;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#0009;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.modal{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:520px;max-height:90vh;box-shadow:var(--shadow-lg);overflow-y:auto}.modal-lg{max-width:680px}.modal-header{border-bottom:1px solid var(--border);background:var(--bg-surface);z-index:1;justify-content:space-between;align-items:center;padding:18px 22px;display:flex;position:sticky;top:0}.modal-title{font-size:17px;font-weight:700}.modal-close{cursor:pointer;color:var(--text-3);border-radius:var(--radius-sm);transition:color var(--transition);background:0 0;border:none;padding:4px;font-size:18px}.modal-close:hover{color:var(--text-1)}.modal-body{padding:22px}.modal-footer{border-top:1px solid var(--border);justify-content:flex-end;gap:10px;padding:14px 22px;display:flex}.form-group{margin-bottom:15px}.form-row{grid-template-columns:1fr 1fr;gap:15px;display:grid}.form-label{color:var(--text-2);margin-bottom:5px;font-size:12.5px;font-weight:500;display:block}.form-input,.form-select,.form-textarea{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text-1);font-size:13.5px;font-family:var(--font);transition:border-color var(--transition);padding:9px 12px}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--accent);outline:none}.form-input::placeholder,.form-textarea::placeholder{color:var(--text-3)}.form-select{cursor:pointer}.form-textarea{resize:vertical;min-height:80px;line-height:1.55}.input-with-toggle{position:relative}.input-with-toggle .form-input{padding-right:38px}.input-toggle-btn{cursor:pointer;color:var(--text-3);background:0 0;border:none;font-size:14px;position:absolute;top:50%;right:10px;transform:translateY(-50%)}.star-rating{align-items:center;gap:2px;display:flex}.star{cursor:pointer;color:var(--text-3);transition:color var(--transition), transform var(--transition);font-size:16px}.star:hover{transform:scale(1.15)}.star.filled{color:#f59e0b}.empty-state{text-align:center;padding:72px 24px}.empty-icon{opacity:.5;margin-bottom:14px;font-size:52px}.empty-title{color:var(--text-2);margin-bottom:6px;font-size:17px;font-weight:600}.empty-desc{color:var(--text-3);margin-bottom:22px;font-size:13.5px}.login-page{background:var(--bg-base);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.login-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);text-align:center;width:100%;max-width:420px;box-shadow:var(--shadow-lg);padding:52px 44px}.login-icon{margin-bottom:14px;font-size:56px}.login-title{color:var(--text-1);letter-spacing:-.5px;margin-bottom:8px;font-size:28px;font-weight:800}.login-subtitle{color:var(--text-3);margin-bottom:36px;font-size:14.5px;line-height:1.55}.btn-google{background:var(--bg-hover);border:1px solid var(--border);border-radius:var(--radius-md);width:100%;font-size:15px;font-weight:600;font-family:var(--font);color:var(--text-1);cursor:pointer;transition:background var(--transition), box-shadow var(--transition);justify-content:center;align-items:center;gap:12px;padding:12px;display:flex}.btn-google:hover{background:var(--bg-card);box-shadow:var(--shadow-sm)}.login-theme-toggle{position:fixed;top:20px;right:20px}.dash-greeting-block{margin-bottom:28px}.dash-greeting-text{color:var(--text-1);letter-spacing:-.5px;margin-bottom:4px;font-size:26px;font-weight:800}.dash-greeting-text span{color:var(--accent)}.dash-greeting-date{color:var(--text-3);font-size:13px;font-weight:400}.stats-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px;margin-bottom:24px;display:grid}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);transition:box-shadow var(--transition), transform var(--transition), border-color var(--transition);cursor:pointer;align-items:center;gap:14px;padding:16px 18px;text-decoration:none;display:flex}.stat-card:hover{box-shadow:var(--shadow-md);border-color:var(--accent-border);transform:translateY(-2px)}.stat-card-icon{border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:20px;display:flex}.stat-card-body{flex:1;min-width:0}.stat-card-value{color:var(--text-1);letter-spacing:-.5px;margin-bottom:3px;font-size:22px;font-weight:800;line-height:1}.stat-card-label{color:var(--text-3);font-size:12px;font-weight:500}.stat-card-arrow{opacity:0;transition:opacity var(--transition);flex-shrink:0;font-size:16px}.stat-card:hover .stat-card-arrow{opacity:1}.dashboard-sections{grid-template-columns:1fr 1fr;gap:16px;display:grid}.dash-panel{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:20px}.dash-panel-header{justify-content:space-between;align-items:center;margin-bottom:14px;display:flex}.dash-panel-title{color:var(--text-1);text-transform:uppercase;letter-spacing:.5px;align-items:center;gap:8px;font-size:13px;font-weight:700;display:flex}.dash-panel-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.dash-panel-link{color:var(--accent);font-size:12px;font-weight:500}.dash-row{border-bottom:1px solid var(--border-subtle);justify-content:space-between;align-items:center;padding:8px 0;display:flex}.dash-row:last-child{border-bottom:none}.dash-row-name{color:var(--text-2);text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:13px;overflow:hidden}.dash-row-badge{border-radius:20px;flex-shrink:0;margin-left:8px;padding:2px 8px;font-size:11px;font-weight:600}.dash-row-badge.accent{background:var(--accent-bg);color:var(--accent)}.dash-row-badge.success{background:var(--success-bg);color:var(--success)}.dash-row-badge.warning{background:var(--warning-bg);color:var(--warning)}.dash-panel-spend .dash-spend-amount{color:var(--text-1);letter-spacing:-1px;margin:8px 0 4px;font-size:36px;font-weight:800}.dash-panel-spend .dash-spend-amount span{color:var(--text-3);letter-spacing:0;font-size:16px;font-weight:400}.dash-panel-spend .dash-spend-sub{color:var(--text-3);font-size:12px}.dash-empty{color:var(--text-3);text-align:center;padding:24px 0;font-size:13px}.expense-summary{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px;margin-bottom:22px;display:grid}.expense-stat{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:14px 16px}.expense-stat-label{color:var(--text-3);text-transform:uppercase;letter-spacing:.5px;margin-bottom:5px;font-size:11px}.expense-stat-value{color:var(--text-1);font-size:22px;font-weight:700}.expense-stat-sub{color:var(--text-3);margin-top:2px;font-size:11px}.sub-banner{background:var(--accent-bg);border:1px solid var(--accent-border);border-radius:var(--radius-md);gap:28px;margin-bottom:20px;padding:14px 20px;display:flex}.sub-banner-label{color:var(--accent);margin-bottom:3px;font-size:11px;font-weight:600}.sub-banner-value{color:var(--text-1);font-size:20px;font-weight:700}.card-visual{background:linear-gradient(135deg, var(--accent) 0%, #b06dfa 100%);border-radius:var(--radius-md);color:#fff;flex-direction:column;justify-content:space-between;min-height:88px;margin-bottom:12px;padding:14px 16px;display:flex}.card-visual-number{letter-spacing:2px;font-family:SF Mono,monospace;font-size:14px}.card-visual-row{justify-content:space-between;align-items:flex-end;display:flex}.card-visual-holder{letter-spacing:.5px;font-size:12px;font-weight:600}.card-visual-expiry{opacity:.8;font-size:11px}.card-visual-network{opacity:.85;text-align:right;font-size:12px;font-weight:600}.note-content{color:var(--text-2);white-space:pre-wrap;-webkit-line-clamp:4;-webkit-box-orient:vertical;font-size:13px;line-height:1.6;display:-webkit-box;overflow:hidden}.note-tags{flex-wrap:wrap;gap:4px;margin-top:10px;display:flex}.note-tag{background:var(--accent-bg);color:var(--accent);border-radius:20px;padding:2px 8px;font-size:11px}.dump-item{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);margin-bottom:10px;padding:14px 16px}.dump-timestamp{color:var(--text-3);margin-bottom:7px;font-size:11px}.dump-content{color:var(--text-1);white-space:pre-wrap;font-size:13.5px;line-height:1.6}.divider{background:var(--border);height:1px;margin:14px 0}.loading{min-height:200px;color:var(--text-3);justify-content:center;align-items:center;font-size:13.5px;display:flex}.flex-between{justify-content:space-between;align-items:center;display:flex}.flex-gap{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.text-accent{color:var(--accent)}.text-success{color:var(--success)}.text-warning{color:var(--warning)}.text-danger{color:var(--danger)}.text-muted{color:var(--text-3)}.upload-zone{border:2px dashed var(--border);border-radius:var(--radius-md);text-align:center;cursor:pointer;transition:border-color var(--transition), background var(--transition);-webkit-user-select:none;user-select:none;margin-bottom:16px;padding:32px 24px}.upload-zone:hover,.upload-zone.dragging{border-color:var(--accent);background:var(--accent-bg)}.upload-zone.uploading{cursor:default}.upload-icon{margin-bottom:8px;font-size:36px}.upload-text{color:var(--text-1);margin-bottom:4px;font-size:15px;font-weight:600}.upload-sub{color:var(--text-3);font-size:12px}.upload-progress-bar-wrap{background:var(--border);margin-top:14px;border-radius:3px;max-width:300px;height:5px;margin-inline:auto;overflow:hidden}.upload-progress-fill{background:var(--accent);border-radius:3px;height:100%;transition:width .15s}.cat-picker{flex-wrap:wrap;gap:6px;display:flex}.cat-pill{cursor:pointer;border:1px solid var(--border);color:var(--text-2);font-size:12px;font-weight:500;font-family:var(--font);transition:all var(--transition);background:0 0;border-radius:20px;padding:5px 12px}.cat-pill:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-bg)}.cat-pill.active{background:var(--accent);color:#fff;border-color:var(--accent)}.doc-card{text-align:center;padding:16px}.doc-preview-img{object-fit:cover;border-radius:var(--radius-sm);width:100%;height:110px;margin-bottom:10px;display:block}.doc-file-icon{margin-bottom:8px;font-size:44px;line-height:1}.doc-name{color:var(--text-1);text-overflow:ellipsis;white-space:nowrap;max-width:100%;margin-bottom:2px;font-size:12.5px;font-weight:500;overflow:hidden}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-3)}.sidebar-overlay{z-index:99;background:#00000080;position:fixed;inset:0}@media (width<=768px){.sidebar{box-shadow:none;transform:translate(-100%)}.sidebar.open{box-shadow:var(--shadow-lg);transform:translate(0)}.main-content{margin-left:0}.menu-btn{justify-content:center;align-items:center;min-width:40px;min-height:40px;display:flex}.topbar{padding:0 14px}.page-content{padding:16px 14px}.page-header{flex-wrap:wrap;gap:10px;margin-bottom:16px}.page-title{font-size:19px}.grid-2,.grid-3{grid-template-columns:1fr}.stats-grid{grid-template-columns:1fr;gap:8px;margin-bottom:18px}.stat-card{padding:12px 14px}.stat-card-icon{width:36px;height:36px;font-size:16px}.stat-card-value{font-size:18px}.dash-greeting-text{font-size:20px}.dashboard-sections{grid-template-columns:1fr;gap:12px}.dashboard-greeting{font-size:18px}.dashboard-date{margin-bottom:18px}.expense-summary{grid-template-columns:repeat(2,1fr)}.sub-banner{flex-direction:column;gap:12px;padding:14px 16px}.section-tools{gap:8px}.search-input{min-width:0}.filter-select{width:100%}.form-row{grid-template-columns:1fr;gap:0}.modal-overlay{align-items:flex-end;padding:0}.modal,.modal-lg{border-radius:var(--radius-lg) var(--radius-lg) 0 0;width:100%;max-width:100%;max-height:92vh}.modal-header,.modal-body{padding:16px 18px}.modal-footer{padding:12px 18px}.form-input,.form-select,.form-textarea,.search-input,.filter-select{font-size:16px}.card{padding:14px}.card-title{font-size:14px}.card-visual{min-height:80px;padding:12px 14px}.card-visual-number{letter-spacing:1.5px;font-size:13px}.btn{min-height:40px;padding:10px 16px}.btn-sm{min-height:34px;padding:7px 12px}.btn-icon{min-width:34px;min-height:34px;padding:8px}.login-card{padding:36px 24px}.login-title{font-size:24px}.dump-item{padding:12px}.field-row{flex-direction:column;gap:8px}.field-row .card-field{flex:none}.copy-btn{padding:5px 10px;font-size:12px}.note-content{-webkit-line-clamp:3}}
