@import url("https://fonts.googleapis.com/css2?family=Cairo:wght@300;400;500;600;700;800;900&display=swap");:root{--primary:#0a6e58;--primary-light:#0c8a70;--primary-dark:#065a47;--primary-subtle:#ecfdf5;--primary-border:#a7f3d0;--gold:#c49a2a;--gold-light:#fef3c7;--bg:#f5f7f6;--surface:#ffffff;--surface-raised:#fafbfa;--text:#111827;--text-secondary:#4b5563;--text-muted:#9ca3af;--border:#e5e7eb;--border-strong:#d1d5db;--shadow-xs:0 1px 2px rgba(0,0,0,0.06);--shadow-sm:0 1px 4px rgba(0,0,0,0.07),0 2px 8px rgba(0,0,0,0.05);--shadow:0 4px 16px rgba(0,0,0,0.08),0 1px 4px rgba(0,0,0,0.04);--shadow-lg:0 12px 40px rgba(0,0,0,0.1),0 4px 12px rgba(0,0,0,0.06);--shadow-primary:0 4px 16px rgba(10,110,88,0.28);--radius-sm:8px;--radius:12px;--radius-lg:16px;--radius-xl:24px}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:Cairo,Tahoma,Arial,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;line-height:1.6;-webkit-font-smoothing:antialiased}body:before{content:"";position:fixed;inset:0;background:radial-gradient(ellipse 90% 50% at 50% -10%,rgba(10,110,88,.07) 0,transparent 60%),radial-gradient(ellipse 60% 40% at 90% 110%,rgba(196,154,42,.05) 0,transparent 55%);pointer-events:none;z-index:0}button,input,select,textarea{font-family:inherit}button{border:none;cursor:pointer;transition:all .18s ease;display:inline-flex;align-items:center;justify-content:center;gap:6px}button:disabled{cursor:not-allowed;opacity:.5}.shell{position:relative;z-index:1;width:min(1240px,calc(100% - 40px));margin:0 auto;padding:40px 0 80px}.home-hero{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;min-height:70vh;padding:60px 20px;gap:0}.home-badge{display:inline-flex;align-items:center;gap:8px;background:var(--primary-subtle);color:var(--primary);font-size:.82rem;font-weight:700;letter-spacing:.06em;padding:8px 18px;border-radius:100px;border:1px solid var(--primary-border);margin-bottom:28px}.home-badge:before{content:"";width:7px;height:7px;border-radius:50%;background:var(--primary);flex-shrink:0;box-shadow:0 0 0 3px rgba(10,110,88,.2)}.home-hero h1{font-size:clamp(2.4rem,5.5vw,4.2rem);font-weight:900;line-height:1.15;color:var(--text);max-width:680px;margin-bottom:20px}.home-hero h1 em{font-style:normal;color:var(--primary)}.home-description{font-size:1.05rem;color:var(--text-secondary);max-width:480px;line-height:1.8;margin-bottom:40px}.home-url-card{display:inline-flex;align-items:center;gap:14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px 22px;box-shadow:var(--shadow-sm)}.home-url-card .url-label{font-size:.8rem;color:var(--text-muted);font-weight:600;border-left:1px solid var(--border);padding-left:14px}.home-url-card code{font-family:Cairo,monospace;font-size:1rem;font-weight:700;color:var(--primary);direction:ltr;unicode-bidi:embed}.home-url-card code span{color:var(--gold)}.hero{padding:52px 0 44px;position:relative}.hero.single{padding:44px 0 36px}.eyebrow{display:inline-flex;align-items:center;gap:8px;background:var(--primary-subtle);color:var(--primary);font-size:.8rem;font-weight:700;letter-spacing:.06em;padding:6px 14px;border-radius:100px;border:1px solid var(--primary-border);margin-bottom:20px}.eyebrow:before{content:"";width:6px;height:6px;border-radius:50%;background:var(--primary);flex-shrink:0}h1{font-size:clamp(2rem,4vw,3.4rem);font-weight:900;line-height:1.18;color:var(--text);max-width:680px}.intro{color:var(--text-secondary);font-size:1rem;line-height:1.85;margin-top:16px;max-width:560px}.intro strong{color:var(--primary);font-weight:700}.notice{background:var(--surface);border:1px solid var(--border);border-right:4px solid var(--primary);border-radius:var(--radius);padding:14px 18px;margin-bottom:20px;color:var(--text);font-size:.93rem;font-weight:500;box-shadow:var(--shadow-xs);animation:noticeSlide .25s ease}.notice-loading{border-right-color:var(--gold);color:var(--text-secondary)}.notice-error{border-right-color:#dc2626}.notice-success{position:fixed;top:28px;left:50%;right:auto;transform:translateX(-50%);background:linear-gradient(135deg,#10b981,#059669 55%,#047857);color:#fff;border:none;border-radius:18px;padding:18px 28px;margin:0;display:flex;align-items:center;gap:12px;font-size:1rem;font-weight:700;box-shadow:0 8px 32px rgba(5,150,105,.45),0 2px 8px rgba(0,0,0,.1),inset 0 1px 0 rgba(255,255,255,.2);z-index:9999;min-width:300px;max-width:90vw;animation:toastPop .4s cubic-bezier(.34,1.56,.64,1) forwards;white-space:nowrap}.notice-icon{width:28px;height:28px;flex-shrink:0}@keyframes noticeSlide{0%{transform:translateY(-6px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes toastPop{0%{transform:translateX(-50%) translateY(-16px) scale(.94);opacity:0}to{transform:translateX(-50%) translateY(0) scale(1);opacity:1}}.workspace{display:grid;grid-gap:24px;gap:24px;grid-template-columns:290px 1fr;align-items:start}.teacher-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow);overflow:hidden;position:-webkit-sticky;position:sticky;top:24px}.teacher-panel-header{background:linear-gradient(145deg,var(--primary-dark) 0,var(--primary) 60%,var(--primary-light) 100%);padding:26px 22px 22px;position:relative;overflow:hidden}.teacher-panel-header:before{top:-40px;left:-24px;width:130px;height:130px;background:rgba(255,255,255,.07)}.teacher-panel-header:after,.teacher-panel-header:before{content:"";position:absolute;border-radius:50%;pointer-events:none}.teacher-panel-header:after{bottom:-32px;right:10px;width:100px;height:100px;background:rgba(255,255,255,.04)}.teacher-panel-header .panel-kicker{color:rgba(255,255,255,.65);font-size:.73rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;display:block;margin-bottom:8px;position:relative;z-index:1}.teacher-panel-header h2{color:#ffffff;font-size:1.3rem;font-weight:800;line-height:1.3;position:relative;z-index:1}.teacher-panel-header .teacher-subtitle{color:rgba(255,255,255,.7);font-size:.86rem;margin-top:5px;position:relative;z-index:1}.teacher-panel dl{padding:6px 22px 8px;display:grid;grid-gap:0;gap:0}.teacher-panel dl div{display:flex;justify-content:space-between;align-items:center;padding:14px 0;border-bottom:1px solid var(--border)}.teacher-panel dl div:last-child{border-bottom:none}dt{color:var(--text-muted);font-size:.83rem;font-weight:500}dd{font-weight:700;color:var(--text);font-size:.93rem;margin:0}.attendance-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:28px}.panel-header{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:24px}.attendance-panel .panel-kicker{display:block;color:var(--primary);font-size:.73rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;margin-bottom:5px}.attendance-panel h2{color:var(--text);font-size:1.35rem;font-weight:800}.btn-primary{background:var(--primary);color:#fff;border-radius:var(--radius-sm);padding:10px 22px;font-size:.9rem;font-weight:700;min-height:44px;box-shadow:var(--shadow-primary)}.btn-primary:hover:not(:disabled){background:var(--primary-light);transform:translateY(-1px);box-shadow:0 6px 20px rgba(10,110,88,.38)}.btn-primary:active:not(:disabled){transform:translateY(0)}.ghost,.secondary{background:transparent;border:1.5px solid var(--primary);color:var(--primary);border-radius:var(--radius-sm);padding:10px 22px;font-size:.9rem;font-weight:600;min-height:44px}.ghost:hover:not(:disabled),.secondary:hover:not(:disabled){background:var(--primary-subtle);transform:translateY(-1px);box-shadow:var(--shadow-xs)}.circle-grid{display:flex;gap:10px;overflow-x:auto;padding:20px 2px 10px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:var(--border-strong) transparent}.circle-grid::-webkit-scrollbar{height:3px}.circle-grid::-webkit-scrollbar-track{background:transparent}.circle-grid::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:4px}.circle-card{flex-shrink:0;scroll-snap-align:start;position:relative;display:flex;flex-direction:column;justify-content:center;gap:4px;min-width:148px;max-width:180px;background:var(--surface-raised);border:2px solid var(--border);border-radius:var(--radius);padding:14px 16px;cursor:pointer;transition:border-color .18s ease,background .18s ease,box-shadow .18s ease,transform .18s ease}.circle-card input[type=radio]{position:absolute;opacity:0;pointer-events:none;width:0;height:0}.circle-card:hover{border-color:var(--primary);transform:translateY(-3px);box-shadow:var(--shadow-sm)}.circle-card:has(input:checked){background:var(--primary);border-color:var(--primary);box-shadow:var(--shadow-primary);transform:translateY(-3px)}.circle-number{font-size:1rem;font-weight:800;color:var(--primary);transition:color .18s ease}.circle-card:has(input:checked) .circle-number{color:rgba(255,255,255,.95)}.circle-card span:not(.circle-number){font-size:.83rem;color:var(--text-secondary);font-weight:500;transition:color .18s ease}.circle-card:has(input:checked) span{color:rgba(255,255,255,.82)!important}.circle-card small{font-size:.75rem;color:var(--text-muted);margin-top:1px;transition:color .18s ease;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.circle-card:has(input:checked) small{color:rgba(255,255,255,.65)!important}.loading-students{display:flex;flex-direction:column;align-items:center;gap:16px;padding:48px 20px;margin-top:20px;border-top:1px solid var(--border)}.loading-students p{color:var(--text-muted);font-size:.9rem;font-weight:600}.loading-dots{display:flex;gap:8px}.loading-dots span{width:10px;height:10px;border-radius:50%;background:var(--primary);animation:dotBounce 1.2s ease-in-out infinite}.loading-dots span:nth-child(2){animation-delay:.2s;opacity:.7}.loading-dots span:nth-child(3){animation-delay:.4s;opacity:.45}@keyframes dotBounce{0%,80%,to{transform:translateY(0)}40%{transform:translateY(-10px)}}.students-section{margin-top:28px;padding-top:28px;border-top:1px solid var(--border)}.students-toolbar{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:20px}.toolbar-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.students-toolbar .panel-kicker{display:block;color:var(--primary);font-size:.73rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;margin-bottom:5px}.students-toolbar h3{font-size:1.15rem;font-weight:800;color:var(--text);margin-bottom:4px}.students-toolbar p{color:var(--text-muted);font-size:.83rem}.student-list{display:grid;grid-gap:10px;gap:10px}.student-row{background:var(--surface-raised);border:1px solid var(--border);border-right:3px solid transparent;border-radius:var(--radius);overflow:hidden;transition:background .2s ease,border-color .2s ease,box-shadow .15s ease}.student-row:hover{box-shadow:var(--shadow-xs)}.student-row[data-status="حاضر"]{background:#f0fdf4;border-color:#a7f3d0 #059669 #a7f3d0 #a7f3d0}.student-row[data-status="غائب"]{background:#fef2f2;border-color:#fecaca #dc2626 #fecaca #fecaca}.student-row[data-status="متأخر"]{background:#fffbeb;border-color:#fde68a #d97706 #fde68a #fde68a}.student-row[data-status="مستأذن"]{background:#eff6ff;border-color:#bfdbfe #2563eb #bfdbfe #bfdbfe}.achv{display:flex;align-items:center;gap:7px;margin-top:7px}.achv-bar{position:relative;height:6px;width:110px;background:#e5e7eb;border-radius:999px;overflow:hidden}.achv-bar.lg{width:100%;height:10px}.achv-fill{height:100%;border-radius:999px;transition:width .3s ease}.achv-fill.high{background:#16a34a}.achv-fill.mid{background:#d97706}.achv-fill.low{background:#dc2626}.achv-pct{font-size:.72rem;font-weight:800;min-width:32px}.achv-pct.high{color:#15803d}.achv-pct.mid{color:#b45309}.achv-pct.low{color:#b91c1c}.circle-achv{margin-bottom:18px;padding:14px 18px;background:var(--surface);border:1px solid var(--border);border-radius:12px}.circle-achv-head{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin-bottom:10px}.circle-achv-pct{font-size:1.35rem;font-weight:800}.circle-achv-pct.high{color:#15803d}.circle-achv-pct.mid{color:#b45309}.circle-achv-pct.low{color:#b91c1c}.status-badge{display:inline-flex;align-items:center;padding:6px 14px;border-radius:999px;font-size:.82rem;font-weight:700;white-space:nowrap;border:1px solid transparent}.status-badge[data-status="حاضر"]{background:#f0fdf4;color:#059669;border-color:#a7f3d0}.status-badge[data-status="غائب"]{background:#fef2f2;color:#dc2626;border-color:#fecaca}.status-badge[data-status="متأخر"]{background:#fffbeb;color:#d97706;border-color:#fde68a}.status-badge[data-status="مستأذن"]{background:#eff6ff;color:#2563eb;border-color:#bfdbfe}.student-row-main{padding:14px 15px 14px 18px;display:grid;grid-template-columns:1fr auto auto;grid-gap:16px;gap:16px;align-items:center}.student-info strong{display:block;font-size:.96rem;font-weight:700;color:var(--text);margin-bottom:4px}.student-info span{display:block;font-size:.79rem;color:var(--text-muted);font-weight:400}.recitation-toggle{background:var(--surface);border:1.5px solid var(--border-strong);color:var(--text-secondary);border-radius:var(--radius-sm);padding:6px 12px;font-size:.8rem;font-weight:700;min-height:34px;white-space:nowrap;flex-shrink:0;gap:5px;transition:all .18s ease}.recitation-toggle:hover{color:var(--gold)}.recitation-toggle.open,.recitation-toggle:hover{border-color:var(--gold);background:var(--gold-light)}.recitation-toggle.open{color:#92400e}.plan-edit-btn{background:var(--surface);border:1.5px solid var(--border-strong);color:var(--text-secondary);border-radius:var(--radius-sm);padding:6px 9px;min-height:34px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .18s ease;cursor:pointer}.plan-edit-btn:hover{background:color-mix(in srgb,var(--primary) 8%,transparent)}.plan-edit-btn.active,.plan-edit-btn:hover{border-color:var(--primary);color:var(--primary)}.plan-edit-btn.active{background:color-mix(in srgb,var(--primary) 10%,transparent)}.plan-edit-btn.no-plan{border-color:#fca5a5;color:#dc2626;background:#fef2f2}.plan-edit-btn.no-plan:hover{border-color:#dc2626;background:#fee2e2}.plan-edit-panel{border-top:1px solid var(--border);padding:14px 18px;background:#f8f9ff;display:grid;grid-gap:12px;gap:12px;animation:recitationOpen .2s ease}.plan-edit-fields{display:flex;flex-wrap:wrap;gap:12px}.plan-edit-field{display:flex;flex-direction:column;gap:4px}.plan-edit-field span{font-size:.75rem;font-weight:700;color:var(--text-secondary)}.plan-edit-field input[type=number],.plan-edit-field select{background:var(--surface);border:1px solid var(--border-strong);border-radius:6px;padding:5px 8px;font-size:.82rem;font-family:inherit;color:var(--text);outline:none;min-height:34px;cursor:pointer;transition:border-color .15s ease}.plan-edit-field input[type=number]:focus,.plan-edit-field select:focus{border-color:var(--primary)}.plan-edit-field input[type=number]{width:90px}.plan-edit-actions{display:flex;gap:8px;align-items:center}.plan-panel-toggle{display:inline-flex;align-items:center;gap:7px;flex-shrink:0;background:var(--surface);border:1px solid var(--border-strong);border-radius:8px;padding:8px 14px;font-size:.85rem;font-weight:700;font-family:inherit;color:var(--primary);cursor:pointer;transition:background .15s ease,border-color .15s ease,color .15s ease}.plan-panel-toggle:hover{border-color:var(--primary);background:#f8f9ff}.plan-panel-toggle.active{background:var(--primary);border-color:var(--primary);color:#fff}.plan-modal-overlay{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;background:rgba(15,23,42,.55);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);animation:planOverlayIn .18s ease}.plan-modal{width:min(720px,100%);max-height:min(85vh,100%);display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--border);border-radius:16px;box-shadow:0 24px 60px rgba(15,23,42,.35);overflow:hidden;animation:planModalIn .2s ease}.plan-modal-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:16px 20px;border-bottom:1px solid var(--border);background:#f8f9ff}.plan-modal-close{flex-shrink:0;width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;font-size:1.5rem;line-height:1;border:1px solid var(--border-strong);border-radius:8px;background:var(--surface);color:var(--text-muted);cursor:pointer;transition:background .15s ease,color .15s ease,border-color .15s ease}.plan-modal-close:hover{background:#fee2e2;border-color:#fca5a5;color:#dc2626}.plan-modal-body{overflow-y:auto}@keyframes planOverlayIn{0%{opacity:0}to{opacity:1}}@keyframes planModalIn{0%{opacity:0;transform:translateY(12px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.plan-panel-hint{font-size:.8rem;color:var(--text-muted)}.plan-panel-list{padding:14px 18px}.plan-panel-list,.plan-panel-row{display:grid;grid-gap:12px;gap:12px}.plan-panel-row{padding:14px;background:var(--surface);border:1px solid var(--border);border-radius:10px}.plan-panel-student{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap}.plan-panel-student strong{font-size:.95rem;font-weight:800;color:var(--text)}.plan-panel-student span{font-size:.78rem;color:var(--text-muted)}.recitation-panel{border-top:1px solid var(--border);padding:14px 18px;background:#fffef8;display:grid;grid-gap:10px;gap:10px;animation:recitationOpen .2s ease}@keyframes recitationOpen{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.recitation-section{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.recitation-label{font-size:.8rem;font-weight:800;color:var(--gold);min-width:52px;text-align:right;flex-shrink:0}.recitation-selects{display:flex;align-items:center;gap:6px;flex-wrap:wrap;flex:1 1}.recitation-selects span{font-size:.78rem;color:var(--text-muted);font-weight:600;flex-shrink:0}select.sura-select{padding:4px 8px;width:140px}select.aya-select,select.sura-select{background:var(--surface);border:1px solid var(--border-strong);border-radius:6px;font-size:.8rem;font-family:inherit;color:var(--text);outline:none;min-height:32px;cursor:pointer;transition:border-color .15s ease}select.aya-select{padding:4px 6px;width:62px}select.grade-select{background:var(--surface);border:1px solid var(--border-strong);border-radius:6px;padding:4px 8px;font-size:.8rem;font-family:inherit;color:var(--text);outline:none;min-height:32px;width:110px;cursor:pointer;transition:border-color .15s ease}select.aya-select:focus,select.grade-select:focus,select.sura-select:focus{border-color:var(--gold);box-shadow:0 0 0 2px rgba(196,154,42,.15)}.status-options{display:flex;gap:7px;flex-shrink:0}.status{border-radius:var(--radius-sm);padding:6px 14px;font-size:.81rem;font-weight:700;min-height:36px;white-space:nowrap;transition:all .15s ease;border:1.5px solid transparent;cursor:pointer}.status-options .status:first-child{background:#f0fdf4;color:#059669;border-color:#a7f3d0}.status-options .status:first-child.active{background:#059669;color:#fff;border-color:#059669;box-shadow:0 2px 8px rgba(5,150,105,.35)}.status-options .status:first-child:not(.active):hover{background:#dcfce7;border-color:#6ee7b7}.status-options .status:nth-child(2){background:#fef2f2;color:#dc2626;border-color:#fecaca}.status-options .status:nth-child(2).active{background:#dc2626;color:#fff;border-color:#dc2626;box-shadow:0 2px 8px rgba(220,38,38,.35)}.status-options .status:nth-child(2):not(.active):hover{background:#fee2e2;border-color:#fca5a5}.status-options .status:nth-child(3){background:#fffbeb;color:#d97706;border-color:#fde68a}.status-options .status:nth-child(3).active{background:#d97706;color:#fff;border-color:#d97706;box-shadow:0 2px 8px rgba(217,119,6,.35)}.status-options .status:nth-child(3):not(.active):hover{background:#fef3c7;border-color:#fcd34d}.status-options .status:nth-child(4){background:#eff6ff;color:#2563eb;border-color:#bfdbfe}.status-options .status:nth-child(4).active{background:#2563eb;color:#fff;border-color:#2563eb;box-shadow:0 2px 8px rgba(37,99,235,.35)}.status-options .status:nth-child(4):not(.active):hover{background:#dbeafe;border-color:#93c5fd}.empty-state{background:var(--surface-raised);border:1.5px dashed var(--border-strong);border-radius:var(--radius);padding:44px 20px;text-align:center;color:var(--text-muted);font-size:.93rem;margin-top:16px}.save-bar{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-top:24px;padding:16px 18px;background:var(--primary-subtle);border:1px solid var(--primary-border);border-radius:var(--radius)}.save-bar>span{color:var(--primary-dark);font-weight:700;font-size:.9rem}.harvest-panel{margin-top:20px;padding:18px 20px;background:#f8f9ff;border:1px solid var(--border-strong);border-radius:var(--radius);display:grid;grid-gap:16px;gap:16px;animation:recitationOpen .2s ease}.harvest-header{display:flex;flex-wrap:wrap;align-items:baseline;justify-content:space-between;gap:8px}.harvest-header p{margin:0;font-size:.9rem;color:var(--text-secondary)}.harvest-fields{display:flex;flex-wrap:wrap;gap:16px}.harvest-field{display:flex;flex-direction:column;gap:6px;flex:1 1;min-width:200px}.harvest-field span{font-size:.82rem;font-weight:700;color:var(--text-secondary)}.harvest-field input[type=number]{background:var(--surface);border:1px solid var(--border-strong);border-radius:8px;padding:10px 12px;font-size:1rem;font-family:inherit;color:var(--text);outline:none;min-height:44px;transition:border-color .15s ease}.harvest-field input[type=number]:focus{border-color:var(--primary)}@media (max-width:900px){.workspace{grid-template-columns:1fr}.teacher-panel{position:static}}@media (max-width:640px){.shell{width:calc(100% - 24px);padding:24px 0 60px}.hero,.hero.single{padding:32px 0 24px}.attendance-panel{padding:20px 16px}.panel-header{align-items:stretch}.panel-header,.students-toolbar{flex-direction:column}.student-row-main{grid-template-columns:1fr;gap:10px}.status-options{display:grid;grid-template-columns:repeat(2,1fr)}.status-options .status{width:100%}.recitation-section{flex-direction:column;align-items:flex-start}select.sura-select{width:100%}select.aya-select{width:70px}.save-bar{flex-direction:column;align-items:stretch;text-align:center}}.admin-center{display:flex;justify-content:center;align-items:center;min-height:70vh}.admin-login-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);padding:44px 40px;width:min(420px,100%);text-align:center}.admin-login-header{margin-bottom:32px}.admin-lock-icon{display:inline-flex;align-items:center;justify-content:center;width:56px;height:56px;border-radius:16px;background:var(--primary-subtle);color:var(--primary);margin-bottom:18px}.admin-lock-icon svg{width:26px;height:26px}.admin-login-header h1{font-size:1.6rem;font-weight:900;color:var(--text);max-width:none;margin-bottom:6px}.admin-login-header p{color:var(--text-muted);font-size:.9rem}.admin-login-form{display:flex;flex-direction:column;gap:14px}.admin-password-input{width:100%;background:var(--surface-raised);border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:12px 16px;font-size:1rem;color:var(--text);text-align:center;letter-spacing:.12em;transition:border-color .18s ease,box-shadow .18s ease;min-height:48px}.admin-password-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(10,110,88,.12)}.admin-login-error{color:#dc2626;font-size:.87rem;font-weight:600}.admin-login-btn{width:100%;min-height:48px;font-size:1rem}.btn-spinner{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0}@keyframes spin{to{transform:rotate(1turn)}}.admin-toolbar{display:flex;align-items:center;gap:12px;margin-bottom:24px;flex-wrap:wrap}.admin-logout-btn{margin-right:auto}.admin-table-wrapper{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow);overflow:hidden}.admin-table{width:100%;border-collapse:collapse;font-size:.9rem}.admin-table thead{background:var(--primary-subtle)}.admin-table th{padding:14px 18px;text-align:right;font-size:.78rem;font-weight:700;color:var(--primary-dark);letter-spacing:.04em;border-bottom:1px solid var(--primary-border);white-space:nowrap}.admin-table td{padding:14px 18px;border-bottom:1px solid var(--border);color:var(--text);vertical-align:middle}.admin-table tbody tr:last-child td{border-bottom:none}.admin-table tbody tr:hover td{background:var(--surface-raised)}.admin-td-num{color:var(--text-muted);font-size:.82rem;font-weight:600;width:40px}.admin-td-name{font-weight:700}.admin-td-mono{font-family:monospace;font-size:.88rem;color:var(--text-secondary)}.admin-suburl{display:inline-block;background:var(--primary-subtle);color:var(--primary-dark);border:1px solid var(--primary-border);border-radius:6px;padding:3px 10px;font-size:.82rem;font-family:monospace;font-weight:600;direction:ltr}@media (max-width:640px){.admin-login-card{padding:32px 20px}.admin-table td:nth-child(3),.admin-table th:nth-child(3){display:none}}.admin-tabs{display:flex;gap:8px;border-bottom:2px solid var(--border);margin-bottom:24px;overflow-x:auto;scrollbar-width:none}.admin-tabs::-webkit-scrollbar{display:none}.tab-btn{background:transparent;color:var(--text-secondary);font-size:.95rem;font-weight:700;padding:12px 24px;border-bottom:3px solid transparent;border-radius:0;white-space:nowrap;transition:all .18s ease}.tab-btn:hover{color:var(--primary);background:rgba(10,110,88,.04)}.tab-btn.active{color:var(--primary);border-bottom-color:var(--primary)}.stats-container{display:flex;flex-direction:column;gap:28px;animation:noticeSlide .25s ease}.stats-filter-bar{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px;gap:20px;box-shadow:var(--shadow-xs)}.filter-group,.stats-filter-bar{display:flex;flex-wrap:wrap;align-items:center}.filter-group{gap:12px}.filter-label{font-weight:700;color:var(--text-secondary);font-size:.9rem}.filter-options{display:flex;gap:6px;background:var(--bg);padding:4px;border-radius:var(--radius-sm);border:1px solid var(--border)}.filter-opt-btn{background:transparent;color:var(--text-secondary);font-size:.85rem;font-weight:700;padding:6px 14px;border-radius:6px;min-height:auto}.filter-opt-btn:hover{color:var(--primary)}.filter-opt-btn.active{background:var(--surface);color:var(--primary);box-shadow:var(--shadow-xs)}.custom-date-form{display:flex;align-items:flex-end;gap:14px;flex-wrap:wrap;border-right:1px solid var(--border);padding-right:20px}.custom-date-form .input-field{display:flex;flex-direction:column;gap:5px}.custom-date-form label{font-size:.78rem;font-weight:700;color:var(--text-muted)}.custom-date-form input{padding:7px 12px;border:1px solid var(--border-strong);border-radius:6px;font-family:inherit;font-size:.85rem;outline:none;background:var(--surface-raised)}.custom-date-form input:focus{border-color:var(--primary);background:var(--surface)}.btn-apply{background:var(--primary-dark);color:#fff;font-size:.85rem;font-weight:700;padding:8px 16px;border-radius:6px;min-height:auto}.btn-apply:hover{background:var(--primary)}.stats-kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));grid-gap:16px;gap:16px}.kpi-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px;display:flex;flex-direction:column;gap:6px;box-shadow:var(--shadow-xs);transition:transform .2s ease,box-shadow .2s ease}.kpi-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-sm)}.kpi-title{font-size:.82rem;font-weight:700;color:var(--text-muted)}.kpi-value{font-size:2.1rem;font-weight:900;color:var(--primary-dark);line-height:1.1}.kpi-desc{font-size:.78rem;color:var(--text-secondary)}.stats-distribution-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow-xs)}.stats-distribution-section h3{font-size:1.05rem;font-weight:800;color:var(--text);margin-bottom:18px}.stats-distribution{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));grid-gap:12px;gap:12px}.dist-item{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:16px;border-radius:var(--radius);border:1.5px solid transparent;gap:4px;text-align:center}.dist-item .dist-label{font-size:.85rem;font-weight:700}.dist-item strong{font-size:1.35rem;font-weight:800}.dist-item strong small{font-size:.8rem;font-weight:500;opacity:.85}.dist-present{background:#f0fdf4;border-color:#d1fae5;color:#065f46}.dist-absent{background:#fef2f2;border-color:#fee2e2;color:#991b1b}.dist-late{background:#fffbeb;border-color:#fef3c7;color:#92400e}.dist-excused{background:#eff6ff;border-color:#dbeafe;color:#1e40af}.trend-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow-xs)}.trend-section h3{font-size:1.05rem;font-weight:800;color:var(--text);margin-bottom:24px}.trend-bar-chart{display:flex;align-items:flex-end;gap:10px;height:180px;padding-bottom:20px;border-bottom:2px solid var(--border);overflow-x:auto;scrollbar-width:thin}.trend-bar-wrapper{flex:1 1;min-width:40px;display:flex;flex-direction:column;align-items:center;gap:8px}.trend-bar-container{height:120px;background:var(--bg);display:flex;align-items:flex-end}.trend-bar,.trend-bar-container{width:100%;border-radius:4px 4px 0 0;position:relative}.trend-bar{background:linear-gradient(to top,var(--primary) 0,var(--primary-light) 100%);transition:all .3s ease;cursor:pointer}.trend-bar:hover{background:var(--primary-light);transform:scaleX(1.05)}.trend-bar-tooltip{top:-30px;background:var(--text);color:#fff;font-size:.72rem;font-weight:700;padding:3px 8px;border-radius:4px;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .15s ease,transform .15s ease;z-index:10}.trend-bar-tooltip,.trend-bar-tooltip:after{position:absolute;left:50%;transform:translateX(-50%)}.trend-bar-tooltip:after{content:"";bottom:-4px;border-width:4px 4px 0;border-style:solid;border-color:var(--text) transparent}.trend-bar:hover .trend-bar-tooltip{opacity:1;transform:translateX(-50%) translateY(-2px)}.trend-bar-date{font-size:.72rem;font-weight:700;color:var(--text-muted)}.circles-stats-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow-xs);display:flex;flex-direction:column;gap:16px}.circles-stats-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}.circles-stats-header h3{font-size:1.05rem;font-weight:800;color:var(--text)}.today-submission-rate{font-size:.85rem;color:var(--text-secondary);background:var(--primary-subtle);border:1px solid var(--primary-border);padding:6px 14px;border-radius:100px;font-weight:500}.today-submission-rate strong{color:var(--primary-dark)}.circle-tag{display:inline-block;background:var(--bg);border:1px solid var(--border);color:var(--text-secondary);font-size:.73rem;font-weight:700;padding:2px 8px;border-radius:4px;margin-left:4px}.circle-tag.category{background:#fffbeb;border-color:#fde68a;color:#b45309}.circle-status-badge{display:inline-flex;align-items:center;gap:5px;font-size:.75rem;font-weight:700;padding:4px 10px;border-radius:100px}.circle-status-badge:before{content:"";width:5px;height:5px;border-radius:50%;background:currentColor}.circle-status-badge.submitted{background:#dcfce7;color:#15803d}.circle-status-badge.pending{background:#f3f4f6;color:#6b7280}.top-controls{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin:6px 0 16px}.top-controls-label{font-size:.85rem;font-weight:700;color:var(--text-secondary)}.top-count-options{display:flex;gap:6px}.top-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));grid-gap:16px;gap:16px;margin-bottom:16px}.top-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:16px 18px;margin-bottom:16px}.top-card h3{font-size:1rem;font-weight:800;color:var(--text);margin-bottom:12px}.rank-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:4px}.rank-list li{display:flex;align-items:center;gap:12px;padding:9px 8px;border-radius:8px}.rank-list li:nth-child(odd){background:var(--bg)}.rank-num{flex-shrink:0;width:26px;height:26px;display:inline-flex;align-items:center;justify-content:center;border-radius:50%;background:var(--primary);color:#fff;font-size:.8rem;font-weight:800}.rank-list li:first-child .rank-num{background:#f59e0b}.rank-list li:nth-child(2) .rank-num{background:#94a3b8}.rank-list li:nth-child(3) .rank-num{background:#b45309}.rank-main{flex:1 1;display:flex;flex-direction:column;gap:2px;font-size:.88rem;font-weight:700;color:var(--text)}.rank-main small{font-weight:600;color:var(--text-muted);font-size:.75rem}.rank-sub{font-size:.75rem}.rank-val{flex-shrink:0;font-size:.95rem;font-weight:800}.rank-val small{font-size:.72rem;font-weight:700;opacity:.8}.rank-val.high{color:#15803d}.rank-val.mid{color:#b45309}.rank-val.low{color:#b91c1c}.circle-status-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:4px;max-height:320px;overflow-y:auto}.circle-status-list li{display:flex;align-items:center;gap:10px;padding:8px;border-radius:8px}.circle-status-list li:nth-child(odd){background:var(--bg)}.status-dot{flex-shrink:0;width:9px;height:9px;border-radius:50%}.status-dot.active{background:#16a34a}.status-dot.inactive{background:#cbd5e1}.circles-settings-intro{margin-bottom:16px;color:var(--text-secondary);font-size:.9rem;line-height:1.7}.element-toggle{display:inline-flex;align-items:center;gap:6px;min-width:78px;justify-content:center;padding:6px 12px;border-radius:100px;font-size:.78rem;font-weight:700;font-family:inherit;cursor:pointer;border:1px solid transparent;transition:background .15s ease,color .15s ease,border-color .15s ease}.element-toggle:before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor}.element-toggle.on{background:#dcfce7;color:#15803d;border-color:#bbf7d0}.element-toggle.on:hover{background:#bbf7d0}.element-toggle.off{background:#fef2f2;color:#b91c1c;border-color:#fecaca}.element-toggle.off:hover{background:#fecaca}.circles-settings-savebar{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-top:18px;padding:14px 18px;background:var(--surface);border:1px solid var(--border);border-radius:12px}.circles-settings-savebar span{font-size:.85rem;color:var(--text-secondary);font-weight:600}.circle-dist-pills{display:flex;gap:4px}.circle-dist-pills .pill{display:inline-block;font-size:.72rem;font-weight:700;padding:1px 6px;border-radius:4px;min-width:22px;text-align:center}.circle-dist-pills .pill.present{background:#f0fdf4;color:#16a34a}.circle-dist-pills .pill.absent{background:#fef2f2;color:#dc2626}.circle-dist-pills .pill.late{background:#fffbeb;color:#d97706}.circle-dist-pills .pill.excused{background:#eff6ff;color:#2563eb}.circle-att-rate{font-size:.95rem;font-weight:800;color:var(--primary-dark)}.stats-refresh-btn-wrapper{display:flex;align-items:center}@media (max-width:768px){.custom-date-form{border-right:none;padding-right:0;width:100%}.stats-filter-bar{flex-direction:column;align-items:flex-start}}.presentation-intro-card{max-width:640px;margin:10px auto;padding:36px 32px;text-align:center;background:var(--surface);border:1px solid var(--border);border-radius:16px}.presentation-intro-icon{display:inline-flex;align-items:center;justify-content:center;width:76px;height:76px;border-radius:50%;background:#eef2ff;color:var(--primary);margin-bottom:18px}.presentation-intro-card h3{font-size:1.3rem;font-weight:800;color:var(--text);margin-bottom:10px}.presentation-intro-card p{color:var(--text-secondary);font-size:.92rem;line-height:1.8;margin-bottom:22px}.presentation-options{display:flex;align-items:center;justify-content:center;gap:12px;flex-wrap:wrap;margin-bottom:22px}.presentation-options>span{font-size:.88rem;font-weight:700;color:var(--text-secondary)}.presentation-start-btn{display:inline-flex;align-items:center;gap:8px;font-size:1rem;padding:12px 26px}.present-hint{margin-top:14px;font-size:.85rem;color:var(--text-muted)}.present-overlay{position:fixed;inset:0;z-index:2000;display:flex;flex-direction:column;background:linear-gradient(160deg,#0b1220,#0f2540);color:#fff;direction:rtl;overflow:hidden}.present-header{display:flex;align-items:baseline;justify-content:space-between;gap:16px;padding:clamp(20px,4vh,48px) clamp(24px,5vw,72px) 0}.present-title{font-size:clamp(1.8rem,4.5vw,3.4rem);font-weight:900;letter-spacing:-.01em}.present-meta{font-size:clamp(.9rem,1.6vw,1.3rem);font-weight:700;color:#93c5fd;white-space:nowrap}.present-body{flex:1 1;display:flex;align-items:center;justify-content:center;padding:clamp(16px,3vh,40px) clamp(24px,5vw,72px);min-height:0}.present-kpis{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:clamp(14px,2.5vw,34px);gap:clamp(14px,2.5vw,34px);width:100%;max-width:1500px}.present-kpi{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:18px;padding:clamp(18px,3.5vh,46px) clamp(16px,2vw,32px);text-align:center}.present-kpi span{display:block;font-size:clamp(.95rem,1.7vw,1.5rem);font-weight:700;color:#cbd5e1;margin-bottom:12px}.present-kpi strong{font-size:clamp(2.6rem,7vw,5.5rem);font-weight:900;line-height:1;color:#fff}.present-dist-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-gap:clamp(14px,2.5vw,34px);gap:clamp(14px,2.5vw,34px);width:100%;max-width:1500px}.present-dist{border-radius:18px;padding:clamp(20px,4vh,52px) 18px;text-align:center;border:2px solid transparent}.present-dist span{display:block;font-size:clamp(1rem,2vw,1.7rem);font-weight:800;margin-bottom:14px}.present-dist strong{font-size:clamp(2.4rem,6vw,5rem);font-weight:900;line-height:1}.present-dist strong small{display:block;font-size:clamp(1rem,2vw,1.7rem);font-weight:800;opacity:.85;margin-top:8px}.present-dist.present{background:rgba(22,163,74,.16);border-color:rgba(22,163,74,.4);color:#86efac}.present-dist.absent{background:rgba(220,38,38,.16);border-color:rgba(220,38,38,.4);color:#fca5a5}.present-dist.late{background:rgba(217,119,6,.16);border-color:rgba(217,119,6,.4);color:#fcd34d}.present-dist.excused{background:rgba(37,99,235,.16);border-color:rgba(37,99,235,.4);color:#93c5fd}.present-rank{list-style:none;margin:0;padding:0;width:100%;max-width:1300px;display:flex;flex-direction:column;gap:clamp(8px,1.4vh,16px)}.present-rank li{display:flex;align-items:center;gap:clamp(14px,2vw,28px);background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:14px;padding:clamp(10px,1.8vh,20px) clamp(16px,2.4vw,30px)}.present-rank-num{flex-shrink:0;width:clamp(40px,4vw,60px);height:clamp(40px,4vw,60px);display:inline-flex;align-items:center;justify-content:center;border-radius:50%;background:var(--primary);color:#fff;font-size:clamp(1.1rem,2.2vw,1.8rem);font-weight:900}.present-rank li:first-child .present-rank-num{background:#f59e0b}.present-rank li:nth-child(2) .present-rank-num{background:#cbd5e1;color:#0f172a}.present-rank li:nth-child(3) .present-rank-num{background:#b45309}.present-rank-main{flex:1 1;display:flex;flex-direction:column;gap:4px;font-size:clamp(1.2rem,2.6vw,2.1rem);font-weight:800}.present-rank-main small{font-size:clamp(.85rem,1.5vw,1.2rem);font-weight:600;color:#94a3b8}.present-rank-val{flex-shrink:0;font-size:clamp(1.4rem,3.2vw,2.8rem);font-weight:900}.present-rank-val.high{color:#4ade80}.present-rank-val.mid{color:#fbbf24}.present-rank-val.low{color:#f87171}.present-active-wrap{display:flex;flex-direction:column;align-items:center;gap:clamp(18px,3vh,40px);width:100%;max-width:1400px}.present-active-count{text-align:center}.present-active-count strong{display:block;font-size:clamp(3.5rem,11vw,9rem);font-weight:900;line-height:1;color:#4ade80}.present-active-count span{display:block;font-size:clamp(1.1rem,2.2vw,1.8rem);font-weight:700;margin-top:8px}.present-active-count em{display:block;font-style:normal;font-size:clamp(.9rem,1.6vw,1.2rem);color:#94a3b8;margin-top:6px}.present-chips{display:flex;flex-wrap:wrap;justify-content:center;gap:clamp(8px,1.2vw,14px);max-height:40vh;overflow-y:auto}.present-chip{display:inline-flex;align-items:center;gap:8px;background:rgba(22,163,74,.16);border:1px solid rgba(22,163,74,.35);border-radius:100px;padding:8px 18px;font-size:clamp(.9rem,1.6vw,1.25rem);font-weight:700}.present-chip small{font-weight:600;color:#86efac;font-size:.85em}.present-controls{display:flex;align-items:center;justify-content:center;gap:clamp(8px,1.2vw,16px);flex-wrap:wrap;padding:clamp(12px,2vh,22px);background:rgba(0,0,0,.25);border-top:1px solid rgba(255,255,255,.1)}.present-controls button{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);color:#fff;border-radius:10px;padding:8px 14px;font-size:1rem;font-weight:700;font-family:inherit;cursor:pointer;transition:background .15s ease}.present-controls button:hover{background:rgba(255,255,255,.2)}.present-controls .present-play{min-width:96px}.present-dots{display:flex;gap:8px;margin:0 8px}.present-dots .dot{width:11px;height:11px;border-radius:50%;background:rgba(255,255,255,.3);cursor:pointer;transition:background .15s ease,transform .15s ease}.present-dots .dot.active{background:#fff;transform:scale(1.25)}.present-interval{display:flex;gap:4px;margin:0 6px}.present-interval button{padding:6px 10px;font-size:.85rem}.present-interval button.active{background:var(--primary);border-color:var(--primary)}.present-exit{background:rgba(220,38,38,.85)!important;border-color:rgba(220,38,38,.9)!important}@media (max-width:640px){.present-dist-grid,.present-kpis{grid-template-columns:repeat(2,1fr)}}