*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-base:#0a0a0f;--bg-surface:#111118;--bg-card:#16161f;--bg-card-hover:#1c1c28;--border:#ffffff12;--border-active:#8b5cf680;--accent:#8b5cf6;--accent-bright:#a78bfa;--accent-dim:#8b5cf626;--accent-glow:#8b5cf640;--green:#10b981;--green-dim:#10b98126;--red:#ef4444;--red-dim:#ef44441f;--amber:#f59e0b;--amber-dim:#f59e0b26;--blue:#3b82f6;--blue-dim:#3b82f626;--pink:#ec4899;--pink-dim:#ec489926;--text-primary:#f0f0f8;--text-secondary:#9090a8;--text-muted:#5a5a72;--sidebar-width:240px;--topbar-height:60px;--radius:12px;--radius-sm:8px;--radius-xs:6px;--shadow:0 4px 24px #0006;--shadow-card:0 2px 12px #0000004d}html,body,#root{background:var(--bg-base);height:100%;color:var(--text-primary);-webkit-font-smoothing:antialiased;font-family:Inter,system-ui,sans-serif;font-size:14px;line-height:1.6}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#fff3}.app-layout{height:100vh;display:flex;overflow:hidden}.sidebar{width:var(--sidebar-width);background:var(--bg-surface);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;display:flex;overflow-y:auto}.sidebar-logo{border-bottom:1px solid var(--border);padding:20px 20px 16px}.sidebar-logo .logo-name{background:linear-gradient(135deg, var(--accent-bright), #c084fc);-webkit-text-fill-color:transparent;letter-spacing:-.5px;-webkit-background-clip:text;background-clip:text;font-size:20px;font-weight:800}.sidebar-logo .logo-sub{color:var(--text-muted);letter-spacing:.3px;margin-top:2px;font-size:11px}.sidebar-section{padding:16px 12px 8px}.sidebar-section-label{letter-spacing:1.2px;text-transform:uppercase;color:var(--text-muted);margin-bottom:6px;padding:0 8px;font-size:10px;font-weight:600}.nav-item{border-radius:var(--radius-xs);color:var(--text-secondary);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:10px;width:100%;padding:9px 10px;font-size:13px;font-weight:500;text-decoration:none;transition:all .15s;display:flex}.nav-item:hover{color:var(--text-primary);background:#ffffff0d}.nav-item.active{background:var(--accent-dim);color:var(--accent-bright);border:1px solid var(--accent-glow)}.nav-item .nav-icon{flex-shrink:0;width:16px;height:16px}.nav-item .nav-badge{background:var(--accent-dim);color:var(--accent-bright);border-radius:10px;margin-left:auto;padding:2px 6px;font-size:10px;font-weight:600}.nav-item .nav-soon{color:var(--text-muted);background:#ffffff0f;border-radius:10px;margin-left:auto;padding:2px 6px;font-size:9px;font-weight:600}.sidebar-footer{border-top:1px solid var(--border);color:var(--text-muted);margin-top:auto;padding:16px;font-size:12px}.sidebar-footer strong{color:var(--text-secondary);margin-bottom:2px;display:block}.main-area{flex-direction:column;flex:1;display:flex;overflow:hidden}.topbar{height:var(--topbar-height);background:var(--bg-surface);border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;gap:16px;padding:0 24px;display:flex}.topbar-title{color:var(--text-primary);font-size:15px;font-weight:600}.topbar-meta{color:var(--text-muted);margin-left:auto;font-size:12px}.topbar-date{color:var(--text-secondary);background:#ffffff0d;border-radius:20px;padding:4px 10px;font-size:12px}.page-content{flex:1;padding:24px;overflow-y:auto}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;margin-bottom:24px;display:grid}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:18px 20px;transition:all .2s;position:relative;overflow:hidden}.stat-card:before{content:"";background:var(--card-accent,var(--accent));opacity:.7;height:2px;position:absolute;top:0;left:0;right:0}.stat-card:hover{background:var(--bg-card-hover);border-color:#ffffff1f}.stat-label{letter-spacing:.5px;color:var(--text-muted);text-transform:uppercase;margin-bottom:8px;font-size:11px;font-weight:600}.stat-value{color:var(--text-primary);letter-spacing:-.5px;font-size:24px;font-weight:700;line-height:1.2}.stat-sub{color:var(--text-muted);margin-top:4px;font-size:11px}.section-header{justify-content:space-between;align-items:center;margin-bottom:14px;display:flex}.section-title{color:var(--text-primary);align-items:center;gap:8px;font-size:14px;font-weight:700;display:flex}.section-title svg{color:var(--accent-bright)}.btn{border-radius:var(--radius-xs);cursor:pointer;white-space:nowrap;border:1px solid #0000;align-items:center;gap:6px;padding:8px 14px;font-family:inherit;font-size:13px;font-weight:500;text-decoration:none;transition:all .15s;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}.btn-primary:hover:not(:disabled){background:var(--accent-bright);border-color:var(--accent-bright);box-shadow:0 0 16px var(--accent-glow)}.btn-secondary{color:var(--text-secondary);border-color:var(--border);background:#ffffff0f}.btn-secondary:hover:not(:disabled){color:var(--text-primary);background:#ffffff1a}.btn-danger{background:var(--red-dim);color:var(--red);border-color:#ef44444d}.btn-danger:hover:not(:disabled){background:#ef444433}.btn-ghost{color:var(--text-muted);background:0 0;border-color:#0000;padding:6px 8px}.btn-ghost:hover{color:var(--text-primary);background:#ffffff0f}.btn-sm{padding:5px 10px;font-size:12px}.btn-icon{border-radius:var(--radius-xs);padding:7px}.form-group{flex-direction:column;gap:5px;display:flex}.form-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:600}.form-control{border:1px solid var(--border);border-radius:var(--radius-xs);color:var(--text-primary);background:#ffffff0d;outline:none;padding:8px 12px;font-family:inherit;font-size:13px;transition:all .15s}.form-control:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow);background:#8b5cf60d}.form-control::placeholder{color:var(--text-muted)}select.form-control{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%235a5a72' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;padding-right:32px}.expense-layout{flex-direction:column;gap:20px;display:flex}.toolbar{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.toolbar-spacer{flex:1;min-width:12px}.category-pills{flex-wrap:wrap;gap:6px;margin-bottom:4px;display:flex}.pill{cursor:pointer;color:var(--text-muted);background:#ffffff0d;border:1px solid #0000;border-radius:20px;padding:4px 12px;font-size:12px;font-weight:600;transition:all .15s}.pill.active,.pill:hover{background:var(--pill-bg,var(--accent-dim));color:var(--pill-color,var(--accent-bright));border-color:var(--pill-border,var(--accent-glow))}.table-container{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.expense-table{border-collapse:collapse;width:100%}.expense-table th{text-align:left;letter-spacing:.8px;text-transform:uppercase;color:var(--text-muted);border-bottom:1px solid var(--border);background:#ffffff08;padding:10px 14px;font-size:10px;font-weight:700}.expense-table td{color:var(--text-secondary);vertical-align:middle;border-bottom:1px solid #ffffff08;padding:11px 14px;font-size:13px}.expense-table tr:last-child td{border-bottom:none}.expense-table tbody tr:hover td{color:var(--text-primary);background:#ffffff05}.expense-table .amount-cell{font-variant-numeric:tabular-nums;color:var(--text-primary);font-weight:700}.expense-table tfoot td{border-top:1px solid var(--accent-glow);color:var(--text-primary);background:#8b5cf60f;font-size:13px;font-weight:700}.cat-badge{border-radius:12px;align-items:center;gap:5px;padding:3px 8px;font-size:11px;font-weight:600;display:inline-flex}.project-badge{background:var(--accent-dim);color:var(--accent-bright);border-radius:12px;align-items:center;gap:4px;padding:3px 8px;font-size:11px;font-weight:600;display:inline-flex}.modal-backdrop{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:1000;background:#000000b3;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);width:100%;max-width:520px;max-height:90vh;box-shadow:var(--shadow);overflow-y:auto}.modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:20px 20px 16px;display:flex}.modal-title{color:var(--text-primary);font-size:15px;font-weight:700}.modal-body{flex-direction:column;gap:14px;padding:20px;display:flex}.modal-footer{border-top:1px solid var(--border);justify-content:flex-end;gap:8px;padding:16px 20px;display:flex}.form-row{grid-template-columns:1fr 1fr;gap:14px;display:grid}@media print{.sidebar,.topbar,.toolbar,.no-print,.btn-icon,.modal-backdrop{display:none!important}.app-layout,.main-area{display:block}.page-content{padding:0;overflow:visible}.expense-table td,.expense-table th{border:1px solid #ddd;color:#000!important;background:#fff!important}.expense-table{border-collapse:collapse}.stat-card{page-break-inside:avoid;border:1px solid #ccc}.cat-badge,.project-badge{border:1px solid #ccc;color:#000!important;background:#f5f5f5!important}@page{margin:20mm}}.coming-soon{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:12px;min-height:60vh;display:flex}.coming-soon .icon{background:var(--accent-dim);border-radius:16px;justify-content:center;align-items:center;width:56px;height:56px;margin-bottom:8px;display:flex}.coming-soon h2{color:var(--text-primary);font-size:18px;font-weight:700}.coming-soon p{color:var(--text-muted);font-size:13px}.empty-state{text-align:center;color:var(--text-muted);padding:40px 20px;font-size:13px}.month-group-header{color:var(--accent-bright);border-bottom:1px solid var(--border);background:#ffffff05;justify-content:space-between;align-items:center;padding:8px 14px;font-size:12px;font-weight:700;display:flex}.month-total-badge{background:var(--accent-dim);color:var(--accent-bright);border-radius:10px;padding:2px 8px;font-size:11px}.cat-breakdown{flex-direction:column;gap:10px;display:flex}.cat-row{align-items:center;gap:10px;display:flex}.cat-row-label{width:80px;color:var(--text-secondary);flex-shrink:0;font-size:12px;font-weight:600}.cat-bar-track{background:#ffffff0f;border-radius:4px;flex:1;height:8px;overflow:hidden}.cat-bar-fill{border-radius:4px;height:100%;transition:width .4s}.cat-row-amount{text-align:right;font-variant-numeric:tabular-nums;width:80px;color:var(--text-primary);flex-shrink:0;font-size:12px;font-weight:700}.summary-grid{grid-template-columns:1fr 1fr;gap:16px;display:grid}@media (width<=900px){.summary-grid{grid-template-columns:1fr}}.login-page{background:var(--bg-base);background-image:radial-gradient(at 30% 20%,#8b5cf61f 0%,#0000 60%),radial-gradient(at 80% 80%,#60a5fa14 0%,#0000 60%);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.login-card{background:var(--bg-card);border:1px solid var(--border);text-align:center;border-radius:20px;flex-direction:column;align-items:center;gap:12px;width:100%;max-width:380px;padding:40px 36px;display:flex;box-shadow:0 20px 60px #00000080}.login-logo .logo-name{background:linear-gradient(135deg, var(--accent-bright), #c084fc);-webkit-text-fill-color:transparent;letter-spacing:-.5px;-webkit-background-clip:text;background-clip:text;font-size:28px;font-weight:800}.login-shield{background:var(--accent-dim);border:1px solid var(--accent-glow);border-radius:16px;justify-content:center;align-items:center;width:60px;height:60px;margin:4px 0;display:flex}.login-title{color:var(--text-primary);font-size:20px;font-weight:700}.login-sub{color:var(--text-muted);margin-bottom:4px;font-size:13px;line-height:1.6}.login-sub strong{color:var(--text-secondary)}.login-error{background:var(--red-dim);border-radius:var(--radius-xs);width:100%;color:var(--red);text-align:center;border:1px solid #ef44444d;padding:10px 14px;font-size:12px}.btn-google{color:#1f1f1f;border-radius:var(--radius-sm);cursor:pointer;background:#fff;border:none;justify-content:center;align-items:center;gap:10px;width:100%;margin-top:4px;padding:12px 20px;font-family:inherit;font-size:14px;font-weight:600;transition:all .15s;display:flex;box-shadow:0 2px 8px #0003}.btn-google:hover{background:#f5f5f5;transform:translateY(-1px);box-shadow:0 4px 16px #0000004d}.login-footer{color:var(--text-muted);margin-top:8px;font-size:11px}.user-chip{border:1px solid var(--border);cursor:default;background:#ffffff0d;border-radius:20px;align-items:center;gap:8px;padding:4px 12px 4px 4px;display:flex}.user-avatar{object-fit:cover;border:1px solid var(--accent-glow);border-radius:50%;width:26px;height:26px}.user-avatar-fallback{background:var(--accent-dim);width:26px;height:26px;color:var(--accent-bright);border-radius:50%;justify-content:center;align-items:center;font-size:11px;font-weight:700;display:flex}.user-name{color:var(--text-secondary);font-size:12px;font-weight:500}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.toast{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);box-shadow:var(--shadow);z-index:2000;align-items:center;gap:8px;padding:12px 16px;font-size:13px;animation:.2s slideIn;display:flex;position:fixed;bottom:24px;right:24px}@keyframes slideIn{0%{opacity:0;transform:translate(100px)}to{opacity:1;transform:translate(0)}}.toast.success{border-color:#10b98166}.toast.error{border-color:#ef444466}
