/* Guild Crawl — 마을 껍데기 스타일 (플레이스홀더 아트) */
:root{
  --bg:#1b1526; --ink:#f3ecdd; --gold:#ffd76a; --accent:#7dd3c0;
  --card:#2a2036; --card2:#352a44; --line:#4a3b5e;
  --sky-top:#3a5a8c; --sky-bot:#8fb0d6; --grass:#5c8a4a; --grass-dk:#3f6a34; --dirt:#7a5c3a;
}
*{ box-sizing:border-box; -webkit-tap-highlight-color:transparent; }
html,body{ margin:0; height:100%; }
body{
  font-family:system-ui,-apple-system,"Segoe UI",Roboto,"Noto Sans KR",sans-serif;
  background:var(--bg); color:var(--ink); overflow:hidden;
  image-rendering:pixelated;
}
#app{
  position:relative; width:100%; height:100vh; height:100dvh;
  max-width:560px; margin:0 auto; display:flex; flex-direction:column;
  background:var(--bg);
}

/* ── 상단바 ── */
#topbar{
  flex:0 0 auto; display:flex; align-items:center; gap:8px;
  padding:8px 10px; background:rgba(0,0,0,.35); backdrop-filter:blur(4px);
  border-bottom:1px solid var(--line); z-index:5;
}
.cur{ display:flex; align-items:center; gap:4px; font-weight:700; font-size:14px;
  background:rgba(0,0,0,.25); padding:4px 10px; border-radius:999px; }
.cur .ci{ font-size:15px; }
#gold{ color:var(--gold); }
.spacer{ flex:1; }
.tb-btn{ background:none; border:none; font-size:20px; cursor:pointer; padding:2px 6px; }

/* ── 마을 (이미지 없음: 위치만 잡는 텍스트 진입) ── */
#village{ position:relative; flex:1 1 auto; overflow:hidden; }
/* 배경 자리(추후 마을 전경 이미지). 지금은 밋밋한 패널 + 위치 감각용 옅은 격자. */
#scene{
  position:absolute; inset:0;
  background:
    repeating-linear-gradient(0deg, transparent 0 47px, rgba(255,255,255,.03) 47px 48px),
    repeating-linear-gradient(90deg, transparent 0 47px, rgba(255,255,255,.03) 47px 48px),
    #221a30;
}

#buildings{ position:absolute; inset:0; }
.building{
  position:absolute; transform:translate(-50%,-50%);
  cursor:pointer; white-space:nowrap;
  font-size:14px; font-weight:700; color:var(--ink);
  padding:10px 16px; border-radius:10px;
  background:var(--card2); border:1px solid var(--line);
  box-shadow:0 2px 6px rgba(0,0,0,.35);
  transition:transform .08s ease, background .12s ease;
}
.building:hover{ background:#41334f; }
.building:active{ transform:translate(-50%,-50%) scale(.94); }

/* ── 다이얼로그 ── */
#modal{
  position:absolute; inset:0; z-index:20;
  background:rgba(0,0,0,.55); display:flex; align-items:center; justify-content:center;
  padding:16px;
}
#modal.hidden{ display:none; }
#dialog{
  position:relative; width:100%; max-width:420px; max-height:80%;
  overflow:auto; background:var(--card); border:2px solid var(--line);
  border-radius:16px; padding:18px 16px 20px; box-shadow:0 12px 40px rgba(0,0,0,.5);
  animation:pop .14s ease;
}
@keyframes pop{ from{ transform:scale(.94); opacity:0; } to{ transform:scale(1); opacity:1; } }
#dlgClose{
  position:absolute; top:10px; right:10px; width:30px; height:30px;
  border:none; border-radius:8px; background:var(--card2); color:var(--ink);
  font-size:15px; cursor:pointer;
}
#dlgTitle{ margin:2px 30px 12px 2px; font-size:19px; }
.dlg-blurb{ margin:0 0 12px; color:var(--accent); font-size:13px; }
.dlg-stub{
  background:var(--card2); border:1px dashed var(--line); border-radius:10px;
  padding:16px; font-size:13px; line-height:1.5; color:#cfc4dd;
}

/* 탭 */
.tabs{ display:flex; gap:6px; margin-bottom:10px; }
.tab{ flex:1; cursor:pointer; background:var(--card2); border:1px solid var(--line);
  color:#b3a6c4; border-radius:8px; padding:8px; font-size:13px; font-weight:700; }
.tab.on{ background:var(--accent); color:#10201c; border-color:var(--accent); }

/* 리스트(로스터·장비) */
.list{ display:flex; flex-direction:column; gap:6px; }
.row{
  display:block; width:100%; text-align:left; cursor:pointer;
  background:var(--card2); border:1px solid var(--line); border-radius:10px;
  padding:9px 12px; color:var(--ink);
}
.row.static{ cursor:default; }
.row:not(.static):hover{ background:#41334f; }
.row-main{ font-size:14px; }
.row-sub{ font-size:12px; color:#b3a6c4; margin-top:2px; }
.tag{ font-size:11px; background:#4a3b5e; color:#e7dcf5; padding:1px 7px; border-radius:999px; }
.tag.t2{ background:#3a5e4a; }
.tag.eq{ background:#5e4a3a; }
.tag.free{ background:#3a4a5e; }
.plus{ color:var(--gold); font-weight:800; }

/* 상세 */
.back{ background:none; border:none; color:var(--accent); font-size:14px; cursor:pointer; padding:0 0 8px; }
.adv-hd{ display:flex; align-items:center; gap:6px; flex-wrap:wrap; margin-bottom:10px; font-size:17px; }
.adv-hd .lv{ margin-left:auto; color:var(--gold); font-weight:700; font-size:14px; }
.sect-hd{ font-size:12px; color:#9c8fb2; text-transform:uppercase; letter-spacing:.5px; margin:14px 0 6px; }
.stats{ display:grid; grid-template-columns:1fr 1fr; gap:6px; }
.sbox{ display:flex; justify-content:space-between; background:var(--card2); border:1px solid var(--line);
  border-radius:8px; padding:7px 10px; font-size:13px; }
.sbox b{ color:#fff; }
.slot{ display:flex; align-items:center; gap:8px; background:var(--card2); border:1px solid var(--line);
  border-radius:8px; padding:8px 10px; margin-bottom:6px; }
.slot-lbl{ font-size:12px; color:#9c8fb2; width:56px; flex:0 0 auto; }
.g-name{ flex:1; font-size:13px; }
.mini{ margin-left:auto; font-size:12px; padding:4px 12px; border-radius:7px; cursor:pointer;
  background:var(--card); border:1px solid var(--line); color:var(--ink); }
.mini.alt{ background:var(--accent); color:#10201c; border:none; font-weight:700; }
.evo-note{ font-size:12px; color:#b3a6c4; background:var(--card2); border:1px solid var(--line);
  border-radius:8px; padding:10px; }
.evo-wrap{ display:flex; flex-direction:column; gap:6px; }
.evo-hd{ font-size:12px; color:var(--accent); }
.evo-btn{ display:flex; align-items:center; justify-content:space-between; cursor:pointer;
  background:#3a5e4a; border:1px solid #4f7a63; color:#eafff5; font-size:13px; font-weight:700;
  border-radius:9px; padding:9px 12px; }
.evo-btn[disabled]{ opacity:.45; cursor:not-allowed; }
.evo-btn .cost{ font-weight:600; font-size:12px; }

/* 영입/판매 행 */
.buy-row{ display:flex; align-items:center; gap:8px; margin-top:6px; }
.buy-row .row-sub{ flex:1; margin-top:0; }
.mini[disabled]{ opacity:.45; cursor:not-allowed; }
.lv{ color:var(--gold); font-size:12px; font-weight:700; }
.wide-btn{ display:block; width:100%; margin-top:10px; cursor:pointer;
  background:var(--card2); border:1px solid var(--line); color:var(--ink);
  border-radius:10px; padding:11px; font-size:13px; font-weight:700; }
.wide-btn:hover{ background:#41334f; }
.wide-btn[disabled]{ opacity:.45; cursor:not-allowed; }
.wide-btn.go{ background:var(--accent); color:#10201c; border:none; }
.row.locked{ opacity:.5; }
.pick-row.on{ background:#2f4a3a; border-color:#4f7a63; }
.mini-prog{ height:6px; background:#20242e; border:1px solid var(--line); border-radius:4px; overflow:hidden; margin:6px 0 2px; }
.mini-prog > i{ display:block; height:100%; background:linear-gradient(90deg,#3b6ee0,#5fd0c0); transition:width .3s; }

/* ── 던전 크롤 오버레이 ── */
#crawlOverlay{ position:absolute; inset:0; z-index:30; background:var(--bg); display:flex; flex-direction:column; }
#crawlOverlay.hidden{ display:none; }
.c-top{ display:flex; align-items:center; gap:6px; padding:8px 10px; flex-wrap:wrap;
  border-bottom:1px solid var(--line); background:rgba(0,0,0,.3); }
.c-name{ font-weight:800; font-size:14px; }
.c-badge{ font-size:12px; background:rgba(0,0,0,.3); padding:3px 8px; border-radius:999px; }
.c-btn{ background:var(--card2); border:1px solid var(--line); color:var(--ink);
  border-radius:8px; padding:5px 10px; font-size:13px; cursor:pointer; }
.c-prog{ flex:1 1 100%; height:8px; background:#20242e; border:1px solid var(--line); border-radius:6px; overflow:hidden; }
.c-prog > i{ display:block; height:100%; width:0%; background:linear-gradient(90deg,#3b6ee0,#5fd0c0); transition:width .2s; }
.c-stage{ position:relative; flex:1 1 auto; background:#000; overflow:hidden;
  display:flex; align-items:center; justify-content:center; }
.c-canvas canvas{ width:100%; height:auto; display:block; image-rendering:pixelated; }
.c-battle{ position:absolute; inset:0; flex-direction:column; padding:12px; overflow:hidden;
  background:radial-gradient(120% 100% at 50% 0%, #1a1420 0%, #0a0c12 70%); }
.c-battle .brow{ display:flex; justify-content:center; gap:8px; flex-wrap:wrap; }
.c-battle .enemies{ align-items:flex-start; margin-bottom:6px; }
.c-battle .vs{ text-align:center; color:#c05aa0; font-size:12px; letter-spacing:2px; margin:8px 0; opacity:.8; }
.c-battle .party{ margin-top:auto; align-items:flex-end; }
.bcard{ position:relative; width:84px; background:#141926; border:1px solid #2a3142; border-radius:8px;
  padding:7px 6px 6px; text-align:center; transition:opacity .3s,filter .3s; }
.bcard.enemy{ background:#1e1420; border-color:#3a2438; }
.bcard.dead{ opacity:.28; filter:grayscale(1); }
.bcard .emo{ font-size:26px; line-height:1.1; }
.bcard .bn{ font-size:10px; font-weight:bold; margin-top:2px; white-space:nowrap; overflow:hidden; }
.bcard .bar{ height:6px; background:#2a1a1a; border-radius:4px; overflow:hidden; margin-top:3px; }
.bcard .bar > i{ display:block; height:100%; background:#5fd06a; transition:width .12s; }
.bcard .bar.mp{ background:#182238; } .bcard .bar.mp > i{ background:#5a8fe0; }
.bcard .bar.atb{ height:3px; background:#20242e; } .bcard .bar.atb > i{ background:#e8c46a; }
.bcard .lbl{ font-size:9px; color:#8b93a4; margin-top:2px; }
.pop{ position:absolute; left:50%; top:12px; transform:translateX(-50%); font-weight:bold; font-size:14px;
  pointer-events:none; animation:cfloat .75s ease-out forwards; text-shadow:0 1px 2px #000; }
.pop.dmg{ color:#ff8a7a; } .pop.heal{ color:#8fe0a0; } .pop.miss{ color:#9aa4b4; font-size:11px; }
@keyframes cfloat{ 0%{opacity:1; top:12px;} 100%{opacity:0; top:-14px;} }
.blog{ margin-top:6px; font-size:11px; color:#9aa8bc; height:48px; overflow:hidden; }
.blog div{ padding:1px 0; }
.flash{ animation:cfl .25s; } @keyframes cfl{ 0%{background:#3a2030;} 100%{} }
.c-bottom{ flex:0 0 auto; padding:8px 10px; border-top:1px solid var(--line);
  display:flex; flex-direction:column; gap:6px; max-height:40%; overflow:hidden; }
.c-squad{ display:grid; grid-template-columns:1fr 1fr; gap:6px; }
.c-hero{ background:var(--card2); border:1px solid var(--line); border-radius:8px; padding:6px 8px; }
.c-hrow{ display:flex; justify-content:space-between; font-size:12px; font-weight:700; }
.c-tag{ font-size:11px; color:#9c8fb2; }
.c-hbar{ height:7px; background:#3a2020; border-radius:4px; overflow:hidden; margin:3px 0; }
.c-hbar > span{ display:block; height:100%; transition:width .15s; }
.c-ctrl{ display:flex; align-items:center; gap:8px; }
.c-sld{ display:flex; align-items:center; gap:6px; font-size:12px; color:#9c8fb2; }
.c-sld input{ width:90px; }
.c-log{ height:50px; overflow-y:auto; font-size:11px; }
.c-log div{ padding:1px 0; border-bottom:1px solid #1c212b; }
.l-heal{ color:#8fe0a0; } .l-loot{ color:var(--gold); } .l-sys{ color:#7fb0ff; } .l-warn{ color:#e8b04a; } .l-die{ color:#ff7a6a; }
.c-result{ position:absolute; inset:0; z-index:5; background:rgba(0,0,0,.72);
  display:flex; align-items:center; justify-content:center; padding:16px; }
.c-result-card{ background:var(--card); border:2px solid var(--line); border-radius:14px;
  padding:22px; text-align:center; max-width:300px; width:100%; }
.c-result-card h2{ margin:0 0 8px; font-size:18px; }
.c-result-card p{ color:var(--accent); font-size:13px; margin:0 0 16px; line-height:1.5; }
