:root{--bg:#0b0e14;--panel:#121622ee;--panel2:#0f1320ee;--text:#e6edf3;--muted:#96a0aa;--accent:#6ae3ff;--accent2:#9b7bff;--good:#79ffa1;--warn:#fc6;--bad:#f67;--border:#202533}*{box-sizing:border-box}html,body{background:var(--bg);color:var(--text);margin:0;padding:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,Apple Color Emoji,Segoe UI Emoji}canvas{touch-action:none;width:100vw;height:100vh;display:block;position:fixed;inset:0}#hud{z-index:10;color:var(--text);border:1px solid var(--border);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border-radius:10px;padding:8px 12px;font-size:12px;line-height:1.4;position:fixed;top:10px;left:10px;box-shadow:0 6px 20px #00000040}#hud .row{flex-wrap:wrap;align-items:center;gap:12px;display:flex}#hud .tag{border:1px solid var(--border);color:var(--muted);background:#0d111a;border-radius:999px;align-items:center;gap:8px;padding:4px 10px;line-height:1;display:inline-flex}#hud .tag svg{width:12px;height:12px;display:block}#hud .tag b{color:var(--text);font-variant-numeric:tabular-nums}#hud .btn{border:1px solid var(--border);color:var(--text);cursor:pointer;background:#0e1220;border-radius:6px;margin-left:6px;padding:2px 8px;font-weight:600}#hud .btn:hover{border-color:#2a2f40}#panel{z-index:20;border:1px solid var(--border);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:0 0;border-radius:14px;flex-direction:column;width:min(420px,92vw);display:flex;position:fixed;top:14px;bottom:14px;right:14px;overflow:hidden;box-shadow:0 10px 30px #00000059}#panelHeader{border-bottom:1px solid var(--border);background:0 0;justify-content:space-between;align-items:center;padding:10px 12px;display:flex}#panelHeader .title{letter-spacing:.3px;font-weight:800}#panelHeader .actions{gap:8px;display:flex}#panelHeader button{border:1px solid var(--border);color:var(--text);cursor:pointer;background:#0f1524;border-radius:10px;padding:8px 10px;font-weight:700}#panelHeader button.primary{background:linear-gradient(#2a3553,#222a42);border-color:#2f3755}#tabs{border-bottom:1px solid var(--border);background:var(--panel2);flex-wrap:wrap;gap:6px;padding:8px 10px;display:flex}#tabs button{border:1px solid var(--border);color:var(--muted);cursor:pointer;background:#0e1423;border-radius:999px;padding:6px 10px;font-size:12px;font-weight:600}#tabs button.active{color:var(--text);background:linear-gradient(#18203a,#121a30);border-color:#2a2f40}#content{flex:1;padding:14px;overflow:hidden auto}.group{border:1px solid var(--border);background:#0a0c128c;border-radius:12px;margin-bottom:12px;padding:10px}.group h3{letter-spacing:.2px;color:#a9b3c0;margin:0 0 8px;font-size:13px}.group.collapsed .ctrl{display:none}.group.collapsed h3{margin:0}.ctrl{grid-template-columns:1fr auto;align-items:center;gap:6px;margin:8px 0;display:grid}.ctrl label{color:#b4beca;font-size:12px}.ctrl input[type=range]{width:170px}.ctrl input[type=color]{background:0 0;border:none;width:40px;height:28px}.ctrl select,.ctrl input[type=number],.ctrl input[type=text]{border:1px solid var(--border);color:var(--text);background:#0d1322;border-radius:8px;min-width:140px;padding:6px 8px}.ctrl .value{font-variant-numeric:tabular-nums;color:#cdd6e3;font-size:12px}.icon-buttons{flex-wrap:wrap;gap:4px;display:flex}.icon-btn{border:1px solid var(--border);color:var(--text);cursor:pointer;background:#0d1322;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;padding:6px 8px;font-size:16px;display:flex}.icon-btn:hover{border-color:#2a2f40}.icon-btn.active{background:linear-gradient(#18203a,#121a30);border-color:#2a2f40}.rowline{flex-wrap:wrap;gap:6px;display:flex}.smallnote{color:#8c97a6;font-size:11px}.footerNote{color:#7e8796;text-align:center;margin-top:6px;font-size:11px}#tiltPrompt{z-index:15;pointer-events:none;background:linear-gradient(#0000,#00000080);justify-content:center;align-items:flex-end;padding:16px;display:flex;position:fixed;inset:auto 0 0}#tiltPrompt .bubble{pointer-events:auto;border:1px solid var(--border);background:#12182a;border-radius:14px;max-width:min(560px,92vw);padding:12px;box-shadow:0 8px 24px #00000059}#tiltPrompt .bubble .row{align-items:center;gap:8px;display:flex}#tiltPrompt .bubble button{border:1px solid var(--border);color:#fff;cursor:pointer;background:#0f1524;border-radius:10px;padding:8px 12px;font-weight:700}#tiltPrompt .bubble button.primary{background:linear-gradient(#2a3553,#222a42);border-color:#2f3755}#togglePanel{z-index:30;border:1px solid var(--border);color:var(--text);cursor:pointer;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:0 0;border-radius:999px;padding:8px 10px;font-weight:800;position:fixed;bottom:10px;left:10px;box-shadow:0 8px 24px #00000040}#togglePanel small{color:#98a3b0}#panel.hidden{display:none}.chip{border:1px solid var(--border);color:#8ea0b7;background:#0e1423;border-radius:999px;align-items:center;gap:6px;margin-right:6px;padding:4px 8px;font-size:12px;display:inline-flex}.flex{align-items:center;gap:8px;display:flex}a,a:visited{color:var(--accent);text-decoration:none}#tiltPrompt{display:none!important}
:root{--panel-width:320px}#panel{border-radius:8px;padding:0;top:8px;bottom:8px;right:8px;width:min(var(--panel-width),92vw)!important}#panelHeader{padding:6px 8px}#panelHeader .title{font-size:13px}#panelHeader button{padding:5px 6px;font-size:12px}#tabs{gap:6px;padding:6px}#tabs button{padding:4px 7px;font-size:11px}#content{padding:8px}.group{border-radius:8px;margin-bottom:8px;padding:6px}.group h3{margin-bottom:6px;font-size:12px}.ctrl{gap:6px;margin:6px 0}.ctrl input[type=range]{width:110px}.ctrl select,.ctrl input[type=number],.ctrl input[type=text]{min-width:100px;padding:4px 6px;font-size:12px}.icon-btn{width:26px;height:26px;padding:3px;font-size:13px}#togglePanel{padding:6px 8px;bottom:8px;left:8px}#hud{padding:6px 8px;font-size:11px}html,body{font-size:13px}.icon-btn.active{color:var(--accent)}.icon-btn.active svg[fill=none],.icon-btn.active svg[fill=none] *{stroke:var(--accent)!important;fill:none!important}.icon-btn.active svg:not([fill=none]),.icon-btn.active svg:not([fill=none]) *{fill:var(--accent)!important;stroke:var(--accent)!important}
