:root{--ink: #1b1410;--gold: #d8b65a;--gold-bright: #f4d98a;--jade: #5fb98a;--blood: #c0392b;--paper: #efe6d2}*{margin:0;padding:0;box-sizing:border-box}html,body{width:100%;height:100%;overflow:hidden;background:#000;font-family:"Noto Serif SC",Songti SC,STSong,serif;color:var(--paper);-webkit-user-select:none;user-select:none}#app{position:relative;width:100vw;height:100vh}.hidden{display:none!important}canvas#game{display:block;position:fixed;top:0;right:0;bottom:0;left:0;z-index:0;image-rendering:optimizeQuality}#touchpad{position:fixed;left:28px;bottom:28px;width:140px;height:140px;z-index:11;border-radius:50%;background:#14100c47;border:2px solid rgba(216,182,90,.35);touch-action:none}#touch-controls{position:fixed;right:22px;bottom:28px;z-index:11;display:flex;gap:18px}#touch-controls button{width:64px;height:64px;border-radius:50%;border:2px solid rgba(255,255,255,.35);background:#14100c8c;color:var(--paper);font-family:inherit;font-size:1.4rem;letter-spacing:0;box-shadow:0 0 18px #00000059;touch-action:none}#touch-spell{border-color:#5fb98aa6;color:#9ff0c4}#touch-atk{border-color:#d8b65aa6;color:var(--gold-bright)}@media (hover: hover) and (pointer: fine){#touchpad,#touch-controls{display:none}}#title-screen{position:absolute;top:0;right:0;bottom:0;left:0;z-index:20;display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse at 50% 30%,rgba(80,60,30,.5),transparent 60%),linear-gradient(160deg,#0a0d14,#141b22 45%,#0a0d14)}.title-inner{text-align:center;animation:fade-in 1.6s ease both}#title-screen h1{font-size:5rem;letter-spacing:.3rem;color:var(--gold-bright);text-shadow:0 0 24px rgba(216,182,90,.6),0 4px 10px #000}#title-screen h1 span{display:block;font-size:1.6rem;letter-spacing:1.2rem;margin-top:.4rem;color:var(--jade)}.subtitle{margin:1rem 0 2.4rem;font-size:1.1rem;color:#b9a98a;letter-spacing:.4rem}#start-btn{font-family:inherit;font-size:1.5rem;letter-spacing:.8rem;padding:.7rem 2.6rem .7rem 3.4rem;color:var(--ink);background:linear-gradient(180deg,var(--gold-bright),var(--gold));border:2px solid #fff4d0;border-radius:4px;cursor:pointer;box-shadow:0 0 30px #d8b65a73;transition:transform .15s,box-shadow .15s}#start-btn:hover{transform:translateY(-2px);box-shadow:0 0 44px #f4d98ab3}.controls-hint{list-style:none;margin-top:2.6rem;display:flex;gap:1.6rem;justify-content:center;flex-wrap:wrap;color:#9c8e72;font-size:.95rem}.controls-hint b{color:var(--gold-bright)}#hud{position:absolute;top:0;right:0;bottom:0;left:0;z-index:10;pointer-events:none;padding:22px}.player-stats{display:flex;align-items:center;gap:14px}.portrait{width:64px;height:64px;display:flex;align-items:center;justify-content:center;text-align:center;line-height:1.1;font-size:1rem;color:var(--gold-bright);background:#14100cc7;border:2px solid var(--gold);border-radius:6px;box-shadow:0 0 16px #0009}.bars{display:flex;flex-direction:column;gap:8px}.bar{position:relative;width:280px;height:20px;background:#0a0806cc;border:1px solid #000;border-radius:10px;overflow:hidden;box-shadow:inset 0 0 6px #000c}.bar span{display:block;height:100%;width:100%;transform-origin:left center;transition:transform .25s ease}.bar.hp span{background:linear-gradient(180deg,#e15a4a,var(--blood))}.bar.mp span{background:linear-gradient(180deg,#74c6ff,#2f7fd1)}.bar label{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;padding-left:10px;font-size:.78rem;letter-spacing:.3rem;color:#fff;text-shadow:0 1px 2px #000}#top-right{position:absolute;top:26px;right:26px;display:flex;flex-direction:column;gap:8px;align-items:flex-end}#top-right>div{background:#14100cb3;border:1px solid var(--gold);border-radius:4px;padding:6px 14px;font-size:.95rem;letter-spacing:.2rem}#top-right b{color:var(--gold-bright);font-size:1.15rem}#wave-info{border-color:var(--jade)!important}#wave-info b{color:var(--jade)}#wave-banner{position:absolute;left:50%;top:38%;text-align:center;font-size:3rem;letter-spacing:.8rem;color:var(--gold-bright);text-shadow:0 0 24px rgba(216,182,90,.6),0 4px 10px #000;animation:banner 2s ease forwards}@keyframes banner{0%{opacity:0;transform:translate(-50%,-50%) scale(1.3)}20%{opacity:1;transform:translate(-50%,-50%) scale(1)}80%{opacity:1}to{opacity:0}}#combat-log{position:absolute;left:50%;bottom:80px;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:4px}.float-text{font-size:1.1rem;letter-spacing:.2rem;text-shadow:0 2px 4px #000;animation:rise 1.1s ease forwards}#overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:30;display:flex;align-items:center;justify-content:center;background:#050403d1}.overlay-inner{text-align:center;animation:fade-in .6s ease both}#overlay-title{font-size:3.4rem;letter-spacing:.6rem;color:var(--gold-bright)}#overlay-text{margin:1rem 0 2rem;color:#c9bda3;letter-spacing:.2rem}#overlay-btn{font-family:inherit;font-size:1.2rem;letter-spacing:.6rem;padding:.6rem 2.4rem;cursor:pointer;color:var(--ink);background:linear-gradient(180deg,var(--gold-bright),var(--gold));border:2px solid #fff4d0;border-radius:4px}.dialogue-box{position:fixed;left:50%;bottom:24px;transform:translate(-50%);width:min(92vw,860px);z-index:25;background:#0c0a08eb;border:2px solid var(--gold);border-radius:8px;box-shadow:0 0 28px #000000b3,inset 0 0 0 1px #d8b65a2e;padding:18px 22px;animation:fade-in .3s ease both}.dialogue-inner{display:flex;gap:18px;align-items:flex-start}.dialogue-avatar{display:flex;flex-direction:column;align-items:center;gap:8px;flex-shrink:0}.dialogue-avatar-circle{width:56px;height:56px;border-radius:50%;background:radial-gradient(circle at 35% 30%,#d8b65a40,#14100ce6);border:2px solid var(--gold);box-shadow:0 0 12px #d8b65a40,inset 0 0 8px #0009;display:flex;align-items:center;justify-content:center;font-family:"Noto Serif SC",Songti SC,STSong,serif;font-size:1.6rem;color:var(--gold-bright);text-shadow:0 1px 3px rgba(0,0,0,.8);-webkit-user-select:none;user-select:none}.dialogue-speaker{font-size:.85rem;letter-spacing:.15rem;color:var(--gold-bright);text-shadow:0 1px 2px rgba(0,0,0,.8);white-space:nowrap}.dialogue-body{flex:1;display:flex;flex-direction:column;gap:14px;min-width:0}.dialogue-text{font-size:1.05rem;line-height:1.75;color:var(--paper);letter-spacing:.08rem;min-height:3.2em;word-break:break-word}.dialogue-choices{display:flex;flex-wrap:wrap;gap:10px;justify-content:flex-end}.dialogue-choice-btn{font-family:"Noto Serif SC",Songti SC,STSong,serif;font-size:.95rem;letter-spacing:.1rem;padding:8px 18px;color:var(--ink);background:linear-gradient(180deg,var(--gold-bright),var(--gold));border:2px solid #fff4d0;border-radius:4px;cursor:pointer;box-shadow:0 0 14px #d8b65a40;transition:transform .12s,box-shadow .12s}.dialogue-choice-btn:hover{transform:translateY(-2px);box-shadow:0 0 22px #f4d98a73}.dialogue-choice-btn:active{transform:translateY(0)}.scene-fade{position:fixed;top:0;right:0;bottom:0;left:0;z-index:15;background:#000;opacity:0;pointer-events:none;transition:opacity .6s ease}
