:root{--primary:#f97316;--primary-hover:#ea580c;--primary-light:#ffedd5;--secondary:#f59e0b;--accent-1:#fbbf24;--accent-2:#fb923c;--danger:#ef4444;--success:#10b981;--bg-body:#fff7ed;--bg-card:#fff;--bg-gradient:linear-gradient(135deg,#fff7ed 0%,#ffedd5 100%);--text-main:#2a1205;--text-muted:#7c2d12;--text-light:#9a3412;--shadow-sm:0 1px 2px 0 #f973160d;--shadow-md:0 4px 6px -1px #f973161a,0 2px 4px -2px #f973160f;--shadow-lg:0 10px 15px -3px #f973161a,0 4px 6px -4px #f973160d;--shadow-xl:0 20px 25px -5px #f973161a,0 10px 10px -5px #f973160a;--shadow-2xl:0 25px 50px -12px #f9731640;--radius:16px;--radius-lg:24px;--radius-xl:32px;--space-xs:4px;--space-sm:8px;--space-md:12px;--space-lg:16px;--space-xl:24px;--space-2xl:32px;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;font-weight:400;line-height:1.5}html{-webkit-text-size-adjust:100%}body{min-width:320px;min-height:100vh;min-height:-webkit-fill-available;color:var(--text-main);-webkit-font-smoothing:antialiased;background:linear-gradient(135deg,#ffedd5 0%,#fed7aa 100%);margin:0}#root{min-height:100vh;min-height:-webkit-fill-available}button,input,select,textarea{font-family:inherit;font-size:16px}button{touch-action:manipulation;cursor:pointer;-webkit-tap-highlight-color:transparent}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}html{scroll-behavior:smooth}body{overscroll-behavior-y:contain}@media (max-width:768px){::-webkit-scrollbar{display:none}body{-ms-overflow-style:none;scrollbar-width:none;-ms-overflow-style:none;scrollbar-width:none}}@keyframes fadeInScale{0%{opacity:0;transform:scale(.98)translateY(10px)}to{opacity:1;transform:scale(1)translateY(0)}}.page-enter{animation:.4s cubic-bezier(.16,1,.3,1) forwards fadeInScale}.login-container{min-height:100vh;background:linear-gradient(135deg,#f97316 0%,#c2410c 50%,#f59e0b 100%) 0 0/200% 200%;flex-direction:column;justify-content:center;align-items:center;min-height:100dvh;padding:20px;animation:8s infinite gradientShift;display:flex;position:relative;overflow:hidden}.login-container:before,.login-container:after{content:"";background:#ffffff1a;border-radius:50%;animation:6s ease-in-out infinite float;position:absolute}.login-container:before{width:300px;height:300px;animation-delay:0s;top:-100px;right:-100px}.login-container:after{width:200px;height:200px;animation-delay:3s;bottom:-50px;left:-50px}@keyframes gradientShift{0%,to{background-position:0%}50%{background-position:100%}}@keyframes float{0%,to{transform:translateY(0)rotate(0)}50%{transform:translateY(-20px)rotate(5deg)}}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes pulse{0%,to{box-shadow:0 0 #f9731666}50%{box-shadow:0 0 0 8px #f9731600}}.login-card{-webkit-backdrop-filter:blur(20px);z-index:1;background:#fffffff2;border-radius:28px;width:100%;max-width:400px;padding:36px 28px;animation:.5s cubic-bezier(.16,1,.3,1) slideUp;position:relative;box-shadow:0 25px 60px -12px #0006,0 0 0 1px #fff3}.login-header{text-align:center;margin-bottom:32px}.login-logo{background:linear-gradient(135deg,#f97316 0%,#c2410c 100%);border-radius:20px;justify-content:center;align-items:center;width:72px;height:72px;margin:0 auto 16px;animation:2s ease-in-out infinite pulse;display:flex;box-shadow:0 10px 30px #f9731666}.login-logo svg{color:#fff;width:40px;height:40px}.login-header h1{color:#1e293b;letter-spacing:-.5px;margin:0 0 8px;font-size:1.6rem;font-weight:800}.login-header p{color:#64748b;margin:0;font-size:.9rem;font-weight:500}.login-form{flex-direction:column;gap:20px;display:flex}.form-group{flex-direction:column;gap:8px;display:flex}.form-group label{color:#334155;align-items:center;gap:6px;font-size:.85rem;font-weight:600;display:flex}.form-group label svg{color:#f97316;width:16px;height:16px}.input-wrapper{position:relative}.input-wrapper svg{color:#94a3b8;width:20px;height:20px;transition:color .2s;position:absolute;top:50%;left:14px;transform:translateY(-50%)}.input-wrapper input:focus+svg,.input-wrapper input:focus~svg{color:#f97316}.form-group input{background:#f8fafc;border:2px solid #e2e8f0;border-radius:14px;padding:16px 16px 16px 48px;font-size:16px;font-weight:500;transition:all .3s cubic-bezier(.4,0,.2,1)}.form-group input::placeholder{color:#94a3b8}.form-group input:focus{background:#fff;border-color:#f97316;outline:none;box-shadow:0 0 0 4px #f9731626}.error-message{color:#dc2626;text-align:center;background:linear-gradient(135deg,#fee2e2 0%,#fecaca 100%);border:1px solid #fecaca;border-radius:12px;justify-content:center;align-items:center;gap:8px;padding:14px 16px;font-size:.9rem;font-weight:600;display:flex}.login-button{color:#fff;cursor:pointer;text-transform:uppercase;letter-spacing:1px;background:linear-gradient(135deg,#f97316 0%,#c2410c 100%);border:none;border-radius:14px;justify-content:center;align-items:center;gap:8px;min-height:56px;margin-top:8px;padding:18px;font-size:1rem;font-weight:700;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;box-shadow:0 8px 24px #f9731666}.login-button svg{width:20px;height:20px}.login-button:hover:not(:disabled){transform:translateY(-3px);box-shadow:0 12px 32px #f9731680}.login-button:active:not(:disabled){transform:translateY(-1px)}.login-button:disabled{opacity:.7;cursor:not-allowed;transform:none}.login-footer{text-align:center;color:#fff;opacity:.9;margin-top:24px;font-size:.85rem}.spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:20px;height:20px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}@media (min-width:480px){.login-card{padding:48px 40px}.login-header h1{font-size:1.875rem}.login-logo{border-radius:24px;width:80px;height:80px}.login-logo svg{width:44px;height:44px}}.dashboard-container{min-height:100vh;background:var(--bg-body);min-height:-webkit-fill-available;padding-bottom:calc(70px + env(safe-area-inset-bottom));background-image:radial-gradient(at 0 0,#fdd5b44d 0,#0000 50%),radial-gradient(at 100% 0,#fde1b44d 0,#0000 50%)}.desktop-only,.navbar-right{display:none}@media (min-width:768px){.mobile-only{display:none!important}.desktop-only,.navbar-right{display:flex!important}}.btn-export-mobile{background:var(--primary);color:#fff;padding:var(--space-sm)var(--space-md);cursor:pointer;border:none;border-radius:8px;font-size:1.1rem;transition:all .2s}.navbar{padding:var(--space-md)var(--space-lg);z-index:100;justify-content:space-between;align-items:center;gap:var(--space-sm);background:#fff;display:flex;position:sticky;top:0;box-shadow:0 2px 8px #0000001a}.navbar h2{color:var(--primary-hover);letter-spacing:-.5px;margin:0;font-size:1.25rem;font-weight:800}.btn-categories,.btn-export{background:var(--primary);color:#fff;padding:var(--space-sm)var(--space-md);cursor:pointer;white-space:nowrap;border:none;border-radius:8px;font-size:.85rem;font-weight:600;transition:all .2s}.btn-categories:hover,.btn-export:hover{background:var(--primary-hover);transform:translateY(-1px)}.content{max-width:1200px;padding:var(--space-lg);margin:0 auto}.dashboard-grid{flex-direction:column;gap:24px;display:flex}@media (min-width:1024px){.dashboard-grid{grid-template-columns:400px 1fr;align-items:start;gap:32px;display:grid}.dashboard-left{flex-direction:column;gap:24px;display:flex}.dashboard-right{flex-direction:column;gap:24px;min-width:0;display:flex}.summary-cards{grid-template-columns:1fr!important;gap:16px!important}}.btn-privacy-toggle{cursor:pointer;opacity:.7;background:0 0;border:none;justify-content:center;align-items:center;padding:4px;font-size:1.2rem;transition:opacity .2s;display:flex}.btn-privacy-toggle:hover{opacity:1;transform:scale(1.1)}.balance-amount.blurred{filter:blur(8px);-webkit-user-select:none;user-select:none;opacity:.8}.balance-section{gap:var(--space-lg);margin-bottom:var(--space-xl);flex-direction:column;display:flex}.balance-card{border-radius:var(--radius-lg);padding:var(--space-xl);color:#fff;background:linear-gradient(135deg,#f97316 0%,#c2410c 100%);position:relative;overflow:hidden;box-shadow:0 20px 25px -5px #f9731640,0 8px 10px -6px #f973161a}.balance-card:before{content:"";pointer-events:none;background:radial-gradient(circle at 100% 0,#fff3 0%,#0000 60%);position:absolute;inset:0}.balance-header{gap:var(--space-md);margin-bottom:var(--space-lg);flex-direction:column;display:flex}.balance-header h3{opacity:.9;margin:0;font-size:.9rem;font-weight:600}.balance-actions{gap:var(--space-sm);display:flex}.btn-topup,.btn-withdraw{padding:var(--space-sm)var(--space-md);cursor:pointer;text-align:center;border:none;border-radius:8px;flex:1;font-size:.8rem;font-weight:600;transition:all .2s}.btn-topup{color:#10b981;background:#fffffff2}.btn-topup:hover{background:#fff;transform:translateY(-2px)}.btn-withdraw{color:#fff;background:#fff3;border:1px solid #ffffff4d}.btn-withdraw:hover{background:#ffffff4d}.balance-amount{letter-spacing:-1px;word-break:break-all;text-shadow:0 2px 4px #0000001a;font-size:2rem;font-weight:800}.balance-history{border-radius:var(--radius-lg);padding:var(--space-lg);box-shadow:var(--shadow-md);background:#fff}.history-header{gap:var(--space-md);margin-bottom:var(--space-lg);flex-direction:column;display:flex}.balance-history h4{color:#333;margin:0;font-size:1rem}.history-filter{align-items:center;gap:var(--space-sm);flex-wrap:wrap;display:flex}.history-filter input,.history-filter select{min-width:120px;padding:var(--space-sm);background-color:#fff;border:1px solid #e2e8f0;border-radius:8px;flex:1;font-family:inherit;font-size:.85rem}.history-filter span{color:#999;font-size:.85rem}.history-list{gap:var(--space-sm);flex-direction:column;max-height:500px;display:flex;overflow-y:auto}.history-item{padding:var(--space-md);justify-content:space-between;align-items:flex-start;gap:var(--space-sm);background:#f8fafc;border-radius:8px;font-size:.85rem;display:flex}.history-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.history-type{border-radius:4px;width:fit-content;padding:2px 8px;font-size:.7rem;font-weight:600;display:inline-block}.type-topup,.type-initial{color:#059669;background:#d1fae5}.type-withdraw{color:#d97706;background:#fef3c7}.type-expense{color:#dc2626;background:#fee2e2}.type-expense_deleted{color:#c2410c;background:#ffedd5}.history-note{color:#666;word-break:break-word;font-size:.8rem}.history-details{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:2px;display:flex}.history-amount{font-size:.9rem;font-weight:600}.history-amount.positive{color:#10b981}.history-amount.negative{color:#ef4444}.category-badge{background-color:var(--primary-light);color:var(--text-dark);border:1px solid #f9731633;border-radius:20px;padding:4px 12px;font-size:.75rem;font-weight:600;display:inline-block}.history-date{color:#999;font-size:.7rem}.history-category{color:#c2410c;background:#ffedd5;border-radius:12px;padding:2px 8px;font-size:.7rem;font-weight:600}.balance-modal .form-group textarea{width:100%;padding:var(--space-md);resize:vertical;border:2px solid #e0e0e0;border-radius:8px;min-height:80px;font-family:inherit;font-size:14px}.btn-topup-submit{background:linear-gradient(135deg,#10b981 0%,#059669 100%)!important}.btn-withdraw-submit{background:linear-gradient(135deg,#f59e0b 0%,#d97706 100%)!important}.summary-cards{gap:var(--space-md);margin-bottom:var(--space-xl);grid-template-columns:1fr;display:grid}.summary-card{border-radius:var(--radius);padding:var(--space-lg);box-shadow:var(--shadow-md);align-items:center;gap:var(--space-md);background:#fff;transition:transform .2s;display:flex}.summary-card:active{transform:scale(.98)}.summary-card.today{background:linear-gradient(145deg,#fff 0%,#fff7ed 100%);border:1px solid #f973161a}.summary-card.week{background:linear-gradient(145deg,#fff 0%,#fffbeb 100%);border:1px solid #f59e0b1a}.summary-card.month{background:linear-gradient(145deg,#fff 0%,#fff1f2 100%);border:1px solid #fb71851a}.card-icon{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#fff9;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:24px;display:flex;box-shadow:0 2px 4px #0000000d}.card-content h3{margin:0 0 4px;font-size:.75rem;font-weight:500}.card-content .amount{color:#333;margin:0;font-size:1.25rem;font-weight:700}.chart-card{border-radius:var(--radius-lg);padding:var(--space-lg);box-shadow:var(--shadow-md);margin-bottom:var(--space-xl);background:#fff}.chart-card h3{color:#333;margin:0;font-size:1rem}.chart-header{margin-bottom:var(--space-xl);justify-content:space-between;align-items:center;gap:var(--space-md);flex-wrap:wrap;display:flex}.chart-filter{align-items:center;gap:var(--space-sm);display:flex}.filter-date-small{color:#64748b;border:1px solid #e2e8f0;border-radius:6px;outline:none;padding:6px 12px;font-size:.8rem;transition:all .2s}.filter-date-small:focus{border-color:var(--primary);color:var(--primary)}.recent-expenses{border-radius:var(--radius-lg);padding:var(--space-lg);box-shadow:var(--shadow-md);background:#fff}.recent-expenses h3{white-space:nowrap;margin:0;font-size:1rem}.expenses-header{gap:var(--space-md);margin-bottom:var(--space-lg);flex-direction:column;display:flex}@media (min-width:1024px){.expenses-header{flex-direction:column;gap:12px}.expenses-header h3{margin:0}.filter-section{width:100%}.filter-section .filter-header{display:none!important}.filter-inputs{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;margin:0;padding:14px 18px;animation:none;flex-flow:wrap!important;align-items:center!important;gap:10px!important;display:flex!important}.filter-inputs>.filter-searchbox{flex:200px;min-width:150px;max-width:280px;border:1px solid #e2e8f0!important;border-radius:8px!important;padding:10px 14px!important;font-size:.9rem!important}.filter-inputs>.filter-select{flex:none;min-width:160px;background:#fff!important;border:1px solid #e2e8f0!important;border-radius:8px!important;padding:10px 14px!important;font-size:.9rem!important}.filter-inputs>.date-filter-group{flex:none;flex-direction:row!important;align-items:center!important;gap:8px!important;display:flex!important}.filter-inputs .date-filter-group .date-label{color:#64748b;white-space:nowrap;font-size:.85rem;font-weight:500}.filter-inputs .date-filter-group .filter-date{border:1px solid #e2e8f0!important;border-radius:8px!important;width:145px!important;padding:10px 12px!important;font-size:.9rem!important}.filter-inputs>.btn-clear-filter{flex:none;border-radius:8px!important;padding:10px 16px!important}}.filter-section{gap:var(--space-sm);flex-direction:column;display:flex}.filter-group{align-items:center;gap:var(--space-sm);display:flex}.filter-group label{color:#555;white-space:nowrap;font-size:.8rem;font-weight:500}.filter-date{padding:var(--space-sm)var(--space-md);border:2px solid #e0e0e0;border-radius:8px;flex:1;font-size:14px;transition:border-color .2s}.filter-date:focus{border-color:var(--primary);outline:none}.filter-searchbox{border:1px solid #e2e8f0;border-radius:6px;width:100%;padding:8px 12px;font-size:.9rem;transition:border-color .2s}.filter-searchbox:focus{border-color:var(--primary);outline:none}.filter-select{cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:6px;padding:8px 12px;font-size:.9rem;transition:border-color .2s}.filter-select:focus{border-color:var(--primary);outline:none}.btn-clear-filter{background:var(--danger);color:#fff;padding:var(--space-sm)var(--space-md);cursor:pointer;border:none;border-radius:8px;font-size:.8rem;font-weight:500;transition:background .2s}.btn-clear-filter:hover{background:#dc2626}.btn-filter-toggle{width:100%;padding:var(--space-md);color:var(--primary);cursor:pointer;margin-bottom:var(--space-sm);background:#fff;border:1px solid #e2e8f0;border-radius:8px;justify-content:center;align-items:center;gap:8px;font-size:.9rem;font-weight:600;transition:all .2s;display:flex;box-shadow:0 1px 2px #0000000d}.btn-filter-toggle:active{background:#f8fafc;transform:translateY(1px)}.date-range-group{align-items:center;gap:8px;width:100%;display:flex}.date-filter-group{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.date-label{color:#64748b;white-space:nowrap;font-size:.85rem;font-weight:500}.date-separator{color:#666;font-weight:700}@media (max-width:767px){.history-filter,.filter-inputs{gap:var(--space-md);padding:var(--space-md);margin-bottom:var(--space-md);background:#f8fafc;border:1px solid #edf2f7;border-radius:8px;flex-direction:column;animation:.3s fadeIn;display:none}.history-filter.show,.filter-inputs.show{display:flex}.history-filter input,.history-filter select,.filter-inputs input,.filter-inputs select,.filter-date{width:100%;min-width:0;height:44px;padding:10px;font-size:16px}.date-range-group{flex-direction:row;gap:4px}.date-range-group .filter-date{font-size:.8rem}.btn-clear-filter{width:100%;height:44px;margin-top:4px}.filter-group{width:100%}}@media (min-width:768px){.btn-filter-toggle{display:none}.history-filter,.filter-inputs{background:0 0;border:none;flex-direction:row;margin:0;padding:0;animation:none;display:flex!important}.history-filter-header{display:none}.filter-inputs{flex-wrap:wrap;align-items:flex-end}.date-range-group{width:auto}.dashboard-left .history-filter{align-items:stretch;gap:8px;flex-direction:column!important}.dashboard-left .history-filter input,.dashboard-left .history-filter select,.dashboard-left .history-filter .btn-clear-filter{width:100%;min-width:0}.dashboard-left .history-filter .date-range-group{gap:8px;width:100%;display:flex}.dashboard-left .history-filter .date-range-group input{width:50%}.dashboard-left .history-header>div:first-child{flex-direction:column;gap:8px;align-items:flex-start!important}.dashboard-left .history-header .btn-export-tiny{text-align:center;width:100%}}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.expense-cards-container{gap:var(--space-md);grid-template-columns:repeat(2,1fr);grid-auto-rows:1fr;display:grid}.expense-card{background:#fff;border:1px solid #f9731614;border-radius:16px;flex-direction:column;height:100%;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;position:relative;overflow:hidden;box-shadow:0 4px 12px #00000014,0 1px 3px #0000000a}.expense-card:before{content:"";background:linear-gradient(90deg,var(--primary),#fb923c);opacity:0;height:3px;transition:opacity .3s;position:absolute;top:0;left:0;right:0}.expense-card:active{transform:scale(.97);box-shadow:0 2px 8px #f973161f}.expense-card:active:before{opacity:1}@media (min-width:768px){.expense-card:hover{border-color:#f9731633;transform:translateY(-4px);box-shadow:0 12px 24px #f9731626,0 4px 8px #00000014}.expense-card:hover:before{opacity:1}}.expense-card-image{cursor:pointer;background:linear-gradient(135deg,#fff7ed 0%,#fed7aa 100%);width:100%;height:160px;position:relative;overflow:hidden}.expense-card-image img{object-fit:cover;width:100%;height:100%;transition:transform .3s}.expense-card-image:active img{transform:scale(1.05)}@media (min-width:768px){.expense-card-image:hover img{transform:scale(1.1)}}.expense-card-body{padding:var(--space-md);padding-bottom:calc(var(--space-lg) + 4px);flex-direction:column;flex:1;display:flex}.expense-card-header{gap:var(--space-sm);margin-bottom:var(--space-sm);flex-direction:column;display:flex}.expense-card-title{color:#111827;word-break:break-word;letter-spacing:-.02em;margin:0;font-size:.95rem;font-weight:700;line-height:1.3}.expense-card-price{background:linear-gradient(135deg,#f97316 0%,#ea580c 100%);-webkit-text-fill-color:transparent;margin-bottom:var(--space-sm);letter-spacing:-.03em;-webkit-background-clip:text;background-clip:text;font-size:1.15rem;font-weight:800}.expense-card-details{margin-bottom:var(--space-sm);background:linear-gradient(135deg,#fef3c7 0%,#fde68a 100%);border:1px solid #fbbf2433;border-radius:10px;flex-direction:column;gap:6px;padding:10px;display:flex}.expense-card-detail-item{justify-content:space-between;align-items:center;font-size:.85rem;display:flex}.detail-label{color:#92400e;font-size:.7rem;font-weight:600}.detail-value{color:#78350f;font-weight:700}.expense-card-meta{gap:var(--space-sm);padding-top:var(--space-sm);margin-bottom:var(--space-md);border-top:1px solid #e2e8f0;display:flex}.expense-card-meta-item{color:#64748b;align-items:center;gap:6px;font-size:.8rem;display:flex}.meta-icon{font-size:1rem}.expense-card-actions{padding-top:var(--space-sm);border-top:1px solid #e2e8f0;justify-content:center;gap:8px;display:flex}.btn-card-action{cursor:pointer;border:none;border-radius:10px;flex:1;justify-content:center;align-items:center;min-height:44px;padding:10px;font-size:1.3rem;font-weight:600;transition:all .2s;display:flex}.btn-card-action.btn-edit{color:#c2410c;background:linear-gradient(135deg,#fff7ed 0%,#ffedd5 100%);border:1.5px solid #f9731640;font-weight:700}.btn-card-action.btn-edit:active{background:linear-gradient(135deg,#fed7aa 0%,#fdba74 100%);border-color:#f9731666;transform:scale(.95)}@media (min-width:768px){.btn-card-action.btn-edit:hover{background:linear-gradient(135deg,#ffedd5 0%,#fed7aa 100%);transform:translateY(-1px);box-shadow:0 2px 8px #f9731633}}.btn-card-action.btn-delete{color:#dc2626;background:linear-gradient(135deg,#fef2f2 0%,#fee2e2 100%);border:1.5px solid #dc262640;font-weight:700}.btn-card-action.btn-delete:active{background:linear-gradient(135deg,#fecaca 0%,#fca5a5 100%);border-color:#dc262666;transform:scale(.95)}@media (min-width:768px){.btn-card-action.btn-delete:hover{background:linear-gradient(135deg,#fee2e2 0%,#fecaca 100%);transform:translateY(-1px);box-shadow:0 2px 8px #dc262633}}@media (min-width:1024px){.expense-cards-container{gap:var(--space-lg);grid-template-columns:repeat(auto-fill,minmax(320px,1fr));display:grid}.expense-card-image{height:200px}}.expense-table{-webkit-overflow-scrolling:touch;margin:0 calc(-1*var(--space-lg));padding:0 var(--space-lg);overflow-x:auto}.expense-table table{border-collapse:separate;border-spacing:0;width:100%;font-size:.9rem}.expense-table th{padding:var(--space-md);text-align:left;color:#64748b;white-space:nowrap;text-transform:uppercase;letter-spacing:.5px;background:#f8fafc;border-bottom:2px solid #e2e8f0;font-size:.8rem;font-weight:600}.expense-table td{padding:var(--space-md);vertical-align:middle;border-bottom:1px solid #f0f0f0;font-size:.85rem}.expense-table tr:hover td{background-color:#fafafa}.expense-thumbnail{object-fit:cover;cursor:pointer;border:1px solid #f0f0f0;border-radius:8px;width:44px;height:44px;transition:all .2s;box-shadow:0 2px 4px #0000001a}.expense-thumbnail:active{transform:scale(1.05)}.amount-cell{color:#10b981;white-space:nowrap;font-size:.9rem;font-weight:700}.btn-action{cursor:pointer;background:0 0;border:none;border-radius:6px;padding:6px;font-size:1.1rem;transition:background .2s}.image-modal{z-index:1000;cursor:pointer;z-index:1000;cursor:pointer;padding:env(safe-area-inset-top)env(safe-area-inset-right)env(safe-area-inset-bottom)env(safe-area-inset-left);background:#000000f2;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.date-header-cell{color:#c2410c;text-transform:uppercase;letter-spacing:.5px;background:#fff7ed;font-weight:700;padding:var(--space-sm)var(--space-md)!important;font-size:.75rem!important}.modal-content img{object-fit:contain;border-radius:8px;max-width:100%;max-height:90vh}.modal-overlay{top:0;left:0;right:0;bottom:calc(70px + env(safe-area-inset-bottom));z-index:900;background:#00000080;justify-content:center;align-items:flex-end;padding:0;display:flex;position:fixed}.modal-card{border-radius:var(--radius-xl)var(--radius-xl)0 0;padding:var(--space-xl);background:#fff;width:100%;max-width:500px;max-height:calc(85vh - 70px);animation:.3s slideUp;overflow-y:auto}.modal-card h3{margin:0 0 var(--space-lg)0;font-size:1.1rem}.modal-body{margin-bottom:var(--space-lg)}.modal-body .form-group{margin-bottom:var(--space-md)}.modal-body .form-group label{color:#444;margin-bottom:6px;font-size:.9rem;font-weight:500;display:block}.modal-body .form-group input{width:100%;padding:var(--space-md);border:2px solid #e0e0e0;border-radius:8px;font-size:16px}.modal-actions{gap:var(--space-md);padding-bottom:env(safe-area-inset-bottom);display:flex}.btn-cancel{color:var(--text-muted);padding:var(--space-md)var(--space-lg);cursor:pointer;background:#f1f5f9;border:none;border-radius:10px;flex:1;font-size:1rem;font-weight:600}.btn-submit{color:#fff;padding:var(--space-md)var(--space-lg);cursor:pointer;background:linear-gradient(135deg,#10b981 0%,#059669 100%);border:none;border-radius:10px;flex:2;font-size:1rem;font-weight:600}.btn-submit:disabled{opacity:.6;cursor:not-allowed}.action-cell{white-space:nowrap}.btn-action{cursor:pointer;padding:var(--space-sm);background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;min-width:36px;min-height:36px;font-size:16px;transition:background .2s;display:inline-flex}.btn-action:hover{background:#0000000d}.btn-edit:hover,.btn-delete:hover{background:#667eea1a}.btn-delete:hover{background:#ef44441a}.category-badge{background-color:var(--primary-light);color:var(--text-dark);white-space:nowrap;border:1px solid #f9731633;border-radius:20px;padding:4px 12px;font-size:.75rem;font-weight:600;display:inline-block}.edit-modal{max-width:550px}.edit-modal .form-group select,.edit-modal .form-group textarea{width:100%;padding:var(--space-md);border:2px solid #e0e0e0;border-radius:8px;font-family:inherit;font-size:16px}.edit-modal .form-group select:focus,.edit-modal .form-group textarea:focus{border-color:var(--primary);outline:none}@media (min-width:768px){.navbar{padding:var(--space-lg)var(--space-xl)}.navbar h2{font-size:1.5rem}.balance-header{flex-direction:row;justify-content:space-between;align-items:center}.balance-amount{font-size:2.5rem}.btn-topup,.btn-withdraw{flex:initial}.history-header{flex-direction:row;justify-content:space-between;align-items:center}.summary-cards{gap:var(--space-xl);grid-template-columns:repeat(3,1fr)}.summary-card:hover{transform:translateY(-4px)}.card-icon{font-size:40px}.card-content .amount{font-size:1.5rem}.expenses-header{flex-direction:row;justify-content:space-between;align-items:center}.filter-section{align-items:center;gap:var(--space-md);flex-direction:row}.expense-table table{font-size:.9rem}.expense-table th,.expense-table td{padding:var(--space-md)}.expense-thumbnail{width:60px;height:60px}.modal-overlay{padding:var(--space-xl);align-items:center}.modal-card{border-radius:var(--radius-lg);max-height:85vh}.form-row{gap:var(--space-lg);grid-template-columns:1fr 1fr}}.pagination-controls-simple{padding:var(--space-md)0 0 0;margin-top:var(--space-md);border-top:1px solid #f0f0f0;justify-content:space-between;align-items:center;display:flex}.btn-page-nav{border:1px solid var(--primary);color:var(--primary);cursor:pointer;background:#fff;border-radius:8px;align-items:center;gap:8px;padding:8px 16px;font-size:.85rem;font-weight:600;transition:all .2s;display:flex}.btn-page-nav:disabled{opacity:.5;cursor:not-allowed;color:#a0aec0;box-shadow:none;background:#f8fafc;border-color:#cbd5e0}.btn-page-nav:not(:disabled):hover{background:var(--primary);color:#fff;transform:translateY(-1px);box-shadow:0 2px 4px #f9731633}.page-info{color:#64748b;background:#fff;border:1px solid #f1f5f9;border-radius:20px;padding:6px 16px;font-size:.9rem;font-weight:600;box-shadow:inset 0 2px 4px #0000000d}.expenses-container{min-height:100vh;background-color:var(--bg-body);min-height:-webkit-fill-available;padding-bottom:calc(70px + env(safe-area-inset-bottom))}.navbar-right{display:none}.navbar{-webkit-backdrop-filter:blur(12px);padding:var(--space-md)var(--space-lg);box-shadow:var(--shadow-sm);gap:var(--space-sm);z-index:100;background:#fffc;border-bottom:1px solid #f973161a;flex-direction:column;display:flex;position:sticky;top:0}.navbar-left{gap:var(--space-sm);flex-direction:column;width:100%;display:flex}.navbar-top{justify-content:space-between;align-items:center;width:100%;display:flex}.navbar h2{color:var(--primary);align-items:center;gap:var(--space-sm);margin:0;font-size:1.1rem;font-weight:700;display:flex}.navbar-right span{display:none}.btn-logout{color:var(--danger);border:1px solid var(--danger);padding:var(--space-sm)var(--space-md);cursor:pointer;background:#fff;border-radius:8px;font-size:.85rem;font-weight:600;transition:all .2s}.btn-logout:hover{background:var(--danger);color:#fff}.nav-tabs{gap:var(--space-xs);background:#f1f5f9;border-radius:10px;width:100%;padding:4px;display:flex}.nav-tab{padding:var(--space-sm)var(--space-md);color:var(--text-muted);cursor:pointer;text-align:center;white-space:nowrap;background:0 0;border:none;border-radius:8px;flex:1;font-size:.85rem;font-weight:500;transition:all .2s}.nav-tab.active{color:var(--primary);box-shadow:var(--shadow-sm);background:#fff;font-weight:600}.nav-tab:hover:not(.active){color:var(--text-main);background:#ffffff80}.type-tabs-container{max-width:1200px;padding:var(--space-lg)var(--space-lg)0;margin:0 auto}.type-tabs{gap:var(--space-md);padding:var(--space-sm);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);background:#fff;display:flex}.type-tab{padding:var(--space-md);color:var(--text-muted);border-radius:var(--radius);cursor:pointer;justify-content:center;align-items:center;gap:var(--space-sm);background:0 0;border:none;flex:1;font-size:1rem;font-weight:600;transition:all .2s;display:flex}.type-tab:hover{background:var(--bg-body);color:var(--text-main)}.type-tab.active{box-shadow:var(--shadow-sm)}.type-tab.expense.active{color:#ef4444;background:#fef2f2;border:1px solid #fee2e2}.type-tab.income.active{color:#10b981;background:#ecfdf5;border:1px solid #d1fae5}.content{max-width:1200px;padding:var(--space-lg);margin:0 auto;animation:.3s ease-out fadeIn}.expense-form-card{background:var(--bg-card);border-radius:var(--radius-lg);padding:var(--space-lg);box-shadow:var(--shadow-md);margin-bottom:var(--space-xl);border:1px solid #0000000d}.expense-form-card h3{margin:0 0 var(--space-lg)0;color:var(--text-main);font-size:1.1rem;font-weight:600}.form-row{gap:var(--space-md);grid-template-columns:1fr;display:grid}.form-group{margin-bottom:var(--space-md)}.form-group label{margin-bottom:var(--space-sm);color:var(--text-main);font-size:.9rem;font-weight:500;display:block}.form-group input,.form-group select,.form-group textarea{width:100%;padding:var(--space-md);appearance:none;background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;font-size:16px;transition:box-shadow .3s cubic-bezier(.4,0,.2,1),border-color .3s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--primary);background:#fff;outline:none;box-shadow:0 0 0 3px #f973161a}.image-preview{margin-top:var(--space-md);background:#fafafa;border:2px dashed #cbd5e1;border-radius:12px;padding:4px;overflow:hidden}.image-preview img{border-radius:10px;width:100%;height:auto;display:block}.total-display{background:linear-gradient(135deg,var(--primary)0%,var(--primary-hover)100%);color:#fff;padding:var(--space-lg);border-radius:var(--radius);text-align:center;margin-bottom:var(--space-lg);box-shadow:var(--shadow-lg);font-size:1.1rem;font-weight:600}.upload-options{gap:var(--space-sm);display:flex}.btn-upload{padding:var(--space-md);cursor:pointer;justify-content:center;align-items:center;gap:var(--space-sm);border:none;border-radius:10px;flex:1;font-size:.9rem;font-weight:500;transition:transform .2s,box-shadow .2s;display:flex}.btn-upload.camera{color:var(--primary);border:1px dashed var(--primary);background:#ffedd5}.btn-upload.gallery{color:var(--secondary);border:1px dashed var(--secondary);background:#ecfdf5}.btn-upload.webcam{color:#d97706;background:#fef3c7;border:1px dashed #d97706}.btn-upload:active{transform:scale(.97)}.form-actions{gap:var(--space-md);margin-top:var(--space-sm);display:flex}.btn-submit,.btn-cancel{padding:var(--space-md);cursor:pointer;border:none;border-radius:12px;min-height:48px;font-size:1rem;font-weight:600;transition:transform .1s,box-shadow .2s}.btn-submit{background:var(--primary);color:#fff;flex:2;box-shadow:0 4px 12px #f973164d}.btn-submit:hover:not(:disabled){background:var(--primary-hover)}.btn-submit:active:not(:disabled){transform:scale(.98)}.btn-cancel{color:var(--text-muted);background:#f1f5f9;flex:1}.btn-cancel:hover{color:var(--text-main);background:#e2e8f0}.expenses-list h3{color:var(--text-main);margin:0;font-size:1.1rem}.expenses-list-header{gap:var(--space-md);margin-bottom:var(--space-lg);flex-direction:column;display:flex}.view-toggle{background:#f1f5f9;border-radius:10px;gap:4px;width:fit-content;padding:4px;display:flex}.view-btn{padding:var(--space-sm)var(--space-md);cursor:pointer;color:var(--text-muted);background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;min-width:40px;font-size:1rem;transition:all .2s;display:flex}.view-btn.active{color:var(--primary);box-shadow:var(--shadow-sm);background:#fff}.expense-grid{gap:var(--space-md);grid-template-columns:repeat(2,1fr);display:grid}.expense-card{border-radius:var(--radius);box-shadow:var(--shadow-sm);background:#fff;border:1px solid #00000008;flex-direction:column;transition:all .2s;display:flex;overflow:hidden}.expense-card:active{transform:scale(.98)}@media (hover:hover){.expense-card:hover{transform:translateY(-4px);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d}}.expense-image{cursor:zoom-in;width:100%;height:100px;position:relative;overflow:hidden}.expense-image img{object-fit:cover;width:100%;height:100%;transition:transform .3s}.expense-details{padding:var(--space-sm);flex-direction:column;flex:1;gap:2px;display:flex}.expense-details h4{color:var(--text-main);-webkit-line-clamp:2;line-clamp:2;-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0;font-size:.8rem;font-weight:600;line-height:1.2;display:-webkit-box;overflow:hidden}.expense-category{color:var(--primary);text-transform:uppercase;font-size:.65rem;font-weight:600}.expense-details p{color:var(--text-muted);margin:0;font-size:.7rem}.expense-total{padding-top:var(--space-sm);border-top:1px solid #f1f5f9;font-weight:700;color:var(--secondary)!important;margin-top:auto!important;font-size:.85rem!important}.expense-date{color:var(--text-light)!important;font-size:.65rem!important}.expense-actions{gap:var(--space-xs);padding:var(--space-sm);padding-top:0;display:flex}.btn-edit,.btn-delete{padding:var(--space-sm);cursor:pointer;border:none;border-radius:8px;flex:1;min-height:32px;font-size:.7rem;font-weight:600;transition:all .2s}.btn-edit{color:#d97706;background:#fef3c7}.btn-edit:active{background:#fde68a}.btn-delete{color:#dc2626;background:#fee2e2}.btn-delete:active{background:#fecaca}.image-modal{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;padding:env(safe-area-inset-top)var(--space-md)env(safe-area-inset-bottom);background:#0f172af7;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal-content img{border-radius:var(--radius);object-fit:contain;max-width:100%;max-height:90vh;box-shadow:var(--shadow-2xl)}.expense-table-container{-webkit-overflow-scrolling:touch;border-radius:var(--radius);box-shadow:var(--shadow-sm);margin:0 calc(-1*var(--space-lg));padding:0 var(--space-lg);background:#fff;overflow-x:auto}.expense-list-table{border-collapse:collapse;width:100%;font-size:.8rem}.expense-list-table th{padding:var(--space-sm);text-align:left;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;background:#f8fafc;border-bottom:2px solid #e2e8f0;font-size:.7rem;font-weight:600}.expense-list-table td{padding:var(--space-sm);vertical-align:middle;border-bottom:1px solid #f1f5f9}.expense-list-table tbody tr:active{background:#f8fafc}.list-thumbnail{object-fit:cover;cursor:pointer;border-radius:6px;width:40px;height:40px}.supplier-text{color:var(--text-muted);margin-top:2px;font-size:.7rem}.category-badge{color:var(--primary);background:#ffedd5;border-radius:20px;padding:2px 8px;font-size:.7rem;font-weight:600;display:inline-block}.total-cell{color:var(--secondary);white-space:nowrap;font-weight:700}.table-actions{gap:var(--space-xs);display:flex}.btn-icon-edit,.btn-icon-delete{cursor:pointer;padding:var(--space-sm);background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;min-width:32px;min-height:32px;font-size:14px;transition:background .2s;display:flex}.btn-icon-edit:active{background:#fef3c7}.btn-icon-delete:active{background:#fee2e2}.webcam-modal{z-index:1000;padding:var(--space-lg);background:#000000f2;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.webcam-content{padding:var(--space-lg);border-radius:var(--radius-lg);text-align:center;background:#fff;width:100%;max-width:500px}.webcam-content h3{margin-top:0;margin-bottom:var(--space-md);color:var(--text-main);font-size:1rem}.video-container{border-radius:var(--radius);width:100%;margin-bottom:var(--space-lg);background:#000;padding-top:75%;position:relative;overflow:hidden}.video-container video{object-fit:cover;width:100%;height:100%;position:absolute;top:0;left:0}.webcam-actions{gap:var(--space-md);display:flex}.btn-capture{background:var(--primary);color:#fff;padding:var(--space-md);cursor:pointer;border:none;border-radius:10px;flex:2;min-height:48px;font-size:1rem;font-weight:600;transition:background .2s}.btn-capture:active{background:var(--primary-hover)}@media (min-width:768px){.navbar{padding:var(--space-lg)var(--space-xl);flex-direction:row;justify-content:space-between;display:flex!important}.navbar-right{display:flex!important}.navbar-left{align-items:center;gap:var(--space-xl);flex-direction:row;width:auto}.navbar h2{font-size:1.4rem}.navbar-right span{color:var(--text-muted);font-weight:500;display:inline}.nav-tabs{width:auto}.nav-tab{padding:var(--space-sm)var(--space-lg)}.form-row{gap:var(--space-lg);grid-template-columns:1fr 1fr}.expense-form-card{padding:var(--space-2xl)}.expenses-list-header{flex-direction:row;justify-content:space-between;align-items:center}}@media (min-width:1024px){.expense-grid{gap:var(--space-lg);grid-template-columns:repeat(4,1fr)}.expense-image{height:140px}.expense-details{padding:var(--space-md)}.expense-details h4{font-size:.9rem}.expense-card:hover{transform:translateY(-4px);box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.expense-card:hover .expense-image img{transform:scale(1.05)}.btn-edit:hover{background:#fde68a}.btn-delete:hover{background:#fecaca}.btn-icon-edit:hover{background:#fef3c7}.btn-icon-delete:hover{background:#fee2e2}}@media (min-width:1280px){.expense-grid{grid-template-columns:repeat(5,1fr)}}.categories-container{background:var(--bg-body);min-height:100vh;padding-bottom:calc(70px + env(safe-area-inset-bottom))}.mobile-only{display:flex}.desktop-only,.navbar-right{display:none}@media (min-width:768px){.mobile-only{display:none!important}.desktop-only,.navbar-right{display:flex!important}}.navbar{z-index:100;background:#fff;justify-content:space-between;align-items:center;margin-bottom:16px;padding:12px 16px;display:flex;position:sticky;top:0;box-shadow:0 2px 8px #0000001a}.navbar h2{color:var(--primary);margin:0;font-size:1.1rem;font-weight:700}.navbar-right{align-items:center;gap:8px}.navbar-right span{color:#64748b;font-size:.9rem;font-weight:500}.btn-back{color:#fff;cursor:pointer;background:#6b7280;border:none;border-radius:8px;padding:8px 16px;font-size:.85rem;font-weight:500}.btn-logout{color:#ef4444;cursor:pointer;background:#fff;border:1px solid #ef4444;border-radius:8px;padding:8px 12px;font-size:.85rem;font-weight:600}.content{max-width:1200px;margin:0 auto;padding:0 16px}.section-card{box-shadow:var(--shadow-md);background:#fff;border:1px solid #f973160d;border-radius:16px;margin-bottom:16px;padding:16px}.section-header{flex-direction:column;gap:12px;margin-bottom:16px;display:flex}.section-header h3{color:#0f172a;margin:0;font-size:1.1rem}.btn-add{color:#fff;cursor:pointer;background:linear-gradient(135deg,#f97316 0%,#c2410c 100%);border:none;border-radius:10px;width:100%;min-height:44px;padding:12px 16px;font-size:.9rem;font-weight:600;transition:all .2s;box-shadow:0 4px 12px #f973164d}.btn-back{color:#fff;cursor:pointer;background:#6b7280;border:none;border-radius:8px;padding:8px 16px;font-weight:500}.category-form{background:#f9fafb;border-radius:12px;margin-bottom:16px;padding:16px}.categories-grid{grid-template-columns:1fr;gap:16px;display:grid}.category-group{background:#fafbfc;border-radius:12px;padding:12px}.category-group h4{color:var(--primary);margin:0 0 12px;font-size:.9rem}.category-list{flex-direction:column;gap:8px;display:flex}.category-item{background:#fff;border-radius:10px;justify-content:space-between;align-items:center;padding:12px;display:flex;box-shadow:0 1px 2px #0000000d}.category-actions{gap:4px;display:flex}.btn-edit{color:#78350f;cursor:pointer;background:#fbbf24;border:none;border-radius:8px;min-height:36px;padding:8px 12px;font-size:.8rem;font-weight:600}.btn-delete{color:#fff;cursor:pointer;background:#ef4444;border:none;border-radius:8px;min-height:36px;padding:8px 12px;font-size:.8rem;font-weight:600}.satuan-form{flex-direction:column;gap:12px;margin-bottom:16px;display:flex}.satuan-form input{border:2px solid #e0e0e0;border-radius:10px;padding:12px;font-size:16px}.satuan-grid{grid-template-columns:repeat(2,1fr);gap:8px;display:grid}.satuan-item{color:#9a3412;background:#fff7ed;border:1px solid #fdba74;border-radius:10px;justify-content:space-between;align-items:center;padding:12px;font-size:.85rem;font-weight:600;display:flex}.satuan-actions{gap:4px;display:flex}.btn-edit-small{cursor:pointer;background:0 0;border:none;padding:4px;font-size:14px}.btn-delete-small{color:#fff;cursor:pointer;background:#ef4444;border:none;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:14px;display:flex}.btn-save-small{color:#fff;cursor:pointer;background:#10b981;border:none;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:14px;display:flex}.btn-cancel-small{color:#fff;cursor:pointer;background:#6b7280;border:none;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:14px;display:flex}.satuan-item .edit-input{border:2px solid var(--primary);border-radius:6px;flex:1;min-width:60px;padding:6px;font-size:14px}@media (min-width:768px){.section-card{padding:24px}.section-header{flex-direction:row;justify-content:space-between;align-items:center}.btn-add{width:auto}.categories-grid{grid-template-columns:1fr 1fr;gap:24px}.satuan-form{flex-direction:row}.satuan-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}}.balance-cat-groups{flex-direction:column;gap:16px;display:flex}.balance-cat-group h4{color:#64748b;margin:0 0 8px;font-size:.9rem}.satuan-item.type-topup{border-left:3px solid #10b981}.satuan-item.type-withdraw{border-left:3px solid #f59e0b}.empty-msg{color:#94a3b8;font-size:.85rem;font-style:italic}.satuan-form select{background:#fff;border:2px solid #e0e0e0;border-radius:8px;padding:10px 12px;font-size:14px}.settings-container{max-width:800px;margin:0 auto;padding:20px}.settings-card{background:#fff;border-radius:12px;margin-top:1.5rem;padding:24px;box-shadow:0 4px 6px -1px #0000001a}.logo-upload-container{background:#f7fafc;border:2px dashed #cbd5e0;border-radius:8px;flex-direction:column;align-items:center;gap:1rem;padding:1rem;display:flex}.logo-preview{object-fit:contain;background:#fff;border-radius:8px;width:120px;height:120px;padding:4px;box-shadow:0 2px 4px #0000001a}.logo-placeholder{color:#a0aec0;text-align:center;background:#edf2f7;border-radius:8px;justify-content:center;align-items:center;width:120px;height:120px;font-size:.9rem;display:flex}.file-input{width:100%;font-size:.9rem}.settings-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.settings-header h2{color:#2d3748;margin:0}.settings-form{flex-direction:column;gap:20px;display:flex}.form-group label{color:#4a5568;margin-bottom:8px;font-weight:500;display:block}.form-group input,.form-group select,.form-group textarea{border:1px solid #e2e8f0;border-radius:6px;width:100%;padding:10px;font-size:14px;transition:all .2s}.form-group input:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #f973161a}.btn-save{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:6px;align-self:flex-start;padding:12px 24px;font-weight:600}.btn-save:hover{background:var(--primary-hover)}.btn-back{color:#4a5568;cursor:pointer;background:0 0;border:1px solid #cbd5e0;border-radius:6px;align-items:center;gap:8px;padding:8px 16px;text-decoration:none;display:inline-flex}.btn-back:hover{background:#f7fafc}.setting-hint{color:#718096;margin-top:6px;font-size:12px;display:block}.bottom-nav{-webkit-backdrop-filter:blur(16px);padding:6px 8px;padding-bottom:calc(6px + env(safe-area-inset-bottom));z-index:1000;background:#ffffffe6;border-top:1px solid #f9731614;justify-content:space-around;align-items:stretch;display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -8px 32px #f9731626}.nav-item{cursor:pointer;color:#94a3b8;-webkit-tap-highlight-color:transparent;background:0 0;border:none;border-radius:12px;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:2px;padding:8px 4px;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;position:relative}.nav-item:before{content:"";background:linear-gradient(90deg,#f97316,#ea580c);border-radius:0 0 4px 4px;width:24px;height:3px;transition:transform .3s;position:absolute;top:0;left:50%;transform:translate(-50%)scaleX(0)}.nav-item.active:before{transform:translate(-50%)scaleX(1)}.nav-item.active{color:#f97316;background:#f9731614}.nav-item.active .nav-icon{filter:drop-shadow(0 2px 4px #f973164d);transform:translateY(-2px)scale(1.15)}.nav-item.export{color:#059669}.nav-item.export:active{background:#0596691a}.nav-item.logout{color:#dc2626}.nav-item.logout:active{background:#dc26261a}.nav-item:active{background:#94a3b81a;transform:scale(.95)}.nav-icon{font-size:1.5rem;line-height:1;transition:all .3s cubic-bezier(.4,0,.2,1)}.nav-label{letter-spacing:.2px;text-transform:uppercase;font-size:.65rem;font-weight:700}@media (min-width:768px){.bottom-nav{display:none}}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.loading{min-height:100vh;color:var(--primary);justify-content:center;align-items:center;font-size:18px;display:flex}#root{min-height:100vh}
