:root{color:#172033;background:#f5f7fb;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*,:before,:after{box-sizing:border-box}html{-webkit-text-size-adjust:100%}body{margin:0;overflow-x:clip}main{width:100%;max-width:1280px;padding-top:clamp(12px,3.5vw,32px);padding-bottom:max(clamp(12px, 3.5vw, 32px), env(safe-area-inset-bottom,0px));padding-left:max(clamp(12px, 3.5vw, 32px), env(safe-area-inset-left,0px));padding-right:max(clamp(12px, 3.5vw, 32px), env(safe-area-inset-right,0px));margin:0 auto}.auth-main{place-items:center;min-height:100vh;display:grid}.auth-card{background:#fff;border:1px solid #dbe3f0;border-radius:24px;gap:16px;width:min(420px,100vw - 24px);padding:clamp(18px,5vw,28px);display:grid;box-shadow:0 18px 60px #0f2f5724}.auth-card p,.auth-card h1{margin:0}.auth-card h1{color:#16325c}.hero{color:#fff;background:linear-gradient(135deg,#16325c,#315f9f);border-radius:clamp(16px,4vw,24px);flex-direction:row;justify-content:space-between;align-items:center;gap:clamp(14px,3vw,24px);min-width:0;padding:clamp(18px,4vw,32px);display:flex}.hero p{opacity:.85;margin:0 0 8px}.hero h1{word-break:break-word;margin:0 0 12px;font-size:clamp(1.35rem,5vw + .5rem,52px);line-height:1.15}.hero>div:first-child{min-width:0}.hero>div:first-child>span{opacity:.95;font-size:clamp(.88rem,2.5vw,1rem);line-height:1.45;display:block}@media (width<=719px){.hero{flex-direction:column;align-items:stretch}.hero-actions,.hero-actions .button-link{width:100%}}.hero-actions{flex-shrink:0;gap:10px;min-width:0;display:grid}@media (width>=720px){.hero-actions{min-width:210px}}.user-pill{color:#fff;text-overflow:ellipsis;white-space:nowrap;background:#ffffff29;border-radius:999px;place-items:center;max-width:100%;min-height:38px;padding:0 12px;font-weight:800;display:grid;overflow:hidden}.button-link{color:#16325c;background:#fff;border-radius:10px;place-items:center;min-height:40px;padding:0 12px;font-weight:800;text-decoration:none;display:grid}.grid,.panels{grid-template-columns:repeat(auto-fit,minmax(min(100%,280px),1fr));gap:18px;min-width:0;margin-top:18px;display:grid}.card{background:#fff;border:1px solid #dbe3f0;border-radius:18px;min-width:0;padding:clamp(14px,3vw,20px);box-shadow:0 10px 30px #16325c0f}.full-width-card{grid-column:1/-1}.card h2{margin:0 0 16px;font-size:18px}.collapsible-card summary{cursor:pointer;font-size:18px;font-weight:700}.collapsible-content{margin-top:16px}form{gap:10px;display:grid}.inline-form{grid-template-columns:repeat(auto-fit,minmax(min(100%,160px),1fr));align-items:end;margin-bottom:14px}input,select,textarea,button{min-height:40px;font:inherit;border:1px solid #cdd7e6;border-radius:10px;padding:0 12px}textarea{resize:vertical;min-height:160px;padding:12px}button{color:#fff;cursor:pointer;background:#16325c;border:0;font-weight:700}button:disabled{cursor:not-allowed;background:#aab6c8}.secondary-button{color:#16325c;background:#edf3fb}.action-row{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:14px;display:flex}.message{top:max(12px, env(safe-area-inset-top,0px));right:max(12px, env(safe-area-inset-right,0px));left:max(12px, env(safe-area-inset-left,0px));z-index:50;color:#16325c;background:#e9f2ff;border:1px solid #bfd0e8;border-radius:14px;align-items:flex-start;gap:12px;width:auto;max-width:min(520px,100vw - 24px);margin-left:auto;padding:14px 18px;font-weight:700;display:flex;position:fixed;box-shadow:0 18px 50px #0f2f5738}.message span{flex:1}.message button{background:#16325c;min-height:30px;padding:0 10px;font-size:12px}.page-tabs{-webkit-overflow-scrolling:touch;scrollbar-width:thin;overscroll-behavior-x:contain;background:#fff;border:1px solid #dbe3f0;border-radius:18px;flex-wrap:nowrap;gap:8px;margin-top:18px;padding:8px;display:flex;overflow:auto hidden}.page-tabs button{color:#172033;background:#edf3fb;flex:none;min-height:38px;padding:0 14px;font-size:clamp(.8rem,2.8vw,1rem)}.page-tabs button.active{color:#fff;background:#16325c}.academic-view-toggle{flex-wrap:wrap;gap:8px;margin-bottom:12px;display:flex}.academic-view-toggle button{color:#172033;background:#edf3fb;min-height:38px}.academic-view-toggle button.active{color:#fff;background:#16325c}.status-strip{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin-top:18px;display:grid}.status-strip div{background:#fff;border:1px solid #dbe3f0;border-radius:14px;gap:6px;padding:14px;display:grid}.status-strip strong{color:#5d6b82;font-size:13px}.status-strip span{color:#16325c;font-size:18px;font-weight:800}.upload{gap:8px;margin-bottom:10px;font-weight:700;display:grid}.hint{color:#5d6b82;font-size:14px;line-height:1.5}.rule-list{gap:10px;margin:0 0 14px;padding-left:20px;line-height:1.5;display:grid}.course-list{gap:8px;max-height:180px;margin-bottom:12px;display:grid;overflow:auto}.compact-list{gap:8px;max-height:160px;margin-top:12px;display:grid;overflow:auto}.subcard-title{color:#16325c;margin:0 0 4px;font-size:15px;font-weight:700}.period-hub{flex-direction:column;gap:20px;display:flex}.period-hub-section{min-width:0}.period-hub-title{color:#16325c;letter-spacing:-.02em;margin:0 0 6px;font-size:15px;font-weight:800}.period-hub-hint{margin-top:0;margin-bottom:12px}.period-select-toolbar{flex-wrap:wrap;align-items:stretch;gap:10px;display:flex}.period-select-input{flex:1;min-width:min(100%,220px);min-height:44px}.button-danger-ghost{color:#9b1c12;background:#fff5f4;border:1px solid #c4352b;border-radius:10px;flex-shrink:0;min-height:44px;padding:0 14px;font-weight:700}.button-danger-ghost:hover:not(:disabled){background:#ffe8e6}.button-danger-ghost:disabled{opacity:.45;cursor:not-allowed;color:#8894a8;background:#f0f2f6;border-color:#d5dbe8}.period-hub-settings{border-top:1px solid #e8eef8;padding-top:4px}.period-collapse{background:#fbfcff;border:1px solid #dfe8f4;border-radius:12px;margin-top:10px;overflow:hidden}.period-collapse summary{cursor:pointer;color:#16325c;background:linear-gradient(#f2f6fd,#eef3fb);border-bottom:1px solid #0000;padding:12px 14px;font-size:14px;font-weight:700;list-style:none}.period-collapse[open] summary{border-bottom-color:#dfe8f4}.period-collapse summary::-webkit-details-marker{display:none}.period-collapse summary:after{content:"";float:right;border-bottom:2px solid #315f9f;border-right:2px solid #315f9f;width:8px;height:8px;margin-top:5px;margin-left:10px;transition:transform .15s;transform:rotate(45deg)}.period-collapse[open] summary:after{margin-top:8px;transform:rotate(-135deg)}.period-collapse-body{padding:12px 14px 14px}.period-details-form--nested,.export-title-form--nested{border-top:0;margin-top:0;padding-top:0}.period-hub-new{background:linear-gradient(165deg,#f7faff,#f0f5fc);border:1px solid #d6e2f5;border-radius:14px;padding:16px}.new-period-form{gap:14px}.form-fieldset{background:#fff;border:1px solid #dbe7f6;border-radius:12px;margin:0;padding:12px 14px 14px}.form-fieldset legend{color:#214a7a;padding:0 8px;font-size:13px;font-weight:800}.form-fieldset-optional{background:#fcfdff;border-style:dashed}.fieldset-hint{margin:0 0 10px;font-size:13px}.form-row-2{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));align-items:end;gap:10px;display:grid}.stacked-label{gap:6px;display:grid}.stacked-label .label-text{color:#3d4f6f;font-size:13px;font-weight:700}.textarea-compact{min-height:88px}.new-period-submit{min-height:46px;margin-top:4px;font-size:15px}.period-details-form{border-top:1px solid #dfe6f2;gap:10px;margin-top:16px;padding-top:14px;display:grid}.course-button{color:#172033;text-align:left;background:#edf3fb;min-height:36px;font-weight:600}.course-button.selected{color:#fff;background:#16325c}.course-summary{color:#172033;background:#edf3fb;border-radius:10px;gap:4px;padding:10px;display:grid}.course-summary strong{color:#16325c}.selected-students{background:#f5f7fb;border-radius:12px;margin-top:14px;padding:12px;font-size:14px}.danger-button{background:#b42318;width:100%;margin-top:10px}.no-margin{margin-top:0}.small-danger-button{background:#b42318;min-height:28px;padding:0 10px;font-size:12px}.table-scroll{-webkit-overflow-scrolling:touch;overscroll-behavior:contain;max-width:100%;max-height:460px;overflow:auto}.compact-table{max-height:220px;margin-top:10px}.calendar-scroll{-webkit-overflow-scrolling:touch;overscroll-behavior-x:contain;border-radius:inherit;touch-action:pan-x pan-y;width:100%;max-width:100%;overflow:auto visible}.day-calendar{margin-top:18px}.day-calendar-title{color:#16325c;flex-wrap:wrap;align-items:baseline;gap:10px;margin:0 0 10px;display:inline-flex}.day-calendar-title span{text-transform:capitalize}.day-calendar-title small{color:#5d6b82;text-transform:capitalize;font-size:14px;font-weight:800}.week-controls{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;margin-bottom:12px;display:flex}.week-controls button{flex:0 auto;min-height:40px}.week-controls strong{text-align:center;color:#16325c;flex:100%;order:3}@media (width>=480px){.week-controls strong{flex:0 auto;order:unset;text-align:center}}.calendar-grid{border:1px solid #dbe3f0;border-radius:14px;width:100%;min-width:0;display:grid;overflow:hidden}.class-calendar-grid{border:1px solid #dbe3f0;border-radius:14px;grid-template-columns:minmax(4.75rem,9rem) repeat(4,minmax(0,1fr));width:100%;min-width:0;display:grid;overflow:hidden}.calendar-head,.calendar-time,.calendar-cell{border-bottom:1px solid #edf1f7;border-right:1px solid #edf1f7;padding:10px}.calendar-head{z-index:1;color:#16325c;background:#edf3fb;font-weight:800;position:sticky;top:0}.calendar-time{color:#5d6b82;background:#f8fafd;font-weight:700}.calendar-cell{background:#fff;min-width:0;min-height:96px}.calendar-cell:hover{background:#f5f9ff}.calendar-cell--empty.calendar-cell--placeable{cursor:pointer}.calendar-cell--empty.calendar-cell--placeable:hover{outline-offset:-1px;background:#eef5ff;outline:1px dashed #9bb8e8}.calendar-cell--picker-open{z-index:3;outline-offset:-2px;background:#eef4fc;outline:2px solid #6b9ae8;position:relative}.cell-place-hint{text-align:center;color:#6b8fc4;opacity:.75;pointer-events:none;-webkit-user-select:none;user-select:none;padding:12px 6px;font-size:12px;font-weight:600;display:block}.calendar-cell--placeable:hover .cell-place-hint{opacity:1;color:#3d6eb5}.cell-place-picker{background:#fff;border:1px solid #bfd0e8;border-radius:10px;gap:6px;padding:8px;display:grid;overflow:auto;box-shadow:0 8px 24px #16325c24}.cell-place-picker--floating{z-index:10000}.cell-place-picker-header{color:#16325c;justify-content:space-between;align-items:center;gap:8px;font-size:12px;font-weight:800;display:flex}.cell-place-picker-close{color:#5d6b82;cursor:pointer;background:0 0;border:none;padding:0 4px;font-size:18px;line-height:1}.cell-place-picker-close:hover{color:#16325c}.cell-place-picker-empty{color:#5d6b82;margin:0;font-size:12px}.cell-place-picker-list{gap:4px;margin:0;padding:0;list-style:none;display:grid}.cell-place-picker-item{text-align:left;cursor:pointer;width:100%;font:inherit;background:#f8fafd;border:1px solid #dbe3f0;border-radius:8px;gap:2px;padding:8px 10px;display:grid}.cell-place-picker-item:hover{background:#edf3fb;border-color:#9bb8e8}.cell-place-picker-item strong{color:#16325c;font-size:12px}.cell-place-picker-item span{color:#5d6b82;font-size:11px}.cell-place-picker-subtitle{color:#5d6b82;margin-top:2px;font-size:10px;font-weight:600;display:block}.cell-place-picker-item--blocked{cursor:not-allowed;opacity:.62;background:#f3f4f6;border-color:#e2e6ed}.cell-place-picker-item--blocked:hover{background:#f3f4f6;border-color:#e2e6ed}.cell-place-picker-block-reason{color:#9a4a4a;font-size:10px;font-style:normal;line-height:1.35}.export-title-form{border-top:1px solid #e4eaf4;gap:8px;margin-top:14px;padding-top:12px;display:grid}.export-title-form textarea{min-height:72px}.schedule-toolbar{flex-wrap:wrap;gap:8px;margin-bottom:12px;display:flex}.invigilator-load-panel{background:#fbfdff;border:1px solid #dbe3f0;border-radius:12px;margin-bottom:14px;padding:10px 12px}.invigilator-load-panel summary{cursor:pointer;color:#16325c;font-weight:700}.invigilator-load-list{gap:6px;margin:10px 0 0;padding:0;list-style:none;display:grid}.invigilator-load-row{grid-template-columns:minmax(120px,1.4fr) 1fr auto;align-items:center;gap:8px;font-size:12px;display:grid}.invigilator-load-name{color:#2a3142}.invigilator-load-bar-wrap{background:#e8eef8;border-radius:999px;height:8px;overflow:hidden}.invigilator-load-bar{border-radius:inherit;background:linear-gradient(90deg,#6b9ae8,#3d6eb5);height:100%;display:block}.invigilator-load-count{text-align:right;color:#16325c;min-width:1.5rem}.exam-editor-meta{margin:0 0 10px}.invigilator-load-badge{color:#5d6b82;font-weight:600;display:block}.schedule-conflict-panel{background:#fff8f7;border:1px solid #e8b8b4;border-radius:12px;margin-bottom:16px;padding:12px 14px}.schedule-conflict-panel h4{color:#8b1d15;margin:0 0 6px;font-size:15px}.schedule-conflict-list{color:#2a3142;margin:8px 0 0;padding-left:1.1rem;font-size:13px;line-height:1.45}.schedule-conflict-list>li{gap:6px;margin-bottom:14px;display:grid}.schedule-conflict-hint{margin:0 0 10px;font-size:12px}.schedule-conflict-body{gap:6px;display:grid}.schedule-conflict-severity{text-transform:uppercase;border-radius:4px;margin-right:6px;padding:1px 6px;font-size:11px;font-weight:800;display:inline-block}.schedule-conflict-severity--hard{color:#8b1d15;background:#fde2e0}.schedule-conflict-severity--soft{color:#7a5a00;background:#fff4d6}.schedule-conflict-message{display:inline}.schedule-conflict-students{gap:8px;margin:0;padding:0;list-style:none;display:grid}.schedule-conflict-students-fallback{color:#3d4f6f;margin:0;font-size:12px}.schedule-conflict-student-row{color:#2a3142;background:#fff;border:1px solid #e8d4d2;border-radius:8px;gap:4px;padding:8px 10px;font-size:12px;display:grid}.schedule-conflict-student-row strong{color:#16325c}.schedule-conflict-courses{flex-wrap:wrap;gap:6px;display:flex}.schedule-conflict-course-tag{color:#8b1d15;background:#fde2e0;border-radius:6px;gap:1px;padding:4px 8px;font-size:11px;font-weight:700;display:inline-grid}.schedule-conflict-course-tag small{color:#6b3a36;font-size:10px;font-weight:500}.unscheduled-pool{background:#fbfdff;border:1px dashed #bfd0e8;border-radius:12px;margin-bottom:16px;padding:12px}.unscheduled-pool h4{margin:0 0 6px;font-size:14px}.unscheduled-pool-chips{flex-wrap:wrap;gap:8px;display:flex}.exam-chip-unscheduled{margin-bottom:0}.exam-chip-actions{flex-wrap:wrap;gap:6px;margin-top:4px;display:flex}.exam-chip{color:#16325c;cursor:grab;text-align:left;overflow-wrap:anywhere;word-break:break-word;background:#e9f2ff;border:1px solid #bfd0e8;border-radius:12px;gap:4px;min-width:0;margin-bottom:8px;padding:10px;display:grid}.exam-chip:active{cursor:grabbing}.exam-chip-readonly,.exam-chip-readonly:active{cursor:default}.exam-chip-own{background:#e8f5e9;border-color:#2d6a4f}.exam-chip span{color:#34445c;font-size:12px;line-height:1.3}.exam-chip-meta{grid-template-columns:repeat(2,minmax(0,1fr));gap:6px;display:grid}.exam-chip-meta span{background:#fff9;border-radius:8px;gap:2px;min-width:0;padding:6px;display:grid}.exam-chip-meta b{color:#16325c;font-size:11px}.exam-chip small{color:#607089;font-weight:700}.chip-edit-button{color:#16325c;background:#fff;border:1px solid #bfd0e8;min-height:30px;margin-top:0;padding:0 10px;font-size:12px}.assignment-editor-actions{flex-wrap:wrap;gap:10px;margin-top:8px;display:flex}.assignment-editor{right:max(12px, env(safe-area-inset-right,0px));bottom:max(12px, env(safe-area-inset-bottom,0px));left:max(12px, env(safe-area-inset-left,0px));z-index:20;width:auto;max-width:min(760px,100vw - 24px);max-height:min(560px, calc(100vh - 24px - env(safe-area-inset-top,0px) - env(safe-area-inset-bottom,0px)));-webkit-overflow-scrolling:touch;background:#f8fbff;border:1px solid #bfd0e8;border-radius:16px;margin:0 auto;padding:16px;position:fixed;overflow:auto;box-shadow:0 18px 60px #0f2f5738}.assignment-editor-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px;display:flex}.assignment-editor-header div{gap:4px;display:grid}.assignment-editor-header span{color:#5d6b82;font-size:13px}.assignment-editor-header button{color:#16325c;background:#edf3fb;min-height:34px}.schedule-edit-grid{grid-template-columns:repeat(auto-fit,minmax(min(100%,160px),1fr));gap:10px;margin-bottom:14px;display:grid}.schedule-edit-grid label{color:#16325c;gap:6px;font-size:13px;font-weight:800;display:grid}.assignment-columns{grid-template-columns:repeat(auto-fit,minmax(min(100%,220px),1fr));gap:16px;display:grid}.assignment-columns h4{color:#16325c;margin:0 0 8px}.check-list{background:#fff;border:1px solid #dbe3f0;border-radius:12px;gap:8px;max-height:220px;padding:10px;display:grid;overflow:auto}.check-list label{align-items:center;gap:8px;font-size:14px;display:flex}.check-list input{min-height:auto}table{border-collapse:collapse;width:100%;font-size:14px}th,td{text-align:left;vertical-align:top;border-bottom:1px solid #edf1f7;padding:10px}td input,td select{box-sizing:border-box;width:100%}.table-actions{flex-wrap:wrap;align-items:center;gap:8px;display:flex}form.inline-row-form{gap:0;min-height:0;margin:0;padding:0;display:inline-flex}form.inline-row-form button{min-height:34px}@media (width<=640px){.academic-view-toggle{flex-direction:column}.academic-view-toggle button{flex:unset;width:100%;min-height:42px}.exam-chip-meta{grid-template-columns:1fr}.calendar-head,.calendar-time,.calendar-cell{padding:7px 5px;font-size:.78rem}.calendar-time{-webkit-hyphens:auto;hyphens:auto;font-size:.72rem;line-height:1.25}.card h2{font-size:clamp(1rem,4.2vw,18px)}th,td{padding:8px 6px;font-size:.85rem}.page-tabs button{min-height:40px}}@media (width>=1100px){.class-calendar-grid{grid-template-columns:8.75rem repeat(4,minmax(11rem,1fr))}}.tab-nav{border-bottom:1px solid #d4d8dd;flex-wrap:wrap;gap:.4rem;margin:1rem 0 1.25rem;display:flex}.tab-nav button{color:#4a5159;cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;padding:.55rem .95rem;font-size:.95rem;font-weight:600}.tab-nav button:hover{color:#1f3a8a}.tab-nav button.active{color:#1f3a8a;border-bottom-color:#1f3a8a}.data-panel{padding:1rem 0}.data-panel .subnav{flex-wrap:wrap;gap:.35rem;margin-bottom:1rem;display:flex}.data-panel .subnav button{cursor:pointer;background:#eef1f5;border:1px solid #0000;border-radius:999px;padding:.35rem .9rem;font-size:.9rem}.data-panel .subnav button.active{color:#fff;background:#1f3a8a}.data-section{background:#fff;border-radius:10px;padding:1rem;box-shadow:0 1px 2px #0000000d}.inline-form{flex-wrap:wrap;align-items:center;gap:.5rem;margin-bottom:.85rem;display:flex}.inline-form input,.inline-form select{border:1px solid #cfd4da;border-radius:6px;padding:.4rem .6rem;font-size:.92rem}.search-input{border:1px solid #cfd4da;border-radius:6px;width:100%;max-width:320px;margin-bottom:.5rem;padding:.4rem .65rem}.data-table-wrap{border:1px solid #e2e6ea;border-radius:8px;max-height:60vh;overflow-y:auto}.data-table{border-collapse:collapse;width:100%;font-size:.9rem}.data-table thead{z-index:1;background:#f4f6f8;position:sticky;top:0}.data-table th,.data-table td{text-align:left;border-bottom:1px solid #eef0f3;padding:.5rem .7rem}.data-table tbody tr:hover{background:#f9fafb}.empty-row{text-align:center;color:#888;padding:1rem}.link-button,.link-danger{color:#1f3a8a;cursor:pointer;background:0 0;border:none;padding:0;font-size:.88rem}.link-danger{color:#c0392b}.link-button:hover,.link-danger:hover{text-decoration:underline}.textarea-paste{resize:vertical;border:1px solid #cfd4da;border-radius:6px;width:100%;padding:.5rem;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.9rem}.periods-panel{padding:1rem 0}.period-layout{grid-template-columns:280px 1fr;gap:1rem;display:grid}.period-list{background:#fff;border-radius:10px;padding:.75rem;box-shadow:0 1px 2px #0000000d}.period-list h3{margin:0 0 .5rem;font-size:.95rem}.period-list ul{flex-direction:column;gap:.3rem;margin:0;padding:0;list-style:none;display:flex}.period-list li{background:#fafbfc;border:1px solid #e2e6ea;border-radius:8px;justify-content:space-between;align-items:center;gap:.5rem;padding:.4rem .55rem;display:flex}.period-list li.active{background:#eef2fc;border-color:#1f3a8a}.period-list li button:first-child{text-align:left;cursor:pointer;font:inherit;background:0 0;border:none;flex-direction:column;flex:1;padding:0;display:flex}.period-list li button strong{color:#1f2937;font-size:.95rem}.period-list li .period-meta{color:#6b7280;font-size:.8rem}.period-detail{flex-direction:column;gap:1rem;display:flex}.period-form-block{background:#fff;border-radius:10px;padding:.75rem 1rem;box-shadow:0 1px 2px #0000000d}.period-form-block summary{cursor:pointer;padding:.25rem 0;font-weight:600}.grid-form{grid-template-columns:1fr 1fr;gap:.6rem;margin-top:.6rem;display:grid}.grid-form label{color:#4b5563;flex-direction:column;font-size:.85rem;display:flex}.grid-form input,.grid-form select{border:1px solid #cfd4da;border-radius:6px;margin-top:.18rem;padding:.4rem .55rem;font-size:.92rem}.grid-form .span-2{grid-column:span 2}.grid-form .row-end{justify-content:flex-end;display:flex}@media (width<=900px){.period-layout,.grid-form{grid-template-columns:1fr}.grid-form .span-2{grid-column:span 1}}.rules-panel{padding:1rem 0}.rules-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:.85rem;display:grid}.rule-card{background:#fff;border-radius:10px;flex-direction:column;gap:.55rem;padding:.85rem 1rem;display:flex;box-shadow:0 1px 2px #0000000d}.rule-card header{justify-content:space-between;align-items:flex-start;gap:.5rem;display:flex}.rule-card header strong{font-size:.95rem;display:block}.rule-card header small{color:#6b7280;font-size:.78rem}.rule-card label{color:#4b5563;flex-direction:column;font-size:.83rem;display:flex}.rule-card input,.rule-card select{border:1px solid #cfd4da;border-radius:6px;margin-top:.18rem;padding:.36rem .55rem;font-size:.9rem}.rule-card .toggle{flex-direction:row;align-items:center;gap:.4rem;margin-top:.2rem}.rule-card .row-end{justify-content:flex-end;display:flex}.export-panel{padding:1rem 0}.export-card{background:#fff;border-radius:10px;max-width:540px;padding:1rem 1.25rem;box-shadow:0 1px 2px #0000000d}.export-card label{color:#4b5563;flex-direction:column;gap:.3rem;font-size:.9rem;display:flex}.export-card select{border:1px solid #cfd4da;border-radius:6px;padding:.5rem .6rem}.export-actions{flex-wrap:wrap;gap:.6rem;margin-top:.85rem;display:flex}.schedule-toolbar{justify-content:flex-end;gap:.5rem;margin:.5rem 0 .75rem;display:flex}.exam-chip .chip-rooms,.exam-chip .chip-invigilators,.exam-chip .chip-instructor{color:#4b5563;white-space:normal;margin-top:2px;font-size:.78rem;line-height:1.25;display:block}.exam-editor-create-type{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;flex-wrap:wrap;align-items:flex-end;gap:.75rem;margin:.75rem 0;padding:.75rem;display:flex}.exam-editor-create-type label{flex-direction:column;gap:.25rem;font-size:.85rem;display:flex}.exam-chip .chip-exam-type{color:#1e40af;background:#dbeafe;border-radius:4px;width:fit-content;margin-top:2px;padding:1px 6px;font-size:.72rem;font-weight:600;display:inline-block}.exam-chip .chip-instructor{color:#7c2d12}.exam-chip .chip-invigilators{color:#1f3a8a}.chip-reshuffle{z-index:2;pointer-events:auto;color:#1f3a8a;cursor:pointer;background:0 0;border:1px solid #1f3a8a;border-radius:999px;align-self:flex-start;margin-top:4px;padding:2px 6px;font-size:.72rem;position:relative}.chip-reshuffle:hover:not(:disabled){color:#fff;background:#1f3a8a}.chip-reshuffle:disabled{opacity:.65;cursor:wait}.export-header-preview{text-align:center;background:#f8fafd;border:1px solid #dbe3f0;border-radius:8px;margin:10px 0 4px;padding:10px 12px}.export-header-preview-line{color:#16325c;margin:4px 0 0;font-size:12px;font-weight:700;line-height:1.35}.export-header-preview-line:first-of-type{font-size:13px}.export-grid{grid-template-columns:1fr 1fr;gap:1rem;margin-top:.85rem;display:grid}.export-grid h4{color:#1f3a8a;margin:0 0 .4rem;font-size:.95rem}@media (width<=700px){.export-grid{grid-template-columns:1fr}}.modal-backdrop{z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0f172a8c;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.modal-card{background:#fff;border-radius:14px;flex-direction:column;width:min(960px,100%);max-height:calc(100vh - 2rem);display:flex;overflow:hidden;box-shadow:0 24px 60px #0f172a40}.modal-header{border-bottom:1px solid #e2e8f0;align-items:flex-start;gap:1rem;padding:1rem 1.25rem .5rem;display:flex}.modal-header h3{margin:0;font-size:1.15rem}.modal-eyebrow{color:#64748b;text-transform:uppercase;letter-spacing:.04em;font-size:.75rem;display:block}.modal-subtitle{color:#475569;margin:.15rem 0 0;font-size:.9rem}.modal-close{cursor:pointer;color:#475569;background:0 0;border:none;border-radius:6px;margin-left:auto;padding:.1rem .4rem;font-size:1.6rem}.modal-close:hover{background:#f1f5f9}.exam-editor-form{flex-direction:column;gap:.85rem;padding:1rem 1.25rem 1.1rem;display:flex;overflow:auto}.exam-editor-grid{grid-template-columns:1fr 1fr;gap:.85rem;display:grid}.exam-editor-grid label{flex-direction:column;gap:.25rem;display:flex}.exam-editor-grid input,.exam-editor-grid select{border:1px solid #cbd5e1;border-radius:8px;padding:.45rem .55rem}.exam-editor-columns{grid-template-columns:1fr 1fr;gap:.85rem;display:grid}.exam-editor-list{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;flex-direction:column;min-height:240px;max-height:320px;display:flex}.exam-editor-list header{background:#f1f5f9;border-bottom:1px solid #e2e8f0;border-radius:10px 10px 0 0;align-items:center;gap:.5rem;padding:.5rem .7rem;display:flex}.exam-editor-list header h4{flex:1;margin:0;font-size:.95rem}.exam-editor-list header input{border:1px solid #cbd5e1;border-radius:6px;width:50%;padding:.3rem .45rem;font-size:.85rem}.exam-editor-list ul{flex:1;margin:0;padding:.3rem .4rem;list-style:none;overflow-y:auto}.exam-editor-list li{border-radius:6px;padding:.18rem .2rem}.exam-editor-list li:hover{background:#e2e8f0}.exam-editor-list li label{cursor:pointer;align-items:center;gap:.45rem;display:flex}.exam-editor-list li label small{color:#64748b}.modal-footer{border-top:1px solid #e2e8f0;flex-wrap:wrap;justify-content:space-between;gap:.5rem;margin-top:.4rem;padding-top:.7rem;display:flex}.modal-footer-actions{flex-wrap:wrap;gap:.5rem;display:flex}.danger-button{color:#991b1b;cursor:pointer;background:#fee2e2;border:1px solid #fecaca;border-radius:8px;padding:.45rem .85rem}.danger-button:hover:not(:disabled){background:#fecaca}.danger-button:disabled{opacity:.55;cursor:not-allowed}.exam-chip-clickable{cursor:pointer}.exam-chip-clickable:hover{box-shadow:0 4px 14px #1e40af2e}.exam-chip-clickable:focus-visible{outline-offset:2px;outline:2px solid #2563eb}@media (width<=700px){.exam-editor-grid,.exam-editor-columns{grid-template-columns:1fr}}.error-dialog{max-width:560px}.error-dialog .modal-header h3{color:#b91c1c}.error-dialog-body{color:#1f2937;white-space:pre-wrap;padding:.85rem 1.25rem .4rem;font-size:.95rem;line-height:1.45}.modal-footer-end{justify-content:flex-end;padding:.6rem 1.25rem 1rem}.period-actions{flex-wrap:wrap;gap:.5rem;display:flex}.row-actions{flex-wrap:wrap;gap:.4rem;display:flex}.danger-link{color:#b91c1c!important}.danger-link:hover{text-decoration:underline;color:#7f1d1d!important}
