:root{--color-bg: #f6f3ee;--color-bg-strong: #efe8df;--color-panel: rgba(255, 253, 250, .94);--color-panel-muted: rgba(252, 249, 245, .96);--color-border: rgba(99, 74, 49, .16);--color-border-strong: rgba(99, 74, 49, .26);--color-text: #1f2933;--color-text-soft: #4e5d6c;--color-text-muted: #6e7f90;--color-ink-inverse: #fffdf9;--color-accent: #de7a3c;--color-accent-strong: #9f4b17;--color-success: #2f855a;--color-danger: #c05621;--color-info: #2563eb;--radius-sm: .85rem;--radius-md: 1.05rem;--radius-lg: 1.35rem;--radius-xl: 1.7rem;--radius-pill: 999px;--shadow-card: 0 8px 24px rgba(56, 37, 21, .08);--shadow-glow: 0 8px 20px rgba(159, 75, 23, .16);--font-display: "SUIT Variable", "Pretendard Variable", "Segoe UI", sans-serif;--font-body: "Pretendard Variable", "Noto Sans KR", "Apple SD Gothic Neo", sans-serif;--content-max: 1180px}*,*:before,*:after{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;min-width:320px}button,input,textarea,select{font:inherit}img{display:block;max-width:100%}a{color:inherit;text-decoration:none}body{font-family:var(--font-body);color:var(--color-text);background:radial-gradient(circle at top left,rgba(255,206,166,.42),transparent 26%),radial-gradient(circle at top right,rgba(135,206,235,.18),transparent 24%),linear-gradient(180deg,var(--color-bg),#fbfaf7 58%,var(--color-bg-strong))}#root{min-height:100vh}.app-frame{width:min(100% - 2rem,var(--content-max));margin:0 auto;padding:1.25rem 0 2rem}.section-intro{display:grid;gap:.45rem}.section-intro p,.section-intro h1,.section-intro h2{margin:0}.section-intro p{color:var(--color-text-soft);line-height:1.6}.eyebrow{color:var(--color-accent-strong);font-size:.78rem;font-weight:800;letter-spacing:.16em;text-transform:uppercase}.chip-row,.stats-row{display:flex;flex-wrap:wrap;gap:.7rem}.chip{display:inline-flex;align-items:center;justify-content:center;min-height:2.2rem;padding:.55rem .85rem;border-radius:var(--radius-pill);background:#ff8c421f;color:var(--color-accent-strong);font-size:.88rem;font-weight:700}.metric-grid,.card-grid{display:grid;gap:1rem}@media(min-width:768px){.metric-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.card-grid--two{grid-template-columns:repeat(2,minmax(0,1fr))}.card-grid--three{grid-template-columns:repeat(3,minmax(0,1fr))}}.muted{color:var(--color-text-soft)}.stack-sm{display:grid;gap:.65rem}.stack-md{display:grid;gap:1rem}.stack-lg{display:grid;gap:1.5rem}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}.ui-button{min-height:2.85rem;padding:.72rem 1rem;border:1px solid transparent;border-radius:var(--radius-md);font:inherit;font-weight:700;letter-spacing:-.01em;transition:transform .18s ease,box-shadow .18s ease,background-color .18s ease,border-color .18s ease;cursor:pointer}.ui-button:hover:not(:disabled){transform:none}.ui-button:disabled{opacity:.55;cursor:not-allowed;transform:none}.ui-button--full{width:100%}.ui-button--primary{background:linear-gradient(135deg,color-mix(in srgb,var(--color-accent) 88%,#ffffff 12%),var(--color-accent-strong));color:var(--color-ink-inverse);border-color:color-mix(in srgb,var(--color-accent-strong) 36%,transparent);box-shadow:var(--shadow-glow)}.ui-button--secondary{background:var(--color-panel);color:var(--color-text);border:1px solid var(--color-border-strong)}.ui-button--ghost{background:transparent;color:var(--color-text-muted);border:1px solid var(--color-border)}.ui-card{display:grid;gap:.85rem;padding:1.15rem;border:1px solid var(--color-border);border-radius:var(--radius-xl);background:var(--color-panel);box-shadow:var(--shadow-card)}.ui-card--accent{background:radial-gradient(circle at top right,rgba(222,122,60,.12),transparent 46%),var(--color-panel);border-color:#de7a3c4d}.ui-card--soft{background:var(--color-panel-muted)}.ui-card__eyebrow{margin:0;color:var(--color-accent-strong);font-size:.78rem;font-weight:800;letter-spacing:.16em;text-transform:uppercase}.ui-card__title{margin:0;font-size:1.12rem;line-height:1.2;letter-spacing:-.03em}.progress-bar{display:grid;gap:.55rem}.progress-bar__head{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.progress-bar__head strong,.progress-bar__head span{font-size:.95rem}.progress-bar__head span{color:var(--color-text-muted)}.progress-bar__track{height:.7rem;overflow:hidden;border-radius:999px;background:#1e293b14}.progress-bar__fill{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--color-accent-strong),var(--color-accent))}.progress-bar__helper{margin:0;color:var(--color-text-soft);font-size:.88rem;line-height:1.55}.assessment-page{display:grid;gap:1.25rem}.assessment-page__actions{display:flex;flex-wrap:wrap;gap:.85rem;align-items:center}.assessment-page__list{margin:0;padding-left:1.1rem;color:var(--color-text-soft);line-height:1.7}.assessment-page__question-stack,.assessment-page__result-stack,.assessment-page__feedback-list{display:grid;gap:1rem}.assessment-page__question{display:grid;gap:.9rem;padding:1rem;border-radius:var(--radius-lg);border:1px solid var(--color-border);background:#ffffff9e}.assessment-page__question-head{display:grid;gap:.35rem}.assessment-page__question-head span{color:var(--color-accent-strong);font-size:.82rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.assessment-page__question-head strong{font-size:1rem;line-height:1.55}.assessment-page__option-grid,.assessment-page__insight-grid{display:grid;gap:.75rem}.assessment-page__option{display:grid;grid-template-columns:auto 1fr;gap:.8rem;align-items:start;width:100%;padding:.9rem 1rem;border:1px solid var(--color-border);border-radius:var(--radius-lg);background:#ffffffdb;text-align:left;color:var(--color-text);transition:transform .16s ease,border-color .16s ease,background-color .16s ease}.assessment-page__option span{display:inline-flex;align-items:center;justify-content:center;width:2rem;height:2rem;border-radius:50%;background:#ff8c4224;color:var(--color-accent-strong);font-weight:800}.assessment-page__option strong{line-height:1.5}.assessment-page__option:hover{transform:translateY(-1px)}.assessment-page__option.is-active{border-color:#ff8c426b;background:#fff5ecfa;box-shadow:var(--shadow-glow)}.assessment-page__textarea{min-height:10rem;padding:1rem;border:1px solid var(--color-border);border-radius:var(--radius-lg);background:#fffffff0;color:var(--color-text);resize:vertical}.assessment-page__result-hero{display:grid;gap:1rem}.assessment-page__lottie-wrap{width:min(100%,12rem);justify-self:end;border-radius:var(--radius-lg);border:1px solid rgba(255,140,66,.22);background:#ffffffb8;min-height:8rem;overflow:hidden}.assessment-page__lottie-wrap canvas{width:100%!important;height:100%!important}.assessment-page__lottie-skeleton{width:100%;min-height:8rem;background:radial-gradient(circle at 30% 28%,#fff1e6eb,#ffb2784d),#ffffffb3}.assessment-page__score-label{display:block;color:var(--color-text-soft);font-size:.86rem;text-transform:uppercase;letter-spacing:.08em}.assessment-page__score-value{display:block;font-size:clamp(2.6rem,7vw,4.5rem);line-height:.95;letter-spacing:-.05em}.assessment-page__insight{display:grid;gap:.55rem;padding:.95rem 1rem;border-radius:var(--radius-lg);background:#ffffffad;border:1px solid var(--color-border)}.assessment-page__insight p{margin:0;color:var(--color-text-soft);line-height:1.6}.assessment-page__insight-head{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.assessment-page__insight-head span{color:var(--color-accent-strong);font-weight:800}.assessment-page__feedback-item{display:grid;gap:.35rem;padding:.95rem 1rem;border-radius:var(--radius-lg);border:1px solid var(--color-border);background:#ffffffb3}.assessment-page__feedback-item p,.assessment-page__feedback-item strong{margin:0}.assessment-page__feedback-item strong{line-height:1.4}.assessment-page__feedback-item p{line-height:1.6}@media(min-width:900px){.assessment-page__option-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.assessment-page__result-hero{grid-template-columns:.4fr minmax(0,1fr) auto;align-items:center}.assessment-page__insight-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:899px){.assessment-page__lottie-wrap{justify-self:start;width:min(100%,10rem)}}.provider-page{display:grid;gap:1rem}.provider-page__header{display:flex;flex-wrap:wrap;justify-content:space-between;gap:.8rem;padding:1rem;border:1px solid var(--color-border);border-radius:var(--radius-xl);background:linear-gradient(160deg,#faf6f0f2,#ffffffeb)}.provider-page__header h2,.provider-page__header p{margin:0}.provider-page__header-meta{display:grid;gap:.35rem;align-content:start;justify-items:end;color:var(--color-text-soft);font-size:.9rem}.provider-page__tabs{display:flex;gap:.55rem;flex-wrap:wrap}.provider-page__mode-row{display:flex;flex-wrap:wrap;gap:.45rem}.provider-page__mode-chip{min-height:2rem;padding:.35rem .7rem;border-radius:var(--radius-pill);border:1px solid var(--color-border);background:#ffffffbf;color:var(--color-text-soft);font-size:.82rem;font-weight:700}.provider-page__mode-chip.is-active{border-color:#ff8c4270;background:#fff5ecf0;color:var(--color-accent-strong)}.provider-page__tab{min-height:2.3rem;padding:.45rem .85rem;border-radius:var(--radius-pill);border:1px solid var(--color-border);background:#ffffffbf;color:var(--color-text)}.provider-page__tab.is-active{border-color:#ff8c4266;background:#fff5ecf0;color:var(--color-accent-strong);font-weight:700}.provider-page__layout,.provider-page__board,.provider-page__content{display:grid;gap:1rem}.provider-page__board-card{gap:.7rem}.provider-page__board-toolbar{display:flex;justify-content:space-between;gap:.45rem;flex-wrap:wrap}.provider-page__refresh{display:inline-flex;align-items:center;gap:.28rem;min-height:2rem;padding:.35rem .62rem;border:1px solid var(--color-border);border-radius:var(--radius-pill);background:#ffffffc2;color:var(--color-text);font-size:.78rem;font-weight:700}.provider-page__extend-row{display:inline-flex;align-items:center;gap:.3rem}.provider-page__extend-row input{width:4rem;min-height:2rem;padding:.28rem .42rem;border:1px solid var(--color-border);border-radius:var(--radius-pill);background:#ffffffc7}.provider-page__add-day{display:inline-flex;align-items:center;gap:.26rem;min-height:2rem;padding:.34rem .62rem;border:1px solid rgba(255,140,66,.38);border-radius:var(--radius-pill);background:#fff5eceb;color:var(--color-accent-strong);font-size:.78rem;font-weight:700}.provider-page__day-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.5rem}.provider-page__day-card{display:grid;gap:.2rem;width:100%;padding:.65rem;text-align:left;border:1px solid var(--color-border);border-radius:var(--radius-md);background:#ffffffbd;color:var(--color-text)}.provider-page__day-card span{font-size:.86rem;color:var(--color-text-soft);line-height:1.35}.provider-page__day-card small{font-size:.72rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em}.provider-page__day-card.is-active{border-color:#ff8c425c;background:#fff5ecf0}.provider-page__form{display:grid;gap:.7rem}.provider-page__form label{display:grid;gap:.3rem;font-size:.92rem;color:var(--color-text)}.provider-page__form input,.provider-page__form textarea{width:100%;padding:.65rem .75rem;border:1px solid var(--color-border);border-radius:var(--radius-md);background:#ffffffd1;color:var(--color-text)}.provider-page__form textarea{min-height:4.5rem;resize:vertical}.provider-page__field-title{margin:0;font-size:.9rem;font-weight:700;color:var(--color-accent-strong)}.provider-page__validator{display:grid;gap:.65rem}.provider-page__actions{display:flex;flex-wrap:wrap;gap:.5rem}.provider-page__meta-inline{display:flex;flex-wrap:wrap;gap:.45rem;color:var(--color-text-soft);font-size:.82rem}.provider-page__upload-row{align-items:start}.provider-page__upload-row span{line-height:1.4;word-break:break-all}.provider-page__hook-tools{display:flex;gap:.45rem;flex-wrap:wrap;margin:.2rem 0}.provider-page__hook-tool-btn{min-height:1.9rem;padding:.3rem .62rem;border:1px solid var(--color-border);border-radius:var(--radius-pill);background:#ffffffd1;color:var(--color-text);font-size:.78rem;font-weight:700}.provider-page__preview{display:grid;gap:.45rem}.provider-page__preview p{margin:0}.provider-page__preview-lyrics{display:grid;gap:.28rem}.provider-page__preview-lyrics-head{display:flex;align-items:center;justify-content:space-between;gap:.55rem;flex-wrap:wrap}.provider-page__preview-toggle{display:inline-flex;gap:.35rem;padding:.18rem;border:1px solid var(--color-border);border-radius:var(--radius-pill);background:#ffffffc2}.provider-page__preview-toggle button{border:0;border-radius:var(--radius-pill);background:transparent;color:var(--color-text-soft);font-size:.78rem;font-weight:600;line-height:1;min-height:1.7rem;padding:.28rem .58rem}.provider-page__preview-toggle button.is-active{background:#ff8c4229;color:var(--color-accent-strong)}.provider-page__preview-lyrics-box{max-height:15rem;overflow:auto;display:grid;gap:.16rem;padding:.55rem .62rem;border:1px solid var(--color-border);border-radius:var(--radius-md);background:#ffffffb3}.provider-page__preview-lyrics-box p{margin:0;line-height:1.35;font-size:.86rem}.provider-page__preview-lyrics-line.is-clamped{display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2;overflow:hidden}.provider-page__finding-summary{display:flex;flex-wrap:wrap;gap:.6rem}.provider-page__finding-list{margin:0;padding-left:1.1rem;display:grid;gap:.3rem}.provider-page__finding-list li.is-error{color:#b42318}.provider-page__finding-list li.is-warn{color:#b54708}.provider-page__analytics{display:grid;gap:.9rem}.provider-page__msg-error{color:#b42318}.provider-page__msg-success{color:#12663d}@media(min-width:980px){.provider-page__layout{grid-template-columns:minmax(290px,340px) minmax(0,1fr);align-items:start}.provider-page__board{position:sticky;top:.8rem}.provider-page__day-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.provider-page__analytics{grid-template-columns:repeat(2,minmax(0,1fr))}}.grammar-layout{display:grid;gap:1rem}.grammar-editor{display:grid;gap:.8rem}.grammar-editor textarea{min-height:10rem;padding:1rem;border:1px solid var(--color-border);border-radius:var(--radius-lg);background:#ffffffdb;resize:vertical}.grammar-feedback__pair,.grammar-feedback__versions{display:grid;gap:.8rem}.grammar-feedback__pair span,.grammar-feedback__versions strong{display:block;margin-bottom:.35rem;color:var(--color-accent-strong)}.grammar-feedback__pair p,.grammar-feedback__versions p,.grammar-feedback__why{margin:0;line-height:1.65}.grammar-feedback__corrected{font-size:1.05rem;font-weight:700}.grammar-feedback__why{padding:1rem;border-radius:var(--radius-md);background:#ff8c4214;color:var(--color-text-soft)}.grammar-feedback__versions article{padding:1rem;border-radius:var(--radius-md);background:#fff9}@media(min-width:900px){.grammar-layout{grid-template-columns:.95fr 1.05fr;align-items:start}.grammar-feedback__pair,.grammar-feedback__versions{grid-template-columns:repeat(2,minmax(0,1fr))}}.grammar-page{display:grid;gap:1.25rem}.ui-bottom-sheet__backdrop{position:fixed;inset:0;z-index:60;background:#0f172a6b;display:grid;align-items:end}.ui-bottom-sheet{background:#fff;border-top-left-radius:1rem;border-top-right-radius:1rem;padding:.85rem .9rem max(.9rem,env(safe-area-inset-bottom));box-shadow:0 -8px 30px #0f172a29;max-height:min(70vh,620px);display:grid;gap:.6rem}.ui-bottom-sheet__head{display:flex;align-items:center;justify-content:space-between;gap:.6rem}.ui-bottom-sheet__head p{margin:0;font-size:.95rem;font-weight:700;color:var(--color-text)}.ui-bottom-sheet__body{overflow:auto;display:grid;gap:.55rem;padding-bottom:.2rem}.home-dashboard{display:grid;gap:.85rem}.home-dashboard__hero{gap:.7rem}.home-dashboard__hero-title{margin:0;font-size:clamp(1.35rem,5vw,1.9rem);letter-spacing:-.03em;line-height:1.15}.home-dashboard__hero-description{margin:0;color:var(--color-text-soft);line-height:1.55}.home-dashboard__hero-meta{display:grid;gap:.4rem;grid-template-columns:repeat(3,minmax(0,1fr))}.home-dashboard__hero-meta span{display:inline-flex;align-items:center;gap:.3rem;min-height:2rem;padding:.36rem .52rem;border:1px solid rgba(99,74,49,.18);border-radius:var(--radius-sm);background:#ffffffc7;font-size:.76rem;color:var(--color-text-soft)}.home-dashboard__hero-cta{margin-top:.15rem}.home-dashboard__status-card{gap:.7rem}.home-dashboard__status-grid{display:grid;gap:.45rem;grid-template-columns:repeat(2,minmax(0,1fr))}.home-dashboard__status-grid article{display:grid;gap:.14rem;padding:.65rem .7rem;border-radius:var(--radius-md);border:1px solid var(--color-border);background:#ffffffc7}.home-dashboard__status-grid article span{font-size:.76rem;color:var(--color-text-soft)}.home-dashboard__status-grid article strong{font-size:.94rem;letter-spacing:-.01em}.home-dashboard__stepper{display:grid;gap:.5rem;margin:0;padding:0;list-style:none}.home-dashboard__stepper li{display:grid;grid-template-columns:auto minmax(0,1fr);gap:.55rem;align-items:start;padding:.62rem;border-radius:var(--radius-md);border:1px solid var(--color-border);background:#ffffffbd}.home-dashboard__step-index{display:inline-flex;align-items:center;justify-content:center;width:1.55rem;height:1.55rem;border-radius:999px;background:#de7a3c26;color:var(--color-accent-strong);font-size:.8rem;font-weight:800}.home-dashboard__stepper strong{display:block;margin-bottom:.2rem;font-size:.9rem}.home-dashboard__stepper p{margin:0;color:var(--color-text-soft);font-size:.84rem;line-height:1.45}.home-dashboard__review-list{display:grid;gap:.48rem}.home-dashboard__review-title{margin:0;font-size:.86rem;color:var(--color-text-soft)}.home-dashboard__review-list ul{margin:0;padding-left:1rem;display:grid;gap:.32rem;color:var(--color-text)}.home-dashboard__review-list li{font-size:.87rem;line-height:1.45}.home-dashboard__review-weak{margin:0;color:var(--color-text-soft);font-size:.82rem}.home-dashboard__insight{display:grid;gap:.55rem;grid-template-columns:minmax(0,1fr) auto;align-items:center}.home-dashboard__insight p{margin:0;color:var(--color-text-soft);line-height:1.45;font-size:.86rem}.home-dashboard__insight-chart{display:grid;gap:.3rem;grid-template-columns:repeat(5,minmax(0,1fr))}.home-dashboard__insight-chart span{min-width:1.8rem;text-align:center;padding:.28rem .35rem;border-radius:var(--radius-sm);border:1px solid var(--color-border);background:#fffc;font-size:.74rem;color:var(--color-text-soft)}.home-dashboard__insight-chart span.is-done{border-color:#de7a3c4d;background:#fff5ece6;color:var(--color-accent-strong)}.home-dashboard__accordion-wrap{gap:.6rem}.home-dashboard__accordion{border:1px solid var(--color-border);border-radius:var(--radius-md);background:#ffffffbd;overflow:hidden}.home-dashboard__accordion>button{display:flex;align-items:center;justify-content:space-between;width:100%;min-height:2.4rem;padding:.52rem .62rem;border:none;background:transparent;font-size:.88rem;font-weight:700;color:var(--color-text)}.home-dashboard__accordion-content{display:grid;gap:.48rem;padding:.05rem .62rem .62rem;border-top:1px solid rgba(99,74,49,.12)}.home-dashboard__accordion-content p{margin:0;color:var(--color-text-soft);font-size:.84rem;line-height:1.45}.home-dashboard__settings-actions{display:flex;flex-wrap:wrap;gap:.4rem}.home-dashboard__level-row{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.38rem}.home-dashboard__level-row button{display:grid;gap:.08rem;padding:.52rem .45rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:#fffc;text-align:left}.home-dashboard__level-row button strong{font-size:.84rem;color:var(--color-text)}.home-dashboard__level-row button span{font-size:.74rem;color:var(--color-text-soft)}.home-dashboard__level-row button.is-active{border-color:#de7a3c66;background:#fff5eceb}.home-dashboard__level-row button:disabled{opacity:.48;cursor:not-allowed}.home-dashboard__mode-sheet{display:grid;gap:.36rem;grid-template-columns:repeat(2,minmax(0,1fr))}.home-dashboard__mode-sheet button{display:grid;gap:.1rem;width:100%;min-height:3.05rem;padding:.5rem .62rem;border:1px solid var(--color-border);border-radius:var(--radius-md);background:#ffffffdb;text-align:left}.home-dashboard__mode-sheet button strong{font-size:.84rem;color:var(--color-text)}.home-dashboard__mode-sheet button span{font-size:.72rem;color:var(--color-text-soft)}.home-dashboard__mode-sheet button.is-active{border-color:#de7a3c73;background:#fff5ecf2}.home-dashboard__mode-sheet-modal{width:min(100%,760px);justify-self:center;max-height:min(56vh,440px)}.home-dashboard__desktop-hint{display:none}@media(min-width:980px){.home-dashboard{gap:1rem}.home-dashboard__hero-meta{max-width:38rem}.home-dashboard__status-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.home-dashboard__desktop-hint{display:inline-flex;align-items:center;gap:.35rem;color:var(--color-text-muted);font-size:.8rem}}@media(max-width:680px){.home-dashboard__hero-meta,.home-dashboard__insight{grid-template-columns:1fr}.home-dashboard__settings-actions .ui-button{width:100%}.home-dashboard__level-row,.home-dashboard__mode-sheet{grid-template-columns:1fr}.home-dashboard__mode-sheet-modal{width:100%;max-height:min(62vh,500px)}}.lesson-v2{display:grid;gap:12px;max-width:720px;margin:0 auto;padding-bottom:84px}.lesson-v2__header{display:grid;gap:6px}.lesson-v2__header h2{margin:0}.lesson-v2__eyebrow{margin:0;font-size:12px;color:#667085}.lesson-v2__step{margin:0;font-size:13px;color:#667085}.lesson-v2__progress{height:6px;border-radius:999px;background:#eaecf0;overflow:hidden}.lesson-v2__progress span{display:block;height:100%;background:#1570ef}.lesson-v2__row{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.lesson-v2__speed{display:flex;gap:8px;margin:10px 0}.lesson-v2__speed button{border:1px solid #d0d5dd;border-radius:999px;background:#fff;padding:6px 12px;font-size:13px}.lesson-v2__speed button.is-active{border-color:#1570ef;color:#1570ef;font-weight:700}.lesson-v2__transcript{border-top:1px solid #eaecf0;padding-top:10px;display:grid;gap:6px}.lesson-v2__chunk-list,.lesson-v2__recall-item{display:grid;gap:10px}.lesson-v2__chunk-item{border:1px solid #eaecf0;border-radius:10px;padding:10px}.lesson-v2__ok{margin:0;color:#087443;font-size:13px;font-weight:700}.lesson-v2 textarea{width:100%;min-height:88px;border:1px solid #d0d5dd;border-radius:10px;padding:10px;font:inherit}.lesson-v2__song-actions{margin:10px 0}.lesson-v2__audio{width:100%}.lesson-v2__lyrics{margin-top:10px;display:grid;gap:6px}.lesson-v2__lyrics p{margin:0;color:#667085}.lesson-v2__lyrics p.is-active{color:#101828;font-weight:700}.lesson-v2__feedback{border-top:1px solid #eaecf0;margin-top:10px;padding-top:10px;display:grid;gap:6px}.lesson-v2__live-stt{margin:0;color:#1570ef;font-size:13px}.lesson-v2__error{margin:0;color:#b42318;font-size:13px}.lesson-v2__footer{position:sticky;bottom:0;display:flex;gap:8px;justify-content:space-between;padding:10px;border:1px solid #eaecf0;border-radius:14px;background:#fffffff5;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}@media(max-width:640px){.lesson-v2{gap:10px;padding-bottom:92px}.lesson-v2__row{gap:6px}.lesson-v2__footer{border-radius:12px}}.listening-layout{display:grid;gap:1rem}.listening-player__sentence{margin:0;font-size:1.2rem;line-height:1.55;letter-spacing:-.02em}.listening-player__actions{display:flex;gap:.75rem;flex-wrap:wrap}.listening-player__browser-tip{display:grid;gap:.55rem;padding:.95rem;border-radius:var(--radius-lg);border:1px solid rgba(255,140,66,.45);background:#fff6ebf2}.listening-player__browser-tip p{margin:0;line-height:1.55}.listening-player__browser-tip-actions{display:flex;flex-wrap:wrap;gap:.5rem}.listening-player__voice-panel{display:grid;gap:.75rem;padding:.95rem;border:1px solid var(--color-border);border-radius:var(--radius-lg);background:#fff8f2d6}.listening-player__voice-grid{display:grid;gap:.75rem}.listening-player__field{display:grid;gap:.45rem}.listening-player__field span{font-size:.9rem;font-weight:700;color:var(--color-text-soft)}.listening-player__field select{width:100%;padding:.85rem 1rem;border:1px solid var(--color-border);border-radius:var(--radius-md);background:#fffffff5;color:var(--color-text)}.listening-player__field select:disabled{cursor:not-allowed;opacity:.6}.listening-player__voice-note{margin:0;font-size:.94rem;color:var(--color-text-soft);line-height:1.55}.listening-player__note,.dictation-box__meta span{margin:0;color:var(--color-text-soft);line-height:1.55}.dictation-box{display:grid;gap:.8rem}.dictation-box textarea{min-height:9rem;padding:1rem;border:1px solid var(--color-border);border-radius:var(--radius-lg);background:#ffffffdb;color:var(--color-text);resize:vertical}.dictation-box__meta{display:grid;gap:.35rem}.choice-grid{display:grid;gap:.7rem}.choice-button{display:flex;align-items:center;justify-content:space-between;gap:.6rem;width:100%;padding:1rem;border:1px solid var(--color-border);border-radius:var(--radius-lg);background:#ffffffb8;text-align:left;color:var(--color-text)}.choice-button.is-active{border-color:#ff8c4257;background:#fff5eceb}.choice-button.is-correct{border-color:#67aa6f8c;background:#eaf8ecf5}.choice-button.is-wrong{border-color:#d6717173;background:#fff2f2eb}.choice-button__badge{display:inline-flex;align-items:center;padding:.24rem .62rem;border-radius:var(--radius-pill);background:#5a9c6624;color:#2f6b2f;font-size:.8rem;font-weight:700}.listening-step-progress{display:flex;flex-wrap:wrap;gap:.45rem;margin-top:.9rem}.listening-step-progress .chip{opacity:.72}.listening-step-progress .chip.is-done{opacity:1;border:1px solid rgba(103,170,111,.45);background:#eaf8ecf5;color:#2f6b2f}.listening-step-progress .chip.is-current{opacity:1;border:1px solid rgba(255,140,66,.35);background:#fff5ecf5;color:var(--color-accent-strong)}.meaning-feedback-box{display:grid;gap:.35rem;margin-top:.75rem;padding:.9rem;border-radius:var(--radius-lg);border:1px solid var(--color-border)}.meaning-feedback-box p{margin:0;line-height:1.55}.meaning-feedback-box.is-success{border-color:#67aa6f73;background:#eaf8ecf0;animation:meaning-success-pop .22s ease-out}.meaning-feedback-box.is-retry{border-color:#ffa64261;background:#fff9ecf0}.meaning-react-box{margin-top:.75rem}@keyframes meaning-success-pop{0%{transform:translateY(4px) scale(.99);opacity:.2}to{transform:translateY(0) scale(1);opacity:1}}@media(min-width:900px){.listening-layout{grid-template-columns:1.05fr .95fr;align-items:start}.listening-player__voice-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.listening-player__field--wide{grid-column:1/-1}}.listening-page{display:grid;gap:1.25rem}.pronunciation-layout{display:grid;gap:1rem}.pronunciation-recorder__copy{display:grid;gap:.45rem}.pronunciation-recorder__copy p{margin:0}.pronunciation-recorder__sentence{font-family:var(--font-display);font-size:clamp(1.25rem,2vw,1.6rem);line-height:1.35;letter-spacing:-.03em}.pronunciation-recorder__status{display:flex;align-items:center;justify-content:space-between;gap:.8rem;flex-wrap:wrap}.status-pill{display:inline-flex;align-items:center;min-height:2.4rem;padding:.55rem .85rem;border-radius:var(--radius-pill);font-size:.9rem;font-weight:700}.status-pill--neutral{background:#2563eb14;color:var(--color-info)}.status-pill--success{background:#2f855a1a;color:var(--color-success)}.status-pill--warning{background:#c056211a;color:var(--color-danger)}.pronunciation-recorder__note,.pronunciation-feedback__headline p,.pronunciation-feedback__action{margin:0;color:var(--color-text-soft);line-height:1.6}.pronunciation-recorder__actions{display:flex;gap:.75rem;flex-wrap:wrap}.pronunciation-recorder__audio{width:100%}.pronunciation-feedback__headline{display:flex;align-items:end;justify-content:space-between;gap:1rem;flex-wrap:wrap}.pronunciation-feedback__headline strong{font-size:clamp(2rem,5vw,3rem);letter-spacing:-.05em}.pronunciation-feedback__label{font-size:.98rem}.pronunciation-feedback__list{margin:0;padding-left:1.1rem;color:var(--color-text-soft);line-height:1.65}.pronunciation-feedback__action{padding:1rem;border-radius:var(--radius-md);background:#ff8c4214;color:var(--color-accent-strong);font-weight:700}@media(min-width:900px){.pronunciation-layout{grid-template-columns:1.15fr .85fr;align-items:start}}.waveform{display:grid;grid-template-columns:repeat(18,minmax(0,1fr));align-items:end;gap:.35rem;min-height:7rem;padding:1rem;border-radius:var(--radius-lg);background:linear-gradient(180deg,#ffffffd9,#f6f3eff2),var(--color-panel-muted);border:1px solid rgba(255,140,66,.12)}.waveform span{display:block;border-radius:999px;background:linear-gradient(180deg,#ff8c4259,#1e293bcc);transition:height .12s ease}.waveform--active span{background:linear-gradient(180deg,var(--color-accent),var(--color-accent-strong))}.pronunciation-page{display:grid;gap:1.25rem}.review-page{display:grid;gap:.85rem}.review-page__lead{margin:0;color:var(--color-text-soft);line-height:1.55}.review-page__stats{display:grid;gap:.45rem;grid-template-columns:repeat(2,minmax(0,1fr))}.review-page__stats article{display:grid;gap:.14rem;padding:.62rem .68rem;border:1px solid var(--color-border);border-radius:var(--radius-md);background:#ffffffc7}.review-page__stats span{font-size:.76rem;color:var(--color-text-soft)}.review-page__stats strong{font-size:.92rem}.review-page__expression{display:grid;gap:.25rem}.review-page__expression p{margin:0;font-size:.96rem;color:var(--color-text)}.review-page__expression small{color:var(--color-text-soft);font-size:.79rem}.review-page__list{margin:0;padding:0;list-style:none;display:grid;gap:.45rem}.review-page__list li{display:grid;gap:.18rem;padding:.62rem;border:1px solid var(--color-border);border-radius:var(--radius-md);background:#ffffffc2}.review-page__list strong{font-size:.89rem;color:var(--color-text)}.review-page__list p{margin:0;color:var(--color-text-soft);line-height:1.45;font-size:.84rem}.review-page__queue-head{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin-bottom:.55rem}.review-page__queue-state{display:inline-flex;align-items:center;min-height:1.8rem;padding:.25rem .55rem;border-radius:var(--radius-pill);border:1px solid var(--color-border);background:#ffffffc7;color:var(--color-text-soft);font-size:.75rem;font-weight:700}.review-page__queue-state.is-ready{border-color:#2f855a47;background:#edfaf1d9;color:#1f6f46}.review-page__queue-state.is-error{border-color:#c55a2147;background:#fff5ede6;color:#9c4a1d}.review-page__reload{min-height:1.85rem;padding:.22rem .55rem;border:1px solid var(--color-border);border-radius:var(--radius-pill);background:#ffffffc7;color:var(--color-text);font-size:.74rem;font-weight:700}.review-page__actions{display:grid;gap:.45rem}.review-page__error-note{margin:0;display:inline-flex;align-items:center;gap:.3rem;color:#9c4a1d;font-size:.78rem}@media(min-width:980px){.review-page__stats{grid-template-columns:repeat(4,minmax(0,1fr))}.review-page__actions{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:640px){.review-page__queue-head{flex-direction:column;align-items:stretch}}.speaking-layout{display:grid;gap:1rem}.speaking-prompt__question{margin:0;font-size:clamp(1.15rem,2vw,1.45rem);line-height:1.5;letter-spacing:-.02em}.speaking-workbench{display:grid;gap:.8rem}.speaking-workbench textarea{min-height:11rem;padding:1rem;border:1px solid var(--color-border);border-radius:var(--radius-lg);background:#ffffffdb;resize:vertical}.speaking-workbench__speech-row{display:flex;flex-wrap:wrap;gap:.55rem;align-items:center}.speaking-workbench__speech-state{font-size:.9rem;color:var(--color-text-soft)}.speaking-feedback__block{display:grid;gap:.32rem;padding:.95rem 1rem;border:1px solid var(--color-border);border-radius:var(--radius-md);background:#ffffffad}.speaking-feedback__block p{margin:0;line-height:1.55}.speaking-feedback__block--accent{border-color:#ff8c4257;background:#fff5ecd1}.speaking-feedback__label{color:var(--color-accent-strong);font-weight:700;font-size:.82rem;letter-spacing:.04em;text-transform:uppercase}.speaking-feedback__grid{display:grid;gap:.9rem}.speaking-feedback__grid article{display:grid;gap:.35rem;padding:1rem;border-radius:var(--radius-md);background:#ffffff9e}.speaking-feedback__grid strong,.speaking-feedback__grid p{margin:0}.speaking-feedback__grid p{color:var(--color-text-soft);line-height:1.6}.speaking-feedback__rating-grid{display:grid;gap:.55rem;grid-template-columns:repeat(2,minmax(0,1fr))}.speaking-feedback__rating-item{display:flex;align-items:center;justify-content:space-between;padding:.7rem .82rem;border-radius:var(--radius-md);border:1px solid var(--color-border);background:#ffffffb8}.speaking-feedback__rating-item span{color:var(--color-text-soft);font-size:.88rem}.speaking-feedback__rating-item strong{font-size:.9rem}@media(min-width:900px){.speaking-layout{grid-template-columns:.95fr 1.05fr;align-items:start}.speaking-feedback__grid{grid-template-columns:repeat(2,minmax(0,1fr))}}.speaking-page{display:grid;gap:1.25rem}.speaking-page__section6{display:grid;gap:.9rem}.speaking-page__mode-actions{display:flex;flex-wrap:wrap;gap:.6rem}.speaking-page__step-card{display:grid;gap:.55rem;padding:.9rem;border-radius:var(--radius-lg);border:1px solid var(--color-border);background:#ffffffb3}.speaking-page__step-card p{margin:0;line-height:1.6}.speaking-page__step-title{font-size:.84rem;letter-spacing:.06em;text-transform:uppercase;color:var(--color-accent-strong);font-weight:700}.app-shell{display:grid;gap:.9rem;padding-bottom:calc(4.4rem + env(safe-area-inset-bottom))}.app-header{display:grid;grid-template-columns:minmax(0,1fr) auto auto;align-items:center;gap:.55rem;padding:.8rem .9rem;border:1px solid var(--color-border);border-radius:var(--radius-lg);background:linear-gradient(180deg,#fffdfaf5,#f7f2ecf0);box-shadow:var(--shadow-card)}.app-header__brand{display:grid;gap:.08rem;border:0;padding:0;background:transparent;text-align:left;cursor:pointer}.app-header__brand strong{font-size:1rem;letter-spacing:-.02em;text-transform:lowercase}.app-header__brand span{color:var(--color-text-soft);font-size:.76rem}.app-header__status{display:inline-flex;align-items:center;gap:.28rem;padding:.28rem .55rem;border-radius:var(--radius-pill);border:1px solid rgba(222,122,60,.3);background:#fff5ece0;color:var(--color-accent-strong);font-size:.75rem;font-weight:700}.app-header__menu-btn{display:inline-flex;align-items:center;justify-content:center;gap:.26rem;min-height:2.05rem;padding:.34rem .58rem;border:1px solid var(--color-border-strong);border-radius:var(--radius-md);background:#ffffffb8;color:var(--color-text);font-size:.78rem;font-weight:700}.app-header__menu-btn.is-open{border-color:#de7a3c61;background:#fff5ecf0}.app-header-menu{display:grid;gap:.7rem;padding:.9rem;border:1px solid var(--color-border);border-radius:var(--radius-lg);background:#fffdfaf2;box-shadow:var(--shadow-card)}.app-header-menu__title{margin:0;font-size:.84rem;font-weight:800;color:var(--color-accent-strong);letter-spacing:.08em;text-transform:uppercase}.app-header-menu__status{display:grid;gap:.35rem;grid-template-columns:repeat(3,minmax(0,1fr))}.app-header-menu__status span{padding:.45rem .55rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:#ffffffc7;font-size:.75rem;color:var(--color-text-soft)}.app-header-menu__list{display:grid;gap:.45rem}.app-header-menu__list button{display:grid;gap:.14rem;padding:.62rem .7rem;border:1px solid var(--color-border);border-radius:var(--radius-md);background:#ffffffc7;text-align:left}.app-header-menu__list strong{font-size:.88rem;color:var(--color-text)}.app-header-menu__list span{font-size:.78rem;color:var(--color-text-soft);line-height:1.45}.app-layout{display:grid;gap:.9rem}.app-sidebar{display:none}.app-main{display:grid;gap:1rem}.app-admin-auth{display:grid;gap:.6rem;padding:1rem;border:1px solid var(--color-border);border-radius:var(--radius-lg);background:#fffdfaf5;box-shadow:var(--shadow-card)}.app-admin-auth h2,.app-admin-auth p{margin:0}.app-admin-auth label{display:grid;gap:.3rem;font-size:.9rem;color:var(--color-text)}.app-admin-auth input{min-height:2.35rem;padding:.45rem .65rem;border:1px solid var(--color-border);border-radius:var(--radius-md);background:#ffffffd1;color:var(--color-text)}.app-admin-auth__actions{display:flex;flex-wrap:wrap;gap:.5rem}.app-admin-auth__actions button{min-height:2.15rem;padding:.38rem .75rem;border:1px solid var(--color-border-strong);border-radius:var(--radius-md);background:#ffffffd1;color:var(--color-text);font-weight:700}.app-admin-auth__help,.app-admin-auth__message{font-size:.84rem;color:var(--color-text-soft)}.app-bottom-nav{position:fixed;left:.6rem;right:.6rem;bottom:.55rem;z-index:60;display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:.3rem;padding:.34rem;border:1px solid var(--color-border);border-radius:var(--radius-lg);background:#fffdfaf0;box-shadow:0 12px 28px #3825152e;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.app-bottom-nav.is-hidden-on-lesson{display:none}.app-bottom-nav__item{min-height:2.25rem;border:1px solid transparent;border-radius:var(--radius-md);background:transparent;color:var(--color-text-soft);font-size:.78rem;font-weight:700}.app-bottom-nav__item.is-active{border-color:#de7a3c5c;background:#fff5eceb;color:var(--color-accent-strong)}.app-admin-fab{position:fixed;right:.8rem;bottom:calc(.32rem + env(safe-area-inset-bottom));z-index:70;border:none;border-radius:0;background:transparent;color:#757f8c94;font-size:.68rem;font-weight:500;min-height:auto;padding:.1rem .2rem;box-shadow:none;letter-spacing:.01em;text-decoration:none;text-underline-offset:.12rem}.app-admin-fab:hover{color:#616b78b8;text-decoration:underline}.app-admin-fab.is-active{color:#576372bd}@media(min-width:980px){.app-shell{padding-bottom:0}.app-layout{grid-template-columns:minmax(0,240px) minmax(0,1fr);align-items:start}.app-sidebar{position:sticky;top:1rem;display:grid;gap:.5rem;padding:.65rem;border:1px solid var(--color-border);border-radius:var(--radius-lg);background:#fffdfaf0;box-shadow:var(--shadow-card)}.app-sidebar__item{display:grid;gap:.14rem;padding:.62rem .68rem;border:1px solid var(--color-border);border-radius:var(--radius-md);background:#ffffffc7;text-align:left}.app-sidebar__item span{font-size:.88rem;color:var(--color-text);font-weight:700}.app-sidebar__item small{font-size:.76rem;color:var(--color-text-soft)}.app-sidebar__item.is-active{border-color:#de7a3c5c;background:#fff5eceb}.app-bottom-nav{display:none}.app-admin-fab{right:1rem;bottom:.72rem;font-size:.7rem}}@media(max-width:680px){.app-header{grid-template-columns:minmax(0,1fr) auto;grid-template-areas:"brand menu" "status status";gap:.45rem}.app-header__brand{grid-area:brand}.app-header__menu-btn{grid-area:menu}.app-header__status{grid-area:status;width:fit-content}.app-header-menu__status{grid-template-columns:1fr}.app-admin-fab{display:none}}
