.app{min-height:100vh}.app-header{background-color:var(--bg-card);padding:24px 30px;box-shadow:0 2px 8px var(--shadow-sm);margin-bottom:30px;border-radius:10px;display:flex;align-items:center;justify-content:space-between;transition:background-color .4s ease,box-shadow .4s ease;border-left:4px solid #F96302}.app-header h1{color:var(--text-primary);font-size:28px;font-weight:700;letter-spacing:-.3px;transition:color .4s ease}.title-accent{color:#f96302;font-weight:800;text-transform:uppercase;letter-spacing:1.5px;font-size:.95em}.title-version{background:linear-gradient(135deg,#f96302,#ff8c42);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-weight:800;font-size:1.05em}.title-separator{color:var(--text-secondary, #999);font-weight:300;margin:0 4px;opacity:.5}.header-controls{display:flex;align-items:center;gap:16px}.loading-indicator{display:inline-block;color:var(--text-link);font-size:14px;font-weight:500}.error-indicator{display:inline-block;color:#e74c3c;font-size:14px;font-weight:500}.countdown-banner{text-align:center;padding:24px 16px}.countdown-label{font-size:16px;font-weight:600;text-transform:uppercase;letter-spacing:2px;color:var(--text-primary);margin-bottom:12px}.countdown-timer{display:flex;align-items:baseline;justify-content:center;gap:8px}.countdown-segment{display:flex;flex-direction:column;align-items:center}.countdown-value{font-size:56px;font-weight:800;line-height:1;color:var(--text-primary);font-variant-numeric:tabular-nums}.countdown-unit{font-size:12px;font-weight:500;text-transform:uppercase;letter-spacing:1px;color:var(--text-secondary, var(--text-primary));margin-top:4px}.countdown-colon{font-size:48px;font-weight:800;color:var(--text-primary);line-height:1;align-self:flex-start}.live-indicator{display:inline-flex;align-items:center;color:var(--live-color);font-size:13px;font-weight:500;gap:2px;animation:fadeIn .3s ease-in}.pulse-dot{display:inline-block;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;text-align:center}.loading-spinner{width:50px;height:50px;border:4px solid var(--spinner-track);border-top:4px solid var(--spinner-fill);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:20px;transition:border-color .4s ease}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-container p{color:var(--text-secondary);font-size:16px;transition:color .4s ease}.search-bar-container{padding:0 10px;margin-bottom:16px}.search-bar{display:flex;align-items:center;gap:10px;max-width:420px;padding:10px 16px;background-color:var(--bg-card);border:1px solid var(--border-medium);border-radius:10px;box-shadow:0 1px 4px var(--shadow-sm);transition:border-color .2s ease,box-shadow .2s ease,background-color .4s ease}.search-bar:focus-within{border-color:var(--text-link);box-shadow:0 0 0 3px #2196f326}.search-icon{flex-shrink:0;color:var(--text-muted);transition:color .2s ease}.search-bar:focus-within .search-icon{color:var(--text-link)}.search-input{flex:1;border:none;outline:none;background:transparent;font-size:15px;color:var(--text-primary);font-family:inherit}.search-input::placeholder{color:var(--text-muted)}.search-clear{display:flex;align-items:center;justify-content:center;width:22px;height:22px;padding:0;border:none;border-radius:50%;background-color:var(--bg-hover);color:var(--text-secondary);font-size:12px;cursor:pointer;transition:background-color .15s ease,color .15s ease}.search-clear:hover{background-color:var(--border-medium);color:var(--text-primary)}.dashboard-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px;padding:0 10px}@media (max-width: 768px){.dashboard-container{grid-template-columns:1fr}.app-header{flex-direction:column;gap:16px;align-items:flex-start}}.flying-rocket{position:fixed;z-index:10000;pointer-events:none;will-change:left,top,transform,opacity;animation:crossColumnFlight 3.2s cubic-bezier(.25,.1,.25,1) forwards;filter:drop-shadow(0 0 12px rgba(255,120,0,.9)) drop-shadow(0 0 30px rgba(255,80,0,.4))}.flying-rocket-body{font-size:36px;line-height:1;display:block}.rocket-shake{animation:liftoffRumble 3.2s ease-out forwards}@keyframes liftoffRumble{0%{transform:translate(0)}1%{transform:translate(-2px,1px)}2%{transform:translate(2px,-1px)}3%{transform:translate(-1px,2px)}4%{transform:translate(3px)}5%{transform:translate(-2px,-1px)}6%{transform:translate(1px,2px)}7%{transform:translate(-3px,-1px)}8%{transform:translate(2px,1px)}9%{transform:translate(-1px,-2px)}10%{transform:translate(2px,1px)}12%{transform:translate(-1px)}14%{transform:translate(1px,-1px)}16%{transform:translate(-1px,1px)}18%{transform:translate(0)}20%{transform:translate(0)}to{transform:translate(0)}}.exhaust-trail{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:0;height:0;pointer-events:none}.exhaust-particle{position:absolute;width:6px;height:6px;border-radius:50%;opacity:0}.exhaust-particle.p1{background:#f80;box-shadow:0 0 8px 4px #f809;animation:exhaustDrift .6s 0s ease-out infinite}.exhaust-particle.p2{background:#f60;box-shadow:0 0 6px 3px #ff660080;animation:exhaustDrift .6s .12s ease-out infinite}.exhaust-particle.p3{background:#fa3;box-shadow:0 0 10px 5px #fa36;animation:exhaustDrift .6s .24s ease-out infinite}.exhaust-particle.p4{background:#f40;box-shadow:0 0 6px 3px #ff440080;animation:exhaustDrift .6s .36s ease-out infinite}.exhaust-particle.p5{background:#c60;box-shadow:0 0 5px 2px #c606;animation:exhaustDrift .6s .48s ease-out infinite}@keyframes exhaustDrift{0%{opacity:.9;transform:translate(0) scale(1)}50%{opacity:.4;transform:translate(calc(-8px * var(--dir, 1)),12px) scale(.6)}to{opacity:0;transform:translate(calc(-16px * var(--dir, 1)),24px) scale(.2)}}.flying-rocket:after{content:"";position:absolute;top:50%;left:50%;width:10px;height:10px;margin:-5px 0 0 -5px;border-radius:50%;background:#ffb432cc;animation:engineGlow 3.2s ease-out forwards;box-shadow:0 0 8px 4px #ff780099,0 0 20px 10px #ff500059,0 0 40px 20px #ff320026}@keyframes engineGlow{0%{opacity:0;transform:scale(0)}3%{opacity:1;transform:scale(1.5)}20%{opacity:1;transform:scale(1.3)}40%{opacity:.5;transform:scale(.7)}55%{opacity:.4;transform:scale(.5)}70%{opacity:.9;transform:scale(1.2)}85%{opacity:.7;transform:scale(.8)}95%{opacity:.3;transform:scale(.3)}to{opacity:0;transform:scale(0)}}@keyframes crossColumnFlight{0%{left:var(--start-x);top:var(--start-y);transform:translate(-50%,-50%) scale(0) rotate(-45deg);opacity:0}3%{left:var(--start-x);top:var(--start-y);transform:translate(-50%,-50%) scale(.7) rotate(-45deg);opacity:.8}8%{left:var(--start-x);top:calc(var(--start-y) - 20px);transform:translate(-50%,-50%) scale(1) rotate(calc(-45deg + 5deg * var(--dir)));opacity:1}16%{left:var(--start-x);top:calc(var(--start-y) - 80px);transform:translate(-50%,-50%) scale(1.05) rotate(calc(-45deg + 15deg * var(--dir)));opacity:1}28%{left:var(--start-x);top:var(--peak-y);transform:translate(-50%,-50%) scale(1.1) rotate(calc(-45deg + 35deg * var(--dir)));opacity:1}38%{left:calc(var(--start-x) + (var(--end-x) - var(--start-x)) * .2);top:calc(var(--peak-y) - 15px);transform:translate(-50%,-50%) scale(1.05) rotate(calc(-45deg + 65deg * var(--dir)));opacity:1}48%{left:calc(var(--start-x) + (var(--end-x) - var(--start-x)) * .5);top:var(--peak-y);transform:translate(-50%,-50%) scale(1) rotate(calc(-45deg + 90deg * var(--dir)));opacity:1}58%{left:calc(var(--start-x) + (var(--end-x) - var(--start-x)) * .8);top:calc(var(--peak-y) + 30px);transform:translate(-50%,-50%) scale(1) rotate(calc(-45deg + 115deg * var(--dir)));opacity:1}68%{left:calc(var(--start-x) + (var(--end-x) - var(--start-x)) * .95);top:calc(var(--end-y) - 100px);transform:translate(-50%,-50%) scale(.95) rotate(calc(-45deg + 140deg * var(--dir)));opacity:1}80%{left:var(--end-x);top:calc(var(--end-y) - 40px);transform:translate(-50%,-50%) scale(.9) rotate(calc(-45deg + 160deg * var(--dir)));opacity:1}88%{left:var(--end-x);top:calc(var(--end-y) - 10px);transform:translate(-50%,-50%) scale(.7) rotate(calc(-45deg + 172deg * var(--dir)));opacity:.9}94%{left:var(--end-x);top:var(--end-y);transform:translate(-50%,-50%) scale(.35) rotate(calc(-45deg + 178deg * var(--dir)));opacity:.5}to{left:var(--end-x);top:var(--end-y);transform:translate(-50%,-50%) scale(0) rotate(calc(-45deg + 180deg * var(--dir)));opacity:0}}.auth-loading{display:flex;justify-content:center;align-items:center;min-height:100vh;font-size:1.2rem;color:#666}.sign-out-button{padding:6px 16px;font-size:.85rem;font-weight:600;color:#fff;background:#555;border:none;border-radius:6px;cursor:pointer;transition:background .2s;margin-left:8px}.sign-out-button:hover{background:#f96302}.route-list{background-color:var(--bg-card);border-radius:8px;box-shadow:0 2px 8px var(--shadow-sm);overflow:hidden;display:flex;flex-direction:column;height:fit-content;transition:box-shadow .3s ease,background-color .4s ease}.route-list:hover{box-shadow:0 4px 12px var(--shadow-md)}.route-list-header{padding:20px;border-left:4px solid;display:flex;justify-content:space-between;align-items:center;background-color:var(--bg-card-header);transition:background-color .4s ease}.route-list-header h2{font-size:20px;font-weight:600;color:var(--text-primary);margin:0;transition:color .4s ease}.route-count{color:#fff;padding:4px 12px;border-radius:12px;font-size:14px;font-weight:600;min-width:30px;text-align:center}.route-list-toolbar{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:8px 20px;border-bottom:1px solid var(--border-medium);transition:border-color .4s ease}.route-list-description{color:var(--text-secondary);font-size:14px;margin:0;transition:color .4s ease}.sort-filter-wrapper{position:relative;flex-shrink:0}.sort-filter-button{display:flex;align-items:center;gap:4px;padding:4px 8px;font-size:12px;border:1px solid var(--border-medium);border-radius:6px;background-color:var(--bg-card);color:var(--text-secondary);cursor:pointer;outline:none;transition:border-color .2s ease,background-color .4s ease,color .4s ease}.sort-filter-button:hover,.sort-filter-button.active{border-color:var(--text-link, #4A90E2);color:var(--text-link, #4A90E2)}.sort-filter-button.has-active{border-color:var(--text-link, #4A90E2)}.active-badge{display:inline-flex;align-items:center;justify-content:center;min-width:16px;height:16px;padding:0 4px;font-size:10px;font-weight:700;color:#fff;background-color:var(--text-link, #4A90E2);border-radius:8px;line-height:1}.sort-filter-menu{z-index:1000;min-width:200px;padding:8px 0;background-color:var(--bg-card);border:1px solid var(--border-medium);border-radius:8px;box-shadow:0 8px 24px var(--shadow-md, rgba(0,0,0,.15));animation:menu-fade-in .15s ease}@keyframes menu-fade-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.menu-section{padding:4px 12px}.menu-section-label{display:block;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);padding:4px 0}.menu-option{display:flex;align-items:center;gap:6px;width:100%;padding:6px 8px;font-size:13px;color:var(--text-primary);background:none;border:none;border-radius:4px;cursor:pointer;text-align:left;transition:background-color .15s ease}.menu-option:hover{background-color:var(--bg-hover, rgba(0,0,0,.05))}.menu-option.selected{font-weight:600;color:var(--text-link, #4A90E2)}.check-mark{font-size:12px;width:14px}.menu-divider{height:1px;margin:6px 12px;background-color:var(--border-light, #eee)}.service-filter-select{width:100%;padding:6px 8px;margin-top:2px;font-size:13px;border:1px solid var(--border-medium);border-radius:6px;background-color:var(--bg-card);color:var(--text-primary);cursor:pointer;outline:none;transition:border-color .2s ease,background-color .4s ease}.service-filter-select:focus{border-color:var(--text-link, #4A90E2);box-shadow:0 0 0 2px #4a90e233}.menu-reset{display:block;width:calc(100% - 24px);margin:2px 12px 4px;padding:6px 8px;font-size:12px;color:var(--text-secondary);background:none;border:1px dashed var(--border-medium);border-radius:4px;cursor:pointer;text-align:center;transition:color .15s ease,border-color .15s ease}.menu-reset:hover{color:var(--text-link, #4A90E2);border-color:var(--text-link, #4A90E2)}.route-items{padding:10px 0}.route-items ul{list-style:none;padding:0;margin:0}.route-item{border-bottom:1px solid var(--border-light);transition:border-color .4s ease}.route-item:last-child{border-bottom:none}.failure-reason-banner{display:flex;align-items:center;gap:6px;padding:6px 0;margin-bottom:8px;font-size:12px}.failure-reason-label{font-weight:600;color:var(--text-secondary);font-size:11px;text-transform:uppercase;letter-spacing:.03em}.failure-tag{display:inline-block;padding:1px 8px;border-radius:10px;font-size:11px;font-weight:600;line-height:1.6}.failure-tag-deployment{background-color:#fee2e2;color:#991b1b}.failure-tag-healthcheck{background-color:#fef3c7;color:#92400e}[data-theme=dark] .failure-tag-deployment{background-color:#7f1d1d;color:#fca5a5}[data-theme=dark] .failure-tag-healthcheck{background-color:#78350f;color:#fcd34d}.route-header{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;transition:background-color .2s ease}.route-header:hover{background-color:var(--bg-hover)}.route-link{flex:1;text-decoration:none;color:inherit;padding:4px 0}.route-name{font-weight:600;color:var(--text-route);font-size:15px;transition:color .2s ease}.route-link:hover .route-name{color:var(--text-link)}.toggle-button{background:none;border:none;cursor:pointer;padding:8px 12px;font-size:12px;color:var(--text-secondary);transition:all .2s ease;border-radius:4px}.toggle-button:hover{background-color:var(--bg-hover);color:var(--text-primary)}.route-details{padding:24px 20px 16px;background-color:var(--bg-dropdown);animation:slideDown .2s ease-out;transition:background-color .4s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.route-metadata{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}.metadata-row{display:flex;align-items:center;gap:8px;font-size:12px}.metadata-label{font-weight:600;color:var(--text-secondary);min-width:130px;transition:color .4s ease}.metadata-value{color:var(--text-primary);font-weight:500;transition:color .4s ease}.metrics-links{display:flex;align-items:center;gap:6px;margin-bottom:12px;font-size:12px}.metrics-label{font-weight:600;color:var(--text-secondary);min-width:130px;transition:color .4s ease}.metrics-link-inline{color:var(--text-link);text-decoration:none;font-weight:600;padding:2px 8px;border-radius:3px;transition:all .2s ease;background-color:var(--bg-metrics)}.metrics-link-inline:hover{background-color:var(--bg-metrics-hover);text-decoration:underline}.metrics-separator{color:var(--text-muted);margin:0 4px}.deployment-status-meta{display:flex;align-items:center;gap:8px;margin-bottom:12px;font-size:12px}.status-label{font-weight:600;color:var(--text-secondary);min-width:130px;transition:color .4s ease}.status-badge{padding:4px 10px;border-radius:4px;font-size:11px;font-weight:600;text-transform:uppercase;white-space:nowrap;transition:background-color .4s ease,color .4s ease}.status-deployed{background-color:var(--status-success-bg);color:var(--status-success-text)}.status-deployment-failed{background-color:var(--status-danger-bg);color:var(--status-danger-text)}.status-in-progress,.status-pending,.status-processing,.status-validating{background-color:var(--status-info-bg);color:var(--status-info-text)}.status-rolling-back{background-color:var(--status-warn-bg);color:var(--status-warn-text)}.deploy-time-meta{display:flex;align-items:center;gap:8px;margin-bottom:12px;font-size:12px}.deploy-time-label{font-weight:600;color:var(--text-secondary);min-width:130px;transition:color .4s ease}.deploy-time-value{color:var(--text-primary);font-weight:500;font-family:monospace;transition:color .4s ease}.health-data{margin-top:8px;display:flex;flex-direction:column;gap:8px}.health-row{display:flex;align-items:center;gap:8px;font-size:12px}.health-label{font-weight:600;color:var(--text-secondary);min-width:130px;transition:color .4s ease}.health-value{padding:3px 10px;background-color:var(--bg-input);border-radius:4px;color:var(--text-primary);font-weight:500;font-size:12px;transition:background-color .4s ease,color .4s ease}.health-value.passing{background-color:var(--status-success-bg);color:var(--status-success-text);font-weight:600}.health-value.failing{background-color:var(--status-danger-bg);color:var(--status-danger-text);font-weight:600}.health-separator{color:var(--text-muted);font-weight:700;margin:0 4px}.empty-state{padding:40px 20px;text-align:center;color:var(--text-muted);font-style:italic;transition:color .4s ease}.show-more-button{width:100%;padding:12px;border:none;border-top:1px solid var(--border-medium);background-color:var(--bg-card-header);color:var(--text-secondary);font-size:14px;font-weight:600;cursor:pointer;transition:background-color .2s ease,color .2s ease}.show-more-button:hover{background-color:var(--border-medium);color:var(--text-primary)}.rocket-landing{position:relative;overflow:visible!important}.rocket-landing>.route-header{animation:routeCardAppear 1s cubic-bezier(.34,1.56,.64,1) both}@keyframes routeCardAppear{0%{opacity:0;transform:scaleY(.1) scaleX(.85);transform-origin:top center}20%{opacity:.6;transform:scaleY(.5) scaleX(.92);transform-origin:top center}40%{opacity:1;transform:scaleY(1.08) scaleX(1.03);transform-origin:top center}55%{transform:scaleY(.96) scaleX(.99)}70%{transform:scaleY(1.03) scaleX(1.01)}85%{transform:scaleY(.99)}to{opacity:1;transform:scaleY(1) scaleX(1)}}.landing-effect{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;justify-content:center;align-items:center;pointer-events:none;z-index:100;overflow:visible}.landing-flash{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:0;height:0;border-radius:50%;background:radial-gradient(circle,rgba(255,165,0,.5) 0%,rgba(255,100,0,.2) 40%,transparent 70%);animation:landingImpact 1s ease-out forwards;pointer-events:none}@keyframes landingImpact{0%{width:0;height:0;opacity:0}15%{width:60px;height:60px;opacity:.8}35%{width:100px;height:90px;opacity:1}to{width:180px;height:50px;opacity:0}}.rocket-landing:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:4px;height:4px;border-radius:50%;box-shadow:-15px -5px #c8c8c800,15px -8px #c8c8c800,-8px -12px #c8c8c800,8px -3px #c8c8c800,0 -15px #c8c8c800;animation:smokeParticles 1s ease-out forwards;pointer-events:none;z-index:99}@keyframes smokeParticles{0%{box-shadow:0 0 #c8c8c800,0 0 #c8c8c800,0 0 #c8c8c800,0 0 #c8c8c800,0 0 #c8c8c800}15%{box-shadow:-12px -4px 0 2px #c8c8c880,14px -6px 0 2px #c8c8c866,-6px -10px 0 1px #c8c8c84d,8px -2px 0 2px #c8c8c866,0 -12px 0 1px #c8c8c833}35%{box-shadow:-24px -10px 0 3px #c8c8c899,26px -14px 0 3px #c8c8c880,-16px -22px 0 2px #c8c8c866,18px -6px 0 3px #c8c8c880,0 -26px 0 2px #c8c8c84d}to{box-shadow:-45px -20px #c8c8c800,48px -25px #c8c8c800,-28px -38px #c8c8c800,32px -14px #c8c8c800,0 -48px #c8c8c800}}.theme-toggle{background:none;border:none;cursor:pointer;padding:4px;display:flex;align-items:center;outline:none}.toggle-track{position:relative;width:56px;height:28px;border-radius:14px;background:var(--toggle-track-bg);display:flex;align-items:center;justify-content:space-between;padding:0 5px;transition:background .4s cubic-bezier(.4,0,.2,1);box-shadow:inset 0 1px 3px #00000026,0 1px 2px #ffffff0d}.toggle-icon{font-size:13px;line-height:1;z-index:1;transition:opacity .3s ease;-webkit-user-select:none;user-select:none}[data-theme=light] .toggle-sun{opacity:1}[data-theme=light] .toggle-moon,[data-theme=dark] .toggle-sun{opacity:.35}[data-theme=dark] .toggle-moon{opacity:1}.toggle-thumb{position:absolute;top:3px;left:3px;width:22px;height:22px;border-radius:50%;background:var(--toggle-thumb-bg);box-shadow:0 1px 4px #0003;transition:transform .4s cubic-bezier(.4,0,.2,1),background .4s cubic-bezier(.4,0,.2,1)}[data-theme=dark] .toggle-thumb{transform:translate(28px)}.theme-toggle:hover .toggle-thumb{box-shadow:0 2px 6px #0000004d}.theme-toggle:active .toggle-thumb{width:26px}[data-theme=dark] .theme-toggle:active .toggle-thumb{transform:translate(24px)}.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:#f5f5f5}[data-theme=dark] .login-container{background:#1e1e2e}.login-card{text-align:center;padding:48px 40px;background:#fff;border-radius:12px;box-shadow:0 4px 24px #0000001a;max-width:400px;width:90%}[data-theme=dark] .login-card{background:#2a2a3e}.login-header h1{font-size:1.4rem;margin-bottom:8px;color:#1a1a2e}[data-theme=dark] .login-header h1{color:#e0e0e0}.login-header p{color:#666;font-size:.9rem;margin-bottom:28px}[data-theme=dark] .login-header p{color:#aaa}.login-error{background:#fdecea;color:#b71c1c;padding:10px 16px;border-radius:8px;margin-bottom:20px;font-size:.85rem}.login-button{padding:12px 28px;font-size:1rem;font-weight:600;color:#fff;background:#2f2f2f;border:none;border-radius:8px;cursor:pointer;transition:background .2s}.login-button:hover{background:#404040}.notification-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9998;background:#00000059;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);animation:backdropFadeIn .3s ease-out forwards}.notification-backdrop.dismissing{animation:backdropFadeOut .4s ease-in forwards}[data-theme=dark] .notification-backdrop{background:#0000008c}.notification-banner{position:fixed;top:28vh;left:50%;transform:translate(-50%);z-index:9999;display:flex;align-items:flex-start;gap:24px;width:calc(100% - 40px);max-width:760px;padding:36px 40px;border-radius:20px;border:1px solid rgba(255,255,255,.15);color:#fff;line-height:1.5;animation:bannerFadeIn .4s cubic-bezier(.16,1,.3,1) forwards}.notification-banner.dismissing{animation:bannerFadeOut .4s ease-in forwards}[data-theme=light] .notification-banner,:root .notification-banner{background:linear-gradient(160deg,#f96302,#e85500);box-shadow:0 24px 72px #f9630266,0 4px 20px #0000001f;animation:bannerFadeIn .4s cubic-bezier(.16,1,.3,1) forwards,bannerGlow 3s ease-in-out 1s infinite}[data-theme=light] .notification-banner.dismissing,:root .notification-banner.dismissing{animation:bannerFadeOut .4s ease-in forwards}[data-theme=dark] .notification-banner{background:linear-gradient(160deg,#1e2436,#1a1f30);border-color:#f963024d;box-shadow:0 24px 72px #0000008c,0 0 0 1px #f9630226,0 4px 20px #00000059;animation:bannerFadeIn .4s cubic-bezier(.16,1,.3,1) forwards,bannerGlowDark 3s ease-in-out 1s infinite}[data-theme=dark] .notification-banner.dismissing{animation:bannerFadeOut .4s ease-in forwards}.notification-banner-icon{display:flex;align-items:center;justify-content:center;width:56px;height:56px;flex-shrink:0;border-radius:14px}.icon-bell{animation:bellRing .6s ease-in-out .5s;transform-origin:top center}.icon-gif{background:transparent!important;overflow:hidden}.notification-banner-gif{width:48px;height:48px;object-fit:contain}[data-theme=light] .notification-banner-icon,:root .notification-banner-icon{background:#ffffff2e}[data-theme=dark] .notification-banner-icon{background:#f9630226;color:#ff8c42}.notification-banner-content{flex:1;min-width:0;text-align:center}.notification-banner-title{font-size:14px;font-weight:600;text-transform:uppercase;letter-spacing:1.4px;margin-bottom:8px}[data-theme=light] .notification-banner-title,:root .notification-banner-title{opacity:.8}[data-theme=dark] .notification-banner-title{color:#ff8c42}.notification-banner-message{font-size:20px;font-weight:500;line-height:1.55}[data-theme=light] .notification-banner-message,:root .notification-banner-message{color:#fff}[data-theme=dark] .notification-banner-message{color:#ffffffe0}.notification-banner-close{position:absolute;top:14px;right:14px;display:flex;align-items:center;justify-content:center;width:30px;height:30px;padding:0;border:none;border-radius:8px;background:transparent;color:#ffffff80;cursor:pointer;flex-shrink:0;transition:background .15s ease,color .15s ease}.notification-banner-close:hover{background:#ffffff1f;color:#fff}[data-theme=dark] .notification-banner-close{color:#ffffff59}[data-theme=dark] .notification-banner-close:hover{background:#ffffff14;color:#ffffffb3}.notification-banner:before{content:"";position:absolute;left:0;top:20px;bottom:20px;width:4px;border-radius:0 4px 4px 0;animation:accentPulse 2s ease-in-out infinite}[data-theme=light] .notification-banner:before,:root .notification-banner:before{background:#ffffff80}[data-theme=dark] .notification-banner:before{background:#f96302}@keyframes backdropFadeIn{0%{opacity:0}to{opacity:1}}@keyframes backdropFadeOut{0%{opacity:1}to{opacity:0}}@keyframes bannerFadeIn{0%{opacity:0;transform:translate(-50%) translateY(16px) scale(.96)}to{opacity:1;transform:translate(-50%) translateY(0) scale(1)}}@keyframes bannerFadeOut{0%{opacity:1;transform:translate(-50%) translateY(0) scale(1)}to{opacity:0;transform:translate(-50%) translateY(10px) scale(.97)}}@keyframes bellRing{0%{transform:rotate(0)}15%{transform:rotate(14deg)}30%{transform:rotate(-12deg)}45%{transform:rotate(8deg)}60%{transform:rotate(-5deg)}75%{transform:rotate(2deg)}to{transform:rotate(0)}}@keyframes accentPulse{0%,to{opacity:.4}50%{opacity:1}}@keyframes bannerGlow{0%,to{box-shadow:0 24px 72px #f9630266,0 4px 20px #0000001f}50%{box-shadow:0 24px 72px #f963028c,0 0 40px #f9630240,0 4px 20px #0000001f}}@keyframes bannerGlowDark{0%,to{box-shadow:0 24px 72px #0000008c,0 0 0 1px #f9630226,0 4px 20px #00000059;border-color:#f963024d}50%{box-shadow:0 24px 72px #0000008c,0 0 30px #f9630233,0 0 0 1px #f963024d,0 4px 20px #00000059;border-color:#f9630280}}:root,[data-theme=light]{--bg-primary: #f5f5f5;--bg-card: #ffffff;--bg-card-header: #f8f9fa;--bg-hover: #f8f9fa;--bg-input: #f0f0f0;--bg-dropdown: #f4f6f8;--bg-metrics: #f0f7ff;--bg-metrics-hover: #e3f2fd;--text-primary: #333333;--text-secondary: #666666;--text-muted: #999999;--text-link: #2196F3;--text-route: #2c3e50;--border-light: #f0f0f0;--border-medium: #e0e0e0;--shadow-sm: rgba(0, 0, 0, .1);--shadow-md: rgba(0, 0, 0, .15);--status-success-bg: #d4edda;--status-success-text: #155724;--status-danger-bg: #f8d7da;--status-danger-text: #721c24;--status-info-bg: #d1ecf1;--status-info-text: #0c5460;--status-warn-bg: #fff3cd;--status-warn-text: #856404;--spinner-track: #f3f3f3;--spinner-fill: #2196F3;--toggle-track-bg: #d1d5db;--toggle-thumb-bg: #ffffff;--live-color: #1a9c54}[data-theme=dark]{--bg-primary: #0f1117;--bg-card: #1a1d27;--bg-card-header: #22252f;--bg-hover: #262a36;--bg-input: #2a2e3a;--bg-dropdown: #1e2130;--bg-metrics: rgba(33, 150, 243, .1);--bg-metrics-hover: rgba(33, 150, 243, .18);--text-primary: #e1e4ea;--text-secondary: #9ca3af;--text-muted: #6b7280;--text-link: #60a5fa;--text-route: #c9cdd5;--border-light: #2a2e3a;--border-medium: #333844;--shadow-sm: rgba(0, 0, 0, .35);--shadow-md: rgba(0, 0, 0, .5);--status-success-bg: rgba(46, 204, 113, .15);--status-success-text: #6ee7a0;--status-danger-bg: rgba(231, 76, 60, .15);--status-danger-text: #fca5a5;--status-info-bg: rgba(74, 144, 226, .15);--status-info-text: #93c5fd;--status-warn-bg: rgba(241, 196, 15, .15);--status-warn-text: #fde68a;--spinner-track: #2a2e3a;--spinner-fill: #60a5fa;--live-color: #2ECC71;--toggle-track-bg: #374151;--toggle-thumb-bg: #e1e4ea}*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--bg-primary);color:var(--text-primary);padding:20px;transition:background-color .4s ease,color .4s ease}#root{max-width:1400px;margin:0 auto}
