/* ============================================================
   ATELIER — wedding invitation
   путь:  invite/static/invite/css/style.css
   Tokens
============================================================ */
:root{
  --noir:#14100f;
  --noir-2:#1d1715;
  --paper:#f6efe6;
  --paper-2:#faf5ed;
  --paper-3:#efe4d6;

  --bordeaux:#7a2a33;
  --bordeaux-deep:#5c1d25;
  --rose:#cf9f9c;
  --rose-deep:#b97f7c;
  --sage:#5b6b56;

  --gold:#bd9a57;
  --gold-soft:#d8bd86;
  --gold-line:rgba(189,154,87,.45);

  --ink:#2a2022;
  --ink-soft:#6c5557;
  --ink-faint:#9a8385;

  --line:rgba(108,85,87,.16);
  --shadow:0 30px 70px rgba(58,34,38,.16);

  --serif:'Cormorant Garamond', serif;
  --num:'Oranienbaum', serif;
  --sans:'Inter', sans-serif;
  --script:'Marck Script', cursive;

  --ease:cubic-bezier(.22,.61,.36,1);
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  color:var(--ink);
  font-family:var(--sans);
  background:var(--paper);
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer}
input,textarea,select{font:inherit}

body::before{
  content:"";position:fixed;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(120% 80% at 50% -10%, rgba(255,250,242,.9), transparent 55%),
    radial-gradient(80% 60% at 100% 30%, rgba(207,159,156,.10), transparent 55%),
    radial-gradient(70% 60% at 0% 70%, rgba(91,107,86,.07), transparent 55%);
}

/* film grain */
.grain{
  position:fixed;inset:-50%;z-index:9000;pointer-events:none;opacity:.05;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='120' height='120'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  animation:grain 6s steps(6) infinite;
}
@keyframes grain{
  0%{transform:translate(0,0)}10%{transform:translate(-4%,-4%)}30%{transform:translate(3%,-2%)}
  50%{transform:translate(-2%,3%)}70%{transform:translate(4%,2%)}90%{transform:translate(-3%,1%)}100%{transform:translate(0,0)}
}

.page-shell{max-width:100%;overflow-x:hidden}
.wrap{position:relative;z-index:1}

.petals-canvas{position:fixed;inset:0;z-index:8000;pointer-events:none}

/* ---------- Loader ---------- */
#loader{
  position:fixed;inset:0;z-index:10000;display:grid;place-items:center;
  background:radial-gradient(circle at 50% 40%,#211a18,#0c0908);
  transition:opacity 1s var(--ease),visibility 1s;
}
#loader.done{opacity:0;visibility:hidden}
.loader-mono{font-family:var(--serif);color:var(--gold-soft);text-align:center}
.loader-mono .amp{font-size:clamp(3rem,11vw,5.5rem);letter-spacing:.04em;display:flex;gap:.18em;align-items:center;justify-content:center}
.loader-mono .amp span{opacity:0;transform:translateY(14px);animation:rise .9s var(--ease) forwards}
.loader-mono .amp span:nth-child(2){animation-delay:.18s}
.loader-mono .amp span:nth-child(3){animation-delay:.36s}
@keyframes rise{to{opacity:1;transform:none}}
.loader-line{width:0;height:1px;margin:18px auto 0;background:var(--gold-line);animation:lline 1.6s .5s var(--ease) forwards}
@keyframes lline{to{width:120px}}
.loader-mono small{display:block;margin-top:14px;letter-spacing:.42em;font-family:var(--sans);font-size:.6rem;color:rgba(216,189,134,.6);text-transform:uppercase}

/* ---------- Custom cursor ---------- */
.cursor,.cursor-ring{position:fixed;top:0;left:0;border-radius:50%;pointer-events:none;z-index:9500;mix-blend-mode:difference}
.cursor{width:7px;height:7px;background:#fff;transform:translate(-50%,-50%)}
.cursor-ring{width:38px;height:38px;border:1px solid rgba(255,255,255,.6);transform:translate(-50%,-50%);transition:width .25s,height .25s,border-color .25s,opacity .25s}
.cursor-ring.hover{width:62px;height:62px;border-color:var(--gold-soft)}
body.touch .cursor,body.touch .cursor-ring{display:none}

/* ---------- Buttons ---------- */
.btn{
  --bg1:var(--bordeaux);--bg2:var(--bordeaux-deep);
  position:relative;display:inline-flex;align-items:center;justify-content:center;gap:.6em;
  min-height:58px;padding:0 32px;border:none;border-radius:999px;
  font-family:var(--sans);font-size:.82rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;
  color:#f7eee6;background:linear-gradient(160deg,var(--bg1),var(--bg2));
  box-shadow:0 16px 34px rgba(92,29,37,.30),inset 0 1px 0 rgba(255,255,255,.14);
  overflow:hidden;transition:transform .4s var(--ease),box-shadow .4s var(--ease);
  will-change:transform;
}
.btn::after{content:"";position:absolute;top:0;left:-120%;width:60%;height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.35),transparent);transform:skewX(-18deg);transition:left .7s var(--ease)}
.btn:hover{box-shadow:0 22px 44px rgba(92,29,37,.40),inset 0 1px 0 rgba(255,255,255,.2)}
.btn:hover::after{left:140%}
.btn:focus-visible{outline:2px solid var(--gold);outline-offset:3px}
.btn.ghost{--bg1:transparent;--bg2:transparent;color:var(--ink);border:1px solid var(--gold-line);box-shadow:none;background:rgba(255,255,255,.3);backdrop-filter:blur(6px)}
.btn.ghost:hover{border-color:var(--gold);box-shadow:0 10px 26px rgba(189,154,87,.18)}
.btn.gold{--bg1:#caa765;--bg2:#a47f3f;color:#2a1c10;box-shadow:0 16px 34px rgba(164,127,63,.3)}
.btn.full{width:100%}

/* ---------- Shared typography ---------- */
.eyebrow{
  display:inline-flex;align-items:center;gap:.7em;
  font-family:var(--sans);font-size:.66rem;letter-spacing:.42em;text-transform:uppercase;color:var(--bordeaux);
}
.eyebrow::before,.eyebrow::after{content:"";width:30px;height:1px;background:var(--gold-line)}
.eyebrow.solo::before{display:none}
.display{font-family:var(--serif);font-weight:600;line-height:.95;letter-spacing:-.01em;color:var(--ink)}

.section{position:relative;z-index:1;padding:clamp(72px,12vw,140px) 22px;max-width:1180px;margin:0 auto}
.center{text-align:center}

/* hairline gold divider */
.ribbon-rule{position:relative;height:60px;display:grid;place-items:center;z-index:2}
.ribbon-rule::before{content:"";position:absolute;left:50%;top:0;width:1px;height:100%;background:linear-gradient(var(--gold-line),transparent)}
.ribbon-rule span{width:7px;height:7px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 5px rgba(189,154,87,.12)}

/* reveal base */
.reveal{opacity:0;transform:translateY(34px)}
.reveal-stagger>*{opacity:0;transform:translateY(26px)}

/* ============================================================
   HERO
============================================================ */
.hero{
  position:relative;min-height:100svh;display:flex;flex-direction:column;
  align-items:center;justify-content:center;text-align:center;
  color:#f4ece2;overflow:hidden;background:var(--noir);z-index:1;
}
.hero-media{position:absolute;inset:0;z-index:0}
.hero-media img{
  width:100%;height:120%;object-fit:cover;object-position:50% 26%;
  filter:grayscale(.12) contrast(1.1) brightness(.76) saturate(1.04);
  will-change:transform;
}
.hero-media::after{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(98% 82% at 50% 30%,transparent,rgba(12,9,8,.30) 72%,rgba(12,9,8,.68)),
    linear-gradient(180deg,rgba(12,9,8,.30),transparent 26%,rgba(12,9,8,.44));
}
.hero-webgl{position:absolute;inset:0;z-index:1;pointer-events:none;mix-blend-mode:screen}
.hero-sweep{position:absolute;top:-20%;left:-30%;width:40%;height:140%;z-index:1;pointer-events:none;
  background:linear-gradient(90deg,transparent,rgba(255,247,230,.10),transparent);transform:skewX(-16deg);
  animation:sweep 9s var(--ease) infinite}
@keyframes sweep{0%{left:-40%;opacity:0}20%{opacity:.8}55%{left:130%;opacity:.4}100%{left:130%;opacity:0}}

.hero-inner{position:relative;z-index:2;padding:0 18px;will-change:transform}
.hero-kicker{margin-bottom:26px;color:var(--gold-soft);justify-content:center}
.hero-kicker::before,.hero-kicker::after{background:rgba(216,189,134,.5)}
.hero-names{
  font-family:var(--serif);font-weight:500;line-height:.9;letter-spacing:-.01em;
  font-size:clamp(3.6rem,15vw,10rem);color:#fbf3e9;margin:0;
  text-shadow:0 20px 50px rgba(0,0,0,.5);
}
.hero-names .amp{display:block;font-style:italic;font-size:.42em;color:var(--gold-soft);margin:.12em 0;letter-spacing:.02em}
.hero-sub{margin:30px auto 0;max-width:30ch;font-size:1.02rem;line-height:1.7;color:rgba(244,236,226,.82)}
.hero-meta{margin-top:30px;display:flex;gap:20px;align-items:center;justify-content:center;flex-wrap:wrap;
  font-family:var(--num);letter-spacing:.18em;font-size:1.05rem;color:#f0e6d9}
.hero-meta i{width:5px;height:5px;border-radius:50%;background:var(--gold);font-style:normal}
.hero-cta{margin-top:42px;display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

.scroll-cue{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);z-index:3;display:grid;justify-items:center;gap:10px;color:rgba(244,236,226,.7);font-family:var(--sans);font-size:.6rem;letter-spacing:.3em;text-transform:uppercase}
.scroll-cue .bar{width:1px;height:46px;background:linear-gradient(var(--gold-soft),transparent);position:relative;overflow:hidden}
.scroll-cue .bar::after{content:"";position:absolute;top:-50%;left:0;width:100%;height:50%;background:var(--gold-soft);animation:cue 2.2s var(--ease) infinite}
@keyframes cue{0%{top:-50%}60%,100%{top:120%}}

/* ============================================================
   MARQUEE
============================================================ */
.marquee{position:relative;z-index:1;background:var(--noir);color:#efe1cf;overflow:hidden;padding:18px 0;border-top:1px solid rgba(189,154,87,.2);border-bottom:1px solid rgba(189,154,87,.2)}
.marquee-track{display:flex;gap:48px;white-space:nowrap;width:max-content;animation:marq 28s linear infinite;font-family:var(--serif);font-style:italic;font-size:1.5rem;letter-spacing:.04em}
.marquee-track span{display:inline-flex;align-items:center;gap:48px;color:#e9d9c4}
.marquee-track span::after{content:"✦";color:var(--gold)}
@keyframes marq{to{transform:translateX(-50%)}}

/* ============================================================
   ENVELOPE
============================================================ */
.envelope-section{display:grid;place-items:center;perspective:1600px}
.env-head{margin-bottom:48px}
.env-head .display{font-size:clamp(2.2rem,6vw,4.4rem)}
.envelope{position:relative;width:min(560px,90vw);aspect-ratio:1.5/1;transform-style:preserve-3d;overflow:visible;margin-bottom:clamp(18px,6vw,50px)}
.env-body{position:absolute;inset:0;z-index:1;border-radius:8px;background:
  linear-gradient(160deg,#864049,#5c1d25);box-shadow:var(--shadow),inset 0 0 60px rgba(0,0,0,.25);overflow:hidden}
.env-body::after{content:"";position:absolute;inset:0;background:
  linear-gradient(120deg,transparent 40%,rgba(255,255,255,.06) 50%,transparent 60%)}
/* письмо — отдельной карточкой ПОВЕРХ конверта, ничем не обрезается */
.env-card{
  position:absolute;left:7%;right:7%;top:15%;z-index:8;
  padding:clamp(20px,4vw,30px) clamp(18px,4vw,28px);
  border-radius:6px;text-align:center;
  background:linear-gradient(180deg,var(--paper-2),var(--paper-3));
  border:1px solid rgba(115,89,82,.14);
  box-shadow:0 26px 46px rgba(40,20,24,.30),inset 0 1px 0 rgba(255,255,255,.7);
}
.env-card .eyebrow{margin-bottom:10px;justify-content:center}
.env-card h3{font-family:var(--serif);font-weight:600;font-size:clamp(1.3rem,3.6vw,2rem);line-height:1.12;margin:0 0 10px;color:var(--ink)}
.env-card p{margin:0 auto;max-width:32ch;line-height:1.62;color:var(--ink-soft);font-size:.92rem}
.env-front{position:absolute;inset:0;z-index:3;border-radius:8px;overflow:hidden;
  clip-path:polygon(0 38%,50% 100%,100% 38%,100% 100%,0 100%)}
.env-front::before{content:"";position:absolute;inset:0;background:linear-gradient(160deg,#7a2a33,#561b23)}
.env-front::after{content:"";position:absolute;left:0;right:0;bottom:0;top:38%;
  background:linear-gradient(180deg,rgba(255,255,255,.05),transparent)}
.env-flap{position:absolute;left:0;right:0;top:0;height:62%;z-index:5;transform-origin:top center;
  clip-path:polygon(0 0,100% 0,50% 100%);
  background:linear-gradient(180deg,#8a3742,#67222b);
  box-shadow:0 6px 14px rgba(0,0,0,.2);backface-visibility:hidden}
.env-seal{position:absolute;left:50%;top:44%;width:62px;height:62px;border-radius:50%;z-index:6;transform:translate(-50%,-50%);
  background:radial-gradient(circle at 35% 30%,#caa765,#8a5e2a);box-shadow:0 6px 14px rgba(0,0,0,.35),inset 0 2px 4px rgba(255,255,255,.3);
  display:grid;place-items:center;font-family:var(--serif);font-style:italic;color:#3a2410;font-size:1.4rem;transition:opacity .3s}
.env-hint{margin-top:30px;font-family:var(--sans);font-size:.66rem;letter-spacing:.34em;text-transform:uppercase;color:var(--ink-faint)}

/* ============================================================
   DATE / calendar
============================================================ */
.date-section{display:grid;justify-items:center;text-align:center}
.date-big{font-family:var(--serif);font-weight:600;font-size:clamp(2.6rem,9vw,6rem);color:var(--bordeaux);line-height:.9;margin:0}
.date-big em{font-style:italic;color:var(--ink)}
.date-sub{margin:18px auto 0;max-width:34ch;color:var(--ink-soft);line-height:1.7}

.cal{margin-top:54px;width:min(380px,86vw);border-radius:22px;overflow:hidden;background:var(--paper-2);
  box-shadow:var(--shadow);border:1px solid var(--line);position:relative}
.cal-top{background:linear-gradient(160deg,#2f4036,#1f2b25);padding:26px 0 22px;text-align:center;position:relative}
.cal-top::after{content:"";position:absolute;left:0;right:0;bottom:0;height:1px;background:rgba(255,255,255,.12)}
.cal-rings{position:absolute;top:-10px;left:0;right:0;display:flex;justify-content:space-between;padding:0 64px}
.cal-rings i{width:13px;height:34px;border-radius:999px;background:linear-gradient(180deg,#caa765,#8a5e2a)}
.cal-month{font-family:var(--serif);color:#f3ead9;font-size:1.5rem;letter-spacing:.12em}
.cal-body{padding:20px 18px 26px}
.cal-week,.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:7px;text-align:center}
.cal-week{margin-bottom:10px}
.cal-week span{font-size:.74rem;letter-spacing:.06em;color:var(--ink-faint);font-weight:600}
.cal-grid span{aspect-ratio:1;display:grid;place-items:center;font-family:var(--num);font-size:1.02rem;color:var(--ink);position:relative}
.cal-grid .mute{opacity:0}
.cal-grid .heart{color:#fff;font-weight:700}
.cal-grid .heart::before{content:"";position:absolute;inset:-4px;background:
  radial-gradient(circle at 50% 42%,var(--rose-deep),var(--bordeaux));
  clip-path:path("M22 38C8 28 2 20 2 12 2 6 6 2 12 2 16 2 20 5 22 9 24 5 28 2 32 2 38 2 42 6 42 12 42 20 36 28 22 38Z");
  z-index:-1;box-shadow:0 8px 18px rgba(122,42,51,.4)}

/* ============================================================
   LOCATION
============================================================ */
.location-section{position:relative;text-align:center;overflow:hidden}
.outline-word{font-family:var(--serif);font-weight:700;text-transform:uppercase;line-height:.82;
  font-size:clamp(3.4rem,17vw,12rem);letter-spacing:-.01em;color:transparent;
  -webkit-text-stroke:1.4px rgba(122,42,51,.35);position:relative;z-index:0}
.outline-word .fill{position:absolute;inset:0;color:var(--bordeaux);-webkit-text-stroke:0;
  clip-path:inset(0 100% 0 0);will-change:clip-path}
.loc-card{position:relative;z-index:2;margin:-2vw auto 0;max-width:560px;display:grid;gap:22px;justify-items:center}
.loc-photo{width:min(320px,80vw);aspect-ratio:1/1.05;border-radius:20px;overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--line);
  transform-style:preserve-3d;will-change:transform}
.loc-photo img{width:100%;height:100%;object-fit:cover;filter:saturate(.92) contrast(.98)}
.loc-name{font-family:var(--serif);font-weight:600;font-size:clamp(1.8rem,5vw,2.8rem);color:var(--ink);margin:14px 0 8px}
.loc-addr{color:var(--ink-soft);line-height:1.6;max-width:26ch;margin:0 auto}

/* ============================================================
   TIMELINE
============================================================ */
.timeline-section{text-align:center}
.ribbon-wrap{position:relative;width:min(620px,94vw);margin:54px auto 0;aspect-ratio:.62/1}
.ribbon-svg{position:absolute;inset:0;width:100%;height:100%;overflow:visible}
.ribbon-svg .bg{fill:none;stroke:rgba(122,42,51,.14);stroke-width:2}
.ribbon-svg .draw{fill:none;stroke:url(#goldgrad);stroke-width:2.4;stroke-linecap:round;
  filter:drop-shadow(0 0 4px rgba(189,154,87,.4))}
.heart-rider{position:absolute;top:0;left:0;width:34px;height:32px;z-index:4;transform:translate(-50%,-50%);
  filter:drop-shadow(0 8px 12px rgba(122,42,51,.35))}
.heart-rider svg{width:100%;height:100%;fill:var(--bordeaux)}
.tl-item{position:absolute;width:min(230px,40vw);z-index:3}
.tl-item .t{font-family:var(--serif);font-weight:700;font-size:clamp(2rem,6vw,3.2rem);color:var(--bordeaux);line-height:.9}
.tl-item h4{font-family:var(--serif);font-weight:600;font-size:1.3rem;margin:6px 0 6px;color:var(--ink)}
.tl-item p{margin:0;font-size:.9rem;line-height:1.55;color:var(--ink-soft)}
.tl-1{left:2%;top:7%;text-align:left}
.tl-2{right:2%;top:40%;text-align:right}
.tl-3{left:2%;top:74%;text-align:left}

/* ============================================================
   DRESS CODE
============================================================ */
.dress-section{text-align:center}
.palette{display:flex;justify-content:center;gap:clamp(10px,3vw,18px);flex-wrap:nowrap;margin:34px 0 44px}
.swatch{width:clamp(46px,12vw,60px);height:clamp(46px,12vw,60px);flex:0 0 auto;border-radius:50%;position:relative;overflow:hidden;
  box-shadow:0 10px 22px rgba(0,0,0,.1),inset 0 2px 3px rgba(255,255,255,.4),inset 0 -10px 16px rgba(0,0,0,.08);
  border:1px solid rgba(255,255,255,.4);transition:transform .4s var(--ease)}
.swatch::before{content:"";position:absolute;inset:-20%;background:
  conic-gradient(from 200deg,transparent,rgba(255,255,255,.4),transparent 120deg,rgba(0,0,0,.06),transparent 250deg,rgba(255,255,255,.3),transparent);
  animation:silk 7s linear infinite}
@keyframes silk{to{transform:rotate(360deg)}}
.swatch:hover{transform:translateY(-4px) scale(1.06)}
.s1{background:linear-gradient(145deg,#dde4ef,#8fa3bf)}
.s2{background:linear-gradient(145deg,#f5dde4,#c08e9d)}
.s3{background:linear-gradient(145deg,#ecdac9,#cda588)}
.s4{background:linear-gradient(145deg,#d2d4ba,#9ea37c)}
.s5{background:linear-gradient(145deg,#a17963,#5a3528)}
.s6{background:linear-gradient(145deg,#e8d2c2,#bc917e)}

/* разбросанная editorial-галерея: картинки целиком, лёгкий хаос */
.gallery{column-count:2;column-gap:16px;max-width:720px;margin:6px auto 0}
@media(min-width:760px){.gallery{column-count:3;column-gap:24px;max-width:920px}}
.gallery .g{break-inside:avoid;margin:0 0 20px;position:relative;
  transform:rotate(var(--r,0deg));transition:transform .55s var(--ease);will-change:transform}
.gallery .g:hover{transform:rotate(0deg) scale(1.045);z-index:3}
.gallery .g-inner{position:relative;border-radius:16px;overflow:hidden;
  box-shadow:0 18px 40px rgba(58,34,38,.18);will-change:transform,opacity}
.gallery .g-inner::after{content:"";position:absolute;inset:0;border:1px solid rgba(189,154,87,.28);
  border-radius:16px;pointer-events:none}
.gallery img{width:100%;height:auto;display:block;filter:saturate(1.03) contrast(1.02)}
.g1{--r:-3deg}
.g2{--r:2.6deg;margin-top:24px}
.g3{--r:-1.8deg}
.g4{--r:3.2deg;margin-top:32px}
.g5{--r:-2.6deg;margin-top:14px}
.g6{--r:2deg;margin-top:28px}
@media(max-width:760px){.g2,.g3,.g4,.g5,.g6{margin-top:0}}
.dress-note{margin:40px auto 0;max-width:46ch;line-height:1.75;color:var(--ink-soft);font-size:.96rem}
.dress-note strong{color:var(--bordeaux);font-weight:600}

/* ============================================================
   COUNTDOWN
============================================================ */
.count-section{text-align:center;position:relative}
.count-head{font-family:var(--serif);font-weight:600;font-size:clamp(2.2rem,7vw,4.4rem);color:var(--ink);line-height:.95;margin:0}
.count-grid{margin-top:44px;display:grid;grid-template-columns:repeat(4,1fr);gap:14px;max-width:620px;margin-inline:auto}
.count-cell{padding:26px 10px;border-radius:18px;background:rgba(255,255,255,.45);border:1px solid var(--line);
  box-shadow:0 14px 30px rgba(58,34,38,.06);backdrop-filter:blur(4px)}
.count-num{font-family:var(--serif);font-weight:600;font-size:clamp(2.4rem,7vw,4rem);color:var(--bordeaux);line-height:.9;font-variant-numeric:tabular-nums}
.count-lab{margin-top:10px;font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;color:var(--sage)}

/* ============================================================
   RSVP CTA (на главной)
============================================================ */
.rsvp-cta-section{text-align:center;display:grid;justify-items:center;gap:22px}
.rsvp-cta-section .display{font-size:clamp(2.2rem,6vw,3.8rem);max-width:14ch}
.rsvp-cta-section p{max-width:40ch;color:var(--ink-soft);line-height:1.7;margin:0}

/* секция чата с ведущим */
.chat-section{text-align:center;display:grid;justify-items:center;gap:20px}
.chat-section .display{font-size:clamp(2rem,5.5vw,3.4rem);max-width:16ch}
.chat-section p{max-width:42ch;color:var(--ink-soft);line-height:1.7;margin:0}
.chat-cta{position:relative;margin-top:10px;display:grid;place-items:center}
.chat-btn{position:relative;gap:.7em;animation:chatglow 2.6s var(--ease) infinite}
.chat-btn .chat-ico{width:20px;height:20px;position:relative;z-index:2}
@keyframes chatglow{
  0%,100%{box-shadow:0 16px 34px rgba(164,127,63,.32),0 0 0 0 rgba(189,154,87,.5)}
  50%{box-shadow:0 18px 38px rgba(164,127,63,.46),0 0 0 14px rgba(189,154,87,0)}
}
@media(prefers-reduced-motion:reduce){.chat-btn{animation:none}}

/* ============================================================
   SIGN-OFF / footer
============================================================ */
.signoff{position:relative;z-index:1;background:var(--noir);color:#efe1cf;text-align:center;
  min-height:92svh;display:grid;align-items:end;justify-items:center;
  padding:clamp(70px,12vw,120px) 22px clamp(54px,12vh,120px);overflow:hidden}
.signoff-media{position:absolute;inset:0;z-index:0}
.signoff-media::after{content:"";position:absolute;inset:0;z-index:1;background:
  radial-gradient(95% 85% at 50% 42%,transparent,rgba(12,9,8,.5) 72%,rgba(12,9,8,.84)),
  linear-gradient(180deg,rgba(12,9,8,.5),transparent 30%,rgba(12,9,8,.62))}
.signoff-inner{position:relative;z-index:2}
.signoff .script{font-family:var(--script);font-size:clamp(3rem,11vw,6rem);color:var(--gold-soft);line-height:1}
.signoff .sub{margin-top:14px;letter-spacing:.3em;text-transform:uppercase;font-size:.7rem;color:rgba(239,225,207,.6)}
.signoff .names{margin-top:18px;font-family:var(--serif);font-size:clamp(1.4rem,5vw,2.2rem);letter-spacing:.16em;color:#f6ecdd}
.signoff .pet{margin-top:30px;color:var(--gold)}

/* full-bleed киносекция с фото пары */
.interlude{position:relative;z-index:1;min-height:86svh;display:grid;place-items:center;overflow:hidden;background:var(--noir);text-align:center}
.interlude-media{position:absolute;inset:0;z-index:0}
.interlude-media > img{width:100%;height:120%;object-fit:cover;object-position:50% 30%;
  filter:grayscale(.1) contrast(1.06) brightness(.6) saturate(1.03);will-change:transform}
.interlude-media::after{content:"";position:absolute;inset:0;z-index:1;background:
  radial-gradient(92% 82% at 50% 40%,transparent,rgba(12,9,8,.46) 74%,rgba(12,9,8,.78)),
  linear-gradient(180deg,rgba(12,9,8,.42),transparent 32%,rgba(12,9,8,.54))}
.interlude-inner{position:relative;z-index:2;padding:0 24px;color:#f4ece2;max-width:760px}
.interlude .eyebrow{color:var(--gold-soft);justify-content:center}
.interlude .eyebrow::before,.interlude .eyebrow::after{background:rgba(216,189,134,.5)}
.interlude .line{font-family:var(--script);font-size:clamp(2.4rem,9vw,4.8rem);color:var(--gold-soft);line-height:1.06;margin-top:18px}
.interlude .sub{margin:20px auto 0;max-width:34ch;line-height:1.75;color:rgba(244,236,226,.84);font-size:1.02rem}

/* фото целиком: размытая заливка фона + резкое фото поверх (contain) */
.photo-fill{position:absolute;inset:0;overflow:hidden}
.photo-fill .pf-bg{position:absolute;inset:-4%;width:108%;height:108%;object-fit:cover;
  transform:scale(1.12);filter:blur(34px) brightness(.5) saturate(1.05);will-change:transform}
.photo-fill .pf-main{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;object-position:center;
  filter:contrast(1.04) saturate(1.03)}
.signoff-media .pf-main{filter:contrast(1.04) saturate(1.02) brightness(.92)}

/* ============================================================
   RSVP PAGE
============================================================ */
.rsvp-hero{position:relative;z-index:1;text-align:center;padding:clamp(96px,18vw,160px) 22px clamp(20px,5vw,40px);display:grid;justify-items:center;gap:16px}
.rsvp-hero .display{font-size:clamp(2.6rem,9vw,5rem);max-width:11ch}
.rsvp-hero p{margin:0;max-width:36ch;color:var(--ink-soft);line-height:1.7}
.rsvp-hero .date-pill{margin-top:6px;font-family:var(--num);letter-spacing:.18em;color:var(--bordeaux);font-size:1.05rem}

.form-wrap{max-width:680px;margin:0 auto;padding:0 22px clamp(40px,8vw,80px)}
.form-card{position:relative;background:rgba(255,255,255,.45);border:1px solid var(--line);border-radius:26px;
  padding:clamp(26px,5vw,46px);box-shadow:var(--shadow);backdrop-filter:blur(6px)}
.rsvp-form{display:flex;flex-direction:column;gap:30px}
.rsvp-block{padding-bottom:26px;border-bottom:1px solid var(--line)}
.rsvp-block:last-of-type{border-bottom:none;padding-bottom:0}
.rsvp-block-title{font-family:var(--serif);font-weight:600;font-size:clamp(1.4rem,4vw,2rem);color:var(--ink);margin:0 0 16px;line-height:1.1}

.field{display:block}
.rsvp-form input[type=text],
.rsvp-form input[type=email],
.rsvp-form input[type=tel],
.rsvp-form textarea{
  width:100%;padding:16px 18px;border-radius:14px;border:1px solid var(--line);
  background:var(--paper-2);color:var(--ink);outline:none;transition:.25s;font-family:var(--sans)
}
.rsvp-form textarea{min-height:120px;resize:vertical}
.rsvp-form input::placeholder,.rsvp-form textarea::placeholder{color:var(--ink-faint)}
.rsvp-form input:focus,.rsvp-form textarea:focus{border-color:var(--gold);background:#fffaf2;box-shadow:0 0 0 4px rgba(189,154,87,.12)}

/* animated checks (radio + checkbox unified) */
.choice-group{display:grid;gap:2px}
.choice{position:relative;display:flex;align-items:center;gap:14px;padding:14px 0;cursor:pointer;user-select:none;border-bottom:1px solid var(--line)}
.choice:last-child{border-bottom:none}
.choice input{position:absolute;opacity:0;inset:0;width:100%;height:100%;margin:0;cursor:pointer}
.mark{position:relative;flex:0 0 26px;width:26px;height:26px;border-radius:8px;border:1.5px solid var(--gold-line);
  background:var(--paper-2);box-shadow:inset 0 1px 0 rgba(255,255,255,.6);transition:.25s var(--ease)}
.mark::after{content:"";position:absolute;left:9px;top:4px;width:6px;height:12px;
  border-right:2.5px solid #fff;border-bottom:2.5px solid #fff;transform:rotate(45deg) scale(0);transition:transform .22s var(--ease)}
.choice input:checked ~ .mark{background:linear-gradient(160deg,#caa765,#8a5e2a);border-color:#8a5e2a;box-shadow:0 6px 14px rgba(138,94,42,.3)}
.choice input:checked ~ .mark::after{transform:rotate(45deg) scale(1)}
.choice:hover .mark{border-color:var(--gold)}
.choice input:focus-visible ~ .mark{box-shadow:0 0 0 4px rgba(189,154,87,.18)}
.choice .txt{font-size:1.05rem;color:var(--ink);line-height:1.3}
.drinks{display:grid;grid-template-columns:1fr 1fr;gap:0 24px}
@media(max-width:520px){.drinks{grid-template-columns:1fr}}

.companion-wrap{max-height:0;opacity:0;overflow:hidden;transform:translateY(-8px);
  transition:max-height .45s var(--ease),opacity .3s,transform .35s,margin-top .35s;margin-top:0}
.companion-wrap.is-visible{max-height:200px;opacity:1;transform:none;margin-top:16px}

.rsvp-submit{margin-top:6px}
.rsvp-signoff{margin:42px auto 0;text-align:center}
.rsvp-signoff .script{font-family:var(--script);font-size:clamp(2.6rem,9vw,4.4rem);color:var(--bordeaux);line-height:1}
.rsvp-signoff .sub{margin-top:10px;letter-spacing:.3em;text-transform:uppercase;font-size:.7rem;color:var(--sage)}
.rsvp-signoff .names{margin-top:12px;font-family:var(--serif);letter-spacing:.16em;font-size:1.3rem;color:var(--ink)}

/* ============================================================
   RSVP — экран благодарности
============================================================ */
.rsvp-thanks{text-align:center;display:grid;gap:18px;justify-items:center;animation:gateIn .8s var(--ease) both}
.thanks-script{font-family:var(--script);font-size:clamp(2.6rem,9vw,4.4rem);color:var(--bordeaux);line-height:1}
.rsvp-thanks p{margin:0;max-width:34ch;color:var(--ink-soft);line-height:1.7}

/* ============================================================
   GUEST GATE (вход по приглашению)
============================================================ */
.gate{min-height:100svh;display:grid;place-items:center;padding:24px;position:relative;z-index:1;
  background:radial-gradient(circle at 50% 28%,#241c1a,#0c0908)}
.gate-card{position:relative;width:min(440px,100%);text-align:center;
  padding:clamp(30px,6vw,48px);border-radius:26px;
  background:rgba(255,255,255,.04);border:1px solid rgba(216,189,134,.18);
  box-shadow:0 40px 90px rgba(0,0,0,.5);backdrop-filter:blur(10px);
  animation:gateIn .9s var(--ease) both}
.gate-mono{font-family:var(--serif);font-style:italic;font-size:2.4rem;color:var(--gold-soft);line-height:1}
.gate-eyebrow{display:inline-block;margin-top:12px;font-size:.64rem;letter-spacing:.4em;text-transform:uppercase;color:rgba(216,189,134,.75)}
.gate-card h1{font-family:var(--serif);font-weight:600;color:#fbf3e9;font-size:clamp(2rem,7vw,3rem);line-height:1;margin:14px 0 0}
.gate-card .lead{color:rgba(244,236,226,.66);margin:16px auto 0;max-width:30ch;line-height:1.6;font-size:.95rem}
.gate-error{margin:18px 0 0;padding:12px 16px;border-radius:12px;border:1px solid rgba(214,120,120,.4);
  background:rgba(214,120,120,.12);color:#f0c6c6;font-size:.9rem}
.gate-form{margin-top:24px;display:grid;gap:14px;text-align:left}
.gate-form label{display:grid;gap:8px}
.gate-form label>span{font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-soft)}
.gate-form input{width:100%;padding:15px 16px;border-radius:12px;border:1px solid rgba(216,189,134,.22);
  background:rgba(255,255,255,.05);color:#f6ecdd;outline:none;transition:.25s;font-family:var(--sans)}
.gate-form input::placeholder{color:rgba(244,236,226,.4)}
.gate-form input:focus{border-color:var(--gold);background:rgba(255,255,255,.08);box-shadow:0 0 0 4px rgba(189,154,87,.15)}
.gate-form .btn{margin-top:8px}

@keyframes gateIn{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}

/* ============================================================
   Responsive
============================================================ */
@media(max-width:680px){
  .section{padding:64px 18px}
  .hero-cta{width:100%}
  .hero-cta .btn{flex:1;min-width:0;padding:0 18px}
  .gallery{column-gap:12px}
  .ribbon-wrap{aspect-ratio:.5/1}
  .tl-item{width:42vw}
  .count-grid{grid-template-columns:repeat(2,1fr)}
  .env-card p{font-size:.86rem}
}

@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none!important;transition:none!important}
  .reveal,.reveal-stagger>*{opacity:1!important;transform:none!important}
  .outline-word .fill{clip-path:none!important}
}