*{box-sizing:border-box}html,body,#root{margin:0;padding:0;height:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Noto Sans TC,PingFang TC,Microsoft JhengHei,sans-serif;background:radial-gradient(ellipse at top,#2a1a4d,#0e0820 60%,#07041a);color:#f4ecd8;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}body{overflow:hidden}button,input,textarea{font-family:inherit}input,textarea{-webkit-user-select:text;user-select:text}:root{--gold: #d4a64c;--gold-bright: #f0c870;--purple: #6a4ea0;--purple-dark: #2a1a4d;--bg-card: rgba(28, 18, 56, .92);--bg-tile: rgba(40, 28, 76, .5);--bg-tile-grass: linear-gradient(135deg, #4d8a3a, #6dab4a);--bg-tile-floor: linear-gradient(135deg, #3a3050, #4a4060);--bg-tile-wall: linear-gradient(135deg, #1a1230, #251a3a);--bg-tile-shop: linear-gradient(135deg, #c08833, #d4a64c);--bg-tile-inn: linear-gradient(135deg, #3a8a8c, #4ca8aa);--bg-tile-dungeon: linear-gradient(135deg, #501030, #7a2050);--bg-tile-exit: linear-gradient(135deg, #2a5a8a, #3a7aaa);--bg-tile-boss: linear-gradient(135deg, #8a1a30, #c02a4a);--hp: linear-gradient(90deg, #d4413a, #f06866);--mp: linear-gradient(90deg, #3a72d4, #66a0f0);--xp: linear-gradient(90deg, #d4a64c, #f0c870)}.app-shell{display:flex;flex-direction:column;height:100vh;height:100dvh;max-width:1100px;margin:0 auto;padding:12px}.app-footer{text-align:center;font-size:11px;color:#8074a4;padding:6px 0 2px;letter-spacing:.05em}.title-scene{flex:1;display:flex;align-items:center;justify-content:center;overflow-y:auto}.title-card{background:var(--bg-card);border:2px solid var(--gold);border-radius:16px;padding:32px 36px;max-width:460px;width:100%;box-shadow:0 8px 40px #0009,inset 0 0 0 1px #ffffff0d}.title-main{font-size:38px;text-align:center;margin:0 0 4px;letter-spacing:.05em;background:linear-gradient(180deg,#f0c870,#c08833);-webkit-background-clip:text;background-clip:text;color:transparent;text-shadow:0 0 30px rgba(212,166,76,.3)}.title-sub{display:block;font-size:14px;font-weight:400;letter-spacing:.2em;background:linear-gradient(180deg,#d4a64c,#8a7030);-webkit-background-clip:text;background-clip:text;color:transparent;margin-top:4px}.title-tagline{text-align:center;color:#b8a8d0;font-size:13px;margin:8px 0 24px;letter-spacing:.05em}.title-banner{display:flex;align-items:center;justify-content:center;gap:14px;margin-bottom:6px}.title-banner-deco{font-size:28px;opacity:.7}.title-subtitle{text-align:center;color:#b8a8d0;font-size:13px;letter-spacing:.3em;margin:0 0 24px}.title-audio-toggle{margin-top:18px}.title-footer{margin-top:24px;color:#6f6790;font-size:11px;letter-spacing:.05em;text-align:center}.title-footer a{color:var(--gold-bright);text-decoration:none}.title-footer a:hover{text-decoration:underline}.title-footer-sep{color:#4a4360}.title-section{margin-bottom:16px}.title-label{display:flex;flex-direction:column;font-size:13px;color:#b8a8d0;letter-spacing:.05em}.title-input{margin-top:6px;padding:10px 14px;font-size:16px;background:#0000004d;border:1px solid var(--purple);border-radius:8px;color:#f4ecd8;outline:none;transition:border-color .2s}.title-input:focus{border-color:var(--gold)}.title-buttons{display:flex;flex-direction:column;gap:8px}.title-import{margin-top:12px;display:flex;flex-direction:column;gap:8px}.title-textarea{padding:8px;font-size:12px;font-family:monospace;background:#0000004d;border:1px solid var(--purple);border-radius:6px;color:#f4ecd8;resize:vertical}.title-controls{margin-top:18px;font-size:11px;color:#8074a4;text-align:center;letter-spacing:.05em}.btn{padding:10px 16px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:transform .1s,box-shadow .1s,opacity .15s;letter-spacing:.03em;color:#fff;text-align:center}.btn:active:not(:disabled){transform:translateY(1px)}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-full{width:100%}.btn-primary{background:linear-gradient(180deg,#d4a64c,#a07a30);box-shadow:0 2px #604818,inset 0 1px #ffffff4d}.btn-primary:hover:not(:disabled){background:linear-gradient(180deg,#f0c870,#c08833)}.btn-secondary{background:linear-gradient(180deg,#5a4a90,#3a2a70);box-shadow:0 2px #20104a,inset 0 1px #fff3}.btn-secondary:hover:not(:disabled){background:linear-gradient(180deg,#6a5aa0,#4a3a80)}.btn-danger{background:linear-gradient(180deg,#a04050,#702030);box-shadow:0 2px #401020,inset 0 1px #fff3}.btn-danger:hover:not(:disabled){background:linear-gradient(180deg,#c05060,#803040)}.action-desc{display:block;font-size:11px;font-weight:400;color:#ffffffb3;margin-top:2px}.bar-wrap{display:flex;flex-direction:column;gap:2px}.bar-label{font-size:11px;color:#b8a8d0;letter-spacing:.05em}.bar{position:relative;height:16px;background:#0006;border:1px solid #2a1a4d;border-radius:4px;overflow:hidden}.bar-fill{position:absolute;top:0;left:0;height:100%;transition:width .3s ease-out}.bar-hp .bar-fill{background:var(--hp)}.bar-mp .bar-fill{background:var(--mp)}.bar-xp .bar-fill{background:var(--xp)}.bar-text{position:relative;display:block;font-size:11px;text-align:center;line-height:16px;font-weight:600;text-shadow:0 1px 2px rgba(0,0,0,.8);letter-spacing:.02em}.overworld-scene{flex:1;display:flex;flex-direction:column;gap:8px;overflow:hidden}.overworld-header{display:flex;justify-content:space-between;align-items:center;background:var(--bg-card);border:1px solid var(--purple);border-radius:10px;padding:8px 14px;font-size:13px}.map-name{font-weight:700;color:var(--gold-bright);letter-spacing:.05em}.map-pos{margin-left:8px;color:#8074a4;font-size:11px;font-family:monospace}.player-status{display:flex;gap:12px}.player-name{color:#f4ecd8}.player-gold{color:var(--gold-bright);font-weight:700}.overworld-body{flex:1;display:grid;grid-template-columns:1fr 280px;gap:12px;overflow:hidden;min-height:0}@media (max-width: 720px){.overworld-body{grid-template-columns:1fr;grid-template-rows:auto 1fr}}.map-grid{display:grid;gap:2px;background:var(--bg-card);border:2px solid var(--gold);border-radius:12px;padding:8px;aspect-ratio:10 / 8;max-height:100%;max-width:100%;align-self:center;justify-self:center;box-shadow:0 4px 20px #00000080}.tile{display:flex;align-items:center;justify-content:center;font-size:clamp(14px,3.5vw,28px);border-radius:4px;background:var(--bg-tile);color:#fff6}.tile-grass{background:var(--bg-tile-grass)}.tile-floor{background:var(--bg-tile-floor)}.tile-wall{background:var(--bg-tile-wall)}.tile-shop{background:var(--bg-tile-shop)}.tile-inn{background:var(--bg-tile-inn)}.tile-dungeon-entry{background:var(--bg-tile-dungeon)}.tile-village-exit{background:var(--bg-tile-exit)}.tile-boss{background:var(--bg-tile-boss);animation:pulse-boss 1.8s ease-in-out infinite}.tile-treasure{background:linear-gradient(135deg,#c0a040,#8a7020);box-shadow:0 0 8px #d4a64c66}.tile-npc{background:linear-gradient(135deg,#4a8a8c,#2a5a5c)}.tile-mini-boss{background:linear-gradient(135deg,#8a4040,#5a2020);box-shadow:0 0 8px #d44c4c66}@keyframes pulse-boss{0%,to{box-shadow:0 0 8px #c02a4a80}50%{box-shadow:0 0 24px #ff6482e6}}.tile-player{z-index:2;filter:drop-shadow(0 0 8px rgba(255,240,180,.8));animation:player-bob 2s ease-in-out infinite}@keyframes player-bob{0%,to{transform:translateY(0)}50%{transform:translateY(-2px)}}.overworld-side{display:flex;flex-direction:column;gap:8px;overflow-y:auto}.status-panel{background:var(--bg-card);border:1px solid var(--purple);border-radius:10px;padding:12px;display:flex;flex-direction:column;gap:8px}.stat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin-top:4px}.stat-grid>div{background:#0000004d;border-radius:6px;padding:4px 6px;text-align:center;font-size:11px}.stat-grid span{color:#8074a4;display:block}.stat-grid strong{color:var(--gold-bright);font-size:16px}.equip-line{display:flex;justify-content:space-between;font-size:12px;color:#b8a8d0}.equip-line strong{color:#f4ecd8}.message-log{background:var(--bg-card);border:1px solid var(--purple);border-radius:10px;padding:10px 12px;font-size:12px;min-height:80px;display:flex;flex-direction:column;gap:2px}.message-line{color:#d8ccea}.message-empty{color:#5a4d7a;font-style:italic}.mobile-controls{display:grid;grid-template-columns:repeat(3,1fr);gap:4px;margin-top:auto}.dpad{background:linear-gradient(180deg,#4a3a80,#2a1a60);border:1px solid #6a4ea0;color:#f4ecd8;border-radius:8px;padding:12px 0;font-size:18px;cursor:pointer}.dpad:active{background:linear-gradient(180deg,#6a4ea0,#4a3a80)}.battle-scene{flex:1;display:flex;flex-direction:column;gap:8px;background:radial-gradient(ellipse at center,rgba(80,30,60,.4),transparent 70%),var(--bg-card);border:2px solid #a04060;border-radius:12px;padding:14px;overflow:hidden}.battle-boss{border-color:#f0c870;box-shadow:0 0 30px #c02a4a66}.battle-stage{flex:1;display:grid;grid-template-rows:1fr 1fr;gap:12px;min-height:0}.combatant{display:flex;flex-direction:column;align-items:center;gap:4px;position:relative;padding:12px;border-radius:12px;background:#0000004d}.combatant-enemy{background:linear-gradient(180deg,#a040504d,#3214284d)}.combatant-player{background:linear-gradient(180deg,#323c784d,#141e3c4d)}.combatant-portrait{font-size:clamp(48px,12vw,96px);line-height:1;margin-bottom:4px;filter:drop-shadow(0 4px 8px rgba(0,0,0,.5));position:relative}.combatant-name{font-size:16px;font-weight:700;color:var(--gold-bright);letter-spacing:.05em}.combatant.shake{animation:shake .4s}@keyframes shake{0%,to{transform:translate(0)}20%,60%{transform:translate(-6px)}40%,80%{transform:translate(6px)}}.combatant.defending:after{content:"🛡️ 防禦中";position:absolute;top:8px;right:8px;background:#3250a0b3;padding:2px 6px;border-radius:4px;font-size:11px}.damage-number{position:absolute;top:-10px;left:50%;font-size:28px;font-weight:800;color:#fff;text-shadow:0 0 6px rgba(0,0,0,.9),0 0 12px rgba(0,0,0,.7);pointer-events:none;font-family:monospace;animation:dmg-float 1s ease-out forwards;z-index:50}.damage-number.crit{font-size:38px;color:var(--gold-bright);text-shadow:0 0 10px rgba(0,0,0,.9),0 0 16px rgba(240,200,112,.7)}.damage-number.heal{color:#66f088;text-shadow:0 0 8px rgba(0,0,0,.9),0 0 14px rgba(102,240,136,.6)}@keyframes dmg-float{0%{transform:translate(-50%);opacity:1}60%{opacity:1}to{transform:translate(-50%,-50px);opacity:0}}.combatant-portrait.lunge-up{animation:lunge-up .25s ease-out}.combatant-portrait.lunge-down{animation:lunge-down .25s ease-out}.combatant-portrait.crit-impact{animation:crit-impact .3s ease-out}.combatant-portrait.defeated{animation:defeated-fade .8s ease-in forwards}@keyframes lunge-up{0%,to{transform:translateY(0)}50%{transform:translateY(-24px)}}@keyframes lunge-down{0%,to{transform:translateY(0)}50%{transform:translateY(24px)}}@keyframes crit-impact{0%,to{transform:scale(1)}40%{transform:scale(1.25)}}@keyframes defeated-fade{to{opacity:0;transform:translateY(30px)}}.hit-flash{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle,rgba(255,64,64,.7),transparent 70%);pointer-events:none;animation:hit-flash-anim .2s ease-out;z-index:1}.hit-flash.heal{background:radial-gradient(circle,rgba(64,240,128,.7),transparent 70%)}@keyframes hit-flash-anim{0%{opacity:0}30%{opacity:1}to{opacity:0}}.bar-wrap{width:100%;max-width:280px}.battle-log{background:#0006;border-radius:8px;padding:8px 12px;min-height:90px;max-height:110px;overflow-y:auto;font-size:13px;display:flex;flex-direction:column;gap:3px}.log-line{color:#e8dcfc}.battle-menu{min-height:100px}.action-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}.action-grid-list{grid-template-columns:1fr}.action-grid .btn-full{grid-column:1 / -1}.battle-wait{text-align:center;padding:20px;font-style:italic;color:#b8a8d0}.battle-result{display:flex;flex-direction:column;gap:10px;align-items:center}.result-text{font-size:20px;font-weight:900;color:var(--gold-bright);text-shadow:0 0 12px rgba(212,166,76,.5)}.empty-inv{text-align:center;color:#8074a4;font-style:italic;padding:16px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:100;padding:12px}.modal-card{background:var(--bg-card);border:2px solid var(--gold);border-radius:12px;padding:20px;max-width:480px;width:100%;display:flex;flex-direction:column;gap:8px;max-height:90vh;overflow-y:auto}.modal-card h3{margin:0 0 8px;color:var(--gold-bright)}.shop-card{max-width:560px}.shop-header{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--purple);padding-bottom:12px;margin-bottom:6px}.shop-header h2{margin:0;color:var(--gold-bright)}.shop-gold{color:var(--gold-bright);font-weight:700;font-size:18px}.shop-tabs{display:flex;gap:4px;margin-bottom:8px}.tab{flex:1;padding:8px;background:#0000004d;border:1px solid var(--purple);border-radius:6px;color:#b8a8d0;cursor:pointer;font-size:13px}.tab.active{background:linear-gradient(180deg,var(--gold),#a07a30);color:#1a1230;font-weight:700;border-color:var(--gold)}.shop-list{display:flex;flex-direction:column;gap:4px;max-height:50vh;overflow-y:auto}.shop-row{display:grid;grid-template-columns:1fr auto;gap:12px;padding:10px;background:#00000040;border-radius:8px;align-items:center}.shop-row-info{display:flex;flex-direction:column}.shop-row-info strong{color:#f4ecd8;font-size:14px}.shop-row-desc{font-size:11px;color:#b8a8d0}.shop-row-actions{display:flex;align-items:center;gap:8px}.shop-row-price{color:var(--gold-bright);font-weight:700;font-size:13px;min-width:50px;text-align:right}.shop-footer{margin-top:8px}.gameover-scene{flex:1;display:flex;align-items:center;justify-content:center}.gameover-card{background:var(--bg-card);border:2px solid #a04050;border-radius:16px;padding:40px 32px;text-align:center;max-width:400px;width:100%;box-shadow:0 0 60px #a0405066}.gameover-title{font-size:48px;margin:0 0 12px;color:#c05060;text-shadow:0 0 24px rgba(192,42,74,.6);letter-spacing:.1em}.gameover-sub{color:#b8a8d0;font-size:14px;margin:0 0 6px}.gameover-stats{color:#8074a4;font-size:12px;margin:0 0 24px}.gameover-buttons{display:flex;flex-direction:column;gap:8px}.game-complete-backdrop{z-index:350}.game-complete-panel{max-width:420px;border:2px solid var(--gold-bright);box-shadow:0 0 60px #f0c87066;animation:gc-zoom .4s ease-out}.gc-banner{text-align:center;font-size:24px;font-weight:800;color:var(--gold-bright);letter-spacing:.1em;margin:4px 0 16px;text-shadow:0 0 12px rgba(240,200,112,.7)}.gc-stats{background:#00000059;border:1px solid var(--purple);border-radius:8px;padding:12px 14px;margin-bottom:12px;display:flex;flex-direction:column;gap:6px}.gc-stat-row{display:flex;justify-content:space-between;font-size:13px;color:#d8ccea}.gc-stat-row strong{color:var(--gold-bright);font-weight:600}.gc-thank{text-align:center;color:#e8dcfc;font-size:14px;margin:8px 0 12px}@keyframes gc-zoom{0%{transform:scale(.7);opacity:0}to{transform:scale(1);opacity:1}}.levelup-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:300;background:#000000b3;display:grid;place-items:center;animation:levelup-fadein .3s ease-out,levelup-fadeout .3s ease-in 1.7s forwards}.levelup-panel{background:linear-gradient(135deg,#2a1a4d,#1a1230);border:2px solid var(--gold-bright);border-radius:12px;padding:24px 32px;min-width:260px;text-align:center;box-shadow:0 0 40px #f0c87066;animation:levelup-zoom .3s ease-out}.levelup-banner{font-size:26px;font-weight:800;color:var(--gold-bright);letter-spacing:.1em;margin-bottom:8px;text-shadow:0 0 12px rgba(240,200,112,.6)}.levelup-level{font-size:18px;color:#e8dcfc;margin-bottom:16px}.levelup-stats{display:flex;flex-direction:column;gap:4px;margin-bottom:12px}.levelup-stat{font-size:15px;color:#66f088;font-family:monospace}.levelup-hint{font-size:11px;color:#8074a4;letter-spacing:.05em}@keyframes levelup-fadein{0%{opacity:0}to{opacity:1}}@keyframes levelup-fadeout{to{opacity:0}}@keyframes levelup-zoom{0%{transform:scale(.7);opacity:0}to{transform:scale(1);opacity:1}}.dialog-modal{max-width:480px}.dialog-speaker{display:flex;align-items:center;gap:10px;padding-bottom:12px;margin-bottom:12px;border-bottom:1px solid var(--purple)}.dialog-emoji{font-size:32px}.dialog-name{color:var(--gold-bright);font-weight:700;font-size:16px;letter-spacing:.05em}.dialog-text{font-size:14px;line-height:1.7;color:#e8dcfc;min-height:60px;white-space:pre-line;margin-bottom:12px}.dialog-hint{font-size:11px;color:#8074a4;text-align:center;margin-top:6px;letter-spacing:.05em}.dialog-choices{display:flex;flex-direction:column;gap:6px}.items-modal{max-width:480px}.items-list{display:flex;flex-direction:column;gap:4px;max-height:50vh;overflow-y:auto;margin-bottom:8px}.equip-modal{max-width:480px}.equip-current{background:#0000004d;border:1px solid var(--purple);border-radius:8px;padding:10px 12px;margin-bottom:12px;display:flex;flex-direction:column;gap:6px}.equip-slot{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:8px;font-size:13px}.equip-slot-label{color:#b8a8d0;min-width:60px}.equip-slot-value{color:var(--gold-bright);font-weight:600}.equip-bonus{color:#66f088;font-size:11px;font-family:monospace}.equip-list-title{color:var(--gold-bright);font-size:14px;margin-bottom:6px;letter-spacing:.05em}.equip-list{display:flex;flex-direction:column;gap:4px;max-height:40vh;overflow-y:auto;margin-bottom:8px}.lock-backdrop{z-index:200;background:#000000d9}.lock-modal h3{color:var(--gold-bright);margin:0 0 12px;font-size:20px;letter-spacing:.05em}.lock-modal p{font-size:13px;line-height:1.6;color:#d8ccea;margin:0 0 12px}.lock-hint{font-size:12px;color:#8074a4;font-style:italic}.dialogue-box{background:var(--bg-card);border:1px solid var(--gold);border-radius:10px;padding:12px 16px}.dialogue-title{color:var(--gold-bright);font-weight:700;font-size:14px;margin-bottom:6px}.dialogue-body{font-size:13px;color:#e8dcfc;line-height:1.5}
