@font-face{
  font-family:"Pixel";
  src:url("./assets/pixel.ttf") format("truetype");
  font-weight:400;
  font-style:normal;
  font-display:swap;
}
@font-face{
  font-family:"Pixeled";
  src:url("./assets/Pixeled.ttf") format("truetype");
  font-weight:400;
  font-style:normal;
  font-display:swap;
}
@font-face{
  font-family:"DogicaBold";
  src:url("./assets/dogicabold.ttf") format("truetype");
  font-weight:700;
  font-style:normal;
  font-display:swap;
}

:root{
  --bg:#2e40a6;
  --panel:#2e40a6;
  --border:rgba(255,255,255,.12);
  --border2:rgba(255,255,255,.18);
  --text:#e7e7e7;
  --muted:rgba(255,255,255,.78);
  --gold:#f2c14b;
  --elixir:#b46dff;
}
html,body{
  height:100%;
  width:100%;
  margin:0;
  background:linear-gradient(#2e40a6 0 49.9%, #8e6b33 50.1% 100%);
  color:var(--text);
  font-family:system-ui,Segoe UI,Roboto,Arial;
  overflow:hidden;
}
.wrap{ display:flex; flex-direction:column; height:100%; width:100%; background:#2e40a6; }

.main{ flex:1; min-height:0; position:relative; width:100%; height:100%; background:#2e40a6; }
canvas{
  width:100%;
  height:100%;
  display:block;
  image-rendering:pixelated;
  background:#2e40a6;
}
#fx{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  z-index:45;
  pointer-events:none;
  background:transparent;
}

.resourceStack{
  position:absolute;
  top:130px;
  left:14px;
  display:flex;
  flex-direction:column;
  gap:10px;
  z-index:30;
  pointer-events:none;
}
.questLog{
  position:absolute;
  top: var(--quest-y, 14px);
  left: var(--quest-x, 14px);
  right:auto;
  width: 288px;
  min-height: 114px;
  padding:0;
  border-radius:0;
  border:none;
  background:none;
  backdrop-filter:none;
  background-repeat:no-repeat;
  background-size:288px 114px;
  background-position:0 0;
  overflow:visible;
  image-rendering:pixelated;
  font-weight:800;
  font-size:12px;
  line-height:1.2;
  z-index:30;
  pointer-events:none;
  isolation:isolate;
}
.questLogEnemy{
  top: var(--quest-enemy-y, 14px);
  left:auto;
  right: var(--quest-enemy-x, 14px);
}
.questTitle{
  font-weight:1000;
  font-size:12px;
  letter-spacing:.5px;
  text-transform:uppercase;
  color:rgba(255,255,255,.9);
  margin-bottom:6px;
  display:none;
}
.questLevel{
  font-weight:900;
  font-size:12px;
  color:rgba(255,255,255,.95);
  margin-bottom:6px;
  display:none;
}
.questBody{
  display:flex;
  flex-direction:column;
  gap:6px;
}
.questText{
  color:#000;
  font-weight:900;
  width: var(--quest-text-w, 165px);
  height: var(--quest-text-h, 65px);
  position: relative;
  display:flex;
  align-items:center;
  justify-content:center;
  left: var(--quest-text-x, 80px);
  top: var(--quest-text-y, 10px);
  font-size: var(--quest-text-size, 9px);
  font-family:"Pixeled","Pixel","Pixeloid Sans","Press Start 2P","Courier New",monospace;
  line-height: 1.8;
  letter-spacing: 0.2px;
  text-align: center;
  border:none;
}
.questLogEnemy .questText{
  width: var(--quest-text-enemy-w, var(--quest-text-w, 165px));
  height: var(--quest-text-enemy-h, var(--quest-text-h, 65px));
  left: var(--quest-text-enemy-x, var(--quest-text-x, 50px));
  top: var(--quest-text-enemy-y, var(--quest-text-y, 10px));
  font-size: var(--quest-text-enemy-size, var(--quest-text-size, 9px));
}
.questBar{
  width: var(--quest-bar-w, 203px);
  height: var(--quest-bar-h, 5.6px);
  border-radius:0;
  background:transparent;
  border:none;
  overflow:hidden;
  position: relative;
  left: var(--quest-bar-x, 24px);
  top: var(--quest-bar-y, 13.2px);
}
.questLogEnemy .questBar{
  width: var(--quest-bar-enemy-w, var(--quest-bar-w, 203.2px));
  height: var(--quest-bar-enemy-h, var(--quest-bar-h, 5.6px));
  left: var(--quest-bar-enemy-x, var(--quest-bar-x, 60.4px));
  top: var(--quest-bar-enemy-y, var(--quest-bar-y, 13.2px));
}
.questBarFill{
  height:100%;
  width:0%;
  background:#634d28;
}
.resHud{
  display:flex;
  align-items:center;
  gap:10px;
  padding:8px 10px;
  min-height:0;
  border-radius:0;
  border:none;
  background:none;
  backdrop-filter:none;
  pointer-events:none;
}
.resHud img{
  width:50px;
  height:50px;
  image-rendering:pixelated;
}
.resHud .col{
  display:flex;
  flex-direction:column;
  line-height:1.05;
  gap:4px;
}
.resHud .amt{
  font-weight:900;
  font-size:20px;
  letter-spacing:.2px;
}
.resHud .amtMax{
  margin-left:4px;
  font-weight:900;
  font-size:14px;
  color:rgba(255,255,255,.75);
}
.resHud .rate{
  font-size:12px;
  color:rgba(255,255,255,.78);
  font-weight:800;
}

.shopOverlay{
  position:absolute;
  top:24px;
  left:50%;
  transform:translateX(-50%);
  display:flex;
  gap:12px;
  align-items:center;
  justify-content:center;
  z-index:20;
  pointer-events:auto;
  flex-wrap:wrap;
  max-width: calc(100% - 24px);
}

.upgradeOverlay{
  position:absolute;
  left:50%;
  transform:translateX(-50%);
  bottom:47px;
  display:flex;
  gap:12px;
  align-items:center;
  justify-content:center;
  z-index:25;
  pointer-events:auto;
  flex-wrap:wrap;
  max-width: calc(100% - 24px);
}

.shopBtn{
  width:72px; height:72px;
  border-radius:0;
  border:none;
  background:rgba(255,255,255,.02);
  cursor:pointer;
  user-select:none;
  display:flex;
  align-items:center;
  justify-content:center;
  position:relative;
  overflow:visible;
  transition: transform 0.12s ease-out;
  transform-origin: center;
}
.shopBtn:hover{ transform: scale(1.06); }
.shopBtn.purchased{
  border-color:var(--gold);
  box-shadow:0 0 0 2.5px rgba(242,193,75,.8);
}
.shopBtn:active{ transform: translateY(1px); }
.shopBtn[disabled]{ opacity:.45; cursor:not-allowed; transform:none; }
.upgradeOverlay .shopBtn[disabled]{ opacity:1; }
.shopBtn.cooldown{
  background:rgba(255,255,255,.02);
}
.shopBtn.cooldown::after{
  content:"";
  position:absolute;
  left:50%;
  top:50%;
  width:72px;
  height:72px;
  transform:translate(-50%, -50%);
  background:
    linear-gradient(to top,
      rgba(255,255,255,.38) 0%,
      rgba(255,255,255,.38) calc(var(--p, 0) * 100%),
      rgba(255,255,255,.10) calc(var(--p, 0) * 100%),
      rgba(255,255,255,.10) 100%);
  pointer-events:none;
}
.shopIcon{
  width:72px; height:72px;
  image-rendering:pixelated;
  border-radius:0;
  background:rgba(255,255,255,.04);
  border:none;
}
.priceTag{
  position:absolute;
  left:50%;
  transform:translateX(-50%);
  width:50px;
  height:30px;
  background:none;
  border:none;
  text-shadow:none;
  pointer-events:none;
  z-index:1;
  image-rendering:pixelated;
}
.priceBottom{ bottom:-35px; }
.priceTop{ top:-35px; }

.tooltip{ display:none; }
.tooltip .title{ font-weight:900; color:#fff; margin-bottom:6px; }
.tooltip .line{ font-size:13px; color:var(--muted); margin:2px 0; }
.tooltip .line strong{ color:var(--text); font-weight:800; }

.upgradeOverlay .tooltip{ top:auto; bottom:112px; }

.waveBarWrap{
  position:absolute;
  left:50%;
  transform:translateX(-50%);
  bottom:14px;
  width:min(720px, calc(100% - 28px));
  background:rgba(0,0,0,.28);
  border:1px solid rgba(255,255,255,.12);
  border-radius:14px;
  padding:10px 12px;
  backdrop-filter: blur(6px);
  z-index:15;
}
.waveLevelLabel{
  font-weight:1000;
  font-size:14px;
  margin-bottom:8px;
  color:rgba(255,255,255,.92);
  letter-spacing:.2px;
  text-align:center;
}
.bar{
  height:10px;
  border-radius:999px;
  background:rgba(255,255,255,.10);
  overflow:hidden;
  border:1px solid rgba(255,255,255,.10);
}
.barFill{ height:100%; width:0%; background:rgba(255,255,255,.35); }

.gameOverOverlay{
  position:absolute;
  inset:0;
  display:none;
  align-items:center;
  justify-content:center;
  z-index:100;
  background:rgba(0,0,0,.45);
  backdrop-filter: blur(4px);
}
.gameOverCard{
  width:min(520px, calc(100% - 28px));
  border-radius:18px;
  border:1px solid rgba(255,255,255,.16);
  background:rgba(17,24,39,.92);
  padding:18px 16px;
  box-shadow:0 20px 60px rgba(0,0,0,.45);
  text-align:center;
}
.gameOverTitle{ font-size:22px; font-weight:1000; margin-bottom:8px; }
.gameOverDesc{ color:rgba(255,255,255,.78); font-weight:800; margin-bottom:14px; }
.scoreLine{
  font-weight:1000;
  font-size:16px;
  margin-bottom:6px;
}
.bestScoreLine{
  color:rgba(255,255,255,.78);
  font-weight:900;
  margin-bottom:12px;
}
.replayBtn{
  padding:10px 16px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.18);
  background:rgba(255,255,255,.10);
  color:#fff;
  font-weight:1000;
  cursor:pointer;
}
.replayBtn:active{ transform: translateY(1px); }

.audioPanel{
  position:absolute;
  left:0px;
  bottom:-5px;
  z-index:40;
  display:flex;
  flex-direction:column;
  gap:10px;
  padding:10px 12px;
  border-radius:0;
  border:none;
  background:none;
  backdrop-filter:none;
  width: 220px;
  pointer-events:auto;
}
.spellBtn{
  position:absolute;
  left:50%;
  bottom:170px;
  transform:translateX(-50%);
  width:92px;
  height:92px;
  border-radius:0;
  border:none;
  background:transparent;
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  z-index:42;
  transition:transform 0.12s ease-out;
}
.spellBtn:hover{ transform: translateX(-50%) scale(1.06); }
.spellBtn.cooldown{
  transform:translateX(-50%);
}
.spellBtn::before{
  content:"";
  position:absolute;
  inset:0;
  background:rgba(255,255,255,.06);
  mask-image: url("./assets/spell_glue.png");
  mask-repeat: no-repeat;
  mask-position: center;
  mask-size: 92px 92px;
  -webkit-mask-image: url("./assets/spell_glue.png");
  -webkit-mask-repeat: no-repeat;
  -webkit-mask-position: center;
  -webkit-mask-size: 92px 92px;
  pointer-events:none;
}
.spellBtn img{
  width:92px;
  height:92px;
  image-rendering:pixelated;
}
.spellBtn:active{ transform: translate(-50%, 1px); }
.spellBtn[disabled]{
  opacity:.45;
  cursor:not-allowed;
  transform:translateX(-50%);
}
.spellBtn.cooldown::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(to top,
      rgba(255,255,255,.50) 0%,
      rgba(255,255,255,.50) calc(var(--p, 0) * 100%),
      rgba(255,255,255,.12) calc(var(--p, 0) * 100%),
      rgba(255,255,255,.12) 100%);
  mask-image: url("./assets/spell_glue.png");
  mask-repeat: no-repeat;
  mask-position: center;
  mask-size: 82px 82px;
  -webkit-mask-image: url("./assets/spell_glue.png");
  -webkit-mask-repeat: no-repeat;
  -webkit-mask-position: center;
  -webkit-mask-size: 82px 82px;
  pointer-events:none;
}
.speedRow{
  display:flex;
  align-items:center;
  gap:8px;
}
.settingsBtn{
  width:34px;
  height:34px;
  border-radius:8px;
  border:1px solid rgba(255,255,255,.2);
  background:rgba(255,255,255,.12);
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  align-self:flex-start;
}
.settingsBtn img{
  width:18px;
  height:18px;
  image-rendering:pixelated;
}
.settingsBtn:active{ transform: translateY(1px); }
.audioPanel .settingsMenu{
  display:none;
  flex-direction:column;
  gap:10px;
}
.audioPanel.is-open .settingsMenu{
  display:flex;
}
.pauseBtn{
  width:34px;
  height:34px;
  border-radius:8px;
  border:1px solid rgba(255,255,255,.2);
  background:rgba(255,255,255,.12);
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  align-self:flex-start;
}
.pauseBtn img{
  width:18px;
  height:18px;
  image-rendering:pixelated;
}
.pauseBtn.is-paused{
  box-shadow:0 0 0 1px rgba(242,193,75,.55);
}
.pauseBtn:active{ transform: translateY(1px); }
.speedBtn{
  padding:6px 10px;
  border-radius:10px;
  border:1px solid rgba(255,255,255,.2);
  background:rgba(255,255,255,.12);
  color:#fff;
  font-weight:1000;
  cursor:pointer;
  align-self:flex-start;
}
.speedBtn:active{ transform: translateY(1px); }
.speedBtn.is-fast{ color:var(--gold); }
.speedBtn.is-faster{ color:#ef4444; }
.creativePanel{
  position:absolute;
  right:-5px;
  bottom:-5px;
  z-index:45;
  display:flex;
  flex-direction:column;
  gap:8px;
  padding:10px 12px;
  border-radius:0;
  border:none;
  background:none;
  backdrop-filter:none;
  width: 220px;
  pointer-events:auto;
}
.creativePanel:not(.is-collapsed){
  border-radius:14px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(0,0,0,.28);
  backdrop-filter: blur(6px);
}
.creativePanel.is-collapsed .creativeTitle,
.creativePanel.is-collapsed .creativeRow{
  display:none;
}
.creativeToggle{
  align-self:flex-end;
  padding:4px 8px;
  border-radius:8px;
  border:1px solid rgba(255,255,255,.2);
  background:rgba(255,255,255,.14);
  color:#fff;
  font-weight:900;
  cursor:pointer;
  font-size:12px;
}
.creativeToggle:active{ transform: translateY(1px); }
.creativeTitle{
  font-weight:1000;
  font-size:12px;
  letter-spacing:.4px;
  text-transform:uppercase;
  color:rgba(255,255,255,.85);
}
.creativeRow{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
  font-size:12px;
  color:rgba(255,255,255,.9);
  font-weight:800;
}
.creativeInput{
  width:70px;
  border-radius:8px;
  border:1px solid rgba(255,255,255,.2);
  background:rgba(255,255,255,.08);
  color:#fff;
  padding:4px 6px;
  font-size:12px;
  font-weight:900;
}
.creativeSelect{
  flex:1;
  min-width:90px;
  border-radius:8px;
  border:1px solid rgba(255,255,255,.2);
  background:rgba(255,255,255,.08);
  color:#691515;
  padding:4px 6px;
  font-size:12px;
  font-weight:900;
}
.creativeBtn{
  padding:4px 8px;
  border-radius:8px;
  border:1px solid rgba(255,255,255,.2);
  background:rgba(255,255,255,.12);
  color:#fff;
  font-weight:900;
  cursor:pointer;
}
.creativeBtn:active{ transform: translateY(1px); }
.audioRow{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  font-weight:900;
  color:rgba(255,255,255,.9);
  font-size:12px;
}
.audioRow input[type="range"]{ width: 130px; cursor:pointer; }
.audioVal{
  width: 34px;
  text-align:right;
  color:rgba(255,255,255,.8);
  font-weight:900;
  font-size:12px;
}

.codexBtn{
  position:relative;
  width:96px;
  height:70px;
  border:none;
  background:none;
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  z-index:60;
  margin-bottom:6px;
  transition: transform .12s ease, filter .12s ease;
}
.codexBtn:hover{
  transform: scale(1.08);
  filter: brightness(1.08);
}
.codexBtn img{
  width:96px;
  height:70px;
  image-rendering:pixelated;
}
.codexBtnStart{
  position:absolute;
  right:20px;
  bottom:20px;
}
.codexPanel{
  position:absolute;
  inset:0;
  display:none;
  align-items:center;
  justify-content:center;
  z-index:110;
  background:rgba(3,7,14,.65);
  font-family:"Pixeled","Pixel","Pixeloid Sans","Press Start 2P","Courier New",monospace;
  font-weight:900;
  font-size:20px;
}
.codexPanel.is-open{ display:flex; }
.codexPanel[data-page="slime"] .codexWindow{ --codex-bg:url("./assets/codex_slime.png"); }
.codexPanel[data-page="monsters"] .codexWindow{ --codex-bg:url("./assets/codex_monster.png"); }
.codexPanel[data-page="human"] .codexWindow{ --codex-bg:url("./assets/codex_human.png"); }
.codexPanel[data-page="elements"] .codexWindow{ --codex-bg:url("./assets/codex_elements.png"); }
.codexPanel[data-page="plants"] .codexWindow{ --codex-bg:url("./assets/codex_plants.png"); }
.codexPanel[data-page="steampunk"] .codexWindow{ --codex-bg:url("./assets/codex_steampunk.png"); }
.codexPanel[data-page="events"] .codexWindow{ --codex-bg:url("./assets/codex_events.png"); }
.codexPanel[data-page="upgrades"] .codexWindow{ --codex-bg:url("./assets/codex_upgrades.png"); }
.codexWindow{
  --codex-width: min(620px, calc(100% - 28px), calc(72vh / 0.6875));
  width:var(--codex-width);
  height:calc(var(--codex-width) * 0.6875);
  background:transparent;
  border:none;
  border-radius:0;
  box-shadow:none;
  position:relative;
}
.codexWindow::before{
  content:"";
  position:absolute;
  inset:0;
  background-image:var(--codex-bg);
  background-repeat:no-repeat;
  background-position:center;
  background-size:contain;
  transform:scale(2);
  transform-origin:center;
  image-rendering:pixelated;
  z-index:0;
}
.codexWindow > *{
  position:relative;
  z-index:1;
}
.codexHeader{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  padding:12px 14px;
}
.codexClose{
  border:none;
  background:rgba(255,255,255,.12);
  color:#fff;
  font-weight:900;
  border-radius:10px;
  width:30px;
  height:30px;
  cursor:pointer;

}
.codexTabs{
  position:absolute;
  inset:0;
  pointer-events:none;
  z-index:5;
}
.codexTab{
  display:flex;
  align-items:center;
  gap:0;
  padding:0;
  width:85px;
  height:55px;
  min-width:85px;
  min-height:55px;
  flex:0 0 85px;
  border-radius:12px;
  border:1px solid transparent;
  background:transparent;
  color:transparent;
  font-weight:900;
  font-size:12px;
  cursor:pointer;
  white-space:nowrap;
  position:absolute;
  left:var(--x, 0px);
  top:var(--y, 0px);
  pointer-events:auto;
}
.codexTab.is-active{
  background:transparent;
  border-color:transparent;
}
.codexBody{
  padding:12px 14px 16px;
  overflow:visible;
  max-height:none;
  height:100%;
  position:relative;
}
.codexSpread{
  position:relative;
  display:block;
  width:100%;
  height:100%;
}
.codexPageLeft,
.codexPageRight{
  background:transparent;
  color:#111;
  border-radius:6px;
  padding:12px 0;
  width:350px;
  height:500px;
  box-sizing:border-box;
  position:absolute;
  left:var(--x, 10px);
  top:var(--y, 0px);
}
.codexPage{ display:none; }
.codexPage.is-active{
  display:block;
  height:100%;
}
.codexSectionTitle{
  font-size:13px;
  font-weight:1000;
  margin-bottom:10px;
  color:#111;
}
.codexUnitList{
  display:flex;
  flex-direction:column;
  gap:16px;
  width:100%;
  height:100%;
}
.codexUnit{
  display:flex;
  flex-direction:column;
  gap:8px;
  padding:10px;
  border-radius:0;
  border:none;
  background:transparent;
}
.codexSpriteStack{
  width:64px;
  height:64px;
  position:relative;
  overflow:visible;
  border-radius:0;
  border:none;
  background:transparent;
  flex:0 0 auto;
  display:flex;
  align-items:flex-start;
  justify-content:flex-start;
}
.codexSprite{
  width:64px;
  height:64px;
  position:relative;
  overflow:visible;
  border-radius:0;
  border:none;
  background:transparent;
  display:flex;
  align-items:flex-start;
  justify-content:flex-start;
}
.codexSpriteExtra{
  position:absolute;
  left:-26px;
  top:95px;
  image-rendering:pixelated;
}
.codexSpriteFrame{
  position:relative;
  left:120px;
  top:85px;
}
.codexSpriteFrame.is-tower{
  top:65px;
}
.codexSprite img{
  image-rendering:pixelated;
  display:block;
}
.codexSpriteFrame{
  image-rendering:pixelated;
}
.codexUnitBody{
  flex:1;
  display:flex;
  flex-direction:column;
  gap:6px;
}
.codexUnitHeader{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:flex-start;
  gap:12px;
}
.codexUnitName{
  font-weight:1000;
  font-size:24px;
  color:#111;
  position:relative;
  left:0px;
  top:110px;
  width:100%;
  min-width:320px;
  max-width:none;
  text-align:center;
  flex:1 0 auto;
}
.codexUnitCost{
  display:flex;
  flex-direction:row;
  align-items:center;
  gap:6px;
  position:relative;
  left:-10px;
  top:76px;
  
  font-weight:1000;
  color:#111;
  font-size:26px;
}
.codexUnitCost img{
  width:46px;
  height:46px;
  image-rendering:pixelated;
  position:relative;
  top:5px;
}
.codexStats{
  position:relative;
  min-height:200px;
  font-size:14px;
  color:#111;
  font-weight:900;
}
.codexStatItem{
  position:absolute;
  left:var(--x, 0px);
  top:var(--y, 0px);
  display:flex;
  align-items:center;
  gap:8px;
}
.codexStatItem.is-skill{
  gap:0;
  margin:0;
  padding:0;
  line-height:2;
}
.codexStatItem img{
  width:24px;
  height:24px;
  image-rendering:inherit;
}
.codexNotes{
  width:100%;
  margin-top:6px;
  min-height:54px;
  background:#fff;
  border:1px solid #cfcfcf;
  border-radius:6px;
  color:#111;
  padding:6px 8px;
  font-weight:700;
  font-size:11px;
}
.codexPlaceholder{
  color:rgba(255,255,255,.7);
  font-weight:900;
  padding:16px 4px;
}
.codexListTitle{
  font-weight:1000;
  margin-bottom:8px;
  color:#111;
  font-size:12px;
}
.codexList{
  display:flex;
  flex-direction:column;
  gap:12px;
  font-weight:900;
  color:#111;
  font-size:16px;
  line-height:1.15;
}
.codexListItem{
  background:none;
  border:none;
  padding:0;
  text-align:left;
  font:inherit;
  color:inherit;
  cursor:pointer;
  transition:transform 120ms ease;
  display:flex;
  align-items:baseline;
  gap:12px;
}
.codexListItem--tier{
  color:#f59e0b;
}
.codexListItem--tower{
  color:#16a34a;
}
.codexListItem--baseStart{
  margin-top:4px;
}
.codexListIndex{
  display:inline-block;
  width:60px;
  text-align:right;
  flex:0 0 60px;
}
.codexListItem:hover{
  transform:scale(1.08);
}
.codexListItem.is-active{
  font-weight:1000;
}
.codexFactionTitle{
  font-size:40px;
  font-weight:1000;
  text-align:center;
  margin:10px 0 14px;
}

.startOverlay{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  z-index:120;
  background:rgba(0,0,0,.55);
  backdrop-filter: blur(6px);
}
.startCard{
  width:min(520px, calc(100% - 28px));
  border-radius:18px;
  border:1px solid rgba(255,255,255,.16);
  background:rgba(17,24,39,.92);
  padding:18px 16px;
  box-shadow:0 20px 60px rgba(0,0,0,.45);
  text-align:center;
}
.startPanel{
  display:flex;
  flex-direction:column;
  gap:12px;
  text-align:left;
}
.bestScoreStart{
  font-weight:1000;
  font-size:16px;
  margin:6px 0 12px;
  color:rgba(255,255,255,.9);
}
.startSection{
  display:flex;
  flex-direction:column;
  gap:8px;
}
.startSectionTitle{
  font-weight:900;
  letter-spacing:.2px;
}
.startSplit{
  display:flex;
  gap:12px;
}
.startColumn{
  flex:1 1 0;
  display:flex;
  flex-direction:column;
  gap:8px;
}
.startGrid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:8px;
}
.startOption{
  border:1px solid rgba(255,255,255,.18);
  background:rgba(16,24,38,.9);
  color:#fff;
  font-weight:800;
  padding:8px 10px;
  border-radius:10px;
  cursor:pointer;
}
.startOption.is-active{
  border-color:#5eead4;
  box-shadow:0 0 0 2px rgba(94,234,212,.25);
}
.startOption.is-disabled{
  opacity:.45;
  cursor:not-allowed;
}
.startTitle{ font-size:26px; font-weight:1000; margin:2px 0 10px; letter-spacing:.2px; }
.startDesc{ color:rgba(255,255,255,.78); font-weight:800; margin-bottom:14px; }
.playBtn{
  padding:12px 18px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.18);
  background:rgba(255,255,255,.12);
  color:#fff;
  font-weight:1000;
  cursor:pointer;
  min-width:180px;
  font-size:16px;
}
.playBtn:disabled{
  opacity:.5;
  cursor:not-allowed;
}
.playBtn:active{ transform: translateY(1px); }
.loadPill{
  position:absolute;
  top:12px;
  left:12px;
  z-index:80;
  padding:8px 10px;
  background:rgba(10,14,40,0.85);
  border:1px solid rgba(255,255,255,0.2);
  border-radius:8px;
  color:#fff;
  font-size:12px;
  font-weight:900;
  display:flex;
  flex-direction:column;
  gap:6px;
  min-width:240px;
  pointer-events:none;
}
.startOverlay .loadPill{
  top:16px;
  left:16px;
}
.loadBar{
  width:100%;
  height:6px;
  background:rgba(255,255,255,0.15);
  border-radius:4px;
  overflow:hidden;
}
.loadBarFill{
  width:0%;
  height:100%;
  background:#7dd3fc;
  transition:width 0.08s linear;
}
.loadText{
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
