*{margin:0;padding:0;box-sizing:border-box;font-family:Arial,sans-serif}body{background:#f5f5f5}.notification-icon-container{position:relative;margin-right:20px}.notification-bell{position:relative;cursor:pointer;padding:8px;border-radius:50%;transition:all .3s ease}.notification-bell:hover{background-color:#ffffff1a}.bell-icon{font-size:20px;color:#fff}.notification-badge{position:absolute;top:-5px;right:-5px;background-color:#f44;color:#fff;border-radius:50%;padding:2px 6px;font-size:12px;font-weight:700;min-width:18px;height:18px;display:flex;align-items:center;justify-content:center;animation:pulse 2s infinite}@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.1)}to{transform:scale(1)}}.notification-dropdown{position:absolute;top:100%;right:0;width:350px;background:#fff;border-radius:8px;box-shadow:0 4px 12px #0000001a;opacity:0;visibility:hidden;transform:translateY(10px);transition:all .3s ease;z-index:1000}.notification-icon-container:hover .notification-dropdown{opacity:1;visibility:visible;transform:translateY(0)}.notification-header{display:flex;justify-content:space-between;align-items:center;padding:15px;border-bottom:1px solid #eee}.notification-header h4{margin:0;color:#2c3e50;font-size:16px}.preferences-toggle{background:none;border:none;color:#666;cursor:pointer;padding:5px;border-radius:50%;transition:all .3s ease}.preferences-toggle:hover{background:#f0f0f0;color:#333}.notification-preferences{padding:15px;border-bottom:1px solid #eee}.notification-preferences h5{margin:0 0 10px;color:#2c3e50;font-size:14px}.preference-options{display:flex;gap:10px}.preference-option{display:flex;flex-direction:column;align-items:center;padding:10px;border-radius:6px;background:#f8f9fa;cursor:pointer;transition:all .3s ease;border:1px solid #e0e0e0;min-width:80px}.preference-option:hover{transform:translateY(-2px);box-shadow:0 2px 4px #0000001a}.preference-option.active{background:#e3f2fd;border-color:#2196f3}.preference-option .icon{font-size:20px;margin-bottom:5px;color:#2196f3}.preference-option span{font-size:12px;color:#333}.notification-list{max-height:300px;overflow-y:auto}.notification-item{padding:15px;border-bottom:1px solid #eee;transition:background-color .3s ease}.notification-item:hover{background-color:#f8f9fa}.notification-content{display:flex;justify-content:space-between;align-items:center;margin-bottom:5px}.visitor-name{font-weight:600;color:#2c3e50}.notification-time{font-size:12px;color:#666}.notification-message{font-size:14px;color:#666;margin-bottom:10px}.notification-actions{display:flex;gap:10px;justify-content:flex-end}.accept-btn,.reject-btn{display:flex;align-items:center;gap:5px;padding:6px 12px;border-radius:4px;border:none;cursor:pointer;font-weight:500;font-size:12px;transition:all .3s ease}.accept-btn{background:#4caf50;color:#fff}.reject-btn{background:#f44336;color:#fff}.accept-btn:hover,.reject-btn:hover{opacity:.9;transform:translateY(-1px)}.notification-status{display:flex;align-items:center;gap:5px;padding:6px 12px;border-radius:4px;font-weight:500;font-size:12px;margin-top:10px}.notification-status.accepted{background:#e8f5e9;color:#2e7d32}.notification-status.rejected{background:#ffebee;color:#c62828}.header{position:fixed;top:0;left:0;width:100%;background-color:#2c3e50;padding:20px 30px;color:#fff;display:flex;justify-content:space-between;align-items:center;z-index:1000}body{padding-top:80px}.logo{display:flex;align-items:center}.header-logo{height:40px;width:auto;object-fit:contain}.nav-links{display:flex;gap:20px;align-items:center}.nav-links a,.logout-btn{display:flex;align-items:center;gap:8px;color:#fff;text-decoration:none;font-size:16px;padding:8px 12px;border-radius:5px;transition:background .3s}.nav-links a:hover,.logout-btn:hover{background-color:#34495e}.icon{font-size:18px}.logout-btn{background-color:#e74c3c;border:none;cursor:pointer;display:flex;align-items:center;gap:8px}.logout-btn:hover{background-color:#c0392b}@media (max-width: 768px){.header{flex-direction:column;padding:1rem}.logo{margin-bottom:1rem}.header-logo{height:30px}.nav-links{flex-wrap:wrap;justify-content:center;gap:1rem}.nav-links a{padding:.5rem}}.visitor-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:15px;padding:20px}.stat-card{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px;border-radius:8px;color:#fff;text-align:center;min-width:150px;min-height:100px;box-shadow:0 4px 6px #0003}.stat-icon{font-size:30px;margin-bottom:10px}.stat-title{font-size:16px;font-weight:700}.stat-count{font-size:24px;font-weight:700;margin-top:5px}.visitors-table{margin-top:20px;padding:20px}.visitors-table h2{color:#2c3e50;margin-bottom:20px}.visitors-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px;margin-bottom:30px}.visitor-card{background:#fff;border-radius:10px;padding:20px;box-shadow:0 2px 4px #0000001a;transition:transform .2s ease,box-shadow .2s ease;position:relative;overflow:hidden}.visitor-card:hover{transform:translateY(-5px);box-shadow:0 4px 8px #0003}.visitor-card .status-badge{position:absolute;top:0;right:0;padding:8px 15px;color:#fff;font-weight:500;font-size:.9rem;border-bottom-left-radius:10px}.visitor-card .status-badge.Expected{background-color:#f1c40f}.visitor-card .status-badge.Checked-In{background-color:#2ecc71}.visitor-info{margin-top:10px}.visitor-name{font-size:1.2rem;font-weight:600;color:#2c3e50;margin-bottom:10px}.visitor-detail{display:flex;align-items:center;margin-bottom:8px;color:#34495e}.visitor-detail.clickable{cursor:pointer;transition:color .2s ease}.visitor-detail.clickable:hover,.visitor-detail.clickable i{color:#3498db}.visitor-detail i{margin-right:8px;width:20px;color:#7f8c8d}.visitor-actions{display:flex;gap:10px;margin-top:15px;padding-top:15px;border-top:1px solid #eee}.visitor-actions button{flex:1;padding:8px;border:none;border-radius:5px;cursor:pointer;font-weight:500;transition:opacity .2s ease}.visitor-actions button:hover{opacity:.9}.edit-btn{background-color:#3498db;color:#fff}.delete-btn{background-color:#e74c3c;color:#fff}.section-title{font-size:1.5rem;color:#2c3e50;margin:30px 0 20px;padding-bottom:10px;border-bottom:2px solid #eee}@media (max-width: 768px){.visitors-grid{grid-template-columns:1fr}.visitor-card{margin-bottom:15px}}.home{padding-top:80px;margin:0 auto}.add-visitor{width:100%;max-width:400px;margin:100px auto;padding:20px;background:#f8f9fa;box-shadow:0 4px 6px #0000001a;border-radius:8px}.add-visitor h2{text-align:center;color:#333}.visitor-form{display:flex;flex-direction:column}.visitor-form input,.visitor-form select{padding:10px;margin:8px 0;border:1px solid #ccc;border-radius:5px}.visitor-form select{cursor:pointer}.visitor-form button{background:#007bff;color:#fff;padding:10px;border:none;cursor:pointer;font-size:16px;border-radius:5px;margin-top:10px}.visitor-form button:hover{background:#0056b3}.visitor-registration-container{margin-top:80px;padding:20px;background:linear-gradient(to right,#aad6ff,#8ec6ff);border-radius:8px;min-height:calc(100vh - 100px)}.visitor-registration-content{display:flex;gap:20px;margin-top:20px}.form-section{flex:3;background:#fff;padding:20px;border-radius:8px;box-shadow:0 2px 4px #0000001a}.media-capture-section{margin:20px 0;background:#f8f9fa;border-radius:8px;box-shadow:0 2px 4px #0000001a;overflow:hidden}.photo-section,.card-scan-section{padding:20px}.photo-section{border-bottom:1px solid #dee2e6}.section-title{font-size:18px;font-weight:600;color:#333;margin-bottom:15px}.form-row{display:flex;gap:20px;margin-bottom:15px}.form-group{flex:1;display:flex;flex-direction:column;position:relative}.form-group.full-width{flex:2}.visitor-registration-container .form-group label,.visitor-registration-content .form-group label,.form-section .form-group label{margin-bottom:5px;font-weight:700!important;color:#333;font-family:Arial,sans-serif}.form-group input[type=text],.form-group input[type=email],.form-group select,.form-group textarea{padding:8px 12px;border:1px solid #ccc;border-radius:4px;font-size:14px;transition:border-color .3s,box-shadow .3s}.form-group input.error,.form-group select.error,.form-group textarea.error{border-color:#dc3545;background-color:#fff8f8}.error-message{color:#dc3545;font-size:14px;margin-top:5px;display:block}.form-group textarea{min-height:80px;resize:vertical}.input-with-button{display:flex;gap:10px}.input-with-button input{flex:1}.input-with-button button{padding:8px 15px;background:#007bff;color:#fff;border:none;border-radius:4px;cursor:pointer;min-width:80px;transition:all .3s ease}.input-with-button button.verified{background-color:#28a745;pointer-events:none}.required{color:red;margin-left:2px}.checkbox-group{flex-direction:row;align-items:center;gap:10px}.checkbox-group input[type=checkbox]{width:16px;height:16px}.photo-container,.card-scan-container{max-width:500px;margin:0 auto;text-align:center}.photo-placeholder,.card-placeholder{width:100%;height:300px;background:#e9ecef;display:flex;align-items:center;justify-content:center;border-radius:8px;margin-bottom:15px}.photo-placeholder p,.card-placeholder p{color:#6c757d;font-size:16px}video{width:100%;max-height:300px;border-radius:8px;margin-bottom:15px;background:#000}.captured-photo,.scanned-card{width:100%;max-height:300px;object-fit:contain;border-radius:8px;margin-bottom:15px;box-shadow:0 2px 4px #0000001a}.photo-buttons,.card-buttons{display:flex;gap:10px;justify-content:center;margin-top:10px}.photo-buttons button,.card-buttons button{padding:8px 16px;border:none;border-radius:4px;cursor:pointer;font-weight:500;transition:all .3s ease}.photo-buttons button:first-child,.card-buttons button:first-child{background-color:#007bff;color:#fff}.photo-buttons button:first-child:hover,.card-buttons button:first-child:hover{background-color:#0056b3}.photo-buttons button:last-child,.card-buttons button:last-child{background-color:#dc3545;color:#fff}.photo-buttons button:last-child:hover,.card-buttons button:last-child:hover{background-color:#c82333}.photo-buttons button:disabled,.card-buttons button:disabled{background-color:#6c757d;cursor:not-allowed}.photo-preview,.card-preview{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#28a745;font-weight:500}.form-actions{display:flex;gap:15px;justify-content:flex-end;margin-top:30px;padding:20px;background:#f8f9fa;border-radius:8px;box-shadow:0 2px 4px #0000000d}.form-actions button{padding:12px 24px;border:none;border-radius:6px;font-weight:600;font-size:16px;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;min-width:180px;position:relative;overflow:hidden}.form-actions button:not(:last-child){background:linear-gradient(135deg,#007bff,#0056b3);color:#fff;box-shadow:0 2px 4px #007bff33}.form-actions button:not(:last-child):hover{transform:translateY(-2px);box-shadow:0 4px 8px #007bff4d;background:linear-gradient(135deg,#0056b3,#003d7a)}.form-actions button:last-child{background:linear-gradient(135deg,#6c757d,#495057);color:#fff;box-shadow:0 2px 4px #6c757d33}.form-actions button:last-child:hover{transform:translateY(-2px);box-shadow:0 4px 8px #6c757d4d;background:linear-gradient(135deg,#495057,#343a40)}.form-actions button:disabled{background:#e9ecef;color:#6c757d;cursor:not-allowed;transform:none;box-shadow:none}.form-actions button:not(:last-child):after{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,#ffffff1a,#fff0);transition:opacity .3s ease}.form-actions button:not(:last-child):hover:after{opacity:0}.form-group.success input{border-color:#28a745;background-color:#f8fff8}button.loading{position:relative;pointer-events:none;opacity:.8}button.loading:after{content:"";position:absolute;width:16px;height:16px;top:50%;left:50%;margin-left:-8px;margin-top:-8px;border:2px solid rgba(255,255,255,.3);border-radius:50%;border-top-color:#fff;animation:spin 1s ease-in-out infinite}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 1024px){.visitor-registration-content{flex-direction:column}.photo-section{flex-direction:row}.photo-container,.business-card-section{flex:1}}@media (max-width: 768px){.form-row{flex-direction:column;gap:15px}.media-capture-section{margin:15px 0}.photo-section,.card-scan-section{padding:15px}.photo-placeholder,.card-placeholder{height:250px}.photo-buttons,.card-buttons{flex-direction:column;gap:8px}.photo-buttons button,.card-buttons button{width:100%}.error-message{position:static;margin-top:4px}.form-actions{flex-direction:column;gap:10px;padding:15px}.form-actions button{width:100%;min-width:auto}}.dropdown-container{position:relative;width:100%}.dropdown-container select{width:100%;padding:10px 35px 10px 15px;border:1px solid #ced4da;border-radius:4px;background-color:#fff;font-size:14px;color:#495057;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;transition:all .3s ease}.dropdown-container select:focus{outline:none;border-color:#80bdff;box-shadow:0 0 0 .2rem #007bff40}.dropdown-container select:disabled{background-color:#e9ecef;cursor:not-allowed}.dropdown-container:after{content:"";position:absolute;right:15px;top:50%;transform:translateY(-50%);width:0;height:0;border-left:5px solid transparent;border-right:5px solid transparent;border-top:5px solid #495057;pointer-events:none}.dropdown-container select:disabled+.loading-spinner{display:none}.loading-spinner{position:absolute;right:15px;top:50%;transform:translateY(-50%);width:16px;height:16px;border:2px solid #f3f3f3;border-top:2px solid #007bff;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:translateY(-50%) rotate(0)}to{transform:translateY(-50%) rotate(360deg)}}.error-message{color:#dc3545;font-size:12px;margin-top:5px;display:block}.form-group select.error{border-color:#dc3545;background-color:#fff8f8}.form-group select.error:focus{border-color:#dc3545;box-shadow:0 0 0 .2rem #dc354540}.profile-container{padding:2rem;max-width:1200px;margin:0 auto}.profile-header{margin-top:80px;background:linear-gradient(135deg,#6a0dad,#4c6fff);border-radius:15px;padding:2rem;color:#fff;margin-bottom:2rem;display:flex;align-items:center;gap:2rem;box-shadow:0 4px 6px #0000001a}.profile-avatar{width:120px;height:120px;border-radius:50%;border:4px solid white;background-color:#fff3;box-shadow:0 4px 6px #0000001a;display:flex;align-items:center;justify-content:center}.profile-info h1{margin:0;font-size:2rem;font-weight:600}.profile-role{background-color:#fff3;padding:.5rem 1rem;border-radius:20px;font-size:.9rem;display:inline-block;margin-top:.5rem}.profile-content{display:grid;grid-template-columns:2fr 1fr;gap:2rem}@media (max-width: 768px){.profile-content{grid-template-columns:1fr}.profile-header{flex-direction:column;text-align:center}.info-grid,.stats-grid{grid-template-columns:1fr}}.profile-section{background:#fff;border-radius:15px;padding:2rem;box-shadow:0 2px 4px #0000000d}.profile-section h2{margin:0 0 1.5rem;color:#2c3e50;font-size:1.5rem;font-weight:600}.info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}.info-item{display:flex;flex-direction:column;gap:.5rem}.info-label{color:#2b8c93;font-size:.9rem;display:flex;align-items:center;gap:.5rem}.info-value{color:#2c3e50;font-size:1rem;font-weight:500}.activity-list{display:flex;flex-direction:column;gap:1rem}.activity-item{display:flex;align-items:center;gap:1rem;padding:1rem;background:#f8f9fa;border-radius:10px;transition:transform .2s}.activity-item:hover{transform:translate(5px)}.activity-icon{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff}.activity-info{flex:1}.activity-title{font-weight:500;color:#2c3e50;margin:0}.activity-time{color:#7f8c8d;font-size:.9rem;margin:0}.edit-profile-btn{background-color:#4c6fff;color:#fff;border:none;border-radius:8px;padding:.75rem 1.5rem;font-size:1rem;font-weight:500;cursor:pointer;transition:background-color .2s;display:flex;align-items:center;gap:.5rem}.edit-profile-btn:hover{background-color:#3d5ce4}.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.stat-card{background:#6b9aca;border-radius:10px;padding:1.5rem;text-align:center;transition:transform .2s}.stat-card:hover{transform:translateY(-2px)}.stat-number{font-size:2.2rem;font-weight:700;color:#040c13;margin:0;line-height:1.2}.stat-label{color:#147ae1;font-size:1rem;font-weight:600;margin:.5rem 0 0;text-transform:uppercase;letter-spacing:.5px}.stat-card[data-label="Total Visitors"] .stat-label{color:#2196f3}.stat-card[data-label="Pending Requests"] .stat-label{color:#ff5722}.stat-card[data-label="Approved Today"] .stat-label{color:#4caf50}.stat-card[data-label="This Month"] .stat-label{color:#9c27b0}.notification-settings{margin-top:2rem}.toggle-group{display:flex;flex-direction:column;gap:1rem}.toggle-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:#f8f9fa;border-radius:10px;transition:background-color .2s}.toggle-item:hover{background-color:#f1f3f5}.toggle-label{display:flex;align-items:center;gap:.5rem;color:#2c3e50;font-weight:500}.toggle-switch{position:relative;display:inline-block;width:50px;height:26px}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:#ccc;transition:.4s;border-radius:34px}.toggle-slider:before{position:absolute;content:"";height:18px;width:18px;left:4px;bottom:4px;background-color:#fff;transition:.4s;border-radius:50%}input:checked+.toggle-slider{background-color:#4c6fff}input:checked+.toggle-slider:before{transform:translate(24px)}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.section-header h2{margin:0}.change-password-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background-color:#f8f9fa;border:1px solid #e2e8f0;border-radius:8px;color:#4c6fff;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s}.change-password-btn:hover{background-color:#4c6fff;color:#fff;transform:translateY(-1px)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content{background:#fff;padding:2rem;border-radius:15px;width:100%;max-width:500px;position:relative;box-shadow:0 4px 6px #0000001a;animation:slideIn .3s ease-out}@keyframes slideIn{0%{transform:translateY(-20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.modal-header h2{margin:0;color:#2c3e50;font-size:1.5rem}.close-button{background:none;border:none;color:#7f8c8d;cursor:pointer;padding:.5rem;display:flex;align-items:center;justify-content:center;transition:color .2s}.close-button:hover{color:#34495e}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;color:#2c3e50;font-weight:500}.password-input-container{position:relative;display:flex;align-items:center}.password-input-container input{width:100%;padding:.75rem 1rem;border:1px solid #e0e0e0;border-radius:8px;font-size:1rem;color:#2c3e50;transition:border-color .2s}.password-input-container input:focus{outline:none;border-color:#4c6fff;box-shadow:0 0 0 3px #4c6fff1a}.toggle-password{position:absolute;right:1rem;background:none;border:none;color:#7f8c8d;cursor:pointer;padding:0;display:flex;align-items:center}.toggle-password:hover{color:#34495e}.error-message{background-color:#fee2e2;color:#dc2626;padding:.75rem 1rem;border-radius:8px;margin-bottom:1rem;font-size:.9rem}.success-message{background-color:#dcfce7;color:#16a34a;padding:.75rem 1rem;border-radius:8px;margin-bottom:1rem;font-size:.9rem}.button-group{display:flex;gap:1rem;margin-top:2rem}.cancel-button,.save-button{padding:.75rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s;flex:1}.cancel-button{background-color:#f1f5f9;border:1px solid #e2e8f0;color:#64748b}.cancel-button:hover{background-color:#e2e8f0}.save-button{background-color:#4c6fff;border:none;color:#fff}.save-button:hover{background-color:#3d5ce4}@media (max-width: 640px){.modal-content{margin:1rem;padding:1.5rem}.button-group{flex-direction:column}.button-group button{width:100%}}.visitor-container{margin-top:80px;padding:20px;background:linear-gradient(to right,#aad6ff,#8ec6ff);border-radius:8px}.visitor-content{display:flex;gap:20px;margin-top:20px}.visitor-search-section{flex:1}.search-filters{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:20px}.search-filters input{padding:8px;border:1px solid #ccc;border-radius:4px}.visitor-table{width:100%;border-collapse:collapse;background:#fff;border-radius:5px;overflow:hidden}.visitor-table th,.visitor-table td{padding:10px;border:1px solid #ddd;text-align:left}.visitor-table th{background:#007bff;color:#fff}.visitor-table tr{cursor:pointer}.visitor-table tr:hover{background-color:#0000000d}.visitor-table tr.selected{background-color:#cce5ff!important;border:2px solid #007bff}.visitor-table tr.in{background:#f99}.visitor-table tr.out{background:#9f9}.visitor-table tr.expected{background:#ff9}.overdue-section{margin-bottom:20px;border:1px solid #ff6b6b;border-radius:8px;overflow:hidden}.overdue-header{background-color:#ff6b6b;color:#fff;padding:10px 15px;margin:0;display:flex;justify-content:space-between;align-items:center}.toggle-overdue{background-color:transparent;border:1px solid white;color:#fff;padding:5px 10px;border-radius:4px;cursor:pointer;transition:all .3s ease}.toggle-overdue:hover{background-color:#fff;color:#ff6b6b}.overdue-table{margin:0;border-top:none}.overdue-table tbody tr{background-color:#fff5f5}.overdue-table tbody tr:hover{background-color:#ffe3e3}.overdue-table tbody tr.overdue td{color:#5080be;font-weight:500}.overdue-table tbody tr.overdue td:last-child{color:red;font-weight:700}.stat-panel{width:200px;background-color:#2c3e50;border-radius:8px;padding:15px;margin-right:20px}.stat-item{background-color:#34495e;border-radius:6px;padding:12px;margin-bottom:10px}.stat-item:last-child{margin-bottom:0}.stat-label{color:#ecf0f1;font-size:14px;margin-bottom:5px}.stat-value{font-size:24px;font-weight:700;text-align:center}.check-in{color:#2ecc71}.check-out{color:#3498db}.expected{color:#f1c40f}.total{color:#9b59b6}.overdue{color:#e74c3c}.status-indicator-container{display:flex;justify-content:space-between;align-items:center;padding:10px;background-color:#f8f9fa;border-radius:4px;margin-top:20px;box-shadow:0 2px 4px #0000001a}.status-indicator{display:flex;align-items:center;gap:20px}.status-item{display:flex;align-items:center;gap:8px}.status-box{width:16px;height:16px;border-radius:3px}.status-label{font-size:14px;color:#333;font-weight:500}.status-box.red{background-color:red}.status-box.green{background-color:#90ee90}.status-box.yellow{background-color:#ff9}.status-box.blue{background-color:#87ceeb}.status-box.red-dark{background-color:#8b0000}.action-buttons{display:flex;gap:10px}.action-button{padding:6px 12px;background:linear-gradient(to bottom,#f0f0f0,#e0e0e0);border:1px solid #999;border-radius:3px;color:#333;font-size:14px;cursor:pointer;min-width:100px;text-align:center}.action-button:hover{background:linear-gradient(to bottom,#e0e0e0,#d0d0d0)}.action-button:active{background:linear-gradient(to bottom,#d0d0d0,#e0e0e0)}body,html{margin:0;padding:0;height:100%;font-family:Arial,sans-serif}.login-container{display:flex;justify-content:flex-end;align-items:center;min-height:100vh;width:100%;padding:20px;background-image:url(./login-bg-joLKZIaO.jpg);background-size:cover;background-position:center;background-repeat:no-repeat;position:relative;z-index:1}.login-container:before{content:"";position:absolute;top:0;left:0;height:100%;width:100%;background-color:#0000004d;z-index:0}.login-card{background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000001a;padding:40px;width:100%;max-width:420px;position:relative;z-index:1}.login-header{text-align:center;margin-bottom:32px}.logo-container{margin-bottom:24px;display:flex;justify-content:center}.vst-logo{width:180px;height:auto;object-fit:contain}.company-name{color:#4c6fff;font-size:24px;font-weight:600;margin:0}.login-header h1{font-size:24px;color:#2c3e50;margin:0 0 8px;font-weight:600}.login-header p{color:#7f8c8d;margin:0;font-size:14px}.login-form{display:flex;flex-direction:column;gap:20px}.error-message{background-color:#fee2e2;color:#dc2626;padding:12px;border-radius:8px;font-size:14px;text-align:center}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-size:14px;color:#2c3e50;font-weight:500}.input-container,.password-input-container{position:relative;display:flex;align-items:center}.input-icon{position:absolute;left:16px;color:#95a5a6;font-size:16px;z-index:1}.input-container input,.password-input-container input{width:100%;padding:12px 44px;border:1px solid #e0e0e0;border-radius:8px;font-size:14px;color:#2c3e50;transition:all .2s}.input-container input:focus,.password-input-container input:focus{outline:none;border-color:#4c6fff;box-shadow:0 0 0 3px #4c6fff1a}.input-container input.input-error,.password-input-container input.input-error{border-color:#dc2626;background-color:#fef2f2}.input-container input.input-error:focus,.password-input-container input.input-error:focus{box-shadow:0 0 0 3px #dc26261a}.input-container input:disabled,.password-input-container input:disabled{background-color:#f8f9fa;cursor:not-allowed}.toggle-password{position:absolute;right:16px;color:#95a5a6;cursor:pointer;background:none;border:none;padding:0;display:flex;align-items:center;justify-content:center;transition:color .2s;width:24px;height:24px;z-index:2}.toggle-password:hover:not(:disabled){color:#2c3e50}.toggle-password:disabled{cursor:not-allowed;opacity:.6}.password-input-container.show-password .input-icon{display:none}.form-footer{display:flex;justify-content:space-between;align-items:center;margin-top:-8px}.remember-me{display:flex;align-items:center;gap:8px}.remember-me input[type=checkbox]{width:16px;height:16px;margin:0;cursor:pointer;accent-color:#4c6fff}.remember-me input[type=checkbox]:disabled{cursor:not-allowed}.remember-me label{font-size:14px;color:#2c3e50;cursor:pointer}.forgot-password{font-size:14px;color:#4c6fff;text-decoration:none;background:none;border:none;cursor:pointer;padding:0;transition:color .2s}.forgot-password:hover:not(:disabled){color:#3d5ce4;text-decoration:underline}.forgot-password:disabled{cursor:not-allowed;opacity:.6}.login-button{background-color:#4c6fff;color:#fff;border:none;border-radius:8px;padding:12px;font-size:16px;font-weight:500;cursor:pointer;transition:all .2s;margin-top:8px;position:relative}.login-button:hover:not(:disabled){background-color:#3d5ce4}.login-button:disabled,.login-button.loading{background-color:#a5b4fc;cursor:not-allowed}.register-prompt{text-align:center;margin-top:24px;font-size:14px;color:#7f8c8d}.create-account-link{color:#4c6fff;text-decoration:none;font-weight:500;transition:color .2s}.create-account-link:hover{color:#3d5ce4;text-decoration:underline}@media (max-width: 768px){.login-container{justify-content:center;padding:40px 20px}}@media (max-width: 480px){.login-card{padding:24px}.vst-logo{width:150px}.login-header h1{font-size:20px}.form-footer{flex-direction:column;gap:16px;align-items:flex-start}}.registered-visitors-container{margin-top:80px;padding:2rem;width:100%;min-height:100vh;background:linear-gradient(to right,#aad6ff,#8ec6ff);color:#fff;display:flex;flex-direction:column;align-items:center}.search-section{width:100%;max-width:1200px;display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;gap:1rem;background-color:#fffffffa;padding:1.5rem;border-radius:12px;box-shadow:0 4px 15px #0000001a}.search-box{flex:1;position:relative;max-width:500px}.search-box input{width:100%;padding:1rem 1rem 1rem 3rem;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;background-color:#fff;transition:all .3s ease}.search-box input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.search-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:#666;font-size:1.2rem}.print-btn{display:flex;align-items:center;gap:.5rem;padding:1rem 2rem;background:#0056b3;color:#fff;border:none;border-radius:8px;cursor:pointer;transition:all .3s ease;font-weight:500;box-shadow:0 2px 8px #00000026}.print-btn:hover{transform:translateY(-2px);background:#004494;box-shadow:0 4px 12px #0003}.visitors-table-container{width:100%;max-width:1200px;overflow-x:auto;background:#fffffffa;border-radius:12px;box-shadow:0 4px 15px #0000001a;padding:0;margin-top:2rem}.visitors-table{width:100%;border-collapse:separate;border-spacing:0}.visitors-table th{background-color:#007bff;font-weight:700;color:#fff;position:sticky;top:0;z-index:1;text-transform:uppercase;font-size:.9rem;letter-spacing:.5px;padding:1.25rem 1rem;border-bottom:none;box-shadow:0 2px 4px #0000001a}.visitors-table th:first-child{border-top-left-radius:8px}.visitors-table th:last-child{border-top-right-radius:8px}.visitors-table td{padding:1.25rem 1rem;text-align:left;border-bottom:1px solid #eee;color:#333;font-weight:500}.visitors-table tr:hover{background-color:#f8f9fa;transform:translate(4px);transition:all .3s ease}.status-badge{padding:.5rem 1rem;border-radius:20px;font-size:.875rem;font-weight:500;display:inline-block;text-transform:capitalize}.status-badge.active{background-color:#e3fcef;color:#00a854}.status-badge.inactive{background-color:#fff1f0;color:#f5222d}.action-buttons{display:flex;gap:.75rem}.action-btn{padding:.75rem;border:none;border-radius:8px;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #0000001a}.action-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.action-btn.view{background-color:#e6f7ff;color:#1890ff}.action-btn.edit{background-color:#fff7e6;color:#fa8c16}.action-btn.delete{background-color:#fff1f0;color:#f5222d}.no-results{text-align:center;padding:3rem 2rem;font-size:1.1rem;color:#333;background-color:#fffffffa;border-radius:12px;margin-top:1rem;box-shadow:0 4px 15px #0000001a}@media (max-width: 768px){.registered-visitors-container{padding:1rem}.search-section{flex-direction:column;align-items:stretch;padding:1rem}.search-box{max-width:none}.print-btn{width:100%;justify-content:center}.visitors-table th,.visitors-table td{padding:1rem .75rem;font-size:.875rem;white-space:nowrap}.action-buttons{gap:.5rem}.action-btn{padding:.5rem}}@media print{.search-section,.action-buttons{display:none}.visitors-table,.visitors-table th,.visitors-table td{border:1px solid #ddd}}
