@font-face {
  font-family: 'PressStart2P';
  src: url('./assets/external/fonts/PressStart2P-Regular.ttf') format('truetype');
  font-display: swap;
}

@font-face {
  font-family: 'VT323Custom';
  src: url('./assets/external/fonts/VT323-Regular.ttf') format('truetype');
  font-display: swap;
}

@font-face {
  font-family: 'ZCOOLKuaiLe';
  src: url('./assets/external/fonts/ZCOOLKuaiLe-Regular.ttf') format('truetype');
  font-display: swap;
}

:root {
  --bg-tile: url('./assets/svg/backgrounds/pastel-stars.svg');
}

* { box-sizing: border-box; }
html, body { height: 100%; }
body {
  margin: 0;
  font-family: 'VT323Custom', 'ZCOOLKuaiLe', 'Noto Sans SC', 'PingFang SC', 'Microsoft YaHei', 'WenQuanYi Micro Hei', system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji", "Segoe UI Emoji";
  background-image: var(--bg-tile);
  background-size: 400px 400px;
  color: var(--ink);
}

.stage {
  min-height: 100vh;
  display: grid;
  place-items: center;
  padding: 24px;
}

.egg {
  position: relative;
  width: 360px;
  height: 460px;
}

.egg-shell {
  width: 100%;
  height: 100%;
  display: block;
}

.screen {
  position: absolute;
  left: 50%;
  top: 46%;
  width: 170px;
  height: 130px;
  transform: translate(-50%, -50%);
  display: grid;
  place-items: center;
  overflow: hidden;
}

.pet {
  width: 110px;
  height: 110px;
  filter: drop-shadow(0 2px 4px rgba(40,40,60,0.12));
  transition: transform 220ms ease, filter 220ms ease;
}

.hud-outside {
  position: absolute;
  top: -100px;
  left: 50%;
  transform: translateX(-50%);
  width: 220px;
  display: grid;
  gap: 10px;
}

.hud-outside .stat { display: grid; grid-template-columns: 28px 1fr; align-items: center; gap: 10px; }
.hud-outside .icon { width: 28px; height: 28px; opacity: 0.95; }
.hud-outside .bar { height: 10px; background: #eef2ff; border-radius: 10px; overflow: hidden; border: 1px solid #cfd8ff; }
.hud-outside .fill { height: 100%; width: 50%; background: linear-gradient(90deg, #8aa4ff, #f4accb); }

.controls {
  position: absolute;
  left: 50%;
  bottom: -20px;
  transform: translateX(-50%);
  display: grid;
  grid-template-columns: repeat(3, 120px);
  grid-template-rows: auto auto;
  align-items: center;
  justify-items: center;
  gap: 12px 14px;
}

.controls button {
  font-family: 'PressStart2P', 'ZCOOLKuaiLe', 'Noto Sans SC', 'PingFang SC', 'Microsoft YaHei', 'WenQuanYi Micro Hei', monospace;
  font-size: 12px;
  padding: 10px 12px;
  border-radius: 12px;
  background: var(--paper);
  border: 2px solid var(--accent);
  box-shadow: var(--shadow-sm);
  color: var(--ink);
  cursor: pointer;
  min-width: 110px;
}

.controls button:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
}

.char-label {
  font-family: 'PressStart2P', 'ZCOOLKuaiLe', 'Noto Sans SC', 'PingFang SC', 'Microsoft YaHei', 'WenQuanYi Micro Hei', monospace;
  font-size: 11px;
  padding: 8px 0;
  line-height: 1;
}

.char-select {
  font-family: 'PressStart2P', 'ZCOOLKuaiLe', 'Noto Sans SC', 'PingFang SC', 'Microsoft YaHei', 'WenQuanYi Micro Hei', monospace;
  font-size: 12px;
  padding: 10px 12px;
  border-radius: 12px;
  background: var(--paper);
  border: 2px solid var(--accent-2);
  color: var(--ink);
  height: 40px; /* 统一 Chrome/Safari 高度渲染 */
  line-height: 1.2; /* 避免不同浏览器默认行高差异 */
}

.area-label { grid-column: 1; grid-row: 1; justify-self: end; align-self: center; }
.area-select { grid-column: 2 / 4; grid-row: 1; width: 180px; justify-self: start; align-self: center; }
.area-feed { grid-column: 1; grid-row: 2; }
.area-play { grid-column: 2; grid-row: 2; }
.area-clean { grid-column: 3; grid-row: 2; }

/* simple animations */
.pet.bounce { transform: translateY(-8px) scale(1.03); }
.pet.spin { transform: rotate(-6deg) scale(1.02); }
.pet.shake { transform: translateX(2px); }

/* ensure image fits both svg and raster */
.pet { object-fit: contain; }

/* screen toast */
.screen .toast {
  position: absolute;
  inset: auto 8px 8px 8px;
  padding: 6px 10px;
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.85);
  border: 1px solid rgba(138, 164, 255, 0.5);
  font-family: 'PressStart2P', 'ZCOOLKuaiLe', 'Noto Sans SC', 'PingFang SC', 'Microsoft YaHei', 'WenQuanYi Micro Hei', monospace;
  font-size: 10px;
  color: var(--ink);
  text-align: center;
  box-shadow: var(--shadow-sm);
  animation: toast-in 280ms ease;
}

@keyframes toast-in { from { opacity: 0; transform: translateY(6px);} to { opacity: 1; transform: translateY(0);} }

/* Modal */
.modal.hidden { display: none; }
.modal { position: fixed; inset: 0; z-index: 40; }
.modal-backdrop { position: absolute; inset: 0; background: rgba(0,0,0,0.25); backdrop-filter: blur(2px); }
.modal-card { position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%); width: min(92vw, 420px); background: var(--paper); border-radius: 16px; box-shadow: var(--shadow-md); display: grid; grid-template-rows: auto 1fr auto; overflow: hidden; }
.modal-header { display: flex; align-items: center; justify-content: space-between; padding: 10px 14px; background: linear-gradient(90deg, var(--lavender-100), var(--pink-200)); border-bottom: 1px solid rgba(0,0,0,0.06); font-family: 'PressStart2P', 'ZCOOLKuaiLe', monospace; font-size: 12px; }
#chatClose { border: none; background: transparent; font-size: 20px; cursor: pointer; line-height: 1; }
.modal-log { padding: 12px; max-height: 50vh; overflow: auto; display: grid; gap: 8px; }
.msg { padding: 8px 10px; border-radius: 12px; font-size: 13px; }
.msg.me { background: #e9f0ff; justify-self: end; }
.msg.npc { background: #ffe9f2; justify-self: start; }
.msg .meta { opacity: 0.6; font-size: 10px; margin-top: 4px; }
.modal-form { display: grid; grid-template-columns: 1fr auto; gap: 8px; padding: 10px 12px 12px; }
#chatInput { padding: 10px 12px; border-radius: 12px; border: 1px solid #cfd8ff; font-size: 14px; }
.modal-form button { padding: 10px 14px; border-radius: 12px; border: 2px solid var(--accent); background: var(--paper); font-family: 'PressStart2P', 'ZCOOLKuaiLe', 'Noto Sans SC', 'PingFang SC', 'Microsoft YaHei', 'WenQuanYi Micro Hei', monospace; font-size: 12px; cursor: pointer; }

/* Debug indicator */
#debugIndicator {
  position: fixed;
  right: 14px;
  bottom: 14px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 10px;
  border-radius: 999px;
  border: 1px solid rgba(0,0,0,0.1);
  background: rgba(255,255,255,0.9);
  box-shadow: var(--shadow-sm);
  font-family: 'PressStart2P', 'ZCOOLKuaiLe', 'Noto Sans SC', 'PingFang SC', 'Microsoft YaHei', 'WenQuanYi Micro Hei', monospace;
  font-size: 11px;
  color: var(--ink);
}
.debug-dot { width: 10px; height: 10px; border-radius: 50%; background: #ccc; display: inline-block; }
.debug-enabled .debug-dot { background: #22c55e; }
.debug-disabled .debug-dot { background: #ef4444; }
