:root{--color-bg-primary: #0a0e17;--color-bg-secondary: #131a2b;--color-bg-tertiary: #1a2540;--color-bg-card: rgba(26, 37, 64, .8);--color-accent-primary: #00d4ff;--color-accent-secondary: #7b5cff;--color-accent-gold: #ffd700;--color-accent-green: #00ff88;--color-accent-red: #ff4466;--color-text-primary: #ffffff;--color-text-secondary: #a0b0c0;--color-text-muted: #607080;--gradient-primary: linear-gradient(135deg, #00d4ff 0%, #7b5cff 100%);--gradient-gold: linear-gradient(135deg, #ffd700 0%, #ff8c00 100%);--gradient-card: linear-gradient(180deg, rgba(26, 37, 64, .9) 0%, rgba(10, 14, 23, .95) 100%);--gradient-hbm: linear-gradient(135deg, #00d4ff 0%, #0088ff 100%);--gradient-nand: linear-gradient(135deg, #7b5cff 0%, #aa44ff 100%);--glass-bg: rgba(26, 37, 64, .6);--glass-border: rgba(255, 255, 255, .1);--glass-blur: blur(20px);--font-display: "Orbitron", sans-serif;--font-body: "Roboto", sans-serif;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--spacing-2xl: 48px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .3);--shadow-md: 0 4px 16px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .5);--shadow-glow-cyan: 0 0 20px rgba(0, 212, 255, .3);--shadow-glow-gold: 0 0 20px rgba(255, 215, 0, .3);--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .4s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-tap-highlight-color:transparent}body{font-family:var(--font-body);background:var(--color-bg-primary);color:var(--color-text-primary);min-height:100vh;min-height:100dvh;overflow-x:hidden;line-height:1.5;touch-action:manipulation}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--color-bg-secondary)}::-webkit-scrollbar-thumb{background:var(--color-accent-primary);border-radius:var(--radius-sm)}#app{display:flex;flex-direction:column;min-height:100vh;min-height:100dvh}.game-header{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;padding:var(--spacing-xs) var(--spacing-sm);background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-bottom:1px solid var(--glass-border);position:sticky;top:0;z-index:100}.logo h1{font-family:var(--font-display);font-size:1rem;font-weight:700;letter-spacing:1px;text-transform:uppercase}.logo .accent{background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.stats-bar{display:flex;gap:var(--spacing-sm);flex:1;justify-content:center;padding:0}.stat{display:flex;flex-direction:column;align-items:center;padding:0 var(--spacing-sm)}.stat-label{font-size:.65rem;text-transform:uppercase;letter-spacing:1px;color:var(--color-text-muted)}.stat-value{font-family:var(--font-display);font-size:.8rem;font-weight:700}.stat.cash .stat-value{color:var(--color-accent-green)}.header-actions{display:flex;gap:var(--spacing-sm)}.header-actions button{padding:var(--spacing-xs) var(--spacing-sm);font-size:.75rem;border:1px solid var(--glass-border);border-radius:var(--radius-sm);background:var(--glass-bg);color:var(--color-text-primary);cursor:pointer;transition:var(--transition-fast)}.header-actions button:hover{background:var(--color-accent-primary);border-color:var(--color-accent-primary)}.game-main{display:flex;flex-direction:column;flex:1;padding:var(--spacing-sm);gap:var(--spacing-sm);overflow-y:auto}.section-header h2{font-family:var(--font-display);font-size:.85rem;font-weight:700;text-transform:uppercase;letter-spacing:1px}.fab-floor-section{background:var(--gradient-card);border-radius:var(--radius-lg);padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--glass-border);overflow-x:auto;-webkit-overflow-scrolling:touch}.floor-status{font-size:.75rem;color:var(--color-accent-green)}.fab-floor-container{position:relative;aspect-ratio:16 / 9;background:linear-gradient(180deg,#0d1220,#151f35);border-radius:var(--radius-md);overflow:hidden}.fab-overlay{position:absolute;bottom:0;left:0;right:0;padding:var(--spacing-sm);background:linear-gradient(transparent,#000c)}.wafer-progress{position:relative;height:8px;background:var(--color-bg-primary);border-radius:var(--radius-sm);overflow:hidden}.progress-bar{height:100%;width:0%;background:var(--gradient-primary);border-radius:var(--radius-sm);transition:width .1s linear}.progress-text{position:absolute;right:var(--spacing-sm);top:50%;transform:translateY(-50%);font-size:.6rem;font-weight:700}.pipeline-visualizer{display:flex;position:relative}.pipeline-visualizer.horizontal{align-items:center;justify-content:space-between;padding:40px 0;margin:var(--spacing-sm) 0;min-width:600px;flex-wrap:nowrap;overflow-x:auto}.pipeline-visualizer.vertical{flex-direction:column;align-items:center;min-height:480px;max-width:100%;margin:0 auto;padding:20px 0}.pipeline-visualizer::-webkit-scrollbar{height:6px;width:6px;display:block}.pipeline-visualizer::-webkit-scrollbar-thumb{background:var(--color-accent-primary);border-radius:3px}.wafer-progress-container{margin-top:var(--spacing-sm);padding:0 var(--spacing-sm)}.pipeline-stage{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xs);min-width:80px;position:relative;z-index:2}.vertical .pipeline-stage{flex-direction:row;min-width:220px;justify-content:flex-start;gap:12px;padding:6px}.vertical .detail-label{width:100px;text-align:right;font-size:.75rem}.stage-icon{width:40px;height:40px;background:var(--color-bg-tertiary);border:1px solid var(--glass-border);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.2rem;transition:var(--transition-normal);box-shadow:var(--shadow-sm)}.pipeline-stage.active .stage-icon{background:var(--gradient-primary);border-color:transparent;box-shadow:var(--shadow-glow-cyan);transform:scale(1.1)}.stage-name{font-size:.65rem;font-weight:700;text-transform:uppercase;color:var(--color-text-muted)}.pipeline-stage.active .stage-name{color:var(--color-accent-primary)}.pipeline-stage{cursor:pointer;transition:transform .2s ease}.pipeline-stage:hover .stage-icon{transform:scale(1.1);box-shadow:0 0 15px var(--color-accent-primary)}.stage-active-indicator{width:6px;height:6px;border-radius:50%;background:var(--color-bg-tertiary);margin-top:2px}.pipeline-stage.active .stage-active-indicator{background:var(--color-accent-green);box-shadow:0 0 5px var(--color-accent-green)}.pipeline-connector{flex:1;background:#1e293b;border-radius:4px;position:relative;overflow:hidden;border:2px solid #334155;box-shadow:inset 0 4px 8px #0009;z-index:1}.horizontal .pipeline-connector{height:24px;margin:0 -4px;transform:translateY(-8px)}.vertical .pipeline-connector{width:24px;height:40px;margin:-5px 0;flex:none}.pipeline-connector:before{content:"";position:absolute;top:0;left:0;z-index:1}.horizontal .pipeline-connector:before{width:200%;height:100%;background-image:repeating-linear-gradient(90deg,transparent,transparent 12px,rgba(0,0,0,.4) 12px,rgba(0,0,0,.4) 14px)}.vertical .pipeline-connector:before{width:100%;height:200%;background-image:repeating-linear-gradient(0deg,transparent,transparent 12px,rgba(0,0,0,.4) 12px,rgba(0,0,0,.4) 14px)}@keyframes belt-scroll-horizontal{0%{background-position-x:0}to{background-position-x:24px}}@keyframes belt-scroll-vertical{0%{background-position-y:0}to{background-position-y:24px}}.horizontal.running .pipeline-connector:before{animation:belt-scroll-horizontal 1s linear infinite}.vertical.running .pipeline-connector:before{animation:belt-scroll-vertical 1.2s linear infinite}.pipeline-connector:after{content:"";position:absolute;opacity:.5;z-index:2}.horizontal .pipeline-connector:after{top:50%;left:0;width:100%;height:4px;background:repeating-linear-gradient(90deg,#475569 0px,#475569 2px,transparent 2px,transparent 20px);transform:translateY(-50%)}.vertical .pipeline-connector:after{left:50%;top:0;height:100%;width:4px;background:repeating-linear-gradient(0deg,#475569 0px,#475569 2px,transparent 2px,transparent 20px);transform:translate(-50%)}.connector-bar{height:18px;width:18px;background:radial-gradient(circle at 30% 30%,#f8fafc,#64748b,#0f172a);border-radius:50%;position:absolute;top:50%;left:-20px;z-index:10;transition:left .1s linear;border:1px solid rgba(0,212,255,.8);box-shadow:0 0 10px #00d4ff80,inset 0 0 4px #ffffff80}.connector-bar:after{content:"";position:absolute;top:15%;left:15%;width:30%;height:30%;background:#fff;border-radius:50%;filter:blur(1px);opacity:.8}.flow-particles{position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(0,212,255,.1),transparent);transform:translate(-100%);opacity:0;z-index:2}.pipeline-visualizer.running .flow-particles{animation:flow-glow 2s linear infinite;opacity:1}@keyframes flow-glow{0%{transform:translate(-100%)}to{transform:translate(200%)}}@keyframes flow{0%{transform:translate(-100%)}to{transform:translate(200%)}}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-sm)}.header-left{display:flex;flex-direction:column}.quick-action-btn{display:flex;align-items:center;gap:var(--spacing-xs);padding:6px 12px;background:var(--color-bg-tertiary);border:1px solid var(--color-accent-primary);border-radius:var(--radius-sm);color:var(--color-text-primary);font-size:.75rem;cursor:pointer;transition:var(--transition-fast)}.quick-action-btn:hover{background:var(--color-accent-primary);box-shadow:var(--shadow-glow-cyan)}.quick-action-btn:active{transform:scale(.95)}.line-actions{margin:var(--spacing-xs) 0}.upgrade-tier-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-sm);background:var(--color-bg-tertiary);border:1px dashed var(--color-text-muted);border-radius:var(--radius-sm);color:var(--color-text-secondary);font-size:.8rem;cursor:pointer;transition:var(--transition-normal)}.upgrade-tier-btn:not(:disabled):hover{background:var(--color-bg-secondary);border-color:var(--color-accent-primary);color:var(--color-text-primary)}.upgrade-tier-btn:disabled{opacity:.5;cursor:not-allowed}.upgrade-tier-btn.available{border-style:solid;border-color:var(--color-accent-gold);background:#ffd7001a;color:var(--color-accent-gold);font-weight:700;animation:pulse-border 2s infinite}@keyframes pulse-border{0%{border-color:#ffd70066}50%{border-color:gold}to{border-color:#ffd70066}}.production-section{display:flex;flex-direction:column;gap:var(--spacing-md)}.production-line{background:var(--gradient-card);border-radius:var(--radius-lg);padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--glass-border);transition:var(--transition-normal)}.production-line:hover{border-color:var(--color-accent-primary);box-shadow:var(--shadow-glow-cyan)}.production-line.producing{animation:producing-pulse .6s ease-out;border-color:var(--color-accent-green);box-shadow:0 0 25px #0f86}@keyframes producing-pulse{0%{transform:scale(1)}30%{transform:scale(1.02)}to{transform:scale(1)}}.line-header{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-xs)}.line-icon{width:48px;height:48px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center}.hbm-icon{background:var(--gradient-hbm);box-shadow:var(--shadow-glow-cyan)}.hbm-icon:after{content:"⚡";font-size:1.5rem}.nand-icon{background:var(--gradient-nand)}.nand-icon:after{content:"💾";font-size:1.5rem}.line-info{flex:1}.line-info h3{font-family:var(--font-display);font-size:1rem;font-weight:700}.line-tier{font-size:.75rem;color:var(--color-text-secondary)}.line-price{text-align:right}.price-label{display:block;font-size:.65rem;color:var(--color-text-muted);text-transform:uppercase}.price-value{font-family:var(--font-display);font-size:1.1rem;font-weight:700;color:var(--color-accent-green)}.line-stats{display:flex;justify-content:space-between;padding:var(--spacing-sm) 0;border-top:1px solid var(--glass-border);border-bottom:1px solid var(--glass-border)}.stat-item{text-align:center}.stat-item .label{display:block;font-size:.65rem;color:var(--color-text-muted);text-transform:uppercase}.stat-item .value{font-family:var(--font-display);font-size:.9rem;font-weight:700}.line-visual{height:30px;margin-top:var(--spacing-xs);display:flex;align-items:center;justify-content:center}.chip-stack,.layer-stack{display:flex;flex-direction:column-reverse;align-items:center;gap:2px}.hbm-die{width:24px;height:4px;background:var(--color-accent-primary);border-radius:1px;box-shadow:0 0 8px #00d4ff66;transition:var(--transition-normal)}.layer-stack{flex-direction:row}.nand-block{width:8px;height:24px;background:var(--color-accent-secondary);border-radius:1px;box-shadow:0 0 8px #7b5cff66;transition:var(--transition-normal)}.market-upgrades-section{display:flex;flex-direction:column;gap:var(--spacing-md)}.price-ticker-container{background:var(--gradient-card);border-radius:var(--radius-lg);padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--glass-border)}.market-status{font-size:.75rem;padding:var(--spacing-xs) var(--spacing-sm);background:var(--color-bg-tertiary);border-radius:var(--radius-sm);color:var(--color-text-secondary)}.market-status.supercycle{background:var(--gradient-gold);color:var(--color-bg-primary);animation:glow 1s ease-in-out infinite alternate}@keyframes glow{0%{box-shadow:0 0 5px #ffd70080}to{box-shadow:0 0 20px #ffd700cc}}#price-ticker-canvas{width:100%;max-width:100%;height:180px;background:#05070a;border-radius:var(--radius-md);margin:var(--spacing-sm) 0;border:1px solid var(--glass-border);display:block;box-sizing:border-box}.price-legend{display:flex;justify-content:center;gap:var(--spacing-lg);font-size:.75rem}.legend-hbm{color:var(--color-accent-primary)}.legend-nand{color:var(--color-accent-secondary)}.upgrades-container{background:var(--gradient-card);border-radius:var(--radius-lg);padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--glass-border);flex:1}.upgrade-categories{display:flex;flex-direction:column;gap:var(--spacing-xs);margin-bottom:var(--spacing-md)}.upgrade-tab{flex:1;min-width:max-content;padding:var(--spacing-xs) var(--spacing-sm);font-size:.7rem;font-weight:500;text-transform:uppercase;letter-spacing:.5px;border:1px solid var(--glass-border);border-radius:var(--radius-sm);background:transparent;color:var(--color-text-secondary);cursor:pointer;transition:var(--transition-fast)}.upgrade-tab:hover{border-color:var(--color-accent-primary);color:var(--color-accent-primary)}.upgrade-tab.active{background:var(--gradient-primary);border-color:transparent;color:var(--color-bg-primary)}.upgrades-list{display:flex;flex-direction:column;gap:var(--spacing-sm);max-height:300px;overflow-y:auto}.upgrade-item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--color-bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--glass-border);cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.upgrade-item:before{content:"";position:absolute;top:0;left:0;width:4px;height:100%;background:var(--color-text-muted);transition:background .2s ease}.upgrade-item:hover:not(.locked):not(.purchased){border-color:var(--color-accent-primary);background:var(--color-bg-tertiary);transform:translate(4px)}.upgrade-item:hover:not(.locked):not(.purchased):before{background:var(--color-accent-primary)}.upgrade-item.locked{opacity:.4;cursor:not-allowed;filter:grayscale(.8)}.upgrade-item.purchased{border-color:#00ff884d;background:#00ff880d}.upgrade-item.purchased:before{background:var(--color-accent-green)}.upgrade-icon{width:44px;height:44px;border-radius:var(--radius-md);background:var(--color-bg-tertiary);display:flex;align-items:center;justify-content:center;font-size:1.4rem;box-shadow:var(--shadow-sm);flex-shrink:0}.upgrade-item.purchased .upgrade-icon{background:var(--color-accent-green);color:var(--color-bg-primary)}.upgrade-info{flex:1}.upgrade-name{font-family:var(--font-display);font-size:.9rem;font-weight:700;margin-bottom:2px;color:var(--color-text-primary)}.upgrade-desc{font-size:.75rem;color:var(--color-text-secondary);line-height:1.3}.upgrade-cost{font-family:var(--font-display);font-size:.85rem;font-weight:700;color:var(--color-accent-gold);background:#ffd7001a;padding:4px 8px;border-radius:var(--radius-sm);border:1px solid rgba(255,215,0,.2);transition:all .2s ease}.upgrade-cost.affordable{color:var(--color-accent-green);background:#00ff881a;border-color:#00ff884d;box-shadow:0 0 10px #0f83}.purchased .upgrade-cost{color:var(--color-accent-green);background:#00ff8826;border-color:#0f86}.upgrade-flavor{font-size:.65rem;color:var(--color-text-muted);font-style:italic;margin-top:4px;line-height:1.2}.milestone-badge{font-size:.8rem;margin-left:8px;vertical-align:middle;filter:drop-shadow(0 0 5px var(--color-accent-gold))}.event-banner{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--gradient-gold);color:var(--color-bg-primary);position:fixed;bottom:0;left:0;right:0;transform:translateY(0);transition:transform var(--transition-slow);z-index:200}.event-banner.hidden{transform:translateY(100%)}.event-icon{font-size:2rem;animation:bounce .6s ease infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.event-content{flex:1}.event-title{font-family:var(--font-display);font-size:1rem;font-weight:700}.event-description{font-size:.8rem;opacity:.9}.event-timer{font-family:var(--font-display);font-size:1.2rem;font-weight:700}.footer-nav{display:flex;justify-content:space-around;align-items:center;background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-top:1px solid var(--glass-border);padding:var(--spacing-xs) 0;position:fixed;bottom:0;left:0;right:0;width:100%;z-index:9999!important;pointer-events:auto!important}.nav-item{display:flex;flex-direction:column;align-items:center;gap:2px;padding:var(--spacing-xs) var(--spacing-sm);background:transparent;border:none;color:var(--color-text-muted);cursor:pointer;transition:var(--transition-fast);flex:1;max-width:100px}.nav-item:hover{color:var(--color-text-secondary)}.nav-item.active{color:var(--color-accent-primary)}.nav-item.active .nav-icon{transform:scale(1.1)}.nav-icon{font-size:1.5rem;transition:var(--transition-fast)}.nav-label{font-size:.65rem;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.page-container{flex:1;overflow:hidden;position:relative;padding-bottom:60px}.page{display:none;position:absolute;inset:0;overflow-y:auto;overflow-x:hidden;padding-bottom:100px;animation:fadeIn .3s ease;-webkit-overflow-scrolling:touch}.page.active{display:block}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.page-content{padding:var(--spacing-sm) var(--spacing-md);padding-bottom:20px;display:flex;flex-direction:column;gap:var(--spacing-sm)}.production-lines-grid{display:flex;flex-direction:column;gap:var(--spacing-sm)}.market-page-container{display:flex;flex-direction:column;gap:var(--spacing-lg)}.market-stats-container{background:var(--gradient-card);border-radius:var(--radius-lg);padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--glass-border)}.market-price-cards{display:flex;flex-direction:column;gap:var(--spacing-md)}.price-card{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--color-bg-secondary);border-radius:var(--radius-md);border:1px solid var(--glass-border);transition:var(--transition-normal)}.price-card:hover{border-color:var(--color-accent-primary);box-shadow:var(--shadow-glow-cyan)}.price-card.hbm .price-card-icon{background:var(--gradient-hbm)}.price-card.nand .price-card-icon{background:var(--gradient-nand)}.price-card-icon{width:48px;height:48px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:1.5rem}.price-card-info{flex:1}.price-card-label{display:block;font-size:.75rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px}.price-card-value{font-family:var(--font-display);font-size:1.5rem;font-weight:700;color:var(--color-accent-green)}.price-card-trend{font-size:1.5rem;font-weight:700;padding:var(--spacing-xs)}.price-card-trend.up{color:var(--color-accent-green)}.price-card-trend.down{color:var(--color-accent-red)}.upgrades-page-container{background:var(--gradient-card);border-radius:var(--radius-lg);padding:var(--spacing-md);border:1px solid var(--glass-border);flex:1}.upgrades-page-container .upgrades-list{max-height:calc(100vh - 320px)}.settings-page-container{display:flex;flex-direction:column;gap:var(--spacing-lg)}.settings-section{background:var(--gradient-card);border-radius:var(--radius-lg);padding:var(--spacing-lg);border:1px solid var(--glass-border)}.settings-section.danger{border-color:#ff44664d}.settings-section-title{font-family:var(--font-display);font-size:1rem;font-weight:700;margin-bottom:var(--spacing-md);color:var(--color-text-primary)}.settings-buttons{display:flex;gap:var(--spacing-md);flex-wrap:wrap}.settings-btn{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);background:var(--gradient-primary);border:none;border-radius:var(--radius-md);color:var(--color-bg-primary);font-weight:600;font-size:.9rem;cursor:pointer;transition:var(--transition-normal);flex:1;justify-content:center;min-width:140px}.settings-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-glow-cyan)}.settings-btn:active{transform:translateY(0)}.settings-btn.save-btn{background:linear-gradient(135deg,#0f8,#00d4ff)}.settings-btn.load-btn{background:linear-gradient(135deg,#7b5cff,#00d4ff)}.settings-btn.danger-btn{background:linear-gradient(135deg,#f46,#f80)}.btn-icon{font-size:1.2rem}.settings-hint{font-size:.75rem;color:var(--color-text-muted);margin-top:var(--spacing-sm)}.settings-hint.danger{color:var(--color-accent-red)}.settings-option{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm) 0;border-bottom:1px solid var(--glass-border)}.settings-option:last-child{border-bottom:none}.option-label{font-size:.9rem;color:var(--color-text-secondary)}.toggle-switch{position:relative;display:inline-block;width:50px;height:28px}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;inset:0;background-color:var(--color-bg-tertiary);transition:var(--transition-normal);border-radius:28px;border:1px solid var(--glass-border)}.toggle-slider:before{position:absolute;content:"";height:20px;width:20px;left:4px;bottom:3px;background-color:var(--color-text-muted);transition:var(--transition-normal);border-radius:50%}.toggle-switch input:checked+.toggle-slider{background:var(--gradient-primary);border-color:transparent}.toggle-switch input:checked+.toggle-slider:before{transform:translate(22px);background-color:var(--color-bg-primary)}.about-info{text-align:center;padding:var(--spacing-md)}.about-info p{margin-bottom:var(--spacing-xs)}.about-info .version{font-size:.8rem;color:var(--color-text-muted)}.about-info .credits{font-size:.85rem;color:var(--color-text-secondary)}.settings-btn.help-btn{background:linear-gradient(135deg,gold,#ff8c00)}.modal-overlay{position:fixed;inset:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:2000;padding:var(--spacing-md);opacity:1;transition:opacity .3s ease}.modal-overlay.hidden{opacity:0;pointer-events:none}.modal-content{background:var(--gradient-card);border:1px solid var(--glass-border);border-radius:var(--radius-xl);max-width:500px;width:100%;max-height:85vh;overflow:hidden;display:flex;flex-direction:column;animation:modalSlideIn .3s ease}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-lg);border-bottom:1px solid var(--glass-border);background:#00d4ff1a}.modal-header h2{font-family:var(--font-display);font-size:1.2rem;font-weight:700;color:var(--color-accent-primary);margin:0}.modal-close{background:none;border:none;color:var(--color-text-muted);font-size:2rem;cursor:pointer;line-height:1;padding:0;transition:var(--transition-fast)}.modal-close:hover{color:var(--color-accent-primary)}.modal-body{padding:var(--spacing-lg);overflow-y:auto;flex:1}.tutorial-section{margin-bottom:var(--spacing-lg)}.tutorial-section:last-child{margin-bottom:0}.tutorial-section h3{font-family:var(--font-display);font-size:.95rem;font-weight:700;margin-bottom:var(--spacing-sm);color:var(--color-accent-secondary)}.tutorial-section p{font-size:.9rem;color:var(--color-text-secondary);line-height:1.6}.tutorial-section ul{list-style:none;padding:0}.tutorial-section li{font-size:.85rem;color:var(--color-text-secondary);padding:var(--spacing-xs) 0;padding-left:var(--spacing-md);position:relative}.tutorial-section li:before{content:"▸";position:absolute;left:0;color:var(--color-accent-primary)}.tutorial-section strong{color:var(--color-accent-primary)}.highlight-gold{color:var(--color-accent-gold);font-weight:600}.modal-footer{padding:var(--spacing-lg);border-top:1px solid var(--glass-border);display:flex;justify-content:center}.modal-btn{padding:var(--spacing-md) var(--spacing-xl);border:none;border-radius:var(--radius-md);font-weight:700;font-size:1rem;cursor:pointer;transition:var(--transition-normal)}.modal-btn.primary{background:var(--gradient-primary);color:var(--color-bg-primary)}.modal-btn.primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-glow-cyan)}.modal-btn.secondary{background:var(--color-bg-tertiary);color:var(--color-text-primary);border:1px solid var(--glass-border);margin-right:var(--spacing-md)}.modal-btn.secondary:hover{background:#ffffff1a}.modal-body-content{color:var(--color-text-secondary);line-height:1.6;font-size:1rem}.modal-body-content strong{color:var(--color-accent-gold)}@media(min-width:768px){.game-header{padding:var(--spacing-md) var(--spacing-lg)}.logo h1{font-size:1.5rem}.stat-value{font-size:1.1rem}.game-main{flex-direction:row;padding:var(--spacing-md)}.fab-floor-section{flex:1}.production-section{width:300px}.market-upgrades-section{width:280px}#price-ticker-canvas{height:220px}}@media(min-width:1200px){.game-main{padding:var(--spacing-lg);gap:var(--spacing-md)}.production-section{width:350px}.market-upgrades-section{width:320px}#price-ticker-canvas{height:260px}.upgrades-list{max-height:400px}}#page-fab-floor{background:var(--color-bg-primary);z-index:500}.fab-floor-detail-container{display:flex;flex-direction:column;min-height:100%;padding:var(--spacing-sm);padding-bottom:40px}.fab-detail-header{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-md);padding:var(--spacing-sm) 0;border-bottom:1px solid var(--glass-border)}.fab-detail-header h2{font-family:var(--font-display);font-size:1.1rem;color:var(--color-accent-primary);text-transform:uppercase}.back-btn{background:var(--color-bg-tertiary);border:1px solid var(--glass-border);color:var(--color-text-primary);padding:8px 16px;border-radius:var(--radius-md);cursor:pointer;display:flex;align-items:center;gap:8px;font-size:.85rem;transition:var(--transition-fast)}.back-btn:hover{background:var(--color-bg-secondary);border-color:var(--color-accent-primary)}.fab-detail-content{flex:1;display:flex;flex-direction:column;gap:var(--spacing-md)}.detailed-canvas-container{flex:1;min-height:250px;background:#0d1220;border:1px solid var(--glass-border);border-radius:var(--radius-lg);overflow:hidden;position:relative}#fab-canvas{width:100%;height:100%;display:block}.fab-status-panel{background:var(--gradient-card);padding:var(--spacing-md);border-radius:var(--radius-lg);border:1px solid var(--glass-border);display:flex;flex-wrap:wrap;gap:var(--spacing-lg)}.status-item{flex:1;min-width:150px}.status-item .label{display:block;font-size:.7rem;color:var(--color-text-muted);text-transform:uppercase;margin-bottom:4px}.status-item .value{font-family:var(--font-display);font-size:1rem;font-weight:700}.state-active{color:var(--color-accent-green);text-shadow:0 0 10px rgba(0,255,136,.3)}.mini-progress-bg{height:10px;background:var(--color-bg-primary);border-radius:5px;margin-top:8px;overflow:hidden}.mini-progress-bar{height:100%;width:0%;background:var(--gradient-primary);transition:width .1s linear}.page.active{display:block!important}.horizontal.detail-view .detail-label{position:absolute;top:-30px;font-size:.6rem;color:var(--color-text-muted);white-space:nowrap;text-transform:uppercase;font-weight:700;letter-spacing:.5px}.horizontal.detail-view .pipeline-stage.active .detail-label{color:var(--color-accent-primary)}.info-banner{background:#00d4ff1a;border-left:4px solid var(--color-accent-primary);padding:var(--spacing-sm) var(--spacing-md);margin-bottom:var(--spacing-md);border-radius:4px;display:flex;align-items:center;gap:var(--spacing-sm);font-size:.85rem;line-height:1.4}.upgrade-explanation{display:grid;grid-template-columns:1fr;gap:12px;background:var(--color-bg-secondary);padding:var(--spacing-md);border-radius:12px;margin-bottom:var(--spacing-lg);border:1px solid var(--glass-border);box-shadow:0 4px 20px #0006;max-width:100%}.explanation-item{display:flex;align-items:center;gap:8px;color:var(--color-text-secondary);font-size:.85rem}.upgrade-tabs-container{width:100%;background:var(--color-bg-tertiary);border-radius:10px;padding:4px;margin-bottom:var(--spacing-md);border:1px solid var(--glass-border)}.upgrade-categories{display:flex;flex-direction:column;width:100%;gap:4px}.upgrade-tab{flex:1;padding:12px;border:none;background:transparent;color:var(--color-text-muted);font-family:var(--font-display);font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;cursor:pointer;transition:all .2s ease;border-radius:6px}.upgrade-tab.active{background:var(--gradient-primary);color:#000;box-shadow:var(--shadow-glow-cyan)}.explanation-item strong{color:var(--color-accent-primary);white-space:nowrap}.pipeline-visualizer::-webkit-scrollbar{height:8px;display:block}.pipeline-visualizer::-webkit-scrollbar-track{background:#ffffff0d;border-radius:4px}.pipeline-visualizer::-webkit-scrollbar-thumb{background:var(--gradient-primary);border-radius:4px}.detailed-canvas-container{min-height:200px;flex:1;background:#0006;border-radius:12px;overflow:hidden;border:1px solid var(--glass-border)}.contracts-page-container{display:flex;flex-direction:column;gap:var(--spacing-lg);padding:0 5px}.contracts-section{display:flex;flex-direction:column;gap:var(--spacing-md)}.contracts-section-title{font-family:var(--font-display);font-size:1.1rem;font-weight:700;color:var(--color-text-primary);display:flex;align-items:center;gap:8px}.section-title-with-btn{display:flex;justify-content:space-between;align-items:center}.refresh-contracts-btn{background:var(--color-bg-secondary);border:1px solid var(--glass-border);color:var(--color-text-secondary);padding:4px 12px;border-radius:var(--radius-md);font-size:.8rem;cursor:pointer;transition:all .2s ease}.refresh-contracts-btn:hover{background:var(--color-bg-tertiary);color:var(--color-text-primary);border-color:var(--color-accent-primary)}.contracts-list{display:grid;grid-template-columns:1fr;gap:var(--spacing-md)}.contract-card{background:var(--color-bg-secondary);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:var(--spacing-md);position:relative;overflow:hidden;transition:transform .2s ease}.active-contract{border-left:4px solid var(--color-accent-primary)}.available-contract{border-left:4px solid var(--color-accent-gold)}.contract-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-md)}.client-name{font-family:var(--font-display);font-weight:700;font-size:1rem;color:var(--color-text-primary)}.client-flavor{font-size:.7rem;color:var(--color-text-muted)}.contract-type,.contract-badge{font-size:.7rem;font-weight:700;background:#ffffff0d;padding:2px 8px;border-radius:4px}.contract-timer{font-family:var(--font-display);font-size:.9rem;font-weight:700;color:var(--color-accent-primary)}.contract-timer.urgent{color:#ff4d4d;animation:pulse-red 1s infinite}.contract-progress-container{margin-bottom:var(--spacing-sm)}.progress-labels{display:flex;justify-content:space-between;font-size:.75rem;margin-bottom:4px;color:var(--color-text-secondary)}.contract-progress-bar{height:8px;background:#ffffff1a;border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--color-accent-primary),var(--color-accent-secondary));transition:width .3s ease}.contract-profit,.contract-payout{font-family:var(--font-display);font-size:.85rem;font-weight:700;color:var(--color-accent-green);text-align:right}.contract-details{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:var(--spacing-md)}.detail{font-size:.75rem;color:var(--color-text-secondary)}.detail span{color:var(--color-text-muted)}.detail.payout{grid-column:span 2;font-size:.9rem;padding-top:4px;border-top:1px solid rgba(255,255,255,.05)}.accept-btn{width:100%;background:var(--color-accent-gold);color:#000;border:none;padding:10px;border-radius:var(--radius-md);font-weight:700;font-size:.9rem;cursor:pointer;transition:all .2s ease}.accept-btn:hover{transform:translateY(-2px);filter:brightness(1.1);box-shadow:0 4px 15px #ffd7004d}.no-contracts{text-align:center;padding:var(--spacing-xl);background:#0003;border-radius:var(--radius-lg);color:var(--color-text-muted);font-style:italic;font-size:.85rem}.contracts-explanation{background:var(--color-bg-secondary);padding:var(--spacing-md);border-radius:var(--radius-lg);border:1px solid var(--glass-border);display:flex;flex-direction:column;gap:12px}@keyframes pulse-red{0%{opacity:1}50%{opacity:.5}to{opacity:1}}@media(min-width:768px){.contracts-list{grid-template-columns:1fr 1fr}}
