﻿@font-face {
  font-family: "Marck Script";
  src: url("fonts/MarckScript-Regular.ttf") format("truetype");
  font-style: normal;
  font-weight: 400;
  font-display: swap;
}

@font-face {
  font-family: "Bad Script";
  src: url("fonts/BadScript-Regular.ttf") format("truetype");
  font-style: normal;
  font-weight: 400;
  font-display: swap;
}

@font-face {
  font-family: "Great Vibes";
  src: url("fonts/GreatVibes-Regular.ttf") format("truetype");
  font-style: normal;
  font-weight: 400;
  font-display: swap;
}

:root {
  --bg-1: #f2eee5;
  --bg-2: #e7ddcc;
  --ink: #23201d;
  --muted: #5e584f;
  --paper: #fbf7ef;
  --frame: #201d1a;
  --accent: #8b5d2b;
  --line: #cdbca5;
  --mut-duration: 1000ms;
  --mut-jitter-x: 2.5px;
  --mut-jitter-y: 2px;
  --mut-blur: 6.2px;
  --mut-scale: 0.035;
  --photo-jitter-x: 1.2px;
  --photo-jitter-y: 0.9px;
  --photo-jitter-blur: 0.6px;
}

* {
  box-sizing: border-box;
}

body {
  margin: 0;
  min-height: 100vh;
  background-image:
    linear-gradient(rgba(242, 238, 229, 0.75), rgba(231, 221, 204, 0.75)),
    url("images/pattern/1f81af08-1ff3-475c-a3ce-d580d56ee21f.png");
  background-repeat: repeat, repeat;
  background-size: auto, auto;
  color: var(--ink);
  font-family: "Palatino Linotype", "Book Antiqua", Palatino, serif;
}

.intro-note {
  max-width: 1084px;
  width: min(1084px, calc(100% - 56px));
  margin: 20px auto 0;
  padding: 20px 20px 18px;
  color: #2f261e;
  font-size: 21px;
  font-weight: 600;
  line-height: 1.45;
  font-family: "Bad Script", "Marck Script", cursive;
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: 18px;
  box-shadow: 0 12px 36px rgba(31, 25, 18, 0.12);
}

.scene {
  max-width: 1140px;
  margin: 0 auto;
  padding: 28px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 22px;
}

.photo-card,
.text-card {
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: 18px;
  box-shadow: 0 12px 36px rgba(31, 25, 18, 0.12);
}

.photo-card {
  background-color: #ffffff;
  background-image: url("images/pattern/chatgpt-pattern-195616.png");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  padding: 12px;
  display: flex;
  align-items: center;
}

.photo-card .frame {
  width: 100%;
}

.frame {
  position: relative;
  min-height: 560px;
  border-radius: 12px;
  overflow: hidden;
  background: transparent;
  display: grid;
  place-items: center;
  --album-left: 20px;
  --album-top: 20px;
  --album-right: 20px;
  --album-bottom: 20px;
}

.frame img {
  grid-area: 1 / 1;
  width: auto;
  height: auto;
  max-width: calc(100% - 70px);
  max-height: calc(100% - 70px);
  opacity: 0;
  transition: opacity 4s ease;
  filter: sepia(0.24) contrast(1.02) saturate(0.92);
  border-radius: 14px;
  box-shadow: 0 3px 8px rgba(18, 12, 8, 0.38);
}

.frame img.show {
  opacity: 1;
}

.album-corners {
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.corner {
  position: absolute;
  width: 36px;
  height: 36px;
  background:
    repeating-linear-gradient(
      135deg,
      rgba(255, 255, 255, 0.08) 0px,
      rgba(255, 255, 255, 0.08) 1px,
      rgba(0, 0, 0, 0.03) 1px,
      rgba(0, 0, 0, 0.03) 2px
    ),
    linear-gradient(180deg, #c6a171, #aa8457);
  opacity: 1;
  border-radius: 4px;
  box-shadow: inset 0 1px 0 rgba(255, 245, 228, 0.32);
  filter: drop-shadow(0 0 1px rgba(18, 12, 8, 0.28)) drop-shadow(0 0 2px rgba(18, 12, 8, 0.18));
  z-index: 2;
}

.corner-shadow {
  display: none;
}

.corner-shadow.tl {
  left: var(--album-left);
  top: var(--album-top);
  clip-path: polygon(0 0, 100% 0, 0 100%);
}

.corner-shadow.tr {
  right: var(--album-right);
  top: var(--album-top);
  clip-path: polygon(0 0, 100% 0, 100% 100%);
}

.corner-shadow.bl {
  left: var(--album-left);
  bottom: var(--album-bottom);
  clip-path: polygon(0 0, 0 100%, 100% 100%);
}

.corner-shadow.br {
  right: var(--album-right);
  bottom: var(--album-bottom);
  clip-path: polygon(100% 0, 0 100%, 100% 100%);
}

.corner::before {
  content: none;
  position: absolute;
  inset: -2px;
  background: rgba(18, 12, 8, 0.55);
  filter: blur(1.4px);
  border-radius: 6px;
  z-index: -1;
}

.corner.tl {
  left: var(--album-left);
  top: var(--album-top);
  clip-path: polygon(0 0, 100% 0, 0 100%);
}

.corner.tl::before {
  clip-path: none;
}

.corner.tr {
  right: var(--album-right);
  top: var(--album-top);
  clip-path: polygon(0 0, 100% 0, 100% 100%);
}

.corner.tr::before {
  clip-path: none;
}

.corner.bl {
  left: var(--album-left);
  bottom: var(--album-bottom);
  clip-path: polygon(0 0, 0 100%, 100% 100%);
}

.corner.bl::before {
  clip-path: none;
}

.corner.br {
  right: var(--album-right);
  bottom: var(--album-bottom);
  clip-path: polygon(100% 0, 0 100%, 100% 100%);
}

.corner.br::before {
  clip-path: none;
}

.grain::after {
  display: none;
}

@keyframes dust {
  from { transform: translate3d(0, 0, 0); }
  to { transform: translate3d(-8%, 7%, 0); }
}

.stamp {
  position: absolute;
  right: 16px;
  bottom: 16px;
  padding: 7px 10px;
  border: 1px solid rgba(238, 182, 124, 0.65);
  color: rgba(238, 182, 124, 0.9);
  font: 600 11px/1 "Trebuchet MS", sans-serif;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  transform: rotate(-4deg);
  background: rgba(36, 24, 12, 0.28);
  backdrop-filter: blur(1px);
}

.text-card {
  padding: 20px 20px 18px;
  min-height: 860px;
  display: flex;
  flex-direction: column;
}

h1 {
  margin: 0 0 14px;
  font-size: clamp(24px, 3vw, 33px);
  line-height: 1.08;
  letter-spacing: 0.01em;
  font-family: "Book Antiqua", "Palatino Linotype", "Times New Roman", serif;
}

.quote {
  margin: 0;
  font-size: 18px;
  line-height: 1.56;
  color: #312b24;
  min-height: 560px;
  font-family: "Cormorant Garamond", Garamond, "Palatino Linotype", serif;
  letter-spacing: 0.01em;
  overflow-y: auto;
  overflow-x: hidden;
  scrollbar-gutter: stable;
}

.quote p {
  margin: 0 0 14px;
  text-wrap: pretty;
}

#quoteBody {
  margin-bottom: 26px;
}

.quote p[data-pidx="2"] {
  min-height: 2.6em;
  margin-bottom: 0;
}

.quote p:last-child {
  margin-bottom: 0;
}

.inscription {
  margin-top: 0;
  padding-top: 30px;
  padding-bottom: 18px;
  border-top: 1px solid #ccb89d;
  font-size: 30px;
  line-height: 1.2;
  letter-spacing: 0.01em;
  text-transform: none;
  font-family: "Great Vibes", "Marck Script", "Bad Script", cursive;
  color: #66635f;
  opacity: 0.88;
  transform: rotate(-2.4deg);
  transform-origin: left center;
  text-shadow:
    0.3px 0.3px 0 rgba(50, 50, 50, 0.28),
    -0.2px 0.2px 0 rgba(70, 70, 70, 0.2),
    0 0 0.6px rgba(40, 40, 40, 0.22);
  filter: grayscale(1) contrast(0.92);
  text-align: center;
}

.mutate-out,
.mutate-in {
  display: inline-block;
  will-change: transform, filter, opacity;
}

.mutate-out {
  animation: mutateOut var(--mut-duration) linear forwards;
}

.mutate-in {
  animation: mutateIn var(--mut-duration) linear forwards;
}

@keyframes mutateOut {
  0% {
    transform: translate(0, 0);
    filter: blur(0px);
    opacity: 1;
  }
  40% {
    transform: translate(calc(var(--mut-jitter-x) * 0.2), calc(var(--mut-jitter-y) * -0.25));
    filter: blur(calc(var(--mut-blur) * 0.13));
    opacity: 0.98;
  }
  62% {
    transform: translate(calc(var(--mut-jitter-x) * -0.4), calc(var(--mut-jitter-y) * 0.5));
    filter: blur(calc(var(--mut-blur) * 0.29));
    opacity: 0.95;
  }
  76% {
    transform: translate(calc(var(--mut-jitter-x) * 0.4), calc(var(--mut-jitter-y) * 0.25));
    filter: blur(calc(var(--mut-blur) * 0.45));
    opacity: 0.9;
  }
  86% {
    transform: translate(calc(var(--mut-jitter-x) * -0.6), calc(var(--mut-jitter-y) * -0.5));
    filter: blur(calc(var(--mut-blur) * 0.61));
    opacity: 0.84;
  }
  93% {
    transform: translate(calc(var(--mut-jitter-x) * 0.8), calc(var(--mut-jitter-y) * 0.75));
    filter: blur(calc(var(--mut-blur) * 0.77));
    opacity: 0.76;
  }
  97% {
    transform: translate(calc(var(--mut-jitter-x) * -0.8), calc(var(--mut-jitter-y) * 0.5));
    filter: blur(calc(var(--mut-blur) * 0.9));
    opacity: 0.68;
  }
  100% {
    transform: translate(var(--mut-jitter-x), calc(var(--mut-jitter-y) * -1));
    filter: blur(var(--mut-blur));
    opacity: 0.62;
  }
}

@keyframes mutateIn {
  0% {
    transform: translate(var(--mut-jitter-x), calc(var(--mut-jitter-y) * -1));
    filter: blur(var(--mut-blur));
    opacity: 0.62;
  }
  3% {
    transform: translate(calc(var(--mut-jitter-x) * -0.8), calc(var(--mut-jitter-y) * 0.5));
    filter: blur(calc(var(--mut-blur) * 0.9));
    opacity: 0.68;
  }
  8% {
    transform: translate(calc(var(--mut-jitter-x) * 0.8), calc(var(--mut-jitter-y) * 0.75));
    filter: blur(calc(var(--mut-blur) * 0.77));
    opacity: 0.76;
  }
  16% {
    transform: translate(calc(var(--mut-jitter-x) * -0.6), calc(var(--mut-jitter-y) * -0.5));
    filter: blur(calc(var(--mut-blur) * 0.61));
    opacity: 0.84;
  }
  28% {
    transform: translate(calc(var(--mut-jitter-x) * 0.4), calc(var(--mut-jitter-y) * 0.25));
    filter: blur(calc(var(--mut-blur) * 0.45));
    opacity: 0.9;
  }
  44% {
    transform: translate(calc(var(--mut-jitter-x) * -0.4), calc(var(--mut-jitter-y) * 0.5));
    filter: blur(calc(var(--mut-blur) * 0.29));
    opacity: 0.95;
  }
  64% {
    transform: translate(calc(var(--mut-jitter-x) * 0.2), calc(var(--mut-jitter-y) * -0.25));
    filter: blur(calc(var(--mut-blur) * 0.13));
    opacity: 0.98;
  }
  100% {
    transform: translate(0, 0);
    filter: blur(0px);
    opacity: 1;
  }
}

.buy-btn {
  margin-top: auto;
  width: 100%;
  border: 1px solid #7a4d24;
  border-radius: 11px;
  padding: 12px 14px;
  background: linear-gradient(180deg, #99602c, #7f4d21);
  color: #fff6e7;
  font: 600 16px/1.2 "Trebuchet MS", sans-serif;
  letter-spacing: 0.02em;
  cursor: pointer;
  transition: transform 0.14s ease, box-shadow 0.14s ease, filter 0.14s ease;
}

.buy-btn:hover {
  transform: translateY(-1px);
  box-shadow: 0 8px 18px rgba(98, 58, 24, 0.28);
  filter: brightness(1.03);
}

.buy-btn:active {
  transform: translateY(0);
}

.buy-note {
  margin: 10px 2px 0;
  min-height: 20px;
  color: #6a6359;
  font-size: 13px;
}

.modal {
  position: fixed;
  inset: 0;
  display: none;
  z-index: 80;
}

.modal.open {
  display: block;
}

.modal-overlay {
  position: absolute;
  inset: 0;
  background: rgba(23, 18, 12, 0.45);
  backdrop-filter: blur(2px);
}

.modal-card {
  position: relative;
  max-width: 760px;
  max-height: calc(100vh - 40px);
  margin: 20px auto;
  padding: 20px 20px 18px;
  background: #fffdf8;
  border: 1px solid #d6c3a8;
  border-radius: 16px;
  box-shadow: 0 24px 48px rgba(38, 27, 15, 0.28);
  overflow: auto;
}

.modal-close {
  position: absolute;
  top: 10px;
  right: 10px;
  width: 34px;
  height: 34px;
  border: 1px solid #bea27f;
  border-radius: 50%;
  background: #fff;
  color: #5f4f3c;
  font-size: 22px;
  line-height: 1;
  cursor: pointer;
}

.modal-card h2 {
  margin: 0 32px 8px 0;
  font-size: 22px;
  line-height: 1.12;
}

.modal-subtitle {
  margin: 0 0 16px;
  color: #5e584f;
  font-size: 15px;
  line-height: 1.4;
}

.checkout-form {
  display: grid;
  gap: 12px;
}

.field {
  display: grid;
  gap: 6px;
  font-size: 14px;
  color: #3c342a;
}

.field-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}

.field input,
.field textarea {
  width: 100%;
  border: 1px solid #cdb89b;
  border-radius: 10px;
  padding: 10px 12px;
  background: #fff;
  color: #2f2a24;
  font: 400 15px/1.3 "Book Antiqua", "Palatino Linotype", serif;
}

.field textarea {
  resize: vertical;
  min-height: 90px;
}

.pay-btn {
  margin-top: 6px;
  width: 100%;
  border: 1px solid #6f431c;
  border-radius: 11px;
  padding: 12px 14px;
  background: linear-gradient(180deg, #97602f, #7d4a1f);
  color: #fff7e8;
  font: 400 12px/1.35 "Trebuchet MS", sans-serif;
  letter-spacing: 0;
  cursor: pointer;
}

.owner-opt {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  color: #3c342a;
  font-size: 14px;
}

.owner-opt input {
  margin-top: 2px;
}

.owner-opt-note {
  margin: -4px 0 4px 28px;
  color: #6a6156;
  font-size: 13px;
  line-height: 1.35;
}

.owners-gallery {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 12px;
}

.owner-card {
  border: 1px solid #d8c7af;
  border-radius: 12px;
  background: #fffdf8;
  overflow: hidden;
  box-shadow: 0 8px 22px rgba(46, 32, 18, 0.12);
}

.owner-card img {
  display: block;
  width: 100%;
  aspect-ratio: 5 / 7;
  object-fit: cover;
}

.owner-card-meta {
  padding: 9px 10px 10px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.owner-initials {
  font-weight: 700;
  letter-spacing: 0.06em;
  color: #3c342b;
}

.owner-time {
  font-size: 12px;
  color: #786d5f;
}

.owners-empty {
  border: 1px dashed #d3c2a8;
  border-radius: 12px;
  padding: 14px 12px;
  color: #685e50;
  font-size: 14px;
  background: rgba(255, 252, 246, 0.7);
}

.owner-page {
  max-width: 1140px;
  margin: 0 auto;
  padding: 24px 28px 34px;
  display: grid;
  gap: 16px;
}

.owner-header-card,
.owner-gallery-card {
  background: #fffdf8;
  border: 1px solid #d8c7af;
  border-radius: 14px;
  padding: 16px;
  box-shadow: 0 8px 24px rgba(46, 32, 18, 0.1);
}

.owner-header-card h1 {
  margin: 0 0 8px;
  font-size: 32px;
}

.owner-meta {
  margin: 0;
  color: #5e5448;
  font-size: 14px;
}

.owner-gallery-card h2 {
  margin: 0 0 12px;
  font-size: 22px;
}

@media (max-width: 920px) {
  .intro-note {
    width: calc(100% - 32px);
  }

  .scene {
    grid-template-columns: 1fr;
    padding: 16px;
  }

  .frame {
    min-height: 430px;
  }

  .field-row {
    grid-template-columns: 1fr;
  }

  .modal-card {
    margin: 10px;
    max-height: calc(100vh - 20px);
  }

  .owner-page {
    padding: 0 16px;
  }
}

