*{margin:0;padding:0;box-sizing:border-box}body,html{height:100%;font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Oxygen,Ubuntu,Cantarell,'Open Sans','Helvetica Neue',sans-serif;line-height:1.6;background-color:#ffc600}#app{display:flex;flex-direction:column;height:100vh}header{display:flex;justify-content:space-between;align-items:center;padding:.5rem;background-color:#ffc600}main{display:flex;flex-grow:1;overflow:hidden}#map{flex:1;height:100%}#content-list-container{width:400px;border-left:1px solid #ddd;height:auto;overflow-y:hidden;padding:1rem;background-color:#ffeb77;position:relative}#content-list{max-height:100%;overflow-y:auto;padding-right:10px}#content-list-container::-webkit-scrollbar{width:8px}#content-list-container::-webkit-scrollbar-track{background:#f1f1f1}#content-list-container::-webkit-scrollbar-thumb{background:#888;border-radius:4px}#content-list-container::-webkit-scrollbar-thumb:hover{background:#555}.content-list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.content-item{display:flex;align-items:center;margin-bottom:.7rem;padding:.5rem;border:5px solid #ddd;border-radius:24px}.content-item-checkbox{margin-right:.5rem}.content-item-details{flex-grow:1}.content-item-title{font-weight:700}.content-item-description{color:#666;font-size:.8rem}.content-item-time{font-size:.7rem;color:#666;margin-top:5px;padding-top:3px;border-top:1px solid #eee}.content-item-time .time-status{color:#f44;font-weight:700}.content-item-time .time-status-text{color:#666}.content-item-time.out-of-range{color:#f44;font-weight:700}.content-item.achieved{background-color:#e6f3e6;border-color:#a3cea5}.content-item.not-achieved{background-color:#fff;border-color:silver}.content-item.out-of-time-range{opacity:.6;background-color:#f0f0f0}.content-item.out-of-time-range.achieved{background-color:#e6f3e6;opacity:.8}#toggle-achieved-btn{padding:.25rem .5rem;background-color:#007bff;color:#fff;border:none;border-radius:4px;cursor:pointer}#help-button{width:30px;height:30px;border-radius:50%;background-color:#007bff;color:#fff;border:none;cursor:pointer}.content-item-play-btn{background-color:#4caf50;color:#fff;border:none;border-radius:4px;padding:10px 15px;margin-left:10px;cursor:pointer;transition:background-color .3s;font-size:16px;min-width:60px;text-align:center}.content-item-play-btn:disabled{background-color:#ccc;cursor:not-allowed}.content-item-play-btn:not(:disabled):hover{background-color:#45a049}.content-modal{position:fixed;z-index:1000;left:0;top:0;width:100%;height:100%;overflow:auto;background-color:rgba(0,0,0,.8);display:flex;justify-content:center;align-items:center}.content-modal-content{position:relative;background-color:#fefefe;margin:auto;padding:20px;border-radius:10px;max-width:95%;max-height:98%;width:95%;height:95%;display:flex;flex-direction:column;align-items:center;justify-content:center;overflow:hidden}.content-modal-close{color:#333;position:absolute;top:5px;right:15px;font-size:36px;font-weight:700;cursor:pointer;z-index:1001;opacity:1;text-shadow:0 0 5px rgba(255,255,255,.7);transition:color .3s ease}.content-modal-close:hover{color:#666;text-decoration:none;text-shadow:0 0 8px rgba(255,255,255,.9)}.content-modal-content img,.content-modal-content video{max-width:100%;max-height:90vh;height:auto;object-fit:contain;display:block;margin:0 auto}.content-modal-content .text-content{padding:20px;line-height:1.6;max-height:80vh;height:100%;overflow-y:auto;white-space:pre-wrap;word-wrap:break-word;font-size:1.1rem}.modal{display:none;position:fixed;z-index:1000;left:0;top:0;width:100%;height:100%;overflow:auto;background-color:rgba(0,0,0,.5)}.modal-content{background-color:#fefefe;margin:10% auto;padding:20px;border-radius:10px;width:80%;max-width:600px;max-height:70vh;overflow-y:auto;position:relative}.modal-close{color:#aaa;float:right;font-size:28px;font-weight:700;cursor:pointer}.modal-close:focus,.modal-close:hover{color:#000;text-decoration:none}.credits-content,.help-content{margin:20px 0}.credits-content p,.help-content p{margin-bottom:10px}#show-credits-btn{display:block;margin:20px auto 0;padding:10px 20px;background-color:#007bff;color:#fff;border:none;border-radius:5px;cursor:pointer}.achievement-modal{position:fixed;z-index:2000;left:0;top:0;width:100%;height:100%;overflow:auto;background-color:rgba(0,0,0,.5);display:flex;justify-content:center;align-items:center;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;cursor:default}.achievement-modal-content{background-color:#fff;padding:30px;border-radius:15px;text-align:center;max-width:90%;width:500px;box-shadow:0 4px 6px rgba(0,0,0,.1);position:relative}.achievement-modal-title{font-size:2rem;color:#333;margin-bottom:15px}.achievement-modal-description{font-size:1.1rem;color:#666;margin-bottom:25px;line-height:1.6}.achievement-modal-play-btn{background-color:#4caf50;color:#fff;border:none;padding:12px 24px;font-size:1.5rem;border-radius:50%;width:60px;height:60px;display:flex;justify-content:center;align-items:center;cursor:pointer;transition:background-color .3s ease;margin:0 auto}.achievement-modal-play-btn:hover{background-color:#45a049}.achievement-modal-close{color:#333;position:absolute;top:10px;right:15px;font-size:36px;font-weight:700;cursor:pointer;z-index:1001;opacity:1;text-shadow:0 0 5px rgba(255,255,255,.7);transition:color .3s ease}.achievement-modal-close:hover{color:#666;text-decoration:none;text-shadow:0 0 8px rgba(255,255,255,.9)}.debug-modal{position:fixed;z-index:2000;left:0;top:0;width:100%;height:100%;overflow:auto;background-color:rgba(0,0,0,.5);display:flex;justify-content:center;align-items:center}.debug-modal-content{background-color:#fff;padding:30px;border-radius:10px;width:80%;max-width:800px;max-height:80vh;overflow:auto;position:relative}.debug-modal-close{position:absolute;top:10px;right:15px;font-size:30px;cursor:pointer;color:#333}.debug-info{background-color:#f4f4f4;border:1px solid #ddd;padding:15px;margin:15px 0;max-height:70vh;min-height:300px;overflow:auto;white-space:pre-wrap;word-wrap:break-word;font-size:.9rem;line-height:1.4}.debug-modal-content button{background-color:#f44;color:#fff;border:none;padding:10px 20px;border-radius:5px;cursor:pointer;margin-top:15px}.debug-modal-content button:hover{background-color:#f66}.debug-drag-control{display:flex;align-items:center;margin-bottom:15px;padding:10px;background-color:#f0f0f0;border-radius:5px}.debug-drag-control input[type=checkbox]{margin-right:10px}.debug-drag-control label{font-size:.9rem;cursor:pointer}.header-buttons{display:flex;gap:10px}#debug-button{width:30px;height:30px;border-radius:50%;background-color:#007bff;color:#fff;border:none;cursor:pointer;font-weight:700}.content-url-iframe{width:100%;height:70vh;border:none;background-color:#fff}.content-url-modal-content{display:flex;flex-direction:column;width:95%;max-width:1200px;height:90vh;max-height:90vh;padding:0;margin:auto;border-radius:15px;overflow:hidden;background-color:#fff;box-shadow:0 4px 6px rgba(0,0,0,.1);position:relative}.content-modal-close{position:absolute;top:10px;right:15px;font-size:30px;color:#666;cursor:pointer;transition:color .3s ease;z-index:10}.content-modal-close:hover{color:#333}.content-url-modal-title{padding:10px 20px;padding-right:50px;background-color:#f4f4f4;border-bottom:1px solid #ddd;font-size:1.2rem;margin:0}.content-url-iframe-container{flex-grow:1;overflow:hidden}.content-url-iframe{width:100%;height:100%;border:none;background-color:#fff}@media (max-width:768px){main{display:flex;flex-direction:column;height:100vh;overflow:hidden}#map{flex:0 0 50vh;min-height:300px;max-height:50vh}#content-list-container{flex:1;width:100%;border-left:none;border-top:1px solid #ddd;max-height:50vh;height:auto;overflow-y:auto}#content-list{max-height:none;overflow-y:visible}}@media (orientation:landscape){main{flex-direction:row;overflow:hidden}#map{flex:0 0 50vw;max-width:50vw;max-height:100vh;min-height:auto}#content-list-container{flex:1;max-height:100vh;max-width:50vw;border-top:none;border-left:1px solid #ddd}}.achievement-modal-close,.content-modal-close{position:absolute;top:-10px;right:5px;font-size:36px;color:#333;cursor:pointer;z-index:10;opacity:1}.achievement-modal-close:hover,.content-modal-close:hover{color:#666}.header-audio-status{display:inline-block;margin-left:10px;font-size:.8rem;color:#666;background-color:rgba(0,0,0,.05);padding:3px 8px;border-radius:4px}.content-video-modal{position:fixed;z-index:2000;left:0;top:0;width:100%;height:100%;background-color:#000;display:flex;justify-content:center;align-items:center;overflow:hidden}.content-video-modal-close{position:absolute;top:-12px;right:2px;font-size:36px;color:#fff;cursor:pointer;background-color:rgba(0,0,0,.5);width:50px;height:50px;display:flex;justify-content:center;align-items:center;border-radius:0 0 0 10px}.content-video-modal-content{position:relative;width:100%;height:100%;max-width:100%;max-height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:0}.content-video-modal-content video{width:100%;height:100%;object-fit:contain;max-width:100%;max-height:100%}.content-face-image-container{position:absolute;bottom:-10px;left:0;z-index:1000;background-color:transparent;padding:0;margin:0;max-width:39%;max-height:39%}.content-face-image{width:100%;height:100%;object-fit:cover;object-position:bottom;padding:0;margin:0}.arrival-confirm-modal{position:fixed;z-index:1000;left:0;top:0;width:100%;height:100%;overflow:auto;background-color:rgba(0,0,0,.4);display:flex;justify-content:center;align-items:center;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;cursor:default}.arrival-confirm-modal-content{background-color:#fefefe;padding:20px;border-radius:10px;width:80%;max-width:400px;text-align:center;box-shadow:0 4px 6px rgba(0,0,0,.1);display:flex;flex-direction:column;align-items:center}.arrival-confirm-modal .arrival-confirm-content{user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;cursor:default}.arrival-modal-title{margin-bottom:15px;color:#333}.arrival-modal-face-image{max-width:200px;max-height:200px;margin-bottom:20px;border-radius:10px;user-drag:none;-webkit-user-drag:none;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;pointer-events:none}.arrival-modal-ok-btn{background-color:#4caf50;color:#fff;border:none;padding:10px 20px;text-align:center;text-decoration:none;display:inline-block;font-size:16px;margin-top:10px;cursor:pointer;border-radius:5px;transition:background-color .3s;position:relative;bottom:0}.arrival-modal-ok-btn:hover{background-color:#45a049}.header-logo-container{display:flex;align-items:center;gap:10px}.header-logo{height:3rem;object-fit:contain;margin-right:.5rem}.markdown-content img{max-width:100%;height:auto;display:block;margin:10px 0}.markdown-content h1{font-size:1.4em;margin-bottom:10px;font-weight:700}.markdown-content h2{font-size:1.2em;margin-bottom:8px;font-weight:700;padding:5px;background-color:#ffc600}.markdown-content h3{font-size:1.1em;margin-bottom:6px;font-weight:700;padding:5px;background-color:#ffeb77}.markdown-content p{margin-bottom:5px;line-height:1.6}.markdown-content ol,.markdown-content ul{margin-left:20px;margin-bottom:5px}.markdown-content li{margin-bottom:5px}.markdown-content a{color:#06c;text-decoration:none}.markdown-content a:hover{text-decoration:underline}.markdown-content code{background-color:#f4f4f4;padding:2px 4px;border-radius:3px;font-family:monospace;font-size:.9em}.markdown-content pre{background-color:#f4f4f4;padding:10px;border-radius:5px;overflow-x:auto;margin-bottom:5px}.markdown-content blockquote{border-left:4px solid #ccc;padding-left:10px;color:#666;margin-bottom:5px;font-style:italic}.credits-content h3{margin-top:20px;margin-bottom:10px;font-size:1.1rem;color:#333;border-bottom:1px solid #ddd;padding-bottom:5px}.credits-content ul{list-style-type:none;padding:0;margin:0}.credits-content li{margin-bottom:5px;font-size:.9rem;color:#666}.no-tour-message{list-style-type:none;text-align:center;padding:20px;color:#666;font-size:16px;background-color:#f9f9f9;border-radius:8px;margin:10px}@keyframes audioStatusFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}.content-audio-status-container{position:absolute;bottom:10px;left:10px;z-index:1000;background-color:rgba(224,81,205,.8);color:#fff;padding:6px 22px;border-radius:40px;border:6x solid rgba(255,255,255,.8);font-size:2rem;font-weight:700;font-family:Arial,sans-serif;animation:audioStatusFloat 1.5s ease-in-out infinite;box-shadow:0 4px 6px rgba(0,0,0,.2);cursor:pointer;transition:opacity .3s ease}.content-audio-status-container.paused{animation-play-state:paused;opacity:.6}.move-to-current-location-btn{width:30px;height:30px;background:0 0;border:none;padding:0;cursor:pointer;display:flex;justify-content:center;align-items:center}.move-to-current-location-btn img{width:100%;height:100%;object-fit:contain}.tour-logo-overlay{position:absolute;bottom:10px;right:10px;z-index:1000;max-width:40%;max-height:120px;min-width:100px;object-fit:contain;pointer-events:none;padding:5px;border-radius:8px}@media (max-width:768px){.tour-logo-overlay{bottom:5px;right:5px;max-width:40vw;min-width:80px;max-height:15vh;min-height:40px}}.content-audio-status-container,.content-face-image-container{user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;cursor:default}