.app-nav{-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border-subtle);z-index:100;-webkit-app-region:no-drag;background:#ffffffd9;flex-shrink:0;justify-content:space-between;align-items:center;height:52px;padding:0 24px;display:flex;position:sticky;top:0}.app-nav-left{align-items:center;gap:20px;display:flex}.app-nav-logo{font-size:var(--text-base);color:var(--text-primary);letter-spacing:-.03em;white-space:nowrap;align-items:center;gap:8px;font-weight:650;text-decoration:none;display:flex}.app-nav-logo:hover{color:var(--text-primary)}.app-nav-logo-icon{width:22px;height:22px;color:var(--accent)}.app-nav-links{align-items:center;gap:2px;display:flex}.app-nav-link{border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--text-secondary);transition:all var(--transition-fast);cursor:pointer;white-space:nowrap;background:0 0;border:none;padding:6px 14px;font-family:inherit;font-weight:450;text-decoration:none;position:relative}.app-nav-link:hover{color:var(--text-primary);background:var(--accent-subtle)}.app-nav-link.active{color:var(--text-primary);font-weight:550}.app-nav-link.active:after{content:"";background:var(--accent);border-radius:1px;width:20px;height:2px;position:absolute;bottom:-1px;left:50%;transform:translate(-50%)}.app-nav-right{align-items:center;gap:8px;display:flex}.app-nav-plan-badge{border-radius:var(--radius-full);cursor:pointer;transition:all var(--transition-fast);align-items:center;gap:4px;padding:3px 10px;font-family:inherit;font-size:11px;font-weight:550;display:inline-flex}.app-nav-plan-badge.free{color:var(--text-muted);border:1px solid var(--border-subtle);background:#0000000a}.app-nav-plan-badge.free:hover{color:var(--accent);background:#6366f114;border-color:#6366f14d}.app-nav-plan-badge.pro{color:#6366f1;background:linear-gradient(135deg,#6366f11f,#8b5cf61f);border:1px solid #6366f140}.app-nav-plan-badge.teacher{color:#f59e0b;background:linear-gradient(135deg,#f973161f,#eab3081f);border:1px solid #f9731640}.app-nav-auth-btn{border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;padding:5px 12px;font-family:inherit;font-weight:450}.app-nav-auth-btn:hover{color:var(--text-primary);background:var(--accent-subtle)}@media (width<=767px){.app-nav{height:48px;padding:0 16px}.app-nav-links{display:none}.app-nav-left{gap:12px}.app-nav-plan-badge{padding:2px 8px;font-size:10px}}.mobile-bottom-nav{-webkit-backdrop-filter:blur(16px);border-top:1px solid var(--border-subtle);z-index:100;height:64px;padding:6px 0 env(safe-area-inset-bottom,0);background:#ffffffeb;justify-content:space-around;align-items:stretch;display:none;position:fixed;bottom:0;left:0;right:0}.mb-nav-item{color:var(--text-muted);transition:all var(--transition-fast);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:2px;padding:4px 0;text-decoration:none;display:flex;position:relative}.mb-nav-item.active{color:var(--text-primary)}.mb-nav-item.active:after{content:"";background:var(--accent);border-radius:1px;width:24px;height:2px;position:absolute;top:0;left:50%;transform:translate(-50%)}.mb-nav-label{letter-spacing:-.01em;font-size:10px;font-weight:500}.mb-nav-item.active .mb-nav-label{color:var(--text-primary);font-weight:600}@media (width<=767px){.mobile-bottom-nav{display:flex}.page-layout{padding-bottom:64px}}.page-layout{background:var(--bg-deep);flex-direction:column;min-height:100dvh;display:flex}.page-main{flex-direction:column;flex:1;width:100%;max-width:100vw;display:flex;overflow-x:hidden}.camera-capture{padding:4px 0}.cc-title{color:#2c3e50;margin-bottom:10px;font-size:13px;font-weight:600}.cc-capture-area{justify-content:center;display:flex}.cc-capture-btn{cursor:pointer;background:#fafbfc;border:2px dashed #d0d2d8;border-radius:8px;flex-direction:column;align-items:center;gap:6px;width:100%;padding:24px 16px;transition:all .2s;display:flex}.cc-capture-btn:hover{background:#f0f4fa;border-color:#4a90e2}.cc-capture-icon{font-size:32px;line-height:1}.cc-capture-text{color:#555;font-size:14px;font-weight:600}.cc-capture-hint{color:#bbb;font-size:10px}.cc-preview{border:1.5px solid #e0e3e8;border-radius:8px;overflow:hidden}.cc-preview-img{object-fit:contain;background:#f5f5f5;width:100%;max-height:200px;display:block}.cc-preview-actions{background:#fafbfc;border-top:1px solid #e0e3e8;gap:8px;padding:10px 12px;display:flex}.cc-btn{cursor:pointer;border:none;border-radius:5px;padding:8px 16px;font-size:13px;font-weight:600;transition:all .15s}.cc-btn:disabled{opacity:.5;cursor:not-allowed}.cc-btn-primary{color:#fff;background:linear-gradient(135deg,#4a90e2 0%,#357abd 100%);flex:1}.cc-btn-primary:hover:not(:disabled){box-shadow:0 2px 8px #4a90e24d}.cc-btn-ghost{color:#666;background:#fff;border:1px solid #d0d2d8}.cc-btn-ghost:hover:not(:disabled){background:#f5f5f5}.cc-message{border-radius:5px;margin-top:8px;padding:8px 12px;font-size:12px;font-weight:500}.cc-error{color:#c62828;background:#fef0ef;border:1px solid #f5c6cb}.cc-status{color:#4a90e2;background:#e8f0fc;border:1px solid #c5d9f2}@media (width<=767px){.cc-capture-btn{padding:28px 16px}.cc-capture-icon{font-size:40px}.cc-btn{min-height:44px;padding:10px 18px;font-size:14px}.cc-preview-img{max-height:250px}}.landing{background:linear-gradient(#f8f9ff 0%,#fff 40%);flex-direction:column;align-items:center;min-height:calc(100vh - 52px);padding:0 16px 48px;display:flex}.landing-hero{text-align:center;flex-direction:column;align-items:center;width:100%;max-width:640px;padding:48px 0 32px;display:flex}.landing-hero-inner{flex-direction:column;align-items:center;width:100%;display:flex}.landing-logo{align-items:center;gap:10px;margin-bottom:20px;display:flex}.landing-logo-svg{color:#6366f1;stroke-width:1.8px;width:32px;height:32px}.landing-logo-text{letter-spacing:-.03em;color:var(--text-primary);font-size:22px;font-weight:650}.landing-title{letter-spacing:-.03em;color:var(--text-primary);background:linear-gradient(135deg,#1d1d1f 0%,#6366f1 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:8px;font-size:36px;font-weight:700;line-height:1.15}.landing-subtitle{font-size:var(--text-lg);color:var(--text-muted);margin-bottom:28px}.landing-input-wrap{background:var(--bg-surface);border:1px solid var(--border-default);width:100%;max-width:560px;box-shadow:var(--shadow-xs);border-radius:16px;padding:14px 16px 10px;transition:all .2s}.landing-input-wrap.focused{background:var(--bg-surface);border-color:#6366f1;box-shadow:0 0 0 4px #6366f11a}.landing-input{resize:none;width:100%;font-size:var(--text-base);font-family:var(--font-sans);color:var(--text-primary);background:0 0;border:none;outline:none;min-height:56px;line-height:1.6}.landing-input::placeholder{color:var(--text-muted);font-size:var(--text-sm)}.landing-input-footer{border-top:1px solid var(--border-subtle);justify-content:space-between;align-items:center;margin-top:6px;padding-top:8px;display:flex}.landing-input-hint{font-size:var(--text-xs);color:var(--text-muted)}.landing-submit{color:#fff;border-radius:var(--radius-full);font-size:var(--text-sm);cursor:pointer;letter-spacing:-.01em;background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;align-items:center;gap:6px;padding:7px 18px;font-family:inherit;font-weight:550;transition:all .15s;display:inline-flex}.landing-submit:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #6366f14d}.landing-submit:disabled{opacity:.3;cursor:not-allowed}.landing-submit-shortcut{border-radius:var(--radius-sm);background:#fff3;justify-content:center;align-items:center;width:20px;height:20px;font-size:11px;font-weight:500;display:inline-flex}.landing-error{border-radius:var(--radius-md);color:var(--color-error);font-size:var(--text-xs);background:#f8514914;border:1px solid #f8514926;margin-top:12px;padding:8px 16px}.landing-camera-toggle{width:100%;margin-top:12px}.landing-camera-trigger{border-radius:var(--radius-full);border:1px solid var(--border-subtle);color:var(--text-muted);font-size:var(--text-xs);cursor:pointer;transition:all var(--transition-fast);background:0 0;align-items:center;gap:4px;padding:6px 14px;font-family:inherit;font-weight:500;display:inline-flex}.landing-camera-trigger:hover{border-color:var(--border-emphasis);color:var(--text-primary);background:var(--accent-subtle)}.landing-camera-panel{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);width:100%;padding:12px}.landing-camera-close{border-radius:var(--radius-md);color:var(--text-muted);cursor:pointer;transition:color var(--transition-fast);background:0 0;border:none;margin-top:8px;padding:4px 10px;font-family:inherit;font-size:11px;display:block}.landing-camera-close:hover{color:var(--text-primary)}.landing-section{width:100%;max-width:640px;margin-bottom:28px}.landing-section-header{margin-bottom:12px}.landing-section-title{font-size:var(--text-base);color:var(--text-primary);font-weight:600}.landing-examples-grid{grid-template-columns:repeat(2,1fr);gap:8px;display:grid}@media (width<=480px){.landing-examples-grid{grid-template-columns:1fr}}.landing-example-card{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);cursor:pointer;text-align:left;color:inherit;flex-direction:column;gap:4px;padding:12px 14px;font-family:inherit;transition:all .15s;display:flex}.landing-example-card:hover{box-shadow:var(--shadow-sm);background:#6366f108;border-color:#6366f14d;transform:translateY(-1px)}.landing-example-category{color:#6366f1;letter-spacing:.03em;text-transform:uppercase;font-size:10px;font-weight:550}.landing-example-title{font-size:var(--text-sm);color:var(--text-primary);font-weight:550}.landing-example-desc{color:var(--text-muted);text-overflow:ellipsis;white-space:nowrap;font-size:11px;overflow:hidden}.landing-history-list{flex-direction:column;gap:4px;display:flex}.landing-history-item{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-md);cursor:pointer;text-align:left;color:inherit;justify-content:space-between;align-items:center;width:100%;padding:10px 14px;font-family:inherit;transition:all .15s;display:flex}.landing-history-item:hover{border-color:var(--border-default);background:var(--accent-subtle)}.landing-history-left{align-items:center;gap:12px;min-width:0;display:flex}.landing-history-date{color:var(--text-muted);white-space:nowrap;flex-shrink:0;font-size:11px;font-weight:500}.landing-history-text{font-size:var(--text-sm);color:var(--text-secondary);text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.landing-history-arrow{font-size:var(--text-sm);color:var(--text-muted);flex-shrink:0;margin-left:8px}.landing-footer{border-top:1px solid var(--border-subtle);text-align:center;flex-direction:column;align-items:center;gap:8px;width:100%;max-width:640px;margin-top:16px;padding:24px 0;display:flex}.landing-footer-brand{font-size:var(--text-sm);color:var(--text-primary);align-items:center;gap:8px;font-weight:600;display:flex}.landing-footer-brand svg{color:#6366f1;width:18px;height:18px}.landing-footer-text{font-size:var(--text-xs);color:var(--text-muted)}.landing-footer-upgrade{border-radius:var(--radius-full);color:#6366f1;font-size:var(--text-xs);cursor:pointer;background:linear-gradient(135deg,#6366f11a,#8b5cf61a);border:1px solid #6366f133;padding:6px 14px;font-family:inherit;font-weight:550;transition:all .15s}.landing-footer-upgrade:hover{background:linear-gradient(135deg,#6366f12e,#8b5cf62e);border-color:#6366f159}@media (width<=767px){.landing{min-height:calc(100vh - 112px);padding:0 12px 32px}.landing-hero{padding:32px 0 24px}.landing-title{font-size:26px}.landing-subtitle{font-size:var(--text-base);margin-bottom:20px}.landing-input-wrap{padding:10px 12px 8px}.landing-input{font-size:var(--text-sm);min-height:44px}.landing-section{margin-bottom:20px}.landing-examples-grid{grid-template-columns:1fr}}.error-boundary{background:var(--bg-deep);flex:1;justify-content:center;align-items:center;min-height:60vh;padding:32px;display:flex}.error-boundary-card{text-align:center;background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);max-width:400px;box-shadow:var(--shadow-md);flex-direction:column;align-items:center;padding:40px 32px;display:flex}.error-boundary-icon{width:48px;height:48px;color:var(--color-error);background:#f851491a;border-radius:50%;justify-content:center;align-items:center;margin-bottom:16px;font-size:24px;font-weight:700;display:flex}.error-boundary-title{font-size:var(--text-xl);color:var(--text-primary);margin-bottom:8px;font-weight:600}.error-boundary-desc{font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:24px;line-height:1.6}.error-boundary-actions{flex-wrap:wrap;justify-content:center;gap:10px;display:flex}.error-boundary-btn{border-radius:var(--radius-full);font-size:var(--text-sm);transition:all var(--transition-fast);cursor:pointer;padding:8px 20px;font-family:inherit;font-weight:500;text-decoration:none}.error-boundary-btn-primary{background:var(--accent);color:var(--text-inverse);border:none}.error-boundary-btn-primary:hover{background:var(--accent-hover)}.error-boundary-btn-secondary{color:var(--text-secondary);border:1px solid var(--border-default);background:0 0}.error-boundary-btn-secondary:hover{border-color:var(--border-emphasis);color:var(--text-primary)}:root{--brand-blue:#6366f1;--brand-purple:#8b5cf6;--brand-gradient:linear-gradient(135deg, #6366f1, #8b5cf6);--bg-deep:#fff;--bg-base:#f8f9ff;--bg-surface:#fff;--bg-elevated:#f0f0f6;--bg-overlay:#0f172a59;--bg-glass:#ffffffb8;--border-subtle:#e8e8ee;--border-default:#d0d0d8;--border-emphasis:#a0a0b0;--border-focus:#6366f1;--text-primary:#1d1d1f;--text-secondary:#444456;--text-muted:#6b6b78;--text-inverse:#fff;--accent:#6366f1;--accent-hover:#4f46e5;--accent-subtle:#6366f10f;--accent-pressed:#6366f11f;--color-success:#16a34a;--color-warning:#d97706;--color-error:#dc2626;--color-info:#6366f1;--shadow-xs:0 0 0 1px #0000000a;--shadow-sm:0 1px 3px #0000000f, 0 1px 2px #0000000a;--shadow-md:0 4px 12px #00000012;--shadow-lg:0 8px 32px #00000014;--shadow-xl:0 16px 48px #0000001a;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--radius-full:9999px;--space-xs:4px;--space-sm:8px;--space-md:12px;--space-lg:16px;--space-xl:24px;--space-2xl:32px;--space-3xl:48px;--space-4xl:64px;--transition-fast:.12s ease;--transition-base:.2s ease;--transition-slow:.3s ease;--font-sans:-apple-system, BlinkMacSystemFont, "Segoe UI", "Inter", "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", sans-serif;--font-mono:"SF Mono", "JetBrains Mono", "Consolas", "Courier New", monospace;--font-math:"Cambria Math", "Georgia", "Times New Roman", serif;--text-xs:11px;--text-sm:13px;--text-base:15px;--text-lg:18px;--text-xl:22px;--text-2xl:28px;--text-3xl:36px;--text-4xl:48px;--text-5xl:60px}.glass{background:var(--bg-glass);-webkit-backdrop-filter:blur(16px);border:1px solid #ffffff80}.glass-strong{-webkit-backdrop-filter:blur(24px);border:1px solid var(--border-subtle);background:#ffffffd9}:root{--color-primary:var(--text-primary);--color-primary-dark:var(--text-secondary);--color-primary-light:#6366f10f;--color-primary-glow:#6366f108;--color-success-light:#16a34a14;--color-warning-light:#d9770614;--color-error-light:#dc262614;--color-gold:var(--color-warning);--color-gold-light:#d9770614;--color-gold-dark:#b45309;--color-pro:#6366f1;--color-pro-light:#6366f114;--color-pro-gradient:linear-gradient(135deg, #6366f1, #8b5cf6);--color-teacher:#f59e0b;--color-teacher-light:#f59e0b14;--color-teacher-gradient:linear-gradient(135deg, #f59e0b, #d97706);--color-free:var(--text-muted);--color-free-light:#00000005;--color-text:var(--text-primary);--color-text-secondary:var(--text-secondary);--color-text-muted:var(--text-muted);--color-border:var(--border-default);--color-border-light:var(--border-subtle);--color-bg:var(--bg-deep);--color-bg-alt:var(--bg-surface);--color-bg-hover:#6366f10a;--badge-pro-bg:#6366f11a;--badge-pro-text:#6366f1;--badge-teacher-bg:#f59e0b1a;--badge-teacher-text:#f59e0b}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{width:100%;height:100%;margin:0;padding:0}body{font-family:var(--font-sans);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--bg-deep);color:var(--text-primary);letter-spacing:-.01em;line-height:1.5;overflow:hidden}::selection{color:var(--text-primary);background:#0000001a}:focus-visible{outline:2px solid var(--border-focus);outline-offset:2px;border-radius:var(--radius-sm)}a{color:var(--text-secondary);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--text-primary)}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#0000001f;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#0003}*{scrollbar-width:thin;scrollbar-color:#0000001f transparent}button{cursor:pointer;color:inherit;font-family:inherit;font-size:inherit;background:0 0;border:none}input,textarea{color:inherit;font-family:inherit}@media (width<=767px){body{-webkit-overflow-scrolling:touch;overflow:auto}html,body,#root{height:auto;min-height:100dvh}}
