@import "https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:ital,wght@0,300;0,400;0,500;0,600;0,700;0,800;1,400;1,600&family=Lora:ital,wght@0,400;0,500;0,600;0,700;1,400;1,600&family=JetBrains+Mono:wght@400;500&display=swap";*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--green-950:#052010;--green-900:#0d2818;--green-800:#1b4332;--green-700:#2d6a4f;--green-600:#40916c;--green-500:#52b788;--green-400:#74c69d;--green-300:#95d5b2;--green-200:#b7e4c7;--green-100:#d8f3dc;--green-50:#f0fff4;--gold-700:#92690b;--gold-600:#b8860b;--gold-500:#d4a843;--gold-400:#e2b95a;--gold-200:#f5dfa0;--gold-100:#fef3c7;--gray-950:#0a0f14;--gray-900:#111827;--gray-800:#1f2937;--gray-700:#374151;--gray-600:#4b5563;--gray-500:#6b7280;--gray-400:#9ca3af;--gray-300:#d1d5db;--gray-200:#e5e7eb;--gray-100:#f3f4f6;--gray-50:#f9fafb;--warm-bg:#f8f6f2;--warm-50:#f4f1ec;--warm-100:#ede7dc;--warm-200:#ddd3c5;--warm-300:#c9b9a6;--red-600:#dc2626;--red-100:#fee2e2;--amber-600:#d97706;--white:#fff;--black:#0a0f14;--primary:var(--green-800);--primary-hover:var(--green-700);--accent:var(--gold-500);--accent-hover:var(--gold-600);--bg:var(--warm-bg);--bg-subtle:var(--warm-50);--surface:var(--white);--surface-raised:var(--white);--surface-hover:var(--warm-50);--border:var(--warm-100);--border-strong:var(--warm-200);--border-focus:var(--green-500);--text:#16213e;--text-secondary:#374151;--text-muted:var(--gray-500);--text-subtle:var(--gray-400);--text-inverse:var(--white);--font-sans:"Plus Jakarta Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-serif:"Lora", "Georgia", serif;--font-mono:"JetBrains Mono", "Courier New", monospace;--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--radius-xl:20px;--radius-2xl:28px;--radius-full:9999px;--shadow-xs:0 1px 2px #0000000a;--shadow-sm:0 1px 3px #00000014, 0 1px 2px #0000000d;--shadow-md:0 4px 8px #00000012, 0 2px 4px #0000000d;--shadow-lg:0 10px 24px #00000014, 0 4px 8px #0000000a;--shadow-xl:0 20px 40px #0000001a, 0 8px 16px #0000000f;--shadow-glow:0 0 0 3px #40916c2e;--ease-out:cubic-bezier(.16, 1, .3, 1);--ease-inout:cubic-bezier(.4, 0, .2, 1);--transition-fast:.12s var(--ease-inout);--transition-base:.22s var(--ease-out);--transition-slow:.36s var(--ease-out)}.dark{--primary:var(--green-400);--primary-hover:var(--green-300);--accent:var(--gold-400);--accent-hover:var(--gold-500);--bg:#0e1117;--bg-subtle:#131920;--surface:#161d27;--surface-raised:#1c2534;--surface-hover:#1e2a3a;--border:#ffffff12;--border-strong:#ffffff21;--border-focus:var(--green-500);--text:#edf0f5;--text-secondary:#c8d0dc;--text-muted:#7a8899;--text-subtle:#4d5d70;--text-inverse:#0e1117;--shadow-sm:0 1px 3px #00000080;--shadow-md:0 4px 8px #00000080;--shadow-lg:0 10px 24px #0009;--shadow-xl:0 20px 40px #000000b3;--shadow-glow:0 0 0 3px #74c69d2e}html{-webkit-font-smoothing:antialiased;scroll-behavior:smooth;font-size:16px}body{font-family:var(--font-sans);background:var(--bg);color:var(--text);min-height:100vh;line-height:1.6;transition:background-color .22s,color .22s}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--warm-200);border-radius:99px}.dark ::-webkit-scrollbar-thumb{background:#ffffff1a}::selection{background:var(--green-100);color:var(--green-900)}.dark ::selection{color:var(--green-200);background:#74c69d33}:focus-visible{outline:2px solid var(--border-focus);outline-offset:2px;border-radius:var(--radius-sm)}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes slide-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slide-down{0%{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}@keyframes scale-in{0%{opacity:0;transform:scale(.94)}to{opacity:1;transform:scale(1)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes cursor-blink{0%,50%{opacity:1}51%,to{opacity:0}}@keyframes loading-bounce{0%,80%,to{opacity:.2;transform:scale(.8)}40%{opacity:1;transform:scale(1)}}@keyframes toast-slide{0%{opacity:0;transform:translate(calc(100% + 16px))}to{opacity:1;transform:translate(0)}}@keyframes section-reveal{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes typing-dot{0%,60%,to{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-4px)}}@keyframes pulse-glow{0%,to{box-shadow:0 0 #40916c66}50%{box-shadow:0 0 0 8px #40916c00}}@keyframes progress-bar{0%{transform:scaleX(1)}to{transform:scaleX(0)}}.animate-fade-in{animation:.22s forwards fade-in}.animate-slide-up{animation:.36s forwards slide-up}.animate-scale-in{animation:.22s forwards scale-in}.landing{background:var(--warm-bg);min-height:100vh;color:var(--text);font-family:var(--font-sans);overflow-x:hidden}.nav{-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--warm-100);z-index:100;background:#f8f6f2e0;justify-content:space-between;align-items:center;height:64px;padding:0 40px;display:flex;position:sticky;top:0}.nav-logo{align-items:center;gap:12px;display:flex}.nav-mark{background:linear-gradient(135deg, var(--green-800), var(--green-600));color:#fff;letter-spacing:.5px;width:36px;height:36px;box-shadow:var(--shadow-md);border-radius:10px;justify-content:center;align-items:center;font-size:13px;font-weight:800;display:flex}.nav-name{color:var(--text);letter-spacing:-.3px;font-size:16px;font-weight:800}.nav-sub{color:var(--text-muted);letter-spacing:.5px;font-size:9.5px}.nav-links{align-items:center;gap:28px;display:flex}.nav-links a{color:var(--text-muted);transition:color var(--transition-fast);font-size:14px;font-weight:500;text-decoration:none}.nav-links a:hover{color:var(--text)}.nav-cta{background:linear-gradient(135deg, var(--green-800), var(--green-700));color:#fff;border-radius:var(--radius-md);cursor:pointer;font-size:14px;font-weight:700;font-family:var(--font-sans);transition:all var(--transition-fast);box-shadow:var(--shadow-sm);letter-spacing:.1px;border:none;padding:9px 20px}.nav-cta:hover{box-shadow:var(--shadow-md);background:linear-gradient(135deg, var(--green-700), var(--green-600));transform:translateY(-1px)}.nav-signout{border:1px solid var(--warm-200);color:var(--text-muted);border-radius:var(--radius-md);cursor:pointer;font-size:13px;font-weight:500;font-family:var(--font-sans);transition:all var(--transition-fast);background:0 0;padding:8px 16px}.nav-signout:hover{border-color:var(--warm-300);color:var(--text)}.nav-user{align-items:center;gap:10px;display:flex}.nav-avatar{border:2px solid var(--warm-200);border-radius:50%;width:30px;height:30px}.hero-section{background:radial-gradient(70% 60% at 50% -10%,#40916c1f 0%,#0000 70%),radial-gradient(50% 40% at 90%,#d4a8430f 0%,#0000 60%);padding:96px 40px 80px;position:relative;overflow:hidden}.hero-inner{text-align:center;max-width:800px;margin:0 auto}.hero-badge{background:var(--green-50);border:1px solid var(--green-200);border-radius:var(--radius-full);color:var(--green-700);letter-spacing:1.2px;text-transform:uppercase;align-items:center;gap:8px;margin-bottom:24px;padding:6px 16px;font-size:10.5px;font-weight:700;animation:.5s both slide-down;display:inline-flex}.hero-title{font-family:var(--font-serif);color:var(--text);letter-spacing:-1px;margin-bottom:20px;font-size:clamp(36px,6vw,56px);font-weight:700;line-height:1.2;animation:.5s .1s both slide-up}.hero-accent{background:linear-gradient(135deg, var(--green-700), var(--green-500));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.hero-subtitle{color:var(--text-muted);max-width:600px;margin:0 auto 36px;font-size:18px;line-height:1.7;animation:.5s .2s both slide-up}.hero-actions{flex-wrap:wrap;justify-content:center;gap:14px;margin-bottom:20px;animation:.5s .3s both slide-up;display:flex}.btn-hero-primary{background:linear-gradient(135deg, var(--green-800), var(--green-600));color:#fff;border-radius:var(--radius-lg);cursor:pointer;font-size:16px;font-weight:700;font-family:var(--font-sans);transition:all var(--transition-base);box-shadow:var(--shadow-md), 0 0 0 0 #40916c66;letter-spacing:.1px;border:none;padding:14px 32px}.btn-hero-primary:hover{box-shadow:var(--shadow-xl), 0 0 0 6px #40916c1f;transform:translateY(-2px)}.btn-hero-ghost{border:1.5px solid var(--warm-200);color:var(--text-secondary);border-radius:var(--radius-lg);cursor:pointer;font-size:15px;font-weight:600;font-family:var(--font-sans);transition:all var(--transition-fast);background:0 0;align-items:center;padding:14px 28px;text-decoration:none;display:inline-flex}.btn-hero-ghost:hover{border-color:var(--warm-300);color:var(--text);background:var(--warm-50)}.hero-proof{color:var(--text-subtle);margin-bottom:48px;font-size:12px;animation:.6s .4s both fade-in}.hero-stats{background:var(--white);border:1px solid var(--warm-100);border-radius:var(--radius-xl);box-shadow:var(--shadow-md);flex-wrap:wrap;justify-content:center;gap:0;animation:.5s .5s both slide-up;display:flex;overflow:hidden}.hero-stat{text-align:center;border-right:1px solid var(--warm-100);flex:1;min-width:120px;padding:20px 36px}.hero-stat:last-child{border-right:none}.hero-stat-number{color:var(--green-800);letter-spacing:-1px;font-size:28px;font-weight:800;font-family:var(--font-serif)}.hero-stat-label{color:var(--text-muted);margin-top:2px;font-size:11.5px;font-weight:500}.section-label{letter-spacing:2.5px;text-transform:uppercase;color:var(--green-700);margin-bottom:12px;font-size:10px;font-weight:800;display:block}.section-title{font-family:var(--font-serif);color:var(--text);letter-spacing:-.5px;margin-bottom:48px;font-size:clamp(26px,4vw,36px);font-weight:700;line-height:1.25}.features-section{max-width:1100px;margin:0 auto;padding:96px 40px}.features-grid{grid-template-columns:repeat(3,1fr);gap:20px;display:grid}.feature-card{background:var(--white);border:1px solid var(--warm-100);border-radius:var(--radius-xl);transition:all var(--transition-base);padding:28px 24px;position:relative;overflow:hidden}.feature-card:after{content:"";background:linear-gradient(90deg, var(--green-600), var(--green-400));height:3px;transition:transform var(--transition-base);transform-origin:0;position:absolute;bottom:0;left:0;right:0;transform:scaleX(0)}.feature-card:hover{box-shadow:var(--shadow-lg);border-color:var(--warm-200);transform:translateY(-4px)}.feature-card:hover:after{transform:scaleX(1)}.feature-icon{margin-bottom:14px;font-size:28px}.feature-card h3{color:var(--text);margin-bottom:8px;font-size:15px;font-weight:700}.feature-card p{color:var(--text-muted);font-size:13.5px;line-height:1.6}.how-section{background:var(--white);padding:96px 40px}.how-section .section-title,.how-section .section-label{text-align:center}.how-section .section-title{max-width:600px;margin:0 auto 56px}.steps{flex-wrap:wrap;justify-content:center;align-items:flex-start;gap:16px;max-width:900px;margin:0 auto;display:flex}.step{text-align:center;flex:1;min-width:200px;max-width:280px}.step-num{background:linear-gradient(135deg, var(--green-800), var(--green-600));color:#fff;border-radius:var(--radius-xl);width:48px;height:48px;box-shadow:var(--shadow-md);justify-content:center;align-items:center;margin:0 auto 16px;font-size:15px;font-weight:800;display:flex}.step h3{color:var(--text);margin-bottom:8px;font-size:16px;font-weight:700}.step p{color:var(--text-muted);font-size:13.5px;line-height:1.65}.step-arrow{color:var(--warm-300);flex-shrink:0;padding-top:12px;font-size:24px}.pricing-section{text-align:center;max-width:1100px;margin:0 auto;padding:96px 40px}.pricing-subtitle{color:var(--text-muted);font-size:17px}.pricing-grid{grid-template-columns:repeat(3,1fr);gap:20px;max-width:960px;margin:0 auto 32px;display:grid}.pricing-card{background:var(--white);border:1.5px solid var(--warm-100);border-radius:var(--radius-2xl);text-align:left;transition:all var(--transition-base);padding:32px 28px;position:relative}.pricing-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}.pricing-card.featured{border-color:var(--green-500);box-shadow:var(--shadow-lg), 0 0 0 1px var(--green-500);transform:scale(1.02)}.pricing-card.featured:hover{transform:scale(1.02)translateY(-4px)}.pricing-card.coming-soon{opacity:.7}.pricing-badge{background:linear-gradient(135deg, var(--green-800), var(--green-600));color:#fff;letter-spacing:1.2px;text-transform:uppercase;border-radius:var(--radius-full);margin-bottom:12px;padding:4px 10px;font-size:9.5px;font-weight:800;display:inline-block}.pricing-badge-soon{background:var(--warm-100);color:var(--text-muted);letter-spacing:1px;text-transform:uppercase;border-radius:var(--radius-full);margin-bottom:12px;padding:3px 10px;font-size:9.5px;font-weight:700;display:inline-block}.pricing-tier{color:var(--text-subtle);letter-spacing:2px;text-transform:uppercase;margin-bottom:8px;font-size:11px;font-weight:800}.pricing-price{color:var(--text);font-size:36px;font-weight:800;font-family:var(--font-serif);letter-spacing:-1px;margin-bottom:4px}.pricing-price span{color:var(--text-muted);letter-spacing:0;font-size:14px;font-weight:500;font-family:var(--font-sans)}.pricing-price-tbd{font-size:28px}.pricing-price-row{align-items:baseline;gap:10px;margin-bottom:4px;display:flex}.pricing-strike{color:var(--text-subtle);font-size:16px;font-weight:500;text-decoration:line-through}.pricing-annual-note{color:var(--text-muted);margin-bottom:4px;font-size:12px}.save-inline{background:var(--gold-100);color:var(--gold-600);border-radius:var(--radius-full);padding:1px 6px;font-size:11px;font-weight:700}.pricing-desc{color:var(--text-muted);margin-bottom:20px;font-size:13px}.pricing-features{flex-direction:column;gap:9px;margin-bottom:24px;list-style:none;display:flex}.pricing-features li{color:var(--text-secondary);align-items:flex-start;gap:6px;font-size:13.5px;display:flex}.pricing-features li.dim{color:var(--text-subtle)}.pricing-features li.indent{color:var(--text-muted);padding-left:18px;font-size:12.5px}.pricing-btn-primary{background:linear-gradient(135deg, var(--green-800), var(--green-600));color:#fff;border-radius:var(--radius-md);cursor:pointer;width:100%;font-size:14px;font-weight:700;font-family:var(--font-sans);transition:all var(--transition-fast);box-shadow:var(--shadow-sm);border:none;padding:13px}.pricing-btn-primary:hover{background:linear-gradient(135deg, var(--green-700), var(--green-500));box-shadow:var(--shadow-md)}.pricing-btn-ghost{border:1.5px solid var(--warm-200);width:100%;color:var(--text-secondary);border-radius:var(--radius-md);cursor:pointer;font-size:14px;font-weight:600;font-family:var(--font-sans);transition:all var(--transition-fast);background:0 0;padding:12px}.pricing-btn-ghost:hover{border-color:var(--green-400);color:var(--green-700);background:var(--green-50)}.pricing-btn-disabled{background:var(--warm-100);border:1px solid var(--warm-200);width:100%;color:var(--text-subtle);border-radius:var(--radius-md);cursor:not-allowed;font-size:14px;font-weight:600;font-family:var(--font-sans);padding:12px}.pricing-guarantee{color:var(--text-subtle);text-align:center;margin-top:10px;font-size:11.5px}.pricing-note{color:var(--text-muted);background:var(--gold-50);border:1px solid var(--gold-200);border-radius:var(--radius-lg);max-width:460px;margin:0 auto;padding:14px 20px;font-size:13px}.faq-section{max-width:720px;margin:0 auto;padding:96px 40px}.faq-section .section-title{text-align:center}.faq-list{border:1px solid var(--warm-100);border-radius:var(--radius-xl);background:var(--white);flex-direction:column;gap:0;display:flex;overflow:hidden}.faq-item{border-bottom:1px solid var(--warm-100)}.faq-item:last-child{border-bottom:none}.faq-item summary{color:var(--text);cursor:pointer;transition:background var(--transition-fast);justify-content:space-between;align-items:center;padding:18px 22px;font-size:15px;font-weight:600;list-style:none;display:flex}.faq-item summary::-webkit-details-marker{display:none}.faq-item summary:after{content:"+";color:var(--text-subtle);transition:transform var(--transition-fast);font-size:20px;font-weight:300}.faq-item[open] summary:after{transform:rotate(45deg)}.faq-item summary:hover{background:var(--warm-50)}.faq-item p{color:var(--text-muted);padding:0 22px 18px;font-size:14px;line-height:1.7}.cta-section{text-align:center;background:linear-gradient(135deg, var(--green-900) 0%, var(--green-800) 100%);padding:96px 40px;position:relative;overflow:hidden}.cta-section:before{content:"";background:radial-gradient(60% 60% at 50% 0,#ffffff0d 0%,#0000 70%);position:absolute;inset:0}.cta-section h2{font-family:var(--font-serif);color:#fff;letter-spacing:-.5px;margin-bottom:12px;font-size:clamp(28px,4vw,40px);font-weight:700;position:relative}.cta-section p{color:var(--green-200);margin-bottom:32px;font-size:16px;position:relative}.cta-section .btn-hero-primary{color:var(--green-900);box-shadow:var(--shadow-xl);background:#fff}.cta-section .btn-hero-primary:hover{background:var(--green-50)}.payment-modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:300;background:#0009;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0;overflow-y:auto}.payment-modal{background:var(--white);border-radius:var(--radius-2xl);width:100%;max-width:480px;box-shadow:var(--shadow-xl);border:1px solid var(--warm-100);flex-direction:column;max-height:calc(100vh - 32px);margin:auto;animation:.22s forwards scale-in;display:flex;overflow:hidden}.payment-modal-header{flex-shrink:0;justify-content:space-between;align-items:center;margin-bottom:16px;padding:20px 24px 0;display:flex}.payment-modal-header h2{color:var(--text);font-size:20px;font-weight:700}.payment-modal-close{background:var(--warm-50);border:1px solid var(--warm-100);color:var(--text-muted);border-radius:var(--radius-md);cursor:pointer;width:30px;height:30px;transition:all var(--transition-fast);flex-shrink:0;justify-content:center;align-items:center;font-size:13px;display:flex}.payment-modal-close:hover{background:var(--warm-100);color:var(--text)}.payment-modal-body{-webkit-overflow-scrolling:touch;flex:1;padding:0 24px 24px;overflow-y:auto}.payment-options{grid-template-columns:1fr 1fr;gap:12px;margin-bottom:20px;display:grid}.payment-option{border:1.5px solid var(--warm-100);border-radius:var(--radius-lg);text-align:center;padding:16px;position:relative}.payment-option.featured{border-color:var(--green-500);background:var(--green-50)}.payment-option-badge{letter-spacing:1px;color:var(--green-700);background:var(--green-100);border-radius:var(--radius-full);text-transform:uppercase;margin-bottom:4px;padding:2px 8px;font-size:9px;font-weight:800;display:inline-block}.payment-option-label{color:var(--text-muted);letter-spacing:.5px;text-transform:uppercase;margin-bottom:6px;font-size:11px;font-weight:600}.payment-option-price{color:var(--text);font-size:22px;font-weight:800;font-family:var(--font-serif)}.payment-option-price span{color:var(--text-muted);font-size:12px;font-family:var(--font-sans);font-weight:500}.payment-gcash{background:var(--warm-50);border:1px solid var(--warm-100);border-radius:var(--radius-xl);margin-bottom:14px;padding:20px}.payment-gcash-title{color:var(--text);margin-bottom:10px;font-size:14px;font-weight:700}.payment-paypal-buttons{flex-direction:column;gap:8px;margin-bottom:16px;display:flex}.paypal-btn{color:#fff;border-radius:var(--radius-md);cursor:pointer;font-size:14px;font-weight:700;font-family:var(--font-sans);transition:all var(--transition-fast);background:#0070ba;border:none;padding:12px}.paypal-btn:hover{background:#005ea6}.paypal-btn-annual{background:#003087}.paypal-btn-annual:hover{background:#002066}.payment-divider{text-align:center;color:var(--text-subtle);margin:16px 0;font-size:12px;position:relative}.payment-divider:before{content:"";background:var(--warm-200);height:1px;position:absolute;top:50%;left:0;right:0}.payment-divider span{background:var(--warm-50);padding:0 12px;position:relative}.payment-gcash-steps{flex-direction:column;gap:10px;display:flex}.payment-step{color:var(--text-secondary);align-items:flex-start;gap:10px;font-size:13px;line-height:1.5;display:flex}.payment-step-num{background:var(--green-800);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;margin-top:1px;font-size:11px;font-weight:700;display:flex}.payment-note{color:var(--text-muted);text-align:center;background:var(--green-50);border:1px solid var(--green-100);border-radius:var(--radius-md);padding:10px;font-size:12px}.landing-footer{border-top:1px solid var(--warm-100);color:var(--text-subtle);background:var(--white);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;padding:24px 40px;font-size:12.5px;display:flex}@media (width<=900px){.features-grid{grid-template-columns:repeat(2,1fr)}.pricing-grid{grid-template-columns:1fr;max-width:400px}.pricing-card.featured{transform:none}.pricing-card.featured:hover{transform:translateY(-4px)}}@media (width<=640px){.nav{padding:0 20px}.nav-links a{display:none}.hero-section{padding:64px 20px 60px}.hero-stats{flex-direction:column}.hero-stat{border-right:none;border-bottom:1px solid var(--warm-100)}.hero-stat:last-child{border-bottom:none}.features-section,.how-section,.pricing-section,.faq-section{padding:64px 20px}.features-grid{grid-template-columns:1fr}.steps{flex-direction:column;align-items:center}.step-arrow{display:none}.cta-section{padding:64px 20px}.landing-footer{flex-direction:column;align-items:center}}.hero-inner,.section-inner,.cta-inner{opacity:0;transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1);transform:translateY(32px)}.hero-inner.in-view,.section-inner.in-view,.cta-inner.in-view{opacity:1;transform:translateY(0)}.features-grid .feature-card{opacity:0;transition:opacity .5s cubic-bezier(.16,1,.3,1),transform .5s cubic-bezier(.16,1,.3,1),box-shadow .22s,border-color .22s;transform:translateY(24px)}.section-inner.in-view .feature-card{opacity:1;transform:translateY(0)}.steps .step{opacity:0;transition:opacity .5s cubic-bezier(.16,1,.3,1),transform .5s cubic-bezier(.16,1,.3,1);transform:translate(-20px)}.section-inner.in-view .step{opacity:1;transform:translate(0)}.testimonial-card{opacity:0;transition:opacity .5s cubic-bezier(.16,1,.3,1),transform .5s cubic-bezier(.16,1,.3,1);transform:translateY(20px)}.section-inner.in-view .testimonial-card{opacity:1;transform:translateY(0)}.pricing-card{opacity:0;transition:opacity .5s cubic-bezier(.16,1,.3,1),transform .5s cubic-bezier(.16,1,.3,1),box-shadow .22s,border-color .22s;transform:translateY(24px)}.section-inner.in-view .pricing-card{opacity:1;transform:translateY(0)}.section-inner.in-view .pricing-card.featured{transform:scale(1.02)}.section-inner.in-view .pricing-card.featured:hover{transform:scale(1.02)translateY(-4px)}.hero-mockup{max-width:820px;margin:48px auto 0;animation:5s ease-in-out infinite float}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.mockup-browser{background:var(--white);border:1px solid var(--warm-200);border-radius:12px;overflow:hidden;box-shadow:0 24px 64px #0000002e,0 4px 16px #00000014}.mockup-bar{border-bottom:1px solid var(--warm-200);background:#f0ede8;align-items:center;gap:12px;padding:10px 16px;display:flex}.mockup-dots{gap:6px;display:flex}.mockup-dots span{border-radius:50%;width:10px;height:10px}.mockup-dots span:first-child{background:#ff5f57}.mockup-dots span:nth-child(2){background:#febc2e}.mockup-dots span:nth-child(3){background:#28c840}.mockup-url{text-align:center;color:#8a8575;background:var(--white);border:1px solid var(--warm-200);border-radius:6px;flex:1;padding:4px 12px;font-family:JetBrains Mono,monospace;font-size:11px}.mockup-screen{grid-template-columns:1fr auto 1fr;gap:0;min-height:220px;display:grid}.mockup-before,.mockup-after{padding:20px;position:relative}.mockup-before{border-right:1px solid var(--warm-100);background:#fffbf5}.mockup-after{background:#f0fff4}.mockup-label-tag{letter-spacing:.5px;border-radius:4px;margin-bottom:10px;padding:3px 8px;font-size:10px;font-weight:700;display:inline-block}.mockup-label-tag.before{color:#92400e;background:#fef3c7}.mockup-label-tag.after{color:#065f46;background:#d1fae5}.mockup-notes-text{color:#6b7280;font-family:JetBrains Mono,monospace;font-size:11px;line-height:1.7}.mockup-arrow{background:var(--white);border-left:1px solid var(--warm-100);border-right:1px solid var(--warm-100);flex-direction:column;justify-content:center;align-items:center;gap:8px;padding:16px 12px;display:flex}.mockup-arrow-line{background:linear-gradient(to bottom, var(--green-300), var(--green-600));border-radius:1px;width:2px;height:40px;position:relative}.mockup-arrow-line:after{content:"▼";color:var(--green-600);font-size:10px;position:absolute;bottom:-16px;left:50%;transform:translate(-50%)}.mockup-arrow-label{color:var(--green-700);text-align:center;writing-mode:vertical-rl;text-orientation:mixed;letter-spacing:.5px;font-size:9.5px;font-weight:700}.mockup-report-id{color:#6b7280;letter-spacing:.5px;margin-bottom:6px;font-family:monospace;font-size:9px}.mockup-report-title{color:#1b4332;margin-bottom:14px;font-size:12px;font-weight:700;line-height:1.4}.mockup-section{align-items:center;gap:8px;margin-bottom:8px;display:flex}.mockup-section-head{color:#1b4332;letter-spacing:1px;flex-shrink:0;font-size:8px;font-weight:800}.mockup-section-line{background:var(--warm-200);border-radius:1px;flex:1;height:2px}.mockup-section-line.short{flex:.6}.mockup-actions-row{gap:6px;margin-top:14px;display:flex}.mockup-btn{background:var(--warm-50);border:1px solid var(--warm-200);color:#6b7280;border-radius:4px;padding:4px 8px;font-size:9px;font-weight:600}.mockup-btn.primary{color:#fff;background:#1b4332;border-color:#1b4332}.testimonials-section{background:linear-gradient(135deg,#0d2818 0%,#1b4332 100%);padding:96px 40px}.testimonials-section .section-label{color:var(--green-400)}.testimonials-section .section-title{color:#fff}.testimonials-grid{grid-template-columns:repeat(3,1fr);gap:20px;max-width:1100px;margin:0 auto;display:grid}.testimonial-card{border-radius:var(--radius-xl);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:background var(--transition-base), transform var(--transition-base);background:#ffffff12;border:1px solid #ffffff1f;padding:28px 24px}.testimonial-card:hover{background:#ffffff1c;transform:translateY(-4px)}.testimonial-quote-mark{color:var(--green-400);opacity:.8;margin-bottom:8px;font-family:Georgia,serif;font-size:48px;line-height:1}.testimonial-quote{color:#ffffffe0;margin-bottom:20px;font-size:14px;font-style:italic;line-height:1.75}.testimonial-author{align-items:center;gap:12px;display:flex}.testimonial-avatar{background:linear-gradient(135deg, var(--green-600), var(--green-400));color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:16px;font-weight:700;display:flex}.testimonial-name{color:#fff;font-size:13.5px;font-weight:700}.testimonial-role{color:var(--green-300);margin-top:2px;font-size:11.5px}.testimonial-location{color:#ffffff73;margin-top:2px;font-size:11px}.cta-proof{color:var(--green-300);opacity:.8;margin-top:16px;font-size:12px}@media (width<=900px){.testimonials-grid{grid-template-columns:1fr;max-width:480px;margin:0 auto}.mockup-screen{grid-template-columns:1fr}.mockup-arrow{flex-direction:row;padding:10px 20px}.mockup-arrow-line{width:40px;height:2px}.mockup-arrow-line:after{content:"▶";inset:50% -14px auto auto;transform:translateY(-50%)}.mockup-arrow-label{writing-mode:horizontal-tb}.mockup-before{border-right:none;border-bottom:1px solid var(--warm-100)}}@media (width<=640px){.testimonials-section{padding:64px 20px}.hero-mockup{display:none}}.payment-qr-section{margin-bottom:16px}.payment-qr-row{justify-content:center;gap:16px;margin-bottom:16px;display:flex}.payment-qr-item{flex-direction:column;align-items:center;gap:8px;display:flex}.payment-qr-img{object-fit:contain;border-radius:var(--radius-lg);border:1px solid var(--warm-200);background:#fff;width:140px;height:140px;padding:8px}.payment-qr-label{color:var(--text);font-size:13px;font-weight:700}.app{background:var(--bg);min-height:100vh;color:var(--text);font-family:var(--font-sans);display:flex}.app-layout{width:100%;min-height:100vh;display:flex}.app-main{flex-direction:column;flex:1;min-width:0;display:flex;overflow-x:hidden}.sidebar{background:var(--surface);border-right:1px solid var(--border);z-index:50;flex-direction:column;flex-shrink:0;align-self:flex-start;width:260px;height:100vh;transition:width .25s cubic-bezier(.16,1,.3,1);display:flex;position:sticky;top:0;overflow:hidden}.sidebar.collapsed{width:64px}.sidebar-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:49;opacity:0;pointer-events:none;background:#00000073;transition:opacity .22s;display:none;position:fixed;inset:0}.sidebar-overlay.visible{opacity:1;pointer-events:all}.sidebar-logo{border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;gap:10px;min-height:64px;padding:18px 16px;display:flex}.sidebar-logo-mark{background:linear-gradient(135deg, var(--green-800), var(--green-600));color:#fff;border-radius:var(--radius-md);letter-spacing:.5px;width:34px;height:34px;box-shadow:var(--shadow-sm), 0 0 0 0 #40916c4d;flex-shrink:0;justify-content:center;align-items:center;font-size:12px;font-weight:800;transition:box-shadow .3s;display:flex}.sidebar-logo-mark:hover{box-shadow:var(--shadow-md), 0 0 0 6px #40916c1f}.sidebar-logo-text{flex:1;min-width:0}.sidebar-logo-title{color:var(--text);white-space:nowrap;letter-spacing:-.2px;font-size:14px;font-weight:700}.sidebar-logo-sub{color:var(--text-muted);letter-spacing:.3px;white-space:nowrap;text-overflow:ellipsis;font-size:10px;overflow:hidden}.sidebar-collapse-btn{border:1px solid var(--border);color:var(--text-muted);border-radius:var(--radius-sm);cursor:pointer;width:26px;height:26px;transition:all var(--transition-fast);background:0 0;flex-shrink:0;justify-content:center;align-items:center;display:flex}.sidebar-collapse-btn:hover{border-color:var(--green-600);color:var(--green-700);background:var(--green-50)}.dark .sidebar-collapse-btn:hover{color:var(--green-400);background:#40916c26}.sidebar-collapse-btn-solo{width:100%;height:100%;color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);border-radius:var(--radius-md);background:0 0;border:none;justify-content:center;align-items:center;padding:8px;display:flex}.sidebar-collapse-btn-solo:hover{background:var(--surface-hover);color:var(--green-600)}.sidebar-scroll-area{-webkit-overflow-scrolling:touch;flex:1;min-height:0;overflow:hidden auto}.sidebar-nav{padding:12px 8px}.sidebar-bottom{border-top:1px solid var(--border);flex-shrink:0}.sidebar-nav-label{color:var(--text-subtle);letter-spacing:1.8px;text-transform:uppercase;align-items:center;height:24px;margin-bottom:4px;padding:0 8px;font-size:9.5px;font-weight:700;display:flex}.sidebar-nav-item{border-radius:var(--radius-md);width:100%;color:var(--text-muted);font-family:var(--font-sans);cursor:pointer;text-align:left;transition:all var(--transition-fast);white-space:nowrap;background:0 0;border:none;align-items:center;gap:10px;padding:9px 12px;font-size:13.5px;font-weight:500;display:flex;position:relative;overflow:hidden}.sidebar-nav-item:hover{background:var(--surface-hover);color:var(--text)}.sidebar-nav-item.active{background:var(--green-50);color:var(--green-800);font-weight:600}.dark .sidebar-nav-item.active{color:var(--green-400);background:#40916c26}.sidebar-nav-icon{text-align:center;flex-shrink:0;width:20px;font-size:16px}.sidebar-nav-text{flex:1}.sidebar-nav-badge{background:var(--green-100);color:var(--green-800);border-radius:var(--radius-full);flex-shrink:0;padding:1px 6px;font-size:10px;font-weight:700}.dark .sidebar-nav-badge{color:var(--green-400);background:#40916c33}.sidebar-plan{padding:12px}.sidebar-plan-badge{background:var(--bg-subtle);border:1px solid var(--border);border-radius:var(--radius-md);align-items:center;gap:8px;margin-bottom:8px;padding:8px 10px;display:flex}.sidebar-plan-icon{flex-shrink:0;font-size:14px}.sidebar-plan-name{color:var(--text-muted);letter-spacing:1px;font-size:10px;font-weight:700}.sidebar-plan-limit{color:var(--text-subtle);margin-top:1px;font-size:11px}.sidebar-plan-limit.limit-reached{color:var(--red-600);font-weight:600}.sidebar-plan-limit.limit-warning{color:var(--amber-600);font-weight:600}.sidebar-upgrade-btn{background:linear-gradient(135deg, var(--green-800), var(--green-600));color:#fff;border-radius:var(--radius-md);cursor:pointer;width:100%;font-size:12px;font-weight:600;font-family:var(--font-sans);transition:all var(--transition-fast);letter-spacing:.2px;box-shadow:var(--shadow-sm);border:none;padding:8px 12px}.sidebar-upgrade-btn:hover{background:linear-gradient(135deg, var(--green-700), var(--green-500));box-shadow:var(--shadow-md);transform:translateY(-1px)}.sidebar-user-wrapper{padding:8px 12px 12px;position:relative}.sidebar-user{border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);background:var(--bg-subtle);border:1px solid #0000;align-items:center;gap:10px;padding:10px 12px;display:flex}.sidebar-user:hover{background:var(--surface-hover);border-color:var(--border)}.sidebar-user.active{border-color:var(--border-focus)}.sidebar-avatar{object-fit:cover;border:2px solid var(--border);border-radius:50%;flex-shrink:0;width:30px;height:30px}.sidebar-user-info{flex:1;min-width:0}.sidebar-user-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.sidebar-user-email{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:11px;overflow:hidden}.sidebar-user-chevron{color:var(--text-subtle);transition:transform var(--transition-fast);font-size:12px}.sidebar-user.active .sidebar-user-chevron{transform:rotate(180deg)}.sidebar-user-dropdown{background:var(--surface-raised);border:1px solid var(--border-strong);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);z-index:100;animation:.2s forwards slide-up;position:absolute;bottom:calc(100% - 8px);left:12px;right:12px;overflow:hidden}.sud-info{align-items:center;gap:10px;padding:14px 16px;display:flex}.sud-avatar{border:2px solid var(--border);border-radius:50%;width:36px;height:36px}.sud-name{color:var(--text);font-size:13px;font-weight:600}.sud-email{color:var(--text-muted);font-size:11px}.sud-divider{background:var(--border);height:1px}.sud-plan{align-items:center;gap:8px;padding:10px 16px;display:flex}.sud-plan-icon{font-size:14px}.sud-plan-text{color:var(--text-muted);flex:1;font-size:12px;font-weight:600}.sud-upgrade{color:var(--green-700);cursor:pointer;font-size:11px;font-weight:600;font-family:var(--font-sans);background:0 0;border:none}.dark .sud-upgrade{color:var(--green-400)}.sud-item{color:var(--text-secondary);cursor:pointer;text-align:left;width:100%;font-size:13px;font-weight:500;font-family:var(--font-sans);transition:all var(--transition-fast);background:0 0;border:none;align-items:center;gap:10px;padding:10px 16px;display:flex}.sud-item:hover{background:var(--surface-hover)}.sud-item.danger{color:var(--red-600)}.sud-item.danger:hover{background:var(--red-100)}.dark .sud-item.danger:hover{background:#dc26261a}.header{border-bottom:1px solid var(--border);background:var(--surface);z-index:40;flex-shrink:0;justify-content:space-between;align-items:center;height:56px;padding:0 24px;display:flex;position:sticky;top:0}.header-left{align-items:center;gap:12px;display:flex}.header-report-title{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;max-width:400px;font-size:13.5px;font-weight:600;overflow:hidden}.hamburger{border:1px solid var(--border);color:var(--text-muted);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);background:0 0;padding:6px 10px;font-size:16px;display:none}.hamburger:hover{border-color:var(--green-600);color:var(--green-700)}.mobile-only{display:none}.main{flex:1;width:100%;max-width:860px;margin:0 auto;padding:28px;overflow-y:auto}.dashboard-greeting{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:28px;display:flex}.greeting-text{color:var(--text);letter-spacing:-.4px;font-size:22px;font-weight:700;line-height:1.3}.greeting-sub{color:var(--text-muted);margin-top:4px;font-size:13px}.greeting-right{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:6px;display:flex}.plan-badge{border-radius:var(--radius-full);letter-spacing:1px;text-transform:uppercase;align-items:center;gap:6px;padding:5px 12px;font-size:10.5px;font-weight:700;display:inline-flex}.plan-badge.free{background:var(--green-50);color:var(--green-800);border:1px solid var(--green-200)}.plan-badge.pro{background:linear-gradient(135deg, var(--gold-100), var(--gold-200));color:var(--gold-700);border:1px solid var(--gold-400)}.dark .plan-badge.free{color:var(--green-400);background:#40916c1f;border-color:#40916c33}.dark .plan-badge.pro{color:var(--gold-400);background:#d4a84326;border-color:#d4a8434d}.plan-icon{font-size:12px}.plan-reports{color:var(--text-muted);font-size:11px}.plan-reports.limit-reached{color:var(--red-600);font-weight:600}.plan-reports.limit-warning{color:var(--amber-600);font-weight:600}.dashboard-section{margin-bottom:28px;animation:.35s both section-reveal}.dashboard-section:nth-child(2){animation-delay:60ms}.dashboard-section:nth-child(3){animation-delay:.12s}.dashboard-section:nth-child(4){animation-delay:.18s}.step-header{align-items:center;gap:12px;margin-bottom:14px;display:flex}.step-number{background:var(--primary);color:#fff;border-radius:var(--radius-md);letter-spacing:.5px;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:11px;font-weight:800;display:flex}.step-title{color:var(--text);font-size:15px;font-weight:700}.template-group{margin-bottom:16px}.template-group-label{color:var(--text-subtle);letter-spacing:1.4px;text-transform:uppercase;align-items:center;gap:8px;margin-bottom:10px;font-size:10.5px;font-weight:700;display:flex}.template-group-label.ph{color:var(--text-muted)}.pro-label{background:linear-gradient(135deg, var(--gold-100), var(--gold-200));color:var(--gold-700);border-radius:var(--radius-full);letter-spacing:1px;padding:2px 6px;font-size:9px;font-weight:800}.dark .pro-label{color:var(--gold-400);background:#d4a84333}.template-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px;display:grid}.template-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;text-align:left;font-family:var(--font-sans);transition:all var(--transition-base);padding:16px 14px;position:relative;overflow:hidden}.template-card:before{content:"";background:linear-gradient(90deg, var(--green-600), var(--green-400));opacity:0;height:3px;transition:opacity var(--transition-fast);position:absolute;top:0;left:0;right:0}.template-card:hover{border-color:var(--green-400);box-shadow:var(--shadow-md);transform:translateY(-2px)}.template-card:hover:before{opacity:1}.template-card.active{border-color:var(--green-600);background:var(--green-50);box-shadow:var(--shadow-glow)}.template-card.active:before{opacity:1}.dark .template-card.active{border-color:var(--green-500);background:#40916c1a}.template-icon{margin-bottom:8px;font-size:22px}.template-name{color:var(--text);margin-bottom:4px;font-size:13px;font-weight:700}.template-desc{color:var(--text-muted);font-size:11.5px;line-height:1.45}.template-card.ph-template{opacity:.65}.pro-lock{background:var(--gold-100);color:var(--gold-700);border-radius:var(--radius-full);align-items:center;gap:4px;margin-top:8px;padding:3px 8px;font-size:10px;font-weight:700;display:inline-flex}.dark .pro-lock{color:var(--gold-400);background:#d4a84326}.lock-icon{font-size:10px}.input-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-xs);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);padding:20px}.input-card:focus-within{border-color:var(--green-400);box-shadow:var(--shadow-glow)}.input-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.input-label{color:var(--text);font-size:13px;font-weight:700}.btn-link-small{color:var(--text-subtle);cursor:pointer;font-size:12px;font-family:var(--font-sans);transition:color var(--transition-fast);background:0 0;border:none;-webkit-text-decoration:underline dotted;text-decoration:underline dotted}.btn-link-small:hover{color:var(--red-600)}.sample-library{margin-bottom:12px}.sample-label{color:var(--text-muted);margin-bottom:8px;font-size:11px;font-weight:500}.sample-grid{flex-wrap:wrap;gap:6px;display:flex}.sample-chip{background:var(--bg-subtle);border:1px solid var(--border);border-radius:var(--radius-full);color:var(--text-secondary);cursor:pointer;font-size:12px;font-weight:500;font-family:var(--font-sans);transition:all var(--transition-fast);white-space:nowrap;padding:5px 12px}.sample-chip:hover{background:var(--green-50);border-color:var(--green-400);color:var(--green-800)}.dark .sample-chip:hover{border-color:var(--green-500);color:var(--green-400);background:#40916c1f}.notes-input{background:var(--bg-subtle);border:1.5px solid var(--border);border-radius:var(--radius-lg);width:100%;min-height:200px;font-family:var(--font-sans);color:var(--text);resize:none;transition:all var(--transition-fast);caret-color:var(--green-600);padding:14px;font-size:13.5px;line-height:1.7}.notes-input:focus{border-color:var(--border-focus);background:var(--surface);box-shadow:var(--shadow-glow);outline:none}.notes-input::placeholder{color:var(--text-subtle);font-style:italic}.notes-input.auto-grow{overflow:hidden}.input-footer{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-top:14px;display:flex}.footer-left{align-items:center;gap:12px;display:flex}.char-count{color:var(--text-subtle);font-size:11.5px;font-family:var(--font-mono)}.btn-link{color:var(--green-700);cursor:pointer;font-size:12px;font-family:var(--font-sans);transition:color var(--transition-fast);background:0 0;border:none;-webkit-text-decoration:underline dotted;text-decoration:underline dotted}.dark .btn-link{color:var(--green-400)}.btn-link:hover{color:var(--green-600)}.btn-primary{background:linear-gradient(135deg, var(--green-800), var(--green-600));color:#fff;border-radius:var(--radius-md);font-family:var(--font-sans);cursor:pointer;transition:all var(--transition-base);box-shadow:var(--shadow-sm);white-space:nowrap;letter-spacing:.1px;border:none;align-items:center;gap:8px;padding:10px 20px;font-size:13.5px;font-weight:600;display:inline-flex}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg, var(--green-700), var(--green-500));box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-primary:active:not(:disabled){box-shadow:var(--shadow-xs);transform:translateY(0)}.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-ghost{background:var(--surface);border:1.5px solid var(--border);color:var(--text-secondary);border-radius:var(--radius-md);font-family:var(--font-sans);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;align-items:center;gap:6px;padding:9px 16px;font-size:13px;font-weight:500;display:inline-flex}.btn-ghost:hover{border-color:var(--border-strong);color:var(--text);background:var(--surface-hover);box-shadow:var(--shadow-xs)}.loading-dots{align-items:center;gap:1px;display:inline-flex}.loading-dots span{animation:1.2s infinite typing-dot}.loading-dots span:nth-child(2){animation-delay:.2s}.loading-dots span:nth-child(3){animation-delay:.4s}.skeleton-report{margin-top:24px;animation:.3s forwards fade-in}.skeleton-header{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl) var(--radius-xl) 0 0;border-bottom:none;padding:24px}.skeleton-body{background:var(--surface);border:1px solid var(--border);border-radius:0 0 var(--radius-xl) var(--radius-xl);padding:0 24px 24px}.skeleton-section{border-bottom:1px solid var(--border);padding:20px 0}.skeleton-section:last-child{border-bottom:none}.skeleton-line{border-radius:var(--radius-full);background:linear-gradient(90deg, var(--warm-100) 25%, var(--warm-50) 50%, var(--warm-100) 75%);background-size:200% 100%;height:10px;margin-bottom:10px;animation:1.5s linear infinite shimmer}.dark .skeleton-line{background:linear-gradient(90deg,#ffffff0f 25%,#ffffff08 50%,#ffffff0f 75%) 0 0/200% 100%}.skeleton-id{width:80px;height:8px}.skeleton-title{width:60%;height:16px;margin-bottom:8px}.skeleton-meta{width:30%;height:8px}.skeleton-heading{background:var(--green-100);width:35%;height:9px;margin-bottom:12px}.dark .skeleton-heading{background:#40916c26}.skeleton-text{width:100%}.skeleton-text.short{width:65%}.streaming-preview{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius-xl);margin-top:24px;animation:.3s forwards fade-in;overflow:hidden}.streaming-header{border-bottom:1px solid var(--border);background:var(--bg-subtle);align-items:center;gap:10px;padding:14px 20px;display:flex}.streaming-pulse{background:var(--green-500);border-radius:50%;width:8px;height:8px;animation:1.4s infinite pulse-ring;box-shadow:0 0 #52b78899}@keyframes pulse-ring{0%{box-shadow:0 0 #dc262680}70%{box-shadow:0 0 0 8px #dc262600}to{box-shadow:0 0 #dc262600}}.streaming-label{color:var(--green-700);font-size:12px;font-weight:600;font-family:var(--font-mono)}.dark .streaming-label{color:var(--green-400)}.streaming-content{font-family:var(--font-mono);color:var(--text-secondary);white-space:pre-wrap;word-break:break-word;max-height:380px;padding:20px;font-size:12.5px;line-height:1.7;overflow-y:auto}.streaming-cursor{color:var(--green-600);font-weight:700;animation:1s infinite cursor-blink}.error-box{background:var(--red-100);border-radius:var(--radius-lg);color:var(--red-600);border:1px solid #dc262633;margin-top:16px;padding:14px 16px;font-size:13.5px;line-height:1.5}.dark .error-box{background:#dc26261a;border-color:#dc262640}.report{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);animation:.35s forwards slide-up;overflow:hidden}.report-header{border-bottom:1px solid var(--border);padding:28px 32px 24px}.report-meta{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.report-id{font-family:var(--font-mono);color:var(--text-muted);letter-spacing:.5px;background:var(--bg-subtle);border:1px solid var(--border);border-radius:var(--radius-sm);padding:3px 8px;font-size:11px;font-weight:600}.report-date{color:var(--text-subtle);font-size:12px}.report-stats{color:var(--text-subtle);flex-wrap:wrap;align-items:center;gap:6px;margin-bottom:12px;font-size:11.5px;display:flex}.stat-item{align-items:center;gap:4px;display:flex}.stat-divider{color:var(--border-strong)}.report-title{font-family:var(--font-serif);color:var(--text);letter-spacing:-.3px;cursor:pointer;transition:color var(--transition-fast);align-items:flex-start;gap:8px;margin-bottom:20px;font-size:22px;font-weight:700;line-height:1.35;display:flex}.report-title:hover{color:var(--green-800)}.dark .report-title:hover{color:var(--green-400)}.edit-hint{color:var(--text-subtle);opacity:0;transition:opacity var(--transition-fast);flex-shrink:0;margin-top:4px;font-size:14px}.report-title:hover .edit-hint{opacity:1}.title-edit{width:100%;font-family:var(--font-serif);color:var(--text);border:none;border-bottom:2px solid var(--border-focus);background:0 0;outline:none;margin-bottom:20px;padding:2px 0;font-size:22px;font-weight:700;line-height:1.35}.reviewer-block{border:1px dashed var(--border-strong);border-radius:var(--radius-lg);background:var(--bg-subtle);margin-bottom:20px;padding:16px 20px}.reviewer-label{color:var(--text-subtle);letter-spacing:1.8px;text-transform:uppercase;margin-bottom:14px;font-size:9.5px;font-weight:700}.reviewer-sig-line{border-top:1px solid var(--border-strong);width:240px;margin:0 0 4px}.reviewer-sig-hint{color:var(--text-subtle);letter-spacing:.8px;text-transform:uppercase;margin-bottom:16px;font-size:10px}.report-actions{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:14px;display:flex}.ai-watermark{color:var(--gold-600);background:var(--gold-50);border:1px solid var(--gold-200);border-radius:var(--radius-md);padding:8px 12px;font-size:11px;line-height:1.5}.dark .ai-watermark{color:var(--gold-400);background:#d4a84314;border-color:#d4a84333}.report-body{padding:4px 0}.section{border-bottom:1px solid var(--border);transition:background var(--transition-fast);padding:20px 32px;animation:.3s both section-reveal}.section:first-child{animation-delay:0s}.section:nth-child(2){animation-delay:60ms}.section:nth-child(3){animation-delay:.12s}.section:nth-child(4){animation-delay:.18s}.section:nth-child(5){animation-delay:.24s}.section:nth-child(6){animation-delay:.3s}.section:last-child{border-bottom:none}.section:hover{background:var(--bg-subtle)}.section.section-collapsed{padding-bottom:12px}.section-head-row{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.section-head-left{align-items:center;gap:8px;display:flex}.section-toggle{color:var(--text-subtle);cursor:pointer;transition:color var(--transition-fast);font-size:11px;font-family:var(--font-sans);background:0 0;border:none;padding:2px 4px}.section-toggle:hover{color:var(--text-muted)}.section-heading{color:var(--green-800);letter-spacing:1.6px;text-transform:uppercase;font-size:10.5px;font-weight:800}.dark .section-heading{color:var(--green-400)}.edit-btn{color:var(--text-subtle);background:var(--bg-subtle);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;font-size:11.5px;font-weight:600;font-family:var(--font-sans);transition:all var(--transition-fast);white-space:nowrap;padding:3px 10px}.edit-btn:hover{color:var(--green-700);border-color:var(--green-400);background:var(--green-50)}.dark .edit-btn:hover{color:var(--green-400);border-color:var(--green-500);background:#40916c1f}.section-content{color:var(--text-secondary);font-size:14px;line-height:1.8;font-family:var(--font-sans);white-space:pre-wrap;word-break:break-word}.section-edit{width:100%;font-family:var(--font-sans);color:var(--text);background:var(--bg-subtle);border:1.5px solid var(--border-focus);border-radius:var(--radius-md);resize:vertical;box-shadow:var(--shadow-glow);outline:none;padding:12px 14px;font-size:14px;line-height:1.8}.template-upload-label{color:var(--text);align-items:center;gap:8px;margin-bottom:10px;font-size:13px;font-weight:600;display:flex}.template-upload-optional{color:var(--text-subtle);font-size:11px;font-weight:400}.template-dropzone{border:2px dashed var(--border-strong);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-base);background:var(--bg-subtle);text-align:center;padding:28px}.template-dropzone:hover,.template-dropzone.dragging{border-color:var(--green-500);background:var(--green-50);transform:scale(1.005)}.dark .template-dropzone:hover,.dark .template-dropzone.dragging{background:#40916c14}.template-dropzone-content{flex-direction:column;align-items:center;gap:6px;display:flex}.template-drop-icon{font-size:28px}.template-drop-text{color:var(--text);font-size:13.5px;font-weight:500}.template-drop-sub{color:var(--text-muted);font-size:12px}.template-reading-spinner{font-size:24px;animation:1.5s linear infinite spin}.template-reading{color:var(--text);font-size:13px;font-weight:500}.template-reading-sub{color:var(--text-muted);font-size:11.5px}.template-error{color:var(--red-600);background:var(--red-100);border-radius:var(--radius-md);margin-top:8px;padding:8px 12px;font-size:12px}.dark .template-error{background:#dc26261a}.template-upload-hints{flex-wrap:wrap;gap:8px;margin-top:10px;display:flex}.template-hint-item{color:var(--text-muted);background:var(--bg-subtle);border:1px solid var(--border);border-radius:var(--radius-full);padding:4px 10px;font-size:11.5px}.template-upload-locked{background:var(--bg-subtle);border:1.5px dashed var(--border-strong);border-radius:var(--radius-lg);align-items:flex-start;gap:16px;padding:18px 20px;display:flex}.tul-icon{flex-shrink:0;font-size:24px}.tul-title{color:var(--text);align-items:center;gap:8px;margin-bottom:4px;font-size:14px;font-weight:700;display:flex}.tul-desc{color:var(--text-muted);margin-bottom:12px;font-size:12.5px;line-height:1.6}.pro-lock-inline{border-radius:var(--radius-full);background:var(--gold-100);color:var(--gold-700);letter-spacing:.8px;padding:2px 7px;font-size:9.5px;font-weight:800}.dark .pro-lock-inline{color:var(--gold-400);background:#d4a84326}.tul-upgrade{color:var(--green-700);background:var(--green-50);border:1.5px solid var(--green-200);border-radius:var(--radius-md);cursor:pointer;font-size:12.5px;font-weight:600;font-family:var(--font-sans);transition:all var(--transition-fast);padding:6px 14px}.tul-upgrade:hover{background:var(--green-100);border-color:var(--green-400)}.dark .tul-upgrade{color:var(--green-400);background:#40916c1f;border-color:#40916c4d}.template-upload-success{background:var(--green-50);border:1.5px solid var(--green-200);border-radius:var(--radius-lg);align-items:flex-start;gap:14px;padding:16px 18px;display:flex}.dark .template-upload-success{background:#40916c1a;border-color:#40916c40}.tus-icon{flex-shrink:0;font-size:22px}.tus-info{flex:1}.tus-name{color:var(--green-800);margin-bottom:6px;font-size:13.5px;font-weight:700}.dark .tus-name{color:var(--green-400)}.tus-meta{flex-wrap:wrap;gap:6px;margin-bottom:8px;display:flex}.tus-badge{background:var(--green-100);color:var(--green-800);border-radius:var(--radius-full);padding:2px 8px;font-size:11px;font-weight:500}.dark .tus-badge{color:var(--green-400);background:#40916c33}.tus-sections{color:var(--green-700);margin-bottom:8px;font-size:12.5px}.dark .tus-sections{color:var(--green-400)}.tus-section-list{flex-wrap:wrap;gap:6px;display:flex}.tus-section-chip{background:var(--surface);border:1px solid var(--green-200);color:var(--green-800);border-radius:var(--radius-full);padding:3px 10px;font-size:11px;font-weight:500}.dark .tus-section-chip{color:var(--green-400);background:#40916c14;border-color:#40916c40}.tus-clear{color:var(--text-subtle);cursor:pointer;font-size:11px;font-family:var(--font-sans);border-radius:var(--radius-sm);transition:all var(--transition-fast);background:0 0;border:none;flex-shrink:0;padding:2px 6px}.tus-clear:hover{color:var(--red-600);background:var(--red-100)}.modal-overlay{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:200;background:#00000080;justify-content:center;align-items:center;padding:24px;animation:.18s forwards fade-in;display:flex;position:fixed;inset:0}.modal{background:var(--surface);border-radius:var(--radius-2xl);width:100%;max-width:500px;box-shadow:var(--shadow-xl);border:1px solid var(--border-strong);text-align:center;padding:32px;animation:.22s forwards scale-in}.modal-icon{margin-bottom:12px;font-size:36px}.modal-title{color:var(--text);letter-spacing:-.3px;margin-bottom:8px;font-size:20px;font-weight:700}.modal-subtitle{color:var(--text-muted);margin-bottom:20px;font-size:13.5px;line-height:1.6}.modal-checklist{text-align:left;flex-direction:column;gap:12px;margin-bottom:24px;display:flex}.modal-check-item{color:var(--text-secondary);cursor:pointer;align-items:flex-start;gap:10px;font-size:13.5px;line-height:1.6;display:flex}.modal-check-item input[type=checkbox]{accent-color:var(--green-600);flex-shrink:0;margin-top:2px}.modal-check-item.static{cursor:default}.check-icon{color:var(--green-600);flex-shrink:0;margin-top:1px;font-size:16px;font-weight:700}.modal-actions{flex-wrap:wrap;justify-content:center;gap:10px;display:flex}.history-drawer{background:var(--surface);border-radius:var(--radius-2xl);width:100%;max-width:560px;max-height:85vh;box-shadow:var(--shadow-xl);border:1px solid var(--border-strong);flex-direction:column;animation:.28s forwards slide-up;display:flex;overflow:hidden}.history-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:flex-start;padding:24px 24px 16px;display:flex}.history-subtitle{color:var(--text-muted);margin-top:4px;font-size:12px}.history-close{background:var(--bg-subtle);border:1px solid var(--border);color:var(--text-muted);border-radius:var(--radius-md);cursor:pointer;width:30px;height:30px;transition:all var(--transition-fast);flex-shrink:0;justify-content:center;align-items:center;font-size:12px;display:flex}.history-close:hover{color:var(--text);background:var(--surface-hover)}.history-empty{text-align:center;padding:48px 24px}.history-empty-text{color:var(--text);margin-bottom:6px;font-size:15px;font-weight:600}.history-empty-hint{color:var(--text-muted);font-size:13px}.history-list{flex:1;padding:8px;overflow-y:auto}.history-item{border-radius:var(--radius-md);align-items:center;gap:8px;margin-bottom:2px;padding:2px;display:flex}.history-item-main{cursor:pointer;border-radius:var(--radius-md);transition:background var(--transition-fast);border:1px solid #0000;flex:1;padding:12px 14px}.history-item-main:hover{background:var(--surface-hover);border-color:var(--border)}.history-item-id{font-family:var(--font-mono);color:var(--text-muted);margin-bottom:4px;font-size:10.5px}.history-item-title{color:var(--text);margin-bottom:3px;font-size:13.5px;font-weight:600;line-height:1.4}.history-item-date{color:var(--text-subtle);font-size:11px}.history-item-delete{cursor:pointer;color:var(--text-subtle);border-radius:var(--radius-md);transition:all var(--transition-fast);background:0 0;border:none;flex-shrink:0;padding:8px;font-size:14px}.history-item-delete:hover{background:var(--red-100);color:var(--red-600)}.dark .history-item-delete:hover{background:#dc26261a}.history-footer{border-top:1px solid var(--border);flex-shrink:0;justify-content:flex-end;padding:12px 20px;display:flex}.shortcuts-modal{background:var(--surface);border-radius:var(--radius-2xl);width:100%;max-width:440px;box-shadow:var(--shadow-xl);border:1px solid var(--border-strong);animation:.22s forwards scale-in;overflow:hidden}.shortcuts-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:flex-start;padding:24px 24px 16px;display:flex}.shortcuts-list{padding:16px 24px}.shortcuts-group{margin-bottom:20px}.shortcuts-group:last-child{margin-bottom:0}.shortcuts-group-label{color:var(--text-subtle);letter-spacing:1.6px;text-transform:uppercase;margin-bottom:10px;font-size:9.5px;font-weight:700}.shortcut-row{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:8px 0;display:flex}.shortcut-row:last-child{border-bottom:none}.shortcut-desc{color:var(--text-secondary);font-size:13.5px}.shortcut-keys{align-items:center;gap:4px;display:flex}kbd{background:var(--bg-subtle);border:1px solid var(--border-strong);border-radius:var(--radius-sm);font-family:var(--font-mono);color:var(--text-secondary);border-bottom-width:2px;justify-content:center;align-items:center;min-width:24px;padding:3px 8px;font-size:11px;display:inline-flex}.shortcuts-footer{border-top:1px solid var(--border);color:var(--text-subtle);padding:14px 24px;font-size:12px}.onboarding-overlay{z-index:300;background:#0000008c;position:fixed;inset:0}.onboarding-tooltip{z-index:301;background:var(--green-900);color:#fff;border-radius:var(--radius-xl);width:300px;box-shadow:var(--shadow-xl);padding:20px 24px;animation:.25s forwards scale-in;position:absolute;transform:translate(-50%)}.onboarding-step-count{color:var(--green-400);letter-spacing:1px;text-transform:uppercase;margin-bottom:6px;font-size:10px;font-weight:700}.onboarding-title{color:#fff;margin-bottom:8px;font-size:15px;font-weight:700}.onboarding-desc{color:var(--green-200);margin-bottom:16px;font-size:13px;line-height:1.6}.onboarding-progress{gap:6px;margin-bottom:16px;display:flex}.onboarding-dot{width:6px;height:6px;transition:all var(--transition-fast);background:#ffffff40;border-radius:50%}.onboarding-dot.active{background:#fff;border-radius:3px;width:18px}.onboarding-dot.done{background:var(--green-400)}.onboarding-actions{justify-content:space-between;align-items:center;display:flex}.onboarding-skip{color:var(--green-300);cursor:pointer;font-size:13px;font-family:var(--font-sans);opacity:.7;background:0 0;border:none}.onboarding-next{color:var(--green-900);border-radius:var(--radius-md);cursor:pointer;font-size:13px;font-weight:700;font-family:var(--font-sans);transition:all var(--transition-fast);background:#fff;border:none;padding:8px 16px}.onboarding-next:hover{background:var(--green-100)}.toast{z-index:9999;border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);align-items:center;gap:8px;max-width:360px;padding:12px 18px;font-size:13.5px;font-weight:500;animation:.3s cubic-bezier(.16,1,.3,1) forwards toast-slide;display:flex;position:fixed;bottom:24px;right:24px}.toast-success{background:var(--green-900);color:#fff;border:1px solid var(--green-700)}.toast-error{color:#fff;border:1px solid var(--red-600);background:#7f1d1d}.dark .toast-success{background:var(--green-800)}.footer{border-top:1px solid var(--border);color:var(--text-subtle);text-align:center;flex-shrink:0;padding:16px 28px;font-size:12px}.auth-page{background:var(--bg);flex-direction:column;align-items:center;min-height:100vh;padding:40px 24px;display:flex}.auth-header{cursor:pointer;align-items:center;gap:12px;margin-bottom:32px;display:flex}.auth-content{flex:1;justify-content:center;align-items:flex-start;display:flex}.auth-back{color:var(--text-muted);cursor:pointer;font-size:13px;font-family:var(--font-sans);border-radius:var(--radius-md);transition:color var(--transition-fast);background:0 0;border:none;margin-top:24px;padding:8px}.auth-back:hover{color:var(--text)}.auth-loading{flex-direction:column;justify-content:center;align-items:center;gap:16px;min-height:100vh;display:flex}.auth-loading-mark{background:linear-gradient(135deg, var(--green-800), var(--green-600));color:#fff;border-radius:var(--radius-lg);justify-content:center;align-items:center;width:48px;height:48px;font-size:16px;font-weight:800;animation:2s infinite float;display:flex}.auth-loading-text{color:var(--text-muted);font-size:14px;animation:.5s forwards fade-in}@media (width<=768px){.sidebar{z-index:50;width:280px;height:100%;transition:transform .28s cubic-bezier(.16,1,.3,1),box-shadow .28s;position:fixed;top:0;left:0;transform:translate(-100%)}.sidebar.mobile-open{box-shadow:var(--shadow-2xl);transform:translate(0)}.sidebar-overlay{display:block}.mobile-only{display:flex}.main{padding:20px 16px}.report-header{padding:20px 20px 18px}.section{padding:16px 20px}.template-grid{grid-template-columns:repeat(2,1fr)}.history-drawer{border-radius:var(--radius-xl) var(--radius-xl) 0 0;max-width:100%;max-height:90vh}.modal-overlay{align-items:flex-end}.modal{border-radius:var(--radius-xl) var(--radius-xl) 0 0;padding:24px 20px 32px}.report-actions{gap:6px}.dashboard-greeting{flex-direction:column}.greeting-right{align-items:flex-start}.header{padding:0 16px}}@media (width<=480px){.template-grid{grid-template-columns:1fr}.report-title{font-size:18px}.report-header{padding:16px 16px 14px}.section{padding:14px 16px}.btn-primary,.btn-ghost{padding:8px 14px;font-size:12.5px}}@media print{.sidebar,.header,.report-actions,.footer,.ai-watermark{display:none!important}.report{box-shadow:none;border:none}.section{break-inside:avoid;border-bottom:1px solid #ddd}body{background:#fff}}.sidebar-avatar-fallback{background:linear-gradient(135deg, var(--green-700), var(--green-500));color:#fff;border:2px solid var(--border);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;font-size:13px;font-weight:700;display:flex}.audio-locked{background:var(--bg-subtle);border:1.5px dashed var(--border-strong);border-radius:var(--radius-lg);align-items:flex-start;gap:16px;padding:18px 20px;display:flex}.audio-locked-icon{flex-shrink:0;font-size:24px}.audio-locked-title{color:var(--text);align-items:center;gap:8px;margin-bottom:4px;font-size:14px;font-weight:700;display:flex}.audio-locked-desc{color:var(--text-muted);margin-bottom:12px;font-size:12.5px;line-height:1.6}.audio-recorder{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius-lg);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);overflow:hidden}.audio-recorder.expanded{border-color:var(--green-400);box-shadow:var(--shadow-glow)}.audio-header{cursor:pointer;width:100%;font-family:var(--font-sans);transition:background var(--transition-fast);background:0 0;border:none;justify-content:space-between;align-items:center;padding:14px 18px;display:flex}.audio-header:hover{background:var(--surface-hover)}.audio-header-left{align-items:center;gap:12px;display:flex}.audio-header-icon{flex-shrink:0;font-size:20px}.audio-header-title{color:var(--text);text-align:left;font-size:13.5px;font-weight:700}.audio-header-sub{color:var(--text-muted);text-align:left;margin-top:2px;font-size:11.5px}.audio-header-right{align-items:center;gap:10px;display:flex}.audio-chevron{color:var(--text-subtle);font-size:11px}.audio-rec-dot{background:var(--red-600);border-radius:50%;width:8px;height:8px;animation:1.2s infinite pulse-ring;box-shadow:0 0 #dc262680}.audio-body{border-top:1px solid var(--border);padding:16px 18px 20px;animation:.2s forwards fade-in}.audio-actions{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.audio-or{color:var(--text-subtle);font-size:12px}.audio-btn-record{background:var(--red-600);color:#fff;border-radius:var(--radius-md);font-family:var(--font-sans);cursor:pointer;transition:all var(--transition-fast);box-shadow:var(--shadow-sm);border:none;align-items:center;gap:8px;padding:10px 20px;font-size:13.5px;font-weight:600;display:inline-flex}.audio-btn-record:hover{box-shadow:var(--shadow-md);background:#b91c1c;transform:translateY(-1px)}.audio-btn-upload{background:var(--surface);border:1.5px solid var(--border-strong);color:var(--text-secondary);border-radius:var(--radius-md);font-family:var(--font-sans);cursor:pointer;transition:all var(--transition-fast);align-items:center;gap:8px;padding:10px 20px;font-size:13.5px;font-weight:500;display:inline-flex}.audio-btn-upload:hover{border-color:var(--green-400);color:var(--green-700);background:var(--green-50)}.dark .audio-btn-upload:hover{color:var(--green-400);background:#40916c1a}.audio-recording-state{flex-direction:column;align-items:center;gap:16px;padding:12px 0;display:flex}.audio-wave{align-items:center;gap:4px;height:40px;display:flex}.audio-wave-bar{background:var(--red-600);border-radius:2px;width:4px;animation:.8s infinite alternate wave-bar}.audio-wave-bar:first-child{height:20px}.audio-wave-bar:nth-child(2){height:32px}.audio-wave-bar:nth-child(3){height:40px}.audio-wave-bar:nth-child(4){height:28px}.audio-wave-bar:nth-child(5){height:16px}@keyframes wave-bar{0%{opacity:.6;transform:scaleY(.4)}to{opacity:1;transform:scaleY(1)}}.audio-timer{font-family:var(--font-mono);color:var(--text);letter-spacing:2px;font-size:28px;font-weight:700}.audio-timer-max{color:var(--text-subtle);letter-spacing:0;font-size:13px;font-weight:400}.audio-btn-stop{background:var(--bg-subtle);border:1.5px solid var(--border-strong);color:var(--text-secondary);border-radius:var(--radius-md);font-family:var(--font-sans);cursor:pointer;transition:all var(--transition-fast);align-items:center;gap:8px;padding:10px 24px;font-size:13.5px;font-weight:600;display:inline-flex}.audio-btn-stop:hover{border-color:var(--red-600);color:var(--red-600)}.audio-preview-state{flex-direction:column;gap:12px;display:flex}.audio-player{border-radius:var(--radius-md);width:100%;accent-color:var(--green-600)}.audio-file-name{color:var(--text-subtle);font-size:12px;font-family:var(--font-mono)}.audio-preview-actions{flex-wrap:wrap;gap:10px;display:flex}.audio-btn-reset{border:1.5px solid var(--border-strong);color:var(--text-muted);border-radius:var(--radius-md);font-family:var(--font-sans);cursor:pointer;transition:all var(--transition-fast);background:0 0;padding:9px 16px;font-size:13px;font-weight:500}.audio-btn-reset:hover{border-color:var(--red-600);color:var(--red-600)}.audio-btn-transcribe{background:linear-gradient(135deg, var(--green-800), var(--green-600));color:#fff;border-radius:var(--radius-md);font-family:var(--font-sans);cursor:pointer;transition:all var(--transition-fast);box-shadow:var(--shadow-sm);border:none;align-items:center;gap:8px;padding:10px 22px;font-size:13.5px;font-weight:600;display:inline-flex}.audio-btn-transcribe:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.audio-transcribing-state{flex-direction:column;align-items:center;gap:12px;padding:20px 0;display:flex}.audio-transcribing-spinner{align-items:center;gap:8px;display:flex}.audio-transcribing-dot{background:var(--green-500);border-radius:50%;width:10px;height:10px;animation:1.2s infinite typing-dot}.audio-transcribing-label{color:var(--text);font-size:14px;font-weight:600}.audio-transcribing-sub{color:var(--text-muted);text-align:center;font-size:12px}.audio-done-state{flex-direction:column;gap:12px;display:flex}.audio-transcript-label{color:var(--text-subtle);letter-spacing:1.2px;text-transform:uppercase;font-size:11px;font-weight:700}.audio-transcript-preview{color:var(--text-secondary);background:var(--bg-subtle);border:1px solid var(--border);border-radius:var(--radius-md);max-height:140px;padding:12px 14px;font-size:13.5px;font-style:italic;line-height:1.7;overflow-y:auto}.audio-done-actions{flex-wrap:wrap;gap:10px;display:flex}.audio-btn-use{background:linear-gradient(135deg, var(--green-800), var(--green-600));color:#fff;border-radius:var(--radius-md);font-family:var(--font-sans);cursor:pointer;transition:all var(--transition-fast);box-shadow:var(--shadow-sm);border:none;align-items:center;gap:8px;padding:10px 22px;font-size:13.5px;font-weight:600;display:inline-flex}.audio-btn-use:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.audio-hint{color:var(--text-subtle);font-size:11.5px;line-height:1.5}.audio-error{color:var(--red-600);background:var(--red-100);border-radius:var(--radius-md);border:1px solid #dc262633;margin-top:4px;padding:10px 12px;font-size:12.5px}.dark .audio-error{background:#dc26261a}.history-source{font-size:11px;font-weight:600}.history-source.cloud{color:var(--green-700)}.history-source.local{color:var(--text-subtle)}.dark .history-source.cloud{color:var(--green-400)}@supports (padding:env(safe-area-inset-bottom)){.footer{padding-bottom:calc(16px + env(safe-area-inset-bottom))}.toast{bottom:calc(24px + env(safe-area-inset-bottom))}}.toast{z-index:9999;border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);border-left:4px solid #0000;align-items:center;gap:10px;max-width:360px;padding:14px 18px 14px 16px;font-size:13.5px;font-weight:500;animation:.32s cubic-bezier(.16,1,.3,1) forwards toast-slide;display:flex;position:fixed;bottom:24px;right:24px;overflow:hidden}.toast:after{content:"";transform-origin:0;background:#ffffff4d;height:3px;animation:3.5s linear forwards progress-bar;position:absolute;bottom:0;left:0;right:0}.toast-success{color:#fff;border-left-color:var(--green-500);background:#0d2818}.toast-error{color:#fff;border-left-color:var(--red-600);background:#450a0a}.toast-success:before{content:"✓";color:var(--green-400);flex-shrink:0;font-size:16px;font-weight:800}.toast-error:before{content:"✕";color:#fca5a5;flex-shrink:0;font-size:16px;font-weight:800}.generation-progress{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius-xl);margin-top:24px;padding:24px 28px;animation:.3s forwards fade-in}.generation-progress-header{align-items:center;gap:12px;margin-bottom:20px;display:flex}.generation-progress-pulse{background:var(--green-500);border-radius:50%;flex-shrink:0;width:10px;height:10px;animation:1.2s infinite pulse-ring}.generation-progress-title{color:var(--text);font-size:14px;font-weight:700}.generation-progress-subtitle{color:var(--text-muted);font-size:12px;font-family:var(--font-mono);margin-left:auto}.generation-stages{flex-direction:column;gap:12px;display:flex}.generation-stage{align-items:center;gap:12px;display:flex}.generation-stage-icon{width:28px;height:28px;transition:all var(--transition-base);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:12px;display:flex}.generation-stage-icon.waiting{background:var(--bg-subtle);border:1.5px solid var(--border);color:var(--text-subtle)}.generation-stage-icon.active{background:var(--green-50);border:1.5px solid var(--green-400);color:var(--green-700);animation:1s linear infinite spin}.generation-stage-icon.done{background:var(--green-100);border:1.5px solid var(--green-500);color:var(--green-700)}.dark .generation-stage-icon.done{color:var(--green-400);background:#40916c33}.dark .generation-stage-icon.active{border-color:var(--green-500);color:var(--green-400);background:#40916c1f}.generation-stage-label{color:var(--text-muted);transition:color var(--transition-fast);font-size:13px}.generation-stage-label.active{color:var(--text);font-weight:600}.generation-stage-label.done{color:var(--green-700)}.dark .generation-stage-label.done{color:var(--green-400)}.generation-bar-track{background:var(--bg-subtle);border-radius:2px;height:4px;margin-top:20px;overflow:hidden}.generation-bar-fill{background:linear-gradient(90deg, var(--green-600), var(--green-400));border-radius:2px;height:100%;transition:width .6s cubic-bezier(.16,1,.3,1)}.history-empty{text-align:center;flex-direction:column;align-items:center;gap:8px;padding:48px 24px;display:flex}.history-empty-illustration{margin-bottom:8px}.history-empty-icon{margin-bottom:8px;font-size:48px}.history-empty-text{color:var(--text);font-size:16px;font-weight:700}.history-empty-hint{color:var(--text-muted);max-width:300px;font-size:13.5px;line-height:1.6}.history-empty-cta{background:var(--green-50);border:1.5px solid var(--green-200);color:var(--green-800);border-radius:var(--radius-md);cursor:pointer;font-size:13px;font-weight:600;font-family:var(--font-sans);transition:all var(--transition-fast);margin-top:16px;padding:10px 20px}.history-empty-cta:hover{background:var(--green-100)}.dark .history-empty-cta{color:var(--green-400);background:#40916c1a;border-color:#40916c40}.pwa-prompt{z-index:9998;background:var(--green-900);color:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);border:1px solid #ffffff1a;align-items:center;gap:14px;width:calc(100% - 32px);max-width:420px;padding:16px 20px;animation:.4s cubic-bezier(.16,1,.3,1) forwards slide-up;display:flex;position:fixed;bottom:24px;left:50%;transform:translate(-50%)}.pwa-prompt-mark{background:linear-gradient(135deg, var(--green-600), var(--green-400));color:#fff;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:13px;font-weight:800;display:flex}.pwa-prompt-content{flex:1;min-width:0}.pwa-prompt-title{color:#fff;margin-bottom:2px;font-size:14px;font-weight:700}.pwa-prompt-desc{color:var(--green-200);font-size:12px;line-height:1.4}.pwa-prompt-actions{flex-direction:column;flex-shrink:0;gap:6px;display:flex}.pwa-prompt-install{color:var(--green-900);border-radius:var(--radius-md);cursor:pointer;font-size:13px;font-weight:700;font-family:var(--font-sans);transition:all var(--transition-fast);white-space:nowrap;background:#fff;border:none;padding:8px 16px}.pwa-prompt-install:hover{background:var(--green-50)}.pwa-prompt-dismiss{color:#ffffff80;cursor:pointer;font-size:12px;font-family:var(--font-sans);text-align:center;transition:color var(--transition-fast);background:0 0;border:none;padding:6px}.pwa-prompt-dismiss:hover{color:#fff}.notfound-page{background:var(--bg);min-height:100vh;font-family:var(--font-sans);justify-content:center;align-items:center;padding:40px 24px;display:flex}.notfound-inner{text-align:center;max-width:440px;animation:.4s forwards slide-up}.notfound-mark{background:linear-gradient(135deg, var(--green-800), var(--green-600));color:#fff;letter-spacing:.5px;width:64px;height:64px;box-shadow:var(--shadow-lg);border-radius:16px;justify-content:center;align-items:center;margin:0 auto 20px;font-size:18px;font-weight:800;display:flex}.notfound-code{color:var(--green-100);font-size:96px;font-weight:800;font-family:var(--font-serif);letter-spacing:-4px;margin-bottom:8px;line-height:1}.dark .notfound-code{color:#40916c26}.notfound-title{color:var(--text);letter-spacing:-.3px;margin-bottom:12px;font-size:24px;font-weight:700}.notfound-desc{color:var(--text-muted);margin-bottom:28px;font-size:15px;line-height:1.7}.notfound-actions{flex-wrap:wrap;justify-content:center;gap:10px;margin-bottom:24px;display:flex}.notfound-hint{color:var(--text-subtle);font-size:12px}.notfound-hint a{color:var(--green-700);font-weight:600;text-decoration:none}.dark .notfound-hint a{color:var(--green-400)}.notfound-hint a:hover{text-decoration:underline}.sidebar.collapsed .sidebar-user{justify-content:center;padding:8px}.sidebar.collapsed .sidebar-user-dropdown{z-index:200;width:220px;position:fixed;bottom:12px;left:72px;right:auto}.sidebar.collapsed .sidebar-user-info,.sidebar.collapsed .sidebar-user-chevron{display:none}.admin{background:var(--bg);min-height:100vh;font-family:var(--font-sans)}.admin-layout{min-height:100vh;display:flex}.admin-main{flex-direction:column;flex:1;min-width:0;display:flex}.admin-header{border-bottom:1px solid var(--border);background:var(--surface);z-index:40;flex-shrink:0;justify-content:space-between;align-items:center;height:56px;padding:0 28px;display:flex;position:sticky;top:0}.admin-header-left{align-items:center;gap:12px;display:flex}.admin-header-title{color:var(--text);font-size:15px;font-weight:700}.admin-header-badge{background:var(--red-100);color:var(--red-600);border-radius:var(--radius-full);letter-spacing:1px;text-transform:uppercase;padding:3px 8px;font-size:10px;font-weight:800}.dark .admin-header-badge{color:#fca5a5;background:#dc262626}.admin-header-right{align-items:center;gap:10px;display:flex}.admin-refresh-btn{background:var(--surface);border:1.5px solid var(--border);color:var(--text-secondary);border-radius:var(--radius-md);cursor:pointer;font-size:12.5px;font-weight:600;font-family:var(--font-sans);transition:all var(--transition-fast);align-items:center;gap:6px;padding:7px 14px;display:inline-flex}.admin-refresh-btn:hover{border-color:var(--green-400);color:var(--green-700)}.admin-refresh-btn.spinning{animation:1s linear infinite spin}.admin-content{flex:1;padding:28px;overflow-y:auto}.admin-stats-grid{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:28px;display:grid}.admin-stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);transition:all var(--transition-base);padding:20px 22px;animation:.35s both slide-up;position:relative;overflow:hidden}.admin-stat-card:before{content:"";height:3px;position:absolute;top:0;left:0;right:0}.admin-stat-card.green:before{background:linear-gradient(90deg, var(--green-600), var(--green-400))}.admin-stat-card.blue:before{background:linear-gradient(90deg,#2563eb,#60a5fa)}.admin-stat-card.gold:before{background:linear-gradient(90deg, var(--gold-600), var(--gold-400))}.admin-stat-card.red:before{background:linear-gradient(90deg,#dc2626,#f87171)}.admin-stat-card.purple:before{background:linear-gradient(90deg,#7c3aed,#a78bfa)}.admin-stat-card.teal:before{background:linear-gradient(90deg,#0d9488,#2dd4bf)}.admin-stat-card.orange:before{background:linear-gradient(90deg,#ea580c,#fb923c)}.admin-stat-card.pink:before{background:linear-gradient(90deg,#db2777,#f472b6)}.admin-stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.admin-stat-icon{margin-bottom:10px;font-size:22px}.admin-stat-value{color:var(--text);letter-spacing:-1px;font-size:28px;font-weight:800;font-family:var(--font-serif);margin-bottom:4px}.admin-stat-label{color:var(--text-muted);font-size:12px;font-weight:500}.admin-stat-sub{color:var(--text-subtle);margin-top:4px;font-size:11px}.admin-stat-change{border-radius:var(--radius-full);align-items:center;gap:3px;margin-top:6px;padding:2px 6px;font-size:11px;font-weight:600;display:inline-flex}.admin-stat-change.up{background:var(--green-50);color:var(--green-700)}.admin-stat-change.neutral{background:var(--bg-subtle);color:var(--text-muted)}.dark .admin-stat-change.up{color:var(--green-400);background:#40916c26}.admin-grid{grid-template-columns:1fr 1fr;gap:20px;margin-bottom:24px;display:grid}.admin-grid.full{grid-template-columns:1fr}.admin-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);animation:.4s both slide-up;overflow:hidden}.admin-section-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.admin-section-title{color:var(--text);font-size:13.5px;font-weight:700}.admin-section-sub{color:var(--text-muted);margin-top:2px;font-size:11.5px}.admin-section-badge{background:var(--bg-subtle);border:1px solid var(--border);color:var(--text-muted);border-radius:var(--radius-full);padding:3px 10px;font-size:11px;font-weight:700}.admin-table-wrap{overflow-x:auto}.admin-table{border-collapse:collapse;width:100%;font-size:13px}.admin-table th{text-align:left;color:var(--text-subtle);letter-spacing:1.2px;text-transform:uppercase;background:var(--bg-subtle);border-bottom:1px solid var(--border);padding:10px 16px;font-size:10px;font-weight:700}.admin-table td{border-bottom:1px solid var(--border);color:var(--text-secondary);vertical-align:middle;padding:12px 16px}.admin-table tr:last-child td{border-bottom:none}.admin-table tr:hover td{background:var(--surface-hover)}.admin-table .email{font-family:var(--font-mono);color:var(--text);font-size:12px}.admin-table .badge{border-radius:var(--radius-full);letter-spacing:.5px;align-items:center;gap:4px;padding:3px 8px;font-size:10.5px;font-weight:700;display:inline-flex}.admin-table .badge.pro{background:var(--gold-100);color:var(--gold-700)}.admin-table .badge.free{background:var(--green-50);color:var(--green-700);border:1px solid var(--green-200)}.dark .admin-table .badge.pro{color:var(--gold-400);background:#d4a84326}.dark .admin-table .badge.free{color:var(--green-400);background:#40916c1f}.admin-table .count{color:var(--text);font-weight:700;font-family:var(--font-mono)}.admin-table .date{color:var(--text-subtle);font-size:12px}.admin-table .action-badge{border-radius:var(--radius-full);padding:2px 8px;font-size:11px;font-weight:600}.admin-table .action-badge.report{background:var(--green-50);color:var(--green-700)}.admin-table .action-badge.audio{background:var(--blue-100);color:var(--blue-600)}.dark .admin-table .action-badge.report{color:var(--green-400);background:#40916c1f}.dark .admin-table .action-badge.audio{color:#60a5fa;background:#2563eb1f}.activity-list{padding:8px 0}.activity-item{border-bottom:1px solid var(--border);transition:background var(--transition-fast);align-items:flex-start;gap:12px;padding:10px 20px;display:flex}.activity-item:last-child{border-bottom:none}.activity-item:hover{background:var(--surface-hover)}.activity-icon{background:var(--bg-subtle);border:1px solid var(--border);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:14px;display:flex}.activity-content{flex:1;min-width:0}.activity-text{color:var(--text-secondary);font-size:13px;line-height:1.5}.activity-text strong{color:var(--text);font-weight:600}.activity-time{color:var(--text-subtle);margin-top:2px;font-size:11px}.admin-empty{text-align:center;color:var(--text-muted);padding:40px 20px;font-size:13.5px}.admin-empty-icon{margin-bottom:10px;font-size:36px}.admin-empty-text{color:var(--text);margin-bottom:4px;font-weight:600}.admin-empty-sub{color:var(--text-muted);font-size:12.5px}.revenue-breakdown{flex-direction:column;gap:12px;padding:16px 20px;display:flex}.revenue-row{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:10px 0;display:flex}.revenue-row:last-child{border-bottom:none}.revenue-label{color:var(--text-secondary);font-size:13px}.revenue-value{color:var(--text);font-size:15px;font-weight:700;font-family:var(--font-mono)}.revenue-value.highlight{color:var(--green-700);font-size:18px}.dark .revenue-value.highlight{color:var(--green-400)}.template-bars{flex-direction:column;gap:12px;padding:16px 20px;display:flex}.template-bar-item{flex-direction:column;gap:5px;display:flex}.template-bar-label{color:var(--text-secondary);justify-content:space-between;align-items:center;font-size:12.5px;display:flex}.template-bar-count{color:var(--text);font-weight:700;font-family:var(--font-mono);font-size:12px}.template-bar-track{background:var(--bg-subtle);border-radius:3px;height:6px;overflow:hidden}.template-bar-fill{background:linear-gradient(90deg, var(--green-700), var(--green-500));border-radius:3px;height:100%;transition:width .8s cubic-bezier(.16,1,.3,1)}.health-list{padding:8px 0}.health-item{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:12px 20px;display:flex}.health-item:last-child{border-bottom:none}.health-left{align-items:center;gap:10px;display:flex}.health-icon{flex-shrink:0;font-size:18px}.health-label{color:var(--text);font-size:13px;font-weight:600}.health-sub{color:var(--text-muted);margin-top:1px;font-size:11.5px}.health-status{border-radius:var(--radius-full);letter-spacing:.5px;padding:4px 10px;font-size:11px;font-weight:700}.health-status.ok{background:var(--green-50);color:var(--green-700);border:1px solid var(--green-200)}.health-status.warn{background:var(--amber-100);color:var(--amber-600)}.health-status.manual{background:var(--bg-subtle);color:var(--text-muted);border:1px solid var(--border)}.dark .health-status.ok{color:var(--green-400);background:#40916c1f;border-color:#40916c33}.admin-loading{flex-direction:column;justify-content:center;align-items:center;gap:16px;min-height:100vh;display:flex}.admin-loading-mark{background:linear-gradient(135deg, var(--green-800), var(--green-600));color:#fff;border-radius:var(--radius-lg);justify-content:center;align-items:center;width:48px;height:48px;font-size:16px;font-weight:800;display:flex}.admin-loading-text{color:var(--text-muted);font-size:14px}@media (width<=1100px){.admin-stats-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=768px){.admin-stats-grid{grid-template-columns:repeat(2,1fr)}.admin-grid{grid-template-columns:1fr}.admin-content{padding:16px}}@media (width<=480px){.admin-stats-grid{grid-template-columns:1fr}}
