:root{
  --bg:#faf8f2; --surf:#ffffff; --surf2:#fbf9f3;
  --gold:#b8901e; --goldB:#caa62f; --goldL:rgba(184,144,30,.40); --goldFaint:rgba(184,144,30,.13);
  --ink:#2c2620; --muted:#8f897c; --line:rgba(40,34,26,.10);
  --r1:#9a948a; --r2:#6f9a3e; --r3:#3a72c9; --r4:#8a4fc0; --r5:#c08a14; --r6:#b8901e;
  --shadow:0 6px 22px rgba(60,48,20,.08);
  --serif:"Iropke Batang","Nanum Myeongjo",Georgia,"Times New Roman",serif;
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html,body{height:100%}
body{font-family:"Pretendard","Apple SD Gothic Neo","Malgun Gothic",system-ui,sans-serif;
  color:var(--ink);background:var(--bg);display:flex;justify-content:center}
.app{width:100%;max-width:460px;min-height:100vh;display:flex;flex-direction:column;
  background:var(--surf);box-shadow:0 0 50px rgba(80,60,20,.07)}

/* topbar — 흰 바탕, 얇은 골드 헤어라인 */
.topbar{display:flex;justify-content:space-between;align-items:center;padding:18px 20px 14px;
  border-bottom:1px solid var(--goldL)}
.brand{display:flex;align-items:center;gap:11px}
.crest{width:34px;height:34px;display:grid;place-items:center;border:1.5px solid var(--gold);
  border-radius:8px;color:var(--gold);font-size:16px;font-weight:700}
.brandtxt b{font-family:var(--serif);font-size:21px;letter-spacing:5px;color:var(--ink);font-weight:600}
.brandtxt small{display:block;font-size:9.5px;letter-spacing:3px;color:var(--gold);margin-top:1px}
.wallet{display:flex;align-items:center;gap:6px;padding:7px 14px;border:1px solid var(--goldL);
  border-radius:30px;background:var(--surf2);font-variant-numeric:tabular-nums}
.wallet .coin{color:var(--gold);font-size:11px}
#points{font-size:16px;font-weight:700;color:var(--ink)}
.pUnit{color:var(--gold);font-size:12px;margin-left:1px}
.wallet.bump{animation:bump .4s}
@keyframes bump{40%{transform:scale(1.1);border-color:var(--gold)}}

/* tabs — 활성=골드 밑줄 */
.tabs{display:flex;padding:0 16px;border-bottom:1px solid var(--line)}
.tab{flex:1;padding:13px 0;background:none;border:none;border-bottom:2px solid transparent;
  color:var(--muted);font-size:15px;font-weight:600;cursor:pointer;transition:.18s;font-family:inherit}
.tab.active{color:var(--ink);border-bottom-color:var(--gold)}

main{flex:1;padding:16px 16px 10px;overflow-y:auto}
.panel{display:none;animation:fade .25s}
.panel.active{display:block}
@keyframes fade{from{opacity:0;transform:translateY(5px)}}
h3.sec{font-family:var(--serif);font-size:14px;color:var(--ink);font-weight:600;
  margin:4px 0 10px;padding-bottom:6px;border-bottom:1px solid var(--goldFaint);letter-spacing:.5px}

/* 버튼 — 골드 아웃라인(흰 바탕) + 채움 골드 1개 */
.btn{border-radius:11px;padding:12px;font-size:14px;font-weight:600;cursor:pointer;transition:.14s;
  font-family:inherit;border:1px solid var(--goldL);background:var(--surf);color:var(--gold)}
.btn:active{transform:scale(.96)}
.btn.fill{background:var(--gold);color:#fff;border-color:var(--gold);box-shadow:0 3px 12px rgba(184,144,30,.28)}
.btn.ink{color:var(--ink);border-color:var(--line)}
.btn:disabled{opacity:.4;cursor:default}
.btn.tiny{padding:6px 11px;font-size:12px;border-radius:8px}
.row{display:flex;gap:8px}.row>.btn{flex:1}

/* 채굴 scene */
.fieldsel{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:13px;padding-bottom:2px}
.fchip{flex:none;padding:8px 13px;border:1px solid var(--goldL);border-radius:20px;background:var(--surf);
  font-size:13px;cursor:pointer;color:var(--muted);transition:.15s;white-space:nowrap}
.fchip.on{background:var(--surf2);color:var(--ink);border-color:var(--gold);font-weight:600}
.mine{border:1px solid var(--goldL);border-radius:16px;padding:16px;margin-bottom:13px;
  background:linear-gradient(180deg,#fff,#fdfbf5);position:relative;overflow:hidden}
.mineHead{display:flex;justify-content:space-between;align-items:center;font-size:13px;color:var(--muted);margin-bottom:6px}
.mineHead b{color:var(--ink);font-weight:600}
.oreStage{height:84px;display:grid;place-items:center;margin:6px 0}
.oreStage svg{width:72px;height:72px;filter:drop-shadow(0 4px 8px rgba(60,48,20,.18))}
.oreStage.pop svg{animation:pop .4s}
@keyframes pop{0%{transform:scale(.5) rotate(-10deg)}60%{transform:scale(1.15)}100%{transform:scale(1)}}
.gauge{height:7px;border-radius:7px;background:var(--surf2);border:1px solid var(--line);overflow:hidden;margin-top:4px}
.gauge i{display:block;height:100%;background:linear-gradient(90deg,var(--goldB),var(--gold));width:0;transition:width .25s}
.gsub{display:flex;justify-content:space-between;font-size:11px;color:var(--muted);margin-top:4px}

.orelist{display:flex;flex-direction:column;gap:6px;min-height:24px}
.orerow{display:flex;align-items:center;gap:10px;padding:8px 11px;border-radius:10px;
  background:var(--surf2);border:1px solid var(--line)}
.orerow svg{width:26px;height:26px;flex:none}
.orerow .nm{flex:1;font-size:13px}.orerow .nm small{color:var(--muted)}
.orerow .ct{color:var(--muted);font-size:13px;font-variant-numeric:tabular-nums}
.orerow .vl{color:var(--gold);font-size:13px;font-weight:600;min-width:62px;text-align:right}
.orerow.t6,.orerow.t5{border-color:var(--goldL)}
.empty{color:var(--muted);font-size:13px;text-align:center;padding:14px}
.est{margin-top:9px;text-align:right;font-size:12px;color:var(--muted)}.est b{color:var(--gold);font-size:14px}
.est:empty{display:none}

/* 식물 */
.shop{border:1px solid var(--line);border-radius:13px;margin-bottom:12px;overflow:hidden}
.shop summary{padding:11px 14px;font-size:13px;font-weight:600;color:var(--ink);cursor:pointer;list-style:none;background:var(--surf2)}
.shop summary::-webkit-details-marker{display:none}
.shopbody{padding:8px 12px;max-height:230px;overflow-y:auto}
.shoprow{display:flex;align-items:center;gap:9px;padding:7px 4px;border-bottom:1px solid var(--line);font-size:13px}
.shoprow:last-child{border:none}.shoprow .e{font-size:17px}.shoprow .t{flex:1}
.shoprow .t small{color:var(--muted);display:block;font-size:11px}
.gradehdr{font-size:11px;color:var(--gold);font-weight:600;margin:8px 0 3px;letter-spacing:1px}

.pots{display:grid;grid-template-columns:repeat(3,1fr);gap:9px;margin-bottom:8px}
.pot{aspect-ratio:1/1.15;border:1px solid var(--goldL);border-radius:13px;background:var(--surf);
  display:flex;flex-direction:column;align-items:center;justify-content:flex-end;padding:7px;
  cursor:pointer;position:relative;overflow:hidden;transition:.15s}
.pot:active{transform:scale(.96)}
.pot.emptyp{justify-content:center;color:var(--muted);font-size:13px;border-style:dashed}
.pot svg{width:58px;height:58px}
.pot .pn{font-size:11px;color:var(--ink);margin-top:1px;text-align:center;line-height:1.2}
.pot .pbar{width:100%;height:4px;border-radius:4px;background:var(--surf2);border:1px solid var(--line);overflow:hidden;margin-top:5px}
.pot .pbar i{display:block;height:100%;background:linear-gradient(90deg,var(--goldB),var(--gold));width:0}
.pot .stat{position:absolute;top:6px;left:7px;right:7px;display:flex;justify-content:space-between;font-size:9.5px}
.pot .w{color:#4a86c0}.pot .w.low{color:#d07a2a}.pot .h{color:#c0506a}
.pot .haz{position:absolute;bottom:34px;font-size:13px}
.pot.bloom{border-color:var(--gold);box-shadow:0 0 0 1px var(--goldFaint)}
.pot .tag{position:absolute;top:6px;left:50%;transform:translateX(-50%);font-size:9px;color:#fff;
  background:var(--gold);padding:1px 7px;border-radius:6px;font-weight:600}
.hint{font-size:11.5px;color:var(--muted);text-align:center;margin-top:4px}

/* 하단 시트 / 모달 */
.sheet{position:fixed;inset:0;background:rgba(30,24,14,.32);display:none;align-items:center;
  justify-content:center;z-index:60;padding:16px}
.sheet.show{display:flex}
.sheetbox{width:100%;max-width:420px;background:var(--surf);border-radius:16px;
  border:1px solid var(--gold);padding:18px;animation:pop .2s;box-shadow:0 14px 44px rgba(30,24,14,.32)}
@keyframes pop{from{transform:scale(.94);opacity:.4}}
.sheetbox h4{font-family:var(--serif);font-size:15px;margin-bottom:4px}
.sheetbox .sub{font-size:12px;color:var(--muted);margin-bottom:12px}
.sheetgrid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}
.sheetgrid .btn{padding:13px 10px;text-align:center}
/* 가방 칸 그리드 (겟앰프드식 인벤토리) */
.baggrid{display:grid;grid-template-columns:repeat(8,1fr);gap:5px;max-height:48vh;overflow-y:auto;padding:2px}
.bagcell{aspect-ratio:1;border-radius:8px;border:1px solid var(--line);background:var(--surf2);display:flex;align-items:center;justify-content:center;overflow:hidden}
.bagcell.empty{background:rgba(40,34,26,.035);border-style:dashed}
.bagcell img{width:82%;height:82%;object-fit:contain}
.bagcell.t4,.bagcell.t5,.bagcell.t6{box-shadow:0 0 7px var(--goldL);border-color:var(--gold)}

/* 로그 패널 */
.logwrap{border-top:1px solid var(--goldL)}
.logwrap summary{padding:9px 16px;font-size:12px;color:var(--muted);cursor:pointer;list-style:none;
  display:flex;justify-content:space-between;align-items:center}
.logwrap summary::-webkit-details-marker{display:none}
.logwrap summary b{color:var(--gold)}
#log{max-height:160px;overflow-y:auto;padding:6px 14px 12px;font-family:ui-monospace,Menlo,Consolas,monospace;
  font-size:10.5px;line-height:1.55;color:#5a544a}
#log .lg{white-space:pre-wrap;word-break:break-all}
#log .e-err{color:#c0392b}.e-eco{color:var(--gold)}.e-act{color:#3a72c9}.e-sys{color:var(--muted)}
.logbtns{display:flex;gap:6px;padding:0 14px 12px}

.foot{display:flex;justify-content:space-between;align-items:center;padding:11px 16px;
  border-top:1px solid var(--line);font-size:10.5px;color:var(--muted)}

.toast{position:fixed;left:50%;bottom:90px;transform:translate(-50%,16px);background:#fff;
  border:1px solid var(--gold);color:var(--ink);padding:10px 18px;border-radius:11px;font-size:13.5px;
  opacity:0;pointer-events:none;transition:.25s;box-shadow:var(--shadow);z-index:70;max-width:88%}
.toast.show{opacity:1;transform:translate(-50%,0)}
.burst{position:fixed;inset:0;pointer-events:none;display:grid;place-items:center;z-index:65}
.burst.go::before{content:"💎 보물!";font-family:var(--serif);font-size:30px;font-weight:700;color:var(--gold);
  text-shadow:0 2px 14px rgba(184,144,30,.4);animation:tr 1.1s ease-out}
@keyframes tr{0%{transform:scale(.4);opacity:0}30%{transform:scale(1.15);opacity:1}70%{opacity:1}100%{transform:scale(1.4);opacity:0}}
.spark{position:fixed;width:6px;height:6px;border-radius:50%;background:var(--goldB);pointer-events:none;z-index:64}
/* 생성 이미지 에셋 */
.oimg{object-fit:contain;display:block}
.pimg{object-fit:contain;display:block}
.orerow .oimg{width:30px;height:30px;flex:none}
.oreStage .oimg{width:88px;height:88px;filter:drop-shadow(0 4px 8px rgba(60,48,20,.18))}
.pot .pimg{width:66px;height:66px;filter:drop-shadow(0 4px 7px rgba(60,48,20,.24))}
.slip{font-size:11.5px;color:var(--muted);line-height:1.65;background:var(--surf2);border:1px solid var(--goldFaint);border-radius:10px;padding:9px 12px;margin-bottom:12px}
.slip:empty{display:none}

/* 캐릭터 — 광부 본체 + 곡괭이 레이어(곡괭이만 손잡이 축으로 회전 = 진짜 내리찍기) */
.minerWrap{display:block;margin:-4px 0 6px}
.rig{position:relative;width:100%}
.rig .body{position:absolute;inset:0;width:130px;height:130px;object-fit:contain;
  filter:drop-shadow(0 6px 9px rgba(60,48,20,.22))}
.rig .pick{position:absolute;width:66px;height:66px;left:6px;top:2px;object-fit:contain;
  transform-origin:50% 74%;                 /* 손이 쥔 지점(손잡이 중하단) */
  filter:drop-shadow(0 3px 4px rgba(60,48,20,.25));
  transform:rotate(-50deg)}                  /* 기본: 곡괭이 치켜든 상태 */
.rig.mining .pick{animation:swingpick .58s cubic-bezier(.45,.05,.55,.95) infinite}
@keyframes swingpick{
  0%{transform:rotate(-50deg)}               /* 치켜듦 */
  48%{transform:rotate(22deg)}                /* 내리찍기 */
  62%{transform:rotate(22deg)}                /* 잠깐 박힘 */
  100%{transform:rotate(-50deg)}}
