:root{--color-primary:#1e40af;--color-primary-light:#3b82f6;--color-primary-dark:#1e3a8a;--color-secondary:#059669;--color-accent:#f59e0b;--color-danger:#dc2626;--color-success:#059669;--color-warning:#f59e0b;--color-info:#6366f1;--color-background:#fff;--color-surface:#f9fafb;--color-text-primary:#1f2937;--color-text-secondary:#6b7280;--color-border:#e5e7eb;--gradient-primary:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);--gradient-secondary:linear-gradient(135deg,var(--color-secondary) 0%,#047857 100%);--gradient-accent:linear-gradient(135deg,var(--color-accent) 0%,#d97706 100%);--gradient-danger:linear-gradient(135deg,var(--color-danger) 0%,#b91c1c 100%);--gradient-info:linear-gradient(135deg,var(--color-info) 0%,#4f46e5 100%);--gradient-background:linear-gradient(135deg,var(--color-primary-light) 0%,var(--color-primary-dark) 100%);--color-error-bg:#fee2e2;--color-error-text:#991b1b;--color-error-border:#fecaca}[data-theme=dark]{--color-primary:#60a5fa;--color-primary-light:#93c5fd;--color-primary-dark:#3b82f6;--color-background:#111827;--color-surface:#1f2937;--color-text-primary:#f9fafb;--color-text-secondary:#d1d5db;--color-border:#374151;--gradient-primary:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);--gradient-secondary:linear-gradient(135deg,var(--color-secondary) 0%,#10b981 100%);--gradient-accent:linear-gradient(135deg,var(--color-accent) 0%,#fbbf24 100%);--gradient-danger:linear-gradient(135deg,#ef4444,#dc2626);--gradient-info:linear-gradient(135deg,#818cf8 0%,var(--color-info) 100%);--gradient-background:linear-gradient(135deg,#1e293b,#0f172a);--color-error-bg:#7f1d1d;--color-error-text:#fecaca;--color-error-border:#991b1b}*{box-sizing:border-box;padding:0;margin:0}html{font-family:var(--font-lato),"Lato",-apple-system,BlinkMacSystemFont,"Segoe UI","Roboto","Oxygen","Ubuntu","Cantarell","Fira Sans","Droid Sans","Helvetica Neue",sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body,html{max-width:100vw;overflow-x:hidden!important;overflow-y:auto!important;height:auto!important}body{background:var(--gradient-background);padding:0}#__next,body{min-height:100vh}#__next{height:auto!important}.container{max-width:1200px;margin:0 auto;background:var(--color-background);border-radius:12px;box-shadow:0 20px 60px rgba(0,0,0,.3);padding:1.5rem}.header{flex-direction:row;justify-content:space-between;text-align:center;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:2px solid var(--color-border);gap:1rem;position:relative;flex-wrap:wrap}.header,.header-logo{display:flex;align-items:center}.header-logo{justify-content:center}.logo-image{border-radius:8px;-o-object-fit:contain;object-fit:contain;max-width:120px;height:auto}.header-content{display:flex;flex-direction:column;align-items:center;flex:1;min-width:0}.header-actions{display:flex;align-items:center;justify-content:flex-end;flex-shrink:0;gap:.75rem}.language-toggle{display:flex;align-items:center;gap:.25rem;border:1px solid var(--color-border);border-radius:8px;padding:.25rem;background:var(--color-surface)}.language-button{padding:.5rem .75rem;border:none;border-radius:6px;background:transparent;color:var(--color-text-primary);font-size:clamp(.75rem,2vw,.875rem);font-weight:600;cursor:pointer;transition:all .2s ease;min-height:36px;touch-action:manipulation}.language-button:hover{background:var(--color-border)}.language-button.active{background:var(--color-primary);color:#fff}.language-button:focus{outline:none;box-shadow:0 0 0 3px rgba(30,64,175,.1)}.header h1{color:var(--color-text-primary);font-size:clamp(1.25rem,5vw,2rem);font-weight:700;margin-bottom:.5rem;line-height:1.3}.header p{color:var(--color-text-secondary);font-size:clamp(.875rem,3vw,1rem)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:.75rem;margin-bottom:1.5rem}.stats-grid .stat-card{display:flex;flex-direction:column;justify-content:center;align-items:center;min-width:0;width:100%;box-sizing:border-box}.stat-card{background:var(--gradient-primary);padding:1rem;border-radius:8px;min-width:0;overflow:hidden}.stat-card,.stat-card h3{color:hsla(0,0%,100%,.95);text-align:center}.stat-card h3{font-size:clamp(.75rem,2.5vw,.875rem);font-weight:500;margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.5px;line-height:1.3;word-wrap:break-word;overflow-wrap:break-word;width:100%}.stat-card .value{font-weight:700;white-space:nowrap;overflow:visible;max-width:100%;line-height:1.2;padding:0 .25rem;box-sizing:border-box;width:100%;text-align:center;min-width:0;color:#fff}.stat-card .stat-subtitle{font-size:clamp(.65rem,2vw,.75rem);color:hsla(0,0%,100%,.85);margin-top:.25rem;text-transform:none;letter-spacing:normal;line-height:1.3;word-wrap:break-word;overflow-wrap:break-word;text-align:center;width:100%}.stat-card-pending{background:var(--gradient-danger);order:-1}.stat-card-ordered{background:var(--gradient-accent);order:0}.stat-card-paid{background:var(--gradient-secondary);order:1}.stat-card-carryover{background:var(--gradient-info);order:2}.monthly-reports{margin-top:2rem}.monthly-reports h2{color:var(--color-text-primary);font-size:1.5rem;font-weight:600;margin-bottom:1.5rem}.month-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;padding:1rem;margin-bottom:1rem;transition:all .2s ease}.month-card:hover{box-shadow:0 4px 12px rgba(0,0,0,.1);transform:translateY(-2px)}.month-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem;flex-wrap:wrap;gap:1rem}.month-title{font-size:clamp(1rem,3vw,1.25rem);font-weight:600;color:var(--color-text-primary)}.month-amounts{display:flex;flex-direction:column;gap:.5rem;align-items:flex-end;width:100%;min-width:0}.month-amount-group{display:flex;align-items:center;gap:.5rem;min-width:0;flex-wrap:nowrap}.amount-label{font-size:clamp(.75rem,2vw,.875rem);color:var(--color-text-secondary);font-weight:500;white-space:nowrap;flex-shrink:0}.month-amount{font-weight:700;white-space:nowrap;overflow:visible;max-width:100%;text-align:right;flex-shrink:1;min-width:0}.month-amount-ordered{color:var(--color-accent)}.month-amount-paid{color:var(--color-secondary)}.month-amount-carryover{color:var(--color-info)}.month-details{display:flex;gap:1rem;color:var(--color-text-secondary);font-size:clamp(.75rem,2vw,.875rem);flex-wrap:wrap}.error{background:var(--color-error-bg);color:var(--color-error-text);padding:1rem;border-radius:8px;border:1px solid var(--color-error-border);margin:1rem 0;font-size:clamp(.875rem,2.5vw,1rem)}.loading{font-size:1.125rem}.empty-state,.loading{text-align:center;padding:3rem;color:var(--color-text-secondary)}.empty-state h3{font-size:1.25rem;margin-bottom:.5rem;color:var(--color-text-primary)}.filterable-chart-container{margin:2rem 0}.format-toggle{gap:.75rem;padding:.75rem;border-radius:8px;flex-wrap:wrap}.format-toggle,.theme-toggle-switch{display:flex;align-items:center;background:var(--color-surface);border:1px solid var(--color-border);box-sizing:border-box}.theme-toggle-switch{justify-content:center;padding:.5rem;border-radius:8px;color:var(--color-text-primary);cursor:pointer;transition:all .2s ease;min-width:44px;min-height:44px;touch-action:manipulation}.theme-toggle-switch:hover{background:var(--color-primary);border-color:var(--color-primary);transform:scale(1.05)}.theme-toggle-switch:focus{outline:none;box-shadow:0 0 0 3px rgba(30,64,175,.1)}.theme-toggle-icon{font-size:1.5rem;line-height:1;display:block}.format-toggle-label{font-weight:600;color:var(--color-text-primary);font-size:clamp(.75rem,2vw,.875rem);flex-shrink:0}.format-toggle-buttons{display:flex;gap:.5rem;flex-wrap:wrap}.format-button{padding:.625rem 1rem;border:1px solid var(--color-border);border-radius:6px;background:var(--color-background);color:var(--color-text-primary);font-size:clamp(.75rem,2vw,.875rem);cursor:pointer;transition:all .2s ease;min-height:44px;touch-action:manipulation}.format-button:hover{border-color:var(--color-primary);color:var(--color-primary)}.format-button.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.format-button:focus{outline:none;box-shadow:0 0 0 3px rgba(30,64,175,.1)}.chart-controls{display:flex;flex-direction:row;align-items:stretch;gap:1rem;margin-bottom:1rem;flex-wrap:wrap;justify-content:space-between}.chart-filter{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:var(--color-surface);border-radius:8px;border:1px solid var(--color-border);flex-wrap:wrap;flex:1;min-width:0;box-sizing:border-box}.chart-format-toggle-wrapper{flex-shrink:0;display:flex;align-items:stretch}.filter-label{font-weight:600;flex-shrink:0}.filter-label,.filter-select{color:var(--color-text-primary);font-size:clamp(.75rem,2vw,.875rem)}.filter-select{padding:.625rem 1rem;border:1px solid var(--color-border);border-radius:6px;background:var(--color-background);cursor:pointer;transition:all .2s ease;min-height:44px;touch-action:manipulation;flex:1;min-width:150px}.filter-select:focus,.filter-select:hover{border-color:var(--color-primary)}.filter-select:focus{outline:none;box-shadow:0 0 0 3px rgba(30,64,175,.1)}.filter-info{color:var(--color-text-secondary);font-size:clamp(.75rem,2vw,.875rem);margin-left:auto;flex-basis:100%}.chart-container{background:var(--color-background);border-radius:8px;padding:1rem;box-shadow:0 1px 3px rgba(0,0,0,.1);overflow-x:auto;overflow-y:visible;width:100%;max-width:100%}.chart-container h2{color:var(--color-text-primary);font-size:clamp(1.125rem,4vw,1.5rem);font-weight:600;margin-bottom:1rem;text-align:center}.chart-bar-label{-webkit-user-select:none;-moz-user-select:none;user-select:none;pointer-events:none}@media (max-width:640px){html{-webkit-text-size-adjust:100%}body{padding:.5rem}.container{padding:1rem;border-radius:8px}.transactions-list{max-height:400px}.header{margin-bottom:1.5rem;padding-bottom:1rem;gap:.75rem;padding-top:3.5rem;flex-direction:column}.header-logo{order:1}.header-content{order:2;width:100%;padding-right:0;padding-left:0;margin-top:0}.header h1{font-size:clamp(1rem,4vw,1.5rem);padding-right:0;text-align:center}.header p{font-size:clamp(.75rem,3vw,.875rem);text-align:center}.header-actions{position:absolute;top:.5rem;right:.5rem;justify-content:center;width:auto;flex-direction:row;gap:.5rem;z-index:10}.language-toggle{padding:.125rem;gap:.125rem}.language-button{padding:.375rem .5rem;font-size:.75rem;min-height:32px}.theme-toggle-switch{width:36px;height:36px;font-size:1.1rem}.logo-image{max-width:80px}.stats-grid{grid-template-columns:1fr;gap:.5rem;margin-bottom:1.5rem}.stat-card{padding:.875rem;min-height:auto}.stat-card h3{font-size:clamp(.7rem,2.5vw,.875rem);margin-bottom:.5rem;line-height:1.2}.stat-card .value{margin:.5rem 0}.stat-card .stat-subtitle{font-size:clamp(.65rem,2vw,.75rem);margin-top:.25rem}.monthly-reports{margin-top:1.5rem}.monthly-reports h2{font-size:clamp(1rem,4vw,1.25rem);margin-bottom:1rem}.month-card{padding:.875rem;margin-bottom:.75rem}.month-header{flex-direction:column;align-items:stretch;gap:.75rem}.month-title{font-size:clamp(.95rem,3vw,1.125rem);width:100%}.month-amounts{width:100%;align-items:stretch;gap:.5rem}.month-amount-group{width:100%;justify-content:space-between;gap:.5rem;padding:.25rem 0}.month-amount{text-align:right;flex:1;min-width:0}.amount-label{flex-shrink:0}.month-details{flex-direction:column;gap:.5rem;margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--color-border)}.chart-controls,.chart-filter{flex-direction:column;gap:.75rem}.chart-filter{align-items:stretch;flex:1}.chart-controls-right{flex-direction:column;gap:.75rem;width:100%}.chart-format-toggle-wrapper,.chart-theme-toggle-wrapper,.format-toggle,.format-toggle-buttons,.theme-toggle,.theme-toggle-buttons{width:100%}.format-button,.theme-button{flex:1;min-width:0}.filter-select{width:100%;min-width:0}.filter-info{margin-left:0;flex-basis:auto}.chart-container{padding:.5rem;overflow-x:auto;-webkit-overflow-scrolling:touch;width:100%;max-width:100%;box-sizing:border-box}.chart-container h2{font-size:1rem;margin-bottom:.75rem}.recharts-wrapper{min-width:100%}.recharts-cartesian-axis-tick{font-size:10px!important}.drilldown-summary{flex-direction:column;align-items:flex-start;gap:.25rem}.drilldown-summary span:nth-child(2n){display:none}}@media (min-width:641px) and (max-width:768px){body{padding:.75rem}.container{padding:1.25rem}.stats-grid{grid-template-columns:repeat(2,1fr);gap:.75rem}.stat-card{padding:1rem}.month-amounts,.month-header{flex-wrap:wrap;gap:.75rem}.month-amounts{flex-direction:row;align-items:flex-start}.month-amount-group{flex-direction:column;align-items:flex-end;gap:.25rem;min-width:120px}.month-amount{text-align:right}}@media (min-width:769px){.stats-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}}.month-drilldown{margin-top:1rem;border-top:1px solid var(--color-border);padding-top:1rem}.drilldown-toggle{display:flex;align-items:center;gap:.5rem;background:none;border:1px solid var(--color-border);border-radius:6px;padding:.75rem 1rem;color:var(--color-primary);font-size:clamp(.75rem,2vw,.875rem);font-weight:500;cursor:pointer;transition:all .2s ease;width:100%;text-align:left;min-height:44px;touch-action:manipulation}.drilldown-toggle:hover{background:var(--color-surface);border-color:var(--color-primary)}.drilldown-toggle:focus{outline:none;box-shadow:0 0 0 3px rgba(30,64,175,.1)}.drilldown-icon{font-size:.75rem;transition:transform .2s ease}.drilldown-text{flex:1}.drilldown-content{margin-top:1rem;animation:slideDown .3s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.drilldown-header{margin-bottom:1rem;padding-bottom:.75rem;border-bottom:2px solid var(--color-border)}.drilldown-header h3{color:var(--color-text-primary);font-size:1.125rem;font-weight:600;margin-bottom:.5rem}.drilldown-summary{display:flex;gap:.5rem;color:var(--color-text-secondary);font-size:.875rem;align-items:center}.transactions-list{display:flex;flex-direction:column;gap:.75rem;max-height:500px;overflow-y:auto;overflow-x:hidden;padding-right:.5rem;-webkit-overflow-scrolling:touch}.transaction-item{background:var(--color-surface);border:1px solid var(--color-border);border-radius:6px;padding:.75rem;transition:all .2s ease}.transaction-item:hover{box-shadow:0 2px 4px rgba(0,0,0,.05)}.transaction-item.transaction-purchase{border-left:4px solid var(--color-danger)}.transaction-item.transaction-purchase:hover{border-color:var(--color-danger);background:var(--color-error-bg)}.transaction-item.transaction-payment{border-left:4px solid var(--color-secondary)}.transaction-item.transaction-payment:hover{border-color:var(--color-secondary);background:#f0fdf4}.transaction-main{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;gap:1rem;min-width:0}.transaction-main>*{min-width:0}.transaction-date{color:var(--color-text-primary);font-weight:500;font-size:clamp(.75rem,2vw,.875rem)}.transaction-amount{word-break:break-word;overflow-wrap:break-word;max-width:100%;text-align:right;white-space:nowrap;overflow:visible;min-width:0;font-weight:700}.transaction-amount.expense{color:var(--color-danger)}.transaction-amount.payment{color:var(--color-secondary)}.transaction-description{font-size:clamp(.75rem,2vw,.875rem);font-style:italic;word-break:break-word}.transaction-bill,.transaction-description{color:var(--color-text-secondary);margin-bottom:.25rem}.transaction-bill{font-size:clamp(.625rem,1.5vw,.75rem)}.transaction-balance{color:var(--color-text-secondary);margin-top:.5rem;padding-top:.5rem;border-top:1px solid var(--color-border);white-space:nowrap;overflow:visible}@media (max-width:768px){.transaction-main{gap:.5rem}.drilldown-summary,.transaction-main{flex-direction:column;align-items:flex-start}.drilldown-summary{gap:.25rem}.drilldown-summary span:nth-child(2){display:none}}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;background:var(--color-background)}.login-card{width:100%;max-width:420px;background:var(--color-surface);border-radius:12px;padding:2.5rem;box-shadow:0 4px 6px rgba(0,0,0,.1),0 2px 4px rgba(0,0,0,.06);border:1px solid var(--color-border)}[data-theme=dark] .login-card{box-shadow:0 4px 6px rgba(0,0,0,.3),0 2px 4px rgba(0,0,0,.2)}.login-header{text-align:center;margin-bottom:2rem}.login-logo{display:flex;justify-content:center;margin-bottom:1rem}.login-logo .logo-image{border-radius:50%;border:3px solid var(--color-primary)}.login-header h1{font-size:1.75rem;font-weight:700;color:var(--color-text-primary);margin:0 0 .5rem}.login-subtitle{color:var(--color-text-secondary);font-size:.95rem;margin:0}.login-form{gap:1.5rem}.login-form,.login-input-group{display:flex;flex-direction:column}.login-input-group{gap:.5rem}.login-input-group label{font-weight:500;color:var(--color-text-primary);font-size:.9rem}.login-input{width:100%;padding:.875rem 1rem;font-size:1rem;border:2px solid var(--color-border);border-radius:8px;background:var(--color-background);color:var(--color-text-primary);transition:all .2s ease;font-family:inherit}.login-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(30,64,175,.1)}[data-theme=dark] .login-input:focus{box-shadow:0 0 0 3px rgba(96,165,250,.2)}.login-input.error{border-color:var(--color-danger)}.login-input:disabled{opacity:.6;cursor:not-allowed}.login-error{color:var(--color-danger);font-size:.875rem;margin-top:.25rem}.login-button{width:100%;padding:.875rem 1.5rem;font-size:1rem;font-weight:600;color:#fff;background:var(--gradient-primary);border:none;border-radius:8px;cursor:pointer;transition:all .2s ease;font-family:inherit}.login-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px rgba(30,64,175,.3)}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.login-loading{text-align:center;padding:2rem;color:var(--color-text-secondary);font-size:1rem}.logout-button{background:transparent;border:1px solid var(--color-border);border-radius:6px;padding:.5rem;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--color-text-primary);transition:all .2s ease;min-width:36px;height:36px}.logout-button:hover{background:var(--color-surface);border-color:var(--color-primary);color:var(--color-primary)}.logout-button svg{width:18px;height:18px}@media (max-width:768px){.login-container{padding:1rem}.login-card{padding:2rem 1.5rem}.login-header h1{font-size:1.5rem}.logout-button{min-width:32px;height:32px;padding:.375rem}.logout-button svg{width:16px;height:16px}}