:root{
  --oct:polygon(31% 0,69% 0,100% 31%,100% 69%,69% 100%,31% 100%,0 69%,0 31%);
  --gold:#e8c372; --gold-l:#f7e3a6; --gold-d:#bd8f3f;
  --cho:#2fae72; --cho-d:#0f5e35;
  --han:#dc4a44; --han-d:#8a1f1c;
  --ink:#f1e9d6; --mut:#94a39a;
  --glass:rgba(255,255,255,.055);
  --line:rgba(255,255,255,.10);
  --r:16px;
}
*{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(--ink);
  height:100dvh;-webkit-user-select:none;user-select:none;
  background:
    radial-gradient(680px 480px at 16% -4%,rgba(47,174,114,.20),transparent 62%),
    radial-gradient(700px 520px at 102% 104%,rgba(220,74,68,.16),transparent 60%),
    linear-gradient(168deg,#121d19,#0a100e 70%);
}
body::before{
  content:"";position:fixed;inset:-25%;z-index:-1;pointer-events:none;
  background:radial-gradient(38% 38% at 50% 50%,rgba(232,195,114,.10),transparent 70%);
  animation:drift 17s ease-in-out infinite alternate;
}
@keyframes drift{from{transform:translate(-9%,-6%);}to{transform:translate(11%,9%);}}
button,select{font-family:inherit;color:inherit;touch-action:manipulation;}

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

/* ========== topbar ========== */
.topbar{display:flex;align-items:center;gap:10px;}
.brand{display:flex;flex-direction:column;align-items:flex-start;gap:1px;line-height:1.05;flex:0 0 auto;margin:0;}
.brand b{
  font-family:"Black Han Sans",sans-serif;font-size:22px;font-weight:400;letter-spacing:2px;
  white-space:nowrap;
  background:linear-gradient(180deg,#fbeec0,#c89640);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  filter:drop-shadow(0 2px 3px rgba(0,0,0,.4));
}
.brand span{font-size:10px;font-weight:700;color:var(--gold-d);letter-spacing:1.5px;white-space:nowrap;}
.turn{
  margin-left:auto;display:flex;align-items:center;gap:8px;
  padding:8px 15px;border-radius:999px;font-size:13px;font-weight:800;letter-spacing:.5px;
  background:var(--glass);border:1px solid var(--line);white-space:nowrap;
}
.turn::before{content:"";width:9px;height:9px;border-radius:50%;background:var(--mut);}
.turn.cho{color:#5fe0a0;border-color:rgba(47,174,114,.55);}
.turn.cho::before{background:#43d68d;box-shadow:0 0 10px #43d68d;animation:blink 1.6s infinite;}
.turn.han{color:#f3938e;border-color:rgba(220,74,68,.55);}
.turn.han::before{background:#f0726d;box-shadow:0 0 10px #f0726d;animation:blink 1.6s infinite;}
.turn.over{color:var(--gold);border-color:rgba(232,195,114,.5);}
.turn.over::before{background:var(--gold);box-shadow:0 0 10px var(--gold);}
@keyframes blink{0%,100%{opacity:1;}50%{opacity:.35;}}
.gear{
  display:none;width:42px;height:42px;flex:0 0 auto;border-radius:12px;cursor:pointer;
  align-items:center;justify-content:center;font-size:19px;
  background:var(--glass);border:1px solid var(--line);
}
.gear:active{transform:scale(.93);}

/* ========== player cards ========== */
.players{display:flex;flex-direction:column;gap:10px;justify-content:center;}
/* 한(漢) 플레이어 — 뒤집힌 판에 맞춰 내 카드를 아래쪽으로 */
.players.flip{flex-direction:column-reverse;}
.vs{
  align-self:center;font-family:"Black Han Sans",sans-serif;font-size:13px;
  color:var(--gold-d);letter-spacing:1px;position:relative;padding:0 12px;
}
.vs::before,.vs::after{content:"";position:absolute;top:50%;width:34px;height:1px;
  background:linear-gradient(90deg,transparent,var(--line));}
.vs::before{right:100%;}
.vs::after{left:100%;transform:scaleX(-1);}
.pcard{
  position:relative;display:flex;align-items:center;gap:11px;padding:11px;
  border-radius:var(--r);
  background:linear-gradient(160deg,rgba(255,255,255,.08),rgba(255,255,255,.025));
  border:1px solid var(--line);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.07);
  transition:box-shadow .3s,border-color .3s,transform .2s;
}
.emblem{
  width:46px;height:46px;flex:0 0 auto;border-radius:13px;
  display:flex;align-items:center;justify-content:center;
  font-size:25px;font-weight:900;position:relative;
  box-shadow:inset 0 2px 3px rgba(255,255,255,.3),inset 0 -3px 5px rgba(0,0,0,.35),
    0 4px 9px rgba(0,0,0,.4);
}
.pcard.han .emblem{background:linear-gradient(160deg,#ec6f6a,#9a2521);color:#fff1ef;}
.pcard.cho .emblem{background:linear-gradient(160deg,#46c386,#15703f);color:#ecfff5;}
.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:9.5px;font-weight:800;letter-spacing:.5px;
  padding:2px 7px;border-radius:999px;background:rgba(255,255,255,.1);color:var(--mut);
}
.caps{display:flex;flex-wrap:nowrap;gap:3px;margin-top:5px;min-width:0;
  height:26px;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;}
.caps::-webkit-scrollbar{display:none;}
.cap{
  width:24px;height:24px;clip-path:var(--oct);flex:0 0 auto;
  display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:900;
}
.cap.cho{background:linear-gradient(160deg,#3bb47a,#15703f);color:#ecfff5;}
.cap.han{background:linear-gradient(160deg,#df5a55,#8a1f1c);color:#fff1ef;}
.pscore{
  flex:0 0 auto;text-align:center;min-width:46px;
  background:rgba(0,0,0,.28);border-radius:11px;padding:6px 4px;
  border:1px solid var(--line);
}
.pscore b{display:block;font-size:17px;font-weight:900;color:var(--gold-l);line-height:1;}
.pscore span{font-size:8.5px;color:var(--mut);letter-spacing:1px;}
.pcard.active{transform:translateY(-1px);}
.pcard.active.han{border-color:var(--han);
  box-shadow:0 0 0 1px var(--han),0 8px 26px rgba(220,74,68,.34),inset 0 1px 0 rgba(255,255,255,.08);
  animation:glowHan 1.8s ease-in-out infinite;}
.pcard.active.cho{border-color:var(--cho);
  box-shadow:0 0 0 1px var(--cho),0 8px 26px rgba(47,174,114,.34),inset 0 1px 0 rgba(255,255,255,.08);
  animation:glowCho 1.8s ease-in-out infinite;}
@keyframes glowHan{0%,100%{box-shadow:0 0 0 1px var(--han),0 6px 18px rgba(220,74,68,.26),inset 0 1px 0 rgba(255,255,255,.08);}
  50%{box-shadow:0 0 0 1px var(--han),0 9px 30px rgba(220,74,68,.5),inset 0 1px 0 rgba(255,255,255,.08);}}
@keyframes glowCho{0%,100%{box-shadow:0 0 0 1px var(--cho),0 6px 18px rgba(47,174,114,.26),inset 0 1px 0 rgba(255,255,255,.08);}
  50%{box-shadow:0 0 0 1px var(--cho),0 9px 30px rgba(47,174,114,.5),inset 0 1px 0 rgba(255,255,255,.08);}}

/* ========== board ========== */
.stage{position:relative;display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:6px;
  min-height:0;min-width:0;overflow:hidden;}
.banner{
  position:absolute;top:8px;left:50%;z-index:25;pointer-events:none;white-space:nowrap;
  transform:translate(-50%,-14px) scale(.9);opacity:0;
  padding:10px 26px;border-radius:999px;font-weight:900;letter-spacing:3px;font-size:16px;
  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,#8a1f1f,#e7544e,#8a1f1f);color:#fff0ec;
  box-shadow:0 10px 30px rgba(220,74,68,.6);}
.banner.win{background:linear-gradient(100deg,#9a7420,#f3d27a,#9a7420);color:#241a02;
  box-shadow:0 10px 30px rgba(232,195,114,.55);}

/* LLM 한 수 해설 — 장기판 바로 아래 */
.llmnote{
  display:none;flex:0 0 auto;order:2;
  width:94%;max-width:560px;min-height:76px;height:auto;max-height:132px;
  padding:9px 14px;border-radius:14px;
  background:linear-gradient(160deg,rgba(40,52,48,.97),rgba(22,31,28,.97));
  border:1px solid rgba(232,195,114,.42);
  color:#f1e7cf;font-size:12px;font-weight:600;line-height:1.5;text-align:left;
  box-shadow:0 6px 18px rgba(0,0,0,.45);
  overflow-y:auto;-webkit-overflow-scrolling:touch;
}
.llmnote::-webkit-scrollbar{display:none;}

.scaler{transform-origin:top left;}
.boardwrap{
  position:relative;width:560px;padding:16px;border-radius:24px;
  background:linear-gradient(155deg,#48301a,#1f140a 78%);
  box-shadow:
    0 34px 60px -14px rgba(0,0,0,.78),
    0 0 0 1px rgba(0,0,0,.6),
    inset 0 2px 2px rgba(255,224,170,.22),
    inset 0 -8px 16px rgba(0,0,0,.6);
}
.boardwrap::before{
  content:"";position:absolute;inset:8px;border-radius:16px;pointer-events:none;
  border:1.5px solid rgba(232,195,114,.4);
  box-shadow:inset 0 0 12px rgba(0,0,0,.45);
}
.board{
  position:relative;width:528px;height:584px;border-radius:8px;overflow:hidden;
  background:
    repeating-linear-gradient(91deg,rgba(120,72,26,.045) 0 7px,rgba(255,238,205,.05) 7px 15px),
    radial-gradient(120% 80% at 30% 12%,#f3d6a6,transparent 60%),
    linear-gradient(158deg,#ecc78f,#dca867 54%,#ce9a58);
  box-shadow:inset 0 0 44px rgba(96,54,12,.4);
}
/* 한(漢) 플레이어 시점 — 나무 배경은 그대로 두고, 그 위 레이어(격자·기물·마커)만
   180° 회전한다. 격자·기물 팔각형이 180° 대칭이라 왜곡 없음.
   기물 글자만 다시 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(58,32,8,.62);stroke-width:1.8;stroke-linecap:round;}
.br{stroke:rgba(58,32,8,.5);stroke-width:1.8;stroke-linecap:round;}

/* 실제 나무 장기알 — 알은 나무색, 글자만 색(한=적/초=녹), 음각 */
.piece{
  position:absolute;clip-path:var(--oct);cursor:pointer;
  background:linear-gradient(158deg,#bf9356 6%,#9a7236 56%,#785525);
  filter:drop-shadow(0 4px 5px rgba(0,0,0,.52));
  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:
    repeating-linear-gradient(94deg,rgba(104,66,20,.05) 0 3px,rgba(255,242,208,.055) 3px 8px),
    radial-gradient(82% 72% at 40% 26%,#f8e9c0,#e7cb8e 56%,#d0aa6c);
  display:flex;align-items:center;justify-content:center;
  font-weight:900;line-height:1;font-size:24px;
  box-shadow:inset 0 2px 2px rgba(255,249,228,.65),inset 0 -3px 6px rgba(92,56,14,.42);
}
.piece .face::before{
  content:"";position:absolute;inset:11%;clip-path:var(--oct);
  box-shadow:inset 0 0 0 1.4px rgba(96,60,20,.42);
}
.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%;
  transform:translate(0,0);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%;}

/* ========== controls (settings) ========== */
.controls{overflow:auto;}
.sheet{
  background:linear-gradient(160deg,rgba(255,255,255,.07),rgba(255,255,255,.02));
  border:1px solid var(--line);border-radius:18px;padding:15px;
  display:flex;flex-direction:column;gap:13px;
}
.sheethead{display:flex;align-items:center;justify-content:space-between;}
.sheethead h2{font-size:15px;letter-spacing:1px;color:var(--gold-l);}
.x{display:none;width:34px;height:34px;border-radius:10px;cursor:pointer;border:none;
  background:rgba(255,255,255,.09);font-size:14px;}
.field>label{display:block;font-size:11px;color:var(--mut);margin-bottom:7px;
  letter-spacing:1px;font-weight:700;}
.seg{display:flex;gap:6px;background:rgba(0,0,0,.25);padding:5px;border-radius:13px;}
.seg button{
  flex:1;padding:10px 4px;border-radius:9px;cursor:pointer;
  font-size:12.5px;font-weight:800;background:transparent;color:#b9c2bb;
  border:none;transition:.15s;
}
.seg button.on{
  background:linear-gradient(180deg,var(--gold-l),var(--gold-d));color:#241a05;
  box-shadow:0 3px 8px rgba(0,0,0,.4),inset 0 1px 0 rgba(255,255,255,.5);
}
.duo{display:flex;gap:8px;}
select{
  width:100%;padding:11px 9px;border-radius:11px;font-size:12.5px;font-weight:700;
  background:#1d2824;border:1px solid var(--line);
}
.hint{font-size:10.5px;color:var(--mut);margin-top:6px;line-height:1.5;}

/* 온라인 대국 — 장기판 위 오버레이 참가 카드 */
.onlinepanel{
  position:absolute;inset:0;z-index:30;display:none;
  place-items:center;padding:18px;
  background:rgba(10,14,12,.62);
}
.onlinepanel.show{display:grid;}
.opcard{
  width:100%;max-width:300px;text-align:center;
  background:linear-gradient(160deg,#243430,#161f1c);
  border:1px solid rgba(232,195,114,.3);border-radius:20px;
  padding:24px 20px;box-shadow:0 24px 60px rgba(0,0,0,.6);
}
.optitle{font-family:"Black Han Sans",sans-serif;font-size:20px;color:var(--gold-l);letter-spacing:1px;}
.opsub{font-size:11px;color:var(--mut);margin:6px 0 14px;line-height:1.55;}
.onlinein{
  width:100%;padding:11px;border-radius:11px;
  font-size:14px;font-weight:700;color:var(--ink);text-align:center;
  background:#1d2824;border:1px solid var(--line);
}
.onlinein::placeholder{color:var(--mut);font-weight:600;}
.obtn{width:100%;min-height:46px;font-size:14px;border-radius:12px;margin-top:9px;}
.omsg{
  margin-top:11px;padding:8px 11px;border-radius:10px;
  font-size:11px;line-height:1.5;font-weight:600;color:#e8dcc0;
  background:rgba(0,0,0,.28);border:1px solid var(--line);
}
.omsg.bad{color:#f3a09d;}
#llmStat{font-weight:800;}
#llmStat.ok{color:#5fd394;} #llmStat.bad{color:#f0908d;}
.sheetnew{display:none;}

/* ========== action buttons ========== */
.actions{display:flex;gap:9px;}
.btn{
  flex:1;min-height:54px;border-radius:15px;cursor:pointer;
  font-weight:900;font-size:14.5px;letter-spacing:.5px;
  background:linear-gradient(180deg,rgba(255,255,255,.16),rgba(255,255,255,.05));
  border:1px solid var(--line);color:var(--ink);
  box-shadow:0 4px 0 rgba(0,0,0,.4),inset 0 1px 0 rgba(255,255,255,.16);
  transition:transform .07s,box-shadow .07s,filter .12s;
}
.btn:active{transform:translateY(4px);box-shadow:0 0 0 rgba(0,0,0,.4),inset 0 1px 0 rgba(255,255,255,.16);}
.btn:disabled{opacity:.32;}
.btn:disabled:active{transform:none;box-shadow:0 4px 0 rgba(0,0,0,.4);}
.btn.primary{
  background:linear-gradient(180deg,#f4dc94,#c2912f);color:#2a1e03;border:none;
  box-shadow:0 4px 0 #6e4f12,0 6px 16px rgba(232,195,114,.4),inset 0 1px 0 rgba(255,255,255,.55);
}
.btn.primary:active{transform:translateY(4px);
  box-shadow:0 0 0 #6e4f12,0 2px 8px rgba(232,195,114,.4),inset 0 1px 0 rgba(255,255,255,.55);}

/* ========== result modal ========== */
.modal{
  position:fixed;inset:0;z-index:90;display:none;place-items:center;padding:24px;
  background:rgba(7,10,9,.74);backdrop-filter:blur(5px);
}
.modal.show{display:grid;animation:fadeIn .22s ease;}
@keyframes fadeIn{from{opacity:0;}to{opacity:1;}}
.resultcard{
  width:100%;max-width:340px;text-align:center;padding:30px 22px 22px;
  border-radius:24px;
  background:linear-gradient(165deg,#243430,#161f1c);
  border:1px solid rgba(232,195,114,.32);
  box-shadow:0 30px 70px rgba(0,0,0,.7),inset 0 1px 0 rgba(255,255,255,.07);
  animation:popIn .42s cubic-bezier(.2,1.5,.4,1) both;
}
@keyframes popIn{from{opacity:0;transform:scale(.7) translateY(20px);}
  to{opacity:1;transform:scale(1) translateY(0);}}
.rmedal{position:relative;width:104px;height:104px;margin:0 auto 16px;}
.rmedal::before{
  content:"";position:absolute;inset:-12px;border-radius:50%;
  background:conic-gradient(from 0deg,transparent,var(--gold),transparent 55%);
  animation:spin 3.6s linear infinite;opacity:.85;
}
@keyframes spin{to{transform:rotate(360deg);}}
.disc{
  position:absolute;inset:0;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:48px;font-weight:900;
  background:radial-gradient(circle at 40% 32%,#fffaef,#ead9ac);
  box-shadow:inset 0 -6px 12px rgba(0,0,0,.28),inset 0 3px 5px rgba(255,255,255,.6);
}
.disc.cho{color:#13713f;} .disc.han{color:#9a2420;} .disc.draw{color:#9a7a36;}
.rtitle{font-family:"Black Han Sans",sans-serif;font-size:27px;letter-spacing:1px;
  color:var(--gold-l);}
.rdesc{font-size:13px;color:var(--mut);margin:5px 0 20px;}
.rbtns{display:flex;gap:9px;}

/* ========== mobile ========== */
@media (max-width:820px){
  .app{
    grid-template-columns:minmax(0,1fr);grid-template-rows:auto auto auto 1fr auto;
    grid-template-areas:"topbar" "playbar" "players" "stage" "actions";
    gap:7px;max-width:600px;
    padding:calc(6px + env(safe-area-inset-top)) 10px
            calc(8px + env(safe-area-inset-bottom)) 10px;
  }
  .gear{display:flex;width:40px;height:40px;}
  .topbar{gap:6px;}
  .turn{margin-left:0;padding:7px 11px;}
  .brand b{font-size:21px;letter-spacing:1.5px;}
  .brand span{display:none;}
  .players{flex-direction:row;align-items:stretch;}
  .players.flip{flex-direction:row-reverse;}
  .pcard{flex:1;min-width:0;padding:7px 9px;gap:9px;}
  .pcard .emblem{width:38px;height:38px;font-size:19px;border-radius:10px;}
  .pname{font-size:12.5px;}
  .caps{margin-top:3px;height:24px;}
  .cap{width:22px;height:22px;font-size:12px;}
  .pscore{display:none;}
  .vs{padding:0 2px;font-size:11px;}
  .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,12,11,.8);backdrop-filter:blur(4px);
  }
  .controls.show{display:grid;animation:fadeIn .2s ease;}
  .sheet{
    width:100%;max-width:380px;max-height:84dvh;overflow:auto;
    background:linear-gradient(160deg,#243430,#161f1c);border-radius:22px;
    padding:18px 16px calc(16px + env(safe-area-inset-bottom));gap:15px;
    box-shadow:0 30px 70px rgba(0,0,0,.7);animation:popIn .35s cubic-bezier(.2,1.4,.4,1) both;
  }
  .sheethead h2{font-size:17px;}
  .x{display:flex;align-items:center;justify-content:center;}
  .sheetnew{display:block;}
  .btn{min-height:50px;}
}
@media (max-width:360px){
  .pname i{display:none;} .btn{font-size:13px;}
}
@media (min-width:821px){
  .pcard{cursor:default;}
  .pscore{min-width:50px;}
}

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