@import "https://fonts.googleapis.com/css2?family=Cormorant+Garant:ital,wght@0,400;0,500;0,600;0,700;1,400;1,600&family=Plus+Jakarta+Sans:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap";*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#f8faf8;--surface:#fff;--card:#fff;--input-bg:#f4f9f5;--border:#1e7a3a26;--border-md:#1e7a3a40;--green:#1e7a3a;--green-br:#1f8a40;--green-lt:#2ea550;--green-dim:#1e7a3a14;--green-glow:#1e7a3a33;--text:#0f2d18;--text-sec:#2d6b42;--text-mute:#7aaa88;--text-faint:#b0ccb8;--red:#dc2626;--red-dim:#dc262617;--amber:#d97706;--amber-dim:#d9770617;--blue:#2563eb;--blue-dim:#2563eb17;--sidebar-w:272px;--topbar-h:64px;--radius:14px;--radius-sm:9px;--ease:cubic-bezier(.4,0,.2,1)}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;overflow-x:hidden}body{background:var(--bg);color:var(--text);-webkit-tap-highlight-color:transparent;max-width:100vw;min-height:100vh;font-family:Plus Jakarta Sans,sans-serif;line-height:1.5;overflow-x:hidden}#root{max-width:100vw;overflow-x:hidden}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-md);border-radius:4px}.app-shell{min-height:100vh;display:flex}.main-area{margin-left:var(--sidebar-w);flex-direction:column;flex:1;min-height:100vh;display:flex}.page-content{flex:1;padding:28px 32px}.sidebar{width:var(--sidebar-w);min-width:var(--sidebar-w);border-right:1px solid var(--border);z-index:100;background:#fff;flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0;overflow-y:auto;box-shadow:2px 0 12px #1e7a3a0d}.sidebar-brand{border-bottom:1px solid var(--border);padding:22px 20px 18px}.brand-logo-box{background:var(--green-dim);border:1px solid var(--border);border-radius:12px;justify-content:center;align-items:center;margin-bottom:12px;padding:10px 8px;display:flex}.brand-logo-box img{object-fit:contain;max-height:68px}.brand-divider{background:linear-gradient(90deg,transparent,var(--border-md),transparent);height:1px;margin:10px 0}.brand-dept{text-align:center;letter-spacing:1.5px;text-transform:uppercase;color:var(--green);margin-bottom:8px;font-size:10px;font-weight:700}.semester-pill{background:var(--green-dim);border:1px solid var(--border-md);color:var(--green);border-radius:20px;justify-content:center;align-items:center;gap:6px;padding:5px 14px;font-size:11.5px;font-weight:600;display:flex}.semester-dot{background:var(--green);border-radius:50%;width:6px;height:6px;animation:2s infinite pulse}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.7)}}.sidebar-nav{flex:1;padding:12px 0 20px}.nav-section{letter-spacing:2.5px;text-transform:uppercase;color:var(--text-faint);padding:10px 20px 4px;font-size:9px;font-weight:700}.nav-item{cursor:pointer;color:var(--text-mute);transition:all .2s var(--ease);border:1px solid #0000;border-radius:9px;align-items:center;gap:10px;margin:1px 8px;padding:9px 12px;font-size:13.5px;font-weight:500;display:flex}.nav-item:hover{background:var(--green-dim);color:var(--text)}.nav-item.active{background:var(--green-dim);color:var(--green);border-color:var(--border);font-weight:600}.nav-item.locked{opacity:.35;pointer-events:none}.nav-icon{background:#1e7a3a0f;border-radius:7px;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;display:flex}.nav-item.active .nav-icon{background:#1e7a3a1f}.nav-badge{background:var(--red);color:#fff;border-radius:10px;margin-left:auto;padding:2px 7px;font-size:10px;font-weight:700}.sidebar-footer{border-top:1px solid var(--border);padding:12px 18px}.sf-row{justify-content:space-between;padding:4px 0;font-size:12px;display:flex}.sf-label{color:var(--text-faint)}.sf-val{color:var(--green);font-family:JetBrains Mono,monospace;font-weight:600}.topbar{height:var(--topbar-h);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--border);z-index:50;background:#ffffffeb;justify-content:space-between;align-items:center;padding:0 28px;display:flex;position:sticky;top:0;box-shadow:0 1px 12px #1e7a3a0f}.topbar-breadcrumb{color:var(--text-faint);letter-spacing:1px;text-transform:uppercase;margin-bottom:2px;font-size:10px;font-weight:600}.topbar-title{color:var(--text);font-family:Cormorant Garant,serif;font-size:21px;font-weight:600;line-height:1}.topbar-right{align-items:center;gap:10px;display:flex}.topbar-date{color:var(--text-mute);background:var(--green-dim);border:1px solid var(--border);border-radius:8px;padding:5px 12px;font-family:JetBrains Mono,monospace;font-size:12px}.user-chip{background:var(--green-dim);border:1px solid var(--border);border-radius:10px;align-items:center;gap:9px;padding:5px 12px 5px 6px;display:flex}.user-av{background:linear-gradient(135deg,var(--green),var(--green-lt));color:#fff;border-radius:7px;justify-content:center;align-items:center;width:28px;height:28px;font-size:12px;font-weight:700;display:flex}.user-name{color:var(--text);font-size:13px;font-weight:600}.user-role{color:var(--text-mute);font-size:11px}.role-pill{border-radius:20px;align-items:center;gap:5px;padding:3px 9px;font-size:11px;font-weight:700;display:inline-flex}.role-admin{color:#2563eb;background:#2563eb1a;border:1px solid #2563eb33}.role-teacher{background:var(--green-dim);color:var(--green);border:1px solid var(--border)}.btn{border-radius:var(--radius-sm);cursor:pointer;transition:all .18s var(--ease);white-space:nowrap;border:1px solid #0000;justify-content:center;align-items:center;gap:7px;padding:9px 18px;font-family:Plus Jakarta Sans,sans-serif;font-size:13.5px;font-weight:600;display:inline-flex}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:var(--green);color:#fff;border-color:var(--green)}.btn-primary:hover{background:var(--green-br);box-shadow:0 4px 16px var(--green-glow);transform:translateY(-1px)}.btn-ghost{color:var(--text-sec);border-color:var(--border);background:#1e7a3a12}.btn-ghost:hover{color:var(--text);background:#1e7a3a1f}.btn-danger{background:var(--red-dim);color:var(--red);border-color:#dc262633}.btn-danger:hover{background:#dc262626}.btn-sm{border-radius:7px;padding:6px 14px;font-size:12.5px}.btn-xs{border-radius:6px;padding:4px 10px;font-size:11.5px}.btn-full{width:100%}.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);transition:border-color .2s;overflow:hidden}.card:hover{border-color:var(--border-md)}.card-head{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:12px;padding:15px 20px;display:flex}.card-title{color:var(--text);font-size:14px;font-weight:600}.card-sub{color:var(--text-mute);margin-top:1px;font-size:12px}.card-body{padding:20px}.stats-grid{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px;display:grid}.stat-card{border:1px solid var(--border);border-radius:var(--radius);background:#fff;padding:20px;transition:all .2s}.stat-card:hover{border-color:var(--border-md);transform:translateY(-1px);box-shadow:0 4px 20px #1e7a3a14}.stat-icon{border-radius:9px;justify-content:center;align-items:center;width:38px;height:38px;margin-bottom:14px;display:flex}.stat-icon.blue{background:#2563eb1a}.stat-icon.green{background:var(--green-dim)}.stat-icon.amber{background:var(--amber-dim)}.stat-icon.red{background:var(--red-dim)}.stat-label{text-transform:uppercase;letter-spacing:.8px;color:var(--text-faint);margin-bottom:5px;font-size:10.5px;font-weight:700}.stat-number{color:var(--text);margin-bottom:3px;font-family:Cormorant Garant,serif;font-size:38px;font-weight:600;line-height:1}.stat-hint{color:var(--text-faint);font-size:12px}.badge{border-radius:20px;align-items:center;gap:5px;padding:2px 9px;font-size:11.5px;font-weight:600;display:inline-flex}.badge:before{content:"";border-radius:50%;flex-shrink:0;width:5px;height:5px}.badge-green{background:var(--green-dim);color:var(--green)}.badge-green:before{background:var(--green)}.badge-red{background:var(--red-dim);color:var(--red)}.badge-red:before{background:var(--red)}.badge-amber{background:var(--amber-dim);color:var(--amber)}.badge-amber:before{background:var(--amber)}.badge-blue{background:var(--blue-dim);color:var(--blue)}.badge-blue:before{background:var(--blue)}.badge-dim{color:var(--text-sec);background:#0000000d}.badge-dim:before{background:var(--text-mute)}.table-wrap{overflow-x:auto}table{border-collapse:collapse;width:100%}thead th{text-transform:uppercase;letter-spacing:1px;color:var(--text-mute);border-bottom:1px solid var(--border);text-align:left;white-space:nowrap;background:#1e7a3a08;padding:9px 14px;font-size:10px;font-weight:700}tbody td{color:var(--text-sec);border-bottom:1px solid var(--border);padding:12px 14px;font-size:13.5px}tbody tr:last-child td{border-bottom:none}tbody tr:hover td{color:var(--text);background:#1e7a3a08}.form-group{margin-bottom:16px}.form-label{color:var(--text-sec);margin-bottom:6px;font-size:12px;font-weight:600;display:block}.form-input{background:var(--input-bg);border:1.5px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text);outline:none;padding:9px 13px;font-family:Plus Jakarta Sans,sans-serif;font-size:13.5px;transition:all .18s}.form-input:focus{border-color:var(--green);background:#fff;box-shadow:0 0 0 3px #1e7a3a14}.form-input::placeholder{color:var(--text-faint)}.form-input option{color:var(--text);background:#fff}.form-row{grid-template-columns:1fr 1fr;gap:14px;display:grid}.form-full{grid-column:1/-1}.pwd-wrap{position:relative}.pwd-wrap .form-input{padding-right:42px}.pwd-toggle{cursor:pointer;color:var(--text-mute);background:0 0;border:none;padding:4px;font-size:15px;position:absolute;top:50%;right:10px;transform:translateY(-50%)}.alert{border-radius:var(--radius-sm);align-items:flex-start;gap:10px;margin-bottom:14px;padding:12px 14px;font-size:13px;display:flex}.alert-info{background:var(--blue-dim);color:#1e40af;border:1px solid #2563eb2e}.alert-success{background:var(--green-dim);color:var(--green);border:1px solid #1e7a3a33}.alert-warning{background:var(--amber-dim);color:#92400e;border:1px solid #d977062e}.alert-danger{background:var(--red-dim);color:#991b1b;border:1px solid #dc26262e}.upload-zone{border:2px dashed var(--border-md);border-radius:var(--radius);text-align:center;cursor:pointer;background:#1e7a3a05;padding:44px 28px;transition:all .2s}.upload-zone:hover,.upload-zone.drag{border-color:var(--green);background:var(--green-dim)}.upload-icon{border:1px solid var(--border);background:#1e7a3a14;border-radius:14px;justify-content:center;align-items:center;width:56px;height:56px;margin:0 auto 16px;display:flex}.upload-title{color:var(--text);margin-bottom:4px;font-family:Cormorant Garant,serif;font-size:20px;font-weight:600}.upload-sub{color:var(--text-mute);margin-bottom:16px;font-size:13px}.fmt-tags{flex-wrap:wrap;justify-content:center;gap:7px;display:flex}.fmt-tag{border:1px solid var(--border);color:var(--text-sec);background:#1e7a3a12;border-radius:5px;padding:2px 9px;font-family:JetBrains Mono,monospace;font-size:11px}.section-header{margin-bottom:24px}.section-eyebrow{letter-spacing:2px;text-transform:uppercase;color:var(--green);align-items:center;gap:8px;margin-bottom:5px;font-size:10px;font-weight:700;display:flex}.section-eyebrow:before{content:"";background:var(--green);width:20px;height:1px}.section-title{color:var(--text);margin-bottom:4px;font-family:Cormorant Garant,serif;font-size:28px;font-weight:600;line-height:1.1}.section-sub{color:var(--text-mute);font-size:13.5px}.roster-list{flex-direction:column;gap:5px;display:flex}.roster-item{border:1px solid var(--border);background:#1e7a3a08;border-radius:9px;grid-template-columns:32px 1fr auto;align-items:center;gap:12px;padding:9px 12px;transition:all .15s;display:grid}.roster-item:hover{border-color:var(--border-md);background:#1e7a3a0f}.roster-num{width:26px;height:26px;color:var(--text-mute);background:#1e7a3a14;border-radius:6px;justify-content:center;align-items:center;font-family:JetBrains Mono,monospace;font-size:11px;font-weight:600;display:flex}.student-name{color:var(--text);font-size:13.5px;font-weight:500}.student-id{color:var(--text-faint);font-family:JetBrains Mono,monospace;font-size:11.5px}.att-btns{gap:4px;display:flex}.att-btn{cursor:pointer;background:0 0;border:1px solid;border-radius:6px;justify-content:center;align-items:center;width:36px;height:28px;font-family:JetBrains Mono,monospace;font-size:12px;font-weight:700;transition:all .12s;display:flex}.att-btn.P{color:#1e7a3a99;border-color:#1e7a3a4d}.att-btn.P:hover{border-color:var(--green);color:var(--green)}.att-btn.P.active{background:var(--green);border-color:var(--green);color:#fff;box-shadow:0 0 10px var(--green-glow)}.att-btn.A{color:#dc262699;border-color:#dc26264d}.att-btn.A:hover{border-color:var(--red);color:var(--red)}.att-btn.A.active{background:var(--red);border-color:var(--red);color:#fff}.att-btn.L{color:#d9770699;border-color:#d977064d}.att-btn.L:hover{border-color:var(--amber);color:var(--amber)}.att-btn.L.active{background:var(--amber);border-color:var(--amber);color:#fff}.progress-track{background:#1e7a3a1a;border-radius:3px;height:5px;overflow:hidden}.progress-fill{height:100%;transition:width .5s var(--ease);border-radius:3px}.pf-green{background:linear-gradient(90deg,var(--green),var(--green-lt))}.pf-amber{background:linear-gradient(90deg,var(--amber),#fbbf24)}.pf-red{background:linear-gradient(90deg,var(--red),#f87171)}.modal-overlay{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:500;background:#0a281473;justify-content:center;align-items:center;padding:20px;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal-box{border:1px solid var(--border-md);width:100%;max-width:640px;max-height:88vh;animation:scaleIn .2s var(--ease);background:#fff;border-radius:18px;flex-direction:column;display:flex;box-shadow:0 20px 60px #00000026}.modal-head{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:17px 22px;display:flex}.modal-title{color:var(--text);font-size:15px;font-weight:600}.modal-close{border:1px solid var(--border);cursor:pointer;width:28px;height:28px;color:var(--text-mute);background:0 0;border-radius:7px;justify-content:center;align-items:center;font-size:18px;transition:all .15s;display:flex}.modal-close:hover{background:var(--green-dim);color:var(--text)}.modal-body{flex:1;padding:22px;overflow-y:auto}.modal-foot{border-top:1px solid var(--border);justify-content:flex-end;gap:8px;padding:14px 22px;display:flex}.teacher-card{border:1px solid var(--border);background:#fff;border-radius:11px;align-items:center;gap:12px;margin-bottom:8px;padding:14px 16px;transition:all .18s;display:flex}.teacher-card:hover{border-color:var(--border-md);box-shadow:0 2px 10px #1e7a3a12}.teacher-av{background:linear-gradient(135deg,var(--green),var(--green-lt));color:#fff;border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;font-size:15px;font-weight:700;display:flex}.teacher-name{color:var(--text);font-size:14px;font-weight:600}.teacher-meta{color:var(--text-mute);font-family:JetBrains Mono,monospace;font-size:12px}.report-student{border-bottom:1px solid var(--border);padding:14px 18px}.report-student:last-child{border-bottom:none}.report-pct{font-family:Cormorant Garant,serif;font-size:26px;font-weight:600;line-height:1}.report-pct.hi{color:var(--green)}.report-pct.med{color:var(--amber)}.report-pct.lo{color:var(--red)}.activity-row{border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:10px 14px;transition:background .15s;display:flex}.activity-row:last-child{border-bottom:none}.activity-row:hover{background:#1e7a3a08}.activity-dot{border-radius:50%;flex-shrink:0;width:7px;height:7px}.g2{grid-template-columns:1fr 1fr;gap:20px;display:grid}.g3{grid-template-columns:1fr 1fr 1fr;gap:16px;display:grid}.flex-between{justify-content:space-between;align-items:center;display:flex}.mono{font-family:JetBrains Mono,monospace}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}@keyframes pageIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.page-anim{animation:pageIn .28s var(--ease)}.email-shell{border:1px solid var(--border-md);border-radius:var(--radius);background:#f8faf8;overflow:hidden}.email-head{background:linear-gradient(135deg,#0d3a1a,#0a2e15);align-items:center;gap:14px;padding:18px 22px;display:flex}.email-body{color:var(--text-sec);padding:20px 22px;font-size:14px;line-height:1.8}.email-body p{margin-bottom:10px}.email-warn{background:var(--red-dim);border-left:3px solid var(--red);color:var(--text);border-radius:0 8px 8px 0;margin:12px 0;padding:12px 14px}.divider{background:var(--border);height:1px;margin:16px 0}.settings-section-title{text-transform:uppercase;letter-spacing:1.5px;color:var(--green);border-bottom:1px solid var(--border);margin-bottom:12px;padding-bottom:8px;font-size:10.5px;font-weight:700}.scroll-area{max-height:400px;overflow-y:auto}.empty-state{text-align:center;padding:48px 20px}.empty-icon{opacity:.3;margin-bottom:12px;font-size:44px}.empty-title{color:var(--text-sec);margin-bottom:4px;font-size:15px;font-weight:600}.empty-sub{color:var(--text-faint);font-size:13px}.ml-legend{border-radius:var(--radius-sm);border:1px solid var(--border);background:#1e7a3a0a;flex-wrap:wrap;gap:18px;margin-bottom:14px;padding:11px 14px;display:flex}.mli{color:var(--text-mute);align-items:center;gap:7px;font-size:12px;display:flex}.mli-dot{border-radius:3px;flex-shrink:0;width:9px;height:9px}.ibar-wrap{align-items:center;gap:8px;display:flex}.ibar{background:#1e7a3a1a;border-radius:2px;flex:1;height:4px;overflow:hidden}.ibar-fill{border-radius:2px;height:100%}.mobile-toggle{border:1.5px solid var(--border);cursor:pointer;width:38px;height:38px;color:var(--text);background:0 0;border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;margin-right:10px;padding:0;display:none}.mobile-toggle:hover{background:var(--green-dim);border-color:var(--border-md)}.sidebar-backdrop{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:99;background:#0a281473;animation:.15s fadeIn;display:none;position:fixed;inset:0}@media (width<=900px){.stats-grid{grid-template-columns:repeat(2,1fr);gap:12px}.g2{grid-template-columns:1fr;gap:14px}.page-content{padding:18px 16px}.topbar{padding:0 14px}}@media (width<=768px){.sidebar{transition:transform .25s var(--ease);transform:translate(-100%);box-shadow:4px 0 20px #0000001f}.app-shell.sidebar-open .sidebar{transform:translate(0)}.app-shell.sidebar-open .sidebar-backdrop{display:block}.main-area{margin-left:0}.mobile-toggle{display:flex}.table-wrap,.table-scroll{-webkit-overflow-scrolling:touch;overflow-x:auto}table{min-width:600px}.modal-overlay{padding:8px}.modal-box{border-radius:14px;max-height:94vh}.modal-head{padding:14px 16px}.modal-body{padding:16px}.modal-foot{flex-wrap:wrap;padding:12px 16px}.section-title{font-size:24px!important}.section-eyebrow{font-size:10.5px}.card-head,.card-body{padding:14px 16px}}@media (width<=480px){.stats-grid{grid-template-columns:1fr;gap:10px}.page-content{padding:14px 12px}.roster-item{grid-template-columns:32px 1fr;gap:8px;padding:8px 10px}.stat-number{font-size:26px}.stat-card{padding:14px}.modal-foot .btn{flex:1;min-width:120px}}@media (width<=768px){.topbar-date,.topbar-logout-label,.user-chip-text{display:none}.topbar-breadcrumb{font-size:9.5px}.topbar-title{font-size:15px}}@media (width<=480px){.role-pill{display:none}.topbar-right{gap:6px!important}.att-btn{width:44px;height:36px;font-size:14px}.att-btns{gap:6px}}[data-theme=dark]{--bg:#0e1612;--bg-soft:#16201b;--surface:#1a2620;--card:#1a2620;--input-bg:#0f1813;--border:#50b47829;--border-md:#50b47847;--green:#4ec77a;--green-br:#5dd687;--green-lt:#6fdf95;--green-dim:#50b47829;--green-glow:#50b47852;--text:#e6f0e9;--text-sec:#a8d4b8;--text-mute:#6f9685;--text-faint:#4a6b5d;--red:#ef5e5e;--red-dim:#ef5e5e29;--amber:#f4a747;--amber-dim:#f4a74729;--blue:#5b8df7;--blue-dim:#5b8df729}[data-theme=dark] .modal-box,[data-theme=dark] .modal-overlay>div{background:var(--card);color:var(--text)}[data-theme=dark] .topbar{background:#1a2620eb}[data-theme=dark] .sidebar{background:var(--bg-soft)}[data-theme=dark] table{color:var(--text)}[data-theme=dark] table th{background:var(--bg-soft);color:var(--text-sec)}[data-theme=dark] .table-wrap,[data-theme=dark] .table-scroll,[data-theme=dark] .email-shell{background:var(--card)}[data-theme=dark] .email-head{background:linear-gradient(135deg,#0a1d12,#102a1b)}[data-theme=dark] .form-input::placeholder{color:var(--text-faint)}[data-theme=dark] input:focus,[data-theme=dark] select:focus,[data-theme=dark] textarea:focus{border-color:var(--green)}[data-theme=dark] [style*="background:#fff"],[data-theme=dark] [style*="background: #fff"],[data-theme=dark] [style*="background:rgba(255,255,255"]{background:var(--card)!important}.topbar-right .mobile-toggle{display:flex!important}@media (width<=600px){.roster-item{grid-template-areas:"num name""btns btns";gap:6px 10px;padding:10px 12px;grid-template-columns:auto 1fr!important}.roster-num{grid-area:num}.roster-item>div:nth-child(2){grid-area:name;min-width:0}.roster-item>div:nth-child(2)>div:first-child{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.att-btns{grid-area:btns;grid-template-columns:repeat(2,1fr);gap:6px;width:100%;margin-top:4px;display:grid!important}.att-btn{width:100%!important;height:40px!important;font-size:14px!important}}@media (width<=768px){.form-input,input,select,textarea{font-size:16px!important}.page-content{max-width:100vw;overflow-x:hidden}.card{max-width:100%}td,.student-id,.student-email{word-break:break-word;overflow-wrap:anywhere}.modal-box{width:calc(100vw - 16px);max-width:calc(100vw - 16px)!important}.topbar{padding-top:env(safe-area-inset-top,0);padding-left:max(16px, env(safe-area-inset-left,0));padding-right:max(16px, env(safe-area-inset-right,0))}.page-content{padding-left:max(14px, env(safe-area-inset-left,0));padding-right:max(14px, env(safe-area-inset-right,0));padding-bottom:max(14px, env(safe-area-inset-bottom,0))}}@media print{@page{margin:14mm}html,body,#root{color:#000!important;background:#fff!important}.sidebar,.topbar,.no-print,button,.btn,.form-input,input,select,textarea,.modal-overlay,.toast-container{display:none!important}.page-content{width:100%!important;margin:0!important;padding:0!important}.card{page-break-inside:avoid;box-shadow:none!important;background:#fff!important;border:none!important;margin:0 0 12pt!important;padding:0!important}table{border-collapse:collapse!important;width:100%!important;min-width:0!important;font-size:9.5pt!important}th,td{color:#000!important;background:#fff!important;border:1px solid #888!important;padding:4px 6px!important}th{background:#f0f0f0!important;font-weight:700!important}.badge{color:#000!important;background:0 0!important;border:1px solid #888!important;padding:1px 4px!important;font-size:8.5pt!important}.badge-green{color:#1e7a3a!important}.badge-red{color:#b91c1c!important}.badge-amber{color:#b45309!important}[class*=Sec\ ]{color:#000!important;background:#f0f0f0!important}.print-header{border-bottom:2px solid #000;margin-bottom:12pt;padding-bottom:6pt;display:block!important}.print-header h1{margin:0 0 2pt;font-size:16pt;font-weight:700}.print-header .print-sub{color:#444;font-size:10pt}.student-print-block{page-break-inside:avoid}[type=search],[type=text][placeholder*=Search],[type=date],[placeholder]{display:none!important}h1,h2,h3,.card-title,.settings-section-title{color:#000!important}[data-theme=dark] *,*{color:#000!important;background-color:#fff!important}[data-theme=dark] .badge-green,.badge-green{color:#1e7a3a!important}[data-theme=dark] .badge-red,.badge-red{color:#b91c1c!important}[data-theme=dark] .badge-amber,.badge-amber{color:#b45309!important}}.print-header{display:none}
