:root{color:#17202a;font-synthesis:none;text-rendering:optimizelegibility;background:#f4f6f8;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{min-width:320px;min-height:100vh;margin:0}button,textarea{font:inherit}button{cursor:pointer}.app-shell{grid-template-columns:260px 1fr;min-height:100vh;display:grid}.sidebar{background:#fff;border-right:1px solid #dce3ea;flex-direction:column;gap:24px;padding:24px;display:flex}.brand{align-items:center;gap:12px;display:flex}.brand-mark{color:#fff;background:#0f766e;border-radius:8px;place-items:center;width:40px;height:40px;font-weight:800;display:grid}.brand strong,.brand span{display:block}.brand span{color:#64748b;margin-top:2px;font-size:13px}.role-switch{background:#eef3f5;border-radius:8px;grid-template-columns:1fr 1fr;gap:4px;padding:4px;display:grid}.role-switch button{color:#506172;background:0 0;border:0;border-radius:6px;padding:9px 10px;font-weight:700}.role-switch .active{color:#0f766e;background:#fff;box-shadow:0 1px 3px #0f172a1f}.nav-list{gap:8px;display:grid}.nav-button{color:#5b6b7c;text-align:left;background:0 0;border:0;border-radius:8px;align-items:center;gap:10px;width:100%;padding:12px;display:flex}.nav-button.active,.nav-button:hover{color:#0f766e;background:#e8f4f2}.content{flex-direction:column;gap:24px;padding:28px;display:flex}.topbar,.section-title,.panel-header,.card-title-row,.download-panel{justify-content:space-between;align-items:center;gap:16px;display:flex}.topbar h1,.section-title h2,.panel h2,.template-card h3,.download-panel h2{margin:0;line-height:1.2}.topbar h1{font-size:30px}.eyebrow{color:#64748b;letter-spacing:0;margin:0 0 6px;font-size:13px;font-weight:800}.topbar-actions{flex-wrap:wrap;gap:8px;display:flex}.status-pill,.mini-badge{color:#475569;background:#e7edf3;border-radius:999px;align-items:center;min-height:28px;padding:0 10px;font-size:13px;font-weight:700;display:inline-flex}.status-pill.success{color:#0f766e;background:#dff5ef}.page-stack,.grid{gap:20px;display:grid}.two-columns{grid-template-columns:minmax(0,1.35fr) minmax(320px,.65fr)}.teacher-grid{grid-template-columns:minmax(340px,.95fr) minmax(360px,1.05fr)}.summary-grid{grid-template-columns:repeat(5,minmax(150px,1fr));gap:16px;display:grid}.metric-card,.panel{background:#fff;border:1px solid #dce3ea;border-radius:8px;box-shadow:0 1px 2px #0f172a0d}.metric-card{padding:18px}.metric-card span,.panel p,.template-card p,.download-panel p{color:#64748b}.metric-card strong{margin-top:10px;font-size:28px;display:block}.metric-card.green strong{color:#0f766e}.metric-card.blue strong{color:#2563eb}.metric-card.amber strong{color:#b45309}.panel{padding:20px}.steps-list,.mapping-list,.check-list{gap:12px;margin-top:18px;display:grid}.step-row,.mapping-row,.check-row{background:#f7fafc;border-radius:8px;align-items:center;gap:12px;padding:12px;display:flex}.step-row>span{color:#0f766e;background:#dff5ef;border-radius:999px;place-items:center;width:30px;height:30px;font-weight:800;display:grid}.step-row p,.action-panel p,.template-card p,.download-panel p{margin:4px 0 0}.primary-button{color:#fff;background:#0f766e;border:0;border-radius:8px;justify-content:center;align-items:center;gap:8px;min-height:42px;padding:0 16px;font-weight:800;display:inline-flex}.primary-button:hover{background:#0b5f59}.action-panel{align-content:center;gap:14px;display:grid}.template-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;display:grid}.template-card{gap:18px;display:grid}.template-icon{color:#0f766e;background:#e8f4f2;border-radius:8px;place-items:center;width:42px;height:42px;display:grid}.disabled-upload{color:#64748b;border:1px dashed #b7c4d1;border-radius:8px;justify-content:center;align-items:center;gap:8px;min-height:44px;font-weight:700;display:inline-flex}.field-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin-top:18px;display:grid}.field-grid span{color:#334155;background:#f7fafc;border-radius:8px;padding:12px;font-weight:700}.mapping-board{grid-template-columns:minmax(0,1fr) 70px minmax(0,1fr);align-items:stretch;gap:12px;display:grid}.document-panel{background:#fff;border:1px solid #dce3ea;border-radius:8px;padding:18px}.document-panel h3{margin:0 0 14px}.doc-slot{background:#f8fafc;border:1px solid #b7c4d1;border-radius:8px;min-height:48px;margin-top:10px;padding:13px;font-weight:800}.doc-slot.source{background:#fff8e6}.arrow-column{align-content:end;gap:10px;padding-bottom:1px;display:grid}.connector{color:#0f766e;place-items:center;height:48px;display:grid}.mapping-row span{color:#475569;min-width:190px}.mapping-row strong,.ok-icon{color:#0f766e}.warn-icon{color:#b45309}.preview-sheet{background:#f8fafc;border:1px solid #dce3ea;border-radius:8px;grid-template-columns:120px 1fr;gap:10px;margin-top:18px;padding:16px;display:grid}.preview-sheet strong{color:#475569}.week-list{grid-template-columns:repeat(5,1fr);gap:8px;margin-top:18px;display:grid}.day-chip{color:#334155;background:#fff;border:1px solid #dce3ea;border-radius:8px;gap:4px;min-height:86px;padding:12px;display:grid}.day-chip.active{background:#e8f4f2;border-color:#0f766e}.day-chip em{color:#b45309;font-size:12px;font-style:normal;font-weight:800}.info-strip{color:#7c4a03;background:#fff8e6;border-radius:8px;margin-top:14px;padding:12px;font-weight:700}textarea{color:#17202a;resize:vertical;border:1px solid #cbd5e1;border-radius:8px;width:100%;min-height:180px;margin-top:16px;padding:14px}textarea:focus{border-color:#0f766e;outline:3px solid #c7eee7}.child-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;margin-top:16px;display:grid}.child-note span{font-weight:800;display:block}.download-panel{background:#f3fbf8;border-color:#9dd8cc}@media (width<=1100px){.app-shell{grid-template-columns:1fr}.sidebar{position:static}.summary-grid,.template-grid,.two-columns,.teacher-grid,.child-grid,.mapping-board{grid-template-columns:1fr}.arrow-column{display:none}}@media (width<=720px){.content{padding:18px}.topbar,.section-title,.download-panel{flex-direction:column;align-items:flex-start}.week-list,.field-grid{grid-template-columns:repeat(2,1fr)}}button:disabled{cursor:not-allowed;opacity:.55}.button-row{flex-wrap:wrap;gap:10px;display:flex}.secondary-button{color:#334155;background:#fff;border:1px solid #cbd5e1;border-radius:8px;justify-content:center;align-items:center;gap:8px;min-height:42px;padding:0 14px;font-weight:800;display:inline-flex}.secondary-button:hover{color:#0f766e;border-color:#0f766e}.labeling-toolbar{grid-template-columns:minmax(220px,1fr) auto minmax(220px,1fr) auto;align-items:end;gap:14px;display:grid}.labeling-toolbar label,.field-label{color:#334155;gap:8px;font-weight:800;display:grid}select,.text-input{color:#17202a;background:#fff;border:1px solid #cbd5e1;border-radius:8px;width:100%;min-height:42px;padding:0 12px}select:focus,.text-input:focus{border-color:#0f766e;outline:3px solid #c7eee7}.mapping-board.interactive{align-items:start}.slot-list{gap:8px;display:grid}.slot-button{color:#334155;text-align:left;background:#f8fafc;border:1px solid #dce3ea;border-radius:8px;justify-content:space-between;align-items:center;gap:10px;width:100%;min-height:44px;padding:10px 12px;font-weight:800;display:flex}.slot-button.source{background:#fff8e6}.slot-button.selected{color:#0f766e;background:#e8f4f2;border-color:#0f766e}.slot-button em{color:#64748b;font-size:12px;font-style:normal;font-weight:800}.week-selector{grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;margin-top:18px;display:grid}.week-selector button{color:#334155;background:#fff;border:1px solid #dce3ea;border-radius:8px;gap:4px;min-height:62px;padding:10px;display:grid}.week-selector button.active{color:#0f766e;background:#e8f4f2;border-color:#0f766e}.week-selector span{color:#64748b;font-size:13px}.template-toggle{background:#eef3f5;border-radius:8px;grid-template-columns:1fr 1fr;gap:6px;margin-top:14px;padding:4px;display:grid}.template-toggle button{color:#506172;background:0 0;border:0;border-radius:6px;min-height:38px;font-weight:800}.template-toggle button.active{color:#0f766e;background:#fff;box-shadow:0 1px 3px #0f172a1f}.template-toggle+.text-input{margin-top:10px}.preview-sheet.compact{grid-template-columns:72px 1fr}.field-label+.field-label{margin-top:18px}.child-stack{gap:16px;margin-top:16px;display:grid}.child-entry{background:#f8fafc;border:1px solid #dce3ea;border-radius:8px;gap:8px;padding:14px;display:grid}.child-entry textarea{background:#fff;min-height:92px;margin-top:0}.text-preview{color:#17202a;white-space:pre-wrap;background:#f8fafc;border:1px solid #dce3ea;border-radius:8px;max-height:360px;margin:16px 0 0;padding:16px;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:13px;line-height:1.6;overflow:auto}@media (width<=1100px){.labeling-toolbar{grid-template-columns:1fr;align-items:stretch}}@media (width<=720px){.week-selector{grid-template-columns:repeat(2,1fr)}}.blank-field-list{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:16px;display:grid}.blank-field-list span{color:#334155;background:#f8fafc;border:1px solid #dce3ea;border-radius:8px;padding:12px;font-weight:800}@media (width<=720px){.blank-field-list{grid-template-columns:1fr}}.r2-panel{gap:16px;display:grid}.r2-status-row{color:#334155;background:#f8fafc;border:1px solid #dce3ea;border-radius:8px;align-items:flex-start;gap:12px;padding:14px;display:flex}.r2-status-row svg{color:#0f766e;flex:none}.r2-status-row strong,.remote-template-row strong{display:block}.r2-status-row p{color:#64748b;margin:4px 0 0}.remote-template-list{gap:8px;display:grid}.remote-template-row{color:#17202a;background:#fff;border:1px solid #dce3ea;border-radius:8px;justify-content:space-between;align-items:center;gap:12px;padding:12px;text-decoration:none;display:flex}.remote-template-row:hover{border-color:#0f766e}.remote-template-row em{color:#64748b;margin-top:3px;font-size:12px;font-style:normal;display:block}.remote-template-row small{color:#475569;flex:none;font-weight:800}.empty-state{color:#64748b;background:#fff;border:1px dashed #b7c4d1;border-radius:8px;padding:14px;font-weight:700}.compact-panel{padding:16px 20px}.file-drop{color:#475569;background:#f8fafc;border:1px dashed #9fb0c1;border-radius:8px;justify-content:center;align-items:center;gap:8px;min-height:44px;padding:0 14px;font-weight:800;display:inline-flex;position:relative;overflow:hidden}.file-drop:hover{color:#0f766e;border-color:#0f766e}.file-drop.loading{opacity:.65}.file-drop.wide{width:100%;margin-top:16px}.file-drop input{opacity:0;cursor:pointer;position:absolute;inset:0}.upload-message,.parse-status{color:#64748b;background:#f7fafc;border-radius:8px;margin:0;padding:10px 12px;font-size:13px;font-weight:800}.upload-message.done,.parse-status.done{color:#0f766e;background:#dff5ef}.upload-message.error,.parse-status.error{color:#b91c1c;background:#fee2e2}.parse-status{margin-top:10px}.month-selector{grid-template-columns:repeat(6,minmax(0,1fr));gap:8px;margin-top:16px;display:grid}.month-selector button{color:#334155;background:#fff;border:1px solid #dce3ea;border-radius:8px;min-height:38px;font-weight:800}.month-selector button.active{color:#0f766e;background:#e8f4f2;border-color:#0f766e}.sample-pair-panel{gap:16px;display:grid}.sample-pair-grid{grid-template-columns:minmax(0,1fr) auto minmax(0,1fr);align-items:center;gap:14px;display:grid}.sample-list{background:#f8fafc;border:1px solid #dce3ea;border-radius:8px;gap:8px;padding:14px;display:grid}.sample-list a,.sample-list span{color:#475569;font-size:13px;font-weight:700;text-decoration:none}.sample-list a:hover{color:#0f766e}.history-list{gap:10px;display:grid}.history-row{background:#f8fafc;border:1px solid #dce3ea;border-radius:8px;justify-content:space-between;align-items:center;gap:14px;padding:14px;display:flex}.history-row strong,.history-row span,.history-row em{display:block}.history-row span,.history-row em{color:#64748b;margin-top:4px;font-size:13px;font-style:normal}.history-row small{color:#0f766e;flex:none;font-weight:800}.settings-form{grid-template-columns:repeat(3,minmax(0,1fr));gap:18px;display:grid}.settings-form .field-label:last-child{grid-column:1/-1}@media (width<=900px){.month-selector{grid-template-columns:repeat(3,minmax(0,1fr))}.sample-pair-grid,.settings-form{grid-template-columns:1fr}}.generation-note{font-weight:800;color:#0f766e!important;margin-top:8px!important}.cell-label-panel{gap:14px;display:grid}.compact-toggle{width:168px;margin-top:0}.cell-label-summary{flex-wrap:wrap;gap:8px;display:flex}.cell-label-summary span{color:#475569;background:#f8fafc;border-radius:8px;padding:8px 10px;font-size:13px;font-weight:800}.cell-grid{background:#f8fafc;border:1px solid #dce3ea;border-radius:8px;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;max-height:420px;padding:10px;display:grid;overflow:auto}.cell-button{color:#334155;text-align:left;background:#fff;border:1px solid #dce3ea;border-radius:8px;gap:5px;min-height:84px;padding:10px;display:grid}.cell-button:hover{border-color:#0f766e}.cell-button.assigned{background:#e8f4f2;border-color:#0f766e}.cell-button.suggested:not(.assigned){background:#fff8e6;border-color:#e3c46a}.cell-button strong{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.cell-button span,.cell-button em{color:#64748b;font-size:12px;font-style:normal;font-weight:800}.mapping-row em{color:#0f766e;margin-left:auto;font-size:12px;font-style:normal;font-weight:800}@media (width<=1100px){.cell-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width<=720px){.cell-grid{grid-template-columns:1fr}}.upload-rule{color:#64748b;margin:-6px 0 0;font-size:12px;font-weight:800}
