:root{--bg-base:#0a0e1a;--bg-card:#111827;--bg-elevated:#1a2235;--bg-input:#0d1320;--border:#1f2d45;--border-bright:#2d4060;--accent:#f59e0b;--accent-dim:#f59e0b1f;--accent2:#3b82f6;--accent2-dim:#3b82f61f;--success:#10b981;--success-dim:#10b9811f;--warning:#f59e0b;--warning-dim:#f59e0b1f;--danger:#ef4444;--danger-dim:#ef44441f;--mou:#8b5cf6;--mou-dim:#8b5cf61f;--text-primary:#f1f5f9;--text-secondary:#94a3b8;--text-muted:#475569;--font-display:"Space Grotesk",sans-serif;--font-body:"Inter",sans-serif;--font-mono:"Roboto Mono",monospace;--radius:12px;--radius-sm:8px;--shadow:0 4px 24px #00000080}*,:after,:before{box-sizing:border-box;margin:0;padding:0}#root,body,html{-webkit-font-smoothing:antialiased;background:#0a0e1a;background:var(--bg-base);color:#f1f5f9;color:var(--text-primary);font-family:Inter,sans-serif;font-family:var(--font-body);font-size:14px;height:100%;overflow:hidden}::-webkit-scrollbar{height:4px;width:4px}::-webkit-scrollbar-track{background:#0000}::-webkit-scrollbar-thumb{background:#2d4060;background:var(--border-bright);border-radius:2px}.loading-screen{align-items:center;display:flex;height:100vh;justify-content:center}.spinner{animation:spin .8s linear infinite;border:3px solid #1f2d45;border-top-color:#f59e0b;border:3px solid var(--border);border-radius:50%;border-top-color:var(--accent);height:36px;width:36px}@keyframes spin{to{transform:rotate(1turn)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn .2s ease}.top-bar{align-items:center;background:#111827;background:var(--bg-card);border-bottom:1px solid #1f2d45;border-bottom:1px solid var(--border);display:flex;flex-shrink:0;gap:10px;height:48px;min-height:48px;padding:0 12px 0 10px;z-index:100}.top-bar-logo{flex:1 1;min-width:0}.top-bar-name{font-family:Space Grotesk,sans-serif;font-family:var(--font-display);font-size:15px;font-weight:800;line-height:1.1}.top-bar-name .gold{color:#f59e0b;color:var(--accent)}.top-bar-name .white{color:#f1f5f9;color:var(--text-primary)}.top-bar-sub{color:#475569;color:var(--text-muted);font-family:Roboto Mono,monospace;font-family:var(--font-mono);font-size:9px;letter-spacing:.08em;text-transform:uppercase}.hamburger{align-items:center;background:none;border:none;border-radius:6px;color:#f59e0b;color:var(--accent);cursor:pointer;display:flex;flex-shrink:0;padding:6px}.app-layout{flex-direction:column;height:100vh}.app-body,.app-layout{display:flex;overflow:hidden}.app-body{flex:1 1}.sidebar{background:#111827;background:var(--bg-card);border-right:1px solid #1f2d45;border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;min-width:220px;overflow-x:hidden;overflow-y:auto;width:220px}.sidebar-user{border-bottom:1px solid #1f2d45;border-bottom:1px solid var(--border);gap:8px;padding:10px 14px}.sidebar-user,.user-avatar{align-items:center;display:flex}.user-avatar{background:#f59e0b1f;background:var(--accent-dim);border:1.5px solid #f59e0b;border:1.5px solid var(--accent);border-radius:50%;color:#f59e0b;color:var(--accent);flex-shrink:0;font-family:Space Grotesk,sans-serif;font-family:var(--font-display);font-size:12px;font-weight:700;height:30px;justify-content:center;width:30px}.user-info{flex:1 1;min-width:0}.user-name{color:#f1f5f9;color:var(--text-primary);font-size:12px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-role{color:#475569;color:var(--text-muted);font-family:Roboto Mono,monospace;font-family:var(--font-mono);font-size:9px;letter-spacing:.08em;text-transform:uppercase}.sidebar-nav{flex:1 1;padding:6px 0}.nav-section-label{color:#475569;color:var(--text-muted);font-family:Roboto Mono,monospace;font-family:var(--font-mono);font-size:9px;letter-spacing:.12em;padding:10px 14px 3px;text-transform:uppercase}.nav-item{align-items:center;border-left:2px solid #0000;color:#94a3b8;color:var(--text-secondary);cursor:pointer;display:flex;font-size:13px;font-weight:500;gap:8px;padding:10px 14px;text-decoration:none;transition:all .15s}.nav-item:hover{background:#1a2235;background:var(--bg-elevated);color:#f1f5f9;color:var(--text-primary)}.nav-item.active{background:#f59e0b1f;background:var(--accent-dim);border-left-color:#f59e0b;border-left-color:var(--accent);color:#f59e0b;color:var(--accent)}.nav-icon{flex-shrink:0;opacity:.7}.nav-item.active .nav-icon,.nav-item:hover .nav-icon{opacity:1}.nav-badge{background:#ef4444;background:var(--danger);border-radius:8px;color:#fff;font-family:Roboto Mono,monospace;font-family:var(--font-mono);font-size:9px;font-weight:700;margin-left:auto;padding:1px 5px}.sidebar-footer{border-top:1px solid #1f2d45;border-top:1px solid var(--border);padding:10px 14px}.version-tag{color:#475569;color:var(--text-muted);font-family:Roboto Mono,monospace;font-family:var(--font-mono);font-size:9px;letter-spacing:.05em;padding:6px 0 2px;text-align:center}.main-content{-webkit-overflow-scrolling:touch;background:#0a0e1a;background:var(--bg-base);display:flex;flex:1 1;flex-direction:column;min-width:0;overflow-x:hidden;overflow-y:auto}.page-header{align-items:center;background:#111827;background:var(--bg-card);border-bottom:1px solid #1f2d45;border-bottom:1px solid var(--border);display:flex;flex-shrink:0;justify-content:space-between;padding:14px 16px 12px}.page-title{color:#f1f5f9;color:var(--text-primary);font-family:Space Grotesk,sans-serif;font-family:var(--font-display);font-size:17px;font-weight:700}.page-subtitle{color:#475569;color:var(--text-muted);font-size:11px;margin-top:2px}.page-body{-webkit-overflow-scrolling:touch;flex:1 1;overflow-y:auto;padding:14px 14px 80px}.card{background:#111827;background:var(--bg-card);border:1px solid #1f2d45;border:1px solid var(--border);border-radius:12px;border-radius:var(--radius);padding:14px}.card-title{color:#475569;color:var(--text-muted);font-family:Space Grotesk,sans-serif;font-family:var(--font-display);font-size:11px;font-weight:700;letter-spacing:.1em;margin-bottom:10px;text-transform:uppercase}.quick-actions{grid-gap:10px;display:grid;gap:10px;grid-template-columns:1fr 1fr;margin-bottom:12px}.quick-action-btn{align-items:center;border:none;border-radius:12px;border-radius:var(--radius);cursor:pointer;display:flex;flex-direction:column;font-family:Space Grotesk,sans-serif;font-family:var(--font-display);font-weight:700;gap:5px;justify-content:center;padding:16px 12px;text-decoration:none;transition:all .2s;width:100%}.quick-action-btn.entry{background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 4px 16px #10b9814d;color:#fff}.quick-action-btn.exit{background:linear-gradient(135deg,#f59e0b,#d97706);box-shadow:0 4px 16px #f59e0b4d;color:#000}.quick-action-icon{font-size:26px}.quick-action-label{font-size:13px;font-weight:700}.quick-action-sub{font-size:10px;font-weight:400;opacity:.8}.checkpoint-btn{align-items:center;background:#10b9811f;background:var(--success-dim);border:2px solid #10b981;border:2px solid var(--success);border-radius:12px;border-radius:var(--radius);color:#10b981;color:var(--success);cursor:pointer;display:flex;font-family:Space Grotesk,sans-serif;font-family:var(--font-display);font-size:14px;font-weight:700;gap:8px;justify-content:center;margin-bottom:12px;padding:14px;transition:all .15s;width:100%}.checkpoint-btn:hover{background:#10b981;background:var(--success);color:#fff}.occupancy-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(2,1fr);margin-bottom:12px}.occ-box{background:#111827;background:var(--bg-card);border:1px solid #1f2d45;border:1px solid var(--border);border-radius:12px;border-radius:var(--radius);padding:14px 10px;text-align:center}.occ-number{font-family:Space Grotesk,sans-serif;font-family:var(--font-display);font-size:36px;font-weight:800;line-height:1}.occ-label{color:#475569;color:var(--text-muted);font-family:Roboto Mono,monospace;font-family:var(--font-mono);font-size:10px;letter-spacing:.08em;margin-top:5px;text-transform:uppercase}.stat-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(2,1fr);margin-bottom:12px}.stat-box{background:#111827;background:var(--bg-card);border:1px solid #1f2d45;border:1px solid var(--border);border-radius:12px;border-radius:var(--radius);overflow:hidden;padding:12px;position:relative;text-align:center}.stat-box:after{bottom:0;content:"";height:3px;left:0;position:absolute;right:0}.stat-box.gold:after{background:#f59e0b;background:var(--accent)}.stat-box.green:after{background:#10b981;background:var(--success)}.stat-box.blue:after{background:#3b82f6;background:var(--accent2)}.stat-box.red:after{background:#ef4444;background:var(--danger)}.stat-box.purple:after{background:#8b5cf6;background:var(--mou)}.stat-icon{display:block;font-size:20px;margin-bottom:5px}.stat-label{color:#475569;color:var(--text-muted);font-family:Roboto Mono,monospace;font-family:var(--font-mono);font-size:9px;letter-spacing:.1em;margin-bottom:5px;text-transform:uppercase}.stat-value{color:#f1f5f9;color:var(--text-primary);font-family:Space Grotesk,sans-serif;font-family:var(--font-display);font-size:18px;font-weight:800;line-height:1}.stat-sub{color:#475569;color:var(--text-muted);font-size:10px;margin-top:3px}.footfall-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(2,1fr);text-align:center}.footfall-item .num{font-family:Space Grotesk,sans-serif;font-family:var(--font-display);font-size:28px;font-weight:800;line-height:1}.footfall-item .lbl{color:#475569;color:var(--text-muted);font-family:Roboto Mono,monospace;font-family:var(--font-mono);font-size:9px;margin-top:4px;text-transform:uppercase}.vehicle-card{align-items:center;background:#0d1320;background:var(--bg-input);border:1px solid #1f2d45;border:1px solid var(--border);border-radius:8px;border-radius:var(--radius-sm);cursor:pointer;display:flex;gap:10px;margin-bottom:6px;padding:10px 12px;transition:border-color .15s}.vehicle-card:hover{border-color:#f59e0b;border-color:var(--accent)}.vehicle-plate{background:#f59e0b1f;background:var(--accent-dim);border:1px solid #f59e0b33;border-radius:8px;border-radius:var(--radius-sm);color:#f59e0b;color:var(--accent);font-family:Roboto Mono,monospace;font-family:var(--font-mono);font-size:13px;font-weight:700;letter-spacing:.08em;min-width:70px;padding:5px 8px;text-align:center;white-space:nowrap}.vehicle-info{flex:1 1;min-width:0}.vehicle-type{color:#475569;color:var(--text-muted);font-size:11px}.vehicle-time{color:#94a3b8;color:var(--text-secondary);font-size:11px;margin-top:1px}.vehicle-live{color:#10b981;color:var(--success);font-size:11px;font-weight:600;margin-top:2px}.live-fee,.vehicle-live{font-family:Roboto Mono,monospace;font-family:var(--font-mono)}.live-fee{color:#f59e0b;color:var(--warning);font-size:12px;font-weight:700;white-space:nowrap}.keypad-overlay{background:#000000b3;display:flex;flex-direction:column;inset:0;justify-content:flex-end;position:fixed;z-index:200}.keypad-container{background:#111827;background:var(--bg-card);border-radius:12px 12px 0 0;border-radius:var(--radius) var(--radius) 0 0;border-top:2px solid #2d4060;border-top:2px solid var(--border-bright);padding:14px}.keypad-display{background:#0d1320;background:var(--bg-input);border:1px solid #1f2d45;border:1px solid var(--border);border-radius:8px;border-radius:var(--radius-sm);color:#f59e0b;color:var(--accent);font-family:Roboto Mono,monospace;font-family:var(--font-mono);font-size:22px;font-weight:700;letter-spacing:.12em;margin-bottom:12px;min-height:52px;padding:12px 16px;text-align:center}.keypad-grid{grid-gap:6px;display:grid;gap:6px;grid-template-columns:repeat(5,1fr);margin-bottom:8px}.keypad-btn{-webkit-tap-highlight-color:transparent;background:#1a2235;background:var(--bg-elevated);border:1px solid #1f2d45;border:1px solid var(--border);border-radius:8px;border-radius:var(--radius-sm);color:#f1f5f9;color:var(--text-primary);cursor:pointer;font-family:Roboto Mono,monospace;font-family:var(--font-mono);font-size:14px;font-weight:700;padding:12px 6px;text-align:center;transition:all .1s}.keypad-btn:active{background:#f59e0b;background:var(--accent);color:#000}.keypad-btn.num{background:#1a2235;background:var(--bg-elevated);font-size:18px}.keypad-btn.letter{background:#0d1320;background:var(--bg-input);font-size:12px;padding:10px 4px}.keypad-btn.action{background:#1f2d45;background:var(--border);color:#f1f5f9;color:var(--text-primary)}.keypad-btn.confirm{background:#10b981;background:var(--success);color:#fff;font-size:15px}.keypad-actions{grid-gap:6px;display:grid;gap:6px;grid-template-columns:1fr 1fr 2fr}.btn{-webkit-tap-highlight-color:transparent;align-items:center;border:none;border-radius:8px;border-radius:var(--radius-sm);cursor:pointer;display:inline-flex;font-family:Inter,sans-serif;font-family:var(--font-body);font-size:13px;font-weight:600;gap:6px;justify-content:center;outline:none;padding:9px 14px;transition:all .15s;white-space:nowrap}.btn-primary{background:#f59e0b;background:var(--accent);color:#000}.btn-primary:hover{filter:brightness(1.1)}.btn-success{background:#10b981;background:var(--success);color:#fff}.btn-danger{background:#ef4444;background:var(--danger);color:#fff}.btn-warning{background:#f59e0b;background:var(--warning);color:#000}.btn-blue{background:#3b82f6;background:var(--accent2);color:#fff}.btn-whatsapp{background:#25d366;color:#fff}.btn-outline{background:#0000;border:1px solid #2d4060;border:1px solid var(--border-bright);color:#94a3b8;color:var(--text-secondary)}.btn-outline:hover{border-color:#f59e0b;border-color:var(--accent);color:#f59e0b;color:var(--accent)}.btn-ghost{background:#0000;color:#94a3b8;color:var(--text-secondary)}.btn-ghost:hover{background:#1a2235;background:var(--bg-elevated);color:#f1f5f9;color:var(--text-primary)}.btn-lg{border-radius:12px;border-radius:var(--radius);font-size:15px;padding:14px 22px}.btn-sm{font-size:12px;padding:6px 10px}.btn-full{width:100%}.btn:disabled{cursor:not-allowed;opacity:.4}.form-group{margin-bottom:12px}.form-label{color:#475569;color:var(--text-muted);display:block;font-family:Roboto Mono,monospace;font-family:var(--font-mono);font-size:10px;letter-spacing:.1em;margin-bottom:5px;text-transform:uppercase}.form-input,.form-select{background:#0d1320;background:var(--bg-input);border:1px solid #1f2d45;border:1px solid var(--border);border-radius:8px;border-radius:var(--radius-sm);color:#f1f5f9;color:var(--text-primary);font-family:Inter,sans-serif;font-family:var(--font-body);font-size:14px;outline:none;padding:10px 12px;transition:border-color .15s;width:100%}.form-input:focus,.form-select:focus{border-color:#f59e0b;border-color:var(--accent)}.form-input.plate-input{cursor:pointer;font-family:Roboto Mono,monospace;font-family:var(--font-mono);font-size:20px;font-weight:700;letter-spacing:.12em;padding:14px;text-align:center;text-transform:uppercase}.form-select{cursor:pointer}option{background:#111827;background:var(--bg-card)}.payment-select{grid-gap:10px;display:grid;gap:10px;grid-template-columns:1fr 1fr}.payment-btn{-webkit-tap-highlight-color:transparent;align-items:center;background:#0d1320;background:var(--bg-input);border:2px solid #1f2d45;border:2px solid var(--border);border-radius:12px;border-radius:var(--radius);color:#94a3b8;color:var(--text-secondary);cursor:pointer;display:flex;flex-direction:column;font-family:Space Grotesk,sans-serif;font-family:var(--font-display);font-size:14px;font-weight:700;gap:6px;padding:16px;transition:all .15s}.payment-btn.selected-cash{background:#10b9811f;background:var(--success-dim);border-color:#10b981;border-color:var(--success);color:#10b981;color:var(--success)}.payment-btn.selected-card{background:#3b82f61f;background:var(--accent2-dim);border-color:#3b82f6;border-color:var(--accent2);color:#3b82f6;color:var(--accent2)}.badge{align-items:center;border-radius:4px;display:inline-flex;font-family:Roboto Mono,monospace;font-family:var(--font-mono);font-size:10px;font-weight:600;gap:3px;letter-spacing:.04em;padding:2px 7px;text-transform:uppercase}.badge-success{background:#10b9811f;background:var(--success-dim);color:#10b981;color:var(--success)}.badge-danger{background:#ef44441f;background:var(--danger-dim);color:#ef4444;color:var(--danger)}.badge-warning{background:#f59e0b1f;background:var(--warning-dim);color:#f59e0b;color:var(--warning)}.badge-accent{background:#f59e0b1f;background:var(--accent-dim);color:#f59e0b;color:var(--accent)}.badge-mou{background:#8b5cf61f;background:var(--mou-dim);color:#8b5cf6;color:var(--mou)}.badge-blue{background:#3b82f61f;background:var(--accent2-dim);color:#3b82f6;color:var(--accent2)}.badge-neutral{background:#1a2235;background:var(--bg-elevated);color:#94a3b8;color:var(--text-secondary)}.table-wrap{-webkit-overflow-scrolling:touch;overflow-x:auto}table{border-collapse:collapse;width:100%}th{color:#475569;color:var(--text-muted);font-family:Roboto Mono,monospace;font-family:var(--font-mono);font-size:9px;letter-spacing:.1em;padding:8px 10px;text-align:left;text-transform:uppercase;white-space:nowrap}td,th{border-bottom:1px solid #1f2d45;border-bottom:1px solid var(--border)}td{color:#f1f5f9;color:var(--text-primary);font-size:13px;padding:10px;vertical-align:middle}tr:last-child td{border-bottom:none}tr:hover td{background:#1a2235;background:var(--bg-elevated)}.plate-cell{color:#f59e0b;color:var(--accent);font-family:Roboto Mono,monospace;font-family:var(--font-mono);font-weight:600;letter-spacing:.08em}.modal-overlay{align-items:flex-end;animation:fadeIn .15s ease;background:#000000bf;display:flex;inset:0;justify-content:center;position:fixed;z-index:150}.modal{animation:slideUp .2s ease;background:#111827;background:var(--bg-card);border:1px solid #2d4060;border:1px solid var(--border-bright);border-radius:12px 12px 0 0;border-radius:var(--radius) var(--radius) 0 0;box-shadow:0 4px 24px #00000080;box-shadow:var(--shadow);max-height:90vh;max-width:100%;overflow-y:auto;width:100%}.modal-header{align-items:center;border-bottom:1px solid #1f2d45;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:14px 16px}.modal-title{font-family:Space Grotesk,sans-serif;font-family:var(--font-display);font-size:15px;font-weight:700}.modal-body{padding:16px}.modal-footer{border-top:1px solid #1f2d45;border-top:1px solid var(--border);display:flex;gap:8px;justify-content:flex-end;padding:12px 16px}.alert{align-items:flex-start;border-radius:8px;border-radius:var(--radius-sm);display:flex;font-size:13px;gap:7px;margin-bottom:12px;padding:10px 12px}.alert-danger{background:#ef44441f;background:var(--danger-dim);border:1px solid #ef44444d;color:#ef4444;color:var(--danger)}.alert-success{background:#10b9811f;background:var(--success-dim);border:1px solid #10b9814d;color:#10b981;color:var(--success)}.alert-warning{background:#f59e0b1f;background:var(--warning-dim);border:1px solid #f59e0b4d;color:#f59e0b;color:var(--warning)}.alert-info{background:#3b82f61f;background:var(--accent2-dim);border:1px solid #3b82f64d;color:#3b82f6;color:var(--accent2)}.divider{background:#1f2d45;background:var(--border);height:1px;margin:12px 0}.empty-state{color:#475569;color:var(--text-muted);padding:36px 20px;text-align:center}.empty-state-icon{font-size:36px;margin-bottom:10px;opacity:.5}.empty-state-text{font-size:14px}.flex-row{gap:8px}.flex-between,.flex-row{align-items:center;display:flex}.flex-between{justify-content:space-between}.mt-8{margin-top:8px}.mt-12{margin-top:12px}.mt-16{margin-top:16px}.mb-8{margin-bottom:8px}.mb-12{margin-bottom:12px}.checkbox-group{align-items:flex-start;background:#0d1320;background:var(--bg-input);border:1px solid #1f2d45;border:1px solid var(--border);border-radius:8px;border-radius:var(--radius-sm);cursor:pointer;display:flex;gap:10px;padding:10px 12px}.checkbox-group input[type=checkbox]{accent-color:#f59e0b;accent-color:var(--accent);cursor:pointer;flex-shrink:0;height:18px;margin-top:1px;width:18px}.checkbox-label{color:#f1f5f9;color:var(--text-primary);font-size:13px;line-height:1.4}.receipt{background:#fff;border-radius:12px;border-radius:var(--radius);color:#111;font-family:Roboto Mono,monospace;font-family:var(--font-mono);font-size:11px;line-height:1.6;margin:0 auto;max-width:340px;padding:16px}.receipt-header{margin-bottom:10px;text-align:center}.receipt-title{font-size:14px;font-weight:700}.receipt-divider{border:none;border-top:1px dashed #bbb;margin:7px 0}.receipt-row{display:flex;justify-content:space-between;margin-bottom:2px}.receipt-balance,.receipt-total{font-size:13px;font-weight:700}.receipt-balance{color:#c00}.live-dot{animation:pulse 2s infinite;background:#10b981;background:var(--success);border-radius:50%;display:inline-block;height:7px;width:7px}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.search-bar{margin-bottom:10px;position:relative}.search-bar input{padding-left:36px}.search-icon{color:#475569;color:var(--text-muted);left:10px;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}@media print{body *{visibility:hidden}.receipt,.receipt *{visibility:visible}.receipt{background:#fff;color:#000;font-size:11px;left:0;position:fixed;top:0;width:80mm}}@media(min-width:769px){.modal{border-radius:12px;border-radius:var(--radius);margin:auto;max-width:500px}.modal-overlay{align-items:center}.page-body{padding:16px 20px 80px}.footfall-grid,.occupancy-grid,.stat-grid{grid-template-columns:repeat(4,1fr)}.quick-actions{grid-template-columns:1fr 1fr}}
/*# sourceMappingURL=main.bfe4e064.css.map*/