:root{--ink:#0F172A;--ink-light:#334155;--muted:#64748B;--line:#E2E8F0;--bg:#F8FAFC;--panel:#FFFFFF;--accent:#0F766E;--accent-strong:#115E59;--accent-light:#CCFBF1;--gold:#D97706;--gold-bg:#FEF3C7;--danger:#DC2626;--danger-bg:#FEE2E2;--ok:#16A34A;--ok-bg:#DCFCE7;--blue:#2563EB;--blue-bg:#DBEAFE;--shadow-sm:0 1px 2px 0 rgb(0 0 0/0.05);--shadow:0 4px 6px -1px rgb(0 0 0/0.1),0 2px 4px -2px rgb(0 0 0/0.1);--shadow-md:0 10px 15px -3px rgb(0 0 0/0.1),0 4px 6px -4px rgb(0 0 0/0.1);--shadow-lg:0 20px 25px -5px rgb(0 0 0/0.1),0 8px 10px -6px rgb(0 0 0/0.1);--shadow-glow:0 0 20px rgba(15,118,110,0.15);--sidebar-width:280px;--sidebar-bg:#0F172A;--sidebar-text:#94A3B8;--sidebar-text-hover:#F8FAFC;--sidebar-active-bg:rgba(255,255,255,0.1)}*{box-sizing:border-box}.app-main,.brand-text,.logout-btn span,.nav-group span,.nav-link-text,.powered-by,.sidebar{transition:width .3s cubic-bezier(.4,0,.2,1),margin .3s cubic-bezier(.4,0,.2,1),padding .3s cubic-bezier(.4,0,.2,1),opacity .3s ease,transform .3s ease}body{margin:0;min-height:100vh;color:var(--ink);background:var(--bg);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}::selection{color:white;background:var(--accent)}button,input,select,textarea{font:inherit}button{cursor:pointer;border:none;background:none}a{color:inherit;text-decoration:none}.toast{position:fixed;bottom:28px;left:50%;transform:translateX(-50%) translateY(16px);z-index:100000;max-width:min(420px,calc(100vw - 32px));padding:14px 22px;border-radius:12px;font-size:14px;font-weight:600;line-height:1.45;text-align:center;color:#fff;background:#0f172a;box-shadow:0 12px 40px rgba(15,23,42,.28),0 4px 12px rgba(0,0,0,.12);border:1px solid rgba(255,255,255,.12);opacity:0;pointer-events:none;transition:opacity .25s ease,transform .25s ease}.toast--visible{opacity:1;transform:translateX(-50%) translateY(0);pointer-events:auto}.toast--success{background:#14532d;border-color:rgba(187,247,208,.35);box-shadow:0 12px 40px rgba(20,83,45,.35)}.toast--error{background:#7f1d1d;border-color:rgba(254,202,202,.35);box-shadow:0 12px 40px rgba(127,29,29,.35)}.toast--info{background:#115e59;border-color:rgba(153,246,228,.35)}.toast-message{display:block;word-break:break-word}.loading-screen{position:fixed;inset:0;background:rgba(248,250,252,.9);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);flex-direction:column;z-index:9999;gap:24px}.loader,.loading-screen{display:flex;align-items:center;justify-content:center}.loader{width:56px;height:56px;position:relative}.loader:after,.loader:before{content:"";position:absolute;border-radius:50%;animation:pulse-ring 2s linear infinite}.loader:before{inset:0;border-left:3px solid transparent;border-right:3px solid transparent;border-top:3px solid transparent;border-top-color:var(--accent);border-bottom:3px solid transparent;border-bottom-color:var(--blue);animation:spin 1.5s cubic-bezier(.68,-.55,.265,1.55) infinite}.loader-inner{width:24px;height:24px;background:linear-gradient(135deg,var(--accent),var(--blue));border-radius:50%;animation:pulse-dot 1.5s ease-in-out infinite alternate}.loading-screen p{color:var(--ink-light);font-weight:600;letter-spacing:.5px;animation:pulse-text 1.5s ease-in-out infinite alternate}@keyframes spin{to{transform:rotate(1turn)}}@keyframes pulse-ring{0%{transform:scale(.8);opacity:0}50%{opacity:1}to{transform:scale(1.2);opacity:0}}@keyframes pulse-dot{0%{transform:scale(.8)}to{transform:scale(1.1);box-shadow:var(--shadow-glow)}}@keyframes pulse-text{0%{opacity:.5}to{opacity:1}}.eyebrow{font-size:12px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:1px;margin:0 0 4px}.separator{color:#CBD5E1;margin:0 4px}h1,h2,h3,h4,h5,h6{margin:0;color:var(--ink)}p{margin:0}.text-muted{color:var(--muted)}.text-sm{font-size:14px}.app-layout{display:flex;min-height:100vh}.app-layout:has(.sidebar.collapsed){--sidebar-width:88px}.sidebar{width:var(--sidebar-width);background:var(--sidebar-bg);color:white;display:flex;flex-direction:column;position:fixed;top:0;bottom:0;left:0;z-index:50;transition:width .3s cubic-bezier(.4,0,.2,1),transform .3s cubic-bezier(.4,0,.2,1)}.brand{padding:24px;display:flex;align-items:center;gap:16px;border-bottom:1px solid rgba(255,255,255,.05);position:relative;min-height:90px}.sidebar.collapsed .brand{padding:24px 16px;justify-content:center}.brand-logo{object-fit:contain;background:white;padding:2px}.brand-logo,.brand-mark{width:40px;height:40px;border-radius:10px;flex-shrink:0}.brand-mark{background:linear-gradient(135deg,var(--accent),var(--blue));color:white;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:18px;box-shadow:0 4px 12px rgba(15,118,110,.4)}.brand-text{overflow:hidden;white-space:normal;word-break:break-word;overflow-wrap:break-word;transition:opacity .2s ease}.sidebar.collapsed .brand-text{opacity:0;width:0;pointer-events:none;white-space:nowrap}.brand-text h1{font-size:18px;font-weight:700;color:white;letter-spacing:-.5px;word-break:break-word;overflow-wrap:break-word}.brand-text p{font-size:12px;font-weight:600;color:var(--accent-light);margin-top:2px}.toggle-sidebar-btn{position:absolute;right:-12px;top:33px;width:24px;height:24px;background:var(--accent);color:white;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:var(--shadow);z-index:100;border:2px solid var(--sidebar-bg);transition:all .2s ease}.toggle-sidebar-btn:hover{background:var(--accent-strong);transform:scale(1.1)}.sidebar.collapsed .toggle-sidebar-btn{transform:rotate(180deg)}.sidebar.collapsed .toggle-sidebar-btn:hover{transform:rotate(180deg) scale(1.1)}.close-menu-btn{display:none;background:none;border:none;color:var(--sidebar-text);padding:8px;margin-left:auto;border-radius:8px}.close-menu-btn:hover{color:white;background:rgba(255,255,255,.1)}.nav{flex-direction:column;overflow:hidden}.nav,.nav-scroll{display:flex;flex:1 1}.nav-scroll{overflow-y:auto;padding:24px 16px;flex-direction:column;gap:24px}.sidebar.collapsed .nav-scroll{padding:24px 12px;align-items:center}.nav-scroll::-webkit-scrollbar{width:6px}.nav-scroll::-webkit-scrollbar-thumb{background:rgba(255,255,255,.1);border-radius:10px}.nav-group{width:100%}.nav-group span{display:block;padding:0 24px;margin-bottom:12px;font-size:11px;font-weight:700;color:var(--sidebar-text);text-transform:uppercase;letter-spacing:1.2px;white-space:nowrap;overflow:hidden}.sidebar.collapsed .nav-group span{opacity:0;height:0;margin:0}.tab-nav{display:flex;align-items:center;justify-content:center;gap:8px;background:var(--line);padding:4px;border-radius:12px;flex-wrap:wrap}.tab-nav button{background:transparent;border:none;padding:8px 16px;font-size:14px;font-weight:600;color:var(--muted);border-radius:8px;transition:all .2s ease}.tab-nav button:hover{color:var(--ink)}.tab-nav button.active{background:white;color:var(--ink);box-shadow:var(--shadow-sm)}.nav-link{position:relative;display:flex;align-items:center;padding:12px 24px;border-radius:12px;color:var(--sidebar-text);font-weight:600;font-size:14px;transition:all .2s ease;margin-bottom:4px;width:100%;gap:16px}.sidebar.collapsed .nav-link{padding:12px;justify-content:center;width:48px;height:48px;margin:0 auto 8px}.nav-link svg{flex-shrink:0}.nav-link:hover{color:var(--sidebar-text-hover);background:rgba(255,255,255,.05);transform:translateX(4px)}.sidebar.collapsed .nav-link:hover{transform:scale(1.1)}.nav-link.active{color:white;background:var(--sidebar-active-bg)}.nav-link-text{white-space:nowrap;overflow:hidden;transition:opacity .2s ease}.sidebar.collapsed .nav-link-text{display:none}.nav-link-indicator{position:absolute;left:0;top:50%;transform:translateY(-50%) scaleY(0);width:4px;height:20px;background:var(--accent);border-radius:0 4px 4px 0;transition:transform .2s ease}.sidebar.collapsed .nav-link-indicator{left:-12px}.nav-link.active .nav-link-indicator{transform:translateY(-50%) scaleY(1)}.sidebar-footer{padding:20px 16px;border-top:1px solid rgba(255,255,255,.05);display:flex;flex-direction:column;gap:12px}.sidebar.collapsed .sidebar-footer{padding:20px 8px;align-items:center}.logout-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;background:rgba(220,38,38,.1);border:1px solid rgba(220,38,38,.2);padding:12px;color:#FCA5A5;font-weight:600;border-radius:12px;transition:all .2s ease}.sidebar.collapsed .logout-btn{padding:12px;width:48px;height:48px}.sidebar.collapsed .logout-btn span{display:none}.powered-by{margin-top:16px;text-align:center;font-size:10px;font-weight:600;color:var(--sidebar-text);text-transform:uppercase;letter-spacing:.5px;line-height:1.6}.sidebar.collapsed .powered-by{display:none}.powered-by a{color:var(--accent-light);font-weight:700}.powered-by a:hover{text-decoration:underline}.app-main{flex:1 1;margin-left:var(--sidebar-width);display:flex;flex-direction:column;min-width:0;min-height:100vh;transition:margin-left .3s cubic-bezier(.4,0,.2,1)}.topbar{position:-webkit-sticky;position:sticky;top:0;z-index:40;margin:16px 24px 0;padding:16px 24px;background:rgba(255,255,255,.85);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--line);border-radius:16px;justify-content:space-between;box-shadow:var(--shadow-sm)}.topbar,.topbar-left{display:flex;align-items:center}.topbar-left{gap:16px}.mobile-menu-btn{display:none;background:white;border:1px solid var(--line);border-radius:8px;padding:8px;color:var(--ink);box-shadow:var(--shadow-sm)}.topbar h2{font-size:20px;font-weight:800;color:var(--ink);letter-spacing:-.5px}.topbar-right{display:flex;align-items:center;gap:24px}.user-profile-badge{gap:12px;padding-right:24px;border-right:1px solid var(--line)}.avatar,.user-profile-badge{display:flex;align-items:center}.avatar{width:36px;height:36px;border-radius:50%;background:var(--accent-light);color:var(--accent-strong);justify-content:center;font-weight:700;font-size:16px}.user-email{font-size:14px;font-weight:600;color:var(--ink-light)}.topbar-actions{display:flex;gap:12px}.content-scroll{flex:1 1;padding:24px;width:100%}.content-inner{max-width:1400px;margin:0 auto}.content-inner--full{max-width:none;width:100%;margin:0}.content-scroll--full{padding:12px 32px 20px}.danger-button,.ghost-button,.primary-button,.small-button{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:1px solid transparent;border-radius:10px;padding:10px 18px;font-size:14px;font-weight:600;transition:all .2s ease;white-space:nowrap}.primary-button{color:white;background:var(--ink);box-shadow:var(--shadow-sm)}.primary-button:hover{background:#000000;transform:translateY(-1px);box-shadow:var(--shadow)}.ghost-button{color:var(--ink-light);background:white;border-color:var(--line);box-shadow:var(--shadow-sm)}.ghost-button:hover{background:#F1F5F9;color:var(--ink);transform:translateY(-1px)}.danger-button{color:white;background:var(--danger);box-shadow:var(--shadow-sm)}.danger-button:hover{background:#B91C1C;transform:translateY(-1px);box-shadow:var(--shadow)}.icon-btn{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:10px;border:1px solid var(--line);background:white;color:var(--ink-light);cursor:pointer;transition:all .2s ease;box-shadow:var(--shadow-sm)}.icon-btn:hover{color:var(--ink);background:#F1F5F9;transform:translateY(-1px)}.icon-btn.accent{color:var(--accent-strong);background:var(--accent-light);border-color:transparent}.icon-btn.accent:hover{background:var(--accent);color:white}.icon-btn.danger{color:var(--danger);background:var(--danger-bg);border-color:transparent}.icon-btn.danger:hover{background:var(--danger);color:white}.icon-btn.present{color:var(--ok);background:var(--ok-bg);border-color:transparent;font-weight:800}.icon-btn.present.active,.icon-btn.present:hover{background:var(--ok);color:white;border-color:transparent;box-shadow:0 4px 10px rgba(22,163,74,.2)}.icon-btn.absent{color:var(--danger);background:var(--danger-bg);border-color:transparent;font-weight:800}.icon-btn.absent.active,.icon-btn.absent:hover{background:var(--danger);color:white;border-color:transparent;box-shadow:0 4px 10px rgba(220,38,38,.2)}.action-dots{display:inline-flex;align-items:center;gap:8px;justify-content:flex-end}label{display:flex;flex-direction:row;gap:6px;color:var(--ink-light);font-size:14px;font-weight:500}input,select,textarea{width:100%;border:1px solid var(--line);border-radius:10px;padding:12px 16px;color:var(--ink);background:white;font-size:14px;transition:all .2s ease;box-shadow:var(--shadow-sm)}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light)}.auth-card,.metric,.module-card,.panel{background:var(--panel);border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow);transition:all .3s ease}.panel{padding:24px;animation:riseIn .4s cubic-bezier(.16,1,.3,1) both}.panel-header{margin-bottom:20px;display:flex;justify-content:space-between;align-items:center}.metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));grid-gap:20px;gap:20px;margin-bottom:24px}.metric{padding:20px;position:relative;overflow:hidden;animation:riseIn .4s cubic-bezier(.16,1,.3,1) both}.metric:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:#CBD5E1}.metric strong{display:block;font-size:32px;font-weight:800;margin-top:12px;color:var(--ink);letter-spacing:-1px}.table-wrap{overflow-x:auto;border-radius:12px;border:1px solid var(--line);background:white;box-shadow:var(--shadow-sm)}table{width:100%;border-collapse:collapse}td,th{padding:16px;text-align:left;border-bottom:1px solid var(--line);font-size:14px}th{background:#F8FAFC;color:var(--muted);font-weight:600;text-transform:uppercase;font-size:12px;letter-spacing:.5px}tbody tr{transition:background .2s}tbody tr:hover{background:#F1F5F9}@media (max-width:768px){.table-wrap:has(.responsive-table){border:none;background:transparent;box-shadow:none;overflow-x:visible}.responsive-table,.responsive-table tbody,.responsive-table td,.responsive-table th,.responsive-table thead,.responsive-table tr{display:block}.responsive-table{min-width:0}.responsive-table thead tr{position:absolute;top:-9999px;left:-9999px}.responsive-table tr{border:1px solid var(--line);border-radius:12px;background:white;margin-bottom:16px;box-shadow:var(--shadow-sm)}.responsive-table td{border:none;border-bottom:1px solid var(--line);position:relative;padding-left:45%;text-align:right;min-height:50px;display:flex;flex-direction:column;justify-content:center;align-items:flex-end;gap:4px}.responsive-table td:last-child{border-bottom:0}.responsive-table td:before{content:attr(data-label);position:absolute;left:16px;top:50%;transform:translateY(-50%);width:40%;padding-right:10px;white-space:nowrap;text-align:left;font-weight:700;font-size:11px;color:var(--muted);text-transform:uppercase}.responsive-table .action-dots{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:8px}.responsive-table .profile-cell{justify-content:flex-end;text-align:right}}.status{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:4px 12px;font-size:12px;font-weight:700;text-transform:capitalize}.status.good,.status.paid,.status.pass,.status.present{color:var(--ok);background:var(--ok-bg)}.status.partial,.status.warn{color:var(--gold);background:var(--gold-bg)}.status.absent,.status.fail,.status.pending,.status.risk{color:var(--danger);background:var(--danger-bg)}.status.neutral{color:var(--ink-light);background:#F1F5F9}.login-page{min-height:100vh;display:grid;grid-template-columns:1fr 1fr}.login-hero{background:linear-gradient(135deg,var(--sidebar-bg),#1E293B);color:white;padding:64px;display:flex;flex-direction:column;justify-content:space-between}.login-hero h1{font-size:56px;line-height:1.1;color:white}.login-hero p{color:#94A3B8;font-size:18px;line-height:1.6;max-width:480px}.login-panel{padding:64px;display:grid;align-content:center;justify-content:center;background:var(--bg)}.auth-card{width:100%;max-width:420px;padding:40px}.auth-card h2{font-size:28px;font-weight:800;margin-bottom:8px}.auth-card p{color:var(--muted)}@keyframes riseIn{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.split-layout{display:grid;grid-template-columns:360px 1fr;grid-gap:24px;gap:24px}.form-row{display:grid;grid-template-columns:1fr 1fr;grid-gap:16px;gap:16px}.mobile-overlay{display:none;position:fixed;inset:0;background:rgba(15,23,42,.6);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:45;animation:fadeIn .3s ease}@media (max-width:1024px){.app-main{margin-left:0}.sidebar{transform:translateX(-100%);box-shadow:var(--shadow-lg)}.sidebar.open{transform:translateX(0)}.mobile-overlay{display:block}.close-menu-btn,.mobile-menu-btn{display:flex;align-items:center;justify-content:center}.user-profile-badge{padding-right:0;border-right:none}.user-email{display:none}.login-page,.split-layout{grid-template-columns:1fr}.login-hero{padding:40px;text-align:center;justify-content:center;min-height:40vh}.login-panel{padding:40px 20px}}@media (max-width:640px){.topbar{flex-direction:column;align-items:flex-start;gap:16px;margin:12px 16px 0;padding:16px}.topbar-right{width:100%;justify-content:space-between;flex-direction:row-reverse}.content-scroll{padding:16px}.form-row{grid-template-columns:1fr}.panel-header{flex-direction:column;align-items:flex-start;gap:16px}.panel-header .actions{width:100%;display:grid;grid-template-columns:1fr}}.skel{background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0 50%,#f0f0f0 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:6px}.skel-profile{height:40px;width:180px;border-radius:8px}.skel-line{height:12px;width:100%;max-width:120px;margin-bottom:6px}.skel-line.short{max-width:72px;margin-bottom:0}.skel-badge{height:28px;width:72px;border-radius:8px}.skel-pill{height:26px;width:64px;border-radius:999px}.skel-actions{height:36px;width:140px;margin-left:auto;border-radius:8px}.skeleton-row td{padding:16px 18px}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.list-panel{padding:0;overflow:hidden;border-radius:14px}.list-panel-top{display:grid;grid-template-columns:1fr auto;align-items:end;grid-gap:16px 24px;gap:16px 24px;padding:18px 20px 14px}.list-title-block h3{margin:0;font-size:20px;font-weight:800;color:var(--ink)}.list-title-block .muted{margin:6px 0 0;font-size:13px}.list-panel-actions{align-items:center;justify-content:flex-end}.list-panel-actions,.list-stats{display:flex;gap:12px;flex-wrap:wrap}.stat-chip{display:flex;flex-direction:column;gap:4px;padding:10px 16px;background:var(--bg);border:1px solid var(--line);border-radius:12px;min-width:120px}.stat-chip.accent{background:var(--accent-light);border-color:transparent}.stat-label{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.5px;color:var(--muted)}.stat-chip strong{font-size:20px;font-weight:800;color:var(--ink);line-height:1}.stat-chip.accent strong{color:var(--accent)}.filter-bar{display:grid;grid-template-columns:minmax(200px,2fr) minmax(130px,1fr) minmax(130px,1fr) auto;align-items:end;grid-gap:12px 14px;gap:12px 14px;padding:14px 20px 16px;background:var(--bg);border-top:1px solid #eef2f7;border-bottom:1px solid var(--line)}.search-wrap{position:relative;min-width:0}.search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--muted);pointer-events:none}.search-wrap input{width:100%;padding:12px 14px 12px 42px;border:1px solid var(--line);border-radius:10px;font-size:14px;font-weight:500;background:var(--panel);box-shadow:0 1px 2px rgba(0,0,0,.04)}.search-wrap input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light)}.filter-field{display:flex;flex-direction:column;gap:6px;min-width:0}.filter-field label{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.5px;color:var(--muted)}.filter-field select{padding:12px 14px;border:1px solid var(--line);border-radius:10px;font-size:14px;font-weight:600;background:var(--panel);color:var(--ink);cursor:pointer;box-shadow:0 1px 2px rgba(0,0,0,.04)}.filter-field select:disabled{opacity:.55;cursor:not-allowed}.filter-field select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light)}.clear-filters-btn{padding:12px 16px;border:1px dashed #cbd5e1;border-radius:10px;background:var(--panel);font-size:13px;font-weight:700;color:var(--muted);cursor:pointer;white-space:nowrap;transition:.2s}.clear-filters-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-light)}.active-filters{display:flex;flex-wrap:wrap;gap:8px;padding:10px 20px 12px;background:var(--panel);border-bottom:1px solid #eef2f7}.filter-tag{display:inline-flex;align-items:center;padding:6px 12px;font-size:12px;font-weight:700;color:var(--accent-strong);background:var(--accent-light);border:1px solid rgba(15,118,110,.2);border-radius:999px}.table-scroll{max-height:calc(100vh - 300px);min-height:280px;overflow:auto;-webkit-overflow-scrolling:touch}.table-scroll.is-loading{pointer-events:none}.list-panel .table-wrap{border:none;border-radius:0;box-shadow:none;width:100%}.modern-table{width:100%;border-collapse:collapse;border-spacing:0}.modern-table th{text-align:left;padding:14px 18px;background:var(--bg);border-bottom:2px solid var(--line);color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.6px;font-weight:800;position:-webkit-sticky;position:sticky;top:0;z-index:2}.modern-table td{padding:14px 18px;border-bottom:1px solid #f1f5f9;font-size:14px;vertical-align:middle;text-align:left}.data-row{transition:background .12s ease}.data-row:hover{background:var(--bg)}.data-row:nth-child(2n){background:#fcfdfe}.data-row:nth-child(2n):hover{background:#f1f5f9}.profile-cell{display:flex;align-items:center;gap:12px;cursor:pointer;border:none;background:transparent;padding:4px 6px;margin:-4px -6px;border-radius:10px;text-align:left;width:100%;transition:background .15s}.profile-cell:hover{background:var(--accent-light)}.profile-text{min-width:0}.profile-text strong{display:block;font-size:14px;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:220px}.cell-primary{display:block;font-weight:600;color:var(--ink)}.sub-text{display:block;font-size:11px;color:var(--muted);margin-top:4px}.class-badge{display:inline-block;padding:5px 10px;font-size:12px;font-weight:800;color:var(--accent-strong);background:var(--accent-light);border:1px solid #a7f3d0;border-radius:8px;white-space:nowrap}.avatar.fallback{background:var(--accent);color:white;display:grid;place-items:center;font-weight:800;font-size:16px}.toolbar-title h2{font-size:22px;font-weight:800;letter-spacing:-.5px;margin:0}.toolbar-title p{font-size:13px;color:var(--muted);margin:2px 0 0}.attendance-toolbar,.exam-toolbar,.finance-toolbar,.notifications-toolbar,.staff-toolbar,.students-toolbar,.timetable-toolbar{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:20px 0 16px;flex-wrap:wrap}.attendance-tab-nav,.exam-tab-nav,.notifications-tab-nav,.staff-tab-nav,.students-tab-nav,.timetable-tab-nav{display:flex;align-items:center;gap:4px;background:var(--line);padding:4px;border-radius:12px;flex-wrap:wrap}.attendance-tab-nav button,.exam-tab-nav button,.notifications-tab-nav button,.staff-tab-nav button,.students-tab-nav button,.timetable-tab-nav button{background:transparent;border:none;padding:8px 16px;font-size:14px;font-weight:600;color:var(--muted);border-radius:8px;transition:all .2s ease;white-space:nowrap}.attendance-tab-nav button:hover,.exam-tab-nav button:hover,.notifications-tab-nav button:hover,.staff-tab-nav button:hover,.students-tab-nav button:hover,.timetable-tab-nav button:hover{color:var(--ink)}.attendance-tab-nav button.active,.exam-tab-nav button.active,.notifications-tab-nav button.active,.staff-tab-nav button.active,.students-tab-nav button.active,.timetable-tab-nav button.active{background:white;color:var(--ink);box-shadow:var(--shadow-sm)}.list-title-block .list-meta{font-size:13px;color:var(--muted);margin-top:4px}.stat-chip.accent .stat-label,.stat-chip.accent strong{color:var(--accent-strong)}.list-footer{justify-content:space-between;padding:16px 0 0;gap:16px;flex-wrap:wrap;border-top:1px solid var(--line);margin-top:8px}.list-footer,.rows-per-page{display:flex;align-items:center}.rows-per-page{gap:8px;font-size:13px;color:var(--muted);font-weight:600}.rows-per-page select{width:auto;padding:6px 10px;font-size:13px;border-radius:8px}.pagination{display:flex;align-items:center;gap:4px}.page-btn{padding:6px 12px;font-size:13px;font-weight:600;color:var(--ink-light);background:white;border:1px solid var(--line);border-radius:8px;cursor:pointer;transition:all .2s ease}.page-btn:hover:not(:disabled){background:#F1F5F9;color:var(--ink)}.page-btn:disabled{opacity:.4;cursor:not-allowed}.page-pills{display:flex;gap:4px}.page-pill{width:32px;height:32px;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;color:var(--ink-light);background:white;border:1px solid var(--line);border-radius:8px;cursor:pointer;transition:all .2s ease}.page-pill:hover{background:#F1F5F9;color:var(--ink)}.page-pill.active{background:var(--ink);color:white;border-color:var(--ink)}.page-ellipsis{width:32px;height:32px;display:flex;align-items:center;justify-content:center;font-size:13px;color:var(--muted)}.empty-icon{font-size:40px;line-height:1}.empty-state h4{font-size:16px;font-weight:700;color:var(--ink);margin:0}.empty-state p{font-size:14px;color:var(--muted);max-width:360px;margin:0}.enrollment-panel{display:flex;flex-direction:column;gap:0}.enrollment-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:16px;flex-wrap:wrap}.enrollment-header h3{font-size:20px;font-weight:800;margin:0}.enrollment-header p{font-size:13px;color:var(--muted);margin:4px 0 0}.staff-sections-row{display:flex;gap:16px;align-items:flex-start}.staff-sections-row>.form-section-block{flex:1 1;min-width:0;margin-bottom:0}.form-section-block{margin-bottom:18px;padding:20px;background:#f8fafc;border:1px solid var(--line);border-radius:12px;box-sizing:border-box}.section-title{font-size:13px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.8px;margin:0 0 12px;padding-bottom:8px;border-bottom:1px solid var(--line)}.enrollment-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));grid-gap:14px 16px;gap:14px 16px}.form-field{display:flex;flex-direction:column;gap:6px}.form-field label{font-size:13px;font-weight:600;color:var(--ink-light);display:flex;flex-direction:row;align-items:center;gap:4px;white-space:nowrap}.form-field .required-star{color:var(--danger);font-size:13px;line-height:1;flex-shrink:0}.form-field input,.form-field select,.form-field textarea{width:100%;border:1px solid var(--line);border-radius:8px;padding:9px 12px;font-size:14px;color:var(--ink);background:white;transition:all .2s ease;box-shadow:var(--shadow-sm)}.form-field input:focus,.form-field select:focus,.form-field textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light)}.form-field.has-error input,.form-field.has-error select,.form-field.has-error textarea{border-color:var(--danger);box-shadow:0 0 0 3px var(--danger-bg)}.field-error{font-size:12px;color:var(--danger);font-weight:600}.field-hint{font-size:12px;color:var(--muted)}.form-actions{display:flex;gap:12px;margin-top:16px;flex-wrap:wrap}.modal-overlay{position:fixed;inset:0;background:rgba(15,23,42,.5);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:grid;place-items:center;z-index:1000;padding:16px}.modal-box{background:white;border-radius:16px;box-shadow:var(--shadow-lg);width:100%;max-width:max-content;max-height:calc(100vh - 32px);overflow-y:auto;animation:riseIn .3s cubic-bezier(.16,1,.3,1) both}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid var(--line)}.modal-header h3{font-size:18px;font-weight:700;margin:0}.modal-body{padding:20px 24px;display:flex;flex-direction:column;gap:16px}.modal-footer{display:flex;gap:12px;padding:16px 24px 20px;border-top:1px solid var(--line);justify-content:flex-end}.attendance-manager,.exam-manager,.finance-manager,.notifications-manager,.staff-manager,.students-manager,.timetable-manager{display:flex;flex-direction:column;gap:20px;padding-bottom:60px}.type-toggle{display:flex;align-items:center;gap:4px;background:var(--line);padding:4px;border-radius:10px}.type-toggle button{padding:6px 14px;font-size:13px;font-weight:600;color:var(--muted);background:transparent;border:none;border-radius:7px;cursor:pointer;transition:all .2s ease}.type-toggle button.active{background:white;color:var(--ink);box-shadow:var(--shadow-sm)}.att-a-btn,.att-p-btn{width:32px;height:32px;border-radius:8px;font-size:13px;font-weight:800;border:1px solid var(--line);cursor:pointer;transition:all .2s ease}.att-p-btn{background:var(--ok-bg);color:var(--ok)}.att-p-btn.active,.att-p-btn:hover{background:var(--ok);color:white;border-color:var(--ok)}.att-a-btn{background:var(--danger-bg);color:var(--danger)}.att-a-btn.active,.att-a-btn:hover{background:var(--danger);color:white;border-color:var(--danger)}.room-card{display:flex;align-items:center;gap:16px;padding:16px 20px}.room-card .room-icon{font-size:24px}.room-card .room-info{flex:1 1}.room-card .room-info h4{font-size:15px;font-weight:700;margin:0 0 2px}.room-card .room-info p{font-size:13px;color:var(--muted);margin:0}.room-card.available{border-color:var(--ok)}.room-card .status-badge{font-size:11px;font-weight:700;color:var(--ok);background:var(--ok-bg);padding:3px 8px;border-radius:999px}.rooms-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));grid-gap:16px;gap:16px}.delete-btn{padding:6px 14px;font-size:13px;font-weight:600;color:var(--danger);background:var(--danger-bg);border:1px solid transparent;border-radius:8px;cursor:pointer;transition:all .2s ease}.delete-btn:hover{background:var(--danger);color:white}.notification-card{background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:20px 24px;box-shadow:var(--shadow-sm);transition:all .2s ease}.notification-card:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:var(--shadow)}.notification-card .card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.notification-card h3{font-size:16px;font-weight:700;margin:0 0 6px}.notification-card p{font-size:14px;color:var(--ink-light);line-height:1.6;margin:0}.notification-card .card-footer{margin-top:14px;padding-top:10px;border-top:1px solid var(--line);display:flex;justify-content:flex-end}.notification-card .sender{font-size:12px;font-weight:600;color:var(--muted)}.notification-card .date{font-size:11px;color:var(--muted);font-weight:600}.notif-tag{font-size:10px;font-weight:800;text-transform:uppercase;padding:3px 10px;border-radius:999px}.notif-tag.all{background:var(--blue-bg);color:var(--blue)}.notif-tag.role{background:var(--ok-bg);color:var(--ok)}.notif-tag.class{background:var(--gold-bg);color:var(--gold)}.notif-tag.user{background:var(--danger-bg);color:var(--danger)}.notification-list{display:flex;flex-direction:column;gap:12px}@media (max-width:768px){.attendance-toolbar,.exam-toolbar,.finance-toolbar,.notifications-toolbar,.staff-toolbar,.students-toolbar,.timetable-toolbar{flex-direction:column;align-items:flex-start}.list-footer,.list-panel-top{flex-direction:column}.list-footer{align-items:flex-start}.enrollment-grid{grid-template-columns:1fr}.modal-box{max-width:100%}.rooms-grid{grid-template-columns:1fr}.filter-bar{flex-direction:column;align-items:stretch}.search-wrap{min-width:0}}.staff-meta{display:flex;flex-direction:column;gap:4px}.staff-meta .badge{display:inline-block;padding:3px 10px;border-radius:999px;font-size:11px;font-weight:700;background:var(--accent-light);color:var(--accent-strong)}.staff-meta .dept{font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted)}.text-success{color:var(--ok)}.text-danger{color:var(--danger)}.history-header,.payroll-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;flex-wrap:wrap;gap:12px}.history-header h3,.payroll-header h3{margin:0;font-size:18px;font-weight:800;color:var(--ink)}.month-picker{display:flex;gap:12px}.month-picker select{padding:8px 12px;border:1px solid var(--line);border-radius:8px;font-weight:600;background:white;color:var(--ink)}.badge{display:inline-block;padding:4px 12px;border-radius:999px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.badge.success{background:var(--ok-bg);color:var(--ok)}.badge.pending{background:var(--gold-bg);color:var(--gold)}.slip-modal{background:white;border-radius:20px;width:100%;max-width:600px;padding:32px;box-shadow:var(--shadow-md);max-height:90vh;overflow-y:auto}.slip-content{border:2px solid var(--line);padding:24px;border-radius:12px;margin-bottom:24px}.slip-header{text-align:center;margin-bottom:32px;border-bottom:2px dashed var(--line);padding-bottom:20px}.slip-header h2{color:var(--accent);letter-spacing:2px;margin:0 0 4px}.slip-header h3{font-size:14px;color:var(--muted);margin:4px 0}.slip-header p{margin:0;font-size:14px;font-weight:700;color:var(--ink-light)}.slip-header .slip-addr{font-size:11px;color:var(--muted);max-width:300px;margin:4px auto;text-align:center;white-space:pre-line}.divider{height:1px;background:var(--line);margin:15px 0}.slip-meta{display:grid;grid-template-columns:1fr 1fr;grid-gap:24px;gap:24px;margin-bottom:32px}.meta-group label{display:block;font-size:11px;text-transform:uppercase;color:var(--muted);font-weight:700;margin-bottom:4px}.meta-group strong{font-size:16px;color:var(--ink)}.slip-table{display:grid;grid-template-columns:1fr 1fr;grid-gap:40px;gap:40px;margin-bottom:32px}.table-col h4{font-size:12px;margin-bottom:16px;color:var(--ink-light);padding-bottom:8px;border-bottom:1px solid var(--line);margin-top:0}.slip-row{font-size:13px;margin-bottom:8px;color:var(--muted)}.slip-row,.slip-total{display:flex;justify-content:space-between}.slip-total{font-size:14px;font-weight:800;margin-top:12px;border-top:1px solid var(--line);padding-top:8px;color:var(--ink)}.slip-footer{text-align:center;border-top:2px dashed var(--line);padding-top:24px}.net-pay{background:var(--ok-bg);padding:20px 40px;border-radius:12px;margin-bottom:20px}.net-pay label{font-size:12px;color:var(--ok);text-transform:uppercase;font-weight:700;display:block}.net-pay h1{font-size:32px;color:var(--ok);margin:8px 0 0}.slip-note{font-size:10px;color:var(--muted);margin-top:20px;font-style:italic}.modal-actions{display:flex;gap:12px;margin-top:24px;flex-wrap:wrap}.staff-form-panel{padding:28px 32px 32px}.upload-box{border:2px dashed var(--line);padding:20px;border-radius:12px;text-align:center;background:var(--bg)}.upload-box img{width:80px;height:80px;border-radius:10px;object-fit:cover;margin-bottom:10px;display:block;margin-left:auto;margin-right:auto}.upload-box p{font-size:11px;color:var(--muted);margin-top:5px}.upload-box input[type=file]{display:block;margin:8px auto 0}.custom-textarea{padding:12px;border:1px solid var(--line);border-radius:8px;width:100%;font-family:inherit;font-size:14px;resize:vertical}.custom-textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light)}.span-2{grid-column:span 2}.slip-branding-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:24px;gap:24px;max-width:900px;align-items:stretch}.slip-branding-left{gap:16px}.slip-branding-left,.slip-branding-right{display:flex;flex-direction:column}.slip-branding-right .form-field{height:100%}.slip-branding-right .custom-textarea{height:calc(100% - 24px);min-height:120px;resize:vertical}@media (max-width:768px){.slip-branding-grid{grid-template-columns:1fr;gap:16px}.slip-branding-right .custom-textarea{height:auto;min-height:100px}}.id-designer{display:grid;grid-template-columns:1.2fr 1fr;grid-gap:32px;gap:32px;align-items:start}.config-panel{padding:32px;border-radius:24px;background:white;border:1px solid var(--line)}.config-panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px;flex-wrap:wrap;gap:12px}.config-panel-header h2{margin:0;font-size:20px;font-weight:800;color:var(--ink)}.config-panel-header p{margin:4px 0 0;font-size:13px;color:var(--muted)}.config-panel-actions{display:flex;gap:12px}.checkbox-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));grid-gap:10px;gap:10px}.check-item{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--bg);border-radius:12px;cursor:pointer;border:1px solid var(--line);transition:all .2s ease;-webkit-user-select:none;-moz-user-select:none;user-select:none}.check-item:hover{background:#F1F5F9;border-color:#CBD5E1}.check-item.active{background:var(--ok-bg);border-color:#BBF7D0;box-shadow:0 4px 12px rgba(34,197,94,.08)}.check-item.compact{padding:10px 12px;font-size:11px;font-weight:700}.check-item.highlight{background:#EFF6FF;border-color:#BFDBFE}.check-item input[type=checkbox]{width:16px;height:16px;border-radius:4px;cursor:pointer;accent-color:var(--accent)}.check-text strong{display:block;font-size:13px;color:var(--ink)}.check-text p{margin:0;font-size:10px;color:var(--muted)}.fields-label{font-size:12px;font-weight:800;text-transform:uppercase;color:var(--muted);margin-bottom:12px;display:block}.preview-stage{background:var(--bg);border-radius:24px;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;padding:40px;border:1px dashed #cbd5e1;position:-webkit-sticky;position:sticky;top:24px;align-self:start}.preview-stage h4{margin:0 0 32px;font-size:14px;text-transform:uppercase;letter-spacing:2px;color:#94A3B8;font-weight:800}.color-inputs{display:flex;gap:12px;margin-top:8px}.color-inputs input[type=color]{width:44px;height:44px;border-radius:10px;border:2px solid white;box-shadow:0 2px 8px rgba(0,0,0,.1);cursor:pointer;padding:2px}.color-field-group{margin-top:24px}.color-field-group label{display:block;font-size:13px;font-weight:600;color:var(--ink-light);margin-bottom:6px}.color-field-group input:not([type=color]),.color-field-group input[type=text]{margin-top:8px}.id-card-container{display:flex;gap:20px;flex-wrap:wrap;justify-content:center}.id-card-render{position:relative;overflow:hidden;box-shadow:0 15px 35px rgba(0,0,0,.1)}.id-card-render .card-bg-accent{position:absolute;inset:0;pointer-events:none}.id-card-render .card-header{text-align:center;position:relative;z-index:1;width:100%}.id-card-render .card-header h2{font-size:16px;margin:0;text-transform:uppercase}.id-card-render .card-header span{font-size:10px;opacity:.6;text-transform:uppercase;display:block;margin-top:2px}.id-card-render .card-logo{width:32px;height:32px;border-radius:6px;display:grid;place-items:center;color:white;font-weight:900;margin:0 auto 8px}.id-card-render .card-photo{position:relative;z-index:1;border-radius:12px;overflow:hidden;background:#eee;display:grid;place-items:center}.id-card-render .card-photo img{width:100%;height:100%;object-fit:cover}.id-card-render .card-info{position:relative;z-index:1;text-align:center;width:100%}.id-card-render .card-info h3{font-size:22px;margin:0 0 4px;font-weight:800}.id-card-render .card-bar{width:100%;height:6px;border-radius:99px;z-index:1;margin-top:auto}.id-card-render .back-header{position:relative;z-index:1;width:100%;padding-bottom:8px;margin-bottom:20px}.id-card-render .back-details{position:relative;z-index:1;width:100%;display:grid;grid-gap:16px;gap:16px}.id-card-render .back-item{text-align:left}.id-card-render .back-item label{font-size:9px;opacity:.5;text-transform:uppercase;display:block;margin-bottom:1px}.id-card-render .back-item p,.id-card-render .back-item strong{margin:0;font-size:13px;display:block}.id-card-render .back-footer{position:relative;z-index:1;width:100%;display:flex;align-items:center;gap:15px;padding-top:15px;margin-top:auto}.id-card-render .qr-box{width:70px;height:70px;background:white;padding:4px;border-radius:8px;box-shadow:0 4px 12px rgba(0,0,0,.1)}.id-card-render .qr-box img{width:100%;height:100%;object-fit:contain}.id-card-render .school-mini{font-size:10px}.id-card-render .school-mini strong{display:block;text-transform:uppercase;font-size:12px}.id-card-render .role-tag{display:inline-block;padding:4px 12px;border-radius:20px;font-size:12px;font-weight:800}.id-card-modal{background:white;padding:40px;border-radius:24px;max-width:960px;width:100%;max-height:90vh;overflow-y:auto}.id-card-modal-header{text-align:center;margin-bottom:24px}.id-card-modal-header h2{margin:0;font-size:22px;font-weight:800;color:var(--ink)}.id-card-modal-header p{margin:4px 0 0;font-size:13px;color:var(--muted)}.id-card-modal-actions{margin-top:32px;display:flex;gap:16px;justify-content:center;flex-wrap:wrap}.id-card-modal-actions button{min-width:160px}.slip-design-form{padding:20px}.slip-design-form h2{margin-bottom:8px}.slip-design-form .form-field{margin-top:20px}@media (max-width:900px){.id-designer{grid-template-columns:1fr}.preview-stage{position:static;padding:24px}.id-card-container{flex-direction:column;align-items:center}}@media (max-width:768px){.slip-meta,.slip-table{grid-template-columns:1fr;gap:16px}.modal-actions{flex-direction:column}.id-card-modal-actions{flex-direction:column;align-items:stretch}.id-card-modal-actions button{min-width:0}.span-2{grid-column:span 1}}.modern-table td.right,.modern-table th.right{text-align:right}.modern-table td.center,.modern-table th.center{text-align:center}.modern-table td.bold,.text-ok-val{font-weight:700}.text-ok-val{color:var(--ok)}.text-danger-val{color:var(--danger);font-weight:700}.badge-sm{font-size:11px;color:var(--muted);font-weight:500}.empty-row{text-align:center;padding:32px 16px;color:var(--muted);font-size:14px}.history-scroll{max-height:360px;overflow-y:auto}.history-empty{text-align:center;padding:24px 0}.form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.form-group label{font-size:13px;font-weight:600;color:var(--ink-light)}.form-group input,.form-group select,.form-group textarea{padding:10px 12px;border:1px solid var(--line);border-radius:10px;font-size:14px;color:var(--ink);background:var(--bg);outline:none;transition:border-color .15s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--accent)}.badge.status-active{background:var(--ok-bg);color:var(--ok)}.badge.status-error{background:var(--danger-bg);color:var(--danger)}.badge.status-warning{background:var(--gold-bg);color:var(--gold)}.danger-button.small,.ghost-button.small,.primary-button.small,.secondary-button.small,.small-button{padding:6px 12px;font-size:12px;border-radius:8px;gap:6px}.small-button{background:var(--bg);color:var(--ink-light);border:1px solid var(--line);box-shadow:var(--shadow-sm);display:inline-flex;align-items:center;justify-content:center;font-weight:600;cursor:pointer;transition:all .2s ease;white-space:nowrap}.small-button:hover{background:#F1F5F9;color:var(--ink);transform:translateY(-1px)}.small-button.primary{background:var(--accent);color:white;border-color:transparent}.small-button.primary:hover{background:var(--accent-strong);color:white}.small-button.danger{background:var(--danger-bg);color:var(--danger);border-color:transparent}.small-button.danger:hover{background:var(--danger);color:white}.action-group{display:flex;align-items:center;gap:6px;justify-content:flex-end;flex-wrap:wrap}.mark-input{width:72px;padding:6px 10px;border:1px solid var(--line);border-radius:8px;font-size:14px;color:var(--ink);background:var(--bg);outline:none;transition:border-color .15s;text-align:center}.mark-input:focus{border-color:var(--accent)}.mark-input:disabled{background:var(--line);color:var(--muted);cursor:not-allowed}.total-cap{font-size:13px;color:var(--muted);margin-left:6px}.modern-table td.col-narrow,.modern-table th.col-narrow{width:60px;text-align:center}.modern-table td.col-marks,.modern-table th.col-marks{width:160px}.secondary-button{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:10px;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s ease;background:var(--bg);color:var(--ink-light);border:1px solid var(--line)}.secondary-button:hover{background:#F1F5F9;color:var(--ink)}.secondary-button.danger{color:var(--danger);border-color:var(--danger-bg)}.secondary-button.active,.secondary-button.danger:hover{background:var(--danger-bg)}.secondary-button.active{color:var(--danger);border-color:var(--danger-bg)}.title-stack{display:flex;flex-direction:column;gap:4px}.title-stack h3{margin:0;font-size:18px;font-weight:700;color:var(--ink)}.title-stack p{margin:0;font-size:13px;color:var(--muted)}.panel-actions-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.stats-divider{width:1px;height:24px;background:var(--line);flex-shrink:0}@media (max-width:900px){.stats-divider{display:none}}.attendance-toolbar{display:flex;gap:16px;align-items:center;flex-wrap:wrap}@media (max-width:900px){.attendance-toolbar{width:100%;margin-top:12px;justify-content:flex-start}}.notify-selector{display:flex;align-items:center;gap:8px}.notify-selector label{font-size:12px;font-weight:700;color:var(--ink-light);white-space:nowrap}.notify-selector select{padding:6px 10px;border:1px solid var(--line);border-radius:8px;font-size:13px;font-weight:600;outline:none;background:var(--bg);color:var(--ink);transition:border-color .15s}.notify-selector select:focus{border-color:var(--accent)}.quick-actions{display:flex;gap:8px}.toggle-group{gap:12px}.checkbox-wrap,.toggle-group{display:flex;align-items:center}.checkbox-wrap{gap:4px;cursor:pointer;font-size:11px;font-weight:700;color:var(--ink-light);-webkit-user-select:none;-moz-user-select:none;user-select:none}.checkbox-wrap input[type=checkbox]{cursor:pointer}.student-profile{display:flex;align-items:center;gap:10px;font-weight:600;color:var(--ink)}.mini-avatar{width:32px;height:32px;border-radius:50%;display:grid;place-items:center;color:white;font-size:12px;font-weight:800;flex-shrink:0;background:var(--accent)}.mini-avatar.present{background:var(--ok)}.mini-avatar.absent{background:var(--danger)}.mini-stats{display:flex;flex-direction:column;gap:2px}.mini-stats .count{font-size:12px;font-weight:700;color:var(--ink-light)}.mini-stats .percent{font-size:11px;font-weight:800;color:var(--ok)}.mini-stats .percent.low{color:var(--danger)}.status-pill{display:inline-flex;align-items:center;padding:4px 12px;border-radius:999px;font-size:11px;font-weight:700;text-transform:capitalize}.status-pill.present{background:var(--ok-bg);color:var(--ok)}.status-pill.absent{background:var(--danger-bg);color:var(--danger)}.status-pill.pending{background:#F1F5F9;color:var(--ink-light)}.action-buttons{display:flex;gap:8px;justify-content:center}.monthly-scroll{overflow-x:auto;max-width:100%}.monthly-table{min-width:1200px}.day-col{width:30px;text-align:center;font-size:10px!important;padding:10px 4px!important}.day-col.sunday-head{background:#E5E7EB!important;color:var(--danger)}.sticky-col{left:0;background:var(--panel)!important;border-right:2px solid var(--line);min-width:180px}.sticky-col,.sticky-right{position:-webkit-sticky;position:sticky;z-index:2}.sticky-right{right:0;background:var(--bg)!important;border-left:2px solid var(--line);width:80px}.day-status,.sticky-right{text-align:center;font-weight:700}.day-status{font-size:12px}.day-status.present{color:var(--ok);background:var(--ok-bg)}.day-status.absent{color:var(--danger);background:var(--danger-bg)}.day-status.sunday{background:#F3F4F6;color:var(--muted);font-size:10px}.student-cell{display:flex;flex-direction:column;gap:2px}.student-cell strong{font-size:13px;font-weight:700;color:var(--ink)}.student-cell small{font-size:11px;color:var(--muted)}.percent-cell{text-align:center}.student-history-view{display:flex;flex-direction:column;gap:20px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));grid-gap:16px;gap:16px}.stat-card{padding:28px 24px;text-align:center;border-radius:16px;background:var(--panel);border:1px solid var(--line);box-shadow:var(--shadow-sm)}.stat-card label{display:block;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--muted)}.stat-card h2{margin:12px 0 0;font-size:36px;font-weight:800;color:var(--ink)}.stat-card.highlight{border-top:4px solid var(--ok)}.stat-card.danger{border-top:4px solid var(--danger)}.stat-card.primary{border-top:4px solid var(--accent)}.low-text{color:var(--danger)}.qr-section{display:grid;grid-template-columns:1fr 380px;grid-gap:20px;gap:20px}.scanner-header{text-align:center;margin-bottom:16px}.scanner-header .icon{font-size:42px;display:block;margin-bottom:8px}.scanner-header h2{margin:0 0 4px;font-size:22px;font-weight:800;color:var(--ink)}.scanner-header p{margin:0;font-size:13px;color:var(--muted)}.camera-toggle-area{text-align:center;margin-bottom:12px}.camera-box{width:100%;max-width:400px;margin:0 auto 16px;border-radius:16px;overflow:hidden;border:3px solid var(--line);box-shadow:var(--shadow)}#reader{background:#000}#reader__dashboard_section_csr button{background:var(--accent)!important;color:white!important;border:none!important;padding:8px 16px!important;border-radius:6px!important;font-weight:600!important;margin:10px!important;cursor:pointer!important}#reader__camera_selection{padding:8px!important;border-radius:6px!important;border:1px solid var(--line)!important;margin:10px!important}.scan-form{gap:16px;margin:24px 0}.input-with-label,.scan-form{display:flex;flex-direction:column;align-items:center}.input-with-label{gap:6px;width:100%}.input-with-label label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--muted)}.scan-input{width:100%;max-width:450px;padding:16px 24px;font-size:20px;border:3px solid var(--line);border-radius:16px;outline:none;transition:border-color .2s,box-shadow .2s;text-align:center;font-weight:700;letter-spacing:2px;background:var(--bg);color:var(--ink)}.scan-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light);background:var(--panel)}.scan-overlay{position:fixed;inset:0;z-index:9999;display:flex;justify-content:center;align-items:center;background:rgba(0,0,0,.4);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .2s ease-out}.scan-popup{background:white;padding:40px;border-radius:24px;text-align:center;box-shadow:0 20px 40px rgba(0,0,0,.2);transform:scale(.9);animation:popIn .4s cubic-bezier(.175,.885,.32,1.275) forwards;max-width:400px;width:100%}@keyframes popIn{to{transform:scale(1);opacity:1}}.result-avatar{width:80px;height:80px;border-radius:16px;background:var(--bg);overflow:hidden;display:grid;place-items:center;font-size:32px;font-weight:800;color:var(--muted);box-shadow:var(--shadow-sm);flex-shrink:0}.result-avatar img{width:100%;height:100%;object-fit:cover}.popup-icon-container{margin-bottom:24px;display:flex;justify-content:center}.animated-icon{width:80px;height:80px;border-radius:50%;display:block;stroke-width:4;stroke:#fff;stroke-miterlimit:10;box-shadow:inset 0 0 0 #10b981;animation:fillIcon .4s ease-in-out .4s forwards,scaleIcon .3s ease-in-out .9s both}.animated-icon.success{stroke:#10b981;box-shadow:inset 0 0 0 #10b981;animation:fillSuccess .4s ease-in-out .4s forwards,scaleIcon .3s ease-in-out .9s both}.animated-icon.warning{stroke:var(--gold);box-shadow:inset 0 0 0 var(--gold);animation:fillWarning .4s ease-in-out .4s forwards,scaleIcon .3s ease-in-out .9s both}.checkmark-circle,.warning-circle{stroke-dasharray:166;stroke-dashoffset:166;stroke-width:4;stroke-miterlimit:10;fill:none;animation:strokeCircle .6s cubic-bezier(.65,0,.45,1) forwards}.checkmark-check{stroke-dasharray:48;stroke-dashoffset:48}.checkmark-check,.warning-line{transform-origin:50% 50%;animation:strokeCheck .3s cubic-bezier(.65,0,.45,1) .8s forwards}.warning-line{stroke-dasharray:20;stroke-dashoffset:20}@keyframes strokeCircle{to{stroke-dashoffset:0}}@keyframes strokeCheck{to{stroke-dashoffset:0}}@keyframes fillSuccess{to{box-shadow:inset 0 0 0 50px #10b981;stroke:#fff}}@keyframes fillWarning{to{box-shadow:inset 0 0 0 50px var(--gold);stroke:#fff}}@keyframes scaleIcon{0%,to{transform:none}50%{transform:scale3d(1.1,1.1,1)}}.today-log{display:flex;flex-direction:column}.log-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.log-header h2{margin:0;font-size:18px;font-weight:700;color:var(--ink)}.count-pill{padding:4px 10px;background:var(--accent);color:white;border-radius:999px;font-size:12px;font-weight:700}.log-list{display:flex;flex-direction:column;gap:8px}.log-item{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--bg);border-radius:12px;font-size:13px;transition:all .2s;border:1px solid transparent}.log-item:hover{background:var(--panel);border-color:var(--line);transform:translateX(4px);box-shadow:var(--shadow-sm)}.log-time{font-weight:700;color:var(--muted);white-space:nowrap}.log-name{flex:1 1;font-weight:600;color:var(--ink)}.log-type{padding:2px 6px;border-radius:4px;font-size:10px;font-weight:800}.log-type.std{background:#DBEAFE;color:var(--blue)}.log-type.stf{background:var(--danger-bg);color:var(--danger)}.log-status{color:var(--ok);font-weight:700;font-size:12px}.empty-log{text-align:center;padding:32px 0;color:var(--muted);font-size:13px}.fade-in{animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateX(-8px)}to{opacity:1;transform:translateX(0)}}.staff-name-display{padding:10px 14px;border:1px solid var(--line);border-radius:10px;background:var(--bg);font-weight:600;color:var(--ink);font-size:14px}@media (max-width:768px){.qr-section{grid-template-columns:1fr}.stats-grid{grid-template-columns:1fr 1fr}.panel-actions-row{gap:8px}.stats-divider{display:none}.scan-input{max-width:100%;font-size:16px;padding:14px 16px}.scan-result,.status-line{flex-direction:column;align-items:flex-start}.status-line{gap:6px}.log-item{flex-wrap:wrap}}.form-steps-nav{background:var(--bg);border:1px solid var(--line);border-radius:12px;padding:12px 20px;margin-bottom:20px;gap:12px}.form-steps-nav,.step-nav-btn{display:flex;align-items:center}.step-nav-btn{background:none;border:none;gap:10px;cursor:pointer;padding:6px 12px;border-radius:8px;transition:all .2s ease;text-align:left}.step-nav-btn:hover{background:var(--line)}.step-num{width:28px;height:28px;border-radius:50%;background:#cbd5e1;color:#fff;display:grid;place-items:center;font-size:13px;font-weight:800;transition:all .2s ease}.step-nav-btn.active .step-num{background:var(--accent)}.step-label{display:flex;flex-direction:column}.step-title{font-size:13px;font-weight:700;color:var(--muted);transition:all .2s ease}.step-nav-btn.active .step-title{color:var(--ink)}.step-desc{font-size:10px;color:var(--muted)}.step-nav-line{flex:1 1;height:2px;background:var(--line);border-radius:2px;min-width:10px}.step-content-fade{display:flex;flex-direction:column;gap:16px}.enrollment-grid-compact{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));grid-gap:14px 16px;gap:14px 16px}@media (max-width:720px){.form-steps-nav{flex-direction:column;align-items:stretch;gap:10px;padding:10px 14px}.step-nav-line{display:none}.step-nav-btn{width:100%;padding:6px}.enrollment-grid-compact{grid-template-columns:1fr}}.student-step-personal-layout{display:grid;grid-template-columns:1.5fr 1fr;grid-gap:20px;gap:20px;align-items:start}.student-step-row-layout{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:20px;gap:20px;align-items:start}.form-field-vertical-stack{display:flex;flex-direction:column;gap:12px}.student-form-fields-column{display:flex;flex-direction:column;gap:16px}.student-photo-column{position:-webkit-sticky;position:sticky;top:20px}.photo-upload-row-vertical{display:flex;flex-direction:column;align-items:center;gap:12px;background:var(--bg);border:1px solid var(--line);padding:20px;border-radius:12px}@media (max-width:900px){.student-step-personal-layout,.student-step-row-layout{grid-template-columns:1fr}.student-photo-column{position:static}}.premium-summary-card{display:flex;flex-direction:column;background:var(--bg);border:1px solid var(--line);padding:18px;border-radius:12px;box-sizing:border-box}.summary-item{display:flex;gap:12px;align-items:flex-start}.summary-icon{font-size:20px;background:#f1f5f9;width:38px;height:38px;border-radius:50%;display:grid;place-items:center;flex-shrink:0}.summary-item strong{display:block;font-size:13px;color:var(--ink);margin-bottom:2px}.summary-item p{margin:0;font-size:11px;color:var(--muted)}.breakdown-row{display:flex;justify-content:space-between;align-items:center;font-size:12px;padding:6px 0;color:var(--ink-light)}.breakdown-row strong{color:var(--ink)}.breakdown-row.concession{background:rgba(34,197,94,.05);padding:6px 8px;border-radius:6px;margin-top:4px}.breakdown-divider{height:1px;background:var(--line);margin:10px 0}.breakdown-row.total{font-size:13px;font-weight:800;padding-top:4px}.staff-photo-panel{background:var(--bg);border:1px solid var(--line);border-radius:14px;padding:20px;display:flex;flex-direction:column;gap:16px;position:-webkit-sticky;position:sticky;top:20px}.staff-photo-header{display:flex;align-items:center;gap:12px}.staff-photo-icon-ring{font-size:20px;width:40px;height:40px;border-radius:50%;background:var(--accent-soft,rgba(22,163,74,.1));display:grid;place-items:center;flex-shrink:0;border:1.5px solid var(--line)}.staff-photo-dropzone{display:flex;align-items:center;justify-content:center;border:2px dashed var(--line);border-radius:12px;width:100%;aspect-ratio:1;max-height:180px;cursor:pointer;overflow:hidden;transition:border-color .2s,background .2s;background:var(--surface,#f8fafc)}.staff-photo-dropzone:hover{border-color:var(--accent);background:rgba(22,163,74,.04)}.staff-photo-placeholder{display:flex;flex-direction:column;align-items:center;gap:6px;padding:12px;text-align:center}.staff-photo-plus{font-size:28px;color:var(--muted);line-height:1;margin-bottom:4px}.staff-photo-preview-img{width:100%;height:100%;object-fit:cover;border-radius:10px}.staff-photo-tips{display:flex;flex-direction:column;gap:7px;padding-top:4px;border-top:1px solid var(--line)}.staff-tip-row{display:flex;align-items:center;gap:8px;font-size:11px;color:var(--ink-light)}.tip-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.tip-dot.good{background:#22c55e}.tip-dot.neutral{background:#f59e0b}.tip-dot.bad{background:#ef4444}.staff-salary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));grid-gap:14px;gap:14px}.salary-input-card{background:var(--bg);border:1px solid var(--line);border-radius:10px;padding:14px 16px;display:flex;flex-direction:column;gap:8px}.salary-input-label{font-size:12px;font-weight:700;color:var(--ink-light);text-transform:uppercase;letter-spacing:.04em}.salary-input-wrap{display:flex;align-items:center;border:1.5px solid var(--line);border-radius:8px;overflow:hidden;background:var(--surface,#f8fafc);transition:border-color .2s}.salary-input-wrap:focus-within{border-color:var(--accent);background:var(--bg)}.salary-currency{padding:8px 10px;font-size:14px;font-weight:700;color:var(--muted);border-right:1.5px solid var(--line);background:var(--bg);flex-shrink:0}.salary-input-wrap input{border:none!important;background:transparent!important;padding:8px 12px!important;font-size:15px;font-weight:600;color:var(--ink);flex:1 1;min-width:0;box-shadow:none!important;outline:none!important}.salary-input-desc{font-size:11px;color:var(--muted)}.salary-calc-panel{background:var(--bg);border:1px solid var(--line);border-radius:14px;padding:20px;display:flex;flex-direction:column;gap:16px;position:-webkit-sticky;position:sticky;top:20px}.salary-calc-header{display:flex;align-items:center;gap:12px;padding-bottom:12px;border-bottom:1px solid var(--line)}.salary-calc-rows{display:flex;flex-direction:column;gap:8px}.salary-calc-row{display:flex;justify-content:space-between;align-items:center;font-size:12px;color:var(--ink-light);padding:6px 0}.salary-calc-row.deduct{opacity:.8}.salary-calc-row strong{color:var(--ink);font-size:13px}.salary-calc-total{padding:12px 14px;background:linear-gradient(135deg,rgba(22,163,74,.06),rgba(16,185,129,.06));border:1px solid rgba(22,163,74,.15);border-radius:10px;font-size:13px;font-weight:700;color:var(--ink)}.salary-calc-annual,.salary-calc-total{display:flex;justify-content:space-between;align-items:center}.salary-calc-annual{padding:6px 2px;border-top:1px dashed var(--line)}.salary-guide-rules{display:flex;flex-direction:column;gap:8px;padding-top:4px;border-top:1px solid var(--line)}.salary-rule-item{display:flex;align-items:center;gap:10px;font-size:11px}.rule-badge{display:inline-block;padding:2px 8px;border-radius:20px;font-size:10px;font-weight:700;letter-spacing:.03em;flex-shrink:0}.rule-badge.blue{background:rgba(59,130,246,.12);color:#2563eb}.rule-badge.green{background:rgba(34,197,94,.12);color:#16a34a}.rule-badge.orange{background:rgba(245,158,11,.12);color:#d97706}.rule-badge.red{background:rgba(239,68,68,.12);color:#dc2626}.rule-text{color:var(--ink-light)}