:root{
  --bg:#060815;
  --card:rgba(255,255,255,.06);
  --stroke:rgba(255,255,255,.14);
  --text:rgba(255,255,255,.92);
  --muted:rgba(255,255,255,.68);
  --shadow:0 20px 60px rgba(0,0,0,.35);
  --radius:18px;
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, "Noto Sans KR", Arial;
  background:
    radial-gradient(900px 600px at 15% 10%, rgba(34,197,94,.22), transparent 60%),
    radial-gradient(900px 600px at 80% 20%, rgba(59,130,246,.18), transparent 60%),
    radial-gradient(900px 600px at 70% 90%, rgba(245,158,11,.14), transparent 60%),
    linear-gradient(180deg, #070a15, #060817);
  color:var(--text);
}
.wrap{max-width:1200px;margin:0 auto;padding:18px 14px 40px}
.top{display:flex;justify-content:space-between;gap:14px;align-items:center;margin-bottom:14px}
.brand{display:flex;gap:12px;align-items:center}
.logo{width:44px;height:44px;filter:drop-shadow(0 14px 20px rgba(0,0,0,.35))}
.brand h1{margin:0;font-size:20px}
.brand p{margin:2px 0 0;color:var(--muted);font-size:12px}
.toolbar{display:flex;gap:10px;align-items:center;flex-wrap:wrap;justify-content:flex-end}
.seg{display:flex;border:1px solid rgba(255,255,255,.18);border-radius:999px;overflow:hidden;background:rgba(255,255,255,.06)}
.segBtn{border:0;background:transparent;color:rgba(255,255,255,.75);padding:9px 12px;font-weight:900;cursor:pointer}
.segBtn.active{background:rgba(34,197,94,.22);color:rgba(255,255,255,.95)}
.grid{display:grid;grid-template-columns: 1.05fr .95fr;gap:14px}
@media (max-width: 980px){.grid{grid-template-columns:1fr}}
.card{background:var(--card);border:1px solid var(--stroke);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}
.cardHead{padding:12px 14px;border-bottom:1px solid rgba(255,255,255,.10)}
.cardHead h2{margin:0;font-size:16px}
.cardHead p{margin:6px 0 0;color:var(--muted);font-size:12px}
.sword{padding:14px}
.swordRow{display:flex;gap:14px;align-items:stretch}
.swordBox{position:relative;width:210px;min-width:210px;border-radius:16px;border:1px solid rgba(255,255,255,.12);background:rgba(0,0,0,.18);display:grid;place-items:center;padding:10px}
@media (max-width: 980px){.swordBox{width:160px;min-width:160px}}
#swordImg{width:100%;height:auto;opacity:.95}
.lvlPill{position:absolute;top:10px;right:10px;background:rgba(0,0,0,.45);border:1px solid rgba(255,255,255,.18);border-radius:999px;padding:6px 10px;font-weight:1000}
.swordInfo{flex:1;min-width:0}
.swordName{font-size:22px;font-weight:1000;letter-spacing:-.02em;margin-bottom:10px}
.subInfo{display:grid;grid-template-columns: repeat(2, 1fr);gap:10px}
.kpi{border:1px solid rgba(255,255,255,.12);background:rgba(0,0,0,.18);border-radius:14px;padding:10px 12px;display:flex;justify-content:space-between;align-items:center;min-width:0}
.kpi span{color:var(--muted);font-weight:900;font-size:12px}
.kpi b{font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.wallet{margin-top:12px;display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
@media (max-width:980px){.wallet{grid-template-columns:repeat(2,1fr)}}
.chip{border:1px solid rgba(255,255,255,.12);background:rgba(0,0,0,.18);border-radius:14px;padding:10px 12px;display:flex;justify-content:space-between;align-items:center}
.chip span{color:var(--muted);font-weight:900;font-size:12px}
.chip b{font-size:14px}
.msg{margin-top:12px;border:1px dashed rgba(255,255,255,.18);background:rgba(0,0,0,.12);border-radius:14px;padding:10px 12px;font-weight:900;color:rgba(255,255,255,.88)}
.actions{padding:14px;display:flex;flex-direction:column;gap:10px}
.btn{border:1px solid rgba(255,255,255,.16);background:rgba(0,0,0,.18);color:rgba(255,255,255,.92);padding:12px 14px;border-radius:14px;cursor:pointer;font-weight:1000}
.btn:hover{background:rgba(255,255,255,.08)}
.btn:disabled{opacity:.5;cursor:not-allowed}
.btn.primary{background:linear-gradient(180deg, rgba(34,197,94,.30), rgba(34,197,94,.14));border-color:rgba(34,197,94,.30)}
.btn.danger{background:linear-gradient(180deg, rgba(239,68,68,.26), rgba(239,68,68,.14));border-color:rgba(239,68,68,.30)}
.btn.ghost{background:transparent}
.miniRow{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
.materials{margin-top:6px;border:1px solid rgba(255,255,255,.12);border-radius:14px;background:rgba(0,0,0,.14);padding:10px}
.matTitle{font-weight:1000;font-size:13px;margin-bottom:8px;color:rgba(255,255,255,.88)}
.matGrid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}
.mat{display:flex;justify-content:space-between;align-items:center;gap:10px;border:1px solid rgba(255,255,255,.10);border-radius:12px;padding:8px 10px;background:rgba(255,255,255,.06)}
.mat span{color:rgba(255,255,255,.75);font-size:12px;font-weight:900}
.mat b{font-size:12px}
.craft{padding:0}
.craftGrid{padding:12px 14px;display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
@media (max-width:980px){.craftGrid{grid-template-columns:1fr}}
.craftItem{display:flex;gap:10px;border:1px solid rgba(255,255,255,.12);border-radius:14px;padding:10px;background:rgba(0,0,0,.14)}
.craftItem img{width:42px;height:42px;opacity:.95}
.craftItem h3{margin:0;font-size:14px}
.craftItem p{margin:6px 0 8px;color:var(--muted);font-size:12px;line-height:1.35}
.craftRow{display:flex;justify-content:space-between;align-items:center;gap:10px;flex-wrap:wrap}
.pill{border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.06);border-radius:999px;padding:4px 9px;font-weight:1000;font-size:12px;color:rgba(255,255,255,.78)}
.log{padding:0}
.logBox{padding:12px 14px;max-height:360px;overflow:auto}
.line{padding:6px 0;border-bottom:1px solid rgba(255,255,255,.06);font-size:13px}
.line:last-child{border-bottom:none}
.tag{display:inline-block;padding:2px 8px;border-radius:999px;border:1px solid rgba(255,255,255,.16);margin-right:8px;font-size:11px;color:rgba(255,255,255,.75)}
.tag.ok{border-color:rgba(34,197,94,.35);color:rgba(167,243,208,.95)}
.tag.bad{border-color:rgba(239,68,68,.35);color:rgba(254,202,202,.95)}
.tag.warn{border-color:rgba(245,158,11,.35);color:rgba(253,230,138,.95)}
.modal{position:fixed;inset:0;background:rgba(0,0,0,.55);display:grid;place-items:center;padding:16px}
.modalPanel{width:min(820px, 96vw);background:rgba(12,16,32,.96);border:1px solid rgba(255,255,255,.16);border-radius:18px;box-shadow:0 30px 90px rgba(0,0,0,.45);overflow:hidden}
.modalHead{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;padding:12px 14px;border-bottom:1px solid rgba(255,255,255,.10)}
.modalHead h2{margin:0;font-size:16px}
.modalHead p{margin:6px 0 0;color:var(--muted);font-size:12px}
.shopGrid{padding:12px 14px;display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
@media (max-width:720px){.shopGrid{grid-template-columns:1fr}}
.shopItem{display:flex;gap:10px;border:1px solid rgba(255,255,255,.12);border-radius:14px;padding:10px;background:rgba(255,255,255,.06)}
.shopItem img{width:42px;height:42px}
.shopItem h3{margin:0;font-size:14px}
.shopItem p{margin:6px 0 8px;color:var(--muted);font-size:12px;line-height:1.35}
.foot{margin:0;padding:10px 14px;color:rgba(255,255,255,.65);font-size:12px;border-top:1px solid rgba(255,255,255,.10)}
