/* ============ Палитра и базовые переменные ============ */
:root{
  --ivory:#f7f3ec;
  --cream:#efe7d9;
  --sage:#8a9a7b;
  --sage-deep:#5f6f52;
  --leaf:#9bb396;
  --gold:#c4a661;
  --gold-soft:#d8c08a;
  --ink:#3a3730;
  --ink-soft:#6b6457;
  --green-mono:#2d4222;
  --white:#fffdf9;
  --shadow:0 18px 50px rgba(58,55,48,.18);
  --serif:'Playfair Display', Georgia, serif;
  --body:'Montserrat', 'Segoe UI', sans-serif;
  --script:'Marck Script', cursive;
  --cormorant:'Cormorant Garamond', Georgia, serif;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:var(--body);
  background:var(--ivory);
  color:var(--ink);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
body.locked{overflow:hidden;height:100vh;touch-action:none}
img{display:block;max-width:100%}

/* ============ Монограмма-логотип (SVG) ============ */
.mono-logo{
  display:block;
  width:auto;height:auto;
  margin-left:auto;margin-right:auto;
  filter:drop-shadow(0 6px 14px rgba(45,66,34,.18));
}

/* ============ Листья-декор ============ */
.leaf{
  position:absolute;
  pointer-events:none;user-select:none;
  z-index:1;opacity:.55;
}

/* ============ Кнопка музыки ============ */
.music-btn{
  position:fixed;top:16px;right:16px;z-index:60;
  width:46px;height:46px;border-radius:50%;
  border:1px solid rgba(196,166,97,.6);
  background:rgba(255,253,249,.78);
  backdrop-filter:blur(6px);
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  box-shadow:0 6px 18px rgba(58,55,48,.18);
  transition:transform .25s ease, background .25s ease;
}
.music-btn:hover{transform:scale(1.06)}
.music-ico{display:flex;align-items:flex-end;gap:3px;height:18px}
.music-ico span{width:3px;height:6px;background:var(--gold);border-radius:2px;animation:eq 900ms ease-in-out infinite}
.music-ico span:nth-child(2){animation-delay:.15s}
.music-ico span:nth-child(3){animation-delay:.3s}
.music-ico span:nth-child(4){animation-delay:.45s}
@keyframes eq{0%,100%{height:5px}50%{height:18px}}
.music-btn.paused .music-ico span{animation-play-state:paused;height:5px}

/* ============ Intro overlay ============ */
.intro{
  position:fixed;inset:0;z-index:80;overflow:hidden;
  background:radial-gradient(circle at 50% 35%, #f1e9da 0%, #e6dac6 60%, #d8c8ad 100%);
  display:flex;align-items:center;justify-content:center;text-align:center;
  transition:opacity .9s ease, visibility .9s ease;
}
.intro.hide{opacity:0;visibility:hidden}
.intro-inner{padding:30px;position:relative;z-index:2}
.intro-mono{width:clamp(150px,42vw,210px)}
.intro-names{
  font-family:var(--cormorant);font-size:22px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--ink-soft);margin:14px 0 30px;
}
.enter-btn{
  font-family:var(--body);font-size:13px;letter-spacing:.14em;text-transform:uppercase;
  padding:14px 30px;border:1px solid var(--gold);
  background:transparent;color:var(--ink);cursor:pointer;border-radius:40px;
  transition:background .3s ease,color .3s ease;
}
.enter-btn:hover{background:var(--gold);color:#fff}
.intro-hint{margin-top:16px;font-size:11px;letter-spacing:.1em;color:var(--ink-soft);opacity:.8}
.intro-leaf-l{top:-30px;left:-70px;width:230px;transform:rotate(20deg);opacity:.5}
.intro-leaf-r{bottom:-40px;right:-70px;width:240px;transform:scaleX(-1) rotate(20deg);opacity:.5}

/* ============ Секции ============ */
.screen{
  position:relative;min-height:100svh;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:70px 22px;overflow:hidden;
}

.eyebrow{font-family:var(--body);font-size:12px;letter-spacing:.34em;text-transform:uppercase;color:var(--gold);margin-bottom:18px}
.eyebrow.dark{color:var(--gold)}
.section-head{text-align:center;margin-bottom:34px;position:relative;z-index:2}
.section-head h2,.date-title{font-family:var(--serif);font-weight:500;color:var(--ink);font-size:clamp(30px,8vw,46px)}

.divider{display:flex;align-items:center;justify-content:center;gap:12px;color:var(--gold);margin:18px auto}
.divider span{display:block;width:46px;height:1px;background:linear-gradient(90deg,transparent,var(--gold-soft))}
.divider span:last-child{background:linear-gradient(90deg,var(--gold-soft),transparent)}
.divider.dark span{background:linear-gradient(90deg,transparent,var(--gold))}
.divider.dark span:last-child{background:linear-gradient(90deg,var(--gold),transparent)}

/* ============ Экран 1 — Hero ============ */
.hero{justify-content:flex-start;padding-top:84px;text-align:center}
.hero .eyebrow{color:#a6863f;text-shadow:0 0 10px rgba(247,243,236,.95)}
.hero-bg{
  position:absolute;inset:0;z-index:0;
  background:url('img/hero-wall.jpg') center 32%/cover no-repeat;
  transform:scale(1.04);
  animation:slowZoom 20s ease-in-out infinite alternate;
}
@keyframes slowZoom{to{transform:scale(1.12)}}
.hero-veil{
  position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg,
    rgba(247,243,236,.94) 0%,
    rgba(247,243,236,.72) 22%,
    rgba(247,243,236,.5) 40%,
    rgba(247,243,236,.28) 58%,
    rgba(247,243,236,.05) 76%,
    rgba(247,243,236,.4) 100%);
}
.hero-leaf-l{top:54%;left:-90px;width:210px;transform:rotate(8deg);opacity:.5;z-index:2}
.hero-leaf-r{top:50%;right:-90px;width:220px;transform:scaleX(-1) rotate(8deg);opacity:.5;z-index:2}
.hero-card{position:relative;z-index:3;display:flex;flex-direction:column;align-items:center}
.hero-mono{width:clamp(170px,52vw,250px)}
.names{
  font-family:var(--serif);font-weight:700;color:var(--ink);
  font-size:clamp(32px,10vw,60px);line-height:1.1;letter-spacing:.01em;margin-top:6px;
  text-shadow:0 0 12px rgba(247,243,236,.98),0 0 24px rgba(247,243,236,.95),0 0 40px rgba(247,243,236,.85),0 2px 4px rgba(58,55,48,.22);
}
.names span{display:block}
.names .amp-script{font-family:var(--script);color:var(--gold);font-weight:400;font-size:.62em;display:block;margin:.02em 0;text-shadow:0 0 14px rgba(247,243,236,.95)}
.hero-date{font-family:var(--cormorant);font-weight:600;font-size:clamp(18px,5vw,24px);letter-spacing:.3em;text-transform:uppercase;margin-top:6px;color:var(--ink);text-shadow:0 0 12px rgba(247,243,236,.98),0 0 22px rgba(247,243,236,.9),0 1px 3px rgba(58,55,48,.2)}

.scroll-cue{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);z-index:4;width:26px;height:42px;border:1px solid var(--ink-soft);border-radius:14px;display:flex;justify-content:center;padding-top:8px;opacity:.7}
.scroll-cue span{width:3px;height:8px;background:var(--ink-soft);border-radius:2px;animation:scrolldot 1.6s ease-in-out infinite}
@keyframes scrolldot{0%{opacity:0;transform:translateY(-4px)}40%{opacity:1}80%{opacity:0;transform:translateY(12px)}}

/* ============ Экран 2 — История (masonry-галерея) ============ */
.story{background:var(--ivory)}
.story-leaf{top:-30px;right:-80px;width:230px;transform:scaleX(-1) rotate(12deg);opacity:.32}
.gallery{column-count:2;column-gap:12px;width:100%;max-width:680px;margin-bottom:34px;position:relative;z-index:2}
.gallery figure{break-inside:avoid;margin:0 0 12px;border-radius:12px;overflow:hidden;box-shadow:var(--shadow);position:relative}
.gallery figure::after{content:"";position:absolute;inset:0;box-shadow:inset 0 0 0 1px rgba(196,166,97,.3);border-radius:12px;pointer-events:none}
.gallery img{width:100%;height:auto;display:block;transition:transform .8s ease}
.gallery figure:hover img{transform:scale(1.05)}

.story-text{max-width:560px;text-align:center;position:relative;z-index:2}
.story-text p{font-family:var(--cormorant);font-size:clamp(18px,4.6vw,22px);color:var(--ink-soft);margin-bottom:14px}
.story-text b{color:var(--ink);font-weight:600}
.story-sign{font-family:var(--script);font-size:clamp(22px,6vw,30px)!important;color:var(--sage-deep)!important;margin-top:6px}

/* ============ Экран 3 — Дата ============ */
.date{color:var(--white);text-align:center}
.date-bg{position:absolute;inset:0;background:url('img/date-rings.jpg') center/cover no-repeat;transform:scale(1.05)}
.date-veil{position:absolute;inset:0;background:linear-gradient(180deg,rgba(50,46,40,.55),rgba(50,46,40,.7))}
.date-content{position:relative;z-index:2;width:100%;max-width:560px}
.date .eyebrow{color:rgba(255,253,249,.85)}
.date-title{color:var(--white);text-shadow:0 3px 18px rgba(0,0,0,.4)}
.date-big{display:flex;align-items:center;justify-content:center;gap:18px;margin:18px 0 6px}
.db-part{display:flex;flex-direction:column;align-items:center}
.db-num{font-family:var(--serif);font-size:clamp(46px,15vw,86px);line-height:1;color:var(--gold-soft)}
.db-lbl{font-family:var(--cormorant);letter-spacing:.28em;text-transform:uppercase;font-size:14px;margin-top:6px;color:rgba(255,253,249,.9)}
.db-sep{font-size:22px;color:var(--gold-soft)}
.date-time{font-family:var(--cormorant);font-size:clamp(18px,5vw,24px);letter-spacing:.16em;margin-top:6px;color:var(--white)}
.date .divider span{background:linear-gradient(90deg,transparent,rgba(255,253,249,.6))}
.date .divider span:last-child{background:linear-gradient(90deg,rgba(255,253,249,.6),transparent)}
.cd-label{font-family:var(--cormorant);letter-spacing:.2em;text-transform:uppercase;font-size:13px;color:rgba(255,253,249,.85);margin-bottom:14px}
.countdown{display:flex;justify-content:center;gap:10px}
.cd-cell{background:rgba(255,253,249,.12);backdrop-filter:blur(4px);border:1px solid rgba(255,253,249,.28);border-radius:12px;padding:14px 6px;min-width:70px;display:flex;flex-direction:column;align-items:center}
.cd-num{font-family:var(--serif);font-size:clamp(26px,7vw,38px);line-height:1;color:var(--white)}
.cd-unit{font-size:10px;letter-spacing:.16em;text-transform:uppercase;margin-top:6px;color:rgba(255,253,249,.8)}

/* ============ Экран 4 — Локация ============ */
.venue{background:var(--cream)}
.venue-leaf{bottom:-40px;left:-80px;width:200px;transform:rotate(-12deg);opacity:.35}
.hosts{text-align:center;margin-bottom:30px;position:relative;z-index:2}
.hosts-line{font-family:var(--cormorant);font-size:18px;letter-spacing:.1em;color:var(--ink-soft)}
.hosts-names{font-family:var(--script);font-size:clamp(30px,9vw,46px);color:var(--sage-deep);margin-top:4px}
.venue-card{background:var(--white);border-radius:18px;box-shadow:var(--shadow);border:1px solid rgba(196,166,97,.3);padding:34px 26px;text-align:center;max-width:420px;width:100%;position:relative;z-index:2}
.vc-ico{font-size:30px;color:var(--sage)}
.vc-label{font-family:var(--body);font-size:12px;letter-spacing:.24em;text-transform:uppercase;color:var(--gold);margin:10px 0 12px}
.vc-addr{font-family:var(--cormorant);font-size:clamp(19px,5vw,23px);color:var(--ink);line-height:1.55}
.map-btn{display:inline-flex;align-items:center;gap:9px;margin-top:22px;font-family:var(--body);font-size:13px;letter-spacing:.12em;text-transform:uppercase;padding:14px 28px;border-radius:40px;text-decoration:none;background:var(--sage-deep);color:#fff;transition:transform .25s ease,background .25s ease;box-shadow:0 10px 24px rgba(95,111,82,.35)}
.map-btn:hover{transform:translateY(-2px);background:var(--sage)}
.map-pin{color:var(--gold-soft);font-size:11px}

/* ============ Экран 5 — RSVP ============ */
.rsvp{background:var(--ivory)}
.rsvp-leaf{top:-30px;left:-80px;width:220px;transform:rotate(14deg);opacity:.3}
.rsvp-form{width:100%;max-width:440px;display:flex;flex-direction:column;gap:18px;position:relative;z-index:2}
.field{display:flex;flex-direction:column;gap:8px}
.field>span{font-family:var(--body);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft)}
.field input[type=text],.field select,.field textarea{font-family:var(--cormorant);font-size:18px;color:var(--ink);background:var(--white);border:1px solid rgba(196,166,97,.4);border-radius:12px;padding:13px 15px;width:100%;outline:none;transition:border .25s ease,box-shadow .25s ease}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(196,166,97,.18)}
.field textarea{resize:vertical}
.choice{display:flex;flex-direction:column;gap:10px}
.opt{display:flex;align-items:center;gap:12px;cursor:pointer;background:var(--white);border:1px solid rgba(196,166,97,.4);border-radius:12px;padding:13px 15px;font-family:var(--cormorant);font-size:18px;transition:border .25s ease,background .25s ease}
.opt input{accent-color:var(--sage-deep);width:18px;height:18px}
.opt:has(input:checked){border-color:var(--sage);background:#f3f1e8}
.submit-btn{font-family:var(--body);font-size:13px;letter-spacing:.14em;text-transform:uppercase;padding:16px;border:none;border-radius:40px;cursor:pointer;margin-top:6px;background:var(--gold);color:#fff;transition:transform .25s ease,background .25s ease;box-shadow:0 10px 26px rgba(196,166,97,.4)}
.submit-btn:hover{transform:translateY(-2px);background:#b8974f}
.form-note{font-size:12px;text-align:center;color:#b14b3f;min-height:14px;letter-spacing:.03em}
.rsvp-done{text-align:center;max-width:420px;position:relative;z-index:2;animation:fadeUp .7s ease both}
.done-ico{font-size:42px;color:var(--gold)}
.done-title{font-family:var(--serif);font-size:34px;color:var(--ink);margin:6px 0}
.done-text{font-family:var(--cormorant);font-size:20px;color:var(--ink-soft)}
.contact{text-align:center;margin-top:40px;position:relative;z-index:2}
.contact-label{font-family:var(--body);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:8px}
.contact-phone{font-family:var(--serif);font-size:clamp(22px,6vw,28px);color:var(--sage-deep);text-decoration:none;letter-spacing:.04em}
.contact-phone:hover{color:var(--gold)}
.footer{text-align:center;margin-top:48px;color:var(--ink-soft);position:relative;z-index:2}
.footer-mono{width:90px;margin:0 auto 8px}
.footer p{font-family:var(--cormorant);letter-spacing:.18em;text-transform:uppercase;font-size:12px}

/* ============ Reveal-анимации ============ */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .9s ease,transform .9s ease}
.reveal.in{opacity:1;transform:none}
@keyframes fadeUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}

/* ============ Адаптив ============ */
@media(min-width:720px){
  .gallery{column-count:3;max-width:900px}
  .cd-cell{min-width:90px}
  .hero-leaf-l,.hero-leaf-r{width:300px}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important}
  .reveal{opacity:1;transform:none}
  html{scroll-behavior:auto}
}
