:root { --bg:#F6F8EE; --ink:#1f2937; --muted:#64748b; --brand:#92400e; --ring:rgba(146,64,14,.25); }
*{box-sizing:border-box} html,body{height:100%}
body{margin:0;font:16px/1.6 system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,'Helvetica Neue',Arial;background:var(--bg);color:var(--ink)}

.container{max-width:1100px;margin:0 auto;padding:0 16px}
.section{padding:64px 0}
.h2{font-size:clamp(24px,3.5vw,32px);margin:0 0 4px}
.h3{font-size:18px;margin:0 0 6px}
.h4{font-size:14px;margin:0 0 6px}
.title{font-size:clamp(40px,7vw,64px);margin:6px 0 8px}
.eyebrow{color:#6B7751}
.muted{color:var(--muted)}
.card{border:1px solid #e2e8f0;background:#ffffffcc;border-radius:16px;padding:16px;box-shadow:0 8px 24px rgba(0,0,0,.06)}
.grid-2{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px}
.grid-3{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}
.center{display:flex;align-items:center;justify-content:center;min-height:200px}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:1px solid #cbd5e1;background:#fff;color:#334155;padding:10px 14px;border-radius:12px;font-weight:600;cursor:pointer;box-shadow:0 1px 2px rgba(0,0,0,.06)}
.btn:hover{box-shadow:0 4px 14px rgba(0,0,0,.08);transform:translateY(-1px)}
.btn:focus{outline:4px solid var(--ring)}
.btn--primary{background:var(--brand);color:#fff;border-color:rgba(0,0,0,0)}

.field{display:grid;gap:6px;font-size:14px}
.field input,.field select,.field textarea{border:1px solid #cbd5e1;border-radius:12px;padding:10px 12px;outline:0;box-shadow:0 1px 1px rgba(0,0,0,.03)}
.field input:focus,.field select:focus,.field textarea:focus{box-shadow:0 0 0 4px var(--ring)}
.check{display:flex;gap:8px;align-items:flex-start}
.form__msg{margin-top:8px;min-height:1.2em;color:var(--muted)}

.chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}
.chip{border:1px solid #cbd5e1;background:#fff;border-radius:12px;padding:6px 10px;font-size:12px;color:#334155;text-decoration:none}
.pills{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}
.pill{background:#f1f5f9;border-radius:999px;padding:6px 10px;font-size:12px}
.tag{border:1px solid #cbd5e1;background:#fff;border-radius:999px;padding:6px 10px;font-size:12px}

.gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:8px}
.gallery img{width:100%;aspect-ratio:1/1;object-fit:cover;border-radius:12px;border:1px solid #e2e8f0}
.thumb{width:100%;height:160px;object-fit:cover;border-radius:12px;border:1px solid #e2e8f0}
.embed{position:relative;padding-bottom:56.25%;height:0;border-radius:12px;overflow:hidden;border:1px solid #e2e8f0}
.embed iframe{position:absolute;inset:0;width:100%;height:100%;border:0}

.hero__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;align-items:center}
.hero__media img{max-height:260px}

.copyline{display:flex;gap:8px}
.copyline input{flex:1}
.qr{width:196px;height:196px;border:1px solid #e2e8f0;border-radius:12px}

.footer{border-top:1px solid #e2e8f0;background:#fff6}
.footer__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;padding:24px 0}
.footer a{color:inherit}
.footer ul{list-style:none;padding:0;margin:0}
.footer li{margin:4px 0}

/* Sticky CTA */
.cta-sticky{position:fixed;right:16px;bottom:16px;background:var(--brand);color:#fff;border-radius:999px;padding:12px 16px;text-decoration:none;font-weight:700;box-shadow:0 18px 40px rgba(0,0,0,.15);z-index:40}

/* Cover con música */
.cover{position:fixed;inset:0;display:grid;place-items:center;background:var(--bg);z-index:50}
.cover[hidden]{display:none}
.cover__box{max-width:520px;margin:0 16px;text-align:center}
.cover__img{width:100%;max-height:160px;object-fit:contain;border-radius:16px;box-shadow:0 10px 20px rgba(0,0,0,.08)}
.cover__title{color:#6B7751;margin:8px 0 0}
.cover__names{font-size:clamp(36px,6vw,56px);margin:4px 0 6px}
.cover__subtitle{color:var(--muted);margin:0 0 10px}
.cover__actions{display:flex;gap:10px;justify-content:center}
.cover__hint{margin-top:8px;color:var(--muted);font-size:12px}

/* Countdown */
.countdown{display:flex;gap:8px;margin-top:12px}
.timebox{min-width:70px;border:1px solid #e2e8f0;background:#fff;border-radius:12px;padding:8px 10px;text-align:center}
.num{font-size:22px;font-weight:700;font-variant-numeric:tabular-nums}
.lbl{font-size:12px;color:var(--muted)}

/* --- Portada con foto y transparencia --- */
.cover--photo{
  position:fixed; inset:0; display:grid; place-items:center; z-index:50;
  background: var(--bg);
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
}
.cover--photo[hidden]{ display:none; }

.cover__bg{
  position:absolute; inset:0; width:100%; height:100%; object-fit:cover; filter:grayscale(10%);
}

.cover__veil{
  position:absolute; inset:0;
  /* Blanco con transparencia para lavar la foto */
  background: rgba(255,255,255,.78);
}

/* Caligrafía gigante de agua (marcaje sutil) */
.cover__script{
  position:absolute; inset:0;
  display:flex; align-items:center; justify-content:center;
  font-family: "Great Vibes", cursive;
  font-size: min(22vw, 220px);
  color:#ffffff;
  mix-blend-mode: screen;
  opacity:.5;
  pointer-events:none;
  transform: translateY(-6%);
}

/* Contenido */
.cover__content{
  position:relative; z-index:2;
  text-align:center; padding:0 16px; max-width: 980px;
}

.cover__hello{
  margin:0 0 4px; font-size: clamp(18px, 2.4vw, 22px); color:#6B7751; font-weight:600;
}

.cover__headline{
  margin: 0 0 8px;
  font-family: "Playfair Display", serif;
  font-weight: 700;
  line-height: 1.1;
  color: #a76408; /* dorado cálido */
  font-size: clamp(32px, 6.2vw, 64px);
}
.cover__names{
  display:inline-block;
}

.cover__tagline{
  margin: 6px 0 12px;
  font-size: clamp(16px, 2.6vw, 22px);
  color: #9ca3af;
  font-weight: 600;
}

.cover__subtitle{
  margin: 0 0 14px;
  color: var(--muted);
  font-size: clamp(14px, 2vw, 18px);
}

.cover__actions{ display:flex; gap:12px; justify-content:center; flex-wrap:wrap; }

/* ===== HERO “full photo” ===== */
.hero-full{position:relative;min-height:92vh;display:grid;place-items:center;overflow:hidden}
.hero-full .hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transform:translateZ(0)}
.hero-full .hero-veil{position:absolute;inset:0;background:linear-gradient(to bottom, rgba(255,255,255,.25), rgba(255,255,255,.35));backdrop-filter:saturate(105%) blur(0px)}
.hero-full .hero-content{position:relative;z-index:2;text-align:center;color:#fff;padding:0 16px;max-width:1100px}

.hero-date{font-family:Inter,system-ui,sans-serif;font-weight:800;letter-spacing:.04em;
  font-size:clamp(16px,2.4vw,26px); opacity:.95; text-shadow:0 2px 10px rgba(0,0,0,.35); margin-bottom:10px}

.hero-names{display:flex;align-items:center;justify-content:center;gap:min(4vw,32px);margin:4px 0}
.name-left,.name-right{font-family:"Great Vibes",cursive;font-size:min(14vw,132px);line-height:1;color:#fff;
  text-shadow:0 2px 18px rgba(0,0,0,.35)}
.amp{display:inline-grid;place-items:center;width:min(11vw,88px);height:min(11vw,88px);border-radius:999px;
  background:#fff;color:#a76408;font-family: "Playfair Display",serif;font-weight:700;font-size:min(7vw,44px);
  box-shadow:0 8px 26px rgba(0,0,0,.25);}

.hero-divider{height:1px;background:linear-gradient(90deg,transparent,#ffffffa8,transparent);
  margin:clamp(8px,2.2vw,22px) auto;width:min(64vw,860px)}

.hero-quote{margin:clamp(8px,2.2vw,24px) 0;color:#ffffff;opacity:.95}
.hero-quote .qmark{font-family:"Playfair Display",serif;font-size:min(10vw,72px);line-height:1;vertical-align:top;opacity:.95;text-shadow:0 2px 14px rgba(0,0,0,.35)}
.hero-quote .qmark--end{margin-left:6px}
.hero-quote .qtext{font-family:Inter,system-ui,sans-serif;font-weight:600;font-size:clamp(18px,2.8vw,28px);
  text-shadow:0 2px 14px rgba(0,0,0,.35)}

.hero-cta{display:grid;gap:14px;justify-items:center;margin-top:clamp(10px,2.6vw,24px)}
.hero-cta .countdown .timebox{background:#ffffffd6;border-color:transparent}
.hero-cta .num{color:#111827}
.hero-cta .lbl{color:#4b5563}

/* === HERO: tamaños más chicos === */
.hero-full { min-height: 88vh; }

.hero-date{
  font-size: clamp(14px, 1.6vw, 20px);
  margin-bottom: 6px;
}

.hero-names{ gap: min(2.8vw, 22px); }
.name-left, .name-right{
  /* antes: min(14vw,132px) */
  font-size: min(10vw, 96px);
  text-shadow: 0 1px 12px rgba(0,0,0,.28);
}

.amp{
  /* antes: min(11vw,88px) */
  width: min(8vw, 64px);
  height: min(8vw, 64px);
  font-size: min(5.2vw, 32px);
  box-shadow: 0 6px 18px rgba(0,0,0,.22);
}

.hero-divider{
  width: min(56vw, 680px);
  margin: clamp(6px, 1.6vw, 16px) auto;
}

.hero-quote{
  margin: clamp(6px, 1.8vw, 16px) 0;
}
.hero-quote .qmark{
  /* antes: min(10vw,72px) */
  font-size: min(7vw, 48px);
}
.hero-quote .qtext{
  /* antes: clamp(18px,2.8vw,28px) */
  font-size: clamp(16px, 2vw, 22px);
  line-height: 1.35;
}

/* Countdown y CTA un toque más compactos */
.hero-cta { gap: 10px; margin-top: clamp(6px, 1.6vw, 14px); }
.hero-cta .timebox{ min-width: 60px; padding: 6px 8px; }
.hero-cta .num{ font-size: 18px; }
.hero-cta .lbl{ font-size: 11px; }


/* ==== Contador post-hero ==== */
.countdown-section{
  padding-top: clamp(36px, 6vw, 72px);
  padding-bottom: clamp(28px, 5vw, 56px);
  background: #fff; /* o el color que uses para la sección siguiente */
}

.countdown-title{
  margin: 0 0 18px;
  font-family: "Great Vibes", cursive;
  font-size: clamp(28px, 4.6vw, 56px);
  text-align: center;
  color: #a76408; /* dorado cálido */
}

.count-row{
  display: grid;
  grid-auto-flow: column;
  align-items: center;
  justify-content: center;
  gap: clamp(14px, 3vw, 28px);
}

.count-col{
  display: grid;
  justify-items: center;
  min-width: clamp(70px, 12vw, 120px);
}

.count-num{
  font-family: "Playfair Display", serif;
  font-weight: 600;
  font-size: clamp(28px, 6vw, 64px);
  line-height: 1;
  color: #7e672f;   /* dorado más oscuro para números */
}

.count-lbl{
  margin-top: 6px;
  font-family: Inter, system-ui, sans-serif;
  letter-spacing: .12em;
  font-weight: 600;
  font-size: clamp(10px, 1.6vw, 14px);
  color: #6b7280;   /* gris */
}

.count-sep{
  width: 1px;
  height: clamp(42px, 7vw, 72px);
  background: linear-gradient(#ddd, #cfcfcf);
  opacity: .9;
}

/* Responsive: en pantallas angostas, apilar dos por fila */
@media (max-width: 520px){
  .count-row{ grid-template-columns: 1fr 8px 1fr; row-gap: 18px; }
  .count-sep{ height: 44px; }
}


/* ===== CTAs debajo del contador ===== */
.count-ctas{
  margin-top: clamp(14px, 3vw, 28px);
  display: flex;
  gap: 12px;
  justify-content: center;
  flex-wrap: wrap;
}

/* Botón dorado */
.btn--gold{
  background: #a76408;
  color: #fff;
  border: 1px solid transparent;
  border-radius: 999px;
  padding: 12px 18px;
  font-weight: 700;
  box-shadow: 0 10px 24px rgba(166, 100, 8, .22);
}
.btn--gold:hover{ transform: translateY(-1px); box-shadow: 0 14px 30px rgba(166,100,8,.28); }

/* Variante ghost (también dorada, con borde) */
.btn--gold.btn--ghost{
  background: transparent;
  color: #a76408;
  border-color: #a76408;
  box-shadow: none;
}
.btn--gold.btn--ghost:hover{
  background: rgba(166,100,8,.08);
  transform: translateY(-1px);
}
/* Aplica a todos tus botones-enlace */
.btn, .btn:link, .btn:visited,
.btn--gold, .btn--gold:link, .btn--gold:visited {
  text-decoration: none;
}

/* Por si algún estilo lo vuelve a activar en hover/focus */
.btn:hover, .btn:focus,
.btn--gold:hover, .btn--gold:focus {
  text-decoration: none;
  outline: none;            /* opcional; si lo quitás, dejá un focus visible propio */
}

.hero-full { position: relative; min-height: 92vh; display: grid; place-items: center; overflow: hidden; }
.hero-bg-video{
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;            /* recorta para cubrir */
  object-position: center;      /* ajuste del encuadre */
  z-index: 0;
}
.hero-veil   { position:absolute; inset:0; background:linear-gradient(to bottom, rgba(255,255,255,.22), rgba(255,255,255,.35)); z-index: 1; }
.hero-content{ position:relative; z-index: 2; }

/* Flecha flotante al borde del hero */
.scroll-down{
  position: absolute;
  left: 50%;
  bottom: 18px;
  transform: translateX(-50%);
  z-index: 3;
  width: 52px; height: 52px;
  border-radius: 999px;
  display: grid; place-items: center;
  color: #a76408;                 /* dorado */
  background: #ffffffde;          /* blanquito */
  box-shadow: 0 10px 24px rgba(0,0,0,.18);
  text-decoration: none;
  transition: transform .2s ease, box-shadow .2s ease, background .2s ease;
  animation: scroll-bounce 1.8s ease-in-out infinite;
}
.scroll-down:hover{
  transform: translateX(-50%) translateY(-2px);
  box-shadow: 0 14px 32px rgba(0,0,0,.22);
}
@keyframes scroll-bounce{
  0%,100% { transform: translateX(-50%) translateY(0); }
  50%     { transform: translateX(-50%) translateY(-6px); }
}

/* Si preferís menos distracción en mobile */
@media (max-width: 420px){
  .scroll-down{ width:46px; height:46px; bottom:12px; }
}

/* ===== Sección Detalles con imagen de fondo ===== */
.detalles-section{
  position: relative;
  padding-top: clamp(48px, 6vw, 84px);
  padding-bottom: clamp(48px, 6vw, 84px);
  overflow: hidden;
}
.detalles-section::before{
  content:"";
  position:absolute; inset:0;
  background:
    linear-gradient(to bottom, rgba(255,255,255,.92), rgba(255,255,255,.88)),
    url("/img/fondo.jpg") center/cover no-repeat;
  z-index:-1;
  filter: saturate(105%) contrast(102%);
}
.detalles-section .subtitle{ margin-top:.25rem; margin-bottom:1.5rem; color:#6b7280; }

/* ===== Grid ===== */
.grid-2{
  display:grid; gap: clamp(16px, 2.8vw, 28px);
  grid-template-columns: 1fr;
}
@media (min-width: 900px){ .grid-2{ grid-template-columns: 1fr 1fr; } }

/* ===== Card premium (glass) ===== */
.event-card{
  position: relative;
  border-radius: 18px;
  padding: clamp(18px, 2.4vw, 26px);
  background: linear-gradient(180deg, rgba(255,255,255,.75), rgba(255,255,255,.68));
  backdrop-filter: blur(6px);
  box-shadow:
    0 24px 44px -18px rgba(17,24,39,.25),
    inset 0 1px 0 rgba(255,255,255,.7);
  border: 1px solid rgba(166,100,8,.22);
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.event-card::after{
  content:"";
  position:absolute; inset:-1px;
  border-radius:19px; pointer-events:none;
  background:
    radial-gradient(140px 120px at 8% 0%, rgba(166,100,8,.22), transparent 60%),
    radial-gradient(160px 140px at 100% 100%, rgba(166,100,8,.18), transparent 60%);
  opacity:.65;
}
.event-card:hover{
  transform: translateY(-3px);
  box-shadow: 0 28px 52px -18px rgba(17,24,39,.28);
  border-color: rgba(166,100,8,.35);
}

/* Encabezado con badge */
.card-head{ display:flex; align-items:center; gap:.6rem; margin-bottom:.2rem; }
.badge-dot{
  width:14px; height:14px; border-radius:999px; flex:0 0 auto;
  background: radial-gradient(circle at 30% 30%, #ffd9a8, #a76408);
  box-shadow: 0 0 0 3px rgba(166,100,8,.12);
}

/* Tipos dentro de la card */
.event-card .place{ color:#334155; font-weight:600; margin:.25rem 0 .5rem; }
.event-card .time-addr{ margin:0 0 .9rem; }

/* Acciones (botones mapas) */
.card-actions{ display:flex; gap:10px; flex-wrap:wrap; }
.btn{ text-decoration:none; }
.btn-outline{
  background: transparent; color:#a76408; border:1px solid #a76408;
  border-radius:999px; padding:10px 14px; font-weight:700;
  box-shadow:none; transition: background .2s, transform .2s, box-shadow .2s;
}
.btn-outline:hover{
  background: rgba(166,100,8,.08);
  transform: translateY(-1px);
}

/* Chips y tags */
.chips-row{ margin-top: clamp(12px, 2.2vw, 18px); display:flex; gap:10px; flex-wrap:wrap; }
.chip, .tag{
  background:#fff; border:1px solid rgba(166,100,8,.22); color:#374151;
  border-radius:999px; padding:8px 12px; font-weight:600;
  box-shadow:0 6px 18px rgba(17,24,39,.06);
}

/* Fondo suave opcional para #ubicacion (podés cambiar la imagen) */
.ubicacion-section{
  position: relative;
  padding-top: clamp(48px, 6vw, 84px);
  padding-bottom: clamp(48px, 6vw, 84px);
  overflow: hidden;
}
.ubicacion-section::before{
  content:"";
  position:absolute; inset:0;
  background:
    linear-gradient(to bottom, rgba(255,255,255,.88), rgba(255,255,255,.84)),
    url("/img/ubicacion-bg.jpg") center/cover no-repeat;
  z-index:-1;
  filter: saturate(105%) contrast(102%);
}
.ubicacion-section .subtitle{ margin-top:.25rem; margin-bottom:1.5rem; color:#6b7280; }

/* Redondeo del iframe + borde interior */
.embed--rounded iframe{
  width:100%; height:360px; border:0; display:block;
  border-radius: 14px;
  box-shadow: inset 0 0 0 1px rgba(0,0,0,.06);
}

/* Lista con separación suave */
.list--soft{ margin: 14px 0 18px; }
.list--soft li{ margin: 6px 0; }

/* ===== Secciones con fondo suave opcional (podés cambiar imagen/ruta) ===== */
.historia-section::before,
.galeria-section::before,
.faq-section::before,
.playlist-section::before,
.regalos-section::before{
  content:"";
  position:absolute; inset:0; z-index:-1;
  background: linear-gradient(to bottom, rgba(255,255,255,.92), rgba(255,255,255,.88));
}
.historia-section, .galeria-section, .faq-section, .playlist-section, .regalos-section{
  position: relative;
  overflow: hidden;
}

/* ===== Grids ===== */
.grid-3{ display:grid; gap: clamp(16px,2.6vw,24px); grid-template-columns: 1fr; }
@media (min-width: 900px){ .grid-3{ grid-template-columns: repeat(3, 1fr); } }

/* ===== Imágenes / thumbs ===== */
.thumb{ width: 100%; max-width: 160px; margin: .5rem auto 0; display:block; }
.rounded{ border-radius: 14px; }

/* ===== Galería “cards de vidrio” ===== */
.gallery{
  display:grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: clamp(10px, 2vw, 16px);
  margin-top: 14px;
}
.gallery-item{
  background: linear-gradient(180deg, rgba(255,255,255,.75), rgba(255,255,255,.65));
  backdrop-filter: blur(5px);
  border:1px solid rgba(166,100,8,.18);
  border-radius: 16px;
  overflow:hidden;
  box-shadow: 0 16px 30px -16px rgba(17,24,39,.22);
  transition: transform .2s ease, box-shadow .2s ease;
}
.gallery-item img{ width:100%; height:100%; object-fit:cover; display:block; }
.gallery-item:hover{ transform: translateY(-3px); box-shadow: 0 24px 44px -18px rgba(17,24,39,.28); }

/* ===== FAQ como cards ===== */
.faq-card{ padding: clamp(16px,2.2vw,22px); }
.faq-card summary{
  list-style:none; cursor:pointer; font-weight:800; color:#1f2937;
  display:flex; align-items:center; gap:.6rem;
}
.faq-card summary::-webkit-details-marker{ display:none; }
.faq-card[open] summary{ color:#a76408; }
.faq-card p{ margin:.6rem 0 0; }

/* ===== Copylines (Regalos) ===== */
.copyline{
  display:flex; gap:8px; align-items:center; margin:.35rem 0 1rem;
}
.copyline input{
  flex:1 1 auto; height:44px; border-radius:12px; border:1px solid rgba(0,0,0,.08);
  padding:0 12px; background:#fff;
}
.copyline--glass input{
  background: linear-gradient(180deg, rgba(255,255,255,.85), rgba(255,255,255,.78));
  box-shadow: inset 0 1px 0 rgba(255,255,255,.7);
}

/* ===== Form playlist ===== */
.field{ display:grid; gap:6px; margin:.6rem 0 1rem; }
.field input{
  height:44px; border-radius:12px; border:1px solid rgba(0,0,0,.08); padding:0 12px;
  background:#fff;
}

/* ===== QR ===== */
.qr{ width:min(260px, 90%); display:block; margin:.5rem auto 0; }

/* ===== Embeds redondeados ===== */
.embed--rounded iframe{
  width:100%; height:360px; border:0; display:block;
  border-radius:14px; box-shadow: inset 0 0 0 1px rgba(0,0,0,.06);
}

/* ===== Centrados rápidos ===== */
.center{ text-align:center; }

/* Fondo suave opcional */
.valor-section{
  position: relative; overflow: hidden;
}
.valor-section::before{
  content:"";
  position:absolute; inset:0; z-index:-1;
  background: linear-gradient(to bottom, rgba(255,255,255,.92), rgba(255,255,255,.88));
}

/* Layout interno */
.valor-row{
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
  align-items: center;
  margin: .4rem 0 1rem;
}
@media (min-width: 760px){
  .valor-row{ grid-template-columns: 1fr auto; }
}

/* Precio */
.precio-actual{
  display:flex; align-items: baseline; gap:10px;
}
.precio-actual .moneda{
  display:inline-block; padding:4px 10px; border-radius:999px;
  background: #fff; border:1px solid rgba(166,100,8,.25); color:#a76408; font-weight:700;
  box-shadow: 0 6px 16px rgba(17,24,39,.06);
}
.monto{
  font-size: clamp(28px, 4.4vw, 44px);
  line-height: 1; font-weight: 900; color:#1f2937;
  text-shadow: 0 1px 6px rgba(0,0,0,.06);
}

/* Chips de medios de pago */
.valor-pagos{ display:flex; gap:10px; flex-wrap:wrap; justify-content:flex-start; }

/* FAQ compacto y estético */
.faq-card{
  padding: clamp(14px, 2.0vw, 18px);
}

.faq-card summary{
  list-style: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: .55rem;
  font-weight: 800;
  color: #1f2937;
  /* tamaño de letra más pequeño */
  font-size: clamp(14px, 1.6vw, 16px);
}

/* ocultar el marcador por defecto */
.faq-card summary::-webkit-details-marker{ display: none; }

/* efecto al abrir */
.faq-card[open] summary{ color: #a76408; }

/* respuesta más pequeña y legible */
.faq-card p{
  margin: .5rem 0 0;
  font-size: clamp(13px, 1.5vw, 15px);
  line-height: 1.45;
}

/* chevron minimalista al final del summary */
.faq-card summary::after{
  content: "";
  width: 10px; height: 10px; margin-left: auto;
  border-right: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
  transform: rotate(45deg);
  transition: transform .2s ease;
  opacity: .8;
}
.faq-card[open] summary::after{ transform: rotate(-135deg); }

/* badge ya existente, un toque más chico */
.faq-card .badge-dot{ width: 10px; height: 10px; box-shadow: 0 0 0 2px rgba(166,100,8,.12); }

/* Fondo con imagen para #valor */
.valor-section{
  position: relative;
  overflow: hidden;
  padding-top: clamp(48px, 6vw, 84px);
  padding-bottom: clamp(48px, 6vw, 84px);
}
.valor-section::before{
  content:"";
  position:absolute; inset:0; z-index:-1;
  background:
    /* velo: bajá/ subí opacidad si querés ver más/menos la foto */
    linear-gradient(to bottom, rgba(255,255,255,.82), rgba(255,255,255,.78)),
    url("/img/fondo2.jpg") center/cover no-repeat;
  filter: saturate(108%) contrast(103%);
}
/* Un toque más glass para la card sobre foto */
.valor-section .event-card{
  background: linear-gradient(180deg, rgba(255,255,255,.72), rgba(255,255,255,.62));
  backdrop-filter: blur(6px);
  border-color: rgba(166,100,8,.26);
  box-shadow: 0 30px 60px -20px rgba(17,24,39,.28), inset 0 1px 0 rgba(255,255,255,.75);
}
/* Si en mobile falta contraste, subimos el velo un poquito */
@media (max-width: 540px){
  .valor-section::before{
    background:
      linear-gradient(to bottom, rgba(255,255,255,.88), rgba(255,255,255,.84)),
      url("/img/fondo2-celu.jpg") center/cover no-repeat;
  }
}

/* Botón flotante de música */
.music-btn{
  position: fixed; right: 16px; bottom: 16px; z-index: 50;
  width: 46px; height: 46px; border-radius: 999px;
  border: 1px solid #a76408; background: #fff; color:#a76408;
  display: grid; place-items: center; font-weight: 700;
  box-shadow: 0 10px 24px rgba(0,0,0,.18); cursor: pointer;
}
.music-btn:hover{ transform: translateY(-1px); box-shadow: 0 14px 30px rgba(0,0,0,.22); }
.music-btn[aria-pressed="true"]{ background:#a76408; color:#fff; }

/* Fondo con imagen para la sección Valor */
.valor-section{
  position: relative; overflow: hidden;
  padding-top: clamp(48px, 6vw, 84px);
  padding-bottom: clamp(48px, 6vw, 84px);
}
.valor-section::before{
  content:""; position:absolute; inset:0; z-index:-1;
  background:
    linear-gradient(to bottom, rgba(255,255,255,.82), rgba(255,255,255,.78)),
    var(--valor-bg, url('/img/valor-bg.jpg')) center/cover no-repeat;
  filter: saturate(108%) contrast(103%);
}
.valor-section .event-card{
  background: linear-gradient(180deg, rgba(255,255,255,.72), rgba(255,255,255,.62));
  backdrop-filter: blur(6px);
  border-color: rgba(166,100,8,.26);
  box-shadow: 0 30px 60px -20px rgba(17,24,39,.28), inset 0 1px 0 rgba(255,255,255,.75);
}
@media (max-width: 540px){
  .valor-section::before{
    background:
      linear-gradient(to bottom, rgba(255,255,255,.88), rgba(255,255,255,.84)),
      var(--valor-bg, url('/img/valor-bg.jpg')) center/cover no-repeat;
  }
}

/* FAQ compacto */
.faq-card{ padding: clamp(14px, 2.0vw, 18px); }
.faq-card summary{
  list-style: none; cursor: pointer; display:flex; align-items:center; gap:.55rem;
  font-weight:800; color:#1f2937; font-size: clamp(14px, 1.6vw, 16px);
}
.faq-card summary::-webkit-details-marker{ display:none; }
.faq-card[open] summary{ color:#a76408; }
.faq-card p{ margin:.5rem 0 0; font-size:clamp(13px,1.5vw,15px); line-height:1.45; }
.faq-card summary::after{
  content:""; width:10px; height:10px; margin-left:auto;
  border-right:2px solid currentColor; border-bottom:2px solid currentColor;
  transform:rotate(45deg); transition:transform .2s ease; opacity:.8;
}
.faq-card[open] summary::after{ transform:rotate(-135deg); }
.faq-card .badge-dot{ width:10px; height:10px; box-shadow:0 0 0 2px rgba(166,100,8,.12); }

/* === FAQ: tipografías y pesos más livianos === */
#faq .faq-card summary,
#faq .faq-card p{
  font-family: "Inter", system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
}

/* títulos del acordeón (la pregunta) */
#faq .faq-card summary{
  font-weight: 500;            /* antes 800 */
  letter-spacing: .1px;
}

/* estado abierto: un poquito más marcado si querés */
#faq .faq-card[open] summary{
  font-weight: 600;            /* podés dejar 500 si lo querés igual */
  color: #a76408;              /* o quitá esta línea si no querés color */
}

/* texto de las respuestas */
#faq .faq-card p{
  font-weight: 400;            /* normal */
}

/* flechita más fina (opcional) */
#faq .faq-card summary::after{
  border-right-width: 1.5px;
  border-bottom-width: 1.5px;
}


.detalles-grid {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: 2rem;
}

.detalles-left {
  display: grid;
  gap: 1.5rem;
}

.chips-col {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

@media (max-width: 768px) {
  .detalles-grid {
    grid-template-columns: 1fr;
  }
}

.embed iframe {
  min-height: 180px;
  filter: saturate(0.9) contrast(0.95);
}

/* DETALLES layout 2 columnas */
.detalles-grid{
  display: grid;
  grid-template-columns: 1.1fr .9fr; /* izq más grande, der más compacta */
  gap: 28px;
  align-items: start;
}

/* derecha: stack vertical */
.detalles-side{
  display: grid;
  gap: 18px;
}

/* hacer que la columna derecha “suba” y se vea centrada visualmente */
@media (min-width: 980px){
  .detalles-side{
    margin-top: 12px; /* ajustá 0-20px según tu ojo */
  }
}

/* tamaño del mapa para que no deforme la card */
.detalles-map iframe{
  width: 100%;
  height: 240px; /* ajustá si querés más chico */
  border: 0;
}

/* responsive */
@media (max-width: 980px){
  .detalles-grid{
    grid-template-columns: 1fr;
  }
  .detalles-map iframe{
    height: 200px;
  }
}
/* ===== Card con imagen de fondo (solo donde la uses) ===== */
.card-bg{
  position: relative;
  overflow: hidden;
  isolation: isolate;
  background: rgba(255,255,255,.06);
}

.card-bg::before{
  content:"";
  position:absolute;
  inset:0;
  background-image: var(--card-bg, none);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  opacity: var(--card-bg-opacity, .28);
  transform: scale(1.04);
  z-index: 0;
}

.card-bg::after{
  content:"";
  position:absolute;
  inset:0;
  background: linear-gradient(180deg,
    rgba(0,0,0,.35),
    rgba(0,0,0,.55)
  );
  opacity: var(--card-overlay-opacity, .35);
  z-index: 0;
}

.card-bg > *{
  position: relative;
  z-index: 1;
}
/* ===== Cards con fondo real (solo las que tengan .card-bg) ===== */

/* 1) que no las tape el fondo glass de .event-card */
.event-card.card-bg{
  background: transparent !important;
}

/* 2) imagen (ruta correcta desde css/styles.css) */
.card-bg::before{
  background-image: var(--card-bg, url('../img/fondo.jpg')) !important;
  opacity: var(--card-bg-opacity, .85) !important;
  transform: scale(1.03);
}

/* 3) overlay más suave para que se vea la foto */
.card-bg::after{
  opacity: var(--card-overlay-opacity, .18) !important;
}



/* ===== Card con fondo: texto blanco + mejor contraste ===== */
.event-card.card-bg{
  color: #fff;
}

.event-card.card-bg .muted,
.event-card.card-bg p,
.event-card.card-bg li{
  color: rgba(255,255,255,.92) !important;
}

/* títulos un poco más sólidos */
.event-card.card-bg .h3,
.event-card.card-bg .h4{
  color: #fff !important;
  text-shadow: 0 2px 10px rgba(0,0,0,.35);
}

/* listitas más legibles */
.event-card.card-bg li{
  text-shadow: 0 2px 10px rgba(0,0,0,.35);
}

/* badge que siga viéndose bien */
.event-card.card-bg .badge-dot{
  box-shadow: 0 0 0 3px rgba(255,255,255,.14);
}

/* ===== Botones: que resalten sobre foto ===== */
.event-card.card-bg .btn{
  background: rgba(255,255,255,.92);
  color: #111827;
  border-color: transparent;
  box-shadow: 0 14px 30px rgba(0,0,0,.25);
}

.event-card.card-bg .btn:hover{
  transform: translateY(-2px);
  box-shadow: 0 18px 40px rgba(0,0,0,.32);
}

/* Botón principal (el que querés que destaque más) */
.event-card.card-bg .btn.btn-outline{
  background: #a76408;     /* dorado */
  color: #fff;
  border-color: transparent;
  box-shadow: 0 16px 34px rgba(0,0,0,.28);
}

.event-card.card-bg .btn.btn-outline:hover{
  background: #8f5606;
}

/* En mobile: usar otra imagen si existe --card-bg-m */
@media (max-width: 540px){
  .card-bg::before{
    background-image: var(--card-bg-m, var(--card-bg)) !important;
    background-position: center;
    background-size: cover;
    transform: scale(1.08); /* opcional */
  }
}

/* ===== ESPACIO ENTRE CARDS (solo en esta página si querés) ===== */
.container > .event-card{
  margin-top: 18px;
}
.container > .event-card:first-of-type{
  margin-top: 14px;
}

/* ===== LEGIBILIDAD dentro de cards con imagen ===== */
.event-card.card-bg{
  padding: clamp(18px, 3.6vw, 28px);
}

/* Más contraste: oscurecer overlay (subí/bajá a gusto) */
.event-card.card-bg::after{
  opacity: .30 !important;
}

/* Texto: más grande + más espaciado */
.event-card.card-bg,
.event-card.card-bg p,
.event-card.card-bg li{
  font-size: 16px;
  line-height: 1.75;
}

/* Subtítulos H4 un toque más visibles */
.event-card.card-bg .h4{
  font-size: 15px;
  margin-top: 14px;
  margin-bottom: 6px;
}

/* La lista: separación entre items */
.event-card.card-bg ul{
  margin-top: 10px !important;
}
.event-card.card-bg li{
  margin: 6px 0;
}

/* Que no quede texto “muy ancho” en desktop (más legible) */
@media (min-width: 900px){
  .event-card.card-bg{
    max-width: 980px;
    margin-left: auto;
    margin-right: auto;
  }
}

/* MOBILE: un poquito más grande y overlay un toque más fuerte */
@media (max-width: 540px){
  .container > .event-card{ margin-top: 14px; }

  .event-card.card-bg,
  .event-card.card-bg p,
  .event-card.card-bg li{
    font-size: 16px;
    line-height: 1.8;
  }

  .event-card.card-bg::after{
    opacity: .38 !important;
  }
}
/* Playlist más grande en desktop */
@media (min-width: 900px){
  #playlist .grid-2{
    grid-template-columns: 1.35fr .95fr; /* izquierda más ancha */
    align-items: start;
  }
}

/* 1) Bloqueo de overflow horizontal por seguridad */
html, body { max-width: 100%; overflow-x: hidden; }

/* 2) Media/iframes nunca deben exceder el ancho */
img, video, iframe { max-width: 100%; height: auto; }

/* 3) Asegurar que la container no genere overflow */
.container { width: 100%; }

/* 4) Spotify embed sin ratio 16:9 (para que no rompa en mobile) */
.embed--spotify iframe{
  display: block;
  width: 100%;
  height: 560px;
  border: 0;
}

/* En celular, un poco menos alto para que se vea cómodo */
@media (max-width: 520px){
  .embed--spotify iframe{ height: 460px; }
}

/* 5) Separación entre cards cuando están una debajo de la otra (mobile) */
@media (max-width: 900px){
  .grid-2{ grid-template-columns: 1fr; }
  .grid-2 > *{ margin-bottom: 16px; }
  .grid-2 > *:last-child{ margin-bottom: 0; }
}
.footer--simple{
  padding: 18px 0;
  text-align: center;
}

.footer--simple .footer-text{
  margin: 0;
  color: var(--muted);
  font-weight: 600;
  letter-spacing: .2px;
}

.faq-section{
  position: relative;
  overflow: hidden;
}

.faq-section::before{
  content:"";
  position:absolute; inset:0; z-index:-1;
  background:
    linear-gradient(to bottom, rgba(255,255,255,.88), rgba(255,255,255,.86)),
    url("/img/fondo-celu.jpg") center/cover no-repeat;
}

/* Quitar foto de fondo SOLO en Detalles del evento */
.detalles-section::before{
  background-image: none !important;
  background: linear-gradient(to bottom, rgba(255,255,255,.92), rgba(255,255,255,.88)) !important;
  filter: none !important;
}
.map-embed{
  width:100%;
  border-radius:16px;
  overflow:hidden;
  border:1px solid rgba(148,163,184,.35);
  background:#fff;
}
.map-embed iframe{
  width:100%;
  height:280px; /* ajustá */
  border:0;
  display:block;
}
.rsvp-section{
  background: #F6F8EE; /* o el tono que estés usando */
  position: relative;
  overflow: hidden;
  padding: 72px 0;
}

/* si tenías overlay, eliminá esto */
.rsvp-section::before{ display:none; }
/* ✅ RSVP: fondo blanco */
.rsvp-section{
  background: #fff !important;
}

/* ✅ por si había overlay */
.rsvp-section::before{
  display: none !important;
}
/* HERO contenedor */
.hero-full{
  position: relative;
  min-height: 100vh;
  overflow: hidden;
}

.site-footer{
  position: relative;
  padding: 22px 16px 28px;
  background: linear-gradient(180deg, rgba(246,248,238,0), rgba(246,248,238,.95));
}

.site-footer::before{
  content:"";
  position:absolute;
  left:16px;
  right:16px;
  top:0;
  height:1px;
  background: rgba(146,64,14,.18); /* doradito suave */
}

.footer-inner{
  max-width: 1100px;
  margin: 0 auto;
  display: flex;
  gap: 10px;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;

  padding: 12px 14px;
  border: 1px solid rgba(148,163,184,.22);
  border-radius: 999px;

  background: rgba(255,255,255,.72);
  backdrop-filter: blur(6px);
  box-shadow: 0 14px 30px rgba(15,23,42,.08);
}

.footer-chip{
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(146,64,14,.10);
  border: 1px solid rgba(146,64,14,.18);
  color: #1f2937;
  font-weight: 600;
  letter-spacing: .2px;
}

.footer-dot{
  width: 6px;
  height: 6px;
  border-radius: 999px;
  background: rgba(146,64,14,.55);
}

.footer-date{
  color: #64748b;
  font-weight: 600;
}

.footer-icons{
  display: inline-flex;
  gap: 6px;
  font-size: 16px;
  transform: translateY(1px);
}
.gallery-item--video .gallery-video{
  width: 100%;
  height: 100%;
  display: block;
  border-radius: 14px;
  object-fit: cover;
  background: #000;
}
.fotos-btn{
  width: 100%;
  justify-content: center;
}


/* ✅ Evitar que el botón muestre texto tipo "Reproducir" por ::before/::after */
.music-btn::before,
.music-btn::after{
  content: none !important;
}

/* ✅ Asegurar que el símbolo se vea bien centrado */
.music-btn{
  width:46px;
  height:46px;
  padding:0;
  border-radius:999px;
  display:grid;
  place-items:center;
  line-height:1;
  font-size:18px;
  overflow:hidden;
  white-space:nowrap;
}
