*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-webkit-tap-highlight-color:transparent;background:#0f1117;margin:0;overflow-x:hidden}input,select,button,textarea{font-family:inherit}.pin-overlay{z-index:9999;background:#0f1117;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.pin-card{flex-direction:column;align-items:center;gap:16px;padding:48px 40px;display:flex}.pin-lock-icon{color:#6b7280;margin-bottom:8px}.pin-card h1{color:#fff;letter-spacing:-.5px;margin:0;font-size:28px;font-weight:700}.pin-card>p{color:#6b7280;margin:0;font-size:14px}.pin-inputs{gap:12px;margin-top:12px;display:flex}.pin-digit{color:#fff;text-align:center;caret-color:#2563eb;background:#161922;border:2px solid #2a2d37;border-radius:12px;outline:none;width:52px;height:64px;font-size:24px;font-weight:700;transition:all .15s}.pin-digit:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb33}.pin-digit.filled{border-color:#3a3d47}.pin-digit.error{border-color:#f87171}.pin-digit.error:focus{border-color:#f87171;box-shadow:0 0 0 3px #f8717133}.pin-error{color:#f87171;margin:4px 0 0;font-size:13px;font-weight:500}.pin-inputs.shake{animation:.4s ease-in-out shake}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-10px)}40%{transform:translate(10px)}60%{transform:translate(-6px)}80%{transform:translate(6px)}}@media (width<=768px){.pin-card{padding:40px 28px}.pin-card h1{font-size:26px}.pin-digit{width:48px;height:60px;font-size:22px}}@media (width<=480px){.pin-card{width:100%;padding:32px 20px}.pin-card h1{font-size:24px}.pin-card>p{font-size:13px}.pin-lock-icon svg{width:40px;height:40px}.pin-inputs{gap:8px}.pin-digit{border-radius:10px;width:44px;height:56px;font-size:20px}}.export-dialog{background:#161922;border:1px solid #2a2d37;border-radius:16px;flex-direction:column;width:100%;max-width:560px;max-height:90vh;display:flex;overflow:hidden;box-shadow:0 24px 48px #0006}.export-header{border-bottom:1px solid #2a2d37;justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.export-header h2{color:#fff;margin:0;font-size:20px;font-weight:700}.export-body{flex-direction:column;gap:24px;padding:24px;display:flex;overflow-y:auto}.export-section h3{color:#9ca3af;text-transform:uppercase;letter-spacing:.5px;margin:0 0 10px;font-size:13px;font-weight:600}.export-dates{gap:16px;display:flex}.export-dates label{flex-direction:column;flex:1;gap:4px;display:flex}.export-dates label span{color:#6b7280;font-size:12px}.export-dates input{color:#e1e4e8;--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;background:#1e2130;border:1px solid #2a2d37;border-radius:8px;outline:none;padding:10px 14px;font-size:14px;transition:border-color .15s}.export-dates input:focus{border-color:#2563eb}.export-type-options{flex-direction:column;gap:8px;display:flex}.export-type-card{cursor:pointer;background:#1e2130;border:2px solid #2a2d37;border-radius:10px;align-items:flex-start;gap:12px;padding:14px 16px;transition:all .15s;display:flex}.export-type-card:hover{border-color:#3a3d47}.export-type-card.active{background:#2563eb0d;border-color:#2563eb}.export-type-card input[type=radio]{accent-color:#2563eb;flex-shrink:0;margin-top:3px}.export-type-info{flex-direction:column;gap:2px;display:flex}.export-type-info strong{color:#e1e4e8;font-size:14px}.export-type-info span{color:#6b7280;font-size:12px;line-height:1.4}.export-detail-toggle{gap:8px;display:flex}.detail-toggle-btn{color:#e1e4e8;cursor:pointer;text-align:left;background:#1e2130;border:2px solid #2a2d37;border-radius:10px;flex-direction:column;flex:1;gap:4px;padding:14px 16px;font-size:14px;font-weight:600;transition:all .15s;display:flex}.detail-toggle-btn:hover{border-color:#3a3d47}.detail-toggle-btn.active{background:#2563eb0d;border-color:#2563eb}.detail-toggle-desc{color:#6b7280;font-size:12px;font-weight:400}.export-preview{grid-template-columns:repeat(4,1fr);gap:10px;display:grid}.export-preview-stat{background:#1e2130;border-radius:8px;flex-direction:column;gap:4px;padding:12px;display:flex}.export-preview-stat .label{color:#6b7280;text-transform:uppercase;letter-spacing:.3px;font-size:11px}.export-preview-stat .value{color:#e1e4e8;font-size:16px;font-weight:700}.export-preview-stat .value.income{color:#34d399}.export-preview-stat .value.expense{color:#f87171}.export-footer{border-top:1px solid #2a2d37;justify-content:flex-end;gap:10px;padding:16px 24px;display:flex}.export-cancel-btn{color:#9ca3af;cursor:pointer;background:0 0;border:1px solid #2a2d37;border-radius:8px;padding:10px 20px;font-size:14px;transition:all .15s}.export-cancel-btn:hover{color:#e1e4e8;border-color:#6b7280}.export-btn{color:#fff;cursor:pointer;background:#2563eb;border:none;border-radius:8px;padding:10px 24px;font-size:14px;font-weight:600;transition:background .15s}.export-btn:hover{background:#1d4ed8}.export-btn:disabled{opacity:.4;cursor:not-allowed}@media (width<=768px){.export-dialog{border-radius:16px 16px 0 0;max-width:100%;max-height:95vh;margin-top:auto}.modal-overlay{align-items:flex-end;padding:0}.export-header{padding:16px 20px}.export-header h2{font-size:18px}.export-body{gap:20px;padding:20px}.export-dates{flex-direction:column;gap:10px}.export-detail-toggle{flex-direction:column}.export-preview{grid-template-columns:repeat(2,1fr);gap:8px}.export-preview-stat{padding:10px}.export-preview-stat .value{font-size:14px}.export-footer{padding:14px 20px}.export-cancel-btn,.export-btn{padding:10px 16px;font-size:13px}}@media (width<=480px){.export-body{padding:16px}.export-type-card,.detail-toggle-btn{padding:12px 14px}}.transactions-page{padding:0}.tx-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.tx-header h1{color:#fff;margin:0;font-size:26px;font-weight:700}.tx-header-actions{align-items:center;gap:12px;display:flex}.date-picker{color:#e1e4e8;cursor:pointer;--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;background:#161922;border:1px solid #2a2d37;border-radius:8px;outline:none;padding:10px 14px;font-size:14px;transition:border-color .15s}.date-picker:focus{border-color:#2563eb}.add-btn{color:#fff;cursor:pointer;background:#2563eb;border:none;border-radius:8px;padding:10px 20px;font-size:14px;font-weight:600;transition:background .15s}.add-btn:hover{background:#1d4ed8}.export-trigger-btn{color:#34d399;cursor:pointer;background:#1e2130;border:1px solid #34d3994d;border-radius:8px;padding:10px 20px;font-size:14px;font-weight:600;transition:all .15s}.export-trigger-btn:hover{background:#34d3991a}.tx-form{background:#161922;border:1px solid #2a2d37;border-radius:12px;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:24px;padding:20px;display:grid}.tx-form input,.tx-form select{color:#e1e4e8;background:#1e2130;border:1px solid #2a2d37;border-radius:8px;outline:none;padding:10px 14px;font-size:14px;transition:border-color .15s}.tx-form input:focus,.tx-form select:focus{border-color:#2563eb}.tx-form input::placeholder{color:#6b7280}.form-actions{grid-column:1/-1;justify-content:flex-end;gap:10px;display:flex}.submit-btn{color:#0f1117;cursor:pointer;background:#34d399;border:none;border-radius:8px;padding:10px 24px;font-size:14px;font-weight:600;transition:background .15s}.submit-btn:hover{background:#2abb85}.cancel-btn{color:#9ca3af;cursor:pointer;background:0 0;border:1px solid #2a2d37;border-radius:8px;padding:10px 24px;font-size:14px;transition:all .15s}.cancel-btn:hover{color:#e1e4e8;border-color:#6b7280}.tx-stats{grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:24px;display:grid}.stat-box{background:#161922;border:1px solid #2a2d37;border-radius:12px;flex-direction:column;gap:4px;padding:18px 20px;display:flex}.stat-label{color:#6b7280;text-transform:uppercase;letter-spacing:.5px;font-size:12px}.stat-value{font-size:24px;font-weight:700}.stat-value.income{color:#34d399}.stat-value.expense{color:#f87171}.tx-filters{flex-direction:column;gap:12px;margin-bottom:20px;display:flex}.search-input{color:#e1e4e8;background:#161922;border:1px solid #2a2d37;border-radius:10px;outline:none;width:100%;padding:12px 16px;font-size:14px;transition:border-color .15s}.search-input:focus{border-color:#2563eb}.search-input::placeholder{color:#6b7280}.category-filters{flex-wrap:wrap;gap:6px;display:flex}.filter-btn{color:#9ca3af;cursor:pointer;background:#161922;border:1px solid #2a2d37;border-radius:20px;padding:6px 14px;font-size:13px;transition:all .15s}.filter-btn:hover{color:#e1e4e8;border-color:#6b7280}.filter-btn.active{color:#fff;background:#2563eb;border-color:#2563eb}.tx-list{flex-direction:column;gap:4px;display:flex}.tx-row{background:#161922;border:1px solid #2a2d37;border-radius:10px;justify-content:space-between;align-items:center;padding:14px 18px;transition:background .15s;display:flex}.tx-row:hover{background:#1e2130}.tx-left{align-items:center;gap:14px;display:flex}.tx-icon-circle{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;font-size:16px;font-weight:700;display:flex}.tx-icon-circle.in{color:#34d399;background:#34d39926}.tx-icon-circle.out{color:#f87171;background:#f8717126}.tx-info{flex-direction:column;gap:2px;display:flex}.tx-desc{color:#e1e4e8;font-size:14px;font-weight:500}.tx-meta{color:#6b7280;font-size:12px}.tx-amount{font-size:15px;font-weight:700}.tx-amount.positive{color:#34d399}.tx-amount.negative{color:#f87171}.tx-empty{text-align:center;color:#6b7280;padding:40px;font-size:14px}.view-mode-selector{background:#161922;border-radius:8px;gap:4px;padding:4px;display:flex}.view-mode-btn{color:#9ca3af;cursor:pointer;background:0 0;border:none;border-radius:6px;padding:6px 14px;font-size:13px;transition:all .15s}.view-mode-btn.active{color:#fff;background:#2563eb}.view-mode-btn:hover:not(.active){color:#e1e4e8}.tx-date-range{gap:16px;margin-bottom:20px;display:flex}.tx-date-range label{align-items:center;gap:8px;display:flex}.tx-date-range label span{color:#6b7280;font-size:13px;font-weight:500}.tx-right{align-items:center;gap:8px;display:flex}.tx-action-icon{color:#6b7280;cursor:pointer;opacity:0;background:0 0;border:none;border-radius:6px;padding:4px 6px;font-size:16px;line-height:1;transition:all .15s}.tx-row:hover .tx-action-icon{opacity:1}.tx-action-icon.edit:hover{color:#60a5fa;background:#60a5fa1a}.tx-action-icon.delete{font-size:18px}.tx-action-icon.delete:hover{color:#f87171;background:#f871711a}.tx-edit-row{background:#1e2130;border:1px solid #2563eb;border-radius:10px;align-items:center;gap:10px;padding:10px 16px;display:flex}.tx-edit-row input,.tx-edit-row select{color:#e1e4e8;background:#161922;border:1px solid #2a2d37;border-radius:6px;outline:none;flex:1;padding:8px 12px;font-size:13px;transition:border-color .15s}.tx-edit-row input:focus,.tx-edit-row select:focus{border-color:#2563eb}.tx-edit-row input[type=number]{max-width:120px}.tx-edit-row input[type=date]{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;max-width:150px}.tx-edit-actions{flex-shrink:0;gap:6px;display:flex}.tx-action-btn{cursor:pointer;border:none;border-radius:6px;padding:6px 14px;font-size:12px;font-weight:600;transition:all .15s}.tx-action-btn.save{color:#0f1117;background:#34d399}.tx-action-btn.save:hover{background:#2abb85}.tx-action-btn.cancel{color:#9ca3af;background:0 0;border:1px solid #2a2d37}.tx-action-btn.cancel:hover{color:#e1e4e8;border-color:#6b7280}.tx-type-toggle{background:#161922;border:1px solid #2a2d37;border-radius:10px;grid-column:1/-1;gap:0;padding:4px;display:flex}.tx-type-btn{cursor:pointer;color:#6b7280;background:0 0;border:none;border-radius:8px;flex:1;padding:10px 16px;font-size:14px;font-weight:600;transition:all .15s}.tx-type-btn.expense.active{color:#f87171;background:#f8717126}.tx-type-btn.income.active{color:#34d399;background:#34d39926}.tx-type-btn:hover:not(.active){color:#e1e4e8}.tx-toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;margin-bottom:12px;display:flex}.tx-count{color:#6b7280;font-size:13px;font-weight:500}.tx-sort-options{align-items:center;gap:4px;display:flex}.tx-sort-label{color:#6b7280;margin-right:4px;font-size:12px}.tx-sort-btn{color:#9ca3af;cursor:pointer;white-space:nowrap;background:0 0;border:1px solid #2a2d37;border-radius:6px;padding:4px 10px;font-size:12px;transition:all .15s}.tx-sort-btn:hover{color:#e1e4e8;border-color:#6b7280}.tx-sort-btn.active{color:#60a5fa;background:#1e2130;border-color:#2563eb}.sort-arrow{font-size:11px}.tx-date-group{color:#6b7280;text-transform:uppercase;letter-spacing:.5px;padding:16px 4px 6px;font-size:12px;font-weight:600}.tx-date-group:first-child{padding-top:4px}.tx-pagination{justify-content:center;align-items:center;gap:16px;padding:20px 0 4px;display:flex}.tx-page-btn{color:#e1e4e8;cursor:pointer;background:#161922;border:1px solid #2a2d37;border-radius:8px;padding:8px 16px;font-size:13px;font-weight:500;transition:all .15s}.tx-page-btn:hover:not(:disabled){color:#60a5fa;background:#1e2130;border-color:#2563eb}.tx-page-btn:disabled{opacity:.3;cursor:not-allowed}.tx-page-info{color:#6b7280;font-size:13px;font-weight:500}.transactions-page .modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#000000b3;justify-content:center;align-items:center;padding:40px;display:flex;position:fixed;inset:0}.transactions-page .confirm-dialog{background:#161922;border:1px solid #2a2d37;border-radius:16px;width:100%;max-width:420px;padding:28px 32px;box-shadow:0 24px 48px #0006}.transactions-page .confirm-dialog h3{color:#fff;margin:0 0 12px;font-size:18px;font-weight:700}.transactions-page .confirm-dialog p{color:#e1e4e8;margin:0 0 8px;font-size:14px;line-height:1.5}.transactions-page .confirm-hint{color:#6b7280!important;font-size:13px!important}.transactions-page .confirm-actions{justify-content:flex-end;gap:10px;margin-top:20px;display:flex}.transactions-page .modal-action-btn{cursor:pointer;border:none;border-radius:8px;padding:8px 16px;font-size:13px;font-weight:600;transition:all .15s}.transactions-page .modal-action-btn.cancel{color:#9ca3af;background:0 0;border:1px solid #2a2d37}.transactions-page .modal-action-btn.cancel:hover{color:#e1e4e8;border-color:#6b7280}.transactions-page .modal-action-btn.delete{color:#f87171;background:#f871711a;border:1px solid #f8717133}.transactions-page .modal-action-btn.delete:hover{background:#f8717133}@media (width<=768px){.tx-header{flex-direction:column;align-items:flex-start;gap:12px}.tx-header h1{font-size:22px}.tx-header-actions{flex-wrap:wrap;gap:8px;width:100%}.view-mode-selector{order:-1;width:100%}.view-mode-btn{text-align:center;flex:1}.add-btn,.export-trigger-btn{text-align:center;flex:1;padding:10px 12px;font-size:13px}.tx-date-range{flex-direction:column;gap:8px}.tx-date-range label{flex-direction:row;align-items:center;gap:10px}.tx-date-range label span{min-width:40px}.date-picker{flex:1;width:100%}.tx-form{grid-template-columns:1fr;padding:16px}.tx-stats{grid-template-columns:1fr;gap:8px;margin-bottom:16px}.stat-box{flex-direction:row;justify-content:space-between;align-items:center;padding:14px 16px}.stat-value{font-size:20px}.category-filters{-webkit-overflow-scrolling:touch;flex-wrap:nowrap;padding-bottom:4px;overflow-x:auto}.filter-btn{white-space:nowrap;flex-shrink:0}.tx-row{padding:12px 14px}.tx-left{flex:1;gap:10px;min-width:0}.tx-info{min-width:0}.tx-desc{white-space:nowrap;text-overflow:ellipsis;font-size:13px;overflow:hidden}.tx-meta{font-size:11px}.tx-right{flex-shrink:0}.tx-amount{font-size:13px}.tx-action-icon{opacity:1;padding:6px 8px}.tx-toolbar{flex-direction:column;align-items:flex-start;gap:6px}.tx-sort-options{-webkit-overflow-scrolling:touch;width:100%;overflow-x:auto}.tx-pagination{gap:10px;padding:16px 0}.tx-page-btn{padding:8px 12px;font-size:12px}.transactions-page .modal-overlay{padding:16px}.transactions-page .confirm-dialog{padding:24px 20px}.tx-edit-row{flex-direction:column;gap:8px;padding:14px}.tx-edit-row input,.tx-edit-row select{width:100%;max-width:none}.tx-edit-row input[type=number],.tx-edit-row input[type=date]{max-width:none}.tx-edit-actions{justify-content:flex-end;width:100%}}@media (width<=480px){.tx-header h1{font-size:20px}.tx-icon-circle{width:32px;height:32px;font-size:14px}.tx-row{padding:10px 12px}.stat-box{border-radius:10px;padding:12px 14px}}.recycle-page{flex-direction:column;height:100%;padding:0;display:flex}.recycle-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.recycle-header h1{color:#fff;margin:0;font-size:26px;font-weight:700}.recycle-actions{gap:10px;display:flex}.recycle-btn{cursor:pointer;border:none;border-radius:8px;padding:9px 18px;font-size:14px;font-weight:600;transition:all .15s}.recycle-btn.restore-all{color:#34d399;background:#1e2130;border:1px solid #34d3994d}.recycle-btn.restore-all:hover{background:#34d3991a}.recycle-btn.empty-trash{color:#f87171;background:#f871711a;border:1px solid #f8717133}.recycle-btn.empty-trash:hover{background:#f8717133}.recycle-info{color:#6b7280;margin-bottom:20px;font-size:13px}.recycle-list{flex-direction:column;flex:1;gap:4px;display:flex;overflow-y:auto}.recycle-item{background:#161922;border:1px solid #2a2d37;border-radius:10px;align-items:center;gap:14px;padding:12px 16px;transition:background .15s;display:flex}.recycle-item:hover{background:#1e2130}.recycle-icon{opacity:.5;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:28px;display:flex}.recycle-details{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.recycle-name{color:#9ca3af;white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:500;overflow:hidden}.recycle-meta{color:#6b7280;font-size:12px}.recycle-item-actions{opacity:0;gap:8px;transition:opacity .15s;display:flex}.recycle-item:hover .recycle-item-actions{opacity:1}.recycle-action-btn{cursor:pointer;border:none;border-radius:6px;padding:6px 14px;font-size:12px;font-weight:600;transition:all .15s}.recycle-action-btn.restore{color:#34d399;background:#34d3991a}.recycle-action-btn.restore:hover{background:#34d39933}.recycle-action-btn.perm-delete{color:#f87171;background:#f871711a}.recycle-action-btn.perm-delete:hover{background:#f8717133}.recycle-empty{color:#6b7280;justify-content:center;align-items:center;padding:60px 20px;font-size:14px;display:flex}@media (width<=768px){.recycle-header{flex-direction:column;align-items:flex-start;gap:12px}.recycle-header h1{font-size:22px}.recycle-actions{width:100%}.recycle-btn{text-align:center;flex:1;padding:9px 14px;font-size:13px}.recycle-item{gap:10px;padding:10px 12px}.recycle-icon{width:34px;height:34px;font-size:24px}.recycle-name{font-size:13px}.recycle-item-actions{opacity:1;flex-direction:column;gap:4px}.recycle-action-btn{padding:6px 10px;font-size:11px}.modal-overlay{padding:16px}.confirm-dialog{padding:24px 20px}}@media (width<=480px){.recycle-header h1{font-size:20px}.recycle-item{gap:8px;padding:8px 10px}.recycle-icon{width:30px;height:30px;font-size:22px}.recycle-name{font-size:12px}.recycle-action-btn{padding:5px 8px;font-size:10px}}.files-page{flex-direction:column;height:100%;padding:0;display:flex}.files-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.files-header h1{color:#fff;margin:0;font-size:26px;font-weight:700}.files-actions{gap:10px;display:flex}.files-btn{cursor:pointer;border:none;border-radius:8px;padding:9px 18px;font-size:14px;font-weight:600;transition:all .15s}.files-btn.primary{color:#fff;background:#2563eb}.files-btn.primary:hover{background:#1d4ed8}.files-btn.secondary{color:#e1e4e8;background:#1e2130;border:1px solid #2a2d37}.files-btn.secondary:hover{border-color:#6b7280}.files-btn.trash{color:#f87171;background:#1e2130;border:1px solid #f8717133}.files-btn.trash:hover{background:#f871711a}.files-btn.cancel{color:#9ca3af;background:0 0;border:1px solid #2a2d37}.files-btn.cancel:hover{color:#e1e4e8;border-color:#6b7280}.files-breadcrumb{align-items:center;gap:0;margin-bottom:20px;font-size:14px;display:flex}.breadcrumb-item{color:#6b7280;cursor:pointer;background:0 0;border:none;border-radius:4px;padding:4px 6px;font-size:14px;transition:all .15s}.breadcrumb-item:hover{color:#e1e4e8;background:#1e2130}.breadcrumb-item.active{color:#fff;font-weight:600}.breadcrumb-sep{color:#3a3d47;margin:0 2px}.new-folder-form{align-items:center;gap:10px;margin-bottom:20px;display:flex}.new-folder-form input{color:#e1e4e8;background:#161922;border:1px solid #2a2d37;border-radius:8px;outline:none;flex:1;max-width:300px;padding:10px 14px;font-size:14px;transition:border-color .15s}.new-folder-form input:focus{border-color:#2563eb}.new-folder-form input::placeholder{color:#6b7280}.files-grid{flex-direction:column;flex:1;gap:4px;display:flex;overflow-y:auto}.file-item{cursor:pointer;background:#161922;border:1px solid #2a2d37;border-radius:10px;align-items:center;gap:14px;padding:12px 16px;transition:all .15s;display:flex;position:relative}.file-item:hover{background:#1e2130}.file-item.back{opacity:.7}.file-item.back:hover{opacity:1}.file-icon{flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:28px;display:flex}.file-details{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.file-name{color:#e1e4e8;white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:500;overflow:hidden}.file-meta{color:#6b7280;font-size:12px}.file-delete{color:#6b7280;cursor:pointer;opacity:0;background:0 0;border:none;border-radius:6px;padding:4px 8px;font-size:20px;line-height:1;transition:all .15s}.file-item:hover .file-delete{opacity:1}.file-delete:hover{color:#f87171;background:#f871711a}.files-empty{color:#6b7280;justify-content:center;align-items:center;width:100%;padding:60px 20px;font-size:14px;display:flex}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#000000b3;justify-content:center;align-items:center;padding:40px;display:flex;position:fixed;inset:0}.modal-container{background:#161922;border:1px solid #2a2d37;border-radius:16px;flex-direction:column;width:100%;max-width:720px;max-height:85vh;display:flex;overflow:hidden;box-shadow:0 24px 48px #0006}.modal-header{border-bottom:1px solid #2a2d37;justify-content:space-between;align-items:center;gap:16px;padding:20px 24px;display:flex}.modal-header h2{color:#fff;white-space:nowrap;text-overflow:ellipsis;flex:1;margin:0;font-size:18px;font-weight:600;overflow:hidden}.modal-close{color:#6b7280;cursor:pointer;background:0 0;border:none;border-radius:8px;flex-shrink:0;padding:4px 8px;font-size:26px;line-height:1;transition:all .15s}.modal-close:hover{color:#e1e4e8;background:#1e2130}.modal-rename-form{flex:1;align-items:center;gap:10px;display:flex}.modal-rename-form input{color:#e1e4e8;background:#1e2130;border:1px solid #2a2d37;border-radius:6px;outline:none;flex:1;padding:8px 12px;font-size:16px;transition:border-color .15s}.modal-rename-form input:focus{border-color:#2563eb}.modal-body{background:#0f1117;flex:1;justify-content:center;align-items:center;min-height:200px;padding:24px;display:flex;overflow:auto}.modal-preview-media{object-fit:contain;border-radius:8px;max-width:100%;max-height:50vh}.modal-preview-audio{width:100%}.modal-preview-pdf-wrapper{width:100%;height:55vh}.modal-preview-pdf{border:none;border-radius:8px;width:100%;height:100%}.modal-preview-unsupported{color:#6b7280;flex-direction:column;align-items:center;gap:12px;padding:40px;display:flex}.modal-preview-icon{font-size:56px}.modal-footer{border-top:1px solid #2a2d37;justify-content:space-between;align-items:center;gap:16px;padding:16px 24px;display:flex}.modal-info{color:#6b7280;flex-wrap:wrap;gap:16px;font-size:12px;display:flex}.modal-actions{flex-shrink:0;gap:8px;display:flex}.modal-action-btn{cursor:pointer;border:none;border-radius:8px;align-items:center;padding:8px 16px;font-size:13px;font-weight:600;text-decoration:none;transition:all .15s;display:inline-flex}.modal-action-btn.rename{color:#e1e4e8;background:#1e2130;border:1px solid #2a2d37}.modal-action-btn.rename:hover{border-color:#6b7280}.modal-action-btn.download{color:#fff;background:#2563eb}.modal-action-btn.download:hover{background:#1d4ed8}.modal-action-btn.delete{color:#f87171;background:#f871711a;border:1px solid #f8717133}.modal-action-btn.delete:hover{background:#f8717133}.modal-action-btn.save{color:#0f1117;background:#34d399}.modal-action-btn.save:hover{background:#2abb85}.modal-action-btn.cancel{color:#9ca3af;background:0 0;border:1px solid #2a2d37}.modal-action-btn.cancel:hover{color:#e1e4e8;border-color:#6b7280}.file-checkbox{accent-color:#2563eb;cursor:pointer;flex-shrink:0;width:18px;height:18px}.file-checkbox-spacer{flex-shrink:0;width:18px}.file-item.selected{background:#1e2130;border-color:#2563eb}.files-select-all{margin-bottom:10px}.checkbox-label{color:#9ca3af;cursor:pointer;align-items:center;gap:8px;padding:4px 0;font-size:13px;display:inline-flex}.checkbox-label input{accent-color:#2563eb;cursor:pointer;width:18px;height:18px}.selected-count{color:#60a5fa;align-items:center;font-size:13px;font-weight:600;display:flex}.files-btn.danger{color:#f87171;background:#f871711a;border:1px solid #f8717133}.files-btn.danger:hover{background:#f8717133}.confirm-dialog{background:#161922;border:1px solid #2a2d37;border-radius:16px;width:100%;max-width:420px;padding:28px 32px;box-shadow:0 24px 48px #0006}.confirm-dialog h3{color:#fff;margin:0 0 12px;font-size:18px;font-weight:700}.confirm-dialog p{color:#e1e4e8;margin:0 0 8px;font-size:14px;line-height:1.5}.confirm-hint{color:#6b7280!important;font-size:13px!important}.confirm-actions{justify-content:flex-end;gap:10px;margin-top:20px;display:flex}@media (width<=768px){.files-header{flex-direction:column;align-items:flex-start;gap:12px}.files-header h1{font-size:22px}.files-actions{flex-wrap:wrap;gap:8px;width:100%}.files-btn{padding:9px 14px;font-size:13px}.files-actions .files-btn.primary,.files-actions .files-btn.secondary,.files-actions .files-btn.trash,.files-actions .files-btn.danger{text-align:center;flex:1;min-width:0}.selected-count{justify-content:center;width:100%;font-size:12px}.files-breadcrumb{-webkit-overflow-scrolling:touch;flex-wrap:nowrap;margin-bottom:16px;padding-bottom:4px;overflow-x:auto}.breadcrumb-item{white-space:nowrap;flex-shrink:0}.new-folder-form{flex-direction:column}.new-folder-form input{width:100%;max-width:none}.file-item{gap:10px;padding:10px 12px}.file-icon{width:34px;height:34px;font-size:24px}.file-name{font-size:13px}.file-meta{font-size:11px}.file-delete{opacity:1;padding:6px 10px}.modal-overlay{align-items:flex-end;padding:0}.modal-container{border-radius:16px 16px 0 0;max-width:100%;max-height:95vh}.modal-header{padding:16px}.modal-header h2{font-size:16px}.modal-body{min-height:150px;padding:16px}.modal-preview-media{max-height:40vh}.modal-footer{flex-direction:column;gap:12px;padding:14px 16px}.modal-info{justify-content:center}.modal-actions{justify-content:stretch;width:100%}.modal-actions .modal-action-btn{text-align:center;flex:1;justify-content:center}.modal-rename-form{flex-direction:column;gap:8px}.modal-rename-form input{font-size:14px}.confirm-dialog{margin:16px;padding:24px 20px}.confirm-dialog h3{font-size:16px}}@media (width<=480px){.files-header h1{font-size:20px}.file-item{border-radius:8px;gap:8px;padding:10px}.file-icon{width:30px;height:30px;font-size:22px}.file-checkbox{width:16px;height:16px}}.analytics-page{padding:0}.analytics-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.analytics-header h1{color:#fff;margin:0;font-size:26px;font-weight:700}.analytics-view-toggle{background:#161922;border-radius:8px;gap:4px;padding:4px;display:flex}.view-toggle-btn{color:#9ca3af;cursor:pointer;background:0 0;border:none;border-radius:6px;padding:8px 18px;font-size:14px;font-weight:500;transition:all .15s}.view-toggle-btn.active{color:#fff;background:#2563eb}.view-toggle-btn:hover:not(.active){color:#e1e4e8}.analytics-card{background:#161922;border:1px solid #2a2d37;border-radius:12px;margin-bottom:20px;padding:24px}.analytics-card h3{color:#e1e4e8;margin:0 0 16px;font-size:16px;font-weight:600}.analytics-card-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:20px;display:flex}.analytics-card-header h3{margin:0}.card-subtitle{color:#6b7280;margin-left:8px;font-size:12px;font-weight:400}.analytics-row{grid-template-columns:1fr 1fr;gap:20px;margin-bottom:0;display:grid}.analytics-half{margin-bottom:20px}.insights-card{background:#161922;border:1px solid #2a2d37;border-radius:12px;margin-bottom:20px;padding:20px 24px}.insights-card h3{color:#e1e4e8;margin:0 0 12px;font-size:15px;font-weight:600}.insights-list{flex-direction:column;gap:8px;display:flex}.insight-item{color:#e1e4e8;border-radius:8px;align-items:flex-start;gap:10px;padding:10px 14px;font-size:13px;line-height:1.5;display:flex}.insight-item.positive{background:#34d39914;border-left:3px solid #34d399}.insight-item.warning{background:#fbbf2414;border-left:3px solid #fbbf24}.insight-item.danger{background:#f8717114;border-left:3px solid #f87171}.insight-item.info{background:#60a5fa14;border-left:3px solid #60a5fa}.insight-icon{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;margin-top:1px;font-size:11px;font-weight:700;display:flex}.insight-item.positive .insight-icon{color:#34d399;background:#34d39933}.insight-item.warning .insight-icon{color:#fbbf24;background:#fbbf2433}.insight-item.danger .insight-icon{color:#f87171;background:#f8717133}.insight-item.info .insight-icon{color:#60a5fa;background:#60a5fa33}.insight-text{flex:1}.donut-container{align-items:center;gap:16px;display:flex}.donut-legend{flex-direction:column;gap:6px;min-width:0;display:flex}.donut-legend-item{align-items:center;gap:8px;font-size:12px;display:flex}.donut-legend-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.donut-legend-name{color:#9ca3af;white-space:nowrap;text-overflow:ellipsis;flex:1;overflow:hidden}.donut-legend-pct{color:#e1e4e8;flex-shrink:0;font-weight:600}.ranking-list{flex-direction:column;gap:10px;display:flex}.ranking-item{flex-direction:column;gap:4px;display:flex}.ranking-info{align-items:center;gap:8px;font-size:13px;display:flex}.ranking-pos{color:#6b7280;flex-shrink:0;width:24px;font-weight:600}.ranking-name{color:#e1e4e8;flex:1;font-weight:500}.ranking-value{color:#f87171;flex-shrink:0;font-weight:600}.ranking-bar-track{background:#1e2130;border-radius:3px;height:6px;overflow:hidden}.ranking-bar-fill{border-radius:3px;height:100%;transition:width .5s}.compare-months{color:#6b7280;margin-left:10px;font-size:12px;font-weight:400}.compare-table-wrap{-webkit-overflow-scrolling:touch;overflow-x:auto}.compare-table{border-collapse:collapse;width:100%;min-width:400px}.compare-table th{text-align:left;text-transform:uppercase;letter-spacing:.5px;color:#6b7280;border-bottom:1px solid #2a2d37;padding:10px 12px;font-size:11px}.compare-table td{color:#e1e4e8;border-bottom:1px solid #1e2130;padding:10px 12px;font-size:13px}.compare-table tr:last-child td{border-bottom:none}.compare-cat,.compare-change{font-weight:600}.compare-change.positive{color:#34d399}.compare-change.negative{color:#f87171}.compare-pct{opacity:.8;font-size:11px}.trend-metric-toggle{background:#0f1117;border-radius:8px;gap:4px;padding:3px;display:flex}.metric-btn{color:#6b7280;cursor:pointer;background:0 0;border:none;border-radius:6px;padding:5px 12px;font-size:12px;font-weight:500;transition:all .15s}.metric-btn.active{color:#e1e4e8;background:#1e2130}.metric-btn:hover:not(.active){color:#9ca3af}.trend-summary{border-top:1px solid #2a2d37;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:20px;padding-top:20px;display:grid}.trend-stat{flex-direction:column;gap:4px;display:flex}.trend-stat-label{color:#6b7280;text-transform:uppercase;letter-spacing:.5px;font-size:11px}.trend-stat-value{color:#e1e4e8;font-size:18px;font-weight:700}.trend-stat-value.income{color:#34d399}.trend-stat-value.expense{color:#f87171}.savings-legend{color:#6b7280;justify-content:center;gap:20px;margin-top:12px;font-size:12px;display:flex}.savings-legend-item{align-items:center;gap:6px;display:flex}.savings-dot{border-radius:50%;width:8px;height:8px;display:inline-block}.top-expenses-list{flex-direction:column;gap:4px;display:flex}.top-expense-item{border-radius:8px;align-items:center;gap:12px;padding:10px 12px;transition:background .15s;display:flex}.top-expense-item:hover{background:#1e2130}.top-expense-rank{color:#6b7280;flex-shrink:0;width:28px;font-size:13px;font-weight:700}.top-expense-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.top-expense-desc{color:#e1e4e8;white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:500;overflow:hidden}.top-expense-meta{color:#6b7280;font-size:12px}.top-expense-amount{color:#f87171;flex-shrink:0;font-size:15px;font-weight:700}.cat-filter-pills{flex-wrap:wrap;gap:6px;margin-bottom:20px;display:flex}.cat-pill{color:#6b7280;cursor:pointer;background:#0f1117;border:1px solid #2a2d37;border-radius:20px;align-items:center;gap:6px;padding:5px 12px;font-size:13px;transition:all .15s;display:flex}.cat-pill:hover{border-color:#6b7280}.cat-pill.active{background:#1e2130}.cat-pill-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.cat-actions{gap:6px;display:flex}.cat-toggle-btn{color:#6b7280;cursor:pointer;background:0 0;border:1px solid #2a2d37;border-radius:6px;padding:4px 10px;font-size:12px;transition:all .15s}.cat-toggle-btn:hover{color:#e1e4e8;border-color:#6b7280}.analytics-tooltip{background:#1e2130;border:1px solid #2a2d37;border-radius:10px;padding:12px 14px;box-shadow:0 8px 24px #0000004d}.tooltip-label{color:#6b7280;margin-bottom:8px;font-size:12px;font-weight:600}.tooltip-row{align-items:center;gap:8px;padding:2px 0;font-size:13px;display:flex}.tooltip-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.tooltip-name{color:#9ca3af;text-transform:capitalize;flex:1}.tooltip-value{color:#e1e4e8;font-weight:600}.analytics-empty{text-align:center;color:#6b7280;padding:60px 20px;font-size:14px}.analytics-empty-small{text-align:center;color:#6b7280;padding:40px 20px;font-size:13px}@media (width<=768px){.analytics-header{flex-direction:column;align-items:flex-start;gap:12px}.analytics-header h1{font-size:22px}.analytics-view-toggle{align-self:stretch}.view-toggle-btn{text-align:center;flex:1}.analytics-row{grid-template-columns:1fr;gap:0}.analytics-card{margin-bottom:16px;padding:16px}.analytics-card-header{flex-direction:column;align-items:flex-start;gap:10px;margin-bottom:16px}.trend-metric-toggle{align-self:stretch}.metric-btn{text-align:center;flex:1}.trend-summary{grid-template-columns:repeat(2,1fr);gap:10px}.trend-stat-value{font-size:16px}.donut-container{flex-direction:column}.donut-legend{flex-flow:wrap;gap:8px}.cat-filter-pills{-webkit-overflow-scrolling:touch;flex-wrap:nowrap;padding-bottom:4px;overflow-x:auto}.cat-pill{white-space:nowrap;flex-shrink:0}.savings-legend{flex-direction:column;align-items:center;gap:6px}.compare-table{min-width:360px}.insights-card{padding:16px}.insight-item{font-size:12px}}@media (width<=480px){.analytics-header h1{font-size:20px}.analytics-card{border-radius:10px;padding:12px}.trend-summary{grid-template-columns:1fr 1fr}.top-expense-item{gap:8px;padding:8px}.top-expense-amount{font-size:13px}}.settings-page{padding:0}.settings-header{margin-bottom:24px}.settings-header h1{color:#fff;margin:0;font-size:26px;font-weight:700}.settings-grid{grid-template-columns:1fr 1fr;gap:24px;display:grid}.settings-category-section{background:#161922;border:1px solid #2a2d37;border-radius:12px;padding:20px}.settings-section-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.settings-section-header h3{color:#e1e4e8;margin:0;font-size:16px;font-weight:600}.settings-add-btn{color:#fff;cursor:pointer;background:#2563eb;border:none;border-radius:6px;padding:6px 14px;font-size:13px;font-weight:600;transition:background .15s}.settings-add-btn:hover{background:#1d4ed8}.settings-add-form,.settings-cat-edit{background:#1e2130;border:1px solid #2563eb;border-radius:8px;align-items:center;gap:8px;margin-bottom:12px;padding:10px 12px;display:flex}.settings-color-pick{flex-shrink:0}.color-input{cursor:pointer;background:0 0;border:none;border-radius:6px;width:32px;height:32px;padding:0}.color-input::-webkit-color-swatch-wrapper{padding:0}.color-input::-webkit-color-swatch{border:2px solid #2a2d37;border-radius:6px}.settings-text-input{color:#e1e4e8;background:#161922;border:1px solid #2a2d37;border-radius:6px;outline:none;flex:1;min-width:0;padding:8px 12px;font-size:14px;transition:border-color .15s}.settings-text-input:focus{border-color:#2563eb}.settings-text-input::placeholder{color:#6b7280}.settings-save-btn{color:#0f1117;cursor:pointer;background:#34d399;border:none;border-radius:6px;flex-shrink:0;padding:6px 14px;font-size:13px;font-weight:600;transition:background .15s}.settings-save-btn:hover{background:#2abb85}.settings-cancel-btn{color:#9ca3af;cursor:pointer;background:0 0;border:1px solid #2a2d37;border-radius:6px;flex-shrink:0;padding:6px 14px;font-size:13px;transition:all .15s}.settings-cancel-btn:hover{color:#e1e4e8;border-color:#6b7280}.settings-cat-list{flex-direction:column;gap:2px;display:flex}.settings-cat-item{border-radius:8px;align-items:center;gap:10px;padding:10px 12px;transition:background .15s;display:flex}.settings-cat-item:hover{background:#1e2130}.settings-cat-dot{border-radius:50%;flex-shrink:0;width:12px;height:12px}.settings-cat-name{color:#e1e4e8;flex:1;font-size:14px;font-weight:500}.settings-cat-actions{opacity:0;gap:4px;transition:opacity .15s;display:flex}.settings-cat-item:hover .settings-cat-actions{opacity:1}.settings-icon-btn{color:#6b7280;cursor:pointer;background:0 0;border:none;border-radius:6px;padding:4px 6px;font-size:16px;line-height:1;transition:all .15s}.settings-icon-btn.edit:hover{color:#60a5fa;background:#60a5fa1a}.settings-icon-btn.delete{font-size:20px}.settings-icon-btn.delete:hover{color:#f87171;background:#f871711a}.settings-empty{text-align:center;color:#6b7280;padding:24px;font-size:13px}.settings-page .modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#000000b3;justify-content:center;align-items:center;padding:40px;display:flex;position:fixed;inset:0}.settings-page .confirm-dialog{background:#161922;border:1px solid #2a2d37;border-radius:16px;width:100%;max-width:420px;padding:28px 32px;box-shadow:0 24px 48px #0006}.settings-page .confirm-dialog h3{color:#fff;margin:0 0 12px;font-size:18px;font-weight:700}.settings-page .confirm-dialog p{color:#e1e4e8;margin:0 0 8px;font-size:14px;line-height:1.5}.settings-page .confirm-hint{color:#6b7280!important;font-size:13px!important}.settings-page .confirm-actions{justify-content:flex-end;gap:10px;margin-top:20px;display:flex}.settings-page .modal-action-btn{cursor:pointer;border:none;border-radius:8px;padding:8px 16px;font-size:13px;font-weight:600;transition:all .15s}.settings-page .modal-action-btn.cancel{color:#9ca3af;background:0 0;border:1px solid #2a2d37}.settings-page .modal-action-btn.cancel:hover{color:#e1e4e8;border-color:#6b7280}.settings-page .modal-action-btn.delete{color:#f87171;background:#f871711a;border:1px solid #f8717133}.settings-page .modal-action-btn.delete:hover{background:#f8717133}@media (width<=768px){.settings-grid{grid-template-columns:1fr;gap:16px}.settings-header h1{font-size:22px}.settings-category-section{padding:16px}.settings-cat-actions{opacity:1}.settings-add-form,.settings-cat-edit{flex-wrap:wrap}.settings-text-input{flex:60%}}@media (width<=480px){.settings-header h1{font-size:20px}}.dashboard{color:#e1e4e8;background:#0f1117;height:100vh;font-family:Segoe UI,system-ui,-apple-system,sans-serif;display:flex}.sidebar{background:#161922;border-right:1px solid #2a2d37;flex-direction:column;width:260px;min-width:260px;padding:0;display:flex}.sidebar-header{border-bottom:1px solid #2a2d37;padding:24px 20px 16px}.sidebar-header h2{color:#fff;letter-spacing:-.3px;margin:0;font-size:20px;font-weight:700}.sidebar-header p{color:#6b7280;margin:4px 0 0;font-size:12px}.sidebar-nav{flex-direction:column;flex:1;gap:2px;padding:12px 10px;display:flex}.sidebar-nav button{color:#9ca3af;cursor:pointer;text-align:left;background:0 0;border:none;border-radius:8px;align-items:center;gap:12px;width:100%;padding:10px 14px;font-size:14px;transition:all .15s;display:flex}.sidebar-nav button:hover{color:#e1e4e8;background:#1e2130}.sidebar-nav button.active{color:#fff;background:#1e2130;font-weight:600}.sidebar-nav button .icon{text-align:center;width:24px;font-size:18px}.sidebar-summary{border-top:1px solid #2a2d37;padding:16px 20px}.summary-card{background:#1e2130;border-radius:10px;margin-bottom:8px;padding:14px 16px}.summary-card:last-child{margin-bottom:0}.summary-card .label{color:#6b7280;text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px;font-size:11px}.summary-card .value{font-size:22px;font-weight:700}.summary-card .value.income{color:#34d399}.summary-card .value.expense{color:#f87171}.summary-card .value.balance{color:#60a5fa}.main-content{flex-direction:column;flex:1;padding:28px 32px;display:flex;overflow-y:auto}.main-header{justify-content:space-between;align-items:center;margin-bottom:28px;display:flex}.main-header h1{color:#fff;margin:0;font-size:26px;font-weight:700}.period-selector{background:#161922;border-radius:8px;gap:4px;padding:4px;display:flex}.period-selector button{color:#9ca3af;cursor:pointer;background:0 0;border:none;border-radius:6px;padding:6px 14px;font-size:13px;transition:all .15s}.period-selector button.active{color:#fff;background:#2563eb}.period-selector button:hover:not(.active){color:#e1e4e8}.chart-card{background:#161922;border:1px solid #2a2d37;border-radius:12px;margin-bottom:24px;padding:24px}.chart-card h3{color:#e1e4e8;margin:0 0 20px;font-size:16px;font-weight:600}.transactions-card{background:#161922;border:1px solid #2a2d37;border-radius:12px;flex:1;padding:24px}.transactions-card h3{color:#e1e4e8;margin:0 0 16px;font-size:16px;font-weight:600}.transactions-table{border-collapse:collapse;width:100%}.transactions-table th{text-align:left;text-transform:uppercase;letter-spacing:.5px;color:#6b7280;border-bottom:1px solid #2a2d37;padding:10px 12px;font-size:11px}.transactions-table td{border-bottom:1px solid #1e2130;padding:12px;font-size:14px}.transactions-table tr:last-child td{border-bottom:none}.transactions-table .amount.positive{color:#34d399;font-weight:600}.transactions-table .amount.negative{color:#f87171;font-weight:600}.transactions-table .category-tag{color:#9ca3af;background:#1e2130;border-radius:4px;padding:2px 8px;font-size:12px;display:inline-block}.chart-empty{text-align:center;color:#6b7280;padding:40px;font-size:14px}.dash-greeting{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:24px;display:flex}.dash-greeting h1{color:#fff;margin:0;font-size:26px;font-weight:700}.dash-today-summary{color:#6b7280;margin:6px 0 0;font-size:14px}.dash-stats-row{grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:20px;display:grid}.dash-stat-card{background:#161922;border:1px solid #2a2d37;border-radius:12px;flex-direction:column;gap:4px;padding:18px 20px;display:flex}.dash-stat-label{color:#6b7280;text-transform:uppercase;letter-spacing:.5px;font-size:11px}.dash-stat-value{font-size:22px;font-weight:700}.dash-stat-value.income{color:#34d399}.dash-stat-value.expense{color:#f87171}.dash-stat-value.warning{color:#fbbf24}.dash-stat-change{font-size:12px;font-weight:500}.dash-stat-change.up{color:#34d399}.dash-stat-change.down{color:#f87171}.dash-stat-change.neutral{color:#6b7280}.dash-insights{flex-wrap:wrap;gap:10px;margin-bottom:20px;display:flex}.dash-insight{color:#e1e4e8;border-radius:8px;flex:1;align-items:center;gap:8px;min-width:200px;padding:10px 14px;font-size:13px;line-height:1.4;display:flex}.dash-insight.positive{background:#34d39914;border-left:3px solid #34d399}.dash-insight.warning{background:#fbbf2414;border-left:3px solid #fbbf24}.dash-insight.info{background:#60a5fa14;border-left:3px solid #60a5fa}.dash-insight-icon{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;font-size:10px;font-weight:700;display:flex}.dash-insight.positive .dash-insight-icon{color:#34d399;background:#34d39933}.dash-insight.warning .dash-insight-icon{color:#fbbf24;background:#fbbf2433}.dash-insight.info .dash-insight-icon{color:#60a5fa;background:#60a5fa33}.dash-row{grid-template-columns:1fr 1fr;gap:20px;margin-bottom:0;display:grid}.dash-half{margin-bottom:20px}.dash-donut-wrap{align-items:center;gap:12px;display:flex}.dash-donut-legend{flex-direction:column;gap:5px;min-width:0;display:flex}.dash-donut-item{align-items:center;gap:6px;font-size:12px;display:flex}.dash-donut-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.dash-donut-name{color:#9ca3af;white-space:nowrap;text-overflow:ellipsis;flex:1;overflow:hidden}.dash-donut-pct{color:#e1e4e8;flex-shrink:0;font-weight:600}.dash-top-list{flex-direction:column;gap:2px;display:flex}.dash-top-item{border-radius:6px;align-items:center;gap:10px;padding:8px 4px;display:flex}.dash-top-item:hover{background:#1e2130}.dash-top-rank{color:#6b7280;flex-shrink:0;width:24px;font-size:12px;font-weight:700}.dash-top-info{flex-direction:column;flex:1;gap:1px;min-width:0;display:flex}.dash-top-desc{color:#e1e4e8;white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:500;overflow:hidden}.dash-top-meta{color:#6b7280;font-size:11px}.dash-top-amount{color:#f87171;flex-shrink:0;font-size:14px;font-weight:700}.dash-recent-list{flex-direction:column;gap:2px;display:flex}.dash-recent-item{border-radius:6px;align-items:center;gap:10px;padding:7px 4px;display:flex}.dash-recent-item:hover{background:#1e2130}.dash-recent-icon{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;font-size:13px;font-weight:700;display:flex}.dash-recent-icon.in{color:#34d399;background:#34d39926}.dash-recent-icon.out{color:#f87171;background:#f8717126}.dash-recent-info{flex-direction:column;flex:1;gap:1px;min-width:0;display:flex}.dash-recent-desc{color:#e1e4e8;white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:500;overflow:hidden}.dash-recent-meta{color:#6b7280;font-size:11px}.dash-recent-amount{flex-shrink:0;font-size:13px;font-weight:600}.dash-recent-amount.positive{color:#34d399}.dash-recent-amount.negative{color:#f87171}.dash-tooltip{background:#1e2130;border:1px solid #2a2d37;border-radius:10px;padding:10px 12px;box-shadow:0 8px 24px #0000004d}.dash-tooltip-label{color:#6b7280;margin-bottom:6px;font-size:11px;font-weight:600}.dash-tooltip-row{align-items:center;gap:6px;padding:1px 0;font-size:12px;display:flex}.dash-tooltip-dot{border-radius:50%;flex-shrink:0;width:7px;height:7px}.dash-tooltip-name{color:#9ca3af;text-transform:capitalize;flex:1}.dash-tooltip-val{color:#e1e4e8;font-weight:600}.recharts-cartesian-grid line{stroke:#2a2d37}.recharts-text{fill:#6b7280;font-size:12px}.recharts-tooltip-wrapper .recharts-default-tooltip{color:#e1e4e8!important;background:#1e2130!important;border:1px solid #2a2d37!important;border-radius:8px!important}.mobile-header{z-index:100;background:#161922;border-bottom:1px solid #2a2d37;align-items:center;gap:12px;padding:14px 16px;display:none;position:sticky;top:0}.mobile-header h2{color:#fff;margin:0;font-size:18px;font-weight:700}.hamburger-btn{cursor:pointer;background:0 0;border:none;flex-direction:column;gap:5px;padding:4px;display:flex}.hamburger-btn span{background:#e1e4e8;border-radius:2px;width:22px;height:2px;transition:all .2s;display:block}.sidebar-overlay{display:none}.sidebar-close{color:#6b7280;cursor:pointer;background:0 0;border:none;padding:0;font-size:28px;line-height:1;display:none;position:absolute;top:20px;right:16px}.sidebar-close:hover{color:#e1e4e8}@media (width<=768px){.dashboard{flex-direction:column;height:auto;min-height:100vh}.mobile-header{display:flex}.sidebar-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:998;background:#0009;display:block;position:fixed;inset:0}.sidebar{z-index:999;width:280px;min-width:280px;transition:transform .3s cubic-bezier(.4,0,.2,1);position:fixed;top:0;bottom:0;left:0;overflow-y:auto;transform:translate(-100%)}.sidebar.open{transform:translate(0)}.sidebar-close{display:block}.sidebar-header{position:relative}.main-content{min-height:0;padding:20px 16px}.main-header{flex-direction:column;align-items:flex-start;gap:12px;margin-bottom:20px}.main-header h1{font-size:22px}.period-selector{align-self:stretch}.period-selector button{text-align:center;flex:1}.chart-card{margin-bottom:16px;padding:16px}.chart-card h3{margin-bottom:16px;font-size:15px}.transactions-card{padding:16px}.transactions-table th,.transactions-table td{padding:8px 6px;font-size:12px}.transactions-table .category-tag{padding:2px 6px;font-size:11px}.summary-card .value{font-size:18px}.dash-greeting{flex-direction:column;gap:12px;margin-bottom:20px}.dash-greeting h1{font-size:22px}.dash-stats-row{grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:16px}.dash-stat-value{font-size:18px}.dash-stat-card{padding:14px 16px}.dash-insights{flex-direction:column;gap:6px}.dash-insight{min-width:0}.dash-row{grid-template-columns:1fr;gap:0}.dash-donut-wrap{flex-direction:column}.dash-donut-legend{flex-flow:wrap;gap:8px}}@media (width<=480px){.main-content{padding:16px 12px}.main-header h1{font-size:20px}.chart-card,.transactions-card{border-radius:10px;padding:12px}.transactions-table th:nth-child(3),.transactions-table td:nth-child(3){display:none}.dash-greeting h1{font-size:20px}.dash-stats-row{grid-template-columns:1fr 1fr;gap:8px}.dash-stat-value{font-size:16px}.dash-stat-change{font-size:11px}}
