@import "https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@300;400;500;600;700;800&display=swap";
:root{--font-family:"Plus Jakarta Sans", system-ui, -apple-system, sans-serif;--bg-primary:#0b0f17;--bg-secondary:#121824;--bg-tertiary:#1b2436;--card-bg:#121824bf;--card-border:#ffffff0f;--card-hover-border:#6366f140;--text-primary:#f8fafc;--text-secondary:#94a3b8;--text-muted:#64748b;--accent-color:#6366f1;--accent-gradient:linear-gradient(135deg, #6366f1 0%, #a855f7 100%);--accent-glow:#6366f126;--gain-color:#10b981;--gain-gradient:linear-gradient(135deg, #10b981 0%, #059669 100%);--gain-bg-light:#10b9811a;--expense-color:#f43f5e;--expense-gradient:linear-gradient(135deg, #f43f5e 0%, #e11d48 100%);--expense-bg-light:#f43f5e1a;--warning-color:#f59e0b;--border-radius-sm:8px;--border-radius-md:12px;--border-radius-lg:16px;--border-radius-xl:24px;--transition-fast:.15s ease;--transition-normal:.3s cubic-bezier(.4, 0, .2, 1);--sidebar-width:260px}*{box-sizing:border-box;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0;padding:0}body{background-color:var(--bg-primary);color:var(--text-primary);font-family:var(--font-family);min-height:100vh;overflow-x:hidden}.glass{background:var(--card-bg);-webkit-backdrop-filter:blur(16px);border:1px solid var(--card-border);box-shadow:0 8px 32px #0000004d}.app-container{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-width);z-index:100;border-right:1px solid var(--card-border);flex-direction:column;min-height:100vh;padding:2rem 1.5rem;display:flex;position:fixed;top:0;left:0}.logo-container{align-items:center;gap:.75rem;margin-bottom:3rem;display:flex}.logo-text{letter-spacing:-.025em;background:var(--accent-gradient);-webkit-text-fill-color:transparent;-webkit-background-clip:text;font-size:1.5rem;font-weight:800}.nav-links{flex-direction:column;gap:.5rem;list-style:none;display:flex}.nav-item a{color:var(--text-secondary);border-radius:var(--border-radius-md);transition:var(--transition-normal);border:1px solid #0000;align-items:center;gap:.875rem;padding:.875rem 1rem;font-size:.95rem;font-weight:500;text-decoration:none;display:flex}.nav-item a:hover{color:var(--text-primary);background-color:#ffffff08}.nav-item.active a{color:var(--text-primary);background:#6366f114;border-color:#6366f133}.nav-item.active a svg{color:var(--accent-color)}.sidebar-footer{border-top:1px solid var(--card-border);align-items:center;gap:.75rem;margin-top:auto;padding-top:2rem;display:flex}.footer-avatar{background:var(--accent-gradient);border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;font-size:.9rem;font-weight:700;display:flex}.footer-info{flex-direction:column;display:flex}.footer-title{color:var(--text-primary);font-size:.875rem;font-weight:600}.footer-subtitle{color:var(--text-muted);font-size:.75rem}.main-content{margin-left:var(--sidebar-width);max-width:1400px;width:calc(100% - var(--sidebar-width));flex:1;padding:2.5rem}.page-header{margin-bottom:2.5rem}.page-title{letter-spacing:-.02em;color:var(--text-primary);margin-bottom:.5rem;font-size:2rem;font-weight:800}.page-subtitle{color:var(--text-secondary);font-size:1rem}.kpi-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;margin-bottom:2.5rem;display:grid}.kpi-card{border-radius:var(--border-radius-lg);transition:var(--transition-normal);padding:1.75rem;position:relative;overflow:hidden}.kpi-card:hover{border-color:var(--card-hover-border);transform:translateY(-4px)}.kpi-header{justify-content:space-between;align-items:center;margin-bottom:1.25rem;display:flex}.kpi-title{text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);font-size:.875rem;font-weight:600}.kpi-icon-wrapper{border-radius:var(--border-radius-md);justify-content:center;align-items:center;width:48px;height:48px;display:flex}.kpi-icon-wrapper.gain{background:var(--gain-bg-light);color:var(--gain-color)}.kpi-icon-wrapper.expense{background:var(--expense-bg-light);color:var(--expense-color)}.kpi-icon-wrapper.balance{color:var(--accent-color);background:#6366f11a}.kpi-value{letter-spacing:-.02em;margin-bottom:.5rem;font-size:2rem;font-weight:800}.kpi-value.gain{color:var(--gain-color)}.kpi-value.expense{color:var(--expense-color)}.kpi-value.balance-positive{color:var(--gain-color)}.kpi-value.balance-negative{color:var(--expense-color)}.kpi-desc{color:var(--text-muted);font-size:.875rem}.dashboard-grid{grid-template-columns:1.6fr 1fr;gap:1.5rem;margin-bottom:2.5rem;display:grid}@media (max-width:1024px){.dashboard-grid{grid-template-columns:1fr}}.dashboard-card{border-radius:var(--border-radius-lg);height:100%;padding:1.75rem}.card-title-container{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.card-title{color:var(--text-primary);align-items:center;gap:.5rem;font-size:1.25rem;font-weight:700;display:flex}.chart-container{align-items:flex-end;gap:1.5rem;height:280px;padding-top:1rem;display:flex;position:relative}.chart-bar-wrapper{flex-direction:column;flex:1;justify-content:flex-end;align-items:center;height:100%;display:flex}.chart-bar-group{justify-content:center;align-items:flex-end;gap:4px;width:100%;height:80%;display:flex}.chart-bar{border-radius:4px 4px 0 0;width:14px;transition:height .6s cubic-bezier(.175,.885,.32,1.275);position:relative}.chart-bar:hover:after{content:attr(data-value);background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--card-border);white-space:nowrap;pointer-events:none;z-index:10;border-radius:4px;padding:4px 8px;font-size:.75rem;font-weight:600;position:absolute;top:-30px;left:50%;transform:translate(-50%)}.chart-bar.gain{background:var(--gain-gradient)}.chart-bar.expense{background:var(--expense-gradient)}.chart-label{color:var(--text-secondary);text-align:center;margin-top:.75rem;font-size:.75rem}.chart-legend{justify-content:center;gap:1rem;margin-top:1.5rem;display:flex}.legend-item{color:var(--text-secondary);align-items:center;gap:.375rem;font-size:.825rem;display:flex}.legend-dot{border-radius:50%;width:8px;height:8px}.legend-dot.gain{background:var(--gain-color)}.legend-dot.expense{background:var(--expense-color)}.transaction-list{flex-direction:column;gap:.875rem;display:flex}.transaction-item{border-radius:var(--border-radius-md);border:1px solid var(--card-border);transition:var(--transition-normal);background:#ffffff03;justify-content:space-between;align-items:center;padding:1rem;display:flex}.transaction-item:hover{border-color:var(--card-hover-border);background:#ffffff08;transform:translate(4px)}.trans-info-group{align-items:center;gap:1rem;display:flex}.trans-icon-box{border-radius:50%;justify-content:center;align-items:center;width:42px;height:42px;display:flex}.trans-icon-box.gain,.trans-icon-box.income{background:var(--gain-bg-light);color:var(--gain-color)}.trans-icon-box.expense{background:var(--expense-bg-light);color:var(--expense-color)}.trans-details{flex-direction:column;gap:.25rem;display:flex}.trans-title{color:var(--text-primary);font-size:.95rem;font-weight:600}.trans-subtitle{color:var(--text-muted);font-size:.775rem}.trans-meta-group{align-items:center;gap:1.5rem;display:flex}.trans-amount{text-align:right;font-size:1.05rem;font-weight:700}.trans-amount.gain,.trans-amount.income{color:var(--gain-color)}.trans-amount.expense{color:var(--expense-color)}.trans-date{color:var(--text-muted);font-size:.8rem}.progress-list{flex-direction:column;gap:1.25rem;display:flex}.progress-item{flex-direction:column;gap:.5rem;display:flex}.progress-info{justify-content:space-between;font-size:.875rem;font-weight:500;display:flex}.progress-label{color:var(--text-primary)}.progress-value{color:var(--text-secondary)}.progress-bar-bg{background:var(--bg-tertiary);border-radius:3px;height:6px;overflow:hidden}.progress-bar-fill{border-radius:3px;height:100%;transition:width .8s cubic-bezier(.4,0,.2,1)}.progress-bar-fill.expense{background:var(--expense-gradient)}.progress-bar-fill.gain{background:var(--gain-gradient)}.form-card{border-radius:var(--border-radius-lg);margin-bottom:2rem;padding:2rem}.form-title{background:var(--accent-gradient);-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin-bottom:1.5rem;font-size:1.35rem;font-weight:700}.form-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.25rem;margin-bottom:1.5rem;display:grid}.form-group{flex-direction:column;gap:.5rem;display:flex}.form-label{color:var(--text-secondary);font-size:.85rem;font-weight:600}.form-input{background:var(--bg-tertiary);border:1px solid var(--card-border);color:var(--text-primary);font-family:var(--font-family);border-radius:var(--border-radius-md);transition:var(--transition-fast);outline:none;padding:.75rem 1rem;font-size:.95rem}.form-input:focus{border-color:var(--accent-color);box-shadow:0 0 0 3px #6366f126}.btn-primary{background:var(--accent-gradient);color:#fff;border-radius:var(--border-radius-md);cursor:pointer;font-weight:600;font-family:var(--font-family);transition:var(--transition-normal);border:none;justify-content:center;align-items:center;gap:.5rem;padding:.875rem 1.75rem;font-size:.95rem;display:inline-flex}.btn-primary:hover{opacity:.95;transform:translateY(-2px);box-shadow:0 4px 20px #6366f166}.btn-primary:active{transform:translateY(0)}.btn-secondary{color:var(--text-secondary);border:1px solid var(--card-border);border-radius:var(--border-radius-md);cursor:pointer;font-weight:500;font-family:var(--font-family);transition:var(--transition-fast);background:0 0;padding:.875rem 1.5rem;font-size:.95rem}.btn-secondary:hover{color:var(--text-primary);border-color:var(--text-secondary);background:#ffffff08}.btn-danger{background:var(--expense-bg-light);color:var(--expense-color);border-radius:var(--border-radius-md);cursor:pointer;transition:var(--transition-fast);border:1px solid #f43f5e33;padding:.5rem .875rem;font-size:.85rem;font-weight:500}.btn-danger:hover{background:var(--expense-color);color:#fff}.categories-container{grid-template-columns:1fr 1fr;gap:2rem;display:grid}@media (max-width:900px){.categories-container{grid-template-columns:1fr}}.category-setup-card{border-radius:var(--border-radius-lg);margin-bottom:1.5rem;padding:1.75rem}.category-setup-header{border-bottom:1px solid var(--card-border);justify-content:space-between;align-items:center;margin-bottom:1.25rem;padding-bottom:1rem;display:flex}.category-name-title{font-size:1.15rem;font-weight:700}.products-wrapper{flex-direction:column;gap:.75rem;display:flex}.product-item{border:1px solid var(--card-border);border-radius:var(--border-radius-md);background:#ffffff05;justify-content:space-between;align-items:center;padding:.625rem .875rem;display:flex}.product-name{font-size:.9rem;font-weight:500}.add-product-form{gap:.5rem;margin-top:1rem;display:flex}.add-product-input{flex:1;padding:.5rem .875rem;font-size:.875rem}.empty-state{text-align:center;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;padding:3rem;display:flex}.app-loading{min-height:100vh;color:var(--text-muted);justify-content:center;align-items:center;font-size:1rem;display:flex}.empty-icon{color:var(--text-muted);opacity:.5;margin-bottom:1rem;font-size:2.5rem}.filter-bar{border-radius:var(--border-radius-lg);margin-bottom:2rem;padding:1.5rem}.filter-actions{grid-column:span 1;gap:.5rem;height:42px;display:flex}.category-comparison-grid{grid-template-columns:1fr 1fr;gap:2rem;display:grid}.report-summary-bar{grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-bottom:2rem;display:grid}.summary-item{border-radius:var(--border-radius-md);text-align:center;padding:1.25rem}.summary-item-label{text-transform:uppercase;color:var(--text-secondary);margin-bottom:.375rem;font-size:.8rem;font-weight:600}.summary-item-value{font-size:1.5rem;font-weight:800}.table-responsive{width:100%;overflow-x:auto}.reports-table{border-collapse:collapse;text-align:left;width:100%}.reports-table th{color:var(--text-secondary);border-bottom:2px solid var(--card-border);background:#ffffff03;padding:1rem;font-size:.875rem;font-weight:600}.reports-table td{border-bottom:1px solid var(--card-border);padding:1rem;font-size:.9rem}.reports-table tr:hover td{background:#ffffff05}.badge{text-transform:uppercase;border-radius:6px;padding:4px 8px;font-size:.75rem;font-weight:600;display:inline-block}.badge.expense{background:var(--expense-bg-light);color:var(--expense-color)}.badge.gain{background:var(--gain-bg-light);color:var(--gain-color)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.animate-fade-in{animation:.4s cubic-bezier(.16,1,.3,1) forwards fadeIn}select.form-input{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%2394a3b8' stroke-width='2'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' d='M19.5 8.25l-7.5 7.5-7.5-7.5'/%3E%3C/svg%3E");background-position:right 1rem center;background-repeat:no-repeat;background-size:1rem;padding-right:2.5rem}.auth-page{background:var(--bg-primary);justify-content:center;align-items:center;min-height:100vh;padding:2rem;display:flex;position:relative;overflow:hidden}.auth-page:before{content:"";pointer-events:none;background:radial-gradient(circle,#6366f11f 0%,#0000 70%);border-radius:50%;width:500px;height:500px;position:absolute;top:-100px;right:-100px}.auth-page:after{content:"";pointer-events:none;background:radial-gradient(circle,#a855f714 0%,#0000 70%);border-radius:50%;width:400px;height:400px;position:absolute;bottom:-80px;left:-80px}.auth-card{border-radius:var(--border-radius-xl);z-index:1;width:100%;max-width:440px;padding:2.5rem}.auth-logo{text-align:center;margin-bottom:2.5rem}.auth-logo-icon{background:var(--accent-gradient);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:64px;height:64px;margin-bottom:1rem;display:inline-flex;box-shadow:0 8px 32px #6366f14d}.auth-logo-text{letter-spacing:-.03em;background:var(--accent-gradient);-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin-bottom:.5rem;font-size:2rem;font-weight:800}.auth-subtitle{color:var(--text-secondary);font-size:.95rem}.auth-form{flex-direction:column;gap:1.25rem;display:flex}.auth-error{border-radius:var(--border-radius-md);background:var(--expense-bg-light);color:var(--expense-color);border:1px solid #f43f5e33;padding:.75rem 1rem;font-size:.875rem;font-weight:500}.auth-success{border-radius:var(--border-radius-md);background:var(--gain-bg-light);color:var(--gain-color);border:1px solid #10b98133;padding:.75rem 1rem;font-size:.875rem;font-weight:500}.password-wrapper{align-items:center;display:flex;position:relative}.password-wrapper .form-input{width:100%;padding-right:3rem}.password-toggle{cursor:pointer;color:var(--text-muted);transition:var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;padding:.25rem;display:flex;position:absolute;right:.75rem}.password-toggle:hover{color:var(--text-secondary)}.auth-btn{width:100%;margin-top:.5rem;padding:1rem;font-size:1rem}.auth-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.auth-footer{text-align:center;color:var(--text-muted);justify-content:center;gap:.5rem;margin-top:2rem;font-size:.9rem;display:flex}.auth-link{color:var(--accent-color);transition:var(--transition-fast);font-weight:600;text-decoration:none}.auth-link:hover{color:#a855f7;text-decoration:underline}.mobile-header,.sidebar-overlay,.sidebar-close-btn{display:none}@media (max-width:768px){.mobile-header{-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--card-border);z-index:90;background:#0b0f17f2;align-items:center;gap:1rem;height:56px;padding:0 1rem;display:flex;position:fixed;top:0;left:0;right:0}.mobile-menu-btn{border:1px solid var(--card-border);border-radius:var(--border-radius-md);width:40px;height:40px;color:var(--text-primary);cursor:pointer;transition:var(--transition-fast);background:#ffffff0d;justify-content:center;align-items:center;display:flex}.mobile-menu-btn:hover{border-color:var(--card-hover-border);background:#ffffff14}.mobile-header-brand{letter-spacing:-.025em;background:var(--accent-gradient);-webkit-text-fill-color:transparent;-webkit-background-clip:text;align-items:center;gap:.5rem;font-size:1.125rem;font-weight:800;display:flex}.sidebar-overlay{z-index:150;opacity:0;visibility:hidden;pointer-events:none;background:#0009;transition:opacity .2s,visibility .2s;display:block;position:fixed;inset:0}.app-container[data-menu-open] .sidebar-overlay{opacity:1;visibility:visible;pointer-events:auto}.sidebar{z-index:200;width:min(280px,85vw);padding:1.5rem 1.25rem;transition:transform .3s cubic-bezier(.4,0,.2,1);transform:translate(-100%)}.app-container[data-menu-open] .sidebar{transform:translate(0)}.sidebar-close-btn{border:1px solid var(--card-border);border-radius:var(--border-radius-sm);width:36px;height:36px;color:var(--text-secondary);cursor:pointer;transition:var(--transition-fast);background:#ffffff0d;justify-content:center;align-items:center;margin-left:auto;display:flex}.sidebar-close-btn:hover{color:var(--text-primary);background:#ffffff14}.logo-container{margin-bottom:2rem}.main-content{width:100%;max-width:100%;margin-left:0;padding:4.5rem 1rem 1.5rem}.page-header{margin-bottom:1.5rem}.page-title{font-size:1.5rem}.page-subtitle{font-size:.9rem}.kpi-grid{grid-template-columns:1fr;gap:1rem;margin-bottom:1.5rem}.kpi-card{padding:1.25rem}.kpi-value{font-size:1.625rem}.dashboard-grid{gap:1rem;margin-bottom:1.5rem}.dashboard-card{padding:1.25rem}.card-title{flex-wrap:wrap;font-size:1.05rem}.chart-container{gap:.5rem;height:200px;padding-bottom:.5rem;overflow-x:auto}.chart-bar-wrapper{min-width:36px}.chart-bar{width:10px}.chart-label{font-size:.65rem}.transaction-item{flex-direction:column;align-items:flex-start;gap:.75rem;padding:.875rem}.trans-meta-group{justify-content:space-between;gap:.75rem;width:100%}.trans-title{word-break:break-word;font-size:.875rem}.form-card{padding:1.25rem}.form-title{font-size:1.15rem}.form-grid{grid-template-columns:1fr;gap:1rem}.report-summary-bar{grid-template-columns:1fr;gap:.75rem}.summary-item-value{font-size:1.25rem}.filter-bar{padding:1rem}.filter-actions{flex-wrap:wrap;height:auto}.category-comparison-grid{grid-template-columns:1fr;gap:1.5rem}.category-selector-panel{padding:1rem!important}.category-setup-card{padding:1.25rem}.category-setup-header{flex-direction:column;align-items:flex-start;gap:.75rem}.add-product-form{flex-direction:column}.product-item{flex-direction:column;align-items:flex-start;gap:.5rem}.footer-info{flex:1;min-width:0}.footer-title,.footer-subtitle{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.auth-page{padding:1rem}.auth-card{padding:1.75rem 1.25rem}.auth-logo-text{font-size:1.625rem}}@media (max-width:480px){.main-content{padding:4.25rem .75rem 1.25rem}.kpi-icon-wrapper{width:40px;height:40px}.kpi-icon-wrapper svg{width:18px;height:18px}.trans-info-group{gap:.75rem;width:100%}.trans-icon-box{flex-shrink:0;width:36px;height:36px}.trans-amount{font-size:.95rem}.reports-table th,.reports-table td{padding:.75rem .5rem;font-size:.8rem}.filter-actions{flex-direction:column}.filter-actions .btn-primary,.filter-actions .btn-secondary{width:100%;flex:none!important}}
