@import"https://fonts.googleapis.com/css2?family=Yomogi&family=Zen+Maru+Gothic:wght@400;500;700;900&display=swap";:root{--font-sans: "Inter", "Noto Sans JP", "Yu Gothic UI", "Meiryo", system-ui, sans-serif;--color-bg: #f6f5f2;--color-surface: #ffffff;--color-surface-soft: #fbfaf7;--color-card-blue: #f4f9ff;--color-card-beige: #fff9ee;--color-text: #232323;--color-muted: #6b6a66;--color-border: #dedbd3;--color-accent: #16645a;--color-accent-strong: #0f4f47;--color-link-bg: #eef7f4;--color-note-bg: #fff7df;--color-note-border: #e3bd52;--shadow-soft: 0 10px 28px rgb(35 35 35 / 8%);--radius-card: 8px;--radius-button: 7px;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--text-xs: .78rem;--text-sm: .9rem;--text-md: 1rem;--text-lg: 1.16rem;--text-xl: 1.42rem;--line-body: 1.72;--line-body-em: 1.72em;--line-tight: 1.35}*{box-sizing:border-box}html{min-width:0;background:var(--color-bg);color:var(--color-text);font-family:var(--font-sans);font-size:16px;letter-spacing:0}body{margin:0;overflow-x:hidden}button,input,textarea{font:inherit}a{color:var(--color-accent-strong)}.app-shell{min-height:100vh}.app-shell--side-viewer{background:var(--color-bg)}.app-main{width:min(100%,920px);margin:0 auto;padding:88px clamp(12px,3vw,32px) 48px}.app-shell--side-viewer .app-main{width:min(100%,360px);padding:50px 8px 32px}.app-main:has(.teacher-editor){padding-top:0}.app-main:has(.import-page),.app-main:has(.teacher-preview-page){padding-top:0}.app-main:has(.import-page) .viewer-header{display:none}.app-main:has(.teacher-preview-page) .viewer-header,.app-main:has(.teacher-preview-empty) .viewer-header{display:none}.app-main:has(.catalog-page--teacher){width:100%;padding-top:0;padding-bottom:0;padding-inline:0}.app-main:has(.student-login-cover){width:100%;padding:0}.app-main:has(.teacher-material-folder-setup){width:100%;min-height:100vh;display:grid;place-items:center;padding:32px 16px}.app-shell--side-viewer .app-main:has(.student-login-cover){width:100%;padding:0}.app-version{position:fixed;right:10px;bottom:8px;color:var(--color-muted);font-size:var(--text-xs);opacity:.75}.published-local-preview-notice{position:fixed;top:10px;right:10px;z-index:35;display:flex;max-width:min(420px,calc(100vw - 20px));gap:8px;align-items:center;border:1px solid rgb(70 90 84 / 18%);border-radius:6px;background:#ffffffeb;box-shadow:0 6px 18px #2837321a;color:#536761;font-size:11px;line-height:1.35;padding:7px 9px;pointer-events:none}.published-local-preview-notice strong{flex:0 0 auto;color:#314842;font-weight:900}.published-local-preview-notice span{min-width:0}.app-shell--side-viewer .published-local-preview-notice{left:8px;right:8px;justify-content:center;font-size:10px}.visually-hidden{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap}.viewer-header{position:fixed;top:0;left:0;z-index:20;width:100%;border-bottom:1px solid var(--color-border);background:#fffffff0;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 4px 18px #2323230d}.viewer-header__row,.viewer-header__meta{width:min(100%,920px);margin:0 auto;padding-inline:clamp(12px,3vw,32px)}.app-shell--side-viewer .viewer-header__row,.app-shell--side-viewer .viewer-header__meta{width:min(100%,360px);padding-inline:8px}.viewer-header__row{display:flex;min-height:54px;align-items:center;justify-content:space-between;gap:var(--space-3)}.viewer-header__row .button{white-space:nowrap}.viewer-font--sans{font-family:Yu Gothic,Meiryo,system-ui,sans-serif}.viewer-font--serif{font-family:Yu Mincho,Hiragino Mincho ProN,serif}.viewer-font--mono{font-family:ui-monospace,SFMono-Regular,Consolas,Yu Gothic,monospace}.viewer-font--softHandwriting{font-family:Yomogi,Zen Maru Gothic,Kiwi Maru,Hachi Maru Pop,"M PLUS Rounded 1c",Hiragino Maru Gothic ProN,Yu Gothic,sans-serif}.viewer-header__actions{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:6px}.viewer-header__title{min-width:0;overflow:hidden;font-weight:750;line-height:var(--line-tight);text-overflow:ellipsis;white-space:nowrap}.viewer-header__meta{display:grid;grid-template-columns:auto 1fr;align-items:center;gap:var(--space-3);padding-bottom:10px}.viewer-header--compact .viewer-header__row{min-height:30px}.viewer-header--compact .viewer-header__title{font-size:var(--text-sm);font-weight:750}.viewer-header--compact .viewer-header__row,.viewer-header--compact .viewer-header__meta{padding-inline:clamp(10px,2vw,24px)}.viewer-header--compact .viewer-header__meta{gap:8px;padding-bottom:5px}.app-shell--side-viewer .viewer-header__actions .button{min-height:28px;padding:4px 7px;font-size:10px}.app-shell--side-viewer .viewer-header__title{font-size:var(--text-sm)}.app-shell--side-viewer .viewer-header__meta{grid-template-columns:auto minmax(0,1fr);gap:7px}.position-count{color:var(--color-muted);font-size:var(--text-sm);font-variant-numeric:tabular-nums;white-space:nowrap}.progress{height:6px;overflow:hidden;border-radius:999px;background:#e8e5dc}.progress span{display:block;height:100%;border-radius:inherit;background:var(--color-accent);transition:width .18s ease}.button{min-height:42px;border:1px solid var(--color-accent);border-radius:var(--radius-button);background:var(--color-accent);color:#fff;cursor:pointer;font-weight:700;padding:9px 14px;box-shadow:0 2px #0000002e;transform:translateY(0);transition:background-color .12s ease,box-shadow .12s ease,transform .12s ease}.button--ghost,.button--secondary{border-color:var(--color-border);background:var(--color-surface);color:var(--color-text)}.button--tiny{min-height:28px;padding:4px 8px;font-size:var(--text-xs)}.button--danger{border-color:#e8b7b0;background:#fff3f1;color:#9b1c1c}.button:hover:not(:disabled){filter:brightness(.98)}.button:active:not(:disabled){box-shadow:0 0 #0000;transform:translateY(2px)}.catalog-page h1{margin:0 0 var(--space-5);font-size:var(--text-xl);line-height:var(--line-tight)}.catalog-list{display:grid;gap:4px}.catalog-section{display:grid;gap:5px;margin-top:6px}.catalog-section h2,.catalog-section summary{color:var(--color-muted);font-size:var(--text-xs);font-weight:900}.catalog-section summary{cursor:pointer;list-style-position:inside}.catalog-section summary::marker{font-size:10px}.catalog-section--archived{border-top:1px dashed var(--color-border);padding-top:6px}.catalog-section--deleted{border-top:1px dashed #e3b9b9;padding-top:6px}.student-toc{display:grid;gap:var(--space-2);margin-bottom:var(--space-4)}.student-toc__list{display:grid;gap:6px;margin:0;padding:0;list-style:none}.student-toc__open{display:grid;grid-template-columns:56px minmax(0,1fr) auto;align-items:center;gap:var(--space-2);width:100%;min-height:42px;border:1px solid var(--color-border);border-radius:var(--radius-card);background:#ffffffdb;color:var(--color-text);cursor:pointer;padding:7px 10px;text-align:left}.student-toc__item--current .student-toc__open{border-color:var(--color-accent);background:#eef7f4}.student-toc__order,.student-toc__status{color:var(--color-muted);font-size:var(--text-xs);font-weight:900;white-space:nowrap}.student-toc__order{display:grid;grid-template-columns:32px 16px;align-items:center;gap:2px;font-variant-numeric:tabular-nums}.student-toc__check{display:inline-block;min-width:16px;color:var(--color-accent-strong);text-align:center}.student-toc__title{min-width:0;overflow:hidden;font-size:var(--text-sm);font-weight:800;text-overflow:ellipsis;white-space:nowrap}.student-toc__empty{border:1px dashed var(--color-border);border-radius:var(--radius-card);background:#ffffffb3;color:var(--color-muted);font-size:var(--text-sm);font-weight:800;padding:var(--space-4)}.student-toc--compact{gap:3px;margin-bottom:var(--space-2)}.student-toc--compact .student-toc__list{gap:2px}.student-toc--compact .student-toc__open{grid-template-columns:38px minmax(0,1fr) auto;gap:3px;min-height:19px;padding:1px 4px;border-radius:5px}.student-toc--compact .student-toc__order,.student-toc--compact .student-toc__status{font-size:8px;line-height:1.1}.student-toc--compact .student-toc__order{grid-template-columns:24px 10px;gap:1px}.student-toc--compact .student-toc__title{font-size:9px;line-height:1.15;white-space:nowrap;text-overflow:ellipsis}.student-toc--compact .student-toc__status{grid-column:3;justify-self:start}.student-toc__separator{min-height:8px;border-radius:999px;background:#dedbd3;opacity:.75}.catalog-page--side-viewer{display:grid;gap:var(--space-3)}.catalog-page--side-viewer .student-toc{gap:5px;margin-bottom:var(--space-2)}.catalog-page--side-viewer .student-toc__open{grid-template-columns:42px minmax(0,1fr);gap:5px;min-height:34px;padding:5px 7px}.catalog-page--side-viewer .student-toc__order{grid-template-columns:26px 10px;gap:1px;font-size:9px}.catalog-page--side-viewer .student-toc__title{font-size:12px;line-height:1.35;white-space:normal}.catalog-page--side-viewer .student-toc__status{grid-column:2;font-size:9px}.catalog-page--side-viewer .student-toc--compact .student-toc__open{grid-template-columns:36px minmax(0,1fr);min-height:24px}.catalog-page--side-viewer .student-toc--compact .student-toc__title{font-size:10px;white-space:normal}.student-toc--compact .student-toc__separator{min-height:5px}.viewer-font--softHandwriting .student-toc__title,.viewer-font--softHandwriting .lesson-card__body-text,.viewer-font--softHandwriting .lesson-card p{line-height:1.82}.viewer-font--softHandwriting .lesson-card__title-row{letter-spacing:0}.student-login-cover{display:grid;min-height:100vh;place-items:center;padding:clamp(18px,5vw,56px);background:radial-gradient(circle at 50% 14%,rgb(255 255 255 / 42%),transparent 34%),#fbf3dc;color:#fff;font-family:Yomogi,Zen Maru Gothic,Kiwi Maru,Hachi Maru Pop,"M PLUS Rounded 1c",Hiragino Maru Gothic ProN,Yu Gothic,sans-serif}.student-login-cover__book{display:grid;justify-items:center;align-content:center;gap:clamp(26px,5vh,46px);width:min(90vw,640px);min-height:min(78vh,720px);border:clamp(8px,1.8vw,14px) solid #c8eadc;border-radius:clamp(28px,6vw,52px);background:#d99aa5;padding:clamp(44px,8vw,76px) clamp(26px,7vw,58px);box-shadow:0 24px 56px #73544a29;text-align:center}.student-login-cover__title{display:grid;gap:.08em;width:100%;font-size:clamp(2rem,5.2vw,3rem);font-weight:700;line-height:1.14;text-shadow:0 2px 0 rgb(182 115 126 / 22%)}.student-login-cover__line{display:block;white-space:nowrap}.student-login-cover__line--intro+.student-login-cover__line--intro{margin-top:-.03em}.student-login-cover__maybe{margin-top:.72em;font-size:.38em;font-weight:700;letter-spacing:0;white-space:nowrap}.student-login-cover__line--maya{margin-top:.06em;font-size:1.08em}.student-login-cover__login{display:grid;justify-items:center;gap:10px;align-self:start;width:min(100%,230px)}.student-login-cover__login label{font-size:clamp(.86rem,2.5vw,1.04rem);font-weight:700;line-height:1.25}.student-login-cover__login input{width:min(100%,190px);min-height:34px;border:1px solid rgb(255 255 255 / 76%);border-radius:999px;background:#fffffff0;color:#5d4c4d;font-family:Yu Gothic,sans-serif;font-size:.95rem;padding:6px 14px;text-align:center;box-shadow:inset 0 1px 4px #78575b1a}.student-login-cover__login input:focus-visible{border-color:#fff;outline:3px solid rgb(255 255 255 / 28%)}.student-login-cover__login button{min-width:86px;min-height:32px;border:0;border-radius:999px;background:#fff7e7;color:#bf6f7e;cursor:pointer;font-size:.92rem;font-weight:800;padding:5px 20px;box-shadow:0 5px 12px #89585e24}.student-login-cover__login button:hover,.student-login-cover__login button:focus-visible{background:#fffaf0;outline:3px solid rgb(255 255 255 / 28%)}.student-login-cover__error{min-height:1.4em;margin:0;color:#fff7e7;font-size:.82rem;font-weight:700;line-height:1.35}.teacher-material-folder-setup{width:min(720px,100%)}.teacher-material-folder-setup__panel{display:grid;gap:18px;padding:28px;border:1px solid var(--color-border);border-radius:8px;background:var(--color-surface);box-shadow:var(--shadow-soft)}.teacher-material-folder-setup__copy{display:grid;gap:8px}.teacher-material-folder-setup__eyebrow{margin:0;color:var(--color-muted);font-size:var(--text-sm);font-weight:700}.teacher-material-folder-setup h1{margin:0;font-size:1.8rem}.teacher-material-folder-setup__copy p:not(.teacher-material-folder-setup__eyebrow){margin:0;color:var(--color-text);line-height:1.7}.teacher-material-folder-setup__path{display:grid;gap:6px;min-width:0;padding:12px 14px;border:1px solid var(--color-border);border-radius:8px;background:var(--color-surface-soft)}.teacher-material-folder-setup__path strong{font-size:var(--text-sm)}.teacher-material-folder-setup__path p{margin:0;overflow-wrap:anywhere;color:var(--color-muted)}.teacher-material-folder-setup__actions{display:flex;flex-wrap:wrap;gap:10px}.teacher-material-folder-setup__message{min-height:20px;margin:0;color:var(--color-muted);font-weight:700}.app-shell--side-viewer .student-login-cover{min-height:100vh;min-height:100svh;padding:10px}.app-shell--side-viewer .student-login-cover__book{align-content:center;gap:clamp(18px,4vh,30px);width:min(100%,340px);min-height:calc(100svh - 20px);border-width:8px;border-radius:30px;padding:clamp(30px,7vh,54px) 18px clamp(24px,5vh,40px)}.app-shell--side-viewer .student-login-cover__title{gap:.08em;font-size:clamp(1.58rem,8.5vw,1.95rem);line-height:1.15}.app-shell--side-viewer .student-login-cover__line{white-space:normal}.app-shell--side-viewer .student-login-cover__maybe{margin-top:.66em;font-size:.42em}.app-shell--side-viewer .student-login-cover__line--maya{font-size:1.05em}.app-shell--side-viewer .student-login-cover__login{gap:8px;width:min(100%,210px)}.app-shell--side-viewer .student-login-cover__login input{width:min(100%,180px);min-height:32px}.app-shell--side-viewer .student-login-cover__login button{min-width:78px;min-height:30px;padding:4px 16px}.app-shell--side-viewer .student-identity{gap:var(--space-3)}.app-shell--side-viewer .student-identity__header h1{font-size:var(--text-lg)}.app-shell--side-viewer .student-identity__header p,.app-shell--side-viewer .student-identity__search label,.app-shell--side-viewer .student-identity__temporary label{font-size:12px}.app-shell--side-viewer .student-identity__search,.app-shell--side-viewer .student-identity__candidate{grid-template-columns:1fr}.app-shell--side-viewer .student-identity__candidate{gap:2px}.student-identity{display:grid;gap:var(--space-4)}.student-identity__header{display:grid;gap:4px}.student-identity__header h1{margin:0;font-size:var(--text-xl);line-height:var(--line-tight)}.student-identity__header p{margin:0;color:var(--color-muted);font-size:var(--text-sm);line-height:var(--line-body)}.student-identity__search{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:var(--space-2);align-items:end}.student-identity__search label,.student-identity__temporary label{display:grid;gap:5px;color:var(--color-muted);font-size:var(--text-sm);font-weight:800}.student-identity input{width:100%;border:1px solid var(--color-border);border-radius:var(--radius-button);background:#fff;color:var(--color-text);padding:10px 11px}.student-identity__results{display:grid;gap:7px}.student-identity__candidate{display:grid;grid-template-columns:minmax(0,1fr) auto auto;gap:var(--space-2);align-items:center;min-height:44px;border:1px solid var(--color-border);border-radius:var(--radius-card);background:#ffffffdb;color:var(--color-text);cursor:pointer;padding:8px 10px;text-align:left}.student-identity__candidate span,.student-identity__temporary p{margin:0;color:var(--color-muted);font-size:var(--text-sm)}.student-identity__temporary{display:grid;gap:var(--space-2);border:1px dashed var(--color-border);border-radius:var(--radius-card);background:#ffffffb3;padding:var(--space-4)}.lesson-completion{display:flex;align-items:center;flex-direction:column;gap:var(--space-2);justify-content:center;padding:var(--space-5) 0 var(--space-2)}.lesson-completion__check{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--color-border);border-radius:var(--radius-button);background:#fff;color:var(--color-text);cursor:pointer;font-size:1rem;font-weight:900;padding:10px 14px}.lesson-completion__check input{width:20px;height:20px}.lesson-completion__done{border:1px solid #c7d8d3;border-radius:var(--radius-button);background:#eef7f4;color:var(--color-accent-strong);font-weight:900;padding:10px 14px}.lesson-completion__next{min-width:180px}.lesson-completion__hint{margin:0;color:var(--color-muted);font-size:var(--text-sm);font-weight:700}.lesson-completion__error{color:#b42318;font-size:.95rem;font-weight:700}.catalog-message{margin:0 0 var(--space-3);color:var(--color-muted);font-size:var(--text-sm);font-weight:700}.catalog-selection-bar{display:grid;gap:3px;margin:0;color:var(--color-muted);font-size:var(--text-xs);font-weight:800}.catalog-selection-bar__row{display:flex;align-items:center;gap:3px}.catalog-selection-bar__row--status{gap:18px}.catalog-selection-bar__row--operations{gap:5px}.catalog-selection-bar__row--operations{flex-wrap:nowrap;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none}.catalog-selection-bar__row--operations::-webkit-scrollbar{width:0;height:0}.catalog-selection-bar__chip{border:1px solid var(--color-border);border-radius:var(--radius-button);background:#eef7f4;color:var(--color-text);cursor:default;padding:2px 7px;white-space:nowrap}.catalog-selection-bar__stat{display:inline-flex;align-items:baseline;gap:4px;color:var(--color-muted);cursor:default;font-size:11px;font-weight:800;line-height:1.2;white-space:nowrap}.catalog-selection-bar__stat strong{color:var(--color-text);font-size:12px;font-weight:900}.catalog-selection-bar__message{flex:1 1 160px;min-width:0;overflow:hidden;color:var(--color-muted);font-size:11px;font-weight:800;line-height:1.2;text-overflow:ellipsis;white-space:nowrap}.catalog-selection-bar .button{min-height:24px;font-size:11px;padding:2px 7px;white-space:nowrap}.catalog-page--teacher{display:flex;flex-direction:column;width:100%;height:100vh;min-height:0;overflow:hidden}.teacher-page-header{position:sticky;top:0;z-index:35;display:grid;gap:7px;border-bottom:1px solid var(--color-border);background:#faf8f1f5;padding:6px clamp(12px,3vw,32px) 8px;box-shadow:0 4px 18px #2323230d;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.teacher-page-header__tabs{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-3)}.teacher-page-header__tab-group,.teacher-page-header__actions{display:flex;flex-wrap:wrap;gap:6px}.teacher-page-header__tab-group--side{margin-left:auto;border-left:1px solid var(--color-border);padding-left:var(--space-3)}.teacher-page-header__tab{min-height:24px;border:0;border-bottom:2px solid transparent;border-radius:0;background:transparent;color:var(--color-muted);cursor:pointer;font-size:var(--text-xs);font-weight:850;padding:2px 0 4px;white-space:nowrap}.teacher-page-header__tab--active{border-bottom-color:var(--color-accent-strong);color:var(--color-accent-strong)}.teacher-page-header__body{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3)}.teacher-page-header__copy{min-width:0}.teacher-page-header h1{margin:0;font-size:var(--text-lg);line-height:var(--line-tight)}.teacher-page-header p{margin:2px 0 0;overflow:hidden;color:var(--color-muted);font-size:var(--text-sm);font-weight:700;line-height:var(--line-tight);text-overflow:ellipsis;white-space:nowrap}.teacher-page-header__actions{justify-content:flex-end}.teacher-page-header__actions .button{min-height:34px;padding:6px 11px;font-size:var(--text-sm);white-space:nowrap}.teacher-page-header--compact{gap:5px;padding-block:5px 6px}.teacher-page-header--compact .teacher-page-header__tab{min-height:22px;padding-bottom:3px}.teacher-page-header--compact .teacher-page-header__tabs,.teacher-page-header--compact .teacher-page-header__actions{flex-wrap:nowrap;gap:4px;overflow-x:auto;scrollbar-width:none}.teacher-page-header--compact .teacher-page-header__tabs::-webkit-scrollbar,.teacher-page-header--compact .teacher-page-header__actions::-webkit-scrollbar{width:0;height:0}.teacher-page-header--compact .teacher-page-header__body{align-items:start}.teacher-page-header--compact h1{font-size:var(--text-md)}.teacher-page-header--compact p{font-size:var(--text-xs)}.teacher-page-header--compact .teacher-page-header__actions .button{min-height:26px;padding:3px 7px;font-size:11px}.catalog-teacher-sticky{position:sticky;top:0;z-index:20;display:grid;width:min(100%,920px);margin-inline:auto;gap:4px;border-bottom:1px solid var(--color-border);background:#faf8f1f5;padding:0 0 6px;box-shadow:0 4px 18px #2323230d;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.catalog-teacher-sticky .teacher-page-header{position:static;width:100%;margin:0;border-bottom:1px solid var(--color-border);background:transparent;box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none}.catalog-teacher-sticky .teacher-hint{display:none}.catalog-teacher-sticky .teacher-tools,.catalog-teacher-sticky .catalog-selection-bar,.catalog-teacher-sticky .catalog-message{width:100%;padding-inline:clamp(12px,3vw,32px)}.catalog-teacher-scroll .catalog-section{width:min(100%,920px);margin-inline:auto;padding-inline:clamp(12px,3vw,32px)}.catalog-teacher-scroll{flex:1 1 auto;min-height:0;overflow-y:auto;scrollbar-width:none;-ms-overflow-style:none;padding-bottom:var(--space-5)}.catalog-teacher-scroll::-webkit-scrollbar{width:0;height:0}.teacher-side-panel{position:fixed;top:190px;right:clamp(6px,1.2vw,18px);bottom:0;z-index:12;display:flex;flex-direction:column;width:min(310px,max(300px,calc((100vw - 920px)/2 - 14px)));min-width:0;overflow:hidden;border-left:1px solid var(--color-border);background:#faf8f1f0;padding:8px 4px 14px 6px;scrollbar-width:thin}.teacher-side-panel__body{display:grid;grid-template-rows:auto minmax(0,1fr);gap:7px;flex:1 1 auto;min-height:0}.teacher-side-panel__header{border-bottom:1px solid var(--color-border);padding-bottom:6px}.teacher-side-panel h2,.teacher-side-panel h3,.teacher-side-panel p{margin:0}.teacher-side-panel h2{font-size:13px;line-height:1.25}.teacher-side-panel h3{color:var(--color-muted);font-size:11px;font-weight:900;line-height:1.25}.teacher-side-panel p{color:var(--color-muted);font-size:11px;font-weight:700;line-height:1.45}.teacher-side-section{display:flex;flex-direction:column;gap:6px;min-height:0;border:1px solid var(--color-border);border-radius:7px;background:#ffffffbd;padding:7px}.teacher-side-dl{display:grid;gap:3px;margin:0}.teacher-side-dl div{display:grid;grid-template-columns:48px minmax(0,1fr);gap:6px;align-items:baseline}.teacher-side-dl dt{color:var(--color-muted);font-size:10px;font-weight:900}.teacher-side-dl dd{min-width:0;margin:0;overflow:hidden;color:var(--color-text);font-size:11px;font-weight:800;text-overflow:ellipsis;white-space:nowrap}.teacher-side-add,.teacher-side-option__edit,.teacher-side-group__edit,.teacher-side-course__edit,.teacher-side-pair__edit{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:4px}.teacher-side-option__edit{grid-template-columns:minmax(0,1fr) auto auto;width:100%}.teacher-side-add--pair{grid-template-columns:minmax(0,.8fr) minmax(0,1.1fr) auto}.teacher-side-add--course{grid-template-columns:minmax(0,1fr) auto}.teacher-side-add--group{grid-template-columns:minmax(0,1fr) minmax(72px,.8fr) auto}.teacher-side-group__edit{grid-column:1 / -1;grid-template-columns:minmax(0,1fr)}.teacher-side-course__edit,.teacher-side-pair__edit{grid-template-columns:minmax(0,.8fr) minmax(0,1.1fr) auto auto;grid-column:1 / -1}.teacher-side-course__edit{grid-template-columns:minmax(0,1fr) auto auto}.teacher-side-add input,.teacher-side-add select,.teacher-side-option__edit input,.teacher-side-group__edit input,.teacher-side-course__edit input,.teacher-side-pair__edit input{min-width:0;min-height:25px;border:1px solid var(--color-border);border-radius:var(--radius-button);background:#fff;color:var(--color-text);font-size:11px;padding:3px 7px}.teacher-side-add select{padding-inline:4px}.teacher-side-list{display:grid;gap:4px;flex:1 1 auto;max-height:none;min-height:0;overflow-y:auto;padding-right:2px;scrollbar-width:thin}.teacher-side-validation{margin:2px 0 0;color:#a03b2e;font-size:10px;font-weight:800;line-height:1.35}.teacher-side-option{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:5px;align-items:center;min-height:29px;border-top:1px solid rgb(222 219 211 / 70%);padding-top:5px}.teacher-side-option--archived{opacity:.62}.teacher-side-option__text{display:flex;min-width:0;align-items:center;gap:5px}.teacher-side-option__text--stack{display:grid;gap:2px;align-items:start}.teacher-side-option__text strong{min-width:0;overflow:hidden;font-size:11px;text-overflow:ellipsis;white-space:nowrap}.teacher-side-option__text span{min-width:0;overflow:hidden;color:var(--color-muted);font-size:10px;font-weight:800;text-overflow:ellipsis;white-space:nowrap}.teacher-side-option__text code{color:var(--color-muted);font-size:10px;font-weight:800;white-space:nowrap}.teacher-side-option__actions{display:flex;gap:3px;justify-content:flex-end;flex-wrap:wrap}.teacher-side-check-list{display:grid;max-height:124px;overflow:auto;gap:3px;border:1px solid var(--color-border);border-radius:7px;background:#fff;padding:5px}.teacher-side-check{display:grid;grid-template-columns:auto minmax(0,1fr);gap:5px;align-items:start;color:var(--color-text);font-size:10px;font-weight:800;line-height:1.25}.teacher-side-check input{width:13px;height:13px;margin:0}.teacher-side-check span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.teacher-side-course-head,.teacher-side-course,.teacher-side-pair-head,.teacher-side-pair{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:5px;align-items:center}.teacher-side-course-head,.teacher-side-pair-head{grid-template-columns:minmax(0,.8fr) minmax(0,1.1fr) 104px;color:var(--color-muted);font-size:10px;font-weight:900}.teacher-side-course-head{grid-template-columns:minmax(0,1fr) 104px}.teacher-side-course,.teacher-side-pair{min-height:29px;border-top:1px solid rgb(222 219 211 / 70%);padding-top:5px}.teacher-side-course{position:relative;grid-template-columns:minmax(0,1fr);grid-auto-flow:row;grid-auto-rows:max-content;align-items:stretch;gap:5px;min-height:54px;border:1px solid rgb(222 219 211 / 82%);border-radius:7px;background:#ffffffc2;padding:6px}.teacher-side-course--confirming-delete{z-index:2}.teacher-side-course__main-row{display:grid;grid-template-columns:minmax(42px,1fr) max-content;gap:4px;align-items:center}.teacher-side-course__id{min-width:0;overflow:hidden;color:var(--color-text);font-size:12px;font-weight:900;text-overflow:ellipsis;white-space:nowrap}.teacher-side-course__badges{display:flex;min-width:0;gap:1px;justify-content:flex-end;flex-wrap:nowrap}.teacher-side-badge{display:inline-flex;align-items:center;min-height:16px;border:1px solid rgb(120 145 137 / 18%);border-radius:999px;background:#e5f0ecb3;color:#5b6f68;font-size:7.5px;font-weight:900;line-height:1;padding:1px 3px;white-space:nowrap}.teacher-side-badge--quiet{border-color:#857e7433;background:#f1eee8cc;color:#7a7166}.teacher-side-project-root{display:grid;grid-template-columns:minmax(0,1fr) max-content;gap:6px;align-items:center;border:1px solid rgb(120 145 137 / 18%);border-radius:6px;background:#f8faf6c7;padding:6px}.teacher-side-project-root strong{display:block;color:#536761;font-size:10px;font-weight:900}.teacher-side-project-root p{margin:2px 0 0;color:#6e7a75;font-size:9px;font-weight:700;line-height:1.35;overflow-wrap:anywhere;word-break:break-word}.teacher-side-publish-message{display:grid;gap:4px;flex:0 0 auto;margin-top:auto;border:1px solid rgb(120 145 137 / 18%);border-radius:6px;background:#f8faf6d1;padding:6px}.teacher-side-publish-message h4{margin:0;color:#536761;font-size:10px;font-weight:900;line-height:1.25}.teacher-side-publish-message p{max-height:96px;overflow-y:auto;white-space:pre-line;color:#65736d;font-size:10px;font-weight:700;line-height:1.45;scrollbar-width:thin}.teacher-side-publish-message__preview{display:grid;gap:4px;border-top:1px solid rgb(120 145 137 / 18%);padding-top:6px}.teacher-side-publish-message__preview p{max-height:none;margin:0;overflow:visible;color:#536761;font-size:9px}.teacher-side-course__values,.teacher-side-pair__values{display:grid;grid-template-columns:minmax(0,.8fr) minmax(0,1.1fr) auto;gap:5px;min-width:0;align-items:center}.teacher-side-course__actions-row{display:flex;gap:3px;align-items:center;flex-wrap:nowrap;min-width:0}.teacher-side-course__actions-row .button{flex:0 0 auto;min-height:22px;padding:2px;font-size:8px;line-height:1;white-space:nowrap}.teacher-side-course__values span,.teacher-side-pair__values strong,.teacher-side-pair__values span{min-width:0;overflow:hidden;font-size:11px;text-overflow:ellipsis;white-space:nowrap}.teacher-side-pair__values strong{font-weight:900}.teacher-side-course__delete-confirm{grid-column:1 / -1;position:relative;z-index:2;display:grid;gap:5px;border:1px solid rgb(190 83 70 / 35%);border-radius:6px;background:#fff7f4d1;padding:6px}.teacher-side-course__delete-confirm p{margin:0;color:#8f332b;font-size:10px;font-weight:800;line-height:1.35}.teacher-side-course__status,.teacher-side-password-status{color:var(--color-muted);font-size:10px;font-weight:900}.teacher-side-modal-backdrop{position:fixed;inset:0;z-index:30;display:grid;place-items:center;background:#221f1b52;padding:16px}.teacher-side-modal{display:grid;width:min(420px,calc(100vw - 32px));max-height:calc(100vh - 32px);overflow:auto;gap:10px;border:1px solid var(--color-border);border-radius:8px;background:#fffdf8;box-shadow:0 18px 48px #1f1c1738;padding:14px}.teacher-side-modal__header{border-bottom:1px solid var(--color-border);padding-bottom:8px}.teacher-side-modal__field{display:grid;gap:4px;color:var(--color-muted);font-size:11px;font-weight:900}.teacher-side-modal__field input,.teacher-side-modal__field textarea{min-width:0;border:1px solid var(--color-border);border-radius:var(--radius-button);background:#fff;color:var(--color-text);font-size:12px;font-weight:700;padding:6px 8px}.teacher-side-modal__field textarea{resize:vertical}.teacher-side-modal__status{color:var(--color-text);font-size:11px}.teacher-side-modal__hint{color:var(--color-muted);font-size:10px;font-weight:800;line-height:1.4}.teacher-side-modal__field--nested{gap:3px}.teacher-side-password-input{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:5px;align-items:center}.teacher-side-modal__dates{display:grid;grid-template-columns:1fr 1fr;gap:8px}.teacher-side-modal__check{display:grid;grid-template-columns:auto minmax(0,1fr);gap:6px;align-items:center;color:var(--color-text);font-size:12px;font-weight:800}.teacher-side-modal__check input{width:15px;height:15px;margin:0}.teacher-side-modal__actions{display:flex;justify-content:flex-end;gap:6px}.teacher-side-panel .button{min-height:24px;padding:2px 7px;font-size:10px}.teacher-side-panel .teacher-side-course__actions-row .button{min-height:22px;padding:2px;font-size:8px}.teacher-side-panel .teacher-side-course__actions-row .button:last-child{font-size:8px}.teacher-side-panel .teacher-side-delete{padding-inline:6px}.teacher-side-panel .teacher-side-course__actions-row .teacher-side-delete{padding-inline:2px}.teacher-side-panel-tabs{display:inline-flex;align-items:center;gap:4px;margin-left:10px;padding-left:10px;border-left:1px solid var(--color-border)}.teacher-tools__data-actions .teacher-side-panel-tab{min-height:22px;padding-inline:8px}.teacher-tools__data-actions .teacher-side-panel-tab--active{border-color:var(--color-accent-strong);background:#eef7f4;color:var(--color-accent-strong)}.teacher-hint{color:var(--color-muted);font-size:var(--text-xs);font-weight:700}.teacher-tools{display:grid;grid-template-columns:minmax(230px,auto) minmax(0,1fr);align-items:center;gap:4px;margin:0}.teacher-school-switch{display:flex;align-items:center;gap:6px;width:min(100%,220px);color:var(--color-muted);font-size:11px;font-weight:800}.teacher-school-switch span,.teacher-course-title span{color:var(--color-muted);font-size:11px;font-weight:850;white-space:nowrap}.teacher-course-title{display:flex;align-items:center;gap:6px;min-width:0;overflow:hidden;align-self:center;min-height:28px;border:0;background:transparent;padding:0;line-height:1.2}.teacher-course-title strong{min-width:0;overflow:hidden;color:var(--color-text);font-size:12px;font-weight:850;text-overflow:ellipsis;white-space:nowrap}.teacher-school-switch select{width:100%;min-height:28px;border:1px solid var(--color-border);border-radius:var(--radius-button);background:#fff;color:var(--color-text);font-size:11px;font-weight:700;padding:2px 8px}.teacher-school-switch select:focus-visible{border-color:var(--color-accent);outline:none}.teacher-tools__buttons{display:grid;grid-column:1 / -1;gap:3px}.teacher-tools__data-actions{display:flex;grid-column:1 / -1;flex-wrap:nowrap;align-items:center;gap:4px;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none}.teacher-tools__data-actions::-webkit-scrollbar{width:0;height:0}.teacher-tools__button-row{display:flex;flex-wrap:wrap;gap:4px}.teacher-tools__buttons .button{width:auto;min-height:20px;font-size:10px;padding:1px 6px;text-align:left}.teacher-tools__data-actions .button{width:auto;min-height:22px;padding:2px 7px;font-size:10px;white-space:nowrap}.catalog-page--teacher .teacher-tools__buttons{display:block}.catalog-page--teacher .teacher-tools{grid-template-columns:minmax(160px,220px) minmax(0,1fr);padding-block:2px}.catalog-page--teacher .teacher-tools__button-row--secondary{gap:4px;flex-wrap:nowrap;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none}.catalog-page--teacher .teacher-tools__button-row--secondary::-webkit-scrollbar{width:0;height:0}.catalog-page--teacher .teacher-school-switch{width:min(100%,200px)}.catalog-page--teacher .project-route-status{border:0;background:transparent;gap:3px;padding:0}.catalog-page--teacher .project-route-status__main{display:none}.catalog-page--teacher .project-route-status__actions{gap:4px}.project-route-status{display:flex;flex-wrap:wrap;align-items:center;gap:4px 6px;grid-column:1 / -1;width:auto;border:1px solid var(--color-border);border-radius:var(--radius-card);background:#ffffffc2;padding:2px 5px;color:var(--color-muted);font-size:11px}.project-route-status--active{border-color:#25845c73;background:#edf8f2d1}.project-route-status__main,.project-route-status__details,.project-route-status__actions{display:flex;flex-wrap:wrap;align-items:center;gap:6px 10px}.project-route-status__main strong{color:var(--color-text);font-size:11px}.project-route-status__label{font-weight:800}.project-route-status__details{display:none}.project-route-status__actions .button{min-height:20px;padding:1px 6px;font-size:10px}.catalog-item{position:relative;display:grid;grid-template-columns:48px minmax(0,1fr) repeat(4,auto);align-items:center;gap:5px;width:100%;min-height:30px;border:1px solid var(--color-border);border-radius:var(--radius-card);background:var(--color-surface);color:var(--color-text);cursor:pointer;padding:3px 6px;text-align:left;box-shadow:0 1px #23232308}.catalog-item:not(.catalog-item--teacher){grid-template-columns:36px minmax(0,1fr);min-height:32px;border-color:#dedbd3;background:#ffffffd1;padding:5px 8px;box-shadow:0 1px #2323230a}.catalog-item--teacher{grid-template-columns:18px 34px minmax(0,1fr) repeat(8,auto)}.catalog-item--separator{min-height:12px;border-style:dashed;background:#f1f1ee}.catalog-item--separator.catalog-item--teacher{grid-template-columns:18px minmax(0,1fr) repeat(3,auto)}.catalog-item__separator-line{position:relative;z-index:2;height:8px;border-radius:999px;background:#d6d6d1}.catalog-item__move{position:relative;z-index:3;min-height:24px;border:1px solid var(--color-border);border-radius:var(--radius-button);background:#fff;color:var(--color-muted);cursor:pointer;font-size:var(--text-xs);font-weight:800;padding:2px 6px}.catalog-item--archived{background:#f7f5ef}.catalog-item--deleted{border-color:#e3b9b9;background:#fff7f7}.catalog-item:hover,.catalog-item:focus-within{border-color:var(--color-accent);outline:none}.catalog-item__order{position:relative;z-index:2;color:var(--color-muted);font-size:var(--text-xs);font-variant-numeric:tabular-nums}.catalog-item:not(.catalog-item--teacher) .catalog-item__order{font-size:11px}.catalog-item__check{position:relative;z-index:3;width:13px;height:13px;accent-color:var(--color-accent);cursor:pointer}.catalog-item__order--drag{cursor:grab;-webkit-user-select:none;user-select:none}.catalog-item__order--drag:active{cursor:grabbing}.catalog-item__title{min-width:0;font-weight:700;line-height:var(--line-tight);overflow-wrap:normal}.catalog-item:not(.catalog-item--teacher) .catalog-item__title{overflow:hidden;font-size:var(--text-xs);text-overflow:ellipsis;white-space:nowrap}.catalog-item--teacher .catalog-item__title{font-size:var(--text-xs)}.catalog-item__delete,.catalog-item__duplicate,.catalog-item__editor-open,.catalog-item__move{position:relative;z-index:3;min-height:24px;cursor:pointer;font-size:var(--text-xs);font-weight:800;padding:2px 6px}.catalog-item__delete{border:1px solid #e3b9b9;border-radius:var(--radius-button);background:#fff4f4;color:#a34444}.catalog-item__duplicate{border:1px solid #c7d8d3;border-radius:var(--radius-button);background:#eef7f4;color:var(--color-accent-strong)}.catalog-item__editor-open{border:1px solid #c7d8d3;border-radius:var(--radius-button);background:#f7fbfa;color:var(--color-accent-strong);white-space:nowrap}.catalog-item__scope{position:relative;z-index:3;min-height:24px;max-width:112px;border:1px solid var(--color-border);border-radius:var(--radius-button);background:#fff;color:var(--color-text);cursor:pointer;font-size:var(--text-xs);font-weight:700;padding:2px 6px}.catalog-item__toggle{position:relative;z-index:3;display:inline-flex;align-items:center;gap:4px;color:var(--color-muted);cursor:pointer;font-size:var(--text-xs);font-weight:800;white-space:nowrap}.catalog-item__toggle input{accent-color:var(--color-accent)}.catalog-item__scope:focus-visible{border-color:var(--color-accent);outline:none}.catalog-item__delete:hover,.catalog-item__delete:focus-visible{border-color:#b85b5b;outline:none}.catalog-item__move:hover,.catalog-item__move:focus-visible{border-color:var(--color-accent);outline:none}.catalog-item__duplicate:hover,.catalog-item__duplicate:focus-visible,.catalog-item__editor-open:hover,.catalog-item__editor-open:focus-visible{border-color:var(--color-accent);outline:none}.catalog-item__open{position:absolute;inset:0;z-index:1;border:0;background:transparent;cursor:pointer}.catalog-item--teacher .catalog-item__open{grid-column:1 / 4;grid-row:1;inset:0}.catalog-item__title,.catalog-item .label{position:relative;z-index:2;pointer-events:none}.label{border:1px solid #c7d8d3;border-radius:999px;color:var(--color-accent-strong);font-size:11px;font-weight:800;padding:2px 6px;white-space:nowrap}.label--quiet{color:var(--color-muted)}.lesson-page{display:grid;gap:var(--space-4);padding-top:var(--space-4);padding-bottom:calc(100vh - 82px)}.lesson-page--side-viewer{gap:10px;padding-top:8px}.lesson-card-anchor{scroll-margin-top:92px}.lesson-card{position:relative;border:1px solid var(--color-border);border-radius:var(--radius-card);background:var(--color-surface);box-shadow:var(--shadow-soft);padding:var(--space-5)}.lesson-page--side-viewer .lesson-card{padding:12px}.lesson-card-anchor:nth-child(odd) .lesson-card{background:var(--color-card-blue)}.lesson-card-anchor:nth-child(2n) .lesson-card{background:var(--color-card-beige)}.lesson-card__number{margin-bottom:var(--space-3);color:var(--color-muted);font-size:var(--text-sm);font-variant-numeric:tabular-nums;font-weight:750}.lesson-card h2{margin:0;font-size:var(--text-xl);line-height:var(--line-tight);overflow-wrap:anywhere}.lesson-page--side-viewer .lesson-card h2{font-size:var(--text-md)}.lesson-card__title-row,.lesson-card__body-row{display:grid;grid-template-columns:42px minmax(0,1fr);align-items:start;gap:var(--space-3)}.lesson-page--side-viewer .lesson-card__title-row,.lesson-page--side-viewer .lesson-card__body-row{grid-template-columns:30px minmax(0,1fr);gap:8px}.catalog-selection-bar__font{display:inline-flex;align-items:center;gap:5px;color:var(--color-muted);font-size:var(--text-xs);font-weight:900;white-space:nowrap}.catalog-selection-bar__font select{min-height:26px;border:1px solid var(--color-border);border-radius:var(--radius-button);background:#fff;color:var(--color-text);font-size:11px;padding:3px 8px}.lesson-card__body-row--mini-image{grid-template-columns:minmax(72px,112px) minmax(0,1fr);align-items:center}.lesson-page--side-viewer .lesson-card__body-row--mini-image{grid-template-columns:minmax(48px,72px) minmax(0,1fr)}.lesson-card__body-row--mini-image .media-block{align-self:start;margin:0}.lesson-card__body-row--mini-image .media-block__image{max-height:128px}.lesson-card__title-row{align-items:center}.lesson-card p,.lesson-card__body-text{margin:0;font-size:var(--text-md);line-height:var(--line-body);overflow-wrap:anywhere}.lesson-page--side-viewer .lesson-card p,.lesson-page--side-viewer .lesson-card__body-text{font-size:.92rem;line-height:1.72}.lesson-card__body-text{display:flex;flex-direction:column}.lesson-card__text-line{min-height:calc(var(--text-md) * var(--line-body))}.lesson-card__blank-line{display:block;height:calc(var(--text-md) * var(--line-body) * .5)}.lesson-card__body~.media-block{margin-top:.86em}.rich-text-run{white-space:pre-wrap}.mini-thumb{display:grid;width:42px;height:42px;place-items:center;border:1px solid var(--color-border);border-radius:50%;background:#ffffffd1;color:var(--color-muted);font-weight:900;line-height:1}.lesson-page--side-viewer .mini-thumb{width:30px;height:30px;font-size:.78rem}.mini-thumb--hanamaru{border-color:#e6adc2;background:#fff0f5;color:#b23a62}.mini-thumb--alert{border-color:#e3bd52;background:#fff7df;color:#8a6500}.mini-thumb--step{border-color:#c7d8d3;background:#f0faf7;color:var(--color-accent-strong)}.mini-thumb--video{border-color:#c8ced8;background:#f3f5f8}.lesson-card--heading{border-color:#c9d9d5}.lesson-card--note{border-color:var(--color-note-border)}.lesson-card--completion{border-color:#efbed0;background:#fff0f6!important}.lesson-card--completion h2{color:#c06b91}.link-card{display:block;color:var(--color-text)}.link-card p{margin:0;line-height:var(--line-body);white-space:pre-wrap;overflow-wrap:anywhere}.link-card__button{display:inline-grid;min-height:42px;min-width:64px;place-items:center;border-radius:var(--radius-button);background:var(--color-accent);color:#fff;font-weight:800;text-decoration:none;vertical-align:middle}.link-card__button:hover,.link-card__button:focus-visible{background:var(--color-accent-strong);outline:none}.media-block,.state-panel{border:1px dashed var(--color-border);border-radius:var(--radius-card);background:var(--color-surface-soft);color:var(--color-muted);padding:var(--space-5)}.media-block{width:100%;display:grid;place-items:center;position:relative;overflow:hidden;padding:0;background:linear-gradient(135deg,rgb(255 255 255 / 30%) 25%,transparent 25%) 0 0 / 22px 22px,linear-gradient(135deg,transparent 75%,rgb(255 255 255 / 30%) 75%) 0 0 / 22px 22px,#d8d8d4}.media-block--size-60,.media-block--size-30{justify-self:center}.media-block--size-60{width:60%}.media-block--size-30{width:30%}.media-block--interactive{cursor:zoom-in}.media-block--static{display:none}.media-block--video{cursor:zoom-in;background:linear-gradient(135deg,rgb(255 255 255 / 24%) 25%,transparent 25%) 0 0 / 22px 22px,linear-gradient(135deg,transparent 75%,rgb(255 255 255 / 24%) 75%) 0 0 / 22px 22px,#cfd4dc}.media-block__label{border-radius:999px;background:#ffffffb8;color:var(--color-muted);font-weight:800;padding:8px 12px;margin:var(--space-5)}.media-block__sub-label{align-self:start;margin-top:calc(var(--space-5) * -1);color:var(--color-muted);font-size:var(--text-sm)}.media-block__image,.media-block__video{width:100%;max-width:100%;height:auto;max-height:min(72vh,680px);display:block;object-fit:contain;background:transparent;border:0}.media-block--image,.media-block--video-source{border:0;background:transparent;box-shadow:none}.media-block__track{position:absolute;inset:18px;border:2px solid rgb(255 255 255 / 55%);border-radius:6px}.media-block__dot{position:absolute;width:46px;height:46px;border-radius:50%;background:#2323237f;animation:media-drift 2.2s ease-in-out infinite alternate}@keyframes media-drift{0%{transform:translate(-105px,-58px) scale(.8)}to{transform:translate(105px,58px) scale(1.1)}}.source-input{position:relative;z-index:25;margin-bottom:var(--space-5)}.source-input__toggle{min-height:38px;border:1px solid var(--color-border);border-radius:var(--radius-button);background:var(--color-surface);color:var(--color-muted);cursor:pointer;font-weight:750;padding:7px 12px}.source-input__panel{margin-top:var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-card);background:var(--color-surface);padding:var(--space-4);box-shadow:var(--shadow-soft)}.source-input__grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--space-3)}.source-input label{display:grid;gap:var(--space-1);color:var(--color-muted);font-size:var(--text-sm);font-weight:700}.source-input input,.source-input textarea{width:100%;border:1px solid var(--color-border);border-radius:var(--radius-button);color:var(--color-text);padding:10px 11px}.source-input__wide{grid-column:1 / -1}.source-input__actions{display:flex;flex-wrap:wrap;gap:var(--space-2);align-items:center;margin-top:var(--space-3)}.source-input__check{display:inline-flex!important;grid-auto-flow:column;align-items:center;gap:var(--space-2)!important}.source-input__hint,.toast{margin-top:var(--space-2);color:var(--color-muted);font-size:var(--text-sm);overflow-wrap:anywhere}.import-page{display:grid;gap:var(--space-5)}.import-panel{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-card);background:var(--color-surface);padding:var(--space-4);box-shadow:var(--shadow-soft)}.import-help{display:flex;justify-content:space-between;gap:var(--space-4);align-items:flex-start;border:1px solid var(--color-border);border-radius:var(--radius-card);background:var(--color-surface-soft);padding:var(--space-4)}.import-help strong{display:block;margin-bottom:var(--space-2)}.import-help ol{margin:0;padding-left:1.35em;color:var(--color-muted);font-size:var(--text-sm);line-height:var(--line-body)}.import-panel label{display:grid;gap:var(--space-1);color:var(--color-muted);font-size:var(--text-sm);font-weight:800}.import-panel input,.import-panel select,.import-panel textarea{width:100%;border:1px solid var(--color-border);border-radius:var(--radius-button);background:#fff;color:var(--color-text);padding:10px 11px}.import-panel textarea{min-height:260px;resize:vertical;white-space:pre}.import-panel__wide,.import-message{grid-column:1 / -1}.import-actions{display:flex;flex-wrap:wrap;gap:var(--space-2)}.import-folder-loader{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-2);color:var(--color-muted);font-size:var(--text-sm)}.import-folder-loader input{display:none}.button:disabled{border-color:var(--color-border);background:#d8d8d4;color:var(--color-muted);cursor:not-allowed}.import-message{color:var(--color-muted);font-size:var(--text-sm);line-height:var(--line-body);white-space:pre-wrap}.import-preview{border-top:1px solid var(--color-border);padding-top:var(--space-5)}@media(hover:none)and (pointer:coarse){.media-block--interactive{display:none}.media-block--static{display:grid}}@media(max-width:500px){.app-main{padding:82px 10px 40px}.viewer-header__row{min-height:50px}.viewer-header--compact .viewer-header__row{min-height:30px}.viewer-header__title{font-size:var(--text-sm)}.button{min-height:40px;padding-inline:10px}.viewer-header__row .button{font-size:var(--text-xs);padding-inline:8px}.teacher-page-header__body{align-items:stretch;flex-direction:column}.teacher-page-header p{white-space:normal}.teacher-page-header__actions .button{flex:1 1 128px}.app-main:has(.catalog-page--teacher){padding:0 8px}.teacher-tools{grid-template-columns:1fr}.teacher-tools__buttons,.teacher-course-title,.project-route-status{grid-column:1}.catalog-item{grid-template-columns:34px minmax(0,1fr) 82px auto auto;gap:6px;min-height:42px;padding:7px 8px}.catalog-item:not(.catalog-item--teacher){grid-template-columns:30px minmax(0,1fr);min-height:30px;padding:4px 7px}.catalog-item--teacher{grid-template-columns:20px 34px minmax(0,1fr) auto}.catalog-item .label{grid-column:2 / 4;justify-self:start}.catalog-item__toggle{grid-column:2 / -1;justify-self:start}.catalog-item__delete,.catalog-item__duplicate,.catalog-item__editor-open{min-width:42px;white-space:nowrap;padding-inline:7px}.catalog-item__scope{width:82px;max-width:82px}.student-toc__open{grid-template-columns:44px minmax(0,1fr) auto}.student-toc__status{grid-column:3}.student-toc--compact .student-toc__open{grid-template-columns:38px minmax(0,1fr) auto}.student-identity__search,.student-identity__candidate{grid-template-columns:1fr}.lesson-card{padding:var(--space-4)}.lesson-card h2{font-size:var(--text-lg)}.lesson-card__title-row,.lesson-card__body-row{grid-template-columns:36px minmax(0,1fr)}.lesson-card__body-row--mini-image{grid-template-columns:minmax(58px,88px) minmax(0,1fr)}.mini-thumb,.link-card__icon{width:36px;height:36px}.source-input__grid,.import-panel{grid-template-columns:1fr}.import-help{flex-direction:column}}.teacher-editor{--teacher-editor-stack-gap: var(--space-4);display:grid;gap:var(--teacher-editor-stack-gap)}.teacher-editor__sticky{position:sticky;top:0;z-index:35;display:grid;gap:0;background:#faf8f1f5;box-shadow:0 4px 18px #2323230d;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.teacher-editor__sticky .teacher-page-header{position:static;border-bottom:1px solid var(--color-border);background:transparent;box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none}.teacher-editor__toolbar{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));align-items:center;gap:4px;border:0;border-bottom:1px solid var(--color-border);border-top:0;border-radius:0;background:transparent;padding:6px clamp(12px,3vw,32px)}.teacher-editor__toolbar .button,.teacher-card-editor__actions .button,.capture-tray__header .button,.teacher-card-item__bar .button,.teacher-editor__section-head .button,.capture-tray__item .button,.teacher-card-item__style .button,.teacher-card-item__size-buttons .button,.teacher-card-list__header .button,.teacher-validation__toggle{min-height:34px;font-size:var(--text-xs);padding:6px 10px}.teacher-editor__toolbar .button{width:100%;min-width:0;min-height:30px;padding:4px 5px;font-size:12px;line-height:1.15;white-space:nowrap}.teacher-editor__meta-panel{display:grid;gap:var(--space-2)}.teacher-editor__meta{display:grid;grid-template-columns:minmax(180px,.45fr) minmax(240px,1fr);gap:var(--space-3)}.teacher-editor__meta label,.teacher-card-item label{display:grid;gap:var(--space-1);color:var(--color-muted);font-size:var(--text-sm);font-weight:800}.teacher-editor input,.teacher-editor textarea{width:100%;border:1px solid var(--color-border);border-radius:var(--radius-button);background:#fff;color:var(--color-text);padding:10px 11px}.teacher-editor textarea{min-height:132px;resize:vertical;line-height:var(--line-body)}.teacher-editor input:focus-visible,.teacher-editor textarea:focus-visible{border-color:var(--color-accent);outline:none}.teacher-editor__message,.teacher-editor__issues{margin:0;border-radius:var(--radius-card);padding:var(--space-3);font-size:var(--text-sm);line-height:var(--line-body);overflow-wrap:anywhere}.teacher-editor__message{border:1px solid #c7d8d3;background:#eef7f4;color:var(--color-accent-strong);font-weight:700}.teacher-editor__issues{display:grid;gap:4px;border:1px solid #e3bd52;background:#fff7df;color:#745500;font-weight:700}.teacher-editor__confirm{display:grid;gap:8px;border:1px solid #e3bd52;border-radius:var(--radius-card);background:#fff7df;color:#5f4700;padding:var(--space-3);font-size:var(--text-sm);font-weight:700;line-height:var(--line-body)}.teacher-editor__confirm p{margin:0}.teacher-editor__confirm-meta{color:var(--color-muted);font-size:var(--text-xs);overflow-wrap:anywhere}.teacher-editor__confirm-actions{display:flex;flex-wrap:wrap;gap:8px}.teacher-validation{display:grid;gap:6px;border:1px solid #e3bd52;border-radius:var(--radius-card);background:#fffaf0;padding:7px 10px;font-size:var(--text-sm);line-height:1.35}.teacher-validation__summary{display:flex;flex-wrap:wrap;gap:4px 10px;align-items:center;color:#745500}.teacher-validation__count--error{color:#9b1c1c;font-weight:900}.teacher-validation__count--warning{color:#745500;font-weight:900}.teacher-validation__toggle{margin-left:auto;min-height:28px;padding:3px 8px}.teacher-validation__list{display:grid;gap:6px;max-height:220px;overflow:auto;padding-right:2px}.teacher-validation__item{display:grid;grid-template-columns:auto minmax(96px,.35fr) minmax(160px,1fr) auto;gap:6px 10px;align-items:start;border-radius:var(--radius-button);background:#ffffffc7;padding:8px 10px;overflow-wrap:anywhere}.teacher-validation__item--error strong{color:#9b1c1c}.teacher-validation__item--warning strong{color:#745500}.teacher-validation__item code{border-radius:6px;background:#0000000f;padding:1px 5px;font-size:var(--text-xs)}.teacher-editor__layout{display:grid;grid-template-columns:minmax(0,1fr) minmax(240px,280px);align-items:start;gap:var(--space-4)}.teacher-editor__cards,.teacher-editor__card-flow,.teacher-card-editor__items,.capture-tray__list,.teacher-card-list__items{display:grid;gap:var(--space-3)}.teacher-editor__section-head,.teacher-card-editor__header,.capture-tray__header,.teacher-card-item__bar,.teacher-card-item__style,.teacher-card-item__size-buttons,.teacher-card-list__header{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:var(--space-2)}.teacher-editor__section-head h1,.capture-tray h2{margin:0;font-size:var(--text-lg);line-height:var(--line-tight)}.capture-tray__header{display:grid;justify-content:stretch;gap:var(--space-2)}.capture-tray__title-row,.capture-tray__capture-row{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-2)}.capture-tray__title-row{justify-content:space-between}.capture-tray__capture-row{justify-content:flex-start}.capture-tray__header h2{min-height:20px;border:1px solid transparent;padding:2px 3px;color:var(--color-text);font-size:10px;font-weight:900;line-height:1.1}.teacher-editor__section-foot{display:flex;justify-content:center;padding:var(--space-2) 0 var(--space-4)}.teacher-card-list{position:sticky;top:148px;display:grid;gap:var(--space-3);max-height:calc(100vh - 168px);overflow:auto;border:1px solid var(--color-border);border-radius:var(--radius-card);background:var(--color-surface-soft);padding:var(--space-3)}.teacher-card-list:not([open]){overflow:visible;padding:0}.teacher-card-list__summary-toggle{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px;align-items:center;min-height:42px;border-radius:var(--radius-card);color:var(--color-text);cursor:pointer;font-size:var(--text-sm);font-weight:900;list-style-position:inside;padding:10px 12px}.teacher-card-list[open] .teacher-card-list__summary-toggle{border-bottom:1px solid var(--color-border);border-radius:var(--radius-card) var(--radius-card) 0 0}.teacher-card-list__summary-toggle span:last-child{color:var(--color-muted);font-size:var(--text-xs)}.teacher-card-list__header{justify-content:flex-end;padding-top:var(--space-3)}.teacher-card-list__item{display:grid;grid-template-columns:auto minmax(0,1fr);gap:4px 8px;align-items:center;width:100%;border:1px solid var(--color-border);border-radius:var(--radius-button);background:#fff;color:var(--color-text);padding:9px 10px;text-align:left;cursor:pointer}.teacher-card-list__item--selected{border-color:var(--color-accent);background:#eef7f4;box-shadow:0 0 0 2px #508f7f2e}.teacher-card-list__item--empty{color:var(--color-muted)}.teacher-card-list__number{color:var(--color-muted);font-size:var(--text-xs);font-weight:900}.teacher-card-list__item-summary{overflow:hidden;font-size:var(--text-sm);font-weight:800;text-overflow:ellipsis;white-space:nowrap}.teacher-card-list__schools{grid-column:2;color:var(--color-muted);font-size:var(--text-xs);overflow-wrap:anywhere}.teacher-card-editor{display:grid;gap:var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-card);background:var(--color-surface);padding:var(--space-4);box-shadow:0 1px #2323230a}.teacher-card-editor--selected{border-color:var(--color-accent);box-shadow:0 0 0 3px #508f7f29}.teacher-card-editor__header strong{font-size:var(--text-sm)}.teacher-card-editor__actions{display:flex;flex-wrap:wrap;gap:6px}.teacher-editor__viewer-settings,.teacher-editor__lesson-schools,.teacher-card-editor__schools{display:flex;flex-wrap:wrap;gap:6px 10px;margin:0;border:1px dashed var(--color-border);border-radius:var(--radius-card);padding:9px 10px 10px}.teacher-editor__viewer-settings,.teacher-editor__lesson-schools{background:#ffffffb3}.teacher-editor__viewer-settings legend,.teacher-editor__lesson-schools legend,.teacher-card-editor__schools legend{color:var(--color-muted);font-size:var(--text-xs);font-weight:900;padding-inline:4px}.teacher-editor__viewer-settings label,.teacher-editor__lesson-schools label,.teacher-card-editor__schools label{display:inline-flex;align-items:center;gap:4px;color:var(--color-muted);font-size:var(--text-xs);font-weight:800;white-space:nowrap}.teacher-editor__viewer-settings input,.teacher-editor__lesson-schools input,.teacher-card-editor__schools input{width:auto;padding:0;accent-color:var(--color-accent)}.teacher-card-item{display:grid;gap:var(--space-2);border:1px solid #dedbd3;border-radius:var(--radius-card);background:#ffffffb8;padding:var(--space-3)}.teacher-card-item__bar{color:var(--color-muted);font-size:var(--text-xs);font-weight:900;text-transform:uppercase}.teacher-card-item__style{justify-content:flex-start}.teacher-card-item__bar-actions{display:flex;flex-wrap:wrap;gap:3px;align-items:center;justify-content:flex-end;margin-left:auto}.teacher-card-item__bar-actions>.button:first-child{flex:0 0 auto}.teacher-card-item__bar-actions .button{min-height:28px;padding:4px 7px;font-size:var(--text-xs)}.teacher-card-item__style-button--active{border-color:var(--color-accent);background:#eef7f4;color:var(--color-accent-strong);box-shadow:inset 0 0 0 1px #508f7f52}.teacher-card-item__media{display:grid;gap:var(--space-2)}.teacher-card-item__style,.teacher-card-item__size-buttons{gap:3px}.teacher-card-item__mini-image{display:grid;grid-template-columns:96px minmax(180px,1fr);gap:var(--space-2);align-items:start;border:1px dashed var(--color-border);border-radius:var(--radius-card);background:#ffffff94;padding:var(--space-2)}.teacher-card-item__mini-image-preview{display:grid;width:96px;min-height:72px;place-items:center;overflow:hidden;border-radius:var(--radius-button);background:linear-gradient(135deg,rgb(0 0 0 / 6%) 25%,transparent 25%) 0 0 / 16px 16px,linear-gradient(135deg,transparent 75%,rgb(0 0 0 / 6%) 75%) 0 0 / 16px 16px,#ffffffc2}.teacher-card-item__mini-image-preview img{display:block;width:100%;height:auto;max-height:120px;object-fit:contain}.teacher-card-item__mini-image-preview--empty span{color:var(--color-muted);font-size:var(--text-xs);font-weight:800}.teacher-card-item__mini-image-actions,.teacher-card-item__size-options{display:flex;flex-wrap:wrap;gap:6px}.teacher-card-item__size-options{align-items:center;flex:0 0 246px;margin:0;border:0;padding:0}.teacher-card-item__size-options label{display:inline-flex;gap:4px;align-items:center;padding:0;color:var(--color-muted);font-size:var(--text-xs);font-weight:900}.teacher-card-item__size-slider{display:grid!important;grid-template-columns:auto 40px minmax(160px,1fr);gap:4px;min-width:0;width:100%}.teacher-card-item__size-options input{width:100%;min-width:0;margin:0;padding:0;accent-color:var(--color-accent)}.teacher-card-item__size-options input[type=range]{display:block;height:18px;background:transparent}.teacher-card-item__size-options input[type=range]::-webkit-slider-runnable-track{height:4px;border-radius:999px;background:var(--color-border)}.teacher-card-item__size-options input[type=range]::-webkit-slider-thumb{margin-top:-6px}.teacher-card-item__size-value{display:inline-block;width:40px;text-align:right;font-variant-numeric:tabular-nums}.teacher-card-item__path-display{padding:var(--space-2) var(--space-3) var(--space-3)}.teacher-card-item__mini-image .teacher-card-item__path-display{grid-column:2;min-width:0;padding:0}.teacher-card-item:has(.teacher-card-item__media){gap:0;overflow:hidden;padding:0}.teacher-card-item:has(.teacher-card-item__media) .teacher-card-item__bar{padding:var(--space-3) var(--space-3) var(--space-2)}.teacher-card-item:has(.teacher-card-item__media) .teacher-card-item__media label{padding:var(--space-2) var(--space-3) var(--space-3)}.teacher-card-item__image-preview{display:block;min-height:0;margin:0;overflow:hidden;border:0;border-radius:0;background:transparent;padding:0}.teacher-card-item__image-preview--empty{display:grid;min-height:150px;place-items:center;border:1px dashed var(--color-border);background:#ffffff94;padding:var(--space-4);text-align:center}.teacher-card-item__image-preview img,.teacher-card-item__image-preview video{display:block;width:100%;max-width:100%;height:auto;margin:0;object-fit:contain}.teacher-card-item__image-preview span{color:var(--color-muted);font-size:var(--text-sm);font-weight:800}.teacher-media-path{display:grid;grid-template-columns:auto minmax(0,1fr);gap:6px;align-items:center;border:1px dashed var(--color-border);border-radius:var(--radius-button);background:#ffffffb8;padding:6px 8px}.teacher-media-path__type{color:var(--color-muted);font-size:var(--text-xs);font-weight:900}.teacher-media-path__value{overflow:hidden;border-radius:6px;background:#0000000f;padding:2px 5px;color:var(--color-text);font-size:var(--text-xs);font-weight:700;text-overflow:ellipsis;white-space:nowrap}.teacher-media-path__value--empty{color:var(--color-muted)}.capture-tray{position:sticky;top:148px;display:grid;gap:var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-card);background:var(--color-surface-soft);padding:var(--space-4);box-shadow:var(--shadow-soft)}.capture-tray p{margin:0;color:var(--color-muted);font-size:var(--text-sm);line-height:var(--line-body)}.capture-tray__recording-panel{display:grid;gap:var(--space-2);border:1px solid var(--color-border);border-radius:var(--radius-card);background:#fff;padding:var(--space-3)}.capture-tray__recording-panel strong{font-size:var(--text-sm)}.capture-tray__recording-panel small{color:var(--color-muted);font-size:var(--text-xs)}.capture-tray__recording-actions{display:flex;flex-wrap:wrap;gap:var(--space-2)}.capture-tray__item,.capture-tray__empty{border:1px solid var(--color-border);border-radius:var(--radius-card);background:#fff;padding:var(--space-3)}.capture-tray__item{display:grid;gap:5px}.capture-tray__item[draggable=true]{cursor:grab}.capture-tray__item[draggable=true]:active{cursor:grabbing}.capture-tray__item strong{overflow-wrap:anywhere;font-size:var(--text-sm)}.capture-tray__item span,.capture-tray__item small,.capture-tray__empty{color:var(--color-muted);font-size:var(--text-xs);overflow-wrap:anywhere}@media(max-width:760px){.teacher-card-list,.capture-tray{position:static;max-height:none}.teacher-editor__meta,.teacher-editor__layout{grid-template-columns:1fr}.teacher-card-editor__actions .button{flex:1 1 96px}}@media(max-width:640px){.teacher-validation__item{grid-template-columns:1fr}}@media(max-width:500px){.teacher-editor__toolbar{grid-template-columns:repeat(3,minmax(0,1fr))}.teacher-editor__toolbar .button{min-height:30px;padding:4px 5px;font-size:12px}.teacher-card-editor,.capture-tray,.teacher-card-list{padding:var(--space-3)}.teacher-card-item__style .button{flex:1 1 88px}}.teacher-editor{--teacher-editor-stack-gap: 8px;font-size:12px}.teacher-editor__toolbar{gap:3px;padding:4px}.teacher-editor__toolbar .button,.teacher-card-editor__actions .button,.capture-tray__header .button,.teacher-card-item__bar .button,.teacher-editor__section-head .button,.capture-tray__item .button,.teacher-card-item__style .button,.teacher-validation__toggle{min-height:20px;padding:2px 5px;font-size:10px;line-height:1.1}.teacher-editor input,.teacher-editor textarea{padding:5px 7px;font-size:11px}.teacher-editor textarea{min-height:82px}.teacher-editor__layout,.teacher-editor__card-flow,.teacher-card-editor__items,.capture-tray__list{gap:8px}.teacher-card-editor,.capture-tray,.teacher-card-item{padding:7px}.teacher-card-editor{gap:8px}.teacher-card-editor__actions{gap:4px}.teacher-editor__viewer-settings,.teacher-editor__lesson-schools,.teacher-card-editor__schools{gap:4px 8px;padding:6px 8px 7px}.teacher-card-item{gap:6px}.teacher-card-item__image-preview{min-height:0}.teacher-card-item__image-preview img,.teacher-card-item__image-preview video{max-height:none}.capture-tray{gap:8px}.capture-tray p{display:none}.capture-tray__item,.capture-tray__empty{padding:6px}.capture-tray__item{display:grid;grid-template-columns:64px minmax(0,1fr);gap:5px 7px;align-items:center}.capture-tray__item strong{overflow-wrap:anywhere;font-size:11px}.capture-tray__item span,.capture-tray__item small{display:none}.capture-tray__actions{grid-column:2;display:flex;flex-wrap:wrap;gap:4px}.capture-tray__actions .button{flex:1 1 74px;min-width:0}.capture-tray__remove{color:#9b1c1c}.capture-tray__thumb{grid-row:span 2;display:grid;place-items:center;width:64px;aspect-ratio:4 / 3;overflow:hidden;border:1px solid var(--color-border);border-radius:6px;background:#f0eee8;color:var(--color-muted);font-size:10px;font-weight:900}.capture-tray__thumb img,.capture-tray__thumb video{width:100%;height:100%;object-fit:cover}.teacher-preview-card__items{display:grid;gap:var(--space-3)}.teacher-preview-target{border-bottom:1px solid var(--color-border);background:#faf8f1eb;padding:5px clamp(10px,2vw,24px)}.teacher-preview-target label{display:flex;width:min(100%,920px);margin-inline:auto;align-items:center;gap:6px;color:var(--color-muted);font-size:11px;font-weight:700;line-height:1.2;white-space:nowrap}.teacher-preview-target label span{flex:0 0 auto}.teacher-preview-target select{flex:0 1 220px;width:min(220px,62vw);min-width:0;min-height:26px;border:1px solid var(--color-border);border-radius:var(--radius-button);background:#fff;color:var(--color-text);font-size:11px;font-weight:700;padding:2px 6px}.teacher-preview-card__text{margin:0}.teacher-course-root{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:var(--space-2);border:1px solid #c7d8d3;border-radius:var(--radius-card);background:#eef7f4;padding:8px 10px}.teacher-course-root--browser{border-color:var(--color-border);background:var(--color-surface-soft)}.teacher-course-root strong{color:var(--color-accent-strong);font-size:var(--text-sm)}.teacher-course-root p{margin:2px 0 0;color:var(--color-muted);font-size:var(--text-xs);line-height:var(--line-body);overflow-wrap:anywhere}.teacher-course-root .button{min-height:30px;padding:4px 9px;font-size:var(--text-xs)}
