@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swap";.login-root{min-height:100vh;min-height:100dvh;background:var(--bg-surface);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;padding:24px 20px;padding-top:calc(24px + env(safe-area-inset-top));padding-bottom:calc(24px + env(safe-area-inset-bottom))}.login-bg-circle-1{position:absolute;top:-80px;right:-80px;width:260px;height:260px;border-radius:50%;background:radial-gradient(circle,rgba(124,58,237,.08) 0%,transparent 70%);pointer-events:none}.login-bg-circle-2{position:absolute;bottom:-60px;left:-60px;width:220px;height:220px;border-radius:50%;background:radial-gradient(circle,rgba(245,158,11,.08) 0%,transparent 70%);pointer-events:none}.login-container{width:100%;max-width:360px;display:flex;flex-direction:column;gap:24px;position:relative;z-index:1}.login-logo-section{display:flex;flex-direction:column;align-items:center;gap:8px}.login-logo-wrap{width:72px;height:72px;border-radius:20px;background:var(--bg-surface);box-shadow:var(--shadow-md);display:flex;align-items:center;justify-content:center;overflow:hidden;border:1px solid var(--border-subtle)}.login-logo{width:54px;height:54px;object-fit:contain}.login-brand{font-size:24px;font-weight:800;color:var(--text-primary);letter-spacing:-.02em;margin-top:4px}.login-tagline{font-size:13px;color:var(--text-tertiary);font-weight:400}.login-card{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);box-shadow:var(--shadow-md);padding:24px 20px;display:flex;flex-direction:column;gap:20px}.login-card-header{display:flex;flex-direction:column;gap:4px}.login-title{font-size:20px;font-weight:700;color:var(--text-primary)}.login-desc{font-size:14px;color:var(--text-tertiary)}.login-error{display:flex;align-items:center;gap:8px;padding:10px 14px;background:var(--danger-bg);border:1px solid rgba(239,68,68,.2);border-radius:var(--radius-md);color:var(--danger);font-size:13px;font-weight:500}.login-form{display:flex;flex-direction:column;gap:16px}.login-footer{text-align:center;font-size:13px;color:var(--text-tertiary)}.login-link{color:var(--brand-primary);font-weight:600;text-decoration:none}.login-link:hover{text-decoration:underline}.top-header{position:fixed;top:0;left:50%;transform:translate(-50%);width:100%;max-width:var(--app-max-width);height:var(--top-header-h);background:#fffffff2;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-bottom:1px solid var(--border-subtle);z-index:400;padding-top:env(safe-area-inset-top)}.top-header.transparent{background:transparent;border-bottom-color:transparent;-webkit-backdrop-filter:none;backdrop-filter:none}.top-header-inner{height:100%;display:flex;align-items:center;justify-content:space-between;padding:0 16px;gap:12px}.header-logo-wrap{display:flex;align-items:center}.header-logo{height:32px;width:auto;object-fit:contain}.header-title-wrap{flex:1}.header-title{font-size:18px;font-weight:700;color:var(--text-primary);line-height:1.2}.header-subtitle{font-size:12px;color:var(--text-tertiary);font-weight:400;margin-top:1px}.header-right{display:flex;align-items:center;gap:8px;flex-shrink:0}.bottom-nav{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:var(--app-max-width);height:var(--bottom-nav-h);background:#fffffff2;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-top:1px solid var(--border-subtle);display:flex;align-items:center;justify-content:space-around;z-index:500;padding-bottom:env(safe-area-inset-bottom)}.nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;flex:1;height:100%;color:var(--text-tertiary);transition:color var(--dur-fast) var(--ease-smooth);position:relative;text-decoration:none;padding:4px 8px}.nav-item:active{transform:scale(.92)}.nav-item.active{color:var(--brand-primary)}.nav-icon{position:relative;z-index:1;transition:transform var(--dur-fast) var(--ease-bounce)}.nav-item.active .nav-icon{transform:translateY(-2px)}.nav-label{font-size:10px;font-weight:600;letter-spacing:.02em;line-height:1}.nav-indicator{position:absolute;top:0;left:50%;transform:translate(-50%);width:32px;height:3px;background:var(--brand-primary);border-radius:0 0 4px 4px}.page-dashboard{padding-left:0;padding-right:0}.greeting-section{padding:20px 16px 0}.greeting-text{font-size:14px;color:var(--text-tertiary);font-weight:400}.greeting-name{font-size:22px;font-weight:800;color:var(--text-primary);letter-spacing:-.02em;margin-top:2px}.notif-btn{width:38px;height:38px;border-radius:50%;background:var(--bg-surface-2);display:flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:all var(--dur-fast) var(--ease-smooth);border:1px solid var(--border-subtle)}.notif-btn:hover{background:var(--bg-surface-3)}.notif-btn:active{transform:scale(.92)}.sub-card{margin:16px 16px 0;background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);box-shadow:var(--shadow-md);overflow:hidden}.sub-card-header{display:flex;align-items:flex-start;justify-content:space-between;padding:16px 16px 12px;border-bottom:1px solid var(--border-subtle)}.sub-card-label{font-size:12px;text-transform:uppercase;letter-spacing:.06em;color:var(--text-tertiary);font-weight:600;margin-bottom:4px}.sub-card-plan{font-size:18px;font-weight:700;color:var(--text-primary)}.sub-card-body{padding:16px;display:flex;flex-direction:column;gap:16px}.sub-info-rows{width:100%;display:flex;flex-direction:column;gap:12px}.sub-info-row{display:flex;align-items:center;justify-content:space-between;padding-bottom:8px;border-bottom:1px dashed var(--border-subtle)}.sub-info-row:last-child{padding-bottom:0;border-bottom:none}.sir-label{font-size:13px;color:var(--text-tertiary);font-weight:500}.sir-value{font-size:14px;color:var(--text-primary);font-weight:600}.sub-card-progress{width:100%;margin-top:4px}.progress-bar-wrap{display:flex;flex-direction:column;gap:8px}.pb-header{display:flex;align-items:center;justify-content:space-between}.pb-label{font-size:12px;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.04em}.pb-value{font-size:14px;font-weight:700;color:var(--brand-primary)}.pb-track{width:100%;height:6px;background:var(--bg-surface-2);border-radius:var(--radius-full);overflow:hidden}.pb-fill{height:100%;background:linear-gradient(90deg,var(--brand-primary),var(--brand-primary-light));border-radius:var(--radius-full);transition:width 1s var(--ease-smooth)}.sub-info-rows{flex:1;display:flex;flex-direction:column;gap:10px}.sub-info-row{display:flex;align-items:center;justify-content:space-between}.sir-label{font-size:12px;color:var(--text-tertiary);font-weight:500}.sir-value{font-size:13px;color:var(--text-primary);font-weight:600}.no-sub{padding:16px;display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center}.no-sub-text{font-size:14px;color:var(--text-tertiary)}.section-title{font-size:14px;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;margin-bottom:12px}.quick-section{padding:20px 16px 0}.quick-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.quick-card{display:flex;flex-direction:column;align-items:flex-start;gap:8px;padding:14px 14px 16px;background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);box-shadow:var(--shadow-xs);text-align:left;cursor:pointer;transition:all var(--dur-normal) var(--ease-smooth)}.quick-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.quick-card:active{transform:translateY(0);box-shadow:var(--shadow-xs)}.quick-icon{width:42px;height:42px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center}.quick-label{font-size:14px;font-weight:700;color:var(--text-primary)}.quick-desc{font-size:11px;color:var(--text-tertiary);font-weight:400;line-height:1.4}.info-banner{margin:16px;display:flex;align-items:center;gap:10px;padding:14px;border-radius:var(--radius-lg)}.info-banner-danger{background:var(--danger-bg);border:1px solid rgba(239,68,68,.2);color:var(--danger)}.info-banner>svg{flex-shrink:0}.ib-title{font-size:13px;font-weight:700;color:var(--danger)}.ib-desc{font-size:12px;color:#dc2626;margin-top:1px}.info-banner .btn{margin-left:auto;flex-shrink:0}.token-summary{padding:0 16px;margin-top:16px}.token-summary-list{display:flex;flex-direction:column;gap:8px}.ts-item{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:12px 14px;background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-md);box-shadow:var(--shadow-xs)}.ts-code{font-family:Courier New,monospace;font-size:13px;font-weight:700;color:var(--text-primary);letter-spacing:.06em}.source-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0006;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:1.5rem;animation:fadeIn .3s ease}.source-modal{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);width:100%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:slideUp var(--dur-normal) var(--ease-bounce);display:flex;flex-direction:column}.source-modal-header{padding:1.5rem;border-bottom:1px solid var(--border-subtle);display:flex;justify-content:space-between;align-items:center;background:var(--bg-surface-2);border-radius:var(--radius-xl) var(--radius-xl) 0 0}.source-modal-header h3{font-size:1.25rem;font-weight:700;color:var(--text-primary);margin:0}.source-modal-header p{font-size:.875rem;color:var(--text-secondary);margin:.25rem 0 0}.btn-close{background:var(--bg-surface);border:1px solid var(--border-subtle);color:var(--text-secondary);width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;box-shadow:var(--shadow-xs)}.btn-close:hover{background:var(--bg-surface-3);color:var(--text-primary)}.source-modal-body{padding:1.5rem;display:flex;flex-direction:column;gap:1.25rem}.source-type-toggle{display:flex;background:var(--bg-surface-2);border-radius:var(--radius-md);padding:.25rem;border:1px solid var(--border-subtle)}.source-type-btn{flex:1;padding:.75rem;background:transparent;border:none;border-radius:calc(var(--radius-md) - .25rem);color:var(--text-secondary);font-weight:600;font-size:.875rem;cursor:pointer;transition:all .3s}.source-type-btn.active{background:var(--bg-surface);color:var(--brand-primary);box-shadow:var(--shadow-sm);border:1px solid var(--border-subtle)}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.875rem;font-weight:600;color:var(--text-primary)}.form-group input{background:var(--bg-surface-2);border:1px solid var(--border-subtle);padding:.875rem 1rem;border-radius:var(--radius-md);color:var(--text-primary);font-size:1rem;transition:all .2s}.form-group input:focus{outline:none;border-color:var(--brand-primary);background:var(--bg-surface);box-shadow:0 0 0 3px #7c3aed26}.form-group input::placeholder{color:var(--text-tertiary)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.source-modal-footer{padding:1.25rem 1.5rem;border-top:1px solid var(--border-subtle);display:flex;justify-content:flex-end;gap:1rem;background:var(--bg-surface-2);border-radius:0 0 var(--radius-xl) var(--radius-xl)}.source-modal-footer .btn{padding:.875rem 1.5rem}.error-message{background:var(--danger-bg);border:1px solid rgba(239,68,68,.2);color:var(--danger);padding:1rem;border-radius:var(--radius-md);font-size:.875rem;display:flex;gap:.75rem;align-items:center}.tokens-info-bar{display:flex;align-items:center;justify-content:space-around;margin-top:16px;padding:16px;background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);box-shadow:var(--shadow-xs)}.tib-item{display:flex;flex-direction:column;align-items:center;gap:2px}.tib-value{font-size:22px;font-weight:800;color:var(--text-primary);line-height:1}.tib-label{font-size:11px;color:var(--text-tertiary);font-weight:500;text-transform:uppercase;letter-spacing:.04em}.tib-divider{width:1px;height:32px;background:var(--border-subtle)}.redeem-card{margin-top:16px;background:linear-gradient(135deg,#faf5ff,#f5f3ff);border:1px solid rgba(124,58,237,.15);border-radius:var(--radius-xl);padding:24px 16px;display:flex;flex-direction:column;align-items:center;gap:8px;text-align:center}.redeem-icon-wrap{width:56px;height:56px;border-radius:var(--radius-lg);background:#7c3aed1f;display:flex;align-items:center;justify-content:center;color:var(--brand-primary);margin-bottom:4px}.redeem-title{font-size:18px;font-weight:700;color:var(--text-primary)}.redeem-desc{font-size:13px;color:var(--text-tertiary);max-width:260px;line-height:1.5}.tokens-divider{display:flex;align-items:center;gap:10px;margin:20px 0 14px;color:var(--text-tertiary);font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.06em}.tokens-divider:before,.tokens-divider:after{content:"";flex:1;height:1px;background:var(--border-subtle)}.tokens-loading{display:flex;flex-direction:column;gap:8px}.token-skeleton{height:110px;border-radius:var(--radius-lg)}.tokens-list{list-style:none;display:flex;flex-direction:column;gap:10px}.token-item{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:14px 16px;display:flex;flex-direction:column;gap:8px;box-shadow:var(--shadow-xs)}.token-item-top{display:flex;align-items:center;justify-content:space-between;gap:8px}.token-code{font-family:Courier New,monospace;font-size:16px;font-weight:700;color:var(--text-primary);letter-spacing:.06em}.token-meta-grid{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.token-plan-badge{font-size:11px;font-weight:700;color:var(--brand-primary);background:#7c3aed14;padding:2px 8px;border-radius:var(--radius-full)}.token-platform{font-size:11px;font-weight:600;color:var(--text-tertiary);background:var(--bg-surface-2);padding:2px 8px;border-radius:var(--radius-full)}.token-days-bar{padding-top:2px}.token-days-label{display:flex;justify-content:space-between;font-size:11px;color:var(--text-tertiary);margin-bottom:5px}.token-bar{height:4px;background:var(--bg-surface-2);border-radius:var(--radius-full);overflow:hidden}.token-bar-fill{height:100%;background:linear-gradient(90deg,var(--brand-primary),var(--brand-primary-light));border-radius:var(--radius-full);transition:width .8s var(--ease-smooth)}.token-item-bottom{display:flex;align-items:center;justify-content:space-between;gap:8px}.token-meta{display:flex;align-items:center;gap:5px;color:var(--text-tertiary);font-size:12px}.token-no-device{font-size:12px;color:var(--text-tertiary);font-style:italic}.profile-avatar-section{display:flex;align-items:center;gap:16px;margin-top:16px;padding:20px;background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm)}.profile-avatar{width:64px;height:64px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:26px;font-weight:800;color:#fff;flex-shrink:0;letter-spacing:-.02em}.profile-avatar-info{flex:1;min-width:0}.profile-name{font-size:18px;font-weight:700;color:var(--text-primary);letter-spacing:-.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.profile-email{font-size:13px;color:var(--text-tertiary);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.profile-status-dot{display:inline-flex;align-items:center;margin-top:6px;padding:3px 10px;border-radius:var(--radius-full);font-size:11px;font-weight:700;color:#fff;text-transform:uppercase;letter-spacing:.04em}.header-action-btn{display:flex;align-items:center;gap:5px;padding:7px 12px;border-radius:var(--radius-md);background:#7c3aed14;color:var(--brand-primary);font-size:13px;font-weight:600;border:none;cursor:pointer;transition:all var(--dur-fast) var(--ease-smooth)}.header-action-btn:hover{background:#7c3aed24}.header-action-btn:active{transform:scale(.95)}.form-section-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-tertiary);margin-bottom:14px}.profile-form{margin-top:12px;background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);padding:20px 16px;display:flex;flex-direction:column;gap:14px;box-shadow:var(--shadow-sm)}.form-actions{display:flex;gap:10px;margin-top:4px}.form-actions .btn{flex:1}.profile-info-card{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);padding:20px 16px;display:flex;flex-direction:column;gap:0;box-shadow:var(--shadow-xs)}.info-row{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:12px 0;border-bottom:1px solid var(--border-subtle)}.info-row:last-child{border-bottom:none;padding-bottom:0}.info-row:first-of-type{padding-top:0}.info-row-label{font-size:13px;color:var(--text-tertiary);font-weight:500;flex-shrink:0}.info-row-value{font-size:14px;color:var(--text-primary);font-weight:600;text-align:right;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:200px}.profile-logout-wrap{margin-top:16px;margin-bottom:8px}.logout-modal-desc{font-size:14px;color:var(--text-secondary);line-height:1.6;margin-bottom:20px}.logout-modal-actions{display:flex;flex-direction:column;gap:8px}:root{--brand-primary: #3b82f6;--brand-primary-light: #60a5fa;--brand-primary-dark: #2563eb;--brand-accent: #f59e0b;--brand-accent-light: #fbbf24;--bg-root: #f8f9fc;--bg-surface: #ffffff;--bg-surface-2: #f1f3f8;--bg-surface-3: #e8ecf4;--text-primary: #0f172a;--text-secondary: #475569;--text-tertiary: #94a3b8;--text-on-brand: #ffffff;--border-subtle: rgba(15, 23, 42, .08);--border-medium: rgba(15, 23, 42, .14);--success: #10b981;--success-bg: #ecfdf5;--warning: #f59e0b;--warning-bg: #fffbeb;--danger: #ef4444;--danger-bg: #fef2f2;--info: #3b82f6;--info-bg: #eff6ff;--shadow-xs: 0 1px 2px rgba(0,0,0,.05);--shadow-sm: 0 2px 8px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 4px 16px rgba(0,0,0,.08), 0 2px 4px rgba(0,0,0,.04);--shadow-lg: 0 8px 32px rgba(0,0,0,.1), 0 4px 8px rgba(0,0,0,.05);--shadow-brand: 0 4px 20px rgba(59, 130, 246, .25);--font: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--radius-full: 9999px;--app-max-width: 430px;--bottom-nav-h: 64px;--top-header-h: 60px;--ease-bounce: cubic-bezier(.34, 1.56, .64, 1);--ease-smooth: cubic-bezier(.4, 0, .2, 1);--dur-fast: .15s;--dur-normal: .25s;--dur-slow: .35s}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}html{font-size:16px;-webkit-text-size-adjust:100%;scroll-behavior:smooth}body{font-family:var(--font);background:var(--bg-root);color:var(--text-primary);min-height:100vh;min-height:100dvh;overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{display:flex;flex-direction:column;min-height:100vh;min-height:100dvh}img,svg{display:block}button{cursor:pointer;border:none;background:none;font-family:inherit}a{text-decoration:none;color:inherit}input,textarea,select{font-family:inherit}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-medium);border-radius:var(--radius-full)}.app-shell{width:100%;max-width:var(--app-max-width);margin:0 auto;min-height:100vh;min-height:100dvh;background:var(--bg-surface);position:relative;box-shadow:0 0 60px #0000001a}.page{padding-top:var(--top-header-h);padding-bottom:calc(var(--bottom-nav-h) + 16px);min-height:100vh;min-height:100dvh}.page-content{padding:0 16px}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.skeleton{background:linear-gradient(90deg,var(--bg-surface-2) 25%,var(--bg-surface-3) 50%,var(--bg-surface-2) 75%);background-size:200% 100%;animation:skeleton-shimmer 1.5s infinite;border-radius:var(--radius-sm)}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes fadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse-ring{0%{transform:scale(.95);box-shadow:0 0 #7c3aed66}70%{transform:scale(1);box-shadow:0 0 0 10px #7c3aed00}to{transform:scale(.95);box-shadow:0 0 #7c3aed00}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes countUp{0%{transform:translateY(8px);opacity:0}to{transform:translateY(0);opacity:1}}.animate-in{animation:fadeIn var(--dur-slow) var(--ease-smooth) both}.animate-in-delay-1{animation-delay:60ms}.animate-in-delay-2{animation-delay:.12s}.animate-in-delay-3{animation-delay:.18s}.animate-in-delay-4{animation-delay:.24s}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:var(--radius-full);font-size:11px;font-weight:600;letter-spacing:.02em;text-transform:uppercase}.badge-success{background:var(--success-bg);color:var(--success)}.badge-warning{background:var(--warning-bg);color:var(--warning)}.badge-danger{background:var(--danger-bg);color:var(--danger)}.badge-info{background:var(--info-bg);color:var(--info)}.badge-brand{background:#7c3aed1a;color:var(--brand-primary)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 20px;border-radius:var(--radius-md);font-size:15px;font-weight:600;transition:all var(--dur-fast) var(--ease-smooth);white-space:nowrap;position:relative;overflow:hidden}.btn:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:#fff0;transition:background var(--dur-fast)}.btn:active:after{background:#ffffff26}.btn:disabled{opacity:.5;pointer-events:none}.btn-primary{background:linear-gradient(135deg,var(--brand-primary),var(--brand-primary-light));color:#fff;box-shadow:var(--shadow-brand)}.btn-primary:hover{filter:brightness(1.05);transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:var(--bg-surface-2);color:var(--text-primary)}.btn-secondary:hover{background:var(--bg-surface-3)}.btn-outline{background:transparent;color:var(--brand-primary);border:1.5px solid rgba(124,58,237,.3)}.btn-outline:hover{background:#7c3aed0f;border-color:var(--brand-primary)}.btn-danger{background:var(--danger-bg);color:var(--danger)}.btn-danger:hover{background:#fee2e2}.btn-full{width:100%}.btn-sm{padding:8px 14px;font-size:13px;border-radius:var(--radius-sm)}.btn-lg{padding:15px 24px;font-size:16px}.spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}.spinner-brand{border-color:#7c3aed33;border-top-color:var(--brand-primary)}.card{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}.card-pad{padding:16px}.card-hover{transition:all var(--dur-normal) var(--ease-smooth);cursor:pointer}.card-hover:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.card-hover:active{transform:translateY(0);box-shadow:var(--shadow-sm)}.divider{height:1px;background:var(--border-subtle);border:none;margin:0}.form-group{display:flex;flex-direction:column;gap:6px}.form-label{font-size:13px;font-weight:600;color:var(--text-secondary)}.form-input{width:100%;padding:12px 14px;background:var(--bg-surface-2);border:1.5px solid transparent;border-radius:var(--radius-md);font-size:15px;color:var(--text-primary);transition:all var(--dur-fast) var(--ease-smooth);outline:none}.form-input::placeholder{color:var(--text-tertiary)}.form-input:focus{background:var(--bg-surface);border-color:var(--brand-primary);box-shadow:0 0 0 3px #7c3aed1f}.form-input.error{border-color:var(--danger)}.form-hint{font-size:12px;color:var(--text-tertiary)}.form-error{font-size:12px;color:var(--danger)}.input-wrapper{position:relative}.input-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-tertiary);pointer-events:none}.input-wrapper .form-input{padding-left:40px}.input-icon-right{position:absolute;right:12px;top:50%;transform:translateY(-50%);color:var(--text-tertiary);cursor:pointer}.toast-container{position:fixed;bottom:calc(var(--bottom-nav-h) + 16px);left:50%;transform:translate(-50%);z-index:9999;display:flex;flex-direction:column;gap:8px;width:calc(100% - 32px);max-width:400px}.toast{display:flex;align-items:center;gap:10px;padding:12px 16px;background:var(--text-primary);color:#fff;border-radius:var(--radius-md);box-shadow:var(--shadow-lg);font-size:14px;font-weight:500;animation:slideUp var(--dur-normal) var(--ease-bounce)}.toast-success{background:var(--success)}.toast-error{background:var(--danger)}.toast-warning{background:var(--warning);color:var(--text-primary)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:900;display:flex;align-items:flex-end;justify-content:center}.modal-sheet{background:var(--bg-surface);border-radius:var(--radius-xl) var(--radius-xl) 0 0;width:100%;max-width:var(--app-max-width);padding:24px 20px;padding-bottom:calc(24px + env(safe-area-inset-bottom));animation:slideUp var(--dur-normal) var(--ease-bounce)}.modal-handle{width:36px;height:4px;background:var(--border-medium);border-radius:var(--radius-full);margin:0 auto 20px}.modal-title{font-size:18px;font-weight:700;margin-bottom:16px}.empty-state{display:flex;flex-direction:column;align-items:center;gap:12px;padding:48px 24px;text-align:center}.empty-icon{width:64px;height:64px;border-radius:var(--radius-full);background:var(--bg-surface-2);display:flex;align-items:center;justify-content:center;color:var(--text-tertiary)}.empty-title{font-size:16px;font-weight:600;color:var(--text-secondary)}.empty-desc{font-size:14px;color:var(--text-tertiary)}.loading-page{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg-surface);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;z-index:9999}
