@import"https://fonts.googleapis.com/css2?family=Press+Start+2P&display=swap";:root{--ink: #e8e0ff;--ink-dim: #9a8fc4;--gold: #ffcf5c;--ember: #ff8a3d;--teal: #38e1c4;--magenta: #c14bd6;--violet: #b06bff;--heart: #ff4d6d;--panel: #140e2e;--panel-edge: #4a3a86;--bg: #0c0820;--font: "Press Start 2P", ui-monospace, "Courier New", monospace}*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}html,body{width:100%;height:100%;overflow:hidden;background:var(--bg);color:var(--ink);font-family:var(--font);touch-action:none;overscroll-behavior:none}#game-root{position:fixed;inset:0;width:100%;height:100%}#game-canvas{position:absolute;inset:0;width:100%;height:100%;display:block;image-rendering:auto}#ui-root,#touch-root{position:absolute;inset:0;pointer-events:none}.hidden{display:none!important}.screen{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:clamp(12px,2.4vh,26px);text-align:center;pointer-events:auto;background:radial-gradient(120% 90% at 50% 18%,#1b1442,#0c0820 70%,#060312);padding:5vmin;animation:fade-in .4s ease}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.title-logo{font-size:clamp(28px,8.5vw,86px);line-height:1.1;letter-spacing:2px;color:var(--ink);text-shadow:0 0 14px var(--violet),0 0 34px var(--magenta),4px 5px 0 #2a1a55;animation:glow-pulse 3.4s ease-in-out infinite}@keyframes glow-pulse{0%,to{text-shadow:0 0 14px var(--violet),0 0 30px var(--magenta),4px 5px 0 #2a1a55}50%{text-shadow:0 0 20px var(--teal),0 0 46px var(--violet),4px 5px 0 #2a1a55}}.subtitle{font-size:clamp(8px,1.9vw,14px);color:var(--teal);letter-spacing:1px;text-shadow:0 0 10px rgba(56,225,196,.6)}.tagline{font-size:clamp(7px,1.5vw,11px);color:var(--ink-dim);max-width:44ch;line-height:1.9}.blink{animation:blink 1.1s steps(2,start) infinite}@keyframes blink{50%{opacity:0}}.menu{display:flex;flex-direction:column;gap:10px;pointer-events:auto;width:min(92vw,560px)}.menu-item{font-size:clamp(9px,2vw,15px);color:var(--ink);background:linear-gradient(180deg,#1d1542,#140e2e);border:3px solid var(--panel-edge);border-radius:8px;padding:clamp(10px,1.8vh,16px) 18px;cursor:pointer;letter-spacing:1px;transition:transform .08s,border-color .12s,box-shadow .12s;text-align:left;display:flex;justify-content:space-between;align-items:center;gap:12px}.menu-item .meta{font-size:.7em;color:var(--ink-dim)}.menu-item.sel,.menu-item:hover{border-color:var(--teal);box-shadow:0 0 0 1px var(--teal),0 0 18px #38e1c466;transform:translate(6px);color:#fff}.menu-item.sel:before{content:"▶ ";color:var(--ember)}.menu-item.danger.sel,.menu-item.danger:hover{border-color:var(--heart);box-shadow:0 0 0 1px var(--heart),0 0 18px #ff4d6d66}.panel{background:var(--panel);border:4px solid var(--panel-edge);border-radius:12px;padding:clamp(14px,3vw,28px);box-shadow:0 0 30px #0009,inset 0 0 24px #4a3a8640;pointer-events:auto}.help-grid{display:grid;grid-template-columns:auto 1fr;gap:8px 18px;font-size:clamp(7px,1.5vw,11px);line-height:1.7;text-align:left;max-width:92vw}.help-grid .k{color:var(--gold);white-space:nowrap}.help-grid .v{color:var(--ink-dim)}.section-title{font-size:clamp(10px,2.4vw,18px);color:var(--gold);text-shadow:0 0 12px rgba(255,207,92,.4);margin-bottom:4px}.namebox{font-size:clamp(14px,4vw,28px);letter-spacing:6px;color:#fff;min-height:1.4em;border-bottom:3px solid var(--teal);padding:6px 14px;min-width:8ch}.kbd{display:grid;grid-template-columns:repeat(10,1fr);gap:5px;pointer-events:auto;width:min(94vw,520px)}.kbd .key{background:#1a1340;border:2px solid var(--panel-edge);border-radius:6px;padding:10px 0;text-align:center;font-size:clamp(8px,2vw,13px);cursor:pointer}.kbd .key.wide{grid-column:span 3}.kbd .key.sel,.kbd .key:hover{border-color:var(--teal);color:#fff;box-shadow:0 0 12px #38e1c466}.swatches{display:flex;gap:12px;pointer-events:auto;flex-wrap:wrap;justify-content:center}.swatch{width:clamp(34px,8vw,52px);height:clamp(34px,8vw,52px);border-radius:8px;border:3px solid #2a2350;cursor:pointer}.swatch.sel{border-color:#fff;box-shadow:0 0 0 2px #fff,0 0 16px currentColor;transform:scale(1.12)}#hud{position:absolute;top:0;left:0;right:0;display:flex;justify-content:space-between;align-items:flex-start;padding:clamp(6px,1.6vw,14px) clamp(8px,2vw,18px);font-size:clamp(7px,1.6vw,12px);pointer-events:none;background:linear-gradient(180deg,#080516d9,#08051600);z-index:5}.hud-block{display:flex;flex-direction:column;gap:6px}.hearts{display:flex;gap:3px;flex-wrap:wrap;max-width:52vw}.heart{width:clamp(12px,2.6vw,20px);height:clamp(12px,2.6vw,20px);background-size:contain;background-repeat:no-repeat;image-rendering:pixelated}.counters{display:flex;gap:clamp(8px,2vw,16px);align-items:center;color:var(--ink)}.counter{display:flex;gap:5px;align-items:center}.counter .ic{width:clamp(12px,2.6vw,18px);height:clamp(12px,2.6vw,18px)}.hud-right{align-items:flex-end}.item-slot{display:flex;gap:8px;align-items:center}.item-box{width:clamp(26px,6vw,40px);height:clamp(26px,6vw,40px);border:3px solid var(--panel-edge);border-radius:6px;background:#100a26;display:flex;align-items:center;justify-content:center;font-size:clamp(14px,4vw,22px)}.item-box.veil-on{border-color:var(--violet);box-shadow:0 0 16px var(--violet)}.label{font-size:.72em;color:var(--ink-dim)}#dialogue{position:absolute;left:50%;bottom:clamp(80px,14vh,130px);transform:translate(-50%);width:min(92vw,720px);background:linear-gradient(180deg,#0e0826,#160f36);border:4px solid var(--panel-edge);border-radius:12px;padding:clamp(12px,2.4vw,20px) clamp(16px,3vw,26px);font-size:clamp(8px,1.9vw,13px);line-height:2;color:var(--ink);pointer-events:auto;box-shadow:0 10px 30px #0009,inset 0 0 18px #4a3a8640;z-index:8}#dialogue .speaker{color:var(--teal);font-size:.86em;margin-bottom:10px;text-shadow:0 0 8px rgba(56,225,196,.5)}#dialogue .next{text-align:right;color:var(--gold);font-size:.8em;margin-top:8px}#toast{position:absolute;left:50%;top:22%;transform:translate(-50%);background:#0c0820eb;border:3px solid var(--gold);border-radius:10px;padding:14px 22px;font-size:clamp(8px,2vw,14px);color:var(--gold);text-align:center;pointer-events:none;z-index:9;text-shadow:0 0 12px rgba(255,207,92,.5);box-shadow:0 0 26px #ffcf5c4d;max-width:88vw;line-height:1.8}.fade-out{animation:fade-out .6s ease forwards}@keyframes fade-out{to{opacity:0;transform:translate(-50%) translateY(-12px)}}#pause{position:absolute;inset:0;background:#060410db;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;pointer-events:auto;z-index:10}.inv-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;width:min(92vw,460px)}.inv-slot{aspect-ratio:1;border:3px solid var(--panel-edge);border-radius:8px;background:#100a26;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;font-size:clamp(16px,5vw,28px);cursor:pointer;position:relative}.inv-slot .nm{font-size:clamp(6px,1.3vw,8px);color:var(--ink-dim)}.inv-slot.equipped{border-color:var(--teal);box-shadow:0 0 16px #38e1c480}.inv-slot.empty{opacity:.3}#flash{position:absolute;inset:0;background:#000;opacity:0;pointer-events:none;z-index:20;transition:opacity .18s linear}#loading{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:18px;background:var(--bg);z-index:30;color:var(--teal);font-size:14px;pointer-events:auto}.spinner{width:44px;height:44px;border:4px solid #2a2350;border-top-color:var(--teal);border-radius:50%;animation:spin .9s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}#touch-root.active{pointer-events:none}.touch-zone{position:absolute;pointer-events:auto}#dpad{left:clamp(12px,4vw,40px);bottom:clamp(14px,5vh,54px);width:clamp(120px,34vw,180px);height:clamp(120px,34vw,180px);border-radius:50%;background:radial-gradient(circle,rgba(40,30,80,.5) 0%,rgba(20,14,46,.3) 70%,transparent 72%);border:2px solid rgba(74,58,134,.5);touch-action:none}#dpad .stick{position:absolute;left:50%;top:50%;width:42%;height:42%;border-radius:50%;background:radial-gradient(circle,var(--teal) 0%,#1a8f7e 80%);transform:translate(-50%,-50%);opacity:.8;box-shadow:0 0 18px #38e1c480}.btn-cluster{right:clamp(10px,3vw,36px);bottom:clamp(14px,5vh,54px);width:clamp(150px,42vw,220px);height:clamp(150px,42vw,220px)}.tbtn{position:absolute;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:clamp(11px,3vw,16px);color:#fff;border:3px solid rgba(255,255,255,.25);background:#1e1440a6;width:clamp(56px,16vw,80px);height:clamp(56px,16vw,80px);touch-action:none}.tbtn:active,.tbtn.down{transform:scale(.92);filter:brightness(1.4)}.tbtn.a{right:4px;bottom:30%;border-color:var(--ember);background:#783214b3}.tbtn.b{right:38%;bottom:2px;border-color:var(--teal);background:#145046b3}.tbtn.veil{left:0;top:6px;border-color:var(--violet);background:#46286eb3;font-size:clamp(7px,2vw,10px)}.tbtn-top{position:absolute;top:clamp(8px,2vh,16px);right:clamp(10px,3vw,40px);display:flex;gap:8px;pointer-events:auto}.tbtn-top .tbtn{position:static;width:clamp(40px,11vw,56px);height:clamp(40px,11vw,56px);font-size:clamp(6px,1.8vw,9px);border-color:var(--panel-edge);background:#140e2eb3}.btn{pointer-events:auto;font-family:var(--font);font-size:clamp(8px,1.9vw,13px);color:var(--ink);background:linear-gradient(180deg,#241a52,#160f36);border:3px solid var(--panel-edge);border-radius:8px;padding:12px 22px;cursor:pointer;letter-spacing:1px}.btn:hover,.btn.sel{border-color:var(--teal);color:#fff;box-shadow:0 0 16px #38e1c466}.btn.primary{border-color:var(--gold);color:var(--gold)}.btn.primary:hover{box-shadow:0 0 18px #ffcf5c80}.hint-bar{position:absolute;bottom:8px;left:50%;transform:translate(-50%);font-size:clamp(6px,1.4vw,10px);color:var(--ink-dim);pointer-events:none;text-align:center;line-height:1.8;width:96vw}.flex-row{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;pointer-events:auto}.col{display:flex;flex-direction:column;gap:12px;align-items:center}
