@import"https://fonts.googleapis.com/css2?family=IM+Fell+English:ital@0;1&display=swap";*{margin:0;padding:0;box-sizing:border-box}body{background:#000;color:#e0e0e0;font-family:Courier New,monospace;overflow:hidden;width:100vw;height:100vh}#app{display:flex;flex-direction:column;width:100%;height:100%}.game-header{display:flex;justify-content:space-between;align-items:center;padding:8px 16px;background:#16213e;border-bottom:1px solid #333;flex-shrink:0}.game-header h1{font-size:18px;color:#e94560;letter-spacing:2px}.game-status{font-size:13px;color:#aaa}.game-main{display:flex;flex:1;overflow:hidden;position:relative}.grid-container{flex:1;display:flex;align-items:center;justify-content:center;overflow:auto}.side-panel{width:220px;background:#16213e;border-left:1px solid #333;padding:12px;display:flex;flex-direction:column;gap:12px;flex-shrink:0}.panel-section{border:1px solid #333;border-radius:4px;padding:8px}.panel-section h3{font-size:12px;text-transform:uppercase;color:#e94560;margin-bottom:6px;letter-spacing:1px}.entity-info{font-size:12px;line-height:1.6}.entity-info .label{color:#888}.entity-info .value{color:#e0e0e0}.health-bar{height:6px;background:#333;border-radius:3px;margin-top:4px;overflow:hidden}.health-bar-fill{height:100%;background:#2ecc71;border-radius:3px;transition:width .3s ease}.instructions{font-size:11px;color:#888;line-height:1.5}.hex-grid{cursor:pointer}.hex-cell{transition:fill .15s ease}.hex-cell:hover{filter:brightness(1.2)}.hex-cell.hex-reachable{fill:#2ecc714d!important;stroke:#2ecc71;stroke-width:2}.hex-cell.hex-path{fill:#2ecc718c!important;stroke:#27ae60;stroke-width:2}.hex-cell.hex-selected{fill:#3498db66!important;stroke:#3498db;stroke-width:2}.hex-cell.hex-goal{stroke:#f1c40f;stroke-width:2.5;stroke-dasharray:4 2}.hex-overlay .hex-cell{fill:transparent;stroke:#ffffff14;stroke-width:1;cursor:pointer}.hex-overlay .hex-cell:hover{fill:#ffffff0f;stroke:#fff3;filter:none}.hex-overlay .hex-cell.hex-reachable{fill:#2ecc7140;stroke:#2ecc7199;stroke-width:2}.hex-overlay .hex-cell.hex-reachable:hover{fill:#2ecc7173;stroke:#2ecc71e6}.entity{transition:transform .25s ease}.encounter-layout{display:grid;grid-template-columns:240px 1fr 240px;grid-template-rows:auto 1fr;width:100%;height:100%;background:#000}.encounter-center{grid-column:2;grid-row:2;display:flex;align-items:center;justify-content:center;overflow:hidden}.encounter-svg{width:100%;height:100%;display:block}.entity-token{pointer-events:none;filter:drop-shadow(0 2px 4px rgba(0,0,0,.7));transition:x .5s ease,y .5s ease}.encounter-panel{grid-row:2;background:#000000d9;border:1px solid rgba(212,96,26,.2);padding:16px 12px;display:flex;flex-direction:column;gap:20px;overflow-y:auto}.encounter-panel-left{grid-column:1;border-right:1px solid rgba(212,96,26,.3);display:flex;flex-direction:column}.event-log-wrapper{margin-top:auto;display:flex;flex-direction:column;min-height:0;border-top:1px solid rgba(212,96,26,.15)}.event-log-arrows{display:flex;justify-content:center;gap:12px;padding:2px 0}.event-log-arrow{font-size:8px;color:#d4601a33;cursor:pointer;line-height:1;transition:color .2s;-webkit-user-select:none;user-select:none;padding:0 4px}.event-log-arrow:hover{color:#d4601a80}.event-log{overflow-y:hidden;padding:4px 10px 6px;display:flex;flex-direction:column;gap:2px;max-height:calc(14em + 8px)}.event-log-entry{font-family:IM Fell English,serif;font-size:11px;color:#c4a96a99;line-height:1.4;flex-shrink:0}.hex-stats-box{margin-top:auto;padding:6px 10px;font-family:IM Fell English,serif;font-size:.85rem;color:#c4a96a;border-top:1px solid rgba(212,96,26,.3);min-height:1.4em}.encounter-panel-right{grid-column:3;border-left:1px solid rgba(212,96,26,.3)}.panel-entity{display:flex;flex-direction:column;align-items:center;gap:6px}.panel-portrait{width:150px;height:150px;object-fit:cover;border:1px solid rgba(212,96,26,.4);background:#000}.panel-name{font-family:IM Fell English,serif;font-size:16px;color:#d4601a;text-align:center}.ability-select{width:100%;font-family:IM Fell English,serif;font-size:14px;background:#000c;color:#e0e0e0;border:1px solid rgba(212,96,26,.4);padding:4px;cursor:pointer}.ability-select:focus{outline:none;border-color:#d4601a}.timeline-bar{grid-column:2;grid-row:1;background:#000000e6;border-bottom:1px solid rgba(212,96,26,.3);padding:4px 8px;overflow-x:auto}.timeline-row{display:flex;align-items:center;gap:0}.timeline-header{margin-bottom:2px}.timeline-label{width:80px;flex-shrink:0;font-family:IM Fell English,serif;font-size:11px;color:#d4601a;padding-right:4px;text-align:right;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.timeline-action-label{font-family:IM Fell English,serif;font-size:10px;color:#d4601a80;font-style:italic;padding-left:6px;white-space:nowrap}.timeline-tick{width:28px;height:20px;flex-shrink:0;border:1px solid rgba(212,96,26,.15);display:flex;align-items:center;justify-content:center;font-family:IM Fell English,serif;font-size:10px;color:#d4601a66}.timeline-tick.timeline-current{background:#d4601a33;border-color:#d4601a80;color:#d4601a}.timeline-tick.timeline-action{background:#d4601a59;border-color:#d4601a}.timeline-tick.timeline-action:after{content:"◆";color:#d4601a;font-size:10px}.victory-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:100}.victory-message{background:#16213e;border:2px solid #f1c40f;border-radius:8px;padding:32px 48px;text-align:center}.victory-message h2{font-size:28px;color:#f1c40f;margin-bottom:12px}.victory-message p{font-size:14px;color:#ccc}.preloader-screen{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:#000}.preloader-pct{font-family:IM Fell English,serif;font-size:1.4rem;color:#8a7a5a;letter-spacing:.1em;opacity:.7}.lantern-screen{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:#000}.lantern-img{max-height:45vh;cursor:pointer;opacity:0;animation:lantern-appear 2s ease forwards}@keyframes lantern-appear{0%{opacity:0}to{opacity:.85}}.lantern-img.lantern-snuffed{animation:lantern-dim .15s ease forwards}@keyframes lantern-dim{0%{opacity:.85}to{opacity:.5}}.lantern-screen.lantern-fade-out{animation:lantern-to-black .8s ease forwards}@keyframes lantern-to-black{0%{opacity:1}to{opacity:0}}.char-select{width:100%;max-height:100%}.figurine-label{opacity:0;transition:opacity .3s ease}.figurine-group:hover .figurine-label{opacity:.75}.figurine-group.figurine-selected:hover .figurine-label{opacity:0}.parchment{position:absolute;left:3%;top:8%;width:32%;max-height:84%;background:linear-gradient(168deg,#dab078,#d2a46c 40%,#c89a62);box-shadow:inset 0 0 20px #2814054d,0 4px 20px #00000080;padding:32px 28px;overflow-y:auto;opacity:0;animation:parchment-appear .8s ease forwards;z-index:20;clip-path:polygon(0% 1%,2% 0%,8% .5%,15% 0%,22% .3%,35% 0%,45% .4%,55% 0%,65% .3%,78% 0%,85% .5%,92% 0%,98% .3%,100% 1%,100% 4%,99.5% 12%,100% 22%,99.6% 35%,100% 48%,99.5% 60%,100% 72%,99.6% 85%,100% 94%,99.5% 99%,98% 100%,90% 99.5%,82% 100%,70% 99.6%,58% 100%,45% 99.5%,32% 100%,20% 99.6%,10% 100%,3% 99.5%,0% 99%,.5% 90%,0% 78%,.4% 65%,0% 52%,.5% 38%,0% 25%,.4% 12%)}.parchment:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(30,10,0,.04) 2px,rgba(30,10,0,.04) 4px),repeating-linear-gradient(90deg,transparent,transparent 3px,rgba(20,8,0,.03) 3px,rgba(20,8,0,.03) 6px),radial-gradient(ellipse at 15% 10%,rgba(30,10,0,.15) 0%,transparent 50%),radial-gradient(ellipse at 85% 90%,rgba(30,10,0,.1) 0%,transparent 40%);pointer-events:none;z-index:1}.parchment>*{position:relative;z-index:2}@keyframes parchment-appear{0%{opacity:0}to{opacity:.85}}.parchment-story{flex-shrink:0}.parchment-entry{font-family:IM Fell English,serif;font-size:28px;line-height:1.45;color:#0a0805;margin-bottom:18px;opacity:0;animation:entry-appear .5s ease forwards}@keyframes entry-appear{0%{opacity:0}to{opacity:.7}}.parchment-choices{display:flex;flex-direction:column;gap:16px;padding-top:20px;border-top:1px solid rgba(20,10,0,.2);margin-top:8px}.parchment-option{font-family:IM Fell English,serif;font-style:italic;font-size:28px;line-height:1.45;color:#12100a;cursor:pointer;padding:12px 16px;border-radius:2px;transition:background .2s ease,color .2s ease}.parchment-option:hover{background:#0a05001a;color:#000}.portrait-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;z-index:30;opacity:0;animation:portrait-appear .8s ease forwards;pointer-events:none}.portrait-container{display:flex;flex-direction:column;align-items:center;gap:12px;pointer-events:auto}.portrait-img{max-width:38vw;max-height:72vh;object-fit:contain;filter:drop-shadow(0 2px 4px rgba(0,0,0,.6)) drop-shadow(0 8px 16px rgba(0,0,0,.5)) drop-shadow(0 0 30px rgba(0,0,0,.4));opacity:1;transition:opacity .5s ease}.portrait-img.figurine-view{background:#000;padding:16px 24px;filter:drop-shadow(0 3px 6px rgba(0,0,0,.8)) drop-shadow(0 8px 24px rgba(0,0,0,.7)) drop-shadow(0 0 40px rgba(0,0,0,.5))}.portrait-img.portrait-fade-out{opacity:0}.portrait-img.portrait-fade-in{animation:portrait-appear .6s ease forwards}.portrait-check{width:48px;height:48px;border-radius:50%;border:2px solid #d4601a;background:#000000b3;color:#d4601a;font-size:22px;cursor:pointer;transition:background .2s ease,transform .15s ease;font-family:IM Fell English,serif}.portrait-check:hover{background:#d4601a33;transform:scale(1.1)}.portrait-overlay.portrait-fade-out{opacity:0;transition:opacity .6s ease}@keyframes portrait-appear{0%{opacity:0}to{opacity:1}}.world-map{width:100%;max-height:100%}.title-name{opacity:0;animation:title-fade-in 3.25s ease forwards;animation-delay:5.4s}.title-begin-group{opacity:0;animation:title-fade-in 1.4s ease forwards;animation-delay:9.4s}.title-dot{opacity:0;transition:opacity .3s ease}.title-begin-group:hover .title-dot{opacity:.6}@keyframes title-fade-in{0%{opacity:0}to{opacity:.6}}.screen-fade{animation:screen-fade-in .4s ease both}@keyframes screen-fade-in{0%{opacity:0}to{opacity:1}}.mute-btn{position:fixed;bottom:6px;right:8px;z-index:9999;background:none;border:none;color:#50505066;font-size:14px;cursor:pointer;padding:2px 4px;line-height:1;transition:color .2s}.mute-btn:hover{color:#78787899}.mute-btn.muted{color:#50505040;text-decoration:line-through}.name-entry-screen{display:flex;align-items:center;gap:12px;opacity:0;animation:parchment-appear 1s ease forwards}.name-input{font-family:IM Fell English,serif;font-size:22px;background:#0000;border:none;border-bottom:1px solid rgba(212,96,26,.4);color:#d4601a;padding:6px 4px;width:200px;outline:none;text-align:center}.name-input::placeholder{color:#d4601a4d;font-style:italic}.name-input:focus{border-bottom-color:#d4601a}.name-check{width:36px;height:36px;border-radius:50%;border:1px solid rgba(212,96,26,.4);background:#0000;color:#d4601a;font-size:18px;cursor:pointer;transition:background .2s ease,border-color .2s ease;font-family:IM Fell English,serif}.name-check:hover{background:#d4601a1a;border-color:#d4601a}.controller-panel{position:absolute;top:12px;right:12px;background:#000000d9;border:1px solid rgba(212,96,26,.3);padding:10px 14px;font-family:IM Fell English,serif;font-size:14px;color:#c4a96a;z-index:25;display:flex;flex-direction:column;gap:6px;min-width:160px}.controller-panel .controller-label{font-size:11px;color:#d4601a80;text-transform:uppercase;letter-spacing:.5px}.controller-panel .controller-name{color:#d4601a;font-style:italic}.controller-panel .player-list{display:flex;flex-direction:column;gap:4px;margin-top:4px}.controller-panel button{font-family:IM Fell English,serif;font-size:12px;background:#0009;border:1px solid rgba(212,96,26,.3);color:#c4a96a;padding:4px 8px;cursor:pointer;transition:background .2s,border-color .2s}.controller-panel button:hover{background:#d4601a26;border-color:#d4601a}.parchment-option.readonly{cursor:default;color:#4a4030;font-style:italic}.parchment-option.readonly:hover{background:transparent;color:#4a4030}.assignment-panel{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;z-index:30;background:#000000b3;opacity:0;animation:portrait-appear .8s ease forwards}.assignment-inner{background:#000000e6;border:1px solid rgba(212,96,26,.4);padding:32px 40px;display:flex;flex-direction:column;align-items:center;gap:24px;max-width:700px}.assignment-title{font-family:IM Fell English,serif;font-size:28px;color:#d4601a;font-style:italic}.assignment-cards{display:flex;gap:32px}.assignment-card{display:flex;flex-direction:column;align-items:center;gap:10px;background:#0009;border:1px solid rgba(212,96,26,.3);padding:16px;min-width:200px}.assignment-card img{width:120px;height:120px;object-fit:contain}.assignment-card .card-class{font-family:IM Fell English,serif;font-size:18px;color:#d4601a;font-style:italic}.assignment-card select{font-family:IM Fell English,serif;font-size:14px;background:#0009;color:#c4a96a;border:1px solid rgba(212,96,26,.3);padding:4px 8px;cursor:pointer;width:100%;-webkit-appearance:none;-moz-appearance:none;appearance:none}.assignment-card select option{background:#1a1008;color:#c4a96a}.assignment-card select:focus{outline:none;border-color:#d4601a}.assignment-start{font-family:IM Fell English,serif;font-size:22px;font-style:italic;background:#000000b3;border:1px solid rgba(212,96,26,.5);color:#d4601a;padding:10px 32px;cursor:pointer;transition:background .2s,border-color .2s}.assignment-start:hover:not(:disabled){background:#d4601a26;border-color:#d4601a}.assignment-start:disabled{opacity:.3;cursor:default}.assignment-waiting{font-family:IM Fell English,serif;font-size:16px;color:#c4a96a;font-style:italic}
