:root{
  /* Jadwalist Brand Book — ألوان مرجعية */
  --brand-navy:#0F172A;
  --brand-emerald:#10B982;
  --brand-cyan:#2EC4A0;
  /* شعار المنصة — نفس قيم الهوية (لا تُستبدل بألوان خارجية) */
  --brand-logo-primary:var(--brand-cyan);
  --brand-logo-accent:var(--brand-emerald);
  --brand-logo-shade:#219B82;
  --brand-amber:#D8DCE8;
  --brand-cloud:#FAFAFC;
  --brand-slate:#94A3B8;
  /* Color Role Map — مرجع موحّد لتوزيع الألوان */
  --color-primary:#10B982;
  --color-accent:#1E293B;
  --color-info:#94A3B8;
  --color-error:#D94F3B;
  --color-base-dark:#0F172A;
  --color-base-mid:#1E293B;
  --color-surface-light:#FAFAFC;
  --color-surface-muted:#F4F5F9;
  --color-text-primary:#2A3050;
  --color-text-secondary:#64748B;
  --color-text-muted:#94A3B8;
  /* واجهة داكنة متسقة مع الهوية */
  --bg:var(--color-base-dark);--bg2:var(--color-base-mid);--bg3:#243447;--bg4:#2c3f57;
  --surface:rgba(216,220,232,.08);--surface2:rgba(46,196,160,.11);
  --border:rgba(154,160,184,.24);--border2:rgba(154,160,184,.4);--border3:rgba(216,220,232,.45);
  --accent:var(--color-primary);--accent2:var(--color-accent);--accent3:var(--color-info);
  --gold:#D8DCE8;--teal:var(--color-info);--green:var(--color-primary);--red:var(--color-error);
  --orange:#ea580c;--navy:var(--color-base-dark);--purple:#6366f1;
  --muted:var(--color-text-muted);--muted2:#cbd5e1;--text:#f4f5f9;--text2:#cbd5e1;
  --sidebar-w:256px;
  --space-4:4px;--space-6:6px;--space-8:8px;--space-10:10px;--space-12:12px;--space-14:14px;--space-16:16px;--space-18:18px;--space-20:20px;--space-24:24px;
  --card-border:rgba(148,163,184,.2);
  --card-shadow:0 4px 20px rgba(0,0,0,.32),0 1px 4px rgba(0,0,0,.22);
  --accent-glow:rgba(16,185,130,.18);
  --blue-glow:rgba(148,163,184,.14);
  --input-bg:rgba(30,41,59,.62);
  --accent-hover-soft:color-mix(in srgb,var(--accent) 10%,transparent);
  --accent-hover-strong:color-mix(in srgb,var(--accent) 14%,transparent);
  --accent-shadow-soft:color-mix(in srgb,var(--accent) 24%,transparent);
  --panel-bg:color-mix(in srgb,var(--bg2) 78%,var(--bg));
  --panel-bg-strong:color-mix(in srgb,var(--bg3) 88%,var(--bg2));
  --panel-border:color-mix(in srgb,var(--border) 90%,var(--border2));
  --panel-border-hover:color-mix(in srgb,var(--accent) 30%,var(--border2));
  --card-bg:color-mix(in srgb,var(--bg3) 86%,var(--bg2));
  --card-bg-soft:color-mix(in srgb,var(--surface) 72%,var(--bg3));
  --card-text:color-mix(in srgb,var(--text) 90%,#ffffff);
  --card-text-soft:color-mix(in srgb,var(--muted2) 84%,#ffffff);
  --tab-bg:color-mix(in srgb,var(--surface) 82%,transparent);
  --tab-hover-bg:color-mix(in srgb,var(--accent) 10%,transparent);
  --tab-active-shadow:0 2px 8px color-mix(in srgb,var(--accent) 30%,transparent);
  --tc:var(--brand-emerald);
  --brand-logo-svg:url("jadwalist-logo-color.png");
  /* تمييز «تعديل الجدول» */
  --sched-edit-source:#22c55e;
  --sched-edit-simple:#3b82f6;
  --sched-edit-compound:#eab308;
  --sched-edit-dim:#ef4444;
  /* حالات موحّدة (success/info/warn/error) */
  --state-ok-bg:rgba(16,185,130,.1);
  --state-ok-border:rgba(16,185,130,.28);
  --state-ok-text:#10B982;
  --state-info-bg:rgba(148,163,184,.14);
  --state-info-border:rgba(148,163,184,.3);
  --state-info-text:#94A3B8;
  --state-warn-bg:rgba(216,220,232,.2);
  --state-warn-border:rgba(154,160,184,.34);
  --state-warn-text:#6A7190;
  --state-error-bg:rgba(217,79,59,.1);
  --state-error-border:rgba(217,79,59,.3);
  --state-error-text:#D94F3B;
  /* تدرجات موحّدة — تتبع الثيم تلقائياً (نفس فكرة رؤوس الجداول: color-mix + متغيرات) */
  --grad-cta: linear-gradient(135deg, color-mix(in srgb, var(--bg2) 90%, #ffffff), color-mix(in srgb, var(--accent) 88%, #ffffff));
  --grad-card: linear-gradient(150deg, var(--bg2) 0%, var(--bg) 50%, color-mix(in srgb, var(--bg3) 72%, var(--bg)) 100%);
  --grad-kpi: linear-gradient(135deg, color-mix(in srgb, var(--bg3) 92%, var(--bg2)), color-mix(in srgb, var(--accent2) 16%, var(--bg3)));
  --grad-tab-active: linear-gradient(135deg, color-mix(in srgb, var(--accent) 20%, transparent), color-mix(in srgb, var(--accent2) 12%, transparent));
  --grad-avatar: linear-gradient(135deg, color-mix(in srgb, var(--accent) 80%, #ffffff), color-mix(in srgb, var(--accent2) 88%, #ffffff));
  --grad-radial-body:
    radial-gradient(ellipse 80% 50% at 15% 0%, color-mix(in srgb, var(--accent) 10%, transparent), transparent 60%),
    radial-gradient(ellipse 50% 40% at 85% 100%, color-mix(in srgb, var(--accent2) 8%, transparent), transparent 60%);
  --grad-text-hero: linear-gradient(110deg, #ffffff, color-mix(in srgb, var(--accent3) 62%, #ffffff));
  --grad-text-stat: linear-gradient(135deg, color-mix(in srgb, #ffffff 92%, var(--accent3)), color-mix(in srgb, var(--accent3) 78%, #ffffff));
  --grad-wa-header: linear-gradient(135deg, color-mix(in srgb, var(--green) 42%, var(--bg)), color-mix(in srgb, var(--green) 28%, var(--bg3)));
  --grad-wa-send: linear-gradient(135deg, color-mix(in srgb, var(--bg2) 92%, #ffffff), color-mix(in srgb, var(--accent) 22%, var(--bg3)));
  --grad-admin-shell:
    radial-gradient(ellipse 100% 50% at 50% -8%, color-mix(in srgb, var(--accent2) 16%, transparent), transparent 55%),
    radial-gradient(ellipse 45% 35% at 100% 5%, color-mix(in srgb, var(--accent) 10%, transparent), transparent 50%),
    linear-gradient(180deg, color-mix(in srgb, var(--bg2) 18%, var(--bg)) 0%, var(--bg) 32%);
  --grad-admin-topbar: linear-gradient(180deg, color-mix(in srgb, var(--bg2) 55%, transparent), color-mix(in srgb, var(--bg) 88%, transparent));
  --grad-admin-card: linear-gradient(155deg, color-mix(in srgb, var(--bg2) 48%, transparent), color-mix(in srgb, var(--bg) 94%, transparent));
  --grad-admin-toolbar: linear-gradient(135deg, color-mix(in srgb, var(--bg3) 90%, var(--bg)), color-mix(in srgb, var(--bg) 78%, var(--bg3)));
  --grad-admin-brand: linear-gradient(145deg, color-mix(in srgb, var(--accent2) 20%, transparent), color-mix(in srgb, var(--accent) 16%, transparent));
  --card-bg-elevated: var(--grad-card);
  /* مقياس خطوط موحّد — القائمة الجانبية واللوحات والجداول والشريط العلوي */
  --fs-app: clamp(13px, 0.25vw + 12.6px, 14px);
  --fs-sidebar-brand: clamp(13.5px, 0.28vw + 13px, 14.8px);
  --fs-sidebar-tagline: clamp(9.5px, 0.2vw + 9px, 10.5px);
  --fs-nav-item: clamp(11.3px, 0.22vw + 11px, 12.2px);
  --fs-nav-section: clamp(8.4px, 0.16vw + 8px, 9.2px);
  --fs-nav-hint: clamp(9px, 0.2vw + 8.4px, 9.8px);
  --fs-nav-icon: clamp(13px, 0.24vw + 12.6px, 15px);
  --fs-panel-h2: clamp(14.5px, 0.25vw + 14px, 16px);
  --fs-panel-h3: clamp(13px, 0.22vw + 12.5px, 14px);
  --fs-ui: clamp(12px, 0.22vw + 11.6px, 13px);
  --fs-ui-sm: clamp(11px, 0.18vw + 10.7px, 12px);
  --fs-label: clamp(11px, 0.2vw + 10.5px, 12px);
  --fs-table: clamp(12px, 0.2vw + 11.7px, 13px);
  --fs-table-head: clamp(9.5px, 0.18vw + 9px, 10.5px);
  --fs-topbar-title: clamp(14px, 0.25vw + 13.5px, 15px);
  --fs-topbar-sub: clamp(9.5px, 0.2vw + 9px, 10.5px);
}

/* ══ ثيمات متناسقة — وضوح النص مضمون ══ */

/* Navy — مطابق للهوية: أزرق داكن + cyan */
[data-theme="navy"]{
  --bg:#0F172A;--bg2:#1E293B;--bg3:#243447;--bg4:#2c3f57;
  --surface:rgba(148,163,184,.08);--surface2:rgba(16,185,130,.1);
  --border:rgba(148,163,184,.22);--border2:rgba(148,163,184,.34);--border3:rgba(203,213,225,.42);
  --accent:#10B982;--accent2:#1E293B;--accent3:#94A3B8;
  --gold:#D8DCE8;--teal:#94A3B8;--green:#10B982;--red:#D94F3B;
  --orange:#ea580c;--navy:#0F172A;--purple:#6366f1;
  --muted:#94A3B8;--muted2:#cbd5e1;--text:#f4f5f9;--text2:#cbd5e1;
  --card-border:rgba(148,163,184,.2);
  --card-shadow:0 4px 20px rgba(0,0,0,.35),0 1px 4px rgba(0,0,0,.22);
  --accent-glow:rgba(16,185,130,.18);
  --blue-glow:rgba(148,163,184,.13);
  --input-bg:rgba(30,41,59,.66);
  --sidebar-w:256px;
}
[data-theme="navy"] .sidebar { background:#1b2636; border-left:1px solid rgba(148,163,184,.22); }
[data-theme="navy"] .nav-item { color:#cbd5e1; }
[data-theme="navy"] .nav-item:hover { background:rgba(16,185,130,.08); color:#f4f7fa; }
[data-theme="navy"] .nav-item.active { background:rgba(16,185,130,.14); color:#f4f5f9; border-right-color:#10B982; }
[data-theme="navy"] .nav-section-label { color:#94a3b8; }
[data-theme="navy"] .form-input, [data-theme="navy"] .form-select { background:rgba(30,41,59,.82); border-color:rgba(148,163,184,.28); color:#f4f7fa; }
[data-theme="navy"] .btn-secondary { background:rgba(16,185,130,.08); border-color:rgba(148,163,184,.28); color:#cbd5e1; }
[data-theme="navy"] .btn-primary { box-shadow:0 4px 14px color-mix(in srgb, var(--accent) 35%, transparent); }
[data-theme="navy"] .tag { background:rgba(16,185,130,.12); color:#b7f3e3; border-color:rgba(148,163,184,.25); }
[data-theme="navy"] .log-box { background:rgba(12,25,41,.75); color:#cbd5e1; }

/* Slate — رمادي مع لمسات الهوية (Emerald/Cyan للأزرار) */
[data-theme="slate"]{
  --bg:#181c20;--bg2:#22282e;--bg3:#2c333a;--bg4:#3d454d;
  --surface:rgba(255,255,255,.04);--surface2:rgba(6,182,212,.08);
  --border:rgba(255,255,255,.12);--border2:rgba(255,255,255,.2);--border3:rgba(255,255,255,.32);
  --accent:#10B981;--accent2:#06B6D4;--accent3:#475569;
  --gold:#F59E0B;--teal:#06B6D4;--green:#10B981;--red:#dc2626;
  --orange:#ea580c;--navy:#2c333a;--purple:#6366f1;
  --muted:#64748b;--muted2:#94a3b8;--text:#f2f4f5;--text2:#d4d8dc;
  --card-border:rgba(255,255,255,.14);
  --card-shadow:0 4px 20px rgba(0,0,0,.38),0 1px 4px rgba(0,0,0,.24);
  --accent-glow:rgba(16,185,129,.12);
  --blue-glow:rgba(6,182,212,.1);
  --input-bg:rgba(34,40,46,.88);
  --sidebar-w:256px;
}
[data-theme="slate"] .sidebar { background:#1c2127; border-left:1px solid rgba(255,255,255,.12); }
[data-theme="slate"] .nav-item { color:#d4d8dc; }
[data-theme="slate"] .nav-item:hover { background:rgba(255,255,255,.06); color:#f2f4f5; }
[data-theme="slate"] .nav-item.active { background:rgba(16,185,129,.12); color:#f2f4f5; border-right-color:#10B981; }
[data-theme="slate"] .nav-section-label { color:#64748b; }
[data-theme="slate"] .form-input, [data-theme="slate"] .form-select { background:rgba(34,40,46,.9); border-color:rgba(255,255,255,.18); color:#f2f4f5; }
[data-theme="slate"] .btn-secondary { background:rgba(255,255,255,.08); border-color:rgba(255,255,255,.2); color:#d4d8dc; }
[data-theme="slate"] .btn-primary { box-shadow:0 4px 14px color-mix(in srgb, var(--accent) 30%, transparent); }
[data-theme="slate"] .tag { background:rgba(255,255,255,.08); color:#94a3b8; border-color:rgba(255,255,255,.16); }
[data-theme="slate"] .log-box { background:rgba(24,28,32,.8); color:#d4d8dc; }

/* Pink — وردي فاتح بتدرجاته */
[data-theme="pink"]{
  --bg:#2a1c24;--bg2:#35222c;--bg3:#402a34;--bg4:#4e3642;
  --surface:rgba(232,168,192,.06);--surface2:rgba(240,192,208,.08);
  --border:rgba(220,160,188,.2);--border2:rgba(220,160,188,.32);--border3:rgba(220,160,188,.48);
  --accent:#d87098;--accent2:#e8a8c0;--accent3:#c86088;
  --gold:#d4a898;--teal:#c890a8;--green:#70b088;--red:#e05878;
  --orange:#d88870;--navy:#35222c;--purple:#a878b0;
  --muted:#906878;--muted2:#c8a8b8;--text:#f5eaee;--text2:#e8d8e0;
  --card-border:rgba(220,160,188,.22);
  --card-shadow:0 4px 20px rgba(0,0,0,.35),0 1px 4px rgba(0,0,0,.24);
  --accent-glow:rgba(216,112,152,.18);
  --blue-glow:rgba(232,168,192,.12);
  --input-bg:rgba(53,34,44,.88);
  --sidebar-w:256px;
}
[data-theme="pink"] .sidebar { background:#251a20; border-left:1px solid rgba(220,160,188,.2); }
[data-theme="pink"] .nav-item { color:#e8d8e0; }
[data-theme="pink"] .nav-item:hover { background:rgba(216,112,152,.12); color:#f5eaee; }
[data-theme="pink"] .nav-item.active { background:rgba(216,112,152,.2); color:#f5eaee; border-right-color:#d87098; }
[data-theme="pink"] .nav-section-label { color:#906878; }
[data-theme="pink"] .form-input, [data-theme="pink"] .form-select { background:rgba(53,34,44,.9); border-color:rgba(220,160,188,.3); color:#f5eaee; }
[data-theme="pink"] .btn-secondary { background:rgba(216,112,152,.1); border-color:rgba(220,160,188,.3); color:#e8d8e0; }
[data-theme="pink"] .btn-primary { box-shadow:0 4px 14px color-mix(in srgb, var(--accent) 35%, transparent); }
[data-theme="pink"] .tag { background:rgba(216,112,152,.14); color:#f0c8d8; border-color:rgba(220,160,188,.28); }
[data-theme="pink"] .log-box { background:rgba(42,28,36,.78); color:#e8d8e0; }

.theme-pick-btn {
  background: var(--bg3);
  border: 2px solid var(--border);
  border-radius: 12px;
  padding: 0;
  cursor: pointer;
  text-align: right;
  transition: all .25s cubic-bezier(.34,1.56,.64,1);
  overflow: hidden;
  font-family: Tajawal, Cairo, sans-serif;
  position: relative;
}
.theme-pick-btn:hover {
  transform: translateY(-3px);
  border-color: var(--tc);
  box-shadow: 0 8px 24px rgba(0,0,0,.3);
}
.theme-pick-btn.active {
  border-color: var(--tc);
  box-shadow: 0 0 0 3px rgba(16,185,129,.25), 0 8px 24px rgba(0,0,0,.25);
}
@supports (color: color-mix(in srgb, red, red)) {
  .theme-pick-btn.active {
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--tc) 25%, transparent), 0 8px 24px rgba(0,0,0,.25);
  }
}
.tp-preview {
  border-radius: 8px 8px 0 0;
  overflow: hidden;
  border-bottom: 1px solid rgba(255,255,255,.06);
}
.tp-bar {
  display: flex;
  align-items: center;
  gap: 5px;
  padding: 5px 8px;
  font-size: 12px;
}
.tp-body {
  display: flex;
  height: 52px;
}
.tp-sidebar {
  width: 30px;
  padding: 6px 5px;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
}
.tp-main {
  flex: 1;
  padding: 7px 8px;
}
.tp-label {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 9px 10px 3px;
  font-size: 12px;
  font-weight: 800;
  color: var(--text);
}
.tp-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
}
.tp-name { flex: 1; }
.tp-check {
  font-size: 13px;
  color: var(--tc);
  font-weight: 900;
}
.tp-sub {
  font-size: 9px;
  color: var(--muted2);
  padding: 0 10px 9px;
  font-weight: 500;
  line-height: 1.4;
}

/* Theme transition — only on UI elements, not globally */
.sidebar, .topbar, .section-card, .overview-card, .scroll-area,
.form-input, .form-select, .data-table tbody tr, .tag, .btn-secondary {
  transition: background-color .3s ease, border-color .3s ease, color .2s ease;
}
.theme-pick-btn, .btn, .nav-item {
  transition: all .25s ease;
}



.nav-section-label{
  font-size:var(--fs-nav-section);
  font-weight:700;
  color:var(--muted);
  letter-spacing:.03em;
  padding:11px 10px 5px;
  margin-bottom:4px;
  display:flex;
  align-items:center;
  gap:6px;
  line-height:1.35;
  position:relative;
}
.nav-section-label:not(:first-child){margin-top:10px}
.nav-section-label::after{content:"";flex:1;height:1px;background:rgba(148,163,184,.1);min-width:8px}
.nav-section-label:first-child{padding-top:8px;margin-top:0}
.step-badge{
  width:15px;height:15px;border-radius:50%;
  background:var(--grad-cta);
  color:#fff;font-size:8.5px;font-weight:900;display:inline-flex;
  align-items:center;justify-content:center;flex-shrink:0;
  box-shadow:0 1px 4px rgba(16,185,129,.3)
}
.nav-item{
  display:flex;align-items:center;gap:9px;padding:8px 11px;border-radius:10px;border:none;
  background:transparent;color:var(--muted2);font-family:Tajawal,Cairo,sans-serif;
  font-size:var(--fs-nav-item);font-weight:600;cursor:pointer;transition:background .18s,color .18s,border-color .18s,box-shadow .18s;width:100%;text-align:right;
  position:relative;min-height:36px;border:1px solid transparent;box-sizing:border-box
}
/* تجربة وضوح الياء: توحيد خط القائمة الجانبية */
.sidebar .nav-item,
.sidebar .nav-section-label,
.sidebar .sb-name,
.sidebar .sb-tagline{
  font-family:Tajawal,Cairo,sans-serif;
}
.nav-item:hover{background:var(--accent-hover-soft);color:var(--text);border-color:rgba(148,163,184,.16)}
.nav-item:focus-visible{
  outline:2px solid color-mix(in srgb,var(--accent) 70%,transparent);
  outline-offset:2px;
}
.nav-item.active{
  background:var(--grad-tab-active);
  color:#ecfdf5;
  border-color:color-mix(in srgb,var(--accent) 24%,transparent);
  border-inline-end:2px solid color-mix(in srgb,var(--accent) 80%,#fff);
  font-weight:700;
  box-shadow:0 1px 0 rgba(255,255,255,.04) inset,0 5px 12px color-mix(in srgb,var(--accent) 13%,transparent);
}
.nav-item.active .nav-icon{color:var(--accent)}
.nav-icon{width:22px;text-align:center;font-size:var(--fs-nav-icon);flex-shrink:0;line-height:1;display:inline-flex;align-items:center;justify-content:center}
.nav-label{
  flex:1;min-width:0;
  overflow:hidden;
  display:-webkit-box;
  -webkit-box-orient:vertical;
  -webkit-line-clamp:2;
  line-clamp:2;
  white-space:normal;
  line-height:1.38;
  word-break:break-word;
}
.nav-hint{font-size:var(--fs-nav-hint);color:var(--muted);font-weight:400;white-space:nowrap;margin-right:auto}
.nav-badge{background:var(--red);color:#fff;font-size:9px;font-weight:900;padding:1px 5px;border-radius:7px;min-width:16px;text-align:center;display:none;flex-shrink:0}
.nav-badge.gold{background:var(--gold)}
.nav-badge.green{background:var(--green)}
/* Sidebar user footer */
.sb-title-wrap{flex:1;min-width:0}
.sb-logout-btn{color:var(--red);width:100%;margin-top:3px}
.sb-admin-pin-wrap{padding:10px 12px;border-top:1px solid rgba(148,163,184,.12);margin-top:8px}
.sb-admin-pin-btn{width:100%;background:rgba(148,163,184,.06);border:1px solid rgba(148,163,184,.15);border-radius:8px;padding:8px 12px;color:var(--muted2);font-family:Tajawal,sans-serif;font-size:var(--fs-ui-sm);cursor:pointer;display:flex;align-items:center;gap:8px;transition:all .2s}
.sb-admin-pin-btn:hover{background:rgba(16,185,129,.12);color:var(--text)}
.topbar-current-user{font-size:11px;color:var(--muted2);padding:4px 8px;max-width:min(200px,28vw);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;align-self:center}
.topbar-admin-pin-wrap{margin:0;padding:0;border:none;display:inline-flex;align-items:center;align-self:center}
.topbar .topbar-admin-pin-wrap .sb-admin-pin-btn{width:auto;max-width:min(200px,34vw);min-height:30px;padding:5px 10px;font-size:10.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sb-footer{padding:8px 6px;border-top:1px solid rgba(148,163,184,.1)}
.sb-user{display:flex;align-items:center;gap:9px;padding:9px 10px;border-radius:9px;
  background:rgba(148,163,184,.06);border:1px solid rgba(148,163,184,.1);margin-bottom:5px}
.sb-avatar{width:28px;height:28px;border-radius:7px;
  background:var(--grad-avatar);
  display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;color:#fff;flex-shrink:0}
.sb-user-name{font-size:var(--fs-ui-sm);font-weight:700;color:var(--text2);line-height:1.3}
.sb-user-role{font-size:10px;color:var(--muted)}






.main-area{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}

.status-pill{display:flex;align-items:center;gap:6px;background:var(--surface);border:1px solid var(--border);border-radius:7px;padding:5px 10px;font-size:11px;font-weight:700}
.dot{width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 5px var(--green);animation:blink 2.4s infinite}


.scroll-area{flex:1;overflow-y:auto;padding:var(--space-20);min-height:0;scroll-padding-top:8px}.scroll-area::-webkit-scrollbar{width:5px}.scroll-area::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px}
.scroll-area [id^="panel-"]{display:none;animation:fadeUp .25s ease}
.scroll-area [id^="panel-"].active{display:block!important}
.panel-content{display:none;animation:fadeUp .25s ease}.panel-content.active{display:block}
.section-card{background:var(--grad-card);border:1px solid var(--panel-border);border-radius:14px;padding:20px 22px;margin-bottom:18px;box-shadow:0 2px 10px rgba(0,0,0,.18);transition:border-color .25s,transform .2s ease,box-shadow .25s ease}.section-card:hover{border-color:var(--panel-border-hover);transform:translateY(-1px);box-shadow:0 4px 16px rgba(0,0,0,.24)}
.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-14);gap:var(--space-8)}
.section-title2{display:flex;align-items:center;gap:8px;font-family:Tajawal,Cairo,sans-serif;font-size:var(--fs-panel-h2);font-weight:800;color:var(--text);letter-spacing:-0.02em;line-height:1.35}
.section-header-compact{margin-bottom:var(--space-14);gap:12px}
.classes-toolbar{display:flex;align-items:center;gap:10px;flex-shrink:0}
.classes-toolbar .btn.classes-toolbar-btn{height:36px;min-height:36px;padding:0 16px;margin:0;display:inline-flex;align-items:center;justify-content:center;border-radius:10px;font-size:11px;line-height:1.35;box-sizing:border-box;white-space:nowrap}
.classes-toolbar .btn-primary.classes-toolbar-btn{padding:0 24px;min-width:110px}
.classes-naming-select{width:120px;min-width:0;padding:0 12px;font-size:11px;height:36px;line-height:1.35;border-radius:10px;border:1px solid var(--border);background:var(--bg3);color:var(--text);direction:rtl;text-align:right;box-sizing:border-box;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2394a3b8' d='M6 8L2 4h8z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:left 10px center;padding-right:12px;padding-left:28px}
.classes-naming-select:focus{border-color:var(--accent);outline:none}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.divider{height:1px;background:var(--border);margin:13px 0}
.form-group{display:flex;flex-direction:column;gap:var(--space-4);margin-bottom:var(--space-12)}
.form-group label{font-size:var(--fs-label);font-weight:700;color:var(--muted2)}
.form-input{background:var(--surface);border:1.5px solid var(--border);border-radius:10px;padding:8px 11px;color:var(--text);font-family:Tajawal,sans-serif;font-size:var(--fs-ui);outline:none;transition:border-color .25s;width:100%}
.form-input:focus{border-color:var(--accent)}
.form-select{background:var(--bg3);border:1.5px solid var(--border);border-radius:10px;padding:8px 11px;color:var(--text);font-family:Tajawal,sans-serif;font-size:var(--fs-ui);outline:none;cursor:pointer;width:100%}
.form-select:focus{border-color:var(--accent)}
select option,.form-select option{background:var(--bg2);color:var(--text)}
textarea.form-input{resize:vertical;min-height:62px}
.btn{padding:7px 15px;border-radius:10px;border:none;font-family:Tajawal,sans-serif;font-size:var(--fs-ui);font-weight:700;cursor:pointer;transition:all .25s;display:inline-flex;align-items:center;gap:6px}
.btn-primary{background:var(--accent);color:#fff;box-shadow:0 3px 10px var(--accent-shadow-soft)}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 5px 14px color-mix(in srgb,var(--accent) 32%,transparent)}
.btn-success{background:var(--bg3);color:#fff}
.btn-danger{background:rgba(185,28,28,.1);color:var(--red);border:1px solid rgba(185,28,28,.2)}
.btn-danger:hover{background:rgba(185,28,28,.18)}
.btn-secondary{background:var(--surface);border:1px solid var(--border);color:var(--muted2)}
.btn-secondary:hover{background:var(--surface2);color:var(--text)}
.btn:focus-visible,.btn-primary:focus-visible,.btn-secondary:focus-visible,.btn-danger:focus-visible,.btn-success:focus-visible,.btn-gold:focus-visible{
  outline:2px solid color-mix(in srgb,var(--accent) 65%,transparent);
  outline-offset:2px;
}
.btn-gold{background:color-mix(in srgb,var(--bg3) 90%,#ffffff);color:#fff}
.btn-sm{padding:5px 11px;font-size:var(--fs-ui-sm)}.btn-icon{width:28px;height:28px;padding:0;justify-content:center}
.data-table{width:100%;border-collapse:separate;border-spacing:0 3px;font-variant-numeric:tabular-nums}
.data-table th{
  font-size:var(--fs-table-head);font-weight:800;color:var(--muted2);padding:10px 10px;background:linear-gradient(180deg,color-mix(in srgb,var(--surface) 90%,var(--bg3)),color-mix(in srgb,var(--bg3) 92%,var(--bg2)));text-align:right;
  text-transform:uppercase;letter-spacing:0.04em;
  position:sticky;top:0;z-index:2;
  box-shadow:0 1px 0 rgba(0,0,0,.25);
}
.data-table th:first-child{border-radius:0 7px 7px 0}.data-table th:last-child{border-radius:7px 0 0 7px}
.data-table td{padding:10px 10px;background:var(--bg3);font-size:var(--fs-table);text-align:right;line-height:1.55;border-bottom:1px solid rgba(255,255,255,.06)}
.data-table tbody tr:nth-child(even) td{background:color-mix(in srgb,var(--bg3) 86%,#ffffff)}
.data-table tr:hover td{background:color-mix(in srgb,var(--accent) 8%,var(--bg3))}
.data-table td:first-child{border-radius:0 7px 7px 0}.data-table td:last-child{border-radius:7px 0 0 7px}
.tag{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:5px;font-size:11px;font-weight:700}
.tag-blue{background:var(--state-info-bg);color:var(--state-info-text)}.tag-green{background:var(--state-ok-bg);color:var(--state-ok-text)}
.tag-gold{background:var(--state-warn-bg);color:var(--state-warn-text)}.tag-red{background:var(--state-error-bg);color:var(--state-error-text)}
.tag-gray{background:rgba(75,85,99,.1);color:var(--muted2)}
.chip{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:700;border:1px solid}
.chip-blue{background:var(--state-info-bg);border-color:var(--state-info-border);color:var(--state-info-text)}
.chip-gold{background:var(--state-warn-bg);border-color:var(--state-warn-border);color:var(--state-warn-text)}
.chip-green{background:var(--state-ok-bg);border-color:var(--state-ok-border);color:var(--state-ok-text)}
.chip-red{background:var(--state-error-bg);border-color:var(--state-error-border);color:var(--state-error-text)}
.chip-gray{background:rgba(75,85,99,.06);border-color:var(--border);color:var(--muted2)}
.filter-row{display:flex;gap:5px;flex-wrap:wrap;margin-bottom:12px}
.filter-btn{padding:5px 13px;border-radius:8px;border:1.5px solid var(--border);background:transparent;color:var(--muted2);font-size:12px;font-weight:700;cursor:pointer;font-family:Tajawal,sans-serif;transition:all .2s}
.filter-btn:focus-visible{outline:2px solid color-mix(in srgb,var(--accent) 60%,transparent);outline-offset:2px}
.filter-btn.active{border-color:var(--accent);color:var(--accent);background:var(--tab-hover-bg)}
.sub-tabs{display:flex;gap:3px;background:var(--tab-bg);border:1px solid var(--panel-border);border-radius:10px;padding:3px;width:fit-content;margin-bottom:var(--space-16)}
.sub-tab{padding:6px 14px;border-radius:8px;border:none;background:transparent;color:var(--muted2);font-size:12px;font-weight:700;cursor:pointer;font-family:Tajawal,sans-serif;transition:all .25s}
.sub-tab:hover{background:var(--tab-hover-bg);color:var(--text)}
.sub-tab.active{background:var(--grad-cta);color:#fff;box-shadow:var(--tab-active-shadow)}
.progress-wrap{background:rgba(255,255,255,.05);border-radius:5px;height:7px;overflow:hidden;margin:6px 0}
.progress-fill{height:100%;border-radius:5px;background:linear-gradient(90deg,var(--accent),var(--accent2));transition:width .4s ease}
.log-box{background:var(--bg);border:1px solid var(--border);border-radius:9px;padding:12px;height:200px;overflow-y:auto;font-family:monospace;font-size:11px;color:var(--muted2)}
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.72);backdrop-filter:blur(7px);z-index:1000;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .3s}
.modal-overlay.open{opacity:1;pointer-events:all}
.modal-box{background:var(--panel-bg);border:1px solid var(--panel-border);border-radius:18px;padding:24px;width:min(540px,95vw);max-height:90vh;overflow-y:auto;transform:translateY(18px);transition:transform .3s}
.modal-overlay.open .modal-box{transform:translateY(0)}
.modal-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.modal-hdr h3{font-family:Tajawal,Cairo,sans-serif;font-size:var(--fs-panel-h2);font-weight:800}
.modal-close{background:transparent;border:none;color:var(--muted);font-size:22px;cursor:pointer}.modal-close:hover{color:var(--red)}
.timetable-wrap{overflow-x:auto}
.timetable{min-width:580px;border-collapse:separate;border-spacing:3px}
.timetable th{background:var(--bg3);border-radius:7px;padding:7px 10px;font-size:11px;font-weight:800;color:var(--muted);text-align:center}
.timetable td{background:var(--bg3);border-radius:7px;padding:4px;min-width:85px;vertical-align:top}
.timetable-slot{border-radius:6px;padding:4px 7px;font-size:11px;font-weight:600}
.metrics-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:16px}
.metric-card{background:var(--card-bg);border:1px solid var(--panel-border);border-radius:11px;padding:13px;text-align:center}
.metric-val{font-family:Tajawal,Cairo,sans-serif;font-size:24px;font-weight:900}.metric-lbl{font-size:11px;color:var(--card-text-soft);margin-top:3px}
.empty-state{text-align:center;padding:44px 20px;color:var(--muted2);border:1px dashed color-mix(in srgb,var(--border2) 75%,transparent);border-radius:16px;background:var(--card-bg-soft);margin:10px 0}
.empty-icon{font-size:40px;line-height:1;margin-bottom:14px;opacity:.88;display:block;filter:drop-shadow(0 4px 14px color-mix(in srgb,var(--accent) 18%,transparent))}
.empty-state-title{font-family:Tajawal,Cairo,sans-serif;font-size:15px;font-weight:800;color:var(--text);margin-bottom:8px;line-height:1.4}
.empty-state-desc{font-size:var(--fs-ui);line-height:1.7;margin-bottom:16px;max-width:28em;margin-left:auto;margin-right:auto;color:var(--card-text-soft)}
.empty-state--compact{padding:28px 16px;margin:6px 0}
.empty-state--compact .empty-icon{font-size:32px;margin-bottom:10px}
.ov-kpi{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-14);margin-bottom:var(--space-18)}
.kpi-card{background:var(--grad-kpi);border:1px solid color-mix(in srgb,var(--border) 85%,var(--accent2));border-radius:12px;padding:17px 18px;position:relative;overflow:hidden;box-shadow:0 2px 9px rgba(0,0,0,.18);transition:border-color .25s,transform .2s ease,box-shadow .22s ease}
.kpi-card:hover{border-color:color-mix(in srgb,var(--accent2) 44%,var(--border2));transform:translateY(-1px);box-shadow:0 4px 14px rgba(0,0,0,.22)}
.kpi-val{font-family:Tajawal,Cairo,sans-serif;font-size:27px;font-weight:900;line-height:1;letter-spacing:-0.01em}
.kpi-lbl{font-size:11px;color:var(--card-text-soft);margin-top:5px;font-weight:600}
.kpi-glyph{position:absolute;top:13px;left:15px;font-size:24px;opacity:.1}
.ov-item{display:flex;align-items:center;gap:10px;padding:9px 0;border-bottom:1px solid rgba(255,255,255,.04)}
.ov-item:last-child{border-bottom:none}
.ov-welcome-card{background:linear-gradient(135deg,color-mix(in srgb,var(--surface) 100%,transparent),color-mix(in srgb,var(--bg3) 94%,var(--bg)));border:1px solid var(--border2);border-radius:12px;padding:20px 24px;margin-bottom:var(--space-20);display:flex;align-items:center;gap:18px;position:relative;overflow:hidden;box-shadow:0 2px 12px rgba(0,0,0,.2)}
.ov-logo-wrap{width:52px;height:52px;border-radius:12px;background:rgba(255,255,255,.07);border:2px solid rgba(16,185,129,.25);display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0;overflow:hidden}
.ov-welcome-body{flex:1;position:relative}
.ov-school-title{font-family:Tajawal,Cairo,sans-serif;font-size:18px;font-weight:900;color:var(--text)}
.ov-school-meta{font-size:12px;color:var(--card-text-soft);margin-top:3px}
.ov-welcome-btn{flex-shrink:0;position:relative}
.ov-date-bar{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;margin-bottom:var(--space-14);padding:10px 14px;background:var(--surface);border:1px solid var(--border);border-radius:12px;font-size:12px}
.ov-date-label{color:var(--muted2);font-weight:700}
.ov-alert{padding:10px 14px;border-radius:10px;margin-bottom:8px;font-size:12px;display:flex;align-items:center;justify-content:space-between;gap:10px}
.ov-alert-warn{background:var(--state-warn-bg);border:1px solid var(--state-warn-border);color:var(--text2)}
.ov-alert-info{background:var(--state-info-bg);border:1px solid var(--state-info-border);color:var(--text2)}
.sb-stat-row{display:grid;grid-template-columns:repeat(4,1fr);gap:11px;margin-bottom:var(--space-16)}
.sb-stat-card{background:var(--panel-bg);border:1px solid var(--panel-border);border-radius:10px;padding:12px;text-align:center}
.sb-stat-num{font-family:Tajawal,Cairo,sans-serif;font-size:22px;font-weight:900}.sb-stat-lbl{font-size:11px;color:var(--card-text-soft);margin-top:3px}
.sb-slot-card{display:flex;align-items:center;gap:10px;background:var(--card-bg);border:1px solid var(--panel-border);border-radius:10px;padding:12px;margin-bottom:7px}
.cov-card{display:flex;align-items:center;gap:10px;background:var(--card-bg);border:1px solid var(--panel-border);border-radius:10px;padding:12px;margin-bottom:7px}
.cov-card.covered{border-color:var(--state-ok-border);background:var(--state-ok-bg)}
.cov-card.pending{border-color:var(--state-warn-border);background:var(--state-warn-bg)}
.task-card{display:flex;align-items:flex-start;gap:10px;background:var(--card-bg);border:1px solid var(--panel-border);border-radius:10px;padding:12px;margin-bottom:7px}
.task-card:hover{border-color:var(--panel-border-hover)}
.task-card.done{opacity:.48}.task-card.done .task-title{text-decoration:line-through;color:var(--muted)}
.task-check{width:19px;height:19px;border-radius:5px;border:2px solid var(--border2);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0;margin-top:2px}
.task-check.checked{background:var(--green);border-color:var(--green);color:#fff;font-size:10px}
.task-title{font-size:13px;font-weight:700;margin-bottom:4px}
.task-meta{display:flex;gap:6px;flex-wrap:wrap;align-items:center}
.wa-hdr-card{background:var(--grad-wa-header);border-radius:14px;padding:18px;margin-bottom:16px;display:flex;align-items:center;gap:13px;border:1px solid color-mix(in srgb,var(--green) 22%,transparent)}
.wa-bubble{background:#1a3a2a;border-radius:0 11px 11px 11px;padding:12px 14px;font-size:12px;line-height:1.85;border:1px solid rgba(37,211,102,.1);white-space:pre-wrap;word-break:break-word;color:#d1fae5}
.wa-send-btn{background:var(--grad-wa-send);color:#fff;border:none;padding:9px 20px;border-radius:9px;font-family:Tajawal,sans-serif;font-size:13px;font-weight:700;cursor:pointer;transition:all .3s}
.wa-send-btn:hover{transform:translateY(-2px);box-shadow:0 7px 18px rgba(37,211,102,.4)}
.tab-container{background:transparent!important}.tab-panel{display:none!important}
.result-class-tabs{display:flex;gap:3px;flex-wrap:wrap;margin-bottom:13px}
.result-tab{padding:8px 16px;border-radius:9px;border:1.5px solid var(--panel-border);background:var(--card-bg);color:var(--muted2);font-size:12px;font-weight:700;cursor:pointer;font-family:Tajawal,sans-serif;transition:all .2s;display:inline-flex;align-items:center;gap:6px}
.result-tab:hover{border-color:var(--accent);color:var(--accent);background:var(--tab-hover-bg)}
.result-tab.active{background:var(--grad-cta);color:#fff;border-color:transparent;box-shadow:var(--tab-active-shadow)}
.result-tabs{display:flex;gap:5px;flex-wrap:wrap;margin-bottom:18px;padding-bottom:14px;border-bottom:1px solid var(--border)}

/* تعديل الجدول — بسيط/مركب/غير متاح/مصدر عبر --sched-edit-* (ثابتة بكل الثيمات) */
.schedule-edit-cell-source{
  position:relative;
  z-index:3;
  outline:2px solid color-mix(in srgb, var(--sched-edit-source) 85%, transparent);
  outline-offset:-2px;
  box-shadow:inset 0 0 0 1px color-mix(in srgb, var(--sched-edit-source) 35%, transparent);
}
.schedule-edit-cell-source::before{
  content:'';
  position:absolute;
  inset-block:2px;
  inset-inline-end:2px;
  width:5px;
  border-radius:3px;
  background:linear-gradient(180deg,color-mix(in srgb,var(--sched-edit-source) 88%,transparent),color-mix(in srgb,var(--sched-edit-source) 52%,transparent));
  pointer-events:none;
  z-index:2;
}
.schedule-edit-cell-source::after{
  content:'';
  position:absolute;
  inset:0;
  border-radius:2px;
  background:color-mix(in srgb, var(--sched-edit-source) 20%, transparent);
  pointer-events:none;
  z-index:0;
}
.schedule-edit-cell-target{
  position:relative;
  z-index:1;
}
.schedule-edit-cell-target-simple{
  outline:1px solid color-mix(in srgb, var(--sched-edit-simple) 52%, transparent);
  outline-offset:-2px;
}
.schedule-edit-cell-target-simple::before{
  content:'';
  position:absolute;
  inset-block:2px;
  inset-inline-end:2px;
  width:5px;
  border-radius:3px;
  background:linear-gradient(180deg,var(--sched-edit-simple),color-mix(in srgb,var(--sched-edit-simple) 48%,transparent));
  pointer-events:none;
  z-index:2;
}
.schedule-edit-cell-target-simple::after{
  content:'';
  position:absolute;
  inset:0;
  border-radius:2px;
  background:color-mix(in srgb, var(--sched-edit-simple) 30%, transparent);
  pointer-events:none;
  z-index:0;
}
.schedule-edit-cell-target-compound{
  outline:1px solid color-mix(in srgb, var(--sched-edit-compound) 58%, transparent);
  outline-offset:-2px;
}
.schedule-edit-cell-target-compound::before{
  content:'';
  position:absolute;
  inset-block:2px;
  inset-inline-end:2px;
  width:5px;
  border-radius:3px;
  background:linear-gradient(180deg,color-mix(in srgb,var(--sched-edit-compound) 90%,#fef08a),color-mix(in srgb,var(--sched-edit-compound) 45%,transparent));
  pointer-events:none;
  z-index:2;
}
.schedule-edit-cell-target-compound::after{
  content:'';
  position:absolute;
  inset:0;
  border-radius:2px;
  background:color-mix(in srgb, var(--sched-edit-compound) 34%, transparent);
  pointer-events:none;
  z-index:0;
}
.schedule-edit-cell-dim{
  position:relative;
  z-index:0;
}
.schedule-edit-cell-dim::after{
  content:'';
  position:absolute;
  inset:0;
  border-radius:2px;
  background:color-mix(in srgb, var(--sched-edit-dim) 16%, transparent);
  box-shadow:inset 0 0 0 1px color-mix(in srgb, var(--sched-edit-dim) 38%, transparent);
  pointer-events:none;
}
.schedule-edit-cell-pending-choice{
  z-index:2;
  outline:2px dashed color-mix(in srgb, var(--sched-edit-source) 75%, transparent);
  outline-offset:-3px;
  box-shadow:0 0 0 1px color-mix(in srgb, var(--sched-edit-source) 25%, transparent);
}
@supports not (background:color-mix(in srgb,red,red)){
  .schedule-edit-cell-source::after{background:rgba(34,197,94,.18)}
  .schedule-edit-cell-source{outline-color:rgba(34,197,94,.72);box-shadow:inset 0 0 0 1px rgba(34,197,94,.28)}
  .schedule-edit-cell-target-simple::after{background:rgba(59,130,246,.26)}
  .schedule-edit-cell-target-simple{outline-color:rgba(59,130,246,.45)}
  .schedule-edit-cell-target-compound::after{background:rgba(234,179,8,.28)}
  .schedule-edit-cell-target-compound{outline-color:rgba(234,179,8,.42)}
  .schedule-edit-cell-dim::after{background:rgba(239,68,68,.12)}
  .schedule-edit-cell-dim{box-shadow:inset 0 0 0 1px rgba(239,68,68,.22)}
  .schedule-edit-cell-pending-choice{outline-color:rgba(34,197,94,.6);box-shadow:0 0 0 1px rgba(34,197,94,.2)}
}
.schedule-edit-popover{
  width:min(94vw,360px);
  max-width:min(94vw,360px);
  animation:schedule-edit-popover-enter .28s ease;
}
@keyframes schedule-edit-popover-enter{
  from{opacity:0;transform:scale(.96)}
  to{opacity:1;transform:scale(1)}
}
.schedule-edit-popover-card{
  background:var(--panel-bg);
  border:1px solid var(--panel-border);
  border-radius:12px;
  border-right:4px solid var(--sched-edit-source);
  box-shadow:0 12px 40px rgba(0,0,0,.45);
  overflow:hidden;
}
.schedule-edit-popover-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
  padding:8px 10px;
  background:var(--surface);
  border-bottom:1px solid var(--border);
}
.schedule-edit-popover-head-title{
  font-size:12px;
  font-weight:800;
  color:var(--text2);
}
.schedule-edit-popover-close{
  width:32px;
  height:32px;
  flex-shrink:0;
  border:none;
  border-radius:8px;
  background:var(--bg3);
  color:var(--muted2);
  font-size:20px;
  line-height:1;
  cursor:pointer;
  transition:background .2s,color .2s;
}
.schedule-edit-popover-close:hover{background:var(--surface2);color:var(--text)}
.schedule-edit-confirm-body{padding:10px 12px}
.schedule-edit-confirm-type{font-size:13px;font-weight:800;margin-bottom:6px}
.schedule-edit-confirm-simple{color:var(--sched-edit-simple)}
.schedule-edit-confirm-compound{color:#ca8a04}
.schedule-edit-confirm-desc{font-size:11px;color:var(--muted2);margin:0 0 10px;line-height:1.55}
.schedule-edit-confirm-chain{font-size:11px;color:var(--text2);line-height:1.6}
.schedule-edit-confirm-chain ol{margin:6px 0 0;padding:0 18px 0 0}
.schedule-edit-confirm-chain-teacher{color:var(--muted2);font-size:10px}
.schedule-edit-confirm-meta{font-size:10px;color:var(--muted2);margin-top:10px;padding-top:8px;border-top:1px dashed var(--border)}
.schedule-edit-confirm-actions{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end;padding:8px 12px 10px;border-top:1px solid var(--border);background:var(--surface)}
.schedule-edit-popover-foot{
  margin:0;
  padding:6px 12px 10px;
  font-size:9px;
  color:var(--muted2);
  line-height:1.45;
  border-top:1px solid var(--border);
  background:rgba(0,0,0,.06);
}
.schedule-edit-opt-k{color:var(--muted2);font-weight:600}
.schedule-edit-kbd{
  display:inline-block;
  padding:1px 6px;
  margin:0 2px;
  font-size:9px;
  font-weight:800;
  font-family:inherit;
  vertical-align:middle;
  border:1px solid var(--border2);
  border-radius:4px;
  background:var(--bg3);
  color:var(--muted2);
}
/* تفاعل النقرات: لمس أسرع، منع تحديد النص، لمعة عند النقر غير الصالح */
.schedule-edit-touch-wrap td[onclick]{
  touch-action:manipulation;
  -webkit-user-select:none;
  user-select:none;
  -webkit-tap-highlight-color:rgba(34,197,94,.22);
}
.schedule-edit-cell-target-simple:active,
.schedule-edit-cell-target-compound:active{filter:brightness(1.09)}
.schedule-edit-cell-source:active{
  filter:brightness(1.05);
}
@keyframes schedule-edit-invalid-pulse{
  0%,100%{box-shadow:inset 0 0 0 0 transparent}
  35%{box-shadow:inset 0 0 0 3px rgba(239,68,68,.72)}
  70%{box-shadow:inset 0 0 0 2px rgba(239,68,68,.45)}
}
.schedule-edit-invalid-flash{
  animation:schedule-edit-invalid-pulse .48s ease;
}
@media(max-width:600px){
  .schedule-edit-popover{max-width:min(96vw,380px)}
}
.result-conflicts-alert{margin-bottom:16px}
.result-conflicts-box{background:var(--state-error-bg);border:1px solid var(--state-error-border);border-radius:12px;padding:14px 18px}
.result-conflicts-head{display:flex;align-items:center;gap:8px;font-family:Tajawal,Cairo,sans-serif;font-size:14px;font-weight:800;color:var(--red);margin-bottom:8px}
.result-conflicts-icon{font-size:18px}
.result-conflicts-msg{font-size:12px;color:var(--text2);margin:0 0 10px;line-height:1.6}
.result-conflicts-list{margin:0;padding:0 0 0 20px;font-size:12px;color:var(--text2);line-height:1.8}
.result-conflicts-list li{margin-bottom:4px}
.tt-grid-wrap{overflow-x:auto;margin-bottom:8px}
.tt-grid{display:grid;gap:2px}
.tt-header{background:var(--bg3);border-radius:6px;padding:8px 6px;font-size:11px;font-weight:800;color:var(--muted);text-align:center}
/* تمييز أيام 6 حصص عن أيام 7 حصص في جداول النتائج */
.tt-day-cell{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px}
.tt-day-ppd-6{background:linear-gradient(135deg,var(--surface),color-mix(in srgb,var(--accent3) 14%,transparent))!important;border-right:2px solid var(--accent3)!important}
.tt-day-ppd-6 .tt-day-ppd-badge{font-size:9px;font-weight:700;color:var(--accent3);background:color-mix(in srgb,var(--accent3) 14%,transparent);padding:1px 5px;border-radius:4px}
.tt-day-ppd-7 .tt-day-ppd-badge{font-size:9px;font-weight:700;color:var(--accent);background:rgba(16,185,129,.1);padding:1px 5px;border-radius:4px}
.tt-cell{min-width:80px}
.tt-cell.tt-time{display:flex;align-items:center;justify-content:center;font-size:11px;color:var(--muted2);font-weight:700;background:var(--surface);border-radius:5px;padding:4px}
.tt-lesson{border-radius:6px;padding:5px 6px;text-align:center;min-height:40px;display:flex;flex-direction:column;align-items:center;justify-content:center}
.tt-lesson-subject{font-size:11px;font-weight:800;line-height:1.2}
.tt-lesson-teacher{font-size:9px;color:var(--muted2);margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:90px}
.tt-empty{display:flex;align-items:center;justify-content:center;min-height:40px;color:var(--muted);font-size:11px;background:rgba(255,255,255,.02);border-radius:5px}
.rct-btn{padding:5px 13px;border-radius:7px;border:1.5px solid var(--border2);background:var(--surface);color:var(--text2);font-size:12px;font-weight:700;cursor:pointer;font-family:Tajawal,sans-serif;transition:all .2s}
.rct-btn:hover{border-color:var(--accent);color:var(--text);background:var(--tab-hover-bg)}
.rct-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}
.gen-page-wrap{display:flex;flex-direction:column;gap:20px;max-width:1200px;margin:0 auto}
/* معايير الجدولة ثابتة — إخفاء من الواجهة فقط (لا تُزال من DOM) */
.gen-criteria-fixed-hidden{display:none!important}
.gen-criteria-card .section-card-header{margin-bottom:14px}
.gen-criteria-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px 18px;align-items:start}
.gen-criteria-grid .gen-field-full{grid-column:1/-1}
.gen-days-chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:6px}
.gen-optim-label{grid-column:1/-1;margin-bottom:4px}
.gen-optim-title{font-family:Tajawal,Cairo,sans-serif;font-size:13px;font-weight:700;color:var(--muted)}
.gen-optim-check{display:flex;flex-wrap:wrap;align-items:flex-start;gap:8px;cursor:pointer;padding:12px 14px;background:var(--surface);border:1px solid var(--border);border-radius:10px;font-size:12px;transition:border-color .2s,background .2s}
.gen-optim-check:hover{border-color:var(--border2);background:var(--surface2)}
.gen-optim-check input{flex-shrink:0;margin-top:2px}
.gen-optim-name{font-weight:700;color:var(--text);display:block}
.gen-optim-desc{font-size:10px;color:var(--muted);display:block;margin-top:2px}
.gen-main-grid{display:grid;grid-template-columns:minmax(280px,360px) 1fr;gap:20px;align-items:start}
.gen-actions-card .section-card-header{margin-bottom:12px}
.gen-actions-header{display:flex;flex-wrap:wrap;align-items:center;gap:10px}
.gen-actions-header .section-card-title{flex:1;min-width:0}
.gen-status-wrap{display:flex;align-items:center;gap:7px;flex-shrink:0}
.gen-status-text{font-size:11px;color:var(--muted)}
.gen-readiness-box{margin-bottom:12px}
.gen-readiness-panel{
  border-radius:10px;padding:12px;border:1px solid var(--panel-border);
  background:var(--card-bg);
}
.gen-readiness-panel.gen-r-issues{
  border-color:color-mix(in srgb,var(--red) 45%,var(--border));
  background:color-mix(in srgb,var(--red) 11%,var(--bg3));
}
.gen-readiness-panel.gen-r-warn{
  border-color:color-mix(in srgb,var(--gold) 50%,var(--border));
  background:color-mix(in srgb,var(--gold) 12%,var(--bg3));
}
.gen-readiness-panel.gen-r-ok{
  border-color:color-mix(in srgb,var(--green) 45%,var(--border));
  background:color-mix(in srgb,var(--green) 10%,var(--bg3));
}
.gen-readiness-head{
  font-weight:700;font-size:12px;margin-bottom:8px;display:flex;align-items:center;gap:6px;
  color:var(--text2);
}
.gen-readiness-panel.gen-r-issues .gen-readiness-head{color:var(--red)}
.gen-readiness-panel.gen-r-warn .gen-readiness-head{color:var(--gold)}
.gen-readiness-panel.gen-r-ok .gen-readiness-head{color:var(--green)}
.gen-readiness-item{font-size:11px;padding:3px 0;line-height:1.45}
.gen-readiness-item.gen-r-issue{color:var(--red)}
.gen-readiness-item.gen-r-warn{color:var(--gold)}
.gen-readiness-item.gen-r-ok{color:var(--green)}
.gen-readiness-more{font-size:10px;color:var(--muted);padding-top:4px}
.gen-summary-text{font-size:13px;color:var(--card-text-soft);line-height:1.9;margin-bottom:16px}
.gen-buttons{display:flex;flex-direction:column;gap:10px}
.gen-btn-primary{width:100%}
.gen-btn-secondary{width:100%}
.gen-preview-card{min-height:320px;display:flex;flex-direction:column}
.gen-preview-card .section-card-header{margin-bottom:12px}
.gen-preview-area{overflow:auto;flex:1;min-height:200px}
.gen-empty-state{padding:40px;text-align:center}
.gen-log-box{max-height:120px;margin-top:10px}
@keyframes fadeUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.4}}
@media(max-width:900px){.sidebar{display:none}.ov-kpi,.metrics-grid,.sb-stat-row{grid-template-columns:1fr 1fr}.gen-main-grid{grid-template-columns:1fr}}
@media(max-width:600px){.ov-kpi,.grid-2,.grid-3{grid-template-columns:1fr}.gen-criteria-grid{grid-template-columns:1fr}}

/* Topbar */
.topbar{height:50px;background:color-mix(in srgb,var(--bg3) 88%,var(--bg2));backdrop-filter:blur(20px);
  border-bottom:1px solid rgba(148,163,184,.12);display:flex;align-items:center;
  padding:0 18px;gap:12px;flex-shrink:0;z-index:4}
#app-topbar{height:auto;min-height:50px;padding-top:6px;padding-bottom:6px}
.topbar-title{font-family:Tajawal,Cairo,sans-serif;font-size:var(--fs-topbar-title);font-weight:800;color:var(--text);line-height:1.2}
.topbar-sub{font-size:var(--fs-topbar-sub);color:var(--muted2);font-weight:400;margin-top:1px}
.topbar-right{display:flex;align-items:center;gap:7px;margin-right:auto}
.topbar-steps{
  display:flex;align-items:center;gap:4px;
  flex-wrap:nowrap;
  overflow-x:auto;
  overflow-y:hidden;
  -webkit-overflow-scrolling:touch;
  scroll-snap-type:x proximity;
  max-width:min(200px,32vw);
  padding:4px 2px;
  scrollbar-width:thin;
  scrollbar-color:var(--border2) transparent;
}
.topbar-steps::-webkit-scrollbar{height:3px}
.topbar-steps::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px}
.ts{
  flex:0 0 auto;scroll-snap-align:start;
  width:22px;height:22px;border-radius:6px;background:var(--surface);
  border:1px solid var(--border);color:var(--muted2);font-size:9.5px;font-weight:900;
  display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;
  font-family:Tajawal,Cairo,sans-serif}
.ts:hover{background:rgba(16,185,129,.1);border-color:var(--accent);color:var(--accent)}
.ts.done{background:rgba(22,163,74,.1);border-color:rgba(22,163,74,.28);color:var(--green)}
.icon-btn{width:30px;height:30px;border-radius:7px;background:var(--surface);border:1px solid var(--border);
  color:var(--muted2);font-size:var(--fs-ui);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}
.icon-btn:hover{background:var(--surface2);color:var(--text)}
.topbar-logout-btn{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;white-space:nowrap}
.icon-btn:focus-visible{
  outline:2px solid color-mix(in srgb,var(--accent2) 70%,transparent);
  outline-offset:2px;
}


.status-dot{width:8px;height:8px;border-radius:50%;background:var(--muted);flex-shrink:0}
.status-dot.ready{background:var(--accent);box-shadow:0 0 6px rgba(16,185,129,.4)}
.status-dot.running{background:var(--gold);animation:pulse 1s infinite}
.status-dot.done{background:var(--green);box-shadow:0 0 6px rgba(22,163,74,.4)}
.status-dot.error{background:var(--red)}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}


#si-logo-preview:hover{border-color:var(--accent)!important;background:rgba(16,185,129,.08)!important}


/* ── New Panels CSS ── */
.section-badge{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:22px;padding:0 6px;border-radius:6px;font-size:11px;font-weight:800;background:rgba(16,185,129,.15);color:var(--accent);border:1px solid rgba(16,185,129,.25);}
.section-card-title{display:flex;align-items:center;gap:8px;font-family:Tajawal,Cairo,sans-serif;font-size:15px;font-weight:800;letter-spacing:-0.02em;color:var(--text);}
.section-card-title h3{margin:0;font-size:15px;font-weight:800;}
.section-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;flex-wrap:wrap;gap:8px;}
.kpi-mini{background:var(--grad-kpi);border:1px solid var(--border);border-radius:10px;padding:10px 14px;display:flex;flex-direction:column;gap:3px;}
.kpi-mini-val{font-family:Tajawal,Cairo,sans-serif;font-size:20px;font-weight:900;line-height:1;}
.kpi-mini-lbl{font-size:10px;color:var(--muted2);}
.att-row{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:9px;border:1px solid var(--border);background:var(--bg3);margin-bottom:6px;}
.att-status-btn{padding:4px 10px;border-radius:6px;border:1.5px solid;font-size:11px;font-weight:700;cursor:pointer;font-family:Tajawal,sans-serif;transition:.15s;}
.mtg-card{background:var(--bg3);border:1px solid var(--border);border-radius:10px;padding:12px 14px;display:flex;align-items:flex-start;gap:12px;margin-bottom:8px;}
.mtg-type-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;margin-top:4px;}
.ana-chart-wrap{background:var(--bg3);border:1px solid var(--border);border-radius:12px;padding:16px;margin-bottom:12px;}
.bar-row{display:flex;align-items:center;gap:10px;margin-bottom:7px;}
.bar-label{width:130px;font-size:12px;color:var(--muted2);text-align:right;flex-shrink:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.bar-track{flex:1;height:10px;background:rgba(255,255,255,.06);border-radius:5px;overflow:hidden;}
.bar-fill{height:100%;border-radius:5px;transition:width .4s ease;}
.bar-val{width:40px;font-size:11px;font-weight:700;text-align:left;flex-shrink:0;}
.perm-role-btn{padding:7px 16px;border-radius:8px;border:1.5px solid var(--border);background:transparent;color:var(--muted2);font-family:Tajawal,sans-serif;font-size:12px;font-weight:700;cursor:pointer;transition:.15s;}
.perm-role-btn.active{border-color:var(--accent);background:rgba(16,185,129,.15);color:var(--text);}
.perm-row{display:flex;align-items:center;justify-content:space-between;padding:9px 12px;border-radius:8px;border:1px solid var(--border);margin-bottom:6px;font-size:13px;}
.noor-import-card,.noor-export-card{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:9px;border:1px solid var(--border);background:var(--bg3);cursor:pointer;font-family:Tajawal,sans-serif;font-size:13px;font-weight:600;color:var(--text);transition:.15s;width:100%;text-align:right;}
.noor-import-card:hover,.noor-export-card:hover{border-color:var(--accent);background:rgba(16,185,129,.1);}
.exam-card{background:var(--bg3);border:1px solid var(--border);border-radius:10px;padding:12px;display:flex;align-items:center;gap:12px;margin-bottom:7px;}
.tp-stat-row{display:flex;align-items:center;justify-content:space-between;padding:8px 10px;border-radius:7px;background:var(--bg3);border:1px solid var(--border);margin-bottom:6px;font-size:12px;}
.user-row{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:9px;border:1px solid var(--border);background:var(--bg3);margin-bottom:6px;}
.rec-card{display:flex;align-items:flex-start;gap:10px;padding:10px 12px;border-radius:9px;border-right:3px solid;margin-bottom:7px;background:var(--bg3);}
.daily-slot{padding:3px 6px;border-radius:5px;font-size:10.5px;font-weight:700;letter-spacing:.01em;text-align:center;min-height:28px;display:flex;align-items:center;justify-content:center;cursor:default;}
.divider{height:1px;background:var(--border);margin:14px 0;}

.nav-badge.red{background:rgba(185,28,28,.85);color:#fff;}
.nav-badge.green{background:rgba(22,163,74,.85);color:#fff;}
.tag-gold{background:var(--state-warn-bg);color:var(--state-warn-text);border:1px solid var(--state-warn-border);}
.tag-blue{background:var(--state-info-bg);color:var(--state-info-text);border:1px solid var(--state-info-border);}

.form-row-3{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.form-row-4{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.form-row{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
/* ── New Panel Style Fixes ── */
/* h3 داخل عنوان اللوحة — يتبع --fs-panel-h3 */
.section-title2 h3 { font-size:var(--fs-panel-h3); font-weight:800; margin:0; font-family:Tajawal,Cairo,sans-serif; }

/* Attendance rows — consistent with task/standby rows */
.att-row { display:flex; align-items:center; gap:10px; padding:10px 14px;
  background:var(--bg3); border:1px solid var(--border); border-radius:10px; margin-bottom:6px; }
.att-status-btn { padding:4px 12px; border-radius:7px; border:1.5px solid;
  font-size:12px; font-weight:700; cursor:pointer; font-family:Tajawal,sans-serif;
  transition:.15s; background:transparent; }

/* Meetings card — uniform with existing list cards */
.mtg-card { background:var(--bg3); border:1px solid var(--border); border-radius:10px;
  padding:12px 14px; display:flex; align-items:flex-start; gap:12px; margin-bottom:7px;
  transition:border-color .2s; }
.mtg-card:hover { border-color:rgba(16,185,129,.35); }

/* Analytics chart wrapper */
.ana-chart-wrap { background:var(--bg3); border:1px solid var(--border);
  border-radius:12px; padding:18px; margin-bottom:12px; }
.ana-chart-wrap h4 { font-family:Tajawal,Cairo,sans-serif; font-size:13px; font-weight:800;
  color:var(--muted2); margin:0 0 14px; }
.bar-row { display:flex; align-items:center; gap:10px; margin-bottom:8px; direction:ltr; }
.bar-label { width:140px; font-size:12px; color:var(--muted2); direction:rtl;
  text-align:right; flex-shrink:0; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.bar-track { flex:1; height:10px; background:rgba(255,255,255,.07);
  border-radius:5px; overflow:hidden; position:relative; }
.bar-fill { height:100%; border-radius:5px; transition:width .5s ease; }
.bar-val { width:48px; font-size:11px; font-weight:700; text-align:left; flex-shrink:0; direction:ltr; }

/* عرض اسم الفصل: (الصف) مسافة (/) مسافة (الفصل) — تُقرأ من اليمين لليسار */
.class-name-rtl { direction: rtl; display: inline-block; text-align: right; unicode-bidi: embed; }

/* Exam cards */
.exam-card { background:var(--bg3); border:1px solid var(--border); border-radius:10px;
  padding:12px 14px; display:flex; align-items:center; gap:12px; margin-bottom:7px;
  transition:border-color .2s; }
.exam-card:hover { border-color:rgba(16,185,129,.3); }

/* Permission rows */
.perm-row { display:flex; align-items:center; justify-content:space-between;
  padding:10px 14px; border-radius:9px; background:var(--bg3);
  border:1px solid var(--border); margin-bottom:6px; font-size:13px; }

/* User rows */
.user-row { display:flex; align-items:center; gap:10px; padding:10px 14px;
  background:var(--bg3); border:1px solid var(--border); border-radius:10px; margin-bottom:6px; }

/* Role buttons */
.perm-role-btn { padding:7px 16px; border-radius:8px; border:1.5px solid var(--border);
  background:transparent; color:var(--muted2); font-family:Tajawal,sans-serif;
  font-size:12px; font-weight:700; cursor:pointer; transition:.15s; }
.perm-role-btn:hover { border-color:var(--accent); color:var(--text); }
.perm-role-btn.active { border-color:var(--accent); background:rgba(16,185,129,.15); color:var(--text); }

/* Section badge inside headers */
.section-title2 .section-badge { margin-right: 4px; }

/* Noor import/export cards */
.noor-import-card, .noor-export-card { display:flex; align-items:center; gap:10px;
  padding:11px 14px; border-radius:9px; border:1px solid var(--border);
  background:var(--bg3); cursor:pointer; font-family:Tajawal,sans-serif;
  font-size:13px; font-weight:600; color:var(--text); transition:.15s; width:100%;
  text-align:right; }
.noor-import-card:hover, .noor-export-card:hover { border-color:rgba(16,185,129,.5);
  background:rgba(16,185,129,.08); }

/* Daily KPI mini cards */
.kpi-mini { background:var(--grad-kpi); border:1px solid var(--border);
  border-radius:10px; padding:10px 14px; display:flex; flex-direction:column; gap:3px; }
.kpi-mini-val { font-family:Tajawal,Cairo,sans-serif; font-size:20px; font-weight:900; line-height:1; }
.kpi-mini-lbl { font-size:10px; color:var(--muted2); }

/* Recommendation cards (daily view) */
.rec-card { display:flex; align-items:flex-start; gap:10px; padding:10px 14px;
  border-radius:9px; border-right:3px solid; margin-bottom:7px; background:var(--bg3);
  font-size:13px; }

/* TP stats rows */
.tp-stat-row { display:flex; align-items:center; justify-content:space-between;
  padding:8px 12px; border-radius:7px; background:var(--bg3);
  border:1px solid var(--border); margin-bottom:5px; font-size:12px; }

/* Daily slot cells */
.daily-slot { padding:3px 5px; border-radius:5px; font-size:10.5px; font-weight:700;
  text-align:center; min-height:28px; display:flex; align-items:center;
  justify-content:center; }

/* Form row grids — override any conflicting definitions */
.form-row-3 { display:grid; grid-template-columns:repeat(3,1fr); gap:12px; margin-bottom:12px; }
.form-row-4 { display:grid; grid-template-columns:repeat(4,1fr); gap:12px; margin-bottom:12px; }

/* Tag variants */
.tag-gold { background:var(--state-warn-bg); color:var(--state-warn-text);
  border:1px solid var(--state-warn-border) !important; }
.tag-blue { background:var(--state-info-bg); color:var(--state-info-text);
  border:1px solid var(--state-info-border) !important; }


*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html,body{height:100%;overflow:hidden}
body{font-family:Tajawal,Cairo,sans-serif;background:var(--bg);color:var(--text);font-size:var(--fs-app)}
body::before{content:"";position:fixed;inset:0;pointer-events:none;background:var(--grad-radial-body)}
.font-en{font-family:Inter,ui-sans-serif,sans-serif}
.page{position:fixed;inset:0;z-index:10;opacity:0;pointer-events:none;transform:translateY(8px);transition:opacity .3s,transform .3s}
.page.active{opacity:1;pointer-events:all;transform:translateY(0)}
/* الصفحة الرئيسية: حاوية تمرير بارتفاع الشاشة (body له overflow:hidden) */
#page-landing{
  display:flex;
  flex-direction:column;
  position:relative;
  inset:auto;
  width:100%;
  height:100vh;
  height:100dvh;
  max-height:100vh;
  max-height:100dvh;
  min-height:0;
  overflow-y:auto;
  overflow-x:hidden;
  -webkit-overflow-scrolling:touch;
  overscroll-behavior-y:contain;
  background:var(--bg);
  z-index:10;
}
#page-landing::before{content:"";position:absolute;inset:0;pointer-events:none;opacity:.12;
  background-image:radial-gradient(#94a3b8 1px,transparent 1px);background-size:24px 24px}
.land-nav{position:sticky;top:0;z-index:100;display:flex;align-items:center;justify-content:space-between;
  padding:13px 44px;background:color-mix(in srgb,var(--bg3) 90%,var(--bg2));backdrop-filter:blur(20px);border-bottom:1px solid var(--border)}
.land-logo{width:clamp(46px,2.85vw,56px);height:clamp(46px,2.85vw,56px);border-radius:12px;flex-shrink:0;
  background:var(--brand-logo-svg) center/100% no-repeat,transparent;
  display:flex;align-items:center;justify-content:center;font-size:0;color:transparent;overflow:hidden;text-indent:-99px}
#page-landing .land-nav .land-logo{width:clamp(40px,2.4vw,48px);height:clamp(40px,2.4vw,48px)}
.land-hero-brand{display:flex;flex-direction:row;align-items:center;justify-content:center;gap:clamp(10px,2vw,16px);
  margin:0 auto 18px;max-width:100%;direction:rtl}
.land-hero-logo{width:clamp(56px,9vw,76px);height:clamp(56px,9vw,76px);margin:0;border-radius:0;flex-shrink:0;
  background:var(--brand-logo-svg) center/contain no-repeat,transparent;
  filter:drop-shadow(0 6px 20px color-mix(in srgb,var(--brand-logo-primary) 32%,transparent))}
.land-hero-text{display:flex;flex-direction:column;align-items:flex-start;text-align:right;gap:2px;line-height:1.15}
.land-hero-line{font-family:Tajawal,Cairo,sans-serif;font-size:clamp(20px,3vw,28px);font-weight:900;margin:0;
  background:linear-gradient(90deg,#fff 5%,var(--brand-logo-primary));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.land-hero-line--sub{font-size:clamp(14px,2vw,18px);font-weight:700;color:var(--muted2);
  background:none;-webkit-text-fill-color:unset}
.land-name{font-family:Tajawal,Cairo,sans-serif;font-size:17px;font-weight:900;background:linear-gradient(90deg,#fff,var(--muted2));-webkit-background-clip:text;-webkit-text-fill-color:transparent}
#page-landing .hero{display:flex;flex-direction:column;align-items:center;text-align:center;padding:40px 24px 38px;width:100%;box-sizing:border-box}
#page-landing .hero h1{width:100%;max-width:720px;margin-left:auto;margin-right:auto}
#page-landing .hero-paths{width:100%;max-width:520px;margin:0 auto}
.hero h1{font-family:Tajawal,Cairo,sans-serif;font-size:clamp(30px,4.5vw,54px);font-weight:900;line-height:1.15;margin-bottom:28px}
.hero h1 em{font-style:normal;background:var(--grad-text-hero);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.hero p{font-size:15px;color:var(--muted2);max-width:520px;margin:0 auto 30px;line-height:1.85}
.hero-cta{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}
.btn-main{padding:11px 30px;background:var(--accent);color:#fff;border:none;border-radius:11px;font-family:Tajawal,sans-serif;font-size:14px;font-weight:700;cursor:pointer;transition:all .3s}
.btn-main:hover{transform:translateY(-2px);box-shadow:0 8px 20px color-mix(in srgb,var(--accent) 30%,transparent)}
.btn-ghost{padding:10px 28px;background:transparent;color:var(--text2);border:1.5px solid var(--border2);border-radius:11px;font-family:Tajawal,sans-serif;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold)}
.stats-bar{display:flex;justify-content:center;border-top:1px solid var(--border);border-bottom:1px solid var(--border);flex-wrap:wrap}
.stat-pill{flex:1;min-width:160px;text-align:center;padding:20px 28px;border-left:1px solid var(--border)}
.stat-pill:last-child{border-left:none}
.stat-num{font-family:Tajawal,Cairo,sans-serif;font-size:30px;font-weight:900;background:var(--grad-text-stat);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.stat-lbl{font-size:12px;color:var(--muted2);margin-top:3px;font-weight:700}
.features{padding:16px 12px 22px;display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:8px;max-width:1180px;margin:10px auto 0}
.feat-card{background:var(--panel-bg);border:1px solid var(--panel-border);border-radius:12px;padding:10px 8px;transition:all .3s;min-height:84px}
.feat-card:hover{border-color:color-mix(in srgb,var(--accent) 32%,transparent);transform:translateY(-3px)}
.feat-icon{width:26px;height:26px;border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:12px;margin-bottom:6px}
.feat-name{font-family:Tajawal,Cairo,sans-serif;font-size:12px;font-weight:800;margin-bottom:3px}
.feat-desc{font-size:9.5px;color:var(--card-text-soft);line-height:1.35}
.landing-philo{position:relative;padding:22px 44px 46px;background:linear-gradient(180deg,color-mix(in srgb,var(--bg2) 92%,var(--bg)),color-mix(in srgb,var(--bg) 96%,#000))}
.landing-philo-head{text-align:center;max-width:900px;margin:0 auto 20px}
.landing-philo-kicker{font-family:Inter,sans-serif;font-size:10px;letter-spacing:.26em;color:color-mix(in srgb,var(--accent) 70%,#fff);font-weight:700;margin-bottom:8px}
.landing-philo-head h2{font-family:Inter,serif;font-size:clamp(28px,4.4vw,50px);letter-spacing:.22em;font-weight:900;color:#eaf0fb;margin:0 0 8px;direction:ltr}
.landing-philo-head p{font-size:13px;color:rgba(216,220,232,.78);line-height:1.85;margin:0}
.landing-philo-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1px;background:color-mix(in srgb,var(--border) 48%,transparent);border-radius:18px;overflow:hidden;max-width:1120px;margin:0 auto;direction:ltr}
.lp-card{position:relative;padding:14px 12px;min-height:108px;background:var(--panel-bg-strong);overflow:hidden;text-align:right}
.lp-letter{position:absolute;top:7px;left:10px;font-family:Inter,serif;font-size:36px;font-weight:900;line-height:1;color:rgba(255,255,255,.07);pointer-events:none;direction:ltr}
.lp-key{position:relative;display:block;font-family:Inter,sans-serif;font-size:9px;letter-spacing:.2em;color:color-mix(in srgb,var(--accent) 72%,#fff);font-weight:700;margin-bottom:6px}
.lp-card h3{position:relative;font-family:Tajawal,Cairo,sans-serif;font-size:14px;font-weight:800;color:#f1f5f9;margin:0 0 4px;line-height:1.35}
.lp-card p{position:relative;font-size:11px;color:var(--card-text-soft);line-height:1.6;margin:0}
.land-footer{text-align:center;padding:22px;color:var(--muted);font-size:12px;border-top:1px solid var(--border)}
#page-auth{display:flex;align-items:center;justify-content:center;background:var(--bg);overflow-y:auto;padding:var(--space-16);min-height:100vh;box-sizing:border-box}
.auth-wrap{width:min(420px,96vw);max-width:100%;background:var(--panel-bg);border:1px solid var(--panel-border);border-radius:22px;padding:var(--space-24);margin:var(--space-20) 0}
.auth-tabs{display:flex;gap:var(--space-4);background:var(--tab-bg);border:1px solid var(--panel-border);border-radius:12px;padding:var(--space-4);margin-bottom:var(--space-20);width:100%;box-sizing:border-box}
.auth-tab{flex:1;min-height:44px;padding:10px var(--space-8);border-radius:9px;border:none;background:transparent;color:var(--muted2);font-family:Tajawal,sans-serif;font-size:13px;font-weight:700;cursor:pointer;transition:all .25s;touch-action:manipulation}
.auth-tab:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.auth-tab:hover{background:var(--tab-hover-bg);color:var(--text)}
.auth-tab.active{background:var(--grad-cta);color:#fff;box-shadow:var(--tab-active-shadow)}
.auth-form{display:flex;flex-direction:column;gap:var(--space-12)}
.f-label{font-size:11px;font-weight:700;color:var(--muted2);display:block;margin-bottom:var(--space-4)}
.f-input{background:var(--surface);border:1.5px solid var(--border);border-radius:9px;padding:var(--space-10) var(--space-12);color:var(--text);font-family:Tajawal,Cairo,sans-serif;font-size:14px;outline:none;transition:border-color .25s;width:100%;box-sizing:border-box}
.f-input:focus{border-color:var(--accent)}
.btn-auth{background:var(--accent);color:#fff;border:none;padding:var(--space-12);border-radius:10px;font-family:Tajawal,sans-serif;font-size:15px;font-weight:700;cursor:pointer;transition:all .3s;margin-top:var(--space-4)}
.btn-auth:hover{box-shadow:0 6px 16px color-mix(in srgb,var(--accent) 30%,transparent)}
.auth-or{display:flex;align-items:center;gap:var(--space-10);color:var(--muted);font-size:11px}
.auth-or::before,.auth-or::after{content:"";flex:1;height:1px;background:var(--border)}
.btn-guest{background:transparent;border:1.5px solid var(--border2);color:var(--text2);padding:var(--space-10);border-radius:10px;font-family:Tajawal,sans-serif;font-size:13px;font-weight:600;cursor:pointer;transition:all .25s;width:100%}
.btn-guest:hover{border-color:var(--gold);color:var(--gold)}
@media(max-width:480px){.auth-wrap{padding:var(--space-20)}#page-auth{padding:var(--space-12)}}
@media(max-width:380px){
  .auth-tabs{flex-direction:column;align-items:stretch}
  .auth-tab{width:100%}
}

/* صفحة دخول المشترك المفعّل: تمركز كامل بمنتصف الشاشة */
#page-school-login{
  display:flex;
  align-items:center;
  justify-content:center;
  background:var(--bg);
  overflow-y:auto;
  padding:18px;
  min-height:100vh;
  box-sizing:border-box;
}
#page-school-login .auth-wrap{width:min(480px,96vw)}
#page-school-login .f-input{min-height:54px}
#page-school-login .btn-auth{min-height:56px}
@media(max-width:900px){.landing-philo{padding:20px 20px 34px}.landing-philo-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}
@media(max-width:700px){.landing-philo-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:600px){.landing-philo{padding:18px 14px 28px}.landing-philo-head h2{font-size:clamp(22px,8vw,34px);letter-spacing:.14em}.landing-philo-grid{grid-template-columns:1fr}.lp-card{min-height:98px}.lp-letter{font-size:32px}}

/* ══ صفحة الدخول بالاشتراك وباقات الأسعار ══ */
#page-pricing{display:flex;flex-direction:column;overflow-y:auto;background:var(--bg);min-height:100vh}
.pricing-nav{position:sticky;top:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:13px 44px;background:color-mix(in srgb,var(--bg3) 90%,var(--bg2));backdrop-filter:blur(20px);border-bottom:1px solid var(--border)}
.pricing-hero{text-align:center;padding:30px 24px 22px}
.pricing-hero h1{font-family:Tajawal,Cairo,sans-serif;font-size:clamp(24px,4vw,32px);font-weight:900;margin-bottom:8px}
.pricing-hero p{font-size:14px;color:var(--muted2);margin:0 auto;max-width:640px;line-height:1.7}
.pricing-login-box{max-width:980px;margin:0 auto 28px;background:linear-gradient(180deg,rgba(255,255,255,.02),rgba(255,255,255,.01));border:1px solid color-mix(in srgb,var(--panel-border) 84%,var(--accent2));border-radius:18px;padding:24px 26px;box-shadow:0 10px 26px rgba(0,0,0,.24)}
.pricing-login-box .auth-tabs{margin:0 0 16px auto;max-width:280px}
.pricing-login-box .auth-form{display:grid;grid-template-columns:repeat(2,minmax(240px,1fr));gap:12px;max-width:900px;margin:0 auto}
.pricing-login-box .auth-form > div{display:flex;flex-direction:column;gap:6px}
.pricing-login-box .auth-form .btn-auth{grid-column:1/-1;width:min(420px,100%);margin:10px auto 0;justify-content:center}
.pricing-login-box .auth-form .btn.btn-secondary{width:100%}
#pricing-cloud-status{max-width:900px !important}
#pricing-quick-school{max-width:900px !important}
#pricing-bank-request .auth-form{display:grid;grid-template-columns:1fr 1fr;gap:12px;max-width:none}
#pricing-bank-request textarea.f-input{resize:vertical;min-height:86px}
#pricing-bank-request .bank-transfer-actions{
  display:flex;
  flex-direction:row;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
}
#pricing-bank-request .bank-transfer-btn-main{
  margin-top:0;
  flex:1 1 240px;
  min-height:46px;
}
#pricing-bank-request .bank-transfer-btn-cancel{
  flex:1 1 180px;
  min-height:46px;
  justify-content:center;
}
@media(max-width:900px){
  .pricing-login-box{max-width:100%;margin:0 16px 24px;padding:18px 16px}
  .pricing-login-box .auth-tabs{max-width:none;margin:0 0 12px}
  .pricing-login-box .auth-form{grid-template-columns:1fr;max-width:none}
  .pricing-login-box .auth-form .btn-auth{width:100%;margin:6px 0 0}
  #pricing-bank-request .auth-form{grid-template-columns:1fr}
  #pricing-bank-request .bank-transfer-actions{flex-direction:column}
  #pricing-bank-request .bank-transfer-btn-main,
  #pricing-bank-request .bank-transfer-btn-cancel{width:100%;flex:1 1 auto}
}
.pricing-plans{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px;max-width:1320px;margin:0 auto 40px;padding:0 24px}
.plan-card{background:var(--panel-bg);border:2px solid var(--panel-border);border-radius:18px;padding:24px;position:relative;transition:all .3s;display:flex;flex-direction:column}
.plan-card:hover{border-color:rgba(16,185,129,.45);transform:translateY(-4px);box-shadow:0 12px 32px rgba(0,0,0,.25)}
.plan-card.featured{border-color:var(--accent);background:linear-gradient(180deg,color-mix(in srgb,var(--accent) 12%,transparent) 0%,var(--panel-bg) 40%);box-shadow:0 8px 24px color-mix(in srgb,var(--accent) 22%,transparent)}
.plan-card.featured .plan-name{color:var(--accent)}
.plan-badge{position:absolute;top:-10px;left:50%;transform:translateX(-50%);background:var(--accent);color:#fff;font-size:11px;font-weight:800;padding:4px 14px;border-radius:20px;white-space:nowrap}
.plan-name{font-family:Tajawal,Cairo,sans-serif;font-size:18px;font-weight:900;margin-bottom:6px}
.plan-desc{font-size:12px;color:var(--card-text-soft);margin-bottom:16px;line-height:1.6}
.plan-price{font-family:Tajawal,Cairo,sans-serif;font-size:28px;font-weight:900;color:var(--text);margin-bottom:4px}
.plan-price span{font-size:13px;font-weight:600;color:var(--muted2)}
.plan-price-note{font-size:12px;color:var(--muted2);margin:-2px 0 10px;line-height:1.5}
.plan-save{font-size:11px;font-weight:700;color:var(--brand-logo-primary);background:color-mix(in srgb,var(--brand-logo-primary) 12%,transparent);
  border:1px solid color-mix(in srgb,var(--brand-logo-primary) 28%,transparent);border-radius:8px;padding:6px 10px;margin-bottom:12px;line-height:1.45}
.plan-badge--value{background:var(--brand-logo-primary)}
.pricing-vat-note{text-align:center;font-size:11px;color:var(--muted2);max-width:720px;margin:-24px auto 32px;padding:0 24px;line-height:1.65}
.plan-features{list-style:none;padding:0;margin:0 0 20px;flex:1}
.plan-features li{font-size:13px;color:var(--text2);padding:6px 0;padding-right:24px;position:relative;line-height:1.5}
.plan-features li::before{content:"✓";position:absolute;right:0;color:var(--accent);font-weight:800}
.plan-cta{width:100%;padding:12px 20px;border-radius:10px;font-family:Tajawal,sans-serif;font-size:14px;font-weight:700;cursor:pointer;border:none;transition:all .25s}
.plan-cta.primary{background:var(--accent);color:#fff}
.plan-cta.primary:hover{box-shadow:0 6px 20px rgba(16,185,129,.4)}
.plan-cta.secondary{background:transparent;color:var(--text2);border:2px solid var(--border2)}
.plan-cta.secondary:hover{border-color:var(--gold);color:var(--gold)}
.pricing-footer{text-align:center;padding:20px;color:var(--muted);font-size:12px;border-top:1px solid var(--border)}

#page-app{display:flex;height:100vh;height:100dvh;overflow:hidden}
@media(min-width:1200px){#page-app{--sidebar-w:272px}}
@media(min-width:1600px){#page-app{--sidebar-w:288px}}
.sidebar{width:var(--sidebar-w);background:var(--bg2);border-left:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;z-index:5}
.sidebar-hdr{padding:14px 13px 10px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:10px}
.sb-logo{width:42px;height:42px;border-radius:10px;flex-shrink:0;
  background:var(--brand-logo-svg) center/100% no-repeat,transparent;
  display:flex;align-items:center;justify-content:center;font-size:0;color:transparent;overflow:hidden;text-indent:-99px}
.sb-name{font-family:Tajawal,Cairo,sans-serif;font-size:var(--fs-sidebar-brand);font-weight:900;background:linear-gradient(90deg,#fff,var(--muted2));-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.sb-tagline{font-size:var(--fs-sidebar-tagline);color:var(--muted)}


/* Sidebar upgrade */
.sb-scroll{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;padding:8px 8px 14px;-webkit-overflow-scrolling:touch;scroll-padding-top:8px;scroll-padding-bottom:20px}
.sb-scroll::-webkit-scrollbar{width:4px}
.sb-scroll::-webkit-scrollbar-thumb{background:var(--border2);border-radius:2px}

/* بحث عام + جوال + جدول */
.global-search-dropdown{display:none;position:absolute;top:100%;right:0;margin-top:4px;min-width:260px;max-height:320px;overflow:auto;background:var(--bg2);border:1px solid var(--border);border-radius:10px;box-shadow:0 8px 24px rgba(0,0,0,.4);z-index:9998}
.global-search-dropdown.open{display:block}
.global-search-dropdown a{display:block;padding:10px 14px;font-size:12px;color:var(--text);border-bottom:1px solid var(--border);text-decoration:none;transition:background .15s}
.global-search-dropdown a:hover{background:var(--surface)}
.global-search-dropdown .search-section{font-size:10px;color:var(--muted);padding:6px 14px;font-weight:700}
.hamburger-btn{display:none}
@media(max-width:900px){.hamburger-btn{display:flex}.global-search-wrap{display:none}.icon-btn{width:44px;height:44px;min-width:44px;min-height:44px;font-size:14px}.nav-item{min-height:44px;padding:10px 12px;align-items:flex-start;padding-top:12px}.nav-item .nav-icon{margin-top:2px}.topbar{min-height:54px;height:auto;padding-top:6px;padding-bottom:6px}}
@media(max-width:900px){.topbar-steps{max-width:min(240px,42vw);gap:5px}}
@media(max-width:900px){.sidebar.mobile-open{display:flex!important;flex-direction:column;position:fixed;top:0;bottom:0;right:0;width:min(300px,calc(100vw - 36px));max-width:100%;max-height:100vh;max-height:100dvh;z-index:9999;box-shadow:-4px 0 24px rgba(0,0,0,.5)}.sidebar.mobile-open .sb-scroll{flex:1;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch}.sidebar.mobile-open~.main-area::before{content:"";position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:9998;cursor:pointer}.sidebar-close-mobile{display:none}}
.sidebar-close-mobile{display:none}
@media(max-width:900px){.sidebar-close-mobile{display:flex!important;align-items:center;justify-content:center;width:44px;height:44px;min-width:44px;min-height:44px;border-radius:8px;border:1px solid var(--border);background:var(--surface);color:var(--muted2);font-size:18px;cursor:pointer;flex-shrink:0}.sidebar-close-mobile:hover{background:var(--surface2);color:var(--text)}}
.global-loading-wrap{position:fixed;inset:0;background:rgba(0,0,0,.5);backdrop-filter:blur(6px);z-index:10000;display:none;align-items:center;justify-content:center;flex-direction:column;gap:var(--space-12)}
.global-loading-wrap.active{display:flex}
.global-loading-spinner{width:44px;height:44px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}
.global-loading-text{font-size:var(--fs-ui);color:var(--text2);font-weight:600}
@keyframes spin{to{transform:rotate(360deg)}}
.schedule-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;margin-bottom:12px;border-radius:12px;border:1px solid rgba(148,163,184,.14)}
.schedule-table-wrap table{min-width:600px;font-variant-numeric:tabular-nums}
.schedule-table-wrap table thead th{
  position:sticky;top:0;z-index:2;
  background:var(--bg3);
  background:linear-gradient(180deg,var(--bg3),color-mix(in srgb,var(--bg) 88%,var(--bg3)));
  box-shadow:0 2px 8px rgba(0,0,0,.2);
}
.schedule-table-wrap table tbody tr:hover td{background:rgba(16,185,129,.06)}
#subscription-expiry-banner.subscription-expiry-banner-inner{display:flex;align-items:center;justify-content:space-between;gap:12px}

/* ══ صفحة بيانات المدرسة — استغلال المساحة ══ */
#panel-schoolinfo .si-layout{display:grid;gap:20px;grid-template-columns:1fr;align-items:start}
@media(min-width:900px){#panel-schoolinfo .si-layout{grid-template-columns:1fr 1fr}}
@media(min-width:1200px){#panel-schoolinfo .si-layout{grid-template-columns:1fr 1fr 1fr}}
#panel-schoolinfo .si-col{display:flex;flex-direction:column;gap:16px;min-width:0}

/* ══ تحسينات الجوال والتابلت ══ */
@media(min-width:1100px){
  .topbar-steps{max-width:min(240px,22vw)}
}
@media(max-width:600px){
  #app-topbar > div:first-child{flex:1 1 auto!important;min-width:0!important}
  .topbar-right{flex-wrap:wrap;justify-content:flex-end;align-items:center;row-gap:6px;min-width:0}
  .topbar-steps{flex:1 1 auto;min-width:0;max-width:min(280px,58vw);justify-content:flex-end}
  .scroll-area{padding:16px}
  .land-nav{padding:13px 20px}
  .hero{padding:50px 20px 40px}
  .land-hero-logo{width:clamp(52px,14vw,68px);height:clamp(52px,14vw,68px)}
  .features{padding:24px 12px}
  .stat-pill{min-width:120px}
  .topbar{padding-left:12px;padding-right:12px}
  .nav-item{min-height:44px;padding-top:12px;padding-bottom:12px}
  .filter-btn{min-height:44px;padding:10px 14px}
  .icon-btn{min-width:44px;min-height:44px}
  .btn-sm{min-height:44px;padding:10px 14px}
}
@media(max-width:1200px){.features{grid-template-columns:repeat(3,minmax(0,1fr));max-width:920px}}
@media(max-width:780px){.features{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:520px){.features{grid-template-columns:1fr}}
@media(max-width:480px){
  .scroll-area{padding:12px}
  .land-nav{padding:13px 16px}
  .hero{padding:40px 16px 30px}
  .stat-pill{min-width:100px}
  .pricing-nav{padding:13px 16px}
  .pricing-plans{grid-template-columns:1fr;padding:0 16px}
  .task-check{width:24px;height:24px;font-size:12px}
  .btn-sm{min-height:44px;padding:10px 14px;font-size:max(13px,var(--fs-ui-sm))}
  .data-table th{font-size:max(11px,var(--fs-table-head))}
  .kpi-mini-lbl,.tt-lesson-teacher,.nav-hint{font-size:max(11px,var(--fs-nav-hint))}
  .topbar-sub{font-size:max(11px,var(--fs-topbar-sub))}
  .bar-label{width:100px;font-size:11px}
  .ov-welcome-card{flex-direction:column;text-align:center;padding:16px}
  .ov-welcome-card .btn{width:100%;justify-content:center;min-height:44px}
  .sidebar-close,.nav-item{min-height:44px}
  .task-check{min-width:44px;min-height:44px}
}
@media(max-width:900px){
  .topbar{padding-left:env(safe-area-inset-left,12px);padding-right:env(safe-area-inset-right,12px)}
  .sidebar.mobile-open{padding-right:env(safe-area-inset-right,0)}
}
@media(max-width:768px){
  .scroll-area{overflow-x:auto;-webkit-overflow-scrolling:touch}
  .data-table-wrap,.schedule-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
  #ov-teacher-dashboard .grid-3{grid-template-columns:1fr}
}

@media print{
  .data-table thead th,.schedule-table-wrap table thead th{position:static!important;box-shadow:none!important}
  .schedule-edit-cell-source,.schedule-edit-cell-target,.schedule-edit-cell-target-simple,.schedule-edit-cell-target-compound,.schedule-edit-cell-dim,.schedule-edit-cell-pending-choice{
    outline:none !important;
    box-shadow:none !important;
    animation:none !important;
    opacity:1 !important;
  }
  .schedule-edit-cell-source::before,.schedule-edit-cell-source::after,.schedule-edit-cell-target-simple::before,.schedule-edit-cell-target-simple::after,.schedule-edit-cell-target-compound::before,.schedule-edit-cell-target-compound::after,.schedule-edit-cell-dim::after{display:none !important}
  .schedule-edit-invalid-flash{animation:none !important}
  .schedule-edit-popover{display:none !important}
  .schedule-table-wrap{overflow:visible}
  .schedule-table-wrap table{min-width:auto;page-break-inside:avoid}
  .no-print,.topbar,.sidebar,.icon-btn,.btn,.hamburger-btn,#global-search,.topbar-steps{display:none!important}
  .main-area,.scroll-area{padding:0}
  @page{margin:12mm;size:A4}
}

/* روابط داخل منطقة التمرير — تركيز لوحة المفاتيح */
.scroll-area a:focus-visible{
  outline:2px solid color-mix(in srgb,var(--accent2) 70%,transparent);
  outline-offset:3px;
  border-radius:6px;
}

/* ═══ لوحة مالك المنصة (admin.html) + بوابة المالك (owner.html) ═══ */
/* التطبيق الرئيسي يستخدم body { overflow:hidden }؛ الصفحات المستقلة تحتاج تمرير للوثيقة */
html.admin-doc-scroll,
html:has(body.admin-page) {
  height: auto;
  min-height: 100vh;
  min-height: 100dvh;
  overflow-x: hidden;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}
body.admin-page {
  min-height: 100vh;
  min-height: 100dvh;
  height: auto;
  overflow-x: hidden;
  overflow-y: visible;
  background: var(--grad-admin-shell);
}
/* حقل التاريخ في RTL: يمنع اختلال عرض بعض المتصفحات */
body.admin-page input[type='date'] {
  direction: ltr;
  unicode-bidi: isolate;
  text-align: left;
  font-family: ui-sans-serif, system-ui, 'Segoe UI', sans-serif;
}
.admin-topbar {
  position: sticky;
  top: 0;
  z-index: 10;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 20px;
  margin: -8px -8px 20px;
  background: var(--grad-admin-topbar);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--border);
  border-radius: 0 0 16px 16px;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.22);
}
.admin-brand {
  display: flex;
  align-items: center;
  gap: 12px;
}
.admin-brand-mark {
  width: 42px;
  height: 42px;
  border-radius: 12px;
  background: var(--brand-logo-svg) center / 90% no-repeat, var(--grad-admin-brand);
  border: 1px solid rgba(148, 163, 184, 0.28);
  box-shadow: 0 4px 14px rgba(0, 0, 0, 0.2);
  flex-shrink: 0;
}
.admin-brand-title {
  font-size: 17px;
  font-weight: 800;
  color: var(--text);
  letter-spacing: -0.02em;
  line-height: 1.2;
}
.admin-brand-sub {
  font-size: 12px;
  color: var(--muted);
  margin-top: 2px;
  font-weight: 600;
}
.admin-wrap {
  max-width: 920px;
  margin: 0 auto;
  padding: 12px 18px 56px;
}
.admin-hero {
  margin-bottom: 28px;
  padding: 4px 2px 0;
}
.admin-hero h1 {
  font-size: 1.55rem;
  font-weight: 800;
  margin: 0 0 10px;
  color: var(--text);
  letter-spacing: -0.03em;
  text-shadow: 0 2px 28px rgba(6, 182, 212, 0.12);
}
.admin-hero p {
  font-size: 13.5px;
  color: var(--muted2);
  margin: 0;
  line-height: 1.75;
  max-width: 52em;
}
.admin-hero code {
  font-size: 12px;
  padding: 2px 6px;
  border-radius: 6px;
  background: rgba(6, 182, 212, 0.12);
  border: 1px solid rgba(148, 163, 184, 0.2);
}
.admin-card {
  background: var(--grad-admin-card);
  border: 1px solid var(--card-border);
  border-radius: 16px;
  padding: 20px 22px;
  margin-bottom: 18px;
  box-shadow: var(--card-shadow);
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}
.admin-card:hover {
  border-color: rgba(148, 163, 184, 0.32);
}
.admin-card h2 {
  font-size: 15px;
  margin: 0 0 14px;
  display: flex;
  align-items: center;
  gap: 10px;
  font-weight: 800;
  color: var(--text);
}
.admin-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 18px;
  padding: 16px 18px;
  background: var(--grad-admin-toolbar);
  border: 1px solid var(--border);
  border-radius: 16px;
  box-shadow: 0 4px 24px rgba(0, 0, 0, 0.18);
}
.admin-badge {
  font-size: 11px;
  padding: 6px 12px;
  border-radius: 999px;
  background: rgba(16, 185, 129, 0.14);
  color: #6ee7b7;
  border: 1px solid rgba(16, 185, 129, 0.35);
  font-weight: 700;
}
.admin-badge.warn {
  background: rgba(234, 179, 8, 0.12);
  color: #fde68a;
  border-color: rgba(234, 179, 8, 0.4);
}
.admin-badge.err {
  background: rgba(220, 38, 38, 0.12);
  color: #fecaca;
  border-color: rgba(248, 113, 113, 0.35);
}
.admin-table-wrap {
  overflow-x: auto;
  border: 1px solid var(--border);
  border-radius: 12px;
  background: rgba(15, 23, 42, 0.4);
}
table.admin-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
}
.admin-table th,
.admin-table td {
  padding: 12px 14px;
  text-align: right;
  border-bottom: 1px solid var(--border);
}
.admin-table th {
  background: rgba(23, 37, 84, 0.85);
  color: var(--muted2);
  font-weight: 800;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.admin-table tbody tr {
  transition: background 0.15s ease;
}
.admin-table tbody tr:hover {
  background: rgba(6, 182, 212, 0.06);
}
.admin-table tr:last-child td {
  border-bottom: none;
}
.admin-perms {
  list-style: none;
  padding: 0;
  margin: 0;
  font-size: 13px;
  color: var(--muted2);
  line-height: 1.85;
}
.admin-perms li {
  position: relative;
  padding-right: 22px;
}
.admin-perms li::before {
  content: "";
  position: absolute;
  right: 0;
  top: 0.55em;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--grad-cta);
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--accent) 20%, transparent);
}
.admin-perms code {
  font-size: 11.5px;
  padding: 1px 5px;
  border-radius: 5px;
  background: rgba(0, 0, 0, 0.25);
  border: 1px solid rgba(148, 163, 184, 0.2);
}
.admin-json {
  font-family: ui-monospace, "Cascadia Code", Consolas, monospace;
  font-size: 11.5px;
  line-height: 1.55;
  background: rgba(12, 25, 41, 0.85);
  padding: 16px;
  border-radius: 12px;
  overflow-x: auto;
  white-space: pre-wrap;
  word-break: break-word;
  border: 1px solid rgba(148, 163, 184, 0.18);
  color: #cbd5e1;
}
.admin-links {
  font-size: 13px;
  margin-top: 28px;
  padding-top: 20px;
  border-top: 1px solid var(--border);
  display: flex;
  flex-wrap: wrap;
  gap: 10px 18px;
  align-items: center;
}
.admin-links a {
  color: var(--accent2);
  font-weight: 600;
  text-decoration: none;
  padding: 8px 14px;
  border-radius: 10px;
  background: rgba(6, 182, 212, 0.08);
  border: 1px solid rgba(6, 182, 212, 0.22);
  transition: background 0.2s ease, transform 0.15s ease;
}
.admin-links a:hover {
  background: rgba(6, 182, 212, 0.16);
  transform: translateY(-1px);
}
.admin-login-actions .btn-primary {
  margin-top: 4px;
  min-height: 44px;
  font-weight: 800;
  border-radius: 12px;
  box-shadow: 0 4px 18px rgba(16, 185, 129, 0.28);
}
.admin-loading-dots {
  display: inline-flex;
  gap: 6px;
  align-items: center;
}
.admin-loading-dots span {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--accent2);
  animation: admin-dot 1.1s ease-in-out infinite;
}
.admin-loading-dots span:nth-child(2) { animation-delay: 0.15s; }
.admin-loading-dots span:nth-child(3) { animation-delay: 0.3s; }
@keyframes admin-dot {
  0%, 80%, 100% { opacity: 0.35; transform: scale(0.85); }
  40% { opacity: 1; transform: scale(1); }
}
@media (max-width: 520px) {
  .admin-topbar { margin: -8px -4px 16px; padding: 12px 14px; }
  .admin-wrap { padding: 8px 12px 40px; }
  .admin-toolbar { flex-direction: column; align-items: stretch; }
}

/* تحسين تركيز حقول النماذج (جدوليست + لوحة المالك) */
.f-input:focus-visible {
  box-shadow: 0 0 0 3px rgba(16, 185, 129, 0.22);
}
