:root{
  --bg:#f8f1ea;            /* тёплая шампань-айвори */
  --bg-alt:#efe5d9;
  --ink:#594539;          /* тёплый коричневый (мокко) */
  --ink-soft:#8c7868;
  --accent:#cf9d97;        /* пыльная роза */
  --accent-deep:#b3766f;   /* насыщенная роза */
  --sage:#9aa585;          /* шалфей */
  --line:#e6d8c9;
  --white:#fffdfa;
  --shadow:0 18px 50px -24px rgba(110,88,73,.45);
  --serif:"Saint",Georgia,serif;
  --sans:"Saint",system-ui,sans-serif;
  --script:"Passions","Saint",cursive;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);
  font-weight:300;          /* Saint Light — как текст на референсе */
  color:var(--ink);
  background:var(--bg);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}

/* переливающийся фон (плавно перетекает через палитру) */
.shimmer-bg{
  background:linear-gradient(125deg,
    #f7eee1 0%, #f4ded7 18%, #eed2cb 34%, #ece4d3 50%,
    #e2ead7 64%, #f1e0d6 82%, #f7eee1 100%);
  background-size:400% 400%;
  animation:bgShift 26s ease-in-out infinite;
}
@keyframes bgShift{
  0%{background-position:0% 50%}
  50%{background-position:100% 50%}
  100%{background-position:0% 50%}
}
img{max-width:100%;display:block}

/* Шрифты: Passions Conflict (каллиграфия, заголовки) + Saint (текст, с референса) */
@font-face{font-family:'Passions';src:url('assets/fonts/PassionsConflictRUS.otf') format('opentype');font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:'Saint';src:url('assets/fonts/Saint-Light.woff') format('woff');font-weight:300;font-style:normal;font-display:swap}
@font-face{font-family:'Saint';src:url('assets/fonts/Saint-Normal.woff') format('woff');font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:'Saint';src:url('assets/fonts/Saint-Medium.woff') format('woff');font-weight:500;font-style:normal;font-display:swap}

/* имена и акцентные надписи — каллиграфия Passions Conflict */
.gate__names,.hero__names,.footer__names,.hero__greeting,.calendar__note,.invite__text p:first-child{
  font-style:normal;line-height:1.25;
}
.gate__names,.hero__names,.footer__names{font-weight:400;letter-spacing:.01em}

/* ===== Кнопки ===== */
.btn{
  display:inline-block;
  font-family:var(--sans);
  font-size:.82rem;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--white);
  background:var(--accent-deep);
  padding:.95em 2.4em;
  border:none;border-radius:999px;
  cursor:pointer;
  text-decoration:none;
  transition:transform .25s ease,background .25s ease,box-shadow .25s ease;
  box-shadow:0 12px 28px -14px rgba(169,138,134,.9);
}
.btn:hover{background:var(--ink);transform:translateY(-2px)}
.btn--full{width:100%}

/* ===== ГЕЙТ ===== */
.gate{
  min-height:100svh;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:24px;position:relative;overflow:hidden;
}
.gate__card{
  width:min(440px,100%);
  background:var(--white);
  border:1px solid var(--line);
  border-radius:26px;
  padding:48px 34px;
  text-align:center;
  box-shadow:var(--shadow);
  position:relative;z-index:2;
}
.gate__eyebrow{
  font-size:.72rem;letter-spacing:.32em;text-transform:uppercase;
  color:var(--accent-deep);margin-bottom:14px;
}
.gate__names{
  font-family:var(--script);
  font-size:2.9rem;line-height:1;color:var(--ink);font-weight:400;
  margin-bottom:20px;
}
.gate__hint{font-size:.92rem;color:var(--ink-soft);margin-bottom:26px}
.gate__form{display:flex;flex-direction:column;gap:12px}
.gate__input{
  font-family:var(--sans);font-size:1rem;text-align:center;
  padding:.9em 1em;border:1px solid var(--line);border-radius:14px;
  background:var(--bg);color:var(--ink);transition:border .2s,box-shadow .2s;
}
.gate__input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 4px rgba(201,169,166,.18)}
.gate__error{min-height:1.2em;margin-top:14px;color:#b4524d;font-size:.88rem}
.gate__error.shake{animation:shake .4s}
@keyframes shake{10%,90%{transform:translateX(-2px)}30%,70%{transform:translateX(4px)}50%{transform:translateX(-6px)}}

/* ===== Конверт с письмом (экран входа) ===== */
.env-scene{position:relative;width:min(372px,92vw);height:520px;margin:auto;perspective:1500px}
.letter{
  position:absolute;left:5%;top:0;width:90%;
  background:var(--white);border:1px solid var(--line);border-radius:14px;
  padding:30px 24px 26px;text-align:center;box-shadow:var(--shadow);
  z-index:2;transform:translateY(330px);opacity:0;
  animation:letterRise 1.25s cubic-bezier(.2,.75,.2,1) 1.6s forwards;
}
.env__back{position:absolute;left:0;bottom:0;width:100%;height:236px;z-index:1;
  background:linear-gradient(#e8d9c1,#e0cfb1);border-radius:13px;box-shadow:var(--shadow)}
.env__front{position:absolute;left:0;bottom:0;width:100%;height:132px;z-index:3;
  background:linear-gradient(#ede1cc,#e3d3b7);border-radius:0 0 13px 13px;
  clip-path:polygon(0 0,50% 44%,100% 0,100% 100%,0 100%);
  box-shadow:0 -1px 8px rgba(110,88,73,.07)}
.env__flap{position:absolute;left:0;top:284px;width:100%;height:120px;z-index:6;
  background:linear-gradient(#e7d7be,#dcc8a8);
  clip-path:polygon(0 0,100% 0,50% 100%);transform-origin:top center;
  animation:flapOpen 1.05s ease .6s forwards}
.env__seal{position:absolute;left:50%;top:330px;width:46px;height:46px;margin-left:-23px;z-index:7;
  display:flex;align-items:center;justify-content:center;border-radius:50%;font-size:18px;color:#fff;
  background:radial-gradient(circle at 35% 30%,#d6a39d,#9c5752);
  box-shadow:0 6px 14px -6px rgba(120,60,60,.75);
  animation:sealOff .45s ease .5s forwards}
@keyframes flapOpen{
  0%{transform:rotateX(0);z-index:6}
  17%{z-index:6}
  18%{z-index:1}
  100%{transform:rotateX(173deg);z-index:1}
}
@keyframes letterRise{
  0%{transform:translateY(330px);opacity:0}
  14%{opacity:1}
  100%{transform:translateY(20px);opacity:1}
}
@keyframes sealOff{to{transform:scale(.35) translateY(-6px);opacity:0}}

.gate__decor{position:absolute;left:0;right:0;height:120px;opacity:.5;pointer-events:none;z-index:1;
  background-repeat:no-repeat;background-position:center;background-size:contain}
.gate__decor--top{top:-10px;background-image:var(--sprig)}
.gate__decor--bottom{bottom:-10px;transform:scaleY(-1);background-image:var(--sprig)}

/* ===== Общие секции ===== */
.site{max-width:760px;margin:0 auto;background:transparent;position:relative;
  padding-bottom:clamp(175px,26vh,250px)}
/* карточка контента (после голубей). На десктопе прозрачная, на мобильном — светлая подложка + золотые боковые линии */
.content-card{position:relative;z-index:1}
@media (max-width:560px){
  /* карточка УЖЕ — больше полей по бокам, цветы выглядывают из-за неё */
  .content-card{
    background:rgba(249,243,235,0.78);
    -webkit-backdrop-filter:blur(3px); backdrop-filter:blur(3px);
    margin:0 22px 16px; border-radius:18px;
    box-shadow:0 12px 36px -16px rgba(110,88,73,.5);
  }
  /* две тонкие золотые вертикальные линии по бокам карточки */
  .content-card::before,.content-card::after{
    content:"";position:absolute;top:16px;bottom:16px;width:1.4px;
    background:linear-gradient(180deg,#e9c87a,#c79a4e 50%,#a87a32);
    opacity:.92;pointer-events:none;z-index:2}
  .content-card::before{left:10px}
  .content-card::after{right:10px}
  /* контент — строго внутри линий, с зазором; текст чуть сжат */
  .content-card .section{padding-left:26px;padding-right:26px}
  .content-card .footer{padding-left:26px;padding-right:26px}
  .calendar__card,.rsvp__form,.venues,.timeline__list,.map,.dress__text,.contacts__intro,.invite__text p{max-width:100%}
  /* дата/приветствие внутри карточки */
  .intro{padding-top:24px;padding-bottom:6px}
  .content-card .hero__date{font-size:1.32rem}
  .content-card .hero__greeting{font-size:clamp(1.7rem,7vw,2.2rem);margin-top:14px}
  .content-card .hero__sub{font-size:.92rem}
  /* на светлой карточке тяжёлое свечение тексту не нужно */
  .content-card .hero__date,.content-card .hero__greeting,.content-card .hero__sub{text-shadow:none}
}
/* пионы по углам белых карточек (верх-право и низ-лево), разные */
.calendar__card,.vcard{position:relative}
.calendar__card::before,.calendar__card::after,.vcard::before,.vcard::after{
  content:"";position:absolute;width:clamp(84px,26vw,128px);height:clamp(84px,26vw,128px);
  background-repeat:no-repeat;background-position:center;background-size:contain;
  pointer-events:none;z-index:4;filter:drop-shadow(0 5px 9px rgba(110,88,73,.2))}
.calendar__card::before{top:-32px;right:-18px;background-image:url(assets/peony2.png?v=1)}
.calendar__card::after {bottom:-32px;left:-18px;background-image:url(assets/peony1.png?v=1)}
.vcard::before{top:-32px;right:-18px;background-image:url(assets/peony4.png?v=1)}
.vcard::after {bottom:-32px;left:-18px;background-image:url(assets/peony3.png?v=1)}
.vcard:nth-of-type(2)::before{background-image:url(assets/peony1.png?v=1)}
.vcard:nth-of-type(2)::after {background-image:url(assets/peony2.png?v=1)}

/* мягкая айвори-подложка под текстовыми секциями — читаемость поверх цветов */
.invite,.dress,.contacts,.rsvp,.timeline,.countdown{isolation:isolate}
.invite::before,.dress::before,.contacts::before,.rsvp::before{content:"";position:absolute;inset:4% 2%;z-index:-1;
  background:radial-gradient(ellipse 72% 66% at 50% 50%,rgba(248,241,234,.92),rgba(248,241,234,.6) 54%,rgba(248,241,234,0) 80%);
  filter:blur(10px);pointer-events:none}
.section{padding:64px 26px;text-align:center;position:relative}
.section__title{
  font-family:var(--script);font-weight:400;font-size:2.9rem;line-height:1.15;color:var(--ink);
  margin-bottom:34px;position:relative;display:inline-block;
}
.section__title::after{
  content:"";display:block;width:54px;height:1px;background:var(--accent);
  margin:14px auto 0;
}

/* ===== Обложка ===== */
.hero{
  min-height:auto;display:flex;align-items:center;justify-content:center;
  text-align:center;padding:clamp(200px,52vw,300px) 24px 18px;position:relative;overflow:visible;
  background:transparent;
}
.hero__inner{position:relative;z-index:2}
/* цветочные акценты в пустых местах обложки */
.hero-bloom{position:absolute;left:50%;transform:translateX(-50%);pointer-events:none;
  filter:drop-shadow(0 5px 9px rgba(110,88,73,.18))}
.hero-bloom--top{top:4%;width:clamp(74px,17vw,108px);z-index:0;opacity:.92}
.hero-bloom--mid{bottom:2%;width:clamp(104px,27vw,156px);z-index:1}
/* цветы-рамка по бокам ВСЕЙ страницы (фиксированы во вьюпорте) + нижняя гирлянда у конца */
.page-flower{pointer-events:none;object-fit:cover;user-select:none;z-index:0}
.page-flower--l,.page-flower--r{position:fixed;top:0;height:100vh;width:clamp(210px,34vw,560px)}
/* плотные до линии: держим цветы насыщенными почти до внутреннего края, мягкий срез лишь на последних ~18% */
.page-flower--l{left:0;object-position:left center;
  -webkit-mask-image:linear-gradient(to right,#000 0%,#000 82%,transparent 100%);
          mask-image:linear-gradient(to right,#000 0%,#000 82%,transparent 100%)}
.page-flower--r{right:0;object-position:right center;
  -webkit-mask-image:linear-gradient(to left,#000 0%,#000 82%,transparent 100%);
          mask-image:linear-gradient(to left,#000 0%,#000 82%,transparent 100%)}
.page-flower--bottom{position:absolute;left:0;bottom:0;width:100%;
  height:clamp(150px,22vh,250px);object-fit:cover;object-position:center bottom;
  /* радиальная маска: плотно у низа-центра, мягко растворяется по краям и вверх — без обрубленных краёв */
  -webkit-mask-image:radial-gradient(135% 108% at 50% 100%,#000 50%,transparent 100%);
          mask-image:radial-gradient(135% 108% at 50% 100%,#000 50%,transparent 100%)}
@media (max-width:560px){
  /* цветы за карточкой — пышнее, выглядывают из-за узкой рамки */
  .page-flower--l,.page-flower--r{width:43vw;opacity:1}
  .page-flower--l{-webkit-mask-image:linear-gradient(to right,#000 0%,#000 78%,transparent 100%);
                          mask-image:linear-gradient(to right,#000 0%,#000 78%,transparent 100%)}
  .page-flower--r{-webkit-mask-image:linear-gradient(to left,#000 0%,#000 78%,transparent 100%);
                          mask-image:linear-gradient(to left,#000 0%,#000 78%,transparent 100%)}
}
/* голуби держат ленту с кольцами — единая «корона» над именами, парит как целое */
.hero__crown{position:absolute;top:2%;left:50%;transform:translateX(-50%);
  z-index:1;width:min(92vw,560px);pointer-events:none;
  filter:drop-shadow(0 14px 16px rgba(110,88,73,.18));
  animation:crownFloat 6s ease-in-out infinite}
.crown-img{width:100%;height:auto;display:block}
@media (max-width:560px){
  .hero__crown{top:1.5%;width:108vw}
}
.hero__eyebrow{font-size:.74rem;letter-spacing:.38em;text-transform:uppercase;color:var(--accent-deep);margin-bottom:22px}
.hero__names{font-family:var(--script);font-size:clamp(3.2rem,13vw,5.4rem);line-height:1;font-weight:400;color:var(--ink);text-shadow:0 1px 12px rgba(248,241,234,.95)}
/* каллиграфические имена/заголовки картинками (как референс) */
.names-img{display:block;margin:0 auto;height:auto;
  filter:drop-shadow(0 0 4px #f8f1ea) drop-shadow(0 0 9px rgba(248,241,234,.95)) drop-shadow(0 1px 3px rgba(248,241,234,.9))}
.hero__names .names-img{width:min(94%,560px)}
.gate__names .names-img{width:min(90%,360px)}
.footer__names .names-img{width:min(82%,320px)}
/* заголовки секций — каллиграфия картинками */
.title-img{display:block;margin:0 auto;height:clamp(52px,11vw,66px);width:auto;max-width:96%;
  filter:drop-shadow(0 1px 8px rgba(248,241,234,.92))}
.eyebrow-img{display:block;margin:0 auto;height:clamp(26px,7vw,34px);width:auto;max-width:72%}
.amp{font-size:.5em;color:var(--accent);vertical-align:middle;font-weight:400}
.hero__rule{display:flex;align-items:center;justify-content:center;gap:14px;color:var(--accent);margin:22px 0}
.hero__rule span{height:1px;width:60px;background:var(--line)}
.hero__date{font-family:var(--serif);font-size:1.7rem;letter-spacing:.04em;color:var(--ink);text-shadow:0 0 5px #f8f1ea,0 0 11px rgba(248,241,234,.9),0 1px 2px rgba(248,241,234,.95)}
.hero__greeting{margin-top:22px;font-family:var(--script);font-size:clamp(2rem,7vw,2.8rem);line-height:1.15;color:var(--accent-deep);text-shadow:0 0 5px #f8f1ea,0 0 11px rgba(248,241,234,.9),0 1px 2px rgba(248,241,234,.95)}
.hero__sub{max-width:30ch;margin:14px auto 0;color:var(--ink-soft);font-size:.96rem;text-shadow:0 0 4px #f8f1ea,0 0 8px rgba(248,241,234,.92),0 1px 2px rgba(248,241,234,.95)}

/* ===== Обратный отсчёт ===== */
.countdown__grid{display:flex;justify-content:center;gap:14px;flex-wrap:wrap}
.cd{
  background:var(--white);border:1px solid var(--line);border-radius:18px;
  width:88px;padding:18px 6px;box-shadow:0 14px 30px -22px rgba(110,88,73,.5);
}
.cd__num{display:block;font-family:var(--serif);font-size:2.4rem;font-weight:500;color:var(--accent-deep);line-height:1}
.cd__label{display:block;margin-top:6px;font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft)}

/* ===== Приглашение ===== */
.invite__text p{font-family:var(--serif);font-size:1.32rem;color:var(--ink);margin:0 auto 16px;max-width:34ch}
.invite__text p:first-child{font-family:var(--script);font-size:clamp(2.4rem,8vw,3.2rem);line-height:1.15;color:var(--accent-deep);margin-bottom:22px}

/* ===== Программа ===== */
.timeline__list{max-width:430px;margin:0 auto;text-align:left}
.tl{display:flex;gap:20px;padding:18px 0;border-bottom:1px solid var(--line)}
.tl:last-child{border-bottom:none}
.tl__time{font-family:var(--serif);font-size:1.5rem;font-weight:500;color:var(--accent-deep);min-width:74px}
.tl__body{padding-top:3px}
.tl__title{font-size:1rem;color:var(--ink)}
.tl__note{font-size:.84rem;color:var(--ink-soft);margin-top:2px}

/* ===== Места ===== */
.venues{display:flex;flex-direction:column;gap:30px;max-width:540px;margin:0 auto}
.vcard{
  background:var(--white);border:1px solid var(--line);border-radius:22px;
  padding:26px 22px;box-shadow:var(--shadow);
}
.vcard__title{font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;color:var(--accent-deep);margin-bottom:10px}
.vcard__time{font-family:var(--serif);font-size:2.2rem;font-weight:500;color:var(--ink);line-height:1;margin-bottom:8px}
.vcard__sched{display:inline-flex;flex-direction:column;gap:9px;margin:2px auto 14px;text-align:left}
.vcard__sched-row{display:flex;align-items:baseline;gap:12px}
.vcard__sched-time{font-family:var(--serif);font-size:1.7rem;font-weight:500;color:var(--ink);line-height:1;min-width:3.4ch}
.vcard__sched-label{font-size:.82rem;letter-spacing:.06em;text-transform:uppercase;color:var(--accent-deep)}
.vcard__name{font-family:var(--serif);font-size:1.4rem;color:var(--ink)}
.vcard__addr{color:var(--ink-soft);margin-top:6px}
.vcard__note{font-size:.9rem;color:var(--sage);margin-top:8px}
.vcard .map{margin:20px auto 18px}
.vcard__name + .map{margin-top:18px}

/* ===== Дресс-код ===== */
.dress__text{max-width:36ch;margin:0 auto 22px;color:var(--ink)}
.dress__palette{display:flex;justify-content:center;flex-wrap:wrap;gap:16px;margin-bottom:22px}
.dress__palette span{
  position:relative;width:56px;height:56px;border-radius:50%;overflow:hidden;
  box-shadow:
    inset 7px 7px 13px rgba(255,255,255,.5),
    inset -6px -9px 16px rgba(0,0,0,.20),
    0 10px 20px -9px rgba(110,88,73,.55);
}
.dress__palette span::after{
  content:"";position:absolute;inset:0;border-radius:50%;
  background:linear-gradient(135deg, rgba(255,255,255,.6) 0%, rgba(255,255,255,0) 40%, rgba(0,0,0,0) 60%, rgba(0,0,0,.18) 100%);
}
.dress__palette span::before{
  content:"";position:absolute;top:16%;left:20%;width:34%;height:24%;border-radius:50%;
  background:rgba(255,255,255,.55);filter:blur(3px);transform:rotate(-25deg);
}
.dress__note{font-family:var(--serif);font-size:1.2rem;color:var(--accent-deep)}

/* ===== RSVP ===== */
.rsvp__deadline{color:var(--ink-soft);margin-bottom:30px}
.rsvp__form{max-width:440px;margin:0 auto;text-align:left;display:flex;flex-direction:column;gap:22px}
/* honeypot — скрыт от людей, в DOM для ботов (не display:none) */
.hp{position:absolute;left:-9999px;top:0;width:1px;height:1px;opacity:0;pointer-events:none}
.field{display:flex;flex-direction:column;gap:10px;border:none}
.field__label{font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:var(--accent-deep)}
.field__input{
  font-family:var(--sans);font-size:1rem;padding:.8em 1em;color:var(--ink);
  border:1px solid var(--line);border-radius:12px;background:var(--white);width:100%;
  transition:border .2s,box-shadow .2s;
}
.field__input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 4px rgba(201,169,166,.16)}
textarea.field__input{resize:vertical}
.choices{display:flex;flex-direction:column;gap:10px}
.choices--wrap{flex-direction:row;flex-wrap:wrap}
.choice{position:relative;cursor:pointer}
.choice input{position:absolute;opacity:0;inset:0;cursor:pointer}
.choice span{
  display:inline-block;padding:.6em 1.1em;border:1px solid var(--line);border-radius:999px;
  background:var(--white);font-size:.9rem;color:var(--ink);transition:all .2s;
}
.choice input:checked+span{background:var(--accent);border-color:var(--accent);color:var(--white)}
.choice input:focus-visible+span{box-shadow:0 0 0 4px rgba(201,169,166,.25)}
.rsvp__status{min-height:1.4em;font-size:.92rem;text-align:center;color:var(--sage)}
.rsvp__status.err{color:#b4524d}

/* ===== Контакты ===== */
.contacts__intro{max-width:44ch;margin:0 auto 26px;color:var(--ink);font-size:1.04rem;line-height:1.6}
.contacts__list{display:flex;flex-direction:column;gap:14px;align-items:center}
.contact{font-size:1.05rem}
.contact b{font-family:var(--serif);font-weight:500}
.contact a{color:var(--accent-deep);text-decoration:none;border-bottom:1px solid var(--line)}

/* ===== Подвал ===== */
.footer{text-align:center;padding:52px 24px 40px;background:transparent;position:relative;z-index:1}
.footer__rule{display:flex;align-items:center;justify-content:center;gap:14px;color:var(--accent);margin-bottom:18px}
.footer__rule span{height:1px;width:50px;background:var(--line)}
.footer__names{font-family:var(--script);font-size:2.2rem;color:var(--ink);margin-bottom:24px}
.credit{
  display:inline-flex;align-items:center;gap:8px;font-size:.72rem;letter-spacing:.16em;
  text-transform:uppercase;color:var(--ink-soft);text-decoration:none;
}
.credit b{
  font-family:var(--serif);font-weight:700;letter-spacing:.05em;color:var(--accent-deep);
  border:1px solid var(--accent);border-radius:6px;padding:2px 7px;font-size:.82rem;
}

/* ===== Цветочный декор (SVG-веточка через переменную) ===== */
:root{
  --sprig:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="200" height="90" viewBox="0 0 200 90"><g fill="none" stroke="%239caf88" stroke-width="1.4" stroke-linecap="round" opacity="0.9"><path d="M20 80 C70 60 120 40 185 18"/><path d="M60 66 C66 54 60 44 50 42"/><path d="M95 54 C101 42 95 32 85 30"/><path d="M130 42 C136 30 130 20 120 18"/></g><g fill="%23ffffff" stroke="%23c9a9a6" stroke-width="1"><circle cx="50" cy="40" r="4"/><circle cx="85" cy="28" r="4"/><circle cx="120" cy="16" r="4"/><circle cx="165" cy="20" r="4.5"/><circle cx="185" cy="18" r="3.5"/></g></svg>');
}
.floral{position:absolute;width:200px;height:90px;background:var(--sprig);background-repeat:no-repeat;background-size:contain;opacity:.7;pointer-events:none}
.floral--tl{top:24px;left:-30px;transform:rotate(-12deg)}
.floral--br{bottom:24px;right:-30px;transform:scale(-1,-1) rotate(-12deg)}
.floral--center{top:18px;left:50%;transform:translateX(-50%);opacity:.55}

/* ===== Адаптив ===== */
@media (max-width:480px){
  .section{padding:54px 20px}
  .cd{width:72px}
  .cd__num{font-size:2rem}
  .floral{display:none}
}
/* внутри карточки контент уже — отсчёт ужимаем, чтобы 4 в ряд внутри золотых линий */
@media (max-width:560px){
  .content-card .countdown__grid{gap:8px}
  .content-card .cd{width:66px;padding-left:6px;padding-right:6px}
  .content-card .cd__num{font-size:1.85rem}
}

/* плавное появление секций */
.reveal{opacity:0;transform:translateY(30px);
  transition:opacity .7s ease,transform .7s cubic-bezier(.2,.7,.2,1);
  transition-delay:var(--rd,0s)}
.reveal.in{opacity:1;transform:none}

/* ===== Календарь ===== */
.calendar__card{
  max-width:360px;margin:0 auto;background:var(--white);
  border:1px solid var(--line);border-radius:22px;padding:26px 22px 30px;
  box-shadow:var(--shadow);
}
.cal__head{font-family:var(--serif);font-size:1.5rem;color:var(--ink);margin-bottom:18px;letter-spacing:.04em}
.cal__grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}
.cal__dow{font-size:.66rem;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);padding-bottom:8px}
.cal__cell{aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:.95rem;color:var(--ink);border-radius:50%}
.cal__cell--muted{color:transparent}
.cal__cell--wknd{color:var(--accent-deep)}
.cal__cell--day{
  position:relative;color:var(--white);font-weight:500;
  background:var(--accent-deep);box-shadow:0 8px 20px -8px rgba(169,138,134,.95);
  animation:pulseDay 2.6s ease-in-out infinite;
}
.cal__cell--day::after{
  content:"❤";position:absolute;top:-14px;left:50%;transform:translateX(-50%);
  font-size:.7rem;color:var(--accent);
}
@keyframes pulseDay{0%,100%{transform:scale(1)}50%{transform:scale(1.12)}}
.calendar__note{margin-top:20px;font-family:var(--script);font-size:1.6rem;color:var(--accent-deep)}

/* ===== Карта ===== */
.map{position:relative;max-width:520px;margin:0 auto 28px}
.map__frame{
  position:relative;border-radius:20px;overflow:hidden;
  border:1px solid var(--line);box-shadow:var(--shadow);
  background:var(--bg-alt);
}
.map__frame iframe{
  width:100%;height:340px;border:0;display:block;
  /* «свадебный» нежный вид карты */
  filter:saturate(.72) sepia(.12) brightness(1.03) contrast(.96);
}
.map__corner{position:absolute;width:64px;height:64px;background:var(--sprig);
  background-repeat:no-repeat;background-size:contain;opacity:.85;pointer-events:none;z-index:2}
.map__corner--tl{top:-14px;left:-14px;transform:rotate(-18deg)}
.map__corner--br{bottom:-14px;right:-14px;transform:scale(-1,-1) rotate(-18deg)}

/* ===== Летящие лепестки ===== */
.petals{position:fixed;inset:0;overflow:hidden;pointer-events:none;z-index:55}
.petal{
  position:absolute;top:-8vh;width:13px;height:13px;
  background:radial-gradient(circle at 35% 30%, #e7bdb4 0%, #cf9d97 60%, #b3766f 100%);
  border-radius:50% 50% 50% 0;opacity:0;
  box-shadow:0 1px 3px rgba(169,138,134,.14);
  animation:fall linear infinite;
}
@keyframes fall{
  0%{transform:translateY(-8vh) translateX(0) rotate(0) scale(var(--s,1));opacity:0}
  12%{opacity:.5}
  50%{transform:translateY(50vh) translateX(28px) rotate(170deg) scale(var(--s,1))}
  88%{opacity:.45}
  100%{transform:translateY(110vh) translateX(52px) rotate(340deg) scale(var(--s,1));opacity:0}
}
/* праздничный дождь лепестков по кнопке «Отправить» */
.petal-burst{position:fixed;inset:0;pointer-events:none;z-index:60;overflow:hidden}
.petal-b{position:absolute;top:-8vh;width:14px;height:14px;
  background:radial-gradient(circle at 35% 30%,#e7bdb4 0%,#cf9d97 58%,#b3766f 100%);
  border-radius:50% 50% 50% 0;opacity:0;box-shadow:0 1px 3px rgba(169,138,134,.18);
  animation:petalFall linear forwards}
@keyframes petalFall{
  0%{transform:translateY(-8vh) translateX(0) rotate(0) scale(var(--s,1));opacity:0}
  10%{opacity:.95}
  85%{opacity:.85}
  100%{transform:translateY(112vh) translateX(var(--x,40px)) rotate(var(--r,360deg)) scale(var(--s,1));opacity:0}
}
.petal:nth-child(1){left:5%;--s:.7;animation-duration:15s;animation-delay:0s}
.petal:nth-child(2){left:14%;--s:1.1;animation-duration:19s;animation-delay:-4s}
.petal:nth-child(3){left:23%;--s:.85;animation-duration:13s;animation-delay:-9s}
.petal:nth-child(4){left:33%;--s:.6;animation-duration:21s;animation-delay:-2s}
.petal:nth-child(5){left:43%;--s:1;animation-duration:16s;animation-delay:-11s}
.petal:nth-child(6){left:52%;--s:.75;animation-duration:18s;animation-delay:-6s}
.petal:nth-child(7){left:62%;--s:1.05;animation-duration:14s;animation-delay:-13s}
.petal:nth-child(8){left:71%;--s:.7;animation-duration:20s;animation-delay:-3s}
.petal:nth-child(9){left:80%;--s:.9;animation-duration:17s;animation-delay:-8s}
.petal:nth-child(10){left:88%;--s:.8;animation-duration:15s;animation-delay:-15s}
.petal:nth-child(11){left:95%;--s:.65;animation-duration:22s;animation-delay:-5s}
.petal:nth-child(12){left:38%;--s:1.15;animation-duration:24s;animation-delay:-17s}

/* мягкое «парение» короны (голуби + лента + кольца как целое) */
@keyframes crownFloat{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(-9px)}}

/* ===== Вступительная анимация обложки ===== */
.hero__inner > *{opacity:0;animation:riseIn .9s ease forwards}
.hero__eyebrow{animation-delay:.1s}
.hero__names{animation-delay:.3s}
.hero__rule{animation-delay:.6s}
.hero__date{animation-delay:.75s}
.hero__sub{animation-delay:.9s}
.hero__greeting{animation-delay:1.05s}
@keyframes riseIn{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:none}}

/* лёгкое покачивание цветочного декора */
.floral--tl{animation:sway 6s ease-in-out infinite}
@keyframes sway{0%,100%{transform:translateY(0) rotate(-12deg)}50%{transform:translateY(-6px) rotate(-9deg)}}
.floral--br{animation:swayBr 7s ease-in-out infinite}
@keyframes swayBr{0%,100%{transform:scale(-1,-1) rotate(-12deg)}50%{transform:scale(-1,-1) translateY(6px) rotate(-9deg)}}
.floral--center{animation:swayC 6s ease-in-out infinite}
@keyframes swayC{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(-6px)}}

@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .petals{display:none}
  .hero__crown{animation:none}
  .hero__inner > *{opacity:1;animation:none}
  .floral,.cal__cell--day,.shimmer-bg{animation:none}
  .letter{animation:none;transform:translateY(20px);opacity:1}
  .env__flap{animation:none;transform:rotateX(173deg);z-index:1}
  .env__seal{display:none}
}
