/* ============================================
   PAST LOVER — neon_cyber 테마
   네온 글로우, 둥근 그라디언트, 사이버펑크 UI
   ============================================ */
:root{--primary:#a855f7;--secondary:#06b6d4;--bg:#0a0a1a;--text:#e0e0f0;--card-bg:rgba(168,85,247,0.06);--card-border:rgba(168,85,247,0.2);--card-shadow:0 0 20px rgba(168,85,247,0.08);--radius:20px;--font:'Nanum Square Round','Apple SD Gothic Neo',sans-serif;--primary-rgb:168,85,247}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--font);background:var(--bg);color:var(--text);min-height:100vh;display:flex;flex-direction:column;align-items:center;padding:16px 12px;overflow-x:hidden;position:relative}
body::before{content:'';position:fixed;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(ellipse at 30% 20%,rgba(168,85,247,0.08),transparent 50%),radial-gradient(ellipse at 70% 80%,rgba(6,182,212,0.06),transparent 50%);z-index:0;pointer-events:none}
#bg-canvas{position:fixed;top:0;left:0;width:100%;height:100%;z-index:0;pointer-events:none}
#app{position:relative;z-index:1;width:100%;max-width:480px;padding:24px 16px}

/* 프로그레스 — 둥근 네온 그라디언트 바 */
.progress-wrap{width:100%;height:8px;background:rgba(168,85,247,0.08);border-radius:4px;margin-bottom:24px;overflow:hidden;display:none;box-shadow:inset 0 0 8px rgba(0,0,0,0.3)}
.progress-bar{height:100%;width:0%;background:linear-gradient(90deg,var(--primary),var(--secondary),var(--primary));background-size:200% 100%;animation:gradientFlow 3s ease infinite;border-radius:4px;transition:width .4s ease;box-shadow:0 0 12px rgba(168,85,247,0.4)}
@keyframes gradientFlow{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}

.screen{display:none;animation:portalIn .6s ease}
.screen.active{display:block}
@keyframes portalIn{from{opacity:0;transform:scale(.9) rotate(-2deg)}to{opacity:1;transform:scale(1) rotate(0)}}

.hero-img{width:100%;aspect-ratio:2/1;object-fit:cover;border-radius:var(--radius);margin-bottom:20px;display:none;border:1px solid var(--card-border);box-shadow:0 0 20px rgba(168,85,247,0.15)}

h1{font-size:1.6em;text-align:center;line-height:1.4;margin-bottom:12px;background:linear-gradient(135deg,var(--primary),var(--secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
h2{font-size:1.1em;text-align:center;line-height:1.5;margin-bottom:20px;font-weight:400;opacity:.8}
p{text-align:center;line-height:1.7;margin-bottom:14px;opacity:.75}
.q-emoji{display:block;text-align:center;font-size:2.8em;margin-bottom:8px;filter:drop-shadow(0 0 8px rgba(168,85,247,0.3))}
.q-sub{font-size:.82em;opacity:.5;text-align:center}

/* 버튼 — 둥근 그라디언트 글로우 */
.btn{display:block;width:100%;padding:16px;font-size:.95em;font-weight:700;cursor:pointer;border:none;border-radius:50px;margin:24px 0;transition:all .3s ease;font-family:var(--font)}
.btn-primary{background:linear-gradient(135deg,var(--primary),var(--secondary));color:#fff;box-shadow:0 4px 20px rgba(168,85,247,0.3)}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 8px 30px rgba(168,85,247,0.5)}
.btn-outline{background:transparent;border:2px solid var(--primary);color:var(--primary);border-radius:50px}
.btn-outline:hover{background:rgba(168,85,247,0.1);box-shadow:0 0 20px rgba(168,85,247,0.2)}
.btn-link{background:rgba(168,85,247,0.08);color:var(--text);border-radius:50px;border:1px solid var(--card-border)}

/* 선택지 — 둥근 카드, 네온 보더 글로우 */
.choice-btn{display:flex;align-items:center;gap:14px;width:100%;padding:16px 20px;font-size:.92em;font-weight:600;cursor:pointer;border:1px solid var(--card-border);background:var(--card-bg);color:var(--text);border-radius:16px;margin:10px 0;transition:all .25s ease;text-align:left;backdrop-filter:blur(8px);font-family:var(--font)}
.choice-btn:hover{border-color:var(--primary);box-shadow:0 0 20px rgba(168,85,247,0.15),inset 0 0 20px rgba(168,85,247,0.05);transform:scale(1.02)}
.choice-btn .choice-icon{font-size:1.4em;flex-shrink:0;filter:drop-shadow(0 0 4px rgba(168,85,247,0.3))}
.choice-btn.selected{border-color:var(--primary);background:rgba(168,85,247,0.12);box-shadow:0 0 24px rgba(168,85,247,0.2)}

.timer-wrap{display:none;margin-bottom:16px;position:relative;height:28px;background:rgba(168,85,247,0.06);border-radius:14px;overflow:hidden;border:1px solid rgba(168,85,247,0.15)}
.timer-bar{height:100%;background:linear-gradient(90deg,var(--primary),#ef4444);border-radius:14px;transition:width .1s linear;box-shadow:0 0 10px rgba(168,85,247,0.3)}
.timer-wrap span{position:absolute;right:10px;top:50%;transform:translateY(-50%);font-size:.75em;font-weight:700}

.result-label{font-size:.7em;text-transform:uppercase;letter-spacing:3px;opacity:.4;text-align:center;margin-bottom:4px;color:var(--secondary)}
.result-title{font-size:1.7em;text-align:center;background:linear-gradient(135deg,var(--primary),var(--secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1.4}
.result-subtitle{font-size:.88em;opacity:.6;text-align:center}
.result-desc{font-size:.95em;text-align:center;line-height:1.8}
.tags-wrap{display:flex;flex-wrap:wrap;justify-content:center;gap:8px;margin:16px 0}
.tag{padding:5px 14px;border-radius:50px;font-size:.72em;font-weight:700;background:rgba(168,85,247,0.1);color:var(--primary);border:1px solid rgba(168,85,247,0.25)}
details{margin:20px 0;text-align:left;background:rgba(168,85,247,0.04);border-radius:12px;overflow:hidden}
details summary{cursor:pointer;font-weight:700;padding:12px 16px;opacity:.7;font-size:.88em}
details p{padding:8px 16px 16px;font-size:.88em;line-height:1.8;text-align:left}
#radar-chart{display:block;margin:20px auto}
.compat-box{padding:14px;border-radius:12px;background:rgba(168,85,247,0.06);border:1px solid rgba(168,85,247,0.12);margin:16px 0;font-size:.85em;text-align:center}
.loader{width:44px;height:44px;border:3px solid rgba(168,85,247,.1);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite;margin:50px auto 20px;box-shadow:0 0 20px rgba(168,85,247,0.15)}
@keyframes spin{to{transform:rotate(360deg)}}
#screen-loading h2{text-align:center;margin-top:16px}
#recovery-banner{display:none;background:rgba(168,85,247,0.08);color:var(--primary);padding:12px;border-radius:12px;text-align:center;font-size:.82em;font-weight:700;cursor:pointer;margin-bottom:20px;border:1px solid rgba(168,85,247,0.2)}
.pulse{animation:pulse 2.5s ease infinite}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(168,85,247,.3)}50%{box-shadow:0 0 0 14px rgba(168,85,247,0)}}
@keyframes shake{0%,100%{transform:translateX(0)}25%{transform:translateX(-6px) rotate(-1deg)}75%{transform:translateX(6px) rotate(1deg)}}
@keyframes glow{0%{box-shadow:0 0 0 rgba(168,85,247,0)}50%{box-shadow:0 0 30px rgba(168,85,247,.4)}100%{box-shadow:0 0 0 rgba(168,85,247,0)}}
@keyframes confettiBurst{0%{transform:scale(1)}50%{transform:scale(1.06)}100%{transform:scale(1)}}
@keyframes flash{0%{filter:brightness(1) hue-rotate(0)}50%{filter:brightness(1.5) hue-rotate(20deg)}100%{filter:brightness(1) hue-rotate(0)}}
.react-shake{animation:shake .4s ease}.react-glow{animation:glow .6s ease}.react-confetti{animation:confettiBurst .4s ease}.react-flash{animation:flash .3s ease}
.mood-tense #app{filter:contrast(1.05)}.mood-dramatic #app{filter:saturate(1.15)}.mood-mysterious{background:radial-gradient(ellipse at center,rgba(168,85,247,.1),transparent)}.mood-playful #app{filter:saturate(1.1)}
