:root{color:#17211c;background:#f6f2ea;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;--ink: #17211c;--muted: #68756d;--line: #d9d5ca;--paper: #fffdf7;--paper-strong: #ffffff;--green: #1f6f58;--green-soft: #dfeee8;--blue: #1c5f91;--blue-soft: #e0edf7;--red: #b74b43;--gold: #9c6b16;--shadow: 0 18px 45px rgba(45, 40, 30, .11)}*{box-sizing:border-box}body{margin:0;min-width:320px;overflow-x:hidden}button,textarea,input{font:inherit}input,select,textarea{font-size:16px}button{cursor:pointer}a{color:inherit}html{scroll-behavior:smooth}.appShell{min-height:100vh}.authShell{align-items:center;display:grid;min-height:100vh;padding:20px}.authPanel{background:var(--paper);border:1px solid var(--line);border-radius:8px;box-shadow:var(--shadow);display:grid;gap:16px;margin:0 auto;max-width:460px;padding:24px;width:100%}.authPanel h1{font-size:34px;line-height:1.1;margin:0}.authPanel p{color:var(--muted);line-height:1.6;margin:0}.authPanel small{color:var(--muted);line-height:1.45}.authTabs{background:#fbf9f2;border:1px solid var(--line);border-radius:8px;display:grid;gap:6px;grid-template-columns:repeat(2,minmax(0,1fr));padding:6px}.authTabs button{background:transparent;border:1px solid transparent;border-radius:8px;color:var(--muted);font-weight:900;min-height:38px}.authTabs button.active{background:var(--ink);border-color:var(--ink);color:#fffdf7}.authPanel label{display:grid;gap:8px}.authPanel label span{color:var(--muted);font-size:13px;font-weight:900}.authPanel input{background:#fffefa;border:1px solid var(--line);border-radius:8px;color:var(--ink);min-height:44px;outline:none;padding:10px 12px;width:100%}.authPanel input:focus{border-color:var(--blue);box-shadow:0 0 0 3px #1c5f911f}.topbar{align-items:center;border-bottom:1px solid var(--line);display:flex;gap:24px;justify-content:space-between;padding:22px 28px}.topbar h1,.chapterHero h2,.sectionTitle h2,.comingSoon h2{letter-spacing:0;line-height:1.08;margin:0}.topbar h1{font-size:clamp(26px,3vw,42px)}.eyebrow{color:var(--gold);font-size:12px;font-weight:800;letter-spacing:.08em;margin:0 0 8px;text-transform:uppercase}.topStats{display:grid;gap:10px;grid-template-columns:repeat(4,minmax(76px,1fr));min-width:410px}.stat{background:var(--paper);border:1px solid var(--line);border-radius:8px;padding:10px 12px}.stat span,.chapterButton small,.taskItem small,.recordingList p,.sideBox p,.reviewItem small,.threeDayPreview small,.sourceList small{color:var(--muted)}.stat span{display:block;font-size:12px}.stat strong{display:block;font-size:20px;margin-top:2px}.logoutButton{background:var(--paper);border:1px solid var(--line);border-radius:8px;color:var(--muted);font-size:13px;font-weight:900;min-height:100%;padding:10px 12px}.layout{display:grid;gap:22px;grid-template-columns:340px minmax(0,1fr);padding:22px 28px 34px}.sidebar,.workPanel,.practicePanel,.comingSoon{min-width:0}.sidebar{align-self:start;background:#fffdf7b3;border:1px solid var(--line);border-radius:8px;max-height:calc(100vh - 120px);overflow:auto;padding:14px;position:sticky;top:18px}.panelHeader,.inlineTitle,.expressionTop,.reviewActions,.buttonRow,.chapterMeta,.promptItem{align-items:center;display:flex}.panelHeader,.inlineTitle{gap:8px}.panelHeader{color:var(--muted);font-weight:800;margin:2px 4px 12px}.chapterSwitcher{background:var(--paper-strong);border:1px solid var(--line);border-radius:8px;display:grid;gap:8px;margin-bottom:14px;padding:10px}.chapterSwitcher>span{color:var(--muted);font-size:12px;font-weight:900}.chapterSwitcher div{display:grid;gap:8px;grid-template-columns:repeat(2,minmax(0,1fr))}.chapterSwitcher button{background:#fbf9f2;border:1px solid var(--line);border-radius:8px;color:var(--muted);font-weight:900;min-height:38px}.chapterSwitcher button.active{background:var(--ink);border-color:var(--ink);color:#fffdf7}.chapterList{display:grid;gap:8px}.chapterButton{align-items:center;background:transparent;border:1px solid transparent;border-radius:8px;color:var(--ink);display:grid;gap:10px;grid-template-columns:34px minmax(0,1fr) 16px;padding:10px;text-align:left;text-decoration:none;width:100%}.chapterButton:hover,.chapterButton.active{background:var(--paper-strong);border-color:var(--line);box-shadow:0 8px 24px #322d2412}.chapterButton strong,.chapterButton small{display:block}.chapterButton strong{font-size:14px;line-height:1.25}.chapterButton small{font-size:12px;line-height:1.35;margin-top:4px}.chapterNumber{align-items:center;background:var(--green-soft);border-radius:999px;color:var(--green);display:inline-flex;font-weight:900;height:34px;justify-content:center;width:34px}.studyArea{display:grid;gap:16px;min-width:0}.chapterHero{align-items:end;background:linear-gradient(135deg,#fffdf7,#e7f1ed 55%,#e7eef5);border:1px solid var(--line);border-radius:8px;box-shadow:var(--shadow);display:grid;gap:20px;grid-template-columns:minmax(0,1fr) auto;min-height:178px;padding:24px}.chapterHero h2{font-size:clamp(26px,4vw,54px);max-width:820px}.chapterHero p{color:var(--muted);font-size:17px;line-height:1.6;margin:14px 0 0}.chapterMeta{align-items:stretch;flex-direction:column;gap:8px;min-width:210px}.chapterMeta span,.chapterMeta a{background:#ffffffb8;border:1px solid rgba(217,213,202,.88);border-radius:8px;color:var(--muted);font-size:13px;font-weight:750;padding:10px 12px;text-decoration:none}.chapterMeta a{align-items:center;color:var(--blue);display:flex;gap:6px;justify-content:space-between}.dayTabs{background:var(--paper);border:1px solid var(--line);border-radius:8px;display:grid;gap:8px;grid-template-columns:repeat(3,1fr);padding:8px}.dayTabs button{background:transparent;border:1px solid transparent;border-radius:8px;color:var(--muted);min-height:66px;padding:10px;text-align:left}.dayTabs button.active{background:var(--ink);color:#fffdf7}.dayTabs span,.dayTabs strong{display:block}.dayTabs span{font-size:12px;font-weight:850}.dayTabs strong{font-size:15px;line-height:1.25;margin-top:5px}.studyGrid{display:grid;gap:16px;grid-template-columns:minmax(0,1fr)}.workPanel,.sideBox,.comingSoon{background:var(--paper);border:1px solid var(--line);border-radius:8px}.workPanel{display:grid;gap:20px;padding:20px}.sectionTitle{align-items:start;display:flex;gap:16px;justify-content:space-between}.sectionTitle h2{font-size:30px}.summaryPill{background:var(--blue-soft);border-radius:999px;color:var(--blue);font-size:13px;font-weight:800;line-height:1.3;max-width:300px;padding:9px 12px}.statusBanner{align-items:start;background:var(--green-soft);border:1px solid #b8dbcd;border-radius:8px;color:var(--green);display:grid;gap:4px;padding:12px 14px}.statusBanner.warning{background:#fff3df;border-color:#e2bd7a;color:var(--gold)}.statusBanner strong,.statusBanner span{display:block}.statusBanner span{color:var(--ink);line-height:1.5}.sectionTabs{background:#fbf9f2;border:1px solid var(--line);border-radius:8px;display:grid;gap:10px;padding:10px}.sectionTabList{display:grid;gap:8px;grid-template-columns:repeat(6,minmax(0,1fr))}.sectionTabList button{background:#fffefa;border:1px solid var(--line);border-radius:8px;color:var(--muted);display:grid;gap:4px;min-height:58px;padding:8px;text-align:left}.sectionTabList button.active{background:var(--ink);border-color:var(--ink);color:#fffdf7}.sectionTabList span{align-items:center;background:var(--green-soft);border-radius:999px;color:var(--green);display:inline-flex;font-size:12px;font-weight:900;height:24px;justify-content:center;width:24px}.sectionTabList button.active span{background:#fffdf729;color:#fffdf7}.sectionTabList strong{font-size:12px;line-height:1.25}.sectionTabs p{color:var(--muted);font-size:13px;font-weight:800;line-height:1.4;margin:0}.inlineTitle{color:var(--ink);min-height:26px}.inlineTitle h3{font-size:17px;margin:0}.inlineTitle span{color:var(--muted);font-size:13px;font-weight:800;margin-left:auto}.taskList{display:grid;gap:10px}.taskItem{align-items:start;background:#fbf9f2;border:1px solid var(--line);border-radius:8px;color:var(--ink);display:grid;gap:12px;grid-template-columns:26px minmax(0,1fr) 58px;padding:13px;text-align:left;width:100%}.taskItem.done{background:var(--green-soft);border-color:#b6d8cb}.taskIcon{color:var(--green);line-height:0;padding-top:2px}.taskItem strong,.taskItem small{display:block}.taskItem small{line-height:1.45;margin-top:4px}.taskItem em{color:var(--muted);font-size:12px;font-style:normal;font-weight:800;text-align:right}.expressionDeck{display:grid;gap:14px}.cardRail{display:flex;gap:8px;overflow-x:auto;padding-bottom:4px}.cardRail button,.chips button,.chipText,.miniButton,.reviewActions button{border-radius:999px;white-space:nowrap}.cardRail button{background:#f6f2ea;border:1px solid var(--line);color:var(--muted);flex:0 0 auto;font-size:13px;font-weight:800;padding:8px 11px}.cardRail button.active{background:var(--green);border-color:var(--green);color:#fff}.chipText{background:var(--blue-soft);border:1px solid #bed6e8;color:var(--blue);display:inline-flex;font-size:13px;font-weight:800;line-height:1.3;padding:7px 10px}.expressionCard,.scriptPanel,.notesPanel{background:var(--paper-strong);border:1px solid var(--line);border-radius:8px;padding:16px}.expressionTop{justify-content:space-between}.expressionCard h3{font-size:30px;letter-spacing:0;line-height:1.1;margin:0}.iconButton{align-items:center;background:var(--ink);border:0;border-radius:999px;color:#fff;display:inline-flex;height:38px;justify-content:center;width:38px}.expressionCard dl{display:grid;gap:10px;margin:16px 0}.expressionCard dl div{border-top:1px solid var(--line);display:grid;gap:8px;grid-template-columns:112px minmax(0,1fr);padding-top:10px}.expressionCard dt{color:var(--muted);font-size:13px;font-weight:900}.expressionCard dd{line-height:1.55;margin:0}.chips{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px}.chips button{background:var(--blue-soft);border:1px solid #bed6e8;color:var(--blue);font-size:13px;font-weight:800;padding:7px 10px}.textField{display:grid;gap:8px}.textField span{color:var(--muted);font-size:13px;font-weight:850}textarea{background:#fffefa;border:1px solid var(--line);border-radius:8px;color:var(--ink);min-height:96px;outline:none;padding:12px;resize:vertical;width:100%}textarea:focus{border-color:var(--blue);box-shadow:0 0 0 3px #1c5f911f}.buttonRow{flex-wrap:wrap;gap:10px;margin-top:12px}.primaryButton,.secondaryButton,.recordButton{align-items:center;border-radius:8px;display:inline-flex;font-weight:850;gap:8px;justify-content:center;min-height:42px;padding:10px 13px}.primaryButton{background:var(--green);border:1px solid var(--green);color:#fff}.secondaryButton{background:transparent;border:1px solid var(--line);color:var(--ink)}.scriptPanel,.notesPanel{display:grid;gap:12px}.promptList{display:grid;gap:8px}.promptItem{background:#fbf9f2;border:1px solid var(--line);border-radius:8px;gap:10px;padding:10px}.promptItem .iconButton{flex:0 0 auto;height:32px;width:32px}.promptItem span{flex:1;font-weight:800;min-width:0}.miniButton,.reviewActions button{background:#fffefa;border:1px solid var(--line);color:var(--muted);font-size:12px;font-weight:850;padding:6px 9px}.miniButton,.chipButton{align-items:center;display:inline-flex;gap:5px;justify-content:center}.ttsButtonWrap{align-items:center;display:inline-grid;gap:4px;max-width:100%}.ttsButtonWrap button{width:100%}.ttsFallbackStatus{color:var(--muted);font-size:12px;font-weight:800;line-height:1.35;white-space:normal}.notesPanel textarea{min-height:128px}.lessonFlow{display:grid;gap:18px}.learningSection{background:var(--paper-strong);border:1px solid var(--line);border-radius:8px;display:grid;gap:12px;padding:16px}.sectionHint{color:var(--muted);line-height:1.55;margin:0}.passageBox{display:grid;gap:12px}.shadowCoach{display:grid;gap:8px;grid-template-columns:repeat(4,minmax(0,1fr))}.shadowCoach span{background:var(--blue-soft);border:1px solid #bed6e8;border-radius:8px;color:var(--blue);font-size:12px;font-weight:900;line-height:1.3;padding:8px 10px}.audioWarmupStatus{align-items:center;background:var(--green-soft);border:1px solid #b8dbcd;border-radius:8px;color:var(--green);display:flex;flex-wrap:wrap;gap:8px 12px;justify-content:space-between;padding:9px 11px}.audioWarmupStatus span{font-size:13px;font-weight:900}.audioWarmupStatus small{color:var(--muted);font-size:12px;font-weight:800}.passageSpeedControl{align-items:center;background:#fbf9f2;border:1px solid var(--line);border-radius:8px;display:grid;gap:10px;grid-template-columns:160px minmax(0,1fr);padding:10px 12px}.passageSpeedControl span{color:var(--muted);font-size:13px;font-weight:900}.passageSpeedControl input[type=range]{accent-color:var(--green);width:100%}.shadowLine,.speechLine{align-items:start;background:#fbf9f2;border:1px solid var(--line);border-radius:8px}.shadowLine{display:grid;gap:12px;padding:14px}.shadowLineTop{align-items:center;display:flex;gap:9px}.lineNumber{align-items:center;background:var(--green-soft);border-radius:999px;color:var(--green);display:inline-flex;font-size:12px;font-weight:900;height:30px;justify-content:center;width:30px}.shadowLineTop strong{color:var(--blue)}.shadowLine p{font-size:17px;line-height:1.55;margin:0}.shadowActions{display:flex;flex-wrap:wrap;gap:8px}.inlineRecord{min-height:36px;padding:7px 10px;width:auto}.shadowStatus{color:var(--muted);font-size:12px;font-weight:850}.shadowPlayback{display:grid;gap:8px;grid-template-columns:repeat(2,minmax(0,1fr))}.shadowPlayback div{background:var(--paper-strong);border:1px solid var(--line);border-radius:8px;display:grid;gap:6px;padding:9px}.shadowPlayback span{color:var(--muted);font-size:12px;font-weight:900}.shadowPlayback audio{width:100%}.shadowScorePanel{background:var(--paper-strong);border:1px solid var(--line);border-radius:8px;display:grid;gap:10px;padding:12px}.shadowScorePanel label{display:grid;gap:7px}.shadowScorePanel label span,.shadowScorePanel .buttonRow small{color:var(--muted);font-size:12px;font-weight:850}.shadowScorePanel textarea{min-height:68px}.shadowScoreResult{border-radius:8px;display:grid;gap:8px;padding:12px}.shadowScoreResult.good{background:#edf6f3;border:1px solid #b9dbce}.shadowScoreResult.needsPractice{background:#fff7e8;border:1px solid #e4c891}.scoreHeader{align-items:center;display:flex;gap:10px}.scoreHeader strong{align-items:center;background:var(--ink);border-radius:999px;color:#fff;display:inline-flex;font-size:20px;height:48px;justify-content:center;width:48px}.scoreHeader span{font-weight:900}.shadowScoreResult p,.shadowScoreResult ul{line-height:1.55;margin:0}.shadowScoreResult ul{padding-left:18px}.shadowScoreResult small{line-height:1.45}.speechLine{display:grid;gap:10px;grid-template-columns:78px minmax(0,1fr) auto auto;padding:11px}.speechLine span{color:var(--blue);font-weight:900}.speechLine p{line-height:1.55;margin:0}.vocabGrid{align-items:start;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}.vocabCard{background:var(--paper-strong);border:1px solid var(--line);border-radius:8px;display:grid;gap:10px;padding:14px}.vocabCardTop{align-items:center;display:flex;gap:8px;justify-content:space-between}.vocabCard strong{font-size:18px;line-height:1.25}.vocabCard p,.vocabCard small,.vocabCard em{line-height:1.45;margin:0}.vocabCard small{color:var(--muted)}.vocabCard em{color:var(--blue);font-style:normal;font-weight:750}.vocabListenRow{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.vocabListenRow small{font-size:12px}.vocabPractice{margin-top:4px}.vocabPractice summary{align-items:center;background:#f7f4ed;border:1px solid var(--line);border-radius:8px;cursor:pointer;display:flex;gap:10px;justify-content:space-between;list-style:none;padding:9px 11px}.vocabPractice summary::-webkit-details-marker{display:none}.vocabPractice summary span{color:var(--green);font-size:13px;font-weight:900}.vocabPractice summary small{color:var(--muted);font-size:12px;font-weight:800;text-align:right}.vocabPracticeBody{display:grid;gap:8px;padding-top:10px}.vocabPracticeBody label{display:grid;gap:6px}.vocabPracticeBody label span{color:var(--muted);font-size:12px;font-weight:900}.vocabPractice textarea{min-height:74px}.compactButton{min-height:36px;padding:7px 10px}.smallIcon{height:30px;width:30px}.sentencePractice{display:grid;gap:10px}.referenceLine{align-items:center;display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between}.referenceLine .sectionHint{flex:1 1 260px}.aiResult{border-radius:8px;display:grid;gap:8px;margin-top:2px;padding:12px}.aiResult.correct{background:#edf6f3;border:1px solid #b9dbce}.aiResult.needsWork{background:#fff7e8;border:1px solid #e4c891}.aiResult strong{color:var(--green)}.aiResult.needsWork strong{color:var(--gold)}.aiResult b{color:var(--ink);margin-right:4px}.correctionLine{align-items:start;display:grid;gap:8px;grid-template-columns:minmax(0,1fr) auto}.aiResult p,.aiResult ul{line-height:1.55;margin:0}.aiResult ul{padding-left:18px}.exerciseLayout{display:grid;gap:14px;grid-template-columns:220px minmax(0,1fr)}.exercisePicker{align-content:start;display:grid;gap:8px}.exercisePicker button{align-items:center;background:#fbf9f2;border:1px solid var(--line);border-radius:8px;color:var(--ink);display:grid;gap:8px;grid-template-columns:34px minmax(0,1fr);min-height:56px;padding:9px;text-align:left}.exercisePicker button.active{background:var(--green-soft);border-color:#b9dbce}.exercisePicker button.hasAnswer:not(.active){box-shadow:inset 4px 0 0 var(--blue)}.exercisePicker span{align-items:center;background:var(--paper-strong);border-radius:999px;color:var(--green);display:inline-flex;font-size:12px;font-weight:900;height:34px;justify-content:center;grid-row:span 2;width:34px}.exercisePicker strong,.exercisePicker small{display:block}.exercisePicker strong{font-size:14px}.exercisePicker small{color:var(--muted);font-size:12px;font-weight:800}.exerciseCard{background:var(--paper-strong);border:1px solid var(--line);border-radius:8px;display:grid;gap:14px;padding:16px}.exerciseCardTop{align-items:center;display:flex;gap:12px;justify-content:space-between}.exerciseCardTop h4{font-size:22px;margin:0}.exerciseCardTop span{background:var(--blue-soft);border-radius:999px;color:var(--blue);font-size:12px;font-weight:900;padding:7px 10px;white-space:nowrap}.exercisePrompt{background:#fbf9f2;border:1px solid var(--line);border-radius:8px;display:grid;gap:5px;max-height:460px;overflow:auto;padding:14px}.exercisePrompt p{line-height:1.5;margin:0}.exercisePrompt .instruction{color:var(--muted)}.exercisePrompt .question{color:var(--ink);font-weight:850;margin-top:8px}.exercisePrompt .option{color:var(--blue);padding-left:14px}.exerciseAnswer{display:grid;gap:7px}.exerciseAnswer span{color:var(--muted);font-size:13px;font-weight:900}.exerciseAnswer textarea{min-height:138px}.feedbackList{display:grid;gap:6px}.challengeSummary{align-items:center;background:#fbf9f2;border:1px solid var(--line);border-radius:8px;display:flex;gap:12px;justify-content:space-between;padding:12px}.challengeSummary strong,.challengeSummary small{display:block}.challengeSummary small{color:var(--muted);line-height:1.35;margin-top:3px}.challengeGrid{align-items:start;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}.challengeCard{background:#fbf9f2;border:1px solid var(--line);border-radius:8px;display:grid;gap:10px;padding:14px}.challengeTop{align-items:center;display:grid;gap:8px;grid-template-columns:34px minmax(0,1fr) auto}.challengeTop>span{align-items:center;background:var(--green-soft);border-radius:999px;color:var(--green);display:inline-flex;font-size:12px;font-weight:900;height:34px;justify-content:center;width:34px}.challengeTop strong{font-size:18px;line-height:1.25}.challengeCard p,.challengeCard small{line-height:1.45;margin:0}.challengeCard>small{color:var(--muted)}.challengeAnswer{display:grid;gap:7px}.challengeAnswer span{color:var(--muted);font-size:12px;font-weight:900}.challengeAnswer textarea{min-height:88px}.challengeRecorder{align-items:center;display:inline-flex;flex-wrap:wrap;gap:8px}.challengeRecorder audio{height:34px;max-width:180px}.practicePanel{display:grid;gap:14px;align-content:start}.speakingToolsGrid{display:grid;gap:12px;grid-template-columns:repeat(2,minmax(0,1fr))}.sideAnchor{display:grid;gap:14px;scroll-margin-top:18px}.sideBox{display:grid;gap:12px;padding:16px}.sourceList{display:grid;gap:8px}.sourceList a{background:#fbf9f2;border:1px solid var(--line);border-radius:8px;display:block;padding:10px;text-decoration:none}.sourceList strong,.sourceList small{display:block}.sourceList small{line-height:1.35;margin-top:3px}.recordButton{background:var(--ink);border:1px solid var(--ink);color:#fff;width:100%}.recordButton.recording{background:var(--red);border-color:var(--red)}.errorText{color:var(--red);font-weight:800}.recordingList{display:grid;gap:10px}.recordingItem{background:#fbf9f2;border:1px solid var(--line);border-radius:8px;display:grid;gap:7px;padding:10px}.recordingItem span{color:var(--muted);font-size:12px;font-weight:800}.recordingItem audio{height:36px;width:100%}.officialAudio audio{width:100%}.inlineOfficialAudio{background:#fbf9f2;border:1px solid var(--line);border-radius:8px;display:grid;gap:8px;padding:10px}.inlineOfficialAudio strong{color:var(--blue);font-size:13px}.audioTitle{color:var(--ink);line-height:1.35}.selectField{background:#fffefa;border:1px solid var(--line);border-radius:8px;color:var(--ink);min-height:42px;padding:9px 10px;width:100%}.audioControls{align-items:center;display:grid;gap:10px;grid-template-columns:minmax(0,1fr) auto}.audioControls label{display:grid;gap:6px}.audioControls span{color:var(--muted);font-size:12px;font-weight:850}.audioControls input[type=range]{accent-color:var(--green);width:100%}.toggleLine{align-items:center;color:var(--muted);display:inline-flex!important;font-size:13px;font-weight:850;gap:6px!important;white-space:nowrap}.lineButtons{display:grid;gap:7px;grid-template-columns:repeat(2,minmax(0,1fr));max-height:164px;overflow:auto;padding-right:2px}.lineButtons button{background:#fbf9f2;border:1px solid var(--line);border-radius:8px;color:var(--muted);font-size:12px;font-weight:850;min-height:34px}.lineButtons button.active{background:var(--green);border-color:var(--green);color:#fff}.localVoice textarea{min-height:84px}.localVoice audio{width:100%}.chatHistory{display:grid;gap:8px;max-height:280px;overflow:auto;padding-right:2px}.chatBubble{border:1px solid var(--line);border-radius:8px;display:grid;gap:4px;padding:10px}.chatBubble.assistant{background:#fbf9f2}.chatBubble.user{background:var(--blue-soft);border-color:#bed6e8}.chatBubble span{color:var(--muted);font-size:12px;font-weight:900}.chatBubble p{line-height:1.5;margin:0}.tutorBox textarea{min-height:86px}.reviewList{display:grid;gap:8px}.reviewItem{background:#fbf9f2;border:1px solid var(--line);border-radius:8px;display:grid;gap:8px;padding:10px}.reviewItem.due{border-color:#cfa24e;box-shadow:inset 4px 0 #cfa24e}.reviewItem strong,.reviewItem small{display:block}.reviewActions{gap:6px}.reviewActions button{align-items:center;display:inline-flex;gap:4px}button:disabled{cursor:not-allowed;opacity:.58}.comingSoon{padding:24px}.comingSoon p{color:var(--muted);line-height:1.65;max-width:820px}.threeDayPreview{display:grid;gap:10px;grid-template-columns:repeat(3,1fr);margin-top:18px}.threeDayPreview div{background:var(--paper-strong);border:1px solid var(--line);border-radius:8px;padding:14px}.threeDayPreview span,.threeDayPreview strong,.threeDayPreview small{display:block}.threeDayPreview span{color:var(--gold);font-size:12px;font-weight:900;text-transform:uppercase}.threeDayPreview strong{margin:6px 0}@media(max-width:1120px){.layout,.studyGrid{grid-template-columns:1fr}.sidebar{max-height:none;position:static}.chapterList{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:760px){body{background:#f7f3eb}.authShell{align-items:start;min-height:100svh;padding:12px}.authPanel{border-radius:18px;box-shadow:0 14px 34px #2d281e1a;gap:14px;margin-top:max(12px,env(safe-area-inset-top));padding:18px 16px}.authPanel h1{font-size:28px}.authPanel p{font-size:14px;line-height:1.5}.authTabs button,.authPanel input,.primaryButton,.secondaryButton,.recordButton{min-height:46px}.topbar>div{max-width:100%;min-width:0}.eyebrow{font-size:10px;line-height:1.3}.topbar h1{overflow-wrap:anywhere}.topbar{align-items:stretch;flex-direction:column;gap:12px;padding:calc(12px + env(safe-area-inset-top)) 12px 12px}.topbar h1{font-size:25px;line-height:1.12}.topStats{gap:8px;grid-template-columns:repeat(2,minmax(0,1fr));max-width:100%;min-width:0;width:100%}.stat{min-width:0;padding:9px 10px}.stat strong{font-size:17px;white-space:nowrap}.topStats .stat:nth-child(3){display:none}.logoutButton{grid-column:1 / -1;min-height:42px}.layout{gap:10px;padding:10px 10px 22px}.sidebar{background:#fffdf7f5;border-radius:14px;margin-inline:-2px;padding:10px;top:0}.panelHeader{margin-bottom:8px}.chapterSwitcher{margin-bottom:10px;padding:9px}.chapterSwitcher div{display:flex;gap:8px;overflow-x:auto;padding-bottom:2px;scrollbar-width:none}.chapterSwitcher div::-webkit-scrollbar,.chapterList::-webkit-scrollbar{display:none}.chapterSwitcher button{flex:0 0 auto;min-height:42px;min-width:72px}.chapterHero{grid-template-columns:1fr;gap:14px;min-height:0;padding:16px}.chapterHero h2{font-size:28px;line-height:1.12}.chapterHero p{font-size:15px;line-height:1.45;margin-top:10px}.chapterMeta{display:grid;grid-template-columns:1fr;min-width:0}.chapterMeta a{display:none}.dayTabs,.threeDayPreview{grid-template-columns:1fr}.chapterList{display:flex;gap:8px;overflow-x:auto;padding-bottom:2px;scrollbar-width:none}.chapterButton{flex:0 0 178px;gap:8px;grid-template-columns:30px minmax(0,1fr);min-height:76px;padding:9px}.chapterButton svg{display:none}.chapterNumber{height:30px;width:30px}.chapterButton strong{font-size:13px}.chapterButton small{display:-webkit-box;font-size:11px;line-height:1.25;overflow:hidden;-webkit-box-orient:vertical;-webkit-line-clamp:2}.studyArea,.studyGrid,.lessonFlow,.practicePanel{gap:10px}.sectionTabs{border-radius:14px;padding:8px}.sectionTabList{display:flex;gap:8px;overflow-x:auto;padding-bottom:2px;scrollbar-width:none}.sectionTabList button{flex:0 0 138px;min-height:54px}.speakingToolsGrid{grid-template-columns:1fr}.workPanel,.sideBox,.comingSoon{border-radius:14px}.workPanel{gap:14px;padding:12px}.sectionTitle{display:grid;gap:10px}.sectionTitle h2{font-size:23px;line-height:1.15}.summaryPill{border-radius:12px;max-width:none}.taskItem{grid-template-columns:26px minmax(0,1fr)}.taskItem em{grid-column:2;text-align:left}.expressionCard dl div,.shadowCoach,.shadowPlayback,.passageSpeedControl,.speechLine,.vocabGrid,.exerciseLayout,.challengeGrid{grid-template-columns:1fr}.learningSection,.expressionCard,.scriptPanel,.notesPanel{border-radius:14px;padding:12px;scroll-margin-top:12px}.inlineTitle h3{font-size:16px}.sectionHint{font-size:14px;line-height:1.45}.shadowCoach{display:flex;gap:7px;overflow-x:auto;padding-bottom:2px}.shadowCoach span{flex:0 0 132px}.audioWarmupStatus{align-items:start;display:grid;gap:4px}.passageSpeedControl{padding:10px}.shadowLine{border-radius:14px;gap:10px;padding:12px}.shadowLine p{font-size:16px;line-height:1.5}.shadowActions,.buttonRow{display:grid;grid-template-columns:1fr}.shadowActions .compactButton,.shadowActions .miniButton,.buttonRow>button,.buttonRow>.ttsButtonWrap{width:100%}.compactButton,.inlineRecord,.miniButton{min-height:42px}.shadowScorePanel{border-radius:14px;padding:10px}audio{max-width:100%}textarea{min-height:92px;padding:11px}.vocabGrid{gap:10px}.vocabCard{border-radius:14px;padding:12px}.vocabCard strong{font-size:17px}.vocabCardTop,.referenceLine,.correctionLine{align-items:stretch;display:grid;grid-template-columns:1fr}.vocabPractice summary{align-items:start;display:grid;gap:4px}.vocabPractice summary small{text-align:left}.selectField{min-height:46px;width:100%}.aiResult,.shadowScoreResult{border-radius:14px}.challengeSummary{align-items:stretch;display:grid}.exerciseCardTop{align-items:start;display:grid}.practicePanel{margin-top:0}.sideBox{padding:12px}.speechLine .miniButton{grid-column:auto}.promptItem{align-items:start;display:grid;grid-template-columns:1fr}.promptItem .miniButton{grid-column:auto;justify-self:start}}@media(max-width:430px){.topbar,.layout,.authShell{padding-left:8px;padding-right:8px}.chapterHero h2{font-size:25px}.chapterButton{flex-basis:160px}.topStats{gap:6px}.stat{padding:8px}}
