/* ============================================
   LOVE TIMER — pastel_dream 테마
   파스텔 버블, 소프트 그림자, 플로팅 카드, 구름 같은 UI
   ============================================ */
:root{--primary:#ec4899;--secondary:#8b5cf6;--bg:#fef7ff;--text:#4a3060;--card-bg:rgba(236,72,153,0.04);--card-border:rgba(236,72,153,0.12);--card-shadow:0 8px 24px rgba(236,72,153,0.08);--radius:24px;--font:'Nanum Square Round','Apple SD Gothic Neo',sans-serif;--primary-rgb:236,72,153}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--font);background:var(--bg);background-image:radial-gradient(ellipse at 20% 0%,rgba(236,72,153,0.06),transparent 60%),radial-gradient(ellipse at 80% 100%,rgba(139,92,246,0.06),transparent 60%);color:var(--text);min-height:100vh;display:flex;flex-direction:column;align-items:center;padding:16px 12px;overflow-x:hidden}
#bg-canvas{display:none}
#app{position:relative;z-index:1;width:100%;max-width:480px;padding:28px 16px}

/* 프로그레스 — 둥근 파스텔 도트 스타일 */
.progress-wrap{width:100%;height:10px;background:rgba(236,72,153,0.06);border-radius:5px;margin-bottom:24px;overflow:hidden;display:none}
.progress-bar{height:100%;width:0%;background:linear-gradient(90deg,var(--primary),var(--secondary));border-radius:5px;transition:width .5s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 8px rgba(236,72,153,0.2)}

.screen{display:none;animation:floatIn .7s cubic-bezier(.4,0,.2,1)}
.screen.active{display:block}
@keyframes floatIn{from{opacity:0;transform:translateY(40px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}

.hero-img{width:100%;aspect-ratio:3/2;object-fit:cover;border-radius:20px;margin-bottom:20px;display:none;box-shadow:0 12px 32px rgba(236,72,153,0.12)}

h1{font-size:1.5em;text-align:center;line-height:1.5;margin-bottom:8px;font-weight:800;color:var(--text)}
h2{font-size:1.05em;text-align:center;line-height:1.5;margin-bottom:24px;font-weight:400;color:rgba(74,48,96,0.65)}
p{text-align:center;line-height:1.8;margin-bottom:14px;opacity:.75;font-size:.92em}
.q-emoji{display:block;text-align:center;font-size:2.8em;margin-bottom:8px;animation:floaty 3s ease-in-out infinite}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
.q-sub{font-size:.82em;opacity:.45;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 .35s cubic-bezier(.4,0,.2,1);font-family:var(--font)}
.btn-primary{background:linear-gradient(135deg,var(--primary),var(--secondary));color:#fff;box-shadow:0 6px 20px rgba(236,72,153,0.25)}
.btn-primary:hover{transform:translateY(-3px) scale(1.02);box-shadow:0 10px 30px rgba(236,72,153,0.35)}
.btn-outline{background:#fff;border:2px solid var(--primary);color:var(--primary);border-radius:50px;box-shadow:0 4px 12px rgba(0,0,0,0.04)}
.btn-outline:hover{background:var(--primary);color:#fff;box-shadow:0 6px 20px rgba(236,72,153,0.2)}
.btn-link{background:#fff;color:var(--text);border-radius:50px;box-shadow:0 2px 8px rgba(0,0,0,0.04)}

/* 선택지 — 부풀어오르는 버블 카드 */
.choice-btn{display:flex;align-items:center;gap:14px;width:100%;padding:18px 20px;font-size:.92em;font-weight:600;cursor:pointer;border:none;background:#fff;color:var(--text);border-radius:20px;margin:10px 0;transition:all .3s cubic-bezier(.4,0,.2,1);text-align:left;font-family:var(--font);box-shadow:0 4px 16px rgba(0,0,0,0.04)}
.choice-btn:hover{transform:translateY(-3px) scale(1.01);box-shadow:0 8px 24px rgba(236,72,153,0.12);background:linear-gradient(135deg,rgba(236,72,153,0.03),rgba(139,92,246,0.03))}
.choice-btn .choice-icon{font-size:1.4em;flex-shrink:0;width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:rgba(236,72,153,0.06);border-radius:14px}
.choice-btn.selected{background:linear-gradient(135deg,rgba(236,72,153,0.08),rgba(139,92,246,0.08));box-shadow:0 4px 16px rgba(236,72,153,0.15);transform:scale(.97)}

.timer-wrap{display:none;margin-bottom:20px;position:relative;height:24px;background:rgba(236,72,153,0.05);border-radius:12px;overflow:hidden}
.timer-bar{height:100%;background:linear-gradient(90deg,var(--primary),#ef4444);border-radius:12px;transition:width .1s linear}
.timer-wrap span{position:absolute;right:10px;top:50%;transform:translateY(-50%);font-size:.72em;font-weight:700;color:rgba(74,48,96,0.5)}

.result-label{font-size:.7em;text-transform:uppercase;letter-spacing:3px;opacity:.35;text-align:center;margin-bottom:4px}
.result-title{font-size:1.6em;text-align:center;background:linear-gradient(135deg,var(--primary),var(--secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-weight:800;line-height:1.4}
.result-subtitle{font-size:.88em;opacity:.55;text-align:center}
.result-desc{font-size:.92em;text-align:center;line-height:1.9}
.tags-wrap{display:flex;flex-wrap:wrap;justify-content:center;gap:8px;margin:16px 0}
.tag{padding:6px 16px;border-radius:50px;font-size:.72em;font-weight:700;background:rgba(236,72,153,0.06);color:var(--primary);border:none;box-shadow:0 2px 6px rgba(236,72,153,0.08)}
details{margin:20px 0;text-align:left;background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 4px 12px rgba(0,0,0,0.03)}
details summary{cursor:pointer;font-weight:700;padding:14px 16px;opacity:.6;font-size:.85em}
details p{padding:0 16px 16px;font-size:.87em;line-height:1.8;text-align:left}
#radar-chart{display:block;margin:24px auto}
.compat-box{padding:16px;border-radius:16px;background:#fff;box-shadow:0 4px 12px rgba(0,0,0,0.03);margin:16px 0;font-size:.85em;text-align:center}
.loader{width:40px;height:40px;border:4px solid rgba(236,72,153,.08);border-top-color:var(--primary);border-radius:50%;animation:spin 1s cubic-bezier(.5,0,.5,1) infinite;margin:50px auto 20px}
@keyframes spin{to{transform:rotate(360deg)}}
#screen-loading h2{text-align:center;margin-top:16px;font-weight:400}
#recovery-banner{display:none;background:#fff;color:var(--primary);padding:14px;border-radius:16px;text-align:center;font-size:.82em;font-weight:700;cursor:pointer;margin-bottom:20px;box-shadow:0 4px 12px rgba(236,72,153,0.08)}
.pulse{animation:softPulse 2.5s ease infinite}
@keyframes softPulse{0%,100%{box-shadow:0 6px 20px rgba(236,72,153,.25)}50%{box-shadow:0 6px 20px rgba(236,72,153,.45),0 0 0 8px rgba(236,72,153,.06)}}
@keyframes shake{0%,100%{transform:translateY(-3px)}50%{transform:translateY(3px)}}
@keyframes glow{0%{box-shadow:0 4px 16px rgba(0,0,0,.04)}50%{box-shadow:0 4px 24px rgba(236,72,153,.2)}100%{box-shadow:0 4px 16px rgba(0,0,0,.04)}}
@keyframes confettiBurst{0%{transform:scale(1)}40%{transform:scale(1.06) rotate(1deg)}100%{transform:scale(1)}}
@keyframes flash{0%{background:#fff}50%{background:rgba(236,72,153,0.06)}100%{background:#fff}}
.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{}.mood-dramatic #app{filter:saturate(1.1)}.mood-mysterious{}.mood-playful #app{filter:brightness(1.02)}
