:root{
  --wd:#1e0c02;--wm:#4a2008;--wl:#7a3a10;--wp:#a85c28;
  --hj:#f5e8c8;--hjw:#d4b87a;
  --gold:#c8960c;--glt:#f0c040;--gdk:#8a6408;
}
*{margin:0;padding:0;box-sizing:border-box}
html,body{width:100%;height:100%;overflow:hidden}
body{font-family:'Nanum Myeongjo',serif;background:var(--wd);user-select:none}

/* ─────────────────────────────
   Screen
───────────────────────────── */
.screen{display:none;width:100vw;height:100vh;flex-direction:column;align-items:center;justify-content:center}
.screen.show{display:flex}
#sm{background:radial-gradient(ellipse at 50% 30%,#3a1a06,#1e0c02 70%)}
#sg{background:radial-gradient(ellipse at 50% 50%,#2a1a08,#1e0c02 80%);overflow:hidden}

/* ─────────────────────────────
   Menu
───────────────────────────── */
.mttl{
  color:var(--glt);font-size:2.4rem;letter-spacing:.25em;margin-bottom:.3rem;
  text-shadow:0 0 30px rgba(240,192,64,.4)
}
.msub{color:var(--hjw);font-size:.82rem;letter-spacing:.2em;margin-bottom:2.5rem;opacity:.7}
.mrow{display:flex;gap:1.5rem;flex-wrap:wrap;justify-content:center}
.mc{
  background:linear-gradient(160deg,rgba(90,45,15,.9),rgba(20,10,2,.95));
  border:2px solid var(--wp);border-radius:16px;padding:1.8rem 2.2rem;
  text-align:center;cursor:pointer;transition:all .25s;min-width:180px
}
.mc:hover{transform:translateY(-6px);border-color:var(--gold)}
.mc .ico{font-size:2.5rem;display:block;margin-bottom:.7rem}
.mc h3{color:var(--glt);font-size:1.1rem;margin-bottom:.3rem}
.mc p{color:var(--hjw);font-size:.76rem;line-height:1.7;opacity:.8}

/* ─────────────────────────────
   Modal
───────────────────────────── */
.mbg{display:none;position:fixed;inset:0;background:rgba(0,0,0,.85);z-index:500;align-items:center;justify-content:center}
.mbg.show{display:flex}
.mbox{
  background:linear-gradient(160deg,rgba(90,45,15,.97),rgba(20,10,2,.99));
  border:2px solid var(--gold);border-radius:16px;padding:1.8rem;
  max-width:380px;width:92%;text-align:center;animation:mIn .3s ease
}
@keyframes mIn{from{transform:scale(.85);opacity:0}to{transform:scale(1);opacity:1}}
.mbox h2{color:var(--glt);font-size:1.4rem;margin-bottom:.7rem}

.dbtn{
  display:flex;align-items:center;gap:.9rem;
  background:linear-gradient(135deg,rgba(90,45,15,.8),rgba(20,10,2,.9));
  border:1.5px solid var(--wp);border-radius:10px;padding:.7rem .9rem;
  cursor:pointer;width:100%;text-align:left;transition:all .2s;
  font-family:inherit;margin-bottom:.55rem
}
.dbtn:hover{border-color:var(--gold);transform:translateX(4px)}
.dico{font-size:1.8rem;flex-shrink:0}
.dnm{color:var(--glt);font-size:.95rem;font-weight:700;margin-bottom:.1rem}
.dds{color:var(--hjw);font-size:.7rem;opacity:.8}
.mbtns{display:flex;gap:.7rem;justify-content:center;margin-top:1.2rem;flex-wrap:wrap}
.ba{
  background:linear-gradient(135deg,var(--wl),var(--wm));
  border:1.5px solid var(--wp);color:var(--hj);padding:.4rem .9rem;
  border-radius:7px;cursor:pointer;font-family:inherit;font-size:.8rem;
  letter-spacing:.04em;transition:all .2s;white-space:nowrap
}
.ba:hover:not(:disabled){border-color:var(--gold);color:var(--glt)}

/* ─────────────────────────────
   Game Header
───────────────────────────── */
.ghdr{
  height:44px;flex-shrink:0;
  background:linear-gradient(90deg,var(--wd),var(--wm),var(--wd));
  border-bottom:2px solid var(--gold);
  display:flex;align-items:center;justify-content:space-between;
  padding:0 .8rem;position:relative;z-index:10;width:100%
}
.ghdr h2{
  color:var(--glt);font-size:.98rem;letter-spacing:.15em;
  position:absolute;left:50%;transform:translateX(-50%)
}
.hdl,.hdr_{display:flex;gap:.4rem;align-items:center}
.bh{
  background:transparent;border:1px solid var(--wp);color:var(--hjw);
  padding:.2rem .65rem;border-radius:5px;cursor:pointer;
  font-family:inherit;font-size:.72rem;transition:all .2s
}
.bh:hover{border-color:var(--gold);color:var(--glt)}

/* ─────────────────────────────
   Layout
───────────────────────────── */
.gbody{
  flex:1;display:flex;gap:.5rem;padding:.4rem .5rem;
  overflow:hidden;width:100%;min-height:0
}
.bwrap{
  flex-shrink:0;display:flex;align-items:center;justify-content:center;
  position:relative
}

/* ✅ 여기부터 핵심: 배경 이미지와 캔버스의 좌표계를 완전 동일하게 */
#yb-container{
  position:relative;
  width:min(52vw,52vh,480px);
  height:min(52vw,52vh,480px);
  z-index:1;
  cursor:pointer;
}

/* 배경 이미지: contain → 100% 100% (좌표 맞춤 핵심) */
.board-bg-img{
  position:absolute; inset:0;
  background-image:url('/allgame/files/Yunnori.PNG');
  background-size:100% 100% !important;
  background-repeat:no-repeat;
  background-position:center;
  opacity:1;
  pointer-events:none;
  z-index:1;
}

/* 캔버스도 배경과 똑같이 absolute로 덮어쓰기 */
#yb{
  position:absolute; inset:0;
  width:100%;
  height:100%;
  display:block;
  background:transparent;
  z-index:2;
}

/* ─────────────────────────────
   Side Panel
───────────────────────────── */
.side{
  flex:1;display:flex;flex-direction:column;gap:.3rem;
  min-width:150px;max-width:280px;overflow:hidden
}
.pgrid{display:grid;grid-template-columns:1fr 1fr;gap:.3rem;flex-shrink:0}
.pcard{
  background:rgba(0,0,0,.5);
  border:1.5px solid rgba(255,255,255,.1);
  border-radius:9px;padding:.4rem .5rem;transition:all .3s
}
.pcard.active{
  border-color:var(--gold);
  box-shadow:0 0 12px rgba(200,150,12,.4);
  background:rgba(200,150,12,.08)
}
.pch{display:flex;align-items:center;gap:.3rem;margin-bottom:.2rem}
.pcdot{width:9px;height:9px;border-radius:50%;flex-shrink:0}
.pcnm{color:var(--hj);font-size:.68rem;font-weight:700;flex:1}
.pcst{font-size:.56rem;padding:1px 4px;border-radius:8px;white-space:nowrap}
.st-turn{background:rgba(200,150,12,.25);color:var(--glt);border:1px solid var(--gdk)}
.st-wait{background:rgba(0,0,0,.3);color:rgba(255,255,255,.3)}
.hrow{display:flex;gap:2px;flex-wrap:wrap;align-items:center}
.hchip{
  width:16px;height:16px;border-radius:50%;
  border:1.5px solid rgba(255,255,255,.3);
  display:flex;align-items:center;justify-content:center;
  font-size:.5rem;color:white;font-weight:800
}
.hchip.done{opacity:.25;filter:grayscale(1);border-color:transparent}
.donecount{font-size:.55rem;color:var(--hjw);margin-left:2px}

/* ─────────────────────────────
   Throw Area
───────────────────────────── */
.tarea{
  flex-shrink:0;background:rgba(0,0,0,.4);
  border:1px solid rgba(255,255,255,.1);
  border-radius:10px;padding:.55rem .7rem
}
.yut-stage{display:flex;justify-content:center;align-items:flex-end;gap:6px;height:60px;margin-bottom:.3rem}
.yut-stick{width:14px;height:45px;border-radius:8px;position:relative;transform-origin:center bottom;}
.yut-stick.face-up{
  background:linear-gradient(180deg,#f8e8b0 0%,#e8c860 40%,#d4a820 100%);
  box-shadow:inset -2px -2px 4px rgba(0,0,0,.3), 0 3px 8px rgba(0,0,0,.5);
}
.yut-stick.face-down{
  background:linear-gradient(180deg,#5a3010 0%,#3a1a06 50%,#5a3010 100%);
  box-shadow:inset -2px -2px 4px rgba(0,0,0,.5), 0 3px 8px rgba(0,0,0,.5);
}
@keyframes yutRoll{
  0%{transform:translateY(0) rotateZ(0deg)}
  20%{transform:translateY(-40px) rotateZ(180deg)}
  50%{transform:translateY(-65px) rotateZ(540deg)}
  75%{transform:translateY(-15px) rotateZ(750deg)}
  90%{transform:translateY(-3px) rotateZ(820deg)}
  100%{transform:translateY(0) rotateZ(var(--final-rot,0deg))}
}
.yut-stick.rolling{animation:yutRoll 0.8s cubic-bezier(.34,.07,.22,.97) forwards}
.yut-stick.rolling:nth-child(2){animation-delay:.08s}
.yut-stick.rolling:nth-child(3){animation-delay:.16s}
.yut-stick.rolling:nth-child(4){animation-delay:.24s}

.yres{
  font-size:2.2rem;font-weight:800;color:var(--glt);letter-spacing:.15em;
  min-height:36px;text-align:center;
  text-shadow:0 0 20px rgba(240,192,64,.8);
  background:rgba(200,150,12,.2);
  border:2px solid var(--gold);
  border-radius:10px;padding:.5rem;margin:.4rem 0
}
.yres-sub{font-size:.75rem;color:var(--hjw);margin-top:.2rem}
.yres-steps{font-size:1.2rem;color:var(--glt);font-weight:700}

.yq{display:flex;gap:.3rem;align-items:center;justify-content:center;flex-wrap:wrap;min-height:18px;margin-bottom:.3rem}
.qchip{
  background:rgba(200,150,12,.25);border:1px solid var(--gdk);
  color:var(--glt);font-size:.7rem;padding:1px 7px;border-radius:9px;font-weight:700
}

.btnthrow{
  width:100%;
  background:linear-gradient(135deg,#7a5c00,#4a3800);
  border:2px solid var(--gold);
  color:var(--glt);
  padding:.55rem;border-radius:8px;
  cursor:pointer;font-family:inherit;font-size:.88rem;font-weight:700;
  letter-spacing:.1em;transition:all .2s
}
.btnthrow:hover:not(:disabled){
  background:linear-gradient(135deg,#9a7c10,#6a5010);
  box-shadow:0 0 16px rgba(200,150,12,.55);
  transform:scale(1.02)
}
.btnthrow:disabled{opacity:.35;cursor:not-allowed}

/* ─────────────────────────────
   Home
───────────────────────────── */
.home-area{
  background:rgba(0,0,0,.5);
  border:2px dashed rgba(200,150,12,.5);
  border-radius:10px;padding:.6rem;margin-bottom:.3rem;text-align:center
}
.home-label{color:var(--gold);font-size:.7rem;font-weight:700;margin-bottom:.3rem}
.home-horses{display:flex;gap:.4rem;flex-wrap:wrap;justify-content:center}
.home-horse{
  width:36px;height:36px;border-radius:50%;
  border:2.5px solid;
  display:flex;align-items:center;justify-content:center;
  font-size:.8rem;font-weight:700;color:white;
  cursor:pointer;transition:all .2s;
  box-shadow:0 2px 8px rgba(0,0,0,.5)
}
.home-horse:hover{transform:scale(1.2);box-shadow:0 0 20px rgba(255,255,255,.5)}

/* ─────────────────────────────
   Yut Select
───────────────────────────── */
.yut-select-area{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:center;margin:.8rem 0}
.yut-select-btn{
  background:linear-gradient(135deg,rgba(90,45,15,.8),rgba(20,10,2,.9));
  border:2px solid var(--gold);
  border-radius:10px;
  padding:1rem 1.5rem;
  cursor:pointer;
  color:var(--glt);
  font-size:1.2rem;
  font-weight:700;
  transition:all .2s;
  text-align:center
}
.yut-select-btn:hover{transform:scale(1.05);box-shadow:0 0 20px rgba(200,150,12,.6)}
.yut-select-btn-name{font-size:1.5rem;display:block;margin-bottom:.3rem}
.yut-select-btn-step{font-size:.8rem;color:var(--hjw)}

/* ─────────────────────────────
   Shortcut Modal
───────────────────────────── */
.sc-opts{display:flex;gap:.7rem;justify-content:center;margin-top:.8rem}
.scbtn{
  flex:1;padding:.65rem;border-radius:9px;cursor:pointer;
  font-family:inherit;font-size:.82rem;
  border:2px solid var(--wp);
  background:rgba(0,0,0,.4);
  color:var(--hj);transition:all .2s
}
.scbtn:hover{border-color:var(--gold);color:var(--glt);transform:scale(1.05)}

/* ─────────────────────────────
   Result
───────────────────────────── */
.rrk{display:flex;flex-direction:column;gap:.35rem;margin:.6rem 0}
.rkrow{display:flex;align-items:center;gap:.5rem;background:rgba(0,0,0,.3);border-radius:7px;padding:.35rem .6rem}
.rknum{font-size:1.1rem;width:22px;text-align:center}
.rknm{flex:1;font-size:.85rem}
.rkdn{font-size:.7rem;color:var(--hjw)}

/* ─────────────────────────────
   Log
───────────────────────────── */
.loga{
  flex:1;background:rgba(0,0,0,.3);
  border:1px solid rgba(255,255,255,.06);
  border-radius:7px;padding:.3rem .45rem;
  overflow-y:auto;min-height:0;
  scrollbar-width:thin;scrollbar-color:var(--gold) transparent
}
.ll{font-size:.66rem;color:var(--hjw);padding:.1rem 0;border-bottom:1px solid rgba(255,255,255,.04);line-height:1.4}
.ll.em{color:var(--glt);font-weight:700}

/* ─────────────────────────────
   Toast / Pop
───────────────────────────── */
.toast{
  position:fixed;top:52px;left:50%;
  transform:translateX(-50%) translateY(-8px);
  background:rgba(10,5,0,.96);
  border:1.5px solid var(--gold);
  color:var(--glt);
  padding:.4rem 1.3rem;border-radius:30px;
  font-size:.78rem;letter-spacing:.06em;
  z-index:700;opacity:0;transition:all .25s;
  pointer-events:none;white-space:nowrap;max-width:90vw
}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

@keyframes spopA{0%{transform:translateY(0) scale(1.2);opacity:1}100%{transform:translateY(-60px) scale(.7);opacity:0}}
.spop{
  position:fixed;pointer-events:none;z-index:800;
  color:var(--glt);font-size:1.8rem;font-weight:800;
  text-shadow:0 0 12px rgba(240,192,64,.9),2px 2px 0 #000;
  animation:spopA 1s ease forwards;white-space:nowrap
}

/* ─────────────────────────────
   Misc
───────────────────────────── */
.ai-think{
  display:none;align-items:center;gap:.4rem;
  background:rgba(0,0,0,.6);
  border:1.5px solid var(--wp);
  border-radius:20px;padding:.18rem .8rem;
  color:var(--hjw);font-size:.72rem;flex-shrink:0
}
.ai-think.show{display:flex}

.turn-badge{
  background:rgba(0,0,0,.6);
  border:1.5px solid var(--gold);
  border-radius:20px;padding:.2rem .9rem;
  color:var(--glt);font-size:.8rem;letter-spacing:.06em;
  flex-shrink:0;text-align:center;margin-bottom:.2rem
}

/* ─────────────────────────────
   Mobile
───────────────────────────── */
@media(max-width:640px){
  .gbody{flex-direction:column;padding:.25rem}
  #yb-container{width:min(96vw,44vh)!important;height:min(96vw,44vh)!important}
  .pgrid{grid-template-columns:repeat(4,1fr)}
  .loga{display:none}
}