@import url('https://fonts.googleapis.com/css2?family=El+Messiri:wght@400..700&display=swap');
/* Edu Dashboard System v14 — unified RTL design system for admin / teacher / student panels */
:root{
  --bg:#f5f7fb;
  --surface:#ffffff;
  --surface-2:#f8fafc;
  --surface-3:#eef2ff;
  --text:#101827;
  --text-soft:#526070;
  --muted:#7b8794;
  --line:#e6eaf2;
  --primary:#7c3cff;
  --primary-2:#2563eb;
  --primary-3:#a855f7;
  --accent:#06b6d4;
  --success:#10b981;
  --danger:#ef4444;
  --warning:#f59e0b;
  --info:#0ea5e9;
  --shadow-sm:0 10px 24px rgba(15,23,42,.06);
  --shadow:0 18px 48px rgba(15,23,42,.10);
  --shadow-lg:0 28px 80px rgba(30,41,59,.16);
  --radius-xl:30px;
  --radius-lg:24px;
  --radius:18px;
  --radius-sm:14px;
  --sidebar:276px;
  --content-max:1480px;
  --font:"El Messiri", sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:
  radial-gradient(circle at 12% 6%,rgba(124,60,255,.13),transparent 30%),
  radial-gradient(circle at 90% 0%,rgba(6,182,212,.12),transparent 32%),
  linear-gradient(180deg,var(--bg),#fff 180%);color:var(--text);font-family:var(--font);line-height:1.62;min-height:100vh;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto}
button,input,select,textarea{font:inherit}
::selection{background:rgba(124,60,255,.18)}
.ltr{direction:ltr;unicode-bidi:embed;text-align:left}
.muted,small{color:var(--muted)}
.is-hidden{display:none!important}

/* Shared buttons */
button,.btn,.portal-file,.ui-clear-search{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:0;border-radius:15px;padding:11px 18px;min-height:44px;background:linear-gradient(135deg,var(--primary),var(--primary-2));color:#fff;font-weight:900;letter-spacing:-.01em;cursor:pointer;box-shadow:0 12px 25px rgba(124,60,255,.22);transition:transform .18s ease,box-shadow .18s ease,background .18s ease,opacity .18s ease;white-space:nowrap}
button:hover,.btn:hover,.portal-file:hover,.ui-clear-search:hover{transform:translateY(-1px);box-shadow:0 18px 34px rgba(124,60,255,.27)}
button:active,.btn:active{transform:translateY(0)}
button.light,.btn.light,.light,button[type="reset"]{background:var(--surface-2)!important;color:var(--text)!important;border:1px solid var(--line)!important;box-shadow:none!important}
button.good,.btn.good,.good:not(.pill):not(.status){background:linear-gradient(135deg,#13c296,#16a34a)!important;color:#fff!important}
button.danger,.btn.danger,.danger:not(.pill):not(.status),.ui-action-list .danger{background:linear-gradient(135deg,#fb7185,#ef4444)!important;color:#fff!important}
button.tiny,.btn.tiny,.tiny{min-height:34px;padding:7px 11px;border-radius:12px;font-size:.82rem}
button[aria-busy="true"],form.is-submitting button{opacity:.72;pointer-events:none}

/* Form system */
input,select,textarea{width:100%;border:1px solid var(--line);background:var(--surface);color:var(--text);border-radius:15px;padding:12px 14px;outline:none;transition:border-color .18s ease,box-shadow .18s ease,background .18s ease;min-height:46px}
textarea{min-height:112px;resize:vertical}
input:focus,select:focus,textarea:focus{border-color:rgba(124,60,255,.68);box-shadow:0 0 0 4px rgba(124,60,255,.12)}
label{display:flex;align-items:center;gap:8px;font-weight:900;color:var(--text-soft);font-size:.92rem;margin-bottom:7px}
label input[type="checkbox"]{width:18px;height:18px;min-height:auto;accent-color:var(--primary)}
.panel-form{display:grid;grid-template-columns:repeat(12,minmax(0,1fr));gap:14px;align-items:end}
.field{grid-column:span 4;min-width:0}.field.two{grid-column:span 6}.field.full{grid-column:1/-1}.field.actions,.actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.compact-form .field{grid-column:span 6}.compact-form .field.full{grid-column:1/-1}
.ui-select-filter{grid-column:1/-1;display:flex;align-items:center;gap:8px;margin-bottom:-3px}.ui-select-search{min-height:38px;padding:8px 12px}.ui-select-filter small{font-size:.78rem;white-space:nowrap}

/* Admin layout */
.app{width:100%;min-height:100vh;display:grid;grid-template-columns:var(--sidebar) minmax(0,1fr);gap:0}
.sidebar{position:sticky;top:0;height:100vh;padding:22px 18px;background:rgba(255,255,255,.76);backdrop-filter:blur(18px);border-left:1px solid rgba(226,232,240,.75);box-shadow:8px 0 28px rgba(15,23,42,.05);overflow:auto;z-index:20}
.brand,.teacher-brand{display:flex;align-items:center;gap:12px;margin-bottom:22px}.brand-mark,.teacher-brand span,.portal-brand{width:48px;height:48px;border-radius:16px;display:grid;place-items:center;background:linear-gradient(135deg,var(--primary),var(--primary-2));color:#fff;font-weight:1000;box-shadow:0 15px 35px rgba(124,60,255,.25)}
.brand h1,.brand b{margin:0;font-size:1.08rem}.brand small,.teacher-brand small{display:block;color:var(--muted);font-weight:800;font-size:.8rem}
.sidebar-nav-group{border:1px solid transparent;border-radius:18px;margin:4px 0 10px;overflow:hidden}.sidebar-group-title{display:flex;align-items:center;justify-content:space-between;gap:8px;list-style:none;padding:10px 12px;color:var(--muted);font-weight:1000;font-size:.79rem;text-transform:none;cursor:pointer}.sidebar-group-title::-webkit-details-marker{display:none}.sidebar-nav-group[open] .sidebar-group-title{color:var(--text)}.sidebar-group-links{display:grid;gap:5px;padding:0 0 8px}
.nav-link,.teacher-sidebar nav a{position:relative;display:flex;align-items:center;justify-content:space-between;gap:8px;min-height:46px;border-radius:15px;padding:10px 12px;margin:2px 0;color:var(--text-soft);font-weight:900;transition:.18s ease}.nav-link::before,.teacher-sidebar nav a::before{content:attr(data-icon);width:30px;height:30px;border-radius:11px;display:grid;place-items:center;background:var(--surface-2);margin-left:4px}.nav-link:hover,.nav-link.active,.teacher-sidebar nav a:hover,.teacher-sidebar nav a.active{background:linear-gradient(135deg,rgba(124,60,255,.13),rgba(37,99,235,.10));color:var(--primary);box-shadow:var(--shadow-sm)}
.badge,.pill,.status,.student-code,.code{display:inline-flex;align-items:center;justify-content:center;gap:5px;border-radius:999px;background:var(--surface-3);color:var(--primary);font-weight:1000;font-size:.78rem;padding:4px 10px;border:1px solid rgba(124,60,255,.14);white-space:nowrap}.code{direction:ltr;unicode-bidi:embed;background:#eef2ff;color:#4338ca}.pill.good,.status.present{background:rgba(16,185,129,.12);color:#059669;border-color:rgba(16,185,129,.18)}.pill.bad,.status.absent,.status.late_blocked{background:rgba(239,68,68,.12);color:#dc2626;border-color:rgba(239,68,68,.18)}.pill.warn,.status.late,.status.excused{background:rgba(245,158,11,.12);color:#d97706;border-color:rgba(245,158,11,.18)}
.logout{margin-top:18px;padding-top:16px;border-top:1px solid var(--line);display:grid;gap:8px}.logout a{display:flex;padding:10px 12px;border-radius:14px;color:var(--text-soft);font-weight:900;background:var(--surface-2)}.logout a:last-child{color:#ef4444;background:rgba(239,68,68,.08)}
.main{min-width:0;padding:20px 24px 44px;width:100%;max-width:var(--content-max);margin:0 auto}.topbar{position:sticky;top:14px;z-index:15;display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:20px;padding:13px 16px;border:1px solid rgba(226,232,240,.8);border-radius:24px;background:rgba(255,255,255,.76);backdrop-filter:blur(16px);box-shadow:var(--shadow-sm)}.topbar-info,.toolbar{display:flex;align-items:center;gap:10px;min-width:0}.admin-chip{background:var(--surface-3);color:var(--primary);padding:8px 12px;border-radius:999px;font-weight:1000}.smart-search,#global-search{min-width:min(380px,45vw);background:var(--surface-2)}.mobile-nav-toggle,.teacher-mobile-nav-toggle{display:none;min-width:44px;padding:9px 12px;background:var(--surface-2)!important;color:var(--text)!important;border:1px solid var(--line)!important;box-shadow:none!important}
.workspace-section{display:none;animation:fadeUp .22s ease}.workspace-section.active{display:block}.section-head,.panel-head,.card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin:0 0 16px}.section-head h2,.panel-head h2{margin:0;font-size:1.55rem;letter-spacing:-.04em}.section-head h3,.panel-head h3,.card h3,.card-soft h3{margin:0 0 10px;font-size:1.12rem;letter-spacing:-.025em}.section-head p,.panel-head p{margin:5px 0 0;color:var(--muted);max-width:760px}.grid{display:grid;grid-template-columns:repeat(12,minmax(0,1fr));gap:16px}.col-12{grid-column:span 12}.col-8{grid-column:span 8}.col-7{grid-column:span 7}.col-6{grid-column:span 6}.col-5{grid-column:span 5}.col-4{grid-column:span 4}.card,.panel,.login-card,.student-header-card,.card-soft{background:rgba(255,255,255,.86);border:1px solid rgba(226,232,240,.86);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:20px;min-width:0}.premium-card{background:linear-gradient(180deg,rgba(255,255,255,.95),rgba(248,250,252,.9))}.admin-mini-grid,.stats-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-bottom:16px}.admin-mini-card,.stat-card,.stat{position:relative;overflow:hidden;background:var(--surface);border:1px solid var(--line);border-radius:22px;padding:18px;box-shadow:var(--shadow-sm)}.admin-mini-card::after,.stat-card::after,.stat::after{content:"";position:absolute;inset:auto -24px -30px auto;width:90px;height:90px;border-radius:50%;background:linear-gradient(135deg,rgba(124,60,255,.16),rgba(6,182,212,.12))}.admin-mini-card b,.stat-card b,.stat b{display:block;font-size:1.9rem;line-height:1;color:var(--text);letter-spacing:-.04em}.admin-mini-card span,.stat-card span,.stat span{display:block;margin-top:7px;color:var(--muted);font-weight:900}.quick-actions{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.quick-actions a{display:flex;align-items:center;gap:10px;border-radius:20px;padding:18px;background:linear-gradient(135deg,rgba(124,60,255,.10),rgba(37,99,235,.08));border:1px solid rgba(124,60,255,.12);font-weight:1000}.quick-actions .icon{width:40px;height:40px;border-radius:14px;display:grid;place-items:center;background:linear-gradient(135deg,var(--primary),var(--primary-2));color:#fff}

/* Cards, details and action dropdowns */
.editor,.ui-pretty-details,.student-drop,.application-card,.batch-panel{border:1px solid var(--line);border-radius:18px;background:var(--surface-2);margin:8px 0;overflow:visible}.editor>summary,.ui-pretty-details>summary,.student-drop>summary,.application-card>summary,.batch-header{display:flex;align-items:center;justify-content:space-between;gap:10px;list-style:none;cursor:pointer;padding:12px 14px;font-weight:1000;color:var(--text)}.editor>summary::-webkit-details-marker,.ui-pretty-details>summary::-webkit-details-marker,.student-drop>summary::-webkit-details-marker{display:none}.editor>summary::after,.student-drop>summary::after,.ui-pretty-details>summary::after{content:"⌄";transition:transform .2s ease;color:var(--muted)}.editor[open]>summary::after,.student-drop[open]>summary::after,.ui-pretty-details[open]>summary::after{transform:rotate(180deg)}.editor[open],.student-drop[open],.ui-pretty-details[open]{background:var(--surface);box-shadow:var(--shadow-sm)}.editor form,.ui-pretty-details form,.drop-body{padding:14px;border-top:1px solid var(--line)}
.ui-action-menu{position:relative;display:inline-block;overflow:visible!important}.ui-action-trigger{list-style:none;cursor:pointer;min-height:38px;border-radius:14px;padding:9px 14px;background:linear-gradient(135deg,var(--primary),var(--primary-2));color:#fff;font-weight:1000;box-shadow:0 12px 25px rgba(124,60,255,.22)}.ui-action-trigger::-webkit-details-marker{display:none}.ui-action-list{position:absolute;top:calc(100% + 8px);left:0;min-width:230px;background:var(--surface);border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow-lg);padding:9px;z-index:80;display:grid;gap:7px}.ui-open-up .ui-action-list{top:auto;bottom:calc(100% + 8px)}.ui-action-list form,.ui-action-list details,.ui-action-list a,.ui-action-list button{width:100%;margin:0!important}.ui-action-list button,.ui-action-list .btn,.ui-action-list summary{width:100%;justify-content:flex-start;min-height:38px;padding:8px 12px;border-radius:12px;box-shadow:none}.ui-action-list .editor{background:transparent;border:0;margin:0}.ui-action-list .editor>summary{background:var(--surface-2);padding:9px 12px}.ui-action-list .panel-form{grid-template-columns:repeat(2,1fr);padding:10px}.ui-action-list .field{grid-column:span 2}.ui-action-list .field.two{grid-column:span 1}

/* Tables */
.table-wrap{width:100%;overflow:auto;border:1px solid var(--line);border-radius:20px;background:var(--surface)}table{width:100%;border-collapse:separate;border-spacing:0;min-width:760px}th,td{padding:13px 14px;text-align:right;vertical-align:top;border-bottom:1px solid var(--line);font-size:.92rem}th{position:sticky;top:0;background:var(--surface-2);z-index:1;color:var(--text-soft);font-size:.82rem;text-transform:none;font-weight:1000}tr:last-child td{border-bottom:0}tbody tr:hover{background:rgba(124,60,255,.04)}.barcode{display:block;width:124px;max-height:44px;margin-top:6px;background:#fff;border-radius:8px;padding:3px}.ui-table-tools{display:flex;align-items:center;gap:10px;margin:0 0 10px}.ui-table-search{max-width:380px;background:var(--surface-2)}.ui-empty-row td,.empty{padding:18px;border:1px dashed var(--line);border-radius:16px;background:var(--surface-2);color:var(--muted);font-weight:900;text-align:center}.items,.clean-list{margin:0;padding:0;list-style:none;display:grid;gap:8px}.items li,.clean-list li,.dashboard-list .schedule-chip{border:1px solid var(--line);border-radius:16px;background:var(--surface-2);padding:10px 12px}

/* Attendance */
.subtabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px}.subtabs button{background:var(--surface-2)!important;color:var(--text)!important;border:1px solid var(--line)!important;box-shadow:none!important}.subtabs button.active{background:linear-gradient(135deg,var(--primary),var(--primary-2))!important;color:#fff!important}.subtab-panel{display:none}.subtab-panel.active{display:block}.attendance-scan-form{display:grid;grid-template-columns:1fr auto;gap:10px}.attendance-result{border-radius:18px;padding:16px;margin-top:12px;background:var(--surface-2);border:1px solid var(--line);font-weight:900}.attendance-result.success{background:rgba(16,185,129,.12);border-color:rgba(16,185,129,.24);color:#047857}.attendance-result.error{background:rgba(239,68,68,.10);border-color:rgba(239,68,68,.24);color:#dc2626}.attendance-result.warning{background:rgba(245,158,11,.12);border-color:rgba(245,158,11,.24);color:#d97706}.attendance-live-list{display:grid;gap:8px;margin:0;padding:0;list-style:none}.attendance-live-list li{padding:10px 12px;border:1px solid var(--line);border-radius:16px;background:var(--surface-2)}.kpi-row{display:flex;gap:8px;flex-wrap:wrap}

/* Teacher panel */
.teacher-app{display:grid;grid-template-columns:var(--sidebar) minmax(0,1fr);min-height:100vh}.teacher-sidebar{position:sticky;top:0;height:100vh;padding:22px 18px;background:rgba(255,255,255,.76);backdrop-filter:blur(18px);border-left:1px solid rgba(226,232,240,.75);overflow:auto}.teacher-sidebar nav{display:grid;gap:6px}.teacher-main{min-width:0;padding:22px 26px 48px;max-width:var(--content-max);width:100%;margin:0 auto}.teacher-topbar{position:sticky;top:14px;z-index:15;display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:18px;padding:14px 16px;border:1px solid var(--line);border-radius:26px;background:rgba(255,255,255,.78);backdrop-filter:blur(16px);box-shadow:var(--shadow-sm)}.teacher-topbar h1{margin:0;font-size:1.35rem}.teacher-topbar p{margin:2px 0 0;color:var(--muted)}.teacher-tools{display:flex;align-items:center;gap:10px}.teacher-tools input{min-width:320px;background:var(--surface-2)}.panel{margin-bottom:18px}.readonly-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.readonly-grid>div{border:1px solid var(--line);border-radius:18px;background:var(--surface-2);padding:13px}.readonly-grid .full{grid-column:1/-1}.readonly-grid span{display:block;color:var(--muted);font-weight:900;font-size:.8rem}.readonly-grid b{display:block;margin-top:4px}.mini-filter{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin-bottom:12px}.mini-filter button,.mini-filter .btn{width:auto}.accordion-list{display:grid;gap:9px}.student-drop summary small{display:block;color:var(--muted);font-weight:800}.drop-body.two-cols,.two-cols{display:grid;grid-template-columns:1fr 1.25fr;gap:14px}.info-card{border:1px solid var(--line);border-radius:18px;background:var(--surface-2);padding:14px}.grid-2{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:16px}.flash{border-radius:18px;padding:12px 14px;margin-bottom:14px;font-weight:1000;border:1px solid var(--line);background:var(--surface-2)}.flash.ok{background:rgba(16,185,129,.12);color:#047857}.flash.err,.flash.error{background:rgba(239,68,68,.10);color:#dc2626}

/* Student portal */
.portal-shell{max-width:1180px;width:calc(100% - 28px);margin:0 auto;padding:28px 0 44px}.portal-hero{position:relative;overflow:hidden;display:grid;grid-template-columns:auto 1fr;gap:14px;align-items:center;border-radius:32px;padding:26px;margin-bottom:18px;background:linear-gradient(135deg,#7c3cff,#2563eb 62%,#06b6d4);color:#fff;box-shadow:var(--shadow-lg)}.portal-hero::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 16% 0%,rgba(255,255,255,.28),transparent 26%),radial-gradient(circle at 88% 20%,rgba(255,255,255,.18),transparent 30%);pointer-events:none}.portal-back{position:absolute;top:16px;left:18px;z-index:1;background:rgba(255,255,255,.16);padding:8px 12px;border-radius:999px;font-weight:900}.portal-hero>div,.portal-brand{position:relative;z-index:1}.portal-kicker{display:inline-flex;padding:5px 10px;border-radius:999px;background:rgba(255,255,255,.18);font-weight:1000}.portal-hero h1{margin:8px 0 4px;font-size:2rem;letter-spacing:-.04em}.login-card{max-width:560px;margin:24px auto}.portal-login-form{display:grid;gap:12px}.student-header-card{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:14px}.student-header-card h2{margin:7px 0 3px}.student-actions{display:flex;gap:8px;flex-wrap:wrap}.stats-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.portal-grid{display:grid;grid-template-columns:repeat(12,minmax(0,1fr));gap:16px}.span-4{grid-column:span 4}.span-8{grid-column:span 8}.span-12{grid-column:span 12}.details-list{display:grid;grid-template-columns:auto 1fr;gap:8px 12px}.details-list dt{color:var(--muted);font-weight:900}.details-list dd{margin:0;font-weight:900}.booking-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.booking-item{border:1px solid var(--line);border-radius:18px;background:var(--surface-2);padding:14px}.booking-item b,.booking-item span,.booking-item small{display:block}.eval-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.eval-card{border:1px solid var(--line);border-radius:18px;background:var(--surface-2);padding:14px}.eval-date{font-weight:1000;color:var(--primary);margin-bottom:8px}.eval-pills{display:flex;gap:6px;flex-wrap:wrap}

/* Admin specific cards */
.teacher-card{display:grid;grid-template-columns:1.25fr 1fr 1fr;gap:14px;border:1px solid var(--line);border-radius:24px;background:var(--surface);padding:16px;margin-bottom:12px;box-shadow:var(--shadow-sm)}.teacher-title{display:flex;align-items:center;gap:10px}.avatar{width:48px;height:48px;border-radius:17px;display:grid;place-items:center;background:linear-gradient(135deg,var(--primary),var(--primary-2));color:#fff;font-weight:1000}.teacher-grid{display:grid;gap:12px}.application-card{padding:0}.application-summary{display:flex;align-items:center;justify-content:space-between;gap:12px}.application-actions{display:flex;gap:10px;flex-wrap:wrap}.codes-layout .code-create-card{position:sticky;top:110px;align-self:start}

@keyframes fadeUp{from{opacity:0;transform:translateY(7px)}to{opacity:1;transform:translateY(0)}}
@media(max-width:1180px){.field{grid-column:span 6}.col-7,.col-6,.col-5,.col-4,.col-8{grid-column:span 12}.teacher-card{grid-template-columns:1fr}.quick-actions{grid-template-columns:repeat(2,1fr)}.readonly-grid{grid-template-columns:repeat(2,1fr)}.grid-2{grid-template-columns:1fr}.eval-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:900px){:root{--sidebar:280px}.app,.teacher-app{display:block}.sidebar,.teacher-sidebar{position:fixed;top:0;right:0;width:min(86vw,300px);height:100vh;transform:translateX(105%);transition:transform .22s ease;box-shadow:-20px 0 60px rgba(15,23,42,.22);z-index:100}.admin-sidebar-open .sidebar,.teacher-sidebar.is-open,.teacher-sidebar-open .teacher-sidebar{transform:translateX(0)}.mobile-nav-toggle,.teacher-mobile-nav-toggle{display:inline-flex}.main,.teacher-main{padding:14px 12px 34px}.topbar,.teacher-topbar{top:8px;flex-wrap:wrap;border-radius:20px}.toolbar,.teacher-tools{width:100%;justify-content:stretch}.smart-search,#global-search,.teacher-tools input{min-width:0;flex:1}.admin-mini-grid,.stats-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.panel-form{grid-template-columns:1fr}.field,.field.two,.field.full,.compact-form .field{grid-column:1/-1}.mini-filter{grid-template-columns:1fr}.drop-body.two-cols,.two-cols{grid-template-columns:1fr}.portal-grid{grid-template-columns:1fr}.span-4,.span-8,.span-12{grid-column:1/-1}.student-header-card{display:grid}.booking-list{grid-template-columns:1fr}}
@media(max-width:650px){body{font-size:15px}.portal-shell{width:calc(100% - 18px);padding-top:12px}.portal-hero{grid-template-columns:1fr;padding:22px 18px;border-radius:24px}.portal-back{position:static;width:max-content;margin-bottom:8px}.portal-hero h1{font-size:1.45rem}.card,.panel,.login-card,.student-header-card,.card-soft{padding:14px;border-radius:20px}.section-head,.panel-head,.card-head{display:grid;gap:8px}.admin-mini-grid,.stats-grid{grid-template-columns:1fr}.quick-actions{grid-template-columns:1fr}.ui-table-tools{display:grid}.ui-table-search{max-width:none}.ui-stack-mobile{min-width:0}.ui-stack-mobile thead{display:none}.ui-stack-mobile tbody,.ui-stack-mobile tr,.ui-stack-mobile td{display:block;width:100%}.ui-stack-mobile tr{border:1px solid var(--line);border-radius:18px;margin:10px;padding:8px;background:var(--surface)}.ui-stack-mobile td{border:0;padding:8px 10px}.ui-stack-mobile td::before{content:attr(data-label);display:block;color:var(--muted);font-weight:1000;font-size:.76rem;margin-bottom:2px}.table-wrap{overflow:visible}.eval-grid{grid-template-columns:1fr}.details-list{grid-template-columns:1fr}.ui-action-list{left:auto;right:0;min-width:220px}.attendance-scan-form{grid-template-columns:1fr}}
@media print{.sidebar,.teacher-sidebar,.topbar,.teacher-topbar,.logout,.toolbar,.teacher-tools,.mobile-nav-toggle,.teacher-mobile-nav-toggle,.ui-table-tools{display:none!important}.app,.teacher-app{display:block}.main,.teacher-main{padding:0;max-width:none}.workspace-section{display:block!important}.card,.panel{box-shadow:none;break-inside:avoid}}

/* Attendance live monitor */
.attendance-monitor-body{min-height:100vh;background:linear-gradient(135deg,#0f172a,#1e1b4b 52%,#312e81);color:#fff}.attendance-monitor-screen{width:min(1180px,calc(100% - 28px));margin:0 auto;padding:28px 0 44px}.attendance-monitor-header{display:flex;justify-content:space-between;gap:18px;align-items:flex-start;margin-bottom:18px;padding:22px;border:1px solid rgba(255,255,255,.14);border-radius:30px;background:rgba(255,255,255,.10);backdrop-filter:blur(14px);box-shadow:0 30px 80px rgba(0,0,0,.25)}.attendance-monitor-header h1{margin:6px 0 4px;font-size:2rem}.attendance-monitor-label{display:inline-flex;border-radius:999px;background:rgba(255,255,255,.15);padding:5px 11px;font-weight:1000}.attendance-monitor-tools{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.attendance-monitor-date{direction:ltr;background:rgba(255,255,255,.12);border-radius:999px;padding:8px 12px;font-weight:1000}.attendance-monitor-latest,.attendance-monitor-list-card{border:1px solid rgba(255,255,255,.14);border-radius:30px;background:rgba(255,255,255,.12);backdrop-filter:blur(14px);padding:24px;margin-bottom:18px}.attendance-monitor-latest strong{display:block;font-size:2.3rem;letter-spacing:-.04em}.attendance-monitor-latest span{color:rgba(255,255,255,.72);font-weight:1000}.attendance-monitor-latest time{display:inline-flex;margin-top:6px;border-radius:999px;padding:6px 12px;background:rgba(255,255,255,.16);font-weight:1000}.attendance-monitor-list-head{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px}.attendance-monitor-list-head h2{margin:0}.attendance-monitor-list{display:grid;gap:10px;margin:0;padding:0;list-style:none}.attendance-monitor-list li{display:grid;grid-template-columns:1.2fr 1fr auto;gap:10px;align-items:center;padding:14px;border-radius:18px;background:rgba(255,255,255,.92);color:#111827}.attendance-monitor-student{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.attendance-monitor-student b{font-size:1.05rem}.attendance-monitor-lesson{color:#526070;font-weight:900}@media(max-width:760px){.attendance-monitor-header,.attendance-monitor-list-head{display:grid}.attendance-monitor-list li{grid-template-columns:1fr}.attendance-monitor-latest strong{font-size:1.55rem}}

/* Login pages */
.admin-login-body{min-height:100vh;display:grid;place-items:center;padding:22px;background:radial-gradient(circle at 16% 8%,rgba(124,60,255,.20),transparent 28%),linear-gradient(135deg,#f5f7fb,#eef2ff)}.login-shell{width:min(1050px,100%);display:grid;grid-template-columns:1.1fr .9fr;gap:18px;align-items:stretch}.login-hero,.login-card{border:1px solid rgba(226,232,240,.84);border-radius:32px;background:rgba(255,255,255,.82);backdrop-filter:blur(16px);box-shadow:var(--shadow);padding:30px}.login-hero{background:linear-gradient(135deg,#7c3cff,#2563eb);color:#fff;overflow:hidden;position:relative}.login-hero::after{content:"";position:absolute;inset:auto -50px -80px auto;width:260px;height:260px;border-radius:50%;background:rgba(255,255,255,.14)}.login-mark{width:62px;height:62px;border-radius:22px;display:grid;place-items:center;background:rgba(255,255,255,.16);font-weight:1000;margin-bottom:18px}.login-hero h1,.login-card h2{margin:0 0 8px;letter-spacing:-.04em}.login-hero p,.login-card p{color:inherit;opacity:.82}.login-features{display:grid;gap:10px;margin-top:22px}.login-feature{background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.12);border-radius:16px;padding:12px;font-weight:900}.login-card form{display:grid;gap:10px}.err,.alert.error{background:rgba(239,68,68,.10);color:#dc2626;border:1px solid rgba(239,68,68,.22);border-radius:16px;padding:12px;margin:10px 0}.hint,.alert.info{background:rgba(14,165,233,.10);color:#0369a1;border:1px solid rgba(14,165,233,.22);border-radius:16px;padding:12px;margin:10px 0}.back{display:inline-flex;margin-top:12px;color:var(--muted);font-weight:900}@media(max-width:800px){.login-shell{grid-template-columns:1fr}.login-hero,.login-card{padding:22px;border-radius:24px}}
.teacher-login-body{min-height:100vh;display:grid;place-items:center;padding:22px;background:radial-gradient(circle at 12% 4%,rgba(124,60,255,.18),transparent 28%),linear-gradient(135deg,#f5f7fb,#eef2ff)!important}.teacher-login-card{width:min(500px,100%);margin:auto}.teacher-login-card button{width:100%}.teacher-login-card .check{display:flex;align-items:center;gap:8px;margin-top:4px}.teacher-login-card .check input{width:18px;min-height:auto}.teacher-login-card .ltr{text-align:left}

/* =========================================================
   V15 Reference Dashboard Rebuild Layer
   Light luxury LMS/admin style inspired by the provided references.
   This layer intentionally overrides V14 visual choices without touching PHP names/IDs.
   ========================================================= */
:root{
  --v15-bg:#f4f7fd;
  --v15-bg2:#eef3ff;
  --v15-panel:#ffffff;
  --v15-panel-soft:#f8faff;
  --v15-text:#172033;
  --v15-soft:#6f7b91;
  --v15-muted:#9aa6ba;
  --v15-line:#e5eaf4;
  --v15-primary:#7b2ff7;
  --v15-primary2:#2f6df6;
  --v15-accent:#a855f7;
  --v15-blue:#2f80ed;
  --v15-green:#18b883;
  --v15-pink:#ec2f78;
  --v15-orange:#ffb020;
  --v15-red:#ef4444;
  --v15-shadow:0 18px 45px rgba(40,52,88,.10);
  --v15-shadow2:0 26px 70px rgba(52,66,112,.16);
  --v15-radius:26px;
  --v15-radius-sm:18px;
  --v15-sidebar:282px;
  --font:"Tajawal","Cairo","IBM Plex Sans Arabic","Segoe UI",Tahoma,Arial,sans-serif;
  --bg:var(--v15-bg)!important;
  --surface:var(--v15-panel)!important;
  --surface-2:var(--v15-panel-soft)!important;
  --surface-3:#f0e9ff!important;
  --text:var(--v15-text)!important;
  --text-soft:var(--v15-soft)!important;
  --muted:var(--v15-muted)!important;
  --line:var(--v15-line)!important;
  --primary:var(--v15-primary)!important;
  --primary-2:var(--v15-primary2)!important;
  --primary-3:var(--v15-accent)!important;
  --success:var(--v15-green)!important;
  --danger:var(--v15-red)!important;
  --warning:var(--v15-orange)!important;
  --shadow-sm:0 10px 28px rgba(38,50,86,.08)!important;
  --shadow:var(--v15-shadow)!important;
  --shadow-lg:var(--v15-shadow2)!important;
  --radius-xl:32px!important;
  --radius-lg:26px!important;
  --radius:20px!important;
  --radius-sm:16px!important;
  --sidebar:var(--v15-sidebar)!important;
  --content-max:1580px!important;
}
body{
  background:
    radial-gradient(circle at 8% 0%, rgba(123,47,247,.18), transparent 28%),
    radial-gradient(circle at 92% 7%, rgba(47,109,246,.16), transparent 30%),
    linear-gradient(135deg,#f7f9ff 0%,#eff4ff 50%,#f8faff 100%)!important;
  color:var(--text)!important;
  font-family:var(--font)!important;
  letter-spacing:-.01em;
}
body::before{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  background-image:linear-gradient(rgba(122,47,247,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(47,109,246,.035) 1px,transparent 1px);
  background-size:44px 44px;
  mask-image:linear-gradient(180deg,rgba(0,0,0,.55),transparent 55%);
  z-index:-1;
}

/* New reference layout */
.app{
  width:min(100%,1760px)!important;
  margin:0 auto!important;
  display:grid!important;
  grid-template-columns:var(--sidebar) minmax(0,1fr)!important;
  gap:24px!important;
  padding:18px 18px 28px!important;
  min-height:100vh!important;
}
.sidebar{
  position:sticky!important;
  top:18px!important;
  height:calc(100vh - 36px)!important;
  padding:18px 14px!important;
  background:rgba(255,255,255,.92)!important;
  color:var(--text)!important;
  border:1px solid rgba(228,234,246,.88)!important;
  border-radius:30px!important;
  box-shadow:0 28px 80px rgba(38,50,86,.12)!important;
  backdrop-filter:blur(22px)!important;
  overflow:auto!important;
  scrollbar-width:thin;
}
.sidebar::-webkit-scrollbar{width:5px}.sidebar::-webkit-scrollbar-thumb{background:#d4dbea;border-radius:999px}
.brand,.teacher-brand{
  margin:0 0 20px!important;
  padding:8px 8px 18px!important;
  border-bottom:1px solid var(--line)!important;
}
.brand-mark,.teacher-brand span,.portal-brand{
  width:48px!important;height:48px!important;border-radius:16px!important;
  background:linear-gradient(135deg,#8b5cf6,#2f6df6)!important;
  box-shadow:0 18px 34px rgba(123,47,247,.24)!important;
}
.brand h1,.brand b,.teacher-brand b{font-size:1.05rem!important;color:var(--text)!important;letter-spacing:-.03em!important}
.brand small,.teacher-brand small{font-size:.78rem!important;color:var(--muted)!important}
.sidebar-nav-group{
  margin:8px 0!important;
  border:0!important;
  border-radius:20px!important;
  background:transparent!important;
}
.sidebar-group-title{
  min-height:42px!important;
  color:#8893a7!important;
  padding:10px 12px!important;
  font-size:.78rem!important;
  font-weight:1000!important;
  letter-spacing:0!important;
}
.sidebar-group-title::after{content:"⌄";font-size:1rem;color:#a2aec1;transition:.18s ease}
.sidebar-nav-group[open] .sidebar-group-title::after{transform:rotate(180deg)}
.sidebar-group-links{gap:6px!important;padding:2px 0 8px!important}
.nav-link,.teacher-sidebar nav a{
  min-height:48px!important;
  border-radius:16px!important;
  padding:10px 12px!important;
  color:#526074!important;
  background:transparent!important;
  box-shadow:none!important;
  justify-content:flex-start!important;
  gap:10px!important;
  font-size:.96rem!important;
  position:relative!important;
}
.nav-link::before,.teacher-sidebar nav a::before{
  flex:0 0 36px!important;
  width:36px!important;height:36px!important;
  margin:0!important;
  border-radius:14px!important;
  background:#f2f5fb!important;
  color:#7a879a!important;
  font-size:1rem!important;
}
.nav-link .badge{margin-right:auto!important}
.nav-link:hover,.nav-link.active,.teacher-sidebar nav a:hover,.teacher-sidebar nav a.active{
  background:linear-gradient(135deg,#f1e9ff,#edf4ff)!important;
  color:#6d28d9!important;
  box-shadow:inset 0 0 0 1px rgba(123,47,247,.08),0 14px 30px rgba(123,47,247,.10)!important;
}
.nav-link:hover::before,.nav-link.active::before,.teacher-sidebar nav a:hover::before,.teacher-sidebar nav a.active::before{
  background:linear-gradient(135deg,#7b2ff7,#2f6df6)!important;color:#fff!important;
}
.logout{border-top:1px solid var(--line)!important;margin-top:16px!important;padding-top:14px!important}
.logout a{background:#f7f9fd!important;border:1px solid var(--line)!important;color:#536074!important;border-radius:15px!important;justify-content:center!important}.logout a:hover{color:#6d28d9!important;border-color:rgba(123,47,247,.25)!important}
.logout a:last-child{background:#fff1f3!important;color:#e11d48!important;border-color:#ffe0e8!important}

.main{
  max-width:100%!important;
  padding:0!important;
  min-width:0!important;
  margin:0!important;
}
.topbar,.teacher-topbar{
  position:sticky!important;top:18px!important;z-index:18!important;
  min-height:72px!important;
  padding:14px 18px!important;
  margin:0 0 22px!important;
  border:1px solid rgba(228,234,246,.88)!important;
  border-radius:26px!important;
  background:rgba(255,255,255,.88)!important;
  box-shadow:0 18px 45px rgba(38,50,86,.08)!important;
  backdrop-filter:blur(20px)!important;
}
.topbar-info,.toolbar,.teacher-tools{gap:12px!important;min-width:0!important}.toolbar{margin-right:auto!important}
.admin-chip{
  background:linear-gradient(135deg,#f0e9ff,#edf4ff)!important;
  color:#6d28d9!important;
  border:1px solid rgba(123,47,247,.12)!important;
  padding:9px 14px!important;
}
.smart-search,#global-search,.teacher-tools input{
  min-width:min(440px,42vw)!important;
  border-radius:16px!important;
  background:#f7f9fd!important;
  border:1px solid var(--line)!important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.7)!important;
}
.mobile-nav-toggle,.teacher-mobile-nav-toggle{border-radius:15px!important}

/* Headings as reference cards */
.workspace-section{display:none!important;animation:fadeUp .22s ease}.workspace-section.active{display:block!important}
.section-head,.panel-head,.card-head{
  align-items:center!important;
  margin-bottom:18px!important;
}
.section-head h2,.panel-head h2{
  font-size:1.52rem!important;
  font-weight:1000!important;
  margin:0!important;
  color:#172033!important;
}
.section-head p,.panel-head p{font-size:.95rem!important;color:#7a879a!important;margin-top:4px!important}

/* Dashboard hero and high quality blocks */
.dashboard-hero-v15{
  position:relative;
  overflow:hidden;
  border-radius:32px;
  padding:34px 34px 28px;
  min-height:230px;
  color:#fff;
  background:
    linear-gradient(115deg,rgba(117,38,242,.96),rgba(69,62,204,.92) 52%,rgba(32,94,222,.95)),
    radial-gradient(circle at 82% 18%,rgba(255,255,255,.22),transparent 24%);
  box-shadow:0 28px 80px rgba(72,63,204,.30);
  margin-bottom:22px;
}
.dashboard-hero-v15::before{content:"";position:absolute;inset:0;background:linear-gradient(105deg,transparent 0 35%,rgba(255,255,255,.10) 36% 40%,transparent 41% 48%,rgba(255,255,255,.12) 49% 52%,transparent 53%),radial-gradient(circle at 88% 25%,rgba(255,255,255,.18),transparent 17%);opacity:.8}
.dashboard-hero-v15::after{content:"✦";position:absolute;left:54px;top:50px;font-size:4.4rem;color:rgba(255,255,255,.20);filter:drop-shadow(0 12px 20px rgba(255,255,255,.2))}
.dashboard-hero-v15>*{position:relative;z-index:1}.dashboard-hero-v15 h2{margin:0 0 10px;font-size:2rem;line-height:1.25;color:#fff!important}.dashboard-hero-v15 p{margin:0 0 20px;color:rgba(255,255,255,.82);font-weight:800;max-width:650px}.hero-stats-v15{display:flex;gap:30px;flex-wrap:wrap}.hero-stats-v15 b{display:block;font-size:1.55rem;line-height:1;color:#fff}.hero-stats-v15 span{display:block;color:rgba(255,255,255,.78);font-weight:800;font-size:.9rem;margin-top:5px}.hero-actions-v15{display:flex;gap:10px;flex-wrap:wrap;margin-top:20px}.hero-actions-v15 .btn{background:rgba(255,255,255,.17)!important;border:1px solid rgba(255,255,255,.22)!important;box-shadow:none!important;color:#fff!important}.hero-actions-v15 .btn.good{background:#fff!important;color:#6d28d9!important;border-color:transparent!important}

.admin-mini-grid,.stats-grid{
  display:grid!important;
  grid-template-columns:repeat(4,minmax(0,1fr))!important;
  gap:18px!important;
  margin-bottom:22px!important;
}
.admin-mini-card,.stat-card,.stats-grid .stat-card{
  position:relative!important;
  min-height:124px!important;
  padding:22px!important;
  border:1px solid rgba(228,234,246,.88)!important;
  border-radius:24px!important;
  background:rgba(255,255,255,.92)!important;
  box-shadow:0 18px 45px rgba(38,50,86,.09)!important;
  overflow:hidden!important;
}
.admin-mini-card::after,.stat-card::after{content:"";position:absolute;left:18px;top:18px;width:54px;height:54px;border-radius:18px;background:linear-gradient(135deg,rgba(123,47,247,.14),rgba(47,109,246,.12));}
.admin-mini-card:nth-child(2)::after,.stat-card:nth-child(2)::after{background:linear-gradient(135deg,rgba(47,109,246,.16),rgba(14,165,233,.14))}.admin-mini-card:nth-child(3)::after,.stat-card:nth-child(3)::after{background:linear-gradient(135deg,rgba(24,184,131,.15),rgba(34,197,94,.12))}.admin-mini-card:nth-child(4)::after,.stat-card:nth-child(4)::after{background:linear-gradient(135deg,rgba(236,47,120,.14),rgba(255,176,32,.14))}
.admin-mini-card b,.stat-card b{font-size:2rem!important;font-weight:1000!important;letter-spacing:-.05em!important;color:#121a2d!important}.admin-mini-card span,.stat-card span{display:block!important;color:#7a879a!important;font-weight:900!important}.stat-card small{display:block!important;margin-top:8px!important;color:#a0aabc!important}
.grid{gap:18px!important}.card,.panel,.card-soft,.student-header-card,.login-card{
  background:rgba(255,255,255,.94)!important;
  border:1px solid rgba(228,234,246,.88)!important;
  border-radius:26px!important;
  box-shadow:0 18px 45px rgba(38,50,86,.09)!important;
  padding:22px!important;
}
.card:hover,.panel:hover{box-shadow:0 24px 62px rgba(38,50,86,.12)!important}
.card h3,.card-soft h3,.panel h3{font-size:1.08rem!important;font-weight:1000!important;color:#172033!important}.dashboard-list{display:grid!important;gap:10px!important}.schedule-chip,.info-card,.booking-item,.eval-card{
  background:#f8faff!important;
  border:1px solid #e7edf8!important;
  border-radius:18px!important;
  padding:14px!important;
}
.quick-actions{display:grid!important;grid-template-columns:repeat(4,minmax(0,1fr))!important;gap:14px!important}.quick-actions a{
  min-height:96px!important;
  background:linear-gradient(135deg,#f6f0ff,#edf4ff)!important;
  border:1px solid rgba(123,47,247,.12)!important;
  border-radius:22px!important;
  padding:18px!important;
  color:#172033!important;
  box-shadow:0 14px 34px rgba(38,50,86,.07)!important;
  font-weight:1000!important;
}.quick-actions a .icon{width:42px;height:42px;border-radius:16px;background:linear-gradient(135deg,#7b2ff7,#2f6df6);color:#fff;display:inline-grid;place-items:center;margin-left:8px}

/* Buttons */
button,.btn,.portal-file,.ui-clear-search{
  min-height:44px!important;
  border-radius:14px!important;
  padding:10px 17px!important;
  background:linear-gradient(135deg,#7b2ff7,#2f6df6)!important;
  color:#fff!important;
  border:0!important;
  box-shadow:0 12px 26px rgba(123,47,247,.20)!important;
  font-weight:1000!important;
}
button:hover,.btn:hover{transform:translateY(-1px)!important;box-shadow:0 18px 34px rgba(123,47,247,.24)!important}
button.light,.btn.light,.light,button[type="reset"]{background:#fff!important;color:#526074!important;border:1px solid var(--line)!important;box-shadow:none!important}
button.good,.btn.good,.good:not(.pill):not(.status){background:linear-gradient(135deg,#18b883,#27c96f)!important;color:#fff!important}
button.danger,.btn.danger,.danger:not(.pill):not(.status){background:linear-gradient(135deg,#ff5b7f,#ef4444)!important;color:#fff!important}
button.tiny,.btn.tiny,.tiny{min-height:34px!important;padding:7px 11px!important;border-radius:12px!important}
.badge,.pill,.status,.student-code,.code{border-radius:999px!important;background:#f0e9ff!important;color:#6d28d9!important;border:1px solid rgba(123,47,247,.10)!important;padding:5px 10px!important}.pill.good,.status.present{background:#e9fbf5!important;color:#079366!important;border-color:#c9f2e4!important}.pill.bad,.status.absent,.status.late_blocked{background:#fff0f3!important;color:#e11d48!important;border-color:#ffd5df!important}.pill.warn,.status.late,.status.excused{background:#fff7e6!important;color:#b7791f!important;border-color:#ffe5ad!important}.code{direction:ltr!important;unicode-bidi:embed!important;background:#edf4ff!important;color:#2457d6!important}

/* Forms: modern and compact */
input,select,textarea{
  min-height:48px!important;
  border-radius:15px!important;
  border:1px solid #dfe6f2!important;
  background:#fbfcff!important;
  color:#172033!important;
  padding:12px 14px!important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.75)!important;
}
textarea{min-height:118px!important}input:focus,select:focus,textarea:focus{border-color:#9b6cf6!important;box-shadow:0 0 0 4px rgba(123,47,247,.12)!important;background:#fff!important}
label{font-weight:1000!important;color:#6f7b91!important;margin-bottom:6px!important}.panel-form{gap:14px 16px!important;align-items:end!important}.field.full.actions,.field.actions,.actions{gap:10px!important}.field.full.actions{justify-content:flex-start!important}
input[type="checkbox"]{width:18px!important;height:18px!important;min-height:auto!important;accent-color:#7b2ff7!important}

/* Tables */
.table-wrap{
  border:1px solid #e5eaf4!important;
  border-radius:22px!important;
  overflow:auto!important;
  background:#fff!important;
  box-shadow:0 12px 30px rgba(38,50,86,.06)!important;
}
table{width:100%!important;border-collapse:separate!important;border-spacing:0!important;background:#fff!important;min-width:720px!important}thead th{
  background:#f8faff!important;
  color:#6f7b91!important;
  font-size:.86rem!important;
  font-weight:1000!important;
  padding:14px 16px!important;
  border-bottom:1px solid #e5eaf4!important;
  white-space:nowrap!important;
}td{padding:14px 16px!important;border-bottom:1px solid #edf1f8!important;color:#253149!important;vertical-align:middle!important}tbody tr:hover td{background:#faf7ff!important}tbody tr:last-child td{border-bottom:0!important}.ui-empty-row td,.empty{background:#f2f7ff!important;color:#5270a9!important;text-align:center!important;border-radius:16px!important;font-weight:900!important}.ui-table-tools{display:flex!important;gap:10px!important;justify-content:space-between!important;margin:0 0 12px!important}.ui-table-search{max-width:360px!important;background:#fff!important}

/* Dropdown action menu */
.ui-action-menu{position:relative!important;display:inline-block!important;z-index:10!important}.ui-action-trigger{
  list-style:none!important;cursor:pointer!important;min-height:38px!important;border-radius:13px!important;padding:8px 14px!important;background:linear-gradient(135deg,#f0e9ff,#edf4ff)!important;color:#6d28d9!important;font-weight:1000!important;border:1px solid rgba(123,47,247,.12)!important;box-shadow:none!important
}.ui-action-trigger::-webkit-details-marker{display:none}.ui-action-trigger::after{content:"⌄";margin-right:8px}.ui-action-list{
  position:absolute!important;top:calc(100% + 8px)!important;left:0!important;min-width:230px!important;background:#fff!important;border:1px solid #e5eaf4!important;border-radius:18px!important;padding:8px!important;box-shadow:0 26px 70px rgba(38,50,86,.18)!important;display:grid!important;gap:7px!important;z-index:999!important
}.ui-action-menu.ui-open-up .ui-action-list{top:auto!important;bottom:calc(100% + 8px)!important}.ui-action-list>*{width:100%!important;margin:0!important}.ui-action-list button,.ui-action-list .btn,.ui-action-list summary{width:100%!important;justify-content:flex-start!important;text-align:right!important;background:#f8faff!important;color:#526074!important;border:1px solid #edf1f8!important;box-shadow:none!important}.ui-action-list .danger, .ui-action-list button.danger{background:#fff0f3!important;color:#e11d48!important;border-color:#ffd5df!important}

/* Accordions and collapsible details */
.ui-pretty-details,.student-drop,details.editor{
  border:1px solid #e5eaf4!important;border-radius:20px!important;background:#fff!important;margin:10px 0!important;box-shadow:0 12px 30px rgba(38,50,86,.05)!important;overflow:hidden!important
}.ui-pretty-details>summary,.student-drop>summary,details.editor>summary{
  min-height:54px!important;padding:14px 16px!important;cursor:pointer!important;list-style:none!important;font-weight:1000!important;color:#253149!important;background:#fbfcff!important;display:flex!important;align-items:center!important;justify-content:space-between!important;gap:12px!important
}.ui-pretty-details>summary::-webkit-details-marker,.student-drop>summary::-webkit-details-marker,details.editor>summary::-webkit-details-marker{display:none}.ui-pretty-details>summary::after,.student-drop>summary::after,details.editor>summary::after{content:"⌄";color:#8e99ad}.ui-pretty-details[open]>summary::after,.student-drop[open]>summary::after,details.editor[open]>summary::after{transform:rotate(180deg)}.drop-body{padding:16px!important;background:#fff!important;border-top:1px solid #edf1f8!important}.drop-body.two-cols,.two-cols{grid-template-columns:1fr 1.1fr!important;gap:16px!important}.subtabs{background:#f8faff!important;border:1px solid #e5eaf4!important;border-radius:18px!important;padding:6px!important;display:flex!important;gap:6px!important;overflow:auto!important;margin-bottom:16px!important}.subtabs button{background:transparent!important;color:#6f7b91!important;box-shadow:none!important;border-radius:14px!important}.subtabs button.active{background:#fff!important;color:#6d28d9!important;box-shadow:0 10px 24px rgba(38,50,86,.08)!important}.mini-panel,.subtab-panel{display:none!important}.mini-panel.active,.subtab-panel.active{display:block!important}

/* Teacher panel */
.teacher-app{
  width:min(100%,1760px)!important;margin:0 auto!important;display:grid!important;grid-template-columns:var(--sidebar) minmax(0,1fr)!important;gap:24px!important;padding:18px!important;min-height:100vh!important
}.teacher-sidebar{position:sticky!important;top:18px!important;height:calc(100vh - 36px)!important;border-radius:30px!important;background:rgba(255,255,255,.92)!important;border:1px solid rgba(228,234,246,.88)!important;box-shadow:0 28px 80px rgba(38,50,86,.12)!important;padding:18px 14px!important;overflow:auto!important}.teacher-main{padding:0!important;min-width:0!important}.teacher-topbar h1{margin:0!important;font-size:1.5rem!important;color:#172033!important}.teacher-topbar p{margin:4px 0 0!important;color:#7a879a!important}.readonly-grid{display:grid!important;grid-template-columns:repeat(4,minmax(0,1fr))!important;gap:12px!important}.readonly-grid>div{background:#f8faff!important;border:1px solid #e5eaf4!important;border-radius:18px!important;padding:14px!important}.readonly-grid span{display:block!important;color:#8a95a8!important;font-weight:900!important}.readonly-grid b{display:block!important;color:#172033!important;margin-top:4px!important}.readonly-grid .full{grid-column:1/-1!important}.mini-filter{display:grid!important;grid-template-columns:1.4fr repeat(2, minmax(160px,.5fr))!important;gap:10px!important;margin-bottom:14px!important}.accordion-list{display:grid!important;gap:10px!important}.flash{border-radius:18px!important;border:1px solid #e5eaf4!important;background:#fff!important;box-shadow:0 14px 34px rgba(38,50,86,.08)!important;padding:14px 16px!important;margin-bottom:14px!important;font-weight:900!important}.flash.ok,.alert.success{background:#e9fbf5!important;color:#079366!important;border-color:#c9f2e4!important}.flash.err,.alert.error{background:#fff0f3!important;color:#e11d48!important;border-color:#ffd5df!important}
.teacher-card{grid-template-columns:1.2fr 1fr .9fr!important;border-radius:24px!important;background:#fff!important;border-color:#e5eaf4!important;box-shadow:0 18px 45px rgba(38,50,86,.08)!important}.avatar{background:linear-gradient(135deg,#7b2ff7,#2f6df6)!important;color:#fff!important;border-radius:16px!important}

/* Student portal */
.portal-shell{width:min(1180px,calc(100% - 28px))!important;margin:0 auto!important;padding:22px 0 48px!important}.portal-hero{border-radius:34px!important;padding:34px!important;min-height:250px!important;background:linear-gradient(115deg,#7b2ff7,#5846d9 58%,#2f6df6)!important;box-shadow:0 28px 80px rgba(72,63,204,.28)!important;color:#fff!important}.portal-hero::after{opacity:.45!important}.portal-hero h1{font-size:2.25rem!important;color:#fff!important}.portal-hero p{color:rgba(255,255,255,.82)!important}.student-header-card{border-radius:28px!important}.student-actions{display:flex!important;gap:10px!important;flex-wrap:wrap!important}.portal-grid{gap:18px!important}.details-list{gap:10px 14px!important}.details-list dt{color:#8a95a8!important;font-weight:1000!important}.details-list dd{color:#172033!important;font-weight:1000!important}

/* Login and monitor */
.admin-login-body,.teacher-login-body{background:radial-gradient(circle at 14% 8%,rgba(123,47,247,.16),transparent 28%),linear-gradient(135deg,#f7f9ff,#eff4ff)!important}.login-hero{background:linear-gradient(135deg,#7b2ff7,#2f6df6)!important;border-radius:34px!important}.login-card,.login-hero{box-shadow:0 28px 80px rgba(38,50,86,.14)!important}.attendance-monitor-body{background:linear-gradient(135deg,#151f33,#402489 55%,#2f6df6)!important}.attendance-monitor-header,.attendance-monitor-latest,.attendance-monitor-list-card{border-radius:32px!important;background:rgba(255,255,255,.13)!important}

/* Compatibility with older Smart Center style names found in some builds */
.admin-layout,.dashboard-layout,.smart-layout{background:var(--v15-bg)!important;color:var(--v15-text)!important}.admin-sidebar,.dashboard-sidebar,.side-menu,.admin-menu{background:rgba(255,255,255,.92)!important;color:var(--v15-text)!important;border:1px solid var(--v15-line)!important;border-radius:30px!important;box-shadow:var(--v15-shadow)!important}.admin-sidebar a,.dashboard-sidebar a,.side-menu a,.admin-menu a{color:#526074!important;border-radius:16px!important}.admin-sidebar a.active,.dashboard-sidebar a.active,.side-menu a.active,.admin-menu a.active{background:linear-gradient(135deg,#f1e9ff,#edf4ff)!important;color:#6d28d9!important}.content,.dashboard-content,.page-content{background:transparent!important}.box,.widget,.form-box,.table-box{background:#fff!important;border:1px solid var(--v15-line)!important;border-radius:26px!important;box-shadow:var(--v15-shadow)!important}.page-title,.content-title{color:#172033!important;font-weight:1000!important}.floating-help,.quick-setup,.setup-fast,.help-bubble{display:none!important}

@media(max-width:1180px){
  .admin-mini-grid,.stats-grid{grid-template-columns:repeat(2,minmax(0,1fr))!important}.quick-actions{grid-template-columns:repeat(2,minmax(0,1fr))!important}.readonly-grid{grid-template-columns:repeat(2,minmax(0,1fr))!important}.teacher-card{grid-template-columns:1fr!important}.col-8,.col-7,.col-6,.col-5,.col-4{grid-column:span 12!important}.drop-body.two-cols,.two-cols{grid-template-columns:1fr!important}
}
@media(max-width:900px){
  .app,.teacher-app{display:block!important;padding:12px!important}.sidebar,.teacher-sidebar{position:fixed!important;top:12px!important;right:12px!important;width:min(88vw,310px)!important;height:calc(100vh - 24px)!important;transform:translateX(115%)!important;transition:transform .24s ease!important;z-index:200!important}.admin-sidebar-open .sidebar,.teacher-sidebar.is-open,.teacher-sidebar-open .teacher-sidebar{transform:translateX(0)!important}.mobile-nav-toggle,.teacher-mobile-nav-toggle{display:inline-flex!important}.topbar,.teacher-topbar{top:10px!important;border-radius:22px!important;flex-wrap:wrap!important}.toolbar,.teacher-tools{width:100%!important;display:flex!important}.smart-search,#global-search,.teacher-tools input{min-width:0!important;flex:1!important}.dashboard-hero-v15{padding:26px 20px!important;border-radius:26px!important}.hero-stats-v15{gap:18px!important}.panel-form{grid-template-columns:1fr!important}.field,.field.two,.field.full{grid-column:1/-1!important}.mini-filter{grid-template-columns:1fr!important}
}
@media(max-width:650px){
  body{font-size:15px!important}.topbar-info,.toolbar,.teacher-tools{width:100%!important}.section-head,.panel-head,.card-head{display:grid!important;gap:10px!important}.dashboard-hero-v15 h2,.portal-hero h1{font-size:1.55rem!important}.admin-mini-grid,.stats-grid,.quick-actions,.readonly-grid{grid-template-columns:1fr!important}.card,.panel,.card-soft,.student-header-card,.login-card{padding:16px!important;border-radius:22px!important}.table-wrap{overflow:visible!important;background:transparent!important;border:0!important;box-shadow:none!important}table.ui-stack-mobile{min-width:0!important}.ui-stack-mobile thead{display:none!important}.ui-stack-mobile tbody,.ui-stack-mobile tr,.ui-stack-mobile td{display:block!important;width:100%!important}.ui-stack-mobile tr{background:#fff!important;border:1px solid #e5eaf4!important;border-radius:18px!important;margin:10px 0!important;padding:8px!important;box-shadow:0 12px 30px rgba(38,50,86,.06)!important}.ui-stack-mobile td{border:0!important;padding:8px 10px!important}.ui-stack-mobile td::before{content:attr(data-label);display:block!important;font-weight:1000!important;color:#8a95a8!important;font-size:.76rem!important}.ui-action-list{right:0!important;left:auto!important}.login-shell{grid-template-columns:1fr!important}.portal-shell{width:calc(100% - 18px)!important}.portal-hero{padding:24px 18px!important;border-radius:26px!important}.portal-grid{grid-template-columns:1fr!important}.span-4,.span-8,.span-12{grid-column:1/-1!important}
}

/* V31 FORCE EL MESSIRI FONT */
body.admin-area,
body.admin-area *,
body.admin-login-body,
body.admin-login-body *,
body.teacher-login-body,
body.teacher-login-body *,
body.admin-area button,
body.admin-area input,
body.admin-area select,
body.admin-area textarea,
body.admin-login-body button,
body.admin-login-body input,
body.admin-login-body select,
body.admin-login-body textarea,
body.teacher-login-body button,
body.teacher-login-body input,
body.teacher-login-body select,
body.teacher-login-body textarea {
  font-family: "El Messiri", sans-serif !important;
}
