*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{overflow-x:hidden}:root{--navy:#0a3d36;--navy-light:#0d4d44;--teal:#0d9488;--teal-dark:#0f766e;--teal-light:#ccfbf1;--gray-50:#f8fafc;--gray-100:#f3f4f6;--gray-200:#e5e7eb;--gray-400:#9ca3af;--gray-500:#6b7280;--gray-600:#4b5563;--gray-700:#374151;--gray-800:#1f2937;--white:#fff;--red:#dc2626;--font:"Inter", "Segoe UI", system-ui, sans-serif;--radius:10px;--shadow:0 1px 4px #00000014, 0 2px 12px #0000000f}body{font-family:var(--font);background:var(--gray-50);color:var(--gray-800);min-height:100vh;overflow-x:hidden}.navbar{background:var(--navy);color:var(--white);z-index:50;align-items:center;gap:1.75rem;height:64px;padding:0 2rem;display:flex;position:sticky;top:0;box-shadow:0 2px 10px #00000040}.navbar-brand{flex-direction:column;flex-shrink:0;line-height:1.15;display:flex}.brand-name{letter-spacing:.2px;color:var(--white);font-size:1rem;font-weight:700}.brand-sub{opacity:.55;letter-spacing:.5px;text-transform:uppercase;font-size:.67rem}.navbar-links{flex:1;gap:.15rem;display:flex}.nav-link{color:#ffffffb3;white-space:nowrap;border-radius:6px;padding:.4rem .9rem;font-size:.875rem;font-weight:500;text-decoration:none;transition:background .15s,color .15s}.nav-link:hover{color:var(--white);background:#ffffff1f}.nav-link.active{color:var(--white);background:#ffffff2e;font-weight:600}.navbar-right{flex-shrink:0;align-items:center;gap:0;margin-left:auto;display:flex}.navbar-user{flex-shrink:0;align-items:center;gap:.75rem;display:flex}.user-avatar{border:2px solid #fff6;border-radius:50%;width:32px;height:32px}.user-info{flex-direction:column;line-height:1.2;display:flex}.user-name{font-size:.84rem;font-weight:600}.user-last-login{opacity:.6;text-transform:capitalize;font-size:.68rem}.btn-logout{color:#ffffffd9;cursor:pointer;white-space:nowrap;background:#ffffff1a;border:1px solid #fff3;border-radius:6px;padding:.3rem .8rem;font-size:.8rem;font-weight:500;transition:background .15s,color .15s}.btn-logout:hover{color:var(--white);background:#fff3}.page-breadcrumb{color:var(--gray-400);flex-wrap:wrap;align-items:center;gap:.35rem;margin-bottom:1.25rem;font-size:.8rem;display:flex}.page-breadcrumb a{color:var(--gray-500);text-decoration:none}.page-breadcrumb a:hover{color:var(--teal-dark);text-decoration:underline}.page-breadcrumb .bc-sep{color:var(--gray-300);font-size:.75rem}.page-breadcrumb .bc-current{color:var(--gray-700);font-weight:600}.student-name-link{color:var(--teal-dark);align-items:center;gap:.25rem;font-weight:600;text-decoration:none;display:inline-flex}.student-name-link:hover{text-decoration:underline}.student-name-link .snl-arrow{color:var(--gray-400);font-size:.7rem;transition:color .12s,transform .12s}tr:hover .student-name-link .snl-arrow{color:var(--teal);transform:translate(2px)}.nav-menu-logout{display:none}.hamburger{cursor:pointer;color:#fffc;background:0 0;border:none;border-left:1px solid #ffffff26;border-radius:6px;flex-shrink:0;margin-left:.75rem;padding:.4rem .5rem .4rem .85rem;line-height:1;transition:background .15s,color .15s;display:none}.hamburger:hover{color:var(--white);background:#ffffff1a}.main-content{max-width:1200px;margin:0 auto;padding:2rem}.page-header{margin-bottom:1.75rem}.page-header h2{color:var(--gray-800);font-size:1.5rem;font-weight:700}.page-subtitle{color:var(--gray-600);margin-top:.25rem;font-size:.9rem}.dashboard-date{color:var(--gray-800);margin-top:.75rem;font-size:1.25rem;font-weight:700}.stats-row{grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1.75rem;display:grid}.stats-row-two{grid-template-columns:repeat(2,1fr)}.stat-card{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);align-items:center;gap:1rem;padding:1.25rem 1.5rem;display:flex}.stat-icon{font-size:2rem}.stat-value{color:var(--teal-dark);font-size:1.5rem;font-weight:700}.stat-label{color:var(--gray-600);margin-top:.1rem;font-size:.8rem}.dashboard-panels{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.panel{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.panel-header{border-bottom:1px solid var(--gray-200);padding:1rem 1.5rem}.panel-header h3{font-size:1rem;font-weight:600}.panel-body{padding:1.25rem 1.5rem}.dashboard-actions{flex-wrap:wrap;align-items:center;gap:1rem;padding-top:.5rem;display:flex}.btn-primary,.btn-secondary{cursor:pointer;border:none;border-radius:10px;justify-content:center;align-items:center;min-width:180px;padding:.85rem 1.15rem;font-weight:600;transition:background .15s,transform .15s;display:inline-flex}.btn-primary:hover,.btn-secondary:hover{transform:translateY(-1px)}.btn-secondary{color:var(--gray-800);background:#f3f4f6}.coming-soon{color:var(--gray-400);font-size:.875rem;font-style:italic}.login-page{background:linear-gradient(135deg, #062a24 0%, var(--navy) 50%, var(--teal-dark) 100%);justify-content:center;align-items:center;min-height:100vh;display:flex}.login-card{background:var(--white);text-align:center;border-radius:16px;width:360px;padding:2.5rem 2rem;box-shadow:0 20px 60px #0003}.login-logo-circle{background:var(--teal);width:64px;height:64px;color:var(--white);border-radius:50%;justify-content:center;align-items:center;margin:0 auto 1rem;font-size:1.4rem;font-weight:700;display:flex}.login-title{margin-bottom:.25rem;font-size:1.4rem;font-weight:700}.login-subtitle{color:var(--gray-600);margin-bottom:.1rem;font-size:.875rem}.login-org{color:var(--gray-400);margin-bottom:1rem;font-size:.75rem}.login-intro{color:var(--gray-500);text-align:left;margin-bottom:1.5rem;font-size:.8rem;line-height:1.55}.login-form{flex-direction:column;gap:.9rem;margin-bottom:1.25rem;display:flex}.login-field{text-align:left;flex-direction:column;gap:.35rem;display:flex}.login-field label{color:var(--gray-700);font-size:.8rem;font-weight:600}.login-field input{border:1px solid var(--gray-200);border-radius:8px;outline:none;padding:.6rem .75rem;font-size:.9rem;transition:border-color .15s,box-shadow .15s}.login-field input:focus{border-color:var(--teal);box-shadow:0 0 0 3px #0d948826}.btn-login{background:var(--teal);width:100%;color:var(--white);cursor:pointer;border:none;border-radius:8px;margin-top:.25rem;padding:.7rem 1rem;font-size:.95rem;font-weight:600;transition:background .15s}.btn-login:hover:not(:disabled){background:var(--teal-dark)}.btn-login:disabled{opacity:.6;cursor:not-allowed}.login-note{color:var(--gray-400);font-size:.75rem}.student-form{gap:1rem;display:grid}.form-row{gap:.5rem;margin-bottom:.75rem;display:grid}.form-row label{color:var(--gray-600);font-size:.85rem}.form-row input,.form-row textarea{border:1px solid var(--gray-200);background:var(--white);width:100%;color:var(--gray-800);border-radius:10px;padding:.85rem 1rem;font-size:.95rem}.btn-primary,.btn-secondary{cursor:pointer;border:none;border-radius:10px;justify-content:center;align-items:center;font-weight:600;transition:background .15s;display:inline-flex}.btn-primary{background:var(--teal);color:var(--white);padding:.85rem 1.25rem}.btn-primary:hover{background:var(--teal-dark)}.btn-secondary{background:var(--gray-100);color:var(--gray-800);padding:.6rem .9rem}.btn-secondary:hover{background:var(--gray-200)}.student-list{gap:1rem;display:grid}.student-card{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);justify-content:space-between;align-items:flex-start;gap:1rem;padding:1rem 1.25rem;display:flex}.student-card h4{margin-bottom:.25rem}.student-meta{color:var(--gray-600);margin-bottom:.35rem;font-size:.9rem}.student-notes{color:var(--gray-700);font-size:.95rem}.info-block{color:var(--gray-600);background:#f8fafc;border-radius:10px;padding:1rem;font-size:.94rem}.invoice-form{gap:1rem;display:grid}.invoice-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem;display:grid}.invoice-row{gap:.5rem;display:grid}.invoice-row label{color:var(--gray-600);font-size:.85rem}.invoice-summary{background:var(--gray-50);border:1px solid var(--gray-200);border-radius:12px;justify-content:space-between;align-items:center;margin-top:.5rem;padding:1rem 1.25rem;font-weight:600;display:flex}.invoice-list{gap:1rem;display:grid}.invoice-card{border-radius:var(--radius);background:var(--white);box-shadow:var(--shadow);justify-content:space-between;gap:1rem;padding:1rem 1.25rem;display:flex}.invoice-card h4{margin-bottom:.35rem}.invoice-meta{color:var(--gray-600);margin-bottom:.25rem;font-size:.9rem}.invoice-right{text-align:right;flex-direction:column;justify-content:center;align-items:flex-end;gap:.35rem;display:flex}.invoice-amount{color:var(--teal-dark);font-weight:700}.alert{border-radius:8px;margin-bottom:1rem;padding:.75rem 1rem;font-size:.85rem}.alert-success{color:#15803d;cursor:default;background:#f0fdf4;border:1px solid #bbf7d0}.alert-error{color:var(--red);background:#fef2f2;border:1px solid #fecaca}.loading-screen{justify-content:center;align-items:center;min-height:160px;display:flex}.spinner{border:3px solid var(--gray-200);border-top-color:var(--teal);border-radius:50%;width:36px;height:36px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}@media (width<=768px){.navbar{gap:0;padding:0 1rem}.navbar-brand{flex:1}.hamburger{justify-content:center;align-items:center;display:flex}.navbar-right{margin-left:0}.navbar-links{background:var(--navy);z-index:49;border-top:1px solid #ffffff14;flex-direction:column;gap:.15rem;padding:.6rem 1rem .85rem;display:none;position:absolute;top:64px;left:0;right:0;box-shadow:0 6px 18px #00000047}.navbar-links.open{display:flex}.nav-link{padding:.6rem .85rem;font-size:.9rem}.navbar-user{display:none}.hamburger{border-left:none;margin-left:0;padding-left:.5rem}.nav-menu-logout{border-top:1px solid #ffffff1f;justify-content:space-between;align-items:center;gap:.75rem;margin-top:.5rem;padding:.75rem .85rem .5rem;display:flex}.nav-menu-user{flex-direction:column;gap:.1rem;display:flex}.nav-menu-user-name{color:#ffffffe6;font-size:.88rem;font-weight:600}.nav-menu-user-role{color:#ffffff73;text-transform:capitalize;font-size:.72rem}.nav-menu-logout-btn{color:#fca5a5;cursor:pointer;white-space:nowrap;background:#dc26262e;border:1px solid #dc262666;border-radius:7px;flex-shrink:0;align-items:center;gap:.4rem;padding:.45rem 1rem;font-size:.82rem;font-weight:600;transition:background .15s;display:inline-flex}.nav-menu-logout-btn:hover{background:#dc26264d}.main-content{padding:1.25rem 1rem}.stats-row,.stats-row-two{grid-template-columns:1fr 1fr}.dashboard-panels{grid-template-columns:1fr}.invoice-grid,.action-cards{grid-template-columns:1fr 1fr}.panel-header{padding:.75rem 1rem}.panel-body{padding:1rem}.login-card{width:min(360px,100% - 2rem)}}@media (width<=480px){.user-last-login{display:none}.stats-row,.stats-row-two,.invoice-grid,.dashboard-panels,.action-cards{grid-template-columns:1fr}.invoice-card{flex-direction:column}.invoice-right{text-align:left;flex-flow:wrap;align-items:flex-start;gap:.5rem}.student-card{flex-direction:column}.btn-primary,.btn-secondary{width:100%;min-width:0}.login-card{width:calc(100% - 2rem);padding:2rem 1.25rem}.page-header h2{font-size:1.25rem}.dashboard-date{font-size:1rem}}@media (width<=360px){.main-content{padding:1rem .75rem}}.action-cards{grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1.75rem;display:grid}@media (width<=768px){.action-cards{grid-template-columns:1fr 1fr}}@media (width<=480px){.action-cards{grid-template-columns:1fr}}.action-card{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);flex-direction:column;gap:.6rem;padding:1.5rem;display:flex}.action-card-icon{font-size:1.5rem}.action-card-title{color:var(--gray-800);font-size:.95rem;font-weight:700}.action-card-desc{color:var(--gray-600);flex:1;font-size:.82rem;line-height:1.55}.overlay-card-wide{max-width:560px}.overlay-context{color:var(--gray-600);margin-bottom:.25rem;font-size:.85rem;line-height:1.55}.students-page-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:1rem;display:flex}.btn-auto{min-width:0;width:auto!important}.overlay-backdrop{z-index:100;background:#00000073;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.overlay-card{background:var(--white);border-radius:var(--radius);flex-direction:column;width:100%;max-width:460px;max-height:90vh;display:flex;box-shadow:0 8px 40px #0003}.overlay-header{border-bottom:1px solid var(--gray-200);flex-shrink:0;justify-content:space-between;align-items:center;padding:1.1rem 1.5rem;display:flex}.overlay-header h3{font-size:1rem;font-weight:600}.overlay-close{cursor:pointer;color:var(--gray-400);background:0 0;border:none;padding:0 .2rem;font-size:1.5rem;line-height:1}.overlay-close:hover{color:var(--gray-800)}.overlay-body{flex:1;padding:1.25rem 1.5rem;overflow-y:auto}.overlay-footer{border-top:1px solid var(--gray-200);flex-shrink:0;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;display:flex}.overlay-footer .btn-primary,.overlay-footer .btn-secondary,.overlay-footer .btn-danger{width:auto;min-width:0}.student-table{border-collapse:collapse;width:100%}.student-table th{text-align:left;color:var(--gray-600);text-transform:uppercase;letter-spacing:.04em;border-bottom:2px solid var(--gray-200);background:var(--gray-50);padding:.6rem 1.25rem;font-size:.78rem;font-weight:600}.student-table td{border-bottom:1px solid var(--gray-100);color:var(--gray-800);padding:.85rem 1.25rem;font-size:.9rem}.student-table tbody tr:last-child td{border-bottom:none}.student-table tbody tr:hover td{background:var(--gray-50)}.student-group-header td{text-transform:uppercase;letter-spacing:.06em;color:var(--gray-500);background:var(--gray-50);border-bottom:1px solid var(--gray-200);pointer-events:none;padding:.45rem 1.25rem;font-size:.72rem;font-weight:700}.student-group-header:hover td{background:var(--gray-50)!important}.student-group-border td{border-top:2px solid var(--gray-200)}.student-group-count{background:var(--gray-200);min-width:18px;height:16px;color:var(--gray-600);vertical-align:middle;border-radius:8px;justify-content:center;align-items:center;margin-left:6px;padding:0 5px;font-size:.68rem;font-weight:600;display:inline-flex}.td-action{text-align:right;width:120px}.student-gender-inline{display:none}@media (width<=640px){.student-gender-col,.student-table th:nth-child(3),.student-joined-col,.student-table th:nth-child(4){display:none}.student-gender-inline{display:inline}}.btn-view-details{border:1px solid var(--teal);color:var(--teal);cursor:pointer;white-space:nowrap;background:0 0;border-radius:6px;padding:.3rem .75rem;font-size:.8rem;font-weight:500;transition:background .15s,color .15s}.btn-view-details:hover{background:var(--teal);color:var(--white)}.btn-danger{color:var(--red);cursor:pointer;background:#fef2f2;border:1px solid #fecaca;border-radius:10px;padding:.6rem 1rem;font-size:.875rem;font-weight:600;transition:background .15s}.btn-danger:hover{background:#fee2e2}.detail-list{margin:0}.detail-row{border-bottom:1px solid var(--gray-100);grid-template-columns:90px 1fr;align-items:baseline;gap:.75rem;padding:.65rem 0;display:grid}.detail-row:last-child{border-bottom:none}.detail-list-wide .detail-row{grid-template-columns:140px 1fr}.detail-row dt{color:var(--gray-600);text-transform:uppercase;letter-spacing:.04em;font-size:.78rem;font-weight:600}.detail-row dd{color:var(--gray-800);word-break:break-word;font-size:.9rem}.btn-email{border:1px solid var(--teal);color:var(--teal);cursor:pointer;white-space:nowrap;background:0 0;border-radius:6px;padding:.3rem .75rem;font-size:.8rem;font-weight:500;transition:background .15s,color .15s}.btn-email:hover:not(:disabled){background:var(--teal);color:var(--white)}.btn-email:disabled{opacity:.55;cursor:default}.invoice-card-actions{flex-direction:column;align-items:flex-end;gap:.4rem;display:flex}.history-actions{flex-wrap:wrap;gap:.75rem;margin-top:1rem;display:flex}.checkbox-label{color:var(--gray-800);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:.5rem;font-size:.875rem;display:flex}.checkbox-label input[type=checkbox]{cursor:pointer;width:16px;height:16px}.checkbox-disabled{opacity:.55;cursor:default}.email-unavailable{color:var(--gray-400);font-size:.8rem}.settings-grid{grid-template-columns:1fr 1fr;align-items:start;gap:1.25rem;display:grid}.settings-form{gap:.25rem;display:grid}.settings-form-row-2{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.sig-preview-block{background:var(--gray-50);border:1px solid var(--gray-200);border-radius:var(--radius);flex-direction:column;gap:.5rem;padding:1rem;display:inline-flex}.sig-label{color:var(--gray-600);text-transform:uppercase;letter-spacing:.04em;font-size:.78rem;font-weight:600}.sig-preview-img{object-fit:contain;max-width:240px;max-height:80px}.help-sections{gap:1.25rem;display:grid}.faq-list{padding:0!important}.faq-item{border-bottom:1px solid var(--gray-100)}.faq-item:last-child{border-bottom:none}.faq-question{cursor:pointer;text-align:left;width:100%;color:var(--gray-800);background:0 0;border:none;justify-content:space-between;align-items:center;gap:1rem;padding:1rem 1.5rem;font-size:.9rem;font-weight:600;transition:background .15s;display:flex}.faq-question:hover{background:var(--gray-50)}.faq-item-open .faq-question{color:var(--teal-dark);background:var(--gray-50)}.faq-chevron{color:var(--gray-400);flex-shrink:0;font-size:.65rem}.faq-item-open .faq-chevron{color:var(--teal)}.faq-answer{color:var(--gray-600);padding:0 1.5rem 1rem;font-size:.875rem;line-height:1.7}@media (width<=768px){.settings-grid,.settings-form-row-2{grid-template-columns:1fr}.invoice-card-actions{flex-direction:row;align-items:center}}@media (width<=480px){.invoice-card-actions{flex-wrap:wrap}}.gender-badge{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;display:inline-flex}.gender-badge-male{color:#1d4ed8;background:#dbeafe}.gender-badge-female{color:#be185d;background:#fce7f3}.student-mobile-actions{display:none}@media (width<=640px){.student-mobile-actions{flex-wrap:nowrap;gap:.3rem;margin-top:.5rem;display:flex}.student-mobile-actions .btn-view-details{padding:.25rem .45rem;font-size:.72rem}.student-desktop-actions,.student-desktop-actions-th{display:none!important}}.gender-radio-group{flex-wrap:wrap;align-items:center;gap:.5rem;margin-top:.15rem;display:flex}.gender-radio-label{border:1.5px solid var(--gray-200);cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:8px;align-items:center;gap:.35rem;padding:.45rem .9rem;font-size:.875rem;transition:border-color .15s,background .15s;display:flex}.gender-radio-label input{display:none}.gender-radio-label.selected{border-color:var(--teal);background:var(--teal-light);color:var(--teal-dark);font-weight:600}.gender-radio-label:hover:not(.selected){border-color:var(--gray-400)}.gender-radio-clear{color:var(--gray-400);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:.2rem .4rem;font-size:.78rem}.gender-radio-clear:hover{color:var(--red)}.att-controls{flex-wrap:wrap;align-items:center;gap:1rem;margin-bottom:1rem;display:flex}.att-month-select{border:1.5px solid var(--gray-200);color:var(--gray-800);background:var(--white);cursor:pointer;border-radius:8px;outline:none;padding:.5rem .85rem;font-size:.9rem;font-weight:600;transition:border-color .15s}.att-month-select:focus{border-color:var(--teal)}.att-gender-tabs{background:var(--gray-100);border-radius:9px;gap:.25rem;padding:3px;display:flex}.att-gender-tab{cursor:pointer;color:var(--gray-600);white-space:nowrap;background:0 0;border:none;border-radius:7px;padding:.35rem .85rem;font-size:.82rem;font-weight:500;transition:background .15s,color .15s}.att-gender-tab:hover{background:var(--gray-200);color:var(--gray-800)}.att-gender-tab-active{font-weight:700;box-shadow:0 1px 4px #0000001a;background:var(--white)!important;color:var(--teal-dark)!important}.att-summary-bar{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);flex-wrap:wrap;align-items:center;gap:0;margin-bottom:1.25rem;padding:.85rem 1.5rem;display:flex}.att-summary-item{align-items:center;gap:.5rem;padding:.25rem 0;display:flex}.att-summary-num{color:var(--teal-dark);font-size:1.3rem;font-weight:700}.att-num-absent{color:#dc2626}.att-num-tardy{color:#a16207}.att-summary-lbl{color:var(--gray-500);font-size:.8rem}.att-summary-divider{background:var(--gray-200);width:1px;height:2rem;margin:0 1.25rem}.att-grid-wrap{border-radius:var(--radius);box-shadow:var(--shadow);background:var(--white);margin-bottom:1rem;overflow-x:auto}@media (width<=640px){.att-grid-wrap{display:none}}.att-table{border-collapse:collapse;width:max-content;min-width:100%}.att-name-col{background:var(--white);z-index:2;min-width:150px;max-width:200px;position:sticky;left:0}.att-name-th{border-right:1px solid var(--gray-200);background:var(--gray-50)!important;z-index:3!important}.att-week-th{background:var(--navy);color:#ffffffe6;text-align:center;letter-spacing:.04em;border-right:2px solid var(--navy-light);padding:.45rem .5rem;font-size:.75rem;font-weight:700}.att-day-th{background:var(--gray-50);text-align:center;border-bottom:2px solid var(--gray-200);border-right:1px solid var(--gray-100);vertical-align:top;min-width:42px;padding:.3rem .25rem .2rem}.att-day-th:last-child{border-right:none}.att-day-today{background:var(--teal-light)!important}.att-day-future{opacity:.5}.att-day-holiday{background:#fef3c7!important}.att-cell-holiday{color:#d97706;cursor:default;background:#fef9ee;font-size:.65rem}.att-day-dow{color:var(--gray-500);text-transform:uppercase;font-size:.65rem;font-weight:600;display:block}.att-day-num{color:var(--gray-800);font-size:.85rem;font-weight:700;line-height:1.3;display:block}.att-confirm-btn{border:1px solid var(--gray-300);color:var(--gray-400);cursor:pointer;white-space:nowrap;background:0 0;border-radius:4px;margin:.15rem auto 0;padding:1px 4px;font-size:.6rem;line-height:1.4;transition:background .15s,color .15s,border-color .15s;display:block}.att-confirm-btn:hover{background:var(--teal-light);color:var(--teal-dark);border-color:var(--teal)}.att-confirm-done{cursor:default;color:#15803d!important;background:#dcfce7!important;border-color:#bbf7d0!important}.att-day-actions{justify-content:center;gap:2px;margin-top:.15rem;display:flex}.att-holiday-btn{border:1px solid var(--gray-200);color:var(--gray-300);cursor:pointer;background:0 0;border-radius:4px;align-items:center;padding:1px 3px;transition:background .15s,color .15s,border-color .15s;display:flex}.att-holiday-btn:hover,.att-holiday-btn.att-holiday-active{color:#d97706;background:#fef3c7;border-color:#fcd34d}.att-holiday-label{color:#d97706;text-transform:uppercase;margin-top:1px;font-size:.55rem;font-weight:700;display:block}.mob-day-holiday{background:#fffbeb!important;border-color:#fcd34d!important}.mob-holiday-badge{color:#d97706;background:#fef3c7;border-radius:4px;margin-left:.4rem;padding:1px 5px;font-size:.65rem;font-weight:600}.mob-holiday-badge-sm{color:#d97706;font-size:.78rem;font-weight:600}.mob-holiday-toggle-btn{border:1px solid var(--gray-200);background:var(--gray-50);width:100%;color:var(--gray-500);cursor:pointer;border-radius:6px;align-items:center;gap:.35rem;margin-bottom:.4rem;padding:.4rem .6rem;font-size:.8rem;display:flex}.mob-holiday-toggle-btn:hover{color:#d97706;background:#fef3c7;border-color:#fcd34d}.mob-holiday-toggle-btn.active{color:#d97706;background:#fef3c7;border-color:#fcd34d;font-weight:600}.att-table td.att-name-col{border-right:1px solid var(--gray-200);border-bottom:1px solid var(--gray-100);padding:.5rem .75rem;font-size:.85rem}.att-group-sep{background:var(--gray-50);color:var(--gray-600);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--gray-200);padding:.35rem .75rem;font-size:.72rem;font-weight:700}.att-group-count{color:var(--gray-400);font-weight:400}.att-student-link{color:var(--gray-800);font-weight:500;text-decoration:none}.att-student-link:hover{color:var(--teal);text-decoration:underline}.att-cell{text-align:center;border-bottom:1px solid var(--gray-100);border-right:1px solid var(--gray-100);vertical-align:middle;min-width:38px;padding:.4rem .2rem;font-size:.8rem;font-weight:700}.att-cell:last-child{border-right:none}.att-cell-edit{cursor:pointer;transition:opacity .1s,transform .1s}.att-cell-edit:hover{opacity:.75}.att-cell-edit:active{transform:scale(.88)}.att-present{color:#15803d;background:#dcfce7}.att-absent{color:#dc2626;background:#fee2e2}.att-tardy{color:#a16207;background:#fef9c3}.att-empty{background:var(--white);color:var(--gray-400)}.att-cell-future{background:var(--gray-100);color:var(--gray-300);cursor:default}.att-cell-preenroll{background:var(--gray-50);color:var(--gray-300);cursor:default;font-size:.65rem}.att-saving{opacity:.5;pointer-events:none}.att-legend{color:var(--gray-600);flex-wrap:wrap;gap:1rem;margin-top:.75rem;font-size:.78rem;display:flex}.att-legend-item{align-items:center;gap:.35rem;display:flex}.att-legend-swatch{width:24px;height:20px;min-width:unset;border:1px solid #0000;border-radius:4px;justify-content:center;align-items:center;padding:0;font-size:.7rem;display:inline-flex}.att-mobile-wrap{display:none}@media (width<=640px){.att-mobile-wrap{display:block}}.mob-week-block{margin-bottom:1.25rem}.mob-week-label{text-transform:uppercase;letter-spacing:.06em;color:var(--gray-500);border-bottom:1px solid var(--gray-200);margin-bottom:.4rem;padding:0 0 .4rem;font-size:.72rem;font-weight:700}.mob-day-block{box-shadow:var(--shadow);background:var(--white);border-radius:8px;margin-bottom:.5rem;overflow:hidden}.mob-day-today{border-left:3px solid var(--teal)}.mob-day-header{cursor:pointer;text-align:left;background:0 0;border:none;justify-content:space-between;align-items:center;gap:.5rem;width:100%;padding:.7rem 1rem;display:flex}.mob-day-header:disabled{cursor:default;opacity:.6}.mob-day-title{color:var(--gray-800);align-items:center;gap:.5rem;font-size:.9rem;font-weight:600;display:flex}.mob-today-badge{background:var(--teal);color:var(--white);border-radius:99px;padding:2px 6px;font-size:.65rem;font-weight:700}.mob-day-right{flex-shrink:0;align-items:center;gap:.5rem;display:flex}.mob-future-label{color:var(--gray-400);font-size:.75rem}.mob-recorded-badge{color:#15803d;background:#dcfce7;border-radius:99px;padding:2px 7px;font-size:.75rem;font-weight:600}.mob-unrecorded-badge{color:var(--gray-500);font-size:.75rem}.mob-chevron{color:var(--gray-400);font-size:.6rem}.mob-day-body{border-top:1px solid var(--gray-100);padding:.5rem .75rem .75rem}.mob-confirm-all-btn{background:var(--teal-light);width:100%;color:var(--teal-dark);cursor:pointer;border:1px solid #99f6e4;border-radius:7px;margin-bottom:.75rem;padding:.55rem;font-size:.85rem;font-weight:700;transition:background .15s}.mob-confirm-all-btn:hover{background:#99f6e4}.mob-group-label{text-transform:uppercase;letter-spacing:.05em;color:var(--gray-500);padding:.4rem 0 .2rem;font-size:.7rem;font-weight:700}.mob-student-row{border-bottom:1px solid var(--gray-100);justify-content:space-between;align-items:center;gap:.5rem;padding:.5rem 0;display:flex}.mob-student-row:last-child{border-bottom:none}.mob-student-locked{opacity:.45}.mob-student-name{color:var(--gray-800);text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-size:.875rem;overflow:hidden}.mob-locked-label{color:var(--gray-400);font-size:.75rem}.mob-att-btns{flex-shrink:0;gap:.3rem;display:flex}.mob-att-btn{border:1.5px solid var(--gray-200);background:var(--white);width:38px;height:36px;color:var(--gray-500);cursor:pointer;border-radius:7px;font-size:.85rem;font-weight:700;transition:background .12s,color .12s,border-color .12s}.mob-att-btn:active{transform:scale(.9)}.mob-att-p.mob-att-active{color:#15803d;background:#dcfce7;border-color:#bbf7d0}.mob-att-a.mob-att-active{color:#dc2626;background:#fee2e2;border-color:#fecaca}.mob-att-t.mob-att-active{color:#a16207;background:#fef9c3;border-color:#fde047}.sa-back-link{color:var(--teal);margin-bottom:1.25rem;font-size:.875rem;font-weight:500;text-decoration:none;display:inline-block}.sa-back-link:hover{text-decoration:underline}.sa-student-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1.25rem;display:flex}.sa-student-meta{color:var(--gray-600);margin-top:.25rem;font-size:.875rem}.sa-meta-dot{margin:0 .35rem}.sa-year-nav{align-items:center;gap:.5rem;display:flex}.sa-year-label{color:var(--gray-600);font-size:.8rem;font-weight:600}.sa-stats-row{grid-template-columns:repeat(4,1fr);gap:.75rem;margin-bottom:1.25rem;display:grid}@media (width<=640px){.sa-stats-row{grid-template-columns:repeat(2,1fr)}}.sa-stat-card{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);text-align:center;border-top:3px solid #0000;padding:1rem 1.25rem}.sa-stat-present{border-top-color:#15803d}.sa-stat-absent{border-top-color:#dc2626}.sa-stat-tardy{border-top-color:#a16207}.sa-stat-rate{border-top-color:var(--teal)}.sa-stat-num{color:var(--gray-800);font-size:1.6rem;font-weight:700}.sa-stat-present .sa-stat-num{color:#15803d}.sa-stat-absent .sa-stat-num{color:#dc2626}.sa-stat-tardy .sa-stat-num{color:#a16207}.sa-stat-rate .sa-stat-num{color:var(--teal-dark)}.sa-stat-lbl{color:var(--gray-500);margin-top:.2rem;font-size:.75rem}.sa-months{gap:.6rem;display:grid}.sa-month-block{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.sa-month-toggle{cursor:pointer;text-align:left;background:0 0;border:none;justify-content:space-between;align-items:center;gap:1rem;width:100%;padding:.9rem 1.25rem;transition:background .15s;display:flex}.sa-month-toggle:hover{background:var(--gray-50)}.sa-month-title{color:var(--gray-800);align-items:center;gap:.75rem;font-size:.95rem;font-weight:600;display:flex}.sa-month-total{color:var(--gray-500);font-size:.78rem;font-weight:400}.sa-month-mini{flex-shrink:0;align-items:center;gap:.75rem;font-size:.8rem;display:flex}.sa-mini-p{color:#15803d;font-weight:600}.sa-mini-a{color:#dc2626;font-weight:600}.sa-mini-t{color:#a16207;font-weight:600}.sa-chevron{color:var(--gray-400);margin-left:.25rem;font-size:.6rem}.sa-month-body{border-top:1px solid var(--gray-100)}.sa-day-table{border-collapse:collapse;width:100%}.sa-day-table th{text-align:left;text-transform:uppercase;letter-spacing:.04em;color:var(--gray-500);background:var(--gray-50);border-bottom:1px solid var(--gray-200);padding:.5rem 1.25rem;font-size:.72rem;font-weight:700}.sa-day-table td{border-bottom:1px solid var(--gray-100);color:var(--gray-800);padding:.6rem 1.25rem;font-size:.875rem}.sa-day-table tbody tr:last-child td{border-bottom:none}.sa-day-table tbody tr:hover td{background:var(--gray-50)}.sa-status-badge{border-radius:5px;justify-content:center;align-items:center;width:26px;height:22px;font-size:.78rem;font-weight:700;display:inline-flex}.sa-week-grid-wrap{-webkit-overflow-scrolling:touch;padding:.75rem 1.25rem 1rem;overflow-x:auto}.sa-week-table{border-collapse:collapse;width:100%;min-width:300px}.sa-week-table th,.sa-week-table td{text-align:center;border:1px solid var(--gray-200);padding:.45rem .6rem;font-size:.82rem}.sa-wk-th{width:36px;border:none!important}.sa-wk-label{color:var(--gray-500);background:var(--gray-50);white-space:nowrap;font-size:.75rem;font-weight:600}.sa-day-col{color:var(--navy);min-width:46px;font-size:.78rem;font-weight:600}.sa-week-cell{cursor:default;vertical-align:middle}.sa-cell-d{color:var(--gray-500);font-size:.7rem;line-height:1.2;display:block}.sa-cell-s{font-size:.82rem;font-weight:700;line-height:1.4;display:block}.sa-cell-noschool{background:var(--gray-50);color:var(--gray-300)}.sa-cell-blank{background:0 0;border-color:#0000!important}.form-section-label{text-transform:uppercase;letter-spacing:.06em;color:var(--gray-500);border-top:1px solid var(--gray-200);margin-top:.5rem;padding:.75rem 0 .25rem;font-size:.72rem;font-weight:700}.detail-section-divider{text-transform:uppercase;letter-spacing:.06em;color:var(--gray-500);border-top:1px solid var(--gray-200);margin-top:.25rem;padding:.6rem 0 .25rem;font-size:.72rem;font-weight:700}.rc-stats-bar{color:var(--gray-600);flex-wrap:wrap;align-items:center;gap:.6rem;margin-bottom:1rem;font-size:.875rem;display:flex}.rc-stat-dot{color:var(--gray-300)}.rc-stat-sent strong{color:#15803d}.rc-stat-complete strong{color:#0d9488}.rc-stat-draft strong{color:var(--gray-500)}.rc-stat-none strong{color:var(--gray-400)}.rc-status-badge{letter-spacing:.03em;white-space:nowrap;border-radius:99px;padding:.2rem .55rem;font-size:.72rem;font-weight:700;display:inline-block}.rc-status-sent{color:#15803d;background:#dcfce7}.rc-status-complete{color:#0f766e;background:#ccfbf1}.rc-status-draft{background:var(--gray-100);color:var(--gray-500)}.rc-status-none{color:var(--gray-400);background:#f3f4f6}.rc-table th:nth-child(2),.rc-table th:nth-child(3),.rc-table th:nth-child(4),.rc-table td:nth-child(2),.rc-table td:nth-child(3),.rc-table td:nth-child(4){text-align:center}.rc-btn-email{color:#0f766e!important}.rc-btn-delete{color:#dc2626!important}.rc-row-actions{flex-wrap:nowrap;gap:.35rem;margin-top:.5rem;display:flex}@media (width<=640px){.rc-row-actions .btn-view-details{padding:.25rem .45rem;font-size:.72rem}}.rc-edit-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1.25rem;display:flex}.rc-edit-header h2{margin:0}.rc-info-grid{grid-template-columns:1fr 1fr;gap:0 1.5rem;display:grid}@media (width<=600px){.rc-info-grid{grid-template-columns:1fr}}.rc-att-grid{grid-template-columns:repeat(5,1fr);gap:1rem;display:grid}@media (width<=640px){.rc-att-grid{grid-template-columns:repeat(3,1fr)}}@media (width<=400px){.rc-att-grid{grid-template-columns:repeat(2,1fr)}}.rc-att-cell{flex-direction:column;gap:.3rem;display:flex}.rc-att-label{color:var(--gray-500);text-transform:uppercase;letter-spacing:.04em;font-size:.75rem;font-weight:600}.rc-att-input{border:1px solid var(--gray-200);border-radius:var(--radius);text-align:center;width:100%;color:var(--gray-800);padding:.45rem .6rem;font-size:1.1rem;font-weight:700}.rc-att-input:focus{border-color:var(--teal);outline:none;box-shadow:0 0 0 2px #0d948826}.rc-att-rate{padding-top:.3rem;font-size:1.2rem;font-weight:700}.rc-progress-cards{flex-direction:column;gap:0;padding:0;display:flex}.rc-cat-card{border-bottom:1px solid var(--gray-100)}.rc-cat-card:last-child{border-bottom:none}.rc-cat-card-header{border-bottom:1px solid var(--gray-100);background:#f0fdfa;align-items:baseline;gap:.6rem;padding:.65rem 1rem .4rem;display:flex}.rc-cat-card-title{color:var(--teal-dark);font-size:.9rem;font-weight:700}.rc-cat-card-desc{color:var(--gray-500);font-size:.75rem}.rc-cat-card-body{flex-direction:column;gap:.65rem;padding:.75rem 1rem .85rem;display:flex}.rc-cat-fields{grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:.5rem .75rem;display:grid}.rc-cat-field{flex-direction:column;gap:.2rem;display:flex}.rc-cat-field-label{color:var(--gray-500);text-transform:uppercase;letter-spacing:.04em;font-size:.7rem;font-weight:600}.rc-cat-field-input{border:1px solid var(--gray-200);color:var(--gray-800);background:var(--white);border-radius:6px;width:100%;padding:.3rem .5rem;font-size:.875rem}.rc-cat-field-input:focus{border-color:var(--teal);outline:none}.rc-cat-field-yesno{flex-direction:row;align-items:center;gap:.5rem}.rc-yesno-btns{gap:.3rem;display:flex}.rc-yesno-btn{border:1.5px solid var(--gray-300);background:var(--white);color:var(--gray-600);cursor:pointer;border-radius:20px;padding:.25rem .65rem;font-size:.78rem;font-weight:600;transition:all .12s}.rc-yesno-btn:hover{border-color:var(--teal);color:var(--teal)}.rc-yesno-yes{color:#15803d!important;background:#dcfce7!important;border-color:#16a34a!important}.rc-yesno-no{color:#dc2626!important;background:#fee2e2!important;border-color:#dc2626!important}.rc-cat-rating-row{flex-wrap:wrap;align-items:center;gap:.6rem;display:flex}.rc-cat-rating-btns{flex-wrap:wrap;gap:.4rem;display:flex}.rc-notes-input{border:1px solid var(--gray-200);width:100%;color:var(--gray-700);background:var(--white);border-radius:4px;padding:.3rem .5rem;font-size:.82rem}.rc-notes-input:focus{border-color:var(--teal,#0d9488);outline:none}.rc-prog-pill{border:2px solid var(--gray-200);background:var(--white);width:100%;color:var(--gray-700);text-align:left;cursor:pointer;border-radius:8px;padding:.55rem .75rem;font-size:.9rem;font-weight:500;transition:border-color .12s,background .12s,color .12s}.rc-prog-pill:hover{border-color:var(--teal)}.rc-prog-pill-sel{font-weight:600;background:var(--teal)!important;border-color:var(--teal)!important;color:var(--white)!important}.rc-stars-row{align-items:center;gap:.5rem;display:flex}.rc-star-btn{border:2px solid var(--gray-300);background:var(--white);cursor:pointer;width:32px;height:32px;color:var(--gray-700);border-radius:50%;justify-content:center;align-items:center;font-size:1.1rem;font-weight:700;line-height:1;transition:border-color .12s;display:inline-flex}.rc-star-btn:hover{border-color:var(--teal,#0d9488);color:var(--teal,#0d9488)}.rc-star-count{color:var(--gray-800);text-align:center;min-width:2rem;font-size:1.4rem;font-weight:700}.rc-remarks{border:1px solid var(--gray-200);border-radius:var(--radius);width:100%;color:var(--gray-800);resize:vertical;padding:.65rem .85rem;font-family:inherit;font-size:.9rem;line-height:1.6}.rc-remarks:focus{border-color:var(--teal,#0d9488);outline:none;box-shadow:0 0 0 2px #0d94881f}.rc-edit-footer{border-top:1px solid var(--gray-200);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;margin-top:1.25rem;padding-top:1.25rem;display:flex}.inv-tabs{border:1px solid var(--gray-200);border-radius:var(--radius);background:var(--white);gap:0;margin-bottom:1.25rem;display:flex;overflow:hidden}.inv-tab{background:var(--white);color:var(--gray-600);cursor:pointer;border:none;border-right:1px solid var(--gray-200);flex:1;padding:.6rem 1.25rem;font-size:.9rem;font-weight:500;transition:background .15s,color .15s}.inv-tab:last-child{border-right:none}.inv-tab:hover{background:var(--gray-50);color:var(--gray-800)}.inv-tab-active{font-weight:600;background:var(--teal)!important;color:var(--white)!important}@media (width<=640px){.inv-tab{padding:.6rem .5rem;font-size:.85rem}}.page{padding-bottom:2rem}.icon-btn{align-items:center;gap:.3rem;display:inline-flex!important}a.icon-btn{text-decoration:none}.nav-link{align-items:center;gap:.3rem;display:inline-flex}.dash-action-btn{align-items:center;gap:.4rem;text-decoration:none;display:inline-flex!important}.stat-icon-svg{color:var(--teal-600,#0d9488);align-items:center;display:flex}.att-summary-item{align-items:center;gap:.35rem;display:flex}.att-summary-icon{opacity:.65;flex-shrink:0}.att-icon-absent{color:#dc2626}.att-icon-tardy{color:#d97706}.prog-stat-icon{opacity:.9;justify-content:center;margin-bottom:4px;display:flex}.prog-section-title{align-items:center;gap:.35rem;display:flex}.prog-backdrop{z-index:200;background:#00000073;justify-content:center;align-items:flex-end;display:flex;position:fixed;inset:0}@media (width>=640px){.prog-backdrop{align-items:center}}.prog-panel{background:#fff;border-radius:16px 16px 0 0;flex-direction:column;width:100%;max-width:520px;max-height:92vh;display:flex;overflow:hidden;box-shadow:0 -4px 24px #00000026}@media (width>=640px){.prog-panel{border-radius:12px;max-height:88vh;box-shadow:0 8px 32px #0000002e}}.prog-header{border-bottom:1px solid var(--gray-100);flex-shrink:0;justify-content:space-between;align-items:flex-start;padding:1rem 1.25rem .75rem;display:flex}.prog-header-name{color:var(--gray-900);font-size:1.05rem;font-weight:700}.prog-header-date{color:var(--gray-500);margin-top:2px;font-size:.8rem}.prog-close{color:var(--gray-400);cursor:pointer;background:0 0;border:none;flex-shrink:0;padding:0 0 0 .5rem;font-size:1.4rem;line-height:1}.prog-close:hover{color:var(--gray-700)}.prog-body{flex-direction:column;flex:1;gap:0;padding:.75rem 1.25rem 1rem;display:flex;overflow-y:auto}.prog-section{border-bottom:1px solid var(--gray-100);padding:.85rem 0}.prog-section:last-child{border-bottom:none}.prog-section-title{color:var(--teal-700,#0d9488);text-transform:uppercase;letter-spacing:.04em;margin-bottom:2px;font-size:.85rem;font-weight:700}.prog-section-desc{color:var(--gray-500);margin-bottom:.65rem;font-size:.78rem}.prog-field{flex-direction:column;flex:1;gap:3px;display:flex}.prog-field label{color:var(--gray-600);font-size:.75rem;font-weight:600}.prog-field select,.prog-field input{border:1px solid var(--gray-300);color:var(--gray-800);background:#fff;border-radius:6px;width:100%;padding:.42rem .6rem;font-size:.88rem}.prog-field select:focus,.prog-field input:focus{border-color:#0d9488;outline:none;box-shadow:0 0 0 2px #0d948826}.prog-field-row{gap:.6rem;margin-top:.6rem;display:flex}.prog-field-row .prog-field{min-width:0}.prog-yn-row{gap:.5rem;margin-top:.25rem;display:flex}.prog-yn-btn{border:2px solid var(--gray-200);color:var(--gray-500);cursor:pointer;background:#fff;border-radius:8px;flex:1;padding:.5rem;font-size:.88rem;font-weight:600;transition:all .15s}.prog-yn-yes.prog-yn-active{color:#15803d;background:#dcfce7;border-color:#16a34a}.prog-yn-no.prog-yn-active{color:#dc2626;background:#fee2e2;border-color:#dc2626}.prog-yn-btn:not(.prog-yn-active):hover{border-color:var(--gray-300);background:var(--gray-50)}.prog-footer{border-top:1px solid var(--gray-100);flex-shrink:0;gap:.75rem;padding:.85rem 1.25rem;display:flex}.prog-footer .btn-secondary{flex:1}.prog-footer .btn-primary{flex:2}.prog-stars-row{align-items:center;gap:.6rem;margin-top:.5rem;display:flex}.prog-star-adj{border:1px solid var(--gray-200);background:var(--gray-50);cursor:pointer;border-radius:.375rem;justify-content:center;align-items:center;width:2rem;height:2rem;font-size:1.1rem;display:flex}.prog-star-adj:hover{background:var(--gray-100)}.prog-stars-display{gap:.25rem;display:flex}.prog-star-icon{cursor:pointer;color:var(--gray-300);transition:color .15s}.prog-star-icon.prog-star-filled{color:#f59e0b}.prog-star-icon:hover{color:#fbbf24}.att-name-row{align-items:center;gap:.4rem;display:flex}.att-log-btn{cursor:pointer;opacity:0;background:0 0;border:none;border-radius:4px;padding:2px 4px;font-size:.85rem;line-height:1;transition:opacity .15s}.att-table tr:hover .att-log-btn{opacity:1}.att-log-btn:hover{background:var(--gray-100);opacity:1}.mob-att-log{background:var(--gray-100);color:var(--gray-700);font-size:.85rem;border:1px solid var(--gray-200)!important}.mob-att-log:hover{background:var(--gray-200)}.prog-stats-row{gap:1rem;margin-bottom:1.25rem;display:flex}.prog-stat-card{border:1px solid var(--gray-200);text-align:center;background:#fff;border-radius:10px;flex:1;padding:1rem}.prog-stat-value{color:var(--gray-800);font-size:1.6rem;font-weight:800;line-height:1.1}.prog-stat-label{color:var(--gray-500);text-transform:uppercase;letter-spacing:.04em;margin-top:4px;font-size:.75rem;font-weight:600}.prog-stat-sub{color:var(--gray-400);margin-top:2px;font-size:.7rem}@media (width<=480px){.prog-stats-row{gap:.5rem}.prog-stat-card{padding:.65rem .5rem}.prog-stat-value{font-size:1.2rem}}.prog-chart-panel{margin-bottom:1.25rem;padding:1rem 1.25rem}.prog-chart-title{color:var(--gray-700);text-transform:uppercase;letter-spacing:.04em;margin-bottom:.75rem;font-size:.85rem;font-weight:700}.daily-date-nav{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.daily-nav-btn{border:1px solid var(--gray-200);width:32px;height:32px;color:var(--gray-700);cursor:pointer;background:#fff;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.daily-nav-btn:hover:not(:disabled){background:var(--gray-100)}.daily-nav-btn:disabled{opacity:.35;cursor:default}.daily-date-display{color:var(--gray-800);white-space:nowrap;align-items:center;gap:.4rem;font-size:.9rem;font-weight:600;display:inline-flex}.daily-date-display svg{color:var(--teal);flex-shrink:0}.daily-today-btn{padding:.3rem .75rem;font-size:.8rem}.daily-status-bar{border:1px solid var(--gray-200);background:#fff;border-radius:8px;align-items:center;gap:.45rem;margin-bottom:1.25rem;padding:.5rem .75rem;font-size:.82rem;font-weight:500;display:flex}.daily-status-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.daily-status-dot.green{background:#16a34a}.daily-status-dot.gray{background:var(--gray-400)}.daily-status-sep{background:var(--gray-200);width:1px;height:14px}.daily-status-present{color:#15803d}.daily-status-absent{color:#dc2626}.daily-status-tardy{color:#d97706}.daily-status-dim{color:var(--gray-500)}.daily-status-future{color:var(--gray-500);font-style:italic}.daily-group-header{text-transform:uppercase;letter-spacing:.06em;color:var(--gray-500);margin-bottom:.75rem;padding:.4rem 0;font-size:.78rem;font-weight:700}.daily-group-border{margin-top:1.5rem}.daily-cards-grid{grid-template-columns:repeat(3,1fr);gap:.85rem;margin-bottom:.5rem;display:grid}@media (width<=900px){.daily-cards-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=560px){.daily-cards-grid{grid-template-columns:1fr}}.daily-card{border:2px solid var(--gray-200);background:#fff;border-radius:10px;flex-direction:column;gap:.65rem;padding:.85rem;transition:border-color .15s,background .15s;display:flex}.daily-card-p{border-color:var(--gray-200);background:#fff}.daily-card-a{background:#fff8f8;border-color:#fca5a5}.daily-card-t{background:#fffdf0;border-color:#fcd34d}.daily-card-offday{border-color:var(--gray-200);background:var(--gray-50);opacity:.6}.daily-offday-label{color:var(--gray-400);margin-top:.4rem;font-size:.8rem;font-style:italic}.daily-holiday-btn{cursor:pointer;border:1px solid var(--gray-200);background:var(--gray-50);color:var(--gray-500);border-radius:6px;align-items:center;gap:.35rem;padding:.35rem .75rem;font-size:.8rem;transition:background .15s,color .15s,border-color .15s;display:flex}.daily-holiday-btn:hover{color:#d97706;background:#fef3c7;border-color:#fcd34d}.daily-holiday-btn.active{color:#d97706;background:#fef3c7;border-color:#fcd34d;font-weight:600}.daily-holiday-banner{text-align:center;background:#fffbeb;border:1px solid #fcd34d;border-radius:12px;flex-direction:column;justify-content:center;align-items:center;gap:.75rem;margin-top:1.5rem;padding:3rem 1.5rem;display:flex}.daily-holiday-icon{color:#d97706}.daily-holiday-title{color:#92400e;font-size:1.4rem;font-weight:700}.daily-holiday-sub{color:#b45309;margin-bottom:.5rem;font-size:.9rem}.daily-card-header{justify-content:space-between;align-items:flex-start;gap:.5rem;display:flex}.daily-card-name{color:var(--gray-800);flex:1;align-items:center;gap:.35rem;min-width:0;font-size:.92rem;font-weight:600;display:flex}.daily-card-grade{color:var(--gray-500);background:var(--gray-100);white-space:nowrap;border-radius:4px;flex-shrink:0;padding:2px 6px;font-size:.72rem}.daily-att-row{gap:.35rem;display:flex}.daily-att-btn{border:1.5px solid var(--gray-200);background:var(--gray-50);color:var(--gray-600);cursor:pointer;border-radius:6px;flex:1;padding:.3rem 0;font-size:.78rem;font-weight:600;transition:background .12s,border-color .12s,color .12s}.daily-att-btn:disabled{opacity:.4;cursor:default}.daily-att-btn:not(:disabled):hover{background:var(--gray-100)}.daily-att-P.active{color:#15803d;background:#dcfce7;border-color:#4ade80}.daily-att-A.active{color:#dc2626;background:#fee2e2;border-color:#f87171}.daily-att-T.active{color:#b45309;background:#fef3c7;border-color:#fbbf24}.daily-att-P:not(:disabled):not(.active):hover{background:#f0fdf4;border-color:#bbf7d0}.daily-att-A:not(:disabled):not(.active):hover{background:#fef2f2;border-color:#fca5a5}.daily-att-T:not(:disabled):not(.active):hover{background:#fffbeb;border-color:#fde68a}.daily-progress-btn{border:1.5px dashed var(--teal);width:100%;color:var(--teal);cursor:pointer;background:0 0;border-radius:7px;padding:.42rem 0;font-size:.8rem;font-weight:600;transition:background .12s}.daily-progress-btn:hover{background:var(--teal-light)}.daily-progress-btn.logged{color:#15803d;background:#f0fdf4;border-style:solid;border-color:#4ade80}.daily-progress-btn.logged:hover{background:#dcfce7}.sp-hero{align-items:center;gap:1rem;margin-bottom:1.5rem;display:flex}.sp-avatar{background:var(--teal);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:56px;height:56px;font-size:1.5rem;font-weight:700;display:flex}.sp-hero-info{flex-direction:column;gap:.2rem;display:flex}.sp-name{color:var(--gray-800);align-items:center;gap:.4rem;margin:0;font-size:1.35rem;font-weight:700;display:flex}.sp-grade{color:var(--gray-500);font-size:.82rem}.sp-joined{color:var(--gray-400);font-size:.78rem}.sp-actions-grid{grid-template-columns:repeat(4,1fr);gap:.85rem;margin-bottom:1.5rem;display:grid}@media (width<=768px){.sp-actions-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=420px){.sp-actions-grid{grid-template-columns:1fr 1fr}}.sp-action-card{border:1.5px solid var(--gray-200);cursor:pointer;text-align:center;background:#fff;border-radius:10px;flex-direction:column;justify-content:center;align-items:center;gap:.4rem;padding:1.1rem .75rem;text-decoration:none;transition:transform .1s,box-shadow .1s,border-color .1s;display:flex}.sp-action-card:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 14px #00000017}.sp-action-card:disabled{opacity:.65;cursor:default}.sp-action-daily svg{color:#f59e0b}.sp-action-attendance svg{color:var(--teal)}.sp-action-progress svg{color:#3b82f6}.sp-action-report svg{color:#8b5cf6}.sp-action-label{color:var(--gray-800);font-size:.82rem;font-weight:700;line-height:1.2}.sp-action-sub{color:var(--gray-500);font-size:.71rem}.sp-details-panel{margin-bottom:1.5rem}.sp-panel-header{border-bottom:1px solid var(--gray-100);justify-content:space-between;align-items:center;padding:.75rem 1.25rem;display:flex}.sp-panel-title{text-transform:uppercase;letter-spacing:.05em;color:var(--gray-500);font-size:.78rem;font-weight:700}.sp-panel-actions{align-items:center;gap:.4rem;display:flex}.sp-icon-btn{border:1px solid var(--gray-200);cursor:pointer;background:#fff;border-radius:6px;justify-content:center;align-items:center;width:30px;height:30px;transition:background .12s,border-color .12s;display:flex}.sp-edit-btn{color:var(--gray-600)}.sp-edit-btn:hover{background:var(--gray-100)}.sp-trash-btn{color:#dc2626;border-color:#fca5a5}.sp-trash-btn:hover:not(:disabled){background:#fef2f2}.sp-trash-btn:disabled{opacity:.4;cursor:default}.sp-edit-footer{border-top:1px solid var(--gray-100);gap:.6rem;padding:.85rem 1.25rem;display:flex}.sp-edit-footer .btn-secondary,.sp-edit-footer .btn-primary{align-items:center;gap:.35rem;display:inline-flex}.sp-contact-link{color:var(--teal-dark);align-items:center;gap:.3rem;text-decoration:none;display:inline-flex}.sp-contact-link:hover{text-decoration:underline}.wpb-backdrop{z-index:1000;background:#00000080;justify-content:center;align-items:center;padding:1.5rem;display:flex;position:fixed;inset:0}.wpb-panel{background:#fff;border-radius:16px;flex-direction:column;width:100%;max-width:1060px;max-height:88vh;display:flex;overflow:hidden;box-shadow:0 24px 80px #00000038}.wpb-header{border-bottom:1px solid var(--gray-100);flex-shrink:0;justify-content:space-between;align-items:flex-start;padding:1.3rem 1.6rem 1rem;display:flex}.wpb-student-name{color:var(--gray-900,#111827);font-size:1.25rem;font-weight:700}.wpb-student-sub{color:var(--gray-500);margin-top:2px;font-size:.87rem}.wpb-nav{border-bottom:1px solid var(--gray-100);flex-shrink:0;justify-content:space-between;align-items:center;gap:.5rem;padding:.8rem 1.6rem;display:flex}.wpb-nav-btn{border:1px solid var(--gray-200);cursor:pointer;color:var(--gray-600);background:0 0;border-radius:8px;flex-shrink:0;padding:.5rem 1.1rem;font-size:.92rem;transition:background .15s}.wpb-nav-btn:hover:not(:disabled){background:var(--gray-100)}.wpb-nav-btn:disabled{opacity:.35;cursor:default}.wpb-nav-label{color:var(--gray-700);text-align:center;flex:1;font-size:.97rem;font-weight:600}.wpb-table-wrap{flex:1;overflow:auto}.wpb-table{border-collapse:collapse;width:100%;font-size:.9rem}.wpb-table th{background:var(--gray-50);text-align:left;text-transform:uppercase;letter-spacing:.05em;color:var(--gray-500);border-bottom:2px solid var(--gray-200);white-space:nowrap;z-index:1;padding:.7rem 1.1rem;font-size:.73rem;font-weight:700;position:sticky;top:0}.wpb-table td{border-bottom:1px solid var(--gray-100);vertical-align:middle;padding:.9rem 1.1rem}.wpb-row-clickable{cursor:pointer}.wpb-row-clickable:hover td{background:var(--teal-light,#f0fdf9)}.wpb-row-noclass td{background:var(--gray-50);color:var(--gray-300);font-style:italic}.wpb-row-holiday td{background:#fffbeb}.wpb-row-future td{color:var(--gray-300)}.wpb-row-has-data{background:#fafffe}.wpb-day-cell{white-space:nowrap;color:var(--gray-700);min-width:90px;font-size:.9rem;font-weight:700}.wpb-day-today{color:var(--teal-dark,#0d9488)!important}.wpb-cell-text{color:var(--gray-800)}.wpb-badge{white-space:nowrap;border-radius:5px;align-items:center;padding:3px 9px;font-size:.78rem;font-weight:600;display:inline-flex}.wpb-good{color:#15803d;background:#dcfce7}.wpb-ni{color:#dc2626;background:#fee2e2}.wpb-yes{color:#065f46;background:#d1fae5}.wpb-no{background:var(--gray-100);color:var(--gray-500)}.wpb-missed{color:#92400e;background:#fef3c7}.wpb-special{color:#1d4ed8;background:#dbeafe}.wpb-rating-badge{border-radius:4px;margin-left:5px;padding:1px 5px;font-size:.68rem;font-weight:700;display:inline-block}.wpb-stars{color:#f59e0b;letter-spacing:1px;font-size:.95rem}.wpb-holiday-cell{color:#d97706;font-size:.85rem;font-weight:600}.wpb-noclass-cell{color:var(--gray-400);font-size:.85rem;font-style:italic}.wpb-cards{display:none}@media (width<=1000px){.wpb-backdrop{padding:1rem}.wpb-panel{max-width:98vw}}@media (width<=820px){.wpb-backdrop{align-items:flex-end;padding:0}.wpb-panel{border-radius:20px 20px 0 0;max-width:100%;max-height:94vh}.wpb-header{padding:1rem 1.1rem .8rem}.wpb-student-name{font-size:1.1rem}.wpb-nav{padding:.65rem 1rem}.wpb-nav-label{font-size:.88rem}.wpb-nav-btn{padding:.45rem .8rem;font-size:.85rem}.wpb-table-wrap{display:none}.wpb-cards{flex-direction:column;flex:1;gap:.6rem;padding:.75rem;display:flex;overflow-y:auto}.wpb-card{border:1px solid var(--gray-200);background:#fff;border-radius:12px;overflow:hidden}.wpb-card-clickable{cursor:pointer}.wpb-card-clickable:active .wpb-card-head{background:var(--teal-light,#f0fdf9)}.wpb-card-head{background:var(--gray-50);border-bottom:1px solid var(--gray-200);justify-content:space-between;align-items:center;padding:.7rem 1rem;display:flex}.wpb-card-head-day{color:var(--gray-800);font-size:1rem;font-weight:700}.wpb-card-head-today{color:var(--teal-dark,#0d9488)!important}.wpb-card-edit-hint{color:var(--gray-400);font-size:.72rem}.wpb-card-body{grid-template-columns:1fr 1fr;display:grid}.wpb-card-field{border-bottom:1px solid var(--gray-100);border-right:1px solid var(--gray-100);flex-direction:column;gap:5px;padding:.65rem .9rem;display:flex}.wpb-card-field:nth-child(2n){border-right:none}.wpb-card-field:nth-last-child(-n+2){border-bottom:none}.wpb-card-label{text-transform:uppercase;letter-spacing:.05em;color:var(--gray-400);font-size:.64rem;font-weight:700}.wpb-card-value{color:var(--gray-800);flex-wrap:wrap;align-items:center;gap:3px;min-height:22px;font-size:.9rem;display:flex}.wpb-card-future-label{color:var(--gray-300);grid-column:1/-1;padding:.7rem .9rem;font-size:.82rem;font-style:italic}.wpb-card-simple{justify-content:space-between;align-items:center;padding:.7rem 1rem;display:flex}.wpb-card-simple-day{color:var(--gray-800);font-size:1rem;font-weight:700}.wpb-card-noclass{background:var(--gray-50)}.wpb-card-holiday{background:#fffbeb}.wpb-card-noclass-text{color:var(--gray-400);font-size:.82rem;font-style:italic}.wpb-card-holiday-text{color:#d97706;font-size:.82rem;font-weight:600}}.prog-sub-rating{margin-top:.6rem}.prog-sub-rating-label{color:var(--gray-500);margin-bottom:.35rem;font-size:.75rem}
