:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:dark;color:#ffffffde;background-color:#0a0a0a;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;background-color:#0a0a0a;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}.title-screen{max-width:800px;margin:0 auto;padding:40px 20px;text-align:center}.title-header{margin-bottom:50px;padding:30px;background:linear-gradient(135deg,#1a1a2e,#0f0f1a);border:3px solid #3d3d5c;border-radius:8px;box-shadow:0 0 30px #3d3d5c4d,inset 0 0 20px #00000080}.title-main{margin:0 0 20px;font-size:3em;font-weight:700;color:#8b9da9;text-shadow:0 0 10px rgba(139,157,169,.5),0 2px 4px rgba(0,0,0,.8);letter-spacing:2px}.title-subtitle{margin:0;font-size:1.2em;color:#6d7d89;font-style:italic;text-shadow:0 1px 2px rgba(0,0,0,.8)}.title-menu{margin:40px 0}.title-button{font-size:1.3em;padding:15px 40px;background:linear-gradient(135deg,#2d3561,#1a1f3a);border:2px solid #4a5f8f;color:#c9d5e0;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:2px;font-weight:700;box-shadow:0 4px 8px #00000080}.title-button:hover{background:linear-gradient(135deg,#3d4671,#2a2f4a);border-color:#6a7f9f;box-shadow:0 0 20px #4a5f8f80,0 4px 8px #00000080;transform:translateY(-2px)}.title-flavor{margin-top:50px;padding:20px;background:#0000004d;border:1px solid #2d2d3d;border-radius:4px;line-height:1.8}.title-flavor p{margin:8px 0;color:#7d8d99;font-style:italic;font-size:.95em}#app{width:100%;min-height:100vh;padding:clamp(16px,2vw,32px);text-align:center;box-sizing:border-box}.exploration-container{display:flex;gap:20px;align-items:stretch;justify-content:space-between;text-align:left;width:100%}.viewport-container{flex:1 1 60%;border:3px solid #3d3d3d;background:#0a0a0a;box-shadow:0 0 20px #000c,inset 0 0 10px #00000080;border-radius:4px;padding:10px;box-sizing:border-box}.dungeon-viewport{display:block;width:100%;height:auto;image-rendering:auto;image-rendering:crisp-edges;image-rendering:-moz-crisp-edges}.info-panel{flex:0 1 380px;min-width:320px;padding:15px;background:linear-gradient(135deg,#1a1a1a,#0f0f0f);border:2px solid #3d3d3d;border-radius:4px;box-shadow:0 0 15px #00000080}.location-info{margin-bottom:15px;padding:10px;background:#0000004d;border:1px solid #2d2d2d;border-radius:3px}.location-info h3{margin:0 0 5px;font-size:1.3em;color:#8b9da9}.location-info p{margin:0;color:#aaa;font-size:.9em}.direction-indicator{margin-top:8px!important;padding:5px 10px;background:#2d35614d;border:1px solid #4a5f8f;border-radius:3px;color:#8b9da9!important;font-weight:700;text-align:center}.party-panel{display:block;margin:10px 0;border-radius:3px}.minimap-panel{display:block;margin:10px 0;border-radius:3px;border:2px solid #2d3561;box-shadow:0 0 10px #2d35614d}.minimap-wrapper{position:relative;display:inline-block}.minimap-zoom-button{position:absolute;bottom:10px;right:10px;width:32px;height:32px;border-radius:50%;border:1px solid #4a5f8f;background:radial-gradient(circle at 30% 30%,#1c2238,#0f1321);color:#b7c7ff;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 0 12px #4c649e66;transition:transform .1s ease,box-shadow .2s ease}.minimap-zoom-button:hover{transform:scale(1.05);box-shadow:0 0 16px #6496ff99}.minimap-zoom-button:active{transform:scale(.97)}.minimap-modal-overlay{position:fixed;inset:0;background:#07080ecc;display:flex;align-items:center;justify-content:center;z-index:2000;padding:20px;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.minimap-modal{background:linear-gradient(145deg,#0f1424,#0c0f1a);border:2px solid #2d3561;box-shadow:0 20px 40px #0009;border-radius:8px;width:min(540px,90vw);max-width:540px;padding:12px 12px 16px}.minimap-modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;color:#c5d4ff;font-weight:700;letter-spacing:.5px}.minimap-modal-close{background:none;border:none;color:#c5d4ff;font-size:20px;cursor:pointer;padding:4px 8px;line-height:1}.minimap-modal-close:hover{color:#fff}.minimap-modal-canvas{display:block;width:100%;height:auto;border-radius:4px;border:1px solid #2d3561}.instructions{margin-top:15px;padding:10px;background:#0000004d;border:1px solid #2d2d2d;border-radius:3px;font-size:.85em;color:#999}.instructions p{margin:5px 0}.instructions strong{color:#8b9da9}.audio-controls{margin-top:15px;padding:10px;background:#0006;border:1px solid #2d2d2d;border-radius:3px;font-size:.85em;color:#999}.audio-controls p{margin:5px 0}.audio-controls strong{color:#8b9da9}.audio-controls label{display:block;margin:8px 0;color:#aaa}.audio-controls input[type=range]{width:100%;margin-top:4px;accent-color:#4a5f8f}.event-container{max-width:800px;margin:0 auto;padding:20px}.event-header{margin-bottom:30px;padding:20px;background:linear-gradient(135deg,#1a1a2e,#0f0f1a);border:2px solid #3d3d5c;border-radius:6px;box-shadow:0 0 20px #3d3d5c4d}.event-title{margin:0;font-size:2em;color:#8b9da9;text-align:center;text-shadow:0 0 8px rgba(139,157,169,.4)}.event-description{margin-bottom:30px;padding:25px;background:#0006;border:1px solid #2d2d3d;border-radius:4px;line-height:1.8}.event-description p{margin:0;color:#c9d5e0;font-size:1.1em}.event-choices{display:flex;flex-direction:column;gap:15px}.event-choice-button{display:flex;align-items:center;padding:15px 20px;background:linear-gradient(135deg,#1a1f3a,#0f1220);border:2px solid #2d3561;border-radius:6px;color:#c9d5e0;font-size:1em;cursor:pointer;transition:all .3s ease;text-align:left;box-shadow:0 2px 4px #00000080}.event-choice-button:hover{background:linear-gradient(135deg,#2a2f4a,#1f2430);border-color:#4a5f8f;box-shadow:0 0 15px #4a5f8f66,0 2px 4px #00000080;transform:translate(5px)}.choice-number{display:inline-block;width:30px;height:30px;margin-right:15px;background:#2d3561;border:1px solid #4a5f8f;border-radius:50%;text-align:center;line-height:30px;font-weight:700;color:#8b9da9;flex-shrink:0}.choice-text{flex-grow:1;line-height:1.5}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.vanilla:hover{filter:drop-shadow(0 0 2em #3178c6aa)}.card{padding:2em}.read-the-docs{color:#888}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}.mobile-controls{position:fixed;bottom:20px;left:0;right:0;display:flex;justify-content:space-between;padding:0 20px;pointer-events:none;z-index:1000}.mobile-controls>*{pointer-events:auto}.movement-pad{display:grid;grid-template-columns:repeat(3,60px);grid-template-rows:repeat(3,60px);gap:5px}.rotation-pad{display:flex;flex-direction:column;gap:8px;align-items:center}.rotation-label{font-size:.75em;color:#8b9da9;text-align:center;margin-bottom:2px}.control-btn{width:60px;height:60px;border-radius:12px;border:2px solid #4a5f8f;background:linear-gradient(135deg,#2d3561,#1a1f3a);color:#c9d5e0;font-size:1.5em;font-weight:700;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 8px #00000080;user-select:none;-webkit-user-select:none;touch-action:manipulation}.control-btn:active{background:linear-gradient(135deg,#3d4671,#2a2f4a);transform:scale(.95);box-shadow:0 0 15px #4a5f8f99,0 2px 4px #00000080}.control-center{width:60px;height:60px;border-radius:12px;border:2px dashed #3d3d5c;background:#1a1a2e4d}.control-empty{width:60px;height:60px}.turn-btn{width:60px;height:60px;font-size:1.2em}@media(max-width:768px){#app{padding:1rem .5rem;max-width:100%}.title-screen{padding:20px 10px}.title-main{font-size:2em}.title-subtitle{font-size:1em}.title-button{font-size:1.1em;padding:12px 30px}.exploration-container{flex-direction:column;gap:10px}.viewport-container{width:100%;max-width:100%}.dungeon-viewport{width:100%;height:auto}.info-panel{width:100%;min-width:unset;padding:10px}.location-info h3{font-size:1.1em}.location-info p{font-size:.85em}.instructions{font-size:.75em}.debug-controls{display:flex;gap:5px;flex-wrap:wrap}.debug-controls button{flex:1;min-width:100px;padding:8px;font-size:.9em}.audio-controls{font-size:.75em}.event-container{padding:15px 10px}.event-title{font-size:1.5em}.event-description p{font-size:1em}.event-choice-button{padding:12px 15px;font-size:.95em}.choice-number{width:25px;height:25px;line-height:25px;margin-right:10px}}@media(max-width:480px){.title-main{font-size:1.5em}.title-subtitle{font-size:.9em}.movement-pad{grid-template-columns:repeat(3,50px);grid-template-rows:repeat(3,50px);gap:4px}.control-btn,.control-center,.control-empty{width:50px;height:50px}.control-btn{font-size:1.3em}.turn-btn{width:50px;height:50px;font-size:1em}}@media(orientation:portrait)and (max-width:768px){.exploration-container{height:auto}.viewport-container{margin-bottom:80px}}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#0a0a0a}a:hover{color:#747bff}button{background-color:#1a1a1a}}
