*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}textarea::placeholder,input::placeholder{color:#b0bec5}:root{--bg: #f8fafc;--bg-card: #ffffff;--bg-card-2: #f1f5f9;--purple: #7c3aed;--purple-light: #a78bfa;--cyan: #0891b2;--cyan-light: #67e8f9;--green: #059669;--green-light: #6ee7b7;--gold: #d97706;--gold-light: #fcd34d;--red: #dc2626;--text: #0f172a;--text-2: #475569;--text-3: #94a3b8;--border: #e2e8f0;--border-2: #cbd5e1}html,body{height:100%;background:var(--bg);color:var(--text);font-family:Noto Sans KR,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;-webkit-font-smoothing:antialiased;line-height:1.6}#root{min-height:100vh}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}@keyframes fadeUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{opacity:0;transform:scale(.85)}to{opacity:1;transform:scale(1)}}@keyframes slideRight{0%{transform:translate(110%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes slideOut{0%{transform:translate(0);opacity:1}to{transform:translate(110%);opacity:0}}@keyframes badgePop{0%{transform:scale(0) rotate(-20deg);opacity:0}65%{transform:scale(1.2) rotate(5deg)}to{transform:scale(1) rotate(0);opacity:1}}@keyframes shimmer{0%{background-position:-200% center}to{background-position:200% center}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.55}}@keyframes xpFloat{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(-50px) scale(1.3)}}@keyframes glow{0%,to{box-shadow:0 0 10px #7c3aed40}50%{box-shadow:0 0 22px #7c3aed8c}}@keyframes spin{to{transform:rotate(360deg)}}.fade-up{animation:fadeUp .45s ease both}.fade-in{animation:fadeIn .3s ease both}.scale-in{animation:scaleIn .35s ease both}.gold-text{background:linear-gradient(135deg,#f59e0b,#fcd34d);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.progress-track{width:100%;height:8px;background:#e2e8f0;border-radius:999px;overflow:hidden}.progress-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,var(--purple),var(--cyan));transition:width .9s cubic-bezier(.4,0,.2,1)}button{cursor:pointer;border:none;font-family:inherit;font-size:1rem}input,textarea{font-family:inherit}.badge-toast{position:fixed;top:24px;right:24px;z-index:9999;display:flex;align-items:center;gap:14px;padding:16px 20px;background:#fff;border:1px solid rgba(124,58,237,.3);border-radius:16px;box-shadow:0 8px 32px #0000001f,0 0 0 1px #7c3aed1a;animation:slideRight .5s cubic-bezier(.34,1.56,.64,1) both;max-width:340px}.badge-toast.hiding{animation:slideOut .4s ease forwards}.legendary-shimmer{background:linear-gradient(90deg,#fde04714,#fde04740,#fde04714);background-size:200% 100%;animation:shimmer 2.5s linear infinite}
