:root {
  --wood-dark:#1e0c02; --wood-mid:#4a2008; --wood-light:#7a3a10;
  --wood-pale:#a85c28; --hanji:#f5e8c8; --hanji-warm:#d4b87a;
  --gold:#c8960c; --gold-lt:#f0c040; --gold-dk:#8a6408;
  --red:#c0392b; --shadow:rgba(0,0,0,.7);
  --panel-bg:rgba(0,0,0,.55);
}
*{margin:0;padding:0;box-sizing:border-box}
html,body{width:100%;height:100%;overflow:hidden}
body{font-family:'Nanum Myeongjo',serif;background:var(--wood-dark);user-select:none;}

/* ══ 화면 전환 ══ */
.screen{display:none;width:100vw;height:100vh;flex-direction:column;align-items:center;justify-content:center;}
.screen.active{display:flex}

/* ══ 모드 선택 ══ */
#screen-mode{background:radial-gradient(ellipse at 50% 30%,#3a1a06,#1e0c02 70%);}
.hub-logo{text-align:center;margin-bottom:2.5rem}
.hub-logo h1{font-size:clamp(2.5rem,8vw,5rem);color:var(--gold-lt);text-shadow:0 0 60px rgba(240,192,64,.5),4px 4px 0 #000;letter-spacing:.3em}
.hub-logo .sub{color:var(--hanji-warm);font-size:.85rem;letter-spacing:.3em;margin-top:.4rem;opacity:.7}
.hub-logo .subsub{color:var(--hanji-warm);font-size:.7rem;letter-spacing:.1em;margin-top:.2rem;opacity:.5}
.mode-row{display:flex;gap:1.5rem;flex-wrap:wrap;justify-content:center;margin-bottom:2rem}
.mc{background:linear-gradient(160deg,rgba(90,45,15,.9),rgba(20,10,2,.95));border:2px solid var(--wood-pale);border-radius:16px;padding:1.8rem 2rem;text-align:center;cursor:pointer;transition:all .25s;min-width:160px;}
.mc:hover{transform:translateY(-6px);border-color:var(--gold);box-shadow:0 14px 36px var(--shadow),0 0 20px rgba(200,150,12,.35)}
.mc .ico{font-size:2.5rem;display:block;margin-bottom:.6rem}
.mc h3{color:var(--gold-lt);font-size:1.1rem;letter-spacing:.1em;margin-bottom:.3rem}
.mc p{color:var(--hanji-warm);font-size:.75rem;line-height:1.6;opacity:.8}
.xe-badge{display:inline-block;margin-top:.6rem;font-size:.65rem;padding:2px 9px;border-radius:20px;background:rgba(200,150,12,.15);color:var(--gold);border:1px solid var(--gold-dk)}
.btn-home{background:transparent;border:1px solid var(--wood-pale);color:var(--hanji-warm);padding:.5rem 1.4rem;border-radius:8px;cursor:pointer;font-family:inherit;font-size:.85rem;transition:all .2s;text-decoration:none;display:inline-block;}
.btn-home:hover{border-color:var(--gold);color:var(--gold-lt)}

/* ══ 로비 화면 ══ */
#screen-lobby{background:radial-gradient(ellipse at 50% 30%,#3a1a06,#1e0c02 70%);padding:1.5rem;overflow-y:auto;}
.lobby-box{background:linear-gradient(160deg,rgba(90,45,15,.95),rgba(20,10,2,.98));border:2px solid var(--gold);border-radius:16px;padding:1.8rem;max-width:480px;width:100%;max-height:calc(100vh - 3rem);overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--gold) transparent;}
.lobby-box h2{color:var(--gold-lt);font-size:1.25rem;letter-spacing:.15em;margin-bottom:1.2rem;text-align:center}
.xe-check{background:rgba(0,0,0,.4);border:1px solid rgba(255,255,255,.1);border-radius:10px;padding:.8rem 1rem;margin-bottom:1rem;text-align:center;}
.xe-user{color:var(--gold-lt);font-size:.95rem;margin-bottom:.2rem}
.xe-status{color:var(--hanji-warm);font-size:.75rem;opacity:.7}
#lobby-guest-section{text-align:center;padding:1rem 0}
#lobby-guest-section p{color:var(--hanji-warm);font-size:.82rem;line-height:1.8;margin-bottom:1rem}
#lobby-member-section{display:none}
.room-section h4{color:var(--hanji-warm);font-size:.8rem;letter-spacing:.08em;margin-bottom:.5rem}
#lobby-room-list{max-height:160px;overflow-y:auto;margin-bottom:.8rem;scrollbar-width:thin;scrollbar-color:var(--gold) transparent;}
.room-item{display:flex;align-items:center;justify-content:space-between;background:rgba(0,0,0,.35);border:1px solid rgba(255,255,255,.08);border-radius:8px;padding:.5rem .8rem;margin-bottom:.3rem;cursor:pointer;transition:all .2s;}
.room-item:hover:not(.full){border-color:var(--gold);background:rgba(200,150,12,.1)}
.room-item.full{cursor:not-allowed;opacity:.55}
.room-name{color:var(--hanji);font-size:.85rem}
.room-info{color:var(--hanji-warm);font-size:.72rem;opacity:.7}
.room-empty{color:rgba(255,255,255,.3);font-size:.78rem;text-align:center;padding:.6rem 0}
.s-wait{font-size:.68rem;padding:2px 8px;border-radius:10px;background:rgba(20,90,20,.5);color:#8f8;border:1px solid #5d5}
.s-full{font-size:.68rem;padding:2px 8px;border-radius:10px;background:rgba(90,20,20,.5);color:#f88;border:1px solid #d44}
.ri{width:100%;background:rgba(0,0,0,.4);border:1px solid var(--wood-pale);color:var(--hanji);padding:.55rem .8rem;border-radius:8px;font-family:inherit;font-size:.88rem;margin-bottom:.6rem}
.ri:focus{outline:none;border-color:var(--gold)}
.code-row{display:flex;gap:.5rem;margin-bottom:.6rem}
.code-row .ri{margin-bottom:0;flex:1;text-transform:uppercase;letter-spacing:.2em;font-size:.95rem;text-align:center}
.lobby-btns{display:flex;gap:.6rem;flex-wrap:wrap}
.btn-lob{flex:1;background:linear-gradient(135deg,var(--wood-light),var(--wood-mid));border:1px solid var(--wood-pale);color:var(--hanji);padding:.55rem;border-radius:8px;cursor:pointer;font-family:inherit;font-size:.82rem;letter-spacing:.04em;transition:all .2s;text-align:center;}
.btn-lob:hover{border-color:var(--gold);color:var(--gold-lt)}
.btn-lob.red{background:linear-gradient(135deg,#7a1515,#4f0a0a);border-color:var(--red)}
.btn-ghost{background:transparent;border:1px solid var(--wood-pale);color:var(--hanji-warm);padding:.45rem 1.2rem;border-radius:8px;cursor:pointer;font-family:inherit;font-size:.8rem;transition:all .2s;}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold-lt)}

/* ══ 맵 선택 UI ══ */
.map-select-section{margin-bottom:.8rem}
.map-select-section h4{color:var(--hanji-warm);font-size:.8rem;letter-spacing:.08em;margin-bottom:.5rem}
.map-grid{display:grid;grid-template-columns:1fr 1fr;gap:.45rem}
.map-card{background:rgba(0,0,0,.4);border:1.5px solid var(--wood-pale);border-radius:10px;padding:.5rem .6rem;cursor:pointer;transition:all .2s;text-align:left;font-family:inherit;position:relative;overflow:hidden;}
.map-card:hover{border-color:var(--gold);background:rgba(200,150,12,.08)}
.map-card.selected{border-color:var(--gold-lt);background:rgba(200,150,12,.15);box-shadow:0 0 12px rgba(200,150,12,.25)}
.map-card.selected::after{content:'✓';position:absolute;top:4px;right:7px;color:var(--gold-lt);font-size:.8rem;font-weight:700}
.map-card-ico{font-size:1.3rem;display:block;margin-bottom:.2rem}
.map-card-name{color:var(--gold-lt);font-size:.8rem;font-weight:700;display:block;margin-bottom:.1rem}
.map-card-desc{color:var(--hanji-warm);font-size:.65rem;opacity:.75;line-height:1.4}
/* 맵 미리보기 미니 캔버스 */
.map-preview{display:block;margin:.4rem auto 0;border:1px solid rgba(255,255,255,.12);border-radius:3px;background:#0a0500;width:48px;height:58px;}
/* 대기방에 표시되는 맵 배지 */
.map-badge{display:inline-flex;align-items:center;gap:.3rem;background:rgba(200,150,12,.12);border:1px solid var(--gold-dk);color:var(--gold-lt);font-size:.7rem;padding:.2rem .6rem;border-radius:20px;margin:.4rem 0;}

/* ══ 모달 ══ */
.modal-bg{display:none;position:fixed;inset:0;background:rgba(0,0,0,.85);z-index:500;align-items:center;justify-content:center}
.modal-bg.show{display:flex}
.modal-box{background:linear-gradient(160deg,rgba(90,45,15,.97),rgba(20,10,2,.99));border:2px solid var(--gold);border-radius:16px;padding:2rem;max-width:360px;width:90%;text-align:center;animation:mIn .3s ease}
@keyframes mIn{from{transform:scale(.85);opacity:0}to{transform:scale(1);opacity:1}}
.modal-box h2{color:var(--gold-lt);font-size:1.3rem;margin-bottom:.8rem;letter-spacing:.1em}
.diff-btn{display:flex;align-items:center;gap:1rem;background:linear-gradient(135deg,rgba(90,45,15,.8),rgba(20,10,2,.9));border:1.5px solid var(--wood-pale);border-radius:10px;padding:.75rem 1rem;cursor:pointer;width:100%;text-align:left;transition:all .2s;font-family:inherit;margin-bottom:.6rem;}
.diff-btn:hover{border-color:var(--gold);transform:translateX(4px);}
.diff-ico{font-size:2rem;flex-shrink:0}
.diff-name{color:var(--gold-lt);font-size:1rem;font-weight:700;margin-bottom:.1rem}
.diff-desc{color:var(--hanji-warm);font-size:.72rem;opacity:.8}

/* ══ 대기 모달 ══ */
.p-slots{display:flex;gap:1.5rem;justify-content:center;margin:1rem 0}
.p-slot{text-align:center}
.p-avatar{width:58px;height:58px;border-radius:50%;border:2px solid var(--wood-pale);display:flex;align-items:center;justify-content:center;font-size:1.5rem;margin:0 auto .3rem;background:rgba(0,0,0,.4);}
.p-avatar.on{border-color:var(--gold);background:rgba(200,150,12,.15)}
.p-sname{color:var(--hanji);font-size:.72rem;max-width:72px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.code-display{background:rgba(0,0,0,.4);border:1px solid var(--gold);border-radius:8px;padding:.5rem 1.2rem;display:inline-block;margin:.7rem 0;cursor:pointer;}
.code-display:hover{background:rgba(200,150,12,.1)}
.code-display span{color:var(--gold-lt);font-size:1.4rem;font-weight:700;letter-spacing:.35em}
.dot-ani span{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--gold);margin:0 2px;animation:dot 1.2s infinite}
.dot-ani span:nth-child(2){animation-delay:.2s}
.dot-ani span:nth-child(3){animation-delay:.4s}
@keyframes dot{0%,80%,100%{opacity:.25}40%{opacity:1}}
.modal-btns{display:flex;gap:.8rem;justify-content:center;margin-top:1.3rem;flex-wrap:wrap}

/* ══ 게임 화면 ══ */
#screen-game{background:radial-gradient(ellipse at 50% 50%,#3a1a06 0%,#1e0c02 100%);gap:0;overflow:hidden;}
.g-header{width:100%;height:44px;flex-shrink:0;background:linear-gradient(90deg,var(--wood-dark),var(--wood-mid),var(--wood-dark));border-bottom:2px solid var(--gold);display:flex;align-items:center;justify-content:space-between;padding:0 1rem;position:relative;}
.g-header h2{color:var(--gold-lt);font-size:1rem;letter-spacing:.2em;position:absolute;left:50%;transform:translateX(-50%);}
.hdr-l,.hdr-r{display:flex;gap:.4rem;align-items:center}
.btn-h{background:transparent;border:1px solid var(--wood-pale);color:var(--hanji-warm);padding:.2rem .7rem;border-radius:5px;cursor:pointer;font-family:inherit;font-size:.72rem;transition:all .2s}
.btn-h:hover{border-color:var(--gold);color:var(--gold-lt)}

/* ══ 테트리스 게임 본체 ══ */
.game-area{flex:1;display:flex;align-items:center;justify-content:center;gap:1.2rem;padding:.6rem;min-height:0;width:100%;}

/* 플레이어 영역 */
.player-zone{display:flex;flex-direction:column;align-items:center;gap:.5rem;flex-shrink:0;}
.player-label{color:var(--gold-lt);font-size:.75rem;letter-spacing:.15em;text-align:center;}
.player-name-tag{color:var(--hanji);font-size:.85rem;font-weight:700;text-align:center;max-width:130px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.board-container{position:relative;}
canvas.tetris-board{display:block;border:2px solid var(--wood-pale);box-shadow:0 0 0 1px #4a2008,0 0 20px rgba(200,150,12,.2),inset 0 0 30px rgba(0,0,0,.5);background:#0a0500;}
.board-overlay{display:none;position:absolute;inset:0;background:rgba(0,0,0,.75);align-items:center;justify-content:center;flex-direction:column;gap:.5rem;border:2px solid var(--gold);}
.board-overlay.show{display:flex}
.overlay-text{color:var(--gold-lt);font-size:1.1rem;letter-spacing:.2em;text-align:center;line-height:1.6}

/* 사이드 패널 */
.side-info{display:flex;flex-direction:column;gap:.5rem;width:110px;flex-shrink:0;}
.info-card{background:var(--panel-bg);border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:.5rem .6rem;backdrop-filter:blur(6px);}
.info-card.active-turn{border-color:var(--gold);box-shadow:0 0 10px rgba(200,150,12,.3)}
.ic-label{color:var(--hanji-warm);font-size:.6rem;letter-spacing:.1em;margin-bottom:.2rem;opacity:.8}
.ic-val{color:var(--hanji);font-size:1rem;font-weight:700}
.next-canvas{display:block;margin:0 auto;}
.online-badge{display:inline-flex;align-items:center;gap:.3rem;font-size:.6rem;padding:.1rem .4rem;border-radius:8px;margin-top:.2rem;}
.online-badge.on{background:rgba(20,90,20,.5);color:#8f8;border:1px solid #5d5}
.online-badge.off{background:rgba(60,20,20,.5);color:#f88;border:1px solid #d44}

/* 가운데 VS */
.vs-divider{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.8rem;flex-shrink:0;}
.vs-text{color:var(--gold);font-size:1.6rem;font-weight:700;text-shadow:0 0 20px rgba(200,150,12,.5)}
.attack-log{background:rgba(0,0,0,.5);border:1px solid rgba(255,255,255,.08);border-radius:8px;padding:.4rem .5rem;width:70px;max-height:160px;overflow:hidden;}
.attack-log h5{color:var(--hanji-warm);font-size:.6rem;text-align:center;margin-bottom:.3rem;opacity:.7}
.atk-item{font-size:.65rem;color:var(--hanji-warm);text-align:center;padding:.1rem 0;opacity:.7;}
.atk-item.mine{color:#f0c040}
.atk-item.theirs{color:#f88}

/* 결과 모달 */
.result-box{max-width:380px;width:90%;text-align:center;}
.res-title{color:var(--gold-lt);font-size:2rem;margin-bottom:.5rem}
.res-sub{color:var(--hanji);font-size:.9rem;line-height:1.6;margin-bottom:1.2rem}
.btn-act{background:linear-gradient(135deg,var(--wood-light),var(--wood-mid));border:1.5px solid var(--wood-pale);color:var(--hanji);padding:.5rem 1rem;border-radius:8px;cursor:pointer;font-family:inherit;font-size:.82rem;letter-spacing:.04em;transition:all .2s;}
.btn-act:hover{border-color:var(--gold);color:var(--gold-lt)}
.btn-act.red{background:linear-gradient(135deg,#8B1A1A,#5a0f0f);border-color:var(--red)}

/* 공격 라인 표시 */
.atk-flash{position:absolute;bottom:0;left:0;right:0;background:rgba(255,80,80,.3);animation:atkFlash .4s ease-out forwards;pointer-events:none;}
@keyframes atkFlash{0%{opacity:1;height:100%}100%{opacity:0;height:0}}

/* 모바일 */
.mobile-controls{display:none;position:fixed;bottom:0;left:0;right:0;background:rgba(0,0,0,.8);border-top:1px solid var(--wood-pale);padding:.5rem;gap:.4rem;justify-content:center;align-items:center;z-index:200;}
@media(max-width:700px){
  .mobile-controls{display:flex}
  .side-info{display:none}
  .attack-log{display:none}
  .game-area{padding-bottom:70px}
}
.mob-btn{background:rgba(90,45,15,.8);border:1px solid var(--wood-pale);color:var(--hanji);padding:.5rem .9rem;border-radius:8px;cursor:pointer;font-size:1.1rem;touch-action:manipulation;}
.mob-btn:active{background:rgba(200,150,12,.3);border-color:var(--gold)}

.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(--gold-lt);padding:.4rem 1.3rem;border-radius:30px;font-size:.8rem;letter-spacing:.07em;z-index:700;opacity:0;transition:all .25s;pointer-events:none;white-space:nowrap;}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ══ 싱글 기록 모드 화면 ══ */
#screen-single{background:radial-gradient(ellipse at 50% 30%,#3a1a06,#1e0c02 70%);overflow-y:auto;padding:1.5rem;align-items:center;justify-content:flex-start;}
.single-wrap{width:100%;max-width:500px;}
.single-wrap h2{color:var(--gold-lt);font-size:1.2rem;letter-spacing:.15em;text-align:center;margin-bottom:1.2rem}
/* 난이도 탭 */
.diff-tabs{display:flex;gap:.4rem;margin-bottom:1rem;background:rgba(0,0,0,.3);border-radius:10px;padding:.3rem;}
.dtab{flex:1;background:transparent;border:none;color:var(--hanji-warm);padding:.4rem;border-radius:7px;cursor:pointer;font-family:inherit;font-size:.78rem;transition:all .2s;}
.dtab.on{background:rgba(200,150,12,.2);color:var(--gold-lt);border:1px solid var(--gold-dk)}
/* 랭킹 테이블 */
.rank-table{width:100%;border-collapse:collapse;margin-bottom:1rem;}
.rank-table th{color:var(--hanji-warm);font-size:.7rem;letter-spacing:.08em;padding:.4rem .5rem;border-bottom:1px solid rgba(255,255,255,.1);text-align:left;}
.rank-table td{color:var(--hanji);font-size:.82rem;padding:.45rem .5rem;border-bottom:1px solid rgba(255,255,255,.05);}
.rank-table tr:hover td{background:rgba(200,150,12,.06)}
.rank-1 td{color:var(--gold-lt)} .rank-2 td{color:#e0e0e0} .rank-3 td{color:#cd9b4a}
.rank-num{font-weight:700;font-size:.9rem;width:28px}
.rank-mine{background:rgba(200,150,12,.08)!important}
/* 내 기록 박스 */
.mybest-box{background:rgba(0,0,0,.4);border:1px solid var(--gold-dk);border-radius:10px;padding:.8rem 1rem;margin-bottom:1rem;}
.mybest-box h4{color:var(--gold);font-size:.78rem;letter-spacing:.1em;margin-bottom:.6rem}
.mybest-row{display:flex;justify-content:space-between;color:var(--hanji-warm);font-size:.78rem;padding:.2rem 0;}
.mybest-row span{color:var(--hanji);font-weight:700}
/* 점수 저장 폼 */
.save-form{background:rgba(0,0,0,.4);border:1px solid rgba(255,255,255,.1);border-radius:10px;padding:.8rem 1rem;margin-bottom:1rem;}
.save-form h4{color:var(--hanji-warm);font-size:.78rem;margin-bottom:.6rem}
.save-row{display:flex;gap:.5rem;align-items:center;}
.personal-best-badge{display:inline-block;background:rgba(200,150,12,.2);border:1px solid var(--gold);color:var(--gold-lt);font-size:.7rem;padding:2px 10px;border-radius:20px;margin-bottom:.5rem;}
/* 싱글 게임 화면 — 1인용 레이아웃 */
.single-game-area{flex:1;display:flex;align-items:center;justify-content:center;gap:1.2rem;padding:.6rem;min-height:0;width:100%;}
.single-side{display:flex;flex-direction:column;gap:.5rem;width:130px;flex-shrink:0;}
.single-board-zone{display:flex;flex-direction:column;align-items:center;gap:.3rem;}

/* ══ 홀드 카드 ══ */
.hold-locked{opacity:.4;pointer-events:none}

/* ══ 콤보/점수 팝업 ══ */
.score-popup{position:absolute;pointer-events:none;font-family:'Nanum Myeongjo',serif;font-weight:700;font-size:1.1rem;color:var(--gold-lt);text-shadow:0 0 8px rgba(240,192,64,.8);animation:scoreFloat 1.2s ease-out forwards;z-index:300;}
@keyframes scoreFloat{0%{opacity:1;transform:translateY(0) scale(1)}60%{opacity:1;transform:translateY(-40px) scale(1.15)}100%{opacity:0;transform:translateY(-70px) scale(.9)}}
.combo-popup{position:absolute;pointer-events:none;font-family:'Nanum Myeongjo',serif;font-weight:800;font-size:1.4rem;color:#f0c040;text-shadow:0 0 14px rgba(240,192,64,1);animation:comboFloat 1.4s ease-out forwards;z-index:301;}
@keyframes comboFloat{0%{opacity:1;transform:translateY(0) scale(1.2)}50%{opacity:1;transform:translateY(-30px) scale(1.4)}100%{opacity:0;transform:translateY(-60px) scale(1)}}
.tspin-popup{position:absolute;pointer-events:none;font-family:'Nanum Myeongjo',serif;font-weight:800;font-size:1.1rem;color:#a78bfa;text-shadow:0 0 12px rgba(167,139,250,.9);animation:scoreFloat 1.3s ease-out forwards;z-index:302;}

/* ══ 줄 제거 이펙트 ══ */
.clear-flash{position:absolute;left:0;right:0;pointer-events:none;background:rgba(255,255,255,.55);animation:clearFlash .35s ease-out forwards;z-index:200;}
@keyframes clearFlash{0%{opacity:1}100%{opacity:0}}
.levelup-flash{position:absolute;inset:0;background:rgba(200,150,12,.18);animation:lvlFlash .6s ease-out forwards;pointer-events:none;z-index:200;border-radius:4px;}
@keyframes lvlFlash{0%{opacity:1}100%{opacity:0}}

/* ══ 일시정지 오버레이 ══ */
.pause-overlay{display:none;position:absolute;inset:0;background:rgba(0,0,0,.78);align-items:center;justify-content:center;flex-direction:column;gap:.6rem;z-index:250;border-radius:4px;}
.pause-overlay.show{display:flex}
.pause-title{color:var(--gold-lt);font-size:1.3rem;letter-spacing:.25em}
.pause-hint{color:var(--hanji-warm);font-size:.72rem;opacity:.7;letter-spacing:.08em}

/* ══ AI 실력 슬라이더 ══ */
.skill-row{display:grid;grid-template-columns:1fr auto;align-items:center;gap:.6rem;padding:.5rem 0;border-bottom:1px solid rgba(255,255,255,.04);}
.skill-row:last-child{border-bottom:none}
.skill-label{color:var(--hanji-warm);font-size:.78rem}
.skill-label small{display:block;color:rgba(255,255,255,.3);font-size:.65rem;margin-top:.1rem}
.skill-slider-wrap{display:flex;align-items:center;gap:.5rem;min-width:180px;}
.skill-slider{-webkit-appearance:none;appearance:none;width:120px;height:5px;border-radius:3px;background:rgba(255,255,255,.15);outline:none;cursor:pointer;}
.skill-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:var(--gold-lt);cursor:pointer;box-shadow:0 0 6px rgba(240,192,64,.5);}
.skill-slider::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:var(--gold-lt);cursor:pointer;border:none;}
.skill-pct{color:var(--gold-lt);font-size:.85rem;font-weight:700;width:38px;text-align:right;}
/* 관리자 공통 */
.cfg-row{display:grid;grid-template-columns:1fr auto;align-items:center;gap:.6rem;padding:.3rem 0;border-bottom:1px solid rgba(255,255,255,.04);}
.cfg-row:last-child{border-bottom:none}
.cfg-label{color:var(--hanji-warm);font-size:.78rem;line-height:1.4}
.cfg-label small{display:block;color:rgba(255,255,255,.3);font-size:.65rem;margin-top:.1rem}
.cfg-input{background:rgba(0,0,0,.45);border:1px solid var(--wood-pale);color:var(--hanji);padding:.35rem .55rem;border-radius:6px;font-family:inherit;font-size:.82rem;width:90px;text-align:right;}
.cfg-input:focus{outline:none;border-color:var(--gold)}
.tier-table{width:100%;border-collapse:collapse;margin-top:.4rem}
.tier-table th{color:var(--hanji-warm);font-size:.68rem;letter-spacing:.06em;padding:.3rem .4rem;border-bottom:1px solid rgba(255,255,255,.1);text-align:left;}
.tier-table td{padding:.25rem .4rem;border-bottom:1px solid rgba(255,255,255,.04);}
.tier-table input{background:rgba(0,0,0,.4);border:1px solid var(--wood-pale);color:var(--hanji);padding:.2rem .4rem;border-radius:5px;font-family:inherit;font-size:.8rem;width:80px;text-align:right;}
.tier-table input:focus{outline:none;border-color:var(--gold)}