/**
 * @file
 * Page /contacto — design V7.
 *
 * Layout :
 *   1. Hero : kicker + h1 "Contacto" + lead (rendu via title du node ou page_title)
 *   2. Section TOP : grid 50/50
 *      - GAUCHE : Formulaire wrappé dans une box V7 (border ink + bg blanc
 *        + offset shadow signature + padding généreux)
 *      - DROITE : Carte Info Local (adresse + horaires + map ronde
 *        intégrée en bas de la card)
 *   3. Section FAQ : container 900px max, h2 Fraunces avec vague bleu
 *      glacier (rendu auto), accordion details/summary stylé V7
 */

/* ─────────── Wrapper principal page contacto ─────────── */
.path-contacto .layout-content {
  max-width: var(--ocdm-container-max, 1280px);
  margin: 0 auto;
  padding: 2rem clamp(1rem, 2vw + 0.5rem, 2.5rem);
}

/* ─────────── Section TOP : 50/50 form + info ─────────── */
/* Bootstrap Barrio rend la structure suivante dans page.html.twig :
     <div class="row row-offcanvas row-offcanvas-left clearfix">
       <main class="main-content col" role="main">…form…</main>
       <div class="sidebar_second sidebar col-md-3 order-last">…info…</div>
     </div>
   La col-md-3 de la sidebar + la col flex-grow du main donnent un 75/25
   très moche pour cette page. On force un grid 50/50 propre. */
.path-contacto .row-offcanvas {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 2.5rem !important;
  align-items: start;
  margin: 0 !important;
  --bs-gutter-x: 0;
}

/* Reset des col Bootstrap sur les 2 enfants directs */
.path-contacto .row-offcanvas > .main-content,
.path-contacto .row-offcanvas > main {
  max-width: 100% !important;
  width: 100% !important;
  flex: none !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}

.path-contacto .row-offcanvas > .sidebar_second,
.path-contacto .row-offcanvas > .sidebar {
  max-width: 100% !important;
  width: 100% !important;
  flex: none !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
  order: 0 !important;  /* annule order-last pour respecter l'ordre DOM */
}

@media (max-width: 991px) {
  .path-contacto .row-offcanvas {
    grid-template-columns: 1fr !important;
    gap: 2rem !important;
  }
}

/* ─────────── Formulaire wrappé dans une box V7 ─────────── */
.path-contacto .block-webform {
  background: var(--ocdm-bg-elevated, #fff);
  border: 1.5px solid var(--ocdm-text-strong, #1f1820);
  border-radius: var(--ocdm-radius-lg, 16px);
  padding: 2.25rem 2rem;
  box-shadow: 4px 4px 0 var(--ocdm-text-strong, #1f1820);
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}
@media (max-width: 540px) {
  .path-contacto .block-webform {
    padding: 1.5rem 1.25rem;
    box-shadow: 2px 2px 0 var(--ocdm-text-strong, #1f1820);
  }
}

.path-contacto .block-webform h2 {
  font-family: var(--ocdm-font-display);
  font-weight: 800;
  font-size: clamp(1.5rem, 1.2rem + 1vw, 2rem);
  letter-spacing: -0.025em;
  color: var(--ocdm-text-strong);
  margin: 0 0 0.5rem;
}
.path-contacto .block-webform h2::after { display: none !important; }

.path-contacto .block-webform > p,
.path-contacto .block-webform .webform-description {
  color: var(--ocdm-text-muted);
  margin: 0 0 1.5rem;
  font-size: 0.95rem;
  line-height: 1.55;
}

/* Inputs : reset propre V7 (le style global ocdm-overrides s'applique aussi). */
.path-contacto .block-webform .form-item {
  margin-bottom: 1.1rem;
}

.path-contacto .block-webform input[type="submit"],
.path-contacto .block-webform button[type="submit"] {
  background: var(--ocdm-framboise);
  color: #fff;
  border: 1px solid var(--ocdm-framboise);
  padding: 12px 28px;
  border-radius: 999px;
  font-family: var(--ocdm-font-body);
  font-weight: 600;
  font-size: 15px;
  cursor: pointer;
  transition: all 0.15s ease;
}
.path-contacto .block-webform input[type="submit"]:hover,
.path-contacto .block-webform button[type="submit"]:hover {
  background: var(--ocdm-framboise-dark);
  border-color: var(--ocdm-framboise-dark);
  transform: translateY(-1px);
  box-shadow: 0 6px 18px rgba(201, 53, 122, 0.25);
}

/* ─────────── Card Info Local (adresse + horaires + map) ─────────── */
.block-info-local {
  background: var(--ocdm-bg-elevated, #fff);
  border: 1.5px solid var(--ocdm-text-strong, #1f1820);
  border-radius: var(--ocdm-radius-lg, 16px);
  overflow: hidden;
  box-shadow: 4px 4px 0 var(--ocdm-text-strong, #1f1820);
  display: flex;
  flex-direction: column;
}
@media (max-width: 540px) {
  .block-info-local {
    box-shadow: 2px 2px 0 var(--ocdm-text-strong, #1f1820);
  }
}

/* Sections internes : padding cohérent avec form */
.block-info-local__address,
.block-info-local__hours {
  padding: 1.5rem 1.75rem;
  border-bottom: 1px dashed var(--ocdm-border, #d9c9c5);
  font-size: 0.95rem;
  line-height: 1.55;
}

.block-info-local h3 {
  font-family: var(--ocdm-font-body);
  font-weight: 700;
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--ocdm-framboise);
  margin: 0 0 0.5rem;
}
.block-info-local h3::after { display: none !important; }

.block-info-local__address p,
.block-info-local__address ul,
.block-info-local__hours p,
.block-info-local__hours ul {
  margin: 0 0 0.35rem;
}
.block-info-local__address p:last-child,
.block-info-local__hours p:last-child { margin-bottom: 0; }

.block-info-local__hours ul,
.block-info-local__address ul {
  padding-left: 1.2rem;
}

/* Map en bas de card, full width, sans bordure interne */
.block-info-local__map {
  position: relative;
  background: var(--ocdm-bg-sunken, #f6ebe0);
  border: 0;
  border-radius: 0;
}

.block-info-local__map iframe {
  display: block;
  width: 100%;
  height: 260px;
  border: 0;
  /* Layer "hot" (Humanitarian OSM) déjà plus sobre que mapnik (beige/crème).
     On désature un peu + ajoute brightness pour un look encore plus light,
     cohérent avec la charte V7 crème/framboise. */
  filter: saturate(0.6) brightness(1.04) contrast(0.95);
}

.block-info-local__map-link {
  position: absolute;
  bottom: 0.75rem;
  right: 0.75rem;
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 8px 14px;
  background: #fff;
  border: 1.5px solid var(--ocdm-text-strong);
  border-radius: 999px;
  font-family: var(--ocdm-font-body);
  font-weight: 600;
  font-size: 0.8rem;
  color: var(--ocdm-text-strong);
  text-decoration: none !important;
  box-shadow: 2px 2px 0 var(--ocdm-text-strong);
  transition: all 0.15s ease;
}
.block-info-local__map-link:hover {
  background: var(--v7-blue, #b8d0db);
  color: var(--ocdm-text-strong);
  transform: translate(-1px, -1px);
  box-shadow: 3px 3px 0 var(--ocdm-text-strong);
}

/* ─────────── Section FAQ ─────────── */
.path-contacto .region-featured-bottom-first {
  margin-top: 4rem;
  padding: 3rem clamp(1.25rem, 2vw + 0.75rem, 2.5rem);
  background: var(--ocdm-bg-sunken, #f6ebe0);
  border-top: 1px solid var(--ocdm-border-soft, #ecdfd9);
  border-bottom: 1px solid var(--ocdm-border-soft, #ecdfd9);
}

/* Mobile : padding latéral plus généreux pour éviter que les cards .faq-item
   collent au bord de l'écran iPhone (border 1.5px ink + offset shadow 2px
   doivent rester respirables). */
@media (max-width: 540px) {
  .path-contacto .region-featured-bottom-first {
    padding: 2.5rem 1.25rem;
  }
}

.path-contacto .block-views-blockfaq-block-1,
.path-contacto .view-faq {
  max-width: 880px;
  margin: 0 auto;
}

/* Header bloc FAQ : kicker Caveat + h2 Fraunces */
.path-contacto .block-views-blockfaq-block-1 .block__title,
.path-contacto .block-views-blockfaq-block-1 > h2,
.path-contacto .view-faq .view-header,
.path-contacto .view-faq .view-content > h2:first-child {
  text-align: center;
  margin: 0 0 0.5rem;
}

.path-contacto .block-views-blockfaq-block-1 > h2,
.path-contacto .view-faq .view-content > h2:first-child {
  font-family: var(--ocdm-font-display);
  font-weight: 800;
  font-size: clamp(1.75rem, 1.4rem + 1.4vw, 2.5rem);
  letter-spacing: -0.025em;
  color: var(--ocdm-text-strong);
  margin: 0 auto 0.5rem;
}

.path-contacto .block-views-blockfaq-block-1 > h2::after,
.path-contacto .view-faq .view-content > h2:first-child::after {
  margin: 0.5rem auto 0;
}

/* Petit kicker au-dessus du h2 — injecté via view-header text area */
.path-contacto .faq-kicker {
  font-family: var(--ocdm-font-hand);
  font-size: 1.35rem;
  color: var(--ocdm-framboise);
  text-align: center;
  line-height: 1;
  margin: 0 0 0.5rem;
}

.path-contacto .faq-lead {
  text-align: center;
  color: var(--ocdm-text-muted);
  max-width: 560px;
  margin: 0 auto 2.5rem;
  font-size: 1rem;
  line-height: 1.55;
}

/* ─────────── FAQ accordion (HTML <details>/<summary>) ─────────── */
.faq-item {
  background: var(--ocdm-bg-elevated, #fff);
  border: 1.5px solid var(--ocdm-text-strong, #1f1820);
  border-radius: var(--ocdm-radius-md, 12px);
  margin-bottom: 0.75rem;
  overflow: hidden;
  transition: box-shadow 0.2s ease, transform 0.2s ease;
}

.faq-item:hover {
  box-shadow: 2px 2px 0 var(--ocdm-text-strong, #1f1820);
  transform: translate(-1px, -1px);
}

.faq-item[open] {
  box-shadow: 3px 3px 0 var(--ocdm-text-strong, #1f1820);
  transform: translate(-1px, -1px);
}

.faq-item__question {
  cursor: pointer;
  padding: 1.15rem 3rem 1.15rem 1.5rem;
  font-family: var(--ocdm-font-display);
  font-weight: 700;
  font-size: 1.05rem;
  letter-spacing: -0.01em;
  line-height: 1.35;
  color: var(--ocdm-text-strong);
  list-style: none;
  position: relative;
  user-select: none;
}
.faq-item__question::after { display: none !important; }
.faq-item__question::-webkit-details-marker { display: none; }

.faq-item__question::before {
  content: '';
  position: absolute;
  right: 1.25rem;
  top: 50%;
  width: 16px;
  height: 16px;
  margin-top: -8px;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='none' stroke='%23c9357a' stroke-width='2.5' stroke-linecap='round'><line x1='8' y1='2' x2='8' y2='14'/><line x1='2' y1='8' x2='14' y2='8'/></svg>");
  background-repeat: no-repeat;
  background-position: center;
  transition: transform 0.2s ease;
}

.faq-item[open] .faq-item__question::before {
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='none' stroke='%23c9357a' stroke-width='2.5' stroke-linecap='round'><line x1='2' y1='8' x2='14' y2='8'/></svg>");
  transform: rotate(180deg);
}

.faq-item__answer {
  padding: 0 1.5rem 1.25rem;
  font-family: var(--ocdm-font-body);
  font-size: 0.95rem;
  line-height: 1.6;
  color: var(--ocdm-text);
  border-top: 1px dashed var(--ocdm-border-soft, #ecdfd9);
}

.faq-item__answer p {
  margin: 1rem 0 0;
}
.faq-item__answer p:first-child {
  margin-top: 1rem;
}
.faq-item__answer p:last-child { margin-bottom: 0; }

.faq-item__answer ul,
.faq-item__answer ol {
  margin: 1rem 0 0;
  padding-left: 1.5rem;
}
.faq-item__answer a {
  color: var(--ocdm-framboise);
  text-decoration: underline;
  text-decoration-color: var(--v7-blue, #b8d0db);
}

/* ─────── Webform email_confirm — retire le fieldset visuel ─────── */
/* Markup natif : <fieldset class="webform-element-email-confirm">
                    <legend>...</legend>
                    <div class="form-item-email-confirm-mail-1">...</div>
                    <div class="form-item-email-confirm-mail-2">...</div>
                  </fieldset>
   On veut juste 2 form-items empilés, pas de fieldset border ni pastille. */
/* Classes réelles rendues par Webform 6.3 sur le composite email_confirm :
     fieldset.webform-email-confirm--wrapper
     fieldset.webform-type-webform-email-confirm
     fieldset.js-webform-type-webform-email-confirm
   Une seule suffit mais on couvre les 3 par sécurité. */
fieldset.webform-email-confirm--wrapper,
fieldset.webform-type-webform-email-confirm,
fieldset.js-webform-type-webform-email-confirm {
  border: none !important;
  padding: 0 !important;
  margin: 0 0 1rem !important;
  background: none !important;
  box-shadow: none !important;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
fieldset.webform-email-confirm--wrapper > legend,
fieldset.webform-type-webform-email-confirm > legend,
fieldset.js-webform-type-webform-email-confirm > legend {
  /* Cache visuellement le legend du fieldset (la "pastille bleue") tout en
     gardant l'accessibilité screen-reader. */
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0,0,0,0) !important;
  white-space: nowrap !important;
  border: 0 !important;
}
