/* Suniia — en-tête fixe, logo + navigation sur une ligne */

.suniia-header {
  /* Glassmorphisme : semi-transparent pour laisser la lumière ambiante traverser */
  background-color: rgba(var(--color-obsidian-rgb), 0.75);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  width: 100%;
  position: sticky;
  top: 0;
  z-index: 100;
  min-height: 48px; /* hauteur compacte — libère l'écran pour le contenu */
  /* Ligne de coupe + ombre descendante : résiste à l'éblouissement du ::after */
  border-bottom: 1px solid rgba(var(--color-champagne-rgb), 0.10);
  box-shadow:
    0 1px 0 rgba(var(--color-champagne-rgb), 0.08),
    0 4px 24px rgba(var(--color-black-rgb), 0.50);
}

/* Profondeur simulée : lumière dorée qui se déverse sous le header
   Donne l'impression que le header "projette" de la lumière vers le bas */
.suniia-header::after {
  content: '';
  position: absolute;
  top: 100%;
  left: 0;
  width: 100%;
  height: 120px;
  background: linear-gradient(to bottom, rgba(var(--color-champagne-rgb), 0.05), transparent);
  pointer-events: none;
}

.suniia-header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  max-width: var(--max-w-header);
  margin: 0 auto;
  padding: 0 2rem;
  min-height: 48px;
}

/* -------------------------------------------------------
   Neutralisation du composant de marque Olivero
   (.site-branding transporte min-width, min-height 180px,
   margin-inline négatif et background-image qui brisent
   notre layout flex)
------------------------------------------------------- */
.suniia-header .site-branding {
  all: unset;
  display: flex;
  align-items: center;
  flex-shrink: 0;
}

.suniia-header .site-branding__inner {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.suniia-header .site-branding__logo img {
  height: 36px;
  width: auto;
  display: block;
}

.suniia-header .site-branding__text {
  color: var(--color-pearl);
}

.suniia-header .site-branding__name a,
.suniia-header .site-branding__slogan {
  color: inherit;
  text-decoration: none;
}

/* Zone gauche : bloc de marque + navigation principale en ligne */
.suniia-header__branding {
  display: flex;
  align-items: center;
  gap: 2rem;
  flex: 1;
}

.suniia-header__branding .block {
  margin: 0;
  padding: 0;
}

/* Liens du menu principal — couvre <a>, <span> nolink et <button> toggle */
/* Olivero nav-primary-wide.css applique font-size:1rem via body:not(.is-always-mobile-nav) .primary-nav__menu-link (0,2,1).
   Les <a> sont couverts par .suniia-header .menu a (0,2,1) qui gagne à ordre de chargement.
   Les <span> nolink ne sont PAS des <a> : ils perdent contre Olivero (0,2,0 < 0,2,1).
   Solution : ajouter body:not(.is-always-mobile-nav) pour monter à 0,3,1 sur desktop. */
.suniia-header .menu a,
.suniia-header .primary-nav__menu-link,
.suniia-header .primary-nav__menu-link--nolink {
  color: rgba(var(--color-pearl-rgb), 0.85);
  text-decoration: none;
  text-transform: uppercase;
  transition: color 0.3s ease;
}

/* Propriétés typographiques séparées : desktop uniquement, avec ancrage body pour battre Olivero wide (0,3,1 > 0,2,1) */
@media (min-width: 75rem) {
  body:not(.is-always-mobile-nav) .suniia-header .primary-nav__menu-link,
  body:not(.is-always-mobile-nav) .suniia-header .primary-nav__menu-link--nolink {
    font-size: 0.8rem;
    font-weight: 300;
    letter-spacing: 0.12em;
  }
}

/* Mobile : les font-size/weight/letter-spacing sont dans le bloc @media max-width ci-dessous */

.suniia-header .menu a:hover,
.suniia-header .primary-nav__menu-link:hover {
  color: var(--color-champagne);
}

/* Item actif : ancrage magenta — distingue "où je suis" du hover doré */
/* font-size/weight/letter-spacing répétés pour neutraliser Olivero qui injecte bold sur active-trail */
.suniia-header .primary-nav__menu .primary-nav__menu-link--active-trail {
  font-size: 0.8rem;
  font-weight: 300;
  letter-spacing: 0.12em;
  color: var(--color-pearl);
  text-decoration: underline;
  text-decoration-color: rgba(var(--color-magenta-rgb), 0.65);
  text-decoration-thickness: 1px;
  text-underline-offset: 6px;
}

/* Zone droite : menu secondaire (recherche, connexion) */
.suniia-header__nav {
  display: flex;
  align-items: center;
  gap: 1rem;
  color: var(--clr-text-light);
  flex-shrink: 0;
}

/* Seulement le niveau 1 en flex horizontal */
.suniia-header__branding .primary-nav__menu--level-1,
.suniia-header__nav .menu {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 1rem;
  margin: 0;
  padding: 0;
  list-style: none;
}

/* Restore nav-primary.css flex rules (removed in W0) */
.suniia-header .primary-nav__menu-item {
  display: flex;
  flex-wrap: nowrap;
}

.suniia-header .primary-nav__menu-item--has-children {
  position: relative;
  flex-wrap: wrap;
}

.suniia-header .primary-nav__menu-link,
.suniia-header .primary-nav__menu-link--nolink {
  flex-grow: 1;
}

/* isDesktopNav() checks getComputedStyle(mobile-buttons).display === 'none'.
   On desktop: display:none → isDesktopNav() returns true → JS hover dropdowns fire.
   On mobile: visually hidden but not display:none → isDesktopNav() returns false. */
.suniia-header .mobile-buttons {
  position: absolute;
  width: 0;
  height: 0;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
  margin: 0;
  padding: 0;
  pointer-events: none;
}

@media (min-width: 75rem) {
  body:not(.is-always-mobile-nav) .suniia-header .mobile-buttons {
    display: none;
  }
}

/* Masquer le bouton toggle sur desktop (le survol suffit) */
@media (min-width: 75rem) {
  body:not(.is-always-mobile-nav) .suniia-header .primary-nav__button-toggle {
    display: none !important;
  }
}

/* ── Icône cadenas (Video) ── */
.nav-lock-icon {
  display: inline-block;
  vertical-align: middle;
  margin-left: 5px;
  margin-top: -2px;
  opacity: 0.65;
  color: var(--color-champagne);
  transition: opacity 0.3s ease;
}

.suniia-header .menu a:hover .nav-lock-icon,
.suniia-header .primary-nav__menu-link:hover .nav-lock-icon {
  opacity: 1;
}

/* -------------------------------------------------------
   Sous-menu niveau 2 : panneau verre dépoli
   Replaces nav-primary.css + nav-primary-wide.css (removed W0).
------------------------------------------------------- */

/* Desktop ≥ 75rem: hidden by default, shown on .is-active-menu-parent (Olivero JS) */
@media (min-width: 75rem) {
  body:not(.is-always-mobile-nav) .primary-nav__menu--level-2 {
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translate(-50%, -8px);
    visibility: hidden;
    opacity: 0;
    transition: visibility 0.18s ease, opacity 0.18s ease, transform 0.18s ease;
    z-index: 300;
    min-width: 180px;
    overflow: auto;
  }

  body:not(.is-always-mobile-nav) .primary-nav__menu--level-2.is-active-menu-parent {
    visibility: visible;
    opacity: 1;
    transform: translate(-50%, 0);
  }

  /* CSS hover fallback — works without JS is-active-menu-parent */
  body:not(.is-always-mobile-nav) .suniia-header .primary-nav__menu-item--has-children:hover > .primary-nav__menu--level-2,
  body:not(.is-always-mobile-nav) .suniia-header .primary-nav__menu-item--has-children:focus-within > .primary-nav__menu--level-2 {
    visibility: visible;
    opacity: 1;
    transform: translate(-50%, 0);
  }

  /* Prevent nav items from wrapping (replaces nav-primary-wide.css) */
  body:not(.is-always-mobile-nav) .suniia-header .primary-nav__menu-item {
    flex-wrap: nowrap;
    white-space: nowrap;
  }

  body:not(.is-always-mobile-nav) .suniia-header .primary-nav__menu-item--level-1 {
    position: relative;
    display: flex;
    align-items: center;
  }
}

.suniia-header .primary-nav__menu--level-2 {
  background: rgba(var(--color-obsidian-rgb), 0.92);
  backdrop-filter: blur(20px) saturate(140%);
  -webkit-backdrop-filter: blur(20px) saturate(140%);
  border: 1px solid rgba(var(--color-champagne-rgb), 0.08);
  box-shadow: 0 12px 32px rgba(var(--color-black-rgb), 0.65);
  border-radius: 0 0 6px 6px;
  padding-inline-start: 0;
  padding-inline-end: 0;
  padding-block: 6px;
}

.suniia-header .primary-nav__menu--level-2 .primary-nav__menu-link {
  color: rgba(var(--color-pearl-rgb), 0.70);
  font-size: 0.75rem;
  font-weight: 300;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  line-height: 1.2;
  padding-block: 10px;
  padding-inline: 20px;
  display: block;
  transition: background 0.25s ease, color 0.25s ease;
}

.suniia-header .primary-nav__menu--level-2 .primary-nav__menu-link:hover {
  background: rgba(var(--color-champagne-rgb), 0.06);
  color: var(--color-champagne);
}

/* Séparateur visuel entre items du sous-menu social */
.suniia-header .nav-social-menu .primary-nav__menu-item + .primary-nav__menu-item {
  border-top: 1px solid rgba(var(--color-champagne-rgb), 0.05);
}

@media (max-width: 74.9375rem) {
  .suniia-header .primary-nav__menu-link {
    font-size: 0.8rem;
    line-height: 1.2;
    font-weight: 300;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: rgba(var(--color-pearl-rgb), 0.85);
  }

  .suniia-header .primary-nav__menu-item {
    margin-block-end: 0;
    align-items: center;
  }

  .suniia-header .primary-nav__menu-item--has-children .primary-nav__menu-link--link,
  .suniia-header .primary-nav__menu-item--has-children .primary-nav__menu-link--nolink {
    flex-basis: auto;
  }

  .suniia-header .primary-nav__menu--level-2 {
    display: none;
  }
}

/* ── Panneau de recherche étendu ── */

/* Réinitialise le positionnement Olivero (offset -5.625rem + bande grise)
   et remplace le fond noir par glassmorphisme */
.suniia-header .block-search-wide__wrapper {
  inset-inline-start: 0;
  width: 100%;
  max-width: none;
  height: 4.5rem;
  background: rgba(var(--color-obsidian-rgb), 0.96);
  backdrop-filter: blur(20px) saturate(140%);
  -webkit-backdrop-filter: blur(20px) saturate(140%);
  border-inline-start: none;
  border-top: 1px solid rgba(var(--color-champagne-rgb), 0.08);
}

.suniia-header .block-search-wide__wrapper.is-active {
  max-height: 4.5rem;
}

/* Recentrage du contenu dans notre max-width */
.suniia-header .block-search-wide__container {
  max-width: var(--max-w-content);
  margin: 0 auto;
  padding-inline: var(--sp2);
  height: 100%;
  display: flex;
  align-items: center;
}

/* Passe la grille Olivero en flex pour éviter les variables de colonne */
.suniia-header .block-search-wide__grid {
  display: flex;
  align-items: center;
  height: 100%;
  width: 100%;
}

.suniia-header .block-search-wide__wrapper form {
  display: flex;
  align-items: center;
  width: 100%;
}

/* Champ de saisie : typographie Suniia, pas de serif Olivero */
.suniia-header .block-search-wide__wrapper input[type="search"] {
  color: var(--color-pearl);
  font-family: 'Inter', sans-serif;
  font-weight: 300;
  font-size: 1.1rem;
  letter-spacing: 0.04em;
  padding-inline-start: 0;
  height: 100%;
}

.suniia-header .block-search-wide__wrapper input[type="search"]::placeholder {
  color: rgba(var(--color-pearl-rgb), 0.30);
}

/* Remplacement de l'animation de soulignement bleue par champagne */
[dir] .suniia-header .block-search-wide__wrapper input[type="search"] {
  background-image: linear-gradient(var(--color-champagne));
}

/* Bouton ouvert : pas de fond noir Olivero */
.suniia-header .block-search-wide__button[aria-expanded="true"] {
  background: transparent;
  color: var(--color-champagne);
}

/* ── Icônes compte (connexion / déconnexion) ── */
.suniia-header .menu--account {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 0.25rem;
  margin: 0;
  padding: 0;
  list-style: none;
}

.suniia-header .menu--account .menu__item {
  margin: 0;
  padding: 0;
}

.suniia-header .menu--account .menu__link--icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  border-radius: 50%;
  color: rgba(var(--color-pearl-rgb), 0.65);
  text-decoration: none;
  transition: color 0.3s ease, background 0.3s ease;
}

.suniia-header .menu--account .menu__link--icon:hover {
  color: var(--color-champagne);
  background: rgba(var(--color-champagne-rgb), 0.06);
}

.suniia-header .menu--account .menu__link--icon svg {
  flex-shrink: 0;
  display: block;
}

/* ── Icône de recherche — Olivero applique color: near-black via currentColor ── */
.suniia-header .block-search-wide__button,
.suniia-header .block-search-wide__button svg {
  color: rgba(var(--color-pearl-rgb), 0.65) !important;
}

.suniia-header .block-search-wide__button:hover,
.suniia-header .block-search-wide__button:hover svg {
  color: var(--color-champagne) !important;
}

/* Adaptation mobile — réduction de l'espacement et de la taille */
@media (max-width: 480px) {
  .suniia-header__inner {
    padding: 0 1rem;
    gap: 0.5rem;
  }

  .suniia-header .menu a {
    font-size: 0.8rem;
  }

  .suniia-header__branding {
    gap: 0.75rem;
  }

  .suniia-header__branding .primary-nav .menu,
  .suniia-header__nav .menu {
    gap: 0.25rem;
  }
}

/* ═══════════════════════════════════════════════════════════════════
   NAVIGATION MOBILE — barre 3 colonnes + tiroir off-canvas + recherche
   Actif en dessous de 75rem (breakpoint Olivero desktop)
═══════════════════════════════════════════════════════════════════ */

/* ── Safe-area notch iPhone ── */
.suniia-header {
  padding-top: env(safe-area-inset-top);
}

/* ── Barre 3 colonnes (mobile uniquement) ── */
.suniia-mobile-bar {
  display: none; /* caché par défaut — actif uniquement sous 75rem */
  align-items: center;
  justify-content: space-between;
  width: 100%;
  max-width: var(--max-w-header);
  margin: 0 auto;
  padding: 0 1.25rem;
  min-height: 48px;
}

@media (max-width: 74.9375rem) {
  /* Masquer le header desktop, afficher la barre mobile */
  .suniia-header__inner {
    display: none;
  }

  .suniia-mobile-bar {
    display: flex;
  }
}

/* Logo centré dans la barre mobile */
.suniia-mobile-logo {
  display: flex;
  align-items: center;
}

.suniia-mobile-logo img {
  height: 32px;
  width: auto;
  display: block;
}

/* Boutons icônes de la barre mobile */
.suniia-hamburger,
.suniia-search-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  padding: 0;
  background: transparent;
  border: none;
  cursor: pointer;
  color: rgba(var(--color-pearl-rgb), 0.75);
  border-radius: 50%;
  transition: color 0.25s ease, background 0.25s ease;
}

.suniia-hamburger:hover,
.suniia-hamburger:focus-visible,
.suniia-search-btn:hover,
.suniia-search-btn:focus-visible {
  color: var(--color-champagne);
  background: rgba(var(--color-champagne-rgb), 0.06);
  outline: none;
}

/* ── Tiroir de navigation (off-canvas, glisse depuis la gauche) ── */
.suniia-drawer {
  position: fixed;
  inset-block-start: 0;
  inset-inline-start: 0;
  z-index: 200; /* au-dessus du header (100) */
  display: flex;
  flex-direction: column;
  width: min(85vw, 320px);
  height: 100%;
  padding-top: env(safe-area-inset-top);
  /* Glassmorphisme conforme au Style Guide */
  background: rgba(var(--color-obsidian-rgb), 0.96);
  backdrop-filter: blur(20px) saturate(140%);
  -webkit-backdrop-filter: blur(20px) saturate(140%);
  border-inline-end: 1px solid rgba(var(--color-champagne-rgb), 0.10);
  box-shadow: 4px 0 40px rgba(var(--color-black-rgb), 0.60);
  /* Fermé : déplacé hors écran à gauche */
  transform: translateX(-100%);
  visibility: hidden;
  transition: transform 0.28s cubic-bezier(0.25, 0.46, 0.45, 0.94),
              visibility 0.28s;
  overflow-y: auto;
  overscroll-behavior: contain;
}

/* État ouvert */
.suniia-drawer.is-open {
  transform: translateX(0);
  visibility: visible;
}

/* En-tête du tiroir : logo + bouton fermeture */
.suniia-drawer__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1rem 1.25rem;
  border-bottom: 1px solid rgba(var(--color-champagne-rgb), 0.08);
  flex-shrink: 0;
}

.suniia-drawer__logo {
  display: flex;
  align-items: center;
}

.suniia-drawer__logo img {
  height: 30px;
  width: auto;
}

.suniia-drawer__close {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  padding: 0;
  background: transparent;
  border: none;
  cursor: pointer;
  color: rgba(var(--color-pearl-rgb), 0.60);
  border-radius: 50%;
  transition: color 0.25s ease, background 0.25s ease;
}

.suniia-drawer__close:hover,
.suniia-drawer__close:focus-visible {
  color: var(--color-champagne);
  background: rgba(var(--color-champagne-rgb), 0.06);
  outline: none;
}

/* Corps du tiroir : menu principal */
.suniia-drawer__nav {
  flex: 1;
  overflow-y: auto;
  padding: 1rem 0;
}

/* Items du menu dans le tiroir */
.suniia-drawer__nav .primary-nav__menu--level-1 {
  display: flex;
  flex-direction: column;
  list-style: none;
  margin: 0;
  padding: 0;
}

.suniia-drawer__nav .primary-nav__menu-item {
  margin: 0;
  border-bottom: 1px solid rgba(var(--color-champagne-rgb), 0.05);
}

.suniia-drawer__nav .primary-nav__menu-item--has-children {
  flex-wrap: wrap;
}

.suniia-drawer__nav .primary-nav__menu-link {
  display: flex;
  align-items: center;
  min-height: 52px;
  padding: 0 1.5rem;
  font-size: 0.85rem;
  font-weight: 300;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(var(--color-pearl-rgb), 0.80);
  text-decoration: none;
  transition: color 0.2s ease, background 0.2s ease;
  line-height: 1.2;
}

.suniia-drawer__nav .primary-nav__menu-link:hover,
.suniia-drawer__nav .primary-nav__menu-link:focus-visible {
  color: var(--color-champagne);
  background: rgba(var(--color-champagne-rgb), 0.04);
}

.suniia-drawer__nav .primary-nav__menu-link--active-trail {
  color: var(--color-pearl);
  text-decoration: underline;
  text-decoration-color: rgba(var(--color-magenta-rgb), 0.65);
  text-decoration-thickness: 1px;
  text-underline-offset: 4px;
}

/* Bouton d'expansion sous-menu dans le tiroir */
.suniia-drawer__nav .primary-nav__button-toggle {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  margin-inline-start: auto;
  background: transparent;
  border: none;
  cursor: pointer;
  color: rgba(var(--color-pearl-rgb), 0.45);
  flex-shrink: 0;
  text-indent: 0;
  position: relative;
}

/* Icône +/− custom — remplace l'icône Olivero (dépend de border-color) */
.suniia-drawer__nav .primary-nav__button-toggle .icon--menu-toggle {
  display: none; /* icône Olivero masquée, on utilise ::before/::after */
}

.suniia-drawer__nav .primary-nav__button-toggle::before,
.suniia-drawer__nav .primary-nav__button-toggle::after {
  content: '';
  position: absolute;
  width: 14px;
  height: 1.5px;
  background: currentColor;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  transition: opacity 0.2s ease, transform 0.2s ease;
}

.suniia-drawer__nav .primary-nav__button-toggle::after {
  transform: translate(-50%, -50%) rotate(90deg);
}

/* État ouvert : trait horizontal reste, trait vertical disparaît → croix */
.suniia-drawer__nav .primary-nav__button-toggle[aria-expanded="true"] {
  color: var(--color-champagne);
}

.suniia-drawer__nav .primary-nav__button-toggle[aria-expanded="true"]::after {
  opacity: 0;
}

/* Sous-menu niveau 2 dans le tiroir */
.suniia-drawer__nav .primary-nav__menu--level-2 {
  display: none;
  flex-basis: 100%;
  list-style: none;
  margin: 0;
  padding: 0 0 0.5rem 0;
  background: rgba(var(--color-charcoal-rgb), 0.40);
}

.suniia-drawer__nav .primary-nav__menu--level-2.is-active-menu-parent {
  display: block;
}

.suniia-drawer__nav .primary-nav__menu--level-2 .primary-nav__menu-link {
  min-height: 44px;
  padding-inline-start: 2.5rem;
  font-size: 0.75rem;
  color: rgba(var(--color-pearl-rgb), 0.55);
  letter-spacing: 0.12em;
}

.suniia-drawer__nav .primary-nav__menu--level-2 .primary-nav__menu-link:hover {
  color: var(--color-champagne);
}

/* Masquer la flèche carotte Olivero dans le tiroir */
.suniia-drawer__nav .primary-nav__menu-🥕 {
  display: none;
}

/* Pied du tiroir : menu secondaire (lien connexion) */
.suniia-drawer__footer {
  padding: 1rem 1.25rem;
  border-top: 1px solid rgba(var(--color-champagne-rgb), 0.08);
  flex-shrink: 0;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

/* Masquer le bloc de recherche Olivero dans le tiroir — la recherche mobile
   est gérée par l'overlay dédié (#suniia-search-overlay) */
.suniia-drawer__footer #block-suniia-theme-searchform {
  display: none;
}

/* Corriger les styles Olivero du menu secondaire (secondary-nav) sur fond sombre */
.suniia-drawer__footer .secondary-nav__menu {
  flex-direction: column;
  align-items: flex-start;
  gap: 0.25rem;
}

.suniia-drawer__footer .secondary-nav__menu-item {
  width: auto;
  max-width: none;
  margin-inline-end: 0;
}

.suniia-drawer__footer .secondary-nav__menu-link {
  display: flex;
  align-items: center;
  padding: 0.55rem 0;
  color: rgba(var(--color-pearl-rgb), 0.75);
  font-size: 0.9375rem;
  font-weight: 500;
  letter-spacing: 0.02em;
  transition: color 0.2s ease;
}

/* Supprimer l'animation de soulignement Olivero — inadaptée au fond sombre */
.suniia-drawer__footer .secondary-nav__menu-link::after {
  display: none;
}

.suniia-drawer__footer .secondary-nav__menu-link:hover {
  color: var(--color-champagne);
}

/* ── Fond d'overlay (tiroir) ── */
.suniia-drawer-overlay {
  position: fixed;
  inset: 0;
  z-index: 150;
  background: rgba(var(--color-obsidian-rgb), 0.65);
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.28s ease, visibility 0.28s;
}

.suniia-drawer-overlay.is-visible {
  opacity: 1;
  visibility: visible;
}

/* ── Verrouillage du scroll quand tiroir ou recherche est ouvert ── */
body.suniia-nav-open,
body.suniia-search-open {
  position: fixed;
  width: 100%;
  overflow-y: scroll; /* maintient la largeur de la scrollbar pour éviter le décalage */
}

/* ── Recherche plein écran ── */
.suniia-search-overlay {
  position: fixed;
  inset: 0;
  z-index: 300;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 2rem 1.5rem;
  background: rgba(var(--color-obsidian-rgb), 0.95);
  backdrop-filter: blur(20px) saturate(140%);
  -webkit-backdrop-filter: blur(20px) saturate(140%);
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.25s ease, visibility 0.25s;
}

.suniia-search-overlay.is-open {
  opacity: 1;
  visibility: visible;
}

/* Bouton fermeture positionné en haut à droite */
.suniia-search-overlay__close {
  position: absolute;
  top: max(1.25rem, env(safe-area-inset-top));
  right: 1.25rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  background: transparent;
  border: none;
  cursor: pointer;
  color: rgba(var(--color-pearl-rgb), 0.55);
  border-radius: 50%;
  transition: color 0.25s ease;
}

.suniia-search-overlay__close:hover,
.suniia-search-overlay__close:focus-visible {
  color: var(--color-champagne);
  outline: none;
}

/* Zone centrale du formulaire */
.suniia-search-overlay__body {
  width: 100%;
  max-width: 560px;
}

.suniia-search-overlay__form {
  display: flex;
  align-items: center;
  gap: 0;
  border-bottom: 1px solid rgba(var(--color-champagne-rgb), 0.35);
  padding-bottom: 0.5rem;
}

/* Champ de saisie — style minimaliste, soulignement doré */
.suniia-search-overlay__input {
  flex: 1;
  background: transparent;
  border: none;
  outline: none;
  color: var(--color-pearl);
  font-family: 'Inter', sans-serif;
  font-size: clamp(1.25rem, 4vw, 1.75rem);
  font-weight: 200;
  letter-spacing: 0.04em;
  padding: 0.5rem 0;
  caret-color: var(--color-champagne);
  /* Supprime les flèches natives du type search */
  -webkit-appearance: none;
  appearance: none;
}

.suniia-search-overlay__input::placeholder {
  color: rgba(var(--color-pearl-rgb), 0.25);
}

.suniia-search-overlay__input::-webkit-search-cancel-button {
  -webkit-appearance: none;
}

/* Bouton submit (loupe) */
.suniia-search-overlay__submit {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  background: transparent;
  border: none;
  cursor: pointer;
  color: rgba(var(--color-pearl-rgb), 0.45);
  flex-shrink: 0;
  transition: color 0.25s ease;
}

.suniia-search-overlay__submit:hover,
.suniia-search-overlay__input:focus ~ .suniia-search-overlay__submit {
  color: var(--color-champagne);
}

/* Masquer le bloc site-branding dans le tiroir mobile — le logo y est déjà dans __head */
.suniia-drawer__nav .site-branding {
  display: none;
}

/* Sur desktop : masquer tiroir et barre mobile — inutiles */
@media (min-width: 75rem) {
  .suniia-mobile-bar {
    display: none;
  }

  .suniia-drawer,
  .suniia-drawer-overlay {
    display: none;
  }
}
