body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}*{box-sizing:border-box}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,#f8fafc,#e2e8f0);color:#1e293b;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;margin:0;min-height:100vh}.App,.dashboard-container{min-height:100vh;padding:0}.dashboard-container{background:linear-gradient(135deg,#f8fafc,#e2e8f0)}.dashboard-wrapper{margin:0 auto;max-width:1200px;padding:2rem}.dashboard-header{animation:fadeIn .8s ease-out;margin-bottom:3rem;text-align:center}.dashboard-title{color:#1e293b;font-size:2.5rem;font-weight:700;letter-spacing:-.025em;margin-bottom:.5rem}.dashboard-subtitle{color:#64748b;font-size:1.125rem;font-weight:400;margin:0}.dashboard-card{animation:slideUp .6s ease-out;background:#fff;border:1px solid #e2e8f0;border-radius:16px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;overflow:hidden}.card-header{background:linear-gradient(135deg,#3b82f6,#1d4ed8);padding:2rem;text-align:center}.card-header h2{color:#fff;font-size:1.5rem;font-weight:600;margin:0 0 .5rem}.card-header p{color:#ffffffe6;font-size:1rem;font-weight:400;margin:0}.card-content{padding:2rem}.form-container{display:flex;flex-direction:column;gap:1.5rem}.form-row{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:1fr 1fr}@media (max-width:768px){.form-row{grid-template-columns:1fr}.dashboard-title{font-size:2rem}.dashboard-wrapper{padding:1rem}}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-label{color:#374151;font-size:.875rem;font-weight:600;margin-bottom:.25rem}.form-input,.form-select,.form-textarea{background:#fff;border:2px solid #d1d5db;border-radius:8px;color:#1f2937;font-family:inherit;font-size:.875rem;padding:.75rem 1rem;transition:all .2s ease;width:100%}.form-input::placeholder,.form-textarea::placeholder{color:#9ca3af}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.form-textarea{min-height:100px;resize:vertical}.btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:inline-flex;font-family:inherit;font-size:.875rem;font-weight:600;gap:.5rem;justify-content:center;padding:.75rem 1.5rem;text-decoration:none;transition:all .2s ease}.btn-primary{background:#3b82f6;box-shadow:0 1px 2px 0 #0000000d;color:#fff}.btn-primary:hover:not(:disabled){background:#2563eb;box-shadow:0 4px 6px -1px #0000001a}.btn-secondary{background:#fff;border:1px solid #d1d5db;color:#374151}.btn-secondary:hover:not(:disabled){background:#f9fafb;border-color:#9ca3af}.btn-large{font-size:1rem;margin-top:1rem;padding:1rem 2rem;width:100%}.btn:disabled{cursor:not-allowed;opacity:.5;transform:none!important}.alert{align-items:center;animation:bounceIn .6s ease-out;border-radius:8px;display:flex;font-size:.875rem;font-weight:500;gap:.75rem;margin-bottom:1.5rem;padding:1rem}.alert-error{background:#fef2f2;border:1px solid #fecaca;color:#dc2626}.alert-success{background:#f0fdf4;border:1px solid #bbf7d0;color:#16a34a}.photo-capture{background:#f9fafb;border:2px dashed #d1d5db;border-radius:12px;padding:1.5rem;text-align:center}.photo-buttons{align-items:center;display:flex;flex-direction:column;gap:1rem}@media (min-width:640px){.photo-buttons{flex-direction:row;justify-content:center}}.webcam-container{animation:slideUp .4s ease-out;background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:1rem}.webcam-controls{display:flex;gap:.75rem;justify-content:center;margin-top:1rem}.photo-preview{animation:bounceIn .6s ease-out}.photo-preview img{border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 1px 3px 0 #0000001a;height:150px;margin-bottom:1rem;object-fit:cover;width:200px}.loading-spinner{animation:spin 1s linear infinite;border:3px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:24px;width:24px}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes bounceIn{0%{opacity:0;transform:scale(.3)}50%{transform:scale(1.05)}70%{transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.navigation-menu{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#fffffff2;border-bottom:1px solid #e5e7ebcc;box-shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;padding:1rem 0;position:-webkit-sticky;position:sticky;top:0;transition:all .3s ease;z-index:1000}.navigation-menu.scrolled{background:#fffffffa;border-bottom:1px solid #e5e7eb;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.nav-container{justify-content:space-between;margin:0 auto;max-width:1200px;padding:0 2rem;transition:all .3s ease}.nav-brand,.nav-container{align-items:center;display:flex}.nav-brand{gap:1rem}.brand-logo,.nav-brand{flex-shrink:0}.logo-image{height:50px;object-fit:contain;width:auto}.brand-text{text-align:left}.brand-text h2{color:#1f2937;font-size:1.1rem;font-weight:700;line-height:1.2;margin:0;white-space:nowrap}.brand-text p{color:#6b7280;font-size:.8rem;font-weight:500;margin:0;white-space:nowrap}.nav-items{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#f3f4f6cc;border-radius:12px;display:flex;gap:.25rem;margin-left:auto;padding:.25rem}.nav-item{align-items:center;background:#0000;border:none;border-radius:8px;color:#6b7280;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:.5rem;overflow:hidden;padding:.75rem 1.25rem;position:relative;text-decoration:none;transition:all .2s ease}.nav-item:before{background:linear-gradient(90deg,#0000,#fff6,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .5s ease;width:100%}.nav-item:hover:before{left:100%}.nav-item:hover{background:#fffc;box-shadow:0 2px 4px #0000001a;color:#374151;transform:translateY(-1px)}.nav-item.active{background:linear-gradient(135deg,#3b82f6,#1d4ed8);box-shadow:0 2px 8px #3b82f64d;color:#fff;transform:translateY(-1px)}.nav-item.active:hover{background:linear-gradient(135deg,#2563eb,#1e40af);box-shadow:0 4px 12px #3b82f666;transform:translateY(-2px)}.nav-label{font-size:.875rem;font-weight:600}@media (max-width:768px){.nav-container{flex-direction:column;gap:1rem;padding:0 1rem}.nav-brand{justify-content:center}.brand-text h2{font-size:.9rem}.brand-text p{font-size:.7rem}.logo-image{height:40px}.nav-items{background:#f3f4f6e6;border-radius:16px;justify-content:center;margin-left:0;padding:.5rem;width:100%}.nav-item{flex:1 1;min-width:0;padding:.5rem 1rem;text-align:center}.nav-item,.nav-label{font-size:.8rem}}@media (max-width:480px){.nav-items{flex-direction:column;gap:.25rem}.nav-item{justify-content:center;width:100%}}.visitor-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}.visitor-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 1px 3px 0 #0000001a;padding:1.5rem;position:relative;transition:all .2s ease}.visitor-card:hover{border-color:#d1d5db;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;transform:translateY(-2px)}.visitor-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:1rem;position:relative}.visitor-info{flex:1 1;margin-right:1rem}.visitor-info h3{color:#1f2937;font-size:1.1rem;font-weight:600;margin:0 0 .25rem}.visitor-mobile{color:#6b7280;font-size:.875rem;margin:0}.visitor-status{border-radius:12px;color:#fff;font-size:.75rem;font-weight:600;padding:.25rem .75rem;position:absolute;right:80px;text-transform:uppercase;top:0;z-index:10}.visitor-details{display:flex;flex-direction:column;gap:.5rem}.detail-row{align-items:center;display:flex;justify-content:space-between;padding:.25rem 0}.detail-label{color:#6b7280;flex-shrink:0;font-size:.875rem;font-weight:500;margin-right:1rem}.detail-value{color:#1f2937;font-size:.875rem;text-align:right;word-break:break-word}.visitor-photo{position:absolute;right:1rem;top:1rem;z-index:5}.loading-container{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:4rem}.empty-state{color:#64748b;padding:3rem;text-align:center}.visitor-actions{display:flex;gap:.5rem;margin-top:1rem}.print-btn{background-color:#3b82f6;border:none;border-radius:6px;color:#fff;cursor:pointer;flex:1 1;font-size:.75rem;font-weight:600;padding:.5rem 1rem;transition:all .2s ease}.print-btn:hover{background-color:#2563eb;transform:translateY(-1px)}.expire-btn{background-color:#f87171;border:none;border-radius:6px;color:#fff;cursor:pointer;flex:1 1;font-size:.75rem;font-weight:600;padding:.5rem 1rem;transition:all .2s ease}.expire-btn:hover:not(:disabled){background-color:#ef4444;transform:translateY(-1px)}.expire-btn:disabled{cursor:not-allowed;opacity:.5;transform:none}.reports-controls{grid-gap:2rem;background:#f9fafb;border:1px solid #e5e7eb;border-radius:12px;display:grid;gap:2rem;grid-template-columns:1fr 1fr;margin-bottom:2rem;padding:1.5rem}.date-filters h3,.export-controls h3{color:#1f2937;font-size:1.125rem;font-weight:600;margin:0 0 1rem}.filter-buttons{display:flex;gap:.5rem;margin-bottom:1rem}.filter-btn{background:#fff;border:2px solid #d1d5db;border-radius:8px;color:#6b7280;cursor:pointer;font-weight:500;padding:.5rem 1rem;transition:all .2s ease}.filter-btn:hover{border-color:#3b82f6;color:#3b82f6}.filter-btn.active{background:#3b82f6;border-color:#3b82f6;color:#fff}.custom-date-inputs{margin-top:1rem}.export-buttons{display:flex;gap:1rem}.results-summary{background:#f0f9ff;border-left:4px solid #3b82f6;border-radius:8px;margin-bottom:2rem;padding:1rem}.results-summary h3{color:#1e40af;font-size:1.125rem;margin:0 0 .5rem}.results-summary p{color:#1e40af;font-weight:500;margin:0}.visitors-table-container{border:1px solid #e5e7eb;border-radius:8px;overflow-x:auto}.visitors-table{background:#fff;border-collapse:collapse;width:100%}.visitors-table th{background:#f9fafb;border-bottom:1px solid #e5e7eb;color:#374151;font-size:.875rem;font-weight:600;padding:1rem;text-align:left}.visitors-table td{border-bottom:1px solid #f3f4f6;color:#1f2937;font-size:.875rem;padding:1rem}.visitors-table tr:hover{background:#f9fafb}.visitors-table tr:last-child td{border-bottom:none}@media (max-width:768px){.reports-controls{gap:1.5rem;grid-template-columns:1fr}.export-buttons,.filter-buttons{flex-direction:column}.visitors-table-container{font-size:.75rem}.visitors-table td,.visitors-table th{padding:.5rem}}@media print{body *{visibility:hidden}.visitor-pass,.visitor-pass *{visibility:visible}.visitor-pass{left:0;position:absolute;top:0;width:100%}.btn{display:none!important}body *{visibility:hidden}.visitor-pass,.visitor-pass *{visibility:visible}.visitor-pass{left:0;position:absolute;top:0;width:100%}button{display:none!important}}@media (max-width:768px){.dashboard-container{border-radius:16px;margin:10px}.dashboard-header{padding:30px 20px}.dashboard-header h1{font-size:2rem}.dashboard-content{padding:30px 20px}}@media print{.btn,.export-buttons,.filter-buttons,.reports-controls,button{display:none!important}.visitors-table{page-break-inside:auto}.visitors-table tr{page-break-after:auto;page-break-inside:avoid}.visitors-table thead{display:table-header-group}.visitors-table tfoot{display:table-footer-group}.visitor-pass{margin:0!important;max-width:none!important;padding:20px!important}.visitor-pass img{print-color-adjust:exact;-webkit-print-color-adjust:exact}}.date-filter-container{display:flex;justify-content:center;margin-bottom:2rem}.date-filter{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 2px 4px #0000001a;display:flex;gap:1rem;padding:1rem 1.5rem}.date-filter .form-label{color:#374151;font-weight:600;margin:0;white-space:nowrap}.date-filter .form-input{margin:0;min-width:150px}@media (max-width:768px){.date-filter{flex-direction:column;gap:.5rem;text-align:center}.date-filter .form-input{width:100%}}