*{box-sizing:border-box;padding:0;margin:0;scrollbar-color:var(--color-border) transparent;scrollbar-width:thin}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}html{scroll-behavior:smooth}:root{color-scheme:light;--color-bg: #fafafa;--color-surface: #ffffff;--color-surface-hover: #f0f0f0;--color-border: #e0e0e0;--color-text: #1a1a1a;--color-text-muted: #666666;--color-primary: #4f46e5;--color-primary-hover: #4338ca;--color-success: #16a34a;--color-error: #dc2626;--color-warning: #a16207;--color-tooltip-bg: #333333;--color-tooltip-text: #ffffff;--font-sans: "Inter", system-ui, -apple-system, sans-serif;--font-mono: "SF Mono", "Fira Code", monospace;--font-shavian: "Noto Sans Shavian", sans-serif;--font-deseret: "Noto Sans Deseret", sans-serif}[data-theme=dark]{color-scheme:dark;--color-bg: #0f0f0f;--color-surface: #1a1a1a;--color-surface-hover: #252525;--color-border: #333333;--color-text: #f5f5f5;--color-text-muted: #999999;--color-primary: #818cf8;--color-primary-hover: #a5b4fc;--color-success: #22c55e;--color-error: #ef4444;--color-warning: #facc15;--color-tooltip-bg: #e0e0e0;--color-tooltip-text: #1a1a1a}body{min-height:100vh;font-family:var(--font-sans);line-height:1.6;color:var(--color-text);background-color:var(--color-bg)}a{color:var(--color-primary);text-decoration:none}a:hover{text-decoration:underline}[data-orig]{position:relative;cursor:help}[data-orig]:hover:after{position:absolute;bottom:100%;left:50%;z-index:100;padding:4px 8px;font-family:system-ui,-apple-system,sans-serif;font-size:.85em;line-height:1.4;color:var(--color-tooltip-text);white-space:nowrap;pointer-events:none;content:attr(data-orig);background:var(--color-tooltip-bg);border-radius:4px;opacity:0;transform:translate(-50%);animation:tooltip-fade-in .15s ease-out forwards}[data-orig]:hover:before{position:absolute;bottom:100%;left:50%;z-index:100;margin-bottom:-10px;pointer-events:none;content:"";border:5px solid transparent;border-top-color:var(--color-tooltip-bg);opacity:0;transform:translate(-50%);animation:tooltip-fade-in .15s ease-out forwards}[data-orig].tooltip-below:hover:after{top:calc(100% + 5px);bottom:auto}[data-orig].tooltip-below:hover:before{top:100%;bottom:auto;margin-bottom:0;border-top-color:transparent;border-bottom-color:var(--color-tooltip-bg)}@keyframes tooltip-fade-in{to{opacity:1}}#root{max-width:1200px;padding:2rem;margin:0 auto}.app{display:flex;flex-direction:column;min-height:100vh}.loading-screen{display:flex;flex-direction:column;gap:1rem;align-items:center;padding-top:4rem}.error-screen{display:flex;flex:1;flex-direction:column;gap:1rem;align-items:center;justify-content:center}.loading-spinner{width:40px;height:40px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.error-boundary{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:200px;padding:2rem;margin:1rem;text-align:center;background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px}.error-boundary h2{margin:0 0 .5rem;color:var(--color-error, #dc2626)}.error-boundary .error-message{max-width:400px;margin:0 0 1rem;color:var(--color-text-muted)}.update-banner{padding:.5rem 1rem;margin-bottom:1rem;font-size:.875rem;color:#fff;text-align:center;background:var(--color-primary);border-radius:.5rem}.update-banner button{padding:.25rem .75rem;margin-left:.5rem;font-size:.875rem;font-weight:600;color:#fff;cursor:pointer;background:#fff3;border:1px solid rgba(255,255,255,.4);border-radius:.375rem}.update-banner button:hover{background:#ffffff4d}.header{margin-bottom:2rem;text-align:center}.header-title{display:flex;gap:1rem;align-items:center;justify-content:center}.logo-link{display:flex;gap:1rem;align-items:center;text-decoration:none}.subtitle-link{padding:0;font-size:1.25rem;color:var(--color-text-muted);cursor:pointer;background:none;border:none}.subtitle-link:hover{color:var(--color-primary)}.logo{width:56px;height:56px}.header h1{font-size:3rem;font-weight:700;background:linear-gradient(135deg,var(--color-primary),#a855f7);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.toggle-buttons{position:absolute;top:1rem;right:1rem;display:flex;gap:.5rem;align-items:center}.theme-toggle{padding:.5rem;font-size:1.25rem;line-height:1;color:var(--color-text);cursor:pointer;background:var(--color-surface);border:1px solid var(--color-border);border-radius:.5rem;transition:background-color .2s}.theme-toggle:hover{background:var(--color-surface-hover)}.tabs{display:flex;gap:.5rem;padding-bottom:.5rem;margin-bottom:1.5rem;overflow-x:auto;scrollbar-width:none;border-bottom:1px solid var(--color-border)}.tabs::-webkit-scrollbar{display:none}.tab{padding:.75rem .875rem;font-size:.9375rem;font-weight:500;color:var(--color-text-muted);white-space:nowrap;text-decoration:none;cursor:pointer;background:transparent;border:none;border-radius:.5rem;transition:background-color .2s,color .2s}.tab:hover{color:var(--color-text);background:var(--color-surface)}.tab.active{color:var(--color-primary);background:var(--color-surface)}.main{flex:1}.footer{padding-top:1.5rem;margin-top:3rem;text-align:center;border-top:1px solid var(--color-border)}.footer p{font-size:.875rem;color:var(--color-text-muted)}@media(max-width:640px){#root{padding:1rem}.header{margin-bottom:1rem;text-align:left}.header-title{justify-content:flex-start}.header h1{font-size:2rem}.logo{width:40px;height:40px}.subtitle-link{display:none}.toggle-buttons{top:.5rem;right:.5rem;gap:.25rem}.theme-toggle{padding:.25rem;font-size:1rem}.tabs{flex-wrap:nowrap;gap:.375rem;overflow-x:auto;scrollbar-width:none}.tabs::-webkit-scrollbar{display:none}.tab{flex-shrink:0;padding:.5rem .75rem;font-size:.8125rem;white-space:nowrap;border:1px solid var(--color-border)}.footer{padding-top:1rem;margin-top:2rem}}.btn-primary,.btn-secondary{min-width:5.5rem;padding:.75rem 1.5rem;font-size:.875rem;font-weight:500;cursor:pointer;border:none;border-radius:.5rem;transition:background-color .2s,color .2s,border-color .2s}.btn-primary{color:#fff;background:var(--color-primary)}.btn-primary:hover:not(:disabled){background:var(--color-primary-hover)}.btn-primary:disabled{cursor:not-allowed;opacity:.5}.btn-secondary{color:var(--color-text);background:var(--color-surface);border:1px solid var(--color-border)}.btn-secondary:hover:not(:disabled){background:var(--color-surface-hover)}.btn-secondary:disabled{cursor:not-allowed;opacity:.5}.btn-copied,.btn-speaking{color:#fff!important;background:var(--color-primary)!important;border-color:var(--color-primary)!important}.btn-icon{display:inline-flex;align-items:center;justify-content:center;min-width:auto;padding:.75rem}.btn-loading{position:relative;color:transparent!important}.btn-loading:after{position:absolute;top:50%;left:50%;width:16px;height:16px;margin-top:-8px;margin-left:-8px;content:"";border:2px solid transparent;border-top-color:currentcolor;border-radius:50%;animation:spin .8s linear infinite}.btn-primary.btn-loading:after{border-top-color:#fff}.btn-secondary.btn-loading:after{border-top-color:var(--color-text)}.button-group{display:flex;gap:.5rem}.format-toggle{min-width:6rem}.error-message{padding:1rem;color:var(--color-error);background:#ef44441a;border:1px solid var(--color-error);border-radius:.5rem}.success-message{padding:1rem;color:var(--color-success);background:#22c55e1a;border:1px solid var(--color-success);border-radius:.5rem}.warning-message{padding:.75rem 1rem;font-size:.875rem;color:var(--color-warning);background:#eab3081a;border:1px solid #eab308;border-radius:.5rem}.info-box{padding:1.5rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:.5rem}.info-box h3{margin-bottom:.75rem;font-size:1rem;font-weight:600;color:var(--color-text)}.info-box p{margin-bottom:.75rem;color:var(--color-text-muted)}.info-box ul{display:flex;flex-wrap:wrap;gap:.5rem 1.5rem;color:var(--color-text-muted);list-style:none}.info-box li strong{font-family:var(--font-mono);color:var(--color-primary)}.note{padding:.75rem 1rem;margin-top:1rem;font-size:.9rem;color:var(--color-text-muted);background:var(--color-surface);border-left:3px solid var(--color-primary);border-radius:.5rem}@media(max-width:640px){.btn-primary,.btn-secondary{min-width:auto;padding:.5rem .75rem;font-size:.8125rem}.btn-icon{padding:.5rem}.button-group{flex-wrap:wrap;justify-content:flex-end}}.text-translator{display:flex;flex-direction:column;gap:1.5rem}.language-select,.sample-select{padding:.75rem;font-size:.875rem;font-weight:500;color:var(--color-text);cursor:pointer;background:var(--color-surface);border:1px solid var(--color-border);border-radius:.5rem}[data-theme=dark] .language-select option,[data-theme=dark] .sample-select option{color:var(--color-text);background:var(--color-surface)}.translator-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}@media(max-width:768px){.translator-grid{grid-template-columns:1fr;gap:0}.translator-grid .input-section{padding:1rem;border:1px solid var(--color-border)}.translator-grid .input-section:first-child{border-bottom:none;border-radius:.5rem .5rem 0 0}.translator-grid .ingglish-section{background:var(--color-surface-hover);border-radius:0 0 .5rem .5rem}.translator-grid .input-section .text-input{background:transparent;border:none;border-radius:0}.translator-grid .input-section .text-input:focus{box-shadow:inset 0 0 0 1px var(--color-primary)}}.input-section{display:flex;flex-direction:column;gap:.75rem;min-width:0;overflow:hidden}.section-header,.section-footer{display:flex;gap:.5rem;align-items:center;justify-content:space-between}.section-footer .sample-select{flex:1;min-width:5rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sample-source-link{flex-shrink:0;font-size:.8125rem;color:var(--color-primary);white-space:nowrap;text-decoration:none}.sample-source-link:hover{text-decoration:underline}.format-cycle-btn{padding:.75rem;font-size:.875rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;cursor:pointer;background:none;border:1px solid var(--color-border);border-radius:.5rem;transition:background-color .15s,border-color .15s}.format-cycle-btn:hover{background:var(--color-surface-hover);border-color:var(--color-text-muted)}.format-cycle-icon{margin-left:.25em;font-size:.75em;opacity:.5}.format-cycle-inline{font-weight:600;text-transform:none;letter-spacing:normal}.text-input{min-height:300px;padding:1rem;font-family:var(--font-sans);font-size:1rem;line-height:1.7;color:var(--color-text);resize:vertical;background:var(--color-surface);border:1px solid var(--color-border);border-radius:.5rem}.text-input:focus{outline:none;border-color:var(--color-primary)}.word-token{padding:.1em .15em;cursor:pointer;border-radius:.2em;transition:background-color .15s,color .15s}.word-token:hover,.word-token.highlighted{color:#fff;background:var(--color-primary)}.word-token.spoken{color:#fff;text-decoration:underline;text-underline-offset:.15em;background:var(--color-primary)}.overlay-textarea{position:relative;display:flex;flex:1;flex-direction:column}.overlay-textarea textarea{position:relative;z-index:1;flex:1;color:transparent;caret-color:var(--color-text);background:transparent}.overlay-textarea textarea::placeholder{color:var(--color-text-muted)}.overlay-textarea-display{position:absolute;inset:0;overflow-y:auto;overflow-wrap:break-word;white-space:pre-wrap;pointer-events:none;background:var(--color-surface);border-color:transparent}.overlay-textarea-display .word-token{margin:0 -.15em;transition:none}.target-output{flex:1;overflow-y:auto;overflow-wrap:break-word;white-space:pre-wrap}.target-output-placeholder,.target-output-loading{font-style:italic;color:var(--color-text-muted)}.target-not-found{text-decoration:underline wavy var(--color-error);text-decoration-thickness:1.5px;text-underline-offset:.2em;opacity:.6}@media(max-width:640px){.text-translator{gap:1rem}.text-input{min-height:150px;font-size:16px}.section-header{flex-wrap:wrap}.format-cycle-btn{padding:.5rem .75rem}.language-select,.sample-select{max-width:100%;padding:.5rem .75rem}}.url-translator{display:flex;flex-direction:column;gap:1rem}.url-form{display:flex;gap:.75rem}.url-input{flex:1;padding:.75rem 1rem;font-size:1rem;color:var(--color-text);background:var(--color-surface);border:1px solid var(--color-border);border-radius:.5rem}.url-input:focus{outline:none;border-color:var(--color-primary)}.iframe-container{position:relative;overflow:hidden;background:var(--color-surface);border:1px solid var(--color-border);border-radius:.5rem}.iframe-container--empty{display:none}.iframe-loading-indicator{position:absolute;inset:0;z-index:10;display:flex;align-items:center;justify-content:center;pointer-events:none;background:var(--color-surface)}.page-iframe{width:100%;min-height:500px;background:#fff;border:none;opacity:0;transition:opacity .2s ease-in}.page-iframe--ready{opacity:1}.example-urls{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.example-label{font-size:.875rem;font-weight:500;color:var(--color-text-muted)}.example-link{padding:.375rem .75rem;font-size:.8125rem;color:var(--color-primary);cursor:pointer;background:none;border:1px solid var(--color-border);border-radius:1rem;transition:background-color .2s,border-color .2s,color .2s}.example-link:hover:not(:disabled){color:#fff;background:var(--color-primary);border-color:var(--color-primary)}.example-link:disabled{cursor:not-allowed;opacity:.5}.url-note{font-size:.875rem;color:var(--color-text-muted);text-align:center}.fullscreen-btn{position:absolute;top:.5rem;right:.5rem;z-index:20;padding:.5rem;color:#fff;cursor:pointer;background:#0009;border:none;border-radius:.375rem;opacity:0;transition:opacity .2s,background-color .2s}.iframe-container:hover .fullscreen-btn{opacity:1}.fullscreen-btn:hover{background:#000c}.iframe-container--fullscreen{position:fixed;inset:0;z-index:9999;background:#fff;border:none;border-radius:0}.iframe-container--fullscreen .page-iframe{height:100vh;min-height:100vh}.iframe-container--fullscreen .fullscreen-btn{top:1rem;right:1rem;opacity:1}@media(max-width:640px){.url-form{flex-direction:column}.url-input{font-size:16px}.page-iframe{min-height:300px}.example-urls{justify-content:center}.example-label{width:100%;text-align:center}}.spelling-guide{max-width:800px;margin:0 auto}.guide-intro{margin-bottom:2rem}.guide-intro h2{margin-bottom:.75rem;font-size:1.5rem}.guide-intro p{line-height:1.7;color:var(--color-text-muted)}.guide-intro p+p{margin-top:1rem}.guide-section{margin-bottom:2rem}.guide-section h3{margin-bottom:1rem;font-size:1.25rem;color:var(--color-primary)}.guide-section h4{margin-top:1.5rem}.sound-groups{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}.sound-group h4{margin-bottom:.5rem;font-size:.875rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}details.sound-group>summary{cursor:pointer;list-style:revert}details.sound-group>summary>h4{display:inline}.mapping-table{width:100%;overflow:hidden;border-collapse:collapse;background:var(--color-surface);border-radius:.5rem}.mapping-table th,.mapping-table td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid var(--color-border)}.mapping-table th{font-size:.875rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;white-space:nowrap;background:var(--color-surface-hover)}.mapping-table th:nth-child(1),.mapping-table th:nth-child(2){width:3.5rem;text-align:center}.mapping-table tr:last-child td{border-bottom:none}.mapping-table .ipa-cell{width:3.5rem;font-family:var(--font-mono);font-size:1.1rem;font-weight:600;color:var(--color-text);text-align:center}.mapping-table .ingglish-cell{width:3.5rem;font-family:var(--font-mono);font-size:1.1rem;font-weight:600;color:var(--color-primary);text-align:center}.sound-note{font-size:.7rem;font-weight:400;vertical-align:super;cursor:help;opacity:.5}.examples-cell{font-size:.875rem;color:var(--color-text-muted)}.example-pair{white-space:nowrap}.examples-cell strong{font-weight:inherit;color:var(--color-text);text-decoration:underline;text-decoration-color:var(--color-primary);text-underline-offset:2px}.principles-list{display:flex;flex-direction:column;gap:.75rem;list-style:none}.principles-list li{padding:.75rem 1rem;background:var(--color-surface);border-left:3px solid var(--color-primary);border-radius:.5rem}.principles-list li strong{color:var(--color-text)}@media(max-width:640px){.spelling-guide{padding:0}.guide-intro h2{font-size:1.25rem}.sound-groups{grid-template-columns:1fr}.mapping-table th,.mapping-table td{padding:.5rem;font-size:.875rem}.mapping-table .ipa-cell,.mapping-table .ingglish-cell{width:2.5rem;font-size:1rem}.mapping-table th:nth-child(1),.mapping-table th:nth-child(2){width:2.5rem}}.extension-page{max-width:800px;margin:0 auto}.install-steps{display:flex;flex-direction:column;gap:1rem;list-style:none;counter-reset:step}.install-steps li{position:relative;padding:1rem 1rem 1rem 3.5rem;counter-increment:step;background:var(--color-surface);border-radius:.5rem}.install-steps li:before{position:absolute;top:1rem;left:1rem;display:flex;align-items:center;justify-content:center;width:1.75rem;height:1.75rem;font-size:.875rem;font-weight:600;color:#fff;content:counter(step);background:var(--color-primary);border-radius:50%}.install-steps li strong{display:block;margin-bottom:.25rem}.install-steps li p{margin:0;font-size:.9rem;color:var(--color-text-muted)}.install-steps li code{padding:.125rem .375rem;font-family:var(--font-mono);font-size:.85rem;background:var(--color-surface-hover);border-radius:.25rem}.bookmarklet-container{display:flex;gap:1rem;align-items:center;margin:1rem 0}.bookmarklet-button{display:inline-block;padding:.625rem 1.5rem;font-size:1rem;font-weight:600;color:#fff;text-decoration:none;cursor:grab;background:var(--color-primary);border-radius:.5rem;box-shadow:0 2px 8px #00000026;transition:transform .15s,box-shadow .15s}.bookmarklet-button:hover{color:#fff;box-shadow:0 4px 12px #0003;transform:translateY(-1px)}.bookmarklet-button:active{cursor:grabbing}.bookmarklet-hint{font-size:.875rem;color:var(--color-text-muted)}.link-button{padding:0;font-size:inherit;color:var(--color-primary);text-decoration:underline;cursor:pointer;background:none;border:none}.link-button:hover{color:var(--color-primary-hover, var(--color-primary))}@media(max-width:640px){.install-steps li{padding:1rem 1rem 1rem 3rem}.install-steps li:before{left:.75rem;width:1.5rem;height:1.5rem;font-size:.75rem}}.docs-container{display:flex;gap:2rem;max-width:1200px;margin:0 auto}.docs-sidebar{flex-shrink:0;width:200px;overflow:hidden}.docs-sidebar>ul{padding:0;margin:0;list-style:none}.docs-sidebar li{margin-bottom:.25rem}.docs-section-header{padding:.375rem 1rem;margin-top:1rem;margin-bottom:.25rem;font-size:.6875rem;font-weight:700;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.docs-sidebar li:first-child .docs-section-header{margin-top:0}.docs-nav-item{display:block;width:100%;padding:.5rem 1rem;font-weight:600;color:var(--color-text);text-align:left;text-decoration:none;cursor:pointer;background:none;border:none;border-radius:.5rem;transition:background-color .2s,color .2s}.docs-nav-item:hover{color:var(--color-text);background:var(--color-surface)}.docs-nav-item.active{color:#fff;background:var(--color-primary)}.docs-subsections{padding:0;margin:.25rem 0 .5rem;list-style:none}.docs-subsections li{margin-bottom:0}.docs-subsection-link{display:block;padding:.2rem 1rem .2rem 1.75rem;overflow:hidden;text-overflow:ellipsis;font-size:.75rem;color:var(--color-text-muted);white-space:nowrap;text-decoration:none;border-radius:.25rem;transition:background-color .15s,color .15s}.docs-subsection-link:hover{color:var(--color-text);background:var(--color-surface)}.docs-subsection-h3{padding-left:2.25rem}.docs-content{flex:1;min-width:0;overflow-x:auto}.docs-header{display:flex;justify-content:flex-end;margin-bottom:1rem}.docs-edit-link{display:inline-flex;gap:.375rem;align-items:center;padding:.375rem .75rem;font-size:.875rem;color:var(--color-text-muted);text-decoration:none;background:var(--color-surface);border-radius:.375rem;transition:background-color .2s,color .2s}.docs-edit-link:hover{color:var(--color-text);background:var(--color-surface-hover)}.docs-content h1{margin-bottom:1rem;font-size:2rem;color:var(--color-text)}.docs-content h2{padding-bottom:.5rem;margin-top:2rem;margin-bottom:1rem;font-size:1.5rem;color:var(--color-text);border-bottom:1px solid var(--color-border)}.docs-content h3{margin-top:1.5rem;margin-bottom:.75rem;font-size:1.25rem;color:var(--color-text)}.docs-content h4{margin-top:1.25rem;margin-bottom:.5rem;font-size:1rem;color:var(--color-text)}.docs-content p{margin-bottom:1rem;line-height:1.7}.docs-content ul,.docs-content ol{padding-left:1.5rem;margin-bottom:1rem}.docs-content li{margin-bottom:.5rem;line-height:1.6}.docs-content code{padding:.125rem .375rem;font-family:var(--font-mono);font-size:.875rem;background:var(--color-surface);border-radius:.25rem}.docs-content pre{padding:1rem;margin-bottom:1rem;overflow-x:auto;background:var(--color-surface);border-radius:.5rem}.docs-content pre code{padding:0;background:none}.docs-content table{width:100%;margin-bottom:1rem;border-collapse:collapse}.docs-content th,.docs-content td{padding:.75rem;text-align:left;border-bottom:1px solid var(--color-border)}.docs-content th{font-weight:600;background:var(--color-surface)}.docs-content a{color:var(--color-primary)}.docs-content a:hover{text-decoration:underline}.docs-content hr{margin:2rem 0;border:none;border-top:1px solid var(--color-border)}.docs-content blockquote{padding-left:1rem;margin:1rem 0;color:var(--color-text-muted);border-left:3px solid var(--color-primary)}@media(max-width:640px){.docs-container{flex-direction:column}.docs-sidebar{width:100%}.docs-sidebar>ul{position:static;display:flex;flex-wrap:nowrap;gap:.375rem;padding-bottom:.5rem;overflow-x:auto;scrollbar-width:none}.docs-sidebar>ul::-webkit-scrollbar{display:none}.docs-sidebar>ul>li{flex-shrink:0;margin-bottom:0}.docs-section-header{display:none}.docs-nav-item{padding:.375rem .75rem;font-size:.8125rem;white-space:nowrap;border:1px solid var(--color-border)}.docs-subsections{display:none}}.tutorial{max-width:720px;padding-bottom:4rem;margin:0 auto}.tutorial-section{display:grid;align-content:center;min-width:0;padding:4rem 0}.tutorial-section:first-child{min-height:60vh}.tutorial-section:nth-child(2){min-height:80vh}.scroll-hint{display:flex;justify-content:center;padding-top:2rem;font-size:1.5rem;opacity:.5;animation:bounce 2s infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(8px)}}.tutorial-heading{margin-bottom:2rem;font-size:2rem;font-weight:700;text-align:center}.tutorial-subheading{margin-bottom:.5rem;font-size:1.5rem;font-weight:600}.tutorial-caption{margin-bottom:1.5rem;color:var(--color-text-muted)}.tutorial-punchline{margin-top:2rem;font-size:1.1rem;font-style:italic;color:var(--color-text-muted);text-align:center}.tutorial-substep{margin-bottom:3rem;opacity:0;transition:opacity .6s ease}.tutorial-substep.revealed{opacity:1}.ough-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.ough-card{display:flex;gap:.75rem;align-items:center;padding:1rem 1.25rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:.5rem;opacity:0;transition:opacity .4s ease}.ough-card.revealed{opacity:1}.ough-english-word,.ough-ingglish-word{flex:1;font-size:1.3rem;font-weight:600}.ough-english-word{text-align:right}.ough-ingglish-word{text-align:left}.ough-ingglish-text{position:relative;opacity:0;transform:translate(-8px);transition:opacity .6s ease .6s,transform .6s ease .6s}.ough-highlight-old{font-weight:700;color:var(--color-error)}.ough-arrow{color:var(--color-text-muted);opacity:0;transition:opacity .5s ease .4s}.ough-arrow.shown{opacity:1}.ough-ingglish-word.shown .ough-ingglish-text{opacity:1;transform:translate(0)}.ough-highlight-new{font-weight:700;color:var(--color-primary)}.tutorial-whatif{padding:6rem 0;text-align:center}.whatif-line{margin-bottom:1.5rem;font-size:1.5rem;line-height:1.6;opacity:0;transition:opacity .6s ease}.whatif-line.revealed{opacity:1}.whatif-punchline{font-size:2rem;font-weight:700;color:var(--color-primary)}.sound-group{margin-bottom:2rem}.sound-examples{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:.75rem}.sound-word{display:inline-flex;gap:.5rem;align-items:center;font-size:1.1rem;opacity:0;transition:opacity .3s ease}.sound-word.animate{opacity:1}.sound-english{font-weight:500}.sound-highlight-old{font-weight:700;color:var(--color-error)}.sound-highlight-new{font-weight:700;color:var(--color-primary)}.sound-arrow{font-size:.9rem;color:var(--color-text-muted);opacity:0;transition:opacity .3s ease}.sound-word.animate .sound-arrow{opacity:1;transition-delay:.3s}.sound-morph{position:relative;display:inline-grid}.sound-morph-before,.sound-morph-after{grid-area:1 / 1;font-weight:600}.sound-morph-before{opacity:0;transform:translate(-2rem);transition:opacity .3s ease,transform .4s ease}.sound-word.animate .sound-morph-before{opacity:1;transform:translate(0);transition:opacity .3s ease .3s,transform .4s ease .3s}.sound-word.morphed .sound-morph-before{opacity:0;transform:translate(0);transition:opacity .3s ease}.sound-morph-after{opacity:0;transition:opacity .3s ease}.sound-word.morphed .sound-morph-after{opacity:1}.sound-ingglish{position:relative;font-weight:600;opacity:0;transition:opacity .4s ease .5s}.sound-word.animate .sound-ingglish{opacity:1}.sound-description{font-size:.95rem;color:var(--color-text-muted);opacity:0;transition:opacity .4s ease}.sound-description.animate{opacity:1}.progressive-paragraph{padding:2rem;margin-bottom:2rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:.75rem}.progressive-text{min-height:10rem;font-size:1.25rem;line-height:2}.progressive-word{position:relative;display:inline-block;transition:transform .4s ease,color .4s ease}.progressive-word.transformed{color:var(--color-primary)}.progressive-word.highlighted{padding:0 2px;background:color-mix(in srgb,var(--color-primary) 15%,transparent);border-radius:3px}.progressive-caption{min-height:3rem;margin-top:1rem;margin-bottom:.75rem;font-size:.95rem;font-style:italic;color:var(--color-text-muted);text-align:center}.progressive-controls{display:flex;gap:1rem;align-items:center;justify-content:center;margin-top:1.5rem}.progressive-btn{padding:.5rem 1.25rem;font-size:.95rem;color:var(--color-text);cursor:pointer;background:var(--color-surface);border:1px solid var(--color-border);border-radius:.5rem;transition:background-color .2s}.progressive-btn:hover:not(:disabled){background:var(--color-surface-hover)}.progressive-btn:disabled{cursor:default;opacity:.3}.progressive-btn-next{color:#fff;background:var(--color-primary);border-color:var(--color-primary)}.progressive-btn-next:hover:not(:disabled){background:var(--color-primary-hover)}.progressive-indicator{min-width:6rem;font-size:.9rem;color:var(--color-text-muted);text-align:center}.poem-attribution{margin-bottom:1.5rem;font-size:.95rem;font-style:italic;color:var(--color-text-muted);text-align:center}.poem-paragraph{padding:2rem;margin-bottom:1.5rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:.75rem}.poem-controls{float:right;margin:-.5rem -.5rem 0 .5rem}.poem-control-btn{padding:.25rem .5rem;font-size:1.25rem;line-height:1;color:var(--color-text);cursor:pointer;background:var(--color-surface);border:1px solid var(--color-border);border-radius:.5rem;transition:background-color .2s}.poem-control-btn:hover{background:var(--color-surface-hover)}.poem-text-sizer{display:grid}.poem-text-sizer>.poem-text{grid-area:1 / 1}.poem-text-hidden{visibility:hidden;pointer-events:none}.poem-text{font-size:1.2rem;line-height:2}.poem-word{position:relative;display:inline-block;transition:color .5s ease}.poem-word.transformed{color:var(--color-primary)}.poem-word.highlighted{padding:0 2px;background:color-mix(in srgb,var(--color-primary) 15%,transparent);border-radius:3px}.reading-test{text-align:center}.reading-ingglish{margin-bottom:2rem;font-family:var(--font-mono);font-size:1.3rem;line-height:1.8;color:var(--color-primary)}.reading-attribution{font-size:.95rem;font-style:italic;color:var(--color-text-muted)}.try-it-container{width:100%;max-width:480px;margin:0 auto}.try-it-input{width:100%;padding:.75rem 1rem;font-size:1.5rem;color:var(--color-text);outline:none;background:var(--color-surface);border:1px solid var(--color-border);border-radius:.5rem;transition:border-color .2s}.try-it-input:focus{border-color:var(--color-primary)}.try-it-output.word-display{min-height:2.75rem;max-height:none;padding:.75rem 1rem;margin-top:1rem;overflow:visible;font-family:var(--font-mono);font-size:1.3rem;font-weight:600;color:var(--color-primary);text-align:left;overflow-wrap:break-word;background:var(--color-surface);border:1px solid var(--color-border);border-radius:.5rem}.try-it-input-wrapper{position:relative}.try-it-input.demo-cursor{caret-color:transparent}.try-it-input.demo-cursor:after{content:""}.try-it-input-wrapper:after{display:none;content:""}.try-it-input.demo-cursor+.try-it-cursor-blink,.try-it-input-wrapper:has(.demo-cursor):after{position:absolute;top:50%;right:1rem;display:block;width:2px;height:1.4em;content:"";background:var(--color-text);transform:translateY(-50%);animation:cursor-blink 1s step-end infinite}@keyframes cursor-blink{0%,to{opacity:1}50%{opacity:0}}.tutorial-try-it{min-height:80vh}.try-it-cta{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;margin-top:2rem}.try-it-cta-prompt{width:100%;margin:0;font-size:.95rem;color:var(--color-text-muted);text-align:center}.tutorial-cta{padding:6rem 0 2rem;text-align:center}.cta-buttons{display:grid;grid-template-columns:repeat(2,auto);gap:1rem;justify-content:center}.cta-primary,.cta-secondary{display:inline-block;padding:1rem 2rem;font-size:1.1rem;font-weight:600;text-decoration:none;border-radius:.5rem;transition:background-color .2s,transform .1s}.cta-primary:hover,.cta-secondary:hover{text-decoration:none;transform:translateY(-1px)}.cta-primary:active,.cta-secondary:active{transform:translateY(0)}.cta-primary{color:#fff;background:var(--color-primary)}.cta-primary:hover{background:var(--color-primary-hover)}.cta-secondary{color:var(--color-text);background:var(--color-surface);border:1px solid var(--color-border)}.cta-secondary:hover{background:var(--color-surface-hover)}@media(prefers-reduced-motion:reduce){.tutorial-substep,.ough-card,.ough-arrow,.ough-ingglish-text,.whatif-line,.sound-word,.sound-arrow,.sound-ingglish,.sound-morph-before,.sound-morph-after,.sound-description,.progressive-word{opacity:1!important;transform:none!important;transition:none!important}}@media(max-width:640px){.tutorial{padding-bottom:2rem}.tutorial-section{padding:2rem 0}.tutorial-heading{font-size:1.5rem}.tutorial-subheading{font-size:1.25rem}.ough-grid{grid-template-columns:1fr}.tutorial-whatif{padding:4rem 0}.whatif-line{font-size:1.2rem}.whatif-punchline{font-size:1.5rem}.progressive-paragraph{position:static;padding:1.25rem}.progressive-text,.reading-ingglish{font-size:1.1rem}.cta-buttons{grid-template-columns:1fr;justify-items:center}.cta-primary,.cta-secondary{width:100%;max-width:300px;text-align:center}.try-it-cta{flex-direction:column;align-items:center}.try-it-cta .cta-primary,.try-it-cta .cta-secondary{width:100%;max-width:300px;text-align:center}}.experiment-page{max-width:1200px;margin:0 auto}.experiment-intro{margin-bottom:1.5rem}.experiment-intro p{line-height:1.7;color:var(--color-text-muted)}.experiment-presets{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center;margin-bottom:1.5rem}.presets-label{font-size:.875rem;font-weight:600;color:var(--color-text-muted)}.preset-link{padding:.25rem .625rem;font-size:.875rem;color:var(--color-text);text-decoration:none;cursor:pointer;background:var(--color-surface);border:1px solid var(--color-border);border-radius:999px;transition:background .15s,border-color .15s}.preset-link:hover{background:var(--color-surface-hover);border-color:var(--color-primary)}.preset-active{color:#fff;background:var(--color-primary);border-color:var(--color-primary)}.preset-active:hover{background:var(--color-primary)}.presets-break{flex-basis:100%;height:0}.presets-divider{width:1px;height:1.25rem;background:var(--color-border)}button.preset-action{font-weight:500}button.preset-action:disabled{cursor:not-allowed;opacity:.4}.experiment-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:2rem;align-items:start}.experiment-right{position:sticky;top:1rem;display:flex;flex-direction:column;gap:1.5rem;max-height:calc(100vh - 2rem);overflow:hidden auto}.mapping-editor{min-width:0;overflow-x:auto}.editor-controls{margin-bottom:1rem}.advanced-toggle{display:flex;gap:.5rem;align-items:center;font-size:.875rem;color:var(--color-text-muted);cursor:pointer}.advanced-toggle input{cursor:pointer}.editor-section{margin-bottom:1.5rem}.editor-section h3{margin-bottom:1rem;font-size:1.25rem;color:var(--color-primary)}.duplicate-warnings{padding:.75rem 1rem;margin-bottom:1rem;font-size:.875rem;background:#fef3cd;border:1px solid #ffc107;border-radius:.5rem}[data-theme=dark] .duplicate-warnings{background:#332b00;border-color:var(--color-warning)}.duplicate-warnings ul{padding-left:1.25rem;margin-top:.5rem}.duplicate-warnings li{margin-bottom:.25rem}.experiment-table th:nth-child(1),.experiment-table th:nth-child(2),.experiment-table th:nth-child(3){width:3.5rem;text-align:center}.editable-cell{height:1px;padding:0!important}.cell-input{width:100%;height:100%;padding:.75rem .25rem;font-family:var(--font-mono);font-size:1.1rem;font-weight:600;color:var(--color-primary);text-align:center;cursor:text;outline:none;background:transparent;border:none;border-bottom:1.5px dashed var(--color-border);transition:border-color .15s,background .15s}.cell-input:hover{background:var(--color-surface-hover);border-bottom-color:var(--color-primary)}.cell-input:focus{background:var(--color-surface-hover);border-bottom-color:transparent;border-radius:2px;box-shadow:inset 0 0 0 2px var(--color-primary)}.cell-input::placeholder{font-weight:400;color:var(--color-text-muted);opacity:.5}.cell-changed{background:#4f46e514}[data-theme=dark] .cell-changed{background:#818cf81a}.cell-duplicate{background:#dc262614}[data-theme=dark] .cell-duplicate{background:#ef44441a}.default-cell{font-family:var(--font-mono);font-size:.875rem;color:var(--color-text-muted);text-align:center;opacity:.6}.r-colored-input{display:flex;align-items:center;justify-content:center;height:100%}.r-colored-input .cell-input{width:3rem;padding-right:0;text-align:right}.r-suffix{font-family:var(--font-mono);font-size:1.1rem;font-weight:600;color:var(--color-text-muted)}.stress-variant-row{background:var(--color-surface-hover)}.stress-variant-row .ipa-cell{font-size:.8rem;color:var(--color-text-muted)}.stress-label{font-family:var(--font-mono)!important;font-size:.75rem!important}.experiment-translator{padding:1.25rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:.5rem}.experiment-translator-header{display:flex;gap:.75rem;align-items:center;justify-content:space-between;margin-bottom:.75rem}.experiment-translator-header h3{margin:0;font-size:1rem}.experiment-input{width:100%;min-height:5rem;resize:vertical}.experiment-output{padding:1.75rem .75rem .75rem;margin-top:.75rem;background:var(--color-surface-hover);border-radius:.375rem}.experiment-output-label{margin-bottom:.5rem;font-size:.75rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.experiment-words{max-height:none;overflow-y:visible;font-size:1rem;line-height:1.6}.experiment-words .word-token:hover,.experiment-words .word-token.highlighted{color:inherit;background:transparent}.experiment-words [data-orig]:hover:after{left:0;max-width:min(30rem,90vw);overflow:hidden;text-overflow:ellipsis;transform:none}.experiment-words [data-orig]:hover:before{left:.5em;transform:none}.format-diff{text-decoration:underline dotted var(--color-primary);text-decoration-thickness:1.5px;text-underline-offset:.2em}.experiment-plain-output{margin-top:.75rem}.experiment-plain-text{font-family:var(--font-mono);font-size:.875rem;line-height:1.5;color:var(--color-text-muted);overflow-wrap:break-word;white-space:pre-wrap}.mapping-stats{padding:1.25rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:.5rem}.mapping-stats h3{margin-bottom:1rem;font-size:1rem}.stats-updating{font-size:.75rem;font-weight:400;color:var(--color-text-muted)}.stats-loading{font-size:.875rem;color:var(--color-text-muted)}.stats-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;margin-bottom:1rem}.stat-card{padding:.75rem;text-align:center;background:var(--color-surface-hover);border-radius:.375rem}.stat-value{font-size:1.5rem;font-weight:700;color:var(--color-text)}.stat-label{font-size:.75rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.stat-delta{margin-left:.25rem;font-size:.75rem;font-weight:600;vertical-align:super}.stat-delta-better{color:var(--color-success)}.stat-delta-worse{color:var(--color-error)}.stats-details{margin-top:.5rem;margin-bottom:.5rem}.stats-details summary{font-size:.8rem;color:var(--color-text-muted);cursor:pointer}.stats-details summary:hover{color:var(--color-text)}.stats-extra{display:flex;flex-direction:column;gap:.75rem;padding-top:.75rem}.stats-extra-row{padding:.5rem .625rem;background:var(--color-surface-hover);border-radius:.375rem}.stats-extra-header{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:.25rem}.stats-extra-name{font-size:.8rem;font-weight:600}.stats-extra-value{font-size:.95rem;font-weight:700}.stats-extra-desc{font-size:.75rem;line-height:1.4;color:var(--color-text-muted)}.stats-extra-link{font-size:.75rem}.top-changes{margin-top:1rem}.top-changes h4{margin-bottom:.5rem;font-size:.875rem;font-weight:600;color:var(--color-text-muted)}.changes-table{width:100%;overflow:hidden;border-collapse:collapse;background:var(--color-surface);border-radius:.5rem}.changes-table th,.changes-table td{padding:.5rem .75rem;text-align:left;border-bottom:1px solid var(--color-border)}.changes-table th{font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;background:var(--color-surface-hover)}.changes-table tr:last-child td{border-bottom:none}.top-collisions{margin-top:1rem}.top-collisions h4{margin-bottom:.5rem;font-size:.875rem;font-weight:600;color:var(--color-text-muted)}.collision-table th:nth-child(1){width:5rem}@media(max-width:768px){.experiment-grid{grid-template-columns:1fr}.experiment-right{position:static}.stats-cards{grid-template-columns:repeat(3,1fr)}.experiment-table th,.experiment-table td{padding:.5rem;font-size:.875rem}.cell-input{font-size:1rem}}@media(max-width:480px){.experiment-share-bar{flex-direction:column}}.word-explorer{max-width:800px;margin:0 auto}.explorer-input-row{display:flex;gap:.5rem;margin-bottom:1.5rem}.explorer-input{flex:1;padding:.75rem 1rem;font-size:1.1rem;color:var(--color-text);outline:none;background:var(--color-surface);border:2px solid var(--color-border);border-radius:.5rem;transition:border-color .15s}.explorer-input:focus{border-color:var(--color-primary)}.explorer-empty{padding:2rem;color:var(--color-text-muted);text-align:center}.suggestion-chips{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;margin-top:.75rem}.suggestion-chip{padding:.375rem .75rem;font-size:.9rem;color:var(--color-text);cursor:pointer;background:var(--color-surface);border:1px solid var(--color-border);border-radius:1rem;transition:background .15s,border-color .15s}.suggestion-chip:hover{background:var(--color-surface-hover);border-color:var(--color-primary)}.word-card{padding:1.5rem;margin-bottom:1.5rem;overflow:hidden;background:var(--color-surface);border:1px solid var(--color-border);border-radius:.75rem}.word-card-header{display:flex;flex-wrap:wrap;gap:1rem;align-items:baseline;justify-content:space-between;margin-bottom:.75rem}.word-main{display:flex;flex-wrap:wrap;gap:.5rem;align-items:baseline;min-width:0}.word-english{font-size:1.5rem;font-weight:700;overflow-wrap:anywhere}.word-arrow{font-size:1.25rem;color:var(--color-text-muted)}.word-translated{font-size:1.5rem;font-weight:700;color:var(--color-primary);overflow-wrap:anywhere}.word-ipa{font-family:var(--font-mono);font-size:1.1rem;color:var(--color-text-muted);overflow-wrap:anywhere}.word-meta{display:flex;flex-wrap:wrap;gap:.375rem;margin-bottom:1rem}.badge{display:inline-block;padding:.2rem .5rem;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em;border-radius:.25rem}.badge-dict{color:var(--color-success);background:#16a34a1a}.badge-fallback{color:var(--color-warning);background:#eab30826}.badge-freq{color:var(--color-text-muted);background:var(--color-surface-hover)}.badge-homo{color:var(--color-primary);background:#4f46e51a}.explorer-section{margin-top:1.25rem}.explorer-section h4{margin-bottom:.5rem;font-size:.875rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.section-note{margin-bottom:.5rem;font-size:.85rem;color:var(--color-text-muted)}.chain-table{width:100%;font-size:.9rem;border-collapse:collapse}.chain-table th{padding:.375rem .75rem;font-size:.75rem;font-weight:600;color:var(--color-text-muted);text-align:left;text-transform:uppercase;letter-spacing:.05em;border-bottom:2px solid var(--color-border)}.chain-table td{padding:.375rem .75rem;border-bottom:1px solid var(--color-border)}.chain-table .mono{font-family:var(--font-mono)}.chain-table .highlight{font-weight:600;color:var(--color-primary)}.chain-table .type-label{font-size:.8rem;color:var(--color-text-muted)}.chain-table .rule-code{font-size:.8rem;color:var(--color-text-muted);white-space:nowrap}.vowel-row{background:#4f46e50a}[data-theme=dark] .vowel-row{background:#818cf80f}.format-comparison{display:flex;flex-wrap:wrap;gap:1.5rem}.format-item{display:flex;flex-direction:column;gap:.25rem}.format-label{font-size:.75rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.format-value{font-size:1.1rem}.format-value.mono{font-family:var(--font-mono)}.homophone-list{display:flex;flex-wrap:wrap;gap:.375rem}.homophone-chip{display:inline-flex;gap:.25rem;align-items:center;padding:.3rem .6rem;font-size:.85rem;color:var(--color-text);cursor:pointer;background:var(--color-surface);border:1px solid var(--color-border);border-radius:.375rem;transition:background .15s,border-color .15s}.homophone-chip:hover{background:var(--color-surface-hover);border-color:var(--color-primary)}.chip-english{font-weight:600}.chip-arrow{font-size:.75rem;color:var(--color-text-muted)}.chip-translated{font-family:var(--font-mono);color:var(--color-primary)}.chip-freq{margin-left:.125rem;font-size:.7rem;color:var(--color-text-muted)}.more-count{padding:.3rem .5rem;font-size:.85rem;color:var(--color-text-muted)}@media(max-width:640px){.word-card-header{flex-direction:column;gap:.25rem}.word-english,.word-translated{font-size:1.25rem}.explorer-input-row{flex-direction:column}.format-comparison{flex-direction:column;gap:.75rem}}.challenge-page{max-width:640px;margin:0 auto}.challenge-intro{padding:2rem 0;text-align:center}.challenge-intro h2{margin-bottom:1rem;font-size:1.75rem}.challenge-intro p{margin-bottom:1.5rem;line-height:1.7;color:var(--color-text-muted)}.challenge-rules{padding:1.25rem;margin-bottom:2rem;text-align:left;background:var(--color-surface);border:1px solid var(--color-border);border-radius:.5rem}.challenge-rules li{margin-bottom:.5rem;margin-left:1.25rem;color:var(--color-text-muted)}.challenge-rules li:last-child{margin-bottom:0}.challenge-progress{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem;font-size:.875rem;color:var(--color-text-muted)}.challenge-progress-bar{flex:1;height:4px;margin:0 1rem;overflow:hidden;background:var(--color-border);border-radius:2px}.challenge-progress-fill{height:100%;background:var(--color-primary);border-radius:2px;transition:width .3s ease}.challenge-timer{min-width:2.5rem;font-size:.875rem;font-weight:700;font-variant-numeric:tabular-nums;color:var(--color-text-muted);text-align:center;transition:color .2s}.challenge-timer-warning{color:var(--color-error);animation:timer-pulse 1s ease-in-out infinite}@keyframes timer-pulse{0%,to{opacity:1}50%{opacity:.5}}.challenge-tier-badge{padding:.2rem .5rem;font-size:.75rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;background:var(--color-surface-hover);border-radius:.25rem}.challenge-sentence-card{padding:1.5rem;margin-bottom:1.5rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:.75rem}.challenge-sentence-label{margin-bottom:.75rem;font-size:.75rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.challenge-sentence-text{font-size:1.25rem;font-weight:500;line-height:1.6}.challenge-input-area{margin-bottom:1rem}.challenge-input{width:100%;padding:.75rem 1rem;font-family:var(--font-sans);font-size:1rem;color:var(--color-text);background:var(--color-surface);border:1px solid var(--color-border);border-radius:.5rem;transition:border-color .2s}.challenge-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #4f46e526}.challenge-input:disabled{opacity:.6}.challenge-actions{display:flex;gap:.5rem;justify-content:flex-end}.challenge-feedback{padding:1rem;margin-top:1rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:.5rem}.challenge-feedback-score{margin-bottom:.75rem;font-weight:600}.challenge-feedback-words{display:flex;flex-wrap:wrap;gap:.5rem;line-height:1.8}.challenge-word{display:inline-flex;flex-direction:column;gap:.125rem;align-items:center}.challenge-word-ingglish{font-size:.7rem;color:var(--color-text-muted)}.challenge-word-result{padding:.2rem .4rem;font-size:.9rem;border-radius:.25rem}.challenge-word-correct{color:var(--color-success);background:#22c55e26}.challenge-word-fuzzy{color:var(--color-warning, #ca8a04);background:#eab30826}.challenge-word-incorrect{color:var(--color-error);text-decoration:line-through;background:#ef444426}.challenge-word-expected{font-size:.75rem;font-weight:500;color:var(--color-error)}.challenge-results{padding:2rem 0;text-align:center}.challenge-results h2{margin-bottom:.5rem;font-size:1.75rem}.challenge-overall-score{margin-bottom:.5rem;font-size:3rem;font-weight:700;color:var(--color-primary)}.challenge-score-label{margin-bottom:2rem;color:var(--color-text-muted)}.challenge-round-bars{display:flex;flex-direction:column;gap:.5rem;margin-bottom:2rem;text-align:left}.challenge-round-row{display:flex;gap:.75rem;align-items:center;font-size:.875rem}.challenge-round-label{flex-shrink:0;width:5rem;color:var(--color-text-muted)}.challenge-round-bar{flex:1;height:1.25rem;overflow:hidden;background:var(--color-surface-hover);border-radius:.25rem}.challenge-round-fill{height:100%;border-radius:.25rem;transition:width .5s ease}.challenge-round-fill-good{background:var(--color-success)}.challenge-round-fill-ok{background:#eab308}.challenge-round-fill-bad{background:var(--color-error)}.challenge-round-pct{width:3rem;font-size:.8rem;font-weight:600;text-align:right}.challenge-round-time{width:2.5rem;font-size:.75rem;font-variant-numeric:tabular-nums;color:var(--color-text-muted);text-align:right}.challenge-result-actions{display:flex;flex-wrap:wrap;gap:.75rem;justify-content:center}@media(max-width:640px){.challenge-page{padding:0 .5rem}.challenge-sentence-text{font-size:1.1rem}.challenge-overall-score{font-size:2.5rem}}
