@import "https://fonts.googleapis.com/css2?family=Rubik:wght@300;400;500;600&display=swap";@import "https://fonts.googleapis.com/css2?family=Rubik:wght@300;400;500;600&family=Noto+Sans+Arabic:wght@300;400;500;600&display=swap";:root{--orange:#f47c20;--purple:#6b52ae;--purple-dark:#4e3a8a;--purple-light:#f0ecfa;--purple-xlight:#f7f4fd}.login-page{background:var(--purple-xlight);direction:rtl;justify-content:center;align-items:center;min-height:100vh;padding:20px;font-family:Rubik,Noto Sans Arabic,sans-serif;display:flex}.login-page:before{content:"";pointer-events:none;background-image:radial-gradient(circle at 20% 20%,#6b52ae14 0%,#0000 50%),radial-gradient(circle at 80% 80%,#f47c2012 0%,#0000 50%);position:fixed;inset:0}.login-page .card{background:#fff;border-radius:24px;width:100%;max-width:920px;display:flex;position:relative;overflow:hidden;box-shadow:0 20px 60px #6b52ae2e,0 4px 16px #00000014}.login-page .left{background:var(--purple);color:#fff;flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;width:340px;padding:44px 28px;display:flex;position:relative;overflow:hidden}.login-page .left:before{content:"";background:#ffffff0f;border-radius:50%;width:300px;height:300px;position:absolute;bottom:-100px;right:-80px}.login-page .left:after{content:"";background:#f47c201f;border-radius:50%;width:180px;height:180px;position:absolute;top:-50px;left:-50px}.login-page .logo-wrap{z-index:1;margin-bottom:28px;position:relative}.login-page .logo-img{border-radius:10px;width:auto;height:80px}.login-page .panel-tagline{text-align:center;z-index:1;margin-bottom:8px;font-size:18px;font-weight:500;position:relative}.login-page .panel-sub{text-align:center;opacity:.82;z-index:1;margin-bottom:28px;font-size:13px;line-height:1.8;position:relative}.login-page .feats{z-index:1;flex-direction:column;gap:10px;width:100%;display:flex;position:relative}.login-page .feat{background:#ffffff1f;border:1px solid #ffffff26;border-radius:12px;align-items:center;gap:11px;padding:10px 13px;font-size:13px;font-weight:300;transition:background .2s;display:flex}.login-page .feat:hover{background:#ffffff2e}.login-page .feat-ic{background:#ffffff2e;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:16px;display:flex}.login-page .right{background:#fff;flex-direction:column;flex:1;justify-content:center;align-items:center;padding:48px 44px;display:flex}.login-page .tabs{background:var(--purple-light);border-radius:14px;width:100%;max-width:360px;margin-bottom:30px;padding:4px;display:flex}.login-page .tab{cursor:pointer;color:#999;background:0 0;border:none;border-radius:11px;flex:1;padding:10px;font-family:Rubik,Noto Sans Arabic,sans-serif;font-size:14px;font-weight:400;transition:all .22s}.login-page .tab.on{background:var(--purple);color:#fff;box-shadow:0 3px 12px #6b52ae59}.login-page .fc{width:100%;max-width:360px}.login-page .fp{animation:.25s fadeIn}@keyframes fadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}.login-page .ft{color:#1a1020;margin-bottom:4px;font-size:22px;font-weight:500}.login-page .fs{color:#aaa;margin-bottom:24px;font-size:13px}.login-page .acc{color:var(--orange)}.login-page .fg{margin-bottom:15px}.login-page .fl{color:#555;margin-bottom:6px;font-size:12px;font-weight:400;display:block}.login-page .fi{color:#1a1a1a;direction:rtl;background:#faf9fe;border:1.5px solid #e8e0f5;border-radius:11px;outline:none;width:100%;padding:11px 14px;font-family:Rubik,Noto Sans Arabic,sans-serif;font-size:14px;transition:border .2s,box-shadow .2s}.login-page .fi:focus{border-color:var(--purple);background:#fff;box-shadow:0 0 0 3px #6b52ae1a}.login-page .fi::placeholder{color:#ccc}.login-page .row2{grid-template-columns:1fr 1fr;gap:10px;display:grid}.login-page .sbtn{background:var(--purple);color:#fff;cursor:pointer;border:none;border-radius:12px;width:100%;margin-top:6px;padding:13px;font-family:Rubik,Noto Sans Arabic,sans-serif;font-size:15px;font-weight:500;transition:background .2s,transform .1s,box-shadow .2s;box-shadow:0 4px 14px #6b52ae4d}.login-page .sbtn:hover:not(:disabled){background:var(--purple-dark);box-shadow:0 6px 18px #6b52ae66}.login-page .sbtn:active{transform:scale(.98)}.login-page .sbtn:disabled{opacity:.6;cursor:not-allowed}.login-page .forgot{text-align:center;color:var(--purple);cursor:pointer;margin-top:13px;font-size:13px;font-weight:300}.login-page .forgot:hover{text-decoration:underline}.login-page .small{color:#bbb;text-align:center;margin-top:14px;font-size:12px;line-height:1.7}.login-page .small span{color:var(--orange);cursor:pointer;font-weight:400}.login-page .small span:hover{text-decoration:underline}.login-page .pstrength{background:#eee;border-radius:2px;height:3px;margin-top:5px;overflow:hidden}.login-page .pstrength-bar{border-radius:2px;width:0;height:100%;transition:width .3s,background .3s}.login-page .err-msg{color:#c33;text-align:center;background:#fee;border:1px solid #fcc;border-radius:10px;margin-bottom:14px;padding:10px 14px;font-size:13px}.login-page .google-divider{color:#ccc;align-items:center;gap:12px;margin:16px 0 12px;font-size:13px;display:flex}.login-page .google-divider:before,.login-page .google-divider:after{content:"";background:#e8e0f5;flex:1;height:1px}.login-page .google-btn{color:#333;cursor:pointer;background:#fff;border:1.5px solid #e8e0f5;border-radius:12px;justify-content:center;align-items:center;gap:10px;width:100%;padding:12px;font-family:Rubik,Noto Sans Arabic,sans-serif;font-size:14px;font-weight:500;transition:background .2s,box-shadow .2s,border-color .2s;display:flex}.login-page .google-btn:hover:not(:disabled){background:#f8f7fc;border-color:#d4cce8;box-shadow:0 2px 8px #0000000f}.login-page .google-btn:disabled{opacity:.6;cursor:not-allowed}#captcha-slot{justify-content:center;margin:8px 0;display:flex}@media (width<=860px){.login-page{padding:12px}.login-page .card{flex-direction:column;max-width:440px}.login-page .left{width:100%;padding:28px 24px 24px}.login-page .left:before{width:200px;height:200px;bottom:-70px;right:-50px}.login-page .left:after{width:120px;height:120px;top:-30px;left:-30px}.login-page .logo-wrap{margin-bottom:16px}.login-page .logo-img{height:60px}.login-page .panel-tagline{margin-bottom:4px;font-size:16px}.login-page .panel-sub{margin-bottom:16px;font-size:12px}.login-page .feats{display:none}.login-page .right{padding:28px 24px}}@media (width<=480px){.login-page{align-items:stretch;padding:0}.login-page .card{box-shadow:none;border-radius:0;max-width:100%;min-height:100vh}.login-page .left{padding:24px 20px 20px}.login-page .logo-img{height:60px}.login-page .panel-tagline{font-size:15px}.login-page .panel-sub{margin-bottom:0;font-size:11px}.login-page .right{padding:24px 18px 40px}.login-page .tabs{margin-bottom:22px}.login-page .ft{font-size:20px}.login-page .fs{margin-bottom:18px;font-size:12px}.login-page .fc{max-width:100%}.login-page .fi{padding:12px 14px;font-size:15px}.login-page .row2{grid-template-columns:1fr;gap:0}}@media (width<=360px){.login-page .left{padding:18px 14px 14px}.login-page .panel-sub{display:none}.login-page .right{padding:20px 14px 32px}}.dash-page{direction:rtl;background:#f7f4fd;min-height:100vh;padding:24px;font-family:Rubik,Noto Sans Arabic,sans-serif}.dash-container{max-width:800px;margin:0 auto}.dash-header{text-align:center;background:#fff;border:1.5px solid #ece6f8;border-radius:16px;flex-direction:column;align-items:center;gap:10px;margin-bottom:16px;padding:20px 24px;display:flex}.dash-header-right{flex-wrap:wrap;align-items:center;gap:14px;display:flex}.dash-logo{border-radius:10px;height:48px}.dash-greeting{color:#6b52ae;margin:0;font-size:20px;font-weight:800}.dash-logout{color:#888;cursor:pointer;background:0 0;border:1.5px solid #e0dce8;border-radius:10px;padding:8px 18px;font-family:inherit;font-size:13px;font-weight:500;transition:all .15s}.dash-logout:hover{color:#6b52ae;background:#f5f3fa;border-color:#d4cce8}.dash-stats{gap:12px;margin-bottom:16px;display:flex}.dash-stat{background:#fff;border:1.5px solid #ece6f8;border-radius:14px;flex:1;align-items:center;gap:10px;padding:16px 20px;display:flex}.dash-stat-val{font-size:28px;font-weight:900}.dash-stat-lbl{color:#888;font-size:13px;font-weight:500}.dash-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:14px;display:grid}.dash-tile{cursor:pointer;background:#fff;border:1.5px solid #ece6f8;border-radius:16px;flex-direction:column;align-items:center;gap:12px;padding:24px 16px;font-family:inherit;transition:all .15s;display:flex}.dash-tile:hover{border-color:#d4cce8;transform:translateY(-2px);box-shadow:0 6px 20px #6b52ae1a}.dash-tile-icon{border-radius:14px;justify-content:center;align-items:center;width:48px;height:48px;display:flex}.dash-tile-icon svg{width:24px;height:24px}.dash-tile-label{color:#1a1020;font-size:14px;font-weight:600}@media (width<=600px){.dash-page{padding:14px}.dash-header{border-radius:14px;padding:16px}.dash-greeting{font-size:17px}.dash-grid{grid-template-columns:repeat(2,1fr);gap:10px}.dash-tile{padding:18px 12px}.dash-tile-icon{border-radius:12px;width:40px;height:40px}.dash-tile-icon svg{width:20px;height:20px}.dash-tile-label{font-size:13px}.dash-stats{flex-flow:wrap}.dash-stat{padding:12px 16px}.dash-stat-val{font-size:22px}}.upload-page{--purple:#6b52ae;--purple-dark:#4e3a8a;--purple-light:#f0ecfa;--orange:#f47c20;--bg:#f7f4fd;--card:#fff;--text:#1a1020;--muted:#aaa;--border:#ece6f8;--green:#16a34a;--green-bg:#dcfce7;--green-b:#86efac;--red:#dc2626;--red-bg:#fee2e2;--red-b:#fca5a5;background:var(--bg);direction:rtl;min-height:100vh;font-family:Rubik,Noto Sans Arabic,sans-serif}.upload-page .navbar{background:var(--purple);z-index:200;justify-content:space-between;align-items:center;gap:10px;padding:10px 16px;display:flex;position:sticky;top:0;box-shadow:0 2px 10px #6b52ae4d}.upload-page .nav-logo-box{background:#fff;border-radius:7px;align-items:center;gap:6px;padding:4px 9px;display:flex}.upload-page .nav-dftr{color:var(--purple);letter-spacing:1px;font-size:15px;font-weight:600}.upload-page .nav-ar{color:#888;font-size:8px;font-weight:400}.upload-page .nav-title{color:#fff;text-align:center;flex:1;font-size:14px;font-weight:500}.upload-page .back-btn{color:#fff;cursor:pointer;background:#ffffff2e;border:none;border-radius:8px;padding:7px 12px;font-family:inherit;font-size:12px;font-weight:500}.upload-page .back-btn:hover{background:#ffffff47}.upload-page .page{flex-direction:column;gap:14px;max-width:720px;margin:0 auto;padding:16px;display:flex}.upload-page .steps{align-items:center;display:flex}.upload-page .step{flex:1;align-items:center;gap:5px;display:flex}.upload-page .step-circle{border:2px solid var(--border);width:26px;height:26px;color:var(--muted);background:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:11px;font-weight:500;transition:all .3s;display:flex}.upload-page .step-label{color:var(--muted);white-space:nowrap;font-size:11px;font-weight:500;transition:color .3s}.upload-page .step-line{background:var(--border);flex:1;height:2px;margin:0 4px;transition:background .3s}.upload-page .step.done .step-circle{background:var(--green);border-color:var(--green);color:#fff}.upload-page .step.done .step-label{color:var(--green)}.upload-page .step.done .step-line{background:var(--green)}.upload-page .step.active .step-circle{background:var(--purple);border-color:var(--purple);color:#fff}.upload-page .step.active .step-label{color:var(--purple)}.upload-page .card{border:1.5px solid var(--border);background:#fff;border-radius:16px;flex-direction:column;gap:14px;padding:18px;display:flex}.upload-page .card-title{color:var(--text);font-size:15px;font-weight:500}.upload-page .card-sub{color:var(--muted);margin-top:-8px;font-size:12px;line-height:1.6}.upload-page .upload-zone{border:2px dashed var(--border);text-align:center;cursor:pointer;background:var(--bg);border-radius:14px;flex-direction:column;align-items:center;gap:8px;padding:28px 16px;transition:all .2s;display:flex}.upload-page .upload-zone:hover,.upload-page .upload-zone.dragover{border-color:var(--purple);background:var(--purple-light)}.upload-page .upload-zone.done{border-color:var(--green-b);background:var(--green-bg);border-style:solid}.upload-page .upload-icon{background:var(--purple-light);border-radius:13px;justify-content:center;align-items:center;width:48px;height:48px;display:flex}.upload-page .upload-title{color:var(--text);font-size:14px;font-weight:500}.upload-page .upload-sub{color:var(--muted);font-size:12px}.upload-page .upload-file{color:var(--green);font-size:13px;font-weight:500}.upload-page .template-btn{border:1.5px dashed var(--border);cursor:pointer;color:var(--purple);background:#fff;border-radius:11px;justify-content:center;align-items:center;gap:8px;width:100%;padding:10px 14px;font-family:inherit;font-size:13px;font-weight:400;display:flex}.upload-page .template-btn:active{background:var(--purple-light)}.upload-page .map-list{flex-direction:column;gap:10px;display:flex}.upload-page .map-row{align-items:center;gap:8px;display:flex}.upload-page .req-dot{background:var(--red);border-radius:50%;flex-shrink:0;width:6px;height:6px}.upload-page .opt-dot{background:var(--muted);border-radius:50%;flex-shrink:0;width:6px;height:6px}.upload-page .map-label{color:var(--text);flex-shrink:0;min-width:80px;font-size:13px;font-weight:500}.upload-page .map-arrow{color:var(--muted);flex-shrink:0;font-size:13px}.upload-page .map-sel{border:1.5px solid var(--border);color:var(--text);direction:rtl;background:#faf9fe;border-radius:10px;outline:none;flex:1;padding:9px 11px;font-family:inherit;font-size:13px}.upload-page .map-sel:focus{border-color:var(--purple)}.upload-page .legend{color:var(--muted);gap:12px;font-size:11px;display:flex}.upload-page .legend span{align-items:center;gap:4px;display:flex}.upload-page .legend i{border-radius:50%;width:7px;height:7px;display:inline-block}.upload-page .fg{flex-direction:column;gap:5px;display:flex}.upload-page .fl{color:#666;font-size:12px;font-weight:500}.upload-page .fi{border:1.5px solid var(--border);color:var(--text);direction:rtl;background:#faf9fe;border-radius:11px;outline:none;padding:11px 13px;font-family:inherit;font-size:15px;font-weight:500;transition:border .18s}.upload-page .fi:focus{border-color:var(--purple);background:#fff}.upload-page .fi::placeholder{color:#ccc;font-weight:300}.upload-page .subject-hint{color:var(--muted);font-size:11px;line-height:1.6}.upload-page .preview-wrap{border:1px solid var(--border);border-radius:10px;overflow-x:auto}.upload-page .ptable{border-collapse:collapse;width:100%;min-width:320px;font-size:12px}.upload-page .ptable th{background:var(--purple-light);color:var(--purple);text-align:right;border-bottom:1px solid var(--border);white-space:nowrap;padding:8px 12px;font-weight:500}.upload-page .ptable td{border-bottom:1px solid var(--border);color:var(--text);white-space:nowrap;padding:8px 12px}.upload-page .ptable tr:last-child td{border-bottom:none}.upload-page .ptable tr.err td{background:var(--red-bg)}.upload-page .dot-ok{background:var(--green);border-radius:50%;width:7px;height:7px;display:inline-block}.upload-page .dot-err{background:var(--red);border-radius:50%;width:7px;height:7px;display:inline-block}.upload-page .summary{flex-wrap:wrap;gap:7px;display:flex}.upload-page .chip{border-radius:20px;padding:4px 12px;font-size:12px;font-weight:500}.upload-page .chip.t{background:var(--purple-light);color:var(--purple)}.upload-page .chip.ok{background:var(--green-bg);color:var(--green)}.upload-page .chip.err{background:var(--red-bg);color:var(--red)}.upload-page .action-row{gap:8px;display:flex}.upload-page .abtn{cursor:pointer;border:none;border-radius:12px;flex:1;padding:13px;font-family:inherit;font-size:14px;font-weight:500}.upload-page .abtn.p{background:var(--purple);color:#fff}.upload-page .abtn.p:hover:not(:disabled){background:var(--purple-dark)}.upload-page .abtn.s{color:#666;background:#f3f4f6}.upload-page .abtn:disabled{opacity:.4;cursor:not-allowed}.upload-page .done-card{background:var(--green-bg);border:1.5px solid var(--green-b);text-align:center;border-radius:16px;flex-direction:column;align-items:center;gap:8px;padding:28px 20px;display:flex}.upload-page .done-icon{font-size:48px}.upload-page .done-title{color:var(--green);font-size:18px;font-weight:600}.upload-page .done-sub{color:#166534;font-size:13px;line-height:1.7}.upload-page .sheet-tabs{flex-wrap:wrap;gap:6px;display:flex}.upload-page .sheet-tab{cursor:pointer;border:1.5px solid var(--border);color:var(--text);background:#faf9fe;border-radius:10px;padding:7px 16px;font-family:inherit;font-size:12px;font-weight:600;transition:all .15s}.upload-page .sheet-tab:hover{border-color:var(--purple);background:var(--purple-light)}.upload-page .sheet-tab.active{background:var(--purple);color:#fff;border-color:var(--purple)}.upload-page .raw-preview th{background:var(--purple-light);color:var(--purple);white-space:nowrap;padding:5px 8px;font-size:10px}.upload-page .raw-preview td{white-space:nowrap;text-overflow:ellipsis;max-width:160px;padding:4px 8px;font-size:11px;overflow:hidden}.upload-page .toast{color:#fff;z-index:999;white-space:nowrap;background:#1a1020;border-radius:12px;padding:10px 22px;font-size:13px;font-weight:400;animation:.25s toastIn;position:fixed;bottom:28px;left:50%;transform:translate(-50%)}@keyframes toastIn{0%{opacity:0;transform:translate(-50%)translateY(-10px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.classroom-page{--purple:#6b52ae;--purple-dark:#4e3a8a;--purple-light:#f0ecfa;--orange:#f47c20;--bg:#f7f4fd;--card:#fff;--text:#1a1020;--muted:#aaa;--border:#ece6f8;--green:#16a34a;--green-bg:#dcfce7;--red:#dc2626;--red-bg:#fee2e2;--amber:#f59e0b;--amber-bg:#fef3c7;background:var(--bg);direction:rtl;min-height:100vh;padding-bottom:90px;font-family:Rubik,Noto Sans Arabic,sans-serif}.classroom-page .navbar{background:var(--purple);z-index:200;justify-content:space-between;align-items:center;gap:10px;padding:10px 16px;display:flex;position:sticky;top:0;box-shadow:0 2px 10px #6b52ae4d}.classroom-page .back-btn{color:#fff;cursor:pointer;background:#ffffff2e;border:none;border-radius:8px;padding:7px 12px;font-family:inherit;font-size:12px;font-weight:500}.classroom-page .back-btn:hover{background:#ffffff47}.classroom-page .nav-title{color:#fff;text-align:center;flex:1;font-size:14px;font-weight:500}.classroom-page .nav-date{color:#fff;opacity:.9;font-size:12px}.classroom-page .cr-main{flex-direction:column;gap:12px;max-width:820px;margin:0 auto;padding:14px;display:flex}.classroom-page .cr-loading,.classroom-page .cr-error{text-align:center;color:var(--muted);padding:28px;font-size:14px}.classroom-page .cr-error{color:var(--red)}.classroom-page .cr-empty{border:1.5px dashed var(--border);text-align:center;background:#fff;border-radius:16px;flex-direction:column;align-items:center;gap:10px;padding:36px 20px;display:flex}.classroom-page .cr-empty-emoji{font-size:42px}.classroom-page .cr-empty-title{color:var(--text);font-size:16px;font-weight:500}.classroom-page .cr-empty-sub{color:var(--muted);font-size:13px}.classroom-page .cr-empty-small{color:var(--muted);text-align:center;padding:16px;font-size:13px}.classroom-page .cr-picker-header{color:var(--text);align-items:center;gap:8px;margin-bottom:12px;padding:0 2px;font-size:15px;font-weight:600;display:flex}.classroom-page .cr-picker-header svg{color:var(--purple)}.classroom-page .cr-picker-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px;display:grid}@media (width<=600px){.classroom-page .cr-picker-grid{grid-template-columns:1fr}}.classroom-page .cr-picker-card{border:1.5px solid var(--border);cursor:pointer;text-align:right;background:#fff;border-radius:12px;flex-direction:column;padding:0;font-family:inherit;transition:transform .15s,box-shadow .2s,border-color .2s;display:flex;overflow:visible}.classroom-page .cr-picker-card:hover{border-color:#d4cce8;transform:translateY(-2px);box-shadow:0 6px 18px #6b52ae1f}.classroom-page .cr-picker-accent{width:100%;height:3px}.classroom-page .cr-picker-body{flex-direction:column;gap:3px;padding:12px 14px 14px;display:flex}.classroom-page .cr-picker-sub{font-size:11px;font-weight:600}.classroom-page .cr-picker-big{color:var(--text);font-size:14px;font-weight:700}.classroom-page .cr-picker-meta{color:var(--muted);flex-wrap:wrap;align-items:center;gap:6px;margin-top:2px;font-size:11px;display:flex}.classroom-page .cr-picker-date{color:#999;margin-top:2px;font-size:10px;display:block}.classroom-page .cr-picker-color-btn{cursor:pointer;border:2px solid #fff;border-radius:50%;width:20px;height:20px;transition:transform .15s;position:absolute;top:8px;left:8px;box-shadow:0 1px 4px #00000026}.classroom-page .cr-picker-color-btn:hover{transform:scale(1.2)}.classroom-page .cr-picker-card{position:relative}.classroom-page .cr-color-picker{z-index:200;border:1px solid var(--border);background:#fff;border-radius:12px;flex-wrap:wrap;gap:6px;width:148px;padding:10px;display:flex;position:fixed;box-shadow:0 6px 24px #0003}.classroom-page .cr-color-dot{cursor:pointer;border:2px solid #0000;border-radius:50%;width:22px;height:22px;transition:transform .1s}.classroom-page .cr-color-dot:hover{transform:scale(1.15)}.classroom-page .cr-color-dot.active{border-color:#333}.classroom-page .cr-color-overlay{z-index:199;background:0 0;position:fixed;inset:0}.classroom-page .date-nav{border:1px solid var(--border);background:#fff;border-radius:12px;align-items:center;gap:8px;padding:8px 12px;display:flex}.classroom-page .date-arrow{background:var(--purple-light);color:var(--purple);cursor:pointer;border:none;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;font-family:inherit;font-size:16px;font-weight:600;display:flex}.classroom-page .date-arrow:hover:not(:disabled){background:var(--purple);color:#fff}.classroom-page .date-arrow:disabled{opacity:.3;cursor:not-allowed}.classroom-page .date-center{flex-direction:column;flex:1;align-items:center;gap:2px;display:flex}.classroom-page .date-input{color:var(--purple);text-align:center;cursor:pointer;background:0 0;border:none;outline:none;font-family:inherit;font-size:13px;font-weight:500}.classroom-page .date-label{color:var(--muted);font-size:11px;font-weight:400}.classroom-page .date-today{background:var(--purple);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:8px;padding:6px 12px;font-family:inherit;font-size:11px;font-weight:500}.classroom-page .date-today:hover{background:var(--purple-dark)}.classroom-page .period-bar{border:1px solid var(--border);scrollbar-width:none;background:#fff;border-radius:12px;align-items:center;gap:6px;padding:8px 10px;display:flex;overflow-x:auto}.classroom-page .period-bar::-webkit-scrollbar{display:none}.classroom-page .period-pill{border:1.5px solid var(--border);color:var(--text);cursor:pointer;white-space:nowrap;background:#fff;border-radius:10px;flex-shrink:0;align-items:center;gap:5px;padding:7px 14px;font-family:inherit;font-size:12px;font-weight:500;transition:all .15s;display:flex}.classroom-page .period-pill:hover{border-color:var(--purple);color:var(--purple)}.classroom-page .period-pill.active{background:var(--purple);color:#fff;border-color:var(--purple);box-shadow:0 2px 8px #6b52ae40}.classroom-page .period-pill .p-num{background:#00000014;border-radius:6px;justify-content:center;align-items:center;width:20px;height:20px;font-size:11px;font-weight:600;display:flex}.classroom-page .period-pill.active .p-num{background:#ffffff40}.classroom-page .period-pill .p-dot{background:var(--green);border-radius:50%;width:6px;height:6px}.classroom-page .period-pill.active .p-dot{background:#86efac}.classroom-page .period-pill.empty .p-dot{background:var(--border)}.classroom-page .period-add{border:1.5px dashed var(--border);width:34px;height:34px;color:var(--muted);cursor:pointer;background:0 0;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;font-family:inherit;font-size:18px;transition:all .15s;display:flex}.classroom-page .period-add:hover{border-color:var(--purple);color:var(--purple);background:var(--purple-light)}.classroom-page .saved-banner{color:#0369a1;background:#e0f2fe;border:1px solid #7dd3fc;border-radius:10px;align-items:center;gap:8px;padding:8px 14px;font-size:12px;font-weight:500;display:flex}.classroom-page .saved-dot{background:#0ea5e9;border-radius:50%;flex-shrink:0;width:8px;height:8px}.classroom-page .stats-row{border:1.5px solid var(--border);background:#fff;border-radius:14px;grid-template-columns:repeat(6,1fr);gap:6px;padding:10px;display:grid}.classroom-page .stat{text-align:center;padding:4px 2px}.classroom-page .stat-val{font-size:18px;font-weight:600;line-height:1.1}.classroom-page .stat-lbl{color:var(--muted);margin-top:2px;font-size:10px;font-weight:500}.classroom-page .top-actions{flex-wrap:wrap;gap:7px;display:flex}.classroom-page .tact{border:1.5px solid var(--border);color:var(--text);cursor:pointer;background:#fff;border-radius:11px;padding:9px 14px;font-family:inherit;font-size:12px;font-weight:500}.classroom-page .tact:hover{border-color:var(--purple);color:var(--purple)}.classroom-page .tact.on{background:var(--green);border-color:var(--green);color:#fff}.classroom-page .tact.on:hover{color:#fff;background:#15803d;border-color:#15803d}.classroom-page .tact.on.late{background:var(--amber);border-color:var(--amber)}.classroom-page .tact.on.late:hover{background:#d97706;border-color:#d97706}.classroom-page .tact.on.hw{background:#0891b2;border-color:#0891b2}.classroom-page .tact.on.hw:hover{background:#0e7490;border-color:#0e7490}.classroom-page .tact.on.hw-p{background:var(--amber);border-color:var(--amber)}.classroom-page .tact.on.hw-p:hover{background:#d97706;border-color:#d97706}.classroom-page .search{border:1.5px solid var(--border);direction:rtl;background:#fff;border-radius:11px;outline:none;flex:1;min-width:150px;padding:9px 12px;font-family:inherit;font-size:13px}.classroom-page .search:focus{border-color:var(--purple)}.classroom-page .slist{flex-direction:column;gap:8px;display:flex}.classroom-page .scard{border:1px solid var(--border);background:#fff;border-radius:14px;overflow:hidden}.classroom-page .scard.present{border:1px solid var(--green)}.classroom-page .scard.late{border:1px solid var(--amber)}.classroom-page .crow{border-bottom:1px solid var(--border);align-items:center;gap:8px;padding:10px 12px;display:flex}.classroom-page .crow:last-child{border-bottom:none}.classroom-page .crow-pad{padding:7px 12px}.classroom-page .crow-pad-sm{padding:6px 12px}.classroom-page .avatar{background:var(--purple-light);width:34px;height:34px;color:var(--purple);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:12px;font-weight:600;display:flex}.classroom-page .sname{color:var(--text);flex:1;font-size:14px;font-weight:500}.classroom-page .btn-group{align-items:center;gap:4px;display:flex}.classroom-page .btn-group.wrap{flex-wrap:wrap;gap:5px}.classroom-page .mr-auto{margin-right:auto}.classroom-page .ab{border:1.5px solid var(--border);cursor:pointer;color:#666;background:#fff;border-radius:8px;padding:5px 10px;font-family:inherit;font-size:11px;font-weight:500}.classroom-page .ab.present.on{background:var(--green);color:#fff;border-color:var(--green)}.classroom-page .ab.late.on{background:var(--amber);color:#fff;border-color:var(--amber)}.classroom-page .ab.absent.on{background:var(--red);color:#fff;border-color:var(--red)}.classroom-page .stars{gap:2px;display:flex}.classroom-page .star{color:#ddd;cursor:pointer;font-size:22px;line-height:1}.classroom-page .star.on{color:var(--orange)}.classroom-page .hb{border:1.5px solid var(--border);cursor:pointer;color:#666;background:#fff;border-radius:7px;padding:5px 9px;font-family:inherit;font-size:11px;font-weight:500}.classroom-page .hb.done.on{color:#fff;background:#0891b2;border-color:#0891b2}.classroom-page .hb.partial.on{color:#fff;background:#f59e0b;border-color:#f59e0b}.classroom-page .bb{border:1.5px solid var(--border);cursor:pointer;color:#666;background:#fff;border-radius:7px;padding:5px 9px;font-family:inherit;font-size:11px;font-weight:500}.classroom-page .bb.warn.on{background:var(--red);color:#fff;border-color:var(--red)}.classroom-page .bb.excel.on{background:var(--orange);color:#fff;border-color:var(--orange)}.classroom-page .bb.activity.on{background:var(--purple);color:#fff;border-color:var(--purple)}.classroom-page .bb.research.on{color:#fff;background:#0891b2;border-color:#0891b2}.classroom-page .note-ic{cursor:pointer;color:#bbb;background:#f5f3fa;border-radius:7px;justify-content:center;align-items:center;width:28px;height:28px;font-size:14px;display:flex}.classroom-page .note-ic.has{background:var(--purple-light);color:var(--purple)}.classroom-page .note-row{flex-direction:column;gap:6px;padding:8px 12px 12px;display:flex}.classroom-page .note-ta{resize:vertical;border:1.5px solid var(--border);direction:rtl;background:#faf9fe;border-radius:10px;outline:none;width:100%;min-height:54px;padding:8px 10px;font-family:inherit;font-size:13px}.classroom-page .note-ta:focus{border-color:var(--purple)}.classroom-page .note-suggestions{flex-wrap:wrap;gap:5px;display:flex}.classroom-page .note-sug{background:var(--purple-light);color:var(--purple);cursor:pointer;border-radius:14px;padding:4px 10px;font-size:11px;font-weight:400}.classroom-page .note-sug:hover{background:var(--purple);color:#fff}.classroom-page .note-display{color:var(--purple);background:var(--purple-light);cursor:pointer;border-radius:9px;padding:7px 10px;font-size:12px}.classroom-page .save-bar{color:#fff;cursor:pointer;z-index:150;background:var(--purple);border:none;justify-content:center;align-items:center;gap:10px;padding:12px 20px;font-family:inherit;font-size:14px;font-weight:500;transition:background .4s,box-shadow .4s;display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -4px 20px #6b52ae4d}.classroom-page .save-bar:hover{background:var(--purple-dark)}.classroom-page .save-bar:active{opacity:.9}.classroom-page .save-bar.saving{cursor:not-allowed;background:#888}.classroom-page .save-bar.saved{cursor:default;background:#16a34a;box-shadow:0 -4px 20px #16a34a40}.classroom-page .save-bar .save-icon{font-size:18px;line-height:1}@keyframes barPulse{0%,to{opacity:1}50%{opacity:.7}}.classroom-page .save-bar.saving .save-icon{animation:.8s infinite barPulse}.classroom-page .overlay{z-index:500;background:#0006;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.classroom-page .modal{background:#fff;border-radius:18px;flex-direction:column;align-items:center;gap:10px;min-width:240px;max-width:90%;padding:28px 24px;display:flex}.classroom-page .moji{font-size:42px}.classroom-page .mname{color:var(--purple);font-size:20px;font-weight:600}.classroom-page .msub{color:var(--muted);font-size:13px}.classroom-page .abtn.p{background:var(--purple);color:#fff;cursor:pointer;border:none;border-radius:11px;padding:10px 22px;font-family:inherit;font-size:14px;font-weight:500}.classroom-page .toast{color:#fff;z-index:999;white-space:nowrap;background:#1a1020;border-radius:12px;padding:10px 22px;font-size:13px;font-weight:400;animation:.25s toastIn;position:fixed;bottom:86px;left:50%;transform:translate(-50%)}.classroom-page .rand-modal{background:#fff;border-radius:20px;flex-direction:column;gap:14px;width:92%;max-width:380px;max-height:90vh;padding:22px 20px;animation:.25s randIn;display:flex;overflow-y:auto}@keyframes randIn{0%{opacity:0;transform:scale(.92)translateY(12px)}to{opacity:1;transform:scale(1)translateY(0)}}.classroom-page .rand-header{text-align:center}.classroom-page .rand-badge{background:var(--purple-light,#f0ecfa);color:var(--purple);border-radius:20px;padding:5px 14px;font-size:13px;font-weight:700}.classroom-page .rand-profile{flex-direction:column;align-items:center;gap:8px;display:flex}.classroom-page .rand-av{background:var(--purple);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;font-size:20px;font-weight:900;display:flex}.classroom-page .rand-name{color:var(--text,#1a1020);font-size:20px;font-weight:800}.classroom-page .rand-section{flex-direction:column;gap:6px;display:flex}.classroom-page .rand-label{color:var(--muted,#888);font-size:12px;font-weight:700}.classroom-page .rand-stars{justify-content:center;gap:6px;display:flex}.classroom-page .rand-stars .star{cursor:pointer;font-size:28px}.classroom-page .rand-flags{flex-wrap:wrap;justify-content:center;gap:6px;display:flex}.classroom-page .rand-flag{border:1.5px solid var(--border,#ece6f8);cursor:pointer;background:#fff;border-radius:10px;padding:7px 14px;font-family:inherit;font-size:13px;font-weight:600;transition:all .15s}.classroom-page .rand-flag.excel.on{color:#0e7490;background:#cffafe;border-color:#0e7490}.classroom-page .rand-flag.warn.on{color:#dc2626;background:#fee2e2;border-color:#dc2626}.classroom-page .rand-flag.activity.on{border-color:var(--purple);color:var(--purple);background:#f0ecfa}.classroom-page .rand-flag.research.on{color:#1d4ed8;background:#dbeafe;border-color:#1d4ed8}.classroom-page .rand-notes-list{flex-wrap:wrap;gap:5px;display:flex}.classroom-page .rand-note-chip{border:1px solid var(--border,#ece6f8);cursor:pointer;color:var(--text,#1a1020);background:#faf9fe;border-radius:8px;padding:5px 10px;font-size:11px;font-weight:600;transition:all .15s}.classroom-page .rand-note-chip:active{transform:scale(.96)}.classroom-page .rand-note-chip.on{background:var(--purple);color:#fff;border-color:var(--purple)}.classroom-page .rand-note-ta{border:1.5px solid var(--border,#ece6f8);resize:none;direction:rtl;background:#faf9fe;border-radius:10px;outline:none;width:100%;height:50px;padding:10px 12px;font-family:inherit;font-size:13px;transition:border .15s}.classroom-page .rand-note-ta:focus{border-color:var(--purple);background:#fff}.classroom-page .rand-actions{gap:8px;display:flex}.classroom-page .rand-btn{cursor:pointer;border:none;border-radius:12px;flex:1;padding:12px;font-family:inherit;font-size:14px;font-weight:700;transition:all .15s}.classroom-page .rand-btn.next{color:var(--purple);background:#f0ecfa}.classroom-page .rand-btn.next:active{background:#e0d8f4}.classroom-page .rand-btn.done{background:var(--purple);color:#fff}.classroom-page .rand-btn.done:active{background:#4e3a8a}@media (width<=480px){.classroom-page .stats-row{grid-template-columns:repeat(3,1fr)}.classroom-page .stat-val{font-size:16px}.classroom-page .sname{font-size:13px}.classroom-page .star{font-size:20px}.classroom-page .rand-modal{gap:12px;padding:18px 16px}.classroom-page .rand-stars .star{font-size:26px}}.qr-page{--purple:#6b52ae;--purple-dark:#4e3a8a;--purple-light:#f0ecfa;--orange:#f47c20;--bg:#f7f4fd;--card:#fff;--text:#1a1020;--muted:#aaa;--border:#ece6f8;--green:#16a34a;--green-bg:#dcfce7;--red:#dc2626;--red-bg:#fee2e2;background:var(--bg);direction:rtl;min-height:100vh;font-family:Rubik,Noto Sans Arabic,sans-serif}.qr-page .navbar{background:var(--purple);z-index:200;justify-content:space-between;align-items:center;gap:10px;padding:10px 16px;display:flex;position:sticky;top:0;box-shadow:0 2px 10px #6b52ae4d}.qr-page .back-btn{color:#fff;cursor:pointer;background:#ffffff2e;border:none;border-radius:8px;padding:7px 12px;font-family:inherit;font-size:12px;font-weight:500}.qr-page .back-btn:hover{background:#ffffff47}.qr-page .nav-title{color:#fff;text-align:center;flex:1;font-size:14px;font-weight:500}.qr-page .qr-main{flex-direction:column;gap:14px;max-width:820px;margin:0 auto;padding:16px;display:flex}.qr-page .card{border:1.5px solid var(--border);background:#fff;border-radius:16px;flex-direction:column;gap:12px;padding:18px;display:flex}.qr-page .card-title{color:var(--text);font-size:15px;font-weight:500}.qr-page .fg{flex-direction:column;gap:5px;display:flex}.qr-page .fl{color:#666;font-size:12px;font-weight:500}.qr-page .fi{border:1.5px solid var(--border);color:var(--text);direction:rtl;background:#faf9fe;border-radius:11px;outline:none;width:100%;padding:11px 13px;font-family:inherit;font-size:14px}.qr-page .fi:focus{border-color:var(--purple);background:#fff}.qr-page .show-btn{background:var(--purple);color:#fff;cursor:pointer;border:none;border-radius:12px;justify-content:center;align-items:center;gap:8px;width:100%;padding:13px;font-family:inherit;font-size:14px;font-weight:500;display:flex}.qr-page .show-btn:hover:not(:disabled){background:var(--purple-dark)}.qr-page .show-btn:disabled{opacity:.5;cursor:not-allowed}.qr-page .card-sub{color:var(--muted);margin-top:-6px;font-size:12px;line-height:1.6}.qr-page .fi-hint{color:var(--muted);margin-top:-2px;font-size:11px}.qr-page .results-section{flex-direction:column;gap:12px;display:flex}.qr-page .results-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;display:flex}.qr-page .results-label{color:var(--text);font-size:13px;font-weight:500}.qr-page .results-count{color:var(--muted);font-size:12px}.qr-page .pdf-all-btn{background:var(--purple-light);color:var(--purple);border:1.5px solid var(--border);cursor:pointer;border-radius:10px;align-items:center;gap:6px;padding:8px 14px;font-family:inherit;font-size:12px;font-weight:500;display:flex}.qr-page .pdf-all-btn:hover{background:var(--purple);color:#fff;border-color:var(--purple)}.qr-page .qr-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px;display:grid}.qr-page .qr-card{border:1px solid var(--border);background:#fff;border-radius:14px;flex-direction:column;align-items:center;gap:8px;padding:14px 10px;transition:border-color .15s;display:flex}.qr-page .qr-card:hover{border-color:var(--purple)}.qr-page .qr-canvas-wrap{background:var(--bg);border-radius:10px;justify-content:center;align-items:center;width:110px;height:110px;display:flex;overflow:hidden}.qr-page .qr-name{color:var(--text);text-align:center;font-size:11px;font-weight:500;line-height:1.4}.qr-page .qr-meta{color:var(--muted);text-align:center;font-size:10px}.qr-page .qr-dl-btn{background:var(--purple-light);color:var(--purple);cursor:pointer;border:none;border-radius:8px;width:100%;padding:5px 12px;font-family:inherit;font-size:11px;font-weight:500}.qr-page .qr-dl-btn:hover{background:var(--purple);color:#fff}.qr-page .empty{text-align:center;color:var(--muted);padding:40px 20px}.qr-page .empty-icon{opacity:.4;margin-bottom:10px;font-size:40px}.qr-page .empty-txt{font-size:14px;font-weight:400}.qr-page .toast{color:#fff;z-index:999;white-space:nowrap;background:#1a1020;border-radius:12px;padding:10px 22px;font-size:13px;font-weight:400;animation:.25s qrToastIn;position:fixed;bottom:28px;left:50%;transform:translate(-50%)}@keyframes qrToastIn{0%{opacity:0;transform:translate(-50%)translateY(16px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.qr-page .qr-warning{color:#9a3412;background:#fff7ed;border:1.5px solid #fed7aa;border-radius:12px;align-items:flex-start;gap:10px;padding:14px 16px;font-size:13px;display:flex}.qr-page .qr-date-info{background:var(--purple-light);border:1.5px solid var(--border);color:var(--text);border-radius:12px;align-items:center;gap:10px;padding:12px 16px;font-size:13px;display:flex}.qr-page .qr-settings-link{color:var(--purple);cursor:pointer;text-underline-offset:2px;font-weight:500;text-decoration:underline}.qr-page .qr-settings-link:hover{opacity:.7}@media (width<=480px){.qr-page .qr-grid{grid-template-columns:repeat(2,1fr)}}.students-page{--purple:#6b52ae;--purple-dark:#4e3a8a;--purple-light:#f0ecfa;--orange:#f47c20;--bg:#f7f4fd;--card:#fff;--text:#1a1020;--muted:#aaa;--border:#ece6f8;--green:#16a34a;--red:#dc2626;--red-bg:#fee2e2;background:var(--bg);direction:rtl;min-height:100vh;font-family:Rubik,Noto Sans Arabic,sans-serif}.students-page .st-loading{text-align:center;color:var(--muted);padding:40px;font-size:14px}.students-page .navbar{background:var(--purple);z-index:200;justify-content:space-between;align-items:center;gap:10px;padding:10px 16px;display:flex;position:sticky;top:0;box-shadow:0 2px 10px #6b52ae4d}.students-page .back-btn{color:#fff;cursor:pointer;background:#ffffff2e;border:none;border-radius:8px;padding:7px 12px;font-family:inherit;font-size:12px;font-weight:500}.students-page .back-btn:hover{background:#ffffff47}.students-page .nav-title{color:#fff;text-align:center;flex:1;font-size:14px;font-weight:500}.students-page .statsbar{scrollbar-width:none;gap:8px;padding:12px 16px;display:flex;overflow-x:auto}.students-page .statsbar::-webkit-scrollbar{display:none}.students-page .sc{border:1px solid var(--border);text-align:center;background:#fff;border-radius:10px;flex-shrink:0;padding:8px 14px}.students-page .sc-n{color:var(--text);font-size:20px;font-weight:500;line-height:1}.students-page .sc-l{color:var(--muted);margin-top:2px;font-size:10px;font-weight:400}.students-page .sc.p .sc-n{color:var(--purple)}.students-page .filterbar{flex-direction:column;gap:8px;padding:0 16px 10px;display:flex}.students-page .filter-row{scrollbar-width:none;gap:6px;display:flex;overflow-x:auto}.students-page .filter-row::-webkit-scrollbar{display:none}.students-page .fpill{white-space:nowrap;border:1.5px solid var(--border);cursor:pointer;color:var(--text);background:#fff;border-radius:20px;flex-shrink:0;padding:5px 12px;font-family:inherit;font-size:12px;font-weight:400}.students-page .fpill.on{background:var(--purple);color:#fff;border-color:var(--purple)}.students-page .search-row{gap:8px;display:flex}.students-page .search-input{border:1.5px solid var(--border);color:var(--text);direction:rtl;background:#fff;border-radius:11px;outline:none;flex:1;padding:9px 13px;font-family:inherit;font-size:13px}.students-page .search-input:focus{border-color:var(--purple)}.students-page .add-btn{background:var(--purple);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:11px;flex-shrink:0;padding:9px 16px;font-family:inherit;font-size:13px;font-weight:500}.students-page .add-btn:hover{background:var(--purple-dark)}.students-page .slist{flex-direction:column;gap:8px;padding:0 16px 40px;display:flex}.students-page .srow{border:1px solid var(--border);background:#fff;border-radius:13px;align-items:center;gap:10px;padding:12px 14px;display:flex}.students-page .av{background:var(--purple-light);width:40px;height:40px;color:var(--purple);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:13px;font-weight:500;display:flex}.students-page .sinfo{flex:1;min-width:0}.students-page .sname{color:var(--text);text-overflow:ellipsis;white-space:nowrap;font-size:14px;font-weight:500;overflow:hidden}.students-page .smeta{flex-wrap:wrap;align-items:center;gap:6px;margin-top:3px;display:flex}.students-page .stag{white-space:nowrap;border-radius:10px;padding:2px 8px;font-size:10px;font-weight:500}.students-page .stag.subject{background:var(--purple-light);color:var(--purple)}.students-page .stag.class{color:#0369a1;background:#f0f9ff}.students-page .stag.id{color:#6b7280;background:#f9fafb}.students-page .sactions{flex-shrink:0;gap:6px;display:flex}.students-page .ic-btn{border:1px solid var(--border);cursor:pointer;background:#fff;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;font-family:inherit;font-size:14px;display:flex}.students-page .ic-btn.edit{color:var(--purple)}.students-page .ic-btn.edit:hover{background:var(--purple-light)}.students-page .ic-btn.del{color:var(--red)}.students-page .ic-btn.del:hover{background:var(--red-bg)}.students-page .select-btn{border:1.5px solid var(--border);cursor:pointer;width:40px;height:40px;color:var(--purple);background:#fff;border-radius:11px;flex-shrink:0;justify-content:center;align-items:center;font-size:16px;display:flex}.students-page .select-btn:hover{background:var(--purple-light)}.students-page .cancel-sel-btn{color:#666;cursor:pointer;white-space:nowrap;background:#f3f4f6;border:none;border-radius:11px;flex-shrink:0;padding:9px 16px;font-family:inherit;font-size:13px;font-weight:500}.students-page .bulk-bar{background:var(--red-bg);border-radius:12px;align-items:center;gap:10px;margin:0 16px 4px;padding:8px 16px;display:flex}.students-page .bulk-check-all{border:1.5px solid var(--border);cursor:pointer;color:var(--text);background:#fff;border-radius:8px;padding:5px 12px;font-family:inherit;font-size:12px;font-weight:500}.students-page .bulk-count{color:var(--red);flex:1;font-size:13px;font-weight:500}.students-page .bulk-del-btn{background:var(--red);color:#fff;cursor:pointer;border:none;border-radius:10px;padding:7px 16px;font-family:inherit;font-size:13px;font-weight:500}.students-page .bulk-del-btn:disabled{opacity:.4;cursor:default}.students-page .sel-check{border:2px solid var(--border);color:#fff;background:#fff;border-radius:7px;flex-shrink:0;justify-content:center;align-items:center;width:26px;height:26px;font-size:14px;font-weight:600;transition:all .15s;display:flex}.students-page .sel-check.on{background:var(--purple);border-color:var(--purple)}.students-page .srow.sel{background:var(--purple-light);border-color:var(--purple)}.students-page .srow.sel .sel-check{background:var(--purple);border-color:var(--purple)}.students-page .empty{text-align:center;color:var(--muted);padding:48px 20px}.students-page .empty-icon{opacity:.4;margin-bottom:12px;font-size:40px}.students-page .empty-text{font-size:14px;font-weight:400}.students-page .overlay{z-index:500;background:#00000080;justify-content:center;align-items:flex-end;display:flex;position:fixed;inset:0}.students-page .modal{background:#fff;border-radius:20px 20px 0 0;width:100%;max-width:500px;max-height:90vh;padding:20px 20px 32px;animation:.28s ease-out stSlideUp;overflow-y:auto}@keyframes stSlideUp{0%{transform:translateY(100%)}to{transform:none}}.students-page .modal-handle{background:#e5e7eb;border-radius:2px;width:40px;height:4px;margin:0 auto 16px}.students-page .modal-title{color:var(--text);text-align:center;margin-bottom:18px;font-size:17px;font-weight:500}.students-page .fg{margin-bottom:14px}.students-page .fl{color:#666;margin-bottom:5px;font-size:12px;font-weight:500;display:block}.students-page .fi{border:1.5px solid var(--border);width:100%;color:var(--text);direction:rtl;background:#faf9fe;border-radius:11px;outline:none;padding:11px 13px;font-family:inherit;font-size:14px}.students-page .fi:focus{border-color:var(--purple);background:#fff}.students-page .fi-hint{color:var(--muted);margin-top:5px;font-size:11px;line-height:1.5}.students-page .modal-actions{gap:8px;margin-top:6px;display:flex}.students-page .mbtn{cursor:pointer;border:none;border-radius:12px;flex:1;padding:13px;font-family:inherit;font-size:14px;font-weight:500}.students-page .mbtn.primary{background:var(--purple);color:#fff}.students-page .mbtn.primary:hover{background:var(--purple-dark)}.students-page .mbtn.sec{color:#666;background:#f3f4f6}.students-page .del-modal{text-align:center;background:#fff;border-radius:18px;width:100%;max-width:300px;margin:auto;padding:24px}.students-page .del-icon{margin-bottom:10px;font-size:36px}.students-page .del-name{color:var(--text);margin-bottom:4px;font-size:15px;font-weight:500}.students-page .del-sub{color:var(--muted);margin-bottom:18px;font-size:12px;line-height:1.6}.students-page .keep-toggle{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:8px;margin-bottom:14px;display:flex}.students-page .keep-check{border:2px solid var(--border);color:#fff;background:#fff;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;font-size:13px;font-weight:600;transition:all .15s;display:flex}.students-page .keep-check.on{background:var(--green);border-color:var(--green)}.students-page .keep-toggle span{color:var(--text);font-size:12px;font-weight:400;line-height:1.4}.students-page .del-actions{gap:8px;display:flex}.students-page .dbtn{cursor:pointer;border:none;border-radius:11px;flex:1;padding:12px;font-family:inherit;font-size:13px;font-weight:500}.students-page .dbtn.confirm{background:var(--red-bg);color:var(--red)}.students-page .dbtn.cancel{color:#666;background:#f3f4f6}.students-page .toast{color:#fff;z-index:999;white-space:nowrap;background:#1a1020;border-radius:12px;padding:10px 22px;font-size:13px;font-weight:400;animation:.25s stToastIn;position:fixed;bottom:28px;left:50%;transform:translate(-50%)}@keyframes stToastIn{0%{opacity:0;transform:translate(-50%)translateY(16px)}to{opacity:1;transform:translate(-50%)translateY(0)}}@media (width<=480px){.students-page .srow{gap:8px;padding:10px 12px}.students-page .av{width:34px;height:34px;font-size:11px}.students-page .sname{font-size:13px}}.report-page{--purple:#6b52ae;--purple-light:#f0ecfa;--orange:#f47c20;--bg:#f7f4fd;--text:#1a1020;--muted:#aaa;--border:#ece6f8;background:var(--bg);direction:rtl;min-height:100vh;padding-bottom:40px;font-family:Rubik,Noto Sans Arabic,sans-serif}.report-page .rp-loading,.report-page .rp-error{text-align:center;color:var(--muted);padding:40px;font-size:15px}.report-page .rp-error{color:#dc2626}.report-page .rp-header{background:var(--purple);justify-content:space-between;align-items:center;padding:18px 16px;display:flex;box-shadow:0 2px 10px #6b52ae4d}.report-page .rp-logo-img{border-radius:10px;width:auto;height:36px}.report-page .rp-school{color:#ffffffd9;font-size:12px;font-weight:400}.report-page .rp-card{border:1px solid var(--border);background:#fff;border-radius:16px;flex-direction:column;gap:10px;margin:12px 16px 0;padding:18px;display:flex}.report-page .rp-card-title{color:var(--purple);font-size:14px;font-weight:500}.report-page .rp-name{color:var(--text);font-size:20px;font-weight:600}.report-page .rp-meta{color:var(--muted);font-size:12px}.report-page .rp-enr{flex-wrap:wrap;gap:6px;display:flex}.report-page .rp-tag{background:var(--purple-light);color:var(--purple);border-radius:12px;padding:4px 10px;font-size:11px;font-weight:500}.report-page .rp-date-range{color:var(--purple);background:var(--purple-light);border-radius:8px;width:fit-content;padding:5px 10px;font-size:11px;font-weight:500}.report-page .rp-bar-wrap{align-items:center;gap:10px;display:flex}.report-page .rp-bar{background:#f0f0f0;border-radius:10px;flex:1;height:14px;display:flex;overflow:hidden}.report-page .rp-seg{min-width:4px;transition:flex .3s}.report-page .rp-seg.green{background:#16a34a}.report-page .rp-seg.amber{background:#f59e0b}.report-page .rp-seg.red{background:#dc2626}.report-page .rp-bar-pct{color:var(--purple);text-align:center;min-width:40px;font-size:16px;font-weight:600}.report-page .rp-stats-row{flex-wrap:wrap;gap:8px;display:flex}.report-page .rp-stat{text-align:center;background:var(--bg);border-radius:10px;flex:1;min-width:70px;padding:8px 4px}.report-page .rp-stat-val{font-size:20px;font-weight:600;line-height:1.2}.report-page .rp-stat-lbl{color:var(--muted);margin-top:2px;font-size:10px;font-weight:500}.report-page .rp-stat-stars{color:var(--orange);letter-spacing:2px;font-size:20px}.report-page .rp-empty{text-align:center;color:var(--muted);align-items:center;font-size:14px}.report-page .rp-empty-icon{opacity:.5;font-size:36px}.report-page .rp-notes-list{flex-direction:column;gap:8px;display:flex}.report-page .rp-note-item{background:var(--bg);border-radius:10px;padding:10px 12px}.report-page .rp-note-date{color:var(--muted);margin-bottom:3px;font-size:10px}.report-page .rp-note-text{color:var(--text);font-size:13px;font-weight:400;line-height:1.6}.report-page .rp-log{flex-direction:column;gap:6px;display:flex}.report-page .rp-log-row{background:var(--bg);border-radius:8px;flex-wrap:wrap;align-items:center;gap:6px;padding:8px 10px;font-size:11px;display:flex}.report-page .rp-log-date{color:var(--muted);min-width:75px;font-weight:400}.report-page .rp-log-subj{color:var(--text);min-width:50px;font-weight:500}.report-page .rp-log-stars{color:var(--orange);letter-spacing:1px;font-size:13px}.report-page .rp-pill{border-radius:8px;padding:2px 8px;font-size:10px;font-weight:500}.report-page .rp-pill.green{color:#16a34a;background:#dcfce7}.report-page .rp-pill.amber{color:#d97706;background:#fef3c7}.report-page .rp-pill.red{color:#dc2626;background:#fee2e2}.report-page .rp-pill.cyan{color:#0891b2;background:#cffafe}.report-page .rp-footer{text-align:center;color:var(--muted);padding:20px;font-size:11px;font-weight:400}@media (width<=480px){.report-page .rp-stats-row{gap:4px}.report-page .rp-stat{min-width:60px;padding:6px 2px}.report-page .rp-stat-val{font-size:16px}}.st-page{direction:rtl;background:#f7f4fd;min-height:100vh;font-family:Rubik,Noto Sans Arabic,sans-serif}.st-navbar{z-index:200;background:#6b52ae;justify-content:space-between;align-items:center;padding:10px 16px;display:flex;position:sticky;top:0;box-shadow:0 2px 10px #6b52ae4d}.st-back{cursor:pointer;background:#ffffff26;border:none;border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.st-back:active{background:#ffffff40}.st-nav-title{color:#fff;font-size:15px;font-weight:500}.st-content{flex-direction:column;gap:14px;max-width:600px;margin:0 auto;padding:16px 16px 40px;display:flex}.st-profile-header{color:#fff;background:#6b52ae;border-radius:16px;align-items:center;gap:14px;padding:20px;display:flex}.st-profile-av{background:#fff3;border:2px solid #ffffff4d;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:60px;height:60px;font-size:20px;font-weight:600;display:flex}.st-profile-name{font-size:17px;font-weight:600;line-height:1.3}.st-profile-meta{opacity:.8;margin-top:3px;font-size:12px}.st-tabs-bar{background:#fff;border:1.5px solid #ece6f8;border-radius:14px;gap:4px;padding:4px;display:flex}.st-tab-btn{cursor:pointer;color:#aaa;background:0 0;border:none;border-radius:10px;flex:1;justify-content:center;align-items:center;gap:6px;padding:10px 8px;font-family:Rubik,Noto Sans Arabic,sans-serif;font-size:13px;font-weight:500;transition:all .2s;display:flex}.st-tab-btn.active{color:#fff;background:#6b52ae}.st-tab-content{flex-direction:column;gap:14px;display:flex}.st-card{background:#fff;border:1.5px solid #ece6f8;border-radius:16px;overflow:hidden}.st-card-header{border-bottom:1px solid #ece6f8;align-items:center;gap:10px;padding:14px 18px;display:flex}.st-card-icon{border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.st-card-icon.purple{background:#f0ecfa}.st-card-icon.green{background:#dcfce7}.st-card-icon.red{background:#fee2e2}.st-card-icon.orange{background:#fff7ed}.st-card-title{color:#1a1020;font-size:14px;font-weight:500}.st-card-body{flex-direction:column;gap:12px;padding:14px 18px;display:flex}.st-fg{flex-direction:column;gap:5px;display:flex}.st-fl{color:#666;font-size:12px;font-weight:500}.st-fi{color:#1a1020;box-sizing:border-box;direction:rtl;background:#faf9fe;border:1.5px solid #ece6f8;border-radius:11px;outline:none;width:100%;padding:11px 13px;font-family:Rubik,Noto Sans Arabic,sans-serif;font-size:14px;transition:border .18s}.st-fi:focus{background:#fff;border-color:#6b52ae}.st-fi::placeholder{color:#ccc}.st-fi:disabled{color:#aaa;cursor:not-allowed;background:#f5f5f5}.st-row2{grid-template-columns:1fr 1fr;gap:10px;display:grid}.st-hint{color:#aaa;margin-top:3px;font-size:11px}.st-pw-strength{background:#ece6f8;border-radius:2px;height:4px;margin-top:5px;overflow:hidden}.st-pw-bar{border-radius:2px;width:0;height:100%;transition:width .3s,background .3s}.st-pw-hint{color:#aaa;margin-top:4px;font-size:11px}.st-save-btn{color:#fff;cursor:pointer;background:#6b52ae;border:none;border-radius:12px;justify-content:center;align-items:center;width:100%;padding:13px;font-family:Rubik,Noto Sans Arabic,sans-serif;font-size:14px;font-weight:500;transition:background .2s;display:flex}.st-save-btn:active{background:#4e3a8a}.st-save-btn:disabled{opacity:.6;cursor:not-allowed}.st-save-btn.green{background:#16a34a}.st-save-btn.green:active{background:#15803d}.st-danger-row{border-top:1px solid #ece6f8;justify-content:space-between;align-items:center;gap:12px;padding:14px 18px;display:flex}.st-danger-row:first-child{border-top:none}.st-danger-label{color:#1a1020;font-size:13px;font-weight:500}.st-danger-sub{color:#aaa;margin-top:2px;font-size:11px}.st-danger-btn{color:#dc2626;cursor:pointer;white-space:nowrap;background:#fee2e2;border:1.5px solid #fca5a5;border-radius:10px;flex-shrink:0;padding:8px 16px;font-family:Rubik,Noto Sans Arabic,sans-serif;font-size:12px;font-weight:500}.st-logout-btn{color:#555;cursor:pointer;white-space:nowrap;background:#f3f4f6;border:1.5px solid #ece6f8;border-radius:10px;flex-shrink:0;padding:8px 16px;font-family:Rubik,Noto Sans Arabic,sans-serif;font-size:12px;font-weight:500}.st-notes-group{background:#fff;border:1.5px solid #ece6f8;border-radius:16px;overflow:hidden}.st-notes-group-header{background:#f7f4fd;border-bottom:1px solid #ece6f8;justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.st-notes-group-title{color:#1a1020;font-size:13px;font-weight:500}.st-notes-group-count{color:#aaa;font-size:11px;font-weight:400}.st-cat-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.st-note-item{border-bottom:1px solid #ece6f8;align-items:center;gap:10px;padding:11px 16px;display:flex}.st-note-item:last-child{border-bottom:none}.st-note-text{color:#1a1020;flex:1;font-size:13px;font-weight:400}.st-note-del{cursor:pointer;background:#fee2e2;border:1.5px solid #fca5a5;border-radius:7px;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;display:flex}.st-note-del:active{background:#fecaca}.st-notes-empty{text-align:center;color:#aaa;padding:20px;font-size:13px}.st-version{text-align:center;color:#aaa;padding:8px;font-size:11px}.st-toast{color:#fff;z-index:999;opacity:0;white-space:nowrap;background:#1a1020;border-radius:12px;padding:10px 22px;font-family:Rubik,Noto Sans Arabic,sans-serif;font-size:13px;font-weight:400;transition:all .25s;position:fixed;bottom:28px;left:50%;transform:translate(-50%)translateY(16px)}.st-toast.show{opacity:1;transform:translate(-50%)translateY(0)}.rpt-page{direction:rtl;background:#f7f4fd;min-height:100vh;font-family:Rubik,Noto Sans Arabic,sans-serif}.rpt-navbar{z-index:200;background:#6b52ae;justify-content:space-between;align-items:center;padding:10px 16px;display:flex;position:sticky;top:0;box-shadow:0 2px 10px #6b52ae4d}.rpt-back{cursor:pointer;background:#ffffff26;border:none;border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.rpt-back:active{background:#ffffff40}.rpt-nav-title{color:#fff;font-size:15px;font-weight:500}.rpt-content{flex-direction:column;gap:14px;max-width:820px;margin:0 auto;padding:16px 16px 40px;display:flex}.rpt-card{background:#fff;border:1.5px solid #ece6f8;border-radius:16px;flex-direction:column;gap:13px;padding:18px;display:flex}.rpt-card-title{color:#1a1020;font-size:15px;font-weight:500}.rpt-fg{flex-direction:column;gap:5px;display:flex}.rpt-fl{color:#666;font-size:12px;font-weight:500}.rpt-fi{color:#1a1020;box-sizing:border-box;direction:rtl;background:#faf9fe;border:1.5px solid #ece6f8;border-radius:11px;outline:none;width:100%;padding:11px 13px;font-family:Rubik,Noto Sans Arabic,sans-serif;font-size:14px;transition:border .18s}.rpt-fi:focus{background:#fff;border-color:#6b52ae}.rpt-date-row{grid-template-columns:1fr 1fr;gap:10px;display:grid}.rpt-date-row .rpt-fi[type=date]{text-align:right;direction:ltr}.rpt-preview-btn{color:#fff;cursor:pointer;background:#6b52ae;border:none;border-radius:12px;justify-content:center;align-items:center;gap:8px;width:100%;padding:13px;font-family:Rubik,Noto Sans Arabic,sans-serif;font-size:14px;font-weight:500;transition:background .2s;display:flex}.rpt-preview-btn:active{background:#4e3a8a}.rpt-preview-btn:disabled{opacity:.5;cursor:not-allowed}.rpt-results{flex-direction:column;gap:14px;display:flex}.rpt-stats-grid{grid-template-columns:1fr 1fr 1fr;gap:8px;display:grid}.rpt-stat{text-align:center;background:#f7f4fd;border:1px solid #ece6f8;border-radius:12px;padding:12px 8px}.rpt-stat-num{font-size:22px;font-weight:600;line-height:1}.rpt-stat-lbl{color:#aaa;margin-top:3px;font-size:11px;font-weight:400}.rpt-stat.p .rpt-stat-num{color:#6b52ae}.rpt-stat.g .rpt-stat-num{color:#16a34a}.rpt-stat.r .rpt-stat-num{color:#dc2626}.rpt-stat.y .rpt-stat-num{color:#b45309}.rpt-stat.o .rpt-stat-num{color:#f47c20}.rpt-stat.t .rpt-stat-num{color:#0e7490}.rpt-tbl-wrap{border:1px solid #ece6f8;border-radius:10px;overflow-x:auto}.rpt-tbl{border-collapse:collapse;width:100%;min-width:400px;font-size:12px}.rpt-tbl th{color:#6b52ae;text-align:right;white-space:nowrap;background:#f0ecfa;border-bottom:1px solid #ece6f8;padding:9px 10px;font-weight:500}.rpt-tbl td{color:#1a1020;white-space:nowrap;border-bottom:1px solid #ece6f8;padding:9px 10px}.rpt-tbl tr:last-child td{border-bottom:none}.rpt-tbl tr:nth-child(2n) td{background:#faf9fe}.rpt-badge{border-radius:10px;padding:2px 9px;font-size:11px;font-weight:500;display:inline-block}.rpt-badge.present{color:#16a34a;background:#dcfce7}.rpt-badge.late{color:#b45309;background:#fef9c3}.rpt-badge.absent{color:#dc2626;background:#fee2e2}.rpt-stars-cell{color:#f59e0b;letter-spacing:1px;font-size:13px}.rpt-hw-yes{color:#16a34a;font-weight:500}.rpt-hw-no{color:#dc2626;font-weight:500}.rpt-export-btns{flex-direction:column;gap:10px;display:flex}.rpt-ebtn{cursor:pointer;border:none;border-radius:12px;justify-content:center;align-items:center;gap:8px;width:100%;padding:13px;font-family:Rubik,Noto Sans Arabic,sans-serif;font-size:14px;font-weight:500;transition:all .2s;display:flex}.rpt-ebtn.pdf{color:#dc2626;background:#fee2e2;border:1.5px solid #fca5a5}.rpt-ebtn.pdf:active{background:#fecaca}.rpt-ebtn.link{color:#6b52ae;background:#f0ecfa;border:1.5px solid #c4b5fd}.rpt-ebtn.link:active{background:#e0d9f7}.rpt-or-divider{color:#aaa;align-items:center;gap:10px;font-size:12px;display:flex}.rpt-or-divider:before,.rpt-or-divider:after{content:"";background:#ece6f8;flex:1;height:1px}.rpt-toast{color:#fff;z-index:999;opacity:0;white-space:nowrap;background:#1a1020;border-radius:12px;padding:10px 22px;font-family:Rubik,Noto Sans Arabic,sans-serif;font-size:13px;font-weight:400;transition:all .25s;position:fixed;bottom:28px;left:50%;transform:translate(-50%)translateY(16px)}.rpt-toast.show{opacity:1;transform:translate(-50%)translateY(0)}.srp-page{--purple:#6b52ae;--purple-dark:#4e3a8a;--purple-light:#f0ecfa;--orange:#f47c20;--bg:#f7f4fd;--card:#fff;--text:#1a1020;--muted:#aaa;--border:#ece6f8;--green:#16a34a;--green-bg:#dcfce7;--green-b:#86efac;--red:#dc2626;--red-bg:#fee2e2;--red-b:#fca5a5;--yellow:#b45309;--yellow-bg:#fef9c3;--yellow-b:#fde047;--teal:#0e7490;--teal-bg:#cffafe;background:var(--bg);direction:rtl;min-height:100vh;font-family:Rubik,Noto Sans Arabic,sans-serif}.srp-navbar{background:var(--purple);z-index:100;justify-content:space-between;align-items:center;padding:10px 16px;display:flex;position:sticky;top:0;box-shadow:0 2px 10px #6b52ae4d}.srp-back{cursor:pointer;background:#ffffff26;border:none;border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.srp-nav-title{color:#fff;font-size:14px;font-weight:700}.srp-content{flex-direction:column;gap:14px;padding:16px 16px 40px;display:flex}.srp-card{border:1.5px solid var(--border);background:#fff;border-radius:16px;flex-direction:column;gap:13px;padding:18px;display:flex}.srp-card-title{color:var(--text);font-size:15px;font-weight:800}.srp-fg{flex-direction:column;gap:5px;display:flex}.srp-fl{color:#666;font-size:12px;font-weight:700}.srp-fi{border:1.5px solid var(--border);color:var(--text);direction:rtl;background:#faf9fe;border-radius:11px;outline:none;width:100%;padding:11px 13px;font-family:Rubik,Noto Sans Arabic,sans-serif;font-size:14px;transition:border .18s}.srp-fi:focus{border-color:var(--purple);background:#fff}.srp-date-row{grid-template-columns:1fr 1fr;gap:10px;display:grid}.srp-date-row .srp-fi[type=date]{text-align:right;direction:ltr}.srp-action-btn{background:var(--purple);color:#fff;cursor:pointer;border:none;border-radius:12px;justify-content:center;align-items:center;gap:8px;width:100%;padding:13px;font-family:Rubik,Noto Sans Arabic,sans-serif;font-size:14px;font-weight:700;display:flex}.srp-action-btn:active{background:var(--purple-dark)}.srp-action-btn:disabled{opacity:.6;cursor:not-allowed}.srp-output{flex-direction:column;gap:14px;display:flex}.srp-profile{background:var(--purple);color:#fff;border-radius:16px;align-items:center;gap:14px;padding:18px;display:flex}.srp-profile-av{background:#fff3;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:52px;height:52px;font-size:18px;font-weight:900;display:flex}.srp-profile-name{font-size:16px;font-weight:900;line-height:1.3}.srp-profile-meta{opacity:.8;margin-top:3px;font-size:12px}.srp-stats-grid{grid-template-columns:repeat(3,1fr);gap:8px;display:grid}.srp-sbox{background:var(--bg);text-align:center;border:1px solid var(--border);border-radius:12px;padding:11px 8px}.srp-sbox-n{font-size:20px;font-weight:900;line-height:1}.srp-sbox-l{color:var(--muted);margin-top:3px;font-size:10px;font-weight:600}.srp-sbox.g .srp-sbox-n{color:var(--green)}.srp-sbox.r .srp-sbox-n{color:var(--red)}.srp-sbox.y .srp-sbox-n{color:var(--yellow)}.srp-sbox.p .srp-sbox-n{color:var(--purple)}.srp-sbox.t .srp-sbox-n{color:var(--teal)}.srp-sbox.o .srp-sbox-n{color:var(--orange)}.srp-table-wrap{margin:0 -4px;overflow-x:auto}.srp-table{border-collapse:separate;border-spacing:0;white-space:nowrap;width:100%;font-size:12px}.srp-table thead th{background:var(--purple);color:#fff;text-align:center;padding:9px 10px;font-size:11px;font-weight:700;position:sticky;top:0}.srp-table thead th:first-child{border-radius:0 10px 0 0}.srp-table thead th:last-child{border-radius:10px 0 0}.srp-table tbody td{text-align:center;border-bottom:1px solid var(--border);color:var(--text);vertical-align:middle;padding:8px 10px;font-weight:600}.srp-table tbody tr:last-child td{border-bottom:none}.srp-tr-absent{background:var(--red-bg)}.srp-tr-absent td{color:var(--red);opacity:.8}.srp-tr-late{background:var(--yellow-bg)}.srp-tr-present:nth-child(2n){background:#faf9fe}.srp-td-date{color:var(--muted);font-size:11px;font-weight:700}.srp-td-day{font-weight:800}.srp-td-period{color:var(--purple);font-weight:700}.srp-td-stars{white-space:nowrap}.srp-td-beh{flex-wrap:wrap;justify-content:center;gap:4px;display:flex}.srp-td-notes{white-space:normal;max-width:140px;color:var(--muted);text-align:start;font-size:11px;font-style:italic}.srp-att-badge{border-radius:8px;padding:3px 8px;font-size:10px;font-weight:700;display:inline-block}.srp-att-badge.att-present{background:var(--green-bg);color:var(--green)}.srp-att-badge.att-late{background:var(--yellow-bg);color:var(--yellow)}.srp-att-badge.att-absent{background:var(--red-bg);color:var(--red)}.srp-stars-sm{color:#f59e0b;letter-spacing:-1px;font-size:12px}.srp-stars-sm .off{color:#e5e7eb}.srp-tag-sm{border-radius:6px;padding:2px 7px;font-size:10px;font-weight:700;display:inline-block}.tag-hw-done{background:var(--green-bg);color:var(--green)}.tag-hw-partial{background:var(--yellow-bg);color:var(--yellow)}.tag-hw-miss,.tag-warn{background:var(--red-bg);color:var(--red)}.tag-excel{background:var(--teal-bg);color:var(--teal)}.tag-activity{background:var(--purple-light);color:var(--purple)}.tag-research{color:#1d4ed8;background:#dbeafe}.srp-note-hint{color:var(--muted);margin-top:-8px;font-size:12px}.srp-note-area{border:1.5px solid var(--border);resize:none;width:100%;color:var(--text);direction:rtl;background:#faf9fe;border-radius:11px;outline:none;height:80px;padding:11px 13px;font-family:Rubik,Noto Sans Arabic,sans-serif;font-size:13px;transition:border .18s,height .2s}.srp-note-area:focus{border-color:var(--purple);background:#fff;height:110px}.srp-note-area::placeholder{color:#ccc}.srp-export-btns{flex-direction:column;gap:10px;display:flex}.srp-ebtn{cursor:pointer;border:none;border-radius:12px;justify-content:center;align-items:center;gap:8px;width:100%;padding:13px;font-family:Rubik,Noto Sans Arabic,sans-serif;font-size:14px;font-weight:700;display:flex}.srp-ebtn.pdf{background:var(--red-bg);color:var(--red);border:1.5px solid var(--red-b)}.srp-ebtn.link{background:var(--purple-light);color:var(--purple);border:1.5px solid #c4b5fd}.srp-or-div{color:var(--muted);align-items:center;gap:10px;font-size:12px;display:flex}.srp-or-div:before,.srp-or-div:after{content:"";background:var(--border);flex:1;height:1px}.srp-toast{color:#fff;z-index:999;opacity:0;white-space:nowrap;pointer-events:none;background:#1a1020;border-radius:12px;padding:10px 22px;font-size:13px;font-weight:600;transition:all .25s;position:fixed;bottom:28px;left:50%;transform:translate(-50%)translateY(16px)}.srp-toast.show{opacity:1;transform:translate(-50%)translateY(0)}@media (width<=480px){.srp-stats-grid{gap:4px}.srp-sbox{padding:8px 4px}.srp-sbox-n{font-size:16px}.srp-table{font-size:11px}.srp-table thead th{padding:7px 6px;font-size:10px}.srp-table tbody td{padding:6px}.srp-td-notes{max-width:100px}}.rec-page{--purple:#6b52ae;--purple-dark:#4e3a8a;--purple-light:#f0ecfa;--orange:#f47c20;--bg:#f7f4fd;--card:#fff;--text:#1a1020;--muted:#aaa;--border:#ece6f8;--green:#16a34a;--green-bg:#dcfce7;--red:#dc2626;--red-bg:#fee2e2;--yellow:#b45309;--yellow-bg:#fef9c3;background:var(--bg);direction:rtl;min-height:100vh;font-family:Rubik,Noto Sans Arabic,sans-serif}.rec-navbar{background:var(--purple);z-index:100;justify-content:space-between;align-items:center;padding:10px 16px;display:flex;position:sticky;top:0;box-shadow:0 2px 10px #6b52ae4d}.rec-back{cursor:pointer;background:#ffffff26;border:none;border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.rec-nav-title{color:#fff;font-size:14px;font-weight:700}.rec-content{flex-direction:column;gap:14px;max-width:900px;margin:0 auto;padding:16px 16px 40px;display:flex}.rec-card{border:1.5px solid var(--border);background:#fff;border-radius:16px;flex-direction:column;gap:13px;padding:18px;display:flex}.rec-card-title{color:var(--text);font-size:15px;font-weight:800}.rec-fg{flex-direction:column;gap:5px;display:flex}.rec-fl{color:#666;font-size:12px;font-weight:700}.rec-fi{border:1.5px solid var(--border);color:var(--text);direction:rtl;background:#faf9fe;border-radius:11px;outline:none;width:100%;padding:10px 12px;font-family:inherit;font-size:13px;transition:border .18s}.rec-fi:focus{border-color:var(--purple);background:#fff}.rec-row2{grid-template-columns:1fr 1fr;gap:10px;display:grid}.rec-fi[type=date]{text-align:right;direction:ltr}.rec-toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;display:flex}.rec-count{color:var(--muted);font-size:13px;font-weight:700}.rec-count b{color:var(--purple)}.rec-del-btn{background:var(--red-bg);color:var(--red);cursor:pointer;border:none;border-radius:10px;align-items:center;gap:5px;padding:8px 16px;font-family:inherit;font-size:13px;font-weight:700;display:flex}.rec-del-btn:disabled{opacity:.4;cursor:not-allowed}.rec-del-btn:not(:disabled):active{background:#fca5a5}.rec-table-wrap{margin:0 -4px;overflow-x:auto}.rec-table{border-collapse:separate;border-spacing:0;white-space:nowrap;width:100%;font-size:12px}.rec-table thead th{background:var(--purple);color:#fff;text-align:center;padding:9px 8px;font-size:11px;font-weight:700;position:sticky;top:0}.rec-table thead th:first-child{border-radius:0 10px 0 0}.rec-table thead th:last-child{border-radius:10px 0 0}.rec-table tbody td{text-align:center;border-bottom:1px solid var(--border);color:var(--text);vertical-align:middle;padding:8px;font-weight:600}.rec-table tbody tr:last-child td{border-bottom:none}.rec-tr-absent{background:var(--red-bg)}.rec-tr-absent td{color:var(--red)}.rec-tr-late{background:var(--yellow-bg)}.rec-tr-present:nth-child(2n){background:#faf9fe}.rec-table .rec-check{border:1.5px solid var(--border);cursor:pointer;color:#fff;background:#fff;border-radius:5px;justify-content:center;align-items:center;width:18px;height:18px;font-size:11px;transition:all .15s;display:inline-flex}.rec-table .rec-check.on{background:var(--purple);border-color:var(--purple)}.rec-th-check{cursor:pointer}.rec-td-name{text-align:start!important;font-weight:700!important}.rec-td-group{color:var(--muted);font-size:11px}.rec-td-stars{color:#f59e0b;letter-spacing:-1px;font-size:12px}.rec-td-stars .off{color:#e5e7eb}.rec-att{border-radius:8px;padding:2px 8px;font-size:10px;font-weight:700;display:inline-block}.rec-att.present{background:var(--green-bg);color:var(--green)}.rec-att.late{background:var(--yellow-bg);color:var(--yellow)}.rec-att.absent{background:var(--red-bg);color:var(--red)}.rec-hw{border-radius:6px;padding:2px 7px;font-size:10px;font-weight:700}.rec-hw-done{background:var(--green-bg);color:var(--green)}.rec-hw-partial{background:var(--yellow-bg);color:var(--yellow)}.rec-hw-miss{background:var(--red-bg);color:var(--red)}.rec-paging{justify-content:center;align-items:center;gap:6px;display:flex}.rec-pg-btn{border:1.5px solid var(--border);cursor:pointer;color:var(--text);background:#fff;border-radius:9px;padding:7px 14px;font-family:inherit;font-size:13px;font-weight:700;transition:all .15s}.rec-pg-btn.on{background:var(--purple);color:#fff;border-color:var(--purple)}.rec-pg-btn:disabled{opacity:.4;cursor:not-allowed}.rec-pg-info{color:var(--muted);font-size:12px;font-weight:600}.rec-empty{text-align:center;color:var(--muted);padding:40px 0}.rec-empty-icon{margin-bottom:8px;font-size:40px}.rec-empty-text{font-size:14px;font-weight:600}.rec-loading{text-align:center;color:var(--muted);padding:40px 0;font-size:14px}.rec-overlay{z-index:500;background:#0006;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.rec-del-modal{background:#fff;border-radius:18px;flex-direction:column;align-items:center;gap:12px;min-width:260px;max-width:90%;padding:28px 24px;display:flex}.rec-del-icon{font-size:40px}.rec-del-title{color:var(--text);font-size:16px;font-weight:800}.rec-del-sub{color:var(--muted);text-align:center;font-size:13px;line-height:1.6}.rec-del-actions{gap:8px;width:100%;display:flex}.rec-del-actions button{cursor:pointer;border:none;border-radius:11px;flex:1;padding:11px;font-family:inherit;font-size:14px;font-weight:700}.rec-del-actions .confirm{background:var(--red);color:#fff}.rec-del-actions .cancel{color:var(--text);background:#f5f3fa}.rec-toast{color:#fff;z-index:999;opacity:0;white-space:nowrap;pointer-events:none;background:#1a1020;border-radius:12px;padding:10px 22px;font-size:13px;font-weight:600;transition:all .25s;position:fixed;bottom:28px;left:50%;transform:translate(-50%)translateY(16px)}.rec-toast.show{opacity:1;transform:translate(-50%)translateY(0)}@media (width<=480px){.rec-table{font-size:11px}.rec-table thead th{padding:7px 5px;font-size:10px}.rec-table tbody td{padding:6px 5px}}.admin-page{direction:rtl;background:#f5f3fa;min-height:100vh;padding:0 0 40px;font-family:Segoe UI,Tahoma,sans-serif}.admin-toast{z-index:999;color:#fff;background:#1a1020;border-radius:10px;padding:10px 28px;font-size:14px;font-weight:600;animation:.3s toastIn;position:fixed;top:20px;left:50%;transform:translate(-50%);box-shadow:0 4px 20px #0003}.admin-header{background:#fff;border-bottom:1.5px solid #ece6f8;justify-content:space-between;align-items:center;padding:16px 24px;display:flex}.admin-header-right{align-items:center;gap:12px;display:flex}.admin-title{color:#1a1020;font-size:18px;font-weight:800}.admin-subtitle{color:#888;margin-top:2px;font-size:12px}.admin-back-btn{color:#6b52ae;cursor:pointer;background:#f5f3fa;border:1.5px solid #ece6f8;border-radius:10px;padding:8px 18px;font-size:13px;font-weight:600;transition:all .15s}.admin-back-btn:hover{background:#ece6f8}.admin-stats{flex-wrap:wrap;gap:12px;padding:20px 24px 0;display:flex}.admin-stat{text-align:center;background:#fff;border:1.5px solid #ece6f8;border-radius:12px;flex:1;min-width:140px;padding:16px}.admin-stat-val{color:#6b52ae;font-size:28px;font-weight:900}.admin-stat-lbl{color:#888;margin-top:4px;font-size:12px}.admin-toolbar{flex-wrap:wrap;align-items:center;gap:10px;padding:16px 24px;display:flex}.admin-search{direction:rtl;border:1.5px solid #ece6f8;border-radius:10px;outline:none;flex:1;min-width:200px;padding:10px 14px;font-family:inherit;font-size:14px}.admin-search:focus{border-color:#6b52ae}.admin-sort{cursor:pointer;direction:rtl;background:#fff;border:1.5px solid #ece6f8;border-radius:10px;outline:none;padding:10px 14px;font-family:inherit;font-size:13px}.admin-count{color:#888;white-space:nowrap;font-size:13px;font-weight:600}.admin-table-wrap{background:#fff;border:1.5px solid #ece6f8;border-radius:12px;margin:0 24px;overflow-x:auto}.admin-table{border-collapse:collapse;width:100%;font-size:13px}.admin-table th{color:#6b52ae;text-align:right;white-space:nowrap;background:#f9f7fd;border-bottom:1.5px solid #ece6f8;padding:12px 10px;font-size:12px;font-weight:700}.admin-table td{vertical-align:middle;border-bottom:1px solid #f0ecf5;padding:10px}.admin-table tbody tr:hover{background:#faf8fe}.admin-row-admin{background:#f5f0ff!important}.admin-teacher-name{color:#1a1020;align-items:center;gap:6px;font-weight:600;display:flex}.admin-badge{color:#fff;background:#6b52ae;border-radius:6px;padding:2px 8px;font-size:10px;font-weight:700}.admin-email{color:#666;text-align:right;direction:ltr;font-size:12px}.admin-num{text-align:center;color:#6b52ae;font-weight:700}.admin-no-login{color:#ccc;font-size:12px}.admin-del-btn{cursor:pointer;opacity:.5;background:0 0;border:none;font-size:16px;transition:opacity .15s}.admin-del-btn:hover{opacity:1}.admin-del-btn:disabled{opacity:.2;cursor:not-allowed}.admin-del-confirm{align-items:center;gap:6px;font-size:12px;display:flex}.admin-del-confirm span{color:#dc2626;font-weight:600}.admin-del-yes{color:#fff;cursor:pointer;background:#dc2626;border:none;border-radius:6px;padding:4px 10px;font-size:11px;font-weight:700}.admin-del-no{color:#333;cursor:pointer;background:#eee;border:none;border-radius:6px;padding:4px 10px;font-size:11px;font-weight:600}.admin-loading{text-align:center;color:#888;padding:60px;font-size:16px}@media (width<=768px){.admin-stats{flex-direction:column}.admin-header{text-align:center;flex-direction:column;gap:10px}.admin-toolbar{flex-direction:column}.admin-table{font-size:12px}}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{font-feature-settings:"tnum";min-height:100vh;font-family:Rubik,Noto Sans Arabic,sans-serif}html,body{overflow-x:hidden}#captcha-slot{transform-origin:50%}@media (width<=380px){#captcha-slot{transform:scale(.9)}}#root{overflow-x:hidden}*,:before,:after{font-variant-numeric:lining-nums tabular-nums}input,select,textarea,button,table,th,td,div,span,p,label,a{font-family:Rubik,Noto Sans Arabic,sans-serif}input[type=date],input[type=number],input[type=tel]{font-family:Rubik,sans-serif}
