html,body,#root{height:100%;margin:0}:root{--bg:#0a0a0a;--card-bg:#161616;--card-bg-2:#1f1f1f;--border:#2a2a2a;--border-strong:#3a3a3a;--text:#f5f5f5;--muted:#888;--accent:#f59e0b;--accent-bright:#fbbf24;--accent-dark:#b45309;--warn:#ef4444;--header-bg:#0a0a0a;--tab-bg:#0a0a0a;--tab-active:#f59e0b}*{box-sizing:border-box}html,body{background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Hiragino Sans,Yu Gothic UI,Segoe UI,sans-serif}.app{background:var(--bg);flex-direction:column;height:100dvh;display:flex;overflow:hidden}.header{background:var(--header-bg);flex:none;justify-content:center;align-items:center;padding:14px 16px 8px;display:flex}.header-icon{display:none}.header-title{text-align:center}.header-jp{color:var(--text);letter-spacing:.5px;font-size:20px;font-weight:700}.header-en{color:var(--muted);letter-spacing:1px;margin-top:1px;font-size:11px}.fixed-top{flex-direction:column;flex:none;gap:10px;width:100%;max-width:720px;margin:0 auto;padding:8px 14px 0;display:flex}.scroll-area{-webkit-overflow-scrolling:touch;flex-direction:column;flex:auto;gap:12px;width:100%;max-width:720px;min-height:0;margin:0 auto;padding:10px 14px 24px;display:flex;overflow-y:auto}.placeholder{background:var(--card-bg);text-align:center;color:var(--muted);border-radius:12px;padding:40px 16px}.result-card{background:var(--card-bg);border-radius:12px;align-items:stretch;gap:14px;padding:14px 16px;display:flex}.result-left{border:1.5px solid var(--accent);border-radius:10px;flex-direction:column;flex:none;justify-content:center;padding:8px 14px;display:flex}.result-label{color:var(--text);margin-bottom:2px;font-size:12px}.result-percent{color:var(--accent-bright);align-items:baseline;display:flex}.result-num{letter-spacing:-1px;font-size:38px;font-weight:700;line-height:1}.result-pct{margin-left:4px;font-size:18px;font-weight:600}.result-right{flex:1;align-items:center;gap:14px;display:flex}.result-metric{text-align:left;flex:1}.metric-title{color:var(--muted);margin-bottom:3px;font-size:11px}.metric-value{color:var(--text);font-size:24px;font-weight:600;line-height:1}.metric-unit{color:var(--muted);margin-top:2px;font-size:11px}.metric-divider{display:none}.scene-card{background:var(--card-bg);border-radius:12px;height:clamp(280px,42vh,420px);padding:0;position:relative;overflow:hidden}.scene-container{width:100%;height:100%;position:relative}.scene-container canvas{display:block;width:100%!important;height:100%!important}.color-legend{color:var(--text);font-variant-numeric:tabular-nums;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#141414b3;border-radius:8px;flex-direction:column;gap:4px;padding:8px;font-size:10px;display:flex;position:absolute;top:10px;bottom:10px;right:10px}.legend-unit{text-align:right;color:var(--muted);font-size:10px;font-weight:500}.legend-strip-row{flex:1;align-items:stretch;gap:4px;display:flex}.legend-strip{border:.5px solid var(--border-strong);background:linear-gradient(#a50026 0%,#f46d43 18%,#fdae61 35%,#ffffbf 50%,#abd9e9 65%,#4575b4 82%,#313695 100%);border-radius:3px;width:12px}.legend-ticks{color:var(--text);flex-direction:column;justify-content:space-between;font-size:9px;display:flex}.legend-tick{line-height:1}.viewer-controls{pointer-events:none;flex-direction:column;gap:6px;display:flex;position:absolute;top:10px;left:10px}.viewer-btn{pointer-events:auto;border:1px solid var(--border-strong);width:32px;height:32px;color:var(--accent-bright);cursor:pointer;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#141414b3;border-radius:8px;margin:0;padding:0;font-size:16px;font-weight:600}.viewer-btn:hover{background:#282828e6}.viewer-hint{color:var(--muted);pointer-events:none;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#14141499;border-radius:6px;flex-direction:column;gap:2px;padding:4px 8px;font-size:10px;display:flex}@media (width<=480px){.viewer-hint{display:none}}.legend-control{background:var(--card-bg);border-radius:12px;flex-direction:column;gap:6px;padding:10px 14px;font-size:12px;display:flex}.legend-control-row{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.legend-control-label{color:var(--muted);min-width:60px;font-size:11px}.legend-control-value{color:var(--accent-bright);font-variant-numeric:tabular-nums;font-size:16px;font-weight:600}.legend-control-unit-inline{color:var(--muted);font-size:11px;font-weight:400}.legend-control-unit{color:var(--muted);font-size:11px}.legend-input-group{flex:1;align-items:center;gap:4px;min-width:0;display:flex}.legend-input-group>span{color:var(--muted);font-size:11px}.legend-input-group input{background:var(--card-bg-2);border:1px solid var(--border);min-width:0;color:var(--text);font-variant-numeric:tabular-nums;border-radius:6px;flex:1;padding:5px 8px;font-size:12px}.legend-reset-btn{color:var(--accent);border:1px solid var(--accent);cursor:pointer;background:0 0;border-radius:6px;margin:0 0 0 auto;padding:3px 10px;font-size:11px}.card{background:var(--card-bg);border-radius:12px;grid-template-rows:auto auto;grid-template-columns:28px 1fr;align-items:start;gap:8px 12px;padding:14px 16px;display:grid}.card-icon{background:var(--accent);color:#000;border-radius:6px;grid-area:1/1/3/2;justify-content:center;align-items:center;width:26px;height:26px;font-size:15px;font-weight:700;display:flex}.card-title{color:var(--text);grid-column:2/3;font-size:14px;font-weight:600}.card-fields{flex-wrap:wrap;grid-column:2/3;align-items:center;gap:10px;display:flex}.card-hint{color:var(--muted);grid-column:2/3;margin-top:4px;font-size:11px}.field{flex-direction:column;flex:auto;gap:4px;min-width:100px;display:flex}.field.full{flex:100%}.field-label{color:var(--muted);font-size:11px}.field input,.field select{background:var(--card-bg-2);border:1px solid var(--border);width:100%;color:var(--text);font-variant-numeric:tabular-nums;border-radius:8px;padding:9px 10px;font-size:14px}.field input:focus,.field select:focus{border-color:var(--accent);outline:2px solid #f59e0b33}.field select{cursor:pointer}.toggle-group{background:var(--card-bg-2);border-radius:8px;gap:6px;width:100%;padding:4px;display:flex}.toggle{color:var(--muted);cursor:pointer;background:0 0;border:0;border-radius:6px;flex:1;margin:0;padding:8px 0;font-size:13px;font-weight:500}.toggle.active{background:var(--accent);color:#000}.action-btn{background:var(--accent);color:#000;cursor:pointer;text-align:center;border:0;border-radius:8px;flex:100%;justify-content:center;align-items:center;gap:6px;margin:0;padding:10px 12px;font-size:13px;font-weight:600;display:flex}.action-btn:disabled{opacity:.5;cursor:not-allowed}.action-btn:hover{background:var(--accent-bright)}.apply-btn{color:var(--accent);border:1px dashed var(--accent);cursor:pointer;background:0 0;border-radius:8px;grid-column:2/3;margin:4px 0 0;padding:6px 10px;font-size:12px}.err{color:var(--warn);grid-column:2/3;margin:4px 0 0;font-size:11px}.tilt-row{flex:100%;align-items:center;gap:10px;display:flex}.tilt-slider{accent-color:var(--accent);flex:1}.tilt-num{flex:0 0 70px}.field-hint{color:var(--muted);margin-left:4px;font-size:11px}.tabs{background:var(--tab-bg);border-top:1px solid var(--border);padding:4px 0 calc(4px + env(safe-area-inset-bottom));flex:none;display:flex}.tab{color:var(--muted);cursor:pointer;background:0 0;border:0;flex-direction:column;flex:1;align-items:center;gap:2px;margin:0;padding:6px 0;font-size:11px;display:flex}.tab.active{color:var(--tab-active)}.tab-icon{font-size:18px;line-height:1}.tab-label{line-height:1}.viewer-hint-bottom{color:var(--muted);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);pointer-events:none;white-space:nowrap;background:#14141499;border-radius:6px;padding:4px 10px;font-size:10px;position:absolute;bottom:8px;right:80px}.viewer-hint{display:none}.iframe-wrap{background:var(--card-bg);flex:auto;min-height:0;display:flex}.detail-iframe{background:#fff;border:0;flex:1;width:100%;height:100%}.result-card{gap:10px;padding:8px 12px}.result-left{border-width:1px;padding:4px 10px}.result-label{margin-bottom:0;font-size:10px}.result-num{font-size:28px}.result-pct{font-size:14px}.result-right{border-left:0;gap:10px;padding-left:0}.metric-title{margin-bottom:1px;font-size:10px}.metric-value{font-size:18px}.metric-unit{margin-top:1px;font-size:9px}.scene-card{height:clamp(240px,36vh,360px)}.header{padding:8px 16px 4px}.header-jp{font-size:17px}.header-en{font-size:10px}.spin-input{background:var(--card-bg-2);border:1px solid var(--border);-webkit-user-select:none;user-select:none;touch-action:none;border-radius:8px;align-items:stretch;gap:0;display:flex;overflow:hidden}.spin-btn{color:var(--accent);cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:0;min-width:36px;margin:0;padding:0 12px;font-size:18px;font-weight:700}.spin-btn:active{background:#f59e0b26}.spin-value{text-align:center;color:var(--text);cursor:ns-resize;font-variant-numeric:tabular-nums;background:0 0;border:0;flex:1;justify-content:center;align-items:center;min-width:0;padding:8px 4px;font-size:14px;font-weight:600;display:flex}.spin-value-edit{cursor:text;outline:2px solid #f59e0b4d}.spin-input:focus-within{border-color:var(--accent)}
