:root{--cell-size: 40px;--grid-width: 15;--grid-height: 15;--bg-color: #1a1a1a;--ui-bg: rgba(255, 255, 255, .1);--ui-border: rgba(255, 255, 255, .2);--primary-color: #4caf50;--accent-color: #ff9800;--text-color: #ffffff;--danger-color: #f44336;--ap-color: #2196f3;--mp-color: #4caf50}body{margin:0;padding:0;background-color:var(--bg-color);color:var(--text-color);font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;overflow:hidden;display:flex;justify-content:center;align-items:center;height:100vh;-webkit-user-select:none;user-select:none}#wallet-tab{position:fixed;top:0;left:0;right:0;padding:20px 30px;display:flex;justify-content:flex-end;align-items:center;background:transparent;color:#e8f7ff;font-family:Nunito,sans-serif;z-index:999;border-bottom:none;pointer-events:none}#wallet-tab>*{pointer-events:auto}#wallet-connected-container{display:flex;align-items:center;gap:15px;background:#0009;padding:8px 16px;border-radius:20px;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);border:1px solid rgba(255,255,255,.1)}.clickable-text{cursor:pointer;font-weight:700;transition:color .2s}.clickable-text:hover{color:#00f5a0;text-decoration:underline}#wallet-credits{color:#00f5a0;margin-right:10px}#wallet-address{color:#fff}#wallet-connect{background:#00f5a0;border:none;border-radius:999px;padding:10px 24px;font-weight:800;font-family:Nunito,sans-serif;cursor:pointer;color:#03151f;box-shadow:0 4px 15px #00f5a066;transition:transform .15s ease,box-shadow .2s ease;text-transform:uppercase;letter-spacing:.5px}#wallet-connect:hover{transform:translateY(-2px);box-shadow:0 6px 20px #00f5a099}#wallet-connect:active{transform:translateY(1px)}#app{position:relative;width:100%;height:100%;display:flex;justify-content:center;align-items:center}#menu-screen{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;flex-direction:column;justify-content:center;align-items:center;z-index:100;overflow:hidden}.menu-background{position:absolute;top:0;left:0;width:100%;height:100%;background:url(/bg-fantasy.jpg) no-repeat center center/cover;z-index:-1;filter:brightness(.9)}.menu-content{background:#ffffffd9;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);padding:2rem 4rem;border-radius:30px;border:4px solid #5d4037;box-shadow:0 10px 30px #0000004d;text-align:center;animation:fadeIn .8s ease-out;max-width:800px;width:90%}#menu-screen h1{font-family:Fredoka One,cursive;font-size:4rem;margin-bottom:2rem;color:#2e7d32;text-transform:uppercase;letter-spacing:2px;text-shadow:2px 2px 0px #fff,4px 4px 0px #5d4037}.class-selection{margin-bottom:2rem}.class-selection h2{font-family:Nunito,sans-serif;color:#5d4037;margin-bottom:1.5rem;font-weight:700}.class-options{display:flex;justify-content:center;gap:2rem;flex-wrap:wrap}.class-card{background:#fff;border:3px solid #a1887f;border-radius:15px;padding:1.5rem;width:180px;cursor:pointer;transition:all .3s cubic-bezier(.175,.885,.32,1.275);position:relative;overflow:hidden}.class-card:hover{transform:translateY(-10px);border-color:#2e7d32;box-shadow:0 10px 20px #2e7d3233}.class-card.selected{border-color:#2e7d32;background:#e8f5e9;transform:scale(1.05);box-shadow:0 0 0 4px #2e7d324d}.card-image{width:100px;height:100px;margin:0 auto 1rem;background-size:contain;background-repeat:no-repeat;background-position:center}.pepe-preview{background-image:url(/sprites/pepe_r0_c21.png)}.doge-preview{background-image:url(/sprites/doge_r0_c9.png);transform:scale(1.5);transform-origin:center}.class-card h3{font-family:Fredoka One,cursive;color:#3e2723;margin:.5rem 0;font-size:1.2rem}.class-card p{font-family:Nunito,sans-serif;color:#795548;font-size:.9rem;margin:0}#start-btn{font-family:Fredoka One,cursive;font-size:2rem;padding:15px 50px;background:linear-gradient(to bottom,#66bb6a,#43a047);color:#fff;border:none;border-radius:50px;border-bottom:6px solid #2e7d32;cursor:pointer;transition:all .2s ease;text-transform:uppercase;letter-spacing:1px;margin-top:1rem;text-shadow:1px 1px 2px rgba(0,0,0,.2)}#start-btn:hover:not(:disabled){transform:translateY(-2px);filter:brightness(1.1)}#start-btn:active:not(:disabled){transform:translateY(2px);border-bottom-width:2px;margin-top:calc(1rem + 4px)}#start-btn:disabled{background:#bdbdbd;border-bottom-color:#9e9e9e;cursor:not-allowed;transform:none}#credits-modal{position:fixed;top:0;right:0;bottom:0;left:0;display:none;align-items:center;justify-content:center;z-index:1000}#credits-modal.is-visible{display:flex}.credits-modal__backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#050a14a6;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.credits-modal__panel{position:relative;width:min(420px,90vw);max-height:90vh;background:#0c1526;border-radius:24px;border:1px solid rgba(255,255,255,.08);color:#f4f8ff;box-shadow:0 25px 80px #0006;display:flex;flex-direction:column}.credits-modal__header{padding:18px 22px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid rgba(255,255,255,.08)}.credits-modal__header h3{margin:0;font-size:1.2rem}#credits-modal-close{border:none;background:transparent;color:#fff;font-size:1.4rem;cursor:pointer}.credits-modal__body{padding:18px 22px;overflow-y:auto;max-height:60vh}.credits-modal__item{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;padding:12px 0;border-bottom:1px solid rgba(255,255,255,.05)}.credits-modal__item .title{font-weight:700}.credits-modal__item .subtitle{font-size:.85rem;color:#ffffffb3}.credits-modal__item button{border:none;border-radius:999px;padding:6px 14px;font-weight:600;cursor:pointer;background:#00f5a0;color:#091623}.credits-modal__item button:disabled{background:#fff3;color:#fff9;cursor:not-allowed}.credits-modal__footer{padding:0 22px 18px;font-size:.75rem;color:#fff9}.credits-modal__error{color:#ff8a80;font-weight:600}.credits-modal__message{padding:0 22px 14px;font-size:.85rem;color:#8df5c2}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.class-options{display:flex;gap:30px;justify-content:center;margin-bottom:40px}.class-card{background:#ffffff0d;border:2px solid transparent;border-radius:15px;padding:20px;width:200px;cursor:pointer;transition:all .3s}.class-card:hover{background:#ffffff1a;transform:translateY(-10px)}.class-card.selected{border-color:#4caf50;background:#4caf501a;box-shadow:0 0 20px #4caf504d}.class-icon{width:100px;height:100px;margin:0 auto 20px;background-size:contain;background-repeat:no-repeat;background-position:center}.pepe-icon{background-image:url(/sprites/pepe_r0_c21.png)}.doge-icon{background-image:url(/sprites/doge_r0_c9.png)}.entity.Pepe .entity-sprite{bottom:20px}.entity.Pepe.Warrior .entity-sprite{filter:drop-shadow(0 0 10px rgba(239,83,80,.6))}.entity.Doge .entity-sprite{width:159%;height:240%}.entity.Doge.Ranger .entity-sprite{filter:drop-shadow(0 0 10px rgba(255,215,0,.6))}.entity.Pepe.Ranger .entity-sprite{filter:drop-shadow(0 0 10px rgba(102,187,106,.6))}#start-game-btn{padding:15px 40px;font-size:1.5em;background:#4caf50;color:#fff;border:none;border-radius:10px;cursor:pointer;transition:all .2s;text-transform:uppercase;font-weight:700;letter-spacing:2px}#start-game-btn:disabled{background:#555;cursor:not-allowed;opacity:.5}#start-game-btn:not(:disabled):hover{background:#43a047;transform:scale(1.05);box-shadow:0 0 20px #4caf5080}#end-screen{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,#2b323af2,#1a1a1af2);display:flex;justify-content:center;align-items:center;z-index:2000;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.end-screen-content{text-align:center;color:#fff;background:#000000b3;padding:60px;border-radius:20px;border:3px solid #444;box-shadow:0 0 50px #000c}#end-screen-title{font-size:4em;margin-bottom:20px;text-shadow:0 0 30px rgba(76,175,80,.8);letter-spacing:5px;text-transform:uppercase}#end-screen-title.victory{color:#4caf50}#end-screen-title.defeat{color:#f44336}#end-screen-message{font-size:1.5em;margin-bottom:40px;opacity:.9}#back-to-menu-btn{padding:15px 40px;font-size:1.3em;background:#4caf50;color:#fff;border:none;border-radius:10px;cursor:pointer;transition:all .2s;text-transform:uppercase;font-weight:700;letter-spacing:2px}#back-to-menu-btn:hover{background:#43a047;transform:scale(1.05);box-shadow:0 0 20px #4caf5080}#turn-indicator{position:absolute;top:20px;left:50%;transform:translate(-50%);font-size:20px;font-weight:700;color:#fff;text-shadow:0 2px 4px black;z-index:1000}#game-container{position:relative;width:100%;height:100%;background-image:url(/map-bg.png);background-position:40% 35%;background-repeat:no-repeat;background-size:150%;overflow:hidden}#iso-grid{position:relative;transform:rotateX(60deg) rotate(45deg);transform-style:preserve-3d;width:calc(var(--cell-size) * var(--grid-width));height:calc(var(--cell-size) * var(--grid-height));background:transparent;box-shadow:none;border:none;margin:100px auto auto}.cell{position:absolute;width:calc(var(--cell-size) + 1px);height:calc(var(--cell-size) + 1px);background-color:#ffffff0d;border:1px solid rgba(255,255,255,.3);box-sizing:border-box;transition:background-color .2s,transform .2s,border-color .2s;transform-style:preserve-3d}.cell:hover{background-color:#fff3;border:1px solid rgba(255,255,255,.6);cursor:pointer;transform:translateZ(5px)}.cell.highlight-move{background-color:#4caf5080;box-shadow:0 0 10px var(--mp-color)}.cell.highlight-spell{background-color:#2196f380;box-shadow:0 0 10px var(--ap-color)}.cell.highlight-attack{background-color:#f4433680;box-shadow:0 0 10px var(--danger-color)}.cell.highlight-preview{background-color:#ff980099;box-shadow:0 0 15px #ff9800;border:2px solid #ff9800}.cell.obstacle{background-color:#388e3c;transform:translateZ(30px);box-shadow:none;border:1px solid #1b5e20}.cell.obstacle:after{content:"";position:absolute;left:0;bottom:-30px;width:100%;height:30px;background-color:#1b5e20;transform-origin:top;transform:rotateX(-90deg);border:1px solid #003300}.cell.obstacle:before{content:"";position:absolute;right:-30px;top:0;width:30px;height:100%;background-color:#2e7d32;transform-origin:left;transform:rotateY(90deg);border:1px solid #003300}.entity{position:absolute;width:var(--cell-size);height:var(--cell-size);transform-origin:center center;transform:translateZ(0) rotate(-45deg) rotateX(-60deg) translateY(0);pointer-events:none;z-index:10;display:flex;justify-content:center;align-items:flex-end;transform-style:preserve-3d}.entity-sprite{width:106%;height:160%;background-size:contain;background-repeat:no-repeat;background-position:bottom center;position:relative;bottom:10px;filter:drop-shadow(0 5px 5px rgba(0,0,0,.5));transition:filter .3s}.spell-effect{position:absolute;width:100%;height:100%;pointer-events:none;z-index:100}.effect-slash{animation:slash-swing .6s ease-out forwards;background:linear-gradient(135deg,transparent 40%,#795548 45%,#d7ccc8 50%,#795548 55%,transparent 60%);transform-origin:center}@keyframes slash-swing{0%{transform:rotate(-45deg) scale(.5);opacity:0}50%{opacity:1}to{transform:rotate(45deg) scale(1.5);opacity:0}}.effect-bolt{animation:bolt-impact .7s ease-out forwards;background:radial-gradient(circle,#ff5722 0%,#ff9800 30%,#ffc107 60%,transparent 100%)}@keyframes bolt-impact{0%{transform:scale(.3);opacity:1;filter:brightness(2)}50%{transform:scale(1.2);opacity:1}to{transform:scale(2);opacity:0;filter:brightness(1)}}.effect-leap-out{animation:leap-fade-out .15s ease-out forwards;background:radial-gradient(circle,#64b5f6 0%,#2196f3 40%,transparent 70%)}@keyframes leap-fade-out{0%{transform:scale(1);opacity:1}to{transform:scale(2) rotate(180deg);opacity:0}}.effect-leap-in{animation:leap-fade-in .15s ease-out forwards;background:radial-gradient(circle,#64b5f6 0%,#2196f3 40%,transparent 70%)}@keyframes leap-fade-in{0%{transform:scale(2) rotate(-180deg);opacity:0}to{transform:scale(1);opacity:1}}.effect-rage{animation:rage-pulse .8s ease-out forwards;background:radial-gradient(circle,#f44336 0%,#ff5722 30%,#ff9800 60%,transparent 100%)}@keyframes rage-pulse{0%,to{transform:scale(.5);opacity:0}25%{transform:scale(1.3);opacity:1;filter:brightness(1.5)}50%{transform:scale(.8);opacity:.8}75%{transform:scale(1.5);opacity:1}}.effect-hook{animation:hook-pull .6s ease-out forwards;background:repeating-linear-gradient(45deg,#607d8b,#607d8b 10px,#90a4ae 10px,#90a4ae 20px);clip-path:polygon(40% 0%,60% 0%,60% 100%,40% 100%)}@keyframes hook-pull{0%{transform:translate(-100%) scaleX(.5);opacity:1}50%{transform:translate(0) scaleX(1);opacity:1}to{transform:translate(100%) scaleX(.5);opacity:0}}.effect-bash{animation:bash-impact .6s ease-out forwards;background:radial-gradient(circle,#8d6e63 0%,#a1887f 30%,#bcaaa4 60%,transparent 100%)}@keyframes bash-impact{0%{transform:scale(.5);opacity:1;filter:brightness(1.5)}30%{transform:scale(1) rotate(15deg);opacity:1}60%{transform:scale(1.5) rotate(-15deg);opacity:.7}to{transform:scale(2.5);opacity:0}}@keyframes projectile{0%{transform:translate(0) scale(.5);opacity:1}to{transform:translate(var(--tx),var(--ty)) scale(1);opacity:0}}@keyframes explosion{0%{transform:scale(.5);opacity:1;background-color:#fffc}50%{transform:scale(1.5);opacity:.8}to{transform:scale(2);opacity:0}}@keyframes buff-glow{0%{filter:drop-shadow(0 0 5px gold);transform:scale(1)}50%{filter:drop-shadow(0 0 20px gold);transform:scale(1.1)}to{filter:drop-shadow(0 0 5px gold);transform:scale(1)}}@keyframes teleport-out{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(.1) translateY(-50px)}}@keyframes teleport-in{0%{opacity:0;transform:scale(.1) translateY(-50px)}to{opacity:1;transform:scale(1)}}.spell-effect{position:absolute;width:var(--cell-size);height:var(--cell-size);pointer-events:none;z-index:20;border-radius:50%}.effect-projectile{background:radial-gradient(circle,#ff9800,transparent);width:20px;height:20px;z-index:30}.effect-explosion{background:radial-gradient(circle,rgba(255,87,34,.8),transparent)}.effect-earth{background:radial-gradient(circle,#795548,transparent)}.effect-wind{background:radial-gradient(circle,#e0e0e0,transparent);border:2px solid #fff}.entity.Knight .entity-sprite{filter:drop-shadow(0 0 10px rgba(239,83,80,.6))}.entity.Mercenary .entity-sprite{filter:drop-shadow(0 0 10px rgba(102,187,106,.6))}.entity.Iop .entity-sprite{filter:drop-shadow(0 0 10px rgba(239,83,80,.6))}.entity.Cra .entity-sprite{filter:drop-shadow(0 0 10px rgba(102,187,106,.6))}#ui-layer{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;display:flex;flex-direction:column;justify-content:space-between;padding:20px;box-sizing:border-box}.hud-top{display:flex;justify-content:space-between;width:100%;position:absolute;top:0;left:0;padding:10px 20px;box-sizing:border-box}.character-info{background:var(--ui-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--ui-border);padding:10px 20px;border-radius:10px;display:flex;gap:20px;align-items:center;pointer-events:auto}.stat-orb{width:40px;height:40px;border-radius:50%;display:flex;justify-content:center;align-items:center;font-weight:700;font-size:1.2em;box-shadow:inset 0 0 10px #00000080}.ap-orb{background:radial-gradient(circle at 30% 30%,#64b5f6,#1976d2);border:2px solid #1565c0}.mp-orb{background:radial-gradient(circle at 30% 30%,#81c784,#388e3c);border:2px solid #2e7d32}.hp-bar-container{width:150px;height:20px;background:#333;border-radius:10px;overflow:hidden;border:1px solid #555;position:relative;display:flex;align-items:center;justify-content:center}.hp-bar-fill{position:absolute;left:0;top:0;height:100%;background:linear-gradient(90deg,#ef5350,#c62828);width:100%;transition:width .3s}.hp-bar-text{position:relative;z-index:1;color:#fff;font-weight:700;font-size:11px;text-shadow:1px 1px 2px rgba(0,0,0,.8);pointer-events:none}.hud-bottom{display:flex;justify-content:center;align-items:flex-end;gap:20px;pointer-events:auto;position:absolute;bottom:20px;left:50%;transform:translate(-50%)}#spell-bar{display:flex;gap:10px;background:var(--ui-bg);padding:10px;border-radius:10px;border:1px solid var(--ui-border);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.spell-slot{width:50px;height:50px;background:#00000080;border:2px solid #555;border-radius:5px;cursor:pointer;transition:all .2s;display:flex;justify-content:center;align-items:center;position:relative}.spell-slot:hover{border-color:var(--accent-color);transform:translateY(-5px)}.spell-slot.active{border-color:var(--ap-color);box-shadow:0 0 10px var(--ap-color)}.spell-slot.disabled{opacity:.5;cursor:not-allowed;filter:grayscale(1)}.spell-icon{width:80%;height:80%;background-size:contain;background-repeat:no-repeat;background-position:center}.spell-cost{position:absolute;bottom:2px;right:4px;background:#2196f3e6;color:#fff;font-size:10px;font-weight:700;padding:2px 4px;border-radius:3px;min-width:12px;text-align:center;box-shadow:0 1px 2px #00000080}.spell-hotkey{position:absolute;top:2px;left:4px;background:#fff3;color:#fff;font-size:11px;font-weight:700;padding:2px 5px;border-radius:3px;min-width:14px;text-align:center;box-shadow:0 1px 2px #00000080;border:1px solid rgba(255,255,255,.3)}#turn-btn{width:80px;height:80px;border-radius:50%;background:radial-gradient(circle at 30% 30%,#ffb74d,#f57c00);border:4px solid #ef6c00;color:#fff;font-weight:700;cursor:pointer;box-shadow:0 0 20px #ff980066;transition:all .2s;display:flex;justify-content:center;align-items:center;text-align:center;font-size:.9em}#turn-btn:hover{transform:scale(1.1);box-shadow:0 0 30px #ff980099}#turn-btn:active{transform:scale(.95)}#combat-log{position:absolute;bottom:20px;left:20px;width:300px;height:150px;background:#000000b3;border-radius:5px;padding:10px;overflow-y:auto;font-size:.9em;color:#ddd;pointer-events:auto;border:1px solid #444}.log-entry{margin-bottom:5px;border-bottom:1px solid rgba(255,255,255,.1);padding-bottom:2px}.log-entry.damage{color:#ef5350}.log-entry.heal{color:#66bb6a}.log-entry.info{color:#90caf9}#turn-counter{position:absolute;bottom:20px;right:20px;background:#000000b3;color:#fff;padding:10px 20px;border-radius:5px;font-size:14px;font-weight:700;border:1px solid #444;pointer-events:none}.floating-text{position:absolute;color:#fff;font-weight:700;font-size:1.5em;pointer-events:none;animation:floatUp 1s ease-out forwards;z-index:100;text-shadow:2px 2px 0 #000}@keyframes floatUp{0%{transform:translateY(0) scale(1);opacity:1}to{transform:translateY(-50px) scale(1.2);opacity:0}}#chat-input{position:absolute;bottom:120px;left:20px;width:300px;padding:10px;background:#000000b3;border:1px solid rgba(255,255,255,.2);border-radius:5px;color:#fff;font-family:Nunito,sans-serif;z-index:1000}#waiting-message{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;color:#fff;background:#000c;padding:20px;border-radius:10px;z-index:2000;display:none}#waiting-message h2{margin-bottom:10px;color:#4caf50}#chat-input:focus{outline:none;border-color:#4caf50;background:#000000e6}#combat-log{bottom:170px!important;height:200px}.log-entry.chat{color:#fff;margin-top:4px}.log-entry.chat .sender{font-weight:700;margin-right:5px}.log-entry.chat.player .sender{color:#4caf50}.log-entry.chat.opponent .sender{color:#f44336}
