:root{
  --bg0:#080610;
  --bg1:#150b26;
  --gold:#f5c451;
  --rare:#ffd76a;
  --ink:#f6efe3;
  --glow:#f5c451;        /* 현재 카드 색, JS가 갱신 */
  --cardW:clamp(220px,62vw,268px);
}
*{box-sizing:border-box;}
html{margin:0;background:var(--bg0);overflow-x:hidden;width:100%;}
body{
  margin:0;min-height:100vh;width:100%;max-width:100%;
  position:relative;
  font-family:system-ui,-apple-system,"Segoe UI","Apple SD Gothic Neo",sans-serif;
  color:var(--ink);
  background:linear-gradient(165deg,var(--bg1),var(--bg0) 70%) fixed;
  overflow-x:hidden;
}
/* ───────── 언어 토글 ───────── */
.lang-toggle{
  position:fixed;top:12px;right:12px;z-index:120;
  display:flex;gap:2px;padding:3px;border-radius:30px;
  background:rgba(20,10,40,.7);backdrop-filter:blur(6px);
  border:1px solid rgba(245,196,81,.3);
}
.lang-toggle button{
  cursor:pointer;border:none;background:none;
  padding:5px 11px;border-radius:30px;
  font-size:12px;font-weight:700;letter-spacing:.04em;
  color:rgba(246,239,227,.5);transition:background .15s,color .15s;
}
.lang-toggle button.active{background:var(--gold);color:#1a0e2e;}
.lang-toggle button:not(.active):hover{color:rgba(246,239,227,.9);}

/* ───────── 로딩 화면 (카드 셔플) ───────── */
.loader{
  position:fixed;inset:0;z-index:999;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;
  background:radial-gradient(circle at 50% 38%,#1c1033,#080610 78%);
  transition:opacity .55s ease,visibility .55s ease;
}
.loader.hide{opacity:0;visibility:hidden;pointer-events:none;}
.load-deck{
  position:relative;width:108px;height:162px;margin-bottom:26px;
  perspective:900px;
}
.load-card{
  position:absolute;top:0;left:0;width:108px;height:162px;border-radius:11px;
  background:url(cards/back.webp) center/cover no-repeat,#150b26;
  box-shadow:0 10px 30px rgba(0,0,0,.55),inset 0 0 0 1px rgba(245,196,81,.25);
  transform-origin:50% 120%;
  animation:shuffle 1.9s cubic-bezier(.45,.05,.35,1) infinite;
}
.load-card:nth-child(1){--dx:-78px;--rz:-20deg;animation-delay:0s;}
.load-card:nth-child(2){--dx:62px;--rz:16deg;animation-delay:.09s;}
.load-card:nth-child(3){--dx:-50px;--rz:-12deg;animation-delay:.18s;}
.load-card:nth-child(4){--dx:44px;--rz:11deg;animation-delay:.27s;}
.load-card:nth-child(5){--dx:-30px;--rz:-7deg;animation-delay:.36s;}
.load-card:nth-child(6){--dx:24px;--rz:6deg;animation-delay:.45s;}
.load-card:nth-child(7){--dx:0px;--rz:0deg;animation-delay:.54s;}
@keyframes shuffle{
  0%   {transform:translate(0,0) rotateZ(0) scale(1);}
  30%  {transform:translate(var(--dx),-46px) rotateZ(var(--rz)) scale(1.02);}
  55%  {transform:translate(calc(var(--dx)*-.55),12px) rotateZ(calc(var(--rz)*-.5)) scale(.99);}
  80%  {transform:translate(calc(var(--dx)*.25),-6px) rotateZ(calc(var(--rz)*.3)) scale(1);}
  100% {transform:translate(0,0) rotateZ(0) scale(1);}
}
.load-title{
  font-size:clamp(22px,5vw,32px);font-weight:800;letter-spacing:.22em;
  background:linear-gradient(90deg,#fff,var(--gold),#fff);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  filter:drop-shadow(0 0 22px rgba(245,196,81,.35));
}
.load-sub{font-size:12px;letter-spacing:.26em;color:rgba(246,239,227,.5);}
.load-dots::after{content:"";animation:loadDots 1.4s steps(4,end) infinite;}
@keyframes loadDots{0%{content:"";}25%{content:".";}50%{content:"..";}75%{content:"...";}100%{content:"";}}

canvas#nebula,canvas#stars{position:fixed;inset:0;width:100%;height:100%;z-index:0;pointer-events:none;}
canvas#fx{position:fixed;inset:0;width:100%;height:100%;z-index:40;pointer-events:none;}
#flash{position:fixed;inset:0;z-index:45;pointer-events:none;opacity:0;
  background:radial-gradient(circle at 50% 42%,rgba(255,245,210,.9),rgba(255,215,106,.35) 40%,transparent 70%);}
#flash.go{animation:flash .7s ease-out;}
@keyframes flash{0%{opacity:0;}12%{opacity:1;}100%{opacity:0;}}

.scene-wrap{position:relative;z-index:1;max-width:760px;margin:0 auto;padding:26px 18px 70px;text-align:center;}

.topbar h1{
  margin:6px 0 2px;font-size:clamp(24px,5.5vw,38px);font-weight:800;letter-spacing:.18em;
  background:linear-gradient(90deg,#fff,var(--gold),#fff);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  filter:drop-shadow(0 0 24px rgba(245,196,81,.3));
}
.sub{margin:0 0 10px;font-size:12px;letter-spacing:.34em;color:rgba(246,239,227,.5);}
.streak{margin:0 0 12px;font-size:12px;letter-spacing:.06em;font-weight:600;
  color:#ffb347;text-shadow:0 0 14px rgba(255,140,40,.4);min-height:16px;}

/* ───────── 3D 무대 ───────── */
.stage{
  position:relative;
  height:clamp(420px,68vw,470px);
  perspective:1300px;perspective-origin:50% 40%;
  display:flex;align-items:center;justify-content:center;
}

/* 빛나는 후광 */
.halo{
  position:absolute;width:calc(var(--cardW)*1.7);height:calc(var(--cardW)*1.7);
  border-radius:50%;pointer-events:none;z-index:0;
  background:radial-gradient(circle,color-mix(in srgb,var(--glow) 55%,transparent),transparent 62%);
  filter:blur(12px);opacity:.18;transition:opacity .45s ease,transform .45s ease;
}
.stage.hot .halo{opacity:.5;transform:scale(1.06);}
.stage.revealed .halo{opacity:.45;animation:haloBreath 3.4s ease-in-out infinite;}
.stage.revealed.rare .halo{opacity:.7;}
@keyframes haloBreath{0%,100%{transform:scale(1);opacity:.4;}50%{transform:scale(1.12);opacity:.7;}}

/* 회전하는 빛줄기 */
.rays{
  position:absolute;width:calc(var(--cardW)*2.5);height:calc(var(--cardW)*2.5);
  pointer-events:none;z-index:0;opacity:0;transition:opacity .8s ease;
  background:repeating-conic-gradient(from 0deg,
    color-mix(in srgb,var(--glow) 45%,transparent) 0deg 4deg,
    transparent 4deg 16deg);
  -webkit-mask:radial-gradient(circle,transparent 24%,#000 30%,transparent 72%);
          mask:radial-gradient(circle,transparent 24%,#000 30%,transparent 72%);
  animation:spinRays 24s linear infinite;
}
.stage.revealed .rays{opacity:.35;}
.stage.revealed.rare .rays{opacity:.6;animation-duration:14s;}
@keyframes spinRays{to{transform:rotate(360deg);}}

/* 골드 충격파 (레어) */
.shock{
  position:absolute;width:var(--cardW);height:var(--cardW);border-radius:50%;
  pointer-events:none;z-index:30;opacity:0;border:3px solid var(--rare);
  box-shadow:0 0 40px rgba(255,215,106,.8),inset 0 0 30px rgba(255,215,106,.5);
}
.shock.go{animation:shockwave 1.1s cubic-bezier(.1,.7,.3,1);}
@keyframes shockwave{0%{opacity:.9;transform:scale(.3);}100%{opacity:0;transform:scale(3.4);}}

/* ───────── 카드 레이어 ───────── */
.card-float{transform-style:preserve-3d;animation:floaty 4.6s ease-in-out infinite;}
@keyframes floaty{0%,100%{transform:translateY(0) rotateZ(-1deg);}50%{transform:translateY(-16px) rotateZ(1deg);}}

.card-tilt{
  transform-style:preserve-3d;
  transition:transform .25s ease;
  transform:rotateX(0) rotateY(0) scale(1);
  cursor:pointer;
}
.stage.hot .card-tilt{transition:transform .08s linear;}

.card-flip{
  position:relative;width:var(--cardW);aspect-ratio:2/3;
  transform-style:preserve-3d;
  transition:transform 1.15s cubic-bezier(.2,.85,.2,1);
  transform:rotateY(180deg);
  z-index:10;
}
/* 뽑기: 뒷면 유지한 채 흔들림 + 빛 점멸 (앞면이 보이지 않음) */
.card-flip.charging{animation:cardCharge 1.15s ease-in-out;}
@keyframes cardCharge{
  0%  {transform:rotateY(180deg) translate(0,0) rotateZ(0);}
  8%  {transform:rotateY(180deg) translate(-5px,1px) rotateZ(-1.6deg);}
  16% {transform:rotateY(180deg) translate(6px,-1px) rotateZ(1.8deg);}
  24% {transform:rotateY(180deg) translate(-7px,1px) rotateZ(-2.1deg);}
  32% {transform:rotateY(180deg) translate(7px,-2px) rotateZ(2.3deg);}
  40% {transform:rotateY(180deg) translate(-8px,1px) rotateZ(-2.5deg) scale(1.01);}
  48% {transform:rotateY(180deg) translate(8px,-1px) rotateZ(2.7deg) scale(1.02);}
  56% {transform:rotateY(180deg) translate(-9px,2px) rotateZ(-2.9deg) scale(1.03);}
  64% {transform:rotateY(180deg) translate(9px,-2px) rotateZ(3deg) scale(1.04);}
  72% {transform:rotateY(180deg) translate(-8px,1px) rotateZ(-2.6deg) scale(1.05);}
  80% {transform:rotateY(180deg) translate(6px,-1px) rotateZ(2deg) scale(1.06);}
  88% {transform:rotateY(180deg) translate(-3px,0) rotateZ(-1deg) scale(1.05);}
  100%{transform:rotateY(180deg) translate(0,0) rotateZ(0) scale(1.03);}
}
/* 충전 중 빛 점멸 */
.stage.charging .halo{opacity:1;animation:haloBlink .3s ease-in-out infinite;}
@keyframes haloBlink{0%,46%{opacity:.85;transform:scale(1.12);}50%,100%{opacity:.12;transform:scale(.95);}}
.card-flip.charging .back{animation:backEdgeGlow .3s ease-in-out infinite;}
@keyframes backEdgeGlow{
  0%,46%{box-shadow:0 0 0 3px rgba(245,196,81,.85),0 0 32px rgba(245,196,81,.65),0 0 72px rgba(245,196,81,.35),0 26px 64px rgba(0,0,0,.62);}
  50%,100%{box-shadow:0 0 0 1px rgba(245,196,81,.1),0 26px 64px rgba(0,0,0,.62);}
}
/* ───── 레어/포일 전조(omen): 공개 직전 기대감 연출 ───── */
/* 흔들림을 더 길게(충전 1.65s에 맞춰) + 막판에 더 크게 떨림 */
.card-flip.charging.omen{animation:cardCharge 1.55s ease-in-out;}
/* 두근거림(배경 빛)을 더 빠르게 */
.stage.charging.omen .halo{animation-duration:.2s;}

/* 레어: 금빛 + 백광이 더 크고 강하게 맥동 */
.card-flip.charging.omen-rare .back{animation:omenGlowRare .24s ease-in-out infinite;}
@keyframes omenGlowRare{
  0%,42%{box-shadow:0 0 0 4px rgba(255,236,150,.95),0 0 50px rgba(255,212,92,.85),0 0 120px rgba(255,200,80,.55),0 26px 64px rgba(0,0,0,.62);}
  50%,100%{box-shadow:0 0 0 2px rgba(255,236,150,.28),0 0 16px rgba(255,212,92,.28),0 26px 64px rgba(0,0,0,.62);}
}
/* 포일: 무지개 메탈릭 빛이 끊김 없이 색을 도는 전조 */
.card-flip.charging.omen-foil .back{animation:omenGlowFoil 1s linear infinite;}
@keyframes omenGlowFoil{
  0%  {box-shadow:0 0 0 4px hsla(0,90%,72%,.92),0 0 54px hsla(0,90%,66%,.7),0 0 110px hsla(0,90%,66%,.4),0 26px 64px rgba(0,0,0,.62);}
  25% {box-shadow:0 0 0 4px hsla(90,90%,72%,.92),0 0 54px hsla(90,90%,66%,.7),0 0 110px hsla(90,90%,66%,.4),0 26px 64px rgba(0,0,0,.62);}
  50% {box-shadow:0 0 0 4px hsla(185,90%,72%,.92),0 0 54px hsla(185,90%,66%,.7),0 0 110px hsla(185,90%,66%,.4),0 26px 64px rgba(0,0,0,.62);}
  75% {box-shadow:0 0 0 4px hsla(280,90%,74%,.92),0 0 54px hsla(280,90%,66%,.7),0 0 110px hsla(280,90%,66%,.4),0 26px 64px rgba(0,0,0,.62);}
  100%{box-shadow:0 0 0 4px hsla(360,90%,72%,.92),0 0 54px hsla(360,90%,66%,.7),0 0 110px hsla(360,90%,66%,.4),0 26px 64px rgba(0,0,0,.62);}
}

/* 레어 + 특성 = 잭팟: 금빛 안쪽 링 고정 + 무지개 바깥 광이 도는 전조 */
.card-flip.charging.omen-both .back{animation:omenGlowBoth .8s linear infinite;}
@keyframes omenGlowBoth{
  0%  {box-shadow:0 0 0 4px rgba(255,236,150,.95),0 0 56px hsla(0,90%,66%,.78),0 0 130px hsla(0,90%,66%,.45),0 26px 64px rgba(0,0,0,.62);}
  25% {box-shadow:0 0 0 4px rgba(255,236,150,.95),0 0 56px hsla(90,90%,66%,.78),0 0 130px hsla(90,90%,66%,.45),0 26px 64px rgba(0,0,0,.62);}
  50% {box-shadow:0 0 0 4px rgba(255,236,150,.95),0 0 56px hsla(185,90%,66%,.78),0 0 130px hsla(185,90%,66%,.45),0 26px 64px rgba(0,0,0,.62);}
  75% {box-shadow:0 0 0 4px rgba(255,236,150,.95),0 0 56px hsla(280,90%,68%,.78),0 0 130px hsla(280,90%,66%,.45),0 26px 64px rgba(0,0,0,.62);}
  100%{box-shadow:0 0 0 4px rgba(255,236,150,.95),0 0 56px hsla(360,90%,66%,.78),0 0 130px hsla(360,90%,66%,.45),0 26px 64px rgba(0,0,0,.62);}
}

/* 뒤집히는 동안 배경 빛 점멸 (부드럽게) */
.stage.flipping .halo{opacity:.6;animation:haloFlipBlink .34s ease-in-out infinite;}
@keyframes haloFlipBlink{0%,100%{opacity:.28;transform:scale(1);}50%{opacity:.9;transform:scale(1.12);}}
.stage.flipping .rays{opacity:.3;}
.card-flip.flipped{transform:rotateY(0deg);}
.card-flip.flipped.pop{animation:pop 1s cubic-bezier(.2,.9,.2,1);}
@keyframes pop{0%{transform:rotateY(0) scale(1);}38%{transform:rotateY(0) scale(1.06);}100%{transform:rotateY(0) scale(1);}}

.face{position:absolute;inset:0;border-radius:16px;backface-visibility:hidden;overflow:hidden;
  box-shadow:0 26px 64px rgba(0,0,0,.62);}

/* 앞면 */
.front{background:#160f22;border:1.5px solid color-mix(in srgb,var(--glow) 55%,#000);}
.front img{width:100%;height:100%;object-fit:cover;display:block;}
.front .sheen{position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(115deg,transparent 32%,rgba(255,255,255,.45) 48%,transparent 64%);
  transform:translateX(-130%);}
/* 기울기 반사광 (공개 후 마우스 조작 시) */
.front .glare{position:absolute;inset:0;pointer-events:none;opacity:0;
  transition:opacity .35s ease;mix-blend-mode:overlay;
  background:
    radial-gradient(circle at var(--gx,50%) var(--gy,50%),rgba(255,255,255,.6),rgba(255,255,255,0) 42%),
    linear-gradient(calc(var(--gang,120deg)),transparent 38%,rgba(255,255,255,.22) 50%,transparent 62%);}
.stage.revealed.hot .front .glare{opacity:1;}
.card-flip.flipped .front .sheen{animation:sheen 1.2s ease .2s 1;}
@keyframes sheen{to{transform:translateX(130%);}}
/* 현상 연출: 앞면이 드러날 때 흰빛 → 원래 카드 모습으로 */
.front .materialize{position:absolute;inset:0;border-radius:16px;pointer-events:none;opacity:0;
  background:radial-gradient(circle at 50% 42%,#ffffff,#fff3cf 52%,#ffd76a 82%);}
.card-flip.flipped .front .materialize{animation:materialize .7s ease-out;}
@keyframes materialize{0%,28%{opacity:1;}50%{opacity:0;}100%{opacity:0;}}
.card-flip.flipped .front img{animation:materializeImg .7s ease-out;}
@keyframes materializeImg{0%,28%{filter:brightness(3.2) saturate(.25);}55%{filter:brightness(1) saturate(1);}100%{filter:brightness(1) saturate(1);}}
.card-flip.flipped .front{animation:frontGlow .7s ease-out;}
@keyframes frontGlow{
  0%,28%{box-shadow:0 0 70px 14px rgba(255,255,255,.9),0 26px 64px rgba(0,0,0,.62);}
  52%,100%{box-shadow:0 26px 64px rgba(0,0,0,.62);}
}

.rare-frame{position:absolute;inset:0;border-radius:16px;pointer-events:none;opacity:0;}
.card-flip.rare.flipped .rare-frame{
  opacity:1;border:2px solid var(--rare);border-radius:16px;
  box-shadow:0 0 26px rgba(255,215,106,.85),inset 0 0 22px rgba(255,215,106,.5);
  animation:rareFramePulse 2s ease-in-out infinite;
}
@keyframes rareFramePulse{0%,100%{box-shadow:0 0 22px rgba(255,215,106,.6),inset 0 0 16px rgba(255,215,106,.4);}50%{box-shadow:0 0 40px rgba(255,215,106,1),inset 0 0 28px rgba(255,215,106,.7);}}
.card-flip.rare.flipped .front{border-color:var(--rare);}

/* ───────── 카드 속성(variant) 효과 ───────── */
.variant-fx{position:absolute;inset:0;pointer-events:none;opacity:0;border-radius:16px;z-index:6;}
.card-flip.flipped .variant-fx{opacity:1;}

/* FOIL — 무지개 메탈릭 스윕 */
.card-flip.v-foil .variant-fx{mix-blend-mode:color-dodge;
  background:linear-gradient(115deg,transparent 18%,rgba(255,0,170,.5),rgba(0,230,255,.5),rgba(255,235,0,.5),rgba(120,80,255,.5),transparent 82%);
  background-size:280% 280%;animation:foilSweep 3.6s linear infinite;}
@keyframes foilSweep{0%{background-position:0% 50%;}100%{background-position:200% 50%;}}
.card-flip.v-foil .front{box-shadow:0 0 26px rgba(120,200,255,.4);}

/* HOLO — 은은한 홀로그램 (실버 베이스 + 기울이면 흐르는 무지개) */
.card-flip.v-holo .variant-fx{mix-blend-mode:screen;
  background:
    radial-gradient(circle at var(--gx,50%) var(--gy,50%),rgba(255,255,255,.28),transparent 48%),
    linear-gradient(108deg,transparent 4%,rgba(255,150,205,.16) 20%,rgba(150,205,255,.16) 38%,rgba(170,255,200,.16) 54%,rgba(255,235,160,.16) 70%,rgba(205,165,255,.16) 86%,transparent 96%);
  background-size:auto,220% 100%;
  background-position:center,var(--gx,50%) center;}
.card-flip.v-holo .front{box-shadow:0 0 26px rgba(190,205,255,.4);}

/* GLITCH — 외곽 RGB 라인 글리치(위쪽 강조) + 카드 흔들림 */
.card-flip.v-glitch .variant-fx{border-radius:16px;animation:glitchEdge 2.6s steps(1) infinite;}
@keyframes glitchEdge{
  0%,54%,100%{box-shadow:inset 0 3px 0 rgba(0,230,255,.55),inset 0 -1px 0 rgba(255,0,90,.4),inset 2px 0 0 rgba(0,230,255,.45),inset -2px 0 0 rgba(255,0,90,.45);}
  57%{box-shadow:inset 0 7px 0 rgba(0,230,255,.95),inset 0 -3px 0 rgba(255,0,90,.6),inset 6px 0 0 rgba(0,230,255,.85),inset -6px 0 0 rgba(255,0,90,.85);}
  61%{box-shadow:inset 0 2px 0 rgba(0,230,255,.7),inset 0 -6px 0 rgba(255,0,90,.7),inset -4px 0 0 rgba(0,230,255,.8),inset 4px 0 0 rgba(255,0,90,.8);}
  65%{box-shadow:inset 0 9px 0 rgba(0,230,255,.9),inset 0 -2px 0 rgba(255,0,90,.5),inset 3px 0 0 rgba(0,230,255,.7),inset -3px 0 0 rgba(255,0,90,.7);}
  69%{box-shadow:inset 0 4px 0 rgba(0,230,255,.8),inset 0 -4px 0 rgba(255,0,90,.6),inset 5px 0 0 rgba(0,230,255,.6),inset -5px 0 0 rgba(255,0,90,.6);}}
.card-flip.v-glitch .front{box-shadow:0 0 24px rgba(0,210,255,.4);}
.card-flip.v-glitch.flipped .front img{animation:glitchShake 2.6s steps(1) infinite;}
@keyframes glitchShake{
  0%,54%,100%{transform:translate(0,0);}
  57%{transform:translate(-3px,1px);}
  61%{transform:translate(3px,-1px);}
  65%{transform:translate(-2px,1px);}
  69%{transform:translate(2px,0);}}

/* BLOOD — 핏빛 글리치 */
.card-flip.v-blood .variant-fx{mix-blend-mode:multiply;opacity:1;
  background:
    radial-gradient(circle at 50% 8%,rgba(60,0,0,0),rgba(70,0,8,.6) 92%),
    linear-gradient(0deg,rgba(120,0,0,.55),transparent 38%);}
.card-flip.v-blood.flipped .front img{filter:saturate(1.15) contrast(1.06) brightness(.9) hue-rotate(-12deg);
  animation:bloodFlick 4s steps(1) infinite;}
@keyframes bloodFlick{0%,95%,100%{filter:saturate(1.15) contrast(1.06) brightness(.9) hue-rotate(-12deg);}97%{filter:saturate(1.4) contrast(1.2) brightness(.75) hue-rotate(-20deg);}}
.card-flip.v-blood .front{box-shadow:0 0 30px rgba(180,0,30,.55);border-color:rgba(160,0,30,.8);}

/* GOLD — 금빛 광채 */
.card-flip.v-gold .variant-fx{mix-blend-mode:overlay;
  background:linear-gradient(115deg,transparent 28%,rgba(255,225,140,.85) 50%,transparent 72%);
  background-size:250% 250%;animation:goldSweep 2.9s linear infinite;}
@keyframes goldSweep{0%{background-position:0% 50%;}100%{background-position:200% 50%;}}
.card-flip.v-gold .front{box-shadow:inset 0 0 0 3px rgba(255,215,106,.9),0 0 44px rgba(255,200,80,.6);}

/* DIAMOND — 유리 케이스에 봉인된 듯한 고급 3D 글래스 */
.card-flip.v-diamond .variant-fx{border-radius:16px;
  background:
    linear-gradient(115deg,transparent 36%,rgba(255,255,255,.4) 47%,rgba(255,255,255,.12) 50%,rgba(255,255,255,.36) 53%,transparent 63%),
    radial-gradient(85% 60% at var(--gx,28%) var(--gy,18%),rgba(235,250,255,.42),transparent 42%),
    linear-gradient(135deg,rgba(255,255,255,.2),transparent 20%,transparent 80%,rgba(6,22,48,.42));
  background-size:260% 100%,auto,auto;
  background-position:var(--gx,40%) center,center,center;
  box-shadow:
    inset 0 0 0 2px rgba(255,255,255,.4),
    inset 7px 7px 16px rgba(255,255,255,.28),
    inset -7px -7px 18px rgba(6,22,48,.5);}
.card-flip.v-diamond.flipped .front{box-shadow:0 0 0 3px rgba(235,248,255,.45),0 0 38px rgba(175,222,255,.6);border-color:transparent;}

/* 결과 속성 배너 */
.variant-banner{display:none;margin:0 auto 12px;width:max-content;max-width:100%;
  padding:6px 20px;border-radius:999px;font-size:13px;font-weight:800;letter-spacing:.22em;
  color:#fff;text-transform:uppercase;}
.result.has-variant .variant-banner{display:block;}
.vb-foil{background:linear-gradient(90deg,#ff2db4,#27e6ff,#ffe600,#7b5cff);box-shadow:0 0 22px rgba(80,200,255,.6);color:#1a0e2e;}
.vb-holo{background:linear-gradient(90deg,#dfe8ff,#ffe0f3,#e0ffe9,#fff4d6);box-shadow:0 0 22px rgba(190,205,255,.6);color:#1a2233;}
.vb-glitch{background:linear-gradient(90deg,#00d6ff,#ff0060);box-shadow:0 0 22px rgba(0,210,255,.6);}
.vb-blood{background:linear-gradient(90deg,#7a0010,#c8001e);box-shadow:0 0 22px rgba(200,0,40,.7);}
.vb-gold{background:linear-gradient(135deg,#fff0bf,#f5c451);box-shadow:0 0 26px rgba(255,200,80,.7);color:#1a0e2e;}
.vb-diamond{background:linear-gradient(135deg,#eaf7ff,#bfe4ff,#e4fbff,#cfe0ff);box-shadow:0 0 28px rgba(185,228,255,.8);color:#16314a;}

/* 뒷면 (이미지) */
.back{transform:rotateY(180deg);
  background:url(cards/back.webp) center/cover no-repeat;
  border:none;
  display:flex;align-items:center;justify-content:center;}
.back-inner{position:absolute;inset:0;border-radius:inherit;border:none;
  display:flex;flex-direction:column;align-items:center;justify-content:center;}
.emblem{display:none;}
.back-label{display:none;}

/* ───────── 컨트롤 ───────── */
.controls{margin-top:6px;}
.draw-btn{appearance:none;border:none;cursor:pointer;position:relative;overflow:hidden;
  padding:15px 42px;border-radius:999px;font-size:16px;font-weight:800;letter-spacing:.14em;color:#1a0e2e;
  background:linear-gradient(135deg,#ffe9a8,var(--gold) 55%,#e0a92e);
  box-shadow:0 12px 32px rgba(245,196,81,.42),inset 0 1px 0 rgba(255,255,255,.6);
  transition:transform .15s ease,box-shadow .15s ease,opacity .25s;}
.draw-btn:hover{transform:translateY(-2px);box-shadow:0 16px 40px rgba(245,196,81,.6);}
.draw-btn:active{transform:translateY(0);}
.draw-btn:disabled{opacity:.4;cursor:default;transform:none;box-shadow:none;}
.draw-btn::after{content:"";position:absolute;top:0;left:-60%;width:40%;height:100%;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,.8),transparent);
  transform:skewX(-20deg);animation:btnShine 3.6s ease-in-out infinite;}
@keyframes btnShine{0%,60%{left:-60%;}80%,100%{left:130%;}}
.hint{margin-top:10px;font-size:12px;color:rgba(246,239,227,.4);letter-spacing:.1em;transition:opacity .3s;}

/* ───────── 결과 ───────── */
.result{max-width:560px;margin:26px auto 0;text-align:left;opacity:0;transform:translateY(20px);
  transition:opacity .6s ease,transform .6s ease;pointer-events:none;}
.result.show{opacity:1;transform:translateY(0);pointer-events:auto;}
.shared-banner{display:none;margin:0 auto 14px;width:max-content;max-width:100%;
  padding:6px 18px;border-radius:999px;font-size:12px;font-weight:700;letter-spacing:.2em;
  color:#fff;background:linear-gradient(135deg,rgba(255,45,120,.35),rgba(180,60,255,.3));
  border:1px solid rgba(255,45,120,.5);box-shadow:0 0 22px rgba(255,45,120,.3);}
.result.is-shared .shared-banner{display:block;}
.rare-banner{display:none;}
.result.is-rare .rare-banner{display:block;margin:0 auto 16px;width:max-content;
  padding:7px 22px;border-radius:999px;font-size:13px;font-weight:800;letter-spacing:.34em;color:#1a0e2e;
  background:linear-gradient(135deg,#fff0bf,var(--rare));box-shadow:0 0 30px rgba(255,215,106,.7);
  animation:rareBannerIn .6s cubic-bezier(.18,.9,.3,1.5), rareBannerPulse 1.8s ease-in-out .6s infinite;}
@keyframes rareBannerPulse{0%,100%{transform:scale(1);}50%{transform:scale(1.05);}}
/* 레어 배너 등장: 작게 튀어나오며 반짝 */
@keyframes rareBannerIn{
  0%{opacity:0;transform:scale(.3) translateY(6px);filter:brightness(2.2);}
  55%{opacity:1;transform:scale(1.12) translateY(0);filter:brightness(1.5);}
  100%{transform:scale(1);filter:brightness(1);}}
.rare-prob{font-size:11px;font-weight:600;letter-spacing:.12em;opacity:.7;vertical-align:middle;}
.r-head{display:flex;align-items:center;gap:16px;margin-bottom:14px;}
.r-no{font-size:30px;font-weight:800;color:var(--glow);font-variant-numeric:tabular-nums;
  text-shadow:0 0 18px color-mix(in srgb,var(--glow) 60%,transparent);min-width:62px;}
.r-name{margin:0;font-size:23px;font-weight:800;letter-spacing:.03em;line-height:1.15;}
.r-kor{margin:3px 0 0;font-size:13px;color:rgba(246,239,227,.6);letter-spacing:.12em;}
.chips{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px;}
.chip{font-size:12px;padding:5px 13px;border-radius:999px;letter-spacing:.03em;
  background:color-mix(in srgb,var(--glow) 14%,transparent);
  border:1px solid color-mix(in srgb,var(--glow) 40%,transparent);color:var(--glow);}
.block{background:rgba(255,255,255,.04);border:1px solid rgba(246,239,227,.1);border-radius:14px;
  padding:16px 18px;margin-bottom:12px;}
.block.fortune{border-color:color-mix(in srgb,var(--glow) 30%,transparent);
  background:color-mix(in srgb,var(--glow) 7%,rgba(255,255,255,.03));}
.block h3{margin:0 0 7px;font-size:11px;letter-spacing:.2em;color:var(--glow);font-weight:700;}
.block p{margin:0;line-height:1.75;font-size:15px;color:rgba(246,239,227,.92);}
.result-actions{display:flex;flex-direction:column;align-items:center;gap:20px;margin-top:36px;}
.action-row{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;}
.again{display:inline-block;cursor:pointer;color:var(--glow);font-size:14px;letter-spacing:.1em;
  background:none;border:none;text-decoration:underline;text-underline-offset:4px;}
.daily-note{display:none;margin:0;text-align:center;line-height:1.7;
  font-size:13px;letter-spacing:.06em;color:var(--glow);opacity:.85;}
.daily-note span{font-size:11px;letter-spacing:.14em;color:rgba(246,239,227,.5);}

/* 통계 패널 */
.stats{
  display:none;width:100%;max-width:420px;margin:8px auto 0;
  grid-template-columns:repeat(auto-fit,minmax(0,1fr));gap:8px;
}
.stats.show{display:grid;}
.stat{
  display:flex;flex-direction:column;align-items:center;gap:4px;
  padding:14px 6px;border-radius:12px;
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);
}
.stat-num{font-size:19px;font-weight:800;letter-spacing:.02em;
  color:var(--glow);font-variant-numeric:tabular-nums;line-height:1;}
.stat-label{font-size:10px;letter-spacing:.08em;color:rgba(246,239,227,.5);white-space:nowrap;}
#statGlobalCell .stat-num{color:#ffb347;}
.draw-mine{display:none;cursor:pointer;
  padding:12px 28px;border-radius:40px;
  background:linear-gradient(135deg,rgba(255,45,120,.25),rgba(180,60,255,.2));
  border:1.5px solid rgba(255,45,120,.55);color:#fff;font-size:14px;font-weight:600;letter-spacing:.06em;
  box-shadow:0 0 18px rgba(255,45,120,.25);transition:transform .12s,box-shadow .18s;}
.draw-mine:hover{transform:scale(1.05);box-shadow:0 0 28px rgba(255,45,120,.45);}

/* 공유 / 도감 공통 알약 버튼 */
.pill-btn{
  display:inline-flex;align-items:center;gap:9px;
  padding:13px 28px;cursor:pointer;
  border-radius:40px;
  font-size:14px;font-weight:600;letter-spacing:.08em;color:#fff;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08);
  transition:background .18s,box-shadow .18s,transform .12s,border-color .18s;
}
.pill-btn svg{width:16px;height:16px;}
.pill-btn:hover{transform:scale(1.06);}
.share-btn{
  background:linear-gradient(135deg,rgba(255,45,120,.25),rgba(180,60,255,.2));
  border:1.5px solid rgba(255,45,120,.55);
  box-shadow:0 0 18px rgba(255,45,120,.25),inset 0 1px 0 rgba(255,255,255,.08);
}
.share-btn:hover{
  background:linear-gradient(135deg,rgba(255,45,120,.42),rgba(180,60,255,.35));
  border-color:rgba(255,45,120,.85);
  box-shadow:0 0 30px rgba(255,45,120,.45),inset 0 1px 0 rgba(255,255,255,.12);
}
.codex-btn{
  background:linear-gradient(135deg,rgba(245,196,81,.22),rgba(120,80,200,.18));
  border:1.5px solid rgba(245,196,81,.5);
  box-shadow:0 0 18px rgba(245,196,81,.2),inset 0 1px 0 rgba(255,255,255,.08);
}
.codex-btn:hover{
  background:linear-gradient(135deg,rgba(245,196,81,.38),rgba(120,80,200,.3));
  border-color:rgba(245,196,81,.85);
  box-shadow:0 0 30px rgba(245,196,81,.4),inset 0 1px 0 rgba(255,255,255,.12);
}

/* 공유 모달 */
.share-modal{
  position:fixed;inset:0;z-index:200;
  background:rgba(0,0,0,.55);backdrop-filter:blur(4px);
  opacity:0;pointer-events:none;
  transition:opacity .22s;
}
.share-modal.open{opacity:1;pointer-events:auto;}
.share-sheet{
  position:absolute;left:0;right:0;bottom:0;
  width:auto;max-width:none;
  background:#150b26;
  border:1px solid rgba(255,45,120,.2);
  border-bottom:none;
  border-radius:22px 22px 0 0;
  padding:24px 24px 40px;
  transform:translateY(100%);
  transition:transform .28s cubic-bezier(.32,1,.5,1);
}
.share-modal.open .share-sheet{transform:translateY(0);}
.share-sheet-head{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:24px;
}
.share-sheet-head span{font-size:15px;font-weight:700;letter-spacing:.1em;color:rgba(246,239,227,.9);}
.share-close{
  background:none;border:none;cursor:pointer;
  color:rgba(246,239,227,.45);font-size:18px;
  line-height:1;padding:4px;
  transition:color .15s;
}
.share-close:hover{color:rgba(246,239,227,.9);}
.share-options{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;}
.share-opt{
  display:flex;flex-direction:column;align-items:center;gap:8px;
  padding:14px 6px;cursor:pointer;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.1);
  border-radius:14px;color:rgba(246,239,227,.85);
  font-size:11px;letter-spacing:.03em;
  transition:background .16s,border-color .16s,transform .12s;
}
.share-opt:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.25);transform:scale(1.06);}
.share-opt-icon{
  width:42px;height:42px;border-radius:12px;
  display:flex;align-items:center;justify-content:center;
}
.share-opt-icon svg{width:21px;height:21px;}
.so-kakao{background:#ffe812;color:#3a1d00;}
.so-kakao svg{fill:#3a1d00;}
.so-insta{background:linear-gradient(135deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888);color:#fff;}
.so-insta svg{stroke:#fff;}
.so-x{background:#000;color:#fff;}
.so-x svg{fill:#fff;}
.so-threads{background:#000;color:#fff;}
.so-threads svg{fill:#fff;}
.so-copy{background:rgba(255,255,255,.1);color:rgba(246,239,227,.8);}
.so-copy svg{stroke:rgba(246,239,227,.8);}
.so-image{background:linear-gradient(135deg,#f5c451,#ff9a3c);color:#3a1d00;}
.so-image svg{stroke:#3a1d00;}

/* ───────── 카드 도감 (그리드 팝업) ───────── */
.codex-modal{
  position:fixed;inset:0;z-index:210;
  display:flex;align-items:flex-end;justify-content:center;
  background:rgba(0,0,0,.6);backdrop-filter:blur(4px);
  opacity:0;pointer-events:none;transition:opacity .22s;
}
.codex-modal.open{opacity:1;pointer-events:auto;}
.codex-sheet{
  position:relative;width:100%;max-width:680px;height:88vh;
  background:#120a22;border:1px solid rgba(245,196,81,.2);border-bottom:none;
  border-radius:22px 22px 0 0;
  display:flex;flex-direction:column;
  transform:translateY(100%);transition:transform .3s cubic-bezier(.32,1,.5,1);
}
.codex-modal.open .codex-sheet{transform:translateY(0);}
.codex-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:20px 22px 14px;flex-shrink:0;
  border-bottom:1px solid rgba(255,255,255,.07);
}
.codex-head span{font-size:16px;font-weight:700;letter-spacing:.08em;color:rgba(246,239,227,.95);}
.codex-head em{font-style:normal;font-size:13px;color:var(--gold);margin-left:6px;letter-spacing:.04em;}
.codex-close{background:none;border:none;cursor:pointer;color:rgba(246,239,227,.45);font-size:18px;padding:4px;transition:color .15s;}
.codex-close:hover{color:rgba(246,239,227,.9);}
.codex-grid{
  flex:1;overflow-y:auto;
  display:grid;grid-template-columns:repeat(auto-fill,minmax(58px,1fr));gap:18px 10px;
  padding:18px 16px 44px;align-content:start;
}
.codex-cell{
  position:relative;aspect-ratio:2/3;cursor:default;
  border:none;background:none;padding:0;border-radius:8px;
}
/* 카드 이미지 자체를 둥글게 + 그림자 → 한 장 한 장 카드처럼 보이게 */
.codex-cell img{
  width:100%;height:100%;object-fit:contain;display:block;border-radius:8px;
  box-shadow:0 4px 12px rgba(0,0,0,.5);
}
.codex-cell.owned{cursor:pointer;transition:transform .15s;}
.codex-cell.owned:hover{transform:translateY(-5px) scale(1.08);z-index:2;}
.codex-cell.owned:hover img{box-shadow:0 10px 22px rgba(0,0,0,.6),0 0 16px rgba(245,196,81,.5);}
.codex-cell.owned.rare:hover img{box-shadow:0 10px 22px rgba(0,0,0,.6),0 0 20px rgba(255,215,106,.8);}
.codex-cell.rare img{outline:1.5px solid rgba(255,215,106,.55);outline-offset:-1.5px;}
.codex-no{position:absolute;left:50%;transform:translateX(-50%);bottom:-13px;
  font-size:10px;font-weight:700;color:rgba(246,239,227,.7);letter-spacing:.04em;}
.codex-lock{position:relative;width:100%;height:100%;border-radius:8px;overflow:hidden;}
.codex-lock img{filter:brightness(.3) grayscale(.7);border-radius:8px;}
.codex-lock span{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  font-size:24px;color:rgba(245,196,81,.45);font-weight:700;}

.codex-detail{
  position:absolute;inset:0;z-index:20;
  background:#120a22;border-radius:22px 22px 0 0;
  padding:22px;overflow-y:auto;text-align:center;
  opacity:0;pointer-events:none;transform:translateY(12px);
  transition:opacity .2s,transform .2s;
}
.codex-detail.show{opacity:1;pointer-events:auto;transform:translateY(0);}
.codex-back{background:none;border:none;cursor:pointer;color:var(--glow);font-size:14px;
  letter-spacing:.06em;display:block;margin:0 0 14px;padding:4px 0;}

/* 도감 상세 3D 카드 프리뷰 */
.codex-detail-card{width:210px;max-width:60%;margin:0 auto 18px;perspective:850px;}
.cx-preview{position:relative;aspect-ratio:2/3;border-radius:13px;cursor:grab;
  transform-style:preserve-3d;transition:transform .12s ease;
  box-shadow:0 16px 42px rgba(0,0,0,.6);}
.cx-preview:active{cursor:grabbing;}
.cx-img{width:100%;height:100%;object-fit:cover;border-radius:13px;display:block;}
.cx-fx{position:absolute;inset:0;border-radius:13px;pointer-events:none;opacity:0;}

.codex-detail-no{font-size:13px;letter-spacing:.16em;color:var(--glow);font-weight:800;margin-bottom:6px;
  text-shadow:0 0 16px color-mix(in srgb,var(--glow) 55%,transparent);}
.codex-detail h3{margin:0 0 4px;font-size:24px;font-weight:800;letter-spacing:.03em;
  color:#fff;text-shadow:0 0 22px color-mix(in srgb,var(--glow) 45%,transparent);}
.codex-detail-kor{margin:0 0 14px;font-size:14px;color:rgba(246,239,227,.6);letter-spacing:.1em;}
.codex-detail .chips{justify-content:center;margin:0 auto 16px;max-width:440px;}
.codex-detail-desc{margin:0 auto 16px;max-width:440px;line-height:1.75;font-size:15px;color:rgba(246,239,227,.9);}
.codex-detail-fortune{margin:0 auto;max-width:440px;line-height:1.75;font-size:15px;
  color:rgba(246,239,227,.92);padding:14px 18px;border-radius:12px;
  background:color-mix(in srgb,var(--glow) 8%,rgba(255,255,255,.03));
  border:1px solid color-mix(in srgb,var(--glow) 32%,transparent);}

/* 프리뷰 속성 효과 (메인 카드와 동일, 기존 keyframes 재사용) */
.cx-preview.v-foil .cx-fx{opacity:1;mix-blend-mode:color-dodge;
  background:linear-gradient(115deg,transparent 18%,rgba(255,0,170,.5),rgba(0,230,255,.5),rgba(255,235,0,.5),rgba(120,80,255,.5),transparent 82%);
  background-size:280% 280%;animation:foilSweep 3.6s linear infinite;}
.cx-preview.v-foil{box-shadow:0 16px 42px rgba(0,0,0,.6),0 0 26px rgba(120,200,255,.45);}
.cx-preview.v-holo .cx-fx{opacity:1;mix-blend-mode:screen;
  background:
    radial-gradient(circle at var(--gx,50%) var(--gy,50%),rgba(255,255,255,.28),transparent 48%),
    linear-gradient(108deg,transparent 4%,rgba(255,150,205,.16) 20%,rgba(150,205,255,.16) 38%,rgba(170,255,200,.16) 54%,rgba(255,235,160,.16) 70%,rgba(205,165,255,.16) 86%,transparent 96%);
  background-size:auto,220% 100%;background-position:center,var(--gx,50%) center;}
.cx-preview.v-holo{box-shadow:0 16px 42px rgba(0,0,0,.6),0 0 26px rgba(190,205,255,.45);}
.cx-preview.v-glitch .cx-fx{opacity:1;border-radius:13px;animation:glitchEdge 2.6s steps(1) infinite;}
.cx-preview.v-glitch .cx-img{animation:glitchShake 2.6s steps(1) infinite;}
.cx-preview.v-glitch{box-shadow:0 16px 42px rgba(0,0,0,.6),0 0 24px rgba(0,210,255,.45);}
.cx-preview.v-blood .cx-fx{opacity:1;mix-blend-mode:multiply;
  background:radial-gradient(circle at 50% 8%,rgba(60,0,0,0),rgba(70,0,8,.6) 92%),linear-gradient(0deg,rgba(120,0,0,.55),transparent 38%);}
.cx-preview.v-blood .cx-img{filter:saturate(1.15) contrast(1.06) brightness(.9) hue-rotate(-12deg);animation:bloodFlick 4s steps(1) infinite;}
.cx-preview.v-blood{box-shadow:0 16px 42px rgba(0,0,0,.6),0 0 30px rgba(180,0,30,.6);}
.cx-preview.v-gold .cx-fx{opacity:1;mix-blend-mode:overlay;
  background:linear-gradient(115deg,transparent 28%,rgba(255,225,140,.85) 50%,transparent 72%);
  background-size:250% 250%;animation:goldSweep 2.9s linear infinite;}
.cx-preview.v-gold{box-shadow:inset 0 0 0 3px rgba(255,215,106,.9),0 0 44px rgba(255,200,80,.6);}
.cx-preview.v-diamond .cx-fx{opacity:1;border-radius:13px;
  background:
    linear-gradient(115deg,transparent 36%,rgba(255,255,255,.4) 47%,rgba(255,255,255,.12) 50%,rgba(255,255,255,.36) 53%,transparent 63%),
    radial-gradient(85% 60% at var(--gx,28%) var(--gy,18%),rgba(235,250,255,.42),transparent 42%),
    linear-gradient(135deg,rgba(255,255,255,.2),transparent 20%,transparent 80%,rgba(6,22,48,.42));
  background-size:260% 100%,auto,auto;
  background-position:var(--gx,40%) center,center,center;
  box-shadow:inset 0 0 0 2px rgba(255,255,255,.4),inset 7px 7px 16px rgba(255,255,255,.28),inset -7px -7px 18px rgba(6,22,48,.5);}
.cx-preview.v-diamond{box-shadow:0 16px 42px rgba(0,0,0,.6),0 0 0 3px rgba(235,248,255,.45),0 0 34px rgba(175,222,255,.6);}

/* 도감 썸네일: 우측 세로 속성 태그 (각 색상 + 외곽선) */
.codex-vtags{position:absolute;top:4px;right:-3px;z-index:3;
  display:flex;flex-direction:column;gap:3px;align-items:flex-end;pointer-events:none;}
.codex-vtag{font-size:8px;font-weight:800;letter-spacing:.01em;line-height:1.1;
  padding:2px 4px;border-radius:5px;white-space:nowrap;
  border:1px solid rgba(0,0,0,.45);box-shadow:0 1px 3px rgba(0,0,0,.55);}
.vt-foil{background:linear-gradient(135deg,#ff2db4,#27e6ff,#ffe600);color:#1a0e2e;}
.vt-holo{background:linear-gradient(135deg,#dfe8ff,#ffe0f3,#e0ffe9);color:#1a2233;}
.vt-glitch{background:linear-gradient(135deg,#00d6ff,#ff0060);color:#fff;}
.vt-blood{background:linear-gradient(135deg,#7a0010,#c8001e);color:#fff;}
.vt-gold{background:linear-gradient(135deg,#fff0bf,#f5c451);color:#3a2600;}
.vt-diamond{background:linear-gradient(135deg,#eaf7ff,#bfe4ff,#e4fbff);color:#16314a;}

/* 도감 상세: 획득한 속성 칩 */
.codex-variants{margin:18px auto 0;max-width:440px;}
.codex-variants-t{margin:0 0 10px;font-size:12px;letter-spacing:.14em;color:var(--glow);font-weight:700;}
.vchips{display:flex;flex-wrap:wrap;gap:7px;justify-content:center;}
.vchip{font-size:11px;font-weight:700;letter-spacing:.04em;padding:6px 13px;border-radius:999px;
  color:rgba(246,239,227,.3);background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.1);text-transform:uppercase;transition:transform .12s;}
.vchip.got{color:#1a0e2e;border-color:transparent;cursor:pointer;}
.vchip.got:hover{transform:scale(1.08);}
.vchip.got.active{outline:2px solid #fff;outline-offset:2px;}
.vchip-normal.got{background:rgba(246,239,227,.85);}
.vchip-foil.got{background:linear-gradient(90deg,#ff2db4,#27e6ff,#ffe600);}
.vchip-holo.got{background:linear-gradient(90deg,#dfe8ff,#ffe0f3,#e0ffe9);}
.vchip-glitch.got{background:linear-gradient(90deg,#00d6ff,#ff0060);color:#fff;}
.vchip-blood.got{background:linear-gradient(90deg,#7a0010,#c8001e);color:#fff;}
.vchip-gold.got{background:linear-gradient(135deg,#fff0bf,#f5c451);}
.vchip-diamond.got{background:linear-gradient(135deg,#eaf7ff,#bfe4ff,#e4fbff);color:#16314a;}

/* 카드 전체화면 확대 */
.card-zoom{position:fixed;inset:0;z-index:240;display:none;
  align-items:center;justify-content:center;padding:18px;
  background:rgba(0,0,0,.9);backdrop-filter:blur(8px);cursor:zoom-out;
  opacity:0;transition:opacity .22s;}
.card-zoom.show{display:flex;opacity:1;}
.card-zoom-inner{height:72vh;max-width:90vw;}
.card-zoom .cx-preview{height:72vh;max-width:90vw;width:auto;aspect-ratio:2/3;
  cursor:zoom-out;box-shadow:0 24px 70px rgba(0,0,0,.7);}
.card-zoom .cx-img{height:100%;width:auto;max-width:94vw;}

/* 토스트 */
.toast{
  position:fixed;bottom:30px;left:50%;transform:translateX(-50%) translateY(20px);
  z-index:300;
  background:rgba(20,10,40,.92);border:1px solid rgba(245,196,81,.35);
  color:rgba(246,239,227,.95);
  padding:10px 20px;border-radius:30px;
  font-size:13px;letter-spacing:.06em;
  opacity:0;pointer-events:none;
  transition:opacity .2s,transform .2s;
  white-space:nowrap;
}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0);}

footer{position:relative;z-index:1;text-align:center;padding:0 0 30px;color:rgba(246,239,227,.28);
  font-size:11px;letter-spacing:.18em;}

/* ───────── Follow Dev 섹션 ───────── */
/* ───────── 홈화면 추가(PWA 설치) 안내 ───────── */
.install-card{
  display:none;position:relative;z-index:1;
  align-items:center;gap:12px;
  max-width:520px;margin:46px auto 0;padding:14px 16px;
  background:linear-gradient(135deg,rgba(245,196,81,.14),rgba(180,120,255,.1));
  border:1px solid rgba(245,196,81,.4);border-radius:16px;
  box-shadow:0 0 24px rgba(245,196,81,.12);
}
.install-card.show{display:flex;animation:installIn .5s ease;}
@keyframes installIn{from{opacity:0;transform:translateY(14px);}to{opacity:1;transform:translateY(0);}}
.install-ico{flex-shrink:0;width:40px;height:40px;border-radius:11px;
  display:flex;align-items:center;justify-content:center;
  background:rgba(245,196,81,.18);color:var(--gold);}
.install-ico svg{width:22px;height:22px;}
.install-txt{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0;}
.install-txt strong{font-size:14px;font-weight:700;color:rgba(246,239,227,.95);}
.install-txt small{font-size:11.5px;color:rgba(246,239,227,.55);letter-spacing:.02em;}
.install-btn{flex-shrink:0;cursor:pointer;border:none;
  padding:9px 18px;border-radius:30px;font-size:13px;font-weight:700;letter-spacing:.04em;
  color:#1a0e2e;background:linear-gradient(135deg,#fff0bf,var(--gold));
  box-shadow:0 0 16px rgba(245,196,81,.35);transition:transform .12s;}
.install-btn:hover{transform:scale(1.05);}
.install-close{flex-shrink:0;cursor:pointer;background:none;border:none;
  color:rgba(246,239,227,.4);font-size:15px;padding:2px 4px;transition:color .15s;}
.install-close:hover{color:rgba(246,239,227,.85);}

/* iOS 안내 토스트 */
.ios-guide{position:fixed;inset:0;z-index:320;display:none;
  align-items:flex-end;justify-content:center;
  background:rgba(0,0,0,.5);backdrop-filter:blur(3px);padding:0 14px 22px;}
.ios-guide.show{display:flex;}
.ios-guide-inner{position:relative;width:100%;max-width:420px;
  background:#1a1030;border:1px solid rgba(245,196,81,.3);border-radius:18px;
  padding:22px 22px 20px;text-align:center;}
.ios-guide-close{position:absolute;top:10px;right:12px;background:none;border:none;
  cursor:pointer;color:rgba(246,239,227,.45);font-size:16px;}
.ios-guide-inner p{margin:6px 0 14px;font-size:14px;line-height:1.7;color:rgba(246,239,227,.9);}
.ios-guide-inner b{color:var(--gold);}
.ios-share-ico{width:42px;height:42px;margin:0 auto;border-radius:12px;
  display:flex;align-items:center;justify-content:center;
  background:rgba(245,196,81,.15);color:var(--gold);}
.ios-share-ico svg{width:22px;height:22px;}

.follow-dev{
  position:relative;z-index:1;
  margin:46px auto 0;padding:0 18px 40px;
  max-width:560px;text-align:left;
  opacity:0;transform:translateY(24px);
  pointer-events:none;
  transition:opacity .6s ease,transform .6s ease;
}
.follow-dev.visible{opacity:1;transform:translateY(0);pointer-events:auto;}
.fd-inner{
  border-top:1px solid rgba(255,45,120,.25);
  padding-top:32px;
}
.fd-label{
  margin:0 0 6px;
  font-size:10px;letter-spacing:.28em;
  color:rgba(255,45,120,.6);font-weight:700;
}
.fd-title{
  margin:0 0 10px;
  font-family:'Press Start 2P',monospace;
  font-size:clamp(18px,4vw,26px);
  color:#ff2d78;
  text-shadow:0 0 22px rgba(255,45,120,.55),0 0 6px rgba(255,45,120,.4);
  letter-spacing:.04em;
  line-height:1.3;
}
.fd-sub{
  margin:0 0 28px;
  font-size:12px;letter-spacing:.02em;
  color:rgba(246,239,227,.55);
  line-height:1.6;
}
.fd-links{display:flex;flex-direction:column;gap:8px;}
.fd-link{
  display:flex;align-items:center;gap:12px;
  padding:10px 16px;
  background:rgba(255,45,120,.06);
  border:1px solid rgba(255,45,120,.18);
  border-radius:10px;
  text-decoration:none;color:inherit;
  transition:background .18s,border-color .18s,transform .15s;
}
.fd-link:hover{
  background:rgba(255,45,120,.14);
  border-color:rgba(255,45,120,.5);
  transform:translateX(4px);
}
.fd-icon{
  flex-shrink:0;width:32px;height:32px;
  display:flex;align-items:center;justify-content:center;
  border-radius:8px;
  color:#ff2d78;
}
.fd-icon svg{width:18px;height:18px;}
.fd-yt{background:rgba(255,45,80,.12);}
.fd-ig{background:rgba(255,45,120,.12);}
.fd-dc{background:rgba(255,45,120,.12);}
.fd-ml{background:rgba(255,45,120,.12);}
.fd-info{flex:1;display:flex;flex-direction:column;gap:2px;}
.fd-info strong{font-size:13px;font-weight:700;color:rgba(246,239,227,.95);}
.fd-info small{font-size:11px;color:#ff2d78;letter-spacing:.01em;}
.fd-arrow{color:rgba(255,45,120,.45);font-size:11px;flex-shrink:0;}

@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms !important;animation-iteration-count:1 !important;}
}

/* ───────── 모바일 반응형 ───────── */
@media (max-width:640px){
  /* 카드: stage overflow 방지 */
  :root{ --cardW:clamp(220px,62vw,260px); }

  /* 헤더가 카드 위에 오도록 */
  .topbar{position:relative;z-index:20;}

  .scene-wrap{padding:16px 14px 50px;}

  /* 섹션 간격 */
  .result{padding:0;margin-top:4px;}

  /* 공유·다시뽑기 */
  .result-actions{width:100%;gap:16px;margin-top:28px;}
  .share-btn{
    width:100%;max-width:none;
    justify-content:center;
    padding:15px 0;font-size:15px;border-radius:14px;
  }
  .again{font-size:15px;}

  /* Follow Dev */
  .follow-dev{padding:0 14px 32px;margin-top:44px;}
  .fd-inner{padding-top:26px;}
  .fd-sub{margin-bottom:20px;}

  /* 공유 모달: 3열 2줄 */
  .share-sheet{padding:22px 16px 40px;}
  .share-options{grid-template-columns:repeat(3,1fr);gap:10px;}
  .share-opt{padding:14px 6px;font-size:11px;}
  .share-opt-icon{width:40px;height:40px;}
  .share-opt-icon svg{width:20px;height:20px;}
}
