:root{--bg-primary:#0b0f19;--bg-secondary:#ffffff08;--border-color:#ffffff14;--text-primary:#fff;--text-secondary:#94a3b8;--color-green:#10b981;--color-red:#ef4444;--color-orange:#f59e0b;--color-blue:#3b82f6;--font-family:"Outfit", sans-serif;font-family:var(--font-family);background-color:var(--bg-primary);color:var(--text-primary);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-primary);min-height:100vh;margin:0;padding:0}#root{flex-direction:column;width:100%;min-height:100vh;display:flex}:root{--bg-primary:#03050c;--bg-card:#0a0f1e80;--border-color:#ffffff0d;--border-glow:#3b82f626;--text-primary:#f1f5f9;--text-secondary:#64748b;--color-green:#10b981;--color-red:#f43f5e;--color-orange:#f59e0b;--color-blue:#3b82f6;--color-purple:#a855f7;--glow-green:#10b9814d;--glow-red:#f43f5e4d;--glow-blue:#3b82f64d;--glow-purple:#a855f74d;--font-family:"Outfit", sans-serif}.app-wrapper{background-color:var(--bg-primary);background-image:radial-gradient(circle at 10% 20%,#3b82f61f 0%,#0000 40%),radial-gradient(circle at 90% 10%,#a855f71a 0%,#0000 40%),radial-gradient(circle at 50% 80%,#10b9810f 0%,#0000 45%);background-size:200% 200%;flex-direction:column;min-height:100vh;animation:25s infinite bgAnimation;display:flex;position:relative;overflow:hidden}.app-wrapper:before{content:"";pointer-events:none;z-index:0;background-image:linear-gradient(#ffffff01 1px,#0000 1px),linear-gradient(90deg,#ffffff01 1px,#0000 1px);background-size:30px 30px;width:100%;height:100%;position:absolute;top:0;left:0}.app-wrapper:after{content:"";z-index:99;pointer-events:none;opacity:.2;background:linear-gradient(#12101000 50%,#0000001f 50%) 0 0/100% 4px;width:100%;height:100%;position:absolute;top:0;left:0}@keyframes bgAnimation{0%{background-position:0%}50%{background-position:100%}to{background-position:0%}}header{border-bottom:1px solid var(--border-color);-webkit-backdrop-filter:blur(20px)saturate(180%);backdrop-filter:blur(20px)saturate(180%);z-index:100;background:#03050ccc;justify-content:space-between;align-items:center;padding:22px 5%;display:flex;position:sticky;top:0;box-shadow:0 4px 30px #0000004d}.logo-container{align-items:center;gap:16px;display:flex}.logo-icon{background:linear-gradient(135deg, var(--color-blue), var(--color-purple));border-radius:14px;justify-content:center;align-items:center;width:48px;height:48px;font-size:24px;animation:4s infinite alternate logoPulse;display:flex;box-shadow:0 0 20px #3b82f666}@keyframes logoPulse{0%{transform:scale(1);box-shadow:0 0 15px #3b82f64d}to{transform:scale(1.03);box-shadow:0 0 25px #a855f799}}.hologram-text{letter-spacing:-.5px;background:linear-gradient(90deg,#fff 0%,#a855f7 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;font-size:22px;font-weight:800;animation:6s infinite alternate textShine}@keyframes textShine{0%{filter:hue-rotate()}to{filter:hue-rotate(45deg)}}.subtitle{color:#64748b;letter-spacing:1px;text-transform:uppercase;font-size:11px;font-weight:600}.status-badge{border:1px solid var(--border-color);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff05;border-radius:30px;align-items:center;gap:10px;padding:8px 18px;font-size:12px;font-weight:600;display:flex;box-shadow:0 4px 12px #0003}.status-dot{border-radius:50%;width:8px;height:8px;position:relative}.status-dot:after{content:"";background:inherit;opacity:.4;border-radius:50%;width:12px;height:12px;animation:1.5s infinite pulseGlow;position:absolute;top:-2px;left:-2px}@keyframes pulseGlow{0%{opacity:.4;transform:scale(1)}to{opacity:0;transform:scale(2.2)}}.status-badge.demo-active{color:var(--color-orange);background:#f59e0b14;border-color:#f59e0b33}.status-badge.demo-active .status-dot{background-color:var(--color-orange)}.status-badge.online{color:var(--color-green);background:#10b98114;border-color:#10b98133}.status-badge.online .status-dot{background-color:var(--color-green)}.status-badge.offline{color:var(--color-red);background:#f43f5e14;border-color:#f43f5e33}.status-badge.offline .status-dot{background-color:var(--color-red)}main{z-index:1;flex-direction:column;flex:1;gap:30px;width:100%;max-width:1600px;margin:0 auto;padding:30px 5%;display:flex}.config-card{background:var(--bg-card);border:1px solid var(--border-color);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:20px;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:20px;padding:20px 28px;display:flex;box-shadow:0 10px 30px #0000004d}.config-form{flex-wrap:wrap;flex-grow:1;align-items:center;gap:15px;display:flex}.config-group{flex-grow:1;align-items:center;gap:12px;display:flex}.config-group label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-size:13px;font-weight:700}.config-group input{border:1px solid var(--border-color);color:var(--text-primary);background:#0006;border-radius:10px;width:100%;max-width:450px;padding:12px 16px;font-family:inherit;font-size:14px;transition:all .3s;box-shadow:inset 0 2px 4px #0000004d}.config-group input:focus{border-color:var(--color-blue);outline:none;box-shadow:0 0 12px #3b82f640}.btn{background:linear-gradient(135deg, var(--color-blue) 0%, #1d4ed8 100%);color:#fff;cursor:pointer;border:none;border-radius:10px;padding:12px 24px;font-family:inherit;font-size:14px;font-weight:600;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 15px #3b82f633}.btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #3b82f666}.btn-secondary{border:1px solid var(--border-color);color:var(--text-primary);box-shadow:none;background:#ffffff0a}.btn-secondary:hover{background:#ffffff14;border-color:#ffffff26}.active-demo-btn{color:var(--color-orange);background:#f59e0b14;border-color:#f59e0b4d}.active-demo-btn:hover{background:#f59e0b26}.btn-clear{color:var(--color-red);background:#f43f5e14;border:1px solid #f43f5e33;border-radius:8px;padding:8px 16px;font-size:12px}.btn-clear:hover{background:#f43f5e26}.error-alert{color:var(--color-red);background:#f43f5e14;border:1px solid #f43f5e33;border-radius:12px;padding:14px 24px;font-weight:600}.metrics-dashboard-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:24px;display:grid}.card-stat{background:var(--bg-card);border:1px solid var(--border-color);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:20px;flex-direction:column;gap:12px;padding:26px;transition:all .4s cubic-bezier(.25,1,.5,1);display:flex;position:relative;overflow:hidden;box-shadow:0 10px 25px #0003}.card-stat:hover{transform:translateY(-5px)scale(1.02)}.card-stat:before{content:"";width:100%;height:4px;position:absolute;top:0;left:0}.stat-blue:before{background:linear-gradient(90deg, var(--color-blue), #1d4ed8)}.stat-green:before{background:linear-gradient(90deg, var(--color-green), #047857)}.stat-orange:before{background:linear-gradient(90deg, var(--color-orange), #b45309)}.stat-purple:before{background:linear-gradient(90deg, var(--color-purple), #6d28d9)}.card-stat:hover.stat-blue{border-color:#3b82f64d;box-shadow:0 15px 30px #3b82f633}.card-stat:hover.stat-green{border-color:#10b9814d;box-shadow:0 15px 30px #10b98133}.card-stat:hover.stat-orange{border-color:#f59e0b4d;box-shadow:0 15px 30px #f59e0b33}.card-stat:hover.stat-purple{border-color:#a855f74d;box-shadow:0 15px 30px #a855f733}.stat-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:1px;font-size:12px;font-weight:700}.stat-value{color:var(--text-primary);letter-spacing:-1px;font-size:40px;font-weight:800;line-height:1}.font-large{font-size:30px}.stat-desc{color:var(--text-secondary);font-size:12px;font-weight:500}.diagnostics-panel{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff03;border:1px solid #ffffff08;border-radius:16px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:15px;padding:16px 24px;display:grid}.diag-item{align-items:center;gap:10px;font-size:13px;display:flex}.diag-dot{border-radius:50%;width:6px;height:6px}.dot-blue{background-color:var(--color-blue);box-shadow:0 0 6px var(--color-blue)}.dot-purple{background-color:var(--color-purple);box-shadow:0 0 6px var(--color-purple)}.dot-green{background-color:var(--color-green);box-shadow:0 0 6px var(--color-green)}.dot-orange{background-color:var(--color-orange);box-shadow:0 0 6px var(--color-orange)}.diag-label{color:var(--text-secondary);font-weight:500}.diag-val{color:var(--text-primary);font-weight:700}.font-mono{font-family:ui-monospace,monospace}.badge-density{border-radius:12px;padding:2px 8px;font-size:11px;font-weight:800}.density-low{color:var(--color-green);background:#10b9811f}.density-med{color:var(--color-orange);background:#f59e0b1f}.density-high{color:var(--color-red);background:#f43f5e1f}.monitor-layout{grid-template-columns:1.15fr 1.85fr;gap:30px;display:grid}@media (width<=1024px){.monitor-layout{grid-template-columns:1fr}}.panel-visual{background:var(--bg-card);border:1px solid var(--border-color);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:24px;flex-direction:column;justify-content:center;align-items:center;gap:30px;min-height:440px;padding:35px;display:flex;position:relative;box-shadow:0 15px 35px #0000004d}.visual-title{color:var(--text-secondary);text-transform:uppercase;letter-spacing:1.2px;font-size:13px;font-weight:700;position:absolute;top:24px;left:28px}.hologram-bracket{pointer-events:none;border-style:solid;border-color:#3b82f666;width:16px;height:16px;position:absolute}.bracket-tl{border-width:2px 0 0 2px;top:18px;left:18px}.bracket-tr{border-width:2px 2px 0 0;top:18px;right:18px}.bracket-bl{border-width:0 0 2px 2px;bottom:18px;left:18px}.bracket-br{border-width:0 2px 2px 0;bottom:18px;right:18px}.panel-visual:hover .hologram-bracket{border-color:var(--color-blue);filter:drop-shadow(0 0 5px var(--color-blue));transition:all .3s}.visual-elements{justify-content:center;align-items:center;gap:40px;width:100%;height:190px;display:flex;position:relative}.traffic-light{background:linear-gradient(135deg,#0f1322 0%,#1c2642 100%);border:2px solid #ffffff0a;border-radius:16px;flex-direction:column;justify-content:space-between;align-items:center;width:52px;height:145px;padding:12px;display:flex;box-shadow:0 15px 30px #0009,inset 0 3px 5px #ffffff0d}.light{background-color:#121727;border-radius:50%;width:28px;height:28px;transition:all .4s cubic-bezier(.25,1,.5,1);position:relative;box-shadow:inset 0 3px 5px #000000b3}.light:before{content:"";background:#ffffff26;border-radius:50%;width:8px;height:8px;position:absolute;top:4px;left:4px}.light.red.active{background-color:var(--color-red);box-shadow:0 0 20px var(--color-red), 0 0 40px var(--color-red), inset 0 -2px 6px #0003}.light.yellow.active{background-color:var(--color-orange);box-shadow:0 0 20px var(--color-orange), 0 0 40px var(--color-orange), inset 0 -2px 6px #0003}.light.green.active{background-color:var(--color-green);box-shadow:0 0 20px var(--color-green), 0 0 40px var(--color-green), inset 0 -2px 6px #0003}.gate-container{justify-content:center;align-items:center;width:220px;height:220px;display:flex;position:relative}.gate-post{z-index:2;background:linear-gradient(90deg,#4b5563 0%,#1f2937 100%);border-radius:8px;width:28px;height:130px;position:absolute;bottom:20px;left:35px;box-shadow:5px 10px 20px #00000080}.gate-post:after{content:"";background:radial-gradient(circle,#fbbf24 30%,#d97706 100%);border:4px solid #0b0f19;border-radius:50%;width:36px;height:36px;animation:1.5s infinite alternate beaconFlash;position:absolute;top:15px;left:-4px;box-shadow:0 2px 5px #00000080}@keyframes beaconFlash{0%{filter:brightness(.9);box-shadow:0 0 4px #fbbf244d}to{filter:brightness(1.2);box-shadow:0 0 16px #fbbf24cc}}.gate-arm{transform-origin:0%;z-index:3;background:repeating-linear-gradient(45deg,#f43f5e,#f43f5e 12px,#f8fafc 12px 24px);border-radius:8px;width:155px;height:14px;transition:transform 1.6s cubic-bezier(.25,1,.5,1);position:absolute;bottom:96px;left:55px;transform:rotate(0);box-shadow:0 6px 12px #00000073}.gate-container.open .gate-arm{transition:transform 1.6s cubic-bezier(.25,1,.5,1);transform:rotate(-90deg)}.gate-container.closing .gate-arm{transition:transform 5s linear;transform:rotate(0)}.car-visual-overlay{opacity:0;pointer-events:none;transition:all 1.8s cubic-bezier(.25,1,.5,1);position:absolute;bottom:25px;right:-90px}.gate-container.open~.car-visual-overlay{opacity:1;animation:4s forwards carPassingAnimation}@keyframes carPassingAnimation{0%{opacity:0;right:-75px;transform:scale(.95)}20%{opacity:1;right:48px;transform:scale(1)}75%{opacity:1;right:48px;transform:scale(1)}to{opacity:0;right:195px;transform:scale(.95)}}.visual-display-status{text-align:center;z-index:10}.visual-status-text{text-transform:uppercase;letter-spacing:1.5px;text-shadow:0 2px 10px #00000080;font-size:26px;font-weight:800}.text-red{color:var(--color-red)}.text-green{color:var(--color-green)}.text-orange{color:var(--color-orange)}.manual-controls{border-top:1px solid #ffffff0a;flex-direction:column;align-items:center;width:100%;padding-top:15px;display:flex}.manual-title{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.8px;font-size:11px;font-weight:700}.btn-manual{border:1px solid var(--border-color);cursor:pointer;color:var(--text-primary);background:#ffffff05;border-radius:8px;padding:8px 18px;font-family:inherit;font-size:12px;font-weight:700;transition:all .3s cubic-bezier(.4,0,.2,1)}.btn-open:hover:not(:disabled){color:var(--color-green);background:#10b9811a;border-color:#10b9814d;box-shadow:0 0 12px #10b98133}.btn-close:hover:not(:disabled){color:var(--color-red);background:#f43f5e1a;border-color:#f43f5e4d;box-shadow:0 0 12px #f43f5e33}.btn-auto:hover:not(:disabled){color:var(--color-blue);background:#3b82f61a;border-color:#3b82f64d;box-shadow:0 0 12px #3b82f633}.btn-manual:disabled{opacity:.35;cursor:not-allowed}.panel-charts{background:var(--bg-card);border:1px solid var(--border-color);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:24px;flex-direction:column;gap:20px;padding:28px;display:flex;box-shadow:0 15px 35px #0000004d}.chart-canvas-container{background:#00000040;border:1px solid #ffffff05;border-radius:16px;width:100%;height:295px;padding:15px;position:relative}.panel-logs{background:var(--bg-card);border:1px solid var(--border-color);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:24px;flex-direction:column;gap:20px;padding:28px;display:flex;box-shadow:0 15px 35px #0000004d}.logs-header{justify-content:space-between;align-items:center;display:flex}.table-container{border:1px solid var(--border-color);background:#0003;border-radius:14px;width:100%;overflow-x:auto}table{border-collapse:collapse;text-align:left;width:100%}th{color:var(--text-secondary);border-bottom:1px solid var(--border-color);text-transform:uppercase;letter-spacing:.8px;background:#ffffff03;padding:16px 20px;font-size:11px;font-weight:700}td{color:var(--text-primary);border-bottom:1px solid #ffffff05;padding:16px 20px;font-size:14px;transition:background-color .2s}tr:hover td{background:#ffffff04}tr:last-child td{border-bottom:none}.event-text-label{font-weight:600}.text-purple{color:#c084fc}.empty-table-cell{text-align:center;color:var(--text-secondary);font-weight:500;padding:50px!important}.badge-table{text-transform:uppercase;letter-spacing:.5px;border-radius:30px;padding:5px 10px;font-size:11px;font-weight:700;display:inline-block}.badge-table.open{color:var(--color-green);background:#10b98114;border:1px solid #10b98133;box-shadow:0 0 10px #10b9810d}.badge-table.closed{color:var(--color-red);background:#f43f5e14;border:1px solid #f43f5e33;box-shadow:0 0 10px #f43f5e0d}footer{text-align:center;color:var(--text-secondary);border-top:1px solid var(--border-color);letter-spacing:1px;background:#03050c66;margin-top:auto;padding:35px;font-size:12px;font-weight:600}
