*{margin:0;padding:0;box-sizing:border-box}body{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background:linear-gradient(135deg,#667eea,#764ba2);color:#333;padding:0;min-height:100vh}.app-container{max-width:600px;margin:0 auto;min-height:100vh;padding-bottom:80px;position:relative}.container{max-width:100%;margin:0;background:transparent;border-radius:0;box-shadow:none;padding:20px;animation:fadeIn .5s ease-in}.page{display:none;animation:fadeIn .3s ease-in}.page.active{display:block}.bottom-nav{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:600px;background:#fff;border-top:1px solid #e0e0e0;display:flex;justify-content:space-around;align-items:center;padding:8px 0;box-shadow:0 -2px 10px #0000001a;z-index:1000}.nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;background:transparent;border:none;color:#95a5a6;font-size:11px;font-weight:500;cursor:pointer;padding:8px 12px;transition:all .3s ease;min-width:60px}.nav-item svg{margin-bottom:4px;transition:all .3s ease}.nav-item:hover,.nav-item.active{color:#667eea;background:#667eea1a;border-radius:8px}.nav-item.active svg{stroke:#667eea;transform:scale(1.1)}@media (min-width: 601px){.app-container{padding-top:20px}.container{background:#fff;border-radius:16px 16px 0 0;box-shadow:0 -2px 10px #0000001a;padding:30px}}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}header{text-align:center;margin-bottom:30px}header h1{color:#2c3e50;margin-bottom:10px;font-size:28px}header p{color:#7f8c8d;font-size:14px}section{margin-bottom:25px}h2{color:#2c3e50;border-bottom:3px solid #667eea;padding-bottom:10px;margin-bottom:15px;font-size:20px}.tabs{display:flex;gap:10px;margin-bottom:20px;background:#f8f9fa;padding:5px;border-radius:10px}.tab-btn{flex:1;background:transparent;color:#6c757d;padding:12px 20px;border:none;border-radius:8px;cursor:pointer;font-size:15px;font-weight:600;transition:all .3s ease;position:relative;overflow:hidden}.tab-btn:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,#667eea,#764ba2);opacity:0;transition:opacity .3s ease;z-index:-1}.tab-btn:hover{color:#495057;background:#667eea1a}.tab-btn.active{color:#fff;background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 4px 12px #667eea66}.tab-btn.active:before{opacity:1}.history-tabs{margin-top:15px}.tab-content{display:none;animation:slideIn .3s ease-out}.tab-content.active{display:block}@keyframes slideIn{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}.input-section{background:#f8f9fa;padding:20px;border-radius:12px;margin-bottom:20px}.tab-content h2{margin-top:0}input[type=text],input[type=number],input[type=date]{width:100%;padding:12px;margin:8px 0;border:2px solid #e0e0e0;border-radius:8px;font-size:16px;transition:border-color .3s}input[type=text]:focus,input[type=number]:focus,input[type=date]:focus{outline:none;border-color:#667eea}input.error{border-color:#e74c3c}button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:12px 20px;border-radius:8px;cursor:pointer;font-size:16px;width:100%;font-weight:600;transition:transform .2s,box-shadow .2s}button:hover{transform:translateY(-2px);box-shadow:0 5px 15px #667eea66}button:active{transform:translateY(0)}button:disabled{opacity:.6;cursor:not-allowed;transform:none}.form-message{padding:12px;border-radius:8px;margin-bottom:15px;font-weight:500;animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.form-message.success{background:#d4edda;color:#155724;border:1px solid #c3e6cb}.form-message.error{background:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.field-error{color:#e74c3c;font-size:12px;margin-top:5px;animation:shake .5s}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}.summary-section{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:25px;border-radius:12px;margin-bottom:25px}.summary-section h2{color:#fff;border-bottom-color:#ffffff4d}#summary{display:grid;gap:15px}.summary-card{background:#ffffff26;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:20px;border-radius:12px;display:flex;justify-content:space-between;align-items:center;transition:all .3s ease;border:2px solid rgba(255,255,255,.2)}.summary-card:hover{transform:translateY(-2px);box-shadow:0 6px 20px #00000026;border-color:#ffffff4d}.summary-label{font-weight:600;color:#ffffffe6;font-size:15px}.summary-value{font-weight:700;font-size:18px}.summary-value.expense{color:gold}.summary-value.planning{color:#87ceeb}.summary-value.balance{color:#90ee90}.balance-positive{color:#90ee90!important}.balance-neutral{color:gold!important}.balance-negative{color:#ff6b6b!important}ul{list-style:none}.expense-item,.planning-item{padding:16px;border-bottom:1px solid #eee;display:flex;justify-content:space-between;align-items:center;transition:background .2s;animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}.expense-item:hover,.planning-item:hover{background:#f8f9fa}.expense-item:last-child,.planning-item:last-child{border-bottom:none}.expense-item-content,.planning-item-content{flex:1}.expense-item-name,.planning-item-name{font-weight:600;color:#2c3e50;margin-bottom:6px}.expense-item-details,.planning-item-details{display:flex;gap:15px;font-size:14px}.expense-item-amount,.planning-item-amount{color:#667eea;font-weight:600}.expense-item-date,.planning-item-date{color:#95a5a6}.expense-item-delete,.planning-item-delete{background:#e74c3c;color:#fff;border:none;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:14px;width:auto;transition:background .2s}.expense-item-delete:hover,.planning-item-delete:hover{background:#c0392b}.empty-state{text-align:center;padding:40px 20px;color:#95a5a6;display:flex;flex-direction:column;align-items:center;gap:15px}.empty-state svg{opacity:.5}.empty-state p{font-size:15px;font-weight:500;font-style:italic}.empty-state:not(:has(~*)){display:flex}.empty-state:has(+ul:not(:empty)){display:none}.loading-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#ffffffe6;display:flex;justify-content:center;align-items:center;z-index:9999}.loading-spinner{width:50px;height:50px;border:5px solid #f3f3f3;border-top:5px solid #667eea;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.report-section{margin-bottom:30px;animation:fadeIn .5s ease-in}.report-section h2{color:#2c3e50;border-bottom:3px solid #667eea;padding-bottom:10px;margin-bottom:20px}.category-card{background:#fff;border-radius:12px;padding:20px;margin-bottom:15px;box-shadow:0 2px 8px #0000001a;transition:transform .2s,box-shadow .2s;border:2px solid #e0e0e0}.category-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #00000026}.category-card.uncategorized{border-color:#95a5a6;background:#f8f9fa}.category-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.category-name{font-size:18px;font-weight:600;color:#2c3e50;margin:0}.category-percentage{font-size:20px;font-weight:700;padding:6px 12px;border-radius:8px}.category-percentage.good{color:#2ecc71;background:#d4edda}.category-percentage.warning{color:#f39c12;background:#fff3cd}.category-percentage.danger{color:#e74c3c;background:#f8d7da}.category-count{font-size:14px;color:#7f8c8d;font-weight:500}.category-card-details{display:flex;flex-direction:column;gap:10px;margin-bottom:15px}.detail-row{display:flex;justify-content:space-between;align-items:center}.detail-label{font-weight:500;color:#7f8c8d}.detail-value{font-weight:600;color:#2c3e50}.detail-value.positive{color:#2ecc71}.detail-value.negative{color:#e74c3c}.progress-container{width:100%;height:8px;background:#e0e0e0;border-radius:4px;overflow:hidden}.progress-bar{height:100%;transition:width .5s ease-in-out;border-radius:4px}.progress-bar.good{background:linear-gradient(90deg,#2ecc71,#27ae60)}.progress-bar.warning{background:linear-gradient(90deg,#f39c12,#e67e22)}.progress-bar.danger{background:linear-gradient(90deg,#e74c3c,#c0392b)}.progress-bar.over-budget{position:relative}.progress-bar.over-budget:after{content:"⚠️";position:absolute;right:-25px;top:50%;transform:translateY(-50%);font-size:16px}.no-categories-message{text-align:center;padding:40px 20px;color:#95a5a6;font-style:italic;background:#f8f9fa;border-radius:12px;border:2px dashed #dee2e6}.report-error{background:#f8d7da;color:#721c24;padding:15px;border-radius:8px;margin-bottom:15px;text-align:center;font-weight:500}.category-badge{display:inline-block;padding:4px 10px;margin-left:10px;border-radius:12px;font-size:12px;font-weight:600;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;white-space:nowrap}.category-badge.uncategorized{background:#95a5a6;color:#fff}select{width:100%;padding:12px;margin:8px 0;border:2px solid #e0e0e0;border-radius:8px;font-size:16px;transition:border-color .3s;background:#fff;cursor:pointer}select:focus{outline:none;border-color:#667eea}select.error{border-color:#e74c3c}label{display:block;margin-top:15px;margin-bottom:5px;font-weight:600;color:#2c3e50;font-size:14px}body.loading .loading-overlay{display:flex!important}.app-error{background:#f8d7da;color:#721c24;border:1px solid #f5c6cb;padding:15px;border-radius:8px;margin-bottom:20px;animation:slideDown .3s ease-out}@media (max-width: 480px){.app-container{padding-bottom:70px}.container{padding:15px}.bottom-nav{padding:6px 0}.nav-item{padding:6px 8px;min-width:50px;font-size:10px}.nav-item svg{width:20px;height:20px}header h1{font-size:24px}header p{font-size:13px}h2{font-size:18px}input,button{padding:10px;font-size:14px}.expense-item,.planning-item{flex-direction:column;align-items:flex-start;gap:10px}.expense-item-delete,.planning-item-delete{width:100%}.summary-section{padding:20px}#summary p{font-size:14px}#summary span{font-size:16px}}@media (min-width: 481px){.container{background:#fff;border-radius:16px;box-shadow:0 10px 40px #0000001a;padding:30px;margin:20px}.bottom-nav{border-radius:0 0 16px 16px}}@media print{body{background:#fff}.container{box-shadow:none}.input-section,.planning-section,button{display:none}}
