:root{--bg:#050a1a;--bg2:#0d1117;--panel:#0d1a2a;--card:#111c2e;--bdr:#1a3a5a;--cyan:#00f3ff;--yellow:#deff9a;--gold:#d4af37;--purple:#8b00ff;--green:#2ecc71;--red:#e74c3c;--blue:#4a90d9;--txt:#ccd6f6;--dim:#446677;--muted:#2a3a4a}
*{margin:0;padding:0;box-sizing:border-box}
html{background:#000;width:100vw;height:100vh;overflow:hidden}
body{background:var(--bg);color:var(--txt);font-family:'Malgun Gothic','맑은 고딕','Courier New',monospace;overflow:hidden;width:100vw;height:100vh;user-select:none;display:flex;align-items:center;justify-content:center}
/* 게임 무대: 1536x864 기본 사이즈, 화면 크기/비율에 따라 비례 축소·확대 (transform:scale) */
#game-stage{position:relative;width:1536px;height:864px;flex-shrink:0;transform-origin:center center;transform:scale(var(--gs,1));background:var(--bg);overflow:hidden}
.scr{position:fixed;inset:0;display:none;flex-direction:column;align-items:center;justify-content:center;z-index:1}.scr.on{display:flex}
#s-loading{z-index:999;background:var(--bg)}
.btn{padding:10px 24px;border:1px solid var(--cyan);background:transparent;color:var(--cyan);font-family:'Malgun Gothic','맑은 고딕','Courier New',monospace;font-size:17px;cursor:pointer;letter-spacing:1px;transition:all .2s;border-radius:5px}
.btn:hover{background:var(--cyan);color:var(--bg)}.btn:disabled{opacity:.3;cursor:not-allowed;pointer-events:none}
.btn-gold{border-color:var(--gold);color:var(--gold)}.btn-gold:hover{background:var(--gold);color:var(--bg)}
.btn-red{border-color:var(--red);color:var(--red)}.btn-red:hover{background:var(--red);color:#fff}
.btn-green{border-color:var(--green);color:var(--green)}.btn-green:hover{background:var(--green);color:var(--bg)}
.btn-purple{border-color:var(--purple);color:var(--purple)}.btn-purple:hover{background:var(--purple);color:#fff}
.btn-sm{padding:6px 14px;font-size:14px}.btn-lg{padding:14px 42px;font-size:21px}
.inp{background:var(--card);border:1px solid var(--bdr);color:#fff;font-family:'Malgun Gothic','맑은 고딕','Courier New',monospace;font-size:17px;padding:9px 13px;border-radius:5px;outline:none;width:100%}
.inp:focus{border-color:var(--cyan)}
#hud{position:fixed;top:0;left:0;right:0;height:44px;background:rgba(5,10,26,.96);border-bottom:1px solid var(--bdr);display:none;align-items:center;justify-content:space-between;padding:0 16px;z-index:200}
#hud.on{display:flex}
#notif{position:fixed;top:56px;right:16px;z-index:500;display:flex;flex-direction:column;gap:8px;pointer-events:none;max-width:300px}
/* 전투 모드: 전투 헤더(44px) + 페이지 헤더(44px) + 여유(50px) = 138px 부터 알림 시작 */
/* 학익진·시간차공격·테슬라·제네시스·데스티네이션 버튼이 줄넘김 시에도 안전 */
body.combat-mode #notif{top:138px;max-width:260px}
.ni{background:var(--panel);border-left:3px solid var(--cyan);padding:8px 12px;font-size:14px;border-radius:4px;animation:sli .3s ease;transition:opacity .4s}
.ni.ok{border-color:var(--green)}.ni.err{border-color:var(--red)}.ni.gold{border-color:var(--gold)}.ni.pur{border-color:var(--purple)}
@keyframes sli{from{transform:translateX(110%);opacity:0}to{transform:translateX(0);opacity:1}}
#bkdialog{height:210px;background:rgba(5,12,26,.97);border:1px solid rgba(0,243,255,.3);border-top:2px solid rgba(0,243,255,.4);border-top-left-radius:10px;border-top-right-radius:10px;display:none;flex-direction:row;overflow:hidden;z-index:450;box-shadow:0 -4px 24px rgba(0,0,0,.6);flex-shrink:0;width:100%}
#bkdialog.bk-open{display:flex}
#bkdialog.bk-closed{max-height:36px}
#bkdialog.bk-floating{position:fixed;bottom:auto;right:auto;border-radius:10px;transition:none;width:auto}
#bk-resize-handle{position:absolute;bottom:0;right:0;width:14px;height:14px;cursor:se-resize;opacity:.5;z-index:10}
#bk-resize-handle::after{content:'';position:absolute;right:2px;bottom:2px;width:8px;height:8px;border-right:2px solid rgba(0,243,255,.6);border-bottom:2px solid rgba(0,243,255,.6)}
#bk-body{display:flex;flex-direction:row;flex:1;min-height:0;overflow:hidden}
#bk-toggle-bar{display:flex;align-items:center;justify-content:space-between;padding:6px 10px;cursor:pointer;background:rgba(0,243,255,.06);border-bottom:1px solid rgba(0,243,255,.15);flex-shrink:0;user-select:none}
#bk-toggle-bar:hover{background:rgba(0,243,255,.12)}
#bk-img-area{position:relative;aspect-ratio:1/1;flex-shrink:0;overflow:hidden;background:linear-gradient(180deg,#050f1e,#0a1a30);align-self:stretch}
#bk-msgs{flex:1;min-height:0;overflow-y:auto;display:flex;flex-direction:column;gap:3px;padding:4px 10px 4px;scrollbar-width:thin;scrollbar-color:rgba(0,243,255,.2) transparent}
#bk-msgs::-webkit-scrollbar{width:3px}#bk-msgs::-webkit-scrollbar-thumb{background:rgba(0,243,255,.25);border-radius:4px}
@keyframes bkIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
.bk-msg{color:var(--yellow);font-size:13px;line-height:1.55;padding:3px 0;border-bottom:1px solid rgba(255,255,255,.05);animation:bkIn .35s ease}
.bk-msg:last-child{border-bottom:none;color:#fffde0}
#modal-bg{position:fixed;inset:0;background:rgba(0,0,0,.75);z-index:1000;display:none;align-items:center;justify-content:center}
#modal-bg.on{display:flex}
.modal{background:var(--panel);border:1px solid var(--bdr);border-radius:12px;padding:24px;max-width:520px;width:92%;max-height:82vh;overflow-y:auto}
.modal.modal-wide{max-width:624px}
.modal.modal-report{max-width:720px;padding:14px 16px;max-height:88vh}
.modal.modal-report .modal-t{font-size:16px;margin-bottom:8px;padding-bottom:4px}
.modal-t{color:var(--yellow);font-size:19px;font-weight:bold;margin-bottom:16px;padding-bottom:8px;border-bottom:1px solid var(--bdr)}
/* HUB */
#s-hub{padding-top:44px;padding-bottom:0;flex-direction:row;align-items:stretch;justify-content:flex-start;overflow:hidden}
#hub-planet-bg{position:absolute;inset:0;background-size:cover;background-position:center;background-repeat:no-repeat;opacity:.18;pointer-events:none;transition:opacity .4s ease;z-index:0}
.hub-side,.hub-body{position:relative;z-index:1}
.hub-side{width:192px;background:rgba(13,26,42,.99);border-right:1px solid var(--bdr);padding:0;display:flex;flex-direction:column;flex-shrink:0;overflow:hidden}
.hs-menu-scroll{flex:1;min-height:0;overflow-y:auto;padding-bottom:5px;display:flex;flex-direction:column}
.hs-profile{display:flex;align-items:center;gap:8px;padding:10px 11px;border-bottom:1px solid var(--bdr)}
.hs-av{width:30px;height:30px;background:var(--card);border:2px solid var(--cyan);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}
.hs-co{color:var(--yellow);font-size:13px;font-weight:bold}
.hs-pl{color:var(--dim);font-size:12px;margin-top:1px}
.hs-res{display:flex;justify-content:space-around;padding:6px 8px;background:rgba(0,0,0,.25);border-bottom:1px solid var(--bdr)}
.hs-ri{font-size:12px;color:var(--txt);display:flex;align-items:center;gap:3px}
.hn-sec{padding:5px 11px 2px;font-size:11px;color:var(--muted);letter-spacing:1px;text-transform:uppercase;margin-top:3px}
.hn-btn{display:flex;align-items:center;gap:8px;padding:7px 13px;cursor:pointer;color:var(--dim);font-size:16px;border:none;background:transparent;font-family:'Malgun Gothic','맑은 고딕','Courier New',monospace;transition:all .2s;text-align:left;border-left:3px solid transparent;width:100%;white-space:nowrap;overflow:hidden}
.hn-btn:hover{color:var(--txt);background:rgba(255,255,255,.04)}
.hn-btn.on{color:var(--cyan);border-left-color:var(--cyan);background:rgba(0,243,255,.07)}
.hn-ic{font-size:17px;flex-shrink:0;width:18px;text-align:center}
.hn-btn.ha{color:var(--blue)}.hn-btn.hs{color:var(--green)}.hn-btn.hb{color:var(--muted)}
.hn-folder-btn{display:flex;align-items:center;gap:8px;padding:7px 12px;cursor:pointer;color:var(--dim);font-size:16px;border:none;background:transparent;font-family:'Malgun Gothic','맑은 고딕','Courier New',monospace;transition:all .2s;text-align:left;border-left:3px solid transparent;width:100%;white-space:nowrap;overflow:hidden}
.hn-folder-btn:hover{color:var(--txt);background:rgba(255,255,255,.04)}
.hn-folder-btn.on{color:var(--cyan);border-left-color:var(--cyan);background:rgba(0,243,255,.07)}
.hn-folder-items{overflow:hidden;max-height:0;transition:max-height .25s ease}
.hn-folder-items.open{max-height:160px}
.hn-sub{padding-left:26px!important;font-size:13px!important}
.folder-arrow{margin-left:auto;font-size:9px;color:var(--dim);transition:transform .2s;flex-shrink:0}
.hn-folder.open-folder .folder-arrow{transform:rotate(90deg)}
.hub-body{flex:1;overflow:hidden;display:flex;flex-direction:column;box-sizing:border-box}
.hub-body.cv{padding:0!important;padding-bottom:0!important;overflow:hidden!important;display:flex!important;flex-direction:column!important}
.hub-scroll{overflow-y:auto;padding:16px 20px;flex:1;min-height:0}
.hub-t{color:var(--yellow);font-size:18px;font-weight:bold;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--bdr);word-break:keep-all}
/* info chips */
.ic{background:var(--card);border:1px solid var(--bdr);border-radius:6px;padding:5px 10px;display:flex;flex-direction:column;gap:1px;white-space:nowrap}
.icl{font-size:11px;color:var(--dim);text-transform:uppercase}
.icv{font-size:14px;color:var(--txt);font-weight:bold}
/* ship cards */
.ship-c{background:var(--card);border:1px solid var(--bdr);border-radius:10px;padding:12px;margin-bottom:10px}
/* crew */
.crew-grid{display:grid;grid-template-columns:repeat(8,1fr);gap:6px}
.crew-c{background:var(--card);border-radius:8px;padding:6px 5px;text-align:center}
.crew-av{font-size:22px;margin-bottom:4px;display:flex;justify-content:center;align-items:center;padding-top:4px}.crew-nm{color:var(--txt);font-size:11px;font-weight:bold;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.crew-cl{font-size:10px;color:var(--dim)}
.cr-N{color:#666;border:1px solid #444;border-radius:8px;padding:1px 6px;font-size:11px;display:inline-block;margin-top:3px}
.cr-R{color:var(--blue);border:1px solid var(--blue);border-radius:8px;padding:1px 6px;font-size:11px;display:inline-block;margin-top:3px}
.cr-H{color:var(--purple);border:1px solid var(--purple);border-radius:8px;padding:1px 6px;font-size:11px;display:inline-block;margin-top:3px}
.cr-L{color:var(--gold);border:1px solid var(--gold);border-radius:8px;padding:1px 6px;font-size:11px;display:inline-block;margin-top:3px}
/* gacha */
.gc-panel{display:flex;height:100%;overflow:hidden}
/* 버튼 컬럼 — 좌측 메뉴 바로 옆 */
.gc-btn-col{width:154px;flex-shrink:0;display:flex;flex-direction:column;padding:14px 10px;gap:8px;background:rgba(5,10,22,.97);border-right:1px solid var(--bdr);overflow-y:auto}
.gc-action{width:100%;display:block;padding:10px 7px;font-size:13px;text-align:center;border-radius:8px;cursor:pointer;font-family:'Malgun Gothic','맑은 고딕','Courier New',monospace;transition:all .2s;border:1px solid;line-height:1.4}
.gc-action:disabled{opacity:.38;cursor:not-allowed}
/* 메인 영역 — 타번 이미지 배경 + 인물 결과 오버레이 */
.gc-main{flex:1;position:relative;overflow:hidden;display:flex;flex-direction:column}
.gc-tavern-bg{position:absolute;inset:0;z-index:0}
.gc-tavern-bg img{width:100%;height:100%;object-fit:cover;opacity:.35}
.gc-tavern-bg-fallback{display:none;width:100%;height:100%;background:radial-gradient(ellipse at 30% 60%,#1a0a2e 0%,#050814 100%)}
.gc-tavern-overlay{position:absolute;inset:0;background:linear-gradient(90deg,rgba(5,10,22,.55) 0%,rgba(5,10,18,.2) 60%,rgba(5,10,18,.5) 100%);z-index:1}
/* 결과 패널 — 배경 위에 올라옴 */
.gc-result{position:relative;z-index:2;flex:1;display:flex;flex-direction:column;overflow:hidden}
.gc-result-hdr{padding:12px 18px 10px;border-bottom:1px solid rgba(255,255,255,.1);flex-shrink:0;background:rgba(5,10,22,.7);backdrop-filter:blur(4px)}
.gc-result-body{flex:1;overflow-y:auto;padding:12px 14px;display:flex;flex-direction:row;flex-wrap:wrap;gap:8px;align-content:flex-start;justify-content:flex-start}
.gc-empty{display:flex;align-items:center;justify-content:center;height:100%;flex-direction:column;gap:10px;color:var(--dim);width:100%}
.gc-char{width:88px;flex-shrink:0;display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 4px 6px;border-radius:8px;background:rgba(8,16,36,.82);border:1px solid var(--bdr);animation:bkIn .4s ease;backdrop-filter:blur(2px);text-align:center;position:relative}
.gc-char.rL{border-color:var(--gold);background:rgba(30,22,4,.85);box-shadow:0 0 18px rgba(212,175,55,.25)}
.gc-char.rH{border-color:var(--purple);background:rgba(20,4,36,.85);box-shadow:0 0 14px rgba(139,0,255,.2)}
.gc-char.rR{border-color:var(--blue);background:rgba(4,16,36,.82)}
.gc-card{width:86px;background:rgba(8,16,36,.9);border:2px solid var(--bdr);border-radius:10px;padding:10px 7px;text-align:center;min-height:110px;display:flex;align-items:center;justify-content:center;flex-direction:column}
.gc-card.cr-L{border-color:var(--gold);box-shadow:0 0 14px rgba(212,175,55,.4)}.gc-card.cr-H{border-color:var(--purple);box-shadow:0 0 12px rgba(139,0,255,.4)}.gc-card.cr-R{border-color:var(--blue)}
@keyframes cardFlip{from{transform:rotateY(90deg) scale(.8);opacity:0}to{transform:rotateY(0) scale(1);opacity:1}}
/* combat */
.cb-log div{color:var(--dim);word-break:keep-all}.cb-log .crit{color:var(--yellow)}.cb-log .win{color:var(--green)}.cb-log .lose{color:var(--red)}
/* planet/item */
.pl-item{background:var(--card);border:1px solid var(--bdr);border-radius:8px;padding:12px;margin-bottom:8px;display:flex;justify-content:space-between;align-items:center}
.pl-nm{color:var(--txt);font-size:16px;font-weight:bold;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
/* bars */
.bar-bg{height:8px;background:var(--panel);border-radius:4px;overflow:hidden;flex:1}
.bar-fi{height:100%;border-radius:4px;transition:width .3s}
/* misc */
.badge{display:inline-block;padding:2px 8px;border-radius:10px;font-size:12px;border:1px solid}
.bd-cy{color:var(--cyan);border-color:var(--cyan)}.bd-gd{color:var(--gold);border-color:var(--gold)}.bd-gn{color:var(--green);border-color:var(--green)}.bd-rd{color:var(--red);border-color:var(--red)}
::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:var(--bg2)}::-webkit-scrollbar-thumb{background:var(--bdr);border-radius:2px}
@keyframes cardFlip{0%{transform:scaleX(0);opacity:.3}50%{transform:scaleX(0)}100%{transform:scaleX(1);opacity:1}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
@keyframes _voidPulse{0%,100%{box-shadow:0 0 12px rgba(204,102,255,.35),inset 0 0 10px rgba(204,102,255,.06);border-color:#cc66ff}50%{box-shadow:0 0 22px rgba(204,102,255,.7),inset 0 0 16px rgba(204,102,255,.14);border-color:#dd88ff}}
#de-tooltip{position:fixed;z-index:99999;background:rgba(4,12,28,.97);border:1px solid rgba(0,243,255,.5);border-radius:9px;padding:11px 15px;max-width:300px;font-size:12px;line-height:1.75;color:rgba(220,235,255,.95);pointer-events:none;display:none;box-shadow:0 0 28px rgba(0,243,255,.18),0 4px 20px rgba(0,0,0,.7);font-family:'Malgun Gothic','맑은 고딕',sans-serif;word-break:keep-all;white-space:pre-line}