/* ============================================================
   ANDREA & BRAIS — Boda 07.08.2026
   Look & feel inspirado en la ilustración: crema, terracota,
   naranja flor, azul marino y verde salvia.
   ============================================================ */

:root{
  /* Paleta */
  --cream:      #FBF5E9;
  --cream-2:    #F5EAD6;
  --sand:       #F1E3C9;
  --ink:        #3A2A22;
  --ink-soft:   #6B574c;
  --terra:      #BB4F36;
  --terra-deep: #8F3826;
  --orange:     #E6963A;
  --navy:       #2C3A4C;
  --sage:       #8A9A5B;
  --gold:       #C99A4E;
  --line:       rgba(58,42,34,.14);

  /* Tipografía */
  --f-script: "Great Vibes", cursive;
  --f-serif:  "Cormorant Garamond", Georgia, serif;
  --f-sans:   "Mulish", system-ui, -apple-system, "Segoe UI", sans-serif;

  --maxw: 1140px;
  --radius: 18px;
  --shadow: 0 18px 50px -24px rgba(58,42,34,.45);
  --shadow-sm: 0 10px 30px -18px rgba(58,42,34,.5);
  --ease: cubic-bezier(.22,.61,.36,1);
}

*,*::before,*::after{ box-sizing:border-box; }

html{ scroll-behavior:smooth; scroll-padding-top:84px; -webkit-text-size-adjust:100%; }

body{
  margin:0;
  font-family:var(--f-sans);
  color:var(--ink);
  background:var(--cream);
  line-height:1.7;
  font-weight:400;
  overflow-x:hidden;
}

img{ max-width:100%; display:block; }
a{ color:var(--terra); text-decoration:none; transition:color .2s var(--ease); }
a:hover{ color:var(--terra-deep); }

.container{ width:min(var(--maxw), 92vw); margin-inline:auto; }

/* ---------- Tipografía base ---------- */
h1,h2,h3,h4{ margin:0; font-weight:600; line-height:1.15; }
.amp{ font-family:var(--f-script); color:var(--orange); font-weight:400; }

.eyebrow{
  font-family:var(--f-sans);
  text-transform:uppercase;
  letter-spacing:.32em;
  font-size:.72rem;
  font-weight:700;
  color:var(--terra);
  margin:0 0 .8rem;
}
.eyebrow--light{ color:var(--orange); }

.section__title{
  font-family:var(--f-serif);
  font-size:clamp(2.1rem, 5.5vw, 3.4rem);
  font-weight:600;
  color:var(--ink);
  letter-spacing:.01em;
}
.section__title--light{ color:#FBF5E9; }

.section__intro{
  max-width:46ch;
  margin:1.1rem auto 0;
  color:var(--ink-soft);
  font-family:var(--f-serif);
  font-size:1.3rem;
  font-style:italic;
}

/* ---------- Divider floral ---------- */
.divider{ margin:1.1rem auto .2rem; width:140px; }
.divider__svg{ width:100%; height:24px; }
.divider__svg path{ stroke:var(--gold); stroke-width:1.4; fill:none; }
.divider__svg circle{ fill:none; stroke:var(--terra); stroke-width:1.4; }
.divider--light .divider__svg path{ stroke:var(--orange); }
.divider--light .divider__svg circle{ stroke:#FBF5E9; }

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:fixed; inset:0 0 auto 0; z-index:60;
  transition:background .35s var(--ease), box-shadow .35s var(--ease), padding .35s var(--ease);
  padding:.5rem 0;
}
.nav.is-stuck{
  background:rgba(251,245,233,.86);
  backdrop-filter:saturate(140%) blur(12px);
  -webkit-backdrop-filter:saturate(140%) blur(12px);
  box-shadow:0 6px 24px -18px rgba(58,42,34,.6);
  border-bottom:1px solid var(--line);
}
.nav__inner{
  width:min(var(--maxw),94vw); margin-inline:auto;
  display:flex; align-items:center; justify-content:space-between;
  min-height:64px;
}
.nav__brand{ display:flex; flex-direction:column; line-height:1; color:var(--ink); }
.nav__brand-script{ font-family:var(--f-script); font-size:1.7rem; color:var(--terra); }
.nav__brand-date{ font-size:.62rem; letter-spacing:.34em; color:var(--ink-soft); margin-top:2px; }

.nav__menu{ display:flex; align-items:center; gap:1.5rem; }
.nav__menu a{
  color:var(--ink); font-weight:600; font-size:.85rem;
  letter-spacing:.01em; position:relative; padding:.2rem 0; white-space:nowrap;
}
.nav__full{ display:none; }
.nav__short{ display:inline; }
.nav__menu a:not(.nav__cta)::after{
  content:""; position:absolute; left:0; bottom:-3px; height:2px; width:0;
  background:var(--terra); transition:width .3s var(--ease);
}
.nav__menu a:not(.nav__cta):hover::after{ width:100%; }
.nav__cta{
  background:var(--terra); color:#fff !important; padding:.55rem 1.1rem;
  border-radius:999px; font-size:.82rem;
  box-shadow:0 10px 22px -12px rgba(187,79,54,.8);
}
.nav__cta:hover{ background:var(--terra-deep); transform:translateY(-1px); }

.nav__toggle{ display:none; flex-direction:column; gap:5px; background:none; border:0; cursor:pointer; padding:8px; }
.nav__toggle span{ width:26px; height:2px; background:var(--ink); border-radius:2px; transition:.3s var(--ease); }
.nav.is-open .nav__toggle span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.nav.is-open .nav__toggle span:nth-child(2){ opacity:0; }
.nav.is-open .nav__toggle span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative; min-height:100svh;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  text-align:center; padding:7rem 1.2rem 4rem;
  background:
    radial-gradient(120% 90% at 50% 0%, #FFFBF2 0%, var(--cream) 45%, var(--cream-2) 100%);
  overflow:hidden;
}
.hero::before,.hero::after{
  content:""; position:absolute; border-radius:50%; filter:blur(6px); opacity:.5;
  background:radial-gradient(circle at 30% 30%, var(--orange), transparent 70%);
}
.hero::before{ width:340px; height:340px; top:-90px; left:-90px; }
.hero::after{ width:300px; height:300px; bottom:-80px; right:-80px;
  background:radial-gradient(circle at 70% 70%, rgba(138,154,91,.6), transparent 70%); }

.hero__inner{ position:relative; z-index:2; max-width:680px; width:100%; }

.hero__overline{
  font-family:var(--f-sans); text-transform:uppercase; letter-spacing:.5em;
  font-size:.72rem; font-weight:700; color:var(--terra); margin:0 0 .4rem;
}
.hero__overline .ornament{ color:var(--orange); margin:0 .4rem; }

.hero__title{
  font-family:var(--f-script);
  font-size:clamp(3.4rem, 12vw, 6.4rem);
  font-weight:400; color:var(--terra); line-height:.95;
  margin:.2rem 0;
  text-shadow:0 2px 0 rgba(255,255,255,.4);
}
.hero__title .amp{ font-size:.8em; }
.hero__meta{
  font-family:var(--f-serif); font-style:italic; font-size:1.18rem;
  color:var(--ink-soft); margin:.2rem 0 1.6rem;
}

.hero__card{
  margin:0 auto 1.8rem; max-width:340px; padding:14px;
  background:#fff; border-radius:14px;
  box-shadow:var(--shadow), 0 0 0 1px rgba(201,154,78,.25);
  transform:rotate(-1.2deg);
  transition:transform .5s var(--ease);
}
.hero__card:hover{ transform:rotate(0deg) scale(1.015); }
.hero__card img{ border-radius:8px; }

/* Countdown */
.countdown{
  display:inline-flex; align-items:flex-start; gap:.5rem;
  margin:0 auto 1.8rem; padding:.9rem 1.4rem;
  background:rgba(255,255,255,.6); border:1px solid var(--line);
  border-radius:14px; backdrop-filter:blur(6px); box-shadow:var(--shadow-sm);
}
.countdown__item{ display:flex; flex-direction:column; align-items:center; min-width:58px; }
.countdown__num{
  font-family:var(--f-serif); font-weight:600; font-size:2.2rem;
  color:var(--terra); line-height:1; font-variant-numeric:tabular-nums;
}
.countdown__label{ font-size:.64rem; text-transform:uppercase; letter-spacing:.22em; color:var(--ink-soft); margin-top:4px; }
.countdown__sep{ font-family:var(--f-serif); font-size:1.8rem; color:var(--orange); line-height:1.2; }

/* Scroll cue */
.hero__scroll{ position:absolute; bottom:22px; left:50%; transform:translateX(-50%); z-index:2; }
.hero__scroll span{
  display:block; width:24px; height:38px; border:2px solid var(--terra); border-radius:14px; position:relative;
}
.hero__scroll span::after{
  content:""; position:absolute; left:50%; top:7px; width:4px; height:7px; border-radius:2px;
  background:var(--terra); transform:translateX(-50%); animation:scrollDot 1.6s var(--ease) infinite;
}
@keyframes scrollDot{ 0%{opacity:0;transform:translate(-50%,0)} 40%{opacity:1} 80%{opacity:0;transform:translate(-50%,12px)} 100%{opacity:0} }

/* ============================================================
   BOTONES
   ============================================================ */
.btn{
  display:inline-block; font-family:var(--f-sans); font-weight:700;
  letter-spacing:.04em; font-size:.92rem; padding:.95rem 2.1rem; border-radius:999px;
  cursor:pointer; transition:transform .25s var(--ease), box-shadow .25s var(--ease), background .25s var(--ease);
  border:0;
}
.btn--primary{ background:var(--terra); color:#fff; box-shadow:0 16px 30px -14px rgba(187,79,54,.85); }
.btn--primary:hover{ background:var(--terra-deep); color:#fff; transform:translateY(-2px); box-shadow:0 20px 34px -12px rgba(143,56,38,.9); }
.btn--light{ background:#fff; color:var(--terra); box-shadow:var(--shadow-sm); }
.btn--light:hover{ color:var(--terra-deep); transform:translateY(-2px); }
.btn--ghost{ background:transparent; color:var(--ink); border:1.5px solid var(--ink); }
.btn--ghost:hover{ background:var(--ink); color:var(--cream); }

/* ============================================================
   SECCIONES
   ============================================================ */
.section{ padding:clamp(4rem, 9vw, 7rem) 0; position:relative; }
.section--cream{ background:var(--cream); }
.section--sand{ background:linear-gradient(180deg,var(--cream-2),var(--sand)); }
.section__head{ text-align:center; max-width:720px; margin:0 auto clamp(2.4rem,5vw,3.6rem); }

.block-title{
  text-align:center; font-family:var(--f-serif); font-size:1.9rem; color:var(--ink);
  margin:3.4rem 0 1.6rem; font-weight:600;
}

/* ---------- Tarjetas de info ---------- */
.info-cards{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.6rem; }
.info-card{
  background:#fff; border-radius:var(--radius); padding:2.4rem 1.6rem; text-align:center;
  box-shadow:var(--shadow-sm); border:1px solid var(--line); position:relative;
  transition:transform .35s var(--ease), box-shadow .35s var(--ease);
}
.info-card:hover{ transform:translateY(-6px); box-shadow:var(--shadow); }
.info-card__icon{ font-size:2.4rem; margin-bottom:.4rem; }
.info-card h3{
  font-family:var(--f-sans); text-transform:uppercase; letter-spacing:.24em;
  font-size:.74rem; font-weight:700; color:var(--terra); margin-bottom:.6rem;
}
.info-card__big{ font-family:var(--f-serif); font-size:1.6rem; font-weight:600; color:var(--ink); margin:0; }
.info-card__note{ color:var(--ink-soft); margin:.2rem 0 0; font-size:.95rem; }

/* ============================================================
   RSVP
   ============================================================ */
.section--rsvp{
  background:linear-gradient(135deg, var(--terra) 0%, var(--terra-deep) 100%);
  color:#fdeee6;
}
.section--rsvp .rsvp__lead strong{ color:#fff; }
.rsvp{ display:grid; grid-template-columns:1.1fr .9fr; gap:3rem; align-items:center; }
.rsvp__lead{ font-size:1.12rem; max-width:42ch; color:#fce6dc; }
.rsvp__must{ margin:1.2rem 0 .2rem; font-weight:700; font-size:1.05rem; }
.badge{
  display:inline-block; background:#fff; color:var(--terra-deep); font-weight:800;
  text-transform:uppercase; letter-spacing:.12em; font-size:.7rem;
  padding:.3rem .7rem; border-radius:6px; margin-right:.5rem;
}
.rsvp__hint{ color:#fce0d4; margin:.2rem 0 1.6rem; font-family:var(--f-serif); font-style:italic; font-size:1.2rem; }

.rsvp__img{
  position:relative; display:block; border-radius:var(--radius); overflow:hidden;
  box-shadow:0 24px 50px -20px rgba(0,0,0,.55); border:3px solid rgba(255,255,255,.5);
  transition:transform .4s var(--ease);
}
.rsvp__img:hover{ transform:translateY(-5px) scale(1.01); }
.rsvp__img img{ width:100%; aspect-ratio:1/1; object-fit:cover; }
.rsvp__img-tag{
  position:absolute; left:50%; bottom:14px; transform:translateX(-50%);
  background:rgba(44,30,28,.78); color:#fff; padding:.5rem 1rem; border-radius:999px;
  font-weight:700; font-size:.82rem; letter-spacing:.04em; white-space:nowrap;
  backdrop-filter:blur(4px);
}

/* ============================================================
   TIMELINE — LA BODA
   ============================================================ */
.timeline{ list-style:none; margin:0 auto; padding:0; max-width:760px; position:relative; }
.timeline::before{
  content:""; position:absolute; left:27px; top:8px; bottom:8px; width:2px;
  background:linear-gradient(var(--gold),var(--terra)); opacity:.4;
}
.timeline__item{ position:relative; display:flex; gap:1.4rem; padding:0 0 2.2rem 0; }
.timeline__item:last-child{ padding-bottom:0; }
.timeline__dot{
  flex:0 0 56px; height:56px; border-radius:50%; background:#fff;
  display:grid; place-items:center; font-size:1.5rem; z-index:1;
  box-shadow:var(--shadow-sm); border:1px solid var(--line);
}
.timeline__body{
  background:#fff; border-radius:var(--radius); padding:1.4rem 1.6rem; flex:1;
  box-shadow:var(--shadow-sm); border:1px solid var(--line);
  transition:transform .3s var(--ease);
}
.timeline__item:hover .timeline__body{ transform:translateX(4px); }
.timeline__time{
  display:inline-block; font-size:.72rem; font-weight:700; text-transform:uppercase;
  letter-spacing:.16em; color:var(--terra); background:rgba(187,79,54,.1);
  padding:.2rem .6rem; border-radius:6px; margin-bottom:.5rem;
}
.timeline__body h3{ font-family:var(--f-serif); font-size:1.5rem; color:var(--ink); margin-bottom:.3rem; }
.timeline__body p{ margin:0; color:var(--ink-soft); }

/* ============================================================
   FEATURE (imagen + texto)
   ============================================================ */
.feature{
  display:grid; grid-template-columns:1fr 1fr; gap:3rem; align-items:center;
  margin-bottom:3.4rem;
}
.feature--reverse .feature__img{ order:2; }
.feature__img{ margin:0; }
.feature__img img{ width:100%; border-radius:var(--radius); box-shadow:var(--shadow); }
.feature__img--round{
  max-width:330px; margin-inline:auto;
}
.feature__img--round img{
  border-radius:50%; aspect-ratio:1/1; object-fit:cover; background:#fff;
  border:6px solid #fff; box-shadow:var(--shadow);
}
.feature__text h3{ font-family:var(--f-serif); font-size:1.8rem; color:var(--ink); margin-bottom:.6rem; }
.feature__text p{ color:var(--ink-soft); margin:0 0 1rem; }
.feature__small{ font-size:.92rem; }

/* Map */
.map{ border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow); border:1px solid var(--line); min-height:300px; }
.map iframe{ width:100%; height:100%; min-height:340px; border:0; display:block; filter:saturate(.9); }

/* ---------- Tick list ---------- */
.ticklist{ list-style:none; padding:0; margin:1rem 0; }
.ticklist li{ position:relative; padding-left:1.8rem; margin-bottom:.7rem; color:var(--ink-soft); }
.ticklist li::before{
  content:"✦"; position:absolute; left:0; top:0; color:var(--orange); font-size:.9rem;
}

/* ---------- Note cards ---------- */
.note-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:1.6rem; }
.note-grid--2{ grid-template-columns:repeat(2,1fr); }
.note-card{
  background:#fff; border-radius:var(--radius); padding:2rem; box-shadow:var(--shadow-sm);
  border:1px solid var(--line); border-top:4px solid var(--gold);
  transition:transform .3s var(--ease), box-shadow .3s var(--ease);
}
.note-card:hover{ transform:translateY(-4px); box-shadow:var(--shadow); }
.note-card--accent{ border-top-color:var(--terra); background:linear-gradient(180deg,#fff,#fff7f3); }
.note-card__icon{ font-size:2rem; margin-bottom:.5rem; }
.note-card h3{ font-family:var(--f-serif); font-size:1.5rem; color:var(--ink); margin-bottom:.6rem; }
.note-card p{ color:var(--ink-soft); margin:0 0 .8rem; }
.note-card p:last-child{ margin-bottom:0; }

/* ============================================================
   LOCALIZACIÓN + ALOJAMIENTO
   ============================================================ */
.locator{
  display:flex; flex-wrap:wrap; gap:1.6rem; justify-content:space-between; align-items:center;
  background:#fff; border-radius:var(--radius); padding:1.6rem 2rem; box-shadow:var(--shadow-sm);
  border:1px solid var(--line); margin-bottom:1rem;
}
.locator__addr{ display:flex; gap:1rem; align-items:flex-start; }
.locator__pin{ font-size:1.6rem; }
.locator__addr h3{ font-family:var(--f-serif); font-size:1.4rem; color:var(--ink); }
.locator__addr p{ margin:.2rem 0 0; color:var(--ink-soft); }
.locator__dist{ list-style:none; display:flex; gap:1.4rem; flex-wrap:wrap; padding:0; margin:0; }
.locator__dist li{ display:flex; flex-direction:column; }
.locator__dist span{ font-size:.72rem; text-transform:uppercase; letter-spacing:.16em; color:var(--terra); }
.locator__dist strong{ color:var(--ink); }

.lodging{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.6rem; }
.lodging__col{
  background:#fff; border-radius:var(--radius); padding:1.8rem; box-shadow:var(--shadow-sm);
  border:1px solid var(--line);
}
.lodging__col h4{
  font-family:var(--f-serif); font-size:1.5rem; color:var(--terra); margin-bottom:1rem;
  padding-bottom:.6rem; border-bottom:1px solid var(--line);
}
.lodging__col ul{ list-style:none; padding:0; margin:0; }
.lodging__col li{ margin-bottom:1.1rem; }
.lodging__col li:last-child{ margin-bottom:0; }
.lodging__col li strong{ color:var(--ink); }
.lodging__col li p{ margin:.3rem 0 0; color:var(--ink-soft); font-size:.94rem; }
.tag{ display:inline-block; font-size:.66rem; font-weight:800; letter-spacing:.06em; padding:.15rem .45rem; border-radius:5px; vertical-align:middle; margin-left:.3rem; }
.tag--deal{ background:var(--sage); color:#fff; }

.tipbar{
  display:flex; gap:1rem; align-items:flex-start;
  background:linear-gradient(135deg, rgba(230,150,58,.16), rgba(201,154,78,.1));
  border:1px dashed var(--gold); border-radius:var(--radius); padding:1.4rem 1.6rem; margin-top:1.6rem;
}
.tipbar span{ font-size:1.4rem; }
.tipbar p{ margin:0; color:var(--ink); }

/* ============================================================
   BELLEZA
   ============================================================ */
.beauty{ display:grid; grid-template-columns:repeat(2,1fr); gap:1.8rem; }
.beauty__col{
  background:#fff; border-radius:var(--radius); padding:2rem 2.2rem; box-shadow:var(--shadow-sm);
  border:1px solid var(--line);
}
.beauty__city{
  font-family:var(--f-script); font-size:2.6rem; color:var(--terra); line-height:1;
  margin-bottom:.6rem;
}
.beauty__sub{
  text-transform:uppercase; letter-spacing:.2em; font-size:.72rem; font-weight:700;
  color:var(--orange); margin:1.2rem 0 .4rem;
}
.beauty__list{ list-style:none; padding:0; margin:0; }
.beauty__list li{ padding:.55rem 0; border-bottom:1px solid var(--line); color:var(--ink-soft); }
.beauty__list li:last-child{ border-bottom:0; }
.beauty__list strong{ color:var(--ink); }

.continuara{
  text-align:center; font-family:var(--f-script); font-size:2rem; color:var(--terra);
  margin:2.6rem 0 0;
}
.continuara--light{ color:var(--orange); }

/* ============================================================
   TURISMO
   ============================================================ */
.tourism{ display:grid; grid-template-columns:repeat(2,1fr); gap:1.8rem; }
.tour-card{
  background:#fff; border-radius:var(--radius); padding:2rem 2.2rem; box-shadow:var(--shadow-sm);
  border:1px solid var(--line); transition:transform .3s var(--ease), box-shadow .3s var(--ease);
}
.tour-card:hover{ transform:translateY(-5px); box-shadow:var(--shadow); }
.tour-card__icon{ font-size:2.2rem; margin-bottom:.4rem; }
.tour-card h3{ font-family:var(--f-serif); font-size:1.6rem; color:var(--ink); margin-bottom:.8rem; }
.tour-card ul{ list-style:none; padding:0; margin:0; }
.tour-card li{ position:relative; padding-left:1.4rem; margin-bottom:.7rem; color:var(--ink-soft); }
.tour-card li::before{ content:"·"; position:absolute; left:.3rem; top:-.15rem; color:var(--orange); font-size:1.6rem; }
.tour-card li strong{ color:var(--ink); }

/* ============================================================
   GANADORES
   ============================================================ */
.section--winners{
  background:linear-gradient(135deg, var(--navy) 0%, #1f2a38 100%);
  color:#e9eef4;
}
.winners__lead{ text-align:center; max-width:60ch; margin:0 auto 2.6rem; color:#cfd8e2; font-size:1.1rem; }
.winners__lead a{ color:var(--orange); }
.winners{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.6rem; }
.winner{
  background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.14);
  border-radius:var(--radius); padding:2.2rem 1.8rem; text-align:center;
  backdrop-filter:blur(4px); transition:transform .3s var(--ease), background .3s var(--ease);
}
.winner:hover{ transform:translateY(-6px); background:rgba(255,255,255,.09); }
.winner__q{
  display:inline-block; font-family:var(--f-script); font-size:3rem; color:var(--orange);
  line-height:1; margin-bottom:.6rem;
}
.winner p{ margin:0; font-family:var(--f-serif); font-size:1.3rem; color:#f3f6fa; font-style:italic; }

/* ============================================================
   FOOTER
   ============================================================ */
.footer{
  background:var(--ink); color:#f3e7da; text-align:center;
  padding:clamp(3rem,7vw,5rem) 0 2.4rem;
}
.footer__inner{ display:flex; flex-direction:column; align-items:center; }
.footer__names{ font-family:var(--f-script); font-size:3.2rem; color:#fff; margin:0; line-height:1; }
.footer__names .amp{ color:var(--orange); }
.footer__date{ color:#c9b9a8; margin:.6rem 0 1.6rem; font-family:var(--f-serif); font-style:italic; font-size:1.05rem; }
.footer .btn--ghost{ border-color:#f3e7da; color:#f3e7da; }
.footer .btn--ghost:hover{ background:#f3e7da; color:var(--ink); }
.footer__rule{ width:60px; height:2px; background:var(--gold); margin:2.4rem auto 1.4rem; opacity:.6; }
.footer__credit{ margin:0; font-size:.92rem; letter-spacing:.04em; color:#cdbdac; }
.footer__credit strong{ color:#fff; }
.footer__credit .heart{ color:var(--terra); font-size:1.05rem; }
.footer__brand-link{ color:#fff; text-decoration:none; border-bottom:1px solid rgba(201,154,78,.55); transition:border-color .25s var(--ease), color .25s var(--ease); }
.footer__brand-link:hover{ color:var(--gold); border-bottom-color:var(--gold); }

/* ---------- Back to top ---------- */
.to-top{
  position:fixed; right:20px; bottom:20px; z-index:50;
  width:46px; height:46px; border-radius:50%; background:var(--terra); color:#fff !important;
  display:grid; place-items:center; font-size:1.2rem; text-decoration:none;
  box-shadow:0 14px 26px -12px rgba(187,79,54,.9);
  opacity:0; transform:translateY(14px) scale(.9); pointer-events:none;
  transition:opacity .3s var(--ease), transform .3s var(--ease), background .2s var(--ease);
}
.to-top.is-visible{ opacity:1; transform:none; pointer-events:auto; }
.to-top:hover{ background:var(--terra-deep); }

/* ============================================================
   REVEAL (animaciones on-scroll)
   ============================================================ */
html.js .reveal{ opacity:0; transform:translateY(26px); transition:opacity .8s var(--ease), transform .8s var(--ease); will-change:opacity,transform; }
html.js .reveal.is-visible{ opacity:1; transform:none; }

/* ============================================================
   MULTIPÁGINA — nav activa, subhero, home cards, IBAN, galería
   ============================================================ */

/* Nav: enlace activo */
.nav__menu a.is-active{ color:var(--terra); }
.nav__menu a.is-active:not(.nav__cta)::after{ width:100%; }

/* ---------- SUBHERO (cabecera de subpágina) ---------- */
.subhero{
  position:relative; padding:8.5rem 1.2rem 3.4rem; text-align:center;
  background:radial-gradient(120% 110% at 50% 0%, #FFFBF2 0%, var(--cream) 55%, var(--cream-2) 100%);
  overflow:hidden;
}
.subhero::before,.subhero::after{
  content:""; position:absolute; border-radius:50%; filter:blur(8px); opacity:.45; pointer-events:none;
}
.subhero::before{ width:240px;height:240px; top:-70px; left:-70px; background:radial-gradient(circle at 30% 30%,var(--orange),transparent 70%); }
.subhero::after{ width:220px;height:220px; bottom:-80px; right:-60px; background:radial-gradient(circle at 70% 70%,rgba(138,154,91,.6),transparent 70%); }
.subhero__inner{ position:relative; z-index:2; max-width:780px; margin:0 auto; }
.subhero__title{
  font-family:var(--f-serif); font-weight:600; color:var(--ink);
  font-size:clamp(2.3rem,6vw,3.8rem); line-height:1.08; margin:.2rem 0;
}
.subhero__sub{
  font-family:var(--f-serif); font-style:italic; color:var(--ink-soft);
  font-size:1.25rem; max-width:54ch; margin:1rem auto 0;
}
.subhero .divider{ margin-top:1.3rem; }

/* ---------- HOME: tarjetas de navegación a secciones ---------- */
.home-nav{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.4rem; }
.home-nav__card{
  display:flex; flex-direction:column; gap:.5rem; text-decoration:none;
  background:#fff; border:1px solid var(--line); border-radius:var(--radius);
  padding:1.8rem; box-shadow:var(--shadow-sm); color:var(--ink);
  transition:transform .3s var(--ease), box-shadow .3s var(--ease);
  position:relative; overflow:hidden;
}
.home-nav__card::after{
  content:"→"; position:absolute; right:1.4rem; top:1.6rem; color:var(--terra);
  font-size:1.2rem; opacity:0; transform:translateX(-6px); transition:.3s var(--ease);
}
.home-nav__card:hover{ transform:translateY(-6px); box-shadow:var(--shadow); color:var(--ink); }
.home-nav__card:hover::after{ opacity:1; transform:none; }
.home-nav__icon{ font-size:2rem; }
.home-nav__card h3{ font-family:var(--f-serif); font-size:1.45rem; color:var(--ink); }
.home-nav__card p{ margin:0; color:var(--ink-soft); font-size:.95rem; }

/* ---------- Banner de imagen grande (regalo) ---------- */
.bigbanner{ margin:0 auto; max-width:560px; }
.bigbanner img{
  width:100%; border-radius:var(--radius); box-shadow:var(--shadow);
  border:6px solid #fff;
}

/* ---------- Foto destacada con marco ---------- */
.framed{ margin:0; }
.framed img{ width:100%; border-radius:var(--radius); box-shadow:var(--shadow); display:block; }
.framed figcaption{ text-align:center; font-family:var(--f-serif); font-style:italic; color:var(--ink-soft); margin-top:.7rem; }

/* ---------- IBAN / número de cuenta ---------- */
.iban-card{
  max-width:640px; margin:2rem auto 0; background:#fff; border:1px solid var(--line);
  border-top:4px solid var(--gold); border-radius:var(--radius); padding:2rem; text-align:center;
  box-shadow:var(--shadow-sm);
}
.iban-card__label{ text-transform:uppercase; letter-spacing:.22em; font-size:.72rem; font-weight:700; color:var(--terra); margin:0 0 .8rem; }
.iban-row{ display:flex; flex-wrap:wrap; gap:.7rem; align-items:center; justify-content:center; }
.iban-number{
  font-family:"Courier New",monospace; font-size:clamp(1rem,3.6vw,1.5rem); font-weight:700; letter-spacing:.06em;
  color:var(--ink); background:var(--cream); padding:.7rem 1rem; border-radius:10px; border:1px dashed var(--gold);
  word-break:break-all;
}
.copy-btn{
  border:0; cursor:pointer; background:var(--terra); color:#fff; font-family:var(--f-sans); font-weight:700;
  padding:.7rem 1.2rem; border-radius:999px; font-size:.85rem; transition:background .2s var(--ease), transform .2s var(--ease);
  box-shadow:0 10px 22px -12px rgba(187,79,54,.8);
}
.copy-btn:hover{ background:var(--terra-deep); transform:translateY(-1px); }
.copy-btn.copied{ background:var(--sage); }

/* ---------- Galería de fotos (turismo) ---------- */
.gallery{ display:grid; grid-template-columns:repeat(4,1fr); gap:1rem; margin-top:.5rem; }
.gallery figure{ margin:0; border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow-sm); position:relative; }
.gallery img{ width:100%; height:220px; object-fit:cover; display:block; transition:transform .5s var(--ease); }
.gallery figure:hover img{ transform:scale(1.06); }
.gallery figcaption{
  position:absolute; left:0; right:0; bottom:0; padding:.7rem .9rem;
  background:linear-gradient(transparent, rgba(44,30,28,.78)); color:#fff;
  font-size:.85rem; font-weight:600;
}

/* ---------- Lista de alojamiento detallada ---------- */
.hotel{ background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:1.6rem 1.8rem; box-shadow:var(--shadow-sm); margin-bottom:1.2rem; }
.hotel:last-child{ margin-bottom:0; }
.hotel__head{ display:flex; flex-wrap:wrap; align-items:center; gap:.6rem; margin-bottom:.5rem; }
.hotel__name{ font-family:var(--f-serif); font-size:1.4rem; color:var(--ink); margin:0; }
.hotel p{ margin:.4rem 0 0; color:var(--ink-soft); }
.hotel a{ font-weight:600; }
.city-title{ font-family:var(--f-script); font-size:2.4rem; color:var(--terra); margin:2rem 0 1rem; line-height:1; }
.city-title:first-of-type{ margin-top:0; }

/* Caja de descuento */
.promo{ background:linear-gradient(135deg, rgba(138,154,91,.16), rgba(201,154,78,.12)); border:1px dashed var(--sage); border-radius:12px; padding:1rem 1.2rem; margin-top:.8rem; }
.promo code{ background:var(--ink); color:var(--cream); padding:.15rem .5rem; border-radius:5px; font-weight:700; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1180px){
  .nav__toggle{ display:flex; }
  .nav__menu{
    position:fixed; inset:64px 0 auto 0; flex-direction:column; gap:0; align-items:stretch;
    background:rgba(251,245,233,.98); backdrop-filter:blur(12px);
    padding:.6rem 0 1.4rem; box-shadow:0 20px 40px -20px rgba(58,42,34,.5);
    border-bottom:1px solid var(--line);
    transform:translateY(-130%); transition:transform .4s var(--ease); z-index:55;
    max-height:calc(100vh - 64px); overflow-y:auto;
  }
  .nav.is-open .nav__menu{ transform:none; }
  .nav__menu a{ padding:.95rem 8vw; width:100%; font-size:1.02rem; }
  .nav__menu a:not(.nav__cta){ border-bottom:1px solid var(--line); }
  .nav__menu a:not(.nav__cta)::after{ display:none; }
  .nav__menu a.nav__cta{ width:auto; align-self:center; margin:1.2rem auto 0; padding:.85rem 2.2rem; }
  /* en el menú desplegable mostramos el nombre completo */
  .nav__short{ display:none; }
  .nav__full{ display:inline; }
}

@media (max-width: 980px){
  .home-nav{ grid-template-columns:repeat(2,1fr); }
  .gallery{ grid-template-columns:repeat(2,1fr); }
}

@media (max-width: 920px){
  .rsvp{ grid-template-columns:1fr; gap:2rem; }
  .feature, .feature--reverse{ grid-template-columns:1fr; gap:1.6rem; }
  .feature--reverse .feature__img{ order:0; }
}

@media (max-width: 760px){
  .info-cards{ grid-template-columns:1fr; }
  .note-grid, .note-grid--2{ grid-template-columns:1fr; }
  .lodging{ grid-template-columns:1fr; }
  .beauty, .tourism, .winners{ grid-template-columns:1fr; }
  .locator{ flex-direction:column; align-items:flex-start; }
  .home-nav{ grid-template-columns:1fr; }
  .gallery{ grid-template-columns:1fr 1fr; }
  .gallery img{ height:160px; }
  .iban-number{ width:100%; }
  .countdown__item{ min-width:48px; }
  .countdown__num{ font-size:1.7rem; }
  .countdown{ gap:.2rem; padding:.8rem 1rem; }
  .section__intro{ font-size:1.15rem; }
}

@media (max-width: 380px){
  .countdown__sep{ display:none; }
  .countdown{ gap:.6rem; }
}

/* ---------- Reduce motion ---------- */
@media (prefers-reduced-motion: reduce){
  *{ animation-duration:.001ms !important; animation-iteration-count:1 !important; transition-duration:.001ms !important; scroll-behavior:auto !important; }
  html.js .reveal{ opacity:1 !important; transform:none !important; }
}
