@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+KR:wght@400;700;900&family=Cinzel:wght@700;900&display=swap');
*{margin:0;padding:0;box-sizing:border-box}
/* Splash */
#splash{position:fixed;inset:0;z-index:9999;background:var(--bg);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;
  transition:opacity .5s ease}
#splash.fade-out{opacity:0;pointer-events:none}
.splash-title{font-family:'Cinzel',serif;font-weight:900;font-size:28px;color:var(--gold);
  letter-spacing:4px;text-shadow:0 0 30px rgba(240,192,64,.3)}
@keyframes dotPulse{0%,100%{opacity:.3}50%{opacity:1}}
.splash-loading{font-size:12px;color:var(--dim);letter-spacing:3px;animation:dotPulse 1.2s ease-in-out infinite}
:root{--bg:#0a0e1a;--panel:#111827;--gold:#f0c040;--gold-d:#a08020;
  --blue:#3b82f6;--red:#ef4444;--green:#22c55e;--text:#e2e8f0;--dim:#64748b}
html,body{width:100%;height:100%;background:var(--bg);color:var(--text);
  font-family:'Noto Sans KR',sans-serif;overflow:hidden;
  touch-action:manipulation;-webkit-user-select:none;user-select:none}
#app{width:100%;height:100%;display:flex;flex-direction:column}
#top-bar{height:46px;min-height:46px;background:linear-gradient(180deg,#1a2340,#111827);
  border-bottom:2px solid #1e293b;display:flex;align-items:center;justify-content:space-between;padding:0 8px;z-index:100}
.tb-left,.tb-right{display:flex;align-items:center;gap:6px}
#turn-indicator{font-family:'Cinzel',serif;font-weight:900;font-size:12px;
  letter-spacing:2px;text-transform:uppercase;padding:3px 10px;border-radius:4px;transition:all .3s}
#turn-indicator.player{background:var(--blue);color:#fff}
#turn-indicator.enemy{background:var(--red);color:#fff}
#stage-info{font-size:10px;color:var(--gold);font-weight:700;text-align:center;line-height:1.3}
#stage-info .si-turn{font-size:9px;color:var(--dim)}
.cam-btn{width:32px;height:32px;border-radius:6px;border:1px solid rgba(255,255,255,.15);
  background:rgba(255,255,255,.06);color:var(--text);font-size:14px;font-weight:900;cursor:pointer;
  display:flex;align-items:center;justify-content:center;transition:all .15s}
.cam-btn:hover{background:rgba(255,255,255,.15);border-color:var(--gold)}
.cam-btn:active{transform:scale(.9)}
#btn-end-turn{font-family:'Cinzel',serif;font-weight:700;font-size:11px;
  background:linear-gradient(135deg,var(--gold),#d4a017);color:#1a1a2e;border:none;
  padding:5px 12px;border-radius:4px;cursor:pointer;text-transform:uppercase;letter-spacing:1px;transition:all .2s}
#btn-end-turn:hover{transform:scale(1.05);filter:brightness(1.1)}
#btn-end-turn:disabled{opacity:.4;cursor:default;transform:none}
#map-container{flex:1;overflow:auto;position:relative;cursor:pointer;
  background:radial-gradient(ellipse at 50% 30%,rgba(20,40,80,.4),transparent 70%),var(--bg)}
#iso-world{position:absolute;transition:none}
.iso-tile{position:absolute;pointer-events:none;transition:filter .1s}
.unit-sprite{position:absolute;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;
  pointer-events:none;z-index:10;
  transition:left .32s cubic-bezier(.4,0,.2,1),top .32s cubic-bezier(.4,0,.2,1)}
.unit-sprite .u-icon{font-size:26px;filter:drop-shadow(0 2px 4px rgba(0,0,0,.8));line-height:1}
.unit-sprite.acted{opacity:.45}
.unit-sprite .u-shadow{width:26px;height:7px;background:rgba(0,0,0,.35);border-radius:50%;margin-top:1px}
.hp-bg{width:44px;height:4px;background:#222;border-radius:2px;margin-top:1px;overflow:hidden}
.hp-fill{height:100%;border-radius:2px;transition:width .3s}
.mp-bg{width:44px;height:3px;background:#181818;border-radius:2px;margin-top:2px;overflow:hidden}
.mp-fill{height:100%;border-radius:2px;transition:width .3s}
.unit-sprite.ally .hp-fill{background:#22c55e}
.unit-sprite.enemy .hp-fill{background:var(--red)}
.unit-sprite.enemy .u-icon{filter:drop-shadow(0 0 5px rgba(239,68,68,.6)) drop-shadow(0 2px 4px rgba(0,0,0,.8))}
@keyframes atkShake{0%,100%{transform:translate(0)}25%{transform:translate(-3px,-2px)}50%{transform:translate(3px,2px)}75%{transform:translate(-2px,-1px)}}
.unit-sprite.shaking{animation:atkShake .25s ease}
@keyframes spawnPop{0%{opacity:0;transform:scale(.3) translateY(8px)}60%{opacity:1;transform:scale(1.12) translateY(-2px)}100%{transform:scale(1) translateY(0)}}
.unit-sprite.spawning{animation:spawnPop .4s ease-out}
@keyframes deathDissolve{0%{opacity:1;filter:brightness(1)}30%{opacity:.8;filter:brightness(2) saturate(0)}70%{opacity:.3;filter:brightness(3) saturate(0) blur(2px)}100%{opacity:0;filter:brightness(4) saturate(0) blur(6px);transform:scale(.7)}}
.unit-sprite.dying{animation:deathDissolve .6s ease-out forwards}
@keyframes screenShake{0%,100%{transform:translate(0)}10%{transform:translate(-4px,-3px)}30%{transform:translate(4px,2px)}50%{transform:translate(-3px,3px)}70%{transform:translate(3px,-2px)}90%{transform:translate(-2px,1px)}}
#iso-world.screen-shake{animation:screenShake .3s ease}
@keyframes turnFlash{0%{opacity:0}30%{opacity:1}100%{opacity:0}}
#turn-flash{position:fixed;inset:0;z-index:250;pointer-events:none;opacity:0}
#turn-flash.player-flash{background:radial-gradient(ellipse,rgba(59,130,246,.15),transparent 70%);animation:turnFlash .6s ease-out}
#turn-flash.enemy-flash{background:radial-gradient(ellipse,rgba(239,68,68,.15),transparent 70%);animation:turnFlash .6s ease-out}
@keyframes tilePulse{0%,100%{opacity:.6}50%{opacity:1}}
.iso-tile.hl-move svg polygon:last-of-type,.iso-tile.hl-attack svg polygon:last-of-type,
.iso-tile.hl-heal svg polygon:last-of-type{animation:tilePulse 1.2s ease-in-out infinite}
#vfx-canvas{position:absolute;top:0;left:0;pointer-events:none;z-index:350}
@keyframes buffGlow{0%{filter:brightness(1)}50%{filter:brightness(1.8) drop-shadow(0 0 8px rgba(34,197,94,.6))}100%{filter:brightness(1)}}
.unit-sprite.buff-glow{animation:buffGlow .5s ease}
.float-text{position:absolute;font-family:'Cinzel',serif;font-weight:900;font-size:15px;z-index:400;
  pointer-events:none;animation:isoFloat .9s ease-out forwards;text-shadow:0 1px 4px rgba(0,0,0,.9)}
.float-text.damage{color:#ff4444}.float-text.heal{color:#44ff88}
@keyframes isoFloat{0%{opacity:1;transform:translateY(0) scale(1)}70%{opacity:1;transform:translateY(-22px) scale(1.12)}100%{opacity:0;transform:translateY(-36px) scale(.9)}}
#action-menu{position:absolute;z-index:300;display:none;flex-direction:column;gap:3px;
  background:rgba(17,24,39,.95);border:1px solid var(--gold-d);border-radius:6px;padding:5px;box-shadow:0 4px 20px rgba(0,0,0,.7)}
#action-menu.show{display:flex}
#action-menu button{font-family:'Noto Sans KR',sans-serif;font-weight:700;font-size:11px;
  padding:4px 12px;border:1px solid rgba(255,255,255,.15);border-radius:4px;cursor:pointer;color:#fff;transition:all .15s}
#action-menu button:hover{filter:brightness(1.2)}
#btn-move{background:#10b981}#btn-attack{background:#ef4444}#btn-skill{background:#7c3aed}#btn-item{background:#f59e0b}#btn-dash{background:var(--blue)}#btn-cancel{background:#4b5563}
#info-panel{height:96px;min-height:96px;background:linear-gradient(0deg,#0d1117,var(--panel));
  border-top:2px solid #1e293b;display:flex;align-items:center;padding:0 8px;gap:8px;z-index:100;overflow-x:auto}
.info-card{min-width:115px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);
  border-radius:8px;padding:6px 8px;display:flex;flex-direction:column;gap:2px}
.info-card .ic-top{display:flex;align-items:center;gap:4px;font-size:12px}
.info-card .ic-top .ic-icon{font-size:15px}.info-card .ic-top .ic-name{font-weight:700;font-size:10px}
.info-card .ic-top .ic-class{font-size:9px;color:var(--dim)}
.info-card .ic-stats{display:grid;grid-template-columns:1fr 1fr;gap:1px 6px;font-size:9px;color:var(--dim)}
.info-card .ic-stats span b{color:var(--text)}
.info-card.ally-card{border-color:rgba(59,130,246,.3)}.info-card.enemy-card{border-color:rgba(239,68,68,.3)}
#modal-overlay{position:fixed;inset:0;z-index:500;background:rgba(0,0,0,.75);
  display:none;align-items:center;justify-content:center;backdrop-filter:blur(4px)}
#modal-overlay.show{display:flex}
#modal-box{background:var(--panel);border:2px solid var(--gold-d);border-radius:12px;
  padding:28px 32px;text-align:center;box-shadow:0 0 60px rgba(240,192,64,.15);max-width:340px;width:90%}
#modal-title{font-family:'Cinzel',serif;font-weight:900;font-size:24px;margin-bottom:8px}
#modal-title.win{color:var(--gold)}#modal-title.lose{color:var(--red)}
#modal-sub{color:var(--dim);font-size:12px;margin-bottom:16px}
.modal-btn{font-family:'Cinzel',serif;font-weight:700;font-size:12px;
  background:linear-gradient(135deg,var(--gold),#d4a017);color:#1a1a2e;border:none;
  padding:8px 22px;border-radius:6px;cursor:pointer;text-transform:uppercase;letter-spacing:1px;transition:all .2s;margin:3px}
.modal-btn:hover{transform:scale(1.05)}.modal-btn.secondary{background:linear-gradient(135deg,#475569,#334155);color:#e2e8f0}
/* Turn End Confirm */
#turn-confirm{position:fixed;inset:0;z-index:450;background:rgba(0,0,0,.5);
  display:none;align-items:center;justify-content:center;backdrop-filter:blur(2px)}
#turn-confirm.show{display:flex}
#tc-box{background:var(--panel);border:2px solid var(--blue);border-radius:10px;
  padding:16px 20px;text-align:center;box-shadow:0 0 30px rgba(59,130,246,.2);max-width:260px;width:85%}
#tc-box .tc-msg{font-size:12px;font-weight:700;color:var(--text);margin-bottom:12px}
#tc-box .tc-btns{display:flex;gap:6px;justify-content:center;margin-bottom:10px}
#tc-box .tc-btns button{font-family:'Noto Sans KR',sans-serif;font-weight:700;font-size:11px;
  padding:6px 16px;border-radius:5px;cursor:pointer;border:none;transition:all .15s}
#tc-box .tc-btns .tc-yes{background:var(--blue);color:#fff}
#tc-box .tc-btns .tc-no{background:#475569;color:#e2e8f0}
#tc-box .tc-btns button:hover{transform:scale(1.05)}
#tc-box .tc-skip{display:flex;align-items:center;justify-content:center;gap:4px;
  font-size:10px;color:var(--dim);cursor:pointer;user-select:none}
#tc-box .tc-skip input{width:13px;height:13px;accent-color:var(--blue);cursor:pointer}
.stage-subtitle{font-size:11px;color:var(--dim);margin-bottom:12px;text-align:center}
#stage-list{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;max-width:380px;padding:0 16px}
.stage-btn{width:96px;padding:12px 6px;border-radius:10px;background:rgba(255,255,255,.05);border:2px solid rgba(255,255,255,.1);
  cursor:pointer;text-align:center;transition:all .2s;color:var(--text)}
.stage-btn:hover{border-color:var(--gold);transform:translateY(-2px)}
.stage-btn.locked{opacity:.35;cursor:default;pointer-events:none}
.stage-btn.cleared{border-color:var(--green);background:rgba(34,197,94,.08)}
.stage-btn .sb-num{font-family:'Cinzel',serif;font-weight:900;font-size:16px;color:var(--gold)}
.stage-btn.locked .sb-num{color:var(--dim)}
.stage-btn .sb-name{font-size:10px;margin-top:3px;color:var(--dim)}
.stage-btn .sb-stars{font-size:12px;margin-top:3px}.stage-btn .sb-info{font-size:9px;margin-top:2px;color:var(--dim)}
body[data-page="party-select"] #content{overflow:hidden;padding:8px 12px}
.ps-sub{font-size:12px;color:var(--dim);margin-bottom:4px;text-align:center;flex-shrink:0}
/* ── 좌우 분할 레이아웃 ── */
.ps-layout{display:flex;gap:14px;flex:1;overflow:hidden;width:100%;max-width:560px}
.ps-left{width:80px;flex-shrink:0;display:flex;flex-direction:column;overflow:hidden}
.ps-counter{font-size:12px;color:var(--blue);font-weight:700;text-align:center;margin-bottom:3px;flex-shrink:0}
.ps-party{display:flex;flex-direction:column;gap:2px;flex:1;overflow-y:auto;
  scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.1) transparent}
.ps-party::-webkit-scrollbar{width:2px}
.ps-party::-webkit-scrollbar-thumb{background:rgba(255,255,255,.15);border-radius:2px}
.party-slot{width:100%;min-height:36px;flex-shrink:0;background:rgba(255,255,255,.04);border:1.5px dashed rgba(255,255,255,.12);
  border-radius:7px;display:flex;align-items:center;gap:3px;padding:2px 4px;
  transition:all .2s;cursor:pointer;position:relative}
.party-slot .ps-num{font-size:10px;font-weight:900;color:var(--dim);width:13px;text-align:center;flex-shrink:0}
.party-slot.filled{border-style:solid;border-color:var(--blue);background:rgba(59,130,246,.08)}
.party-slot.filled:hover{border-color:var(--red);background:rgba(239,68,68,.08)}
.party-slot .ps-lv{font-size:9px;font-weight:900;color:var(--gold);margin-left:auto;flex-shrink:0}
.party-slot .ps-x{position:absolute;top:-3px;right:-3px;background:var(--red);color:#fff;
  width:14px;height:14px;border-radius:50%;font-size:10px;font-weight:900;display:none;align-items:center;justify-content:center}
.party-slot.filled:hover .ps-x{display:flex}
/* ── 우측: 탭 + 로스터 리스트 ── */
.ps-right{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}
.ps-tabs{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:5px;flex-shrink:0}
.ps-tab{font-size:12px;font-weight:700;padding:3px 9px;border-radius:12px;border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.04);color:var(--dim);cursor:pointer;transition:all .15s;white-space:nowrap}
.ps-tab:hover{border-color:var(--blue);color:var(--text)}
.ps-tab.active{border-color:var(--gold);background:rgba(240,192,64,.12);color:var(--gold)}
.ps-roster{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:3px;
  scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.1) transparent}
.ps-roster::-webkit-scrollbar{width:3px}
.ps-roster::-webkit-scrollbar-thumb{background:rgba(255,255,255,.15);border-radius:2px}
/* ── 로스터 리스트 행 ── */
.rl-row{display:flex;align-items:center;gap:7px;padding:6px 8px;
  background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);border-radius:8px;
  cursor:pointer;transition:all .15s;flex-shrink:0}
.rl-row:hover{border-color:var(--blue);background:rgba(59,130,246,.06)}
.rl-row.selected{border-color:var(--gold);background:rgba(240,192,64,.08)}
.rl-icon{width:30px;height:30px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.rl-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}
.rl-top{display:flex;align-items:baseline;gap:5px}
.rl-name{font-weight:900;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rl-lv{font-size:11px;color:var(--dim);flex-shrink:0}
.rl-grade{font-weight:900;font-size:12px;text-shadow:0 0 4px rgba(0,0,0,.5);flex-shrink:0;margin-left:auto}
.rl-stats{font-size:11px;color:var(--dim);display:flex;flex-wrap:wrap;gap:1px 5px;line-height:1.3}
.rl-stats b{color:var(--text)}
.rl-pot{font-size:10px;color:#64748b;line-height:1.2}
.rl-exp{height:3px;background:rgba(255,255,255,.08);border-radius:2px;overflow:hidden;margin-top:1px}
.rl-exp-fill{height:100%;background:linear-gradient(90deg,#a78bfa,#7c3aed);border-radius:2px}
.rl-actions{display:flex;gap:6px;flex-shrink:0}
.rl-btn{width:26px;height:26px;border-radius:6px;border:none;font-size:15px;font-weight:900;
  cursor:pointer;color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s}
.rl-btn.add{background:var(--blue)}
.rl-btn.chk{background:var(--gold);color:#1a1a2e}
.rl-btn:hover{transform:scale(1.1)}
.rl-release{font-size:11px;padding:4px 8px;border:none;border-radius:4px;
  background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;font-weight:600;cursor:pointer;
  transition:all .15s;flex-shrink:0}
.rl-release:hover{transform:scale(1.05);box-shadow:0 2px 4px rgba(239,68,68,.4)}
.rl-release:active{transform:scale(.95)}
/* ── 출격 버튼 ── */
.ps-start{font-family:'Cinzel',serif;font-weight:900;font-size:15px;
  background:linear-gradient(135deg,var(--gold),#d4a017);color:#1a1a2e;border:none;
  padding:8px 28px;border-radius:8px;cursor:pointer;text-transform:uppercase;letter-spacing:2px;transition:all .2s;
  margin-top:6px;flex-shrink:0}
.ps-start:hover{transform:scale(1.05)}.ps-start:disabled{opacity:.3;cursor:default;transform:none}
#enemy-banner{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);
  font-family:'Cinzel',serif;font-weight:900;font-size:22px;color:var(--red);
  text-shadow:0 0 20px rgba(239,68,68,.5);z-index:300;opacity:0;pointer-events:none;transition:opacity .3s;letter-spacing:4px}
#enemy-banner.show{opacity:1}
#wave-banner{position:fixed;top:42%;left:50%;transform:translate(-50%,-50%);
  font-family:'Cinzel',serif;font-weight:900;font-size:16px;color:var(--gold);
  text-shadow:0 0 16px rgba(240,192,64,.4);z-index:300;opacity:0;pointer-events:none;transition:opacity .4s;letter-spacing:3px}
#wave-banner.show{opacity:1}
#cam-dir{position:fixed;bottom:108px;right:10px;z-index:150;display:flex;flex-direction:column;align-items:center;gap:2px}
#cam-dir .cd-arrow{font-size:18px;color:var(--gold);text-shadow:0 0 8px rgba(240,192,64,.4)}
#cam-dir .cd-label{font-size:8px;color:var(--dim);font-weight:700;letter-spacing:1px}
/* Ally Nav Panel */
#ally-nav{position:fixed;top:54px;right:6px;z-index:200;
  display:flex;flex-direction:column;align-items:flex-end;gap:2px;max-height:calc(100vh - 160px);overflow-y:auto;
  scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.1) transparent}
#ally-nav::-webkit-scrollbar{width:2px}
#ally-nav::-webkit-scrollbar-thumb{background:rgba(255,255,255,.15);border-radius:2px}
.an-unit{display:inline-flex;align-items:center;gap:0;padding:2px;
  background:rgba(10,14,26,.88);border:1.5px solid rgba(59,130,246,.2);border-radius:5px;
  cursor:pointer;transition:all .15s;height:28px}
.an-unit:hover{border-color:var(--blue);background:rgba(59,130,246,.1)}
.an-unit.selected{background:rgba(240,192,64,.1)}
.an-unit.dead{pointer-events:none;border-color:rgba(255,255,255,.05)}
.an-buffs{display:flex;gap:2px;align-items:center;justify-content:flex-end}
.an-buffs:not(:empty){padding:0 3px}
.an-buff{position:relative;width:16px;height:16px;border-radius:3px;font-size:10px;
  display:flex;align-items:center;justify-content:center;line-height:1}
.an-buff.buff{background:rgba(34,197,94,.2);border:1px solid rgba(34,197,94,.3)}
.an-buff.debuff{background:rgba(239,68,68,.2);border:1px solid rgba(239,68,68,.3)}
.an-buff.neutral{background:rgba(59,130,246,.15);border:1px solid rgba(59,130,246,.25)}
.an-buff .bf-turn{position:absolute;bottom:-1px;right:0;font-size:7px;font-weight:900;
  color:#fff;text-shadow:0 0 2px #000,0 0 2px #000;line-height:1}
.an-vhp{width:4px;height:22px;background:rgba(255,255,255,.1);border-radius:2px;
  overflow:hidden;display:flex;flex-direction:column;justify-content:flex-end;flex-shrink:0}
.an-vhp-fill{width:100%;border-radius:2px;transition:height .3s;min-height:0}
.an-vres{width:3px;height:22px;background:rgba(255,255,255,.08);border-radius:2px;
  overflow:hidden;display:flex;flex-direction:column;justify-content:flex-end;flex-shrink:0;margin-right:2px}
.an-vres-fill{width:100%;border-radius:2px;transition:height .3s;min-height:0}
.an-icon{width:22px;height:22px;border-radius:4px;background:rgba(255,255,255,.06);
  display:flex;align-items:center;justify-content:center;font-size:12px;flex-shrink:0;
  border:1px solid rgba(255,255,255,.1);margin-left:4px}
.an-unit.selected .an-icon{border-color:var(--gold);background:rgba(240,192,64,.08)}

/* Minimap */
#minimap{position:fixed;top:54px;left:8px;z-index:200;border:2px solid rgba(255,255,255,.15);
  border-radius:6px;background:rgba(10,14,26,.85);box-shadow:0 2px 12px rgba(0,0,0,.5);
  cursor:pointer;overflow:hidden}
#minimap canvas{display:block}
#minimap .mm-vp{position:absolute;border:1.5px solid var(--gold);pointer-events:none;border-radius:1px;
  box-shadow:0 0 6px rgba(240,192,64,.3)}
/* Settings */
#settings-btn{position:fixed;bottom:110px;left:8px;z-index:1001;width:36px;height:36px;
  border-radius:50%;border:1.5px solid rgba(255,255,255,.15);background:rgba(17,24,39,.85);
  color:var(--dim);font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;
  box-shadow:0 2px 10px rgba(0,0,0,.4);transition:all .2s;backdrop-filter:blur(4px)}
#settings-btn:hover{background:rgba(30,41,59,.95);border-color:var(--gold);color:var(--gold)}
#settings-btn:focus{outline:none;border-color:rgba(255,255,255,.15)}
#settings-panel{position:fixed;bottom:110px;left:52px;z-index:1001;width:260px;
  background:rgba(17,24,39,.96);border:1.5px solid rgba(255,255,255,.12);border-radius:10px;
  padding:14px 16px;box-shadow:0 4px 24px rgba(0,0,0,.6);backdrop-filter:blur(8px);
  display:none;flex-direction:column;gap:12px}
#settings-panel.show{display:flex}
#settings-backdrop{position:fixed;inset:0;z-index:1000;display:none}
#settings-backdrop.show{display:block}
#settings-panel .sp-title{font-family:'Cinzel',serif;font-weight:700;font-size:13px;color:var(--gold);
  letter-spacing:1px;border-bottom:1px solid rgba(255,255,255,.08);padding-bottom:6px;margin-bottom:2px}
.sp-row{display:flex;align-items:center;justify-content:space-between;gap:8px}
.sp-row .sp-label{font-size:11px;font-weight:700;color:var(--text);white-space:nowrap;min-width:60px}
.sp-row .sp-val{font-size:10px;color:var(--dim);min-width:28px;text-align:right}
.sp-row input[type="range"]{flex:1;height:4px;accent-color:var(--gold);cursor:pointer;
  -webkit-appearance:none;appearance:none;background:rgba(255,255,255,.1);border-radius:2px;outline:none}
.sp-row input[type="range"]::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;
  border-radius:50%;background:var(--gold);cursor:pointer;border:2px solid #1a1a2e}
.sp-toggle{display:flex;align-items:center;gap:8px}
.sp-tlabel{font-size:11px;font-weight:700;color:var(--text);flex:1;cursor:default}
.sp-switch{position:relative;width:38px;height:20px;flex-shrink:0}
.sp-switch input{opacity:0;width:0;height:0}
.sp-switch .slider{position:absolute;inset:0;background:rgba(255,255,255,.1);border-radius:10px;
  transition:.2s;cursor:pointer}
.sp-switch .slider:before{content:'';position:absolute;width:16px;height:16px;border-radius:50%;
  left:2px;bottom:2px;background:#64748b;transition:.2s}
.sp-switch input:checked+.slider{background:rgba(240,192,64,.3)}
.sp-switch input:checked+.slider:before{transform:translateX(18px);background:var(--gold)}
.sp-divider{height:1px;background:rgba(255,255,255,.06)}
.sp-btn-row{display:flex;gap:6px;justify-content:center;margin-top:2px}
.sp-btn{font-family:'Noto Sans KR',sans-serif;font-weight:700;font-size:10px;
  padding:5px 14px;border-radius:5px;cursor:pointer;border:1px solid rgba(255,255,255,.12);
  color:var(--text);background:rgba(255,255,255,.06);transition:all .15s}
.sp-btn:hover{background:rgba(255,255,255,.12);border-color:var(--gold)}
.sp-btn.danger{color:var(--red);border-color:rgba(239,68,68,.3)}
.sp-btn.danger:hover{background:rgba(239,68,68,.1)}
@media(max-width:480px){#top-bar{height:40px;min-height:40px}#info-panel{height:84px;min-height:84px}
  .cam-btn{width:28px;height:28px;font-size:12px}#turn-indicator{font-size:10px;padding:2px 8px}#btn-end-turn{font-size:10px;padding:4px 8px}}

/* ═══ PC Version (1024px+) ═══ */
@media(min-width:1024px){
  /* Top Bar */
  #top-bar{height:58px;min-height:58px;padding:0 12px}
  .tb-left,.tb-right{gap:9px}
  #turn-indicator{font-size:16px;padding:4px 14px;border-radius:5px;letter-spacing:2px}
  #stage-info{font-size:14px}
  #stage-info .si-turn{font-size:12px}
  .cam-btn{width:42px;height:42px;font-size:18px;border-radius:8px}
  #btn-end-turn{font-size:14px;padding:7px 18px;border-radius:5px;letter-spacing:1px}

  /* Info Panel */
  #info-panel{height:128px;min-height:128px;padding:0 12px;gap:12px}
  .info-card{min-width:160px;border-radius:10px;padding:9px 12px;gap:3px}
  .info-card .ic-top{gap:6px;font-size:16px}
  .info-card .ic-top .ic-icon{font-size:20px}
  .info-card .ic-top .ic-name{font-size:14px}
  .info-card .ic-top .ic-class{font-size:11px}
  .info-card .ic-stats{gap:2px 9px;font-size:12px}

  /* Action Menu */
  #action-menu{gap:4px;border-radius:8px;padding:7px}
  #action-menu button{font-size:14px;padding:6px 18px;border-radius:5px}

  /* Ally Nav */
  #ally-nav{top:66px;right:10px;gap:3px}
  #ally-nav::-webkit-scrollbar{width:3px}
  .an-unit{padding:3px;border-radius:6px;height:38px}
  .an-buffs{gap:3px}
  .an-buffs:not(:empty){padding:0 4px}
  .an-buff{width:22px;height:22px;border-radius:4px;font-size:13px}
  .an-buff .bf-turn{font-size:9px}
  .an-vhp{width:5px;height:30px}
  .an-vres{width:4px;height:30px;margin-right:3px}
  .an-icon{width:30px;height:30px;border-radius:5px;font-size:17px;margin-left:5px}

  /* Minimap */
  #minimap{top:66px;left:12px;border-radius:8px}

  /* Settings */
  #settings-btn{bottom:142px;left:12px;width:44px;height:44px;font-size:22px;border-radius:50%}
  #settings-panel{bottom:142px;left:64px;width:300px;padding:16px 20px;gap:14px;border-radius:12px}
  #settings-panel .sp-title{font-size:15px}
  .sp-row .sp-label{font-size:13px}.sp-row .sp-val{font-size:12px}
  .sp-tlabel{font-size:13px}
  .sp-btn{font-size:12px;padding:6px 16px}

  /* Camera Direction */
  #cam-dir{bottom:142px;right:14px;gap:3px}
  #cam-dir .cd-arrow{font-size:24px}
  #cam-dir .cd-label{font-size:11px;letter-spacing:1px}

  /* Float Text */
  .float-text{font-size:19px}

  /* Enemy / Wave Banners */
  #enemy-banner{font-size:30px;letter-spacing:6px}
  #wave-banner{font-size:22px;letter-spacing:4px}

  /* Modal */
  #modal-box{padding:38px 44px;border-radius:14px;max-width:420px}
  #modal-title{font-size:32px;margin-bottom:10px}
  #modal-sub{font-size:16px;margin-bottom:22px}
  .modal-btn{font-size:16px;padding:10px 30px;border-radius:8px;margin:4px}

  /* Turn Confirm */
  #tc-box{border-radius:12px;padding:22px 28px;max-width:340px}
  #tc-box .tc-msg{font-size:16px;margin-bottom:16px}
  #tc-box .tc-btns{gap:9px;margin-bottom:12px}
  #tc-box .tc-btns button{font-size:14px;padding:8px 22px;border-radius:6px}
  #tc-box .tc-skip{gap:6px;font-size:13px}
  #tc-box .tc-skip input{width:16px;height:16px}

  /* Stage Select */
  .stage-subtitle{font-size:15px}
  #stage-list{gap:14px;max-width:540px;padding:0 24px}
  .stage-btn{width:128px;padding:16px 9px;border-radius:12px}
  .stage-btn .sb-num{font-size:22px}
  .stage-btn .sb-name{font-size:13px;margin-top:4px}
  .stage-btn .sb-stars{font-size:16px;margin-top:4px}
  .stage-btn .sb-info{font-size:11px;margin-top:3px}

  /* Party Select */
  body[data-page="party-select"] #content{padding:14px 20px}
  .ps-sub{font-size:14px;margin-bottom:8px}
  .ps-layout{max-width:720px;gap:24px}
  .ps-left{width:110px}
  .ps-counter{font-size:14px}
  .party-slot{min-height:44px;border-radius:10px;padding:3px 8px;gap:6px}
  .party-slot .ps-num{font-size:12px;width:16px}
  .party-slot .ps-lv{font-size:11px}
  .party-slot .ps-x{top:-4px;right:-4px;width:16px;height:16px;font-size:11px}
  .ps-tabs{gap:6px;margin-bottom:8px}
  .ps-tab{font-size:13px;padding:5px 14px}
  .rl-row{padding:8px 12px;gap:10px}
  .rl-icon{width:36px;height:36px}
  .rl-name{font-size:15px}
  .rl-lv{font-size:13px}
  .rl-grade{font-size:14px}
  .rl-stats{font-size:12px;gap:2px 8px}
  .rl-pot{font-size:11px}
  .rl-exp{height:4px}
  .rl-btn{width:32px;height:32px;font-size:18px;border-radius:8px}
  .ps-start{font-size:18px;padding:12px 40px;border-radius:10px;letter-spacing:2px}
}
/* ═══ Full-Screen Utility (battle only) ═══ */
.full-screen{position:fixed;inset:0;z-index:600;
  background:radial-gradient(ellipse at 50% 30%,#1a2340,#0a0e1a);
  display:none;flex-direction:column;align-items:center;overflow-y:auto;padding:16px}
.full-screen.show{display:flex}
.full-screen.hidden{display:none}

/* ═══ Common Layout (non-battle) ═══ */
body:not([data-page="battle"]){display:flex;flex-direction:column;height:100dvh;overflow:hidden}
#top-nav{height:48px;flex-shrink:0;display:flex;align-items:center;padding:0 12px;
  background:var(--panel);border-bottom:1px solid rgba(255,255,255,.08);z-index:10}
#nav-back{width:36px;height:36px;background:none;border:none;color:var(--text);font-size:18px;cursor:pointer}
#nav-back.hidden{visibility:hidden}
#nav-title{flex:1;text-align:center;font-family:'Cinzel',serif;font-weight:900;font-size:16px;color:var(--gold);letter-spacing:2px}
#nav-settings{width:36px;height:36px;background:none;border:none;color:var(--dim);font-size:18px;cursor:pointer}
#nav-settings.hidden{visibility:hidden}
#content{flex:1;overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column;align-items:center;padding:16px;
  background:radial-gradient(ellipse at 50% 30%,#1a2340,#0a0e1a);position:relative}
#bottom-nav{height:56px;flex-shrink:0;display:flex;background:var(--panel);border-top:1px solid rgba(255,255,255,.08);z-index:10}
.bnav-tab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;
  background:none;border:none;color:var(--dim);cursor:pointer;transition:color .2s}
.bnav-tab.active{color:var(--gold)}
.bnav-icon{font-size:20px}
.bnav-label{font-size:10px;font-weight:700}

/* ═══ Lobby ═══ */
.lobby-bg{position:absolute;inset:0;background:radial-gradient(ellipse at 50% 20%,rgba(240,192,64,.08),transparent 60%),
  radial-gradient(ellipse at 30% 80%,rgba(59,130,246,.06),transparent 50%),
  radial-gradient(ellipse at 70% 70%,rgba(239,68,68,.04),transparent 50%);pointer-events:none}
.lobby-content{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;gap:20px;z-index:1; width: 100%;}
.lobby-gold{font-size:14px;color:var(--gold);font-weight:700;
  background:rgba(240,192,64,.08);border:1px solid rgba(240,192,64,.2);border-radius:20px;padding:4px 16px}

/* ═══ Clan Hideout ═══ */
.clan-hideout{position:relative;width:100%;max-width:420px;height:100%;border-radius:12px;overflow:hidden;
  background:
    radial-gradient(circle at 50% 50%,rgba(255,160,40,.15),transparent 60%),
    repeating-linear-gradient(90deg,rgba(255,255,255,.02) 0px,rgba(255,255,255,.02) 1px,transparent 1px,transparent 24px),
    linear-gradient(180deg,#12100e 0%,#1a1410 30%,#221a12 60%,#2a1f15 100%);
  border:1px solid rgba(255,255,255,.08);
  box-shadow:inset 0 -30px 40px -20px rgba(255,140,40,.06),0 4px 20px rgba(0,0,0,.4)}
.clan-hideout::before{content:'';position:absolute;inset:0;
  background:
    linear-gradient(90deg,rgba(0,0,0,.35) 0%,transparent 15%,transparent 85%,rgba(0,0,0,.35) 100%),
    linear-gradient(180deg,rgba(0,0,0,.5) 0%,transparent 40%);
  pointer-events:none;z-index:1}
.hideout-torch{position:absolute;top:14%;width:6px;height:18px;border-radius:50% 50% 30% 30%;z-index:2;
  background:radial-gradient(ellipse,#ff9922,#ff6600 60%,transparent 100%);
  box-shadow:0 0 12px 4px rgba(255,140,40,.35),0 0 30px 8px rgba(255,100,20,.15);
  animation:torchFlicker 1.5s ease-in-out infinite alternate}
.hideout-torch.t-left{left:8%;top:50%;transform:translateY(-50%)}
.hideout-torch.t-right{right:8%;top:50%;transform:translateY(-50%)}
.hideout-torch.t-top-left{left:10%;top:12%}
.hideout-torch.t-top-right{right:10%;top:12%}
.hideout-torch.t-bottom-left{left:10%;bottom:10%;top:auto}
.hideout-torch.t-bottom-right{right:10%;bottom:10%;top:auto}
@keyframes torchFlicker{0%{opacity:.7;transform:scaleY(.9)}50%{opacity:1;transform:scaleY(1.1)}100%{opacity:.8;transform:scaleY(.95)}}
.hideout-table{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:140px;height:140px;border-radius:50%;z-index:4;
  background:radial-gradient(ellipse at 30% 30%,#8b6f47,#5c4a2f);
  border:3px solid #3d2817;box-shadow:0 8px 16px rgba(0,0,0,.6),inset 0 1px 2px rgba(255,255,255,.1),inset 0 -2px 4px rgba(0,0,0,.5)}
.hideout-unit{position:absolute;z-index:3;display:flex;flex-direction:column;align-items:center;
  filter:drop-shadow(0 3px 4px rgba(0,0,0,.7));
  transition:left 3.5s ease-in-out,top 3.5s ease-in-out}
.hideout-unit .hu-shadow{width:20px;height:5px;background:rgba(0,0,0,.3);border-radius:50%;margin-top:1px}
.hideout-unit .hu-name{font-size:12px;color:rgba(255,255,255,.5);margin-top:1px;white-space:nowrap;text-shadow:0 1px 2px #000;font-weight:700}
@keyframes hideoutFloat{0%{transform:translateY(-8px) scale(1.01)}50%{transform:translateY(-12px) scale(1.03)}100%{transform:translateY(-8px) scale(1.01)}}
@keyframes hideoutIdle{0%,100%{transform:translateY(0)}50%{transform:translateY(-3px)}}
.hideout-label{position:absolute;top:8px;left:50%;transform:translateX(-50%);z-index:4;
  font-size:9px;color:rgba(255,255,255,.35);letter-spacing:2px;font-weight:700;white-space:nowrap}

/* ═══ Screen Common ═══ */
.screen-title{font-family:'Cinzel',serif;font-weight:900;font-size:20px;color:var(--gold);letter-spacing:2px;margin-bottom:4px}
.screen-sub{font-size:11px;color:var(--dim);margin-bottom:8px;text-align:center}
.screen-gold{font-size:12px;color:var(--gold);font-weight:700;margin-bottom:12px;
  background:rgba(240,192,64,.08);border:1px solid rgba(240,192,64,.15);border-radius:14px;padding:3px 12px}
/* ═══ Card List (Generic) ═══ */
.card-list{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;max-width:400px;margin-bottom:16px;min-height:60px}

/* ═══ Shop List (2-column grid) ═══ */
#shop-list{display:grid !important;grid-template-columns:repeat(2,1fr);gap:10px;width:100%;max-width:330px;margin:0 auto 16px;min-height:60px}

/* ═══ Sanctuary List (Vertical flex) ═══ */
#sanc-list{display:flex !important;flex-direction:column;align-items:center;gap:10px;max-width:360px;margin:0 auto 16px}

/* ═══ Sanctuary ═══ */
.sanc-card{width:100%;max-width:340px;display:flex;align-items:center;gap:10px;
  background:rgba(255,255,255,.04);border:1px solid rgba(168,85,247,.2);border-radius:10px;padding:10px 12px}
.sanc-icon{font-size:28px;flex-shrink:0}
.sanc-info{flex:1}
.sanc-name{font-weight:700;font-size:12px}
.sanc-stats{font-size:10px;color:var(--dim);margin-top:2px}
.sanc-btn{font-weight:700;font-size:11px;padding:6px 12px;border-radius:6px;border:none;cursor:pointer;
  background:linear-gradient(135deg,#a855f7,#7c3aed);color:#fff;transition:all .15s;white-space:nowrap}
.sanc-btn:hover{transform:scale(1.05)}.sanc-btn.disabled{opacity:.3;cursor:default}

/* ═══ Shop HUD ═══ */
.shop-hud{width:100%;display:flex;justify-content:center;padding:12px 0 8px;margin-bottom:12px}
.shop-hud-gold{display:inline-flex;align-items:center;font-size:13px;color:var(--gold);font-weight:700;
  background:rgba(240,192,64,.08);border:1px solid rgba(240,192,64,.2);border-radius:16px;padding:3px 12px}
.shop-info-row{display:flex;align-items:baseline;justify-content:space-between;width:100%;max-width:330px;margin-bottom:8px}
.shop-info-title{font-size:14px;font-weight:900;color:var(--text)}
.shop-info-timer{font-size:11px;font-weight:700;color:#60a5fa}

/* ═══ Sanctuary HUD ═══ */
.sanc-hud{display:flex;justify-content:center;padding:12px 0 8px;margin-bottom:12px}
.sanc-hud-gold{font-size:13px;color:var(--gold);font-weight:700;
  background:rgba(240,192,64,.08);border:1px solid rgba(240,192,64,.2);border-radius:16px;padding:3px 12px}
.sanc-info-row{border-top:1px solid rgba(255,255,255,.15);border-bottom:1px solid rgba(255,255,255,.15);
  display:flex;flex-direction:column;align-items:center;width:100%;max-width:330px;padding:12px 0;margin-bottom:8px}
.sanc-info-title{font-size:14px;font-weight:900;color:var(--text)}

/* ═══ Shop ═══ */
.shop-card{width:100%;background:rgba(255,255,255,.04);border:2px solid rgba(34,197,94,.15);
  border-radius:10px;padding:10px 8px;text-align:center;position:relative;transition:all .2s}
.shop-card:hover{border-color:var(--green);transform:translateY(-2px)}
.shop-card.sold{opacity:.4;pointer-events:none}
.shop-grade{position:absolute;top:4px;right:6px;font-weight:900;font-size:12px;text-shadow:0 0 6px rgba(0,0,0,.5)}
.shop-icon{font-size:28px;margin-bottom:4px}
.shop-name{font-weight:900;font-size:12px;color:var(--text)}
.shop-cls{font-size:9px;color:var(--dim);margin-top:2px}
.shop-stats{font-size:9px;color:var(--dim);margin-top:3px}
.shop-pot{font-size:8px;color:#64748b;margin-top:3px}
.shop-btn{font-weight:700;font-size:10px;padding:5px 12px;border-radius:5px;border:none;cursor:pointer;
  background:linear-gradient(135deg,var(--green),#16a34a);color:#fff;margin-top:6px;transition:all .15s}
.shop-btn:hover{transform:scale(1.05)}.shop-btn.disabled{opacity:.3;cursor:default}
.shop-btn.sold-btn{background:#475569}

/* ═══ Class Change Scroll Card ═══ */
.shop-card.cc-card{border-color:rgba(147,51,234,.2)}
.shop-card.cc-card:hover{border-color:#9333ea}
.shop-btn.cc-btn{background:linear-gradient(135deg,#9333ea,#7c3aed)}

/* ═══ Class Selection Grid ═══ */
.class-select-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:8px;margin-top:8px}
.cs-card{background:rgba(255,255,255,.04);border:2px solid rgba(147,51,234,.15);border-radius:8px;
  padding:10px 6px;text-align:center;cursor:pointer;transition:all .2s}
.cs-card:hover{border-color:#9333ea;transform:translateY(-2px);background:rgba(147,51,234,.1)}
.cs-icon{font-size:28px;margin-bottom:4px}
.cs-name{font-weight:900;font-size:11px;color:var(--text);margin-bottom:3px}
.cs-stats{font-size:8px;color:var(--dim);margin-bottom:2px}
.cs-role{font-size:7px;color:#64748b}

/* ═══ EXP Bar (Party Card) ═══ */
.cc-exp{display:flex;align-items:center;gap:4px;margin-top:3px}
.cc-exp-bar{flex:1;height:4px;background:rgba(255,255,255,.1);border-radius:2px;overflow:hidden}
.cc-exp-fill{height:100%;background:linear-gradient(90deg,#a78bfa,#7c3aed);border-radius:2px;transition:width .3s}
.cc-exp-txt{font-size:7px;color:#a78bfa;min-width:30px;text-align:right}

/* ═══ Release Button (Party Card) ═══ */
.cc-release-btn{font-weight:700;font-size:9px;padding:4px 10px;margin:4px 0 0 0;border:none;
  border-radius:4px;background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;cursor:pointer;
  transition:all .15s;box-shadow:0 1px 2px rgba(0,0,0,.2)}
.cc-release-btn:hover{transform:scale(1.05);box-shadow:0 2px 4px rgba(239,68,68,.4)}
.cc-release-btn:active{transform:scale(.95)}

/* ═══ Potion Card ═══ */
.potion-card{border-color:rgba(167,139,250,.2)!important}
.potion-card:hover{border-color:#a78bfa!important}
.potion-btn{background:linear-gradient(135deg,#a78bfa,#7c3aed)!important}

/* ═══ Shop Tabs ═══ */
.shop-tabs-wrapper{width:100%;display:flex;justify-content:center;padding:8px 0;border-bottom:1px solid rgba(255,255,255,.05)}
.shop-tabs{display:flex;gap:6px;max-width:330px;width:100%}
.shop-tab-btn{flex:1;padding:10px 6px;font-size:11px;font-weight:700;color:var(--dim);background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);border-radius:6px;cursor:pointer;transition:all .2s}
.shop-tab-btn:hover{color:var(--text);background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.15)}
.shop-tab-btn.active{color:#fff;background:rgba(96,165,250,.2);border-color:#60a5fa}

/* ═══ Potion Modal ═══ */
.potion-target-list{display:flex;flex-direction:column;gap:6px;max-height:200px;overflow-y:auto;margin-top:4px}
.pt-btn{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:8px;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);cursor:pointer;transition:all .15s}
.pt-btn:hover{border-color:var(--gold);background:rgba(240,192,64,.08)}
.pt-btn.pt-max{opacity:.4;cursor:default;pointer-events:none}
.pt-icon{font-size:18px}.pt-info{flex:1;font-size:11px;font-weight:700;text-align:left}
.pt-exp{font-size:9px;color:#a78bfa}

/* ═══ Class Icon (Emoji) ═══ */
.cls-icon{display:inline-block;vertical-align:middle;line-height:1}

/* ═══ Stealth (Assassin) ═══ */
.unit-sprite.stealthed{opacity:.5;filter:drop-shadow(0 0 6px rgba(139,92,246,.5))}
.unit-sprite.stealthed .u-icon{animation:stealthPulse 2s ease-in-out infinite}
@keyframes stealthPulse{0%,100%{opacity:.4}50%{opacity:.7}}

/* ═══ Stunned (Trap/Immobilized) ═══ */
.unit-sprite.stunned{filter:grayscale(1) brightness(0.85)}
.unit-sprite.stunned .u-icon{filter:drop-shadow(0 0 4px rgba(255,100,100,.8))}
.stun-label{position:absolute;bottom:-8px;left:50%;transform:translateX(-50%);background:#ff4444;color:#fff;padding:2px 6px;border-radius:3px;font-size:11px;font-weight:700;white-space:nowrap;z-index:10;font-weight:bold}
#action-menu .am-skill{background:#7c3aed}
#action-menu .am-skill:disabled{opacity:.35;cursor:default}

/* ═══ EXP Float Text ═══ */
.float-text.exp{color:#a78bfa}

/* ═══ Lobby Settings ═══ */
.settings-content{width:100%;max-width:300px;display:flex;flex-direction:column;gap:12px;margin-bottom:16px}

@media(min-width:1024px){
  #nav-settings{font-size:26px;cursor:pointer}
  #top-nav{height:56px;padding:0 16px}
  #nav-title{font-size:20px}
  #bottom-nav{height:64px}
  .bnav-icon{font-size:24px}
  .bnav-label{font-size:12px}
  #content{padding:24px}
  .lobby-gold{font-size:18px;padding:6px 22px}
  .clan-hideout{max-width:560px;height:320px;border-radius:14px}
  .hideout-unit .hu-name{font-size:13px}
  .hideout-label{font-size:11px}
  .screen-title{font-size:26px}.screen-sub{font-size:14px}
  .shop-hud{max-width:420px}
  .shop-hud-gold{font-size:16px;padding:4px 16px}
  .shop-info-row{max-width:420px}
  .shop-info-title{font-size:17px}
  .shop-info-timer{font-size:13px}
  #shop-list{max-width:420px}
  #sanc-list{max-width:480px}
  .shop-card{width:100%;padding:14px 10px}
  .shop-icon{font-size:36px}.shop-name{font-size:14px}
  .sanc-card{max-width:460px;padding:14px 16px}
  .settings-content{max-width:380px}
  .cc-exp-bar{height:5px}
  .cc-exp-txt{font-size:9px}
  .pt-btn{padding:10px 14px}
  .pt-icon{font-size:22px}.pt-info{font-size:13px}
  .pt-exp{font-size:11px}
}
