*{box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);margin:0;padding:20px;min-height:100vh;color:#2c3e50}.app-container{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:24px;align-items:start}.control-panel,.map-panel{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:16px;padding:32px;box-shadow:0 8px 32px #0000000f;border:1px solid rgba(255,255,255,.2);text-align:center}h1{color:#2c3e50;margin-bottom:8px;font-size:2.2em;text-align:center;grid-column:1 / -1;font-weight:600;letter-spacing:-.5px}.subtitle{color:#7f8c8d;margin-bottom:40px;font-size:1.1em;text-align:center;grid-column:1 / -1;margin-top:0;font-weight:400}.destination-display{background:#ffffffe6;border:1px solid rgba(255,255,255,.3);border-radius:20px;padding:32px 24px;margin:32px 0;min-height:120px;display:flex;align-items:center;justify-content:center;transition:all .5s cubic-bezier(.4,0,.2,1);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 4px 20px #0000000d}.destination-display.result{background:linear-gradient(135deg,#1a1a1af2,#2c2c2cf2);border:4px solid rgba(212,175,55,.8);color:#fff;transform:scale(1.02);box-shadow:0 8px 25px #0003;position:relative;overflow:hidden}.destination-display.result:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(212,175,55,.6),transparent)}.destination-display.result:after{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(212,175,55,.04) 0%,transparent 60%);animation:subtle-glow 6s ease-in-out infinite}.destination-text{font-size:1.4em;color:#2c3e50;font-weight:500;line-height:1.5;text-align:center;letter-spacing:.3px}.destination-display.result .destination-text{color:#fff;font-size:1.8em;font-weight:600;letter-spacing:.8px;text-shadow:0 2px 8px rgba(0,0,0,.4),0 0 15px rgba(212,175,55,.2);position:relative;z-index:2}.spin-button{background:linear-gradient(135deg,#2c3e50,#34495e);color:#fff;border:none;padding:16px 40px;font-size:1.1em;font-weight:500;border-radius:50px;cursor:pointer;transition:all .4s cubic-bezier(.4,0,.2,1);box-shadow:0 6px 20px #2c3e5033;min-width:200px;letter-spacing:.3px;position:relative;overflow:hidden}.spin-button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);transition:left .6s}.spin-button:hover:before{left:100%}.spin-button:hover{transform:translateY(-3px);box-shadow:0 10px 30px #2c3e504d;background:linear-gradient(135deg,#34495e,#2c3e50)}.spin-button:active{transform:translateY(-1px);box-shadow:0 6px 20px #2c3e5033}.spin-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.spin-button.can-stop{background:linear-gradient(135deg,#e67e22,#f39c12);animation:gentle-pulse 2s ease-in-out infinite alternate;box-shadow:0 6px 20px #e67e224d}.spin-button.spinning{background:linear-gradient(135deg,#7f8c8d,#95a5a6);box-shadow:0 6px 20px #7f8c8d33}@keyframes gentle-pulse{0%{box-shadow:0 6px 20px #e67e224d;transform:translateY(-3px)}to{box-shadow:0 10px 30px #e67e2266;transform:translateY(-2px)}}.destination-spinning{animation:spin .15s linear infinite}@keyframes spin{0%{transform:rotateY(0)}to{transform:rotateY(360deg)}}@keyframes subtle-glow{0%,to{opacity:.3;transform:scale(1)}50%{opacity:.5;transform:scale(1.02)}}#japan-map{width:100%;height:400px}#japan-map svg{width:100%;height:100%}.prefecture{fill:#e8f4f8;stroke:#4a90e2;stroke-width:1;cursor:pointer;transition:all .2s ease}.prefecture:hover{fill:#d1ecf1;stroke:#17a2b8}.prefecture.selected{fill:#667eea!important;stroke:#5a6fd8!important;stroke-width:3!important;animation:pulse-prefecture 2s ease-in-out infinite alternate}.prefecture.current-location{fill:#feca57!important;stroke:#ff9ff3!important;stroke-width:3!important;animation:pulse-current-location 1.5s ease-in-out infinite alternate}@keyframes pulse-current-location{0%{opacity:.7}to{opacity:1}}@keyframes pulse-prefecture{0%{opacity:.8}to{opacity:1}}.map-title{font-size:1.3em;color:#2c3e50;margin-bottom:20px;font-weight:600}.filter-controls{margin-bottom:24px;padding:20px;background:#f8f9fa;border-radius:12px;border:1px solid #e9ecef}.control-group{margin-bottom:16px}.control-group:last-child{margin-bottom:0}.control-label{display:block;font-size:.9em;font-weight:600;color:#495057;margin-bottom:8px}.prefecture-select{width:100%;padding:10px 12px;border:2px solid #e9ecef;border-radius:8px;font-size:1em;background:#fff;color:#495057;transition:border-color .2s ease}.prefecture-select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.distance-slider{width:100%;height:6px;border-radius:3px;background:#e9ecef;outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none}.distance-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:#667eea;cursor:pointer;box-shadow:0 2px 6px #667eea4d;transition:transform .2s ease}.distance-slider::-webkit-slider-thumb:hover{transform:scale(1.1)}.distance-slider::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:#667eea;cursor:pointer;border:none;box-shadow:0 2px 6px #667eea4d}.radio-group{display:flex;gap:16px;flex-wrap:wrap}.radio-label{display:flex;align-items:center;cursor:pointer;font-size:.9em;color:#495057}.radio-label input[type=radio]{margin-right:6px;accent-color:#667eea}.radio-text{font-weight:500}.city-marker{filter:drop-shadow(0 2px 4px rgba(255,107,107,.3))}.share-buttons{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:16px;padding:20px;margin-top:20px;box-shadow:0 8px 32px #0000000f;border:1px solid rgba(255,255,255,.2);text-align:center}.share-title{font-size:1.1em;color:#2c3e50;margin-bottom:16px;font-weight:600}.share-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.share-button{display:flex;align-items:center;gap:8px;padding:10px 16px;border:none;border-radius:12px;font-size:.9em;font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 8px #0000001a;min-width:100px}.share-button:hover{transform:translateY(-2px);box-shadow:0 4px 15px #00000026}.share-button:active{transform:translateY(0)}.share-button.twitter{background:linear-gradient(135deg,#000,#333);color:#fff}.share-button.twitter:hover{box-shadow:0 4px 15px #0000004d}.share-button.line{background:linear-gradient(135deg,#06c755,#00b04f);color:#fff}.share-button.line:hover{box-shadow:0 4px 15px #06c7554d}.share-button.copy{background:linear-gradient(135deg,#6c757d,#495057);color:#fff}.share-button.copy:hover{box-shadow:0 4px 15px #6c757d4d}.share-icon{font-size:1.1em}.share-text{font-size:.9em}.missions-panel{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:16px;padding:24px;margin-top:24px;box-shadow:0 8px 32px #0000000f;border:1px solid rgba(255,255,255,.2)}.missions-title{font-size:1.3em;color:#2c3e50;margin-bottom:16px;font-weight:600;text-align:center}.missions-list{display:flex;flex-direction:column;gap:12px}.mission-item{background:#f8f9fa;border-radius:12px;padding:16px;border-left:4px solid #667eea;transition:transform .2s ease,box-shadow .2s ease}.mission-item:hover{transform:translate(4px);box-shadow:0 4px 15px #667eea26}.mission-header{display:flex;align-items:center;gap:12px;margin-bottom:8px}.mission-emoji{font-size:1.4em;width:24px;text-align:center}.mission-title{font-weight:600;color:#2c3e50;font-size:1.1em;flex:1}.mission-difficulty{font-size:.9em;padding:4px 8px;border-radius:8px;font-weight:700}.mission-difficulty.easy{color:#27ae60;background:#27ae601a}.mission-difficulty.medium{color:#f39c12;background:#f39c121a}.mission-difficulty.hard{color:#e74c3c;background:#e74c3c1a}.mission-description{color:#7f8c8d;font-size:.95em;line-height:1.4;margin-left:36px}@media (max-width: 768px){body{padding:16px}.app-container{grid-template-columns:1fr;gap:20px}.map-panel{order:-1;padding:24px}.control-panel{padding:24px}h1{font-size:1.8em}.subtitle{font-size:1em;margin-bottom:32px}.destination-display{padding:24px 20px;margin:24px 0;min-height:100px}.destination-text{font-size:1.3em}.destination-display.result .destination-text{font-size:1.6em}.spin-button{padding:14px 32px;font-size:1em;min-width:180px;border-radius:40px}.missions-panel{padding:20px;margin-top:20px}.missions-title{font-size:1.2em;margin-bottom:12px}.mission-item{padding:12px}.mission-header{gap:8px}.mission-title{font-size:1em}.mission-emoji{font-size:1.2em}.mission-description{margin-left:28px;font-size:.9em}.share-buttons{padding:16px;margin-top:16px}.share-title{font-size:1em;margin-bottom:12px}.share-actions{gap:8px}.share-button{padding:8px 12px;font-size:.85em;min-width:80px}.share-icon{font-size:1em}.share-text{font-size:.8em}}.seo-content{margin-top:40px;padding:40px 0;background:#ffffffb3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.seo-content .container{max-width:1100px;margin:0 auto;padding:0 24px}.seo-content h2{color:#2c3e50;font-size:1.8em;font-weight:600;margin-bottom:16px;text-align:center}.seo-content h3{color:#2c3e50;font-size:1.4em;font-weight:600;margin:32px 0 16px}.seo-content h4{color:#34495e;font-size:1.1em;font-weight:600;margin:16px 0 8px}.seo-content p{color:#555;line-height:1.6;margin-bottom:16px}.seo-content ul,.seo-content ol{color:#555;line-height:1.6;margin-bottom:24px;padding-left:20px}.seo-content li{margin-bottom:8px}.faq{display:flex;flex-direction:column;gap:20px}.faq-item{background:#fffc;border-radius:12px;padding:20px;box-shadow:0 2px 10px #0000000d}.keywords{margin-top:32px;padding:16px;background:#f8f9facc;border-radius:8px;text-align:center}.keywords small{color:#6c757d;font-size:.85em;line-height:1.4}@media (max-width: 768px){.seo-content{margin-top:20px;padding:24px 0}.seo-content .container{padding:0 16px}.seo-content h2{font-size:1.5em}.seo-content h3{font-size:1.2em;margin:24px 0 12px}}.ad-header{max-width:728px;margin:15px auto;text-align:center;background:transparent;padding:0}.ad-result{margin:15px auto;text-align:center;max-width:300px;background:transparent;padding:0}.ad-mission{margin:15px auto;text-align:center;max-width:468px;background:transparent;padding:0}.ad-footer{max-width:728px;margin:20px auto 15px;text-align:center;background:transparent;padding:0}.ad-mobile-top{position:sticky;top:0;z-index:100;background:transparent;text-align:center;padding:2px 0}.ad-mobile-result{margin:10px auto;text-align:center;max-width:300px;background:transparent;padding:0}.ad-mobile-bottom{position:sticky;bottom:0;z-index:100;background:transparent;text-align:center;padding:2px 0;margin-top:15px}.ad-header img,.ad-result img,.ad-mission img,.ad-footer img,.ad-mobile-top img,.ad-mobile-result img,.ad-mobile-bottom img{max-width:100%;height:auto;display:inline-block}@media (max-width: 768px){.ad-header,.ad-mission,.ad-footer{display:none}body{padding-top:54px;padding-bottom:54px}}@media (min-width: 769px){.ad-mobile-top,.ad-mobile-result,.ad-mobile-bottom{display:none}}.ad-header,.ad-result,.ad-mission,.ad-footer,.ad-mobile-result{animation:fadeIn .5s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
