:root{--font-primary:"Sarabun", "Outfit", system-ui, -apple-system, sans-serif;--bg-primary:#0b0f19;--bg-secondary:#131926;--bg-tertiary:#1b2336;--card-bg:#131926b3;--card-border:#ffffff14;--text-primary:#f3f4f6;--text-secondary:#9ca3af;--text-muted:#6b7280;--color-primary:#6366f1;--color-primary-glow:#6366f126;--color-primary-hover:#4f46e5;--color-income:#10b981;--color-income-glow:#10b98126;--color-expense:#ef4444;--color-expense-glow:#ef444426;--color-balance:#06b6d4;--color-balance-glow:#06b6d426;--shadow-sm:0 2px 4px #0000001a;--shadow-md:0 10px 15px -3px #0000004d, 0 4px 6px -4px #0000004d;--shadow-lg:0 20px 25px -5px #00000080, 0 8px 10px -6px #00000080;--shadow-glow:0 0 20px #6366f133;--radius-sm:8px;--radius-md:12px;--radius-lg:20px;--transition:all .3s cubic-bezier(.4, 0, .2, 1)}body.light-theme{--bg-primary:#f8fafc;--bg-secondary:#fff;--bg-tertiary:#f1f5f9;--card-bg:#ffffffd9;--card-border:#00000014;--text-primary:#0f172a;--text-secondary:#475569;--text-muted:#94a3b8;--color-primary:#4f46e5;--color-primary-glow:#4f46e51a;--color-primary-hover:#3730a3;--color-income:#059669;--color-income-glow:#0596691a;--color-expense:#dc2626;--color-expense-glow:#dc26261a;--color-balance:#0891b2;--color-balance-glow:#0891b21a;--shadow-sm:0 1px 3px #0000000d;--shadow-md:0 4px 6px -1px #0000000d, 0 2px 4px -2px #0000000d;--shadow-lg:0 10px 15px -3px #00000014, 0 4px 6px -4px #00000014;--shadow-glow:0 0 15px #4f46e526}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-primary);background-color:var(--bg-primary);color:var(--text-primary);transition:var(--transition);background-image:radial-gradient(at 0% 0%, var(--color-primary-glow) 0, transparent 40%), radial-gradient(at 100% 100%, var(--color-balance-glow) 0, transparent 40%);background-attachment:fixed;min-height:100vh;overflow-x:hidden}.app-container{max-width:1280px;margin:0 auto;padding:2rem 1.5rem}header{border-bottom:1px solid var(--card-border);justify-content:space-between;align-items:center;margin-bottom:2.5rem;padding-bottom:1rem;display:flex}.logo-section h1{letter-spacing:-.025em;background:linear-gradient(135deg, var(--text-primary) 30%, var(--color-primary) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;font-size:1.8rem;font-weight:700}.logo-section p{color:var(--text-secondary);margin-top:.2rem;font-size:.9rem}.header-controls{align-items:center;gap:1rem;display:flex}.btn{border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition);font-size:.95rem;font-weight:500;font-family:var(--font-primary);border:1px solid #0000;align-items:center;gap:.5rem;padding:.6rem 1.2rem;display:inline-flex}.btn-primary{background-color:var(--color-primary);color:#fff}.btn-primary:hover{background-color:var(--color-primary-hover);box-shadow:var(--shadow-glow);transform:translateY(-1px)}.btn-secondary{background-color:var(--bg-tertiary);color:var(--text-primary);border-color:var(--card-border)}.btn-secondary:hover{background-color:var(--card-border)}.btn-icon{border:1px solid var(--card-border);color:var(--text-primary);cursor:pointer;width:40px;height:40px;transition:var(--transition);background:0 0;border-radius:50%;justify-content:center;align-items:center;display:flex}.btn-icon:hover{background-color:var(--bg-tertiary);transform:scale(1.05)}.summary-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;margin-bottom:2.5rem;display:grid}.summary-card{background:var(--card-bg);-webkit-backdrop-filter:blur(12px);border:1px solid var(--card-border);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);transition:var(--transition);align-items:center;gap:1.25rem;padding:1.5rem;display:flex;position:relative;overflow:hidden}.summary-card:before{content:"";background:var(--card-accent);width:4px;height:100%;position:absolute;top:0;left:0}.summary-card:hover{box-shadow:var(--shadow-md);border-color:#ffffff26;transform:translateY(-3px)}.summary-card.income{--card-accent:var(--color-income)}.summary-card.expense{--card-accent:var(--color-expense)}.summary-card.balance{--card-accent:var(--color-balance)}.card-icon-wrapper{background-color:var(--card-accent-glow);width:52px;height:52px;color:var(--card-accent);border-radius:12px;justify-content:center;align-items:center;display:flex}.summary-card.income .card-icon-wrapper{--card-accent-glow:var(--color-income-glow)}.summary-card.expense .card-icon-wrapper{--card-accent-glow:var(--color-expense-glow)}.summary-card.balance .card-icon-wrapper{--card-accent-glow:var(--color-balance-glow)}.card-info{flex-direction:column;display:flex}.card-label{color:var(--text-secondary);font-size:.9rem;font-weight:500}.card-val{letter-spacing:-.02em;margin-top:.1rem;font-size:1.6rem;font-weight:700}.dashboard-grid{grid-template-columns:2fr 1fr;gap:1.5rem;margin-bottom:2.5rem;display:grid}@media (width<=992px){.dashboard-grid{grid-template-columns:1fr}}.glass-panel{background:var(--card-bg);-webkit-backdrop-filter:blur(12px);border:1px solid var(--card-border);border-radius:var(--radius-md);box-shadow:var(--shadow-md);padding:1.5rem}.panel-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.panel-title{align-items:center;gap:.5rem;font-size:1.15rem;font-weight:600;display:flex}.chart-container{border-bottom:1px solid var(--card-border);justify-content:space-around;align-items:flex-end;height:250px;padding-top:1rem;display:flex;position:relative}.chart-bar-group{flex-direction:column;justify-content:flex-end;align-items:center;width:50px;height:100%;display:flex}.chart-bar-container{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;position:relative}.chart-bar.income{background:linear-gradient(180deg, var(--color-income), #10b98166)}.chart-bar.expense{background:linear-gradient(180deg, var(--color-expense), #ef444466)}.chart-bar:hover:after{content:attr(data-value);background-color:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--card-border);white-space:nowrap;z-index:10;border-radius:4px;padding:2px 6px;font-size:.75rem;position:absolute;top:-28px;left:50%;transform:translate(-50%)}.chart-label{color:var(--text-secondary);text-align:center;margin-top:.5rem;font-size:.75rem}.donut-chart-container{flex-direction:column;justify-content:center;align-items:center;height:250px;display:flex}.donut-legend{grid-template-columns:repeat(2,1fr);gap:.5rem 1rem;width:100%;max-height:100px;margin-top:1rem;display:grid;overflow-y:auto}.legend-item{color:var(--text-secondary);align-items:center;gap:.5rem;font-size:.8rem;display:flex}.legend-color{border-radius:50%;width:10px;height:10px}.form-group{margin-bottom:1.25rem}.form-group label{color:var(--text-secondary);margin-bottom:.4rem;font-size:.85rem;font-weight:500;display:block}.form-input,.form-select,.form-textarea{background-color:var(--bg-primary);border:1px solid var(--card-border);border-radius:var(--radius-sm);width:100%;color:var(--text-primary);font-family:var(--font-primary);transition:var(--transition);padding:.65rem .9rem;font-size:.9rem}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-glow);outline:none}.form-row{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.radio-group{grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1.25rem;display:grid}.radio-btn{border:1px solid var(--card-border);border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition);background-color:var(--bg-primary);justify-content:center;align-items:center;gap:.5rem;padding:.75rem;font-weight:600;display:flex;position:relative}.radio-btn.income-btn.active{border-color:var(--color-income);background-color:var(--color-income-glow);color:var(--color-income)}.radio-btn.expense-btn.active{border-color:var(--color-expense);background-color:var(--color-expense-glow);color:var(--color-expense)}.radio-btn input{opacity:0;cursor:pointer;position:absolute}.recent-transactions{margin-top:1.5rem}.table-responsive{border-radius:var(--radius-sm);border:1px solid var(--card-border);width:100%;overflow-x:auto}.transactions-table{border-collapse:collapse;text-align:left;width:100%;font-size:.9rem}.transactions-table th{background-color:var(--bg-tertiary);color:var(--text-secondary);border-bottom:1px solid var(--card-border);padding:.9rem 1.2rem;font-weight:600}.transactions-table td{border-bottom:1px solid var(--card-border);color:var(--text-primary);padding:.9rem 1.2rem}.transactions-table tbody tr:hover{background-color:#ffffff05}body.light-theme .transactions-table tbody tr:hover{background-color:#00000003}.badge{border-radius:9999px;align-items:center;padding:.25rem .6rem;font-size:.75rem;font-weight:600;display:inline-flex}.badge-income{background-color:var(--color-income-glow);color:var(--color-income)}.badge-expense{background-color:var(--color-expense-glow);color:var(--color-expense)}.badge-category{background-color:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--card-border)}.actions-cell{gap:.5rem;display:flex}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;background-color:#0009;justify-content:center;align-items:center;animation:.2s ease-out fadeIn;display:flex;position:fixed;inset:0}.modal-content{background-color:var(--bg-secondary);border:1px solid var(--card-border);border-radius:var(--radius-md);width:90%;max-width:500px;max-height:90vh;box-shadow:var(--shadow-lg);animation:.3s cubic-bezier(.34,1.56,.64,1) slideUp;position:relative;overflow-y:auto}.modal-header{border-bottom:1px solid var(--card-border);justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;display:flex}.modal-header h3{font-size:1.2rem;font-weight:600}.modal-body{padding:1.5rem}.scanner-container{flex-direction:column;gap:1rem;display:flex}.upload-area{border:2px dashed var(--card-border);border-radius:var(--radius-md);text-align:center;cursor:pointer;transition:var(--transition);flex-direction:column;align-items:center;gap:.75rem;padding:2rem 1.5rem;display:flex}.upload-area:hover{border-color:var(--color-primary);background-color:var(--color-primary-glow)}.preview-container{border-radius:var(--radius-sm);border:1px solid var(--card-border);width:100%;max-height:250px;position:relative;overflow:hidden}.preview-img{object-fit:contain;width:100%;height:auto;max-height:250px}.ocr-progress-bar{background-color:var(--bg-tertiary);border-radius:3px;width:100%;height:6px;margin-top:.5rem;overflow:hidden}.ocr-progress-fill{background-color:var(--color-primary);width:0%;height:100%;transition:width .3s}.ocr-status-text{color:var(--text-secondary);text-align:center;margin-top:.3rem;font-size:.8rem}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.empty-state{text-align:center;color:var(--text-secondary);flex-direction:column;align-items:center;gap:.75rem;padding:3rem 1.5rem;display:flex}.empty-state-icon{color:var(--text-muted);width:48px;height:48px}footer{text-align:center;border-top:1px solid var(--card-border);color:var(--text-muted);margin-top:4rem;padding-top:1.5rem;font-size:.8rem}@media (width<=768px){.app-container{padding:1rem .75rem}header{text-align:center;flex-direction:column;align-items:stretch;gap:1.25rem;margin-bottom:1.5rem}.header-controls{flex-direction:column;align-items:stretch;gap:.75rem;width:100%}.header-controls .btn{justify-content:center;width:100%;padding:.8rem 1.2rem;font-size:1rem}.logo-section h1{font-size:1.6rem}.summary-grid{grid-template-columns:1fr;gap:1rem;margin-bottom:1.5rem}.summary-card{padding:1.25rem}.card-val{font-size:1.5rem}.glass-panel{padding:1rem}.panel-header{flex-direction:column;align-items:flex-start;gap:.75rem}.panel-header div{flex-wrap:wrap;justify-content:flex-start;gap:.5rem;width:100%}.form-input,.form-select,.form-textarea{padding:.8rem 1rem;font-size:16px!important}.radio-btn{padding:.9rem;font-size:1rem}.btn-icon{width:44px;height:44px}.transactions-table th,.transactions-table td{padding:.75rem .5rem;font-size:.8rem}.badge{padding:.2rem .4rem;font-size:.7rem}.modal-content{width:95%;max-height:85vh;margin:10px}.modal-body{padding:1rem}.form-row{grid-template-columns:1fr;gap:0}}@media (width<=480px){.logo-section h1{font-size:1.4rem}.card-val{font-size:1.3rem}.donut-chart-container svg{width:160px;height:160px}}
