/* ====================================================================
   GUNGMA — UI 디자인 시스템
   토큰(색·간격·라운드·그림자)을 한 곳에서 정의하고 전 컴포넌트가 공유한다.
   방향: 따뜻한 우드 보드에 어울리는 "차분한 다크 + 골드 악센트" 한 가지 톤.
   ==================================================================== */
:root{
  --oct:polygon(31% 0,69% 0,100% 31%,100% 69%,69% 100%,31% 100%,0 69%,0 31%);

  /* 표면 — 따뜻한 톤의 짙은 중성색 */
  --bg:#14140f;
  --surface:#20211b;
  --surface-hi:#2b2c23;
  --surface-inset:#16160f;

  /* 경계선 */
  --border:rgba(238,230,210,.09);
  --border-hi:rgba(238,230,210,.17);

  /* 글자 */
  --text:#ece5d6;
  --text-dim:#a7a092;
  --text-mute:#6f6a5d;

  /* 강조 — 골드 */
  --gold:#cf9f55;
  --gold-bright:#e9c378;

  /* 진영색 */
  --cho:#43bd83;
  --cho-deep:#1b6e43;
  --han:#e15a52;
  --han-deep:#8d2a25;

  /* 라운드 */
  --r-sm:9px;
  --r-md:13px;
  --r-lg:18px;
  --r-xl:24px;

  /* 그림자 (elevation) */
  --sh-1:0 1px 3px rgba(0,0,0,.4);
  --sh-2:0 10px 30px rgba(0,0,0,.45);
  --sh-3:0 26px 62px rgba(0,0,0,.62);
}

*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent;}
html,body{height:100%;overflow:hidden;overscroll-behavior:none;}
body{
  font-family:"Noto Serif KR",serif;color:var(--text);
  height:100dvh;-webkit-user-select:none;user-select:none;
  background:
    radial-gradient(1000px 620px at 50% -16%,#202219,transparent 72%),
    var(--bg);
}
button,select,input{font-family:inherit;color:inherit;touch-action:manipulation;}

/* ===================== layout ===================== */
.app{
  height:100dvh;max-width:1240px;margin:0 auto;padding:22px;
  display:grid;gap:12px 18px;
  grid-template-columns:minmax(0,1fr) 326px;
  grid-template-rows:1fr auto auto auto auto auto auto 1fr;
  grid-template-areas:
    "stage ."
    "stage topbar"
    "stage playbar"
    "stage testbar"
    "stage players"
    "stage controls"
    "stage actions"
    "stage .";
}
.topbar{grid-area:topbar;}
.playseg{grid-area:playbar;}
.testbar{grid-area:testbar;}
.players{grid-area:players;}
.controls{grid-area:controls;}
.actions{grid-area:actions;}
.stage{grid-area:stage;}

/* ===================== topbar ===================== */
.topbar{display:flex;align-items:center;gap:12px;}
.brand{display:flex;flex-direction:column;gap:3px;line-height:1;flex:0 0 auto;margin:0;}
.brand b{
  font-family:"Black Han Sans",sans-serif;font-size:23px;font-weight:400;
  letter-spacing:2.5px;white-space:nowrap;
  background:linear-gradient(180deg,#f1dca2,#c89944);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.brand span{
  font-size:9.5px;font-weight:700;letter-spacing:2px;
  color:var(--text-mute);white-space:nowrap;
}
.turn{
  margin-left:auto;display:flex;align-items:center;gap:8px;
  padding:9px 15px;border-radius:999px;white-space:nowrap;
  font-size:12.5px;font-weight:800;letter-spacing:.3px;
  background:var(--surface);border:1px solid var(--border);
}
.turn::before{
  content:"";width:8px;height:8px;border-radius:50%;
  background:var(--text-mute);transition:.2s;
}
.turn.cho{color:#74d6a4;border-color:rgba(67,189,131,.4);}
.turn.cho::before{background:var(--cho);box-shadow:0 0 8px rgba(67,189,131,.7);}
.turn.han{color:#f0938c;border-color:rgba(225,90,82,.4);}
.turn.han::before{background:var(--han);box-shadow:0 0 8px rgba(225,90,82,.7);}
.turn.over{color:var(--gold-bright);border-color:rgba(207,159,85,.4);}
.turn.over::before{background:var(--gold);box-shadow:0 0 8px rgba(207,159,85,.7);}

.gear{
  display:none;width:42px;height:42px;flex:0 0 auto;border-radius:var(--r-md);
  cursor:pointer;align-items:center;justify-content:center;font-size:18px;
  background:var(--surface);border:1px solid var(--border);color:var(--text-dim);
  transition:.15s;
}
.gear:hover{border-color:var(--border-hi);color:var(--text);}
.gear:active{transform:scale(.94);}

/* ===================== segmented control ===================== */
.seg{
  display:flex;gap:4px;padding:4px;border-radius:var(--r-md);
  background:var(--surface-inset);border:1px solid var(--border);
}
.seg button{
  flex:1;padding:9px 6px;border-radius:9px;cursor:pointer;border:none;
  background:transparent;color:var(--text-dim);
  font-size:12.5px;font-weight:800;letter-spacing:.2px;
  transition:background .16s,color .16s;
}
.seg button:hover{color:var(--text);}
.seg button.on{
  background:var(--surface-hi);color:var(--gold-bright);
  box-shadow:var(--sh-1),inset 0 1px 0 rgba(255,255,255,.05);
}

/* ===================== player cards ===================== */
.players{display:flex;flex-direction:column;gap:9px;justify-content:center;}
/* 한(漢) 플레이어 — 뒤집힌 판에 맞춰 내 카드를 아래쪽으로 */
.players.flip{flex-direction:column-reverse;}
.pcard{
  position:relative;display:flex;align-items:center;gap:12px;padding:12px;
  border-radius:var(--r-lg);
  background:var(--surface);border:1px solid var(--border);
  box-shadow:var(--sh-1);
  transition:border-color .25s,box-shadow .25s;
}
.emblem{
  width:46px;height:46px;flex:0 0 auto;border-radius:var(--r-md);
  display:flex;align-items:center;justify-content:center;
  font-size:24px;font-weight:900;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.18),var(--sh-1);
}
.pcard.han .emblem{background:linear-gradient(155deg,#e4655d,#9a2f29);color:#fff0ee;}
.pcard.cho .emblem{background:linear-gradient(155deg,#48c489,#196e43);color:#eefff6;}
.pmid{flex:1;min-width:0;}
.pname{font-size:14px;font-weight:900;display:flex;align-items:center;gap:6px;}
.cname{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.pname i{
  flex:0 0 auto;font-style:normal;font-size:9px;font-weight:800;letter-spacing:.4px;
  padding:3px 7px;border-radius:999px;
  background:var(--surface-inset);color:var(--text-dim);
}
.caps{
  display:flex;flex-wrap:nowrap;gap:3px;margin-top:6px;min-width:0;
  height:24px;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;
}
.caps::-webkit-scrollbar{display:none;}
.cap{
  width:22px;height:22px;clip-path:var(--oct);flex:0 0 auto;
  display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:900;
}
.cap.cho{background:linear-gradient(155deg,#3bb47a,#15703f);color:#ecfff5;}
.cap.han{background:linear-gradient(155deg,#df5a55,#8a1f1c);color:#fff1ef;}
.pscore{
  flex:0 0 auto;text-align:center;min-width:50px;
  background:var(--surface-inset);border:1px solid var(--border);
  border-radius:var(--r-sm);padding:7px 6px;
}
.pscore b{display:block;font-size:17px;font-weight:900;color:var(--gold-bright);line-height:1;}
.pscore span{font-size:8px;color:var(--text-mute);letter-spacing:1.5px;}
/* 대국 시계 — 시계 사용 시 점수 자리에 표시 */
.pclock{
  display:none;flex:0 0 auto;min-width:66px;text-align:center;
  padding:5px 8px;border-radius:var(--r-sm);
  background:var(--surface-inset);border:1px solid var(--border);
}
.pclock b{
  display:block;font-variant-numeric:tabular-nums;letter-spacing:.5px;
  font-size:18px;font-weight:900;color:var(--text-dim);line-height:1.2;
}
.pclock i{
  display:block;font-style:normal;font-size:8.5px;font-weight:700;
  letter-spacing:.5px;color:var(--text-mute);
}
.pclock.run{border-color:var(--border-hi);}
.pclock.run b{color:var(--text);}
.pclock.low{border-color:rgba(225,90,82,.55);}
.pclock.low b{color:#f0938c;}
.players.clocked .pscore{display:none;}
.players.clocked .pclock{display:block;}
.pcard.active.cho{
  border-color:rgba(67,189,131,.7);
  box-shadow:0 0 0 1px rgba(67,189,131,.5),0 8px 26px rgba(67,189,131,.2);
}
.pcard.active.han{
  border-color:rgba(225,90,82,.7);
  box-shadow:0 0 0 1px rgba(225,90,82,.5),0 8px 26px rgba(225,90,82,.2);
}
.vs{
  align-self:center;font-family:"Black Han Sans",sans-serif;font-size:11px;
  color:var(--text-mute);letter-spacing:2px;position:relative;padding:0 14px;
}
.vs::before,.vs::after{
  content:"";position:absolute;top:50%;width:30px;height:1px;background:var(--border-hi);
}
.vs::before{right:100%;}
.vs::after{left:100%;}

/* ===================== board ===================== */
.stage{
  position:relative;display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:8px;
  min-height:0;min-width:0;overflow:hidden;
}
.banner{
  position:absolute;top:10px;left:50%;z-index:25;pointer-events:none;white-space:nowrap;
  transform:translate(-50%,-12px) scale(.92);opacity:0;
  padding:9px 24px;border-radius:999px;
  font-weight:900;letter-spacing:3px;font-size:15px;box-shadow:var(--sh-2);
  transition:transform .3s cubic-bezier(.2,1.4,.4,1),opacity .3s;
}
.banner.show{opacity:1;transform:translate(-50%,0) scale(1);}
.banner.check{background:linear-gradient(100deg,#8f2723,#e2564e,#8f2723);color:#fff0ee;}
.banner.win{background:linear-gradient(100deg,#9c7526,#eccb7e,#9c7526);color:#241a04;}

/* LLM 한 수 해설 — 장기판 바로 아래 */
.llmnote{
  display:none;flex:0 0 auto;order:2;
  width:94%;max-width:560px;min-height:74px;max-height:130px;
  padding:11px 14px;border-radius:var(--r-md);
  background:var(--surface);border:1px solid var(--border);
  color:var(--text);font-size:12px;font-weight:600;line-height:1.55;text-align:left;
  box-shadow:var(--sh-1);
  overflow-y:auto;-webkit-overflow-scrolling:touch;
}
.llmnote::-webkit-scrollbar{display:none;}

.scaler{transform-origin:top left;}
.boardwrap{
  position:relative;width:546px;padding:9px;border-radius:13px;
  background:#241608 url("/img/wood-frame.jpg") center/cover;
  box-shadow:
    0 28px 56px -18px rgba(0,0,0,.7),
    0 0 0 1px rgba(0,0,0,.55),
    inset 0 1px 1px rgba(255,226,172,.16);
}
/* 가는 금장 테두리 한 줄 */
.boardwrap::before{
  content:"";position:absolute;inset:4.5px;border-radius:8px;pointer-events:none;
  border:1px solid rgba(216,178,110,.5);
}
.board{
  position:relative;width:528px;height:584px;border-radius:4px;overflow:hidden;
  background:
    radial-gradient(150% 100% at 28% 6%,rgba(255,244,214,.12),transparent 64%),
    #d8a960 url("/img/wood-board.jpg") center/cover;
  box-shadow:inset 0 0 48px rgba(86,48,8,.28);
}
/* 한(漢) 시점 — 나무 배경은 두고 그 위 레이어만 180° 회전, 기물 글자만 다시 세움 */
.board.flip>.grid,
.board.flip>.layer{transform:rotate(180deg);}
.board.flip .piece .face{transform:rotate(180deg);}
.layer{position:absolute;inset:0;pointer-events:none;}
svg.grid{position:absolute;inset:0;}
.ln{stroke:rgba(45,26,7,.72);stroke-width:1.7;stroke-linecap:round;}
.br{stroke:rgba(45,26,7,.64);stroke-width:1.7;stroke-linecap:round;}

/* 팔각 장기알 — 진한 나무 테두리 + 밝은 상아빛 알면 */
.piece{
  position:absolute;clip-path:var(--oct);cursor:pointer;
  background:linear-gradient(158deg,#9c6e34 4%,#7a5224 54%,#573917);
  filter:drop-shadow(0 1px 1px rgba(0,0,0,.55)) drop-shadow(0 5px 7px rgba(0,0,0,.4));
  animation:placeIn .4s cubic-bezier(.2,1.3,.4,1) both;
  transition:left .27s cubic-bezier(.25,.85,.3,1),top .27s cubic-bezier(.25,.85,.3,1),
    transform .14s ease,opacity .3s ease,filter .15s;
}
@keyframes placeIn{from{opacity:0;transform:scale(.2);}to{opacity:1;transform:scale(1);}}
.piece .face{
  position:absolute;inset:2.5px 3px 4.5px 3px;clip-path:var(--oct);
  background:radial-gradient(82% 72% at 40% 28%,#fdf4da,#f2dfb2 58%,#e6cd94);
  display:flex;align-items:center;justify-content:center;
  font-weight:900;line-height:1;font-size:24px;
  box-shadow:inset 0 2px 3px rgba(255,253,243,.8),inset 0 -3px 6px rgba(108,70,22,.34);
}
.piece .face::before{
  content:"";position:absolute;inset:11%;clip-path:var(--oct);
  box-shadow:inset 0 0 0 1.5px rgba(82,50,12,.5);
}
.piece.cho .face{color:#155f2c;
  text-shadow:0 1px 0 rgba(255,251,232,.6),0 -1px 1px rgba(46,26,4,.42);}
.piece.han .face{color:#a81f19;
  text-shadow:0 1px 0 rgba(255,251,232,.6),0 -1px 1px rgba(46,26,4,.42);}
.piece.selected{z-index:7;
  filter:drop-shadow(0 0 11px rgba(255,209,92,.95)) drop-shadow(0 4px 5px rgba(0,0,0,.5));
  animation:selPulse 1s ease-in-out infinite;}
@keyframes selPulse{0%,100%{transform:scale(1.1);}50%{transform:scale(1.17);}}
.piece.captured{opacity:0;transform:scale(.15) rotate(40deg);}

.poof{position:absolute;width:50px;height:50px;border-radius:50%;
  pointer-events:none;animation:poof .5s ease-out forwards;}
.poof.cho{background:radial-gradient(circle,rgba(74,210,141,.85),transparent 70%);}
.poof.han{background:radial-gradient(circle,rgba(239,122,114,.85),transparent 70%);}
@keyframes poof{from{opacity:.9;transform:scale(.5);}to{opacity:0;transform:scale(2.1);}}

.marker{position:absolute;transform:translate(-50%,-50%);}
.marker.move{width:22px;height:22px;border-radius:50%;
  background:radial-gradient(circle,rgba(40,24,6,.6),rgba(40,24,6,.12));
  animation:mk .3s ease-out;}
.marker.capture{width:52px;height:52px;border-radius:50%;
  border:4px solid rgba(202,46,42,.85);animation:capRing 1.1s ease-in-out infinite;}
@keyframes mk{from{transform:translate(-50%,-50%) scale(0);}to{transform:translate(-50%,-50%) scale(1);}}
@keyframes capRing{0%,100%{box-shadow:0 0 0 0 rgba(202,46,42,0);}
  50%{box-shadow:0 0 10px 2px rgba(202,46,42,.45);}}
.lastdot{position:absolute;width:48px;height:48px;border-radius:50%;
  transform:translate(-50%,-50%);background:rgba(255,206,74,.3);
  box-shadow:0 0 0 2px rgba(255,206,74,.32);}
.hot{position:absolute;width:58px;height:58px;cursor:pointer;pointer-events:auto;
  touch-action:manipulation;transform:translate(-50%,-50%);border-radius:50%;}

/* ===================== settings ===================== */
.controls{overflow:auto;}
.controls::-webkit-scrollbar{width:0;}
.sheet{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r-lg);padding:16px;box-shadow:var(--sh-1);
  display:flex;flex-direction:column;gap:14px;
}
.sheethead{display:flex;align-items:center;justify-content:space-between;}
.sheethead h2{font-size:14px;letter-spacing:.5px;color:var(--text);font-weight:900;}
.x{
  display:none;width:34px;height:34px;border-radius:var(--r-sm);cursor:pointer;
  background:var(--surface-inset);border:1px solid var(--border);
  color:var(--text-dim);font-size:13px;
}
.field>label{
  display:block;font-size:10.5px;color:var(--text-mute);margin-bottom:8px;
  letter-spacing:.8px;font-weight:700;
}
select{
  width:100%;padding:11px 30px 11px 12px;border-radius:var(--r-sm);
  font-size:12.5px;font-weight:700;color:var(--text);cursor:pointer;
  background-color:var(--surface-inset);border:1px solid var(--border);
  appearance:none;-webkit-appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='11' height='7'%3E%3Cpath d='M1.2 1.4l4.3 4.2 4.3-4.2' fill='none' stroke='%23a7a092' stroke-width='1.7' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 11px center;
}
select:focus{outline:none;border-color:var(--border-hi);}
.duo{display:flex;gap:8px;}
.hint{font-size:10.5px;color:var(--text-mute);margin-top:7px;line-height:1.55;}
#llmStat{font-weight:800;}
#llmStat.ok{color:var(--cho);}
#llmStat.bad{color:var(--han);}
.sheetnew{display:none;}

/* ===================== online panel ===================== */
.onlinepanel{
  position:absolute;inset:0;z-index:30;display:none;
  place-items:center;padding:18px;
  background:rgba(12,13,9,.7);backdrop-filter:blur(3px);
}
.onlinepanel.show{display:grid;}

/* 시작 대기 — 보드 위 "대국 시작" 오버레이 */
.startoverlay{
  position:absolute;inset:0;z-index:25;display:none;
  flex-direction:column;align-items:center;justify-content:center;gap:13px;
  padding:18px;text-align:center;
  background:rgba(12,13,9,.58);backdrop-filter:blur(2px);
}
.startoverlay.show{display:flex;}
.startoverlay .startbtn{
  flex:0 0 auto;min-width:190px;min-height:56px;padding:0 26px;
  font-size:17px;box-shadow:var(--sh-2);
}
.starthint{font-size:11px;color:var(--text-dim);letter-spacing:.2px;}
.opcard{
  width:100%;max-width:310px;text-align:center;
  background:var(--surface);border:1px solid var(--border-hi);
  border-radius:var(--r-lg);padding:26px 22px;box-shadow:var(--sh-3);
}
.optitle{font-family:"Black Han Sans",sans-serif;font-size:19px;color:var(--text);letter-spacing:.5px;}
.opsub{font-size:11px;color:var(--text-dim);margin:7px 0 16px;line-height:1.6;}
.onlinein{
  width:100%;margin-top:8px;padding:12px;border-radius:var(--r-sm);
  font-size:14px;font-weight:700;color:var(--text);text-align:center;
  background:var(--surface-inset);border:1px solid var(--border);
}
.onlinein:focus{outline:none;border-color:var(--gold);}
.onlinein::placeholder{color:var(--text-mute);font-weight:600;}
.obtn{width:100%;min-height:48px;font-size:14px;margin-top:10px;}
.omsg{
  margin-top:12px;padding:9px 11px;border-radius:var(--r-sm);
  font-size:11px;line-height:1.55;font-weight:600;color:var(--text-dim);
  background:var(--surface-inset);border:1px solid var(--border);
}
.omsg:empty{display:none;}
.omsg.bad{color:#f0938c;}

/* 계정 — 구글 버튼 / 이메일 로그인 폼 */
.obtn.google{
  background:#fff;color:#1f1f1f;border:1px solid #dadce0;
  display:flex;align-items:center;justify-content:center;gap:9px;font-weight:800;
}
.obtn.google:hover{background:#f1f3f4;}
.gicon{
  display:inline-flex;align-items:center;justify-content:center;
  width:20px;height:20px;border-radius:50%;font-size:12px;font-weight:900;
  font-family:Arial,Helvetica,sans-serif;color:#fff;
  background:conic-gradient(from -45deg,#ea4335,#fbbc05 90deg,#34a853 180deg,#4285f4 270deg,#ea4335);
}
.opdiv{
  display:flex;align-items:center;gap:10px;margin:17px 2px 2px;
  color:var(--text-mute);font-size:10px;font-weight:700;letter-spacing:1px;
}
.opdiv::before,.opdiv::after{content:"";flex:1;height:1px;background:var(--border);}
.authswitch{margin-top:11px;font-size:11px;color:var(--text-dim);}
.authswitch a,.opsub a{
  color:var(--gold-bright);font-weight:800;cursor:pointer;text-decoration:none;
}
.authswitch a:hover,.opsub a:hover{text-decoration:underline;}

/* 가입 동의 / 약관 링크 / 전적 */
.consent{
  display:flex;align-items:flex-start;gap:7px;margin-top:11px;
  font-size:11px;color:var(--text-dim);line-height:1.5;text-align:left;cursor:pointer;
}
.consent input{flex:0 0 auto;width:15px;height:15px;margin-top:1px;accent-color:var(--gold);}
.consent a{color:var(--gold-bright);font-weight:700;}
.legalrow{margin-top:14px;font-size:11px;color:var(--text-mute);text-align:center;}
.legalrow a{color:var(--text-dim);text-decoration:none;}
.legalrow a:hover{text-decoration:underline;}
.mestats{margin:5px 0 14px;font-size:11.5px;color:var(--gold-bright);font-weight:700;}
.meactions{margin-top:13px;font-size:11px;color:var(--text-mute);}
.meactions a{color:var(--text-dim);font-weight:700;cursor:pointer;text-decoration:none;}
.meactions a:hover{text-decoration:underline;}

/* ===================== buttons ===================== */
.actions{display:flex;gap:9px;}
.btn{
  flex:1;min-height:52px;border-radius:var(--r-md);cursor:pointer;
  font-weight:800;font-size:14px;letter-spacing:.3px;
  background:var(--surface-hi);border:1px solid var(--border-hi);color:var(--text);
  transition:background .15s,border-color .15s,transform .08s,filter .12s;
}
.btn:hover{background:#33342a;}
.btn:active{transform:translateY(1px);}
.btn:disabled{opacity:.34;cursor:default;}
.btn:disabled:hover{background:var(--surface-hi);}
.btn:disabled:active{transform:none;}
.btn.primary{
  background:linear-gradient(180deg,var(--gold-bright),var(--gold));
  color:#2a1d04;border:1px solid rgba(0,0,0,.16);
  box-shadow:0 6px 18px rgba(207,159,85,.26),inset 0 1px 0 rgba(255,255,255,.42);
}
.btn.primary:hover{filter:brightness(1.06);background:linear-gradient(180deg,var(--gold-bright),var(--gold));}
.btn.primary:active{transform:translateY(1px);}
/* 기권 확인 대기 상태 — 위험 강조 */
.btn.armed{
  background:linear-gradient(180deg,#e0564f,#9a2f29);
  color:#fff;border-color:rgba(0,0,0,.2);
}
.btn.armed:hover{filter:brightness(1.06);background:linear-gradient(180deg,#e0564f,#9a2f29);}

/* ===================== result modal ===================== */
.modal{
  position:fixed;inset:0;z-index:90;display:none;place-items:center;padding:24px;
  background:rgba(8,9,7,.78);backdrop-filter:blur(6px);
}
.modal.show{display:grid;animation:fadeIn .22s ease;}
@keyframes fadeIn{from{opacity:0;}to{opacity:1;}}
.resultcard{
  width:100%;max-width:330px;text-align:center;padding:32px 24px 24px;
  border-radius:var(--r-xl);
  background:var(--surface);border:1px solid var(--border-hi);
  box-shadow:var(--sh-3);
  animation:popIn .42s cubic-bezier(.2,1.5,.4,1) both;
}
@keyframes popIn{from{opacity:0;transform:scale(.8) translateY(16px);}
  to{opacity:1;transform:scale(1) translateY(0);}}
.rmedal{position:relative;width:96px;height:96px;margin:0 auto 16px;}
.rmedal::before{
  content:"";position:absolute;inset:-10px;border-radius:50%;
  background:conic-gradient(from 0deg,transparent,var(--gold),transparent 55%);
  animation:spin 4s linear infinite;opacity:.7;
}
@keyframes spin{to{transform:rotate(360deg);}}
.disc{
  position:absolute;inset:0;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:44px;font-weight:900;
  background:radial-gradient(circle at 40% 32%,#fffaef,#e8d6a8);
  box-shadow:inset 0 -5px 11px rgba(0,0,0,.26),inset 0 3px 5px rgba(255,255,255,.6);
}
.disc.cho{color:var(--cho-deep);}
.disc.han{color:var(--han-deep);}
.disc.draw{color:#9a7a36;}
.rtitle{font-family:"Black Han Sans",sans-serif;font-size:25px;letter-spacing:.5px;color:var(--text);}
.rdesc{font-size:12.5px;color:var(--text-dim);margin:6px 0 22px;}
.rbtns{display:flex;gap:9px;}

/* 상단 아이콘 버튼 묶음 */
.topbtns{display:flex;gap:6px;align-items:center;}

/* 정보 모달 — 랭킹 / 도움말 */
.infocard{max-width:384px;text-align:left;padding:22px 20px 20px;}
.ititle{
  font-family:"Black Han Sans",sans-serif;font-size:20px;letter-spacing:.5px;
  color:var(--text);text-align:center;margin-bottom:14px;
}
.ibody{
  max-height:58vh;overflow-y:auto;font-size:13px;
  color:var(--text-dim);line-height:1.6;
}
.infoclose{width:100%;margin-top:16px;min-height:48px;flex:0 0 auto;}
.helpbody h4{margin:15px 0 5px;font-size:13.5px;color:var(--gold-bright);}
.helpbody h4:first-child{margin-top:0;}
.helpbody p{margin:0 0 4px;}
.helpbody ul{margin:4px 0;padding-left:18px;}
.helpbody li{margin:3px 0;}
.helpbody b{color:var(--text);}

/* 랭킹 표 */
.lbrow{
  display:flex;align-items:center;gap:10px;padding:8px 4px;
  border-bottom:1px solid var(--border);
}
.lbrow:last-child{border-bottom:none;}
.lbrank{flex:0 0 26px;text-align:center;font-weight:900;font-size:14px;color:var(--text-mute);}
.lbrow.top1 .lbrank{color:#f0c860;}
.lbrow.top2 .lbrank{color:#cdd2da;}
.lbrow.top3 .lbrank{color:#d99b63;}
.lbnick{
  flex:1;min-width:0;font-weight:800;color:var(--text);
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.lbrec{flex:0 0 auto;font-size:11px;color:var(--text-mute);}
.lbrating{flex:0 0 auto;font-weight:900;color:var(--gold-bright);font-size:14px;}
.lbempty{text-align:center;color:var(--text-mute);padding:24px 0;font-size:12.5px;}
#nickEditBtn{color:var(--text-mute);cursor:pointer;font-size:12px;text-decoration:none;}
#nickEditBtn:hover{color:var(--gold-bright);}

/* 기보 목록 */
.kfrow{
  display:flex;align-items:center;gap:10px;padding:9px 4px;cursor:pointer;
  border-bottom:1px solid var(--border);
}
.kfrow:last-child{border-bottom:none;}
.kfrow:hover{background:var(--surface-hi);}
.kfres{flex:0 0 auto;width:34px;text-align:center;font-weight:900;font-size:12px;}
.kfres.win{color:#7fd0a0;}
.kfres.loss{color:#f0938c;}
.kfres.draw{color:var(--text-mute);}
.kfvs{
  flex:1;min-width:0;font-weight:700;color:var(--text);
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.kfvs small{color:var(--text-mute);font-weight:600;}
.kfdate{flex:0 0 auto;font-size:10.5px;color:var(--text-mute);}
.kfempty{text-align:center;color:var(--text-mute);padding:24px 0;font-size:12.5px;line-height:1.6;}

/* 복기 컨트롤 바 — 푸터 자리에 표시 */
.replaybar{grid-area:actions;display:none;align-items:center;gap:8px;}
body.replaying .actions{display:none;}
body.replaying .replaybar{display:flex;}
.rpbtn{
  flex:0 0 auto;width:46px;min-height:52px;border-radius:var(--r-md);cursor:pointer;
  font-size:15px;font-weight:800;
  background:var(--surface-hi);border:1px solid var(--border-hi);color:var(--text);
}
.rpbtn:active{transform:scale(.94);}
.rppos{
  flex:1;text-align:center;font-weight:900;font-size:14px;
  font-variant-numeric:tabular-nums;color:var(--text-dim);
}
.rpexit{flex:0 0 auto;min-height:52px;padding:0 14px;}

/* ===================== 급수 테스트 ===================== */
.testbar{display:flex;align-items:center;gap:7px;}
.trbadge{
  flex:0 0 auto;white-space:nowrap;
  font-size:10.5px;font-weight:800;color:var(--gold-bright);
  padding:9px 11px;border-radius:var(--r-sm);
  background:var(--surface);border:1px solid var(--border);
}
.tbtn{
  flex:1;min-height:40px;border-radius:var(--r-sm);cursor:pointer;
  font-size:12px;font-weight:800;letter-spacing:.2px;
  background:var(--surface-hi);border:1px solid var(--border-hi);color:var(--text);
  transition:background .15s,transform .08s;
}
.tbtn:hover{background:#33342a;}
.tbtn:active{transform:translateY(1px);}
/* 측정 진행 중 — 배지를 골드로 강조 */
.trbadge.testing{
  color:#221a06;border-color:rgba(0,0,0,.2);
  background:linear-gradient(180deg,var(--gold-bright),var(--gold));
}
.testcard{text-align:center;}

/* 동작 확인용 토스트 */
.toast{
  position:fixed;left:50%;top:18px;z-index:120;pointer-events:none;
  transform:translate(-50%,-16px);opacity:0;
  padding:11px 20px;border-radius:999px;white-space:nowrap;
  background:var(--surface-hi);border:1px solid var(--border-hi);
  color:var(--text);font-size:13px;font-weight:800;letter-spacing:.3px;
  box-shadow:var(--sh-2);
  transition:opacity .25s,transform .25s cubic-bezier(.2,1.4,.4,1);
}
.toast.show{opacity:1;transform:translate(-50%,0);}

/* 연결 상태 알림 띠 — 재접속 시도/상대 끊김 등 */
.netstat{
  position:fixed;left:50%;top:14px;z-index:110;max-width:92vw;
  transform:translate(-50%,-14px);opacity:0;pointer-events:none;
  padding:9px 18px;border-radius:999px;
  background:var(--surface-hi);border:1px solid var(--border-hi);
  color:var(--text);font-size:12.5px;font-weight:800;letter-spacing:.2px;
  box-shadow:var(--sh-2);
  transition:opacity .22s,transform .22s;
}
.netstat.show{opacity:1;transform:translate(-50%,0);}
.netstat.warn{
  background:linear-gradient(100deg,#7a5a1f,#caa24e,#7a5a1f);
  border-color:transparent;color:#1c1503;
}
.tsub{font-size:12px;color:var(--text-dim);letter-spacing:.5px;}
.trank{
  font-family:"Black Han Sans",sans-serif;font-size:46px;line-height:1.1;margin:4px 0 14px;
  background:linear-gradient(180deg,var(--gold-bright),var(--gold));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.tmeter{
  height:9px;border-radius:999px;margin:0 0 13px;overflow:hidden;
  background:var(--surface-inset);border:1px solid var(--border);
}
.tmeter>span{display:block;height:100%;border-radius:999px;
  background:linear-gradient(90deg,var(--gold),var(--gold-bright));}
.tstats{font-size:12.5px;color:var(--text-dim);line-height:1.75;margin-bottom:18px;}
.tstats b{color:var(--text);font-size:14px;}
.tnote{font-size:12px;color:var(--text-dim);line-height:1.6;margin:2px 0 18px;}
.tnote b{color:var(--gold-bright);}

/* ===================== mobile ===================== */
@media (max-width:820px){
  .app{
    grid-template-columns:minmax(0,1fr);
    grid-template-rows:auto auto auto auto 1fr auto;
    grid-template-areas:"topbar" "playbar" "testbar" "players" "stage" "actions";
    gap:8px;max-width:600px;
    padding:calc(8px + env(safe-area-inset-top)) 11px
            calc(10px + env(safe-area-inset-bottom)) 11px;
  }
  .gear{display:flex;}
  .turn{margin-left:0;}
  .brand b{font-size:21px;}
  .brand span{display:none;}
  .players{flex-direction:row;align-items:stretch;}
  .players.flip{flex-direction:row-reverse;}
  .pcard{flex:1;min-width:0;padding:9px 10px;gap:9px;}
  .pcard .emblem{width:38px;height:38px;font-size:19px;border-radius:var(--r-sm);}
  .pname{font-size:12.5px;}
  .caps{margin-top:4px;height:22px;}
  .cap{width:20px;height:20px;font-size:11px;}
  .pscore{display:none;}
  .pclock{min-width:56px;padding:5px 5px;}
  .pclock b{font-size:16px;}
  .vs{padding:0 3px;}
  .vs::before,.vs::after{display:none;}
  .controls{
    position:fixed;inset:0;z-index:80;overflow:visible;
    display:none;place-items:center;padding:22px;
    background:rgba(8,9,7,.82);backdrop-filter:blur(5px);
  }
  .controls.show{display:grid;animation:fadeIn .2s ease;}
  .sheet{
    width:100%;max-width:380px;max-height:84dvh;overflow:auto;
    border-color:var(--border-hi);
    padding:18px 16px calc(16px + env(safe-area-inset-bottom));gap:15px;
    box-shadow:var(--sh-3);animation:popIn .35s cubic-bezier(.2,1.4,.4,1) both;
  }
  .sheethead h2{font-size:16px;}
  .x{display:flex;align-items:center;justify-content:center;}
  .sheetnew{display:block;}
}
@media (max-width:360px){
  .pname i{display:none;}
  .btn{font-size:13px;}
}
@media (min-width:821px){
  .pcard{cursor:default;}
}

/* ===================== noscript SEO fallback ===================== */
.noscript-seo{
  max-width:680px;margin:48px auto;padding:0 24px;
  font-family:"Noto Serif KR",serif;color:var(--text-dim);line-height:1.75;
}
.noscript-seo h2{color:var(--gold-bright);font-size:22px;margin:0 0 14px;}
.noscript-seo p{margin:0 0 12px;font-size:15px;}
