:root{--ash:#15110f;--ember:#ff6a1f;--enchant:#56b6ff;--parch:#f4ece2;--muted:#b8a99b}*{box-sizing:border-box}html,body,#root{background:#0c0a09;width:100%;height:100%;margin:0;overflow:hidden}body{color:var(--parch);-webkit-font-smoothing:antialiased;font-family:Segoe UI,Roboto,Helvetica,Arial,sans-serif}.app{position:fixed;inset:0}canvas{touch-action:none;display:block}.overlay{pointer-events:none;position:absolute;inset:0}.brand{padding:22px 28px}.brand h1{letter-spacing:.18em;background:linear-gradient(#ffb347,#ff6a1f);color:#0000;text-shadow:0 0 40px #ff6a1f4d;-webkit-background-clip:text;background-clip:text;margin:0;font-size:clamp(32px,6vw,64px)}.brand .epithet{color:var(--muted);letter-spacing:.28em;text-transform:uppercase;margin-top:4px;font-size:12px}.hud-bars{pointer-events:none;flex-direction:column;gap:9px;width:min(230px,44vw);display:flex;position:absolute;top:100px;left:28px}.bar{letter-spacing:.12em;color:var(--muted);align-items:center;gap:9px;font-size:11px;display:flex}.bar>span{flex:none;width:42px}.bar>.track{background:#ffffff14;border-radius:999px;flex:1;height:9px;overflow:hidden}.bar>.track>i{height:100%;transition:width .2s;display:block}.bar>.track>i.hp{background:linear-gradient(90deg,#ff3a2f,#ff8a3d);box-shadow:0 0 12px #ff5a2f80}.bar>.track>i.mana{background:linear-gradient(90deg,#3a7bff,#7fd1ff);box-shadow:0 0 12px #56b6ff80}.foes{letter-spacing:.05em;color:var(--muted);pointer-events:none;text-shadow:0 0 8px #0009;font-size:12px;position:absolute;top:152px;left:28px}.portrait-card{pointer-events:auto;background:#1a1411;border:1px solid #4a3a2e;border-radius:14px;width:min(220px,38vw);animation:.45s ease-out fadeup;position:absolute;bottom:120px;right:24px;overflow:hidden;box-shadow:0 16px 50px #0009}.portrait-card.charm{border-color:#56b6ff80;box-shadow:0 16px 50px #0009,0 0 28px #56b6ff40}.portrait-card.battle{border-color:#ff6a1f80;box-shadow:0 16px 50px #0009,0 0 28px #ff6a1f40}.portrait-card img{width:100%;height:auto;display:block}.portrait-card .cap{color:var(--muted);padding:8px 12px;font-size:12px;line-height:1.5}.portrait-card .cap b{color:var(--parch)}.hint{pointer-events:none;color:var(--parch);letter-spacing:.04em;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);white-space:nowrap;background:#14100e8c;border:1px solid #ffffff14;border-radius:999px;padding:6px 14px;font-size:12px;position:absolute;bottom:86px;left:50%;transform:translate(-50%)}.controls{pointer-events:none;position:absolute;bottom:30px;left:50%;transform:translate(-50%)}.stance-btn{pointer-events:auto;cursor:pointer;color:var(--parch);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#14100ed1;border:1px solid #4a3a2e;border-radius:999px;padding:13px 20px;font-size:15px;font-weight:600;transition:transform .18s,box-shadow .18s,border-color .18s}.stance-btn:hover{transform:translateY(-2px)}.stance-btn.battle{border-color:#ff6a1f99;box-shadow:0 0 26px #ff6a1f73}.stance-btn.charm{border-color:#56b6ff99;box-shadow:0 0 26px #56b6ff73}.joy{pointer-events:auto;touch-action:none;background:#14100e52;border:1px solid #ffffff1f;border-radius:50%;width:116px;height:116px;position:absolute;bottom:30px;left:26px}.joy .knob{background:radial-gradient(circle at 40% 35%,#ffb347,#ff6a1f);border-radius:50%;width:50px;height:50px;margin:-25px 0 0 -25px;position:absolute;top:50%;left:50%;box-shadow:0 0 18px #ff6a1f80}.act{pointer-events:auto;color:#fff;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);cursor:pointer;touch-action:none;background:#14100e9e;border:1px solid #ffffff24;border-radius:50%;width:78px;height:78px;font-size:30px;line-height:1;position:absolute;bottom:30px;right:26px}.act:active{transform:scale(.94)}.act.battle{border-color:#ff6a1f99;box-shadow:0 0 24px #ff6a1f80}.act.charm{border-color:#56b6ff99;box-shadow:0 0 24px #56b6ff80}.foot{pointer-events:none;color:#b8a99bb3;text-align:right;font-size:10px;line-height:1.6;position:absolute;top:14px;right:14px}@keyframes fadeup{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@media (max-width:680px){.brand{padding:14px 16px}.brand h1{font-size:30px}.portrait-card{width:30vw;top:56px;bottom:auto;right:12px}.hud-bars{width:42vw;top:72px;left:14px}.foes{top:122px;left:14px}.hint{white-space:normal;text-align:center;max-width:78vw;font-size:11px;bottom:186px}.controls{bottom:132px}.foot{display:none}.joy{width:126px;height:126px;bottom:26px;left:18px}.act{width:86px;height:86px;font-size:32px;bottom:42px;right:18px}}
