/**
 * Page contact — layout (.arkt-contact).
 * Champs : styles noyau + espacements label / contrôle (ci-dessous).
 */

.arkt-contact {
  /* Transparent pour laisser voir les halos (#portfolio_background, main.css) */
  background: transparent;
  color: var(--arkt-text);
}

.arkt-contact__alert {
  padding: 1rem 1.15rem;
  border-radius: var(--arkt-radius-card);
  margin-bottom: 1rem;
  border: 1px solid transparent;
}

.arkt-contact__alert--success {
  background: var(--arkt-color-success-bg);
  border-color: var(--arkt-color-success-border);
  color: var(--arkt-color-ok-soft);
}

.arkt-contact__alert--error {
  background: var(--arkt-color-error-bg);
  border-color: var(--arkt-color-error-border);
  color: var(--arkt-color-err-soft);
}

#portfolio_page .arkt-contact #hero .content-article,
#portfolio_page .arkt-contact .arkt-contact__intro-body {
  color: var(--arkt-text-muted);
}

#portfolio_page .arkt-contact #hero .content-article p,
#portfolio_page .arkt-contact .arkt-contact__intro-body p {
  margin: 0.75rem 0 0;
}

#portfolio_page .arkt-contact .arkt-contact__intro-body > :first-child {
  margin-top: 0;
}

.arkt-contact__section-title-link {
  color: inherit;
  text-decoration: none;
  border-bottom: 1px solid color-mix(in srgb, var(--arkt-accent) 45%, transparent);
  padding-bottom: 2px;
}

.arkt-contact__section-title-link:hover {
  color: var(--arkt-accent);
  border-bottom-color: var(--arkt-accent);
}

.arkt-contact__details {
  list-style: none;
  margin: 0;
  padding: 0;
}

.arkt-contact__detail-card {
  height: 100%;
}

.arkt-contact__detail-inner {
  list-style: none;
  margin: 0;
  padding: 0;
}

.arkt-contact__detail-label {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-weight: var(--arkt-type-h3-weight);
  margin-bottom: 0.5rem;
  color: var(--arkt-text);
  font-size: var(--arkt-type-h3-size);
  line-height: var(--arkt-type-h3-line);
}

.arkt-contact__detail-inner > li:last-child {
  color: var(--arkt-text-muted);
  line-height: var(--portfolios-line-height-base, 1.5);
}

.arkt-contact__form-grid {
  align-items: stretch;
  width: 100%;
  gap: var(--arkt-space-form-grid-gap);
}

.arkt-contact__aside-img {
  width: 100%;
  height: 100%;
  min-height: var(--arkt-contact-aside-min-height);
  max-height: var(--arkt-contact-aside-max-height);
  object-fit: cover;
  border-radius: var(--arkt-radius-card);
  opacity: var(--arkt-opacity-sidecard);
}

/* Bloc « Qui sommes-nous » */
.arkt-contact__identity {
  position: relative;
  overflow: hidden;
  background: var(--arkt-bg);
}

/* Première section : dégagement sous le header flottant */
#portfolio_page .arkt-contact .arkt-contact__identity--lead {
  padding-top: calc(var(--arkt-header-overlap-offset) + clamp(1.5rem, 4vw, 2.5rem)) !important;
}

#portfolio_page .arkt-contact .arkt-contact__identity:not(.arkt-contact__identity--lead) {
  padding-top: clamp(2rem, 5vw, 3rem) !important;
}

#portfolio_page .arkt-contact .arkt-contact__identity-header,
#portfolio_page .arkt-contact .arkt-contact__identity-features,
#portfolio_page .arkt-contact .arkt-contact__identity .limited-width.big-margin-top {
  position: relative;
  z-index: 1;
}

/* En-tête « Qui sommes-nous » : titres + textes centrés (évite héritage / grilles du gabarit portfolio) */
#portfolio_page .arkt-contact .arkt-contact__identity-header {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  width: 100%;
  box-sizing: border-box;
}

#portfolio_page .arkt-contact .arkt-contact__identity .arkt-features__title,
#portfolio_page .arkt-contact .arkt-contact__identity .arkt-features__subtitle,
#portfolio_page .arkt-contact .arkt-contact__identity .arkt-features__lede {
  text-align: center;
  width: 100%;
  max-width: 42rem;
  box-sizing: border-box;
}

#portfolio_page .arkt-contact .arkt-contact__identity .arkt-wide-placeholder {
  width: 100%;
  height: auto;
  border-radius: var(--arkt-radius-card);
  display: block;
}

#portfolio_page .arkt-contact .arkt-contact__identity .arkt-contact__identity-caption {
  text-align: center;
}

#portfolio_page .arkt-contact .arkt-contact__identity .arkt-feature-card {
  position: relative;
  padding-bottom: 2.25rem;
  box-sizing: border-box;
  text-align: left;
}

#portfolio_page .arkt-contact .arkt-contact__identity .arkt-feature-card h3 {
  margin: 0.75rem 0 0.5rem;
  color: var(--arkt-text);
}

#portfolio_page .arkt-contact .arkt-contact__identity .arkt-feature-card__icon {
  color: var(--arkt-rgba-white-90);
}

#portfolio_page .arkt-contact .arkt-contact__identity .arkt-feature-card__arrow {
  position: absolute;
  right: 1.25rem;
  bottom: 1.25rem;
  font-size: var(--arkt-type-feature-arrow-size);
  color: var(--arkt-rgba-white-75);
}

#portfolio_page .arkt-contact .arkt-contact__identity .arkt-features__title {
  margin: 0 0 0.35rem;
  font-size: var(--arkt-type-h1-size);
  line-height: var(--arkt-type-h1-line);
  font-weight: var(--arkt-type-h1-weight);
  color: var(--arkt-type-h1-color);
}

#portfolio_page .arkt-contact .arkt-contact__identity .arkt-features__subtitle {
  margin: 0 0 1rem;
  font-size: var(--arkt-type-caption-size);
  line-height: calc(var(--arkt-type-caption-size) + 0.35rem);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  font-weight: var(--arkt-type-h3-weight);
  color: var(--arkt-accent-title);
}

#portfolio_page .arkt-contact .arkt-contact__identity .arkt-features__lede {
  max-width: 40rem;
  margin-left: auto;
  margin-right: auto;
}

#portfolio_page .arkt-contact .arkt-contact__identity .arkt-contact__identity-intro {
  max-width: 42rem;
  margin-left: auto;
  margin-right: auto;
  text-align: center;
  color: var(--arkt-text-muted);
}

#portfolio_page .arkt-contact .arkt-contact__identity .arkt-contact__identity-intro :is(p, ul, ol) {
  text-align: center;
}

@media screen and (max-width: 650px) {
  #portfolio_page .arkt-contact .arkt-contact__identity-header .arkt-features__lede,
  #portfolio_page .arkt-contact .arkt-contact__identity-header .arkt-contact__identity-intro {
    max-width: 100%;
  }
}

/* ----- Équipe : cartes horizontales (photo, nom, fonction, description) ----- */
.arkt-contact-members {
  position: relative;
  overflow: hidden;
  background: linear-gradient(
    180deg,
    color-mix(in srgb, var(--arkt-bg) 96%, var(--arkt-accent) 4%) 0%,
    var(--arkt-bg) 55%
  );
  border-top: var(--arkt-page-border-width) solid var(--arkt-page-border-color);
}

.arkt-contact-members__head {
  margin-bottom: clamp(1.75rem, 4vw, 2.75rem);
  max-width: 38rem;
  margin-left: auto;
  margin-right: auto;
}

.arkt-contact-members__eyebrow {
  margin: 0 0 0.4rem;
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--arkt-accent-title);
}

.arkt-contact-members__title {
  margin: 0 0 0.65rem;
  font-size: var(--arkt-type-h1-size);
  line-height: var(--arkt-type-h1-line);
  font-weight: var(--arkt-type-h1-weight);
  color: var(--arkt-type-h1-color);
}

.arkt-contact-members__subtitle {
  margin: 0;
  font-size: var(--arkt-type-h2-size);
  line-height: var(--arkt-type-h2-line);
  font-weight: var(--arkt-type-subtle-weight);
  color: var(--arkt-mockup-text-subtle);
}

.arkt-contact-members__lede {
  margin: 0.85rem 0 0;
  line-height: 1.55;
  font-size: var(--arkt-type-caption-size);
}

.arkt-contact-members__list {
  list-style: none;
  margin: 0 auto;
  padding: 0;
  max-width: min(100%, 52rem);
  display: flex;
  flex-direction: column;
  gap: clamp(1.15rem, 2.8vw, 1.65rem);
}

.arkt-contact-member {
  margin: 0;
  padding: 0;
  border-radius: var(--arkt-radius-card);
  border: var(--arkt-page-border);
  background: color-mix(in srgb, var(--arkt-card-bg) 94%, transparent);
  box-shadow: 0 8px 28px var(--arkt-rgba-black-35-shadow);
  overflow: hidden;
}

.arkt-contact-member__inner {
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(1rem, 2.5vw, 1.5rem);
  align-items: start;
  padding: clamp(1.1rem, 2.4vw, 1.45rem) clamp(1rem, 2.2vw, 1.35rem);
  box-sizing: border-box;
}

@media screen and (min-width: 640px) {
  .arkt-contact-member__inner {
    grid-template-columns: minmax(7.5rem, 10rem) 1fr;
    align-items: center;
  }
}

.arkt-contact-member__media {
  margin: 0;
  border-radius: var(--arkt-radius-card);
  overflow: hidden;
  border: 1px solid var(--arkt-rgba-border-on-dark-soft);
  background: var(--arkt-card-bg);
  justify-self: center;
  width: min(100%, 10rem);
}

@media screen and (min-width: 640px) {
  .arkt-contact-member__media {
    justify-self: stretch;
    width: auto;
  }
}

.arkt-contact-member__img {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 1;
  object-fit: cover;
}

.arkt-contact-member__img--empty {
  aspect-ratio: 1;
  min-height: 7.5rem;
  background: linear-gradient(
    145deg,
    color-mix(in srgb, var(--arkt-card-bg) 82%, var(--arkt-text-muted)),
    color-mix(in srgb, var(--arkt-bg) 72%, var(--arkt-accent) 18%)
  );
}

.arkt-contact-member__body {
  min-width: 0;
  text-align: left;
}

.arkt-contact-member__name {
  margin: 0 0 0.35rem;
  font-size: var(--arkt-type-h3-size);
  line-height: var(--arkt-type-h3-line);
  font-weight: var(--arkt-type-h3-weight);
  color: var(--arkt-text);
}

.arkt-contact-member__role {
  margin: 0 0 0.75rem;
  font-size: var(--arkt-type-caption-size);
  line-height: 1.45;
  color: var(--arkt-accent-title);
  font-weight: 600;
}

.arkt-contact-member__desc {
  margin: 0;
  font-size: var(--arkt-type-project-body-size, 0.95rem);
  line-height: 1.6;
  color: var(--arkt-text-muted);
}

.arkt-contact__form-heading {
  margin: 0 0 1.25rem;
}

#portfolio_page .arkt-contact .arkt-contact__form {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 1.35rem;
}

/* Champs : bordures neutres uniquement (sans vert / rouge / accent du noyau sur cette page) */
#portfolio_page .arkt-contact .arkt-contact__form :is(input:not([type="submit"]), select, textarea) {
  border-color: var(--arkt-page-border-color) !important;
  box-shadow: none !important;
}

#portfolio_page .arkt-contact .arkt-contact__form :is(input:not([type="submit"]), select, textarea):required,
#portfolio_page .arkt-contact .arkt-contact__form :is(input:not([type="submit"]), select, textarea):required:valid,
#portfolio_page .arkt-contact .arkt-contact__form :is(input:not([type="submit"]), select, textarea):required:invalid {
  border-color: var(--arkt-page-border-color) !important;
}

#portfolio_page .arkt-contact .arkt-contact__form :is(input:not([type="submit"]), select, textarea):focus {
  outline: none;
  border-color: var(--arkt-page-border-color) !important;
  box-shadow: none !important;
}

#portfolio_page .arkt-contact .arkt-contact__form :is(input:not([type="submit"]), select, textarea):focus-visible {
  outline: 2px solid var(--arkt-text-muted);
  outline-offset: 2px;
}

#portfolio_page .arkt-contact .arkt-contact__form .arkt-field__label {
  font-weight: 600;
}

#portfolio_page .arkt-contact .arkt-contact__form label[for="captcha"] .captcha-question {
  box-shadow: none;
  transform: none;
}

/* Espacements formulaire : le noyau met margin-bottom sur tous les label (#portfolio_page label) */
#portfolio_page .arkt-contact .arkt-field {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 1.125rem;
}

#portfolio_page .arkt-contact .arkt-field__label {
  margin-bottom: 0;
}

#portfolio_page .arkt-contact .arkt-field__hint-block {
  display: block;
  margin-top: 0.5rem;
  font-weight: var(--portfolios-font-weight-normal, 400);
}

#portfolio_page .arkt-contact .arkt-field__hint {
  display: block;
}

.arkt-contact__footnote {
  margin: 0.5rem 0 0;
  color: var(--arkt-text-muted);
  font-size: var(--arkt-type-footer-bottom-size);
}

@media screen and (max-width: 1100px) {
  .arkt-contact__aside {
    display: none;
  }
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font .arkt-contact .arkt-field {
  display: flex !important;
  flex-direction: column !important;
  align-items: stretch !important;
  gap: 1.125rem !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font .arkt-contact .arkt-field__label {
  margin-bottom: 0 !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font .arkt-contact .arkt-field__hint-block {
  display: block !important;
  margin-top: 0.5rem !important;
  font-weight: var(--portfolios-font-weight-normal, 400) !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font .arkt-contact .arkt-field__hint {
  display: block !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font .arkt-contact .arkt-contact__form {
  display: flex !important;
  flex-direction: column !important;
  align-items: stretch !important;
  gap: 1.35rem !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font .arkt-contact .arkt-contact__form :is(input:not([type="submit"]), select, textarea) {
  border-color: var(--arkt-page-border-color) !important;
  box-shadow: none !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font .arkt-contact .arkt-contact__form :is(input:not([type="submit"]), select, textarea):required,
body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font .arkt-contact .arkt-contact__form :is(input:not([type="submit"]), select, textarea):required:valid,
body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font .arkt-contact .arkt-contact__form :is(input:not([type="submit"]), select, textarea):required:invalid {
  border-color: var(--arkt-page-border-color) !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font .arkt-contact .arkt-contact__form :is(input:not([type="submit"]), select, textarea):focus {
  outline: none !important;
  border-color: var(--arkt-page-border-color) !important;
  box-shadow: none !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font .arkt-contact .arkt-contact__form :is(input:not([type="submit"]), select, textarea):focus-visible {
  outline: 2px solid var(--arkt-text-muted) !important;
  outline-offset: 2px !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font .arkt-contact .arkt-contact__form .arkt-field__label {
  font-weight: 600 !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font .arkt-contact .arkt-contact__form label[for="captcha"] .captcha-question {
  box-shadow: none !important;
  transform: none !important;
}
