.dashboard{animation:fadeIn .4s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.dashboard-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem}.month-selector{display:flex;align-items:center;gap:.5rem}.month-input{padding:.5rem .75rem;background-color:var(--input-bg);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);font-family:inherit;font-size:.9rem;transition:border-color .2s ease;color-scheme:var(--color-scheme)}.month-input:focus{outline:none;border-color:var(--accent-color)}.clear-btn{background:transparent;border:none;color:var(--danger-color);cursor:pointer;padding:.5rem;font-size:.85rem;font-weight:600;border-radius:4px;transition:background-color .2s}.clear-btn:hover{background-color:#ef444426}.dashboard-header h1{font-size:2rem;font-weight:700;color:var(--text-primary);margin-bottom:.5rem}.subtitle{color:var(--text-secondary);font-size:1rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card{background-color:var(--panel-bg);padding:1.5rem;border-radius:var(--border-radius);border:1px solid var(--border-color);box-shadow:var(--shadow-sm);transition:transform .2s ease,box-shadow .2s ease}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.stat-card h3{color:var(--text-secondary);font-size:.9rem;font-weight:500;margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.5px}.stat-value{font-size:2rem;font-weight:700}.text-success{color:var(--success-color)}.text-danger{color:var(--danger-color)}.text-warning{color:var(--warning-color)}.charts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:1.5rem;margin-bottom:2rem}.chart-card{background-color:var(--panel-bg);padding:1.5rem;border-radius:var(--border-radius);border:1px solid var(--border-color)}.chart-card h3{font-size:1.1rem;margin-bottom:1rem;color:var(--text-primary)}.chart-container{width:100%}.ledger-page{animation:fadeIn .4s ease-out}.ledger-header{display:block;justify-content:space-between;align-items:flex-start;margin-bottom:.5rem}.ledger-header h1{font-size:2rem;margin-bottom:.5rem}.table-container{background-color:var(--panel-bg);border-radius:var(--border-radius);border:1px solid var(--border-color);overflow:hidden;box-shadow:var(--shadow-sm);width:100%;overflow-x:auto;max-height:60vh;overflow-y:auto}.ledger-table{width:100%;border-collapse:collapse;text-align:left;min-width:1000px}.ledger-table thead{position:sticky;top:0;z-index:10}.ledger-table th,.ledger-table td{padding:.25rem .5rem;border-bottom:1px solid var(--border-color);white-space:nowrap}.ledger-table th{background-color:#0003;color:var(--text-secondary);font-weight:600;font-size:.85rem;text-transform:uppercase;letter-spacing:.5px}.ledger-table thead th{background-color:var(--table-header-bg)}.accounts-list{width:100%}.accounts-list h3{margin-bottom:1rem;font-size:1.1rem}.accounts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.account-card{display:flex;align-items:center;gap:12px;background:linear-gradient(145deg,var(--panel-bg),var(--panel-bg-hover));padding:.25rem .5rem;border-radius:var(--border-radius);border:1px solid var(--border-color);transition:transform .2s ease,box-shadow .2s ease}.account-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.account-icon-wrapper{width:40px;height:40px;border-radius:5px;display:flex;align-items:center;justify-content:center;border:1px solid var(--border-color);flex-shrink:0;overflow:hidden}.account-brand-icon{max-width:99%;max-height:99%;object-fit:contain}.account-fallback-icon{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background-color:#f59e0b1a;color:var(--warning-color)}.account-info{display:flex;flex-direction:column}.account-name{font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:2px}.account-balance{font-size:1.15rem;font-weight:700;color:var(--text-primary)}.ledger-table tr:hover td{background-color:#ffffff05}.inline-add-row{background-color:#3b82f60d}.ledger-table thead .inline-add-row td{background-color:var(--table-add-row-bg);padding:.25rem!important;border-bottom:2px solid var(--border-color)}.inline-input{width:100%;padding:.6rem;background-color:var(--input-bg);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);font-family:inherit;font-size:.9rem;transition:border-color .2s ease}.inline-input:focus{outline:none;border-color:var(--accent-color)}.inline-input:disabled{opacity:.5;cursor:not-allowed}.inline-input option{background-color:var(--panel-bg);color:var(--text-primary)}.text-right{text-align:right}.btn-save-inline{width:100%;padding:.6rem;background-color:var(--accent-color);color:#fff;border:none;border-radius:6px;font-weight:600;cursor:pointer;transition:background-color .2s ease}.btn-save-inline:hover{background-color:var(--accent-hover)}.amount-col{text-align:right;width:120px}.balance-col{text-align:right;width:180px}.font-mono{font-family:monospace;font-size:1.1rem}.text-white{color:#fff}.badge{padding:.25rem .6rem;border-radius:12px;font-size:.75rem;font-weight:700;text-transform:uppercase;display:inline-block;text-align:center}.badge-income,.type-income{color:var(--success-color)}.badge-expense,.type-expense{color:var(--danger-color)}.badge-transfer,.type-transfer{color:var(--accent-color)}.badge-select{font-weight:600;border:none}.balance-text{font-family:monospace;font-size:.95rem;color:var(--text-secondary)}.multi-balance{display:flex;flex-direction:column;gap:4px}.balance-divider{border-top:1px dotted var(--border-color);padding-top:4px;color:var(--text-primary)}.error-alert{background-color:#ef44441a;color:var(--danger-color);padding:.75rem 1rem;border-radius:8px;font-size:.9rem;border:1px solid rgba(239,68,68,.2)}.action-col{width:80px;text-align:right}.action-buttons{display:flex;justify-content:flex-end;gap:8px}.icon-btn{background:transparent;border:none;color:var(--text-secondary);cursor:pointer;padding:6px;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:all .2s}.icon-btn:hover{background-color:#ffffff1a;color:var(--text-primary)}.btn-danger-text:hover{background-color:#ef444426;color:var(--danger-color)}.btn-success{color:var(--success-color)}.btn-success:hover{background-color:#10b98126}.editing-row{background-color:#ffffff08}.text-secondary{color:var(--text-secondary)}.text-center{text-align:center}.transaction-title{width:100%}.loans-page{animation:fadeIn .4s ease-out}.loans-header{margin-bottom:1.5rem}.loans-header h1{font-size:2rem;margin-bottom:.5rem}.loans-summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem;margin-bottom:1.5rem}.loans-summary-card{background:linear-gradient(145deg,var(--panel-bg),var(--panel-bg-hover));padding:1rem 1.25rem;border-radius:var(--border-radius);border:1px solid var(--border-color);display:flex;flex-direction:column;gap:4px;box-shadow:var(--shadow-sm)}.summary-title{font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.summary-value{font-size:1.35rem;font-weight:700;font-family:monospace}.loans-toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem;gap:1rem;flex-wrap:wrap}.search-wrapper{position:relative;flex:1;max-width:350px;min-width:240px}.search-wrapper .search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-secondary);pointer-events:none}.search-input{width:100%;padding:.55rem .55rem .55rem 2.4rem;background-color:var(--input-bg);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);font-size:.9rem;transition:border-color .2s,box-shadow .2s}.search-input:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 2px #3b82f626}.btn-lend-loan{padding:.55rem 1.5rem;background-color:var(--accent-color);color:#fff;border:none;border-radius:6px;font-weight:600;cursor:pointer;transition:background-color .2s,transform .1s;font-size:.9rem;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.btn-lend-loan:hover{background-color:var(--accent-hover)}.btn-lend-loan:active{transform:scale(.97)}.modal-backdrop{position:fixed;top:0;left:0;width:100%;height:100%;background:#0009;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;justify-content:center;align-items:center;z-index:1000;animation:fadeIn .25s ease-out}.modal-container{background:var(--panel-bg);border:1px solid var(--border-color);border-radius:var(--border-radius);box-shadow:var(--shadow-lg),0 20px 25px -5px #0000004d;width:95%;max-width:780px;max-height:90vh;overflow-y:auto;padding:1.75rem;position:relative;animation:scaleIn .3s cubic-bezier(.34,1.56,.64,1);color:var(--text-primary)}.modal-header{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border-color);padding-bottom:.85rem;margin-bottom:1.5rem}.modal-header h3{margin:0;font-size:1.25rem;font-weight:700;color:var(--text-primary)}.modal-close-btn{background:transparent;border:none;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;padding:6px;border-radius:50%;transition:background-color .2s,color .2s}.modal-close-btn:hover{background-color:var(--panel-bg-hover);color:var(--text-primary)}.loan-form{display:flex;flex-direction:column;gap:1.5rem}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:.85rem;font-weight:600;color:var(--text-secondary)}.form-group input[type=text],.form-group input[type=number],.form-group input[type=date],.form-group select{width:100%;padding:.6rem;background-color:var(--input-bg);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);font-family:inherit;font-size:.9rem;transition:border-color .2s ease;color-scheme:var(--color-scheme)}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--accent-color)}.input-with-icon{position:relative;width:100%}.input-with-icon .input-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--text-secondary);pointer-events:none}.input-with-icon input{padding-left:2.2rem!important}.checkbox-group{justify-content:center}.toggle-label{display:flex;align-items:center;gap:8px;cursor:pointer;-webkit-user-select:none;user-select:none;font-size:.85rem!important;font-weight:600;color:var(--text-primary)!important}.toggle-label input{width:16px;height:16px;accent-color:var(--accent-color);cursor:pointer}.calculator-live-results{background-color:var(--panel-bg-hover);padding:1.25rem;border-radius:8px;border:1px dashed var(--border-color)}.calculator-live-results h4{font-size:.9rem;color:var(--text-secondary);text-transform:uppercase;margin-bottom:.75rem;letter-spacing:.5px}.results-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.result-item{display:flex;flex-direction:column;gap:4px}.result-label{font-size:.8rem;color:var(--text-secondary)}.result-value{font-size:1.15rem;font-weight:700;font-family:monospace;color:var(--text-primary)}.result-item.highlight .result-value{font-size:1.35rem;color:var(--success-color)}.override-input{width:100%;padding:4px 8px;background-color:var(--panel-bg);border:1px solid var(--border-color);border-radius:4px;color:var(--text-primary);font-family:monospace;font-size:.95rem}.override-input:focus{outline:none;border-color:var(--accent-color)}.btn-submit-loan{padding:.75rem;background-color:var(--accent-color);color:#fff;border:none;border-radius:6px;font-weight:600;cursor:pointer;transition:background-color .2s ease,transform .1s ease;font-size:.95rem}.btn-submit-loan:hover{background-color:var(--accent-hover)}.btn-submit-loan:active{transform:scale(.99)}.badge-loan-active{background-color:#3b82f626;color:var(--accent-color)}.badge-loan-paid{background-color:#10b98126;color:var(--success-color)}.fee-breakdown-subtext{font-size:.75rem;color:var(--text-secondary)}.gst-rate-subtext,.interest-rate-subtext{font-size:.7rem;color:var(--text-secondary)}.loan-paid-row td{opacity:.5}.loan-paid-row .borrower-name-cell{text-decoration:line-through}.loan-paid-row td.action-col{opacity:1}.text-accent{color:#a855f7}.grace-settlement-subtext{font-size:.7rem;color:var(--success-color);margin-top:2px;font-weight:500}.grace-period-item{border:1px solid var(--success-color);background:#10b9810d;border-radius:6px;padding:8px 12px;margin-top:10px}.editing-row td{background-color:#3b82f608!important;padding:.35rem .25rem!important}.editing-row .inline-input{width:100%;padding:.4rem;background-color:var(--input-bg);border:1px solid var(--border-color);border-radius:4px;color:var(--text-primary);font-size:.85rem;font-family:inherit}.editing-row .inline-input:focus{outline:none;border-color:var(--accent-color)}.btn-action-repay{padding:.35rem .8rem;background-color:var(--success-color);color:#fff;border:none;border-radius:4px;font-size:.8rem;font-weight:600;cursor:pointer;transition:background-color .2s,transform .1s;box-shadow:var(--shadow-sm)}.btn-action-repay:hover{background-color:#059669}.btn-action-repay:active{transform:scale(.95)}.btn-action-reopen{padding:.35rem .8rem;background-color:#3b82f61f;color:var(--accent-color);border:1px solid rgba(59,130,246,.3);border-radius:4px;font-size:.8rem;font-weight:600;cursor:pointer;transition:background-color .2s,transform .1s,border-color .2s}.btn-action-reopen:hover{background-color:#3b82f633;border-color:var(--accent-color)}.btn-action-reopen:active{transform:scale(.95)}.schedule-summary{background-color:var(--panel-bg-hover);border:1px solid var(--border-color);border-radius:6px;padding:1rem;margin-bottom:1.25rem;display:flex;flex-direction:column;gap:8px}.schedule-summary-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem}.schedule-summary-grid div{display:flex;flex-direction:column;gap:2px}.summary-label{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase}.summary-value{font-size:.95rem;font-weight:700;font-family:monospace}.schedule-grace-note{border-top:1px solid var(--border-color);padding-top:6px;font-size:.85rem;color:var(--text-secondary)}.schedule-total-summary{margin-top:1.25rem;border-top:1px solid var(--border-color);padding-top:.85rem;display:flex;flex-direction:column;align-items:flex-end;gap:4px;font-size:.9rem;color:var(--text-secondary)}.schedule-total-summary .grand-total{font-size:1.15rem;font-weight:700;color:var(--success-color);margin-top:4px}.schedule-table{min-width:100%!important;width:100%}.schedule-table th,.schedule-table td{padding:.5rem!important;font-size:.8rem!important;white-space:nowrap}.btn-view-schedule{background:transparent;border:none;color:var(--accent-color);font-size:.75rem;font-weight:600;cursor:pointer;padding:2px 4px;border-radius:4px;transition:background-color .2s,color .2s;text-decoration:underline;margin-top:2px;display:inline-block}.btn-view-schedule:hover{background-color:#3b82f61a;color:var(--accent-hover)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}@media (max-width: 768px){.results-grid{grid-template-columns:1fr 1fr}.modal-container{padding:1.25rem}}.navbar{position:sticky;top:0;width:100%;background:var(--navbar-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border-color);z-index:1000;box-shadow:0 4px 20px #0000001a}.navbar-container{max-width:1200px;margin:0 auto;padding:.5rem;display:flex;align-items:center;justify-content:space-between;height:45px}.navbar-left{display:flex;align-items:center}.logo{display:flex;align-items:center;gap:12px;cursor:pointer;-webkit-user-select:none;user-select:none}.logo-icon{width:36px;height:36px;background:linear-gradient(135deg,var(--accent-color),#8b5cf6);border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:1.1rem;box-shadow:0 4px 10px #3b82f64d;transition:transform .2s ease}.logo:hover .logo-icon{transform:scale(1.05)}.logo h2{font-size:1.2rem;font-weight:700;color:var(--text-primary);letter-spacing:-.5px}.navbar-middle{display:flex;gap:.75rem;align-items:center}.nav-link{display:flex;align-items:center;gap:8px;padding:.5rem 1rem;background:transparent;border:none;border-radius:5px;color:var(--text-secondary);font-size:.95rem;font-weight:600;cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1);text-decoration:none}.nav-link:hover{background-color:var(--panel-bg-hover);color:var(--text-primary)}.nav-link.active{background-color:#3b82f626;color:var(--accent-color);box-shadow:inset 0 0 0 1px #3b82f633}.navbar-right{display:flex;align-items:center}.theme-btn{background:transparent;border:1px solid var(--border-color);border-radius:5px;color:var(--text-primary);cursor:pointer;display:flex;align-items:center;justify-content:center;padding:.25rem;margin-right:.5rem;transition:all .25s ease;height:28px;width:28px}.theme-btn:hover{background-color:var(--panel-bg-hover);border-color:var(--text-secondary)}.export-btn{display:flex;align-items:center;gap:8px;padding:.25rem;background-color:var(--panel-bg-hover);color:var(--text-primary);border:1px solid var(--border-color);border-radius:5px;cursor:pointer;font-size:.9rem;font-weight:600;text-decoration:none;transition:all .25s ease}.export-btn:hover{background-color:var(--accent-color);border-color:var(--accent-color);color:#fff;transform:translateY(-1px);box-shadow:0 4px 12px #3b82f640}.export-btn:active{transform:translateY(0)}.desktop-only{display:flex}.mobile-only{display:none}.menu-toggle-btn{background:none;border:none;color:var(--text-primary);cursor:pointer;display:flex;align-items:center;justify-content:center;padding:8px;border-radius:8px;transition:background-color .2s}.menu-toggle-btn:hover{background-color:var(--panel-bg-hover)}.mobile-nav-dropdown{position:absolute;top:45px;left:0;right:0;background:var(--mobile-menu-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border-color);max-height:0;overflow:hidden;transition:max-height .3s cubic-bezier(.4,0,.2,1);box-shadow:0 10px 25px #00000026}.mobile-nav-dropdown.open{max-height:250px}.mobile-nav-menu{display:flex;flex-direction:column;padding:1.25rem 1.5rem;gap:.75rem}.mobile-nav-link{display:flex;align-items:center;gap:12px;padding:.8rem 1.2rem;background:transparent;border:none;border-radius:12px;color:var(--text-secondary);font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;text-align:left}.mobile-nav-link:hover,.mobile-nav-link.active{background-color:#3b82f61a;color:var(--accent-color);padding-left:1.5rem}.mobile-nav-divider{border:none;border-top:1px solid var(--border-color);margin:.25rem 0}.mobile-export-btn{display:flex;align-items:center;justify-content:center;gap:10px;padding:.8rem;background-color:var(--panel-bg-hover);color:var(--text-primary);border:1px solid var(--border-color);border-radius:12px;cursor:pointer;font-size:1rem;font-weight:600;text-decoration:none;transition:all .2s ease}.mobile-export-btn:hover{background-color:var(--accent-color);border-color:var(--accent-color);color:#fff}@media (max-width: 768px){.desktop-only{display:none}.mobile-only{display:block}.navbar-container{padding:.75rem 1.25rem}}:root{--font-family: "Inter", system-ui, Avenir, Helvetica, Arial, sans-serif;--bg-color: #0f111a;--panel-bg: #1a1d2d;--panel-bg-hover: #222639;--text-primary: #f8fafc;--text-secondary: #94a3b8;--accent-color: #3b82f6;--accent-hover: #2563eb;--success-color: #10b981;--danger-color: #ef4444;--warning-color: #f59e0b;--border-color: #2e334d;--border-radius: 5px;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--input-bg: rgba(0, 0, 0, .2);--table-header-bg: #141724;--table-add-row-bg: #192035;--color-scheme: dark;--navbar-bg: rgba(26, 29, 45, .85);--mobile-menu-bg: rgba(26, 29, 45, .95)}[data-theme=light]{--bg-color: #f8fafc;--panel-bg: #ffffff;--panel-bg-hover: #f1f5f9;--text-primary: #0f172a;--text-secondary: #64748b;--accent-color: #2563eb;--accent-hover: #1d4ed8;--border-color: #e2e8f0;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .05), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .08), 0 4px 6px -2px rgba(0, 0, 0, .05);--input-bg: #ffffff;--table-header-bg: #f8fafc;--table-add-row-bg: #eff6ff;--color-scheme: light;--navbar-bg: rgba(255, 255, 255, .85);--mobile-menu-bg: rgba(255, 255, 255, .95)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-family);background-color:var(--bg-color);color:var(--text-primary);line-height:1.5;-webkit-font-smoothing:antialiased}#root{display:flex;flex-direction:column;min-height:100vh}.app-container{display:flex;flex-direction:column;min-height:100vh;width:100%}.main-content{flex:1;padding:.5rem;max-width:1200px;width:100%;margin:0 auto;background-color:var(--bg-color)}.main-content.full-width-content{max-width:100%;padding-left:2rem;padding-right:2rem}@media (max-width: 768px){.main-content{padding:1.5rem 1rem}}
