.upload-page[data-v-c73c45b9]{display:flex;flex-direction:column;gap:20px;flex:1}.preview-section[data-v-c73c45b9]{display:flex;flex-direction:column;gap:16px;align-items:center}.preview-container[data-v-c73c45b9]{position:relative;width:100%;max-width:320px;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}.preview-img[data-v-c73c45b9]{width:100%;height:auto;display:block;aspect-ratio:3/4;object-fit:cover}.btn-remove[data-v-c73c45b9]{position:absolute;top:8px;right:8px;width:32px;height:32px;border-radius:50%;border:none;background:#00000080;color:#fff;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center}.preview-actions[data-v-c73c45b9]{display:flex;flex-direction:column;gap:12px;width:100%}.drop-zone[data-v-c73c45b9]{border:2px dashed var(--border);border-radius:var(--radius);padding:40px 20px;text-align:center;cursor:pointer;transition:all .2s;background:var(--card-bg)}.drop-zone[data-v-c73c45b9]:hover,.drop-zone.drag-over[data-v-c73c45b9]{border-color:var(--primary);background:#f5f3ff}.drop-icon[data-v-c73c45b9]{font-size:48px;margin-bottom:12px}.drop-text[data-v-c73c45b9]{font-size:16px;font-weight:500;color:var(--text)}.drop-hint[data-v-c73c45b9]{font-size:13px;color:var(--text-secondary);margin-top:8px}.upload-actions[data-v-c73c45b9]{display:flex;gap:12px}.btn[data-v-c73c45b9]{display:flex;align-items:center;justify-content:center;gap:8px;padding:14px 24px;border-radius:12px;border:none;font-size:16px;font-weight:500;cursor:pointer;transition:all .2s;width:100%}.btn-camera[data-v-c73c45b9]{background:var(--primary);color:#fff}.btn-camera[data-v-c73c45b9]:hover{background:var(--primary-dark)}.btn-gallery[data-v-c73c45b9]{background:var(--card-bg);color:var(--text);border:2px solid var(--border)}.btn-gallery[data-v-c73c45b9]:hover{border-color:var(--primary)}.btn-primary[data-v-c73c45b9]{background:linear-gradient(135deg,var(--primary),#7c3aed);color:#fff;font-size:18px;padding:16px 24px}.btn-primary[data-v-c73c45b9]:hover{opacity:.9}.btn-outline[data-v-c73c45b9]{background:transparent;color:var(--text-secondary);border:1px solid var(--border);padding:12px 24px}.btn-outline[data-v-c73c45b9]:hover{background:var(--bg)}.error-msg[data-v-c73c45b9]{background:#fef2f2;border:1px solid #fecaca;border-radius:12px;padding:12px 16px;color:#dc2626;font-size:14px;display:flex;align-items:center;gap:8px}.tips[data-v-c73c45b9]{background:var(--card-bg);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow)}.tips h3[data-v-c73c45b9]{font-size:15px;margin-bottom:12px}.tips ul[data-v-c73c45b9]{list-style:none;font-size:13px;color:var(--text-secondary);display:flex;flex-direction:column;gap:8px}.tips li[data-v-c73c45b9]{padding-left:20px;position:relative}.tips li[data-v-c73c45b9]:before{content:"•";position:absolute;left:4px;color:var(--primary)}.hidden-input[data-v-c73c45b9]{display:none}.loading-page[data-v-62300433]{display:flex;align-items:center;justify-content:center;flex:1;padding:40px 0}.loading-card[data-v-62300433]{text-align:center;display:flex;flex-direction:column;align-items:center;gap:20px}.spinner[data-v-62300433]{position:relative;width:80px;height:80px}.spinner-ring[data-v-62300433]{position:absolute;width:100%;height:100%;border-radius:50%;border:4px solid transparent;border-top-color:var(--primary);animation:spin-62300433 1.2s linear infinite}.spinner-ring-inner[data-v-62300433]{width:60%;height:60%;top:20%;left:20%;border-top-color:#ec4899;animation-duration:.8s;animation-direction:reverse}@keyframes spin-62300433{to{transform:rotate(360deg)}}.loading-title[data-v-62300433]{font-size:20px;font-weight:600;color:var(--text)}.loading-tip[data-v-62300433]{font-size:15px;color:var(--text-secondary);min-height:24px}.dots[data-v-62300433]{display:inline-block;min-width:24px;text-align:left}.progress-bar[data-v-62300433]{width:240px;height:4px;background:var(--border);border-radius:2px;overflow:hidden}.progress-fill[data-v-62300433]{width:100%;height:100%;background:linear-gradient(90deg,var(--primary),#ec4899);border-radius:2px;animation:progress-62300433 3s ease-in-out infinite;transform-origin:left}@keyframes progress-62300433{0%{transform:scaleX(.1);opacity:1}50%{transform:scaleX(.8);opacity:.8}to{transform:scaleX(.1);opacity:1}}.loading-hint[data-v-62300433]{font-size:13px;color:var(--text-secondary)}.share-panel[data-v-96e533c3]{background:var(--card-bg);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow)}.share-header[data-v-96e533c3]{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.share-header h3[data-v-96e533c3]{font-size:17px;font-weight:600}.share-actions[data-v-96e533c3]{display:flex;flex-direction:column;gap:10px}.share-btn[data-v-96e533c3]{display:flex;align-items:center;justify-content:center;gap:8px;padding:14px 20px;border-radius:12px;border:1px solid var(--border);font-size:15px;font-weight:500;cursor:pointer;transition:all .2s;width:100%}.share-btn[data-v-96e533c3]:disabled{opacity:.6;cursor:not-allowed}.share-btn.primary[data-v-96e533c3]{background:linear-gradient(135deg,var(--primary),#7c3aed);color:#fff;border:none}.share-btn.primary[data-v-96e533c3]:hover:not(:disabled){opacity:.9}.share-btn.success[data-v-96e533c3]{background:#059669;color:#fff;border:none}.share-btn.success[data-v-96e533c3]:hover{opacity:.9}.share-btn.outline[data-v-96e533c3]{background:var(--card-bg);color:var(--text)}.share-btn.outline[data-v-96e533c3]:hover{border-color:var(--primary);color:var(--primary)}.btn-icon[data-v-96e533c3]{font-size:20px}.preview-area[data-v-96e533c3]{margin:8px 0;border-radius:12px;overflow:hidden;border:1px solid var(--border);max-height:360px;overflow-y:auto}.preview-img[data-v-96e533c3]{width:100%;display:block}.share-tips[data-v-96e533c3]{margin-top:14px;text-align:center;font-size:13px;color:var(--text-secondary);background:#fffbeb;border:1px solid #fde68a;border-radius:10px;padding:10px 16px}.report-page[data-v-756d78f4]{display:flex;flex-direction:column;gap:16px;padding-bottom:24px;position:relative}.free-watermark[data-v-756d78f4]{position:absolute;top:120px;right:-30px;transform:rotate(45deg);font-size:14px;color:#8b5cf626;font-weight:700;letter-spacing:4px;pointer-events:none;z-index:0}.season-badge[data-v-756d78f4]{display:flex;align-items:center;gap:16px;padding:20px;border-radius:var(--radius);border:2px solid;box-shadow:var(--shadow)}.season-emoji[data-v-756d78f4]{font-size:40px}.season-info[data-v-756d78f4]{display:flex;flex-direction:column;gap:4px}.season-label[data-v-756d78f4]{font-size:20px;font-weight:700}.sub-season[data-v-756d78f4]{font-size:16px;color:var(--text-secondary);font-weight:500}.section[data-v-756d78f4]{background:var(--card-bg);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow)}.section-title[data-v-756d78f4]{font-size:17px;font-weight:600;margin-bottom:16px;display:flex;align-items:center;gap:8px}.description-card p[data-v-756d78f4]{font-size:15px;line-height:1.7;color:var(--text)}.analysis-grid[data-v-756d78f4]{display:grid;grid-template-columns:1fr 1fr;gap:12px}.analysis-item[data-v-756d78f4]{display:flex;flex-direction:column;gap:4px}.analysis-label[data-v-756d78f4]{font-size:12px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.analysis-value[data-v-756d78f4]{font-size:14px;font-weight:500;color:var(--text)}.palette-group[data-v-756d78f4]{margin-bottom:16px}.palette-group[data-v-756d78f4]:last-child{margin-bottom:0}.palette-label[data-v-756d78f4]{font-size:14px;font-weight:500;margin-bottom:8px}.palette-best[data-v-756d78f4]{color:#16a34a}.palette-neutral[data-v-756d78f4]{color:var(--text-secondary)}.palette-avoid[data-v-756d78f4]{color:#dc2626}.color-chips[data-v-756d78f4]{display:flex;flex-wrap:wrap;gap:8px}.chip[data-v-756d78f4]{padding:6px 14px;border-radius:20px;font-size:13px;background:#f0fdf4;color:#166534;border:1px solid #bbf7d0}.chip-neutral[data-v-756d78f4]{background:#f8fafc;color:var(--text-secondary);border-color:var(--border)}.chip-avoid[data-v-756d78f4]{background:#fef2f2;color:#991b1b;border-color:#fecaca}.recommendations-section[data-v-756d78f4]{position:relative;overflow:hidden;min-height:200px}.lock-overlay[data-v-756d78f4]{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:32px 20px;text-align:center;background:linear-gradient(to bottom,rgba(255,255,255,0),var(--card-bg) 30%);position:relative;z-index:1}.lock-icon[data-v-756d78f4]{font-size:40px}.lock-title[data-v-756d78f4]{font-size:18px;font-weight:600;color:var(--text)}.lock-text[data-v-756d78f4]{font-size:14px;color:var(--text-secondary);max-width:280px;line-height:1.6}.lock-text strong[data-v-756d78f4]{color:#dc2626;font-size:18px}.btn-unlock[data-v-756d78f4]{padding:12px 32px;border-radius:12px;border:none;background:linear-gradient(135deg,var(--primary),#7c3aed);color:#fff;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s;margin-top:8px}.btn-unlock[data-v-756d78f4]:hover{opacity:.9;transform:translateY(-1px)}.rec-card[data-v-756d78f4]{display:flex;gap:14px;padding:16px;background:var(--bg);border-radius:12px;margin-bottom:12px}.rec-card[data-v-756d78f4]:last-child{margin-bottom:0}.rec-icon[data-v-756d78f4]{font-size:28px;flex-shrink:0;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--card-bg);border-radius:12px}.rec-content h4[data-v-756d78f4]{font-size:14px;font-weight:600;margin-bottom:4px}.rec-content p[data-v-756d78f4]{font-size:13px;line-height:1.6;color:var(--text-secondary)}.report-actions[data-v-756d78f4]{display:flex;flex-direction:column;gap:12px;margin-top:8px}.btn[data-v-756d78f4]{display:flex;align-items:center;justify-content:center;gap:8px;padding:14px 24px;border-radius:12px;border:none;font-size:16px;font-weight:500;cursor:pointer;transition:all .2s;width:100%}.btn-primary[data-v-756d78f4]{background:linear-gradient(135deg,var(--primary),#7c3aed);color:#fff}.btn-primary[data-v-756d78f4]:hover{opacity:.9}.btn-outline[data-v-756d78f4]{background:var(--card-bg);color:var(--text);border:2px solid var(--border)}.btn-outline[data-v-756d78f4]:hover{border-color:var(--primary);color:var(--primary)}.remaining-badge[data-v-756d78f4]{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:10px;font-size:14px;color:#166534}.btn-mini[data-v-756d78f4]{padding:6px 14px;border-radius:8px;border:1px solid #86efac;background:#fff;color:#166534;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s}.btn-mini[data-v-756d78f4]:hover{background:#dcfce7}.haircut-item[data-v-756d78f4]{margin-bottom:12px;padding-bottom:12px;border-bottom:1px dashed #eee}.haircut-item[data-v-756d78f4]:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.haircut-item strong[data-v-756d78f4]{display:block;font-size:15px;color:#1e293b;margin-bottom:4px}.haircut-item p[data-v-756d78f4]{font-size:13px;color:#475569;line-height:1.5;margin:0 0 4px}.haircut-scenario[data-v-756d78f4]{display:inline-block;font-size:12px;color:#8b5cf6;background:#f5f3ff;padding:2px 8px;border-radius:10px}.practical-grid[data-v-756d78f4]{display:grid;grid-template-columns:1fr 1fr;gap:12px}.practical-item[data-v-756d78f4]{background:#f8fafc;padding:10px 12px;border-radius:8px}.practical-label[data-v-756d78f4]{display:block;font-size:11px;color:#94a3b8;margin-bottom:4px;text-transform:uppercase}.practical-item span[data-v-756d78f4]:last-child{font-size:14px;color:#1e293b;font-weight:500}.modal-overlay[data-v-3c0f659a]{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal[data-v-3c0f659a]{background:#fff;border-radius:20px;padding:32px 24px;width:100%;max-width:380px;position:relative;animation:modalIn-3c0f659a .3s ease}@keyframes modalIn-3c0f659a{0%{transform:scale(.9) translateY(20px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}.modal.success[data-v-3c0f659a]{text-align:center;padding:48px 24px}.modal-close[data-v-3c0f659a]{position:absolute;top:12px;right:12px;width:32px;height:32px;border-radius:50%;border:none;background:var(--bg, #f1f5f9);color:var(--text-secondary, #64748b);font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}.modal-close[data-v-3c0f659a]:hover{background:#e2e8f0}.modal-header[data-v-3c0f659a]{text-align:center;margin-bottom:24px}.modal-header h2[data-v-3c0f659a]{font-size:22px;font-weight:700;margin-bottom:8px}.modal-subtitle[data-v-3c0f659a]{font-size:14px;color:var(--text-secondary, #64748b)}.modal-subtitle strong[data-v-3c0f659a]{color:#dc2626;font-size:20px}.pay-methods[data-v-3c0f659a]{display:flex;gap:12px;margin-bottom:24px}.pay-method[data-v-3c0f659a]{flex:1;padding:12px;border-radius:12px;border:2px solid #e2e8f0;background:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;font-size:15px;font-weight:500;transition:all .2s}.pay-method[data-v-3c0f659a]:hover{border-color:#cbd5e1}.pay-method.active[data-v-3c0f659a]{border-color:var(--primary, #8b5cf6);background:#f5f3ff}.method-icon[data-v-3c0f659a]{font-size:20px}.qr-section[data-v-3c0f659a]{text-align:center;margin-bottom:20px}.qr-placeholder[data-v-3c0f659a]{display:flex;justify-content:center;margin-bottom:12px}.qr-frame[data-v-3c0f659a]{position:relative;width:200px;height:200px;background:#fff;border:3px solid var(--primary, #8b5cf6);border-radius:16px;padding:12px;display:flex;align-items:center;justify-content:center}.real-qr[data-v-3c0f659a]{width:100%;height:100%;object-fit:contain;border-radius:8px}.qr-grid[data-v-3c0f659a]{display:grid;grid-template-columns:repeat(12,1fr);grid-template-rows:repeat(12,1fr);gap:2px;width:100%;height:100%}.qr-dot[data-v-3c0f659a]{border-radius:2px;background:#f1f5f9;transition:background .1s}.qr-dot.dark[data-v-3c0f659a]{background:#1e293b}.qr-center[data-v-3c0f659a]{position:absolute;width:48px;height:48px;background:#fff;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:28px;box-shadow:0 0 0 3px #fff,0 0 0 5px var(--primary, #8b5cf6)}.qr-hint[data-v-3c0f659a]{font-size:14px;color:var(--text-secondary, #64748b)}.polling-hint[data-v-3c0f659a]{font-size:13px;color:#059669;margin-top:8px;font-weight:500}.error-msg[data-v-3c0f659a]{color:#dc2626;font-size:13px;text-align:center;margin-bottom:12px}.btn-pay[data-v-3c0f659a]{width:100%;padding:14px;border-radius:12px;border:none;background:linear-gradient(135deg,#10b981,#059669);color:#fff;font-size:16px;font-weight:600;cursor:pointer;transition:opacity .2s}.btn-pay[data-v-3c0f659a]:hover{opacity:.9}.btn-pay[data-v-3c0f659a]:disabled{opacity:.6;cursor:not-allowed}.pay-note[data-v-3c0f659a]{text-align:center;font-size:12px;color:#94a3b8;margin-top:10px}.success-animation[data-v-3c0f659a]{margin-bottom:16px}.checkmark[data-v-3c0f659a]{font-size:64px;animation:popIn-3c0f659a .5s ease}@keyframes popIn-3c0f659a{0%{transform:scale(0)}50%{transform:scale(1.2)}to{transform:scale(1)}}.success-title[data-v-3c0f659a]{font-size:24px;font-weight:700;margin-bottom:8px;color:#059669}.success-text[data-v-3c0f659a]{font-size:15px;color:var(--text-secondary, #64748b)}.auth-overlay[data-v-dba7031f]{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px}.auth-modal[data-v-dba7031f]{background:#fff;border-radius:16px;padding:28px 24px;width:100%;max-width:400px;position:relative;box-shadow:0 8px 40px #0000001f}.close-btn[data-v-dba7031f]{position:absolute;top:12px;right:16px;background:none;border:none;font-size:24px;color:#94a3b8;cursor:pointer}.close-btn[data-v-dba7031f]:hover{color:#475569}.tabs[data-v-dba7031f]{display:flex;gap:0;margin-bottom:20px;border-bottom:2px solid #e2e8f0}.tab[data-v-dba7031f]{flex:1;padding:10px 0;text-align:center;background:none;border:none;font-size:16px;font-weight:500;color:#94a3b8;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .2s}.tab.active[data-v-dba7031f]{color:#8b5cf6;border-bottom-color:#8b5cf6}.auth-form[data-v-dba7031f]{display:flex;flex-direction:column;gap:16px}.field[data-v-dba7031f]{display:flex;flex-direction:column;gap:6px}.field label[data-v-dba7031f]{font-size:13px;font-weight:500;color:#475569}.field input[data-v-dba7031f]{padding:10px 12px;border:1.5px solid #e2e8f0;border-radius:10px;font-size:15px;outline:none;transition:border-color .2s}.field input[data-v-dba7031f]:focus{border-color:#8b5cf6}.code-row[data-v-dba7031f]{display:flex;gap:8px}.code-row input[data-v-dba7031f]{flex:1}.code-btn[data-v-dba7031f]{white-space:nowrap;padding:10px 12px;background:#f5f3ff;border:1.5px solid #ddd6fe;border-radius:10px;color:#7c3aed;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s}.code-btn[data-v-dba7031f]:hover:not(:disabled){background:#ede9fe}.code-btn[data-v-dba7031f]:disabled{opacity:.5;cursor:not-allowed}.msg[data-v-dba7031f]{font-size:13px;text-align:center}.msg.error[data-v-dba7031f]{color:#ef4444}.msg.success[data-v-dba7031f]{color:#22c55e}.submit-btn[data-v-dba7031f]{padding:12px;background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff;border:none;border-radius:10px;font-size:16px;font-weight:600;cursor:pointer;transition:opacity .2s}.submit-btn[data-v-dba7031f]:disabled{opacity:.6;cursor:not-allowed}.submit-btn[data-v-dba7031f]:hover:not(:disabled){opacity:.9}.hint[data-v-dba7031f]{font-size:13px;color:#64748b;text-align:center}.hint a[data-v-dba7031f]{color:#8b5cf6;text-decoration:none;font-weight:500}.hint a[data-v-dba7031f]:hover{text-decoration:underline}:root{--primary: #8b5cf6;--primary-light: #a78bfa;--primary-dark: #7c3aed;--bg: #f8fafc;--card-bg: #ffffff;--text: #1e293b;--text-secondary: #64748b;--border: #e2e8f0;--radius: 16px;--shadow: 0 4px 24px rgba(0, 0, 0, .06)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;min-height:100dvh}.app{max-width:480px;margin:0 auto;padding:16px;min-height:100dvh;display:flex;flex-direction:column}.app-header{text-align:center;padding:24px 0 16px}.logo{display:flex;align-items:center;justify-content:center;gap:10px}.logo-icon{font-size:32px}.logo h1{font-size:24px;font-weight:700;background:linear-gradient(135deg,var(--primary),#ec4899);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.subtitle{color:var(--text-secondary);font-size:14px;margin-top:8px}.price-badge{display:inline-block;margin-top:12px;padding:6px 16px;background:linear-gradient(135deg,#fef3c7,#fde68a);border-radius:20px;font-size:13px;font-weight:500;color:#92400e;border:1px solid #fcd34d}.report-type-selector{margin-bottom:16px}.selector-label{display:block;font-size:14px;font-weight:600;color:var(--text);margin-bottom:8px}.type-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.type-card{display:flex;flex-direction:column;gap:2px;padding:10px;border-radius:12px;border:2px solid var(--border);background:var(--card-bg);cursor:pointer;text-align:left;transition:all .2s}.type-card:hover{border-color:var(--primary-light)}.type-card.active{border-color:var(--primary);background:#f5f3ff}.type-name{font-size:13px;font-weight:600;color:var(--text)}.type-desc{font-size:11px;color:var(--text-secondary);line-height:1.3}.plans-page{padding:16px 0}.plans-page h2{font-size:20px;text-align:center;margin-bottom:4px}.plans-subtitle{text-align:center;color:var(--text-secondary);font-size:14px;margin-bottom:20px}.plans-grid{display:flex;flex-direction:column;gap:12px}.plan-card{position:relative;padding:16px;border-radius:var(--radius);border:2px solid var(--border);background:var(--card-bg);cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:16px}.plan-card:hover{border-color:var(--primary-light)}.plan-card.selected{border-color:var(--primary);background:#f5f3ff}.plan-card .popular-badge{position:absolute;top:-8px;right:12px;background:linear-gradient(135deg,var(--primary),#ec4899);color:#fff;font-size:11px;font-weight:600;padding:2px 10px;border-radius:10px}.plan-card h3{font-size:16px;font-weight:600;min-width:60px}.plan-price{font-size:22px;font-weight:700;color:var(--primary)}.plan-quota{font-size:13px;color:var(--text-secondary)}.plan-features{list-style:none;font-size:12px;color:var(--text-secondary)}.plan-features li:before{content:"✓ ";color:var(--primary)}.plans-actions{display:flex;gap:12px;margin-top:20px}.plans-actions .btn{flex:1;padding:12px;border-radius:12px;font-size:15px;font-weight:600;cursor:pointer;border:none;transition:all .2s}.plans-actions .btn-primary{background:linear-gradient(135deg,var(--primary),#7c3aed);color:#fff}.plans-actions .btn-secondary{background:var(--border);color:var(--text)}.auth-bar{display:flex;align-items:center;justify-content:center;gap:12px;margin-top:12px}.user-email{font-size:13px;color:#64748b;font-weight:500}.auth-btn{padding:6px 16px;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;border:1.5px solid #ddd6fe;background:#fff;color:#7c3aed;transition:all .2s}.auth-btn:hover{background:#f5f3ff}.logout-btn{border-color:#e2e8f0;color:#64748b}.logout-btn:hover{background:#fef2f2;border-color:#fecaca;color:#ef4444}.app-main{flex:1;display:flex;flex-direction:column}.app-footer{text-align:center;padding:16px 0;color:var(--text-secondary);font-size:12px}.fade-enter-active,.fade-leave-active{transition:opacity .3s ease,transform .3s ease}.fade-enter-from{opacity:0;transform:translateY(12px)}.fade-leave-to{opacity:0;transform:translateY(-12px)}
