/* ====================================================
   MOLES — ASCII Roguelike
   ==================================================== */

:root {
  --bg:          #0a0a0a;
  --bg-panel:    #111111;
  --bg-panel2:   #0d0d0d;
  --border:      #2a2a2a;
  --text:        #cccccc;
  --dim:         #555555;
  --accent:      #888888;

  /* Tile colors */
  --col-sky:       #1a1a2e;
  --col-grass:     #228b22;
  --col-dirt:      #8b4513;
  --col-clay:      #a0522d;
  --col-sand:      #c8a22a;
  --col-gravel:    #7a7a7a;
  --col-rock:      #505050;
  --col-limestone: #aaaaaa;
  --col-bedrock:   #333333;
  --col-tunnel:    #000000;
  --col-water:     #4169e1;
  --col-cave:      #444444;
  --col-loam:      #5c7a3e;

  /* Entity colors */
  --col-mole:         #ffffff;
  --col-mole-partner: #00cccc;
  --col-centipede:  #cc5500;
  --col-mole-rat:   #b8860b;
  --col-cave-leech: #8b0000;
  --col-blind-snake:#556b2f;
  --col-merchant:   #ffd700;
  --col-dollar-bill:#85bb65;

  /* Item colors */
  --col-worm:     #ff69b4;
  --col-grub:     #fffacd;
  --col-larva:    #f5f5f5;
  --col-mushroom: #9b59b6;
  --col-fossil:   #d2b48c;
  --col-ruby:     #e74c3c;
  --col-crystal:  #00ffff;
  --col-coin:     #ffd700;
  --col-root:     #d2b48c;
  /* Crafted consumables */
  --col-dirt-coffee:   #c8a22a;
  --col-mole-mittens:  #b8860b;
  --col-clay-poultice: #88cc88;
  --col-gravel-jerky:  #aaaaaa;
  --col-rock-cake:     #cc8844;
  --col-earthen-tonic: #88ddcc;
  --col-rod-of-dirt:   #8b4513;

  /* Bar colors */
  --bar-hp:     #e74c3c;
  --bar-energy: #3498db;
  --bar-hunger: #f39c12;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html, body {
  background: var(--bg);
  color: var(--text);
  font-family: 'IBM Plex Mono', 'Courier New', Courier, monospace;
  font-size: 14px;
  line-height: 1.4;
  height: 100%;
  overflow: hidden;
  user-select: none;
}

/* ---- Layout ---- */

#game, .game-container {
  display: flex;
  flex-direction: column;
  height: 100vh;
  max-width: 900px;
  margin: 0 auto;
  border: 1px solid var(--border);
}

.title-bar {
  background: var(--bg-panel);
  border-bottom: 1px solid var(--border);
  padding: 4px 10px;
  font-size: 12px;
  color: var(--accent);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  flex-shrink: 0;
}

.main-area {
  display: flex;
  flex: 1;
  overflow: hidden;
  min-height: 0;
}

.viewport {
  flex: 1;
  background: #000;
  padding: 4px 6px;
  overflow: hidden;
  font-size: 14px;
  line-height: 1.35;
  white-space: pre;
  cursor: default;
  font-family: inherit;
  border: none;
}

.panel {
  width: 130px;
  flex-shrink: 0;
  background: var(--bg-panel);
  padding: 8px 6px;
  overflow: hidden;
  font-size: 12px;
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.stats-panel {
  border-right: 1px solid var(--border);
}

.side-panel {
  border-left: 1px solid var(--border);
}

.msg-log {
  background: var(--bg-panel2);
  border-top: 1px solid var(--border);
  padding: 4px 10px;
  font-size: 12px;
  min-height: 80px;
  max-height: 100px;
  overflow-y: auto;
  flex-shrink: 0;
  line-height: 1.5;
}

/* ---- Stats Panel ---- */

.stat-row {
  display: flex;
  align-items: center;
  gap: 4px;
  margin-bottom: 2px;
}
.stat-label {
  width: 20px;
  font-size: 11px;
  color: var(--accent);
  flex-shrink: 0;
}
.stat-label.warn { color: var(--bar-hunger); }
.stat-bar { flex: 1; font-size: 11px; }
.stat-val { font-size: 10px; color: var(--dim); white-space: nowrap; }
.stat-divider { border-top: 1px solid var(--border); margin: 4px 0; }
.stat-item { font-size: 11px; color: var(--text); }
.stat-hint { font-size: 10px; color: var(--dim); }
.stat-buff { font-size: 11px; color: #b8860b; font-style: italic; }

.bar-hp     { color: var(--bar-hp); }
.bar-energy { color: var(--bar-energy); }
.bar-hunger { color: var(--bar-hunger); }
.bar-empty  { color: #2a2a2a; }

/* ---- Side Panel ---- */

.panel-title {
  font-size: 11px;
  color: var(--accent);
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-bottom: 4px;
}
.panel-divider { border-top: 1px solid var(--border); margin: 4px 0; }
.panel-item { font-size: 11px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.dim-text { color: var(--dim); }
.zone-text { color: #88aacc; font-size: 11px; }

/* ---- Message log types ---- */

.msg-normal  { color: var(--text); }
.msg-dig     { color: #88aa88; }
.msg-eat     { color: #aaddaa; }
.msg-pickup  { color: #aadddd; }
.msg-kill    { color: #dd8844; }
.msg-damage  { color: #dd4444; }
.msg-danger  { color: #ff2222; font-weight: bold; }
.msg-warn    { color: #ddaa44; }
.msg-info    { color: #6688aa; }
.msg-gameover { color: #ff4444; font-weight: bold; }

/* ---- Tile colors ---- */

.tile-sky       { color: var(--col-sky);       }
.tile-grass     { color: var(--col-grass);     }
.tile-dirt      { color: var(--col-dirt);      }
.tile-clay      { color: var(--col-clay);      }
.tile-sand      { color: var(--col-sand);      }
.tile-gravel    { color: var(--col-gravel);    }
.tile-rock      { color: var(--col-rock);      }
.tile-limestone { color: var(--col-limestone); }
.tile-bedrock   { color: var(--col-bedrock);   }
.tile-tunnel    { color: var(--col-tunnel);    }
.tile-water     { color: var(--col-water);     }
.tile-cave      { color: var(--col-cave);      }
.tile-loam      { color: var(--col-loam);      }

/* ---- Entity colors ---- */

.entity-mole, .mole         { color: var(--col-mole);         font-weight: bold; }
.entity-mole-partner        { color: var(--col-mole-partner); font-weight: bold; }
.entity-mole-partner-dead   { color: #336666; }
.centipede                 { color: var(--col-centipede);  }
.mole-rat                  { color: var(--col-mole-rat);   }
.cave-leech                { color: var(--col-cave-leech); }
.blind-snake               { color: var(--col-blind-snake);}
.merchant                  { color: var(--col-merchant);   font-weight: bold; }
.friendly-entity           { color: #ffd700 !important;    } /* overrides hostile colour */

/* ---- Item colors ---- */

.item-worm     { color: var(--col-worm);     }
.item-grub     { color: var(--col-grub);     }
.item-larva    { color: var(--col-larva);    }
.item-mushroom { color: var(--col-mushroom); }
.item-fossil   { color: var(--col-fossil);   }
.item-ruby     { color: var(--col-ruby);     }
.item-crystal  { color: var(--col-crystal);  }
.item-coin     { color: var(--col-coin);     }
.item-root         { color: var(--col-root);         }
.item-dollar-bill  { color: var(--col-dollar-bill);  }
/* Crafted consumables */
.item-dirt-coffee   { color: var(--col-dirt-coffee);   }
.item-mole-mittens  { color: var(--col-mole-mittens);  }
.item-clay-poultice { color: var(--col-clay-poultice); }
.item-gravel-jerky  { color: var(--col-gravel-jerky);  }
.item-rock-cake     { color: var(--col-rock-cake);     }
.item-earthen-tonic { color: var(--col-earthen-tonic); }
.item-rod-of-dirt   { color: var(--col-rod-of-dirt);   }
/* Temple / bounty */
.item-bounty           { color: #d4a017; }
.entity-temple-altar   { color: #c8a84b; font-weight: bold; }
.temple-ok             { color: #88dd88; }
.temple-no             { color: #555555; }
.temple-owned          { color: #444444; }

/* ---- Title / Help screens ---- */

/* Crafting screen styles (applied inside viewport pre) */
.craft-ok          { color: #88dd88; }
.craft-no          { color: #666666; }
.craft-locked      { color: #3a3a3a; }
.craft-ingredients { color: #aa8855; font-size: 13px; }
.craft-desc        { color: #557799; font-size: 13px; }
.shop-header       { color: #ccaa44; letter-spacing: 1px; }

.title-screen, .help-screen {
  color: var(--text);
  padding: 10px 20px;
  font-family: inherit;
  font-size: 14px;
  line-height: 1.5;
  white-space: pre;
}

/* ---- Dead overlay text ---- */

.dead-text  { color: #ff4444; font-weight: bold; }
.warn-text  { color: #ffaa44; font-weight: bold; }
.hint-text  { color: var(--dim); font-size: 11px; }

/* ---- Scrollbar ---- */

.msg-log::-webkit-scrollbar { width: 4px; }
.msg-log::-webkit-scrollbar-track { background: transparent; }
.msg-log::-webkit-scrollbar-thumb { background: var(--border); border-radius: 2px; }

/* ---- Mobile / small screens ---- */

@media (max-width: 700px) {
  body { font-size: 11px; }
  .panel { width: 90px; }
  .viewport { font-size: 11px; }
}
