:root {
  --rice: #F4EBDD;
  --kraft: #D7B98A;
  --walnut: #3F3024;
  --sepia: #8A6245;
  --rose: #B86F61;
  --green: #7F8A5B;
  --indigo: #586C8C;
  --butter: #F2D98B;
  --cream: #EFE0CB;
  --border: rgba(138, 98, 69, 0.35);
  --shadow: 0 1px 0 rgba(63,48,36,.12), 0 12px 30px rgba(63,48,36,.08);
}

* { box-sizing: border-box; }

html {
  scroll-behavior: smooth;
  scroll-snap-type: y proximity;
}

body {
  margin: 0;
  min-height: 100vh;
  font-family: "Nunito Sans", "Inter", system-ui, sans-serif;
  color: var(--walnut);
  background:
    radial-gradient(circle at 14% 10%, rgba(242, 217, 139, .34), transparent 28rem),
    radial-gradient(circle at 82% 20%, rgba(184, 111, 97, .11), transparent 22rem),
    linear-gradient(135deg, var(--rice), var(--cream));
  overflow-x: hidden;
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  opacity: .28;
  background-image:
    linear-gradient(rgba(63,48,36,.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(63,48,36,.022) 1px, transparent 1px);
  background-size: 34px 34px, 34px 34px;
  z-index: 0;
}

.desktop-grain {
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 1;
  opacity: .2;
  background:
    repeating-linear-gradient(101deg, transparent 0 18px, rgba(138, 98, 69, .05) 19px 20px),
    radial-gradient(ellipse at 20% 70%, rgba(138,98,69,.18), transparent 26rem);
  mix-blend-mode: multiply;
}

.drawer-tabs {
  position: fixed;
  right: 1.1rem;
  top: 1.1rem;
  z-index: 10;
  display: flex;
  gap: .35rem;
  flex-wrap: wrap;
  justify-content: flex-end;
  max-width: 22rem;
}

.drawer-tabs a {
  font-family: "IBM Plex Mono", monospace;
  font-size: .68rem;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--walnut);
  text-decoration: none;
  padding: .45rem .62rem;
  border: 1px solid var(--border);
  border-radius: 999px;
  background: rgba(244, 235, 221, .76);
  box-shadow: 0 4px 16px rgba(63,48,36,.08);
  transition: transform .28s ease, background .28s ease;
}

.drawer-tabs a:hover { transform: translateX(-8px); background: var(--butter); }

.scene {
  position: relative;
  min-height: 100vh;
  padding: clamp(4rem, 7vw, 7rem) clamp(1rem, 5vw, 5rem);
  display: grid;
  align-items: center;
  scroll-snap-align: start;
  z-index: 2;
}

.bento {
  width: min(1180px, 100%);
  min-height: min(760px, calc(100vh - 8rem));
  display: grid;
  grid-template-columns: repeat(12, minmax(0, 1fr));
  grid-template-rows: repeat(10, minmax(44px, 1fr));
  gap: clamp(.65rem, 1.3vw, 1rem);
  position: relative;
  margin: 0 auto;
}

.tray {
  position: relative;
  border: 1px solid var(--border);
  border-radius: 22px;
  padding: clamp(1rem, 2vw, 1.55rem);
  box-shadow: var(--shadow);
  overflow: hidden;
  transform: translateY(18px) rotate(var(--r, 0deg));
  opacity: 0;
  transition: transform .8s cubic-bezier(.2,.8,.2,1), opacity .7s ease, box-shadow .35s ease;
}

.tray.in-view, .tray.placed { opacity: 1; transform: translateY(0) rotate(var(--r, 0deg)); }
.tray:hover { box-shadow: 0 1px 0 rgba(63,48,36,.16), 0 18px 34px rgba(63,48,36,.12); }

.paper {
  background:
    linear-gradient(135deg, rgba(255,255,255,.28), rgba(215,185,138,.12)),
    radial-gradient(circle at 18% 18%, rgba(242,217,139,.18), transparent 10rem),
    var(--rice);
}

.paper::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  opacity: .33;
  background-image: radial-gradient(rgba(63,48,36,.08) .7px, transparent .8px);
  background-size: 12px 12px;
}

h1, h2, p { margin-top: 0; }
h1, h2 { font-family: "Fraunces", "Lora", Georgia, serif; font-weight: 700; line-height: .94; }
h1 { font-size: clamp(3.4rem, 10vw, 8.8rem); letter-spacing: -.07em; margin-bottom: .65rem; }
h2 { font-size: clamp(2rem, 5vw, 4.7rem); letter-spacing: -.045em; margin-bottom: .75rem; }
p, li { font-size: clamp(.96rem, 1.22vw, 1.16rem); line-height: 1.56; }
small { display: block; font-size: .82rem; line-height: 1.35; }
.micro { display: inline-block; font-family: "IBM Plex Mono", monospace; font-size: .68rem; letter-spacing: .12em; text-transform: uppercase; color: rgba(63,48,36,.72); margin-bottom: .72rem; }

.opening-bento { margin-left: 0; }
.domain-strip { grid-column: 1 / 10; grid-row: 1 / 4; background-color: var(--cream); }
.domain-strip::before {
  content: "";
  position: absolute;
  top: 0; bottom: 0; right: 1.1rem; width: 8px;
  background: radial-gradient(circle, rgba(138,98,69,.35) 2px, transparent 2.5px) center/8px 14px;
}
.specimen { grid-column: 9 / 13; grid-row: 3 / 8; background-color: var(--cream); }
.notebook { grid-column: 1 / 5; grid-row: 4 / 10; background-image: linear-gradient(90deg, rgba(184,111,97,.22) 0 2px, transparent 2px), repeating-linear-gradient(0deg, transparent 0 33px, rgba(88,108,140,.17) 34px 35px); background-color: var(--rice); padding-left: 2.2rem; }
.stamp { grid-column: 5 / 7; grid-row: 5 / 7; display: grid; place-items: center; text-align: center; background: var(--butter); }
.empty-tray { grid-column: 7 / 11; grid-row: 8 / 11; background: rgba(239,224,203,.62); }
.sun-patch { position: absolute; inset: 16% 12%; border-radius: 50%; background: radial-gradient(circle, rgba(242,217,139,.45), transparent 65%); }

.botanical { width: 100%; height: auto; overflow: visible; }
.flower-lift { transition: transform .35s ease; transform-origin: center bottom; }
.flower-lift:hover, .tray:hover .flower-lift { transform: rotate(2deg) translateY(-4px); }

.tape { position: absolute; z-index: 2; width: 72px; height: 24px; background: rgba(242,217,139,.56); border: 1px solid rgba(138,98,69,.16); transform: rotate(-8deg); box-shadow: 0 4px 12px rgba(63,48,36,.05); }
.tape-a { top: 12px; left: 34%; }
.tape-b { top: 18px; right: 18%; transform: rotate(7deg); }
.tab { position: absolute; right: -1px; top: 24px; padding: .45rem .75rem; border: 1px solid var(--border); border-right: 0; border-radius: 12px 0 0 12px; background: var(--kraft); font-family: "IBM Plex Mono", monospace; font-size: .7rem; transition: transform .3s ease; }
.tray:hover .tab { transform: translateX(-8px); }

.stamp-ring { display: grid; place-items: center; width: 74px; height: 74px; border: 2px solid var(--rose); border-radius: 50%; font-family: "IBM Plex Mono", monospace; color: var(--rose); transform: rotate(-10deg); margin: .2rem auto .45rem; }
.interactive-stamp { transition: color .3s ease, filter .3s ease, transform .8s cubic-bezier(.2,.8,.2,1); }
.interactive-stamp:hover { filter: saturate(1.2) contrast(1.05); }

.toy { position: absolute; z-index: 3; box-shadow: 0 7px 18px rgba(63,48,36,.1); }
.circle { width: 48px; height: 48px; border-radius: 50%; background: var(--indigo); }
.opening-bento > .circle { left: 43%; top: 37%; }
.halfmoon { width: 62px; height: 62px; border-radius: 50%; background: linear-gradient(90deg, var(--rose) 50%, transparent 50%); border: 1px solid rgba(63,48,36,.13); right: 5%; bottom: 14%; }
.triangle { width: 0; height: 0; border-left: 34px solid transparent; border-right: 34px solid transparent; border-bottom: 58px solid var(--butter); left: 57%; bottom: 29%; filter: drop-shadow(0 8px 12px rgba(63,48,36,.1)); }
.toy-roll { transition: transform .45s ease; }
.toy-roll:hover, .tray:hover .inline-toy { transform: translateX(12px) rotate(38deg); }

.memory-bento { margin-right: 0; }
.drawer-title { grid-column: 2 / 8; grid-row: 1 / 4; }
.note-card { grid-column: 7 / 12; grid-row: 3 / 7; }
.kraft-pocket { grid-column: 1 / 5; grid-row: 5 / 9; background: var(--kraft); border-radius: 14px 14px 24px 24px; padding-top: 4rem; }
.ruled-slip { grid-column: 5 / 10; grid-row: 7 / 10; background-image: repeating-linear-gradient(0deg, transparent 0 30px, rgba(88,108,140,.18) 31px 32px); }
.tiny-doodle { grid-column: 10 / 12; grid-row: 8 / 10; display: grid; place-items: center; text-align: center; }
.tiny-doodle span { font-size: 3rem; color: var(--rose); }

.skeleton-lines { display: grid; gap: .72rem; margin: .5rem 0 1rem; }
.skeleton-lines i { display: block; height: 15px; border-radius: 999px; background: linear-gradient(90deg, rgba(215,185,138,.34), rgba(244,235,221,.88), rgba(138,98,69,.17)); background-size: 220% 100%; animation: shimmer 2s linear infinite; }
.skeleton-lines i:nth-child(2) { width: 76%; }
.skeleton-lines i:nth-child(3) { width: 52%; }
.resolved-content { opacity: 0; transform: translateY(8px); transition: opacity .55s ease, transform .55s ease; }
.skeleton-card.resolved .skeleton-lines { display: none; }
.skeleton-card.resolved .resolved-content { opacity: 1; transform: translateY(0); }

@keyframes shimmer { from { background-position: 120% 0; } to { background-position: -120% 0; } }

.ledger-heading { grid-column: 1 / 7; grid-row: 1 / 4; }
.inventory { grid-column: 2 / 6; grid-row: 4 / 9; }
.inventory ul { list-style: none; padding: 0; margin: 0; }
.inventory li { border-bottom: 1px dashed rgba(138,98,69,.35); padding: .62rem 0; font-family: "IBM Plex Mono", monospace; font-size: .8rem; }
.geometry { grid-column: 7 / 12; grid-row: 2 / 7; }
.shape-board { height: 100%; min-height: 220px; display: grid; grid-template-columns: repeat(4, 1fr); gap: .75rem; align-items: center; }
.block { display: block; min-height: 96px; border: 1px solid rgba(63,48,36,.1); box-shadow: inset 0 0 0 10px rgba(244,235,221,.22), 0 9px 18px rgba(63,48,36,.08); transition: transform .35s ease; }
.block:hover { transform: translateY(-8px) rotate(2deg); }
.butter { background: var(--butter); border-radius: 50% 50% 14px 14px; }
.indigo { background: var(--indigo); border-radius: 999px; }
.rose { background: var(--rose); border-radius: 16px; }
.green { background: var(--green); border-radius: 60% 8px 60% 8px; }
.vine { position: absolute; grid-column: 4 / 13; grid-row: 3 / 10; width: 100%; height: 100%; z-index: 4; pointer-events: none; opacity: .82; }
.coordinate { grid-column: 8 / 11; grid-row: 8 / 10; z-index: 5; }

.play-title { grid-column: 1 / 8; grid-row: 1 / 4; }
.play-compartment { cursor: pointer; text-align: left; color: var(--walnut); font: inherit; }
.play-compartment:nth-of-type(2) { grid-column: 2 / 6; grid-row: 5 / 8; }
.play-compartment:nth-of-type(3) { grid-column: 6 / 10; grid-row: 4 / 7; }
.play-compartment:nth-of-type(4) { grid-column: 9 / 13; grid-row: 7 / 10; }
.closing { grid-column: 1 / 7; grid-row: 8 / 11; background: var(--cream); }
.inline-toy { position: relative; display: inline-block; width: 42px; height: 42px; vertical-align: middle; margin: .5rem 0; transition: transform .45s ease; }

.reveal-piece:nth-child(1) { --r: -.5deg; }
.reveal-piece:nth-child(2) { --r: 1deg; }
.reveal-piece:nth-child(3) { --r: -1.2deg; }
.reveal-piece:nth-child(4) { --r: .6deg; }
.reveal-piece:nth-child(5) { --r: -1.8deg; }

@media (max-width: 820px) {
  .drawer-tabs { left: .75rem; right: .75rem; top: .6rem; justify-content: center; }
  .scene { padding: 5.6rem .8rem 2rem; }
  .bento { display: flex; flex-direction: column; min-height: auto; }
  .tray { min-height: 150px; }
  .toy, .vine { display: none; }
  h1 { font-size: clamp(3rem, 18vw, 5rem); }
}
