/* ============================================================
   Zhamshid & Sanobar — Wedding invitation
   ============================================================ */

:root{
  --blush:#f7d9e3;
  --blush-deep:#f0a8c0;
  --pink:#e87ba0;
  --blue:#7fb2e8;
  --blue-deep:#5b93d6;
  --cream:#fcf7f1;
  --beige:#e9dcc4;
  --beige-deep:#d8c39e;
  --gold:#c9a24b;
  --gold-deep:#b3852f;
  --gold-light:#e6c878;
  --seal:#b5202f;
  --ink:#5a4b52;
  --ink-soft:#8a7a82;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}

body{
  position:relative;
  font-family:'Montserrat',sans-serif;
  color:var(--ink);
  background:#fbf3f0;
  overflow-x:hidden;
}

h1,h2,h3{font-family:'Cormorant Garamond',serif}

/* ============================================================
   ГЛОБАЛЬНЫЙ ФОН + ПАДАЮЩИЕ ЛЕПЕСТКИ (контрастные)
   ============================================================ */
.bg-stage{
  position:fixed;inset:0;z-index:-2;
  background:
    radial-gradient(circle at 16% 20%, #fbe6ef 0%, transparent 42%),
    radial-gradient(circle at 84% 16%, #e2eefb 0%, transparent 40%),
    radial-gradient(circle at 78% 82%, #fbe0ec 0%, transparent 42%),
    radial-gradient(circle at 22% 86%, #e6f0fb 0%, transparent 42%),
    linear-gradient(160deg,#fdf6f1,#f4eef8 55%,#eef4fb);
}
.petal-layer{position:fixed;inset:0;z-index:-1;overflow:hidden;pointer-events:none}
.gold-leaf{
  position:absolute;top:-60px;
  opacity:.88;
  filter:drop-shadow(0 3px 6px rgba(150,110,30,.38));
  animation:leafDrift linear infinite;
  transform-origin:center center;
}
@keyframes leafDrift{
  0%{transform:translateY(-60px) translateX(0) rotate(0deg);opacity:0}
  6%{opacity:.92}
  50%{transform:translateY(48vh) translateX(42px) rotate(200deg)}
  90%{opacity:.85}
  100%{transform:translateY(108vh) translateX(-36px) rotate(420deg);opacity:0}
}

/* ============================================================
   ЭЛИТНАЯ ЗОЛОТАЯ РАМКА ВОКРУГ ВСЕГО ЛЕНДИНГА (статичная)
   ============================================================ */
.gold-frame{position:absolute;inset:0;z-index:40;pointer-events:none}
.gold-frame::before{
  content:"";position:absolute;inset:14px;border-radius:5px;
  border:14px solid transparent;
  border-image:linear-gradient(135deg,
    #6e4a0d 0%, #b88a28 12%, #f6e08a 26%, #fff7d4 38%, #d3a63c 50%,
    #fff7d4 62%, #f6e08a 74%, #b88a28 88%, #6e4a0d 100%) 1;
  box-shadow:
    0 0 0 2px rgba(110,74,13,.6),
    inset 0 0 0 2px rgba(110,74,13,.6),
    inset 0 0 26px rgba(110,74,13,.22);
}
.gold-frame::after{
  content:"";position:absolute;inset:34px;border-radius:3px;
  border:1.5px solid rgba(201,162,75,.75);
  box-shadow:inset 0 0 0 5px rgba(255,247,205,.3);
}
.gf-corner{position:absolute;width:48px;height:48px}
.gf-tl{top:26px;left:26px;border-top:3px solid #fff4c4;border-left:3px solid #fff4c4;border-top-left-radius:10px}
.gf-tr{top:26px;right:26px;border-top:3px solid #fff4c4;border-right:3px solid #fff4c4;border-top-right-radius:10px}
.gf-bl{bottom:26px;left:26px;border-bottom:3px solid #fff4c4;border-left:3px solid #fff4c4;border-bottom-left-radius:10px}
.gf-br{bottom:26px;right:26px;border-bottom:3px solid #fff4c4;border-right:3px solid #fff4c4;border-bottom-right-radius:10px}

/* ============================================================
   ЭКРАН С КОНВЕРТОМ
   ============================================================ */
.envelope-screen{
  position:fixed;inset:0;z-index:1000;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  background:
    radial-gradient(circle at 30% 20%, #faf0e2 0%, transparent 55%),
    radial-gradient(circle at 75% 78%, #f3e7d2 0%, transparent 55%),
    linear-gradient(160deg,#fdf7ef,#f1e6d4);
  transition:opacity 1s ease, visibility 1s;
}
.envelope-screen.immerse{opacity:0;visibility:hidden;pointer-events:none}
.envelope-wrap{display:flex;flex-direction:column;align-items:center;gap:48px;
  transition:transform 1.1s cubic-bezier(.6,.02,.3,1), opacity 1s ease}
.envelope-screen.immerse .envelope-wrap{transform:scale(7) translateY(-4%);opacity:0}

.envelope{position:relative;width:340px;height:230px;border:none;background:transparent;cursor:pointer;perspective:1400px;
  filter:drop-shadow(0 25px 40px rgba(150,120,80,.32));animation:envFloat 4.5s ease-in-out infinite}
@keyframes envFloat{0%,100%{transform:translateY(0) rotate(-.4deg)}50%{transform:translateY(-14px) rotate(.4deg)}}

.env-back{position:absolute;inset:0;border-radius:10px;background:linear-gradient(135deg,#f3e8d2,#e6d4b2);z-index:0}

.env-letter{
  position:absolute;left:16px;right:16px;top:16px;height:198px;
  background:linear-gradient(180deg,#fffdf8,#fff5ea);border-radius:8px;z-index:1;
  box-shadow:0 6px 18px rgba(150,120,80,.2);
  display:flex;align-items:center;justify-content:center;padding:18px;
  transform:translateY(0);transition:transform 1s cubic-bezier(.2,.8,.2,1) .55s;
}
.letter-inner{text-align:center}
.rings-mini{width:90px;height:60px;margin:0 auto 6px}
.letter-names{display:flex;align-items:center;justify-content:center;gap:6px;flex-wrap:wrap;line-height:1}
.pair-groom,.pair-bride{font-family:'Pinyon Script',cursive;font-weight:400;line-height:1}
.letter-names .pair-groom{font-size:38px;color:var(--gold)}
.letter-names .pair-bride{font-size:38px;color:var(--pink)}
.letter-names .pair-amp{font-family:'Cormorant Garamond',serif;font-weight:600;font-size:34px;color:var(--gold)}
.letter-sub{font-size:13px;letter-spacing:3px;text-transform:uppercase;color:var(--ink-soft);margin-top:8px}

.env-front{position:absolute;inset:0;border-radius:10px;z-index:3;background:linear-gradient(135deg,#ecdfc4,#dcc59c);
  clip-path:polygon(0 0, 50% 50%, 100% 0, 100% 100%, 0 100%);box-shadow:inset 0 0 30px rgba(180,150,100,.3)}
.env-front::after{content:"";position:absolute;inset:0;
  background:linear-gradient(160deg,rgba(255,255,255,.35),transparent 45%);
  clip-path:polygon(0 0, 50% 50%, 100% 0, 100% 100%, 0 100%)}

.env-flap{position:absolute;top:0;left:0;right:0;height:50%;z-index:5;
  background:linear-gradient(135deg,#e6d6b6,#d6bf94);clip-path:polygon(0 0,100% 0,50% 100%);
  transform-origin:top center;transition:transform .9s cubic-bezier(.6,.05,.2,1), z-index 0s}
.env-flap::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(255,255,255,.35),transparent 60%);clip-path:polygon(0 0,100% 0,50% 100%)}

/* золотая печать — разрывается по горизонтали (низ остаётся, верх уходит) */
.wax-seal{position:absolute;top:43%;left:50%;transform:translate(-50%,-50%);width:64px;height:64px;z-index:6}
.seal-half{position:absolute;left:0;width:100%;height:50%;
  background:radial-gradient(circle at 42% 32%,#fcebb0,#d3a63c 60%,#9c7416);
  box-shadow:inset 0 1px 4px rgba(255,255,255,.55), 0 4px 10px rgba(120,90,20,.45);
  transition:transform .85s cubic-bezier(.6,.05,.2,1), opacity .85s ease}
.seal-top{top:0;border-radius:64px 64px 0 0;transform-origin:center bottom}
.seal-bottom{bottom:0;border-radius:0 0 64px 64px}
.wax-seal::after{content:"";position:absolute;left:6px;right:6px;top:50%;height:1.5px;transform:translateY(-50%);
  background:rgba(120,90,20,.55);z-index:3;transition:opacity .3s}
.seal-text{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:#5e3f0c;
  font-family:'Cormorant Garamond',serif;font-weight:700;font-size:15px;letter-spacing:.5px;z-index:4;
  text-shadow:0 1px 1px rgba(255,248,220,.5);transition:opacity .4s ease}

/* открытие */
.envelope.open .env-flap{transform:rotateX(-180deg);z-index:0}
.envelope.open .env-letter{transform:translateY(-172px)}
.envelope.open .seal-top{transform:translateY(-130px) rotate(-10deg);opacity:0}
.envelope.open .seal-text,.envelope.open .wax-seal::after{opacity:0}

.envelope-hint{font-size:16px;letter-spacing:.5px;color:var(--ink-soft);text-align:center;max-width:340px;
  animation:hintPulse 2.4s ease-in-out infinite;transition:opacity .5s ease}
.envelope-hint::after{content:"";display:block;width:40px;height:2px;margin:14px auto 0;
  background:linear-gradient(90deg,transparent,var(--gold),transparent)}
@keyframes hintPulse{0%,100%{opacity:.6}50%{opacity:1}}

.floating-petals{position:absolute;inset:0;overflow:hidden;pointer-events:none}
.floating-petals .gold-leaf{animation-name:leafDriftEnv}
@keyframes leafDriftEnv{
  0%{transform:translateY(-50px) rotate(0);opacity:0}
  8%{opacity:.8}
  100%{transform:translateY(105vh) rotate(480deg);opacity:0}
}

/* ============================================================
   ОСНОВНОЙ САЙТ
   ============================================================ */
.site{opacity:0;transition:opacity 1.2s ease .15s}
.site.show{opacity:1}
.hero,.quote-band,.rings-section,.zone,.rsvp,.countdown-section,.footer{position:relative;z-index:1}

/* ---------- HERO ---------- */
.hero{position:relative;min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;
  padding-top:clamp(60px,11vh,130px);overflow:hidden;
  background-image:
    linear-gradient(to bottom,
      rgba(30,16,34,.32) 0%, rgba(30,16,34,.05) 20%,
      rgba(255,255,255,0) 50%, rgba(247,237,242,.5) 84%, #f7edf2 100%),
    url('assets/hero-bg.png');
  background-size:cover, cover;
  background-position:center top, center 72%;
  background-repeat:no-repeat}
.hero-glow{display:none}
@keyframes glowPulse{0%,100%{transform:scale(1);opacity:.5}50%{transform:scale(1.2);opacity:.8}}

.hero-names{position:relative;width:min(640px,82vw);height:min(46vh,340px)}
.name{position:absolute;font-family:'Pinyon Script',cursive;font-weight:400;line-height:.95;
  font-size:clamp(46px,7.6vw,98px);white-space:nowrap}
.name.groom{top:0;left:6%;color:#f6d885;
  text-shadow:0 2px 4px rgba(60,30,10,.6), 0 6px 24px rgba(0,0,0,.42)}
.name.bride{bottom:0;right:6%;color:#ff9ec1;
  text-shadow:0 2px 4px rgba(80,18,50,.55), 0 6px 24px rgba(0,0,0,.42)}
.amp{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  font-family:'Cormorant Garamond',serif;font-style:normal;font-weight:600;
  font-size:clamp(50px,8.4vw,112px);color:#f6d885;
  text-shadow:0 2px 4px rgba(60,30,10,.6), 0 6px 26px rgba(0,0,0,.42);
  animation:ampBeat 3.5s ease-in-out infinite}
@keyframes ampBeat{0%,100%{transform:translate(-50%,-50%) scale(1)}50%{transform:translate(-50%,-50%) scale(1.08)}}

[data-float]{opacity:0}
.site.show .name.groom{animation:floatInLeft 1.2s cubic-bezier(.2,.8,.2,1) .3s forwards}
.site.show .name.bride{animation:floatInRight 1.2s cubic-bezier(.2,.8,.2,1) .55s forwards}
.site.show .amp{animation:ampBeat 3.5s ease-in-out infinite, popIn 1s cubic-bezier(.2,.8,.2,1) .8s backwards;opacity:1}
@keyframes floatInLeft{0%{opacity:0;transform:translate(-60px,-30px)}100%{opacity:1;transform:translate(0,0)}}
@keyframes floatInRight{0%{opacity:0;transform:translate(60px,30px)}100%{opacity:1;transform:translate(0,0)}}
@keyframes popIn{0%{opacity:0;transform:translate(-50%,-50%) scale(0)}100%{opacity:1}}

.hero-tagline{
  margin-top:14px;padding:10px 28px;border-radius:40px;
  font-family:'Great Vibes',cursive;font-size:clamp(28px,4.2vw,44px);
  color:#fff8e8;
  background:rgba(30,16,34,.42);
  text-shadow:0 2px 8px rgba(0,0,0,.55), 0 0 18px rgba(246,216,133,.35);
  box-shadow:0 4px 18px rgba(0,0,0,.18);
  backdrop-filter:blur(3px)}

/* лебеди — изящные камеи в золотой оправе */
.swan{position:absolute;width:clamp(150px,17vw,230px);height:clamp(118px,13vw,180px);
  object-fit:cover;object-position:50% 38%;border-radius:50%;background:#fffdfa;
  border:4px solid var(--gold-light);
  box-shadow:0 14px 28px rgba(150,120,80,.38), inset 0 0 0 2px #fff;opacity:.99}
.swan-left{left:2vw;bottom:5vh;transform:scaleX(-1);animation:swanBobL 7s ease-in-out infinite}
.swan-right{right:2vw;bottom:5vh;animation:swanBobR 8s ease-in-out infinite}
@keyframes swanBobL{0%,100%{transform:scaleX(-1) translateY(0)}50%{transform:scaleX(-1) translateY(-14px)}}
@keyframes swanBobR{0%,100%{transform:translateY(0)}50%{transform:translateY(-16px)}}

.scroll-cue{position:absolute;bottom:24px;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--ink-soft)}
.scroll-cue span{width:24px;height:40px;border:2px solid var(--gold);border-radius:14px;position:relative}
.scroll-cue span::after{content:"";position:absolute;top:7px;left:50%;transform:translateX(-50%);
  width:5px;height:8px;border-radius:3px;background:var(--gold);animation:scrollDot 1.6s infinite}
.scroll-cue small{font-size:11px;letter-spacing:2px;text-transform:uppercase}
@keyframes scrollDot{0%{opacity:0;top:7px}40%{opacity:1}80%{opacity:0;top:22px}100%{opacity:0}}

/* ---------- ЦИТАТЫ ---------- */
.quote-band{padding:clamp(70px,12vw,140px) 60px;display:flex;justify-content:center;
  background:linear-gradient(135deg,rgba(251,239,245,.4),rgba(238,244,251,.4))}
.quote-band.alt{background:linear-gradient(135deg,rgba(238,244,251,.4),rgba(251,239,245,.4))}
.quote{position:relative;max-width:780px;text-align:center}
.q-mark{font-family:'Cormorant Garamond',serif;font-size:120px;color:var(--blush-deep);opacity:.5;
  position:absolute;top:-60px;left:50%;transform:translateX(-50%)}
.quote p{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:clamp(22px,3.4vw,36px);line-height:1.5;color:var(--ink)}

/* ---------- КОЛЬЦА (реалистичные) ---------- */
.rings-section{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:clamp(120px,18vw,210px) 60px;text-align:center;
  background-image:
    linear-gradient(to bottom, #f7edf2 0%, rgba(247,237,242,0) 20%, rgba(247,237,242,0) 76%, #f7edf2 100%),
    linear-gradient(rgba(22,13,6,.42), rgba(22,13,6,.52)),
    url('assets/rings-bg.png');
  background-size:cover, cover, cover;
  background-position:center top, center, center;
  background-repeat:no-repeat}
.rings-text{max-width:560px}
.rings-text h2{font-size:clamp(28px,4vw,44px);color:#f6d885;margin-bottom:16px;text-shadow:0 2px 6px rgba(0,0,0,.55)}
.rings-text p{font-size:17px;line-height:1.7;color:#fbeede;text-shadow:0 1px 5px rgba(0,0,0,.55)}

/* ---------- ЗОНЫ ---------- */
.zone{padding:clamp(60px,10vw,120px) 60px;text-align:center;
  background:linear-gradient(180deg,rgba(252,247,241,.4),rgba(246,236,227,.4))}
.section-title{font-size:clamp(32px,5vw,56px);color:var(--gold);margin-bottom:10px}
.section-title::after{content:"";display:block;width:70px;height:2px;margin:16px auto 0;
  background:linear-gradient(90deg,transparent,var(--gold),transparent)}
.section-sub{color:var(--ink-soft);font-style:italic;font-family:'Cormorant Garamond',serif;font-size:22px;margin-bottom:30px}
.zone-sub{font-family:'Great Vibes',cursive;font-size:clamp(30px,5vw,48px);color:var(--pink);margin:6px 0 34px}
.zone-address{font-family:'Cormorant Garamond',serif;font-size:clamp(20px,3vw,30px);color:var(--ink);
  max-width:680px;margin:0 auto 14px;line-height:1.45}
.zone-city{font-family:'Great Vibes',cursive;font-size:clamp(30px,4.4vw,46px);color:var(--blue-deep)}

/* ---------- РАМКИ ДЛЯ ФОТО ---------- */
.frame-stack{display:flex;flex-direction:column;align-items:center;gap:50px}
.photo-frame{width:min(380px,86vw)}
.photo-frame.big{width:min(780px,92vw)}
.pf-art{position:relative;border-radius:6px;overflow:hidden;aspect-ratio:4/3;padding:14px;cursor:zoom-in;
  background:linear-gradient(135deg,#f8ecca,#e0bd72 38%,#fcf2d8 55%,#caa044);
  box-shadow:0 18px 38px rgba(150,110,60,.32), inset 0 0 0 2px rgba(255,255,255,.4)}
.photo-frame.big .pf-art{aspect-ratio:16/10}
.pf-art::before{content:"";position:absolute;inset:9px;border-radius:4px;border:2px solid rgba(255,255,255,.55);
  box-shadow:inset 0 0 0 3px rgba(180,140,70,.35);pointer-events:none;z-index:3}
.pf-art img{position:absolute;inset:14px;width:calc(100% - 28px);height:calc(100% - 28px);object-fit:cover;border-radius:3px;display:block;z-index:2}
.pf-placeholder{position:absolute;inset:14px;border-radius:3px;z-index:1;display:none;align-items:center;justify-content:center;
  background:repeating-linear-gradient(45deg,#fbf4e6,#fbf4e6 14px,#f4e9d2 14px,#f4e9d2 28px);
  color:var(--ink-soft);font-family:'Cormorant Garamond',serif;font-size:20px;font-style:italic}
.photo-frame.no-img .pf-placeholder{display:flex}
.photo-frame.no-img img{display:none}
.photo-frame.no-img .pf-art{cursor:default}
.photo-frame figcaption{margin-top:16px;font-family:'Cormorant Garamond',serif;font-size:24px;color:var(--blue-deep)}

/* ---------- КАЛЕНДАРЬ ---------- */
.calendar{max-width:380px;margin:0 auto;background:#fff;border-radius:20px;padding:26px 24px 30px;
  box-shadow:0 18px 40px rgba(180,150,160,.25);border:1px solid rgba(201,162,75,.25)}
.cal-head{font-family:'Cormorant Garamond',serif;font-size:32px;color:var(--gold);margin-bottom:16px;letter-spacing:1px}
.cal-week{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;margin-bottom:8px}
.cal-week span{font-size:12px;letter-spacing:1px;color:var(--ink-soft);text-transform:uppercase}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}
.cal-grid i{position:relative;display:flex;align-items:center;justify-content:center;height:38px;font-style:normal;font-size:15px;color:var(--ink);border-radius:50%}
.cal-grid i.empty{visibility:hidden}
.cal-grid i.marked{color:#fff;font-weight:600;z-index:1}
.cal-heart{position:absolute;inset:0;width:100%;height:100%;z-index:-1;
  filter:drop-shadow(0 4px 8px rgba(232,123,160,.5));animation:heartBeat 1.6s ease-in-out infinite}
@keyframes heartBeat{0%,100%{transform:scale(1)}50%{transform:scale(1.14)}}

/* ---------- СБОР ГОСТЕЙ ---------- */
.gather-card{max-width:560px;margin:0 auto;background:rgba(255,255,255,.7);backdrop-filter:blur(4px);
  border-radius:22px;padding:42px 36px;box-shadow:0 18px 40px rgba(180,150,160,.22);border:1px solid rgba(201,162,75,.25)}
.gather-time{font-family:'Cormorant Garamond',serif;font-size:clamp(48px,9vw,86px);color:var(--blue-deep);line-height:1}
.gather-text{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:clamp(19px,2.6vw,26px);color:var(--ink);margin-top:14px;line-height:1.5}

/* ---------- RSVP ---------- */
.rsvp{padding:clamp(70px,11vw,130px) 60px;text-align:center;
  background:
    radial-gradient(circle at 20% 10%,rgba(251,225,236,.4),transparent 50%),
    radial-gradient(circle at 80% 90%,rgba(220,236,251,.4),transparent 50%),
    linear-gradient(160deg,rgba(253,245,240,.4),rgba(238,244,251,.4));overflow:hidden}
.rsvp-form{max-width:560px;margin:40px auto 0;text-align:left;background:rgba(255,255,255,.82);backdrop-filter:blur(6px);
  border-radius:22px;padding:38px 34px;box-shadow:0 20px 50px rgba(170,130,150,.25);border:1px solid rgba(255,255,255,.6)}
.field{margin-bottom:24px}
.field label,.field-label{display:block;font-size:13px;letter-spacing:1px;text-transform:uppercase;color:var(--ink-soft);margin-bottom:10px}
.field input,.field select,.field textarea{width:100%;padding:13px 16px;border-radius:12px;border:1px solid #e6d5dd;background:#fff;
  font-family:inherit;font-size:15px;color:var(--ink);transition:border-color .3s, box-shadow .3s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 4px rgba(127,178,232,.18)}
.field textarea{resize:vertical}

/* кнопки-варианты без кружочков */
.radio-row{display:flex;flex-direction:column;gap:12px}
.radio{display:block;cursor:pointer;padding:14px 18px;border:1.5px solid #ecdbe3;border-radius:14px;background:#fff;
  font-size:15px;color:var(--ink);text-align:center;transition:border-color .25s, background .25s, color .25s}
.radio:hover{border-color:var(--blue)}
.radio input{position:absolute;opacity:0;width:0;height:0;pointer-events:none}
.radio:has(input:checked){border-color:var(--pink);background:#fff2f6;color:var(--pink);font-weight:500}

.btn-attend{position:relative;display:block;width:100%;margin-top:8px;padding:16px;border:none;border-radius:14px;cursor:pointer;
  font-family:'Cormorant Garamond',serif;font-size:24px;font-weight:600;letter-spacing:1px;color:#fff;
  background:linear-gradient(120deg,var(--blue),var(--pink));background-size:200% 100%;
  box-shadow:0 14px 30px rgba(200,120,160,.4);transition:transform .3s, box-shadow .3s, background-position .6s;overflow:hidden}
.btn-attend:hover{transform:translateY(-3px);background-position:100% 0;box-shadow:0 20px 40px rgba(180,120,170,.5)}
.btn-attend:disabled{opacity:.7;cursor:default}
.btn-attend::after{content:"";position:absolute;top:0;left:-60%;width:40%;height:100%;
  background:linear-gradient(110deg,transparent,rgba(255,255,255,.5),transparent);transform:skewX(-20deg);animation:shine 3.5s infinite}
@keyframes shine{0%{left:-60%}40%,100%{left:130%}}
.form-note{margin-top:16px;text-align:center;font-size:15px;min-height:20px}
.form-note.ok{color:#3f9d72}
.form-note.err{color:#c8607a}

/* ---------- ОТСЧЁТ + РУКИ ---------- */
.countdown-section{position:relative;padding:120px 60px 130px;text-align:center;
  background-image:
    linear-gradient(to bottom, #f7edf2 0%, rgba(247,237,242,0) 20%, rgba(247,237,242,0) 76%, #f7edf2 100%),
    linear-gradient(rgba(18,10,22,.35), rgba(18,10,22,.5)),
    url('assets/hands-bg.png');
  background-size:cover, cover, cover;
  background-position:center top, center, center 28%;
  background-repeat:no-repeat}
.countdown-section .section-title{color:#f6d885;text-shadow:0 2px 6px rgba(0,0,0,.5)}
.countdown-section .cd-date{color:#ffc6dd;text-shadow:0 2px 6px rgba(0,0,0,.45)}
.hands{position:relative;height:clamp(150px,26vw,250px);max-width:780px;margin:0 auto 26px}
.hand{position:absolute;top:50%;width:clamp(210px,42vw,400px);height:auto;filter:drop-shadow(0 16px 22px rgba(120,90,80,.3))}
.hand-l{left:0;animation:reachL 4.6s ease-in-out infinite}
.hand-r{right:0;animation:reachR 4.6s ease-in-out infinite}
@keyframes reachL{0%,100%{transform:translate(-7%,-50%)}50%{transform:translate(2%,-52%)}}
@keyframes reachR{0%,100%{transform:translate(7%,-50%)}50%{transform:translate(-2%,-48%)}}
.spark{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:30px;height:30px;border-radius:50%;
  background:radial-gradient(circle,#fff 0%,rgba(255,238,190,.85) 35%,transparent 70%);
  animation:sparkPulse 2.2s ease-in-out infinite}
@keyframes sparkPulse{0%,100%{opacity:.35;transform:translate(-50%,-50%) scale(.6)}50%{opacity:1;transform:translate(-50%,-50%) scale(1.35)}}

.countdown{display:flex;justify-content:center;align-items:center;gap:14px;flex-wrap:wrap;margin-top:12px}
.cd-box{background:rgba(255,255,255,.82);border-radius:16px;padding:18px 16px;min-width:96px;
  box-shadow:0 12px 26px rgba(180,150,160,.22);border:1px solid rgba(201,162,75,.25)}
.cd-box span{display:block;font-family:'Cormorant Garamond',serif;font-size:clamp(34px,6vw,58px);color:var(--blue-deep);line-height:1}
.cd-box small{display:block;margin-top:6px;font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--ink-soft)}
.cd-sep{font-family:'Cormorant Garamond',serif;font-size:40px;color:var(--gold)}
.cd-date{margin-top:26px;font-family:'Great Vibes',cursive;font-size:clamp(28px,4vw,42px);color:var(--pink)}

/* ---------- ЛАЙТБОКС ---------- */
.lightbox{position:fixed;inset:0;z-index:2000;background:rgba(60,35,50,.88);backdrop-filter:blur(6px);
  display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:.4s;padding:24px}
.lightbox.show{opacity:1;visibility:visible}
.lightbox img{max-width:92vw;max-height:86vh;border-radius:10px;box-shadow:0 30px 60px rgba(0,0,0,.5);transform:scale(.92);transition:.4s}
.lightbox.show img{transform:scale(1)}
.lightbox-close{position:absolute;top:22px;right:30px;font-size:42px;color:#fff;cursor:pointer;line-height:1;background:none;border:none}

/* ---------- ФУТЕР ---------- */
.footer{text-align:center;padding:70px 60px 80px;background:linear-gradient(160deg,rgba(246,236,227,.55),rgba(241,221,233,.55))}
.rings-mini.foot{width:100px;height:auto;margin:0 auto 16px}
.foot-names{display:flex;align-items:center;justify-content:center;gap:10px;flex-wrap:wrap;line-height:1}
.foot-names .pair-groom,.foot-names .pair-bride{font-family:'Pinyon Script',cursive;font-weight:400}
.foot-names .pair-groom{font-size:52px;color:var(--gold)}
.foot-names .pair-bride{font-size:52px;color:var(--pink)}
.foot-names .pair-amp{font-family:'Cormorant Garamond',serif;font-weight:600;font-size:46px;color:var(--gold)}
.foot-sub{color:var(--ink-soft);margin-top:8px;font-style:italic}

/* ---------- SCROLL REVEAL ---------- */
.reveal{opacity:0;transform:translateY(40px);transition:opacity .9s ease, transform .9s ease}
.reveal.in{opacity:1;transform:none}

/* ---------- адаптив ---------- */
@media (max-width:760px){
  .quote-band,.rings-section,.zone,.rsvp,.countdown-section,.footer{padding-left:30px;padding-right:30px}
  .gold-frame::before{inset:8px;border-width:9px}
  .gold-frame::after{inset:20px}
  .gf-corner{width:34px;height:34px}
  .gf-tl,.gf-tr{top:18px}.gf-bl,.gf-br{bottom:18px}
  .gf-tl,.gf-bl{left:18px}.gf-tr,.gf-br{right:18px}
}
@media (max-width:600px){
  .envelope{width:280px;height:190px}
  .env-letter{height:165px}
  .envelope.open .env-letter{transform:translateY(-140px)}
  .swan{width:130px}
  .cd-sep{display:none}
  .cd-box{min-width:70px;padding:14px 10px}
}

@media (prefers-reduced-motion:reduce){
  *{animation:none !important;transition:opacity .3s ease !important}
}
