*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html,body{height:100%;overflow:hidden;background:#0a0d14;color:#eaf2ff;
  font-family:"Segoe UI",system-ui,sans-serif;user-select:none;-webkit-user-select:none;touch-action:none}
#app{position:relative;width:100vw;height:100vh}
.screen{position:absolute;inset:0;display:none;flex-direction:column}
.screen.active{display:flex}

#title,#maps{align-items:center;justify-content:center;gap:18px;text-align:center;padding:24px;
  background:radial-gradient(ellipse at 50% 30%,#16203a,#0a0d14 70%)}
.logo{font-weight:900;font-size:clamp(50px,13vw,130px);letter-spacing:.06em;
  background:linear-gradient(120deg,#ffd23c,#ff7a1a,#39ff14);-webkit-background-clip:text;background-clip:text;color:transparent;
  filter:drop-shadow(0 0 24px rgba(255,160,40,.4))}
.logo2{font-weight:900;font-size:clamp(26px,6vw,44px);letter-spacing:.2em;color:#ffd23c}
.tag{color:#9fb4d6;font-size:clamp(13px,3vw,17px)}
.how{max-width:600px;color:#b8c6e0;line-height:1.8;font-size:14px}.how b{color:#ffd23c}
.foot{color:#5b6a86;letter-spacing:.1em;font-size:12px;margin-top:4px}

.btn{cursor:pointer;border:1px solid #ffae3c;background:rgba(255,174,60,.12);color:#eaf2ff;border-radius:10px;
  padding:11px 20px;font-size:14px;font-weight:700;letter-spacing:.04em;transition:.12s}
.btn:hover{background:rgba(255,174,60,.26);transform:translateY(-2px)}
.btn:disabled{opacity:.4;cursor:not-allowed;transform:none}
.btn.big{font-size:20px;padding:16px 44px;border-color:#39ff14;background:rgba(57,255,20,.14);color:#dfffe0}
.btn.sm{padding:7px 12px;font-size:13px}

#dailyTwist{color:#ffd23c;font-weight:700;font-size:14px;margin:-4px 0 10px;text-align:center}
#statsBody{font-size:16px;line-height:2;text-align:left;color:#dfe9ff}
#statsBody b{color:#ffd23c}
.modbox.wide{min-width:380px;max-width:460px}
.modbox .sub2{font-size:12px;color:#9fb4d6;margin-top:-6px}
#perksAvail{font-size:15px;color:#dfe9ff;margin:2px 0 4px}#perksAvail b{color:#ffd23c;font-size:18px}
#perksBody{display:flex;flex-direction:column;gap:8px;width:100%}
.perk{display:flex;align-items:center;gap:10px;background:rgba(255,255,255,.05);border:1px solid #233152;border-radius:10px;padding:8px 10px;text-align:left}
.perk .pk-ic{font-size:26px}.perk .pk-mid{flex:1}
.perk .pk-name{font-weight:800;font-size:14px}.perk .pk-lv{color:#ffd23c;font-size:11px;font-weight:700}
.perk .pk-desc{font-size:11px;color:#9fb4d6}
.pk-buy{min-width:54px}.pk-buy.ok{border-color:#39ff14;color:#dfffe0;background:rgba(57,255,20,.16)}
#bestiaryBody{display:grid;grid-template-columns:1fr 1fr;gap:8px;width:100%;max-height:58vh;overflow-y:auto}
.best{display:flex;align-items:center;gap:8px;background:rgba(255,255,255,.05);border:1px solid #233152;border-radius:10px;padding:6px 8px;text-align:left}
.best-ic{font-size:24px}.best-name{font-weight:800;font-size:13px}
.best-stat{font-size:10px;color:#8fa3c4}.best-note{font-size:10px;color:#9fe0ff;line-height:1.2}
@media(max-width:520px){#bestiaryBody{grid-template-columns:1fr}}
#medalShelf{display:flex;flex-wrap:wrap;gap:6px;justify-content:center;max-width:420px;margin:14px auto 0}
#medalShelf .medal{font-size:22px;filter:grayscale(1);opacity:.35;transition:.15s;cursor:default}
#medalShelf .medal.got{filter:none;opacity:1;text-shadow:0 0 8px rgba(255,210,60,.6)}
#medalToast{position:fixed;top:18px;left:50%;transform:translateX(-50%) translateY(-120px);z-index:50;display:flex;align-items:center;gap:12px;background:#0e1424;border:2px solid #ffd23c;border-radius:14px;padding:12px 20px;box-shadow:0 8px 30px rgba(0,0,0,.5);opacity:0;transition:.35s;pointer-events:none}
#medalToast.show{transform:translateX(-50%) translateY(0);opacity:1}
#medalToast .mt-ic{font-size:34px}
#medalToast .mt-t{font-weight:800;color:#ffd23c;font-size:15px}
#medalToast .mt-d{font-size:12px;color:#c8d6f0}
/* level trail: compact numbered stepping-stone nodes you progress along */
#mapList{display:flex;flex-wrap:wrap;justify-content:center;align-items:flex-start;gap:14px 6px;max-width:940px;margin:0 auto;padding:8px 6px;max-height:68vh;overflow-y:auto}
.mapnode{position:relative;cursor:pointer;background:none;border:0;display:flex;flex-direction:column;align-items:center;width:82px;padding:0;color:#cdd9ee;font-family:inherit}
.mn-disc{position:relative;width:52px;height:52px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:16px;border:3px solid #39ff14;background:#16223a;box-shadow:0 0 0 3px #0a0d14;transition:.12s;z-index:1}
.mapnode.done .mn-disc{border-color:#ffd23c;color:#ffd23c}
.mapnode.locked{cursor:not-allowed;opacity:.4}
.mapnode.locked .mn-disc{border-color:#3a4560;font-size:18px}
.mapnode:hover .mn-disc{transform:scale(1.13);box-shadow:0 0 14px rgba(57,255,20,.55),0 0 0 3px #0a0d14}
.mn-disc::after{content:'';position:absolute;left:100%;top:50%;width:18px;border-top:2px dashed #2c3a57;margin-left:5px}
.mapnode:last-child .mn-disc::after{display:none}
.mn-stars{height:11px;font-size:9px;color:#ffd23c;letter-spacing:-1px;line-height:11px;margin-top:3px}
.mn-name{font-size:9.5px;line-height:1.12;margin-top:1px;max-width:80px;text-align:center;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}

#game{flex-direction:column}
#hud{display:flex;align-items:center;gap:10px;padding:7px 12px;background:#0d1220;border-bottom:1px solid #1c2740;flex-wrap:wrap}
#hud .stat{font-size:14px;color:#9fb4d6}#hud .stat b{color:#fff;font-size:16px}
.spdrow{display:flex;gap:4px;margin-left:auto}
.spd{cursor:pointer;border:1px solid #2a3550;background:#141b2c;color:#cdd9ee;border-radius:8px;width:34px;height:32px;font-size:13px}
.spd.on{border-color:#ffd23c;color:#ffd23c;box-shadow:0 0 8px rgba(255,210,60,.4)}
.btn.skill{border-color:#ff7a1a;background:rgba(255,122,26,.14);font-size:15px;padding:6px 9px}
.btn.skill:disabled{opacity:.5}
#skFreeze{border-color:#7fe8ff;background:rgba(127,232,255,.14)}
.btn.hero{border-color:#ffd23c;background:rgba(255,210,60,.14);font-size:15px;padding:6px 9px}
.btn.hero:disabled{opacity:.5}
.btn.hero.on{background:rgba(255,210,60,.4);box-shadow:0 0 8px rgba(255,210,60,.6)}
.btn.super{border-color:#ff7a1a;background:rgba(255,122,26,.14);font-size:12px;padding:6px 7px;font-weight:800}
.btn.super:disabled{opacity:.55}
.btn.super.ready{border-color:#ffd23c;color:#fff;animation:pulse .8s infinite}
.btn.start{background:rgba(255,122,26,.16);border-color:#ff7a1a;color:#ffd9b3}
.btn.start.ready{animation:pulse 1s infinite}
.btn.start.urgent{border-color:#ff2b46;color:#fff;animation:urgent .5s infinite alternate}
@keyframes pulse{50%{box-shadow:0 0 16px rgba(255,122,26,.7);transform:scale(1.04)}}
@keyframes urgent{from{background:rgba(255,43,70,.2)}to{background:rgba(255,43,70,.75);box-shadow:0 0 14px rgba(255,43,70,.85);transform:scale(1.05)}}
.btn.quit{background:rgba(255,90,60,.15);border-color:#ff5a3c;color:#ffd0c8}
.btn.endless{border-color:#ffd23c;background:rgba(255,210,60,.18);color:#ffe6a8;font-weight:800;animation:pulse 1.4s infinite}

#stage{position:relative;flex:1;overflow:hidden;background:#080b12}
#cv{position:absolute;top:0;left:0}

#palette{display:flex;gap:8px;padding:8px 10px;background:#0d1220;border-top:1px solid #1c2740;overflow-x:auto;justify-content:center}
.tw{flex:0 0 auto;cursor:pointer;border:2px solid #233152;background:#121a2c;border-radius:12px;padding:5px;width:74px;
  display:flex;flex-direction:column;align-items:center;gap:2px;transition:.12s}
.tw:hover{transform:translateY(-3px);border-color:#ffae3c}
.tw.on{border-color:#39ff14;box-shadow:0 0 12px rgba(57,255,20,.4)}
.tw.poor{opacity:.5}
.tw.sale{border-color:#39ff14;box-shadow:0 0 10px rgba(57,255,20,.5)}
.tw.sale::after{content:'SALE';position:absolute;top:-6px;right:-4px;background:#39ff14;color:#04210a;font-size:8px;font-weight:900;padding:1px 4px;border-radius:5px;transform:rotate(8deg)}
.tw{position:relative}
.tw.locked{opacity:.45;filter:grayscale(1);cursor:not-allowed;border-color:#3a2a2a}
.tw.locked:hover{transform:none;border-color:#5a3a3a}
.twc{width:42px;height:42px;image-rendering:auto}
.twl{display:flex;flex-direction:column;align-items:center;line-height:1.1}
.twl b{font-size:12px;color:#ffd23c}.twl span{font-size:10px;color:#8fa3c4}

#towerPop{position:absolute;left:50%;bottom:10px;transform:translateX(-50%);display:none;z-index:6;
  background:rgba(13,18,32,.96);border:1px solid #ffae3c;border-radius:12px;padding:9px 12px;min-width:210px;box-shadow:0 8px 30px #000a}
#towerPop.show{display:block}
#towerPop.top{bottom:auto;top:10px}
#towerPop{pointer-events:none}#towerPop button{pointer-events:auto}
.pophead{display:flex;align-items:center;gap:8px;font-weight:800;font-size:15px}
.pophead #popName{flex:1}.pophead button{background:none;border:none;color:#8fa3c4;cursor:pointer;font-size:14px}
#popStats{color:#b8c6e0;font-size:12px;margin:5px 0 7px}
.poprow{display:flex;gap:8px}.poprow .btn{flex:1}
#popBranch{display:none;flex-direction:column;gap:5px;margin:0 0 7px}
#popBranch .branchlbl{font-size:11px;color:#ffd23c;font-weight:800;letter-spacing:.05em;text-align:center}
.branchbtn{display:flex;align-items:center;gap:7px;justify-content:center;border-color:#ffd23c;background:rgba(255,210,60,.12)}
.branchbtn span{font-size:12px;font-weight:700}
.branchbtn:disabled{opacity:.5}

#combo{position:absolute;top:8px;left:50%;transform:translateX(-50%);z-index:5;display:none;font-weight:900;font-size:20px;color:#ff7a1a;text-shadow:0 0 12px rgba(255,122,26,.8)}
#combo.show{display:block}
#wavePreview{position:absolute;top:6px;left:50%;transform:translateX(-50%);z-index:6;display:none;gap:5px;align-items:center;flex-wrap:wrap;justify-content:center;max-width:96%;background:rgba(10,13,20,.82);border:1px solid #ff7a3c;border-radius:10px;padding:4px 9px}
#wavePreview.show{display:flex}
#wavePreview .wpl{color:#ff7a3c;font-weight:800;font-size:11px;letter-spacing:.06em;margin-right:3px}
#wavePreview .wpc{display:flex;align-items:center;gap:2px;background:rgba(255,255,255,.06);border-radius:6px;padding:1px 5px 1px 2px}
#wavePreview .wpc.boss{background:rgba(255,43,70,.28);box-shadow:0 0 8px rgba(255,43,70,.5)}
#wavePreview .wpc b{font-size:12px;color:#eaf2ff}
#wavePreview .wpc canvas{width:22px;height:22px}
#waveBanner{position:absolute;top:40%;left:50%;transform:translateX(-50%);z-index:5;font-weight:900;font-size:clamp(22px,5vw,40px);text-shadow:0 0 18px #000;opacity:0;pointer-events:none}
#waveBanner.show{animation:banner 1.8s ease-out}
@keyframes banner{0%{opacity:0;transform:translateX(-50%) scale(.6)}15%{opacity:1;transform:translateX(-50%) scale(1.05)}80%{opacity:1}100%{opacity:0}}
#redflash{position:absolute;inset:0;z-index:4;background:radial-gradient(ellipse at center,transparent 40%,rgba(255,43,70,.5));opacity:0;pointer-events:none}
#redflash.on{animation:rf .4s}
@keyframes rf{0%{opacity:1}100%{opacity:0}}

.modal,.overlay{position:absolute;inset:0;z-index:20;display:none;align-items:center;justify-content:center;background:rgba(6,9,16,.82)}
.modal.show,.overlay.show{display:flex}
.modbox,.ovbox{background:#0e1424;border:1px solid #ffae3c;border-radius:16px;padding:26px 30px;text-align:center;display:flex;flex-direction:column;gap:14px;min-width:300px}
.modbox h3{letter-spacing:.18em;color:#ffae3c}
.modbox label{display:flex;align-items:center;gap:12px;font-size:14px;font-weight:700}
.modbox input[type=range]{flex:1;accent-color:#ff7a1a}
.ovbox h2{font-size:40px}.ovbox.win h2{color:#39ff14}.ovbox.lose h2{color:#ff2b46}
.bigstars{font-size:48px;color:#ffd23c;letter-spacing:6px}
#winOv{background:rgba(6,9,16,.5)}
#winRank .ranklbl{font-size:12px;letter-spacing:.25em;color:#9fb4d6;font-weight:800;margin-bottom:-2px}
#winRank .rank{display:inline-block;font-size:60px;font-weight:900;line-height:1;text-shadow:0 0 20px currentColor}
#winRank .rankS{color:#ffd23c}#winRank .rankA{color:#39ff14}#winRank .rankB{color:#7fe8ff}#winRank .rankC{color:#ff9a3c}
#winRank .rankblurb{font-size:14px;color:#ffe6a8;margin-top:2px;font-weight:700}
.ovbox div{color:#c8d6f0;line-height:1.7}
.row{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

.btn.sm.on{border-color:#ffd23c;background:rgba(255,210,60,.22);box-shadow:0 0 8px rgba(255,210,60,.5)}
