:root{--bg: #1c2634;--bg-panel: #243040;--fg: #e8edf4;--fg-muted: #9aa8b8;--accent: #3d9eff;--accent-hover: #5eb0ff;--border: #2a3544;--product-showcase-bg: #202020;--product-showcase-border: #202020;--error: #ff6b6b;--success: #4ade80;font-family:Segoe UI,system-ui,sans-serif;color:var(--fg);background:var(--bg)}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{width:100%;height:100%;overflow:hidden}button{font:inherit;cursor:pointer;border:none;border-radius:6px;padding:.6rem 1rem;background:var(--accent);color:var(--bg);font-weight:600}button:hover{background:var(--accent-hover)}button:focus-visible{outline:2px solid var(--accent);outline-offset:2px}button.secondary{background:transparent;color:var(--fg);border:1px solid var(--border)}.panel{background:var(--bg-panel);border:1px solid var(--border);border-radius:8px;padding:1rem 1.25rem;box-shadow:0 8px 32px #00000073}.panel h2{font-size:1.15rem;margin-bottom:.5rem;color:var(--fg)}.panel p,.panel li{font-size:.9rem;line-height:1.5;color:var(--fg-muted)}.panel .placeholder{color:var(--fg-muted);font-style:italic}.panel ul{margin:.5rem 0 0 1.1rem}.error-banner{background:#ff6b6b26;border:1px solid var(--error);color:var(--error);padding:.75rem 1rem;border-radius:6px;font-size:.85rem}.loading-overlay{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--bg);z-index:100;gap:1rem}.spinner{width:48px;height:48px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@keyframes explode{0%{transform:translate(0);opacity:.6}to{opacity:1}}.locale-block{max-width:480px;text-align:center;padding:2rem}.app-layout{display:flex;width:100%;height:100%}.rack-canvas-wrap{width:100%;height:100%}.rack-canvas-wrap canvas{cursor:grab}.rack-area{position:relative;background:var(--bg);transition:width .45s ease}.rack-area.full{width:100%}.rack-area.split{width:50%}.detail-area{width:50%;height:100%;overflow-y:auto;background:var(--bg-panel);border-left:1px solid var(--border);padding:1rem}.detail-area.overlay{position:fixed;top:0;right:0;bottom:0;left:0;width:100%;z-index:50}.reset-view-btn{font-size:.78rem;padding:.45rem .65rem;width:100%;text-align:center}.rack-controls-br{position:absolute;bottom:1.5rem;right:1.5rem;z-index:10;display:flex;flex-direction:column;align-items:stretch;gap:.6rem;width:clamp(80px,18vmin,140px)}.rack-controls-br .rotation-wheel{position:relative;bottom:auto;right:auto;width:100%;height:auto;aspect-ratio:1}.rack-controls-br .reset-view-btn{position:relative;top:auto;left:auto}.site-intro{position:absolute;top:1rem;left:1rem;z-index:18;max-width:min(420px,calc(100vw - 2rem));max-height:calc(100vh - 2rem);overflow-y:auto}.site-intro-header{display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem;margin-bottom:.65rem}.site-intro h1{font-size:1.05rem;line-height:1.35;color:var(--fg);font-weight:700}.site-intro-close{flex-shrink:0;width:2rem;height:2rem;padding:0;line-height:1;font-size:1.25rem}.site-intro p{margin-top:.55rem}.site-intro p strong,.site-intro li strong{color:var(--fg);font-weight:600}.site-intro ul{margin-top:.65rem}.site-intro-cta{margin-top:.85rem;width:100%}@media(max-width:640px){.site-intro{top:.75rem;left:.75rem;right:.75rem;max-width:none}}.rotation-wheel{position:absolute;bottom:1.5rem;right:1.5rem;width:clamp(80px,18vmin,140px);height:clamp(80px,18vmin,140px);border-radius:50%;border:3px solid var(--border);background:radial-gradient(circle at 30% 30%,#3a4a5e,#243040);touch-action:none;cursor:grab;z-index:10;display:flex;align-items:center;justify-content:center;-webkit-user-select:none;user-select:none}.rotation-wheel:after{content:"";width:8px;height:28px;background:var(--accent);border-radius:4px;transform-origin:center 36px;position:absolute;top:18%}.exploded-grid{display:grid;gap:.75rem;margin-top:1rem}.deconstruction-block{margin-top:.75rem;margin-bottom:1.5rem}.deconstruction-toolbar{margin-bottom:.65rem}.deconstruction-toggle{display:inline-flex;align-items:center;justify-content:center;min-height:2.5rem;padding:.65rem 1.25rem;font-size:.9rem;font-weight:600;letter-spacing:.01em;color:#0a1018;background:linear-gradient(180deg,var(--accent-hover) 0%,var(--accent) 100%);border:1px solid #7ec8ff;border-radius:8px;box-shadow:0 2px #00000059,0 4px 14px #3d9eff59;cursor:pointer;transition:background .15s ease,box-shadow .15s ease,transform .1s ease}.deconstruction-toggle:hover{background:linear-gradient(180deg,#7ec8ff 0%,var(--accent-hover) 100%);box-shadow:0 2px #00000059,0 6px 18px #3d9eff73}.deconstruction-toggle:active{transform:translateY(1px);box-shadow:0 1px #00000059}.deconstruction-toggle:focus-visible{outline:2px solid #fff;outline-offset:2px}.deconstruction-stage.uses-photo .deconstruction-visual,.deconstruction-stage.uses-photo .deconstruction-image-panel,.deconstruction-stage.uses-photo .deconstruction-layer-stack,.deconstruction-stage.uses-photo .deconstruction-layer-slot{background:var(--product-showcase-bg)}.deconstruction-stage.uses-photo .deconstruction-visual{border:none;border-radius:0;box-shadow:none}.deconstruction-stage.uses-photo .deconstruction-layer-stack{gap:0}.deconstruction-image-panel{width:100%;height:100%;display:flex;align-items:center;justify-content:center;padding:0;background:var(--product-showcase-bg)}.deconstruction-photo-assembled{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;display:block;-webkit-user-select:none;user-select:none;pointer-events:none}.deconstruction-layer-stack{display:flex;flex-direction:column;height:100%;gap:.25rem;padding:0;background:var(--product-showcase-bg)}.deconstruction-layer-slot{flex:1 1 0;min-height:0;display:flex;align-items:center;justify-content:center}.deconstruction-layer-img{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;display:block;-webkit-user-select:none;user-select:none;pointer-events:none}.deconstruction-stage{--stage-height: clamp(560px, 62vh, 720px);display:grid;grid-template-columns:1fr;grid-template-rows:1fr;gap:.65rem;height:var(--stage-height);position:relative}.deconstruction-stage.is-deconstructed{grid-template-columns:minmax(0,1.15fr) minmax(300px,.85fr)}.deconstruction-visual{position:relative;height:100%;min-height:0;border:1px solid var(--border);border-radius:8px;overflow:hidden;background:var(--bg)}.deconstruction-visual:focus-visible{outline:none}.deconstruction-phase-label{position:absolute;left:.75rem;bottom:.75rem;padding:.35rem .65rem;border-radius:4px;background:#1c2634d1;border:1px solid var(--border);font-size:.78rem;color:var(--fg-muted);pointer-events:none;z-index:2}.deconstruction-stage.uses-photo .deconstruction-phase-label{background:#202020e0;border-color:#282828;color:#a8a8a8}.deconstruction-cards{display:grid;grid-template-rows:repeat(var(--layer-count, 4),minmax(84px,1fr));gap:.5rem;height:100%;align-content:stretch}.deconstruction-card.subpart-card{padding:.65rem .75rem;min-height:84px;overflow:visible;display:flex;flex-direction:column;justify-content:flex-start;gap:.15rem}.deconstruction-card.subpart-card:before{display:none}.deconstruction-card{opacity:0;transform:translate(8px);transition:opacity .25s ease,transform .25s ease}.deconstruction-card.is-visible{opacity:1;transform:translate(0)}.deconstruction-card strong{font-size:.9rem;line-height:1.3;word-break:break-word}.deconstruction-card-material,.deconstruction-card-function{font-size:.8rem;line-height:1.4;margin-top:.1rem;word-break:break-word}.recovery-section{margin-top:1.25rem}.metal-wheel-section{margin-top:1.5rem;padding:1rem 1.1rem;border:1px solid var(--border);border-radius:8px;background:#0000001f}.metal-wheel-section h3{font-size:1.05rem;margin-bottom:.65rem}.metal-wheel-section p{font-size:.86rem;line-height:1.6;color:var(--fg-muted);margin-top:.55rem}.metal-wheel-section strong{color:var(--fg)}.metal-wheel-score-box{margin-top:.85rem;padding:.75rem .85rem;border-radius:6px;border:1px solid rgba(61,158,255,.25);background:#3d9eff14}.metal-wheel-score-box h4{font-size:.9rem;color:var(--accent);margin-bottom:.4rem}.metal-wheel-score-highlight{margin-top:.55rem!important;color:var(--fg)!important}.metal-wheel-link{display:inline-block;margin-top:.75rem;font-size:.84rem;color:var(--accent)}.recovery-target-metals{margin-top:.75rem}.recovery-streams-intro{font-size:.84rem;line-height:1.55;color:var(--fg-muted);margin-bottom:.65rem}.recovery-stream-method{color:var(--accent)}.strategic-materials-section{margin-top:1.5rem;padding:1rem 1.1rem;border:1px solid var(--border);border-radius:8px;background:#00000024}.strategic-materials-section h3{font-size:1.05rem;margin-bottom:.55rem}.strategic-materials-intro,.strategic-materials-summary{font-size:.86rem;line-height:1.6;color:var(--fg-muted);margin-top:.5rem}.strategic-materials-summary{color:var(--fg);padding:.5rem .65rem;border-radius:6px;background:#3d9eff14;border:1px solid rgba(61,158,255,.2)}.strategic-materials-group{margin-top:1rem}.strategic-materials-group h4{font-size:.9rem;color:var(--accent);margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.04em}.strategic-materials-list{list-style:none;display:grid;gap:.65rem}.strategic-material-card{padding:.75rem .85rem;border:1px solid var(--border);border-radius:6px;background:#ffffff05}.strategic-material-header{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:.4rem;margin-bottom:.5rem}.strategic-material-header strong{color:var(--fg);font-size:.92rem}.strategic-badge{font-size:.68rem;padding:.2rem .45rem;border-radius:4px;text-transform:uppercase;letter-spacing:.03em;font-weight:600}.strategic-badge-typically-recovered{background:#4ade8026;color:var(--success);border:1px solid rgba(74,222,128,.35)}.strategic-badge-partial{background:#ffc1071f;color:#ffc857;border:1px solid rgba(255,193,7,.35)}.strategic-badge-often-lost{background:#ff6b6b1f;color:var(--error);border:1px solid rgba(255,107,107,.35)}.strategic-material-details{display:grid;gap:.35rem}.strategic-material-details div{display:grid;grid-template-columns:minmax(7rem,9rem) 1fr;gap:.5rem;font-size:.82rem;line-height:1.45}.strategic-material-details dt{color:var(--fg-muted);font-weight:500}.strategic-material-details dd{color:var(--fg-muted);margin:0}.strategic-policy-tags{display:flex;flex-wrap:wrap;gap:.35rem;margin-top:.55rem}.strategic-policy-tag{font-size:.68rem;padding:.15rem .4rem;border-radius:4px;background:#3d9eff1f;color:var(--accent);border:1px solid rgba(61,158,255,.25)}.recovery-cost-note{margin-top:.45rem;font-size:.8rem;line-height:1.55;color:var(--fg-muted);font-style:italic}.recovery-alternatives{margin-top:1rem;padding:.85rem 1rem;border:1px solid var(--border);border-radius:8px;background:#0000002e}.recovery-alternatives h4{font-size:.92rem;color:var(--fg);margin-bottom:.55rem}.recovery-alternatives ul{list-style:none;display:grid;gap:.75rem}.recovery-alternatives li{font-size:.84rem;line-height:1.55;color:var(--fg-muted)}.recovery-alternatives strong{color:var(--fg)}.deconstruction-layer-index{display:block;flex-shrink:0;font-size:.7rem;letter-spacing:.05em;text-transform:uppercase;color:var(--accent);margin-bottom:.15rem}.deconstruction-card.is-active{border-color:var(--accent);box-shadow:0 0 0 1px #3d9eff59}@media(max-width:900px){.deconstruction-stage.is-deconstructed{grid-template-columns:1fr;height:auto}.deconstruction-stage.is-deconstructed .deconstruction-visual{height:clamp(360px,45vh,480px)}.deconstruction-cards{grid-template-rows:none;height:auto;overflow:visible}}.subpart-card{background:#2a3848;border:1px solid var(--border);border-radius:6px;padding:.75rem;animation:explode .5s ease forwards;position:relative}.subpart-card:before{content:"";position:absolute;left:-12px;top:50%;width:10px;height:1px;background:var(--accent)}.chip-view{margin-top:1rem;padding:1rem;background:#2a3544;border-radius:8px;border:1px solid var(--accent)}.chip-element{margin:.5rem 0;padding:.5rem;border-left:3px solid var(--accent)}
