.app-shell--teacher .content{max-width:1280px;padding:28px 32px}.app-shell--teacher .main{background:radial-gradient(ellipse 80% 50% at 100% 0,rgba(37,99,235,.04),transparent 50%),var(--c-bg)}.topbar--teacher{background:hsla(0,0%,100%,.85);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-block-end-color:rgba(226,232,240,.8)}.topbar--teacher .topbar__title{font-size:14px;font-weight:600;color:var(--c-text-muted)}.sidebar--teacher{width:272px;-webkit-border-end:none;border-inline-end:none;box-shadow:-4px 0 24px rgba(15,42,68,.06)}[dir=rtl] .sidebar--teacher{box-shadow:4px 0 24px rgba(15,42,68,.06)}.sidebar--teacher .sidebar__brand{height:72px;padding-inline:22px;background:var(--raqeem-primary)}.sidebar--teacher .brand-logo__mark{width:36px;height:36px}.sidebar--teacher .sidebar__profile{padding:18px 20px;background:linear-gradient(180deg,var(--c-surface-2) 0,var(--c-surface) 100%);-webkit-border-after:1px solid var(--c-border);border-block-end:1px solid var(--c-border)}.sidebar--teacher .sidebar__profile-name{font-size:14px;font-weight:700}.sidebar--teacher .sidebar__profile-role{-webkit-margin-before:4px;margin-block-start:4px;padding:2px 10px;font-size:10px;text-transform:uppercase;letter-spacing:.04em}.sidebar--teacher .sidebar__profile-school{-webkit-margin-before:4px;margin-block-start:4px;font-size:11px}.sidebar--teacher .sidebar__nav{padding:16px 14px}.sidebar--teacher .nav-section-title{font-size:10px;font-weight:700;letter-spacing:.08em;padding:14px 14px 6px;color:var(--c-text-faint)}.sidebar--teacher .nav-link{padding:10px 14px;-webkit-margin-after:2px;margin-block-end:2px;border-radius:10px;font-size:13.5px;gap:12px}.sidebar--teacher .nav-link__icon{width:20px;font-size:15px}.sidebar--teacher .nav-link--active{background:linear-gradient(135deg,var(--c-primary-soft) 0,#dbeafe 100%);color:var(--c-navy);font-weight:700;-webkit-border-start:none;border-inline-start:none;-webkit-padding-start:14px;padding-inline-start:14px;box-shadow:inset 0 0 0 1px rgba(37,99,235,.15)}.sidebar--teacher .nav-link:hover:not(.nav-link--active){background:var(--c-surface-2)}.teacher-workspace{display:flex;flex-direction:column;gap:20px}.t-page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap;-webkit-margin-after:4px;margin-block-end:4px}.t-page-header h1{font-size:26px;font-weight:800;color:var(--c-text);letter-spacing:-.02em;margin:0;line-height:1.2}.t-page-header p{margin:6px 0 0;font-size:14px;color:var(--c-text-muted);max-width:520px}.t-page-header__actions{flex-shrink:0}.t-search{min-width:220px;max-width:280px}.t-hero{position:relative;border-radius:16px;overflow:hidden;background:linear-gradient(135deg,#0f2a44,#1e4976 45%,#2563eb);color:#fff;box-shadow:0 8px 32px rgba(15,42,68,.25)}.t-hero__pattern{position:absolute;inset:0;opacity:.08;background-image:radial-gradient(circle at 20% 80%,#fff 1px,transparent 0),radial-gradient(circle at 80% 20%,#fff 1px,transparent 0);background-size:32px 32px;pointer-events:none}.t-hero__inner{position:relative;display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;padding:28px 32px}.t-hero__greeting{font-size:24px;font-weight:800;margin:0;letter-spacing:-.02em;line-height:1.2}.t-hero__meta{display:flex;align-items:center;flex-wrap:wrap;gap:10px;-webkit-margin-before:10px;margin-block-start:10px}.t-hero__school{font-size:13px;opacity:.85}.t-hero__date{font-size:12px;opacity:.7;padding:2px 10px;border-radius:999px;background:hsla(0,0%,100%,.12)}.t-hero__slot{-webkit-margin-before:16px;margin-block-start:16px}.t-hero__cta{flex-shrink:0}.t-hero-lesson{display:flex;align-items:center;gap:12px}.t-hero-lesson strong{display:block;font-size:16px}.t-hero-lesson__meta{display:block;font-size:13px;opacity:.8;-webkit-margin-before:2px;margin-block-start:2px}.t-hero-lesson--empty{margin:0;font-size:14px;opacity:.75}.btn--hero{display:inline-flex;align-items:center;justify-content:center;padding:12px 24px;border-radius:10px;font-weight:700;font-size:14px;background:#fff;color:var(--c-navy);border:none;box-shadow:0 4px 14px rgba(0,0,0,.15);transition:transform .12s ease,box-shadow .12s ease;cursor:pointer;text-decoration:none}.btn--hero:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(0,0,0,.2)}.btn--hero-ghost{background:hsla(0,0%,100%,.15);color:#fff;border:1px solid hsla(0,0%,100%,.3);box-shadow:none}.btn--hero-ghost:hover{background:hsla(0,0%,100%,.22)}.t-snapshot{display:grid;grid-template-columns:repeat(auto-fill,minmax(148px,1fr));grid-gap:12px;gap:12px}.t-stat-link{display:block;text-decoration:none;color:inherit;border-radius:12px;transition:transform .12s ease}.t-stat-link:hover{transform:translateY(-2px)}.t-stat{display:flex;align-items:flex-start;gap:12px;padding:16px 18px;background:var(--c-surface);border:1px solid var(--c-border);border-radius:12px;box-shadow:var(--shadow-sm);height:100%}.t-stat__icon{font-size:20px;line-height:1;flex-shrink:0;-webkit-margin-before:2px;margin-block-start:2px}.t-stat__body{display:flex;flex-direction:column;gap:4px;min-width:0}.t-stat__label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--c-text-faint);line-height:1.3}.t-stat__value{font-size:22px;font-weight:800;color:var(--c-text);letter-spacing:-.02em;line-height:1.1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.t-stat--amber{border-color:#fde68a;background:linear-gradient(135deg,#fff 0,var(--c-amber-soft) 100%)}.t-stat--blue{border-color:#bfdbfe;background:linear-gradient(135deg,#fff 0,var(--c-blue-soft) 100%)}.t-stat--green{border-color:#bbf7d0;background:linear-gradient(135deg,#fff 0,var(--c-green-soft) 100%)}.t-workspace-grid{display:grid;grid-template-columns:minmax(0,1fr) 320px;grid-gap:20px;gap:20px;align-items:start}.t-workspace-aside,.t-workspace-main{display:flex;flex-direction:column;gap:20px;min-width:0}.t-ws-card{background:var(--c-surface);border:1px solid var(--c-border);border-radius:14px;box-shadow:var(--shadow-sm);overflow:hidden}.t-ws-card--flush .t-ws-card__body{padding:0}.t-ws-card__head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:16px 20px;-webkit-border-after:1px solid var(--c-border);border-block-end:1px solid var(--c-border);background:linear-gradient(180deg,var(--c-surface) 0,var(--c-surface-2) 100%)}.t-ws-card__title{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:700;color:var(--c-text);margin:0}.t-ws-card__icon{font-size:16px}.t-ws-card__body{padding:16px 20px}.t-section__head{display:flex;align-items:center;justify-content:space-between;gap:12px;-webkit-margin-after:12px;margin-block-end:12px}.t-section__head h2{font-size:16px;font-weight:700;margin:0;color:var(--c-text)}.t-chip{display:inline-flex;align-items:center;gap:5px;padding:5px 10px;border-radius:999px;font-size:11px;font-weight:600;background:var(--c-surface-2);border:1px solid var(--c-border);color:var(--c-text-muted);transition:all .12s ease;white-space:nowrap}.t-chip:hover{background:var(--c-primary-soft);border-color:#bfdbfe;color:var(--c-primary)}.t-quick-grid{gap:8px}.t-next-work,.t-quick-grid{display:flex;flex-wrap:wrap}.t-next-work{align-items:center;justify-content:space-between;gap:16px}.t-next-work__actions{display:flex;flex-wrap:wrap;gap:8px}.t-msg-feed{display:flex;flex-direction:column}.t-msg{padding:12px 0;-webkit-border-after:1px solid var(--c-border);border-block-end:1px solid var(--c-border)}.t-msg:last-child{-webkit-border-after:none;border-block-end:none;-webkit-padding-after:0;padding-block-end:0}.t-msg__head{display:flex;align-items:center;justify-content:space-between;gap:8px;-webkit-margin-after:4px;margin-block-end:4px}.t-msg__channel{font-size:11px;font-weight:700;color:var(--c-primary);text-transform:uppercase;letter-spacing:.03em}.t-msg__time{font-size:10px;color:var(--c-text-faint);flex-shrink:0}.t-msg__sender{font-size:12px;font-weight:600;color:var(--c-text);-webkit-margin-after:2px;margin-block-end:2px}.t-msg__body{font-size:12px;color:var(--c-text-muted);line-height:1.45;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.t-empty .state--compact{background:transparent;border:none;box-shadow:none}.grid--class-preview{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));grid-gap:14px;gap:14px}.grid--class-preview[data-count="1"]{max-width:420px}.grid--class-cards{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));grid-gap:16px;gap:16px}.grid--class-cards[data-count="1"],.grid--class-cards[data-count="2"]{max-width:720px}.class-card{position:relative;border-radius:14px;padding:18px;gap:14px;overflow:hidden;transition:box-shadow .15s ease,border-color .15s ease}.class-card:hover{box-shadow:var(--shadow);border-color:#cbd5e1}.class-card__accent{position:absolute;inset-block-start:0;inset-inline:0;height:3px;background:linear-gradient(90deg,var(--c-primary) 0,#60a5fa 100%)}.class-card__head{gap:10px}.class-card__name{font-size:16px;font-weight:700;color:var(--c-text);letter-spacing:-.01em}.class-card__meta{gap:8px;-webkit-margin-before:4px;margin-block-start:4px;font-size:12px}.class-card__level{font-weight:600;color:var(--c-text-body)}.class-card__open{width:100%;padding:10px 16px;font-weight:700;border-radius:10px}.class-card__actions{grid-gap:6px;gap:6px;-webkit-padding-before:4px;padding-block-start:4px}.class-card__action{gap:4px;padding:10px 4px;border-radius:10px;font-weight:600;transition:background .12s ease,color .12s ease}.class-card__action:hover{background:var(--c-primary-soft)}.class-card__action-icon{font-size:18px;line-height:1}.class-card__action-label{line-height:1.2}.class-card__chips{display:flex;flex-wrap:wrap;gap:6px}.class-card--compact{padding:16px}.class-hub{display:flex;flex-direction:column;gap:16px}.class-hub__back{display:inline-flex;align-items:center;gap:4px;font-size:13px;font-weight:600;color:var(--c-text-muted);width:-moz-fit-content;width:fit-content;transition:color .12s ease}.class-hub__back:hover{color:var(--c-primary)}.class-hub__header{position:relative;gap:16px;border-radius:16px;padding:22px 24px;overflow:hidden}.class-hub__header-pattern{position:absolute;inset-block-start:0;inset-inline-end:0;width:200px;height:100%;opacity:.04;background:radial-gradient(circle at 70% 50%,var(--c-primary) 0,transparent 70%);pointer-events:none}.class-hub__title-row{display:flex;align-items:center;flex-wrap:wrap;gap:10px}.class-hub__header h1{font-size:22px;font-weight:800;line-height:1.25;margin:0;letter-spacing:-.02em}.class-hub__section-title{margin:4px 0 0}.class-hub__meta{-webkit-margin-before:8px;margin-block-start:8px}.class-hub__stat{font-size:13px;font-weight:500}.class-hub__header-actions{flex-shrink:0;position:relative;z-index:1}.t-seg-tabs{display:flex;width:100%;padding:5px;gap:4px;background:var(--c-surface-2);border:1px solid var(--c-border);border-radius:14px;overflow-x:auto;scrollbar-width:thin}.t-seg-tabs__item{flex:1 1;display:flex;align-items:center;justify-content:center;gap:6px;padding:10px 12px;min-width:80px;border-radius:10px;font-size:12.5px;font-weight:600;color:var(--c-text-muted);white-space:nowrap;transition:all .12s ease}.t-seg-tabs__item:hover:not(.t-seg-tabs__item--active){background:hsla(0,0%,100%,.7);color:var(--c-text)}.t-seg-tabs__item--active{background:var(--c-surface);color:var(--c-navy);box-shadow:0 2px 8px rgba(15,23,42,.08);font-weight:700}.t-seg-tabs__icon{font-size:14px;flex-shrink:0}.t-overview-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));grid-gap:14px;gap:14px;-webkit-margin-after:16px;margin-block-end:16px}.t-overview-chips{display:flex;flex-wrap:wrap;gap:6px}.t-overview-hint{margin:10px 0 0;font-size:12px}.t-overview-lesson{display:flex;flex-direction:column;gap:4px}.t-overview-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}.t-overview-list__item{display:flex;align-items:center;justify-content:space-between;gap:8px;font-size:13px;font-weight:600;color:var(--c-text);transition:color .12s ease}.t-overview-list__item:hover{color:var(--c-primary)}.t-overview-list__sub{display:block;font-size:11px;font-weight:400;-webkit-margin-before:2px;margin-block-start:2px}.t-overview-actions{display:flex;flex-wrap:wrap;gap:8px}.t-students-section{-webkit-margin-before:4px;margin-block-start:4px}.t-students-table table.data tbody tr{transition:background .1s ease}.t-students-table table.data tbody tr:hover{background:var(--c-surface-2)}.class-hub .table-wrap table.data td,.class-hub .table-wrap table.data th{padding:11px 14px}.grid--content-cards{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));grid-gap:12px;gap:12px}.t-content-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;-webkit-margin-after:12px;margin-block-end:12px;padding:10px 14px;background:var(--c-surface);border:1px solid var(--c-border);border-radius:10px}.t-content-count{font-size:12px;font-weight:600}.t-content-card{display:flex;flex-direction:column;gap:8px;padding:16px 18px;background:var(--c-surface);border:1px solid var(--c-border);border-radius:12px;box-shadow:var(--shadow-sm);height:100%;transition:box-shadow .15s ease,border-color .15s ease}.t-content-card--link{text-decoration:none;color:inherit}.t-content-card--link:hover{box-shadow:var(--shadow);border-color:#bfdbfe}.t-content-card__head{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}.t-content-card__title{font-size:14px;font-weight:700;color:var(--c-text);line-height:1.35}.t-content-card__meta{display:flex;flex-wrap:wrap;gap:8px;font-size:11px;color:var(--c-text-muted)}.t-content-card__footer{-webkit-margin-before:auto;margin-block-start:auto;-webkit-padding-before:4px;padding-block-start:4px}.t-form-panel{-webkit-margin-after:16px;margin-block-end:16px}.t-form__grid{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:14px;gap:14px}.t-form__field{display:flex;flex-direction:column;gap:6px}.t-form__field--wide{grid-column:1/-1}.t-form__label{font-size:12px;font-weight:600;color:var(--c-text-muted)}.t-form__hint{font-size:11px;color:var(--c-text-faint)}.t-form__check{display:flex;align-items:center;gap:8px;font-size:13px;grid-column:1/-1}.t-form__actions{display:flex;flex-wrap:wrap;gap:8px;-webkit-margin-before:16px;margin-block-start:16px;-webkit-padding-before:16px;padding-block-start:16px;-webkit-border-before:1px solid var(--c-border);border-block-start:1px solid var(--c-border)}.t-attendance-ws .attendance-toolbar--premium{-webkit-margin-after:16px;margin-block-end:16px;padding:14px 18px;border-radius:12px;background:var(--c-surface-2);border:1px solid var(--c-border)}.attendance-toolbar__label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--c-text-faint)}.t-attendance-ws .attendance-chips{-webkit-margin-after:14px;margin-block-end:14px}.t-attendance-ws .attendance-chip{padding:6px 14px;font-size:12px}.t-attendance-ws .table-wrap{border-radius:12px;overflow:hidden;border:1px solid var(--c-border)}.t-attendance-ws .save-bar--sticky{-webkit-margin-before:16px;margin-block-start:16px;border-radius:12px;padding:14px 18px;background:var(--c-surface);border:1px solid var(--c-border)}@media (max-width:900px){.app-shell--teacher .content{padding:16px}.t-hero__inner{padding:20px}.t-hero__greeting{font-size:20px}.t-workspace-grid{grid-template-columns:1fr}.t-workspace-aside{order:-1}.t-snapshot{grid-template-columns:repeat(2,1fr)}.t-form__grid{grid-template-columns:1fr}.t-seg-tabs__label{display:none}.t-seg-tabs__item{min-width:52px;padding:10px 8px}.class-card__actions{grid-template-columns:repeat(2,1fr)}.grid--class-cards[data-count="1"],.grid--class-cards[data-count="2"]{max-width:none}.sidebar--teacher{width:var(--sidebar-w)}}@media (max-width:480px){.t-snapshot{grid-template-columns:1fr 1fr}.t-stat__value{font-size:18px}}.teacher-workspace--overview{gap:16px}.t-overview-empty{display:flex;flex-direction:column;gap:14px;padding:32px 20px;text-align:center;background:var(--c-surface);border:1px dashed var(--c-border);border-radius:14px}.t-overview-class,.t-overview-empty,.t-overview-empty .t-empty .state--compact{align-items:center}.t-overview-class{display:inline-flex;padding:2px 8px;border-radius:999px;font-size:11px;font-weight:700;background:var(--c-surface-2);border:1px solid var(--c-border);color:var(--c-primary);transition:background .12s ease}.t-overview-class:hover{background:var(--c-primary-soft);border-color:#bfdbfe}.t-overview-filter{display:flex;align-items:center;gap:8px}.t-overview-filter__label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--c-text-faint);white-space:nowrap}.t-overview-filter .select{min-width:160px}.t-students-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));grid-gap:12px;gap:12px}.t-students-grid--preview{max-width:100%}.t-student-card{display:flex;align-items:center;gap:14px;padding:16px 18px;background:var(--c-surface);border:1px solid var(--c-border);border-radius:14px;box-shadow:var(--shadow-sm);text-decoration:none;color:inherit;transition:box-shadow .15s ease,border-color .15s ease,transform .12s ease}.t-student-card:hover{box-shadow:var(--shadow);border-color:#bfdbfe;transform:translateY(-1px)}.t-student-card__avatar-wrap .avatar{width:48px;height:48px;font-size:16px}.t-student-card__body{flex:1 1;min-width:0}.t-student-card__name{display:block;font-size:15px;font-weight:700;color:var(--c-text);line-height:1.3}.t-student-card__code{display:block;font-size:11px;color:var(--c-text-faint);-webkit-margin-before:2px;margin-block-start:2px}.t-student-card__meta{display:flex;flex-wrap:wrap;gap:6px;-webkit-margin-before:8px;margin-block-start:8px}.t-student-card__arrow{flex-shrink:0;font-size:20px;font-weight:700;color:var(--c-text-faint);transform:rotate(180deg);line-height:1}[dir=rtl] .t-student-card__arrow{transform:none}.t-student-hero{position:relative;display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;padding:28px 32px;border-radius:16px;overflow:hidden;background:linear-gradient(135deg,#1e3a5f,#2563eb 55%,#60a5fa);color:#fff;box-shadow:0 8px 28px rgba(37,99,235,.22);-webkit-margin-after:4px;margin-block-end:4px}.t-student-hero__pattern{position:absolute;inset:0;opacity:.07;background-image:radial-gradient(circle at 15% 50%,#fff 2px,transparent 0);background-size:28px 28px;pointer-events:none}.t-student-hero__main{position:relative;display:flex;align-items:center;gap:20px;min-width:0}.t-student-hero__avatar .avatar{width:72px;height:72px;font-size:24px;border:3px solid hsla(0,0%,100%,.35);box-shadow:0 4px 16px rgba(0,0,0,.15)}.t-student-hero__info h1{margin:0;font-size:24px;font-weight:800;letter-spacing:-.02em;line-height:1.2}.t-student-hero__meta{display:flex;align-items:center;flex-wrap:wrap;gap:10px;-webkit-margin-before:8px;margin-block-start:8px}.t-student-hero__code{font-size:13px;opacity:.85;padding:2px 10px;border-radius:999px;background:hsla(0,0%,100%,.15)}.t-attendance-pill{position:relative;z-index:1;display:flex;flex-direction:column;align-items:flex-end;gap:4px;padding:12px 18px;border-radius:12px;background:hsla(0,0%,100%,.95);color:var(--c-text);box-shadow:0 4px 12px rgba(0,0,0,.1);min-width:120px}.t-attendance-pill__label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--c-text-faint)}.t-attendance-pill__hint{font-size:10px;color:var(--c-text-muted)}.t-attendance-pill--present strong{color:var(--c-green)}.t-attendance-pill--absent strong{color:var(--c-red)}.t-attendance-pill--late strong{color:var(--c-amber)}.t-attendance-pill--left-early strong{color:var(--c-blue)}.t-student-actions{display:flex;flex-wrap:wrap;gap:8px;margin-block:4px 8px}.t-student-panels{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));grid-gap:14px;gap:14px}.t-student-attendance-detail{display:flex;flex-direction:column;gap:10px;align-items:flex-start}.t-student-attendance-detail .t-attendance-pill{background:var(--c-surface-2);box-shadow:none;border:1px solid var(--c-border);align-items:flex-start}.t-student-note{margin:0;font-size:13px;line-height:1.45}.t-student-hint{margin:0;font-size:12px}.t-student-activity{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.t-student-activity__item{-webkit-border-after:1px solid var(--c-border);border-block-end:1px solid var(--c-border);-webkit-padding-after:8px;padding-block-end:8px}.t-student-activity__item:last-child{-webkit-border-after:none;border-block-end:none;-webkit-padding-after:0;padding-block-end:0}.t-student-activity__link{display:block;text-decoration:none;color:inherit;padding:4px 0;border-radius:8px;transition:color .12s ease}.t-student-activity__link:hover{color:var(--c-primary)}.t-student-activity__head{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}.t-student-activity__head strong{font-size:13px;line-height:1.35}.t-student-activity__meta{display:flex;flex-wrap:wrap;gap:8px;-webkit-margin-before:4px;margin-block-start:4px;font-size:11px}.t-student-score{font-weight:700;color:var(--c-text-body)}@media (max-width:900px){.t-student-hero{flex-direction:column;align-items:stretch;padding:20px}.t-attendance-pill{align-items:flex-start;width:100%}.t-student-panels{grid-template-columns:1fr}}.admin-workspace{--admin-accent:var(--raqeem-primary);--admin-accent-soft:#e8edf5;--admin-hero-bg:linear-gradient(135deg,var(--raqeem-primary) 0%,#2d4f82 100%);display:flex;flex-direction:column;gap:10px;max-width:100%}.admin-workspace--dashboard{gap:10px;position:relative;overflow-x:clip;isolation:isolate}.admin-workspace--dashboard .info-banner{-webkit-margin-after:2px;margin-block-end:2px}.admin-workspace--dashboard .admin-dashboard-tail,.admin-workspace--dashboard .admin-hero,.admin-workspace--dashboard .admin-ops-grid,.admin-workspace--dashboard .admin-section,.admin-workspace--dashboard>*{position:relative;z-index:auto;flex-shrink:0;min-width:0}.admin-dashboard-tail{display:flex;flex-direction:column;gap:12px;width:100%;position:relative}.admin-workspace .section{margin:0}.admin-section{display:flex;flex-direction:column;gap:6px}.admin-section__head{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}.admin-section__title{font-size:14px;font-weight:700;color:var(--c-text);margin:0}.admin-section__action{font-size:12px;font-weight:600;color:var(--c-primary);text-decoration:none}.admin-section__action:hover{text-decoration:underline}.admin-hero{background:var(--admin-hero-bg);color:#fff;border-radius:14px;padding:16px 18px;display:grid;grid-template-columns:1fr auto;grid-gap:14px 16px;gap:14px 16px;align-items:start;box-shadow:0 4px 20px rgba(30,58,95,.22);overflow:hidden;isolation:isolate}.admin-hero__main{display:flex;flex-direction:column;gap:6px;min-width:0}.admin-hero__eyebrow{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;opacity:.85}.admin-hero__title{font-size:18px;font-weight:800;line-height:1.25;margin:0;color:#fff}.admin-hero__meta{font-size:12px;opacity:.9;display:flex;flex-wrap:wrap;gap:8px 14px}.admin-hero__summary{font-size:13px;opacity:.92;margin:4px 0 0;line-height:1.45}.admin-hero__kpis{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.admin-hero__kpi{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;border-radius:8px;background:hsla(0,0%,100%,.14);font-size:12px;font-weight:600;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.admin-hero__kpi strong{font-size:15px;font-weight:800}.admin-hero__kpi--green strong{color:#bbf7d0}.admin-hero__kpi--red strong{color:#fecaca}.admin-hero__kpi--amber strong{color:#fde68a}.admin-hero__kpi--blue strong{color:#bfdbfe}.admin-hero__actions{display:flex;flex-direction:column;gap:6px;align-items:stretch;min-width:168px}@media (min-width:640px){.admin-hero__actions{flex-direction:row;flex-wrap:wrap;justify-content:flex-end}.admin-hero__btn{flex:1 1 140px;max-width:200px}}.admin-hero__btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 14px;border-radius:9px;font-size:12px;font-weight:700;text-decoration:none;border:none;cursor:pointer;white-space:nowrap}.admin-hero__btn--primary{background:#fff;color:var(--admin-accent)}.admin-hero__btn--ghost{background:hsla(0,0%,100%,.12);color:#fff;border:1px solid hsla(0,0%,100%,.28)}.admin-ops-grid{display:grid;grid-template-columns:1.2fr .8fr;grid-gap:10px;gap:10px;align-items:start}@media (max-width:960px){.admin-hero{grid-template-columns:1fr}.admin-hero__actions{flex-direction:row;flex-wrap:wrap}.admin-ops-grid{grid-template-columns:1fr}}.admin-card{background:var(--c-surface);border:1px solid var(--c-border);border-radius:12px;padding:12px 14px;display:flex;flex-direction:column;gap:8px}.admin-card--accent{border-color:#bfdbfe;background:linear-gradient(180deg,#f8fbff,#fff)}.admin-card--intervention{border-color:#fde68a;background:linear-gradient(180deg,#fffbeb,#fff 85%)}.admin-card--intervention .admin-card__title{color:#92400e;font-size:14px}.admin-card__footer-secondary{-webkit-margin-before:4px;margin-block-start:4px;-webkit-padding-before:10px;padding-block-start:10px;-webkit-border-before:1px solid hsla(48,97%,77%,.65);border-block-start:1px solid hsla(48,97%,77%,.65)}.admin-card__secondary-link{font-size:12px;font-weight:600;color:var(--c-text-muted);text-decoration:none}.admin-card__secondary-link:hover{color:var(--admin-accent);text-decoration:underline}.admin-card__title{font-size:13px;font-weight:700;margin:0;color:var(--c-text)}.admin-card__desc{font-size:12px;color:var(--c-text-muted);margin:0;line-height:1.4}.admin-kpi-strip{display:flex;flex-wrap:wrap;gap:8px}.admin-kpi{flex:1 1 72px;min-width:72px;padding:8px 10px;border-radius:9px;background:var(--c-surface-2);text-align:center}.admin-kpi--green{background:#ecfdf5;color:#065f46}.admin-kpi--red{background:#fef2f2;color:#991b1b}.admin-kpi--amber{background:#fffbeb;color:#92400e}.admin-kpi--blue{background:#eff6ff;color:#1e40af}.admin-kpi__value{display:block;font-size:18px;font-weight:800;line-height:1.1}.admin-kpi__label{display:block;font-size:10px;font-weight:600;margin-top:3px;opacity:.9}.admin-kpi-strip__foot{display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap;font-size:12px;color:var(--c-text-muted)}.admin-kpi-strip__pct{font-weight:700;color:var(--c-primary)}.admin-action-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}.admin-action-item{display:flex;align-items:flex-start;gap:10px;padding:9px 10px;border-radius:9px;background:var(--c-surface-2);font-size:13px;line-height:1.35}.admin-action-item--link{text-decoration:none;color:inherit;transition:background .15s}.admin-action-item--link:hover{background:var(--admin-accent-soft)}.admin-action-item--amber{-webkit-border-start:3px solid var(--c-amber);border-inline-start:3px solid var(--c-amber)}.admin-action-item__icon{flex-shrink:0;font-size:14px}.admin-action-item__body{flex:1 1;min-width:0}.admin-action-item__hint{display:block;font-size:11px;color:var(--c-text-muted);margin-top:2px}.admin-empty-hint{font-size:13px;color:var(--c-text-muted);margin:0;padding:8px 0}.admin-action-item--amber .admin-action-item__body{font-weight:600}.admin-school-strip{display:grid;grid-template-columns:repeat(4,1fr);grid-gap:10px;gap:10px}@media (max-width:720px){.admin-school-strip{grid-template-columns:repeat(2,1fr)}}.admin-school-cell{display:flex;flex-direction:column;align-items:center;gap:4px;padding:12px 10px;border-radius:10px;background:var(--c-surface);border:1px solid var(--c-border);text-decoration:none;color:inherit;transition:border-color .15s,box-shadow .15s}.admin-school-cell:hover{border-color:var(--c-primary);box-shadow:0 2px 8px rgba(37,99,235,.12)}.admin-school-cell__value{font-size:22px;font-weight:800;color:var(--admin-accent);line-height:1}.admin-school-cell__label{font-size:11px;font-weight:600;color:var(--c-text-muted);text-align:center}.admin-school-cell__icon{font-size:18px}.admin-academic-grid{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:8px;gap:8px}.admin-academic-metric{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:8px 10px;border-radius:8px;background:var(--c-surface-2);text-decoration:none;color:inherit;font-size:12px}.admin-academic-metric:hover{background:var(--admin-accent-soft)}.admin-academic-metric strong{font-size:16px;font-weight:800;color:var(--admin-accent)}.admin-academic-metric--warn strong{color:var(--c-amber)}.admin-next-exam{padding:10px 12px;border-radius:8px;background:var(--c-surface-2);display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:4px}.admin-quick-row{display:flex;flex-wrap:wrap;gap:8px}.admin-quick-action{display:inline-flex;align-items:center;gap:6px;padding:7px 12px;border-radius:8px;border:1px solid var(--c-border);background:var(--c-surface);font-size:12px;font-weight:600;text-decoration:none;color:var(--c-text);transition:background .15s,border-color .15s}.admin-quick-action:hover{border-color:var(--c-primary);background:var(--admin-accent-soft)}.admin-workspace--dashboard .admin-section--academic{-webkit-margin-after:2px;margin-block-end:2px}.admin-workspace--dashboard .admin-section--messages{margin-block:8px 0}.admin-workspace--dashboard .admin-section--messages .card{overflow:hidden}.admin-workspace .msg-feed{max-height:220px;overflow-y:auto;overflow-x:hidden;overscroll-behavior:contain}.admin-workspace .msg-feed__item{padding:10px 14px}.admin-workspace--dashboard .admin-section--quick-ops{-webkit-margin-before:0;margin-block-start:0;-webkit-padding-before:12px;padding-block-start:12px;-webkit-border-before:1px solid var(--c-border);border-block-start:1px solid var(--c-border)}.admin-workspace--dashboard .admin-quick-row{position:static;inset:auto;width:100%;margin:0;padding:0;background:transparent;box-shadow:none;transform:none}.admin-workspace--dashboard .admin-quick-action{position:static;z-index:auto;transform:none}.app-shell--admin .sidebar{border-inline-end-color:#cbd5e1}.app-shell--admin .sidebar__brand{background:var(--admin-accent)}.app-shell--admin .nav-link--active{background:var(--admin-accent-soft);color:var(--admin-accent);font-weight:700;-webkit-border-start:3px solid var(--admin-accent);border-inline-start:3px solid var(--admin-accent);-webkit-padding-start:9px;padding-inline-start:9px}.app-shell--admin .nav-section-title{color:#64748b}.content--admin{max-width:1280px}.sidebar--admin .sidebar__profile-role{color:var(--c-primary);font-weight:600}.admin-attendance-ops,.admin-attendance-page{gap:12px;overflow-x:clip;position:relative}.admin-att-ops-header{background:linear-gradient(135deg,#1e3a5f,#2563eb 58%,#1d4ed8);color:#fff;border-radius:14px;padding:14px 16px;display:grid;grid-template-columns:1fr auto;grid-gap:12px 16px;gap:12px 16px;align-items:start;box-shadow:0 4px 18px rgba(30,58,95,.2);overflow:hidden}.admin-att-ops-header__eyebrow{font-size:11px;font-weight:600;opacity:.88}.admin-att-ops-header__title{font-size:20px;font-weight:800;margin:4px 0 0;line-height:1.2;color:#fff}.admin-att-ops-header__subtitle{font-size:13px;margin:4px 0 0;opacity:.92}.admin-att-ops-header__meta{display:flex;flex-wrap:wrap;gap:8px 16px;margin-top:8px;font-size:12px;opacity:.95}.admin-att-ops-header__actions{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end;align-items:center}.admin-att-ops-header__btn--active{box-shadow:0 0 0 2px hsla(0,0%,100%,.35)}.admin-att-ops-summary{background:var(--c-surface);border:1px solid var(--c-border);border-radius:12px;padding:12px 14px}.admin-att-ops-summary--empty{text-align:center;background:var(--c-surface-2);border-style:dashed}.admin-att-ops-summary__empty-title{margin:0;font-size:14px;font-weight:600;color:var(--c-text-muted)}.admin-att-ops-summary__empty-hint{margin:6px 0 0;font-size:12px;color:var(--c-text-faint)}.admin-att-ops-summary__head{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;margin-bottom:10px}.admin-att-ops-summary__title{font-size:13px;font-weight:700;margin:0;color:var(--c-text)}.admin-att-ops-summary__pct{font-size:12px;font-weight:700;color:var(--c-primary)}.admin-att-ops-summary__grid{display:grid;grid-template-columns:repeat(5,1fr);grid-gap:8px;gap:8px}@media (max-width:720px){.admin-att-ops-header{grid-template-columns:1fr}.admin-att-ops-summary__grid{grid-template-columns:repeat(2,1fr)}}.admin-att-ops-kpi{padding:10px 8px;border-radius:9px;text-align:center;border:1px solid var(--c-border);background:var(--c-surface-2)}.admin-att-ops-kpi--green{background:#ecfdf5;border-color:#a7f3d0}.admin-att-ops-kpi--red{background:#fef2f2;border-color:#fecaca}.admin-att-ops-kpi--amber{background:#fffbeb;border-color:#fde68a}.admin-att-ops-kpi--blue{background:#eff6ff;border-color:#bfdbfe}.admin-att-ops-kpi--total{background:var(--c-surface)}.admin-att-ops-kpi__value{display:block;font-size:20px;font-weight:800;line-height:1.1}.admin-att-ops-kpi__label{display:block;font-size:10px;font-weight:600;margin-top:3px;color:var(--c-text-muted)}.admin-att-ops-summary__scope{margin:8px 0 0;font-size:11px;color:var(--c-text-faint)}.admin-att-ops-filters{background:var(--c-surface);border:1px solid var(--c-border);border-radius:12px;padding:12px 14px}.admin-att-ops-filters__title{font-size:13px;font-weight:700;margin:0 0 10px}.admin-att-ops-filters__row{-webkit-margin-after:0;margin-block-end:0;align-items:flex-end}.admin-att-ops-field{display:flex;flex-direction:column;gap:4px;min-width:140px}.admin-att-ops-field__label{font-size:11px;font-weight:600;color:var(--c-text-muted)}.admin-att-ops-filters__reset{align-self:flex-end}.admin-att-ops-correction{background:#fffbeb;border:1px solid #fde68a;border-radius:12px;padding:12px 14px;display:flex;flex-direction:column;gap:12px}.admin-att-ops-correction__banner{display:flex;flex-direction:column;gap:4px}.admin-att-ops-correction__badge{display:inline-flex;align-self:flex-start;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.04em;padding:3px 8px;border-radius:6px;background:#fef3c7;color:#92400e}.admin-att-ops-correction__hint{margin:0;font-size:12px;color:#92400e}.admin-att-ops-table-section{display:flex;flex-direction:column;gap:10px}.admin-att-ops-table-section__title{font-size:13px;font-weight:700;margin:0}.admin-att-ops-table-wrap{background:var(--c-surface);border:1px solid var(--c-border);border-radius:12px;overflow:hidden}.admin-att-ops-table-wrap table{width:100%}.admin-att-table__student{font-size:13px}.admin-att-table__note{font-size:12px;color:var(--c-text-muted);max-width:200px;display:inline-block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.admin-att-ops-empty{display:flex;flex-direction:column;align-items:center;gap:8px;padding:24px 16px;text-align:center;background:var(--c-surface-2);border:1px dashed var(--c-border);border-radius:12px}.admin-att-ops-empty__icon{font-size:28px}.admin-att-ops-empty__title{margin:0;font-size:15px;font-weight:700}.admin-att-ops-empty__desc{margin:0;font-size:13px;color:var(--c-text-muted);max-width:360px}.admin-att-ops-loading{padding:24px;text-align:center}.content--admin .page-header,.content--admin .toolbar{-webkit-margin-after:12px;margin-block-end:12px}.school-switcher{display:inline-flex;align-items:center;gap:8px;-webkit-margin-end:8px;margin-inline-end:8px}.school-switcher__label{font-size:12px;color:var(--c-text-muted);white-space:nowrap}.school-switcher__select{min-width:140px;max-width:220px}.admin-readonly-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));grid-gap:12px;gap:12px}.admin-readonly-card{display:flex;flex-direction:column;gap:6px;padding:16px;border:1px solid var(--c-border);border-radius:var(--radius-md);background:var(--c-surface);text-decoration:none;color:inherit;transition:border-color .15s,box-shadow .15s}.admin-readonly-card:hover{border-color:var(--c-primary);box-shadow:var(--shadow-sm)}.admin-readonly-card__icon{font-size:22px}.admin-readonly-card__label{font-size:12px;color:var(--c-text-muted)}.admin-readonly-card__value{font-size:22px;font-weight:700}:root{--raqeem-primary:#243b6b;--raqeem-secondary:#24a6a1;--raqeem-accent:#f2a541;--raqeem-background:#f6f8fc;--c-bg:var(--raqeem-background);--c-surface:#fff;--c-surface-2:#eef2f8;--c-border:#e2e8f0;--c-text:#0f172a;--c-text-body:#334155;--c-text-muted:#64748b;--c-text-faint:#94a3b8;--c-navy:var(--raqeem-primary);--c-primary:var(--raqeem-primary);--c-primary-dark:#1a2d52;--c-primary-soft:#e8edf5;--c-green:#16a34a;--c-green-soft:#ecfdf5;--c-red:#dc2626;--c-red-soft:#fef2f2;--c-amber:#d97706;--c-amber-soft:#fffbeb;--c-blue:#2563eb;--c-blue-soft:#eff6ff;--c-slate-soft:#f1f5f9;--c-info:#0284c7;--c-info-soft:#e0f2fe;--c-purple:#7c3aed;--c-purple-soft:#f5f3ff;--radius:12px;--radius-sm:8px;--shadow-sm:0 1px 2px rgba(15,23,42,.06);--shadow:0 4px 16px rgba(15,23,42,.08);--shadow-md:0 8px 24px rgba(15,23,42,.12);--sidebar-w:256px;--topbar-h:60px}*{box-sizing:border-box}body,html{margin:0;padding:0}html[dir=rtl] body{font-family:var(--font-arabic),Cairo,Arial,sans-serif}html[dir=ltr] body{font-family:var(--font-latin),Inter,Arial,sans-serif}body{background:var(--c-bg);color:var(--c-text-body);font-size:14px;line-height:1.6;-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}h1,h2,h3,h4{margin:0;color:var(--c-text);font-weight:650}.app-shell{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-w);flex-shrink:0;background:var(--c-surface);-webkit-border-end:1px solid var(--c-border);border-inline-end:1px solid var(--c-border);display:flex;flex-direction:column;position:-webkit-sticky;position:sticky;inset-block-start:0;height:100vh}.sidebar__brand{height:var(--topbar-h);display:flex;align-items:center;gap:10px;padding-inline:20px;-webkit-border-after:1px solid hsla(0,0%,100%,.1);border-block-end:1px solid hsla(0,0%,100%,.1);font-weight:700;font-size:15px;text-decoration:none;color:#fff;background:var(--c-navy)}.brand-logo__full{display:block;height:36px;width:auto;max-width:100%;object-fit:contain;object-position:start center;flex-shrink:1;min-width:0}.brand-logo__mark{display:block;width:32px;height:32px;object-fit:contain;flex-shrink:0}.sidebar__brand .brand-logo__full{height:34px}.sidebar--teacher .sidebar__brand .brand-logo__full{height:40px}.sidebar__scope{padding:10px 16px 14px;-webkit-border-before:1px solid var(--c-border);border-block-start:1px solid var(--c-border);font-size:11px;color:var(--c-text-muted);display:flex;flex-direction:column;gap:3px}.sidebar__scope-label{font-weight:600;font-size:10px;text-transform:uppercase;letter-spacing:.05em;color:var(--raqeem-accent)}.sidebar__scope-desc{color:var(--c-text-faint);font-size:11px;line-height:1.4}.sidebar__nav{padding:12px;overflow-y:auto;flex:1 1}.nav-section-title{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--c-text-faint);padding:10px 12px 4px}.nav-link{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:var(--radius-sm);color:var(--c-text-muted);font-weight:500;-webkit-margin-after:1px;margin-block-end:1px;transition:background .1s ease,color .1s ease}.nav-link:hover{background:var(--c-surface-2);color:var(--c-text)}.nav-link--active{background:var(--c-primary-soft);color:var(--c-navy);font-weight:600;-webkit-border-start:3px solid var(--raqeem-secondary);border-inline-start:3px solid var(--raqeem-secondary);-webkit-padding-start:9px;padding-inline-start:9px}.nav-link__icon{width:18px;text-align:center;flex-shrink:0}.main{flex:1 1;min-width:0;display:flex;flex-direction:column}.topbar{height:var(--topbar-h);background:var(--c-surface);-webkit-border-after:1px solid var(--c-border);border-block-end:1px solid var(--c-border);box-shadow:0 1px 4px rgba(15,23,42,.04);display:flex;align-items:center;justify-content:space-between;padding-inline:24px;position:-webkit-sticky;position:sticky;inset-block-start:0;z-index:20}.topbar__title{font-size:15px;font-weight:700;color:var(--c-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:320px}.topbar__right{gap:14px}.topbar__right,.user-chip{display:flex;align-items:center}.user-chip{gap:10px}.avatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--c-primary) 0,var(--c-navy) 100%);color:#fff;display:grid;place-items:center;font-size:13px;font-weight:600;flex-shrink:0}.content{padding:24px;max-width:1180px;width:100%;margin-inline:auto}.page-header{-webkit-margin-after:24px;margin-block-end:24px;-webkit-padding-after:20px;padding-block-end:20px;-webkit-border-after:1px solid var(--c-border);border-block-end:1px solid var(--c-border)}.page-header h1{font-size:24px;color:var(--c-text)}.page-header p{margin:4px 0 0;color:var(--c-text-muted);font-size:14px}.card{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius);box-shadow:var(--shadow-sm)}.card--pad{padding:20px}.card.row-link{transition:box-shadow .15s ease,border-color .15s ease}.card.row-link:hover{box-shadow:var(--shadow);border-color:#bfdbfe}.grid{display:grid;grid-gap:16px;gap:16px}.grid--stats{grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.grid--cards{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.grid--form{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px}.stat-card{display:flex;flex-direction:column;gap:6px;padding:20px}.stat-card__label{color:var(--c-text-muted);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;display:flex;align-items:center;gap:8px}.stat-card__value{font-size:30px;font-weight:800;line-height:1;color:var(--c-text)}.section{-webkit-margin-before:28px;margin-block-start:28px}.section__head{display:flex;align-items:center;justify-content:space-between;-webkit-margin-after:14px;margin-block-end:14px}.section__head h2{font-size:15px;color:var(--c-text);font-weight:700}.table-wrap{overflow-x:auto;border-radius:var(--radius)}table.data{width:100%;border-collapse:collapse;background:var(--c-surface);font-size:13.5px}table.data th{text-align:start;font-weight:600;font-size:12px;letter-spacing:.03em;color:var(--c-text-muted);background:var(--c-surface-2);padding:11px 14px;white-space:nowrap}table.data td,table.data th{-webkit-border-after:1px solid var(--c-border);border-block-end:1px solid var(--c-border)}table.data td{padding:12px 14px;vertical-align:middle}table.data tbody tr:last-child td{-webkit-border-after:none;border-block-end:none}table.data tbody tr:hover{background:var(--c-surface-2)}.row-link{cursor:pointer}.badge{display:inline-flex;align-items:center;gap:5px;padding:2px 9px;border-radius:999px;font-size:12px;font-weight:600;line-height:1.6}.badge--green{background:var(--c-green-soft);color:var(--c-green);border:1px solid #bbf7d0}.badge--red{background:var(--c-red-soft);color:var(--c-red);border:1px solid #fecaca}.badge--amber{background:var(--c-amber-soft);color:var(--c-amber);border:1px solid #fde68a}.badge--blue{background:var(--c-blue-soft);color:var(--c-blue);border:1px solid #bfdbfe}.badge--slate{background:var(--c-slate-soft);color:var(--c-text-muted);border:1px solid var(--c-border)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:9px 16px;border-radius:var(--radius-sm);border:1px solid transparent;font-size:14px;font-weight:600;cursor:pointer;font-family:inherit;transition:background .12s ease,border-color .12s ease,box-shadow .12s ease;white-space:nowrap}.btn:disabled{opacity:.55;cursor:not-allowed}.btn--primary{background:var(--c-primary);color:#fff}.btn--primary:not(:disabled):hover{background:var(--c-primary-dark)}.btn--ghost{background:transparent;color:var(--c-text-muted);border-color:var(--c-border)}.btn--ghost:not(:disabled):hover{background:var(--c-surface-2);color:var(--c-text)}.btn--sm{padding:6px 12px;font-size:13px}.btn--block{width:100%}.btn--status-green{background:var(--c-green-soft);color:var(--c-green);border-color:#bbf7d0}.btn--status-green.btn--status-active,.btn--status-green:not(:disabled):hover{background:var(--c-green);color:#fff;border-color:var(--c-green)}.btn--status-red{background:var(--c-red-soft);color:var(--c-red);border-color:#fecaca}.btn--status-red.btn--status-active,.btn--status-red:not(:disabled):hover{background:var(--c-red);color:#fff;border-color:var(--c-red)}.btn--status-amber{background:var(--c-amber-soft);color:var(--c-amber);border-color:#fde68a}.btn--status-amber.btn--status-active,.btn--status-amber:not(:disabled):hover{background:var(--c-amber);color:#fff;border-color:var(--c-amber)}.btn--status-blue{background:var(--c-blue-soft);color:var(--c-blue);border-color:#bfdbfe}.btn--status-blue.btn--status-active,.btn--status-blue:not(:disabled):hover{background:var(--c-blue);color:#fff;border-color:var(--c-blue)}.field{display:flex;flex-direction:column;gap:6px;-webkit-margin-after:14px;margin-block-end:14px}.field label{font-size:13px;font-weight:600;color:var(--c-text)}.input,.select,.textarea{width:100%;padding:10px 12px;border:1px solid var(--c-border);border-radius:var(--radius-sm);font-size:14px;font-family:inherit;background:var(--c-surface);color:var(--c-text)}.input:focus,.select:focus,.textarea:focus{outline:none;border-color:var(--c-primary);box-shadow:0 0 0 3px var(--c-primary-soft)}.toolbar{display:flex;flex-wrap:wrap;gap:10px;align-items:center;-webkit-margin-after:16px;margin-block-end:16px}.toolbar .input,.toolbar .select{width:auto;min-width:160px}.spacer{flex:1 1}.stat-card--green{-webkit-border-start:3px solid var(--c-green);border-inline-start:3px solid var(--c-green);background:var(--c-green-soft)}.stat-card--red{-webkit-border-start:3px solid var(--c-red);border-inline-start:3px solid var(--c-red);background:var(--c-red-soft)}.stat-card--amber{-webkit-border-start:3px solid var(--c-amber);border-inline-start:3px solid var(--c-amber);background:var(--c-amber-soft)}.stat-card--blue{-webkit-border-start:3px solid var(--c-blue);border-inline-start:3px solid var(--c-blue);background:var(--c-blue-soft)}.stat-card--slate{-webkit-border-start:3px solid var(--c-border);border-inline-start:3px solid var(--c-border);background:var(--c-slate-soft)}.stat-card--green .stat-card__value{color:var(--c-green)}.stat-card--red .stat-card__value{color:var(--c-red)}.stat-card--amber .stat-card__value{color:var(--c-amber)}.stat-card--blue .stat-card__value{color:var(--c-blue)}.stat-link{display:block;text-decoration:none;color:inherit;border-radius:var(--radius);transition:transform .12s ease,box-shadow .12s ease}.stat-link:hover .stat-card{box-shadow:var(--shadow-md);transform:translateY(-1px)}.info-banner{display:flex;align-items:flex-start;gap:10px;padding:11px 14px;border-radius:var(--radius-sm);background:var(--c-primary-soft);border:1px solid #bfdbfe;border-inline-start-width:4px;border-inline-start-color:var(--c-primary);color:#1e40af;font-size:13px;line-height:1.5;-webkit-margin-after:16px;margin-block-end:16px}.info-banner__icon{flex-shrink:0;font-size:15px;line-height:1.5}.info-banner__body{display:flex;flex-direction:column;gap:2px}.info-banner__title{font-weight:600;font-size:13px}.info-banner__desc{font-size:12.5px;opacity:.85;line-height:1.45}.info-banner--amber{background:var(--c-amber-soft);border-color:#fde68a;border-inline-start-color:var(--c-amber);color:#92400e}.info-banner--green{background:var(--c-green-soft);border-color:#bbf7d0;border-inline-start-color:var(--c-green);color:#14532d}.tabs{display:flex;gap:2px;padding:3px;background:var(--c-surface-2);border:1px solid var(--c-border);border-radius:var(--radius-sm);-webkit-margin-after:20px;margin-block-end:20px;width:-moz-fit-content;width:fit-content;flex-wrap:wrap}.tab{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border-radius:6px;font-size:13px;font-weight:500;color:var(--c-text-muted);cursor:pointer;transition:color .12s ease;text-decoration:none}.tab:hover{color:var(--c-text)}.tab--active{background:var(--c-surface);color:var(--c-primary);font-weight:600;box-shadow:var(--shadow-sm)}.msg-feed{display:flex;flex-direction:column}.msg-feed__item{padding:14px 18px;-webkit-border-after:1px solid var(--c-border);border-block-end:1px solid var(--c-border);transition:background .1s ease}.msg-feed__item:last-child{-webkit-border-after:none;border-block-end:none}.msg-feed__item:hover{background:var(--c-surface-2)}.msg-feed__meta{display:flex;align-items:baseline;justify-content:space-between;gap:8px;-webkit-margin-after:2px;margin-block-end:2px}.msg-feed__channel{font-weight:600;font-size:13px;color:var(--c-text)}.msg-feed__time{color:var(--c-text-faint);font-size:11px;white-space:nowrap;flex-shrink:0}.msg-feed__sender{color:var(--c-text-muted);font-size:12px;-webkit-margin-after:4px;margin-block-end:4px}.msg-feed__body{font-size:14px;line-height:1.5;color:var(--c-text)}.save-bar{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius-sm);-webkit-margin-before:16px;margin-block-start:16px;gap:12px;transition:background .15s ease,border-color .15s ease}.save-bar--dirty{background:var(--c-amber-soft);border-color:#fde68a}.save-bar__status{font-size:13px;color:var(--c-text-muted);display:flex;align-items:center;gap:6px}.save-bar--dirty .save-bar__status{color:#92400e;font-weight:500}.channel-card--public{-webkit-border-start:3px solid var(--c-blue);border-inline-start:3px solid var(--c-blue)}.channel-card--class{-webkit-border-start:3px solid var(--c-green);border-inline-start:3px solid var(--c-green)}.channel-card--teachers{-webkit-border-start:3px solid var(--c-purple);border-inline-start:3px solid var(--c-purple)}.channel-card--parents{-webkit-border-start:3px solid var(--c-amber);border-inline-start:3px solid var(--c-amber)}.channel-card--announcement{-webkit-border-start:3px solid var(--c-red);border-inline-start:3px solid var(--c-red)}.channel-card--private{-webkit-border-start:3px solid var(--c-border);border-inline-start:3px solid var(--c-border)}.state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:48px 24px;gap:10px;color:var(--c-text-muted)}.state__icon{font-size:28px;-webkit-margin-after:4px;margin-block-end:4px;line-height:1;font-family:Apple Color Emoji,Segoe UI Emoji,Noto Color Emoji,sans-serif}.state-icon{width:52px;height:52px;border-radius:14px;display:grid;place-items:center;font-size:22px;-webkit-margin-after:10px;margin-block-end:10px;box-shadow:var(--shadow-sm)}.state-icon--error{background:var(--c-red-soft);color:var(--c-red)}.state-icon--warning{background:var(--c-amber-soft);color:var(--c-amber)}.state-icon--empty{background:var(--c-slate-soft);color:var(--c-text-faint)}.state-icon--lock{background:var(--c-amber-soft);color:var(--c-amber)}.state-icon--session{background:var(--c-primary-soft);color:var(--c-primary)}.state__title{font-size:16px;font-weight:700;color:var(--c-text)}.state__desc{max-width:380px;text-align:center;line-height:1.6}.spinner{width:26px;height:26px;border:3px solid var(--c-border);border-top-color:var(--raqeem-secondary);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.skeleton{background:linear-gradient(90deg,#eef1f6 25%,#f6f8fc 37%,#eef1f6 63%);background-size:400% 100%;animation:shimmer 1.2s ease infinite;border-radius:6px}@keyframes shimmer{0%{background-position:100% 0}to{background-position:0 0}}.toast-host{position:fixed;inset-block-end:20px;inset-inline-end:20px;display:flex;flex-direction:column;gap:8px;z-index:100}.toast{background:var(--c-text);color:#fff;padding:11px 12px 11px 16px;border-radius:var(--radius-sm);box-shadow:var(--shadow-md);font-size:13.5px;max-width:360px;display:flex;align-items:flex-start;gap:10px;animation:toast-in .2s ease}@keyframes toast-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.toast__body{flex:1 1;line-height:1.4}.toast__dismiss{flex-shrink:0;background:none;border:none;color:hsla(0,0%,100%,.7);cursor:pointer;font-size:16px;line-height:1;padding:0 2px;font-family:inherit;transition:color .12s;-webkit-margin-before:-1px;margin-block-start:-1px}.toast__dismiss:hover{color:#fff}.toast--error{background:var(--c-red)}.toast--success{background:var(--c-green)}.login-wrap{min-height:100vh;display:grid;place-items:center;padding:24px;background:var(--raqeem-background)}.login-card{width:100%;max-width:400px;background:var(--c-surface);border:1px solid var(--c-border);border-radius:20px;box-shadow:0 20px 60px rgba(15,42,68,.12),0 4px 16px rgba(15,23,42,.06);padding:36px}.login-card__brand{-webkit-margin-after:6px;margin-block-end:6px}.login-card__brand .brand-logo__full{height:52px;max-width:100%}.login-card h1{font-size:22px;-webkit-margin-before:18px;margin-block-start:18px;color:var(--c-text)}.login-card p.sub{color:var(--c-text-muted);margin:4px 0 24px}.form-error{background:var(--c-red-soft);color:var(--c-red);padding:10px 12px;border-radius:var(--radius-sm);font-size:13px;-webkit-margin-after:14px;margin-block-end:14px}.chat{display:flex;flex-direction:column;height:calc(100vh - var(--topbar-h) - 48px);min-height:420px}.chat__messages{flex:1 1;overflow-y:auto;padding:18px;display:flex;flex-direction:column;gap:12px}.msg{max-width:78%;padding:10px 14px;border-radius:var(--radius);background:var(--c-surface-2);border:1px solid var(--c-border)}.msg__meta{display:flex;gap:8px;align-items:baseline;-webkit-margin-after:3px;margin-block-end:3px}.msg__sender{font-weight:650;font-size:13px}.msg__time{color:var(--c-text-faint);font-size:11px}.msg__body{font-size:14px;white-space:pre-wrap;word-break:break-word}.chat__composer{padding:12px;gap:10px;align-items:flex-end}.chat__composer,.chat__readonly{-webkit-border-before:1px solid var(--c-border);border-block-start:1px solid var(--c-border);display:flex}.chat__readonly{padding:12px 18px;align-items:center;justify-content:center;gap:8px;color:var(--c-text-muted);font-size:13px;background:var(--c-surface-2);font-style:italic}.chat__readonly-icon{font-size:14px;font-style:normal;flex-shrink:0}.muted{color:var(--c-text-muted)}.faint{color:var(--c-text-faint)}.tiny{font-size:12px}.mono{font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.row{align-items:center;gap:10px}.col,.row{display:flex}.col{flex-direction:column;gap:4px}.between{display:flex;align-items:center;justify-content:space-between;gap:12px}.wrap-gap{display:flex;flex-wrap:wrap;gap:8px}.mt-2{-webkit-margin-before:8px;margin-block-start:8px}.mt-4{-webkit-margin-before:16px;margin-block-start:16px}.mt-6{-webkit-margin-before:24px;margin-block-start:24px}.dl{display:grid;grid-template-columns:160px 1fr;grid-gap:10px 16px;gap:10px 16px}.dl dt{color:var(--c-text-muted)}.dl dd{margin:0;font-weight:500}.class-actions{display:flex;flex-wrap:wrap;gap:8px;-webkit-margin-before:12px;margin-block-start:12px}.class-actions__btn{display:inline-flex;align-items:center;gap:6px}.sidebar__profile{display:flex;align-items:center;gap:12px;padding:14px 16px;-webkit-border-after:1px solid var(--c-border);border-block-end:1px solid var(--c-border);background:var(--c-surface-2)}.sidebar__profile-info{display:flex;flex-direction:column;gap:2px;min-width:0}.sidebar__profile-name{font-weight:600;font-size:13px;color:var(--c-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar__profile-role{display:inline-flex;align-items:center;width:-moz-fit-content;width:fit-content;padding:1px 8px;border-radius:999px;font-size:11px;font-weight:600;background:var(--c-primary-soft);color:var(--c-primary)}.sidebar__profile-school{font-size:11px;color:var(--c-text-faint);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.teacher-workspace{width:100%}.teacher-workspace .page-header{-webkit-margin-after:12px;margin-block-end:12px;-webkit-padding-after:10px;padding-block-end:10px}.teacher-workspace .page-header h1{font-size:20px}.teacher-workspace .page-header p{font-size:13px;-webkit-margin-before:2px;margin-block-start:2px}.teacher-workspace--classes .page-header{-webkit-margin-after:8px;margin-block-end:8px}.teacher-dash-header{-webkit-margin-after:14px;margin-block-end:14px}.teacher-dash-header h1{font-size:20px;font-weight:700}.teacher-dash-header p{margin:2px 0 0;color:var(--c-text-muted);font-size:13px}.teacher-dash-header__school{display:inline-block;-webkit-margin-before:4px;margin-block-start:4px;font-size:12px;color:var(--c-text-faint)}.teacher-dash-panel{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius);padding:14px 16px;box-shadow:var(--shadow-sm)}.teacher-dash-stats{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));grid-gap:10px;gap:10px}.teacher-workspace .stat-card{padding:12px 14px;gap:4px}.teacher-workspace .stat-card__label{font-size:10px}.teacher-workspace .stat-card__value{font-size:22px}.stat-card-link{display:block;text-decoration:none;color:inherit;border-radius:var(--radius-sm);transition:transform .12s ease}.stat-card-link:hover{transform:translateY(-1px)}.stat-card-link .stat-card{height:100%}.teacher-dash-actions{display:flex;flex-wrap:wrap;gap:8px;-webkit-margin-before:12px;margin-block-start:12px;-webkit-padding-before:12px;padding-block-start:12px;-webkit-border-before:1px solid var(--c-border);border-block-start:1px solid var(--c-border)}.teacher-dash-grid{display:grid;grid-template-columns:minmax(0,1fr) 300px;grid-gap:14px;gap:14px;align-items:start;-webkit-margin-before:14px;margin-block-start:14px}.teacher-dash-main{min-width:0;display:flex;flex-direction:column;gap:14px}.teacher-dash-aside{min-width:0}.teacher-dash-aside .section__head{-webkit-margin-after:8px;margin-block-end:8px}.teacher-section{-webkit-margin-before:0;margin-block-start:0}.teacher-section .section__head{-webkit-margin-after:8px;margin-block-end:8px}.teacher-section .section__head h2{font-size:14px}.grid--class-preview{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,280px));justify-content:start;grid-gap:10px;gap:10px}.grid--class-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,300px));justify-content:start;grid-gap:12px;gap:12px}.grid--class-cards[data-count="1"],.grid--class-cards[data-count="2"]{grid-template-columns:repeat(auto-fill,minmax(260px,300px));max-width:640px}.grid--content-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,320px));justify-content:start;grid-gap:10px;gap:10px}.next-lesson-card{display:flex;flex-wrap:wrap;align-items:center;gap:12px;padding:14px 16px;-webkit-border-start:4px solid var(--c-primary);border-inline-start:4px solid var(--c-primary);-webkit-margin-after:0;margin-block-end:0}.next-lesson-card--empty{border-inline-start-color:var(--c-border)}.next-lesson-card__badge{flex-shrink:0}.next-lesson-card__body{flex:1 1;min-width:140px}.next-lesson-card__subject{font-size:16px;display:block}.next-lesson-card__class{margin:2px 0 0;font-size:12px;color:var(--c-text-muted)}.next-lesson-card__actions{display:flex;flex-wrap:wrap;gap:6px}.msg-empty-card,.msg-feed-card{-webkit-margin-before:0;margin-block-start:0}.msg-empty-card{background:transparent;border:none;box-shadow:none;padding:0}.msg-empty-card .state--compact{background:var(--c-surface-2);border-radius:var(--radius-sm)}.teacher-dash-aside .msg-feed__item{padding:10px 12px}.class-card{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius);padding:14px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:10px}.class-card__head{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}.class-card__name{font-size:14px;display:block}.class-card__meta{display:flex;flex-wrap:wrap;gap:6px;-webkit-margin-before:3px;margin-block-start:3px;font-size:11px;color:var(--c-text-muted)}.class-card__actions{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:4px;gap:4px;-webkit-padding-before:2px;padding-block-start:2px;-webkit-border-before:1px solid var(--c-border);border-block-start:1px solid var(--c-border)}.class-card__action{display:flex;flex-direction:column;align-items:center;gap:3px;padding:6px 2px;border-radius:var(--radius-sm);font-size:10px;color:var(--c-text-muted);text-align:center;transition:background .1s ease,color .1s ease}.class-card__action:hover{background:var(--c-surface-2);color:var(--c-primary)}.class-card__action-label{line-height:1.15}.class-hub{width:100%}.class-hub__header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;-webkit-margin-after:10px;margin-block-end:10px;flex-wrap:wrap;background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius);padding:12px 16px;box-shadow:var(--shadow-sm)}.class-hub__header h1{font-size:18px;line-height:1.3}.class-hub__section-title{margin:2px 0 0;font-size:13px;color:var(--c-text-muted);font-weight:500}.class-hub__meta{display:flex;align-items:center;flex-wrap:wrap;gap:8px;-webkit-margin-before:4px;margin-block-start:4px}.class-hub__stat{font-size:12px;color:var(--c-text-muted)}.class-hub__actions{flex-shrink:0}.class-hub__tabs{display:flex;width:100%;max-width:100%;-webkit-margin-after:12px;margin-block-end:12px;padding:4px;gap:3px;background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius);box-shadow:var(--shadow-sm);flex-wrap:nowrap;overflow-x:auto;scrollbar-width:thin}.class-hub__tabs .tab{flex:1 1;justify-content:center;padding:7px 8px;min-width:72px;font-size:12px;white-space:nowrap;border-radius:6px}.class-hub__tabs .tab__icon{flex-shrink:0;font-size:13px}.class-hub__tabs .tab__label{overflow:hidden;text-overflow:ellipsis}.class-hub__tabs .tab--active{background:var(--c-primary-soft);color:var(--c-navy);border:1px solid #bfdbfe;box-shadow:none}.class-hub__body{min-width:0}.class-hub-quick{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));grid-gap:8px;gap:8px;-webkit-margin-after:14px;margin-block-end:14px}.class-hub-quick__item{display:flex;align-items:center;gap:6px;padding:10px 12px;background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius-sm);font-size:12px;font-weight:500;color:var(--c-text-body);transition:border-color .12s ease,box-shadow .12s ease}.class-hub-quick__item:hover{border-color:#bfdbfe;box-shadow:var(--shadow-sm)}.class-hub-section-title{font-size:14px;font-weight:700;-webkit-margin-after:8px;margin-block-end:8px;color:var(--c-text)}.create-panel{-webkit-margin-after:12px;margin-block-end:12px;padding:14px 16px}.content-card{padding:12px 14px;height:100%}.content-card__meta{display:flex;flex-wrap:wrap;gap:8px;-webkit-margin-before:6px;margin-block-start:6px;font-size:11px;color:var(--c-text-muted)}.back-link--compact{-webkit-margin-after:8px;margin-block-end:8px}.state--compact{padding:18px 14px;gap:6px}.state--compact .state-icon{width:40px;height:40px;border-radius:10px;font-size:18px}.state--compact .state__title{font-size:14px}.state--compact .state__desc{font-size:12px;max-width:360px}.attendance-toolbar{display:flex;align-items:center;flex-wrap:wrap;gap:10px;padding:10px 14px;background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius-sm);-webkit-margin-after:12px;margin-block-end:12px}.attendance-toolbar__field{display:flex;align-items:center;gap:8px;font-size:13px}.attendance-chips{display:flex;flex-wrap:wrap;gap:6px;-webkit-margin-after:10px;margin-block-end:10px}.attendance-chip{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:999px;font-size:11px;font-weight:500;border:1px solid var(--c-border);background:var(--c-surface)}.class-hub .table-wrap table.data td,.class-hub .table-wrap table.data th{padding:9px 12px}.attendance-chip--present{background:var(--c-green-soft);border-color:#bbf7d0;color:var(--c-green)}.attendance-chip--absent{background:var(--c-red-soft);border-color:#fecaca;color:var(--c-red)}.attendance-chip--late{background:var(--c-amber-soft);border-color:#fde68a;color:var(--c-amber)}.attendance-chip--left_early{background:var(--c-blue-soft);border-color:#bfdbfe;color:var(--c-blue)}.save-bar--sticky{position:-webkit-sticky;position:sticky;inset-block-end:12px;z-index:10;box-shadow:var(--shadow)}.attachment-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}.attachment-list__item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 12px;background:var(--c-surface-2);border-radius:var(--radius-sm)}.attachment-list__meta{display:flex;flex-direction:column;gap:2px;min-width:0}.attachment-list__name{font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.attachment-list__leading{display:flex;align-items:center;gap:10px;min-width:0;flex:1 1}.attachment-list__actions{flex-shrink:0}.attachment-thumb{flex-shrink:0;object-fit:cover;border-radius:var(--radius-sm)}.attachment-thumb,.attachment-thumb--icon{background:var(--c-surface);border:1px solid var(--c-border)}.attachment-thumb--icon{display:inline-flex;align-items:center;justify-content:center;border-radius:var(--radius-sm)}.attachment-indicator{display:flex;align-items:center;gap:8px;-webkit-margin-before:8px;margin-block-start:8px;flex-wrap:wrap}.attachment-indicator--compact{-webkit-margin-before:0;margin-block-start:0}.attachment-indicator__thumb{object-fit:cover;border-radius:var(--radius-sm);border:1px solid var(--c-border);flex-shrink:0}.attachment-indicator__icon{font-size:16px;line-height:1}.attachment-indicator__badge{font-size:12px;color:var(--c-muted);white-space:nowrap}.attachment-indicator__name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:160px}.modal-overlay{position:fixed;inset:0;z-index:1000;background:rgba(15,23,42,.55);display:flex;align-items:center;justify-content:center;padding:16px}.modal-content{background:var(--c-surface);border-radius:var(--radius-md);border:1px solid var(--c-border);width:min(560px,100%);max-height:min(90vh,720px);display:flex;flex-direction:column;box-shadow:0 20px 40px rgba(0,0,0,.18)}.modal-content--wide{width:min(920px,100%)}.modal-content__header{padding:12px 16px;border-bottom:1px solid var(--c-border)}.modal-content__body{padding:16px;overflow:auto;flex:1 1}.modal-content__footer{padding:12px 16px;border-top:1px solid var(--c-border)}.attachment-preview-image{display:block;max-width:100%;max-height:70vh;margin:0 auto;border-radius:var(--radius-sm)}.attachment-preview-frame{width:100%;min-height:480px;border:none}.attachment-preview-frame,.attachment-preview-text{border-radius:var(--radius-sm);background:var(--c-surface-2)}.attachment-preview-text{white-space:pre-wrap;word-break:break-word;font-size:13px;line-height:1.5;max-height:60vh;overflow:auto;margin:0;padding:12px}.resource-embed-wrap{position:relative;width:100%;padding-bottom:56.25%;height:0;overflow:hidden;border-radius:var(--radius-sm);background:#000}.resource-embed-frame{position:absolute;inset:0;width:100%;height:100%;border:none}.resource-link-card{gap:12px;flex-wrap:wrap}.input--sm{padding:6px 10px;font-size:13px}.result-edit{align-items:center}.topbar__role{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--c-primary);background:var(--c-primary-soft);padding:2px 7px;border-radius:4px;border:1px solid #bfdbfe}.locale-switcher{display:flex;align-items:center;gap:6px}.locale-switcher--compact .locale-switcher__select{font-size:12px;padding:4px 8px;max-width:120px}.timetable-slot__meta{display:flex;flex-wrap:wrap;gap:10px;-webkit-margin-before:8px;margin-block-start:8px;font-size:13px;color:var(--c-text-muted)}.timetable-slot--current{border-color:var(--c-green);background:var(--c-green-soft);box-shadow:0 0 0 2px rgba(22,163,74,.15)}.timetable-slot--next{border-color:var(--c-blue);background:var(--c-blue-soft);box-shadow:0 0 0 2px rgba(37,99,235,.12)}.timetable-day{-webkit-margin-after:20px;margin-block-end:20px}.timetable-day__title{font-size:15px;margin-block:0 10px;color:var(--c-text)}.timetable-day__slots{display:flex;flex-direction:column;gap:10px}.timetable-week{display:flex;flex-direction:column;gap:4px}.back-link{display:inline-flex;align-items:center;gap:6px;color:var(--c-text-muted);font-size:13px;-webkit-margin-after:12px;margin-block-end:12px}.back-link:hover{color:var(--c-primary)}.pagination{justify-content:flex-end;gap:10px;-webkit-margin-before:14px;margin-block-start:14px;font-size:13px;color:var(--c-text-muted)}.avatar-list,.pagination{display:flex;align-items:center}.avatar-list .avatar{width:28px;height:28px;font-size:11px;-webkit-margin-start:-6px;margin-inline-start:-6px;border:2px solid var(--c-surface)}.avatar-list .avatar:first-child{-webkit-margin-start:0;margin-inline-start:0}.menu-toggle{display:none}@media (max-width:900px){.sidebar{position:fixed;inset-inline-start:0;inset-block-start:0;z-index:50;transform:translateX(-110%);transition:transform .2s ease;box-shadow:var(--shadow-md)}[dir=rtl] .sidebar{transform:translateX(110%)}.sidebar--open{transform:translateX(0)!important}.menu-toggle{display:inline-flex}.content{padding:16px}.scrim{position:fixed;inset:0;background:rgba(15,23,42,.4);z-index:40}.tabs{width:100%}.topbar__title{max-width:180px}.info-banner{flex-direction:column;gap:6px}.save-bar{flex-wrap:wrap}.grid--stats{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}.teacher-dash-grid{grid-template-columns:1fr;gap:12px}.teacher-dash-aside{order:-1}.class-card__actions{grid-template-columns:repeat(2,1fr)}.class-hub__tabs .tab{min-width:64px;font-size:11px;padding:6px}.class-hub__tabs .tab__label{display:none}.grid--class-cards[data-count="1"],.grid--class-cards[data-count="2"]{max-width:none}}@font-face{font-family:Plus Jakarta Sans;font-style:normal;font-weight:200 800;font-display:swap;src:url(/_next/static/media/6fe53d21e6e7ebd8-s.woff2) format("woff2");unicode-range:u+0460-052f,u+1c80-1c8a,u+20b4,u+2de0-2dff,u+a640-a69f,u+fe2e-fe2f}@font-face{font-family:Plus Jakarta Sans;font-style:normal;font-weight:200 800;font-display:swap;src:url(/_next/static/media/8ebc6e9dde468c4a-s.woff2) format("woff2");unicode-range:u+0102-0103,u+0110-0111,u+0128-0129,u+0168-0169,u+01a0-01a1,u+01af-01b0,u+0300-0301,u+0303-0304,u+0308-0309,u+0323,u+0329,u+1ea0-1ef9,u+20ab}@font-face{font-family:Plus Jakarta Sans;font-style:normal;font-weight:200 800;font-display:swap;src:url(/_next/static/media/9e7b0a821b9dfcb4-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:Plus Jakarta Sans;font-style:normal;font-weight:200 800;font-display:swap;src:url(/_next/static/media/636a5ac981f94f8b-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:Plus Jakarta Sans Fallback;src:local("Arial");ascent-override:98.88%;descent-override:21.15%;line-gap-override:0.00%;size-adjust:104.98%}.__className_646807{font-family:Plus Jakarta Sans,Plus Jakarta Sans Fallback,Inter,Arial,sans-serif;font-style:normal}.__variable_646807{--font-latin:"Plus Jakarta Sans","Plus Jakarta Sans Fallback",Inter,Arial,sans-serif}@font-face{font-family:IBM Plex Sans Arabic;font-style:normal;font-weight:400;font-display:swap;src:url(/_next/static/media/9da48a48bf6500f8-s.p.woff2) format("woff2");unicode-range:u+06??,u+0750-077f,u+0870-088e,u+0890-0891,u+0897-08e1,u+08e3-08ff,u+200c-200e,u+2010-2011,u+204f,u+2e41,u+fb50-fdff,u+fe70-fe74,u+fe76-fefc,u+102e0-102fb,u+10e60-10e7e,u+10ec2-10ec4,u+10efc-10eff,u+1ee00-1ee03,u+1ee05-1ee1f,u+1ee21-1ee22,u+1ee24,u+1ee27,u+1ee29-1ee32,u+1ee34-1ee37,u+1ee39,u+1ee3b,u+1ee42,u+1ee47,u+1ee49,u+1ee4b,u+1ee4d-1ee4f,u+1ee51-1ee52,u+1ee54,u+1ee57,u+1ee59,u+1ee5b,u+1ee5d,u+1ee5f,u+1ee61-1ee62,u+1ee64,u+1ee67-1ee6a,u+1ee6c-1ee72,u+1ee74-1ee77,u+1ee79-1ee7c,u+1ee7e,u+1ee80-1ee89,u+1ee8b-1ee9b,u+1eea1-1eea3,u+1eea5-1eea9,u+1eeab-1eebb,u+1eef0-1eef1}@font-face{font-family:IBM Plex Sans Arabic;font-style:normal;font-weight:400;font-display:swap;src:url(/_next/static/media/9efac92d680e57b6-s.woff2) format("woff2");unicode-range:u+0460-052f,u+1c80-1c8a,u+20b4,u+2de0-2dff,u+a640-a69f,u+fe2e-fe2f}@font-face{font-family:IBM Plex Sans Arabic;font-style:normal;font-weight:400;font-display:swap;src:url(/_next/static/media/1323037a3e4ea9e8-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:IBM Plex Sans Arabic;font-style:normal;font-weight:400;font-display:swap;src:url(/_next/static/media/17efc7caebbb6a73-s.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:IBM Plex Sans Arabic;font-style:normal;font-weight:500;font-display:swap;src:url(/_next/static/media/f022b1629605b85c-s.p.woff2) format("woff2");unicode-range:u+06??,u+0750-077f,u+0870-088e,u+0890-0891,u+0897-08e1,u+08e3-08ff,u+200c-200e,u+2010-2011,u+204f,u+2e41,u+fb50-fdff,u+fe70-fe74,u+fe76-fefc,u+102e0-102fb,u+10e60-10e7e,u+10ec2-10ec4,u+10efc-10eff,u+1ee00-1ee03,u+1ee05-1ee1f,u+1ee21-1ee22,u+1ee24,u+1ee27,u+1ee29-1ee32,u+1ee34-1ee37,u+1ee39,u+1ee3b,u+1ee42,u+1ee47,u+1ee49,u+1ee4b,u+1ee4d-1ee4f,u+1ee51-1ee52,u+1ee54,u+1ee57,u+1ee59,u+1ee5b,u+1ee5d,u+1ee5f,u+1ee61-1ee62,u+1ee64,u+1ee67-1ee6a,u+1ee6c-1ee72,u+1ee74-1ee77,u+1ee79-1ee7c,u+1ee7e,u+1ee80-1ee89,u+1ee8b-1ee9b,u+1eea1-1eea3,u+1eea5-1eea9,u+1eeab-1eebb,u+1eef0-1eef1}@font-face{font-family:IBM Plex Sans Arabic;font-style:normal;font-weight:500;font-display:swap;src:url(/_next/static/media/18d6d756b83deaa1-s.woff2) format("woff2");unicode-range:u+0460-052f,u+1c80-1c8a,u+20b4,u+2de0-2dff,u+a640-a69f,u+fe2e-fe2f}@font-face{font-family:IBM Plex Sans Arabic;font-style:normal;font-weight:500;font-display:swap;src:url(/_next/static/media/101eb3c626c8a0e0-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:IBM Plex Sans Arabic;font-style:normal;font-weight:500;font-display:swap;src:url(/_next/static/media/b729ad8c86c7d641-s.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:IBM Plex Sans Arabic;font-style:normal;font-weight:600;font-display:swap;src:url(/_next/static/media/e4efb0298547fad0-s.p.woff2) format("woff2");unicode-range:u+06??,u+0750-077f,u+0870-088e,u+0890-0891,u+0897-08e1,u+08e3-08ff,u+200c-200e,u+2010-2011,u+204f,u+2e41,u+fb50-fdff,u+fe70-fe74,u+fe76-fefc,u+102e0-102fb,u+10e60-10e7e,u+10ec2-10ec4,u+10efc-10eff,u+1ee00-1ee03,u+1ee05-1ee1f,u+1ee21-1ee22,u+1ee24,u+1ee27,u+1ee29-1ee32,u+1ee34-1ee37,u+1ee39,u+1ee3b,u+1ee42,u+1ee47,u+1ee49,u+1ee4b,u+1ee4d-1ee4f,u+1ee51-1ee52,u+1ee54,u+1ee57,u+1ee59,u+1ee5b,u+1ee5d,u+1ee5f,u+1ee61-1ee62,u+1ee64,u+1ee67-1ee6a,u+1ee6c-1ee72,u+1ee74-1ee77,u+1ee79-1ee7c,u+1ee7e,u+1ee80-1ee89,u+1ee8b-1ee9b,u+1eea1-1eea3,u+1eea5-1eea9,u+1eeab-1eebb,u+1eef0-1eef1}@font-face{font-family:IBM Plex Sans Arabic;font-style:normal;font-weight:600;font-display:swap;src:url(/_next/static/media/c3d28d0a4af5320e-s.woff2) format("woff2");unicode-range:u+0460-052f,u+1c80-1c8a,u+20b4,u+2de0-2dff,u+a640-a69f,u+fe2e-fe2f}@font-face{font-family:IBM Plex Sans Arabic;font-style:normal;font-weight:600;font-display:swap;src:url(/_next/static/media/b096b166d47a2e73-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:IBM Plex Sans Arabic;font-style:normal;font-weight:600;font-display:swap;src:url(/_next/static/media/79d9077e4fd7eddc-s.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:IBM Plex Sans Arabic;font-style:normal;font-weight:700;font-display:swap;src:url(/_next/static/media/fb66eb17bf011c3b-s.p.woff2) format("woff2");unicode-range:u+06??,u+0750-077f,u+0870-088e,u+0890-0891,u+0897-08e1,u+08e3-08ff,u+200c-200e,u+2010-2011,u+204f,u+2e41,u+fb50-fdff,u+fe70-fe74,u+fe76-fefc,u+102e0-102fb,u+10e60-10e7e,u+10ec2-10ec4,u+10efc-10eff,u+1ee00-1ee03,u+1ee05-1ee1f,u+1ee21-1ee22,u+1ee24,u+1ee27,u+1ee29-1ee32,u+1ee34-1ee37,u+1ee39,u+1ee3b,u+1ee42,u+1ee47,u+1ee49,u+1ee4b,u+1ee4d-1ee4f,u+1ee51-1ee52,u+1ee54,u+1ee57,u+1ee59,u+1ee5b,u+1ee5d,u+1ee5f,u+1ee61-1ee62,u+1ee64,u+1ee67-1ee6a,u+1ee6c-1ee72,u+1ee74-1ee77,u+1ee79-1ee7c,u+1ee7e,u+1ee80-1ee89,u+1ee8b-1ee9b,u+1eea1-1eea3,u+1eea5-1eea9,u+1eeab-1eebb,u+1eef0-1eef1}@font-face{font-family:IBM Plex Sans Arabic;font-style:normal;font-weight:700;font-display:swap;src:url(/_next/static/media/3abc2a74bccacda0-s.woff2) format("woff2");unicode-range:u+0460-052f,u+1c80-1c8a,u+20b4,u+2de0-2dff,u+a640-a69f,u+fe2e-fe2f}@font-face{font-family:IBM Plex Sans Arabic;font-style:normal;font-weight:700;font-display:swap;src:url(/_next/static/media/20e170e88a69dd27-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:IBM Plex Sans Arabic;font-style:normal;font-weight:700;font-display:swap;src:url(/_next/static/media/99dc19e540dbb87b-s.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:IBM Plex Sans Arabic Fallback;src:local("Arial");ascent-override:107.25%;descent-override:41.02%;line-gap-override:0.00%;size-adjust:101.17%}.__className_92a6d2{font-family:IBM Plex Sans Arabic,IBM Plex Sans Arabic Fallback,Cairo,Arial,sans-serif;font-style:normal}.__variable_92a6d2{--font-arabic:"IBM Plex Sans Arabic","IBM Plex Sans Arabic Fallback",Cairo,Arial,sans-serif}