:root{--bg: #f4f6fb;--panel: #ffffff;--panel-soft: #eef3ff;--panel-muted: #f8faff;--line: #d5ddee;--text: #1d2b45;--muted: #60708f;--brand: #1765e2;--brand-deep: #0d4aa8;--success: #1e9b68;--warning: #d97706;--danger: #c33d3d;--shadow: 0 18px 48px rgba(27, 52, 99, .12)}*{box-sizing:border-box}body{margin:0;font-family:Avenir Next,Hiragino Sans,Noto Sans JP,sans-serif;color:var(--text);background:radial-gradient(circle at top left,rgba(23,101,226,.12),transparent 30%),linear-gradient(180deg,#f8fbff 0%,var(--bg) 100%)}button,input,select,textarea{font:inherit}button{border:0;border-radius:14px;padding:12px 16px;cursor:pointer;background:var(--brand);color:#fff;font-weight:700;transition:transform .18s ease,opacity .18s ease,background .18s ease}button:hover:not(:disabled){transform:translateY(-1px)}button.secondary{background:#dfe8fb;color:var(--brand-deep)}button.ghost{background:transparent;color:var(--brand);border:1px solid rgba(255,255,255,.35)}button.warn{background:var(--warning)}button:disabled{opacity:.55;cursor:not-allowed;transform:none}input,select,textarea{width:100%;border:1px solid var(--line);background:#fff;border-radius:12px;padding:12px 14px}.app-shell{max-width:1360px;margin:0 auto;min-height:100vh;padding:14px 18px 18px}.login-shell{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}.login-grid,.hero{display:grid;grid-template-columns:1.35fr 1fr;gap:20px;width:100%;max-width:1280px}.hero{margin-bottom:20px}.hero-card,.panel{background:var(--panel);border:1px solid rgba(213,221,238,.8);border-radius:24px;box-shadow:var(--shadow)}.hero-card{padding:28px;background:linear-gradient(135deg,#1765e214,#fffffff2),var(--panel)}.hero-card h1,.hero-card h2{margin:0}.hero-card h1{font-size:34px;margin-bottom:10px}.hero-card p{margin:0;color:var(--muted);line-height:1.7}.hero-side{padding:24px;background:linear-gradient(180deg,#10284a,#183b6b);color:#fff}.hero-side p,.hero-side li,.hero-side .muted,.hero-side .muted-hint{color:#ffffffd6}.button-quiet{background:#ffffff24;color:#fff}.top-actions{align-items:flex-start}.muted-hint{margin-top:12px;font-size:13px;line-height:1.6}.content-shell{display:flex;flex-direction:column;gap:12px}.layout{display:grid;grid-template-columns:320px 1fr;gap:14px}.layout-single,.sidebar,.content{display:flex;flex-direction:column;gap:14px}.panel{padding:14px}.panel-nested{margin-top:14px;background:var(--panel-muted)}.panel h3{margin:0 0 10px;font-size:17px}.label{display:block;margin-bottom:8px;font-size:13px;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.04em}.stack{display:flex;flex-direction:column;gap:10px}.row{display:flex;gap:10px}.row.wrap{flex-wrap:wrap}.between{display:flex;align-items:center;justify-content:space-between;gap:12px}.section-head{align-items:flex-start}.section-subtitle{margin-bottom:8px;color:var(--muted);font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.04em}.muted{color:var(--muted)}.center{text-align:center}.pill{display:inline-flex;align-items:center;gap:6px;border-radius:999px;padding:6px 12px;font-size:12px;font-weight:800;background:var(--panel-soft);color:var(--brand-deep)}.pill.success{background:#1e9b681f;color:var(--success)}.pill.warning{background:#d9770624;color:var(--warning)}.pill.danger{background:#c33d3d1f;color:var(--danger)}.tab-row{display:flex;gap:8px;flex-wrap:wrap}.tab-button{background:#e8eefc;color:var(--brand-deep);padding:8px 12px;border-radius:12px}.tab-button.active{background:var(--brand);color:#fff}.notice{padding:10px 12px;border-radius:12px;background:#1765e214;color:var(--brand-deep);line-height:1.5}.notice.error{background:#c33d3d1a;color:var(--danger)}.notice.warning{background:#d9770624;color:var(--warning)}.card-list{display:grid;gap:10px}.mini-card{padding:12px;border-radius:14px;background:#fbfcff;border:1px solid var(--line)}.mini-card.active{border-color:var(--brand);box-shadow:inset 0 0 0 1px #1765e21f;background:#f7faff}.mini-card-soft{background:#fff}.status-grid,.info-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}.status-box{padding:12px;border-radius:14px;background:#f9fbff;border:1px solid var(--line)}.status-box strong{display:block;margin-top:6px;font-size:22px}.assignment-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:12px;margin-top:10px}.assignment-tile,.student-list button{width:100%;text-align:left}.assignment-tile{border:1px solid var(--line);border-radius:16px;padding:14px;background:#fff;color:var(--text)}.tile-footer{margin-top:12px;color:var(--brand);font-weight:800;font-size:13px}.breadcrumb{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:10px;color:var(--muted);font-size:13px}.breadcrumb-link{padding:0;background:transparent;color:var(--brand);border-radius:0}.breadcrumb-link:hover{transform:none;text-decoration:underline}.breadcrumb-sep{opacity:.55}.stepper{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:8px;margin-bottom:12px}.step{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:12px;background:#f7faff;border:1px solid var(--line);color:var(--muted)}.step.active{border-color:#1765e259;background:#1765e214;color:var(--brand-deep)}.step.done{background:#1e9b6814;color:var(--success)}.step-dot{width:22px;height:22px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;background:#fff;border:1px solid currentColor;font-weight:800;flex-shrink:0}.step-label{font-size:12px;font-weight:700}.callout{margin-top:10px;padding:12px;border-radius:14px;background:linear-gradient(135deg,#1765e214,#1765e208);border:1px solid rgba(23,101,226,.18)}.two-col-detail{display:grid;grid-template-columns:1.15fr .85fr;gap:14px;margin-top:12px}.reading-text{padding:14px;border-radius:14px;background:#fbfdff;border:1px solid var(--line);line-height:1.7;font-size:17px}.sentences{display:grid;gap:8px;margin-top:10px}.sentence{padding:10px 12px;border-radius:12px;background:#fafcff;border:1px solid var(--line);line-height:1.55;font-size:14px}.info-list{margin:8px 0 0;padding-left:20px;color:var(--muted);line-height:1.6;font-size:14px}.action-stack{display:flex;flex-direction:column;gap:8px}.inline-check{align-items:center}.inline-check input{width:auto}.record-stage{display:grid;grid-template-columns:1.15fr .85fr;gap:14px}.record-column{display:flex;flex-direction:column;gap:10px}.record-box{padding:16px;border-radius:16px;background:linear-gradient(180deg,#132b4d,#1b3f73);color:#fff;box-shadow:inset 0 0 0 1px #ffffff14}.record-box.prominent{min-height:360px;justify-content:center;display:flex;flex-direction:column;gap:10px}.record-indicator{display:inline-flex;align-self:center;padding:6px 10px;border-radius:999px;background:#ffffff1f;font-weight:800}.record-time{font-size:44px;line-height:1;font-weight:800;text-align:center}.scoring-shell{min-height:300px;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center}.loader{width:54px;height:54px;border-radius:50%;border:6px solid rgba(23,101,226,.15);border-top-color:var(--brand);animation:spin 1s linear infinite}.status-line{padding:8px 12px;border-radius:999px;background:#f4f7ff;border:1px solid var(--line);color:var(--muted)}.status-line.active{color:var(--brand-deep);background:#1765e214;border-color:#1765e233}.result-hero{padding:14px;border-radius:16px;display:flex;align-items:center;justify-content:space-between;gap:16px}.success-box{background:#1e9b6814;border:1px solid rgba(30,155,104,.18)}.warning-box{background:#d9770614;border:1px solid rgba(217,119,6,.18)}.score-badge{width:68px;height:68px;border-radius:50%;background:#fff;display:inline-flex;align-items:center;justify-content:center;font-size:24px;font-weight:800;border:1px solid rgba(0,0,0,.06)}.app-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 2px 12px}.app-brand{min-width:0}.app-title-row{display:flex;align-items:center;gap:8px;font-size:15px;line-height:1.2}.screen-title{font-weight:700}.header-divider{color:var(--muted)}.user-line{margin-top:3px;color:var(--muted);font-size:12px}.header-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.text-button{padding:6px 8px;border-radius:10px;background:transparent;color:var(--muted);border:1px solid var(--line);font-size:12px;font-weight:700}.compact-warning{color:var(--warning);font-size:13px;font-weight:700}.compact-form{margin-top:8px}.compact-panel{padding:12px;border-radius:16px}.dense-shell{gap:10px}.compact-grid{gap:8px}.compact-mini-card{padding:10px 12px;border-radius:12px}.compact-card-list{gap:8px}.compact-head h3{margin-bottom:0}.compact-chip-row{gap:8px}.compact-assignment-grid{margin-top:8px}.compact-tile{padding:12px;border-radius:14px}.compact-details{margin-top:10px;border:1px solid var(--line);border-radius:12px;background:#fbfcff;padding:10px 12px}.compact-details summary{cursor:pointer;font-weight:700;color:var(--brand-deep)}.compact-guide{margin-top:8px;color:var(--muted);font-size:13px;line-height:1.5}.inline-guide{margin-top:0}.compact-info-grid{margin-top:10px;grid-template-columns:repeat(3,minmax(0,1fr))}.dense-detail-grid{grid-template-columns:minmax(0,1.3fr) minmax(280px,.7fr)}.reading-text-primary{font-size:18px;line-height:1.65}.compact-sentences{margin-top:8px}.compact-sentence{font-size:13px}.compact-action-stack{margin-bottom:2px}.compact-copy{font-size:13px;line-height:1.5}.compact-row{gap:8px}.link-button{background:transparent;color:var(--brand);padding:8px 6px;border:0;text-align:left}.compact-record-stage{grid-template-columns:minmax(0,1.35fr) minmax(260px,.65fr)}.compact-record-box{min-height:0;gap:12px}.compact-result-hero{align-items:flex-start}.history-card{margin-top:10px}.checkbox-stack{max-height:280px;overflow:auto}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(max-width:1100px){.hero,.login-grid,.layout,.two-col-detail,.record-stage{grid-template-columns:1fr}.status-grid,.info-grid,.stepper{grid-template-columns:repeat(2,minmax(0,1fr))}.compact-info-grid,.dense-detail-grid,.compact-record-stage{grid-template-columns:1fr}}@media(max-width:720px){.app-shell,.login-shell{padding:12px}.hero-card,.panel{border-radius:20px}.status-grid,.info-grid,.stepper{grid-template-columns:1fr}.row{flex-direction:column}.row.wrap{flex-direction:row}.top-actions{flex-direction:column;align-items:flex-start}.app-header{align-items:flex-start;flex-direction:column}.header-actions{width:100%;flex-wrap:wrap}.record-box.prominent{min-height:auto}.record-time{font-size:34px}.result-hero{flex-direction:column;align-items:flex-start}}
