:root{--bg:#ece4d7;--paper:rgba(247,241,231,.72);--text:#58463b;--dark:#3f3029;--muted:#8b7d71;--line:rgba(255,255,255,.72);--brown:#6a5044}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;background:var(--bg);color:var(--text);font-family:Montserrat,Arial,sans-serif;font-weight:300;overflow-x:hidden}.grain{position:fixed;inset:0;pointer-events:none;z-index:5;opacity:.12;background-image:radial-gradient(#5b4b42 .45px,transparent .45px);background-size:4px 4px}.music{position:fixed;right:18px;top:18px;width:44px;height:44px;border:1px solid rgba(255,255,255,.6);border-radius:50%;background:rgba(255,255,255,.38);backdrop-filter:blur(10px);color:var(--dark);z-index:10;font-size:20px}.screen{position:relative; padding:35px 20px;display:flex;justify-content:center;justify-content:center;}.screen:before{ display:none;}.inner{position:relative;z-index:2;width:min(100%,430px);margin:auto;text-align:center}.narrow{width:min(100%,370px)}.hero{min-height:100svh;padding:0;display:flex;align-items:center;justify-content:center;}.hero:after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 50% 38%,rgba(255,255,255,.13),rgba(228,217,201,.45) 50%,rgba(173,159,140,.38))}.overline{text-transform:uppercase;letter-spacing:.18em;font-family:'Cormorant Garamond',serif;font-size:15px;margin:0 0 70px;color:#6f5d50}.hero h1{font-family:'Cormorant Garamond',serif;font-weight:400;text-transform:uppercase;font-size:54px;line-height:.95;letter-spacing:.08em;margin:0;color:#776456;text-shadow:0 1px 18px rgba(255,255,255,.65)}.hero h1 span{font-family:'Great Vibes',cursive;text-transform:none;font-size:54px;letter-spacing:0}.date-block{margin-top:70px;font-family:'Cormorant Garamond',serif;text-transform:uppercase;letter-spacing:.16em;color:#6e5b4e}.date-block strong{display:block;font-size:44px;font-weight:400;line-height:1;letter-spacing:0}.down{display:inline-flex;align-items:center;justify-content:center;margin-top:32px;text-decoration:none;color:#6e5b4e;font-size:36px;animation:float 1.8s infinite}.photo-placeholder{border:1px solid rgba(255,255,255,.82);background:rgba(255,255,255,.22);box-shadow:0 18px 45px rgba(94,75,62,.09);display:flex;align-items:center;justify-content:center;color:#8a7b70}.photo-placeholder.tall{height:420px;margin:0 auto 30px}.photo-placeholder.map{height:270px;margin-top:22px}.photo-placeholder div{padding:25px}.photo-placeholder span{display:block;font-family:'Cormorant Garamond',serif;text-transform:uppercase;letter-spacing:.13em;font-size:21px}.photo-placeholder small{display:block;margin-top:9px;font-size:12px}.screen h2{font-family:'Cormorant Garamond',serif;font-weight:400;text-transform:uppercase;letter-spacing:.08em;font-size:36px;line-height:1;margin:0;color:#3f3029}.script{font-family:'Great Vibes',cursive!important;font-size:36px!important;line-height:1!important;margin:4px 0 15px!important;color:#8b7464!important}.inner p{font-size:15px;line-height:1.75;margin:14px 0}.calendar-section h2{margin-bottom:24px}.calendar{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;padding:22px;border:1px solid var(--line);background:rgba(255,255,255,.23);backdrop-filter:blur(4px)}.calendar div{font-size:11px;color:#8a7b70}.calendar span{height:38px;display:flex;align-items:center;justify-content:center;font-family:'Cormorant Garamond',serif;font-size:19px}.calendar .active{border:1px solid var(--brown);border-radius:50%;background:rgba(106,80,68,.12);color:var(--dark)}.card{border:1px solid var(--line);padding:28px 20px;background:rgba(244,236,224,.48);backdrop-filter:blur(6px);box-shadow:0 22px 50px rgba(80,62,49,.1)}.place{margin-top:20px}.place h3{font-family:'Cormorant Garamond',serif;text-transform:uppercase;letter-spacing:.12em;margin:0 0 10px}.place small{display:block;color:var(--muted);margin-top:5px}.place a{display:block;margin:20px auto 0;width:210px;padding:14px 18px;background:var(--brown);color:#fff;text-decoration:none;text-transform:uppercase;letter-spacing:.08em;font-size:12px}.timeline{margin-top:28px;border:1px solid var(--line);background:rgba(255,255,255,.18)}.item{display:grid;grid-template-columns:95px 1fr;text-align:left;border-bottom:1px solid var(--line);min-height:112px}.item:last-child{border-bottom:0}.item b{font-family:'Great Vibes',cursive;font-size:34px;font-weight:400;color:#3f3029;padding:26px 16px;border-right:1px solid var(--line)}.item span{font-family:'Cormorant Garamond',serif;text-transform:uppercase;letter-spacing:.08em;font-size:18px;color:#3f3029;padding:24px 18px 0}.item p{grid-column:2;padding:0 18px 22px;margin:-28px 0 0;font-size:13px;line-height:1.5}.dress h2 em{font-family:'Great Vibes',cursive;text-transform:none;font-size:42px;font-style:normal;letter-spacing:0}.palette{display:flex;gap:12px;justify-content:center;margin-top:28px}.palette span{width:42px;height:42px;border-radius:50%;border:1px solid rgba(255,255,255,.8)}.palette span:nth-child(1){background:#dbe8f4;}.palette span:nth-child(2){background:#A2AF8D!important;}.palette span:nth-child(3){background:#d8b2b6;}.palette span:nth-child(4){background:#f5f0e8;}.palette span:nth-child(5){background:#8c7467;}.timer{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-top:25px}.timer div{border:1px solid var(--line);padding:20px 10px;background:rgba(255,255,255,.18)}.timer b{display:block;font-family:'Cormorant Garamond',serif;font-size:44px;font-weight:400;color:#3f3029}.timer span{text-transform:uppercase;letter-spacing:.14em;font-size:10px;color:var(--muted)}form{display:grid;gap:12px;margin-top:25px}input,select,textarea{width:100%;border:1px solid rgba(255,255,255,.8);background:rgba(255,255,255,.44);border-radius:0;padding:15px 14px;font:300 14px Montserrat;color:var(--dark);outline:none}textarea{min-height:92px;resize:vertical}button[type=submit]{border:0;background:var(--brown);color:white;padding:16px;text-transform:uppercase;letter-spacing:.1em;font:400 12px Montserrat}.status{font-size:13px!important;color:#6b5a50!important}footer{position:relative;text-align:center;padding:55px 20px 65px;color:#806f64}footer p{font-family:'Cormorant Garamond',serif;text-transform:uppercase;letter-spacing:.1em;font-size:26px;margin:0 0 7px}.reveal{opacity:0;transform:translateY(38px);transition:opacity 1s ease,transform 1s ease}.reveal.show{opacity:1;transform:none}@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(8px)}}@media (min-width:700px){body:before{content:'Сайт сделан под мобильную версию';position:fixed;left:20px;bottom:20px;z-index:20;background:rgba(255,255,255,.55);padding:10px 14px;border-radius:22px;color:#68574b;font-size:12px}.screen{max-width:460px;margin:auto;box-shadow:0 0 0 1px rgba(255,255,255,.35)}}

/* Живая анимация на заднем фоне как в видео */
.animated-bg{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden;background:linear-gradient(145deg,#e9dfd1 0%,#f3ecdf 44%,#d7c8b8 100%)}
.animated-bg:before{content:"";position:absolute;inset:-25%;background:conic-gradient(from 120deg at 50% 45%,rgba(255,255,255,.42),rgba(176,146,124,.2),rgba(255,255,255,.18),rgba(130,103,84,.22),rgba(255,255,255,.42));filter:blur(34px);animation:bgSpin 28s linear infinite}
.animated-bg:after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 30% 18%,rgba(255,255,255,.72),transparent 26%),radial-gradient(circle at 75% 65%,rgba(142,111,90,.24),transparent 32%),radial-gradient(circle at 45% 90%,rgba(255,255,255,.38),transparent 28%);animation:bgBreathe 7s ease-in-out infinite alternate}
.orb{position:absolute;border-radius:50%;filter:blur(18px);opacity:.52;background:rgba(255,255,255,.58);mix-blend-mode:screen;animation:orbFloat 12s ease-in-out infinite}
.orb-1{width:190px;height:190px;left:-55px;top:12%;animation-duration:13s}.orb-2{width:240px;height:240px;right:-95px;top:38%;background:rgba(171,139,116,.33);animation-duration:16s;animation-delay:-5s}.orb-3{width:150px;height:150px;left:34%;bottom:-40px;background:rgba(255,248,235,.52);animation-duration:11s;animation-delay:-2s}
.line{position:absolute;width:1px;height:115vh;top:-8vh;background:linear-gradient(to bottom,transparent,rgba(255,255,255,.7),rgba(118,91,75,.16),transparent);transform:rotate(18deg);opacity:.55;animation:lineMove 9s ease-in-out infinite}
.line-1{left:18%;animation-delay:-1s}.line-2{left:53%;height:105vh;animation-duration:12s;animation-delay:-6s}.line-3{left:82%;height:120vh;animation-duration:10s;animation-delay:-3s}
.petal{position:absolute;width:9px;height:18px;border-radius:9px 9px 9px 0;background:rgba(255,255,255,.62);box-shadow:0 0 18px rgba(255,255,255,.5);animation:petalFall 14s linear infinite}
.petal-1{left:14%;top:-30px;animation-delay:-1s}.petal-2{left:39%;top:-70px;animation-duration:17s;animation-delay:-8s}.petal-3{left:66%;top:-50px;animation-duration:12s;animation-delay:-4s}.petal-4{left:88%;top:-90px;animation-duration:19s;animation-delay:-11s}
main,.screen,footer{position:relative;z-index:1}.screen:before{animation:silkDrift 16s ease-in-out infinite alternate}
.hero h1{animation:titleGlow 4.5s ease-in-out infinite alternate}.date-block{animation:softRise 3.8s ease-in-out infinite alternate}
@keyframes bgSpin{to{transform:rotate(360deg)}}
@keyframes bgBreathe{from{transform:scale(1);opacity:.78}to{transform:scale(1.08);opacity:1}}
@keyframes orbFloat{0%,100%{transform:translate3d(0,0,0) scale(1)}50%{transform:translate3d(28px,-38px,0) scale(1.12)}}
@keyframes lineMove{0%,100%{transform:translateX(-12px) rotate(18deg);opacity:.32}50%{transform:translateX(22px) rotate(18deg);opacity:.72}}
@keyframes petalFall{0%{transform:translate3d(0,-10vh,0) rotate(0deg);opacity:0}10%{opacity:.8}100%{transform:translate3d(34px,112vh,0) rotate(380deg);opacity:0}}
@keyframes silkDrift{from{transform:scale(1.04) translate3d(-8px,-8px,0)}to{transform:scale(1.12) translate3d(12px,10px,0)}}
@keyframes titleGlow{from{text-shadow:0 1px 18px rgba(255,255,255,.55)}to{text-shadow:0 1px 30px rgba(255,255,255,.95)}}
@keyframes softRise{from{transform:translateY(0)}to{transform:translateY(-8px)}}
@media (prefers-reduced-motion:reduce){.animated-bg:before,.animated-bg:after,.orb,.line,.petal,.screen:before,.hero h1,.date-block{animation:none!important}}
.video-bg{
    position:fixed;
    inset:0;
    z-index:-1;
    overflow:hidden;
}

.video-bg video{
    position:absolute;
top:0;
left:0;
    width:100%;
    height:100%;
    object-fit:cover;
    filter:brightness(.9);
}

.video-overlay{
    position:absolute;
    inset:0;
    background:rgba(250,245,238,.30);
}
/* Фото локаций */

.location-photo{
    display:block;
    width:100%;
    height:230px;
    object-fit:cover;
    border-radius:18px;
    margin:18px 0 18px;
    box-shadow:0 12px 35px rgba(0,0,0,.12);
    transition:.35s;
}

.location-photo:hover{
    transform:scale(1.02);
}
.location-photo:hover{
    transform:scale(1.02);
}

.map-btn{
    display:block;
    width:100%;
    text-align:center;
    padding:15px;
    margin-top:15px;
    background:#7b5d4d;
    color:#fff;
    text-decoration:none;
    border-radius:14px;
    font-size:15px;
    letter-spacing:1px;
    transition:.3s;
}

.map-btn:hover{
    background:#6a4e40;
}
.map-btn{
    display:flex;
    justify-content:center;
    align-items:center;
    gap:8px;

    width:100%;
    margin:18px auto 0;
    padding:15px 20px;

    background:#7b5d4d;
    color:#fff;
    text-decoration:none;
    border-radius:14px;

    font-size:15px;
    font-weight:500;
    letter-spacing:1px;

    transition:.3s;
    box-sizing:border-box;
}
.form-group{
  text-align:left;
  margin:18px 0;
}

.form-group p{
  margin:0 0 12px;
  font-family:'Cormorant Garamond',serif;
  text-transform:uppercase;
  letter-spacing:.08em;
  font-size:17px;
  color:#3f3029;
}

.form-group label{
  display:flex;
  align-items:center;
  gap:10px;
  margin:10px 0;
  font-size:14px;
  line-height:1.4;
}

.form-group input{
  width:auto;
}
.dress-gallery{
    display:flex;
    justify-content:center;
    gap:12px;
    flex-wrap:wrap;
    margin-top:20px;
}

.dress-gallery img{
    width:90px;
    height:90px;
    object-fit:cover;
    border-radius:14px;
    border:2px solid rgba(255,255,255,.85);
    box-shadow:0 6px 18px rgba(0,0,0,.12);
    transition:.3s;
}

.dress-gallery img:hover{
    transform:scale(1.05);
}
.dresscode{
  text-align:center;
}

.dress-colors{
    display:flex;
    justify-content:center;
    gap:10px;
    margin:24px 0 14px;
    flex-wrap:nowrap;      /* все в один ряд */
}

.dress-colors span{
    width:52px;
    height:52px;
    border-radius:8px;     /* квадрат с немного скругленными углами */
    display:block;
    border:1px solid rgba(0,0,0,.12);
    box-shadow:0 6px 18px rgba(0,0,0,.08);
    flex-shrink:0;
}

.dress-text{
  font-size:16px;
  color:var(--text);
}
.place h3{
    font-family:'Cormorant Garamond', serif;
    font-size:32px;
    font-weight:400;
    letter-spacing:.18em;
    text-transform:uppercase;
    margin:18px 0 10px;
    color:var(--title);
}
.reveal{
  opacity:1 !important;
  transform:none !important;
}
.second-location h3{
    font-size:28px;
    font-weight:400;
    letter-spacing:.18em;
    text-transform:uppercase;
    margin:0;
}
