.sp{max-width:720px;padding:var(--space-4) var(--space-4) var(--space-8);margin:0 auto}.sp__setup{gap:var(--space-6);flex-direction:column;display:flex}.sp__setup-header{text-align:center}.sp__title{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:var(--font-extrabold);color:var(--color-text);margin:0 0 var(--space-2);letter-spacing:-.02em}@media (min-width:640px){.sp__title{font-size:var(--text-3xl)}}.sp__subtitle{font-size:var(--text-sm);color:var(--color-text-muted);line-height:var(--leading-relaxed);margin:0}.sp__modes{gap:var(--space-3);grid-template-columns:1fr 1fr;display:grid}@media (max-width:560px){.sp__modes{grid-template-columns:1fr}}.sp__mode-card{gap:var(--space-3);padding:var(--space-5);border-radius:var(--radius-2xl);border:2px solid var(--color-border);background:var(--color-surface);cursor:pointer;text-align:left;transition:all var(--duration-normal) var(--ease-default);font-family:var(--font-body);flex-direction:column;display:flex}.sp__mode-card:hover{border-color:var(--color-primary);box-shadow:0 4px 20px #4ade8014}.sp__mode-card--active{border-color:var(--color-primary);background:linear-gradient(135deg,#4ade800f 0%,#3b82f60f 100%);box-shadow:0 4px 24px #4ade801f}.sp__mode-icon{border-radius:var(--radius-xl);width:48px;height:48px;color:var(--color-primary);background:linear-gradient(135deg,#4ade801f,#3b82f61f);justify-content:center;align-items:center;display:flex}.sp__mode-card--active .sp__mode-icon{color:#fff;background:linear-gradient(135deg,#4ade80 0%,#3b82f6 100%)}.sp__mode-info h3{font-size:var(--text-base);font-weight:var(--font-bold);color:var(--color-text);margin:0 0 2px}.sp__mode-info p{font-size:var(--text-xs);color:var(--color-text-muted);line-height:var(--leading-relaxed);margin:0}.sp__mode-features{gap:var(--space-2);flex-wrap:wrap;display:flex}.sp__mode-features span{border-radius:var(--radius-full);background:var(--color-surface-container-high);color:var(--color-text-muted);padding:2px 8px;font-size:10px}.sp__mode-warn{color:#f59e0b;border-radius:var(--radius-lg);background:#f59e0b14;padding:4px 8px;font-size:10px}.sp__options{gap:var(--space-4);padding:var(--space-4);background:var(--color-surface);border-radius:var(--radius-2xl);border:1px solid var(--color-border);flex-direction:column;display:flex}.sp__option{align-items:center;gap:var(--space-3);display:flex}.sp__option-label{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-text);min-width:70px}.sp__option-pills{flex-wrap:wrap;gap:6px;display:flex}.sp__pill{border-radius:var(--radius-full);border:1px solid var(--color-border);color:var(--color-text-muted);font-size:var(--text-xs);font-weight:var(--font-semibold);cursor:pointer;transition:all var(--duration-fast) var(--ease-default);font-family:var(--font-body);background:0 0;padding:5px 14px}.sp__pill:hover{border-color:var(--color-primary);color:var(--color-text)}.sp__pill--active{background:var(--color-primary);border-color:var(--color-primary);color:var(--color-bg)}.sp__start-btn{justify-content:center;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);border-radius:var(--radius-2xl);color:#fff;font-size:var(--text-base);font-weight:var(--font-bold);font-family:var(--font-body);cursor:pointer;transition:all var(--duration-fast) var(--ease-bounce);background:linear-gradient(135deg,#4ade80 0%,#22c55e 50%,#16a34a 100%);border:none;display:flex;box-shadow:0 4px 20px #4ade8040}.sp__start-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 30px #4ade8059}.sp__start-btn:disabled{opacity:.6;cursor:wait}.sp__practice{gap:var(--space-5);flex-direction:column;display:flex}.sp__progress{align-items:center;gap:var(--space-3);display:flex}.sp__progress-bar{background:var(--color-surface-container-high);border-radius:var(--radius-full);flex:1;height:6px;overflow:hidden}.sp__progress-fill{border-radius:var(--radius-full);background:linear-gradient(90deg,#4ade80 0%,#3b82f6 100%);height:100%;transition:width .3s}.sp__progress-text{font-size:var(--text-xs);font-weight:var(--font-bold);color:var(--color-text-muted);white-space:nowrap}.sp__mode-badge{border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--color-primary);background:linear-gradient(135deg,#4ade8014,#3b82f614);border:1px solid #4ade8026;align-items:center;gap:6px;width:fit-content;padding:4px 14px;display:inline-flex}.sp__dictation{gap:var(--space-5);flex-direction:column;display:flex}.sp__listen-area{align-items:center;gap:var(--space-3);padding:var(--space-6);background:var(--color-surface);border-radius:var(--radius-2xl);border:1px solid var(--color-border);flex-direction:column;display:flex}.sp__listen-btn{border-radius:var(--radius-full);border:3px solid var(--color-primary);width:80px;height:80px;color:var(--color-primary);cursor:pointer;transition:all var(--duration-fast) var(--ease-bounce);background:linear-gradient(135deg,#4ade801a,#3b82f61a);justify-content:center;align-items:center;display:flex}.sp__listen-btn:hover{transform:scale(1.08);box-shadow:0 8px 30px #4ade8033}.sp__listen-btn--playing{color:#fff;background:linear-gradient(135deg,#4ade80,#3b82f6);border-color:#0000;animation:1.5s ease-in-out infinite sp-pulse}@keyframes sp-pulse{0%,to{transform:scale(1);box-shadow:0 0 #4ade804d}50%{transform:scale(1.05);box-shadow:0 0 20px 8px #4ade8026}}.sp__listen-hint{font-size:var(--text-sm);color:var(--color-text-muted);margin:0}.sp__topic-badge{border-radius:var(--radius-full);background:var(--color-surface-container-high);color:var(--color-text-muted);padding:2px 10px;font-size:10px}.sp__input-area{gap:var(--space-2);flex-direction:column;display:flex}.sp__input{width:100%;padding:var(--space-3) var(--space-4);border:2px solid var(--color-border);border-radius:var(--radius-xl);background:var(--color-surface);color:var(--color-text);font-size:var(--text-base);font-family:var(--font-body);line-height:var(--leading-relaxed);resize:none;transition:border-color var(--duration-fast)}.sp__input:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 3px #4ade801a}.sp__input:disabled{opacity:.6;background:var(--color-surface-container-high)}.sp__check-btn{align-self:flex-end}.sp__pronunciation{gap:var(--space-5);flex-direction:column;display:flex}.sp__read-area{padding:var(--space-5);background:var(--color-surface);border-radius:var(--radius-2xl);border:1px solid var(--color-border);text-align:center}.sp__read-text{font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--color-text);margin:0 0 var(--space-3);letter-spacing:.02em;line-height:1.6}@media (min-width:640px){.sp__read-text{font-size:var(--text-2xl)}}.sp__read-meta{justify-content:center;align-items:center;gap:var(--space-3);display:flex}.sp__read-translation{font-size:var(--text-sm);color:var(--color-text-muted);font-style:italic}.sp__mic-area{align-items:center;gap:var(--space-3);flex-direction:column;display:flex}.sp__mic-btn{align-items:center;gap:var(--space-2);padding:var(--space-4) var(--space-6);border-radius:var(--radius-2xl);border:2px solid var(--color-primary);color:var(--color-primary);font-size:var(--text-sm);font-weight:var(--font-bold);font-family:var(--font-body);cursor:pointer;transition:all var(--duration-fast) var(--ease-bounce);background:linear-gradient(135deg,#4ade8014,#3b82f614);flex-direction:column;display:flex}.sp__mic-btn:hover{transform:scale(1.03);box-shadow:0 4px 20px #4ade8026}.sp__mic-btn--recording{color:#fff;background:linear-gradient(135deg,#ef4444 0%,#f97316 100%);border-color:#0000;animation:1s ease-in-out infinite sp-pulse}.sp__mic-active{align-items:center;gap:var(--space-3);flex-direction:column;display:flex;position:relative}.sp__mic-pulse{border-radius:var(--radius-full);pointer-events:none;border:2px solid #ef444433;width:120px;height:120px;animation:1.5s ease-out infinite sp-mic-ring;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}@keyframes sp-mic-ring{0%{opacity:1;transform:translate(-50%,-50%)scale(.8)}to{opacity:0;transform:translate(-50%,-50%)scale(1.6)}}.sp__mic-transcript{font-size:var(--text-sm);color:var(--color-text-muted);padding:var(--space-2) var(--space-3);background:var(--color-surface);border-radius:var(--radius-lg);border:1px solid var(--color-border);word-break:break-word;align-items:center;gap:6px;max-width:100%;margin:0;display:flex}.sp__result{gap:var(--space-4);padding:var(--space-5);background:var(--color-surface);border-radius:var(--radius-2xl);border:1px solid var(--color-border);flex-direction:column;animation:.3s ease-out sp-result-in;display:flex}@keyframes sp-result-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.sp__result-score{justify-content:center;align-items:center;gap:var(--space-4);display:flex}.sp__result-score-circle{border-radius:var(--radius-full);background:var(--color-bg);border:4px solid;flex-shrink:0;justify-content:center;align-items:baseline;width:72px;height:72px;display:flex}.sp__result-score-num{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:var(--font-extrabold);color:var(--color-text)}.sp__result-score-pct{font-size:var(--text-sm);font-weight:var(--font-bold);color:var(--color-text-muted)}.sp__result-score-info{flex-direction:column;align-items:center;gap:2px;display:flex}.sp__result-score-emoji{font-size:var(--text-2xl)}.sp__result-diff{padding:var(--space-3);background:var(--color-bg);border-radius:var(--radius-xl)}.sp__diff-label{font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--color-text-muted);margin-bottom:var(--space-2);text-transform:uppercase;letter-spacing:.05em}.sp__diff-words{flex-wrap:wrap;gap:4px;line-height:1.8;display:flex}.sp__diff-word{font-size:var(--text-sm);border-radius:4px;padding:2px 6px;transition:background .15s}.sp__diff-word--correct{color:#16a34a;font-weight:var(--font-semibold);background:#22c55e1f}.sp__diff-word--wrong{background:#ef44441a}.sp__diff-word--wrong s{color:#ef4444;opacity:.6;text-decoration:line-through}.sp__diff-actual{color:#f97316;font-weight:var(--font-bold);margin-left:2px}.sp__diff-missing{color:#ef4444;font-weight:var(--font-semibold);-webkit-text-decoration:underline wavy;text-decoration:underline wavy}.sp__diff-extra{color:#8b5cf6;opacity:.7;font-style:italic}.sp__result-answer{padding:var(--space-3);border-radius:var(--radius-xl);background:linear-gradient(135deg,#4ade800a,#3b82f60a);border:1px solid #4ade801a}.sp__result-correct-text{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--color-text);margin:0 0 var(--space-1)}.sp__result-translation{font-size:var(--text-xs);color:var(--color-text-muted);margin:0;font-style:italic}.sp__result-actions{gap:var(--space-2);justify-content:flex-end;display:flex}.sp__btn{padding:var(--space-2) var(--space-4);border-radius:var(--radius-xl);font-size:var(--text-sm);font-weight:var(--font-bold);font-family:var(--font-body);cursor:pointer;transition:all var(--duration-fast) var(--ease-default);border:none;align-items:center;gap:6px;display:inline-flex}.sp__btn--primary{color:#fff;background:linear-gradient(135deg,#4ade80 0%,#22c55e 100%);box-shadow:0 2px 10px #4ade8033}.sp__btn--primary:hover{transform:translateY(-1px);box-shadow:0 4px 16px #4ade804d}.sp__btn--outline{border:1px solid var(--color-border);color:var(--color-text-muted);background:0 0}.sp__btn--outline:hover{border-color:var(--color-text);color:var(--color-text)}.sp__btn:disabled{opacity:.5;cursor:not-allowed}.sp__summary{gap:var(--space-5);padding:var(--space-5);background:var(--color-surface);border-radius:var(--radius-2xl);border:1px solid var(--color-border);flex-direction:column;display:flex}.sp__summary-header{text-align:center}.sp__summary-emoji{margin-bottom:var(--space-2);font-size:3rem;line-height:1}.sp__summary-title{font-family:var(--font-display);font-size:var(--text-xl);font-weight:var(--font-extrabold);color:var(--color-text);margin:0 0 var(--space-1)}.sp__summary-score{font-family:var(--font-display);font-size:var(--text-4xl,2.25rem);font-weight:var(--font-extrabold);line-height:1}.sp__summary-sub{font-size:var(--text-sm);color:var(--color-text-muted);margin:var(--space-1) 0 0}.sp__summary-stats{gap:var(--space-4);justify-content:center;display:flex}.sp__summary-stat{font-size:var(--text-sm);color:var(--color-text-muted);font-weight:var(--font-medium);align-items:center;gap:6px;display:flex}.sp__summary-list{flex-direction:column;gap:2px;max-height:300px;display:flex;overflow-y:auto}.sp__summary-item{gap:var(--space-2);padding:var(--space-2) var(--space-3);border-radius:var(--radius-lg);grid-template-columns:24px 1fr auto;align-items:center;display:grid}.sp__summary-item:nth-child(odd){background:var(--color-bg)}.sp__summary-item-idx{font-size:var(--text-xs);font-weight:var(--font-bold);color:var(--color-text-muted);text-align:center}.sp__summary-item-text{font-size:var(--text-sm);color:var(--color-text);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.sp__summary-item-score{font-size:var(--text-sm);font-weight:var(--font-bold);text-align:right;min-width:40px}.sp__summary-actions{gap:var(--space-2);justify-content:center;display:flex}
.tools{max-width:800px;padding:var(--space-4) var(--space-4) var(--space-8);margin:0 auto}.tools__header{text-align:center;margin-bottom:var(--space-5)}.tools__title{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:var(--font-extrabold);color:var(--color-text);margin:0 0 var(--space-1);letter-spacing:-.02em}@media (min-width:640px){.tools__title{font-size:var(--text-3xl)}}.tools__subtitle{font-size:var(--text-sm);color:var(--color-text-muted);margin:0}.tools__tabs{background:var(--color-surface-container-high);border-radius:var(--radius-2xl);margin-bottom:var(--space-5);grid-template-columns:repeat(3,1fr);gap:6px;padding:4px;display:grid}.tools__tab{padding:var(--space-3) var(--space-2);border-radius:var(--radius-xl);color:var(--color-text-muted);font-family:var(--font-body);cursor:pointer;transition:all var(--duration-fast) var(--ease-default);background:0 0;border:none;flex-direction:column;align-items:center;gap:2px;display:flex}.tools__tab:hover{color:var(--color-text);background:var(--color-surface)}.tools__tab--active{background:var(--color-surface);color:var(--color-primary);box-shadow:0 2px 8px #0000000f}.tools__tab-label{font-size:var(--text-sm);font-weight:var(--font-bold)}.tools__tab-desc{opacity:.7;font-size:10px;display:none}@media (min-width:480px){.tools__tab-desc{display:block}}.tool-ocr__drop,.tool-pdf__drop{border:2px dashed var(--color-border);border-radius:var(--radius-2xl);background:var(--color-surface);cursor:pointer;min-height:200px;transition:all var(--duration-fast);padding:var(--space-4);justify-content:center;align-items:center;display:flex}.tool-ocr__drop:hover,.tool-pdf__drop:hover{border-color:var(--color-primary);background:linear-gradient(135deg,#4ade800a,#3b82f60a)}.tool-ocr__drop--loading,.tool-pdf__drop--loading{pointer-events:none;opacity:.8}.tool-ocr__input-hidden,.tool-pdf__input-hidden{display:none}.tool-ocr__placeholder,.tool-pdf__placeholder{align-items:center;gap:var(--space-2);color:var(--color-text-muted);flex-direction:column;display:flex}.tool-ocr__drop-title,.tool-pdf__drop-title{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--color-text);margin:0}.tool-ocr__drop-hint,.tool-pdf__drop-hint{font-size:var(--text-xs);margin:0}.tool-ocr__loading,.tool-pdf__loading{align-items:center;gap:var(--space-2);color:var(--color-primary);flex-direction:column;display:flex}.tool-ocr__loading p,.tool-pdf__loading p{font-size:var(--text-sm);margin:0}.tool-ocr{gap:var(--space-4);flex-direction:column;display:flex}.tool-ocr__preview{align-items:center;gap:var(--space-2);flex-direction:column;display:flex}.tool-ocr__image{border-radius:var(--radius-xl);object-fit:contain;max-width:100%;max-height:250px}.tool-ocr__change{font-size:var(--text-xs);color:var(--color-text-muted);margin:0}.tool-ocr__error,.tool-pdf__error,.tool-writing__error{padding:var(--space-3);border-radius:var(--radius-lg);color:#ef4444;font-size:var(--text-sm);font-weight:var(--font-medium);background:#ef444414}.tool-ocr__result{gap:var(--space-4);padding:var(--space-4);background:var(--color-surface);border-radius:var(--radius-2xl);border:1px solid var(--color-border);flex-direction:column;animation:.3s ease-out tools-fade-in;display:flex}@keyframes tools-fade-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.tool-ocr__result-header{justify-content:space-between;align-items:center;gap:var(--space-2);flex-wrap:wrap;display:flex}.tool-ocr__result-header h3{font-size:var(--text-base);font-weight:var(--font-bold);margin:0}.tool-ocr__result-actions{align-items:center;gap:var(--space-2);display:flex}.tool-ocr__confidence{border-radius:var(--radius-full);padding:2px 8px;font-size:10px}.tool-ocr__confidence--high{color:#16a34a;background:#22c55e1a}.tool-ocr__confidence--medium{color:#f59e0b;background:#f59e0b1a}.tool-ocr__confidence--low{color:#ef4444;background:#ef44441a}.tool-ocr__copy-btn{border-radius:var(--radius-lg);border:1px solid var(--color-border);color:var(--color-text-muted);font-size:var(--text-xs);font-family:var(--font-body);cursor:pointer;transition:all var(--duration-fast);background:0 0;align-items:center;gap:4px;padding:4px 10px;display:inline-flex}.tool-ocr__copy-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.tool-ocr__text-box{padding:var(--space-3);background:var(--color-bg);border-radius:var(--radius-xl)}.tool-ocr__text{font-size:var(--text-sm);line-height:var(--leading-relaxed);color:var(--color-text);white-space:pre-wrap;word-break:break-word;font-family:var(--font-body);margin:0}.tool-ocr__speak{margin-top:var(--space-2);font-size:var(--text-xs);color:var(--color-text-muted);align-items:center;gap:6px;display:flex}.tool-ocr__words{gap:var(--space-2);flex-direction:column;display:flex}.tool-ocr__words h4{font-size:var(--text-sm);font-weight:var(--font-semibold);margin:0}.tool-ocr__word-list{flex-wrap:wrap;gap:4px;display:flex}.tool-ocr__word{border-radius:var(--radius-full);font-size:var(--text-xs);color:var(--color-text);cursor:pointer;transition:all var(--duration-fast);background:linear-gradient(135deg,#4ade8014,#3b82f614);border:1px solid #4ade8026;padding:2px 10px}.tool-ocr__word:hover{border-color:var(--color-primary);background:#4ade8026}.tool-pdf{gap:var(--space-4);flex-direction:column;display:flex}.tool-pdf__reader{gap:var(--space-3);flex-direction:column;animation:.3s ease-out tools-fade-in;display:flex}.tool-pdf__reader-header{padding:var(--space-3);background:var(--color-surface);border-radius:var(--radius-xl);border:1px solid var(--color-border);justify-content:space-between;align-items:center;gap:var(--space-2);flex-wrap:wrap;display:flex}.tool-pdf__file-info{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-text);align-items:center;gap:6px;display:flex}.tool-pdf__file-name{text-overflow:ellipsis;white-space:nowrap;max-width:200px;overflow:hidden}.tool-pdf__nav{align-items:center;gap:var(--space-2);display:flex}.tool-pdf__nav-btn{border-radius:var(--radius-lg);border:1px solid var(--color-border);width:28px;height:28px;color:var(--color-text);cursor:pointer;transition:all var(--duration-fast);background:0 0;justify-content:center;align-items:center;display:flex}.tool-pdf__nav-btn:hover:not(:disabled){border-color:var(--color-primary);color:var(--color-primary)}.tool-pdf__nav-btn:disabled{opacity:.3;cursor:not-allowed}.tool-pdf__page-num{font-size:var(--text-xs);font-weight:var(--font-bold);color:var(--color-text-muted);text-align:center;min-width:50px}.tool-pdf__new-btn{border-radius:var(--radius-lg);border:1px solid var(--color-border);color:var(--color-text-muted);font-size:var(--text-xs);font-family:var(--font-body);cursor:pointer;transition:all var(--duration-fast);background:0 0;padding:4px 12px}.tool-pdf__new-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.tool-pdf__content{padding:var(--space-5);background:var(--color-surface);border-radius:var(--radius-2xl);border:1px solid var(--color-border);max-height:500px;overflow-y:auto}.tool-pdf__text-body{font-size:var(--text-sm);color:var(--color-text);line-height:2}.pdf-word{cursor:pointer;border-radius:3px;padding:1px 2px;transition:all .15s}.pdf-word:hover{color:var(--color-primary);background:#4ade8026}.pdf-word--active{outline:2px solid var(--color-primary);outline-offset:1px;background:#4ade8033}.tool-pdf__word-popup{padding:var(--space-3);background:var(--color-surface);border-radius:var(--radius-xl);border:1px solid var(--color-primary);align-items:center;gap:var(--space-3);animation:.2s ease-out tools-fade-in;display:flex;position:sticky;bottom:0;box-shadow:0 -4px 20px #00000014}.tool-pdf__word-popup-header{align-items:center;gap:var(--space-2);font-size:var(--text-base);display:flex}.tool-pdf__word-hint{font-size:var(--text-xs);color:var(--color-text-muted);flex:1;margin:0}.tool-pdf__word-close{border-radius:var(--radius-lg);color:var(--color-text-muted);cursor:pointer;font-size:var(--text-sm);background:0 0;border:none;padding:4px 8px}.tool-pdf__tts-bar{font-size:var(--text-xs);color:var(--color-text-muted);padding:var(--space-2) var(--space-3);background:var(--color-surface);border-radius:var(--radius-lg);align-items:center;gap:6px;width:fit-content;display:flex}.tool-writing{gap:var(--space-4);flex-direction:column;display:flex}.tool-writing__prompt-bar{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border-radius:var(--radius-xl);font-size:var(--text-sm);color:var(--color-text-muted);background:linear-gradient(135deg,#4ade800f,#3b82f60f);border:1px solid #4ade801f;display:flex}.tool-writing__prompt-bar span{flex:1;font-style:italic}.tool-writing__prompt-refresh{border-radius:var(--radius-lg);color:var(--color-text-muted);cursor:pointer;transition:transform var(--duration-fast);background:0 0;border:none;padding:4px}.tool-writing__prompt-refresh:hover{color:var(--color-primary);transform:rotate(-180deg)}.tool-writing__input-area{gap:var(--space-2);flex-direction:column;display:flex}.tool-writing__textarea{width:100%;padding:var(--space-4);border:2px solid var(--color-border);border-radius:var(--radius-xl);background:var(--color-surface);color:var(--color-text);font-size:var(--text-base);font-family:var(--font-body);line-height:var(--leading-relaxed);resize:vertical;min-height:120px;transition:border-color var(--duration-fast)}.tool-writing__textarea:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 3px #4ade8014}.tool-writing__textarea:disabled{opacity:.6}.tool-writing__input-footer{justify-content:space-between;align-items:center;display:flex}.tool-writing__char-count{font-size:var(--text-xs);color:var(--color-text-muted)}.tool-writing__input-actions{gap:var(--space-2);display:flex}.tool-writing__btn{padding:var(--space-2) var(--space-4);border-radius:var(--radius-xl);font-size:var(--text-sm);font-weight:var(--font-bold);font-family:var(--font-body);cursor:pointer;transition:all var(--duration-fast) var(--ease-default);border:none;align-items:center;gap:6px;display:inline-flex}.tool-writing__btn--primary{color:#fff;background:linear-gradient(135deg,#4ade80 0%,#22c55e 100%);box-shadow:0 2px 10px #4ade8033}.tool-writing__btn--primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 16px #4ade804d}.tool-writing__btn--primary:disabled{opacity:.5;cursor:not-allowed}.tool-writing__btn--outline{border:1px solid var(--color-border);color:var(--color-text-muted);background:0 0}.tool-writing__btn--outline:hover{border-color:var(--color-text);color:var(--color-text)}.tool-writing__result{gap:var(--space-4);padding:var(--space-5);background:var(--color-surface);border-radius:var(--radius-2xl);border:1px solid var(--color-border);flex-direction:column;animation:.3s ease-out tools-fade-in;display:flex}.tool-writing__score-bar{align-items:center;gap:var(--space-3);display:flex}.tool-writing__score-circle{border-radius:var(--radius-full);border:4px solid;flex-shrink:0;justify-content:center;align-items:center;width:56px;height:56px;display:flex}.tool-writing__score-num{font-family:var(--font-display);font-size:var(--text-xl);font-weight:var(--font-extrabold);color:var(--color-text)}.tool-writing__score-info{flex-direction:column;gap:2px;display:flex}.tool-writing__score-label{font-weight:var(--font-bold);font-size:var(--text-base)}.tool-writing__score-level{font-size:var(--text-xs);color:var(--color-text-muted)}.tool-writing__perfect{color:#22c55e;font-size:var(--text-sm);font-weight:var(--font-bold);align-items:center;gap:6px;margin-left:auto;display:flex}.tool-writing__corrected{padding:var(--space-3);border-radius:var(--radius-xl);background:#22c55e0d;border:1px solid #22c55e1f}.tool-writing__corrected h4{font-size:var(--text-sm);margin:0 0 var(--space-2)}.tool-writing__corrected-text{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--color-text);margin:0 0 var(--space-2);line-height:var(--leading-relaxed)}.tool-writing__errors h4{font-size:var(--text-sm);margin:0 0 var(--space-2);align-items:center;gap:6px;display:flex}.tool-writing__error-list{gap:var(--space-3);flex-direction:column;display:flex}.tool-writing__error-item{padding:var(--space-3);background:var(--color-bg);border-radius:var(--radius-xl)}.tool-writing__error-header{align-items:center;gap:var(--space-2);margin-bottom:var(--space-2);flex-wrap:wrap;display:flex}.tool-writing__error-type{border-radius:var(--radius-full);font-size:10px;font-weight:var(--font-bold);border:1px solid;padding:2px 10px}.tool-writing__error-diff{font-size:var(--text-sm);align-items:center;gap:6px;display:flex}.tool-writing__error-wrong{color:#ef4444}.tool-writing__error-arrow{color:var(--color-text-muted)}.tool-writing__error-right{color:#22c55e}.tool-writing__error-explain{font-size:var(--text-sm);color:var(--color-text);line-height:var(--leading-relaxed);margin:0}.tool-writing__error-rule{font-size:var(--text-xs);color:var(--color-text-muted);margin:var(--space-1) 0 0;font-style:italic}.tool-writing__suggestions{padding:var(--space-3);border-radius:var(--radius-xl);background:#3b82f60a}.tool-writing__suggestions h4{font-size:var(--text-sm);margin:0 0 var(--space-2)}.tool-writing__suggestions ul{padding-left:var(--space-4);font-size:var(--text-sm);color:var(--color-text);line-height:var(--leading-relaxed);margin:0}.tool-writing__alternative{padding:var(--space-3);border-radius:var(--radius-xl);background:linear-gradient(135deg,#4ade800a,#8b5cf60a);border:1px solid #8b5cf61a}.tool-writing__alternative h4{font-size:var(--text-sm);margin:0 0 var(--space-2)}.tool-writing__alternative p{font-size:var(--text-base);font-weight:var(--font-medium);color:var(--color-text);margin:0 0 var(--space-2);line-height:var(--leading-relaxed)}
.landing{font-family:var(--font-sans);color:var(--color-text);background:var(--color-bg);overflow-x:hidden}.landing-nav{z-index:var(--z-raised);transition:all var(--duration-normal) var(--ease-default);padding:var(--space-4) 0;position:fixed;top:0;left:0;right:0}.landing-nav--scrolled{-webkit-backdrop-filter:blur(20px);box-shadow:var(--shadow-sm);padding:var(--space-3) 0;background:#ffffffd9}.dark .landing-nav--scrolled{background:#0f1512d9}.landing-nav__container{max-width:var(--container-2xl);padding:0 var(--space-8);align-items:center;gap:var(--space-8);margin:0 auto;display:flex}.landing-nav__logo{flex-shrink:0;align-items:baseline;gap:2px;text-decoration:none;display:flex}.landing-nav__logo-primary{font-family:var(--font-display);font-size:var(--text-xl);font-weight:var(--font-extrabold);color:#22c55e}.landing-nav__logo-secondary{font-family:var(--font-display);font-size:var(--text-xl);font-weight:var(--font-semibold);color:#ffffffb3}.landing-nav--scrolled .landing-nav__logo-secondary{color:var(--color-text-muted)}.landing-nav__links{align-items:center;gap:var(--space-6);flex:1;display:flex}.landing-nav__link{font-size:var(--text-sm);font-weight:var(--font-medium);color:#fffc;transition:color var(--duration-fast) var(--ease-default);text-decoration:none}.landing-nav--scrolled .landing-nav__link{color:var(--color-text-muted)}.landing-nav__link:hover{color:#fff}.landing-nav--scrolled .landing-nav__link:hover{color:var(--color-primary)}.landing-nav__actions{align-items:center;gap:var(--space-3);flex-shrink:0;display:flex}.landing-nav__btn-ghost{font-size:var(--text-sm);font-weight:var(--font-medium);color:#ffffffd9;padding:var(--space-2) var(--space-4);border-radius:var(--radius-lg);transition:all var(--duration-fast) var(--ease-default);text-decoration:none}.landing-nav--scrolled .landing-nav__btn-ghost{color:var(--color-text-muted)}.landing-nav__btn-ghost:hover{color:#fff;background:#ffffff26}.landing-nav--scrolled .landing-nav__btn-ghost:hover{background:var(--color-bg-muted);color:var(--color-text)}.landing-nav__btn-primary{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-primary-dark);padding:var(--space-2) var(--space-5);border-radius:var(--radius-full);transition:all var(--duration-fast) var(--ease-bounce);background:#fff;text-decoration:none;box-shadow:0 2px #0000001a}.landing-nav__btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 8px #00000026}.landing-hero{align-items:center;gap:var(--space-16);min-height:100vh;padding:calc(var(--header-height) + var(--space-16)) var(--space-16) var(--space-16);background:linear-gradient(135deg,#003d18 0%,#006a2c 50%,#004d20 100%);grid-template-columns:1fr 1fr;display:grid;position:relative;overflow:hidden}.landing-hero__words{pointer-events:none;z-index:0;position:absolute;inset:0}.landing-hero__word{color:#ffffff1f;font-family:var(--font-display);font-weight:var(--font-bold);white-space:nowrap;animation:heroWordFloat var(--duration,5s) ease-in-out infinite;-webkit-user-select:none;user-select:none;position:absolute}.landing-hero__blob{filter:blur(80px);pointer-events:none;z-index:0;border-radius:50%;animation:10s ease-in-out infinite morphBlob,4s ease-in-out infinite pulseSlow;position:absolute}.landing-hero__blob--1{background:#82ff991f;width:500px;height:500px;top:-100px;right:-100px}.landing-hero__blob--2{background:#ff955a14;width:350px;height:350px;animation-delay:3s;bottom:-80px;left:30%}.landing-hero__content{z-index:1;gap:var(--space-6);flex-direction:column;display:flex;position:relative}.landing-hero__badge{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:var(--radius-full);color:#ffffffe6;font-size:var(--text-sm);font-weight:var(--font-medium);background:#ffffff1f;border:1px solid #fff3;width:fit-content;display:inline-flex}.landing-hero__badge-flag{font-size:var(--text-base)}.landing-hero__title{font-family:var(--font-display);font-size:clamp(3rem,5vw,4.5rem);font-weight:var(--font-extrabold);color:#fff;letter-spacing:-.03em;line-height:1.1}.landing-hero__title-highlight{background:linear-gradient(135deg,#82ff99 0%,#4ade80 50%,#a3e635 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;display:inline-block}.landing-hero__sub{font-size:var(--text-lg);color:#ffffffbf;line-height:var(--leading-vi);max-width:520px}.landing-hero__ctas{align-items:center;gap:var(--space-4);flex-wrap:wrap;display:flex}.landing-btn-primary{align-items:center;gap:var(--space-2);padding:var(--space-4) var(--space-8);font-size:var(--text-base);font-weight:var(--font-bold);font-family:var(--font-display);color:var(--color-primary-dark);border-radius:var(--radius-full);cursor:pointer;transition:all var(--duration-fast) var(--ease-bounce);white-space:nowrap;background:#fff;border:none;text-decoration:none;display:inline-flex;box-shadow:0 4px #0003,0 0 32px #ffffff1a}.landing-btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 16px #0003}.landing-btn-primary:active{box-shadow:none;transform:translateY(2px)}.landing-btn-ghost{align-items:center;gap:var(--space-2);padding:var(--space-4) var(--space-6);font-size:var(--text-base);font-weight:var(--font-semibold);color:#ffffffd9;border-radius:var(--radius-full);transition:all var(--duration-fast) var(--ease-default);white-space:nowrap;border:2px solid #ffffff4d;text-decoration:none;display:inline-flex}.landing-btn-ghost:hover{color:#fff;background:#ffffff1a;border-color:#fff9}.landing-hero__social-proof{align-items:center;gap:var(--space-4);flex-wrap:wrap;display:flex}.landing-hero__stat{align-items:center;gap:var(--space-2);color:#ffffffbf;font-size:var(--text-sm);display:flex}.landing-hero__stat strong{color:#fff}.landing-hero__stat-icon{font-size:var(--text-base)}.landing-hero__stat-divider{background:#fff3;width:1px;height:16px}.landing-hero__mockup{z-index:1;justify-content:center;display:flex;position:relative}.landing-mockup{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:var(--radius-2xl);box-shadow:var(--shadow-float), 0 0 0 1px #ffffff1a;width:100%;max-width:420px;animation:fadeInRight var(--duration-slow) var(--ease-out) both;background:#fffffff2;animation-delay:.4s;overflow:hidden}.dark .landing-mockup{background:#1a2320f2}.landing-mockup__header{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--color-bg-muted);border-bottom:1px solid var(--color-border);display:flex}.landing-mockup__dots{gap:6px;display:flex}.landing-mockup__dots span{border-radius:50%;width:10px;height:10px}.landing-mockup__dots span:first-child{background:#ff5f57}.landing-mockup__dots span:nth-child(2){background:#febc2e}.landing-mockup__dots span:nth-child(3){background:#28c840}.landing-mockup__url{font-size:var(--text-xs);color:var(--color-text-muted);font-family:var(--font-mono);text-align:center;flex:1}.landing-mockup__body{padding:var(--space-5) var(--space-5);gap:var(--space-4);flex-direction:column;display:flex}.landing-mockup__greeting{font-family:var(--font-display);font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--color-text)}.landing-mockup__sub{font-size:var(--text-sm);color:var(--color-text-muted);margin-top:calc(var(--space-1) * -1)}.landing-mockup__stats{gap:var(--space-3);grid-template-columns:repeat(3,1fr);display:grid}.landing-mockup__stat{background:var(--color-bg-subtle);border-radius:var(--radius-xl);padding:var(--space-3);text-align:center;flex-direction:column;gap:2px;display:flex}.landing-mockup__stat--streak{background:var(--color-streak-bg)}.landing-mockup__stat-value{font-family:var(--font-display);font-size:var(--text-lg);font-weight:var(--font-extrabold);color:var(--color-primary)}.landing-mockup__stat--streak .landing-mockup__stat-value{color:var(--color-streak)}.landing-mockup__stat-label{color:var(--color-text-muted);font-size:10px}.landing-mockup__progress-label{font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--color-text-muted)}.landing-mockup__progress{background:var(--color-border);border-radius:var(--radius-full);height:8px;overflow:hidden}.landing-mockup__progress-fill{background:linear-gradient(90deg, var(--color-primary) 0%, #4ade80 100%);border-radius:var(--radius-full);height:100%;animation:slideInLeft var(--duration-slow) var(--ease-out) both;animation-delay:.8s}.landing-mockup__actions{gap:var(--space-2);display:flex}.landing-mockup__action{padding:var(--space-2) var(--space-3);background:var(--color-bg-subtle);border-radius:var(--radius-lg);font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--color-text-muted);text-align:center;border:1px solid var(--color-border);flex:1}.landing-mockup__action--primary{background:var(--color-primary-50);color:var(--color-primary);border-color:var(--color-primary-200);font-weight:var(--font-semibold)}.landing-section-container{max-width:var(--container-2xl);padding:0 var(--space-8);margin:0 auto}.landing-section-header{text-align:center;max-width:640px;margin:0 auto var(--space-16);gap:var(--space-4);flex-direction:column;display:flex}.landing-section-tag{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-primary);background:var(--color-primary-50);padding:var(--space-1) var(--space-4);border-radius:var(--radius-full);border:1px solid var(--color-primary-200);display:inline-block}.landing-section-title{font-family:var(--font-display);font-size:clamp(1.75rem,3vw,2.5rem);font-weight:var(--font-extrabold);color:var(--color-text);line-height:var(--leading-tight);letter-spacing:-.02em}.landing-section-sub{font-size:var(--text-lg);color:var(--color-text-muted);line-height:var(--leading-vi)}.landing-how{padding:var(--space-24) 0;background:var(--color-surface)}.landing-steps{gap:var(--space-8);grid-template-columns:repeat(3,1fr);align-items:flex-start;display:grid;position:relative}.landing-step{text-align:center;align-items:center;gap:var(--space-4);flex-direction:column;display:flex;position:relative}.landing-step__number{font-family:var(--font-display);font-size:var(--text-xs);font-weight:var(--font-bold);color:var(--color-primary);background:var(--color-primary-50);border:2px solid var(--color-primary-200);border-radius:var(--radius-full);justify-content:center;align-items:center;width:32px;height:32px;display:flex}.landing-step__icon{font-size:3rem;line-height:1}.landing-step__title{font-family:var(--font-display);font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--color-text)}.landing-step__desc{font-size:var(--text-base);color:var(--color-text-muted);line-height:var(--leading-vi)}.landing-step__arrow{font-size:var(--text-2xl);color:var(--color-primary-200);z-index:1;position:absolute;top:60px;right:-24px}.landing-features{padding:var(--space-24) 0;background:var(--color-bg)}.landing-features-grid{gap:var(--space-6);grid-template-columns:repeat(3,1fr);display:grid}.landing-feature-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-2xl);padding:var(--space-6);gap:var(--space-4);transition:all var(--duration-normal) var(--ease-default);flex-direction:column;display:flex}.landing-feature-card:hover{box-shadow:var(--shadow-lg);border-color:var(--color-primary-200);transform:translateY(-4px)}.landing-feature-card__icon{border-radius:var(--radius-xl);flex-shrink:0;justify-content:center;align-items:center;width:52px;height:52px;font-size:1.75rem;display:flex}.landing-feature-card__title{font-family:var(--font-display);font-size:var(--text-lg);font-weight:var(--font-bold);color:var(--color-text)}.landing-feature-card__desc{font-size:var(--text-sm);color:var(--color-text-muted);line-height:var(--leading-vi)}.landing-stats{padding:var(--space-16) 0;background:linear-gradient(135deg, var(--color-primary-dark) 0%, var(--color-primary) 100%)}.landing-stats-grid{gap:var(--space-8);grid-template-columns:repeat(4,1fr);display:grid}.landing-stat-card{align-items:center;gap:var(--space-3);text-align:center;flex-direction:column;display:flex}.landing-stat-card__icon{font-size:2.5rem}.landing-stat-card__value{font-family:var(--font-display);font-size:var(--text-4xl);font-weight:var(--font-extrabold);color:#fff;line-height:1}.landing-stat-card__label{font-size:var(--text-sm);color:#ffffffbf;font-weight:var(--font-medium)}.landing-testimonials{padding:var(--space-24) 0;background:var(--color-surface)}.landing-testimonials-grid{gap:var(--space-6);grid-template-columns:repeat(3,1fr);display:grid}.landing-testimonial-card{background:var(--color-bg);border:1px solid var(--color-border);border-left:4px solid var(--color-primary);border-radius:var(--radius-2xl);padding:var(--space-6);gap:var(--space-5);transition:all var(--duration-fast) var(--ease-default);flex-direction:column;display:flex}.landing-testimonial-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.landing-testimonial-card__quote{font-size:var(--text-base);color:var(--color-text);line-height:var(--leading-vi);font-style:italic}.landing-testimonial-card__author{align-items:center;gap:var(--space-3);display:flex}.landing-testimonial-card__avatar{border-radius:var(--radius-full);background:var(--color-primary-100);width:40px;height:40px;color:var(--color-primary);font-weight:var(--font-bold);font-size:var(--text-sm);flex-shrink:0;justify-content:center;align-items:center;display:flex}.landing-testimonial-card__name{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-text)}.landing-testimonial-card__role{font-size:var(--text-xs);color:var(--color-text-muted)}.landing-cta-banner{padding:var(--space-16) 0;background:linear-gradient(135deg,#003d18 0%,#006a2c 60%,#004d20 100%);position:relative;overflow:hidden}.landing-cta-banner__content{max-width:var(--container-2xl);padding:0 var(--space-8);text-align:center;gap:var(--space-6);z-index:1;flex-direction:column;align-items:center;margin:0 auto;display:flex;position:relative}.landing-cta-banner__title{font-family:var(--font-display);font-size:clamp(1.75rem,3vw,2.5rem);font-weight:var(--font-extrabold);color:#fff;line-height:var(--leading-tight)}.landing-cta-banner__sub{font-size:var(--text-base);color:#ffffffbf}.landing-cta-banner__actions{align-items:center;gap:var(--space-4);display:flex}.landing-cta-banner__btn{align-items:center;gap:var(--space-2);padding:var(--space-4) var(--space-10);font-size:var(--text-base);font-weight:var(--font-bold);font-family:var(--font-display);color:var(--color-primary-dark);border-radius:var(--radius-full);transition:all var(--duration-fast) var(--ease-bounce);background:#fff;text-decoration:none;display:inline-flex;box-shadow:0 4px #0003}.landing-cta-banner__btn:hover{transform:translateY(-2px);box-shadow:0 8px 16px #0003}.landing-cta-banner__btn-ghost{font-size:var(--text-sm);font-weight:var(--font-medium);color:#fffc;transition:color var(--duration-fast) var(--ease-default);text-decoration:none}.landing-cta-banner__btn-ghost:hover{color:#fff}.landing-cta-banner__deco{align-items:center;gap:var(--space-24);padding:0 var(--space-8);opacity:.05;font-family:var(--font-display);font-size:var(--text-6xl);font-weight:var(--font-extrabold);color:#fff;pointer-events:none;display:flex;position:absolute;inset:0;overflow:hidden}.landing-footer{padding:var(--space-16) 0 var(--space-8);background:#0a1e10}.landing-footer__container{max-width:var(--container-2xl);padding:0 var(--space-8);gap:var(--space-16);margin:0 auto;margin-bottom:var(--space-12);grid-template-columns:1fr 2fr;display:grid}.landing-footer__brand{gap:var(--space-3);flex-direction:column;display:flex}.landing-footer__logo{align-items:baseline;gap:2px;display:flex}.landing-footer__logo-primary{font-family:var(--font-display);font-size:var(--text-xl);font-weight:var(--font-extrabold);color:#4ade80}.landing-footer__logo-secondary{font-family:var(--font-display);font-size:var(--text-xl);font-weight:var(--font-semibold);color:#fff6}.landing-footer__tagline{font-size:var(--text-sm);color:#fff6;line-height:var(--leading-relaxed)}.landing-footer__links{gap:var(--space-8);grid-template-columns:repeat(3,1fr);display:grid}.landing-footer__col{gap:var(--space-3);flex-direction:column;display:flex}.landing-footer__col-title{font-size:var(--text-xs);font-weight:var(--font-bold);color:#fff6;text-transform:uppercase;letter-spacing:.1em}.landing-footer__link{font-size:var(--text-sm);color:#ffffff8c;transition:color var(--duration-fast) var(--ease-default);text-decoration:none}.landing-footer__link:hover{color:#4ade80}.landing-footer__bottom{max-width:var(--container-2xl);padding:var(--space-6) var(--space-8) 0;font-size:var(--text-sm);color:#ffffff4d;border-top:1px solid #ffffff14;margin:0 auto}.landing-nav__hamburger{cursor:pointer;width:36px;height:36px;z-index:calc(var(--z-raised) + 10);background:0 0;border:none;flex-direction:column;justify-content:center;gap:5px;margin-left:auto;padding:6px;display:none}.landing-nav__hamburger span{transform-origin:50%;background:#ffffffe6;border-radius:2px;width:100%;height:2px;transition:all .3s;display:block}.landing-nav--scrolled .landing-nav__hamburger span{background:var(--color-text)}.landing-nav__hamburger--open span:first-child{transform:translateY(7px)rotate(45deg)}.landing-nav__hamburger--open span:nth-child(2){opacity:0;transform:scaleX(0)}.landing-nav__hamburger--open span:nth-child(3){transform:translateY(-7px)rotate(-45deg)}.landing-mobile-menu{-webkit-backdrop-filter:blur(20px);z-index:calc(var(--z-raised) + 5);justify-content:center;align-items:center;gap:var(--space-10);padding:var(--space-16) var(--space-8);opacity:0;pointer-events:none;background:#001e10f7;flex-direction:column;transition:opacity .3s;display:none;position:fixed;inset:0}.landing-mobile-menu--open{opacity:1;pointer-events:auto}.landing-mobile-menu__links{gap:var(--space-6);flex-direction:column;align-items:center;display:flex}.landing-mobile-menu__link{align-items:center;gap:var(--space-3);font-family:var(--font-display);font-size:var(--text-2xl);font-weight:var(--font-bold);color:#ffffffe6;padding:var(--space-3) var(--space-6);border-radius:var(--radius-xl);text-decoration:none;transition:all .2s;display:flex}.landing-mobile-menu__link:hover{color:#4ade80;background:#ffffff1a}.landing-mobile-menu__link-icon{font-size:var(--text-xl)}.landing-mobile-menu__actions{gap:var(--space-4);flex-direction:column;width:100%;max-width:280px;display:flex}.landing-mobile-menu__btn-ghost{text-align:center;padding:var(--space-3) var(--space-6);font-size:var(--text-base);font-weight:var(--font-medium);color:#ffffffb3;border-radius:var(--radius-xl);border:1px solid #fff3;text-decoration:none;transition:all .2s;display:block}.landing-mobile-menu__btn-ghost:hover{color:#fff;background:#ffffff1a}.landing-mobile-menu__btn-primary{text-align:center;padding:var(--space-4) var(--space-6);font-size:var(--text-base);font-weight:var(--font-bold);color:var(--color-primary-dark);border-radius:var(--radius-xl);background:#fff;text-decoration:none;transition:all .2s;display:block;box-shadow:0 4px #00000026}.landing-mobile-menu__btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px 12px #0003}.landing-pricing{padding:var(--space-24) 0;background:var(--color-bg)}.landing-pricing-grid{gap:var(--space-6);grid-template-columns:repeat(3,1fr);align-items:start;display:grid}.landing-pricing-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-2xl);padding:var(--space-8);gap:var(--space-6);transition:all var(--duration-normal) var(--ease-default);flex-direction:column;display:flex;position:relative}.landing-pricing-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}.landing-pricing-card--featured{border-color:var(--color-primary);box-shadow:0 0 0 1px var(--color-primary), var(--shadow-lg);transform:scale(1.03)}.landing-pricing-card--featured:hover{transform:scale(1.03)translateY(-4px)}.landing-pricing-card__badge{padding:var(--space-1) var(--space-4);background:var(--color-primary);color:#fff;font-size:var(--text-xs);font-weight:var(--font-bold);border-radius:var(--radius-full);white-space:nowrap;position:absolute;top:-12px;left:50%;transform:translate(-50%)}.landing-pricing-card__header{gap:var(--space-2);flex-direction:column;display:flex}.landing-pricing-card__name{font-family:var(--font-display);font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--color-text)}.landing-pricing-card__price{align-items:baseline;gap:var(--space-1);display:flex}.landing-pricing-card__amount{font-family:var(--font-display);font-size:var(--text-3xl);font-weight:var(--font-extrabold);color:var(--color-primary)}.landing-pricing-card__period{font-size:var(--text-sm);color:var(--color-text-muted)}.landing-pricing-card__features{gap:var(--space-3);flex-direction:column;flex:1;margin:0;padding:0;list-style:none;display:flex}.landing-pricing-card__features li{font-size:var(--text-sm);color:var(--color-text-muted);line-height:var(--leading-vi)}.landing-pricing-card__btn{text-align:center;padding:var(--space-3) var(--space-6);font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-primary);background:var(--color-primary-50);border:1px solid var(--color-primary-200);border-radius:var(--radius-xl);transition:all var(--duration-fast) var(--ease-default);text-decoration:none;display:block}.landing-pricing-card__btn:hover{background:var(--color-primary-100)}.landing-pricing-card__btn--featured{color:#fff;background:var(--color-primary);border-color:var(--color-primary)}.landing-pricing-card__btn--featured:hover{background:var(--color-primary-dark)}@media (max-width:1024px){.landing-nav__hamburger,.landing-mobile-menu{display:flex}.landing-nav__links,.landing-nav__actions{display:none}.landing-hero{text-align:center;padding:calc(var(--header-height) + var(--space-12)) var(--space-6) var(--space-12);grid-template-columns:1fr;min-height:auto}.landing-hero__content{align-items:center}.landing-hero__social-proof{justify-content:center}.landing-hero__sub{max-width:100%}.landing-hero__mockup{display:none}.landing-steps{grid-template-columns:1fr}.landing-step__arrow{display:none}.landing-features-grid,.landing-stats-grid{grid-template-columns:repeat(2,1fr)}.landing-testimonials-grid{grid-template-columns:1fr}.landing-pricing-grid{grid-template-columns:1fr;max-width:400px;margin:0 auto}.landing-pricing-card--featured{transform:none}.landing-pricing-card--featured:hover{transform:translateY(-4px)}.landing-footer__container{gap:var(--space-8);grid-template-columns:1fr}}@media (max-width:640px){.landing-features-grid{grid-template-columns:1fr}.landing-stats-grid{grid-template-columns:repeat(2,1fr)}.landing-footer__links{grid-template-columns:1fr 1fr}.landing-cta-banner__actions{flex-direction:column}.landing-hero__title{font-size:var(--text-4xl)}.landing-hero__ctas{flex-direction:column;width:100%}.landing-btn-primary,.landing-btn-ghost{justify-content:center;width:100%}.landing-hero__social-proof{gap:var(--space-2)}.landing-hero__stat{font-size:var(--text-xs)}.landing-hero__stat-divider{display:none}.landing-section-container{padding:0 var(--space-4)}}
.auth-split{grid-template-columns:1fr 1fr;min-height:100vh;display:grid}.auth-split__panel{padding:var(--space-12);background:linear-gradient(145deg,#003d18 0%,#006a2c 55%,#004d20 100%);align-items:center;display:flex;position:relative;overflow:hidden}.auth-split__words{pointer-events:none;position:absolute;inset:0}.auth-split__word{color:#ffffff1a;font-family:var(--font-display);font-weight:var(--font-bold);font-size:var(--text-base);white-space:nowrap;-webkit-user-select:none;user-select:none;animation:5s ease-in-out infinite heroWordFloat;position:absolute}.auth-split__blob{filter:blur(60px);pointer-events:none;border-radius:50%;animation:8s ease-in-out infinite morphBlob,4s ease-in-out infinite pulseSlow;position:absolute}.auth-split__blob--1{background:#82ff991f;width:400px;height:400px;top:-100px;right:-80px}.auth-split__blob--2{background:#ff955a1a;width:250px;height:250px;animation-delay:2s;bottom:-60px;left:30px}.auth-split__panel-content{z-index:1;gap:var(--space-8);flex-direction:column;max-width:460px;display:flex;position:relative}.auth-split__logo{align-items:baseline;gap:2px;display:flex}.auth-split__logo-primary{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:var(--font-extrabold);color:#4ade80}.auth-split__logo-secondary{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:var(--font-semibold);color:#ffffff80}.auth-split__headline{font-family:var(--font-display);font-size:clamp(2rem,3.5vw,3rem);font-weight:var(--font-extrabold);color:#fff;letter-spacing:-.03em;line-height:1.15}.auth-split__headline-accent{background:linear-gradient(135deg,#82ff99,#4ade80);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.auth-split__desc{font-size:var(--text-base);color:#ffffffb3;line-height:var(--leading-vi)}.auth-split__features{gap:var(--space-3);flex-direction:column;display:flex}.auth-split__feature{align-items:center;gap:var(--space-3);color:#fffc;font-size:var(--text-sm);font-weight:var(--font-medium);display:flex}.auth-split__feature-icon{font-size:var(--text-lg)}.auth-split__levels{gap:var(--space-2);display:flex}.auth-split__level-badge{padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);color:#ffffffd9;font-size:var(--text-xs);font-weight:var(--font-bold);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);font-family:var(--font-display);background:#ffffff1f;border:1px solid #ffffff40}.auth-split__form-panel{background:var(--color-surface);padding:var(--space-8);justify-content:center;align-items:center;display:flex;position:relative}.dark .auth-split__form-panel{background:var(--color-bg)}.auth-split__form-wrapper{width:100%;max-width:420px}.auth-form{gap:var(--space-6);flex-direction:column;display:flex}.auth-form__logo-mobile{align-items:baseline;gap:2px;display:none}.auth-form__logo-primary{font-family:var(--font-display);font-size:var(--text-xl);font-weight:var(--font-extrabold);color:var(--color-primary)}.auth-form__logo-secondary{font-family:var(--font-display);font-size:var(--text-xl);font-weight:var(--font-semibold);color:var(--color-text-muted)}.auth-form__header{gap:var(--space-2);flex-direction:column;display:flex}.auth-form__title{font-family:var(--font-display);font-size:var(--text-3xl);font-weight:var(--font-extrabold);color:var(--color-text);letter-spacing:-.02em}.auth-form__subtitle{font-size:var(--text-base);color:var(--color-text-muted)}.auth-form__google-btn{justify-content:center;align-items:center;gap:var(--space-3);width:100%;padding:var(--space-3) var(--space-4);background:var(--color-surface);border:1.5px solid var(--color-border);border-radius:var(--radius-xl);font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-text);cursor:pointer;transition:all var(--duration-fast) var(--ease-default);font-family:var(--font-sans);display:flex}.auth-form__google-btn:hover{background:var(--color-bg-muted);border-color:var(--color-border);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.auth-form__divider{align-items:center;gap:var(--space-3);color:var(--color-text-muted);font-size:var(--text-xs);display:flex}.auth-form__divider:before,.auth-form__divider:after{content:"";background:var(--color-border);flex:1;height:1px}.auth-form__fields{gap:var(--space-4);flex-direction:column;display:flex}.auth-form__group{gap:var(--space-2);flex-direction:column;display:flex}.auth-form__label{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-text)}.auth-form__label-row{justify-content:space-between;align-items:center;display:flex}.auth-form__forgot{font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--color-primary);transition:opacity var(--duration-fast) var(--ease-default);text-decoration:none}.auth-form__forgot:hover{opacity:.75}.auth-form__input-wrapper{position:relative}.auth-form__input{width:100%;padding:var(--space-3) var(--space-4);font-size:var(--text-base);font-family:var(--font-sans);color:var(--color-text);background:var(--color-surface-container-high);border-radius:var(--radius-xl);transition:all var(--duration-fast) var(--ease-default);box-sizing:border-box;border:1.5px solid #0000;outline:none}.auth-form__input:focus{background:var(--color-surface);border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-glow)}.auth-form__input::placeholder{color:var(--color-text-subtle)}.auth-form__input-wrapper .auth-form__input{padding-right:var(--space-12)}.auth-form__toggle-pw{right:var(--space-3);cursor:pointer;font-size:var(--text-base);padding:var(--space-1);border-radius:var(--radius-md);transition:opacity var(--duration-fast) var(--ease-default);background:0 0;border:none;position:absolute;top:50%;transform:translateY(-50%)}.auth-form__toggle-pw:hover{opacity:.7}.auth-form__error{align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);color:var(--color-error);font-size:var(--text-sm);background:#b025000f;border:1px solid #b0250033;display:flex}.auth-form__submit{width:100%;padding:var(--space-4);font-size:var(--text-base);font-weight:var(--font-bold);font-family:var(--font-display);color:var(--primary-foreground);background:linear-gradient(135deg, var(--color-primary), var(--color-primary-dark));border-radius:var(--radius-xl);box-shadow:0 4px 0 var(--color-primary-dark);cursor:pointer;transition:all var(--duration-fast) var(--ease-bounce);justify-content:center;align-items:center;gap:var(--space-2);border:none;display:flex}.auth-form__submit:hover:not(:disabled){box-shadow:0 6px 0 var(--color-primary-dark), var(--shadow-primary);transform:translateY(-1px)}.auth-form__submit:active:not(:disabled){box-shadow:none;transform:translateY(3px)}.auth-form__submit:disabled{opacity:.7;cursor:not-allowed;transform:none}.auth-form__spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:16px;height:16px;animation:.7s linear infinite spin;display:inline-block}.auth-form__footer{font-size:var(--text-sm);color:var(--color-text-muted);text-align:center}.auth-form__footer-link{color:var(--color-primary);font-weight:var(--font-semibold);text-decoration:none}.auth-form__footer-link:hover{text-decoration:underline}.auth-form__terms{font-size:var(--text-xs);color:var(--color-text-muted);text-align:center;line-height:var(--leading-relaxed)}.auth-form__terms a{color:var(--color-primary);text-decoration:none}.auth-form__optional{font-weight:var(--font-normal);color:var(--color-text-subtle);font-size:var(--text-xs)}.auth-form__ref-banner{padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);color:var(--color-primary);font-size:var(--text-sm);line-height:var(--leading-vi);background:#4ade8014;border:1px solid #4ade8040}.dark .auth-form__ref-banner{background:#4ade800f;border-color:#4ade8026}.auth-form__success{align-items:center;gap:var(--space-4);text-align:center;padding:var(--space-8) 0;flex-direction:column;display:flex}.auth-form__success-icon{font-size:4rem}.auth-form__success-title{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--color-text)}.auth-form__success-text{font-size:var(--text-sm);color:var(--color-text-muted);line-height:var(--leading-vi);max-width:320px}.auth-form__success-hint{font-size:var(--text-xs);color:var(--color-text-subtle)}@media (max-width:768px){.auth-split{grid-template-columns:1fr}.auth-split__panel{display:none}.auth-form__logo-mobile{display:flex}.auth-split__form-panel{min-height:100vh;padding:var(--space-6) var(--space-4);padding-top:var(--space-12);align-items:flex-start}}

