@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=Space+Grotesk:wght@500;600;700&display=swap";:root{--your-world-primary: #C08B5C;--your-world-glow: rgba(192, 139, 92, .12);--your-world-dark: #8B6914;--your-world-bg: #FFF8F0;--water-world-primary: #3B8DB5;--water-world-glow: rgba(59, 141, 181, .1);--water-world-dark: #2E5A6B;--water-world-bg: #F0F7FA;--bg-primary: #FFFFFF;--bg-secondary: #F7F6F4;--bg-tertiary: #EEEDEB;--text-primary: #1A1A1A;--text-secondary: #6B6560;--text-muted: #B0AAA4;--accent-danger: #D94840;--accent-success: #4CAF50;--accent-energy: #D4922A;--font-mono: "Inter", system-ui, -apple-system, sans-serif;--font-display: "Space Grotesk", system-ui, sans-serif}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-mono);background:var(--bg-primary);color:var(--text-primary);overflow:hidden;width:100vw;height:100vh;line-height:1.5}#game-canvas{position:fixed;top:0;left:0;width:100%;height:100%;z-index:1}#game-canvas.tab-active{filter:brightness(.97);transition:filter .15s ease}.archive-card{background:var(--bg-secondary);border:1px solid rgba(0,0,0,.08);border-radius:12px;position:relative}.archive-card:before{display:none}.archive-card:after{content:attr(data-label);position:absolute;top:-8px;left:16px;background:var(--bg-primary);padding:0 8px;font-size:.65rem;letter-spacing:.05em;color:var(--text-muted)}.skew-btn{font-family:var(--font-mono);font-weight:600;font-size:.8rem;padding:14px 32px;background:var(--bg-tertiary);border:1px solid rgba(0,0,0,.1);color:var(--text-primary);cursor:pointer;position:relative;border-radius:10px;transition:all .2s ease}.skew-btn:hover:not(:disabled){background:var(--your-world-primary);color:#fff;border-color:var(--your-world-primary)}.skew-btn:disabled{opacity:.4;cursor:not-allowed}.status-pill{display:inline-flex;align-items:center;gap:8px;padding:6px 14px;font-size:.75rem;font-weight:500;border:1px solid currentColor;border-radius:20px;position:relative}.status-pill:before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor}.status-pill.your-world{color:var(--your-world-primary);background:var(--your-world-glow)}.status-pill.water-world{color:var(--water-world-primary);background:var(--water-world-glow)}.start-screen{position:fixed;top:0;left:0;width:100%;height:100%;background:var(--bg-primary);display:flex;align-items:center;justify-content:center;z-index:100;overflow-y:auto}.start-screen-content{max-width:900px;padding:60px 40px;position:relative}.title-block{margin-bottom:50px;position:relative}.start-screen h1{font-family:var(--font-display);font-size:4rem;font-weight:700;line-height:1;margin-bottom:15px;letter-spacing:-.03em}.start-screen h1 .line1{display:block;color:var(--text-primary)}.start-screen h1 .line2{display:block;color:var(--your-world-primary);font-style:italic}.start-screen h2{font-family:var(--font-mono);font-size:.9rem;color:var(--text-secondary);font-weight:400;letter-spacing:.1em}.intro-text{composes:archive-card;padding:30px;margin-bottom:40px;font-size:.85rem;line-height:1.9;color:var(--text-secondary)}.intro-text strong{color:var(--text-primary);font-weight:600}.intro-text .highlight{color:var(--water-world-primary)}.skill-selection{margin-bottom:40px}.skill-selection h3{font-family:var(--font-mono);font-size:.75rem;font-weight:600;color:var(--text-muted);margin-bottom:25px;padding-left:15px;border-left:3px solid var(--your-world-primary)}.skill-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:15px}.skill-btn{composes:archive-card;background:var(--bg-secondary);border:1px solid rgba(0,0,0,.08);padding:20px;cursor:pointer;text-align:left;position:relative;transition:all .25s ease;border-radius:12px}.skill-btn:hover{border-color:var(--text-muted);transform:translateY(-2px);box-shadow:0 4px 12px #0000000f}.skill-btn.selected{border-color:var(--your-world-primary);background:var(--your-world-glow)}.skill-btn.selected:before{content:"✓";position:absolute;top:10px;right:12px;font-size:.8rem;color:var(--your-world-primary);font-weight:700}.skill-name{font-family:var(--font-display);font-weight:600;font-size:1rem;margin-bottom:8px;color:var(--text-primary)}.skill-cost{font-size:.7rem;color:var(--accent-energy);margin-bottom:10px;font-weight:500}.skill-desc{font-size:.75rem;color:var(--text-secondary);line-height:1.6}.dev-options{composes:archive-card;padding:25px;margin-bottom:40px}.dev-options h3{font-size:.75rem;font-weight:600;color:var(--text-muted);margin-bottom:20px}.dev-options label{display:block;margin:15px 0;font-size:.8rem;color:var(--text-secondary);cursor:pointer}.dev-options input[type=range]{width:200px;margin:0 15px;accent-color:var(--your-world-primary)}.dev-options input[type=checkbox]{margin-right:10px;accent-color:var(--your-world-primary)}.start-button{composes:skew-btn;width:100%;font-size:1rem;padding:20px}.game-ui{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:130}.game-ui>*{pointer-events:auto}.ui-top-bar{position:fixed;top:0;left:0;right:0;display:flex;justify-content:space-between;align-items:flex-start;padding:25px 30px;background:linear-gradient(180deg,rgba(255,255,255,.9) 0%,transparent 100%)}.world-indicator{composes:status-pill;font-size:.75rem;padding:10px 20px}.world-indicator.your-world:before{background:var(--your-world-primary)}.world-indicator.water-world:before{background:var(--water-world-primary)}.turn-display{font-family:var(--font-mono);font-size:.75rem;color:var(--text-secondary);padding:10px 15px;border:1px solid rgba(0,0,0,.08);background:#ffffffe6;border-radius:10px}.turn-display span{color:var(--text-primary);font-weight:600;font-size:1.1rem}.ui-left-panel{position:fixed;left:30px;top:100px;width:240px;display:flex;flex-direction:column;gap:15px}.stats-panel{composes:archive-card;padding:20px;background:#ffffffe6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.stats-panel[data-label]:after,.enemy-info[data-label]:after{top:-7px}.stat-row{display:flex;align-items:center;margin-bottom:15px}.stat-row:last-child{margin-bottom:0}.stat-label{width:35px;font-weight:600;font-size:.75rem;color:var(--text-muted)}.bar-container{flex:1;height:8px;background:var(--bg-tertiary);border-radius:4px;position:relative;overflow:hidden}.bar{height:100%;border-radius:4px;transition:width .3s ease}.hp-bar{background:var(--accent-success)}.energy-bar{background:var(--accent-energy)}.stat-value{width:50px;font-size:.8rem;text-align:right;font-weight:600;color:var(--text-primary)}@keyframes alert-pulse{0%,to{opacity:1}50%{opacity:.6}}.ui-bottom-panel{position:fixed;bottom:30px;left:50%;transform:translate(-50%)}.end-turn-btn{composes:skew-btn;background:var(--bg-secondary);border-color:var(--accent-energy);border-width:2px;font-size:1rem;padding:18px 52px;color:var(--accent-energy)}.end-turn-btn:hover:not(:disabled){background:var(--accent-danger);border-color:var(--accent-danger);color:#fff}.message-log{position:fixed;right:28px;top:130px;bottom:360px;left:auto;transform:none;width:min(340px,calc(100vw - 56px));max-height:none;overflow-y:auto;composes:archive-card;padding:15px 20px;display:flex;flex-direction:column;gap:6px;pointer-events:none;z-index:2;background:#ffffff59;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.message{font-size:.75rem;padding:4px 0;border-bottom:1px solid rgba(0,0,0,.05);display:flex;gap:8px}.message:last-child{border-bottom:none}.message:before{content:"•";color:var(--text-muted)}.message.damage{color:var(--accent-danger)}.message.heal{color:var(--accent-success)}.message.system{color:var(--accent-energy)}.message-log:empty{display:none}.message-log .message:nth-last-child(n+5){opacity:.5}.enemy-info{composes:archive-card;padding:20px;background:#ffffffe6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.enemy-info h4{font-family:var(--font-display);font-size:.85rem;margin-bottom:15px;color:var(--text-primary)}.enemy-type{display:flex;align-items:center;margin:12px 0;font-size:.75rem;color:var(--text-secondary)}.enemy-color{width:12px;height:12px;margin-right:12px;border-radius:3px;border:1px solid rgba(0,0,0,.1)}.card-hand-panel{position:fixed;left:0;right:0;bottom:24px;z-index:220;display:flex;justify-content:center;align-items:flex-end;pointer-events:none}.card-hand-shell{position:relative;width:min(1200px,calc(100vw - 48px));display:flex;align-items:flex-end;gap:16px;padding:24px 18px 18px;border:1px solid rgba(0,0,0,.08);background:#fffffff2;box-shadow:0 -4px 24px #0000000f;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);pointer-events:auto;border-radius:18px;overflow:visible}.card-hand-shell:has(.hand-card:hover){overflow:visible;z-index:10}.card-hand-cards:has(.hand-card:hover){z-index:10;overflow:visible}.card-hand-meta{display:flex;flex-direction:column;gap:10px;min-width:92px;position:relative;z-index:1;align-self:stretch}.card-pile-stat{display:flex;flex-direction:column;justify-content:center;gap:2px;padding:10px 12px;border:1px solid rgba(0,0,0,.06);background:var(--bg-tertiary);border-radius:8px;flex:1}.card-pile-label{font-size:.6rem;letter-spacing:.05em;color:var(--text-muted)}.card-pile-value{font-family:var(--font-display);font-size:1.15rem;color:var(--text-primary)}.card-hand-cards{display:flex;align-items:stretch;gap:12px;flex:1;min-width:0;min-height:190px;overflow:visible;padding:2px 2px 0;position:relative;z-index:1}.hand-card{--card-accent: var(--accent-energy);position:relative;flex:0 0 146px;min-height:190px;padding:12px 12px 10px;border:1px solid rgba(0,0,0,.08);background:#fff;color:var(--text-primary);cursor:pointer;text-align:left;display:flex;flex-direction:column;gap:8px;border-radius:10px;box-shadow:0 2px 8px #0000000f;transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease,opacity .18s ease;-webkit-appearance:none;-moz-appearance:none;appearance:none}.hand-card:before{display:none}.hand-card:after{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--card-accent);border-radius:10px 10px 0 0;pointer-events:none}.hand-card:hover:not(.disabled){transform:translateY(-7px);border-color:var(--card-accent);box-shadow:0 8px 20px #0000001a;z-index:10;position:relative}.hand-card.selected{transform:translateY(-9px);border-color:var(--card-accent);box-shadow:0 8px 24px #0000001f,0 0 0 2px color-mix(in srgb,var(--card-accent) 30%,transparent);z-index:10;position:relative}.hand-card.disabled{opacity:.42;cursor:not-allowed}.hand-card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;min-height:30px}.hand-card-type{max-width:78px;font-size:.6rem;letter-spacing:.05em;text-transform:uppercase;color:var(--card-accent);line-height:1.2;font-weight:600}.hand-card-cost{padding:4px 8px;border-radius:999px;background:var(--bg-tertiary);border:1px solid rgba(0,0,0,.08);font-size:.6rem;color:var(--accent-energy);font-weight:600}.hand-card-title{font-family:var(--font-display);font-size:1.15rem;font-weight:700;letter-spacing:-.01em;line-height:1.1;padding-top:2px;min-height:2.4em}.hand-card-desc{flex:1;font-size:.7rem;line-height:1.55;color:var(--text-secondary);overflow:hidden}.hand-card-footer{display:flex;align-items:flex-end;min-height:18px}.hand-card-reason{min-height:1.1em;font-size:.6rem;color:var(--accent-danger);font-weight:500}.card-hand-panel .end-turn-btn{writing-mode:vertical-rl;text-orientation:mixed;padding:24px 10px;min-height:120px;font-size:.85rem;flex:0 0 auto;pointer-events:auto;align-self:stretch}.action-panel{position:fixed;right:30px;top:80px;width:240px;composes:archive-card;padding:20px;z-index:100;pointer-events:none;background:#ffffffe6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.action-panel-title{font-family:var(--font-display);font-size:.85rem;font-weight:600;margin-bottom:15px;text-align:center;color:var(--text-primary)}.action-buttons{display:flex;flex-direction:column;gap:10px;pointer-events:auto}.action-btn{background:var(--bg-tertiary);border:1px solid rgba(0,0,0,.06);padding:12px 15px;color:var(--text-primary);cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:10px;text-align:left;position:relative;border-radius:8px}.action-btn:hover:not(.disabled){border-color:var(--your-world-primary);background:var(--your-world-glow);transform:translate(-4px)}.action-btn.selected{border-color:var(--your-world-primary);background:var(--your-world-glow)}.action-btn.selected:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--your-world-primary);border-radius:4px 0 0 4px}.action-btn.disabled{opacity:.4;cursor:not-allowed}.action-icon{font-size:1.2rem;width:24px;text-align:center}.action-name{font-weight:600;font-size:.85rem;flex:1;white-space:nowrap}.action-count,.action-status,.skill-cost{font-size:.65rem;color:var(--text-secondary);white-space:nowrap}.skill-cost{color:var(--accent-energy)}.action-divider{height:1px;background:#0000000f;margin:10px 0}.skill-btn{position:relative;padding-left:40px;padding-top:10px;padding-bottom:10px;gap:8px}.skill-key{position:absolute;left:10px;top:50%;transform:translateY(-50%);font-size:.7rem;color:var(--text-muted);border:1px solid var(--text-muted);padding:2px 6px;border-radius:4px}.skill-btn:hover:not(.disabled) .skill-key{border-color:var(--your-world-primary);color:var(--your-world-primary)}.action-hint{margin-top:15px;padding:10px;font-size:.7rem;text-align:center;color:var(--text-secondary);border:1px dashed rgba(0,0,0,.1);background:var(--bg-secondary);border-radius:8px}.modal{position:fixed;top:0;left:0;width:100%;height:100%;background:#ffffffd9;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{composes:archive-card;padding:50px 60px;text-align:center;min-width:400px;border-width:2px;background:#fff;box-shadow:0 8px 30px #0000001a;border-radius:16px}.modal-content.victory{border-color:var(--accent-success)}.modal-content.victory:after{content:"任务完成";color:var(--accent-success)}.modal-content.defeat{border-color:var(--accent-danger)}.modal-content.defeat:after{content:"任务失败";color:var(--accent-danger)}.modal-content h2{font-family:var(--font-display);font-size:2.5rem;margin-bottom:25px;letter-spacing:-.02em}.modal-content.victory h2{color:var(--accent-success)}.modal-content.defeat h2{color:var(--accent-danger)}.modal-content p{margin-bottom:35px;color:var(--text-secondary);font-size:.9rem;line-height:1.8}.modal-content button{composes:skew-btn;padding:16px 50px}.modal-stats{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:30px;text-align:left;padding:20px;background:var(--bg-tertiary);border:1px solid rgba(0,0,0,.06);border-radius:10px}.modal-stats .stat-item{display:flex;justify-content:space-between;font-size:.8rem;padding:4px 8px}.modal-stats .stat-key{color:var(--text-secondary)}.modal-stats .stat-val{color:var(--text-primary);font-weight:600}.end-turn-btn.enemy-processing{animation:alert-pulse 1s infinite;border-color:var(--accent-energy);color:var(--accent-energy)}.end-turn-btn.stunned-btn{border-color:var(--accent-danger);color:var(--accent-danger);animation:alert-pulse .8s infinite}.world-indicator.world-preview{animation:world-preview-pulse .8s infinite alternate;border-width:2px}@keyframes world-preview-pulse{0%{border-color:var(--your-world-primary);box-shadow:0 0 8px var(--your-world-glow)}to{border-color:var(--water-world-primary);box-shadow:0 0 8px var(--water-world-glow)}}.skill-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.skill-tag{display:inline-block;padding:2px 8px;font-size:.6rem;font-weight:600;border-radius:10px;text-transform:uppercase;letter-spacing:.05em}.action-btn[data-tooltip]{position:relative}.action-btn[data-tooltip]:hover:after{content:attr(data-tooltip);position:absolute;left:-10px;top:50%;transform:translate(-100%) translateY(-50%);background:#fff;color:var(--text-secondary);border:1px solid rgba(0,0,0,.08);padding:6px 10px;font-size:.7rem;white-space:nowrap;z-index:200;pointer-events:none;border-radius:6px;box-shadow:0 2px 8px #00000014}@media(max-width:1200px){.enemy-info{display:none}}@media(max-width:1024px){.ui-left-panel{width:200px;left:20px}.message-log{width:min(320px,calc(100vw - 56px));top:120px;bottom:340px}.card-hand-shell{width:min(100vw - 24px,1200px);gap:12px;padding:14px}.hand-card{flex-basis:138px;min-height:176px}}@media(max-width:768px){.start-screen h1{font-size:2.5rem}.skill-grid{grid-template-columns:repeat(2,1fr)}.ui-left-panel{left:10px;top:80px;width:160px}.stats-panel,.enemy-info{padding:15px}.message-log{width:calc(100vw - 40px);top:auto;right:20px;left:auto;transform:none;bottom:360px;max-height:140px}.ui-top-bar{padding:15px 20px}.card-hand-panel{bottom:10px}.card-hand-shell{width:calc(100vw - 12px);gap:8px;padding:10px;flex-wrap:wrap}.card-hand-meta{flex-direction:row;width:100%;min-width:0}.card-pile-stat{flex:1}.card-hand-cards{order:3;width:100%;padding-top:6px}.card-hand-panel .end-turn-btn{writing-mode:horizontal-tb;padding:12px 20px;min-height:auto;font-size:.75rem;min-width:100px}}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--text-muted);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}@keyframes card-play-sequence{0%{transform:translateY(0) scale(1);opacity:1}25%{transform:translateY(-70px) scale(1.08);opacity:1}50%{transform:translateY(-70px) scale(1.08);opacity:1}to{transform:translate(var(--fly-dx),var(--fly-dy)) scale(.5);opacity:0}}@keyframes card-discard-fly{0%{transform:translate(0) scale(1);opacity:1}to{transform:translate(var(--fly-dx),var(--fly-dy)) scale(.5);opacity:0}}@keyframes card-draw-appear{0%{transform:translate(var(--draw-dx),var(--draw-dy)) scale(.5);opacity:0}to{transform:translate(0) scale(1);opacity:1}}@keyframes reshuffle-flash{0%,to{opacity:1;transform:scale(1)}25%{opacity:.3;transform:scale(1.15)}50%{opacity:1;transform:scale(1)}75%{opacity:.3;transform:scale(1.15)}}@keyframes reshuffle-badge{0%{transform:translate(-50%) translateY(0) scale(.8);opacity:0}20%{transform:translate(-50%) translateY(-5px) scale(1);opacity:1}80%{transform:translate(-50%) translateY(-5px) scale(1);opacity:1}to{transform:translate(-50%) translateY(-10px) scale(.9);opacity:0}}.card-anim-clone{position:fixed;z-index:9999;pointer-events:none;will-change:transform,opacity}.card-anim-clone .hand-card{cursor:default;margin:0}.pile-flash{animation:reshuffle-flash .5s ease-in-out}.reshuffle-badge{position:absolute;top:-20px;left:50%;transform:translate(-50%);font-size:.6rem;color:var(--accent-energy);white-space:nowrap;animation:reshuffle-badge .8s ease-out forwards;z-index:20}.card-hand-cards.animating{pointer-events:none}.hand-card.card-animating-out{visibility:hidden}
