*{box-sizing:border-box;margin:0;padding:0}:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.5;font-weight:400;color:#213547;background-color:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none}body{margin:0;padding:0;min-width:320px;width:100%;min-height:100vh;min-height:100dvh;overflow-y:auto;-webkit-overflow-scrolling:touch}#root{width:100%;min-height:100vh;min-height:100dvh}button{font-family:inherit;cursor:pointer;border:none;outline:none;-webkit-tap-highlight-color:transparent}@media(hover:none)and (pointer:coarse){button:hover{transform:none}}.country-select{min-height:100dvh;display:flex;flex-direction:column;align-items:center;padding:15px;background:linear-gradient(135deg,#667eea,#764ba2);box-sizing:border-box;width:100%}.title-section{text-align:center;margin-bottom:20px;color:#fff;flex-shrink:0}.title-section h1{font-size:1.8rem;margin-bottom:8px;text-shadow:2px 2px 4px rgba(0,0,0,.3)}.subtitle{font-size:.95rem;margin-bottom:3px;opacity:.95}.instruction{font-size:.9rem;opacity:.9}.country-list{display:flex;flex-direction:column;gap:12px;width:100%;max-width:400px;flex-shrink:0}.country-card{background:#fff;border:none;border-radius:15px;padding:15px;cursor:pointer;transition:all .3s ease;text-align:center;box-shadow:0 4px 6px #0000001a}.country-card.has-image{padding:0;overflow:hidden;aspect-ratio:1280 / 600;position:relative}.country-select-image{width:100%;height:100%;object-fit:cover;display:block}.success-badge{position:absolute;top:10px;right:10px;background:linear-gradient(135deg,gold,#ffed4e);color:#333;padding:8px 16px;border-radius:20px;font-weight:700;font-size:.9rem;box-shadow:0 2px 8px #0000004d;z-index:10;border:2px solid #fff}.country-card:hover{transform:translateY(-5px);box-shadow:0 8px 12px #0003}.country-card:active{transform:translateY(-2px)}.country-icon{font-size:2.5rem;margin-bottom:8px}.country-card h2{font-size:1.3rem;margin:8px 0 4px;color:#333}.leader-name{font-size:.85rem;color:#666;margin-bottom:8px;font-weight:500}.country-desc{font-size:.8rem;color:#888;line-height:1.3;margin:0}@media(max-width:480px){.country-select{padding-top:20px}}@media(min-width:481px){.country-select{padding:20px}.title-section{margin-bottom:40px}.title-section h1{font-size:2.5rem;margin-bottom:10px}.subtitle{font-size:1.1rem;margin-bottom:5px}.instruction{font-size:1rem}.country-list{gap:15px}.country-card{padding:20px}.country-icon{font-size:3rem;margin-bottom:10px}.country-card h2{font-size:1.5rem;margin:10px 0 5px}.leader-name{font-size:.95rem;margin-bottom:10px}.country-desc{font-size:.9rem;line-height:1.4}.success-badge{top:15px;right:15px;padding:10px 20px;font-size:1rem}}.completion-section{margin-top:30px;margin-bottom:30px;padding:20px;background:#fffffff2;border-radius:15px;box-shadow:0 4px 12px #0003;text-align:center;width:100%;max-width:400px;flex-shrink:0;animation:fadeInUp .5s ease}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.completion-message{margin-bottom:20px}.completion-icon{font-size:3rem;margin-bottom:10px}.completion-message h2{font-size:1.5rem;color:#667eea;margin:0 0 10px;font-weight:700}.completion-message p{font-size:1rem;color:#555;margin:0}.completion-storychat-button{background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff;border:none;padding:15px 30px;border-radius:25px;font-size:1rem;font-weight:700;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 10px #f5576c4d}.completion-storychat-button:hover{transform:translateY(-2px);box-shadow:0 6px 15px #f5576c66}.completion-storychat-button:active{transform:translateY(0)}@media(min-width:481px){.completion-section{margin-top:40px;margin-bottom:40px;padding:30px}.completion-icon{font-size:4rem}.completion-message h2{font-size:1.8rem;margin-bottom:15px}.completion-message p{font-size:1.1rem}.completion-storychat-button{padding:18px 40px;font-size:1.1rem}}.swipe-card-container{width:100%;max-width:350px;height:100%;max-height:400px;position:relative;display:flex;align-items:center;justify-content:center}.swipe-card{width:100%;height:100%;background:#fff;border-radius:20px;box-shadow:0 10px 30px #0003;border:3px solid #a0a0e0;position:absolute;-webkit-user-select:none;user-select:none;touch-action:none;transition:transform .1s ease,opacity .1s ease;box-sizing:border-box}.card-content{padding:20px;height:100%;display:flex;flex-direction:column;justify-content:flex-start;box-sizing:border-box;gap:20px}.situation{font-size:1rem;line-height:1.5;color:#333;text-align:center;margin:0;font-weight:500;flex:1;display:flex;align-items:center;justify-content:center}.choices{display:flex;gap:12px;flex-shrink:0;margin-top:auto;margin-bottom:35px}.choice{flex:1;padding:15px;border-radius:12px;border:2px solid #e0e0e0;transition:all .3s ease;opacity:1}.choice.left{background:linear-gradient(135deg,#84fab0,#8fd3f4)}.choice.right{background:linear-gradient(135deg,#fccb90,#d57eeb)}.choice.active{opacity:1;transform:scale(1.05);border-color:#333}.choice-label{display:block;font-size:.8rem;font-weight:700;margin-bottom:6px;text-align:center}.choice p{margin:0;font-size:.8rem;line-height:1.3;text-align:center;color:#333}.swipe-hint{position:absolute;bottom:8px;left:50%;transform:translate(-50%);font-size:.85rem;font-weight:600;color:#666}@media(min-width:481px){.card-content{padding:30px;gap:25px}.situation{font-size:1.2rem;line-height:1.6}.choices{gap:15px;margin-bottom:45px}.choice{padding:20px;border-radius:15px}.choice-label{font-size:.9rem;margin-bottom:8px}.choice p{font-size:.95rem;line-height:1.4}.swipe-hint{bottom:12px;font-size:.95rem}}.leader-response-overlay{position:relative;width:100%;z-index:100;animation:popIn .3s ease;display:flex;justify-content:center;padding-top:10px}.leader-response{background:#fffffff2;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:10px;padding:8px 12px;width:95%;max-width:100%;box-shadow:0 4px 15px #0000004d;position:relative}.leader-response.positive{border:2px solid #4caf50}.leader-response.negative{border:2px solid #f44336}.response-message{font-size:.9rem;line-height:1.3;color:#333;text-align:center;margin:0;font-weight:500}@media(max-width:480px){.leader-response{padding:6px 10px}.response-message{font-size:.85rem;line-height:1.25}}.game-screen{height:100dvh;display:flex;flex-direction:column;padding:15px;transition:background-color .5s ease;box-sizing:border-box;width:100%;max-width:450px;margin:0 auto;border:3px solid rgba(160,160,224,.6);border-radius:25px;box-shadow:0 0 40px #667eea80;background-clip:padding-box;position:relative}@media(max-width:480px){.game-screen{max-width:100%;border:none;border-radius:0;box-shadow:none;padding:8px}}.game-header{display:flex;flex-direction:column;align-items:center;gap:8px;flex-shrink:0}.country-info{text-align:center}.country-info h2{font-size:1.5rem;margin:0 0 3px;color:#333}.country-info p{margin:0;font-size:.9rem;color:#666}.leader-portrait{position:relative;width:100%;max-width:304px;aspect-ratio:1216 / 832;background:#fff;border-radius:12px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #00000026;transition:transform .3s ease;border:3px solid rgba(0,0,0,.1);overflow:hidden}.leader-image{width:100%;height:100%;object-fit:cover;display:block}.leader-icon{font-size:3rem}@keyframes popIn{0%{opacity:0;transform:scale(.8) translateY(-10px)}to{opacity:1;transform:scale(1) translateY(0)}}.persuasion-change-indicator{position:absolute;top:10px;right:10px;z-index:11;animation:popIn .3s ease}.change-badge{display:inline-block;padding:6px 14px;border-radius:20px;font-weight:700;font-size:1rem;box-shadow:0 4px 12px #0000004d;border:2px solid white}.change-badge.positive{background:linear-gradient(135deg,#4caf50,#8bc34a);color:#fff}.change-badge.negative{background:linear-gradient(135deg,#f44336,#ff5722);color:#fff}.leader-response-wrapper{position:absolute;bottom:0;left:0;right:0;height:30%;padding:6px;display:flex;align-items:center;justify-content:center;z-index:10}.leader-response-wrapper.hidden{visibility:hidden}.leader-response-wrapper.visible{visibility:visible}.persuasion-container{width:100%;max-width:400px;overflow:visible}.persuasion-label{display:flex;justify-content:space-between;margin-bottom:6px;font-size:.85rem;color:#333;font-weight:500}.persuasion-value{font-weight:700;color:#2196f3}.persuasion-bar{width:100%;height:20px;background:#fff;border-radius:15px;overflow:visible;box-shadow:inset 0 2px 4px #0000001a;position:relative}.persuasion-bar:before,.persuasion-bar:after{content:"";position:absolute;top:0;height:100%;width:2px;background:#0003;z-index:1}.persuasion-bar:before{left:33.33%}.persuasion-bar:after{left:66.67%}.persuasion-fill{height:100%;transition:width .5s ease,background-color .3s ease;display:flex;align-items:center;justify-content:flex-end;padding-right:10px;color:#fff;font-weight:700;border-radius:15px}.card-progress{font-size:.85rem;color:#666;background:#fff;padding:6px 12px;border-radius:15px;box-shadow:0 2px 4px #0000001a}.card-area{flex:1;display:flex;align-items:center;justify-content:center;padding:10px 0;overflow:hidden;min-height:0}@media(min-width:481px){.game-screen{padding:20px}.game-header{gap:12px}.country-info h2{font-size:1.8rem;margin-bottom:5px}.country-info p{font-size:1rem}.leader-portrait{max-width:380px}.leader-response-wrapper{padding:8px}.change-badge{padding:8px 16px;font-size:1.1rem}.leader-icon{font-size:4rem}.persuasion-label{font-size:.95rem;margin-bottom:8px}.persuasion-bar{height:25px}.card-progress{font-size:.9rem;padding:8px 16px;border-radius:20px}.card-area{padding:20px 0}}.result-screen{min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:20px;box-sizing:border-box;background:linear-gradient(135deg,#667eea,#764ba2);width:100%}.result-content{width:100%;max-width:500px;background:#fff;border-radius:20px;padding:40px;text-align:center;box-shadow:0 10px 30px #0003}.result-icon{font-size:5rem;margin-bottom:20px;animation:bounceIn .6s ease}@keyframes bounceIn{0%{transform:scale(0)}50%{transform:scale(1.1)}to{transform:scale(1)}}.result-title{font-size:2rem;margin:0 0 15px;color:#333}.result-message{font-size:1.1rem;color:#666;margin-bottom:30px;line-height:1.5}.result-stats{background:#f5f5f5;border-radius:15px;padding:20px;margin-bottom:25px}.stat{display:flex;justify-content:space-between;align-items:center}.stat-label{font-size:1rem;color:#666}.stat-value{font-size:1.5rem;font-weight:700;color:#4caf50}.stat-value.failure-value{color:#f44336}.leader-final{display:flex;justify-content:center;margin:25px 0}.leader-final-icon{font-size:4rem;background:#fff;width:100px;height:100px;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #0000001a}.leader-final-image{width:100%;max-width:400px;aspect-ratio:1216 / 832;object-fit:cover;border-radius:12px;box-shadow:0 4px 12px #0000001a;border:3px solid rgba(0,0,0,.1)}.leader-message{font-size:1.1rem;color:#333;margin:20px 0 25px;line-height:1.6;font-weight:500;font-style:italic;padding:15px 20px;background:#ffffff80;border-radius:12px;border-left:4px solid #667eea}.rating-display{display:flex;align-items:center;justify-content:center;gap:10px;margin-top:12px}.rating-stars{font-size:1.8rem;color:gold;letter-spacing:2px}.rating-text{font-size:1.1rem;font-weight:700;color:#666;padding:4px 12px;background:#ffffffb3;border-radius:8px}.button-group{display:flex;flex-direction:column;gap:12px;width:100%}.restart-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:25px;padding:15px 40px;font-size:1.1rem;font-weight:700;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #0003}.restart-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #0000004d}.restart-button:active{transform:translateY(0)}.storychat-button{background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff;border:none;border-radius:25px;padding:15px 40px;font-size:1.1rem;font-weight:700;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #0003}.storychat-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #0000004d}.storychat-button:active{transform:translateY(0)}@media(max-width:480px){.result-screen{padding:20px 15px}.result-content{padding:30px 20px}.result-icon{font-size:4rem}.result-title{font-size:1.6rem}.result-message{font-size:1rem}.leader-final-icon{width:80px;height:80px;font-size:3rem}.leader-final-image{max-width:280px}}.app{width:100%;min-height:100%;display:flex;justify-content:center;align-items:stretch;background-color:#1a1a2e;padding:0}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100dvh;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:2rem;width:100%}.loading-screen h1{font-size:2.5rem;margin-bottom:3rem;text-align:center}.loading-bar{width:80%;max-width:400px;height:8px;background:#fff3;border-radius:4px;overflow:hidden;margin-bottom:1rem}.loading-fill{height:100%;background:#fff;border-radius:4px;transition:width .3s ease}.loading-text{font-size:1rem;opacity:.9}@media(max-width:768px){.loading-screen h1{font-size:2rem}.loading-bar{width:90%}}
