@import url("root.css");
@import url("button.css");
@import url("components.css");
@import url("socials-unified.css");

#portfolio_page.portfolio-font {
  font-family: var(--arkt-font-family-sans);
  color: var(--arkt-text);
  background: var(--arkt-bg);
}

/* Landings (.arkt-landing) : même trait qu’entre le hero et la 1re section sur /custom/home */
#portfolio_page.portfolio-font .arkt-landing > section:not(.arkt-hero) {
  border-top: var(--arkt-page-border-width) solid var(--arkt-page-border-color);
}

/* Hors accueil personnalisé : fond uni via #portfolio_background. */
#portfolio_page.portfolio-font:has(main:not(.arkt-landing)) {
  background: transparent;
}

/* Ancres : décalage scroll. Sous header flottant : padding sur le hero (accueil .arkt-hero__content, blog #hero > .full-width.big-padding-top). */
#portfolio_page.portfolio-font:has(#header.arkt-header) {
  scroll-padding-top: calc(var(--arkt-header-overlap-offset) + 0.35rem);
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font:has(#header.arkt-header) {
  scroll-padding-top: calc(var(--arkt-header-overlap-offset) + 0.35rem) !important;
}

@media screen and (max-width: 1100px) {
  #portfolio_page.portfolio-font:has(#header.arkt-header) {
    --arkt-header-overlap-offset: calc(
      env(safe-area-inset-top, 0px) + (var(--arkt-header-float-inset) * 2) + min(9.5rem, 42vw)
    );
    scroll-padding-top: calc(var(--arkt-header-overlap-offset) + 0.35rem);
  }

  body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font:has(#header.arkt-header) {
    --arkt-header-overlap-offset: calc(
      env(safe-area-inset-top, 0px) + (var(--arkt-header-float-inset) * 2) + min(9.5rem, 42vw)
    );
    scroll-padding-top: calc(var(--arkt-header-overlap-offset) + 0.35rem) !important;
  }

  /*
   * Gouttières horizontales alignées sur le header flottant (inset + padding interne).
   * Cible les blocs de page directement sous main, pas les imbrications (ex. grille features).
   */
  #portfolio_page.portfolio-font:has(#header.arkt-header) main > :is(section, #hero) > .padding-left.padding-right,
  #portfolio_page.portfolio-font:has(#header.arkt-header) main > section > .padding-left.padding-right,
  #portfolio_page.portfolio-font:has(#header.arkt-header) #footer.arkt-footer .padding-left.padding-right {
    padding-left: max(var(--arkt-page-gutter), env(safe-area-inset-left, 0px)) !important;
    padding-right: max(var(--arkt-page-gutter), env(safe-area-inset-right, 0px)) !important;
    box-sizing: border-box;
  }
}

@media screen and (max-width: 650px) {
  #portfolio_page.portfolio-font:has(#header.arkt-header) main .max-padding-top {
    padding-top: clamp(2.5rem, 12vw, 4.5rem) !important;
  }

  #portfolio_page.portfolio-font:has(#header.arkt-header) main .max-padding-bottom {
    padding-bottom: clamp(2.5rem, 12vw, 4.5rem) !important;
  }
}

#portfolio_background {
  background: var(--arkt-bg);
}


/* Fonds cartes (.arkt-card / featured) : ici, pas dans components.css */
#portfolio_page .arkt-card {
  background: var(--arkt-card-bg);
}

#portfolio_page .arkt-card--featured {
  background: var(--arkt-color-featured-card-bg);
}

#portfolio_page.portfolio-font a {
  color: inherit;
}

#portfolio_page.portfolio-font a:hover {
  opacity: 0.92;
}

#portfolio_page.portfolio-font p {
  line-height: var(--portfolios-line-height-base, 1.55);
}

#portfolio_page.portfolio-font :is(h1, h2, h3) {
  font-family: var(--arkt-font-family-sans);
  line-height: 1.2;
}

/* ----- Typographie : gabarit portfolio (cf. headings.css) ----- */

#portfolio_page .arkt-landing :is(h1, .arkt-type-h1) {
  margin: 0;
  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__intro .arkt-contact__intro-body {
  font-size: var(--arkt-type-h3-size);
  line-height: var(--arkt-type-h3-line);
  color: var(--arkt-text-muted);
}

#portfolio_page .arkt-contact .arkt-contact__intro .arkt-contact__intro-body :is(h1, h2, h3) {
  color: var(--arkt-text);
  font-weight: var(--arkt-type-h3-weight);
}

#portfolio_page .arkt-landing .arkt-hero .arkt-hero__subtitle {
  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);
  margin: 0 0 1rem;
}

#portfolio_page .arkt-landing h2.arkt-heading-split,
#portfolio_page .arkt-landing h2.arkt-heading-pricing {
  margin: 0 0 1.25rem;
  font-size: inherit;
  line-height: normal;
  font-weight: inherit;
  color: inherit;
  display: flex;
  flex-direction: column;
  gap: var(--arkt-space-heading-split-gap);
}

#portfolio_page .arkt-landing h2.arkt-heading-pricing {
  margin: 0 0 1rem;
}

#portfolio_page .arkt-landing .arkt-heading-split__strong,
#portfolio_page .arkt-landing .arkt-heading-pricing__strong {
  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-landing .arkt-heading-split__light,
#portfolio_page .arkt-landing .arkt-heading-pricing__light {
  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);
}

#portfolio_page .arkt-landing .arkt-showcase__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-landing .arkt-showcase__subtitle {
  margin: 0 0 1rem;
  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);
}

#portfolio_page .arkt-landing p.arkt-faq__kicker {
  margin: 0 0 0.5rem;
  font-size: var(--arkt-type-caption-size);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  font-weight: var(--arkt-type-h3-weight);
  color: var(--arkt-accent-title);
}

#portfolio_page .arkt-landing .arkt-faq__title {
  margin: 0 0 1rem;
  font-size: var(--arkt-type-h1-size);
  line-height: var(--arkt-type-h1-line);
  font-weight: var(--arkt-type-subtle-weight);
  color: var(--arkt-text);
}

#portfolio_page .arkt-landing :is(h3, .arkt-type-h3) {
  font-size: var(--arkt-type-h3-size);
  line-height: var(--arkt-type-h3-line);
  font-weight: var(--arkt-type-h3-weight);
  color: var(--arkt-type-h3-color);
}

#portfolio_page .arkt-landing .arkt-pricing-card:not(.arkt-card--featured) h3,
#portfolio_page .arkt-landing .arkt-feature-card h3 {
  color: var(--arkt-text);
}

#portfolio_page .arkt-landing .arkt-card--featured.arkt-pricing-card h3 {
  color: var(--arkt-accent-heading-light);
}

#portfolio_page .arkt-contact .arkt-contact__infos > .full-width > h2 {
  margin: 0;
  font-size: var(--arkt-type-h2-size);
  line-height: var(--arkt-type-h2-line);
  font-weight: var(--arkt-type-h2-weight);
  color: color-mix(in srgb, var(--arkt-accent) 24%, var(--arkt-mockup-text-subtle));
}

#portfolio_page .arkt-contact .arkt-contact__form-heading {
  margin: 0 0 1.25rem;
  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);
}

#portfolio_page .arkt-contact .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);
}

#portfolio_page .arkt-contact .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);
}

#portfolio_page .arkt-contact .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);
}

/* ----- Blog : page article (contents/articles.php), sans modifier le HTML ----- */
/* Colonne unique : article principal ; #blog-about masqué (voir règle sur #blog-about) */
#portfolio_page #blog-article.limited-width.grid-aside-right {
  display: grid;
  grid-template-columns: 1fr;
  grid-template-rows: auto auto;
  gap: clamp(1.75rem, 4vw, 2.75rem);
  align-items: stretch;
  width: 100%;
}

#portfolio_page #blog-main-article {
  order: 1;
  width: 100%;
  max-width: 100%;
  background: var(--arkt-card-bg);
  border: var(--arkt-page-border);
  border-radius: var(--arkt-radius-card);
  box-shadow: 0 10px 32px var(--arkt-rgba-black-35-shadow);
  box-sizing: border-box;
  /* Remplace big-padding-right / big-padding-bottom (!important dans grid.css) + complète le haut */
  padding: clamp(1.35rem, 3.2vw, 2rem) clamp(1.15rem, 3vw, 1.75rem) !important;
}

#portfolio_page #blog-about {
  display: none !important;
  order: 2;
  width: 100%;
  max-width: 100%;
  margin: 0;
  padding: clamp(1.35rem, 3.2vw, 2rem);
  box-sizing: border-box;
  background: var(--arkt-card-bg);
  border: var(--arkt-page-border);
  border-radius: var(--arkt-radius-card);
  box-shadow: 0 10px 32px var(--arkt-rgba-black-35-shadow);
}

#portfolio_page #blog-about > h2 {
  margin: 0 0 1.15rem;
  padding: 0 0 0.85rem;
  border-bottom: var(--arkt-page-border);
  font-size: var(--arkt-type-form-heading-size);
  line-height: 1.35;
  font-weight: var(--arkt-type-h3-weight);
  color: var(--arkt-text);
  letter-spacing: 0.01em;
}

#portfolio_page #blog-about > article.text-align-left .grid-one {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 1.15rem 1.5rem;
}

#portfolio_page #blog-about > article.text-align-left .about-artist-img {
  width: 88px;
  height: 88px;
  min-width: 88px;
  border-radius: 50%;
  object-fit: cover;
  object-position: center;
  border: 2px solid var(--arkt-rgba-border-on-dark-medium);
  box-shadow: 0 6px 22px var(--arkt-rgba-black-35-shadow);
}

#portfolio_page #blog-about .about-card-title {
  margin: 0 0 0.35rem;
  font-size: var(--arkt-type-h2-size);
  line-height: var(--arkt-type-h2-line);
  font-weight: var(--arkt-type-h2-weight);
  color: var(--arkt-text);
}

#portfolio_page #blog-about > article.text-align-left h4 {
  margin: 0 0 0.85rem;
  font-size: var(--arkt-type-caption-size);
  font-weight: 500;
  line-height: 1.4;
  color: var(--arkt-text-muted);
}

#portfolio_page #blog-about > article.text-align-left .folio_button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-top: 0.25rem;
  padding: 0.55rem 1.35rem;
  font-size: var(--arkt-type-nav-size);
  font-weight: var(--arkt-btn-font-weight);
  line-height: 1.2;
  text-decoration: none;
  border-radius: var(--arkt-radius-pill);
  border: 1px solid var(--arkt-rgba-border-on-dark-nav);
  background: var(--arkt-rgba-white-08);
  color: var(--arkt-text);
  transition: background 0.15s ease, border-color 0.15s ease, color 0.15s ease;
}

#portfolio_page #blog-about > article.text-align-left .folio_button:hover {
  background: var(--arkt-rgba-white-12);
  border-color: var(--arkt-rgba-border-on-dark-strong);
  color: var(--arkt-text);
}

/* Réseaux : templates/custom/css/socials-unified.css */

#portfolio_page #blog-about > article + article {
  margin-top: 1.25rem;
  padding-top: clamp(1.15rem, 2.8vw, 1.65rem);
  border-top: 1px solid var(--arkt-rgba-border-on-dark-soft);
}

#portfolio_page #blog-about > article + article > h2 {
  margin: 0 0 1rem;
  padding: 0 0 0.75rem;
  border-bottom: var(--arkt-page-border);
  font-size: var(--arkt-type-form-heading-size);
  line-height: 1.35;
  font-weight: var(--arkt-type-h3-weight);
  color: var(--arkt-text);
  letter-spacing: 0.01em;
}

/*
 * Fil d’Ariane : conteneur = carte blog ; liens = mêmes pastilles que #header .arkt-nav > li > a (header.css).
 * Séparateur : li+li::before (breadcrumbs.css), recoloré ici.
 */
#portfolio_page main:not(#blog) #hero .ariane {
  list-style: none;
  margin: 0;
  display: inline-flex;
  flex-wrap: wrap;
  align-items: center;
  width: fit-content;
  max-width: 100%;
  box-sizing: border-box;
}

#portfolio_page main:not(#blog) #hero .ariane li {
  display: inline-flex;
  align-items: center;
}

#portfolio_page main:not(#blog) #hero .ariane li + li::before {
  content: "›";
  font-size: var(--arkt-type-caption-size);
  line-height: 1;
  margin-right: 0.35rem;
  color: var(--arkt-text-muted);
  opacity: 0.65;
  font-weight: 500;
}

#portfolio_page main:not(#blog) #hero .ariane a {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0.5rem 1.05rem !important;
  border-radius: var(--arkt-radius-pill) !important;
  text-decoration: none !important;
  font-size: var(--arkt-type-nav-size) !important;
  line-height: calc(1em + 10px) !important;
  min-height: calc(1em + 10px + 1rem) !important;
  font-weight: var(--portfolios-font-weight-normal, 400) !important;
  font-family: var(--arkt-font-family-sans) !important;
  letter-spacing: normal !important;
  text-transform: none !important;
  color: var(--arkt-color-white) !important;
  background: var(--arkt-header-pill-bg) !important;
  border: 1px solid var(--arkt-header-pill-border) !important;
  box-sizing: border-box !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  transition:
    background 0.2s ease,
    border-color 0.2s ease,
    color 0.2s ease !important;
}

#portfolio_page main:not(#blog) #hero .ariane a:hover {
  color: var(--arkt-color-white) !important;
  background: var(--arkt-header-pill-bg-hover) !important;
  border-color: color-mix(in srgb, var(--arkt-header-pill-border) 70%, var(--arkt-color-white)) !important;
}

/* Page article blog : moins d’air sous le fil seul */
#portfolio_page main > #hero:has(+ #blog-article) {
  padding-bottom: clamp(0.65rem, 2vw, 1.1rem);
}

#portfolio_page #title-article h1 {
  margin: 0 0 0.85rem;
  letter-spacing: -0.02em;
  line-height: 1.12;
}

#portfolio_page #title-article .flex,
#portfolio_page #title-article .title-article-author {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 1rem 0 0;
  margin: 0 0 0.65rem;
  border-top: var(--arkt-page-border);
  text-decoration: none;
  color: inherit;
}

/* Contre la classe utilitaire .margin-bottom (25px !important dans grid.css) */
#portfolio_page #title-article .title-article-author.margin-bottom {
  margin-bottom: 0.65rem !important;
}

#portfolio_page #title-article .title-article-author #profil-infos {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  gap: 0.2rem;
  min-width: 0;
  flex: 1 1 auto;
}

#portfolio_page #title-article .flex {
  transition: opacity 0.15s ease;
}

#portfolio_page #title-article .flex:hover {
  opacity: 0.88;
}

#portfolio_page #title-article .title-article-author__avatar-link {
  display: inline-flex;
  align-items: center;
  flex-shrink: 0;
  text-decoration: none;
  color: inherit;
  transition: opacity 0.15s ease;
}

#portfolio_page #title-article .title-article-author__avatar-link:hover {
  opacity: 0.88;
}

/* Partage article / réseaux : templates/custom/css/socials-unified.css */

#portfolio_page #title-article .title-article-author .about-artist-img {
  width: 3.25rem;
  height: 3.25rem;
  border-radius: 50%;
  border: 2px solid var(--arkt-rgba-border-on-dark-medium);
  flex-shrink: 0;
  object-fit: cover;
  object-position: center;
}

#portfolio_page #title-article #profil-infos .author {
  margin: 0;
  font-size: clamp(1rem, 2.2vw, 1.125rem);
  font-weight: 600;
  line-height: 1.25;
  letter-spacing: -0.015em;
  color: var(--arkt-text);
}

#portfolio_page #title-article #profil-infos .date {
  margin: 0;
  font-size: 0.875rem;
  line-height: 1.35;
  color: var(--arkt-text-muted);
}

/* Chapô : pas de fond ni cadre sur le bloc (le `#blog-main-article` porte déjà la carte). */
#portfolio_page #blog-main-article #subtitle-article {
  display: flex;
  flex-direction: column;
  gap: clamp(0.75rem, 2vw, 1rem);
  margin: 0 0 1.15rem;
  padding: 0 0 1rem !important;
  box-sizing: border-box;
  background: transparent;
  border: none;
  border-radius: 0;
}

#portfolio_page #blog-main-article #subtitle-article h2.subtitle {
  margin: 0;
  font-size: clamp(0.8rem, 1.35vw, 0.9rem);
  font-weight: 400;
  line-height: 1.5;
  color: var(--arkt-text-muted);
  border: 0;
  box-shadow: none;
  outline: 0;
}

#portfolio_page #blog-main-article #subtitle-article :where(h2, p, div, span, li) {
  border: 0;
  box-shadow: none;
  outline: 0;
}

#portfolio_page #blog-main-article #subtitle-article p {
  margin: 0;
  font-size: clamp(0.8rem, 1.35vw, 0.9rem);
  line-height: 1.5;
  color: var(--arkt-text-muted);
}

#portfolio_page #blog-main-article #subtitle-article p + p {
  margin-top: 0.65rem;
  padding-top: 0;
  border-top: none;
}

#portfolio_page #blog-main-article #subtitle-article :is(h2.subtitle, p) :is(strong, b, span, code) {
  color: var(--arkt-text);
}

#portfolio_page #blog-main-article #subtitle-article :is(h2.subtitle, p) :is(strong, b) {
  font-weight: var(--arkt-type-h3-weight);
}

#portfolio_page #blog-main-article #subtitle-article :is(h2.subtitle, p) :is(em, i) {
  font-style: italic;
  color: var(--arkt-text-muted);
}

#portfolio_page #blog-main-article #subtitle-article a {
  color: var(--arkt-accent);
  text-decoration: none;
  border-bottom: 1px solid color-mix(in srgb, var(--arkt-accent) 40%, transparent);
  transition: color 0.15s ease, border-color 0.15s ease;
}

#portfolio_page #blog-main-article #subtitle-article a:hover {
  color: var(--arkt-accent-strong);
  border-bottom-color: color-mix(in srgb, var(--arkt-accent-strong) 55%, transparent);
}

#portfolio_page #blog-main-article #subtitle-article img.full-width {
  margin-top: 0;
  display: block;
  width: 100%;
  height: auto;
  border-radius: var(--arkt-radius-input);
  box-sizing: border-box;
  border: var(--arkt-page-border);
  box-shadow: none;
}

/* Images dans le corps de l’article */
#portfolio_page #blog-main-article #content-article img {
  display: block;
  max-width: 100%;
  height: auto;
  border-radius: var(--arkt-radius-input);
  box-sizing: border-box;
}

#portfolio_page #blog-main-article #content-article p img,
#portfolio_page #blog-main-article #content-article a img {
  display: inline-block;
  vertical-align: middle;
}

#portfolio_page #blog-main-article #content-article {
  line-height: 1.65;
}

#portfolio_page #blog-main-article #content-article :is(p, li) {
  color: var(--arkt-text);
}

#portfolio_page #blog-main-article #content-article :is(h2, h3) {
  margin-top: 1.75rem;
  margin-bottom: 0.65rem;
  color: var(--arkt-text);
}

@media screen and (max-width: 900px) {
  #portfolio_page #blog-main-article {
    padding: clamp(1.15rem, 4vw, 1.65rem) clamp(1rem, 4vw, 1.35rem) !important;
  }
}

#portfolio_page #blog-about h2 a {
  color: inherit;
  text-decoration: none;
  border-bottom: 1px solid var(--arkt-rgba-border-on-dark-medium);
  padding-bottom: 0.12rem;
  transition: color 0.15s ease, border-color 0.15s ease;
}

#portfolio_page #blog-about h2 a:hover {
  color: var(--arkt-accent);
  border-bottom-color: color-mix(in srgb, var(--arkt-accent) 45%, transparent);
}

/* Même logique que footer.css : bouton plein écran quand footer custom (99) ne charge pas footer.css */
#visitor_mode,
#visitor_mode.arkt-visitor-mode {
  position: fixed;
  left: 50%;
  right: auto;
  transform: translateX(-50%);
  bottom: max(1rem, env(safe-area-inset-bottom, 0px));
  width: min(calc(100vw - 2rem), 22rem);
  max-width: 100%;
  margin: 0;
  padding: 0 1rem;
  box-sizing: border-box;
  text-align: center;
  z-index: 9500 !important;
  pointer-events: none;
  font-family: var(--arkt-font-family-sans, inherit);
}

#visitor_mode .arkt-promo-btn,
#visitor_mode.arkt-visitor-mode .arkt-visitor-mode__toggle {
  pointer-events: auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.45rem;
  width: 100%;
  margin: 0;
  padding: 0.65rem 1.15rem;
  border-radius: var(--arkt-radius-pill, 999px);
  font-weight: var(--arkt-btn-font-weight);
  font-size: 0.875rem;
  line-height: 1.2;
  text-decoration: none;
  box-sizing: border-box;
  color: var(--arkt-btn-cta-text);
  background: var(--arkt-btn-cta-bg);
  border: var(--arkt-btn-cta-border);
  box-shadow: var(--arkt-btn-cta-shadow);
  backdrop-filter: var(--arkt-hub-glass-blur);
  -webkit-backdrop-filter: var(--arkt-hub-glass-blur);
  transition:
    background 0.2s ease,
    border-color 0.2s ease,
    box-shadow 0.2s ease,
    transform 0.2s ease;
}

#visitor_mode .arkt-promo-btn:hover,
#visitor_mode.arkt-visitor-mode .arkt-visitor-mode__toggle:hover {
  background: var(--arkt-btn-cta-bg-hover);
  border: var(--arkt-btn-cta-border);
  box-shadow: var(--arkt-btn-cta-shadow-hover);
  transform: translateY(-2px);
  filter: none;
}

body:has(#visitor_mode) #portfolio_page,
body:has(#visitor_mode.arkt-visitor-mode) #portfolio_page {
  padding-bottom: 5.5rem;
}

@media screen and (max-width: 600px) {
  #visitor_mode,
  #visitor_mode.arkt-visitor-mode {
    width: min(92vw, 22rem);
  }
}

/* =============================================================================
   Mode éditeur (portfolio-editor) : hub + headings.css + fonts.css chargés après.
   Forcer variables + typo + surfaces du thème custom dans #webpage-simulation.
   ============================================================================= */
body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font,
body.portfolio-editor #webpage-simulation #portfolio_background {
  --arktefakt-text-main: var(--arkt-text) !important;
  --arktefakt-text-muted: var(--arkt-text-muted) !important;
  --arktefakt-text-inverse: var(--arkt-color-white) !important;
  --arktefakt-text-button: var(--arkt-color-white) !important;
  --arktefakt-text-button-hover: var(--arkt-color-white) !important;
  --arktefakt-text-cta: var(--arkt-color-white) !important;
  --arktefakt-text-cta-hover: var(--arkt-color-white) !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font {
  font-family: var(--arkt-font-family-sans) !important;
  color: var(--arkt-text) !important;
  background: var(--arkt-bg) !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font:has(main:not(.arkt-landing)) {
  background: transparent !important;
}

body.portfolio-editor #webpage-simulation #portfolio_background {
  background: var(--arkt-bg) !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font a:not(.arkt-btn):not(.arkt-promo-btn) {
  color: inherit !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font a:not(.arkt-btn):not(.arkt-promo-btn):hover {
  opacity: 0.92 !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font p {
  line-height: var(--portfolios-line-height-base, 1.55) !important;
  color: var(--arkt-text) !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font :is(h1, h2, h3) {
  font-family: var(--arkt-font-family-sans) !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font .arkt-muted {
  color: var(--arkt-text-muted) !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font .arkt-landing :is(h1, .arkt-type-h1) {
  margin: 0 !important;
  font-size: var(--arkt-type-h1-size) !important;
  line-height: var(--arkt-type-h1-line) !important;
  font-weight: var(--arkt-type-h1-weight) !important;
  color: var(--arkt-type-h1-color) !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font .arkt-contact .arkt-contact__intro .arkt-contact__intro-body {
  font-size: var(--arkt-type-h3-size) !important;
  line-height: var(--arkt-type-h3-line) !important;
  color: var(--arkt-text-muted) !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font .arkt-contact .arkt-contact__intro .arkt-contact__intro-body :is(h1, h2, h3) {
  color: var(--arkt-text) !important;
  font-weight: var(--arkt-type-h3-weight) !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font .arkt-landing .arkt-hero .arkt-hero__subtitle {
  font-size: var(--arkt-type-h2-size) !important;
  line-height: var(--arkt-type-h2-line) !important;
  font-weight: var(--arkt-type-subtle-weight) !important;
  color: var(--arkt-mockup-text-subtle) !important;
  margin: 0 0 1rem !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font .arkt-landing h2.arkt-heading-split,
body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font .arkt-landing h2.arkt-heading-pricing {
  margin: 0 0 1.25rem !important;
  font-size: inherit !important;
  line-height: normal !important;
  font-weight: inherit !important;
  color: inherit !important;
  display: flex !important;
  flex-direction: column !important;
  gap: var(--arkt-space-heading-split-gap) !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font .arkt-landing h2.arkt-heading-pricing {
  margin: 0 0 1rem !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font .arkt-landing .arkt-heading-split__strong,
body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font .arkt-landing .arkt-heading-pricing__strong {
  font-size: var(--arkt-type-h1-size) !important;
  line-height: var(--arkt-type-h1-line) !important;
  font-weight: var(--arkt-type-h1-weight) !important;
  color: var(--arkt-type-h1-color) !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font .arkt-landing .arkt-heading-split__light,
body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font .arkt-landing .arkt-heading-pricing__light {
  font-size: var(--arkt-type-h2-size) !important;
  line-height: var(--arkt-type-h2-line) !important;
  font-weight: var(--arkt-type-subtle-weight) !important;
  color: var(--arkt-mockup-text-subtle) !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font .arkt-features__title,
body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font .arkt-pricing__title {
  margin: 0 0 0.35rem !important;
  font-size: var(--arkt-type-h1-size) !important;
  line-height: var(--arkt-type-h1-line) !important;
  font-weight: var(--arkt-type-h1-weight) !important;
  color: var(--arkt-type-h1-color) !important;
}

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

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font .arkt-pricing__title .arkt-pricing__title-strong {
  font-weight: var(--arkt-type-h1-weight) !important;
  color: var(--arkt-type-h1-color) !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font .arkt-pricing__title .arkt-pricing__title-light {
  font-weight: var(--arkt-type-subtle-weight) !important;
  color: var(--arkt-mockup-text-subtle) !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font .arkt-landing .arkt-showcase__title {
  margin: 0 0 0.35rem !important;
  font-size: var(--arkt-type-h1-size) !important;
  line-height: var(--arkt-type-h1-line) !important;
  font-weight: var(--arkt-type-h1-weight) !important;
  color: var(--arkt-type-h1-color) !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font .arkt-landing .arkt-showcase__subtitle {
  margin: 0 0 1rem !important;
  font-size: var(--arkt-type-h2-size) !important;
  line-height: var(--arkt-type-h2-line) !important;
  font-weight: var(--arkt-type-subtle-weight) !important;
  color: var(--arkt-mockup-text-subtle) !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font .arkt-landing p.arkt-faq__kicker {
  margin: 0 0 0.5rem !important;
  font-size: var(--arkt-type-caption-size) !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  font-weight: var(--arkt-type-h3-weight) !important;
  color: var(--arkt-accent-title) !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font .arkt-landing .arkt-faq__title {
  margin: 0 0 1rem !important;
  font-size: var(--arkt-type-h1-size) !important;
  line-height: var(--arkt-type-h1-line) !important;
  font-weight: var(--arkt-type-subtle-weight) !important;
  color: var(--arkt-text) !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font .arkt-landing :is(h3, .arkt-type-h3) {
  font-size: var(--arkt-type-h3-size) !important;
  line-height: var(--arkt-type-h3-line) !important;
  font-weight: var(--arkt-type-h3-weight) !important;
  color: var(--arkt-type-h3-color) !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font .arkt-landing .arkt-pricing-card:not(.arkt-card--featured) h3,
body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font .arkt-landing .arkt-feature-card h3 {
  color: var(--arkt-text) !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font .arkt-landing .arkt-card--featured.arkt-pricing-card h3 {
  color: var(--arkt-accent-heading-light) !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font .arkt-landing .arkt-card--featured.arkt-pricing-card .arkt-price:not(.arkt-price--old),
body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font .arkt-landing .arkt-card--featured.arkt-pricing-card .arkt-price--promo {
  color: var(--arkt-accent-strong) !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font .arkt-landing .arkt-card--featured.arkt-pricing-card .arkt-price--old {
  color: var(--arkt-text-on-light-muted) !important;
  opacity: 1 !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font .arkt-landing .arkt-card--featured.arkt-pricing-card .arkt-muted,
body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font .arkt-landing .arkt-card--featured.arkt-pricing-card .arkt-list,
body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font .arkt-landing .arkt-card--featured.arkt-pricing-card .arkt-list li {
  color: var(--arkt-text-on-light-muted) !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font .arkt-contact .arkt-contact__infos > .full-width > h2 {
  font-size: var(--arkt-type-h2-size) !important;
  line-height: var(--arkt-type-h2-line) !important;
  font-weight: var(--arkt-type-h2-weight) !important;
  color: color-mix(in srgb, var(--arkt-accent) 24%, var(--arkt-mockup-text-subtle)) !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font .arkt-contact .arkt-contact__form-heading {
  margin: 0 0 1.25rem !important;
  font-size: var(--arkt-type-h3-size) !important;
  line-height: var(--arkt-type-h3-line) !important;
  font-weight: var(--arkt-type-h3-weight) !important;
  color: var(--arkt-text) !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font .arkt-contact .arkt-contact__identity-header {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  text-align: center !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font .arkt-contact .arkt-contact-members__title {
  margin: 0 0 0.65rem !important;
  font-size: var(--arkt-type-h1-size) !important;
  line-height: var(--arkt-type-h1-line) !important;
  font-weight: var(--arkt-type-h1-weight) !important;
  color: var(--arkt-type-h1-color) !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font .arkt-contact .arkt-contact-members__subtitle {
  margin: 0 !important;
  font-size: var(--arkt-type-h2-size) !important;
  line-height: var(--arkt-type-h2-line) !important;
  font-weight: var(--arkt-type-subtle-weight) !important;
  color: var(--arkt-mockup-text-subtle) !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font .arkt-contact .arkt-contact-member__name {
  margin: 0 0 0.35rem !important;
  font-size: var(--arkt-type-h3-size) !important;
  line-height: var(--arkt-type-h3-line) !important;
  font-weight: var(--arkt-type-h3-weight) !important;
  color: var(--arkt-text) !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font .arkt-card {
  background: var(--arkt-card-bg) !important;
  border: var(--arkt-page-border) !important;
  border-radius: var(--arkt-radius-card) !important;
  color: var(--arkt-text) !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font .arkt-card--featured {
  background: var(--arkt-color-featured-card-bg) !important;
  border-color: var(--arkt-rgba-black-06-on-white) !important;
  color: var(--arkt-text-on-light) !important;
  box-shadow: var(--arkt-shadow-featured-card) !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font .arkt-card--featured .arkt-muted {
  color: var(--arkt-text-on-featured-muted) !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font .arkt-accordion {
  border-top: var(--arkt-page-border-width) solid var(--arkt-page-border-color) !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font .arkt-accordion details {
  border-bottom: var(--arkt-page-border-width) solid var(--arkt-page-border-color) !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font .arkt-faq__answer,
body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font .arkt-faq__answer p,
body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font .arkt-faq__answer li {
  line-height: var(--arkt-faq-answer-line-height) !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font .arkt-contact {
  background: transparent !important;
  color: var(--arkt-text) !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font .arkt-contact > section.section-bg {
  background: color-mix(in srgb, var(--arkt-bg) 68%, transparent) !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font #blog-article.limited-width.grid-aside-right {
  display: grid !important;
  grid-template-columns: 1fr !important;
  grid-template-rows: auto auto !important;
  gap: clamp(1.75rem, 4vw, 2.75rem) !important;
  align-items: stretch !important;
  width: 100% !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font #blog-main-article {
  order: 1 !important;
  width: 100% !important;
  max-width: 100% !important;
  background: var(--arkt-card-bg) !important;
  border: var(--arkt-page-border) !important;
  border-radius: var(--arkt-radius-card) !important;
  box-shadow: 0 10px 32px var(--arkt-rgba-black-35-shadow) !important;
  box-sizing: border-box !important;
  padding: clamp(1.35rem, 3.2vw, 2rem) clamp(1.15rem, 3vw, 1.75rem) !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font #blog-about {
  display: none !important;
  order: 2 !important;
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 !important;
  padding: clamp(1.35rem, 3.2vw, 2rem) !important;
  box-sizing: border-box !important;
  background: var(--arkt-card-bg) !important;
  border: var(--arkt-page-border) !important;
  border-radius: var(--arkt-radius-card) !important;
  box-shadow: 0 10px 32px var(--arkt-rgba-black-35-shadow) !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font #blog-about > h2 {
  margin: 0 0 1.15rem !important;
  padding: 0 0 0.85rem !important;
  border-bottom: var(--arkt-page-border) !important;
  font-size: var(--arkt-type-form-heading-size) !important;
  line-height: 1.35 !important;
  font-weight: var(--arkt-type-h3-weight) !important;
  color: var(--arkt-text) !important;
  letter-spacing: 0.01em !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font #blog-about > article.text-align-left .grid-one {
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  gap: 1.15rem 1.5rem !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font #blog-about > article.text-align-left .about-artist-img {
  width: 88px !important;
  height: 88px !important;
  min-width: 88px !important;
  border-radius: 50% !important;
  object-fit: cover !important;
  object-position: center !important;
  border: 2px solid var(--arkt-rgba-border-on-dark-medium) !important;
  box-shadow: 0 6px 22px var(--arkt-rgba-black-35-shadow) !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font #blog-about .about-card-title {
  margin: 0 0 0.35rem !important;
  font-size: var(--arkt-type-h2-size) !important;
  line-height: var(--arkt-type-h2-line) !important;
  font-weight: var(--arkt-type-h2-weight) !important;
  color: var(--arkt-text) !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font #blog-about > article.text-align-left h4 {
  margin: 0 0 0.85rem !important;
  font-size: var(--arkt-type-caption-size) !important;
  font-weight: 500 !important;
  line-height: 1.4 !important;
  color: var(--arkt-text-muted) !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font #blog-about > article.text-align-left .folio_button {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  margin-top: 0.25rem !important;
  padding: 0.55rem 1.35rem !important;
  font-size: var(--arkt-type-nav-size) !important;
  font-weight: var(--arkt-btn-font-weight) !important;
  line-height: 1.2 !important;
  text-decoration: none !important;
  border-radius: var(--arkt-radius-pill) !important;
  border: 1px solid var(--arkt-rgba-border-on-dark-nav) !important;
  background: var(--arkt-rgba-white-08) !important;
  color: var(--arkt-text) !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font #blog-about > article + article {
  margin-top: 1.25rem !important;
  padding-top: clamp(1.15rem, 2.8vw, 1.65rem) !important;
  border-top: 1px solid var(--arkt-rgba-border-on-dark-soft) !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font #blog-about > article + article > h2 {
  margin: 0 0 1rem !important;
  padding: 0 0 0.75rem !important;
  border-bottom: var(--arkt-page-border) !important;
  font-size: var(--arkt-type-form-heading-size) !important;
  line-height: 1.35 !important;
  font-weight: var(--arkt-type-h3-weight) !important;
  color: var(--arkt-text) !important;
  letter-spacing: 0.01em !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font main:not(#blog) #hero .ariane {
  list-style: none !important;
  margin: 0 !important;
  padding: 0.5rem 0.65rem !important;
  display: inline-flex !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  gap: 0.15rem 0.35rem !important;
  width: fit-content !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
  background: var(--arkt-card-bg) !important;
  border: var(--arkt-page-border) !important;
  border-radius: var(--arkt-radius-card) !important;
  box-shadow: 0 8px 28px var(--arkt-rgba-black-35-shadow) !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font main:not(#blog) #hero .ariane li + li::before {
  content: "›" !important;
  font-size: var(--arkt-type-caption-size) !important;
  line-height: 1 !important;
  margin-right: 0.35rem !important;
  color: var(--arkt-text-muted) !important;
  opacity: 0.65 !important;
  font-weight: 500 !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font main:not(#blog) #hero .ariane a {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0.5rem 1.05rem !important;
  border-radius: var(--arkt-radius-pill) !important;
  text-decoration: none !important;
  font-size: var(--arkt-type-nav-size) !important;
  line-height: calc(1em + 10px) !important;
  min-height: calc(1em + 10px + 1rem) !important;
  font-weight: var(--portfolios-font-weight-normal, 400) !important;
  font-family: var(--arkt-font-family-sans) !important;
  letter-spacing: normal !important;
  text-transform: none !important;
  color: var(--arkt-color-white) !important;
  background: var(--arkt-header-pill-bg) !important;
  border: 1px solid var(--arkt-header-pill-border) !important;
  box-sizing: border-box !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  transition:
    background 0.2s ease,
    border-color 0.2s ease,
    color 0.2s ease !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font main:not(#blog) #hero .ariane a:hover {
  color: var(--arkt-color-white) !important;
  background: var(--arkt-header-pill-bg-hover) !important;
  border-color: color-mix(in srgb, var(--arkt-header-pill-border) 70%, var(--arkt-color-white)) !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font main > #hero:has(+ #blog-article) {
  padding-bottom: clamp(0.65rem, 2vw, 1.1rem) !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font #title-article h1 {
  margin: 0 0 0.85rem !important;
  letter-spacing: -0.02em !important;
  line-height: 1.12 !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font #title-article .flex,
body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font #title-article .title-article-author {
  display: flex !important;
  align-items: center !important;
  gap: 1rem !important;
  padding: 1rem 0 0 !important;
  margin: 0 0 0.65rem !important;
  border-top: var(--arkt-page-border) !important;
  text-decoration: none !important;
  color: inherit !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font #title-article .title-article-author.margin-bottom {
  margin-bottom: 0.65rem !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font #title-article .title-article-author #profil-infos {
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
  align-items: flex-start !important;
  gap: 0.2rem !important;
  min-width: 0 !important;
  flex: 1 1 auto !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font #title-article .title-article-author__avatar-link {
  display: inline-flex !important;
  align-items: center !important;
  flex-shrink: 0 !important;
  text-decoration: none !important;
  color: inherit !important;
  transition: opacity 0.15s ease !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font #title-article .title-article-author__avatar-link:hover {
  opacity: 0.88 !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font #title-article .title-article-author .about-artist-img {
  width: 3.25rem !important;
  height: 3.25rem !important;
  border-radius: 50% !important;
  border: 2px solid var(--arkt-rgba-border-on-dark-medium) !important;
  flex-shrink: 0 !important;
  object-fit: cover !important;
  object-position: center !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font #title-article #profil-infos .author {
  margin: 0 !important;
  font-size: clamp(1rem, 2.2vw, 1.125rem) !important;
  font-weight: 600 !important;
  line-height: 1.25 !important;
  letter-spacing: -0.015em !important;
  color: var(--arkt-text) !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font #title-article #profil-infos .date {
  margin: 0 !important;
  font-size: 0.875rem !important;
  line-height: 1.35 !important;
  color: var(--arkt-text-muted) !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font #blog-main-article #subtitle-article {
  display: flex !important;
  flex-direction: column !important;
  gap: clamp(0.75rem, 2vw, 1rem) !important;
  margin: 0 0 1.15rem !important;
  padding: 0 0 1rem !important;
  box-sizing: border-box !important;
  background: transparent !important;
  border: none !important;
  border-radius: 0 !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font #subtitle-article h2.subtitle {
  margin: 0 !important;
  font-size: clamp(0.8rem, 1.35vw, 0.9rem) !important;
  font-weight: 400 !important;
  line-height: 1.5 !important;
  color: var(--arkt-text-muted) !important;
  border: 0 !important;
  box-shadow: none !important;
  outline: 0 !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font #blog-main-article #subtitle-article :where(h2, p, div, span, li) {
  border: 0 !important;
  box-shadow: none !important;
  outline: 0 !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font #blog-main-article #subtitle-article p {
  margin: 0 !important;
  font-size: clamp(0.8rem, 1.35vw, 0.9rem) !important;
  line-height: 1.5 !important;
  color: var(--arkt-text-muted) !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font #blog-main-article #subtitle-article p + p {
  margin-top: 0.65rem !important;
  padding-top: 0 !important;
  border-top: none !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font #blog-main-article #subtitle-article :is(h2.subtitle, p) :is(strong, b, span, code) {
  color: var(--arkt-text) !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font #blog-main-article #subtitle-article :is(h2.subtitle, p) :is(strong, b) {
  font-weight: var(--arkt-type-h3-weight) !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font #blog-main-article #subtitle-article :is(h2.subtitle, p) :is(em, i) {
  font-style: italic !important;
  color: var(--arkt-text-muted) !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font #blog-main-article #subtitle-article a {
  color: var(--arkt-accent) !important;
  text-decoration: none !important;
  border-bottom: 1px solid color-mix(in srgb, var(--arkt-accent) 40%, transparent) !important;
  transition: color 0.15s ease, border-color 0.15s ease !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font #blog-main-article #subtitle-article a:hover {
  color: var(--arkt-accent-strong) !important;
  border-bottom-color: color-mix(in srgb, var(--arkt-accent-strong) 55%, transparent) !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font #blog-main-article #subtitle-article img.full-width {
  margin-top: 0 !important;
  display: block !important;
  width: 100% !important;
  height: auto !important;
  border-radius: var(--arkt-radius-input) !important;
  box-sizing: border-box !important;
  border: var(--arkt-page-border) !important;
  box-shadow: none !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font #blog-main-article #content-article img {
  display: block !important;
  max-width: 100% !important;
  height: auto !important;
  border-radius: var(--arkt-radius-input) !important;
  box-sizing: border-box !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font #blog-main-article #content-article p img,
body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font #blog-main-article #content-article a img {
  display: inline-block !important;
  vertical-align: middle !important;
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font #blog-main-article #content-article {
  line-height: 1.65 !important;
}

@media screen and (max-width: 900px) {
  body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font #blog-main-article {
    padding: clamp(1.15rem, 4vw, 1.65rem) clamp(1rem, 4vw, 1.35rem) !important;
  }
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font #blog-about h2 a {
  border-bottom: 1px solid var(--arkt-rgba-border-on-dark-medium) !important;
  padding-bottom: 0.12rem !important;
}

/* =============================================================================
 * Projets — liste / fiche : rythme de page, liens de section, alignements
 * (détails visuels cartes / hero dans templates/custom/css/components.css)
 * ============================================================================= */

#portfolio_page.portfolio-font:has(main#projects) #hero .big-padding-top {
  max-width: min(100%, var(--arkt-showcase-max-width, 1500px));
  margin-inline: auto;
  padding-top: clamp(2rem, 6vw, 4rem);
}

#portfolio_page.portfolio-font:has(main#projects) #hero .content-article {
  text-align: inherit;
}

#portfolio_page.portfolio-font main#projects > section.section-bg:not(#hero) .full-width {
  max-width: min(100%, var(--arkt-showcase-max-width, 1500px));
  margin-inline: auto;
}

#portfolio_page #about-content > h2 a {
  color: var(--arkt-text);
  text-decoration: none;
  border-bottom: 1px solid var(--arkt-rgba-border-on-dark-medium);
  padding-bottom: 0.15rem;
  transition:
    color 0.15s ease,
    border-color 0.15s ease;
}

#portfolio_page #about-content > h2 a:hover {
  color: var(--arkt-accent);
  border-bottom-color: color-mix(in srgb, var(--arkt-accent) 45%, transparent);
}

#portfolio_page section#projects > h2 a {
  color: var(--arkt-text);
  text-decoration: none;
  border-bottom: 1px solid var(--arkt-rgba-border-on-dark-medium);
  padding-bottom: 0.12rem;
  transition: color 0.15s ease, border-color 0.15s ease;
}

#portfolio_page section#projects > h2 a:hover {
  color: var(--arkt-accent);
  border-bottom-color: color-mix(in srgb, var(--arkt-accent) 45%, transparent);
}

#portfolio_page #content article.main a {
  color: var(--arkt-accent);
  text-decoration: none;
  border-bottom: 1px solid color-mix(in srgb, var(--arkt-accent) 35%, transparent);
}

#portfolio_page #content article.main a:hover {
  color: var(--arkt-accent-strong);
  border-bottom-color: color-mix(in srgb, var(--arkt-accent-strong) 50%, transparent);
}

body.portfolio-editor #webpage-simulation #portfolio_page.portfolio-font:has(main#projects) #hero .big-padding-top {
  max-width: min(100%, var(--arkt-showcase-max-width, 1500px)) !important;
  margin-inline: auto !important;
}

/* =============================================================================
 * Bloc Discord — landing (.arkt-discord), ex hub/css/modules/discord.css
 * ============================================================================= */

#portfolio_page .arkt-landing .arkt-discord {
  --arkt-discord-blurple: #5865f2;
  --arkt-discord-blurple-hover: #4752c4;
  --hub-surface: var(--arktefakt-bg-surface, rgba(30, 31, 34, 0.88));
  --hub-surface-2: var(--arktefakt-bg-surface-secondary, rgba(20, 20, 22, 0.92));
  --hub-border: var(--arktefakt-border-main, rgba(255, 255, 255, 0.08));
  --hub-text: var(--arktefakt-text-main, #f6f6f7);
  --hub-text-muted: var(--arktefakt-text-muted, #a0a0a0);
  --hub-label: var(--arktefakt-text-label, #e2e2e2);
  position: relative;
  overflow: hidden;
  background: var(--arkt-bg, #000);
}

#portfolio_page .arkt-landing .arkt-discord__inner {
  position: relative;
  z-index: 1;
  box-sizing: border-box;
}

#portfolio_page .arkt-landing .arkt-discord__card {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: clamp(1.25rem, 3vw, 2rem);
  align-items: start;
  width: 100%;
  box-sizing: border-box;
  padding: clamp(1.35rem, 3vw, 2rem);
  border-radius: 12px;
  border: 1px solid var(--hub-border);
  background: linear-gradient(
      135deg,
      color-mix(in srgb, var(--hub-surface) 92%, var(--arkt-discord-blurple) 8%) 0%,
      var(--hub-surface-2) 100%
    );
  box-shadow:
    0 0 0 1px color-mix(in srgb, var(--arkt-discord-blurple) 12%, transparent),
    0 18px 48px rgba(0, 0, 0, 0.35);
  backdrop-filter: blur(12px);
}

#portfolio_page .arkt-landing .arkt-discord__mark {
  display: flex;
  align-items: flex-start;
  justify-content: center;
}

#portfolio_page .arkt-landing .arkt-discord__logo-wrap {
  display: flex;
  align-items: center;
  justify-content: center;
  width: clamp(3.5rem, 8vw, 4.5rem);
  height: clamp(3.5rem, 8vw, 4.5rem);
  border-radius: 14px;
  background: linear-gradient(145deg, var(--arkt-discord-blurple), #3c45a5);
  color: #fff;
  box-shadow: 0 8px 24px color-mix(in srgb, var(--arkt-discord-blurple) 45%, transparent);
}

#portfolio_page .arkt-landing .arkt-discord__logo-wrap svg {
  width: 55%;
  height: auto;
  display: block;
}

#portfolio_page .arkt-landing .arkt-discord__body {
  min-width: 0;
  text-align: left;
}

#portfolio_page .arkt-landing .arkt-discord__title {
  margin: 0 0 0.65rem;
  font-size: var(--arkt-type-h2-size, 1.35rem);
  line-height: var(--arkt-type-h2-line, 1.35);
  font-weight: var(--arkt-type-h2-weight, 700);
  color: var(--hub-text);
}

#portfolio_page .arkt-landing .arkt-discord__text {
  margin: 0 0 1.1rem;
  line-height: 1.6;
  color: var(--hub-text-muted);
  font-size: max(0.9rem, 0.95em);
}

#portfolio_page .arkt-landing .arkt-discord__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
  align-items: center;
}

#portfolio_page .arkt-landing .arkt-discord__btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.45rem;
  padding: 0.65rem 1.25rem;
  border-radius: 6px;
  font-size: 0.95rem;
  font-weight: 600;
  text-decoration: none;
  color: #fff !important;
  background: var(--arkt-discord-blurple);
  border: none;
  box-shadow: 0 2px 0 color-mix(in srgb, #000 22%, transparent);
  transition: background 0.15s ease, transform 0.12s ease, box-shadow 0.15s ease;
}

#portfolio_page .arkt-landing .arkt-discord__btn:hover {
  background: var(--arkt-discord-blurple-hover);
  transform: translateY(-1px);
}

#portfolio_page .arkt-landing .arkt-discord__btn:focus-visible {
  outline: 2px solid #fff;
  outline-offset: 2px;
}

@media screen and (max-width: 640px) {
  #portfolio_page .arkt-landing .arkt-discord__card {
    grid-template-columns: 1fr;
    text-align: center;
  }

  #portfolio_page .arkt-landing .arkt-discord__body {
    text-align: center;
  }

  #portfolio_page .arkt-landing .arkt-discord__actions {
    justify-content: center;
  }
}

@media (prefers-reduced-motion: reduce) {
  #portfolio_page .arkt-landing .arkt-discord__btn:hover {
    transform: none;
  }
}
