@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swap";:root{--primary-50:#eef2ff;--primary-100:#e0e7ff;--primary-200:#c7d2fe;--primary-400:#818cf8;--primary-500:#6366f1;--primary-600:#4f46e5;--primary-700:#4338ca;--primary-gradient:linear-gradient(135deg, #6366f1 0%, #4f46e5 50%, #7c3aed 100%);--success:#10b981;--success-bg:#d1fae5;--warning:#f59e0b;--warning-bg:#fef3c7;--danger:#ef4444;--danger-bg:#fee2e2;--info:#0ea5e9;--info-bg:#e0f2fe;--bg:#f0f2ff;--bg-secondary:#e8eaf6;--surface:#fff;--surface-2:#f8f9ff;--surface-3:#f0f2ff;--border:#6366f11a;--border-strong:#6366f133;--text-primary:#0f0f1a;--text-secondary:#6b7280;--text-tertiary:#9ca3af;--text-on-primary:#fff;--shadow-sm:0 1px 3px #0000000f, 0 1px 2px #0000000a;--shadow-md:0 4px 16px #6366f114, 0 2px 8px #0000000f;--shadow-lg:0 8px 32px #6366f11f, 0 4px 16px #00000014;--shadow-card:0 2px 12px #6366f114;--shadow-fab:0 8px 24px #6366f166;--cat-groceries:#f97316;--cat-medical:#ef4444;--cat-fuel:#3b82f6;--cat-shopping:#a855f7;--cat-education:#14b8a6;--cat-bills:#f59e0b;--cat-entertainment:#ec4899;--cat-savings:#10b981;--cat-food:#fb923c;--cat-travel:#6366f1;--cat-rent:#8b5cf6;--cat-donation:#06b6d4;--cat-others:#6b7280;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-8:32px;--space-10:40px;--space-12:48px;--space-16:64px;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:20px;--radius-2xl:24px;--radius-full:9999px;--font:"Inter", system-ui, -apple-system, sans-serif;--nav-h:72px;--safe-bottom:env(safe-area-inset-bottom,0px);--transition-fast:.15s cubic-bezier(.4, 0, .2, 1);--transition-base:.25s cubic-bezier(.4, 0, .2, 1);--transition-slow:.4s cubic-bezier(.4, 0, .2, 1);--transition-spring:.4s cubic-bezier(.34, 1.56, .64, 1)}[data-theme=dark]{--primary-50:#1e1b4b;--primary-100:#312e81;--bg:#0a0a12;--bg-secondary:#0f0f1a;--surface:#13131f;--surface-2:#1a1a2e;--surface-3:#1e1e30;--border:#6366f11f;--border-strong:#6366f140;--text-primary:#f0f0ff;--text-secondary:#94a3b8;--text-tertiary:#64748b;--shadow-sm:0 1px 3px #0000004d;--shadow-md:0 4px 16px #0000004d, 0 2px 8px #6366f11a;--shadow-lg:0 8px 32px #0006, 0 4px 16px #6366f11f;--shadow-card:0 2px 12px #0000004d;--shadow-fab:0 8px 24px #6366f180;--success-bg:#10b98126;--warning-bg:#f59e0b26;--danger-bg:#ef444426;--info-bg:#0ea5e926}*,:before,:after{box-sizing:border-box;-webkit-tap-highlight-color:transparent;margin:0;padding:0}html{scroll-behavior:smooth;overscroll-behavior:none;touch-action:manipulation;height:100%;font-size:16px;overflow:hidden}body{font-family:var(--font);background:var(--bg);color:var(--text-primary);touch-action:manipulation;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;height:100%;transition:background var(--transition-base), color var(--transition-base);overflow:hidden}#root{background:var(--bg);flex-direction:column;max-width:480px;height:100%;margin:0 auto;display:flex;position:relative;overflow:hidden;box-shadow:0 0 80px #6366f10f}h1,h2,h3,h4,h5,h6{font-family:var(--font);color:var(--text-primary);font-weight:700;line-height:1.2}.text-display{letter-spacing:-.03em;font-size:2.5rem;font-weight:800}.text-h1{letter-spacing:-.02em;font-size:1.75rem;font-weight:700}.text-h2{letter-spacing:-.015em;font-size:1.375rem;font-weight:700}.text-h3{font-size:1.125rem;font-weight:600}.text-h4{font-size:1rem;font-weight:600}.text-body{font-size:.9375rem;font-weight:400;line-height:1.6}.text-sm{font-size:.8125rem}.text-xs{font-size:.75rem}.text-label{letter-spacing:.05em;text-transform:uppercase;font-size:.75rem;font-weight:500}.text-amount{letter-spacing:-.02em;font-variant-numeric:tabular-nums;font-size:1.5rem;font-weight:800}.text-amount-lg{letter-spacing:-.03em;font-variant-numeric:tabular-nums;font-size:2.25rem;font-weight:800}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(30px)}to{opacity:1;transform:translate(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-30px)}to{opacity:1;transform:translate(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.85)}to{opacity:1;transform:scale(1)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes ripple{0%{opacity:.4;transform:scale(0)}to{opacity:0;transform:scale(4)}}@keyframes confetti{0%{opacity:1;transform:translateY(0)rotate(0)}to{opacity:0;transform:translateY(-200px)rotate(720deg)}}@keyframes strokeDraw{0%{stroke-dashoffset:1000px}to{stroke-dashoffset:0}}@keyframes countUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes floatUp{0%{transform:translateY(0)}50%{transform:translateY(-6px)}to{transform:translateY(0)}}@keyframes glowPulse{0%,to{box-shadow:0 8px 24px #6366f166}50%{box-shadow:0 8px 32px #6366f1a6}}.animate-fadeIn{animation:fadeIn var(--transition-base) both}.animate-fadeInUp{animation:.5s cubic-bezier(.4,0,.2,1) both fadeInUp}.animate-slideUp{animation:.4s cubic-bezier(.34,1.56,.64,1) both slideUp}.animate-scaleIn{animation:.3s cubic-bezier(.34,1.56,.64,1) both scaleIn}.animate-float{animation:3s ease-in-out infinite floatUp}.delay-100{animation-delay:.1s}.delay-150{animation-delay:.15s}.delay-200{animation-delay:.2s}.delay-300{animation-delay:.3s}.delay-400{animation-delay:.4s}.delay-500{animation-delay:.5s}.delay-600{animation-delay:.6s}.delay-700{animation-delay:.7s}.delay-800{animation-delay:.8s}.skeleton{background:linear-gradient(90deg, var(--surface-2) 25%, var(--surface-3) 50%, var(--surface-2) 75%);border-radius:var(--radius-sm);background-size:200% 100%;animation:1.5s infinite shimmer}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:var(--radius-full)}.flex{display:flex}.flex-col{flex-direction:column;display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-1{gap:var(--space-1)}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-6{gap:var(--space-6)}.w-full{width:100%}.text-center{text-align:center}.relative{position:relative}.overflow-hidden{overflow:hidden}.text-primary-color{color:var(--primary-500)}.text-success{color:var(--success)}.text-danger{color:var(--danger)}.text-warning{color:var(--warning)}.text-secondary{color:var(--text-secondary)}.font-bold{font-weight:700}.font-semibold{font-weight:600}.font-medium{font-weight:500}.page{overscroll-behavior-y:contain;-webkit-overflow-scrolling:touch;flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden auto}.page>*{flex-shrink:0}.page:after{content:"";min-height:calc(var(--nav-h) + var(--safe-bottom) + 16px);flex-shrink:0;display:block}.page-no-nav{overscroll-behavior-y:contain;-webkit-overflow-scrolling:touch;flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden auto}.page-no-nav>*{flex-shrink:0}.page-content{padding:0 var(--space-4) var(--space-6);gap:var(--space-4);flex-direction:column;display:flex}.ptr-indicator{height:48px;color:var(--text-secondary);justify-content:center;align-items:center;font-size:.875rem;display:flex}.hero-gradient{background:var(--primary-gradient);border-radius:0 0 var(--radius-2xl) var(--radius-2xl);position:relative;overflow:hidden}.hero-gradient:before{content:"";pointer-events:none;background:radial-gradient(at 70% 20%,#ffffff26 0%,#0000 60%);position:absolute;inset:0}.glass{-webkit-backdrop-filter:blur(12px);background:#ffffff1f;border:1px solid #fff3}.divider{background:var(--border);height:1px;margin:var(--space-4) 0}.section-header{margin-bottom:var(--space-3);justify-content:space-between;align-items:center;display:flex}.section-title{color:var(--text-primary);font-size:1rem;font-weight:700}.section-link{color:var(--primary-500);cursor:pointer;background:0 0;border:none;padding:0;font-size:.8125rem;font-weight:600;text-decoration:none}.ripple-container{cursor:pointer;position:relative;overflow:hidden}.ripple-container:after{content:"";opacity:0;background:#6366f133;border-radius:50%;width:100%;padding-top:100%;transition:transform .5s,opacity .5s;display:block;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)scale(0)}.ripple-container:active:after{opacity:0;transition:all;transform:translate(-50%,-50%)scale(2)}:focus-visible{outline:2px solid var(--primary-500);outline-offset:2px;border-radius:var(--radius-sm)}.scroll-row{gap:var(--space-3);padding-bottom:var(--space-2);scrollbar-width:none;-ms-overflow-style:none;scroll-snap-type:x mandatory;display:flex;overflow-x:auto}.scroll-row::-webkit-scrollbar{display:none}.scroll-row>*{scroll-snap-align:start;flex-shrink:0}.status-bar{height:env(safe-area-inset-top,0);background:0 0}.bottom-nav{width:100%;max-width:480px;height:var(--nav-h);padding-bottom:var(--safe-bottom);background:var(--surface);border-top:1px solid var(--border);z-index:100;justify-content:space-around;align-items:center;display:flex;position:fixed;bottom:0;left:50%;transform:translate(-50%);box-shadow:0 -4px 24px #0000000f}.nav-item{height:100%;color:var(--text-tertiary);cursor:pointer;transition:color var(--transition-fast);-webkit-tap-highlight-color:transparent;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:2px;min-width:44px;padding-bottom:4px;text-decoration:none;display:flex;position:relative}.nav-item:hover{color:var(--text-secondary)}.nav-item-active{color:var(--primary-500)}.nav-icon{transition:transform var(--transition-spring);font-size:1.375rem;line-height:1;display:block}.nav-item-active .nav-icon{transform:translateY(-2px)scale(1.1)}.nav-label{letter-spacing:.03em;transition:font-weight var(--transition-fast), color var(--transition-fast);font-size:.625rem;font-weight:500;font-family:var(--font)}.nav-item-active .nav-label{color:var(--primary-500);font-weight:700}.nav-indicator{background:var(--primary-gradient);border-radius:0 0 var(--radius-sm) var(--radius-sm);width:32px;height:3px;animation:.25s cubic-bezier(.34,1.56,.64,1) both scaleIn;position:absolute;top:6px}.expense-card-wrapper{border-radius:var(--radius-lg);margin-bottom:2px;position:relative;overflow:hidden}.expense-swipe-hints{pointer-events:none;justify-content:space-between;align-items:center;padding:0 20px;display:flex;position:absolute;inset:0}.swipe-hint-edit{color:var(--primary-500);font-size:.8125rem;font-weight:600}.swipe-hint-delete{color:var(--danger);font-size:.8125rem;font-weight:600}.expense-card{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);border:1px solid var(--border);will-change:transform;cursor:grab;align-items:center;gap:12px;padding:14px 16px;display:flex;position:relative}.expense-card:active{cursor:grabbing}.expense-cat-icon{border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:1.25rem;display:flex}.expense-info{flex:1;min-width:0}.expense-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:.9375rem;font-weight:600;overflow:hidden}.expense-meta{color:var(--text-secondary);flex-wrap:wrap;align-items:center;gap:4px;margin-top:2px;font-size:.75rem;display:flex}.expense-cat-label{font-weight:600}.expense-dot{color:var(--text-tertiary)}.expense-amount-col{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:3px;display:flex}.expense-amount{font-variant-numeric:tabular-nums;letter-spacing:-.02em;font-size:1rem;font-weight:800}.expense-mode{font-size:.875rem}.expense-card-deleted{height:0;transition:height .35s;overflow:hidden}.add-expense-step1{flex-direction:column;gap:0;display:flex}.amount-display{border-bottom:1px solid var(--border);justify-content:center;align-items:baseline;gap:6px;padding:20px 24px 16px;display:flex}.amount-currency{color:var(--text-secondary);font-variant-numeric:tabular-nums;font-size:1.75rem;font-weight:400}.amount-value{color:var(--text-primary);font-variant-numeric:tabular-nums;letter-spacing:-.04em;min-width:1ch;font-size:3rem;font-weight:800}.quick-amounts{gap:8px;padding:12px 16px 8px}.quick-amount-btn{border-radius:var(--radius-full);background:var(--surface-2);border:1.5px solid var(--border);height:34px;font-family:var(--font);color:var(--text-secondary);cursor:pointer;white-space:nowrap;transition:all var(--transition-fast);flex-shrink:0;padding:0 14px;font-size:.8125rem;font-weight:600}.quick-amount-btn:hover,.quick-amount-btn:active{background:var(--primary-50);border-color:var(--primary-400);color:var(--primary-600);transform:scale(.97)}.numpad{grid-template-columns:repeat(3,1fr);gap:6px;padding:8px 16px 16px;display:grid}.numpad-key{border-radius:var(--radius-md);background:var(--surface-2);border:1px solid var(--border);height:60px;font-family:var(--font);color:var(--text-primary);cursor:pointer;transition:all var(--transition-fast);justify-content:center;align-items:center;font-size:1.25rem;font-weight:600;display:flex}.numpad-key:active{background:var(--primary-50);transform:scale(.93)}.numpad-del{background:var(--danger-bg);color:var(--danger);border-color:#ef444426}.numpad-del:active{background:#ef444433}.add-expense-step2{flex-direction:column;gap:0;padding:0 20px 8px;display:flex}.step2-amount-summary{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;margin-bottom:4px;padding:12px 0 16px;display:flex}.step2-amount{color:var(--primary-600);font-variant-numeric:tabular-nums;letter-spacing:-.03em;font-size:2rem;font-weight:800}.step2-edit-amount{color:var(--primary-500);background:var(--primary-50);border-radius:var(--radius-full);cursor:pointer;border:none;padding:4px 12px;font-size:.875rem;font-weight:600}.form-section{border-bottom:1px solid var(--border);padding:12px 0}.form-label{color:var(--text-secondary);letter-spacing:.05em;text-transform:uppercase;margin-bottom:8px;font-size:.75rem;font-weight:700;display:block}.form-input{background:var(--surface-2);border:1.5px solid var(--border);border-radius:var(--radius-md);width:100%;height:48px;font-family:var(--font);color:var(--text-primary);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);outline:none;padding:0 14px;font-size:.9375rem;font-weight:500}.form-input:focus{border-color:var(--primary-500);background:var(--surface);box-shadow:0 0 0 3px #6366f11f}.form-input::placeholder{color:var(--text-tertiary);font-weight:400}.member-selector{flex-wrap:wrap;gap:8px;display:flex}.member-select-btn{border-radius:var(--radius-full);border:1.5px solid var(--border);background:var(--surface-2);height:36px;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);align-items:center;gap:6px;padding:0 12px;font-size:.8125rem;font-weight:600;display:flex}.member-select-avatar{border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;font-size:.5625rem;font-weight:800;display:flex}.member-select-active{color:var(--text-primary);font-weight:700}.payment-mode-row{gap:8px}.payment-mode-btn{border-radius:var(--radius-full);border:1.5px solid var(--border);background:var(--surface-2);height:36px;font-family:var(--font);color:var(--text-secondary);cursor:pointer;white-space:nowrap;transition:all var(--transition-fast);flex-shrink:0;padding:0 14px;font-size:.8125rem;font-weight:600}.payment-mode-active{background:var(--primary-50);border-color:var(--primary-400);color:var(--primary-600)}.app-shell{flex-direction:column;flex:1;min-height:0;display:flex;position:relative}.app-main{flex-direction:column;flex:1;min-height:0;display:flex}.fab{bottom:calc(var(--nav-h) + 20px + var(--safe-bottom));background:var(--primary-gradient);cursor:pointer;width:60px;height:60px;box-shadow:var(--shadow-fab);z-index:110;transition:transform var(--transition-spring), box-shadow var(--transition-fast);-webkit-tap-highlight-color:transparent;border:none;border-radius:50%;justify-content:center;align-items:center;animation:3s ease-in-out infinite glowPulse;display:flex;position:fixed;right:20px}.fab:hover{transform:translateY(-2px)scale(1.05);box-shadow:0 12px 32px #6366f18c}.fab:active{animation:none;transform:translateY(2px)scale(.95)}.fab-icon{color:#fff;transition:transform var(--transition-spring);font-size:1.75rem;font-weight:300;line-height:1;display:block}.fab:before{content:"";border:3px solid var(--bg);pointer-events:none;border-radius:50%;position:absolute;inset:-3px}.splash-screen{background:var(--primary-gradient);flex-direction:column;justify-content:center;align-items:center;min-height:100dvh;display:flex;position:relative;overflow:hidden}.splash-screen:before{content:"";background:radial-gradient(circle at 20% 80%,#ffffff1a 0%,#0000 50%),radial-gradient(circle at 80% 20%,#ffffff14 0%,#0000 50%);position:absolute;inset:0}.splash-content{z-index:1;flex-direction:column;align-items:center;gap:20px;display:flex}.splash-logo{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#fff3;border:2px solid #ffffff4d;border-radius:28px;justify-content:center;align-items:center;width:96px;height:96px;display:flex;box-shadow:0 8px 32px #0003}.splash-emoji{font-size:3rem;animation:2s ease-in-out infinite floatUp;display:block}.splash-brand{text-align:center}.splash-title{color:#fff;letter-spacing:-.04em;margin:0;font-size:2rem;font-weight:800}.splash-tagline{color:#fffc;margin-top:4px;font-size:.9375rem;font-weight:400}.splash-dots{gap:8px;margin-top:8px;display:flex}.dot{width:8px;height:8px;transition:all var(--transition-base);background:#fff6;border-radius:50%}.dot-active{background:#fff;border-radius:4px;width:24px}.splash-footer{color:#fff9;font-size:.8125rem;position:absolute;bottom:32px}.welcome-page{background:var(--bg);flex-direction:column;min-height:100dvh;display:flex;overflow:hidden}.welcome-hero{background:var(--primary-gradient);border-radius:0 0 40px 40px;flex-direction:column;flex:1;justify-content:center;align-items:center;padding:48px 24px 60px;display:flex;position:relative;overflow:hidden}.welcome-hero:before{content:"";background:radial-gradient(circle at 70% 30%,#ffffff1f 0%,#0000 60%);position:absolute;inset:0}.welcome-illustration{filter:drop-shadow(0 8px 16px #00000026);margin-bottom:24px;font-size:5rem;animation:3s ease-in-out infinite floatUp}.welcome-title{color:#fff;text-align:center;letter-spacing:-.03em;z-index:1;margin:0;font-size:2rem;font-weight:800;line-height:1.15}.welcome-subtitle{color:#fffc;text-align:center;z-index:1;max-width:280px;margin-top:10px;font-size:1rem;line-height:1.55}.welcome-features{z-index:1;flex-wrap:wrap;justify-content:center;gap:12px;margin-top:24px;display:flex}.welcome-feature-chip{color:#fff;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff2e;border:1px solid #ffffff40;border-radius:24px;align-items:center;gap:6px;padding:6px 14px;font-size:.8125rem;font-weight:500;display:flex}.welcome-actions{flex-direction:column;gap:12px;padding:32px 24px;display:flex}.welcome-privacy{text-align:center;color:var(--text-tertiary);margin-top:4px;font-size:.75rem}.auth-page{background:var(--bg);flex-direction:column;min-height:100dvh;padding:0;display:flex}.auth-header{align-items:center;gap:12px;padding:16px 20px;display:flex}.auth-back-btn{background:var(--surface);border:1px solid var(--border);cursor:pointer;width:40px;height:40px;color:var(--text-primary);transition:background var(--transition-fast);box-shadow:var(--shadow-sm);border-radius:12px;justify-content:center;align-items:center;font-size:1.125rem;display:flex}.auth-back-btn:hover{background:var(--surface-2)}.auth-content{flex-direction:column;flex:1;padding:16px 24px 32px;display:flex}.auth-hero-icon{margin-bottom:16px;font-size:3.5rem;animation:3s ease-in-out infinite floatUp}.auth-title{color:var(--text-primary);letter-spacing:-.03em;margin:0;font-size:1.75rem;font-weight:800;line-height:1.2}.auth-subtitle{color:var(--text-secondary);margin-top:8px;font-size:.9375rem;line-height:1.55}.auth-form{flex-direction:column;flex:1;gap:16px;margin-top:32px;display:flex}.auth-phone-input{background:var(--surface);border:1.5px solid var(--border-strong);border-radius:var(--radius-md);height:56px;box-shadow:var(--shadow-sm);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);align-items:center;gap:0;display:flex;overflow:hidden}.auth-phone-input:focus-within{border-color:var(--primary-500);box-shadow:0 0 0 3px #6366f126}.auth-country-code{color:var(--text-primary);border-right:1.5px solid var(--border);white-space:nowrap;background:var(--surface-2);align-items:center;gap:6px;height:100%;padding:0 12px 0 16px;font-size:.9375rem;font-weight:600;display:flex}.auth-phone-field{height:100%;font-family:var(--font);color:var(--text-primary);background:0 0;border:none;outline:none;flex:1;padding:0 16px;font-size:1rem;font-weight:500}.auth-phone-field::placeholder{color:var(--text-tertiary);font-weight:400}.auth-divider{align-items:center;gap:12px;margin:8px 0;display:flex}.auth-divider:before,.auth-divider:after{content:"";background:var(--border);flex:1;height:1px}.auth-divider span{color:var(--text-tertiary);font-size:.8125rem;font-weight:500}.auth-footer-text{text-align:center;color:var(--text-secondary);margin-top:auto;padding-top:24px;font-size:.8125rem}.auth-link{color:var(--primary-500);cursor:pointer;font-weight:600;text-decoration:none}.otp-inputs{justify-content:center;gap:10px;margin-top:8px;display:flex}.otp-input{border-radius:var(--radius-md);border:1.5px solid var(--border-strong);background:var(--surface);width:48px;height:56px;font-family:var(--font);color:var(--text-primary);text-align:center;transition:border-color var(--transition-fast), box-shadow var(--transition-fast), transform var(--transition-spring);box-shadow:var(--shadow-sm);outline:none;font-size:1.5rem;font-weight:700}.otp-input:focus{border-color:var(--primary-500);transform:scale(1.05);box-shadow:0 0 0 3px #6366f126}.otp-filled{border-color:var(--primary-500);background:var(--primary-50)}.resend-timer{text-align:center;color:var(--text-secondary);margin-top:12px;font-size:.875rem}.resend-link{color:var(--primary-500);cursor:pointer;font-weight:600;text-decoration:none}.setup-options{flex-direction:column;gap:14px;margin-top:8px;display:flex}.setup-option-card{background:var(--surface);border-radius:var(--radius-lg);border:2px solid var(--border);cursor:pointer;transition:all var(--transition-fast);box-shadow:var(--shadow-sm);align-items:center;gap:16px;padding:18px;display:flex}.setup-option-card:hover{border-color:var(--primary-400);box-shadow:var(--shadow-md)}.setup-option-card-active{border-color:var(--primary-500);background:var(--primary-50);box-shadow:0 0 0 3px #6366f11f}.setup-option-icon{border-radius:16px;flex-shrink:0;justify-content:center;align-items:center;width:52px;height:52px;font-size:1.75rem;display:flex}.setup-option-text{flex:1}.setup-option-title{color:var(--text-primary);font-size:1rem;font-weight:700}.setup-option-desc{color:var(--text-secondary);margin-top:2px;font-size:.8125rem}.setup-option-arrow{color:var(--text-tertiary);transition:transform var(--transition-fast);font-size:1.125rem}.setup-option-card:hover .setup-option-arrow,.setup-option-card-active .setup-option-arrow{color:var(--primary-500);transform:translate(3px)}.code-input-wrapper{margin-top:8px;position:relative}.code-input{background:var(--surface);border:1.5px solid var(--border-strong);border-radius:var(--radius-md);width:100%;height:56px;font-family:var(--font);color:var(--primary-600);letter-spacing:.1em;text-align:center;text-transform:uppercase;transition:border-color var(--transition-fast), box-shadow var(--transition-fast);box-shadow:var(--shadow-sm);outline:none;padding:0 48px 0 16px;font-size:1.25rem;font-weight:700}.code-input:focus{border-color:var(--primary-500);box-shadow:0 0 0 3px #6366f126}.dashboard-page{padding-bottom:calc(var(--nav-h) + 16px + var(--safe-bottom))}.dashboard-header{color:#fff;padding:48px 20px 28px}.dashboard-header-top{justify-content:space-between;align-items:flex-start;margin-bottom:20px;display:flex}.dashboard-greeting{color:#fffc;margin:0;font-size:.875rem;font-weight:500}.dashboard-user-name{color:#fff;letter-spacing:-.03em;margin:2px 0 0;font-size:1.625rem;font-weight:800}.dashboard-header-actions{gap:8px;display:flex}.header-icon-btn{cursor:pointer;color:#fff;width:40px;height:40px;transition:background var(--transition-fast);-webkit-tap-highlight-color:transparent;background:#ffffff2e;border:1px solid #ffffff40;border-radius:12px;justify-content:center;align-items:center;font-size:1.125rem;display:flex;position:relative}.header-icon-btn:hover{background:#ffffff47}.notification-dot{background:#f59e0b;border:1.5px solid #0000;border-radius:50%;width:8px;height:8px;animation:2s ease-in-out infinite glowPulse;position:absolute;top:7px;right:7px}.monthly-card{border-radius:var(--radius-xl);color:#fff;padding:18px}.monthly-card-header{justify-content:space-between;align-items:flex-start;margin-bottom:16px;display:flex}.monthly-card-label{color:#ffffffbf;letter-spacing:.03em;text-transform:uppercase;margin:0 0 4px;font-size:.75rem;font-weight:500}.monthly-card-amount{letter-spacing:-.04em;font-variant-numeric:tabular-nums;color:#fff;font-size:2.25rem;font-weight:800;line-height:1}.monthly-card-badge{border-radius:var(--radius-full);color:#ffffffe6;background:#fff3;border:1px solid #ffffff40;padding:4px 12px;font-size:.75rem;font-weight:600}.monthly-card-row{border-radius:var(--radius-md);background:#ffffff1f;gap:0;display:flex;overflow:hidden}.monthly-stat{text-align:center;flex:1;padding:10px 12px}.monthly-stat-divider{background:#ffffff26;align-self:stretch;width:1px;margin:8px 0}.monthly-stat-label{color:#ffffffb3;letter-spacing:.02em;margin-bottom:3px;font-size:.6875rem;font-weight:500}.monthly-stat-value{color:#fff;font-variant-numeric:tabular-nums;font-size:.9375rem;font-weight:700}.settlement-status-card{border-radius:var(--radius-lg);cursor:pointer;transition:transform var(--transition-fast), box-shadow var(--transition-fast);border:1.5px solid;align-items:center;gap:12px;padding:14px 16px;display:flex}.settlement-status-card:active{transform:scale(.98)}.settlement-receive{background:var(--success-bg);border-color:#10b98140}.settlement-pay{background:var(--danger-bg);border-color:#ef444440}.settlement-zero{background:var(--surface);border-color:var(--border-strong)}.settlement-status-icon{flex-shrink:0;font-size:1.75rem}.settlement-status-label{color:var(--text-secondary);font-size:.8125rem;font-weight:500}.settlement-status-amount{color:var(--text-primary);font-variant-numeric:tabular-nums;letter-spacing:-.02em;font-size:1.25rem;font-weight:800}.settlement-status-arrow{color:var(--text-tertiary);margin-left:auto;font-size:1.5rem}.stats-row{gap:10px;padding:4px 0 8px}.stat-tile{background:var(--surface);border-radius:var(--radius-lg);border:1px solid var(--border);min-width:110px;box-shadow:var(--shadow-card);transition:transform var(--transition-fast);flex-direction:column;gap:4px;padding:14px 16px;display:flex}.stat-tile:active{transform:scale(.97)}.stat-icon{font-size:1.25rem}.stat-value{color:var(--text-primary);font-variant-numeric:tabular-nums;letter-spacing:-.02em;font-size:1rem;font-weight:800}.stat-label{color:var(--text-secondary);font-size:.6875rem;font-weight:500}.members-row{grid-template-columns:repeat(4,1fr);gap:8px;display:grid}.member-card{background:var(--surface);border-radius:var(--radius-md);border:1px solid var(--border);box-shadow:var(--shadow-sm);cursor:pointer;transition:transform var(--transition-fast);flex-direction:column;align-items:center;gap:4px;padding:12px 8px;display:flex}.member-card:active{transform:scale(.96)}.member-name{color:var(--text-primary);text-align:center;font-size:.75rem;font-weight:700}.member-paid{color:var(--text-secondary);font-variant-numeric:tabular-nums;font-size:.6875rem;font-weight:600}.member-balance{font-variant-numeric:tabular-nums;font-size:.6875rem;font-weight:700}.expense-date-header{color:var(--text-secondary);letter-spacing:.05em;text-transform:uppercase;margin-bottom:8px;padding-left:4px;font-size:.75rem;font-weight:700}.recent-expense-row{background:var(--surface);border-radius:var(--radius-md);border:1px solid var(--border);box-shadow:var(--shadow-sm);align-items:center;gap:10px;padding:10px 12px;display:flex}.recent-expense-icon{border-radius:11px;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;font-size:1.125rem;display:flex}.recent-expense-info{flex:1;min-width:0}.recent-expense-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:.875rem;font-weight:600;overflow:hidden}.recent-expense-meta{color:var(--text-secondary);align-items:center;gap:4px;margin-top:2px;font-size:.75rem;font-weight:500;display:flex}.recent-expense-amount{font-variant-numeric:tabular-nums;letter-spacing:-.01em;flex-shrink:0;font-size:.9375rem;font-weight:800}.quick-actions-grid{grid-template-columns:repeat(4,1fr);gap:10px;display:grid}.quick-action-btn{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;box-shadow:var(--shadow-sm);transition:all var(--transition-fast);-webkit-tap-highlight-color:transparent;flex-direction:column;align-items:center;gap:6px;padding:14px 6px;display:flex}.quick-action-btn:hover{border-color:var(--primary-400);background:var(--primary-50)}.quick-action-btn:active{transform:scale(.93)}.quick-action-icon{font-size:1.375rem}.quick-action-label{color:var(--text-secondary);text-align:center;font-size:.6875rem;font-weight:600;font-family:var(--font)}.expense-list-page{padding-bottom:calc(var(--nav-h) + 16px + var(--safe-bottom))}.expense-list-header{background:var(--primary-gradient);flex-direction:column;gap:16px;padding:52px 20px 20px;display:flex;position:relative;overflow:hidden}.expense-list-header:before{content:"";pointer-events:none;background:radial-gradient(circle,#ffffff1f 0%,#0000 70%);width:200px;height:200px;position:absolute;top:-40px;right:-40px}.expense-list-header:after{content:"";pointer-events:none;background:radial-gradient(circle,#7c3aed59 0%,#0000 70%);width:140px;height:140px;position:absolute;bottom:20px;left:-30px}.elh-top{z-index:1;justify-content:space-between;align-items:flex-start;display:flex;position:relative}.elh-month{color:#ffffffa6;letter-spacing:.06em;text-transform:uppercase;margin:0 0 4px;font-size:.75rem;font-weight:600}.elh-title{color:#fff;letter-spacing:-.04em;margin:0;font-size:2rem;font-weight:800;line-height:1}.elh-icon-btn{color:#fff;cursor:pointer;width:38px;height:38px;transition:background var(--transition-fast);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff26;border:1px solid #fff3;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.elh-icon-btn:hover{background:#ffffff40}.elh-stats{z-index:1;gap:8px;display:flex;position:relative}.elh-stat-pill{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);min-width:0;transition:background var(--transition-fast);background:#ffffff1f;border:1px solid #ffffff2e;border-radius:14px;flex:1;align-items:center;gap:8px;padding:10px 12px;display:flex}.elh-stat-pill:active{background:#fff3}.elh-stat-pill-accent{background:#ffffff38;border-color:#ffffff4d}.elh-stat-icon{flex-shrink:0;font-size:1.1rem;line-height:1}.elh-stat-value{color:#fff;font-variant-numeric:tabular-nums;letter-spacing:-.02em;white-space:nowrap;text-overflow:ellipsis;font-size:.9375rem;font-weight:800;line-height:1.1;overflow:hidden}.elh-stat-label{color:#ffffffa6;letter-spacing:.02em;margin-top:1px;font-size:.625rem;font-weight:500}.elh-top-cats{z-index:1;flex-wrap:wrap;gap:8px;display:flex;position:relative}.elh-cat-pill{border-radius:var(--radius-full);height:30px;font-family:var(--font);color:#ffffffd9;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;background:#ffffff1a;border:1px solid #ffffff2e;align-items:center;gap:5px;padding:0 10px;font-size:.75rem;font-weight:600;display:inline-flex}.elh-cat-pill:active{transform:scale(.95)}.elh-cat-pill-active{color:var(--cat-color,var(--primary-600));background:#fffffff2;border-color:#0000;box-shadow:0 2px 10px #00000026}.elh-cat-pill-label{text-overflow:ellipsis;max-width:60px;overflow:hidden}.elh-cat-pill-amount{color:inherit;opacity:.75;font-variant-numeric:tabular-nums;font-weight:700}.elh-cat-pill-active .elh-cat-pill-amount{opacity:1}.elh-search{border-radius:var(--radius-full);z-index:1;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);height:46px;transition:background var(--transition-fast), border-color var(--transition-fast), box-shadow var(--transition-fast);background:#ffffff26;border:1.5px solid #ffffff38;align-items:center;gap:10px;padding:0 14px;display:flex;position:relative}.elh-search-active{background:#fffffff5;border-color:#0000;box-shadow:0 4px 20px #00000026}.elh-search-active .elh-search-icon{color:var(--primary-500)}.elh-search-active .elh-search-input{color:var(--text-primary)}.elh-search-active .elh-search-input::placeholder{color:var(--text-tertiary)}.elh-search-icon{color:#ffffffb3;transition:color var(--transition-fast);flex-shrink:0}.elh-search-input{font-family:var(--font);color:#ffffffe6;background:0 0;border:none;outline:none;flex:1;min-width:0;font-size:.9375rem;font-weight:500}.elh-search-input::placeholder{color:#ffffff80;font-weight:400}.elh-search-clear{color:#fffc;cursor:pointer;width:24px;height:24px;transition:background var(--transition-fast);background:#fff3;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.elh-search-active .elh-search-clear{background:var(--surface-3);color:var(--text-secondary)}.elh-search-clear:hover{background:#ffffff59}.category-filter-row{gap:8px;padding:12px 16px 4px}.elh-results-bar{align-items:center;gap:8px;padding:8px 20px 0;display:flex}.elh-results-count{color:var(--text-primary);font-size:.8125rem;font-weight:700}.elh-results-total{color:var(--primary-500);font-variant-numeric:tabular-nums;font-size:.8125rem;font-weight:600}.elh-results-clear{color:var(--danger);background:var(--danger-bg);border-radius:var(--radius-full);cursor:pointer;font-size:.75rem;font-weight:600;font-family:var(--font);border:none;margin-left:auto;padding:3px 10px}.expense-group{margin-bottom:4px}.expense-date-label{color:var(--text-secondary);letter-spacing:.05em;text-transform:uppercase;justify-content:space-between;align-items:center;margin-bottom:8px;padding:0 4px;font-size:.75rem;font-weight:700;display:flex}.expense-group-total{font-variant-numeric:tabular-nums;color:var(--text-primary)}.reports-page{padding-bottom:calc(var(--nav-h) + 16px + var(--safe-bottom))}.reports-header{color:#fff;padding:48px 20px 0}.reports-tabs{border-radius:var(--radius-full);background:#ffffff1f;gap:4px;margin-top:16px;padding:4px;display:flex}.reports-tab{border-radius:var(--radius-full);height:36px;font-family:var(--font);color:#ffffffb3;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;background:0 0;border:none;flex:1;font-size:.8125rem;font-weight:600}.reports-tab-active{color:var(--primary-600);background:#fffffff2}.report-stats-grid{grid-template-columns:repeat(2,1fr);gap:10px;display:grid}.report-stat-card{background:var(--surface);border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-sm);flex-direction:column;gap:4px;padding:14px;display:flex}.report-stat-value{font-variant-numeric:tabular-nums;letter-spacing:-.02em;font-size:1.125rem;font-weight:800}.report-stat-label{color:var(--text-primary);font-size:.8125rem;font-weight:600}.report-stat-sub{color:var(--text-secondary);font-size:.6875rem}.top-expense-row{border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:8px 0;display:flex}.top-expense-row:last-child{border-bottom:none}.top-expense-rank{color:var(--text-tertiary);text-align:center;width:24px;font-size:.75rem;font-weight:700}.top-expense-icon{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:1.05rem;display:flex}.top-expense-info{flex:1;min-width:0}.top-expense-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:.875rem;font-weight:600;overflow:hidden}.top-expense-cat{margin-top:1px;font-size:.6875rem;font-weight:600}.top-expense-amount{font-variant-numeric:tabular-nums;flex-shrink:0;font-size:.9375rem;font-weight:800}.cat-breakdown-row{border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:8px 0;display:flex}.cat-breakdown-row:last-child{border-bottom:none}.cat-breakdown-icon{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:1.05rem;display:flex}.cat-breakdown-info{flex:1;min-width:0}.cat-breakdown-header{justify-content:space-between;align-items:center;display:flex}.cat-breakdown-name{color:var(--text-primary);font-size:.875rem;font-weight:600}.cat-breakdown-amount{color:var(--text-primary);font-variant-numeric:tabular-nums;font-size:.875rem;font-weight:700}.cat-breakdown-pct{color:var(--text-secondary);margin-top:4px;font-size:.6875rem}.member-report-header{align-items:center;gap:12px;display:flex}.download-section{text-align:center;padding:8px 4px 4px}.download-buttons{justify-content:center;gap:10px;display:flex}.download-btn{border-radius:var(--radius-full);background:var(--surface);border:1.5px solid var(--border-strong);height:40px;font-family:var(--font);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);box-shadow:var(--shadow-sm);align-items:center;gap:6px;padding:0 20px;font-size:.875rem;font-weight:600;display:flex}.download-btn:hover{border-color:var(--primary-400);color:var(--primary-500);background:var(--primary-50)}.settlement-page{padding-bottom:calc(var(--nav-h) + 16px + var(--safe-bottom));position:relative}.confetti-container{pointer-events:none;z-index:999;position:fixed;inset:0;overflow:hidden}.settlement-header{color:#fff;padding:48px 20px 24px}.settlement-header-top{justify-content:space-between;align-items:flex-start;margin-bottom:16px;display:flex}.settlement-title{color:#fff;letter-spacing:-.03em;margin:0;font-size:1.625rem;font-weight:800}.settlement-month{color:#ffffffbf;margin:2px 0 0;font-size:.875rem}.settlement-status-pill{border-radius:var(--radius-full);color:#ffffffe6;white-space:nowrap;background:#ffffff2e;border:1px solid #ffffff40;padding:4px 14px;font-size:.75rem;font-weight:700}.settlement-summary{border-radius:var(--radius-xl);align-items:center;padding:16px;display:flex}.settlement-summary-item{text-align:center;flex:1}.settlement-summary-value{color:#fff;font-variant-numeric:tabular-nums;letter-spacing:-.02em;font-size:1.125rem;font-weight:800}.settlement-summary-label{color:#ffffffb3;margin-top:2px;font-size:.6875rem;font-weight:500}.settlement-summary-divider{background:#fff3;align-self:stretch;width:1px;margin:4px 0}.member-balance-card{border-radius:var(--radius-lg);border:1.5px solid;align-items:center;gap:12px;padding:14px;display:flex}.balance-receive{background:#10b9810f;border-color:#10b98133}.balance-pay{background:#ef44440f;border-color:#ef444433}.balance-zero{background:var(--surface);border-color:var(--border)}.member-balance-info{flex:1;min-width:0}.member-balance-name{color:var(--text-primary);font-size:.9375rem;font-weight:700}.member-balance-bar{background:var(--surface-3);border-radius:var(--radius-full);height:4px;margin-top:6px;overflow:hidden}.member-balance-fill{border-radius:var(--radius-full);height:100%;transition:width 1s cubic-bezier(.4,0,.2,1)}.member-balance-status{flex-direction:column;align-items:flex-end;gap:4px;display:flex}.balance-badge{border-radius:var(--radius-full);white-space:nowrap;padding:3px 10px;font-size:.6875rem;font-weight:700}.balance-amount{font-variant-numeric:tabular-nums;letter-spacing:-.01em;font-size:.9375rem;font-weight:800}.txn-card{background:var(--surface);border-radius:var(--radius-xl);border:1.5px solid var(--border);box-shadow:var(--shadow-md);transition:opacity var(--transition-base);overflow:hidden}.txn-settled{opacity:.6}.txn-card-body{justify-content:space-between;align-items:center;gap:8px;padding:20px;display:flex}.txn-member{flex-direction:column;flex:1;align-items:center;gap:6px;display:flex}.txn-member-name{color:var(--text-primary);text-align:center;font-size:.875rem;font-weight:700}.txn-member-role{text-align:center;font-size:.6875rem;font-weight:600}.txn-arrow{flex-direction:column;flex:1;align-items:center;gap:4px;display:flex}.txn-amount{color:var(--primary-600);font-variant-numeric:tabular-nums;letter-spacing:-.02em;font-size:1rem;font-weight:800}.txn-arrow-line{align-items:center;gap:0;display:flex}.txn-arrow-head{color:var(--primary-400);font-size:1.5rem;animation:.5s cubic-bezier(.34,1.56,.64,1) both slideInRight}.txn-settle-btn{border:none;border-top:1px solid var(--border);background:var(--primary-50);width:100%;height:44px;font-family:var(--font);color:var(--primary-600);cursor:pointer;transition:all var(--transition-fast);font-size:.9375rem;font-weight:700}.txn-settle-btn:hover:not(:disabled){background:var(--primary-100)}.txn-settle-btn:active:not(:disabled){transform:scale(.98)}.txn-settle-btn-done{background:var(--success-bg)!important;color:var(--success)!important;cursor:default!important}.settlement-perfect,.settlement-celebration{background:var(--surface);border-radius:var(--radius-xl);border:2px dashed var(--border-strong);text-align:center;flex-direction:column;align-items:center;padding:32px 20px;display:flex}.profile-page{padding-bottom:calc(var(--nav-h) + 16px + var(--safe-bottom))}.profile-header{color:#fff;flex-direction:column;align-items:center;gap:8px;padding:48px 20px 24px;display:flex}.profile-avatar-wrapper{margin-bottom:4px;position:relative}.profile-edit-avatar{background:var(--warning);border:2.5px solid var(--bg);cursor:pointer;width:26px;height:26px;transition:transform var(--transition-spring);border-radius:50%;justify-content:center;align-items:center;font-size:.75rem;display:flex;position:absolute;bottom:0;right:-2px}.profile-edit-avatar:hover{transform:scale(1.15)}.profile-name{color:#fff;letter-spacing:-.03em;font-size:1.5rem;font-weight:800}.profile-email{color:#ffffffbf;font-size:.875rem}.profile-role-badge{margin-top:2px}.profile-stats{background:var(--surface);border-bottom:1px solid var(--border);box-shadow:var(--shadow-sm);align-items:center;display:flex}.profile-stat{text-align:center;flex:1;padding:14px 8px}.profile-stat-value{color:var(--text-primary);font-variant-numeric:tabular-nums;letter-spacing:-.02em;font-size:1rem;font-weight:800}.profile-stat-label{color:var(--text-secondary);margin-top:2px;font-size:.6875rem;font-weight:500}.profile-stat-divider{background:var(--border);width:1px;height:36px}.profile-member-row{border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:10px 0;display:flex}.profile-member-row:last-child{border-bottom:none}.setting-row{border-bottom:1px solid var(--border);cursor:pointer;transition:background var(--transition-fast);align-items:center;gap:12px;padding:14px 16px;display:flex}.setting-row:last-child{border-bottom:none}.setting-row:hover{background:var(--surface-2)}.setting-icon{text-align:center;flex-shrink:0;width:28px;font-size:1.125rem}.setting-label{color:var(--text-primary);flex:1;font-size:.9375rem;font-weight:500}.setting-right{align-items:center;gap:8px;display:flex}.setting-badge{color:var(--text-secondary);background:var(--surface-2);border-radius:var(--radius-full);border:1px solid var(--border);padding:2px 8px;font-size:.75rem;font-weight:600}.setting-arrow{color:var(--text-tertiary);font-size:1.25rem}.toggle-pill{background:var(--surface-3);border-radius:var(--radius-full);width:44px;height:24px;transition:background var(--transition-base);border:1px solid var(--border);position:relative}.toggle-on{background:var(--primary-gradient);border-color:#0000}.toggle-thumb{width:18px;height:18px;transition:transform var(--transition-spring);background:#fff;border-radius:50%;position:absolute;top:2px;left:2px;box-shadow:0 1px 4px #0003}.toggle-on .toggle-thumb{transform:translate(20px)}.logout-btn{border-radius:var(--radius-lg);background:var(--danger-bg);width:100%;height:52px;font-family:var(--font);color:var(--danger);cursor:pointer;transition:all var(--transition-fast);border:1.5px solid #ef444433;font-size:1rem;font-weight:700}.logout-btn:hover{background:#ef444426}.logout-btn:active{transform:scale(.98)}.btn{font-family:var(--font);cursor:pointer;border-radius:var(--radius-full);transition:transform var(--transition-fast), box-shadow var(--transition-fast), background var(--transition-fast), opacity var(--transition-fast);letter-spacing:-.01em;white-space:nowrap;-webkit-user-select:none;user-select:none;border:none;justify-content:center;align-items:center;gap:8px;font-weight:600;text-decoration:none;display:inline-flex;position:relative;overflow:hidden}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-sm{height:36px;padding:0 16px;font-size:.8125rem}.btn-md{height:48px;padding:0 24px;font-size:.9375rem}.btn-lg{height:56px;padding:0 32px;font-size:1.0625rem}.btn-full{width:100%}.btn-primary{background:var(--primary-gradient);color:#fff;box-shadow:0 4px 16px #6366f159}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 24px #6366f180}.btn-secondary{background:var(--primary-50);color:var(--primary-600);box-shadow:none}.btn-secondary:hover:not(:disabled){background:var(--primary-100)}.btn-ghost{color:var(--text-secondary);background:0 0}.btn-ghost:hover:not(:disabled){background:var(--surface-2);color:var(--text-primary)}.btn-danger{background:var(--danger);color:#fff;box-shadow:0 4px 16px #ef44444d}.btn-success{background:var(--success);color:#fff;box-shadow:0 4px 16px #10b9814d}.btn-spinner{border:2px solid #fff6;border-top-color:#fff;border-radius:50%;width:18px;height:18px;animation:.7s linear infinite spin}.btn-icon-left,.btn-icon-right{align-items:center;font-size:1.1em;display:flex}.input-wrapper{width:100%;position:relative}.input-field{background:var(--surface);border:1.5px solid var(--border-strong);border-radius:var(--radius-md);width:100%;height:56px;font-family:var(--font);color:var(--text-primary);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);box-shadow:var(--shadow-sm);outline:none;padding:0 16px;font-size:1rem;font-weight:500}.input-field:focus{border-color:var(--primary-500);box-shadow:0 0 0 3px #6366f126}.input-field::placeholder{color:var(--text-tertiary);font-weight:400}.input-label{color:var(--text-tertiary);pointer-events:none;transition:all var(--transition-fast);background:0 0;font-size:.9375rem;font-weight:400;position:absolute;top:50%;left:16px;transform:translateY(-50%)}.input-field:focus~.input-label,.input-has-value~.input-label{color:var(--primary-500);letter-spacing:.05em;background:var(--surface);padding:0 4px;font-size:.6875rem;font-weight:600;top:0;transform:translateY(-50%)}.input-icon{color:var(--text-secondary);font-size:1.1rem;position:absolute;top:50%;right:16px;transform:translateY(-50%)}.input-error .input-field{border-color:var(--danger);box-shadow:0 0 0 3px #ef44441a}.input-helper{color:var(--text-secondary);margin-top:6px;padding-left:4px;font-size:.75rem}.input-error .input-helper{color:var(--danger)}.card{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);border:1px solid var(--border);transition:transform var(--transition-fast), box-shadow var(--transition-fast);overflow:hidden}.card-elevated{box-shadow:var(--shadow-md)}.card-pressable{cursor:pointer}.card-pressable:active{transform:scale(.985)}.card-body{padding:16px}.card-body-lg{padding:20px}.avatar{font-weight:700;font-family:var(--font);-webkit-user-select:none;user-select:none;border:2px solid #ffffff80;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.avatar-xs{width:28px;height:28px;font-size:.625rem}.avatar-sm{width:36px;height:36px;font-size:.75rem}.avatar-md{width:44px;height:44px;font-size:.875rem}.avatar-lg{width:56px;height:56px;font-size:1.125rem}.avatar-xl{width:72px;height:72px;font-size:1.5rem}.badge{border-radius:var(--radius-full);letter-spacing:.03em;text-transform:uppercase;align-items:center;gap:4px;padding:2px 10px;font-size:.6875rem;font-weight:700;display:inline-flex}.badge-success{background:var(--success-bg);color:var(--success)}.badge-danger{background:var(--danger-bg);color:var(--danger)}.badge-warning{background:var(--warning-bg);color:var(--warning)}.badge-info{background:var(--info-bg);color:var(--info)}.badge-primary{background:var(--primary-50);color:var(--primary-600)}.badge-neutral{background:var(--surface-3);color:var(--text-secondary)}.chip{border-radius:var(--radius-full);background:var(--surface-2);border:1.5px solid var(--border);height:36px;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;align-items:center;gap:6px;padding:0 14px;font-size:.8125rem;font-weight:500;display:inline-flex}.chip:hover{border-color:var(--primary-400);color:var(--primary-500)}.chip-active{background:var(--primary-50);border-color:var(--primary-400);color:var(--primary-600);font-weight:600}.sheet-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;background:#00000080;align-items:flex-end;animation:.2s both fadeIn;display:flex;position:fixed;inset:0}.sheet-container{background:var(--surface);border-radius:var(--radius-2xl) var(--radius-2xl) 0 0;width:100%;max-width:480px;padding-bottom:calc(var(--space-6) + var(--safe-bottom));max-height:90dvh;margin:0 auto;animation:.35s cubic-bezier(.34,1.56,.64,1) both slideUp;overflow-y:auto}.sheet-handle{background:var(--border-strong);border-radius:var(--radius-full);width:40px;height:4px;margin:12px auto 0}.sheet-header{justify-content:space-between;align-items:center;padding:16px 20px 8px;display:flex}.sheet-title{color:var(--text-primary);font-size:1.125rem;font-weight:700}.sheet-close{background:var(--surface-2);cursor:pointer;width:32px;height:32px;color:var(--text-secondary);transition:background var(--transition-fast);border:none;border-radius:50%;justify-content:center;align-items:center;font-size:1rem;display:flex}.sheet-close:hover{background:var(--surface-3)}.snackbar{bottom:calc(var(--nav-h) + 16px + var(--safe-bottom));z-index:500;border-radius:var(--radius-full);background:var(--text-primary);color:var(--bg);white-space:nowrap;align-items:center;gap:10px;max-width:calc(100vw - 32px);padding:12px 20px;font-size:.875rem;font-weight:500;animation:.3s cubic-bezier(.34,1.56,.64,1) both fadeInUp;display:flex;position:fixed;left:50%;transform:translate(-50%);box-shadow:0 8px 32px #00000040}.snackbar-success{background:var(--success);color:#fff}.snackbar-danger{background:var(--danger);color:#fff}.snackbar-info{background:var(--primary-600);color:#fff}.empty-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:48px 32px;display:flex}.empty-icon{font-size:3.5rem;animation:3s ease-in-out infinite floatUp}.empty-title{color:var(--text-primary);font-size:1.125rem;font-weight:700}.empty-desc{color:var(--text-secondary);max-width:240px;font-size:.875rem;line-height:1.6}.progress-bar-track{background:var(--surface-3);border-radius:var(--radius-full);width:100%;height:6px;overflow:hidden}.progress-bar-fill{border-radius:var(--radius-full);height:100%;transition:width .8s cubic-bezier(.4,0,.2,1)}
