:root{--ink: #111;--paper: #f4f1ea;--line: #111}*{box-sizing:border-box}html,body{margin:0;height:100%;background:var(--paper);color:var(--ink);font-family:Courier New,ui-monospace,monospace;overflow:hidden}#app{width:100vw;height:100vh;height:100dvh}.screen{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:safe center;gap:18px;background:var(--paper);overflow-y:auto;padding:24px 0;box-sizing:border-box}.panel{border:3px solid var(--line);background:var(--paper);padding:26px 30px;min-width:360px;max-width:760px;box-shadow:8px 8px 0 var(--ink)}.panel-wide{min-width:680px}.title-art{display:block;max-width:150px;max-height:150px;object-fit:contain;margin:0 auto 10px;border:2px solid var(--line);filter:grayscale(1) contrast(1.05)}h1{font-size:30px;letter-spacing:2px;margin:0 0 4px}h2{font-size:18px;margin:0 0 14px;border-bottom:2px solid var(--line);padding-bottom:6px}.sub{font-size:12px;opacity:.7;margin-bottom:16px}label{display:block;font-size:12px;margin:12px 0 4px;letter-spacing:1px}input[type=text]{width:100%;padding:10px;font-family:inherit;font-size:15px;border:2px solid var(--line);background:#fff;color:var(--ink)}button{font-family:inherit;font-size:14px;letter-spacing:1px;cursor:pointer;border:2px solid var(--line);background:var(--ink);color:var(--paper);padding:10px 18px;transition:transform .05s}button:hover{transform:translate(-1px,-1px);box-shadow:3px 3px 0 var(--ink)}button.ghost{background:var(--paper);color:var(--ink)}button:disabled{opacity:.35;cursor:not-allowed;box-shadow:none;transform:none}.jobs{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:6px 0 14px}.job-card{border:2px solid var(--line);padding:12px 8px;text-align:center;cursor:pointer;background:var(--paper);-webkit-user-select:none;user-select:none}.job-card .jn{font-size:16px;font-weight:700}.job-card .jh{font-size:11px;opacity:.7}.job-card.sel,.modebtn.sel,.sizebtn.sel,.teambtn.sel{background:var(--ink);color:var(--paper)}.job-card .skills{font-size:10px;margin-top:6px;opacity:.8;line-height:1.4}.maps{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:6px 0 14px}.map-card{border:2px solid var(--line);padding:10px 12px;cursor:pointer;background:var(--paper);-webkit-user-select:none;user-select:none}.map-card.sel{background:var(--ink);color:var(--paper)}.map-card.locked{opacity:.45;cursor:not-allowed;background:repeating-linear-gradient(45deg,var(--paper),var(--paper) 6px,#e5e1d8 6px,#e5e1d8 12px)}.map-card .mn{font-size:15px;font-weight:700}.map-card .mh{font-size:11px;opacity:.75;margin-top:3px;line-height:1.3}.players{list-style:none;padding:0;margin:0;max-height:220px;overflow-y:auto}.players li{display:flex;justify-content:space-between;align-items:center;border:2px solid var(--line);padding:8px 12px;margin-bottom:6px;font-size:13px}.badge{font-size:10px;border:1px solid var(--line);padding:1px 6px;margin-left:6px}.badge.ready{background:var(--ink);color:var(--paper)}.badge.host{background:var(--paper)}.kick{font-size:10px;padding:1px 7px;margin-left:6px;border:1px solid var(--line);background:var(--paper);cursor:pointer}.kick:hover{background:var(--ink);color:var(--paper)}.row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.spacer{flex:1}.err{color:#b00;font-size:12px;min-height:16px}.member-box{border:2px solid var(--line);padding:8px 12px;margin:8px 0;font-size:13px}.vbadge{display:inline-block;background:var(--ink);color:var(--paper);border-radius:50%;width:16px;height:16px;line-height:16px;text-align:center;font-size:11px;font-weight:700;margin-left:3px}.auth-toggle{margin-top:14px}button.link{background:none;border:none;color:var(--ink);text-decoration:underline;padding:2px;box-shadow:none}button.link:hover{transform:none;box-shadow:none}.auth-form{border:2px dashed var(--line);padding:12px;margin-top:8px}.auth-msg{font-size:12px;margin-top:8px;min-height:16px;opacity:.85}.auth-links{margin-top:8px;font-size:12px}.auth-links .link{font-size:12px}#game-root{position:relative;width:100%;height:100%}#game-root canvas{display:block;image-rendering:pixelated}.hud{position:absolute;left:12px;top:12px;font-size:12px;border:2px solid var(--line);background:#f4f1ead9;padding:8px 10px}.controls-help{position:absolute;right:12px;top:12px;font-size:11px;text-align:right;border:2px solid var(--line);background:#f4f1ead9;padding:8px 10px;line-height:1.6}.actionbar{position:absolute;bottom:14px;left:50%;transform:translate(-50%);display:flex;gap:16px;align-items:flex-end}.bar-divider{width:2px;align-self:stretch;background:var(--line);opacity:.5;margin:6px 0}.skillbar{display:flex;gap:8px}.slot{width:56px;height:56px;border:2px solid var(--line);background:var(--paper);position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:10px;text-align:center;overflow:hidden}.slot.active{background:var(--ink);color:var(--paper);animation:slotpulse .5s ease-in-out infinite alternate}.slot.active .key{color:var(--paper)}@keyframes slotpulse{0%{box-shadow:0 0 0 0 var(--ink)}to{box-shadow:0 0 0 3px var(--ink)}}.slot .key{position:absolute;top:2px;left:4px;font-weight:700;font-size:11px}.slot .cdmask{position:absolute;left:0;bottom:0;width:100%;background:#111111a6}.slot .cdtxt{position:absolute;color:var(--paper);font-size:14px;font-weight:700}.slot .charge{position:absolute;bottom:2px;right:3px;font-size:11px;font-weight:700;background:var(--ink);color:var(--paper);padding:0 3px}.itembar{display:flex;gap:6px;align-items:flex-end}.islot{width:52px;height:50px;border:2px solid var(--line);background:var(--paper);position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:9px;text-align:center;overflow:hidden}.islot{cursor:grab;-webkit-user-select:none;user-select:none}.islot:active{cursor:grabbing}.islot *{pointer-events:none}.islot.empty{opacity:.4}.islot.over{outline:2px dashed var(--ink);outline-offset:-4px;background:#1111111f}.islot.active{background:var(--ink);color:var(--paper);animation:slotpulse .6s ease-in-out infinite alternate}.islot.active .key,.islot.active .iicon{color:var(--paper)}.islot .key{position:absolute;top:1px;left:3px;font-weight:700;font-size:11px}.islot .iicon{font-size:17px;line-height:1}.islot .iname{font-size:8px;margin-top:1px}.islot .icount{position:absolute;bottom:1px;right:3px;font-size:11px;font-weight:700}.islot .cdtxt{position:absolute;top:1px;right:3px;font-size:10px;font-weight:700;color:var(--paper);background:var(--ink);padding:0 2px}.topbar{position:absolute;top:12px;left:50%;transform:translate(-50%);border:2px solid var(--line);background:#f4f1eae6;padding:6px 14px;font-size:13px}.skill-list{display:flex;flex-direction:column;gap:8px;margin:6px 0}.skill-row{display:flex;gap:10px;border:2px solid var(--line);padding:8px 10px;background:var(--paper)}.skill-key{flex:0 0 28px;height:28px;border:2px solid var(--line);background:var(--ink);color:var(--paper);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px}.skill-body{flex:1}.skill-head{display:flex;align-items:center;gap:8px;font-size:14px}.skill-tag{font-size:10px;border:1px solid var(--line);padding:0 5px}.skill-cd{font-size:11px;opacity:.7;margin-left:auto}.skill-desc{font-size:12px;opacity:.85;margin-top:3px;line-height:1.4}.info-btn{position:absolute;right:12px;bottom:14px;padding:8px 12px;font-size:12px}.skill-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#11111159;z-index:20}.skill-overlay.hidden{display:none}.skill-overlay-box{border:3px solid var(--line);background:var(--paper);box-shadow:8px 8px 0 var(--ink);padding:20px 24px;min-width:460px;max-width:620px;max-height:80vh;overflow-y:auto}.shop-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:#0a0a0ab8;display:flex;align-items:center;justify-content:center;animation:shopFade .15s ease-out}@keyframes shopFade{0%{opacity:0}to{opacity:1}}.shop-modal{width:min(860px,94vw);max-height:88vh;overflow-y:auto;border:3px solid var(--line);background:var(--paper);color:var(--ink);padding:18px 22px;box-shadow:8px 8px #00000080}.shop-head{display:flex;align-items:center;gap:14px}.shop-head h2{margin:0;font-size:22px;letter-spacing:2px}.shop-sub{font-size:12px;opacity:.55;font-weight:400;letter-spacing:1px}.shop-gold{margin-left:auto;font-size:16px;color:#8a6d1d}.shop-gold b{font-size:19px}.shop-close{width:34px;height:34px;padding:0;font-size:16px;line-height:1;background:var(--paper);color:var(--ink);border:2px solid var(--line)}.shop-close:hover{background:var(--ink);color:var(--paper)}.shop-hint{font-size:12px;opacity:.65;margin:8px 0 14px}.shop-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px}.shop-card{border:2px solid var(--line);background:#fff;padding:14px;display:flex;flex-direction:column;gap:6px;position:relative;transition:transform .08s ease-out,box-shadow .08s ease-out}.shop-card:hover{transform:translateY(-2px);box-shadow:4px 4px #00000040}.shop-card.on{border-color:#b8912f;box-shadow:0 0 0 2px #b8912f59}.shop-card.on:after{content:"적용중";position:absolute;top:-10px;right:10px;font-size:11px;font-weight:700;padding:2px 8px;background:#b8912f;color:#fff;border:2px solid var(--line)}.shop-icon{font-size:34px;line-height:1}.shop-name{font-size:16px;font-weight:700}.shop-desc{font-size:12px;opacity:.75;min-height:32px}.shop-meta{font-size:12px;opacity:.8}.shop-meta .left{color:#8a6d1d}.shop-actions{display:flex;gap:6px;margin-top:6px}.shop-actions button{flex:1;padding:8px 6px;font-size:13px}.shop-actions .tg.active{background:#b8912f;border-color:#8a6d1d;color:#fff}.shop-actions .buy.no{opacity:.45;text-decoration:line-through}.shop-msg{margin-top:12px;font-size:13px;min-height:18px}.lobby-top{display:flex;align-items:center;gap:10px;margin:6px 0 2px}.lobby-top .gold{color:#8a6d1d;font-weight:700}.lobby-top .spacer{flex:1}.lobby-top button{padding:6px 14px;font-size:13px}#game-root.touch-mode{touch-action:none;-webkit-user-select:none;user-select:none}.touch-controls{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:40}.touch-controls>*{pointer-events:auto}#game-root.touch-mode{--tc: clamp(60px, 13vmin, 100px)}.tc-stick{position:absolute;left:calc(env(safe-area-inset-left,0px) + 3vmin);bottom:calc(env(safe-area-inset-bottom,0px) + 3vmin);width:calc(var(--tc) * 1.3);height:calc(var(--tc) * 1.3);border-radius:50%;border:3px solid var(--line);background:#f4f1ea73;display:flex;align-items:center;justify-content:center;touch-action:none}.tc-knob{width:55%;height:55%;border-radius:50%;border:3px solid var(--line);background:#1111112e;transition:transform .03s linear}.tc-btn{border:3px solid var(--line);background:#f4f1ea8c;color:var(--ink);font-family:inherit;font-weight:700;touch-action:none;-webkit-tap-highlight-color:transparent;display:flex;align-items:center;justify-content:center;padding:0}.tc-btn.pressed{background:var(--ink);color:var(--paper)}.tc-aimcol{position:absolute;left:calc(env(safe-area-inset-left,0px) + 3vmin);bottom:calc(env(safe-area-inset-bottom,0px) + 3vmin + var(--tc) * 1.3 + 2vmin);display:flex;flex-direction:row;gap:2vmin}.tc-aim{width:calc(var(--tc) * .62);height:calc(var(--tc) * .54);border-radius:12px;font-size:calc(var(--tc) * .26)}.tc-jump{position:absolute;right:calc(env(safe-area-inset-right,0px) + 3vmin);bottom:calc(env(safe-area-inset-bottom,0px) + 3vmin);width:var(--tc);height:var(--tc);border-radius:50%;font-size:calc(var(--tc) * .2)}.tc-torch{position:absolute;left:calc(env(safe-area-inset-left,0px) + 3vmin);bottom:calc(env(safe-area-inset-bottom,0px) + 3vmin + var(--tc) * 1.3 + var(--tc) * .54 + 4vmin);width:calc(var(--tc) * .6);height:calc(var(--tc) * .6);border-radius:50%;font-size:calc(var(--tc) * .22)}.touch-mode .actionbar{display:contents}.touch-mode .bar-divider{display:none}.touch-mode .skillbar{position:absolute;right:calc(env(safe-area-inset-right,0px) + 3vmin);bottom:calc(env(safe-area-inset-bottom,0px) + 3vmin + var(--tc) + 2vmin);display:flex;flex-wrap:wrap;justify-content:flex-end;gap:1.4vmin;max-width:56vw}.touch-mode .itembar{position:absolute;top:calc(env(safe-area-inset-top,0px) + 6px);right:calc(env(safe-area-inset-right,0px) + 56px);display:flex;gap:1.4vmin}.touch-mode .slot{width:clamp(46px,8.5vmin,62px);height:clamp(46px,8.5vmin,62px)}.touch-mode .islot{width:clamp(42px,7.5vmin,54px);height:clamp(40px,7vmin,52px);cursor:default}.touch-mode .info-btn{bottom:auto;top:56px;right:12px}#rotate-gate{display:none}@keyframes tcrot{0%,40%{transform:rotate(0)}60%,to{transform:rotate(-90deg)}}@media(orientation:portrait)and (pointer:coarse){#rotate-gate{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;background:var(--paper);color:var(--ink);text-align:center;padding:24px;font-weight:700}#rotate-gate .rg-ic{font-size:56px;animation:tcrot 1.6s ease-in-out infinite}#rotate-gate .rg-sub{font-size:13px;opacity:.7;font-weight:400}#rotate-gate .rg-btn{margin-top:6px;font-size:15px;padding:12px 20px}}#fs-btn{display:none}@media(pointer:coarse){#fs-btn{display:flex;align-items:center;justify-content:center;position:fixed;top:8px;right:8px;z-index:9998;width:40px;height:40px;padding:0;font-size:20px;line-height:1;border:2px solid var(--line);background:#f4f1eabf;color:var(--ink)}}:fullscreen #fs-btn,:-webkit-full-screen #fs-btn{display:none}@media(orientation:landscape)and (max-height:560px)and (pointer:coarse){.screen{padding:0}.panel,.panel-wide{min-width:0;width:98vw;max-width:98vw;max-height:96dvh;padding:10px 14px;overflow-y:auto;box-shadow:none}h1{font-size:17px;margin:0}.sub{font-size:11px;margin-bottom:6px}h2{font-size:13px;margin:6px 0 4px}.lobby-cols{display:grid;grid-template-columns:1fr 1fr;gap:16px;align-items:start}.jobs{grid-template-columns:repeat(2,1fr);gap:6px}.maps{grid-template-columns:1fr;gap:6px}.job-card{padding:6px 4px}.job-card .jn{font-size:13px}.job-card .skills{display:none}.map-card .mh{font-size:10px}.players{max-height:22vh}.lobby-actions{position:sticky;bottom:0;margin-top:8px!important;background:var(--paper);border-top:2px solid var(--line);padding:8px 0 2px;z-index:2}}@media(max-width:680px){.screen{padding:12px 0;gap:12px}.panel,.panel-wide{min-width:0;width:94vw;max-width:94vw;padding:16px;box-shadow:5px 5px 0 var(--ink)}h1{font-size:22px;letter-spacing:1px;overflow-wrap:break-word}h2{font-size:15px}.title-art{max-width:92px;max-height:92px}.jobs{grid-template-columns:repeat(2,1fr);gap:8px}.maps{grid-template-columns:1fr;gap:8px}.job-card{padding:9px 6px}.job-card .jn{font-size:14px}.job-card .skills{display:none}button{padding:9px 13px;font-size:13px}input[type=text]{font-size:16px}.players{max-height:150px}.players li{padding:6px 9px;font-size:12px}.skill-overlay-box{min-width:0;width:94vw;padding:14px}.shop-modal{padding:14px}.shop-grid{grid-template-columns:1fr}}.hero-split{display:flex;width:100%;height:100%;background:var(--ink);overflow:hidden}.hero-art{flex:1 1 42%;min-width:320px;position:relative;background-size:cover;background-position:center;background-repeat:no-repeat;display:flex;align-items:center;justify-content:center;padding:clamp(18px,3vh,40px)}.hero-art:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:linear-gradient(180deg,#08080c38,#08080c85)}.hero-overlay{position:relative;z-index:1;width:100%;max-width:400px;max-height:100%;overflow-y:auto;background:#0e0e1480;backdrop-filter:blur(10px) saturate(1.1);-webkit-backdrop-filter:blur(10px) saturate(1.1);border:2px solid rgba(244,241,234,.35);box-shadow:8px 8px #00000073;padding:clamp(22px,3vh,34px) clamp(20px,2vw,30px);color:var(--paper)}.hero-overlay button.link{color:var(--paper)}.hero-overlay .check-hint{color:#f4f1eab3}.hero-overlay .member-box{background:#ffffff14;border-color:#f4f1ea4d;color:var(--paper)}.hero-overlay .auth-form,.hero-overlay .claim-banner{border-color:#f4f1ea59}.hero-title{color:var(--paper);font-size:clamp(30px,3.2vw,46px);line-height:.98;letter-spacing:2px;margin:0;text-shadow:3px 3px 0 rgba(0,0,0,.5)}.hero-title span{font-size:.72em;opacity:.9}.hero-tag{color:#f4f1ead1;font-size:12px;margin:12px 0 2px;letter-spacing:.5px;line-height:1.4}.room-create-stack{display:flex;flex-direction:column;gap:12px;margin-top:14px}.room-create-stack .check{justify-content:flex-start}.room-create-stack button{width:100%;padding:13px;font-size:15px}.hero-rooms{flex:1 1 58%;min-width:0;height:100%;display:flex;flex-direction:column;background:var(--paper);border-left:4px solid var(--ink);padding:clamp(24px,4vh,44px) clamp(24px,2.6vw,46px)}.lobby-art{flex:0 0 clamp(220px,28%,380px);min-width:0;align-items:flex-end;justify-content:flex-start}.lobby-art-cap{position:relative;z-index:1}.lobby-room-name{color:var(--paper);font-size:clamp(15px,1.6vw,20px);margin-top:12px;letter-spacing:.5px;text-shadow:2px 2px 0 rgba(0,0,0,.6)}.lobby-room-name button.link{color:var(--paper);font-size:13px}.lobby-main{flex:1 1 auto;min-width:0;height:100%;overflow-y:auto;background:var(--paper);border-left:4px solid var(--ink)}.lobby-scroll{padding:clamp(18px,3vh,34px) clamp(20px,2.4vw,42px)}.check{display:inline-flex;align-items:center;gap:7px;font-size:13px;letter-spacing:0;margin:0;cursor:pointer;-webkit-user-select:none;user-select:none}.check input{width:16px;height:16px;accent-color:var(--ink);cursor:pointer}.check-hint{font-size:11px;opacity:.6}.room-create-row{align-items:center}button.mini{padding:5px 12px;font-size:12px}.roomlist-head{display:flex;align-items:baseline;justify-content:space-between;margin:22px 0 10px;flex:0 0 auto}.roomlist-head h2{margin:0;border:none;padding:0;font-size:18px;letter-spacing:1px}.room-list{flex:1 1 auto;min-height:280px;display:flex;flex-direction:column;gap:10px;overflow-y:auto;padding:4px 4px 2px}.room-row{display:flex;align-items:center;justify-content:space-between;gap:14px;border:2px solid var(--line);background:#fff;padding:14px 16px;box-shadow:4px 4px 0 var(--ink);transition:transform .06s,box-shadow .06s}.room-row:hover{transform:translate(-2px,-2px);box-shadow:7px 7px 0 var(--ink)}.room-info{min-width:0}.room-name{font-size:18px;font-weight:700;letter-spacing:.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.room-tags{display:flex;gap:7px;margin-top:7px;flex-wrap:wrap}.rtag{font-size:11px;border:1px solid var(--line);padding:2px 8px;background:var(--paper);white-space:nowrap}.room-act{display:flex;flex-direction:column;align-items:center;gap:7px;flex:0 0 auto}.room-count{font-size:15px;font-weight:700;font-variant-numeric:tabular-nums;letter-spacing:1px}.room-count.full{opacity:.5}.join-btn{padding:9px 18px;font-size:14px}.room-empty{flex:1 1 auto;display:flex;align-items:center;justify-content:center;text-align:center;font-size:13px;opacity:.55;padding:30px 16px;border:2px dashed var(--line);background:#00000005}@media(max-width:900px){.hero-split{flex-direction:column}.hero-art{flex:1 1 46%;min-width:0;min-height:280px}.hero-rooms{flex:1 1 54%;border-left:none;border-top:4px solid var(--ink);padding:18px 16px}.hero-overlay{max-width:460px}.room-list{min-height:180px}.lobby-art{flex:0 0 180px;min-height:0}.lobby-main{flex:1 1 auto;border-left:none;border-top:4px solid var(--ink)}}@media(max-height:860px){.panel{padding:16px 22px}.panel h1{font-size:20px;margin:4px 0}.panel h2{font-size:14px;margin:10px 0 6px}.job-card .jface{width:64px!important;height:64px!important}.job-card,.map-card{padding:8px}.players li{padding:4px 8px}}
