:root{color:#17202a;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;background:#fff;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Microsoft YaHei,sans-serif}*{box-sizing:border-box}body{min-width:320px;min-height:100vh;margin:0}button{font:inherit}.app-shell{background:linear-gradient(#fff 0%,#f6f8fb 58%,#eef4f9 100%);place-items:center;min-height:100vh;padding:20px;display:grid}.lesson-frame{background:#fff;border:1px solid #dde6ee;border-radius:28px;flex-direction:column;gap:14px;width:min(100%,460px);min-height:min(820px,100vh - 40px);padding:20px;display:flex;overflow:hidden;box-shadow:0 24px 70px #192b4624}.course-shell{place-items:start center}.course-center-frame{background:#fff;border:1px solid #dde6ee;border-radius:24px;flex-direction:column;gap:14px;width:min(100%,480px);min-height:min(860px,100vh - 40px);padding:18px;display:flex;box-shadow:0 24px 70px #192b4624}.course-center-header,.course-section-heading,.entitlement-panel{align-items:center;gap:12px;display:flex}.course-center-header{justify-content:space-between}.course-center-header h1{letter-spacing:0;margin:0;font-size:25px;font-weight:800;line-height:1.16}.course-header-actions{flex-wrap:wrap;align-items:center;gap:8px;display:inline-flex}.course-backoffice-link{color:#1f5b89;background:#fff;border:1px solid #d6e2ec;border-radius:10px;align-items:center;min-height:42px;padding:0 14px;font-size:14px;font-weight:760;text-decoration:none;display:inline-flex}.icon-action{color:#395063;cursor:pointer;background:#fff;border:1px solid #d6e2ec;border-radius:10px;place-items:center;width:42px;min-height:42px;display:inline-grid}.course-message{color:#395063;background:#f7fbff;border:1px solid #d6e2ec;border-radius:10px;align-items:flex-start;gap:8px;margin:0;padding:10px 12px;font-size:14px;font-weight:720;line-height:1.45;display:flex}.course-message.error{color:#8c2f29;background:#fdecea;border-color:#efc1bd}.next-lesson-panel{background:linear-gradient(135deg,#f3f9ff 0%,#fff 62%);border:1px solid #d9e7f1;border-radius:20px;grid-template-columns:auto 1fr;align-items:center;gap:14px;padding:16px;display:grid}.course-progress-ring{color:#155c96;background:#fff;border:8px solid #d8ebfb;border-top-color:#1f78d1;border-radius:999px;align-content:center;place-items:center;width:86px;height:86px;display:grid}.course-progress-ring strong{font-size:21px;line-height:1}.course-progress-ring span{color:#607080;margin-top:4px;font-size:12px;font-weight:760}.next-lesson-copy{min-width:0}.next-lesson-copy p{color:#1f78d1;margin:0 0 5px;font-size:15px;font-weight:820}.next-lesson-copy h2{letter-spacing:0;margin:0;font-size:26px;font-weight:820;line-height:1.14}.next-lesson-copy span{color:#52616f;margin-top:8px;font-size:16px;font-weight:680;line-height:1.42;display:block}.course-primary-action{grid-column:1/-1;width:100%;margin-top:0}.course-section,.entitlement-panel{background:#fff;border:1px solid #dfe8ef;border-radius:16px;padding:14px}.course-section-heading{color:#1f5b89;align-items:flex-start}.course-section-heading h2,.entitlement-panel h2{color:#17202a;letter-spacing:0;margin:0;font-size:19px;font-weight:820;line-height:1.2}.course-section-heading p,.entitlement-panel p{color:#586776;margin:5px 0 0;font-size:15px;line-height:1.45}.trial-strip{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin-top:12px;display:grid}.trial-step{color:#516070;cursor:pointer;background:#f5f8fb;border:1px solid #d8e4ed;border-radius:12px;place-items:center;gap:4px;min-height:72px;display:grid}.trial-step.open{color:#185f99;background:#edf7ff;border-color:#b9d9ef}.trial-step:disabled{cursor:not-allowed}.trial-step strong{color:#fff;background:#1f78d1;border-radius:999px;place-items:center;width:30px;height:30px;font-size:17px;line-height:1;display:grid}.trial-step:not(.open) strong{background:#95a4b1}.trial-step span{font-size:14px;font-weight:780}.review-list,.lesson-list{gap:9px;margin-top:12px;display:grid}.weakness-chip-row{flex-wrap:wrap;gap:7px;margin-top:12px;display:flex}.weakness-chip-row span{color:#8b3c17;background:#fff4e8;border-radius:8px;align-items:center;min-height:30px;padding:0 10px;font-size:14px;font-weight:780;display:inline-flex}.review-row{color:#263849;text-align:left;cursor:pointer;background:#f8fbfd;border:1px solid #d8e4ed;border-radius:12px;justify-content:space-between;align-items:center;gap:12px;min-height:50px;padding:10px 12px;display:flex}.review-row:disabled{cursor:not-allowed;color:#6a7885}.review-row span,.review-row strong{overflow-wrap:anywhere;min-width:0}.review-row strong{color:#1f78d1;font-size:14px}.learning-report-panel{gap:12px;display:grid}.learning-overview-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin-top:2px;display:grid}.learning-overview-grid div{background:#f7fbff;border:1px solid #d8e4ed;border-radius:12px;align-content:center;gap:5px;min-height:74px;padding:10px;display:grid}.learning-overview-grid span,.learning-next-action span,.learning-suggestions span{color:#5d6b78;font-size:13px;font-weight:760;line-height:1.2}.learning-overview-grid strong{color:#17202a;font-size:21px;font-weight:840;line-height:1.1}.learning-next-action{background:#f8fbfd;border:1px solid #d8e4ed;border-radius:12px;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:12px;padding:12px;display:grid}.learning-next-action strong{color:#17202a;overflow-wrap:anywhere;margin-top:4px;font-size:17px;font-weight:820;line-height:1.25;display:block}.learning-next-action p,.learning-suggestions p,.learning-report-footnote{color:#586776;margin:5px 0 0;font-size:14px;font-weight:700;line-height:1.45}.learning-suggestions{background:#fffaf0;border:1px solid #eadfc5;border-radius:12px;gap:8px;padding:12px;display:grid}.learning-chip-row{flex-wrap:wrap;gap:7px;margin-top:8px;display:flex}.learning-chip-row span{color:#7a4317;background:#fff;border:1px solid #efd7ad;border-radius:999px;align-items:center;min-height:30px;padding:0 10px;font-size:14px;font-weight:800;display:inline-flex}.learning-lesson-records{gap:9px;display:grid}.learning-record-row{background:#fff;border:1px solid #d8e4ed;border-radius:12px;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:10px;padding:10px;display:grid}.learning-record-row h3{color:#17202a;overflow-wrap:anywhere;margin:0;font-size:16px;font-weight:820;line-height:1.2}.learning-record-row p{color:#5b6874;gap:2px;margin:5px 0 0;font-size:13px;line-height:1.35;display:grid}.learning-record-row p strong{color:#1f5b89;font-size:13px;font-weight:820;line-height:1.2}.learning-record-row p span{overflow-wrap:anywhere}.learning-report-footnote{margin-top:0}.lesson-list-row{background:#fff;border:1px solid #d8e4ed;border-radius:14px;grid-template-columns:auto 1fr auto;align-items:center;gap:10px;min-height:82px;padding:12px;display:grid}.lesson-list-row.locked{background:#f7f8fa}.lesson-order-mark{color:#fff;background:#1f78d1;border-radius:12px;place-items:center;width:38px;height:38px;font-size:17px;font-weight:840;display:grid}.lesson-list-row.locked .lesson-order-mark{color:#667482;background:#e2e8ee}.lesson-list-row h3{color:#17202a;letter-spacing:0;margin:0;font-size:17px;font-weight:820;line-height:1.25}.lesson-list-row p{color:#596978;margin:5px 0 0;font-size:14px;line-height:1.38}.lesson-row-action{color:#fff;cursor:pointer;background:#1f78d1;border:0;border-radius:10px;min-width:76px;min-height:42px;padding:0 12px;font-size:15px;font-weight:820}.lesson-row-action.disabled,.lesson-row-action:disabled{color:#6a7885;cursor:not-allowed;background:#dce5ec}.entitlement-panel{color:#1f5b89;background:#f7fbff;align-items:flex-start}.share-panel{background:#fff;border:1px solid #dfe8ef;border-radius:16px;gap:12px;padding:14px;display:grid}.share-panel h2{color:#17202a;margin:0;font-size:19px;font-weight:820;line-height:1.2}.share-panel p{color:#586776;margin:5px 0 0;font-size:15px;line-height:1.45}.share-link-box{background:#f8fbfd;border:1px solid #d8e4ed;border-radius:12px;grid-template-columns:auto 1fr;align-items:center;gap:12px;padding:10px;display:grid}.referral-qr-image{object-fit:contain;background:#fff;border:1px solid #e1e8ef;border-radius:8px;width:88px;height:88px;padding:6px}.share-link-box span{overflow-wrap:anywhere;color:#395063;min-width:0;font-size:13px;font-weight:700;line-height:1.35}.share-message{background:#f7fbff;border:1px solid #d6e2ec;border-radius:10px;padding:9px 11px;font-weight:760}.share-actions{grid-template-columns:1fr 1fr 1fr;gap:8px;display:grid}.share-actions .primary-action,.share-actions .secondary-action{border-radius:10px;min-height:46px;margin:0;font-size:15px}.share-primary-action{box-shadow:none}.share-history-panel{background:#f8fbfe;border:1px solid #dce8f0;border-radius:14px;gap:12px;padding:14px;display:grid}.share-history-heading{gap:4px;display:grid}.share-history-heading h3{color:#17202a;margin:0;font-size:18px;font-weight:820;line-height:1.2}.share-history-heading p,.share-history-empty,.share-history-entry-meta span,.share-history-entry-top a{color:#586776;margin:0;font-size:14px;line-height:1.45}.share-history-stats{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;display:grid}.share-history-stats div,.share-history-entry{background:#fff;border:1px solid #d8e4ed;border-radius:12px;gap:6px;padding:12px;display:grid}.share-history-stats strong{color:#1f5b89;font-size:24px;line-height:1}.share-history-list{gap:10px;display:grid}.share-history-entry-top,.share-history-entry-meta{flex-wrap:wrap;justify-content:space-between;gap:10px;display:flex}.share-history-entry-top div{gap:4px;min-width:0;display:grid}.share-history-entry-top strong{color:#17202a;font-size:14px;font-weight:780}.share-history-entry-top a{overflow-wrap:anywhere;text-decoration:none}.share-history-entry-top>span{color:#1f5b89;font-size:14px;font-weight:780}.public-share-shell{place-items:center;min-height:100vh;padding:24px;display:grid}.public-share-card{background:#fff;border:1px solid #dfe8ef;border-radius:8px;gap:14px;width:min(100%,440px);padding:24px;display:grid;box-shadow:0 18px 44px #17202a1f}.public-share-card h1{color:#17202a;margin:0;font-size:30px;line-height:1.15}.public-share-card p{color:#435467;margin:0;font-size:17px;line-height:1.55}.public-share-lead{font-weight:760}.public-share-message{background:#f7fbff;border:1px solid #d6e2ec;border-radius:8px;padding:12px}.public-share-action{margin:8px 0 0;text-decoration:none}.entitlement-login-action{color:#fff;cursor:pointer;background:#1f78d1;border:0;border-radius:10px;min-width:86px;min-height:40px;margin-left:auto;padding:0 12px;font-size:15px;font-weight:820}.lesson-header{justify-content:space-between;align-items:center;gap:16px;display:flex}.header-label{color:#677483;margin:0 0 3px;font-size:15px;line-height:1.2}.lesson-header h1{letter-spacing:0;margin:0;font-size:27px;font-weight:760;line-height:1.12}.progress-summary{color:#395063;text-align:right;gap:7px;width:104px;font-size:16px;font-weight:740;display:grid}.progress-track{background:#e5edf3;border-radius:999px;height:8px;overflow:hidden}.progress-track div{border-radius:inherit;background:#1f78d1;height:100%;transition:width .22s}.student-chip{color:#52616f;margin:7px 0 0;font-size:14px;font-weight:700;line-height:1.2}.logout-button{color:#395063;cursor:pointer;background:#fff;border:1px solid #d6e2ec;border-radius:8px;justify-content:center;align-items:center;gap:5px;min-height:32px;display:inline-flex}.audio-control-row{gap:8px;margin-top:12px;display:grid}.auto-play-toggle{color:#26475d;background:#f7fbff;border:1px solid #d6e2ec;border-radius:12px;justify-content:space-between;align-items:center;gap:10px;width:100%;min-height:44px;padding:8px 12px;font-size:15px;font-weight:780;display:inline-flex}.auto-play-toggle input{accent-color:#1f78d1;width:22px;height:22px}.auto-play-toggle span{flex:1}.auto-play-toggle strong{color:#165f9d;text-align:right;min-width:32px}.audio-hint{color:#604916;background:#fff9e8;border:1px solid #ead28a;border-radius:10px;margin:0;padding:9px 11px;font-size:14px;font-weight:700;line-height:1.45}.step-rail{gap:7px;padding-bottom:2px;display:flex;overflow-x:auto}.step-rail span{color:#6f7d88;background:#f1f5f8;border-radius:10px;align-items:center;gap:4px;min-width:fit-content;min-height:34px;padding:0 11px;font-size:15px;font-weight:680;display:inline-flex}.step-rail span.active{color:#165f9d;background:#e5f1fb}.step-rail span.done{color:#257142;background:#ebf7ee}.cover-screen,.content-stack,.complete-screen{flex-direction:column;flex:1;gap:16px;display:flex}.cover-copy h2,.instruction-row h2,.complete-screen h2{letter-spacing:0;margin:0;font-size:30px;font-weight:790;line-height:1.14}.cover-copy p,.instruction-row p,.complete-screen p{color:#52616f;margin:8px 0 0;font-size:19px;line-height:1.55}.cover-hero-image,.generic-scene-image{background:#edf4f8;border:2px solid #d8e4ee;border-radius:24px;margin:0;overflow:hidden}.cover-hero-image img,.generic-scene-image img{aspect-ratio:16/9;object-fit:cover;width:100%;display:block}.object-hotspot-scene{background:#edf4f8;border:2px solid #d8e4ee;border-radius:24px;position:relative;overflow:hidden}.object-hotspot-scene img{aspect-ratio:16/9;object-fit:cover;width:100%;display:block}.object-hotspot{background:#2176d205;border:2px solid #0000;border-radius:18px;position:absolute}.object-hotspot span{color:#164e7f;text-align:center;background:#ffffffe6;border-radius:999px;min-width:64px;font-size:16px;font-weight:760;display:none;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 8px 24px #142d4629}.object-hotspot.assist{background:#287bd32e;border-color:#287bd3}.object-hotspot.assist span{display:block}.primary-action,.secondary-action,.audio-button,.choice-button,.character-card,.scene-target{cursor:pointer;-webkit-tap-highlight-color:transparent;border:0}.primary-action,.secondary-action{border-radius:16px;justify-content:center;align-items:center;gap:10px;min-height:62px;font-size:22px;font-weight:780;display:inline-flex}.primary-action{color:#fff;background:#1f78d1;margin-top:auto;box-shadow:0 14px 32px #1f78d13d}.primary-action:disabled{cursor:not-allowed;color:#6a7885;box-shadow:none;background:#d7e3ec}.secondary-action{color:#1f5b89;background:#e8f2fb;padding:0 20px}.prompt-panel{background:#f5f8fb;border:1px solid #e0e9f1;border-radius:18px;grid-template-columns:1fr auto;align-items:center;gap:12px;padding:16px;display:grid}.prompt-panel h2{letter-spacing:0;margin:0;font-size:28px;font-weight:800;line-height:1.2}.prompt-panel p{color:#536270;margin:8px 0 0;font-size:18px;line-height:1.35}.prompt-panel p.success{color:#1f7a45}.prompt-panel p.error{color:#b7432e}.audio-button{color:#20465e;background:#fff;border:1px solid #dce8f0;border-radius:16px;place-items:center;gap:3px;width:76px;min-height:76px;font-size:13px;font-weight:760;display:grid}.primary-action:focus-visible,.secondary-action:focus-visible,.audio-button:focus-visible,.choice-button:focus-visible,.character-card:focus-visible,.scene-target:focus-visible,.logout-button:focus-visible,.icon-action:focus-visible,.trial-step:focus-visible,.review-row:focus-visible,.entitlement-login-action:focus-visible,.lesson-row-action:focus-visible,.learning-record-row:focus-within{outline-offset:4px;outline:4px solid #1f78d157}.auto-play-toggle:focus-within{outline-offset:3px;outline:4px solid #1f78d147}.login-frame{justify-content:center}.login-hero{gap:8px;display:grid}.login-hero h1{letter-spacing:0;margin:0;font-size:34px;line-height:1.12}.login-hero p:last-child{color:#52616f;margin:0;font-size:18px;line-height:1.5}.login-form,.student-form{gap:14px;display:grid}.login-form label,.student-form label{color:#425161;gap:7px;font-size:15px;font-weight:760;display:grid}.login-form input,.student-form input,.student-form select,.student-form textarea{color:#17202a;width:100%;min-height:50px;font:inherit;background:#fff;border:1px solid #d6e2ec;border-radius:10px;padding:0 13px;font-size:17px}.student-form textarea{resize:vertical;min-height:96px;padding-top:12px}.login-error,.student-admin-message{color:#604916;background:#fff9e8;border:1px solid #ead28a;border-radius:8px;padding:12px 14px;font-size:15px;font-weight:700;line-height:1.45}.login-error,.student-admin-message.error{color:#8c2f29;background:#fdecea;border-color:#efc1bd}.login-links{flex-wrap:wrap;justify-content:center;gap:18px;padding-top:6px;display:flex}.login-links a{color:#1f5b89;font-size:16px;font-weight:760;text-decoration:none}.backoffice-status-frame{gap:20px}.backoffice-status-actions{gap:12px;display:grid}.backoffice-status-link{width:100%;text-decoration:none}.backoffice-role-selection{gap:12px;display:grid}.backoffice-role-option{text-align:left;justify-content:flex-start;align-items:flex-start}.backoffice-role-option strong{font-size:18px}.backoffice-role-option span{color:#5d7388;font-size:14px}.backoffice-role-switcher{z-index:20;background:#fffffff5;border:1px solid #d9e6f2;border-radius:18px;gap:10px;width:min(360px,100vw - 32px);padding:14px;display:grid;position:fixed;bottom:16px;right:16px;box-shadow:0 16px 32px #11182724}.backoffice-role-switcher>span{color:#5d7388;font-size:13px}.backoffice-role-switcher-actions{gap:8px;display:grid}.status-icon{color:#1f78d1}.status-icon.spin{animation:1s linear infinite status-spin}@keyframes status-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.student-admin{gap:18px}.portal-page,.portal-section{gap:18px;display:grid}.portal-metric-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.portal-metric-card{background:#fff;border:1px solid #dfe8ef;border-radius:14px;gap:6px;padding:16px;display:grid}.portal-metric-card span{color:#1f5b89}.portal-metric-card strong{color:#17202a;font-size:24px;line-height:1}.portal-metric-card small{color:#607080;font-size:14px;font-weight:760}.portal-section-heading{justify-content:space-between;align-items:center;gap:12px;display:flex}.portal-section-heading h2{color:#17202a;margin:0;font-size:20px;font-weight:800;line-height:1.2}.portal-section-heading span{color:#607080;font-size:14px;font-weight:760}.student-form{background:#fff;border:1px solid #dfe6eb;border-radius:8px;grid-template-columns:repeat(2,minmax(0,1fr));padding:18px}.student-form-wide{grid-column:1/-1}.student-form-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;display:grid}.student-table{background:#fff;border:1px solid #dfe6eb;border-radius:8px;display:grid;overflow:hidden}.student-table-row{color:#263849;border-top:1px solid #edf1f4;grid-template-columns:1fr 1.2fr .7fr 1.4fr;gap:12px;padding:12px 14px;font-size:15px;display:grid}.student-table-row.header{color:#4d5a66;background:#f5f8fb;border-top:0;font-weight:780}.student-table-row span{overflow-wrap:anywhere;min-width:0}.platform-overview-row{grid-template-columns:1.2fr 1fr 1.1fr .9fr .7fr .7fr .9fr}.coach-overview-row{grid-template-columns:1fr 1.1fr .7fr .8fr .7fr}.student-assignment-row{grid-template-columns:.9fr 1fr .7fr 1fr 1.2fr}.coach-inline-button{color:#1f5b89;min-height:36px;font:inherit;background:#fff;border:1px solid #d6e2ec;border-radius:999px;padding:0 12px;font-weight:760}.reward-rule-table .student-table-row,.benefit-ledger-table .student-table-row{grid-template-columns:1.4fr 1fr .8fr 1.2fr}.benefit-ledger-table .student-table-row,.compensation-table .student-table-row{grid-template-columns:1.1fr 1fr .9fr 1.4fr 1fr}.compensation-search{align-items:end}.compensation-search label{color:#425161;gap:7px;width:min(520px,100%);font-size:15px;font-weight:760;display:grid}.search-input{background:#fff;border:1px solid #d6e2ec;border-radius:10px;align-items:center;gap:10px;min-height:50px;padding:0 12px;display:flex}.search-input svg{color:#687684;flex:none}.search-input input{color:#17202a;width:100%;min-width:0;font:inherit;border:0;outline:0;font-size:16px}.assist-note{color:#604916;background:#fff8df;border:1px solid #ead28a;border-radius:16px;margin:0;padding:14px 16px;font-size:18px;font-weight:720;line-height:1.45}.intersection-scene{background-color:#3d4650;background-position:50%;background-size:cover;border-radius:22px;min-height:360px;position:relative;overflow:hidden;box-shadow:inset 0 0 0 1px #ffffff47}.intersection-scene:before{content:"";pointer-events:none;background:linear-gradient(#08121c0f,#08121c33);position:absolute;inset:0}.crosswalk,.stop-line{display:none}.scene-target{z-index:2;background:0 0;place-items:center;display:grid;position:absolute}.scene-target span{color:#17202a;background:#fff;border:2px solid #dce5ec;border-radius:12px;place-items:center;min-width:44px;height:44px;font-size:28px;font-weight:850;display:grid;position:absolute;bottom:-8px;right:-6px;box-shadow:0 8px 18px #131f2d1f}.scene-target.assist{outline-offset:6px;background:#ffffff1a;border-radius:20px;outline:5px solid #1f78d161}.scene-target.car{border-radius:22px;width:126px;height:74px;bottom:24%;left:18%}.scene-target.car:before{content:none}.scene-target.person{opacity:0;pointer-events:none;width:60px;height:108px;top:40%;left:54%}.scene-target.person.visible{opacity:1;pointer-events:auto}.scene-target.person:before,.scene-target.person:after{content:none}.scene-target.light{border-radius:20px;width:66px;height:148px;top:14%;right:15%}.scene-target.light i,.scene-target.light i.red,.scene-target.light i.green{display:none}.scene-target.road{border-radius:22px;width:42%;height:28%;bottom:5%;left:5%}.scene-target.road span{bottom:10px;left:10px;right:auto}.choice-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.choice-button{color:#17202a;overflow-wrap:anywhere;background:#fff;border:2px solid #dce6ee;border-radius:18px;min-height:96px;font-size:38px;font-weight:860;line-height:1.12;box-shadow:0 10px 22px #1d344b17}.choice-button.assist,.character-card.assist{color:#8e3d08;background:#fff8df;border-color:#d99720;box-shadow:0 0 0 5px #d997202e,0 12px 26px #5c400e1f}.character-board{flex:1;grid-template-columns:repeat(3,minmax(0,1fr));align-content:center;gap:12px;display:grid}.character-card{aspect-ratio:1;color:#17202a;background:#fff;border:2px solid #dce6ee;border-radius:22px;font-size:82px;font-weight:870;line-height:1;box-shadow:0 12px 24px #1d344b1a}.character-card.with-image{color:#fff;text-shadow:0 2px 8px #000000ad,0 0 2px #000000b8;background-color:#fff;background-position:50%;background-size:cover}.word-strip{grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;display:grid}.word-strip span{color:#536270;background:#f3f6f9;border-radius:14px;place-items:center;min-height:56px;font-size:31px;font-weight:850;display:grid}.word-strip span.current{color:#b73226;background:#fff0eb}.video-box{background:#17202a;border-radius:22px;overflow:hidden}.video-box video{aspect-ratio:16/10;width:100%;display:block}.instruction-row{grid-template-columns:1fr auto;align-items:center;gap:14px;display:grid}.instruction-row .video-play-hint{color:#9f4529;font-weight:700}.video-required-hint{color:#65727f;text-align:center;margin:-6px 0 0;font-size:15px;font-weight:700;line-height:1.45}.quiz-card{background:#fff;border:2px solid #dce6ee;border-radius:22px;place-items:center;min-height:220px;padding:24px;display:grid;box-shadow:0 12px 24px #1d344b14}.quiz-card p{margin:0;font-size:34px;font-weight:760;line-height:1.45}mark{color:#a82f25;background:#fff0cf;border-radius:8px;padding:0 5px}.complete-screen{text-align:center;justify-content:center}.result-label{color:#1f5b89;background:#e8f2fb;border-radius:999px;align-self:center;align-items:center;min-height:38px;padding:0 16px;font-size:18px;font-weight:780;display:inline-flex}.complete-mark{color:#fff;background:#2fac66;border-radius:28px;align-self:center;place-items:center;width:104px;height:104px;display:grid}.coach-summary{background:#f6f9fb;border:1px solid #dfe9f1;border-radius:16px;padding:14px 16px}.summary-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin:6px 0 8px;display:grid}.summary-grid div{background:#f3f7fa;border-radius:16px;align-content:center;gap:4px;min-height:90px;display:grid}.summary-grid strong{font-size:31px}.summary-grid span{color:#63717d;font-size:15px;font-weight:680}.draft-cover-screen{gap:12px}.draft-cover-hero{background-position:50%;background-size:cover;border-radius:22px;align-items:flex-end;min-height:190px;padding:16px;display:flex;overflow:hidden;box-shadow:inset 0 0 0 1px #fff6}.draft-cover-badge,.draft-reference-banner,.draft-scene-note,.draft-callout-card figcaption,.draft-guide-chip,.draft-review-card figcaption{background:#fffffff0;border:1px solid #dce6ee;border-radius:16px}.draft-cover-badge,.draft-reference-banner,.draft-scene-note,.draft-guide-chip,.draft-review-card figcaption{padding:10px 12px}.draft-cover-badge span,.draft-reference-banner span,.draft-scene-note span,.draft-guide-chip span,.draft-review-card figcaption span,.draft-callout-card figcaption span{color:#5f6d79;font-size:12px;line-height:1.4;display:block}.draft-cover-badge strong,.draft-reference-banner strong,.draft-scene-note strong,.draft-guide-chip strong,.draft-review-card figcaption strong,.draft-callout-card figcaption strong{color:#17202a;margin-top:4px;font-size:14px;font-weight:780;line-height:1.35;display:block}.draft-cover-badge p,.draft-reference-banner p,.draft-scene-note p,.draft-guide-chip p,.draft-review-card figcaption p,.draft-callout-card figcaption p{color:#52616f;margin:4px 0 0;font-size:12px;line-height:1.35}.draft-cover-guides,.draft-character-row{gap:8px;display:grid}.draft-guide-chip{grid-template-columns:64px 1fr;align-items:center;gap:10px;display:grid}.draft-guide-chip img{object-fit:contain;width:56px;height:56px}.draft-scene-card,.draft-scene-main{gap:10px;display:grid}.draft-scene-main img{aspect-ratio:16/9;object-fit:contain;background:#eef4f8;border-radius:18px;width:100%;display:block}.draft-callout-row,.draft-review-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.draft-callout-card,.draft-review-card{gap:6px;margin:0;display:grid}.draft-callout-card img,.draft-review-card img{aspect-ratio:16/10;object-fit:contain;background:#eef4f8;border-radius:16px;width:100%;display:block}.draft-callout-card figcaption{padding:9px 10px}.draft-tag-row{flex-wrap:wrap;gap:6px;display:flex}.draft-tag-row span{color:#2f5169;background:#eef5fa;border:1px solid #d8e5ee;border-radius:999px;align-items:center;min-height:28px;padding:0 9px;font-size:12px;font-weight:740;display:inline-flex}.draft-choice-grid{gap:8px}.draft-option-card{gap:5px;display:grid}.draft-choice-grid .choice-button{min-height:76px;font-size:24px;line-height:1.18}.inline-audio-button{color:#37556d;background:#fff;border:1px solid #dce6ee;border-radius:12px;justify-content:center;align-items:center;gap:6px;min-height:34px;font-size:12px;font-weight:760;display:inline-flex}@media (width>=700px){.lesson-frame{width:min(100%,560px)}.draft-cover-guides,.draft-character-row{grid-template-columns:repeat(2,minmax(0,1fr))}}.coach-shell{color:#17202a;background:#f5f7f8;min-height:100vh;padding:24px}.coach-workspace{gap:18px;width:min(1180px,100%);margin:0 auto;display:grid}.coach-header{border-bottom:1px solid #dfe6eb;justify-content:space-between;align-items:center;gap:16px;min-height:72px;display:flex}.coach-kicker{color:#697580;margin:0 0 4px;font-size:14px;font-weight:720;line-height:1.2}.coach-header h1{letter-spacing:0;margin:0;font-size:28px;line-height:1.15}.coach-back-link,.coach-icon-button{border-radius:8px;align-items:center;gap:8px;min-height:40px;font-size:15px;font-weight:720;text-decoration:none;display:inline-flex}.coach-back-link{color:#1f5b89;background:#e7eef4;padding:0 14px}.coach-icon-button{color:#243849;cursor:pointer;background:#fff;border:1px solid #cfd9e1;padding:0 13px}.coach-back-link:focus-visible,.coach-icon-button:focus-visible{outline-offset:3px;outline:4px solid #1f78d147}.coach-toolbar{background:#fff;border:1px solid #dfe6eb;border-radius:8px;justify-content:space-between;align-items:center;gap:16px;min-height:58px;padding:12px 14px;display:flex}.coach-toolbar div{gap:3px;display:grid}.coach-toolbar strong{font-size:16px}.coach-toolbar span{color:#687684;font-size:14px}.coach-alert,.coach-message{color:#604916;background:#fff9e8;border:1px solid #ead28a;border-radius:8px;align-items:flex-start;gap:12px;display:flex}.coach-alert{align-items:center;min-height:44px;padding:10px 12px;font-size:15px;font-weight:680}.coach-message{padding:20px}.coach-message h2{margin:0;font-size:20px}.coach-message p{color:#604916;margin:6px 0 0;font-size:16px;line-height:1.5}.coach-overview{grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;display:grid}.coach-overview div{background:#fff;border:1px solid #dfe6eb;border-radius:8px;align-content:center;gap:5px;min-height:86px;padding:12px 14px;display:grid}.coach-overview strong{font-size:29px;line-height:1}.coach-overview span{color:#687684;font-size:14px;font-weight:700}.coach-card-list{gap:12px;display:grid}.coach-summary-card{background:#fff;border:1px solid #dfe6eb;border-left:6px solid #2f7d55;border-radius:8px;gap:16px;padding:18px;display:grid}.coach-summary-card.level-watch{border-left-color:#d68b19}.coach-summary-card.level-needed{border-left-color:#b8493f}.coach-card-main{justify-content:space-between;align-items:flex-start;gap:14px;display:flex}.coach-student{align-items:center;gap:12px;display:flex}.coach-avatar{color:#1f5b89;background:#e8f2fb;border-radius:8px;flex:none;place-items:center;width:42px;height:42px;display:grid}.coach-student h2{letter-spacing:0;margin:0;font-size:21px;line-height:1.2}.coach-student p{color:#687684;margin:4px 0 0;font-size:14px}.coach-level{color:#243849;white-space:nowrap;background:#eef2f5;border-radius:999px;align-items:center;min-height:32px;padding:0 12px;font-size:14px;font-weight:760;display:inline-flex}.level-none .coach-level{color:#1f6d44;background:#eaf6ee}.level-watch .coach-level{color:#7a4b08;background:#fff3d9}.level-needed .coach-level{color:#8c2f29;background:#fdecea}.coach-metrics{border-top:1px solid #edf1f4;border-bottom:1px solid #edf1f4;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;padding:12px 0;display:grid}.coach-metric{align-items:center;gap:9px;min-width:0;display:flex}.coach-metric>span{color:#38576f;background:#f1f5f8;border-radius:8px;flex:none;place-items:center;width:32px;height:32px;display:grid}.coach-metric div{gap:2px;min-width:0;display:grid}.coach-metric strong{text-overflow:ellipsis;white-space:nowrap;font-size:17px;line-height:1.2;overflow:hidden}.coach-metric small{color:#687684;font-size:13px;font-weight:700}.coach-detail-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;display:grid}.coach-detail-block{align-content:flex-start;gap:8px;min-width:0;display:grid}.coach-detail-block h3{color:#4d5a66;margin:0;font-size:14px;line-height:1.2}.coach-detail-block div{flex-wrap:wrap;gap:6px;display:flex}.coach-detail-block span{color:#263849;background:#f0f4f7;border-radius:8px;align-items:center;min-height:28px;padding:0 9px;font-size:14px;font-weight:700;display:inline-flex}.coach-advice{color:#263849;background:#f7f9fa;border-radius:8px;margin:0;padding:12px 14px;font-size:16px;line-height:1.55}.student-detail-panel{gap:14px;display:grid}.student-detail-heading,.student-detail-main{justify-content:space-between;align-items:center;gap:14px;min-height:58px;display:flex}.student-detail-heading{background:#fff;border:1px solid #dfe6eb;border-radius:8px;padding:14px 16px}.student-detail-heading h2,.review-suggestion-list h3,.lesson-progress-list h3,.analysis-block h3{margin:0;font-size:20px;line-height:1.2}.student-detail-layout{grid-template-columns:300px minmax(0,1fr);align-items:start;gap:14px;display:grid}.student-picker{gap:8px;display:grid}.student-picker-row{color:#243849;cursor:pointer;text-align:left;background:#fff;border:1px solid #dfe6eb;border-radius:8px;justify-content:space-between;align-items:center;gap:10px;min-height:68px;padding:11px 12px;display:flex}.student-picker-row.active{border-color:#8fb7d8;box-shadow:inset 4px 0 #1f78d1}.student-picker-row span{gap:4px;min-width:0;display:grid}.student-picker-row strong,.student-picker-row small{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.student-picker-row small{color:#687684;font-size:13px;font-weight:700}.student-detail-card{background:#fff;border:1px solid #dfe6eb;border-radius:8px;gap:16px;padding:16px;display:grid}.risk-pill{white-space:nowrap;border-radius:999px;align-items:center;min-height:30px;padding:0 10px;font-size:13px;font-style:normal;font-weight:760;display:inline-flex}.risk-pill.risk-needed{color:#8c2f29;background:#fdecea}.risk-pill.risk-watch{color:#7a4b08;background:#fff3d9}.risk-pill.risk-normal{color:#1f6d44;background:#eaf6ee}.student-progress-overview{grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;display:grid}.student-progress-overview div{background:#f7f9fa;border-radius:8px;align-content:center;gap:5px;min-height:76px;padding:12px;display:grid}.student-progress-overview strong{font-size:24px;line-height:1}.student-progress-overview span{color:#687684;font-size:13px;font-weight:700}.student-detail-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;display:grid}.analysis-block,.review-suggestion-list,.lesson-progress-list{gap:10px;min-width:0;display:grid}.analysis-block{background:#fbfcfd;border:1px solid #edf1f4;border-radius:8px;align-content:start;padding:12px}.analysis-block p,.review-suggestion-list p{color:#687684;margin:0;font-size:14px;line-height:1.5}.analysis-row,.review-suggestion-row,.lesson-progress-row{background:#f3f7fa;border-radius:8px;justify-content:space-between;align-items:center;gap:10px;min-width:0;padding:9px 10px;display:flex}.analysis-row span,.lesson-progress-row span,.review-suggestion-row span{color:#263849;min-width:0;font-size:14px;font-weight:700;line-height:1.4}.analysis-row .coach-icon-button,.review-suggestion-row .coach-icon-button{flex:none;min-height:34px;font-size:13px}.analysis-row .coach-icon-button.is-created,.review-suggestion-row .coach-icon-button.is-created{color:#1f6d44;cursor:default;opacity:1;background:#eaf6ee;border-color:#bfdcc8}.review-suggestion-row>div{gap:4px;min-width:0;display:grid}.review-suggestion-row strong{font-size:15px}.review-suggestion-row span{color:#687684;font-weight:650}.lesson-progress-row strong{flex:none;font-size:15px}.lesson-progress-row em{color:#4d5a66;flex:none;font-size:13px;font-style:normal;font-weight:720}.followup-workbench{gap:14px;padding-top:4px;display:grid}.followup-heading{background:#fff;border:1px solid #dfe6eb;border-radius:8px;justify-content:space-between;align-items:center;gap:14px;min-height:58px;padding:14px 16px;display:flex}.followup-heading h2{margin:0;font-size:23px;line-height:1.2}.followup-state{color:#1f6d44;background:#eaf6ee;border-radius:999px;align-items:center;min-height:30px;padding:0 11px;font-size:14px;font-weight:760;display:inline-flex}.followup-state.state-loading{color:#1f5b89;background:#e8f2fb}.followup-state.state-error{color:#8c2f29;background:#fdecea}.followup-filter-bar{background:#fff;border:1px solid #dfe6eb;border-radius:8px;grid-template-columns:auto repeat(4,minmax(0,1fr)) auto;align-items:end;gap:10px;padding:12px;display:grid}.followup-filter-bar>svg{color:#38576f;margin:0 2px 11px}.followup-filter-bar label{gap:5px;min-width:0;display:grid}.followup-filter-bar label span{color:#687684;font-size:13px;font-weight:720}.followup-filter-bar select{color:#243849;width:100%;min-height:38px;font:inherit;background:#fff;border:1px solid #cfd9e1;border-radius:8px;padding:0 10px;font-size:14px;font-weight:700}.followup-filter-bar select:focus-visible{outline-offset:2px;outline:4px solid #1f78d138}.filter-reset-button{align-self:end;min-height:38px}.filter-reset-button:disabled{cursor:default;opacity:.45}.followup-filter-summary{color:#1f5b89;background:#f1f7fc;border:1px solid #d9e5ef;border-radius:8px;align-items:center;min-height:36px;padding:0 12px;font-size:14px;font-weight:730;display:flex}.followup-overview{grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;display:grid}.followup-overview div{background:#fff;border:1px solid #dfe6eb;border-radius:8px;align-content:center;gap:5px;min-height:76px;padding:12px 14px;display:grid}.followup-overview strong{font-size:27px;line-height:1}.followup-overview span{color:#687684;font-size:14px;font-weight:700}.followup-list{gap:10px;display:grid}.followup-card{background:#fff;border:1px solid #dfe6eb;border-left:6px solid #708292;border-radius:8px;gap:12px;padding:16px;display:grid}.followup-card.priority-urgent{border-left-color:#b8493f}.followup-card.priority-high{border-left-color:#d68b19}.followup-card.priority-normal{border-left-color:#1f6d44}.followup-card-main{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.followup-badges{flex-wrap:wrap;justify-content:flex-end;gap:7px;display:flex}.followup-status,.followup-priority{white-space:nowrap;border-radius:999px;align-items:center;min-height:30px;padding:0 10px;font-size:13px;font-weight:760;display:inline-flex}.followup-status.status-pending{color:#7a4b08;background:#fff3d9}.followup-status.status-in_progress{color:#1f5b89;background:#e8f2fb}.followup-status.status-resolved{color:#1f6d44;background:#eaf6ee}.followup-status.status-dismissed{color:#5c6874;background:#eef2f5}.followup-priority.priority-urgent{color:#8c2f29;background:#fdecea}.followup-priority.priority-high{color:#7a4b08;background:#fff3d9}.followup-priority.priority-normal,.followup-priority.priority-low{color:#263849;background:#f0f4f7}.followup-reason,.followup-note{border-radius:8px;margin:0;font-size:15px;line-height:1.5}.followup-reason{color:#263849}.followup-note{color:#435260;background:#f7f9fa;padding:10px 12px}.followup-meta{flex-wrap:wrap;gap:7px;display:flex}.followup-meta span{color:#4d5a66;background:#f0f4f7;border-radius:8px;align-items:center;min-height:28px;padding:0 9px;font-size:13px;font-weight:720;display:inline-flex}.followup-meta .meta-overdue{color:#8c2f29;background:#fdecea}.followup-actions{flex-wrap:wrap;gap:8px;padding-top:2px;display:flex}.followup-actions .coach-icon-button:disabled{cursor:wait;opacity:.62}@media (width<=520px){.app-shell{padding:0}.lesson-frame,.course-center-frame{width:100%;min-height:100vh;box-shadow:none;border:0;border-radius:0;padding:16px}.course-center-header h1{font-size:22px}.next-lesson-panel{grid-template-columns:1fr}.course-progress-ring{width:78px;height:78px}.next-lesson-copy h2{font-size:24px}.lesson-list-row{grid-template-columns:auto 1fr}.learning-overview-grid{grid-template-columns:1fr}.learning-next-action,.learning-record-row{grid-template-columns:auto minmax(0,1fr)}.lesson-row-action{grid-column:1/-1;width:100%}.lesson-header h1{font-size:24px}.audio-control-row{margin-top:10px}.prompt-panel{grid-template-columns:1fr}.audio-button{grid-auto-flow:column;width:100%;min-height:58px}.instruction-row{grid-template-columns:1fr}.instruction-row .secondary-action{width:100%}.share-history-stats{grid-template-columns:1fr}.share-history-entry-top,.share-history-entry-meta{flex-direction:column}.assist-note{font-size:17px}.intersection-scene{min-height:330px}.choice-button{font-size:32px}.character-card{font-size:68px}}@media (width<=760px){.coach-shell{padding:14px}.coach-header,.coach-toolbar,.coach-card-main{flex-direction:column;align-items:stretch}.coach-header h1{font-size:24px}.coach-back-link,.coach-icon-button{justify-content:center}.coach-overview,.coach-metrics,.coach-detail-grid,.student-detail-layout,.student-progress-overview,.student-detail-grid,.followup-overview,.followup-filter-bar{grid-template-columns:repeat(2,minmax(0,1fr))}.followup-filter-bar>svg{display:none}.filter-reset-button{width:100%}.followup-heading,.student-detail-heading,.student-detail-main,.followup-card-main{flex-direction:column;align-items:stretch}.followup-badges{justify-content:flex-start}.followup-actions .coach-icon-button{flex:140px}.student-form,.student-table-row{grid-template-columns:1fr}.student-table-row.header{display:none}}@media (width<=480px){.coach-overview,.coach-metrics,.coach-detail-grid,.student-detail-layout,.student-progress-overview,.student-detail-grid,.followup-overview,.followup-filter-bar{grid-template-columns:1fr}.analysis-row,.review-suggestion-row,.lesson-progress-row{flex-direction:column;align-items:stretch}.analysis-row .coach-icon-button,.review-suggestion-row .coach-icon-button{width:100%}}
