:root{--bg-color:#050505;--panel-bg:#12141c73;--panel-border:#ffffff0f;--panel-border-glow:#ffffff1f;--text-primary:#fff;--text-secondary:#a1a1aa;--accent:#3b82f6;--accent-hover:#60a5fa;--accent-glow:#3b82f640;--density-low:#10b981;--density-medium:#f59e0b;--density-high:#ef4444;--sidebar-width:280px}*{box-sizing:border-box;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0;padding:0;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif}body{background-color:var(--bg-color);color:var(--text-primary);background-image:radial-gradient(circle at 10% 0,#3b82f61f,#0000 40%),radial-gradient(circle at 90% 10%,#8b5cf61a,#0000 40%),radial-gradient(circle at 50% 100%,#10b9810d,#0000 50%);background-attachment:fixed;min-height:100vh;overflow:hidden}.app-container{width:100vw;height:100vh;display:flex}.glass-panel{background:var(--panel-bg);-webkit-backdrop-filter:blur(24px);border:1px solid var(--panel-border);border-top-color:var(--panel-border-glow);border-left-color:var(--panel-border-glow);border-radius:24px;box-shadow:0 8px 32px #0006}.sidebar{width:var(--sidebar-width);border-right:1px solid var(--panel-border);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);z-index:10;background:#0a0c1099;flex-direction:column;gap:12px;height:100%;padding:32px 24px;display:flex;box-shadow:4px 0 24px #0003}.logo{letter-spacing:-.5px;background:linear-gradient(135deg,#60a5fa 0%,#c084fc 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;align-items:center;gap:12px;margin-bottom:48px;padding-left:8px;font-size:26px;font-weight:800;display:flex}.nav-item{cursor:pointer;color:var(--text-secondary);border:1px solid #0000;border-radius:16px;align-items:center;gap:16px;padding:16px 20px;font-weight:500;transition:all .4s cubic-bezier(.4,0,.2,1);display:flex}.nav-item:hover{color:var(--text-primary);background:#ffffff08}.nav-item.active{color:var(--accent-hover);box-shadow:inset 2px 0 0 var(--accent);background:linear-gradient(90deg,#3b82f626,#3b82f60d);border:1px solid #3b82f633}.main-content{flex:1;padding:48px;position:relative;overflow-y:auto}.header{justify-content:space-between;align-items:center;margin-bottom:48px;display:flex}.header-title{letter-spacing:-1px;color:var(--text-primary);margin-bottom:8px;font-size:32px;font-weight:800}.header p{color:var(--text-secondary);font-size:15px}.header-actions{gap:16px;display:flex}.dashboard-grid{grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:32px;margin-bottom:32px;display:grid}.card{flex-direction:column;gap:20px;padding:32px;transition:transform .4s,box-shadow .4s,border-color .4s;display:flex}.card:hover{border-color:#ffffff26;transform:translateY(-6px);box-shadow:0 20px 40px #00000080}.card-title{color:var(--text-secondary);text-transform:uppercase;letter-spacing:1px;align-items:center;gap:10px;font-size:15px;font-weight:600;display:flex}.card-value{letter-spacing:-1px;background:linear-gradient(#fff,#a1a1aa);-webkit-text-fill-color:transparent;-webkit-background-clip:text;font-size:42px;font-weight:800}.stadium-map{background:linear-gradient(#141a2866 0%,#0a0e1499 100%);grid-template-columns:repeat(4,1fr);gap:24px;padding:32px;display:grid;position:relative}.pitch{color:#10b98180;letter-spacing:4px;background:#10b9810d;border:2px dashed #10b98133;border-radius:120px;grid-area:2/2/4/4;justify-content:center;align-items:center;font-size:24px;font-weight:700;display:flex;box-shadow:inset 0 0 40px #10b9810d}.zone{border:1px solid var(--panel-border);background:#ffffff05;border-radius:20px;flex-direction:column;gap:12px;padding:24px;transition:all .5s cubic-bezier(.4,0,.2,1);display:flex;position:relative;overflow:hidden}.zone-name{color:var(--text-primary);font-size:16px;font-weight:700}.zone-density{text-transform:uppercase;letter-spacing:.5px;font-size:13px;font-weight:600}.zone-status{border-radius:50%;width:14px;height:14px;position:absolute;top:16px;right:16px}.zone.low{background:linear-gradient(#10b98114 0%,#0000 100%);border-color:#10b98133}.zone.low .zone-status{background:var(--density-low);box-shadow:0 0 15px var(--density-low)}.zone.medium{background:linear-gradient(#f59e0b14 0%,#0000 100%);border-color:#f59e0b33}.zone.medium .zone-status{background:var(--density-medium);box-shadow:0 0 15px var(--density-medium)}.zone.high{background:linear-gradient(#ef44441f 0%,#0000 100%);border-color:#ef44444d;animation:2s infinite pulse-red-panel}.zone.high .zone-status{background:var(--density-high);box-shadow:0 0 20px var(--density-high)}@keyframes pulse-red-panel{0%{box-shadow:0 0 #ef444433}70%{box-shadow:0 0 0 15px #ef444400}to{box-shadow:0 0 #ef444400}}@keyframes slideInRight{0%{opacity:0;filter:blur(4px);transform:translate(100%)}to{opacity:1;filter:blur();transform:translate(0)}}.alerts-container{z-index:100;flex-direction:column;gap:16px;width:380px;display:flex;position:absolute;top:48px;right:48px}.alert-item{border-left:4px solid var(--accent);background:#141822d9;align-items:flex-start;gap:16px;padding:20px;animation:.4s cubic-bezier(.175,.885,.32,1.275) forwards slideInRight;display:flex}.alert-item.critical{border-left-color:var(--density-high);box-shadow:0 8px 32px #ef444426}.alert-item.warning{border-left-color:var(--density-medium);box-shadow:0 8px 32px #f59e0b1a}.alert-item.info{border-left-color:var(--accent)}.alert-icon{background:#ffffff0d;border-radius:12px;margin-top:2px;padding:8px}.alert-content{flex:1}.alert-title{color:var(--text-primary);margin-bottom:6px;font-size:15px;font-weight:700}.alert-message{color:var(--text-secondary);font-size:14px;line-height:1.5}.alert-time{color:var(--text-secondary);opacity:.6;margin-top:10px;font-size:12px;font-weight:500}.qr-scanner{background:linear-gradient(#3b82f60d 0%,#3b82f603 100%);border:2px dashed #3b82f64d;border-radius:32px;flex-direction:column;justify-content:center;align-items:center;max-width:440px;margin:32px auto;padding:64px 40px;display:flex;position:relative;box-shadow:inset 0 0 60px #3b82f60d}.qr-line{background:var(--accent);width:70%;height:3px;box-shadow:0 0 20px 4px var(--accent-glow);border-radius:2px;animation:2.5s cubic-bezier(.4,0,.2,1) infinite alternate scan;position:absolute;top:20%}@keyframes scan{0%{opacity:.5;top:20%}50%{opacity:1}to{opacity:.5;top:80%}}.status-badge{text-transform:uppercase;letter-spacing:1.5px;border-radius:100px;padding:10px 24px;font-size:13px;font-weight:800;display:inline-block;box-shadow:0 4px 15px #0003}.status-badge.allowed{color:#34d399;background:linear-gradient(90deg,#10b98133,#10b9811a);border:1px solid #10b9814d}.status-badge.wait{color:#fbbf24;background:linear-gradient(90deg,#f59e0b33,#f59e0b1a);border:1px solid #f59e0b4d}.voice-fab{cursor:pointer;z-index:1000;color:#fff;background:linear-gradient(135deg,#3b82f6 0%,#8b5cf6 100%);border:1px solid #fff3;border-radius:50%;justify-content:center;align-items:center;width:72px;height:72px;transition:all .4s cubic-bezier(.175,.885,.32,1.275);display:flex;position:fixed;bottom:48px;right:48px;box-shadow:0 12px 32px #3b82f64d}.voice-fab:hover{transform:scale(1.08)translateY(-4px);box-shadow:0 20px 40px #3b82f680}.voice-fab.listening{background:#ef4444;animation:1.5s infinite pulse-blue-fab;box-shadow:0 12px 32px #ef444466}@keyframes pulse-blue-fab{0%{box-shadow:0 0 #ef444499}70%{box-shadow:0 0 0 25px #ef444400}to{box-shadow:0 0 #ef444400}}.voice-tooltip{border:1px solid var(--panel-border);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);white-space:nowrap;pointer-events:none;opacity:0;background:#0f141ce6;border-radius:16px;padding:14px 24px;font-size:14px;font-weight:600;transition:all .4s cubic-bezier(.175,.885,.32,1.275);position:absolute;right:90px;transform:translate(15px);box-shadow:0 10px 25px #0000004d}.voice-fab:hover .voice-tooltip{opacity:1;transform:translate(0)}.nav-layout{gap:32px;height:calc(100vh - 160px);display:flex}.destination-panel{flex-direction:column;gap:16px;width:340px;display:flex}.dest-btn{border:1px solid var(--panel-border);color:var(--text-primary);cursor:pointer;background:#ffffff08;border-radius:16px;align-items:center;gap:16px;padding:20px;font-size:15px;font-weight:600;transition:all .3s;display:flex}.dest-btn:hover{background:#ffffff0f;border-color:#ffffff1a;transform:translate(4px)}.dest-btn.active{background:linear-gradient(90deg,#3b82f626,#3b82f60d);border-color:#3b82f666;box-shadow:0 8px 24px #3b82f61a}.dest-icon{color:var(--text-secondary);background:#ffffff0d;border-radius:12px;padding:12px;transition:color .3s}.dest-btn.active .dest-icon{color:var(--accent-hover);background:#3b82f61a}.route-map{flex:1;justify-content:center;align-items:center;padding:32px;display:flex;position:relative}.route-content{flex-direction:column;justify-content:center;align-items:center;gap:32px;width:100%;height:100%;display:flex}.path-step{opacity:0;background:linear-gradient(90deg,#10b9811a,#10b9810d);border:1px solid #10b98133;border-radius:20px;align-items:center;gap:20px;width:80%;max-width:540px;padding:20px 32px;font-size:16px;font-weight:600;animation:.5s cubic-bezier(.175,.885,.32,1.275) forwards fadeInUp;display:flex;transform:translateY(20px);box-shadow:0 8px 24px #0000001a}.path-step:nth-child(2){animation-delay:.15s}.path-step:nth-child(3){animation-delay:.3s}.path-step:nth-child(4){animation-delay:.45s}.path-arrow{color:#10b981;filter:drop-shadow(0 4px 8px #10b9814d)}@keyframes fadeInUp{to{opacity:1;transform:translateY(0)}}.path-time{color:#34d399;margin-left:auto;font-size:15px;font-weight:800}@media (width<=1024px){.stadium-map{grid-template-columns:repeat(2,1fr)}.pitch{grid-area:2/1/3/-1;padding:32px 0}.nav-layout{flex-direction:column;height:auto}.destination-panel{width:100%}}@media (width<=768px){.app-container{flex-direction:column}.sidebar{border-right:none;border-top:1px solid var(--panel-border);z-index:1000;flex-direction:row;justify-content:space-around;align-items:center;width:100%;height:80px;padding:8px;position:fixed;bottom:0;left:0}.logo{display:none}.nav-item{text-align:center;border-radius:12px;flex-direction:column;flex:1;justify-content:center;gap:6px;padding:8px;font-size:11px}.main-content{padding:24px 16px 100px}.header{flex-direction:column;align-items:flex-start;gap:16px;margin-bottom:24px}.header-title{font-size:24px}.header-actions{width:100%}.header-actions button{justify-content:center;width:100%}.stadium-map{grid-template-columns:1fr;padding:16px}.pitch{border-radius:20px;grid-area:auto/1/auto/-1;padding:40px 0}.alerts-container{width:auto;top:16px;left:16px;right:16px}.voice-fab{width:56px;height:56px;bottom:100px;right:24px}.qr-scanner{padding:32px 16px}}
