/* fotomatonbodasbarcelona.com — rendimiento, móvil y bloques SEO local */

:root {
  --bodas-teal: #5a9ea3;
  --bodas-teal-dark: #3d7f84;
  --bodas-teal-light: #8ec9cd;
  --bodas-gold: #c9a962;
  --bodas-cream: #faf9f7;
  --bodas-ink: #1e2a2b;
  --bodas-text: #3d4a4b;
  --bodas-radius: 14px;
  --bodas-shadow: 0 20px 50px rgba(30, 42, 43, 0.08);
  --font-display: "Cormorant Garamond", Georgia, "Times New Roman", serif;
  --font-body: "Outfit", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
}

/* Tipografía premium */
body {
  font-family: var(--font-body);
  color: var(--bodas-text);
  background: var(--bodas-cream);
  -webkit-font-smoothing: antialiased;
}

h1, h2, h3, .tittle, .diferente {
  font-family: var(--font-display);
  font-weight: 600;
  letter-spacing: 0.02em;
  color: var(--bodas-ink);
}

/* No forzar color oscuro dentro del hero/slider */
.banner-info h1,
.banner-info h2,
.banner-info h3 {
  color: #fff;
}

.about h1.tittle,
#about-heading {
  font-size: clamp(1.75rem, 4vw, 2.5rem);
  line-height: 1.2;
}

.site-header.is-fixed {
  background: rgba(30, 42, 43, 0.92);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}

.banner,
.bannerTarragona,
.bannerLleida,
.bannerGirona,
.bannerAndorra,
#home.banner,
#home.bannerTarragona,
#home.bannerLleida,
#home.bannerGirona,
#home.bannerAndorra {
  position: relative;
  min-height: clamp(480px, 58vh, 720px) !important;
  display: flex !important;
  flex-direction: column;
  overflow: hidden;
}

.banner::after,
.bannerTarragona::after,
.bannerLleida::after,
.bannerGirona::after,
.bannerAndorra::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(30, 42, 43, 0.35) 0%, rgba(30, 42, 43, 0.55) 100%);
  pointer-events: none;
  z-index: 1;
}

.banner .header-bottom,
.bannerTarragona .header-bottom,
.bannerLleida .header-bottom,
.bannerGirona .header-bottom,
.bannerAndorra .header-bottom {
  position: relative;
  z-index: 3;
}

.banner-info,
.banner .hero-cta,
.bannerTarragona .hero-cta,
.bannerLleida .hero-cta,
.bannerGirona .hero-cta,
.bannerAndorra .hero-cta {
  position: relative;
  z-index: 2;
}

/* Hero provincias = mismo bloque centrado que la home */
.banner .hero-cta,
.bannerTarragona .hero-cta,
.bannerLleida .hero-cta,
.bannerGirona .hero-cta,
.bannerAndorra .hero-cta,
.banner-info.hero-cta,
#home .banner-info.hero-cta {
  flex: 1 1 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 !important;
  margin-top: 0 !important;
  margin-left: 0 !important;
  padding: 2rem 1rem 4rem !important;
  text-align: center !important;
  box-sizing: border-box;
}

.banner .hero-cta .cta-row,
.bannerTarragona .hero-cta .cta-row,
.bannerLleida .hero-cta .cta-row,
.bannerGirona .hero-cta .cta-row,
.bannerAndorra .hero-cta .cta-row {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  justify-content: center;
  align-items: center;
  margin: 0;
}

/* Sin carrusel en hero: ocultar puntos/flechas huérfanos */
.banner .callbacks_tabs,
.bannerTarragona .callbacks_tabs,
.bannerLleida .callbacks_tabs,
.bannerGirona .callbacks_tabs,
.bannerAndorra .callbacks_tabs,
.banner .callbacks_nav,
.bannerTarragona .callbacks_nav,
.bannerLleida .callbacks_nav,
.bannerGirona .callbacks_nav,
.bannerAndorra .callbacks_nav,
#home.hero-static .callbacks_tabs,
#home.hero-static .callbacks_nav,
#home:has(.hero-cta) .callbacks_tabs,
#home:has(.hero-cta) .callbacks_nav,
body:has(#home .hero-cta) > .callbacks_tabs,
body:has(#home .hero-cta) > .callbacks_nav,
body:has(#home .hero-cta) .callbacks_tabs,
body:has(#home .hero-cta) .callbacks_nav {
  display: none !important;
  visibility: hidden !important;
  pointer-events: none !important;
}

/* Sección about: misma rejilla que home */
.about .container {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  gap: 2rem;
}

.about .container::before,
.about .container::after {
  display: none;
}

.about .about-left,
.about .about-right {
  float: none;
}

@media (min-width: 992px) {
  .about .col-md-7.about-left {
    flex: 0 0 calc(58.333% - 1rem);
    max-width: calc(58.333% - 1rem);
  }

  .about .col-md-5.about-right {
    flex: 0 0 calc(41.666% - 1rem);
    max-width: calc(41.666% - 1rem);
  }
}

.about .about-left.center {
  text-align: left;
}

.about .wow {
  visibility: visible !important;
  opacity: 1 !important;
  animation: none !important;
  transform: none !important;
}

.about .about-right-part1,
.about .about-right-part2,
.about .about-right-part3 {
  overflow: hidden;
  margin-bottom: 1.25rem;
}

.btn-bodas {
  background: linear-gradient(135deg, var(--bodas-teal) 0%, var(--bodas-teal-dark) 100%);
  box-shadow: 0 8px 28px rgba(90, 158, 163, 0.35);
  letter-spacing: 0.04em;
  font-family: var(--font-body);
  text-transform: none;
}

.btn-bodas--ghost {
  background: rgba(255, 255, 255, 0.95) !important;
  color: var(--bodas-teal-dark) !important;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
}

/* Hero: anular estilos antiguos de .banner-info a en los CTAs */
.banner-info a.btn-bodas {
  margin: 0;
  margin-left: 0;
  padding: 14px 28px;
  border: none;
  font-size: 1rem;
  display: inline-block;
}

.banner-info a.btn-bodas--ghost {
  color: var(--bodas-teal-dark) !important;
  background: rgba(255, 255, 255, 0.95) !important;
}

.banner-info a.btn-bodas:not(.btn-bodas--ghost) {
  color: #fff !important;
}

.btn-bodas.is-loading {
  opacity: 0.85;
  pointer-events: none;
}

/* Secciones */
.bodas-zonas,
.bodas-eventos,
.bodas-premium,
#review.reviews {
  background: #fff;
}

.bodas-zonas {
  background: var(--bodas-cream);
}

.bodas-eventos__card,
.review-card,
.faq-accordion__item {
  box-shadow: var(--bodas-shadow);
  border-radius: var(--bodas-radius);
}

.bodas-eventos__card {
  border-left: 4px solid var(--bodas-gold);
}

.review-card {
  border-top: 3px solid var(--bodas-teal-light);
}

.faq-accordion__item[open] {
  box-shadow: 0 12px 32px rgba(90, 158, 163, 0.15);
}

/* Formulario premium — envío en la misma página */
.section-contact.contact-premium,
.contact-premium.section-contact {
  padding: 56px 0 64px;
  background: linear-gradient(165deg, #eef5f6 0%, #faf9f7 45%, #fff 100%);
}

.contact-premium {
  padding: 56px 0 64px;
  background: linear-gradient(165deg, #eef5f6 0%, #faf9f7 45%, #fff 100%);
}

.contact-premium__card {
  max-width: 640px;
  margin: 0 auto;
  padding: clamp(24px, 5vw, 40px);
  background: #fff;
  border-radius: calc(var(--bodas-radius) + 4px);
  box-shadow: var(--bodas-shadow), 0 0 0 1px rgba(90, 158, 163, 0.12);
}

.contact-premium__head {
  text-align: center;
  margin-bottom: 28px;
}

.contact-premium__head h2,
.contact-premium__head h3 {
  margin: 0 0 12px;
  color: var(--bodas-teal-dark);
}

.contact-premium__head p {
  margin: 0;
  line-height: 1.7;
  color: var(--bodas-text);
}

.contact-premium__form {
  display: flex;
  flex-direction: column;
  gap: 18px;
}

.form-field {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

/* Honeypot anti-spam: invisible para visitantes, no rellenar */
.form-field--hp {
  position: absolute !important;
  left: -10000px !important;
  width: 1px !important;
  height: 1px !important;
  overflow: hidden !important;
  clip: rect(0, 0, 0, 0) !important;
  clip-path: inset(50%) !important;
  white-space: nowrap !important;
  padding: 0 !important;
  margin: 0 !important;
  border: 0 !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

.form-field label,
.contact-premium__form > label[for] {
  font-size: 0.88rem;
  font-weight: 600;
  color: var(--bodas-ink);
  letter-spacing: 0.03em;
}

.contact-premium__form input,
.contact-premium__form textarea,
.section-contact input,
.section-contact textarea {
  width: 100%;
  padding: 14px 16px;
  border: 1px solid rgba(90, 158, 163, 0.35);
  border-radius: 10px;
  background: #fafcfc;
  font-size: 16px;
  font-family: var(--font-body);
  color: var(--bodas-ink);
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
  box-sizing: border-box;
}

.contact-premium__form input:focus,
.contact-premium__form textarea:focus,
.section-contact input:focus,
.section-contact textarea:focus {
  outline: none;
  border-color: var(--bodas-teal);
  box-shadow: 0 0 0 3px rgba(90, 158, 163, 0.2);
  background: #fff;
}

.contact-premium__form textarea,
.section-contact textarea {
  min-height: 120px;
  resize: vertical;
}

.form-field--captcha label {
  font-weight: 500;
}

.btn-bodas--submit {
  width: 100%;
  margin-top: 8px;
  padding: 16px 24px;
  font-size: 1.05rem;
}

.form-feedback {
  margin-top: 20px;
  padding: 16px 18px;
  border-radius: 10px;
  font-size: 0.95rem;
  line-height: 1.6;
  text-align: center;
}

.form-feedback[hidden] {
  display: none !important;
}

.form-feedback--success {
  background: #e8f6ef;
  color: #1a5c3a;
  border: 1px solid #9fd4b8;
}

.form-feedback--error {
  background: #fdeeee;
  color: #8b2e2e;
  border: 1px solid #e8b4b4;
}

.form-feedback--info {
  background: #eef5f6;
  color: var(--bodas-ink);
  border: 1px solid var(--bodas-teal-light);
}

.touch {
  background: #fff;
  padding-bottom: 48px;
}

.footer {
  background: var(--bodas-ink);
  color: rgba(255, 255, 255, 0.85);
  padding: 28px 16px;
}

.footer a {
  color: var(--bodas-teal-light);
}

.footer a:hover {
  color: #fff;
}

/* Reducir animaciones (CLS + ahorro CPU) */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}

.wow, .animated {
  visibility: visible !important;
  animation: none !important;
}

/* Nav accesible */
.nav-toggle {
  display: none;
  background: transparent;
  border: 2px solid #fff;
  color: #fff;
  padding: 8px 14px;
  border-radius: 8px;
  cursor: pointer;
  font-size: 0.9rem;
  font-family: inherit;
}

.site-header.is-fixed {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 999;
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.12);
}

/* CTA */
.btn-bodas {
  display: inline-block;
  padding: 14px 28px;
  background: linear-gradient(135deg, var(--bodas-teal), var(--bodas-teal-dark));
  color: #fff !important;
  border-radius: var(--bodas-radius);
  font-weight: 700;
  text-decoration: none;
  text-align: center;
  border: none;
  cursor: pointer;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
  max-width: 100%;
}

.btn-bodas:hover,
.btn-bodas:focus {
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(100, 175, 180, 0.45);
  color: #fff;
  outline: 2px solid #fff;
  outline-offset: 2px;
}

.cta-row {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  justify-content: center;
  margin: 1.5rem 0;
}

/* Zonas locales */
.bodas-zonas {
  padding: 48px 0;
  background: #f7fafb;
}

.bodas-zonas h2 {
  color: var(--bodas-teal);
  text-align: center;
  margin-bottom: 1rem;
}

.bodas-zonas__intro {
  max-width: 42em;
  margin: 0 auto 2rem;
  line-height: 1.75;
  color: var(--bodas-text);
  text-align: center;
}

.bodas-zonas__grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 20px;
  list-style: none;
  padding: 0;
  margin: 0;
}

.bodas-zonas__grid li {
  background: #fff;
  border: 1px solid rgba(100, 175, 180, 0.35);
  border-radius: var(--bodas-radius);
  padding: 20px;
}

.bodas-zonas__grid h3 {
  color: var(--bodas-teal-dark);
  font-size: 1.05em;
  margin: 0 0 0.5em;
}

.bodas-zonas__grid p {
  margin: 0;
  line-height: 1.65;
  font-size: 0.95em;
}

/* Tipos de evento */
.bodas-eventos {
  padding: 48px 0;
}

.bodas-eventos__cards {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 24px;
  margin-top: 1.5rem;
}

.bodas-eventos__card {
  padding: 24px;
  border-radius: var(--bodas-radius);
  background: #fff;
  border-left: 4px solid var(--bodas-teal);
  box-shadow: 0 4px 18px rgba(0, 0, 0, 0.06);
}

.bodas-eventos__card h3 {
  margin-top: 0;
  color: var(--bodas-teal);
}

/* Premium / 360 */
.bodas-premium {
  padding: 40px 0;
  background: linear-gradient(180deg, #eef6f7 0%, #fff 100%);
}

.bodas-premium__cols {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 28px;
  align-items: start;
}

/* Tablet y móvil */
@media (max-width: 991px) {
  .nav-toggle.menu {
    display: inline-block;
    float: right;
    margin: 12px 8px;
    min-width: 44px;
    min-height: 44px;
    line-height: 1.2;
  }

  .top-menu {
    width: 100%;
    float: none;
  }

  .top-menu ul {
    display: none;
    width: 100%;
    clear: both;
    text-align: center;
    padding: 12px 0;
    margin: 0;
    position: relative;
    z-index: 1000;
    background: #7dd4d9;
  }

  .top-menu ul.is-open {
    display: block;
  }

  .top-menu li a {
    display: block;
    padding: 12px 16px;
    min-height: 44px;
    line-height: 1.4;
  }

  .logo {
    width: auto !important;
    margin-left: 0 !important;
    float: none;
    text-align: center;
  }

  .fixed-header {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
  }

  .about-left,
  .about-right,
  .about-btm-left,
  .about-bottom,
  .col-md-7,
  .col-md-5,
  .col-md-6,
  .col-md-8,
  .col-md-4,
  .col-md-9,
  .col-md-3,
  .col-md-12,
  .col-xs-3,
  .col-xs-9 {
    width: 100% !important;
    float: none !important;
    text-align: center;
  }

  .container {
    padding-left: 16px;
    padding-right: 16px;
  }

  .gallery img,
  .blog-gd-w3ls img,
  .gal-spin-effect img {
    width: 100%;
    height: auto;
  }

  .gallery-grids .ggd {
    width: 100% !important;
    margin-bottom: 12px;
  }

  .bodas-zonas__grid {
    grid-template-columns: 1fr;
  }

  .bodas-eventos__cards {
    grid-template-columns: 1fr;
  }

  .bodas-premium__cols {
    grid-template-columns: 1fr;
  }

  .touch-left,
  .touch-right-w3l {
    width: 100%;
    padding: 0;
  }

  .map {
    width: 100%;
  }

  .touch-left iframe {
    width: 100% !important;
    height: min(50vh, 320px) !important;
  }

  .section-contact input,
  .section-contact textarea,
  .section-contact button,
  .section-contact select {
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
  }

  .faq-accordion__question {
    padding: 16px 48px 16px 18px;
    font-size: 1rem;
  }

  .btn-bodas {
    width: 100%;
    max-width: 360px;
  }

  .cta-row {
    flex-direction: column;
    align-items: stretch;
  }

  .whatsapp-float {
    bottom: max(16px, env(safe-area-inset-bottom));
    right: max(16px, env(safe-area-inset-right));
  }

  .banner-info:not(.hero-cta) {
    width: 94% !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding: 1rem !important;
  }

  .banner-info.hero-cta,
  #home .banner-info.hero-cta {
    width: 100% !important;
    margin: 0 !important;
    padding: 1.5rem 1rem 3rem !important;
  }

  #home.bannerLleida,
  #home.bannerTarragona,
  #home.bannerGirona,
  #home.bannerAndorra {
    min-height: clamp(420px, 70vh, 640px) !important;
  }

  .contact-premium {
    padding: 40px 16px 48px;
  }

  .contact-premium__card {
    padding: 20px 18px;
  }

  .btn-bodas--submit {
    max-width: none;
  }
}

/* Reviews estáticas (sin owl) */
.reviews-static {
  max-width: 720px;
  margin: 0 auto;
}

.review-card {
  background: #fff;
  border-radius: var(--bodas-radius);
  padding: 24px;
  margin-bottom: 16px;
  border: 1px solid rgba(100, 175, 180, 0.25);
}

.review-card blockquote {
  margin: 0 0 12px;
  font-style: italic;
  line-height: 1.7;
}

.review-author {
  margin: 0;
  font-weight: 700;
  color: var(--bodas-teal-dark);
}

/* Legacy form sin tarjeta premium */
.section-contact:not(.contact-premium) label {
  display: block;
  margin-top: 12px;
  font-weight: 600;
}

.section-contact:not(.contact-premium) button[type="submit"],
.section-contact.contact-premium button[type="submit"]:not(.btn-bodas--submit) {
  min-height: 48px;
  width: 100%;
  max-width: 320px;
  margin: 20px auto;
  display: block;
}

/* Mapa CLS */
.map {
  aspect-ratio: 4 / 3;
  max-width: 100%;
}

.map iframe {
  width: 100%;
  height: 100%;
  min-height: 280px;
}

/* Footer columnas (espejo y páginas legacy) */
.wrapper {
  max-width: 100%;
  width: 100%;
  margin: 0 auto;
}

.footer-columns {
  display: flex;
  flex-flow: row wrap;
  justify-content: center;
  margin: 0;
  background: var(--bodas-ink);
}

.footer-columns .column {
  text-align: center;
  flex: 1;
  border: 1px solid #333;
  padding: 10px;
}

.footer-columns .column p {
  margin: 0;
  color: rgba(255, 255, 255, 0.75);
}

.wrapper footer {
  padding: 8px 12px;
  text-align: center;
  background: var(--bodas-ink);
  font-weight: 400;
}

.wrapper footer p {
  color: rgba(255, 255, 255, 0.6);
  font-size: 0.85rem;
  margin: 0;
}

.wrapper a {
  text-decoration: none;
  color: var(--bodas-teal-light);
}

.wrapper a:hover {
  color: #fff;
}

@media screen and (max-width: 980px) {
  .footer-columns .column {
    margin-bottom: 5px;
    flex-basis: 40%;
  }

  .footer-columns .column:last-child {
    flex-basis: 100%;
    margin: 0;
  }
}

@media screen and (max-width: 680px) {
  .footer-columns .column {
    flex-basis: 100%;
    margin: 0 0 5px 0;
  }
}

/* Ocultar iconos de redes antiguos si quedan en HTML cacheado */
ul.social li a.fb,
ul.social li a.tw,
ul.social li a.in,
ul.social li a.dott,
ul.social li a:not(.contact-channels__wa):not(.contact-channels__tel):not(.contact-channels__mail) {
  display: none !important;
  width: 0 !important;
  height: 0 !important;
  overflow: hidden !important;
  visibility: hidden !important;
}

ul.social:has(li a.fb),
ul.social:has(li a.tw),
ul.social:has(li a.dott) {
  display: none !important;
}

/* Botonera contacto (estilo iconos redes sociales) */
.contact-channels {
  display: flex;
  flex-wrap: wrap;
  gap: 0.85rem;
  justify-content: flex-start;
  align-items: center;
  list-style: none;
  padding: 0;
  margin: 2rem 0 0;
  text-align: left;
}

.contact-channels li {
  display: inline-block;
  margin: 0;
}

.contact-channels a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 52px;
  height: 52px;
  padding: 0;
  border-radius: 50%;
  text-decoration: none;
  color: #fff;
  background: var(--bodas-teal);
  border: 2px solid transparent;
  box-shadow: 0 4px 14px rgba(30, 42, 43, 0.12);
  transition: transform 0.2s ease, opacity 0.2s ease, background 0.2s ease, box-shadow 0.2s ease;
}

.contact-channels a:hover,
.contact-channels a:focus-visible {
  transform: translateY(-2px);
  opacity: 0.92;
  box-shadow: 0 8px 20px rgba(30, 42, 43, 0.18);
}

.contact-channels__icon {
  display: block;
  width: 26px;
  height: 26px;
  flex-shrink: 0;
  fill: currentColor;
  color: inherit;
}

.contact-channels a svg,
.contact-channels a .contact-channels__icon {
  opacity: 1;
  visibility: visible;
}

.contact-channels__wa {
  background: #25d366;
  border-color: #25d366;
}

.contact-channels__wa:hover,
.contact-channels__wa:focus-visible {
  background: #1da851;
  border-color: #1da851;
}

.contact-channels__tel {
  background: var(--bodas-teal-dark);
  border-color: var(--bodas-teal-dark);
}

.contact-channels__tel:hover,
.contact-channels__tel:focus-visible {
  background: var(--bodas-teal);
  border-color: var(--bodas-teal);
}

.contact-channels__mail {
  background: var(--bodas-gold);
  border-color: var(--bodas-gold);
  color: var(--bodas-ink);
}

.contact-channels__mail:hover,
.contact-channels__mail:focus-visible {
  background: #b8944f;
  border-color: #b8944f;
  color: #fff;
}

.about .contact-channels a,
.social .contact-channels a {
  margin-left: 0;
  margin-right: 0;
  border: 2px solid transparent;
  font-size: 0;
}

.contact-channels .visually-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* Opiniones (Owl): puntos debajo, sin mezclar con flechas */
.sreen-gallery-cursual .owl-theme .owl-controls {
  margin-top: 1.5rem;
}

.sreen-gallery-cursual .owl-theme .owl-controls .owl-pagination {
  display: block;
  text-align: center;
}
