:root{--bg:#f4f6f8;--surface:#fff;--surface-alt:#fafbfc;--line:#e2e8f0;--line-strong:#cbd5e1;--text:#1f2937;--text-soft:#6b7280;--brand:#0f766e;--brand-dark:#115e59;--brand-soft:#e6fffb;--danger:#dc2626;--danger-soft:#fef2f2;--radius-lg:18px;--radius-md:12px;--radius-sm:10px;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,Segoe UI,Arial,sans-serif;font-weight:400;line-height:1.5}*{box-sizing:border-box}html{scroll-behavior:smooth}body{background-color:var(--bg);background-image:url(/background.png);background-position:top;background-repeat:no-repeat;background-size:cover;background-attachment:fixed;min-width:320px;min-height:100vh;margin:0}button,input,select,textarea{font:inherit}button{cursor:pointer}a{color:inherit;text-decoration:none}#root{min-height:100vh}.app-shell{width:min(1180px,100% - 32px);margin:0 auto;padding:16px 0 40px}.landing-shell{width:min(1180px,100% - 32px);margin:0 auto;padding:20px 0 56px}.landing-header,.landing-hero,.landing-section,.landing-cta{border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--surface)}.landing-header{justify-content:space-between;align-items:center;gap:20px;padding:16px 20px;display:flex}.landing-nav,.landing-points,.preview-columns,.steps-grid,.benefit-grid{gap:12px;display:flex}.landing-nav{flex-wrap:wrap;align-items:center}.landing-main{gap:20px;margin-top:20px;display:grid}.landing-hero{grid-template-columns:minmax(0,1.1fr) minmax(320px,.9fr);gap:28px;padding:32px;display:grid}.landing-copy{align-content:start;gap:18px;display:grid}.landing-kicker,.preview-badge,.step-index{border:1px solid var(--line);background:var(--surface-alt);width:fit-content;min-height:32px;color:var(--text-soft);border-radius:999px;align-items:center;padding:0 12px;font-size:.88rem;display:inline-flex}.landing-copy h2,.landing-section-head h3,.landing-cta h3,.benefit-card h4{color:var(--text);margin:0}.landing-copy h2{letter-spacing:-.04em;max-width:11ch;font-size:clamp(2.8rem,6vw,4.8rem);line-height:.96}.landing-copy p,.landing-section-head p,.benefit-card p,.step-card p,.landing-cta p{color:var(--text-soft);margin:0}.landing-copy>p{max-width:58ch;font-size:1.02rem}.landing-points{flex-wrap:wrap}.landing-points span{background:var(--surface-alt);min-height:36px;color:var(--text-soft);border-radius:999px;align-items:center;gap:8px;padding:0 12px;display:inline-flex}.preview-card{border-radius:calc(var(--radius-lg) - 2px);border:1px solid var(--line);background:linear-gradient(#fff 0%,#f8fafc 100%);gap:18px;padding:20px;display:grid}.preview-topbar,.preview-brand,.preview-row{justify-content:space-between;align-items:center;gap:12px;display:flex}.preview-brand{justify-content:flex-start}.preview-dot{background:var(--brand);border-radius:999px;width:10px;height:10px}.preview-columns{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;display:grid}.preview-panel,.benefit-card,.step-card{border-radius:var(--radius-md);border:1px solid var(--line);background:var(--surface-alt);padding:18px}.preview-panel{gap:12px;display:grid}.preview-panel h3{margin:0;font-size:.95rem}.preview-item,.preview-row{border-radius:var(--radius-sm);background:var(--surface);border:1px solid var(--line);padding:12px}.preview-item{gap:2px;display:grid}.preview-item strong,.preview-row span:first-child{color:var(--text)}.preview-item span,.preview-row span{color:var(--text-soft);font-size:.9rem}.preview-status.success{color:var(--brand-dark)}.preview-status.danger{color:var(--danger)}.landing-section{gap:22px;padding:28px;display:grid}.landing-section-head{gap:8px;max-width:640px;display:grid}.benefit-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;display:grid}.benefit-card,.step-card{gap:14px;display:grid}.benefit-icon{background:var(--surface);width:42px;height:42px;color:var(--brand);border:1px solid var(--line);border-radius:12px;place-items:center;display:grid}.benefit-card h4{font-size:1.05rem}.steps-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;display:grid}.step-index{color:var(--brand);font-weight:600}.landing-cta{justify-content:space-between;align-items:center;gap:20px;padding:28px;display:flex}.app-main,.page-grid,.student-list,.week-lessons,.attendance-board{gap:20px;display:grid}.navbar{border-radius:var(--radius-lg);background:var(--surface);border:1px solid var(--line);margin-bottom:24px;padding:14px 20px}.navbar-row{justify-content:space-between;align-items:center;gap:16px;display:flex}.brand-block{align-items:center;gap:12px;display:flex}.brand-mark{border-radius:12px;flex:0 0 40px;justify-content:center;align-items:center;width:40px;height:40px;display:inline-flex;overflow:hidden}.brand-mark img{object-fit:cover;width:100%;height:100%;display:block}.brand-copy h1,.page-header h2,.section-header h3,.panel-headline h3,.modal-copy h3,.week-column-header h4{color:var(--text);margin:0;font-weight:700}.brand-copy h1{font-size:1.1rem}.brand-copy p,.page-header p,.helper-copy,.student-subline,.meta-line,.page-header-meta,.section-header p,.week-column-header p,.schedule-empty,.empty-state p,.label{color:var(--text-soft);margin:0}.nav-links,.hero-actions,.page-header-actions,.header-actions,.inline-actions,.modal-actions,.attendance-controls,.grade-controls,.group-meta{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.nav-links{justify-content:flex-end}.nav-link,.back-link,.page-link{color:var(--text-soft);align-items:center;gap:8px;display:inline-flex}.nav-link{border:1px solid var(--line);background:var(--surface-alt);border-radius:999px;min-height:36px;padding:0 10px;font-weight:600}.nav-link-quran{border-color:var(--brand);background:var(--brand);color:#fff;font-weight:700}.nav-link-live{color:#1d4ed8;background:#eff6ff;border-color:#bfdbfe;font-weight:700}.nav-link-quran svg,.nav-link-live svg{width:17px;height:17px}.back-link-button{width:fit-content;font:inherit;cursor:pointer;background:0 0;border:0;padding:0}.nav-link.active,.nav-link:hover,.back-link:hover,.page-link:hover{background:var(--brand-soft);color:var(--brand-dark);border-color:#99f6e4}.nav-link-quran.active,.nav-link-quran:hover{background:var(--brand);border-color:var(--brand);color:#fff}.nav-link-live.active,.nav-link-live:hover{color:#fff;background:#2563eb;border-color:#2563eb}.nav-role{background:var(--surface-alt);min-height:32px;color:var(--text-soft);border-radius:999px;align-items:center;padding:0 12px;font-size:.9rem;display:inline-flex}.nav-logout{background:var(--danger-soft);color:var(--danger);border-color:#fecaca}.nav-logout:hover{color:#b91c1c;background:#fee2e2;border-color:#fca5a5}.navbar-back-row{margin-top:12px}.navbar-back-button{width:fit-content;font-weight:600}.page-header{border-radius:var(--radius-lg);background:var(--surface);border:1px solid var(--line);justify-content:space-between;align-items:flex-start;gap:20px;padding:24px;display:flex}.groups-page-header{background-image:linear-gradient(90deg,#ffffffd1 0%,#ffffff75 20%,#ffffff29 100%),url(/group_block_bg.png);background-position:50%,50% 70%;background-repeat:no-repeat;background-size:cover}.page-header-main{gap:8px;display:grid}.page-header h2{font-size:clamp(1.9rem,4vw,2.5rem);line-height:1.05}.page-header-meta{flex-wrap:wrap;gap:14px;font-size:.95rem;display:flex}.surface{border-radius:var(--radius-lg);background:var(--surface);border:1px solid var(--line);padding:24px}.surface+.surface{margin-top:20px}.section-header,.panel-headline,.schedule-toolbar,.week-column-header,.attendance-table-head,.attendance-head{justify-content:space-between;align-items:center;gap:16px;display:flex}.section-header,.panel-headline,.attendance-head{margin-bottom:20px}.group-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px;display:grid}.group-card,.student-item,.lesson-card,.week-column,.attendance-row,.modal-card,.empty-state{border-radius:var(--radius-md);border:1px solid var(--line);background:var(--surface-alt)}.group-card{background:var(--surface);border-color:#e8edf3;gap:16px;padding:20px;display:grid;position:relative;overflow:hidden;box-shadow:0 8px 24px #0f172a0f}.group-card-topline{background:var(--group-accent,var(--brand));height:4px;position:absolute;top:0;left:0;right:0}.group-card-head{align-items:flex-start;gap:14px;padding-top:4px;display:flex}.group-card-icon{background:var(--group-accent-soft,var(--brand-soft));width:44px;height:44px;color:var(--group-accent,var(--brand));border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;font-size:1.15rem;display:inline-flex}.group-card-titles{min-width:0}.group-card-titles h3{color:var(--text);margin:0;font-size:1rem;font-weight:700;line-height:1.35}.group-card-titles p{color:var(--text-soft);margin:6px 0 0;font-size:.9rem;line-height:1.4}.group-card-stats{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.group-card-badge{background:var(--group-accent-soft,var(--brand-soft));min-height:36px;color:var(--group-accent,var(--brand));border-radius:999px;justify-content:center;align-items:center;gap:6px;padding:0 12px;font-size:.88rem;font-weight:600;display:inline-flex}.group-card-last-lesson{color:var(--text-soft);flex-wrap:wrap;align-items:center;gap:8px;margin:0;font-size:.9rem;display:flex}.group-card-last-lesson-date{color:var(--text);align-items:center;gap:6px;font-weight:500;display:inline-flex}.group-card-link{width:fit-content;color:var(--group-accent,var(--brand));align-items:center;gap:8px;margin-top:2px;font-weight:600;display:inline-flex}.group-card-link:hover{color:var(--group-accent,var(--brand-dark));opacity:.88}.week-column,.lesson-card,.student-item,.attendance-row{padding:18px}.lesson-card h3{margin:0;font-size:1.1rem;font-weight:700}.group-meta-minimal{color:var(--text-soft);font-size:.94rem}.button{border:1px solid var(--line);background:var(--surface);min-height:40px;color:var(--text);border-radius:999px;justify-content:center;align-items:center;gap:8px;padding:0 16px;font-weight:500;display:inline-flex}.button:hover:not(:disabled){border-color:var(--line-strong)}.button:disabled{opacity:.5;cursor:not-allowed}.button-primary{background:var(--brand);border-color:var(--brand);color:#fff}.button-primary:hover:not(:disabled){background:var(--brand-dark);border-color:var(--brand-dark)}.button-secondary,.button-ghost{background:var(--surface)}.button-danger{background:var(--danger-soft);color:var(--danger);border-color:#fecaca}.button-full{width:100%}.tab-shell{gap:24px;display:grid;overflow:hidden}.group-tabs{border-right:1px solid var(--line);border-bottom:1px solid var(--line);background:#ffffffb8;gap:0;width:fit-content;margin:-24px -24px 0;display:inline-flex}.group-tab{border:0;border-right:1px solid var(--line);min-width:170px;min-height:64px;color:var(--text-soft);background:0 0;border-radius:0;align-items:center;gap:8px;padding:0 28px;font-weight:700;display:inline-flex;position:relative}.group-tab span{background:#ffffffd9;border-radius:999px;justify-content:center;align-items:center;min-width:22px;height:22px;padding:0 6px;font-size:.8rem;display:inline-flex}.group-tab.active{background:var(--surface);color:var(--brand);box-shadow:none}.group-tab.active:after{content:"";background:var(--brand);height:3px;position:absolute;bottom:-1px;left:0;right:0}.tab-panel{min-height:360px}.group-view{gap:18px;display:grid}.material-list{gap:12px}.student-item{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.icon-button{border:1px solid var(--line);background:var(--surface);width:36px;height:36px;color:var(--text-soft);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.icon-button:hover{border-color:var(--line-strong);color:var(--brand-dark)}.student-name{margin:0;font-size:1rem;font-weight:600}.student-subline{margin-top:4px;font-size:.92rem}.schedule-toolbar{margin-bottom:18px}.journal-toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin-bottom:18px;display:flex}.panel-subtitle{color:var(--text-soft);margin:4px 0 0;font-size:.92rem}.journal-hint{border-radius:var(--radius-sm);min-height:42px;color:var(--text-soft);background:linear-gradient(90deg,#e6fffbc7,#fafbfcc7);border:1px solid #d8f3ef;align-items:center;gap:8px;padding:0 14px;font-size:.92rem;font-weight:600;display:flex}.journal-hint svg{color:var(--brand);flex:none}.tag,.status-chip{border:1px solid var(--line);background:var(--surface);min-height:36px;color:var(--text-soft);border-radius:999px;align-items:center;gap:8px;padding:0 12px;font-size:.9rem;display:inline-flex}.status-chip.success{color:var(--brand-dark);background:var(--brand-soft);border-color:#99f6e4}.attendance-pill{border:1px solid var(--line);background:var(--surface);min-height:34px;color:var(--text-soft);border-radius:999px;align-items:center;padding:0 12px;font-size:.9rem;display:inline-flex}.attendance-pill.present{background:var(--brand-soft);color:var(--brand-dark);border-color:#99f6e4}.attendance-pill.absent{background:var(--danger-soft);color:var(--danger);border-color:#fecaca}.week-grid-scroll{overflow-x:auto}.week-grid{grid-template-columns:repeat(7,minmax(170px,1fr));gap:12px;min-width:1220px;display:grid}.week-column{gap:14px;display:grid}.week-column-header h4{font-size:.98rem}.week-column-header p{margin-top:2px;font-size:.86rem}.day-add-button{border-radius:50%;min-width:36px;min-height:36px;padding:0}.schedule-empty{padding:10px 0 0;font-size:.9rem}.lesson-card{gap:12px;display:grid}.lesson-card-compact{padding:12px 14px;display:block}.lesson-card-compact-row{justify-content:space-between;align-items:center;gap:8px;display:flex}.attendance-head h3{margin:0;font-size:1.25rem}.lesson-homework{color:var(--text-soft);margin:6px 0 0}.lesson-homework strong{color:var(--text)}.lesson-sheet-head{border-bottom:1px solid var(--line);color:var(--text-soft);grid-template-columns:minmax(240px,1fr) 96px;gap:18px;padding:0 18px 12px;font-size:.92rem;display:grid}.lesson-sheet-head span:last-child{text-align:center}.lesson-sheet-row{grid-template-columns:minmax(240px,1fr) 96px;align-items:center;gap:18px;display:grid}.lesson-sheet-student{grid-template-columns:36px minmax(0,1fr);align-items:center;gap:14px;display:grid}.lesson-sheet-index{color:var(--text-soft);font-size:.95rem}.lesson-sheet-cell{border:1px solid var(--line);background:var(--surface);width:72px;height:72px;color:var(--text-soft);border-radius:16px;justify-content:center;justify-self:center;align-items:center;font-size:1.2rem;font-weight:700;display:inline-flex}.lesson-sheet-cell span{line-height:1}.lesson-sheet-cell-button{cursor:pointer}.lesson-sheet-cell-button:hover{border-color:var(--line-strong)}.lesson-sheet-cell.is-present,.lesson-sheet-cell.is-graded{color:var(--text)}.lesson-sheet-cell.is-present{background:var(--brand-soft);color:var(--brand-dark);border-color:#99f6e4}.lesson-sheet-cell.is-graded{border-color:var(--brand);color:var(--brand)}.lesson-sheet-cell.is-absent{background:var(--danger-soft);color:var(--danger);border-color:#fecaca}.entry-status-group{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.entry-status-button{border:1px solid var(--line);background:var(--surface);min-height:48px;color:var(--text);border-radius:14px}.entry-status-button.active{background:var(--brand-soft);color:var(--brand-dark);border-color:#99f6e4}.entry-status-button.entry-status-absent.active{background:var(--danger-soft);color:var(--danger);border-color:#fecaca}.journal-table-scroll{border:1px solid var(--line);border-radius:var(--radius-sm);overflow-x:auto}.journal-table{border-collapse:separate;border-spacing:0;width:max-content;min-width:100%}.journal-table th,.journal-table td{border-right:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--surface);text-align:center;vertical-align:middle;min-width:72px;padding:0}.journal-table tr>:last-child{border-right:0}.journal-table tbody tr:last-child>*{border-bottom:0}.journal-table thead th{z-index:2;background:#fbfcfd;position:sticky;top:0}.journal-table thead th:first-child,.journal-table tbody th{z-index:1;background:#fbfcfd;position:sticky;left:0}.journal-table thead th:first-child{z-index:3}.journal-table tr:first-child th{border-top:0}.journal-table tr>:first-child{border-left:0}.journal-student-head{text-align:center;min-width:240px;padding:14px 16px;font-weight:800}.journal-lesson-head{width:56px;min-width:56px;height:66px}.journal-student-cell{text-align:left;vertical-align:middle;min-width:240px;padding:0 16px}.journal-student-cell strong,.journal-student-copy span{display:block}.journal-student-wrap{gap:4px;display:grid}.journal-student-cell-minimal{white-space:nowrap;min-width:240px;height:56px}.journal-student-name{font-weight:600}.journal-row-index{color:var(--text-soft);flex:0 0 28px}.journal-student-copy{text-align:left;gap:4px;display:grid}.journal-student-copy span{color:var(--text-soft);font-size:.88rem}.journal-entry-cell{width:34px;height:34px;color:var(--text-soft);background:0 0;border:1px solid #0000;border-radius:12px;justify-content:center;align-items:center;font-size:1rem;font-weight:700;display:inline-flex}.journal-entry-cell.is-graded{background:var(--brand-soft);color:var(--brand-dark)}.journal-entry-cell.is-present{background:var(--brand-soft);color:var(--brand)}.journal-entry-cell.is-absent{background:var(--danger-soft);color:var(--danger)}.journal-entry-empty{border-color:var(--line);background:var(--surface);color:#9ca3af}button.journal-entry-cell{cursor:pointer}button.journal-entry-cell:hover{background:var(--brand-soft);color:var(--brand-dark);border-color:#99f6e4}.journal-date-head{padding:0}.journal-date-trigger{width:100%;height:100%;min-height:66px;color:var(--text-soft);background:0 0;border:0;flex-direction:column;justify-content:center;align-items:center;gap:3px;font-weight:600;display:inline-flex}.journal-date-weekday{color:var(--text-soft);font-size:.72rem;font-weight:700;line-height:1}.journal-date-markers{justify-content:center;align-items:center;gap:4px;min-height:18px;display:inline-flex}.journal-date-lesson-dot{background:var(--brand);border-radius:50%;width:8px;height:8px;display:block}.journal-date-trigger small{background:var(--surface);min-width:18px;height:18px;color:var(--text-soft);border-radius:50%;justify-content:center;align-items:center;font-size:.72rem;line-height:1;display:inline-flex}button.journal-date-trigger{cursor:pointer}button.journal-date-trigger:hover{color:var(--brand-dark);background:#0f766e0f}.journal-date-trigger.has-lesson{color:var(--brand)}.journal-topic-label{text-align:center;min-width:240px;height:56px;padding:0 16px;font-size:.88rem;font-weight:800}.journal-topic-row td{background:#fbfcfd;height:56px}.journal-topic-cell{overflow-wrap:anywhere;width:100%;max-width:72px;min-height:32px;color:var(--text-soft);background:0 0;border:0;justify-content:center;align-items:center;padding:4px 6px;font-size:.68rem;font-weight:700;line-height:1.2;display:inline-flex}.journal-topic-cell.has-topic{cursor:pointer;color:var(--text-soft)}.journal-topic-cell.has-topic:hover{color:var(--brand)}.journal-topic-add{border:1px solid var(--line);background:var(--surface);color:#9ca3af;border-radius:10px;justify-content:center;align-items:center;width:34px;height:34px;display:inline-flex}.journal-topic-add:hover{background:var(--brand-soft);color:var(--brand);border-color:#99f6e4}.journal-table .journal-col-today{background:var(--brand-soft);box-shadow:inset 0 0 0 2px #0f766e47}.journal-table thead .journal-col-today{background:#dff7f4}.journal-table thead .journal-col-today .journal-date-trigger{color:var(--brand-dark);font-weight:700}.journal-table tbody .journal-col-today .journal-entry-cell,.journal-table tbody .journal-col-today .journal-entry-empty{background:var(--brand-soft)}.journal-footer{border-top:1px solid var(--line);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:14px;padding-top:14px;display:flex}.journal-legend{color:var(--text-soft);flex-wrap:wrap;align-items:center;gap:22px;font-weight:600;display:flex}.journal-legend span{align-items:center;gap:8px;display:inline-flex}.legend-score,.legend-absent{border-radius:10px;justify-content:center;width:28px;height:28px;font-weight:800}.legend-score{background:var(--brand-soft);color:var(--brand-dark)}.legend-absent{background:var(--danger-soft);color:var(--danger)}.legend-topic-dot{background:var(--brand);border-radius:50%;width:8px;height:8px;display:inline-flex}.journal-homework-action{background:var(--brand-soft);color:var(--brand-dark);border-color:#ccfbf1;font-weight:700}.journal-summary{gap:12px;margin-top:24px;display:grid}.journal-summary h4{margin:0;font-size:1rem}.summary-card-grid{grid-template-columns:repeat(4,minmax(160px,1fr));gap:12px;display:grid}.summary-card{border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--surface);align-items:center;gap:12px;min-height:76px;padding:14px;display:flex}.summary-card div>span{color:var(--text-soft);font-size:.88rem;display:block}.summary-card strong{margin-top:2px;font-size:1.12rem;display:block}.summary-icon{border-radius:50%;flex:0 0 38px;justify-content:center;align-items:center;width:38px;height:38px;display:inline-flex}.summary-icon svg{width:18px;height:18px;display:block}.summary-icon.summary-icon-teal{background:var(--brand-soft);color:var(--brand-dark)}.summary-icon.summary-icon-green{color:#15803d;background:#e9fbe8}.summary-icon.summary-icon-violet{color:#6d28d9;background:#f1ecff}.summary-icon.summary-icon-red{background:var(--danger-soft);color:var(--danger)}.summary-table-scroll{border:1px solid var(--line);border-radius:var(--radius-sm);overflow-x:auto}.summary-table{border-collapse:collapse;background:var(--surface);width:100%;min-width:760px}.summary-table th,.summary-table td{border-bottom:1px solid var(--line);border-right:1px solid var(--line);text-align:center;padding:10px 12px}.summary-table th:first-child,.summary-table td:first-child{text-align:left}.summary-table thead th{background:var(--surface-alt);font-size:.9rem}.summary-table tbody tr:last-child th,.summary-table tbody tr:last-child td{border-bottom:0}.summary-table tr>:last-child{border-right:0}.summary-score-pill{background:var(--brand-soft);min-width:32px;height:26px;color:var(--brand-dark);border-radius:999px;justify-content:center;align-items:center;font-weight:700;display:inline-flex}.quran-layout{grid-template-columns:300px minmax(0,1fr);align-items:start;gap:24px;display:grid}.quran-sidebar{gap:18px;display:grid;position:sticky;top:16px}.quran-sidebar-note{color:var(--text-soft);margin:0;font-size:.92rem;line-height:1.55}.quran-audio-panel{border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--surface-alt);gap:10px;padding:14px;display:grid}.quran-audio-panel strong,.quran-audio-panel p{margin:0}.quran-audio-panel p{color:var(--text-soft);font-size:.92rem}.quran-player-actions{gap:8px;display:grid}.quran-audio-player{width:100%;height:40px;margin-top:2px}.quran-audio-player:not([src]){opacity:.55}.quran-ayah-play{border:1px solid var(--line);background:var(--surface);width:40px;height:40px;color:var(--brand);border-radius:50%;justify-content:center;align-self:start;align-items:center;display:inline-flex}.quran-ayah-play:hover:not(:disabled),.quran-ayah.highlighted .quran-ayah-play{background:var(--brand-soft);color:var(--brand-dark);border-color:#99f6e4}.quran-ayah-play:disabled{cursor:not-allowed;opacity:.45}.quran-ayah-meta{background:var(--surface-alt);width:fit-content;min-height:28px;color:var(--text-soft);border-radius:999px;align-items:center;padding:0 10px;font-size:.86rem;font-weight:700;display:inline-flex}.quran-reader{gap:18px;min-width:0;display:grid}.quran-reader-head{border-bottom:1px solid var(--line);justify-content:space-between;align-items:flex-start;gap:16px;padding-bottom:18px;display:flex}.quran-reader-head h3{margin:0;font-size:1.35rem}.quran-reader-head p{color:var(--text-soft);margin:4px 0 0}.quran-reader-icon{background:var(--brand-soft);width:42px;height:42px;color:var(--brand-dark);border-radius:50%;flex:0 0 42px;justify-content:center;align-items:center;display:inline-flex}.quran-ayah-list{display:grid}.quran-ayah{border-bottom:1px solid var(--line);grid-template-columns:48px minmax(0,1fr);gap:18px;padding:22px 0;display:grid}.quran-ayah.highlighted{border-radius:var(--radius-sm);background:var(--brand-soft);margin:0 -14px;padding-inline:14px}.quran-ayah-number{background:var(--surface-alt);width:38px;height:38px;color:var(--text-soft);border-radius:50%;justify-content:center;align-items:center;font-weight:700;display:inline-flex}.quran-ayah-copy{gap:12px;min-width:0;display:grid}.quran-arabic{color:var(--text);text-align:right;margin:0;font-family:Times New Roman,serif;font-size:2rem;line-height:2.05}.quran-translation{color:var(--text-soft);margin:0;font-size:1rem;line-height:1.75}.live-create-card,.live-join-card,.live-stage,.live-chat{gap:18px;display:grid}.live-create-form{gap:14px;max-width:520px;display:grid}.live-status-pill,.live-room-status{border:1px solid var(--line);background:var(--surface-alt);width:fit-content;min-height:34px;color:var(--text-soft);border-radius:999px;align-items:center;gap:8px;padding:0 12px;font-size:.92rem;font-weight:600;display:inline-flex}.live-room-created{border:1px solid var(--line);border-radius:var(--radius-md);background:var(--surface-alt);gap:10px;max-width:520px;padding:18px;display:grid}.live-room-created span{color:var(--text-soft)}.live-room-created strong{letter-spacing:.12em;font-size:clamp(2rem,6vw,3.2rem)}.live-public-shell,.live-room-shell{min-height:100vh}.live-public-main{place-items:center;min-height:calc(100vh - 130px);padding-top:20px;display:grid}.live-join-card,.live-missing-session{width:min(100%,520px)}.live-room-grid{grid-template-columns:minmax(0,1fr) 360px;gap:20px;margin-top:20px;display:grid}.live-stage-head{justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.live-stage-head h2{margin:0;font-size:clamp(1.45rem,3vw,2rem)}.live-stage-head p{color:var(--text-soft);margin:6px 0 0}.live-status-dot{background:var(--text-soft);border-radius:50%;width:9px;height:9px}.live-status-connected{background:#22c55e}.live-status-connecting,.live-status-reconnecting{background:#f59e0b}.live-status-failed,.live-status-disconnected{background:var(--danger)}.live-controls{flex-wrap:wrap;gap:10px;display:flex}.live-media-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:14px;display:grid}.live-media-tile,.live-empty-stage{border:1px solid var(--line);border-radius:var(--radius-md);background:#0f172a;overflow:hidden}.live-empty-stage{text-align:center;color:#fff;place-items:center;min-height:320px;padding:28px;display:grid}.live-empty-stage p{color:#cbd5e1;margin:6px 0 0}.live-media-frame{background:#020617;place-items:center;min-height:260px;display:grid}.live-video-element{object-fit:contain;background:#020617;width:100%;height:100%;max-height:520px;display:block}.live-audio-element{width:calc(100% - 24px)}.live-media-caption{background:var(--surface);justify-content:space-between;align-items:center;gap:12px;padding:12px 14px;display:flex}.live-media-caption span{color:var(--text-soft);font-size:.9rem}.live-chat{align-self:start;max-height:calc(100vh - 40px);position:sticky;top:20px}.live-chat-messages{align-content:start;gap:10px;min-height:320px;max-height:52vh;padding-right:4px;display:grid;overflow:auto}.live-chat-message{border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--surface-alt);gap:6px;padding:12px;display:grid}.live-chat-message div{justify-content:space-between;align-items:center;gap:10px;display:flex}.live-chat-message span{color:var(--text-soft);font-size:.82rem}.live-chat-message p{color:var(--text);margin:0}.live-chat-system{background:var(--brand-soft);color:var(--brand-dark);text-align:center;border-radius:999px;padding:9px 12px;font-size:.9rem}.live-chat-form{grid-template-columns:minmax(0,1fr) 46px;align-items:end;gap:10px;display:grid}.student-home{gap:18px}.student-homework-card{background:linear-gradient(#fff 0%,#f8fbff 100%);border-color:#bfdbfe;gap:16px;display:grid}.student-homework-icon{color:#1d4ed8;background:#eff6ff;border-radius:50%;justify-content:center;align-items:center;width:42px;height:42px;display:inline-flex}.student-homework-list{gap:10px;display:grid}.student-homework-columns{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;display:grid}.student-homework-section{align-content:start;gap:10px;min-width:0;display:grid}.student-homework-section h4{margin:0}.student-homework-item{border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--surface);gap:6px;padding:14px;display:grid}.student-homework-item p{color:var(--text-soft);overflow-wrap:anywhere;margin:0}.student-homework-item strong{overflow-wrap:anywhere}.student-week-grid{scrollbar-width:thin;grid-template-columns:repeat(7,minmax(128px,1fr));gap:12px;min-width:0;padding-bottom:4px;display:grid;overflow-x:auto}.student-day-card{border:1px solid var(--line);border-radius:var(--radius-md);background:var(--surface-alt);align-content:start;gap:12px;min-width:0;min-height:220px;padding:14px;display:grid}.student-day-card-today{background:var(--brand-soft);border-color:#99f6e4}.student-day-head{justify-content:space-between;align-items:flex-start;gap:10px;min-width:0;display:flex}.student-day-head div{gap:2px;min-width:0;display:grid}.student-day-head strong{overflow-wrap:anywhere;line-height:1.25}.student-day-head span{color:var(--text-soft);font-size:.9rem}.student-today-pill{background:var(--brand);border-radius:999px;flex:none;align-items:center;min-height:26px;padding:0 9px;font-weight:700;display:inline-flex;color:#fff!important;font-size:.78rem!important}.student-day-lessons{gap:8px;min-width:0;display:grid}.student-day-lesson{border-radius:var(--radius-sm);border:1px solid var(--line);background:var(--surface);grid-template-columns:22px minmax(0,1fr);gap:8px;min-width:0;padding:10px;display:grid;overflow:hidden}.student-day-lesson svg{color:var(--brand);flex-shrink:0;margin-top:2px}.student-day-lesson div{min-width:0}.student-day-lesson strong{overflow-wrap:anywhere;word-break:break-word;line-height:1.35;display:block}.student-day-lesson p{color:var(--text-soft);overflow-wrap:anywhere;word-break:break-word;margin:4px 0 0;font-size:.9rem;line-height:1.45}.student-day-empty{border:1px dashed var(--line-strong);border-radius:var(--radius-sm);min-height:92px;color:var(--text-soft);text-align:center;place-items:center;gap:6px;display:grid}.student-group-card-wrap{max-width:420px}.staff-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:14px;display:grid}.staff-card{border:1px solid var(--line);border-radius:var(--radius-md);background:var(--surface-alt);gap:14px;padding:18px;display:grid}.staff-card-head{justify-content:space-between;align-items:flex-start;gap:14px;display:flex}.staff-card-head h3,.staff-card-head p,.staff-note{margin:0}.staff-card-head h3{font-size:1.05rem}.staff-card-head p,.staff-note{color:var(--text-soft)}.staff-card-head>span{background:var(--brand-soft);min-height:28px;color:var(--brand-dark);white-space:nowrap;border-radius:999px;align-items:center;padding:0 10px;font-size:.84rem;font-weight:700;display:inline-flex}.staff-groups{flex-wrap:wrap;gap:8px;display:flex}.staff-groups span{border:1px solid var(--line);background:var(--surface);min-height:30px;color:var(--text-soft);border-radius:999px;align-items:center;padding:0 10px;font-size:.88rem;display:inline-flex}.staff-form{gap:14px;display:grid}.staff-form-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.staff-group-picker{border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--surface-alt);grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:8px;max-height:220px;padding:4px;display:grid;overflow:auto}.staff-group-option{border-radius:var(--radius-sm);background:var(--surface);min-height:38px;color:var(--text);align-items:center;gap:8px;padding:0 10px;display:flex}.staff-group-option input{accent-color:var(--brand)}.live-unavailable-shell{width:min(720px,100% - 32px);margin:40px auto}.input-stack{gap:8px;display:grid}.label{font-size:.92rem}.input-field,.textarea-field,.select-field{border-radius:var(--radius-sm);border:1px solid var(--line);background:var(--surface);width:100%;color:var(--text);padding:13px 14px}.input-field:focus,.textarea-field:focus,.select-field:focus{border-color:var(--brand);outline:none;box-shadow:0 0 0 3px #0f766e14}.textarea-field{resize:vertical;min-height:104px}.input-error{color:var(--danger);font-size:.88rem}.modal-overlay{z-index:40;background:#0f172a52;place-items:center;padding:24px;display:grid;position:fixed;inset:0}.modal-card{background:var(--surface);width:min(100%,520px);max-height:calc(100vh - 48px);padding:24px;overflow:auto}.modal-header{justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.modal-copy{gap:4px;display:grid}.modal-body{gap:14px;margin-top:20px;display:grid}.modal-body form .modal-actions{margin-top:12px}.danger-note{border-radius:var(--radius-md);background:var(--danger-soft);color:var(--danger);border:1px solid #fecaca;gap:6px;padding:14px;display:grid}.danger-note strong{color:var(--text)}.empty-state{text-align:center;padding:28px}.empty-state strong{margin-bottom:8px;display:block}.login-shell{place-items:center;min-height:100vh;padding:24px;display:grid}.login-card{border-radius:var(--radius-lg);border:1px solid var(--line);background:var(--surface);gap:24px;width:min(100%,440px);padding:28px;display:grid}.login-copy h1{margin:0;font-size:2rem}.login-copy p{color:var(--text-soft);margin-top:6px}.login-form{gap:16px;display:grid}.login-accounts{gap:12px;display:grid}.login-account{border-radius:var(--radius-md);border:1px solid var(--line);background:var(--surface-alt);gap:4px;padding:14px 16px;display:grid}.form-error{border-radius:var(--radius-sm);background:var(--danger-soft);color:var(--danger);border:1px solid #fecaca;padding:12px 14px}.pulse-in{animation:none}@media (width<=960px){.page-header,.section-header,.panel-headline,.schedule-toolbar,.student-item,.navbar-row,.modal-header{flex-direction:column;grid-template-columns:1fr;align-items:stretch}.lesson-sheet-head{display:none}.lesson-sheet-row{grid-template-columns:1fr;gap:12px}.lesson-sheet-student{grid-template-columns:28px minmax(0,1fr)}.lesson-sheet-cell{justify-self:start}.landing-header,.landing-hero,.landing-cta{flex-direction:column;grid-template-columns:1fr;align-items:stretch}.landing-hero,.benefit-grid,.steps-grid,.preview-columns,.summary-card-grid,.quran-layout,.live-room-grid{grid-template-columns:1fr}.quran-sidebar,.live-chat{max-height:none;position:static}.nav-links{justify-content:flex-start;width:100%}}@media (width<=720px){.app-shell,.landing-shell{width:min(100% - 20px,1180px);padding-top:12px}.surface,.page-header,.modal-card,.landing-header,.landing-hero,.landing-section,.landing-cta{padding:18px}.group-tabs{width:100%}.group-tab{flex:1 1 0;justify-content:center}.landing-copy h2{max-width:none;font-size:clamp(2.2rem,12vw,3.3rem)}.landing-nav,.hero-actions{width:100%}.landing-nav .button,.hero-actions .button{flex:1 1 0}.brand-block,.brand-copy{min-width:0}.brand-copy p{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.nav-links{grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:8px;display:grid}.nav-link,.nav-role{justify-content:center;width:100%;min-height:40px;padding-inline:10px}.quran-ayah{grid-template-columns:1fr;gap:12px}.quran-arabic{font-size:1.65rem}.live-stage-head{flex-direction:column;align-items:stretch}.live-controls{grid-template-columns:1fr;display:grid}.live-media-grid{grid-template-columns:1fr}.live-media-frame{min-height:220px}.live-chat-form,.staff-form-grid,.staff-group-picker,.student-homework-columns{grid-template-columns:1fr}.student-week-grid{grid-template-columns:1fr;overflow:visible}.student-day-card{min-height:auto}}
