body{font-weight:300;font-family:Helvetica Neue!important}html,body{height:100%;margin:0;padding:0}#app{flex:1}#footer{margin-top:auto}#layout{flex-direction:column;min-height:100%;display:flex}.big-button{color:#fff;cursor:pointer;background:#e53935;border:none;border-radius:10px;width:100%;max-width:320px;margin:1.5rem auto;padding:1rem 1.2rem;font-size:1.1rem;transition:background .2s,transform .1s,box-shadow .2s;display:block;box-shadow:0 4px 12px #00000026}.big-button:hover{background:#ef5350;box-shadow:0 6px 16px #0000002e}.big-button:active{transform:scale(.97);box-shadow:0 2px 6px #0003}.big-button:disabled{cursor:not-allowed;box-shadow:none;background:#bdbdbd}.container.svelte-8wk3ol{text-align:center;max-width:650px;margin:0 auto;padding:2rem}.row.svelte-8wk3ol{margin:1.5rem 0}.box.svelte-8wk3ol{background:#fff;border-radius:12px;width:100%;margin-bottom:2rem;overflow:hidden;box-shadow:0 4px 12px #00000014}.box-title.svelte-8wk3ol{color:#fff;letter-spacing:.5px;padding:.9rem;font-size:1.4rem;font-weight:600}.present-title.svelte-8wk3ol{color:#2e7d32;background:linear-gradient(135deg,#e8f5e9,#c8e6c9)}.absent-title.svelte-8wk3ol{color:#c62828;background:linear-gradient(135deg,#ffebee,#ffcdd2)}.student-row.svelte-8wk3ol{border-bottom:1px solid #eee;justify-content:space-between;align-items:center;padding:.75rem 1rem;font-size:1.05rem;display:flex}.student-row.svelte-8wk3ol:last-child{border-bottom:none}.icon-button.svelte-8wk3ol{cursor:pointer;background:0 0;border:none;padding:0}.icon.svelte-8wk3ol{width:28px;height:28px}.empty.svelte-8wk3ol{color:#777;padding:1rem;font-style:italic}.date-row.svelte-8wk3ol{flex-direction:column;gap:.5rem;display:flex}.nav-buttons-row.svelte-8wk3ol{justify-content:center;gap:.5rem;width:100%;display:flex}.today-btn.svelte-8wk3ol,.date-nav-btn.svelte-8wk3ol{color:#fff;cursor:pointer;background:#ce0404;border:none;border-radius:4px;padding:.45rem .75rem;font-size:.95rem;font-weight:500}@media (width<=600px){.today-btn.svelte-8wk3ol,.date-nav-btn.svelte-8wk3ol{border-radius:6px;padding:.8rem 1.2rem;font-size:1.1rem}.nav-buttons-row.svelte-8wk3ol{gap:.75rem}}.today-btn.svelte-8wk3ol:hover,.date-nav-btn.svelte-8wk3ol:hover{background:#a90303}.date-input.svelte-8wk3ol{background:#fff;border:1px solid #ccc;border-radius:10px;width:240px;padding:.7rem 1rem;font-size:1.2rem;box-shadow:0 4px 12px #00000014}.today-btn.svelte-8wk3ol:active,.date-nav-btn.svelte-8wk3ol:active{background:#dcdcdc;transform:scale(.97)}.success-toast.svelte-8wk3ol{color:#fff;background:linear-gradient(135deg,#4caf50,#66bb6a);border-radius:12px;justify-content:center;align-items:center;gap:.8rem;padding:1rem 1.4rem;font-size:1.05rem;animation:.35s ease-out svelte-8wk3ol-fadeInUp;display:flex;box-shadow:0 4px 14px #00000040}@keyframes svelte-8wk3ol-fadeInUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.checkmark.svelte-8wk3ol{background:#fff;border-radius:50%;width:22px;height:22px;animation:.3s ease-out svelte-8wk3ol-pop;position:relative}.checkmark.svelte-8wk3ol:after{content:"";border:3px solid #4caf50;border-width:0 3px 3px 0;width:8px;height:14px;position:absolute;top:2px;left:6px;transform:rotate(45deg)}@keyframes svelte-8wk3ol-pop{0%{transform:scale(.4)}80%{transform:scale(1.15)}to{transform:scale(1)}}.success-toast.svelte-8wk3ol span:where(.svelte-8wk3ol){align-items:center;gap:.2rem;transition:opacity .2s;display:flex}.error-toast.svelte-8wk3ol{color:#c62828;background:#ffebee;border:1px solid #ef9a9a;border-radius:8px;align-items:center;gap:.6rem;padding:.8rem 1.2rem;font-weight:600;animation:.35s ease-out svelte-8wk3ol-fadeInUp;display:flex}.error-cross.svelte-8wk3ol{color:#fff;background:#c62828;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;font-size:16px;font-weight:700;line-height:1;display:flex}.loading-msg.svelte-8wk3ol{color:#444;text-align:center;margin-top:2rem;font-size:1.1rem}.modal-backdrop.svelte-8wk3ol{z-index:999;background:#00000073;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal.svelte-8wk3ol{text-align:center;background:#fff;border-radius:8px;width:90%;max-width:380px;padding:1.5rem;box-shadow:0 4px 20px #00000040}.modal-buttons.svelte-8wk3ol{justify-content:space-between;gap:1rem;margin-top:1rem;display:flex}.modal-buttons.svelte-8wk3ol .yes:where(.svelte-8wk3ol){color:#fff;cursor:pointer;background:#ce0404;border:none;border-radius:6px;flex:1;padding:.6rem}.modal-buttons.svelte-8wk3ol .no:where(.svelte-8wk3ol){cursor:pointer;background:#ccc;border:none;border-radius:6px;flex:1;padding:.6rem}.container.svelte-1i2edv7{text-align:center;max-width:650px;margin:0 auto;padding:2rem}.row.svelte-1i2edv7{margin:1.5rem 0}.box.svelte-1i2edv7{background:#fff;border-radius:12px;width:100%;margin-bottom:2rem;overflow:hidden;box-shadow:0 4px 12px #00000014}.box-title.svelte-1i2edv7{color:#fff;letter-spacing:.5px;padding:.9rem;font-size:1.4rem;font-weight:600}.present-title.svelte-1i2edv7{color:#2e7d32;background:linear-gradient(135deg,#e8f5e9,#c8e6c9)}.absent-title.svelte-1i2edv7{color:#c62828;background:linear-gradient(135deg,#ffebee,#ffcdd2)}.teacher-row.svelte-1i2edv7{border-bottom:1px solid #eee;justify-content:space-between;align-items:center;padding:.75rem 1rem;font-size:1.05rem;display:flex}.teacher-row.svelte-1i2edv7:last-child{border-bottom:none}.icon-button.svelte-1i2edv7{cursor:pointer;background:0 0;border:none;padding:0}.icon.svelte-1i2edv7{width:28px;height:28px}.empty.svelte-1i2edv7{color:#777;padding:1rem;font-style:italic}.date-row.svelte-1i2edv7{flex-direction:column;gap:.5rem;display:flex}.nav-buttons-row.svelte-1i2edv7{justify-content:center;gap:.5rem;width:100%;display:flex}.today-btn.svelte-1i2edv7,.date-nav-btn.svelte-1i2edv7{color:#fff;cursor:pointer;background:#ce0404;border:none;border-radius:4px;padding:.45rem .75rem;font-size:.95rem;font-weight:500}@media (width<=600px){.today-btn.svelte-1i2edv7,.date-nav-btn.svelte-1i2edv7{border-radius:6px;padding:.8rem 1.2rem;font-size:1.1rem}.nav-buttons-row.svelte-1i2edv7{gap:.75rem}}.today-btn.svelte-1i2edv7:hover,.date-nav-btn.svelte-1i2edv7:hover{background:#a90303}.date-input.svelte-1i2edv7{background:#fff;border:1px solid #ccc;border-radius:10px;width:240px;padding:.7rem 1rem;font-size:1.2rem;box-shadow:0 4px 12px #00000014}.today-btn.svelte-1i2edv7:active,.date-nav-btn.svelte-1i2edv7:active{background:#dcdcdc;transform:scale(.97)}.success-toast.svelte-1i2edv7{color:#fff;background:linear-gradient(135deg,#4caf50,#66bb6a);border-radius:12px;justify-content:center;align-items:center;gap:.8rem;padding:1rem 1.4rem;font-size:1.05rem;animation:.35s ease-out svelte-1i2edv7-fadeInUp;display:flex;box-shadow:0 4px 14px #00000040}@keyframes svelte-1i2edv7-fadeInUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.checkmark.svelte-1i2edv7{background:#fff;border-radius:50%;width:22px;height:22px;animation:.3s ease-out svelte-1i2edv7-pop;position:relative}.checkmark.svelte-1i2edv7:after{content:"";border:3px solid #4caf50;border-width:0 3px 3px 0;width:8px;height:14px;position:absolute;top:2px;left:6px;transform:rotate(45deg)}@keyframes svelte-1i2edv7-pop{0%{transform:scale(.4)}80%{transform:scale(1.15)}to{transform:scale(1)}}.success-toast.svelte-1i2edv7 span:where(.svelte-1i2edv7){align-items:center;gap:.2rem;transition:opacity .2s;display:flex}.error-toast.svelte-1i2edv7{color:#c62828;background:#ffebee;border:1px solid #ef9a9a;border-radius:8px;align-items:center;gap:.6rem;padding:.8rem 1.2rem;font-weight:600;animation:.35s ease-out svelte-1i2edv7-fadeInUp;display:flex}.error-cross.svelte-1i2edv7{color:#fff;background:#c62828;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;font-size:16px;font-weight:700;line-height:1;display:flex}.loading-msg.svelte-1i2edv7{color:#444;text-align:center;margin-top:2rem;font-size:1.1rem}.modal-backdrop.svelte-1i2edv7{z-index:999;background:#00000073;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal.svelte-1i2edv7{text-align:center;background:#fff;border-radius:8px;width:90%;max-width:380px;padding:1.5rem;box-shadow:0 4px 20px #00000040}.modal-buttons.svelte-1i2edv7{justify-content:space-between;gap:1rem;margin-top:1rem;display:flex}.modal-buttons.svelte-1i2edv7 .yes:where(.svelte-1i2edv7){color:#fff;cursor:pointer;background:#ce0404;border:none;border-radius:6px;flex:1;padding:.6rem}.modal-buttons.svelte-1i2edv7 .no:where(.svelte-1i2edv7){cursor:pointer;background:#ccc;border:none;border-radius:6px;flex:1;padding:.6rem}.container.svelte-1a65okt{text-align:center;max-width:650px;margin:0 auto;padding:2rem}.row.svelte-1a65okt{margin:1.5rem 0}label.svelte-1a65okt{flex-direction:column;align-items:center;gap:.5rem;display:flex}select.svelte-1a65okt{border:1px solid #ccc;border-radius:10px;width:240px;padding:.7rem 1rem;font-size:1.2rem;box-shadow:0 4px 12px #00000014}.date-row.svelte-1a65okt{flex-direction:column;gap:.5rem;display:flex}.nav-buttons-row.svelte-1a65okt{justify-content:center;gap:.5rem;width:100%;display:flex}.today-btn.svelte-1a65okt,.date-nav-btn.svelte-1a65okt{color:#fff;cursor:pointer;background:#ce0404;border:none;border-radius:4px;padding:.45rem .75rem;font-size:.95rem;font-weight:500}@media (width<=600px){.today-btn.svelte-1a65okt,.date-nav-btn.svelte-1a65okt{border-radius:6px;padding:.8rem 1.2rem;font-size:1.1rem}.nav-buttons-row.svelte-1a65okt{gap:.75rem}}.today-btn.svelte-1a65okt:hover,.date-nav-btn.svelte-1a65okt:hover{background:#a90303}.date-input.svelte-1a65okt{background:#fff;border:1px solid #ccc;border-radius:10px;width:240px;padding:.7rem 1rem;font-size:1.2rem;box-shadow:0 4px 12px #00000014}.today-btn.svelte-1a65okt:active,.date-nav-btn.svelte-1a65okt:active{background:#dcdcdc;transform:scale(.97)}.warning.svelte-1a65okt{color:#d32f2f;margin-bottom:1rem;font-weight:700}.lists.svelte-1a65okt{flex-wrap:wrap;justify-content:center;gap:1rem;display:flex}.box.svelte-1a65okt{box-shadow:none;text-align:left;background:0 0;border-radius:0;width:auto;padding:0}.box-title.svelte-1a65okt{color:#333;background:0 0;border-bottom:2px solid #ddd;padding:.3rem 0;font-size:1.1rem;font-weight:700}.student.svelte-1a65okt{border-bottom:1px solid #eee;padding:.4rem 0;font-size:1rem}.student.svelte-1a65okt:last-child{border-bottom:none}.lists.svelte-1a65okt{display:block}.present-title.svelte-1a65okt{color:#2e7d32;background:linear-gradient(135deg,#e8f5e9,#c8e6c9)}.absent-title.svelte-1a65okt{color:#c62828;background:linear-gradient(135deg,#ffebee,#ffcdd2)}.empty.svelte-1a65okt{color:#777;padding:1rem;font-style:italic}.attendance-summary.svelte-1a65okt p:where(.svelte-1a65okt){margin:.2rem 0}.container.svelte-111ygyj{text-align:center;max-width:650px;margin:0 auto;padding:2rem}label.svelte-111ygyj{flex-direction:column;align-items:center;gap:.5rem;display:flex}.date-row.svelte-111ygyj{flex-direction:column;gap:.5rem;display:flex}.nav-buttons-row.svelte-111ygyj{justify-content:center;gap:.5rem;width:100%;display:flex}.today-btn.svelte-111ygyj,.date-nav-btn.svelte-111ygyj{color:#fff;cursor:pointer;background:#ce0404;border:none;border-radius:4px;padding:.45rem .75rem;font-size:.95rem;font-weight:500}@media (width<=600px){.today-btn.svelte-111ygyj,.date-nav-btn.svelte-111ygyj{border-radius:6px;padding:.8rem 1.2rem;font-size:1.1rem}.nav-buttons-row.svelte-111ygyj{gap:.75rem}}.today-btn.svelte-111ygyj:hover,.date-nav-btn.svelte-111ygyj:hover{background:#a90303}.date-input.svelte-111ygyj{background:#fff;border:1px solid #ccc;border-radius:10px;width:240px;padding:.7rem 1rem;font-size:1.2rem;box-shadow:0 4px 12px #00000014}.today-btn.svelte-111ygyj:active,.date-nav-btn.svelte-111ygyj:active{background:#dcdcdc;transform:scale(.97)}.warning.svelte-111ygyj{color:#d32f2f;margin-bottom:1rem;font-weight:700}.lists.svelte-111ygyj{flex-wrap:wrap;justify-content:center;gap:1rem;display:flex}.box.svelte-111ygyj{box-shadow:none;text-align:left;background:0 0;border-radius:0;width:auto;padding:0}.box-title.svelte-111ygyj{color:#333;background:0 0;border-bottom:2px solid #ddd;padding:.3rem 0;font-size:1.1rem;font-weight:700}.teacher.svelte-111ygyj{border-bottom:1px solid #eee;padding:.4rem 0;font-size:1rem}.teacher.svelte-111ygyj:last-child{border-bottom:none}.lists.svelte-111ygyj{display:block}.present-title.svelte-111ygyj{color:#2e7d32;background:linear-gradient(135deg,#e8f5e9,#c8e6c9)}.absent-title.svelte-111ygyj{color:#c62828;background:linear-gradient(135deg,#ffebee,#ffcdd2)}.empty.svelte-111ygyj{color:#777;padding:1rem;font-style:italic}.attendance-summary.svelte-111ygyj p:where(.svelte-111ygyj){margin:.2rem 0}.container.svelte-o2dhro{justify-content:center;align-items:flex-start;height:100vh;padding-top:4rem;display:flex}form.svelte-o2dhro{background:#fff;border-radius:10px;flex-direction:column;gap:1rem;width:300px;padding:2rem;display:flex;box-shadow:0 4px 16px #0000001f}.form-title.svelte-o2dhro{text-align:center;color:#333;margin:0;font-size:1.4rem;font-weight:600}.helper-text.svelte-o2dhro{text-align:center;color:#666;margin-top:-.5rem;margin-bottom:.5rem;font-size:.95rem}input.svelte-o2dhro{border:1px solid #d0d0d0;border-radius:6px;padding:.75rem;font-size:1rem}button.svelte-o2dhro{color:#fff;cursor:pointer;background:#4a6cf7;border:none;border-radius:6px;padding:.8rem;font-size:1rem}.error.svelte-o2dhro{color:#c00;text-align:center;background:#ffe6e6;border:1px solid #ffb3b3;border-radius:6px;margin-top:-.5rem;padding:.6rem;font-size:.9rem}@keyframes svelte-o2dhro-fadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.form-box.svelte-kd25dq{flex-direction:column;gap:10px;max-width:350px;margin:40px auto;display:flex}.welcome.svelte-1q5o2lv{text-align:center;margin-top:2rem;font-family:Inter,Segoe UI,sans-serif}.welcome.svelte-1q5o2lv h1:where(.svelte-1q5o2lv){margin-bottom:.5rem;font-size:2rem;font-weight:600}.welcome.svelte-1q5o2lv p:where(.svelte-1q5o2lv){color:#555;font-size:1.2rem}header.svelte-13t3afu{color:#fff;background:#ce0404;justify-content:space-between;align-items:center;padding:1rem;display:flex;box-shadow:0 2px 6px #00000080}.title.svelte-13t3afu{color:#fff;cursor:pointer;background:0 0;border:none;padding:0;font-size:1.25rem;font-weight:700}.subheader.svelte-13t3afu{color:#fff;text-align:center;white-space:nowrap;text-overflow:ellipsis;opacity:.95;background:#b10303;width:100%;padding:.4rem .5rem;font-size:clamp(.75rem,2vw,1rem);font-style:italic;font-weight:500;overflow:hidden}.menu-btn.svelte-13t3afu{color:#fff;cursor:pointer;background:0 0;border:none;align-items:center;gap:.4rem;font-size:1.2rem;display:flex}nav.svelte-13t3afu{gap:1rem;display:none}nav.svelte-13t3afu button:where(.svelte-13t3afu){color:#fff;cursor:pointer;background:0 0;border:none;font-size:1rem}.dropdown.svelte-13t3afu{background:#ce0404;flex-direction:column;padding:.5rem 1rem;display:flex}.dropdown.svelte-13t3afu button:where(.svelte-13t3afu){color:#fff;text-align:left;cursor:pointer;background:0 0;border:none;padding:.5rem 0;font-size:1rem}@media (width>=700px){.menu-btn.svelte-13t3afu{display:none}nav.svelte-13t3afu{display:flex}.dropdown.svelte-13t3afu{display:none}}
