:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.login-card{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0000001a;padding:40px;width:100%;max-width:420px}.login-header{text-align:center;margin-bottom:32px}.login-header h1{font-size:28px;font-weight:700;color:#1a202c;margin-bottom:8px}.login-header p{color:#718096;font-size:14px}.login-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-size:14px;font-weight:600;color:#2d3748}.form-group input{padding:12px 16px;border:2px solid #e2e8f0;border-radius:8px;font-size:16px;transition:all .2s}.form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group input:disabled{background-color:#f7fafc;cursor:not-allowed}.form-group small{color:#718096;font-size:12px}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:14px 24px;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #667eea4d}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{background:#fff;color:#667eea;border:2px solid #667eea;padding:12px 24px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.btn-secondary:hover:not(:disabled){background:#f7fafc}.error-message{padding:12px;background-color:#fff5f5;border:1px solid #fc8181;border-radius:6px;color:#c53030;font-size:14px}.success-message{padding:12px;background-color:#f0fff4;border:1px solid #68d391;border-radius:6px;color:#22543d;font-size:14px}.login-footer{margin-top:24px;text-align:center}.login-footer p{color:#718096;font-size:13px;line-height:1.6}.dashboard-container{min-height:100vh;background:#f7fafc}.dashboard-header{background:#fff;box-shadow:0 1px 3px #0000001a;padding:16px 24px}.header-content{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center}.dashboard-header h1{font-size:24px;font-weight:700;color:#1a202c;margin:0}.header-actions{display:flex;align-items:center;gap:16px}.user-email{color:#4a5568;font-size:14px}.btn-logout{background:#e53e3e;color:#fff;border:none;padding:8px 16px;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.btn-admin{background:#667eea;color:#fff;border:none;padding:8px 16px;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;margin-right:10px}.btn-admin:hover{background:#5a67d8}.time-display{text-align:center;margin-bottom:32px}.current-time{font-size:48px;font-weight:700;color:#2d3748;margin-bottom:8px}.current-date{font-size:18px;color:#718096}.alert{padding:16px;border-radius:8px;margin-bottom:24px;font-size:14px;font-weight:500}.alert-error{background-color:#fff5f5;border:1px solid #fc8181;color:#c53030}.alert-success{background-color:#f0fff4;border:1px solid #68d391;color:#22543d}.alert-info{background-color:#ebf8ff;border:1px solid #63b3ed;color:#2c5282}.bssid-input{background:#fff;padding:20px;border-radius:8px;box-shadow:0 1px 3px #0000001a;margin-bottom:32px}.bssid-input label{display:block;font-size:14px;font-weight:600;color:#2d3748;margin-bottom:8px}.bssid-input input{width:100%;padding:10px 14px;border:2px solid #e2e8f0;border-radius:6px;font-size:14px;font-family:Courier New,monospace;transition:all .2s}.bssid-input input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.bssid-input small{display:block;margin-top:6px;color:#718096;font-size:12px}.check-in-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;margin-bottom:32px}.check-in-card{background:#fff;padding:24px;border-radius:12px;box-shadow:0 2px 8px #0000001a;transition:all .2s}.check-in-card:hover{box-shadow:0 4px 12px #00000026}.check-in-card h3{font-size:20px;font-weight:700;color:#2d3748;margin-bottom:8px}.time-window{color:#718096;font-size:14px;margin-bottom:16px}.btn-check-in{width:100%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:14px 24px;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s}.btn-check-in:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #667eea4d}.btn-check-in:disabled{opacity:.6;cursor:not-allowed}.completed{padding:14px;background-color:#f0fff4;border:2px solid #68d391;border-radius:8px;color:#22543d;font-size:14px;font-weight:600;text-align:center}.late-warning{color:#c53030;font-weight:700}.unavailable{padding:14px;background-color:#f7fafc;border:2px solid #e2e8f0;border-radius:8px;color:#718096;font-size:14px;text-align:center}.end-time-display{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:20px;border-radius:12px;text-align:center;font-size:18px;box-shadow:0 4px 12px #667eea4d}.end-time-display strong{display:block;margin-bottom:8px;font-size:16px;opacity:.9}@media(max-width:768px){.header-content{flex-direction:column;gap:12px}.current-time{font-size:36px}.current-date{font-size:16px}.check-in-grid{grid-template-columns:1fr}}.network-info{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:2rem}.info-card{background:#f8f9fa;padding:1rem;border-radius:8px;border:1px solid #dee2e6}.info-card label{display:block;font-weight:600;color:#495057;margin-bottom:.5rem;font-size:.9rem}.info-value{font-size:1.1rem;font-weight:600;color:#007bff;margin-bottom:.25rem;font-family:Courier New,monospace}.info-source{font-size:.8rem;color:#6c757d;font-weight:400;font-style:italic}.info-card input{width:100%;padding:.5rem;border:1px solid #ced4da;border-radius:4px;font-size:.95rem;font-family:Courier New,monospace}.info-card input:disabled{background-color:#e9ecef;cursor:not-allowed}.info-card small{display:block;color:#6c757d;font-size:.85rem;margin-top:.25rem}@media(max-width:768px){.network-info{grid-template-columns:1fr}}.admin-container{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:0}.admin-header{background:#fff;padding:20px 40px;box-shadow:0 2px 10px #0000001a;display:flex;justify-content:space-between;align-items:flex-start}.admin-header h1{margin:0 0 15px;color:#2d3748;font-size:28px}.admin-nav{display:flex;gap:10px}.admin-nav button{padding:8px 16px;border:2px solid #e2e8f0;background:#fff;color:#4a5568;border-radius:6px;cursor:pointer;transition:all .2s;font-size:14px;font-weight:500}.admin-nav button:hover{background:#f7fafc;border-color:#667eea;color:#667eea}.admin-nav button.active{background:#667eea;color:#fff;border-color:#667eea}.btn-logout{padding:10px 20px;background:#e53e3e;color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:background .2s}.btn-logout:hover{background:#c53030}.dashboard-main{max-width:1200px;margin:0 auto;padding:32px 24px}.date-picker-section{display:flex;align-items:center;gap:15px;margin:20px auto;max-width:1200px;padding:20px;background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000001a}.date-picker-section label{font-weight:600;color:#2d3748}.date-picker-section input[type=date]{padding:10px 14px;border:2px solid #e2e8f0;border-radius:8px;font-size:14px;color:#2d3748;background:#fff}.btn-refresh{padding:10px 24px;background:#48bb78;color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:600;transition:all .2s}.btn-refresh:hover{background:#38a169;transform:translateY(-1px);box-shadow:0 4px 6px #48bb784d}.message{padding:16px 20px;margin:20px auto;max-width:1200px;border-radius:12px;text-align:center;font-weight:600;animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.message.success{background:#c6f6d5;color:#22543d;border:2px solid #9ae6b4}.message.error{background:#fed7d7;color:#742a2a;border:2px solid #fc8181}.report-card{background:#fff;border-radius:16px;padding:30px;margin:20px auto;max-width:1200px;box-shadow:0 10px 30px #0000001a}.report-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:25px;padding-bottom:20px;border-bottom:2px solid #e2e8f0}.report-header h2{margin:0;color:#2d3748;font-size:24px;font-weight:700}.btn-send-email{padding:10px 24px;background:#4299e1;color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:600;transition:all .2s}.btn-send-email:hover{background:#3182ce;transform:translateY(-1px);box-shadow:0 4px 6px #4299e14d}.report-summary{margin:20px 0;font-size:16px;color:#4a5568;font-weight:500}.report-summary strong{color:#2d3748;font-weight:700}.count-badge{display:inline-block;padding:4px 12px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:16px;font-size:14px;font-weight:700;margin-left:8px}.subsection-title{margin:30px 0 20px;color:#2d3748;font-size:20px;font-weight:700;padding-bottom:12px;border-bottom:2px solid #e2e8f0}.report-table{width:100%;border-collapse:separate;border-spacing:0;background:#fff;border-radius:8px;overflow:hidden}.report-table thead{background:linear-gradient(135deg,#667eea,#764ba2)}.report-table th,.report-table td{padding:14px 16px;text-align:left;border-bottom:1px solid #e2e8f0}.report-table th{font-weight:700;color:#fff;font-size:13px;text-transform:uppercase;letter-spacing:.5px}.report-table td{color:#2d3748;font-size:14px}.report-table tbody tr{transition:all .2s}.report-table tbody tr:hover{background:#f7fafc;transform:scale(1.01)}.report-table tbody tr:last-child td{border-bottom:none}.late-badge{display:inline-block;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:600;background:#fef08a;color:#854d0e}.warning-badge{display:inline-block;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:600;background:#fed7aa;color:#9a3412}.error-badge{display:inline-block;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:600;background:#fecaca;color:#991b1b}.no-data{padding:40px;text-align:center;color:#718096;background:#f7fafc;border-radius:12px;margin:20px 0;font-size:15px;font-weight:500}.user-table,.bssid-table{width:100%;border-collapse:separate;border-spacing:0;background:#fff;border-radius:8px;overflow:hidden;margin:20px auto;max-width:1200px;box-shadow:0 10px 30px #0000001a}.user-table thead,.bssid-table thead{background:linear-gradient(135deg,#667eea,#764ba2)}.user-table th,.user-table td,.bssid-table th,.bssid-table td{padding:14px 16px;text-align:left;border-bottom:1px solid #e2e8f0}.user-table th,.bssid-table th{font-weight:700;color:#fff;font-size:13px;text-transform:uppercase;letter-spacing:.5px}.user-table td,.bssid-table td{color:#2d3748;font-size:14px}.user-table tbody tr,.bssid-table tbody tr{transition:all .2s}.user-table tbody tr:hover,.bssid-table tbody tr:hover{background:#f7fafc}.user-table tbody tr:last-child td,.bssid-table tbody tr:last-child td{border-bottom:none}.bssid-table code{background:#edf2f7;padding:4px 8px;border-radius:4px;font-family:Courier New,monospace;color:#2d3748;font-size:13px}.toggle-switch{position:relative;display:inline-block;width:50px;height:24px}.toggle-switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;inset:0;background-color:#cbd5e0;transition:.3s;border-radius:24px}.slider:before{position:absolute;content:"";height:18px;width:18px;left:3px;bottom:3px;background-color:#fff;transition:.3s;border-radius:50%}input:checked+.slider{background-color:#48bb78}input:checked+.slider:before{transform:translate(26px)}.add-bssid-form{display:flex;gap:12px;padding:20px;background:#f7fafc;border-radius:12px;border:2px solid #e2e8f0;max-width:1200px;margin:20px auto}.add-bssid-form input{flex:1;padding:12px 16px;border:2px solid #e2e8f0;border-radius:8px;font-size:14px;color:#2d3748;background:#fff;transition:all .2s}.add-bssid-form input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.btn-add{padding:12px 24px;background:#48bb78;color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:600;transition:all .2s}.btn-add:hover{background:#38a169;transform:translateY(-1px);box-shadow:0 4px 6px #48bb784d}.btn-delete{padding:8px 16px;background:#f56565;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:13px;font-weight:600;transition:all .2s}.btn-delete:hover{background:#e53e3e;transform:translateY(-1px);box-shadow:0 4px 6px #f565654d}.info-box{background:#ebf8ff;border:2px solid #bee3f8;border-radius:12px;padding:20px;margin:20px auto;max-width:1200px;color:#2c5282;font-size:14px;line-height:1.6}.info-box h3{margin:0 0 12px;color:#2c5282;font-size:16px;font-weight:700}.info-box ul{margin:10px 0;padding-left:20px}.info-box li{margin:8px 0}.info-box code{background:#bee3f8;padding:2px 6px;border-radius:4px;font-family:Courier New,monospace;color:#2c5282;font-size:13px}@media(max-width:768px){.admin-header{flex-direction:column;gap:15px;padding:15px 20px}.admin-nav{width:100%;flex-direction:column}.admin-nav button{width:100%}.dashboard-main{padding:16px 12px}.date-picker-section{flex-direction:column;align-items:stretch}.date-picker-section input,.btn-refresh{width:100%}.report-card{padding:20px}.report-header{flex-direction:column;gap:15px;align-items:flex-start}.btn-send-email{width:100%}.report-table,.user-table,.bssid-table{font-size:12px}.report-table th,.report-table td,.user-table th,.user-table td,.bssid-table th,.bssid-table td{padding:10px 8px}.add-bssid-form{flex-direction:column}.btn-add{width:100%}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(prefers-reduced-motion:no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#888}
