/* =========================
   MOMENTS PAGE STYLES (page-specific)
   ========================= */

body.scroll-lock{ overflow:hidden; }

.moments-card{ padding: 26px; text-align: left; }

/* =========================
   GRID
   ========================= */
.gallery{
  display:grid;
  grid-template-columns:repeat(12, 1fr);
  gap:14px;
  padding:8px 2px 2px;
}

.tile{
  grid-column:span 4;
  border:0;
  background:transparent;
  padding:0;
  cursor:pointer;
  text-align:left;
  height:326px;

  opacity:0;
  transform:translateY(10px);
  transition:opacity 600ms ease, transform 600ms ease;
}
.tile.in{ opacity:1; transform:translateY(0); }

.tileInner{
  height:100%;
  border:1px solid var(--accent);
  border-radius:20px;
  background:rgba(255,255,255,0.10);
  box-shadow:0 18px 60px rgba(0,0,0,0.12);
  padding:12px;

  transform:rotateZ(var(--tilt, 0deg));
  transition:box-shadow 250ms ease, transform 250ms ease;
}
.tile:hover .tileInner{
  box-shadow:0 26px 80px rgba(0,0,0,0.16);
  transform:rotateZ(var(--tilt, 0deg)) translateY(-1px);
}

.polaroid-shell{
  border-radius:14px;
  background:rgba(255,255,255,0.88);
  position:relative;
  padding:14px 14px 54px;
  box-shadow:inset 0 0 0 1px rgba(0,0,0,0.05);
}

.polaroid-photo{
  height:210px;
  border-radius:10px;
  background:linear-gradient(135deg, rgba(0,0,0,0.32), rgba(0,0,0,0.12));
  border:1px solid rgba(0,0,0,0.08);
}

.polaroid-shell::after,
.polaroid-shell::before{
  content:"♥";
  position:absolute;
  color:rgba(140,25,25,0.45);
  opacity:.75;
  filter:blur(.2px);
}
.polaroid-shell::before{ left:14px; bottom:14px; transform:rotate(8deg); font-size:18px; opacity:.6; }
.polaroid-shell::after{ right:12px; top:10px; transform:rotate(-12deg); font-size:24px; opacity:.45; }

.front-meta{
  margin-top:10px;
  color:var(--text-soft);
  font-size:13px;
  letter-spacing:.06em;
  text-transform:lowercase;
  line-height:1.25;
  min-height:2.4em; /* keep for grid cards */
}

/* =========================
   OVERLAY + ANIM LAYER
   ========================= */
.overlay{
  position:fixed;
  inset:0;
  background:var(--overlay);
  opacity:0;
  pointer-events:none;
  transition:opacity 220ms ease;
  z-index:60;
}
.overlay.open{
  opacity:1;
  pointer-events:auto;
}

.animLayer{
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:70;
  perspective:1000px;
  -webkit-perspective:1000px;
}

/* =========================
   FLYING POLAROID
   ========================= */
.flyOuter{
  position:fixed;
  top:0;
  left:0;
  width:0;
  height:0;
  will-change:transform;
  pointer-events:none;
}

.flyScale{
  position:absolute;
  top:0;
  left:0;
  transform-origin:0 0;
  will-change:transform;
}

.flyFlip{
  position:absolute;
  inset:0;
  border-radius:22px;
  transform-style:preserve-3d;
  -webkit-transform-style:preserve-3d;
  transform-origin:center center;
  will-change:transform;
}

.flyFace{
  position:absolute;
  inset:0;
  border-radius:22px;
  border:1px solid var(--accent);
  background:var(--box-bg);
  box-shadow:0 30px 90px rgba(0,0,0,0.25);
  backface-visibility:hidden;
  -webkit-backface-visibility:hidden;
  overflow:hidden;
}

.flyFront{ padding:14px; }

.flyBack{
  transform:rotateY(180deg);
  padding:14px;
  display:flex;
  flex-direction:column;
  gap:10px; /* tighter */
}

/* tighter "opened" polaroid look (less white space) */
.flyFront .polaroid-shell{ padding:12px 12px 34px; }
.flyFront .polaroid-photo{ height:170px; }
.flyFront .front-meta{ min-height:unset; margin-top:8px; }

/* back image window stays horizontal */
.flyBack .frame{
  width:100%;
  aspect-ratio: 16 / 9;
  max-height:210px;
  border-radius:16px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,0.10);
  background:rgba(0,0,0,0.08);
}

.flyBack .frame img{
  width:100%;
  height:100%;
  object-fit:contain;
  display:block;
}

.flyBack .back-caption{
  margin-top:0;
  color:var(--text-soft);
  font-size:13px;
  letter-spacing:.06em;
  text-transform:lowercase;
  line-height:1.25;
}

/* make close button sit above content nicely */
.flyClose{
  position:absolute;
  top:12px;
  right:12px;
  z-index:2;
  pointer-events:auto;
}

/* =========================
   RESPONSIVE
   ========================= */
@media (max-width: 900px){
  .tile{ grid-column:span 6; height:316px; }
  .polaroid-photo{ height:200px; }
  .flyBack .frame{ max-height:200px; }
}

@media (max-width: 540px){
  .tile{ grid-column:span 12; height:338px; }
  .polaroid-photo{ height:220px; }

  /* give mobile opened view more usable image height */
  .flyFront .polaroid-photo{ height:185px; }
  .flyBack .frame{ max-height:240px; aspect-ratio: 16 / 9; }
}
