: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;--app-topbar-height:var(--topbar-h)}*{box-sizing:border-box}body,html{margin:0;padding:0}html{scrollbar-gutter:stable}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}.sidebar--admin .sidebar__nav{padding:6px 8px 10px;scroll-behavior:smooth;scrollbar-gutter:stable;overscroll-behavior:contain}.sidebar--admin .nav-group{-webkit-margin-after:0;margin-block-end:0;border-radius:var(--radius-sm)}.sidebar--admin .nav-group--open{background:color-mix(in srgb,var(--c-surface-2) 70%,transparent);-webkit-margin-after:2px;margin-block-end:2px}.sidebar--admin .nav-group__toggle{display:flex;align-items:center;justify-content:space-between;gap:6px;width:100%;padding:5px 9px;margin-block:0;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--c-text-muted);cursor:pointer;font-size:11px;font-weight:700;letter-spacing:.03em;text-transform:uppercase;transition:background .12s ease,color .12s ease}.sidebar--admin .nav-group__toggle:hover{background:var(--c-surface-2);color:var(--c-text)}.sidebar--admin .nav-group__toggle--has-active,.sidebar--admin .nav-group__toggle--open{color:var(--c-text)}.sidebar--admin .nav-group__title{flex:1 1;min-width:0;text-align:start;line-height:1.3}.sidebar--admin .nav-group__chevron{flex-shrink:0;opacity:.75;color:var(--c-text-muted);transition:transform .18s ease}.sidebar--admin .nav-group__toggle--open .nav-group__chevron{transform:rotate(180deg);opacity:.9}.sidebar--admin .nav-group__items{padding-block:1px 3px;-webkit-padding-start:2px;padding-inline-start:2px}.sidebar--admin .nav-group__items--closed{display:none}.sidebar--admin .nav-link{padding:6px 9px;-webkit-margin-after:1px;margin-block-end:1px;font-size:13px;line-height:1.35}.sidebar--admin .nav-link:hover:not(.nav-link--active){background:var(--c-surface-2);color:var(--c-text)}.sidebar--admin .nav-link--active{background:var(--c-primary-soft);color:var(--c-navy);font-weight:650;-webkit-border-start:3px solid var(--raqeem-secondary);border-inline-start:3px solid var(--raqeem-secondary);-webkit-padding-start:7px;padding-inline-start:7px}.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%}.sign-out-btn__inner{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:1.1rem}.sign-out-btn__spinner{width:14px;height:14px;border:2px solid color-mix(in srgb,var(--c-text-muted) 35%,transparent 65%);border-top-color:var(--c-primary);border-radius:50%;animation:spin .65s linear infinite;flex-shrink:0}.sign-out-btn--busy:disabled{opacity:1;cursor:wait}.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)}.form-stack{display:flex;flex-direction:column;gap:16px}.form-stack.card{padding:20px}.form-stack .form-field,.form-stack>label{display:grid;grid-gap:6px;gap:6px;font-size:13px;font-weight:600;color:var(--c-text)}.form-stack .form-error{-webkit-margin-after:0;margin-block-end:0}.form-actions{display:flex;flex-wrap:wrap;align-items:center;gap:8px;padding-top:12px;margin-top:4px;border-top:1px solid var(--c-border)}[dir=rtl] .form-actions{flex-direction:row-reverse;justify-content:flex-start}.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-page{--login-brand-primary:var(--raqeem-primary);--login-brand-accent:var(--c-primary-soft);--login-bg-tint:color-mix(in srgb,var(--login-brand-primary) 7%,#fff 93%);position:relative;min-height:100vh;min-height:100dvh;overflow-x:hidden;background:linear-gradient(145deg,color-mix(in srgb,var(--login-brand-accent) 42%,#fff 58%) 0,var(--login-bg-tint) 38%,color-mix(in srgb,var(--login-brand-primary) 8%,#fff 92%) 100%);color:var(--c-text)}.login-page[data-branded=true]{--login-bg-tint:color-mix(in srgb,var(--login-brand-primary) 10%,var(--login-brand-accent) 90%);background:linear-gradient(140deg,color-mix(in srgb,var(--login-brand-accent) 55%,#fff 45%) 0,color-mix(in srgb,var(--login-brand-primary) 12%,var(--login-brand-accent) 88%) 45%,color-mix(in srgb,var(--login-brand-primary) 9%,#fff 91%) 100%)}.login-page__ambient{position:absolute;inset:0;pointer-events:none;overflow:hidden;z-index:0}.login-page__ambient-gradient{position:absolute;inset:0;background:radial-gradient(ellipse 70% 50% at 18% 22%,color-mix(in srgb,var(--login-brand-primary) 14%,transparent 86%) 0,transparent 68%),radial-gradient(ellipse 55% 42% at 82% 78%,color-mix(in srgb,var(--login-brand-accent) 28%,transparent 72%) 0,transparent 62%)}.login-page__ambient-glow{position:absolute;border-radius:50%;filter:blur(64px);opacity:.45}.login-page__ambient-glow--primary{width:min(420px,55vw);height:min(420px,55vw);inset-inline-start:-8%;top:12%;background:color-mix(in srgb,var(--login-brand-primary) 22%,transparent 78%)}.login-page__ambient-glow--accent{width:min(360px,48vw);height:min(360px,48vw);inset-inline-end:-6%;bottom:8%;background:color-mix(in srgb,var(--login-brand-accent) 35%,transparent 65%)}.login-page__locale{position:absolute;z-index:2;inset-inline-start:clamp(16px,3vw,32px);top:clamp(16px,3vh,28px)}.login-page__shell{position:relative;z-index:1;min-height:100vh;min-height:100dvh;width:min(1120px,100%);margin-inline:auto;padding:clamp(72px,10vh,96px) clamp(16px,4vw,40px) clamp(28px,5vh,48px);display:grid;grid-template-columns:minmax(260px,1fr) minmax(300px,420px);align-items:center;grid-gap:clamp(28px,5vw,72px);gap:clamp(28px,5vw,72px)}.login-brand{display:flex;flex-direction:column;gap:clamp(16px,2.5vh,24px);padding-inline:clamp(0px,2vw,12px);max-width:520px}.login-brand__mark{display:flex;align-items:flex-start}.login-brand__name{margin:0;font-size:clamp(1.5rem,3.2vw,2.25rem);font-weight:800;line-height:1.15;letter-spacing:-.02em;color:color-mix(in srgb,var(--login-brand-primary) 78%,var(--c-text) 22%)}.login-brand__tagline{margin:10px 0 0;font-size:clamp(.95rem,1.8vw,1.125rem);line-height:1.55;color:color-mix(in srgb,var(--login-brand-primary) 38%,var(--c-text-muted) 62%);max-width:36ch}.login-brand__year{margin:10px 0 0;font-size:.8125rem;font-weight:600;letter-spacing:.04em;color:color-mix(in srgb,var(--login-brand-primary) 52%,transparent 48%)}.login-brand__platform{display:flex;align-items:center;gap:10px;-webkit-margin-before:clamp(8px,2vh,20px);margin-block-start:clamp(8px,2vh,20px);-webkit-padding-before:clamp(12px,2vh,18px);padding-block-start:clamp(12px,2vh,18px);-webkit-border-before:1px solid color-mix(in srgb,var(--login-brand-primary) 14%,transparent 86%);border-block-start:1px solid color-mix(in srgb,var(--login-brand-primary) 14%,transparent 86%);max-width:34ch}.login-brand__platform-logo{height:clamp(26px,3vw,34px);width:auto;max-width:min(200px,100%);flex-shrink:0}.login-brand__platform-text{margin:0;font-size:.8125rem;line-height:1.4;color:color-mix(in srgb,var(--login-brand-primary) 48%,var(--c-text-muted) 52%)}.login-mark__logo{height:auto;width:auto;object-fit:contain;object-position:start center}.login-mark__logo--brand{max-height:clamp(120px,18vw,200px);max-width:min(380px,100%)}.login-mark__monogram--brand{width:clamp(120px,18vw,168px);height:clamp(120px,18vw,168px);border-radius:22px;display:grid;place-items:center;background:color-mix(in srgb,var(--login-brand-accent) 58%,#fff 42%);border:1px solid color-mix(in srgb,var(--login-brand-primary) 20%,var(--c-border) 80%);color:var(--login-brand-primary)}.login-mark__monogram--brand .login-mark__monogram-glyph{font-size:clamp(2.25rem,5vw,3.25rem);font-weight:700;line-height:1}.login-mark__platform--brand.brand-logo__full{height:clamp(100px,16vw,160px);max-width:min(340px,100%);object-position:start center}.login-card{position:relative;isolation:isolate;width:100%;background:color-mix(in srgb,var(--c-surface) 68%,transparent 32%);backdrop-filter:blur(22px) saturate(1.2);-webkit-backdrop-filter:blur(22px) saturate(1.2);border:1px solid color-mix(in srgb,#fff 72%,var(--login-brand-primary) 28%);border-radius:24px;box-shadow:0 20px 50px color-mix(in srgb,var(--login-brand-primary) 14%,transparent 86%),0 1px 0 color-mix(in srgb,#fff 90%,transparent 10%) inset,0 -1px 0 color-mix(in srgb,var(--login-brand-primary) 6%,transparent 94%) inset;padding:clamp(26px,4.5vw,40px);overflow:hidden}.login-card:before{inset:0;border-radius:inherit;background:linear-gradient(145deg,color-mix(in srgb,#fff 62%,transparent 38%) 0,transparent 38%,color-mix(in srgb,var(--login-brand-accent) 18%,transparent 82%) 100%);opacity:.5}.login-card:after,.login-card:before{content:"";position:absolute;pointer-events:none;z-index:0}.login-card:after{inset-inline:12%;top:0;height:1px;background:linear-gradient(90deg,transparent,color-mix(in srgb,#fff 95%,transparent 5%),transparent);opacity:.85}.login-card>*{position:relative;z-index:1}.login-card__mark{display:flex;justify-content:center;-webkit-margin-after:18px;margin-block-end:18px;-webkit-padding-after:4px;padding-block-end:4px}.login-card__raqeem-logo{height:clamp(34px,4vw,44px);width:auto;max-width:min(220px,100%);filter:drop-shadow(0 2px 6px color-mix(in srgb,var(--login-brand-primary) 12%,transparent 88%))}.login-card__title{font-size:clamp(.9375rem,2vw,1.0625rem);line-height:1.25;margin:0 0 6px;text-align:center;color:var(--c-text);font-weight:700;letter-spacing:-.01em}.login-card__sub{color:color-mix(in srgb,var(--c-text-muted) 88%,var(--login-brand-primary) 12%);margin:0 0 26px;font-size:.9375rem;line-height:1.5;text-align:center}.login-card .field label{font-weight:600;font-size:.8125rem;color:color-mix(in srgb,var(--c-text) 88%,var(--login-brand-primary) 12%)}.login-card .input{background:color-mix(in srgb,var(--c-surface) 52%,transparent 48%);border:1px solid color-mix(in srgb,#fff 58%,var(--login-brand-primary) 22%);border-radius:12px;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);box-shadow:inset 0 1px 0 color-mix(in srgb,#fff 70%,transparent 30%);transition:border-color .15s ease,box-shadow .15s ease,background .15s ease}.login-card .input:focus{border-color:color-mix(in srgb,var(--login-brand-primary) 45%,#fff 55%);background:color-mix(in srgb,var(--c-surface) 78%,transparent 22%);box-shadow:0 0 0 3px color-mix(in srgb,var(--login-brand-primary) 14%,transparent 86%),0 1px 0 color-mix(in srgb,#fff 80%,transparent 20%) inset}.login-password-field{display:flex;align-items:center;gap:0;min-height:44px;padding:0;-webkit-padding-end:6px;padding-inline-end:6px;overflow:hidden;background:color-mix(in srgb,var(--c-surface) 52%,transparent 48%);border:1px solid color-mix(in srgb,#fff 58%,var(--login-brand-primary) 22%);border-radius:12px;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);box-shadow:inset 0 1px 0 color-mix(in srgb,#fff 70%,transparent 30%);transition:border-color .15s ease,box-shadow .15s ease,background .15s ease}.login-password-field:focus-within{border-color:color-mix(in srgb,var(--login-brand-primary) 45%,#fff 55%);background:color-mix(in srgb,var(--c-surface) 78%,transparent 22%);box-shadow:0 0 0 3px color-mix(in srgb,var(--login-brand-primary) 14%,transparent 86%),0 1px 0 color-mix(in srgb,#fff 80%,transparent 20%) inset}.login-password-field__input{flex:1 1;min-width:0;width:auto;min-height:42px;padding:10px 12px;-webkit-padding-end:6px;padding-inline-end:6px}.login-card .login-password-field__input,.login-password-field__input{border:0;border-radius:0;background:transparent;box-shadow:none;backdrop-filter:none;-webkit-backdrop-filter:none}.login-card .login-password-field__input:focus,.login-card .login-password-field__input:focus-visible{border:0;outline:none;box-shadow:none;background:transparent}.login-password-field__toggle{flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;margin:0;padding:0;border:0;border-radius:8px;-moz-appearance:none;appearance:none;-webkit-appearance:none;background:transparent;color:color-mix(in srgb,var(--c-text-muted) 78%,var(--login-brand-primary) 22%);cursor:pointer;transition:color .15s ease,background .15s ease}.login-password-field__toggle:hover:not(:disabled){color:var(--c-text);background:color-mix(in srgb,var(--login-brand-primary) 10%,transparent 90%)}.login-password-field__toggle:focus-visible{outline:2px solid color-mix(in srgb,var(--login-brand-primary) 55%,#fff 45%);outline-offset:0}.login-password-field__toggle:disabled{opacity:.45;cursor:not-allowed}.login-card[data-submitting=true] .login-password-field{background:color-mix(in srgb,var(--c-surface) 40%,transparent 60%)}.login-card[data-submitting=true] .login-password-field__input:disabled{background:transparent}.login-card .btn--primary{background:linear-gradient(165deg,color-mix(in srgb,var(--login-brand-primary) 88%,#fff 12%) 0,var(--login-brand-primary) 55%,color-mix(in srgb,var(--login-brand-primary) 92%,#000 8%) 100%);border-color:color-mix(in srgb,var(--login-brand-primary) 80%,#fff 20%);box-shadow:0 6px 20px color-mix(in srgb,var(--login-brand-primary) 32%,transparent 68%),0 1px 0 color-mix(in srgb,#fff 35%,transparent 65%) inset;font-weight:600;letter-spacing:.02em;transition:transform .12s ease,box-shadow .12s ease}.login-card .btn--primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 10px 26px color-mix(in srgb,var(--login-brand-primary) 36%,transparent 64%),0 1px 0 color-mix(in srgb,#fff 40%,transparent 60%) inset}.login-card .btn--primary:active:not(:disabled){transform:translateY(0)}.login-card .btn,.login-card .input{min-height:44px}.login-card .input:focus-visible{outline:none}.login-card__submit{-webkit-margin-before:10px;margin-block-start:10px}.login-card__submit-inner{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:1.25rem}.login-card__submit-spinner{width:18px;height:18px;border:2px solid color-mix(in srgb,#fff 35%,transparent 65%);border-top-color:#fff;border-radius:50%;animation:spin .65s linear infinite;flex-shrink:0}.login-card .btn--primary.login-card__submit--busy:disabled{opacity:1;cursor:wait}.login-card[data-submitting=true] .field{opacity:.72;pointer-events:none}.login-card[data-submitting=true] .input:disabled{background:color-mix(in srgb,var(--c-surface) 40%,transparent 60%)}.login-card .form-error{background:color-mix(in srgb,var(--c-red-soft) 82%,transparent 18%);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid color-mix(in srgb,var(--c-red) 18%,transparent 82%)}.login-card .form-error--amber{background:color-mix(in srgb,var(--c-amber-soft) 82%,transparent 18%);border:1px solid color-mix(in srgb,var(--c-amber) 18%,transparent 82%);color:var(--c-amber)}@media (max-width:1023px){.login-page__shell{grid-template-columns:1fr;max-width:480px;gap:clamp(24px,4vh,36px);padding-top:clamp(64px,9vh,80px)}.login-brand{max-width:none;text-align:center;align-items:center}.login-brand__mark{justify-content:center}.login-brand__tagline{max-width:none}.login-brand__platform{justify-content:center;max-width:none}}@media (max-width:599px){.login-page__locale{top:12px;inset-inline-start:12px}.login-brand__tagline{font-size:.9rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.login-brand__platform-text{font-size:.75rem}.login-page__shell{padding-top:56px;padding-bottom:20px}.login-card{border-radius:20px;backdrop-filter:blur(18px) saturate(1.15);-webkit-backdrop-filter:blur(18px) saturate(1.15)}}@media (max-height:700px){.login-page__shell{padding-top:56px;padding-bottom:16px;gap:20px}.login-brand__name{font-size:1.35rem}.login-mark__logo--brand{max-height:clamp(96px,22vw,140px)}.login-card{padding:20px 22px}}.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}.locale-switcher--login{gap:0;padding:5px 6px 5px 10px;border-radius:999px;background:color-mix(in srgb,var(--c-surface) 86%,transparent 14%);border:1px solid color-mix(in srgb,var(--login-brand-primary) 14%,var(--c-border) 86%);box-shadow:0 4px 18px color-mix(in srgb,var(--login-brand-primary) 8%,transparent 92%),0 1px 2px rgba(0,0,0,.04);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);transition:border-color .15s ease,box-shadow .15s ease}.locale-switcher--login:hover{border-color:color-mix(in srgb,var(--login-brand-primary) 28%,var(--c-border) 72%);box-shadow:0 6px 22px color-mix(in srgb,var(--login-brand-primary) 10%,transparent 90%),0 1px 3px rgba(0,0,0,.05)}.locale-switcher--login:focus-within{border-color:color-mix(in srgb,var(--login-brand-primary) 42%,var(--c-border) 58%);box-shadow:0 0 0 3px color-mix(in srgb,var(--login-brand-primary) 14%,transparent 86%),0 4px 18px color-mix(in srgb,var(--login-brand-primary) 8%,transparent 92%)}.locale-switcher__globe{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;-webkit-margin-end:4px;margin-inline-end:4px;color:var(--login-brand-primary);background:color-mix(in srgb,var(--login-brand-primary) 10%,transparent 90%);flex-shrink:0}.locale-switcher__globe-icon{display:block}.locale-switcher__control{position:relative;display:inline-flex;align-items:center}.locale-switcher--login .locale-switcher__select{width:auto;min-width:5.5rem;max-width:7.5rem;padding-block:4px;padding-inline:2px 26px;margin:0;border:none;background:transparent;box-shadow:none;font-size:.8125rem;font-weight:600;letter-spacing:.01em;color:var(--c-text);cursor:pointer;-moz-appearance:none;appearance:none;-webkit-appearance:none}.locale-switcher--login .locale-switcher__select:focus{outline:none;box-shadow:none;border:none}.locale-switcher__chevron{position:absolute;inset-inline-end:4px;inset-block-start:50%;transform:translateY(-50%);display:flex;align-items:center;justify-content:center;color:color-mix(in srgb,var(--login-brand-primary) 55%,var(--c-text-muted) 45%);pointer-events:none}.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;text-decoration:none}.back-link:hover{color:var(--c-primary)}[dir=rtl] .back-link{flex-direction:row-reverse}.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}.topbar__start{display:flex;align-items:center;gap:8px;min-width:0;flex:1 1}.topbar__right--mobile{display:none}.admin-account-trigger{display:inline-flex;align-items:center;justify-content:center;min-width:44px;min-height:44px;padding:0;border:1px solid var(--c-border);border-radius:999px;background:var(--c-surface);cursor:pointer}.admin-account-trigger:focus-visible{outline:2px solid var(--c-primary);outline-offset:2px}.sidebar__footer--mobile{display:none}.mobile-sheet__scrim{position:fixed;inset:0;z-index:60;border:none;padding:0;background:rgba(15,23,42,.45);cursor:pointer}.mobile-sheet{position:fixed;inset-inline:0;inset-block-end:0;z-index:70;max-height:min(85vh,640px);display:flex;flex-direction:column;border-radius:16px 16px 0 0;background:var(--c-surface);box-shadow:0 -8px 32px rgba(15,23,42,.18);-webkit-padding-after:env(safe-area-inset-bottom,0);padding-block-end:env(safe-area-inset-bottom,0)}.mobile-sheet__handle{width:40px;height:4px;margin:8px auto 4px;border-radius:999px;background:var(--c-border)}.mobile-sheet__header{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:8px 16px 12px;-webkit-border-after:1px solid var(--c-border);border-block-end:1px solid var(--c-border)}.mobile-sheet__title{margin:0;font-size:15px;font-weight:800}.mobile-sheet__close{min-width:44px;min-height:44px;border:none;background:transparent;font-size:24px;line-height:1;cursor:pointer;color:var(--c-text-muted)}.mobile-sheet__body{overflow:auto;padding:12px 16px 16px;overscroll-behavior:contain}.admin-account-sheet{display:flex;flex-direction:column;gap:16px}.admin-account-sheet__profile{display:flex;gap:12px;align-items:center}.admin-account-sheet__copy{display:flex;flex-direction:column;gap:2px;min-width:0}.admin-account-sheet__role{font-size:12px;color:var(--c-text-muted)}.admin-account-sheet__school{font-size:11px;color:var(--c-text-faint)}.admin-account-sheet__field{display:flex;flex-direction:column;gap:6px}.admin-account-sheet__label{font-size:11px;font-weight:700;color:var(--c-text-muted);text-transform:uppercase;letter-spacing:.04em}.admin-account-sheet__logout{width:100%;min-height:44px;justify-content:center}@media (max-width:900px){:root{--topbar-h:56px}.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);display:flex;flex-direction:column;max-height:100dvh}[dir=rtl] .sidebar{transform:translateX(110%)}.sidebar--open{transform:translateX(0)!important}.menu-toggle{display:inline-flex;min-width:44px;min-height:44px}.content{padding:12px}.scrim{position:fixed;inset:0;border:none;padding:0;background:rgba(15,23,42,.4);z-index:40;cursor:pointer}.topbar{padding-inline:12px;gap:8px}.topbar__right--desktop{display:none}.topbar__right--mobile{display:flex;align-items:center;flex-shrink:0}.topbar__title{max-width:none;flex:1 1;font-size:14px}.sidebar__footer--mobile{display:flex;flex-direction:column;gap:10px;padding:12px 16px calc(12px + env(safe-area-inset-bottom, 0));-webkit-border-before:1px solid var(--c-border);border-block-start:1px solid var(--c-border);-webkit-margin-before:auto;margin-block-start:auto}.sidebar__footer-field{display:flex;flex-direction:column;gap:6px}.sidebar__footer-label{font-size:11px;font-weight:700;color:var(--c-text-muted)}.sidebar__footer-logout{width:100%;min-height:44px;justify-content:center}.tabs{width:100%}.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}