:root{color:#17202a;text-rendering:optimizelegibility;background:#e8eef1;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.5}*{box-sizing:border-box}body{min-width:320px;margin:0}button,input,select{font:inherit}button:disabled{cursor:not-allowed;opacity:.55}.app-shell{min-height:100vh;padding:24px}.submission-surface{background:#fff;border:1px solid #d4dee6;border-radius:8px;grid-template-rows:auto minmax(0,1fr);max-width:1120px;min-height:calc(100vh - 48px);margin:0 auto;display:grid;box-shadow:0 18px 42px #1f313a14}.topbar{background:#fbfcfd;border-bottom:1px solid #dce5ec;justify-content:space-between;align-items:center;gap:20px;padding:18px 22px;display:flex}.brand-row{color:#17202a;flex-wrap:wrap;align-items:center;gap:12px;min-width:0;font-size:.98rem;font-weight:800;display:flex}.brand-logo{flex:none;width:142px;height:auto;display:block}.brand-logo-large{width:min(260px,100%);height:auto;margin-bottom:10px;display:block}.brand-context{color:#344551;overflow-wrap:anywhere;background:#f2f6f8;border:1px solid #dce5ec;border-radius:999px;align-items:center;min-width:0;min-height:30px;padding:0 10px;font-size:.86rem;font-weight:900;line-height:1.2;display:inline-flex}.step-meter{flex-wrap:wrap;justify-content:flex-end;gap:8px;display:flex}.topbar-actions{justify-content:flex-end;align-items:center;gap:12px;min-width:0;display:flex}.teacher-login-link{color:#256f66;white-space:nowrap;background:#fff;border:1px solid #b6d7d0;border-radius:8px;justify-content:center;align-items:center;min-height:38px;padding:0 12px;font-size:.9rem;font-weight:900;text-decoration:none;display:inline-flex}.teacher-login-link:hover{background:#edf8f5}.guide-page{color:#17202a;background-color:#f4f8f9;background-image:linear-gradient(90deg,#256f661a 1px,#0000 1px),linear-gradient(#256f6614 1px,#0000 1px),none;background-position:0 0,0 0,0 0;background-repeat:repeat,repeat,repeat;background-size:42px 42px;background-attachment:scroll,scroll,scroll;background-origin:padding-box,padding-box,padding-box;background-clip:border-box,border-box,border-box;grid-template-rows:auto auto minmax(0,1fr) auto;gap:26px;min-height:100vh;padding:28px;display:grid}.guide-header{justify-content:space-between;align-items:center;gap:18px;display:flex}.guide-screen-chip{color:#123b36;white-space:nowrap;background:#fff;border:1px solid #b6d7d0;border-radius:8px;align-items:center;gap:8px;min-height:42px;padding:0 14px;font-size:1rem;font-weight:900;display:inline-flex}.guide-hero{grid-template-columns:minmax(0,1fr) minmax(250px,340px);align-items:stretch;gap:20px;display:grid}.guide-hero-copy{align-content:center;gap:14px;min-width:0;display:grid}.guide-hero-copy h1{font-size:clamp(3rem,6vw,6.3rem);line-height:1}.guide-hero-copy p:last-child{color:#344551;max-width:850px;margin:0;font-size:clamp(1.2rem,2vw,1.75rem);font-weight:800}.guide-code-panel{color:#17202a;text-align:center;background:#fff;border:2px solid #17202a;border-radius:8px;align-content:center;place-items:center;gap:6px;min-height:220px;padding:20px;display:grid;box-shadow:8px 8px #256f66}.guide-code-panel span,.guide-code-panel small{color:#52616c;font-weight:900}.guide-code-panel strong{color:#b24632;letter-spacing:0;font-size:clamp(4rem,9vw,7.5rem);line-height:.95}.guide-infographic{grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;display:grid}.guide-step-card{background:#fff;border:2px solid #17202a;border-radius:8px;grid-template-rows:auto auto auto minmax(0,1fr);gap:14px;min-height:310px;padding:22px;display:grid;box-shadow:6px 6px #17202a29}.guide-step-number{color:#fff;background:#17202a;border-radius:999px;place-items:center;width:46px;height:46px;font-size:1.25rem;font-weight:900;display:inline-grid}.guide-step-icon{border-radius:999px;place-items:center;width:86px;height:86px;display:grid}.guide-step-card h2{color:#17202a;margin:0;font-size:clamp(1.65rem,2.4vw,2.55rem);line-height:1.05}.guide-step-card p{color:#344551;margin:0;font-size:clamp(1rem,1.45vw,1.35rem);font-weight:800}.guide-step-teal .guide-step-icon{color:#123b36;background:#d9eee9}.guide-step-coral .guide-step-icon{color:#8d2f20;background:#fff0eb}.guide-step-blue .guide-step-icon{color:#1d4d7a;background:#e4f0fb}.guide-step-green .guide-step-icon{color:#1f5c35;background:#e1f3df}.guide-bottom{grid-template-columns:minmax(0,1fr) minmax(320px,.75fr);gap:16px;display:grid}.guide-qr-panel,.guide-reminder{background:#fff;border:2px solid #d0dce4;border-radius:8px;align-items:center;gap:18px;padding:20px;display:grid}.guide-qr-panel{grid-template-columns:minmax(0,1fr) auto}.guide-qr-panel h2{color:#17202a;margin:0;font-size:clamp(1.65rem,2.7vw,3rem);line-height:1.08}.guide-qr-box{background:#fff;border:1px solid #dce5ec;border-radius:8px;place-items:center;width:170px;height:170px;display:grid}.guide-qr-box img{width:150px;height:150px;display:block}.guide-reminder{color:#17202a;background:#fff9e8;border-color:#e0b764;grid-template-columns:auto minmax(0,1fr)}.guide-reminder strong,.guide-reminder span{grid-column:2}.guide-reminder strong{font-size:clamp(1.15rem,1.6vw,1.55rem);line-height:1.2}.guide-reminder span{color:#6f5a28;font-weight:900}.step-meter span{color:#63717b;background:#f3f6f8;border:1px solid #d9e2e9;border-radius:999px;min-height:34px;padding:7px 10px;font-size:.86rem;font-weight:800}.step-meter .is-active{color:#123b36;background:#d9eee9;border-color:#9ccfc4}.content-area{align-items:center;padding:38px 34px;display:grid}.step-layout{gap:22px;width:min(100%,760px);margin:0 auto;display:grid}.code-step{width:min(100%,900px)}.code-hero{grid-template-columns:minmax(0,1fr) 180px;align-items:center;gap:28px;display:grid}.hero-brand-icon{color:#111;background:#f6f9fa;border:1px solid #dce5ec;border-radius:8px;width:180px;height:180px;padding:26px}.copy-block{max-width:680px}.copy-block.compact{max-width:620px}.eyebrow{color:#b24632;margin:0 0 8px;font-size:.9rem;font-weight:900}h1{color:#17202a;letter-spacing:0;margin:0;font-size:clamp(2rem,5.2vw,4.1rem);line-height:1.06}.compact h1,.result-layout h1{font-size:clamp(1.8rem,4vw,3.4rem)}.copy-block p:last-child,.result-layout p{color:#52616c;max-width:620px;margin:14px 0 0;font-size:1.04rem}.action-block{max-width:620px}.code-step .action-block{max-width:680px}.action-block label{color:#344551;margin-bottom:8px;font-weight:800;display:block}.code-input-row{grid-template-columns:minmax(180px,1fr) auto;gap:12px;display:grid}.code-input-row input{color:#17202a;letter-spacing:0;background:#f8fbfd;border:1px solid #b8c7d3;border-radius:8px;width:100%;height:62px;padding:0 18px;font-size:1.72rem;font-weight:900}.ui-button{color:#fff;cursor:pointer;text-align:center;white-space:normal;background:#256f66;border:0;border-radius:8px;justify-content:center;align-items:center;gap:8px;min-width:0;max-width:100%;min-height:58px;padding:0 20px;font-weight:900;line-height:1.2;display:inline-flex}.ui-button svg,.assignment-mini-button svg,.download-link svg,.zip-download-link svg{flex:none}.ui-button:hover:not(:disabled){background:#1c5a53}.secondary-button{color:#23333d;background:#edf2f5}.secondary-button:hover:not(:disabled){background:#dde7ed}.ghost-button{color:#42525d;background:0 0;border:1px solid #cfdbe4}.ghost-button:hover:not(:disabled){color:#17202a;background:#f5f8fa}.assignment-header{background:#f5f8fa;border:1px solid #dce5ec;border-radius:8px;justify-content:space-between;align-items:center;gap:16px;padding:14px 16px;display:flex}.assignment-header span,.assignment-header strong{display:block}.assignment-header span{color:#667682;font-size:.86rem;font-weight:800}.assignment-header strong{color:#17202a;font-size:1.05rem}.assignment-header button{color:#256f66;cursor:pointer;background:#fff;border:1px solid #b6d7d0;border-radius:8px;min-height:38px;padding:0 12px;font-weight:800}.number-grid{grid-template-columns:repeat(auto-fill,minmax(82px,1fr));gap:10px;display:grid}.number-button{color:#17202a;cursor:pointer;background:#fff;border:1px solid #c8d5de;border-radius:8px;place-items:center;min-height:74px;padding:8px;display:grid}.number-button:hover{border-color:#256f66}.number-button strong{font-size:1.55rem;line-height:1}.number-button span{color:#b24632;font-size:.78rem;font-weight:900}.number-button.is-submitted{background:#fff6f3;border-color:#e4b5a8}.roster-select-panel{gap:14px;display:grid}.roster-search-field{color:#52616c;background:#fff;border:1px solid #c8d5de;border-radius:8px;grid-template-columns:auto minmax(0,1fr);align-items:center;gap:10px;min-height:50px;padding:0 14px;display:grid}.roster-search-field:focus-within{border-color:#256f66;box-shadow:0 0 0 3px #256f661f}.roster-search-field input{color:#17202a;width:100%;min-width:0;min-height:46px;font:inherit;background:0 0;border:0;outline:0;padding:0;font-weight:900}.roster-student-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px;display:grid}.roster-student-button{color:#17202a;cursor:pointer;text-align:left;background:#fff;border:1px solid #c8d5de;border-radius:8px;align-content:center;justify-items:start;gap:4px;min-width:0;min-height:86px;padding:12px;display:grid}.roster-student-button:hover{border-color:#256f66;box-shadow:0 8px 18px #1f313a14}.roster-student-button span{color:#63717b;font-size:.84rem;font-weight:900}.roster-student-button strong{overflow-wrap:anywhere;min-width:0;font-size:1.05rem}.roster-student-button small{color:#b24632;font-size:.78rem;font-weight:900}.roster-student-button.is-submitted{background:#fff6f3;border-color:#e4b5a8}.roster-empty-message{color:#63717b;text-align:center;background:#fbfcfd;border:1px dashed #c8d5de;border-radius:8px;grid-column:1/-1;margin:0;padding:18px;font-weight:900}.file-picker{color:#256f66;cursor:pointer;text-align:center;background:#f7fbfa;border:2px dashed #9ccfc4;border-radius:8px;place-items:center;gap:8px;min-height:184px;padding:24px;font-size:1.1rem;font-weight:900;transition:background .16s,border-color .16s,box-shadow .16s,color .16s;display:grid;position:relative}.file-picker:hover,.file-picker.is-drag-active{color:#123b36;background:#edf8f5;border-color:#256f66}.file-picker.is-drag-active{box-shadow:inset 0 0 0 3px #256f6624}.file-picker.has-file{color:#1f5d7a;background:#f8fbfd;border-color:#86b9d7}.file-picker.has-error{color:#8d2f20;background:#fff7f5;border-color:#d98775}.file-picker svg{width:38px;height:38px}.file-picker span,.file-picker small{overflow-wrap:anywhere;max-width:100%}.file-picker small{color:#63717b;font-size:.88rem;font-weight:800}.file-picker input{clip:rect(0 0 0 0);width:1px;height:1px;position:absolute;overflow:hidden}.screen-capture-panel{background:#fbfcfd;border:1px solid #dce5ec;border-radius:8px;gap:14px;padding:16px;display:grid}.screen-capture-copy{grid-template-columns:auto minmax(0,1fr);align-items:start;gap:12px;min-width:0;display:grid}.screen-capture-copy strong,.screen-capture-copy p{overflow-wrap:anywhere}.screen-capture-copy strong{color:#17202a;font-size:1rem;font-weight:900;display:block}.screen-capture-copy p,.screen-capture-note{color:#63717b;margin:4px 0 0;font-size:.9rem;font-weight:800;line-height:1.5}.screen-capture-icon{color:#256f66;background:#edf8f5;border-radius:8px;place-items:center;width:42px;height:42px;display:grid}.screen-capture-preview{background:#17202a;border:1px solid #cfdbe4;border-radius:8px;overflow:hidden}.screen-capture-preview img{object-fit:contain;background:#111820;width:100%;max-height:280px;display:block}.screen-capture-actions{flex-wrap:wrap;gap:10px;display:flex}.screen-capture-actions .ui-button{min-width:144px}.screen-capture-note{margin:0}.file-summary,.confirm-summary{background:#f5f8fa;border:1px solid #dce5ec;border-radius:8px;gap:10px;padding:16px;display:grid}.file-summary{align-items:center}.file-summary.has-error{background:#fff7f5;border-color:#e4b5a8}.file-summary strong,.confirm-summary strong{overflow-wrap:anywhere;min-width:0}.file-summary span,.confirm-summary span{color:#63717b;font-weight:800}.selected-file-list{gap:8px;margin:0;padding:0;list-style:none;display:grid}.selected-file-list li{border-top:1px solid #dce5ec;grid-template-columns:minmax(0,1fr) auto;gap:10px;min-width:0;padding-top:8px;display:grid}.selected-file-list span{color:#17202a;overflow-wrap:anywhere;min-width:0}.selected-file-list small{color:#63717b;white-space:nowrap;font-weight:900}.confirm-file-list{background:#fbfcfd;border:1px solid #dce5ec;border-radius:8px;padding:14px 16px}.confirm-summary div{grid-template-columns:90px minmax(0,1fr);gap:12px;display:grid}.button-row{flex-wrap:wrap;gap:12px;display:flex}.error-message{color:#8d2f20;background:#fff4f1;border:1px solid #e7b5a8;border-radius:8px;margin:0;padding:12px 14px;font-weight:800}.result-layout{text-align:center;justify-items:center;gap:18px;width:min(100%,680px);margin:0 auto;display:grid}.status-icon{color:#256f66;width:58px;height:58px}.status-icon.success{color:#256f66}.status-icon.danger{color:#b24632}.progress-track{background:#dce5ec;border-radius:999px;width:min(100%,420px);height:14px;overflow:hidden}.progress-track span{background:#256f66;height:100%;display:block}.teacher-shell{background:#e8eef1;min-height:100vh;padding:20px}.teacher-workspace,.teacher-login-panel{background:#fff;border:1px solid #d4dee6;border-radius:8px;max-width:1180px;min-height:calc(100vh - 40px);margin:0 auto;box-shadow:0 18px 42px #1f313a14}.teacher-login-panel{grid-template-columns:minmax(0,1fr) minmax(330px,.78fr);align-items:center;gap:32px;padding:48px;display:grid}.teacher-login-copy{align-content:center;gap:14px;max-width:600px;display:grid}.teacher-login-copy h1,.dashboard-heading h1,.teacher-list-heading h1{font-size:clamp(1.85rem,3.2vw,2.8rem)}.teacher-login-copy p:last-child,.dashboard-heading p,.section-heading p,.teacher-list-heading p{color:#52616c;margin:10px 0 0}.teacher-login-form{background:#f8fbfd;border:1px solid #dce5ec;border-radius:8px;gap:10px;padding:22px;display:grid}.teacher-login-form label,.assignment-create-form label{color:#344551;font-weight:900}.teacher-login-form input,.assignment-create-form input,.assignment-create-form select,.journal-modal-form textarea,.roster-upload-modal-form textarea{color:#17202a;background:#fff;border:1px solid #b8c7d3;border-radius:8px;width:100%;min-height:48px;padding:0 12px}.roster-upload-modal-form input[type=file]{align-items:center;padding:10px 12px;display:flex}.roster-upload-modal-form textarea{min-height:150px;font:inherit;resize:vertical;padding:12px;font-weight:800;line-height:1.45}.journal-modal-form textarea{min-height:96px;font:inherit;resize:vertical;padding:12px;font-weight:800;line-height:1.45}.assignment-create-form{border-top:1px solid #dce5ec;gap:10px;padding-top:18px;display:grid}.assignment-create-form .ui-button{width:100%;min-height:46px;padding:8px 12px}.form-two-column{grid-template-columns:minmax(0,.75fr) minmax(0,1.25fr);gap:10px;display:grid}.form-two-column>div{gap:8px;display:grid}.compact-heading{align-items:center;margin-bottom:2px}.compact-error{padding:10px 12px;font-size:.9rem}.modal-backdrop{z-index:30;background:#17202a70;place-items:center;padding:20px;display:grid;position:fixed;inset:0}.modal-panel{background:#fff;border:1px solid #c8d5de;border-radius:8px;gap:18px;width:min(100%,520px);max-height:calc(100vh - 40px);padding:22px;display:grid;overflow:auto;box-shadow:0 22px 54px #17202a38}.modal-header{justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.modal-header h2{color:#17202a;margin:0;font-size:1.45rem;line-height:1.2}.modal-icon-button{color:#344551;cursor:pointer;background:#f5f8fa;border:1px solid #dce5ec;border-radius:8px;flex:none;justify-content:center;align-items:center;width:38px;height:38px;display:inline-flex}.modal-icon-button:hover:not(:disabled){background:#edf2f5}.modal-create-form{border-top:0;padding-top:0}.assignment-context-fields{background:#f8fbfd;border:1px solid #dce5ec;border-radius:8px;gap:10px;padding:14px;display:grid}.context-field-heading{gap:3px;display:grid}.context-field-heading strong{color:#17202a;font-size:.95rem}.context-field-heading span{color:#63717b;font-size:.82rem;font-weight:800;line-height:1.45}.assignment-create-form select:disabled{color:#8a98a3;cursor:not-allowed;background:#edf2f5}.modal-action-row{grid-template-columns:minmax(0,.8fr) minmax(0,1.2fr);gap:10px;margin-top:4px;display:grid}.modal-action-row .ui-button{width:100%;min-height:48px}.danger-button{color:#fff;background:#b24632}.danger-button:hover:not(:disabled){background:#8d2f20}.edit-static-grid,.delete-confirm-box{background:#f5f8fa;border:1px solid #dce5ec;border-radius:8px;gap:10px;padding:14px;display:grid}.edit-static-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.edit-static-grid.single-column{grid-template-columns:1fr}.edit-static-grid span,.delete-confirm-box span{color:#63717b;font-size:.84rem;font-weight:900}.edit-static-grid strong,.delete-confirm-box strong{color:#17202a;overflow-wrap:anywhere;min-width:0}.delete-confirm-box p{color:#8d2f20;margin:0;font-weight:900}.bulk-delete-list{gap:6px;margin:0;padding:0;list-style:none;display:grid}.bulk-delete-list li{background:#fff;border:1px solid #dce5ec;border-radius:8px;grid-template-columns:minmax(0,1fr) auto;gap:10px;min-width:0;padding:8px 10px;display:grid}.bulk-delete-list span{color:#17202a;overflow-wrap:anywhere;min-width:0}.bulk-delete-list small{color:#63717b;white-space:nowrap;font-weight:900}.qr-modal-panel{width:min(100%,420px)}.qr-preview{background:#f8fbfd;border:1px solid #dce5ec;border-radius:8px;place-items:center;min-height:260px;padding:18px;display:grid}.qr-preview img{background:#fff;border:8px solid #fff;border-radius:8px;width:min(100%,260px);height:auto;display:block}.qr-link-box{background:#f5f8fa;border:1px solid #dce5ec;border-radius:8px;gap:4px;padding:12px;display:grid}.qr-link-box span{color:#63717b;font-size:.82rem;font-weight:900}.qr-link-box strong{color:#17202a;overflow-wrap:anywhere;min-width:0;font-size:.92rem}.teacher-topbar{background:#fbfcfd;border-bottom:1px solid #dce5ec;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;padding:18px 20px;display:flex}.teacher-actions{flex-wrap:wrap;justify-content:flex-end;gap:10px;min-width:0;display:flex}.teacher-actions .ui-button{flex:0 auto;min-height:42px;padding:8px 14px}.teacher-page-nav-button{color:#344551;background:#fff;border-color:#c8d5de}.teacher-page-nav-button.is-active{color:#fff;background:#256f66;border-color:#256f66}.teacher-page-nav-button:disabled{color:#8a98a3;background:#edf2f5}.teacher-main{grid-template-columns:296px minmax(0,1fr);min-height:calc(100vh - 118px);display:grid}.assignment-sidebar{background:#f7fafb;border-right:1px solid #dce5ec;align-content:start;gap:16px;padding:20px;display:grid}.teacher-meta{border-bottom:1px solid #dce5ec;gap:2px;padding-bottom:16px;display:grid}.teacher-meta span,.teacher-meta small,.assignment-summary dt{color:#63717b;font-size:.82rem;font-weight:900}.teacher-meta strong{color:#17202a;font-size:1.1rem}.assignment-list-section{gap:10px;min-width:0;display:grid}.assignment-list-header{justify-content:space-between;align-items:center;gap:10px;display:flex}.assignment-list-header h2{color:#17202a;margin:0;font-size:1rem;line-height:1.2}.assignment-list-header span{color:#63717b;font-size:.84rem;font-weight:900}.assignment-list{gap:8px;min-width:0;max-height:360px;padding-right:2px;display:grid;overflow-y:auto}.assignment-list-item{color:#17202a;cursor:pointer;text-align:left;background:#fff;border:1px solid #dce5ec;border-radius:8px;gap:8px;width:100%;min-width:0;padding:12px;display:grid}.assignment-list-item:hover{background:#f8fbfd;border-color:#9ccfc4}.assignment-list-item.is-selected{background:#edf8f5;border-color:#256f66;box-shadow:inset 3px 0 #256f66}.assignment-list-item strong{overflow-wrap:anywhere;min-width:0;font-size:.98rem;line-height:1.25}.assignment-list-meta{color:#52616c;flex-wrap:wrap;gap:6px;font-size:.8rem;font-weight:900;display:flex}.assignment-list-meta span{background:#f3f6f8;border:1px solid #dce5ec;border-radius:999px;min-height:24px;padding:2px 7px}.assignment-list-date{color:#63717b;font-size:.82rem;font-weight:900}.assignment-status-badge{color:#23333d;border:1px solid #d7e0e7;border-radius:999px;justify-self:start;min-height:24px;padding:2px 8px;font-size:.78rem;font-weight:900}.assignment-status-open{color:#123b36;background:#d9eee9;border-color:#9ccfc4}.assignment-status-closed{color:#8d2f20;background:#fff0eb;border-color:#d98775}.assignment-status-expired{color:#7a520c;background:#fff1c9;border-color:#e0b764}.assignment-status-draft{color:#52616c;background:#f3f6f8;border-color:#d7e0e7}.assignment-list-empty{color:#63717b;text-align:center;background:#fff;border:1px dashed #c8d5de;border-radius:8px;align-content:center;place-items:center;gap:8px;min-height:150px;padding:16px;font-weight:900;display:grid}.assignment-list-empty p{margin:0}.assignment-summary{gap:10px;margin:0;display:grid}.assignment-summary-panel{background:#fff;border:1px solid #dce5ec;border-radius:8px;gap:12px;padding:14px;display:grid}.assignment-summary div{grid-template-columns:58px minmax(0,1fr);gap:8px;display:grid}.assignment-summary dd{overflow-wrap:anywhere;min-width:0;margin:0;font-weight:900}.invite-code-chip{color:#123b36;letter-spacing:0;background:#edf8f5;border:1px solid #b6d7d0;border-radius:8px;align-items:center;min-height:30px;padding:0 8px;display:inline-flex}.assignment-action-row{grid-template-columns:1fr;gap:8px;display:grid}.assignment-action-row .danger-mini-button{grid-column:auto}.assignment-mini-button{color:#23333d;cursor:pointer;text-align:center;white-space:normal;background:#fff;border:1px solid #c8d5de;border-radius:8px;justify-content:center;align-items:center;gap:6px;width:100%;min-width:0;min-height:38px;padding:8px 10px;font-size:.86rem;font-weight:900;line-height:1.2;text-decoration:none;display:inline-flex}.assignment-mini-button:hover:not(:disabled){background:#edf8f5;border-color:#9ccfc4}.danger-mini-button{color:#8d2f20;background:#fff7f5;border-color:#e4b5a8}.danger-mini-button:hover:not(:disabled){background:#fff0eb;border-color:#d98775}.teacher-content{min-width:0;padding:24px}.teacher-list-page{gap:18px;min-width:0;padding:24px;display:grid}.teacher-list-heading{border-bottom:1px solid #dce5ec;justify-content:space-between;align-items:flex-start;gap:16px;padding-bottom:16px;display:flex}.teacher-list-heading>div:first-child{min-width:0}.teacher-list-count{background:#f5f8fa;border:1px solid #dce5ec;border-radius:8px;gap:2px;min-width:96px;padding:12px 14px;display:grid}.teacher-list-count span{color:#63717b;font-size:.82rem;font-weight:900}.teacher-list-count strong{color:#17202a;font-size:1.6rem;line-height:1}.bulk-download-bar{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:12px;display:flex}.bulk-download-bar span{color:#52616c;font-weight:900}.assignment-filter-bar{background:#f8fbfd;border:1px solid #dce5ec;border-radius:8px;grid-template-columns:repeat(3,minmax(0,1fr)) auto;align-items:end;gap:10px;padding:14px;display:grid}.assignment-filter-bar label{gap:6px;min-width:0;display:grid}.assignment-filter-bar span{color:#52616c;font-size:.82rem;font-weight:900}.assignment-filter-bar select{color:#17202a;width:100%;min-width:0;min-height:42px;font:inherit;background:#fff;border:1px solid #c8d5de;border-radius:8px;padding:0 10px;font-weight:800}.assignment-filter-bar select:disabled{color:#8a98a3;cursor:not-allowed;background:#edf2f5}.assignment-filter-bar .ui-button{min-height:42px;padding:8px 12px}.school-management-page{align-content:start}.school-management-forms{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:14px;display:grid}.school-management-form{background:#fbfcfd;border:1px solid #dce5ec;border-radius:8px;align-content:start;gap:9px;min-width:0;padding:16px;display:grid}.school-form-heading{color:#17202a;align-items:center;gap:8px;display:flex}.school-form-heading svg{color:#256f66}.school-management-form label,.checkbox-row{color:#52616c;font-size:.84rem;font-weight:900}.school-management-form input,.school-management-form select,.school-management-form textarea,.inline-edit-form input{color:#17202a;min-width:0;min-height:42px;font:inherit;background:#fff;border:1px solid #c8d5de;border-radius:8px;padding:0 12px;font-weight:800}.school-management-form textarea{resize:vertical;min-height:118px;padding:10px 12px;line-height:1.45}.roster-import-form{grid-column:span 2}.csv-preview{background:#f5f8fa;border:1px solid #dce5ec;border-radius:8px;gap:3px;padding:10px 12px;display:grid}.csv-preview strong{color:#17202a;font-weight:900}.csv-preview small{color:#63717b;overflow-wrap:anywhere;font-weight:800}.csv-preview.has-error{background:#fff7f5;border-color:#e4b5a8}.csv-preview.has-error small{color:#8d2f20}.checkbox-row{align-items:center;gap:8px;display:inline-flex}.checkbox-row input{accent-color:#256f66;width:18px;height:18px;min-height:0;padding:0}.school-card-list{gap:12px;display:grid}.school-card{background:#fff;border:1px solid #dce5ec;border-radius:8px;gap:14px;padding:16px;display:grid}.school-card.is-archived,.academic-year-card.is-archived,.class-group-row.is-archived{opacity:.62}.school-card-header,.academic-year-header,.class-group-row{justify-content:space-between;align-items:center;gap:12px;min-width:0;display:flex}.school-card-title{align-items:flex-start;gap:10px;min-width:0;display:flex}.school-card-title svg{color:#256f66;flex:none}.school-card-title strong,.academic-year-header strong,.class-group-row span{color:#17202a;overflow-wrap:anywhere;min-width:0;font-weight:900}.school-card-title small,.academic-year-header small,.class-group-empty{color:#63717b;font-size:.84rem;font-weight:800}.school-card-actions{flex-wrap:wrap;justify-content:flex-end;gap:8px;display:flex}.school-card-actions button,.inline-edit-form button{color:#23333d;cursor:pointer;white-space:nowrap;background:#fff;border:1px solid #c8d5de;border-radius:8px;justify-content:center;align-items:center;gap:5px;min-height:34px;padding:0 10px;font-size:.82rem;font-weight:900;display:inline-flex}.school-card-actions button:hover:not(:disabled),.inline-edit-form button:hover:not(:disabled){background:#edf8f5;border-color:#9ccfc4}.school-card-actions .danger-inline-button{color:#8d2f20;background:#fff7f5;border-color:#e4b5a8}.school-card-actions .danger-inline-button:hover:not(:disabled){background:#fff0eb;border-color:#d98775}.school-card-actions button:disabled,.inline-edit-form button:disabled{cursor:not-allowed}.academic-year-list{border-top:1px solid #e5edf2;gap:0;display:grid}.academic-year-card{border-bottom:1px solid #e5edf2;gap:10px;padding:12px 0;display:grid}.academic-year-card:last-child{border-bottom:0}.current-year-badge{color:#123b36;background:#edf8f5;border:1px solid #b6d7d0;border-radius:8px;align-items:center;min-height:28px;padding:0 8px;font-size:.8rem;font-weight:900;display:inline-flex}.class-group-list{gap:6px;min-width:0;display:grid}.roster-list{border-top:1px dashed #dce5ec;gap:8px;min-width:0;padding-top:10px;display:grid}.roster-list-heading{color:#52616c;justify-content:space-between;align-items:center;gap:10px;font-size:.84rem;font-weight:900;display:flex}.class-group-row{background:#f8fbfd;border:1px solid #e5edf2;border-radius:8px;min-height:42px;padding:8px 10px}.roster-row{background:#fff;border:1px solid #e5edf2;border-radius:8px;justify-content:space-between;align-items:center;gap:12px;min-width:0;min-height:46px;padding:8px 10px;display:flex}.roster-row.is-archived{opacity:.62}.roster-row>span{gap:2px;min-width:0;display:grid}.roster-row strong{color:#17202a;overflow-wrap:anywhere;min-width:0}.roster-row small{color:#63717b;font-size:.82rem;font-weight:800}.class-group-empty{margin:0;padding:8px 10px}.inline-edit-form{flex-wrap:wrap;gap:8px;min-width:0;display:flex}.inline-edit-form input{flex:220px}.table-inline-edit-form{min-width:300px}.school-workspace-layout{grid-template-columns:minmax(240px,300px) minmax(0,1fr);align-items:start;gap:16px;min-width:0;display:grid}.school-workspace-table-layout{grid-template-columns:1fr}.school-workspace-sidebar,.school-workspace-panel{background:#fff;border:1px solid #dce5ec;border-radius:8px;min-width:0}.school-workspace-sidebar{position:sticky;top:16px;overflow:hidden}.school-workspace-create{background:#fbfcfd;border-bottom:1px solid #dce5ec;gap:9px;padding:14px;display:grid}.school-workspace-create label,.class-workspace-create span,.workspace-section-heading span{color:#52616c;font-size:.84rem;font-weight:900}.school-workspace-create input,.workspace-inline-create input,.class-workspace-create input,.manual-roster-count-row input,.manual-roster-name-row input{color:#17202a;width:100%;min-width:0;min-height:42px;font:inherit;background:#fff;border:1px solid #c8d5de;border-radius:8px;padding:0 12px;font-weight:800}.school-workspace-list{gap:8px;min-height:120px;max-height:calc(100vh - 360px);padding:12px;display:grid;overflow:auto}.school-workspace-item{color:#17202a;cursor:pointer;text-align:left;background:#fff;border:1px solid #dce5ec;border-radius:8px;gap:3px;width:100%;padding:12px;display:grid}.school-workspace-item:hover,.school-workspace-item.is-active{background:#edf8f5;border-color:#9ccfc4}.school-workspace-item span{overflow-wrap:anywhere;min-width:0;font-weight:900}.school-workspace-item small{color:#63717b;font-size:.82rem;font-weight:800}.school-workspace-main{gap:14px;min-width:0;display:grid}.school-workspace-panel{gap:16px;padding:16px;display:grid}.school-list-panel{gap:14px}.school-table-wrap{border:1px solid #dce5ec;border-radius:8px;overflow-x:auto}.school-table{border-collapse:collapse;background:#fff;width:100%;min-width:760px}.school-table th,.school-table td{text-align:left;vertical-align:middle;border-bottom:1px solid #e5edf2;padding:11px 12px}.school-table th{color:#52616c;background:#f5f8fa;font-size:.82rem;font-weight:900}.school-table tr:last-child td{border-bottom:0}.school-table tr:hover td,.school-table tr.is-active td{background:#edf8f5}.school-table-title{gap:2px;min-width:0;display:grid}.school-table-title strong{color:#17202a;overflow-wrap:anywhere;font-weight:900}.school-table-title small{color:#63717b;font-size:.82rem;font-weight:800}.school-table-actions{flex-wrap:wrap;gap:8px;display:flex}.school-table-actions .assignment-table-button{min-height:34px}.class-detail-table{min-width:680px}.school-workspace-header,.workspace-section-heading{justify-content:space-between;align-items:flex-start;gap:14px;min-width:0;display:flex}.school-workspace-header h2{color:#17202a;overflow-wrap:anywhere;margin:0;font-size:1.45rem;line-height:1.2}.school-workspace-header>div:first-child,.workspace-section-heading>div:first-child{gap:4px;min-width:0;display:grid}.school-workspace-header>div:first-child>span{color:#63717b;font-size:.9rem;font-weight:800}.school-workspace-section{border-top:1px solid #e5edf2;gap:12px;min-width:0;padding-top:14px;display:grid}.workspace-section-heading strong{color:#17202a;font-size:1.02rem;font-weight:900}.workspace-inline-create{grid-template-columns:minmax(86px,110px) auto;align-items:center;gap:8px;display:grid}.workspace-inline-create .ui-button,.class-workspace-create .ui-button{min-height:42px}.workspace-tab-row{flex-wrap:wrap;gap:8px;display:flex}.class-detail-tabs{flex-wrap:wrap;gap:8px;padding-bottom:2px;display:flex}.workspace-tab{color:#52616c;cursor:pointer;background:#f5f8fa;border:1px solid #dce5ec;border-radius:8px;justify-content:center;align-items:center;gap:6px;min-height:38px;padding:0 12px;font-weight:900;display:inline-flex}.workspace-tab:hover,.workspace-tab.is-active{color:#123b36;background:#edf8f5;border-color:#9ccfc4}.workspace-tab span{color:#1f4f49;background:#fff;border:1px solid #b6d7d0;border-radius:999px;padding:2px 6px;font-size:.72rem;font-weight:900}.class-workspace-create{background:#f8fbfd;border:1px solid #e5edf2;border-radius:8px;grid-template-columns:minmax(120px,.7fr) minmax(160px,1fr) auto;align-items:end;gap:10px;min-width:0;padding:12px;display:grid}.class-workspace-create label{gap:6px;min-width:0;display:grid}.class-workspace-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:10px;min-width:0;display:grid}.class-workspace-card{background:#fff;border:1px solid #dce5ec;border-radius:8px;gap:10px;padding:12px;display:grid}.class-workspace-card.is-active{background:#fbf7ed;border-color:#d8bc72}.class-workspace-card>button{width:100%;color:inherit;cursor:pointer;text-align:left;background:0 0;border:0;gap:3px;padding:0;display:grid}.class-workspace-card strong{color:#17202a;overflow-wrap:anywhere;font-weight:900}.class-workspace-card span{color:#63717b;font-size:.82rem;font-weight:800}.student-roster-workspace{grid-template-columns:1fr;align-items:start;gap:14px;min-width:0;display:grid}.student-roster-current{background:#f8fbfd;border:1px solid #e5edf2;border-radius:8px;gap:12px;min-width:0;padding:14px;display:grid}.student-roster-table-wrap{border:1px solid #dce5ec;border-radius:8px;overflow-x:auto}.student-roster-table{border-collapse:collapse;background:#fff;width:100%;min-width:430px}.student-roster-table th,.student-roster-table td{text-align:left;border-bottom:1px solid #e5edf2;padding:10px 12px}.student-roster-table th{color:#52616c;background:#f5f8fa;font-size:.82rem;font-weight:900}.student-roster-table tr:last-child td{border-bottom:0}.class-record-panel{background:#f8fbfd;border:1px solid #e5edf2;border-radius:8px;gap:12px;min-width:0;padding:14px;display:grid}.class-record-toolbar{grid-template-columns:minmax(150px,220px) minmax(0,1fr);align-items:end;gap:12px;min-width:0;display:grid}.class-record-toolbar label{color:#52616c;gap:6px;font-size:.84rem;font-weight:900;display:grid}.class-record-toolbar input,.attendance-table input,.attendance-table select{color:#17202a;width:100%;min-width:0;min-height:38px;font:inherit;background:#fff;border:1px solid #c8d5de;border-radius:8px;padding:0 10px;font-weight:800}.attendance-summary-row{flex-wrap:wrap;gap:6px;display:flex}.attendance-summary-row span{color:#1f4f49;background:#fff;border:1px solid #d7e0e7;border-radius:8px;align-items:center;min-height:32px;padding:0 8px;font-size:.8rem;font-weight:900;display:inline-flex}.class-record-note{color:#52616c;margin:0;font-size:.84rem;font-weight:800}.class-record-actions{justify-content:flex-end;display:flex}.class-record-actions .ui-button{min-height:42px}.attendance-table{min-width:720px}.attendance-table th:first-child,.attendance-table td:first-child{width:72px}.attendance-table th:nth-child(3),.attendance-table td:nth-child(3){width:150px}.journal-table{min-width:820px}.journal-table th:first-child,.journal-table td:first-child{width:112px}.journal-table th:nth-child(4),.journal-table td:nth-child(4),.journal-table th:nth-child(5),.journal-table td:nth-child(5){width:120px}.journal-summary-text{color:#52616c;-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:.84rem;font-weight:800;display:-webkit-box;overflow:hidden}.journal-linked-assignment-list{flex-wrap:wrap;gap:6px;min-width:0;display:flex}.journal-linked-assignment{color:#1f4f49;text-overflow:ellipsis;white-space:nowrap;background:#edf8f5;border:1px solid #b6d7d0;border-radius:8px;align-items:center;max-width:180px;min-height:28px;padding:0 8px;font-size:.78rem;font-weight:900;display:inline-flex;overflow:hidden}.journal-table-actions{flex-wrap:wrap;gap:6px;display:flex}.journal-table-actions .assignment-table-button{text-decoration:none}.journal-assignment-picker{background:#f8fbfd;border:1px solid #dce5ec;border-radius:8px;gap:10px;padding:12px;display:grid}.journal-assignment-list{gap:8px;max-height:190px;display:grid;overflow:auto}.journal-assignment-option{background:#fff;border:1px solid #e5edf2;border-radius:8px;grid-template-columns:20px minmax(0,1fr);align-items:center;gap:10px;min-width:0;padding:10px;display:grid}.journal-assignment-option input{accent-color:#256f66;width:18px;height:18px;min-height:0;padding:0}.journal-assignment-option span{gap:2px;min-width:0;display:grid}.journal-assignment-option strong,.journal-assignment-option small{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.journal-assignment-option small,.compact-muted-text{color:#63717b;font-size:.82rem;font-weight:800}.compact-muted-text{margin:0}.journal-modal-panel{width:min(100%,680px)}.journal-detail-modal-panel{width:min(100%,720px)}.journal-detail-body{gap:12px;display:grid}.journal-detail-meta{flex-wrap:wrap;gap:8px;display:flex}.journal-detail-meta span{color:#1f4f49;background:#edf8f5;border:1px solid #b6d7d0;border-radius:8px;align-items:center;min-height:30px;padding:0 9px;font-size:.8rem;font-weight:900;display:inline-flex}.journal-detail-section{background:#f8fbfd;border:1px solid #e5edf2;border-radius:8px;gap:8px;padding:12px;display:grid}.journal-detail-section h3{color:#17202a;margin:0;font-size:.95rem}.journal-detail-section p{color:#344551;white-space:pre-wrap;margin:0;font-size:.9rem;font-weight:800;line-height:1.55}.journal-detail-actions{flex-wrap:wrap;justify-content:flex-end;gap:8px;display:flex}.journal-detail-actions .assignment-table-button{min-height:42px;text-decoration:none}.journal-detail-actions .ui-button{min-height:42px}.roster-modal-panel{width:min(100%,640px)}.manual-roster-modal-form{gap:12px}.manual-roster-count-row{grid-template-columns:92px minmax(0,180px);align-items:center;gap:10px;margin:0;display:grid}.manual-roster-count-row span,.manual-roster-name-row span{color:#52616c;font-size:.86rem;font-weight:900}.manual-roster-help{background:#f8fbfd;border:1px solid #e5edf2;border-radius:8px;gap:4px;padding:12px;display:grid}.manual-roster-help strong{color:#17202a;font-size:.94rem}.manual-roster-help span{color:#63717b;font-size:.84rem;font-weight:800;line-height:1.5}.manual-roster-name-grid{background:#f8fbfd;border:1px solid #e5edf2;border-radius:8px;gap:8px;max-height:min(42vh,360px);padding:10px;display:grid;overflow:auto}.manual-roster-name-row{grid-template-columns:64px minmax(0,1fr);align-items:center;gap:10px;min-width:0;margin:0;display:grid}.compact-empty-state{background:#f8fbfd;border:1px solid #e5edf2;border-radius:8px;min-height:180px;padding:18px}.school-modal-form{gap:11px}.assignment-table-wrap{border:1px solid #dce5ec;border-radius:8px;overflow-x:auto}.assignment-table{border-collapse:collapse;background:#fff;width:100%;min-width:900px}.assignment-table th,.assignment-table td{text-align:left;vertical-align:middle;border-bottom:1px solid #e5edf2;padding:11px 12px}.assignment-table th{color:#52616c;background:#f5f8fa;font-size:.82rem;font-weight:900}.assignment-select-cell{text-align:center;width:48px}.assignment-select-cell input{accent-color:#256f66;width:18px;height:18px}.assignment-table tr:last-child td{border-bottom:0}.assignment-table tr:hover td{background:#f8fbfd}.assignment-title-cell{gap:2px;min-width:0;display:grid}.assignment-title-cell strong{color:#17202a;overflow-wrap:anywhere;min-width:0}.assignment-title-cell small{color:#8a98a3;font-size:.8rem;font-weight:800}.assignment-title-cell .assignment-context-line{color:#256f66;font-weight:900}.assignment-table-actions{flex-wrap:wrap;gap:8px;display:flex}.assignment-table-button{color:#23333d;cursor:pointer;white-space:nowrap;background:#fff;border:1px solid #c8d5de;border-radius:8px;justify-content:center;align-items:center;gap:5px;min-height:34px;padding:0 10px;font-size:.84rem;font-weight:900;display:inline-flex}.assignment-table-button:hover{background:#edf2f5}.assignment-table-button.primary{color:#fff;background:#256f66;border-color:#256f66}.assignment-table-button.primary:hover{background:#1c5a53}.assignment-table-button.danger{color:#8d2f20;background:#fff7f5;border-color:#e4b5a8}.assignment-table-button.danger:hover{background:#fff0eb;border-color:#d98775}.back-to-list-button{width:100%;min-height:44px}.dashboard-layout{gap:18px;display:grid}.collage-entry-section,.collage-panel{border-top:1px solid #dce5ec;gap:14px;margin-top:18px;padding-top:18px;display:grid}.collage-entry-section{grid-template-columns:minmax(0,1fr) auto;align-items:center}.collage-entry-section h2,.collage-heading h2{color:#17202a;margin:0;font-size:1.18rem}.collage-entry-section p:last-child,.collage-heading p{color:#63717b;margin:6px 0 0;font-weight:800}.collage-actions{flex-wrap:wrap;justify-content:flex-end;gap:10px;display:flex}.collage-preview-workspace{grid-template-columns:minmax(220px,300px) minmax(0,1fr);align-items:start;gap:14px;display:grid}.collage-option-panel{background:#f8fbfd;border:1px solid #dce5ec;border-radius:8px;align-content:start;gap:14px;min-width:0;padding:14px;display:grid}.collage-option-group,.collage-range-control{gap:8px;min-width:0;display:grid}.collage-option-group>span,.collage-range-control>span{color:#52616c;font-size:.84rem;font-weight:900}.segmented-control{background:#edf2f5;border:1px solid #d7e0e7;border-radius:8px;gap:4px;min-width:0;padding:4px;display:flex}.segmented-control button{color:#52616c;cursor:pointer;min-width:0;min-height:34px;font:inherit;background:0 0;border:0;border-radius:6px;flex:1 1 0;padding:0 10px;font-size:.84rem;font-weight:900}.segmented-control button:hover,.segmented-control button.is-active{color:#1f4f49;background:#fff}.segmented-control button:disabled{color:#8a98a3;cursor:not-allowed}.segmented-control button.is-active{box-shadow:0 1px 4px #17202a1f}.wrap-control{flex-wrap:wrap}.wrap-control button{flex-basis:78px}.collage-range-control input{accent-color:#256f66;width:100%}.color-swatch-row{flex-wrap:wrap;gap:8px;display:flex}.color-swatch-row button{cursor:pointer;border:2px solid #d7e0e7;border-radius:999px;width:34px;height:34px;padding:0;box-shadow:inset 0 0 0 1px #17202a14}.color-swatch-row button:hover,.color-swatch-row button.is-active{border-color:#256f66}.color-swatch-row button.is-active{box-shadow:0 0 0 3px #256f6624,inset 0 0 0 1px #17202a1a}.privacy-notice{color:#285c55;background:#edf8f5;border:1px solid #b6d7d0;border-radius:8px;gap:4px;padding:10px 12px;display:grid}.privacy-notice strong{color:#123b36;font-size:.86rem;font-weight:900}.privacy-notice span{color:#52616c;font-size:.82rem;font-weight:800;line-height:1.45}.privacy-notice.is-warning{color:#7a520c;background:#fff7e8;border-color:#e0b764}.privacy-notice.is-warning strong{color:#6d4403}.collage-preview-stage{background:#fbfcfd;border:1px solid #dce5ec;border-radius:8px;gap:10px;min-width:0;padding:14px;display:grid}.collage-preview-meta{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;display:flex}.collage-preview-meta strong{color:#17202a;font-size:.94rem;font-weight:900}.collage-preview-meta span{color:#63717b;font-size:.82rem;font-weight:800}.collage-preview-stage canvas{background:#fff;border:1px solid #d7e0e7;border-radius:8px;width:100%;height:auto;display:block}.collage-report-download{background:#edf8f5;border:1px solid #b6d7d0;border-radius:8px;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;min-width:0;padding:12px;display:flex}.collage-report-download>div{gap:3px;min-width:0;display:grid}.collage-report-download strong{color:#17202a;overflow-wrap:anywhere;min-width:0;font-weight:900}.collage-report-download span{color:#52616c;font-size:.84rem;font-weight:800}.collage-report-download small{color:#63717b;font-size:.78rem;font-weight:800;line-height:1.4}.collage-image-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px;display:grid}.collage-image-card{background:#fff;border:1px solid #dce5ec;border-radius:8px;min-width:0;display:grid;overflow:hidden}.collage-image-card.is-selected{border-color:#256f66;box-shadow:0 0 0 3px #256f661f}.collage-image-preview-button{aspect-ratio:4/3;cursor:pointer;background:#edf2f5;border:0;width:100%;padding:0;display:block;position:relative;overflow:hidden}.collage-image-preview-button img{object-fit:cover;width:100%;height:100%;display:block}.collage-image-preview-button span{color:#fff;background:#17202ac7;border-radius:8px;min-height:28px;padding:5px 8px;font-size:.78rem;font-weight:900;position:absolute;bottom:8px;right:8px}.collage-image-card.is-selected .collage-image-preview-button span{background:#256f66}.collage-image-meta{gap:3px;min-width:0;padding:10px;display:grid}.collage-image-meta strong,.collage-image-meta span{overflow-wrap:anywhere;min-width:0}.collage-image-meta strong{color:#17202a;font-weight:900}.collage-image-meta span,.collage-image-meta small{color:#63717b;font-size:.82rem;font-weight:800}.dashboard-heading{border-bottom:1px solid #dce5ec;flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;padding-bottom:16px;display:flex}.dashboard-heading>div:first-child{flex:280px;min-width:0}.dashboard-stats{flex:0 300px;grid-template-columns:repeat(3,minmax(76px,1fr));gap:8px;min-width:min(100%,280px);display:grid}.stat-tile{background:#f5f8fa;border:1px solid #dce5ec;border-radius:8px;gap:2px;padding:10px 12px;display:grid}.stat-tile span{color:#63717b;font-size:.82rem;font-weight:900}.stat-tile strong{color:#17202a;font-size:1.45rem;line-height:1}.status-submitted{background:#edf8f5;border-color:#8cc9bc}.status-resubmitted{background:#fff7e8;border-color:#e0b764}.status-missing{color:#63717b;background:#f5f8fa;border-color:#d7e0e7}.submission-section{gap:10px;display:grid}.section-heading{justify-content:space-between;align-items:center;gap:16px;display:flex}.section-heading h2{color:#17202a;margin:0;font-size:1.25rem}.submission-table-wrap{border:1px solid #dce5ec;border-radius:8px;overflow-x:auto}.submission-table{border-collapse:collapse;background:#fff;width:100%;min-width:860px}.submission-table th,.submission-table td{text-align:left;vertical-align:middle;border-bottom:1px solid #e5edf2;padding:10px 12px}.submission-table th{color:#52616c;background:#f5f8fa;font-size:.82rem;font-weight:900}.submission-table tr:last-child td{border-bottom:0}.submission-row:hover{background:#f8fbfd}.submission-row.is-missing{background:#fbfcfd}.student-number-cell{color:#17202a;width:92px;font-size:1.02rem;font-weight:900}.student-identity-cell{gap:2px;min-width:0;display:grid}.student-identity-cell strong{color:#17202a;white-space:nowrap;font-weight:900}.student-identity-cell small{color:#63717b;overflow-wrap:anywhere;font-size:.78rem;font-weight:800}.filename-cell{overflow-wrap:anywhere;gap:3px;max-width:330px;font-weight:900;display:grid}.filename-cell small{color:#63717b;font-size:.78rem;font-weight:800}.muted-cell{color:#8a98a3;font-weight:800}.status-pill{color:#23333d;white-space:nowrap;border:1px solid #d7e0e7;border-radius:999px;align-items:center;gap:6px;min-height:30px;padding:0 9px;font-size:.84rem;font-weight:900;display:inline-flex}.version-badge,.download-link{white-space:nowrap;border-radius:8px;align-items:center;gap:6px;min-height:32px;padding:0 10px;font-size:.88rem;font-weight:900;text-decoration:none;display:inline-flex}.version-badge{color:#1f4f49;background:#e6f5f1}.version-badge.is-resubmitted{color:#7a520c;background:#fff1c9}.download-link{color:#fff;background:#256f66}.zip-download-link{color:#fff;text-align:center;white-space:normal;background:#256f66;border-radius:8px;flex:0 auto;justify-content:center;align-items:center;gap:8px;max-width:100%;min-height:46px;padding:0 16px;font-weight:900;line-height:1.2;text-decoration:none;display:inline-flex}.download-link:hover,.zip-download-link:hover{background:#1c5a53}.zip-download-link.is-disabled{color:#71808b;pointer-events:none;background:#e4ebef}.table-empty,.empty-state{color:#63717b;text-align:center;font-weight:900}.empty-state{align-content:center;place-items:center;gap:12px;min-height:260px;display:grid}.spin{animation:.9s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}@media (width<=980px){.guide-hero,.guide-bottom{grid-template-columns:1fr}.guide-infographic{grid-template-columns:repeat(2,minmax(0,1fr))}.school-management-forms,.school-workspace-layout,.student-roster-workspace{grid-template-columns:1fr}.school-workspace-sidebar{position:static}.school-workspace-list{max-height:none}.teacher-main{grid-template-columns:1fr}.assignment-sidebar{border-bottom:1px solid #dce5ec;border-right:0}.assignment-action-row{grid-template-columns:repeat(auto-fit,minmax(132px,1fr))}.collage-entry-section,.collage-preview-workspace{grid-template-columns:1fr}.assignment-list{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));max-height:none;padding-right:0}.teacher-topbar{align-items:flex-start}.teacher-actions{justify-content:flex-start}.teacher-content{padding:20px}}@media (width<=760px){.guide-page{gap:18px;padding:16px}.guide-header{flex-direction:column;align-items:stretch}.guide-screen-chip{white-space:normal;justify-content:center}.guide-infographic,.guide-qr-panel{grid-template-columns:1fr}.guide-code-panel{min-height:180px}.guide-step-card{min-height:230px}.guide-qr-box{aspect-ratio:1;justify-self:center;width:100%;max-width:220px;height:auto}.app-shell,.teacher-shell{padding:12px}.teacher-workspace,.teacher-login-panel{min-height:calc(100vh - 24px)}.teacher-login-panel{grid-template-columns:1fr;padding:24px}.brand-logo-large{width:min(220px,100%)}.teacher-topbar,.dashboard-heading,.section-heading,.teacher-list-heading,.school-card-header,.academic-year-header,.class-group-row,.roster-row{flex-direction:column;align-items:stretch}.roster-import-form{grid-column:auto}.school-card-actions,.inline-edit-form,.school-table-actions,.school-workspace-header,.workspace-section-heading{justify-content:stretch}.school-workspace-header,.workspace-section-heading{flex-direction:column;align-items:stretch}.school-card-actions button,.school-table-actions .assignment-table-button,.inline-edit-form button{width:100%}.workspace-inline-create,.class-workspace-create,.class-record-toolbar,.manual-roster-count-row,.manual-roster-name-row{grid-template-columns:1fr}.class-record-actions,.class-record-actions .ui-button{width:100%}.assignment-filter-bar{grid-template-columns:1fr}.assignment-filter-bar .ui-button,.teacher-actions,.teacher-actions .ui-button{width:100%}.teacher-main{grid-template-columns:1fr}.assignment-sidebar{border-bottom:1px solid #dce5ec;border-right:0}.teacher-content,.teacher-list-page{padding:18px}.teacher-list-count{width:100%}.bulk-download-bar{flex-direction:column;align-items:stretch}.bulk-download-bar .zip-download-link,.collage-actions,.collage-actions .ui-button,.collage-report-download .zip-download-link,.collage-entry-section .ui-button{width:100%}.segmented-control{align-items:stretch}.collage-option-panel,.collage-preview-stage{padding:12px}.dashboard-stats{grid-template-columns:repeat(3,minmax(0,1fr))}.submission-surface{min-height:calc(100vh - 24px)}.topbar,.assignment-header{flex-direction:column;align-items:stretch}.brand-row{flex-wrap:wrap;justify-content:flex-start}.brand-logo{width:128px}.brand-context{min-height:28px}.step-meter{justify-content:flex-start}.topbar-actions{flex-direction:column;align-items:flex-start}.content-area{padding:20px}.code-hero{grid-template-columns:1fr;gap:18px}.hero-brand-icon{width:118px;height:118px;padding:18px}.code-input-row,.file-summary,.confirm-summary div{grid-template-columns:1fr}.button-row{flex-direction:column}.button-row .ui-button,.code-input-row .ui-button,.screen-capture-actions .ui-button,.modal-action-row{width:100%}.modal-backdrop{padding:12px}.modal-panel{max-height:calc(100vh - 24px);padding:18px}.modal-action-row,.edit-static-grid{grid-template-columns:1fr}}
