:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh;background-color:#fff}*{box-sizing:border-box}.container{padding:10px 15px;max-width:1400px;margin:0 auto}.header-bar{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:15px;border-bottom:2px solid #eee}.header-bar h1{margin:0}.user-info{display:flex;align-items:center;gap:15px}.user-email{font-size:14px;color:#666}.migration-btn{background-color:#2196f3;color:#fff;border:none;padding:8px 12px;border-radius:4px;cursor:pointer;font-size:18px;font-weight:600;transition:background-color .3s;margin-right:10px}.migration-btn:hover{background-color:#0b7dda}.logout-btn{background-color:#f44336;color:#fff;border:none;padding:8px 16px;border-radius:4px;cursor:pointer;font-size:14px;font-weight:600;transition:background-color .3s}.logout-btn:hover{background-color:#d32f2f}.header-summary{background-color:#fff;padding:15px;border-radius:8px;margin-bottom:20px;border:1px solid #ddd;box-shadow:0 4px 6px #0000000d}.month-selector-row{margin-bottom:15px;font-weight:700;display:flex;align-items:center;gap:10px}.month-nav-btn{background-color:#2196f3;color:#fff;border:none;padding:6px 12px;border-radius:4px;cursor:pointer;font-size:16px;font-weight:700}.month-nav-btn:hover{background-color:#1976d2}.calc-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:15px}.calc-group{background:#f9fafb;padding:15px;border-radius:8px;border:1px solid #eee;display:flex;flex-direction:column;gap:10px}.calc-group h3{margin:0 0 10px;font-size:14px;color:#555;border-bottom:1px solid #ddd;padding-bottom:5px}.input-row{display:flex;justify-content:space-between;align-items:center;font-size:14px}.input-row input{width:80px;text-align:right;padding:4px;font-size:14px}.calc-row{display:flex;justify-content:space-between;font-size:14px}.calc-row.minus{color:#d32f2f}.sub-total{text-align:right;font-weight:700;border-top:1px dashed #ccc;padding-top:5px}.calc-result{display:flex;justify-content:space-between;font-weight:700;font-size:1.1rem;border-top:2px solid #ddd;padding-top:5px;margin-top:auto}.final-result{display:flex;justify-content:space-between;font-weight:700;font-size:1.1rem;background-color:#fff3e0;padding:5px;border-radius:4px;color:#e65100;margin-top:auto}.red{color:#d32f2f}.blue{color:#1976d2}@media(max-width:768px){.calc-grid{grid-template-columns:1fr}}.divider{border:0;border-top:2px dashed #ddd;margin:30px 0}.fixed-items-section{background-color:#fff8e1;padding:20px;border-radius:8px;border:1px solid #ffe082;margin-bottom:20px}.fixed-items-section h2{font-size:1.2rem;color:#f57f17;margin-top:0}.fixed-table th{background-color:#fff3e0}.paid-row{background-color:#eee!important;color:#999}.paid-row .col-amount{color:#999;text-decoration:line-through}.type-badge{font-size:10px;background:#eee;padding:2px 4px;border-radius:3px;margin-left:5px;color:#555}.pay-btn{background-color:#ff9800;padding:4px 10px;font-size:12px}.pay-btn:hover{background-color:#f57c00}.paid-mark{font-size:12px;font-weight:700;color:#4caf50}.delete-mini{background:none;border:none;color:#ccc;font-size:10px;margin-left:5px;padding:0;cursor:pointer}.delete-mini:hover{color:red;text-decoration:underline;background:none}.add-fixed-form{display:flex;gap:10px;margin-top:15px;background:#fff;padding:10px;border-radius:5px;border:1px solid #eee}.add-fixed-form input,.add-fixed-form select{padding:8px;border:1px solid #ccc;border-radius:4px}@media(max-width:700px){.add-fixed-form{flex-direction:column}}.col-input-cell{width:140px;text-align:right}.pay-input-wrapper{display:flex;align-items:center;justify-content:flex-end;background:#fff;border:1px solid #ccc;border-radius:4px;padding:0 5px}.pay-input-mini{width:80px;border:none;text-align:right;font-size:14px;padding:6px;outline:none}.paid-amount-text{font-weight:700;color:#4caf50}.cancel-btn{background-color:#90a4ae;padding:4px 10px;font-size:12px}.cancel-btn:hover{background-color:#607d8b}.paid-row{background-color:#f1f8e9!important}.main-content-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;align-items:start}.left-column,.right-column{min-width:0;display:flex;flex-direction:column;align-items:center;width:100%}.expense-section{background-color:#e8f5e9;padding:20px;border-radius:8px;border:1px solid #a5d6a7;width:100%;max-width:550px}.expense-section h3{font-size:1.2rem;color:#2e7d32;margin-top:0;margin-bottom:15px}.left-column .table-container,.left-column .input-area{width:100%}.right-column .fixed-items-section{width:100%;max-width:650px}.divider{display:none}.add-fixed-form{display:flex;flex-wrap:wrap;gap:8px;margin-top:15px;background:#fff;padding:10px;border-radius:5px;border:1px solid #eee}.add-fixed-form input,.add-fixed-form select{padding:8px;border:1px solid #ccc;border-radius:4px;font-size:14px;flex:1;min-width:80px}.add-fixed-form input:first-child{flex:2;min-width:120px}.add-fixed-form button{white-space:nowrap;flex:0 0 auto;padding:8px 15px}@media(max-width:900px){.main-content-grid{grid-template-columns:1fr;gap:20px}.fixed-items-section{margin-bottom:20px!important}.left-column>.table-container{margin-bottom:20px!important}}.editable-label{border:1px solid transparent;background:transparent;font-size:14px;color:#555;width:auto;flex:1;min-width:0;padding:2px 0;text-align:left!important}.editable-label:focus{border-bottom:1px solid #2196F3;outline:none}.income-group .input-row input[type=number]{width:80px;text-align:right;flex:0 0 auto}.portrait-mode .main-content-grid,.portrait-mode .calc-grid{grid-template-columns:1fr!important}.portrait-mode .expense-section,.portrait-mode .fixed-items-section{max-width:100%!important}.landscape-mode .main-content-grid{grid-template-columns:1fr 1fr!important}.landscape-mode .calc-grid{grid-template-columns:1fr 1fr 1fr!important}@media(max-width:768px){.portrait-mode .main-content-grid,.landscape-mode .main-content-grid{grid-template-columns:1fr!important}}.input-area{display:flex;flex-wrap:wrap;gap:8px;margin-top:15px;background:#fff;padding:10px;border-radius:5px;border:1px solid #eee}.input-area .input-date{flex:0 0 130px!important;width:130px!important;min-width:100px;padding:8px;border:1px solid #ccc;border-radius:4px;font-size:14px}.input-area .input-text{flex:1!important;width:auto!important;min-width:120px;padding:8px;border:1px solid #ccc;border-radius:4px;font-size:14px}.input-area .input-amount{flex:0 0 90px!important;width:90px!important;min-width:80px;padding:8px;border:1px solid #ccc;border-radius:4px;font-size:14px;text-align:right}.input-area button{flex:0 0 auto;white-space:nowrap;padding:8px 15px}.table-container table{border-collapse:collapse;width:100%}.table-container table th,.table-container table td{border:1px solid #ddd;padding:8px}.col-amount{text-align:right}.table-container table th{background-color:#f5f5f5;font-weight:700}.table-container table tbody tr:nth-child(odd){background-color:#fff}.table-container table tbody tr:nth-child(2n){background-color:#ffe4e8}.table-container table td:last-child{white-space:nowrap}.table-container table td button{display:inline-block;vertical-align:middle}.edit-btn{background-color:#2196f3;color:#fff;border:none;width:24px;height:24px;padding:0;border-radius:4px;cursor:pointer;font-size:11px;margin-right:4px;display:inline-flex;align-items:center;justify-content:center}.edit-btn:hover{background-color:#1976d2}.save-btn{background-color:#4caf50;color:#fff;border:none;padding:4px 8px;border-radius:4px;cursor:pointer;font-size:11px;margin-right:4px}.save-btn:hover{background-color:#45a049}.cancel-edit-btn{background-color:#f44336;color:#fff;border:none;padding:4px 8px;border-radius:4px;cursor:pointer;font-size:11px}.cancel-edit-btn:hover{background-color:#da190b}.edit-input-date,.edit-input-text{width:100%;padding:4px;border:1px solid #2196F3;border-radius:3px;font-size:12px}.edit-input-amount{width:100%;padding:4px;border:1px solid #2196F3;border-radius:3px;font-size:12px;text-align:right}.move-btn{background-color:#9c27b0;color:#fff;border:none;width:24px;height:24px;padding:0;border-radius:4px;cursor:pointer;font-size:11px;margin-right:4px;display:inline-flex;align-items:center;justify-content:center}.move-btn:hover{background-color:#7b1fa2}.copy-btn{background-color:#4caf50;color:#fff;border:none;width:24px;height:24px;padding:0;border-radius:4px;cursor:pointer;font-size:11px;margin-right:4px;display:inline-flex;align-items:center;justify-content:center}.copy-btn:hover{background-color:#45a049}.delete-btn{background:linear-gradient(135deg,#ff6b6b,#ee5a6f);color:#fff;border:none;width:24px;height:24px;padding:0;border-radius:4px;cursor:pointer;font-size:14px;margin-right:4px;box-shadow:0 2px 4px #ff6b6b4d;transition:all .2s ease;display:inline-flex;align-items:center;justify-content:center}.delete-btn:hover{background:linear-gradient(135deg,#ee5a6f,#c92a2a);transform:scale(1.05);box-shadow:0 3px 6px #ff6b6b66}.delete-btn:active{transform:scale(.95)}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content{background:#fff;padding:25px;border-radius:8px;box-shadow:0 4px 20px #0000004d;min-width:350px;max-width:500px}.modal-content h3{margin-top:0;margin-bottom:20px;color:#333}.primary-btn{background-color:#2196f3;color:#fff;border:none;padding:8px 20px;border-radius:4px;cursor:pointer;font-size:14px}.primary-btn:hover{background-color:#1976d2}.add-fixed-btn{background:linear-gradient(135deg,#11998e,#38ef7d);color:#fff;border:none;padding:10px 20px;border-radius:6px;cursor:pointer;font-size:14px;font-weight:700;box-shadow:0 2px 4px #0003;transition:all .3s ease}.add-fixed-btn:hover{background:linear-gradient(135deg,#38ef7d,#11998e);transform:translateY(-2px);box-shadow:0 4px 8px #0000004d}.add-fixed-btn:active{transform:translateY(0);box-shadow:0 2px 4px #0003}.record-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:10px 20px;border-radius:6px;cursor:pointer;font-size:14px;font-weight:700;box-shadow:0 2px 4px #0003;transition:all .3s ease}.record-btn:hover{background:linear-gradient(135deg,#764ba2,#667eea);transform:translateY(-2px);box-shadow:0 4px 8px #0000004d}.record-btn:active{transform:translateY(0);box-shadow:0 2px 4px #0003}.success-notification{position:fixed;top:20px;right:20px;background-color:#4caf50;color:#fff;padding:15px 25px;border-radius:8px;box-shadow:0 4px 12px #0000004d;z-index:2000;animation:slideIn .3s ease-out;font-size:16px;font-weight:700}@keyframes slideIn{0%{transform:translate(400px);opacity:0}to{transform:translate(0);opacity:1}}.table-container table tbody tr:has(input.edit-input-date){background-color:#e3f2fd!important;box-shadow:0 2px 8px #2196f34d}@media(max-width:768px){.table-container table td button{padding:8px 12px;font-size:14px;min-width:40px;min-height:40px}.edit-btn,.move-btn,.copy-btn,.delete-btn{margin:2px}.modal-content{min-width:90%;max-width:90%;padding:20px}.success-notification{top:10px;right:10px;left:10px;text-align:center}}.login-container{min-height:100vh;display:flex;justify-content:center;align-items:center;background:linear-gradient(135deg,#667eea,#764ba2)}.login-box{background:#fff;padding:40px;border-radius:12px;box-shadow:0 10px 40px #0003;width:100%;max-width:400px;margin:20px}.login-box h1{text-align:center;margin:0 0 10px;font-size:2rem;color:#333}.login-box h2{text-align:center;margin:0 0 30px;font-size:1.5rem;color:#666}.input-group{margin-bottom:20px}.input-group label{display:block;margin-bottom:8px;font-weight:600;color:#333;font-size:14px}.input-group input{width:100%;padding:12px;border:2px solid #e0e0e0;border-radius:6px;font-size:16px;transition:border-color .3s;box-sizing:border-box}.input-group input:focus{outline:none;border-color:#667eea}.error-message{background-color:#ffebee;color:#c62828;padding:12px;border-radius:6px;margin-bottom:20px;font-size:14px;border-left:4px solid #c62828}.submit-btn{width:100%;padding:14px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:6px;font-size:16px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.submit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.submit-btn:disabled{opacity:.6;cursor:not-allowed}.toggle-mode{margin-top:20px;text-align:center;color:#666;font-size:14px}.link-btn{background:none;border:none;color:#667eea;font-weight:600;cursor:pointer;text-decoration:underline;padding:0 4px}.link-btn:hover{color:#764ba2}.migration-overlay{position:fixed;inset:0;background:#000000b3;display:flex;justify-content:center;align-items:center;z-index:9999;padding:20px}.migration-dialog{background:#fff;border-radius:12px;padding:30px;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 10px 40px #0000004d}.migration-dialog h2{margin:0 0 20px;color:#333;font-size:24px}.migration-content{text-align:center}.migration-description{font-size:16px;line-height:1.6;color:#555;margin-bottom:20px}.migration-info{background:#f0f7ff;border:1px solid #b3d9ff;border-radius:8px;padding:15px;margin:20px 0;text-align:left}.migration-info p{margin:8px 0;font-size:14px;color:#333;word-break:break-all}.migration-warning{background:#fff3cd;border:1px solid #ffc107;border-radius:8px;padding:12px;margin:20px 0;font-size:14px;color:#856404}.migration-buttons{display:flex;gap:10px;justify-content:center;margin-top:25px}.migration-buttons button{padding:12px 30px;border:none;border-radius:6px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s}.btn-migrate{background:#4caf50;color:#fff}.btn-migrate:hover{background:#45a049}.btn-cancel,.btn-close{background:#666;color:#fff}.btn-cancel:hover,.btn-close:hover{background:#555}.btn-retry{background:#2196f3;color:#fff}.btn-retry:hover{background:#0b7dda}.migration-spinner{font-size:48px;margin:20px 0;animation:spin 2s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.migration-progress{font-size:18px;color:#333;margin:15px 0;font-weight:600}.migration-note{font-size:14px;color:#666;margin-top:10px}.migration-success{font-size:48px;margin:20px 0;color:#4caf50}.migration-error{font-size:48px;margin:20px 0;color:#f44336}.migration-results{margin:20px 0;text-align:left}.migration-results h3{font-size:18px;margin-bottom:15px;color:#333}.migration-results table{width:100%;border-collapse:collapse;background:#fff}.migration-results th,.migration-results td{padding:12px;text-align:left;border-bottom:1px solid #ddd}.migration-results th{background:#f5f5f5;font-weight:600;color:#333}.migration-results td{color:#555}.migration-results .total-row{background:#f9f9f9;font-weight:600}.migration-results .total-row td{border-top:2px solid #333;color:#333}@media(max-width:768px){.migration-dialog{padding:20px}.migration-dialog h2{font-size:20px}.migration-buttons{flex-direction:column}.migration-buttons button{width:100%}}.console-toggle-btn-inline{background:transparent;border:none;font-size:24px;cursor:pointer;padding:0 8px;margin-left:8px;transition:transform .2s;vertical-align:middle}.console-toggle-btn-inline:hover{transform:scale(1.2)}.console-toggle-btn-inline:active{transform:scale(1)}.error-console{position:fixed;top:80px;right:20px;width:90%;max-width:600px;height:400px;background:#1e1e1e;border-radius:8px;box-shadow:0 8px 24px #00000080;display:flex;flex-direction:column;z-index:10000;font-family:Courier New,monospace}.console-header{background:#2d2d2d;color:#fff;padding:12px 15px;border-radius:8px 8px 0 0;display:flex;justify-content:space-between;align-items:center;font-weight:600;font-size:14px}.console-buttons{display:flex;gap:8px}.console-save-btn,.console-copy-btn,.console-clear-btn,.console-close-btn{background:#ffffff1a;color:#fff;border:none;padding:6px 12px;border-radius:4px;cursor:pointer;font-size:12px;transition:background .3s}.console-save-btn:hover,.console-copy-btn:hover{background:#4caf504d}.console-clear-btn:hover{background:#fff3}.console-close-btn{font-size:18px;padding:4px 10px;font-weight:700}.console-close-btn:hover{background:#f44336}.console-save-btn:disabled,.console-copy-btn:disabled{background:#ffffff0d;color:#666;cursor:not-allowed}.console-body{flex:1;overflow-y:auto;padding:10px;background:#1e1e1e;border-radius:0 0 8px 8px}.console-empty{color:#888;text-align:center;padding:20px;font-size:14px}.console-log{padding:8px;margin-bottom:4px;border-left:3px solid #888;border-radius:2px;font-size:12px;line-height:1.5;word-break:break-all}.console-log-log{background:#ffffff0d;border-left-color:#2196f3;color:#e0e0e0}.console-log-error{background:#f443361a;border-left-color:#f44336;color:#ffcdd2}.console-log-warn{background:#ff98001a;border-left-color:#ff9800;color:#ffe0b2}.console-timestamp{color:#888;margin-right:8px;font-size:11px}.console-type{color:#4caf50;margin-right:8px;font-weight:700;font-size:11px}.console-message{white-space:pre-wrap}.console-body::-webkit-scrollbar{width:8px}.console-body::-webkit-scrollbar-track{background:#2d2d2d}.console-body::-webkit-scrollbar-thumb{background:#555;border-radius:4px}.console-body::-webkit-scrollbar-thumb:hover{background:#777}@media(max-width:768px){.error-console{width:95%;height:50vh;max-height:400px;top:70px;right:10px}.console-toggle-btn-inline{font-size:20px;padding:0 6px}.console-log{font-size:11px}}
