/* ============================================================
   ANAM VALE — styles & animation suite
   All motion is CSS keyframes / transitions (no JS animation).
   Colours via custom properties for consistent theming.
   ============================================================ */

:root {
  --av-up: #2eb872;          /* gaining value */
  --av-down: #ff5d5d;        /* losing value  */
  --av-flat: #f5b942;        /* holding firm  */
  --anam-ink: #3c3358;
  --anam-card: #ffffff;
  --anam-card-soft: #f6f3ff;
  --anam-accent: #7c5cff;
  --anam-accent2: #18c5b6;
  --anam-gold: #ffb937;
  --anam-gold-grad: linear-gradient(135deg, #ffe680, #f5b301);  /* shiny coin gold */
  --anam-gold-deep: #d99400;   /* gold border */
  --anam-gold-ink: #7a5200;    /* readable text on gold */
  --anam-sky: #bfe7ff;
  --anam-border: #e6e0f8;
  --anam-radius: 18px;
  --anam-font: 'Comic Neue', 'Comic Sans MS', 'Segoe UI', system-ui, sans-serif;
}

/* ---------------- topbar chips (injected) ---------------- */
.stat-chip.aurars, .stat-chip.worth { cursor: pointer; }
.stat-chip.aurars { background: var(--anam-gold-grad); border-color: var(--anam-gold-deep); color: var(--anam-gold-ink); }
.stat-chip.worth { background: linear-gradient(135deg, #e8fff7, #d2f7ec); border-color: var(--anam-accent2); }
.aurar-spark { display: inline-block; animation: aurar-spark 2.8s ease-in-out infinite; }
@keyframes aurar-spark {
  0%, 88%, 100% { transform: none; filter: none; }
  92% { transform: scale(1.25) rotate(-10deg); filter: drop-shadow(0 0 6px var(--anam-gold)); }
  96% { transform: scale(1.1) rotate(8deg); }
}

/* ---------------- shell ---------------- */
#screen-anamvale { font-family: var(--anam-font); color: var(--anam-ink); }
/* Anam Vale sits on its own light panel so it stays readable on any
   Word Lab shop theme, including the dark ones */
#anamvale-root {
  max-width: 1020px; margin: 8px auto 30px; padding: 12px 12px 40px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.92), rgba(246, 243, 255, 0.94));
  border-radius: 26px; border: 2px solid rgba(124, 92, 255, 0.18);
}

.anam-head { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; margin: 8px 0 12px; }
.anam-title { margin: 0; flex: 1; font-size: 1.5rem; }
.anam-wallet { display: flex; gap: 8px; }
.aurar-chip, .worth-chip {
  border-radius: 999px;
  padding: 5px 12px; font-weight: 700; font-size: 0.95rem; white-space: nowrap;
}
.aurar-chip { background: var(--anam-gold-grad); border: 2px solid var(--anam-gold-deep); color: var(--anam-gold-ink); }
.worth-chip { background: var(--anam-card); border: 2px solid var(--anam-accent2); cursor: pointer; }
.worth-chip:hover { transform: scale(1.05); }

.anam-banner { border-radius: var(--anam-radius); overflow: hidden; margin-bottom: 12px;
  border: 3px solid var(--anam-border); background: var(--anam-sky); }
.anam-banner svg { display: block; width: 100%; height: clamp(110px, 22vw, 200px); }

.anam-body { animation: anam-fade-in 0.35s ease; }
@keyframes anam-fade-in { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: none; } }

.anam-note { color: #6a6293; font-size: 0.92rem; margin: 6px 2px 12px; }
.map-note { text-align: center; }
.anam-h3 { margin: 18px 4px 8px; font-size: 1.15rem; }

/* ---------------- cards & buttons ---------------- */
.anam-card {
  background: var(--anam-card); border: 2px solid var(--anam-border);
  border-radius: var(--anam-radius); padding: 14px; margin: 10px 0;
  box-shadow: 0 3px 0 rgba(124, 92, 255, 0.08);
}
.anam-empty { text-align: center; }
.anam-btn {
  font-family: var(--anam-font); font-weight: 700; font-size: 0.95rem;
  background: linear-gradient(180deg, #9d83ff, var(--anam-accent));
  color: #fff; border: none; border-radius: 14px; padding: 10px 16px;
  cursor: pointer; box-shadow: 0 3px 0 #5a3fd0; transition: transform 0.12s ease;
  touch-action: manipulation;
}
.anam-btn:hover { transform: translateY(-2px) scale(1.03); }
.anam-btn:active { transform: translateY(1px); box-shadow: 0 1px 0 #5a3fd0; }
.anam-back { background: linear-gradient(180deg, #4fd8cb, var(--anam-accent2)); box-shadow: 0 3px 0 #0e8d82; }
.anam-mini-btn {
  font-family: var(--anam-font); background: var(--anam-card-soft); border: 2px solid var(--anam-border);
  border-radius: 10px; padding: 3px 9px; cursor: pointer; font-size: 0.82rem; font-weight: 700; color: var(--anam-ink);
}
.anam-mini-btn:hover { border-color: var(--anam-accent); }
.anam-input {
  font-family: var(--anam-font); font-size: 1.1rem; padding: 8px 12px; margin: 10px 0;
  border: 2px solid var(--anam-border); border-radius: 12px; width: 80%;
}

.anam-toast {
  position: fixed; left: 50%; bottom: 26px; transform: translateX(-50%) translateY(80px);
  background: var(--anam-ink); color: #fff; font-family: var(--anam-font); font-weight: 700;
  padding: 11px 20px; border-radius: 999px; z-index: 999; opacity: 0;
  transition: transform 0.35s cubic-bezier(0.2, 1.4, 0.4, 1), opacity 0.3s;
  max-width: 88vw; text-align: center; font-size: 0.95rem; pointer-events: none;
}
.anam-toast.show { transform: translateX(-50%); opacity: 1; }

/* ---------------- world map ---------------- */
.anam-map-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: 10px;
}
.anam-area-card {
  font-family: var(--anam-font); background: var(--anam-card); color: var(--anam-ink);
  border: 2px solid var(--anam-border); border-radius: var(--anam-radius);
  padding: 14px 8px; cursor: pointer; text-align: center; display: flex;
  flex-direction: column; gap: 4px; align-items: center;
  transition: transform 0.15s ease, border-color 0.15s ease; touch-action: manipulation;
}
.anam-area-card:hover { transform: translateY(-3px) scale(1.03); border-color: var(--anam-accent); }
.anam-area-card .area-icon { font-size: 2rem; }
.anam-area-card small { color: #6a6293; font-size: 0.78rem; }
.scenic-card { background: var(--anam-card-soft); }
.scenic-card.is-locked { opacity: 0.75; filter: saturate(0.6); }

/* ---------------- tabs / grids ---------------- */
.anam-tabs { display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: 10px; }
.anam-tab {
  font-family: var(--anam-font); font-weight: 700; background: var(--anam-card-soft);
  border: 2px solid var(--anam-border); color: var(--anam-ink);
  border-radius: 999px; padding: 7px 14px; cursor: pointer;
}
.anam-tab.is-on { background: var(--anam-accent); color: #fff; border-color: var(--anam-accent); }

.item-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(225px, 1fr)); gap: 10px; }
.item-card { display: flex; flex-direction: column; gap: 8px; margin: 0; }
.item-head { display: flex; gap: 10px; align-items: center; }
.item-icon { font-size: 2rem; }
.item-blurb { font-size: 0.8rem; color: #6a6293; }
.item-price-row { display: flex; align-items: center; gap: 8px; font-size: 0.92rem; flex-wrap: wrap; }
.item-price { font-weight: 700; font-size: 1.05rem; }
.px-above { color: var(--av-down); font-size: 0.8rem; font-weight: 700; }
.px-below { color: var(--av-up); font-size: 0.8rem; font-weight: 700; }
.px-fair { color: #8d86ad; font-size: 0.8rem; }
.buy-btn { align-self: flex-start; }
.egg-sell-note { font-size: 0.8rem; color: #6a6293; }
.mini-good { text-align: center; margin: 0; padding: 10px; }
.mini-good small { display: block; color: #6a6293; }
.store-chip {
  display: inline-block; background: var(--anam-card-soft); border: 2px solid var(--anam-border);
  border-radius: 999px; padding: 4px 11px; margin: 3px 2px; font-size: 0.88rem; font-weight: 700;
}

/* ============================================================
   INVESTMENT VALUE BAR
   ============================================================ */
.avb { background: var(--anam-card-soft); border-radius: 12px; padding: 6px 8px 4px; }
.avb-chart, .avb-big { display: block; width: 100%; height: auto; overflow: visible; }
.avb-line {
  stroke-dasharray: 100; stroke-dashoffset: 100;
  animation: avb-draw 1.4s ease-out forwards;
}
@keyframes avb-draw { to { stroke-dashoffset: 0; } }
.avb-buy-dot {
  fill: #fff; stroke: var(--anam-accent); stroke-width: 2;
  animation: avb-buy-glow 3s ease-in-out infinite;
}
@keyframes avb-buy-glow {
  0%, 100% { filter: drop-shadow(0 0 1px var(--anam-accent)); }
  50% { filter: drop-shadow(0 0 5px var(--anam-accent)); }
}
/* the live dot pulses gently every 30s as a "this chart is alive" wink */
.avb-live-dot { animation: avb-pulse 30s ease-in-out infinite; }
@keyframes avb-pulse {
  0%, 97%, 100% { transform: scale(1); }
  98.5% { transform: scale(1.8); }
}
.avb-meta { display: flex; justify-content: space-between; align-items: center; font-size: 0.8rem; padding: 2px 2px 0; }
.avb-value { font-weight: 700; }
.avb-tag { color: #6a6293; font-weight: 700; }
.avb-up .avb-tag { color: var(--av-up); }
.avb-down .avb-tag { color: var(--av-down); }
.avb-flat .avb-tag { color: #b8860b; }
.avb-arrow { display: inline-block; }
.avb-arrow-up { animation: arrow-rise 1.6s ease-in-out infinite; }
.avb-arrow-down { animation: arrow-fall 1.6s ease-in-out infinite; }
@keyframes arrow-rise { 0%, 100% { transform: translateY(1px); } 50% { transform: translateY(-2px); } }
@keyframes arrow-fall { 0%, 100% { transform: translateY(-1px); } 50% { transform: translateY(2px); } }
.avb-gain { color: var(--av-up); font-weight: 700; }
.avb-loss { color: var(--av-down); font-weight: 700; }
.avb-empty { color: #8d86ad; font-size: 0.9rem; text-align: center; padding: 16px; }

/* ---------------- market board ---------------- */
.board-flash { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.board-side { margin: 0; }
.board-chip { padding: 5px 2px; font-size: 0.92rem; border-bottom: 1px dashed var(--anam-border); }
.board-table { display: flex; flex-direction: column; }
.board-row {
  display: grid; grid-template-columns: 1.4fr 130px 90px 30px; gap: 8px;
  align-items: center; padding: 6px 2px; border-bottom: 1px dashed var(--anam-border); font-size: 0.92rem;
}
.board-name { font-weight: 700; }
.board-price { text-align: right; font-weight: 700; }
.board-arrow { font-size: 1.05rem; text-align: center; }
.board-up { color: var(--av-up); animation: arrow-rise 1.6s ease-in-out infinite; }
.board-down { color: var(--av-down); animation: arrow-fall 1.6s ease-in-out infinite; }
.board-flat { color: var(--av-flat); }

/* ---------------- vault ---------------- */
.vault-top { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: 10px; }
.vault-stat { margin: 0; text-align: center; }
.vault-stat small { color: #6a6293; display: block; }
.vault-stat strong { font-size: 1.4rem; }
.vault-row {
  display: flex; gap: 10px; align-items: center; flex-wrap: wrap;
  padding: 7px 2px; border-bottom: 1px dashed var(--anam-border); font-size: 0.94rem;
}
.vault-name { flex: 1; font-weight: 700; min-width: 120px; }
.vault-paid { color: #8d86ad; font-size: 0.82rem; }
.vault-now { font-weight: 700; }
.tx-row { font-size: 0.88rem; }

/* ============================================================
   KINDREDS — artwork life
   ============================================================ */
.kart { width: 96px; margin: 0 auto; }
.kart svg { display: block; width: 100%; height: auto; overflow: visible; }
.kart-big { width: clamp(150px, 38vw, 210px); }
.kart-med { width: 130px; }
.kart-mini { width: 56px; }
.kart-missing { font-size: 0.8rem; color: #8d86ad; padding: 20px 4px; text-align: center; }

.kart .k-body, .kart .k-eye, .kart .k-tail, .kart .k-ear, .kart .k-wing {
  transform-box: fill-box; transform-origin: center;
}
.kart .k-body { animation: k-idle 3.2s ease-in-out infinite; transform-origin: 50% 90%; }
@keyframes k-idle { 0%, 100% { transform: translateY(0) scale(1); } 50% { transform: translateY(-3px) scale(1.012, 0.988); } }
.kart .k-eye { animation: k-blink 4.6s infinite; }
@keyframes k-blink { 0%, 94%, 100% { transform: scaleY(1); } 96.5% { transform: scaleY(0.08); } }
.kart .k-tail { animation: k-wag 2.4s ease-in-out infinite; transform-origin: 20% 80%; }
@keyframes k-wag { 0%, 100% { transform: rotate(-6deg); } 50% { transform: rotate(7deg); } }
.kart .k-ear { animation: k-ear 6s ease-in-out infinite; }
@keyframes k-ear { 0%, 91%, 100% { transform: rotate(0); } 94% { transform: rotate(-7deg); } 97% { transform: rotate(4deg); } }
.kart .k-wing { animation: k-flap 1.8s ease-in-out infinite; }
@keyframes k-flap { 0%, 100% { transform: rotate(-4deg); } 50% { transform: rotate(8deg); } }

/* moods & sleep on the Quarter stage */
.k-stage { position: relative; text-align: center; padding: 10px 0 4px; }
.k-stage.mood-happy .k-body { animation: k-happy 1.4s ease-in-out infinite; }
@keyframes k-happy {
  0%, 100% { transform: translateY(0); }
  30% { transform: translateY(-9px) scale(1.03, 0.97); }
  50% { transform: translateY(0) scale(0.98, 1.02); }
}
.k-stage.mood-hungry .k-body { animation: k-droop 3.4s ease-in-out infinite; }
.k-stage.mood-sleepy .k-body { animation: k-droop 4.4s ease-in-out infinite; }
@keyframes k-droop { 0%, 100% { transform: rotate(0); } 50% { transform: rotate(2.5deg) translateY(2px); } }
.k-sleeping .k-body { animation: k-breathe 3.6s ease-in-out infinite !important; }
.k-sleeping .k-eye { transform: scaleY(0.08); animation: none !important; }
@keyframes k-breathe { 0%, 100% { transform: scale(1); } 50% { transform: scale(1.025, 0.985); } }
.k-zzz {
  position: absolute; top: 6px; right: 22%; font-size: 1.5rem;
  animation: k-zzz-float 3s ease-in-out infinite;
}
@keyframes k-zzz-float {
  0% { opacity: 0; transform: translateY(6px) scale(0.7); }
  40% { opacity: 1; }
  100% { opacity: 0; transform: translateY(-16px) scale(1.15); }
}
.k-wear-row { font-size: 1.4rem; min-height: 1.6rem; }
.k-wear-icon { margin: 0 2px; }

.quarter-stage { text-align: center; }
.k-name { margin: 6px 0 2px; font-size: 1.3rem; }
.k-mood { color: #6a6293; font-weight: 700; margin-bottom: 8px; }
.k-bar-row { display: flex; align-items: center; gap: 8px; max-width: 340px; margin: 4px auto; font-size: 0.85rem; }
.k-bar-row span { width: 78px; text-align: right; font-weight: 700; }
.k-bar { flex: 1; height: 13px; background: #ece7fb; border-radius: 999px; overflow: hidden; }
.k-bar-fill { height: 100%; border-radius: 999px; background: linear-gradient(90deg, var(--anam-accent2), #6fe3a5); transition: width 0.6s ease; }
.k-bar-fill.low { background: linear-gradient(90deg, #ffb1b1, var(--av-down)); }

.care-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(135px, 1fr)); gap: 8px; }
.care-btn { display: flex; flex-direction: column; gap: 2px; padding: 9px 6px; font-size: 0.9rem; }
.care-btn small { font-weight: 400; font-size: 0.72rem; opacity: 0.9; }
.care-btn.is-on { outline: 3px solid var(--anam-gold); }
.k-switch-row { display: flex; gap: 8px; flex-wrap: wrap; justify-content: center; }
.k-switch {
  font-family: var(--anam-font); background: var(--anam-card-soft); border: 2px solid var(--anam-border);
  border-radius: 14px; padding: 6px; cursor: pointer; font-weight: 700; color: var(--anam-ink); font-size: 0.78rem;
}
.k-switch.is-active { border-color: var(--anam-accent); background: #efe9ff; }

/* ---------------- collection ---------------- */
.k-coll-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(128px, 1fr)); gap: 10px; }
.k-card {
  position: relative; background: var(--anam-card); border: 2px solid var(--anam-border);
  border-radius: var(--anam-radius); padding: 10px 6px; text-align: center; overflow: hidden;
}
.k-card-name { font-weight: 700; font-size: 0.9rem; margin-top: 4px; }
.k-card-rar { font-size: 0.72rem; color: #8d86ad; }
.k-card-owned { color: var(--av-up); font-weight: 700; font-size: 0.82rem; margin-top: 3px; }
.k-card-buy { margin-top: 5px; }
.k-card.is-unowned { border-style: dashed; }
.k-card.is-unowned .kart { opacity: 0.92; }
.k-card.is-owned { border-color: var(--anam-accent2); box-shadow: 0 0 12px rgba(24, 197, 182, 0.35); }
/* rarity treatments */
.rar-uncommon { box-shadow: 0 0 10px rgba(124, 92, 255, 0.22); }
.rar-rare::after {
  content: '✦'; position: absolute; top: 6px; right: 9px; color: var(--anam-gold);
  animation: rare-sparkle 2.2s ease-in-out infinite;
}
@keyframes rare-sparkle {
  0%, 100% { opacity: 0.4; transform: scale(0.8) rotate(0deg); }
  50% { opacity: 1; transform: scale(1.3) rotate(40deg); }
}
.rar-legendary { border-color: var(--anam-gold); }
.rar-legendary::before {
  content: ''; position: absolute; inset: 0; pointer-events: none;
  background: linear-gradient(110deg, transparent 30%, rgba(255, 215, 100, 0.35) 48%, transparent 65%);
  background-size: 240% 100%;
  animation: legend-shimmer 3.2s linear infinite;
}
@keyframes legend-shimmer { from { background-position: 130% 0; } to { background-position: -110% 0; } }
.rar-legendary::after {
  content: '👑'; position: absolute; top: 5px; right: 7px; font-size: 0.95rem;
}

/* ---------------- hatchery ---------------- */
.hatch-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(190px, 1fr)); gap: 10px; }
.hatch-card { text-align: center; margin: 0; }
.hatch-egg { font-size: 3rem; }
.egg-warm { animation: egg-warm 2.8s ease-in-out infinite; display: inline-block; }
@keyframes egg-warm {
  0%, 100% { transform: scale(1); filter: drop-shadow(0 0 2px #ffd27a); }
  50% { transform: scale(1.05); filter: drop-shadow(0 0 10px #ffb937); }
}
.egg-wobble { animation: egg-wobble 0.9s ease-in-out infinite; display: inline-block; transform-origin: 50% 90%; }
@keyframes egg-wobble {
  0%, 100% { transform: rotate(0); }
  20% { transform: rotate(-9deg); } 40% { transform: rotate(7deg); }
  60% { transform: rotate(-5deg); } 80% { transform: rotate(3deg); }
}
.hatch-card.is-ready { border-color: var(--anam-gold); box-shadow: 0 0 14px rgba(255, 185, 55, 0.45); }
.hatch-timer { color: #6a6293; font-weight: 700; font-size: 0.88rem; margin: 6px 0; }
.hatch-btn { margin: 6px 0; }
.hatch-sell { font-size: 0.82rem; color: #6a6293; margin: 6px 0; }
.hatch-reveal .kart-big { animation: hatch-pop 0.7s cubic-bezier(0.2, 1.6, 0.4, 1); }
@keyframes hatch-pop { from { transform: scale(0.2) rotate(-14deg); opacity: 0; } to { transform: none; opacity: 1; } }

/* ---------------- farm ---------------- */
.farm-card { margin: 0; }
.farm-bounce { display: inline-block; animation: k-idle 2.6s ease-in-out infinite; }
.cafe-row { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; padding: 8px 0; }
.cafe-seat { text-align: center; font-size: 1.2rem; }

/* ============================================================
   DANCE HALL — one keyframe style per classical piece
   ============================================================ */
.dance-floor { text-align: center; padding: 16px 0 8px; position: relative; }
.dancer { display: inline-block; }
.dance-notes { position: absolute; inset: 0; pointer-events: none; }
.dance-notes span { position: absolute; bottom: 18%; font-size: 1.5rem; opacity: 0; animation: note-float 2.6s ease-out infinite; }
.dance-notes span:nth-child(1) { left: 26%; animation-delay: 0s; }
.dance-notes span:nth-child(2) { left: 38%; animation-delay: 0.7s; }
.dance-notes span:nth-child(3) { right: 36%; animation-delay: 1.3s; }
.dance-notes span:nth-child(4) { right: 24%; animation-delay: 1.9s; }
@keyframes note-float {
  0% { opacity: 0; transform: translateY(10px) rotate(-8deg); }
  25% { opacity: 1; }
  100% { opacity: 0; transform: translateY(-70px) rotate(10deg); }
}
.dance-track-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(205px, 1fr)); gap: 8px; }
.dance-track { align-items: flex-start; text-align: left; display: flex; flex-direction: column; gap: 2px; }
.dance-track small { font-weight: 400; font-size: 0.72rem; opacity: 0.92; }
.dance-track.is-on { outline: 3px solid var(--anam-gold); }
.dance-desc { font-style: italic; }

/* Beethoven — joyful bouncing, spinning in celebration */
.dance-joy .k-body { animation: dance-joy 0.95s ease-in-out infinite !important; }
@keyframes dance-joy {
  0%, 100% { transform: translateY(0) rotate(0); }
  25% { transform: translateY(-16px) rotate(-8deg) scale(1.04, 0.96); }
  50% { transform: translateY(0) rotate(0) scale(0.97, 1.03); }
  75% { transform: translateY(-16px) rotate(8deg) scale(1.04, 0.96); }
}
/* Mozart — elegant stepping, small bows, graceful turns */
.dance-minuet .k-body { animation: dance-minuet 1.8s ease-in-out infinite !important; }
@keyframes dance-minuet {
  0%, 100% { transform: translateX(0) rotate(0); }
  20% { transform: translateX(-12px) rotate(-3deg); }
  40% { transform: translateX(-12px) rotate(6deg) translateY(3px); }   /* little bow */
  60% { transform: translateX(12px) rotate(3deg); }
  80% { transform: translateX(12px) rotate(-6deg) translateY(3px); }
}
/* Tchaikovsky — slow graceful swaying, tip-toe, balletic */
.dance-ballet .k-body { animation: dance-ballet 2.5s ease-in-out infinite !important; }
@keyframes dance-ballet {
  0%, 100% { transform: rotate(-5deg) translateY(0); }
  25% { transform: rotate(0deg) translateY(-10px) scale(1, 1.06); }   /* rise to tip-toe */
  50% { transform: rotate(5deg) translateY(0); }
  75% { transform: rotate(0deg) translateY(-10px) scale(1, 1.06); }
}
/* Vivaldi — skipping, leaping, playful jumps */
.dance-skip .k-body { animation: dance-skip 0.8s cubic-bezier(0.4, 0, 0.6, 1) infinite !important; }
@keyframes dance-skip {
  0%, 100% { transform: translateY(0) translateX(-8px) rotate(-4deg); }
  50% { transform: translateY(-20px) translateX(8px) rotate(6deg); }
}
/* Strauss — smooth waltzing in circles, gentle spinning */
.dance-waltz .k-body { animation: dance-waltz 3.2s ease-in-out infinite !important; }
@keyframes dance-waltz {
  0% { transform: translateX(0) rotate(0); }
  25% { transform: translateX(16px) translateY(-6px) rotate(10deg); }
  50% { transform: translateX(0) translateY(0) rotate(0); }
  75% { transform: translateX(-16px) translateY(-6px) rotate(-10deg); }
  100% { transform: translateX(0) rotate(0); }
}
/* Bach — slow peaceful swaying, eyes closed */
.dance-calm .k-body { animation: dance-calm 4.4s ease-in-out infinite !important; }
.dance-calm .k-eye { transform: scaleY(0.1); animation: none !important; }
@keyframes dance-calm {
  0%, 100% { transform: rotate(-3deg); }
  50% { transform: rotate(3deg) translateY(-2px); }
}
/* Handel — grand poses, big jumps, triumphant */
.dance-grand .k-body { animation: dance-grand 1.9s ease-in-out infinite !important; }
@keyframes dance-grand {
  0%, 100% { transform: scale(1); }
  18% { transform: translateY(-22px) scale(1.1); }
  36% { transform: translateY(0) scale(1.06, 0.94); }
  52% { transform: scale(1.12) rotate(-4deg); }   /* chest-puffed pose */
  70% { transform: scale(1.12) rotate(4deg); }
  86% { transform: scale(1); }
}
/* Debussy — dreamy moonlit swaying */
.dance-dreamy .k-body { animation: dance-dreamy 5s ease-in-out infinite !important; }
@keyframes dance-dreamy {
  0%, 100% { transform: translateY(0) rotate(-2deg); filter: none; }
  50% { transform: translateY(-7px) rotate(2deg); filter: drop-shadow(0 0 9px #b9c6ff); }
}
/* Grieg — sneaky then faster and faster spinning */
.dance-sneaky .k-body { animation: dance-sneaky 6s cubic-bezier(0.7, 0, 0.9, 0.4) infinite !important; }
@keyframes dance-sneaky {
  0% { transform: translateX(-14px) rotate(0); }
  15% { transform: translateX(-7px) rotate(-4deg); }
  30% { transform: translateX(0) rotate(4deg); }
  45% { transform: translateX(7px) rotate(-6deg); }
  58% { transform: translateX(14px) rotate(8deg); }
  68% { transform: rotate(120deg); }
  78% { transform: rotate(260deg); }
  88% { transform: rotate(400deg) scale(1.06); }
  100% { transform: rotate(720deg); }
}
/* Rossini — galloping, energetic leaps */
.dance-gallop .k-body { animation: dance-gallop 0.55s ease-in-out infinite !important; }
@keyframes dance-gallop {
  0%, 100% { transform: translateY(0) rotate(3deg) scale(1.02, 0.98); }
  50% { transform: translateY(-13px) rotate(-5deg) scale(0.98, 1.05); }
}

/* ============================================================
   AREA SCENE AMBIENT ANIMATION HOOKS (art-areas.js tags these)
   ============================================================ */
.anam-banner .a-cloud, .anam-banner .a-bird, .anam-banner .a-fly, .anam-banner .a-sway,
.anam-banner .a-glow, .anam-banner .a-fall, .anam-banner .a-bob, .anam-banner .a-water {
  transform-box: fill-box; transform-origin: center;
}
.anam-banner .a-cloud { animation: a-cloud 26s ease-in-out infinite alternate; }
@keyframes a-cloud { from { transform: translateX(-28px); } to { transform: translateX(38px); } }
.anam-banner .a-bird { animation: a-bird 13s ease-in-out infinite alternate; }
@keyframes a-bird {
  0% { transform: translate(-50px, 8px); }
  50% { transform: translate(20px, -10px); }
  100% { transform: translate(70px, 4px); }
}
.anam-banner .a-fly { animation: a-flutter 5.5s ease-in-out infinite alternate; }
@keyframes a-flutter {
  0% { transform: translate(0, 0) rotate(-5deg); }
  30% { transform: translate(14px, -10px) rotate(6deg); }
  65% { transform: translate(-8px, -16px) rotate(-4deg); }
  100% { transform: translate(10px, -4px) rotate(5deg); }
}
.anam-banner .a-sway { animation: a-sway 5s ease-in-out infinite alternate; transform-origin: 50% 100%; }
@keyframes a-sway { from { transform: rotate(-2.4deg); } to { transform: rotate(2.4deg); } }
.anam-banner .a-glow { animation: a-glow 3.4s ease-in-out infinite; }
@keyframes a-glow { 0%, 100% { opacity: 0.55; } 50% { opacity: 1; } }
.anam-banner .a-fall { animation: a-fall 9s linear infinite; }
@keyframes a-fall {
  from { transform: translateY(-30px) rotate(0); opacity: 0; }
  12% { opacity: 1; }
  88% { opacity: 1; }
  to { transform: translateY(150px) rotate(40deg); opacity: 0; }
}
.anam-banner .a-bob { animation: a-bob 4.6s ease-in-out infinite alternate; }
@keyframes a-bob { from { transform: translateY(-5px) rotate(-1.5deg); } to { transform: translateY(6px) rotate(1.5deg); } }
.anam-banner .a-water { animation: a-water 4s ease-in-out infinite alternate; }
@keyframes a-water { from { opacity: 0.5; transform: translateX(-7px); } to { opacity: 1; transform: translateX(7px); } }

/* scenic stage */
.scenic-stage { text-align: center; }
.scenic-wanderer { display: inline-block; animation: wander 11s ease-in-out infinite alternate; }
@keyframes wander {
  0% { transform: translateX(-90px) scaleX(1); }
  48% { transform: translateX(82px) scaleX(1); }
  55% { transform: translateX(82px) scaleX(-1); }
  98% { transform: translateX(-84px) scaleX(-1); }
  100% { transform: translateX(-90px) scaleX(1); }
}

/* ---------------- small screens ---------------- */
@media (max-width: 640px) {
  .board-flash { grid-template-columns: 1fr; }
  .board-row { grid-template-columns: 1fr 96px 70px 22px; font-size: 0.84rem; }
  .anam-title { font-size: 1.2rem; }
  .anam-wallet { width: 100%; justify-content: center; }
}

/* ============================================================
   WORLD LORE & ORIGINS — the Scroll of History
   ============================================================ */
.anam-lore { font-family: var(--anam-font); color: var(--anam-ink); text-align: left; }
.lore-banner {
  border-radius: 14px; overflow: hidden; margin: 6px 0 12px;
  border: 3px solid var(--anam-border); background: var(--anam-sky);
}
.lore-banner svg { display: block; width: 100%; height: auto; }
.lore-title { text-align: center; margin: 4px 0 2px; }
.lore-lede { text-align: center; color: #6a6293; font-size: 0.92rem; margin: 0 0 12px; }

.lore-entries { display: grid; gap: 10px; }
.lore-entry {
  display: flex; gap: 12px; align-items: flex-start;
  background: var(--anam-card-soft); border: 2px solid var(--anam-border);
  border-radius: 14px; padding: 12px;
}
.lore-emblem { flex: 0 0 46px; }
.lore-emblem svg { display: block; width: 46px; height: 46px; }
.lore-text h3 { margin: 0 0 2px; font-size: 1.05rem; }
.lore-text h3 small { color: var(--anam-accent); font-size: 0.8rem; font-weight: 700; }
.lore-origin { margin: 0 0 6px; font-size: 0.78rem; color: #8d86ad; font-style: italic; }
.lore-meaning { margin: 0; font-size: 0.9rem; line-height: 1.45; }

.lore-welcome-note { text-align: center; font-size: 0.9rem; color: #6a6293; margin: 12px 0 0; }
.lore-cta-row { display: flex; justify-content: center; margin-top: 14px; }

/* the re-readable scroll kept on a Library shelf */
.lore-shelf-card { display: flex; gap: 14px; align-items: center; text-align: left; }
.lore-shelf-emblem {
  flex: 0 0 64px; background: var(--anam-card-soft); border: 2px solid var(--anam-border);
  border-radius: 14px; padding: 4px; cursor: pointer;
  transition: transform 0.15s ease, border-color 0.15s ease; touch-action: manipulation;
}
.lore-shelf-emblem:hover { transform: translateY(-3px) scale(1.05); border-color: var(--anam-accent); }
.lore-shelf-emblem svg { display: block; width: 100%; height: auto; }
.lore-shelf-title { margin: 0; font-size: 1.05rem; }

/* reduced motion: everything stays readable with animation off */
@media (prefers-reduced-motion: reduce) {
  #screen-anamvale *, .anam-banner *, .kart * { animation: none !important; transition: none !important; }
}

/* shop explainer + demand line (Village shops) */
.shop-explain { background: linear-gradient(135deg, #fff7e8, #eafaf5); }
.shop-explain h3 { margin: 0 0 4px; }
.shop-demand { font-size: 0.82rem; margin: 4px 0 8px; }

/* Hatch-early (pay Aurars to skip the egg timer) */
.hatch-speed-btn {
  margin-top: 6px;
  background: linear-gradient(160deg, #ffd93d, #ff9f2e);
  border-color: #e07b00; color: #5a3a00; font-weight: 700;
}
.hatch-speed-btn:hover { filter: brightness(1.05); }

/* Kindred care reminders (feed/sleep to keep growing) */
.kv-reminders { position: relative; z-index: 2; display: flex; flex-direction: column; gap: 6px; margin: 8px 0 4px; }
.kv-reminder {
  display: flex; align-items: center; gap: 8px; text-align: left;
  background: #fff7e0; border: 2px solid #ffd479; border-radius: 14px;
  padding: 8px 12px; font-family: inherit; font-weight: 700; font-size: 0.92rem;
  color: #7a5a14; cursor: pointer; box-shadow: 0 3px 0 rgba(0,0,0,.06);
}
.kv-reminder:hover { filter: brightness(1.03); }
.kv-rem-ico { font-size: 1.2rem; }
/* growth status chips on the My Kindred profile */
.level-chip.kv-grow-on  { background: #e5f9ec; color: #1e9e4a; }
.level-chip.kv-grow-off { background: #ffece0; color: #c2611c; }
