:root{color-scheme:light}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{width:100%;height:100%;overflow:hidden;font-family:system-ui,-apple-system,Segoe UI,sans-serif;background:#87ceeb}#app{position:relative;width:100%;height:100%}#app canvas{display:block;width:100%;height:100%;touch-action:none;user-select:none;-webkit-user-select:none}.eq-hud{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.eq-top{position:absolute;top:0;left:0;right:0;display:flex;align-items:center;gap:16px;padding:8px 16px;background:#121622d6;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);pointer-events:auto;z-index:10}.eq-logo{font-size:1rem;font-weight:800;color:#fff}.eq-stat{display:flex;flex-direction:column;align-items:center}.eq-stat-label{font-size:.6rem;color:#9aaccc;text-transform:uppercase;letter-spacing:.08em}.eq-stat span:last-child{font-weight:700;font-size:.92rem;color:#fff}.eq-mode-label{margin-left:auto;font-size:.8rem;font-weight:700;color:#ffd54f;padding:4px 12px;background:#ffd54f1f;border-radius:999px}.eq-toolbar{position:absolute;top:46px;left:0;bottom:0;width:195px;background:#121622e6;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);overflow-y:auto;padding:10px 8px;pointer-events:auto;z-index:10}.eq-toolbar::-webkit-scrollbar{width:4px}.eq-toolbar::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:2px}.eq-cat{margin-bottom:12px}.eq-cat-label{font-size:.6rem;text-transform:uppercase;letter-spacing:.1em;color:#7a8899;font-weight:700;margin-bottom:5px;padding:0 4px}.eq-block-btn{display:flex;align-items:center;gap:7px;width:100%;padding:7px 8px;background:#ffffff0a;border:1px solid rgba(255,255,255,.06);border-radius:8px;color:#ccd4e8;font:inherit;font-size:.78rem;cursor:pointer;transition:background .12s;margin-bottom:3px;text-align:left}.eq-block-btn:hover{background:#ffffff1a;border-color:#ffffff2e}.eq-block-btn--sel{background:#6248ff61;border-color:#8264ff99;color:#fff}.eq-block-swatch{display:inline-block;width:14px;height:14px;border-radius:3px;border:1px solid rgba(255,255,255,.2);flex-shrink:0}.eq-block-name{flex:1}.eq-block-cost{font-size:.7rem;color:#f5c842;font-weight:700}.eq-selected-block{position:absolute;left:205px;bottom:130px;background:#121622d6;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:#ccd4e8;font-size:.82rem;padding:8px 12px;border-radius:8px;pointer-events:none;z-index:9;max-width:260px}.eq-floor-ctrl{position:absolute;left:205px;bottom:76px;display:flex;gap:8px;pointer-events:auto;z-index:10}.eq-actbar{position:absolute;left:205px;bottom:20px;display:flex;gap:8px;pointer-events:auto;z-index:10}.eq-btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;border-radius:8px;padding:8px 14px;font:inherit;font-size:.82rem;font-weight:700;cursor:pointer;background:#ffffff1f;color:#fff;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);transition:background .15s}.eq-btn:hover{background:#ffffff38}.eq-btn-sm{padding:6px 10px;font-size:.76rem}.eq-btn-primary{background:#6248ff}.eq-btn-primary:hover{background:#7a5cff}.eq-btn-danger{background:#dc3232a6}.eq-btn-remove{background:#c87800a6}.eq-btn-remove--active{background:#dc3232d9;box-shadow:0 0 0 2px #f44}.eq-quake-panel{position:absolute;right:16px;top:56px;width:240px;background:#121622e6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:14px 16px;pointer-events:auto;z-index:10}.eq-quake-panel h3{color:#f5c842;font-size:.9rem;margin-bottom:10px}.eq-mag-label{font-size:.78rem;color:#9aaccc;display:block;margin-bottom:6px}.eq-range{width:100%;margin-bottom:12px;accent-color:#6248ff}#eq-mag-val{color:#fff;font-weight:700}.eq-modal{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;background:#080c16b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);pointer-events:auto;z-index:50;overflow-y:auto}.eq-modal[hidden]{display:none!important}.eq-modal-card{width:min(500px,92vw);background:#121624f7;border:1px solid rgba(255,255,255,.1);border-radius:18px;padding:26px 22px;color:#ccd4e8;box-shadow:0 24px 80px #00000080;max-height:92vh;overflow-y:auto}.eq-modal-card h2{font-size:1.2rem;color:#fff;margin-bottom:14px}.eq-grade{font-size:3rem;font-weight:900;text-align:center;margin:10px 0}.eq-grade--S{color:gold}.eq-grade--A{color:#4caf50}.eq-grade--B{color:#8bc34a}.eq-grade--C{color:#ff9800}.eq-grade--D{color:#ff5722}.eq-grade--F{color:#f44336}.eq-result-msg{font-size:.95rem;color:#b8c8e4;margin-bottom:14px}.eq-result-stats{display:flex;gap:16px;margin-bottom:14px;font-size:.88rem;flex-wrap:wrap}.eq-result-stats div{color:#ccd4e8}.eq-result-stats strong{color:#fff}.eq-score-bar{height:10px;background:#ffffff1a;border-radius:5px;margin-bottom:14px;overflow:hidden}.eq-score-fill{height:100%;border-radius:5px;transition:width 1s ease}.eq-tips{background:#6248ff1f;border-left:3px solid #6248ff;border-radius:0 8px 8px 0;padding:10px 14px;margin-bottom:16px}.eq-tips p{font-size:.8rem;color:#a8b8d8;margin-bottom:5px}.eq-tips p:last-child{margin-bottom:0}.eq-fly-badge{position:absolute;top:50px;left:50%;transform:translate(-50%);background:#0078ffd9;color:#fff;font-size:.8rem;font-weight:700;padding:6px 16px;border-radius:999px;pointer-events:none;z-index:20;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.eq-toolbar-toggle,.eq-mobile-cross,.eq-mobile-bar,.eq-mobile-floor,.eq-mobile-sheet{display:none}#free-hud{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.fh-top{position:absolute;top:0;left:0;right:0;display:flex;align-items:center;gap:14px;padding:7px 16px;background:#0e121ee0;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);pointer-events:auto;z-index:10}.fh-logo{font-size:.95rem;font-weight:800;color:#fff}#fh-cost{font-size:.88rem;font-weight:700;color:#f5c842}#fh-count{font-size:.82rem;color:#9aaccc}.fh-mode{margin-left:auto;font-size:.78rem;font-weight:700;color:#ffd54f;padding:3px 10px;background:#ffd54f1f;border-radius:999px}.fh-toolbar{position:absolute;top:42px;left:0;bottom:60px;width:200px;background:#0e121eeb;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);overflow-y:auto;padding:8px;pointer-events:auto;z-index:10}.fh-toolbar::-webkit-scrollbar{width:4px}.fh-toolbar::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:2px}.fh-tool-btn{display:flex;align-items:center;gap:7px;width:100%;padding:7px 8px;background:#ffffff0a;border:1px solid rgba(255,255,255,.06);border-radius:8px;color:#ccd4e8;font:inherit;font-size:.76rem;cursor:pointer;text-align:left;margin-bottom:3px;transition:background .12s}.fh-tool-btn:hover{background:#ffffff1a}.fh-tool-btn--sel{background:#6248ff61;border-color:#8264ff99;color:#fff}.fh-swatch{display:inline-block;width:13px;height:13px;border-radius:3px;border:1px solid rgba(255,255,255,.2);flex-shrink:0}.fh-tlabel{flex:1}.fh-actions{position:absolute;bottom:0;left:0;right:0;display:flex;align-items:center;gap:8px;padding:8px 14px;background:#0e121ee0;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);pointer-events:auto;z-index:10;flex-wrap:wrap}.fh-sep{width:1px;height:24px;background:#ffffff26;margin:0 4px}.fh-mag-label{font-size:.75rem;color:#9aaccc}#fh-mag-val{color:#fff;font-weight:700}.fh-range{accent-color:#6248ff;width:90px}.fh-btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;border-radius:8px;padding:7px 12px;font:inherit;font-size:.8rem;font-weight:700;cursor:pointer;background:#ffffff1f;color:#fff;transition:background .15s}.fh-btn:hover{background:#ffffff38}.fh-danger{background:#dc3232a6}.fh-primary{background:#6248ff}.fh-primary:hover{background:#7a5cff}.fh-result{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;background:#080c16b8;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);pointer-events:auto;z-index:50;overflow-y:auto}.fh-result[hidden]{display:none!important}.fh-result-card{width:min(480px,92vw);background:#101420f7;border:1px solid rgba(255,255,255,.1);border-radius:18px;padding:24px 20px;color:#ccd4e8;box-shadow:0 24px 80px #00000080;max-height:90vh;overflow-y:auto}.fh-result-card h2{font-size:1.1rem;color:#fff;margin-bottom:12px}.fh-grade{font-size:2.8rem;font-weight:900;text-align:center;margin:8px 0}.fh-grade--S{color:gold}.fh-grade--A{color:#4caf50}.fh-grade--B{color:#8bc34a}.fh-grade--C{color:#ff9800}.fh-grade--D{color:#ff5722}.fh-grade--F{color:#f44336}.fh-rmsg{font-size:.9rem;color:#b8c8e4;margin-bottom:12px}.fh-rstats{display:flex;gap:14px;margin-bottom:12px;font-size:.85rem;flex-wrap:wrap}.fh-rstats div{color:#ccd4e8}.fh-rstats strong{color:#fff}.fh-rbar{height:10px;background:#ffffff1a;border-radius:5px;margin-bottom:12px;overflow:hidden}.fh-rbar div{height:100%;border-radius:5px;transition:width 1s}.fh-tips{background:#6248ff1f;border-left:3px solid #6248ff;border-radius:0 8px 8px 0;padding:9px 12px;margin-bottom:14px}.fh-tips p{font-size:.78rem;color:#a8b8d8;margin-bottom:4px}.fh-group-label{font-size:.6rem;text-transform:uppercase;letter-spacing:.1em;color:#7a8899;font-weight:700;margin:8px 0 4px 4px}position:absolute; top:48px; left:50%; transform:translateX(-50%); background:rgba(0,120,255,.85); color:#fff; font-size:.78rem; font-weight:700; padding:6px 14px; border-radius:999px; pointer-events:none; z-index:20; backdrop-filter:blur(4px); } .eq-mobile .eq-top{padding:5px 10px;gap:8px}.eq-mobile .eq-logo{font-size:.82rem}.eq-mobile .eq-stat-label{font-size:.54rem}.eq-mobile .eq-stat span:last-child{font-size:.78rem}.eq-mobile .eq-mode-label{font-size:.7rem;padding:3px 8px}.eq-mobile .eq-toolbar,.eq-mobile .eq-selected-block,.eq-mobile .eq-floor-ctrl,.eq-mobile .eq-actbar,.eq-mobile .eq-quake-panel{display:none}.eq-mobile .eq-fly-badge{top:46px;font-size:.7rem}.eq-mobile .eq-toolbar-toggle{display:flex}.eq-mobile .eq-mobile-cross{display:grid}.eq-mobile .eq-mobile-bar,.eq-mobile .eq-mobile-floor{display:flex}.eq-mobile .eq-toolbar{display:block;position:absolute;top:40px;left:0;bottom:0;transform:translate(-100%);transition:transform .25s ease;z-index:30;width:min(220px,80vw)}.eq-mobile .eq-toolbar--open{transform:translate(0)}.eq-toolbar-toggle{position:absolute;top:44px;left:0;z-index:31;pointer-events:auto;-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;width:36px;height:42px;background:#121622eb;color:#fff;font-size:1.1rem;border-radius:0 8px 8px 0;cursor:pointer;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);align-items:center;justify-content:center}.eq-mobile-cross{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:7;place-items:center}.eq-mobile-cross span{position:absolute;background:#ffffffe6;border-radius:2px}.eq-mobile-cross span:first-child{width:20px;height:3px}.eq-mobile-cross span:last-child{width:3px;height:20px}.eq-mobile-bar{position:absolute;bottom:0;left:0;right:0;align-items:center;gap:0;background:#121622f2;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-top:1px solid rgba(255,255,255,.08);pointer-events:auto;z-index:20;height:72px;padding:0 8px;flex-direction:row}.eq-mobile-block-chip{flex:1;min-width:0;display:flex;align-items:center;gap:8px;padding:0 10px;cursor:pointer;height:100%}.eq-mobile-block-chip .chip-swatch{width:18px;height:18px;border-radius:4px;border:1px solid rgba(255,255,255,.2);flex-shrink:0}.eq-mobile-block-chip .chip-name{font-size:.8rem;font-weight:700;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.eq-mobile-block-chip .chip-cost{font-size:.7rem;color:#f5c842;font-weight:700;white-space:nowrap}.eq-mobile-block-chip .chip-arrow{font-size:.7rem;color:#89a;margin-left:2px}.eq-mobile-bar-btns{display:flex;gap:6px;flex-shrink:0;padding-right:6px}.eq-mobile-icon-btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;cursor:pointer;width:52px;height:52px;border-radius:14px;font-size:1.4rem;display:flex;align-items:center;justify-content:center;font-weight:900;box-shadow:0 4px 14px #0000004d;transition:transform .1s}.eq-mobile-icon-btn:active{transform:scale(.9)}.eq-mobile-btn-place{background:#3cb34a;color:#fff}.eq-mobile-btn-delete{background:#e04040;color:#fff}.eq-mobile-btn-undo{background:#ffffff1f;color:#fff}.eq-mobile-btn-eq{background:#e04040;color:#fff;font-size:1.1rem}.eq-mobile-btn-eq--disabled{background:#c832324d}.eq-mobile-floor{position:absolute;right:12px;bottom:82px;flex-direction:column;gap:8px;pointer-events:auto;z-index:21}.eq-mobile-floor button{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;width:52px;height:52px;border-radius:12px;background:#121622e6;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:#fff;font-size:1.3rem;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 14px #0000004d}.eq-mobile-sheet{position:absolute;bottom:0;left:0;right:0;background:#101420fa;border-radius:20px 20px 0 0;padding:16px 16px 48px;pointer-events:auto;z-index:50;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);max-height:70vh;overflow-y:auto;transform:translateY(100%);transition:transform .28s cubic-bezier(.25,.8,.25,1)}.eq-mobile-sheet--open{transform:translateY(0)}.eq-mobile-sheet-handle{width:40px;height:4px;background:#ffffff2e;border-radius:2px;margin:0 auto 16px}.eq-mobile-sheet-close{position:absolute;top:14px;right:16px;-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;background:#ffffff1a;color:#fff;border-radius:50%;width:30px;height:30px;cursor:pointer;font-size:.9rem}.eq-mobile-mag-wrap{padding:8px 0}.eq-mobile-mag-wrap h3{color:#f5c842;font-size:.9rem;margin-bottom:10px}.eq-mobile-mag-wrap .eq-range{width:100%;accent-color:#e04040;margin-bottom:10px}.eq-mobile-mag-wrap .eq-btn-primary{width:100%;padding:14px;font-size:1rem;margin-bottom:0}
