:root{
  --paper:#fbf7ee;
  --paper-2:#fffaf0;
  --ink:#3b1e12;
  --brown:#8d4215;
  --brown-dark:#642707;
  --gold:#b38a35;
  --soft:#eadbc4;
  --shadow:0 24px 70px rgba(74,35,12,.16);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:
    radial-gradient(circle at top, rgba(179,138,53,.13), transparent 32rem),
    linear-gradient(180deg,var(--paper-2),var(--paper));
  color:var(--ink);
  font-family:"Cormorant Garamond", Georgia, serif;
  font-size:18px;
}

.intro-envelope{
  position:fixed;
  inset:0;
  z-index:999;
  display:grid;
  place-items:center;
  background:
    radial-gradient(circle at center, rgba(179,138,53,.12), transparent 26rem),
    var(--paper-2);
  animation:introFade 3.8s ease forwards;
}
.envelope-stage{
  display:grid;
  place-items:center;
  animation:stageLift 3.2s ease forwards;
}
.envelope{
  position:relative;
  width:min(340px, 78vw);
  aspect-ratio:1.5;
  filter:drop-shadow(0 24px 34px rgba(74,35,12,.2));
  perspective:900px;
}
.envelope-back{
  position:absolute;
  inset:0;
  border-radius:8px;
  background:linear-gradient(145deg, #a95534, #c46f4b);
  border:1px solid rgba(100,39,7,.18);
}
.envelope-pocket{
  position:absolute;
  inset:0;
  border-radius:8px;
  background:
    linear-gradient(35deg, transparent 49.5%, rgba(255,250,240,.18) 50%, transparent 51%),
    linear-gradient(325deg, transparent 49.5%, rgba(100,39,7,.16) 50%, transparent 51%),
    linear-gradient(160deg, #b95f3f 0 50%, #a95534 50% 100%);
  clip-path:polygon(0 36%, 50% 72%, 100% 36%, 100% 100%, 0 100%);
  z-index:3;
}
.wax-seal{
  position:absolute;
  left:50%;
  top:68%;
  z-index:5;
  width:76px;
  height:76px;
  object-fit:contain;
  filter:drop-shadow(0 8px 12px rgba(74,35,12,.3));
  transform:translate(-50%, -50%) rotate(-7deg);
}
.envelope-flap{
  position:absolute;
  inset:0;
  z-index:4;
  border-radius:8px;
  background:linear-gradient(180deg, #cb7650, #a95534);
  clip-path:polygon(0 0, 100% 0, 50% 64%);
  transform-origin:top center;
  animation:flapOpen 3.1s ease forwards;
}
.envelope-letter{
  position:absolute;
  left:8%;
  right:8%;
  bottom:16%;
  z-index:2;
  display:grid;
  justify-items:center;
  align-content:start;
  gap:6px;
  height:76%;
  padding:14px 18px;
  border-radius:6px;
  background:rgba(255,250,240,.96);
  border:1px solid rgba(141,66,21,.24);
  color:var(--gold);
  font-family:"Great Vibes", cursive;
  font-size:29px;
  line-height:1;
  transform:translateY(42%);
  animation:letterRise 3.2s ease forwards;
}
.envelope-letter img{
  width:48%;
  max-height:70px;
  height:auto;
  object-fit:contain;
  mix-blend-mode:multiply;
}
.letter-ornament{
  position:relative;
  width:92px;
  height:12px;
  margin-top:2px;
}
.letter-ornament:before{
  content:"";
  position:absolute;
  left:0;
  right:0;
  top:50%;
  height:1px;
  background:linear-gradient(90deg, transparent, var(--gold), transparent);
}
.letter-ornament:after{
  content:"";
  position:absolute;
  left:50%;
  top:50%;
  width:8px;
  height:8px;
  border:1px solid var(--gold);
  background:var(--paper-2);
  transform:translate(-50%, -50%) rotate(45deg);
}

.intro-envelope.is-hidden{
  display:none;
}

@keyframes flapOpen{
  0%, 30%{transform:rotateX(0deg);z-index:4}
  55%, 100%{transform:rotateX(178deg);z-index:1}
}
@keyframes letterRise{
  0%, 36%{transform:translateY(42%);opacity:0}
  58%{opacity:1}
  82%, 100%{transform:translateY(-30%);opacity:1}
}
@keyframes stageLift{
  0%, 74%{transform:translateY(0) scale(1)}
  100%{transform:translateY(-18px) scale(.96)}
}
@keyframes introFade{
  0%, 82%{opacity:1;visibility:visible}
  100%{opacity:0;visibility:hidden;pointer-events:none}
}

.page-border{
  pointer-events:none;
  position:fixed;
  inset:14px;
  border:1px solid rgba(100,39,7,.35);
  z-index:20;
}

.topbar{
  position:sticky;
  top:0;
  z-index:10;
  display:flex;
  align-items:center;
  justify-content:space-between;
  min-height:98px;
  padding:28px clamp(28px,5vw,74px) 24px;
  background:rgba(251,247,238,.88);
  backdrop-filter:blur(14px);
  border-bottom:1px solid rgba(141,66,21,.13);
}

.brand{
  display:flex;
  align-items:center;
  gap:10px;
  text-decoration:none;
  color:var(--brown-dark);
  font-family:"Cinzel", serif;
  letter-spacing:.14em;
  font-size:14px;
}

.brand img{width:38px;height:38px;object-fit:contain;border-radius:50%}

nav{display:flex;gap:clamp(20px,2.4vw,34px);align-items:center}
nav a{
  color:var(--brown-dark);
  text-decoration:none;
  font-family:"Cinzel", serif;
  font-size:12px;
  letter-spacing:.12em;
  line-height:1;
}
nav a:hover{color:var(--gold)}

.hero{
  min-height:calc(100vh - 98px);
  display:grid;
  place-items:center;
  padding:70px 20px;
  position:relative;
  overflow:hidden;
}
.hero-bg{
  position:absolute;
  inset:0;
  background:
    linear-gradient(rgba(251,247,238,.58), rgba(251,247,238,.72)),
    url("assets/vilaggio_aquarela.png") center/cover no-repeat;
  filter:saturate(.75);
  transform:scale(1.02);
}
.hero-card{
  position:relative;
  width:min(760px,92vw);
  padding:clamp(38px,6vw,64px) clamp(28px,6vw,68px);
  text-align:center;
  background:rgba(255,250,240,.88);
  border:1px solid rgba(141,66,21,.45);
  box-shadow:var(--shadow);
}
.hero-card:before,.hero-card:after{
  content:"";
  position:absolute;
  inset:14px;
  border:1px solid rgba(141,66,21,.26);
  pointer-events:none;
}
.hero-building{
  width:min(310px, 72%);
  display:block;
  margin:0 auto 54px;
  mix-blend-mode:multiply;
  filter:drop-shadow(0 12px 18px rgba(74,35,12,.1));
}
.hero-monogram{
  width:118px;
  height:118px;
  object-fit:contain;
  margin-bottom:8px;
  mix-blend-mode:multiply;
}
.eyebrow{
  margin:0 0 34px;
  color:var(--brown);
  font-family:"Cinzel", serif;
  text-transform:uppercase;
  letter-spacing:.18em;
  font-size:13px;
  font-weight:600;
}
h1,h2,h3{font-weight:500;color:var(--brown-dark);margin:0}
h1{
  font-family:"Great Vibes", cursive;
  font-size:clamp(42px,7vw,82px);
  line-height:1;
  color:var(--gold);
  white-space:nowrap;
}
h2{
  font-family:"Cinzel", serif;
  font-size:clamp(30px,4vw,54px);
  letter-spacing:.08em;
}
h3{
  font-family:"Cinzel", serif;
  letter-spacing:.08em;
  font-size:18px;
}
.date{
  font-family:"Cinzel", serif;
  letter-spacing:.16em;
  color:var(--brown-dark);
  margin:44px 0 42px;
  font-size:15px;
}
.verse{max-width:560px;margin:0 auto 10px;font-size:22px;line-height:1.45}
.verse-ref{font-family:"Cinzel",serif;font-size:12px;letter-spacing:.18em;color:var(--brown)}
.hero-actions{display:flex;justify-content:center;gap:18px;flex-wrap:wrap;margin-top:36px}
.btn{
  display:inline-flex;
  justify-content:center;
  align-items:center;
  min-height:46px;
  padding:12px 22px;
  border:1px solid var(--brown);
  text-decoration:none;
  font-family:"Cinzel",serif;
  letter-spacing:.12em;
  font-size:12px;
  cursor:pointer;
  transition:.25s ease;
}
.btn.primary{background:var(--brown);color:white}
.btn.primary:hover{background:var(--brown-dark)}
.btn:disabled{opacity:.65;cursor:not-allowed}
.btn.secondary{background:rgba(255,250,240,.55);color:var(--brown-dark)}
.btn.secondary:hover{background:var(--soft)}

.section{
  width:min(1120px,92vw);
  margin:0 auto;
  padding:86px 0;
}
.countdown-section{
  text-align:center;
  padding:70px 20px 30px;
}
.ornament{
  width:150px;
  height:20px;
  margin:0 auto 18px;
  background:
    linear-gradient(90deg, transparent, var(--brown), transparent);
  opacity:.55;
  mask: radial-gradient(circle, #000 2px, transparent 3px) center/18px 18px repeat-x;
}
.countdown{
  display:grid;
  grid-template-columns:repeat(4, minmax(90px, 150px));
  justify-content:center;
  gap:16px;
  margin-top:28px;
}
.countdown div{
  padding:20px 14px;
  background:rgba(255,250,240,.75);
  border:1px solid rgba(141,66,21,.25);
  box-shadow:0 14px 38px rgba(74,35,12,.08);
}
.countdown strong{
  display:block;
  font-family:"Cinzel",serif;
  font-size:38px;
  color:var(--brown-dark);
}
.countdown span{
  font-family:"Cinzel",serif;
  letter-spacing:.14em;
  font-size:11px;
  text-transform:uppercase;
  color:var(--brown);
}

.wedding-day{
  text-align:center;
  max-width:860px;
  padding-top:56px;
}
.wedding-day-monogram{
  width:112px;
  height:112px;
  object-fit:contain;
  mix-blend-mode:multiply;
  margin-bottom:20px;
}
.calendar{
  display:grid;
  grid-template-columns:repeat(7, minmax(34px, 1fr));
  gap:16px 20px;
  max-width:720px;
  margin:42px auto 0;
  align-items:center;
}
.calendar span{
  font-family:"Cinzel",serif;
  color:var(--brown-dark);
  font-size:14px;
  font-weight:700;
  letter-spacing:.12em;
  text-transform:uppercase;
}
.calendar time{
  display:grid;
  place-items:center;
  aspect-ratio:1;
  color:#251208;
  font-size:34px;
  line-height:1;
}
.calendar .selected-day{
  width:58px;
  justify-self:center;
  border-radius:50%;
  background:var(--brown);
  color:white;
  box-shadow:0 12px 28px rgba(100,39,7,.2);
}
.arrival-note{
  margin-top:44px;
}
.arrival-note .ornament{
  margin-bottom:22px;
}
.arrival-note p{
  max-width:640px;
  margin:0 auto;
  color:var(--brown-dark);
  font-family:"Cinzel",serif;
  font-size:clamp(20px,3vw,32px);
  letter-spacing:.12em;
  line-height:1.45;
  text-transform:uppercase;
}

.two-col{
  display:grid;
  grid-template-columns:1fr .85fr;
  gap:54px;
  align-items:center;
}
.copy p:not(.eyebrow), .venue-card p, .convidados p, .gifts p, .rsvp p, .dress-code-card p{
  line-height:1.7;
  font-size:22px;
}
.image-frame{
  padding:18px;
  background:rgba(255,250,240,.72);
  border:1px solid rgba(141,66,21,.27);
  box-shadow:var(--shadow);
}
.image-frame img, .venue-art img{width:100%;display:block}
.image-frame img{mix-blend-mode:multiply}

.venue{
  width:100%;
  display:grid;
  grid-template-columns:minmax(300px, 480px) 1fr;
  gap:0;
  align-items:stretch;
  padding:86px clamp(18px,5vw,70px);
}
.venue-card{
  background:var(--paper-2);
  border:1px solid rgba(141,66,21,.35);
  box-shadow:var(--shadow);
  padding:clamp(30px,5vw,58px);
  display:flex;
  flex-direction:column;
  justify-content:center;
  text-align:center;
}
.date-large{font-family:"Cinzel",serif;color:var(--brown);font-size:16px!important;letter-spacing:.1em}
.arrival-text{
  margin-top:8px;
  color:var(--brown-dark);
  font-family:"Cinzel",serif;
  font-size:14px!important;
  letter-spacing:.1em;
  text-transform:uppercase;
}
.venue-art{
  display:grid;
  place-items:center;
  background:linear-gradient(90deg, rgba(234,219,196,.35), transparent);
}
.venue-art img{height:100%;object-fit:cover;min-height:440px}

.convidados{
  text-align:center;
  max-width:850px;
}
.convidados img{
  width:min(560px,92vw);
  margin-top:22px;
  filter:drop-shadow(0 18px 32px rgba(74,35,12,.12));
}

.dress-code{
  text-align:center;
}
.dress-code .copy{
  max-width:860px;
  margin:0 auto 34px;
}
.dress-code-grid{
  display:grid;
  grid-template-columns:repeat(2, 1fr);
  gap:24px;
}
.dress-code-card{
  padding:18px 18px 28px;
  background:rgba(255,250,240,.72);
  border:1px solid rgba(141,66,21,.27);
  box-shadow:var(--shadow);
}
.dress-code-card img{
  width:100%;
  display:block;
  margin-bottom:22px;
}
.dress-code-card h3{
  color:var(--brown-dark);
}
.dress-code-card p{
  max-width:430px;
  margin:12px auto 0;
}

.gifts{text-align:center}
.gift-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
  margin-top:28px;
}
.gift-grid article{
  padding:28px;
  background:rgba(255,250,240,.7);
  border:1px solid rgba(141,66,21,.22);
}
.text-link{color:var(--brown);font-family:"Cinzel",serif;letter-spacing:.1em;font-size:12px;text-transform:uppercase}

.rsvp{
  display:grid;
  place-items:center;
  padding-bottom:100px;
}
.rsvp-panel{
  width:min(760px,100%);
  background:rgba(255,250,240,.88);
  border:1px solid rgba(141,66,21,.35);
  box-shadow:var(--shadow);
  padding:clamp(28px,6vw,58px);
  text-align:center;
}
form{
  margin-top:30px;
  display:grid;
  gap:16px;
  text-align:left;
}
.whatsapp-rsvp{
  max-width:430px;
  margin-left:auto;
  margin-right:auto;
}
.whatsapp-rsvp .btn{
  width:100%;
}
label{
  display:grid;
  gap:8px;
  font-family:"Cinzel",serif;
  letter-spacing:.08em;
  font-size:12px;
  color:var(--brown-dark);
}
input,select,textarea{
  width:100%;
  border:1px solid rgba(141,66,21,.34);
  background:rgba(255,255,255,.72);
  padding:13px 14px;
  font:18px "Cormorant Garamond", Georgia, serif;
  color:var(--ink);
}
textarea{resize:vertical}
.form-message{font-size:18px!important;color:var(--brown);text-align:center;margin:0}

footer{
  text-align:center;
  padding:54px 20px 70px;
  background:rgba(100,39,7,.06);
  border-top:1px solid rgba(141,66,21,.18);
}
footer img{width:80px;mix-blend-mode:multiply}
footer p{
  margin:8px 0 4px;
  font-family:"Great Vibes",cursive;
  font-size:42px;
  color:var(--gold);
}
footer span{font-family:"Cinzel",serif;letter-spacing:.16em;font-size:12px;color:var(--brown)}
footer small{
  display:block;
  margin-top:22px;
  color:rgba(100,39,7,.72);
  font-family:"Cinzel",serif;
  font-size:10px;
  letter-spacing:.12em;
  text-transform:uppercase;
}

@media (max-width: 860px){
  nav{display:none}
  .topbar{justify-content:center}
  .brand{justify-content:center}
  .two-col,.venue,.dress-code-grid{grid-template-columns:1fr}
  .venue{padding-left:20px;padding-right:20px}
  .venue-art img{min-height:auto}
  .countdown{grid-template-columns:repeat(2, minmax(120px, 1fr))}
  .gift-grid{grid-template-columns:1fr}
  .calendar{gap:12px 8px}
  .calendar span{font-size:10px}
  .calendar time{font-size:26px}
  .calendar .selected-day{width:46px}
  .page-border{inset:8px}
  .hero-building{width:min(250px, 68%);margin-bottom:38px}
  h1{font-size:clamp(38px,11vw,58px)}
}


/* Presentes */
.gifts{
  text-align:center;
  max-width:1180px;
}
.gifts-intro{
  max-width:850px;
  margin:18px auto 34px;
}
.gift-list{
  grid-template-columns:repeat(3,1fr);
}
.gift-card{
  position:relative;
  overflow:hidden;
  min-height:310px;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:30px 24px;
  background:
    radial-gradient(circle at top, rgba(179,138,53,.13), transparent 42%),
    rgba(255,250,240,.76);
  border:1px solid rgba(141,66,21,.28);
  box-shadow:0 18px 46px rgba(74,35,12,.09);
}
.gift-card:before{
  content:"";
  position:absolute;
  inset:10px;
  border:1px solid rgba(141,66,21,.13);
  pointer-events:none;
}
.gift-card h3{
  min-height:44px;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
}
.gift-card strong{
  font-family:"Cinzel", serif;
  font-size:32px;
  color:var(--brown-dark);
  letter-spacing:.04em;
}
.gift-card p{
  font-size:20px!important;
  line-height:1.45;
  margin:0;
}
.gift-icon{
  color:var(--gold);
  font-size:24px;
}
.gift-card-custom{
  grid-column:2 / span 1;
}
.payment-modal{
  position:fixed;
  inset:0;
  z-index:50;
  display:none;
  align-items:center;
  justify-content:center;
  padding:18px;
}
.payment-modal.is-open{
  display:flex;
}
.payment-backdrop{
  position:absolute;
  inset:0;
  background:rgba(37,18,8,.48);
  backdrop-filter:blur(4px);
}
.payment-dialog{
  position:relative;
  width:min(720px, 96vw);
  max-height:92vh;
  overflow:auto;
  padding:clamp(28px,5vw,52px);
  text-align:center;
  background:
    linear-gradient(rgba(255,250,240,.92), rgba(255,250,240,.92)),
    radial-gradient(circle at top, rgba(179,138,53,.18), transparent 40%);
  border:1px solid rgba(141,66,21,.45);
  box-shadow:0 28px 90px rgba(37,18,8,.32);
}
.payment-dialog:before{
  content:"";
  position:absolute;
  inset:14px;
  border:1px solid rgba(141,66,21,.18);
  pointer-events:none;
}
.modal-close{
  position:absolute;
  top:14px;
  right:18px;
  z-index:2;
  border:0;
  background:transparent;
  color:var(--brown-dark);
  font-size:34px;
  line-height:1;
  cursor:pointer;
}
.modal-text{
  font-size:22px;
  line-height:1.55;
  max-width:560px;
  margin:18px auto 24px;
}
.payment-options{
  display:flex;
  gap:14px;
  justify-content:center;
  flex-wrap:wrap;
  margin-top:24px;
}
.custom-amount-wrap{
  max-width:340px;
  margin:20px auto 0;
  text-align:left;
}
.payment-notice{
  max-width:560px;
  margin:18px auto 0;
  color:var(--brown);
  font-size:20px;
  line-height:1.45;
}
.pix-box{
  display:grid;
  gap:16px;
  margin-top:24px;
}
.pix-info{
  display:flex;
  justify-content:space-between;
  gap:18px;
  padding:14px 16px;
  background:rgba(255,255,255,.55);
  border:1px solid rgba(141,66,21,.18);
  text-align:left;
}
.pix-info span{
  font-family:"Cinzel", serif;
  color:var(--brown);
  letter-spacing:.08em;
  font-size:12px;
  text-transform:uppercase;
}
.pix-info strong{
  color:var(--brown-dark);
  text-align:right;
}
.qr-wrap{
  display:grid;
  place-items:center;
  padding:18px;
  background:white;
  width:230px;
  height:230px;
  margin:0 auto;
  border:1px solid rgba(141,66,21,.22);
}
.qr-wrap img{
  width:200px;
  height:200px;
  object-fit:contain;
}
.pix-code-label{
  text-align:left;
}
.thanks-message{
  margin-top:22px;
  font-size:22px!important;
  color:var(--brown-dark);
  line-height:1.5;
}
@media (max-width: 860px){
  .gift-list{
    grid-template-columns:1fr;
  }
  .gift-card-custom{
    grid-column:auto;
  }
  .pix-info{
    flex-direction:column;
    gap:4px;
  }
  .pix-info strong{
    text-align:left;
  }
}

@media (prefers-reduced-motion: reduce){
  .intro-envelope{
    animation:introFade 1.2s ease forwards;
  }
  .envelope-stage,
  .envelope-flap,
  .envelope-letter{
    animation:none;
  }
}
