:root{font-family:Segoe UI,system-ui,-apple-system,sans-serif;line-height:1.5;font-weight:400;color:#1a1a2e;background:linear-gradient(135deg,#667eea,#764ba2);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{margin:0;padding:0;box-sizing:border-box}body{min-width:320px;min-height:100vh;display:flex;justify-content:center;align-items:flex-start;padding:2rem 1rem}#root{width:100%;max-width:520px;margin:0 auto}.app{text-align:center}.title{font-size:2rem;font-weight:700;color:#fff;margin-bottom:.5rem;text-shadow:0 2px 10px rgba(0,0,0,.2)}.subtitle{font-size:.95rem;color:#fffc;margin-bottom:2rem}.api-key-section{background:#fffffff2;border-radius:16px;padding:1.5rem;margin-bottom:1.5rem;box-shadow:0 8px 32px #0000001a}.api-key-section label{display:block;font-size:.85rem;font-weight:600;color:#555;margin-bottom:.5rem;text-align:left}.api-key-input-row{display:flex;gap:.5rem}.api-key-input-row input{flex:1;padding:.6rem 1rem;border:2px solid #e0e0e0;border-radius:10px;font-size:.9rem;outline:none;transition:border-color .2s}.api-key-input-row input:focus{border-color:#667eea}.save-btn{padding:.6rem 1.2rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:10px;font-size:.85rem;font-weight:600;cursor:pointer;transition:opacity .2s;white-space:nowrap}.save-btn:hover{opacity:.9}.api-key-saved{display:flex;align-items:center;justify-content:space-between;padding:.6rem 1rem;background:#f0f7f0;border-radius:10px;font-size:.85rem;color:#2d7a2d}.change-key-btn{background:none;border:none;color:#667eea;font-size:.8rem;cursor:pointer;text-decoration:underline;padding:0}.upload-card{background:#fffffff2;border-radius:16px;padding:2rem;margin-bottom:1.5rem;box-shadow:0 8px 32px #0000001a}.dropzone{border:3px dashed #ccc;border-radius:12px;padding:3rem 2rem;cursor:pointer;transition:all .3s;position:relative}.dropzone:hover,.dropzone.drag-over{border-color:#667eea;background:#667eea0d}.dropzone-icon{font-size:3rem;margin-bottom:.5rem}.dropzone p{color:#888;font-size:.95rem}.dropzone small{color:#aaa;font-size:.8rem}.dropzone input{display:none}.preview-section{margin-top:1.5rem}.preview-image{max-width:100%;max-height:300px;border-radius:12px;object-fit:cover;box-shadow:0 4px 16px #0000001a}.analyze-btn{margin-top:1rem;padding:.8rem 2.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .2s,opacity .2s}.analyze-btn:hover:not(:disabled){transform:translateY(-2px);opacity:.95}.analyze-btn:disabled{opacity:.6;cursor:not-allowed}.reset-btn{margin-top:.5rem;padding:.5rem 1.5rem;background:transparent;color:#888;border:1px solid #ddd;border-radius:10px;font-size:.85rem;cursor:pointer;transition:all .2s}.reset-btn:hover{background:#f5f5f5;color:#555}.loading{padding:3rem 2rem}.spinner{width:50px;height:50px;border:4px solid #e0e0e0;border-top-color:#667eea;border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 1rem}@keyframes spin{to{transform:rotate(360deg)}}.loading p{color:#888;font-size:.95rem}.result-card{background:#fffffff2;border-radius:16px;padding:2rem;margin-bottom:1.5rem;box-shadow:0 8px 32px #0000001a}.result-card h2{font-size:1.3rem;color:#333;margin-bottom:1.5rem}.score-item{margin-bottom:1.2rem;text-align:left}.score-label{display:flex;justify-content:space-between;align-items:center;margin-bottom:.4rem}.country-name{font-size:1.1rem;font-weight:600;color:#333}.score-value{font-size:1.1rem;font-weight:700;color:#667eea}.score-bar{height:14px;background:#eee;border-radius:7px;overflow:hidden}.score-fill{height:100%;border-radius:7px;transition:width 1s ease-out}.score-fill.korea{background:linear-gradient(90deg,#0047a0,#cd2e3a)}.score-fill.china{background:linear-gradient(90deg,#de2910,#ffde00)}.score-fill.japan{background:linear-gradient(90deg,#bc002d,#ff6b9d)}.winner{margin:1.5rem 0;padding:1rem;background:linear-gradient(135deg,#fff9c4,#fff176);border-radius:12px;font-size:1.1rem;font-weight:600;color:#5d4037}.comment-box{margin-top:1rem;padding:1rem;background:#f8f9ff;border-radius:12px;text-align:left;line-height:1.7;color:#444;font-size:.92rem}.retry-btn{margin-top:1.5rem;padding:.7rem 2rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;font-size:.95rem;font-weight:600;cursor:pointer;transition:transform .2s}.retry-btn:hover{transform:translateY(-2px)}.error-msg{background:#fff0f0;color:#d32f2f;padding:1rem;border-radius:12px;margin-bottom:1rem;font-size:.9rem}
