:root{--color-primary:#1e3a5f;--color-primary-light:#2d5a8e;--color-primary-dark:#142942;--color-primary-pale:#e8eef6;--color-accent:#4a90d9;--color-accent-light:#6ba8e8;--color-accent-pastel:#b8d4f0;--color-success:#5ba88c;--color-success-pastel:#d4eddf;--color-success-dark:#3d8b6e;--color-warning:#d4a056;--color-warning-pastel:#fef3cd;--color-danger:#c95c5c;--color-danger-pastel:#f8d7da;--color-surface:#f4f6fb;--color-card:#fff;--color-sidebar:#1e3a5f;--color-sidebar-hover:#2a4f7a;--color-sidebar-active:#345d8f;--text-primary:#1a2332;--text-secondary:#5a6a7e;--text-muted:#8e9bae;--text-inverse:#fff;--text-on-primary:#e8eef6;--border-color:#dde3ed;--border-light:#edf1f7;--radius-sm:6px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--radius-pill:50px;--shadow-sm:0 1px 2px #1e3a5f0f;--shadow-md:0 1px 3px #1e3a5f14, 0 4px 12px #1e3a5f0a;--shadow-lg:0 4px 6px #1e3a5f12, 0 10px 24px #1e3a5f0f;--shadow-xl:0 10px 25px #1e3a5f1a, 0 20px 48px #1e3a5f14;--transition-fast:.15s ease;--transition-base:.2s ease;--transition-slow:.3s ease;--sidebar-width:260px;--sidebar-collapsed-width:0px;--header-height:64px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{color:var(--text-primary);background-color:var(--color-surface);min-height:100vh;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6}a{color:var(--color-accent);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--color-primary-light)}h1,h2,h3,h4,h5,h6{color:var(--text-primary);font-weight:600;line-height:1.3}h1{font-size:1.75rem}h2{font-size:1.5rem}h3{font-size:1.25rem}h4{font-size:1.125rem}.text-muted{color:var(--text-muted)}.text-secondary{color:var(--text-secondary)}.login-page{background:linear-gradient(135deg,#1e3a5f 0%,#2d5a8e 40%,#4a90d9 100%);justify-content:center;align-items:center;min-height:100vh;padding:1rem;display:flex;position:relative;overflow:hidden}.login-page:before{content:"";background:radial-gradient(at 30% 20%,#4a90d926 0%,#0000 60%),radial-gradient(at 80% 80%,#1e3a5f1a 0%,#0000 50%);width:200%;height:200%;animation:20s ease-in-out infinite alternate loginBgShift;position:absolute;top:-50%;left:-50%}@keyframes loginBgShift{0%{transform:translate(0)rotate(0)}to{transform:translate(-2%,-1%)rotate(1deg)}}.login-card{background:var(--color-card);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:100%;max-width:420px;padding:2.5rem;animation:.5s ease-out loginCardIn;position:relative}@keyframes loginCardIn{0%{opacity:0;transform:translateY(20px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}.login-brand{text-align:center;margin-bottom:2rem}.login-brand-icon{background:linear-gradient(135deg, var(--color-primary) 0%, var(--color-accent) 100%);border-radius:var(--radius-lg);justify-content:center;align-items:center;width:56px;height:56px;margin-bottom:1rem;display:inline-flex;box-shadow:0 4px 12px #1e3a5f33}.login-brand-icon svg{color:#fff;width:28px;height:28px}.login-brand h1{margin-bottom:.25rem;font-size:1.5rem}.login-brand p{color:var(--text-muted);font-size:.875rem}.app-layout{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-width);background:var(--color-sidebar);z-index:100;height:100vh;transition:transform var(--transition-slow);flex-direction:column;display:flex;position:fixed;top:0;left:0;overflow-y:auto}.sidebar-brand{border-bottom:1px solid #ffffff1a;align-items:center;gap:.75rem;padding:1.25rem 1.5rem;display:flex}.sidebar-brand-icon{background:linear-gradient(135deg, var(--color-accent) 0%, var(--color-primary-light) 100%);border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.sidebar-brand-icon svg{color:#fff;width:20px;height:20px}.sidebar-brand-text{color:var(--text-inverse);font-size:1rem;font-weight:600;line-height:1.3}.sidebar-brand-text small{color:var(--text-on-primary);opacity:.6;margin-top:2px;font-size:.7rem;font-weight:400;display:block}.sidebar-nav{flex:1;padding:1rem 0}.sidebar-nav-label{text-transform:uppercase;letter-spacing:.08em;color:#ffffff59;margin-top:.5rem;padding:.5rem 1.5rem;font-size:.65rem;font-weight:600}.sidebar-link{color:#ffffffb3;transition:all var(--transition-fast);border-left:3px solid #0000;align-items:center;gap:.75rem;padding:.625rem 1.5rem;font-size:.875rem;font-weight:500;display:flex}.sidebar-link:hover{background:var(--color-sidebar-hover);color:var(--text-inverse)}.sidebar-link.active{background:var(--color-sidebar-active);color:var(--text-inverse);border-left-color:var(--color-accent)}.sidebar-link svg{opacity:.8;flex-shrink:0;width:20px;height:20px}.sidebar-link.active svg{opacity:1}.sidebar-footer{border-top:1px solid #ffffff1a;padding:1rem 1.5rem}.sidebar-user{align-items:center;gap:.75rem;display:flex}.sidebar-user-avatar{background:linear-gradient(135deg, var(--color-accent) 0%, var(--color-primary-light) 100%);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:.875rem;font-weight:600;display:flex}.sidebar-user-info{overflow:hidden}.sidebar-user-name{color:var(--text-inverse);white-space:nowrap;text-overflow:ellipsis;font-size:.875rem;font-weight:500;overflow:hidden}.sidebar-user-role{color:#ffffff80;text-transform:capitalize;font-size:.7rem}.main-content{margin-left:var(--sidebar-width);flex-direction:column;flex:1;min-height:100vh;display:flex}.content-header{background:var(--color-card);border-bottom:1px solid var(--border-color);height:var(--header-height);z-index:50;justify-content:space-between;align-items:center;padding:1rem 2rem;display:flex;position:sticky;top:0}.content-header h1{font-size:1.25rem;font-weight:600}.mobile-toggle{color:var(--text-primary);cursor:pointer;border-radius:var(--radius-sm);transition:background var(--transition-fast);background:0 0;border:none;padding:.5rem;display:none}.mobile-toggle:hover{background:var(--color-primary-pale)}.mobile-toggle svg{width:24px;height:24px}.content-body{flex:1;padding:1.5rem 2rem}.sidebar-overlay{z-index:99;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0006;display:none;position:fixed;inset:0}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1.5rem;display:grid}.stat-card{background:var(--color-card);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);transition:all var(--transition-base);align-items:flex-start;gap:1rem;padding:1.25rem;display:flex}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.stat-icon{border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.stat-icon svg{width:22px;height:22px}.stat-icon.blue{background:var(--color-primary-pale);color:var(--color-primary)}.stat-icon.green{background:var(--color-success-pastel);color:var(--color-success)}.stat-icon.amber{background:var(--color-warning-pastel);color:var(--color-warning)}.stat-icon.purple{color:#7c4dff;background:#ede7f6}.stat-value{color:var(--text-primary);font-size:1.5rem;font-weight:700;line-height:1.2}.stat-label{color:var(--text-muted);margin-top:.125rem;font-size:.8rem}.card{background:var(--color-card);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-sm)}.card-header{border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;display:flex}.card-header h2,.card-header h3{font-size:1rem;font-weight:600}.card-body{padding:1.5rem}.card-footer{border-top:1px solid var(--border-light);align-items:center;gap:.75rem;padding:1rem 1.5rem;display:flex}.form-group{margin-bottom:1.25rem}.form-label{color:var(--text-primary);margin-bottom:.375rem;font-size:.8125rem;font-weight:600;display:block}.form-label .required{color:var(--color-danger);margin-left:2px}.form-hint{color:var(--text-muted);margin-top:.25rem;font-size:.75rem}.form-input,.form-select,.form-textarea{border:1px solid var(--border-color);border-radius:var(--radius-sm);width:100%;color:var(--text-primary);background:var(--color-card);transition:all var(--transition-fast);outline:none;padding:.625rem .875rem;font-family:inherit;font-size:.875rem}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px #4a90d926}.form-input::placeholder,.form-textarea::placeholder{color:var(--text-muted)}.form-textarea{resize:vertical;min-height:100px}.form-input.error,.form-select.error,.form-textarea.error{border-color:var(--color-danger);box-shadow:0 0 0 3px #c95c5c1a}.form-error{color:var(--color-danger);margin-top:.25rem;font-size:.75rem}.form-row{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;display:grid}.form-checkbox{cursor:pointer;align-items:center;gap:.5rem;display:flex}.form-checkbox input[type=checkbox]{width:16px;height:16px;accent-color:var(--color-primary);cursor:pointer;border-radius:4px}.form-checkbox label{color:var(--text-secondary);cursor:pointer;font-size:.875rem}.btn{border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;border:1px solid #0000;justify-content:center;align-items:center;gap:.5rem;padding:.625rem 1.25rem;font-family:inherit;font-size:.875rem;font-weight:500;line-height:1.4;text-decoration:none;display:inline-flex}.btn:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.btn svg{width:18px;height:18px}.btn-primary{background:var(--color-primary);color:var(--text-inverse)}.btn-primary:hover{background:var(--color-primary-light);color:var(--text-inverse);box-shadow:var(--shadow-md)}.btn-secondary{background:var(--color-primary-pale);color:var(--color-primary);border-color:var(--border-color)}.btn-secondary:hover{color:var(--color-primary);background:#dce5f2}.btn-danger{background:var(--color-danger);color:var(--text-inverse)}.btn-danger:hover{color:var(--text-inverse);background:#b54a4a}.btn-ghost{color:var(--text-secondary);background:0 0}.btn-ghost:hover{background:var(--color-primary-pale);color:var(--color-primary)}.btn-sm{padding:.375rem .75rem;font-size:.8125rem}.btn-lg{padding:.75rem 1.5rem;font-size:1rem}.btn-block{width:100%;display:flex}.badge{border-radius:var(--radius-pill);letter-spacing:.02em;align-items:center;padding:.2rem .625rem;font-size:.7rem;font-weight:600;display:inline-flex}.badge-morning{background:var(--color-warning-pastel);color:#8a6d2f}.badge-afternoon{background:var(--color-accent-pastel);color:var(--color-primary)}.badge-night{color:#4a3d8f;background:#e3e1f0}.badge-admin{background:var(--color-primary-pale);color:var(--color-primary)}.badge-staff{background:var(--color-success-pastel);color:var(--color-success-dark)}.table-wrapper{border-radius:var(--radius-md);overflow-x:auto}.table{border-collapse:collapse;width:100%;font-size:.875rem}.table thead th{background:var(--color-primary-pale);text-align:left;color:var(--text-primary);white-space:nowrap;border-bottom:1px solid var(--border-color);padding:.75rem 1rem;font-size:.8rem;font-weight:600}.table thead th a{color:var(--text-primary);align-items:center;gap:.25rem;display:inline-flex}.table thead th a:hover{color:var(--color-primary-light)}.table tbody tr{border-bottom:1px solid var(--border-light);transition:background var(--transition-fast)}.table tbody tr:hover{background:#e8eef680}.table tbody td{color:var(--text-secondary);vertical-align:top;padding:.75rem 1rem}.table tbody td.text-truncate{text-overflow:ellipsis;white-space:nowrap;max-width:250px;overflow:hidden}.filter-bar{background:var(--color-card);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);margin-bottom:1rem;padding:1rem 1.25rem}.filter-bar-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;align-items:center;gap:.5rem;margin-bottom:.75rem;font-size:.8rem;font-weight:600;display:flex}.filter-bar-title svg{width:16px;height:16px}.filter-row{flex-wrap:wrap;align-items:flex-end;gap:.75rem;display:flex}.filter-group{flex-direction:column;gap:.25rem;min-width:140px;display:flex}.filter-group label{color:var(--text-secondary);font-size:.75rem;font-weight:500}.filter-group .form-input,.filter-group .form-select{padding:.5rem .75rem;font-size:.8125rem}.alert{border-radius:var(--radius-md);border:1px solid #0000;align-items:center;gap:.75rem;margin-bottom:1rem;padding:.875rem 1.25rem;font-size:.875rem;animation:.3s ease-out alertIn;display:flex}@keyframes alertIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.alert svg{flex-shrink:0;width:20px;height:20px}.alert-success{background:var(--color-success-pastel);color:var(--color-success-dark);border-color:#5da88c33}.alert-danger{background:var(--color-danger-pastel);color:var(--color-danger);border-color:#c95c5c33}.alert-warning{background:var(--color-warning-pastel);color:#8a6d2f;border-color:#d4a05633}.alert-info{background:var(--color-primary-pale);color:var(--color-primary);border-color:#4a90d933}.alert-dismissible{padding-right:3rem;position:relative}.alert-close{cursor:pointer;color:inherit;opacity:.6;border-radius:var(--radius-sm);transition:opacity var(--transition-fast);background:0 0;border:none;padding:.25rem;position:absolute;top:50%;right:.75rem;transform:translateY(-50%)}.alert-close:hover{opacity:1}.pagination-wrapper{justify-content:space-between;align-items:center;padding:1rem 0;font-size:.875rem;display:flex}.pagination-info{color:var(--text-muted)}.pagination{gap:.25rem;list-style:none;display:flex}.pagination li a,.pagination li span{border-radius:var(--radius-sm);min-width:36px;height:36px;color:var(--text-secondary);transition:all var(--transition-fast);justify-content:center;align-items:center;padding:0 .5rem;font-size:.8125rem;font-weight:500;display:inline-flex}.pagination li a:hover{background:var(--color-primary-pale);color:var(--color-primary)}.pagination li.active span{background:var(--color-primary);color:var(--text-inverse)}.pagination li.disabled span{color:var(--text-muted);opacity:.5}.detail-grid{gap:1.25rem;display:grid}.detail-section{border-bottom:1px solid var(--border-light);padding-bottom:1.25rem}.detail-section:last-child{border-bottom:none;padding-bottom:0}.detail-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;align-items:center;gap:.5rem;margin-bottom:.5rem;font-size:.75rem;font-weight:600;display:flex}.detail-label svg{width:16px;height:16px;color:var(--color-accent)}.detail-content{color:var(--text-secondary);white-space:pre-wrap;word-wrap:break-word;font-size:.9375rem;line-height:1.7}.detail-meta{flex-wrap:wrap;gap:1.5rem;padding:1rem 0;display:flex}.detail-meta-item{flex-direction:column;gap:.125rem;display:flex}.detail-meta-label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-size:.7rem;font-weight:600}.detail-meta-value{color:var(--text-primary);font-size:.9375rem;font-weight:500}.empty-state{text-align:center;color:var(--text-muted);padding:3rem 2rem}.empty-state svg{opacity:.4;width:56px;height:56px;margin-bottom:1rem}.empty-state h3{color:var(--text-secondary);margin-bottom:.5rem;font-size:1.1rem}.empty-state p{font-size:.875rem}@media (width<=768px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.sidebar-overlay.show{display:block}.main-content{margin-left:0}.mobile-toggle{display:flex}.content-header,.content-body{padding:1rem 1.25rem}.stats-grid{grid-template-columns:repeat(2,1fr)}.filter-row{flex-direction:column}.filter-group{width:100%}.form-row{grid-template-columns:1fr}.card-footer{flex-wrap:wrap}.detail-meta,.pagination-wrapper{flex-direction:column;gap:.75rem}}@media (width<=480px){.stats-grid{grid-template-columns:1fr}.login-card{padding:1.75rem}}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.text-right{text-align:right}.text-center{text-align:center}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-1{gap:.5rem}.gap-2{gap:1rem}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;opacity:0;transition:opacity var(--transition-base);background:#0f172a99;justify-content:center;align-items:center;display:none;position:fixed;inset:0}.modal-overlay.show{opacity:1;display:flex}.modal-box{background:var(--color-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);width:100%;max-width:600px;max-height:90vh;transition:transform var(--transition-base);overflow-y:auto;transform:scale(.95)}.modal-overlay.show .modal-box{transform:scale(1)}.modal-header{border-bottom:1px solid var(--border-light);background:var(--color-card);z-index:10;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;display:flex;position:sticky;top:0}.modal-title{font-size:1.125rem;font-weight:600}.modal-close{cursor:pointer;color:var(--text-muted);border-radius:var(--radius-sm);background:0 0;border:none;padding:.25rem}.modal-close:hover{background:var(--color-primary-pale);color:var(--text-primary)}.modal-body{padding:1.5rem}.attendance-widget{background:linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-light) 100%);color:#fff;border-radius:var(--radius-md);box-shadow:var(--shadow-md);text-align:center;margin-bottom:1.5rem;padding:2rem}.attendance-widget h2{color:#fff;margin-bottom:1rem;font-size:1.5rem}.attendance-status{border-radius:var(--radius-pill);background:#ffffff1a;margin-bottom:1.5rem;padding:.5rem 1rem;font-size:1.125rem;font-weight:600;display:inline-block}.attendance-buttons{flex-wrap:wrap;justify-content:center;gap:1rem;display:flex}
