:root{font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.5;font-weight:400;color:#e9eef5;background-color:#0b0f17;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{margin:0;min-height:100vh;background:radial-gradient(circle at 20% 20%,#162032,#0b0f17 55%),radial-gradient(circle at 80% 0%,#111a2a,transparent 50%)}a{color:inherit;text-decoration:none}#root{min-height:100vh;background:transparent}.top-nav{position:sticky;top:0;z-index:2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0b0f17b3;border-bottom:1px solid rgba(255,255,255,.06)}.top-nav-inner{max-width:1100px;margin:0 auto;padding:14px 24px;display:flex;align-items:center;justify-content:space-between;gap:12px}.brand{display:flex;flex-direction:column;gap:2px}.brand-title{font-size:18px;letter-spacing:.04em;color:#9fc3ff;font-weight:800;text-transform:uppercase}.brand-subtitle{color:#8aa0c5;font-size:13px;margin:0}.app-shell{max-width:1100px;margin:0 auto;padding:32px 24px 64px}.page{background:#ffffff0a;border:1px solid rgba(255,255,255,.06);border-radius:16px;padding:28px;box-shadow:0 18px 44px #00000059;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:24px}.page-title{margin:0;font-size:30px;font-weight:750;color:#f2f5fb}.subtitle{margin:4px 0 0;color:#c7d4ee;font-size:15px}.card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:18px;margin-top:10px}.action-card{display:flex;flex-direction:column;gap:10px;padding:22px;background:linear-gradient(145deg,#111827,#0d1421);border:1px solid rgba(255,255,255,.08);border-radius:14px;transition:transform .16s ease,border-color .16s ease,box-shadow .18s ease}.action-card:hover{transform:translateY(-3px);border-color:#3a6bff;box-shadow:0 10px 32px #3a6bff2e}.card-title{margin:0;font-size:20px;font-weight:700}.card-desc{margin:0;color:#d0daf0;font-size:14px}.primary-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:11px 14px;border-radius:12px;border:1px solid #3a6bff;background:linear-gradient(135deg,#3553ff,#5f7cff);color:#f6f8ff;font-weight:700;cursor:pointer;transition:transform .14s ease,box-shadow .14s ease;font-size:14px}.secondary-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 12px;border-radius:10px;border:1px solid rgba(255,255,255,.12);background:#ffffff0a;color:#e6edff;font-weight:650;cursor:pointer;transition:border-color .14s ease,background .14s ease;font-size:14px}.secondary-btn:hover{border-color:#ffffff47;background:#ffffff12}.primary-btn:disabled{opacity:.45;cursor:not-allowed;transform:none;box-shadow:none}.primary-btn:not(:disabled):hover{transform:translateY(-1px);box-shadow:0 8px 26px #3f6fff52}.input-group{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.input-label{font-weight:650;color:#c8d4ec;font-size:14px}.text-input{width:100%;padding:12px 14px;border-radius:10px;border:1px solid rgba(255,255,255,.08);background:#ffffff0a;color:#f8fbff;font-size:15px;outline:none;transition:border-color .15s ease,box-shadow .15s ease}.text-input:focus{border-color:#4f7cff;box-shadow:0 0 0 3px #4f7cff2e}.stack{display:flex;flex-direction:column;gap:16px}.qr-card{display:flex;flex-direction:column;align-items:center;gap:10px;padding:20px;border-radius:14px;background:#0d1320;border:1px solid rgba(255,255,255,.07)}.helper{color:#8ca3c8;margin:0}.scanner-wrapper{display:grid;gap:18px;grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}.panel{padding:18px;border-radius:14px;border:1px solid rgba(255,255,255,.07);background:#0e1524}.panel-title{margin:0 0 10px;font-size:18px}#reader{width:100%;min-height:260px;border-radius:14px;overflow:hidden;background:#0a111d;border:1px dashed rgba(255,255,255,.18)}.status{padding:12px;border-radius:12px;background:#3a6bff14;color:#e0e7ff;border:1px solid rgba(58,107,255,.4);font-size:14px}.modal{position:fixed;inset:0;display:grid;place-items:center;background:#0000008c;z-index:10;padding:16px}.modal-card{max-width:420px;width:100%;background:#0f1728;border-radius:16px;border:1px solid rgba(255,255,255,.1);padding:22px;box-shadow:0 20px 60px #00000073}.modal-card h3{margin:0 0 8px}.modal-card p{margin:0 0 16px;color:#cdd8ef}.modal-actions{display:flex;justify-content:flex-end}.card,.table-wrapper{background:#ffffff0a;border:1px solid rgba(255,255,255,.06);border-radius:12px}.table-wrapper{padding:12px;overflow:auto}.attendance-table{width:100%;border-collapse:collapse;font-size:14px}.attendance-table th,.attendance-table td{padding:10px 12px;text-align:left}.attendance-table th{color:#cfdaf4;font-weight:700;border-bottom:1px solid rgba(255,255,255,.08)}.attendance-table tr:not(:last-child) td{border-bottom:1px solid rgba(255,255,255,.04)}.muted{color:#c0cce5;font-size:14px;margin:0}.pill{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;background:#3f6fff1f;color:#c8d7ff;font-weight:650;font-size:13px}
