*{
  box-sizing:border-box;
}

html, body{
  width:100%;
  height:100%;
}

body{
  margin:0;
  min-height:100vh;
  min-height:100dvh;
  overflow:hidden;

  font-family:'Cormorant Garamond', serif;

  background:
    url("background.png") center top / cover no-repeat fixed;

  color:white;

  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}

/* overlay */
.background-overlay{
  position:fixed;
  inset:0;
  background:linear-gradient(rgba(0,0,0,.45), rgba(0,0,0,.45));
  z-index:0;
}

/* main layout */
.page{
  position:relative;
  z-index:2;

  width:100%;
  height:100vh;
  height:100dvh;

  display:flex;
  justify-content:center;
  align-items:center;

  gap:clamp(8px, 2vw, 40px);

  overflow:hidden;
}

/* fade */
.fade-in{
  opacity:0;
  animation:fadeIn 3s ease forwards;
}

@keyframes fadeIn{
  to{ opacity:1; }
}

/* =========================
   PHOTO COLUMNS (FLUID)
========================= */

.scroll{
  width:clamp(55px, 7vw, 140px);
  height:100vh;
  height:100dvh;

  overflow:hidden;
  position:relative;

  transform:translateZ(0);
  will-change:transform;
}

.track{
  display:flex;
  flex-direction:column;

  gap:0;

  animation:photoScroll 28s linear infinite;

  will-change:transform;
  transform:translate3d(0,0,0);
}

.reverse{
  animation-direction:reverse;
}

@keyframes photoScroll{
  from{ transform:translate3d(0,0,0); }
  to{ transform:translate3d(0,-50%,0); }
}

.scroll img{
  width:100%;
  height:auto;

  aspect-ratio:3/4;
  object-fit:cover;

  border-radius:clamp(8px, 1vw, 16px);

  display:block;

  box-shadow:0 8px 18px rgba(0,0,0,.35);
}

/* =========================
   CENTER (MAIN FIX)
========================= */

.center{
  position:relative;

  width:clamp(240px, 32vw, 460px);
  height:100vh;
  height:100dvh;

  display:flex;
  justify-content:center;
  align-items:center;

  flex-shrink:0;
}

/* =========================
   CREST + TEXT (UPDATED FIX)
========================= */

.family-seal{
  position:absolute;
  z-index:20;
  text-align:center;
  cursor:pointer;

  transition:opacity 0.6s ease, transform 0.6s ease;
}

.family-seal.hide{
  opacity:0;
  transform:scale(.7);
  pointer-events:none;
}

.family-seal.remove{
  display:none;
}

.family-seal img{
  width:clamp(260px, 38vw, 650px);
  max-width:95vw;

  display:block;
  margin:0 auto -1.2rem auto;

  filter:drop-shadow(0 15px 30px rgba(0,0,0,.45));
}

/* =========================
   TEXT OVERLAY
========================= */

.announcement{
  margin-top:clamp(-16px, -1vw, -6px);
  text-align:center;

  color:#f5e6a8;
  text-shadow:0 2px 10px rgba(0,0,0,.45);
}

.line1{
  font-size:clamp(18px, 2.2vw, 34px);
  margin-bottom:clamp(2px, .5vw, 6px);
}

.line2{
  font-size:clamp(22px, 2.8vw, 44px);
  font-weight:600;
}

.line2 span{
  letter-spacing:clamp(2px, .4vw, 4px);
}

.tap-note{
  margin-top:clamp(6px, 1vw, 14px);
  font-size:clamp(11px, 1.4vw, 18px);
  letter-spacing:clamp(1px, .3vw, 3px);

  animation:pulse 2.2s infinite;
}

@keyframes pulse{
  0%{opacity:.4;}
  50%{opacity:1;}
  100%{opacity:.4;}
}

/* =========================
   SCROLL (UPDATED FASTER OPEN)
========================= */

.scroll-wrapper{
  position:absolute;
  left:50%;
  top:50%;

  width:clamp(220px, 28vw, 360px);

  opacity:0;
  z-index:5;

  transform:
    translate(-50%, -50%)
    scale(.45)
    rotate(-10deg);

  transition:transform 0.7s cubic-bezier(.22,1,.36,1), opacity 0.6s ease;
}

.scroll-wrapper.show{
  opacity:1;
  transform:
    translate(-50%, -50%)
    scale(1)
    rotate(0deg);
}

.scroll-body{
  max-height:0;
  overflow:hidden;

  transition:max-height 0.6s ease;

  background:
    radial-gradient(circle at 20% 30%, rgba(0,0,0,.06), transparent 60%),
    radial-gradient(circle at 80% 70%, rgba(0,0,0,.04), transparent 60%),
    linear-gradient(#f7e8c8,#e5d4a9);

  box-shadow:0 20px 40px rgba(0,0,0,.35);

  color:#3d2b16;
}

.scroll-wrapper.open .scroll-body{
  max-height:1200px;
}

.roll{
  height:clamp(18px, 2vw, 30px);
  border-radius:50%;

  background:linear-gradient(#d4c19a,#aa956d);
  box-shadow:inset 0 4px 10px rgba(0,0,0,.25);
}

/* =========================
   CONTENT
========================= */

.content{
  padding:clamp(18px, 3vw, 34px);
  text-align:center;
}

.content h2{
  font-size:clamp(16px, 2vw, 24px);
}

.gold-text{
  font-family:'Allura';

  font-size:clamp(28px, 4vw, 54px);

  margin:clamp(8px, 1.5vw, 14px) 0;

  background:
    linear-gradient(120deg,#8f6b1c,#f7e7a6,#d4af37,#fff7cc,#b58a2f);

  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;

  -webkit-text-stroke:.5px rgba(0,0,0,.45);

  text-shadow:0 2px 8px rgba(0,0,0,.25);
}

.content p{
  font-size:clamp(13px, 1.6vw, 18px);
  line-height:1.6;
}

.hashtag{
  font-size:clamp(18px, 2vw, 24px);
  color:#8f6b1c;
}

button{
  margin-top:16px;

  padding:clamp(10px, 1.5vw, 12px) clamp(16px, 2vw, 24px);

  border-radius:30px;
  border:1px solid #a67c00;

  background:transparent;
  color:#8f6b1c;

  font-size:clamp(13px, 1.5vw, 16px);

  cursor:pointer;
}

/* =========================
   MODAL
========================= */

.modal{
  position:fixed;
  inset:0;

  background:rgba(0,0,0,.65);

  display:flex;
  justify-content:center;
  align-items:center;

  opacity:0;
  pointer-events:none;

  transition:.4s ease;

  z-index:100;
}

.modal.show{
  opacity:1;
  pointer-events:auto;
}

.modal-content{
  width:90%;
  max-width:360px;

  background:linear-gradient(#f7e8c8,#e5d4a9);
  color:#3d2b16;

  padding:30px;
  border-radius:18px;

  text-align:center;
}

input, select{
  width:100%;
  margin-top:16px;

  padding:12px;

  border-radius:10px;
  border:1px solid rgba(0,0,0,.2);
}