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

/* ═══════════════════════════════════════════════════════
   CEILEGA v5.0 — Edraak-Inspired Design System
   Purple primary · Orange CTA · White & Clean
═══════════════════════════════════════════════════════ */
:root {
  /* ── Edraak Colors ── */
  --pur:    #6b21a8;   /* purple-800 — primary */
  --pur-m:  #7c3aed;   /* violet-600 */
  --pur-l:  #a855f7;   /* purple-500 */
  --pur-bg: #faf5ff;   /* purple-50 */
  --pur-b:  #e9d5ff;   /* purple-200 */
  --org:    #f97316;   /* orange-500 — CTA */
  --org-d:  #ea580c;   /* orange-600 */
  --org-bg: #fff7ed;   /* orange-50 */
  --teal:   #0d9488;   /* teal-600 */
  --tel-bg: #f0fdfa;
  --grn:    #16a34a;
  --grn-bg: #f0fdf4;
  --red:    #dc2626;
  --red-bg: #fef2f2;
  --amb:    #d97706;
  --amb-bg: #fffbeb;
  --sky:    #0284c7;
  --sky-bg: #f0f9ff;

  /* ── UI Neutrals ── */
  --white:  #ffffff;
  --gray-50:#f9fafb;
  --gray-100:#f3f4f6;
  --gray-200:#e5e7eb;
  --gray-300:#d1d5db;
  --gray-400:#9ca3af;
  --gray-500:#6b7280;
  --gray-700:#374151;
  --gray-800:#1f2937;
  --gray-900:#111827;

  /* ── Semantic aliases ── */
  --bg:     var(--gray-50);
  --bg2:    var(--gray-100);
  --card:   var(--white);
  --bdr:    var(--gray-200);
  --bdr2:   var(--gray-300);
  --t:      var(--gray-900);
  --t2:     var(--gray-700);
  --t3:     var(--gray-500);
  --t4:     var(--gray-400);
  --sid-bg: var(--white);
  --top-bg: var(--white);

  /* ── Shadows ── */
  --sh:    0 1px 3px rgba(0,0,0,.06),0 1px 6px rgba(0,0,0,.04);
  --sh-md: 0 4px 12px rgba(0,0,0,.08),0 2px 6px rgba(0,0,0,.04);
  --sh-lg: 0 8px 24px rgba(0,0,0,.1);
  --sh-xl: 0 16px 48px rgba(0,0,0,.14);
  --sh-pur:0 4px 14px rgba(107,33,168,.25);

  /* ── Shape & Motion ── */
  --r:    8px;
  --r-sm: 6px;
  --r-lg: 12px;
  --r-xl: 16px;
  --r-pill:999px;
  --ease: all .18s ease;
  --font: 'Cairo',sans-serif;
  --sid-w:256px;
  --top-h:62px;
}

/* ── RESET ─────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{direction:rtl;font-size:15px;-webkit-font-smoothing:antialiased}
body{font-family:var(--font);background:var(--bg);color:var(--t);line-height:1.65}
a{text-decoration:none;color:var(--pur);transition:var(--ease)}
a:hover{color:var(--pur-m)}
img{max-width:100%;display:block}
::-webkit-scrollbar{width:4px;height:4px}
::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:99px}

/* ════════════════════════════════════════════════════
   TOPBAR
════════════════════════════════════════════════════ */
.topbar{
  position:fixed;top:0;right:var(--sid-w);left:0;
  height:var(--top-h);
  background:var(--white);
  border-bottom:1px solid var(--bdr);
  display:flex;align-items:center;
  padding:0 1.5rem;z-index:800;gap:.8rem;
  transition:right .3s ease;
}
.topbar.full{right:0}
.tb-title{font-size:.82rem;font-weight:600;color:var(--t2)}
.tb-title strong{color:var(--t);font-weight:700}
.tb-sep{width:1px;height:20px;background:var(--bdr)}
.tb-right{display:flex;align-items:center;gap:.5rem;margin-right:auto;margin-left:0}
.tb-btn{
  width:36px;height:36px;border-radius:var(--r);
  display:flex;align-items:center;justify-content:center;
  background:var(--gray-50);border:1px solid var(--bdr);
  color:var(--t3);font-size:.84rem;cursor:pointer;
  transition:var(--ease);position:relative;text-decoration:none;
}
.tb-btn:hover{background:var(--pur-bg);border-color:var(--pur-b);color:var(--pur)}
.tb-badge{
  position:absolute;top:-4px;left:-4px;
  width:16px;height:16px;border-radius:50%;
  background:var(--red);color:#fff;
  font-size:.5rem;font-weight:800;
  display:flex;align-items:center;justify-content:center;
  border:2px solid var(--white);
}
.tb-ham{
  width:36px;height:36px;border-radius:var(--r);
  display:flex;align-items:center;justify-content:center;
  background:var(--gray-50);border:1px solid var(--bdr);
  color:var(--t3);cursor:pointer;font-size:.9rem;transition:var(--ease);
}
.tb-ham:hover{background:var(--pur-bg);border-color:var(--pur-b);color:var(--pur)}
.tb-user{
  display:flex;align-items:center;gap:.45rem;
  padding:.28rem .6rem;border-radius:var(--r);
  border:1px solid var(--bdr);background:var(--white);
  cursor:pointer;transition:var(--ease);
}
.tb-user:hover{background:var(--pur-bg);border-color:var(--pur-b)}
.tb-av{
  width:30px;height:30px;border-radius:var(--r);
  background:var(--pur);
  display:flex;align-items:center;justify-content:center;
  font-weight:800;color:#fff;font-size:.78rem;flex-shrink:0;
}
.tb-name{font-size:.78rem;font-weight:700;color:var(--t)}
.tb-role{font-size:.6rem;color:var(--t3)}

/* ════════════════════════════════════════════════════
   SIDEBAR — White / Light (Edraak style)
════════════════════════════════════════════════════ */
.sidebar{
  position:fixed;right:0;top:0;bottom:0;
  width:var(--sid-w);
  background:var(--white);
  border-left:1px solid var(--bdr);
  display:flex;flex-direction:column;
  z-index:900;overflow-y:auto;
  transition:transform .3s ease;
}
.sidebar.hidden{transform:translateX(var(--sid-w))}

.sid-brand{
  height:var(--top-h);padding:0 1.2rem;
  display:flex;align-items:center;gap:.7rem;
  border-bottom:1px solid var(--bdr);flex-shrink:0;
}
.sid-logo{
  width:34px;height:34px;border-radius:var(--r);
  background:linear-gradient(135deg,var(--pur),var(--pur-m));
  display:flex;align-items:center;justify-content:center;
  font-size:.9rem;font-weight:900;color:#fff;flex-shrink:0;
}
.sid-app-name{font-size:.9rem;font-weight:800;color:var(--t)}
.sid-app-sub{font-size:.47rem;color:var(--t3);margin-top:1px}

.sid-user{
  padding:.9rem 1.2rem;border-bottom:1px solid var(--bdr);
  display:flex;align-items:center;gap:.65rem;flex-shrink:0;
  background:var(--pur-bg);
}
.sid-av{
  width:36px;height:36px;border-radius:var(--r);
  background:var(--pur);
  display:flex;align-items:center;justify-content:center;
  font-size:.9rem;font-weight:800;color:#fff;flex-shrink:0;
}
.sid-uname{font-weight:700;font-size:.82rem;color:var(--t);line-height:1.25;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:150px}
.sid-urole{font-size:.62rem;color:var(--t3);margin-top:1px}
.sid-role-badge{
  display:inline-block;padding:1px 8px;
  border-radius:99px;font-size:.58rem;font-weight:700;
  background:var(--pur);color:#fff;margin-top:3px;
}

.sid-nav{flex:1;padding:.7rem 0}
.sid-lbl{
  font-size:.56rem;font-weight:700;letter-spacing:.12em;
  text-transform:uppercase;color:var(--t4);
  padding:.65rem 1.2rem .2rem;
}
.sid-lnk{
  display:flex;align-items:center;gap:.6rem;
  padding:.56rem 1.2rem;margin:1px 0;
  color:var(--t2);font-size:.82rem;font-weight:500;
  transition:var(--ease);text-decoration:none;
  border-right:3px solid transparent;
}
.sid-lnk:hover{color:var(--pur);background:var(--pur-bg);text-decoration:none}
.sid-lnk.on{
  color:var(--pur);font-weight:700;
  background:var(--pur-bg);
  border-right-color:var(--pur);
}
.sid-lnk .i{width:18px;text-align:center;font-size:.82rem;flex-shrink:0;color:var(--t4)}
.sid-lnk:hover .i,.sid-lnk.on .i{color:var(--pur)}
.sid-pip{
  margin-right:auto;margin-left:0;
  background:var(--red);color:#fff;
  font-size:.56rem;font-weight:800;
  padding:2px 7px;border-radius:99px;line-height:1.4;
}
.sid-hr{height:1px;background:var(--bdr);margin:.45rem 0}
.sid-out{
  display:flex;align-items:center;gap:.6rem;
  padding:.56rem 1.2rem;margin:1px 0;
  color:var(--red);font-size:.82rem;font-weight:500;
  transition:var(--ease);text-decoration:none;
}
.sid-out:hover{background:var(--red-bg);text-decoration:none}
.sid-out .i{width:18px;text-align:center;font-size:.82rem;flex-shrink:0;color:var(--red)}

/* ════════════════════════════════════════════════════
   LAYOUT
════════════════════════════════════════════════════ */
.main-wrap{
  margin-right:var(--sid-w);
  padding:calc(var(--top-h) + 1.5rem) 1.75rem 2rem;
  min-height:100vh;
  transition:margin-right .3s ease;
}
.main-wrap.full{margin-right:0}
.overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.35);z-index:850}
.overlay.on{display:block}

/* ════════════════════════════════════════════════════
   PAGE HEADER
════════════════════════════════════════════════════ */
.ph,.page-hdr,.page-header{
  display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:.65rem;margin-bottom:1.4rem;
}
.ph h2,.page-hdr h2,.page-header h2{
  font-size:1.15rem;font-weight:800;color:var(--t);margin:0;
  display:flex;align-items:center;gap:.45rem;
}
.ph h2 i,.page-hdr h2 i,.page-header h2 i{color:var(--pur);font-size:.95rem}
.breadcrumb-trail,.ph-sub,.page-header .breadcrumb{
  font-size:.72rem;color:var(--t3);margin-top:.1rem;
}
.breadcrumb-trail a,.ph-sub a,.page-header .breadcrumb a{color:var(--pur);font-weight:500}

/* ════════════════════════════════════════════════════
   STAT CARDS — Edraak style: white + colored icon bg
════════════════════════════════════════════════════ */
.scard{
  background:var(--white);border-radius:var(--r-lg);
  border:1px solid var(--bdr);
  padding:1.25rem;transition:var(--ease);
  box-shadow:var(--sh);
}
.scard:hover{box-shadow:var(--sh-md);transform:translateY(-2px)}
.scard-top{display:flex;align-items:flex-start;justify-content:space-between;gap:.5rem;margin-bottom:.75rem}
.scard-ico{
  width:46px;height:46px;border-radius:var(--r-lg);
  display:flex;align-items:center;justify-content:center;
  font-size:1.2rem;flex-shrink:0;
}
.scard-ico.p{background:var(--pur-bg);color:var(--pur)}
.scard-ico.o{background:var(--org-bg);color:var(--org)}
.scard-ico.t{background:var(--tel-bg);color:var(--teal)}
.scard-ico.g{background:var(--grn-bg);color:var(--grn)}
.scard-ico.r{background:var(--red-bg);color:var(--red)}
.scard-ico.s{background:var(--sky-bg);color:var(--sky)}
.scard-ico.a{background:var(--amb-bg);color:var(--amb)}
.scard-tag{
  font-size:.64rem;font-weight:700;padding:3px 9px;
  border-radius:99px;display:inline-flex;align-items:center;gap:2px;
}
.scard-tag.g{background:var(--grn-bg);color:var(--grn)}
.scard-tag.r{background:var(--red-bg);color:var(--red)}
.scard-tag.o{background:var(--org-bg);color:var(--org)}
.scard-tag.p{background:var(--pur-bg);color:var(--pur)}
.scard-val{font-size:1.85rem;font-weight:800;color:var(--t);line-height:1}
.scard-lbl{font-size:.73rem;color:var(--t3);margin-top:.22rem;font-weight:500}

/* ════════════════════════════════════════════════════
   CARDS
════════════════════════════════════════════════════ */
.card,.sec-card,.section-card{
  background:var(--white);border-radius:var(--r-lg);
  border:1px solid var(--bdr);box-shadow:var(--sh);overflow:hidden;
}
.card:hover,.sec-card:hover{box-shadow:var(--sh-md)}
.card-h,.sec-head{
  padding:.9rem 1.25rem;
  display:flex;align-items:center;justify-content:space-between;gap:.5rem;
  border-bottom:1px solid var(--bdr);
}
.card-h h5,.card-h h6,.sec-head-title{
  font-size:.88rem;font-weight:700;color:var(--t);margin:0;
  display:flex;align-items:center;gap:.42rem;
}
.card-h h5 i,.card-h h6 i{color:var(--pur);font-size:.82rem}
.card-h .link,.sec-link{
  font-size:.75rem;font-weight:600;color:var(--pur);
  padding:.26rem .7rem;border-radius:99px;
  background:var(--pur-bg);transition:var(--ease);
}
.card-h .link:hover,.sec-link:hover{background:var(--pur);color:#fff}
.card-b{padding:1.15rem}
.card-header-custom{background:var(--pur-bg);border-bottom:1px solid var(--pur-b);padding:.88rem 1.25rem;display:flex;align-items:center;justify-content:space-between;gap:.5rem}
.card-header-custom h5,.card-header-custom h6{color:var(--pur);margin:0;font-size:.88rem;font-weight:700}
.sec-icon{width:28px;height:28px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;font-size:.78rem}
.sec-icon.p,.sec-icon.ind{background:var(--pur-bg);color:var(--pur)}
.sec-icon.o{background:var(--org-bg);color:var(--org)}
.sec-icon.t{background:var(--tel-bg);color:var(--teal)}
.sec-icon.g{background:var(--grn-bg);color:var(--grn)}
.sec-icon.r{background:var(--red-bg);color:var(--red)}

/* ════════════════════════════════════════════════════
   TABLES — Edraak style: clean light headers
════════════════════════════════════════════════════ */
.tbl,.dtbl,.table-ceilega{width:100%;border-collapse:collapse;font-size:.83rem}
.tbl thead th,
.dtbl thead th,
.table-ceilega thead th{
  background:var(--gray-50) !important;
  color:var(--gray-500) !important;
  padding:.75rem 1rem;
  font-weight:600;font-size:.73rem;
  text-align:right;white-space:nowrap;
  border-bottom:2px solid var(--bdr) !important;
  letter-spacing:.02em;
}
.tbl tbody tr,
.dtbl tbody tr,
.table-ceilega tbody tr{border-bottom:1px solid var(--gray-100);transition:background .12s}
.tbl tbody tr:last-child td,
.dtbl tbody tr:last-child td,
.table-ceilega tbody tr:last-child td{border-bottom:none}
.tbl tbody tr:hover td,
.dtbl tbody tr:hover td,
.table-ceilega tbody tr:hover td{background:var(--pur-bg)}
.tbl tbody td,
.dtbl tbody td,
.table-ceilega tbody td{padding:.75rem 1rem;vertical-align:middle}
.tbl-wrap,.table-wrapper{border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--bdr);box-shadow:var(--sh);overflow-x:auto}

/* ════════════════════════════════════════════════════
   BADGES
════════════════════════════════════════════════════ */
.bdg,.badge,.badge-status{
  display:inline-flex;align-items:center;gap:.22rem;
  padding:.22rem .68rem;border-radius:99px;
  font-size:.68rem;font-weight:700;white-space:nowrap;
}
.bdg::before,.badge::before,.badge-status::before{content:'';width:5px;height:5px;border-radius:50%;background:currentColor;flex-shrink:0}
.bdg-ok,.status-approved,.status-confirmed,.status-active,.b-success,.status-pass,.status-pub
  {background:#dcfce7;color:#15803d}
.bdg-warn,.status-pending,.b-pending{background:#fef9c3;color:#a16207}
.bdg-err,.status-rejected,.b-danger,.status-fail{background:#fee2e2;color:#b91c1c}
.bdg-info,.status-completed,.b-info{background:#dbeafe;color:#1d4ed8}
.bdg-grey,.status-draft,.b-grey{background:var(--gray-100);color:var(--gray-500)}
.bdg-pur,.bdg-p,.bdg-ind{background:var(--pur-bg);color:var(--pur)}
.mode-online{background:#cffafe;color:#0e7490;border-radius:99px;font-size:.68rem;font-weight:700;padding:.22rem .68rem;display:inline-flex;align-items:center;gap:.28rem}
.mode-presence{background:var(--pur-bg);color:var(--pur);border-radius:99px;font-size:.68rem;font-weight:700;padding:.22rem .68rem;display:inline-flex;align-items:center;gap:.28rem}
.mode-hybrid{background:#ede9fe;color:#6d28d9;border-radius:99px;font-size:.68rem;font-weight:700;padding:.22rem .68rem;display:inline-flex;align-items:center;gap:.28rem}

/* ════════════════════════════════════════════════════
   BUTTONS — Edraak style
════════════════════════════════════════════════════ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.38rem;
  padding:.5rem 1.1rem;border-radius:var(--r);
  font-weight:600;font-family:var(--font);font-size:.83rem;
  cursor:pointer;transition:var(--ease);border:none;line-height:1;
}
.btn-P,.btn-primary,.btn-navy{background:var(--pur);color:#fff;box-shadow:var(--sh-pur)}
.btn-P:hover,.btn-primary:hover,.btn-navy:hover{background:var(--pur-m);color:#fff;transform:translateY(-1px);box-shadow:0 6px 18px rgba(107,33,168,.3)}
.btn-S{background:var(--teal);color:#fff}
.btn-S:hover{background:#0f766e;color:#fff;transform:translateY(-1px)}
.btn-A,.btn-gold{background:var(--org);color:#fff;font-weight:700}
.btn-A:hover,.btn-gold:hover{background:var(--org-d);color:#fff;transform:translateY(-1px)}
.btn-ghost,.btn-outline-navy{
  background:var(--white);color:var(--t2);
  border:1px solid var(--bdr);font-family:var(--font);
}
.btn-ghost:hover,.btn-outline-navy:hover{border-color:var(--pur);color:var(--pur);background:var(--pur-bg)}
.btn-danger{background:var(--red);color:#fff;font-family:var(--font)}
.btn-danger:hover{background:#b91c1c;color:#fff}
.btn-sm{padding:.3rem .72rem;font-size:.74rem;border-radius:var(--r-sm)}
.btn-lg{padding:.65rem 1.8rem;font-size:.9rem;border-radius:var(--r-lg)}
.btn-ico{
  width:32px;height:32px;border-radius:var(--r);
  display:inline-flex;align-items:center;justify-content:center;
  border:1px solid var(--bdr);background:var(--white);
  color:var(--t3);font-size:.78rem;cursor:pointer;transition:var(--ease);
}
.btn-ico:hover{background:var(--pur);color:#fff;border-color:var(--pur)}
.btn-ico-o:hover{background:var(--org);color:#fff;border-color:var(--org)}

/* ════════════════════════════════════════════════════
   FORMS
════════════════════════════════════════════════════ */
.form-control,.form-select{
  border:1px solid var(--bdr);border-radius:var(--r);
  padding:.54rem .95rem;font-family:var(--font);font-size:.84rem;
  color:var(--t);background:var(--white);transition:var(--ease);width:100%;
}
.form-control:focus,.form-select:focus{
  border-color:var(--pur);
  box-shadow:0 0 0 3px rgba(107,33,168,.1);outline:none;
}
.form-label{font-weight:600;font-size:.8rem;color:var(--t);margin-bottom:.3rem;display:block}
.f-sec{font-size:.62rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--pur);padding-bottom:.35rem;border-bottom:1px solid var(--bdr);margin-bottom:.85rem}
.form-check-input{accent-color:var(--pur)}

/* ════════════════════════════════════════════════════
   ALERTS
════════════════════════════════════════════════════ */
.alert,.alert-custom{
  border-radius:var(--r);padding:.82rem 1rem;
  border:1px solid;font-size:.83rem;font-weight:500;
  display:flex;align-items:flex-start;gap:.6rem;
}
.alert-success,.alert-custom.alert-success{background:var(--grn-bg);border-color:#bbf7d0;color:#15803d}
.alert-warning,.alert-custom.alert-warning{background:var(--amb-bg);border-color:#fde68a;color:#a16207}
.alert-danger,.alert-custom.alert-danger{background:var(--red-bg);border-color:#fecaca;color:#b91c1c}
.alert-info,.alert-custom.alert-info{background:var(--pur-bg);border-color:var(--pur-b);color:var(--pur)}

/* ════════════════════════════════════════════════════
   MODALS
════════════════════════════════════════════════════ */
.modal-content{border-radius:var(--r-xl);border:1px solid var(--bdr);box-shadow:var(--sh-xl)}
.modal-header,.modal-ceilega .modal-header{
  background:var(--pur);color:#fff;
  border-radius:var(--r-xl) var(--r-xl) 0 0;padding:1rem 1.4rem;
  border-bottom:none;
}
.modal-title,.modal-ceilega .modal-title{color:#fff;font-weight:700;font-size:.9rem}
.modal-header .btn-close{filter:brightness(10)}

/* ════════════════════════════════════════════════════
   PROGRESS
════════════════════════════════════════════════════ */
.progress,.progress-ceilega{height:6px;background:var(--gray-200);border-radius:99px;overflow:hidden}
.progress-bar,.progress-ceilega .fill{height:100%;background:linear-gradient(90deg,var(--pur),var(--pur-m));border-radius:99px;transition:width .4s ease}

/* ════════════════════════════════════════════════════
   WELCOME BANNER — Edraak purple gradient
════════════════════════════════════════════════════ */
.wc{
  background:linear-gradient(135deg,var(--pur) 0%,var(--pur-m) 60%,#a855f7 100%);
  border-radius:var(--r-xl);padding:1.6rem 1.9rem;margin-bottom:1.4rem;
  position:relative;overflow:hidden;
}
.wc::before{content:'';position:absolute;left:-60px;bottom:-60px;width:220px;height:220px;background:rgba(255,255,255,.06);border-radius:50%}
.wc::after{content:'';position:absolute;left:160px;top:-50px;width:160px;height:160px;background:rgba(255,255,255,.05);border-radius:50%}
.wc-inner{position:relative;z-index:1;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem}
.wc-tag{font-size:.66rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.7);margin-bottom:.3rem}
.wc-title{font-size:1.3rem;font-weight:900;color:#fff;line-height:1.25;margin-bottom:.22rem}
.wc-sub{font-size:.78rem;color:rgba(255,255,255,.62)}
.wc-btn{
  padding:.48rem 1.05rem;border-radius:var(--r);
  font-size:.82rem;font-weight:700;font-family:var(--font);
  cursor:pointer;transition:var(--ease);border:none;
  display:inline-flex;align-items:center;gap:.38rem;text-decoration:none;
}
.wc-btn-w{background:rgba(255,255,255,.18);color:#fff;border:1px solid rgba(255,255,255,.3)}
.wc-btn-w:hover{background:rgba(255,255,255,.28);color:#fff}
.wc-btn-o{background:var(--org);color:#fff;font-weight:800}
.wc-btn-o:hover{background:var(--org-d);color:#fff;transform:translateY(-1px)}

/* ════════════════════════════════════════════════════
   QUICK ACTIONS
════════════════════════════════════════════════════ */
.qa-grid{display:grid;grid-template-columns:1fr 1fr;gap:.55rem;padding:.9rem 1rem}
.qa-item{
  display:flex;flex-direction:column;align-items:center;gap:.42rem;
  padding:.82rem .6rem;border-radius:var(--r);
  border:1px solid var(--bdr);transition:var(--ease);
  cursor:pointer;text-align:center;text-decoration:none;color:var(--t);
  background:var(--white);
}
.qa-item:hover{border-color:var(--pur);background:var(--pur-bg);color:var(--pur);transform:translateY(-2px)}
.qa-ico{width:34px;height:34px;border-radius:var(--r);display:flex;align-items:center;justify-content:center;font-size:.9rem}
.qa-ico.p{background:var(--pur-bg);color:var(--pur)}
.qa-ico.o{background:var(--org-bg);color:var(--org)}
.qa-ico.t{background:var(--tel-bg);color:var(--teal)}
.qa-ico.g{background:var(--grn-bg);color:var(--grn)}
.qa-ico.r{background:var(--red-bg);color:var(--red)}
.qa-ico.s{background:var(--gray-100);color:var(--gray-500)}
.qa-lbl{font-size:.73rem;font-weight:600}

/* ════════════════════════════════════════════════════
   NOTIF ITEMS
════════════════════════════════════════════════════ */
.notif-item{
  display:flex;align-items:flex-start;gap:.68rem;
  padding:.82rem 1.25rem;border-bottom:1px solid var(--gray-100);
  transition:background .12s;cursor:pointer;text-decoration:none;color:var(--t);
}
.notif-item:hover{background:var(--pur-bg)}
.notif-item.unread{border-right:3px solid var(--pur);background:var(--pur-bg)}
.notif-dot{width:8px;height:8px;border-radius:50%;background:var(--pur);flex-shrink:0;margin-top:5px}
.notif-r-dot{width:8px;height:8px;border-radius:50%;background:var(--gray-300);flex-shrink:0;margin-top:5px}

/* ════════════════════════════════════════════════════
   SESSIONS
════════════════════════════════════════════════════ */
.sess-item{
  display:flex;align-items:center;gap:.8rem;
  padding:.75rem .9rem;border-radius:var(--r);
  border:1px solid var(--bdr);margin-bottom:.5rem;
  background:var(--white);transition:var(--ease);
}
.sess-item:hover{border-color:var(--pur);background:var(--pur-bg)}
.sess-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.sess-dot.online{background:var(--teal)}
.sess-dot.presential{background:var(--pur)}

/* ════════════════════════════════════════════════════
   CHATBOT
════════════════════════════════════════════════════ */
/* ════════════════════════════════════════════════════
   CEILEGA ASSISTANT — Chat Widget
════════════════════════════════════════════════════ */
#chatbot-btn{
  position:fixed;left:20px;bottom:22px;z-index:9999;
  width:56px;height:56px;border-radius:50%;
  background:linear-gradient(135deg,var(--pur),var(--pur-m));
  color:#fff;font-size:1.3rem;border:none;
  box-shadow:var(--sh-pur);cursor:pointer;
  display:flex;align-items:center;justify-content:center;transition:var(--ease);
}
#chatbot-btn:hover{transform:scale(1.08) translateY(-2px);box-shadow:0 10px 28px rgba(107,33,168,.42)}
#chatbot-btn .cb-ping{
  position:absolute;top:-3px;left:-3px;width:14px;height:14px;border-radius:50%;
  background:var(--org);border:2px solid var(--white);
  animation:cbPulse 2s ease-in-out infinite;
}
@keyframes cbPulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.25);opacity:.7}}

#chatbot-box{
  position:fixed;left:20px;bottom:90px;z-index:9998;
  width:340px;height:480px;max-height:calc(100vh - 120px);
  background:var(--white);
  border-radius:var(--r-xl);box-shadow:var(--sh-xl);
  display:none;flex-direction:column;overflow:hidden;
  border:1px solid var(--bdr);
  animation:cbSlideUp .25s ease;
}
#chatbot-box.open{display:flex}
@keyframes cbSlideUp{from{opacity:0;transform:translateY(16px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}

#chatbot-hdr{
  background:linear-gradient(135deg,var(--pur) 0%,var(--pur-m) 100%);
  padding:.95rem 1.1rem;color:#fff;
  display:flex;align-items:center;gap:.65rem;flex-shrink:0;
  position:relative;overflow:hidden;
}
#chatbot-hdr::before{
  content:'';position:absolute;left:-30px;top:-30px;width:110px;height:110px;
  background:rgba(255,255,255,.08);border-radius:50%;
}
#chatbot-hdr-av{
  width:38px;height:38px;border-radius:50%;
  background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.3);
  display:flex;align-items:center;justify-content:center;font-size:1.05rem;
  flex-shrink:0;position:relative;z-index:1;
}
#chatbot-hdr-text{position:relative;z-index:1;flex:1;min-width:0}
#chatbot-hdr-title{font-weight:800;font-size:.88rem;line-height:1.3}
#chatbot-hdr-status{font-size:.65rem;opacity:.75;display:flex;align-items:center;gap:.3rem;margin-top:1px}
#chatbot-hdr-status .dot{width:6px;height:6px;border-radius:50%;background:#4ade80;display:inline-block}
#chatbot-close{
  position:relative;z-index:1;margin-right:auto;margin-left:0;
  background:rgba(255,255,255,.15);border:none;color:#fff;border-radius:50%;
  width:26px;height:26px;cursor:pointer;font-size:.7rem;
  display:flex;align-items:center;justify-content:center;transition:var(--ease);
}
#chatbot-close:hover{background:rgba(255,255,255,.28)}

#chatbot-msgs{
  flex:1;overflow-y:auto;padding:1rem .85rem;
  display:flex;flex-direction:column;gap:.55rem;background:var(--gray-50);
}
.cb-row{display:flex;gap:.5rem;align-items:flex-end;max-width:100%}
.cb-row.user{flex-direction:row-reverse}
.cb-av{
  width:26px;height:26px;border-radius:50%;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;font-size:.7rem;
  background:var(--pur-bg);color:var(--pur);border:1px solid var(--pur-b);
}
.cb-row.user .cb-av{background:var(--pur);color:#fff;border-color:var(--pur)}
.cb-bubble{
  max-width:76%;padding:.55rem .82rem;border-radius:12px;
  font-size:.8rem;line-height:1.65;white-space:pre-line;
}
.cb-bubble.bot{background:var(--white);color:var(--t);border-bottom-left-radius:3px;box-shadow:var(--sh)}
.cb-bubble.user{background:var(--pur);color:#fff;border-bottom-right-radius:3px}
.cb-bubble a{color:inherit;text-decoration:underline}
.cb-bubble.bot a{color:var(--pur);font-weight:600}

.cb-typing{display:flex;gap:3px;padding:.6rem .85rem;background:var(--white);border-radius:12px;border-bottom-left-radius:3px;box-shadow:var(--sh);width:fit-content}
.cb-typing span{width:6px;height:6px;border-radius:50%;background:var(--pur-l);animation:cbTyping 1.2s infinite}
.cb-typing span:nth-child(2){animation-delay:.2s}
.cb-typing span:nth-child(3){animation-delay:.4s}
@keyframes cbTyping{0%,60%,100%{transform:translateY(0);opacity:.4}30%{transform:translateY(-4px);opacity:1}}

#chatbot-suggestions{
  display:flex;gap:.4rem;flex-wrap:wrap;padding:0 .85rem .7rem;flex-shrink:0;
}
.cb-chip{
  background:var(--white);border:1px solid var(--pur-b);color:var(--pur);
  font-size:.7rem;font-weight:600;padding:.32rem .75rem;border-radius:99px;
  cursor:pointer;transition:var(--ease);white-space:nowrap;font-family:var(--font);
}
.cb-chip:hover{background:var(--pur);color:#fff;border-color:var(--pur)}

#chatbot-in{display:flex;gap:.4rem;padding:.65rem;border-top:1px solid var(--bdr);background:var(--white);flex-shrink:0}
#chatbot-inp{flex:1;border:1px solid var(--bdr);border-radius:99px;padding:.55rem 1rem;font-size:.8rem;font-family:var(--font);outline:none;transition:var(--ease)}
#chatbot-inp:focus{border-color:var(--pur);box-shadow:0 0 0 3px rgba(107,33,168,.08)}
#chatbot-snd{
  background:var(--pur);color:#fff;border:none;border-radius:50%;
  width:38px;height:38px;flex-shrink:0;font-size:.85rem;cursor:pointer;
  display:flex;align-items:center;justify-content:center;transition:var(--ease);
}
#chatbot-snd:hover{background:var(--pur-m);transform:scale(1.06)}
#chatbot-snd:disabled{opacity:.5;cursor:default;transform:none}

@media(max-width:480px){
  #chatbot-box{width:calc(100vw - 24px);left:12px;right:12px;height:65vh}
  #chatbot-btn{left:14px;bottom:16px}
}

/* ════════════════════════════════════════════════════
   TIMETABLE
════════════════════════════════════════════════════ */
.timetable{width:100%;border-collapse:collapse;font-size:.8rem}
.timetable th{background:var(--pur-bg);color:var(--pur);padding:.7rem .45rem;text-align:center;font-weight:700;border:1px solid var(--pur-b);font-size:.73rem}
.timetable td{border:1px solid var(--bdr);padding:.32rem;vertical-align:top;min-width:108px;height:68px;background:var(--white)}
.timetable td.tc{background:var(--gray-50);font-weight:600;color:var(--t3);font-size:.7rem;text-align:center;vertical-align:middle;min-width:58px}
.tt-s{border-radius:var(--r-sm);padding:.28rem .42rem;font-size:.67rem;font-weight:600;margin-bottom:3px;cursor:pointer;transition:var(--ease)}
.tt-s.online{background:var(--tel-bg);color:var(--teal);border-right:2px solid var(--teal)}
.tt-s.presential{background:var(--pur-bg);color:var(--pur);border-right:2px solid var(--pur)}
.tt-s.hybrid{background:#ede9fe;color:#6d28d9;border-right:2px solid #7c3aed}
.tt-s.done{background:var(--grn-bg);color:var(--grn);border-right:2px solid var(--grn)}
.tt-legend{display:flex;gap:.7rem;flex-wrap:wrap;margin-bottom:.9rem}
.tt-leg{display:flex;align-items:center;gap:.28rem;font-size:.72rem;color:var(--t2)}
.tt-dot{width:9px;height:9px;border-radius:2px;flex-shrink:0}

/* ════════════════════════════════════════════════════
   UPLOAD
════════════════════════════════════════════════════ */
.upload-zone{border:2px dashed var(--bdr);border-radius:var(--r);padding:1.3rem;text-align:center;cursor:pointer;transition:var(--ease);background:var(--gray-50);position:relative}
.upload-zone:hover{border-color:var(--pur);background:var(--pur-bg)}
.upload-zone input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer}
.zone-label{font-size:.76rem;color:var(--t3)}

/* ════════════════════════════════════════════════════
   AUTH PAGE
════════════════════════════════════════════════════ */
.auth-wrap{min-height:100vh;background:linear-gradient(135deg,#1e1b4b 0%,var(--pur) 60%,var(--pur-m) 100%);display:flex;align-items:center;justify-content:center;padding:2rem 1rem}
.auth-card{background:var(--white);border-radius:var(--r-xl);box-shadow:var(--sh-xl);padding:2.2rem;width:100%;max-width:440px}
.auth-tabs{display:flex;gap:.3rem;background:var(--gray-100);padding:.25rem;border-radius:var(--r);margin-bottom:1.3rem}
.auth-tab,.auth-tab.on{flex:1;padding:.44rem;text-align:center;border-radius:var(--r-sm);font-size:.78rem;font-weight:600;cursor:pointer;border:none;font-family:var(--font);transition:var(--ease)}
.auth-tab{background:transparent;color:var(--t3)}
.auth-tab.on{background:var(--pur);color:#fff;box-shadow:var(--sh)}

/* ════════════════════════════════════════════════════
   LANDING PAGE — Edraak inspired
════════════════════════════════════════════════════ */
.lnav{height:64px;background:var(--white);border-bottom:1px solid var(--bdr);position:sticky;top:0;z-index:1000;box-shadow:0 1px 8px rgba(0,0,0,.06)}
.lhero{background:linear-gradient(135deg,#1e1b4b 0%,var(--pur) 55%,var(--pur-m) 100%);min-height:480px;display:flex;align-items:center;padding:3rem 0;position:relative;overflow:hidden}
.lhero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 15% 55%,rgba(255,255,255,.08) 0%,transparent 55%)}
.lhero h1{color:#fff;font-size:clamp(1.8rem,4vw,3rem);font-weight:900;line-height:1.18;margin-bottom:1rem}
.lstats{background:var(--pur-bg);border-top:1px solid var(--pur-b);border-bottom:1px solid var(--pur-b);padding:1.4rem 0}
.lsec{padding:4rem 0}
.lsec-tag{display:inline-block;background:var(--pur-bg);color:var(--pur);font-size:.65rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:.25rem .88rem;border-radius:99px;margin-bottom:.6rem;border:1px solid var(--pur-b)}
.course-card{background:var(--white);border-radius:var(--r-lg);border:1px solid var(--bdr);overflow:hidden;box-shadow:var(--sh);transition:var(--ease);display:flex;flex-direction:column}
.course-card:hover{transform:translateY(-3px);box-shadow:var(--sh-lg)}
.course-thumb{position:relative;height:165px;overflow:hidden;background:var(--gray-100)}
.course-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.course-card:hover .course-thumb img{transform:scale(1.05)}
.course-badge{position:absolute;top:8px;right:8px;background:var(--org);color:#fff;font-size:.6rem;font-weight:800;padding:3px 9px;border-radius:99px}
.course-body{padding:1rem;flex:1;display:flex;flex-direction:column;gap:.3rem}
.course-title{font-size:.86rem;font-weight:700;color:var(--t);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.course-meta{display:flex;gap:.52rem;flex-wrap:wrap}
.course-meta span{font-size:.67rem;color:var(--t3);display:flex;align-items:center;gap:.2rem}
.course-footer{padding:.78rem 1rem;border-top:1px solid var(--gray-100);display:flex;align-items:center;justify-content:space-between}
.course-price{font-size:1rem;font-weight:800;color:var(--pur)}
.course-price.free{color:var(--grn)}
.cat-pill{display:flex;align-items:center;gap:.38rem;padding:.4rem .95rem;border-radius:99px;background:var(--white);border:1px solid var(--bdr);color:var(--t2);font-size:.78rem;font-weight:600;cursor:pointer;transition:var(--ease);text-decoration:none}
.cat-pill:hover,.cat-pill.on{background:var(--pur);color:#fff;border-color:var(--pur)}
.feature-card{background:var(--white);border:1px solid var(--bdr);border-radius:var(--r-lg);padding:1.6rem 1.3rem;box-shadow:var(--sh);transition:var(--ease);text-align:center}
.feature-card:hover{transform:translateY(-3px);box-shadow:var(--sh-md);border-color:var(--pur-b)}
.feature-icon{width:52px;height:52px;border-radius:var(--r-lg);background:var(--pur-bg);display:flex;align-items:center;justify-content:center;font-size:1.3rem;color:var(--pur);margin:0 auto .8rem}
.feature-card h4{font-size:.93rem;font-weight:700;color:var(--t);margin-bottom:.35rem}
.feature-card p{font-size:.79rem;color:var(--t3);line-height:1.65;margin:0}
.inst-av{width:64px;height:64px;border-radius:50%;background:var(--pur-bg);border:2px solid var(--pur-b);display:flex;align-items:center;justify-content:center;font-size:1.4rem;font-weight:800;color:var(--pur);margin:0 auto .85rem}
.instructor-card{background:var(--white);border-radius:var(--r-lg);border:1px solid var(--bdr);padding:1.4rem;text-align:center;box-shadow:var(--sh);transition:var(--ease)}
.instructor-card:hover{transform:translateY(-3px);box-shadow:var(--sh-md)}
.faq-item{background:var(--white);border-radius:var(--r);border:1px solid var(--bdr);margin-bottom:.55rem;overflow:hidden;box-shadow:var(--sh)}
.faq-q{padding:.88rem 1.1rem;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:.5rem;transition:background .12s}
.faq-q:hover,.faq-item.open .faq-q{background:var(--pur-bg)}
.faq-q-text{font-weight:600;font-size:.85rem;color:var(--t);flex:1}
.faq-icon{width:22px;height:22px;border-radius:50%;background:var(--gray-100);display:flex;align-items:center;justify-content:center;font-size:.62rem;color:var(--pur);transition:transform .2s;flex-shrink:0}
.faq-item.open .faq-icon{transform:rotate(45deg);background:var(--pur);color:#fff}
.faq-a{max-height:0;overflow:hidden;transition:max-height .3s ease}
.faq-item.open .faq-a{max-height:300px}
.faq-a-inner{padding:.2rem 1.1rem .9rem;font-size:.83rem;color:var(--t2);line-height:1.7}

/* ════════════════════════════════════════════════════
   COMPAT ALIASES
════════════════════════════════════════════════════ */
.sc,.stat-card{background:var(--white);border:1px solid var(--bdr);border-radius:var(--r-lg);padding:1.15rem;display:flex;align-items:center;gap:.85rem;box-shadow:var(--sh);transition:var(--ease)}
.sc:hover,.stat-card:hover{transform:translateY(-2px);box-shadow:var(--sh-md)}
.sc-ico,.stat-ico,.stat-icon{width:44px;height:44px;border-radius:var(--r-lg);display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0}
.sc-ico.cp,.stat-ico.c-navy,.stat-icon.navy{background:var(--pur-bg);color:var(--pur)}
.sc-ico.cs{background:var(--tel-bg);color:var(--teal)}
.sc-ico.ca,.stat-ico.c-gold,.stat-icon.gold{background:var(--amb-bg);color:var(--amb)}
.sc-ico.ce,.stat-ico.c-red,.stat-icon.red{background:var(--red-bg);color:var(--red)}
.sc-ico.ck,.stat-icon.green{background:var(--grn-bg);color:var(--grn)}
.sc-v,.stat-value,.stat-v{font-size:1.7rem;font-weight:800;line-height:1;color:var(--t)}
.sc-l,.stat-label,.stat-l{font-size:.71rem;color:var(--t3);margin-top:.18rem}
.sc-trend{font-size:.62rem;font-weight:700;padding:2px 7px;border-radius:99px;display:inline-flex;align-items:center;gap:2px;margin-top:.28rem}
.sc-trend.up{background:var(--grn-bg);color:var(--grn)}.sc-trend.down{background:var(--red-bg);color:var(--red)}
.scard-ico.ind{background:var(--pur-bg);color:var(--pur)}
.sa-sec,.sa-section{background:var(--white);border:1px solid var(--bdr);border-radius:var(--r-lg);padding:1.15rem;margin-bottom:1.15rem;box-shadow:var(--sh)}
.sa-sec-title,.sa-section-title{font-size:.6rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--pur);margin-bottom:.85rem;display:flex;align-items:center;gap:.45rem}
.sa-sec-title::after,.sa-section-title::after{content:'';flex:1;height:1px;background:var(--bdr)}
.session-item{display:flex;align-items:center;gap:.78rem;padding:.74rem 1rem;border-radius:var(--r);border:1px solid var(--bdr);margin-bottom:.48rem;background:var(--white);transition:var(--ease)}
.session-item:hover{border-color:var(--pur);background:var(--pur-bg)}
.session-num{width:28px;height:28px;border-radius:50%;flex-shrink:0;background:var(--pur-bg);color:var(--pur);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.72rem}
.divider{height:1px;background:var(--bdr);margin:1rem 0}
.text-pri,.text-P,.text-navy{color:var(--pur)!important}
.text-amber,.text-gold,.text-A{color:var(--amb)!important}
.text-muted{color:var(--t2)!important}
.fw-600{font-weight:600!important}.fw-700{font-weight:700!important}.fw-800{font-weight:800!important}

/* ════════════════════════════════════════════════════
   ANIMATIONS
════════════════════════════════════════════════════ */
@keyframes fadeUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
.fade-up{animation:fadeUp .28s ease forwards}
.fu{animation:fadeUp .28s ease forwards}
.fu-1{animation-delay:.05s}.fu-2{animation-delay:.1s}.fu-3{animation-delay:.15s}.fu-4{animation-delay:.2s}

/* ════════════════════════════════════════════════════
   RESPONSIVE
════════════════════════════════════════════════════ */
@media(max-width:900px){
  .sidebar{transform:translateX(var(--sid-w));transition:transform .3s ease}
  .sidebar.open{transform:translateX(0)}
  .topbar{right:0}
  .main-wrap{margin-right:0;padding:calc(var(--top-h)+1rem) 1rem 1.5rem}
}
@media print{
  .sidebar,.topbar,#chatbot-btn,#chatbot-box{display:none!important}
  .main-wrap{margin:0!important;padding:0!important}
}
