/*
 * eba-style.css — أكاديمية العلم والبيان
 * Shared Design System v1.0
 * 
 * This file contains ALL shared styles across EBA pages.
 * Each page only needs: <link href="eba-style.css" rel="stylesheet">
 * Then add page-specific CSS in a <style> block.
 *
 * Logo sizes: 62px desktop → 50px tablet → 44px mobile
 * Navbar:  72px desktop → 60px tablet → 56px mobile
 * 
 * Last updated: 2026-02-24
 */

/* ============================================================
   1. FONT FACE
   ============================================================ */
@font-face{
  font-family:'Montaser Arabic';
  src:url('Montaser_Arabic.otf') format('opentype'),
      url('fonts/MontaserArabic-Regular.otf') format('opentype');
  font-weight:400;font-style:normal;font-display:swap
}
@font-face{
  font-family:'Montaser Arabic';
  src:url('fonts/MontaserArabic-Bold.otf') format('opentype');
  font-weight:700;font-style:normal;font-display:swap
}

/* ============================================================
   2. CSS VARIABLES
   ============================================================ */
:root{
  /* Navy palette */
  --navy:#233e72;
  --navy-d:#1a2f5a;
  --navy-dp:#0e1f3d;
  --navy-l:#2c4d8a;
  --navy-m:#3a5a94;
  /* Gold palette */
  --gold:#d5ae61;
  --gold-l:#e8ca8e;
  --gold-p:#f5ebd6;
  --gold-d:#b8943e;
  --gold-g:rgba(213,174,97,.10);
  /* Surfaces */
  --bg:#f8f6f2;
  --card:#ffffff;
  --card-h:#fdfcfa;
  --glass:rgba(255,255,255,.85);
  --glass-d:rgba(255,255,255,.95);
  /* Text */
  --tx-h:#151310;
  --tx-p:#2d2a25;
  --tx-s:#6b645b;
  --tx-m:#9e9688;
  /* Borders */
  --brd:#e8e4de;
  --brd-h:#cdc7bd;
  --brd-s:rgba(0,0,0,.035);
  --brd-l:#f0f2f7;
  /* Semantic */
  --success:#10b981;
  --danger:#ef4444;
  --warning:#f59e0b;
  --info:#06b6d4;
  /* Shadows */
  --sh-1:0 1px 3px rgba(17,31,56,.04);
  --sh-2:0 4px 16px rgba(17,31,56,.06);
  --sh-3:0 12px 40px rgba(17,31,56,.08);
  --sh-4:0 24px 64px rgba(17,31,56,.12);
  --sh-glow:0 0 60px rgba(213,174,97,.06);
  --sh-card:0 1px 3px rgba(17,31,56,.03),0 0 0 1px var(--brd-s);
  --sh-card-h:0 24px 48px -8px rgba(17,31,56,.10),0 0 0 1px rgba(17,31,56,.04);
  /* Fonts */
  --fd:'Montaser Arabic','Tajawal',sans-serif;
  --fb:'Tajawal',sans-serif;
  /* Easings */
  --ease:cubic-bezier(.25,.1,.25,1);
  --eout:cubic-bezier(.16,1,.3,1);
  --esp:cubic-bezier(.34,1.4,.64,1);
  --transition:all .3s cubic-bezier(.4,0,.2,1);
  /* Radii */
  --r-s:8px;
  --r-m:12px;
  --r-l:16px;
  --r-x:20px;
  --r-2:24px
}

/* ============================================================
   3. RESET & BASE
   ============================================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
*{-webkit-tap-highlight-color:transparent}
html{scroll-behavior:smooth;scroll-padding-top:80px;min-width:320px;-webkit-text-size-adjust:100%;text-size-adjust:100%}
body{
  font-family:var(--fb);
  background:var(--bg);
  color:var(--tx-p);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  min-height:100vh;
  min-width:320px;
  overflow-x:hidden;
  -webkit-text-size-adjust:100%;
  -ms-text-size-adjust:100%;
  touch-action:pan-x pan-y;
  -webkit-overflow-scrolling:touch;
  position:relative
}
/* Decorative background — grid pattern */
body::before{
  content:'';position:fixed;inset:0;z-index:0;pointer-events:none;
  opacity:.015;overflow:hidden;
  background-image:linear-gradient(var(--gold) .5px,transparent .5px),linear-gradient(90deg,var(--gold) .5px,transparent .5px);
  background-size:52px 52px
}
/* Decorative background — orb glows */
body::after{
  content:'';position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden;
  background:
    radial-gradient(600px circle at 85% 10%,rgba(213,174,97,.06),transparent 70%),
    radial-gradient(500px circle at 5% 90%,rgba(35,62,114,.04),transparent 70%),
    radial-gradient(300px circle at 40% 50%,rgba(213,174,97,.03),transparent 70%)
}
/* Prevent iOS zoom on inputs */
input,select,textarea{font-size:16px !important}

/* ============================================================
   4. NAVBAR — Fixed header variant (sub-pages)
   ============================================================ */
.header{
  background:#fff;
  border-bottom:1px solid var(--brd);
  position:fixed;
  top:0;left:0;right:0;
  z-index:1000;
  padding-top:env(safe-area-inset-top);
  transition:var(--transition)
}
.header.scrolled{box-shadow:0 4px 24px rgba(17,31,56,.06)}
.header::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--gold),var(--navy),transparent);
  opacity:0;transition:opacity .6s var(--eout)
}
.header.scrolled::after{opacity:.15}

.nav-container{
  max-width:1440px;margin:0 auto;
  padding:0 2rem;
  display:flex;align-items:center;justify-content:space-between;
  height:72px;gap:.75rem;overflow:visible
}

/* ============================================================
   5. NAVBAR — Sticky variant (dashboard)
   ============================================================ */
.tnav{
  background:#ffffff;
  backdrop-filter:blur(24px) saturate(1.4);
  -webkit-backdrop-filter:blur(24px) saturate(1.4);
  border-bottom:1px solid var(--brd);
  padding:0 2rem;
  padding-top:env(safe-area-inset-top);
  height:72px;
  display:flex;align-items:center;justify-content:space-between;
  position:sticky;top:0;z-index:100;
  transition:all .45s var(--eout);
  gap:.75rem;overflow:visible
}
.tnav.scrolled{box-shadow:0 4px 24px rgba(17,31,56,.06);background:#ffffff;height:68px}
.tnav::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--gold),var(--navy),transparent);
  opacity:0;transition:opacity .6s var(--eout)
}
.tnav.scrolled::after{opacity:.15}
.tnav-l{display:flex;align-items:center}
.tnav-r{display:flex;align-items:center;gap:.5rem}

/* ============================================================
   6. LOGO
   ============================================================ */
.logo-link{display:flex;align-items:center;text-decoration:none;min-width:0}
.logo-link img{
  height:62px;width:auto;max-width:240px;
  object-fit:contain;
  filter:drop-shadow(0 2px 12px rgba(17,31,56,.06));
  transition:all .45s var(--eout)
}
.logo-link img:hover{
  filter:drop-shadow(0 4px 20px rgba(213,174,97,.12));
  transform:scale(1.03)
}

/* ============================================================
   7. NAV BUTTONS
   ============================================================ */
.nav-actions{display:flex;align-items:center;gap:.5rem;flex-shrink:0}
.nb{
  background:var(--card);border:1px solid var(--brd);border-radius:10px;
  padding:.42rem .9rem;cursor:pointer;
  transition:all .35s var(--eout);
  display:inline-flex;align-items:center;gap:.45rem;
  color:var(--tx-s);font-size:.78rem;font-weight:600;
  font-family:var(--fb);white-space:nowrap;
  text-decoration:none;position:relative;overflow:hidden
}
.nb:hover{border-color:var(--brd-h);color:var(--navy);box-shadow:var(--sh-2);transform:translateY(-1px)}

/* ============================================================
   8. USER MENU
   ============================================================ */
.um{position:relative}
.um-t,.um-trigger{
  display:flex;align-items:center;gap:.45rem;
  background:var(--card);border:1px solid var(--brd);
  border-radius:50px;padding:.3rem .75rem .3rem .3rem;
  cursor:pointer;transition:all .35s var(--eout);
  font-weight:600;font-size:.8rem;color:var(--tx-p);
  font-family:inherit;flex-shrink:0
}
.um-t:hover,.um-trigger:hover{background:var(--card-h);box-shadow:var(--sh-2);border-color:var(--brd-h)}
.um-av,.um-avatar{
  width:30px;height:30px;border-radius:50%;
  background:linear-gradient(135deg,var(--navy),var(--navy-m));
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-weight:800;font-size:.72rem;
  box-shadow:0 2px 6px rgba(35,62,114,.15)
}

/* Dropdown */
.um-dd,.um-dropdown{
  position:absolute;top:calc(100% + 8px);left:0;
  background:var(--card);border:1px solid var(--brd);
  border-radius:var(--r-x);box-shadow:var(--sh-4);
  min-width:240px;opacity:0;visibility:hidden;
  transform:translateY(-8px) scale(.96);
  transition:all .3s var(--eout);z-index:1000;overflow:hidden
}
.um-dd.show,.um-dropdown.show{opacity:1;visibility:visible;transform:translateY(0) scale(1)}

.um-dd-h,.um-dd-header{
  padding:1.2rem;
  background:linear-gradient(150deg,var(--navy-dp),var(--navy));
  color:#fff;position:relative;overflow:hidden
}
.um-dd-h::after,.um-dd-header::after{
  content:'';position:absolute;bottom:-15px;left:-15px;
  width:70px;height:70px;
  background:radial-gradient(circle,rgba(213,174,97,.18),transparent 65%);
  border-radius:50%
}
.um-dd-av,.um-dd-avatar{
  width:44px;height:44px;border-radius:50%;
  background:rgba(255,255,255,.12);
  display:flex;align-items:center;justify-content:center;
  font-size:1.3rem;font-weight:800;margin-bottom:.4rem;
  border:2px solid rgba(213,174,97,.25);color:#fff
}
.um-dd-nm,.um-dd-name{font-family:var(--fd);font-weight:700;font-size:.95rem;color:#fff}
.um-dd-rl,.um-dd-role{font-size:.72rem;opacity:.6;margin-top:.1rem;color:#fff}

.um-dd-mn,.um-dd-menu{padding:.45rem}
.um-dd-i,.um-dd-item{
  display:flex;align-items:center;gap:.65rem;
  padding:.6rem .75rem;color:var(--tx-p);text-decoration:none;
  transition:all .3s var(--eout);font-size:.82rem;
  border-radius:var(--r-m);font-weight:500
}
.um-dd-i i,.um-dd-item i{width:16px;text-align:center;color:var(--tx-m);font-size:.78rem;transition:.2s}
.um-dd-i:hover,.um-dd-item:hover{background:var(--card-h);color:var(--navy)}
.um-dd-i:hover i,.um-dd-item:hover i{color:var(--gold)}
.um-dd-i.lo,.um-dd-item.logout{color:#dc2626;margin-top:.2rem}
.um-dd-i.lo:hover,.um-dd-item.logout:hover{background:rgba(220,38,38,.04)}
.um-dd-i.lo i,.um-dd-item.logout i{color:#dc2626}

/* ============================================================
   9. PAGE HERO (sub-pages) — matches admin_d.php quality
   ============================================================ */
.page-hero{
  background:linear-gradient(155deg,var(--navy-dp) 0%,var(--navy) 45%,var(--navy-l) 100%);
  border-radius:var(--r-2);padding:2rem 2.5rem;
  margin-bottom:2rem;position:relative;overflow:hidden;color:#fff;
  box-shadow:var(--sh-3);
  animation:heroAppear .8s var(--eout) both
}
/* Grid overlay */
.page-hero::before{
  content:'';position:absolute;inset:0;z-index:0;
  opacity:.025;
  background-image:linear-gradient(var(--gold) .5px,transparent .5px),linear-gradient(90deg,var(--gold) .5px,transparent .5px);
  background-size:28px 28px
}
/* Gold radial glow */
.page-hero::after{
  content:'';position:absolute;top:-50%;left:40%;
  width:450px;height:450px;
  background:radial-gradient(circle,rgba(213,174,97,.1),transparent 65%);
  border-radius:50%;pointer-events:none;z-index:0
}
@keyframes heroAppear{from{opacity:0;transform:translateY(16px) scale(.995)}to{opacity:1;transform:none}}
.page-hero h1{font-family:var(--fd);font-size:clamp(1.7rem,3vw,2.25rem);line-height:1.2;position:relative;z-index:2}
.page-hero p{opacity:.85;position:relative;z-index:2;font-size:1rem}
.gold-line{width:60px;height:3px;background:var(--gold);border-radius:3px;margin:1rem 0;position:relative;z-index:2}

/* ============================================================
   10. SECTION HEADERS
   ============================================================ */
.sec-hd{display:flex;align-items:center;gap:.65rem;margin-bottom:1.75rem}
.sec-hd-ico{
  width:36px;height:36px;border-radius:var(--r-s);
  background:var(--gold-p);display:flex;align-items:center;
  justify-content:center;color:var(--gold-d);font-size:.9rem
}
.sec-hd h2{font-family:var(--fd);font-size:1.4rem;color:var(--tx-h);font-weight:900}
.sec-hd-ln{flex:1;height:1px;background:linear-gradient(90deg,var(--brd),transparent);margin-right:.75rem}

/* ============================================================
   11. STATS GRID
   ============================================================ */
.stats-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(200px,1fr));
  gap:1rem;margin-bottom:2rem
}
.stat-card{
  background:var(--card);border-radius:var(--r-m);
  padding:1.25rem;border:1px solid var(--brd);
  display:flex;align-items:center;gap:1rem;
  transition:var(--transition)
}
.stat-card:hover{transform:translateY(-2px);box-shadow:var(--sh-2)}
.stat-icon{
  width:48px;height:48px;border-radius:var(--r-m);
  background:linear-gradient(135deg,var(--navy),var(--navy-l));
  display:flex;align-items:center;justify-content:center;
  color:var(--gold-l);font-size:1.2rem;flex-shrink:0
}
.stat-info h3{font-size:1.5rem;font-weight:800;color:var(--navy);margin:0}
.stat-info p{font-size:.8rem;color:var(--tx-s);margin:0}

/* ============================================================
   12. CARDS
   ============================================================ */
.eba-card{
  background:var(--card);border-radius:var(--r-l);
  box-shadow:var(--sh-1);border:1px solid var(--brd);
  margin-bottom:1.5rem;overflow:hidden
}
.eba-card-header{
  padding:1.25rem 1.5rem;border-bottom:1px solid var(--brd);
  display:flex;align-items:center;justify-content:space-between
}
.eba-card-header h2{
  font-size:1.1rem;font-weight:700;color:var(--navy);margin:0;
  display:flex;align-items:center;gap:8px
}
.eba-card-body{padding:1.5rem}

/* ============================================================
   13. BUTTONS
   ============================================================ */
.btn-eba{
  display:inline-flex;align-items:center;gap:6px;
  padding:10px 20px;border-radius:8px;font-weight:600;
  font-size:.9rem;border:none;cursor:pointer;
  transition:var(--transition);font-family:inherit;text-decoration:none
}
.btn-navy{background:var(--navy);color:#fff}
.btn-navy:hover{background:var(--navy-d);color:#fff;transform:translateY(-1px);box-shadow:var(--sh-2)}
.btn-gold{background:var(--gold);color:var(--navy-dp)}
.btn-gold:hover{background:var(--gold-d);color:#fff;transform:translateY(-1px)}
.btn-danger-eba{background:var(--danger);color:#fff}
.btn-danger-eba:hover{background:#dc2626;color:#fff}
.btn-secondary-eba{background:#6b7280;color:#fff}
.btn-secondary-eba:hover{color:#fff}
.btn-sm-eba{padding:6px 12px;font-size:.8rem}
.btn-white{background:var(--card);color:var(--navy);border:1px solid var(--brd);box-shadow:var(--sh-card)}
.btn-white:hover{border-color:var(--navy);box-shadow:var(--sh-2);transform:translateY(-2px)}

/* ============================================================
   14. FORMS
   ============================================================ */
.form-control-eba,.form-select-eba{
  border:2px solid var(--brd);border-radius:8px;
  padding:10px 14px;font-size:.9rem;font-family:inherit;
  width:100%;background:var(--card);color:var(--tx-p)
}
.form-control-eba:focus,.form-select-eba:focus{
  border-color:var(--gold);
  box-shadow:0 0 0 3px rgba(213,174,97,.15);
  outline:none
}
.form-label-eba{
  font-weight:600;font-size:.85rem;margin-bottom:6px;
  display:flex;align-items:center;gap:6px
}

/* ============================================================
   15. TABLES
   ============================================================ */
.eba-table{width:100%;border-collapse:separate;border-spacing:0}
.eba-table thead th{
  background:var(--navy);color:#fff;
  padding:12px 14px;font-weight:600;font-size:.82rem;
  text-align:center;white-space:nowrap
}
.eba-table thead th:first-child{border-radius:0 8px 0 0}
.eba-table thead th:last-child{border-radius:8px 0 0 0}
.eba-table tbody td{
  padding:10px 14px;border-bottom:1px solid var(--brd-l);
  text-align:center;font-size:.85rem;vertical-align:middle
}
.eba-table tbody tr:hover{background:rgba(35,62,114,.03)}

/* ============================================================
   16. BADGES
   ============================================================ */
.badge-eba{
  display:inline-flex;align-items:center;gap:4px;
  padding:4px 12px;border-radius:50px;
  font-size:.75rem;font-weight:600;border:1px solid
}
.badge-active{background:#ecfdf5;color:#065f46;border-color:#a7f3d0}
.badge-inactive{background:#fef2f2;color:#991b1b;border-color:#fecaca}
.badge-tahseel-yes{background:rgba(213,174,97,.15);color:var(--gold-d);border-color:rgba(213,174,97,.3)}
.badge-tahseel-no{background:var(--bg);color:var(--tx-m);border-color:var(--brd)}

/* ============================================================
   17. ALERTS
   ============================================================ */
.alert-eba{
  border-radius:var(--r-m);padding:1rem 1.25rem;
  margin-bottom:1.5rem;display:flex;align-items:center;
  gap:10px;font-weight:500;animation:slideDown .4s ease
}
.alert-success-eba{background:#ecfdf5;border:1px solid #a7f3d0;color:#065f46}
.alert-error-eba{background:#fef2f2;border:1px solid #fecaca;color:#991b1b}
@keyframes slideDown{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}

/* ============================================================
   18. MODALS
   ============================================================ */
/* Bootstrap modal overrides */
.modal-content{border-radius:var(--r-l);border:none;overflow:hidden}
.modal-header-eba{
  background:linear-gradient(135deg,var(--navy),var(--navy-l));
  color:#fff;padding:1.25rem 1.5rem;border:none
}
.modal-header-eba .modal-title{font-weight:700;display:flex;align-items:center;gap:8px}
.modal-header-eba .btn-close{filter:brightness(0) invert(1);opacity:.7}
.modal-body{padding:1.5rem}
.modal-footer{border-top:1px solid var(--brd);padding:1rem 1.5rem}

/* Custom modal (non-Bootstrap) */
.modal-eba{
  position:fixed;top:0;left:0;width:100%;height:100%;
  background:rgba(0,0,0,.5);display:none;
  justify-content:center;align-items:center;
  z-index:1050;backdrop-filter:blur(5px)
}
.modal-eba.show{display:flex}
.modal-eba .m-dialog{max-width:600px;width:90%;margin:2rem}
.modal-eba .m-content{
  border-radius:var(--r-l);border:none;overflow:hidden;
  box-shadow:0 24px 64px rgba(17,31,56,.15);
  animation:modalIn .3s ease
}
.modal-eba .m-header{
  background:linear-gradient(135deg,var(--navy),var(--navy-l));
  color:#fff;padding:1.25rem 1.5rem;
  display:flex;align-items:center;justify-content:space-between
}
.modal-eba .m-title{font-weight:700;font-size:1.05rem;display:flex;align-items:center;gap:8px}
.modal-eba .m-close{
  background:rgba(255,255,255,.15);border:none;border-radius:50%;
  width:32px;height:32px;color:#fff;cursor:pointer;
  transition:var(--transition);display:flex;align-items:center;justify-content:center
}
.modal-eba .m-close:hover{background:rgba(255,255,255,.3)}
.modal-eba .m-body{padding:1.5rem;background:var(--card);max-height:70vh;overflow-y:auto}
.modal-eba .m-footer{
  border-top:1px solid var(--brd);padding:1rem 1.5rem;
  background:var(--card);display:flex;justify-content:flex-end;gap:.75rem
}
@keyframes modalIn{from{opacity:0;transform:scale(.9) translateY(-20px)}to{opacity:1;transform:scale(1) translateY(0)}}

/* ============================================================
   19. EMPTY STATE
   ============================================================ */
.empty-state{text-align:center;padding:3rem 2rem;color:var(--tx-m)}
.empty-state i{font-size:3rem;opacity:.3;margin-bottom:1rem;display:block}
.empty-state p{font-size:1rem}

/* ============================================================
   20. ACTIONS GRID
   ============================================================ */
.actions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem}
.action-item{
  background:var(--bg);border:2px solid var(--brd);border-radius:var(--r-m);
  padding:1.25rem;cursor:pointer;transition:var(--transition);text-align:center
}
.action-item:hover{border-color:var(--gold);transform:translateY(-3px);box-shadow:var(--sh-2)}
.act-icon{
  width:50px;height:50px;
  background:linear-gradient(135deg,var(--navy),var(--navy-l));
  color:var(--gold-l);border-radius:var(--r-m);
  display:flex;align-items:center;justify-content:center;
  margin:0 auto .75rem;font-size:1.5rem
}
.action-item h5{font-size:.95rem;font-weight:700;margin-bottom:4px}
.action-item p{font-size:.8rem;color:var(--tx-s);margin:0}

/* ============================================================
   21. FOOTER — Unified across all pages
   ============================================================ */
.eba-footer{
  background:linear-gradient(135deg,var(--navy),var(--navy-l));
  color:#fff;padding:1.75rem 2rem;margin-top:3rem;text-align:center;
  position:relative;overflow:hidden
}
.eba-footer::before{
  content:'';position:absolute;top:-50%;right:-10%;
  width:400px;height:400px;
  background:radial-gradient(circle,rgba(213,174,97,.08),transparent 70%);
  border-radius:50%
}
.eba-footer p{margin:0;opacity:.8;font-size:.85rem;position:relative;z-index:1}
.eba-footer .powered{margin-top:.4rem;opacity:.6;font-size:.78rem;position:relative;z-index:1;display:flex;align-items:center;justify-content:center;gap:.4rem}
.eba-footer .powered strong{color:var(--gold)}
.eba-footer .powered img{height:20px;opacity:.7;transition:.3s;vertical-align:middle}
.eba-footer .powered img:hover{opacity:1}
.eba-footer .version{display:inline-flex;background:rgba(255,255,255,.1);padding:.1rem .5rem;border-radius:14px;font-size:.62rem;font-weight:700;letter-spacing:.04em;margin-top:.35rem;position:relative;z-index:1}

/* ============================================================
   22. CONTAINER
   ============================================================ */
.container-xl{max-width:1440px;margin:0 auto;padding:0 2rem}

/* ============================================================
   23. UTILITY ANIMATIONS
   ============================================================ */
@keyframes fadeUp{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}
@keyframes slideIn{from{transform:translateX(40px);opacity:0}to{transform:translateX(0);opacity:1}}
@keyframes slideOut{from{transform:translateX(0);opacity:1}to{transform:translateX(40px);opacity:0}}
.reveal{opacity:0;transform:translateY(20px);transition:all .6s var(--eout)}
.reveal.shown{opacity:1;transform:none}

/* ============================================================
   24. LOADING SCREEN
   ============================================================ */
.loading{
  position:fixed;inset:0;background:var(--bg);z-index:10000;
  display:flex;align-items:center;justify-content:center;
  transition:opacity .5s,visibility .5s
}
.loading.done{opacity:0;visibility:hidden}
.loader{width:48px;height:48px;border:3px solid var(--brd);border-radius:50%;border-top-color:var(--navy);animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* ============================================================
   25. RESPONSIVE — TABLET (≤1024px)
   ============================================================ */
@media(max-width:1024px){
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .actions-grid{grid-template-columns:repeat(2,1fr)}
}

/* ============================================================
   26. RESPONSIVE — MOBILE (≤768px)
   ============================================================ */
@media(max-width:768px){
  /* Navbar */
  .nav-container{padding:0 .75rem;height:60px;gap:.5rem}
  .tnav{padding:0 .75rem;height:60px;gap:.5rem}
  .logo-link img{height:50px;max-width:180px}

  /* User menu — RTL-safe: keep left:0 so dropdown opens toward screen center */
  .um-t span,.um-trigger span{display:none}
  .um-t,.um-trigger{padding:.3rem}
  .um-dd,.um-dropdown{min-width:200px;max-width:min(240px,calc(100vw - 2rem));left:0;right:auto;border-radius:14px}
  .um-dd-h,.um-dd-header{padding:.85rem}
  .um-dd-av,.um-dd-avatar{width:36px;height:36px;font-size:1rem;margin-bottom:.3rem}
  .um-dd-nm,.um-dd-name{font-size:.85rem}
  .um-dd-rl,.um-dd-role{font-size:.65rem}
  .um-dd-mn,.um-dd-menu{padding:.35rem}
  .um-dd-i,.um-dd-item{padding:.5rem .65rem;font-size:.78rem;gap:.5rem}
  .nb span{display:none}
  .nb{padding:.42rem .55rem}

  /* Container */
  .container-xl{padding:0 1rem}

  /* Page hero */
  .page-hero{padding:1.25rem 1.15rem;border-radius:var(--r-m)}
  .page-hero h1{font-size:1.3rem}
  .page-hero p{font-size:.85rem}
  .gold-line{width:45px;margin:.75rem 0}

  /* Stats */
  .stats-grid{grid-template-columns:1fr 1fr;gap:.75rem}
  .stat-card{padding:1rem;gap:.75rem}
  .stat-icon{width:42px;height:42px;font-size:1rem}
  .stat-info h3{font-size:1.3rem}
  .stat-info p{font-size:.72rem}

  /* Actions */
  .actions-grid{grid-template-columns:1fr 1fr;gap:.75rem}
  .action-item{padding:1rem}
  .act-icon{width:42px;height:42px;font-size:1.2rem;margin-bottom:.5rem}
  .action-item h5{font-size:.85rem}
  .action-item p{font-size:.72rem}

  /* Cards */
  .eba-card-header{padding:1rem;flex-wrap:wrap;gap:.5rem}
  .eba-card-header h2{font-size:1rem}
  .eba-card-body{padding:1rem}

  /* Tables */
  .eba-table thead th{padding:8px 6px;font-size:.72rem}
  .eba-table tbody td{padding:8px 6px;font-size:.78rem}
  .btn-sm-eba{padding:5px 8px;font-size:.72rem}

  /* Forms */
  .form-control-eba,.form-select-eba{padding:8px 12px}

  /* Modal */
  .modal-eba .m-dialog{margin:.75rem;width:95%}
  .modal-dialog{margin:.5rem}

  /* Footer */
  .eba-footer{padding:1.25rem 1rem;margin-top:2rem}
  .eba-footer p{font-size:.78rem}
  .eba-footer .powered{font-size:.72rem}

  /* Section headers */
  .sec-hd h2{font-size:1.1rem}
  .sec-hd-ico{width:30px;height:30px;font-size:.8rem}
}

/* ============================================================
   27. RESPONSIVE — SMALL PHONES (≤480px)
   ============================================================ */
@media(max-width:480px){
  /* Navbar */
  .nav-container{padding:0 .6rem;height:56px;gap:.35rem}
  .tnav{padding:0 .6rem;height:56px;gap:.35rem}
  .logo-link img{height:44px;max-width:160px}

  /* User menu — iOS compact, RTL-safe positioning */
  .um-dd,.um-dropdown{min-width:180px;max-width:min(220px,calc(100vw - 1.5rem));left:0;right:auto;border-radius:14px}
  .um-dd-h,.um-dd-header{padding:.75rem}
  .um-dd-av,.um-dd-avatar{width:32px;height:32px;font-size:.9rem;margin-bottom:.25rem}
  .um-dd-nm,.um-dd-name{font-size:.8rem}
  .um-dd-rl,.um-dd-role{font-size:.6rem}
  .um-dd-mn,.um-dd-menu{padding:.3rem}
  .um-dd-i,.um-dd-item{padding:.45rem .6rem;font-size:.75rem;gap:.45rem;border-radius:8px}
  .um-dd-i i,.um-dd-item i{font-size:.7rem}

  /* Container */
  .container-xl{padding:0 .75rem}

  /* Page hero */
  .page-hero{padding:1.25rem 1rem;border-radius:8px}
  .page-hero h1{font-size:1.1rem}
  .page-hero p{font-size:.8rem}
  .gold-line{width:40px;height:2px;margin:.75rem 0}

  /* Stats */
  .stats-grid{grid-template-columns:1fr;gap:.6rem}
  .stat-card{padding:.85rem}

  /* Actions */
  .actions-grid{grid-template-columns:1fr;gap:.6rem}
  .action-item{padding:.85rem}

  /* Cards */
  .eba-card{border-radius:8px}
  .eba-card-header{padding:.85rem}
  .eba-card-body{padding:.85rem}

  /* Tables */
  .eba-table thead th{padding:6px 4px;font-size:.68rem}
  .eba-table tbody td{padding:6px 4px;font-size:.72rem}
  .badge-eba{font-size:.65rem;padding:3px 8px}

  /* Empty state */
  .empty-state{padding:2rem 1rem}
  .empty-state i{font-size:2.5rem}
  .empty-state p{font-size:.9rem}

  /* Modal */
  .modal-eba .m-body{padding:1rem}
  .modal-eba .m-footer{padding:.75rem 1rem}
  .modal-body{padding:1rem}
  .modal-footer{padding:.75rem 1rem}

  /* Footer */
  .eba-footer{padding:1rem .75rem;margin-top:1.5rem}
  .eba-footer p{font-size:.72rem}
  .eba-footer .powered{font-size:.65rem;gap:.3rem}
  .eba-footer .version{font-size:.58rem;padding:.08rem .4rem}
}

/* ============================================================
   28. RTL DROPDOWN FIX — HIGH SPECIFICITY OVERRIDE
   Ensures dropdown stays on-screen on mobile in RTL layout.
   Uses !important to override duplicate page-specific styles.
   ============================================================ */
@media(max-width:768px){
  html[dir="rtl"] .um .um-dd,
  html[dir="rtl"] .um .um-dropdown{
    left:0 !important;
    right:auto !important;
    min-width:200px !important;
    max-width:min(240px,calc(100vw - 2rem)) !important;
    border-radius:14px !important;
  }
}
@media(max-width:480px){
  html[dir="rtl"] .um .um-dd,
  html[dir="rtl"] .um .um-dropdown{
    min-width:180px !important;
    max-width:min(220px,calc(100vw - 1.5rem)) !important;
  }
}

/* ============================================================
   29. REDUCED MOTION
   ============================================================ */
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.01ms!important;transition-duration:.01ms!important}
}