:root {
  --bd-safe-t: env(safe-area-inset-top, 0px);
  --bd-safe-b: env(safe-area-inset-bottom, 0px);
  --bd-radius-xl: 42px;
  --bd-radius-lg: 34px;
  --bd-radius-md: 26px;
  --bd-radius-sm: 18px;
  --bd-shadow: 0 28px 90px rgba(88, 51, 88, .16);
  --bd-shadow-soft: 0 20px 58px rgba(88, 51, 88, .10);
  --bd-line: color-mix(in srgb, var(--bd-ink) 8%, transparent);
  --bd-line-strong: color-mix(in srgb, var(--bd-ink) 14%, transparent);
  --bd-white-glass: rgba(255, 255, 255, .76);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  min-height: 100vh;
  color: var(--bd-ink);
  font-family: var(--bd-font-body), system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  background:
    radial-gradient(circle at 8% 8%, color-mix(in srgb, var(--bd-accent) 24%, transparent), transparent 28%),
    radial-gradient(circle at 90% 10%, color-mix(in srgb, var(--bd-accent2) 24%, transparent), transparent 30%),
    radial-gradient(circle at 75% 90%, color-mix(in srgb, var(--bd-accent3) 22%, transparent), transparent 34%),
    linear-gradient(180deg, var(--bd-bg1), var(--bd-bg2));
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  text-rendering: geometricPrecision;
}
a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }
button, input, textarea, select { font: inherit; }

.bdPage {
  position: relative;
  overflow: hidden;
  padding: calc(88px + var(--bd-safe-t)) 16px calc(48px + var(--bd-safe-b));
}
.bdPage::before,
.bdPage::after {
  content: "";
  position: fixed;
  inset: auto;
  pointer-events: none;
  z-index: 0;
  border-radius: 999px;
  filter: blur(2px);
  opacity: .55;
}
.bdPage::before {
  width: 260px;
  height: 260px;
  left: -92px;
  top: 130px;
  background: radial-gradient(circle, color-mix(in srgb, var(--bd-accent) 30%, #fff), transparent 68%);
}
.bdPage::after {
  width: 300px;
  height: 300px;
  right: -120px;
  bottom: 90px;
  background: radial-gradient(circle, color-mix(in srgb, var(--bd-accent2) 30%, #fff), transparent 70%);
}
.bdShell {
  position: relative;
  z-index: 1;
  width: min(1120px, 100%);
  margin: 0 auto;
}

/* HERO */
.bdHero {
  position: relative;
  min-height: 680px;
  border: 1px solid var(--bd-line);
  border-radius: var(--bd-radius-xl);
  background: linear-gradient(180deg, rgba(255, 255, 255, .88), rgba(255, 255, 255, .72));
  box-shadow: var(--bd-shadow);
  overflow: hidden;
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
}
.bdHero::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 20% 10%, rgba(255, 255, 255, .9), transparent 36%),
    radial-gradient(circle at 80% 0%, color-mix(in srgb, var(--bd-accent2) 18%, transparent), transparent 40%);
  pointer-events: none;
}
.bdHeroGrid {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: minmax(0, 1.08fr) minmax(300px, .72fr);
  gap: 34px;
  align-items: center;
  min-height: 680px;
  padding: 58px;
}
.bdKicker {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  width: max-content;
  max-width: 100%;
  min-height: 36px;
  padding: 0 14px;
  border-radius: 999px;
  background: #fff;
  color: var(--bd-accent);
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .16em;
  font-size: 12px;
  box-shadow: 0 14px 30px rgba(80, 50, 90, .08);
}
.bdTitle {
  margin: 24px 0 0;
  font-family: var(--bd-font-display), var(--bd-font-body), sans-serif;
  font-size: clamp(48px, 8vw, 106px);
  line-height: .9;
  font-weight: 1000;
  letter-spacing: -.06em;
  color: var(--bd-ink);
}
.bdTitle small {
  display: block;
  margin: 0 0 12px;
  font-family: var(--bd-font-body), system-ui, sans-serif;
  font-size: clamp(15px, 1.7vw, 22px);
  line-height: 1.2;
  font-weight: 1000;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--bd-muted);
}
.bdTitle span {
  display: block;
  color: var(--bd-accent);
  text-shadow: 0 14px 32px color-mix(in srgb, var(--bd-accent) 18%, transparent);
}
.bdTitle em {
  display: block;
  margin-top: 6px;
  font-style: normal;
  font-size: .72em;
  line-height: .95;
  color: var(--bd-accent);
}
.bdSubtitle {
  max-width: 660px;
  margin: 24px 0 0;
  color: var(--bd-muted);
  font-size: clamp(16px, 2vw, 20px);
  line-height: 1.72;
  font-weight: 700;
}

/* Красивый блок даты вместо таймера */
.bdDateCard {
  position: relative;
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 16px;
  width: min(560px, 100%);
  margin: 30px 0 0;
  padding: 16px;
  border-radius: 30px;
  background:
    radial-gradient(circle at 12% 8%, rgba(255, 255, 255, .95), transparent 42%),
    linear-gradient(135deg, color-mix(in srgb, var(--bd-accent3) 36%, #fff 64%), color-mix(in srgb, var(--bd-accent2) 18%, #fff 82%));
  border: 2px solid rgba(var(--bd-accent-rgb), .18);
  box-shadow:
    0 20px 46px rgba(80, 50, 90, .12),
    inset 0 0 0 7px rgba(255, 255, 255, .32);
  overflow: hidden;
}
.bdDateCard::before {
  content: "";
  position: absolute;
  inset: 10px;
  border-radius: 24px;
  border: 2px dashed rgba(var(--bd-accent-rgb), .20);
  pointer-events: none;
}
.bdDateCard::after {
  content: "✦";
  position: absolute;
  right: 18px;
  top: 14px;
  color: var(--bd-accent);
  font-size: 24px;
  opacity: .65;
  transform: rotate(12deg);
}
.bdDateCard__icon {
  position: relative;
  z-index: 1;
  width: 74px;
  height: 74px;
  display: grid;
  place-items: center;
  border-radius: 24px;
  background: #fff;
  font-size: 34px;
  box-shadow: 0 14px 26px rgba(63, 35, 70, .10);
  transform: rotate(-4deg);
}
.bdDateCard__body {
  position: relative;
  z-index: 1;
  min-width: 0;
}
.bdDateCard__label {
  width: fit-content;
  min-height: 28px;
  display: inline-flex;
  align-items: center;
  padding: 0 11px;
  border-radius: 999px;
  background: rgba(255, 255, 255, .72);
  color: var(--bd-accent);
  font-size: 11px;
  line-height: 1;
  font-weight: 1000;
  letter-spacing: .13em;
  text-transform: uppercase;
}
.bdDateCard__date {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 8px;
  margin-top: 10px;
  font-family: var(--bd-font-display), var(--bd-font-body), sans-serif;
  color: var(--bd-ink);
}
.bdDateCard__day {
  font-size: clamp(40px, 6vw, 70px);
  line-height: .82;
  font-weight: 1000;
  letter-spacing: -.06em;
  color: var(--bd-accent);
}
.bdDateCard__month {
  font-size: clamp(24px, 3vw, 38px);
  line-height: .9;
  font-weight: 1000;
  letter-spacing: -.04em;
}
.bdDateCard__year,
.bdDateCard__full {
  font-size: clamp(18px, 2.2vw, 28px);
  font-weight: 1000;
  color: var(--bd-muted);
}
.bdDateCard__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 12px;
}
.bdDateCard__meta span {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 0 11px;
  border-radius: 999px;
  background: #fff;
  color: var(--bd-muted);
  border: 1px solid var(--bd-line);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .06em;
}
.bdMeta { display: none !important; }

.bdActions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin: 34px 0 0;
}
.bdBtn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  min-height: 48px;
  padding: 0 20px;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--bd-ink) 10%, transparent);
  background: #fff;
  color: var(--bd-ink);
  font-weight: 1000;
  box-shadow: 0 16px 34px rgba(80, 50, 90, .09);
  transition: transform .22s ease, box-shadow .22s ease, filter .22s ease;
}
.bdBtn:hover { transform: translateY(-2px); box-shadow: 0 20px 42px rgba(80, 50, 90, .14); }
.bdBtnPrimary { background: linear-gradient(135deg, var(--bd-accent), var(--bd-accent2)); color: #fff; border-color: transparent; }
.bdPhotoCard {
  position: relative;
  border-radius: 36px;
  background: #fff;
  padding: 14px;
  box-shadow: 0 26px 60px rgba(80, 50, 90, .15);
  transform: rotate(2deg);
}
.bdPhoto {
  position: relative;
  display: grid;
  place-items: center;
  aspect-ratio: 4 / 5;
  border-radius: 28px;
  overflow: hidden;
  background: linear-gradient(145deg, color-mix(in srgb, var(--bd-accent2) 22%, #fff), color-mix(in srgb, var(--bd-accent3) 22%, #fff));
}
.bdPhoto img { width: 100%; height: 100%; object-fit: cover; }
.bdPhotoPlaceholder {
  width: 100%;
  height: 100%;
  display: grid;
  place-items: center;
  padding: 24px;
  text-align: center;
  color: var(--bd-muted);
  font-weight: 1000;
}
.bdPhotoPlaceholderIcon { font-size: 64px; line-height: 1; }
.bdAgeBadge {
  position: absolute;
  right: -18px;
  top: -18px;
  z-index: 3;
  width: 112px;
  height: 112px;
  display: grid;
  place-items: center;
  border-radius: 999px;
  background: linear-gradient(135deg, var(--bd-accent3), var(--bd-accent));
  color: #fff;
  box-shadow: 0 20px 44px color-mix(in srgb, var(--bd-accent) 28%, transparent);
  transform: rotate(8deg);
  text-align: center;
}
.bdAgeBadge b { display: block; font-size: 42px; line-height: .9; }
.bdAgeBadge span { display: block; font-size: 11px; font-weight: 1000; text-transform: uppercase; letter-spacing: .12em; }

/* DECOR */
.bdCloud { position: absolute; background: #fff; border-radius: 999px; box-shadow: 0 16px 38px rgba(55,45,80,.08); opacity:.88; animation: bdFloat 7s ease-in-out infinite; }
.bdCloud::before, .bdCloud::after { content:""; position:absolute; background:#fff; border-radius:999px; }
.bdCloud::before { width:54%; height:120%; left:14%; bottom:18%; }
.bdCloud::after { width:48%; height:94%; right:12%; bottom:20%; }
.bdCloud--1 { width:136px; height:48px; left:7%; top:11%; }
.bdCloud--2 { width:164px; height:56px; right:8%; top:17%; animation-delay:-2s; }
.bdCloud--3 { width:116px; height:42px; right:18%; bottom:18%; animation-delay:-4s; }
.bdBalloon { position:absolute; width:58px; height:72px; border-radius:58% 58% 52% 52%; background:linear-gradient(140deg, rgba(255,255,255,.85), var(--b)); box-shadow:0 18px 32px color-mix(in srgb, var(--b) 30%, transparent); animation:bdFloat 5.8s ease-in-out infinite; }
.bdBalloon::after { content:""; position:absolute; left:50%; top:100%; width:1px; height:62px; background:color-mix(in srgb, var(--bd-ink) 16%, transparent); transform:translateX(-50%); }
.bdBalloon::before { content:""; position:absolute; left:50%; bottom:-8px; border:7px solid transparent; border-top-color:var(--b); transform:translateX(-50%); }
.bdBalloon--1 { --b: var(--bd-accent); left:7%; bottom:19%; animation-delay:-.8s; }
.bdBalloon--2 { --b: var(--bd-accent2); right:9%; top:35%; animation-delay:-1.8s; }
.bdBalloon--3 { --b: var(--bd-accent3); left:22%; top:16%; width:46px; height:58px; animation-delay:-3s; }
.bdConfetti { position:absolute; width:9px; height:15px; border-radius:4px; background:var(--c); opacity:.8; animation:bdConfetti 7s linear infinite; }
.bdConfetti:nth-child(1){ --c: var(--bd-accent); left:12%; top:-20px; animation-delay:-1s; }
.bdConfetti:nth-child(2){ --c: var(--bd-accent2); left:38%; top:-20px; animation-delay:-3s; }
.bdConfetti:nth-child(3){ --c: var(--bd-accent3); left:62%; top:-20px; animation-delay:-2s; }
.bdConfetti:nth-child(4){ --c: var(--bd-accent4); left:84%; top:-20px; animation-delay:-5s; }

/* SECTIONS */
.bdSection {
  margin: 26px 0 0;
  border: 1px solid var(--bd-line);
  border-radius: var(--bd-radius-lg);
  background: rgba(255,255,255,.74);
  box-shadow: var(--bd-shadow-soft);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  padding: 30px;
  position: relative;
  overflow: hidden;
}
.bdSection::before { content:""; position:absolute; inset:0; background:radial-gradient(circle at 100% 0%, color-mix(in srgb, var(--bd-accent2) 14%, transparent), transparent 34%); pointer-events:none; }
.bdSection > * { position:relative; z-index:1; }
.bdSectionHead { display:flex; align-items:flex-end; justify-content:space-between; gap:20px; margin-bottom:22px; }
.bdSectionKicker { font-size:12px; text-transform:uppercase; letter-spacing:.18em; font-weight:1000; color:var(--bd-accent); }
.bdSectionTitle { margin:7px 0 0; font-family:var(--bd-font-display), var(--bd-font-body), sans-serif; font-size:clamp(28px,4vw,46px); line-height:1; font-weight:1000; letter-spacing:-.04em; }
.bdText { color:var(--bd-muted); font-size:16px; line-height:1.78; font-weight:700; white-space:pre-line; }

/* DETAILS */
.bdDetailsGrid { display:grid; grid-template-columns:1fr .8fr; gap:18px; }
.bdCakeCard { border-radius:28px; background:linear-gradient(145deg, color-mix(in srgb, var(--bd-accent3) 18%, #fff), #fff); padding:22px; display:grid; place-items:center; min-height:220px; }
.bdCake { font-size:96px; filter:drop-shadow(0 18px 28px rgba(80,50,90,.14)); animation:bdWiggle 4s ease-in-out infinite; }

/* SCHEDULE */
.bdSchedule { display:grid; gap:13px; }
.bdScheduleItem { display:grid; grid-template-columns:92px 1fr; gap:14px; align-items:start; }
.bdTime { min-height:58px; display:grid; place-items:center; border-radius:20px; background:linear-gradient(135deg, var(--bd-accent), var(--bd-accent2)); color:#fff; font-weight:1000; box-shadow:0 16px 30px color-mix(in srgb, var(--bd-accent) 20%, transparent); }
.bdProgramCard { border-radius:22px; background:#fff; padding:16px 18px; border:1px solid var(--bd-line); box-shadow:0 10px 24px rgba(80,50,90,.06); }
.bdProgramTitle { font-weight:1000; }
.bdProgramText { margin-top:4px; color:var(--bd-muted); line-height:1.55; font-weight:700; }

/* LOCATION */
.bdLocationCard { display:grid; grid-template-columns:minmax(220px,.72fr) 1fr; gap:18px; align-items:stretch; margin-top:22px; }
.bdLocationPhoto { min-height:260px; border-radius:28px; overflow:hidden; background:linear-gradient(145deg, color-mix(in srgb, var(--bd-accent2) 22%, #fff), color-mix(in srgb, var(--bd-accent3) 18%, #fff)); box-shadow:0 16px 36px rgba(80,50,90,.08); border:1px solid var(--bd-line); }
.bdLocationPhoto img { width:100%; height:100%; object-fit:cover; }
.bdLocationPhoto--empty { display:grid; place-items:center; text-align:center; color:var(--bd-muted); font-weight:1000; padding:24px; }
.bdLocationPhoto--empty div { font-size:70px; line-height:1; }
.bdLocationPhoto--empty span { display:block; margin-top:10px; }
.bdLocationBody { border-radius:28px; background:#fff; padding:22px; border:1px solid var(--bd-line); box-shadow:0 10px 24px rgba(80,50,90,.06); }
.bdLocationBadge { display:inline-flex; align-items:center; min-height:34px; padding:0 13px; border-radius:999px; background:color-mix(in srgb, var(--bd-accent) 12%, #fff); color:var(--bd-accent); font-size:12px; font-weight:1000; text-transform:uppercase; letter-spacing:.12em; }
.bdLocationName { margin:16px 0 10px; font-family:var(--bd-font-display), var(--bd-font-body), sans-serif; font-size:clamp(26px,4vw,42px); line-height:1; font-weight:1000; letter-spacing:-.04em; }
.bdLocationText, .bdLocationNote { color:var(--bd-muted); line-height:1.65; font-weight:800; }
.bdLocationText.is-muted { opacity:.72; }
.bdLocationNote { margin-top:10px; white-space:pre-line; }
.bdLocationActions { display:flex; flex-wrap:wrap; gap:10px; margin-top:18px; }

/* GIFTS */
.bdGiftBox { display:grid; grid-template-columns:auto 1fr; gap:18px; align-items:center; border-radius:28px; background:linear-gradient(135deg, color-mix(in srgb, var(--bd-accent4) 28%, #fff), #fff); padding:20px; margin-top:22px; }
.bdGiftIcon { font-size:68px; }
.bdWishLink { display:inline-flex; margin-top:14px; align-items:center; gap:8px; font-weight:1000; color:var(--bd-accent); }

/* SHARED BLOCKS SKIN */
.bdBlockSkin { position:relative; isolation:isolate; border:3px solid rgba(var(--bd-accent-rgb), .20); background:radial-gradient(circle at 8% 10%, rgba(255,255,255,.88), transparent 24%), radial-gradient(circle at 92% 12%, color-mix(in srgb, var(--bd-accent2) 24%, transparent), transparent 26%), radial-gradient(circle at 88% 88%, color-mix(in srgb, var(--bd-accent3) 28%, transparent), transparent 30%), linear-gradient(135deg, color-mix(in srgb, var(--bd-paper) 94%, var(--bd-bg1) 6%), color-mix(in srgb, var(--bd-bg2) 64%, #fff 36%)); box-shadow:0 24px 70px rgba(63,35,70,.10), inset 0 0 0 8px rgba(255,255,255,.34); }
.bdBlockSkin::before { content:""; position:absolute; inset:14px; z-index:0; border-radius:26px; border:2px dashed color-mix(in srgb, var(--bd-accent) 32%, transparent); pointer-events:none; }
.bdBlockSkin::after { content:"✦ ✿ ★"; position:absolute; right:24px; top:22px; z-index:0; font-size:20px; letter-spacing:.4em; color:color-mix(in srgb, var(--bd-accent) 58%, transparent); opacity:.55; transform:rotate(5deg); pointer-events:none; }
.bdBlockSkin > * { position:relative; z-index:1; }
.bdBlockSkin .bdSectionKicker { display:inline-flex; align-items:center; width:fit-content; min-height:34px; padding:0 14px; border-radius:999px; background:color-mix(in srgb, var(--bd-accent3) 55%, #fff 45%); color:var(--bd-ink); box-shadow:0 10px 24px rgba(63,35,70,.08); }
.bdBlockSkin .bdSectionTitle { margin-top:14px; }

/* SHARED GALLERY */
#galleryWrap .iviGallery, #galleryWrap .iviGalleryWrap, #galleryWrap .iviGalleryGrid { width:100% !important; }
#galleryWrap .iviGalleryHead, #galleryWrap .iviGalleryTitle, #galleryWrap .iviGalleryKicker { display:none !important; }
#galleryWrap .iviGalleryGrid, #galleryWrap .iviGalleryGrid--grid, #galleryWrap .iviGalleryGrid--masonry { display:grid !important; grid-template-columns:repeat(12, minmax(0, 1fr)) !important; gap:16px !important; margin:24px 0 0 !important; padding:0 !important; column-count:initial !important; column-width:initial !important; }
#galleryWrap .iviGalleryItem { position:relative !important; display:block !important; grid-column:span 4 !important; height:260px !important; min-height:0 !important; overflow:hidden !important; border:4px solid #fff !important; border-radius:28px !important; background:var(--bd-paper) !important; box-shadow:0 18px 38px rgba(63,35,70,.13), 0 0 0 1px rgba(var(--bd-accent-rgb), .12) !important; transform:rotate(var(--bd-rot, -1deg)); transition:transform .28s ease, box-shadow .28s ease, filter .28s ease !important; }
#galleryWrap .iviGalleryItem:nth-child(2n){ --bd-rot:1.2deg; }
#galleryWrap .iviGalleryItem:nth-child(3n){ --bd-rot:-.7deg; }
#galleryWrap .iviGalleryItem:nth-child(1){ grid-column:span 7 !important; height:340px !important; }
#galleryWrap .iviGalleryItem:nth-child(2){ grid-column:span 5 !important; height:340px !important; }
#galleryWrap .iviGalleryItem:first-child:last-child{ grid-column:span 12 !important; height:420px !important; }
#galleryWrap .iviGalleryItem img { display:block !important; width:100% !important; height:100% !important; min-height:0 !important; object-fit:cover !important; border-radius:22px !important; filter:saturate(1.04) contrast(1.02) !important; transform:scale(1.01); transition:transform .45s ease, filter .45s ease !important; }
#galleryWrap .iviGalleryItem::before { content:""; position:absolute; left:18px; top:16px; z-index:3; width:42px; height:20px; border-radius:999px; background:color-mix(in srgb, var(--bd-accent3) 82%, #fff 18%); box-shadow:0 8px 16px rgba(63,35,70,.12); transform:rotate(-10deg); opacity:.9; pointer-events:none; }
#galleryWrap .iviGalleryItem::after { content:"★"; position:absolute; right:16px; bottom:12px; z-index:3; width:34px; height:34px; display:grid; place-items:center; border-radius:50%; background:var(--bd-paper); color:var(--bd-accent); box-shadow:0 10px 22px rgba(63,35,70,.14); pointer-events:none; }
#galleryWrap .iviGalleryCaption { display:none !important; }
@media (hover:hover) {
  #galleryWrap .iviGalleryItem:hover { transform:translateY(-6px) rotate(0deg) scale(1.01) !important; box-shadow:0 26px 58px rgba(63,35,70,.18), 0 0 0 1px rgba(var(--bd-accent-rgb), .16) !important; }
  #galleryWrap .iviGalleryItem:hover img { transform:scale(1.07); filter:saturate(1.16) contrast(1.02) !important; }
}

/* RSVP */
#rsvpWrap { scroll-margin-top:90px; }
#rsvpWrap .rsvpSection { padding:0 !important; margin:0 !important; background:transparent !important; color:var(--bd-ink) !important; }
#rsvpWrap .rsvpGrid { display:block !important; }
#rsvpWrap .rsvpFormCard { position:relative; width:100% !important; max-width:820px !important; margin:24px auto 0 !important; padding:clamp(22px,4vw,38px) !important; overflow:hidden; border:3px solid color-mix(in srgb, var(--bd-accent) 24%, #fff 76%) !important; border-radius:32px !important; background:radial-gradient(circle at 12% 10%, rgba(255,255,255,.88), transparent 24%), linear-gradient(145deg, rgba(255,255,255,.92), color-mix(in srgb, var(--bd-bg2) 28%, #fff 72%)) !important; box-shadow:0 20px 50px rgba(63,35,70,.13), inset 0 0 0 7px rgba(255,255,255,.38) !important; }
#rsvpWrap .rsvpFormCard::before { content:"🎉 ФОРМА ОТВЕТА ГОСТЯ"; display:inline-flex; align-items:center; width:fit-content; min-height:34px; margin:0 0 22px; padding:0 14px; border-radius:999px; background:color-mix(in srgb, var(--bd-accent3) 62%, #fff 38%); color:var(--bd-ink); font-family:var(--bd-font-body), Manrope, sans-serif; font-size:12px; line-height:1.2; font-weight:900; letter-spacing:.05em; text-transform:uppercase; box-shadow:0 10px 22px rgba(63,35,70,.10); }
#rsvpWrap .rsvpLabel, #rsvpWrap .rsvpSection > h2, #rsvpWrap .rsvpHint, #rsvpWrap .rose-line-svg { display:none !important; }
#rsvpWrap .row2 { display:grid !important; grid-template-columns:repeat(2, minmax(0,1fr)) !important; gap:14px !important; }
#rsvpWrap .formRow { margin:0 0 16px !important; }
#rsvpWrap .label { display:block !important; margin:0 0 8px !important; color:var(--bd-muted) !important; font-family:var(--bd-font-body), Manrope, sans-serif !important; font-size:12px !important; line-height:1.35 !important; font-weight:900 !important; letter-spacing:.04em !important; text-transform:uppercase !important; }
#rsvpWrap .field { width:100% !important; min-height:52px !important; padding:0 16px !important; border:2px solid color-mix(in srgb, var(--bd-accent) 20%, #fff 80%) !important; border-radius:18px !important; background:rgba(255,255,255,.84) !important; color:var(--bd-ink) !important; outline:none !important; box-shadow:inset 0 -3px 0 rgba(var(--bd-accent-rgb), .06), 0 8px 18px rgba(63,35,70,.06) !important; font-family:var(--bd-font-body), Manrope, sans-serif !important; font-size:15px !important; font-weight:700 !important; transition:border-color .2s ease, box-shadow .2s ease, transform .2s ease !important; }
#rsvpWrap textarea.field { min-height:118px !important; padding-top:14px !important; resize:vertical !important; }
#rsvpWrap .field::placeholder { color:color-mix(in srgb, var(--bd-muted) 70%, transparent) !important; opacity:1 !important; }
#rsvpWrap .field:focus { border-color:var(--bd-accent) !important; box-shadow:0 0 0 5px rgba(var(--bd-accent-rgb), .12), 0 12px 24px rgba(63,35,70,.10) !important; transform:translateY(-1px); }
#rsvpWrap .chips { display:flex !important; flex-wrap:wrap !important; gap:10px !important; }
#rsvpWrap .chip { min-height:44px !important; padding:0 16px !important; border:2px solid color-mix(in srgb, var(--bd-accent) 20%, #fff 80%) !important; border-radius:999px !important; background:#fff !important; color:var(--bd-ink) !important; box-shadow:0 8px 18px rgba(63,35,70,.06) !important; font-family:var(--bd-font-body), Manrope, sans-serif !important; font-size:13px !important; line-height:1.2 !important; font-weight:900 !important; cursor:pointer !important; transition:transform .18s ease, background .18s ease, color .18s ease, border-color .18s ease, box-shadow .18s ease !important; }
#rsvpWrap .chip:hover { transform:translateY(-2px) rotate(-1deg); border-color:var(--bd-accent) !important; }
#rsvpWrap .chip[data-active="true"], #rsvpWrap .chip.is-active, #rsvpWrap .chip.active { background:linear-gradient(135deg, var(--bd-accent), var(--bd-accent2)) !important; color:#fff !important; border-color:transparent !important; box-shadow:0 12px 26px rgba(var(--bd-accent-rgb), .24), inset 0 1px 0 rgba(255,255,255,.34) !important; }
#rsvpWrap .rsvpTotal { width:fit-content; margin:10px 0 18px !important; padding:12px 16px; border-radius:18px; background:color-mix(in srgb, var(--bd-accent4) 55%, #fff 45%); color:var(--bd-ink); font-family:var(--bd-font-display), Nunito, sans-serif !important; font-size:18px !important; font-weight:1000; box-shadow:0 10px 20px rgba(63,35,70,.08); }
#rsvpWrap .consent { display:grid !important; grid-template-columns:22px 1fr !important; gap:12px !important; align-items:start !important; color:var(--bd-muted) !important; font-size:13px !important; line-height:1.55 !important; font-weight:700 !important; }
#rsvpWrap .consent input { width:18px !important; height:18px !important; margin-top:2px !important; accent-color:var(--bd-accent) !important; }
#rsvpWrap .consent a { color:var(--bd-accent) !important; text-decoration:underline; text-underline-offset:3px; font-weight:900; }
#rsvpWrap .btn, #rsvpWrap .btn-full, #rsvpWrap button[type="submit"] { min-height:56px !important; padding:0 22px !important; border:0 !important; border-radius:999px !important; background:linear-gradient(135deg, var(--bd-accent), var(--bd-accent2)) !important; color:#fff !important; box-shadow:0 16px 34px rgba(var(--bd-accent-rgb), .28), inset 0 1px 0 rgba(255,255,255,.35) !important; font-family:var(--bd-font-body), Manrope, sans-serif !important; font-size:14px !important; font-weight:1000 !important; letter-spacing:.02em !important; cursor:pointer !important; transition:transform .18s ease, box-shadow .18s ease, filter .18s ease !important; }
#rsvpWrap .btn:hover, #rsvpWrap .btn-full:hover, #rsvpWrap button[type="submit"]:hover { transform:translateY(-3px) rotate(-.5deg); box-shadow:0 22px 46px rgba(var(--bd-accent-rgb), .34), inset 0 1px 0 rgba(255,255,255,.35) !important; }
#rsvpWrap .statusBox { border-radius:22px !important; border:2px solid rgba(var(--bd-accent-rgb), .16) !important; background:#fff !important; box-shadow:0 12px 26px rgba(63,35,70,.08) !important; }
#rsvpWrap .statusBox.ok { color:#1f8b61 !important; background:color-mix(in srgb, var(--bd-accent4) 44%, #fff 56%) !important; }
#rsvpWrap .statusBox.bad { color:#b33668 !important; background:color-mix(in srgb, var(--bd-accent) 12%, #fff 88%) !important; }
#rsvpWrap .previewLockNote { border-radius:24px !important; border:2px solid rgba(var(--bd-accent-rgb), .15) !important; background:rgba(255,255,255,.86) !important; }

/* MUSIC */
#musicWrap { padding:clamp(22px,4vw,34px); }
#musicWrap .music, #musicWrap .iviMusic, #musicWrap [class*="Music"] { border-radius:26px !important; background:rgba(255,255,255,.66) !important; box-shadow:none !important; }

/* PLACEHOLDERS */
.bdLocationPhoto--empty, .bdPhotoPlaceholder { position:relative; min-height:260px; display:grid; place-items:center; overflow:hidden; border-radius:30px; background:radial-gradient(circle at 25% 20%, color-mix(in srgb, var(--bd-accent3) 50%, transparent), transparent 26%), radial-gradient(circle at 82% 78%, color-mix(in srgb, var(--bd-accent2) 42%, transparent), transparent 28%), linear-gradient(135deg, #fff, color-mix(in srgb, var(--bd-bg2) 50%, #fff 50%)); color:var(--bd-muted); font-family:var(--bd-font-display), Nunito, sans-serif; font-size:22px; font-weight:1000; text-align:center; }
.bdLocationPhoto--empty::before, .bdPhotoPlaceholder::before { content:""; position:absolute; inset:14px; border-radius:24px; border:2px dashed rgba(var(--bd-accent-rgb), .22); pointer-events:none; }
.bdLocationPhoto--empty span, .bdPhotoPlaceholder div div:last-child { display:inline-flex; margin-top:8px; padding:8px 13px; border-radius:999px; background:rgba(255,255,255,.72); font-family:var(--bd-font-body), Manrope, sans-serif; font-size:12px; line-height:1.2; font-weight:900; color:var(--bd-muted); }

/* FOOTER */
.bdFooter { text-align:center; padding:34px 12px 8px; color:var(--bd-muted); font-weight:900; }
.bdFooterName { margin-top:8px; font-family:var(--bd-font-display), var(--bd-font-body), sans-serif; font-size:clamp(28px,5vw,52px); font-weight:1000; color:var(--bd-ink); letter-spacing:-.04em; }

/* ANIMATIONS */
@keyframes bdFloat { 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(-14px); } }
@keyframes bdWiggle { 0%,100%{ transform:rotate(-2deg) scale(1); } 50%{ transform:rotate(3deg) scale(1.04); } }
@keyframes bdConfetti { 0%{ transform:translateY(-40px) rotate(0); } 100%{ transform:translateY(760px) rotate(360deg); } }

/* RESPONSIVE */
@media (max-width:920px) {
  .bdPage { padding-left:10px; padding-right:10px; }
  .bdHero { min-height:auto; }
  .bdHeroGrid { grid-template-columns:1fr; min-height:auto; padding:34px 22px; }
  .bdPhotoCard { max-width:440px; margin:0 auto; }
  .bdDetailsGrid, .bdLocationCard { grid-template-columns:1fr; }
  .bdLocationPhoto { min-height:220px; }
  .bdSectionHead { display:block; }
  .bdScheduleItem { grid-template-columns:74px 1fr; }
  #galleryWrap .iviGalleryGrid, #galleryWrap .iviGalleryGrid--grid, #galleryWrap .iviGalleryGrid--masonry { grid-template-columns:1fr !important; gap:14px !important; }
  #galleryWrap .iviGalleryItem, #galleryWrap .iviGalleryItem:nth-child(1), #galleryWrap .iviGalleryItem:nth-child(2), #galleryWrap .iviGalleryItem:first-child:last-child { grid-column:auto !important; height:280px !important; }
  #rsvpWrap .row2 { grid-template-columns:1fr !important; }
  #rsvpWrap .rsvpFormCard { border-radius:26px !important; padding:20px !important; }
  #rsvpWrap .chips { gap:8px !important; }
  #rsvpWrap .chip { width:100% !important; justify-content:center !important; }
  #rsvpWrap .btn, #rsvpWrap .btn-full, #rsvpWrap button[type="submit"] { width:100% !important; }
}
@media (max-width:560px) {
  .bdHero { border-radius:30px; }
  .bdHeroGrid { padding:30px 16px; }
  .bdTitle { font-size:48px; }
  .bdDateCard { grid-template-columns:1fr; padding:14px; border-radius:26px; text-align:center; }
  .bdDateCard__icon { margin:0 auto; }
  .bdDateCard__label { margin:0 auto; }
  .bdDateCard__date, .bdDateCard__meta { justify-content:center; }
  .bdSection { padding:22px 16px; border-radius:26px; }
  .bdActions .bdBtn { width:100%; }
  .bdAgeBadge { width:88px; height:88px; right:-6px; top:-12px; }
  .bdAgeBadge b { font-size:32px; }
  .bdScheduleItem { grid-template-columns:1fr; }
  .bdTime { width:max-content; min-width:86px; }
  .bdGiftBox { grid-template-columns:1fr; text-align:center; }
  .bdCloud, .bdBalloon { display:none; }
  .bdBlockSkin { border-radius:24px; border-width:2px; }
  .bdBlockSkin::before { inset:10px; border-radius:18px; }
  .bdBlockSkin::after { right:18px; top:18px; font-size:15px; }
  #rsvpWrap .rsvpFormCard { padding:18px 14px !important; }
  #rsvpWrap .rsvpFormCard::before { font-size:11px; max-width:100%; }
  #rsvpWrap .field { border-radius:16px !important; }
  #galleryWrap .iviGalleryItem { border-radius:22px !important; }
  #galleryWrap .iviGalleryItem img { border-radius:16px !important; }
}
@media (prefers-reduced-motion:reduce) { *, *::before, *::after { animation:none !important; transition:none !important; } }

/* =========================================================
   BIRTHDAY DRESSCODE BLOCK
========================================================= */

.bdDresscode {
  width: 100%;
}

.bdDresscodeHead {
  margin-bottom: 22px;
}

.bdDresscodeKicker {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  min-height: 34px;
  padding: 0 14px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--bd-accent3) 55%, #fff 45%);
  color: var(--bd-ink);
  box-shadow: 0 10px 24px rgba(63, 35, 70, .08);
  font-size: 12px;
  line-height: 1;
  font-weight: 1000;
  letter-spacing: .16em;
  text-transform: uppercase;
}

.bdDresscodeTitle {
  margin: 14px 0 0;
  font-family: var(--bd-font-display), var(--bd-font-body), sans-serif;
  font-size: clamp(30px, 4vw, 48px);
  line-height: .98;
  font-weight: 1000;
  letter-spacing: -.045em;
  color: var(--bd-ink);
}

.bdDresscodeText {
  max-width: 760px;
  margin: 14px 0 0;
  color: var(--bd-muted);
  font-size: 16px;
  line-height: 1.75;
  font-weight: 700;
  white-space: pre-line;
}

.bdDresscodeCard {
  display: grid;
  grid-template-columns: minmax(220px, .62fr) minmax(0, 1fr);
  gap: 18px;
  align-items: stretch;
}

.bdDresscodePalette {
  position: relative;
  min-height: 220px;
  display: flex;
  flex-wrap: wrap;
  align-content: center;
  justify-content: center;
  gap: 14px;
  padding: 26px;
  border-radius: 30px;
  background:
    radial-gradient(circle at 20% 20%, rgba(255, 255, 255, .92), transparent 34%),
    linear-gradient(145deg, color-mix(in srgb, var(--bd-accent3) 18%, #fff), color-mix(in srgb, var(--bd-bg2) 34%, #fff));
  border: 1px solid var(--bd-line);
  box-shadow: 0 16px 36px rgba(80, 50, 90, .08);
  overflow: hidden;
}

.bdDresscodePalette::before {
  content: "";
  position: absolute;
  inset: 14px;
  border-radius: 24px;
  border: 2px dashed rgba(var(--bd-accent-rgb), .18);
  pointer-events: none;
}

.bdDresscodeColor {
  position: relative;
  z-index: 1;
  width: 58px;
  height: 58px;
  display: grid;
  place-items: center;
  border-radius: 999px;
  background: #fff;
  box-shadow:
    0 16px 28px rgba(63, 35, 70, .12),
    inset 0 0 0 1px rgba(0, 0, 0, .06);
  transform: rotate(var(--bdc-rot, -2deg));
}

.bdDresscodeColor:nth-child(2n) {
  --bdc-rot: 2deg;
}

.bdDresscodeColor:nth-child(3n) {
  --bdc-rot: -1deg;
}

.bdDresscodeColor i {
  width: 44px;
  height: 44px;
  display: block;
  border-radius: inherit;
  background: var(--bdc-color);
  box-shadow:
    inset 0 0 0 1px rgba(0, 0, 0, .08),
    inset 0 10px 16px rgba(255, 255, 255, .20);
}

.bdDresscodeItems {
  display: grid;
  gap: 12px;
}

.bdDresscodeItem {
  position: relative;
  min-height: 104px;
  padding: 18px 20px;
  border-radius: 26px;
  background: rgba(255, 255, 255, .84);
  border: 1px solid var(--bd-line);
  box-shadow: 0 10px 24px rgba(80, 50, 90, .06);
  overflow: hidden;
}

.bdDresscodeItem::before {
  content: "";
  position: absolute;
  width: 86px;
  height: 86px;
  right: -34px;
  top: -34px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--bd-accent) 12%, transparent);
  pointer-events: none;
}

.bdDresscodeItemTitle {
  position: relative;
  z-index: 1;
  margin: 0 0 7px;
  color: var(--bd-ink);
  font-family: var(--bd-font-display), var(--bd-font-body), sans-serif;
  font-size: 22px;
  line-height: 1.05;
  font-weight: 1000;
  letter-spacing: -.035em;
}

.bdDresscodeItemText {
  position: relative;
  z-index: 1;
  color: var(--bd-muted);
  font-size: 15px;
  line-height: 1.65;
  font-weight: 750;
  white-space: pre-line;
}

@media (max-width: 920px) {
  .bdDresscodeCard {
    grid-template-columns: 1fr;
  }

  .bdDresscodePalette {
    min-height: 180px;
  }
}

@media (max-width: 560px) {
  .bdDresscodeCard {
    gap: 14px;
  }

  .bdDresscodePalette {
    min-height: 150px;
    padding: 22px 16px;
    border-radius: 24px;
  }

  .bdDresscodeColor {
    width: 48px;
    height: 48px;
  }

  .bdDresscodeColor i {
    width: 36px;
    height: 36px;
  }

  .bdDresscodeItem {
    min-height: auto;
    padding: 16px;
    border-radius: 22px;
  }

  .bdDresscodeItemTitle {
    font-size: 20px;
  }
}

/* Cover image visibility from Studio */
body[data-hero-image-enabled="0"] .hero-photo,
body[data-hero-image-enabled="0"] .hero-image,
body[data-hero-image-enabled="0"] .hero__photo,
body[data-hero-image-enabled="0"] .hero__image,
body[data-hero-image-enabled="0"] .cover-photo,
body[data-hero-image-enabled="0"] .cover-image,
body[data-hero-image-enabled="0"] [data-hero-photo],
body[data-hero-image-enabled="0"] [data-hero-image],
html[data-hero-image-enabled="0"] .hero-photo,
html[data-hero-image-enabled="0"] .hero-image,
html[data-hero-image-enabled="0"] .hero__photo,
html[data-hero-image-enabled="0"] .hero__image,
html[data-hero-image-enabled="0"] .cover-photo,
html[data-hero-image-enabled="0"] .cover-image,
html[data-hero-image-enabled="0"] [data-hero-photo],
html[data-hero-image-enabled="0"] [data-hero-image] {
  display: none !important;
}

body[data-hero-image-enabled="0"] .hero,
body[data-hero-image-enabled="0"] .hero__inner,
body[data-hero-image-enabled="0"] .cover,
body[data-hero-image-enabled="0"] .cover__inner,
html[data-hero-image-enabled="0"] .hero,
html[data-hero-image-enabled="0"] .hero__inner,
html[data-hero-image-enabled="0"] .cover,
html[data-hero-image-enabled="0"] .cover__inner {
  background-image: none !important;
}


/* Hero without cover photo */
body[data-hero-image-enabled="0"] .hero-photo,
body[data-hero-image-enabled="0"] .hero-image,
body[data-hero-image-enabled="0"] .hero__photo,
body[data-hero-image-enabled="0"] .hero__image,
body[data-hero-image-enabled="0"] .cover-photo,
body[data-hero-image-enabled="0"] .cover-image,
body[data-hero-image-enabled="0"] [data-hero-photo],
body[data-hero-image-enabled="0"] [data-hero-image],
html[data-hero-image-enabled="0"] .hero-photo,
html[data-hero-image-enabled="0"] .hero-image,
html[data-hero-image-enabled="0"] .hero__photo,
html[data-hero-image-enabled="0"] .hero__image,
html[data-hero-image-enabled="0"] .cover-photo,
html[data-hero-image-enabled="0"] .cover-image,
html[data-hero-image-enabled="0"] [data-hero-photo],
html[data-hero-image-enabled="0"] [data-hero-image] {
  display: none !important;
}

body[data-hero-image-enabled="0"] .hero,
body[data-hero-image-enabled="0"] .hero__inner,
body[data-hero-image-enabled="0"] .hero-inner,
body[data-hero-image-enabled="0"] .hero-grid,
body[data-hero-image-enabled="0"] .cover,
body[data-hero-image-enabled="0"] .cover__inner,
body[data-hero-image-enabled="0"] .cover-inner,
html[data-hero-image-enabled="0"] .hero,
html[data-hero-image-enabled="0"] .hero__inner,
html[data-hero-image-enabled="0"] .hero-inner,
html[data-hero-image-enabled="0"] .hero-grid,
html[data-hero-image-enabled="0"] .cover,
html[data-hero-image-enabled="0"] .cover__inner,
html[data-hero-image-enabled="0"] .cover-inner {
  background-image: none !important;
}

body[data-hero-image-enabled="0"] .hero-grid,
body[data-hero-image-enabled="0"] .hero__inner,
body[data-hero-image-enabled="0"] .hero-inner,
body[data-hero-image-enabled="0"] .cover-grid,
body[data-hero-image-enabled="0"] .cover__inner,
body[data-hero-image-enabled="0"] .cover-inner,
html[data-hero-image-enabled="0"] .hero-grid,
html[data-hero-image-enabled="0"] .hero__inner,
html[data-hero-image-enabled="0"] .hero-inner,
html[data-hero-image-enabled="0"] .cover-grid,
html[data-hero-image-enabled="0"] .cover__inner,
html[data-hero-image-enabled="0"] .cover-inner {
  grid-template-columns: minmax(0, 1fr) !important;
}

body[data-hero-image-enabled="0"] .hero-copy,
body[data-hero-image-enabled="0"] .hero-content,
body[data-hero-image-enabled="0"] .hero__content,
body[data-hero-image-enabled="0"] .hero-text,
body[data-hero-image-enabled="0"] .cover-copy,
body[data-hero-image-enabled="0"] .cover-content,
body[data-hero-image-enabled="0"] .cover__content,
html[data-hero-image-enabled="0"] .hero-copy,
html[data-hero-image-enabled="0"] .hero-content,
html[data-hero-image-enabled="0"] .hero__content,
html[data-hero-image-enabled="0"] .hero-text,
html[data-hero-image-enabled="0"] .cover-copy,
html[data-hero-image-enabled="0"] .cover-content,
html[data-hero-image-enabled="0"] .cover__content {
  width: min(100%, 760px) !important;
  max-width: 760px !important;
  margin-inline: auto !important;
  text-align: center !important;
  justify-self: center !important;
}

body[data-hero-image-enabled="0"] .hero,
body[data-hero-image-enabled="0"] .cover,
html[data-hero-image-enabled="0"] .hero,
html[data-hero-image-enabled="0"] .cover {
  min-height: auto !important;
  padding-top: clamp(72px, 9vw, 130px) !important;
  padding-bottom: clamp(72px, 9vw, 130px) !important;
}

@media (max-width: 760px) {
  body[data-hero-image-enabled="0"] .hero,
  body[data-hero-image-enabled="0"] .cover,
  html[data-hero-image-enabled="0"] .hero,
  html[data-hero-image-enabled="0"] .cover {
    padding-top: 64px !important;
    padding-bottom: 64px !important;
  }

  body[data-hero-image-enabled="0"] .hero-copy,
  body[data-hero-image-enabled="0"] .hero-content,
  body[data-hero-image-enabled="0"] .hero__content,
  body[data-hero-image-enabled="0"] .hero-text,
  body[data-hero-image-enabled="0"] .cover-copy,
  body[data-hero-image-enabled="0"] .cover-content,
  body[data-hero-image-enabled="0"] .cover__content,
  html[data-hero-image-enabled="0"] .hero-copy,
  html[data-hero-image-enabled="0"] .hero-content,
  html[data-hero-image-enabled="0"] .hero__content,
  html[data-hero-image-enabled="0"] .hero-text,
  html[data-hero-image-enabled="0"] .cover-copy,
  html[data-hero-image-enabled="0"] .cover-content,
  html[data-hero-image-enabled="0"] .cover__content {
    width: 100% !important;
    max-width: 100% !important;
    padding-inline: 20px !important;
  }
}


/* v4: hero without cover image */
body[data-hero-image-enabled="0"] .bdPhotoCard,
html[data-hero-image-enabled="0"] .bdPhotoCard {
  display: none !important;
}

body[data-hero-image-enabled="0"] .bdHero,
html[data-hero-image-enabled="0"] .bdHero {
  min-height: auto !important;
}

body[data-hero-image-enabled="0"] .bdHeroGrid,
html[data-hero-image-enabled="0"] .bdHeroGrid {
  min-height: auto !important;
  grid-template-columns: minmax(0, 1fr) !important;
  padding-top: clamp(64px, 8vw, 108px) !important;
  padding-bottom: clamp(64px, 8vw, 108px) !important;
}

body[data-hero-image-enabled="0"] .bdHeroGrid > :first-child,
html[data-hero-image-enabled="0"] .bdHeroGrid > :first-child {
  width: min(100%, 860px);
  margin-inline: auto;
  text-align: center;
}

body[data-hero-image-enabled="0"] .bdKicker,
html[data-hero-image-enabled="0"] .bdKicker {
  margin-inline: auto;
}

@media (max-width: 760px) {
  body[data-hero-image-enabled="0"] .bdHeroGrid,
  html[data-hero-image-enabled="0"] .bdHeroGrid {
    padding: 48px 18px !important;
  }
}

/* Location photo toggle */
.bdLocationCard.bdLocationCard--no-photo{grid-template-columns:minmax(0,1fr)!important}
