/* ==========================================================================
   SECTION.CSS — Component .section
   Contenidor genèric de secció per a contingut text+imatge o centrat.
   Modificadors: --cream, --dark, --white, --reverse
   ========================================================================== */

.section {
   padding: 8rem 2rem;
   color: var(--color-text-body);
   background-color: var(--color-cream);
}

/* Modificadors de fons */
.section--cream {
   background-color: var(--color-cream);
   color: var(--color-text-body);
}

.section--beige {
   background-color: var(--color-beige);
   color: var(--color-text-body);
}

.section--white {
   background-color: var(--color-white);
   color: var(--color-text-body);
}

.section--dark {
   background-color: var(--color-bg-dark);
   color: var(--color-text-main);
}

/* Layout text + imatge (50/50) */
.section--cream,
.section--beige,
.section--white,
.section--dark {
   display: flex;
   align-items: center;
   justify-content: center;
   gap: 4rem;
   flex-wrap: wrap;
   max-width: 1400px;
   margin: 0 auto;
}

/* Però algunes seccions (dark/servicios) usen layout diferent, hauran de sobreescriure */
.section--dark {
   display: block;
   max-width: unset;
   margin: unset;
}

/* Layout invers: imatge a l'esquerra, text a la dreta */
.section--reverse {
   flex-direction: row-reverse;
}

/* Costat de text */
.section__text-side {
   flex: 1;
   min-width: 300px;
   max-width: 560px;
   padding: 1rem 2rem;
}

/* Costat d'imatge */
.section__image-side {
   flex: 1;
   min-width: 280px;
   max-width: 520px;
}

.section__image-side img {
   width: 100%;
   max-height: 460px;
   object-fit: cover;
   border-radius: 8px;
}

/* Elementi interiors */
.section__overline {
   font-size: 0.9rem;
   font-weight: 600;
   letter-spacing: 0.15em;
   text-transform: uppercase;
   color: var(--color-accent);
   margin-bottom: 1rem;
}

.section__title {
   font-size: 2.4rem;
   font-weight: 700;
   line-height: 1.15;
   color: var(--color-black-soft);
   margin-bottom: 1.5rem;
}

.section--dark .section__title {
   color: var(--color-text-main);
}

.section__title--centered {
   text-align: center;
}

.section__divider {
   width: 56px;
   height: 3px;
   background-color: var(--color-accent);
   margin-bottom: 2rem;
}

.section__divider--centered {
   margin: 0 auto 2rem auto;
}

.section p {
   font-size: 1rem;
   line-height: 1.7;
   color: inherit;
   margin-bottom: 1.2rem;
}

.section__intro {
   font-size: 1.1rem;
   font-weight: 300;
   text-align: center;
   margin-bottom: 3rem;
   max-width: 600px;
   margin-left: auto;
   margin-right: auto;
}

.section__cta-phrase {
   font-style: italic;
   color: var(--color-grey-muted);
   margin-top: 1.5rem;
   margin-bottom: 1.5rem;
}

.section__cta {
   margin-top: 2rem;
   display: flex;
   flex-direction: column;
   align-items: flex-start;
   gap: 0.5rem;
}

.section__microcopy {
   font-size: 0.8rem;
   color: var(--color-grey-hint);
   margin-bottom: 0 !important;
}

/* Grid dual (2 columnes) per a serveis */
.section__dual-grid {
   display: grid;
   grid-template-columns: repeat(2, 1fr);
   gap: 2.5rem;
   max-width: 920px;
   margin: 0 auto;
}

/* Grid de contacte */
.section__contact-grid {
   display: flex;
   flex-wrap: wrap;
   gap: 3rem;
   max-width: var(--container-max);
   margin: 0 auto;
   align-items: flex-start;
}

.section__contact-details {
   flex: 1;
   min-width: 260px;
   display: flex;
   flex-direction: column;
   gap: 1.5rem;
}

/* Ítem de contacte */
.contact-detail h4 {
   font-size: 0.8rem;
   text-transform: uppercase;
   letter-spacing: 1px;
   color: var(--color-accent);
   margin-bottom: 0.3rem;
}

.contact-detail p {
   font-size: 0.95rem;
   color: var(--color-dark-grey);
   margin-bottom: 0;
}

/* Contenidor del formulari HubSpot */
#hubspot-form-container {
   flex: 1;
   min-width: 300px;
   max-width: 560px;
   background: var(--color-white);
   padding: 2.5rem;
   border-radius: 12px;
   box-shadow: var(--shadow-card);
}

#hubspot-form-container h3 {
   font-size: 1.4rem;
   font-weight: 600;
   margin-bottom: 0.5rem;
   color: var(--color-black-soft);
}

#hubspot-form-container>p {
   font-size: 0.9rem;
   color: var(--color-grey-muted);
   margin-bottom: 1.5rem;
}

/* Formularis CRM embeguts a secció (fallback si no arriba auto-resize) */
/* El CRM pot tenir 4 camps + botó → mínim 520px per mostrar-ho tot */
#hubspot-form iframe {
   display: block;
   width: 100%;
   max-width: 100%;
   border: 0;
   height: 520px;
   transition: height 0.2s ease;
}

/* Contingut de secció centrat (serveis, etc.) */
.section__content {
   max-width: var(--container-max);
   margin: 0 auto;
   text-align: center;
}

/* ==========================================================================
   RESPONSIVE
   ========================================================================== */
@media (max-width: 1024px) {

   .section--cream,
   .section--beige,
   .section--white {
      gap: 2.5rem;
   }

   .section__text-side {
      padding: 1rem;
   }
}

@media (max-width: 768px) {
   .section {
      padding: 5rem 1.5rem;
   }

   .section--cream,
   .section--beige,
   .section--white {
      flex-direction: column;
      gap: 2rem;
   }

   .section--reverse {
      flex-direction: column;
   }

   .section__title {
      font-size: 1.9rem;
   }

   .section__dual-grid {
      grid-template-columns: 1fr;
   }

   .section__text-side,
   .section__image-side {
      max-width: 100%;
      padding: 0;
   }

   .section__image-side img {
      max-height: 300px;
   }

   #hubspot-form iframe {
      height: 480px;
   }
}