/*=============================================================
  ASHXPRESS — SYSTÈME DE DESIGN CORPORATE PREMIUM v2
  Pure CSS3 · Flat Design · Zero Glassmorphisme
  Refonte complète — classes/IDs originaux intouchables
  Bloc Services : flex / charte compat (tokens)
=============================================================*/


/*-----------------------------------*\
  #DESIGN TOKENS
\*-----------------------------------*/

:root {
  /* ── Couleurs Marque ── */
  --color-brand:          #e11d48;
  --color-brand-dark:     #be123c;
  --color-brand-light:    #fff1f2;

  /* ── Neutrals / Corporate ── */
  --color-ink-950:        #060b15;
  --color-ink-900:        #0f172a;
  --color-ink-800:        #1e293b;
  --color-ink-700:        #2d3a4f;
  --color-ink-600:        #334155;
  --color-ink-400:        #64748b;
  --color-ink-300:        #94a3b8;
  --color-ink-200:        #cbd5e1;
  --color-ink-100:        #e2e8f0;
  --color-ink-50:         #f1f5f9;
  --color-ink-25:         #f8fafc;

  /* ── Surfaces ── */
  --color-white:          #ffffff;
  --color-bg-page:        #f4f5f7;
  --color-bg-card:        var(--color-white);

  /* ── États Sémantiques ── */
  --color-amber:          #f59e0b;
  --color-amber-dark:     #d97706;
  --color-green:          #16a34a;
  --color-green-dark:     #15803d;
  --color-red:            #dc2626;
  --color-red-dark:       #b91c1c;
  --color-warning:        #d97706;
  --color-info:           #1d4ed8;

  /* ── Remap Compatibilité ── */
  --salmon-pink:          var(--color-brand);
  --sandy-brown:          var(--color-amber);
  --bittersweet:          var(--color-red);
  --ocean-green:          var(--color-green);
  --eerie-black:          var(--color-ink-900);
  --onyx:                 var(--color-ink-800);
  --davys-gray:           var(--color-ink-600);
  --sonic-silver:         var(--color-ink-400);
  --spanish-gray:         var(--color-ink-300);
  --cultured:             var(--color-ink-100);
  --white:                var(--color-white);

  /* ── Typographie ── */
  --fs-1:  1.563rem;
  --fs-2:  1.375rem;
  --fs-3:  1.25rem;
  --fs-4:  1.125rem;
  --fs-5:  1rem;
  --fs-6:  0.938rem;
  --fs-7:  0.875rem;
  --fs-8:  0.813rem;
  --fs-9:  0.75rem;
  --fs-10: 0.688rem;
  --fs-11: 0.625rem;

  --weight-300: 300;
  --weight-400: 400;
  --weight-500: 500;
  --weight-600: 600;
  --weight-700: 700;

  /* ── Géométrie ── */
  --border-radius-md:   10px;
  --border-radius-sm:    6px;
  --border-radius-xs:    4px;
  --border-radius-pill: 999px;

  /* ── Élévation subtile ── */
  --shadow-xs: 0 1px 3px rgba(15, 23, 42, 0.05),
               0 1px 2px rgba(15, 23, 42, 0.04);
  --shadow-sm: 0 2px 8px rgba(15, 23, 42, 0.07),
               0 1px 3px rgba(15, 23, 42, 0.05);
  --shadow-md: 0 4px 16px rgba(15, 23, 42, 0.09),
               0 2px 6px  rgba(15, 23, 42, 0.06);
  --shadow-lg: 0 12px 36px rgba(15, 23, 42, 0.12),
               0 4px 12px rgba(15, 23, 42, 0.08);

  /* ── Motion ── */
  --transition-timing: 0.22s cubic-bezier(0.4, 0, 0.2, 1);
  --transition-slow:   0.40s cubic-bezier(0.4, 0, 0.2, 1);

  /* ── Header Heights ── */
  --header-top-h:  38px;
  --header-main-h: 72px;
  --header-nav-h:  48px;
}


/*-----------------------------------*\
  #RESET
\*-----------------------------------*/

*, *::before, *::after {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

a { text-decoration: none; }
li { list-style: none; }

button {
  background: none;
  font: inherit;
  border: none;
  cursor: pointer;
}

img, ion-icon, button, a { display: block; }
span { display: inline-block; }

html {
  font-family: "Poppins", sans-serif;
  scroll-behavior: smooth;
  overscroll-behavior: contain;
}

input {
  display: block;
  width: 100%;
  font: inherit;
}

input::placeholder { font: inherit; }

body {
  background: var(--color-bg-page);
  color: var(--color-ink-800);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}


/*-----------------------------------*\
  #SCROLLBAR
\*-----------------------------------*/

body::-webkit-scrollbar { width: 7px; }
body::-webkit-scrollbar-track { background: var(--color-ink-50); }
body::-webkit-scrollbar-thumb {
  background: var(--color-ink-200);
  border-radius: var(--border-radius-pill);
  border: 2px solid var(--color-ink-50);
}
body::-webkit-scrollbar-thumb:hover { background: var(--color-ink-300); }


/*-----------------------------------*\
  #REUSED STYLE
\*-----------------------------------*/

.container { padding: 0 15px; }

.has-scrollbar { padding-bottom: 5px; }
.has-scrollbar::-webkit-scrollbar { width: 5px; height: 5px; }
.has-scrollbar::-webkit-scrollbar-thumb {
  background: transparent;
  border-radius: var(--border-radius-pill);
}
.has-scrollbar:hover::-webkit-scrollbar-thumb { background: var(--color-ink-100); }
.has-scrollbar::-webkit-scrollbar-thumb:hover { background: var(--color-ink-200); }

.title {
  color: var(--color-ink-900);
  font-size: var(--fs-6);
  font-weight: var(--weight-700);
  letter-spacing: 0.8px;
  text-transform: uppercase;
  padding-bottom: 12px;
  border-bottom: 2px solid var(--color-brand);
  margin-bottom: 28px;
}


/*-----------------------------------*\
  #OVERLAY
\*-----------------------------------*/

.overlay {
  position: fixed;
  top: 0; left: 0;
  width: 100%; height: 100vh;
  background: rgba(9, 14, 29, 0.6);
  opacity: 0;
  pointer-events: none;
  z-index: 15;
  transition: opacity var(--transition-slow);
}
.overlay.active {
  opacity: 1;
  pointer-events: all;
}


/*-----------------------------------*\
  #MODAL NEWSLETTER
\*-----------------------------------*/

.modal {
  position: fixed;
  top: 0; left: 0;
  width: 100%; height: 100vh;
  background: rgba(9, 14, 29, 0.65);
  display: flex;
  justify-content: center;
  align-items: center;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  z-index: 10;
  animation: popup 1s ease-in-out 5s forwards;
}

@keyframes popup {
  0%   { opacity: 0; visibility: hidden; pointer-events: none; }
  100% { opacity: 1; visibility: visible; pointer-events: all; }
}

.modal.closed { display: none; }

.modal-close-overlay {
  position: absolute;
  top: 0; left: 0;
  width: 100%; height: 100%;
  z-index: 1;
}

.newsletter-img { display: none; }

.modal-content {
  position: relative;
  max-width: 360px;
  margin: 20px;
  background: var(--color-white);
  border-radius: 16px;
  overflow: hidden;
  z-index: 2;
  box-shadow: var(--shadow-lg);
  animation: scaleUp 0.5s cubic-bezier(0.34, 1.56, 0.64, 1) 5s forwards;
  transform: scale(0.9);
}

@keyframes scaleUp {
  0%   { transform: scale(0.9); }
  100% { transform: scale(1); }
}

.modal-close-btn {
  position: absolute;
  top: 14px; right: 14px;
  background: var(--color-ink-100);
  color: var(--color-ink-600);
  font-size: 15px;
  padding: 6px;
  border-radius: var(--border-radius-sm);
  z-index: 3;
  transition: background var(--transition-timing), color var(--transition-timing);
}
.modal-close-btn:hover {
  background: var(--color-brand);
  color: var(--color-white);
}
.modal-close-btn ion-icon { --ionicon-stroke-width: 60px; }

.newsletter {
  padding: 44px 32px 40px;
  text-align: center;
}
.newsletter-header { margin-bottom: 22px; }

.newsletter-title {
  color: var(--color-ink-900);
  font-size: var(--fs-2);
  font-weight: var(--weight-700);
  margin-bottom: 10px;
  line-height: 1.25;
}

.newsletter-desc {
  color: var(--color-ink-400);
  font-size: var(--fs-7);
  line-height: 1.65;
}
.newsletter-desc strong {
  color: var(--color-brand);
  font-weight: var(--weight-600);
}

.email-field {
  font-size: var(--fs-7);
  color: var(--color-ink-800);
  padding: 11px 18px;
  border-radius: var(--border-radius-pill);
  border: 1.5px solid var(--color-ink-100);
  background: var(--color-ink-25);
  margin-bottom: 14px;
  transition: border-color var(--transition-timing), box-shadow var(--transition-timing);
}
.email-field:focus {
  outline: none;
  border-color: var(--color-brand);
  box-shadow: 0 0 0 3px var(--color-brand-light);
  background: var(--color-white);
}

.btn-newsletter {
  display: block;
  width: 100%;
  background: var(--color-brand);
  color: var(--color-white);
  font-size: var(--fs-7);
  font-weight: var(--weight-600);
  letter-spacing: 0.6px;
  text-transform: uppercase;
  padding: 12px 20px;
  border-radius: var(--border-radius-pill);
  transition: background var(--transition-timing), transform var(--transition-timing);
}
.btn-newsletter:hover {
  background: var(--color-brand-dark);
  transform: translateY(-1px);
}
.btn-newsletter:active { transform: translateY(0); }


/*-----------------------------------*\
  #MODAL ALERT GLOBAL
\*-----------------------------------*/

.alert-modal {
  position: fixed;
  top: 0; left: 0;
  width: 100%; height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 10000;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity 0.3s ease-in-out, visibility 0.3s ease-in-out;
}
.alert-modal.active {
  opacity: 1;
  visibility: visible;
  pointer-events: all;
}

.alert-modal-overlay {
  position: absolute;
  top: 0; left: 0;
  width: 100%; height: 100%;
  background: rgba(9, 14, 29, 0.72);
  z-index: 10001;
}

.alert-modal-container {
  position: relative;
  background: var(--color-white);
  border-radius: 14px;
  width: 90%;
  max-width: 360px;
  box-shadow: var(--shadow-lg);
  transform: scale(0.82) translateY(-40px);
  transition: transform 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
  overflow: hidden;
  z-index: 10002;
}
.alert-modal.active .alert-modal-container {
  animation: alertModalSlideIn 0.5s ease-out forwards;
}

@keyframes alertModalSlideIn {
  0%   { opacity: 0; transform: scale(0.82) translateY(-40px); }
  70%  { transform: scale(1.03) translateY(8px); }
  100% { opacity: 1; transform: scale(1) translateY(0); }
}

.alert-modal-header {
  display: flex;
  align-items: center;
  padding: 18px 20px 14px;
  color: var(--color-white);
  gap: 12px;
}

.alert-modal-icon {
  font-size: 1.5rem;
  width: 38px; height: 38px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: rgba(255,255,255,.18);
  flex-shrink: 0;
}

.alert-modal-title {
  font-size: 1rem;
  font-weight: var(--weight-700);
  flex-grow: 1;
  margin: 0;
  letter-spacing: 0.3px;
}

.alert-modal-close-btn {
  background: rgba(255,255,255,.18);
  border-radius: 50%;
  font-size: 1rem;
  color: var(--color-white);
  width: 32px; height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: background var(--transition-timing);
  flex-shrink: 0;
}
.alert-modal-close-btn:hover { background: rgba(255,255,255,.30); }

.alert-modal-body { padding: 16px 20px 20px; }

.alert-message-list { list-style: none; }

.alert-message-item {
  padding: 10px 0;
  color: var(--color-ink-700);
  font-size: var(--fs-7);
  line-height: 1.6;
  border-bottom: 1px solid var(--color-ink-100);
  display: flex;
  align-items: flex-start;
  gap: 10px;
}
.alert-message-item::before {
  content: "›";
  color: var(--color-brand);
  font-weight: var(--weight-700);
  font-size: 1.1rem;
  line-height: 1.5;
  flex-shrink: 0;
}
.alert-message-item:last-child { border-bottom: none; }

.alert-theme-success .alert-modal-header,
.success .alert-modal-header { background: var(--color-green); }
.alert-theme-error .alert-modal-header,
.error   .alert-modal-header { background: var(--color-red); }
.alert-theme-warning .alert-modal-header,
.warning .alert-modal-header { background: var(--color-warning); }
.alert-theme-info .alert-modal-header,
.info    .alert-modal-header { background: var(--color-info); }
.alert-theme-debug .alert-modal-header,
.debug   .alert-modal-header { background: var(--color-ink-400); }


/*-----------------------------------*\
  #NOTIFICATION TOAST
\*-----------------------------------*/

.notification-toast {
  position: fixed;
  bottom: 80px;
  left: 20px;
  background: var(--color-white);
  max-width: 300px;
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 14px 14px 14px 18px;
  border-radius: var(--border-radius-md);
  border-left: 4px solid var(--color-brand);
  box-shadow: var(--shadow-md);
  transform: translateX(calc(-100% - 40px));
  transition: transform var(--transition-slow);
  z-index: 5;
  animation: slideInOut 30s ease-in-out infinite;
}

@keyframes slideInOut {
  0%, 45%, 100% {
    transform: translateX(calc(-100% - 40px));
    opacity: 0;
    visibility: hidden;
  }
  50%, 95% {
    transform: translateX(0);
    opacity: 1;
    visibility: visible;
  }
}

.notification-toast.closed { display: none; }

.toast-close-btn {
  position: absolute;
  top: 8px; right: 8px;
  color: var(--color-ink-300);
  font-size: 14px;
  transition: color var(--transition-timing);
}
.toast-close-btn:hover { color: var(--color-ink-600); }
.toast-close-btn ion-icon { --ionicon-stroke-width: 50px; }

.toast-banner {
  width: 60px; height: 60px;
  border: 1px solid var(--color-ink-100);
  border-radius: var(--border-radius-sm);
  overflow: hidden;
  flex-shrink: 0;
  background: var(--color-ink-50);
}
.toast-banner img {
  width: 100%; height: 100%;
  object-fit: contain;
}

.toast-detail {
  width: calc(100% - 74px);
  padding-right: 18px;
}

.toast-message {
  font-size: var(--fs-10);
  color: var(--color-ink-300);
  text-transform: uppercase;
  letter-spacing: 0.4px;
  margin-bottom: 4px;
  font-weight: var(--weight-500);
}

.toast-title {
  font-size: var(--fs-7);
  font-weight: var(--weight-600);
  color: var(--color-ink-800);
  line-height: 1.4;
}

.toast-meta {
  font-size: var(--fs-10);
  color: var(--color-ink-300);
  margin-top: 4px;
}


/*-----------------------------------*\
  #HEADER
\*-----------------------------------*/

.header-top,
.header-user-actions,
.desktop-navigation-menu { display: none; }

/* -- Header Top Bar -- */
.header-top {
  background: var(--color-ink-900);
}

.header-top .container {
  height: var(--header-top-h);
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.header-top-actions {
  display: flex;
  align-items: center;
  gap: 8px;
}

.header-top-actions select {
  border: none;
  background: transparent;
  min-width: 80px;
  padding: 4px 0;
  font: inherit;
  color: var(--color-ink-300);
  font-size: var(--fs-10);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  cursor: pointer;
  transition: color var(--transition-timing);
}
.header-top-actions select:hover { color: var(--color-white); }
.header-top-actions select option { background: var(--color-ink-900); }

.header-alert-news {
  color: var(--color-ink-300);
  font-size: var(--fs-10);
  text-transform: uppercase;
  letter-spacing: 1.2px;
  text-align: center;
}
.header-alert-news strong,
.header-alert-news b {
  color: var(--color-brand);
  font-weight: var(--weight-600);
}

.header-social-container {
  display: flex;
  align-items: center;
  gap: 4px;
}

/* -- Header Main -- */
.header-main {
  background: var(--color-white);
  padding: 14px 0;
  border-bottom: 1px solid var(--color-ink-100);
  box-shadow: var(--shadow-xs);
  position: sticky;
  top: 0;
  z-index: 10;
}

.header-main .container {
  display: flex;
  align-items: center;
  gap: 20px;
}

.header-logo img {
  display: block;
  height: 36px;
  width: auto;
}

.header-search-container {
  flex-grow: 1;
}

.header-search-container form {
  display: flex;
  align-items: center;
  border: 1.5px solid var(--color-ink-100);
  border-radius: var(--border-radius-pill);
  background: var(--color-ink-25);
  overflow: hidden;
  transition: border-color var(--transition-timing), box-shadow var(--transition-timing);
}
.header-search-container form:focus-within {
  border-color: var(--color-brand);
  box-shadow: 0 0 0 3px var(--color-brand-light);
  background: var(--color-white);
}

.search-field {
  flex-grow: 1;
  padding: 10px 16px;
  border: none;
  background: transparent;
  font-size: var(--fs-7);
  color: var(--color-ink-800);
}
.search-field:focus { outline: none; }

.search-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 44px; height: 44px;
  background: var(--color-brand);
  color: var(--color-white);
  font-size: 18px;
  flex-shrink: 0;
  transition: background var(--transition-timing);
}
.search-btn:hover { background: var(--color-brand-dark); }

.header-user-actions {
  display: flex;
  align-items: center;
  gap: 6px;
}
.header-user-actions .action-btn { display: none; }
.header-user-actions .lang-form { display: inline; }

.action-btn {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 22px;
  color: var(--color-ink-600);
  padding: 8px;
  border-radius: var(--border-radius-sm);
  transition: color var(--transition-timing), background var(--transition-timing);
}
.action-btn:hover {
  color: var(--color-brand);
  background: var(--color-brand-light);
}

.action-btn .count {
  position: absolute;
  top: 2px; right: 2px;
  background: var(--color-brand);
  color: var(--color-white);
  font-size: 10px;
  font-weight: var(--weight-700);
  line-height: 1;
  padding: 2px 5px;
  border-radius: var(--border-radius-pill);
  min-width: 18px;
  text-align: center;
}

.lang-select {
  border: 1.5px solid var(--color-ink-100);
  background: var(--color-ink-25);
  color: var(--color-ink-600);
  font: inherit;
  font-size: var(--fs-9);
  padding: 6px 10px;
  border-radius: var(--border-radius-sm);
  cursor: pointer;
  transition: border-color var(--transition-timing);
}
.lang-select:focus { outline: none; border-color: var(--color-brand); }

/* -- Desktop Navigation -- */
.desktop-navigation-menu {
  background: var(--color-ink-900);
  border-bottom: 1px solid rgba(255,255,255,.06);
}

.desktop-navigation-menu .container {
  display: flex;
  align-items: center;
}

.desktop-menu-category-list {
  display: flex;
  justify-content: center;
  align-items: center;
}

.desktop-menu-category-list .menu-category { position: relative; }

.desktop-menu-category-list .menu-category > .menu-title {
  position: relative;
  display: block;
  color: var(--color-ink-200);
  font-size: var(--fs-9);
  font-weight: var(--weight-600);
  text-transform: uppercase;
  letter-spacing: 0.8px;
  padding: 14px 16px;
  transition: color var(--transition-timing);
}

.desktop-menu-category-list .menu-category > .menu-title::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 16px; right: 16px;
  height: 2px;
  background: var(--color-brand);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--transition-timing);
}

.desktop-menu-category-list .menu-category > .menu-title:hover { color: var(--color-white); }
.desktop-menu-category-list .menu-category > .menu-title:hover::after { transform: scaleX(1); }

/* -- Dropdown Simple -- */
.dropdown-list {
  position: absolute;
  top: 100%; left: 0;
  width: 220px;
  background: var(--color-white);
  padding: 8px 0;
  border-radius: 0 0 var(--border-radius-md) var(--border-radius-md);
  border-top: 3px solid var(--color-brand);
  box-shadow: var(--shadow-md);
  transform: translateY(12px);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity var(--transition-timing), transform var(--transition-timing), visibility var(--transition-timing);
  z-index: 5;
}
.desktop-menu-category-list .menu-category:hover > .dropdown-list {
  transform: translateY(0);
  opacity: 1;
  visibility: visible;
  pointer-events: all;
}

.dropdown-list .dropdown-item a {
  display: block;
  color: var(--color-ink-400);
  font-size: var(--fs-7);
  text-transform: capitalize;
  padding: 9px 20px;
  transition: color var(--transition-timing), background var(--transition-timing);
}
.dropdown-list .dropdown-item a:hover {
  color: var(--color-brand);
  background: var(--color-brand-light);
}

/* -- Mobile Bottom Navigation -- */
.mobile-bottom-navigation {
  background: var(--color-white);
  position: fixed;
  bottom: 0; left: 50%;
  transform: translateX(-50%);
  width: 100%;
  max-width: 500px;
  display: flex;
  justify-content: space-around;
  align-items: center;
  padding: 6px 0 8px;
  box-shadow: 0 -1px 0 var(--color-ink-100), 0 -4px 20px rgba(15,23,42,.08);
  z-index: 5;
}
.mobile-bottom-navigation .action-btn {
  font-size: 24px;
  color: var(--color-ink-600);
  padding: 8px 12px;
}
.mobile-bottom-navigation .action-btn:hover { color: var(--color-brand); background: none; }
.mobile-bottom-navigation .count {
  background: var(--color-brand);
  color: var(--color-white);
  position: absolute;
  top: 4px; right: 4px;
  font-size: 10px;
  font-weight: var(--weight-700);
  line-height: 1;
  padding: 2px 5px;
  border-radius: var(--border-radius-pill);
  min-width: 18px;
  text-align: center;
}

/* -- Mobile Menu Slide-out -- */
.mobile-navigation-menu {
  background: var(--color-ink-900);
  position: fixed;
  top: 0; left: -100%; bottom: 0;
  width: 100%; max-width: 300px;
  padding: 0;
  overflow-y: scroll;
  overscroll-behavior: contain;
  visibility: hidden;
  transition: left var(--transition-slow), visibility var(--transition-slow);
  z-index: 20;
  box-shadow: var(--shadow-lg);
}
.mobile-navigation-menu.active {
  left: 0;
  visibility: visible;
}

.menu-top {
  padding: 18px 20px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-bottom: 1px solid rgba(255,255,255,.08);
  background: var(--color-ink-950);
}
.menu-top .menu-title {
  color: var(--color-white);
  font-size: var(--fs-5);
  font-weight: var(--weight-700);
  letter-spacing: 0.5px;
  text-transform: uppercase;
}

.menu-close-btn {
  color: var(--color-ink-300);
  font-size: 22px;
  padding: 4px;
  border-radius: var(--border-radius-xs);
  transition: color var(--transition-timing), background var(--transition-timing);
}
.menu-close-btn:hover { color: var(--color-white); background: rgba(255,255,255,.08); }
.menu-close-btn ion-icon { --ionicon-stroke-width: 50px; }

.mobile-menu-category-list {
  margin-bottom: 0;
  padding: 8px 0;
}
.mobile-menu-category-list .menu-category {
  border-bottom: 1px solid rgba(255,255,255,.06);
}
.mobile-menu-category-list .menu-title {
  color: rgba(255,255,255,.8);
  font-size: var(--fs-7);
  font-weight: var(--weight-500);
  padding: 13px 20px;
  display: block;
  transition: color var(--transition-timing), background var(--transition-timing);
}
.mobile-menu-category-list .menu-category > a.menu-title:hover {
  color: var(--color-white);
  background: rgba(255,255,255,.05);
}

.menu-category .accordion-menu {
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0 20px;
}
.menu-category .accordion-menu .menu-title { padding: 13px 0; }
.accordion-menu > div { font-size: 13px; }
.accordion-menu ion-icon {
  color: var(--color-ink-300);
  --ionicon-stroke-width: 80px;
}
.accordion-menu.active .add-icon,
.accordion-menu .remove-icon { display: none; }
.accordion-menu .add-icon,
.accordion-menu.active .remove-icon { display: block; }

.accordion-menu.active .caret-back { transform: rotate(-0.25turn); }

.menu-category .submenu-category-list {
  background: rgba(0,0,0,.25);
  padding: 0 20px 0 32px;
}
.submenu-title {
  display: block;
  padding: 9px 0;
  font-size: var(--fs-8);
  color: rgba(255,255,255,.5);
  font-weight: var(--weight-400);
  border-bottom: 1px solid rgba(255,255,255,.04);
  transition: color var(--transition-timing);
}
.submenu-title:hover { color: var(--color-brand); }

.submenu-category-list {
  max-height: 0;
  overflow: hidden;
  visibility: hidden;
  transition: max-height var(--transition-slow), visibility var(--transition-slow);
}
.submenu-category-list.active {
  max-height: 300px;
  visibility: visible;
}

.menu-bottom {
  background: var(--color-ink-950);
  padding: 16px 20px 28px;
  border-top: 1px solid rgba(255,255,255,.06);
}
.menu-bottom .menu-category-list { margin-bottom: 20px; }
.menu-bottom .menu-category { border-bottom: none; }
.menu-bottom .menu-title {
  color: rgba(255,255,255,.6);
  font-size: var(--fs-8);
  font-weight: var(--weight-500);
  padding: 10px 0;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.menu-bottom .submenu-category-list {
  border: 1px solid rgba(255,255,255,.1);
  border-radius: var(--border-radius-sm);
  padding: 0 14px;
  background: rgba(0,0,0,.2);
}
.menu-bottom .submenu-category:not(:last-child) {
  border-bottom: 1px solid rgba(255,255,255,.06);
}
.menu-bottom .submenu-title {
  color: rgba(255,255,255,.45);
  border-bottom: none;
}

.menu-social-container {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 10px;
  padding-top: 16px;
}
.menu-social-container .social-link {
  background: rgba(255,255,255,.08);
  color: var(--color-ink-300);
  font-size: 20px;
  padding: 10px 14px;
  border-radius: var(--border-radius-sm);
  transition: background var(--transition-timing), color var(--transition-timing);
}
.menu-social-container .social-link:hover {
  background: var(--color-brand);
  color: var(--color-white);
}

.lang-select-mobile {
  background: rgba(255,255,255,.08);
  color: rgba(255,255,255,.75);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: var(--border-radius-sm);
  font: inherit;
  font-size: var(--fs-7);
  padding: 8px 12px;
  margin-bottom: 4px;
  cursor: pointer;
}

/* -- Sidebar Mobile (catégories) -- */
.sidebar {
  background: var(--color-white);
  position: fixed;
  top: 0; left: -100%; bottom: 0;
  width: 100%; max-width: 300px;
  overflow-y: scroll;
  overscroll-behavior: contain;
  visibility: hidden;
  transition: left var(--transition-slow), visibility var(--transition-slow);
  z-index: 20;
  box-shadow: var(--shadow-lg);
}
.sidebar.active {
  left: 0;
  visibility: visible;
}


/*-----------------------------------*\
  #BANNER
\*-----------------------------------*/

.banner { margin: 20px 0 0; }

.slider-container {
  display: flex;
  align-items: center;
  gap: 10px;
  border-radius: var(--border-radius-md);
  overflow: auto hidden;
  scroll-snap-type: inline mandatory;
  overscroll-behavior-inline: contain;
}

.slider-item {
  position: relative;
  min-width: 100%;
  max-height: 450px;
  aspect-ratio: 1 / 1;
  border-radius: var(--border-radius-md);
  overflow: hidden;
  scroll-snap-align: start;
  background: var(--color-ink-800);
}
.slider-item .banner-img {
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: right;
}
.slider-item::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(to right, rgba(9,14,29,.60) 0%, rgba(9,14,29,.15) 50%, transparent 100%);
  z-index: 1;
}

.banner-content {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  padding: 28px 24px;
  z-index: 2;
  background: linear-gradient(to top, rgba(9,14,29,.85) 0%, transparent 100%);
}

.banner-subtitle {
  color: var(--color-brand);
  font-size: var(--fs-7);
  font-weight: var(--weight-600);
  text-transform: uppercase;
  letter-spacing: 3px;
  margin-bottom: 8px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.banner-title {
  color: var(--color-white);
  font-size: var(--fs-1);
  font-weight: var(--weight-700);
  text-transform: uppercase;
  line-height: 1.1;
  margin-bottom: 10px;
}

.banner-text { display: none; }

.banner-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: var(--color-brand);
  color: var(--color-white);
  font-size: var(--fs-9);
  font-weight: var(--weight-700);
  text-transform: uppercase;
  letter-spacing: 0.8px;
  padding: 9px 22px;
  border-radius: var(--border-radius-pill);
  transition: background var(--transition-timing), transform var(--transition-timing);
}
.banner-btn:hover {
  background: var(--color-brand-dark);
  transform: translateY(-2px);
}
.banner-btn:active { transform: translateY(0); }


/*-----------------------------------*\
  #SIDEBAR DESKTOP — Catégories
\*-----------------------------------*/

.sidebar-category {
  margin-bottom: 16px;
  padding-bottom: 16px;
  border-bottom: 1px solid var(--color-ink-100);
}

.sidebar-top {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 12px;
}

.sidebar-title {
  color: var(--color-ink-900);
  font-size: var(--fs-7);
  text-transform: uppercase;
  letter-spacing: 0.8px;
  font-weight: var(--weight-700);
}

.sidebar-close-btn {
  color: var(--color-ink-400);
  font-size: 22px;
  padding: 4px;
  border-radius: var(--border-radius-xs);
  transition: color var(--transition-timing), background var(--transition-timing);
}
.sidebar-close-btn:hover { color: var(--color-brand); background: var(--color-brand-light); }
.sidebar-close-btn ion-icon { --ionicon-stroke-width: 50px; }

.sidebar-accordion-menu {
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 8px 0;
  transition: color var(--transition-timing);
}
.sidebar .menu-title-flex { display: flex; align-items: center; gap: 10px; }
.sidebar .menu-title {
  font-size: var(--fs-7);
  color: var(--color-ink-600);
  font-weight: var(--weight-500);
  transition: color var(--transition-timing);
}
.sidebar-accordion-menu:hover .menu-title { color: var(--color-brand); }
.sidebar-accordion-menu ion-icon {
  color: var(--color-ink-300);
  font-size: 13px;
  --ionicon-stroke-width: 70px;
}

.sidebar-submenu-category-list {
  border-top: 1px solid var(--color-ink-100);
  max-height: 0;
  overflow: hidden;
  visibility: hidden;
  transition: max-height var(--transition-slow), visibility var(--transition-slow);
}
.sidebar-submenu-category-list.active {
  padding: 10px 0 6px;
  max-height: 200px;
  visibility: visible;
}

.sidebar-submenu-title {
  display: flex;
  justify-content: space-between;
  align-items: center;
  color: var(--color-ink-400);
  font-size: var(--fs-8);
  padding: 5px 0 5px 4px;
  transition: color var(--transition-timing);
}
.sidebar-submenu-title:hover { color: var(--color-brand); }

.sidebar .product-name { text-transform: capitalize; }
.sidebar-accordion-menu.active .add-icon,
.sidebar-accordion-menu .remove-icon { display: none; }
.sidebar-accordion-menu .add-icon,
.sidebar-accordion-menu.active .remove-icon { display: block; }

.sidebar .showcase-heading {
  font-size: var(--fs-8);
  font-weight: var(--weight-700);
  color: var(--color-ink-900);
  text-transform: uppercase;
  letter-spacing: 0.8px;
  margin-bottom: 14px;
  padding-top: 4px;
}

.sidebar .showcase {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 8px 0;
  border-bottom: 1px solid var(--color-ink-100);
}
.sidebar .showcase:last-child { border-bottom: none; }

.sidebar .showcase-img {
  border-radius: var(--border-radius-sm);
  border: 1px solid var(--color-ink-100);
}
.sidebar .showcase-content { width: calc(100% - 90px); }
.sidebar .showcase-title {
  color: var(--color-ink-800);
  font-size: var(--fs-8);
  font-weight: var(--weight-500);
  text-transform: capitalize;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
  transition: color var(--transition-timing);
}
.sidebar .showcase-title:hover { color: var(--color-brand); }

.sidebar .showcase-rating {
  display: flex;
  align-items: center;
  color: var(--color-amber);
  font-size: 12px;
  padding: 3px 0;
  gap: 1px;
}

.sidebar .price-box {
  display: flex;
  align-items: center;
  gap: 10px;
}
.sidebar .price-box del {
  color: var(--color-ink-300);
  font-size: 12px;
}
.sidebar .price-box .price {
  font-size: var(--fs-8);
  font-weight: var(--weight-700);
  color: var(--color-ink-800);
}


/*-----------------------------------*\
  #TESTIMONIALS
\*-----------------------------------*/

.testimonials-box { margin-bottom: 50px; }

.testimonial-card {
  padding: 28px 24px;
  background: var(--color-white);
  border: 1px solid var(--color-ink-100);
  border-radius: 14px;
  text-align: center;
  margin-bottom: 24px;
  box-shadow: var(--shadow-xs);
  transition: box-shadow var(--transition-timing), transform var(--transition-timing);
}
.testimonial-card:hover {
  box-shadow: var(--shadow-sm);
  transform: translateY(-2px);
}

.testimonial-banner {
  display: block;
  margin: 0 auto 18px;
  border-radius: 50%;
  border: 3px solid var(--color-brand-light);
}

.testimonial-name {
  font-weight: var(--weight-700);
  text-transform: uppercase;
  font-size: var(--fs-9);
  letter-spacing: 0.8px;
  color: var(--color-ink-400);
  margin-bottom: 4px;
}

.testimonial-title {
  color: var(--color-brand);
  font-size: var(--fs-7);
  font-weight: var(--weight-500);
  margin-bottom: 14px;
}

.quotation-img {
  display: block;
  margin: 0 auto 10px;
  opacity: 0.15;
}

.testimonial-desc {
  max-width: 80%;
  margin: 0 auto;
  color: var(--color-ink-400);
  font-size: var(--fs-7);
  line-height: 1.7;
}


/*-----------------------------------*\
  #CTA
\*-----------------------------------*/

.cta-container {
  position: relative;
  aspect-ratio: 5 / 6;
  border-radius: var(--border-radius-md);
  overflow: hidden;
  margin-bottom: 24px;
  box-shadow: var(--shadow-sm);
}
.cta-banner {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform var(--transition-slow);
}
.cta-container:hover .cta-banner { transform: scale(1.03); }

.cta-content {
  background: var(--color-ink-900);
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: max-content;
  max-width: 85%;
  padding: 20px 24px;
  text-align: center;
  border-radius: var(--border-radius-sm);
}

.cta-content .discount {
  background: var(--color-brand);
  color: var(--color-white);
  font-size: var(--fs-9);
  font-weight: var(--weight-700);
  text-transform: uppercase;
  letter-spacing: 0.6px;
  width: max-content;
  margin: 0 auto 8px;
  padding: 3px 10px;
  border-radius: var(--border-radius-xs);
}

.cta-title {
  color: var(--color-white);
  font-size: var(--fs-5);
  font-weight: var(--weight-600);
  text-transform: capitalize;
  margin-bottom: 4px;
  line-height: 1.3;
}

.cta-text {
  color: var(--color-ink-300);
  font-size: var(--fs-8);
  margin-bottom: 10px;
}

.cta-btn {
  display: inline-block;
  font-size: var(--fs-9);
  color: var(--color-brand);
  font-weight: var(--weight-700);
  text-transform: uppercase;
  letter-spacing: 0.8px;
  border-bottom: 1px solid var(--color-brand);
  transition: color var(--transition-timing);
}
.cta-btn:hover { color: var(--color-brand-dark); }


/*-----------------------------------*\
  #SERVICE
\*-----------------------------------*/

.service {
  width: 100%;
}

.service-container {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  gap: 0;
  padding: 8px 16px;
  background: var(--color-white);
  border: 1px solid var(--color-ink-100);
  border-radius: 14px;
  box-shadow: var(--shadow-xs);
  transition: box-shadow var(--transition-timing);
}

.service-item {
  min-width: 158px;
  display: flex;
  align-items: center;
  gap: 12px;
  text-decoration: none;
  color: inherit;
  padding: 11px 12px;
  border-radius: 10px;
  transition: background var(--transition-timing);
}

.service-item:not(:last-child) {
  border-bottom: 1px solid var(--color-ink-50);
}

.service-item:hover {
  background: var(--color-ink-25);
}

@media (max-width: 1023px) {
  .service-container {
    gap: 0;
    padding: 4px 14px;
  }

  .service-item {
    padding: 13px 12px;
  }
}

.service-icon {
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  background: var(--color-brand-light);
  border-radius: 10px;
  font-size: 20px;
  color: var(--color-brand);
  transition: background var(--transition-timing), color var(--transition-timing);
}

.service-icon ion-icon { --ionicon-stroke-width: 28px; }

.service-item:hover .service-icon {
  background: var(--color-brand);
  color: var(--color-white);
}

.service-content { min-width: 0; }

.service-title {
  color: var(--color-ink-800);
  font-size: var(--fs-8);
  font-weight: var(--weight-600);
  text-transform: capitalize;
  margin-bottom: 2px;
  line-height: 1.3;
}

.service-desc {
  color: var(--color-ink-400);
  font-size: var(--fs-10);
  line-height: 1.4;
}


/*-----------------------------------*\
  #BLOG
\*-----------------------------------*/

.blog { margin-bottom: 36px; }

.blog-container {
  display: flex;
  align-items: flex-start;
  gap: 20px;
  overflow-x: auto;
  overscroll-behavior-inline: contain;
  scroll-snap-type: inline mandatory;
}

.blog-card {
  min-width: 100%;
  scroll-snap-align: start;
  background: var(--color-white);
  border-radius: var(--border-radius-md);
  overflow: hidden;
  border: 1px solid var(--color-ink-100);
  box-shadow: var(--shadow-xs);
  display: flex;
  flex-direction: column;
  transition: box-shadow var(--transition-timing), transform var(--transition-timing);
  padding: 0;
}
.blog-card:hover {
  box-shadow: var(--shadow-sm);
  transform: translateY(-2px);
}

.blog-banner {
  width: 100%;
  max-width: none;
  height: 200px;
  object-fit: cover;
  object-position: center;
  display: block;
  border-radius: var(--border-radius-md) var(--border-radius-md) 0 0;
  flex-shrink: 0;
}

/* Lien autour de l’image : pleine largeur de la carte (évite le padding erroné sur :not(.blog-banner)) */
.blog-card > a:first-child {
  display: block;
  width: 100%;
  padding: 0;
  margin: 0;
  line-height: 0;
  align-self: stretch;
}

.blog-content {
  padding: 0 16px;
}

.blog-banner-placeholder {
  width: 100% !important;
  min-height: 200px;
  height: 200px;
  border-radius: var(--border-radius-md) var(--border-radius-md) 0 0 !important;
  box-sizing: border-box;
}

.blog-category {
  display: inline-block;
  width: auto;
  color: var(--color-brand);
  font-size: var(--fs-10);
  font-weight: var(--weight-700);
  text-transform: uppercase;
  letter-spacing: 0.8px;
  margin: 14px 0 4px;
  padding: 2px 8px;
  background: var(--color-brand-light);
  border-radius: var(--border-radius-xs);
}

.blog-title {
  padding: 0;
  margin-bottom: 6px;
  color: var(--color-ink-900);
  font-size: var(--fs-6);
  font-weight: var(--weight-700);
  line-height: 1.4;
  transition: color var(--transition-timing);
}
.blog-title:hover { color: var(--color-brand); }

.blog-meta {
  padding: 0 0 16px;
  color: var(--color-ink-300);
  font-size: var(--fs-9);
  margin-top: auto;
}


/*===================================================================
  CORRECTIFS ICÔNES (card-outline / construct-outline)
===================================================================*/

ion-icon[name="card-outline"],
ion-icon[name="construct-outline"] {
  display: none !important;
  width: 0; height: 0;
  overflow: hidden;
}

.social-link:has(ion-icon[name="card-outline"])::before,
.action-btn:has(ion-icon[name="card-outline"])::before {
  font-family: "Font Awesome 6 Free";
  font-weight: 900;
  content: '\f543';
  font-size: 1.4rem;
  display: flex;
  align-items: center;
  justify-content: center;
}

.social-link:has(ion-icon[name="construct-outline"])::before,
.action-btn:has(ion-icon[name="construct-outline"])::before {
  font-family: "Font Awesome 6 Free";
  font-weight: 900;
  content: '\f084';
  font-size: 1.3rem;
  display: flex;
  align-items: center;
  justify-content: center;
}


/*===================================================================
  RESPONSIVE
===================================================================*/

/* ── > 480px ── */
@media (min-width: 480px) {
  :root { --fs-1: 1.875rem; }

  .header-top { display: block; }
  .header-social-container,
  .header-top-actions { display: none; }

  .header-alert-news {
    text-align: center;
    width: 100%;
    font-size: var(--fs-10);
    letter-spacing: 1.2px;
    text-transform: uppercase;
    color: var(--color-ink-300);
  }
  .header-alert-news strong,
  .header-alert-news b {
    color: var(--color-brand);
    font-weight: var(--weight-600);
  }

  .header-main { padding: 14px 0; }

  .mobile-bottom-navigation {
    border-top-left-radius: var(--border-radius-md);
    border-top-right-radius: var(--border-radius-md);
  }

  /* Banner */
  .slider-item { aspect-ratio: 5 / 3; }
  .banner-content {
    top: 50%; right: auto; bottom: auto; left: 0;
    width: 100%; max-width: 360px;
    transform: translateY(-50%);
    padding: 32px 36px;
    background: none;
  }
  .banner-subtitle { --fs-7: 1rem; }
  .banner-text {
    display: block;
    color: rgba(255,255,255,.85);
    font-size: var(--fs-7);
    font-weight: var(--weight-500);
    margin-bottom: 14px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }
  .banner-text b {
    color: var(--color-white);
    font-size: var(--fs-2);
    font-weight: var(--weight-700);
    display: block;
    line-height: 1.2;
  }
  .banner-btn { padding: 10px 28px; }

  /* CTA */
  .cta-content { padding: 32px 36px; }
  .cta-content .discount { padding: 5px 12px; }
  .cta-title { --fs-5: 1.5rem; }
  .cta-text  { --fs-7: 1rem; }
  .cta-btn   { --fs-9: 1rem; }
}


/* ── > 570px ── */
@media (min-width: 570px) {
  .header-top .container,
  .header-main .container {
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
  .header-logo { margin-bottom: 0; }
  .header-top-actions { display: flex; align-items: center; gap: 10px; }
  .header-top-actions select { display: block; }
  .header-search-container { min-width: 300px; }

  .slider-item { aspect-ratio: 4 / 2; }
  .banner-content { background: none; }

  .blog-container { gap: 24px; }
  .blog-card { min-width: calc(50% - 12px); }

  .cta-container { aspect-ratio: 6 / 5; }
}


/* ── > 768px ── */
@media (min-width: 768px) {
  :root { --fs-1: 2.375rem; }

  html { font-size: 17px; }

  .container { max-width: 750px; margin: auto; }

  /* Modal newsletter */
  .modal-content {
    display: flex;
    align-items: center;
    max-width: 700px;
    width: fit-content;
    border-radius: 16px;
  }
  .newsletter-img {
    display: block;
    width: 280px;
    flex-shrink: 0;
    align-self: stretch;
    overflow: hidden;
  }
  .newsletter-img img {
    width: 100%; height: 100%;
    object-fit: cover;
  }
  .newsletter { text-align: left; flex: 1; }

  .header-main .container { gap: 40px; }
  .header-search-container { flex-grow: 1; }

  .slider-item { aspect-ratio: auto; height: 340px; }
  .banner-content { max-width: 400px; }
  .banner-subtitle { --fs-7: 1.25rem; }
  .banner-text     { --fs-7: 1.125rem; }
  .banner-text b   { --fs-2: 1.875rem; }
  .banner-btn      { --fs-11: 0.75rem; }

  .product-minimal {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 20px;
  }
  .product-minimal .product-showcase {
    min-width: calc(50% - 10px);
    width: calc(50% - 10px);
  }
  .product-minimal .showcase-container { min-width: 100%; }
}


/* ── > 1024px ── */
@media (min-width: 1024px) {
  :root {
    --fs-1: 2.625rem;
    --fs-2: 1.125rem;
  }

  .container { max-width: 980px; }

  .notification-toast { bottom: 30px; }

  /* Header top complet */
  .header-top { display: block; }
  .header-top .container { justify-content: space-between; }
  .header-social-container {
    display: flex;
    align-items: center;
    gap: 4px;
  }
  .header-social-container .social-link {
    padding: 5px 8px;
    color: var(--color-ink-300);
    border-radius: var(--border-radius-xs);
    font-size: 15px;
    transition: background var(--transition-timing), color var(--transition-timing);
  }
  .header-social-container .social-link:hover {
    background: var(--color-brand);
    color: var(--color-white);
  }

  .header-user-actions {
    display: flex;
    align-items: center;
    gap: 6px;
    flex-shrink: 0;
  }
  .header-user-actions .action-btn {
    display: flex;
    align-items: center;
    justify-content: center;
  }

  .desktop-navigation-menu { display: block; }

  .mobile-bottom-navigation { display: none; }

  /* Layout produit */
  .product-container .container {
    position: relative;
    display: flex;
    align-items: flex-start;
    gap: 28px;
    margin-bottom: 28px;
  }
  .sidebar {
    --fs-5: 0.938rem;
    position: sticky;
    top: calc(var(--header-main-h) + var(--header-nav-h) + 16px);
    left: 0;
    padding: 0;
    min-width: calc(25% - 14px);
    margin-bottom: 28px;
    visibility: visible;
    overflow-y: auto;
    overscroll-behavior: auto;
    z-index: 0;
    background: transparent;
    box-shadow: none;
  }
  .sidebar-category {
    padding: 18px;
    margin-bottom: 20px;
    border: 1px solid var(--color-ink-100);
    border-radius: var(--border-radius-md);
    background: var(--color-white);
    box-shadow: var(--shadow-xs);
    padding-bottom: 18px;
  }
  .sidebar-close-btn { display: none; }
  .product-box { min-width: calc(75% - 14px); }

  .product-minimal { margin-bottom: 20px; }
  .product-minimal .product-showcase {
    min-width: calc(33.33% - 14px);
    width: calc(33.33% - 14px);
    flex-grow: 1;
  }
  .product-minimal .showcase-wrapper { gap: 10px; }
  .product-minimal .showcase-container { padding: 2px; }

  /* ─────────────────────────────────────────
     TESTIMONIAL | CTA | SERVICES — même ligne
     Grid 3 colonnes : CTA un peu plus large, Services plus étroit
  ───────────────────────────────────────── */
  .testimonials-box {
    display: grid;
    grid-template-columns: 1fr 1.88fr 1.22fr;
    grid-template-rows: 1fr;
    align-items: stretch;
    gap: 24px;
  }

  .testimonial {
    grid-column: 1;
    grid-row: 1;
    min-width: 0;
    width: auto;
    margin-bottom: 0;
  }
  .testimonial-card {
    margin-bottom: 0;
    height: 100%;
  }

  .cta-container {
    grid-column: 2;
    grid-row: 1;
    min-width: 0;
    width: auto;
    margin-bottom: 0;
    aspect-ratio: unset;
    height: 100%;
  }

  .service {
    grid-column: 3;
    grid-row: 1;
    width: auto;
    min-width: 0;
    display: flex;
    flex-direction: column;
    align-self: stretch;
    min-height: 0;
    height: 100%;
  }

  /* Même hauteur que témoignage / CTA ; items répartis sur toute la hauteur */
  .service-container {
    flex: 1 1 auto;
    min-height: 0;
    flex-direction: column;
    flex-wrap: nowrap;
    align-items: stretch;
    justify-content: space-evenly;
    gap: 0;
    padding: 10px 14px;
  }

  .service-item {
    flex: 1 1 0;
    min-width: 0;
    min-height: 0;
    width: 100%;
    gap: 12px;
    padding: 8px 10px;
    align-items: center;
    border-radius: 8px;
  }

  .service-item:not(:last-child) {
    border-bottom: 1px solid var(--color-ink-50);
  }

  .service-icon {
    width: 36px;
    height: 36px;
    font-size: 18px;
    border-radius: 8px;
  }

  /* Blog */
  .blog-card { min-width: calc(33.33% - 16px); }
  .blog-title { --fs-5: 1rem; }
}


/* ── > 1200px ── */
@media (min-width: 1200px) {
  .container { max-width: 1200px; }

  .slider-item:last-child .banner-img { object-position: top; }

  .testimonials-box {
    grid-template-columns: 1fr 2fr 1.12fr;
  }

  .blog-card { min-width: calc(25% - 18px); }
}


/* ── > 1400px ── */
@media (min-width: 1400px) {
  html { font-size: 18px; }
  .container { max-width: 1350px; }
  .slider-item { height: 420px; }
  .banner-content {
    left: 100px;
    max-width: 500px;
    padding: 40px;
  }
}