:root{--bg: #0b0f14;--panel: #121821;--text: #e5eef5;--muted: #9bb1c9;--accent: #5ad6a0;--warn: #ffca5f;--danger: #f45b69}*{box-sizing:border-box}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}html,body,#root{height:100%}body{margin:0;font-family:Chakra Petch,Inter,ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,"Apple Color Emoji","Segoe UI Emoji";background:var(--bg);color:var(--text)}button{background:var(--panel);color:var(--text);border:1px solid #243044;padding:8px 12px;border-radius:8px;cursor:pointer}button:disabled{opacity:.6;cursor:not-allowed}a{color:var(--accent)}.app{display:grid;grid-template-rows:auto 1fr auto;grid-template-columns:1fr;height:100%}.fixed-logo{position:fixed;top:-55px;left:8px;z-index:1000;pointer-events:none}.fixed-logo .logo{height:72px;width:auto;border-radius:0;box-shadow:none;background:transparent;display:block}.header{padding:8px 16px;background:radial-gradient(ellipse at 20% 50%,rgba(90,214,160,.12) 0%,transparent 50%),radial-gradient(ellipse at 80% 30%,rgba(70,230,255,.08) 0%,transparent 50%),radial-gradient(ellipse at 40% 80%,rgba(138,120,255,.06) 0%,transparent 50%),linear-gradient(135deg,#0b0f14,#121821,#1a2332,#121821,#0b0f14);background-size:400% 400%,300% 300%,350% 350%,100% 100%;animation:futuristicShift 12s ease-in-out infinite;border-bottom:1px solid #213148;border-top:2px solid transparent;border-image:linear-gradient(90deg,transparent 0%,rgba(90,214,160,.3) 20%,rgba(70,230,255,.4) 50%,rgba(138,120,255,.3) 80%,transparent 100%) 1;display:flex;gap:12px;align-items:center;justify-content:space-between;min-height:64px;position:relative;overflow:hidden}.header:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent 0%,rgba(90,214,160,.1) 30%,rgba(70,230,255,.15) 50%,rgba(90,214,160,.1) 70%,transparent 100%);animation:scanLine 8s linear infinite;z-index:1}.header:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background-image:radial-gradient(circle at 25% 25%,rgba(90,214,160,.4) 1px,transparent 1px),radial-gradient(circle at 75% 75%,rgba(70,230,255,.3) 1px,transparent 1px),radial-gradient(circle at 50% 10%,rgba(138,120,255,.25) 1px,transparent 1px);background-size:80px 80px,120px 120px,60px 60px;background-position:0 0,40px 40px,20px 20px;animation:particleFloat 15s linear infinite;opacity:.6;z-index:0}@keyframes futuristicShift{0%,to{background-position:0% 50%,100% 30%,50% 80%,0% 0%}25%{background-position:100% 30%,0% 70%,80% 20%,0% 0%}50%{background-position:50% 80%,100% 50%,20% 60%,0% 0%}75%{background-position:20% 60%,50% 80%,100% 30%,0% 0%}}@keyframes scanLine{0%{left:-100%}to{left:100%}}@keyframes particleFloat{0%{background-position:0 0,40px 40px,20px 20px}to{background-position:80px 80px,120px 120px,80px 80px}}.header>*{position:relative;z-index:2}.header .brand{display:flex;align-items:center;justify-content:flex-end;gap:12px;margin-left:300px}.header .tagline{color:#e5eef5;font-size:14px;text-shadow:0 0 8px rgba(90,214,160,.3);font-weight:300}@media (min-width: 768px){.header{min-height:80px}.fixed-logo .logo{height:192px}.header .tagline{font-size:16px;text-shadow:0 0 12px rgba(90,214,160,.4)}}.header h1{font-size:18px;margin:0;font-family:Orbitron,ui-sans-serif;letter-spacing:.02em}.main{display:grid;grid-template-columns:1fr;gap:12px;padding:12px}@media (min-width: 768px){.main{display:flex;gap:12px;padding:12px}.sidebar{position:fixed;top:104px;left:12px;width:320px;max-height:calc(100vh - 180px);overflow-y:auto;z-index:10;box-shadow:0 8px 32px #0006,0 4px 16px #0000004d,0 0 24px #ff6ff326,0 0 48px #ff6ff314}.content{flex:1;margin-left:332px;min-width:0}}.sidebar{background:var(--panel);border:1px solid #213148;border-radius:12px;padding:12px}.content{background:var(--panel);border:1px solid #213148;border-radius:12px;padding:12px;margin-bottom:72px}.music-player{position:fixed;top:12px;right:16px;z-index:1000}.music-button{background:linear-gradient(135deg,#121821,#1a2332);border:1px solid #304761;border-radius:8px;color:var(--accent);padding:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;width:36px;height:36px;position:relative;overflow:hidden}.music-button:hover{background:linear-gradient(135deg,#1a2332,#243242);border-color:var(--accent);box-shadow:0 0 16px #5ad6a04d,0 4px 8px #0003;transform:translateY(-1px)}.music-button:active{transform:translateY(0);box-shadow:0 0 12px #5ad6a066,0 2px 4px #0000004d}.music-button svg{transition:all .3s ease}.music-button:hover svg{filter:drop-shadow(0 0 4px currentColor)}.music-player.pulse-hint .music-button{animation:musicPulse 2s ease-in-out infinite}@keyframes musicPulse{0%,to{box-shadow:0 0 16px #5ad6a04d,0 4px 8px #0003}50%{box-shadow:0 0 24px #5ad6a099,0 4px 12px #0000004d;transform:scale(1.05)}}@media (max-width: 767px){.fixed-logo{top:4px;left:4px}.fixed-logo .logo{height:48px}.header .brand{margin-left:60px}.music-player{top:8px;right:8px}.music-button{width:32px;height:32px;padding:6px}}.footer{padding:8px 12px;font-size:12px;color:var(--muted);border-top:1px solid #213148}.hud-grid{display:grid;grid-template-columns:1fr;gap:8px}@media (min-width: 480px){.hud-grid{grid-template-columns:repeat(2,1fr)}}.stat{background:#0e1520;border:1px solid #1e2a3d;border-radius:10px;padding:10px;transition:all .3s ease}.stat-loc{background:linear-gradient(135deg,#0e1520,#0f1722);border:1px solid #1a3b4d;box-shadow:inset 0 1px #46e6ff1a}.stat-loc:hover{border-color:#2a4b5d;box-shadow:inset 0 1px #46e6ff26,0 0 8px #46e6ff1a}.stat-revenue{background:linear-gradient(135deg,#0e1520,#0f1a15);border:1px solid #1e3d2a;box-shadow:inset 0 1px #5ad6a01a}.stat-revenue:hover{border-color:#2e4d3a;box-shadow:inset 0 1px #5ad6a026,0 0 8px #5ad6a01a}.stat-buffered{background:linear-gradient(135deg,#0e1520,#1a1812);border:1px solid #3d351e;box-shadow:inset 0 1px #ffca5f1a}.stat-buffered:hover{border-color:#4d452e;box-shadow:inset 0 1px #ffca5f26,0 0 8px #ffca5f14}.stat-agents{background:linear-gradient(135deg,#0e1520,#151220);border:1px solid #2a1e3d;box-shadow:inset 0 1px #8a78ff1a}.stat-agents:hover{border-color:#3a2e4d;box-shadow:inset 0 1px #8a78ff26,0 0 8px #8a78ff1a}.stat-debt{background:linear-gradient(135deg,#0e1520,#1a1215);border:1px solid #3d1e2a;box-shadow:inset 0 1px #f45b691a}.stat-debt:hover{border-color:#4d2e3a;box-shadow:inset 0 1px #f45b6926,0 0 8px #f45b6914}.stat .label{color:var(--muted);font-size:12px}.stat .value{font-size:20px;font-weight:600}.actions{display:flex;justify-content:center;align-items:center;gap:12px;margin-top:12px;flex-wrap:wrap;width:100%}.ribbon{display:flex;gap:8px;overflow:auto;padding:4px 0}.badge{background:#0e1520;border:1px solid #1e2a3d;border-radius:999px;padding:6px 10px;font-size:12px;white-space:nowrap}.badge.hit{background:#13301f;border-color:#224c30;color:#b6ffd2}.pill{display:inline-block;padding:2px 8px;border-radius:999px;border:1px solid rgba(255,255,255,.06);background:#ffffff08}.upgrade-indicator{background:linear-gradient(90deg,#5ad6a026,#5ad6a00d);border:1px solid rgba(90,214,160,.3);border-radius:8px;padding:8px 12px;margin-bottom:12px;margin-top:12px;display:flex;align-items:center;gap:8px;font-size:13px;animation:pulse-subtle 2s ease-in-out infinite}.upgrade-count{background:var(--accent);color:var(--bg);font-weight:700;font-size:12px;padding:2px 6px;border-radius:4px;min-width:20px;text-align:center}.upgrade-label{color:var(--accent);font-weight:500;flex:1}.deploy-button-container{position:relative;display:flex;align-items:center;gap:8px;justify-content:center;margin-bottom:8px}.cicd-status-light{width:8px;height:8px;border-radius:50%;background:#00ced1;box-shadow:0 0 4px #00ced1cc,0 0 8px #00ced166,inset 0 0 2px #ffffff4d;animation:cicd-pulse 2s ease-in-out infinite;position:relative}.cicd-status-light:before{content:"";position:absolute;top:-2px;left:-2px;right:-2px;bottom:-2px;border-radius:50%;background:radial-gradient(circle,rgba(0,206,209,.3) 0%,transparent 70%);animation:cicd-glow 2s ease-in-out infinite}.cicd-status-light.high-frequency{background:#48d1cc;box-shadow:0 0 6px #48d1cce6,0 0 12px #48d1cc99,inset 0 0 3px #fff6;animation:none}.cicd-status-light.high-frequency:before{background:radial-gradient(circle,rgba(72,209,204,.5) 0%,transparent 70%);animation:none}.cicd-status-light.flashing{animation:status-light-flash .4s ease-out}@keyframes cicd-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.1)}}@keyframes cicd-glow{0%,to{opacity:.6;transform:scale(1)}50%{opacity:1;transform:scale(1.2)}}@keyframes status-light-flash{0%{background:#00ced1;box-shadow:0 0 4px #00ced1cc,0 0 8px #00ced166,inset 0 0 2px #ffffff4d}50%{background:#fff;box-shadow:0 0 12px #fff,0 0 20px #00ced1cc,inset 0 0 4px #00ced199;transform:scale(1.3)}to{background:#00ced1;box-shadow:0 0 4px #00ced1cc,0 0 8px #00ced166,inset 0 0 2px #ffffff4d}}.tron-button{position:relative;background:linear-gradient(135deg,#0a1118,#1a2332,#0f1419);color:var(--accent);border:2px solid transparent;padding:12px 20px;border-radius:8px;cursor:pointer;font-weight:600;font-size:14px;text-transform:uppercase;letter-spacing:.5px;transition:all .3s ease;overflow:hidden;box-shadow:0 0 10px #5ad6a01a,inset 0 1px #5ad6a033,inset 0 -1px #5ad6a01a}.tron-button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(90,214,160,.3),transparent);transition:left .5s ease}.tron-button:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border:2px solid var(--accent);border-radius:8px;opacity:0;transition:opacity .3s ease}.tron-button:hover{background:linear-gradient(135deg,#0f1621,#253447,#141b22);color:#fff;box-shadow:0 0 25px #5ad6a066,0 0 50px #5ad6a033,inset 0 1px #5ad6a066,inset 0 -1px #5ad6a033;transform:translateY(-1px)}.tron-button:hover:before{left:100%}.tron-button:hover:after{opacity:1}.tron-button:active{transform:translateY(0);box-shadow:0 0 15px #5ad6a099,0 0 30px #5ad6a04d,inset 0 1px #5ad6a099,inset 0 -1px #5ad6a04d}.tron-button:disabled{background:linear-gradient(135deg,#0a0e12,#151a20,#0d1014);color:var(--muted);opacity:.5;cursor:not-allowed;box-shadow:0 0 5px #9bb1c91a,inset 0 1px #9bb1c91a,inset 0 -1px #9bb1c90d;transform:none}.tron-button:disabled:before,.tron-button:disabled:after{display:none}.tron-button.write-code{background:linear-gradient(135deg,#0a1811,#1a3225,#0f1916);color:#5ad6a0;animation:pulse-subtle 2s ease-in-out infinite}.tron-button.write-code:hover{background:linear-gradient(135deg,#0f2118,#254739,#142220);color:#fff;animation:none}.tron-button.ship-build{background:linear-gradient(135deg,#181108,#322a1a,#19140f);color:#ffca5f}.tron-button.ship-build:hover{background:linear-gradient(135deg,#21180f,#473925,#221914);color:#fff;box-shadow:0 0 25px #ffca5f66,0 0 50px #ffca5f33,inset 0 1px #ffca5f66,inset 0 -1px #ffca5f33}.tron-button.ship-build:after{border-color:#ffca5f}@keyframes pulse-subtle{0%,to{box-shadow:0 0 10px #5ad6a01a,inset 0 1px #5ad6a033,inset 0 -1px #5ad6a01a}50%{box-shadow:0 0 20px #5ad6a033,inset 0 1px #5ad6a04d,inset 0 -1px #5ad6a033}}.tron-button.write-code{font-family:Orbitron,Chakra Petch,Inter,ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial;font-weight:700;letter-spacing:.08em;text-transform:uppercase;font-size:18px;padding:16px 28px;min-width:260px;border-radius:14px;color:#a6ffd8;background:radial-gradient(120% 120% at 50% 0%,#5ad6a033,#5ad6a00d 42%,#0a181100 46%),linear-gradient(135deg,#0b1d13,#174936,#0f1f1a);box-shadow:0 0 14px #5ad6a073,0 0 34px #5ad6a040,inset 0 0 12px #5ad6a02e,inset 0 2px #ffffff14;text-shadow:0 0 8px rgba(90,214,160,.6),0 0 16px rgba(90,214,160,.3);animation:writecode-glow 2.6s ease-in-out infinite;will-change:transform,box-shadow,color}.tron-button.write-code:after{border-color:#86f7c9;opacity:1;box-shadow:0 0 24px #86f7c98c,0 0 64px #86f7c940}.tron-button.write-code:before{background:linear-gradient(90deg,transparent,rgba(166,255,216,.6),#ffffff,rgba(166,255,216,.6),transparent)}.tron-button.write-code:hover{background:radial-gradient(120% 120% at 50% 0%,#5ad6a040,#5ad6a014 40%,#0a181100 45%),linear-gradient(135deg,#0f291c,#1e5f45,#14332c);color:#fff;transform:translateY(-2px) scale(1.02);box-shadow:0 0 24px #5ad6a0bf,0 0 80px #5ad6a059,inset 0 0 14px #5ad6a038,inset 0 2px #ffffff1f;text-shadow:0 0 10px rgba(175,255,223,.85),0 0 24px rgba(90,214,160,.45)}.tron-button.write-code:active{transform:translateY(0) scale(.99)}@keyframes writecode-glow{0%,to{box-shadow:0 0 14px #5ad6a073,0 0 34px #5ad6a040,inset 0 0 12px #5ad6a02e,inset 0 2px #ffffff14}50%{box-shadow:0 0 22px #5ad6a0bf,0 0 48px #5ad6a059,inset 0 0 16px #5ad6a03d,inset 0 2px #ffffff1f}}@media (min-width: 768px){.actions .tron-button.write-code{font-size:22px;padding:20px 40px;min-width:360px;letter-spacing:.12em}}@media (prefers-reduced-motion: reduce){.tron-button.write-code{animation:none}}.milestone-progress{background:linear-gradient(135deg,#0a1118,#1a2332,#0f1419);border:2px solid transparent;border-radius:16px;padding:16px 20px;margin-bottom:16px;position:relative;overflow:hidden;box-shadow:0 0 20px #5ad6a026,inset 0 1px #5ad6a033,inset 0 -1px #5ad6a01a}.milestone-progress:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border:2px solid var(--accent);border-radius:16px;opacity:.3;background:radial-gradient(circle at 70% 30%,rgba(90,214,160,.1),transparent 50%)}.milestone-progress.completed{background:linear-gradient(135deg,#1a1108,#332a1a,#19140f);border-color:#ffca5f66;box-shadow:0 0 25px #ffca5f4d,inset 0 1px #ffca5f33}.milestone-progress.completed:before{border-color:var(--warn)}.milestone-header{margin-bottom:12px}.milestone-status{display:flex;align-items:center;gap:8px;font-family:Orbitron,ui-sans-serif;font-size:14px;letter-spacing:.02em}.current-milestone{color:var(--accent);font-weight:600}.next-arrow{color:var(--muted);font-size:12px}.next-milestone{color:var(--text);font-weight:700;text-transform:uppercase}.starting{color:var(--muted);font-style:italic}.milestone-crown{font-size:24px;margin-bottom:8px}.milestone-title{font-family:Orbitron,ui-sans-serif;font-weight:700;font-size:16px;color:var(--warn);letter-spacing:.05em;text-align:center;margin-bottom:4px}.milestone-subtitle{color:var(--muted);text-align:center;font-size:12px;margin-bottom:8px}.milestone-revenue{font-family:Orbitron,ui-sans-serif;font-size:20px;font-weight:600;color:var(--text);text-align:center}.milestone-progress-bar{margin:12px 0}.progress-track{position:relative;height:8px;background:#0006;border-radius:4px;overflow:hidden;border:1px solid rgba(255,255,255,.1)}.progress-fill{height:100%;background:linear-gradient(90deg,var(--accent),#7ee8b8);border-radius:4px;transition:width .5s ease;box-shadow:0 0 8px #5ad6a066}.progress-glow{position:absolute;top:-2px;width:12px;height:12px;background:radial-gradient(circle,rgba(90,214,160,.8),transparent);border-radius:50%;transform:translate(-50%);transition:left .5s ease;filter:blur(1px)}.progress-labels{display:flex;justify-content:space-between;margin-top:6px;font-size:11px;color:var(--muted);font-family:Orbitron,ui-sans-serif}.milestone-details{display:flex;justify-content:space-between;align-items:center;margin-top:8px}.progress-percent{font-family:Orbitron,ui-sans-serif;font-weight:700;font-size:16px;color:var(--accent)}.remaining-amount{font-size:12px;color:var(--muted);text-align:right}.milestone-background{position:relative;overflow:hidden;border-radius:8px;transition:all .4s cubic-bezier(.4,0,.2,1);border:1px solid transparent;background-clip:padding-box}.milestone-background:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:var(--milestone-gradient);border-radius:inherit;z-index:-1;transition:background .8s ease-in-out}.milestone-background{box-shadow:var(--milestone-border-glow),inset 0 1px #ffffff1a;transition:box-shadow .4s ease-in-out}.milestone-bg-gradient{position:absolute;top:0;left:0;right:0;bottom:0;background:var(--milestone-gradient);opacity:.9;z-index:-1;transition:opacity .6s ease}.milestone-particles{position:absolute;top:0;left:0;right:0;bottom:0;pointer-events:none;z-index:1}.milestone-particle{position:absolute;width:var(--particle-size);height:var(--particle-size);background:var(--particle-color);border-radius:50%;opacity:0;animation:particleFloat 8s linear infinite;animation-delay:var(--animation-delay);box-shadow:0 0 4px var(--particle-color)}@keyframes particleFloat{0%{opacity:0;transform:translateY(20px) scale(.8)}10%{opacity:1;transform:translateY(15px) scale(1)}90%{opacity:1;transform:translateY(-15px) scale(1)}to{opacity:0;transform:translateY(-20px) scale(.8)}}.milestone-progress-shimmer{position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(45deg,transparent 30%,rgba(255,255,255,.1) 50%,transparent 70%);animation:shimmer 2s ease-in-out infinite;z-index:2;pointer-events:none}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.achievement-flash{position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle at center,rgba(255,255,255,.8) 0%,rgba(255,255,255,.4) 30%,transparent 70%);animation:achievementFlash 3s ease-out;z-index:3;pointer-events:none}@keyframes achievementFlash{0%{opacity:0;transform:scale(.8)}10%{opacity:1;transform:scale(1.1)}30%{opacity:.6;transform:scale(1)}to{opacity:0;transform:scale(1)}}.achievement-ripple{position:absolute;top:50%;left:50%;width:20px;height:20px;border:2px solid var(--milestone-glow);border-radius:50%;transform:translate(-50%,-50%);animation:achievementRipple 3s ease-out;z-index:3;pointer-events:none}@keyframes achievementRipple{0%{width:20px;height:20px;opacity:1}to{width:300px;height:300px;opacity:0}}.achievement-burst{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:3;pointer-events:none}.burst-particle{position:absolute;width:4px;height:12px;background:var(--burst-color);border-radius:2px;transform-origin:0 6px;transform:rotate(var(--burst-angle)) translate(20px);animation:burstParticle 3s ease-out;box-shadow:0 0 6px var(--burst-color)}@keyframes burstParticle{0%{opacity:1;transform:rotate(var(--burst-angle)) translate(20px) scale(1)}to{opacity:0;transform:rotate(var(--burst-angle)) translate(80px) scale(.3)}}.milestone-content{position:relative;z-index:4;padding:16px;-webkit-backdrop-filter:blur(1px);backdrop-filter:blur(1px);transition:color .4s ease,text-shadow .4s ease}.milestone-background.transitioning{animation:milestoneTransition .8s ease-in-out}@keyframes milestoneTransition{0%,to{transform:scale(1)}50%{transform:scale(1.02)}}.milestone-background.transitioning .milestone-particles .milestone-particle{animation-duration:4s;animation-timing-function:ease-out}.milestone-background.transitioning .milestone-bg-gradient{animation:gradientPulse .8s ease-in-out}@keyframes gradientPulse{0%,to{opacity:.9}50%{opacity:1;filter:brightness(1.1)}}.milestone-background.achieving{animation:achievementGlow 3s ease-out}@keyframes achievementGlow{0%{filter:brightness(1)}20%{filter:brightness(1.3) saturate(1.2)}to{filter:brightness(1)}}.milestone-background.achieving .milestone-particles .milestone-particle{animation:achievementParticles 3s ease-out}@keyframes achievementParticles{0%{opacity:0;transform:translateY(0) scale(.5)}20%{opacity:1;transform:translateY(-5px) scale(1.2)}to{opacity:0;transform:translateY(-30px) scale(.8)}}@media (max-width: 768px){.milestone-particle{animation-duration:6s}.achievement-ripple{animation-duration:2.5s}.milestone-progress-shimmer{animation-duration:1.5s}.milestone-content{padding:12px}}@media (prefers-reduced-motion: reduce){.milestone-particle,.achievement-flash,.achievement-ripple,.burst-particle,.milestone-progress-shimmer{animation:none}.milestone-background{transition:none}.milestone-bg-gradient{transition:opacity .2s ease}}@media (prefers-contrast: high){.milestone-content{background:#000c;border-radius:4px}.milestone-particle{box-shadow:0 0 2px currentColor}}.techtree{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(180px,1fr);gap:20px;overflow:auto}.branch{min-width:180px}.branch h3{margin:0 0 8px;font-size:14px;color:var(--muted);font-family:Orbitron,ui-sans-serif;letter-spacing:.02em}.node{background:#0e1520;border:1px solid #1e2a3d;border-radius:10px;padding:12px;margin-bottom:28px}.node .title{font-weight:600}.node .cost{color:var(--muted);font-size:12px}.node .req{color:var(--muted);font-size:11px}.node .purchased{color:var(--accent);font-size:12px}.node .effects{margin-top:6px}.node .effect{font-size:12px;color:var(--muted)}.node .effect.loc{color:#9ed0ff}.node .effect.ship{color:#ffd48a}.node .effect.revenue{color:#9df1c7}.node .effect.global{color:#d0b3ff}.dependency-line{transition:stroke-opacity .3s ease,stroke-width .3s ease;filter:drop-shadow(0 0 2px rgba(90,214,160,.3))}.dependency-line:hover{stroke-opacity:.8!important;stroke-width:3;filter:drop-shadow(0 0 4px rgba(90,214,160,.6))}.techtree .node[data-node-id]{transition:all .3s ease}.techtree .node[data-node-id]:hover{transform:translateY(-2px);box-shadow:0 4px 20px #5ad6a033,0 0 0 2px #5ad6a01a}.node-background-icon{position:absolute;top:50%;right:8px;transform:translateY(-50%);opacity:.35;z-index:1;pointer-events:none;color:var(--branch-accent);filter:drop-shadow(0 0 8px var(--branch-accent))}.status-icon-container{position:absolute;top:6px;right:6px;z-index:4;display:flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:1px solid rgba(255,255,255,.15)}.status-icon{transition:all .3s ease;display:block;margin:0;padding:0;vertical-align:middle;flex-shrink:0}.purchased-icon{color:#5ad6a0;filter:drop-shadow(0 0 6px rgba(90,214,160,.4))}.unlocked-icon{color:#00eaff;filter:drop-shadow(0 0 6px rgba(0,234,255,.4))}.locked-icon{color:#9bb1c9;opacity:.7;filter:drop-shadow(0 0 4px rgba(155,177,201,.2))}.node-compact-header{position:relative;z-index:2;margin-bottom:4px}.node-id-compact{font-size:12px;font-weight:700;color:var(--branch-accent);opacity:.8;letter-spacing:.5px;margin-bottom:2px}.node-name-compact{font-size:16px;font-weight:600;color:var(--text);line-height:1.2;margin-bottom:6px}.node-effects-compact{position:relative;z-index:2;margin-bottom:8px}.node-effects-compact .effect{font-size:11px;line-height:1.3;margin-bottom:1px;color:var(--muted)}.node-action-compact{position:relative;z-index:2}.node-requirements-compact{font-size:10px;color:var(--muted);opacity:.7;margin-bottom:6px;position:relative;z-index:2}.node.is-purchased .status-icon-container{background:#5ad6a040;border-color:#5ad6a099;box-shadow:0 0 8px #5ad6a066}.node.is-unlocked .status-icon-container{background:#00eaff40;border-color:#00eaff99;box-shadow:0 0 8px #00eaff66}.node.is-locked .status-icon-container{background:#9bb1c926;border-color:#9bb1c94d}.node .tron-button{font-size:12px;padding:4px 8px;min-height:24px;border-radius:6px;width:100%;background:linear-gradient(135deg,#0006,#0003);border:1px solid var(--branch-accent);color:var(--branch-accent);box-shadow:0 0 6px #0000004d;transition:all .3s ease}.node .tron-button:hover:not(:disabled){background:linear-gradient(135deg,var(--branch-accent),rgba(255,255,255,.1));color:var(--bg);box-shadow:0 0 12px var(--branch-accent);transform:translateY(-1px)}.node .tron-button:disabled{opacity:.5;cursor:not-allowed}.purchased-indicator{display:flex;align-items:center;justify-content:center;font-size:12px;padding:4px;background:#5ad6a01a;border:1px solid rgba(90,214,160,.3);border-radius:6px;color:var(--accent);min-height:24px}.unaffordable-price{font-size:10px;color:var(--danger);text-align:center;padding:4px;background:#f45b691a;border:1px solid rgba(244,91,105,.3);border-radius:6px;min-height:24px;display:flex;align-items:center;justify-content:center}.branch{--branch-accent: #5ad6a0;--branch-glow: rgba(90, 214, 160, .22);--branch-bg1: #0d1420;--branch-bg2: #0b121a}.branch-A{--branch-accent: #46e6ff;--branch-glow: rgba(70, 230, 255, .25);--branch-bg1: #061622;--branch-bg2: #0b2433}.branch-B{--branch-accent: #5aa6ff;--branch-glow: rgba(90, 166, 255, .22);--branch-bg1: #0a1424;--branch-bg2: #0b1b34}.branch-C{--branch-accent: #4ae58f;--branch-glow: rgba(74, 229, 143, .25);--branch-bg1: #081a16;--branch-bg2: #0d281e}.branch-D{--branch-accent: #4fd3c6;--branch-glow: rgba(79, 211, 198, .25);--branch-bg1: #0a171a;--branch-bg2: #0e2326}.branch-E{--branch-accent: #b388ff;--branch-glow: rgba(179, 136, 255, .25);--branch-bg1: #130f1a;--branch-bg2: #1a1530}.branch-F{--branch-accent: #ff7ad9;--branch-glow: rgba(255, 122, 217, .28);--branch-bg1: #1a0f16;--branch-bg2: #2a1830}.branch-G{--branch-accent: #ffb15c;--branch-glow: rgba(255, 177, 92, .28);--branch-bg1: #1a140b;--branch-bg2: #2a1d10}.branch-H{--branch-accent: #ff6e9a;--branch-glow: rgba(255, 110, 154, .28);--branch-bg1: #1a0e14;--branch-bg2: #2a1620}.branch-I{--branch-accent: #00ced1;--branch-glow: rgba(0, 206, 209, .3);--branch-bg1: #0b1a1a;--branch-bg2: #112a2a}.branch .node{background:linear-gradient(135deg,var(--branch-bg1),var(--branch-bg2));border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:8px;margin-bottom:14px;position:relative;overflow:hidden;box-shadow:0 0 0 1px #ffffff08,0 2px 8px var(--branch-glow),inset 0 1px #ffffff1a;min-height:120px;transition:all .3s ease}.branch .node:before{content:"";position:absolute;top:-1px;right:-1px;bottom:-1px;left:-1px;border-radius:14px;pointer-events:none;box-shadow:0 0 0 1px var(--branch-accent) inset;opacity:.18}.branch .node.is-unlocked{box-shadow:0 0 0 1px #ffffff0d,0 0 16px var(--branch-glow),0 0 28px color-mix(in srgb,var(--branch-accent) 25%,transparent)}.branch .node.is-unlocked .icon-wrap{transform:scale(1.02);box-shadow:0 0 0 1px var(--branch-accent),0 0 28px var(--branch-glow) inset,0 0 24px color-mix(in srgb,var(--branch-accent) 25%,transparent)}.branch .node.is-locked{opacity:.6;filter:grayscale(.2) saturate(.8)}.branch .node.is-locked .icon-wrap{opacity:.6;filter:grayscale(.5)}.branch .node.is-purchased{border-color:#5ad6a099;box-shadow:0 0 0 1px #5ad6a04d,0 0 20px #5ad6a040 inset}.node-hero{display:grid;grid-template-columns:64px 1fr;gap:10px;align-items:center;padding:6px;border-radius:10px;background:radial-gradient(120px 60px at 20% 40%,rgba(255,255,255,.06),transparent 60%)}.icon-wrap{display:grid;place-items:center;width:64px;height:64px;border-radius:12px;color:#bfe9ff;background:radial-gradient(70% 70% at 50% 40%,rgba(255,255,255,.06),transparent),linear-gradient(180deg,rgba(255,255,255,.03),transparent);outline:1px solid rgba(255,255,255,.06);box-shadow:0 0 0 1px var(--branch-accent),0 0 24px var(--branch-glow) inset}.node-head{display:grid;gap:2px;min-height:3.5em}.node-id{font-family:Orbitron,ui-sans-serif;font-size:12px;letter-spacing:.08em;color:var(--muted);min-height:1.2em;line-height:1.2}.node-name{font-family:Orbitron,ui-sans-serif;font-weight:700;letter-spacing:.02em;font-size:14px;min-height:2em;line-height:1.4;display:flex;align-items:flex-start}.branch .node .cost{color:var(--muted);font-size:12px;margin-top:6px}.branch .node .req{color:var(--muted);font-size:11px;margin-top:6px}.branch .node .purchased{color:var(--accent);font-size:12px;margin-top:6px}.branch .node button{margin-top:8px;width:100%;font-family:Orbitron,ui-sans-serif;letter-spacing:.04em;background:linear-gradient(180deg,rgba(255,255,255,.06),transparent);border:1px solid var(--branch-accent);color:var(--text);box-shadow:0 0 12px var(--branch-glow),inset 0 0 18px #ffffff0a}.branch .node button:hover:not(:disabled){box-shadow:0 0 16px var(--branch-glow),inset 0 0 24px #ffffff12;filter:saturate(1.05)}.purchased-indicator{margin-top:8px;padding:8px 12px;border-radius:8px;background:linear-gradient(180deg,#5ad6a01a,#5ad6a00d);border:1px solid rgba(90,214,160,.3);text-align:center;font-family:Orbitron,ui-sans-serif;letter-spacing:.04em;box-shadow:0 0 12px #5ad6a033}.unaffordable-price{margin-top:8px;padding:8px 12px;border-radius:8px;background:linear-gradient(180deg,#8b000026,#8b000014);border:1px solid rgba(139,0,0,.4);text-align:center;font-family:Orbitron,ui-sans-serif;font-weight:700;font-size:16px;letter-spacing:.04em;color:#8b0000;text-shadow:0 0 8px rgba(139,0,0,.3);box-shadow:0 0 8px #8b000026}.effects{min-height:1.5em}.effect{line-height:1.3;min-height:1.3em}@media (max-width: 767px){.techtree{display:block;overflow-y:auto;overflow-x:hidden}.branch{width:100%;min-width:unset;margin-bottom:32px}.branch h3{position:sticky;top:0;background:var(--panel);padding:8px 0;margin:0 0 12px;font-size:16px;border-bottom:2px solid var(--branch-accent);z-index:10}.branch .node{margin-bottom:32px;padding:16px;min-height:120px}.node-hero{grid-template-columns:80px 1fr;gap:12px;padding:8px}.icon-wrap{width:80px;height:80px;border-radius:16px}.node-name{font-size:16px;min-height:2.5em}.node-id{font-size:13px}.branch .node button{margin-top:12px;padding:14px 20px;font-size:16px;border-radius:10px;min-height:48px}.branch .node .cost,.branch .node .req,.branch .node .purchased{font-size:13px;margin-top:8px}.status-icon-container{width:32px;height:32px;top:12px;right:12px}}.tech-tree-canvas{position:relative;width:100%;height:100%;min-height:500px;background:radial-gradient(ellipse at center,#0d1420,#080e18);overflow:hidden;cursor:grab}.tech-tree-canvas:active{cursor:grabbing}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--muted)}.loading-spinner{width:32px;height:32px;border:3px solid rgba(90,214,160,.3);border-top:3px solid var(--accent);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:12px}.loading-text{font-family:Orbitron,ui-sans-serif;font-size:14px;letter-spacing:.05em}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.tech-tree-content{will-change:transform;transition:none}.nodes-container{position:relative;width:100%;height:100%}.tech-node{position:absolute;background:linear-gradient(180deg,var(--branch-bg1, #0e1520),var(--branch-bg2, #0b121a));border:1px solid rgba(255,255,255,.05);border-radius:12px;padding:10px;transition:all .3s ease;will-change:transform,opacity;-webkit-user-select:none;user-select:none;box-shadow:0 0 0 1px #ffffff08,0 2px 12px var(--branch-glow, rgba(90, 214, 160, .15))}.tech-node:before{content:"";position:absolute;top:-1px;right:-1px;bottom:-1px;left:-1px;border-radius:12px;pointer-events:none;box-shadow:0 0 0 1px var(--branch-accent, #5ad6a0) inset;opacity:.18}.tech-node.is-unlocked{box-shadow:0 0 0 1px #ffffff0d,0 4px 16px var(--branch-glow, rgba(90, 214, 160, .25)),0 0 28px color-mix(in srgb,var(--branch-accent, #5ad6a0) 25%,transparent)}.tech-node.is-unlocked:hover{transform:translateY(-2px) scale(1.02);box-shadow:0 0 0 2px var(--branch-accent, #5ad6a0),0 6px 20px var(--branch-glow, rgba(90, 214, 160, .35)),0 0 32px color-mix(in srgb,var(--branch-accent, #5ad6a0) 35%,transparent)}.tech-node.is-locked{opacity:.6;filter:grayscale(.3) saturate(.7)}.tech-node.is-purchased{border-color:#5ad6a099;box-shadow:0 0 0 1px #5ad6a066,0 0 20px #5ad6a04d inset,0 4px 16px #5ad6a033}.tech-node .node-hero{display:flex;flex-direction:column;align-items:center;gap:6px;text-align:center}.tech-node .icon-wrap{display:grid;place-items:center;border-radius:8px;color:#bfe9ff;background:radial-gradient(70% 70% at 50% 40%,rgba(255,255,255,.06),transparent);outline:1px solid rgba(255,255,255,.06);box-shadow:0 0 0 1px var(--branch-accent, #5ad6a0),0 0 12px var(--branch-glow, rgba(90, 214, 160, .2)) inset;transition:all .3s ease}.tech-node.is-unlocked .icon-wrap{transform:scale(1.02);box-shadow:0 0 0 1px var(--branch-accent, #5ad6a0),0 0 16px var(--branch-glow, rgba(90, 214, 160, .3)) inset}.tech-node.is-locked .icon-wrap{opacity:.6;filter:grayscale(.5)}.node-info{display:flex;flex-direction:column;gap:2px;min-height:2.5em}.node-id{font-family:Orbitron,ui-sans-serif;font-size:10px;letter-spacing:.08em;color:var(--muted);line-height:1.2}.node-name{font-family:Orbitron,ui-sans-serif;font-weight:700;letter-spacing:.02em;font-size:12px;line-height:1.3;color:var(--text)}.effects,.requirements{margin-top:6px;font-size:10px;line-height:1.3;max-height:60px;overflow:hidden}.effect{color:var(--muted);margin-bottom:1px}.effect.loc{color:#9ed0ff}.effect.ship{color:#ffd48a}.effect.revenue{color:#9df1c7}.effect.global{color:#d0b3ff}.effect-more,.req-more{color:var(--muted);opacity:.7;font-style:italic}.requirements{border-top:1px solid rgba(255,255,255,.1);padding-top:4px}.req-label{color:var(--muted);font-weight:600;margin-bottom:2px}.req-item{color:var(--warn);font-family:Orbitron,ui-sans-serif;letter-spacing:.05em}.node-action{margin-top:8px}.purchase-btn{width:100%;font-family:Orbitron,ui-sans-serif;letter-spacing:.04em;background:linear-gradient(180deg,rgba(255,255,255,.06),transparent);border:1px solid var(--branch-accent, #5ad6a0);color:var(--text);box-shadow:0 0 8px var(--branch-glow, rgba(90, 214, 160, .2)),inset 0 0 12px #ffffff0a;transition:all .3s ease}.purchase-btn:hover:not(:disabled){box-shadow:0 0 12px var(--branch-glow, rgba(90, 214, 160, .3)),inset 0 0 16px #ffffff12;filter:saturate(1.05);transform:translateY(-1px)}.purchase-btn:active:not(:disabled){transform:translateY(0)}.status-icon-container{position:absolute;top:6px;right:6px;width:20px;height:20px;border-radius:50%;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;z-index:5}.canvas-controls{position:absolute;top:12px;right:12px;display:flex;flex-direction:column;gap:8px;z-index:10}.zoom-controls{display:flex;flex-direction:column;background:#121821f2;border-radius:8px;border:1px solid rgba(255,255,255,.1);overflow:hidden}.zoom-btn{width:36px;height:36px;background:transparent;border:none;color:var(--text);font-size:18px;font-weight:700;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.zoom-btn:hover{background:#5ad6a01a;color:var(--accent)}.zoom-btn:not(:last-child){border-bottom:1px solid rgba(255,255,255,.1)}.fit-view-btn{padding:8px 12px;font-size:12px;white-space:nowrap;min-width:auto}.layout-status{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#121821f2;border-radius:8px;border:1px solid rgba(255,255,255,.1);font-size:11px;color:var(--muted)}.layout-calculating{display:flex;align-items:center;gap:6px}.status-spinner{width:12px;height:12px;border:2px solid rgba(90,214,160,.3);border-top:2px solid var(--accent);border-radius:50%;animation:spin 1s linear infinite}.gesture-hint{position:absolute;top:0;left:0;right:0;bottom:0;background:#000c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:100;animation:fadeIn .3s ease}.hint-content{background:var(--panel);border-radius:12px;padding:20px;max-width:280px;border:1px solid rgba(90,214,160,.3);box-shadow:0 8px 32px #00000080}.hint-title{font-family:Orbitron,ui-sans-serif;font-weight:700;font-size:16px;color:var(--accent);text-align:center;margin-bottom:16px}.hint-actions{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}.hint-action{display:flex;align-items:center;gap:12px;color:var(--text);font-size:14px}.hint-icon{font-size:20px;width:24px;text-align:center}.hint-dismiss{width:100%;padding:10px;background:var(--accent);color:var(--bg);border:none;border-radius:6px;font-family:Orbitron,ui-sans-serif;font-weight:600;font-size:14px;cursor:pointer;transition:all .2s ease}.hint-dismiss:hover{background:color-mix(in srgb,var(--accent) 90%,white);transform:translateY(-1px)}@keyframes fadeIn{0%{opacity:0;-webkit-backdrop-filter:blur(0px);backdrop-filter:blur(0px)}to{opacity:1;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}}.tech-tree-canvas.panning{cursor:grabbing}.tech-tree-canvas.panning .tech-node{pointer-events:none}.mini-map{position:absolute;bottom:12px;left:12px;width:150px;height:100px;background:#121821f2;border-radius:8px;border:1px solid rgba(255,255,255,.1);z-index:10;pointer-events:none;opacity:0}@keyframes energyFlow{0%{stroke-dashoffset:var(--path-length, 100);opacity:.8}50%{opacity:1}to{stroke-dashoffset:0;opacity:.8}}.connection-line{transition:stroke-width .3s ease,opacity .3s ease}.connection-line:hover{stroke-width:3;opacity:1}.connection-group:hover .connection-glow{opacity:.6;stroke-width:8}@media (max-width: 768px){.tech-tree-canvas{min-height:400px}.canvas-controls{top:8px;right:8px;scale:.9}.zoom-btn{width:32px;height:32px;font-size:16px}.fit-view-btn{padding:6px 10px;font-size:11px}.tech-node{min-height:100px;padding:12px}.purchase-btn{min-height:36px;font-size:12px}.requirements{display:none}.effects{max-height:40px;font-size:9px}}@media (max-width: 480px){.canvas-controls{scale:.8;gap:6px}.tech-node{min-height:80px;padding:8px}.node-id,.node-name{font-size:10px}.effects{display:none}}@media (-webkit-min-device-pixel-ratio: 2),(min-resolution: 192dpi){.dependency-renderer{image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges}}.agent-dashboard{background:radial-gradient(ellipse at 30% 20%,rgba(0,206,209,.08) 0%,transparent 50%),linear-gradient(135deg,#0a1118,#0e1822,#0a1319);border:1px solid rgba(0,206,209,.3);border-radius:12px;padding:16px 12px 12px;margin-bottom:16px;position:relative;overflow:hidden;box-shadow:0 4px 20px #00ced126,0 2px 8px #0006,inset 0 1px #00ced11a}.agent-dashboard:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background-image:linear-gradient(90deg,transparent 0%,rgba(0,206,209,.03) 50%,transparent 100%),repeating-linear-gradient(45deg,transparent,transparent 20px,rgba(0,206,209,.02) 20px,rgba(0,206,209,.02) 22px);pointer-events:none;z-index:0}.agent-digital-display{position:relative;z-index:2;text-align:center;margin-bottom:16px}.agent-count-large{font-family:Courier New,monospace;font-size:24px;font-weight:700;color:#00ced1;text-shadow:0 0 8px rgba(0,206,209,.8),0 0 16px rgba(0,206,209,.4);line-height:1;margin-bottom:4px}.count-number{font-size:28px;letter-spacing:1px}.count-max{opacity:.7;font-size:20px}.agent-label{font-size:10px;font-weight:600;color:#00ced1cc;letter-spacing:1px;display:flex;align-items:center;justify-content:center;gap:4px}.agent-swarm-container{position:relative;height:70px;margin-bottom:16px;background:#0006;border-radius:8px;border:1px solid rgba(0,206,209,.2);overflow:hidden;z-index:2}.agent-swarm-grid{position:absolute;top:0;left:0;right:0;bottom:0;background-image:linear-gradient(rgba(0,206,209,.1) 1px,transparent 1px),linear-gradient(90deg,rgba(0,206,209,.1) 1px,transparent 1px);background-size:20px 20px;opacity:.3;z-index:1}.agent-swarm{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center;z-index:2}.agent-particle{position:absolute;width:var(--size);height:var(--size);background:#00ced1;border-radius:50%;box-shadow:0 0 6px rgba(0,206,209,var(--brightness)),0 0 12px rgba(0,206,209,calc(var(--brightness) * .5));animation:orbit calc(8s / var(--speed)) linear infinite;will-change:transform;contain:layout style}@keyframes orbit{0%{transform:rotate(var(--offset)) translate(var(--radius)) rotate(calc(-1 * var(--offset)))}to{transform:rotate(calc(var(--offset) + 360deg)) translate(var(--radius)) rotate(calc(-1 * (var(--offset) + 360deg)))}}.agent-swarm-center{position:relative;width:32px;height:32px;background:radial-gradient(circle,rgba(0,206,209,.2),transparent);border-radius:50%;border:2px solid rgba(0,206,209,.4);display:flex;align-items:center;justify-content:center;color:#00ced1;z-index:3}.agent-scan-line{position:absolute;top:0;left:0;width:2px;height:100%;background:linear-gradient(to bottom,transparent 0%,rgba(0,206,209,.8) 50%,transparent 100%);animation:scan 4s linear infinite;z-index:4}@keyframes scan{0%{left:0}to{left:calc(100% - 2px)}}.agent-stats-compact{position:relative;z-index:2;display:flex;align-items:center;justify-content:space-between;background:#0006;border:1px solid rgba(0,206,209,.2);border-radius:6px;padding:8px 12px}.agent-stat-item{display:flex;flex-direction:column;align-items:center;gap:2px}.agent-stat-item .stat-value{font-family:Courier New,monospace;font-size:14px;font-weight:700;color:#00ced1;text-shadow:0 0 4px rgba(0,206,209,.6)}.agent-stat-item .stat-label{font-size:9px;font-weight:600;color:#00ced1b3;letter-spacing:.5px}.agent-stat-divider{width:1px;height:24px;background:#00ced14d}.agent-dashboard,.agent-swarm-container{contain:layout style}@media (prefers-reduced-motion: reduce){.agent-particle{animation:none;position:static;display:inline-block;margin:2px;transform:none!important}.agent-swarm{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:4px;padding:8px}.agent-scan-line{display:none}}.quality-dashboard{background:radial-gradient(ellipse at 30% 20%,rgba(90,214,160,.06) 0%,transparent 50%),radial-gradient(ellipse at 70% 80%,rgba(138,120,255,.04) 0%,transparent 50%),linear-gradient(135deg,#0a1118,#0e1822,#0a1319);border:1px solid rgba(90,214,160,.25);border-radius:12px;padding:12px;margin-bottom:16px;position:relative;overflow:hidden;box-shadow:0 4px 20px #5ad6a01f,0 2px 8px #0006,inset 0 1px #5ad6a014}.quality-dashboard:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background-image:linear-gradient(90deg,transparent 0%,rgba(90,214,160,.02) 50%,transparent 100%),repeating-linear-gradient(45deg,transparent,transparent 15px,rgba(90,214,160,.015) 15px,rgba(90,214,160,.015) 17px);pointer-events:none;z-index:0}.quality-dashboard-header{position:relative;z-index:10;display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.dashboard-title{display:flex;align-items:center;gap:6px;color:var(--accent);font-size:12px;font-weight:700;letter-spacing:.5px;text-shadow:0 0 6px rgba(90,214,160,.4)}.dashboard-info-btn{background:#5ad6a014;border:1px solid rgba(90,214,160,.3);color:var(--accent);padding:4px;border-radius:4px;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;width:22px;height:22px;position:relative;z-index:10}.dashboard-info-btn:hover{background:#5ad6a026;transform:scale(1.1);box-shadow:0 0 8px #5ad6a04d}.health-graphs-grid{position:relative;z-index:2;display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:12px}.health-graph-container{background:#0006;border:1px solid rgba(90,214,160,.15);border-radius:8px;padding:8px;position:relative;overflow:hidden}.health-graph-container:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background-image:linear-gradient(90deg,rgba(90,214,160,.03) 1px,transparent 1px),linear-gradient(rgba(90,214,160,.03) 1px,transparent 1px);background-size:10px 10px;opacity:.4;pointer-events:none;z-index:0}.graph-header{position:relative;z-index:2;display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.graph-header-stacked{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;gap:2px;margin-bottom:8px;text-align:center}.graph-label{font-size:10px;font-weight:700;color:#5ad6a0cc;letter-spacing:.5px}.graph-value{font-family:Courier New,monospace;font-size:13px;font-weight:700;text-shadow:0 0 4px currentColor}.graph-display{position:relative;z-index:2;height:40px;border-radius:4px;overflow:hidden;background:#0000004d;border:1px solid rgba(90,214,160,.1)}.health-graph{width:100%;height:100%;display:block}.graph-line{filter:drop-shadow(0 0 2px currentColor);animation:graphPulse 3s ease-in-out infinite alternate}.graph-dot{filter:drop-shadow(0 0 3px currentColor);animation:dotPulse 2s ease-in-out infinite}.graph-fill{opacity:.3}@keyframes graphPulse{0%{opacity:.8}to{opacity:1}}@keyframes dotPulse{0%,to{transform:scale(1);opacity:.8}50%{transform:scale(1.3);opacity:1}}.tech-debt-warning{position:relative;z-index:2;background:radial-gradient(ellipse at 50% 20%,rgba(244,91,105,.08) 0%,transparent 50%),linear-gradient(135deg,#f45b690f,#f45b6905);border:1px solid rgba(244,91,105,.3);border-radius:8px;padding:10px;margin-top:8px;overflow:hidden;box-shadow:0 2px 12px #f45b6926,inset 0 1px #f45b691a}.tech-debt-warning.critical{background:radial-gradient(ellipse at 50% 20%,rgba(244,91,105,.15) 0%,transparent 50%),linear-gradient(135deg,#f45b691a,#f45b690a);border-color:#f45b6980;animation:criticalWarning 2s ease-in-out infinite alternate}@keyframes criticalWarning{0%{box-shadow:0 2px 12px #f45b6926,inset 0 1px #f45b691a}to{box-shadow:0 4px 20px #f45b694d,inset 0 1px #f45b6933}}.tech-debt-warning:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent 0%,rgba(244,91,105,.1) 30%,rgba(244,91,105,.15) 50%,rgba(244,91,105,.1) 70%,transparent 100%);animation:dangerScan 6s linear infinite;z-index:0}@keyframes dangerScan{0%{left:-100%}to{left:100%}}.warning-header{position:relative;z-index:2;display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.warning-indicator{display:flex;align-items:center;gap:6px;color:#f45b69;font-size:10px;font-weight:700;letter-spacing:.5px;text-shadow:0 0 6px rgba(244,91,105,.4)}.debt-amount{font-family:Courier New,monospace;font-size:12px;font-weight:700;text-shadow:0 0 4px currentColor}.debt-penalty-bar{position:relative;z-index:2;background:#0006;height:12px;border-radius:6px;overflow:hidden;border:1px solid rgba(244,91,105,.2);margin-bottom:8px}.penalty-fill{height:100%;border-radius:5px;transition:width .3s ease;box-shadow:0 0 8px #f45b6966}.penalty-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:9px;font-weight:600;color:#f45b69;text-shadow:0 0 3px rgba(0,0,0,.8);letter-spacing:.3px;z-index:1}.debt-emergency-btn{position:relative;z-index:2;width:100%;font-size:10px;font-weight:700;letter-spacing:.5px;padding:8px;background:linear-gradient(135deg,#f45b69cc,#f45b6999);border:1px solid #f45b69;color:#fff;text-shadow:0 0 4px rgba(0,0,0,.5);transition:all .3s ease}.debt-emergency-btn:hover:not(:disabled){background:linear-gradient(135deg,#f45b69,#f45b69cc);box-shadow:0 0 16px #f45b6980;transform:translateY(-1px)}@media (max-width: 767px){.quality-dashboard{padding:10px}.health-graphs-grid{grid-template-columns:1fr;gap:6px}.health-graph-container{padding:6px}.graph-header{margin-bottom:4px}.graph-header-stacked{margin-bottom:6px;gap:1px}.graph-display{height:32px}.graph-label{font-size:9px}.graph-value,.dashboard-title{font-size:11px}}@media (prefers-reduced-motion: reduce){.graph-line,.graph-dot{animation:none}.tech-debt-warning:before{display:none}.tech-debt-warning.critical{animation:none}}.automation-indicator{background:linear-gradient(135deg,#0a1118,#1a2332,#0f1419);border:1px solid #213148;border-radius:12px;padding:16px;margin-bottom:16px;box-shadow:0 4px 8px #0000004d}.automation-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.automation-header h3{margin:0;color:var(--accent);font-size:16px;font-weight:600}.automation-level{background:#ffca5f1a;color:var(--warn);padding:4px 8px;border-radius:6px;font-size:12px;font-weight:600;border:1px solid var(--warn)}.automation-description{color:var(--muted);font-size:14px;margin-bottom:16px;text-align:center}.automation-progress{position:relative}.automation-progress .progress-bar{background:#0006;height:10px;border-radius:5px;overflow:hidden;margin-bottom:8px;border:1px solid #2a3441}.automation-progress-fill{background:linear-gradient(90deg,var(--warn),#fbbf24);height:100%;transition:width .3s ease;box-shadow:0 0 8px #ffca5f66}.step-marker.active{background:var(--warn);border-color:var(--warn);box-shadow:0 0 6px #ffca5f99}.manual-auto-notice{position:relative;z-index:2;margin-top:8px;padding:6px 8px;background:#ffca5f14;border:1px solid rgba(255,202,95,.3);border-radius:4px;text-align:center;font-size:10px;font-weight:600;color:#ffca5f;display:flex;align-items:center;justify-content:center;gap:4px;letter-spacing:.3px;text-shadow:0 0 4px rgba(255,202,95,.4)}.cicd-pipeline-indicator{background:radial-gradient(ellipse at 30% 20%,rgba(0,206,209,.06) 0%,transparent 50%),radial-gradient(ellipse at 70% 80%,rgba(255,202,95,.04) 0%,transparent 50%),linear-gradient(135deg,#0a1118,#0e1822,#0a1319);border:1px solid rgba(0,206,209,.25);border-radius:12px;padding:12px;margin-bottom:16px;position:relative;overflow:hidden;box-shadow:0 4px 20px #00ced11f,0 2px 8px #0006,inset 0 1px #00ced114;contain:layout style}.cicd-pipeline-indicator:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background-image:linear-gradient(90deg,transparent 0%,rgba(0,206,209,.02) 50%,transparent 100%),repeating-linear-gradient(45deg,transparent,transparent 15px,rgba(0,206,209,.015) 15px,rgba(0,206,209,.015) 17px);pointer-events:none;z-index:0}.pipeline-header{position:relative;z-index:2;display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.pipeline-header h3{margin:0;color:#00ced1;font-size:14px;font-weight:700;display:flex;align-items:center;gap:8px;text-shadow:0 0 6px rgba(0,206,209,.4)}.pipeline-icon{display:inline-flex;color:#00ced1;filter:drop-shadow(0 0 4px rgba(0,206,209,.6))}.pipeline-level{position:relative;z-index:2;background:#00ced114;color:#00ced1;padding:3px 6px;border-radius:4px;font-size:10px;font-weight:700;letter-spacing:.5px;border:1px solid rgba(0,206,209,.3);text-shadow:0 0 4px rgba(0,206,209,.4)}.pipeline-description{position:relative;z-index:2;color:#9bb1c9cc;font-size:12px;margin-bottom:10px;text-align:center;font-weight:500}.pipeline-status{position:relative;z-index:2;margin-bottom:10px}.status-row{display:flex;justify-content:space-between;align-items:center;padding:6px 10px;background:#0006;border-radius:6px;border:1px solid rgba(0,206,209,.15);margin-bottom:8px}.status-icon{display:inline-flex;color:#00ced1;margin-right:6px;filter:drop-shadow(0 0 3px rgba(0,206,209,.5));transition:all .4s ease}.status-text{flex:1;color:#e5eef5;font-size:11px;font-weight:600;letter-spacing:.3px;transition:all .4s ease}.countdown{font-family:Courier New,monospace;color:#00ced1;font-size:10px;font-weight:700;padding:2px 5px;background:#00ced114;border-radius:3px;border:1px solid rgba(0,206,209,.3);text-shadow:0 0 4px rgba(0,206,209,.4);letter-spacing:.5px}.pipeline-progress{position:relative;z-index:2}.pipeline-progress .progress-bar{background:#0006;height:8px;border-radius:4px;overflow:hidden;margin-bottom:8px;border:1px solid rgba(0,206,209,.15);box-shadow:inset 0 1px 3px #0000004d}.pipeline-progress-fill{height:100%;transition:width .3s ease;border-radius:4px}.pipeline-progress-fill.idle{background:linear-gradient(90deg,#374151,#4b5563);box-shadow:0 0 4px #4b556366}.pipeline-progress-fill.building{background:linear-gradient(90deg,#f59e0b,#fbbf24);box-shadow:0 0 8px #fbbf2466}.pipeline-progress-fill.deploying{background:linear-gradient(90deg,#00ced1,#48d1cc);box-shadow:0 0 8px #00ced166}.pipeline-progress-fill.success{background:linear-gradient(90deg,#10b981,#34d399);box-shadow:0 0 8px #34d39966}.progress-steps{display:flex;justify-content:space-between;padding:0 2px}.step-marker{width:8px;height:8px;border-radius:50%;background:#9bb1c94d;border:1px solid #2a3441;transition:all .3s ease}.step-marker.active{background:#00ced1;border-color:#00ced1;box-shadow:0 0 6px #00ced199}.tron-button.ship-build.automated{background:linear-gradient(135deg,#00ced133,#00ced11a);border-color:#00ced1;color:#00ced1;cursor:default}.tron-button.ship-build.automated:hover{background:linear-gradient(135deg,#00ced14d,#00ced126);box-shadow:0 0 16px #00ced14d}.cicd-indicator{margin-right:8px;animation:pulse-cicd 2s infinite;display:inline-flex;align-items:center}.cicd-indicator svg{width:16px;height:16px;color:currentColor;filter:drop-shadow(0 0 2px rgba(255,255,255,.3));animation:rocket-hover 3s ease-in-out infinite alternate}@keyframes rocket-hover{0%{transform:translateY(0) rotate(-1deg)}to{transform:translateY(-1px) rotate(1deg)}}@keyframes pulse-cicd{0%,50%,to{transform:scale(1);opacity:1}25%,75%{transform:scale(1.1);opacity:.8}}.cicd-pipeline-indicator.flashing{animation:deploy-flash .5s ease-out;border-color:#00ced1;box-shadow:0 0 16px #00ced199}@keyframes deploy-flash{0%{background:linear-gradient(135deg,#0a1118,#1a2332,#0f1419);box-shadow:0 4px 8px #0000004d}50%{background:linear-gradient(135deg,#00ced133,#00ced11a,#00ced10d);box-shadow:0 0 20px #00ced1cc;border-color:#48d1cc}to{background:linear-gradient(135deg,#0a1118,#1a2332,#0f1419);box-shadow:0 4px 8px #0000004d}}.cicd-pipeline-indicator.high-frequency{background:linear-gradient(135deg,#00ced126,#00ced114,#00ced108);border-color:#00ced199;box-shadow:0 0 12px #00ced166}.cicd-pipeline-indicator.high-frequency .pipeline-header h3{color:#48d1cc}.cicd-pipeline-indicator.high-frequency .pipeline-level{background:#00ced133;color:#48d1cc;border-color:#48d1cc}.intro-modal .modal-container{width:800px;max-width:95vw}.intro-content{padding:0}.intro-hero{padding:32px 32px 24px;text-align:center;background:linear-gradient(135deg,#5ad6a01a,#46e6ff0d);border-bottom:1px solid rgba(90,214,160,.2)}.intro-tagline{margin-bottom:16px}.intro-highlight{font-size:24px;font-weight:700;color:var(--accent);text-shadow:0 0 20px rgba(90,214,160,.5);animation:introGlow 3s ease-in-out infinite alternate}.intro-description{font-size:16px;color:var(--muted);line-height:1.5;max-width:600px;margin:0 auto}.intro-guide{padding:32px;border-bottom:1px solid rgba(90,214,160,.1)}.intro-section-title{display:flex;align-items:center;gap:12px;font-size:20px;font-weight:600;color:var(--text);margin-bottom:24px}.intro-step-icon{font-size:24px}.intro-steps{display:flex;flex-direction:column;gap:20px}.intro-step{display:flex;align-items:flex-start;gap:16px;padding:16px;background:#5ad6a00d;border:1px solid rgba(90,214,160,.1);border-radius:12px;transition:all .3s ease}.intro-step:hover{background:#5ad6a014;border-color:#5ad6a033;transform:translate(4px)}.intro-step-number{flex-shrink:0;width:32px;height:32px;background:linear-gradient(135deg,var(--accent) 0%,#46e6ff 100%);color:var(--bg);border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:16px;box-shadow:0 0 15px #5ad6a066}.intro-step-content h4{color:var(--text);font-size:18px;font-weight:600;margin:0 0 8px}.intro-step-content p{color:var(--muted);line-height:1.5;margin:0}.intro-step-content strong{color:var(--accent);font-weight:600}.intro-features{padding:32px;border-bottom:1px solid rgba(90,214,160,.1)}.intro-feature-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px}.intro-feature{text-align:center;padding:20px 16px;background:#5ad6a008;border:1px solid rgba(90,214,160,.08);border-radius:12px;transition:all .3s ease}.intro-feature:hover{background:#5ad6a00f;border-color:#5ad6a026;transform:translateY(-2px)}.intro-feature-icon{font-size:32px;margin-bottom:12px;display:block}.intro-feature h4{color:var(--text);font-size:14px;font-weight:600;margin:0 0 8px}.intro-feature p{color:var(--muted);font-size:12px;line-height:1.4;margin:0}.intro-cta{padding:32px;text-align:center;background:linear-gradient(135deg,#5ad6a00d,#46e6ff05)}.intro-cta-text{margin-bottom:24px}.intro-cta-text strong{color:var(--text);font-size:18px;display:block;margin-bottom:8px}.intro-cta-hint{color:var(--muted);font-size:14px}.intro-start-button{display:flex;align-items:center;justify-content:center;gap:12px;padding:16px 32px;font-size:18px;font-weight:600;background:linear-gradient(135deg,var(--accent) 0%,#46e6ff 100%);color:var(--bg);border:none;border-radius:12px;cursor:pointer;transition:all .3s ease;box-shadow:0 8px 25px #5ad6a066,inset 0 1px #fff3;margin:0 auto;min-width:200px}.intro-start-button:hover{transform:translateY(-2px) scale(1.02);box-shadow:0 12px 35px #5ad6a099,inset 0 1px #ffffff4d}.intro-start-button:active{transform:translateY(0) scale(.98)}.intro-button-text{flex:1}.intro-button-icon{font-size:20px;transition:transform .3s ease}.intro-start-button:hover .intro-button-icon{transform:translate(4px)}.intro-footer{padding:20px 32px;text-align:center;color:var(--muted);font-size:14px;background:#0003}@keyframes introGlow{0%{text-shadow:0 0 20px rgba(90,214,160,.5)}to{text-shadow:0 0 30px rgba(90,214,160,.8),0 0 40px rgba(70,230,255,.3)}}@media (max-width: 768px){.intro-modal .modal-container{width:95vw;margin:0 10px}.intro-hero,.intro-guide,.intro-features,.intro-cta{padding:24px 20px}.intro-highlight{font-size:20px}.intro-step{flex-direction:column;text-align:center;gap:12px}.intro-feature-grid{grid-template-columns:1fr 1fr;gap:12px}.intro-start-button{padding:14px 28px;font-size:16px}}.modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;z-index:9999;display:flex;align-items:center;justify-content:center;animation:modalFadeIn .3s ease-out}.modal-backdrop{position:absolute;top:0;left:0;width:100%;height:100%;background:#000c;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);animation:backdropFadeIn .3s ease-out}.modal-container{position:relative;max-width:90vw;max-height:90vh;width:600px;animation:modalSlideIn .4s cubic-bezier(.34,1.56,.64,1)}.modal-content{position:relative;background:linear-gradient(135deg,#0a1118,#1a2332,#0f1419);border:2px solid transparent;border-radius:16px;overflow:hidden;box-shadow:0 20px 60px #000c,0 0 0 1px #5ad6a033,inset 0 1px #ffffff1a}.modal-border-glow{position:absolute;top:-2px;left:-2px;right:-2px;bottom:-2px;background:linear-gradient(45deg,var(--accent),transparent 30%,transparent 70%,var(--accent));border-radius:16px;opacity:.6;animation:borderGlow 3s ease-in-out infinite;z-index:-1}.modal-corner-tl,.modal-corner-tr,.modal-corner-bl,.modal-corner-br{position:absolute;width:20px;height:20px;border:2px solid var(--accent);opacity:.8;animation:cornerPulse 2s ease-in-out infinite}.modal-corner-tl{top:8px;left:8px;border-right:none;border-bottom:none;border-top-left-radius:8px}.modal-corner-tr{top:8px;right:8px;border-left:none;border-bottom:none;border-top-right-radius:8px;animation-delay:.5s}.modal-corner-bl{bottom:8px;left:8px;border-right:none;border-top:none;border-bottom-left-radius:8px;animation-delay:1s}.modal-corner-br{bottom:8px;right:8px;border-left:none;border-top:none;border-bottom-right-radius:8px;animation-delay:1.5s}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:24px 32px 16px;border-bottom:1px solid rgba(90,214,160,.2);background:linear-gradient(90deg,transparent,rgba(90,214,160,.05),transparent)}.modal-title-container{display:flex;align-items:center;gap:12px}.modal-title-accent{width:4px;height:24px;background:linear-gradient(180deg,var(--accent),transparent);border-radius:2px;animation:titleAccentPulse 2s ease-in-out infinite}.modal-title{margin:0;font-size:20px;font-weight:600;color:var(--text);font-family:Orbitron,ui-sans-serif;letter-spacing:.02em;text-shadow:0 0 10px rgba(90,214,160,.3)}.modal-close-button{background:#f45b691a;border:1px solid rgba(244,91,105,.3);color:#f45b69;padding:8px;border-radius:8px;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center}.modal-close-button:hover{background:#f45b6933;border-color:#f45b69;transform:scale(1.1);box-shadow:0 0 15px #f45b6966}.modal-body{padding:24px 32px 32px;max-height:70vh;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--accent) transparent}.modal-body::-webkit-scrollbar{width:6px}.modal-body::-webkit-scrollbar-track{background:#0003;border-radius:3px}.modal-body::-webkit-scrollbar-thumb{background:var(--accent);border-radius:3px}.modal-body::-webkit-scrollbar-thumb:hover{background:#7ee8b8}.code-health-info{display:flex;flex-direction:column;gap:24px}.info-section{background:#0000004d;border:1px solid #2a3441;border-radius:12px;padding:20px;position:relative;transition:all .3s ease}.info-section:hover{border-color:var(--accent);box-shadow:0 0 15px #5ad6a033}.info-section.danger{border-color:#f45b6966;background:#f45b690d}.info-section.danger:hover{border-color:#f45b69;box-shadow:0 0 15px #f45b694d}.info-section.strategy{border-color:#ffca5f66;background:#ffca5f0d}.info-section.strategy:hover{border-color:var(--warn);box-shadow:0 0 15px #ffca5f4d}.info-section.formula{border-color:#4fb3d966;background:#4fb3d90d}.info-section.formula:hover{border-color:#4fb3d9;box-shadow:0 0 15px #4fb3d94d}.info-header{display:flex;align-items:center;gap:12px;margin-bottom:16px}.info-icon{font-size:24px;display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:#5ad6a01a;border:1px solid var(--accent);border-radius:8px;animation:iconPulse 3s ease-in-out infinite}.info-section.danger .info-icon{background:#f45b691a;border-color:#f45b69}.info-section.strategy .info-icon{background:#ffca5f1a;border-color:var(--warn)}.info-section.formula .info-icon{background:#4fb3d91a;border-color:#4fb3d9}.info-header h3{margin:0;font-size:18px;font-weight:600;color:var(--text);font-family:Orbitron,ui-sans-serif}.info-section p{margin:0 0 16px;line-height:1.6;color:var(--text)}.info-section ul{margin:0;padding-left:20px;color:var(--muted)}.info-section li{margin-bottom:8px;line-height:1.5}.info-section li:last-child{margin-bottom:0}.info-section strong{color:var(--accent);font-weight:600}.info-section code{background:#0009;color:var(--accent);padding:2px 6px;border-radius:4px;font-family:Courier New,monospace;font-size:13px;border:1px solid rgba(90,214,160,.3)}.formula-box{background:#0009;border:2px solid #4fb3d9;border-radius:8px;padding:16px;margin:16px 0;position:relative;overflow-x:auto}.formula-box:before{content:"";position:absolute;top:-2px;left:-2px;right:-2px;bottom:-2px;background:linear-gradient(45deg,#4fb3d9,transparent 30%,transparent 70%,#4fb3d9);border-radius:8px;opacity:.3;animation:formulaGlow 4s ease-in-out infinite;z-index:-1}.formula-box code{background:none;border:none;color:#4fb3d9;font-size:14px;font-weight:600;display:block;line-height:1.4;white-space:nowrap}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}@keyframes backdropFadeIn{0%{opacity:0;-webkit-backdrop-filter:blur(0px);backdrop-filter:blur(0px)}to{opacity:1;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.8) translateY(-40px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes borderGlow{0%,to{opacity:.6;transform:scale(1)}50%{opacity:.8;transform:scale(1.02)}}@keyframes cornerPulse{0%,to{opacity:.8;box-shadow:0 0 #5ad6a000}50%{opacity:1;box-shadow:0 0 10px #5ad6a099}}@keyframes titleAccentPulse{0%,to{opacity:.8;transform:scaleY(1)}50%{opacity:1;transform:scaleY(1.2)}}@keyframes iconPulse{0%,to{transform:scale(1);opacity:.8}50%{transform:scale(1.05);opacity:1}}@keyframes formulaGlow{0%,to{opacity:.3}50%{opacity:.6}}.tech-node-modal .modal-container{width:500px;max-width:95vw}.tech-node-modal-content{display:flex;flex-direction:column;gap:20px}.tech-node-modal-icon{display:flex;justify-content:center;align-items:center;padding:30px;background:radial-gradient(circle,rgba(90,214,160,.15) 0%,rgba(70,230,255,.08) 50%,transparent 70%);border-radius:20px;border:2px solid transparent;margin-bottom:16px;position:relative;overflow:hidden}.tech-node-modal-icon:before{content:"";position:absolute;top:-2px;left:-2px;right:-2px;bottom:-2px;background:linear-gradient(45deg,var(--accent),#46e6ff,var(--accent),#46e6ff);background-size:400% 400%;border-radius:20px;z-index:-1;animation:neonBorder 3s ease-in-out infinite}.tech-node-modal-icon:after{content:"";position:absolute;top:50%;left:50%;width:120%;height:120%;background:radial-gradient(circle,rgba(90,214,160,.3) 0%,transparent 50%);transform:translate(-50%,-50%);animation:iconPulse 2s ease-in-out infinite;z-index:-1}@keyframes neonBorder{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}@keyframes iconPulse{0%,to{opacity:.3;transform:translate(-50%,-50%) scale(1)}50%{opacity:.6;transform:translate(-50%,-50%) scale(1.1)}}.tech-node-modal-description p{margin:0;text-align:center;font-size:14px;line-height:1.5;padding:16px 20px;background:#5ad6a008;border-radius:8px;border:1px solid rgba(90,214,160,.1);position:relative}.tech-node-modal-description p:before{content:'"';position:absolute;top:8px;left:16px;font-size:24px;color:var(--accent);opacity:.5}.tech-node-modal-description p:after{content:'"';position:absolute;bottom:8px;right:16px;font-size:24px;color:var(--accent);opacity:.5}.tech-node-modal-status{display:flex;justify-content:center;margin-bottom:16px}.status-badge{padding:8px 16px;border-radius:20px;font-size:14px;font-weight:600;display:flex;align-items:center;gap:8px;border:2px solid transparent;transition:all .3s ease}.status-badge.purchased{background:linear-gradient(135deg,#5ad6a033,#5ad6a01a);color:var(--accent);border-color:#5ad6a066;box-shadow:0 0 15px #5ad6a04d}.status-badge.unlocked{background:linear-gradient(135deg,#ffca5f33,#ffca5f1a);color:var(--warn);border-color:#ffca5f66;box-shadow:0 0 15px #ffca5f4d}.status-badge.locked{background:linear-gradient(135deg,#9bb1c933,#9bb1c91a);color:var(--muted);border-color:#9bb1c966}.tech-node-modal-cost{display:flex;justify-content:center;margin-bottom:20px}.cost-container{display:flex;align-items:center;gap:12px;padding:12px 24px;background:#0006;border-radius:12px;border:2px solid rgba(90,214,160,.2)}.cost-label{color:var(--muted);font-size:14px;font-weight:500}.cost-value{font-size:18px;font-weight:700;font-family:Orbitron,ui-sans-serif;transition:all .3s ease}.cost-value.affordable{color:var(--accent);text-shadow:0 0 10px rgba(90,214,160,.5)}.cost-value.expensive{color:var(--danger);text-shadow:0 0 10px rgba(244,91,105,.5)}.tech-node-modal-requirements{margin-bottom:20px}.tech-node-modal-requirements h4{margin:0 0 12px;color:var(--text);font-size:16px;font-weight:600;display:flex;align-items:center;gap:8px}.requirements-list{display:flex;flex-wrap:wrap;gap:8px}.requirement-badge{padding:6px 12px;background:#4fb3d91a;color:#4fb3d9;border:1px solid rgba(79,179,217,.3);border-radius:16px;font-size:12px;font-weight:600;font-family:Orbitron,ui-sans-serif;letter-spacing:.02em;transition:all .3s ease}.requirement-badge:hover{background:#4fb3d933;border-color:#4fb3d9;transform:translateY(-1px);box-shadow:0 4px 12px #4fb3d94d}.tech-node-modal-effects{margin-bottom:20px}.tech-node-modal-effects h4{margin:0 0 16px;color:var(--text);font-size:16px;font-weight:600;display:flex;align-items:center;gap:8px}.effects-list{display:flex;flex-direction:column;gap:10px}.effect-item{display:flex;align-items:center;gap:12px;padding:10px 16px;border-radius:8px;border:1px solid transparent;transition:all .3s ease;position:relative}.effect-item.loc{background:#46e6ff0d;border-color:#46e6ff33}.effect-item.loc .effect-bullet{color:#46e6ff}.effect-item.ship{background:#ffca5f0d;border-color:#ffca5f33}.effect-item.ship .effect-bullet{color:var(--warn)}.effect-item.revenue{background:#5ad6a00d;border-color:#5ad6a033}.effect-item.revenue .effect-bullet{color:var(--accent)}.effect-item.global{background:#8a78ff0d;border-color:#8a78ff33}.effect-item.global .effect-bullet{color:#8a78ff}.effect-bullet{font-size:16px;font-weight:700;flex-shrink:0;width:16px;text-align:center}.effect-text{color:var(--text);font-size:14px;font-weight:500;flex:1}.effect-item:hover{transform:translate(4px);opacity:.9;border-color:inherit;box-shadow:4px 0 12px #0003}.tech-node-modal-details{background:#0000004d;border:1px solid rgba(90,214,160,.1);border-radius:12px;padding:20px;margin-top:20px}.detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:16px}.detail-item{display:flex;flex-direction:column;gap:4px;text-align:center}.detail-label{color:var(--muted);font-size:12px;font-weight:500;text-transform:uppercase;letter-spacing:.05em}.detail-value{color:var(--text);font-size:14px;font-weight:600;font-family:Orbitron,ui-sans-serif}.lightning-icon{color:var(--accent);filter:drop-shadow(0 0 4px rgba(90,214,160,.6));animation:lightningGlow 2s ease-in-out infinite}.chain-icon{color:#4fb3d9;filter:drop-shadow(0 0 4px rgba(79,179,217,.6));animation:chainPulse 2.5s ease-in-out infinite}@keyframes lightningGlow{0%,to{filter:drop-shadow(0 0 4px rgba(90,214,160,.6));transform:scale(1)}50%{filter:drop-shadow(0 0 8px rgba(90,214,160,.9)) drop-shadow(0 0 12px rgba(90,214,160,.5));transform:scale(1.05)}}@keyframes chainPulse{0%,to{filter:drop-shadow(0 0 4px rgba(79,179,217,.6));opacity:.8}50%{filter:drop-shadow(0 0 8px rgba(79,179,217,.9));opacity:1}}@media (max-width: 768px){.tech-node-modal .modal-container{width:95vw;margin:0 10px}.tech-node-modal-content{gap:16px}.tech-node-modal-icon{padding:16px}.tech-node-modal-description p{font-size:13px;padding:12px 16px}.detail-grid{grid-template-columns:1fr;gap:12px}.requirements-list{justify-content:center}.effect-item{padding:8px 12px}.effect-text{font-size:13px}}.garbled-text{font-family:Courier New,monospace;letter-spacing:.05em;position:relative;display:inline-block;min-height:1.2em;vertical-align:top;font-variant-numeric:tabular-nums}.garbled-text.animated{animation:garble-flicker 2s ease-in-out infinite}.garbled-text.corrupted{color:#ff6b6b;text-shadow:0 0 5px rgba(255,107,107,.5),1px 0 0 rgba(255,107,107,.3),-1px 0 0 rgba(107,255,107,.3)}.garbled-text.redacted{color:#333;background:linear-gradient(90deg,#666,#999,#666);-webkit-background-clip:text;background-clip:text;animation:redacted-pulse 1.5s ease-in-out infinite}.garbled-text.glitched{color:#0ff;text-shadow:0 0 3px #00ffff,2px 0 0 #ff0080,-2px 0 0 #00ff40;animation:glitch-shift .3s ease-in-out infinite}.garbled-text.encrypted{color:#0f0;font-family:Orbitron,monospace;text-shadow:0 0 8px rgba(0,255,0,.6);animation:matrix-rain 3s linear infinite}.garbled-text.static{color:#ccc;text-shadow:0 0 2px rgba(255,255,255,.8),0 0 8px rgba(255,255,255,.3);animation:static-noise .1s steps(10) infinite}.garbled-text.fragmented{color:#fa0;text-shadow:0 0 4px rgba(255,170,0,.6),1px 1px 0 rgba(255,170,0,.3);animation:fragment-drift 2.5s ease-in-out infinite}.node.is-locked .garbled-text{cursor:help;transition:all .3s ease}.node.is-locked .garbled-text:hover{transform:scale(1.05);filter:brightness(1.2)}@keyframes garble-flicker{0%,to{opacity:.9}25%{opacity:1;transform:translate(.5px)}50%{opacity:.7;transform:translate(-.5px)}75%{opacity:1;transform:translate(0)}}@keyframes redacted-pulse{0%,to{background:linear-gradient(90deg,#333,#666,#333);-webkit-background-clip:text;background-clip:text}50%{background:linear-gradient(90deg,#666,#999,#666);-webkit-background-clip:text;background-clip:text}}@keyframes glitch-shift{0%{transform:translate(0)}20%{transform:translate(-1px,1px)}40%{transform:translate(-1px,-1px)}60%{transform:translate(1px,1px)}80%{transform:translate(1px,-1px)}to{transform:translate(0)}}@keyframes matrix-rain{0%{text-shadow:0 0 8px rgba(0,255,0,.6);color:#0f0}25%{text-shadow:0 0 12px rgba(0,255,0,.8);color:#40ff40}50%{text-shadow:0 0 8px rgba(0,255,0,.6);color:#0f0}75%{text-shadow:0 0 4px rgba(0,255,0,.4);color:#0c0}to{text-shadow:0 0 8px rgba(0,255,0,.6);color:#0f0}}@keyframes static-noise{0%{text-shadow:0 0 2px rgba(255,255,255,.8),1px 0 0 rgba(255,255,255,.5)}10%{text-shadow:0 0 3px rgba(255,255,255,.9),-1px 0 0 rgba(255,255,255,.6)}20%{text-shadow:0 0 1px rgba(255,255,255,.7),0 1px 0 rgba(255,255,255,.4)}30%{text-shadow:0 0 4px rgba(255,255,255,1),1px 1px 0 rgba(255,255,255,.7)}40%{text-shadow:0 0 2px rgba(255,255,255,.8),-1px -1px 0 rgba(255,255,255,.5)}50%{text-shadow:0 0 5px rgba(255,255,255,1.2),2px 0 0 rgba(255,255,255,.8)}60%{text-shadow:0 0 1px rgba(255,255,255,.6),0 -1px 0 rgba(255,255,255,.3)}70%{text-shadow:0 0 3px rgba(255,255,255,.9),-2px 0 0 rgba(255,255,255,.6)}80%{text-shadow:0 0 2px rgba(255,255,255,.8),1px -1px 0 rgba(255,255,255,.4)}90%{text-shadow:0 0 4px rgba(255,255,255,1),-1px 1px 0 rgba(255,255,255,.7)}to{text-shadow:0 0 2px rgba(255,255,255,.8),0 0 0 rgba(255,255,255,.5)}}@keyframes fragment-drift{0%,to{transform:translateY(0);opacity:.9}25%{transform:translateY(-1px) translate(.5px);opacity:1}50%{transform:translateY(1px) translate(-.5px);opacity:.8}75%{transform:translateY(-.5px) translate(.3px);opacity:1}}.tech-purchase-animation-overlay{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:1000;mix-blend-mode:screen}.tech-purchase-animation-overlay canvas{position:absolute;top:0;left:0;width:100%;height:100%;will-change:transform;backface-visibility:hidden;transform:translateZ(0);opacity:.9;filter:brightness(1.1) saturate(1.3)}.node button.tron-button{position:relative;transition:all .3s ease}.node button.tron-button:active{transform:scale(.95);filter:brightness(1.2) saturate(1.5)}.node button.tron-button:hover{box-shadow:0 0 15px #5ad6a066,inset 0 0 10px #5ad6a01a}.branch-A .node button.tron-button:hover{box-shadow:0 0 15px #46e6ff66,inset 0 0 10px #46e6ff1a}.branch-B .node button.tron-button:hover{box-shadow:0 0 15px #5aa6ff66,inset 0 0 10px #5aa6ff1a}.branch-C .node button.tron-button:hover{box-shadow:0 0 15px #8a5aff66,inset 0 0 10px #8a5aff1a}.branch-D .node button.tron-button:hover{box-shadow:0 0 15px #ff5aa666,inset 0 0 10px #ff5aa61a}.branch-E .node button.tron-button:hover{box-shadow:0 0 15px #ff8a5a66,inset 0 0 10px #ff8a5a1a}.branch-F .node button.tron-button:hover{box-shadow:0 0 15px #5aff8a66,inset 0 0 10px #5aff8a1a}.branch-G .node button.tron-button:hover{box-shadow:0 0 15px #ffff5a66,inset 0 0 10px #ffff5a1a}.branch-H .node button.tron-button:hover{box-shadow:0 0 15px #ff5a5a66,inset 0 0 10px #ff5a5a1a}@keyframes float-up{0%{opacity:1;transform:translateY(0) scale(1)}50%{opacity:1;transform:translateY(-50px) scale(1.1)}to{opacity:0;transform:translateY(-120px) scale(.8)}}.floating-effect-text{position:fixed;font-family:Chakra Petch,monospace;font-weight:600;font-size:16px;color:#5ad6a0;text-shadow:0 0 10px currentColor;pointer-events:none;z-index:1001;animation:float-up 2s ease-out forwards}.tech-purchase-animation-overlay,.floating-effect-text{contain:layout style paint;transform:translateZ(0);will-change:opacity,transform}@media (max-width: 768px){.tech-purchase-animation-overlay canvas{opacity:.7;filter:brightness(1.05) saturate(1.1)}.floating-effect-text{font-size:14px}}@media (prefers-contrast: high){.tech-purchase-animation-overlay{mix-blend-mode:normal}.tech-purchase-animation-overlay canvas{filter:contrast(1.5) brightness(1.2)}}.animation-test-panel{backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.animation-test-panel button:hover{transform:translateY(-1px);box-shadow:0 2px 8px #0003}@media (prefers-reduced-motion: reduce){.tech-purchase-animation-overlay{display:none}.node button.tron-button{transition:none}.floating-effect-text{animation:none;opacity:1;position:static}.animation-test-panel button{transition:none}.animation-test-panel button:hover{transform:none;box-shadow:none}}.action-button-animation-overlay{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:500;mix-blend-mode:normal}.action-button-animation-overlay canvas{position:absolute;top:0;left:0;width:100%;height:100%;will-change:transform;backface-visibility:hidden;transform:translateZ(0);opacity:.7;filter:brightness(1.05) saturate(1.03)}.tron-button{position:relative;transition:all .15s ease;transform-style:preserve-3d;perspective:1000px}.tron-button.write-code{transition:all .1s ease}.tron-button.write-code:active{transform:translateY(1px) scale(.98);box-shadow:0 2px 8px #5ad6a04d,inset 0 1px 3px #0003;filter:brightness(1.2)}.tron-button.write-code:hover:not(:disabled){transform:translateY(-1px) scale(1.02);box-shadow:0 4px 12px #5ad6a066,inset 0 -1px 3px #5ad6a01a}.tron-button.ship-build:active{transform:translateY(2px) scale(.96) rotateX(2deg);box-shadow:0 1px 4px #ffca5f66,inset 0 2px 4px #0003;filter:brightness(1.3) saturate(1.2)}.tron-button.ship-build:hover:not(:disabled){transform:translateY(-2px) scale(1.04) rotateX(-1deg);box-shadow:0 6px 16px #ffca5f80,inset 0 -2px 4px #ffca5f1a}.debt-paydown-btn{position:relative;transition:all .2s ease;transform-style:preserve-3d}.debt-paydown-btn:active{transform:scale(.94) rotateX(3deg);box-shadow:0 2px 8px #f45b6966,inset 0 2px 6px #0000004d;filter:brightness(1.1) contrast(1.1)}.debt-paydown-btn:hover:not(:disabled){transform:scale(1.03) rotateX(-1deg);box-shadow:0 4px 12px #f45b6999,inset 0 -1px 3px #f45b6933}@keyframes button-ripple{0%{transform:scale(0);opacity:1}to{transform:scale(2);opacity:0}}.tron-button:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#ffffff4d;transform:translate(-50%,-50%);transition:width .3s,height .3s;pointer-events:none;z-index:-1}.tron-button:active:before{animation:button-ripple .3s ease-out;width:100%;height:100%}.tron-button.write-code:before{background:#5ad6a066}.tron-button.ship-build:before{background:#ffca5f66}.debt-paydown-btn:before{background:#f45b6966}@keyframes action-glow-pulse{0%,to{box-shadow:0 0 5px currentColor}50%{box-shadow:0 0 15px currentColor,0 0 25px currentColor}}.action-animation-active.write-code{animation:action-glow-pulse .6s ease-in-out}.action-animation-active.ship-build{animation:action-glow-pulse .8s ease-in-out}.action-animation-active.debt-paydown-btn{animation:action-glow-pulse 1s ease-in-out}.tron-button,.debt-paydown-btn{contain:layout style;will-change:transform,box-shadow}@media (prefers-reduced-motion: reduce){.action-button-animation-overlay{display:none}.tron-button,.debt-paydown-btn{transition:none}.tron-button:active,.tron-button:hover,.debt-paydown-btn:active,.debt-paydown-btn:hover{transform:none;animation:none}.tron-button:before{display:none}}@media (prefers-contrast: high){.action-button-animation-overlay{opacity:1;filter:contrast(2)}.tron-button:active,.debt-paydown-btn:active{outline:2px solid currentColor}}@media (max-width: 768px){.action-button-animation-overlay canvas{opacity:.5;filter:brightness(1) saturate(1)}.tron-button:active,.debt-paydown-btn:active{transform:scale(.98)}.tron-button:hover,.debt-paydown-btn:hover{transform:none}}@media (prefers-reduced-motion: reduce){.action-button-animation-overlay{display:none!important}}.debug-action-animations .action-button-animation-overlay{outline:1px dashed #00ff00;opacity:1}.mobile-nav{position:fixed;bottom:0;left:0;right:0;background:var(--panel);border-top:1px solid #213148;display:flex;z-index:100;padding:8px;gap:4px}.mobile-nav-tab{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 4px;background:transparent;border:none;color:var(--muted);cursor:pointer;transition:all .3s ease;border-radius:8px;min-height:60px;touch-action:manipulation}.mobile-nav-tab.active{color:var(--accent);background:#5ad6a01a}.mobile-nav-tab:hover{color:var(--text);background:#ffffff0d}.mobile-nav-tab.active:hover{color:var(--accent);background:#5ad6a026}.mobile-nav-icon{width:20px;height:20px;stroke-width:1.5;transition:all .3s ease}.mobile-nav-tab.active .mobile-nav-icon{filter:drop-shadow(0 0 4px currentColor);stroke-width:2}.mobile-nav-tab:hover .mobile-nav-icon{transform:translateY(-1px);filter:drop-shadow(0 2px 4px rgba(0,0,0,.3))}.mobile-nav-label{font-size:11px;font-weight:500;letter-spacing:.02em}.mobile-tab-content{background:var(--panel);border:1px solid #213148;border-radius:12px;padding:12px;margin-bottom:108px}@media (max-width: 767px){.app{grid-template-rows:auto 1fr}.main{padding:8px;gap:8px}.footer{display:none}.mobile-tab-content{padding-bottom:20px}}@media (max-width: 767px){.tron-button{min-height:48px;font-size:16px;padding:14px 24px;border-radius:12px}.actions{gap:12px;margin-top:12px;justify-content:center;align-items:center}.actions .tron-button{min-height:52px;padding:16px 12px;font-size:15px;flex:1;min-width:0;max-width:100%}.hud-grid{gap:12px;grid-template-columns:1fr;width:100%;max-width:100%;overflow:hidden}.stat{padding:14px;border-radius:12px;min-height:80px;width:100%;max-width:100%;min-width:0;box-sizing:border-box}.stat .value{font-size:22px;font-weight:700}.stat .label{font-size:13px;margin-bottom:4px}.badge{padding:8px 12px;font-size:13px;min-height:32px;display:flex;align-items:center}.ribbon{gap:12px;padding:8px 0}}*{touch-action:manipulation}@media (max-width: 767px){*{-webkit-overflow-scrolling:touch}@media (prefers-reduced-motion: no-preference){.tron-button{transition:all .2s ease}.tron-button:before{transition:left .3s ease}.node-hero{transition:transform .2s ease}}.pulse-subtle{animation:none}.tron-button:hover{transform:none}.tron-button:active{transform:scale(.98);transition:transform .1s ease}body,.tron-button,.node-name,.stat .value{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}}@media (max-width: 767px){html,body{height:100%}.app{height:100vh;height:100dvh}.mobile-tab-content{padding-bottom:20px;width:100%;max-width:100vw;overflow-x:hidden}.mobile-tab-content *{max-width:100%;box-sizing:border-box}.header{padding-top:max(8px,env(safe-area-inset-top));padding-left:max(16px,env(safe-area-inset-left));padding-right:max(16px,env(safe-area-inset-right))}.mobile-nav{padding-bottom:max(8px,env(safe-area-inset-bottom));padding-left:max(8px,env(safe-area-inset-left));padding-right:max(8px,env(safe-area-inset-right))}}.news-ticker{position:fixed;bottom:0;left:0;right:0;height:32px;background:linear-gradient(90deg,var(--panel),rgba(18,24,33,.95));border-top:1px solid rgba(90,214,160,.3);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);overflow:hidden;z-index:100;display:flex;align-items:center;transition:bottom .3s ease}.news-ticker.at-bottom{bottom:40px}.news-label{flex-shrink:0;padding:0 12px;font-size:11px;font-weight:600;color:var(--accent);background:#121821f2;border-right:1px solid rgba(90,214,160,.3);height:100%;display:flex;align-items:center;letter-spacing:.5px;position:relative;z-index:1}.news-content{flex:1;white-space:nowrap;animation:scroll-left 80s linear infinite;font-size:12px;line-height:32px;padding-left:20px}.news-item{color:var(--text);margin-right:40px}.news-item strong{color:var(--accent);font-weight:500}.news-score{color:var(--warn);font-size:10px;font-weight:600}.news-separator{color:var(--muted);opacity:.6}.news-link{color:var(--accent);font-size:10px;text-decoration:none;margin-left:4px;opacity:.8;transition:opacity .2s}.news-link:hover{opacity:1;text-decoration:underline}@keyframes scroll-left{0%{transform:translate(0)}to{transform:translate(-100%)}}.news-ticker.loading .news-content{animation:pulse 1.5s ease-in-out infinite;transform:translate(0)}.news-ticker.loading .news-item{color:var(--muted)}.news-ticker.error .news-content{animation:scroll-left 30s linear infinite}.news-ticker.error .news-item{color:var(--danger)}@keyframes pulse{0%,to{opacity:.6}50%{opacity:1}}@media (max-width: 767px){.news-ticker{bottom:calc(68px + max(8px,env(safe-area-inset-bottom)));height:28px}.news-ticker.at-bottom{bottom:calc(68px + max(8px,env(safe-area-inset-bottom)))}.news-label{font-size:10px;padding:0 8px}.news-content{font-size:11px;line-height:28px;animation:scroll-left 60s linear infinite}}@media (prefers-reduced-motion: reduce){.news-content{animation:none;overflow-x:auto;white-space:nowrap;padding-right:20px}.news-item{display:inline-block;margin-right:20px}}
