:root{--cherry-red: #e74c6f;--cherry-red-light: #ff6b8a;--cherry-red-bg: #fce4ec;--nature-green: #4caf50;--nature-green-light: #81c784;--nature-green-bg: #e8f5e9;--sky-blue: #42a5f5;--sky-blue-light: #90caf9;--sky-blue-bg: #e3f2fd;--sun-yellow: #ffd54f;--sun-orange: #ffb74d;--purple: #ab47bc;--purple-bg: #f3e5f5;--bg-gradient-start: #e0f2fe;--bg-gradient-end: #fef9ef;--text-dark: #3e2723;--text-medium: #5d4037;--text-light: #fff;--text-muted: #8d6e63;--card-bg: rgba(255, 255, 255, .92);--shadow-sm: 0 2px 8px rgba(62, 39, 35, .08);--shadow: 0 4px 16px rgba(62, 39, 35, .12);--shadow-lg: 0 8px 32px rgba(62, 39, 35, .16);--shadow-glow-pink: 0 4px 20px rgba(231, 76, 111, .3);--shadow-glow-blue: 0 4px 20px rgba(66, 165, 245, .3);--shadow-glow-green: 0 4px 20px rgba(76, 175, 80, .3);--radius: 16px;--radius-lg: 24px;--radius-xl: 32px;--sidebar-bg: #1a1a4e}*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none}html,body,#root{width:100%;height:100%;overflow:hidden;cursor:default;user-select:none;-webkit-user-select:none;touch-action:manipulation;overscroll-behavior:none}ruby{position:relative;display:inline;ruby-position:over}rt{font-size:.48em;position:absolute;left:50%;transform:translate(-50%);top:-1.2em;white-space:nowrap;line-height:1;font-weight:700;color:inherit;opacity:.75;letter-spacing:0}body{font-family:"M PLUS Rounded 1c",Hiragino Maru Gothic Pro,BIZ UDPGothic,sans-serif;background:linear-gradient(160deg,var(--bg-gradient-start) 0%,var(--bg-gradient-end) 100%);color:var(--text-dark)}body:before{content:"";position:fixed;bottom:0;left:0;right:0;height:180px;background:linear-gradient(135deg,transparent 33%,rgba(76,175,80,.1) 33%,rgba(76,175,80,.1) 66%,transparent 66%),linear-gradient(45deg,transparent 33%,rgba(129,199,132,.08) 33%,rgba(129,199,132,.08) 66%,transparent 66%);background-size:200px 180px;pointer-events:none;z-index:0}body:after{content:"";position:fixed;top:-60px;right:-60px;width:220px;height:220px;border-radius:50%;background:radial-gradient(circle,rgba(231,76,111,.12) 0%,transparent 70%);pointer-events:none;z-index:0}button{font-family:inherit;cursor:pointer;border:none;outline:none;transition:all .2s ease;position:relative}button:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}button:active{transform:translateY(1px)}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInScale{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes bounceIn{0%{transform:scale(.3);opacity:0}50%{transform:scale(1.08)}70%{transform:scale(.95)}to{transform:scale(1);opacity:1}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.06)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes glow{0%,to{box-shadow:0 0 8px #e74c6f4d}50%{box-shadow:0 0 24px #e74c6f80}}@keyframes wrongShake{0%,to{transform:translate(0)}20%,60%{transform:translate(-6px)}40%,80%{transform:translate(6px)}}@keyframes sparkle{0%{transform:scale(0) rotate(0);opacity:1}to{transform:scale(1) rotate(180deg);opacity:0}}@keyframes confettiFall{0%{transform:translateY(-10px) rotate(0);opacity:1}to{transform:translateY(100vh) rotate(720deg);opacity:0}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-30px)}to{opacity:1;transform:translate(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(30px)}to{opacity:1;transform:translate(0)}}@keyframes countUp{0%{opacity:0;transform:scale(.5)}to{opacity:1;transform:scale(1)}}.fade-in{animation:fadeIn .5s ease-out both}.bounce-in{animation:bounceIn .6s ease-out}.app{width:100vw;height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;overflow:hidden;position:relative;z-index:1}.quit-btn{padding:8px 20px;font-size:.85rem;font-weight:700;color:var(--text-muted);background:var(--card-bg);border-radius:24px;border:2px solid rgba(141,110,99,.2);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);box-shadow:0 2px #8d6e631f,0 2px 6px #0000000f;transition:transform .1s,box-shadow .1s}.quit-btn:active{transform:translateY(1px);box-shadow:0 1px #8d6e631f}.quit-btn:hover{color:var(--cherry-red);border-color:var(--cherry-red);background:var(--cherry-red-bg)}.title-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;text-align:center;animation:fadeIn .8s ease-out;padding:40px;position:relative;width:100%;height:100%}.title-decoration{position:relative;display:flex;align-items:center;justify-content:center;margin-bottom:12px}.title-icons{display:flex;align-items:center;gap:16px}.title-icon-badge{display:flex;align-items:center;justify-content:center;width:72px;height:72px;border-radius:20px;font-size:1.8rem;font-weight:900;box-shadow:0 6px #00000026,var(--shadow-lg);transform:rotate(-3deg);transition:transform .2s}.title-icon-badge:nth-child(2){transform:rotate(2deg) scale(1.05)}.title-icon-badge:nth-child(3){transform:rotate(-1deg)}.title-icon-badge.mountain{background:linear-gradient(135deg,#4caf50,#81c784);color:#fff}.title-icon-badge.ai{background:linear-gradient(135deg,var(--cherry-red),var(--cherry-red-light));color:#fff}.title-icon-badge.quiz{background:linear-gradient(135deg,var(--sky-blue),var(--sky-blue-light));color:#fff}.title-logo{font-size:3.8rem;font-weight:900;color:var(--text-dark);line-height:1.8;letter-spacing:4px;text-shadow:0 4px 0 rgba(62,39,35,.12),0 8px 24px rgba(62,39,35,.08)}.title-logo rt{top:-1.15em}.title-logo .accent{color:var(--cherry-red);font-size:4.5rem;text-shadow:0 4px 0 rgba(231,76,111,.25),0 8px 24px rgba(231,76,111,.12);letter-spacing:8px}.title-subtitle{font-size:1.4rem;color:var(--text-medium);font-weight:700;line-height:2;padding-top:.3em}.start-btn{margin-top:24px;padding:26px 88px;font-size:2rem;font-weight:900;color:#fff;background:linear-gradient(135deg,var(--cherry-red),var(--cherry-red-light));border-radius:50px;box-shadow:0 6px #b71c1c,var(--shadow-glow-pink);animation:pulse 2.5s ease-in-out infinite;letter-spacing:3px;transition:transform .1s,box-shadow .1s;position:relative}.start-btn:after{content:"▶";position:absolute;right:28px;font-size:.8em;opacity:.7}.start-btn:hover{animation:none;transform:translateY(-3px);box-shadow:0 9px #b71c1c,0 12px 40px #e74c6f80}.start-btn:active{transform:translateY(3px);box-shadow:0 1px #b71c1c,0 2px 10px #e74c6f4d}.company-label{margin-top:auto;padding-top:16px;font-size:.85rem;color:var(--text-muted);opacity:.7;letter-spacing:1px}.map-screen{display:flex;flex-direction:column;align-items:center;gap:20px;width:100%;height:100%;padding:28px 40px;animation:fadeIn .5s ease-out}.map-header{display:flex;align-items:center;gap:16px;width:100%;max-width:1200px;justify-content:space-between}.map-title{font-size:1.9rem;font-weight:900;color:var(--text-dark);display:flex;align-items:center;gap:10px}.map-title-icon{font-size:1.6rem}.map-container{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;gap:16px;max-width:960px;width:100%;flex:1;max-height:480px}.region-card{display:flex;flex-direction:row;align-items:center;gap:16px;padding:20px 24px;border-radius:var(--radius-lg);color:#fff;font-weight:700;box-shadow:0 4px #0003,var(--shadow-lg);position:relative;overflow:hidden;transition:transform .15s,box-shadow .15s}.region-card:active{transform:translateY(3px) scale(.98);box-shadow:0 1px #0003,0 2px 6px #0000001a;transition:transform .08s}.region-card:before{content:"";position:absolute;top:-20px;right:-20px;width:80px;height:80px;border-radius:50%;background:#ffffff1f;pointer-events:none}.region-card:after{content:"";position:absolute;bottom:-10px;left:-10px;width:50px;height:50px;border-radius:50%;background:#ffffff14;pointer-events:none}.region-card .region-icon{font-size:3.5rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2));flex-shrink:0}.region-card .region-text{display:flex;flex-direction:column;gap:6px;flex:1;min-width:0;text-align:left}.region-card .region-name{font-size:2.1rem;font-weight:900;text-shadow:0 1px 3px rgba(0,0,0,.15)}.region-card .region-desc{font-size:1.05rem;opacity:.9;font-weight:600;line-height:2}.region-murayama{background:linear-gradient(135deg,#e74c6f,#ec407a)}.region-mogami{background:linear-gradient(135deg,#42a5f5,#29b6f6)}.region-okitama{background:linear-gradient(135deg,#ab47bc,#ba68c8)}.region-shonai{background:linear-gradient(135deg,#4caf50,#66bb6a)}.map-hint{font-size:1.1rem;color:var(--text-muted);font-weight:600}.difficulty-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:28px;padding:40px;animation:fadeIn .5s ease-out}.difficulty-header{display:flex;align-items:center;gap:16px}.difficulty-region-badge{display:inline-flex;align-items:center;gap:6px;padding:8px 20px;border-radius:20px;font-size:1.15rem;font-weight:700;color:#fff}.difficulty-title{font-size:2rem;font-weight:900;color:var(--text-dark)}.difficulty-subtitle{font-size:1.3rem;font-weight:700;color:var(--text-medium);margin-top:-8px}.difficulty-cards{display:flex;gap:20px;max-width:820px;width:100%}.difficulty-card{flex:1;display:flex;flex-direction:column;align-items:center;gap:14px;padding:36px 24px;background:var(--card-bg);border:3px solid #e8e0dc;border-radius:var(--radius-lg);box-shadow:0 4px #8d6e6326,var(--shadow);cursor:pointer;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease;opacity:0;animation:fadeIn .5s ease-out forwards}.difficulty-card:hover{transform:translateY(-6px);box-shadow:0 8px #8d6e631f,var(--shadow-lg)}.difficulty-card:active{transform:translateY(2px) scale(.97);box-shadow:0 1px #8d6e6326,0 2px 4px #00000014;transition:transform .08s}.difficulty-badge{font-size:2.8rem}.difficulty-label{font-size:1.5rem;font-weight:900;color:var(--text-dark)}.difficulty-desc{font-size:.88rem;color:var(--text-muted);text-align:center;line-height:1.5}.difficulty-hint{font-size:1.1rem;color:var(--text-muted);font-weight:600}.difficulty-card.difficulty-easy:hover{border-color:var(--nature-green);background:var(--nature-green-bg)}.difficulty-card.difficulty-normal:hover{border-color:var(--sun-orange);background:#fff8e1}.difficulty-card.difficulty-hard:hover{border-color:var(--cherry-red);background:var(--cherry-red-bg)}.quiz-screen{display:flex;width:100%;height:100%;animation:fadeIn .3s ease-out}.quiz-main{flex:1;display:flex;flex-direction:column;padding:14px 24px;gap:6px}.quiz-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.quiz-badge{display:inline-flex;align-items:center;gap:6px;padding:18px 18px 8px;border-radius:16px;font-size:1.1rem;font-weight:700;color:#fff}.quiz-badge.region{background:var(--cherry-red)}.quiz-badge.difficulty{background:var(--sun-orange)}.quiz-progress{font-size:1.6rem;font-weight:900;color:var(--sky-blue)}.quiz-timer{display:flex;align-items:center;justify-content:center;width:86px;height:86px;border-radius:50%;background:var(--card-bg);border:4px solid var(--nature-green);font-size:2rem;font-weight:900;color:var(--text-dark);box-shadow:var(--shadow-sm);flex-shrink:0}.quiz-timer.warning{border-color:var(--cherry-red);color:var(--cherry-red);animation:pulse .5s ease-in-out infinite}.quiz-score{display:inline-flex;align-items:center;gap:4px;padding:8px 18px;border-radius:16px;background:var(--cherry-red-bg);color:var(--cherry-red);font-size:1.3rem;font-weight:800}.timer-bar{width:100%;height:14px;background:#8d6e631f;border-radius:7px;overflow:hidden}.timer-fill{height:100%;border-radius:7px;transition:width 1s linear}.progress-bar{width:100%;height:14px;background:#8d6e631f;border-radius:7px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--sky-blue),var(--sky-blue-light));border-radius:7px;transition:width .5s ease}.quiz-question-area{display:flex;flex-direction:column;gap:6px}.quiz-category-badge{display:inline-flex;align-items:center;gap:6px;padding:8px 18px;background:var(--sky-blue-bg);color:var(--text-dark);border-radius:16px;font-size:1.25rem;font-weight:700}.quiz-question-text{font-size:1.7rem;font-weight:800;line-height:2;color:var(--text-dark);min-height:5rem;padding-top:.4em;margin:0}.choice-btn.choice-lg{font-size:1.35rem}.choice-btn.choice-sm{font-size:1rem}.choice-btn.choice-xs{font-size:.88rem}.quiz-choices{display:grid;grid-template-columns:1fr;gap:10px}.choices-feedback-row{display:grid;grid-template-columns:2fr 1fr;gap:14px;align-items:start}.choice-btn{padding:16px 16px 10px;font-size:1.1rem;font-weight:700;background:var(--card-bg);border:3px solid rgba(141,110,99,.15);border-radius:var(--radius);text-align:left;box-shadow:0 3px #8d6e632e,0 3px 10px #3e27231a,0 1px 3px #3e272314;display:flex;align-items:center;gap:10px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);transition:box-shadow .15s,border-color .15s,transform .1s;height:100%;line-height:1.2;word-break:keep-all;overflow-wrap:break-word}.choice-btn:hover{transform:translateY(-3px);border-color:var(--sky-blue);background:var(--sky-blue-bg);box-shadow:0 6px #42a5f533,var(--shadow-glow-blue)}.choice-btn:active{transform:translateY(1px) scale(.98);box-shadow:0 1px #8d6e632e,0 1px 4px #3e272314;transition:transform .08s}.choice-btn.correct{border-color:var(--nature-green);background:var(--nature-green-bg);box-shadow:var(--shadow-glow-green)}.choice-btn.wrong{border-color:var(--cherry-red);background:var(--cherry-red-bg);animation:wrongShake .4s ease}.choice-btn.disabled{pointer-events:none;opacity:.7}.choice-btn.show-correct{border-color:var(--nature-green);background:var(--nature-green-bg)}.choice-label{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,var(--sky-blue),var(--sky-blue-light));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:900;font-size:1.1rem;flex-shrink:0;box-shadow:0 2px 6px #42a5f54d}.feedback-area{display:flex;flex-direction:column;gap:10px;visibility:hidden}.feedback-area.visible{visibility:visible;animation:fadeIn .25s ease-out}.explanation-box{padding:14px 18px;min-height:3.2em;background:var(--nature-green-bg);border-radius:var(--radius);font-size:1.25rem;line-height:1.7;border-left:5px solid var(--nature-green);font-weight:600}.explanation-result{font-size:1.4rem;font-weight:800;display:block;margin-bottom:6px}.feedback-area.visible .explanation-box{animation:fadeInScale .3s ease-out}.explanation-box.wrong{background:var(--cherry-red-bg);border-left-color:var(--cherry-red)}.explanation-box.timeout{background:#fff8e1;border-left-color:var(--sun-orange)}.next-btn{padding:14px 40px;font-size:1.15rem;font-weight:800;color:#fff;background:linear-gradient(135deg,var(--sky-blue),var(--sky-blue-light));border-radius:30px;box-shadow:0 3px #1565c0,var(--shadow-glow-blue);letter-spacing:1px;transition:transform .1s,box-shadow .1s;animation:fadeInScale .3s ease-out,nextBtnPulse 1.5s ease-in-out .3s infinite}@keyframes nextBtnPulse{0%,to{box-shadow:0 3px #1565c0,0 4px 15px #42a5f54d}50%{box-shadow:0 3px #1565c0,0 4px 25px #42a5f599}}.next-btn:hover{animation:none;transform:translateY(-2px);box-shadow:0 5px #1565c0,0 6px 20px #42a5f566}.next-btn:active{animation:none;transform:translateY(2px);box-shadow:0 1px #1565c0,0 2px 8px #42a5f54d}.ai-sidebar{width:320px;background:linear-gradient(180deg,var(--sidebar-bg) 0%,#12123a 100%);color:#fff;padding:18px;display:flex;flex-direction:column;align-items:center;gap:14px;overflow-y:auto;border-left:1px solid rgba(255,255,255,.06)}.ai-title{font-size:1.3rem;font-weight:800;text-align:center;display:flex;align-items:center;gap:10px;color:var(--sun-yellow)}.ai-brain-icon{font-size:2.2rem}.ai-thinking-dots{display:flex;gap:6px;align-items:center}.ai-dot{width:10px;height:10px;border-radius:50%;background:#ffd54fcc;animation:aiPulse 1.4s ease-in-out infinite}.ai-dot:nth-child(2){animation-delay:.2s}.ai-dot:nth-child(3){animation-delay:.4s}@keyframes aiPulse{0%,to{transform:scale(.5);opacity:.3}50%{transform:scale(1.1);opacity:1;box-shadow:0 0 8px #ffd54f99}}.ai-thought-bubble{background:#ffffff14;border-radius:var(--radius);padding:16px;width:100%;font-size:1rem;line-height:1.6;border:1px solid rgba(255,255,255,.06)}.ai-thought-bubble .thinking{color:var(--sun-yellow);font-weight:800;margin-bottom:8px;font-size:1.05rem}.ai-stats{width:100%;display:flex;flex-direction:column;gap:10px}.ai-stat-row{display:flex;align-items:center;gap:8px;font-size:1.1rem}.ai-stat-bar{flex:1;height:10px;background:#ffffff1f;border-radius:5px;overflow:hidden}.ai-stat-fill{height:100%;border-radius:4px;transition:width .8s ease}.ai-stat-fill.history{background:linear-gradient(90deg,var(--sun-orange),#ffcc02)}.ai-stat-fill.nature{background:linear-gradient(90deg,var(--nature-green),var(--nature-green-light))}.ai-stat-fill.food{background:linear-gradient(90deg,var(--cherry-red),var(--cherry-red-light))}.ai-stat-fill.culture{background:linear-gradient(90deg,var(--purple),#ce93d8)}.ai-stat-fill.industry{background:linear-gradient(90deg,var(--sky-blue),var(--sky-blue-light))}.ai-prediction{background:#ffffff14;border-radius:var(--radius);padding:14px;width:100%;text-align:center;border:1px solid rgba(255,255,255,.06)}.ai-prediction .label{font-size:1rem;opacity:.7;margin-bottom:4px;font-weight:600}.ai-prediction .value{font-size:1.35rem;font-weight:900;color:var(--sun-yellow)}.result-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;padding:36px;text-align:center;animation:fadeIn .6s ease-out}.result-title{font-size:2rem;font-weight:900;color:var(--text-dark)}.result-score{font-size:4rem;font-weight:900;color:var(--cherry-red);animation:countUp .8s ease-out}.result-rank{padding:14px 40px;border-radius:50px;font-size:1.7rem;font-weight:900;color:#fff;box-shadow:var(--shadow);letter-spacing:2px}.rank-master{background:linear-gradient(135deg,gold,#ffb300)}.rank-expert{background:linear-gradient(135deg,#90a4ae,#b0bec5)}.rank-intermediate{background:linear-gradient(135deg,#cd7f32,#d4955a)}.rank-beginner{background:linear-gradient(135deg,var(--sky-blue),var(--sky-blue-light))}.result-ai-comment{max-width:520px;padding:20px 24px;background:linear-gradient(135deg,var(--sidebar-bg),#12123a);color:#fff;border-radius:var(--radius-lg);font-size:1.1rem;line-height:1.7;box-shadow:var(--shadow);text-align:left}.result-ai-comment .ai-label{color:var(--sun-yellow);font-weight:800;margin-bottom:8px;font-size:1rem}.result-actions{display:flex;gap:14px;margin-top:8px;flex-wrap:wrap;justify-content:center}.retry-btn{padding:16px 36px;font-size:1.1rem;font-weight:800;color:#fff;background:linear-gradient(135deg,var(--nature-green),var(--nature-green-light));border-radius:30px;box-shadow:var(--shadow-glow-green);letter-spacing:1px}.change-difficulty-btn{padding:16px 36px;font-size:1.1rem;font-weight:800;color:#fff;background:linear-gradient(135deg,var(--sun-orange),#ffa726);border-radius:30px;box-shadow:var(--shadow);letter-spacing:1px}.change-region-btn{padding:16px 36px;font-size:1.1rem;font-weight:800;color:var(--text-dark);background:var(--card-bg);border:3px solid rgba(141,110,99,.2);border-radius:30px;letter-spacing:1px}.confetti-container{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:1000}.confetti-piece{position:absolute;width:12px;height:12px;border-radius:2px;animation:confettiFall 3s ease-out forwards}
