:root{--bg:#f1f2f4;--bg-card:#fff;--text:#252526;--text-muted:#544f69;--border:#c0bcdf;--income:#10b981;--expense:#ef4444;--emi:#f59e0b;--accent:#8776ea;--shadow:0 4px 6px -1px #544f6914,0 2px 4px -1px #544f690a;--shadow-lg:0 10px 15px -3px #544f691f,0 4px 6px -2px #544f690f}[data-theme=dark]{--bg:#1d1c1d;--bg-card:#4d4847;--text:#f6f6f6;--text-muted:#6d6a6b;--border:#5c5a59;--income:#34d399;--expense:#f87171;--emi:#fbbf24;--accent:#8776ea;--shadow:0 4px 6px -1px #0009,0 2px 4px -1px #0006;--shadow-lg:0 10px 20px -5px #000000b3}[data-theme=dark] .console-panel.left-panel,[data-theme=dark] .login-card,[data-theme=dark] .mobile-drawer{background:#4d4847!important;border-color:#5c5a59!important}::-webkit-scrollbar{height:6px;width:6px}::-webkit-scrollbar-track{background:#0000}::-webkit-scrollbar-thumb{background:#c0bcdf;background:var(--border);border-radius:10px}::-webkit-scrollbar-thumb:hover{background:#8776ea;background:var(--accent)}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;background:#f1f2f4;background:var(--bg);color:#252526;color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;line-height:1.5;overscroll-behavior-x:none;width:100%}.app,body{overflow-x:hidden}.app{min-height:100vh;padding-bottom:80px;touch-action:pan-y pinch-zoom}.container{margin:0 auto;max-width:600px;padding:12px}.header{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px;padding:12px 0}.header h1{font-size:1.1rem;font-weight:700}.header-actions{align-items:center;display:flex;gap:6px}.toggle{height:22px;position:relative;width:40px}.toggle input{display:none}.toggle-slider{background:#c0bcdf;background:var(--border);border-radius:22px;cursor:pointer;inset:0;position:absolute;transition:.2s}.toggle-slider:before{background:#fff;border-radius:50%;bottom:3px;content:"";height:16px;left:3px;position:absolute;transition:.2s;width:16px}.toggle input:checked+.toggle-slider{background:#8776ea;background:var(--accent)}.toggle input:checked+.toggle-slider:before{transform:translateX(18px)}.tabs{-webkit-overflow-scrolling:touch;background:#fff;background:var(--bg-card);border-radius:10px;box-shadow:0 4px 6px -1px #544f6914,0 2px 4px -1px #544f690a;box-shadow:var(--shadow);display:flex;gap:4px;margin-bottom:12px;overflow-x:auto;padding:4px;scroll-snap-type:x mandatory;scrollbar-width:none}.tabs::-webkit-scrollbar{display:none}.tab{background:#0000;border:none;border-radius:8px;color:#544f69;color:var(--text-muted);cursor:pointer;flex:0 0 auto;font-size:.8rem;font-weight:600;min-width:70px;padding:10px 14px;scroll-snap-align:start;text-align:center;transition:all .15s;white-space:nowrap}.tab:hover{color:#252526;color:var(--text)}.tab.active{background:#8776ea;background:var(--accent);box-shadow:0 2px 8px #0080804d;color:#fff}.btn{border:none;border-radius:10px;cursor:pointer;font-size:.85rem;font-weight:600;padding:10px 14px;touch-action:manipulation;transition:all .15s}.btn:active{transform:scale(.97)}.btn-primary{background:#8776ea;background:var(--accent);color:#fff}.btn-secondary{background:#f1f2f4;background:var(--bg);border:1px solid #c0bcdf;border:1px solid var(--border);color:#252526;color:var(--text)}.btn-sm{font-size:.75rem;padding:6px 10px}.mb-4{margin-bottom:16px}.month-nav{align-items:center;display:flex;gap:12px;justify-content:center;margin-bottom:12px}.month-nav button{background:#fff;background:var(--bg-card);border:1px solid #c0bcdf;border:1px solid var(--border);border-radius:10px;box-shadow:0 4px 6px -1px #544f6914,0 2px 4px -1px #544f690a;box-shadow:var(--shadow);color:#252526;color:var(--text);cursor:pointer;font-size:1.1rem;height:40px;width:40px}.month-nav button:active{background:#c0bcdf;background:var(--border)}.month-nav span{font-size:1rem;font-weight:700;min-width:140px;text-align:center}.money-needed-card{background:#8776ea;background:var(--accent);border-radius:20px;box-shadow:0 10px 25px -5px #8776ea59;color:#fff;margin-bottom:16px;overflow:hidden;padding:24px 20px;position:relative;text-align:center}.money-needed-card:before{background:radial-gradient(circle at top right,#ffffff1a 0,#0000 60%);bottom:0;content:"";left:0;pointer-events:none;position:absolute;right:0;top:0}.money-needed-label{font-size:.85rem;margin-bottom:6px;opacity:.9}.money-needed-value{font-size:1.8rem;font-weight:800;letter-spacing:-.5px;margin-bottom:6px}.money-needed-value.positive{color:#fff}.money-needed-value.negative{color:#fecaca;text-shadow:0 0 10px #ef444480}.money-needed-breakdown{font-size:.8rem;opacity:.85}.warning{background:#fef2f2;border:1px solid #fecaca;border-radius:10px;color:#b91c1c;font-size:.85rem;font-weight:500;margin-bottom:12px;padding:12px}[data-theme=dark] .warning{background:#450a0a;border-color:#7f1d1d;color:#fca5a5}.summary{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr;margin-bottom:24px}.summary-card{background:#fff;background:var(--bg-card);border:1px solid #0000;border-radius:16px;box-shadow:0 4px 6px -1px #544f6914,0 2px 4px -1px #544f690a;box-shadow:var(--shadow);padding:16px;text-align:center;transition:transform .2s,box-shadow .2s}.summary-card:active{transform:scale(.98)}[data-theme=light] .summary-card{border:1px solid #e2e8f099}.summary-card .label{color:#544f69;color:var(--text-muted);font-size:.7rem;font-weight:700;letter-spacing:.5px;margin-bottom:6px;text-transform:uppercase}.summary-card .value{font-size:1.25rem;font-weight:800;letter-spacing:-.5px}.summary-card.income .value{color:#10b981;color:var(--income)}.summary-card.expense .value{color:#ef4444;color:var(--expense)}.summary-card.emi .value{color:#f59e0b;color:var(--emi)}.summary-card.cash .value{color:#8776ea;color:var(--accent)}.summary-card.debt .value{color:#ef4444;color:var(--expense)}.summary-card.owe .value{color:#10b981;color:var(--income)}.summary-card.next-emi{background:#f59e0b0d;border:2px solid #f59e0b;border:2px solid var(--emi)}[data-theme=dark] .summary-card.next-emi{background:#fbbf240d}.summary-card.next-emi .value{color:#f59e0b;color:var(--emi)}.summary-card.positive .value{color:#10b981;color:var(--income)}.summary-card.negative .value{color:#ef4444;color:var(--expense)}.section{background:#fff;background:var(--bg-card);border:1px solid #c0bcdf;border:1px solid var(--border);border-radius:18px;box-shadow:0 4px 6px -1px #544f6914,0 2px 4px -1px #544f690a;box-shadow:var(--shadow);margin-bottom:16px;overflow:hidden}.section-header{align-items:center;border-bottom:1px solid #c0bcdf;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:12px 14px}.section-header h2{font-size:.85rem;font-weight:700}.emi-section{border-left:3px solid #f59e0b;border-left:3px solid var(--emi)}.emi-total{color:#f59e0b;color:var(--emi)}.emi-total,.expense-total{font-size:.9rem;font-weight:700}.expense-total{color:#ef4444;color:var(--expense)}.owe-section{border-left:3px solid #10b981;border-left:3px solid var(--income)}.owe-total{color:#10b981;color:var(--income);font-size:.9rem;font-weight:700}.list-item{align-items:center;border-bottom:1px solid #c0bcdf;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;min-height:56px;padding:12px 14px}.list-item:last-child{border-bottom:none}.list-item:active{background:#f1f2f4;background:var(--bg)}.list-item-info{flex:1 1;min-width:0}.list-item-info h3{font-size:.9rem;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.list-item-info p{color:#544f69;color:var(--text-muted);font-size:.75rem;margin-top:2px}.list-item-right{align-items:center;display:flex;flex-shrink:0;gap:10px}.amount{font-size:.95rem;font-weight:700}.amount.income{color:#10b981;color:var(--income)}.amount.expense{color:#ef4444;color:var(--expense)}.amount.emi{color:#f59e0b;color:var(--emi)}.delete-btn{align-items:center;background:#f1f2f4;background:var(--bg);border:none;border-radius:8px;color:#544f69;color:var(--text-muted);cursor:pointer;display:flex;font-size:1.2rem;height:32px;justify-content:center;width:32px}.delete-btn:active{color:#ef4444;color:var(--expense)}.delete-btn:active,.tag{background:#c0bcdf;background:var(--border)}.tag{border-radius:6px;color:#544f69;color:var(--text-muted);display:inline-block;font-size:.65rem;font-weight:600;padding:3px 8px}.tag.closed{background:#ef4444;background:var(--expense);color:#fff}.stats-row{grid-gap:10px;display:grid;gap:10px;grid-template-columns:1fr 1fr;margin-bottom:12px}.stat-box{background:#fff;background:var(--bg-card);border-radius:12px;box-shadow:0 4px 6px -1px #544f6914,0 2px 4px -1px #544f690a;box-shadow:var(--shadow);padding:14px;text-align:center}.stat-box .stat-label{color:#544f69;color:var(--text-muted);font-size:.65rem;font-weight:600;margin-bottom:4px;text-transform:uppercase}.stat-box .stat-value{font-size:1rem;font-weight:700}.stat-box.next-emi{border:2px solid #f59e0b;border:2px solid var(--emi)}.stat-box.next-emi .stat-value{color:#f59e0b;color:var(--emi)}.loan-card{background:#fff;background:var(--bg-card);border:1px solid #c0bcdf;border:1px solid var(--border);border-radius:16px;box-shadow:0 4px 6px -1px #00000008,0 2px 4px -1px #00000005;overflow:hidden;padding:20px;position:relative;transition:all .25s cubic-bezier(.4,0,.2,1)}.loan-card:hover{background:#94a3b803;box-shadow:0 10px 20px -3px #0000000f,0 4px 8px -2px #0000000a;transform:translateY(-2px)}[data-theme=dark] .loan-card:hover{background:#1e293b40;box-shadow:0 10px 20px -3px #00000040,0 4px 8px -2px #00000026}.loan-card.closed{border-style:dashed;box-shadow:none!important;opacity:.6;transform:none!important}.loan-card-footer{align-items:center;border-top:1px dashed #c0bcdf;border-top:1px dashed var(--border);display:flex;flex-wrap:wrap;gap:8px 12px;justify-content:space-between;margin-top:16px;padding-top:12px}.loan-badge-taken{background:#94a3b81a;border:1px solid #94a3b826;border-radius:8px;color:#544f69;color:var(--text-muted);font-weight:600}.loan-badge-paid,.loan-badge-taken{align-items:center;display:inline-flex;font-size:.75rem;padding:6px 10px}.loan-badge-paid{background:#10b9811a;border:1px solid #10b98133;border-radius:8px;color:#10b981;color:var(--income);font-weight:700}.loan-badge-due{background:#f59e0b1a;border:1px solid #f59e0b33;border-radius:8px;color:#f59e0b;color:var(--emi)}.loan-badge-due,.loan-badge-overdue{align-items:center;display:inline-flex;font-size:.75rem;font-weight:700;padding:6px 10px}.loan-badge-overdue{animation:pulse-badge 2s infinite;background:#ef44441a;border:1px solid #ef444433;border-radius:8px;color:#ef4444;color:var(--expense)}@keyframes pulse-badge{0%{box-shadow:0 0 0 0 #ef444466}70%{box-shadow:0 0 0 6px #ef444400}to{box-shadow:0 0 0 0 #ef444400}}.loan-header{align-items:flex-start;display:flex;gap:10px;justify-content:space-between;margin-bottom:10px}.loan-header h3{flex:1 1;font-size:.95rem;font-weight:700}.loan-type{color:#544f69;color:var(--text-muted);display:block;font-size:.7rem;margin-top:2px}.loan-stats{grid-gap:8px;display:grid;font-size:.8rem;gap:8px;grid-template-columns:repeat(3,1fr)}.loan-stat .label{color:#544f69;color:var(--text-muted);font-size:.65rem;font-weight:600;text-transform:uppercase}.loan-stat .value{font-weight:700;margin-top:2px}.emi-progress-container{background:#c0bcdf;background:var(--border);border-radius:4px;height:8px;margin-top:14px;overflow:hidden}.emi-progress-bar{background:linear-gradient(90deg,#8776ea,#10b981);background:linear-gradient(90deg,var(--accent) 0,var(--income) 100%);border-radius:4px;height:100%;min-width:0;transition:width .4s ease-out}.emi-progress-label{color:#544f69;color:var(--text-muted);font-size:.7rem;font-weight:500;margin-top:6px;text-align:center}.loan-card.closed .emi-progress-bar{background:#10b981;background:var(--income)}.cash-balance-card{background:#fff;background:var(--bg-card);border-radius:16px;box-shadow:0 4px 6px -1px #544f6914,0 2px 4px -1px #544f690a;box-shadow:var(--shadow);margin-bottom:12px;padding:24px;text-align:center}.cash-balance-card .label{color:#544f69;color:var(--text-muted);font-size:.8rem;font-weight:600;margin-bottom:8px}.cash-balance-card .value{font-size:2rem;font-weight:800;margin-bottom:16px}.cash-actions{display:flex;gap:10px;justify-content:center}.empty{color:#544f69;color:var(--text-muted);font-size:.9rem;padding:32px;text-align:center}.modal-overlay{align-items:flex-end;background:#0009;display:flex;inset:0;justify-content:center;padding:0;position:fixed;z-index:100}.modal{animation:slideUp .3s ease;background:#fff;background:var(--bg-card);border-radius:20px 20px 0 0;max-height:90vh;max-width:500px;overflow-y:auto;padding:20px;width:100%}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.modal h2{font-size:1.1rem;font-weight:700;margin-bottom:16px;text-align:center}.form-group{margin-bottom:14px}.form-group label{display:block;font-size:.8rem;font-weight:600;margin-bottom:6px}.form-group input,.form-group select{background:#f1f2f4;background:var(--bg);border:1px solid #c0bcdf;border:1px solid var(--border);border-radius:10px;color:#252526;color:var(--text);font-size:1rem;padding:12px 14px;width:100%}.form-group input:focus,.form-group select:focus{border-color:#8776ea;border-color:var(--accent);outline:none}.form-row{grid-gap:10px;display:grid;gap:10px;grid-template-columns:1fr 1fr}.checkbox-label{align-items:center;cursor:pointer;display:flex;font-size:.9rem;gap:10px;padding:8px 0}.checkbox-label input{accent-color:#8776ea;accent-color:var(--accent);height:20px;width:20px}.type-tabs{display:flex;gap:8px;margin-bottom:16px}.type-tab{background:#0000;border:2px solid #c0bcdf;border:2px solid var(--border);border-radius:10px;cursor:pointer;flex:1 1;font-size:.85rem;font-weight:600;padding:12px}.type-tab.income{color:#10b981;color:var(--income)}.type-tab.expense{color:#ef4444;color:var(--expense)}.type-tab.loan{color:#f59e0b;color:var(--emi)}.type-tab.income.active{background:#10b981;background:var(--income);border-color:#10b981;border-color:var(--income);color:#fff}.type-tab.expense.active{background:#ef4444;background:var(--expense);border-color:#ef4444;border-color:var(--expense);color:#fff}.type-tab.loan.active{background:#f59e0b;background:var(--emi);border-color:#f59e0b;border-color:var(--emi);color:#fff}.form-actions{display:flex;gap:10px;margin-top:20px;padding-bottom:20px}.form-actions button{flex:1 1;font-size:1rem;padding:14px}.import-zone{border:2px dashed #c0bcdf;border:2px dashed var(--border);border-radius:12px;cursor:pointer;padding:40px 20px;text-align:center}.import-zone:active{background:#f1f2f4;background:var(--bg);border-color:#8776ea;border-color:var(--accent)}.import-zone input{display:none}.import-result{margin-top:16px;padding:16px}.import-preview,.import-result{background:#f1f2f4;background:var(--bg);border-radius:10px}.import-preview{font-size:.85rem;margin:12px 0;padding:12px}.preview-row{align-items:center;border-bottom:1px solid #c0bcdf;border-bottom:1px solid var(--border);display:flex;gap:10px;padding:8px 0}.preview-row:last-child{border-bottom:none}@media (min-width:640px){.container{max-width:700px;padding:20px}.header h1{font-size:1.3rem}.summary{grid-template-columns:repeat(4,1fr)}.summary.summary-row-2{grid-template-columns:repeat(2,1fr)}.money-needed-value{font-size:2.5rem}.summary-card .value{font-size:1.25rem}.stats-row{grid-template-columns:repeat(3,1fr)}.modal-overlay{align-items:center;padding:20px}.modal{border-radius:20px;max-width:450px}.app{padding-bottom:40px}}@media (min-width:1024px){.container{max-width:800px}.loan-stats{grid-template-columns:repeat(6,1fr)}}.login-container{align-items:center;background:#f1f2f4;background:var(--bg);display:flex;justify-content:center;min-height:100vh;padding:20px}.login-card{background:#fff;background:var(--bg-card);border:1px solid #c0bcdf;border:1px solid var(--border);border-radius:20px;box-shadow:0 4px 6px -1px #544f6914,0 2px 4px -1px #544f690a;box-shadow:var(--shadow);max-width:400px;padding:32px;width:100%}.login-header{margin-bottom:24px;text-align:center}.login-header h1{color:#252526;color:var(--text);font-size:1.5rem;margin-bottom:8px}.login-header p{color:#544f69;color:var(--text-muted);font-size:.9rem}.error-message{background:#fef2f2;border-radius:8px;color:#b91c1c;font-size:.9rem;margin-bottom:16px;padding:10px;text-align:center}.full-width{width:100%}.login-footer{color:#544f69;color:var(--text-muted);font-size:.9rem;margin-top:20px;text-align:center}.btn-link{background:none;border:none;color:#8776ea;color:var(--accent);cursor:pointer;font-size:.9rem;font-weight:600;margin-left:6px;padding:0}.btn-link:hover{text-decoration:underline}.coming-soon-banner{border:2px dashed #8776ea;border:2px dashed var(--accent);border-radius:12px;margin-bottom:24px;padding:24px}.payment-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(2,1fr);margin-top:16px}.payment-btn{align-items:center;border-radius:12px;display:flex;font-size:1.1rem;font-weight:700;height:60px;justify-content:center;text-decoration:none;transition:transform .1s}.payment-btn:active{transform:scale(.98)}.theme-btn{align-items:center;background:#0000;border:1px solid #c0bcdf;border:1px solid var(--border);border-radius:50%;color:var(--text-primary);cursor:pointer;display:flex;height:36px;justify-content:center;padding:0;transition:all .2s ease;width:36px}.theme-btn:hover{background:var(--bg-secondary);border-color:#8776ea;border-color:var(--accent);color:#8776ea;color:var(--accent);transform:rotate(15deg)}.theme-btn svg{height:20px;width:20px}.transaction-item{align-items:center;border-bottom:1px solid #c0bcdf;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:14px;transition:background .2s}.transaction-item:hover{background:#f1f2f4;background:var(--bg)}.trx-left{gap:12px}.trx-left,.trx-type-icon{align-items:center;display:flex}.trx-type-icon{background:#f1f2f4;background:var(--bg);border-radius:10px;color:#544f69;color:var(--text-muted);font-size:1.1rem;font-weight:700;height:36px;justify-content:center;width:36px}.trx-type-icon[data-type=income]{background:#dcfce7;color:#166534}[data-theme=dark] .trx-type-icon[data-type=income]{background:#05966933;color:#34d399}.trx-type-icon[data-type=cash_spend],.trx-type-icon[data-type=emi_payment],.trx-type-icon[data-type=expense]{background:#fee2e2;color:#991b1b}[data-theme=dark] .trx-type-icon[data-type=cash_spend],[data-theme=dark] .trx-type-icon[data-type=emi_payment],[data-theme=dark] .trx-type-icon[data-type=expense]{background:#ef444433;color:#f87171}.trx-type-icon[data-type=cash_add]{background:#e0f2fe;color:#075985}.trx-desc{font-size:.9rem;font-weight:600}.trx-date{color:#544f69;color:var(--text-muted);font-size:.75rem}.trx-amount{font-size:.95rem;font-weight:700}.trx-amount.positive{color:#10b981;color:var(--income)}.trx-amount.negative{color:#ef4444;color:var(--expense)}.user-badge{border:1px solid #c0bcdf;border:1px solid var(--border);border-radius:20px;color:#8776ea;color:var(--accent);font-size:.75rem;font-weight:700;padding:4px 10px}.loading-overlay{align-items:center;background:#000000b3;display:flex;flex-direction:column;gap:16px;inset:0;justify-content:center;position:fixed;z-index:9999}.loading-overlay span{color:#fff;font-size:1rem;font-weight:600}.loading-spinner{animation:spin .8s linear infinite;border:4px solid #ffffff4d;border-radius:50%;border-top:4px solid var(--accent);height:48px;width:48px}.clean-table{border-collapse:collapse;font-size:.9rem;width:100%}.clean-table th{border-bottom:2px solid #c0bcdf;border-bottom:2px solid var(--border);color:#544f69;color:var(--text-muted);font-size:.75rem;font-weight:600;padding:12px;text-align:left;text-transform:uppercase}.clean-table td{border-bottom:1px solid #c0bcdf;border-bottom:1px solid var(--border);padding:12px;vertical-align:middle}.clean-table tr:last-child td{border-bottom:none}.clean-table tr:hover{background-color:#f1f2f4;background-color:var(--bg)}.badge{background-color:#8776ea;background-color:var(--accent);border-radius:4px;color:#fff;display:inline-block;font-size:.65rem;font-weight:600;margin-top:2px;opacity:.8;padding:2px 6px}.delete-btn-icon{background:#0000;border:none;border-radius:4px;color:#544f69;color:var(--text-muted);cursor:pointer;font-size:1.2rem;opacity:.4;padding:4px 8px;transition:all .2s}.delete-btn-icon:hover{background-color:#fee2e2;color:#b91c1c;opacity:1}[data-theme=dark] .delete-btn-icon:hover{background-color:#450a0a;color:#fca5a5}@media (max-width:480px){.clean-table td,.clean-table th{padding:10px 8px}.clean-table{font-size:.85rem}}.page-content{animation-duration:.4s;animation-fill-mode:forwards;animation-timing-function:cubic-bezier(.2,.8,.2,1);width:100%}@keyframes slideInRight{0%{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translateX(-20px)}to{opacity:1;transform:translateX(0)}}.slide-right{animation-name:slideInRight}.slide-left{animation-name:slideInLeft}.user-badge{background:#f1f2f4;background:var(--bg);border-radius:6px;color:#544f69;color:var(--text-muted);font-size:.8rem;font-weight:600;padding:4px 8px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.spin{animation:spin 1s linear infinite}@media (max-width:480px){.user-badge{display:none}}.split-container{background-color:#f1f2f4;background-color:var(--bg);color:#252526;color:var(--text);display:flex;font-family:Outfit,Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;height:100vh;overflow:hidden;transition:background-color .3s ease,color .3s ease;width:100vw}.console-panel.left-panel{background:#fff;background:var(--bg-card);border-right:1px solid #c0bcdf;border-right:1px solid var(--border);box-shadow:4px 0 24px #0000000d;display:flex;flex-direction:column;flex-shrink:0;height:100%;padding:24px;transition:background .3s ease,border-color .3s ease;width:280px;z-index:100}.console-panel.right-panel{background:#f1f2f4;background:var(--bg);display:flex;flex:1 1;flex-direction:column;height:100%;overflow:hidden;position:relative}.console-body{box-sizing:border-box;flex:1 1;margin:0 auto;max-width:1200px;overflow-y:auto;padding:40px;width:100%}.console-header{justify-content:space-between;margin-bottom:32px}.brand-header,.console-header{align-items:center;display:flex}.brand-header{gap:10px}.brand-name{color:#252526;color:var(--text);font-size:1.4rem;font-weight:800;letter-spacing:-.5px;margin:0}.brand-svg-logo{filter:drop-shadow(0 2px 8px rgba(59,130,246,.3))}.console-version{background:#c0bcdf;background:var(--border);border-radius:4px;font-family:monospace;font-size:.7rem;opacity:.4;padding:2px 6px}.console-user-profile{align-items:center;background:#ffffff08;border:1px solid #c0bcdf;border:1px solid var(--border);border-radius:16px;display:flex;gap:12px;margin-bottom:28px;padding:16px}[data-theme=light] .console-user-profile{background:#00000005}.profile-avatar{align-items:center;background:linear-gradient(135deg,#8776ea,#8b5cf6);background:linear-gradient(135deg,var(--accent),#8b5cf6);border-radius:12px;box-shadow:0 4px 12px #3b82f64d;color:#fff;display:flex;font-size:1.2rem;font-weight:800;height:42px;justify-content:center;width:42px}.profile-info{display:flex;flex-direction:column}.profile-name{color:#252526;color:var(--text);font-size:.95rem;font-weight:700}.profile-role{color:#544f69;color:var(--text-muted);font-size:.75rem;opacity:.8}.console-user-profile-bottom{align-items:center;background:#ffffff0a;border:1px solid #c0bcdf;border:1px solid var(--border);border-radius:12px;display:flex;gap:10px;margin-bottom:12px;padding:10px 12px;transition:all .2s ease}[data-theme=dark] .console-user-profile-bottom{background:#12131a!important;border-color:#222530!important}[data-theme=light] .console-user-profile-bottom{background:#00000003}.profile-avatar-sm{align-items:center;background:linear-gradient(135deg,#8776ea,#8b5cf6);background:linear-gradient(135deg,var(--accent),#8b5cf6);border-radius:8px;box-shadow:0 2px 8px #3b82f633;color:#fff;display:flex;font-size:.9rem;font-weight:800;height:32px;justify-content:center;width:32px}.profile-info-sm{display:flex;flex-direction:column}.profile-name-sm{color:#252526;color:var(--text);font-size:.85rem;font-weight:700;line-height:1.2}.profile-role-sm{color:#544f69;color:var(--text-muted);font-size:.7rem;opacity:.7}.console-menu-container{display:flex;flex:1 1;flex-direction:column;gap:6px;overflow-y:auto}.console-menu-item{align-items:center;background:#0000;border:none;border-radius:12px;color:#544f69;color:var(--text-muted);cursor:pointer;display:flex;font-size:.95rem;font-weight:600;justify-content:space-between;padding:12px 16px;text-align:left;transition:all .2s cubic-bezier(.4,0,.2,1)}.console-menu-item:hover{background:#ffffff0a;color:#252526;color:var(--text)}[data-theme=light] .console-menu-item:hover{background:#00000008}.console-menu-item.active{background:#8776ea;background:var(--accent);box-shadow:0 4px 14px #8776ea59;color:#fff}.console-menu-item-left{align-items:center;display:flex;gap:12px}.console-sidebar-footer{border-top:1px solid #c0bcdf;border-top:1px solid var(--border);padding-top:16px}.btn-logout-sidebar{align-items:center;background:#0000;border:1px solid #c0bcdf;border:1px solid var(--border);border-radius:12px;color:#544f69;color:var(--text-muted);cursor:pointer;display:flex;font-weight:600;justify-content:center;padding:12px;transition:all .2s;width:100%}[data-theme=dark] .btn-logout-sidebar{background:#12131a!important;border-color:#222530!important}.btn-logout-sidebar:hover{background:#ef44441a;border-color:#ef444433;color:#ef4444}.drawer-overlay,.mobile-drawer,.mobile-header{display:none}@media (max-width:900px){.console-panel.left-panel{display:none!important}.console-body{padding:20px 16px 100px}.mobile-header{align-items:center;background:#fff;background:var(--bg-card);border-bottom:1px solid #c0bcdf;border-bottom:1px solid var(--border);display:flex;height:60px;justify-content:space-between;padding:0 16px;position:-webkit-sticky;position:sticky;top:0;z-index:1000}.menu-toggle-btn{background:none;border:none;color:#252526;color:var(--text);cursor:pointer;justify-content:center;padding:6px}.menu-toggle-btn,.mobile-header-actions,.mobile-header-brand{align-items:center;display:flex}.mobile-header-actions{gap:12px}.sync-btn-mobile,.theme-btn-mobile{align-items:center;background:#0000;border:1px solid #c0bcdf;border:1px solid var(--border);border-radius:50%;color:#252526;color:var(--text);cursor:pointer;display:flex;height:32px;justify-content:center;width:32px}.drawer-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;display:block;width:100vw;z-index:10000}.drawer-overlay,.mobile-drawer{height:100vh;left:0;position:fixed;top:0}.mobile-drawer{-webkit-overflow-scrolling:touch;background:#fff;background:var(--bg-card);box-shadow:8px 0 30px #0003;box-sizing:border-box;display:flex;flex-direction:column;height:100dvh;overflow-y:auto;padding:20px;transform:translateX(-100%);transition:transform .3s cubic-bezier(.4,0,.2,1);width:290px;z-index:10001}.mobile-drawer.open{transform:translateX(0)}.drawer-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:24px}.drawer-close-btn{background:none;border:none;color:#544f69;color:var(--text-muted);cursor:pointer;font-size:1.8rem}.drawer-user-profile{align-items:center;background:#ffffff05;border:1px solid #c0bcdf;border:1px solid var(--border);border-radius:12px;display:flex;gap:12px;margin-bottom:20px;padding:12px}.drawer-tabs{display:flex;flex-direction:column;gap:8px;margin-bottom:24px}.drawer-tab{align-items:center;background:#0000;border:none;border-radius:10px;color:#544f69;color:var(--text-muted);cursor:pointer;display:flex;font-size:.95rem;font-weight:600;padding:12px 16px;text-align:left;transition:all .2s}.drawer-tab:hover{background:#ffffff08;color:#252526;color:var(--text)}.drawer-tab.active{background:#8776ea;background:var(--accent);color:#fff}}.analytics-container,.settings-container{animation:fadeIn .4s ease-out}.settings-card{background:#fff;background:var(--bg-card);border:1px solid #c0bcdf;border:1px solid var(--border);border-radius:16px;box-shadow:0 4px 20px #00000005;margin-bottom:20px;padding:24px}.card-header-icon{align-items:center;display:flex;margin-bottom:18px}.card-header-icon h3{font-size:1.15rem;font-weight:700;margin:0}.settings-form{display:flex;flex-direction:column;gap:14px}.theme-toggle-group{align-items:center;display:flex;justify-content:space-between}.theme-buttons{display:flex;gap:8px}.theme-opt-btn{align-items:center;background:#0000;border:1px solid #c0bcdf;border:1px solid var(--border);border-radius:10px;color:#544f69;color:var(--text-muted);cursor:pointer;display:flex;font-weight:600;padding:8px 16px;transition:all .2s}.theme-opt-btn:hover{background:#ffffff0a}.theme-opt-btn.active{background:#8776ea;background:var(--accent);border-color:#8776ea;border-color:var(--accent);color:#fff}.currency-select{background:#f1f2f4;background:var(--bg);border:1px solid #c0bcdf;border:1px solid var(--border);border-radius:10px;color:#252526;color:var(--text);font-weight:600;padding:12px;width:100%}.danger-zone{background:#ef444405;border-color:#ef444433}.danger-zone-desc{color:#544f69;color:var(--text-muted);font-size:.85rem;margin-bottom:16px}.save-status-text{color:#10b981;color:var(--income);font-size:.85rem;font-weight:600;margin-left:12px}.settings-version-footer{color:#544f69;color:var(--text-muted);font-size:.75rem;margin-top:40px;opacity:.5;text-align:center}.analytics-kpis-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));margin-bottom:24px}.kpi-card{background:#fff;background:var(--bg-card);border:1px solid #c0bcdf;border:1px solid var(--border);border-radius:16px;box-shadow:0 4px 16px #00000003;gap:16px;padding:20px}.kpi-card,.kpi-icon-wrapper{align-items:center;display:flex}.kpi-icon-wrapper{border-radius:12px;height:48px;justify-content:center;width:48px}.income-style{background:#10b9811a}.expense-style{background:#ef44441a}.accent-style{background:#3b82f61a}.kpi-details{display:flex;flex-direction:column}.kpi-label{color:#544f69;color:var(--text-muted);font-size:.8rem}.kpi-value{font-size:1.3rem;font-weight:800;letter-spacing:-.5px}.analytics-main-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:2fr 1fr}@media (max-width:1000px){.analytics-main-grid{grid-template-columns:1fr}}.analytics-card{background:#fff;background:var(--bg-card);border:1px solid #c0bcdf;border:1px solid var(--border);border-radius:16px;padding:24px}.card-header-with-actions{display:flex;flex-direction:column;gap:12px}.card-header-with-actions h3{margin:0}.builder-controls{grid-gap:10px;background:#00000005;border:1px solid #c0bcdf;border:1px solid var(--border);border-radius:12px;display:grid;gap:10px;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));padding:12px}[data-theme=dark] .builder-controls{background:#ffffff05}.control-item{display:flex;flex-direction:column;gap:4px}.control-item label{color:#544f69;color:var(--text-muted);font-size:.7rem;font-weight:700;letter-spacing:.5px;text-transform:uppercase}.control-item select{background:#f1f2f4;background:var(--bg);border:1px solid #c0bcdf;border:1px solid var(--border);border-radius:6px;color:#252526;color:var(--text);font-size:.8rem;font-weight:600;padding:6px 10px}.recharts-wrapper{background:#ffffff03;border:1px dashed #c0bcdf;border:1px dashed var(--border);border-radius:12px;padding:10px}.analytics-empty-state{align-items:center;color:#544f69;color:var(--text-muted);display:flex;font-size:.9rem;height:100%;justify-content:center;padding:40px;text-align:center}.fetch-error-banner,.update-warning-banner{align-items:center!important;border-radius:12px!important;box-shadow:0 4px 16px #0000000d!important;display:flex!important;font-weight:600!important;justify-content:space-between!important;margin-bottom:20px!important;padding:12px 20px!important}.update-warning-banner{background:#8776ea!important;background:var(--accent)!important;color:#fff!important}.warning-banner-text{align-items:center;display:flex}.btn-update-now{background:#fff!important;border:none!important;color:#8776ea!important;color:var(--accent)!important;font-weight:700!important}.fetch-error-banner{align-items:center!important;background:#d977061a!important;border:1px solid #d977064d!important;color:#f59e0b!important;color:var(--emi)!important;display:flex!important}.deficit-warning-inline{align-items:center;background:#ef444414;border:1px solid #ef444433;border-radius:10px;color:#ef4444;color:var(--expense);display:flex;font-size:.9rem;font-weight:600;margin-bottom:20px;padding:12px 16px}.badge-due-inline,.badge-paid-inline{border-radius:4px;font-size:.75rem;padding:2px 6px}.badge-paid-inline{background:#10b9811a}.badge-due-inline{background:#d977061a}.coming-soon-banner{align-items:center;background:#fff;background:var(--bg-card);border:1px solid #c0bcdf;border:1px solid var(--border);border-radius:16px;display:flex;flex-direction:column;justify-content:center;padding:48px 24px;text-align:center}.coming-soon-banner h3{font-size:1.3rem;font-weight:700;margin:0 0 8px}.coming-soon-banner p{color:#544f69;color:var(--text-muted);font-size:.9rem;margin:0}.splash-screen.sample-style{align-items:center;background:#5c5be5;box-sizing:border-box;color:#fff;display:flex;flex-direction:column;font-family:Outfit,Inter,sans-serif;height:100vh;justify-content:space-between;left:0;opacity:1;overflow:hidden;padding:calc(env(safe-area-inset-top) + 80px) 24px calc(env(safe-area-inset-bottom) + 24px);position:fixed;top:0;transition:opacity .4s cubic-bezier(.16,1,.3,1);width:100vw;z-index:99999}.splash-screen.fade-out{opacity:0;pointer-events:none}.splash-title-sample{animation:splash-fade-in .8s cubic-bezier(.16,1,.3,1) forwards;animation-delay:.15s;color:#fff;font-size:2.8rem;font-weight:800;letter-spacing:-1.2px;margin:0;text-shadow:0 4px 12px #00000026}.splash-content-sample{align-items:center;display:flex;flex-direction:column;gap:16px;margin:auto 0;text-align:center;transform:translateY(-40px)}.splash-subtitle-sample{animation:splash-fade-in .8s cubic-bezier(.16,1,.3,1) forwards;animation-delay:.25s;color:#ffffffe6;font-size:1.15rem;font-weight:500;letter-spacing:.2px;margin:18px 0 0}.splash-loader-wrapper-sample{align-items:center;animation:splash-fade-in .8s cubic-bezier(.16,1,.3,1) forwards;animation-delay:.4s;display:flex;flex-direction:column;gap:12px;margin-top:16px}.splash-loader-bar{background:#fff3;border-radius:4px;box-shadow:0 1px 2px #0000000d;height:4px;overflow:hidden;position:relative;width:160px}.splash-loader-progress{animation:splash-loading 4.2s cubic-bezier(.25,1,.5,1) forwards;animation-delay:.4s;background:#fff;border-radius:4px;box-shadow:0 0 8px #fffc;height:100%;left:0;position:absolute;top:0;width:0}.splash-loading-text{color:#fffc;font-size:.85rem;font-weight:600;letter-spacing:1px}.splash-footer-sample{animation:splash-fade-in .8s cubic-bezier(.16,1,.3,1) forwards;animation-delay:.6s;margin-bottom:8px}.splash-copyright-sample{color:#ffffffa6;font-size:.78rem;font-weight:600;letter-spacing:.5px;margin:0}@keyframes splash-fade-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes splash-loading{to{width:100%}}.otp-input-container{display:flex;gap:8px;justify-content:space-between;margin:16px auto;max-width:320px}.otp-digit-input{background:#f1f2f4;background:var(--bg);border:1.5px solid #c0bcdf;border:1.5px solid var(--border);border-radius:10px;box-shadow:inset 0 2px 4px #00000005;color:#252526;color:var(--text);font-size:1.25rem;font-weight:700;height:48px;outline:none;text-align:center;transition:all .15s ease-in-out;width:44px}.otp-digit-input:focus{background:#fff;background:var(--bg-card);border-color:#8776ea;border-color:var(--accent);box-shadow:0 0 0 3px #8776ea40;transform:translateY(-2px)}.otp-digit-input:disabled{cursor:not-allowed;opacity:.5}.auth-method-toggle{background:#f1f2f4;background:var(--bg);border:1px solid #c0bcdf;border:1px solid var(--border);border-radius:12px;display:flex;isolation:isolate;margin-bottom:24px;padding:4px;position:relative}.auth-method-btn{align-items:center;background:#0000;border:none;border-radius:8px;color:#544f69;color:var(--text-muted);cursor:pointer;display:flex;flex:1 1;font-size:.85rem;font-weight:600;gap:8px;justify-content:center;padding:10px 16px;position:relative;transition:color .25s cubic-bezier(.4,0,.2,1);z-index:2}.auth-method-btn.active,.auth-method-btn:hover{color:#252526;color:var(--text)}.auth-method-slider{background:#fff;background:var(--bg-card);border-radius:8px;bottom:4px;box-shadow:0 1px 3px #0000000d,0 4px 6px -1px #544f6914,0 2px 4px -1px #544f690a;box-shadow:0 1px 3px #0000000d,var(--shadow);left:4px;position:absolute;top:4px;transition:transform .3s cubic-bezier(.4,0,.2,1);width:calc(50% - 4px);z-index:1}[data-theme=dark] .auth-method-slider{border:1px solid #ffffff0d}.auth-method-slider.slide-right{transform:translateX(100%)}.btn-alternative{align-items:center;background:#fff;background:var(--bg-card);border:1px solid #c0bcdf;border:1px solid var(--border);border-radius:10px;box-shadow:0 4px 6px -1px #544f6914,0 2px 4px -1px #544f690a;box-shadow:var(--shadow);color:#252526;color:var(--text);cursor:pointer;display:flex;font-weight:600;gap:10px;justify-content:center;padding:10px 14px;transition:all .15s ease-in-out;width:100%}.btn-alternative:hover{background:#f1f2f4;background:var(--bg);border-color:#8776ea;border-color:var(--accent);transform:translateY(-1px)}.btn-alternative:active{transform:scale(.98)}