:root{
  --bg:#f5f8ff;--panel:#ffffff;--ink:#102033;--muted:#667085;--line:#e4eaf4;
  --primary:#2263f5;--primary2:#11a7c8;--admin:#6d5dfc;--accent:#f6b93b;
  --danger:#dc2626;--success:#16a34a;--warning:#d97706;--shadow:0 22px 55px rgba(31,55,95,.13);
  --sidebar:#0f1b35;--sidebar2:#13264c;--sidebarText:#dbeafe;--sidebarMuted:#94a3b8;
}
*{box-sizing:border-box}html{height:100%}body{margin:0;min-height:100%;font-family:Inter,system-ui,-apple-system,Segoe UI,sans-serif;color:var(--ink);background:var(--bg);padding-bottom:42px}a{text-decoration:none;color:inherit}button,input,select,textarea{font:inherit}.material-symbols-outlined{font-size:20px;vertical-align:-4px}.app-bg,.login-bg{position:fixed;inset:0;z-index:-1;background:radial-gradient(circle at 10% 8%,rgba(34,99,245,.12),transparent 28%),radial-gradient(circle at 85% 12%,rgba(17,167,200,.13),transparent 30%),linear-gradient(135deg,#f8fbff,#eef5ff)}
/* Login */
.login-body{min-height:100vh;display:grid;place-items:center;padding:24px;background:#f5f8ff}.login-layout{width:min(1120px,100%);display:grid;grid-template-columns:1.05fr .95fr;gap:22px;align-items:stretch}.login-art{position:relative;min-height:640px;border-radius:36px;overflow:hidden;padding:28px;background:linear-gradient(145deg,#0d1b34,#143368 58%,#116e8b);box-shadow:var(--shadow);color:white;display:flex;flex-direction:column;justify-content:space-between}.login-art:before{content:"";position:absolute;inset:-40% -25% auto auto;width:520px;height:520px;border-radius:50%;background:rgba(255,255,255,.13);filter:blur(2px)}.login-art:after{content:"";position:absolute;left:40px;bottom:40px;width:260px;height:260px;border-radius:50%;background:linear-gradient(135deg,rgba(34,99,245,.25),rgba(17,167,200,.4));filter:blur(10px)}.back-parent{position:relative;z-index:2;display:inline-flex;gap:8px;align-items:center;width:max-content;color:#e0f2fe;background:rgba(255,255,255,.11);border:1px solid rgba(255,255,255,.2);border-radius:999px;padding:10px 14px;font-weight:800;backdrop-filter:blur(12px)}.hero-login-card{position:relative;z-index:2;margin-top:auto}.glass-card{border:1px solid rgba(255,255,255,.22);background:rgba(255,255,255,.12);backdrop-filter:blur(18px);box-shadow:0 24px 50px rgba(0,0,0,.18);border-radius:34px;padding:28px}.logo-mark{display:grid!important;width:62px;height:62px;place-items:center;border-radius:22px;background:rgba(255,255,255,.16);font-size:34px!important}.login-art h1{font-size:44px;letter-spacing:-.045em;line-height:1.04;margin:12px 0}.login-art p{color:#dbeafe;line-height:1.7}.mini-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:24px}.mini-stats span{padding:14px;border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.1);border-radius:20px}.mini-stats strong{display:block}.mini-stats small{color:#bfdbfe}.login-panel{display:grid;place-items:center}.login-card{width:min(470px,100%);background:white;border:1px solid var(--line);border-radius:34px;box-shadow:var(--shadow);padding:34px}.login-brand{display:flex;align-items:center;gap:14px;margin-bottom:26px}.brand-icon{display:grid!important;width:52px;height:52px;place-items:center;border-radius:18px;background:linear-gradient(135deg,var(--primary),var(--primary2));color:white;font-size:28px!important}.login-brand h2{margin:0;font-size:25px;letter-spacing:-.03em}.login-brand p{margin:3px 0 0;color:var(--muted);font-weight:700}.field-label{display:block;font-size:13px;font-weight:900;margin:14px 0 8px;color:#344054}.input-wrap{display:flex;align-items:center;gap:10px;border:1px solid var(--line);background:#f8fbff;border-radius:18px;padding:0 13px;transition:.2s}.input-wrap:focus-within{border-color:var(--primary);box-shadow:0 0 0 5px rgba(34,99,245,.1);background:white}.input-wrap input{border:0;outline:0;background:transparent;width:100%;min-height:50px}.inline-icon{border:0;background:transparent;cursor:pointer;color:var(--muted)}.login-meta{display:flex;justify-content:space-between;gap:12px;margin-top:18px;color:var(--muted);font-size:12px;font-weight:800}.login-minimal-note{display:flex;align-items:center;gap:8px;color:#64748b;font-size:12px;margin-top:14px}.login-minimal-note span{color:var(--success)}
/* Shell */
.staff-app{background:var(--bg)}.app-shell{display:grid;grid-template-columns:292px minmax(0,1fr);min-height:calc(100vh - 42px)}.sidebar{position:fixed;inset:0 auto 42px 0;width:292px;background:linear-gradient(180deg,var(--sidebar),var(--sidebar2));color:var(--sidebarText);display:flex;flex-direction:column;z-index:50;box-shadow:20px 0 45px rgba(15,27,53,.2)}.sidebar-brand{display:flex;align-items:center;justify-content:space-between;padding:20px 18px;border-bottom:1px solid rgba(255,255,255,.09)}.brand-block{display:flex;align-items:center;gap:12px;min-width:0}.brand-logo{display:grid!important;width:46px;height:46px;place-items:center;border-radius:17px;background:linear-gradient(135deg,var(--primary),var(--primary2));font-size:27px!important;color:white}.brand-block strong{display:block;font-size:16px}.brand-block small{display:block;color:var(--sidebarMuted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:150px;font-weight:700}.icon-btn{display:inline-grid;place-items:center;width:40px;height:40px;border:1px solid rgba(148,163,184,.2);background:rgba(255,255,255,.08);border-radius:14px;color:inherit;cursor:pointer}.sidebar-close{display:none}.sidebar-nav{padding:14px 12px 160px;overflow:auto;flex:1}.nav-group{margin-bottom:8px}.nav-group-toggle{width:100%;display:flex;align-items:center;gap:10px;border:0;background:transparent;color:#e5edff;border-radius:16px;padding:12px 11px;cursor:pointer;text-align:left}.nav-group-toggle:hover{background:rgba(255,255,255,.07)}.nav-group-toggle strong{flex:1;font-size:13px;text-transform:uppercase;letter-spacing:.08em}.nav-group-toggle i{transition:transform .22s}.nav-group.open .nav-group-toggle i{transform:rotate(180deg)}.nav-submenu{display:grid;grid-template-rows:0fr;transition:grid-template-rows .25s ease}.nav-group.open .nav-submenu{grid-template-rows:1fr}.nav-submenu:before{content:""}.nav-submenu{overflow:hidden}.nav-link{display:flex;align-items:center;gap:10px;margin:4px 0 4px 10px;padding:11px 10px;border-radius:16px;color:var(--sidebarText);position:relative;transition:.18s}.nav-link em{font-style:normal;flex:1;font-size:14px;font-weight:750}.nav-link:hover{background:rgba(255,255,255,.08);transform:translateX(2px)}.nav-link.active{background:linear-gradient(135deg,rgba(34,99,245,.95),rgba(17,167,200,.9));box-shadow:0 12px 26px rgba(34,99,245,.25);color:white}.nav-badge{min-width:22px;height:22px;border-radius:999px;background:#ef4444;color:white;display:inline-grid;place-items:center;font-size:11px;padding:0 6px}.sidebar-footer{position:absolute;left:12px;right:12px;bottom:14px;padding:12px;border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.07);backdrop-filter:blur(14px);border-radius:22px}.profile-mini{display:flex;align-items:center;gap:10px}.avatar{display:inline-grid;width:42px;height:42px;place-items:center;border-radius:15px;background:linear-gradient(135deg,#fff,#c7d2fe);color:#1e3a8a;font-weight:900}.profile-mini strong{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:180px}.profile-mini small{display:block;color:var(--sidebarMuted);font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:180px}.sidebar-actions{display:flex;gap:8px;margin-top:12px}.mini-action{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:5px;border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.08);border-radius:13px;padding:8px 6px;font-size:12px;font-weight:900}.mini-action.danger{color:#fecaca}.main-panel{grid-column:2;padding-bottom:36px;min-width:0}.mobile-topbar{display:none}.sidebar-backdrop{display:none}.page-hero{margin:24px auto 0;max-width:1380px;padding:24px 28px;display:flex;align-items:center;justify-content:space-between;gap:16px}.page-hero h1{font-size:34px;letter-spacing:-.04em;margin:2px 0 6px}.page-hero p{margin:0;color:var(--muted);line-height:1.55}.eyebrow{font-size:12px;text-transform:uppercase;letter-spacing:.12em;font-weight:900;color:var(--primary)!important}.content-wrap{max-width:1380px;margin:0 auto;padding:0 28px 28px}.fixed-footer{position:fixed;left:292px;right:0;bottom:0;height:42px;background:rgba(255,255,255,.88);backdrop-filter:blur(14px);border-top:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;gap:14px;padding:0 24px;color:var(--muted);font-size:12px;z-index:45}.fixed-footer strong{color:#334155}
/* General components */
.nx-card{background:rgba(255,255,255,.95);border:1px solid var(--line);border-radius:26px;box-shadow:0 14px 34px rgba(31,55,95,.08);padding:22px;margin-bottom:18px}.nx-card.soft{background:linear-gradient(135deg,#fff,#f8fbff)}.nx-card h2{font-size:21px;letter-spacing:-.025em;margin:0 0 14px}.nx-card h3{margin:18px 0 10px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;border:1px solid var(--line);background:#fff;color:#0f172a;border-radius:14px;padding:10px 14px;font-weight:900;cursor:pointer;min-height:40px}.btn.primary{background:linear-gradient(135deg,var(--primary),var(--primary2));border-color:transparent;color:white}.btn.danger{background:#fee2e2;border-color:#fecaca;color:#b91c1c}.btn.ghost{background:#f8fafc}.btn.wide{width:100%;margin-top:18px}.btn.tiny{min-height:32px;padding:6px 9px;border-radius:10px;font-size:12px}.actions,.inline-form{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.input{width:100%;min-height:42px;border:1px solid var(--line);border-radius:14px;background:#f8fafc;padding:10px 12px;outline:0}.input:focus{border-color:var(--primary);box-shadow:0 0 0 4px rgba(34,99,245,.1);background:white}.input.compact{min-height:36px;padding:6px 10px}.hint{color:var(--muted);font-size:12px}.alert{display:flex;align-items:flex-start;gap:10px;padding:14px 16px;border-radius:18px;margin-bottom:16px;border:1px solid}.alert.error{background:#fef2f2;color:#991b1b;border-color:#fecaca}.alert.success{background:#f0fdf4;color:#166534;border-color:#bbf7d0}.pill,.priority{display:inline-flex;align-items:center;padding:5px 9px;border-radius:999px;background:#f1f5f9;color:#334155;font-size:12px;font-weight:900;text-transform:capitalize}.pill.active{background:#dcfce7;color:#166534}.pill.expired,.pill.deleted{background:#fee2e2;color:#991b1b}.pill.draft{background:#fef3c7;color:#92400e}.priority.high{background:#fee2e2;color:#991b1b}.priority.medium{background:#fef3c7;color:#92400e}.priority.low{background:#dcfce7;color:#166534}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.grid-two{display:grid;grid-template-columns:1fr 1fr;gap:18px}.grid-two.wide-left{grid-template-columns:minmax(0,1.35fr) minmax(280px,.65fr)}.detail-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.detail-grid div{padding:14px;border:1px solid var(--line);border-radius:16px;background:#f8fafc;min-width:0}.detail-grid small{display:block;color:var(--muted);font-weight:900}.detail-grid strong{display:block;margin-top:5px;word-break:break-word}.filter-bar,.search-panel{display:flex;align-items:center;gap:10px;flex-wrap:wrap;background:#fff;border:1px solid var(--line);border-radius:24px;padding:14px;margin-bottom:18px;box-shadow:0 10px 25px rgba(31,55,95,.05)}.search-panel input{flex:1;min-width:260px;border:0;outline:0;background:transparent}.filter-grid{display:grid;grid-template-columns:repeat(5,minmax(150px,1fr));gap:10px}.filter-grid .btn{height:42px;margin-top:24px}
/* Dashboard */
.stat-grid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:14px;margin-bottom:18px}.stat-grid.compact{grid-template-columns:repeat(4,1fr)}.stat-card{position:relative;overflow:hidden;padding:18px;border-radius:24px;background:#fff;border:1px solid var(--line);box-shadow:0 12px 28px rgba(31,55,95,.07)}.stat-card:after{content:"";position:absolute;right:-22px;top:-22px;width:90px;height:90px;border-radius:999px;background:rgba(34,99,245,.08)}.stat-card span{color:#2563eb;background:#eff6ff;border-radius:14px;padding:8px;margin-bottom:10px}.stat-card small{display:block;color:var(--muted);font-weight:900;text-transform:uppercase;letter-spacing:.08em}.stat-card strong{display:block;font-size:29px;margin-top:4px}.module-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;margin-bottom:18px}.module-card{display:block;padding:22px;border-radius:24px;background:#fff;border:1px solid var(--line);box-shadow:0 10px 26px rgba(31,55,95,.06);transition:.2s}.module-card:hover{transform:translateY(-3px);box-shadow:var(--shadow)}.module-card>span{display:grid!important;width:48px;height:48px;place-items:center;border-radius:16px;background:#eff6ff;color:#2563eb;margin-bottom:14px}.module-card.admin>span{background:#f5f3ff;color:var(--admin)}.module-card strong{display:block;font-size:18px;margin-bottom:6px}.module-card small{color:var(--muted);line-height:1.55}.chart-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:18px}.bar-list{display:grid;gap:12px}.bar-row{display:grid;grid-template-columns:140px 1fr 50px;gap:10px;align-items:center}.bar-track{height:12px;border-radius:999px;background:#eef2ff;overflow:hidden}.bar-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,var(--primary),var(--primary2));min-width:3px}.donut{width:220px;height:220px;border-radius:50%;background:conic-gradient(var(--primary) 0 65%,#22c55e 65% 82%,#f97316 82% 93%,#ef4444 93% 100%);display:grid;place-items:center;margin:auto;box-shadow:inset 0 0 0 34px #fff}.donut strong{font-size:30px}.donut-legend{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;margin-top:14px}.legend-dot{width:10px;height:10px;border-radius:999px;display:inline-block;margin-right:6px;background:#2263f5}.legend-dot.green{background:#22c55e}.legend-dot.orange{background:#f97316}.legend-dot.red{background:#ef4444}
/* Tables */
.table-tools{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;margin:10px 0 12px}.nx-search{position:relative;flex:1;min-width:240px}.nx-search input{width:100%;border:1px solid var(--line);border-radius:14px;padding:10px 12px 10px 38px;background:#f8fafc}.nx-search span{position:absolute;left:12px;top:9px;color:var(--muted)}.nx-page-size{display:flex;align-items:center;gap:8px;color:var(--muted);font-weight:800}.responsive-table{width:100%;overflow:auto;border-radius:18px;border:1px solid var(--line)}.nx-table{width:100%;border-collapse:separate;border-spacing:0;background:#fff;min-width:760px}.nx-table th{position:sticky;top:0;z-index:1;background:#f8fafc;text-align:left;font-size:12px;text-transform:uppercase;letter-spacing:.07em;color:#475569;padding:13px;border-bottom:1px solid var(--line)}.nx-table td{padding:13px;border-bottom:1px solid #edf2f7;vertical-align:top}.nx-table tbody tr:nth-child(even){background:#fbfdff}.nx-table tbody tr:hover{background:#eff6ff}.pagination{display:flex;align-items:center;justify-content:flex-end;gap:6px;margin-top:12px}.pagination button{border:1px solid var(--line);background:#fff;border-radius:10px;min-width:34px;height:34px;font-weight:900}.pagination button.active{background:#2563eb;color:white;border-color:#2563eb}.pagination button:disabled{opacity:.45}.status-badge{display:inline-flex;min-width:32px;justify-content:center;padding:5px 8px;border-radius:999px;font-size:12px;font-weight:900}.status-badge.present{background:#dcfce7;color:#166534}.status-badge.late{background:#ffedd5;color:#9a3412}.status-badge.absent{background:#fee2e2;color:#991b1b}.status-badge.permission{background:#dbeafe;color:#1d4ed8}.status-badge.neutral{background:#f1f5f9;color:#334155}.matrix-wrap{overflow:auto;max-height:70vh;border:1px solid var(--line);border-radius:18px}.matrix-table{border-collapse:separate;border-spacing:0;min-width:900px;width:max-content;background:white}.matrix-table th,.matrix-table td{padding:10px 12px;border-bottom:1px solid #edf2f7;border-right:1px solid #edf2f7;text-align:center;white-space:nowrap}.matrix-table th{position:sticky;top:0;background:#f8fafc;z-index:2}.sticky-left{position:sticky!important;left:0;z-index:3!important;background:#fff!important;text-align:left!important;min-width:210px}.matrix-table th.sticky-left{background:#f8fafc!important;z-index:4!important}.sticky-left small{display:block;color:var(--muted)}
/* Profile */
.profile-header{display:flex;gap:18px;align-items:center}.profile-photo{width:130px;height:130px;border-radius:32px;background:#eff6ff;display:grid;place-items:center;overflow:hidden;flex:0 0 auto;border:5px solid white;box-shadow:0 16px 34px rgba(31,55,95,.12)}.profile-photo img{width:100%;height:100%;object-fit:cover}.profile-photo span{font-size:60px!important;color:#2563eb}.profile-main{flex:1}.profile-main h2{font-size:30px;margin:0 0 6px}.photo-upload{display:flex;flex-direction:column;gap:8px;min-width:260px}.tabs{display:flex;gap:8px;overflow:auto;margin-bottom:14px;position:sticky;top:0;background:rgba(245,248,255,.86);backdrop-filter:blur(10px);z-index:20;padding:8px 0}.tabs button{border:1px solid var(--line);background:#fff;border-radius:14px;padding:11px 15px;font-weight:900;white-space:nowrap;cursor:pointer}.tabs button.active{background:linear-gradient(135deg,var(--primary),var(--primary2));color:white;border-color:transparent}.tab-panel{display:none}.tab-panel.active{display:block}.teacher-card-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}.teacher-card{border:1px solid var(--line);border-radius:22px;padding:16px;background:#fff}.teacher-card small{color:var(--muted);font-weight:900;text-transform:uppercase;letter-spacing:.08em}.teacher-card strong{display:block;font-size:18px;margin:5px 0}.calendar-toolbar{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;margin-bottom:12px}.calendar{border:1px solid var(--line);border-radius:22px;overflow:hidden;background:#fff}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr)}.calendar-cell{min-height:92px;border-right:1px solid #edf2f7;border-bottom:1px solid #edf2f7;padding:8px;background:#fff}.calendar-cell:nth-child(7n){border-right:0}.calendar-head{background:#f8fafc;font-weight:900;color:#475569;text-align:center;min-height:38px}.calendar-date{font-weight:900}.calendar-cell.muted{background:#fafafa;color:#94a3b8}.calendar-cell.today{box-shadow:inset 0 0 0 2px rgba(34,99,245,.35)}.calendar-event{display:inline-flex;margin-top:8px}.status-P,.status-present{background:#dcfce7!important;color:#166534!important}.status-L,.status-late{background:#ffedd5!important;color:#9a3412!important}.status-A,.status-absent{background:#fee2e2!important;color:#991b1b!important}.status-PA,.status-permission{background:#dbeafe!important;color:#1d4ed8!important}.week-list{display:grid;gap:8px}.week-row{display:grid;grid-template-columns:130px 1fr;gap:10px;align-items:center;border:1px solid var(--line);border-radius:14px;padding:10px;background:#fff}.comm-filter-row{display:grid;grid-template-columns:repeat(4,minmax(120px,1fr));gap:10px;margin-bottom:12px}
@media(max-width:1180px){.stat-grid{grid-template-columns:repeat(3,1fr)}.module-grid,.teacher-card-grid{grid-template-columns:repeat(2,1fr)}.chart-grid,.grid-two,.grid-two.wide-left{grid-template-columns:1fr}.detail-grid{grid-template-columns:repeat(2,1fr)}.filter-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:900px){body{padding-bottom:48px}.mobile-topbar{position:fixed;left:0;right:0;top:0;height:64px;display:flex;align-items:center;gap:10px;padding:10px 14px;background:rgba(255,255,255,.9);backdrop-filter:blur(14px);border-bottom:1px solid var(--line);z-index:60}.mobile-brand{display:flex;align-items:center;gap:10px}.app-shell{display:block;padding-top:64px}.main-panel{padding-bottom:48px}.sidebar{transform:translateX(-105%);transition:transform .24s ease;bottom:0}.sidebar.open{transform:translateX(0)}.sidebar-close{display:grid}.sidebar-backdrop.open{display:block;position:fixed;inset:0;background:rgba(15,23,42,.4);z-index:49}.fixed-footer{left:0;height:48px;padding:0 14px}.page-hero{margin-top:0;padding:20px 16px;align-items:flex-start;flex-direction:column}.content-wrap{padding:0 14px 24px}.stat-grid,.stat-grid.compact{grid-template-columns:repeat(2,1fr)}.module-grid,.teacher-card-grid{grid-template-columns:1fr}.login-layout{grid-template-columns:1fr}.login-art{display:none}.login-card{padding:24px}.form-grid,.detail-grid,.filter-grid,.comm-filter-row{grid-template-columns:1fr}.profile-header{flex-direction:column;align-items:flex-start}.photo-upload{width:100%;min-width:0}.responsive-table{border:0;overflow:visible}.nx-table{min-width:0;border-collapse:collapse}.nx-table thead{display:none}.nx-table,.nx-table tbody,.nx-table tr,.nx-table td{display:block;width:100%}.nx-table tr{margin-bottom:12px;border:1px solid var(--line);border-radius:18px;background:#fff;overflow:hidden;box-shadow:0 8px 20px rgba(31,55,95,.05)}.nx-table td{display:flex;justify-content:space-between;gap:14px;padding:11px 13px;border-bottom:1px solid #edf2f7}.nx-table td:before{content:attr(data-label);font-weight:900;color:#475569;min-width:110px}.actions,.inline-form{justify-content:flex-end}.table-tools{align-items:stretch}.nx-search{min-width:100%}.calendar-cell{min-height:74px;font-size:12px}.calendar-grid{min-width:720px}.calendar{overflow:auto}.login-meta{flex-direction:column}}
@media(max-width:540px){.stat-grid,.stat-grid.compact{grid-template-columns:1fr}.page-hero h1{font-size:27px}.nx-card{padding:16px;border-radius:20px}.fixed-footer{font-size:11px}.fixed-footer span:last-child{display:none}.mini-stats{grid-template-columns:1fr}.login-body{padding:14px}.calendar-grid{min-width:640px}.week-row{grid-template-columns:1fr}.donut{width:180px;height:180px;box-shadow:inset 0 0 0 28px #fff}}
@media print{.sidebar,.mobile-topbar,.page-hero,.fixed-footer,.filter-bar,.table-tools,.btn,.tabs,.photo-upload,.sidebar-backdrop{display:none!important}.app-shell{display:block}.main-panel{padding:0}.content-wrap{max-width:none;padding:0}.nx-card{box-shadow:none;border:1px solid #ddd}.tab-panel{display:block!important}.matrix-wrap,.responsive-table{overflow:visible;max-height:none}.matrix-table,.nx-table{font-size:10px}.nx-table thead{display:table-header-group}.nx-table,.nx-table tbody,.nx-table tr,.nx-table td{display:revert;width:auto}.nx-table td:before{content:none}}

/* Staff Login v1.2.1 - image-inspired split layout */
.login-body-v121{
  min-height:100vh;
  display:grid;
  place-items:center;
  padding:clamp(16px,4vw,56px);
  background:#dfe3f1;
}
.login-shell-v121{
  width:min(1180px,100%);
  min-height:min(760px,calc(100vh - 72px));
  display:grid;
  grid-template-columns:0.92fr 1.08fr;
  background:#fff;
  border-radius:0;
  overflow:hidden;
  box-shadow:0 34px 90px rgba(15,23,42,.20);
}
.login-form-side{
  position:relative;
  display:flex;
  flex-direction:column;
  justify-content:center;
  padding:clamp(28px,5.2vw,76px);
  background:#fff;
}
.login-top-mark{
  width:48px;height:48px;
  display:grid;place-items:center;
  margin-bottom:34px;
  color:#4a32e8;
}
.login-top-mark .material-symbols-outlined{font-size:44px!important;font-variation-settings:'FILL' 1,'wght' 700,'GRAD' 0,'opsz' 48}
.login-card-v121{
  width:min(430px,100%);
  background:transparent;
  border:0;
  box-shadow:none;
  padding:0;
}
.login-card-v121.is-hidden{display:none!important}
.login-heading-v121{margin-bottom:26px}
.login-heading-v121 .login-kicker{
  display:inline-flex;
  margin:0 0 8px;
  color:#4a32e8;
  font-size:12px;
  letter-spacing:.08em;
  text-transform:uppercase;
  font-weight:900;
}
.login-heading-v121 h1{
  margin:0;
  color:#11132a;
  font-size:clamp(30px,3vw,40px);
  line-height:1.05;
  letter-spacing:-.05em;
  font-weight:900;
}
.login-heading-v121 span{display:block;margin-top:10px;color:#667085;font-weight:500}
.field-label b{color:#ef4444;font-style:normal}
.input-wrap.v121{
  min-height:54px;
  border-radius:9px;
  background:#fff;
  border:1px solid #d9dce7;
  padding:0 14px;
  box-shadow:none;
}
.input-wrap.v121:focus-within{
  border-color:#4d35ee;
  box-shadow:0 0 0 4px rgba(77,53,238,.10);
}
.input-wrap.v121 input{min-height:52px;color:#15172f}
.input-wrap.v121 .material-symbols-outlined{color:#8b90a5}
.login-row-v121{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  margin:16px 0 24px;
}
.remember-check{
  display:inline-flex;
  align-items:center;
  gap:10px;
  font-size:14px;
  font-weight:700;
  color:#11132a;
  cursor:pointer;
  user-select:none;
}
.remember-check input{position:absolute;opacity:0;pointer-events:none}
.remember-check span{
  width:18px;height:18px;
  display:inline-grid;place-items:center;
  border-radius:3px;
  background:#4d35ee;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.12);
}
.remember-check span:after{content:'✓';font-size:13px;line-height:1;color:#fff;opacity:0;transform:scale(.7);transition:.16s ease}
.remember-check input:checked + span:after{opacity:1;transform:scale(1)}
.forgot-link,.back-login-link{
  border:0;
  background:transparent;
  color:#3215c8;
  font-weight:800;
  cursor:pointer;
  padding:0;
}
.back-login-link{display:inline-flex;align-items:center;justify-content:center;gap:8px;margin-top:16px;width:100%}
.login-submit-v121{
  min-height:56px;
  border-radius:9px;
  background:#4d35ee!important;
  box-shadow:0 14px 30px rgba(77,53,238,.26);
  justify-content:center;
}
.login-footer-row-v121{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  margin-top:22px;
  color:#64748b;
  font-size:13px;
  font-weight:800;
}
.login-footer-row-v121 a{color:#3215c8}
.powered-v121{
  position:absolute;
  left:clamp(28px,5.2vw,76px);
  right:clamp(28px,5.2vw,76px);
  bottom:26px;
  color:#667085;
  font-size:12px;
  margin:0;
}
.compact-alert{width:min(430px,100%);margin:0 0 16px!important;border-radius:10px!important;padding:11px 13px!important;font-size:13px}
.alert.success{border:1px solid #bbf7d0;background:#f0fdf4;color:#166534}
.login-art-v121{
  position:relative;
  overflow:hidden;
  min-height:620px;
  background:#06104a;
  isolation:isolate;
}
.art-grid-v121{
  position:absolute;
  inset:0;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  grid-template-rows:repeat(3,1fr);
}
.shape{position:relative;overflow:hidden;background:#282c99}
.tile-a{background:#8e4cff}.tile-a:before{content:'';position:absolute;inset:0;border-radius:0 50% 50% 0;background:#6828e9}.tile-a:after{content:'';position:absolute;right:0;top:0;width:50%;height:100%;border-radius:50% 0 0 50%;background:#7936f0}
.tile-b{background:#07124e}.tile-b:before{content:'';position:absolute;left:18%;right:18%;top:42%;height:8px;background:#23c8ef;box-shadow:0 18px 0 #2e43db,0 34px 0 -1px #fff,10px 34px 0 -1px #fff,20px 34px 0 -1px #fff,30px 34px 0 -1px #fff,40px 34px 0 -1px #fff}
.tile-b:after{content:'';position:absolute;left:14%;top:26%;width:28px;height:28px;background:#ffcc19;clip-path:polygon(50% 0,100% 50%,50% 100%,0 50%);box-shadow:52px 0 0 #ff7b35}
.tile-c{background:#2b2789}.tile-c:before{content:'';position:absolute;right:-20%;top:-40%;width:86%;height:86%;background:#595ce6;transform:rotate(30deg)}.tile-c:after{content:'';position:absolute;inset:0;background:repeating-radial-gradient(circle at 0 15%,transparent 0 10px,rgba(255,255,255,.10) 11px 13px)}
.tile-d{background:#2e2d98}.tile-d:before{content:'';position:absolute;left:16%;top:24%;width:0;height:0;border-left:45px solid transparent;border-right:45px solid transparent;border-bottom:56px solid #6d86ff;filter:drop-shadow(0 48px 0 #6d86ff)}.tile-d:after{content:'';position:absolute;right:20%;top:26%;width:56px;height:90px;background:linear-gradient(#6571ef 0 32%,transparent 32% 42%,#6571ef 42% 65%,transparent 65% 72%,#6571ef 72%);clip-path:polygon(50% 0,70% 15%,100% 15%,78% 35%,78% 58%,100% 78%,70% 78%,50% 100%,30% 78%,0 78%,22% 58%,22% 35%,0 15%,30% 15%)}
.tile-e{background:#26269b}.tile-e:before{content:'';position:absolute;left:20%;bottom:22%;width:92px;height:92px;background:#ffd600;clip-path:polygon(50% 0,61% 33%,95% 15%,75% 47%,100% 50%,74% 62%,95% 85%,62% 72%,50% 100%,38% 72%,5% 85%,26% 62%,0 50%,25% 47%,5% 15%,39% 33%)}.tile-e:after{content:'';position:absolute;left:0;right:0;top:52%;height:52px;background:repeating-linear-gradient(0deg,#06104a 0 4px,transparent 4px 13px)}
.tile-f{background:#3f42d7}.tile-f:before{content:'';position:absolute;right:-28%;top:-52%;width:106%;height:106%;border-radius:50%;background:#5358e3}.tile-f:after{content:'';position:absolute;left:18%;bottom:18%;width:120px;height:120px;background:radial-gradient(circle,#a66cff 0 3px,transparent 4px);background-size:30px 30px}
.tile-g{background:#07124e}.tile-g:before{content:'';position:absolute;left:0;bottom:0;width:75%;height:75%;border-radius:0 100% 0 0;background:#7a35ef}.tile-g:after{content:'';position:absolute;left:-22%;bottom:-22%;width:85%;height:85%;border:1px solid rgba(255,255,255,.65);border-radius:50%;box-shadow:26px -26px 0 -1px transparent,26px -26px 0 0 rgba(255,255,255,.45)}
.tile-h{background:#07124e}.tile-h:before{content:'';position:absolute;left:22%;bottom:16%;width:130px;height:42px;background:repeating-linear-gradient(0deg,transparent 0 8px,#5a63dd 8px 12px);filter:drop-shadow(0 -18px 0 rgba(90,99,221,.9))}.tile-h:after{content:'';position:absolute;left:8%;top:22%;width:24px;height:88px;background:#2e37ab;box-shadow:66px 20px 0 -3px #2e37ab,108px 72px 0 -1px #2e37ab;border-radius:0 0 1px 1px}
.tile-i{background:#38bed3}.tile-i:before{content:'';position:absolute;left:-52%;top:-52%;width:112%;height:112%;border-radius:50%;background:#16146d;box-shadow:70px 70px 0 0 #3429be}.tile-i:after{content:'';position:absolute;right:12%;bottom:10%;width:90px;height:90px;background:radial-gradient(circle,#fff 0 3px,transparent 4px);background-size:20px 20px}
.art-content-v121{
  position:absolute;
  left:34px;right:34px;bottom:32px;
  color:#fff;
  z-index:2;
  padding:22px;
  border:1px solid rgba(255,255,255,.18);
  background:rgba(6,16,74,.54);
  backdrop-filter:blur(16px);
  border-radius:24px;
}
.art-content-v121 .material-symbols-outlined{font-size:34px!important;color:#38bed3}
.art-content-v121 h2{margin:8px 0 6px;font-size:26px;letter-spacing:-.035em}
.art-content-v121 p{margin:0;color:#dbeafe;max-width:430px;line-height:1.55}
@media(max-width:980px){
  .login-shell-v121{grid-template-columns:1fr;min-height:auto}
  .login-art-v121{min-height:280px;order:-1}.art-grid-v121{grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(2,1fr)}.tile-g,.tile-h,.tile-i{display:none}
  .login-form-side{padding:34px 24px 64px}.powered-v121{left:24px;right:24px;bottom:20px}
  .login-card-v121{width:100%}
}
@media(max-width:560px){
  .login-body-v121{padding:0;place-items:stretch;background:#fff}
  .login-shell-v121{box-shadow:none;width:100%;min-height:100vh}
  .login-art-v121{min-height:170px}.art-content-v121{display:none}
  .login-form-side{justify-content:flex-start;padding:28px 20px 70px}.login-top-mark{margin-bottom:22px}
  .login-row-v121{align-items:flex-start;flex-direction:column;gap:12px}
  .login-footer-row-v121{flex-direction:column;align-items:flex-start;gap:8px}.powered-v121{font-size:11px}
}

/* Dashboard v1.2.2 - section-aware professional analytics */
.dashboard-topline{
  display:grid;
  grid-template-columns:1fr auto;
  gap:18px;
  align-items:stretch;
  margin-bottom:18px;
}
.dashboard-title-card,.dashboard-actions-card{
  border:1px solid rgba(148,163,184,.18);
  background:linear-gradient(135deg,rgba(255,255,255,.95),rgba(248,250,252,.82));
  border-radius:28px;
  box-shadow:0 22px 55px rgba(15,23,42,.08);
  padding:22px;
}
.dashboard-title-card{position:relative;overflow:hidden}.dashboard-title-card:after{content:'';position:absolute;right:-64px;top:-76px;width:190px;height:190px;border-radius:50%;background:radial-gradient(circle,rgba(79,70,229,.18),transparent 68%)}
.dashboard-title-card h2{margin:10px 0 8px;font-size:28px;line-height:1.08;letter-spacing:-.04em;color:#0f172a}.dashboard-title-card p{margin:0;max-width:760px;color:#64748b;line-height:1.6}.dashboard-badge{display:inline-flex;align-items:center;gap:8px;border-radius:999px;background:#eef2ff;color:#4338ca;font-weight:900;padding:8px 12px;font-size:12px;text-transform:uppercase;letter-spacing:.04em}.dashboard-badge .material-symbols-outlined{font-size:18px!important}.dashboard-actions-card{display:flex;gap:12px;align-items:center;justify-content:center;min-width:270px}.dashboard-filter-card{margin-bottom:18px}.filter-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:18px}.filter-card-head h2{margin:0 0 4px}.dashboard-filter-grid{grid-template-columns:repeat(4,minmax(160px,1fr)) auto}.filter-submit{align-self:end;min-height:48px}.btn.soft{background:#f1f5f9;color:#334155;box-shadow:none;border:1px solid #e2e8f0}.metric-grid.pro-metrics{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;margin:18px 0}.metric-card{position:relative;overflow:hidden;border-radius:28px;padding:22px;border:1px solid rgba(148,163,184,.16);background:#fff;box-shadow:0 22px 45px rgba(15,23,42,.08);min-height:154px}.metric-card:before{content:'';position:absolute;right:-44px;top:-48px;width:132px;height:132px;border-radius:50%;background:var(--metric-soft)}.metric-card:after{content:'';position:absolute;right:20px;bottom:20px;width:54px;height:54px;border-radius:18px;background:var(--metric-soft);opacity:.66}.metric-icon{position:relative;z-index:1;width:48px;height:48px;display:grid;place-items:center;border-radius:18px;background:var(--metric);color:#fff;box-shadow:0 14px 28px var(--metric-shadow)}.metric-card small{position:relative;z-index:1;display:block;margin-top:18px;color:#64748b;font-weight:900;text-transform:uppercase;letter-spacing:.04em}.metric-card strong{position:relative;z-index:1;display:block;margin-top:6px;font-size:32px;color:#0f172a;letter-spacing:-.05em}.metric-card em{position:relative;z-index:1;display:block;margin-top:8px;color:#64748b;font-style:normal;font-weight:700;font-size:13px}.accent-blue{--metric:#2563eb;--metric-soft:#dbeafe;--metric-shadow:rgba(37,99,235,.25)}.accent-purple{--metric:#7c3aed;--metric-soft:#ede9fe;--metric-shadow:rgba(124,58,237,.25)}.accent-green{--metric:#059669;--metric-soft:#d1fae5;--metric-shadow:rgba(5,150,105,.24)}.accent-orange{--metric:#f97316;--metric-soft:#ffedd5;--metric-shadow:rgba(249,115,22,.24)}.accent-pink{--metric:#db2777;--metric-soft:#fce7f3;--metric-shadow:rgba(219,39,119,.22)}.accent-cyan{--metric:#0891b2;--metric-soft:#cffafe;--metric-shadow:rgba(8,145,178,.24)}.analysis-grid{display:grid;grid-template-columns:1.35fr .85fr;gap:18px;margin:18px 0}.analysis-grid.second-row{grid-template-columns:1fr 1fr}.analysis-grid.detail-row{grid-template-columns:1fr}.wide-card{grid-column:auto}.chart-card{padding:22px;border-radius:28px}.chart-head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:18px}.chart-head.compact{margin-bottom:14px}.chart-head h2{margin:0 0 4px;font-size:20px;color:#0f172a;letter-spacing:-.025em}.chart-chip{display:inline-flex;align-items:center;gap:7px;padding:8px 11px;border-radius:999px;font-size:12px;font-weight:900}.chart-chip.green{background:#ecfdf5;color:#047857}.chart-chip .material-symbols-outlined{font-size:17px!important}.attendance-trend-bars{height:250px;display:grid;grid-template-columns:repeat(auto-fit,minmax(52px,1fr));gap:12px;align-items:end;padding:18px 4px 2px}.trend-day{text-align:center;display:flex;flex-direction:column;align-items:center;gap:8px;min-width:0}.trend-bars-stack{height:176px;width:42px;display:flex;align-items:flex-end;justify-content:center;gap:4px;padding:8px 6px;border-radius:18px;background:linear-gradient(180deg,#f8fafc,#eef2ff);border:1px solid #e2e8f0}.trend-bars-stack .bar{width:7px;border-radius:999px 999px 3px 3px;min-height:4px;box-shadow:0 8px 16px rgba(15,23,42,.08)}.trend-bars-stack .present{background:#10b981}.trend-bars-stack .absent{background:#ef4444}.trend-bars-stack .late{background:#f59e0b}.trend-bars-stack .permission{background:#6366f1}.trend-day strong{font-size:11px;color:#334155;white-space:nowrap}.trend-day small{color:#64748b;font-weight:800}.chart-legend{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;margin-top:10px}.chart-legend span{display:inline-flex;align-items:center;justify-content:center;min-width:34px;height:24px;border-radius:999px;font-size:11px;font-weight:900;color:#fff}.present-dot{background:#10b981}.absent-dot{background:#ef4444}.late-dot{background:#f59e0b}.permission-dot{background:#6366f1}.result-trend-list,.class-breakdown-list{display:grid;gap:12px}.result-trend-row,.class-breakdown-row{display:grid;grid-template-columns:minmax(105px,1fr) 2fr auto;gap:12px;align-items:center;padding:12px;border-radius:18px;background:#f8fafc;border:1px solid #e2e8f0}.result-trend-row span,.class-breakdown-row strong{font-weight:900;color:#0f172a}.result-trend-row b,.class-breakdown-row b{font-size:15px;color:#111827}.result-track,.class-meter{height:12px;background:#e2e8f0;border-radius:999px;overflow:hidden}.result-track i,.class-meter i{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,#4f46e5,#22c55e)}.class-breakdown-row{grid-template-columns:1.25fr 2fr auto}.class-breakdown-row small{display:block;margin-top:4px;color:#64748b;font-weight:700}.gender-summary{display:grid;grid-template-columns:auto 1fr;gap:22px;align-items:center}.pro-donut{width:170px;height:170px;display:grid;place-items:center;text-align:center}.pro-donut small{display:block;font-size:12px;color:#64748b;margin-top:2px}.gender-list{display:grid;gap:10px}.gender-list span{display:flex;align-items:center;gap:8px;justify-content:space-between;padding:10px 12px;border-radius:14px;background:#f8fafc;border:1px solid #e2e8f0;color:#334155;font-weight:800}.detail-analysis-card{overflow:hidden}.insight-grid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:12px;margin-bottom:18px}.insight-item{padding:16px;border-radius:20px;background:linear-gradient(135deg,#f8fafc,#eef2ff);border:1px solid #e2e8f0;min-height:124px}.insight-item .material-symbols-outlined{width:38px;height:38px;display:grid;place-items:center;border-radius:14px;background:#fff;color:#4f46e5;box-shadow:0 10px 18px rgba(79,70,229,.10)}.insight-item strong{display:block;margin-top:14px;font-size:22px;color:#0f172a;letter-spacing:-.04em}.insight-item small{display:block;margin-top:4px;color:#64748b;font-weight:700}.empty-state{min-height:210px;display:grid;place-items:center;text-align:center;align-content:center;gap:8px;border-radius:22px;background:#f8fafc;border:1px dashed #cbd5e1;color:#64748b}.empty-state.small{min-height:190px}.empty-state .material-symbols-outlined{font-size:40px!important;color:#94a3b8}.empty-state strong{color:#334155}.dashboard-modules{margin-top:18px}.no-card-mobile .table-tools{margin-top:0}
@media(max-width:1180px){.metric-grid.pro-metrics{grid-template-columns:repeat(2,minmax(0,1fr))}.analysis-grid,.analysis-grid.second-row{grid-template-columns:1fr}.dashboard-filter-grid{grid-template-columns:repeat(2,minmax(160px,1fr))}.insight-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}
@media(max-width:760px){.dashboard-topline{grid-template-columns:1fr}.dashboard-actions-card{min-width:0;justify-content:flex-start;flex-wrap:wrap}.filter-card-head{flex-direction:column}.dashboard-filter-grid{grid-template-columns:1fr}.filter-submit{width:100%;justify-content:center}.metric-grid.pro-metrics{grid-template-columns:1fr}.metric-card{min-height:140px}.attendance-trend-bars{overflow-x:auto;grid-auto-flow:column;grid-auto-columns:62px;grid-template-columns:none;justify-content:flex-start}.result-trend-row,.class-breakdown-row{grid-template-columns:1fr}.gender-summary{grid-template-columns:1fr;justify-items:center}.insight-grid{grid-template-columns:1fr 1fr}.chart-head{flex-direction:column}.dashboard-title-card h2{font-size:24px}}
@media(max-width:520px){.insight-grid{grid-template-columns:1fr}.dashboard-title-card,.dashboard-actions-card,.chart-card{border-radius:22px;padding:16px}.metric-card{border-radius:22px}.attendance-trend-bars{height:230px}.trend-bars-stack{height:150px}}

/* Staff Portal v1.2.3 fixed top bar */
.staff-topbar{position:fixed;top:0;left:292px;right:0;height:72px;z-index:47;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:10px 28px;background:rgba(255,255,255,.9);backdrop-filter:blur(18px);border-bottom:1px solid rgba(226,232,240,.86);box-shadow:0 12px 30px rgba(31,55,95,.06)}
.main-panel{padding-top:72px}.staff-topbar .icon-btn,.topbar-icon-btn{color:#334155}.topbar-left,.topbar-actions{display:flex;align-items:center;gap:12px}.topbar-menu{display:none}.topbar-title{display:flex;flex-direction:column;line-height:1.2}.topbar-title strong{font-size:15px;color:#0f172a;letter-spacing:-.01em}.topbar-title small{color:#64748b;font-size:12px;font-weight:800;margin-top:3px}.topbar-actions{margin-left:auto}.topbar-dropdown{position:relative}.topbar-icon-btn,.topbar-user-btn{border:1px solid var(--line);background:#fff;border-radius:18px;min-height:46px;box-shadow:0 10px 24px rgba(31,55,95,.06);cursor:pointer;transition:.18s}.topbar-icon-btn{width:46px;display:grid;place-items:center;position:relative}.topbar-icon-btn:hover,.topbar-user-btn:hover{transform:translateY(-1px);box-shadow:0 16px 30px rgba(31,55,95,.1)}.topbar-badge{position:absolute;right:5px;top:4px;min-width:18px;height:18px;padding:0 5px;border-radius:999px;background:#ef4444;color:#fff;font-size:10px;display:grid;place-items:center;border:2px solid #fff}.topbar-user-btn{display:flex;align-items:center;gap:10px;padding:5px 10px 5px 6px;color:#0f172a}.topbar-avatar{display:inline-grid;width:36px;height:36px;place-items:center;border-radius:14px;background:linear-gradient(135deg,var(--primary),var(--primary2));color:#fff;font-weight:900;box-shadow:0 8px 18px rgba(34,99,245,.22)}.topbar-avatar.large{width:48px;height:48px;border-radius:18px;font-size:18px}.topbar-user-text{display:flex;flex-direction:column;align-items:flex-start;line-height:1.1;max-width:190px}.topbar-user-text strong{font-size:13px;max-width:190px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.topbar-user-text small{font-size:11px;color:#64748b;font-weight:800;margin-top:4px;max-width:190px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.topbar-user-btn .chevron{font-size:20px!important;color:#64748b;transition:transform .18s}.topbar-dropdown.open .chevron{transform:rotate(180deg)}.topbar-menu-panel{position:absolute;right:0;top:calc(100% + 10px);width:320px;background:#fff;border:1px solid var(--line);border-radius:22px;box-shadow:0 24px 60px rgba(15,23,42,.16);padding:10px;opacity:0;visibility:hidden;transform:translateY(-6px) scale(.98);transition:.18s;transform-origin:top right}.topbar-dropdown.open .topbar-menu-panel{opacity:1;visibility:visible;transform:translateY(0) scale(1)}.dropdown-head{padding:10px 10px 12px;border-bottom:1px solid #eef2f7;margin-bottom:6px}.dropdown-head strong{display:block;color:#0f172a}.dropdown-head small{display:block;color:#64748b;font-size:12px;margin-top:3px}.notification-item,.topbar-menu-panel a{display:flex;align-items:center;gap:10px;color:#0f172a;border-radius:16px;padding:11px;text-decoration:none;font-weight:850}.notification-item:hover,.topbar-menu-panel a:hover{background:#f8fafc}.notification-item .material-symbols-outlined{display:grid!important;width:38px;height:38px;place-items:center;border-radius:14px;background:#eef6ff;color:var(--primary)}.notification-item strong{display:block;font-size:13px}.notification-item small{display:block;color:#64748b;font-size:12px;margin-top:2px}.notification-item.muted{color:#64748b}.account-card-mini{display:flex;align-items:center;gap:12px;padding:12px;border-radius:18px;background:linear-gradient(135deg,#f8fbff,#eef6ff);margin-bottom:6px}.account-card-mini strong{display:block}.account-card-mini small{display:block;color:#64748b;font-size:12px;margin-top:2px}.topbar-menu-panel a .material-symbols-outlined{color:#64748b}.topbar-menu-panel a.danger{color:#b91c1c}.topbar-menu-panel a.danger .material-symbols-outlined{color:#b91c1c}.account-grid{display:grid;grid-template-columns:minmax(0,.95fr) minmax(320px,1.05fr);gap:18px}.account-profile-head{display:flex;align-items:center;gap:16px;margin-bottom:18px}.account-profile-head h2{margin:0 0 4px}.account-profile-head p{margin:0;color:var(--muted);font-weight:800}.account-avatar{display:grid;width:76px;height:76px;place-items:center;border-radius:26px;background:linear-gradient(135deg,var(--primary),var(--primary2));color:#fff;font-size:28px;font-weight:900;box-shadow:0 18px 36px rgba(34,99,245,.22)}.account-details{grid-template-columns:repeat(2,1fr)}.card-title-row{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:16px}.card-title-row h2{margin-bottom:4px}.account-security-icon{display:grid!important;width:52px;height:52px;place-items:center;border-radius:18px;background:#eef6ff;color:var(--primary);font-size:28px!important}.account-form{grid-template-columns:1fr}.input-wrap button{border:0;background:transparent;color:#64748b;display:grid;place-items:center;cursor:pointer}.alert.danger{background:#fef2f2;color:#991b1b;border-color:#fecaca}
@media(max-width:1180px){.account-grid{grid-template-columns:1fr}.account-details{grid-template-columns:repeat(2,1fr)}}
@media(max-width:900px){.main-panel{padding-top:0}.staff-topbar{position:sticky;top:64px;left:auto;right:auto;height:auto;min-height:62px;padding:8px 14px;z-index:46}.topbar-menu{display:grid}.topbar-title{display:none}.topbar-user-text{display:none}.topbar-user-btn{padding-right:8px}.topbar-menu-panel{position:fixed;right:12px;top:126px;width:min(340px,calc(100vw - 24px))}.page-hero{padding-top:18px}.account-details{grid-template-columns:1fr}}
@media(max-width:540px){.staff-topbar{gap:8px}.topbar-actions{gap:8px}.topbar-icon-btn{width:42px;min-height:42px}.topbar-user-btn{min-height:42px}.topbar-avatar{width:32px;height:32px;border-radius:12px}.notification-panel,.account-panel{width:calc(100vw - 24px)}}
@media print{.staff-topbar{display:none!important}.main-panel{padding-top:0!important}}

/* Staff Portal v1.2.4 - sidebar aligned with fixed topbar account menu */
.sidebar-nav{
  padding-bottom:92px;
}
.sidebar-meta-footer{
  padding:11px 12px;
  background:rgba(255,255,255,.055);
  border:1px solid rgba(255,255,255,.10);
  box-shadow:none;
}
.sidebar-meta-mark{
  display:flex;
  align-items:center;
  gap:10px;
  min-width:0;
}
.sidebar-meta-mark > .material-symbols-outlined{
  width:34px;
  height:34px;
  display:grid!important;
  place-items:center;
  border-radius:13px;
  background:rgba(255,255,255,.10);
  color:#bfdbfe;
}
.sidebar-meta-mark strong{
  display:block;
  font-size:12px;
  line-height:1.2;
  color:#fff;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  max-width:202px;
}
.sidebar-meta-mark small{
  display:block;
  margin-top:3px;
  color:var(--sidebarMuted);
  font-size:11px;
  line-height:1.2;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  max-width:202px;
}
.sidebar .profile-mini,
.sidebar .sidebar-actions{
  display:none!important;
}
@media(max-width:900px){
  .sidebar{
    width:min(316px,86vw);
    inset:0 auto 0 0;
    border-radius:0 24px 24px 0;
  }
  .sidebar-brand{
    padding:16px 14px;
  }
  .brand-logo{
    width:42px;
    height:42px;
    border-radius:15px;
  }
  .brand-block small{
    max-width:166px;
  }
  .sidebar-nav{
    padding:10px 10px 92px;
  }
  .nav-group-toggle{
    padding:11px 10px;
  }
  .nav-link{
    margin-left:6px;
    padding:11px 10px;
  }
  .sidebar-meta-footer{
    left:10px;
    right:10px;
    bottom:10px;
    border-radius:18px;
  }
  .mobile-topbar{
    height:60px;
  }
  .app-shell{
    padding-top:60px;
  }
  .staff-topbar{
    top:60px;
  }
  .topbar-menu-panel{
    top:118px;
  }
}
@media(max-width:540px){
  .sidebar{
    width:min(304px,90vw);
  }
  .sidebar-meta-mark strong,
  .sidebar-meta-mark small{
    max-width:190px;
  }
  .mobile-brand strong{
    font-size:14px;
  }
}


/* Staff Portal v1.2.5 - remove sidebar powered block and keep only one mobile hamburger */
.mobile-topbar{display:none!important;}
.sidebar-footer,.sidebar-meta-footer,.sidebar-meta-mark{display:none!important;}
.sidebar-nav{padding-bottom:22px!important;}
@media(max-width:900px){
  .app-shell{padding-top:0!important;}
  .staff-topbar{top:0!important;position:sticky!important;left:auto!important;right:auto!important;}
  .topbar-menu{display:grid!important;}
  .topbar-menu-panel{top:72px!important;}
  .main-panel{padding-top:0!important;}
  .sidebar-nav{padding-bottom:22px!important;}
}
@media(max-width:540px){
  .topbar-menu-panel{top:66px!important;}
}

/* Staff Portal v1.2.6 - mobile topbar title restored */
@media(max-width:900px){
  .staff-topbar{
    min-height:64px!important;
    height:64px!important;
    padding:8px 12px!important;
    align-items:center!important;
  }
  .topbar-left{
    flex:1 1 auto!important;
    min-width:0!important;
    gap:10px!important;
  }
  .topbar-title{
    display:flex!important;
    flex:1 1 auto!important;
    min-width:0!important;
    overflow:hidden!important;
    line-height:1.12!important;
  }
  .topbar-title strong{
    display:block!important;
    max-width:calc(100vw - 206px)!important;
    white-space:nowrap!important;
    overflow:hidden!important;
    text-overflow:ellipsis!important;
    font-size:15px!important;
    color:#0f172a!important;
  }
  .topbar-title small{
    display:block!important;
    max-width:calc(100vw - 206px)!important;
    white-space:nowrap!important;
    overflow:hidden!important;
    text-overflow:ellipsis!important;
    font-size:11px!important;
    margin-top:3px!important;
  }
  .topbar-actions{
    flex:0 0 auto!important;
    margin-left:6px!important;
  }
  .topbar-menu{
    flex:0 0 42px!important;
    width:42px!important;
    height:42px!important;
  }
}
@media(max-width:540px){
  .staff-topbar{
    min-height:60px!important;
    height:60px!important;
    padding:8px 10px!important;
  }
  .topbar-left{
    gap:8px!important;
  }
  .topbar-title strong{
    max-width:calc(100vw - 178px)!important;
    font-size:14px!important;
  }
  .topbar-title small{
    display:none!important;
  }
  .topbar-menu{
    flex-basis:40px!important;
    width:40px!important;
    height:40px!important;
  }
  .topbar-actions{
    gap:6px!important;
    margin-left:4px!important;
  }
}

/* Staff Portal v1.2.7 - remove duplicate page hero, refine dashboard and compact statistics */
.content-wrap{padding-top:20px!important;}
.page-hero{display:none!important;}
.dashboard-topline-single{grid-template-columns:1fr!important;margin-top:0!important;}
.dashboard-topline-single .dashboard-title-card{min-height:auto!important;padding:20px 22px!important;}
.dashboard-topline-single .dashboard-title-card h2{margin-top:10px!important;margin-bottom:5px!important;}
.dashboard-filter-grid{grid-template-columns:1.15fr 1.15fr .9fr auto!important;}
.dashboard-filter-card{padding:18px!important;}
.filter-card-head{margin-bottom:12px!important;}
.filter-card-head h2{font-size:19px!important;}
.pro-metrics{gap:12px!important;}
.metric-card{min-height:132px!important;padding:16px!important;}
.metric-card strong{font-size:28px!important;}
.dashboard-stats-row{grid-template-columns:1fr!important;}
.dashboard-stat-table-card{padding:18px!important;}
.dashboard-stats-layout{display:grid;grid-template-columns:minmax(0,1.15fr) minmax(320px,.85fr);gap:16px;align-items:stretch;}
.stats-table-zone{min-width:0;}
.compact-tools{margin:4px 0 10px!important;}
.compact-stat-table-wrap{max-height:420px;overflow:auto;border-radius:16px;}
.dashboard-class-table{min-width:620px!important;}
.dashboard-class-table th,.dashboard-class-table td{padding:10px 12px!important;}
.stats-visual-zone{display:grid;grid-template-columns:1fr;gap:12px;}
.mini-chart-card{border:1px solid var(--line);background:linear-gradient(180deg,#fff,#f8fbff);border-radius:20px;padding:14px;box-shadow:0 10px 24px rgba(31,55,95,.06);}
.mini-chart-card h3{margin:0 0 12px;font-size:14px;letter-spacing:.02em;color:#0f172a;}
.pie-chart{width:180px;height:180px;margin:8px auto 12px;border-radius:50%;display:grid;place-items:center;box-shadow:inset 0 0 0 34px #fff,0 16px 32px rgba(31,55,95,.1);background:#e5e7eb;}
.pie-chart span{width:104px;height:104px;border-radius:50%;background:#fff;display:grid;place-items:center;text-align:center;box-shadow:0 10px 24px rgba(31,55,95,.1);}
.pie-chart strong{display:block;font-size:22px;color:#0f172a;line-height:1;}
.pie-chart small{display:block;color:#64748b;font-weight:900;font-size:11px;text-transform:uppercase;letter-spacing:.08em;margin-top:-16px;}
.pie-legend{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:7px 10px;font-size:12px;color:#475569;font-weight:850;}
.pie-legend span{display:flex;align-items:center;gap:7px;min-width:0;}
.pie-legend i{width:10px;height:10px;border-radius:99px;display:inline-block;flex:0 0 auto;}
.pie-legend b{margin-left:auto;color:#0f172a;}
.compact-bars{display:grid;gap:9px;}
.compact-bar-row{display:grid;grid-template-columns:minmax(86px,.9fr) minmax(120px,1.4fr) 46px;gap:8px;align-items:center;font-size:12px;}
.compact-bar-row small{font-weight:900;color:#475569;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.compact-bar-row b{text-align:right;color:#0f172a;}
.compact-bar-track{height:10px;border-radius:99px;background:#eaf0f8;overflow:hidden;}
.compact-bar-track i{display:block;height:100%;border-radius:99px;background:linear-gradient(90deg,var(--primary),var(--primary2));}
@media(max-width:1180px){.dashboard-stats-layout{grid-template-columns:1fr;}.stats-visual-zone{grid-template-columns:repeat(2,minmax(0,1fr));}.dashboard-filter-grid{grid-template-columns:repeat(2,minmax(0,1fr))!important;}.filter-submit{grid-column:auto!important;}}
@media(max-width:900px){.content-wrap{padding-top:14px!important;}.dashboard-filter-grid{grid-template-columns:1fr!important;}.stats-visual-zone{grid-template-columns:1fr;}.compact-stat-table-wrap{max-height:none;}.dashboard-class-table{min-width:0!important;}.pie-chart{width:160px;height:160px;}.dashboard-topline-single .dashboard-title-card{padding:16px!important;}}
@media(max-width:540px){.pie-legend{grid-template-columns:1fr;}.compact-bar-row{grid-template-columns:78px 1fr 40px;}.metric-card{min-height:auto!important;}}


/* Staff Portal v1.2.8 - dashboard spacing, remove live summary block, five-row stats with bar graph only */
.staff-topbar{
  box-shadow:0 10px 24px rgba(15,23,42,.095)!important;
}
.content-wrap{
  padding-top:34px!important;
}
.dashboard-topline,
.dashboard-topline-single{
  display:none!important;
}
.dashboard-filter-card{
  margin-top:0!important;
}
.dashboard-stats-layout{
  grid-template-columns:minmax(0,1.05fr) minmax(320px,.65fr)!important;
}
.stats-visual-zone{
  display:block!important;
}
.stats-visual-zone .mini-chart-card{
  height:100%;
}
.pie-chart,
.pie-legend{
  display:none!important;
}
.compact-stat-table-wrap{
  max-height:342px!important;
}
.compact-bars{
  gap:13px!important;
}
.compact-bar-row{
  grid-template-columns:minmax(92px,.9fr) minmax(128px,1.4fr) 50px!important;
}
.compact-bar-track{
  height:13px!important;
}
@media(max-width:900px){
  .content-wrap{padding-top:18px!important;}
  .dashboard-stats-layout{grid-template-columns:1fr!important;}
  .compact-stat-table-wrap{max-height:none!important;}
}

/* Student Profile v1.2.9 updates */
.student-search-panel{margin-bottom:18px}.student-profile-hero{display:grid;grid-template-columns:auto minmax(0,1fr) minmax(260px,360px);gap:20px;align-items:center;background:linear-gradient(135deg,#ffffff,#f8fbff 55%,#eef6ff)}.profile-photo.blob-photo{width:132px;height:132px;border-radius:34px;overflow:hidden;background:linear-gradient(135deg,#e0f2fe,#eef2ff);border:1px solid #dbeafe;box-shadow:0 18px 40px rgba(37,99,235,.14);display:grid;place-items:center}.profile-photo.blob-photo img{width:100%;height:100%;object-fit:cover;display:block}.profile-photo.blob-photo .material-symbols-outlined{font-size:56px!important;color:#64748b}.profile-detail-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.profile-detail-grid>div{background:#f8fafc;border:1px solid #e2e8f0;border-radius:18px;padding:14px}.modern-tabs{position:sticky;top:84px;z-index:20;background:rgba(248,250,252,.88);backdrop-filter:blur(16px);padding:10px;border:1px solid #e2e8f0;border-radius:22px;margin:18px 0}.pro-teacher-card{position:relative;overflow:hidden}.pro-teacher-card:before{content:"";position:absolute;right:-30px;top:-30px;width:90px;height:90px;border-radius:50%;background:rgba(79,70,229,.08)}.pro-teacher-card p{margin:6px 0;color:#475569;font-weight:750}.result-card{overflow:visible}.result-tab-head{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:16px}.mini-tabs{display:inline-flex;gap:8px;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:18px;padding:6px}.mini-tabs button{border:0;border-radius:14px;padding:10px 14px;background:transparent;color:#475569;font-weight:900;cursor:pointer}.mini-tabs button.active{background:#fff;color:var(--primary);box-shadow:0 10px 22px rgba(15,23,42,.08)}.result-sub-panel{display:none}.result-sub-panel.active{display:block}.semester-accordion{border:1px solid #e2e8f0;border-radius:22px;background:#fff;margin:12px 0;overflow:hidden}.semester-accordion summary{cursor:pointer;list-style:none;padding:16px 18px;display:flex;align-items:center;gap:10px;font-weight:950;color:#0f172a;background:linear-gradient(135deg,#f8fafc,#eef6ff)}.semester-accordion summary::-webkit-details-marker{display:none}.semester-accordion summary b{margin-left:auto;background:#fff;border:1px solid #e2e8f0;border-radius:999px;padding:6px 10px;font-size:12px;color:#475569}.semester-accordion .responsive-table,.semester-accordion .table-tools{margin:12px 14px}.result-table td,.result-table th{white-space:nowrap}.enhanced-calendar-toolbar{align-items:center;gap:14px;flex-wrap:wrap}.month-nav{display:flex;align-items:center;gap:10px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:18px;padding:8px}.month-nav strong{min-width:118px;text-align:center;color:#0f172a}.attendance-summary-row{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin:16px 0}.attendance-summary-card{border-radius:20px;padding:16px;border:1px solid #e2e8f0;background:#f8fafc;box-shadow:0 12px 28px rgba(15,23,42,.04)}.attendance-summary-card small{display:block;color:#64748b;font-weight:900}.attendance-summary-card strong{display:block;margin-top:6px;font-size:28px;color:#0f172a}.attendance-summary-card.status-P{background:#f0fdf4;border-color:#bbf7d0}.attendance-summary-card.status-A{background:#fef2f2;border-color:#fecaca}.attendance-summary-card.status-L{background:#fffbeb;border-color:#fde68a}.attendance-summary-card.status-PA{background:#eff6ff;border-color:#bfdbfe}.improved-calendar .calendar-cell{min-height:96px}.improved-week-list{max-height:440px;overflow:auto}.communication-thread-card .comm-filter-row{display:grid;grid-template-columns:2fr minmax(220px,.75fr);gap:12px;margin:14px 0 18px}.thread-groups{display:grid;gap:14px}.thread-group{border:1px solid #e2e8f0;border-radius:22px;background:#fff;overflow:hidden}.thread-head{display:flex;align-items:center;gap:12px;padding:14px 16px;background:linear-gradient(135deg,#f8fafc,#eef6ff);border-bottom:1px solid #e2e8f0}.thread-head .material-symbols-outlined{width:42px;height:42px;border-radius:16px;background:#fff;color:var(--primary);display:grid!important;place-items:center;box-shadow:0 10px 20px rgba(79,70,229,.1)}.thread-head strong{display:block;color:#0f172a}.thread-head small{display:block;color:#64748b;font-weight:800;margin-top:3px}.thread-head b{margin-left:auto;background:#fff;border:1px solid #e2e8f0;border-radius:999px;padding:7px 10px;font-size:12px;color:#475569}.chat-thread{padding:16px;display:grid;gap:10px;max-height:520px;overflow:auto;background:#fbfdff}.chat-bubble-row{display:flex}.chat-bubble{max-width:min(760px,92%);border:1px solid #e2e8f0;background:#fff;border-radius:18px 18px 18px 6px;padding:12px 14px;box-shadow:0 8px 20px rgba(15,23,42,.04)}.chat-bubble small{display:block;color:#64748b;font-size:12px;font-weight:850;margin-bottom:5px}.chat-bubble p{margin:0;color:#1f2937;line-height:1.55}.status-badge.status-P,.calendar-event.status-P{background:#dcfce7;color:#166534}.status-badge.status-A,.calendar-event.status-A{background:#fee2e2;color:#991b1b}.status-badge.status-L,.calendar-event.status-L{background:#fef3c7;color:#92400e}.status-badge.status-PA,.calendar-event.status-PA{background:#dbeafe;color:#1d4ed8}
@media(max-width:1000px){.student-profile-hero{grid-template-columns:auto 1fr}.student-profile-hero .photo-upload{grid-column:1/-1}.profile-detail-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.modern-tabs{top:64px;overflow-x:auto;white-space:nowrap}.result-tab-head{flex-direction:column;align-items:flex-start}.attendance-summary-row{grid-template-columns:repeat(2,minmax(0,1fr))}.communication-thread-card .comm-filter-row{grid-template-columns:1fr}}
@media(max-width:620px){.student-profile-hero{grid-template-columns:1fr;text-align:center}.profile-photo.blob-photo{margin:auto}.photo-upload{align-items:stretch}.profile-detail-grid{grid-template-columns:1fr}.modern-tabs{border-radius:18px}.modern-tabs button{padding:10px 12px}.mini-tabs{width:100%;display:grid;grid-template-columns:1fr 1fr}.attendance-summary-row{grid-template-columns:1fr}.month-nav{width:100%;justify-content:space-between}.enhanced-calendar-toolbar .inline-form{width:100%}.enhanced-calendar-toolbar .inline-form .input{flex:1}.improved-calendar .calendar-cell{min-height:76px;padding:8px}.thread-head{align-items:flex-start}.thread-head b{display:none}}

/* Student Profile v1.3.0: corrected results and communication presentation */
.clean-result-card .result-tab-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  flex-wrap:wrap;
}
.result-summary-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:14px;
}
.semester-summary-card{
  border:1px solid rgba(15,90,242,.10);
  border-radius:18px;
  background:linear-gradient(135deg,rgba(255,255,255,.98),rgba(246,249,255,.92));
  padding:16px;
  box-shadow:0 10px 28px rgba(15,23,42,.06);
}
.semester-summary-head{
  display:flex;
  gap:12px;
  align-items:center;
  margin-bottom:14px;
}
.semester-summary-head .material-symbols-outlined{
  width:42px;
  height:42px;
  display:grid;
  place-items:center;
  border-radius:14px;
  background:rgba(15,90,242,.10);
  color:var(--staff-primary,#0f5af2);
}
.semester-summary-head small,
.summary-metrics small,
.subject-result-head small{
  display:block;
  color:#64748b;
  font-size:12px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.03em;
}
.semester-summary-head strong{
  font-size:18px;
  color:#0f172a;
}
.summary-metrics{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
}
.summary-metrics > div{
  border-radius:14px;
  padding:10px 12px;
  background:#fff;
  border:1px solid rgba(148,163,184,.18);
}
.summary-metrics strong{
  font-size:18px;
  color:#0f172a;
}
.subject-result-list{
  display:grid;
  gap:14px;
  margin-top:14px;
}
.subject-result-group{
  border:1px solid rgba(148,163,184,.20);
  border-radius:18px;
  background:#fff;
  padding:14px;
}
.subject-result-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin-bottom:12px;
}
.subject-result-head strong{
  font-size:17px;
  color:#0f172a;
}
.subject-score-pill{
  white-space:nowrap;
  border-radius:999px;
  background:rgba(15,90,242,.08);
  color:#0f5af2;
  font-weight:800;
  padding:8px 12px;
}
.subject-score-pill span{
  margin-left:6px;
  color:#475569;
  font-weight:700;
}
.thread-group{
  border:1px solid rgba(148,163,184,.22);
  border-radius:18px;
  background:#fff;
  padding:14px;
  margin-bottom:14px;
}
.thread-head{
  border-bottom:1px solid rgba(148,163,184,.18);
  padding-bottom:10px;
  margin-bottom:12px;
}
.chat-thread{
  max-height:460px;
  overflow:auto;
  padding-right:4px;
}
.chat-bubble{
  max-width:760px;
}
@media (max-width: 640px){
  .clean-result-card .result-tab-head,
  .subject-result-head{align-items:flex-start;flex-direction:column;}
  .summary-metrics{grid-template-columns:1fr;}
  .subject-score-pill{white-space:normal;}
}

/* Student Profile v1.3.1: subject accordion, active status badges, icon tabs */
.icon-tabs button,
.mini-tabs button{
  display:inline-flex!important;
  align-items:center;
  justify-content:center;
  gap:8px;
}
.icon-tabs .material-symbols-outlined,
.mini-tabs .material-symbols-outlined{
  font-size:19px!important;
  line-height:1;
}
.icon-tabs button.active .material-symbols-outlined,
.mini-tabs button.active .material-symbols-outlined{
  color:var(--primary,#0f5af2);
}
.cell-subtext{
  display:block;
  margin-top:3px;
  color:#64748b;
  font-size:11px;
  font-weight:750;
}
.student-status-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  padding:6px 10px;
  font-size:12px;
  font-weight:900;
  border:1px solid transparent;
  white-space:nowrap;
}
.student-status-badge.active{
  background:#dcfce7;
  color:#166534;
  border-color:#bbf7d0;
}
.student-status-badge.inactive{
  background:#ffedd5;
  color:#9a3412;
  border-color:#fed7aa;
}
.subject-accordion{
  padding:0!important;
  overflow:hidden;
}
.subject-accordion summary.subject-result-head{
  list-style:none;
  cursor:pointer;
  margin:0;
  padding:15px 16px;
  background:linear-gradient(135deg,#ffffff,#f8fbff);
  border-bottom:1px solid rgba(148,163,184,.18);
}
.subject-accordion summary.subject-result-head::-webkit-details-marker{display:none;}
.subject-title-block{
  display:flex;
  align-items:center;
  gap:10px;
  min-width:0;
}
.subject-title-block>.material-symbols-outlined{
  width:42px;
  height:42px;
  display:grid!important;
  place-items:center;
  border-radius:15px;
  background:rgba(15,90,242,.10);
  color:var(--primary,#0f5af2);
  flex:0 0 auto;
}
.exam-count-pill{
  border-radius:999px;
  background:#f8fafc;
  border:1px solid #e2e8f0;
  color:#475569;
  padding:8px 10px;
  font-size:12px;
  font-weight:900;
  white-space:nowrap;
}
.subject-accordion-body{
  padding:0 14px 14px;
}
.subject-accordion-body .table-tools{
  margin-top:14px!important;
}
.result-semester-accordion>summary .material-symbols-outlined{
  color:var(--primary,#0f5af2);
}
@media(max-width:640px){
  .icon-tabs button{min-width:max-content;}
  .subject-accordion summary.subject-result-head{align-items:stretch!important;}
  .subject-title-block{width:100%;}
  .exam-count-pill,.subject-score-pill{width:100%;text-align:center;}
}


/* Student Profile v1.3.2: one exam-detail table grouped by semester and subject */
.one-result-table-wrap{
  margin:12px 14px 16px!important;
}
.unified-result-table .result-subject-row td{
  background:linear-gradient(135deg,#f8fafc,#eef6ff)!important;
  color:#0f172a;
  border-top:1px solid #dbeafe;
  border-bottom:1px solid #dbeafe;
  padding:13px 14px!important;
}
.unified-result-table .result-subject-row td{
  white-space:normal!important;
}
.unified-result-table .result-subject-row span{
  vertical-align:middle;
  display:inline-grid!important;
  place-items:center;
  width:34px;
  height:34px;
  border-radius:12px;
  margin-right:8px;
  background:#fff;
  color:var(--primary,#0f5af2);
  box-shadow:0 8px 18px rgba(15,90,242,.10);
}
.unified-result-table .result-subject-row strong{
  font-weight:950;
  margin-right:10px;
}
.unified-result-table .result-subject-row small{
  color:#64748b;
  font-weight:800;
  margin-right:10px;
}
.unified-result-table .result-subject-row b{
  float:right;
  border-radius:999px;
  padding:6px 10px;
  background:#fff;
  border:1px solid #e2e8f0;
  color:#475569;
  font-size:12px;
}
@media(max-width:700px){
  .unified-result-table .result-subject-row b{float:none;display:inline-flex;margin-top:8px;}
  .unified-result-table .result-subject-row small{display:block;margin:4px 0 0 44px;}
}

/* Student Profile v1.3.3: semester tabs + compact detail exam table */
.semester-tabs-shell{
  display:grid;
  gap:14px;
}
.semester-tabs{
  display:flex;
  gap:10px;
  overflow-x:auto;
  padding:4px 2px 10px;
  scrollbar-width:thin;
}
.semester-tabs button{
  flex:0 0 auto;
  min-width:190px;
  border:1px solid #e2e8f0;
  background:linear-gradient(135deg,#fff,#f8fafc);
  border-radius:18px;
  padding:10px 12px;
  display:grid;
  grid-template-columns:auto 1fr;
  align-items:center;
  column-gap:9px;
  row-gap:2px;
  text-align:left;
  cursor:pointer;
  color:#334155;
  box-shadow:0 8px 18px rgba(15,23,42,.04);
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease, background .18s ease;
}
.semester-tabs button:hover{
  transform:translateY(-1px);
  box-shadow:0 12px 26px rgba(15,23,42,.08);
}
.semester-tabs button.active{
  border-color:rgba(15,90,242,.35);
  background:linear-gradient(135deg,#eef6ff,#ffffff);
  color:var(--primary,#0f5af2);
  box-shadow:0 16px 30px rgba(15,90,242,.12);
}
.semester-tabs .material-symbols-outlined{
  grid-row:1 / span 2;
  width:38px;
  height:38px;
  display:grid!important;
  place-items:center;
  border-radius:14px;
  background:#eff6ff;
  color:var(--primary,#0f5af2);
  font-size:20px!important;
}
.semester-tabs strong{
  font-size:13px;
  font-weight:950;
  line-height:1.15;
  white-space:nowrap;
}
.semester-tabs small{
  font-size:11px;
  font-weight:800;
  color:#64748b;
  white-space:nowrap;
}
.semester-tab-panel{display:none;}
.semester-tab-panel.active{display:block;}
.compact-semester-head{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
  margin:0 0 10px;
  padding:10px 12px;
  border:1px solid #e2e8f0;
  border-radius:16px;
  background:#f8fafc;
}
.compact-semester-head>div{
  margin-right:auto;
}
.compact-semester-head small{
  display:block;
  font-size:11px;
  color:#64748b;
  font-weight:850;
}
.compact-semester-head strong{
  display:block;
  color:#0f172a;
  font-size:15px;
  font-weight:950;
}
.compact-semester-head>span{
  border-radius:999px;
  background:#fff;
  border:1px solid #e2e8f0;
  padding:6px 10px;
  color:#475569;
  font-size:12px;
  font-weight:900;
}
.compact-result-wrap{margin:8px 0 0!important;}
.compact-table-tools{margin:0 0 8px!important;}
.compact-exam-table{
  font-size:13px;
}
.compact-exam-table th,
.compact-exam-table td{
  padding:8px 10px!important;
  vertical-align:middle;
}
.compact-exam-table th{
  font-size:11px;
  letter-spacing:.02em;
  text-transform:uppercase;
  color:#475569;
}
.compact-exam-table .exam-name-cell strong{
  max-width:260px;
  display:inline-block;
  overflow:hidden;
  text-overflow:ellipsis;
  vertical-align:bottom;
}
.unified-result-table .compact-subject-row td{
  padding:9px 10px!important;
}
.unified-result-table .compact-subject-row span{
  width:28px;
  height:28px;
  border-radius:10px;
  font-size:17px!important;
}
.unified-result-table .compact-subject-row strong{
  font-size:13px;
}
.unified-result-table .compact-subject-row small,
.unified-result-table .compact-subject-row b{
  font-size:11px;
  padding:4px 8px;
}
@media(max-width:700px){
  .semester-tabs button{min-width:170px;padding:9px 10px;}
  .compact-semester-head{align-items:flex-start;}
  .compact-semester-head>div{width:100%;}
  .compact-exam-table .exam-name-cell strong{max-width:190px;}
}

/* v1.3.4: attendance detail rows for live schema date_gc/date_et/semister */
.attendance-detail-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:10px 12px;
  border:1px solid rgba(15,23,42,.08);
  border-radius:14px;
  background:#fff;
  margin-bottom:8px;
}
.attendance-detail-row strong{display:block;font-size:.92rem;color:#0f172a;}
.attendance-detail-row small{display:inline-flex;margin-right:8px;color:#64748b;font-size:.76rem;}
.attendance-row-actions{display:flex;align-items:center;justify-content:flex-end;gap:8px;flex-wrap:wrap;}
.parent-response-chip{border-radius:999px;background:#eef2ff;color:#3730a3;padding:4px 8px;font-weight:700;}
@media (max-width: 640px){
  .attendance-detail-row{align-items:flex-start;flex-direction:column;}
  .attendance-row-actions{justify-content:flex-start;}
}

/* Attendance page v1.3.5 - real student_attendance schema */
.attendance-page-shell{display:grid;gap:18px}.attendance-filter-card{overflow:hidden}.attendance-filter-head{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;margin-bottom:18px}.attendance-filter-head h2{margin:4px 0 5px;font-size:26px;letter-spacing:-.035em}.attendance-filter-head p{margin:0;color:var(--muted);line-height:1.55}.attendance-sync-pill{display:inline-flex;align-items:center;gap:8px;padding:10px 13px;border-radius:999px;background:#eef6ff;color:#1d4ed8;border:1px solid #dbeafe;font-weight:900;white-space:nowrap}.attendance-filter-grid{display:grid;grid-template-columns:1.1fr 1fr .9fr .9fr auto;gap:12px;align-items:end}.attendance-filter-grid label{display:grid;gap:7px;font-size:12px;font-weight:900;color:#475569;text-transform:uppercase;letter-spacing:.06em}.attendance-filter-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.attendance-empty-state{min-height:280px;display:grid;place-items:center;text-align:center;border:1px dashed #cbd5e1;background:linear-gradient(135deg,#fff,#f8fbff)}.attendance-empty-state .material-symbols-outlined{font-size:56px!important;color:var(--primary);padding:16px;border-radius:24px;background:#eff6ff}.attendance-empty-state h2{margin:10px 0 2px}.attendance-empty-state p{margin:0;color:var(--muted)}.attendance-kpi-grid{display:grid;grid-template-columns:1.15fr repeat(4,1fr);gap:14px}.attendance-kpi{position:relative;overflow:hidden;border-radius:26px;padding:18px;background:#fff;border:1px solid var(--line);box-shadow:0 14px 34px rgba(31,55,95,.08)}.attendance-kpi:before{content:"";position:absolute;right:-28px;top:-28px;width:96px;height:96px;border-radius:50%;opacity:.18}.attendance-kpi span{display:grid!important;place-items:center;width:44px;height:44px;border-radius:16px;margin-bottom:12px;color:#fff}.attendance-kpi small{display:block;color:#667085;font-weight:900;text-transform:uppercase;letter-spacing:.06em}.attendance-kpi strong{display:block;font-size:32px;letter-spacing:-.04em;margin:2px 0}.attendance-kpi em{font-style:normal;color:#475569;font-weight:900}.attendance-kpi.total span,.attendance-kpi.total:before{background:#2563eb}.attendance-kpi.present span,.attendance-kpi.present:before{background:#16a34a}.attendance-kpi.late span,.attendance-kpi.late:before{background:#f97316}.attendance-kpi.absent span,.attendance-kpi.absent:before{background:#dc2626}.attendance-kpi.permission span,.attendance-kpi.permission:before{background:#1d4ed8}.attendance-layout-grid{display:grid;grid-template-columns:.82fr 1.18fr;gap:18px}.section-title-row{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:12px}.section-title-row h2{margin:0 0 4px}.section-title-row p{margin:0;color:var(--muted);line-height:1.45}.attendance-stat-card{height:100%}.attendance-meter-row{display:grid;gap:7px;margin:16px 0}.attendance-meter-label{display:grid;grid-template-columns:44px 1fr auto;align-items:center;gap:10px;font-size:13px}.attendance-meter-label strong{display:inline-grid;place-items:center;min-width:38px;height:28px;border-radius:999px;background:#f1f5f9}.attendance-meter-label span{font-weight:900;color:#344054}.attendance-meter-label em{font-style:normal;font-weight:900;color:#0f172a}.attendance-meter{height:12px;border-radius:999px;background:#edf2f7;overflow:hidden}.attendance-meter i{display:block;height:100%;border-radius:999px;transition:width .35s ease}.meter-p{background:#16a34a}.meter-l{background:#f97316}.meter-a{background:#dc2626}.meter-pl{background:#1d4ed8}.compact-table-wrap .nx-table{min-width:680px}.attendance-compact-table th,.attendance-compact-table td{padding:9px 10px;font-size:13px}.attendance-detail-table th,.attendance-detail-table td{font-size:13px}.mini-pill{display:inline-flex;align-items:center;justify-content:center;min-width:34px;padding:4px 8px;border-radius:999px;font-size:11px;font-weight:900}.mini-pill.success{background:#dcfce7;color:#166534}.mini-pill.warning{background:#ffedd5;color:#9a3412}.mini-pill.muted{background:#f1f5f9;color:#64748b}.status-badge.permission{background:#dbeafe;color:#1d4ed8}
@media(max-width:1180px){.attendance-filter-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.attendance-filter-actions{grid-column:1/-1}.attendance-kpi-grid{grid-template-columns:repeat(3,1fr)}.attendance-layout-grid{grid-template-columns:1fr}}
@media(max-width:760px){.attendance-filter-head{flex-direction:column}.attendance-filter-grid{grid-template-columns:1fr}.attendance-kpi-grid{grid-template-columns:1fr}.attendance-kpi{border-radius:20px;padding:16px}.attendance-kpi strong{font-size:28px}.attendance-filter-actions .btn{flex:1}.section-title-row{flex-direction:column}.attendance-meter-label{grid-template-columns:38px 1fr auto}.attendance-sync-pill{white-space:normal}.attendance-filter-head h2{font-size:22px}}
@media print{.attendance-filter-card,.attendance-filter-actions,.attendance-empty-state{display:none!important}.attendance-kpi-grid{grid-template-columns:repeat(5,1fr)}.attendance-layout-grid{grid-template-columns:1fr}.attendance-kpi,.nx-card{box-shadow:none}.attendance-detail-table,.attendance-compact-table{font-size:10px}}
