*{box-sizing:border-box;margin:0;padding:0}ul,li{list-style:none}:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}#root{margin:0 auto;padding:2rem;text-align:center;width:100%;font-size:clamp(8px,1.5vh,16px)}.board{display:grid;grid-template-columns:1fr 1fr;gap:2rem;width:100%;margin:0 auto}button{padding:6px 12px;font-size:clamp(12px,1.5vh,1.2rem);color:#fff;background-color:#007bff;border:none;border-radius:4px;cursor:pointer;width:fit-content}button:disabled{background-color:#666;cursor:not-allowed}.board>div{min-width:0}.foes{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.board .actions{display:flex;gap:12px;justify-content:center}.btn-end-turn{margin-top:16px;padding:12px 24px;font-size:clamp(12px,1.5vh,1.2rem);font-weight:700;color:#fff;background-color:#d9534f;border:none;border-radius:8px;cursor:pointer;transition:background-color .3s ease}.btn-flee{margin-top:16px;padding:12px 24px;font-size:clamp(12px,1.5vh,1.2rem);font-weight:700;color:#fff;background-color:#adc910;border:none;border-radius:8px;cursor:pointer;transition:background-color .3s ease}.btn-flee:disabled{background-color:#666;cursor:not-allowed}.dice-pool-section{margin-top:20px;display:flex;flex-direction:column;align-items:center}.battle-report{position:fixed;top:0;left:0;width:100vw;height:100vh;background-color:#000c;color:#fff;overflow-y:auto;z-index:1000}.battle-report-content{position:fixed;top:50%;left:0;width:100vw;transform:translateY(-50%);background-color:#000;color:#fff;padding:20px;border-block:solid 2px #ff6666;max-height:80vh;overflow-y:auto;z-index:1100}.battle-report ul{list-style-type:none;padding:0;margin:0}.battle-report .fade-in{margin-bottom:8px;opacity:0;animation:fadeIn .5s forwards;animation-delay:var(--delay, 0s)}@keyframes fadeIn{to{opacity:1}}.battle-report .enemy{color:#fc0}.battle-report .ability{color:#6f6}.battle-report .damage,.battle-report .attacker{font-weight:700;color:#f66}.battle-report button{margin-top:16px;padding:8px 16px;font-size:1rem;font-weight:700;color:#333;background-color:#fff;border:none;border-radius:8px;cursor:pointer;transition:background-color .3s ease}.splash-image{max-width:300px;aspect-ratio:1/1;margin:20px 0}.splash-panel p{margin-block:20px}.die{font-weight:700;font-size:24px;background-color:#f9f6f2;color:#333;border-radius:4px;width:100%;align-content:center;aspect-ratio:1/1;z-index:10}.die.selected{outline:2px solid #007bff;background-color:#90ee90}.dice-pool-grid{display:grid;grid-template-columns:repeat(auto-fit,40px);gap:8px;width:100%;flex-shrink:0;padding:8px;min-height:60px;border:solid 2px #555}.dice-pool-row{display:contents}.dice-pool-cell{background-color:#333;border:2px solid #555;border-radius:4px;text-align:center;font-size:18px;color:#fff;display:flex;align-items:center;justify-content:center;min-height:40px;min-width:40px;aspect-ratio:1/1}.dice-slot{--slot-count: 3;display:grid;grid-template-columns:auto 1fr auto auto;padding:3px;border:2px solid #555;border-radius:8px;background-color:#222;width:100%;align-content:center}.dice-slot-grid{display:grid;grid-template-columns:repeat(var(--slot-count),1fr);gap:8px;margin-top:12px;margin-inline:auto;justify-items:center}.dice-slot-cell{aspect-ratio:1/1;border:2px dashed #555;border-radius:4px;text-align:center;font-size:18px;color:#fff;display:flex;align-items:center;justify-content:center;width:40px}.dice-slot-cell:hover{background-color:#555;border-color:#777}.dice-slot-totals{width:100%;height:100%;padding:8px;font-size:clamp(12px,1.5vh,1rem);color:#888;align-content:center;pointer-events:none}.dice-slot-success{border-color:green}.dice-slot-failure{border-color:red}.dice-slot-wounded{border:2px solid #888;border-radius:8px;background-color:#300;width:100%;height:100px;display:flex;align-items:center;justify-content:center;font-size:clamp(1rem,6vw,3rem)}.btn-move-dice,.btn-clear-dice{border:none;border-radius:4px;padding:4px 8px;cursor:pointer;font-size:clamp(10px,1.2vh,1rem)}:is(.btn-move-dice,.btn-clear-dice):disabled{opacity:.5;cursor:not-allowed}.btn-clear-dice{background-color:#d9534f;color:#fff}.btn-move-dice{background-color:#005f24;color:#fff}.card{border:1px solid #ccc;border-radius:8px;padding:5px;text-align:center}.card-slot{margin:12px 0}.item-card{display:flex;flex-direction:column;border:1px solid #ccc;border-radius:5px;padding:10px;align-items:center;height:100%}.item-card .item-ability{margin-top:auto}.skill-card{display:flex;flex-direction:column;border:1px solid #ccc;border-radius:5px;padding:10px;align-items:center;height:100%}.equipment{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;margin-top:10px}.equipment-card{padding:10px;border:1px solid #ccc;border-radius:5px;margin-bottom:10px}.skills{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.skill-card{padding:10px;border:1px solid #ccc;border-radius:5px;margin-bottom:10px}.skill-card.disabled{opacity:.5;pointer-events:none}.skill-card button{display:block;margin-top:8px;margin-inline:auto;padding:6px 12px;color:#fff;background-color:#007bff;border:none;border-radius:4px;cursor:pointer}.rewards{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px;max-width:1000px;margin-inline:auto;margin-block:40px}.rewards li{display:flex;flex-direction:column;border:1px solid #ccc;border-radius:5px;padding:10px;align-items:stretch;height:100%}.rewards .reward-card{flex:1;display:flex;flex-direction:column;margin-bottom:10px}.rewards li .reward-card:not(:has(+div.actions)){margin-bottom:40px}.rewards .actions{margin-top:auto;display:flex;justify-content:center}button.skip-reward-button{background-color:#d9534f}.reward-content{height:100%}.generic-reward-card{display:flex;flex-direction:column;border:1px solid #ccc;border-radius:5px;padding:10px;align-items:center;height:100%}.map{margin-top:2rem;overflow-x:scroll;overflow-y:hidden;width:100%;scrollbar-width:none}.map-grid{display:grid;grid-auto-flow:column;grid-auto-columns:min-content;gap:2rem}.map-tile{width:60px;height:60px;border:solid 1px #ccc;position:relative;transition:border .3s ease}.map-tile:before{content:"";position:absolute;inset:0;background-image:url(/map_tiles.png);background-size:120px 120px;transition:filter .3s ease}.map-tile.empty:before{background-image:none}.map-tile.encounter:before{background-position:0 0;filter:brightness(0) saturate(100%) invert(85%) sepia(82%) saturate(1000%) hue-rotate(360deg) brightness(102%) contrast(104%)}.map-tile.pursuers:before{background-position:0 0;filter:brightness(0) saturate(100%) invert(29%) sepia(98%) saturate(7495%) hue-rotate(358deg) brightness(97%) contrast(118%)}.map-tile.elite:before{background-position:-60px 0;filter:brightness(0) saturate(100%) invert(29%) sepia(98%) saturate(7495%) hue-rotate(358deg) brightness(97%) contrast(118%)}.map-tile.boss:before{background-position:0 -60px;filter:brightness(0) saturate(100%) invert(29%) sepia(98%) saturate(7495%) hue-rotate(358deg) brightness(97%) contrast(118%)}.map-tile.fire:before{background-position:-60px -60px;filter:brightness(0) saturate(100%) invert(57%) sepia(93%) saturate(1579%) hue-rotate(356deg) brightness(101%) contrast(105%)}.map-tile.past:before{border:2px solid #888;filter:brightness(0) saturate(100%) invert(74%) sepia(0%) saturate(0%) hue-rotate(179deg) brightness(91%) contrast(89%)}.map-tile.current{border:2px solid #007bff}.custom-drag-layer{position:fixed;pointer-events:none;left:0;top:0;width:100%;height:100%;z-index:1000}.die-preview{display:inline-block}.die-preview .die-face{width:50px;height:50px;display:flex;align-items:center;justify-content:center;border:2px solid #333;color:#333;border-radius:8px;background-color:#fff;font-size:24px;font-weight:700;opacity:.8;cursor:grabbing}
