@import url('https://fonts.googleapis.com/css2?family=Press+Start+2P&family=VT323&family=Inter:wght@400;500;600&display=swap');
*{margin:0;padding:0;box-sizing:border-box}
:root{
  --g1:#4a8c3a;--gold:#e8c84a;--purple:#b07ae0;
  --dirt:#8b6a3c;--stone:#5a5040;--rock:#4a3828;
  --dark:#0f180a;--dark2:#0a1206;
  --text:#dff0c8;--muted:#8aac70;--border:#2d5c1a;
  --hud:rgba(8,18,4,.95);
}
body{background:var(--dark2);color:var(--text);font-family:'Inter',sans-serif;overflow:hidden;user-select:none}

@keyframes blink{0%,100%{opacity:1}50%{opacity:0}}
@keyframes sway{0%,100%{transform:rotate(-1.2deg)}50%{transform:rotate(1.2deg)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
@keyframes popIn{0%{transform:scale(.5);opacity:0}70%{transform:scale(1.15)}100%{transform:scale(1);opacity:1}}
@keyframes shimmer{0%,100%{opacity:.7}50%{opacity:1}}
@keyframes questSlide{from{opacity:0;transform:translateX(-20px)}to{opacity:1;transform:translateX(0)}}
@keyframes starBurst{0%{transform:scale(0) rotate(0deg);opacity:1}100%{transform:scale(1.8) rotate(180deg);opacity:0}}
@keyframes xpGrow{from{width:var(--from)}to{width:var(--to)}}

/* INTRO */
#intro{position:fixed;inset:0;background:#060e04;z-index:500;display:flex;flex-direction:column;align-items:center;justify-content:center;font-family:'Press Start 2P',monospace;overflow:hidden}
#intro h1{font-size:clamp(11px,2.2vw,22px);color:var(--gold);text-align:center;margin-bottom:10px;line-height:1.9;text-shadow:0 0 24px #e8c84a55}
#intro .sub{font-size:clamp(6px,1vw,9px);color:var(--muted);margin-bottom:28px;letter-spacing:2px}
.lang-sel{display:flex;gap:10px;margin-bottom:24px}
.lang-btn{font-family:'Press Start 2P',monospace;font-size:8px;background:transparent;border:1px solid var(--border);color:var(--muted);padding:7px 12px;cursor:pointer;border-radius:3px;display:flex;align-items:center;gap:6px;transition:all .2s}
.lang-btn:hover,.lang-btn.active{border-color:var(--g1);color:var(--g1);background:rgba(74,140,58,.1)}
#start-btn{font-family:'Press Start 2P',monospace;font-size:clamp(12px,2.2vw,18px);background:transparent;border:2px solid var(--g1);color:var(--g1);padding:14px 30px;cursor:pointer;border-radius:3px;animation:blink 1.2s infinite}
#start-btn:hover{background:var(--g1);color:#fff;animation:none}
.intro-forest{position:absolute;bottom:0;left:0;right:0;height:140px;pointer-events:none;overflow:hidden}

/* GAME */
#game-screen{position:fixed;inset:0;display:none;flex-direction:column}
#hud{background:var(--hud);border-bottom:2px solid var(--border);padding:7px 16px;display:flex;align-items:center;gap:14px;font-family:'Press Start 2P',monospace;font-size:8px;color:var(--g1);z-index:100;flex-shrink:0;flex-wrap:wrap}
.hname{color:var(--gold);font-size:9px;text-shadow:0 0 10px #e8c84a66}
.hbar-w{display:flex;align-items:center;gap:5px}
.hbar{width:68px;height:8px;background:#0a180a;border:1px solid var(--border);border-radius:2px;overflow:hidden}
.hbf{height:100%;border-radius:2px}
.hp{background:linear-gradient(90deg,#2d8a2d,#6ecb50)}
.xp{background:linear-gradient(90deg,#b08010,#e8c84a);transition:width .6s ease}
.hsp{flex:1}
#mode-btn{background:transparent;border:1px solid var(--gold);color:var(--gold);font-family:'Press Start 2P',monospace;font-size:7px;padding:6px 10px;cursor:pointer;border-radius:3px;display:flex;align-items:center;gap:5px;white-space:nowrap;transition:all .2s}
#mode-btn:hover{background:var(--gold);color:#111}
.hud-lang{display:flex;gap:4px}
.hud-lang button{background:transparent;border:1px solid var(--border);color:var(--muted);font-family:'Press Start 2P',monospace;font-size:6px;padding:3px 6px;cursor:pointer;border-radius:2px;transition:all .15s}
.hud-lang button.active{border-color:var(--g1);color:var(--g1)}

#world-wrap{flex:1;overflow:hidden;position:relative}
#canvas{display:block;image-rendering:pixelated;image-rendering:crisp-edges}

/* QUEST LOG */
#quest-log{position:fixed;top:54px;left:13px;background:rgba(4,10,2,.94);border:2px solid var(--gold);padding:12px 16px;z-index:150;border-radius:5px;min-width:260px;max-width:340px}
.ql-header{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:0}
.ql-header-left{display:flex;align-items:center;gap:8px;flex:1;min-width:0}
.ql-title{font-family:'Press Start 2P',monospace;font-size:10px;color:var(--gold);display:flex;align-items:center;gap:5px;white-space:nowrap}
.ql-header-right{display:flex;align-items:center;gap:7px;flex-shrink:0}
.ql-progress-text{font-family:'Press Start 2P',monospace;font-size:9px;color:var(--muted)}
.ql-toggle{background:transparent;border:1.5px solid var(--border);color:var(--muted);font-family:'Press Start 2P',monospace;font-size:8px;padding:3px 7px;cursor:pointer;border-radius:2px;transition:all .2s;line-height:1;flex-shrink:0}
.ql-toggle:hover{border-color:var(--gold);color:var(--gold)}
.ql-body{overflow:hidden;max-height:600px;opacity:1;transition:max-height .35s ease,opacity .25s ease,margin-top .25s ease;margin-top:12px}
#quest-log.collapsed .ql-body{max-height:0;opacity:0;margin-top:0}
.ql-progress-bar{height:5px;background:#0a180a;border:1px solid var(--border);border-radius:2px;margin-bottom:12px;overflow:hidden}
.ql-progress-fill{height:100%;background:linear-gradient(90deg,var(--g1),var(--gold));border-radius:2px;transition:width .6s ease}
.ql-item{display:flex;align-items:flex-start;gap:10px;font-family:'Press Start 2P',monospace;font-size:9px;color:var(--muted);margin-bottom:12px;line-height:1.8;cursor:default;animation:questSlide .3s ease forwards}
.ql-item:last-child{margin-bottom:0}
.ql-item.done .ql-text{color:var(--g1);opacity:.7}
.ql-item.done .ql-name{text-decoration:line-through}
.ql-check{width:14px;height:14px;border:1px solid var(--muted);border-radius:2px;flex-shrink:0;margin-top:2px;display:flex;align-items:center;justify-content:center;transition:all .3s}
.ql-check.done{border-color:var(--g1);background:rgba(74,200,74,.2);color:var(--g1)}
.ql-name{display:block;color:var(--text);margin-bottom:3px;font-size:11px}
.ql-desc{display:block;color:var(--muted);font-size:8px;line-height:1.7;opacity:.8}
.ql-item.done .ql-desc{opacity:.4}

/* REWARD OVERLAY */
#reward-overlay{position:fixed;inset:0;z-index:400;pointer-events:none;display:none}
#reward-box{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:rgba(4,10,2,.97);border:3px solid var(--gold);border-radius:8px;padding:28px 38px;text-align:center;font-family:'Press Start 2P',monospace;min-width:320px;max-width:90vw;animation:popIn .4s ease forwards}
.reward-icon{font-size:44px;margin-bottom:12px;display:block;color:var(--gold)}
.reward-title{font-size:12px;color:var(--gold);margin-bottom:10px}
.reward-xp{font-size:10px;color:var(--g1);margin-bottom:8px}
.reward-lore{font-size:9px;color:var(--muted);line-height:1.9;margin-bottom:14px;max-width:280px}
.reward-dismiss{font-size:8px;color:var(--muted);animation:blink 1s infinite}
#particles-canvas{position:fixed;inset:0;pointer-events:none;z-index:399}

/* ALL DONE banner */
#all-done-banner{position:fixed;top:0;left:0;right:0;background:linear-gradient(90deg,#1a4010,#2a6020,#1a4010);border-bottom:2px solid var(--gold);padding:10px;text-align:center;font-family:'Press Start 2P',monospace;font-size:9px;color:var(--gold);z-index:350;display:none;animation:fadeUp .5s ease forwards}

#minimap{position:fixed;top:54px;right:13px;background:rgba(4,10,2,.9);border:2px solid var(--border);padding:6px;z-index:150;border-radius:4px}
#mmc{display:block;margin-bottom:3px;border-radius:2px}
.mml{font-family:'Press Start 2P',monospace;font-size:6px;color:var(--g1);text-align:center}
#ctrl{position:fixed;bottom:10px;right:13px;z-index:150;background:rgba(4,10,2,.85);border:1px solid var(--border);font-family:'Press Start 2P',monospace;font-size:6px;color:var(--muted);padding:7px 10px;line-height:2;border-radius:3px}

/* JOYSTICK */
#joystick-wrap{position:fixed;bottom:24px;left:24px;z-index:160;display:none;touch-action:none}
#joystick-base{width:110px;height:110px;border-radius:50%;background:rgba(4,10,2,.7);border:2px solid var(--border);position:relative;touch-action:none}
#joystick-knob{width:44px;height:44px;border-radius:50%;background:rgba(74,140,58,.85);border:2px solid var(--g1);position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 0 12px rgba(74,200,74,.4);transition:box-shadow .15s;touch-action:none}
#interact-btn{position:fixed;bottom:34px;right:90px;z-index:160;display:none;width:58px;height:58px;border-radius:50%;background:rgba(232,200,74,.85);border:2px solid var(--gold);font-family:'Press Start 2P',monospace;font-size:9px;color:#111;cursor:pointer;touch-action:none;align-items:center;justify-content:center}
@media (pointer:coarse){#joystick-wrap{display:block}#interact-btn{display:flex}#ctrl{display:none}}

/* DIALOG */
#dialog{position:fixed;bottom:0;left:0;right:0;background:rgba(4,10,2,.98);border-top:3px solid var(--g1);padding:22px 34px 18px;z-index:200;display:none;font-family:'VT323',monospace;font-size:clamp(26px,2.4vw,38px);line-height:1.6}
#dtitle{font-family:'Press Start 2P',monospace;font-size:clamp(12px,1.2vw,16px);color:var(--gold);margin-bottom:14px;display:flex;align-items:center;gap:10px}
#dcontent{color:var(--text);max-height:320px;overflow-y:auto;font-size:clamp(26px,2.4vw,38px)}
#dclose{display:block;margin-top:12px;font-family:'Press Start 2P',monospace;font-size:9px;color:var(--muted);animation:blink 1s infinite}
#dialog-close-btn{position:absolute;top:12px;right:14px;background:rgba(74,140,58,.15);border:1.5px solid var(--g1);color:var(--g1);font-family:'Press Start 2P',monospace;font-size:9px;padding:8px 13px;cursor:pointer;border-radius:3px;display:none;align-items:center;gap:6px;line-height:1;transition:all .2s}
#dialog-close-btn:hover{background:rgba(74,140,58,.35)}
@media (pointer:coarse){#dialog-close-btn{display:flex}#dclose{display:none}}

/* RESUME */
#resume-screen{position:fixed;inset:0;background:#fff;color:#111;font-family:'Inter',sans-serif;overflow-y:auto;display:none;z-index:300}
#resume-screen *{box-sizing:border-box}
.rt{background:#1a2e0a;color:#fff;padding:12px 24px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:10;gap:12px;flex-wrap:wrap}
.rt-name{font-size:16px;font-weight:600}.rt-role{font-size:11px;color:#8ac870;margin-top:2px}
.rt-btns{display:flex;gap:7px;flex-shrink:0;flex-wrap:wrap}
.rt-btn{background:transparent;padding:6px 11px;border-radius:5px;cursor:pointer;font-size:12px;font-weight:500;display:flex;align-items:center;gap:5px;transition:all .2s;white-space:nowrap;border:2px solid}
#back-btn{border-color:#5a9e4a;color:#5a9e4a}#back-btn:hover{background:#5a9e4a;color:#fff}
#dl-btn{border-color:#e8c84a;color:#c8a830}#dl-btn:hover{background:#e8c84a;color:#111}
.rlang-btn{border-color:#ddd;color:#5a7040;font-size:11px;padding:5px 9px}
.rlang-btn.active{border-color:#5a9e4a;color:#5a9e4a;background:#eaf3de}
.rb{max-width:780px;margin:0 auto;padding:22px 18px}
.r-name-block{margin-bottom:16px;padding-bottom:14px;border-bottom:2px solid #1a2e0a}
.r-name-block h1{font-size:23px;font-weight:700;color:#1a2e0a;margin-bottom:3px}
.r-name-block .role{font-size:13px;color:#3d6e1e;font-weight:500;margin-bottom:8px}
.r-contacts{display:flex;flex-wrap:wrap;gap:9px;font-size:12px}
.r-contacts a,.r-contacts span{color:#3d6e1e;text-decoration:none;display:flex;align-items:center;gap:4px}
.rs{margin-bottom:18px}
.rs h2{font-size:12px;font-weight:700;color:#1a2e0a;text-transform:uppercase;letter-spacing:.8px;margin-bottom:10px;padding-bottom:5px;border-bottom:1.5px solid #c8dca8}
.r-summary{font-size:13px;color:#333;line-height:1.7}
.skill-cats{display:flex;flex-direction:column;gap:10px}
.skill-cat-row{display:flex;align-items:flex-start;gap:10px}
.skill-cat-label{font-size:11px;font-weight:600;color:#3d6e1e;min-width:110px;padding-top:3px;display:flex;align-items:center;gap:5px}
.skill-tags{display:flex;flex-wrap:wrap;gap:5px}
.skill-tag{background:#eaf3de;color:#1a4a0a;border:1px solid #b8d898;padding:3px 9px;border-radius:3px;font-size:12px}
.job{margin-bottom:13px;padding-bottom:13px;border-bottom:1px solid #e8f0d8}
.job:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}
.job-head{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:4px;margin-bottom:2px}
.job-title{font-size:13px;font-weight:700;color:#1a2e0a}
.job-date{font-size:11px;color:#6a9050;white-space:nowrap}
.job-co{font-size:12px;color:#3d6e1e;font-weight:500;margin-bottom:4px}
.job p{font-size:12px;color:#444;line-height:1.6;margin-top:3px}
.edu-item{margin-bottom:9px}
.edu-title{font-size:13px;font-weight:600;color:#1a2e0a}
.edu-inst{font-size:12px;color:#3d6e1e}
.edu-date{font-size:11px;color:#6a9050}
.list-plain{font-size:12px;color:#333;line-height:1.9;padding-left:16px}
