:root {
  --parchment: #FFF8E8;
  --honey: #D9A441;
  --beeswax: #F2DCA8;
  --walnut: #4B3522;
  --pewter: #7D7467;
  --seafoam: #A9CBBE;
  --blush: #E7B9A9;
  --prism: #C7D8F3;
  --ink: #211B16;
  --display: "Limelight", "Cormorant Garamond", Georgia, serif;
  --body: "Nunito Sans", Inter, system-ui, sans-serif;
  --scripture: "Cormorant Garamond", Georgia, serif;
}

* { box-sizing: border-box; }

html {
  min-height: 100%;
  scroll-behavior: smooth;
  background: var(--ink);
}

body {
  margin: 0;
  min-height: 100%;
  font-family: var(--body);
  color: var(--walnut);
  background: var(--parchment);
  overflow-x: hidden;
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: 30;
  pointer-events: none;
  opacity: .22;
  background-image:
    linear-gradient(102deg, transparent 0 21%, rgba(75, 53, 34, .08) 21.3% 21.6%, transparent 22%),
    linear-gradient(14deg, rgba(255,255,255,.22), transparent 38%),
    radial-gradient(circle at 15% 20%, rgba(242, 220, 168, .5), transparent 20%),
    repeating-linear-gradient(0deg, rgba(75,53,34,.025) 0 1px, transparent 1px 6px);
  mix-blend-mode: multiply;
}

.ambient-light {
  position: fixed;
  inset: -20%;
  z-index: 1;
  pointer-events: none;
  background:
    radial-gradient(circle at var(--mx, 18%) var(--my, 18%), rgba(255,248,232,.95), transparent 18rem),
    radial-gradient(circle at 76% 26%, rgba(199,216,243,.38), transparent 22rem),
    linear-gradient(116deg, rgba(217,164,65,.26), rgba(169,203,190,.12), rgba(231,185,169,.24));
  filter: blur(8px) saturate(1.05);
  transition: background-position .5s ease;
}

#processional { position: relative; z-index: 2; }

.chapel {
  position: relative;
  min-height: 100vh;
  overflow: hidden;
  isolation: isolate;
  display: grid;
  place-items: center;
  padding: clamp(2rem, 6vw, 7rem);
  background:
    linear-gradient(122deg, rgba(255,248,232,.98), rgba(242,220,168,.78) 44%, rgba(199,216,243,.30)),
    var(--parchment);
}

.chapel + .chapel { margin-top: -8vh; }

.chapel::before,
.chapel::after {
  content: "";
  position: absolute;
  pointer-events: none;
  z-index: -1;
}

.chapel::before {
  inset: 4vh -8vw auto auto;
  width: 58vw;
  height: 72vh;
  background:
    linear-gradient(65deg, transparent 0 26%, rgba(217,164,65,.34) 26.2% 27%, transparent 27.3%),
    linear-gradient(112deg, transparent 0 44%, rgba(169,203,190,.28) 44.2% 45.5%, transparent 45.8%),
    radial-gradient(circle at 54% 42%, rgba(255,248,232,.55), transparent 24%);
  clip-path: polygon(20% 0, 100% 8%, 82% 100%, 0 70%);
  border: 1px solid rgba(217,164,65,.28);
  transform: rotate(-6deg);
}

.chapel::after {
  left: -6vw;
  right: -6vw;
  bottom: -7vh;
  height: 18vh;
  background:
    linear-gradient(177deg, transparent 10%, rgba(255,248,232,.72) 42%, rgba(231,185,169,.22) 100%);
  clip-path: polygon(0 28%, 12% 12%, 22% 32%, 36% 16%, 49% 36%, 64% 10%, 79% 28%, 100% 8%, 100% 100%, 0 100%);
}

.procession-marker {
  position: fixed;
  right: clamp(1rem, 2.4vw, 2rem);
  top: 50%;
  z-index: 40;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1.05rem;
  transform: translateY(-50%);
}

.marker-line {
  position: absolute;
  top: .4rem;
  bottom: .4rem;
  width: 1px;
  background: linear-gradient(var(--honey), var(--seafoam), var(--blush));
  opacity: .65;
}

.marker {
  width: 1.15rem;
  height: 1.15rem;
  border: 1px solid rgba(75,53,34,.38);
  background: rgba(255,248,232,.52);
  transform: rotate(45deg);
  cursor: pointer;
  padding: 0;
  transition: transform .35s ease, background .35s ease, border-color .35s ease;
  backdrop-filter: blur(6px);
}

.marker i {
  display: block;
  width: .35rem;
  height: .35rem;
  margin: .32rem;
  background: var(--honey);
  opacity: .55;
}

.marker.active,
.marker:hover {
  background: rgba(217,164,65,.86);
  border-color: var(--walnut);
  transform: rotate(45deg) scale(1.18);
}

.marker.active i,
.marker:hover i { background: var(--parchment); opacity: 1; }

.threshold {
  min-height: 108vh;
  justify-items: start;
  background:
    radial-gradient(circle at 8% 88%, rgba(217,164,65,.35), transparent 23rem),
    linear-gradient(111deg, rgba(255,248,232,.92), rgba(242,220,168,.74) 42%, rgba(199,216,243,.26) 84%),
    var(--parchment);
}

.paper-field {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(255,248,232,.7), transparent 55%),
    repeating-linear-gradient(93deg, rgba(75,53,34,.028) 0 2px, transparent 2px 13px),
    repeating-linear-gradient(2deg, rgba(217,164,65,.06) 0 1px, transparent 1px 9px);
}

.deco-arch {
  position: absolute;
  left: -18vw;
  bottom: -11vh;
  width: min(76vw, 760px);
  height: min(102vh, 860px);
  border: clamp(10px, 1.7vw, 22px) solid rgba(217,164,65,.58);
  border-right-color: rgba(75,53,34,.28);
  border-bottom: 0;
  border-radius: 48% 48% 0 0;
  box-shadow: inset 0 0 0 1px rgba(255,248,232,.8), inset 0 0 80px rgba(217,164,65,.18), 0 0 65px rgba(217,164,65,.23);
  transform: rotate(-4deg);
}

.deco-arch span {
  position: absolute;
  inset: 9% 11% 0 11%;
  border: 1px solid rgba(75,53,34,.24);
  border-bottom: 0;
  border-radius: 48% 48% 0 0;
}

.sunburst {
  position: absolute;
  left: 5vw;
  bottom: 5vh;
  width: min(55vw, 600px);
  height: min(48vh, 420px);
  transform-origin: 0 100%;
}

.sunburst b {
  position: absolute;
  left: 0;
  bottom: 0;
  width: 1px;
  height: 100%;
  background: linear-gradient(to top, rgba(217,164,65,.85), rgba(217,164,65,0));
  transform-origin: bottom;
}
.sunburst b:nth-child(1) { transform: rotate(-66deg); }
.sunburst b:nth-child(2) { transform: rotate(-44deg); }
.sunburst b:nth-child(3) { transform: rotate(-24deg); }
.sunburst b:nth-child(4) { transform: rotate(-5deg); }
.sunburst b:nth-child(5) { transform: rotate(16deg); }
.sunburst b:nth-child(6) { transform: rotate(37deg); }
.sunburst b:nth-child(7) { transform: rotate(58deg); }

.ray-grid, .ray-cross {
  position: absolute;
  inset: -20%;
  background:
    linear-gradient(28deg, transparent 0 48%, rgba(199,216,243,.38) 48.1% 48.5%, transparent 48.8%),
    linear-gradient(143deg, transparent 0 54%, rgba(169,203,190,.34) 54.1% 54.55%, transparent 54.8%),
    linear-gradient(70deg, transparent 0 62%, rgba(217,164,65,.22) 62.1% 62.35%, transparent 62.7%);
  animation: breatheRays 12s ease-in-out infinite alternate;
}

@keyframes breatheRays {
  from { transform: translate3d(-1%, 0, 0) rotate(-1deg); opacity: .68; }
  to { transform: translate3d(1.5%, -1%, 0) rotate(1deg); opacity: .92; }
}

.brass-plaque,
.final-plaque {
  position: absolute;
  left: clamp(2rem, 7vw, 7rem);
  bottom: clamp(2rem, 8vh, 6rem);
  font-family: var(--display);
  letter-spacing: .14em;
  color: var(--walnut);
  background: linear-gradient(92deg, rgba(217,164,65,.94), rgba(242,220,168,.9), rgba(217,164,65,.94));
  border: 1px solid rgba(75,53,34,.34);
  box-shadow: 0 12px 35px rgba(75,53,34,.16), inset 0 0 0 1px rgba(255,248,232,.62);
  padding: .78rem 1rem .68rem;
  font-size: clamp(1rem, 1.8vw, 1.65rem);
}

.shimmer { overflow: hidden; }
.shimmer::after {
  content: "";
  position: absolute;
  inset: -20% auto -20% -40%;
  width: 38%;
  background: linear-gradient(90deg, transparent, rgba(255,248,232,.82), transparent);
  transform: skewX(-18deg);
  animation: brassSweep 5.8s ease-in-out infinite;
}
@keyframes brassSweep { 0%, 45% { left: -40%; } 76%, 100% { left: 115%; } }

.scene-copy {
  position: relative;
  max-width: 36rem;
  z-index: 5;
}

.threshold-copy {
  margin-left: min(50vw, 620px);
  align-self: center;
  transform: translateY(-8vh);
}

.scene-copy h1,
.scene-copy h2 {
  margin: 0;
  font-family: var(--display);
  font-size: clamp(2.4rem, 7vw, 6.7rem);
  line-height: 1.05;
  letter-spacing: .075em;
  color: var(--walnut);
  text-shadow: 0 1px 0 rgba(255,248,232,.7);
}

.scene-copy p,
.vellum-slip p,
.vellum-slip span {
  font-size: clamp(1rem, 1.55vw, 1.28rem);
  line-height: 1.8;
}

.scene-copy p { margin: 1rem 0 0; max-width: 32rem; }

.vellum-slip {
  padding: clamp(1.1rem, 2vw, 1.7rem);
  background: rgba(255,248,232,.62);
  border: 1px solid rgba(217,164,65,.42);
  box-shadow: 0 20px 60px rgba(75,53,34,.13), inset 0 0 38px rgba(255,248,232,.46);
  backdrop-filter: blur(11px);
  transition: transform .45s ease, box-shadow .45s ease, background .45s ease;
}

.vellum-slip:hover,
.vellum-slip.lifted {
  transform: translateY(-7px) rotate(.35deg);
  background: rgba(255,248,232,.76);
  box-shadow: 0 30px 70px rgba(75,53,34,.2), inset 0 0 42px rgba(242,220,168,.5);
}

.vellum-slip em {
  display: block;
  margin-top: .9rem;
  font-family: var(--scripture);
  font-size: clamp(1.18rem, 2vw, 1.7rem);
  color: var(--pewter);
}

.hidden-prayer {
  max-height: 0;
  opacity: 0;
  overflow: hidden;
  transition: max-height .5s ease, opacity .5s ease;
}

.vellum-slip:hover .hidden-prayer,
.vellum-slip.lifted .hidden-prayer {
  max-height: 4rem;
  opacity: 1;
}

.bulletin-tab {
  display: inline-block;
  position: relative;
  margin-bottom: .85rem;
  padding: .28rem .55rem .22rem;
  font-family: var(--display);
  font-size: .75rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--walnut);
  background: rgba(217,164,65,.38);
  border: 1px solid rgba(75,53,34,.2);
  transform-origin: left center;
  transition: transform .35s ease, background .35s ease;
}

.scene-copy:hover .bulletin-tab,
.vellum-slip:hover .bulletin-tab { transform: scaleX(1.08); background: rgba(217,164,65,.58); }

.facet {
  position: absolute;
  z-index: 4;
  width: clamp(5rem, 12vw, 11rem);
  height: clamp(5rem, 12vw, 11rem);
  background: linear-gradient(135deg, rgba(199,216,243,.42), rgba(255,248,232,.22) 40%, rgba(169,203,190,.38));
  border: 1px solid rgba(255,248,232,.7);
  clip-path: polygon(50% 0, 100% 32%, 74% 100%, 18% 78%, 0 24%);
  box-shadow: inset 0 0 32px rgba(255,255,255,.45), 0 16px 40px rgba(75,53,34,.11);
  transition: transform .65s ease;
}
.facet:hover { transform: rotate(2deg) translateY(-4px); }
.cluster-one { top: 18vh; right: 13vw; }
.cluster-two { top: 53vh; right: 30vw; width: 7rem; height: 7rem; transform: rotate(22deg); }
.cluster-three { top: 14vh; left: 43vw; width: 4.8rem; height: 4.8rem; transform: rotate(-16deg); }

.gathering {
  place-items: start end;
  background:
    radial-gradient(circle at 25% 55%, rgba(169,203,190,.26), transparent 20rem),
    linear-gradient(108deg, rgba(242,220,168,.8), rgba(255,248,232,.95) 48%, rgba(231,185,169,.28));
}
.pew-shadow {
  position: absolute;
  inset: 18vh -8vw auto -8vw;
  height: 55vh;
  background: repeating-linear-gradient(102deg, rgba(75,53,34,.13) 0 2rem, transparent 2rem 4.7rem);
  filter: blur(1px);
  opacity: .35;
  transform: rotate(-5deg);
}
.hymn-page {
  position: absolute;
  left: 7vw;
  top: 17vh;
  width: min(33vw, 330px);
  min-height: 48vh;
  padding: 2rem;
  background: rgba(255,248,232,.58);
  border-left: 3px solid rgba(217,164,65,.48);
  box-shadow: 0 26px 70px rgba(75,53,34,.13);
  transform: rotate(-7deg);
  font-family: var(--scripture);
  color: rgba(75,53,34,.54);
}
.hymn-page span { display: block; margin: 1.4rem 0; font-size: clamp(1.5rem, 3vw, 2.4rem); font-style: italic; }
.olive-press { position: absolute; left: 26vw; bottom: 20vh; width: 14rem; height: 10rem; }
.olive-press i { position: absolute; width: 5.5rem; height: 1.8rem; background: rgba(169,203,190,.52); border: 1px solid rgba(75,53,34,.15); border-radius: 100% 0 100% 0; transform: rotate(var(--r, 26deg)); }
.olive-press i:nth-child(2) { --r: -18deg; left: 3.8rem; top: 2.1rem; background: rgba(169,203,190,.38); }
.olive-press i:nth-child(3) { --r: 46deg; left: 6rem; top: 5rem; }
.crystal-window {
  position: absolute;
  right: -6vw;
  top: 9vh;
  width: 42vw;
  height: 74vh;
  border: 1px solid rgba(217,164,65,.35);
  background:
    linear-gradient(45deg, transparent 48%, rgba(217,164,65,.32) 49% 50%, transparent 51%),
    linear-gradient(135deg, rgba(199,216,243,.34), transparent 40%, rgba(231,185,169,.28)),
    rgba(255,248,232,.18);
  clip-path: polygon(28% 0, 100% 6%, 92% 88%, 0 100%, 8% 24%);
}
.side-copy { margin: 17vh 8vw 0 0; text-align: left; }
.prayer-slip { position: absolute; left: 48vw; bottom: 12vh; width: min(29rem, 38vw); }
.prayer-slip strong, .table-slip strong { display: block; font-family: var(--display); letter-spacing: .12em; color: var(--honey); margin-bottom: .4rem; }

.word {
  background:
    radial-gradient(circle at 65% 38%, rgba(199,216,243,.42), transparent 20rem),
    linear-gradient(125deg, rgba(255,248,232,.98), rgba(169,203,190,.22) 54%, rgba(242,220,168,.76));
}
.glass-fan {
  position: absolute;
  top: -16vh;
  left: 10vw;
  width: 80vw;
  height: 80vw;
  border-radius: 50%;
  background: conic-gradient(from 210deg, rgba(217,164,65,.28), rgba(199,216,243,.32), transparent 16deg, rgba(169,203,190,.28) 36deg, transparent 42deg, rgba(231,185,169,.27) 70deg, transparent 86deg);
  clip-path: polygon(0 0, 100% 0, 68% 65%, 32% 65%);
  opacity: .75;
}
.scripture-card { position: absolute; top: 16vh; left: 11vw; width: min(31rem, 42vw); }
.scripture-card p { font-family: var(--scripture); font-size: clamp(2rem, 4.8vw, 5rem); font-style: italic; line-height: 1.02; margin: 0; color: var(--walnut); }
.ray-cross { opacity: .64; transform: rotate(4deg); }
.center-low { align-self: end; justify-self: end; margin: 0 8vw 10vh 0; }
.fragment {
  position: absolute;
  font-family: var(--scripture);
  font-style: italic;
  font-size: clamp(1.2rem, 2.5vw, 2rem);
  color: rgba(75,53,34,.52);
  padding: .4rem .8rem;
  border: 1px solid rgba(199,216,243,.55);
  background: rgba(255,248,232,.34);
  transition: transform .5s ease;
}
.fragment:hover { transform: rotate(2deg) translateY(-5px); }
.fragment-a { right: 19vw; top: 24vh; transform: rotate(8deg); }
.fragment-b { right: 12vw; top: 48vh; transform: rotate(-5deg); }
.fragment-c { left: 38vw; bottom: 20vh; transform: rotate(3deg); }

.table {
  background:
    radial-gradient(circle at 48% 51%, rgba(217,164,65,.34), transparent 17rem),
    linear-gradient(116deg, rgba(75,53,34,.12), rgba(255,248,232,.95) 38%, rgba(231,185,169,.30));
}
.communion-halo {
  position: absolute;
  inset: auto auto 12vh 9vw;
  width: min(62vw, 660px);
  height: min(62vw, 660px);
  border-radius: 50%;
  background: radial-gradient(circle, transparent 0 26%, rgba(217,164,65,.18) 26.5% 28%, transparent 28.6% 42%, rgba(242,220,168,.38) 42.4% 44%, transparent 44.7%);
  border: 1px solid rgba(217,164,65,.26);
}
.tray-rings { position: absolute; left: 13vw; bottom: 20vh; width: 33rem; height: 33rem; }
.tray-rings i { position: absolute; inset: var(--inset, 0); border: 2px solid rgba(217,164,65,.42); border-radius: 50%; box-shadow: inset 0 0 26px rgba(255,248,232,.38); }
.tray-rings i:nth-child(2) { --inset: 4.8rem; border-color: rgba(169,203,190,.38); }
.tray-rings i:nth-child(3) { --inset: 10rem; border-color: rgba(231,185,169,.38); }
.cup-collage {
  position: absolute;
  right: 11vw;
  top: 18vh;
  width: 17rem;
  height: 24rem;
  background:
    radial-gradient(ellipse at 50% 12%, rgba(199,216,243,.46) 0 26%, transparent 27%),
    linear-gradient(90deg, transparent 25%, rgba(75,53,34,.22) 26% 28%, transparent 29% 71%, rgba(75,53,34,.18) 72% 74%, transparent 75%),
    linear-gradient(rgba(255,248,232,.42), rgba(217,164,65,.28));
  border: 1px solid rgba(75,53,34,.16);
  clip-path: polygon(25% 0, 75% 0, 64% 100%, 36% 100%);
  opacity: .82;
}
.table-copy { justify-self: end; margin-right: 8vw; }
.table-slip { position: absolute; left: 11vw; top: 20vh; width: min(27rem, 35vw); transform: rotate(-2deg); }

.sending {
  min-height: 112vh;
  background:
    radial-gradient(circle at 72% 20%, rgba(242,220,168,.78), transparent 20rem),
    linear-gradient(128deg, rgba(255,248,232,.98), rgba(217,164,65,.34) 45%, rgba(169,203,190,.24));
}
.honey-sky {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(23deg, transparent 0 48%, rgba(217,164,65,.26) 48.1% 48.4%, transparent 48.8%),
    linear-gradient(156deg, transparent 0 58%, rgba(199,216,243,.32) 58.1% 58.5%, transparent 58.9%),
    radial-gradient(circle at 50% 84%, rgba(217,164,65,.28), transparent 20rem);
}
.folded-doves { position: absolute; right: 12vw; top: 17vh; width: 31vw; height: 42vh; }
.folded-doves i {
  position: absolute;
  width: 7rem;
  height: 4rem;
  background: linear-gradient(135deg, rgba(255,248,232,.72), rgba(199,216,243,.3));
  clip-path: polygon(0 50%, 46% 0, 100% 46%, 48% 38%, 36% 100%);
  border: 1px solid rgba(217,164,65,.28);
  transform: rotate(var(--rot, -10deg));
}
.folded-doves i:nth-child(2) { --rot: 16deg; left: 11rem; top: 5rem; opacity: .7; }
.folded-doves i:nth-child(3) { --rot: -28deg; left: 5rem; top: 14rem; opacity: .58; }
.deco-gate {
  position: absolute;
  left: -10vw;
  bottom: -12vh;
  width: 48vw;
  height: 58vh;
  border: 2px solid rgba(75,53,34,.18);
  border-bottom: 0;
  border-radius: 50% 50% 0 0;
  box-shadow: inset 0 0 0 18px rgba(217,164,65,.12), inset 0 0 0 28px rgba(255,248,232,.28);
}
.sending-copy { justify-self: start; margin-left: 8vw; }
.final-plaque { left: auto; right: clamp(2rem, 8vw, 8rem); bottom: clamp(2rem, 9vh, 7rem); }

.scene-active .scene-copy,
.scene-active .vellum-slip { animation: arriveSlip .9s ease both; }
@keyframes arriveSlip { from { opacity: .72; transform: translateY(16px); } to { opacity: 1; transform: translateY(0); } }

@media (max-width: 800px) {
  .chapel { min-height: 100vh; padding: 5rem 1.4rem; place-items: center start; }
  .chapel + .chapel { margin-top: -4vh; }
  .procession-marker { right: .55rem; gap: .8rem; }
  .marker { width: .9rem; height: .9rem; }
  .marker i { width: .25rem; height: .25rem; margin: .26rem; }
  .threshold-copy, .side-copy, .center-low, .table-copy, .sending-copy { margin: 0; transform: none; }
  .scene-copy h1, .scene-copy h2 { font-size: clamp(2.35rem, 13vw, 4.4rem); }
  .brass-plaque { left: 1.2rem; bottom: 1.3rem; }
  .deco-arch { width: 95vw; height: 70vh; left: -34vw; }
  .hymn-page, .scripture-card, .prayer-slip, .table-slip { position: relative; left: auto; right: auto; top: auto; bottom: auto; width: min(100%, 28rem); margin: 1rem 0; }
  .scripture-card p { font-size: clamp(2rem, 11vw, 3.4rem); }
  .crystal-window, .tray-rings, .folded-doves { opacity: .45; }
  .facet { opacity: .66; }
  .cup-collage { right: -3rem; opacity: .35; }
}
