/* ================================================================
   نظام مراقبة الامتحانات - كلية التكنولوجيا
   ملف الأنماط (CSS)
   ================================================================ */

@import url('https://fonts.googleapis.com/css2?family=Cairo:wght@400;500;600;700&display=swap');

/* ── المتغيرات العامة ── */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

:root {
  --pr:   #3C3489;
  --pr2:  #534AB7;
  --prl:  #EEEDFE;
  --bg:   #F5F4FC;
  --sf:   #fff;
  --bd:   #DDD9F5;
  --tx:   #1a1825;
  --tx2:  #5e5a7a;
  --tx3:  #9994b8;
  --gn:   #0F6E56;
  --gnb:  #E1F5EE;
  --bl:   #0C447C;
  --blb:  #E6F1FB;
  --am:   #633806;
  --amb:  #FAEEDA;
  --rd:   #A32D2D;
  --rdb:  #FCEBEB;
}

/* ── الجسم الرئيسي ── */
body {
  font-family: 'Cairo', sans-serif;
  background: var(--bg);
  color: var(--tx);
  min-height: 100vh;
}

/* ── الترويسة ── */
.hdr {
  background: var(--pr);
  color: #fff;
  padding: .8rem 1.4rem;
  display: flex;
  align-items: center;
  gap: 12px;
}


.hdr h1 { font-size: 16px; font-weight: 700; }
.hdr p  { font-size: 10px; opacity: .8; margin-top: 1px; }

/* ── الحاوية الرئيسية ── */
.wrap {
  max-width: 1000px;
  margin: 0 auto;
  padding: 1rem;
}

/* ── التبويبات ── */
.tabs {
  display: flex;
  background: var(--sf);
  border-radius: 10px;
  border: 1px solid var(--bd);
  overflow: hidden;
  margin-bottom: 1rem;
  box-shadow: 0 1px 4px rgba(0,0,0,.05);
}

.tab {
  flex: 1;
  padding: 9px 3px;
  font-size: 10.5px;
  font-family: 'Cairo', sans-serif;
  font-weight: 600;
  cursor: pointer;
  border: none;
  background: none;
  color: var(--tx2);
  border-bottom: 3px solid transparent;
  transition: all .2s;
  text-align: center;
}

.tab:hover { background: var(--bg); }
.tab.active {
  color: var(--pr2);
  border-bottom-color: var(--pr2);
  background: var(--prl);
}

/* ── الأقسام ── */
.sec { display: none; }
.sec.active { display: block; }

/* ── البطاقات ── */
.card {
  background: var(--sf);
  border: 1px solid var(--bd);
  border-radius: 10px;
  padding: .85rem 1rem;
  margin-bottom: 8px;
  box-shadow: 0 1px 3px rgba(0,0,0,.04);
}

.ct {
  font-size: 12.5px;
  font-weight: 700;
  color: var(--tx);
  margin-bottom: 9px;
  padding-bottom: 7px;
  border-bottom: 1px solid var(--bd);
}

/* ── الصفوف والحقول ── */
.row {
  display: flex;
  gap: 7px;
  align-items: flex-end;
  flex-wrap: wrap;
}

.f {
  display: flex;
  flex-direction: column;
  gap: 3px;
  flex: 1;
  min-width: 100px;
}

.f label {
  font-size: 11px;
  font-weight: 600;
  color: var(--tx2);
}

/* ── عناصر الإدخال ── */
input, select {
  font-family: 'Cairo', sans-serif;
  font-size: 12px;
  width: 100%;
  padding: 7px 8px;
  border: 1px solid var(--bd);
  border-radius: 6px;
  color: var(--tx);
  background: var(--bg);
  outline: none;
  transition: border .2s;
}

input:focus, select:focus {
  border-color: var(--pr2);
  background: #fff;
}


/* إصلاح عرض حقل القسم في إضافة أستاذ: منع قص الاسم الطويل */
.prof-dept-field{
  flex: 1.15 1 320px;
  min-width: 300px;
  max-width: 460px;
}
.prof-dept-picker{
  display:flex;
  gap:6px;
  align-items:center;
  width:100%;
}
.prof-dept-picker select{
  flex:1 1 auto;
  min-width:0;
  direction:rtl;
  text-align:right;
  text-overflow:ellipsis;
}
.prof-dept-add{
  flex:0 0 34px;
  width:34px;
  padding:7px 0!important;
  text-align:center;
}
@media (max-width: 720px){
  .prof-dept-field{
    flex-basis:100%;
    min-width:100%;
    max-width:none;
  }
}

/* ── الأزرار ── */
.btn {
  padding: 7px 12px;
  font-size: 11px;
  font-family: 'Cairo', sans-serif;
  font-weight: 700;
  cursor: pointer;
  border-radius: 6px;
  transition: all .18s;
  white-space: nowrap;
}

.bpr { background: var(--pr2); color: #fff; border: none; }
.bpr:hover { background: var(--pr); }

.bgr { background: #1D9E75; color: #fff; border: none; }
.bgr:hover { background: var(--gn); }

.bol { background: var(--sf); border: 1px solid var(--bd); color: var(--tx); }
.bol:hover { border-color: var(--pr2); color: var(--pr2); }

.bam { background: var(--amb); border: 1px solid #EF9F27; color: var(--am); }
.bam:hover { background: #f5d9a0; }


/* ── اختيار مستويات الأستاذ: مساحة أعلى وبنية أوضح ── */
.prof-levels-field {
  flex: 0 1 430px;
  min-width: 330px;
  max-width: 460px;
}

.prof-levels-title {
  font-size: 11.5px !important;
  font-weight: 800 !important;
  color: var(--tx2) !important;
}

.prof-levels-help {
  font-size: 10px;
  font-weight: 600;
  color: var(--tx3);
  line-height: 1.35;
  margin-bottom: 5px;
}

.prof-levels-box {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 7px !important;
  padding: 9px !important;
  min-height: 190px !important;
  max-height: 290px;
  overflow-y: auto;
  align-content: start;
  background: linear-gradient(180deg, #FAFAFF 0%, var(--bg) 100%) !important;
  border: 1px solid var(--bd) !important;
  border-radius: 9px !important;
}

.edit-prof-levels-box {
  min-height: 170px !important;
  max-height: 260px;
}

.prof-level-choice {
  min-height: 38px;
  display: flex !important;
  align-items: center !important;
  gap: 7px !important;
  cursor: pointer;
  padding: 7px 9px;
  border: 1px solid #E1DFF2;
  border-radius: 8px;
  background: #fff;
  font-size: 11px !important;
  font-weight: 700;
  color: var(--tx2);
  line-height: 1.35;
  transition: border-color .15s, background .15s, transform .15s;
}

.prof-level-choice:hover {
  background: var(--prl);
  border-color: var(--pr2);
}

.prof-level-choice input {
  width: 15px !important;
  height: 15px !important;
  flex: 0 0 auto;
}

.prof-level-all-choice {
  grid-column: 1 / -1;
  min-height: 40px;
  background: var(--prl);
  color: var(--pr);
  border-color: #C9C4F4;
}

@media (max-width: 680px) {
  .prof-levels-field {
    min-width: 100%;
    max-width: none;
  }
  .prof-levels-box {
    grid-template-columns: 1fr;
    min-height: 220px !important;
  }
}


/* ── اختيار مواد مسؤول المادة: مساحة أعلى وبنية أوضح ── */
.prof-resp-subjects-field {
  flex: 1 1 520px;
  min-width: 420px;
  max-width: 620px;
}

.prof-resp-subjects-title {
  font-size: 11.5px !important;
  font-weight: 800 !important;
  color: var(--tx2) !important;
}

.prof-resp-subjects-title span {
  font-size: 9.7px;
  font-weight: 700;
  color: var(--tx3);
}

.prof-resp-subjects-help {
  font-size: 10px;
  font-weight: 600;
  color: var(--tx3);
  line-height: 1.35;
  margin-bottom: 5px;
}

.prof-resp-subjects-box {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 7px !important;
  padding: 9px !important;
  min-height: 150px !important;
  max-height: 260px;
  overflow-y: auto;
  align-content: start;
  background: linear-gradient(180deg, #FBFFFD 0%, var(--gnb) 100%) !important;
  border: 1px solid #BDE7D8 !important;
  border-radius: 9px !important;
}

.edit-prof-subjects-field {
  min-width: 100%;
  max-width: none;
}

.edit-prof-subjects-box {
  min-height: 140px !important;
  max-height: 240px;
}

.prof-resp-subject-choice {
  min-height: 38px;
  display: flex !important;
  align-items: center !important;
  gap: 7px !important;
  cursor: pointer;
  padding: 7px 9px;
  border: 1px solid #CFEBDD;
  border-radius: 8px;
  background: #fff;
  font-size: 11px !important;
  font-weight: 700;
  color: var(--tx2);
  line-height: 1.35;
  transition: border-color .15s, background .15s, transform .15s;
}

.prof-resp-subject-choice:hover {
  background: #F3FCF8;
  border-color: var(--gn);
}

.prof-resp-subject-choice input {
  width: 15px !important;
  height: 15px !important;
  flex: 0 0 auto;
}

.prof-resp-subject-choice span {
  overflow-wrap: anywhere;
}

.prof-resp-subjects-empty {
  grid-column: 1 / -1;
  min-height: 38px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--tx3);
  font-size: 11px;
  font-weight: 700;
}

@media (max-width: 680px) {
  .prof-resp-subjects-field {
    min-width: 100%;
    max-width: none;
  }
  .prof-resp-subjects-box {
    grid-template-columns: 1fr;
    min-height: 190px !important;
  }
}


.bdl {
  background: none;
  border: 1px solid #F7C1C1;
  color: var(--rd);
  font-size: 10px;
  font-family: 'Cairo', sans-serif;
  font-weight: 600;
  padding: 3px 8px;
  border-radius: 5px;
  cursor: pointer;
}
.bdl:hover { background: var(--rdb); }

/* ── الشارات ── */
.badge {
  font-size: 10px;
  padding: 2px 7px;
  border-radius: 20px;
  font-weight: 700;
}

.bh  { background: var(--blb); color: var(--bl); }
.ba  { background: var(--gnb); color: var(--gn); }
.bo  { background: var(--amb); color: var(--am); }

/* ── صفوف القوائم ── */
.lrow {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 7px 0;
  border-bottom: 1px solid var(--bd);
}
.lrow:last-child { border-bottom: none; }

/* ── الصورة الرمزية ── */
.av {
  width: 30px;
  height: 30px;
  border-radius: 50%;
  background: var(--prl);
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 12px;
  color: var(--pr2);
  flex-shrink: 0;
}

/* ── إحصائيات ── */
.stats {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(110px, 1fr));
  gap: 6px;
  margin-bottom: .9rem;
}

.stat {
  background: var(--sf);
  border: 1px solid var(--bd);
  border-radius: 8px;
  padding: 9px;
  text-align: center;
}

.stat-v { font-size: 19px; font-weight: 700; color: var(--pr2); }
.stat-l { font-size: 10px; color: var(--tx2); margin-top: 1px; font-weight: 600; }

/* ── الجداول ── */
.tbl-w { overflow-x: auto; }

table.tbl {
  width: 100%;
  border-collapse: collapse;
  font-size: 11px;
  min-width: 500px;
}

.tbl th {
  background: transparent;
  color: #111;
  padding: 7px 9px;
  text-align: right;
  font-weight: 900;
  font-size: 10.5px;
  border: 1px solid #999;
}

.tbl td {
  padding: 6px 9px;
  border-bottom: 1px solid var(--bd);
  vertical-align: middle;
}

.tbl tr:last-child td { border-bottom: none; }
.tbl tr:hover td { background: var(--prl); }
.tbl tr.wr td { background: var(--amb); }

/* ── الشريحة ── */
.chip {
  display: inline-block;
  background: var(--prl);
  color: var(--pr);
  border-radius: 4px;
  padding: 1px 5px;
  font-size: 10px;
  margin: 1px;
  font-weight: 600;
}

/* ── تنبيه وملاحظة ── */
.warn {
  background: var(--amb);
  border: 1px solid #EF9F27;
  border-radius: 8px;
  padding: 8px 11px;
  font-size: 11.5px;
  color: var(--am);
  margin-bottom: 8px;
  display: none;
}

.note {
  background: var(--prl);
  border-radius: 6px;
  padding: 6px 10px;
  font-size: 11px;
  color: var(--pr);
  margin-bottom: 9px;
  font-weight: 500;
}

/* ── شبكة ثنائية ── */
.og {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 7px;
  margin-bottom: 9px;
}

/* ── مربع معلومات ── */
.info-box {
  background: var(--gnb);
  border: 1px solid #5DCAA5;
  border-radius: 7px;
  padding: 9px 13px;
  margin-bottom: 10px;
}

.ib-title { font-size: 12.5px; font-weight: 700; color: var(--gn); margin-bottom: 5px; }
.ib-row   { display: flex; justify-content: space-between; font-size: 11.5px; color: var(--tx2); margin-top: 3px; }
.ib-val   { font-weight: 700; color: var(--tx); }

/* ── التاغ ── */
.tag {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  background: var(--bg);
  border: 1px solid var(--bd);
  border-radius: 20px;
  padding: 2px 8px;
  font-size: 11px;
  margin: 2px;
}

.tag button {
  background: none;
  border: none;
  cursor: pointer;
  color: var(--rd);
  font-size: 12px;
  padding: 0;
  line-height: 1;
}

/* ── شريط التقدم ── */
.prog-bar {
  height: 5px;
  background: var(--bg);
  border-radius: 3px;
  overflow: hidden;
  margin-top: 3px;
  border: 1px solid var(--bd);
}

.prog-fill {
  height: 100%;
  border-radius: 3px;
  transition: width .4s;
}

/* ── استجابة الشاشات الصغيرة ── */
@media (max-width: 600px) {
  .og   { grid-template-columns: 1fr; }
  .tabs { flex-wrap: wrap; }
}


/* Backup center */
.backup-hero{display:flex;align-items:center;justify-content:space-between;gap:12px;background:linear-gradient(135deg,#0F6E56,#1D9E75);color:#fff;border-radius:16px;padding:18px 20px;margin-bottom:14px;box-shadow:0 8px 22px rgba(15,110,86,.18)}
.backup-title{font-size:18px;font-weight:900;margin-bottom:5px}
.backup-sub{font-size:12px;opacity:.88;line-height:1.7}
.backup-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.backup-card{background:#fff;border:1px solid var(--bd);border-radius:14px;padding:14px;box-shadow:0 4px 16px rgba(0,0,0,.04)}
.backup-sensitive{border-color:#F0C86A;background:linear-gradient(180deg,#fffaf0,#fff)}
.backup-card-title{font-size:14px;font-weight:900;color:#0F6E56;margin-bottom:8px;border-bottom:1px solid #e6efe9;padding-bottom:7px}
.backup-p{font-size:12px;color:var(--tx2);line-height:1.8;margin:0 0 10px 0}
.backup-actions{display:flex;gap:7px;flex-wrap:wrap;align-items:center}
.backup-file-btn{position:relative;overflow:hidden;display:inline-flex;align-items:center}
.backup-file-btn input{position:absolute;inset:0;opacity:0;cursor:pointer}
.backup-status{font-size:12px;line-height:2;color:var(--tx2)}
.backup-status b{color:#0F6E56}
.backup-list{margin-top:10px;max-height:240px;overflow:auto;border-radius:10px}
.backup-row{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:8px 10px;border:1px solid #e3e7ea;border-radius:9px;margin-bottom:6px;background:#fafafa;font-size:11px}
.backup-row strong{color:#1a1825}
.backup-row span{color:var(--tx3)}
@media(max-width:800px){.backup-grid{grid-template-columns:1fr}.backup-hero{flex-direction:column;align-items:flex-start}}

/* SQLite persistent storage dashboard */
.sqlite-card{border-color:#cde7dc;background:linear-gradient(180deg,#f7fffb,#fff)}
.sqlite-status{font-size:12px;color:#243b53;line-height:1.7}
.sqlite-topline{display:flex;justify-content:space-between;align-items:center;padding:8px 10px;border:1px solid #d9efe5;border-radius:10px;background:#f5fffa;margin-bottom:8px}
.sqlite-topline b{color:#0f6e56;font-size:13px}.sqlite-topline span{font-weight:800;color:#0c447c}
.sqlite-meta{font-size:11.5px;background:#f8fafc;border:1px solid #e5edf5;border-radius:9px;padding:8px;margin-bottom:8px;color:#475569}
.sqlite-bars{display:flex;flex-direction:column;gap:6px}
.sqlite-bar-row{position:relative;overflow:hidden;border:1px solid #e2e8f0;border-radius:8px;background:#fff;display:grid;grid-template-columns:1fr 48px;gap:6px;align-items:center;padding:6px 9px;font-size:11.5px;font-weight:700}
.sqlite-bar-row i{position:absolute;right:0;top:0;bottom:0;background:rgba(15,110,86,.14);z-index:0;border-radius:8px}
.sqlite-bar-row span,.sqlite-bar-row b{position:relative;z-index:1}.sqlite-bar-row b{text-align:left;color:#0c447c}
.sqlite-error{border:1px solid #fecaca;background:#fff1f2;color:#991b1b;border-radius:10px;padding:10px;font-weight:800}
#sqliteMiniStatus small{font-weight:600;color:#64748b}

/* SQLite simplified storage tab */
.backup-grid-single{display:block;max-width:980px;margin:0 auto}
.sqlite-only-card{width:100%;box-sizing:border-box}
.sqlite-simple-actions{margin-top:14px;display:flex;gap:10px;flex-wrap:wrap;justify-content:center}
.sqlite-simple-actions .btn{min-width:130px;justify-content:center}

/* SQLite comparison panel */
.sqlite-compare-block{margin-top:12px;border:1px solid #dbeafe;background:#f8fbff;border-radius:12px;padding:10px}
.sqlite-compare-head{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:8px;color:#123d69;font-size:12.5px}
.sqlite-compare-refresh{font-size:10.5px!important;padding:5px 10px!important;min-width:auto!important}
.sqlite-compare-box{font-size:11.5px;line-height:1.7;color:#243b53}
.sqlite-sync-ok{border:1px solid #bbf7d0;background:#f0fdf4;color:#166534;border-radius:10px;padding:9px;font-weight:800}
.sqlite-sync-warn{border:1px solid #fed7aa;background:#fff7ed;color:#9a3412;border-radius:10px;padding:9px;font-weight:800}
.sqlite-sync-error{border:1px solid #fecaca;background:#fff1f2;color:#991b1b;border-radius:10px;padding:9px;font-weight:800}
.sqlite-compare-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:8px}
.sqlite-compare-mini{background:#fff;border:1px solid #e2e8f0;border-radius:10px;padding:8px}
.sqlite-compare-mini h4{margin:0 0 6px;font-size:12px;color:#0f172a}
.sqlite-compare-mini div{display:flex;justify-content:space-between;border-top:1px dashed #e2e8f0;padding:3px 0}
.sqlite-compare-mini div:first-of-type{border-top:0}
.sqlite-compare-mini b{color:#0c447c}
.sqlite-compare-note{margin-top:7px;color:#64748b;font-size:11px;font-weight:600}
@media(max-width:780px){.sqlite-compare-grid{grid-template-columns:1fr}.sqlite-compare-head{align-items:flex-start;flex-direction:column}}


.sqlite-sync-choice{margin-top:10px;padding:9px;border:1px solid #c7d2fe;background:#eef2ff;border-radius:10px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.sqlite-sync-choice .btn{font-size:11px!important;padding:6px 12px!important;min-width:auto!important}
.sqlite-sync-choice .btn[disabled]{opacity:.45;cursor:not-allowed;filter:grayscale(1)}
.sqlite-sync-choice small{display:block;width:100%;color:#475569;font-size:10.5px;font-weight:700;line-height:1.6}

/* ===== نافذة تقرير السلامة الجديدة ===== */
.audit-modal-overlay{position:fixed;inset:0;z-index:99980;background:rgba(15,23,42,.58);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:18px;direction:rtl;font-family:Cairo,Arial,sans-serif}
.audit-modal{width:min(1180px,96vw);max-height:92vh;background:#F8FAFC;border:1px solid rgba(148,163,184,.45);border-radius:22px;box-shadow:0 24px 70px rgba(15,23,42,.35);overflow:hidden;color:#0F172A;display:flex;flex-direction:column}
.audit-modal *{box-sizing:border-box}
.audit-modal-head{background:linear-gradient(180deg,#fff,#F8FAFC);padding:20px 24px 14px;border-bottom:1px solid #E2E8F0;display:grid;grid-template-columns:auto 1fr auto;gap:14px;align-items:center}
.audit-modal-title{text-align:center}.audit-modal-title h2{margin:0;font-size:25px;font-weight:900;color:#111827}.audit-modal-title p{margin:5px 0 0;color:#64748B;font-size:13px;font-weight:700}.audit-x{border:none;background:#fff;color:#334155;width:38px;height:38px;border-radius:12px;font-size:21px;cursor:pointer;box-shadow:0 1px 4px rgba(15,23,42,.12)}
.audit-modal-body{padding:18px;overflow:auto}.audit-status-banner{display:grid;grid-template-columns:86px 1fr;gap:16px;align-items:center;border:1px solid #BBF7D0;background:linear-gradient(90deg,#F0FDF4,#fff);border-radius:18px;padding:18px 22px;margin-bottom:16px}.audit-status-banner.danger{border-color:#FECACA;background:linear-gradient(90deg,#FEF2F2,#fff)}.audit-status-banner.warn{border-color:#FED7AA;background:linear-gradient(90deg,#FFFBEB,#fff)}
.audit-status-icon{width:72px;height:72px;border-radius:26px;display:flex;align-items:center;justify-content:center;font-size:34px;font-weight:900;background:#DCFCE7;color:#15803D}.audit-status-banner.danger .audit-status-icon{background:#FEE2E2;color:#B91C1C}.audit-status-banner.warn .audit-status-icon{background:#FEF3C7;color:#B45309}.audit-status-text h3{margin:0;font-size:24px;font-weight:900}.audit-status-text p{margin:6px 0 0;color:#475569;font-size:14px;font-weight:700;line-height:1.7}
.audit-metric-grid{display:grid;grid-template-columns:repeat(5,minmax(130px,1fr));gap:12px;margin-bottom:16px}.audit-metric{background:#fff;border:1px solid #E2E8F0;border-radius:16px;padding:14px 15px;min-height:98px;display:grid;grid-template-columns:1fr 46px;align-items:center;box-shadow:0 1px 5px rgba(15,23,42,.04)}.audit-metric span{display:block;color:#64748B;font-size:13px;font-weight:800}.audit-metric b{display:block;margin-top:6px;font-size:30px;line-height:1;font-weight:900}.audit-metric i{font-style:normal;width:46px;height:46px;border-radius:15px;display:flex;align-items:center;justify-content:center;font-size:23px;background:#EFF6FF;color:#1D4ED8}.audit-metric.err b{color:#B91C1C}.audit-metric.warn b{color:#B45309}.audit-metric.ok b{color:#15803D}.audit-metric.rooms b{color:#6D28D9}
.audit-layout{display:grid;grid-template-columns:1fr 295px;gap:14px}.audit-main,.audit-side-card{background:#fff;border:1px solid #E2E8F0;border-radius:18px;box-shadow:0 1px 5px rgba(15,23,42,.04);overflow:hidden}.audit-tabs{display:flex;gap:2px;border-bottom:1px solid #E2E8F0;background:#F8FAFC}.audit-tab{flex:1;padding:14px 10px;background:transparent;border:none;color:#475569;font-size:13px;font-weight:900;cursor:pointer;border-bottom:3px solid transparent}.audit-tab.active{color:#1D4ED8;background:#fff;border-bottom-color:#2563EB}.audit-pane{display:none;padding:14px}.audit-pane.active{display:block}.audit-finding{display:grid;grid-template-columns:92px 1fr 54px;gap:12px;align-items:center;border:1px solid #E5E7EB;border-radius:15px;padding:13px;margin-bottom:10px;background:#fff}.audit-chip{border-radius:999px;padding:7px 10px;font-size:12px;font-weight:900;text-align:center}.audit-chip.error{background:#FEE2E2;color:#B91C1C}.audit-chip.warning{background:#FEF3C7;color:#B45309}.audit-chip.info{background:#DBEAFE;color:#1D4ED8}.audit-chip.good{background:#DCFCE7;color:#15803D}.audit-finding h4{margin:0;font-size:15px;font-weight:900;color:#111827}.audit-finding p{margin:4px 0 0;color:#64748B;font-size:12.5px;font-weight:700;line-height:1.6}.audit-finding-icon{width:48px;height:48px;border-radius:16px;display:flex;align-items:center;justify-content:center;background:#F1F5F9;font-size:23px}.audit-empty{padding:28px;border:1px dashed #86EFAC;background:#F0FDF4;color:#166534;border-radius:16px;text-align:center;font-weight:900}.audit-side-card{padding:16px}.audit-side-card h3{margin:0 0 12px;font-size:17px;font-weight:900;color:#111827}.audit-action{width:100%;height:46px;border:1px solid #CBD5E1;border-radius:13px;background:#fff;color:#0F172A;font-family:Cairo,Arial,sans-serif;font-size:14px;font-weight:900;cursor:pointer;margin-bottom:10px}.audit-action.primary{background:#EFF6FF;border-color:#BFDBFE;color:#1D4ED8}.audit-action:hover{filter:brightness(.98)}.audit-info-box{border:1px dashed #CBD5E1;border-radius:16px;padding:13px;margin-top:12px;background:#F8FAFC}.audit-info-row{display:grid;grid-template-columns:38px 1fr;gap:10px;align-items:center;padding:8px 0}.audit-info-row+ .audit-info-row{border-top:1px solid #E2E8F0}.audit-info-row i{font-style:normal;font-size:25px}.audit-info-row span{display:block;color:#64748B;font-size:12px;font-weight:800}.audit-info-row b{display:block;color:#1D4ED8;font-size:15px;font-weight:900;margin-top:2px}.audit-mini-bars{padding:4px 0}.audit-mini-bars .audit-bar-row{grid-template-columns:90px 40px 1fr}.audit-reco{background:#F8FAFC;border:1px solid #E2E8F0;border-radius:15px;padding:12px;margin-bottom:10px;font-weight:800;line-height:1.7;color:#334155}
@media(max-width:900px){.audit-metric-grid{grid-template-columns:repeat(2,1fr)}.audit-layout{grid-template-columns:1fr}.audit-modal-head{grid-template-columns:auto 1fr}.audit-modal-title{text-align:right}.audit-status-banner{grid-template-columns:1fr}.audit-finding{grid-template-columns:1fr}.audit-finding-icon{display:none}}

/* واجهة تقرير السلامة الرسمية: هادئة وموجهة لملف PDF غير مضغوط */
.audit-modal-head.official{background:#fff;border-bottom:2px solid #0C447C}
.audit-official-modal{width:min(1220px,97vw);background:#F6F8FB}
.official-body{padding:16px 18px 18px}
.official-status{margin-bottom:12px;border-radius:14px;padding:14px 18px}
.audit-formal-summary{display:grid;grid-template-columns:repeat(6,1fr);gap:9px;margin:0 0 13px}
.audit-formal-summary div{background:#fff;border:1px solid #D8E2F0;border-radius:12px;padding:10px 12px;min-height:70px;box-shadow:0 1px 4px rgba(15,23,42,.04)}
.audit-formal-summary span{display:block;color:#64748B;font-size:12px;font-weight:800;margin-bottom:5px}
.audit-formal-summary b{display:block;color:#0C447C;font-size:18px;font-weight:900;line-height:1.2}
.audit-formal-summary b.err{color:#C73535}.audit-formal-summary b.warn{color:#C27803}
.official-layout{grid-template-columns:1fr 265px}.official-main{border-radius:14px}.official-side{border-radius:14px}
.audit-grid-inside{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px}.audit-grid-inside>div{border:1px solid #E2E8F0;border-radius:12px;padding:12px;background:#FAFCFF}.audit-grid-inside h3{margin:0 0 8px;color:#0C447C;font-size:15px;font-weight:900}
.audit-ui-table{width:100%;border-collapse:collapse;table-layout:fixed;font-size:13px;background:#fff}.audit-ui-table th{background:#0C447C;color:#fff;border:1px solid #1B5B96;padding:9px;font-weight:900}.audit-ui-table td{border:1px solid #D4DCE8;padding:9px;vertical-align:top;line-height:1.55;color:#263247;word-break:break-word}.audit-ui-table th:first-child,.audit-ui-table td:first-child{width:92px;text-align:center}.audit-ui-table th:nth-child(2),.audit-ui-table td:nth-child(2){width:260px}.audit-ui-table td span{display:inline-block;border-radius:999px;padding:4px 9px;background:#0F6E56;color:#fff;font-weight:900;font-size:12px}.audit-ui-table tr.err td span{background:#C73535}.audit-ui-table tr.warn td span{background:#C27803}.audit-ui-table td b{display:block;font-weight:900;color:#111827}.audit-ui-table td em{display:block;font-style:normal;color:#64748B;font-size:12px;margin-top:3px}.audit-more-note{margin-top:8px;color:#64748B;font-size:12px;font-weight:800}.audit-empty.compact{padding:18px}.official-side h3{color:#0C447C}.official-side .audit-action.primary{background:#0C447C;border-color:#0C447C;color:#fff}
@media(max-width:980px){.audit-formal-summary{grid-template-columns:repeat(2,1fr)}.audit-grid-inside{grid-template-columns:1fr}.official-layout{grid-template-columns:1fr}}

/* Top storage usage indicator */
.top-storage-meter{width:310px;max-width:100%;border:1px solid rgba(255,255,255,.28);background:rgba(255,255,255,.12);border-radius:9px;padding:5px 7px;color:#fff;font-size:9.5px;line-height:1.35;box-shadow:inset 0 1px 0 rgba(255,255,255,.12)}
.top-storage-row{display:flex;align-items:center;justify-content:space-between;gap:6px;white-space:nowrap}.top-storage-row b{font-weight:900;color:#fff}.top-storage-track{height:5px;border-radius:999px;background:rgba(255,255,255,.22);overflow:hidden;margin:4px 0}.top-storage-track i{display:block;height:100%;border-radius:999px;background:#7EE0B7}.top-storage-track i.warn{background:#F8C35D}.top-storage-track i.danger{background:#FF8A8A}.top-storage-foot{font-size:8.5px;color:rgba(255,255,255,.72);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.top-storage-foot.browser-quota{color:rgba(255,255,255,.58);font-size:8px}
@media(max-width:900px){.top-storage-meter{width:230px}.top-storage-row{flex-direction:column;align-items:flex-start;gap:1px}.top-storage-foot{white-space:normal}}


/* V 3.0 — نافذة تبديل الحصص */
/* V 3.0 fixes 03: واجهة اختيار عملية وكبيرة لتبديل الحصص */
.swap-modal-backdrop{position:fixed;inset:0;background:rgba(13,18,35,.55);z-index:9999;display:none;align-items:center;justify-content:center;padding:10px;backdrop-filter:blur(4px)}
.swap-modal{width:min(1280px,98vw);height:min(92vh,900px);background:var(--card);border:1px solid var(--bd);border-radius:22px;box-shadow:0 28px 84px rgba(31,27,82,.36);direction:rtl;display:flex;flex-direction:column;overflow:hidden}
.swap-head{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:16px 22px;border-bottom:1px solid var(--bd);background:linear-gradient(135deg,var(--prb),#fff);flex:0 0 auto}
.swap-head b{display:block;font-size:21px;color:var(--pr);margin-bottom:4px}.swap-head span{display:block;font-size:13.5px;color:var(--tx2);font-weight:700}
.swap-head button{border:none;background:#fff;color:var(--rd);font-weight:900;font-size:28px;border-radius:14px;width:48px;height:48px;cursor:pointer;box-shadow:0 2px 10px rgba(0,0,0,.12)}
.swap-body{display:grid;grid-template-columns:1fr 1fr;gap:18px;padding:18px 22px 12px;min-height:0;overflow:hidden;flex:1 1 auto}
.swap-pane{background:#f8f8fd;border:1px solid var(--bd);border-radius:18px;padding:14px;min-height:0;display:flex;flex-direction:column;overflow:hidden}
.swap-pane-top{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}.swap-pane-top label{font-weight:900;color:var(--tx);font-size:16px}
.swap-pane select{width:100%;min-height:56px;padding:0 18px;border:2px solid #d9d5ef;border-radius:16px;background:#fff;font-family:Cairo,sans-serif;font-size:16px;font-weight:800;color:var(--tx);margin-bottom:14px;flex:0 0 auto;box-shadow:0 2px 10px rgba(31,27,82,.05)}
.swap-pane select:focus{outline:none;border-color:var(--pr2);box-shadow:0 0 0 4px rgba(60,52,137,.10)}
.swap-count{font-size:13px;color:var(--pr);font-weight:900;background:var(--prb);border:1px solid #d8d4ff;border-radius:999px;display:inline-block;padding:6px 14px;white-space:nowrap}
.swap-list{display:flex;flex-direction:column;gap:12px;overflow:auto;padding-inline-end:6px;min-height:0;flex:1 1 auto}
.swap-item{display:grid!important;grid-template-columns:90px minmax(0,1fr) auto;align-items:center;gap:12px;background:#fff;border:2px solid var(--bd);border-radius:18px;padding:15px 16px!important;cursor:pointer;color:var(--tx);transition:.15s;min-width:0;box-shadow:0 2px 8px rgba(31,27,82,.06)}
.swap-item:hover{border-color:var(--pr2);box-shadow:0 5px 18px rgba(60,52,137,.14);transform:translateY(-1px)}
.swap-item input{position:absolute;opacity:0;pointer-events:none}.swap-pick-mark{display:flex;align-items:center;justify-content:center;min-height:38px;border-radius:999px;background:#f0eff8;color:var(--pr);font-weight:900;font-size:13px;border:1px solid #d8d4ff;white-space:nowrap}.swap-item:has(input:checked){border-color:var(--pr2);background:#fbfaff;box-shadow:0 6px 22px rgba(60,52,137,.18)}.swap-item:has(input:checked) .swap-pick-mark{background:var(--pr2);border-color:var(--pr2);color:#fff}.swap-item:has(input:checked) .swap-pick-mark::before{content:'✓ ';font-weight:900}
.swap-card{min-width:0;display:block}.swap-line{display:flex;align-items:center;gap:10px;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.swap-main{font-size:15px;font-weight:900;color:var(--tx)}.swap-main b{font-weight:900}.swap-main small{font-size:13px;font-weight:900;color:var(--tx2);background:#f0eff8;border-radius:999px;padding:4px 10px;white-space:nowrap}.swap-sub{font-size:13.5px;color:var(--tx2);margin-top:7px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:700}
.swap-item em{font-style:normal;font-size:11.5px;color:#8A5A00;background:#FFF3CD;border:1px solid #F2C670;border-radius:999px;padding:4px 9px;white-space:nowrap}.swap-empty{text-align:center;color:var(--tx3);font-size:14px;font-weight:800;padding:70px 8px}
.swap-preview{margin:0 22px 10px;padding:10px 16px;background:#fff;border:1px dashed var(--bd);border-radius:15px;font-size:13px;color:var(--tx);line-height:1.7;min-height:44px;max-height:82px;overflow:auto;flex:0 0 auto}.swap-ok{margin-top:5px;color:var(--gn);font-weight:900}.swap-bad{margin-top:5px;color:var(--rd);font-weight:900}.swap-warn{margin-top:5px;color:var(--am);font-weight:900}
.swap-actions{display:flex;align-items:center;justify-content:center;gap:12px;padding:12px 22px 16px;flex-wrap:wrap;flex:0 0 auto;border-top:1px solid #eceaf7;background:linear-gradient(180deg,#fff,#fbfbff)}.swap-actions .btn{min-width:136px;min-height:44px;justify-content:center;font-size:14px;font-weight:900}.swap-actions button:disabled{opacity:.45;cursor:not-allowed;pointer-events:none}
@media(max-width:900px){.swap-modal{width:98vw;height:95vh}.swap-body{grid-template-columns:1fr;overflow:auto}.swap-list{min-height:280px}.swap-item{grid-template-columns:82px minmax(0,1fr)}.swap-line{white-space:normal}.swap-sub{white-space:normal}.swap-item em{grid-column:2}.swap-actions .btn{min-width:120px}}

/* V 3.0 fixes 04: إعادة بناء نافذة تبديل الحصص كجدول إداري واضح */
.swap-modal-backdrop{padding:16px!important;align-items:center!important;justify-content:center!important;overflow:hidden!important}
.swap-modal.swap-modal-table{width:min(1180px,96vw)!important;height:min(88vh,820px)!important;border-radius:18px!important;background:#fff!important;display:flex!important;flex-direction:column!important;overflow:hidden!important;box-shadow:0 22px 70px rgba(20,18,50,.32)!important}
.swap-modal-table .swap-head{padding:14px 20px!important;background:#fff!important;border-bottom:1px solid #e6e3f4!important}
.swap-modal-table .swap-head b{font-size:21px!important;color:#2f286e!important}.swap-modal-table .swap-head span{font-size:13px!important;color:#666!important;font-weight:700!important}
.swap-modal-table .swap-head button{width:44px!important;height:44px!important;border-radius:12px!important;background:#fff!important;border:1px solid #eee!important;color:#a42f35!important;font-size:28px!important;line-height:1!important}
.swap-controls{display:grid;grid-template-columns:1fr 1fr;gap:14px;padding:14px 20px;background:#faf9ff;border-bottom:1px solid #e6e3f4;flex:0 0 auto}
.swap-control-row{display:grid;grid-template-columns:110px minmax(0,1fr) 130px;align-items:center;gap:10px;background:#fff;border:1px solid #e4e0f2;border-radius:14px;padding:10px}
.swap-control-row label{font-weight:900;color:#2d294a;font-size:15px;white-space:nowrap}
.swap-control-row select{width:100%;height:46px;border:1px solid #d8d3ed;border-radius:10px;background:#fff;font-family:Cairo,sans-serif;font-size:15px;font-weight:800;color:#24213c;padding:0 10px;outline:none;min-width:0}
.swap-control-row select:focus{border-color:#3C3489;box-shadow:0 0 0 3px rgba(60,52,137,.10)}
.swap-control-row .swap-count{justify-self:end;text-align:center;font-size:12.5px;font-weight:900;color:#3C3489;background:#f0effb;border:1px solid #d8d4ff;border-radius:999px;padding:7px 10px;white-space:nowrap}
.swap-table-wrap{flex:1 1 auto;min-height:0;margin:14px 20px 8px;border:1px solid #ddd8ef;border-radius:14px;overflow:auto;background:#fff}
.swap-compare-table{width:100%;border-collapse:separate;border-spacing:0;table-layout:fixed;direction:rtl;font-size:13.5px;color:#24213c}
.swap-compare-table th{position:sticky;top:0;z-index:2;background:#f0eff8;color:#2f286e;font-weight:900;border-bottom:1px solid #d8d3eb;padding:10px 8px;text-align:center}
.swap-compare-table th:nth-child(2),.swap-compare-table th:nth-child(4){text-align:right}
.swap-check-col{width:92px!important}.swap-compare-table td{border-bottom:1px solid #eeeaf7;padding:9px 8px;vertical-align:middle;background:#fff}.swap-compare-table tr:nth-child(even) td{background:#fcfbff}.swap-compare-table tr:hover td{background:#f8f6ff}
.swap-pick-cell{text-align:center;width:92px}.swap-session-cell{text-align:right;min-width:0}.swap-blank{color:#aaa;text-align:center!important;background:#fafafa!important}
.swap-check-label{display:inline-flex;align-items:center;justify-content:center;min-width:76px;height:38px;border-radius:999px;border:1px solid #d7d1ed;background:#fff;color:#3C3489;font-weight:900;cursor:pointer;user-select:none;transition:.12s}
.swap-check-label:hover{border-color:#3C3489;box-shadow:0 2px 10px rgba(60,52,137,.12)}
.swap-check-label input{position:absolute;opacity:0;pointer-events:none}.swap-check-label span{display:inline-block}.swap-check-label:has(input:checked){background:#3C3489;border-color:#3C3489;color:#fff}.swap-check-label:has(input:checked) span::before{content:'✓ ';font-weight:900}
.swap-session-title{min-width:0}.swap-session-main{display:flex;align-items:center;gap:8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:900;color:#222}.swap-session-main b{font-weight:900}.swap-session-main span{display:inline-flex;align-items:center;justify-content:center;background:#f2f1f8;border-radius:999px;padding:3px 9px;font-size:12.5px;font-weight:900;color:#504d69;white-space:nowrap}.swap-session-sub{margin-top:5px;color:#666;font-size:12.8px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.swap-level-warn{margin-inline-start:8px;color:#8A5A00;background:#FFF3CD;border:1px solid #F2C670;border-radius:999px;padding:2px 7px;font-size:11px;white-space:nowrap}
.swap-modal-table .swap-empty{text-align:center;color:#777;font-size:14px;font-weight:800;padding:40px 10px!important}.swap-modal-table .swap-preview{margin:0 20px 8px!important;min-height:38px!important;max-height:76px!important;padding:9px 13px!important;border-radius:12px!important;background:#fff!important;border:1px dashed #d8d3eb!important;font-size:13px!important;line-height:1.55!important;overflow:auto!important;flex:0 0 auto!important;color:#333!important}.swap-modal-table .swap-actions{display:flex!important;align-items:center!important;justify-content:center!important;gap:10px!important;padding:10px 20px 14px!important;border-top:1px solid #e6e3f4!important;background:#faf9ff!important;flex:0 0 auto!important}.swap-modal-table .swap-actions .btn{min-width:122px!important;min-height:40px!important;border-radius:10px!important;font-size:13.5px!important;font-weight:900!important;justify-content:center!important}.swap-modal-table .swap-ok{color:#16834f!important;font-weight:900}.swap-modal-table .swap-bad{color:#ba2633!important;font-weight:900}.swap-modal-table .swap-warn{color:#956100!important;font-weight:900}
@media(max-width:900px){.swap-modal.swap-modal-table{width:98vw!important;height:94vh!important}.swap-controls{grid-template-columns:1fr;padding:10px}.swap-control-row{grid-template-columns:1fr;gap:7px}.swap-control-row .swap-count{justify-self:start}.swap-table-wrap{margin:10px}.swap-compare-table{min-width:850px}.swap-modal-table .swap-preview{margin:0 10px 8px!important}.swap-modal-table .swap-actions{padding:9px 10px!important}.swap-modal-table .swap-actions .btn{min-width:104px!important}}

/* V 3.0 fixes 05: تكبير مساحة عرض الحصص في نافذة تبديل الحصص */
.swap-modal.swap-modal-table{height:min(95vh,900px)!important;width:min(1220px,97vw)!important}
.swap-modal-table .swap-head{padding:10px 18px!important}
.swap-controls{padding:10px 18px!important;gap:10px!important}
.swap-control-row{padding:8px!important}
.swap-control-row select{height:42px!important}
.swap-table-wrap{margin:10px 18px 6px!important;flex:1 1 auto!important;min-height:520px!important}
.swap-modal-table .swap-preview{margin:0 18px 6px!important;min-height:34px!important;max-height:54px!important;padding:7px 12px!important}
.swap-modal-table .swap-actions{padding:8px 18px 10px!important}
.swap-modal-table .swap-actions .btn{min-height:38px!important}
@media(max-height:760px){.swap-table-wrap{min-height:430px!important}.swap-modal.swap-modal-table{height:96vh!important}.swap-modal-table .swap-head span{display:none!important}}
@media(max-width:900px){.swap-table-wrap{min-height:520px!important;margin:8px!important}.swap-modal.swap-modal-table{height:96vh!important}}

/* V 3.0 fixes 07: make swap modal practical at normal 100% browser zoom */
.swap-modal-backdrop{padding:6px!important;overflow:hidden!important}
.swap-modal.swap-modal-table{
  width:min(1240px,98vw)!important;
  height:96vh!important;
  max-height:96vh!important;
  border-radius:14px!important;
}
.swap-modal-table .swap-head{
  padding:7px 14px!important;
  min-height:0!important;
}
.swap-modal-table .swap-head b{font-size:18px!important;line-height:1.25!important}
.swap-modal-table .swap-head span{font-size:11.5px!important;line-height:1.35!important}
.swap-modal-table .swap-head button{width:36px!important;height:36px!important;border-radius:10px!important;font-size:24px!important}
.swap-controls{
  padding:7px 14px!important;
  gap:8px!important;
}
.swap-control-row{
  grid-template-columns:90px minmax(0,1fr) 108px!important;
  gap:7px!important;
  padding:6px 8px!important;
  border-radius:11px!important;
}
.swap-control-row label{font-size:13px!important}
.swap-control-row select{
  height:36px!important;
  font-size:13px!important;
  border-radius:8px!important;
  padding:0 8px!important;
}
.swap-control-row .swap-count{
  font-size:11.5px!important;
  padding:5px 8px!important;
}
.swap-table-wrap{
  margin:7px 14px 5px!important;
  flex:1 1 auto!important;
  min-height:0!important;
  height:auto!important;
  border-radius:10px!important;
}
.swap-compare-table{font-size:12.2px!important;line-height:1.35!important}
.swap-compare-table th{padding:6px 6px!important;font-size:12.5px!important}
.swap-check-col{width:74px!important}
.swap-compare-table td{padding:5px 6px!important}
.swap-check-label{
  min-width:58px!important;
  padding:5px 7px!important;
  border-radius:9px!important;
  font-size:11.8px!important;
}
.swap-session-main{gap:5px!important;flex-wrap:wrap!important}
.swap-session-main b{font-size:12.6px!important}
.swap-session-main span{
  font-size:11.5px!important;
  padding:3px 6px!important;
  border-radius:8px!important;
}
.swap-session-sub{font-size:11.8px!important;line-height:1.35!important;margin-top:2px!important}
.swap-level-warn{font-size:10.8px!important;padding:2px 5px!important;margin-inline-start:4px!important}
.swap-modal-table .swap-preview{
  margin:0 14px 5px!important;
  min-height:28px!important;
  max-height:48px!important;
  padding:6px 10px!important;
  font-size:12px!important;
  line-height:1.35!important;
  border-radius:10px!important;
}
.swap-modal-table .swap-actions{
  padding:7px 14px 8px!important;
  gap:8px!important;
}
.swap-modal-table .swap-actions .btn{
  min-width:108px!important;
  min-height:34px!important;
  border-radius:9px!important;
  font-size:12.5px!important;
  padding:6px 10px!important;
}
@media(max-height:760px){
  .swap-modal.swap-modal-table{height:97vh!important;max-height:97vh!important}
  .swap-modal-table .swap-head span{display:none!important}
  .swap-controls{padding:5px 10px!important}
  .swap-table-wrap{margin:5px 10px 4px!important}
  .swap-modal-table .swap-preview{max-height:38px!important;min-height:24px!important;margin:0 10px 4px!important}
  .swap-modal-table .swap-actions{padding:5px 10px 6px!important}
}

/* V 3.0 fixes 08: تكبير مساحة معاينة التبديل في نافذة تبديل الحصص */
.swap-modal-table .swap-preview{
  min-height:86px!important;
  max-height:150px!important;
  flex:0 0 96px!important;
  margin:0 14px 7px!important;
  padding:9px 12px!important;
  line-height:1.5!important;
}
@media(max-height:760px){
  .swap-modal-table .swap-preview{
    min-height:68px!important;
    max-height:110px!important;
    flex-basis:78px!important;
  }
}
@media(max-height:620px){
  .swap-modal-table .swap-preview{
    min-height:54px!important;
    max-height:86px!important;
    flex-basis:64px!important;
  }
}

/* V 3.0 fixes 09: زيادة واضحة لارتفاع صندوق معاينة التبديل فقط */
.swap-modal-table .swap-preview{
  min-height:128px!important;
  max-height:220px!important;
  flex:0 0 138px!important;
  margin:0 14px 8px!important;
  padding:12px 14px!important;
  font-size:12.8px!important;
  line-height:1.6!important;
}
@media(max-height:760px){
  .swap-modal-table .swap-preview{
    min-height:96px!important;
    max-height:160px!important;
    flex-basis:108px!important;
  }
}
@media(max-height:620px){
  .swap-modal-table .swap-preview{
    min-height:74px!important;
    max-height:120px!important;
    flex-basis:84px!important;
  }
}

/* Students tab */
.students-stats{display:flex;gap:8px;flex-wrap:wrap;margin:6px 0 10px 0}
.mini-stat{background:#F5F4FC;border:1px solid #DDD9F5;border-radius:8px;padding:8px 12px;min-width:120px;text-align:center}
.mini-stat b{display:block;font-size:18px;color:#3C3489;line-height:1.1}
.mini-stat span{font-size:11px;color:var(--tx2);font-weight:700}


/* مسؤولو المدرجات */
.amphi-resp-card{border:1px solid #DDD9F5;background:#FBFAFF}
.amphi-status-box{border:1px dashed #C9C2EE;border-radius:8px;padding:8px 10px;background:#fff;color:#3C3489;font-size:12px;line-height:1.8}
.amphi-modal{position:fixed;inset:0;background:rgba(15,23,42,.55);z-index:99998;display:flex;align-items:center;justify-content:center;padding:18px;direction:rtl}
.amphi-dialog{width:min(1100px,96vw);max-height:92vh;overflow:auto;background:#fff;border-radius:14px;box-shadow:0 18px 60px rgba(0,0,0,.35);border:1px solid #D8DDEE}
.amphi-head{position:sticky;top:0;background:#3C3489;color:#fff;padding:12px 16px;display:flex;justify-content:space-between;align-items:center;z-index:1}
.amphi-head b{font-size:15px}.amphi-head button{background:transparent;border:none;color:#fff;font-size:26px;cursor:pointer;line-height:1}
.amphi-modal-body{padding:14px}.amphi-explain{background:#F8FBFF;border:1px solid #C9D8EB;border-radius:9px;padding:10px 12px;font-size:12px;color:#334155;line-height:1.8;margin-bottom:10px}
.amphi-summary{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin:10px 0}.amphi-summary div{background:#FBFAFF;border:1px solid #DDD9F5;border-radius:10px;padding:9px;text-align:center}.amphi-summary span{display:block;color:#64748B;font-size:10.5px;font-weight:800}.amphi-summary b{display:block;color:#3C3489;font-size:16px;margin-top:3px}
.amphi-actions{display:flex;gap:6px;flex-wrap:wrap;margin:10px 0 12px}.amphi-table{width:100%;border-collapse:collapse;font-size:11px}.amphi-table th{background:#3C3489;color:#fff;border:1px solid #4F46A5;padding:7px}.amphi-table td{border:1px solid #D8DDEE;padding:6px;vertical-align:top}.amphi-table tr:nth-child(even){background:#FAFAFF}
@media(max-width:780px){.amphi-summary{grid-template-columns:1fr 1fr}.amphi-dialog{width:98vw}.amphi-table{font-size:10px}}

.sqlite-diff-details{background:#fff7ed;border:1px solid #fdba74;border-radius:10px;padding:10px 12px;margin:8px 0;color:#7c2d12}
.sqlite-diff-details div{display:flex;gap:6px;flex-wrap:wrap;margin-top:7px}
.sqlite-diff-details span{background:#ffedd5;border:1px solid #fed7aa;border-radius:999px;padding:3px 9px;font-size:.86rem;font-weight:700}

/* V 3.0.3 — بطاقات تدقيق احترافية داخل تقرير السلامة */
.audit-professional-inline{margin:0 0 13px}
.audit-pro-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:9px;margin:0 0 12px}
.audit-pro-card{background:#fff;border:1px solid #D8E2F0;border-radius:12px;padding:10px 12px;min-height:72px;text-align:center;box-shadow:0 1px 4px rgba(15,23,42,.04)}
.audit-pro-card span{display:block;color:#64748B;font-size:12px;font-weight:900;margin-bottom:5px}
.audit-pro-card b{display:block;color:#0C447C;font-size:17px;font-weight:900;line-height:1.25}
.audit-pro-card.ok{background:#F6FEFA;border-color:#9BD9C5}.audit-pro-card.ok b{color:#0F6E56}
.audit-pro-card.warn{background:#FFF9E8;border-color:#F0D199}.audit-pro-card.warn b{color:#925B00}
.audit-pro-card.err{background:#FFF7F7;border-color:#F0B6B6}.audit-pro-card.err b{color:#B42318}
@media(max-width:980px){.audit-pro-grid{grid-template-columns:repeat(2,1fr)}}

/* V 3.0.8 — تحسين واجهة تقرير السلامة وعدالة الأساتذة */
.audit-scroll-table{max-height:430px;overflow:auto;border:1px solid #E2E8F0;border-radius:14px;background:#fff}
.audit-scroll-table .audit-ui-table{margin:0}
.audit-scroll-table .audit-ui-table thead th{position:sticky;top:0;z-index:2}
.audit-prof-table{max-height:520px}
.audit-fair-chart{max-height:390px;overflow:auto;padding:4px 2px 4px 4px}
.audit-fair-row{display:grid;grid-template-columns:minmax(135px,1fr) 38px 2fr;align-items:center;gap:8px;margin:7px 0;font-size:12px;font-weight:900;color:#334155}
.audit-fair-row span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:#111827}
.audit-fair-row b{text-align:center;color:#0C447C}
.audit-fair-row>div{height:12px;background:#EEF2F7;border-radius:999px;overflow:hidden;border:1px solid #E2E8F0}
.audit-fair-row i{display:block;height:100%;border-radius:999px;background:#0F6E56}
.audit-fair-row.warn i{background:#C27803}
.audit-fair-row.ok i{background:#0F6E56}
.audit-ui-table td em{display:block;font-style:normal;color:#64748B;font-size:12px;margin-top:4px;line-height:1.4}
.audit-tabs{overflow-x:auto;white-space:nowrap}
.audit-tab{min-width:105px}

/* V 3.1 — Safety audit dashboard redesign */
.v31-audit-modal{width:min(1360px,98vw)}
.v31-tabs{flex-wrap:wrap;align-items:stretch}.v31-tabs .audit-tab{flex:1 1 125px;min-width:115px;padding:12px 8px}
.audit-pro-grid.v31-grid{grid-template-columns:repeat(6,1fr)}
.audit-pro-card em{display:block;margin-top:5px;color:#64748B;font-size:11px;font-style:normal;font-weight:800;line-height:1.45}
.audit-exact-table th:first-child,.audit-exact-table td:first-child{width:55%;text-align:right}.audit-exact-table th:nth-child(2),.audit-exact-table td:nth-child(2){width:45%;font-family:ui-monospace,Menlo,Consolas,monospace;direction:ltr;text-align:left;font-weight:900}
.audit-formula-box{margin:12px 0;padding:12px 14px;border:1px solid #BFDBFE;background:#EFF6FF;color:#1E3A8A;border-radius:14px;font-weight:900;line-height:1.8}
.audit-wide-table{min-width:1100px}.audit-wide-table th,.audit-wide-table td{font-size:12.5px}.audit-wide-table th:first-child,.audit-wide-table td:first-child{width:70px}.audit-wide-table th:nth-child(2),.audit-wide-table td:nth-child(2){width:220px}
.v31-chart{max-height:520px;overflow:auto;padding-left:4px}.v31-chart .audit-fair-row span{max-width:210px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
@media(max-width:1180px){.audit-pro-grid.v31-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:760px){.audit-pro-grid.v31-grid{grid-template-columns:repeat(1,1fr)}.v31-tabs .audit-tab{flex-basis:45%}}

/* V 3.1.1 — توسيع واجهة تقرير السلامة وتقليل الضغط البصري */
.v31-audit-modal{width:98.8vw;max-height:96vh;border-radius:18px}
.v31-audit-modal .audit-modal-head{padding:14px 22px 10px;min-height:74px}
.v31-audit-modal .audit-modal-title h2{font-size:26px;line-height:1.25}
.v31-audit-modal .audit-modal-title p{font-size:13px;margin-top:3px}
.v31-audit-modal .official-body{padding:12px 16px 16px;overflow:auto;max-height:calc(96vh - 74px)}
.v31-audit-modal .official-status{display:grid;grid-template-columns:58px 1fr;margin-bottom:10px;padding:10px 14px;border-radius:14px}
.v31-audit-modal .audit-status-icon{width:50px;height:50px;border-radius:16px;font-size:24px}
.v31-audit-modal .audit-status-text h3{font-size:20px}
.v31-audit-modal .audit-status-text p{font-size:12.5px;line-height:1.55;margin-top:3px}
.v31-audit-modal .audit-formal-summary{grid-template-columns:repeat(6,minmax(110px,1fr));gap:8px;margin-bottom:10px}
.v31-audit-modal .audit-formal-summary div{min-height:58px;padding:8px 10px}
.v31-audit-modal .audit-formal-summary b{font-size:17px}
.v31-audit-modal .audit-professional-inline{margin-bottom:10px}
.v31-audit-modal .audit-pro-grid.v31-grid{grid-template-columns:repeat(6,minmax(145px,1fr));gap:8px}
.v31-audit-modal .audit-pro-card{padding:8px;min-height:78px}
.v31-audit-modal .audit-pro-card b{font-size:16px}.v31-audit-modal .audit-pro-card span{font-size:11px}.v31-audit-modal .audit-pro-card em{font-size:10.5px;line-height:1.35}
.audit-top-actions{display:grid;grid-template-columns:auto auto auto minmax(240px,1fr);gap:8px;align-items:center;background:#fff;border:1px solid #D8E2F0;border-radius:14px;padding:8px;margin:0 0 10px;box-shadow:0 1px 4px rgba(15,23,42,.04)}
.audit-top-actions .audit-action{width:auto;min-width:150px;height:40px;margin:0;padding:0 16px;border-radius:11px}
.audit-top-index{justify-self:end;display:flex;align-items:center;gap:10px;border:1px dashed #CBD5E1;background:#F8FAFC;border-radius:12px;padding:7px 12px;white-space:nowrap}
.audit-top-index span{font-size:12px;color:#64748B;font-weight:900}.audit-top-index b{font-size:15px;color:#1D4ED8;font-weight:900}.audit-top-index em{font-style:normal;font-size:11px;color:#64748B;font-weight:800}
.official-layout.v311-layout{display:block;grid-template-columns:none}.official-layout.v311-layout .official-main{width:100%;border-radius:14px;overflow:visible}.official-layout.v311-layout .official-side{display:none!important}
.v31-audit-modal .v31-tabs{display:flex;flex-wrap:nowrap;overflow-x:auto;gap:6px;padding:8px;background:#F8FAFC;border-bottom:1px solid #E2E8F0;scrollbar-width:thin}
.v31-audit-modal .v31-tabs .audit-tab{flex:0 0 auto;min-width:145px;padding:10px 12px;border:1px solid transparent;border-radius:10px 10px 0 0;font-size:12.5px}
.v31-audit-modal .v31-tabs .audit-tab.active{border-color:#BFDBFE;border-bottom-color:#2563EB;background:#fff}
.v31-audit-modal .audit-pane{padding:16px 18px 20px;min-height:420px}.v31-audit-modal .audit-pane>h3{font-size:20px;margin:0 0 12px;color:#0C447C}
.v31-audit-modal .audit-grid-inside{grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}.v31-audit-modal .audit-grid-inside>div{padding:14px;border-radius:14px}
.v31-audit-modal .audit-scroll-table{overflow:auto;max-height:none}.v31-audit-modal .audit-prof-table{max-height:70vh}.v31-audit-modal .audit-ui-table{font-size:13.5px;table-layout:auto}.v31-audit-modal .audit-ui-table th{padding:10px 9px;white-space:nowrap}.v31-audit-modal .audit-ui-table td{padding:10px 9px;line-height:1.6}.v31-audit-modal .audit-wide-table{min-width:1180px}.v31-audit-modal .audit-exact-table{min-width:760px}
.v31-audit-modal .v31-chart{max-height:none;overflow:visible;padding-left:0}.v31-audit-modal .audit-fair-row{grid-template-columns:minmax(210px,320px) 54px 1fr;gap:12px;padding:10px 12px}.v31-audit-modal .v31-chart .audit-fair-row span{max-width:320px}.v31-audit-modal .audit-fair-row>div{height:14px}
.v31-audit-modal .audit-formula-box{font-size:13px;line-height:1.65;margin:12px 0}
@media(max-width:1050px){.v31-audit-modal .audit-pro-grid.v31-grid{grid-template-columns:repeat(3,1fr)}.v31-audit-modal .audit-grid-inside{grid-template-columns:1fr}.audit-top-actions{grid-template-columns:1fr 1fr 1fr}.audit-top-index{grid-column:1/-1;justify-self:stretch;justify-content:center}}
@media(max-width:760px){.v31-audit-modal{width:99vw;max-height:98vh;border-radius:12px}.audit-top-actions{grid-template-columns:1fr}.audit-top-actions .audit-action{width:100%}.v31-audit-modal .audit-pro-grid.v31-grid{grid-template-columns:1fr}.v31-audit-modal .audit-formal-summary{grid-template-columns:repeat(2,1fr)}.v31-audit-modal .v31-tabs .audit-tab{min-width:130px}.v31-audit-modal .audit-pane{padding:12px}}

/* V 3.1.3 — توسيع واجهة إدارة مسؤولي القاعات والمدرجات */
.amphi-modal{padding:10px!important;align-items:center!important;justify-content:center!important}
.amphi-dialog{width:98.5vw!important;max-width:1500px!important;max-height:96vh!important;border-radius:18px!important;overflow:hidden!important;display:flex;flex-direction:column}
.amphi-head{flex:0 0 auto;padding:12px 18px!important;min-height:54px!important}
.amphi-head b{font-size:18px!important;font-weight:900!important}
.amphi-head button{width:38px;height:38px;border-radius:12px;background:rgba(255,255,255,.12)!important}
.amphi-modal-body{padding:12px 16px 16px!important;overflow:auto!important;max-height:calc(96vh - 54px);background:#fff}
.amphi-actions-top{position:sticky;top:0;z-index:8;background:rgba(255,255,255,.96);backdrop-filter:blur(6px);border:1px solid #E2E8F0;border-radius:14px;padding:10px;margin:0 0 10px!important;box-shadow:0 8px 22px rgba(15,23,42,.08);justify-content:center}
.amphi-actions-top .btn{min-width:148px;padding:10px 14px;font-weight:900;border-radius:10px}
.amphi-explain-details{border:1px solid #C9D8EB;border-radius:12px;background:#F8FBFF;margin:0 0 10px;overflow:hidden}
.amphi-explain-details summary{cursor:pointer;padding:9px 13px;font-weight:900;color:#164B78;list-style:none}
.amphi-explain-details summary::-webkit-details-marker{display:none}
.amphi-explain-details summary:before{content:'▸';display:inline-block;margin-left:7px;transition:.15s transform}
.amphi-explain-details[open] summary:before{transform:rotate(-90deg)}
.amphi-explain-details .amphi-explain{border:none;border-top:1px solid #D8E6F4;border-radius:0;margin:0;background:#fff;padding:10px 13px;font-size:12.5px;line-height:1.9}
.amphi-section-title{font-weight:950;color:#3C3489;margin:12px 2px 8px;font-size:16px;display:flex;align-items:center;gap:8px}
.amphi-section-title:before{content:'';width:6px;height:22px;border-radius:999px;background:#3C3489;display:inline-block}
.amphi-warn-title{color:#A32D2D}.amphi-warn-title:before{background:#A32D2D}
.amphi-summary,.amphi-plan-summary,.amphi-status-summary{display:grid!important;grid-template-columns:repeat(auto-fit,minmax(180px,1fr))!important;gap:10px!important;margin:10px 0!important}
.amphi-summary div{min-height:62px;padding:10px 12px!important;border-radius:13px!important;display:flex;flex-direction:column;align-items:center;justify-content:center}
.amphi-summary span{font-size:11.5px!important;line-height:1.45}.amphi-summary b{font-size:18px!important;line-height:1.25}
.amphi-table-wrap{width:100%;overflow:auto;border:1px solid #D8DDEE;border-radius:14px;background:#fff;max-height:52vh}
.amphi-table{min-width:1050px;font-size:12.5px!important;margin:0!important;border-collapse:separate!important;border-spacing:0!important}
.amphi-table th{position:sticky;top:0;z-index:3;padding:9px 8px!important;white-space:nowrap;background:#3C3489!important;color:#fff!important}
.amphi-table td{padding:8px 8px!important;line-height:1.55;font-size:12.5px!important}
.amphi-main-table th:nth-child(1),.amphi-main-table td:nth-child(1){width:54px;text-align:center}
.amphi-main-table th:nth-child(2),.amphi-main-table td:nth-child(2){width:120px;text-align:center}
.amphi-main-table th:nth-child(3),.amphi-main-table td:nth-child(3){width:90px;text-align:center}
.amphi-main-table th:nth-child(4),.amphi-main-table td:nth-child(4){width:170px}
.amphi-main-table th:nth-child(5),.amphi-main-table td:nth-child(5){width:190px}
.amphi-main-table th:nth-child(6),.amphi-main-table td:nth-child(6){width:170px}
.amphi-main-table th:nth-child(7),.amphi-main-table td:nth-child(7){width:220px}
.amphi-main-table th:nth-child(8),.amphi-main-table td:nth-child(8){width:110px;text-align:center}
@media(max-width:900px){.amphi-dialog{width:99vw!important}.amphi-modal{padding:4px!important}.amphi-modal-body{padding:9px!important}.amphi-actions-top{position:relative;top:auto}.amphi-actions-top .btn{flex:1 1 170px}.amphi-summary,.amphi-plan-summary,.amphi-status-summary{grid-template-columns:repeat(2,minmax(0,1fr))!important}.amphi-table{min-width:950px}}
@media(max-height:680px){.amphi-table-wrap{max-height:42vh}.amphi-summary div{min-height:54px}.amphi-actions-top{padding:7px}.amphi-actions-top .btn{padding:8px 10px}}

/* Genetic distribution tab */
.genetic-card{border:1px solid #d8d4f0;background:#fff}
.genetic-check{display:flex;align-items:center;gap:6px;padding:7px 10px;border:1px solid #DDD9F5;border-radius:7px;background:#fff;font-size:11px;font-weight:800;color:#3C3489;cursor:pointer;min-height:34px}
.genetic-check input{accent-color:#3C3489;width:14px;height:14px}
.genetic-result{margin-top:10px;border:1px dashed #DDD9F5;border-radius:8px;padding:10px;background:#FAFAFF}
.genetic-result-title{font-weight:900;color:#3C3489;margin-bottom:8px;font-size:13px}
.genetic-kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:8px;margin:8px 0}
.genetic-kpis>div{border:1px solid #DDD9F5;border-radius:8px;padding:8px 10px;background:#fff;display:flex;justify-content:space-between;gap:8px;align-items:center;font-size:11px}
.genetic-kpis span{color:#5e5a7a;font-weight:700}
.genetic-kpis b{font-size:13px;color:#1a1825}

.sqlite-primary-note{margin-top:10px;padding:12px 14px;border:1px solid #A7F3D0;background:#ECFDF5;color:#065F46;border-radius:12px;font-weight:800;font-size:12px;line-height:1.8}

/* v3.5.15 — توسيع نافذة إدارة مسؤولي القاعات والمدرجات عند تكبير المتصفح 100% */
.amphi-modal{padding:8px!important;align-items:center!important;justify-content:center!important}
.amphi-dialog{width:calc(100vw - 16px)!important;max-width:1680px!important;max-height:96vh!important}
.amphi-modal-body{padding:14px 18px 18px!important;max-height:calc(96vh - 58px)!important}
.amphi-actions-top{display:grid!important;grid-template-columns:repeat(auto-fit,minmax(175px,1fr))!important;gap:8px!important;align-items:stretch!important;justify-content:stretch!important}
.amphi-actions-top .btn{width:100%!important;min-width:0!important;white-space:normal!important;line-height:1.35!important;padding:10px 12px!important}
.amphi-status-summary{grid-template-columns:repeat(4,minmax(150px,1fr))!important}
.amphi-plan-summary{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))!important}
.amphi-table-wrap{max-height:50vh!important}
@media(max-width:1200px){.amphi-status-summary{grid-template-columns:repeat(2,minmax(0,1fr))!important}.amphi-actions-top{grid-template-columns:repeat(auto-fit,minmax(155px,1fr))!important}.amphi-modal-body{padding:10px!important}}

/* v3.5.16 - زر حذف كاش التطبيق */
.cache-clear-btn{
  border-color:#0f766e!important;
  color:#0f766e!important;
  background:#ecfdf5!important;
}
.cache-clear-btn:hover{background:#d1fae5!important}

/* Smart distribution tab */
.smart-choice-card{border:1px solid var(--bd);background:linear-gradient(180deg,#fff,#F8FAFC)}
.smart-choice-grid{display:grid;grid-template-columns:repeat(2,minmax(220px,1fr));gap:10px;margin-top:8px}
.smart-choice{font-family:Cairo,sans-serif;border:1.5px solid var(--bd);background:#fff;border-radius:10px;padding:12px 14px;text-align:right;cursor:pointer;color:var(--tx);box-shadow:0 2px 8px rgba(46,35,105,.06);transition:.15s ease}
.smart-choice:hover{transform:translateY(-1px);border-color:#8B7AE6}
.smart-choice.active{border-color:#3C3489;box-shadow:0 0 0 3px rgba(60,52,137,.12);background:#F4F2FF}
.smart-choice b{display:block;font-size:13px;margin-bottom:4px;color:#1F1B4D}
.smart-choice span{display:block;font-size:11px;color:var(--tx2);line-height:1.7}
.smart-panel{margin-top:10px}
@media(max-width:800px){.smart-choice-grid{grid-template-columns:1fr}}

/* مساعدة قرار الاعتماد في التوزيع الذكي */
.smart-acceptance-help{margin:12px 0;padding:12px;border:1px solid #d8d4ee;border-radius:16px;background:#fbfaff;box-shadow:0 8px 20px rgba(38,29,94,.06)}
.smart-decision{border-radius:14px;padding:12px 14px;margin-bottom:10px;border:1px solid #ddd;background:#fff}
.smart-decision div{display:flex;flex-direction:column;gap:4px}
.smart-decision b{font-size:.9rem;color:#5b5476}
.smart-decision strong{font-size:1.08rem;color:#1f1748}
.smart-decision span{color:#3f3a55;line-height:1.55}
.smart-decision.good{background:#ecfdf5;border-color:#a7f3d0}
.smart-decision.ok{background:#f0fdf4;border-color:#bbf7d0}
.smart-decision.mid{background:#fffbeb;border-color:#fde68a}
.smart-decision.bad{background:#fff1f2;border-color:#fecdd3}
.smart-help-title{font-weight:800;color:#271c5d;margin:8px 0 6px}
.smart-scale{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:10px}
.smart-scale span{font-size:.82rem;font-weight:700;border-radius:999px;padding:5px 9px;border:1px solid transparent}
.smart-scale .good{background:#dcfce7;color:#166534;border-color:#86efac}
.smart-scale .ok{background:#e0f2fe;color:#075985;border-color:#7dd3fc}
.smart-scale .mid{background:#fef3c7;color:#92400e;border-color:#fcd34d}
.smart-scale .bad{background:#ffe4e6;color:#9f1239;border-color:#fda4af}
.smart-help-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:8px}
.smart-metric-row{border:1px solid #ebe7f7;border-radius:12px;background:#fff;padding:9px;display:flex;flex-direction:column;gap:4px;min-height:64px}
.smart-metric-row b{color:#24174d}
.smart-metric-row span{color:#504a66;line-height:1.45;font-size:.9rem}
.smart-metric-row.good{border-color:#86efac;background:#f0fdf4}
.smart-metric-row.ok{border-color:#7dd3fc;background:#f0f9ff}
.smart-metric-row.mid{border-color:#fcd34d;background:#fffbeb}
.smart-metric-row.bad{border-color:#fda4af;background:#fff1f2}
.smart-help-note{margin-top:10px!important}

/* v4.0.13 - التوزيع الذكي + تحسين التوزيع الحالي */


/* V4.0.15 — تقرير تحسين التوزيع والتعيين الحاليين قبل الاعتماد */
.improve-detail-report{
  margin:12px 0;
  padding:12px;
  border:1px solid #cbd5e1;
  border-radius:12px;
  background:#f8fafc;
}
.improve-detail-report h3{margin:0 0 10px;font-size:18px;color:#0f172a}
.improve-detail-report h4{margin:12px 0 6px;color:#334155}
.improve-report-decision{
  display:flex;
  flex-direction:column;
  gap:4px;
  padding:10px;
  border-radius:10px;
  background:#ecfdf5;
  border:1px solid #86efac;
  color:#064e3b;
  margin-bottom:10px;
}
.improve-report-summary{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(130px,1fr));
  gap:8px;
  margin:10px 0;
}
.improve-report-summary div{
  background:white;
  border:1px solid #e2e8f0;
  border-radius:10px;
  padding:8px;
}
.improve-report-summary span{display:block;color:#64748b;font-size:12px}
.improve-report-summary b{font-size:18px;color:#0f172a}
.mini-report-table{width:100%;border-collapse:collapse;background:white;font-size:13px}
.mini-report-table th,.mini-report-table td{border:1px solid #e2e8f0;padding:7px;vertical-align:top}
.mini-report-table th{background:#f1f5f9;color:#0f172a}
.warn-note{background:#fff7ed!important;border-color:#fed7aa!important;color:#9a3412!important}


/* V 4.6.8 — واجهات أوسع وأقل ضغطًا عند تكبير 100% */
.v31-audit-modal{width:calc(100vw - 40px)!important;max-width:1720px!important;max-height:94vh!important;border-radius:20px!important}
.v31-audit-modal .audit-modal-head{padding:18px 28px 14px!important;min-height:84px!important}
.v31-audit-modal .official-body{padding:18px 26px 24px!important;max-height:calc(94vh - 84px)!important}
.v31-audit-modal .official-status{padding:15px 18px!important;margin-bottom:14px!important;grid-template-columns:66px 1fr!important}
.v31-audit-modal .audit-formal-summary{grid-template-columns:repeat(auto-fit,minmax(190px,1fr))!important;gap:12px!important;margin-bottom:14px!important}
.v31-audit-modal .audit-formal-summary div{min-height:76px!important;padding:13px 15px!important}
.v31-audit-modal .audit-pro-grid.v31-grid{grid-template-columns:repeat(auto-fit,minmax(210px,1fr))!important;gap:12px!important}
.v31-audit-modal .audit-pro-card{min-height:92px!important;padding:12px 14px!important}
.audit-top-actions{grid-template-columns:repeat(3,minmax(180px,1fr)) minmax(260px,1fr)!important;gap:10px!important;padding:11px!important;margin-bottom:14px!important}
.audit-top-actions .audit-action{height:44px!important;min-width:0!important;width:100%!important}
.v31-audit-modal .v31-tabs{gap:8px!important;padding:10px 12px!important}
.v31-audit-modal .v31-tabs .audit-tab{min-width:170px!important;padding:12px 14px!important;font-size:13px!important}
.v31-audit-modal .audit-pane{padding:22px 26px 26px!important;min-height:460px!important}
.v31-audit-modal .audit-grid-inside{gap:18px!important;margin-bottom:18px!important}
@media(max-width:1100px){.audit-top-actions{grid-template-columns:repeat(2,minmax(0,1fr))!important}.audit-top-index{grid-column:1/-1}.v31-audit-modal{width:99vw!important}.v31-audit-modal .official-body{padding:12px!important}}

.amphi-dialog{width:calc(100vw - 36px)!important;max-width:1720px!important;max-height:94vh!important;border-radius:20px!important}
.amphi-head{padding:16px 24px!important;min-height:66px!important;background:#3C3489!important}
.amphi-head b{font-size:20px!important;letter-spacing:.1px!important}
.amphi-head button{width:44px!important;height:44px!important;border-radius:14px!important;font-size:24px!important}
.amphi-modal-body{padding:20px 26px 26px!important;max-height:calc(94vh - 66px)!important;background:#fff!important}
.amphi-actions-top{position:relative!important;top:auto!important;display:grid!important;grid-template-columns:repeat(auto-fit,minmax(230px,1fr))!important;gap:12px!important;padding:14px!important;margin-bottom:16px!important;border-radius:16px!important}
.amphi-actions-top .btn{min-height:46px!important;padding:12px 16px!important;font-size:12.5px!important}
.amphi-explain-details{margin-bottom:16px!important;border-radius:15px!important}
.amphi-explain-details summary{padding:12px 16px!important;font-size:14px!important}
.amphi-section-title{font-size:18px!important;margin:22px 4px 12px!important}
.amphi-summary,.amphi-plan-summary,.amphi-status-summary{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))!important;gap:14px!important;margin:14px 0 18px!important}
.amphi-summary div{min-height:82px!important;padding:16px!important;border-radius:16px!important}
.amphi-summary span{font-size:12.5px!important}.amphi-summary b{font-size:21px!important}
.amphi-table-wrap{max-height:54vh!important;border-radius:16px!important;margin-top:6px!important}
.amphi-table{min-width:1180px!important;font-size:13px!important}
.amphi-table th{padding:12px 10px!important}.amphi-table td{padding:11px 10px!important;line-height:1.7!important}
@media(max-width:1200px){.amphi-dialog{width:99vw!important}.amphi-modal-body{padding:14px!important}.amphi-actions-top{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))!important}.amphi-status-summary{grid-template-columns:repeat(2,minmax(0,1fr))!important}}

/* V 4.6.9 — تنظيم الواجهات بدل تكبيرها: تقرير السلامة + إدارة مسؤولي القاعات والمدرجات */
.v31-audit-modal{
  width:min(1280px,96vw)!important;
  max-width:1280px!important;
  max-height:92vh!important;
  border-radius:18px!important;
  overflow:hidden!important;
}
.v31-audit-modal .audit-modal-head{
  min-height:68px!important;
  padding:12px 18px 10px!important;
  border-bottom:1px solid #D9E4F2!important;
}
.v31-audit-modal .audit-modal-title h2{font-size:22px!important;line-height:1.25!important;margin:0!important}
.v31-audit-modal .audit-modal-title p{font-size:12.5px!important;margin-top:2px!important}
.v31-audit-modal .official-body{
  max-height:calc(92vh - 68px)!important;
  padding:14px 18px 18px!important;
  background:#F8FAFC!important;
}
.v31-audit-modal .official-status{
  padding:12px 14px!important;
  margin-bottom:12px!important;
  grid-template-columns:54px 1fr!important;
  border-radius:14px!important;
}
.v31-audit-modal .audit-status-icon{width:48px!important;height:48px!important;border-radius:14px!important}
.v31-audit-modal .audit-status-text h3{font-size:18px!important;margin:0 0 4px!important}
.v31-audit-modal .audit-formal-summary{
  grid-template-columns:repeat(3,minmax(0,1fr))!important;
  gap:10px!important;
  margin-bottom:12px!important;
}
.v31-audit-modal .audit-formal-summary div{
  min-height:66px!important;
  padding:10px 12px!important;
  border-radius:13px!important;
  background:#fff!important;
}
.v31-audit-modal .audit-formal-summary b{font-size:17px!important}
.v31-audit-modal .audit-professional-inline{
  background:#fff!important;
  border:1px solid #E2E8F0!important;
  border-radius:16px!important;
  padding:12px!important;
  margin-bottom:12px!important;
}
.v31-audit-modal .audit-pro-grid.v31-grid{
  grid-template-columns:repeat(3,minmax(0,1fr))!important;
  gap:10px!important;
}
.v31-audit-modal .audit-pro-card{
  min-height:82px!important;
  padding:10px 12px!important;
  border-radius:13px!important;
  text-align:right!important;
}
.v31-audit-modal .audit-pro-card b{font-size:16px!important}
.v31-audit-modal .audit-pro-card span{font-size:11.5px!important}
.audit-top-actions{
  display:flex!important;
  flex-wrap:wrap!important;
  align-items:center!important;
  justify-content:flex-end!important;
  gap:8px!important;
  padding:10px!important;
  margin:0 0 12px!important;
  background:#fff!important;
  border:1px solid #E2E8F0!important;
  border-radius:14px!important;
}
.audit-top-actions .audit-action{
  width:auto!important;
  min-width:132px!important;
  height:38px!important;
  padding:0 14px!important;
  border-radius:10px!important;
  margin:0!important;
  font-size:12.5px!important;
}
.audit-top-index{
  margin-right:auto!important;
  justify-self:auto!important;
  min-height:38px!important;
  padding:6px 10px!important;
}
.v31-audit-modal .v31-tabs{
  gap:5px!important;
  padding:8px 10px!important;
  background:#fff!important;
}
.v31-audit-modal .v31-tabs .audit-tab{
  min-width:126px!important;
  padding:9px 10px!important;
  font-size:12.5px!important;
}
.v31-audit-modal .audit-pane{
  padding:16px 18px 20px!important;
  min-height:390px!important;
  background:#fff!important;
}
.v31-audit-modal .audit-grid-inside{gap:12px!important;margin-bottom:12px!important}
.v31-audit-modal .audit-scroll-table{border-radius:13px!important;max-height:440px!important}
.v31-audit-modal .audit-ui-table th{padding:9px 8px!important}.v31-audit-modal .audit-ui-table td{padding:9px 8px!important}

.amphi-dialog{
  width:min(1220px,96vw)!important;
  max-width:1220px!important;
  max-height:92vh!important;
  border-radius:18px!important;
  overflow:hidden!important;
  display:flex!important;
  flex-direction:column!important;
}
.amphi-head{
  min-height:58px!important;
  padding:12px 18px!important;
  background:#3C3489!important;
  border-bottom:1px solid rgba(255,255,255,.18)!important;
}
.amphi-head b{font-size:18px!important;line-height:1.2!important}
.amphi-head button{width:38px!important;height:38px!important;border-radius:12px!important;font-size:22px!important}
.amphi-modal-body{
  max-height:calc(92vh - 58px)!important;
  overflow:auto!important;
  padding:14px 18px 18px!important;
  background:#F8FAFC!important;
}
.amphi-actions-top{
  position:relative!important;
  top:auto!important;
  display:flex!important;
  flex-wrap:wrap!important;
  justify-content:flex-end!important;
  align-items:center!important;
  gap:8px!important;
  padding:10px!important;
  margin:0 0 12px!important;
  border-radius:14px!important;
  background:#fff!important;
  border:1px solid #E2E8F0!important;
  box-shadow:0 1px 5px rgba(15,23,42,.05)!important;
}
.amphi-actions-top .btn{
  width:auto!important;
  min-width:132px!important;
  min-height:38px!important;
  padding:8px 14px!important;
  border-radius:10px!important;
  font-size:12.5px!important;
  line-height:1.25!important;
  white-space:nowrap!important;
}
.amphi-actions-top .btn.bpr{min-width:200px!important;order:1!important}
.amphi-actions-top .btn.bol{order:2!important;background:#fff!important;color:#334155!important;border:1px solid #CBD5E1!important}
.amphi-actions-top .btn.bgr{order:3!important}
.amphi-actions-top .btn.bam{order:4!important;background:#FFF8E7!important;color:#7A4B00!important;border:1px solid #E9BD62!important}
.amphi-explain-details{
  margin:0 0 12px!important;
  border-radius:13px!important;
  background:#F8FBFF!important;
}
.amphi-explain-details summary{padding:10px 14px!important;font-size:13.5px!important}
.amphi-status-summary,
.amphi-plan-summary{
  background:#fff!important;
  border:1px solid #E2E8F0!important;
  border-radius:16px!important;
  padding:12px!important;
  margin:0 0 14px!important;
}
.amphi-status-summary{
  grid-template-columns:repeat(4,minmax(0,1fr))!important;
  gap:10px!important;
}
.amphi-plan-summary{
  grid-template-columns:repeat(3,minmax(0,1fr))!important;
  gap:10px!important;
}
.amphi-summary div{
  min-height:66px!important;
  padding:10px 12px!important;
  border-radius:13px!important;
  background:#FBFAFF!important;
  display:flex!important;
  flex-direction:column!important;
  justify-content:center!important;
  align-items:center!important;
}
.amphi-summary span{font-size:11.5px!important;line-height:1.35!important}.amphi-summary b{font-size:18px!important;line-height:1.25!important}
.amphi-section-title{
  margin:16px 2px 10px!important;
  font-size:16px!important;
  color:#3C3489!important;
}
.amphi-table-wrap{
  max-height:44vh!important;
  border-radius:14px!important;
  border:1px solid #E2E8F0!important;
  background:#fff!important;
  margin-top:0!important;
}
.amphi-table{
  min-width:1040px!important;
  font-size:12.5px!important;
}
.amphi-table th{padding:10px 8px!important}.amphi-table td{padding:9px 8px!important;line-height:1.55!important;background:#fff}
.amphi-table tr:nth-child(even) td{background:#FAFAFF!important}
@media(max-width:980px){
  .v31-audit-modal,.amphi-dialog{width:98vw!important;max-height:96vh!important}
  .v31-audit-modal .audit-formal-summary,.v31-audit-modal .audit-pro-grid.v31-grid{grid-template-columns:repeat(2,minmax(0,1fr))!important}
  .amphi-status-summary,.amphi-plan-summary{grid-template-columns:repeat(2,minmax(0,1fr))!important}
  .audit-top-actions,.amphi-actions-top{justify-content:stretch!important}
  .audit-top-actions .audit-action,.amphi-actions-top .btn{flex:1 1 160px!important;white-space:normal!important}
}
@media(max-width:640px){
  .v31-audit-modal .audit-formal-summary,.v31-audit-modal .audit-pro-grid.v31-grid,.amphi-status-summary,.amphi-plan-summary{grid-template-columns:1fr!important}
}

/* V4.7.3 — Authentication and roles */
.auth-overlay{position:fixed;inset:0;background:linear-gradient(135deg,rgba(15,68,124,.94),rgba(15,110,86,.94));z-index:999999;display:none;align-items:center;justify-content:center;padding:22px;font-family:Cairo,Tahoma,Arial,sans-serif}
.auth-card{width:min(440px,96vw);background:#fff;border-radius:18px;box-shadow:0 24px 70px rgba(0,0,0,.30);padding:24px;border:1px solid #dbeafe;text-align:right}
.auth-title{font-size:25px;font-weight:900;color:#0C447C;text-align:center;margin-bottom:4px}.auth-sub{text-align:center;color:#64748b;font-weight:800;margin-bottom:18px}.auth-field{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}.auth-field label{font-size:12px;font-weight:900;color:#334155}.auth-field input,.auth-field select{border:1.5px solid #cbd5e1;border-radius:10px;padding:11px 12px;font-size:14px;font-family:Cairo,Tahoma,Arial,sans-serif}.auth-primary{width:100%;border:0;border-radius:12px;background:#0F6E56;color:#fff;padding:12px 14px;font-size:15px;font-weight:900;cursor:pointer;font-family:Cairo,Tahoma,Arial,sans-serif;margin-top:4px}.auth-msg{display:none;border-radius:10px;padding:10px 12px;margin-bottom:12px;font-size:12px;font-weight:800}.auth-msg.bad{background:#fff1f2;color:#be123c;border:1px solid #fecdd3}.auth-msg.ok{background:#ecfdf5;color:#047857;border:1px solid #bbf7d0}.auth-hint{font-size:11px;color:#64748b;background:#f8fafc;border:1px dashed #cbd5e1;border-radius:10px;padding:9px;margin-top:12px;line-height:1.7}.auth-locked .wrap,.auth-locked .hdr{filter:blur(2px);pointer-events:none}.auth-user-badge{display:flex;flex-direction:column;gap:4px;align-items:flex-end;color:#fff;font-size:11px;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.28);padding:7px;border-radius:10px;margin-right:8px;min-width:180px}.auth-user-badge button{font-size:10px;padding:3px 8px;border-radius:7px;border:1px solid rgba(255,255,255,.45);background:rgba(255,255,255,.18);color:#fff;cursor:pointer;font-family:Cairo,Tahoma,Arial,sans-serif}.auth-users-form{align-items:flex-end}.auth-check{display:flex;align-items:center;gap:7px;font-size:12px;font-weight:900;background:#f8fafc;border:1px solid #cbd5e1;border-radius:9px;padding:10px}.auth-users-table{width:100%;border-collapse:collapse;margin-top:12px;font-size:12px}.auth-users-table th,.auth-users-table td{border:1px solid #d8dee9;padding:8px;text-align:right}.auth-users-table th{background:#eef6ff;color:#0C447C;font-weight:900}body[data-role="viewer"] input:not(#authOverlay input):not(#userMgmtPanel input),body[data-role="viewer"] select:not(#authOverlay select):not(#userMgmtPanel select),body[data-role="viewer"] textarea:not(#authOverlay textarea):not(#userMgmtPanel textarea){background:#f8fafc!important;color:#64748b!important}


/* V4.7.3: إخفاء التطبيق نهائياً قبل التحقق من تسجيل الدخول */
body.auth-booting{background:#0C447C;}
body.auth-booting .hdr,body.auth-booting .wrap{display:none!important;}
body.auth-booting::before{content:'جارٍ التحقق من الجلسة...';position:fixed;inset:0;display:flex;align-items:center;justify-content:center;color:#fff;font-family:Cairo,Tahoma,Arial,sans-serif;font-weight:900;font-size:15px;z-index:999990;background:linear-gradient(135deg,#0C447C,#0F6E56);}
body.auth-booting #authOverlay{z-index:1000000;}
body.auth-booting #authOverlay~*{display:none!important;}
.auth-overlay{display:none;}
.auth-links{display:flex;justify-content:space-between;gap:10px;margin-top:10px;flex-wrap:wrap}.auth-links button{border:0;background:transparent;color:#0C447C;font-family:Cairo,Tahoma,Arial,sans-serif;font-size:12px;font-weight:900;cursor:pointer;text-decoration:underline}.auth-panel{width:100%}.auth-card{position:relative;z-index:1000001}.auth-locked .wrap,.auth-locked .hdr{filter:none!important;pointer-events:none}

/* V4.7.5 role-specific dashboards */
.role-dashboard{display:block!important;margin-bottom:14px}
.role-hero{background:linear-gradient(135deg,#0C447C,#3C3489);color:#fff;border-radius:18px;padding:18px 22px;margin:0 0 14px;box-shadow:0 10px 28px rgba(12,68,124,.18)}
.role-hero h2{margin:0 0 6px;font-size:24px;font-weight:900}
.role-hero p{margin:0;opacity:.92;font-size:13px}
.role-card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(235px,1fr));gap:14px;margin:12px 0 18px}
.role-card{background:#fff;border:1px solid #d8e3ef;border-radius:16px;padding:16px;box-shadow:0 8px 22px rgba(16,24,40,.07);min-height:160px;display:flex;flex-direction:column;gap:7px;align-items:flex-start}
.role-card .role-ico{font-size:31px;line-height:1;background:#F3F6FA;border:1px solid #E2E8F0;border-radius:14px;padding:10px}
.role-card h3{margin:5px 0 0;color:#0C447C;font-size:18px;font-weight:900}
.role-card p{margin:0;color:#475569;font-size:12.5px;line-height:1.7;flex:1}
body[data-role="clerk"] #sendSummonsFromProfsBtn{display:none!important}
body[data-role="clerk"] #groupManagementCard{display:none!important}
body[data-role="registrar"] #groupManagementCard button[onclick="printStudentGroups()"]{display:none!important}
body[data-role="registrar"] #roomManagementCard,
body[data-role="registrar"] #roomToolbar,
body[data-role="registrar"] #roomList,
body[data-role="registrar"] #rooms>.note{display:none!important}
body[data-role="viewer"] .tabs{display:none!important}

/* V4.7.6 role dashboards: one expandable section under the cards */
.role-dashboard.sec.active{display:block!important}
.role-open-section{display:block!important;margin-top:18px;border-top:1px solid var(--bd);padding-top:14px}
.role-info-card{margin-top:8px}
.role-info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px;margin-top:10px}
.role-info-grid>div{background:#F8FAFC;border:1px solid var(--bd);border-radius:12px;padding:10px;display:flex;flex-direction:column;gap:4px}
.role-info-grid b{font-size:11px;color:var(--tx2)}
.role-info-grid span{font-size:13px;color:var(--pri);font-weight:800}
.role-info-counts{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:10px;margin-top:12px}
.role-info-counts span{background:#fff;border:1px solid var(--bd);border-radius:12px;padding:10px;text-align:center;color:var(--tx2);font-size:11px}
.role-info-counts b{display:block;color:var(--pri);font-size:18px;margin-bottom:3px}

/* V4.7.7 user account management actions */
.bda{background:#FEE2E2;border:1px solid #FCA5A5;color:#991B1B}
.bda:hover{background:#FECACA;color:#7F1D1D}
.auth-role-select{min-width:150px;border:1px solid var(--bd);border-radius:10px;padding:7px 9px;background:#fff;color:var(--tx);font-weight:800;margin-inline-end:6px}
.auth-small-btn{padding:7px 10px!important;min-height:34px!important;font-size:12px!important}
.auth-users-table td{vertical-align:middle}

/* V4.7.8 role dashboards: grouped report cards and clerk panels */
.role-dashboard .role-hero{background:linear-gradient(135deg,#eef7f2,#f7fbff);border:1px solid var(--bd);border-radius:18px;padding:18px 20px;margin-bottom:16px}
.role-dashboard .role-hero h2{margin:0 0 6px;font-size:20px;color:var(--gn)}
.role-dashboard .role-hero p{margin:0;color:var(--tx2);font-size:13px;line-height:1.7}
.role-card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:14px;margin:14px 0 18px}
.role-card{background:#fff;border:1px solid var(--bd);border-radius:18px;padding:16px;box-shadow:0 7px 18px rgba(31,42,68,.06);display:flex;flex-direction:column;gap:8px;min-height:170px}
.role-card .role-ico{width:44px;height:44px;border-radius:14px;display:flex;align-items:center;justify-content:center;background:#eef7f2;font-size:22px}
.role-card h3{margin:0;font-size:16px;color:var(--tx)}
.role-card p{margin:0;color:var(--tx2);font-size:12px;line-height:1.7;flex:1}
.role-card .btn{align-self:flex-start;margin-top:4px}
.role-runtime-section{margin-top:14px}
.role-open-section{border-top:3px solid var(--gn);padding-top:10px}
.role-package-card{border-radius:18px;border:1px solid var(--bd);box-shadow:0 8px 20px rgba(31,42,68,.07)}
.role-package-desc{font-size:13px;color:var(--tx2);line-height:1.8;margin:5px 0 12px}
.role-package-statuses{display:flex;flex-wrap:wrap;gap:8px;margin:8px 0 14px}
.role-pkg-status{display:inline-flex;gap:6px;align-items:center;border-radius:999px;padding:7px 11px;font-size:12px;border:1px solid var(--bd);background:#f7fbff;color:var(--tx2)}
.role-pkg-status.ok{background:#edf8f2;border-color:#b8e0cc;color:#0F6E56}
.role-pkg-status.warn{background:#fff8e7;border-color:#f0d9a3;color:#925b00}
.role-package-actions{display:flex;flex-wrap:wrap;gap:8px 10px;margin:6px 0 12px}
.role-info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:10px;margin:10px 0 12px}
.role-info-grid>div{background:#f8fbff;border:1px solid var(--bd);border-radius:12px;padding:10px 12px;display:flex;flex-direction:column;gap:4px}
.role-info-grid b{font-size:12px;color:var(--tx2)}
.role-info-grid span{font-size:13px;color:var(--tx);font-weight:800}
.role-info-counts{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:8px}
.role-info-counts span{background:#fff;border:1px solid var(--bd);border-radius:12px;padding:9px 10px;text-align:center;color:var(--tx2);font-size:12px}
.role-info-counts b{display:block;font-size:20px;color:var(--gn)}
body[data-role="clerk"] #profs.role-open-section,
body[data-role="clerk"] #rooms.role-open-section,
body[data-role="clerk"] #exams.role-open-section,
body[data-role="registrar"] #students.role-open-section,
body[data-role="registrar"] #rooms.role-open-section{background:#fff;border:1px solid var(--bd);border-radius:18px;padding:14px;box-shadow:0 8px 20px rgba(31,42,68,.06)}

/* V4.7.13 role/detail refinements */
.top-user-card{min-width:220px;display:flex;align-items:center;justify-content:space-between;gap:8px;background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.35);border-radius:9px;padding:5px 7px;color:#fff}
.top-user-name{font-size:11px;font-weight:900;max-width:150px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.top-user-actions{display:flex;gap:4px;align-items:center}
.top-user-actions button{font-family:Cairo,sans-serif;font-size:10px;font-weight:800;border:1px solid rgba(255,255,255,.45);background:rgba(255,255,255,.18);color:#fff;border-radius:6px;padding:3px 7px;cursor:pointer}
.role-detail-list{margin-top:12px;border-top:1px dashed #d9e2ef;padding-top:10px;display:flex;flex-direction:column;gap:8px;width:100%}
.role-detail-title{font-size:12px;font-weight:900;color:#0c447c;margin-bottom:2px}
.role-detail-row{display:grid;grid-template-columns:minmax(160px,1.1fr) minmax(100px,.7fr) auto;gap:8px;align-items:center;border:1px solid #e2e8f0;background:#fff;border-radius:10px;padding:8px 10px;font-size:11.5px}
.role-detail-row b{color:#1e293b}.role-detail-row span{color:#64748b;font-size:11px}.role-detail-actions{display:flex;gap:5px;flex-wrap:wrap;justify-content:flex-end}.role-detail-actions .btn{font-size:10px!important;padding:4px 9px!important}
.role-detail-empty{margin-top:10px;background:#fff7ed;border:1px solid #fed7aa;color:#9a3412;border-radius:10px;padding:9px;font-size:12px;font-weight:800}
.role-subject-block{border:1px solid #edf2f7;border-radius:11px;padding:8px;background:#fbfdff}.role-subject-block h4{margin:0 0 7px;color:#3C3489;font-size:12px}
.group-choice-host{padding:6px;background:var(--bg);border:1px solid var(--bd);border-radius:6px;min-height:36px}
.group-card-strip{display:flex;gap:8px;overflow-x:auto;padding:4px 2px 7px;align-items:stretch}
.group-mini-card{min-width:190px;max-width:260px;border:1px solid #ddd9f5;background:#fff;border-radius:10px;box-shadow:0 1px 4px rgba(34,28,76,.05);padding:7px;flex:0 0 auto}
.group-mini-title{font-size:11px;font-weight:900;color:#3C3489;border-bottom:1px solid #eeedfe;padding-bottom:5px;margin-bottom:6px;display:flex;justify-content:space-between;gap:8px}.group-mini-title span{background:#eeedfe;border-radius:999px;padding:1px 7px;color:#5e5a7a}
.group-mini-items{display:flex;flex-wrap:wrap;gap:5px;align-content:flex-start}.group-mini-choice{font-size:10.5px;display:flex;align-items:center;gap:4px;cursor:pointer;background:var(--sf);border:1px solid var(--bd);border-radius:7px;padding:4px 7px;white-space:nowrap}
@media(max-width:760px){.role-detail-row{grid-template-columns:1fr}.role-detail-actions{justify-content:flex-start}.top-user-card{min-width:0;flex-wrap:wrap}.group-mini-card{min-width:170px}}

/* V4.7.15: بطاقة المستخدم في موضع بطاقة أعلى أزرار الإدارة بدل البطاقة الجانبية */
.top-user-badge-slot{width:310px;max-width:100%;padding:0!important;background:transparent!important;border:0!important;box-shadow:none!important}
.auth-user-badge-top{width:100%;margin-right:0;min-width:0;box-sizing:border-box;align-items:flex-end}
.auth-user-badge-actions{display:flex;gap:4px;flex-wrap:wrap;justify-content:flex-end}

/* V5.1.9 — تنظيم نهائي لبطاقة المستخدم وبطاقة القسم داخل إطار واحد بين الشعارين */
.hdr{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:nowrap;padding:.9rem 1.25rem 1rem}
.hdr-logo{height:48px;width:48px;object-fit:contain;border-radius:9px;background:#fff;padding:2px;flex-shrink:0}
.hdr-center{flex:1 1 auto;min-width:0;text-align:center;display:flex;flex-direction:column;align-items:center}
.hdr-center h1{font-size:17px;font-weight:900;margin:0;line-height:1.4}
.hdr-center p{font-size:10.5px;opacity:.84;margin:2px 0 0;line-height:1.5}
.top-horizontal-controls{width:min(930px,100%);box-sizing:border-box;display:grid;grid-template-columns:minmax(260px,330px) minmax(420px,1fr);gap:12px;align-items:stretch;margin-top:14px;direction:ltr;background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.28);border-radius:14px;padding:12px;box-shadow:0 10px 24px rgba(0,0,0,.08)}
.top-user-host{min-width:0;display:flex;flex-direction:column;align-items:stretch;gap:6px;order:1;direction:rtl}
.top-department-host{min-width:0;display:flex;justify-content:stretch;order:2;direction:rtl}
.top-save-line{display:flex;align-items:center;gap:6px;justify-content:flex-start;padding-inline:2px;min-height:16px}
.top-save-line #saveInd{font-size:10px;color:rgba(255,255,255,.78)}
.top-save-line #storageSize{font-size:10px;color:rgba(255,255,255,.58)}
.department-selector-panel{width:100%;box-sizing:border-box;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.33);border-radius:12px;padding:11px 12px;color:#fff;box-shadow:0 8px 20px rgba(0,0,0,.07);display:flex;flex-direction:column;gap:9px;min-height:92px}
.department-card-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin:0;flex-wrap:nowrap}
.department-card-title{font-size:12px;font-weight:900;color:#fff;white-space:nowrap}
.department-card-body{display:grid;grid-template-columns:1fr auto;gap:8px;align-items:end}
.department-select-field{min-width:0;flex:1 1 auto;margin:0}
.department-select-field label{color:rgba(255,255,255,.86)}
.department-select-field select{background:#fff;color:#263238;border-color:rgba(255,255,255,.55);height:40px}
.department-status-pill{display:inline-flex;align-items:center;gap:4px;min-height:31px;border-radius:8px;background:rgba(255,255,255,.90);color:#2e2a63;padding:6px 10px;font-size:12px;font-weight:900;white-space:nowrap}
.department-status-pill span{font-weight:900;color:#5b5680}
.department-status-pill b{font-weight:900;color:#2e2a63}
.department-card-note{display:none}
.top-user-badge-slot{width:100%!important;max-width:none!important}
.auth-user-badge-top{width:100%;box-sizing:border-box;justify-content:space-between;margin:0!important;min-height:92px;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.33);box-shadow:0 8px 20px rgba(0,0,0,.07)}
.auth-user-badge-top b{font-size:12px;font-weight:900}
.auth-user-badge-top span{font-size:11px;opacity:.88}
.auth-user-badge-actions{display:flex;gap:5px;flex-wrap:wrap;justify-content:flex-end}
.auth-users-table-clean{table-layout:auto;width:100%}
.auth-users-table-clean th,.auth-users-table-clean td{vertical-align:middle;padding:10px 8px}
.auth-users-table-clean td:nth-child(2){direction:ltr;unicode-bidi:plaintext;white-space:nowrap}
.auth-users-table-clean .auth-role-select,.auth-users-table-clean .auth-department-select,.auth-actions-menu select{min-width:150px;max-width:220px}
.auth-actions-menu{display:flex;gap:6px;align-items:center;justify-content:center;flex-wrap:wrap}
.auth-pill{display:inline-block;border-radius:999px;padding:3px 8px;margin:2px;font-size:10.5px;font-weight:900;border:1px solid transparent;white-space:nowrap}
.auth-pill.ok{background:#e9f8f2;color:#0f6e56;border-color:#abdfcc}
.auth-pill.warn{background:#fff3e2;color:#9a5a00;border-color:#f1c783}
.auth-pill.wait{background:#eef2ff;color:#3c3489;border-color:#c9cef9}
.auth-admin-row{background:#fbfaff}
.prof-dept-picker select:disabled{background:#f7f7ff;color:#3c3489;font-weight:800;opacity:1}
@media(max-width:900px){.hdr{align-items:center}.top-horizontal-controls{grid-template-columns:1fr;align-items:stretch}.top-user-host,.top-department-host{min-width:0}.department-card-body{grid-template-columns:1fr}.department-select-field{min-width:100%}}
.top-horizontal-controls{flex-direction:column;align-items:stretch}.top-user-host,.top-department-host{flex-basis:auto;min-width:0}.department-card-body{grid-template-columns:1fr}.department-select-field{min-width:100%}}

/* V5.1.10 — شريط الهيدر الأفقي في سطر واحد */
.hdr{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:nowrap;padding:.8rem 1.25rem .9rem}
.hdr-logo{height:48px;width:48px;object-fit:contain;border-radius:9px;background:#fff;padding:2px;flex-shrink:0}
.hdr-center{flex:1 1 auto;min-width:0;text-align:center;display:flex;flex-direction:column;align-items:center}
.hdr-center h1{font-size:17px;font-weight:900;margin:0;line-height:1.35}
.hdr-center p{font-size:10.5px;opacity:.84;margin:2px 0 0;line-height:1.45}
.top-horizontal-controls{width:min(1120px,100%);box-sizing:border-box;display:flex;flex-direction:row;gap:12px;align-items:center;justify-content:center;margin-top:12px;direction:ltr;background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.28);border-radius:14px;padding:10px 12px;box-shadow:0 10px 24px rgba(0,0,0,.08)}
.top-user-host{min-width:0;display:flex;flex:0 0 auto;align-items:center;order:1;direction:rtl}
.top-department-host{min-width:0;display:flex;flex:1 1 auto;justify-content:stretch;order:2;direction:rtl}
.top-save-line{display:none!important}
.top-user-badge-slot{width:auto!important;max-width:none!important;min-width:0!important;padding:0!important;background:transparent!important;border:0!important;box-shadow:none!important}
.auth-user-badge-top{width:auto;min-width:330px;box-sizing:border-box;display:flex!important;flex-direction:row!important;align-items:center!important;justify-content:space-between!important;gap:10px;margin:0!important;min-height:44px!important;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.33);box-shadow:0 8px 20px rgba(0,0,0,.07);padding:8px 10px!important;white-space:nowrap}
.auth-user-badge-top>div:first-child{display:flex;align-items:center;gap:3px;min-width:0;overflow:hidden;text-overflow:ellipsis}
.auth-user-badge-top b{font-size:12px;font-weight:900;white-space:nowrap}
.auth-user-badge-top span{font-size:11px;opacity:.88;white-space:nowrap}
.auth-user-badge-actions{display:flex!important;gap:5px;flex-wrap:nowrap!important;justify-content:flex-end;align-items:center;white-space:nowrap}
.auth-user-badge-actions button{white-space:nowrap}
.department-selector-panel{width:100%;box-sizing:border-box;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.33);border-radius:12px;padding:8px 10px;color:#fff;box-shadow:0 8px 20px rgba(0,0,0,.07);display:flex;align-items:center;justify-content:stretch;min-height:44px!important}
.department-inline-row{width:100%;display:flex;flex-direction:row;align-items:center;gap:8px;white-space:nowrap}
.department-inline-select{flex:1 1 260px;min-width:240px;background:#fff;color:#263238;border:1px solid rgba(255,255,255,.55);border-radius:8px;height:38px;padding:7px 10px;font-family:Cairo,Tahoma,Arial,sans-serif;font-size:12px;font-weight:800}
.department-inline-btn{flex:0 0 auto;height:38px;white-space:nowrap;padding:7px 14px!important}
.department-status-pill{display:inline-flex;align-items:center;gap:4px;min-height:30px;border-radius:8px;background:rgba(255,255,255,.90);color:#2e2a63;padding:6px 10px;font-size:12px;font-weight:900;white-space:nowrap;flex:0 0 auto}
.department-status-pill span{font-weight:900;color:#5b5680}
.department-status-pill b{font-weight:900;color:#2e2a63}
.department-card-head,.department-card-title,.department-card-body,.department-select-field{display:contents}
.department-select-field label{display:none!important}
@media(max-width:900px){.hdr{align-items:center}.top-horizontal-controls{flex-direction:column;align-items:stretch}.top-user-host,.top-department-host{width:100%;flex:1 1 auto}.auth-user-badge-top{width:100%;min-width:0}.department-inline-row{flex-wrap:wrap}.department-inline-select{min-width:100%;flex-basis:100%}.department-status-pill{flex:1 1 auto}.department-inline-btn{flex:1 1 auto}}

/* V6.0.1 — رسالة إدارية لغير المدير عند وجود توزيع معتمد للدورة الحالية */
.role-distribution-notice{
  max-width:760px;
  margin:14px auto 18px;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:14px;
  text-align:center;
  direction:rtl;
  background:linear-gradient(135deg,#fff7e6,#fffdf7);
  border:1px solid #f1c97a;
  border-radius:18px;
  padding:16px 18px;
  box-shadow:0 10px 26px rgba(130,87,0,.10);
  color:#5c3b00;
}
.role-distribution-notice-icon{
  width:44px;
  height:44px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:50%;
  background:#fff;
  border:1px solid #f1c97a;
  font-size:22px;
  flex:0 0 auto;
}
.role-distribution-notice strong{display:block;font-size:18px;font-weight:900;margin-bottom:5px;color:#6b4100}
.role-distribution-notice p{margin:0;font-size:14px;font-weight:800;line-height:1.8}
@media(max-width:680px){.role-distribution-notice{align-items:flex-start}.role-distribution-notice p{font-size:13px}}

/* V5.6.6 exam supervisor inline HTML preview */
#examSupervisorSummonHtmlPreview{direction:rtl;background:#fff;color:#111}
#examSupervisorSummonHtmlPreview .note{color:#334155}

/* V6.0.1 — مذكرة تنظيمية لمراقب الامتحان */
.supervisor-memo-overlay{position:fixed;inset:0;background:rgba(15,23,42,.58);z-index:99999;display:flex;align-items:center;justify-content:center;padding:14px;direction:rtl}
.supervisor-memo-dialog{width:min(900px,96vw);max-height:92vh;overflow:auto;background:#fff;border-radius:18px;border:1px solid #DDD9F5;box-shadow:0 22px 70px rgba(15,23,42,.28);font-family:Cairo,Tahoma,Arial,sans-serif}
.supervisor-memo-head{padding:15px 18px;background:linear-gradient(135deg,#3C3489,#5B4CC4);color:#fff;display:flex;justify-content:space-between;gap:12px;align-items:center;flex-wrap:wrap}
.supervisor-memo-head b{font-size:20px}.supervisor-memo-head span{font-size:12px;opacity:.9}
.supervisor-memo-body{padding:16px 20px;color:#1f2937}.supervisor-memo-body h4{margin:8px 0 8px;color:#3C3489}
.supervisor-memo-list{margin:0 18px 12px 0;line-height:1.9}.supervisor-memo-list li{margin:3px 0}
.supervisor-memo-block{border:1px solid #DDAA42;background:#FFF9E8;border-radius:12px;padding:12px;margin-top:12px}
.supervisor-memo-highlight{margin:0 20px 12px 0;line-height:1.9}.supervisor-memo-highlight li{margin:4px 0}
.supervisor-memo-table{width:100%;border-collapse:collapse;background:#fff;border-radius:8px;overflow:hidden;font-size:12px}
.supervisor-memo-table th,.supervisor-memo-table td{border:1px solid #e5e7eb;padding:7px;text-align:center}.supervisor-memo-table th{background:#F5F4FC;color:#3C3489}
.supervisor-memo-actions{padding:12px 18px;border-top:1px solid #EEEDFE;text-align:center;background:#fafafa;position:sticky;bottom:0}


/* V6.1.1 — معلومات المؤسسة والدورة في واجهة تسجيل الدخول */
.auth-institution-info{background:#f8fbff;border:1px solid #dbeafe;border-radius:14px;padding:10px 12px;margin:10px 0 14px;box-shadow:inset 0 1px 0 rgba(255,255,255,.7)}
.auth-institution-row{display:flex;align-items:center;justify-content:space-between;gap:10px;border-bottom:1px dashed #d8e3ef;padding:6px 0;font-size:12px;color:#475569}
.auth-institution-row:last-child{border-bottom:0}
.auth-institution-row span{font-weight:900;color:#64748b;white-space:nowrap}
.auth-institution-row b{font-weight:900;color:#0C447C;text-align:left;direction:rtl;line-height:1.5}
.auth-institution-main{justify-content:center;text-align:center;border-bottom:1px solid #d8e3ef;color:#0C447C;font-size:13px;padding-top:2px}
.auth-institution-main b{text-align:center;color:#0C447C}
.auth-institution-loading{text-align:center;font-size:12px;color:#64748b;font-weight:800;padding:8px 0}

/* V6.4.1 — إضافة تقرير بعد التوزيع وإصلاح تضمين صور PDF المرسلة مع الحفاظ على إعدادات البريد */
.data-repo-intro{margin-bottom:10px!important}
.data-repo-grid{display:grid;grid-template-columns:repeat(3,minmax(250px,1fr));gap:14px;align-items:start}
.data-repo-card{margin:8px 0 12px 0!important;padding:12px!important;border-radius:14px!important;overflow:hidden;min-width:0;box-sizing:border-box;background:#fbfdff!important}
.data-repo-card-title{font-weight:900;color:#25215f;text-align:center;margin-bottom:9px;font-size:13px}
.data-repo-form{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:7px;align-items:end}
.data-repo-form .data-repo-out-label{grid-column:1 / -1;justify-self:start;display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:900;color:#A32D2D;background:#FFF1F1;border:1px solid #F0B6B6;border-radius:9px;padding:5px 8px;min-height:28px;cursor:pointer;max-width:100%;box-sizing:border-box}
.data-repo-form .data-repo-out-label input{accent-color:#C02020;margin:0}
.data-repo-input{min-width:0!important;width:100%}.data-repo-input input{width:100%;box-sizing:border-box;font-size:12px!important}
.data-repo-add-btn,.data-repo-del-btn{min-width:38px!important;width:38px!important;min-height:30px!important;height:30px!important;padding:3px 6px!important;font-size:11px!important;line-height:1!important;border-radius:8px!important;display:inline-flex!important;align-items:center!important;justify-content:center!important;white-space:nowrap!important}
.data-repo-list-box{margin-top:10px;min-width:0}.data-repo-status{font-size:11px;font-weight:800;color:#4b5563;background:#f2f1ff;border:1px solid #e3e0ff;border-radius:9px;padding:6px 8px;text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.data-repo-path-details{margin-top:5px;font-size:10px;color:#64748b;direction:rtl}.data-repo-path-details summary{cursor:pointer;font-weight:800;color:#6b5bbd;text-align:center}.data-repo-path-details code{display:block;margin-top:4px;white-space:normal;overflow-wrap:anywhere;word-break:break-word;background:#f8fafc;border:1px solid #e2e8f0;border-radius:7px;padding:5px;direction:ltr;text-align:left;line-height:1.4}
.data-repo-list{margin-top:9px;display:flex;flex-direction:column;gap:7px}.data-repo-item{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px;align-items:center;border:1px solid #e2e8f0;background:#fff;border-radius:10px;padding:7px 8px;min-width:0}.data-repo-item-text{min-width:0}.data-repo-item-text b{display:block;color:#1e293b;font-size:11.5px;font-weight:900;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.data-repo-item-meta{display:flex;gap:4px;flex-wrap:wrap;margin-top:4px}.data-repo-chip{display:inline-flex;align-items:center;border-radius:999px;background:#f1f0ff;color:#4f46a5;font-size:10px;font-weight:900;padding:2px 6px;line-height:1.4}.data-repo-chip.danger{background:#fee2e2;color:#991b1b;border:1px solid #fecaca}.data-repo-empty{margin-top:8px;background:#fff7ed;border:1px solid #fed7aa;color:#9a3412;border-radius:10px;padding:8px;font-size:11px;font-weight:900;text-align:center}
@media(max-width:1100px){.data-repo-grid{grid-template-columns:repeat(2,minmax(250px,1fr))}}
@media(max-width:720px){.data-repo-grid{grid-template-columns:1fr}.data-repo-form{grid-template-columns:minmax(0,1fr) auto}.data-repo-status{white-space:normal}}

/* V6.4.2 — تقرير تحسين التعيين الحالي لمسؤولي القاعات والمدرجات */
.amphi-improvement-report{margin:14px 0;padding:12px;border:1px solid #d8c7ff;border-radius:14px;background:#fbfaff;box-shadow:0 1px 0 rgba(255,255,255,.8) inset}
.amphi-improve-summary{background:#fff!important;border-color:#e9ddff!important}
.amphi-warn-note{background:#fff7ed!important;border-color:#fdba74!important;color:#9a3412!important}
.amphi-improvement-report details{margin:10px 0;border:1px solid #e5e7eb;border-radius:12px;background:#fff;overflow:hidden}
.amphi-improvement-report summary{cursor:pointer;font-weight:900;color:#3C3489;background:#f5f3ff;padding:9px 12px;border-bottom:1px solid #e9d5ff}
.amphi-rule-list{margin:10px 22px 10px 0;line-height:1.9;font-weight:800;color:#334155}
.amphi-rule-list li{margin:3px 0}

/* V2.3.0 — بوابة مراقب الامتحان: بطاقة أماكن المراقبة */
.supervisor-places-card{margin:14px auto 12px;max-width:980px;border:1px solid #D8D2EE;border-radius:14px;background:#FBFAFF;padding:12px;box-shadow:0 8px 22px rgba(15,23,42,.06)}
.supervisor-places-card .ct{margin-bottom:6px}
.supervisor-places-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:10px}
.supervisor-place-item{border:1px solid #E2DDF5;border-radius:12px;background:#fff;overflow:hidden}
.supervisor-place-head{width:100%;border:0;background:#fff;color:#1A1825;padding:10px 12px;display:flex;justify-content:space-between;gap:10px;align-items:flex-start;text-align:right;cursor:pointer;font-family:Cairo,Tahoma,Arial,sans-serif}
.supervisor-place-head:hover{background:#F4F1FF}
.supervisor-place-head b{display:block;font-size:13px;color:#0C447C}
.supervisor-place-head small{display:block;margin-top:3px;font-size:10.5px;color:#6B647A;line-height:1.6}
.supervisor-place-meta{white-space:nowrap;font-size:10.5px;font-weight:900;color:#0F6E56;background:#EAF8F2;border:1px solid #BCE6D0;border-radius:999px;padding:4px 8px}
.supervisor-peers-box{border-top:1px solid #EFEAFD;background:#FDFDFF;padding:8px}
.supervisor-peers-title{font-size:11px;font-weight:900;color:#4F46A5;margin-bottom:6px}
.supervisor-peer-row{display:flex;justify-content:space-between;align-items:center;gap:8px;border:1px solid #ECE7FA;background:#fff;border-radius:9px;padding:7px 9px;margin-bottom:5px;font-size:11.5px;font-weight:700;color:#29243A}
.supervisor-peer-row.supervisor-peer-responsible{border-color:#F4C46B;background:#FFF8E6;color:#7A4B00}
.supervisor-resp-badge{font-size:10px;font-weight:900;color:#8A4B00;background:#FFE7A5;border:1px solid #F2C35B;border-radius:999px;padding:2px 7px;white-space:nowrap}
.supervisor-me-badge{font-size:9.5px;font-weight:900;color:#fff;background:#0C447C;border-radius:999px;padding:1px 6px;margin-right:5px;white-space:nowrap}

/* V2.3.0 — تحسين نافذة مراسلة زملاء الحصة من بوابة مراقب الامتحان */
.supervisor-mail-overlay{position:fixed;inset:0;background:rgba(15,23,42,.45);z-index:99999;display:flex;align-items:center;justify-content:center;padding:18px;direction:rtl;overflow:hidden}
.supervisor-mail-dialog{width:min(860px,96vw);max-height:92vh;overflow-y:auto;overflow-x:hidden;background:#fff;border-radius:18px;border:1px solid #d8d2ee;box-shadow:0 24px 70px rgba(15,23,42,.25);padding:14px;text-align:right;box-sizing:border-box}
.supervisor-mail-dialog *{box-sizing:border-box}
.supervisor-mail-head{display:flex;justify-content:space-between;align-items:center;gap:10px;border-bottom:1px solid #eee;padding-bottom:10px;margin-bottom:10px;color:#3C3489;font-weight:900}
.supervisor-mail-context,.supervisor-mail-note{margin:8px 0;border-radius:10px;background:#f0edff;color:#40386d;padding:10px 12px;font-size:13px;font-weight:800;line-height:1.7}
.supervisor-mail-note{background:#f8fafc;color:#475569;border:1px solid #e5e7eb}
.supervisor-mail-toolbar{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-start;margin:10px 0}
.supervisor-peer-mail-list{display:flex;flex-direction:column;gap:8px;max-height:260px;overflow-y:auto;overflow-x:hidden;border:1px solid #ece7fa;border-radius:14px;padding:10px;background:#fbfaff}
.supervisor-peer-mail-row{display:grid;grid-template-columns:auto 1fr;align-items:center;gap:10px;width:100%;border:1px solid #e5e7eb;border-radius:12px;background:#fff;padding:10px 12px;cursor:pointer;font-size:12.5px;font-weight:800;color:#1f2937;min-width:0}
.supervisor-peer-mail-row:hover{border-color:#c4b5fd;background:#faf7ff}
.supervisor-peer-mail-row.disabled{opacity:.55;cursor:not-allowed;background:#f8fafc}
.supervisor-peer-mail-check-wrap{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:10px;background:#f5f3ff;border:1px solid #ddd6fe;flex:0 0 auto}
.supervisor-peer-mail-row input{margin:0;width:18px;height:18px;accent-color:#4F46A5}
.supervisor-peer-mail-info{display:flex;flex-direction:column;gap:5px;min-width:0}
.supervisor-peer-mail-name{font-weight:900;color:#111827;line-height:1.3;white-space:normal;overflow-wrap:anywhere}
.supervisor-peer-mail-meta{display:flex;gap:6px;align-items:center;flex-wrap:wrap;min-width:0}
.supervisor-peer-mail-email{font-size:11px;color:#64748b;unicode-bidi:plaintext;direction:ltr;max-width:100%;overflow-wrap:anywhere}
.supervisor-peer-mail-noemail{font-size:11px;color:#991B1B;font-weight:900}
.supervisor-peer-mail-role{font-size:10px;font-weight:900;color:#475569;background:#eef2ff;border:1px solid #dbe3ff;border-radius:999px;padding:2px 7px;white-space:nowrap}
.supervisor-mail-subject{margin-top:12px}
.supervisor-mail-message textarea{width:100%;resize:vertical;min-height:150px;max-width:100%;border-radius:12px;padding:10px;font-family:inherit}
.supervisor-mail-status{margin-top:8px}
.supervisor-mail-actions{display:flex;gap:8px;justify-content:flex-end;flex-wrap:wrap;margin-top:12px;border-top:1px solid #eee;padding-top:10px}
@media(max-width:640px){.supervisor-mail-dialog{width:98vw;padding:10px}.supervisor-mail-actions{justify-content:stretch}.supervisor-mail-actions .btn{flex:1}.supervisor-mail-toolbar .btn{flex:1}.supervisor-peer-mail-list{max-height:220px}}

/* V2.3.5 — صفحة الدخول: عكس الشعارين ووضع عنوان تسجيل الدخول بينهما في نفس السطر */
.auth-card{
  width:min(760px,96vw)!important;
  max-width:760px!important;
  display:grid!important;
  grid-template-columns:minmax(260px,.92fr) minmax(300px,1fr)!important;
  grid-template-areas:
    "logos logos"
    "info panel"
    "msg panel";
  column-gap:22px!important;
  row-gap:10px!important;
  padding:16px 26px 24px!important;
  align-items:start!important;
}
.auth-logo-row{grid-area:logos!important;display:flex!important;align-items:center!important;justify-content:space-between!important;gap:16px!important;min-height:72px!important;margin-bottom:0!important}
.auth-logo{display:block!important;width:118px!important;height:70px!important;object-fit:contain!important;border:0!important;background:transparent!important;flex:0 0 auto!important}
.auth-logo-left{order:1!important}.auth-title-wrap{order:2!important;flex:1 1 auto!important;text-align:center!important;min-width:0!important}.auth-logo-right{order:3!important}
.auth-title{margin:0!important;font-size:25px!important;font-weight:900!important;color:#0C447C!important;text-align:center!important;line-height:1.25!important}
.auth-sub{margin:4px 0 0!important;text-align:center!important;color:#64748b!important;font-weight:800!important;font-size:12px!important;line-height:1.35!important}
.auth-institution-info{grid-area:info!important;margin:0!important;align-self:stretch!important}
.auth-faculty-link{display:block;margin-top:10px;text-align:center;direction:ltr;color:#0C447C;font-weight:900;text-decoration:underline;font-size:12px}
.auth-msg{grid-area:msg!important;margin:10px 0 0!important}
.auth-panel{grid-area:panel!important;align-self:start!important}
.auth-field{margin-bottom:10px!important}
@media(max-width:760px){
  .auth-card{
    width:min(440px,96vw)!important;
    display:block!important;
    padding:16px 20px 22px!important;
  }
  .auth-logo-row{min-height:56px!important;margin-bottom:10px!important;gap:10px!important}
  .auth-logo{width:76px!important;height:50px!important}
  .auth-title{font-size:21px!important}
  .auth-sub{font-size:10.5px!important;margin-top:3px!important}
  .auth-institution-info{margin:10px 0 14px!important}
}


/* V2.3.9 — أدوات الامتحان التعويضي */
.remedial-paper-preview-card{border-color:#E8C36A;background:linear-gradient(180deg,#fff,#FFF9E8);cursor:pointer;transition:.15s ease}
.remedial-paper-preview-card[aria-disabled="true"]{opacity:.62;cursor:not-allowed;filter:grayscale(.12)}
.remedial-paper-preview-card:not([aria-disabled="true"]):hover{box-shadow:0 8px 22px rgba(120,75,0,.10);transform:translateY(-1px)}
.remedial-paper-preview-body{margin-top:10px;border-top:1px solid var(--bd);padding-top:10px;cursor:default}
.remedial-paper-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(290px,1fr));gap:10px}
.remedial-subject-card{border:1px solid var(--bd);border-radius:10px;background:#fff;padding:10px}
.remedial-subject-title{font-size:13px;font-weight:900;color:var(--pr2);margin-bottom:8px;display:flex;justify-content:space-between;gap:8px;align-items:center}
.remedial-mini-form{display:grid;grid-template-columns:repeat(auto-fit,minmax(125px,1fr));gap:7px;margin-bottom:8px}
.remedial-mini-form label{font-size:10.5px;color:var(--tx2);font-weight:800;display:block;margin-bottom:3px}
.remedial-mini-form input,.remedial-mini-form select{width:100%;font-family:Cairo,sans-serif;font-size:11px;border:1px solid #BFD3EA;border-radius:7px;padding:7px;background:#F8FBFF;box-sizing:border-box}
.remedial-entry-list{display:flex;flex-direction:column;gap:6px;margin-top:8px}
.remedial-entry-row{border:1px solid #E1E8F2;background:#FAFCFF;border-radius:8px;padding:7px;font-size:11px;line-height:1.7;display:flex;justify-content:space-between;gap:8px;align-items:flex-start}
.remedial-entry-row b{color:var(--pr2)}
.remedial-entry-actions{display:flex;gap:5px;flex-wrap:wrap;justify-content:flex-end}
.remedial-entry-actions button{font-size:10px;padding:3px 7px}
.remedial-placeholder{background:rgba(154,106,0,.08);border:1px solid #E8C36A;border-radius:8px;padding:8px;font-size:11px;line-height:1.8;color:#7A5200;margin-bottom:8px}

/* V2.6.0: إظهار/إخفاء كلمة السر وتحسين إعدادات الأمن */
.password-eye-wrap{position:relative;display:flex;align-items:center;width:100%}
.password-eye-wrap input{width:100%;padding-inline-end:44px!important}
.password-eye-btn{position:absolute;left:8px;top:50%;transform:translateY(-50%);border:0;background:#eef6ff;color:#0C447C;border-radius:8px;width:34px;height:30px;cursor:pointer;font-size:14px;line-height:1;font-family:Cairo,Tahoma,Arial,sans-serif}
.password-eye-btn:hover{background:#dbeafe}
#settingsSecurity .auth-check{min-height:40px}
#activeSessionsBox table{margin-top:8px}

/* V2.6.1 — واجهة مسؤولي الإدارة: تقارير المواد حسب التاريخ + البحث السريع */
.role-subject-reports-by-date{gap:12px}
.role-date-block{border:1px solid #dbe7f3;border-radius:14px;background:#fbfdff;padding:10px;display:flex;flex-direction:column;gap:8px}
.role-date-head{display:flex;align-items:center;justify-content:space-between;gap:8px;background:#eef6ff;border:1px solid #d8e9fb;border-radius:11px;padding:8px 10px;color:#0C447C;font-size:12px;font-weight:900}
.role-date-head span{font-size:11px;background:#fff;border:1px solid #d8e9fb;border-radius:999px;padding:3px 8px;color:#334155}
.role-quick-search-box{width:100%;margin-top:8px;display:flex;flex-direction:column;gap:12px}
.role-quick-toolbar{display:grid;grid-template-columns:auto minmax(190px,260px) minmax(230px,1fr);gap:8px;align-items:center;width:100%;background:#f8fafc;border:1px solid #e2e8f0;border-radius:14px;padding:10px}
.role-quick-toolbar label{font-size:12px;font-weight:900;color:#0C447C;white-space:nowrap}
.role-quick-toolbar select,.role-quick-toolbar input{border:1px solid #d7e2ee;border-radius:10px;padding:9px 10px;font-family:inherit;font-size:12px;background:#fff;min-width:0}
.role-quick-step-title{font-size:12px;font-weight:900;color:#0C447C;background:#f1f7ff;border:1px solid #dbeafe;border-radius:11px;padding:8px 10px}
.role-quick-card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px;width:100%}
.role-quick-card{border:1px solid #dbe7f3;background:#fff;border-radius:14px;padding:12px;text-align:right;font-family:inherit;cursor:pointer;display:flex;flex-direction:column;gap:5px;box-shadow:0 5px 14px rgba(31,42,68,.05);transition:.15s ease}
.role-quick-card:hover{transform:translateY(-1px);border-color:#9dc5ef;box-shadow:0 8px 20px rgba(12,68,124,.10)}
.role-quick-card.selected{border-color:#0C447C;background:#f0f7ff;box-shadow:0 0 0 2px rgba(12,68,124,.08)}
.role-quick-card b{font-size:13px;color:#1e293b}
.role-quick-card span{font-size:11px;color:#475569;line-height:1.5}
.role-quick-card small{font-size:10.5px;color:#64748b;line-height:1.5}
.role-quick-reset-row{display:flex;justify-content:flex-start;margin-top:-4px}
.role-quick-results{border:1px dashed #cbd5e1;border-radius:13px;background:#fff;padding:9px;display:flex;flex-direction:column;gap:7px}
.role-quick-result-row{display:grid;grid-template-columns:minmax(180px,1fr) auto;gap:8px;align-items:center;border:1px solid #e2e8f0;border-radius:10px;padding:8px;background:#fbfdff}
.role-quick-result-row b{display:block;color:#1e293b;font-size:12px}.role-quick-result-row span{display:block;color:#64748b;font-size:11px;margin-top:2px}
.role-quick-monitors{border:1px solid #dbe7f3;background:#fbfdff;border-radius:14px;padding:10px;display:flex;flex-direction:column;gap:7px;width:100%}
.role-monitor-row{display:flex;align-items:center;gap:9px;background:#fff;border:1px solid #e2e8f0;border-radius:10px;padding:8px}
.role-monitor-num{width:26px;height:26px;border-radius:999px;background:#eef7f2;color:#0F6E56;display:flex;align-items:center;justify-content:center;font-weight:900;font-size:12px;flex:0 0 auto}
.role-monitor-row b{display:block;color:#1e293b;font-size:12px}.role-monitor-row small{display:block;color:#64748b;font-size:10.5px;margin-top:2px}
.role-quick-search-help{margin-top:0!important}
@media(max-width:760px){.role-quick-toolbar{grid-template-columns:1fr}.role-quick-result-row{grid-template-columns:1fr}.role-quick-card-grid{grid-template-columns:1fr}}

/* V2.6.2 — إصلاح البحث السريع + زر تعطيل كل المستخدمين غير المديرين */
.auth-bulk-disable-card{border-color:#fecaca!important;background:#fff7f7!important}
.auth-bulk-disable-card b{color:#991b1b}
.auth-bulk-disable-card .btn.bam{background:#b91c1c;color:#fff;border-color:#991b1b}
.auth-bulk-disable-card .btn.bam:hover{filter:brightness(.96)}
#roleQuickSearchInner select,#roleQuickSearchInner input{pointer-events:auto!important;opacity:1!important}
#roleQuickTeacherResults{display:flex;flex-direction:column;gap:8px}

/* V2.6.3: بحث الاستدعاءات وتنظيم المحاضر حسب المادة في واجهة مسؤولي الإدارة */
.role-summons-search-box{display:grid;grid-template-columns:auto minmax(220px,1fr) auto;gap:8px;align-items:center;border:1px solid #e2e8f0;background:#f8fafc;border-radius:14px;padding:10px;margin:2px 0 8px}
.role-summons-search-box label{font-size:12px;font-weight:900;color:#0C447C;white-space:nowrap}
.role-summons-search-box input{border:1px solid #d7e2ee;border-radius:10px;padding:9px 10px;font-family:inherit;font-size:12px;background:#fff;min-width:0}
.role-summons-search-box span{font-size:11px;color:#64748b;line-height:1.5}
.role-summons-search-box.disabled{opacity:.72;background:#fff7ed;border-color:#fed7aa}
.role-search-count{font-size:11.5px;font-weight:900;color:#3C3489;background:#f3f0ff;border:1px solid #e4dcff;border-radius:999px;padding:5px 10px;width:max-content;max-width:100%;margin:0 0 6px auto}
.role-minutes-subject-cards{gap:10px}
.role-minutes-subject-card{border:1px solid #dbe7f3;border-radius:14px;background:#fbfdff;box-shadow:0 5px 14px rgba(31,42,68,.04);overflow:hidden}
.role-minutes-subject-card.open{background:#fff;border-color:#b9d5ee;box-shadow:0 8px 22px rgba(12,68,124,.08)}
.role-minutes-subject-head{width:100%;border:0;background:linear-gradient(180deg,#f8fbff,#eef6ff);padding:10px 12px;font-family:inherit;text-align:right;cursor:pointer;display:grid;grid-template-columns:minmax(180px,1fr) auto auto;gap:8px;align-items:center;color:#0C447C}
.role-minutes-subject-head b{font-size:13px;color:#1e293b}.role-minutes-subject-head span{font-size:11px;background:#fff;border:1px solid #d8e9fb;border-radius:999px;padding:4px 9px;color:#334155}.role-minutes-subject-head small{font-size:10.5px;color:#64748b}
.role-minutes-subject-head:hover{filter:brightness(.985)}
.role-minutes-subject-body{display:flex;flex-direction:column;gap:7px;padding:10px;border-top:1px dashed #dbe7f3;background:#fff}
@media(max-width:760px){.role-summons-search-box,.role-minutes-subject-head{grid-template-columns:1fr}.role-search-count{width:auto;margin-right:0}}

/* V2.6.4: التصحيح الفعلي لتبويبات الاستدعاءات والمحاضر الأساسية */
.summons-teacher-search-wrap{display:grid;grid-template-columns:auto minmax(240px,1fr) auto;gap:8px;align-items:center;border:1px solid #e2e8f0;background:#f8fafc;border-radius:14px;padding:10px;margin:0 0 12px}
.summons-teacher-search-wrap label{font-size:12px;font-weight:900;color:#3C3489;white-space:nowrap}
.summons-teacher-search-wrap input{border:1px solid #d7e2ee;border-radius:10px;padding:9px 10px;font-family:inherit;font-size:12px;background:#fff;min-width:0;pointer-events:auto!important}
.summons-teacher-search-wrap span{font-size:11px;color:#64748b;line-height:1.5}
.summons-teacher-search-wrap.disabled{opacity:.72;background:#fff7ed;border-color:#fed7aa}
.summons-teacher-search-wrap.disabled input{background:#f8fafc;color:#94a3b8;cursor:not-allowed}
.summons-search-empty{border:1px dashed #d8d1f0;background:#f7f4ff;border-radius:12px;padding:12px;text-align:center;color:#4c3f91;font-size:12px;font-weight:800;margin-top:8px}
.sheets-subject-cards-list{display:flex;flex-direction:column;gap:10px}
.sheets-subject-card{border:1px solid #dbe7f3;border-radius:14px;background:#fbfdff;box-shadow:0 5px 14px rgba(31,42,68,.04);overflow:hidden}
.sheets-subject-card.open{background:#fff;border-color:#b9d5ee;box-shadow:0 8px 22px rgba(12,68,124,.08)}
.sheets-subject-head{width:100%;border:0;background:linear-gradient(180deg,#f8fbff,#eef6ff);padding:11px 13px;font-family:inherit;text-align:right;cursor:pointer;display:grid;grid-template-columns:minmax(220px,1fr) auto auto;gap:8px;align-items:center;color:#0C447C}
.sheets-subject-head b{font-size:13px;color:#1e293b;line-height:1.6}.sheets-subject-head span{font-size:11px;background:#fff;border:1px solid #d8e9fb;border-radius:999px;padding:4px 9px;color:#334155;white-space:nowrap}.sheets-subject-head small{font-size:10.5px;color:#64748b;white-space:nowrap}
.sheets-subject-head:hover{filter:brightness(.985)}
.sheets-subject-body{display:flex;flex-direction:column;gap:7px;padding:10px;border-top:1px dashed #dbe7f3;background:#fff}
@media(max-width:760px){.summons-teacher-search-wrap,.sheets-subject-head{grid-template-columns:1fr}.summons-teacher-search-wrap label,.sheets-subject-head span,.sheets-subject-head small{white-space:normal}}

/* V2.6.6 — استثناءات التوزيع */
.distribution-exceptions-card{box-shadow:0 10px 26px rgba(154,106,0,.08)}
.distribution-exceptions-form{display:grid;grid-template-columns:minmax(190px,1fr) minmax(230px,1.2fr) minmax(260px,1.4fr) auto;gap:10px;align-items:end}
.dist-ex-check-list{border:1px solid var(--bd);border-radius:9px;background:#fff;min-height:42px;max-height:150px;overflow:auto;padding:7px;display:flex;flex-wrap:wrap;gap:6px}
.dist-ex-check-list label{display:inline-flex;align-items:center;gap:5px;border:1px solid #EEE4BC;background:#FFFDF4;border-radius:999px;padding:4px 8px;font-size:11px;font-weight:800;color:#5f4700;cursor:pointer}
.dist-ex-check-list input{width:14px;height:14px;accent-color:#9a6a00;margin:0}
.dist-ex-actions-inline{display:flex;align-items:flex-end;justify-content:flex-end}
.dist-ex-entries{margin-top:10px;display:grid;gap:7px}
.dist-ex-entry{border:1px solid #EEE4BC;background:#fff;border-radius:10px;padding:8px;display:grid;grid-template-columns:minmax(160px,1fr) minmax(240px,2fr) minmax(110px,.7fr) auto;gap:8px;align-items:center;font-size:11.5px}
.dist-ex-entry b{color:#5f4700}
.dist-ex-entry small{color:var(--tx3);line-height:1.6}
.dist-ex-entry-actions{display:flex;gap:5px;justify-content:flex-end;flex-wrap:wrap}
.dist-ex-active-badge{display:inline-flex;align-items:center;gap:4px;margin-inline-start:5px;animation:distExPulse 1s infinite;filter:drop-shadow(0 0 4px rgba(184,28,28,.35))}
@keyframes distExPulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.18);opacity:.72}}
@media(max-width:900px){.distribution-exceptions-form{grid-template-columns:1fr}.dist-ex-entry{grid-template-columns:1fr}.dist-ex-entry-actions{justify-content:flex-start}}
