.grid-container{width:100%;overflow:hidden;border-radius:8px;box-shadow:0 2px 8px #00000014;background:#fff}.grid-scroll{overflow-x:auto;max-height:calc(100vh - 120px)}.grid-table{border-collapse:collapse;font-size:13px;min-width:100%}.grid-table th,.grid-table td{padding:6px 10px;border-right:1px solid #e0e0e0;border-bottom:1px solid #e0e0e0;white-space:nowrap;text-align:right;min-width:100px;transition:min-width .25s ease,width .25s ease}.grid-table th{background:#1b2a4a;color:#fff;font-weight:600;position:sticky;top:0;z-index:2}.header-category{text-align:left!important;min-width:200px!important;position:sticky;left:0;z-index:3}.header-week{text-align:center!important;min-width:85px!important}.week-label{font-size:12px;font-weight:700}.week-date{font-size:10px;opacity:.7;margin-top:2px}.header-total{min-width:110px!important;background:#2e3a52!important}.cell-category{text-align:left!important;position:sticky;left:0;background:inherit;z-index:1;display:flex;flex-direction:column}.cat-name{font-size:13px}.cell-value{font-variant-numeric:tabular-nums;color:#333}.cell-value.clickable{cursor:pointer;transition:background .15s}.cell-value.clickable:hover{background:#d0d8f0}.cell-value.editable{border:1px dashed transparent}.cell-value.editable:hover{border-color:#1b2a4a;background:#fff9e6}.cell-value.cell-editing{padding:0;min-width:110px}.inline-edit-input{width:100%;min-width:110px;padding:5px 8px;border:2px solid #1B2A4A;border-radius:0;font-size:13px;font-variant-numeric:tabular-nums;text-align:right;background:#fff;outline:none;box-sizing:border-box;animation:edit-input-in .2s ease-out}@keyframes edit-input-in{0%{opacity:.6;transform:scale(.97)}to{opacity:1;transform:scale(1)}}.cell-value{transition:background .15s,color .15s}.cell-value.editable-edited{animation:cell-value-pop .3s ease-out}@keyframes cell-value-pop{0%{transform:scale(1.08);background:#c8e6c9}to{transform:scale(1);background:inherit}}.cell-total{font-variant-numeric:tabular-nums;background:#f5f5f5}.section-header-row td{padding:10px 12px;font-size:14px;font-weight:800;background:#fff;border-bottom:2px solid #1B2A4A;text-align:left}.section-total-row td{background:#f0f0f0;border-top:2px solid #999;font-size:13px}.grid-table td:first-child,.grid-table th:first-child{position:sticky;left:0;z-index:1}.category-manager{max-width:800px;margin:0 auto}.category-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.category-reorder-banner{background:#fff3cd;color:#856404;padding:8px 16px;border-radius:6px;margin-bottom:12px;font-size:13px;font-weight:600}.category-form{background:#fff;padding:20px;border-radius:8px;margin-bottom:20px;box-shadow:0 2px 8px #00000014}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px}.form-group input,.form-group select{padding:8px 12px;border:1px solid #ccc;border-radius:6px;font-size:14px}.form-actions{display:flex;gap:8px}.category-type-header{font-size:16px;margin:20px 0 8px;padding-bottom:8px;border-bottom:2px solid #1B2A4A;display:flex;align-items:baseline;gap:8px}.drag-hint{font-size:11px;font-weight:400;color:#999;font-style:italic}.category-table{width:100%;border-collapse:collapse;margin-bottom:12px}.category-table th{text-align:left;font-size:11px;text-transform:uppercase;color:#888;padding:6px 12px;border-bottom:1px solid #eee}.category-table td{padding:8px 12px;border-bottom:1px solid #f0f0f0;font-size:14px}.category-row{cursor:grab;-webkit-user-select:none;user-select:none;transition:background .15s,opacity .15s}.category-row:hover{background:#f5f7ff}.category-row.dragging{opacity:.4;background:#e8f0fe}.category-row.drag-over{background:#d0e8ff;border-top:2px solid #1B2A4A}.drag-handle-cell{width:30px;padding:4px!important;text-align:center!important}.drag-handle{display:inline-block;cursor:grab;color:#aaa;font-size:16px;line-height:1;-webkit-user-select:none;user-select:none;padding:2px 4px;border-radius:3px}.drag-handle:hover{color:#1b2a4a;background:#e8e8e8}.drag-col{width:30px}.actions-cell{display:flex;gap:4px;justify-content:flex-end}.btn-secondary{padding:8px 16px;background:#eee;color:#333;border:1px solid #ccc;border-radius:6px;font-size:14px;cursor:pointer}.btn-sm{padding:4px 8px;background:transparent;border:1px solid #ccc;border-radius:4px;cursor:pointer;font-size:14px}.btn-sm:hover{background:#eee}.btn-danger{color:#c62828}.btn-danger.confirming{background:#ffebee;border-color:#c62828}.text-muted{color:#888;font-size:13px}.history-container{max-width:900px;margin:0 auto}.history-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.history-filters{display:flex;gap:12px;margin-bottom:12px;flex-wrap:wrap;align-items:flex-end}.filter-group{display:flex;flex-direction:column;gap:4px}.filter-group label{font-size:11px;font-weight:600;color:#666;text-transform:uppercase}.filter-group select{padding:6px 10px;border:1px solid #ccc;border-radius:4px;font-size:13px}.history-total{padding:8px 12px;background:#f5f5f5;border-radius:6px;margin-bottom:12px;font-size:14px}.history-table{width:100%;border-collapse:collapse;background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 1px 4px #0000000f}.history-table th{text-align:left;padding:10px 12px;background:#1b2a4a;color:#fff;font-size:12px;text-transform:uppercase}.history-table td{padding:10px 12px;border-bottom:1px solid #f0f0f0;font-size:14px}.history-table tr:hover{background:#f9f9f9}.type-badge{display:inline-block;width:22px;height:22px;line-height:22px;text-align:center;border-radius:50%;font-size:12px;font-weight:700}.type-income{background:#e8f5e9;color:#2e7d32}.type-expense{background:#ffebee;color:#c62828}.type-investment{background:#e3f2fd;color:#1565c0}.text-success{color:#2e7d32;font-weight:600;font-variant-numeric:tabular-nums}.text-danger{color:#c62828;font-weight:600;font-variant-numeric:tabular-nums}.text-muted{color:#888;text-align:center}.btn-primary{padding:8px 16px;border:none;border-radius:6px;background:#1b2a4a;color:#fff;font-size:14px;font-weight:600;cursor:pointer}.btn-primary:hover{background:#2a3f6e}.btn-secondary{padding:6px 12px;border:1px solid #ccc;border-radius:4px;background:#fff;cursor:pointer;font-size:12px}.btn-secondary:hover{background:#eee}.add-transaction{background:#fff;padding:20px;border-radius:8px;margin-bottom:24px;box-shadow:0 1px 4px #0000000f}.add-form{margin-top:12px}.form-row{display:flex;gap:12px;margin-bottom:16px;flex-wrap:wrap}.form-group{display:flex;flex-direction:column;gap:4px}.form-group label{font-size:11px;font-weight:600;color:#666;text-transform:uppercase}.form-group select,.form-group input{padding:8px 10px;border:1px solid #ccc;border-radius:4px;font-size:14px}.readonly-input{background:#f5f5f5!important;cursor:default!important}.category-picker{position:relative;min-width:240px}.category-picker-btn{display:flex;align-items:center;justify-content:space-between;width:100%;padding:8px 10px;border:1px solid #ccc;border-radius:4px;background:#fff;font-size:14px;cursor:pointer;text-align:left}.category-picker-btn:hover{border-color:#999}.category-picker-value{color:#1b2a4a;font-weight:500;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.category-picker-placeholder{color:#aaa;flex:1}.category-picker-chevron{font-size:14px;color:#aaa;transition:transform .2s;margin-left:8px;flex-shrink:0}.category-picker-chevron.open{transform:rotate(180deg)}.category-picker-dropdown{position:absolute;top:100%;left:0;right:0;z-index:100;margin-top:4px;background:#fff;border:1px solid #ccc;border-radius:6px;box-shadow:0 4px 16px #0000001f;max-height:360px;display:flex;flex-direction:column}.category-picker-search{padding:10px 12px;border:none;border-bottom:1px solid #e0e0e0;font-size:14px;outline:none;border-radius:6px 6px 0 0}.category-picker-search::placeholder{color:#bbb}.category-picker-list{overflow-y:auto;flex:1}.category-picker-group{padding:4px 0}.category-picker-group-label{padding:6px 12px;font-size:11px;font-weight:700;color:#888;text-transform:uppercase;background:#f9f9f9;border-top:1px solid #eee;border-bottom:1px solid #eee}.category-picker-group:first-child .category-picker-group-label{border-top:none}.category-picker-option{display:flex;align-items:center;justify-content:space-between;width:100%;padding:8px 12px;border:none;background:transparent;font-size:14px;cursor:pointer;text-align:left}.category-picker-option:hover{background:#f0f4ff}.category-picker-option.selected{background:#e8f0fe}.category-picker-option-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.category-picker-check{color:#2e7d32;font-weight:700;font-size:16px;flex-shrink:0;margin-left:8px}.category-picker-empty{padding:20px;text-align:center;color:#888;font-size:14px}.investment-hint{background:#fff3cd;border:1px solid #ffc107;border-radius:4px;padding:8px 12px;margin-bottom:12px;font-size:13px;color:#856404}.note-cell{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#888;font-size:13px;font-style:italic}.form-group-note{flex:1;min-width:160px}.filter-group-search{position:relative;min-width:200px}.search-input{padding:6px 28px 6px 10px;border:1px solid #ccc;border-radius:4px;font-size:13px}.search-input:focus{outline:none;border-color:#1b2a4a;box-shadow:0 0 0 2px #1b2a4a1a}.search-clear{position:absolute;right:4px;top:22px;background:none;border:none;font-size:12px;color:#999;cursor:pointer;padding:2px 4px;line-height:1}.search-clear:hover{color:#333}.scroll-sentinel{text-align:center;padding:16px;color:#888;font-size:13px}.history-count{margin-left:8px;font-size:12px;color:#888;font-weight:400}.settings-container{max-width:500px;margin:0 auto}.settings-form{background:#fff;padding:24px;border-radius:8px;box-shadow:0 2px 8px #00000014;margin-bottom:24px}.form-group{display:flex;flex-direction:column;gap:4px;margin-bottom:16px}.form-group label{font-size:12px;font-weight:600;color:#666;text-transform:uppercase}.form-group input{padding:8px 12px;border:1px solid #ccc;border-radius:6px;font-size:14px}.settings-actions{display:flex;gap:8px;margin-top:20px}.btn-primary{padding:8px 16px;background:#1b2a4a;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer}.btn-primary:hover{background:#2e3a52}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{padding:8px 16px;background:#eee;color:#333;border:1px solid #ccc;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer}.btn-secondary:hover{background:#ddd}.btn-secondary:disabled{opacity:.6;cursor:not-allowed}.settings-info{background:#f9f9f9;padding:20px;border-radius:8px;font-size:13px;color:#666}.settings-info h3{font-size:14px;margin-bottom:8px;color:#333}.test-result{padding:12px 16px;border-radius:6px;margin-bottom:20px;font-size:14px;font-weight:600}.test-result.success{background:#e8f5e9;color:#2e7d32}.test-result.error{background:#ffebee;color:#c62828}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,sans-serif;background:#f5f7fa;color:#1b2a4a}.app{padding:16px 24px}.app-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.app-title{font-size:24px;font-weight:800}.app-controls{display:flex;gap:8px;align-items:center}.year-select{padding:6px 12px;border:1px solid #ccc;border-radius:6px;font-size:14px}.btn-refresh{padding:6px 12px;border:1px solid #ccc;border-radius:6px;background:#fff;cursor:pointer;font-size:16px}.btn-refresh:hover{background:#eee}.loading{padding:40px;text-align:center;font-size:18px;color:#888}.loading-bar{position:fixed;top:0;left:50%;transform:translate(-50%);padding:4px 20px;background:#1b2a4a;color:#fff;font-size:12px;font-weight:600;text-align:center;border-radius:0 0 8px 8px;z-index:9999;opacity:.95;pointer-events:none}.error{padding:16px;background:#ffebee;color:#c62828;border-radius:8px;margin:16px 0}.week-navigator{display:flex;align-items:center;gap:8px;margin-bottom:16px;flex-wrap:wrap}.week-nav-label{font-weight:600;font-size:14px}.week-nav-buttons{display:flex;gap:4px;flex-wrap:wrap}.week-nav-btn{padding:4px 10px;border:1px solid #ccc;border-radius:4px;background:#fff;cursor:pointer;font-size:12px;font-weight:600;font-variant-numeric:tabular-nums}.week-nav-btn.active{background:#1b2a4a;color:#fff;border-color:#1b2a4a}.week-nav-btn:hover:not(.active){background:#eee}.view-nav{display:flex;gap:4px;border:1px solid #ccc;border-radius:6px;overflow:hidden}.view-btn{padding:6px 14px;border:none;background:#fff;cursor:pointer;font-size:13px;font-weight:600}.view-btn.active{background:#1b2a4a;color:#fff}.view-btn:hover:not(.active){background:#eee}
