.login-container{background:#fcfcff;justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.login-card{background:#fff;border:1px solid #dcdfe6;border-radius:12px;width:100%;max-width:400px;padding:40px 30px;box-shadow:0 4px 20px #0000001a}.login-card h1{text-align:center;color:#2c3e50;margin-bottom:8px;font-size:32px;font-weight:700}.login-card p{text-align:center;color:#7f8c8d;margin-bottom:40px;font-size:16px}.input-group{margin-bottom:20px}.input-group label{color:#2c3e50;margin-bottom:8px;font-size:16px;font-weight:600;display:block}.input-group input{box-sizing:border-box;color:#2c3e50;background-color:#f8f9fa;border:1px solid #dcdfe6;border-radius:8px;width:100%;padding:12px 16px;font-size:16px;transition:border-color .3s}.input-group input:focus{background-color:#fff;border-color:#2ecc71;outline:none}.input-group input::placeholder{color:#999}.input-group input:disabled{color:#bdc3c7;cursor:not-allowed;background-color:#ecf0f1}.loginButton{color:#fff;cursor:pointer;background:#2ecc71;border:none;border-radius:8px;justify-content:center;align-items:center;width:100%;min-height:52px;margin-bottom:16px;padding:16px;font-size:16px;font-weight:700;transition:background-color .3s;display:flex}.loginButton:hover:not(:disabled){background:#27ae60}.loginButton:disabled{cursor:not-allowed;background:#95a5a6}.error-message{color:#e74c3c;text-align:center;background:#e74c3c1a;border:1px solid #e74c3c33;border-radius:8px;margin-bottom:16px;padding:12px 16px;font-size:14px}.info-container{background:#ecf0f1;border-left:4px solid #3498db;border-radius:8px;margin-top:20px;padding:16px}.info-text{color:#2c3e50;text-align:center;margin:0;font-size:14px}.loading-spinner{border:2px solid #0000;border-top-color:#fff;border-radius:50%;width:20px;height:20px;animation:1s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (max-width:480px){.login-container{padding:16px}.login-card{padding:30px 20px}.login-card h1{font-size:28px}.login-card p{margin-bottom:30px;font-size:14px}}.react-grid-layout{transition:height .2s;position:relative}.react-grid-item{transition:left .2s,top .2s,width .2s,height .2s}.react-grid-item img{pointer-events:none;-webkit-user-select:none;user-select:none}.react-grid-item.cssTransforms{transition-property:transform,width,height}.react-grid-item.resizing{z-index:1;will-change:width,height;transition:none}.react-grid-item.react-draggable-dragging{z-index:3;will-change:transform;transition:none}.react-grid-item.dropping{visibility:hidden}.react-grid-item.react-grid-placeholder{opacity:.2;z-index:2;-webkit-user-select:none;user-select:none;-o-user-select:none;background:red;transition-duration:.1s}.react-grid-item.react-grid-placeholder.placeholder-resizing{transition:none}.react-grid-item>.react-resizable-handle{width:20px;height:20px;position:absolute}.react-grid-item>.react-resizable-handle:after{content:"";border-bottom:2px solid #0006;border-right:2px solid #0006;width:5px;height:5px;position:absolute;bottom:3px;right:3px}.react-resizable-hide>.react-resizable-handle{display:none}.react-grid-item>.react-resizable-handle.react-resizable-handle-sw{cursor:sw-resize;bottom:0;left:0;transform:rotate(90deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-se{cursor:se-resize;bottom:0;right:0}.react-grid-item>.react-resizable-handle.react-resizable-handle-nw{cursor:nw-resize;top:0;left:0;transform:rotate(180deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-ne{cursor:ne-resize;top:0;right:0;transform:rotate(270deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-w,.react-grid-item>.react-resizable-handle.react-resizable-handle-e{cursor:ew-resize;margin-top:-10px;top:50%}.react-grid-item>.react-resizable-handle.react-resizable-handle-w{left:0;transform:rotate(135deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-e{right:0;transform:rotate(315deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-n,.react-grid-item>.react-resizable-handle.react-resizable-handle-s{cursor:ns-resize;margin-left:-10px;left:50%}.react-grid-item>.react-resizable-handle.react-resizable-handle-n{top:0;transform:rotate(225deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-s{bottom:0;transform:rotate(45deg)}.dashboard{background-color:var(--primary-bg);min-height:100vh;padding:16px;position:relative}.dashboard-header{margin-bottom:30px}.welcome-card{background:var(--surface);box-shadow:0 2px 8px var(--shadow-color);border-radius:12px;justify-content:space-between;align-items:center;margin-bottom:24px;padding:24px;display:flex}.welcome-text h2{color:var(--text);margin:0 0 4px;font-size:24px;font-weight:700}.welcome-text p{color:var(--subtext);margin:0;font-size:16px}.welcome-controls{align-items:center;gap:16px;display:flex}.header-main{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.header-title{align-items:center;gap:12px;display:flex}.header-title h1{color:var(--text);margin:0;font-size:28px;font-weight:700;line-height:1}.month-selector{background-color:var(--primary-bg);border:1px solid var(--border);border-radius:8px;align-items:center;gap:8px;padding:8px 12px;transition:all .2s;display:flex}.month-selector:hover{border-color:var(--placeholder);box-shadow:0 2px 4px var(--shadow-color)}.month-selector .lucide-calendar{color:var(--subtext)}.select-wrapper{align-items:center;display:flex;position:relative}.month-selector select{appearance:none;color:var(--text);cursor:pointer;background:0 0;border:none;outline:none;min-width:180px;padding:4px 24px 4px 8px;font-size:14px;font-weight:500}.select-arrow{pointer-events:none;color:var(--subtext);position:absolute;right:4px}.summary-cards{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;display:grid}.summary-card{background:var(--surface);box-shadow:0 2px 8px var(--shadow-color);border-radius:12px;align-items:center;gap:20px;padding:20px;transition:transform .2s,box-shadow .2s;display:flex}.summary-card:hover{box-shadow:0 4px 12px var(--shadow-color-hover);transform:translateY(-2px)}.summary-card.positive{border-left:4px solid var(--positive)}.summary-card.negative{border-left:4px solid var(--negative)}.card-icon{border-radius:8px;justify-content:center;align-items:center;width:48px;height:48px;display:flex}.positive .card-icon{color:var(--positive);background-color:#27ae601a}.negative .card-icon{color:var(--negative);background-color:#e74c3c1a}.card-content{flex-direction:column;display:flex}.card-label{color:var(--subtext);margin-bottom:4px;font-size:14px}.card-value{color:var(--text);font-size:20px;font-weight:700}.dashboard-card{background:var(--surface);box-shadow:0 2px 8px var(--shadow-color);border-radius:12px;flex-direction:column;transition:transform .2s,box-shadow .2s,background-color .2s;display:flex;position:relative;overflow:hidden}.dashboard-card:hover{box-shadow:0 4px 16px var(--shadow-color-hover);transform:translateY(-2px)}.dashboard-card:hover .card-close-button{opacity:1;transform:scale(1)}.card-header{justify-content:space-between;align-items:center;margin-bottom:8px;padding:16px 20px 0;display:flex}.card-title-wrapper{align-items:center;gap:8px;display:flex;overflow:hidden}.card-title{color:var(--subtext);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:600;overflow:hidden}.card-close-button{cursor:pointer;width:24px;height:24px;color:var(--danger);opacity:0;background:#e74c3c1a;border:none;border-radius:6px;justify-content:center;align-items:center;transition:all .2s;display:flex;transform:scale(.8)}.card-close-button:hover{background:var(--negative);color:#fff;transform:scale(1.1)}.card-content{flex:1;padding:0 20px 20px;overflow:hidden}.layout-controls-container{position:relative}.layout-settings-button{border:1px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer;box-shadow:0 2px 4px var(--shadow-color);border-radius:8px;align-items:center;gap:8px;padding:10px 16px;font-weight:500;transition:all .2s;display:flex}.layout-settings-button:hover{background:var(--primary-bg);border-color:var(--primary);color:var(--primary);box-shadow:0 4px 8px var(--shadow-color-primary);transform:translateY(-1px)}.layout-toolbox{background:var(--surface);box-shadow:0 8px 32px var(--shadow-color-toolbox);z-index:1000;border:1px solid var(--border);border-radius:12px;width:380px;max-height:80vh;margin-top:8px;padding:0;animation:.2s ease-out slideDown;position:absolute;top:100%;right:0;overflow-y:auto}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.settings-sections{border-bottom:1px solid var(--border);padding:0}.settings-section{padding:3px 5px}.settings-section:last-child{border-bottom:none}.settings-section h5{color:var(--text);margin:0 0 16px;padding-left:10px;font-size:18px;font-weight:700}.settings-section h6{color:var(--subtext);margin:0 0 12px;font-size:14px;font-weight:600}.setting-item{background:var(--primary-bg);cursor:pointer;border:1px solid #0000;border-radius:12px;justify-content:space-between;align-items:center;margin-bottom:10px;padding:16px;transition:all .2s;display:flex}.setting-item:hover{border-color:var(--primary);background:#2ecc710d;transform:translate(4px)}.setting-left{flex:1;align-items:center;display:flex}.setting-icon{color:var(--primary);margin-right:12px}.setting-text{flex:1}.setting-title{color:var(--text);margin-bottom:2px;font-size:16px;font-weight:600}.setting-subtitle{color:var(--subtext);font-size:12px}.setting-arrow{color:var(--placeholder)}.theme-switch{align-items:center;gap:12px;display:flex}.theme-label{color:var(--subtext);font-size:14px;font-weight:500}.switch{background:var(--border);cursor:pointer;border-radius:12px;width:44px;height:24px;transition:all .3s;position:relative}.switch.active{background:var(--primary)}.switch-handle{background:#fff;border-radius:50%;width:20px;height:20px;transition:all .3s;position:absolute;top:2px;left:2px;box-shadow:0 1px 3px #0000004d}.switch.active .switch-handle{left:22px}.settings-footer{text-align:center;border-top:1px solid var(--border);background:var(--primary-bg);border-radius:0 0 12px 12px;padding:20px}.footer-text{color:var(--subtext);margin-bottom:4px;font-size:14px}.footer-subtext{color:var(--placeholder);font-size:12px}.toolbox-header{border-bottom:1px solid var(--border);background:var(--primary-bg);border-radius:12px 12px 0 0;align-items:center;gap:8px;padding:16px 20px;display:flex}.toolbox-header h4{color:var(--text);flex:1;margin:0;font-size:16px;font-weight:600}.toolbox-close{color:var(--subtext);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:4px;transition:all .2s}.toolbox-close:hover{background:var(--border);color:var(--text)}.cards-grid{flex-direction:column;gap:8px;margin-bottom:16px;display:flex}.toolbox-card-item{border:1px solid var(--border);background:var(--primary-bg);cursor:pointer;text-align:left;width:100%;color:var(--text);border-radius:8px;justify-content:space-between;align-items:center;padding:12px;font-size:14px;font-weight:500;transition:all .2s;display:flex}.toolbox-card-item:hover{border-color:var(--primary);color:var(--primary);background:#2ecc710d;transform:translate(4px)}.add-handle{color:var(--subtext);transition:color .2s}.toolbox-card-item:hover .add-handle{color:var(--primary)}.drag-handle{color:var(--subtext);flex-shrink:0}.no-cards-available{text-align:center;color:var(--subtext);background:var(--primary-bg);border:1px dashed var(--border);border-radius:8px;padding:16px;font-size:14px}.layout-actions{gap:8px;display:flex}.layout-action-btn{border:1px solid var(--border);background:var(--primary-bg);color:var(--text);cursor:pointer;border-radius:8px;flex:1;justify-content:center;align-items:center;gap:8px;padding:10px 12px;font-size:14px;font-weight:500;transition:all .2s;display:flex}.layout-action-btn:hover{box-shadow:0 4px 8px var(--shadow-color);transform:translateY(-1px)}.reset-btn{border-color:var(--primary);color:var(--primary);background:#2ecc711a}.reset-btn:hover{background:var(--primary);color:#fff}.clear-btn{border-color:var(--negative);color:var(--negative);background:#e74c3c1a}.clear-btn:hover{background:var(--negative);color:#fff}.logout-btn{border-color:var(--negative);color:var(--negative);background:#e74c3c1a}.logout-btn:hover{background:var(--negative);color:#fff}.theme-btn{color:#8e44ad;background:#8e44ad1a;border-color:#8e44ad}.theme-btn:hover{color:#fff;background:#8e44ad}.toolbox-hint{color:var(--primary);text-align:center;border-top:1px solid var(--border);background:#3498db0d;border-radius:0 0 12px 12px;padding:12px 20px;font-size:12px}.toolbox-overlay{z-index:999;background:0 0;position:fixed;inset:0}.chart-container{flex-direction:column;flex-grow:1;height:100%;display:flex}.chart-container h3{color:var(--text);margin:0 0 16px;font-size:16px;font-weight:600}.metric-card{flex-direction:column;justify-content:space-between;height:100%;padding:0;display:flex}.metric-card-header{color:var(--subtext);align-items:center;gap:10px;margin-bottom:12px;display:flex}.metric-card-body{margin-top:auto}.metric-card-value{color:var(--text);margin:0;font-size:28px;font-weight:700;line-height:1.2}.metric-card-subvalue{color:var(--subtext);white-space:nowrap;text-overflow:ellipsis;margin:4px 0 0;font-size:13px;overflow:hidden}.transaction-list{box-sizing:border-box;flex-direction:column;height:100%;padding:0;display:flex}.transaction-list>h2{color:var(--text);margin-bottom:16px;font-size:16px;font-weight:600}.transactions-grid{flex-direction:column;flex-grow:1;gap:12px;padding-bottom:4px;display:flex;overflow:hidden auto}.transaction-card{background:var(--surface);box-shadow:0 2px 4px var(--shadow-color);border-left:4px solid;border-radius:8px;justify-content:space-between;align-items:center;padding:16px;transition:transform .2s;display:flex}.transaction-card:hover{transform:translate(4px)}.transaction-info{flex:1}.transaction-main{margin-bottom:8px}.transaction-description{color:var(--text);margin:0 0 4px;font-size:14px;font-weight:600}.transaction-category{color:var(--subtext);font-size:12px}.transaction-date{color:var(--placeholder);font-size:12px}.transaction-amount{align-items:center;gap:8px;display:flex}.amount{font-size:14px;font-weight:700}.category-dot{border-radius:50%;width:12px;height:12px}.upcoming-payments-card{flex-direction:column;height:100%;padding:0;display:flex}.upcoming-list{flex-grow:1;margin:12px 0 0;padding:0;list-style:none;overflow-y:auto}.upcoming-item{border-bottom:1px solid var(--border);justify-content:space-between;padding:12px 0;font-size:14px;transition:background-color .2s;display:flex}.upcoming-item:hover{background-color:var(--primary-bg);border-radius:8px;margin:0 -12px;padding:12px}.upcoming-item:last-child{border-bottom:none}.upcoming-details{gap:10px;display:flex}.upcoming-name{color:var(--text);font-weight:600}.upcoming-category{background-color:var(--border);color:var(--subtext);border-radius:4px;margin-left:8px;padding:2px 6px;font-size:11px;font-weight:500}.upcoming-date{color:var(--text);margin-right:10px;font-size:14px;font-weight:600}.upcoming-amount{color:var(--subtext);font-weight:500}.no-data-message{color:var(--subtext);text-align:center;padding:20px}.react-grid-item.react-grid-placeholder{opacity:.15;border-radius:12px;background:var(--primary)!important}.react-grid-item>.react-resizable-handle:after{border-color:var(--text);opacity:.5}.react-grid-item>.react-resizable-handle:hover:after{opacity:1}.drop-zone-hint{background:var(--primary);color:#fff;box-shadow:0 4px 16px var(--shadow-color-primary);z-index:999;border-radius:8px;padding:12px 24px;font-weight:500;animation:2s infinite pulse;position:fixed;bottom:20px;left:50%;transform:translate(-50%)}@keyframes pulse{0%{transform:translate(-50%)scale(1)}50%{transform:translate(-50%)scale(1.05)}to{transform:translate(-50%)scale(1)}}.toolbox-card-item{transition:all .3s;position:relative}.toolbox-card-item:active{opacity:.8;transform:scale(.95)}.layout{min-height:400px;transition:all .3s}.layout.drag-over{border:2px dashed var(--primary);background:#3498db1a;border-radius:12px}.card-title-wrapper{flex:1;align-items:center;gap:8px;display:flex}.card-title-icon{color:var(--subtext);flex-shrink:0}.card-title{color:var(--text);white-space:nowrap;text-overflow:ellipsis;flex:1;font-size:14px;font-weight:600;overflow:hidden}.react-grid-item.react-draggable-dragging{z-index:1000;transition:transform .2s;transform:rotate(5deg)}.react-grid-item.cssTransforms{transition-property:transform;transition-duration:.2s}.react-grid-item.react-grid-placeholder{opacity:.2;border-radius:12px;transition:all .3s;background:var(--primary)!important}@media (max-width:768px){.dashboard{padding:12px}.welcome-card{flex-direction:column;align-items:flex-start;gap:16px}.welcome-controls{justify-content:space-between;width:100%}.header-main{flex-direction:column;align-items:flex-start;gap:16px}.summary-cards{grid-template-columns:1fr}.layout-toolbox{width:320px;right:-20%}.layout-actions{flex-direction:column}.transaction-card{flex-direction:column;align-items:flex-start;gap:12px}.transaction-amount{align-self:flex-end}.settings-section{padding:12px 16px}}@media (max-width:480px){.month-selector select{min-width:140px}.layout-toolbox{width:280px;right:-40%}.welcome-text h2{font-size:20px}.summary-card{padding:16px}.card-value{font-size:18px}}.layout-toolbox::-webkit-scrollbar{width:6px}.layout-toolbox::-webkit-scrollbar-track{background:var(--primary-bg);border-radius:3px}.layout-toolbox::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.layout-toolbox::-webkit-scrollbar-thumb:hover{background:var(--subtext)}.transactions-grid::-webkit-scrollbar{width:6px}.transactions-grid::-webkit-scrollbar-track{background:var(--primary-bg);border-radius:3px}.transactions-grid::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.transactions-grid::-webkit-scrollbar-thumb:hover{background:var(--subtext)}.upcoming-list::-webkit-scrollbar{width:6px}.upcoming-list::-webkit-scrollbar-track{background:var(--primary-bg);border-radius:3px}.upcoming-list::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.upcoming-list::-webkit-scrollbar-thumb:hover{background:var(--subtext)}.layout-settings-button:focus,.month-selector select:focus,.layout-action-btn:focus,.card-close-button:focus,.setting-item:focus{outline:2px solid var(--primary);outline-offset:2px}.dashboard-card.loading{opacity:.7;pointer-events:none}.dashboard-card.loading:after{content:"";background:linear-gradient(90deg,#0000,#fff6,#0000);animation:1.5s infinite loading;position:absolute;inset:0}@keyframes loading{0%{transform:translate(-100%)}to{transform:translate(100%)}}@media print{.layout-settings-button,.card-close-button,.toolbox-overlay{display:none!important}.dashboard-card{break-inside:avoid;box-shadow:none;border:1px solid #ccc}}:root,html[data-theme=light]{--primary-bg:#fff;--surface:#f8f9fa;--text:#2c3e50;--subtext:#7f8c8d;--placeholder:#bdc3c7;--border:#dcdfe6;--positive:#27ae60;--negative:#e74c3c;--warning:#f39c12;--primary:#2ecc71;--primary-hover:#27ae60;--accent:#3498db;--danger:#e74c3c;--modal-overlay:#00000080;--shadow-color:#0000001a;--shadow-color-hover:#00000026;--shadow-color-toolbox:#00000026;--shadow-color-primary:#2ecc7133}html[data-theme=dark]{--primary-bg:#121212;--surface:#1e1e1e;--text:#e0e0e0;--subtext:#9e9e9e;--placeholder:#757575;--border:#424242;--positive:#27ae60;--negative:#e74c3c;--warning:#f39c12;--primary:#2ecc71;--primary-hover:#27ae60;--accent:#3498db;--danger:#e74c3c;--modal-overlay:#000000b3;--shadow-color:#0000004d;--shadow-color-hover:#0006;--shadow-color-toolbox:#00000059;--shadow-color-primary:#2ecc714d}.loading-container{background-color:var(--primary-bg,#f0f2f5);width:100vw;height:100vh;color:var(--text,#555);z-index:9999;flex-direction:column;justify-content:center;align-items:center;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;display:flex;position:fixed;top:0;left:0}.loading-spinner{border:4px solid #0000001a;border-left-color:var(--positive,#27ae60);border-radius:50%;width:36px;height:36px;margin-bottom:20px;animation:1s infinite spin}:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:#ffffffde;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#242424;font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;font-weight:400;line-height:1.5}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}a{color:#646cff;-webkit-text-decoration:inherit;text-decoration:inherit;font-weight:500}a:hover{color:#535bf2}body{min-height:100vh;margin:0}h1{font-size:3.2em;line-height:1.1}button{cursor:pointer;background-color:#1a1a1a;border:1px solid #0000;border-radius:8px;padding:.6em 1.2em;font-family:inherit;font-size:1em;font-weight:500;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}
