/* ============================================================
   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); }
}

/* gold "+N" coin that floats up off the header Aurar chip on every earn */
.aurar-pop {
  position: fixed; z-index: 9999; pointer-events: none;
  font-weight: 900; font-size: .95rem; white-space: nowrap;
  color: var(--anam-gold-ink, #7a5a00);
  background: var(--anam-gold-grad, linear-gradient(135deg, #ffe680, #f5b301));
  border: 2px solid var(--anam-gold-deep, #d99a00); border-radius: 999px;
  padding: 2px 10px; box-shadow: 0 4px 14px rgba(210, 160, 0, .45);
  animation: aurar-pop 1.1s cubic-bezier(.2, .8, .3, 1) forwards;
}
@keyframes aurar-pop {
  0%   { opacity: 0; transform: translate(-50%, 6px) scale(.6); }
  18%  { opacity: 1; transform: translate(-50%, -6px) scale(1.14); }
  40%  { opacity: 1; transform: translate(-50%, -16px) scale(1); }
  100% { opacity: 0; transform: translate(-50%, -44px) scale(.9); }
}
.aurar-bump { animation: aurar-bump .5s ease; }
@keyframes aurar-bump { 0%, 100% { transform: none; } 30% { transform: scale(1.18); } }

/* ---------------- shell ---------------- */
#screen-anamvale { font-family: var(--anam-font); color: var(--anam-ink); }
/* Hearthstone Valley 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(190px, 30vw, 320px); }
.anam-banner-photo {
  width: 100%; aspect-ratio: 16 / 9; min-height: 260px; max-height: 560px;
  background-position: center; background-size: cover; background-repeat: no-repeat;
  box-shadow: 0 5px 0 rgba(31,126,119,.13), 0 14px 28px rgba(38,59,82,.1);
}
#anamvale-root[data-area="dance_hall"] .anam-banner-photo { display: none; }

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

/* ---------------- persistent valley dock ----------------
   Always-on contextual nav for the four valley zones. Floats just above the
   app-wide bottom tab bar (.wl-tabbar, fixed at bottom:0, ~60px tall). When the
   home zone goes immersive (tabbar hidden) the dock drops to the bottom. */
.anam-dock {
  position: fixed; left: 50%; transform: translateX(-50%);
  bottom: 64px; z-index: 901;
  display: flex; gap: 6px;
  background: rgba(255, 255, 255, 0.96);
  border: 2px solid rgba(124, 92, 255, 0.22);
  border-radius: 18px; padding: 5px 7px;
  box-shadow: 0 6px 22px rgba(65, 76, 123, 0.18);
  max-width: calc(100vw - 20px);
}
.anam-dock-btn {
  display: flex; flex-direction: column; align-items: center; gap: 2px;
  border: none; background: transparent; cursor: pointer;
  padding: 6px 16px; border-radius: 13px;
  color: #7a6fae; font-weight: 700; font-size: 0.72rem; white-space: nowrap;
  transition: background 0.15s ease, color 0.15s ease, transform 0.08s ease;
}
.anam-dock-btn .anam-dock-ico { font-size: 1.35rem; line-height: 1; }
.anam-dock-btn.on { background: rgba(124, 92, 255, 0.14); color: #5b3fc4; }
.anam-dock-btn:active { transform: scale(0.93); }
/* keep the last content clear of the floating dock + global tab bar */
#screen-anamvale.active #anamvale-root { padding-bottom: 132px; }
/* immersive home hides the global tab bar (rule above) — drop the dock to the foot */
body:has(#screen-anamvale.active .kv-home-immersive) .anam-dock { bottom: 12px; }
/* lift the floating read-aloud button clear of the dock on every Valley screen */
body:has(#screen-anamvale.active) .tts-launcher { bottom: calc(132px + env(safe-area-inset-bottom, 0px)); }

.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: none; }
.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; }

/* ---- the Scroll of History: parchment unrolls between two wooden rods ---- */
.modal-card.modal-scroll {
  background: transparent; box-shadow: none; padding: 0;
  max-width: 540px; max-height: none; overflow: visible;
}
.modal-card.modal-scroll .modal-x { z-index: 6; }
.lore-scroll { position: relative; filter: drop-shadow(0 16px 30px rgba(50,32,12,.45)); }
.lore-rod {
  position: relative; z-index: 3; height: 22px; margin: 0 4px; border-radius: 12px;
  background: linear-gradient(180deg,#d8ab63 0%,#a9743f 38%,#7a4a22 70%,#5e3717 100%);
  box-shadow: inset 0 2px 2px rgba(255,238,200,.55), inset 0 -4px 5px rgba(40,22,8,.5), 0 2px 5px rgba(40,22,8,.35);
}
.lore-rod::before, .lore-rod::after {
  content: ''; position: absolute; top: 50%; width: 18px; height: 30px; transform: translateY(-50%);
  border-radius: 7px; background: radial-gradient(circle at 42% 32%,#f0cd8c,#a9743f 65%,#5e3717);
  box-shadow: 0 2px 5px rgba(40,22,8,.45);
}
.lore-rod::before { left: -9px; }
.lore-rod::after  { right: -9px; }
.lore-rod-top    { margin-bottom: -5px; }
.lore-rod-bottom { margin-top: -5px; }
.lore-parchment {
  position: relative; z-index: 1; max-height: 76vh; overflow: hidden auto;
  background:
    repeating-linear-gradient(0deg, rgba(180,140,70,.04) 0 22px, rgba(150,110,50,.06) 22px 23px),
    radial-gradient(130% 90% at 50% 0%, #fdf3d6 0%, #f4e4ba 55%, #ecd6a4 100%);
  border-left: 2px solid #d9c189; border-right: 2px solid #d9c189;
  box-shadow: inset 0 0 34px rgba(160,120,60,.18);
}
.lore-parchment-inner { padding: 18px 22px 22px; }
/* the story is inked directly onto the parchment — no floating cards */
.lore-scroll .lore-entries { gap: 0; }
.lore-scroll .lore-entry {
  background: none; border: 0; border-radius: 0; padding: 12px 2px 14px;
  border-bottom: 1px solid rgba(140,100,45,.22); gap: 10px;
}
.lore-scroll .lore-entry:last-child { border-bottom: 0; padding-bottom: 4px; }
.lore-scroll .lore-title   { color: #5a3a1c; }
.lore-scroll .lore-lede    { color: #7a5a2c; }
.lore-scroll .lore-text h3 { color: #5a3a1c; }
.lore-scroll .lore-text h3 small { color: #a06a26; }
.lore-scroll .lore-origin  { color: #8a6a3a; }
.lore-scroll .lore-meaning { color: #463a24; }
.lore-scroll .lore-welcome-note { color: #7a5a2c; }
.lore-scroll .lore-banner  { border-color: #cbb073; }
/* emblems become small inked seals rather than boxed icons */
.lore-scroll .lore-emblem { flex: 0 0 38px; }
.lore-scroll .lore-emblem svg { width: 38px; height: 38px; }
.lore-scroll .lore-emblem svg > circle:first-of-type[fill="#f6f3ff"] { fill: transparent; stroke: rgba(150,110,50,.35); }
/* the unroll itself */
.lore-scroll.is-animating .lore-parchment {
  overflow: hidden; animation: loreUnroll .9s cubic-bezier(.2,.62,.32,1) backwards;
}
.lore-scroll.is-animating .lore-parchment-inner { animation: loreFadeIn .9s ease both; }
@keyframes loreUnroll { from { max-height: 0; } to { max-height: 76vh; } }
@keyframes loreFadeIn { from { opacity: 0; } 35% { opacity: 0; } to { opacity: 1; } }

/* reduced motion: everything stays readable with animation off */
@media (prefers-reduced-motion: reduce) {
  #screen-anamvale *, .anam-banner *, .kart * { animation: none !important; transition: none !important; }
  .lore-scroll.is-animating .lore-parchment,
  .lore-scroll.is-animating .lore-parchment-inner { animation: none !important; }
  .lore-parchment { max-height: 76vh; }
}

/* 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; }

/* Illustrated Hearthstone Valley and Kindred destination treatment. Visual only. */
#anamvale-root{border-radius:12px;border-color:#9bd8d1;box-shadow:0 5px 0 rgba(31,126,119,.12),0 14px 30px rgba(38,59,82,.1)}
#anamvale-root:has(.map-head)::before{content:"";display:block;width:100%;aspect-ratio:3/1;min-height:190px;margin-bottom:13px;border:3px solid #5cc5d3;border-radius:16px;background:#8fdcf0 url("images/anam-vale-world-v2.png") center/cover no-repeat;box-shadow:0 5px 0 rgba(31,126,143,.15),0 14px 30px rgba(65,76,123,.16)}
.anam-head{border-bottom:2px solid #d8ece9;padding-bottom:9px}.anam-title{color:#275d6c}
.anam-btn,.anam-mini-btn,.anam-tab,.anam-area-card,.k-card{border-radius:9px}.anam-btn{background:#537ed8;box-shadow:0 3px 0 #3156a4}.anam-back{background:#19aa9f;box-shadow:0 3px 0 #0f756e}.aurar-chip,.worth-chip{border-radius:8px}
.anam-area-card{min-height:190px;justify-content:flex-end;padding:0;border-color:#d2e7e3;box-shadow:0 3px 0 rgba(38,59,82,.08);transition:transform .17s ease,box-shadow .17s ease,border-color .17s ease}
.anam-area-card:hover{transform:translateY(-5px);box-shadow:0 7px 15px rgba(38,59,82,.12)}
.area-card-art{display:block;position:absolute;inset:0 0 62px;overflow:hidden;background:#dff4f0}.area-card-art svg{display:block;width:100%;height:100%;object-fit:cover}.area-card-photo{background-position:center;background-size:cover;background-repeat:no-repeat}
.area-card-copy{position:relative;z-index:2;display:flex;width:100%;min-height:64px;padding:8px 7px;flex-direction:column;align-items:center;justify-content:center;background:rgba(255,255,255,.94);border-top:2px solid rgba(202,226,221,.9)}
.area-card-copy strong{color:#273a55}.area-card-copy small{line-height:1.2;color:#69728c}.area-lock{position:absolute;z-index:3;top:9px;right:9px;display:grid;width:38px;height:38px;place-items:center;border-radius:10px;background:rgba(255,255,255,.92);box-shadow:0 3px 10px rgba(36,49,70,.2);font-size:1.25rem}
.anam-area-card.is-locked .area-card-art{filter:grayscale(.55) brightness(.78)}.anam-area-card.is-locked .area-card-copy{background:rgba(247,244,249,.96)}
.k-card{border-color:#d7e8e4;box-shadow:0 3px 0 rgba(38,59,82,.08);transition:transform .16s ease,border-color .16s ease}.k-card:hover{transform:translateY(-3px);border-color:#55bfb2}
.kindred-collection-stage{
  display:flex;min-height:clamp(560px,64vw,790px);padding:18px;flex-direction:column;justify-content:flex-end;
  border:3px solid #60cdb7;border-radius:14px;overflow:hidden;
  background:#1e2a2c url("images/area-interiors-storybook-hq/collection.jpg") center/cover no-repeat;
  box-shadow:0 5px 0 rgba(31,126,119,.13),0 14px 28px rgba(38,59,82,.1);
}
.kindred-collection-stage .kindred-collection-copy{max-width:640px;margin:0 auto auto;background:#fff;border:2px solid #d8e8e4;border-radius:10px;box-shadow:0 4px 0 rgba(38,59,82,.08)}
.kindred-collection-stage .anam-note{margin:0;padding:10px 12px;background:transparent}
.kindred-collection-stage .anam-h3{align-self:center;margin:12px 0 10px;padding:8px 14px;border:2px solid #d8e8e4;border-radius:10px;background:#fff;box-shadow:0 4px 0 rgba(38,59,82,.08)}
.kindred-collection-stage .k-coll-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:10px;margin:0}
.kindred-collection-stage .k-card{min-height:230px;padding:10px 8px 9px;background:#fff;border:2px solid #d8e8e4}
:is(#screen-kindredvillage,#screen-anamvale) .pw-sky{padding-top:225px;border:3px solid #62c9b2;border-radius:12px;background-color:#e8f8ef;background-image:url("images/area-interiors-storybook-hq/kindred_village.jpg"),linear-gradient(180deg,#d9f5f0,#f4fbef);background-position:center top,center;background-size:100% 210px,auto;background-repeat:no-repeat;box-shadow:0 5px 0 rgba(31,126,119,.13),0 14px 28px rgba(38,59,82,.1)}
:is(#screen-kindredvillage,#screen-anamvale) .pw-sky:has(.kv-main-tabs .pw-tab:nth-child(2).on){background-image:url("images/area-interiors-storybook-hq/collection.jpg"),linear-gradient(180deg,#eaf8f0,#f4fbef)}
:is(#screen-kindredvillage,#screen-anamvale) .pw-header{padding:9px 10px;border-radius:8px;background:rgba(255,255,255,.9);border:2px solid #d4e9e4}
:is(#screen-kindredvillage,#screen-anamvale) .pw-header h2{color:#245e70;text-shadow:none}:is(#screen-kindredvillage,#screen-anamvale) .pw-tabs{gap:7px}:is(#screen-kindredvillage,#screen-anamvale) .pw-tab{border-radius:8px;border:2px solid #d5e8e4;box-shadow:0 2px 0 rgba(38,59,82,.12)}:is(#screen-kindredvillage,#screen-anamvale) .pw-tab.on{background:#e95d91;border-color:#bd3b6b}
:is(#screen-kindredvillage,#screen-anamvale){overflow-x:hidden}
:is(#screen-kindredvillage,#screen-anamvale) .pw-sky{box-sizing:border-box;width:100%;max-width:100%;overflow:visible}
:is(#screen-kindredvillage,#screen-anamvale) .pw-header{display:flex;align-items:center;flex-wrap:wrap;gap:10px;max-width:100%;overflow:visible}
:is(#screen-kindredvillage,#screen-anamvale) .pw-header h2{display:flex;align-items:center;gap:9px;min-width:0;white-space:normal;line-height:1.1}
:is(#screen-kindredvillage,#screen-anamvale) .pw-tabs{display:flex;align-items:stretch;flex-wrap:wrap;gap:8px;max-width:100%;overflow:visible;margin:10px 0 12px}
:is(#screen-kindredvillage,#screen-anamvale) .pw-tab,:is(#screen-kindredvillage,#screen-anamvale) .pw-action{display:inline-flex;align-items:center;justify-content:center;gap:7px;max-width:100%;min-height:44px;white-space:normal;text-align:center;line-height:1.1;overflow:visible}
:is(#screen-kindredvillage,#screen-anamvale) .pw-tab{padding:7px 12px}
:is(#screen-kindredvillage,#screen-anamvale) .pw-action{padding:8px 13px}
:is(#screen-kindredvillage,#screen-anamvale) .pw-tab .kv-tab-text,:is(#screen-kindredvillage,#screen-anamvale) .pw-action .kv-tab-text{display:block;min-width:0}
:is(#screen-kindredvillage,#screen-anamvale) .pw-map-tab{margin-left:auto}
:is(#screen-kindredvillage,#screen-anamvale) .kv-tab-icon{display:inline-grid;place-items:center;flex:0 0 auto;width:28px;height:28px;overflow:hidden;border-radius:7px;background:#fff;box-shadow:inset 0 0 0 1px rgba(213,232,228,.9),0 2px 4px rgba(38,59,82,.11)}
:is(#screen-kindredvillage,#screen-anamvale) .kv-tab-icon img{display:block;width:100%;height:100%;object-fit:cover}
:is(#screen-kindredvillage,#screen-anamvale) .pw-header h2 .kv-tab-icon{width:34px;height:34px;border-radius:8px}
:is(#screen-kindredvillage,#screen-anamvale) #pw-body{min-width:0;max-width:100%;overflow:visible}
:is(#screen-kindredvillage,#screen-anamvale) #pw-body .pw-grid{grid-template-columns:repeat(auto-fit,minmax(132px,1fr));max-width:100%}
:is(#screen-kindredvillage,#screen-anamvale) .pw-float,:is(#screen-kindredvillage,#screen-anamvale) .pw-twinkle,:is(#screen-kindredvillage,#screen-anamvale) .kv-skyline{display:none}
.kv-stage{border:2px solid #cfe6df;border-radius:10px;background:linear-gradient(180deg,rgba(191,231,255,.72),rgba(239,250,225,.92)),url("images/kindred-village.jpg") center 48%/cover no-repeat}
.kv-avatar{animation:kv-new-bob 3.2s ease-in-out infinite;filter:drop-shadow(0 8px 5px rgba(38,59,82,.18))}@keyframes kv-new-bob{0%,100%{transform:translateY(0) rotate(-1deg)}50%{transform:translateY(-8px) rotate(1deg)}}
.kv-profile-card,.pw-meters,.pw-actions{position:relative;z-index:2}
.kv-xp-card{max-width:760px;margin:10px auto 3px;padding:10px 13px;border:2px solid #d9cff5;border-radius:14px;background:linear-gradient(135deg,rgba(255,255,255,.95),rgba(239,234,255,.95));box-shadow:0 3px 0 rgba(87,62,150,.12)}
.kv-xp-head,.kv-xp-foot{display:flex;justify-content:space-between;align-items:center;gap:10px}.kv-xp-head{color:#49377f}.kv-xp-head span{font-size:.84rem;font-weight:700;color:#66578e}
.kv-xp-track{height:18px;margin:7px 0 5px;border:2px solid #c9b8ef;border-radius:999px;background:#e7e0f5;overflow:hidden}
.kv-xp-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,#7a5be7,#d45ed2,#ffb84d);box-shadow:inset 0 2px 0 rgba(255,255,255,.4);transition:width .55s ease;position:relative;overflow:hidden}
.kv-xp-fill::after{content:"";position:absolute;inset:0;background:linear-gradient(100deg,transparent 20%,rgba(255,255,255,.55) 50%,transparent 80%);background-size:220% 100%;animation:kvShine 2.2s linear infinite}
.kv-xp-foot{font-size:.76rem;color:#675c82}.kv-xp-foot span:last-child{font-weight:700;color:#59429a;text-align:right}
@media(max-width:640px){.kv-xp-head,.kv-xp-foot{align-items:flex-start;flex-direction:column;gap:3px}.kv-xp-foot span:last-child{text-align:left}}
@media(max-width:640px){#anamvale-root:has(.map-head)::before{aspect-ratio:16/9;min-height:160px}.anam-area-card{min-height:166px}.area-card-art{inset:0 0 60px}:is(#screen-kindredvillage,#screen-anamvale) .pw-sky{padding:145px 10px 22px;background-size:auto 135px,auto}}

/* Full-size Kindred galleries and shared creature animation system. */
#anamvale-root{width:100%;max-width:1120px}
.k-coll-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-bottom:22px}
.k-card{min-height:250px;padding:14px 10px 12px;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;background:linear-gradient(180deg,#f7fffc,#fff 62%);border-width:2px;border-style:solid!important}
.k-card .kart{width:clamp(118px,13vw,154px);min-height:145px;display:flex;align-items:flex-end;justify-content:center;margin:auto auto 3px;filter:drop-shadow(0 7px 5px rgba(38,59,82,.15));transform-origin:50% 100%;animation:kindred-gallery-float 3.4s ease-in-out infinite}
.k-card-name{font-size:1rem;color:#2d455c}.k-card-rar{font-size:.8rem}.k-card-buy{width:100%;padding:7px 8px;margin-top:8px;border-radius:7px}
.k-card:hover .kart{animation:kindred-gallery-greet .72s ease-in-out infinite alternate}
.k-card:nth-child(4n+2) .kart{animation-delay:-.7s}.k-card:nth-child(4n+3) .kart{animation-delay:-1.4s}.k-card:nth-child(4n+4) .kart{animation-delay:-2.1s}
@keyframes kindred-gallery-float{0%,100%{transform:translateY(0) rotate(-1deg)}50%{transform:translateY(-7px) rotate(1deg)}}
@keyframes kindred-gallery-greet{from{transform:translateY(-3px) rotate(-3deg) scale(1.02)}to{transform:translateY(-10px) rotate(3deg) scale(1.05)}}

:is(#screen-kindredvillage,#screen-anamvale) .pw-sky{padding:calc(56.25% + 15px) 18px 26px;background-size:100% auto,auto;background-position:center top,center}
:is(#screen-kindredvillage,#screen-anamvale) .kv-stage{background-image:linear-gradient(180deg,rgba(223,247,247,.68),rgba(245,253,232,.87)),url("images/area-interiors-storybook-hq/kindred_village.jpg");background-position:center;background-size:cover}
:is(#screen-kindredvillage,#screen-anamvale) .pw-sky:has(.kv-main-tabs>.pw-tab:nth-child(2).on) #pw-body .pw-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:13px}
:is(#screen-kindredvillage,#screen-anamvale) .pw-sky:has(.kv-main-tabs>.pw-tab:nth-child(2).on) #pw-body .pw-item{min-height:230px;padding:13px 9px 11px;display:flex;flex-direction:column;justify-content:flex-end;border:2px solid #cce5df;border-radius:9px;background:linear-gradient(180deg,#f6fffb,#fff);box-shadow:0 4px 0 rgba(38,59,82,.09)}
:is(#screen-kindredvillage,#screen-anamvale) .pw-sky:has(.kv-main-tabs>.pw-tab:nth-child(2).on) #pw-body .pw-item .kart-mini{width:clamp(110px,13vw,145px);min-height:140px;display:flex;align-items:flex-end;filter:drop-shadow(0 7px 5px rgba(38,59,82,.14));animation:kindred-gallery-float 3.4s ease-in-out infinite}
:is(#screen-kindredvillage,#screen-anamvale) .pw-sky:has(.kv-main-tabs>.pw-tab:nth-child(2).on) #pw-body .pw-item:nth-child(4n+2) .kart{animation-delay:-.7s}
:is(#screen-kindredvillage,#screen-anamvale) .pw-sky:has(.kv-main-tabs>.pw-tab:nth-child(2).on) #pw-body .pw-item:nth-child(4n+3) .kart{animation-delay:-1.4s}
:is(#screen-kindredvillage,#screen-anamvale) .pw-sky:has(.kv-main-tabs>.pw-tab:nth-child(2).on) #pw-body .pw-item:nth-child(4n+4) .kart{animation-delay:-2.1s}
:is(#screen-kindredvillage,#screen-anamvale) .pw-sky:has(.kv-main-tabs>.pw-tab:nth-child(2).on) #pw-body .pw-item .nm{font-size:.98rem;color:#2d455c}
:is(#screen-kindredvillage,#screen-anamvale) .pw-sky:has(.kv-main-tabs>.pw-tab:nth-child(2).on) #pw-body .pw-item .pr{font-size:.78rem}
:is(#screen-kindredvillage,#screen-anamvale) .pw-sky:has(.kv-main-tabs>.pw-tab:nth-child(2).on) #pw-body .pw-item button{width:100%;border-radius:7px;padding:7px 8px}

.kv-avatar>.kart{animation:kindred-stage-breathe 3s ease-in-out infinite;transform-origin:50% 100%}
.kv-avatar.bathing>.kart{animation:none!important;transform:translateY(30px) scale(.68)}
.kv-card-mini{min-width:190px;border-radius:9px;transition:transform .16s ease,border-color .16s ease}.kv-card-mini:hover{transform:translateY(-3px);border-color:#58bfb0}.kv-card-mini .kart-mini{width:72px;animation:kindred-gallery-float 3.2s ease-in-out infinite;filter:drop-shadow(0 4px 3px rgba(38,59,82,.13))}
.kv-card-mini:nth-child(2n) .kart{animation-delay:-1.1s}.kv-card-mini:nth-child(3n) .kart{animation-delay:-2s}
@keyframes kindred-stage-breathe{0%,100%{transform:translateY(0) scale(1)}50%{transform:translateY(-5px) scale(1.025,.98)}}

@media(max-width:850px){.k-coll-grid,:is(#screen-kindredvillage,#screen-anamvale) .pw-sky:has(.kv-main-tabs>.pw-tab:nth-child(2).on) #pw-body .pw-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}
@media(max-width:640px){.k-coll-grid,:is(#screen-kindredvillage,#screen-anamvale) .pw-sky:has(.kv-main-tabs>.pw-tab:nth-child(2).on) #pw-body .pw-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:9px}.k-card{min-height:215px}.k-card .kart,:is(#screen-kindredvillage,#screen-anamvale) .pw-sky:has(.kv-main-tabs>.pw-tab:nth-child(2).on) #pw-body .pw-item .kart-mini{width:105px;min-height:118px}:is(#screen-kindredvillage,#screen-anamvale) .pw-sky{padding:calc(33.333% + 10px) 10px 22px;background-size:100% auto,auto}.kv-card-mini{min-width:calc(50% - 4px);padding:7px}.kv-card-mini .kart-mini{width:58px}}
@media(max-width:900px){.kindred-collection-stage .k-coll-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.kindred-collection-stage{min-height:760px}}
@media(max-width:640px){.kindred-collection-stage{min-height:880px;padding:10px;background-position:center top}.kindred-collection-stage .k-coll-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.kindred-collection-stage .k-card{min-height:210px}}

/* Kindred theme rule: live Kindred room art comes only from images/kindred-theme/.
   Legacy kindred-home-interiors/ and property-interiors/ files are archive-only. */
.anam-map-grid .anam-area-card{position:relative;overflow:hidden;background-color:#fff;isolation:isolate}
.anam-map-grid .anam-area-card:hover .area-card-art svg{transform:scale(1.035)}.area-card-art svg{transition:transform .25s ease}
@keyframes anam-map-icon{0%,100%{transform:translateY(0) rotate(-2deg)}50%{transform:translateY(-7px) rotate(2deg)}}
@keyframes anam-map-greet{from{transform:translateY(-3px) rotate(-5deg) scale(1.04)}to{transform:translateY(-10px) rotate(5deg) scale(1.1)}}

:is(#screen-kindredvillage,#screen-anamvale) .kv-room{aspect-ratio:16/7;min-height:clamp(320px,42vw,520px);border:3px solid #bd8c4e;border-radius:10px;background-color:#f2dfbd;background-position:center;background-size:cover;box-shadow:inset 0 0 0 2px rgba(255,255,255,.42),0 5px 0 rgba(91,57,22,.15)}
:is(#screen-kindredvillage,#screen-anamvale) .kv-room-heading{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:4px 0 10px;padding:9px 11px;border:2px solid #d8e8e2;border-radius:12px;background:rgba(255,255,255,.86)}
:is(#screen-kindredvillage,#screen-anamvale) .kv-room-heading>div{display:flex;align-items:center;gap:10px}.kv-room-home-icon{font-size:2rem}
:is(#screen-kindredvillage,#screen-anamvale) .kv-room-heading h3{margin:0;color:#40345f}.kv-room-heading p{margin:2px 0 0;color:#65708a;font-size:.86rem}
:is(#screen-kindredvillage,#screen-anamvale) .kv-room-heading .pw-action{width:auto;min-width:145px}

/* Every purchasable Kindred home opens into its own illustrated room. */
:is(#screen-kindredvillage,#screen-anamvale) .kv-room.room-tiny{background-image:url("images/kindred-theme/rooms/homes/tiny.jpg")}
:is(#screen-kindredvillage,#screen-anamvale) .kv-room.room-cottage{background-image:url("images/kindred-theme/rooms/homes/cottage.jpg")}
:is(#screen-kindredvillage,#screen-anamvale) .kv-room.room-tree{background-image:url("images/kindred-theme/rooms/homes/tree.jpg")}
:is(#screen-kindredvillage,#screen-anamvale) .kv-room.room-igloo{background-image:url("images/kindred-theme/rooms/homes/igloo.jpg")}
:is(#screen-kindredvillage,#screen-anamvale) .kv-room.room-jungle{background-image:url("images/kindred-theme/rooms/homes/jungle.jpg")}
:is(#screen-kindredvillage,#screen-anamvale) .kv-room.room-mushroom{background-image:url("images/kindred-theme/rooms/homes/mushroom.jpg")}
:is(#screen-kindredvillage,#screen-anamvale) .kv-room.room-candy{background-image:url("images/kindred-theme/rooms/homes/candy.jpg")}
:is(#screen-kindredvillage,#screen-anamvale) .kv-room.room-under{background-image:url("images/kindred-theme/rooms/homes/underwater.jpg")}
:is(#screen-kindredvillage,#screen-anamvale) .kv-room.room-castle{background-image:url("images/kindred-theme/rooms/homes/castle.jpg")}
:is(#screen-kindredvillage,#screen-anamvale) .kv-room.room-space{background-image:url("images/kindred-theme/rooms/homes/space.jpg")}
:is(#screen-kindredvillage,#screen-anamvale) .kv-room-live{position:relative;outline:none;cursor:default}
:is(#screen-kindredvillage,#screen-anamvale) .kv-room-live:focus{box-shadow:inset 0 0 0 2px rgba(255,255,255,.42),0 5px 0 rgba(91,57,22,.15),0 0 0 4px rgba(86,202,188,.22)}
:is(#screen-kindredvillage,#screen-anamvale) .kv-room-live::after{content:"";position:absolute;z-index:1;inset:auto 0 0;height:46%;pointer-events:none;background:linear-gradient(180deg,transparent,rgba(38,45,31,.08))}
:is(#screen-kindredvillage,#screen-anamvale) .kv-room-kindred{position:absolute;bottom:auto!important;left:50%;top:68%;width:auto;pointer-events:none;transform:translate(-50%,-82%);transition:left .12s linear,top .12s linear;animation:room-kindred-breathe 2.7s ease-in-out infinite;filter:drop-shadow(0 9px 6px rgba(64,36,16,.24));transform-origin:50% 100%}
:is(#screen-kindredvillage,#screen-anamvale) .kv-room-kindred .kart-mini{width:clamp(82px,10vw,118px);transition:transform .16s ease}
:is(#screen-kindredvillage,#screen-anamvale) .kv-room-kindred .kart[data-species]{transform:scaleX(var(--face-x,1))!important;transform-origin:center bottom}
:is(#screen-kindredvillage,#screen-anamvale) .kv-room-kindred.is-walking{animation:room-kindred-walk .62s ease-in-out infinite}
@keyframes room-kindred-walk{0%,100%{translate:0 0;scale:1.03 .97;rotate:-1.5deg}25%{translate:0 -10px;scale:.98 1.03;rotate:0deg}50%{translate:0 0;scale:1.04 .96;rotate:1.5deg}75%{translate:0 -8px;scale:.99 1.02;rotate:0deg}}
:is(#screen-kindredvillage,#screen-anamvale) .kv-room-kindred:has(.is-sleeping){animation:room-kindred-breathe 3.2s ease-in-out infinite;filter:drop-shadow(0 7px 5px rgba(46,35,72,.22))}
:is(#screen-kindredvillage,#screen-anamvale) .kv-room-kindred:has(.is-sleeping) .kart-mini{width:clamp(108px,14vw,150px)}
@keyframes room-kindred-breathe{0%,100%{translate:0 0;rotate:-1deg}50%{translate:0 -4px;rotate:1deg}}
@keyframes room-kindred-hop{0%,100%{translate:0 0}50%{translate:0 -8px}}
:is(#screen-kindredvillage,#screen-anamvale) .room-item{position:absolute;z-index:4;transform:translate(-50%,-78%);cursor:grab;user-select:none;touch-action:none;transition:filter .16s ease,scale .16s ease;animation:room-item-idle 3.5s ease-in-out infinite;animation-delay:calc(var(--room-delay,0)*-.4s)}
:is(#screen-kindredvillage,#screen-anamvale) .room-item:hover{filter:drop-shadow(0 8px 5px rgba(59,35,15,.28));scale:1.06}
:is(#screen-kindredvillage,#screen-anamvale) .room-item:active{cursor:grabbing;scale:1.09}
@keyframes room-item-idle{0%,100%{translate:0 0}50%{translate:0 -3px}}

/* Finished home interiors: each purchased house has its own light, atmosphere
   and readable floor zone while keeping decorations draggable. */
:is(#screen-kindredvillage,#screen-anamvale) .kv-room{overflow:hidden;background-position:center 58%;--room-glow:rgba(255,220,137,.18)}
:is(#screen-kindredvillage,#screen-anamvale) .kv-room::before{content:none}
:is(#screen-kindredvillage,#screen-anamvale) .kv-room.room-igloo{--room-glow:rgba(164,239,255,.22)}
:is(#screen-kindredvillage,#screen-anamvale) .kv-room.room-jungle{--room-glow:rgba(141,239,142,.22)}
:is(#screen-kindredvillage,#screen-anamvale) .kv-room.room-mushroom{--room-glow:rgba(255,150,226,.26)}
:is(#screen-kindredvillage,#screen-anamvale) .kv-room.room-candy{--room-glow:rgba(255,190,224,.34)}
:is(#screen-kindredvillage,#screen-anamvale) .kv-room.room-under{--room-glow:rgba(87,227,255,.30)}
:is(#screen-kindredvillage,#screen-anamvale) .kv-room.room-castle{--room-glow:rgba(255,210,115,.28)}
:is(#screen-kindredvillage,#screen-anamvale) .kv-room.room-space{--room-glow:rgba(158,120,255,.22)}

#anamvale-root:has(.anam-body .farm-card) .farm-card{min-height:145px;border-color:#cde5d0;background:linear-gradient(145deg,#fff,#eff9ee);transition:transform .16s ease,box-shadow .16s ease}
#anamvale-root:has(.anam-body .farm-card) .farm-card:hover{transform:translateY(-4px);box-shadow:0 7px 15px rgba(38,59,82,.12)}
#anamvale-root:has(.anam-body .farm-card) .farm-card .item-icon{display:flex;align-items:center;justify-content:center;width:52px;height:52px;border-radius:9px;background:#fff9df;box-shadow:0 3px 0 rgba(91,68,18,.12);animation:farm-producer 2.8s ease-in-out infinite}
#anamvale-root:has(.anam-body .farm-card) .farm-card:nth-child(2n) .item-icon{animation-delay:-1.4s}
@keyframes farm-producer{0%,100%{transform:translateY(0) rotate(-2deg)}45%{transform:translateY(-6px) rotate(2deg)}55%{transform:translateY(-6px) rotate(-2deg)}}
#anamvale-root:has(.anam-body .farm-card) .store-chip{border-radius:7px;border-color:#cde2d0;background:#f3fbf2}

@media(max-width:640px){.anam-banner svg{height:clamp(165px,52vw,230px)}:is(#screen-kindredvillage,#screen-anamvale) .kv-room-kindred .kart-mini{width:clamp(70px,18vw,98px)}}
@media(max-width:640px){:is(#screen-kindredvillage,#screen-anamvale) .kv-room-heading{align-items:flex-start;flex-direction:column}:is(#screen-kindredvillage,#screen-anamvale) .kv-room-heading .pw-action{width:100%}}

:is(#screen-kindredvillage,#screen-anamvale) .pw-item[data-village-kind="furniture"]{
  min-height:220px;justify-content:flex-end;background:linear-gradient(180deg,#fbfffc,#fff 62%);
  border:2px solid #d6eae4;border-radius:10px;box-shadow:0 3px 0 rgba(38,59,82,.08)
}
:is(#screen-kindredvillage,#screen-anamvale) .pw-item[data-village-kind="homes"]{
  min-height:238px;justify-content:flex-end;background:linear-gradient(180deg,#f6fffb,#fff 62%);
  border:2px solid #d6eae4;border-radius:10px;box-shadow:0 3px 0 rgba(38,59,82,.08)
}
:is(#screen-kindredvillage,#screen-anamvale) .pw-item[data-village-kind="food"]{
  min-height:220px;justify-content:flex-end;background:linear-gradient(180deg,#fffaf0,#fff 62%);
  border:2px solid #eadfc9;border-radius:10px;box-shadow:0 3px 0 rgba(38,59,82,.08)
}
:is(#screen-kindredvillage,#screen-anamvale) .pw-item[data-village-kind="furniture"] .big{display:none}
:is(#screen-kindredvillage,#screen-anamvale) .pw-item[data-village-kind="furniture"] button{width:min(88px,100%);align-self:center}
:is(#screen-kindredvillage,#screen-anamvale) .pw-item[data-village-kind="homes"] .big{display:none}
:is(#screen-kindredvillage,#screen-anamvale) .pw-item[data-village-kind="homes"]::before{content:none!important;display:none!important}
:is(#screen-kindredvillage,#screen-anamvale) .pw-item[data-village-kind="homes"] button{width:min(118px,100%);align-self:center}
:is(#screen-kindredvillage,#screen-anamvale) .pw-item[data-village-kind="food"] button{width:min(88px,100%);align-self:center}
.kv-food-art{
  position:relative;display:block;width:118px;height:104px;margin:0 auto 8px;isolation:isolate;
  animation:farm-producer 3s ease-in-out infinite;filter:drop-shadow(0 7px 5px rgba(69,51,31,.14));
}
.kv-food-art img,.decor-img{display:block;width:100%;height:100%;object-fit:contain;user-select:none;-webkit-user-drag:none}
.kv-food-mode-feed{width:130px;height:112px}.kv-food-mode-inventory{width:82px;height:72px;margin:0 auto 4px}.kv-food-mode-fly{width:74px;height:62px;margin:0;animation:none;filter:drop-shadow(0 6px 4px rgba(69,51,31,.18))}
.decor-sprite{
  --decor-room-size:130px;--decor-shadow:rgba(42,43,62,.18);
  position:relative;isolation:isolate;display:block;width:122px;height:108px;margin:0 auto 8px;
  transform-origin:50% 100%;filter:drop-shadow(0 7px 5px rgba(59,35,15,.14));
}
.decor-mode-shop{width:126px;height:112px}
.decor-mode-room{width:var(--decor-room-size);height:calc(var(--decor-room-size)*.82);margin:0;filter:drop-shadow(0 10px 6px rgba(59,35,15,.18))}
.decor-mode-inventory{width:82px;height:72px;margin:0 auto 4px}.decor-mode-chip{width:34px;height:28px;margin:0}
.kv-home-art{display:block;width:100%;margin:0 auto 8px;overflow:hidden;border:2px solid #cfe5df;border-radius:9px;background:#edf8f6;box-shadow:0 3px 0 rgba(38,59,82,.08)}
.kv-home-art img{display:block;width:100%;height:100%;object-fit:cover;user-select:none;-webkit-user-drag:none}
.kv-home-mode-shop{height:112px}
.kv-home-mode-inventory{height:82px}
.decor-sprite::after{content:"";position:absolute;left:14%;right:14%;bottom:5%;height:14%;z-index:-1;border-radius:999px;background:var(--decor-shadow);filter:blur(3px);opacity:.65}
.decor-part{position:absolute;display:none;box-sizing:border-box}
.kv-food-fly{width:74px;height:62px;font-size:0;transform:translate(-50%,-50%) scale(.95)}
.kv-avatar.eating{animation:kvEatBounce .85s ease-in-out!important}
.kv-avatar.eating>.kart{animation:kvKindredChew .42s ease-in-out 2!important;transform-origin:50% 82%}
.kart[data-species="astralynx"][data-action]{
  aspect-ratio:362/336;
  background-size:contain;
  background-position:center;
}
.kv-action-preview{
  grid-column:1/-1;
  display:grid;
  grid-template-columns:repeat(8,minmax(0,1fr));
  gap:6px;
  margin:0;
}
:is(#screen-kindredvillage,#screen-anamvale) .kv-action-preview .pw-action{
  min-height:30px;
  padding:4px 6px;
  border:1px solid rgba(196,220,216,.95);
  border-radius:8px;
  background:linear-gradient(180deg,#fff,#eefbf7);
  color:#31556a;
  font-size:.7rem;
  line-height:1;
  box-shadow:0 2px 0 rgba(38,59,82,.1);
}
@media(max-width:760px){.kv-action-preview{grid-template-columns:repeat(4,minmax(0,1fr))}}
@keyframes kvEatBounce{0%,100%{transform:translateY(0) scale(1)}22%{transform:translateY(-8px) scale(1.03,.97)}44%{transform:translateY(2px) scale(.97,1.04)}67%{transform:translateY(-12px) scale(1.04,.96)}82%{transform:translateY(0) scale(.99,1.02)}}
@keyframes kvKindredChew{0%,100%{transform:scale(1)}34%{transform:scale(1.035,.955) translateY(3px)}68%{transform:scale(.985,1.035) translateY(-2px)}}
.decor-core{left:16%;right:16%;top:34%;bottom:17%;border:2px solid rgba(255,255,255,.82);border-radius:45% 55% 42% 58%/54% 46% 54% 46%;background:linear-gradient(145deg,#fff6d7,#87ceb9);box-shadow:inset 0 -8px 13px rgba(48,43,76,.14),0 5px 0 rgba(42,43,62,.08)}
.decor-a{left:27%;top:18%;width:46%;height:36%;border-radius:50%;background:radial-gradient(circle at 35% 25%,#fff,transparent 34%),linear-gradient(145deg,#fff7bd,#f0c65a);box-shadow:0 4px 7px rgba(45,40,70,.14)}
.decor-b{left:24%;top:57%;width:52%;height:13%;border-radius:999px;background:rgba(255,255,255,.62)}
.decor-c{left:34%;top:42%;width:32%;height:26%;border-radius:50%;background:rgba(255,255,255,.28)}
.decor-place-btn{min-width:0}
:is(#screen-kindredvillage,#screen-anamvale) .decor-room-item{overflow:visible}
:is(#screen-kindredvillage,#screen-anamvale) .decor-takeback{
  position:absolute;left:50%;top:-30px;z-index:10;transform:translateX(-50%);
  display:inline-flex;align-items:center;justify-content:center;min-height:24px;padding:4px 8px;
  border:2px solid #d6e8e4;border-radius:999px;background:rgba(255,255,255,.96);
  color:#25445c;font-family:var(--anam-font);font-weight:700;font-size:.68rem;line-height:1;
  cursor:pointer;opacity:.86;pointer-events:auto;box-shadow:0 2px 0 rgba(38,59,82,.12);
}
:is(#screen-kindredvillage,#screen-anamvale) .room-item:hover .decor-takeback,
:is(#screen-kindredvillage,#screen-anamvale) .room-item:focus-within .decor-takeback{opacity:1}
:is(#screen-kindredvillage,#screen-anamvale) .kv-decor-box{
  margin:12px 0 0;padding:12px;border:2px solid #d8e8e2;border-radius:12px;
  background:rgba(255,255,255,.78);box-shadow:0 3px 0 rgba(38,59,82,.08);
}
:is(#screen-kindredvillage,#screen-anamvale) .kv-decor-box-head{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;margin-bottom:9px}
:is(#screen-kindredvillage,#screen-anamvale) .kv-decor-box-head h3,:is(#screen-kindredvillage,#screen-anamvale) .kv-inventory-title{
  display:flex;align-items:center;gap:8px;margin:0;color:#40345f;line-height:1.1;
}
:is(#screen-kindredvillage,#screen-anamvale) .kv-decor-box-head p{margin:0;color:#65708a;font-size:.84rem}
:is(#screen-kindredvillage,#screen-anamvale) .kv-decor-tray{display:grid;grid-template-columns:repeat(auto-fit,minmax(145px,1fr));gap:8px}
:is(#screen-kindredvillage,#screen-anamvale) .kv-decor-chip{
  display:flex;align-items:center;gap:8px;min-width:0;min-height:48px;padding:7px 9px;
  border:2px solid #d7e8e4;border-radius:9px;background:#fff;color:#26364e;
  font-family:var(--anam-font);font-weight:700;box-shadow:0 2px 0 rgba(38,59,82,.1);cursor:pointer;
}
:is(#screen-kindredvillage,#screen-anamvale) .kv-decor-chip:hover{transform:translateY(-2px);border-color:#58bfb0}
:is(#screen-kindredvillage,#screen-anamvale) .kv-decor-chip.selected{border-color:#35c96d;background:linear-gradient(180deg,#f3fff7,#fff);color:#1c7a44}
:is(#screen-kindredvillage,#screen-anamvale) .kv-decor-chip.elsewhere{opacity:.72}
:is(#screen-kindredvillage,#screen-anamvale) .kv-decor-chip .decor-sprite{flex:0 0 auto;margin:0}
:is(#screen-kindredvillage,#screen-anamvale) .kv-decor-chip span{min-width:0;overflow-wrap:anywhere;text-align:left}
:is(#screen-kindredvillage,#screen-anamvale) .kv-decor-empty{margin:4px 0;color:#5a6691}
:is(#screen-kindredvillage,#screen-anamvale) .kv-inventory-title{margin:12px 0 6px}
:is(#screen-kindredvillage,#screen-anamvale) .kv-inv-cell{display:flex;flex-direction:column;justify-content:flex-end;min-height:190px;overflow:visible}
:is(#screen-kindredvillage,#screen-anamvale) .kv-card-actions{display:flex;flex-direction:column;align-items:center;gap:5px;margin-top:5px}
:is(#screen-kindredvillage,#screen-anamvale) .kv-inv-cell button{align-self:center;width:min(128px,100%);border-radius:8px}
:is(#screen-kindredvillage,#screen-anamvale) .kv-home-thumb{display:block;width:100%;height:82px;margin:0 0 7px;border:2px solid #cfe5df;border-radius:9px;background-position:center;background-size:cover;background-repeat:no-repeat}
.kv-modal-art{display:flex;justify-content:center;margin:0 auto 8px}
.kv-modal-art .kv-tab-icon{display:inline-grid;place-items:center;width:78px;height:58px;overflow:hidden;border:2px solid #cfe5df;border-radius:10px;background:#fff;box-shadow:0 3px 0 rgba(38,59,82,.08)}
.kv-modal-art .kv-tab-icon img{display:block;width:100%;height:100%;object-fit:cover}
.decor-bed{--decor-room-size:104px}.decor-bed .decor-core{left:13%;right:13%;top:52%;bottom:18%;border-radius:999px 999px 42% 42%;background:linear-gradient(180deg,#fff7de,#f2c75f)}.decor-bed .decor-a{left:22%;top:17%;width:42%;height:48%;background:#f8d45d;border-radius:50%;box-shadow:10px 1px 0 #fff7de,0 6px 8px rgba(48,43,76,.13)}.decor-bed .decor-b{left:20%;top:62%;width:62%;height:12%;background:#e7b553}.decor-bed .decor-c{left:58%;top:48%;width:19%;height:15%;background:#fff4b6}
.decor-sofa,.decor-leaf_sofa,.decor-floor_cushions{--decor-room-size:110px}.decor-sofa .decor-core,.decor-leaf_sofa .decor-core,.decor-floor_cushions .decor-core{left:10%;right:10%;top:40%;bottom:17%;border-radius:30% 30% 35% 35%;background:linear-gradient(145deg,#ffd8c5,#f39a6d)}.decor-sofa .decor-a,.decor-floor_cushions .decor-a{left:17%;top:22%;width:32%;height:35%;background:#ffe6d4}.decor-sofa .decor-b,.decor-floor_cushions .decor-b{left:51%;top:22%;width:32%;height:35%;background:#ffc39f;border-radius:42%}.decor-sofa .decor-c,.decor-floor_cushions .decor-c{left:22%;top:60%;width:56%;height:10%;background:#c96f55}.decor-leaf_sofa .decor-core{background:linear-gradient(145deg,#dff9c9,#73bd65)}.decor-leaf_sofa .decor-a{left:16%;top:19%;width:38%;height:41%;border-radius:70% 20% 70% 25%;background:#bde783;transform:rotate(-20deg)}.decor-leaf_sofa .decor-b{left:45%;top:18%;width:39%;height:42%;border-radius:20% 70% 25% 70%;background:#8bd176;transform:rotate(18deg)}
.decor-rug,.decor-pond_mat{--decor-room-size:126px}.decor-rug .decor-core,.decor-pond_mat .decor-core{left:5%;right:5%;top:52%;bottom:16%;border-radius:50%;background:conic-gradient(from 180deg,#ff7baa,#ffd35e,#6bd59f,#70bdf2,#b185e8,#ff7baa);border-width:3px}.decor-rug .decor-a{left:18%;top:57%;width:64%;height:16%;background:#fff6d8}.decor-rug .decor-b{left:29%;top:60%;width:42%;height:7%;background:#78d2bd}.decor-pond_mat .decor-core{background:radial-gradient(circle at 50% 44%,#a8f0dc 0 22%,#6bcbb2 23% 58%,#3fa986 59%)}.decor-pond_mat .decor-a{left:43%;top:30%;width:22%;height:30%;border-radius:50% 50% 45% 45%;background:linear-gradient(#ffd8f2,#ff96cb);transform:rotate(35deg)}.decor-pond_mat .decor-b{left:31%;top:35%;width:22%;height:30%;background:linear-gradient(#fff1fa,#ffb2dc);transform:rotate(-32deg)}.decor-pond_mat .decor-c{left:47%;top:54%;width:22%;height:12%;background:#f6ffea;border-radius:60% 40%}
.decor-lamp,.decor-shell_lamp{--decor-room-size:80px}.decor-lamp .decor-core,.decor-shell_lamp .decor-core{left:35%;right:35%;top:47%;bottom:15%;border-radius:8px;background:linear-gradient(#7c573d,#4d352b)}.decor-lamp .decor-a{left:22%;top:20%;width:56%;height:39%;border-radius:45% 45% 38% 38%;background:radial-gradient(circle at 50% 30%,#fff7c8,#f88f47 65%,#6e3b2e 66%)}.decor-lamp .decor-b,.decor-shell_lamp .decor-b{left:26%;top:68%;width:48%;height:9%;background:#5c3a2e}.decor-shell_lamp .decor-a{left:20%;top:18%;width:60%;height:42%;border-radius:60% 40% 48% 52%;background:repeating-radial-gradient(circle at 30% 35%,#fff7ed 0 8px,#efc0b1 9px 13px);transform:rotate(-24deg)}
.decor-table,.decor-mush_table{--decor-room-size:92px}.decor-table .decor-core,.decor-mush_table .decor-core{left:22%;right:22%;top:45%;bottom:28%;border-radius:50%;background:linear-gradient(#e6bf78,#9b6840)}.decor-table .decor-a{left:33%;top:60%;width:10%;height:25%;background:#7f563b;border-radius:999px}.decor-table .decor-b{left:57%;top:60%;width:10%;height:25%;background:#7f563b;border-radius:999px}.decor-table .decor-c{left:38%;top:27%;width:24%;height:18%;background:radial-gradient(circle at 50% 20%,#fff,#a7d9b7);border-radius:0 0 50% 50%}.decor-mush_table .decor-core{left:16%;right:16%;top:40%;bottom:31%;background:radial-gradient(circle at 50% 35%,#fff6e6 0 12%,#e85e55 13% 70%)}.decor-mush_table .decor-a{left:39%;top:56%;width:22%;height:28%;border-radius:8px;background:#f8d7b0}
.decor-poster,.decor-star_mobile{--decor-room-size:78px}.decor-poster .decor-core{left:21%;right:21%;top:19%;bottom:28%;border-radius:18px;background:radial-gradient(circle at 50% 45%,#fff8c4 0 20%,#f8c94d 21% 42%,#fff2b1 43%)}.decor-poster .decor-a,.decor-star_mobile .decor-a{left:34%;top:11%;width:32%;height:32%;clip-path:polygon(50% 0,62% 35%,98% 35%,68% 55%,80% 92%,50% 68%,20% 92%,32% 55%,2% 35%,38% 35%);background:#ffd24d;filter:drop-shadow(0 3px 2px rgba(76,57,18,.18))}.decor-star_mobile .decor-core{left:46%;right:46%;top:10%;bottom:28%;border-radius:999px;background:#d49b38}.decor-star_mobile .decor-b{left:18%;top:52%;width:25%;height:25%;clip-path:polygon(50% 0,62% 35%,98% 35%,68% 55%,80% 92%,50% 68%,20% 92%,32% 55%,2% 35%,38% 35%);background:#fff1a3}.decor-star_mobile .decor-c{left:61%;top:48%;width:21%;height:21%;clip-path:polygon(50% 0,62% 35%,98% 35%,68% 55%,80% 92%,50% 68%,20% 92%,32% 55%,2% 35%,38% 35%);background:#ffe071}
.decor-books{--decor-room-size:86px}.decor-books .decor-core{left:20%;right:18%;top:31%;bottom:23%;border-radius:8px;background:linear-gradient(90deg,#6fb7e7 0 28%,#fff7d7 29% 36%,#e86c72 37% 64%,#fff7d7 65% 72%,#69b868 73%)}.decor-books .decor-a{left:25%;top:21%;width:48%;height:16%;background:#6a56b4;border-radius:5px;transform:rotate(-9deg)}.decor-books .decor-b{left:35%;top:55%;width:38%;height:7%;background:rgba(255,255,255,.75)}
.decor-tv{--decor-room-size:96px}.decor-tv .decor-core{left:16%;right:16%;top:27%;bottom:25%;border-radius:18px;background:linear-gradient(145deg,#6a4436,#2d2d39)}.decor-tv .decor-a{left:24%;top:33%;width:52%;height:33%;border-radius:12px;background:radial-gradient(circle at 35% 25%,#efffff,#9fb8c2 65%,#485263)}.decor-tv .decor-b{left:37%;top:74%;width:26%;height:7%;background:#704b3a}.decor-tv .decor-c{left:31%;top:14%;width:38%;height:18%;border-radius:50% 50% 0 0;background:transparent;border-top:3px solid #704b3a}
.decor-plant,.decor-flowers,.decor-wreath,.decor-garden_gate,.decor-flower_arch{--decor-room-size:86px}.decor-plant .decor-core,.decor-flowers .decor-core{left:31%;right:31%;top:56%;bottom:14%;border-radius:8px 8px 18px 18px;background:linear-gradient(#df9b5c,#9e653a)}.decor-plant .decor-a,.decor-wreath .decor-a,.decor-garden_gate .decor-a{left:26%;top:25%;width:22%;height:32%;border-radius:80% 20% 80% 25%;background:#71bf62;transform:rotate(-30deg)}.decor-plant .decor-b,.decor-wreath .decor-b,.decor-garden_gate .decor-b{left:50%;top:21%;width:25%;height:34%;border-radius:20% 80% 25% 80%;background:#89d36d;transform:rotate(25deg)}.decor-plant .decor-c{left:41%;top:39%;width:18%;height:25%;background:#54994e;border-radius:999px}.decor-flowers .decor-a,.decor-flower_arch .decor-a{left:21%;top:20%;width:20%;height:20%;border-radius:50%;background:#ff8fc5;box-shadow:18px -6px 0 #ffd047,34px 2px 0 #ff76a8,12px 18px 0 #fff2a8,31px 19px 0 #bb8dff}.decor-flowers .decor-b{left:39%;top:38%;width:22%;height:28%;background:#71bf62;clip-path:polygon(50% 0,68% 100%,32% 100%)}.decor-wreath .decor-core{left:21%;right:21%;top:22%;bottom:24%;border-radius:50%;background:conic-gradient(#8ad36e,#4fae58,#b6e381,#6bb85c,#8ad36e)}.decor-wreath .decor-c{left:35%;top:36%;width:30%;height:26%;border-radius:50%;background:#fff}.decor-garden_gate .decor-core{left:19%;right:19%;top:33%;bottom:18%;border-radius:8px;background:linear-gradient(90deg,#8d6c4e 0 13%,transparent 14% 30%,#8d6c4e 31% 44%,transparent 45% 61%,#8d6c4e 62% 75%,transparent 76%)}.decor-garden_gate .decor-c{left:17%;top:51%;width:66%;height:8%;background:#6ba65a;border-radius:999px}.decor-flower_arch .decor-core{left:13%;right:13%;top:17%;bottom:20%;border-radius:50% 50% 8px 8px;border:6px solid #8abc69;background:transparent}.decor-flower_arch .decor-b{left:59%;top:22%;width:20%;height:20%;border-radius:50%;background:#ff9ccc;box-shadow:-39px 6px 0 #ffc857,-19px -8px 0 #f783b5}
.decor-crystal{--decor-room-size:82px}.decor-crystal .decor-core{left:27%;right:27%;top:18%;bottom:23%;clip-path:polygon(50% 0,84% 22%,74% 82%,50% 100%,26% 82%,16% 22%);border-radius:0;background:linear-gradient(145deg,#fff2ff,#8747ca 62%,#512987)}.decor-crystal .decor-a{left:35%;top:23%;width:18%;height:48%;background:rgba(255,255,255,.55);clip-path:polygon(50% 0,100% 18%,70% 100%,20% 100%,0 18%)}.decor-crystal .decor-b{left:24%;top:72%;width:52%;height:9%;background:#61408f}.decor-crystal .decor-c{left:55%;top:17%;width:9%;height:9%;background:#fff;border-radius:50%}
.decor-fishtank,.decor-bubble_chair{--decor-room-size:96px}.decor-fishtank .decor-core,.decor-bubble_chair .decor-core{left:17%;right:17%;top:27%;bottom:20%;border-radius:28px;background:linear-gradient(145deg,rgba(232,255,255,.96),rgba(99,205,224,.75));border-color:#dffcff}.decor-fishtank .decor-a,.decor-bubble_chair .decor-a{left:26%;top:36%;width:22%;height:22%;border-radius:50%;background:rgba(255,255,255,.78);box-shadow:25px 4px 0 rgba(255,255,255,.55)}.decor-fishtank .decor-b{left:33%;top:62%;width:34%;height:10%;background:#66b996;border-radius:80% 20% 80% 20%}.decor-bubble_chair .decor-b{left:31%;top:57%;width:38%;height:18%;background:#a0e6ee;border-radius:45%}.decor-bubble_chair .decor-c{left:38%;top:73%;width:24%;height:8%;background:#69b8c9;border-radius:999px}
.decor-fireplace{--decor-room-size:100px}.decor-fireplace .decor-core{left:15%;right:15%;top:40%;bottom:17%;border-radius:14px 14px 8px 8px;background:linear-gradient(#8b6047,#52372f)}.decor-fireplace .decor-a{left:36%;top:20%;width:28%;height:47%;border-radius:60% 60% 48% 48%;background:radial-gradient(circle at 50% 75%,#fff48f 0 16%,#ff9e35 17% 54%,#ec4d35 55%)}.decor-fireplace .decor-b{left:21%;top:66%;width:58%;height:9%;background:#3e2a27}.decor-fireplace .decor-c{left:25%;top:48%;width:50%;height:30%;border:3px solid #6f4638;border-radius:8px;background:transparent}
.decor-toybox,.decor-snack_cart{--decor-room-size:98px}.decor-toybox .decor-core,.decor-snack_cart .decor-core{left:17%;right:17%;top:39%;bottom:19%;border-radius:12px;background:linear-gradient(145deg,#ff7ca1,#d94779)}.decor-toybox .decor-a{left:13%;top:31%;width:74%;height:16%;background:#ffd361;border-radius:8px}.decor-toybox .decor-b{left:45%;top:29%;width:10%;height:51%;background:#ffd361}.decor-toybox .decor-c{left:37%;top:18%;width:26%;height:18%;border-radius:50%;background:#ff6d8f}.decor-snack_cart .decor-core{left:18%;right:18%;top:38%;bottom:30%;background:linear-gradient(#96a4f2,#666ec8)}.decor-snack_cart .decor-a{left:21%;top:22%;width:58%;height:25%;border-radius:50%;background:#88a2ff;box-shadow:0 0 0 6px rgba(255,255,255,.42)}.decor-snack_cart .decor-b{left:23%;top:67%;width:13%;height:13%;background:#2d355e;border-radius:50%;box-shadow:39px 0 0 #2d355e}.decor-snack_cart .decor-c{left:64%;top:42%;width:21%;height:6%;background:#7b4f3d;border-radius:999px;transform:rotate(-22deg)}
.decor-piano,.decor-mini_stage{--decor-room-size:108px}.decor-piano .decor-core,.decor-mini_stage .decor-core{left:12%;right:12%;top:46%;bottom:18%;border-radius:12px;background:linear-gradient(145deg,#5f4b83,#2f2a50)}.decor-piano .decor-a{left:20%;top:54%;width:60%;height:13%;background:repeating-linear-gradient(90deg,#fff 0 8%,#252540 9% 12%)}.decor-piano .decor-b,.decor-mini_stage .decor-b{left:30%;top:71%;width:9%;height:17%;background:#2e2740;border-radius:999px;box-shadow:32px 0 0 #2e2740}.decor-piano .decor-c,.decor-mini_stage .decor-a{left:42%;top:20%;width:16%;height:38%;border:3px solid #2e2740;border-left:0;border-bottom:0;border-radius:50%;background:transparent}.decor-mini_stage .decor-core{background:linear-gradient(145deg,#bca5ff,#6e57b8)}.decor-mini_stage .decor-a{left:42%;top:19%;width:16%;height:41%}.decor-mini_stage .decor-c{left:18%;top:41%;width:64%;height:11%;background:repeating-linear-gradient(90deg,#fff4c8 0 12%,#614e8d 13% 22%);border-radius:999px}
.decor-window_seat{--decor-room-size:104px}.decor-window_seat .decor-core{left:14%;right:14%;top:23%;bottom:22%;border-radius:10px;background:linear-gradient(145deg,#b9e6ff,#76bfe1);box-shadow:inset 0 0 0 7px #9a6f4e}.decor-window_seat .decor-a{left:20%;top:29%;width:60%;height:7%;background:#9a6f4e}.decor-window_seat .decor-b{left:47%;top:25%;width:7%;height:47%;background:#9a6f4e}.decor-window_seat .decor-c{left:22%;top:68%;width:56%;height:13%;background:#f0b7ca;border-radius:999px}
.decor-dream_tent{--decor-room-size:112px}.decor-dream_tent .decor-core{left:15%;right:15%;top:23%;bottom:15%;clip-path:polygon(50% 0,100% 100%,0 100%);border-radius:0;background:linear-gradient(135deg,#ffe2a8 0 48%,#e8654d 49% 62%,#fff0bb 63%)}.decor-dream_tent .decor-a{left:40%;top:43%;width:20%;height:39%;clip-path:polygon(50% 0,100% 100%,0 100%);background:#69453a}.decor-dream_tent .decor-b{left:19%;top:76%;width:62%;height:8%;background:#a76549;border-radius:999px}

/* Premium five-family Kindred sprite system and shared animation rig. */
.kart[data-species]{position:relative;aspect-ratio:1/1;background-repeat:no-repeat;background-position:center;background-size:contain;filter:drop-shadow(0 8px 5px rgba(35,48,66,.2));will-change:transform}
.kart[data-species]:not(.is-svg-fallback) svg{visibility:hidden;position:absolute;inset:0}
.kart[data-species].is-svg-fallback{background-image:none!important}
.kart[data-species].is-svg-fallback svg{visibility:visible;position:static;width:100%;height:auto}
.kart[data-species].is-sleeping{animation:kindred-sprite-sleep 3.6s ease-in-out infinite!important;filter:brightness(.82) saturate(.82) drop-shadow(0 8px 5px rgba(35,48,66,.2))}
@keyframes kindred-sprite-sleep{0%,100%{transform:translateY(4px) rotate(-3deg) scale(.98)}50%{transform:translateY(7px) rotate(-3deg) scale(1.015)}}
.kart[data-life-stage="baby"]{scale:.76}.kart[data-life-stage="teen"]{scale:.9}.kart[data-life-stage="adult"]{scale:1}
.kart[data-species="quokka"]{background-image:url("images/kindreds/quokka.png")}
.kart[data-species="wombat"]{background-image:url("images/kindreds/wombat.png")}
.kart[data-species="koala"]{background-image:url("images/kindreds/koala.png")}
.kart[data-species="kangaroo"]{background-image:url("images/kindreds/kangaroo.png")}
.kart[data-species="platypus"]{background-image:url("images/kindreds/platypus.png")}
.kart[data-species="echidna"]{background-image:url("images/kindreds/echidna.png")}
.kart[data-species="numbat"]{background-image:url("images/kindreds/numbat.png")}
.kart[data-species="bilby"]{background-image:url("images/kindreds/bilby.png")}
.kart[data-species="tassie_devil"]{background-image:url("images/kindreds/tassie_devil.png")}
.kart[data-species="kookaburra"]{background-image:url("images/kindreds/kookaburra.png")}
.kart[data-species="cockatoo"]{background-image:url("images/kindreds/cockatoo.png")}
.kart[data-species="lorikeet"]{background-image:url("images/kindreds/lorikeet.png")}
.kart[data-species="sugar_glider"]{background-image:url("images/kindreds/sugar_glider.png")}
.kart[data-species="dingo"]{background-image:url("images/kindreds/dingo.png")}
.kart[data-species="bluetongue"]{background-image:url("images/kindreds/bluetongue.png")}
.kart[data-species="puppy"]{background-image:url("images/kindreds/puppy.png")}
.kart[data-species="kitten"]{background-image:url("images/kindreds/kitten.png")}
.kart[data-species="rabbit"]{background-image:url("images/kindreds/rabbit.png")}
.kart[data-species="hamster"]{background-image:url("images/kindreds/hamster.png")}
.kart[data-species="guinea_pig"]{background-image:url("images/kindreds/guinea_pig.png")}
.kart[data-species="hedgehog"]{background-image:url("images/kindreds/hedgehog.png")}
.kart[data-species="red_panda"]{background-image:url("images/kindreds/red_panda.png")}
.kart[data-species="otter"]{background-image:url("images/kindreds/otter.png")}
.kart[data-species="fox"]{background-image:url("images/kindreds/fox.png")}
.kart[data-species="penguin"]{background-image:url("images/kindreds/penguin.png")}
.kart[data-species="panda"]{background-image:url("images/kindreds/panda.png")}
.kart[data-species="duck"]{background-image:url("images/kindreds/duck.png")}
.kart[data-species="lamb"]{background-image:url("images/kindreds/lamb.png")}
.kart[data-species="piglet"]{background-image:url("images/kindreds/piglet.png")}
.kart[data-species="fawn"]{background-image:url("images/kindreds/fawn.png")}
.kart[data-species="tideglimmer"]{background-image:url("images/kindreds-lifecycle/baby/tideglimmer.png")}
.kart[data-species="crystal_dragon"]{background-image:url("images/kindreds/crystal_dragon.png")}
.kart[data-species="stormplume"]{background-image:url("images/kindreds-lifecycle/baby/stormplume.png")}
.kart[data-species="mosswarcon"]{background-image:url("images/kindreds-lifecycle/baby/mosswarden.png")}
.kart[data-species="astralynx"]{background-image:url("images/kindreds-lifecycle/baby/astralynx.png")}
.kart[data-species="cloud_fox"]{background-image:url("images/kindreds/cloud_fox.png")}
.kart[data-species="marshmallow_sheep"]{background-image:url("images/kindreds/marshmallow_sheep.png")}
.kart[data-species="solforge"]{background-image:url("images/kindreds-lifecycle/baby/solforge.png")}
.kart[data-species="flower_turtle"]{background-image:url("images/kindreds/flower_turtle.png")}
.kart[data-species="emberclast"]{background-image:url("images/kindreds-lifecycle/baby/emberclast.png")}
.kart[data-species="space_hamster"]{background-image:url("images/kindreds/space_hamster.png")}
.kart[data-species="candy_unicorn"]{background-image:url("images/kindreds/candy_unicorn.png")}
.k-card .kart[data-species="kookaburra"],.k-card .kart[data-species="cockatoo"],.k-card .kart[data-species="lorikeet"],.k-card .kart[data-species="penguin"],.k-card .kart[data-species="duck"],.k-card .kart[data-species="sugar_glider"],.k-card .kart[data-species="stormplume"]{animation:kindred-wing-idle 2.5s ease-in-out infinite}
.k-card .kart[data-species="kangaroo"],.k-card .kart[data-species="rabbit"],.k-card .kart[data-species="bilby"],.k-card .kart[data-species="fawn"]{animation:kindred-hop-idle 2.8s ease-in-out infinite}
.k-card .kart[data-species="platypus"],.k-card .kart[data-species="echidna"],.k-card .kart[data-species="bluetongue"],.k-card .kart[data-species="flower_turtle"],.k-card .kart[data-species="mosswarcon"]{animation:kindred-ground-idle 3.6s ease-in-out infinite}
.k-card .kart[data-species="tideglimmer"],.k-card .kart[data-species="crystal_dragon"],.k-card .kart[data-species="astralynx"],.k-card .kart[data-species="cloud_fox"],.k-card .kart[data-species="emberclast"],.k-card .kart[data-species="space_hamster"],.k-card .kart[data-species="candy_unicorn"],.k-card .kart[data-species="solforge"]{animation:kindred-magic-idle 3s ease-in-out infinite}
@keyframes kindred-wing-idle{0%,100%{transform:translateY(0) rotate(-1deg)}45%{transform:translateY(-8px) rotate(2deg)}55%{transform:translateY(-8px) rotate(-2deg)}}
@keyframes kindred-hop-idle{0%,72%,100%{transform:translateY(0) scale(1)}80%{transform:translateY(-11px) scale(1.02,.97)}88%{transform:translateY(0) scale(.98,1.03)}}
@keyframes kindred-ground-idle{0%,100%{transform:translateX(-2px) rotate(-1deg)}50%{transform:translateX(3px) rotate(1deg)}}
@keyframes kindred-magic-idle{0%,100%{transform:translateY(0) scale(1);filter:drop-shadow(0 8px 5px rgba(35,48,66,.2))}50%{transform:translateY(-9px) scale(1.025);filter:drop-shadow(0 9px 9px rgba(93,95,220,.42))}}
.k-card:hover .kart[data-species],.pw-item:hover .kart[data-species],.kv-card-mini:hover .kart[data-species]{animation:kindred-sprite-greet .65s ease-in-out infinite alternate}
@keyframes kindred-sprite-greet{from{transform:translateY(-3px) rotate(-3deg) scale(1.02)}to{transform:translateY(-11px) rotate(3deg) scale(1.07)}}
.kart-big[data-species]{width:clamp(190px,32vw,280px)}.kart-med[data-species]{width:160px}.kart-mini[data-species]{width:78px}

/* Isolated future-species preview: artwork only, no ownership or Aurar hooks. */
.kindred-sample-section{margin-top:28px;padding:18px;border:3px solid #8f7ae5;border-radius:18px;background:linear-gradient(145deg,#f9f6ff,#eef9ff);box-shadow:0 6px 0 rgba(78,62,145,.15)}
.kindred-sample-head{text-align:center;max-width:760px;margin:0 auto 16px}.kindred-sample-head h3{margin:7px 0 4px;font-size:1.55rem;color:#443775}.kindred-sample-head p{margin:0;color:#596482}.kindred-sample-badge{display:inline-block;padding:4px 11px;border-radius:999px;background:#6f56c9;color:#fff;font-weight:700;font-size:.78rem;letter-spacing:.04em;text-transform:uppercase}
.kindred-sample-stage-labels{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;margin:0 0 7px;text-align:center;color:#3f3568;font-weight:700}.kindred-sample-stage-labels span{padding:6px;border-radius:10px;background:#e9e2ff}.kindred-sample-stage-labels small{font-weight:400;color:#665987}
.kindred-sample-sheet{overflow:hidden;margin:0;border:3px solid #d9c78d;border-radius:14px;background:#fff8e8;box-shadow:0 5px 12px rgba(55,46,91,.14)}.kindred-sample-sheet img{display:block;width:100%;height:auto}
.kindred-sample-key{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:8px;margin-top:12px}.kindred-sample-copy{padding:9px;border:2px solid #ded8f4;border-radius:12px;background:rgba(255,255,255,.9);text-align:center}.kindred-sample-copy strong{display:block;font-size:1rem;color:#30285b}.kindred-sample-copy>span{display:inline-block;margin:4px 0 6px;padding:2px 8px;border-radius:999px;background:#e9e2ff;color:#59449a;font-size:.72rem;font-weight:700}.kindred-sample-copy p{margin:0;color:#5a6691;font-size:.78rem;line-height:1.35}.kindred-sample-note{text-align:center;margin:14px 0 0;color:#665987;font-size:.85rem;font-weight:700}
@media(max-width:700px){.kindred-sample-section{padding:11px}.kindred-sample-key{grid-template-columns:1fr}.kindred-sample-copy{text-align:left}.kindred-sample-head h3{font-size:1.3rem}.kindred-sample-stage-labels{font-size:.82rem}.kindred-sample-stage-labels small{font-size:.68rem}}

/* One-time lifecycle evolution ceremony. */
.kv-evolution{text-align:center;overflow:hidden}.kv-evolution-kicker{margin:0;color:#6752a4;font-weight:700;animation:kv-evo-kicker 3.2s ease both}.kv-evolution-stars{color:#f3b928;font-size:1.5rem;letter-spacing:.35em;animation:kv-evo-stars 1.1s linear infinite}.kv-evolution-stage{position:relative;width:min(330px,75vw);aspect-ratio:1/1;margin:0 auto 5px;border-radius:50%;background:radial-gradient(circle,#fff 0 24%,#dff7ff 42%,#a68df3 72%,#37256e 100%);box-shadow:0 0 28px rgba(105,80,210,.55);overflow:hidden}.kv-evolution-form{position:absolute;inset:8%;width:84%;height:84%;object-fit:contain;filter:drop-shadow(0 10px 8px rgba(22,23,56,.3))}.kv-evolution-form.form-old{animation:kv-evo-old 3.15s ease-in-out both}.kv-evolution-form.form-new{opacity:0;animation:kv-evo-new 3.15s ease-in-out both}.kv-evolution-ring{position:absolute;inset:9%;border:5px solid rgba(255,255,255,.82);border-radius:50%;animation:kv-evo-ring 1.1s linear infinite}.kv-evolution-flash{position:absolute;inset:0;background:#fff;opacity:0;animation:kv-evo-flash 3.15s ease both}.kv-evolution h2{margin:4px 0;color:#4c378e;animation:kv-evo-copy 3.2s ease both}.kv-evolution p{margin:4px 0 10px}.kv-evolution-done{animation:kv-evo-copy 3.2s ease both}
@keyframes kv-evo-old{0%,28%{opacity:1;transform:scale(.78) rotate(-3deg);filter:brightness(1) drop-shadow(0 8px 7px rgba(22,23,56,.3))}55%{opacity:1;transform:scale(1.08) rotate(3deg);filter:brightness(4) saturate(0) drop-shadow(0 0 24px #fff)}68%,100%{opacity:0;transform:scale(1.2);filter:brightness(5) saturate(0)}}
@keyframes kv-evo-new{0%,58%{opacity:0;transform:scale(.55);filter:brightness(5) saturate(0)}70%{opacity:1;transform:scale(1.16);filter:brightness(2.2) saturate(.4)}84%,100%{opacity:1;transform:scale(1);filter:brightness(1) saturate(1)}}
@keyframes kv-evo-flash{0%,53%,72%,100%{opacity:0}61%{opacity:.94}}
@keyframes kv-evo-ring{from{transform:rotate(0) scale(.86);opacity:.9}50%{transform:rotate(180deg) scale(1.06);opacity:.35}to{transform:rotate(360deg) scale(.86);opacity:.9}}
@keyframes kv-evo-stars{50%{opacity:.35;transform:scale(1.08)}}@keyframes kv-evo-kicker{0%,72%{opacity:1}82%,100%{opacity:0;height:0;margin:0}}@keyframes kv-evo-copy{0%,72%{opacity:0;transform:translateY(8px)}84%,100%{opacity:1;transform:none}}
@media(prefers-reduced-motion:reduce){.kv-evolution *{animation-duration:.01ms!important;animation-delay:0ms!important}.kv-evolution-form.form-old{display:none}.kv-evolution-form.form-new{opacity:1;transform:none;filter:none}}

/* The Dance Hall's original choreography targeted SVG body groups. Premium
   sprites dance as a whole so every track remains visibly different. */
.dance-joy>.kart{animation:dance-joy .95s ease-in-out infinite!important}
.dance-minuet>.kart{animation:dance-minuet 1.8s ease-in-out infinite!important}
.dance-ballet>.kart{animation:dance-ballet 2.5s ease-in-out infinite!important}
.dance-skip>.kart{animation:dance-skip .8s cubic-bezier(.4,0,.6,1) infinite!important}
.dance-waltz>.kart{animation:dance-waltz 3.2s ease-in-out infinite!important}
.dance-calm>.kart{animation:dance-calm 4.4s ease-in-out infinite!important}
.dance-grand>.kart{animation:dance-grand 1.9s ease-in-out infinite!important}
.dance-dreamy>.kart{animation:dance-dreamy 5s ease-in-out infinite!important}
.dance-sneaky>.kart{animation:dance-sneaky 6s cubic-bezier(.7,0,.9,.4) infinite!important}
.dance-gallop>.kart{animation:dance-gallop .55s ease-in-out infinite!important}

/* Illustrated market, property and village inventory cards. */
.item-card[data-kind="vehicle"],.item-card[data-kind="property"],.item-card[data-business]{position:relative;overflow:hidden;isolation:isolate}
.item-card[data-kind="vehicle"]::before,.item-card[data-kind="property"]::before,.item-card[data-business]::before{content:"";display:block;height:118px;margin:-14px -14px 12px;background-position:center;background-size:contain;background-repeat:no-repeat;background-color:#edf8f6;border-bottom:2px solid #d5e9e5}
.item-card[data-kind="vehicle"] .item-icon,.item-card[data-kind="property"] .item-icon{display:none}
.item-card[data-kind="vehicle"]::before{background-color:#eaf6fb}.item-card[data-kind="property"]::before{background-color:#eef9ed}
.item-card[data-item="veh_bicycle"]::before{background-image:url("images/assets/veh_bicycle.png")}
.item-card[data-item="veh_scooter"]::before{background-image:url("images/assets/veh_scooter.png")}
.item-card[data-item="veh_gokart"]::before{background-image:url("images/assets/veh_gokart.png")}
.item-card[data-item="veh_classic"]::before{background-image:url("images/assets/veh_classic.png")}
.item-card[data-item="veh_sports"]::before{background-image:url("images/assets/veh_sports.png")}
.item-card[data-item="veh_monster"]::before{background-image:url("images/assets/veh_monster.png")}
.item-card[data-item="veh_balloon"]::before{background-image:url("images/assets/veh_balloon.png")}
.item-card[data-item="veh_vintage"]::before{background-image:url("images/assets/veh_vintage.png")}
.item-card[data-item="veh_speedboat"]::before{background-image:url("images/assets/veh_speedboat.png")}
.item-card[data-item="veh_caravan"]::before{background-image:url("images/assets/veh_caravan.png")}
.item-card[data-item^="prop_"]::before{background-size:cover;background-position:center}
.item-card[data-item="prop_cottage"]::before{background-image:url("images/kindred-theme/cards/properties/prop_cottage.jpg")}
.item-card[data-item="prop_village"]::before{background-image:url("images/kindred-theme/cards/properties/prop_village.jpg")}
.item-card[data-item="prop_farmhouse"]::before{background-image:url("images/kindred-theme/cards/properties/prop_farmhouse.jpg")}
.item-card[data-item="prop_beach"]::before{background-image:url("images/kindred-theme/cards/properties/prop_beach.jpg")}
.item-card[data-item="prop_castle"]::before{background-image:url("images/kindred-theme/cards/properties/prop_castle.jpg")}
.item-card[data-item="prop_floating"]::before{background-image:url("images/kindred-theme/cards/properties/prop_floating.jpg")}
.item-card[data-item="prop_treehouse"]::before{background-image:url("images/kindred-theme/cards/properties/prop_treehouse.jpg")}
.item-card[data-item="prop_candy"]::before{background-image:url("images/kindred-theme/cards/homes/home_candy.jpg")}
.item-card[data-item="prop_mushroom"]::before{background-image:url("images/kindred-theme/cards/homes/home_mushroom.jpg")}
.item-card[data-item="prop_jungle"]::before{background-image:url("images/kindred-theme/cards/homes/home_jungle.jpg")}
.item-card[data-item="prop_underwater"]::before{background-image:url("images/kindred-theme/cards/homes/home_under.jpg")}
.item-card[data-item="prop_star"]::before{background-image:url("images/kindred-theme/cards/homes/home_space.jpg")}
.item-card[data-item="prop_castle_home"]::before{background-image:url("images/kindred-theme/cards/homes/home_castle.jpg")}

.item-card[data-business]::before{height:104px;background-size:cover;background-position:center}
.item-card[data-business="biz_kindredshop"]::before{background-image:url("images/shops/kindred-shop.jpg")}
.item-card[data-business="biz_bookshop"]::before{background-image:url("images/shops/book-shop.jpg")}
.item-card[data-business="biz_bakery"]::before{background-image:url("images/shops/bakery.jpg")}
.item-card[data-business="biz_toyshop"]::before{background-image:url("images/shops/toy-shop.jpg")}
.item-card[data-business="biz_flowershop"]::before{background-image:url("images/shops/flower-shop.jpg")}
.item-card[data-business="biz_icecream"]::before{background-image:url("images/shops/ice-cream-shop.jpg")}
.item-card[data-business="biz_cafe"]::before{background-image:url("images/shops/kindred-cafe.jpg")}
.item-card[data-business="biz_garden"]::before{background-image:url("images/shops/garden-centre.jpg")}

:is(#screen-kindredvillage,#screen-anamvale) .pw-item[data-village-item]{overflow:hidden;transition:transform .16s ease,border-color .16s ease}
:is(#screen-kindredvillage,#screen-anamvale) .pw-item[data-village-item]:hover{transform:translateY(-4px);border-color:#58bfb0}
:is(#screen-kindredvillage,#screen-anamvale) .pw-item[data-village-item^="f_"]{background:linear-gradient(155deg,#fff9e7,#fff)}
:is(#screen-kindredvillage,#screen-anamvale) .pw-item[data-village-item^="f_"] .big{animation:farm-producer 2.8s ease-in-out infinite}
:is(#screen-kindredvillage,#screen-anamvale) .pw-item[data-village-item="tiny"] .big,:is(#screen-kindredvillage,#screen-anamvale) .pw-item[data-village-item="cottage"] .big,:is(#screen-kindredvillage,#screen-anamvale) .pw-item[data-village-item="tree"] .big,:is(#screen-kindredvillage,#screen-anamvale) .pw-item[data-village-item="igloo"] .big,:is(#screen-kindredvillage,#screen-anamvale) .pw-item[data-village-item="jungle"] .big,:is(#screen-kindredvillage,#screen-anamvale) .pw-item[data-village-item="mushroom"] .big,:is(#screen-kindredvillage,#screen-anamvale) .pw-item[data-village-item="candy"] .big,:is(#screen-kindredvillage,#screen-anamvale) .pw-item[data-village-item="under"] .big,:is(#screen-kindredvillage,#screen-anamvale) .pw-item[data-village-item="castle"] .big,:is(#screen-kindredvillage,#screen-anamvale) .pw-item[data-village-item="space"] .big{display:none}
:is(#screen-kindredvillage,#screen-anamvale) .pw-item[data-village-item="tiny"]::before,:is(#screen-kindredvillage,#screen-anamvale) .pw-item[data-village-item="cottage"]::before,:is(#screen-kindredvillage,#screen-anamvale) .pw-item[data-village-item="tree"]::before,:is(#screen-kindredvillage,#screen-anamvale) .pw-item[data-village-item="igloo"]::before,:is(#screen-kindredvillage,#screen-anamvale) .pw-item[data-village-item="jungle"]::before,:is(#screen-kindredvillage,#screen-anamvale) .pw-item[data-village-item="mushroom"]::before,:is(#screen-kindredvillage,#screen-anamvale) .pw-item[data-village-item="candy"]::before,:is(#screen-kindredvillage,#screen-anamvale) .pw-item[data-village-item="under"]::before,:is(#screen-kindredvillage,#screen-anamvale) .pw-item[data-village-item="castle"]::before,:is(#screen-kindredvillage,#screen-anamvale) .pw-item[data-village-item="space"]::before{content:"";display:block;width:100%;height:112px;margin-bottom:7px;border:2px solid #cfe5df;border-radius:9px;background-position:center;background-size:cover;background-repeat:no-repeat;box-shadow:0 3px 0 rgba(38,59,82,.08)}
:is(#screen-kindredvillage,#screen-anamvale) .pw-item[data-village-item="tiny"]::before{background-image:url("images/kindred-theme/cards/homes/home_tiny.jpg")}
:is(#screen-kindredvillage,#screen-anamvale) .pw-item[data-village-item="cottage"]::before{background-image:url("images/kindred-theme/cards/homes/home_cottage.jpg")}
:is(#screen-kindredvillage,#screen-anamvale) .pw-item[data-village-item="tree"]::before{background-image:url("images/kindred-theme/cards/homes/home_tree.jpg")}
:is(#screen-kindredvillage,#screen-anamvale) .pw-item[data-village-item="igloo"]::before{background-image:url("images/kindred-theme/cards/homes/home_igloo.jpg")}
:is(#screen-kindredvillage,#screen-anamvale) .pw-item[data-village-item="jungle"]::before{background-image:url("images/kindred-theme/cards/homes/home_jungle.jpg")}
:is(#screen-kindredvillage,#screen-anamvale) .pw-item[data-village-item="mushroom"]::before{background-image:url("images/kindred-theme/cards/homes/home_mushroom.jpg")}
:is(#screen-kindredvillage,#screen-anamvale) .pw-item[data-village-item="candy"]::before{background-image:url("images/kindred-theme/cards/homes/home_candy.jpg")}
:is(#screen-kindredvillage,#screen-anamvale) .pw-item[data-village-item="under"]::before{background-image:url("images/kindred-theme/cards/homes/home_under.jpg")}
:is(#screen-kindredvillage,#screen-anamvale) .pw-item[data-village-item="castle"]::before{background-image:url("images/kindred-theme/cards/homes/home_castle.jpg")}
:is(#screen-kindredvillage,#screen-anamvale) .pw-item[data-village-item="space"]::before{background-image:url("images/kindred-theme/cards/homes/home_space.jpg")}

@media(max-width:640px){.item-card[data-kind="vehicle"]::before,.item-card[data-kind="property"]::before{height:94px}}

/* Distinct business interiors and illustrated stock. */
#anamvale-root[data-area="shop"] .anam-body::before{content:"";display:block;width:100%;aspect-ratio:3/1;min-height:210px;margin-bottom:14px;border:3px solid #78cfc4;border-radius:10px;background-position:center;background-size:cover;background-repeat:no-repeat;box-shadow:0 5px 0 rgba(38,59,82,.12),0 12px 24px rgba(38,59,82,.1)}
#anamvale-root[data-business="biz_kindredshop"] .anam-body::before{background-image:url("images/shop-interiors/kindred-shop.jpg")}
#anamvale-root[data-business="biz_bookshop"] .anam-body::before{background-image:url("images/shop-interiors/book-shop.jpg")}
#anamvale-root[data-business="biz_bakery"] .anam-body::before{background-image:url("images/shop-interiors/bakery.jpg")}
#anamvale-root[data-business="biz_toyshop"] .anam-body::before{background-image:url("images/shop-interiors/toy-shop.jpg")}
#anamvale-root[data-business="biz_flowershop"] .anam-body::before{background-image:url("images/shop-interiors/flower-shop.jpg")}
#anamvale-root[data-business="biz_icecream"] .anam-body::before{background-image:url("images/shop-interiors/ice-cream-shop.jpg")}
#anamvale-root[data-business="biz_cafe"] .anam-body::before{background-image:url("images/shop-interiors/kindred-cafe.jpg")}
#anamvale-root[data-business="biz_garden"] .anam-body::before{background-image:url("images/shop-interiors/garden-centre.jpg")}

.shop-good-card{position:relative;overflow:hidden;min-height:365px}
.shop-good-card::before{content:"";display:block;height:138px;margin:-14px -14px 10px;border-bottom:2px solid #e2d8c8;background-repeat:no-repeat;background-size:300% auto;background-position-y:center;background-color:#f7f1e5}
.shop-good-card .item-icon{display:none}
.shop-good-card[data-good^="gd_collar"]::before,.shop-good-card[data-good^="gd_toybox"]::before,.shop-good-card[data-good^="gd_treats"]::before{background-image:url("images/shop-items/kindred-shop.jpg")}
.shop-good-card[data-good^="gd_picture"]::before,.shop-good-card[data-good^="gd_novel"]::before,.shop-good-card[data-good^="gd_comic"]::before{background-image:url("images/shop-items/book-shop.jpg")}
.shop-good-card[data-good^="gd_bread"]::before,.shop-good-card[data-good^="gd_croiss"]::before,.shop-good-card[data-good^="gd_cake"]::before{background-image:url("images/shop-items/bakery.jpg")}
.shop-good-card[data-good^="gd_teddy"]::before,.shop-good-card[data-good^="gd_blocks"]::before,.shop-good-card[data-good^="gd_yoyo"]::before{background-image:url("images/shop-items/toy-shop.jpg")}
.shop-good-card[data-good^="gd_rose"]::before,.shop-good-card[data-good^="gd_tulip"]::before,.shop-good-card[data-good^="gd_orchid"]::before{background-image:url("images/shop-items/flower-shop.jpg")}
.shop-good-card[data-good^="gd_cone"]::before,.shop-good-card[data-good^="gd_sundae"]::before,.shop-good-card[data-good^="gd_gelato"]::before{background-image:url("images/shop-items/ice-cream-shop.jpg")}
.shop-good-card[data-good^="gd_coffee"]::before,.shop-good-card[data-good^="gd_babycino"]::before,.shop-good-card[data-good^="gd_muffin"]::before{background-image:url("images/shop-items/kindred-cafe.jpg")}
.shop-good-card[data-good^="gd_seedling"]::before,.shop-good-card[data-good^="gd_potted"]::before,.shop-good-card[data-good^="gd_bonsai"]::before{background-image:url("images/shop-items/garden-centre.jpg")}

.shop-good-card[data-good="gd_collar"]::before,.shop-good-card[data-good="gd_picture"]::before,.shop-good-card[data-good="gd_bread"]::before,.shop-good-card[data-good="gd_teddy"]::before,.shop-good-card[data-good="gd_rose"]::before,.shop-good-card[data-good="gd_cone"]::before,.shop-good-card[data-good="gd_coffee"]::before,.shop-good-card[data-good="gd_seedling"]::before{background-position-x:left}
.shop-good-card[data-good="gd_toybox"]::before,.shop-good-card[data-good="gd_novel"]::before,.shop-good-card[data-good="gd_croiss"]::before,.shop-good-card[data-good="gd_blocks"]::before,.shop-good-card[data-good="gd_tulip"]::before,.shop-good-card[data-good="gd_sundae"]::before,.shop-good-card[data-good="gd_babycino"]::before,.shop-good-card[data-good="gd_potted"]::before{background-position-x:center}
.shop-good-card[data-good="gd_treats"]::before,.shop-good-card[data-good="gd_comic"]::before,.shop-good-card[data-good="gd_cake"]::before,.shop-good-card[data-good="gd_yoyo"]::before,.shop-good-card[data-good="gd_orchid"]::before,.shop-good-card[data-good="gd_gelato"]::before,.shop-good-card[data-good="gd_muffin"]::before,.shop-good-card[data-good="gd_bonsai"]::before{background-position-x:right}

@media(max-width:640px){#anamvale-root[data-area="shop"] .anam-body::before{min-height:150px}.shop-good-card{min-height:0}.shop-good-card::before{height:120px}}

/* Estate properties become selectable Kindred Home interiors. */
.property-move-btn{background:#1aaa96;box-shadow:0 3px 0 #107b6d}.property-move-btn:hover{filter:brightness(1.06)}
:is(#screen-kindredvillage,#screen-anamvale) .kv-room.property-prop_cottage{background-image:url("images/kindred-theme/rooms/properties/cottage.jpg")!important}
:is(#screen-kindredvillage,#screen-anamvale) .kv-room.property-prop_village{background-image:url("images/kindred-theme/rooms/properties/village.jpg")!important}
:is(#screen-kindredvillage,#screen-anamvale) .kv-room.property-prop_farmhouse{background-image:url("images/kindred-theme/rooms/properties/farmhouse.jpg")!important}
:is(#screen-kindredvillage,#screen-anamvale) .kv-room.property-prop_beach{background-image:url("images/kindred-theme/rooms/properties/beach.jpg")!important}
:is(#screen-kindredvillage,#screen-anamvale) .kv-room.property-prop_castle.floor-main{background-image:url("images/kindred-theme/rooms/properties/castle-main.jpg")!important}
:is(#screen-kindredvillage,#screen-anamvale) .kv-room.property-prop_castle.floor-upper{background-image:url("images/kindred-theme/rooms/properties/castle-upper.jpg")!important}
:is(#screen-kindredvillage,#screen-anamvale) .kv-room.property-prop_floating{background-image:url("images/kindred-theme/rooms/properties/floating.jpg")!important}
:is(#screen-kindredvillage,#screen-anamvale) .kv-room.property-prop_treehouse{background-image:url("images/kindred-theme/rooms/properties/treehouse.jpg")!important}
:is(#screen-kindredvillage,#screen-anamvale) .kv-room.property-prop_candy{background-image:url("images/kindred-theme/rooms/homes/candy.jpg")!important}
:is(#screen-kindredvillage,#screen-anamvale) .kv-room.property-prop_mushroom{background-image:url("images/kindred-theme/rooms/homes/mushroom.jpg")!important}
:is(#screen-kindredvillage,#screen-anamvale) .kv-room.property-prop_jungle{background-image:url("images/kindred-theme/rooms/homes/jungle.jpg")!important}
:is(#screen-kindredvillage,#screen-anamvale) .kv-room.property-prop_underwater{background-image:url("images/kindred-theme/rooms/homes/underwater.jpg")!important}
:is(#screen-kindredvillage,#screen-anamvale) .kv-room.property-prop_star{background-image:url("images/kindred-theme/rooms/homes/space.jpg")!important}
:is(#screen-kindredvillage,#screen-anamvale) .kv-room.property-prop_castle_home{background-image:url("images/kindred-theme/rooms/homes/castle.jpg")!important}
.property-floor-tabs{display:flex;gap:7px;flex-wrap:wrap;margin:7px 0 9px}.property-floor-tabs .pw-tab{border:2px solid #cfe2df}.property-floor-tabs .pw-tab.on{background:#e95d91;border-color:#bd3b6b;color:#fff}
.property-home-links{display:flex;gap:7px;flex-wrap:wrap;margin:10px 0}.property-home-links .pw-action{width:auto;min-width:160px}
@media(max-width:640px){.property-home-links .pw-action{min-width:0;flex:1}.property-floor-tabs .pw-tab{flex:1}}

/* Property Estate is a destination, not a loose pile of market cards. */
#anamvale-root[data-area="estate"] .anam-body{
  padding:14px;border:2px solid #d8eadf;border-radius:14px;
  background:linear-gradient(180deg,rgba(255,255,255,.96),rgba(241,249,240,.98));
}
.estate-page{display:flex;flex-direction:column;gap:18px}
.estate-section{margin:0;padding:14px;border:2px solid #d9e9df;border-radius:14px;background:rgba(255,255,255,.94);box-shadow:0 4px 0 rgba(52,94,65,.08)}
.estate-section-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:11px}
.estate-section-head .anam-h3,.estate-section-head .anam-note{margin-top:0;margin-bottom:4px}
.estate-grid{grid-template-columns:repeat(auto-fit,minmax(235px,1fr));gap:14px}
#anamvale-root[data-area="estate"] .item-card[data-kind="property"]{
  min-width:0;gap:9px;border-color:#cfe5d4;border-radius:13px;
  background:linear-gradient(180deg,#fff,#f7fcf6);
}
#anamvale-root[data-area="estate"] .item-card[data-kind="property"]::before{
  height:158px;margin:-14px -14px 4px;background-size:cover;background-color:#eaf7eb;
}
#anamvale-root[data-area="estate"] .item-card[data-kind="property"] .anam-btn{
  width:100%;align-self:stretch;margin:0;
}
#anamvale-root[data-area="estate"] .item-price-row{min-height:42px;align-content:center}
#anamvale-root[data-area="estate"] .avb{margin-top:auto}
@media(max-width:640px){
  .anam-banner-photo{aspect-ratio:16/9;min-height:170px}
  #anamvale-root[data-area="estate"] .anam-body{padding:8px}
  .estate-section{padding:10px}.estate-section-head{align-items:stretch;flex-direction:column}
  .estate-grid{grid-template-columns:1fr}
}

/* Window-fit pass for Hearthstone Valley and Kindred Village. The room artwork is
   1920x840, so keep the live room at the same 16:7 ratio while allowing it
   to fill the available browser width. */
#screen-anamvale,
:is(#screen-kindredvillage,#screen-anamvale),
#kindredvillage-root{
  width:100%;
  max-width:100%;
  min-width:0;
}
#anamvale-root{
  width:100%;
  max-width:none!important;
  margin-left:0;
  margin-right:0;
  padding-left:clamp(8px,1.2vw,18px);
  padding-right:clamp(8px,1.2vw,18px);
}
:is(#screen-kindredvillage,#screen-anamvale){
  overflow-x:clip;
}
:is(#screen-kindredvillage,#screen-anamvale) .pw-sky{
  width:100%;
  max-width:100%;
  min-width:0;
  padding-left:clamp(8px,1.2vw,18px);
  padding-right:clamp(8px,1.2vw,18px);
}
:is(#screen-kindredvillage,#screen-anamvale) .pw-header,
:is(#screen-kindredvillage,#screen-anamvale) .pw-tabs,
:is(#screen-kindredvillage,#screen-anamvale) #pw-body,
:is(#screen-kindredvillage,#screen-anamvale) .kv-room-heading,
:is(#screen-kindredvillage,#screen-anamvale) .property-home-links,
:is(#screen-kindredvillage,#screen-anamvale) .kv-decor-box,
:is(#screen-kindredvillage,#screen-anamvale) .kv-decor-tray{
  max-width:100%;
  min-width:0;
}
:is(#screen-kindredvillage,#screen-anamvale) .pw-header>*,
:is(#screen-kindredvillage,#screen-anamvale) .pw-tabs>*,
:is(#screen-kindredvillage,#screen-anamvale) .kv-room-heading>*,
:is(#screen-kindredvillage,#screen-anamvale) .property-home-links>*{
  min-width:0;
}
:is(#screen-kindredvillage,#screen-anamvale) .kv-main-tabs,
:is(#screen-kindredvillage,#screen-anamvale) .kv-shop-tabs,
:is(#screen-kindredvillage,#screen-anamvale) .property-floor-tabs,
:is(#screen-kindredvillage,#screen-anamvale) .property-home-links{
  justify-content:flex-start;
  overflow:visible;
}
:is(#screen-kindredvillage,#screen-anamvale) .kv-room{
  width:100%;
  aspect-ratio:16/7;
  min-height:0;
  background-size:cover;
  background-position:center;
}
:is(#screen-kindredvillage,#screen-anamvale) .kv-room-heading>div{
  flex:1 1 320px;
  min-width:0;
}
:is(#screen-kindredvillage,#screen-anamvale) .kv-room-heading h3,
:is(#screen-kindredvillage,#screen-anamvale) .kv-room-heading p{
  overflow-wrap:anywhere;
}
:is(#screen-kindredvillage,#screen-anamvale) .kv-room-heading .pw-action,
:is(#screen-kindredvillage,#screen-anamvale) .property-home-links .pw-action{
  flex:0 1 auto;
  min-width:min(160px,100%);
}
@media(max-width:760px){
  #anamvale-root{padding-left:6px;padding-right:6px}
  :is(#screen-kindredvillage,#screen-anamvale) .pw-sky{padding-left:6px;padding-right:6px}
  :is(#screen-kindredvillage,#screen-anamvale) .property-home-links .pw-action{flex:1 1 180px}
}
@media(max-width:520px){
  :is(#screen-kindredvillage,#screen-anamvale) .kv-room-heading{align-items:stretch;flex-direction:column}
  :is(#screen-kindredvillage,#screen-anamvale) .kv-room-heading .pw-action{width:100%}
  :is(#screen-kindredvillage,#screen-anamvale) .kv-main-tabs .pw-tab,
  :is(#screen-kindredvillage,#screen-anamvale) .kv-shop-tabs .pw-tab{flex:1 1 145px}
}

/* Immersive My Kindred Home: the owned home is now the main care scene. */
:is(#screen-kindredvillage,#screen-anamvale) .pw-sky:has(.kv-home-immersive){
  padding-top:clamp(8px,1vw,14px);
  background-image:linear-gradient(180deg,#e5f8f1,#f6fbef);
}
:is(#screen-kindredvillage,#screen-anamvale) .pw-sky:has(.kv-home-immersive) .kv-reminders{
  display:none;
}
body:has(:is(#screen-kindredvillage,#screen-anamvale).active .kv-home-immersive) .wl-tabbar{
  display:none;
}
body:has(:is(#screen-kindredvillage,#screen-anamvale).active .kv-home-immersive) .app{
  padding-bottom:0!important;
}
.kv-home-immersive{
  position:relative;
  z-index:2;
  display:flex;
  flex-direction:column;
  gap:8px;
}
.kv-home-titlebar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
  padding:7px 8px;
  border:2px solid #d8e8e2;
  border-radius:10px;
  background:rgba(255,255,255,.88);
}
.kv-home-titlebar>div{
  display:flex;
  align-items:center;
  gap:8px;
  min-width:0;
}
.kv-home-titlebar strong{
  display:block;
  color:#40345f;
  line-height:1.05;
}
.kv-home-titlebar small{
  display:block;
  color:#65708a;
  font-size:.78rem;
  line-height:1.1;
}
.kv-home-titlebar .kv-home-floors{
  display:flex;
  gap:6px;
  flex-wrap:wrap;
  margin-left:auto;
}
.kv-home-titlebar .pw-tab,
.kv-home-titlebar .pw-action{
  min-height:36px;
  padding:6px 10px!important;
  font-size:.82rem;
}
:is(#screen-kindredvillage,#screen-anamvale) .kv-home-live{
  position:relative;
  min-height:clamp(430px,calc(100vh - 330px),820px);
  border-width:3px;
  overflow:hidden;
  isolation:isolate;
}
.kv-home-live::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:0;
  pointer-events:none;
  background:
    linear-gradient(180deg,rgba(255,248,224,.06) 0 56%,rgba(44,32,18,.16) 100%),
    radial-gradient(ellipse at 50% 86%,rgba(255,238,177,.25),transparent 44%);
}
.kv-home-room-layer{
  position:absolute;
  inset:0;
  z-index:2;
}
.kv-home-live.is-bathing-home .kv-bath{
  z-index:58;
}
.kv-home-live.is-bathing-home .kv-home-room-layer{
  z-index:74;
}
.kv-home-live.is-bathing-home .decor-room-item{
  opacity:.82;
  filter:saturate(.92) blur(.2px);
}
.kv-home-live.is-bathing-home .kv-home-kindred{
  z-index:96!important;
}
.kv-home-kindred{
  z-index:84;
  transform:translate(-50%,-98%)!important;
}
/* the immersive-home Kindred is draggable by touch/mouse onto the floor */
:is(#screen-kindredvillage,#screen-anamvale) .kv-home-kindred{ pointer-events:auto; cursor:grab; touch-action:none; }
:is(#screen-kindredvillage,#screen-anamvale) .kv-home-kindred.is-dragging{ transition:none; cursor:grabbing; }
.kv-home-kindred .kv-avatar{
  margin:0;
  cursor:pointer;
}
.kv-home-kindred .kart-big[data-species]{
  width:clamp(150px,14vw,255px);
}
.kv-home-panel{
  position:static;
  margin-top:8px;
  z-index:140;
  display:grid;
  grid-template-columns:minmax(210px,.7fr) minmax(260px,1fr);
  gap:7px 10px;
  padding:9px;
  border:2px solid rgba(210,232,226,.92);
  border-radius:12px;
  background:linear-gradient(180deg,rgba(255,255,255,.9),rgba(244,255,249,.82));
  box-shadow:0 6px 18px rgba(38,59,82,.14);
  backdrop-filter:blur(8px);
}
.kv-home-profile{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
  min-width:0;
}
.kv-home-profile strong{
  display:block;
  color:#2d455c;
  font-size:1rem;
  line-height:1.05;
}
.kv-home-profile small{
  display:block;
  color:#65708a;
  font-size:.72rem;
  line-height:1.15;
}
.kv-mini-rename{
  margin-left:4px;
  padding:2px 6px;
  border:1px solid #cadfdc;
  border-radius:6px;
  background:#fff;
  color:#355064;
  font:inherit;
  font-size:.62rem;
  font-weight:700;
  cursor:pointer;
}
.kv-home-panel .kv-xp-compact{
  grid-column:2;
  grid-row:1;
  margin:0;
  max-width:none;
  padding:6px 8px;
  border-radius:9px;
}
.kv-xp-compact .kv-xp-head,
.kv-xp-compact .kv-xp-foot{
  font-size:.68rem;
  gap:6px;
}
.kv-xp-compact .kv-xp-track{
  height:10px;
  margin:4px 0;
}
.kv-home-meters{
  grid-column:1 / -1;
  display:grid!important;
  grid-template-columns:repeat(5,minmax(0,1fr));
  gap:6px!important;
  margin:0!important;
}
.kv-home-meters .pw-meter{
  min-width:0;
  padding:5px 6px;
  border:1px solid rgba(205,226,222,.95);
  border-radius:8px;
  box-shadow:none;
  background:rgba(255,255,255,.76);
}
.kv-home-meters .pw-meter .label{
  display:block;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
  font-size:.62rem;
}
.kv-home-meters .pw-bar{
  height:8px;
  margin-top:2px;
}
.kv-home-actions{
  grid-column:1 / -1;
  display:grid!important;
  grid-template-columns:repeat(9,minmax(0,1fr));
  gap:6px!important;
  margin:0!important;
}
:is(#screen-kindredvillage,#screen-anamvale) .kv-home-actions .pw-action{
  min-height:34px;
  padding:5px 6px;
  border:1px solid rgba(196,220,216,.95);
  border-radius:8px;
  font-size:.76rem;
  line-height:1;
  box-shadow:0 2px 0 rgba(38,59,82,.12);
}
.kv-home-actions .pw-action small{
  display:block;
  font-size:.58rem;
  line-height:1.05;
}
.kv-home-decor-drawer{
  border:2px solid #d8e8e2;
  border-radius:12px;
  background:rgba(255,255,255,.9);
  box-shadow:0 5px 0 rgba(38,59,82,.08);
  overflow:hidden;
}
.kv-home-decor-drawer>summary{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:10px 12px;
  cursor:pointer;
  color:#2d455c;
  font-weight:900;
  list-style:none;
}
.kv-home-decor-drawer>summary::-webkit-details-marker{
  display:none;
}
.kv-home-decor-drawer>summary::after{
  content:"";
  width:10px;
  height:10px;
  border-right:3px solid #5b6f85;
  border-bottom:3px solid #5b6f85;
  transform:rotate(45deg);
  transition:transform .16s ease;
}
.kv-home-decor-drawer[open]>summary::after{
  transform:rotate(225deg);
}
.kv-home-decor-drawer>summary small{
  margin-left:auto;
  color:#687491;
  font-size:.78rem;
  font-weight:800;
}
.kv-home-decor-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(130px,1fr));
  gap:9px;
  padding:0 12px 12px;
}
.kv-home-decor-card{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:4px;
  min-height:128px;
  width:100%;
  padding:9px 8px;
  border:2px solid #dbe9e5;
  border-radius:10px;
  background:#fff;
  text-align:center;
  box-shadow:0 3px 0 rgba(38,59,82,.08);
  font:inherit;
  cursor:pointer;
  -webkit-appearance:none;
  appearance:none;
  transition:transform .08s ease,border-color .12s ease;
}
.kv-home-decor-card:hover{transform:translateY(-2px);border-color:#58bfb0}
.kv-home-decor-card.selected:hover{border-color:#2bb55f}
.kv-home-decor-card.selected{
  border-color:#35c96d;
  background:linear-gradient(180deg,#f3fff7,#fff);
}
.kv-home-decor-card .nm{
  color:#111;
  font-weight:900;
  line-height:1.05;
}
.kv-home-decor-card .pr{
  min-height:2em;
  color:#647095;
  font-size:.78rem;
  line-height:1.1;
}
.kv-home-decor-card .kv-card-actions{
  display:flex;
  justify-content:center;
  gap:5px;
  flex-wrap:wrap;
  margin-top:auto;
}
.kv-home-decor-card button,
.kv-home-decor-drawer>.pw-action{
  min-height:30px;
  padding:5px 9px;
  border:0;
  border-radius:8px;
  background:#39cb6a;
  color:#fff;
  font:inherit;
  font-size:.74rem;
  font-weight:900;
  box-shadow:0 2px 0 #23a852;
  cursor:pointer;
}
.kv-home-decor-card.selected button,
.kv-home-decor-card button:first-child:not(:only-child){
  background:#5d7fd6;
  box-shadow:0 2px 0 #3d62bd;
}
.kv-decor-drawer-note{
  margin:0;
  padding:0 12px 12px;
  color:#647095;
  font-size:.82rem;
  line-height:1.25;
}
.kv-kindreds-tab{
  position:relative;
  z-index:2;
  padding:12px;
  border:2px solid #d8e8e2;
  border-radius:12px;
  background:rgba(255,255,255,.84);
}
.kv-kindreds-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  margin-bottom:10px;
}
.kv-kindreds-head h3{
  margin:0;
  color:#40345f;
}
.kv-kindreds-tab .kv-card-mini{
  background:#fff;
}

/* Synced 3D Habitat mode inside the real Kindred Village home layout. */
:is(#screen-kindredvillage,#screen-anamvale) .kv-home-titlebar .kv-3d-toggle.on{
  background:#ffe9a8;
  border-color:#d6a741;
  color:#6b4d08;
}
:is(#screen-kindredvillage,#screen-anamvale) .kv-home-titlebar.kv-3d-titlebar{
  display:grid;
  grid-template-columns:minmax(190px,.9fr) minmax(260px,1.4fr) auto;
  align-items:center;
}
:is(#screen-kindredvillage,#screen-anamvale) .kv-3d-room-tabs{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
  min-width:0;
}
:is(#screen-kindredvillage,#screen-anamvale) .kv-3d-room-tabs .pw-tab{
  flex:1 1 118px;
}
:is(#screen-kindredvillage,#screen-anamvale) .kv-3d-room{
  background-image:linear-gradient(180deg,rgba(255,248,224,.03),rgba(44,32,18,.08)),var(--room-bg)!important;
  background-position:center!important;
  background-size:cover!important;
}
:is(#screen-kindredvillage,#screen-anamvale) .kv-3d-scene-item{
  position:absolute;
  display:block;
  transform:translate(-50%,-100%);
  pointer-events:auto;
  filter:drop-shadow(0 16px 10px rgba(33,36,55,.25));
  user-select:none;
  -webkit-user-drag:none;
  cursor:grab;
  touch-action:none;
}
:is(#screen-kindredvillage,#screen-anamvale) .kv-3d-scene-item.is-dragging,
:is(#screen-kindredvillage,#screen-anamvale) .kv-3d-kindred.is-dragging{
  cursor:grabbing;
  transition:none!important;
}
:is(#screen-kindredvillage,#screen-anamvale) .kv-3d-kindred.is-gliding{
  transition:left .9s ease-in-out,top .9s ease-in-out;
}
:is(#screen-kindredvillage,#screen-anamvale) .kv-3d-scene-item.is-action-target{
  filter:drop-shadow(0 16px 10px rgba(33,36,55,.25)) drop-shadow(0 0 16px rgba(255,221,92,.72));
}
:is(#screen-kindredvillage,#screen-anamvale) .kv-3d-scene-item img{
  display:block;
  width:100%;
  height:auto;
}
:is(#screen-kindredvillage,#screen-anamvale) .kv-3d-portal{left:12%;top:69%;width:clamp(128px,13vw,210px);z-index:58}
/* Walk-in portal: a glowing ring on the ground. Walk the Kindred into it to change scene. */
/* Upright doorway shimmer — sits ON the house door. Its (left,top) anchor is the
   door THRESHOLD on the ground, so the Kindred walks up to it. */
:is(#screen-kindredvillage,#screen-anamvale) .kv-3d-portal-ring{
  position:absolute;
  width:clamp(56px,7.4vw,118px);
  height:clamp(116px,16vw,224px);
  transform:translate(-50%,-100%);
  border-radius:50% 50% 14% 14% / 64% 64% 10% 10%;
  background:radial-gradient(ellipse at 50% 42%, rgba(255,249,222,.62), rgba(196,158,255,.32) 52%, rgba(125,92,214,.12) 74%, transparent 84%);
  box-shadow:0 0 26px 9px rgba(255,216,128,.55), inset 0 0 24px 7px rgba(255,238,184,.6);
  cursor:pointer;
  z-index:88;
  animation:kv3dPortal 1.9s ease-in-out infinite;
}
:is(#screen-kindredvillage,#screen-anamvale) .kv-3d-portal-ring::before{
  content:"";position:absolute;inset:5% 11%;border-radius:inherit;
  border:3px solid rgba(255,228,150,.92);
  box-shadow:inset 0 0 16px 3px rgba(255,240,190,.8);
}
:is(#screen-kindredvillage,#screen-anamvale) .kv-3d-portal-ring::after{
  content:"✨";position:absolute;left:50%;top:38%;transform:translate(-50%,-50%);
  font-size:clamp(15px,2vw,26px);filter:drop-shadow(0 0 6px rgba(255,240,180,.9));
}
@keyframes kv3dPortal{
  0%,100%{box-shadow:0 0 22px 6px rgba(255,216,128,.5), inset 0 0 22px 6px rgba(255,238,184,.5);}
  50%{box-shadow:0 0 38px 12px rgba(255,226,150,.92), inset 0 0 30px 9px rgba(255,242,196,.78);}
}
/* ---- placeable habitat decor + the Decorate palette ---- */
:is(#screen-kindredvillage,#screen-anamvale) .kv-3d-decor{position:absolute;transform:translate(-50%,-88%);cursor:grab}
:is(#screen-kindredvillage,#screen-anamvale) .kv-3d-decor img{display:block;width:100%;height:auto;-webkit-user-drag:none;filter:drop-shadow(0 8px 7px rgba(40,30,40,.26))}
:is(#screen-kindredvillage,#screen-anamvale) .kv-3d-decor.is-dragging{cursor:grabbing;filter:brightness(1.05)}
:is(#screen-kindredvillage,#screen-anamvale) .kv-3d-decorating .kv-3d-decor{outline:2px dashed rgba(124,92,255,.7);outline-offset:3px;border-radius:8px}
:is(#screen-kindredvillage,#screen-anamvale) .kv-3d-decor-x{position:absolute;top:-11px;right:-11px;width:26px;height:26px;border-radius:50%;border:2px solid #fff;background:#e24b4a;color:#fff;font:bold 13px/1 sans-serif;cursor:pointer;z-index:5;box-shadow:0 2px 5px rgba(0,0,0,.3);display:grid;place-items:center;padding:0}
.kv-3d-decorate.on{background:linear-gradient(180deg,#b39bff,#7c5cff);color:#fff}
.kv-decor-palette{margin:10px 0 0;border:2px solid #d9d3f4;border-radius:14px;background:rgba(255,255,255,.96);overflow:hidden}
.kv-decor-palette-head{display:flex;align-items:center;gap:10px;padding:10px 13px;font-size:.9rem;color:#4a3f72;border-bottom:1px solid #ece8fb}
.kv-decor-palette-head .pw-action{margin-left:auto}
.kv-decor-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(90px,1fr));gap:8px;padding:12px;max-height:300px;overflow-y:auto}
.kv-decor-chip{display:flex;flex-direction:column;align-items:center;gap:4px;padding:7px 5px;border:1px solid #e3dbff;border-radius:10px;background:#fbfaff;cursor:pointer;transition:transform .1s,box-shadow .1s}
.kv-decor-chip:hover{transform:translateY(-2px);box-shadow:0 4px 10px rgba(124,92,255,.2);border-color:#b9a8ff}
.kv-decor-chip img{width:62px;height:52px;object-fit:contain}
.kv-decor-chip span{font-size:.66rem;line-height:1.1;color:#5a5278;text-align:center}
.kv-decor-chip.owned{border-color:#bfe6cf;background:#f4fff8}
.kv-decor-chip.locked{opacity:.6;cursor:not-allowed}
.kv-decor-chip.locked:hover{transform:none;box-shadow:none;border-color:#e3dbff}
.kv-decor-badge{display:inline-flex;align-items:center;gap:3px;font-size:.6rem;font-weight:800;line-height:1;padding:2px 6px;border-radius:999px;white-space:nowrap}
.kv-decor-badge.free{color:#1c7a44;background:#e3f8ec}
.kv-decor-badge.owned{color:#2a7a5a;background:#e8f7ef}
.kv-decor-badge.cost{color:#7a5b16;background:#fbf0d6}
.kv-decor-badge .coin{width:11px;height:11px}
:is(#screen-kindredvillage,#screen-anamvale) .kv-3d-bed{left:77%;top:74%;width:clamp(190px,20vw,320px);z-index:62}
:is(#screen-kindredvillage,#screen-anamvale) .kv-3d-snack{left:28%;top:81%;width:clamp(112px,11vw,174px);z-index:74}
:is(#screen-kindredvillage,#screen-anamvale) .kv-3d-pool{left:55%;top:92%;width:clamp(210px,24vw,380px);z-index:78;transform:translate(-50%,-78%)}
:is(#screen-kindredvillage,#screen-anamvale) .kv-3d-bath{left:88%;top:91%;width:clamp(124px,13vw,210px);z-index:82;transform:translate(-50%,-88%)}
:is(#screen-kindredvillage,#screen-anamvale) .kv-3d-kindred{
  left:49%;
  top:67%;
  z-index:90;
  transition:none;   /* instant position so proximity reads the true spot (no left/top lag) */
}
/* Other residents glide on their own (they don't drive proximity, so a transition is safe).
   The active kindred (#kv-room-kindred) keeps transition:none above. */
:is(#screen-kindredvillage,#screen-anamvale) .kv-3d-actor-other{
  transition:left 1.9s ease-in-out, top 1.9s ease-in-out;
  cursor:pointer;
}
:is(#screen-kindredvillage,#screen-anamvale) .kv-3d-actor-other .kart-big{opacity:.96;filter:drop-shadow(0 6px 8px rgba(20,30,50,.18))}
:is(#screen-kindredvillage,#screen-anamvale) .kv-3d-actor-other:hover .kart-big{transform:scale(1.04)}
/* Face buttons — tap to choose who you control (sits in the care row, by Feed) */
.kv-3d-resident-bar{display:flex;gap:8px;flex-wrap:wrap;align-items:center;padding:6px 0 2px}
.kv-resident-label{font-family:var(--anam-font);font-weight:800;font-size:.8rem;color:#4a3f72;margin-right:2px}
.kv-resident-chip{display:flex;align-items:center;gap:6px;padding:4px 10px 4px 4px;border:2px solid #e0d8f6;border-radius:999px;background:#fbfaff;color:#4a3f72;font-family:var(--anam-font);font-weight:800;font-size:.78rem;cursor:pointer;transition:transform .1s,border-color .1s,box-shadow .1s}
.kv-resident-chip img{width:34px;height:34px;object-fit:contain;border-radius:50%;background:#efeaff}
.kv-resident-chip:hover{transform:translateY(-1px);border-color:#b9a8ff}
.kv-resident-chip.on{border-color:#7c5cff;background:linear-gradient(180deg,#f1ecff,#fff);box-shadow:0 3px 0 rgba(124,92,255,.18)}
/* In-home Inventory overlay panel (never leaves the 3D scene) */
.kv-inv-panel .kv-inv-body{padding:12px;max-height:320px;overflow-y:auto;display:flex;flex-direction:column;gap:12px}
.kv-inv-sec h4{margin:0 0 6px;color:#4a3f72;font-size:.86rem}
.kv-inv-row{display:flex;flex-wrap:wrap;gap:8px}
.kv-inv-empty{margin:0;color:#7d769b;font-size:.78rem}
.kv-inv-note{margin:0;color:#5a5278;font-size:.8rem}
.kv-inv-chip{display:flex;align-items:center;gap:8px;padding:5px 11px 5px 5px;border:2px solid #e3dbff;border-radius:12px;background:#fbfaff;color:#4a3f72;font-family:var(--anam-font);font-weight:700;font-size:.78rem;cursor:pointer;transition:transform .1s,border-color .1s,box-shadow .1s}
.kv-inv-chip img{width:38px;height:38px;object-fit:contain}
.kv-inv-chip.wide{width:100%;justify-content:flex-start}
.kv-inv-chip:hover{transform:translateY(-1px);border-color:#b9a8ff}
.kv-inv-chip.on{border-color:#35c96d;background:linear-gradient(180deg,#f1fff6,#fff);color:#1c7a44}
:is(#screen-kindredvillage,#screen-anamvale) .kv-3d-kindred .kart-big[data-species]{
  --kv3d-base:clamp(82px,11vw,176px);   /* per-ACTION base size (bigger so Kindreds read well in the room) */
  --kv3d-stage:1;                       /* per-EVOLUTION multiplier */
  width:calc(var(--kv3d-base) * var(--kv3d-stage));
  transition:width .25s ease;
}
/* The Kindred grows with every evolution — Lv1 small → Lv25 → Lv50 → Lv80 → Lv120 biggest. */
:is(#screen-kindredvillage,#screen-anamvale) .kv-3d-kindred .kart-big[data-life-stage="stage1"]{--kv3d-stage:.80}
:is(#screen-kindredvillage,#screen-anamvale) .kv-3d-kindred .kart-big[data-life-stage="stage2"]{--kv3d-stage:.98}
:is(#screen-kindredvillage,#screen-anamvale) .kv-3d-kindred .kart-big[data-life-stage="evolved"]{--kv3d-stage:1.18}
:is(#screen-kindredvillage,#screen-anamvale) .kv-3d-kindred .kart-big[data-life-stage="level80"]{--kv3d-stage:1.40}
:is(#screen-kindredvillage,#screen-anamvale) .kv-3d-kindred .kart-big[data-life-stage="level120"]{--kv3d-stage:1.66}
:is(#screen-kindredvillage,#screen-anamvale) .kv-3d-kindred .kart-big[data-action="eat"]{--kv3d-base:clamp(68px,9.2vw,148px)}
:is(#screen-kindredvillage,#screen-anamvale) .kv-3d-kindred .kart-big[data-action="bath"]{--kv3d-base:clamp(56px,7.7vw,118px)}
:is(#screen-kindredvillage,#screen-anamvale) .kv-3d-kindred .kart-big[data-action="sleep"],
:is(#screen-kindredvillage,#screen-anamvale) .kv-3d-kindred .kart-big[data-action="swim"]{--kv3d-base:clamp(74px,10vw,158px)}
:is(#screen-kindredvillage,#screen-anamvale) .kv-home-live.is-bathing-home .kv-3d-kindred{
  z-index:188!important;
}
:is(#screen-kindredvillage,#screen-anamvale) .kv-3d-kindred .kv-avatar,
:is(#screen-kindredvillage,#screen-anamvale) .kv-3d-kindred .kart{
  pointer-events:auto;
  cursor:grab;
}
:is(#screen-kindredvillage,#screen-anamvale) .kv-3d-pickers{
  grid-column:1 / -1;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:7px;
}
:is(#screen-kindredvillage,#screen-anamvale) .kv-3d-picker-row{
  display:grid;
  grid-template-columns:repeat(5,minmax(0,1fr));
  gap:6px;
}
:is(#screen-kindredvillage,#screen-anamvale) .kv-3d-picker-row .pw-action{
  min-height:32px;
  padding:5px 7px;
  font-size:.72rem;
}
:is(#screen-kindredvillage,#screen-anamvale) .kv-3d-picker-row .pw-action.on{
  border-color:#58bfb0;
  background:#dff9ef;
  color:#244d52;
}
:is(#screen-kindredvillage,#screen-anamvale) .kv-3d-status{
  grid-column:1 / -1;
  min-height:32px;
  padding:7px 9px;
  border:1px solid rgba(205,226,222,.95);
  border-radius:8px;
  background:rgba(255,255,255,.76);
  color:#45606f;
  font-size:.72rem;
  line-height:1.25;
}
@media(max-width:900px){
  :is(#screen-kindredvillage,#screen-anamvale) .kv-home-live{min-height:clamp(440px,72vw,680px)}
  .kv-home-panel{grid-template-columns:1fr}
  .kv-home-panel .kv-xp-compact{grid-column:1;grid-row:auto}
  .kv-home-actions{grid-template-columns:repeat(4,minmax(0,1fr))}
  .kv-home-meters{grid-template-columns:repeat(3,minmax(0,1fr))}
  .kv-home-decor-grid{grid-template-columns:repeat(auto-fill,minmax(118px,1fr))}
  :is(#screen-kindredvillage,#screen-anamvale) .kv-3d-pickers{grid-template-columns:1fr}
  :is(#screen-kindredvillage,#screen-anamvale) .kv-home-titlebar.kv-3d-titlebar{
    grid-template-columns:1fr auto;
  }
  :is(#screen-kindredvillage,#screen-anamvale) .kv-3d-room-tabs{
    grid-column:1 / -1;
    order:3;
  }
}
@media(max-width:560px){
  .kv-home-titlebar{align-items:stretch;flex-direction:column}
  .kv-home-titlebar .kv-home-floors{margin-left:0}
  :is(#screen-kindredvillage,#screen-anamvale) .kv-home-live{min-height:520px}
  .kv-home-panel{padding:7px}
  .kv-home-profile{align-items:flex-start;flex-direction:column}
  .kv-home-profile .pw-action{width:100%}
  .kv-home-meters{grid-template-columns:repeat(2,minmax(0,1fr))}
  .kv-home-actions{grid-template-columns:repeat(2,minmax(0,1fr))}
  .kv-home-kindred .kart-big[data-species]{width:clamp(128px,38vw,190px)}
  :is(#screen-kindredvillage,#screen-anamvale) .kv-3d-kindred .kart-big[data-species]{--kv3d-base:clamp(64px,18vw,116px)}
  :is(#screen-kindredvillage,#screen-anamvale) .kv-3d-kindred .kart-big[data-action="eat"]{--kv3d-base:clamp(54px,15vw,98px)}
  :is(#screen-kindredvillage,#screen-anamvale) .kv-3d-kindred .kart-big[data-action="bath"]{--kv3d-base:clamp(44px,12.5vw,80px)}
  :is(#screen-kindredvillage,#screen-anamvale) .kv-3d-kindred .kart-big[data-action="sleep"],
  :is(#screen-kindredvillage,#screen-anamvale) .kv-3d-kindred .kart-big[data-action="swim"]{--kv3d-base:clamp(56px,16vw,104px)}
  :is(#screen-kindredvillage,#screen-anamvale) .kv-3d-picker-row{grid-template-columns:repeat(2,minmax(0,1fr))}
  .kv-home-decor-drawer>summary{align-items:flex-start;flex-direction:column}
  .kv-home-decor-drawer>summary small{margin-left:0}
}

/* More polished Kindred Storybook spa bath over the actual home scene. */
.kv-home-live .kv-bath-glow{
  left:24%;
  right:24%;
  bottom:27%;
  height:42%;
  border-radius:50%;
  background:radial-gradient(ellipse at 50% 58%,rgba(155,236,255,.5),rgba(155,236,255,.18) 38%,transparent 70%);
}
.kv-home-live .kv-bath-water{
  left:33%;
  right:33%;
  bottom:38%;
  height:15%;
  border-radius:50%;
  background:radial-gradient(ellipse at 50% 38%,rgba(255,255,255,.9),rgba(168,237,255,.8) 48%,rgba(90,190,215,.42) 74%,transparent 76%);
  box-shadow:0 0 24px rgba(123,229,255,.45);
}
.kv-home-live .kv-bath-tub{
  left:50%;
  bottom:30%;
  width:clamp(260px,28vw,430px);
  height:clamp(150px,15vw,240px);
  transform:translateX(-50%);
  filter:drop-shadow(0 18px 12px rgba(47,54,77,.28));
}
.kv-home-live .kv-bath-rim{
  top:20%;
  left:5%;
  right:5%;
  height:26%;
  border:4px solid rgba(255,255,255,.94);
  border-bottom-color:#a7d7df;
  border-radius:999px;
  background:linear-gradient(180deg,#fff,#dcf6f6 58%,#acdbe5);
  box-shadow:inset 0 4px 0 rgba(255,255,255,.8),0 5px 0 rgba(93,138,150,.24);
}
.kv-home-live .kv-bath-bowl{
  top:36%;
  left:10%;
  right:10%;
  bottom:5%;
  border:4px solid rgba(255,255,255,.78);
  border-radius:20% 20% 42% 42%/28% 28% 62% 62%;
  background:linear-gradient(180deg,#eafcff,#b9e9f0 55%,#8fc6d4);
  box-shadow:inset 0 -18px 22px rgba(61,127,148,.24),inset 0 6px 8px rgba(255,255,255,.7);
}
.kv-home-live .kv-bath-foot{
  bottom:3px;
  width:30px;
  height:13px;
  background:linear-gradient(180deg,#a4a8b5,#6f7486);
}
.kv-home-live .kv-bath-foot.foot-a{left:23%}
.kv-home-live .kv-bath-foot.foot-b{right:23%}
.kv-home-live .kv-bath-shower{
  right:15%;
  top:2%;
  width:28%;
  height:36%;
  border-right:5px solid #8cb8c4;
  border-top:5px solid #8cb8c4;
  border-radius:0 999px 0 0;
}
.kv-home-live .kv-bath-shower-head{
  right:10%;
  top:4%;
  width:46px;
  height:26px;
  border-radius:999px 999px 40% 40%;
  background:linear-gradient(180deg,#effcff,#94c8d2);
  box-shadow:inset 0 2px 0 rgba(255,255,255,.8),0 3px 0 rgba(74,119,130,.22);
}


/* ===== Wild Places / Library scenic styling — merged 2026-06-21 (new classes only) ===== */
.scenic-live-wrap{position:relative}
.scenic-live-stage{
  position:relative;
  width:100%;
  aspect-ratio:16/9;
  min-height:clamp(420px,56vw,780px);
  border:3px solid #d9d3f4;
  border-radius:14px;
  overflow:hidden;
  outline:none;
  background-color:#dcefe8;
  background-position:center;
  background-size:cover;
  background-repeat:no-repeat;
  box-shadow:inset 0 0 0 2px rgba(255,255,255,.44),0 5px 0 rgba(78,62,145,.12),0 16px 30px rgba(38,59,82,.14);
  cursor:default;
}
.scenic-live-stage:focus{box-shadow:inset 0 0 0 2px rgba(255,255,255,.44),0 5px 0 rgba(78,62,145,.12),0 0 0 4px rgba(86,202,188,.22),0 16px 30px rgba(38,59,82,.14)}
.scenic-live-stage::after{
  content:"";
  position:absolute;
  z-index:1;
  inset:auto 0 0;
  height:43%;
  pointer-events:none;
  background:linear-gradient(180deg,transparent,rgba(31,45,42,.09));
}
.scenic-kindred{
  position:absolute;
  left:50%;
  top:72%;
  z-index:90;
  transform:translate(-50%,-82%);
  transform-origin:50% 100%;
  pointer-events:none;
  transition:left .12s linear,top .12s linear;
  animation:scenic-kindred-breathe 2.8s ease-in-out infinite;
  filter:drop-shadow(0 10px 7px rgba(38,45,31,.26));
}
.scenic-kindred.is-surprised{animation:scenic-kindred-surprise .48s ease-in-out 4}
/* In the scenic destinations (Library, Park, Cafe, etc.) the Kindred is a single small
   actor on a full-bleed 16:9 scene, so the old 78px kart-mini read far too small against
   the painted background characters. Scale it up ~60% to sit at scene scale. The global
   per-level rule (.kart baby .76 / teen .9 / adult 1, anam.css ~957) still multiplies on
   top, so higher-level Kindreds stay proportionally bigger. Village sizing is untouched. */
.scenic-kindred .kart-mini[data-species]{width:clamp(120px,15vw,210px)}
.scenic-empty-note{text-align:center}
#anamvale-root[data-area="library"] .scenic-live-stage{min-height:clamp(500px,62vw,900px)}
.scenic-hotspot{
  position:absolute;
  z-index:6;
  width:44px;
  height:44px;
  display:grid;
  place-items:center;
  transform:translate(-50%,-50%);
  border:0;
  border-radius:50%;
  background:radial-gradient(circle,#fff 0 18%,#ffe683 19% 44%,rgba(255,220,99,.18) 45% 100%);
  box-shadow:0 0 0 4px rgba(255,255,255,.22),0 0 22px rgba(255,221,82,.72);
  color:#7b5a00;
  font-family:var(--anam-font);
  font-weight:700;
  cursor:pointer;
  animation:scenic-hotspot-pulse 1.8s ease-in-out infinite;
}
.scenic-hotspot-mark{position:relative;display:block;width:22px;height:22px}
.scenic-hotspot-spark .scenic-hotspot-mark::before,
.scenic-hotspot-spark .scenic-hotspot-mark::after{
  content:"";position:absolute;left:50%;top:50%;width:18px;height:5px;border-radius:999px;background:#fff5a8;box-shadow:0 0 8px rgba(255,255,255,.95);transform:translate(-50%,-50%) rotate(45deg)
}
.scenic-hotspot-spark .scenic-hotspot-mark::after{transform:translate(-50%,-50%) rotate(-45deg)}
.scenic-hotspot-book{
  width:36px;height:36px;background:radial-gradient(circle,#fff 0 18%,#b7fff1 19% 46%,rgba(96,210,196,.15) 47% 100%);
  box-shadow:0 0 0 4px rgba(255,255,255,.22),0 0 22px rgba(83,231,211,.68);
}
.scenic-hotspot-book .scenic-hotspot-mark{
  width:20px;height:24px;border-radius:4px 6px 6px 4px;
  background:linear-gradient(90deg,#3d6d8f 0 20%,#5ecfba 21% 100%);
  box-shadow:inset 3px 0 0 rgba(255,255,255,.55),0 2px 3px rgba(42,49,64,.24);
}
.scenic-hotspot-book .scenic-hotspot-mark::after{
  content:"";position:absolute;left:7px;right:4px;top:7px;height:2px;border-radius:999px;background:rgba(255,255,255,.72);box-shadow:0 5px 0 rgba(255,255,255,.55)
}
.scenic-hotspot:hover{scale:1.12;filter:brightness(1.08)}
.scenic-live-stage.secret-active::before{
  content:"";
  position:absolute;
  z-index:4;
  width:180px;
  height:180px;
  left:var(--secret-x,34%);
  top:var(--secret-y,70%);
  transform:translate(-50%,-50%);
  border-radius:50%;
  pointer-events:none;
  background:radial-gradient(circle,rgba(255,255,255,.95) 0 8%,rgba(255,232,117,.75) 9% 28%,rgba(115,220,255,.35) 29% 52%,transparent 53%);
  animation:scenic-secret-pop 1.1s ease-out both;
}
.scenic-activity-drawer{
  margin:10px 0 0;
  border:2px solid #d9d3f4;
  border-radius:12px;
  background:rgba(255,255,255,.94);
  box-shadow:0 3px 0 rgba(124,92,255,.08);
  overflow:hidden;
}
.scenic-activity-drawer summary{
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  padding:10px 13px;cursor:pointer;font-weight:700;color:#40345f;list-style:none;
}
.scenic-activity-drawer summary::-webkit-details-marker{display:none}
.scenic-activity-drawer summary small{font-weight:400;color:#687294}
.library-activity-row{
  display:flex;align-items:center;gap:12px;padding:0 13px 12px;border-top:1px solid #eee8ff;
}
.library-scroll-btn{flex:0 0 auto;background:linear-gradient(180deg,#6bcfc2,#249f96);box-shadow:0 3px 0 #14736c}
.library-found-books{display:flex;flex-wrap:wrap;gap:8px;padding:0 13px 13px}
.scenic-book-modal{text-align:center;color:#3c3358}
.scenic-book-emblem{
  width:58px;height:58px;margin:0 auto 8px;display:grid;place-items:center;border-radius:18px;
  background:linear-gradient(145deg,#e7fff8,#f7f0ff);border:2px solid #d9d3f4;
}
.scenic-book-emblem .scenic-hotspot-mark{
  width:28px;height:34px;border-radius:5px 8px 8px 5px;
  background:linear-gradient(90deg,#3d6d8f 0 20%,#5ecfba 21% 100%);
  box-shadow:inset 4px 0 0 rgba(255,255,255,.55),0 3px 5px rgba(42,49,64,.24);
}
.scenic-book-modal h2{margin:4px 0 8px;color:#40345f}
.scenic-book-modal p{max-width:620px;margin:0 auto 14px;font-size:1rem;line-height:1.55}
/* ---- open-book reader (page-turning) ---- */
/* book reader fits the open window: card fills available height, only the
   story text scrolls — art + page-turn buttons stay visible. */
.modal-card.modal-book{
  max-width:760px;padding:18px;display:flex;flex-direction:column;
  max-height:90vh;overflow:hidden;
}
.scenic-book-reader{max-width:760px;width:100%;margin:0 auto;flex:1;min-height:0;display:flex;flex-direction:column}
.scenic-book{
  display:flex;border-radius:16px;overflow:hidden;padding:14px;
  background:linear-gradient(180deg,#7a4a2b,#5e3720);
  box-shadow:0 14px 34px rgba(42,28,18,.4);
  flex:1;min-height:0;
}
.scenic-book-page{
  flex:1 1 50%;min-width:0;padding:20px 22px;position:relative;
  background:linear-gradient(180deg,#fdf6e4,#f4e9cf);
}
.scenic-book-left{
  border-radius:12px 4px 4px 12px;display:flex;align-items:center;justify-content:center;
  box-shadow:inset -10px 0 16px -10px rgba(94,55,32,.45);
}
.scenic-book-right{
  border-radius:4px 12px 12px 4px;text-align:left;color:#4a3b2a;display:flex;flex-direction:column;
  box-shadow:inset 10px 0 16px -10px rgba(94,55,32,.45);min-height:0;overflow:hidden;
}
.scenic-book-art{display:block;width:100%;height:100%;max-height:320px;object-fit:contain;border-radius:10px}
.scenic-book-art.is-missing{min-height:200px;background:linear-gradient(145deg,#e7fff8,#f7f0ff)}
.scenic-book-title{margin:0 0 2px;color:#5e3720;font-size:1.3rem;line-height:1.15}
.scenic-book-right .scenic-book-source{font-size:.8rem;color:#8a7350;margin-bottom:12px;font-style:italic}
.scenic-book-text{margin:0 0 12px;font-size:1.02rem;line-height:1.6;color:#4a3b2a;flex:1;min-height:0;overflow:auto}
.scenic-book-right .scenic-book-moral{
  background:rgba(247,233,196,.7);border:1px solid #e2cfa0;border-radius:10px;
  padding:8px 12px;font-size:.92rem;color:#6b5535;margin-bottom:10px;
}
.scenic-book-folio{font-size:.78rem;color:#a08a62;text-align:right;margin-top:auto}
.scenic-book-actions{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;margin-top:14px}
.scenic-book-actions .go-btn[disabled]{opacity:.4;cursor:default}
@media (max-width:560px){
  .scenic-book{flex-direction:column}
  .scenic-book-left,.scenic-book-right{border-radius:10px;box-shadow:none}
  .scenic-book-left{flex:0 0 auto}
  .scenic-book-art{max-height:24vh}
}
/* ---- storybook art (drawn markers, fable panels, scroll) ---- */
.scenic-hotspot-drawn{width:56px;height:56px;background:none;box-shadow:none}
.scenic-hotspot-drawn .scenic-hotspot-mark{display:none}
.scenic-hotspot-img{
  display:block;width:100%;height:100%;object-fit:contain;pointer-events:none;-webkit-user-drag:none;
  filter:drop-shadow(0 0 9px rgba(255,221,82,.85)) drop-shadow(0 2px 3px rgba(42,49,64,.3));
}
.scenic-book-illustration{
  display:block;width:100%;max-width:420px;margin:0 auto 12px;
  border-radius:14px;border:2px solid #e3dbff;box-shadow:0 6px 18px rgba(60,51,88,.18);background:#fff;
}
.lore-shelf-art{display:block;width:100%;height:100%;object-fit:contain;-webkit-user-drag:none}
.lore-scroll-banner{display:block;width:100%;max-width:520px;margin:0 auto;object-fit:contain}
.shop-good-art{
  display:block;height:150px;margin:-14px -14px 10px;border-bottom:2px solid #e2d8c8;
  border-radius:8px 8px 0 0;background:#fff8e8;overflow:hidden;
}
.shop-good-art img{
  display:block;width:100%;height:100%;object-fit:contain;object-position:center;user-select:none;-webkit-user-drag:none;
}
