:root {
  --rain-ink: #18252B;
  --washi-cream: #F4EAD8;
  --indigo-noren: #1F4D63;
  --cedar-brown: #7A5435;
  --brass-bell: #C49A4B;
  --rain-glass: #9FC6C3;
  --persimmon-seal: #D6683A;
  --serif: "Noto Serif JP", "Shippori Mincho", "Yu Mincho", "Hiragino Mincho ProN", Georgia, serif;
  --gothic: "Zen Kaku Gothic New", "Hiragino Kaku Gothic ProN", "Yu Gothic", Inter, system-ui, sans-serif;
  --mono: "IBM Plex Mono", ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
}

* { box-sizing: border-box; }

html {
  scroll-behavior: smooth;
  background: var(--rain-ink);
}

body {
  margin: 0;
  color: var(--washi-cream);
  background: var(--rain-ink);
  font-family: var(--gothic);
  overflow-x: hidden;
}

a { color: inherit; }

.rain-shop {
  position: relative;
  min-height: 100vh;
  isolation: isolate;
  background:
    radial-gradient(circle at 14% 12%, rgba(159,198,195,.13), transparent 28rem),
    linear-gradient(180deg, #10191e 0%, var(--rain-ink) 22%, #1b2a2c 58%, #111b20 100%);
}

.paper-fibers,
.rain-pane {
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 12;
}

.paper-fibers {
  opacity: .11;
  mix-blend-mode: screen;
  background-image:
    repeating-linear-gradient(82deg, transparent 0 26px, rgba(244,234,216,.22) 27px, transparent 29px),
    repeating-linear-gradient(173deg, transparent 0 19px, rgba(159,198,195,.18) 20px, transparent 21px);
}

.rain-pane {
  overflow: hidden;
  z-index: 30;
}

.drop {
  position: absolute;
  top: -18vh;
  width: 1px;
  height: var(--drop-height, 90px);
  border-radius: 999px;
  opacity: var(--drop-opacity, .45);
  background: linear-gradient(180deg, transparent, var(--rain-glass), transparent);
  animation: glass-rain var(--drop-speed, 5s) linear infinite;
  animation-delay: var(--drop-delay, 0s);
}

@keyframes glass-rain {
  to { transform: translate3d(var(--drop-drift, 12px), 125vh, 0); }
}

.rain-chain {
  position: fixed;
  right: 22px;
  top: 50%;
  transform: translateY(-50%);
  z-index: 40;
  display: flex;
  flex-direction: column;
  gap: 15px;
}

.rain-chain::before {
  content: "";
  position: absolute;
  top: -30px;
  bottom: -30px;
  left: 50%;
  width: 1px;
  background: linear-gradient(var(--brass-bell), rgba(196,154,75,.18));
}

.chain-bead {
  width: 15px;
  height: 15px;
  display: grid;
  place-items: center;
  border: 1px solid var(--brass-bell);
  border-radius: 50%;
  background: rgba(24,37,43,.82);
  position: relative;
  text-decoration: none;
  box-shadow: 0 0 16px rgba(196,154,75,.18);
}

.chain-bead span {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  transform: scaleY(.12);
  transform-origin: bottom;
  background: var(--rain-glass);
  transition: transform .7s ease, background .7s ease;
}

.chain-bead.active span,
.chain-bead.filled span {
  transform: scaleY(1);
  background: var(--brass-bell);
}

.shop-room {
  position: relative;
  min-height: 100vh;
  overflow: hidden;
  padding: clamp(68px, 9vw, 128px) clamp(28px, 7vw, 110px);
  display: grid;
  align-items: center;
  background:
    linear-gradient(90deg, rgba(244,234,216,.035) 1px, transparent 1px) 0 0 / 82px 100%,
    radial-gradient(circle at 75% 35%, rgba(196,154,75,.10), transparent 28rem);
}

.shop-room::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    repeating-linear-gradient(180deg, rgba(159,198,195,.04) 0 1px, transparent 1px 18px),
    radial-gradient(circle at var(--mist-x, 50%) 72%, rgba(159,198,195,.09), transparent 32rem);
  opacity: .75;
  pointer-events: none;
}

.shop-room::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 34%;
  background: linear-gradient(0deg, rgba(10,16,19,.55), transparent);
  pointer-events: none;
}

.room-copy {
  position: relative;
  z-index: 3;
  max-width: 510px;
  padding: 34px 38px;
  border-left: 1px solid rgba(196,154,75,.55);
  background: linear-gradient(90deg, rgba(24,37,43,.76), rgba(24,37,43,.18));
}

.right-copy { justify-self: end; text-align: left; }
.narrow-copy { max-width: 440px; }

h1, h2 {
  font-family: var(--serif);
  margin: 0;
  font-weight: 500;
  letter-spacing: .03em;
}

h1 {
  font-size: clamp(2.2rem, 7vw, 6.8rem);
  line-height: .92;
  color: var(--rain-ink);
}

h2 {
  font-size: clamp(2.2rem, 5vw, 5.4rem);
  line-height: .98;
  color: var(--washi-cream);
  text-shadow: 0 8px 30px rgba(0,0,0,.35);
}

p {
  font-size: clamp(1rem, 1.4vw, 1.18rem);
  line-height: 1.9;
  color: rgba(244,234,216,.82);
}

.inventory {
  font-family: var(--mono);
  font-size: .68rem;
  letter-spacing: .24em;
  color: var(--brass-bell);
  text-transform: uppercase;
}

.stamp {
  font-family: var(--serif);
  color: var(--persimmon-seal);
  letter-spacing: .34em;
}

.damp-paper {
  background:
    radial-gradient(circle at 22% 18%, rgba(159,198,195,.20), transparent 9rem),
    linear-gradient(135deg, rgba(244,234,216,.98), rgba(228,211,181,.92));
  color: var(--rain-ink);
  box-shadow: 0 18px 80px rgba(0,0,0,.42), inset 0 0 45px rgba(122,84,53,.12);
}

.threshold-room {
  min-height: 108vh;
  place-items: center;
  text-align: center;
  background:
    radial-gradient(circle at 50% 86%, rgba(159,198,195,.22), transparent 23rem),
    linear-gradient(180deg, #0d1519, #18252B 44%, #24383d 100%);
}

.roof-eave {
  position: absolute;
  top: 0;
  left: -5%;
  right: -5%;
  height: 120px;
  z-index: 7;
  background:
    repeating-linear-gradient(90deg, #0b1114 0 54px, #172329 54px 60px),
    linear-gradient(#05080a, #142025);
  box-shadow: 0 22px 44px rgba(0,0,0,.46);
}

.roof-eave::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -18px;
  height: 24px;
  background: repeating-linear-gradient(90deg, var(--cedar-brown) 0 16px, #4f3423 16px 21px);
}

.street-mist {
  position: absolute;
  inset: auto -20% 0;
  height: 42%;
  background: radial-gradient(ellipse at center, rgba(159,198,195,.23), transparent 70%);
  filter: blur(12px);
}

.noren {
  position: absolute;
  top: 88px;
  left: 50%;
  width: min(780px, 82vw);
  height: 49vh;
  transform: translateX(-50%);
  display: flex;
  gap: 6px;
  z-index: 5;
  perspective: 900px;
}

.noren-panel {
  flex: 1;
  transform-origin: top center;
  background:
    linear-gradient(90deg, rgba(255,255,255,.08), transparent 22%, rgba(0,0,0,.10)),
    repeating-linear-gradient(0deg, rgba(244,234,216,.05) 0 2px, transparent 2px 8px),
    var(--indigo-noren);
  box-shadow: inset 0 -25px 45px rgba(0,0,0,.18);
  animation: cloth-breathe 6.8s ease-in-out infinite;
}

.noren-panel:nth-child(2) { animation-delay: -1.3s; }
.noren-panel:nth-child(3) { animation-delay: -2.1s; }
.noren-panel:nth-child(4) { animation-delay: -.6s; }
.noren.parted .noren-panel:nth-child(1),
.noren.parted .noren-panel:nth-child(2) { transform: rotateY(18deg) translateX(-20px); }
.noren.parted .noren-panel:nth-child(3),
.noren.parted .noren-panel:nth-child(4) { transform: rotateY(-18deg) translateX(20px); }

@keyframes cloth-breathe {
  50% { filter: brightness(1.06); clip-path: polygon(0 0,100% 0,96% 100%,4% 97%); }
}

.washi-sign {
  position: relative;
  z-index: 8;
  width: min(760px, 86vw);
  padding: clamp(28px, 6vw, 64px);
  transform: rotate(-1deg);
  border: 1px solid rgba(122,84,53,.32);
}

.washi-sign p { color: rgba(24,37,43,.72); margin-bottom: 0; }

.stone-path {
  position: absolute;
  bottom: 7vh;
  left: 13vw;
  right: 13vw;
  display: flex;
  justify-content: space-around;
  opacity: .72;
}

.stone-path span {
  width: clamp(70px, 13vw, 160px);
  height: 54px;
  border-radius: 48% 52% 42% 58%;
  background: linear-gradient(160deg, rgba(159,198,195,.22), rgba(24,37,43,.88));
  box-shadow: inset 0 8px 20px rgba(244,234,216,.06), 0 14px 26px rgba(0,0,0,.28);
}

.puddle {
  position: absolute;
  bottom: 9vh;
  left: 50%;
  width: min(440px, 62vw);
  height: 58px;
  transform: translateX(-50%);
  border-radius: 50%;
  background: radial-gradient(ellipse at center, rgba(159,198,195,.42), rgba(31,77,99,.16) 55%, transparent 70%);
}

.puddle::after {
  content: attr(data-reflect);
  position: absolute;
  inset: 8px 0 0;
  font-family: var(--serif);
  color: rgba(244,234,216,.25);
  transform: scaleY(-1);
  filter: blur(.6px);
  animation: reflection-wobble 3.8s ease-in-out infinite;
}

@keyframes reflection-wobble {
  50% { letter-spacing: .08em; transform: scaleY(-1) translateX(12px); }
}

.shoji-window {
  position: absolute;
  right: 7vw;
  top: 16vh;
  width: min(430px, 44vw);
  height: 42vh;
  border: 12px solid var(--cedar-brown);
  background: linear-gradient(rgba(244,234,216,.83), rgba(215,205,185,.72));
  box-shadow: 0 18px 70px rgba(0,0,0,.28);
}

.shoji-window::before,
.shoji-window::after {
  content: "";
  position: absolute;
  inset: 0;
  background: repeating-linear-gradient(90deg, transparent 0 31%, rgba(122,84,53,.5) 31% 32%), repeating-linear-gradient(0deg, transparent 0 31%, rgba(122,84,53,.42) 31% 32%);
}

.shoji-window span {
  position: absolute;
  bottom: 12%;
  width: 70px;
  height: 130px;
  border-radius: 50% 50% 14px 14px;
  background: rgba(24,37,43,.24);
  filter: blur(6px);
  animation: shadow-pass 12s linear infinite;
}

.shoji-window span:nth-child(2) { animation-delay: -4s; }
.shoji-window span:nth-child(3) { animation-delay: -7s; }

@keyframes shadow-pass {
  from { transform: translateX(-120px); }
  to { transform: translateX(480px); }
}

.umbrella-rack {
  position: absolute;
  right: 11vw;
  bottom: 9vh;
  width: 330px;
  height: 450px;
  z-index: 4;
}

.ceramic-stand {
  position: absolute;
  bottom: 0;
  left: 96px;
  width: 130px;
  height: 120px;
  border-radius: 18px 18px 42% 42%;
  background:
    linear-gradient(112deg, transparent 44%, var(--brass-bell) 45% 47%, transparent 48%),
    radial-gradient(circle at 30% 20%, rgba(244,234,216,.22), transparent 20%),
    var(--indigo-noren);
  box-shadow: inset -18px -12px 30px rgba(0,0,0,.28);
}

.umbrella {
  position: absolute;
  bottom: 74px;
  width: 210px;
  height: 300px;
  transform-origin: bottom center;
}

.umbrella i {
  position: absolute;
  left: 50%;
  bottom: 0;
  width: 5px;
  height: 260px;
  background: var(--cedar-brown);
  transform: translateX(-50%);
}

.umbrella b {
  position: absolute;
  left: 24px;
  top: 15px;
  width: 164px;
  height: 94px;
  border-radius: 90px 90px 14px 14px;
  background: conic-gradient(from 180deg at 50% 100%, var(--indigo-noren), #2b6679, var(--washi-cream), var(--indigo-noren));
  clip-path: polygon(50% 0,100% 100%,0 100%);
}

.umbrella span {
  position: absolute;
  left: 51%;
  bottom: -18px;
  width: 34px;
  height: 28px;
  border: 5px solid var(--cedar-brown);
  border-top: 0;
  border-radius: 0 0 28px 28px;
}

.umbrella-a { left: 0; transform: rotate(-18deg); }
.umbrella-b { left: 78px; transform: rotate(6deg); }
.umbrella-c { left: 138px; transform: rotate(22deg) scale(.9); }

.hanging-charms {
  position: absolute;
  left: 17vw;
  top: 14vh;
  display: flex;
  gap: 56px;
  z-index: 4;
}

.charm {
  position: relative;
  width: 88px;
  height: 132px;
  transform-origin: top center;
  animation: tag-swing 4.8s ease-in-out infinite;
}

.charm::before {
  content: "";
  display: block;
  width: 1px;
  height: 50px;
  margin: 0 auto;
  background: rgba(244,234,216,.6);
}

.charm i {
  display: block;
  width: 62px;
  height: 52px;
  margin: 0 auto;
  border-radius: 50% 50% 38% 38%;
  background: var(--washi-cream);
  box-shadow: 0 9px 18px rgba(0,0,0,.15);
}

.charm span {
  display: block;
  margin-top: -4px;
  padding: 10px 6px;
  color: var(--rain-ink);
  background: var(--washi-cream);
  font-family: var(--serif);
  font-size: .78rem;
}

.delay { animation-delay: -2s; }

@keyframes tag-swing {
  50% { transform: rotate(5deg) translateY(4px); }
}

.label-room { background-color: #17262b; }

.cedar-counter {
  position: absolute;
  left: 7vw;
  bottom: 11vh;
  width: min(560px, 55vw);
  height: 330px;
  padding: 24px;
  background:
    repeating-linear-gradient(90deg, rgba(244,234,216,.04) 0 2px, transparent 2px 44px),
    linear-gradient(105deg, #5d3c28, var(--cedar-brown));
  border-top: 12px solid #9a7149;
  box-shadow: 0 30px 80px rgba(0,0,0,.38);
  z-index: 3;
}

.drawer {
  position: relative;
  height: 82px;
  margin-bottom: 16px;
  padding: 22px 28px;
  color: var(--washi-cream);
  border: 1px solid rgba(244,234,216,.18);
  background: linear-gradient(90deg, rgba(24,37,43,.24), rgba(122,84,53,.2));
  cursor: pointer;
  transition: transform .55s ease, box-shadow .55s ease;
}

.drawer::after {
  content: "";
  position: absolute;
  right: 24px;
  top: 50%;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: var(--brass-bell);
  transform: translateY(-50%);
}

.drawer.opened {
  transform: translateX(54px);
  box-shadow: -24px 18px 40px rgba(0,0,0,.32);
}

.drawer span { font-family: var(--serif); font-size: 1.4rem; }

.tag-field {
  position: absolute;
  right: 12vw;
  bottom: 14vh;
  z-index: 5;
  display: flex;
  gap: 16px;
  align-items: flex-start;
}

.washi-tag {
  border: 0;
  padding: 18px 16px 28px;
  color: var(--rain-ink);
  background: var(--washi-cream);
  font-family: var(--serif);
  box-shadow: 0 18px 40px rgba(0,0,0,.26);
  transform-origin: top center;
  animation: tag-swing 5.4s ease-in-out infinite;
}

.washi-tag:nth-child(2) { animation-delay: -1.6s; }
.washi-tag:nth-child(3) { animation-delay: -3s; }
.washi-tag.persimmon { color: var(--persimmon-seal); }

.ink-map {
  position: absolute;
  left: 42vw;
  top: 18vh;
  width: 320px;
  height: 210px;
  opacity: .65;
  filter: blur(.2px);
}

.ink-map span {
  position: absolute;
  border-radius: 43% 57% 61% 39%;
  border: 1px solid rgba(159,198,195,.42);
  animation: ink-bloom 8s ease-in-out infinite;
}

.ink-map span:nth-child(1) { inset: 10px 80px 40px 20px; }
.ink-map span:nth-child(2) { inset: 50px 20px 15px 120px; animation-delay: -2s; }
.ink-map span:nth-child(3) { inset: 80px 130px 5px 60px; animation-delay: -4s; }

@keyframes ink-bloom {
  50% { transform: scale(1.12); background: rgba(159,198,195,.05); }
}

.drawer-note {
  position: absolute;
  left: 10vw;
  bottom: 5vh;
  z-index: 4;
  max-width: 420px;
  color: var(--brass-bell);
  font-family: var(--serif);
}

.bowl-room { background-color: #131f24; }

.alcove-frame {
  position: absolute;
  right: 9vw;
  top: 12vh;
  bottom: 11vh;
  width: min(520px, 43vw);
  border: 18px solid var(--cedar-brown);
  border-bottom-width: 36px;
  background: radial-gradient(circle at 52% 58%, rgba(196,154,75,.16), transparent 18rem), rgba(244,234,216,.05);
}

.rain-bowls {
  position: absolute;
  right: 11vw;
  bottom: 18vh;
  width: min(470px, 40vw);
  height: 240px;
  z-index: 4;
}

.bowl {
  position: absolute;
  bottom: 0;
  width: 180px;
  height: 95px;
  border-radius: 0 0 90px 90px;
  background:
    linear-gradient(118deg, transparent 42%, var(--brass-bell) 43% 46%, transparent 47%),
    linear-gradient(180deg, #304c57, var(--indigo-noren));
  box-shadow: inset 0 -22px 34px rgba(0,0,0,.25), 0 24px 40px rgba(0,0,0,.25);
}

.bowl::before {
  content: "";
  position: absolute;
  top: -12px;
  left: 0;
  right: 0;
  height: 26px;
  border-radius: 50%;
  background: radial-gradient(ellipse at center, rgba(159,198,195,.7), rgba(31,77,99,.75) 55%, #466a72 56%);
}

.bowl span,
.bowl i {
  position: absolute;
  top: -22px;
  left: 50%;
  width: 26px;
  height: 8px;
  border: 1px solid rgba(159,198,195,.8);
  border-radius: 50%;
  transform: translateX(-50%);
  animation: ripple 2.8s ease-out infinite;
}

.bowl i { animation-delay: 1.2s; }
.bowl-one { left: 0; transform: scale(.9); }
.bowl-two { left: 120px; bottom: 34px; transform: scale(1.1); }
.bowl-three { right: 0; transform: scale(.76); }

@keyframes ripple {
  to { width: 130px; height: 36px; opacity: 0; }
}

.drip-chain {
  position: absolute;
  right: calc(11vw + 215px);
  top: 12vh;
  z-index: 6;
  display: flex;
  flex-direction: column;
  gap: 13px;
}

.drip-chain span {
  width: 17px;
  height: 17px;
  border-radius: 50%;
  border: 1px solid var(--brass-bell);
  background: radial-gradient(circle at 50% var(--fill, 92%), var(--rain-glass) 0 30%, transparent 31%), rgba(24,37,43,.72);
  animation: bead-fill 5s ease-in-out infinite;
}

.drip-chain span:nth-child(2) { animation-delay: .35s; }
.drip-chain span:nth-child(3) { animation-delay: .7s; }
.drip-chain span:nth-child(4) { animation-delay: 1.05s; }
.drip-chain span:nth-child(5) { animation-delay: 1.4s; }

@keyframes bead-fill { 50% { --fill: 45%; box-shadow: 0 0 18px rgba(159,198,195,.28); } }

.lantern {
  position: absolute;
  left: 52vw;
  top: 18vh;
  width: 58px;
  height: 92px;
  border-radius: 30px;
  background: radial-gradient(circle at 50% 55%, #f0c56b, var(--brass-bell) 52%, rgba(196,154,75,.2) 68%, transparent 70%);
  box-shadow: 0 0 70px rgba(196,154,75,.34);
  animation: lantern-flicker 3.2s ease-in-out infinite;
}

@keyframes lantern-flicker { 50% { opacity: .78; transform: translateY(2px); } }

.ledger-room {
  place-items: center;
  background-color: #172226;
}

.ledger-book {
  position: relative;
  z-index: 5;
  width: min(980px, 84vw);
  min-height: 560px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  color: var(--rain-ink);
  transform: rotate(.8deg);
  box-shadow: 0 32px 90px rgba(0,0,0,.48);
}

.page {
  padding: clamp(36px, 5vw, 72px);
  background:
    repeating-linear-gradient(0deg, transparent 0 37px, rgba(122,84,53,.13) 38px 39px),
    linear-gradient(120deg, var(--washi-cream), #dfd0b6);
}

.left-page { border-right: 1px solid rgba(122,84,53,.25); }
.page h2 { color: var(--rain-ink); text-shadow: none; }
.page p { color: rgba(24,37,43,.74); }
.page ul { padding: 0; margin: 40px 0 0; list-style: none; }
.page li { display: grid; grid-template-columns: 64px 1fr; gap: 20px; padding: 18px 0; border-bottom: 1px solid rgba(122,84,53,.23); font-family: var(--serif); }
.page b { font-family: var(--mono); color: var(--persimmon-seal); }

.sliding-shoji {
  position: absolute;
  inset: 0;
  z-index: 2;
  display: flex;
  pointer-events: none;
}

.sliding-shoji span {
  flex: 1;
  background: linear-gradient(90deg, rgba(244,234,216,.18), rgba(244,234,216,.04));
  border: 12px solid rgba(122,84,53,.38);
  transition: transform 1.2s ease;
}

.ledger-room.in-view .sliding-shoji span:first-child { transform: translateX(-82%); }
.ledger-room.in-view .sliding-shoji span:last-child { transform: translateX(82%); }

.brass-bells {
  position: absolute;
  top: 12vh;
  left: 12vw;
  display: flex;
  gap: 24px;
  z-index: 4;
}

.brass-bells i {
  width: 28px;
  height: 32px;
  border-radius: 50% 50% 8px 8px;
  background: var(--brass-bell);
  box-shadow: 0 0 22px rgba(196,154,75,.24);
  animation: bell-sway 4s ease-in-out infinite;
}
.brass-bells i:nth-child(2) { animation-delay: -1.3s; }
.brass-bells i:nth-child(3) { animation-delay: -2.4s; }
@keyframes bell-sway { 50% { transform: rotate(8deg); } }

.courtyard-room {
  min-height: 108vh;
  place-items: center;
  text-align: center;
  background:
    radial-gradient(circle at 50% 18%, rgba(159,198,195,.23), transparent 24rem),
    linear-gradient(180deg, #1b333b, #111b20 64%, #0c1215);
}

.open-sky {
  position: absolute;
  inset: 0 0 auto;
  height: 45vh;
  background:
    radial-gradient(circle at 42% 20%, rgba(244,234,216,.26), transparent 12rem),
    linear-gradient(180deg, #294f5b, transparent);
}

.courtyard-copy {
  position: relative;
  z-index: 5;
  width: min(720px, 82vw);
  padding: clamp(34px, 6vw, 66px);
}

.courtyard-copy h2 { color: var(--rain-ink); text-shadow: none; }
.courtyard-copy p { color: rgba(24,37,43,.72); }

.bell-link {
  display: inline-block;
  margin-top: 18px;
  padding: 12px 18px;
  color: var(--rain-ink);
  font-family: var(--serif);
  text-decoration: none;
  border: 1px solid var(--persimmon-seal);
  background: rgba(214,104,58,.08);
}

.courtyard-pool {
  position: absolute;
  left: 50%;
  bottom: 7vh;
  width: min(760px, 80vw);
  height: 170px;
  transform: translateX(-50%);
  border-radius: 50%;
  background: radial-gradient(ellipse at center, rgba(159,198,195,.32), rgba(31,77,99,.20) 52%, transparent 72%);
}

.courtyard-pool span {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 40px;
  height: 12px;
  border: 1px solid rgba(159,198,195,.72);
  border-radius: 50%;
  transform: translate(-50%, -50%);
  animation: courtyard-ripple 4.8s ease-out infinite;
}
.courtyard-pool span:nth-child(2) { animation-delay: -1.2s; }
.courtyard-pool span:nth-child(3) { animation-delay: -2.4s; }
.courtyard-pool span:nth-child(4) { animation-delay: -3.6s; }
@keyframes courtyard-ripple { to { width: 720px; height: 150px; opacity: 0; } }

.cloud-map {
  position: absolute;
  right: 11vw;
  top: 14vh;
  width: 230px;
  height: 160px;
  opacity: .38;
}
.cloud-map i {
  position: absolute;
  border: 1px solid var(--rain-glass);
  border-radius: 44% 56% 62% 38%;
}
.cloud-map i:nth-child(1) { inset: 8px 42px 62px 10px; }
.cloud-map i:nth-child(2) { inset: 54px 16px 24px 86px; }
.cloud-map i:nth-child(3) { inset: 80px 96px 10px 42px; }

.shop-room .room-copy,
.cedar-counter,
.umbrella-rack,
.rain-bowls,
.ledger-book,
.courtyard-copy {
  opacity: .35;
  transform: translateY(28px);
  transition: opacity 1.1s ease, transform 1.1s ease;
}

.shop-room.in-view .room-copy,
.shop-room.in-view .cedar-counter,
.shop-room.in-view .umbrella-rack,
.shop-room.in-view .rain-bowls,
.shop-room.in-view .ledger-book,
.shop-room.in-view .courtyard-copy {
  opacity: 1;
  transform: translateY(0);
}

@media (max-width: 820px) {
  .rain-chain { right: 10px; }
  .shop-room { padding: 86px 24px; }
  .right-copy { justify-self: start; }
  .shoji-window, .alcove-frame { opacity: .35; width: 70vw; right: -10vw; }
  .umbrella-rack { right: -40px; transform: scale(.72); transform-origin: bottom right; }
  .hanging-charms, .tag-field { display: none; }
  .cedar-counter { width: 82vw; left: 8vw; opacity: .55; }
  .rain-bowls { width: 75vw; right: 5vw; }
  .ledger-book { grid-template-columns: 1fr; width: 86vw; }
  .sliding-shoji { display: none; }
  .courtyard-pool { width: 94vw; }
}
