/*
  Ponyforge — integrated build.

  The page is the paddock: a single fenced viewport, full bleed, where six
  horses live and breathe. JUICE physics give each horse weight; SANDBOX
  layers stacked hats, editable names, clones; EMERGENT hides a few
  rewards behind exploration; SHOW turns the page into a 14-second
  procession on G. Type system (Fraunces + JetBrains Mono) and oxblood-
  on-paper palette are unchanged.
*/

:root {
  --paper:    #f3efe6;
  --paper-2:  #ebe6da;
  --paper-3:  #e2dccc;
  --paper-night: #e8e3d6;
  --rule:     #cbc4b1;
  --ink:      #14130f;
  --ink-2:    #4a463d;
  --ink-3:    #7c7768;
  --accent:   #8a2a1e;

  --serif: "Fraunces", "GT Sectra", "Caslon", Georgia, serif;
  --mono:  "JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;

  --ease-soft:  cubic-bezier(.22, .61, .36, 1);
  --ease-fall:  cubic-bezier(.55, .055, .675, .19);
  --ease-land:  cubic-bezier(.16, .84, .44, 1);
  --ease-over:  cubic-bezier(.34, 1.56, .64, 1);

  --pony-w: clamp(120px, 13vw, 168px);
}

* { box-sizing: border-box; }
html, body {
  margin: 0; padding: 0;
  height: 100%;
  overflow: hidden;
  overscroll-behavior: none;
}

body {
  font-family: var(--mono);
  font-size: 13px;
  line-height: 1.5;
  color: var(--ink);
  background: var(--paper);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

::selection { background: var(--accent); color: var(--paper); }

.skip {
  position: absolute; left: -9999px; top: 0;
  background: var(--ink); color: var(--paper);
  padding: 0.5rem 0.75rem; text-decoration: none;
  font-family: var(--mono); font-size: 12px;
}
.skip:focus { left: 1rem; top: 1rem; z-index: 100; }

/* ============================================================ PADDOCK = PAGE */

.paddock {
  position: fixed;
  inset: 0;
  width: 100vw;
  height: 100dvh;
  --shake-x: 0px;
  --shake-y: 0px;
  transform: translate3d(var(--shake-x), var(--shake-y), 0);
  background:
    repeating-linear-gradient(
      to bottom,
      transparent 0,
      transparent 31px,
      rgba(20,19,15,0.025) 31px,
      rgba(20,19,15,0.025) 32px
    ),
    linear-gradient(to right,  rgba(20,19,15,0.045) 1px, transparent 1px) 0 0 / 64px 100%,
    linear-gradient(to bottom, rgba(20,19,15,0.045) 1px, transparent 1px) 0 0 / 100% 64px,
    var(--paper);
  overflow: hidden;
  box-shadow: inset 0 0 0 1px var(--ink);
  user-select: none;
  touch-action: none;
  transition: background-color 1200ms var(--ease-soft);
}
.paddock.is-holding { background-color: var(--paper-2); }
.paddock.is-night { background-color: var(--paper-night); }

/* ============================================================ STAMP */

.stamp {
  position: absolute;
  top: clamp(1rem, 2.4vw, 1.75rem);
  left: clamp(1rem, 2.4vw, 1.75rem);
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
  pointer-events: none;
  z-index: 5;
}
.stamp__name {
  font-family: var(--serif);
  font-weight: 400;
  font-variation-settings: "opsz" 144;
  font-size: clamp(1.5rem, 3.4vw, 2.4rem);
  line-height: 0.92;
  letter-spacing: -0.02em;
  color: var(--ink);
}
.stamp__sub {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-3);
}

/* ============================================================ COMPASS */

.compass {
  position: absolute;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.22em;
  color: var(--ink-3);
  pointer-events: none;
  z-index: 4;
}
.compass--n { top: 0.65rem; left: 50%; transform: translateX(-50%); }
.compass--s { bottom: 0.65rem; left: 50%; transform: translateX(-50%); }
.compass--e { right: 0.85rem; top: 50%; transform: translateY(-50%) rotate(90deg); transform-origin: center; }
.compass--w { left: 0.85rem;  top: 50%; transform: translateY(-50%) rotate(-90deg); transform-origin: center; }

/* ============================================================ FOLD */

.fold {
  position: absolute;
  bottom: clamp(0.85rem, 2vw, 1.4rem);
  right: clamp(1rem, 2.4vw, 1.75rem);
  display: flex;
  gap: 0.85rem;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.1em;
  color: var(--ink-3);
  pointer-events: none;
  z-index: 4;
}
.fold span:first-child {
  color: var(--accent);
  font-variant-numeric: tabular-nums;
}

/* ============================================================ RECALL PILL */

.recall {
  position: absolute;
  top: clamp(1rem, 2.4vw, 1.75rem);
  right: clamp(1rem, 2.4vw, 1.75rem);
  appearance: none;
  background: transparent;
  border: 1px solid var(--ink);
  color: var(--ink);
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  padding: 0.5rem 0.85rem;
  cursor: pointer;
  z-index: 6;
  transition: background 200ms var(--ease-soft), color 200ms var(--ease-soft);
}
.recall:hover { background: var(--ink); color: var(--paper); }
.recall:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }

/* ============================================================ AFFORDANCE (G) */

.affordance {
  position: absolute;
  top: clamp(1rem, 2.4vw, 1.75rem);
  right: clamp(7rem, 12vw, 9rem);
  margin: 0;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-3);
  pointer-events: none;
  z-index: 5;
  padding: 0.5rem 0;
  transition: opacity 380ms var(--ease-soft);
}
.affordance__key {
  display: inline-grid;
  place-items: center;
  width: 18px; height: 18px;
  border: 1px solid var(--ink-3);
  color: var(--ink);
  font-size: 10px;
  letter-spacing: 0;
  font-weight: 500;
}
.affordance__sep { color: var(--accent); }

@media (max-width: 720px) {
  .affordance { right: clamp(6rem, 18vw, 7.5rem); font-size: 9px; letter-spacing: 0.14em; }
}

/* ============================================================ HINT */

.hint {
  position: absolute;
  bottom: clamp(0.85rem, 2vw, 1.4rem);
  left: 50%;
  transform: translateX(-50%);
  margin: 0;
  display: flex;
  gap: 0.55rem;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-3);
  pointer-events: none;
  z-index: 4;
  white-space: nowrap;
  transition: opacity 380ms var(--ease-soft);
}
.hint__sep { color: var(--accent); }
.hint.is-faded { opacity: 0; }

@media (max-width: 560px) {
  .hint { font-size: 9px; gap: 0.4rem; letter-spacing: 0.14em; }
  .fold { display: none; }
}

/* ============================================================ MUTE */

.mute {
  position: absolute;
  bottom: clamp(0.85rem, 2vw, 1.4rem);
  left: clamp(1rem, 2.4vw, 1.75rem);
  appearance: none;
  background: transparent;
  border: 1px solid var(--ink);
  color: var(--ink);
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  padding: 0.5rem 0.75rem;
  cursor: pointer;
  z-index: 6;
  transition: background 200ms var(--ease-soft), color 200ms var(--ease-soft);
}
.mute:hover { background: var(--ink); color: var(--paper); }
.mute:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }
.mute .mute__off { display: none; }
.mute[aria-pressed="true"] .mute__on  { display: none; }
.mute[aria-pressed="true"] .mute__off { display: inline; }

@media (max-width: 560px) {
  .mute { font-size: 9px; padding: 0.4rem 0.6rem; letter-spacing: 0.14em; }
}

/* ============================================================ TOAST */

.toast {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%) scale(0.96);
  background: var(--ink);
  color: var(--paper);
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  padding: 0.7rem 1.1rem;
  z-index: 2000;
  opacity: 0;
  pointer-events: none;
  transition: opacity 200ms var(--ease-soft), transform 240ms var(--ease-over);
  white-space: nowrap;
}
.toast.is-on {
  opacity: 1;
  transform: translate(-50%, -50%) scale(1);
}

/* ============================================================ HERD */

.herd {
  position: absolute;
  inset: 0;
  z-index: 10;
}

.pony {
  position: absolute;
  appearance: none;
  border: 0;
  margin: 0;
  padding: 0;
  background: var(--ink);
  width: var(--pony-w);
  aspect-ratio: 16 / 9;
  cursor: grab;
  --depth: 0;
  --x: 0px;
  --y: 0px;
  --r: 0deg;
  --lift: 0;
  --sx: 1;
  --sy: 1;
  --breath: 1;
  --gaze-x: 0deg;
  --base-scale: calc(1 - var(--depth) * 0.20);
  transform:
    translate3d(var(--x), var(--y), 0)
    scale(calc((var(--base-scale) + var(--lift) * 0.05) * var(--sx) * var(--breath)),
          calc((var(--base-scale) + var(--lift) * 0.05) * var(--sy) * var(--breath)))
    rotate(var(--r));
  transform-origin: 50% 100%;
  filter:
    saturate(calc(1 - var(--depth) * 0.15))
    brightness(calc(1 - var(--depth) * 0.04));
  z-index: var(--z, 10);
  transition: filter 240ms var(--ease-soft);
  -webkit-tap-highlight-color: transparent;
  outline: none;
  will-change: transform;
}
.pony:active { cursor: grabbing; }
.pony:focus-visible {
  box-shadow:
    0 0 0 2px var(--paper),
    0 0 0 4px var(--accent);
}

.pony::after {
  content: "";
  position: absolute;
  left: 6%;
  right: 6%;
  bottom: -10px;
  height: 14px;
  background: radial-gradient(
    ellipse at center,
    rgba(20,19,15,0.42) 0%,
    rgba(20,19,15,0.18) 45%,
    rgba(20,19,15,0) 75%
  );
  z-index: -1;
  transform:
    translateY(calc(var(--lift) * 8px))
    scale(
      calc((1 + var(--lift) * 0.6) * (1 - var(--depth) * 0.4)),
      calc((1 + var(--lift) * 0.3) * (1 - var(--depth) * 0.4))
    );
  opacity: calc((1 - var(--depth) * 0.35) * (1 - var(--lift) * 0.25));
  pointer-events: none;
  transition: opacity 240ms var(--ease-soft);
}

.pony.is-lifted {
  cursor: grabbing;
  z-index: 9999 !important;
  filter: saturate(1) brightness(1) drop-shadow(0 18px 22px rgba(20,19,15,0.28));
}

.pony.is-landing { animation: pony-land 460ms var(--ease-over) both; }
@keyframes pony-land {
  0%   { transform: translate3d(var(--x), calc(var(--y) - 10px), 0) scale(calc(var(--base-scale) * 1.05)) rotate(var(--r)); }
  60%  { transform: translate3d(var(--x), calc(var(--y) + 2px),  0) scale(calc(var(--base-scale) * 0.98)) rotate(0deg); }
  100% { transform: translate3d(var(--x), var(--y), 0) scale(var(--base-scale)) rotate(0deg); }
}

.pony img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: contrast(1.02) saturate(0.98);
  pointer-events: none;
  user-select: none;
  -webkit-user-drag: none;
  --face-x: 1;
  transform: scaleX(var(--face-x)) rotate(var(--gaze-x));
  transform-origin: 50% 60%;
  transition: transform 320ms var(--ease-soft);
}

.pony__plate {
  position: absolute;
  top: 0.5rem; left: 0.55rem;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  color: var(--paper);
  background: rgba(20,19,15,0.55);
  padding: 0.18rem 0.4rem;
  z-index: 3;
  pointer-events: none;
}

/* ----- stacked hats (sandbox) ----- */
.hat-stack {
  position: absolute;
  top: 4px;
  left: 50%;
  transform: translate(-50%, -100%);
  display: flex;
  flex-direction: column-reverse;
  align-items: center;
  pointer-events: none;
  z-index: 2;
  filter: drop-shadow(0 1px 0 rgba(0,0,0,0.35));
  line-height: 1;
}
.hat-stack .hat {
  font-size: clamp(1.4rem, 2.8vw, 1.9rem);
  display: block;
  margin-top: -10px;
}
.hat-stack .hat:last-child { margin-top: 0; }

.hat-stack.is-landing .hat:first-child {
  animation: hat-land 380ms var(--ease-land) both;
}
.hat-stack.is-shaking .hat:first-child {
  animation: hat-shake 520ms var(--ease-soft) both;
}
@keyframes hat-land {
  0%   { transform: translateY(-28px) rotate(8deg); opacity: 0; }
  60%  { transform: translateY(2px)   rotate(-2deg); opacity: 1; }
  100% { transform: translateY(0)     rotate(0deg);  opacity: 1; }
}
@keyframes hat-shake {
  0%, 100% { transform: translate(0, 0) rotate(0deg); }
  20%      { transform: translate(-6px, 0) rotate(-8deg); }
  60%      { transform: translate(6px, 0)  rotate(8deg); }
}

/* editable name caption (sandbox) */
.pony__name {
  position: absolute;
  left: 50%;
  bottom: -22px;
  transform: translateX(-50%);
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink);
  background: var(--paper);
  border-bottom: 1px solid var(--ink);
  padding: 0.1rem 0.4rem 0.05rem;
  white-space: nowrap;
  pointer-events: auto;
  cursor: text;
  outline: none;
  min-width: 2rem;
  text-align: center;
  z-index: 4;
}
.pony__name:focus {
  background: var(--paper-3);
  border-bottom-color: var(--accent);
}

/* private (seen) note (emergent) */
.pony__note {
  position: absolute;
  bottom: -38px;
  left: 50%;
  transform: translateX(-50%);
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-3);
  white-space: nowrap;
  pointer-events: none;
  opacity: 0;
  transition: opacity 800ms var(--ease-soft);
  z-index: 4;
}
.pony.is-seen .pony__note { opacity: 1; }
.pony__note .nt { color: var(--accent); }

/* head dip (PONY combo, kiss-on-Vesper, etc.) */
.pony.is-bowing img {
  animation: pony-bow 1100ms var(--ease-soft) both;
}
@keyframes pony-bow {
  0%, 100% { transform: scaleX(var(--face-x)) translateY(0); }
  40%, 60% { transform: scaleX(var(--face-x)) translateY(6px); }
}

/* ============================================================ HAT RING */

.ring {
  position: fixed;
  --rs: 220px;
  width: calc(var(--rs) * 2 + 96px);
  height: calc(var(--rs) * 2 + 96px);
  left: 0; top: 0;
  transform: translate(-50%, -50%) scale(0.86);
  pointer-events: none;
  opacity: 0;
  z-index: 1000;
  transition:
    opacity 180ms var(--ease-soft),
    transform 220ms var(--ease-over);
}
.ring.is-open {
  opacity: 1;
  pointer-events: auto;
  transform: translate(-50%, -50%) scale(1);
}

@media (max-width: 720px) {
  .ring { --rs: 140px; }
}

.ring__center {
  position: absolute;
  left: 50%; top: 50%;
  transform: translate(-50%, -50%);
  width: 116px; height: 116px;
  border: 1px solid var(--ink);
  background: var(--paper);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.25rem;
  pointer-events: none;
}
.ring__caption {
  font-family: var(--serif);
  font-size: 13px;
  color: var(--ink);
  letter-spacing: 0.01em;
}
.ring__sub {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--accent);
}
@media (max-width: 720px) {
  .ring__center { width: 84px; height: 84px; }
  .ring__caption { font-size: 12px; }
  .ring__sub { font-size: 9px; }
}

.ring__hat {
  position: absolute;
  left: 50%; top: 50%;
  width: 56px; height: 56px;
  margin: -28px 0 0 -28px;
  border: 1px solid var(--ink);
  background: var(--paper);
  display: grid;
  place-items: center;
  cursor: pointer;
  font-family: var(--mono);
  color: var(--ink);
  --a: 0deg;
  transform:
    rotate(var(--a))
    translate(var(--rs))
    rotate(calc(var(--a) * -1));
  opacity: 0;
  transition:
    opacity 220ms var(--ease-soft),
    background 160ms var(--ease-soft),
    color 160ms var(--ease-soft);
}
.ring.is-open .ring__hat { opacity: 1; }
.ring__hat .g { font-size: 22px; line-height: 1; }
.ring__hat .k {
  position: absolute;
  bottom: 2px; right: 4px;
  font-size: 8px;
  letter-spacing: 0.06em;
  color: var(--ink-3);
  font-variant-numeric: tabular-nums;
}
.ring__hat:hover { background: var(--ink); color: var(--paper); }
.ring__hat:hover .k { color: var(--paper); }
.ring__hat:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }
.ring__hat.is-active { background: var(--accent); color: var(--paper); }
.ring__hat.is-active .k { color: var(--paper); }

@media (max-width: 720px) {
  .ring__hat { width: 44px; height: 44px; margin: -22px 0 0 -22px; }
  .ring__hat .g { font-size: 18px; }
}

/* ============================================================ HAT PROJECTILE */

.hat-fly {
  position: fixed;
  left: 0; top: 0;
  font-size: 28px;
  line-height: 1;
  pointer-events: none;
  z-index: 1500;
  will-change: transform;
  filter: drop-shadow(0 1px 0 rgba(0,0,0,0.35));
}

/* ============================================================ EMERGENT FX */

/* ribbon (crown + Sable) */
.ribbon {
  position: fixed;
  width: 4px;
  height: 38px;
  background: linear-gradient(to bottom, #c9a13a, #8a6c1c);
  pointer-events: none;
  z-index: 900;
  opacity: 0;
}
.ribbon.is-falling { animation: ribbon-fall 1600ms var(--ease-fall) forwards; }
@keyframes ribbon-fall {
  0%   { opacity: 0; transform: translateY(-180px) rotate(-2deg); }
  10%  { opacity: 1; }
  85%  { opacity: 1; transform: translateY(0) rotate(3deg); }
  100% { opacity: 0.85; transform: translateY(0) rotate(3deg); }
}

/* hats spin (disco) */
.paddock.is-spinning .hat-stack .hat:first-child {
  animation: hat-orbit 6000ms linear 1;
}
@keyframes hat-orbit {
  to { transform: rotate(360deg); }
}

/* drifting petal (rose + Femme) */
.petal {
  position: fixed;
  font-size: 14px;
  pointer-events: none;
  z-index: 900;
  opacity: 0;
}
.petal.is-drifting { animation: petal-drift 7200ms linear forwards; }
@keyframes petal-drift {
  0%   { opacity: 0; transform: translate(0,0) rotate(0deg); }
  10%  { opacity: 1; }
  90%  { opacity: 1; }
  100% { opacity: 0; transform: translate(var(--dx, 320px), var(--dy, 60px)) rotate(540deg); }
}

/* saddle cursor (RIDE) */
.paddock.is-saddled,
.paddock.is-saddled .pony {
  cursor: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='28' height='28' viewBox='0 0 28 28'><text y='22' font-size='22'>🐴</text></svg>") 14 14, grab;
}

/* ============================================================ PROCESSION (G) */

.paddock.is-show {
  background-color: var(--paper-2);
}
.paddock.is-show .stamp {
  opacity: 0.55;
  transition: opacity 800ms var(--ease-soft);
}
.paddock.is-show .affordance,
.paddock.is-show .hint,
.paddock.is-show .recall,
.paddock.is-show .mute,
.paddock.is-show .ring,
.paddock.is-show .compass,
.paddock.is-show .fold {
  opacity: 0;
  pointer-events: none;
  transition: opacity 600ms var(--ease-soft);
}

.paddock.is-show::after {
  content: "";
  position: absolute;
  left: 6%; right: 6%;
  top: 50%;
  height: 1px;
  background: repeating-linear-gradient(
    to right,
    var(--ink-3) 0, var(--ink-3) 4px,
    transparent 4px, transparent 10px
  );
  opacity: 0.35;
  pointer-events: none;
  z-index: 1;
  animation: horizon-fade 800ms var(--ease-soft) both;
}
@keyframes horizon-fade {
  from { opacity: 0; }
  to   { opacity: 0.35; }
}

.paddock.is-show .pony {
  transition:
    transform 1400ms var(--ease-soft),
    filter 600ms var(--ease-soft);
}
.paddock.is-show .pony.is-offstage {
  opacity: 0;
  transition: transform 1400ms var(--ease-soft), opacity 400ms var(--ease-soft);
}
.paddock.is-show .pony.is-onstage {
  filter: saturate(1.05) brightness(1);
  z-index: 9000 !important;
}
.paddock.is-show .pony.is-dim {
  filter: saturate(0.6) brightness(0.92);
  opacity: 0.55;
}

.procession {
  position: absolute;
  left: 50%;
  bottom: clamp(2rem, 8vw, 4rem);
  transform: translateX(-50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.6rem;
  text-align: center;
  pointer-events: none;
  opacity: 0;
  z-index: 50;
  max-width: min(92vw, 540px);
  transition: opacity 360ms var(--ease-soft);
}
.procession.is-visible { opacity: 1; }

.procession__caption {
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
}
.procession__name {
  font-family: var(--serif);
  font-weight: 400;
  font-variation-settings: "opsz" 144;
  font-size: clamp(1.4rem, 3vw, 2rem);
  line-height: 1;
  color: var(--ink);
  letter-spacing: -0.01em;
}
.procession__bio {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.06em;
  color: var(--ink-2);
  line-height: 1.5;
}
.procession__counter {
  margin: 0;
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--ink-3);
  font-variant-numeric: tabular-nums;
}

@media (max-width: 560px) {
  .procession__name { font-size: 1.3rem; }
  .procession__bio  { font-size: 10px; letter-spacing: 0.04em; }
}

/* ============================================================ WITNESS */

.witness {
  position: absolute;
  bottom: clamp(0.85rem, 2vw, 1.4rem);
  left: 50%;
  transform: translateX(-50%) translateY(4px);
  margin: 0;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.18em;
  color: var(--accent);
  pointer-events: none;
  z-index: 4;
  opacity: 0;
  transition: opacity 600ms var(--ease-soft), transform 600ms var(--ease-soft);
}
.witness.is-stamped {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}
.witness.is-just-stamped {
  animation: witness-stamp 700ms var(--ease-over) both;
}
@keyframes witness-stamp {
  0%   { opacity: 0; transform: translateX(-50%) translateY(4px) scale(1.4) rotate(-3deg); }
  40%  { opacity: 1; transform: translateX(-50%) translateY(0)   scale(1.06) rotate(-1deg); }
  100% { opacity: 1; transform: translateX(-50%) translateY(0)   scale(1)    rotate(0deg); }
}

/* ============================================================ A11Y / MOTION */

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}

/* ============================================================ SKY + WEATHER */

:root {
  --sky-band:    #ece5d3;
  --sky-band-2:  #e3dcc7;
  --sky-height:  34vh;
  --weather-tilt: 0deg;
  --wind-dir:    'N';
}

.sky {
  position: absolute;
  left: 0; right: 0; top: 0;
  height: var(--sky-height);
  background: linear-gradient(
    to bottom,
    var(--sky-band-2) 0%,
    var(--sky-band) 55%,
    transparent 100%
  );
  pointer-events: none;
  z-index: 1;
  transition: background 1600ms var(--ease-soft), opacity 1200ms var(--ease-soft);
}

.weather-fx {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 2;
  overflow: hidden;
}

.weather-fx__drizzle {
  position: absolute;
  inset: 0;
  color: var(--ink-2);
  opacity: 0;
  transition: opacity 1400ms var(--ease-soft);
}
.paddock.is-w-drizzle .weather-fx__drizzle { opacity: 0.06; }

.weather-fx__fog {
  position: absolute;
  left: -4%;
  right: -4%;
  top: 0;
  height: 28vh;
  background: linear-gradient(
    to bottom,
    rgba(243,239,230,0.85) 0%,
    rgba(243,239,230,0.55) 40%,
    rgba(243,239,230,0.0) 100%
  );
  filter: blur(18px);
  opacity: 0;
  transition: opacity 1600ms var(--ease-soft);
}
.paddock.is-w-fog .weather-fx__fog { opacity: 1; }

.weather-fx__aurora {
  position: absolute;
  left: 0; right: 0;
  top: 0;
  height: var(--sky-height);
  background: linear-gradient(
    100deg,
    transparent 0%,
    transparent 30%,
    rgba(138,42,30,0.16) 50%,
    transparent 70%,
    transparent 100%
  );
  background-size: 280% 100%;
  background-position: -140% 0;
  opacity: 0;
  transition: opacity 1600ms var(--ease-soft);
}
.paddock.is-w-aurora .weather-fx__aurora {
  opacity: 1;
  animation: aurora-sweep 90s linear 1;
}
@keyframes aurora-sweep {
  from { background-position: -140% 0; }
  to   { background-position: 140% 0; }
}

/* Hats with feathers/ribbons sway with wind tilt; the leaf-like ones lean. */
.hat-stack {
  transform: translate(-50%, -100%) rotate(var(--weather-tilt));
  transition: transform 1800ms var(--ease-soft);
  transform-origin: 50% 100%;
}

/* ----- weather chip ----- */

.weather-chip {
  position: absolute;
  bottom: clamp(0.85rem, 2vw, 1.4rem);
  left: clamp(7rem, 14vw, 9.5rem);
  appearance: none;
  background: transparent;
  border: 1px solid var(--ink-3);
  color: var(--ink-2);
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: lowercase;
  padding: 0.4rem 0.65rem;
  cursor: pointer;
  z-index: 6;
  transition: background 200ms var(--ease-soft), color 200ms var(--ease-soft), border-color 200ms var(--ease-soft);
  white-space: nowrap;
}
.weather-chip:hover { background: var(--ink); color: var(--paper); border-color: var(--ink); }
.weather-chip:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }
.weather-chip.is-aurora { color: var(--accent); border-color: var(--accent); }

@media (max-width: 720px) {
  .weather-chip { left: clamp(5.5rem, 22vw, 8rem); font-size: 9px; padding: 0.3rem 0.5rem; letter-spacing: 0.14em; }
}
@media (max-width: 420px) {
  .weather-chip { display: none; }
}

/* ----- compass wind tick ----- */

.compass {
  transition: color 800ms var(--ease-soft);
}
.compass.is-wind { color: var(--accent); }

/* ----- aurora witness stamp slot (sits next to the (witnessed) line) ----- */

.witness--aurora {
  position: absolute;
  bottom: clamp(2.1rem, 4.4vw, 2.8rem);
  left: 50%;
  transform: translateX(-50%);
  margin: 0;
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: 0.2em;
  color: var(--accent);
  pointer-events: none;
  z-index: 4;
  opacity: 0;
  transition: opacity 600ms var(--ease-soft);
}
.witness--aurora.is-stamped { opacity: 0.8; }

/* ----- per-state paper + sky tints (compose with .is-night) ----- */

.paddock.is-w-clear      { --paper: #f3efe6; --sky-band: #ece5d3; --sky-band-2: #e3dcc7; }
.paddock.is-w-breezy     { --paper: #f1ede2; --sky-band: #e8e1ce; --sky-band-2: #ddd4bd; }
.paddock.is-w-overcast   { --paper: #eceadf; --sky-band: #d8d4c4; --sky-band-2: #cbc6b3; }
.paddock.is-w-drizzle    { --paper: #e7e5da; --sky-band: #c9c6b7; --sky-band-2: #b9b6a6; }
.paddock.is-w-fog        { --paper: #efece2; --sky-band: #dcd9cb; --sky-band-2: #d2cebd; }
.paddock.is-w-dusk       { --paper: #ece2d2; --sky-band: #ddc9b1; --sky-band-2: #c9a98b; }

.paddock.is-night.is-w-clear    { --sky-band: #cfc6b0; --sky-band-2: #b9b09a; }
.paddock.is-night.is-w-overcast { --sky-band: #b9b3a2; --sky-band-2: #a39d8c; }
.paddock.is-night.is-w-drizzle  { --sky-band: #a8a392; --sky-band-2: #928d7c; }
.paddock.is-night.is-w-fog      { --sky-band: #c7c1ad; --sky-band-2: #b3ad99; }

/* night dims the sky band slightly via opacity too, layered on color */
.paddock.is-night .sky { opacity: 0.85; }

/* on dusk, kiss the lower edge of the sky band toward the accent */
.paddock.is-w-dusk .sky {
  background: linear-gradient(
    to bottom,
    var(--sky-band-2) 0%,
    var(--sky-band) 50%,
    rgba(138,42,30,0.05) 88%,
    transparent 100%
  );
}

/* during procession, soften weather */
.paddock.is-show .weather-fx__drizzle,
.paddock.is-show .weather-fx__fog,
.paddock.is-show .weather-fx__aurora { opacity: 0; transition: opacity 600ms var(--ease-soft); }
.paddock.is-show .sky { opacity: 0.5; }
.paddock.is-show .weather-chip { opacity: 0; pointer-events: none; transition: opacity 600ms var(--ease-soft); }
