@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Noto+Sans+Lao:wght@300;400;500;600;700&display=swap";:root{--font-sans:"Noto Sans Lao", "Inter", sans-serif;--bg-app:#0f172a;--bg-card:#1e293bb3;--bg-card-hover:#1e293bf2;--border-color:#ffffff14;--text-primary:#f8fafc;--text-secondary:#94a3b8;--text-muted:#64748b;--color-income:#10b981;--color-income-rgb:16, 185, 129;--color-expense:#f43f5e;--color-expense-rgb:244, 63, 94;--color-primary:#6366f1;--color-primary-hover:#4f46e5;--color-primary-rgb:99, 102, 241;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -1px #0000000f;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -2px #0000000d;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-full:9999px;--transition-fast:.15s ease;--transition-normal:.25s cubic-bezier(.4, 0, .2, 1)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-sans);background-color:var(--bg-app);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-image:radial-gradient(circle at 10% 20%,#6366f126 0%,#0000 40%),radial-gradient(circle at 90% 80%,#10b9811a 0%,#0000 45%);background-attachment:fixed;min-height:100vh;line-height:1.5}.app-container{max-width:1280px;margin:0 auto;padding:2rem 1.5rem}.app-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;margin-bottom:2.5rem;padding-bottom:1.5rem;display:flex}.header-title-area{align-items:center;gap:.75rem;display:flex}.app-logo{background:linear-gradient(135deg, var(--color-primary), var(--color-income));border-radius:var(--radius-md);color:#fff;justify-content:center;align-items:center;width:48px;height:48px;font-size:1.5rem;font-weight:700;display:flex;box-shadow:0 0 20px #6366f14d}.header-text h1{background:linear-gradient(90deg,#fff,#c7d2fe);-webkit-text-fill-color:transparent;-webkit-background-clip:text;font-size:1.75rem;font-weight:700}.header-text p{color:var(--text-secondary);margin-top:.1rem;font-size:.875rem}.main-grid{grid-template-columns:1fr;gap:2rem;display:grid}@media (width>=1024px){.main-grid{grid-template-columns:380px 1fr}}.card{background:var(--bg-card);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);transition:transform var(--transition-normal), box-shadow var(--transition-normal), border-color var(--transition-normal);padding:1.75rem}.card:hover{border-color:#ffffff26;box-shadow:0 20px 25px -5px #0003,0 10px 10px -5px #0000000a}.card-title{color:var(--text-primary);align-items:center;gap:.5rem;margin-bottom:1.25rem;font-size:1.15rem;font-weight:600;display:flex}.dashboard-summary{grid-template-columns:1fr;gap:1.25rem;margin-bottom:2rem;display:grid}@media (width>=640px){.dashboard-summary{grid-template-columns:repeat(3,1fr)}}.stat-card{padding:.1rem 1.25rem;position:relative;overflow:hidden}.stat-card:before{content:"";width:4px;height:100%;position:absolute;top:0;left:0}.stat-card.balance:before{background:var(--color-primary)}.stat-card.income:before{background:var(--color-income)}.stat-card.expense:before{background:var(--color-expense)}.stat-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;align-items:center;gap:.5rem;margin-bottom:.5rem;font-size:.875rem;font-weight:500;display:flex}.stat-value{letter-spacing:-.01em;margin-bottom:.1rem;font-size:1.55rem;font-weight:700}.stat-card.balance .stat-value{color:#fff}.stat-card.income .stat-value{color:var(--color-income)}.stat-card.expense .stat-value{color:var(--color-expense)}.stat-desc{color:var(--text-muted);font-size:.75rem}.form-group{margin-bottom:1.5rem}.form-label{color:var(--text-secondary);margin-bottom:.6rem;font-size:.95rem;font-weight:600;display:block}.input-control{width:100%;font-size:1.05rem;font-family:var(--font-sans);border:1px solid var(--border-color);border-radius:var(--radius-md);color:#fff;transition:all var(--transition-fast);background:#0f172a99;padding:.85rem 1.1rem}.input-control:focus{border-color:var(--color-primary);background:#0f172ad9;outline:none;box-shadow:0 0 0 3px #6366f133}.type-toggle{border-radius:var(--radius-md);border:1px solid var(--border-color);background:#0f172a66;gap:.75rem;padding:.35rem;display:flex}.btn-toggle{border-radius:var(--radius-sm);cursor:pointer;color:var(--text-secondary);transition:all var(--transition-fast);background:0 0;border:none;flex:1;justify-content:center;align-items:center;gap:.5rem;padding:.75rem;font-size:.95rem;font-weight:600;display:flex}.btn-toggle.active.income{background:var(--color-income);color:#fff;box-shadow:0 4px 12px #10b98140}.btn-toggle.active.expense{background:var(--color-expense);color:#fff;box-shadow:0 4px 12px #f43f5e40}.btn{border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);border:none;justify-content:center;align-items:center;gap:.5rem;width:100%;padding:.85rem 1.4rem;font-size:1.05rem;font-weight:600;display:inline-flex}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover{background:var(--color-primary-hover);box-shadow:0 4px 14px #6366f159}.btn-secondary{color:var(--text-primary);border:1px solid var(--border-color);background:#94a3b81a}.btn-secondary:hover{background:#94a3b833}.btn-danger{background:var(--color-expense);color:#fff}.btn-danger:hover{background:#e11d48}.btn-row{gap:.75rem;display:flex}.toolbar{flex-direction:column;gap:1rem;margin-bottom:1.5rem;display:flex}@media (width>=768px){.toolbar{flex-direction:row;justify-content:space-between;align-items:center}}.filters-wrapper{flex-wrap:wrap;align-items:center;gap:.75rem;display:flex}.search-input-wrapper{flex:1;min-width:200px;max-width:300px;position:relative}.select-filter{border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;transition:border-color var(--transition-fast);background:#0f172a80;padding:.5rem 1.5rem .5rem .75rem;font-size:.875rem}.select-filter:focus{border-color:var(--color-primary);outline:none}.table-container{border-radius:var(--radius-md);border:1px solid var(--border-color);overflow-x:auto}.table-records{border-collapse:collapse;text-align:left;width:100%;font-size:.9rem}.table-records th{color:var(--text-secondary);border-bottom:1px solid var(--border-color);text-transform:uppercase;letter-spacing:.05em;background-color:#0f172a66;padding:1rem;font-size:.75rem;font-weight:600}.table-records td{border-bottom:1px solid var(--border-color);color:var(--text-primary);padding:1rem}.table-records tr:last-child td{border-bottom:none}.table-records tr{transition:background-color var(--transition-fast)}.table-records tr:hover{background-color:#ffffff05}.badge{border-radius:var(--radius-full);align-items:center;padding:.15rem .2rem;font-size:.75rem;font-weight:600;line-height:1;display:inline-flex}.badge.income{color:var(--color-income);background:#10b9811a;border:1px solid #10b98133}.badge.expense{color:var(--color-expense);background:#f43f5e1a;border:1px solid #f43f5e33}.amount-value{font-family:Inter,Noto Sans Lao;font-weight:600}.amount-value.income{color:var(--color-income)}.amount-value.expense{color:var(--color-expense)}.action-buttons{gap:.5rem;display:flex}.btn-icon{cursor:pointer;color:var(--text-secondary);border-radius:var(--radius-sm);transition:all var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;padding:.4rem;display:flex}.btn-icon:hover{background:#ffffff0d}.btn-icon.edit:hover{color:var(--color-primary)}.btn-icon.delete:hover{color:var(--color-expense)}.btn-export{color:#a5b4fc;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);background:#6366f126;border:1px solid #6366f14d;align-items:center;gap:.35rem;padding:.5rem 1rem;font-size:.85rem;font-weight:600;display:flex}.btn-export:hover{color:#fff;background:#6366f140;border-color:#6366f180}.chart-container{flex-direction:column;justify-content:center;align-items:center;padding:1rem 0;display:flex}@media (width>=768px){.chart-container{flex-direction:row;gap:2rem}}.chart-svg-wrapper{width:200px;height:200px;position:relative}.chart-details{flex:1;width:100%}.chart-legend-item{border-bottom:1px solid #ffffff0d;justify-content:space-between;align-items:center;padding:.5rem 0;font-size:.85rem;display:flex}.chart-legend-color{border-radius:2px;width:10px;height:10px;margin-right:.5rem}.chart-label-text{color:var(--text-secondary);align-items:center;display:flex}.chart-value-text{color:var(--text-primary);font-family:Inter,Noto Sans Lao;font-weight:600}.alert-toast{border-left:4px solid var(--color-income);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:1000;background:#1e293b;align-items:center;gap:.75rem;padding:1rem 1.5rem;animation:.3s ease-out slideIn;display:flex;position:fixed;bottom:2rem;right:2rem}@keyframes slideIn{0%{opacity:0;transform:translateY(100px)}to{opacity:1;transform:translateY(0)}}.empty-state{color:var(--text-secondary);text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:3rem 1.5rem;display:flex}.empty-state-icon{color:var(--text-muted);margin-bottom:1rem}.chart-pie-segment{cursor:pointer;transition:stroke-width .2s,filter .2s}.chart-pie-segment:hover{stroke-width:22px;filter:drop-shadow(0 0 4px #ffffff1a)}.text-center-val{fill:var(--text-primary);font-family:Inter,Noto Sans Lao;font-weight:700}.text-center-lbl{fill:var(--text-secondary);font-size:9px;font-weight:500}.loading-overlay{color:var(--text-secondary);justify-content:center;align-items:center;gap:.5rem;padding:3rem;font-weight:500;display:flex}.spinner{border:3px solid #ffffff1a;border-top-color:var(--color-primary);border-radius:50%;width:24px;height:24px;animation:1s ease-in-out infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:999;background-color:#0f172ad9;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content{border:1px solid var(--border-color);border-radius:var(--radius-lg);width:100%;max-width:450px;box-shadow:var(--shadow-lg);background:#1e293b;padding:2rem}.modal-header{margin-bottom:1rem;font-size:1.25rem;font-weight:700}.modal-body{color:var(--text-secondary);margin-bottom:1.5rem;font-size:.95rem}.modal-footer{justify-content:flex-end;gap:.75rem;display:flex}@media (width<=640px){.stat-card{padding:.75rem 1rem}.stat-value{font-size:1.35rem}.stat-label{font-size:.8rem}.input-control{padding:.85rem 1.1rem;font-size:1.05rem}}
