:root{
    --ivory:#F6F0E3;
    --paper:#FAF5EA;
    --ink:#4B4136;
    --muted:#8C8170;
    --gold:#AD8754;
    --sage:#7E8A68;
    --sage-dark:#5C6650;
    --lavender:#A89BB3;
    --rule:#E1D7C2;
  }
  *{box-sizing:border-box; margin:0; padding:0;}
  html{scroll-behavior:smooth;}
  body{
    background:var(--ivory);
    color:var(--ink);
    font-family:'Cormorant Garamond', serif;
    -webkit-font-smoothing:antialiased;
  }
  h1,h2,h3{font-weight:500; line-height:1.15;}
  a{color:inherit; text-decoration:none;}
  img{max-width:100%; display:block;}

  /* ---------- i18n ---------- */
  .it{display:none;}
  body.lang-it .es{display:none;}
  body.lang-it .it{display:inline;}
  body.lang-it .it.block{display:block;}
  .es.block{display:block;}

  /* ---------- utility ---------- */
  .label{
    font-family:'Jost', sans-serif;
    font-size:11px;
    letter-spacing:0.22em;
    text-transform:uppercase;
    color:var(--muted);
    font-weight:500;
  }
  .section{
    max-width:880px;
    margin:0 auto;
    padding:110px 28px 90px;
    border-bottom:1px solid var(--rule);
  }
  .section:last-of-type{border-bottom:none;}
  .section h2{
    font-size:34px;
    text-align:center;
    margin-bottom:8px;
  }
  .section .label{
    display:block;
    text-align:center;
    margin-bottom:14px;
  }
  .section .lede{
    text-align:center;
    color:var(--muted);
    font-size:18px;
    max-width:520px;
    margin:0 auto 48px;
  }
  .divider{
    width:60px; height:1px; background:var(--gold);
    margin:22px auto 0;
  }

  /* ---------- nav ---------- */
  nav{
    position:fixed; top:0; left:0; right:0; z-index:100;
    background:rgba(250,245,234,0.92);
    backdrop-filter:blur(6px);
    border-bottom:1px solid var(--rule);
  }
  .nav-inner{
    max-width:1040px; margin:0 auto;
    display:flex; align-items:center; justify-content:space-between;
    padding:16px 24px;
  }
  .nav-mono{
    font-size:20px; letter-spacing:0.15em; font-weight:500;
  }
  .nav-mono span{color:var(--gold); margin:0 4px; font-weight:400;}
  .nav-links{
    display:flex; gap:28px; list-style:none;
    font-family:'Jost', sans-serif; font-size:12px; letter-spacing:0.12em;
    text-transform:uppercase; color:var(--ink);
  }
  .nav-links a:hover{color:var(--gold);}
  .nav-right{display:flex; align-items:center; gap:18px;}
  .lang-toggle{
    font-family:'Jost', sans-serif; font-size:12px; letter-spacing:0.1em;
    display:flex; gap:6px; border:1px solid var(--rule); border-radius:20px;
    padding:4px 4px; cursor:pointer; user-select:none;
  }
  .lang-toggle span{padding:3px 10px; border-radius:16px; transition:.2s;}
  .lang-toggle span.active{background:var(--ink); color:var(--paper);}
  .burger{display:none; flex-direction:column; gap:4px; cursor:pointer;}
  .burger div{width:22px; height:1.5px; background:var(--ink);}

  @media (max-width:760px){
    nav.menu-open{backdrop-filter:none; -webkit-backdrop-filter:none; background:var(--paper);}
    .nav-links{
      position:fixed; top:64px; left:0; right:0; bottom:0;
      background-color:var(--paper); opacity:1; isolation:isolate;
      backdrop-filter:none; -webkit-backdrop-filter:none;
      flex-direction:column; gap:0; z-index:99;
      padding:20px 28px; transform:translateX(100%); transition:transform .25s ease;
    }
    .nav-links.open{transform:translateX(0);}
    .nav-links li{border-bottom:1px solid var(--rule); padding:16px 0;}
    .burger{display:flex;}
  }

  /* ---------- hero ---------- */
  .hero{
    min-height:100vh;
    display:flex; flex-direction:column; justify-content:center; align-items:center;
    text-align:center; padding:140px 24px 60px;
    position:relative; overflow:hidden;
  }
  .hero-mono{
    font-size:46px; letter-spacing:0.3em; font-weight:500;
  }
  .hero-mono span{color:var(--gold); margin:0 8px; font-weight:400;}
  .hero-names{
    font-family:'Cormorant Garamond', serif; font-style:italic;
    font-size:48px; margin-top:18px; color:var(--ink);
  }
  .hero-date{
    margin-top:22px; font-family:'Jost', sans-serif; letter-spacing:0.2em;
    font-size:14px; text-transform:uppercase; color:var(--muted);
  }
  .hero-place{
    font-family:'Jost', sans-serif; letter-spacing:0.18em; font-size:13px;
    text-transform:uppercase; color:var(--ink); margin-top:6px;
  }
  .hero-heart{color:var(--gold); font-size:18px; margin:26px 0;}
  .hero-illustration{
    width:100%; max-width:880px; margin-top:14px;
    border-radius:2px;
    box-shadow:0 18px 40px -20px rgba(75,65,54,0.35);
  }
  .hero-tagline{
    margin-top:34px; font-family:'Jost', sans-serif; font-size:11px;
    letter-spacing:0.2em; text-transform:uppercase; color:var(--muted);
  }

  /* ---------- venue / map ---------- */
  .venue-grid{
  display:grid;
  gap:28px;
  grid-template-columns: 1fr 1fr;
}
  .venue-card{
  background:var(--paper); border:1px solid var(--rule); padding:30px;
  text-align:center;
}
  .venue-card .label{margin-bottom:10px;}
  .venue-card p{font-size:17px; line-height:1.5;}

@media (max-width: 600px){
  .venue-grid{ grid-template-columns: 1fr; }
}
  .map-frame{
    width:100%; height:320px; border:1px solid var(--rule); margin-top:30px;
    background:var(--paper); display:flex; align-items:center; justify-content:center;
    color:var(--muted); font-family:'Jost', sans-serif; font-size:13px; letter-spacing:.05em;
  }
  .btn{
    display:inline-block; margin-top:18px; padding:12px 28px;
    border:1px solid var(--ink); font-family:'Jost', sans-serif; font-size:12px;
    letter-spacing:0.14em; text-transform:uppercase; transition:.2s;
  }
  .btn:hover{background:var(--ink); color:var(--paper);}
  .note{
    margin-top:34px; text-align:center; font-family:'Jost', sans-serif;
    font-size:12.5px; letter-spacing:.04em; color:var(--sage-dark);
    border-top:1px solid var(--rule); padding-top:20px;
  }

  /* ---------- cronograma ---------- */
  .timeline{max-width:480px; margin:0 auto;}
  .tl-item{
    display:grid; grid-template-columns:90px 1fr; gap:20px;
    padding:18px 0; border-bottom:1px solid var(--rule);
  }
  .tl-item:last-child{border-bottom:none;}
  .tl-time{font-family:'Jost', sans-serif; font-size:13px; letter-spacing:.05em; color:var(--gold);}
  .tl-text{font-size:18px;}

  /* ---------- rsvp form ---------- */
  form{max-width:560px; margin:0 auto;}
  .field{margin-bottom:22px;}
  .field label{
    display:block; font-family:'Jost', sans-serif; font-size:11px;
    letter-spacing:0.12em; text-transform:uppercase; color:var(--muted); margin-bottom:8px;
  }
  .field input[type="text"], .field input[type="email"], .field textarea{
    width:100%; padding:12px 14px; border:1px solid var(--rule);
    background:var(--paper); font-family:'Cormorant Garamond', serif; font-size:17px;
    color:var(--ink);
  }
  .field textarea{resize:vertical; min-height:80px;}
  .radio-row{display:flex; gap:24px;}
  .radio-row label{
    display:flex; align-items:center; gap:8px; font-family:'Cormorant Garamond', serif;
    font-size:17px; text-transform:none; letter-spacing:0; color:var(--ink);
  }
  .companion-row{
    display:flex; gap:12px; align-items:center; margin-bottom:10px;
  }
  .companion-row input[type="text"]{flex:1;}
  .companion-row label{display:flex !important; align-items:center; gap:6px; font-size:14px; white-space:nowrap; margin-bottom:0 !important; text-transform:none; letter-spacing:normal; color:var(--ink);}
  #add-companion{
    font-family:'Jost', sans-serif; font-size:12px; letter-spacing:.08em;
    color:var(--sage-dark); cursor:pointer; text-transform:uppercase; border:none; background:none;
    padding:6px 0;
  }
  .companion-row label span{
  text-transform:none;
  letter-spacing: 0.12em;
  font-family:'Jost', sans-serif;
  font-size:11px;
  color:var(--muted);
}
  .remove-companion{
  font-family:'Jost', sans-serif; font-size:16px; color:var(--muted);
  border:1px solid var(--muted); background:none; cursor:pointer; padding:0 4px;
  line-height:1; transition:.2s;
  align-self:center;
}
.remove-companion:hover{ color:var(--ink); }

  .submit-btn{
    width:100%; padding:14px; background:var(--ink); color:var(--paper);
    font-family:'Jost', sans-serif; letter-spacing:0.14em; text-transform:uppercase;
    font-size:13px; border:none; cursor:pointer; margin-top:10px;
  }
  .submit-btn:hover{background:var(--gold);}
  #rsvp-success{
    display:none; text-align:center; font-size:40px; color:var(--sage-dark); margin-top:20px;
  }

  /* ---------- hospedaje ---------- */
  .room-grid{display:grid; gap:24px; grid-template-columns:repeat(auto-fit,minmax(220px,1fr));}
  .room-card{
    border:1px solid var(--rule); padding:26px; text-align:center; background:var(--paper); margin-top:20px;
  }
  .room-gallery{display:flex; gap:10px}
  .room-gallery-credits{font-family:'Jost', sans-serif; font-size:12px; letter-spacing:.05em; color:var(--muted); margin-top:2px; margin-left:2px;}
  .room-card h3{font-size:21px; margin-bottom:8px;}
  .room-card .price{font-family:'Jost', sans-serif; font-size:16px; color:var(--gold); margin:10px 0;}
  .room-card ul{list-style:none; font-size:15px; color:var(--ink); line-height:1.6;}
  .spots-bar{
    max-width:480px; margin:34px auto 0; text-align:center;
    font-family:'Jost', sans-serif; font-size:12px; letter-spacing:.05em; color:var(--muted);
  }
  .spots-track{height:6px; background:var(--rule); margin-top:10px; position:relative;}
  .spots-fill{height:100%; background:var(--gold); width:0%;}

  /* ---------- transporte ---------- */
  .transport-grid{display:grid; gap:22px; grid-template-columns:repeat(auto-fit,minmax(200px,1fr));}
  .transport-card{
    border:1px solid var(--rule); padding:24px; text-align:center; background:var(--paper);
  }
  .transport-card .icon{font-size:26px; color:var(--sage-dark); margin-bottom:10px;}
  .transport-card h3{font-size:18px; margin-bottom:6px;}
  .transport-card p{font-size:14.5px; color:var(--muted); line-height:1.5;}

  /* ---------- regalo ---------- */
  .gift-grid{display:grid; gap:22px; grid-template-columns:repeat(auto-fit,minmax(240px,1fr));}
  .gift-card{
    border:1px solid var(--rule); padding:26px; text-align:center; background:var(--paper);
  }
  .gift-card .label{margin-bottom:12px;}
  .gift-value{
    font-family:'Jost', sans-serif; font-size:14px; letter-spacing:.04em;
    background:var(--ivory); border:1px dashed var(--rule); padding:10px 12px; margin:14px 0;
    word-break:break-all;
  }
  .copy-btn{
    font-family:'Jost', sans-serif; font-size:11px; letter-spacing:.1em; text-transform:uppercase;
    border:1px solid var(--ink); padding:8px 18px; cursor:pointer; background:none; color:var(--ink);
  }
  .copy-btn:hover{background:var(--ink); color:var(--paper);}

  /* ---------- contacto ---------- */
  .contact-grid{display:grid; gap:18px; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); text-align:center;}
  .contact-grid .label{margin-bottom:6px;}
  .contact-grid p{font-size:18px;}

  footer{
    text-align:center; padding:40px 24px; font-family:'Jost', sans-serif;
    font-size:11px; letter-spacing:.1em; color:var(--muted); text-transform:uppercase;
  }
  .powered-by{font-size:7px; margin-top:4px; color:var(--sage-dark);}