.elementor-kit-7{--e-global-color-primary:#B08A4A;--e-global-color-secondary:#95713A;--e-global-color-text:#2C2C2C;--e-global-color-accent:#C8A66A;--e-global-color-muted:#666666;--e-global-color-cream:#F8F7F3;--e-global-color-line:#E8E2D8;--e-global-typography-primary-font-family:"Playfair Display";--e-global-typography-primary-font-size:60px;--e-global-typography-primary-font-weight:600;--e-global-typography-primary-line-height:1.05em;--e-global-typography-secondary-font-family:"Playfair Display";--e-global-typography-secondary-font-size:40px;--e-global-typography-secondary-font-weight:500;--e-global-typography-secondary-line-height:1.1em;--e-global-typography-text-font-family:"Inter";--e-global-typography-text-font-size:17px;--e-global-typography-text-font-weight:400;--e-global-typography-text-line-height:1.7em;--e-global-typography-accent-font-family:"Inter";--e-global-typography-accent-font-size:12px;--e-global-typography-accent-font-weight:700;--e-global-typography-accent-text-transform:uppercase;--e-global-typography-accent-letter-spacing:2.2px;--e-global-typography-display-font-family:"Playfair Display";--e-global-typography-display-font-size:104px;--e-global-typography-display-font-weight:600;--e-global-typography-display-line-height:1.02em;--e-global-typography-h3-font-family:"Playfair Display";--e-global-typography-h3-font-size:29px;--e-global-typography-h3-font-weight:600;--e-global-typography-h3-line-height:1.1em;--e-global-typography-stat-font-family:"Playfair Display";--e-global-typography-stat-font-size:64px;--e-global-typography-stat-font-weight:600;--e-global-typography-stat-line-height:1em;}.elementor-kit-7 e-page-transition{background-color:#FFBC7D;}.elementor-section.elementor-section-boxed > .elementor-container{max-width:1180px;}.e-con{--container-max-width:1180px;}.elementor-widget:not(:last-child){--kit-widget-spacing:20px;}.elementor-element{--widgets-spacing:20px 20px;--widgets-spacing-row:20px;--widgets-spacing-column:20px;}{}h1.entry-title{display:var(--page-title-display);}.site-header .site-branding{flex-direction:column;align-items:stretch;}.site-header{padding-inline-end:0px;padding-inline-start:0px;}.site-footer .site-branding{flex-direction:column;align-items:stretch;}@media(max-width:1024px){.elementor-kit-7{--e-global-typography-primary-font-size:46px;--e-global-typography-display-font-size:78px;}.elementor-section.elementor-section-boxed > .elementor-container{max-width:1024px;}.e-con{--container-max-width:1024px;}}@media(max-width:767px){.elementor-kit-7{--e-global-typography-primary-font-size:36px;--e-global-typography-secondary-font-size:28px;--e-global-typography-display-font-size:56px;--e-global-typography-stat-font-size:48px;}.elementor-section.elementor-section-boxed > .elementor-container{max-width:767px;}.e-con{--container-max-width:767px;}}
/* Start custom CSS *//* ============================================================
   Familia Martínez Osaba — CSS de sitio (kit 7)
   Solo lo que no es una opción nativa de Elementor.
   `.elementor-kit-7` = body.elementor-kit-7
   ============================================================ */

/* --- Header sticky con desenfoque --- */
.elementor-kit-7 .fg-header {
  -webkit-backdrop-filter: blur(16px);
  backdrop-filter: blur(16px);
  background: rgba(255, 255, 255, 0.92) !important;
}

/* --- Hero: imagen (widget) con recorte cover y degradado blanco encima --- */
.elementor-kit-7 .fg-hero-img {
  position: relative;
}
.elementor-kit-7 .fg-hero-img img {
  width: 100%;
  height: 640px;
  object-fit: cover;
  display: block;
}
@media (max-width: 767px) {
  .elementor-kit-7 .fg-hero-img img { height: 420px; }
}
.elementor-kit-7 .fg-hero-img::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 22px;
  background: linear-gradient(90deg, rgba(255, 255, 255, 0.92) 0%, rgba(255, 255, 255, 0.10) 40%);
  pointer-events: none;
  z-index: 1;
}

/* --- Historia: collage como widgets imagen con recorte cover --- */
.elementor-kit-7 .fg-collage-lg img {
  width: 100%;
  height: 440px;
  object-fit: cover;
  display: block;
}
.elementor-kit-7 .fg-collage-sm img {
  width: 100%;
  height: 213px;
  object-fit: cover;
  display: block;
}
@media (max-width: 767px) {
  .elementor-kit-7 .fg-collage-lg img { height: 320px; }
  .elementor-kit-7 .fg-collage-sm img { height: 220px; }
}

/* --- Galería de recuerdos (widget galería + lightbox) --- */
.elementor-kit-7 .fg-gallery img {
  aspect-ratio: 1 / 0.78;
  object-fit: cover;
  border-radius: 14px;
  display: block;
}

/* --- "Un adelanto": vídeo con bordes redondeados --- */
.elementor-kit-7 .fg-video .elementor-wrapper {
  border-radius: 22px;
  overflow: hidden;
}
.elementor-kit-7 .fg-video .elementor-custom-embed-image-overlay {
  min-height: 430px;
  background-size: cover;
  background-position: center center;
}

/* --- Separadores verticales entre tarjetas (info rápida, cuenta atrás) --- */
.elementor-kit-7 .fg-divider-row > .e-con {
  border-right: 1px solid var(--e-global-color-line);
}
.elementor-kit-7 .fg-divider-row > .e-con:last-child {
  border-right: 0;
}
@media (max-width: 767px) {
  .elementor-kit-7 .fg-divider-row > .e-con {
    border-right: 0;
    border-bottom: 1px solid var(--e-global-color-line);
  }
  .elementor-kit-7 .fg-divider-row > .e-con:last-child {
    border-bottom: 0;
  }
}

/* --- Cuenta atrás: cajas transparentes (números dorados sobre crema) --- */
.elementor-kit-7 .fg-countdown .elementor-countdown-item {
  background-color: transparent !important;
  padding: 0 25px;
}
.elementor-kit-7 .fg-countdown .elementor-countdown-item:not(:last-child) {
  border-right: 1px solid var(--e-global-color-line);
}
.elementor-kit-7 .fg-countdown .elementor-countdown-digits {
  margin-top: -25px;
}

/* --- Programa: línea horizontal que conecta los hitos --- */
.elementor-kit-7 .fg-timeline {
  position: relative;
}
.elementor-kit-7 .fg-timeline::before {
  content: "";
  position: absolute;
  top: 28px;
  left: 12.5%;
  width: 75%;
  right: auto;
  height: 1px;
  background: var(--e-global-color-accent);
  z-index: 0;
}
.elementor-kit-7 .fg-timeline > .e-con {
  position: relative;
  z-index: 1;
}
@media (max-width: 767px) {
  .elementor-kit-7 .fg-timeline::before {
    display: none;
  }
}

/* --- Tarjetas de cita: comillas decorativas --- */
.elementor-kit-7 .fg-quote-mark .elementor-heading-title {
  line-height: 0.5;
}

/* --- Acordeón FAQ (clásico): bordes suaves a juego con el diseño --- */
.elementor-kit-7 .fg-faq .elementor-accordion .elementor-accordion-item {
  border: 1px solid var(--e-global-color-line);
  border-radius: 12px;
  margin-bottom: 12px;
  background: #ffffff;
  overflow: hidden;
}
.elementor-kit-7 .fg-faq .elementor-accordion .elementor-tab-title {
  border: 0;
  font-weight: 700;
  color: var(--e-global-color-text);
}
.elementor-kit-7 .fg-faq .elementor-accordion .elementor-tab-content {
  border: 0;
}

/* --- Mapa embebido (iframe) --- */
.elementor-kit-7 .fg-map iframe {
  width: 100%;
  height: 360px;
  border: 0;
  display: block;
}/* End custom CSS */