:root{--primary-50: #eff6ff;--primary-100: #dbeafe;--primary-200: #bfdbfe;--primary-300: #93c5fd;--primary-400: #60a5fa;--primary-500: #3b82f6;--primary-600: #2563eb;--primary-700: #1d4ed8;--surface-0: #ffffff;--surface-50: #f8fafc;--surface-100: #f1f5f9;--surface-200: #e2e8f0;--surface-300: #cbd5e1;--surface-400: #94a3b8;--surface-500: #64748b;--surface-600: #475569;--surface-700: #334155;--surface-800: #1e293b;--surface-900: #0f172a;--success: #10b981;--success-bg: #d1fae5;--danger: #ef4444;--danger-bg: #fee2e2;--warning: #f59e0b;--warning-bg: #fef3c7;--info: #3b82f6;--info-bg: #dbeafe;--glass-bg: rgba(255, 255, 255, .7);--glass-border: rgba(255, 255, 255, .5);--glass-shadow: 0 8px 32px 0 rgba(31, 38, 135, .07);--overlay: rgba(15, 23, 42, .6);--blur-md: blur(12px);--blur-lg: blur(16px);--font-main: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--font-thai: "Prompt", sans-serif;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 1.875rem;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--touch-target: 48px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 20px;--radius-xl: 24px;--radius-full: 9999px;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}body{font-family:var(--font-thai),var(--font-main);background:var(--surface-50);background-image:radial-gradient(at 0% 0%,rgba(59,130,246,.05) 0px,transparent 50%),radial-gradient(at 100% 0%,rgba(16,185,129,.05) 0px,transparent 50%);background-attachment:fixed;color:var(--surface-900);line-height:1.6;-webkit-font-smoothing:antialiased;min-height:100vh}h1,h2,h3,h4,h5,h6{font-weight:600;letter-spacing:-.02em;color:var(--surface-900);line-height:1.2}.text-gradient{background:linear-gradient(135deg,var(--primary-600) 0%,var(--primary-400) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.text-sub{color:var(--surface-500);font-size:var(--text-sm)}.text-xs{font-size:var(--text-xs)}.text-sm{font-size:var(--text-sm)}.text-lg{font-size:var(--text-lg)}.text-xl{font-size:var(--text-xl)}.font-bold{font-weight:600}.text-success{color:var(--success)}.text-danger{color:var(--danger)}.text-warning{color:var(--warning)}.container{width:100%;max-width:1200px;margin:0 auto;padding:0 var(--space-4)}.grid-auto{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:var(--space-4)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-2{gap:var(--space-2)}.gap-4{gap:var(--space-4)}.mt-2{margin-top:var(--space-2)}.mt-4{margin-top:var(--space-4)}.mb-2{margin-bottom:var(--space-2)}.mb-4{margin-bottom:var(--space-4)}.p-4{padding:var(--space-4)}.card{background:var(--glass-bg);backdrop-filter:var(--blur-md);-webkit-backdrop-filter:var(--blur-md);border:1px solid var(--surface-100);border-top:1px solid var(--surface-0);border-radius:var(--radius-lg);padding:var(--space-4);box-shadow:var(--shadow-sm);transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);border-color:var(--primary-200)}.card:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;border-radius:var(--radius-lg);background:linear-gradient(135deg,rgba(255,255,255,.4) 0%,transparent 100%);opacity:0;transition:opacity .3s ease;pointer-events:none}.card:hover:after{opacity:1}.menu-card{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;text-decoration:none;color:var(--surface-900);min-height:160px;cursor:pointer}.menu-card .icon{font-size:3rem;margin-bottom:var(--space-3);filter:drop-shadow(0 4px 6px rgba(0,0,0,.1));transition:transform .3s cubic-bezier(.34,1.56,.64,1)}.menu-card:hover .icon{transform:scale(1.1) rotate(5deg)}.menu-card .title{font-weight:600;font-size:var(--text-lg);margin-bottom:var(--space-1)}.menu-card .desc{font-size:var(--text-sm);color:var(--surface-500);line-height:1.4}.btn{display:inline-flex;align-items:center;justify-content:center;height:var(--touch-target);padding:0 var(--space-6);font-family:var(--font-thai);font-weight:500;font-size:var(--text-base);border-radius:var(--radius-full);border:none;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);gap:var(--space-2);-webkit-user-select:none;user-select:none}.btn:active{transform:scale(.96)}.btn-primary{background:linear-gradient(135deg,var(--primary-600),var(--primary-500));color:#fff;box-shadow:0 4px 12px #2563eb4d}.btn-primary:hover{box-shadow:0 6px 16px #2563eb66;filter:brightness(1.05)}.btn-secondary,.btn-outline{background:transparent;border:1px solid var(--surface-200);color:var(--surface-600)}.btn-secondary:hover,.btn-outline:hover{background:var(--surface-50);border-color:var(--surface-300);color:var(--surface-900)}.btn-ghost{background:transparent;color:var(--surface-500);padding:0 var(--space-3)}.btn-ghost:hover{background:var(--surface-100);color:var(--primary-600)}.btn-sm{height:36px;padding:0 var(--space-3);font-size:var(--text-sm)}.input{width:100%;height:var(--touch-target);padding:0 var(--space-4);background:var(--surface-0);border:1px solid var(--surface-200);border-radius:var(--radius-md);font-family:var(--font-thai);font-size:var(--text-base);color:var(--surface-900);transition:all .2s ease;box-shadow:var(--shadow-sm)}.input:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 4px var(--primary-100)}.input::placeholder{color:var(--surface-400)}.badge{display:inline-flex;align-items:center;padding:2px 10px;border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:600;line-height:1.4}.badge-success{background:var(--success-bg);color:var(--success)}.badge-warning{background:var(--warning-bg);color:var(--warning)}.badge-danger{background:var(--danger-bg);color:var(--danger)}.badge-info{background:var(--info-bg);color:var(--info)}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#0f172a66;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:none;align-items:center;justify-content:center;opacity:0;transition:opacity .3s ease}.modal-overlay.active,.modal-overlay.show{display:flex!important;opacity:1!important}.modal-content{background:var(--surface-0);width:90%;max-width:500px;max-height:90vh;overflow-y:auto;border-radius:var(--radius-xl);padding:var(--space-6);box-shadow:var(--shadow-xl);animation:modalSlideUp .3s cubic-bezier(.16,1,.3,1)}.table-container{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:var(--radius-md);border:1px solid var(--surface-200)}table{width:100%;border-collapse:collapse;font-size:var(--text-sm)}th{background:var(--surface-50);color:var(--surface-500);font-weight:600;text-align:left;padding:var(--space-3);border-bottom:1px solid var(--surface-200);white-space:nowrap}td{padding:var(--space-3);border-bottom:1px solid var(--surface-100);color:var(--surface-700)}tr:last-child td{border-bottom:none}tr:hover td{background:var(--surface-50)}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.skeleton-box{background:linear-gradient(90deg,var(--surface-100) 25%,var(--surface-200) 50%,var(--surface-100) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite linear;border-radius:var(--radius-sm)}.skeleton-text{height:14px;margin-bottom:6px;border-radius:4px;width:100%}.skeleton-title{height:20px;width:60%;margin-bottom:12px}.skeleton-avatar{width:40px;height:40px;border-radius:50%}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-10) var(--space-4);text-align:center;color:var(--surface-500)}.empty-state-icon{font-size:3rem;color:var(--surface-300);margin-bottom:var(--space-4)}.empty-state-title{font-size:var(--text-lg);font-weight:600;color:var(--surface-700);margin-bottom:var(--space-2)}.empty-state-desc{font-size:var(--text-sm);max-width:320px}.dropdown{position:relative;display:inline-block}.dropdown-btn{background:transparent;border:none;color:var(--surface-500);padding:var(--space-2);border-radius:var(--radius-full);cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.dropdown-btn:hover,.dropdown-btn:focus{background:var(--surface-100);color:var(--surface-900)}.dropdown-menu{position:absolute;right:0;top:calc(100% + 4px);background:var(--surface-0);min-width:140px;box-shadow:var(--shadow-xl);border-radius:var(--radius-md);border:1px solid var(--surface-200);z-index:100;padding:var(--space-1);opacity:0;visibility:hidden;transform:translateY(-5px);transition:all .2s cubic-bezier(.16,1,.3,1)}.dropdown.active .dropdown-menu{opacity:1;visibility:visible;transform:translateY(0)}.dropdown-item{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);color:var(--surface-700);text-decoration:none;border-radius:var(--radius-sm);transition:background .2s ease;cursor:pointer;background:transparent;border:none;width:100%;text-align:left;font-family:inherit;font-size:var(--text-sm)}.dropdown-item:hover{background:var(--surface-50);color:var(--primary-600)}.dropdown-item.danger:hover{background:var(--danger-bg);color:var(--danger)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.animate-fade-in{animation:fadeIn .4s ease-out}.animate-slide-up{animation:slideUp .5s cubic-bezier(.16,1,.3,1)}.timeline-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#0f172a66;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:9998;opacity:0;visibility:hidden;transition:all .3s ease}.timeline-overlay.active{opacity:1;visibility:visible}.timeline-drawer{position:fixed;top:0;right:-100%;width:100%;max-width:480px;height:100%;background:var(--surface-0);z-index:9999;box-shadow:-4px 0 24px #0000001a;transition:right .3s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column}.timeline-drawer.active{right:0}.timeline-header{padding:var(--space-4);border-bottom:1px solid var(--surface-200);display:flex;justify-content:space-between;align-items:center;background:var(--surface-50)}.timeline-header h3{margin:0;font-size:var(--text-lg);display:flex;align-items:center;gap:var(--space-2)}.timeline-close{background:transparent;border:none;font-size:1.5rem;color:var(--surface-500);cursor:pointer;padding:4px;border-radius:var(--radius-md);transition:background .2s}.timeline-close:hover{background:var(--surface-200);color:var(--surface-900)}.timeline-content{padding:var(--space-4);flex:1;overflow-y:auto}.timeline-feed{position:relative;padding-left:24px}.timeline-feed:before{content:"";position:absolute;left:7px;top:0;bottom:0;width:2px;background:var(--surface-200)}.timeline-item{position:relative;margin-bottom:var(--space-6);opacity:0;transform:translateY(10px);animation:slideUpFade .4s forwards}@keyframes slideUpFade{to{opacity:1;transform:translateY(0)}}.timeline-item:before{content:"";position:absolute;left:-24px;top:4px;width:16px;height:16px;border-radius:50%;background:var(--primary-500);border:3px solid var(--surface-0);box-shadow:0 0 0 1px var(--surface-200);z-index:1}.timeline-date{font-size:var(--text-xs);color:var(--surface-500);margin-bottom:var(--space-1);font-weight:500}.timeline-card{background:var(--surface-0);border:1px solid var(--surface-200);border-radius:var(--radius-md);padding:var(--space-3);box-shadow:var(--shadow-sm)}.timeline-card-title{font-size:var(--text-sm);font-weight:600;margin-bottom:var(--space-2);display:flex;justify-content:space-between}.timeline-card-amount{color:var(--success);font-weight:700}.timeline-card p{margin:0;font-size:var(--text-xs);color:var(--surface-600);line-height:1.5}.timeline-item.expense:before{background:var(--danger)}.timeline-item.expense .timeline-card-amount{color:var(--danger)}@media(max-width:768px){:root{--space-4: .875rem}body{padding-bottom:var(--space-10)}.container{padding:0 var(--space-4)}h1{font-size:1.75rem}.grid-auto{grid-template-columns:1fr}.card{padding:var(--space-4)}.table-mobile-card{display:block}.table-mobile-card thead{display:none}.table-mobile-card tr{display:block;background:var(--surface-0);border:1px solid var(--surface-200);border-radius:var(--radius-md);margin-bottom:var(--space-3);padding:var(--space-3);box-shadow:var(--shadow-sm)}.table-mobile-card td{display:flex;justify-content:space-between;padding:var(--space-2) 0;border-bottom:1px solid var(--surface-50)}.table-mobile-card td:last-child{border-bottom:none}.table-mobile-card td:before{content:attr(data-label);font-weight:600;color:var(--surface-500);font-size:var(--text-xs);text-transform:uppercase;margin-right:var(--space-4)}}
