:root {
  --ivory: #fffaf2;
  --cream: #fbf3e9;
  --milk: #f7efe6;
  --paper: #fffdf8;
  --blush: #efb8bd;
  --blush-soft: #f7d7d7;
  --dusty-rose: #c7838d;
  --rose-dark: #8f5862;
  --sage: #aebc98;
  --sage-soft: #dfe6d5;
  --deep-sage: #536044;
  --olive: #323826;
  --champagne: #dbc49d;
  --champagne-soft: #f0dec0;
  --ink: #2c2a25;
  --muted: rgba(44, 42, 37, 0.72);
  --line: rgba(83, 96, 68, 0.20);
  --rose-line: rgba(199, 131, 141, 0.26);
  --shadow-soft: 0 24px 70px rgba(83, 72, 59, 0.10);
  --shadow-lift: 0 34px 96px rgba(83, 72, 59, 0.16);
  --shadow-flower: drop-shadow(0 20px 24px rgba(127, 83, 91, 0.13));
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  min-width: 320px;
  background:
    radial-gradient(circle at 11% 7%, rgba(239, 184, 189, 0.25), transparent 27rem),
    radial-gradient(circle at 92% 16%, rgba(219, 196, 157, 0.24), transparent 24rem),
    radial-gradient(circle at 46% 64%, rgba(174, 188, 152, 0.11), transparent 32rem),
    linear-gradient(180deg, #fffaf5 0%, #fbf2e9 42%, #f7eee5 100%);
  color: var(--ink);
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: -3;
  pointer-events: none;
  background-image:
    linear-gradient(rgba(83, 96, 68, 0.032) 1px, transparent 1px),
    linear-gradient(90deg, rgba(83, 96, 68, 0.025) 1px, transparent 1px);
  background-size: 58px 58px;
  mask-image: linear-gradient(180deg, rgba(0,0,0,0.45), transparent 72%);
}

body::after {
  content: "";
  position: fixed;
  inset: 0;
  z-index: -2;
  pointer-events: none;
  opacity: 0.36;
  background:
    radial-gradient(circle at 1px 1px, rgba(143, 88, 98, 0.10) 1px, transparent 0) 0 0 / 22px 22px;
  mix-blend-mode: multiply;
}

main {
  position: relative;
  isolation: isolate;
  overflow-x: clip;
}

main::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  background:
    linear-gradient(115deg, transparent 0 44%, rgba(255,255,255,0.28) 44% 45%, transparent 45% 100%),
    radial-gradient(circle at 50% 8%, rgba(255,255,255,0.48), transparent 28rem);
}

::selection {
  background: rgba(239, 184, 189, 0.58);
}

:focus-visible {
  outline: 3px solid rgba(199, 131, 141, 0.45);
  outline-offset: 4px;
  border-radius: 14px;
}

.font-display {
  font-family: Georgia, "Times New Roman", serif;
  letter-spacing: -0.045em;
}

.font-script {
  font-family: "Palatino Linotype", Palatino, Georgia, serif;
  font-style: italic;
}

.container-soft {
  width: min(1160px, calc(100% - clamp(28px, 5vw, 64px)));
  margin-inline: auto;
}

.section-pad {
  position: relative;
  padding-block: clamp(72px, 8.5vw, 136px);
  scroll-margin-top: 96px;
}

.site-nav {
  position: fixed;
  top: 16px;
  left: 0;
  right: 0;
  z-index: 50;
  padding-inline: 16px;
  pointer-events: none;
}

.site-nav__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  width: min(1060px, 100%);
  margin-inline: auto;
  padding: 10px 12px 10px 14px;
  border: 1px solid rgba(255, 255, 255, 0.84);
  border-radius: 999px;
  background:
    linear-gradient(180deg, rgba(255, 253, 248, 0.86), rgba(255, 250, 242, 0.68));
  box-shadow: 0 18px 64px rgba(83, 72, 59, 0.12);
  backdrop-filter: blur(20px);
  pointer-events: auto;
}

.site-nav__brand {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 58px;
  height: 42px;
  padding-inline: 14px;
  border-radius: 999px;
  background:
    linear-gradient(135deg, rgba(83,96,68,0.98), rgba(50,56,38,0.95));
  color: var(--ivory);
  font-family: Georgia, "Times New Roman", serif;
  font-size: 17px;
  line-height: 1;
  text-decoration: none;
  box-shadow: 0 14px 34px rgba(83, 96, 68, 0.25);
}

.site-nav__brand span:nth-child(2) {
  margin-inline: 4px;
  color: var(--blush-soft);
}

.site-nav__links {
  display: flex;
  align-items: center;
  gap: 4px;
}

.site-nav__links a {
  display: inline-flex;
  align-items: center;
  min-height: 40px;
  padding: 8px 14px;
  border-radius: 999px;
  color: rgba(50, 56, 38, 0.78);
  font-size: 14px;
  font-weight: 650;
  text-decoration: none;
  transition: background 180ms ease, color 180ms ease, transform 180ms ease;
}

.site-nav__links a:hover {
  color: var(--olive);
  background: rgba(239, 184, 189, 0.22);
  transform: translateY(-1px);
}

.hero-section {
  min-height: 100svh;
}

.hero-grid {
  min-height: calc(100svh - 160px);
}

.hero-copy {
  padding-block: 10px;
}

.hero-title {
  position: relative;
  font-size: clamp(4.4rem, 12vw, 10.4rem);
  text-wrap: balance;
  text-shadow: 0 14px 42px rgba(83, 72, 59, 0.08);
}

.hero-title::after {
  content: "";
  display: block;
  width: min(300px, 58vw);
  height: 16px;
  margin: 14px auto 0;
  border-radius: 999px;
  background: linear-gradient(90deg, transparent, rgba(239,184,189,0.54), rgba(219,196,157,0.38), transparent);
  filter: blur(4px);
}

.hero-date-medallion {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-top: 18px;
  padding: 9px 18px;
  border: 1px solid rgba(199, 131, 141, 0.28);
  border-radius: 999px;
  background: rgba(255, 253, 248, 0.72);
  color: rgba(83, 96, 68, 0.76);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  box-shadow: 0 16px 38px rgba(83, 72, 59, 0.07);
  backdrop-filter: blur(10px);
}

.hero-facts > div {
  position: relative;
  overflow: hidden;
  padding: 14px 16px;
  border: 1px solid rgba(83, 96, 68, 0.14);
  border-radius: 22px;
  background: rgba(255, 253, 248, 0.66);
  box-shadow: 0 16px 42px rgba(83, 72, 59, 0.07);
  backdrop-filter: blur(10px);
}

.hero-facts > div::after {
  content: "";
  position: absolute;
  right: -30px;
  top: -36px;
  width: 78px;
  height: 78px;
  border-radius: 999px;
  background: rgba(239,184,189,0.18);
}

.hero-facts span {
  display: block;
  margin-bottom: 4px;
  color: rgba(199, 131, 141, 0.96);
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.20em;
  text-transform: uppercase;
}

.hero-facts strong {
  display: block;
  color: var(--deep-sage);
  font-size: 14px;
  font-weight: 720;
}

.hero-photo-frame {
  padding: clamp(9px, 1.4vw, 15px);
  border: 1px solid rgba(255, 255, 255, 0.86);
  border-radius: clamp(42px, 5vw, 62px);
  background:
    linear-gradient(145deg, rgba(255,255,255,0.86), rgba(255,250,242,0.52)),
    rgba(255, 253, 248, 0.58);
  box-shadow: 0 34px 94px rgba(83, 72, 59, 0.16);
  transform: rotate(1.2deg);
}

.hero-photo-frame::before,
.hero-photo-frame::after {
  content: "";
  position: absolute;
  border-radius: 999px;
  pointer-events: none;
}

.hero-photo-frame::before {
  inset: -16px;
  border: 1px solid rgba(199, 131, 141, 0.18);
}

.hero-photo-frame::after {
  right: 30px;
  top: -11px;
  width: 62px;
  height: 62px;
  background: rgba(255, 253, 248, 0.76);
  box-shadow: inset 0 0 0 1px rgba(199, 131, 141, 0.22), 0 18px 40px rgba(83,72,59,0.09);
}

.save-date-card {
  box-shadow: 0 24px 74px rgba(83, 72, 59, 0.17);
  transform: rotate(-2deg);
}

.save-date-card::before {
  content: "";
  position: absolute;
  inset: 10px;
  border: 1px dashed rgba(199, 131, 141, 0.28);
  border-radius: 24px;
  pointer-events: none;
}

.save-date-card__top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 10px;
}

.save-date-card__top span {
  display: inline-grid;
  place-items: center;
  width: 32px;
  height: 32px;
  border-radius: 999px;
  background: rgba(239,184,189,0.28);
  color: var(--rose-dark);
  font-size: 15px;
}

.hero-photo-badge {
  position: absolute;
  right: 18px;
  bottom: 18px;
  z-index: 3;
  display: grid;
  gap: 3px;
  min-width: 122px;
  padding: 11px 14px;
  border: 1px solid rgba(255,255,255,0.72);
  border-radius: 22px;
  background: rgba(255, 253, 248, 0.76);
  box-shadow: 0 18px 44px rgba(83,72,59,0.11);
  backdrop-filter: blur(12px);
  text-align: center;
}

.hero-photo-badge span {
  color: var(--deep-sage);
  font-family: Georgia, "Times New Roman", serif;
  font-size: 24px;
  line-height: 1;
}

.hero-photo-badge small {
  color: rgba(199, 131, 141, 0.90);
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.glow-spot {
  position: absolute;
  border-radius: 999px;
  filter: blur(36px);
  pointer-events: none;
}

.glow-spot--rose {
  left: -12px;
  top: 36px;
  width: 132px;
  height: 132px;
  background: rgba(239,184,189,0.34);
}

.glow-spot--sage {
  right: -20px;
  bottom: 56px;
  width: 126px;
  height: 126px;
  background: rgba(219, 196, 157, 0.24);
}

.paper-card {
  position: relative;
  border: 1px solid rgba(199, 131, 141, 0.18);
  background:
    linear-gradient(180deg, rgba(255,255,255,0.90), rgba(255,251,246,0.80)),
    var(--paper);
  box-shadow: var(--shadow-soft);
  border-radius: 34px;
  backdrop-filter: blur(8px);
}

.section-card,
.timeline-card,
.rsvp-card {
  box-shadow: var(--shadow-lift);
}

.botanical-card {
  position: relative;
  overflow: hidden;
}

.botanical-card::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  border-radius: inherit;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,0.46);
}

.botanical-card::after {
  content: "";
  position: absolute;
  right: -120px;
  bottom: -120px;
  width: 290px;
  height: 290px;
  border-radius: 999px;
  background: radial-gradient(circle, rgba(239,184,189,0.18), transparent 68%);
  pointer-events: none;
}

.photo-placeholder {
  position: relative;
  overflow: hidden;
  min-height: 260px;
  background:
    radial-gradient(circle at 32% 22%, rgba(255,255,255,0.92), transparent 13rem),
    radial-gradient(circle at 78% 78%, rgba(219, 196, 157, 0.32), transparent 14rem),
    linear-gradient(135deg, rgba(239, 184, 189, 0.38), rgba(174, 188, 152, 0.22));
  border: 1px solid rgba(199, 131, 141, 0.20);
  box-shadow: 0 24px 66px rgba(83, 72, 59, 0.10);
}

.photo-placeholder::before {
  content: "";
  position: absolute;
  inset: 14px;
  border: 1px solid rgba(255, 253, 248, 0.70);
  border-radius: inherit;
  background:
    radial-gradient(circle at 78% 18%, rgba(255,255,255,0.46), transparent 10rem),
    linear-gradient(145deg, transparent 0 42%, rgba(255,255,255,0.22) 42% 56%, transparent 56% 100%);
  pointer-events: none;
}

.photo-placeholder::after {
  content: "Фото";
  position: absolute;
  left: 18px;
  bottom: 16px;
  z-index: 3;
  padding: 8px 14px;
  border: 1px solid rgba(255, 255, 255, 0.76);
  border-radius: 999px;
  background: rgba(255, 253, 248, 0.82);
  color: rgba(50, 56, 38, 0.72);
  font-size: 12px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  backdrop-filter: blur(10px);
}

.photo-placeholder--hero::after {
  content: "Ваше фото";
}

.photo-shine {
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
  background: linear-gradient(115deg, transparent 0 35%, rgba(255,255,255,0.26) 42%, transparent 54% 100%);
  transform: translateX(-55%);
  animation: photo-shimmer 5.4s ease-in-out infinite;
}

.photo-card {
  transition: transform 220ms ease, box-shadow 220ms ease, border-color 220ms ease;
}

.photo-card:hover {
  transform: translateY(-5px) rotate(-0.45deg);
  border-color: rgba(199, 131, 141, 0.30);
  box-shadow: 0 30px 86px rgba(83, 72, 59, 0.14);
}

.map-card::after {
  content: "Карта";
}

.floral-asset {
  position: absolute;
  pointer-events: none;
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  filter: saturate(1.04) contrast(1.02) var(--shadow-flower);
  z-index: 1;
}

.asset-peony-single {
  background-image: url('/decor/asset-peony-single.webp');
  width: clamp(165px, 18vw, 290px);
  aspect-ratio: 921 / 1141;
}

.asset-peony-cluster {
  background-image: url('/decor/asset-peony-cluster.webp');
  width: clamp(230px, 27vw, 430px);
  aspect-ratio: 1049 / 1117;
}

.asset-ranunculus {
  background-image: url('/decor/asset-ranunculus.webp');
  width: clamp(160px, 17vw, 270px);
  aspect-ratio: 1002 / 1053;
}

.asset-camellia {
  background-image: url('/decor/asset-camellia.webp');
  width: clamp(175px, 19vw, 305px);
  aspect-ratio: 1071 / 1109;
}

.asset-soft {
  opacity: 0.18;
}

.asset-medium {
  opacity: 0.25;
}

.asset-strong,
.asset-visible {
  opacity: 0.30;
}

.asset-hero {
  opacity: 0.34;
}

.asset-front {
  z-index: 4;
}

.asset-showcase {
  width: clamp(170px, 20vw, 318px);
  opacity: 0.48;
}

.asset-showcase-left {
  width: clamp(135px, 16vw, 235px);
  opacity: 0.38;
}

.section-divider {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  color: rgba(83, 96, 68, 0.58);
  font-size: 12px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.section-divider::before,
.section-divider::after {
  content: "";
  height: 1px;
  width: 42px;
  background: linear-gradient(90deg, transparent, rgba(201, 138, 151, 0.85), transparent);
}

.soft-button,
.ghost-button {
  text-decoration: none;
}

.soft-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  border: 0;
  border-radius: 999px;
  padding: 15px 24px;
  background:
    linear-gradient(135deg, rgba(83,96,68,0.98), rgba(50,56,38,0.96));
  color: #fffdf8;
  font-weight: 760;
  box-shadow: 0 18px 46px rgba(83, 96, 68, 0.30);
  cursor: pointer;
  transition: transform 180ms ease, box-shadow 180ms ease, background 180ms ease;
}

.soft-button:hover {
  transform: translateY(-2px);
  box-shadow: 0 22px 54px rgba(83, 96, 68, 0.38);
}

.ghost-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  padding: 14px 22px;
  color: var(--deep-sage);
  border: 1px solid rgba(83, 96, 68, 0.24);
  background: rgba(255,255,255,0.56);
  font-weight: 680;
  transition: transform 180ms ease, background 180ms ease, border-color 180ms ease;
}

.ghost-button:hover {
  transform: translateY(-2px);
  border-color: rgba(83, 96, 68, 0.38);
  background: rgba(255,255,255,0.86);
}

.kicker {
  color: var(--dusty-rose);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.24em;
  font-weight: 820;
}

.decor-line {
  height: 1px;
  width: 100%;
  background: linear-gradient(90deg, transparent, rgba(83, 96, 68, 0.30), transparent);
}

.detail-card {
  position: relative;
  overflow: hidden;
  transition: transform 220ms ease, box-shadow 220ms ease;
}

.detail-card::before {
  content: "";
  position: absolute;
  left: 20px;
  top: 20px;
  width: 30px;
  height: 30px;
  border-radius: 999px;
  background: rgba(239,184,189,0.18);
}

.detail-card::after {
  content: "";
  position: absolute;
  inset: auto 18px 0;
  height: 4px;
  border-radius: 999px 999px 0 0;
  background: linear-gradient(90deg, transparent, rgba(199,131,141,0.58), rgba(219,196,157,0.48), transparent);
  opacity: 0.72;
}

.detail-card:hover {
  transform: translateY(-6px);
  box-shadow: var(--shadow-lift);
}

.timeline-card {
  border-color: rgba(199, 131, 141, 0.20);
}

.timeline-dot {
  width: 18px;
  height: 18px;
  border: 5px solid var(--ivory);
  border-radius: 999px;
  background: var(--dusty-rose);
  box-shadow: 0 0 0 1px rgba(199, 131, 141, 0.48), 0 8px 20px rgba(199, 131, 141, 0.26);
}

.timeline-item {
  transition: transform 180ms ease;
}

.timeline-item:hover {
  transform: translateX(4px);
}

.palette-card {
  box-shadow: inset 0 0 0 1px rgba(255,255,255,0.46), 0 18px 46px rgba(83,72,59,0.07);
}

.swatch {
  box-shadow: inset 0 0 0 1px rgba(255,255,255,0.58), 0 12px 28px rgba(83,72,59,0.10);
}

.input-soft {
  width: 100%;
  border-radius: 20px;
  border: 1px solid rgba(83, 96, 68, 0.18);
  background: rgba(255, 253, 248, 0.84);
  padding: 14px 16px;
  outline: none;
  color: var(--ink);
  transition: border-color 160ms ease, box-shadow 160ms ease, background 160ms ease;
}

.input-soft:focus {
  border-color: rgba(83, 96, 68, 0.48);
  box-shadow: 0 0 0 4px rgba(174, 188, 152, 0.18);
  background: #fffdf8;
}

.input-soft::placeholder {
  color: rgba(44, 42, 37, 0.40);
}

.site-footer {
  padding: 46px 0 62px;
  text-align: center;
}

.petal-field {
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  overflow: hidden;
}

.petal-field span {
  position: absolute;
  width: 12px;
  height: 18px;
  border-radius: 999px 999px 999px 2px;
  background: linear-gradient(135deg, rgba(239,184,189,0.72), rgba(255,255,255,0.74));
  box-shadow: 0 8px 22px rgba(199, 131, 141, 0.12);
  opacity: 0.52;
  animation: petal-float 11s linear infinite;
}

.petal-field span:nth-child(1) { left: 12%; top: 16%; animation-delay: -1s; }
.petal-field span:nth-child(2) { left: 34%; top: 10%; animation-delay: -5s; transform: scale(.8) rotate(18deg); }
.petal-field span:nth-child(3) { left: 72%; top: 15%; animation-delay: -7s; transform: scale(1.1) rotate(-20deg); }
.petal-field span:nth-child(4) { left: 86%; top: 45%; animation-delay: -3s; transform: scale(.75) rotate(34deg); }
.petal-field span:nth-child(5) { left: 54%; top: 68%; animation-delay: -9s; transform: scale(.9) rotate(-8deg); }
.petal-field span:nth-child(6) { left: 18%; top: 76%; animation-delay: -4s; transform: scale(.72) rotate(42deg); }

.reveal {
  animation: reveal-up 760ms ease both;
}

@keyframes reveal-up {
  from {
    opacity: 0;
    transform: translateY(24px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes photo-shimmer {
  0%, 45% { transform: translateX(-58%); opacity: 0; }
  58% { opacity: 1; }
  72%, 100% { transform: translateX(58%); opacity: 0; }
}

@keyframes petal-float {
  0% { translate: 0 0; rotate: 0deg; }
  50% { translate: 18px 28px; rotate: 18deg; }
  100% { translate: -12px 58px; rotate: 42deg; }
}

@media (min-width: 1024px) {
  .gallery-feature > .photo-card:first-child,
  .gallery-grid > .photo-card:first-child {
    min-height: 470px;
  }

  .hero-title::after {
    margin-left: 0;
    margin-right: 0;
  }
}

@media (max-width: 900px) {
  .asset-soft { opacity: 0.13; }
  .asset-medium { opacity: 0.18; }
  .asset-strong,
  .asset-visible { opacity: 0.22; }
  .asset-hero { opacity: 0.25; }

  .container-soft {
    width: min(1120px, calc(100% - 24px));
  }

  .site-nav {
    top: 10px;
    padding-inline: 10px;
  }

  .site-nav__inner {
    overflow-x: auto;
    justify-content: flex-start;
    scrollbar-width: none;
  }

  .site-nav__inner::-webkit-scrollbar {
    display: none;
  }

  .site-nav__links {
    min-width: max-content;
  }

  .hero-section,
  .hero-grid {
    min-height: auto;
  }
}

@media (max-width: 640px) {
  body::before,
  body::after {
    opacity: 0.50;
  }

  .container-soft {
    width: min(100% - 22px, 1120px);
  }

  .section-pad {
    padding-block: 60px;
    scroll-margin-top: 86px;
  }

  .site-nav__inner {
    padding: 8px;
  }

  .site-nav__brand {
    min-width: 52px;
    height: 38px;
    padding-inline: 12px;
    font-size: 15px;
  }

  .site-nav__links a {
    min-height: 38px;
    padding: 8px 11px;
    font-size: 13px;
  }

  .hero-section {
    padding-top: 92px;
  }

  .hero-title {
    font-size: clamp(3.55rem, 18vw, 5.15rem);
    line-height: 0.82;
  }

  .hero-date-medallion {
    margin-top: 14px;
    padding: 8px 14px;
    font-size: 10px;
  }

  .hero-copy p:not(.kicker):not(.section-divider) {
    font-size: 16px;
    line-height: 1.7;
  }

  .hero-facts {
    grid-template-columns: 1fr;
  }

  .hero-facts > div {
    padding: 12px 14px;
  }

  .hero-photo-frame {
    border-radius: 42px;
    transform: none;
  }

  .hero-photo-frame::before,
  .hero-photo-frame::after {
    display: none;
  }

  .save-date-card {
    transform: none;
  }

  .glow-spot--sage {
    display: none;
  }

  .paper-card {
    border-radius: 28px;
  }

  .photo-placeholder {
    min-height: 220px;
  }

  .photo-placeholder::before {
    inset: 10px;
  }

  .photo-placeholder::after {
    left: 14px;
    bottom: 14px;
    font-size: 11px;
  }

  .hero-photo-badge {
    right: 14px;
    bottom: 14px;
    min-width: 106px;
    padding: 10px 12px;
  }

  .asset-soft { opacity: 0.10; }
  .asset-medium { opacity: 0.14; }
  .asset-strong,
  .asset-visible { opacity: 0.17; }
  .asset-hero { opacity: 0.20; }

  .asset-peony-cluster {
    width: clamp(172px, 42vw, 250px);
  }

  .asset-peony-single,
  .asset-ranunculus,
  .asset-camellia {
    width: clamp(128px, 32vw, 198px);
  }

  .section-divider::before,
  .section-divider::after {
    width: 28px;
  }

  .timeline-list::before {
    left: 8px;
  }

  .soft-button,
  .ghost-button {
    min-height: 52px;
  }

  .gallery-grid,
  .gallery-feature {
    gap: 14px;
  }

  .petal-field span {
    opacity: 0.30;
  }
}

@media (prefers-reduced-motion: reduce) {
  html {
    scroll-behavior: auto;
  }

  .reveal,
  .photo-shine,
  .petal-field span {
    animation: none;
  }

  .soft-button,
  .ghost-button,
  .photo-card,
  .detail-card,
  .timeline-item,
  .site-nav__links a {
    transition: none;
  }
}

/* Mobile navigation: one-line adaptive menu. */
@media (max-width: 640px) {
  .site-nav {
    padding-inline: clamp(5px, 2.1vw, 8px);
  }

  .site-nav__inner {
    width: min(100%, calc(100vw - clamp(10px, 4.2vw, 16px)));
    max-width: calc(100vw - clamp(10px, 4.2vw, 16px));
    gap: clamp(2px, 0.9vw, 4px);
    padding: clamp(4px, 1.55vw, 6px);
    overflow: hidden;
  }

  .site-nav__brand {
    width: clamp(34px, 10.5vw, 42px);
    min-width: clamp(34px, 10.5vw, 42px);
    height: clamp(30px, 8.2vw, 34px);
    padding-inline: 0;
    font-size: clamp(12px, 3.45vw, 14px);
    flex: 0 0 auto;
  }

  .site-nav__links {
    flex: 1 1 auto;
    min-width: 0;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: clamp(0px, 0.45vw, 2px);
    overflow-x: auto;
    overflow-y: hidden;
    white-space: nowrap;
    scrollbar-width: none;
    -webkit-overflow-scrolling: touch;
  }

  .site-nav__links::-webkit-scrollbar {
    display: none;
  }

  .site-nav__links a {
    flex: 0 1 auto;
    justify-content: center;
    min-height: clamp(30px, 8vw, 34px);
    padding-block: clamp(5px, 1.4vw, 7px);
    padding-inline: clamp(1.5px, 0.85vw, 5px);
    font-size: clamp(11.4px, 3.3vw, 13px);
    letter-spacing: -0.035em;
    line-height: 1.05;
    white-space: nowrap;
  }

  .hero-section {
    padding-top: 92px;
  }

  .section-pad {
    scroll-margin-top: 96px;
  }
}

/* Performance tuning */
.section-pad{content-visibility:auto;contain-intrinsic-size:900px}.hero-section{content-visibility:visible}.photo-real,.place-card,.paper-card{contain:layout paint}.floral-asset,.glow-spot{will-change:auto}@media(max-width:900px){html{scroll-behavior:auto}body:before,body:after,main:before{display:none}.site-nav__inner,.paper-card,.hero-facts>div,.hero-date-medallion,.hero-photo-badge,.photo-placeholder:after{backdrop-filter:none!important}.floral-asset{filter:none}.petal-field span{animation:none}}

/* v18 visual polish: no white photo mats, flowing decor, refined important section. */
body {
  background:
    radial-gradient(circle at 12% 8%, rgba(239, 184, 189, 0.20), transparent 28rem),
    radial-gradient(circle at 92% 18%, rgba(219, 196, 157, 0.18), transparent 26rem),
    radial-gradient(circle at 40% 72%, rgba(174, 188, 152, 0.11), transparent 32rem),
    linear-gradient(180deg, #fffaf5 0%, #fbf2e9 46%, #f8efe6 100%);
}

body::before,
body::after,
main::before {
  display: none !important;
  content: none !important;
}

/* Decorative flowers are section elements now: they scroll with the page and do not create sliced fixed backgrounds. */
.floral-asset {
  position: absolute;
  z-index: 0;
  opacity: 0.18;
  filter: none;
}

.section-pad > .container-soft,
.hero-section > .container-soft {
  position: relative;
  z-index: 2;
}

/* Memory gallery: the image itself defines the card height, so there are no white empty bands. */
#story .gallery-feature {
  align-items: start !important;
  overflow: visible !important;
}

#story .gallery-feature > .photo-real {
  display: block;
  align-self: start;
  height: auto !important;
  min-height: 0 !important;
  aspect-ratio: auto !important;
  overflow: hidden !important;
  background: transparent !important;
  border: 1px solid rgba(199, 131, 141, 0.18);
  box-shadow: 0 22px 60px rgba(83, 72, 59, 0.10);
}

#story .gallery-feature > .photo-real img {
  position: static !important;
  display: block;
  width: 100% !important;
  height: auto !important;
  max-width: 100%;
  max-height: none !important;
  background: transparent !important;
  object-fit: contain !important;
  object-position: center center;
}

@media (min-width: 1024px) {
  #story .gallery-feature {
    gap: clamp(18px, 2.15vw, 28px);
  }

  #story .gallery-feature > .photo-real:nth-child(1) {
    transform: rotate(-0.25deg);
  }

  #story .gallery-feature > .photo-real:nth-child(2) {
    transform: translateY(12px) rotate(0.25deg);
  }

  #story .gallery-feature > .photo-real:nth-child(3) {
    transform: translateY(-2px) rotate(0.35deg);
  }

  #story .gallery-feature > .photo-real:nth-child(4) {
    transform: translateY(-14px) rotate(-0.25deg);
  }

  #story .gallery-feature > .photo-real:nth-child(5) {
    transform: translateY(10px) rotate(0.2deg);
  }
}

/* Important: warmer cards without a flat white field. */
#important .format-grid {
  display: grid;
  grid-template-columns: repeat(12, minmax(0, 1fr));
  gap: clamp(18px, 2.4vw, 28px);
  align-items: start;
}

#important .format-mini-card {
  position: relative;
  grid-column: span 6;
  min-height: 0;
  overflow: hidden;
  padding: clamp(26px, 3vw, 38px);
  border: 1px solid rgba(199, 131, 141, 0.20);
  background:
    radial-gradient(circle at 18% 0%, rgba(239, 184, 189, 0.26), transparent 18rem),
    radial-gradient(circle at 100% 100%, rgba(174, 188, 152, 0.18), transparent 16rem),
    linear-gradient(145deg, rgba(251, 243, 233, 0.90), rgba(240, 222, 192, 0.38));
  box-shadow: 0 24px 70px rgba(83, 72, 59, 0.09);
  backdrop-filter: none !important;
}

#important .format-mini-card:nth-child(1) {
  grid-column: span 7;
}

#important .format-mini-card:nth-child(2) {
  grid-column: span 5;
  background:
    radial-gradient(circle at 100% 0%, rgba(174, 188, 152, 0.28), transparent 17rem),
    radial-gradient(circle at 0% 100%, rgba(239, 184, 189, 0.20), transparent 14rem),
    linear-gradient(145deg, rgba(247, 239, 230, 0.92), rgba(223, 230, 213, 0.36));
}

#important .format-mini-card:nth-child(3) {
  grid-column: span 5;
  background:
    radial-gradient(circle at 0% 100%, rgba(202, 217, 230, 0.32), transparent 16rem),
    linear-gradient(145deg, rgba(251, 243, 233, 0.90), rgba(247, 215, 215, 0.28));
}

#important .format-mini-card:nth-child(4) {
  grid-column: span 7;
  background:
    radial-gradient(circle at 100% 100%, rgba(239, 194, 170, 0.32), transparent 16rem),
    linear-gradient(145deg, rgba(251, 243, 233, 0.90), rgba(219, 196, 157, 0.34));
}

#important .format-mini-card::before {
  content: "";
  position: absolute;
  left: clamp(18px, 2vw, 26px);
  top: clamp(20px, 2.2vw, 28px);
  width: 34px;
  height: 2px;
  border-radius: 999px;
  background: rgba(199, 131, 141, 0.52);
}

#important .format-mini-card::after {
  content: "";
  position: absolute;
  right: -48px;
  bottom: -58px;
  width: 155px;
  height: 155px;
  border-radius: 999px;
  background: rgba(255, 253, 248, 0.34);
  box-shadow: inset 0 0 0 1px rgba(199, 131, 141, 0.12);
  pointer-events: none;
}

#important .format-mini-card .kicker {
  margin-top: 14px;
}

#important .format-mini-card p:not(.kicker) {
  color: rgba(44, 42, 37, 0.72);
  line-height: 1.85;
}

@media (max-width: 900px) {
  body {
    background:
      radial-gradient(circle at 0% 7%, rgba(239, 184, 189, 0.18), transparent 18rem),
      radial-gradient(circle at 100% 38%, rgba(174, 188, 152, 0.12), transparent 18rem),
      linear-gradient(180deg, #fffaf5 0%, #fbf2e9 54%, #f8efe6 100%) !important;
    background-attachment: scroll !important;
  }

  .section-pad {
    overflow: hidden;
    content-visibility: visible;
    contain-intrinsic-size: auto;
  }

  .floral-asset.asset-visible,
  .hero-section .floral-asset.asset-hero,
  .hero-section .floral-asset.asset-medium {
    display: block !important;
    opacity: 0.13;
    width: clamp(120px, 44vw, 210px);
    filter: none !important;
  }

  .floral-asset:not(.asset-visible):not(.asset-hero) {
    display: none !important;
  }

  #story .gallery-feature {
    gap: 16px;
  }

  #story .gallery-feature > .photo-real {
    transform: none !important;
  }

  #important .format-grid {
    grid-template-columns: 1fr;
  }

  #important .format-mini-card,
  #important .format-mini-card:nth-child(1),
  #important .format-mini-card:nth-child(2),
  #important .format-mini-card:nth-child(3),
  #important .format-mini-card:nth-child(4) {
    grid-column: 1 / -1;
  }
}
/* v19 final visual polish */
body{background:radial-gradient(circle at 8% 6%,rgba(239,184,189,.18),transparent 28rem),radial-gradient(circle at 92% 18%,rgba(219,196,157,.20),transparent 26rem),radial-gradient(circle at 22% 62%,rgba(174,188,152,.10),transparent 30rem),linear-gradient(180deg,#fffaf5 0%,#fbf2e9 46%,#f8efe6 100%)!important;background-attachment:scroll!important}body:before,body:after,main:before{display:none!important;content:none!important;background:none!important}.section-pad,.hero-section{background:transparent!important}.section-pad:before{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;background:radial-gradient(circle at 12% 12%,rgba(255,255,255,.34),transparent 20rem),radial-gradient(circle at 88% 82%,rgba(239,184,189,.08),transparent 22rem)}.floral-asset{position:absolute!important;z-index:1;opacity:.20;filter:drop-shadow(0 14px 18px rgba(127,83,91,.08));transform-origin:center;will-change:auto}.section-pad>.container-soft,.hero-section>.container-soft{position:relative;z-index:2}#story .gallery-feature{display:grid;align-items:start!important;max-width:100%;overflow:hidden!important;gap:clamp(16px,2vw,24px)!important}#story .gallery-feature>.photo-real{width:100%;max-width:100%;min-width:0;height:auto!important;min-height:0!important;aspect-ratio:auto!important;padding:0!important;overflow:hidden!important;background:transparent!important;border:1px solid rgba(199,131,141,.16);box-shadow:0 20px 58px rgba(83,72,59,.10);transform:none!important;contain:paint}#story .gallery-feature>.photo-real img{position:static!important;inset:auto!important;display:block;width:100%!important;height:auto!important;max-width:100%;max-height:none!important;background:transparent!important;border-radius:inherit;object-fit:contain!important;object-position:center center}#story .photo-card:hover{transform:translateY(-3px)!important}@media (min-width:1024px){#story .gallery-feature{grid-template-columns:repeat(12,minmax(0,1fr))}#story .gallery-feature>.photo-real:nth-child(1){grid-column:span 7}#story .gallery-feature>.photo-real:nth-child(2){grid-column:span 5}#story .gallery-feature>.photo-real:nth-child(3),#story .gallery-feature>.photo-real:nth-child(4),#story .gallery-feature>.photo-real:nth-child(5){grid-column:span 4}}#important .format-grid{display:grid!important;grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:clamp(18px,2.2vw,28px)!important;align-items:stretch!important;max-width:980px;margin-inline:auto}#important .format-mini-card,#important .format-mini-card:nth-child(1),#important .format-mini-card:nth-child(2),#important .format-mini-card:nth-child(3),#important .format-mini-card:nth-child(4){grid-column:auto!important;min-height:255px;padding:clamp(26px,3vw,38px)!important;overflow:hidden;border:1px solid rgba(199,131,141,.18)!important;background:radial-gradient(circle at 12% 0%,rgba(239,184,189,.20),transparent 14rem),radial-gradient(circle at 100% 100%,rgba(174,188,152,.14),transparent 15rem),linear-gradient(145deg,rgba(251,243,233,.82),rgba(240,222,192,.30))!important;box-shadow:0 22px 62px rgba(83,72,59,.08)!important;backdrop-filter:none!important}#important .format-mini-card:nth-child(2){background:radial-gradient(circle at 100% 0%,rgba(174,188,152,.22),transparent 15rem),linear-gradient(145deg,rgba(247,239,230,.82),rgba(223,230,213,.28))!important}#important .format-mini-card:nth-child(3){background:radial-gradient(circle at 0% 100%,rgba(202,217,230,.24),transparent 15rem),linear-gradient(145deg,rgba(251,243,233,.82),rgba(247,215,215,.24))!important}#important .format-mini-card:nth-child(4){background:radial-gradient(circle at 100% 100%,rgba(239,194,170,.25),transparent 15rem),linear-gradient(145deg,rgba(251,243,233,.82),rgba(219,196,157,.28))!important}#important .format-mini-card p:not(.kicker){line-height:1.85}@media (max-width:900px){.site-nav__inner,.paper-card,.hero-facts>div{backdrop-filter:none!important}.floral-asset.asset-visible,.hero-section .floral-asset.asset-hero,.hero-section .floral-asset.asset-medium{display:block!important;opacity:.12;width:clamp(118px,44vw,205px);filter:none!important}#important .format-grid{grid-template-columns:1fr!important;max-width:560px}#important .format-mini-card,#important .format-mini-card:nth-child(1),#important .format-mini-card:nth-child(2),#important .format-mini-card:nth-child(3),#important .format-mini-card:nth-child(4){min-height:0}}@media (max-width:640px){body{background:radial-gradient(circle at 0% 8%,rgba(239,184,189,.15),transparent 17rem),radial-gradient(circle at 100% 40%,rgba(174,188,152,.11),transparent 17rem),linear-gradient(180deg,#fffaf5 0%,#fbf2e9 56%,#f8efe6 100%)!important}#story .gallery-feature{overflow:visible!important}}
