/*
 * ============================================================
 * SKIFFO — CSS Global
 * Variables · Reset · Typographie · Boutons
 * ============================================================
 */

/* ── Adobe Fonts (Degular) ── */
@import url("https://use.typekit.net/gpd0cjp.css");

/* ── Police Plein (upload dans /themes/do_fitwear/assets/fonts/) ── */
@font-face {
  font-family: 'Plein';
  src: url('/themes/do_fitwear/assets/fonts/Plein-Black.woff2') format('woff2'),
       url('/themes/do_fitwear/assets/fonts/Plein-Black.woff') format('woff');
  font-weight: 900;
  font-style: normal;
}
@font-face {
  font-family: 'Plein';
  src: url('/themes/do_fitwear/assets/fonts/Plein-Bold.woff2') format('woff2'),
       url('/themes/do_fitwear/assets/fonts/Plein-Bold.woff') format('woff');
  font-weight: 700;
  font-style: normal;
}
@font-face {
  font-family: 'Plein';
  src: url('/themes/do_fitwear/assets/fonts/Plein-Medium.woff2') format('woff2'),
       url('/themes/do_fitwear/assets/fonts/Plein-Medium.woff') format('woff');
  font-weight: 500;
  font-style: normal;
}
@font-face {
  font-family: 'Plein';
  src: url('/themes/do_fitwear/assets/fonts/Plein-Regular.woff2') format('woff2'),
       url('/themes/do_fitwear/assets/fonts/Plein-Regular.woff') format('woff');
  font-weight: 400;
  font-style: normal;
}
@font-face {
  font-family: 'Plein';
  src: url('/themes/do_fitwear/assets/fonts/Plein-Light.woff2') format('woff2'),
       url('/themes/do_fitwear/assets/fonts/Plein-Light.woff') format('woff');
  font-weight: 300;
  font-style: normal;
}

/* ── Palette Skiffo ── */
:root {
  --sand: #f4ebda;
  --teal-light: #bed9d4;
  --teal: #70a49f;
  --coral: #e86e61;
  --coral-d: #d45a4d;
  --navy: #1a2b3c;
  --offwhite: #faf8f4;
  --white: #fff;
  --text: #3c3c3c;
  --muted: #7aada9;
}

/* ── Reset ── */
*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { font-family: "degular-text", sans-serif; color: var(--text); background: var(--white); overflow-x: hidden; }
img { display: block; max-width: 100%; }
a { text-decoration: none; color: inherit; }

/* ── Override PrestaShop / Leo — supprime le padding du wrapper global homepage ── */
#content-wrapper { padding: 0 !important; }

/* ── Utilitaires typo ── */
.label {
  font-family: "degular", sans-serif;
  font-size:14px;
  font-weight: 600;
  letter-spacing: 4px;
  text-transform: uppercase;
}

/* ── Boutons ── */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: "degular", sans-serif;
  font-size:15px;
  font-weight: 600;
  letter-spacing: 2px;
  text-transform: uppercase;
  padding: 14px 32px;
  border: none;
  cursor: pointer;
  border-radius: 10px;
  transition: all .25s ease;
}
.btn-coral  { background: var(--coral); color: #fff; }
.btn-coral:hover { background: var(--coral-d); transform: translateY(-1px); }
.btn-white  { background: #fff; color: var(--teal); }
.btn-white:hover { background: var(--sand); }
.btn-outline-w { background: transparent; color: #fff; border: 1.5px solid rgba(255,255,255,.6); }
.btn-outline-w:hover { background: rgba(255,255,255,.1); border-color: #fff; }
.btn-outline-d { background: transparent; color: var(--teal); border: 1.5px solid var(--teal); }
.btn-outline-d:hover { background: var(--teal); color: #fff; }

/* ── Arrow animation ── */
.arr::after { content: '\2192'; font-size: 14px; transition: transform .2s; }
.arr:hover::after { transform: translateX(4px); }
/*
 * ============================================================
 * SKIFFO — Header, Mega Menu & Tiroir Mobile
 * ============================================================
 */

/* ── HEADER BASE ── */
/* Transparent sur hero (homepage), blanc après scroll ou sur autres pages (via .scrolled) */
    .hdr{position:fixed;top:0;left:0;right:0;z-index:900;height:72px;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;padding:0 48px;background:transparent;box-shadow:none;transition:background .4s ease,box-shadow .4s ease}
    .hdr.scrolled{background:#fff;box-shadow:0 4px 24px rgba(0,0,0,.09)}
    /* Logo : blanc sur hero transparent, couleur normale après scroll */
    .hdr-logo{height:32px;width:auto;filter:brightness(0) invert(1);transition:filter .3s ease}
    .hdr.scrolled .hdr-logo{filter:none}
    /* Nav links */
    .hdr-nav{display:flex;gap:36px;align-items:center;justify-content:center}
    .hdr-nav > a{color:rgba(255,255,255,.92);font-family:"degular",sans-serif;font-size:15px;font-weight:500;letter-spacing:1.5px;text-transform:uppercase;transition:color .2s;position:relative;text-decoration:none}
    .hdr-nav > a:hover{color:var(--coral)}
    .hdr-nav .mm-item > a{color:rgba(255,255,255,.92);font-family:"degular",sans-serif;font-size:15px;font-weight:500;letter-spacing:1.5px;text-transform:uppercase;transition:color .2s;text-decoration:none}
    .hdr-nav .mm-item > a:hover,.hdr-nav .mm-item.is-open > a{color:var(--coral)}
    .hdr.scrolled .hdr-nav > a,.hdr.scrolled .hdr-nav .mm-item > a{color:var(--text)}
    /* Droite */
    .hdr-right{display:flex;align-items:center;gap:20px;justify-self:end}
    .lang-btn{color:rgba(255,255,255,.92);font-family:"degular",sans-serif;font-size:14px;font-weight:600;letter-spacing:1.5px;cursor:pointer;transition:color .2s}
    .hdr.scrolled .lang-btn{color:var(--text)}
    .lang-btn:hover{color:var(--coral)}
    /* ── Sélecteur langue dropdown (lang-sw) ── */
    .lang-sw{position:relative}
    .lang-sw-btn{display:flex;align-items:center;gap:5px;background:none;border:none;cursor:pointer;font-family:"degular",sans-serif;font-size:14px;font-weight:600;letter-spacing:1.5px;padding:6px 8px;border-radius:6px;transition:color .2s,background .2s}
    .hdr:not(.scrolled) .lang-sw-btn{color:rgba(255,255,255,.92)}
    .hdr.scrolled .lang-sw-btn{color:var(--text)}
    .lang-sw-btn:hover{color:var(--coral);background:rgba(237,115,101,.06)}
    .lang-sw-btn svg{transition:transform .2s;color:var(--muted)}
    .lang-sw-btn[aria-expanded="true"] svg{transform:rotate(180deg)}
    .lang-sw-panel{position:absolute;top:calc(100% + 8px);right:0;background:#fff;border:1px solid rgba(106,162,158,.2);border-radius:8px;box-shadow:0 8px 32px rgba(0,0,0,.12);min-width:160px;overflow:hidden;opacity:0;pointer-events:none;transform:translateY(-6px);transition:opacity .2s,transform .2s;z-index:1000}
    .lang-sw-panel.is-open{opacity:1;pointer-events:auto;transform:translateY(0)}
    .lang-sw-opt{display:block;padding:10px 16px;font-family:"degular",sans-serif;font-size:14px;font-weight:500;color:var(--text);text-decoration:none;transition:background .15s,color .15s;letter-spacing:.5px}
    .lang-sw-opt:hover{background:rgba(106,162,158,.08);color:var(--coral)}
    .lang-sw-opt.is-active{color:var(--coral);font-weight:700;background:rgba(237,115,101,.05)}
    .lang-sw-opt.is-active::before{content:'✓ ';font-size:13px}
    .cart-btn{position:relative;width:22px;height:22px;display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.92);cursor:pointer;transition:color .2s}
    .hdr.scrolled .cart-btn{color:var(--text)}
    .cart-btn:hover{color:var(--coral)}
    .cart-n{position:absolute;top:-6px;right:-6px;background:var(--coral);color:#fff;border-radius:50%;width:16px;height:16px;display:flex;align-items:center;justify-content:center;font-family:"degular",sans-serif;font-size:12px;font-weight:700}

  /* ── Chevron dans les liens nav ────────────────────────────── */
  .mm-item {
    position: static;
    display: flex;
    align-items: center;
  }
  .mm-item > a {
    display: flex;
    align-items: center;
    gap: 5px;
  }
  .mm-chevron {
    width: 10px; height: 10px;
    transition: transform .25s ease;
    flex-shrink: 0;
  }
  .mm-item.is-open > a .mm-chevron {
    transform: rotate(180deg);
  }

  /* ── Overlay sombre ─────────────────────────────────────────── */
  .mm-overlay {
    position: fixed;
    inset: 0;
    top: 72px;
    background: rgba(10, 22, 22, .42);
    opacity: 0;
    pointer-events: none;
    transition: opacity .3s ease;
    z-index: 840;
  }
  .mm-overlay.active {
    opacity: 1;
    pointer-events: auto;
  }

  /* ── Panel principal ────────────────────────────────────────── */
  .mm-panel {
    position: fixed;
    top: 72px;
    left: 0;
    right: 0;
    background: var(--offwhite, #faf8f4);
    border-top: 3px solid var(--coral, #e86e61);
    box-shadow: 0 24px 64px rgba(0, 0, 0, .16);
    z-index: 850;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transform: translateY(-8px);
    transition: opacity .26s ease, transform .26s ease, visibility 0s .26s;
  }
  .mm-panel.is-open {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: translateY(0);
    transition: opacity .26s ease, transform .26s ease, visibility 0s 0s;
  }

  /* ── Layout interne : sidebar | produits ────────────────────── */
  .mm-inner {
    max-width: 1400px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: 150px 1fr;
    min-height: 430px;
  }

  /* ── Sidebar gauche ─────────────────────────────────────────── */
  .mm-sidebar {
    padding: 28px 16px 32px 24px;
    border-right: 1px solid rgba(106,162,158,.15);
    display: flex;
    flex-direction: column;
    gap: 2px;
  }

  .mm-sidebar-label {
    font-family: "degular", sans-serif;
    font-size:12px;
    font-weight: 700;
    letter-spacing: 3px;
    text-transform: uppercase;
    color: var(--muted, #7aada9);
    margin-bottom: 12px;
    margin-top: 0;
    display: block;
  }

  .mm-cat {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 11px 16px 11px 12px;
    border-radius: 6px;
    cursor: default;
    transition: background .18s ease;
    position: relative;
  }
  .mm-cat::after {
    content: '';
    position: absolute;
    right: -1px;
    top: 50%;
    transform: translateY(-50%);
    width: 3px;
    height: 0;
    background: var(--coral, #e86e61);
    border-radius: 2px 0 0 2px;
    transition: height .2s ease;
  }
  .mm-cat.is-active,
  .mm-cat:hover {
    background: rgba(106,162,158,.1);
  }
  .mm-cat.is-active::after {
    height: 60%;
  }

  .mm-cat-dot {
    width: 10px; height: 10px;
    border-radius: 50%;
    flex-shrink: 0;
    border: 2px solid transparent;
    transition: border-color .2s;
  }
  .mm-cat.is-active .mm-cat-dot,
  .mm-cat:hover .mm-cat-dot {
    border-color: var(--coral, #e86e61);
  }

  .mm-cat-name {
    font-family: "degular", sans-serif;
    font-size:15px;
    font-weight: 600;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    color: var(--text, #2a5754);
    transition: color .18s;
  }
  .mm-cat.is-active .mm-cat-name,
  .mm-cat:hover .mm-cat-name {
    color: var(--coral, #e86e61);
  }

  .mm-cat-count {
    margin-left: auto;
    font-family: "degular", sans-serif;
    font-size:13px;
    color: var(--muted, #7aada9);
    font-weight: 500;
  }

  /* Lien "Voir tout" en bas de sidebar */
  .mm-sidebar-cta {
    margin-top: 16px;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-family: "degular", sans-serif;
    font-size:13px;
    font-weight: 700;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    color: var(--coral, #e86e61);
    text-decoration: none;
    white-space: nowrap;
    transition: gap .2s, color .2s;
  }
  .mm-sidebar-cta:hover {
    gap: 9px;
    color: var(--coral-d, #d45a4d);
  }

  /* ── Zone produits droite ───────────────────────────────────── */
  .mm-products {
    position: relative;
    padding: 28px 24px 28px 20px;
    overflow: hidden;
  }

  /* Panel produits (un par gamme, visible/caché) */
  .mm-product-panel {
    position: absolute;
    inset: 28px 24px 28px 20px;
    opacity: 0;
    pointer-events: none;
    transform: translateX(12px);
    transition: opacity .22s ease, transform .22s ease;
    display: flex;
    flex-direction: column;
    gap: 16px;
  }
  .mm-product-panel.is-active {
    opacity: 1;
    pointer-events: auto;
    transform: translateX(0);
  }

  /* Titre du panel produit */
  .mm-panel-title {
    font-family: "degular", sans-serif;
    font-size:13px;
    font-weight: 700;
    letter-spacing: 3px;
    text-transform: uppercase;
    color: var(--muted, #7aada9);
  }

  /* Grille cartes produit */
  .mm-cards {
    display: flex;
    gap: 14px;
    flex: 1;
  }

  /* Carte individuelle */
  .mm-card {
    flex: 1;
    position: relative;
    overflow: hidden;
    border-radius: 8px;
    background: var(--teal-light, #bed9d4);
    aspect-ratio: 3/4;
    max-height: 330px;
    display: block;
    text-decoration: none;
  }
  .mm-card img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center top;
    transition: transform .5s ease;
    display: block;
  }
  .mm-card:hover img {
    transform: scale(1.07);
  }

  /* Gradient overlay */
  .mm-card-ov {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top,
      rgba(0,0,0,.72) 0%,
      rgba(0,0,0,.18) 45%,
      rgba(0,0,0,0) 70%
    );
    transition: background .3s ease;
  }
  .mm-card:hover .mm-card-ov {
    background: linear-gradient(to top,
      rgba(0,0,0,.78) 0%,
      rgba(0,0,0,.28) 55%,
      rgba(0,0,0,0) 75%
    );
  }

  /* Info texte sur la carte */
  .mm-card-info {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    padding: 16px 14px;
    color: #fff;
  }
  .mm-card-badge {
    display: inline-block;
    font-family: "degular", sans-serif;
    font-size:11px;
    font-weight: 700;
    letter-spacing: 2px;
    text-transform: uppercase;
    background: var(--coral, #e86e61);
    color: #fff;
    padding: 2px 7px;
    border-radius: 3px;
    margin-bottom: 6px;
  }
  .mm-card-name {
    display: block;
    font-family: "degular", sans-serif;
    font-size:16px;
    font-weight: 700;
    letter-spacing: .5px;
    line-height: 1.25;
    margin-bottom: 4px;
  }
  .mm-card-prices {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    margin-top: 6px;
    flex-wrap: wrap;
  }
  .mm-card-price {
    display: inline-block;
    font-family: "degular", sans-serif;
    font-size:15px;
    font-weight: 700;
    color: #fff;
    background: var(--coral, #e86e61);
    padding: 4px 10px;
    border-radius: 4px;
    letter-spacing: .5px;
  }
  .mm-card-price-old {
    display: none;
    font-family: "degular", sans-serif;
    font-size: 13px;
    font-weight: 600;
    color: rgba(255, 255, 255, 0.55);
    text-decoration: line-through;
    text-decoration-thickness: 1.5px;
    text-decoration-color: rgba(237, 115, 101, 0.85);
    letter-spacing: .3px;
  }

  /* ── Pack inclus sidebar ─────────────────────────────────────── */
  .mm-sidebar-sep {
    margin: 16px 12px 14px;
    border: none;
    border-top: 1px solid rgba(106,162,158,.2);
  }
  .mm-pack-label {
    font-family: "degular", sans-serif;
    font-size:12px;
    font-weight: 700;
    letter-spacing: 3px;
    text-transform: uppercase;
    color: var(--muted, #7aada9);
    padding-left: 0;
    margin-bottom: 12px;
    display: block;
  }
  /* Liste verticale : icône + texte sur une ligne */
  .mm-pack-list {
    display: flex;
    flex-direction: column;
    gap: 7px;
  }
  .mm-pack-row {
    display: flex;
    align-items: center;
    gap: 10px;
    cursor: default;
  }
  .mm-pack-ico-ring {
    width: 28px;
    height: 28px;
    flex-shrink: 0;
    border-radius: 50%;
    border: 1.5px solid rgba(106,162,158,.3);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--teal, #70a49f);
    transition: background .2s, border-color .2s, color .2s, transform .2s;
  }
  .mm-pack-row:hover .mm-pack-ico-ring {
    background: var(--coral, #e86e61);
    border-color: var(--coral, #e86e61);
    color: #fff;
    transform: translateY(-1px);
  }
  .mm-pack-ico-ring svg { width: 13px; height: 13px; stroke-width: 1.6; }
  .mm-pack-ico-img{width:16px;height:16px;object-fit:contain;display:block;transition:filter .2s;filter:invert(62%) sepia(22%) saturate(545%) hue-rotate(134deg) brightness(91%) contrast(85%)}
  .mm-pack-row:hover .mm-pack-ico-img{filter:brightness(0) invert(1)}
  .mm-pack-row-name {
    font-family: "degular", sans-serif;
    font-size:14px;
    font-weight: 500;
    color: var(--text, #2a5754);
    line-height: 1.2;
  }

  /* Arrow hover sur la carte */
  .mm-card-arr {
    display: flex;
    align-items: center;
    gap: 5px;
    margin-top: 8px;
    font-family: "degular", sans-serif;
    font-size:13px;
    font-weight: 600;
    letter-spacing: 1px;
    text-transform: uppercase;
    color: rgba(255,255,255,0);
    transition: color .25s ease, gap .25s ease;
  }
  .mm-card:hover .mm-card-arr {
    color: rgba(255,255,255,.85);
    gap: 8px;
  }


  /* ── Layout SUP : sidebar | produits | pack-inclus ──────────── */
  .mm-inner-sup {
    grid-template-columns: 190px 1fr 290px;
    column-gap: 0;
  }

  /* ── Colonne droite : pack inclus ────────────────────────────── */
  .mm-right-col {
    border-left: 1px solid rgba(106,162,158,.15);
    padding: 28px 20px 24px 20px;
    display: flex;
    flex-direction: column;
    gap: 0;
  }
  /* overrides right-col supprimés — styles dans mm-pack-list */
  .mm-pack-cta {
    margin-top: 16px;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-family: "degular", sans-serif;
    font-size:13px;
    font-weight: 700;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    color: var(--coral, #e86e61);
    text-decoration: none;
    transition: gap .2s, color .2s;
  }
  .mm-pack-cta:hover {
    gap: 9px;
    color: var(--coral-d, #d45a4d);
  }

  /* ── Scrollbar du panel si contenu long ────────────────────── */
  .mm-panel { max-height: calc(100vh - 72px); overflow-y: auto; }



/* ── TIROIR NAVIGATION MOBILE ── */
  /* ═══════════════════════════════════════════════════════════
     MOBILE DRAWER — tiroir de navigation latéral
  ═══════════════════════════════════════════════════════════ */
  .hdr-burger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:6px 4px;background:none;border:none;color:var(--text);flex-shrink:0}
  .hdr-burger span{display:block;width:22px;height:2px;background:currentColor;border-radius:2px;transition:transform .3s ease,opacity .3s ease,width .3s ease;transform-origin:center}
  .hdr-burger.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .hdr-burger.is-open span:nth-child(2){opacity:0;width:0}
  .hdr-burger.is-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

  .mob-drawer-overlay{position:fixed;inset:0;background:rgba(10,22,22,.55);z-index:1100;opacity:0;pointer-events:none;transition:opacity .3s ease}
  .mob-drawer-overlay.is-open{opacity:1;pointer-events:auto}

  .mob-drawer{position:fixed;top:0;left:0;bottom:0;width:320px;max-width:88vw;background:var(--offwhite);z-index:1110;transform:translateX(-100%);transition:transform .35s cubic-bezier(.4,0,.2,1);overflow-y:auto;display:flex;flex-direction:column}
  .mob-drawer.is-open{transform:translateX(0)}

  .mob-drawer-hd{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;border-bottom:1px solid rgba(106,162,158,.2);flex-shrink:0}
  .mob-drawer-logo{height:22px}
  .mob-drawer-close{width:34px;height:34px;display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;color:var(--text);border-radius:6px;transition:background .2s}
  .mob-drawer-close:hover{background:rgba(106,162,158,.12)}

  .mob-nav{flex:1;padding:8px 0}
  .mob-nav-item{border-bottom:1px solid rgba(106,162,158,.1)}
  .mob-nav-trigger{display:flex;align-items:center;justify-content:space-between;padding:15px 20px;font-family:"degular",sans-serif;font-size:15px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--text);cursor:pointer;background:none;border:none;width:100%;text-align:left;text-decoration:none;transition:color .2s}
  .mob-nav-trigger:hover{color:var(--coral)}
  .mob-nav-chevron{width:14px;height:14px;flex-shrink:0;transition:transform .25s ease;color:var(--muted)}
  .mob-nav-item.is-open .mob-nav-chevron{transform:rotate(180deg)}
  .mob-nav-item.is-open > .mob-nav-trigger{color:var(--coral)}

  .mob-accordion{max-height:0;overflow:hidden;transition:max-height .35s ease;background:rgba(106,162,158,.05)}
  .mob-nav-item.is-open .mob-accordion{max-height:600px}

  .mob-sub-label{font-family:"degular",sans-serif;font-size:12px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--muted);padding:14px 20px 6px;display:block}
  .mob-sub-link{display:flex;align-items:center;gap:10px;padding:9px 20px;font-family:"degular",sans-serif;font-size:15px;font-weight:500;color:var(--text);text-decoration:none;transition:color .2s}
  .mob-sub-link:hover{color:var(--coral)}
  .mob-sub-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
  .mob-sub-cta{display:flex;align-items:center;gap:6px;padding:10px 20px 16px;font-family:"degular",sans-serif;font-size:13px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--coral);text-decoration:none;transition:gap .2s}
  .mob-sub-cta:hover{gap:10px}

  /* ── Mini-cartes produit dans le tiroir ─────────── */
  .mob-prod-strip{display:flex;overflow-x:auto;gap:10px;padding:6px 0 18px 20px;scrollbar-width:none;-webkit-overflow-scrolling:touch}
  .mob-prod-strip::after{content:'';flex-shrink:0;width:20px}
  .mob-prod-strip::-webkit-scrollbar{display:none}
  .mob-prod-card{flex-shrink:0;width:104px;text-decoration:none;display:flex;flex-direction:column;gap:6px}
  .mob-prod-img{width:104px;height:136px;border-radius:8px;overflow:hidden;background:var(--teal-light);position:relative}
  .mob-prod-img img{width:100%;height:100%;object-fit:cover;object-position:center top;transition:transform .4s ease}
  .mob-prod-card:active .mob-prod-img img{transform:scale(1.05)}
  .mob-prod-badge{position:absolute;top:6px;left:6px;font-family:"degular",sans-serif;font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;background:var(--coral);color:#fff;padding:2px 6px;border-radius:2px}
  .mob-prod-name{font-family:"degular",sans-serif;font-size:13px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;color:var(--text)}
  .mob-prod-price{font-family:"degular",sans-serif;font-size:14px;font-weight:800;color:var(--coral)}
  .mob-prod-prices{display:flex;flex-direction:column;gap:1px}
  .mob-prod-price-old{display:none;font-family:"degular",sans-serif;font-size:12px;font-weight:500;color:#aaa;text-decoration:line-through;letter-spacing:.2px}
  /* Strip accessoires — cartes un peu plus larges */
  .mob-acc-strip{display:flex;overflow-x:auto;gap:10px;padding:6px 0 18px 20px;scrollbar-width:none;-webkit-overflow-scrolling:touch}
  .mob-acc-strip::after{content:'';flex-shrink:0;width:20px}
  .mob-acc-strip::-webkit-scrollbar{display:none}
  .mob-acc-card{flex-shrink:0;width:90px;text-decoration:none;display:flex;flex-direction:column;gap:5px}
  .mob-acc-img{width:90px;height:90px;border-radius:8px;overflow:hidden;background:var(--sand)}
  .mob-acc-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
  .mob-acc-card:active .mob-acc-img img{transform:scale(1.05)}
  .mob-acc-name{font-family:"degular",sans-serif;font-size:12px;font-weight:600;color:var(--text);line-height:1.3}

  .mob-drawer-ft{padding:18px 20px;border-top:1px solid rgba(106,162,158,.2);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
  .mob-langs{display:flex;gap:6px;flex-wrap:wrap}
  .mob-lang-btn{font-family:"degular",sans-serif;font-size:13px;font-weight:600;letter-spacing:1px;color:var(--muted);background:none;border:1px solid rgba(106,162,158,.25);cursor:pointer;padding:4px 8px;border-radius:4px;transition:color .2s,background .2s,border-color .2s}
  .mob-lang-btn.on,.mob-lang-btn:hover{color:var(--coral);background:rgba(237,115,101,.06);border-color:rgba(237,115,101,.3)}
  .mob-cart-link{position:relative;width:38px;height:38px;display:flex;align-items:center;justify-content:center;background:var(--teal);border-radius:8px;color:#fff;text-decoration:none;flex-shrink:0}
  .mob-cart-n{position:absolute;top:-4px;right:-4px;background:var(--coral);color:#fff;border-radius:50%;width:15px;height:15px;display:flex;align-items:center;justify-content:center;font-family:"degular",sans-serif;font-size:11px;font-weight:700}



/* ── Responsive tablette (≤1023px) ── */
@media (max-width:1023px){
  .hdr{padding:0 28px;grid-template-columns:auto 1fr auto}
  .hdr-nav{display:none}
  .hdr-burger{display:flex}
  .hdr-right .lang-btn{display:none}
  .mm-overlay{display:none}
}

/* ── Responsive mobile (≤767px) ── */
@media (max-width:767px){
  .hdr{height:60px;padding:0 18px}
}
/*
 * ============================================================
 * SKIFFO — Footer
 * ============================================================
 */
    /* FOOTER */
    .ftr{background:var(--teal-light);padding:72px 48px 0}
    .ftr-grid{max-width:1280px;margin:0 auto;display:grid;grid-template-columns:1.8fr 1fr 1fr 1.4fr;gap:60px;padding-bottom:60px;border-bottom:1px solid rgba(106,162,158,.25)}
    .ftr-logo{height:26px;filter:none;margin-bottom:20px}
    .ftr-brand p{font-size:14px;color:rgba(42,87,84,.7);line-height:1.7;max-width:280px;margin-bottom:28px}
    .ftr-tl{font-family:"Plein",sans-serif;font-size:17px;color:rgba(42,87,84,.35);letter-spacing:1px}
    .ftr-col h4{font-family:"degular",sans-serif;font-size:13px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--teal);margin-bottom:20px}
    .ftr-col ul{list-style:none}
    .ftr-col ul li{margin-bottom:12px}
    .ftr-col ul li a{font-size:14px;color:rgba(42,87,84,.7);transition:color .2s}
    .ftr-col ul li a:hover{color:var(--coral)}
    .ftr-nl input{width:100%;padding:12px 16px;background:rgba(255,255,255,.6);border:1px solid rgba(106,162,158,.3);color:var(--text);font-family:"degular-text",sans-serif;font-size:13px;outline:none;margin-bottom:10px}
    .ftr-nl input::placeholder{color:rgba(42,87,84,.4)}
    .ftr-nl input:focus{border-color:var(--teal)}
    .ftr-nl .btn{width:100%;justify-content:center;padding:12px}
    .ftr-bt{max-width:1280px;margin:0 auto;padding:24px 0;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px}
    .ftr-bt p{font-size:12px;color:rgba(42,87,84,.5)}
    .ftr-langs{display:flex;gap:12px}
    .flng{font-family:"degular",sans-serif;font-size:14px;font-weight:600;letter-spacing:1px;color:rgba(42,87,84,.5);cursor:pointer;transition:color .2s}
    .flng:hover,.flng.on{color:var(--coral)}
    .ftr-leg{display:flex;gap:20px}
    .ftr-leg a{font-size:11px;color:rgba(42,87,84,.45);transition:color .2s}
    .ftr-leg a:hover{color:var(--coral)}


/* ── Payment Strip ── */
    /* PAYMENT */
    .pay-strip{background:var(--offwhite);padding:18px 48px;display:flex;align-items:center;justify-content:center;gap:22px;border-top:1px solid rgba(0,0,0,.06)}
    .pay-lock{display:flex;align-items:center;gap:8px;font-family:"degular",sans-serif;font-size:14px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--muted)}
    .pay-div{width:1px;height:20px;background:rgba(0,0,0,.1)}
    .pay-ico{height:22px;opacity:.4}


/* ── Responsive tablette ── */
@media (max-width:1023px){
  .ftr{padding:56px 36px 0}
  .ftr-grid{grid-template-columns:1fr 1fr;gap:40px}
}
/* ── Responsive mobile ── */
@media (max-width:767px){
  .ftr{padding:44px 24px 0}
  .ftr-grid{grid-template-columns:1fr;gap:28px}
  .pay-strip{padding:14px 20px;flex-wrap:wrap;gap:12px}
}

/* ════════════════════════════════════════════════════════
   SKIFFO — Newsletter · Section parente (data-id 12f0834)
   Consolidé depuis Elementor → Section → Advanced > Custom CSS
   ════════════════════════════════════════════════════════ */
.elementor-element-12f0834 {
  background-color: var(--coral) !important;
  padding: 56px 64px !important;
  position: relative;
  overflow: hidden;
}
/* Coquillage décoratif — haut droite */
.elementor-element-12f0834::before {
  content: '';
  position: absolute;
  top: -24px;
  right: -24px;
  width: 200px;
  height: 200px;
  background-image: url('/themes/do_fitwear/assets/img/icons/coquillage-2.svg');
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;
  opacity: 0.18;
  pointer-events: none;
  transform: rotate(20deg);
}
/* Étoile de mer décorative — bas gauche */
.elementor-element-12f0834::after {
  content: '';
  position: absolute;
  bottom: -18px;
  left: -18px;
  width: 130px;
  height: 130px;
  background-image: url('/themes/do_fitwear/assets/img/icons/starfish.svg');
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;
  opacity: 0.15;
  pointer-events: none;
  transform: rotate(-25deg);
}
@media (max-width: 640px) {
  .elementor-element-12f0834 {
    padding: 36px 24px !important;
  }
  .elementor-element-12f0834::before {
    width: 130px;
    height: 130px;
    top: -16px;
    right: -16px;
  }
  .elementor-element-12f0834::after {
    width: 90px;
    height: 90px;
  }
}

/*
 * ============================================================
 * SKIFFO — Hero Slider (Homepage)
 * ============================================================
 */
    /* HERO */
    /* margin-top négatif pour remonter le hero derrière le header fixe transparent */
    .hero{position:relative;height:104dvh;min-height:680px;overflow:hidden;margin-top:-72px}
    .slides-wrap{display:flex;height:100%;transition:transform .9s cubic-bezier(.77,0,.175,1);will-change:transform}
    .slide{position:relative;min-width:100%;height:100%;overflow:hidden}
    .slide img{width:100%;height:100%;object-fit:cover;transform:scale(1.06);transition:transform 8s ease}
    .slide.on img{transform:scale(1)}
    /* Overlay allégé (opacité réduite pour laisser transparaître l'image) */
    .slide-ov{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(0,0,0,.30) 0%,rgba(0,0,0,0) 18%),linear-gradient(to right,rgba(0,0,0,.38) 0%,rgba(0,0,0,0) 55%)}
    .slide-txt{position:absolute;bottom:14%;left:10%;max-width:620px;color:#fff;z-index:10}
    .slide-lbl{color:var(--teal-light);margin-bottom:18px;display:block}
    .slide-h{font-family:"Plein",sans-serif;font-size:clamp(44px,5.5vw,72px);color:#fff;line-height:.95;margin-bottom:20px;font-weight:700}
    /* Titre slide vidéo : 2 phrases longues → taille réduite pour tenir sur 2 lignes */
    /* Titre vidéo : "Born to paddle." doit tenir sur 1 ligne → taille réduite */
    .slide-h--video{font-size:clamp(28px,3.2vw,46px);line-height:1.05}
    .slide-sub{font-size:16px;color:rgba(255,255,255,.76);font-weight:300;line-height:1.65;margin-bottom:36px}
    .slide-ctas{display:flex;gap:14px;flex-wrap:wrap}
    .hero-dots{position:absolute;bottom:72px;left:10%;display:flex;gap:8px;z-index:10}
    .dot{width:28px;height:2px;background:rgba(255,255,255,.32);cursor:pointer;transition:all .3s}
    .dot.on{background:var(--coral);width:52px}
    .hero-arrows{position:absolute;bottom:64px;right:8%;display:flex;gap:12px;z-index:10}
    .arr-btn{width:52px;height:52px;border:2px solid rgba(255,255,255,.65);background:rgba(255,255,255,.12);color:#fff;display:flex;align-items:center;justify-content:center;font-size:20px;cursor:pointer;border-radius:10px;transition:all .25s;backdrop-filter:blur(4px)}
    .arr-btn:hover{background:rgba(255,255,255,.28);border-color:#fff;transform:scale(1.06)}
    .hero-ctr{position:absolute;top:50%;right:8%;transform:translateY(-50%);color:rgba(255,255,255,.75);font-family:"degular",sans-serif;font-size:14px;font-weight:600;letter-spacing:3px;writing-mode:vertical-rl}
    .hero-ctr span{color:#fff;font-weight:700}

/* ── Slide Vidéo YouTube — iframe en fond ── */
.slide--video .slide-iframe-wrap{position:absolute;inset:0;overflow:hidden;z-index:1}

/* Desktop : vidéo 16:9 — couvre le slide en horizontal, sans bandes noires */
/*
 * Technique : aspect-ratio:16/9 garantit que YouTube remplit son conteneur
 * sans letterbox. width:max(100%, 184.89dvh) = max(largeur container, 104dvh×16÷9)
 * assure que l'iframe couvre toujours le hero quelle que soit la proportion
 * d'écran (16:9, 16:10, 21:9, format portrait tablette > 768px…).
 */
.slide-iframe-wrap--desk iframe{
  position:absolute;
  aspect-ratio:16/9;
  width:max(100%, 184.89dvh); /* 104dvh × (16÷9) — dimension pilote */
  top:50%; left:50%;
  transform:translate(-50%,-50%);
  pointer-events:none; border:none;
}

/* ── Fix hero vidéo — desktop 16:9 (override avec dimensions explicites) ── */
.slide-iframe-wrap--desk { display: block !important; }
.slide-iframe-wrap--desk iframe {
  position: absolute;
  max-width: none !important;
  width: max(100vw, 185vh) !important;
  height: max(56.25vw, 104vh) !important;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  pointer-events: none; border: none;
}

/* Fallback image mobile — visible derrière l'iframe si autoplay bloqué */
.slide--video-fallback{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;display:none}

/* Mobile : vidéo 9:16 — masquée par défaut, affichée sur mobile */
.slide-iframe-wrap--mob{display:none}

/* ── Fix hero vidéo — mobile 9:16 (override avec dimensions explicites) ── */
.slide-iframe-wrap--mob iframe {
  position: absolute;
  max-width: none !important;
  width: max(56.25vh, 100vw) !important;
  height: max(177.78vw, 100vh) !important;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  pointer-events: none; border: none;
}

@media(max-width:767px){
  .slide--video-fallback{display:block}  /* toujours visible en fond sur mobile */
  .slide-iframe-wrap--desk{display:none}
  .slide-iframe-wrap--mob{display:block;position:absolute;inset:0;overflow:hidden;z-index:2}
}

/* Overlay vidéo : liseré sombre en haut uniquement pour lisibilité du header — rien sur la vidéo */
.slide-ov--video{
  background:
    linear-gradient(to bottom, rgba(0,0,0,.38) 0%, rgba(0,0,0,0) 14%);
  z-index:2
}
.slide--video .slide-txt{z-index:10}


/* ── Responsive mobile ── */
@media (max-width:767px){
  .slide-txt{bottom:16%;left:5%;right:5%;max-width:100%}
  .slide-h{font-size:clamp(32px,9vw,46px)}
  .slide-h--video{font-size:clamp(24px,6.5vw,34px)}
  .slide-sub{font-size:13px;line-height:1.55;margin-bottom:20px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
  .slide-ctas{flex-direction:column;gap:10px}
  .slide-ctas .btn{width:100%;justify-content:center;padding:13px 24px}
  .hero-dots{left:5%;bottom:52px}
  .hero-arrows{right:5%;bottom:46px}
  .hero-ctr{display:none}
  .arr-btn{width:40px;height:40px;font-size:15px}
}
/*
 * ============================================================
 * SKIFFO — Bandeau Réassurance / USP Strip
 * ============================================================
 */
    /* REASSURANCE */
    .reas{background:var(--teal)}
    .reas-grid{display:grid;grid-template-columns:repeat(3,1fr);max-width:1100px;margin:0 auto}
    .reas-item{display:flex;align-items:center;gap:20px;padding:26px 40px;border-right:1px solid rgba(255,255,255,.18)}
    .reas-item:last-child{border-right:none}
    .r-ico{width:38px;height:38px;flex-shrink:0;color:var(--teal-light)}
    .r-ico svg{width:100%;height:100%}
    .r-txt h4{font-family:"degular",sans-serif;font-size:16px;font-weight:700;color:#fff;margin-bottom:3px}
    .r-txt p{font-size:12px;color:rgba(255,255,255,.45)}


/* ── Responsive mobile ── */
@media (max-width:767px){
  .reas-grid{grid-template-columns:1fr}
  .reas-item{border-right:none;border-bottom:1px solid rgba(255,255,255,.15);padding:18px 24px}
  .reas-item:last-child{border-bottom:none}
}
/*
 * ============================================================
 * SKIFFO — Sections Gamme (Collector & Rivage)
 * CSS partagé — utilisé dans 05-home-gamme-collector
 * et 06-home-gamme-rivage
 * ============================================================
 */
    /* GAMME SECTIONS */
    .gamme{display:grid;min-height:640px;max-height:900px;align-items:stretch;overflow:hidden}
    .g-collector{grid-template-columns:1fr 1fr}
    .g-rivage{grid-template-columns:1fr 1fr}
    .g-photo{position:relative;overflow:hidden}
    .g-photo img{width:100%;height:100%;object-fit:cover;object-position:center top;transition:transform 6s ease}
    .gamme:hover .g-photo img{transform:scale(1.04)}
    .g-photo-ov{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.70) 0%,rgba(0,0,0,0) 60%)}
    .g-photo-txt{position:absolute;bottom:30px;left:0;right:0;padding:32px 36px;color:#fff}
    .g-tag{display:inline-block;font-family:"degular",sans-serif;font-size:13px;font-weight:700;letter-spacing:3px;text-transform:uppercase;padding:6px 14px;margin-bottom:14px}
    .g-tag-c{background:var(--coral);color:#fff}
    .g-tag-t{background:var(--teal);color:#fff}
    .g-photo-h{font-family:"degular",sans-serif;font-size:clamp(25px,2.5vw,35px);font-weight:800;color:#fff;line-height:1.15;margin-bottom:10px}
    .g-photo-p{font-size:13px;color:rgba(255,255,255,.68);margin-bottom:24px;line-height:1.6}
    .g-carousel-wrap{display:flex;flex-direction:column;justify-content:center;overflow-x:hidden;overflow-y:visible}
    .g-carousel-wrap.light{background:var(--offwhite)}
    .g-carousel-wrap.dark{background:var(--teal)}
    .g-carousel-hd{padding:40px 52px 8px;display:flex;justify-content:space-between;align-items:flex-end}
    .g-carousel-hd .label{margin-bottom:10px;display:block}
    .g-carousel-hd-left{display:flex;flex-direction:column}
    .g-carousel-hd-arrows{display:flex;gap:8px;align-items:center;padding-bottom:4px;flex-shrink:0}
    .g-carousel-hd.light .label{color:var(--coral)}
    .g-carousel-hd.dark .label{color:var(--teal-light)}
    .g-carousel-hd h2{font-family:"degular",sans-serif;font-size:clamp(27px,3vw,41px);font-weight:800;line-height:1.1}
    .g-carousel-hd.light h2{color:var(--teal)}
    .g-carousel-hd.dark h2{color:#fff}
    .g-carousel{display:flex;overflow-x:auto;scroll-snap-type:x mandatory;scrollbar-width:none;padding:0 52px 44px;gap:20px}
    .g-carousel::-webkit-scrollbar{display:none}
    .g-rivage .g-carousel{flex-direction:row-reverse}
    .p-card{scroll-snap-align:start;flex-shrink:0;width:calc(50% - 10px);background:#fff;overflow:hidden;border-radius:10px;box-shadow:0 4px 24px rgba(106,162,158,.15);transition:box-shadow .3s,transform .3s;cursor:pointer}
    .p-card:hover{box-shadow:0 12px 48px rgba(106,162,158,.28);transform:translateY(-4px)}
    .p-img{position:relative;aspect-ratio:1/1;overflow:hidden}
    .p-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
    .p-card:hover .p-img img{transform:scale(1.05)}
    .p-bdg{position:absolute;top:14px;left:14px;font-family:"degular",sans-serif;font-size:12px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;padding:5px 12px;color:#fff}
    .bdg-c{background:var(--coral)}
    .bdg-t{background:var(--teal)}
    .p-dots{position:absolute;bottom:14px;right:14px;display:flex;gap:5px}
    .cdot{width:20px;height:20px;border-radius:50%;border:2.5px solid #fff;box-shadow:0 1px 4px rgba(0,0,0,.25)}
    .p-body{padding:22px 24px 26px}
    .p-name{font-family:"degular",sans-serif;font-size:20px;font-weight:800;color:var(--text);margin-bottom:4px}
    .p-sub{font-size:12px;color:var(--muted);margin-bottom:18px;letter-spacing:.3px}
    .p-foot{display:flex;align-items:center;justify-content:space-between}
    .p-price{font-family:"degular",sans-serif;font-size:27px;font-weight:800;color:var(--coral)}
    .p-price-old{font-family:"degular",sans-serif;font-size:17px;font-weight:500;color:var(--muted);text-decoration:line-through;line-height:1.2;align-self:center}
    .p-price-note{font-size:11px;font-weight:400;color:var(--muted);display:block;margin-top:-2px}
    .btn-p{font-family:"degular",sans-serif;font-size:13px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;padding:10px 18px;background:var(--coral);color:#fff;border:none;cursor:pointer;border-radius:10px;transition:background .2s}
    .btn-p:hover{background:var(--coral-d)}
    .c-ctrl{display:flex;gap:10px;padding:0 52px 28px}
    .c-btn{width:40px;height:40px;border:1.5px solid;background:none;display:flex;align-items:center;justify-content:center;font-size:16px;cursor:pointer;border-radius:10px;transition:all .2s}
    .c-btn.light{border-color:var(--teal);color:var(--teal)}
    .c-btn.light:hover{background:var(--teal);color:#fff}
    .c-btn.dark{border-color:rgba(255,255,255,.4);color:#fff}
    .c-btn.dark:hover{background:var(--coral);border-color:var(--coral)}


    /* ACCESSOIRES PICTOS — 1 ligne, tooltip coral au survol */
    .acc-section{padding:16px 52px 28px;border-top:1px solid rgba(106,162,158,.15);position:relative;z-index:10;overflow:visible}
    .acc-hd{padding:0 0 12px;display:flex;align-items:baseline;gap:12px}
    .acc-hd-title{font-family:"degular",sans-serif;font-size:15px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--teal)}
    .acc-hd-sub{font-size:12px;color:var(--muted)}
    .acc-grid{display:flex;justify-content:space-between;align-items:center;gap:4px;overflow:visible}
    .acc-item{position:relative;display:flex;align-items:center;justify-content:center;z-index:10;overflow:visible}
    .acc-item:hover{z-index:20}
    .acc-circle{width:58px;height:58px;border-radius:50%;border:1.5px solid var(--teal-light);display:flex;align-items:center;justify-content:center;color:var(--teal);transition:background .25s,color .25s,border-color .25s,transform .25s;cursor:default}
    .acc-item:hover .acc-circle{background:var(--coral);color:#fff;border-color:var(--coral);transform:translateY(-3px)}
    .acc-circle svg{width:26px;height:26px;stroke-width:1.5}
    /* Icône CSS mask (technique partagée Collector + Rivage) */
    .acc-icon{display:block;width:28px;height:28px;background-color:var(--teal);-webkit-mask-image:var(--icon);mask-image:var(--icon);-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;-webkit-mask-position:center;mask-position:center;-webkit-mask-size:contain;mask-size:contain;transition:background-color .22s}
    .acc-item:hover .acc-icon{background-color:#fff}
    .acc-lbl{position:absolute;bottom:calc(100% + 14px);left:50%;transform:translateX(-50%) translateY(4px);background:var(--text);color:#fff;font-family:"degular",sans-serif;font-size:14px;font-weight:600;white-space:nowrap;padding:6px 12px;letter-spacing:.2px;opacity:0;pointer-events:none;transition:opacity .2s,transform .2s;z-index:30}
    .acc-lbl::after{content:'';position:absolute;top:100%;left:50%;transform:translateX(-50%);border:5px solid transparent;border-top-color:var(--text)}
    .acc-item:hover .acc-lbl{opacity:1;transform:translateX(-50%) translateY(0)}


/* ── Responsive tablette ── */
@media (max-width:1023px){
  .g-carousel-hd{padding:28px 32px 12px}
  .g-carousel{padding:0 32px 32px}
  .c-ctrl{padding:0 32px 20px}
  .acc-section{padding:12px 32px 20px}
}
/* ── Responsive mobile ── */
@media (max-width:767px){
  .gamme{grid-template-columns:1fr !important;min-height:unset;max-height:unset}
  .g-photo{min-height:320px;max-height:420px}
  /* overflow:visible — évite que overflow-x:hidden coerce overflow-y:auto
     et clippe les contenus de .acc-section (notamment les cercles) */
  .g-carousel-wrap{order:2;overflow:visible}
  .g-photo{order:1}
  .g-rivage .g-carousel-wrap{order:2}
  .g-rivage .g-photo{order:1}
  .g-carousel-hd{padding:24px 24px 10px;flex-direction:column;align-items:flex-start;gap:12px}
  .g-carousel-hd-arrows{align-self:flex-end}
  .g-carousel{padding:0 0 24px 0;gap:14px}
  .g-carousel::after{content:'';flex-shrink:0;width:20px}
  .g-carousel > .p-card:first-child{margin-left:5%}
  .g-rivage .g-carousel{flex-direction:row}
  .p-card{width:min(72vw, 280px)}
  .c-ctrl{display:none}
  .acc-section{padding:12px 16px 24px;overflow:visible}
  .acc-grid{gap:0;flex-wrap:nowrap;justify-content:space-evenly;align-items:center;overflow:visible}
  /* flex:1 + position:relative — zone de tap uniforme, pas de flex-direction:column */
  .acc-item{flex:1;min-width:0;position:relative;display:flex;align-items:center;justify-content:center}
  .acc-circle{width:40px;height:40px}
  .acc-circle svg{width:18px;height:18px}
  .acc-icon{width:20px;height:20px}
  .acc-item.active .acc-icon{background-color:#fff}
  /* Bulle sous le cercle — position:absolute ne perturbe pas l'alignement des autres */
  .acc-lbl{position:absolute;top:calc(100% + 8px);bottom:auto;left:50%;transform:translateX(-50%);background:var(--navy,#1a2b3c);color:#fff;font-family:"degular",sans-serif;font-size:12px;font-weight:600;white-space:nowrap;padding:4px 9px;letter-spacing:.2px;opacity:0;pointer-events:none;transition:opacity .18s;z-index:50}
  .acc-lbl::after{content:'';position:absolute;bottom:100%;top:auto;left:50%;transform:translateX(-50%);border:4px solid transparent;border-bottom-color:var(--navy,#1a2b3c);border-top-color:transparent}
  .acc-item.active .acc-lbl{opacity:1}
  .acc-item.active .acc-circle{background:var(--coral);color:#fff;border-color:var(--coral);transform:translateY(-3px)}
}

/* ─── Fix hauteur colonne photo — chaîne flex Elementor ────────────────
   Structure réelle Leo Fitwear (Elementor classique) :
   .elementor-column > .elementor-column-wrap > .elementor-widget-wrap
   Le ">" (enfant direct) ratait .elementor-column-wrap intermédiaire.
   ─────────────────────────────────────────────────────────────────── */
#gamme-collector .elementor-row {
  display: flex !important;
  align-items: stretch !important;
}
#gamme-collector .elementor-column:first-child {
  align-self: stretch !important;
  display: flex !important;
  flex-direction: column !important;
}
#gamme-collector .elementor-column:first-child > .elementor-column-wrap {
  flex: 1 1 auto !important;
  display: flex !important;
  flex-direction: column !important;
}
#gamme-collector .elementor-column:first-child .elementor-widget-wrap {
  flex: 1 1 auto !important;
  display: flex !important;
  flex-direction: column !important;
}
#gamme-collector .elementor-column:first-child .elementor-widget,
#gamme-collector .elementor-column:first-child .elementor-widget-container {
  flex: 1 !important;
  display: flex !important;
  flex-direction: column !important;
}
#gamme-collector .g-photo {
  flex: 1 1 auto !important;
  min-height: 0 !important;
}

/* ── Colonne droite : espace absorbé PAR LE HAUT (padding-top dynamique) ────
   Structure Elementor réelle (multi-widgets dans la colonne droite) :
     .elementor-widget-wrap  ← flex container (colonne)
       ├── .elementor-widget  (widget HTML → .g-carousel-hd)    → flex:1, contenu en bas
       ├── .elementor-widget  (widget Leo Products → cartes)    → hauteur naturelle
       └── .elementor-widget  (widget HTML → .acc-section)      → hauteur naturelle
   L'espace vide monte dans le widget header → le titre descend visuellement
   vers les cartes produits, comme un padding-top qui grandit.
   ─────────────────────────────────────────────────────────────────────────── */
#gamme-collector .elementor-column:last-child .elementor-widget-wrap {
  display: flex !important;
  flex-direction: column !important;
}
/* Widget header → grandit et pousse son contenu vers le bas */
#gamme-collector .elementor-column:last-child .elementor-widget:has(.g-carousel-hd) {
  flex: 1 1 auto !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: flex-end !important;
}
/* Couche .elementor-widget-container du header → reste à sa taille naturelle */
#gamme-collector .elementor-column:last-child .elementor-widget:has(.g-carousel-hd) .elementor-widget-container {
  flex: 0 0 auto !important;
}
/* Widget Leo Products → hauteur naturelle (ne grandit pas) */
#gamme-collector .elementor-column:last-child .elementor-widget:not(:has(.g-carousel-hd)):not(:has(.acc-section)) {
  flex: 0 0 auto !important;
  overflow: visible !important;
}
/* Widget accessoires → hauteur naturelle */
#gamme-collector .elementor-column:last-child .elementor-widget:has(.acc-section) {
  flex: 0 0 auto !important;
}

/* ── Widget Header Collector — overrides spécifiques (ex Elementor Custom CSS) ── */
#gamme-collector .g-carousel-hd {
  padding: 28px 40px 14px;
  background: var(--offwhite);
  flex-direction: column;
  align-items: flex-start;
  text-align: left;
}
#gamme-collector .g-carousel-hd .label {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 3px;
  color: var(--coral);
  margin-bottom: 8px;
  text-align: left;
}
#gamme-collector .g-carousel-hd h2 {
  font-size: clamp(22px, 2.8vw, 36px);
  color: var(--teal);
  text-align: left;
  margin: 0;
}

/* ══════════════════════════════════════════════════════════════════
   SLICK-LIST padding — air pour l'ombre portée + hover translateY
   ══════════════════════════════════════════════════════════════════ */
#gamme-collector .slick-list,
#gamme-rivage .slick-list {
  padding: 10px 4px 10px !important;
}

/* ══════════════════════════════════════════════════════════════════
   OMBRE CAROUSEL — Neutralise les box-shadow/border du wrapper Slick
   Leo applique ces styles en mode carousel mais pas en mode grid
   ══════════════════════════════════════════════════════════════════ */
.elementor-LeoProductCarousel-wrapper,
.elementor-slick-slider {
  box-shadow: none !important;
  border: none !important;
  background: transparent !important;
}
.slick-slider,
.slick-list,
.slick-track {
  box-shadow: none !important;
  border: none !important;
}
.slick-slide,
.item.slick-slide {
  box-shadow: none !important;
  border: none !important;
  background: transparent !important;
}

/* ══════════════════════════════════════════════════════════════════
   FIX HAUTEUR COLONNES — Section #gamme-rivage
   Colonnes inversées vs Collector : carousel à gauche, photo à droite
   Colonne :first-child = carousel / :last-child = photo
   ══════════════════════════════════════════════════════════════════ */
#gamme-rivage .elementor-row {
  display: flex !important;
  align-items: stretch !important;
}
#gamme-rivage .elementor-column:last-child {
  align-self: stretch !important;
  display: flex !important;
  flex-direction: column !important;
}
#gamme-rivage .elementor-column:last-child > .elementor-column-wrap {
  flex: 1 1 auto !important;
  display: flex !important;
  flex-direction: column !important;
}
#gamme-rivage .elementor-column:last-child .elementor-widget-wrap {
  flex: 1 1 auto !important;
  display: flex !important;
  flex-direction: column !important;
}
#gamme-rivage .elementor-column:last-child .elementor-widget,
#gamme-rivage .elementor-column:last-child .elementor-widget-container {
  flex: 1 !important;
  display: flex !important;
  flex-direction: column !important;
}
#gamme-rivage .g-photo {
  flex: 1 1 auto !important;
  min-height: 0 !important;
}
#gamme-rivage .elementor-column:first-child .elementor-widget-wrap {
  display: flex !important;
  flex-direction: column !important;
}
#gamme-rivage .elementor-column:first-child .elementor-widget:has(.g-carousel-hd) {
  flex: 1 1 auto !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: flex-end !important;
}
#gamme-rivage .elementor-column:first-child .elementor-widget:has(.g-carousel-hd) .elementor-widget-container {
  flex: 0 0 auto !important;
}
#gamme-rivage .elementor-column:first-child .elementor-widget:not(:has(.g-carousel-hd)):not(:has(.acc-section)) {
  flex: 0 0 auto !important;
  overflow: visible !important;
}
#gamme-rivage .elementor-column:first-child .elementor-widget:has(.acc-section) {
  flex: 0 0 auto !important;
}

/* ══════════════════════════════════════════════════════════════════
   SLICK DOTS — DA Skiffo
   Spécificité renforcée pour écraser le thème Leo
   Dot inactif : cercle contour --teal (8×8px)
   Dot actif   : pill plein --coral   (22×8px)
   ══════════════════════════════════════════════════════════════════ */
ul.slick-dots {
  list-style: none !important;
  margin: 0 !important;
  padding: 10px 0 8px !important;
  display: flex !important;
  gap: 7px !important;
  justify-content: center !important;
  align-items: center !important;
  position: static !important;
  bottom: auto !important;
}
ul.slick-dots li {
  width: auto !important;
  height: auto !important;
  margin: 0 !important;
}
ul.slick-dots li button {
  width: 8px !important;
  height: 8px !important;
  padding: 0 !important;
  font-size: 0 !important;
  line-height: 0 !important;
  color: transparent !important;
  background: transparent !important;
  border: 2px solid var(--teal, #70a49f) !important;
  border-radius: 50% !important;
  cursor: pointer !important;
  display: block !important;
  transition: background .25s, border-color .25s, width .25s, border-radius .25s !important;
  overflow: hidden !important;
}
ul.slick-dots li button::before,
ul.slick-dots li button:before {
  content: '' !important;
  display: block !important;
  width: 0 !important;
  height: 0 !important;
  font-size: 0 !important;
  opacity: 0 !important;
  visibility: hidden !important;
  position: static !important;
}
ul.slick-dots li.slick-active button {
  width: 22px !important;
  background: var(--coral, #e86e61) !important;
  border-color: var(--coral, #e86e61) !important;
  border-radius: 4px !important;
}
.g-carousel-wrap.dark ul.slick-dots li button {
  border-color: rgba(255,255,255,.5) !important;
}
.g-carousel-wrap.dark ul.slick-dots li.slick-active button {
  background: var(--coral, #e86e61) !important;
  border-color: var(--coral, #e86e61) !important;
}

/* ══════════════════════════════════════════════════════════════════
   FIX BOUTON CARD — empêche .btn-p de disparaître à fenêtre étroite
   ══════════════════════════════════════════════════════════════════ */
    .btn-p{flex-shrink:0 !important;white-space:nowrap !important}
    .p-price,.p-price-old{flex-shrink:1 !important;min-width:0 !important}
@media (max-width:480px) {
  .p-foot { flex-direction: column !important; align-items: flex-start !important; gap: 12px !important; }
  .btn-p  { width: 100% !important; justify-content: center !important; }
}

/*
 * ============================================================
 * SKIFFO — Section Pack Accessoires (fond navy)
 * ============================================================
 */
    /* PACK */
    .pack{position:relative;overflow:hidden;background:#70a49f}
    .pack-bg{position:absolute;inset:0}
    .pack-bg img{width:100%;height:100%;object-fit:cover;opacity:.35}
    .pack-in{position:relative;z-index:2;max-width:1280px;margin:0 auto;padding:100px 48px}
    .pack-hd{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:64px}
    .pack-hd-l .label{color:var(--teal-light);margin-bottom:16px;display:block}
    .pack-hd-l h2{font-family:"degular",sans-serif;font-size:clamp(35px,4vw,55px);font-weight:800;color:#fff;line-height:1.1;max-width:480px}
    .pack-hd-r p{font-size:15px;color:rgba(255,255,255,.55);max-width:300px;line-height:1.7;text-align:right}
    .pack-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2px}
    .pack-it{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);padding:36px 28px;transition:background .25s}
    .pack-it:hover{background:rgba(255,255,255,.1)}
    .pack-ico{width:30px;height:30px;color:var(--teal-light);margin-bottom:20px}
    .pack-ico svg{width:100%;height:100%}
    .pack-it h3{font-family:"degular",sans-serif;font-size:17px;font-weight:700;color:#fff;margin-bottom:8px}
    .pack-it p{font-size:12px;color:rgba(255,255,255,.45);line-height:1.6}
    .pack-ft{margin-top:48px;padding-top:48px;border-top:1px solid rgba(255,255,255,.25);display:flex;align-items:center;justify-content:space-between}
    .pack-cta-t{font-family:"degular",sans-serif;font-size:clamp(21px,2.5vw,31px);font-weight:700;color:#fff}
    .pack-cta-t span{color:var(--coral)}


/* ── Responsive tablette ── */
@media (max-width:1023px){
  .pack-in{padding:72px 36px}
  .pack-grid{grid-template-columns:repeat(2,1fr)}
}
/* ── Responsive mobile ── */
@media (max-width:767px){
  .pack-in{padding:52px 18px}
  .pack-hd{flex-direction:column;gap:14px;margin-bottom:32px}
  .pack-hd-r p{text-align:left}
  .pack-grid{grid-template-columns:1fr 1fr;gap:2px}
  .pack-it{padding:24px 18px}
  .pack-ft{flex-direction:column;align-items:flex-start;gap:16px;padding-top:32px;margin-top:32px}
}
/*
 * ============================================================
 * SKIFFO — Section Pack Complet Mosaïque (fond offwhite)
 * Hauteur : min(760px, 100vh - 60px) — toujours dans l'écran
 * CTA en bas colonne droite · Responsive mobile inclus
 * ============================================================
 */
    /* ── Structure globale ── */
    .pack2{background:var(--offwhite);padding:5% 7%;display:flex;align-items:center;justify-content:center;box-sizing:border-box}
    .pack2-inner{width:100%;display:grid;grid-template-columns:1fr 1fr;gap:0}
    /* ── Colonne gauche : mosaïque ── */
    .pack2-left{display:flex;flex-direction:column}
    .pack2-mosaic{width:100%;aspect-ratio:1/1.05;max-height:700px;display:grid;grid-template-columns:2.8fr 1fr 1fr;grid-template-rows:1fr 1fr 1fr 1fr 1fr;gap:5px;border-radius:6px;overflow:hidden}
    .pm{overflow:hidden}
    .pm img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s ease}
    .pm:hover img{transform:scale(1.05)}
    .pm1{grid-column:1;grid-row:1/6}.pm1 img{transition:opacity .45s ease,transform .6s ease}
    .pm2{grid-column:2/4;grid-row:1/2}
    .pm3{grid-column:2;grid-row:2/3}
    .pm4{grid-column:3;grid-row:2/3}
    .pm5{grid-column:2/4;grid-row:3/4}
    .pm6{grid-column:2;grid-row:4/6}
    .pm7{grid-column:3;grid-row:4/5}
    .pm8{grid-column:3;grid-row:5/6}
    /* ── Colonne droite : header + liste + CTA ── */
    .pack2-right{display:flex;flex-direction:column;padding:0 0 0 52px;justify-content:space-between}
    .pack2-hd{margin-bottom:16px;flex-shrink:0}
    .pack2-label{color:var(--coral);display:block;margin-bottom:10px;font-size:14px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;font-family:"degular",sans-serif}
    .pack2-hd h3{font-family:"degular",sans-serif;font-size:clamp(23px,2.2vw,33px);font-weight:800;color:var(--text);line-height:1.1}
    .pack2-list{list-style:none;display:flex;flex-direction:column;gap:3px;margin:0;padding:0}
    .pack2-item{display:flex;align-items:center;gap:12px;padding:7px 12px;cursor:pointer;transition:background .2s,border-color .2s;border:1px solid rgba(42,87,84,.1);border-radius:8px;background:transparent}
    .pack2-item:hover{background:rgba(237,115,101,.06);border-color:rgba(237,115,101,.3)}
    .pack2-item.active{background:rgba(237,115,101,.1);border-color:var(--coral)}
    .pack2-item.active .pack2-ico{background:var(--coral);border-color:var(--coral)}
    .pack2-ico{width:34px;height:34px;flex-shrink:0;border-radius:50%;border:1.5px solid rgba(42,87,84,.2);display:flex;align-items:center;justify-content:center;color:var(--teal);transition:background .2s,border-color .2s,color .2s}
    .pack2-ico svg{width:15px;height:15px;stroke-width:1.5}
    .pack2-item-txt{flex:1;min-width:0}
    .pack2-item-txt strong{display:block;font-family:"degular",sans-serif;font-size:15px;font-weight:700;color:var(--text);margin-bottom:1px}
    .pack2-item-txt span{font-size:11px;color:var(--muted)}
    .pack2-arr{color:rgba(42,87,84,.2);font-size:13px;transition:color .2s;flex-shrink:0}
    .pack2-item:hover .pack2-arr,.pack2-item.active .pack2-arr{color:var(--coral)}
    /* ── Icône CSS mask (même système que acc-section) ── */
    .pack2-icon-mask{display:block;width:16px;height:16px;background-color:var(--teal);-webkit-mask-image:var(--icon);mask-image:var(--icon);-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;-webkit-mask-position:center;mask-position:center;-webkit-mask-size:contain;mask-size:contain;transition:background-color .2s}
    .pack2-item.active .pack2-icon-mask{background-color:#fff}
    /* ── Footer : livraison + CTA ── */
    .pack2-ft{flex-shrink:0;padding-top:16px;margin-top:12px;border-top:1px solid rgba(42,87,84,.1);display:flex;align-items:center;justify-content:space-between;gap:16px}
    .pack2-ft-txt{font-size:12px;color:var(--muted);line-height:1.4;margin:0}
    .pack2-btn{display:inline-flex;align-items:center;gap:10px;letter-spacing:.08em;flex-shrink:0}
/* ── Responsive tablette ── */
@media(max-width:1024px){
  .pack2{padding:5%}
  .pack2-right{padding:0 0 0 32px}
  .pack2-hd h3{font-size:22px}
}
/* ── Responsive mobile ── */
@media(max-width:767px){
  .pack2{padding:32px 20px}
  .pack2-inner{grid-template-columns:1fr;height:auto;gap:0}
  .pack2-left{height:260px;margin-bottom:0}
  .pack2-mosaic{grid-template-columns:1fr;grid-template-rows:1fr;border-radius:12px 12px 0 0}
  .pm{display:none}
  .pm1{display:block;grid-column:1;grid-row:1}
  .pack2-right{padding:24px 0 0 0;height:auto}
  .pack2-hd{margin-bottom:14px}
  .pack2-hd h3{font-size:24px}
  .pack2-list{overflow:visible;gap:6px}
  .pack2-item{padding:10px 14px}
  .pack2-ico{width:38px;height:38px}
  .pack2-icon-mask{width:18px;height:18px}
  .pack2-item-txt strong{font-size:13px}
  .pack2-item-txt span{font-size:12px}
  .pack2-ft{padding-top:20px;margin-top:16px;flex-direction:column;align-items:flex-start;gap:12px}
  .pack2-btn{width:100%;justify-content:center}
}


/* ── image hover sur cards produit ── */
    /* IMAGE SURVOL sur cards produits */
    .p-img-hover{position:absolute;inset:0;opacity:0;transition:opacity .5s ease;z-index:2}
    .p-img-hover img{width:100%;height:100%;object-fit:cover}
    .p-card:hover .p-img-hover{opacity:1}
    .p-bdg{z-index:3}
    .p-dots{z-index:3}


/*
 * ============================================================
 * SKIFFO — Lifestyle Banner + Brand Story
 * ============================================================
 */
    /* LIFESTYLE BANNER */
    .lf-banner{position:relative;height:68vh;min-height:460px;overflow:hidden;display:flex;align-items:center;justify-content:center}
    .lf-banner img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 35%}
    .lf-ov{position:absolute;inset:0;background:rgba(106,162,158,.52)}
    .lf-txt{position:relative;z-index:2;text-align:center;padding:0 40px}
    .lf-txt .big{font-family:"Plein",sans-serif;font-size:clamp(52px,9vw,120px);color:#fff;line-height:.92;text-shadow:0 2px 40px rgba(0,0,0,.28);font-weight:700}
    .lf-txt .big em{color:var(--coral);font-style:normal}
    .lf-txt p{margin-top:28px;font-size:16px;color:rgba(255,255,255,.7);font-weight:300;letter-spacing:.5px}

    /* BRAND */
    .brand{background:var(--sand);display:grid;grid-template-columns:1fr 1fr;min-height:540px}
    .brand-ph{overflow:hidden}
    .brand-ph img{width:100%;height:100%;object-fit:cover;transition:transform 6s ease}
    .brand:hover .brand-ph img{transform:scale(1.04)}
    .brand-tx{display:flex;flex-direction:column;justify-content:center;padding:80px 72px}
    .brand-tx .label{color:var(--teal);margin-bottom:20px;display:block}
    .brand-tx h2{font-family:"Plein",sans-serif;font-size:clamp(36px,4vw,56px);color:var(--teal);line-height:1;margin-bottom:28px;font-weight:700}
    .brand-tx h2 span{color:var(--coral)}
    .brand-tx p{font-size:16px;color:var(--muted);line-height:1.8;margin-bottom:14px;max-width:420px}
    .brand-tx .btn{margin-top:16px}


/*
 * ============================================================
 * SKIFFO — Section 08 · Story immersive (plein écran)
 * ============================================================
 */
    /* STORY — conteneur principal */
    .story{position:relative;height:100vh;min-height:680px;overflow:hidden;display:flex;align-items:center}
    .story-bg{position:absolute;inset:0}
    /* Image : commence zoomée → dézoom lent déclenché par IntersectionObserver (effet plongée) */
    .story-bg img{width:100%;height:100%;object-fit:cover;object-position:center center;transform:scale(1.08);transition:transform 10s cubic-bezier(.25,.46,.45,.94);will-change:transform}
    .story.is-visible .story-bg img{transform:scale(1)}
    /* Overlay directionnel — zone droite plus sombre pour lisibilité texte */
    .story-ov{position:absolute;inset:0;background:linear-gradient(to right,rgba(0,0,0,.04) 20%,rgba(0,0,0,.58) 58%,rgba(0,0,0,.22) 100%)}
    .story-in{position:relative;z-index:2;width:100%;padding:0 15% 0 7%;display:flex;justify-content:flex-end}
    /* Bloc texte — animation entrée (fade + slide) */
    .story-txt{max-width:500px;opacity:0;transform:translateY(28px);transition:opacity .9s ease .25s,transform .9s ease .25s}
    .story.is-visible .story-txt{opacity:1;transform:translateY(0)}
    /* Label — classe dédiée (.story-label) pour éviter collision avec .label global */
    .story-label{font-family:"degular",sans-serif;font-size:14px;font-weight:600;letter-spacing:4px;text-transform:uppercase;color:var(--teal-light);margin-bottom:20px;display:block}
    .story-txt h2{font-family:"Plein",sans-serif;font-size:clamp(50px,6.5vw,86px);color:#fff;line-height:.92;margin-bottom:26px;font-weight:700}
    .story-txt h2 em{color:var(--coral);font-style:normal}
    .story-txt p{font-size:16px;color:rgba(255,255,255,.68);line-height:1.78;margin-bottom:38px;font-weight:300;max-width:400px}
    .story-txt .btn{display:inline-flex;align-items:center}
/* ── Responsive tablette (≤1023px) ── */
@media(max-width:1023px){
  .story-in{padding:0 10% 0 7%}
  .story-txt{max-width:440px}
}
/* ── Responsive mobile (≤767px) ── */
@media(max-width:767px){
  .story{height:100svh;min-height:560px}
  .story-ov{background:rgba(0,0,0,.52)}
  .story-in{justify-content:center;padding:0 28px}
  .story-txt{max-width:100%;text-align:center}
  .story-txt h2{font-size:clamp(40px,11vw,62px)}
  .story-txt p{max-width:100%}
  .story-txt .btn{width:100%;justify-content:center}
}


/*
 * ============================================================
 * SKIFFO — Section 09 · Avis Clients (polaroid slider)
 * ============================================================
 */
    /* ═══ AVIS CLIENTS ═══ */
    .reviews{position:relative;overflow:hidden;padding:110px 0 80px}
    .reviews-bg{position:absolute;inset:0}
    /* Ken Burns au scroll — déclenché par IntersectionObserver */
    .reviews-bg img{width:100%;height:100%;object-fit:cover;object-position:center 55%;transform:scale(1.06);transition:transform 10s cubic-bezier(.25,.46,.45,.94);will-change:transform}
    .reviews.is-visible .reviews-bg img{transform:scale(1)}
    .reviews-ov{position:absolute;inset:0;background:rgba(20,36,52,.78)}
    .reviews-in{position:relative;z-index:2}
    .reviews-hd{text-align:center;padding:0 48px;margin-bottom:60px}
    /* Label dédié — évite collision avec .label global */
    .reviews-label{font-family:"degular",sans-serif;font-size:14px;font-weight:600;letter-spacing:4px;text-transform:uppercase;color:var(--teal-light);margin-bottom:16px;display:block}
    .reviews-hd h2{font-family:"Plein",sans-serif;font-size:clamp(38px,5vw,64px);color:#fff;line-height:.95;font-weight:700}
    .reviews-hd h2 em{color:var(--coral);font-style:normal}
    .reviews-hd p{margin-top:16px;font-size:15px;color:rgba(255,255,255,.5);font-weight:300;letter-spacing:.3px}
    /* Slider */
    .reviews-slider-outer{overflow:hidden;width:100%}
    .reviews-slider{display:flex;gap:36px;overflow-x:auto;scroll-snap-type:x proximity;scrollbar-width:none;padding:40px 7% 50px;cursor:grab;scroll-behavior:smooth;-webkit-overflow-scrolling:touch}
    .reviews-slider::-webkit-scrollbar{display:none}
    .reviews-slider.dragging{cursor:grabbing;user-select:none;scroll-behavior:auto}
    /* Polaroid */
    .rev-card{scroll-snap-align:center;flex-shrink:0;width:290px;background:#fff;padding:13px 13px 44px;box-shadow:0 28px 70px rgba(0,0,0,.5);transition:transform .4s cubic-bezier(.25,.46,.45,.94),box-shadow .4s ease;will-change:transform}
    .rev-card:nth-child(1){transform:rotate(-2.2deg)}
    .rev-card:nth-child(2){transform:rotate(1.8deg)}
    .rev-card:nth-child(3){transform:rotate(-1.2deg)}
    .rev-card:nth-child(4){transform:rotate(2.4deg)}
    .rev-card:nth-child(5){transform:rotate(-1.8deg)}
    .rev-card:nth-child(6){transform:rotate(1.4deg)}
    .rev-card:nth-child(7){transform:rotate(-2deg)}
    .rev-card:nth-child(8){transform:rotate(1.6deg)}
    .rev-card:hover{transform:rotate(0deg) translateY(-12px)!important;box-shadow:0 40px 90px rgba(0,0,0,.55)}
    .rev-photo{aspect-ratio:1/1;overflow:hidden;margin-bottom:18px;background:var(--sand)}
    .rev-photo img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
    .rev-card:hover .rev-photo img{transform:scale(1.05)}
    .rev-stars{display:flex;gap:3px;margin-bottom:10px}
    .rev-star svg{width:14px;height:14px;fill:var(--coral)}
    .rev-quote{font-size:13px;color:#333;line-height:1.72;font-style:italic;margin-bottom:14px;position:relative;padding-left:18px}
    .rev-quote::before{content:'\201C';position:absolute;left:0;top:-4px;font-size:31px;line-height:1;color:var(--coral);font-style:normal;font-family:"degular",sans-serif}
    .rev-name{font-family:"degular",sans-serif;font-size:15px;font-weight:700;color:var(--text);letter-spacing:.3px}
    .rev-detail{font-size:11px;color:var(--muted);margin-top:3px}
    .rev-prod{display:inline-block;margin-top:9px;font-size:13px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--coral);font-family:"degular",sans-serif;border-top:1px solid rgba(237,115,101,.2);padding-top:9px;width:100%}
    /* Barre de progression scroll */
    .reviews-progress{padding:0 7%;margin-top:4px}
    .rev-track{height:3px;background:rgba(255,255,255,.15);border-radius:2px;overflow:hidden;cursor:pointer}
    .rev-fill{height:100%;background:var(--coral);border-radius:2px;width:0%;transition:width .12s linear;pointer-events:none}
    .rev-hint{text-align:center;margin-top:18px;font-family:"degular",sans-serif;font-size:13px;font-weight:600;letter-spacing:3px;text-transform:uppercase;color:rgba(255,255,255,.3);display:flex;align-items:center;justify-content:center;gap:14px}
    .rev-hint::before,.rev-hint::after{content:'';display:block;width:32px;height:1px;background:rgba(255,255,255,.15)}
/* ── Responsive tablette (≤1023px) ── */
@media(max-width:1023px){
  .reviews{padding:80px 0 60px}
  .reviews-hd{padding:0 32px;margin-bottom:44px}
  .reviews-slider{padding:30px 5% 40px;gap:24px}
  .reviews-progress{padding:0 5%}
}
/* ── Responsive mobile (≤767px) ── */
@media(max-width:767px){
  .reviews{padding:64px 0 48px}
  .reviews-hd{padding:0 20px;margin-bottom:36px}
  .rev-card{width:248px;padding:10px 10px 36px}
  .reviews-slider{gap:18px;padding:24px 5% 36px}
  /* Désactive les rotations polaroid sur mobile — lisibilité */
  .rev-card:nth-child(n){transform:rotate(0deg)}
  .rev-card:hover{transform:translateY(-6px)!important}
  .rev-hint{display:none}
}


/*
 * ============================================================
 * SKIFFO — Section 10 · Instagram Feed (grille statique)
 * ============================================================
 */
    /* ═══ INSTAGRAM FEED ═══ */
    .insta{background:var(--offwhite);padding:90px 0 0}
    .insta-hd{text-align:center;margin-bottom:44px;padding:0 48px}
    /* Label dédié — évite collision avec .label global */
    .insta-label{font-family:"degular",sans-serif;font-size:14px;font-weight:600;letter-spacing:4px;text-transform:uppercase;color:var(--teal);margin-bottom:14px;display:block}
    .insta-hd h2{font-family:"degular",sans-serif;font-size:clamp(27px,3vw,39px);font-weight:800;color:var(--text);line-height:1.1}
    .insta-hd p{font-size:15px;color:var(--muted);margin-top:10px;font-weight:300}
    /* Handle @skiffo_sup */
    .insta-handle{display:inline-flex;align-items:center;gap:10px;margin-top:22px;font-family:"degular",sans-serif;font-size:16px;font-weight:600;color:var(--teal);border:1.5px solid var(--teal-light);padding:11px 26px;border-radius:10px;transition:all .25s}
    .insta-handle:hover{background:var(--teal);color:#fff;border-color:var(--teal)}
    .insta-handle svg{width:17px;height:17px;flex-shrink:0}
    /* Grille 6×2 */
    .insta-grid{display:grid;grid-template-columns:repeat(6,1fr);grid-template-rows:repeat(2,1fr);gap:4px;width:100%}
    /* Item = <a> cliquable */
    .insta-item{position:relative;aspect-ratio:1/1;overflow:hidden;cursor:pointer;display:block}
    .insta-item img{width:100%;height:100%;object-fit:cover;transition:transform .6s cubic-bezier(.25,.46,.45,.94)}
    .insta-item:hover img{transform:scale(1.09)}
    .insta-ov{position:absolute;inset:0;background:rgba(26,43,60,.58);opacity:0;transition:opacity .3s;display:flex;align-items:center;justify-content:center;gap:20px}
    .insta-item:hover .insta-ov{opacity:1}
    .insta-stat{color:#fff;display:flex;align-items:center;gap:5px;font-family:"degular",sans-serif;font-size:16px;font-weight:700}
    .insta-stat svg{width:18px;height:18px;stroke:#fff;fill:none;stroke-width:2}
/* ── Responsive tablette (≤1023px) — 4 colonnes, 3 rangées ── */
@media(max-width:1023px){
  .insta{padding:72px 0 0}
  .insta-hd{padding:0 32px;margin-bottom:36px}
  .insta-grid{grid-template-columns:repeat(4,1fr);grid-template-rows:repeat(3,1fr)}
}
/* ── Responsive mobile (≤767px) — 3 colonnes, overlay discret ── */
@media(max-width:767px){
  .insta{padding:56px 0 0}
  .insta-hd{padding:0 20px;margin-bottom:28px}
  .insta-hd h2{font-size:clamp(22px,7vw,30px)}
  .insta-handle{padding:10px 20px;font-size:12px}
  .insta-grid{grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(4,1fr);gap:3px}
  /* Overlay léger permanent — signale la cliquabilité sur touch */
  .insta-ov{background:rgba(26,43,60,.18);opacity:1}
  /* Stats masquées — illisibles en 3 colonnes */
  .insta-stat{display:none}
}


/*
 * ============================================================
 * SKIFFO — Product List Cards
 * Layout : product-list-skiffo (Leo Elements)
 * Zones  : product-image · product-meta
 * ============================================================
 */

/* ── Gap entre les cards (colonnes Bootstrap Leo) ── */
[class*="col-"]:has(.sk-card-img) {
  padding: 10px !important;
}

/* ── Card wrapper ── */
.product-miniature:has(.sk-card-img) {
  background: #fff;
  border-radius: 10px;
  overflow: hidden;
  box-shadow: 0 4px 24px rgba(106,162,158,.15);
  transition: box-shadow .3s, transform .3s;
  display: flex !important;
  flex-direction: column;
  padding: 0 !important;
  height: 100%;
}
.product-miniature:has(.sk-card-img):hover {
  box-shadow: 0 12px 48px rgba(106,162,158,.28);
  transform: translateY(-4px);
}

/* Reset padding zones Leo */
.product-miniature:has(.sk-card-img) .thumbnail-container,
.product-miniature:has(.sk-card-img) .product-description {
  padding: 0 !important;
  margin: 0 !important;
  border: none !important;
}

/* ── Zone image ── */
.sk-card-img {
  position: relative;
  aspect-ratio: 1 / 1;
  overflow: hidden;
  display: block;
}
.sk-card-img > a {
  display: block;
  width: 100%;
  height: 100%;
  position: relative;
}
img.sk-img-main {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .6s ease;
  display: block;
  position: relative;
  z-index: 1;
}
.sk-card-img:hover img.sk-img-main {
  transform: scale(1.04);
}

/* Image hover (2e photo au survol) */
.sk-img-hover {
  position: absolute !important;
  inset: 0;
  opacity: 0;
  transition: opacity .45s ease;
  z-index: 2;
  pointer-events: none;
}
.sk-img-hover img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.sk-card-img:hover .sk-img-hover {
  opacity: 1;
}

/* Badge remise — haut droite */
.sk-badge {
  position: absolute;
  top: 14px;
  right: 14px;
  z-index: 3;
  font-family: "degular", sans-serif;
  font-size:12px;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  padding: 5px 12px;
  color: #fff;
  background: var(--coral, #e86e61);
  border-radius: 0;
  line-height: 1.2;
  white-space: nowrap;
}

/* ── Zone meta ── */
.sk-card-meta {
  padding: 20px 22px 22px;
  flex: 1;
  display: flex;
  flex-direction: column;
}
.sk-card-meta > a.sk-name-link {
  text-decoration: none;
  color: inherit;
  display: block;
}
.sk-pname {
  font-family: "degular", sans-serif;
  font-size:19px;
  font-weight: 800;
  color: var(--text, #3c3c3c);
  margin-bottom: 4px;
  line-height: 1.2;
}
.sk-psub {
  font-size: 12px;
  color: var(--muted, #7aada9);
  margin-bottom: 16px;
  letter-spacing: .3px;
  line-height: 1.4;
}
.sk-pfoot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-top: auto;
}
.sk-price-row {
  display: flex;
  align-items: baseline;
  gap: 8px;
}
.sk-price {
  font-family: "degular", sans-serif;
  font-size:23px;
  font-weight: 800;
  color: var(--coral, #e86e61);
  line-height: 1;
}
.sk-price-old {
  font-family: "degular", sans-serif;
  font-size:16px;
  font-weight: 500;
  color: var(--muted, #7aada9);
  text-decoration: line-through;
  line-height: 1.2;
}

/* ── CTA bouton ── */
.sk-cta {
  font-family: "degular", sans-serif;
  font-size:13px;
  font-weight: 700;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  padding: 9px 16px;
  background: var(--coral, #e86e61);
  color: #fff !important;
  border: none;
  border-radius: 8px;
  text-decoration: none !important;
  display: inline-flex;
  align-items: center;
  gap: 5px;
  transition: background .2s;
  white-space: nowrap;
  flex-shrink: 0;
}
.sk-cta:hover {
  background: var(--coral-d, #d45a4d);
  color: #fff !important;
}

/* ── Responsive product list ── */
@media (max-width: 767px) {
  [class*="col-"]:has(.sk-card-img) { padding: 6px !important; }
  .sk-pname  { font-size: 14px; }
  .sk-price  { font-size: 18px; }
  .sk-card-meta { padding: 16px 16px 18px; }
  .sk-cta    { padding: 8px 12px; font-size: 9px; }
}


/*
 * ============================================================
 * SKIFFO — Overrides cartes produit Leo Elements
 * Section Gamme (colonne droite — Leo Product List)
 * Cible : classes natives PrestaShop/Leo Fitwear
 * Scope : uniquement dans .g-collector / .g-rivage
 * ============================================================
 */

/* ── Wrapper colonne droite ── */
.g-collector .leo-products-wrapper,
.g-collector .products-grid,
.g-collector [class*="leonetwork"],
.g-rivage .leo-products-wrapper,
.g-rivage .products-grid,
.g-rivage [class*="leonetwork"] {
  padding: 0 !important;
  background: transparent !important;
}

/* ── En-tête natif Leo ── */
.g-collector .leo-product-list-title,
.g-collector .block_title,
.g-collector .h4.block-title,
.g-rivage .leo-product-list-title,
.g-rivage .block_title,
.g-rivage .h4.block-title {
  font-family: "Plein", sans-serif !important;
  font-size: clamp(26px, 3.2vw, 40px) !important;
  font-weight: 700 !important;
  color: var(--navy, #1a2b3c) !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
  margin-bottom: 8px !important;
}

/* ── Grille / Carrousel Leo ── */
.g-collector .products,
.g-collector ul.product_list,
.g-collector .leo-product-list,
.g-rivage .products,
.g-rivage ul.product_list,
.g-rivage .leo-product-list {
  display: flex !important;
  flex-direction: column !important;
  gap: 20px !important;
  padding: 24px 32px !important;
  margin: 0 !important;
  list-style: none !important;
  overflow: hidden !important;
}

/* ── Carte produit — layout horizontal ── */
.g-collector .product-miniature,
.g-collector .js-product-miniature,
.g-collector article.product-miniature,
.g-rivage .product-miniature,
.g-rivage .js-product-miniature,
.g-rivage article.product-miniature {
  background: #fff !important;
  border-radius: 16px !important;
  overflow: hidden !important;
  box-shadow: 0 2px 18px rgba(26,43,60,.07) !important;
  transition: transform .25s ease, box-shadow .25s ease !important;
  border: none !important;
  display: flex !important;
  flex-direction: row !important;
  align-items: stretch !important;
  min-height: 200px !important;
}
.g-collector .product-miniature:hover,
.g-collector .js-product-miniature:hover,
.g-rivage .product-miniature:hover,
.g-rivage .js-product-miniature:hover {
  transform: translateY(-4px) !important;
  box-shadow: 0 8px 32px rgba(26,43,60,.13) !important;
}

/* ── Image ── */
.g-collector .thumbnail-container,
.g-collector .product-thumbnail,
.g-collector .product-miniature .img-block,
.g-rivage .thumbnail-container,
.g-rivage .product-thumbnail,
.g-rivage .product-miniature .img-block {
  flex: 0 0 44% !important;
  max-width: 44% !important;
  overflow: hidden !important;
  position: relative !important;
  background: var(--sand, #f4ebda) !important;
}
.g-collector .thumbnail-container img,
.g-collector .product-thumbnail img,
.g-collector .product-miniature .img-block img,
.g-rivage .thumbnail-container img,
.g-rivage .product-thumbnail img,
.g-rivage .product-miniature .img-block img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  display: block !important;
  transition: transform .6s ease !important;
}
.g-collector .product-miniature:hover .thumbnail-container img,
.g-collector .product-miniature:hover .img-block img,
.g-rivage .product-miniature:hover .thumbnail-container img,
.g-rivage .product-miniature:hover .img-block img {
  transform: scale(1.04) !important;
}

/* ── Badge ── */
.g-collector .discount-percentage,
.g-collector .badge-discount,
.g-collector .product-flag.discount,
.g-rivage .discount-percentage,
.g-rivage .badge-discount,
.g-rivage .product-flag.discount {
  position: absolute !important;
  top: 12px !important;
  left: 12px !important;
  background: var(--coral, #e86e61) !important;
  color: #fff !important;
  font-family: "degular", sans-serif !important;
  font-size:13px !important;
  font-weight: 700 !important;
  letter-spacing: 2px !important;
  text-transform: uppercase !important;
  padding: 4px 10px !important;
  border-radius: 0 !important;
  z-index: 5 !important;
}

/* ── Infos droite ── */
.g-collector .product-description,
.g-collector .product-miniature .product-body,
.g-collector .product-miniature .right-block,
.g-rivage .product-description,
.g-rivage .product-miniature .product-body,
.g-rivage .product-miniature .right-block {
  flex: 1 !important;
  padding: 20px !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: space-between !important;
}

/* ── Nom ── */
.g-collector .product-title,
.g-collector .product-title a,
.g-collector h3.product-title,
.g-rivage .product-title,
.g-rivage .product-title a,
.g-rivage h3.product-title {
  font-family: "degular", sans-serif !important;
  font-size:19px !important;
  font-weight: 600 !important;
  color: var(--navy, #1a2b3c) !important;
  line-height: 1.3 !important;
  margin-bottom: 4px !important;
  text-decoration: none !important;
}

/* ── Description courte ── */
.g-collector .product-description-short,
.g-collector .short-desc,
.g-rivage .product-description-short,
.g-rivage .short-desc {
  font-family: "degular-text", sans-serif !important;
  font-size: 12px !important;
  color: #7a8c9a !important;
  line-height: 1.5 !important;
  margin-bottom: 14px !important;
}

/* ── Prix ── */
.g-collector .price,
.g-collector .product-price,
.g-rivage .price,
.g-rivage .product-price {
  font-family: "degular", sans-serif !important;
  font-size:23px !important;
  font-weight: 700 !important;
  color: var(--coral, #e86e61) !important;
}
.g-collector .regular-price,
.g-collector .price-old,
.g-collector del.regular-price,
.g-rivage .regular-price,
.g-rivage .price-old,
.g-rivage del.regular-price {
  font-family: "degular-text", sans-serif !important;
  font-size: 13px !important;
  color: #aab0b8 !important;
  text-decoration: line-through !important;
  margin-left: 6px !important;
}

/* ── Bouton "Ajouter au panier" ── */
.g-collector .add-to-cart,
.g-collector .btn-add-to-cart,
.g-collector .product-miniature .btn,
.g-rivage .add-to-cart,
.g-rivage .btn-add-to-cart,
.g-rivage .product-miniature .btn {
  background: var(--coral, #e86e61) !important;
  color: #fff !important;
  font-family: "degular", sans-serif !important;
  font-size:14px !important;
  font-weight: 700 !important;
  letter-spacing: 2px !important;
  text-transform: uppercase !important;
  padding: 11px 20px !important;
  border: none !important;
  border-radius: 0 !important;
  cursor: pointer !important;
  transition: background .2s, transform .2s !important;
  text-decoration: none !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  width: 100% !important;
  justify-content: center !important;
}
.g-collector .add-to-cart:hover,
.g-collector .btn-add-to-cart:hover,
.g-rivage .add-to-cart:hover,
.g-rivage .btn-add-to-cart:hover {
  background: var(--coral-d, #d45a4d) !important;
  transform: translateY(-1px) !important;
}

/* ── Pastilles coloris (masquées — on utilise nos p-dots) ── */
.g-collector .color-list-container,
.g-collector .product-variants-item,
.g-rivage .color-list-container,
.g-rivage .product-variants-item {
  display: none !important;
}

/* ── Responsive ── */
@media (max-width: 991px) {
  .g-collector .g-photo,
  .g-rivage .g-photo { min-height: 320px; }
  .g-collector .products,
  .g-collector ul.product_list,
  .g-rivage .products,
  .g-rivage ul.product_list { padding: 16px !important; }
}
@media (max-width: 767px) {
  .g-collector .product-miniature,
  .g-collector .js-product-miniature,
  .g-rivage .product-miniature,
  .g-rivage .js-product-miniature {
    flex-direction: column !important;
  }
  .g-collector .thumbnail-container,
  .g-collector .product-miniature .img-block,
  .g-rivage .thumbnail-container,
  .g-rivage .product-miniature .img-block {
    flex: 0 0 auto !important;
    max-width: 100% !important;
    height: 220px !important;
  }
}

/*
 * ================================================================
 * SKIFFO — PRODUCT HERO
 * Fiche produit Rivage — galerie + achat
 * Scope : body.page-product / classes custom .prod-main etc.
 * Le TPL detail2744560523.tpl génère ces classes directement.
 * ================================================================
 */

/* ── Header fixe blanc permanent sur page produit (pas de hero image) ── */
body.page-product .hdr {
  background: #fff !important;
  box-shadow: 0 1px 0 rgba(0,0,0,.07) !important;
}
body.page-product .hdr-logo {
  filter: none !important;
}
body.page-product .hdr-nav > a,
body.page-product .hdr-nav .mm-item > a {
  color: var(--text) !important;
}
body.page-product .hdr-nav > a:hover,
body.page-product .hdr-nav .mm-item > a:hover {
  color: var(--coral) !important;
}
body.page-product .lang-btn,
body.page-product .cart-btn {
  color: var(--text) !important;
}

/* ── Breadcrumb ── */
.breadcrumb-skiffo {
  background: var(--offwhite);
  padding: 14px 48px;
  margin-top: 72px;
  border-bottom: 1px solid rgba(0,0,0,.06);
  display: flex;
  align-items: center;
  gap: 10px;
}
.breadcrumb-skiffo a,
.breadcrumb-skiffo .bc-sep,
.breadcrumb-skiffo .bc-current {
  font-family: "degular", sans-serif;
  font-size:14px;
  font-weight: 500;
  letter-spacing: .5px;
  color: var(--muted);
  text-decoration: none;
}
.breadcrumb-skiffo a:hover       { color: var(--coral); }
.breadcrumb-skiffo .bc-sep       { color: rgba(0,0,0,.18); }
.breadcrumb-skiffo .bc-current   { color: var(--text); font-weight: 600; }

/* ── Layout 2 colonnes ── */
.prod-main {
  max-width: 1280px;
  margin: 0 auto;
  padding: 52px 48px 80px;
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: 72px;
  align-items: start;
}

/* ── Galerie ── */
.gallery-main {
  position: relative;
  aspect-ratio: 1/1;
  overflow: hidden;
  background: var(--offwhite);
  margin-bottom: 14px;
}
.gallery-main img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: opacity .35s ease;
}
.g-badge {
  position: absolute;
  top: 20px; left: 20px;
  font-family: "degular", sans-serif;
  font-size:13px; font-weight: 700;
  letter-spacing: 3px; text-transform: uppercase;
  padding: 6px 14px;
  background: var(--coral);
  color: #fff;
  z-index: 2;
  border-radius: 0;
}
.g-badge-sunrise { background: linear-gradient(135deg, var(--coral) 0%, #f4a35e 100%); }
.gallery-thumbs  { display: flex; gap: 10px; }
.g-thumb {
  flex: 1;
  aspect-ratio: 1;
  overflow: hidden;
  cursor: pointer;
  opacity: .5;
  transition: opacity .25s, outline .2s;
  outline: 2px solid transparent;
  outline-offset: 2px;
  border-radius: 4px;
}
.g-thumb:hover     { opacity: .82; }
.g-thumb.on        { opacity: 1; outline: 2px solid var(--coral); }
.g-thumb img       { width: 100%; height: 100%; object-fit: cover; transition: transform .4s ease; }
.g-thumb:hover img { transform: scale(1.07); }

/* ── Bloc chiffres clés sous galerie ── */
.gallery-extra { margin-top: 18px; display: flex; flex-direction: column; gap: 14px; }
.g-pts {
  display: grid;
  grid-template-columns: repeat(3,1fr);
  border: 1px solid rgba(106,162,158,.18);
  border-radius: 10px;
  overflow: hidden;
}
.g-pt {
  display: flex; flex-direction: column;
  align-items: center; text-align: center;
  padding: 16px 10px; gap: 7px;
  background: var(--offwhite);
  border-right: 1px solid rgba(106,162,158,.18);
  transition: background .2s;
}
.g-pt:last-child { border-right: none; }
.g-pt:hover      { background: #fff; }
.g-pt-ico        { width: 32px; height: 32px; color: var(--teal); }
.g-pt-ico svg    { width: 100%; height: 100%; }
.g-pt-val {
  font-family: "degular", sans-serif;
  font-size:19px; font-weight: 800;
  color: var(--navy); line-height: 1;
}
.g-pt-lbl {
  font-family: "degular", sans-serif;
  font-size:12px; font-weight: 600;
  letter-spacing: 1px; text-transform: uppercase;
  color: var(--muted); line-height: 1.3;
}

/* ── Colonne info ── */
.info-badge {
  display: inline-block;
  font-family: "degular", sans-serif;
  font-size:12px; font-weight: 700;
  letter-spacing: 3px; text-transform: uppercase;
  padding: 5px 12px;
  background: linear-gradient(135deg, var(--coral) 0%, #f4a35e 100%);
  color: #fff;
  margin-bottom: 16px;
  border-radius: 4px;
}
.info-name {
  font-family: "degular", sans-serif !important;
  font-size:clamp(25px, 2.6vw, 37px) !important;
  font-weight: 700 !important;
  color: var(--navy) !important;
  line-height: 1.15 !important;
  margin-bottom: 6px !important;
}
.info-sub {
  font-size: 13px;
  color: var(--muted);
  letter-spacing: .5px;
  margin-bottom: 20px;
}
.info-stars      { display: flex; align-items: center; gap: 10px; margin-bottom: 24px; }
.stars           { display: flex; gap: 2px; }
.stars svg       { width: 15px; height: 15px; fill: var(--coral); stroke: none; }
.info-stars span { font-family: "degular", sans-serif; font-size:15px; color: var(--muted); font-weight: 500; }
.info-div        { height: 1px; background: rgba(0,0,0,.07); margin: 0 0 26px; }

/* ── Swatches coloris ── */
.clr-label {
  font-family: "degular", sans-serif;
  font-size:14px; font-weight: 700;
  letter-spacing: 2px; text-transform: uppercase;
  color: var(--text); margin-bottom: 14px;
  display: flex; align-items: center; gap: 8px;
}
.clr-label span { font-weight: 400; color: var(--muted); letter-spacing: 0; text-transform: none; font-size: 12px; }
.swatches       { display: flex; gap: 10px; margin-bottom: 30px; flex-wrap: wrap; }
.sw             { position: relative; cursor: pointer; user-select: none; }
.sw input       { position: absolute; opacity: 0; pointer-events: none; }
.sw-ring        { width: 42px; height: 42px; border-radius: 50%; border: 2.5px solid transparent; display: flex; align-items: center; justify-content: center; transition: border-color .2s; padding: 3px; }
.sw-dot         { width: 100%; height: 100%; border-radius: 50%; border: 1px solid rgba(0,0,0,.08); }
.sw input:checked + .sw-ring { border-color: var(--coral); }
.sw-name        { font-family: "degular", sans-serif; font-size:12px; text-align: center; margin-top: 5px; color: var(--muted); }

/* ── Prix ── */
.price-row  { display: flex; align-items: baseline; gap: 14px; margin-bottom: 8px; }
.price-old  { font-family: "degular", sans-serif; font-size:25px; font-weight: 500; color: var(--muted); text-decoration: line-through; line-height: 1; }
.price-main { font-family: "degular", sans-serif; font-size:47px; font-weight: 800; color: var(--navy); }
.price-note { font-size: 13px; color: var(--muted); }
.price-ttc  { font-size: 12px; color: var(--muted); margin-bottom: 28px; }

/* ── Pack summary (hardcodé dans TPL, pas dans description courte) ── */
.pack-sum {
  background: var(--offwhite);
  padding: 22px 24px;
  margin-bottom: 24px;
  border-left: 3px solid var(--teal);
  border-radius: 0 8px 8px 0;
}
.pack-sum-ttl {
  font-family: "degular", sans-serif;
  font-size:14px; font-weight: 700;
  letter-spacing: 2.5px; text-transform: uppercase;
  color: var(--teal);
  margin-bottom: 14px;
  display: flex; align-items: center; gap: 8px;
}
.pack-sum-ttl svg { width: 16px; height: 16px; }
.psi-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 7px; }
.psi      { display: flex; align-items: center; gap: 8px; font-size: 12px; color: var(--text); }
.psi svg  { width: 13px; height: 13px; color: var(--teal); flex-shrink: 0; }

/* ── Bouton ATC ── */
.btn-atc {
  width: 100%;
  display: flex !important; align-items: center !important; justify-content: center !important; gap: 10px !important;
  padding: 18px 32px !important;
  font-family: "degular", sans-serif !important;
  font-size:16px !important; font-weight: 700 !important;
  letter-spacing: 3px !important; text-transform: uppercase !important;
  background: var(--coral-d) !important;
  color: #fff !important;
  border: none !important; cursor: pointer !important;
  border-radius: 10px !important;
  transition: background .25s, transform .2s !important;
}
.btn-atc:hover { background: var(--coral) !important; transform: translateY(-2px) !important; }
.btn-atc svg   { width: 18px; height: 18px; }

/* ── Bouton wishlist ── */
.btn-wish {
  width: 100%;
  display: flex; align-items: center; justify-content: center; gap: 8px;
  padding: 13px 32px;
  background: transparent;
  border: 1.5px solid rgba(0,0,0,.1);
  color: var(--muted);
  font-family: "degular", sans-serif;
  font-size:14px; font-weight: 600;
  letter-spacing: 2px; text-transform: uppercase;
  cursor: pointer; border-radius: 10px;
  transition: all .2s;
}
.btn-wish:hover { border-color: var(--coral); color: var(--coral); }

/* ── Garanties ── */
.guarantees {
  display: grid;
  grid-template-columns: repeat(3,1fr);
  gap: 12px; margin-bottom: 24px;
}
.gu {
  display: flex; flex-direction: column;
  align-items: center; text-align: center;
  gap: 7px; padding: 16px 10px;
  background: var(--offwhite); border-radius: 8px;
}
.gu svg { width: 22px; height: 22px; color: var(--teal); }
.gu h5  { font-family: "degular", sans-serif; font-size:13px; font-weight: 700; letter-spacing: .5px; color: var(--navy); }
.gu p   { font-size: 10px; color: var(--muted); line-height: 1.4; }

/* ── Paiement mini-strip ── */
.pay-mini     { border-top: 1px solid rgba(0,0,0,.06); padding-top: 20px; display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.pay-mini-lbl { font-family: "degular", sans-serif; font-size:13px; font-weight: 600; letter-spacing: 1.5px; text-transform: uppercase; color: var(--muted); }
.pay-badge    { height: 24px; background: var(--offwhite); border: 1px solid rgba(0,0,0,.08); border-radius: 4px; padding: 0 8px; display: flex; align-items: center; font-family: "degular", sans-serif; font-size:13px; font-weight: 700; color: var(--muted); }
.pay-badge.pp { color: #003087; }
.pay-secure   { display: flex; align-items: center; gap: 5px; font-size: 10px; color: var(--muted); margin-left: auto; }
.pay-secure svg { width: 13px; height: 13px; color: var(--teal); }

/* ── Forcer suppression du padding PS sur page produit ── */
body.page-product #content-wrapper,
body.page-product #wrapper { padding-top: 0 !important; }

/* ── CTA zone ── */
.cta-area { display: flex; flex-direction: column; gap: 10px; margin-bottom: 28px; }

/*
 * ================================================================
 * SKIFFO — PRODUCT HERO — Overrides sélecteurs natifs Leo/PS
 * Ciblage via les classes réelles du detail2744560523.tpl
 * ================================================================
 */

/* ── Fil d'Ariane fiche produit — spacing + style Skiffo ── */
/* Espace au-dessus : 72px header fixe + 20px air */
body#product .breadcrumb-container,
body#product nav.breadcrumb.hidden-sm-down {
  padding-top: 45px!important;
  padding-bottom: 10px !important;
  padding-left: 48px !important;
  padding-right: 48px !important;
  margin: 0 !important;
  background: transparent !important;
}
body#product nav.breadcrumb.hidden-sm-down .breadcrumb {
  background: transparent !important;
  padding: 0 !important; margin: 0 !important;
}
/* Liste d'items */
body#product .breadcrumb ol,
body#product .breadcrumb li {
  list-style: none; display: inline-flex; align-items: center; padding: 0; margin: 0;
}
body#product .breadcrumb li + li::before {
  content: '›'; color: rgba(0,0,0,.2);
  font-size: 14px; margin: 0 7px; line-height: 1;
}
/* Texte liens */
body#product .breadcrumb a,
body#product .breadcrumb span[itemprop="name"],
body#product .breadcrumb .current {
  font-family: "degular", sans-serif;
  font-size: 10.5px; font-weight: 500;
  color: var(--muted); letter-spacing: 0.3px;
  text-decoration: none; transition: color .2s;
}
body#product .breadcrumb a:hover { color: var(--coral); }
/* Dernier item = nom produit */
body#product .breadcrumb li:last-child a,
body#product .breadcrumb li:last-child span {
  color: #e86e61(--text) !important; font-weight: 400;
}

/* ── Wrapper principal ── */
.produtt-detail.skiffo { padding-top: 0 !important; }
.produtt-detail.skiffo .row { margin: 0; padding-top: 16px; }
.produtt-detail.skiffo .skiffo-col-gallery,
.produtt-detail.skiffo .skiffo-col-info {
  padding-top: 0;
  padding-bottom: 80px;
}
.produtt-detail.skiffo .skiffo-col-gallery { padding-right: 36px; }
.produtt-detail.skiffo .skiffo-col-info    { padding-left: 24px; }

/* ── product-actions : réduire le padding-top ── */
.produtt-detail.skiffo .product-actions { padding-top: 12px !important; margin-top: 0 !important; }

/* ── Supprimer padding-left Bootstrap sur .leo-compare-wishlist-button ── */
.produtt-detail.skiffo .leo-compare-wishlist-button { padding-left: 0 !important; }

/* ── Désactiver le zoom magnifier au survol ── */
.produtt-detail.skiffo .magnify > .magnify-lens { display: none !important; }
.produtt-detail.skiffo #leogallery-zoom { width: 0 !important; height: 0 !important; overflow: hidden !important; pointer-events: none !important; }

/* ── Galerie lightSlider (mode HORIZONTAL — vertical=false) ── */
/* height: 460px = valeur initiale avant que JS calcule la hauteur carrée réelle.
   skiffoUIFix override .lSSlideWrapper, #lightSlider et .lslide avec la largeur réelle. */
.produtt-detail.skiffo .lSSlideWrapper {
  height: 460px !important;
  overflow: hidden !important;
}
/* #lightSlider (l'UL) : Leo le laisse à sa hauteur originale même quand le wrapper est plus grand */
.produtt-detail.skiffo #lightSlider {
  height: 460px !important;
}
.produtt-detail.skiffo .lightSlider .lslide {
  position: relative !important;
  overflow: hidden !important;
  height: 460px !important;
  background: #f5f5f5 !important;
}
.produtt-detail.skiffo .lightSlider .lslide img {
  position: absolute !important;
  top: 0 !important; left: 0 !important;
  width: 100% !important; height: 100% !important;
  object-fit: cover !important;
  margin: 0 !important;
}
/* Flèches prev/next — style Skiffo */
.produtt-detail.skiffo .lSAction { display: flex !important; justify-content: space-between !important; position: absolute !important; top: 50% !important; left: 0 !important; right: 0 !important; transform: translateY(-50%) !important; pointer-events: none !important; padding: 0 10px !important; z-index: 10 !important; }
.produtt-detail.skiffo .lSAction > a {
  pointer-events: auto !important;
  width: 40px !important; height: 40px !important;
  background: rgba(255,255,255,.85) !important;
  border-radius: 50% !important;
  display: flex !important; align-items: center !important; justify-content: center !important;
  color: var(--navy) !important;
  box-shadow: 0 2px 8px rgba(0,0,0,.12) !important;
  transition: background .2s !important;
}
.produtt-detail.skiffo .lSAction > a:hover { background: #fff !important; }
/* Thumbnails en bas — mode horizontal */
.produtt-detail.skiffo .lSPager.lSGallery {
  display: flex !important;
  flex-direction: row !important;
  gap: 8px !important;
  padding: 10px 0 0 !important;
  margin: 0 !important;
  list-style: none !important;
  overflow-x: auto !important;
  overflow-y: hidden !important;
  width: 100% !important;
  height: auto !important;
}
.produtt-detail.skiffo .lSPager.lSGallery li {
  flex: 0 0 88px !important;
  width: 88px !important;
  height: 88px !important;
  border-radius: 6px !important;
  overflow: hidden !important;
  opacity: .55 !important;
  border: 2.5px solid transparent !important;
  transition: opacity .2s, border-color .2s !important;
}
.produtt-detail.skiffo .lSPager.lSGallery li:hover { opacity: .85 !important; }
.produtt-detail.skiffo .lSPager.lSGallery li.active {
  opacity: 1 !important;
  border-color: var(--coral) !important;
}
.produtt-detail.skiffo .lSPager.lSGallery li img {
  width: 100% !important; height: 100% !important;
  object-fit: cover !important;
  display: block !important;
  margin: 0 !important;
  /* Position absolue du module Leo — reset */
  position: static !important;
  top: auto !important; right: auto !important; bottom: auto !important; left: auto !important;
}
/* Masquer les flèches internes du gallery rail (Leo en ajoute parfois) */
.produtt-detail.skiffo .leo-prev-gallery,
.produtt-detail.skiffo .leo-next-gallery { display: none !important; }

/* ── lightGallery popup — style Skiffo ── */
/* Fond sombre navy au lieu du noir pur */
.lg-backdrop { background: rgba(10,18,28,.93) !important; z-index: 10400 !important; }
.lg-outer { z-index: 10500 !important; }
.lg-toolbar, .lg-sub-html { background: rgba(10,18,28,.75) !important; }
.lg-outer .lg-thumb-outer {
  background: rgba(10,18,28,.88) !important;
  height: 84px !important; /* Leo/lightGallery peut injecter height:395px inline — override */
}
.lg-outer .lg-thumb-item {
  border-radius: 4px !important;
  overflow: hidden !important;
  border-width: 2px !important;
  height: 72px !important;
  width: 72px !important;
}
.lg-outer .lg-thumb-item img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
}
.lg-outer .lg-thumb-item.active,
.lg-outer .lg-thumb-item:hover { border-color: var(--coral) !important; }
.lg-actions .lg-next, .lg-actions .lg-prev {
  background: rgba(255,255,255,.1) !important;
  border-radius: 50% !important;
  border: 1.5px solid rgba(255,255,255,.2) !important;
  transition: background .2s !important;
}
.lg-actions .lg-next:hover, .lg-actions .lg-prev:hover { background: rgba(255,255,255,.22) !important; }
.lg-sub-html { display: none !important; }
/* ── lightGallery popup : image carrée (cohérent avec la galerie principale) ── */
.lg-outer .lg-img-wrap {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 !important;
}
.lg-outer .lg-object.lg-image {
  /* Carré basé sur la plus petite dimension du viewport */
  width:  min(80vh, 80vw) !important;
  height: min(80vh, 80vw) !important;
  max-width:  none !important;
  max-height: none !important;
  object-fit: cover !important;
  border-radius: 4px !important;
}
.lg-toolbar .lg-icon { color: rgba(255,255,255,.7) !important; }
.lg-toolbar .lg-icon:hover { color: #fff !important; }

/* ── Image principale ── */
.produtt-detail.skiffo .product-cover {
  aspect-ratio: 1/1;
  overflow: hidden;
  background: var(--offwhite);
  margin-bottom: 14px;
  border: none !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}
.produtt-detail.skiffo .product-cover .js-qv-product-cover {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  transition: opacity .35s ease;
  max-width: none !important;
}
/* Masquer le bouton zoom Leo */
.produtt-detail.skiffo .product-cover .layer { display: none; }

/* ── Flags produit (remplacés par info-badge) ── */
.produtt-detail.skiffo .product-flags { display: none !important; }

/* ── Miniatures (thumb-gallery) ── */
.produtt-detail.skiffo #thumb-gallery {
  display: flex !important;
  gap: 10px !important;
  margin-top: 0 !important;
}
.produtt-detail.skiffo .thumb-container {
  flex: 1 !important;
  aspect-ratio: 1 !important;
  overflow: hidden !important;
  border-radius: 4px !important;
  border: none !important;
  outline: 2px solid transparent !important;
  outline-offset: 2px !important;
  opacity: .5 !important;
  transition: opacity .25s, outline .2s !important;
  padding: 0 !important;
  margin: 0 !important;
}
.produtt-detail.skiffo .thumb-container:hover  { opacity: .82 !important; }
.produtt-detail.skiffo .thumb-container.active  {
  opacity: 1 !important;
  outline: 2px solid var(--coral) !important;
}
.produtt-detail.skiffo .thumb-container img {
  width: 100% !important; height: 100% !important;
  object-fit: cover !important;
  transition: transform .4s ease;
}
.produtt-detail.skiffo .thumb-container:hover img { transform: scale(1.07); }
/* Flèches prev/next mini (masquées : on garde le scroll naturel) */
.produtt-detail.skiffo .arrows-product-fake { display: none; }

/* ── Masquer le #thumb-gallery natif PS (Leo Gallery crée son propre slider) ── */
/* Sans ça, deux rangées de thumbs apparaissent : celle de PS en haut + celle de lightSlider */
.produtt-detail.skiffo #thumb-gallery,
.produtt-detail.skiffo .product-thumb-images { display: none !important; }

/* ── Override complet mode .vertical : forcer galerie en mode horizontal ──
   lightSlider ajoute .vertical sur .lSSlideOuter côté PHP avant window.load.
   Le JS (skiffoUIFix) retire la classe + repositionne les thumbs.
   Ces règles CSS servent de sécurité si le JS arrive après le premier paint. */
.produtt-detail.skiffo .lSSlideOuter.vertical {
  display: block !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}
.produtt-detail.skiffo .lSSlideOuter.vertical .lSSlideWrapper {
  width: 100% !important;
  height: 460px !important;
  float: none !important;
}
.produtt-detail.skiffo .lSSlideOuter.vertical .lSPager.lSGallery {
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: nowrap !important;
  width: 100% !important;
  height: auto !important;
  float: none !important;
  overflow-x: auto !important;
  margin-top: 8px !important;
  gap: 6px !important;
}
.produtt-detail.skiffo .lSSlideOuter.vertical .lSPager.lSGallery li {
  flex: 0 0 88px !important;
  width: 88px !important;
  height: 88px !important;
  min-width: 0 !important;
}

/* ── Badge info-badge Standard Rivage (couleur teal) ── */
.info-badge-std {
  background: linear-gradient(135deg, var(--teal) 0%, var(--teal-light) 100%) !important;
}
/* ── Badge info-badge Suncruise (bleu océan) ── */
.info-badge-suncruise {
  background: linear-gradient(135deg, #2a7fba 0%, #4eb8d8 100%) !important;
}

/* ── Nom produit h1 ── */
.produtt-detail.skiffo h1.product-detail-name {
  font-family: 'Plein', sans-serif !important;
  font-size: clamp(22px, 2.6vw, 34px) !important;
  font-weight: 700 !important;
  color: var(--navy) !important;
  line-height: 1.15 !important;
  margin-bottom: 6px !important;
  letter-spacing: -.3px;
}

/* ── Sous-titre .info-sub ── */
.produtt-detail.skiffo .info-sub {
  font-size: 13px;
  color: var(--muted);
  margin-bottom: 20px;
}

/* ── Prix (product-prices.tpl) — prix courant EN PREMIER, barré ensuite ── */
.produtt-detail.skiffo .product-prices {
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: baseline !important;
  gap: 10px 14px !important;
  margin: 0 0 8px !important;
  padding: 0 !important;
  background: none !important;
}
/* Ordre visuel flex :
   1 = .product-price (prix courant 279€)
   2 = .product-discount (.regular-price 559€ barré)
   3 = .tax-shipping-delivery-label (TTC)
   Badge "Sauvegarder X€" masqué (choix éditorial — redondant avec le prix barré) */
.produtt-detail.skiffo .product-price                    { order: 1 !important; }
.produtt-detail.skiffo .product-discount                 { order: 2 !important; }
.produtt-detail.skiffo .tax-shipping-delivery-label      { order: 3 !important; }
/* Badge SAUVEGARDER : masqué */
.produtt-detail.skiffo .discount.discount-amount { display: none !important; }
.produtt-detail.skiffo .current-price-value,
.produtt-detail.skiffo .current-price .price,
.produtt-detail.skiffo .product-price.price {
  font-family: "degular", sans-serif !important;
  font-size:47px !important;
  font-weight: 800 !important;
  color: var(--navy) !important;
  line-height: 1 !important;
}
.produtt-detail.skiffo .regular-price {
  font-family: "degular", sans-serif !important;
  font-size:25px !important;
  font-weight: 500 !important;
  color: var(--muted) !important;
  text-decoration: line-through !important;
  line-height: 1 !important;
}
.produtt-detail.skiffo .discount-percentage {
  display: none; /* masqué — le badge collector suffit */
}
.produtt-detail.skiffo .tax-shipping-policy {
  font-size: 12px;
  color: var(--muted);
  margin-left: 0 !important;
}

/* ── Mentions prix — UNE SEULE LIGNE : TTC · 3x · EN STOCK à droite ── */
.produtt-detail.skiffo .price-mentions {
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  gap: 14px !important;
  flex-wrap: nowrap !important;
  margin: 8px 0 14px !important;
}
.produtt-detail.skiffo .price-mentions span,
.produtt-detail.skiffo .price-mentions .pm-ttc,
.produtt-detail.skiffo .price-mentions .pm-3x {
  display: flex !important;
  align-items: center !important;
  gap: 5px !important;
  font-family: "degular", sans-serif !important;
  font-size:14px !important;
  font-weight: 500 !important;
  color: var(--teal) !important;
  line-height: 1 !important;
  white-space: nowrap !important;
}
.produtt-detail.skiffo .price-mentions svg {
  flex-shrink: 0 !important;
  stroke: var(--teal) !important;
}
/* EN STOCK : déplacé par JS dans .price-mentions, aligné à droite */
.produtt-detail.skiffo #product-availability.pm-avail {
  margin-left: auto !important;
  font-family: "degular", sans-serif !important;
  font-size:14px !important;
  font-weight: 700 !important;
  color: var(--teal) !important;
  display: flex !important;
  align-items: center !important;
  gap: 5px !important;
}
/* Masquer l'affichage original de #product-availability (hors price-mentions) */
.produtt-detail.skiffo .js-product-availability:not(.pm-avail) {
  display: none !important;
}

/* ── Variantes coloris (product-variants.tpl) ── */
.produtt-detail.skiffo .product-variants { margin-bottom: 30px; }
.produtt-detail.skiffo .product-variants-item > label {
  font-family: "degular", sans-serif !important;
  font-size:14px !important; font-weight: 700 !important;
  letter-spacing: 2px !important; text-transform: uppercase !important;
  color: var(--text) !important;
  margin-bottom: 14px !important;
  display: flex !important; align-items: center !important; gap: 8px !important;
}
/* Swatches circulaires — UL container */
.produtt-detail.skiffo .color-list-container,
.produtt-detail.skiffo ul.clearfix,
.produtt-detail.skiffo .product-variants-item ul {
  display: flex !important; gap: 10px !important; flex-wrap: wrap !important;
  padding: 0 !important; margin: 0 !important; list-style: none !important;
}
/* LI : leo do_fitwear génère <li class="float-xs-left input-container">
   ul#group_X (pas de classe clearfix sur l'UL — clearfix est sur le div parent) */
.produtt-detail.skiffo .color-list-container li,
.produtt-detail.skiffo ul.clearfix li,
.produtt-detail.skiffo li.input-container {
  float: none !important;
  margin: 0 !important; padding: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
}
/* ── Nom de la variante sous chaque swatch (injecté par skiffoUIFix) ── */
.produtt-detail.skiffo .swatch-name {
  display: block !important;
  text-align: center !important;
  font-family: "degular", sans-serif !important;
  font-size:12px !important;
  font-weight: 600 !important;
  color: var(--muted) !important;
  text-transform: capitalize !important;
  margin-top: 5px !important;
  line-height: 1.2 !important;
  letter-spacing: .3px !important;
  max-width: 52px !important;
  word-break: break-word !important;
}
.produtt-detail.skiffo .color-list-container a,
.produtt-detail.skiffo .input-color + span {
  width: 42px !important; height: 42px !important;
  border-radius: 50% !important;
  border: 2.5px solid transparent !important;
  display: flex !important; align-items: center !important; justify-content: center !important;
  padding: 3px !important;
  transition: border-color .2s !important;
}
.produtt-detail.skiffo .color-list-container a.selected,
.produtt-detail.skiffo .input-color:checked + span {
  border-color: var(--coral) !important;
  box-shadow: none !important; outline: none !important;
}

/* ── Bouton Ajouter au panier (product-add-to-cart.tpl) ── */
.produtt-detail.skiffo .product-add-to-cart { margin-top: 0 !important; }
/* Sélecteur précis : le bouton ATC est dans .add, pas dans .leo-compare-wishlist-button */
.produtt-detail.skiffo .product-add-to-cart .add .add-to-cart,
.produtt-detail.skiffo .product-add-to-cart .add .btn-primary,
.produtt-detail.skiffo .product-add-to-cart .add-to-cart {
  width: 100% !important;
  display: flex !important; align-items: center !important; justify-content: center !important;
  padding: 18px 32px !important;
  font-family: "degular", sans-serif !important;
  font-size:16px !important; font-weight: 700 !important;
  letter-spacing: 3px !important; text-transform: uppercase !important;
  background: var(--coral-d) !important;
  color: #fff !important;
  border: none !important; border-radius: 10px !important;
  cursor: pointer !important;
  transition: background .25s, transform .2s !important;
  box-shadow: none !important;
}
.produtt-detail.skiffo .product-add-to-cart .add .add-to-cart:hover,
.produtt-detail.skiffo .product-add-to-cart .add .btn-primary:hover,
.produtt-detail.skiffo .product-add-to-cart .add-to-cart:hover {
  background: var(--coral) !important;
  transform: translateY(-2px) !important;
}
/* Masquer le champ quantité UNIQUEMENT — le bloc .product-quantity contient aussi le bouton ATC */
.produtt-detail.skiffo .product-quantity { display: block !important; }
.produtt-detail.skiffo .product-quantity .qty { display: none !important; }
.produtt-detail.skiffo .product-quantity .product-minimal-quantity { display: none !important; }

/* ── CTAs — layout exact DOM (confirmé via code source)
   Structure réelle :
   .p-cartwapper
     .qty (masqué)
     .add → button.add-to-cart
     .leo-compare-wishlist-button
       .wishlist → a.leo-wishlist-button
       .compare  → a.leo-compare-button (masqué)
   ── */

/* Colonne : ATC puis wishlist */
.produtt-detail.skiffo .product-quantity .p-cartwapper {
  display: flex !important;
  flex-direction: column !important;
  gap: 10px !important;
  padding: 0 !important;
  margin: 0 !important;
  width: 100% !important;
  align-items: stretch !important;
}
/* .add prend toute la largeur */
.produtt-detail.skiffo .product-quantity .p-cartwapper .add {
  width: 100% !important;
  flex: none !important;
}
/* .leo-compare-wishlist-button : pleine largeur, flex colonne */
.produtt-detail.skiffo .leo-compare-wishlist-button {
  width: 100% !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 0 !important;
}
/* .wishlist : pleine largeur */
.produtt-detail.skiffo .leo-compare-wishlist-button .wishlist {
  width: 100% !important;
  display: block !important;
}

/* ── Masquer le bouton Comparer — sélecteur exact ── */
.produtt-detail.skiffo .leo-compare-wishlist-button .compare { display: none !important; }

/* ── Bouton Wishlist — sélecteur exact : a.leo-wishlist-button ── */
.produtt-detail.skiffo a.leo-wishlist-button {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  width: 100% !important;
  padding: 13px 32px !important;
  font-family: "degular", sans-serif !important;
  font-size:14px !important;
  font-weight: 600 !important;
  letter-spacing: 2px !important;
  text-transform: uppercase !important;
  background: transparent !important;
  color: var(--muted) !important;
  border: 1.5px solid rgba(0,0,0,.1) !important;
  border-radius: 10px !important;
  cursor: pointer !important;
  transition: all .2s !important;
  box-shadow: none !important;
  text-decoration: none !important;
}
.produtt-detail.skiffo a.leo-wishlist-button:hover {
  border-color: var(--coral) !important;
  color: var(--coral) !important;
  background: transparent !important;
}
/* Icône material-icons et spinner de chargement */
.produtt-detail.skiffo .leo-wishlist-bt-loading { display: none !important; }
.produtt-detail.skiffo a.leo-wishlist-button .icon-wishlist {
  font-size: 16px !important;
  color: inherit !important;
}
/* Masquer "Supprimer du panier" — n'afficher que "Liste de souhaits" */
.produtt-detail.skiffo a.leo-wishlist-button .text-remove { display: none !important; }

/* ── Description courte — masquée sur page produit (utilisée pour la liste) ── */
.produtt-detail.skiffo .description-short { display: none; }

/* ── Reassurance hook ── */
.produtt-detail.skiffo #product-reassurance,
.produtt-detail.skiffo .product-reassurance {
  display: grid !important;
  grid-template-columns: repeat(3,1fr) !important;
  gap: 12px !important;
  margin: 24px 0 !important;
  padding: 0 !important;
  background: transparent !important;
  list-style: none !important;
}
.produtt-detail.skiffo .product-reassurance li,
.produtt-detail.skiffo .product-reassurance .reassurance-item {
  display: flex !important; flex-direction: column !important;
  align-items: center !important; text-align: center !important;
  gap: 7px !important; padding: 16px 10px !important;
  background: var(--offwhite) !important;
  border-radius: 8px !important;
  border: none !important; list-style: none !important;
}
.produtt-detail.skiffo .product-reassurance img {
  width: 22px !important; height: 22px !important;
}
.produtt-detail.skiffo .product-reassurance p,
.produtt-detail.skiffo .product-reassurance span {
  font-family: "degular", sans-serif !important;
  font-size:13px !important; font-weight: 700 !important;
  color: var(--navy) !important;
  margin: 0 !important;
}

/* ── Section Garanties Skiffo (statique, en remplacement du hook displayReassurance) ── */
.produtt-detail.skiffo .skiffo-guarantees {
  display: flex !important;
  gap: 0 !important;
  margin: 20px 0 0 !important;
  border: 1px solid rgba(0,0,0,.07) !important;
  border-radius: 10px !important;
  overflow: hidden !important;
}
.produtt-detail.skiffo .sg-item {
  flex: 1 !important;
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  padding: 24px 10px !important;
  border-right: 1px solid rgba(0,0,0,.07) !important;
  background: var(--offwhite) !important;
}
.produtt-detail.skiffo .sg-item:last-child { border-right: none !important; }
.produtt-detail.skiffo .sg-ico {
  flex-shrink: 0 !important;
  width: 34px !important; height: 34px !important;
  display: flex !important;
  align-items: center !important; justify-content: center !important;
  background: var(--teal-light) !important;
  border-radius: 50% !important;
  padding: 7px !important;
}
.produtt-detail.skiffo .sg-ico svg { stroke: var(--navy) !important; }
.produtt-detail.skiffo .sg-txt {
  display: flex !important;
  flex-direction: column !important;
  gap: 2px !important;
}
.produtt-detail.skiffo .sg-txt strong {
  font-family: "degular", sans-serif !important;
  font-size:14px !important; font-weight: 700 !important;
  color: var(--navy) !important;
  line-height: 1.2 !important;
  display: block !important;
}
.produtt-detail.skiffo .sg-txt span {
  font-family: "degular", sans-serif !important;
  font-size:13px !important; font-weight: 400 !important;
  color: var(--muted) !important;
  line-height: 1.2 !important;
  display: block !important;
}
@media (max-width: 767px) {
  .produtt-detail.skiffo .skiffo-guarantees { flex-direction: column !important; }
  .produtt-detail.skiffo .sg-item {
    border-right: none !important;
    border-bottom: 1px solid rgba(0,0,0,.07) !important;
    padding: 11px 12px !important;
  }
  .produtt-detail.skiffo .sg-item:last-child { border-bottom: none !important; }
}

/* ── Accordion "More Info" (onglets description) ── */
.produtt-detail.skiffo .col-md-12 { border-top: 1px solid rgba(0,0,0,.06); margin-top: 0; }

/* ══════════════════════════════════════════════════════════════
   MOBILE ≤ 767px — PRODUCT HERO
   ══════════════════════════════════════════════════════════════ */
@media (max-width: 767px) {
  /* Custom classes */
  .breadcrumb-skiffo  { padding: 10px 18px; margin-top: 60px; }
  .prod-main          { grid-template-columns: 1fr; padding: 20px 0 48px; gap: 0; }
  .gallery-main       { border-radius: 0; }
  .gallery-thumbs     { padding: 0 14px; gap: 8px; }
  .gallery-extra      { padding: 0 14px; }
  .g-pt               { padding: 12px 8px; gap: 5px; }
  .g-pt-val           { font-size: 12px; }
  .g-pt-ico           { width: 24px; height: 24px; }
  .info               { padding: 28px 18px 0; }
  .info-name          { font-size: 22px !important; }
  .price-main         { font-size: 36px; }
  .price-row          { gap: 8px; }
  .pack-sum           { padding: 16px 18px; }
  .psi-grid           { gap: 5px; }
  .psi                { font-size: 11px; }
  .guarantees         { gap: 8px; }
  .gu                 { padding: 12px 6px; gap: 5px; }
  .gu h5              { font-size: 9px; }
  .gu p               { font-size: 9px; }
  .swatches           { gap: 7px; }
  .sw-ring            { width: 36px; height: 36px; }

  /* Leo/PS natifs — mobile */
  .produtt-detail.skiffo .skiffo-col-gallery,
  .produtt-detail.skiffo .skiffo-col-info {
    padding-top: 20px !important;
    padding-bottom: 32px !important;
    padding-left: 16px !important;
    padding-right: 16px !important;
  }
  .produtt-detail.skiffo .product-cover { border-radius: 0 !important; margin-bottom: 10px; }
  .produtt-detail.skiffo #thumb-gallery { gap: 6px !important; }
  .produtt-detail.skiffo h1.product-detail-name { font-size: 22px !important; }
  .produtt-detail.skiffo .current-price .price,
  .produtt-detail.skiffo .product-price.price    { font-size: 36px !important; }
  .produtt-detail.skiffo .regular-price          { font-size: 18px !important; }
  .produtt-detail.skiffo #product-reassurance,
  .produtt-detail.skiffo .product-reassurance    { grid-template-columns: repeat(3,1fr) !important; gap: 8px !important; }
  .produtt-detail.skiffo .product-reassurance li,
  .produtt-detail.skiffo .product-reassurance .reassurance-item { padding: 12px 6px !important; }
}

/* ══════════════════════════════════════════════════════════════
   FICHE PRODUIT — TABS HORIZONTAUX
   Description · Détails du produit · Avis
   Source : 11-product-tabs/product-tabs.css
   ══════════════════════════════════════════════════════════════ */

/* ── Conteneur global ──────────────────────────────────────── */
.skiffo-tabs-wrap {
  width: 100%;
  margin-top: 48px;
  border-top: 1px solid rgba(0,0,0,.08);
}

/* ── Barre de navigation ───────────────────────────────────── */
.skiffo-tabs-nav {
  display: flex;
  align-items: flex-end;
  gap: 0;
  border-bottom: 1px solid rgba(0,0,0,.08);
  padding: 0;
  margin: 0;
}

/* ── Bouton tab ────────────────────────────────────────────── */
.skiffo-tab-btn {
  font-family: "degular", sans-serif;
  font-size:14px;
  font-weight: 600;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: rgba(26,43,60,.38);
  background: none;
  border: none;
  border-bottom: 2px solid transparent;
  padding: 18px 28px 16px;
  cursor: pointer;
  transition: color .2s ease, border-color .2s ease;
  white-space: nowrap;
  margin-bottom: -1px;
}

.skiffo-tab-btn:hover { color: var(--navy); }

.skiffo-tab-btn.active {
  color: var(--navy);
  border-bottom-color: var(--navy);
}

/* ── Panels ────────────────────────────────────────────────── */
.skiffo-tab-panel { display: none; padding: 40px 0 60px; }
.skiffo-tab-panel.active { display: block; }

/* ── Panel Description ─────────────────────────────────────── */
.skiffo-desc-inner {
  max-width: 820px;
  font-family: "degular", sans-serif;
  font-size:18px;
  color: var(--navy);
  line-height: 1.75;
}

.skiffo-desc-inner h2,
.skiffo-desc-inner h3 {
  font-family: "degular", sans-serif;
  font-weight: 700;
  color: var(--navy);
  margin-bottom: 12px;
  margin-top: 32px;
}

.skiffo-desc-inner p  { margin-bottom: 16px; color: rgba(26,43,60,.72); }
.skiffo-desc-inner ul { padding-left: 20px; margin-bottom: 16px; }
.skiffo-desc-inner ul li { color: rgba(26,43,60,.72); margin-bottom: 6px; }

/* ── Panel Specs ───────────────────────────────────────────── */
.skiffo-specs-wrap { max-width: 680px; }

.skiffo-specs-label {
  font-family: "degular", sans-serif;
  font-size:13px;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--teal);
  margin-bottom: 24px;
}

.specs-table { width: 100%; border-collapse: collapse; }
.specs-table tr { border-bottom: 1px solid rgba(0,0,0,.06); }
.specs-table tr:last-child { border-bottom: none; }
.specs-table td { padding: 15px 0; vertical-align: middle; font-size: 13px; }
.specs-table td:first-child {
  font-family: "degular", sans-serif;
  font-weight: 600;
  color: rgba(26,43,60,.45);
  font-size:14px;
  letter-spacing: .5px;
  text-transform: uppercase;
  width: 38%;
  padding-right: 20px;
}
.specs-table td:last-child {
  color: var(--navy);
  font-weight: 500;
  font-size:17px;
  font-family: "degular", sans-serif;
}

/* Valeur mise en avant (injecté via backoffice) */
.spec-hl {
  font-family: "degular", sans-serif;
  font-weight: 800;
  font-size:23px;
  color: var(--navy);
}

/* Badge (injecté via backoffice) */
.spec-badge {
  display: inline-block;
  padding: 3px 10px;
  background: var(--teal-light);
  color: var(--navy);
  font-family: "degular", sans-serif;
  font-size:12px;
  font-weight: 700;
  letter-spacing: 1px;
  text-transform: uppercase;
  border-radius: 4px;
  margin-left: 8px;
}

.skiffo-specs-empty {
  font-family: "degular", sans-serif;
  font-size:17px;
  color: rgba(26,43,60,.4);
  padding: 24px 0;
}

/* ── Panel Avis ────────────────────────────────────────────── */
.skiffo-reviews-inner { max-width: 820px; }

/* ── Responsive ≤ 767px ────────────────────────────────────── */
@media (max-width: 767px) {
  .skiffo-tabs-nav {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
  }
  .skiffo-tabs-nav::-webkit-scrollbar { display: none; }
  .skiffo-tab-btn {
    padding: 16px 18px 14px;
    font-size: 10px;
    letter-spacing: 1px;
    flex-shrink: 0;
  }
  .skiffo-tab-panel { padding: 28px 0 40px; }
  .skiffo-desc-inner { font-size: 14px; }
  .specs-table td { padding: 12px 0; }
  .specs-table td:first-child { width: 45%; font-size: 10px; }
  .specs-table td:last-child  { font-size: 13px; }
  .spec-hl { font-size: 16px; }
}

/* ══════════════════════════════════════════════════════════════
   FICHE PRODUIT — MOBILE OVERRIDES v5 (22/04/2026)
   Correctifs layout mobile ≤ 767px
   ══════════════════════════════════════════════════════════════ */

/* ── gallery-extra : desktop / mobile toggle (global) ── */
.gallery-extra-mobile { display: none !important; }

@media (max-width: 767px) {

  /* ── Colonnes : supprimer le vide entre galerie et info ── */
  .produtt-detail.skiffo .skiffo-col-gallery { padding-bottom: 0 !important; }
  .produtt-detail.skiffo .skiffo-col-info    { padding-top:    0 !important; }

  /* ── Prix ── */
  .produtt-detail.skiffo .current-price-value,
  .produtt-detail.skiffo .current-price .price,
  .produtt-detail.skiffo .product-price.price { font-size: 26px !important; }
  .produtt-detail.skiffo .regular-price       { font-size: 14px !important; }
  .produtt-detail.skiffo .product-prices      { gap: 4px 8px !important; }

  /* ── Mentions prix : masquer TTC sur mobile, EN STOCK reste sur la ligne ── */
  .produtt-detail.skiffo .tax-shipping-delivery-label { display: none !important; }
  .produtt-detail.skiffo .price-mentions {
    flex-wrap: nowrap !important;
    overflow: hidden !important;
    max-width: 100% !important;
    gap: 4px 8px !important;
  }
  .produtt-detail.skiffo #product-availability.pm-avail {
    flex-shrink: 1 !important;
    min-width: 0 !important;
    white-space: nowrap !important;
  }

  /* ── gallery-extra : masquer desktop, afficher mobile ── */
  .gallery-extra-desktop { display: none !important; }
  .gallery-extra-mobile {
    display: flex !important;
    margin-top: 12px !important;
    margin-bottom: 0 !important;
    padding: 0 !important;
    width: 100% !important;
  }
  .gallery-extra-mobile .g-pts {
    padding: 0 !important;
    margin: 0 !important;
    width: 100% !important;
    box-sizing: border-box !important;
  }

  /* ── Galerie lightSlider : empêcher le bleed des slides adjacentes ── */
  .produtt-detail.skiffo .lSSlideOuter,
  .produtt-detail.skiffo .lSSlideWrapper,
  .produtt-detail.skiffo .lightSlider,
  .produtt-detail.skiffo #lightSlider,
  .produtt-detail.skiffo .product-cover { overflow: hidden !important; }
  /* Les li (slides) aussi : pas de débordement latéral */
  .produtt-detail.skiffo #lightSlider li,
  .produtt-detail.skiffo #lightSlider li img {
    overflow: hidden !important;
    max-width: 100% !important;
  }
  /* Strip thumbnails généré par data-thumb : masqué sur mobile */
  .produtt-detail.skiffo .lSGallery { display: none !important; }

  /* ── Séparateur post-réassurance : inutile sur mobile ── */
  .produtt-detail.skiffo .skiffo-col-info hr { display: none !important; }

}


/* ══════════════════════════════════════════════════════════════
   FICHE PRODUIT — SECTIONS DESCRIPTION (injections Leo editor)
   Polyvalence · Points Forts · Pack · Techno · Simplicité · Specs · Cross-sell
   ══════════════════════════════════════════════════════════════ */

/* ── 1. POLYVALENCE ──────────────────────────────────────────── */
.polv { display: grid; grid-template-columns: 1fr 1fr; min-height: 680px; }
.polv-photo { position: relative; overflow: hidden; }
.polv-photo img { width: 100%; height: 100%; object-fit: cover; transition: transform 7s ease; }
.polv:hover .polv-photo img { transform: scale(1.04); }
.polv-ov { position: absolute; inset: 0; background: linear-gradient(to right, rgba(26,43,60,.12), rgba(26,43,60,0) 60%); }
.polv-content { background: var(--sand); display: flex; flex-direction: column; justify-content: center; padding: 80px 72px; }
.polv-content .label { color: var(--teal); margin-bottom: 20px; display: inline-block; text-align: left; }
.polv-content h2 { font-family: "Plein", sans-serif; font-size: clamp(40px, 4.5vw, 64px); font-weight: 700; color: var(--navy); line-height: .96; margin-bottom: 28px; }
.polv-content h2 em { color: var(--coral); font-style: normal; display: block; }
.polv-content p { font-size: 16px; color: var(--text); line-height: 1.8; margin-bottom: 36px; max-width: 400px; }
.polv-stats { display: grid; grid-template-columns: repeat(3, 1fr); border-top: 1px solid rgba(26,43,60,.1); border-left: 1px solid rgba(26,43,60,.1); }
.p-stat { padding: 22px 18px; border-right: 1px solid rgba(26,43,60,.1); border-bottom: 1px solid rgba(26,43,60,.1); }
.p-stat-val { font-family: "degular", sans-serif; font-size:clamp(25px, 2.5vw, 33px); font-weight: 800; color: var(--navy); margin-bottom: 4px; }
.p-stat-lbl { font-size: 11px; color: var(--muted); line-height: 1.4; }
.dims { margin-top: 28px; display: flex; flex-wrap: wrap; gap: 8px; }
.dim-pill { font-family: "degular", sans-serif; font-size:14px; font-weight: 600; letter-spacing: 1px; padding: 7px 14px; background: rgba(26,43,60,.06); color: var(--text); border-radius: 6px; }

/* ── 1B. POINTS FORTS INTERACTIFS ───────────────────────────── */
.pf-sec { position: relative; overflow: hidden; padding: 130px 48px; }
.pf-bg { position: absolute; inset: 0; z-index: 0; }
.pf-bg img { width: 100%; height: 100%; object-fit: cover; object-position: center 35%; }
.pf-bg-ov { position: absolute; inset: 0; background: linear-gradient(110deg, rgba(26,43,60,.88) 0%, rgba(26,43,60,.70) 50%, rgba(26,43,60,.38) 100%); }
.pf-in { position: relative; z-index: 2; max-width: 1300px; margin: 0 auto; }
.pf-layout { display: grid; grid-template-columns: 1.25fr 1fr; column-gap: 64px; align-items: stretch; }
.pf-left { display: flex; flex-direction: column; justify-content: space-between; }
.pf-left-hd { flex-shrink: 0; }
.pf-left-hd .label { color: var(--teal-light); display: inline-block; text-align: left; margin-bottom: 10px; }
.pf-left-hd h2 { font-family: "Plein", sans-serif; font-size: clamp(36px, 4vw, 56px); font-weight: 700; color: #fff; line-height: .96; margin-bottom: 10px; }
.pf-left-hd h2 em { color: var(--coral); font-style: normal; display: block; }
.pf-left-hd p { font-size:16px; color: rgba(255,255,255,.5); font-family: "degular", sans-serif; letter-spacing: .3px; line-height: 1.6; }
.pf-conn-svg { position: absolute; top: 0; left: 0; width: 100%; height: 100%; pointer-events: none; z-index: 5; overflow: visible; opacity: 0; transition: opacity .3s ease; }
.pf-conn-svg.visible { opacity: 1; }
.pf-board-float { position: relative; width: 100%; margin-bottom: 28px; }
.pf-board-float > img { width: 100%; display: block; filter: drop-shadow(0 28px 56px rgba(0,0,0,.6)) drop-shadow(0 8px 16px rgba(0,0,0,.35)); }
.pf-spot { position: absolute; transform: translate(-50%, -50%); width: 32px; height: 32px; border-radius: 50%; background: var(--coral); border: 2px solid rgba(255,255,255,.85); color: #fff; cursor: pointer; display: flex; align-items: center; justify-content: center; transition: all .22s ease; z-index: 10; box-shadow: 0 2px 12px rgba(0,0,0,.28); padding: 0; font-family: "degular", sans-serif; font-size:12px; font-weight: 800; letter-spacing: .3px; }
.pf-spot.active { background: #fff; border-color: var(--coral); color: var(--coral); box-shadow: 0 0 0 5px rgba(237,115,101,.28), 0 2px 12px rgba(0,0,0,.28); }
.pf-spot:not(.active):hover { background: var(--coral-d); border-color: #fff; }
@keyframes pfPulse { 0% { box-shadow: 0 0 0 0 rgba(237,115,101,.5); } 70% { box-shadow: 0 0 0 8px rgba(237,115,101,0); } 100% { box-shadow: 0 0 0 0 rgba(237,115,101,0); } }
.pf-spot:not(.active) { animation: pfPulse 3s ease-out infinite; }
.pf-thumbs { display: grid; grid-template-columns: repeat(6, 1fr); gap: 12px; width: 100%; margin-top: 4px; flex-shrink: 0; }
.pf-thumb-wrap { display: flex; flex-direction: column; align-items: center; cursor: pointer; gap: 0; }
.pf-thumb { width: 100%; aspect-ratio: 1; border-radius: 50%; overflow: hidden; border: 3px solid rgba(255,255,255,.22); transition: all .25s ease; }
.pf-thumb img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s ease; }
.pf-thumb-wrap:hover .pf-thumb { border-color: rgba(255,255,255,.65); transform: scale(1.07); }
.pf-thumb-wrap:hover .pf-thumb img { transform: scale(1.1); }
.pf-thumb-wrap.active .pf-thumb { border-color: var(--coral); box-shadow: 0 0 0 3px rgba(237,115,101,.3), 0 4px 14px rgba(0,0,0,.25); }
.pf-thumb-lbl { display: block; text-align: center; font-family: "degular", sans-serif; font-size:15px; font-weight: 600; letter-spacing: .5px; text-transform: uppercase; color: rgba(255,255,255,.5); margin-top: 7px; transition: color .2s; line-height: 1.2; }
.pf-thumb-wrap:hover .pf-thumb-lbl, .pf-thumb-wrap.active .pf-thumb-lbl { color: #fff; }
.pf-panel { background: rgba(255,255,255,.97); border-radius: 16px; overflow: hidden; box-shadow: 0 32px 80px rgba(0,0,0,.32); display: flex; flex-direction: column; max-height: 720px; }
.pf-panel-img { flex: 2; min-height: 0; overflow: hidden; }
.pf-panel-img img { width: 100%; height: 100%; object-fit: cover; object-position: center; transition: opacity .3s ease; }
.pf-panel-img img.pf-fading { opacity: 0; }
.pf-panel-body { flex: 1; padding: 24px 32px 28px; display: flex; flex-direction: column; gap: 10px; justify-content: center; }
.pf-panel-num { font-family: "degular", sans-serif; font-size:13px; font-weight: 700; letter-spacing: 4px; text-transform: uppercase; color: var(--coral); }
.pf-panel-ttl { font-family: "degular", sans-serif; font-size:23px; font-weight: 800; color: var(--navy); line-height: 1.15; }
.pf-panel-desc { font-size: 13px; color: var(--muted); line-height: 1.75; }

/* ── 2. PACK COMPLET ─────────────────────────────────────────── */
.pack-sec { background: var(--navy); padding: 100px 0 80px; position: relative; overflow: hidden; }
.pack-sec-bg { position: absolute; inset: 0; }
.pack-sec-bg img { width: 100%; height: 100%; object-fit: cover; opacity: .07; }
.pack-sec-in { position: relative; z-index: 2; max-width: 1280px; margin: 0 auto; padding: 0 48px; }
.pack-sec-hd { text-align: center; margin-bottom: 64px; }
.pack-sec-hd .label { color: var(--teal-light); margin-bottom: 16px; display: block; }
.pack-sec-hd h2 { font-family: "degular", sans-serif; font-size:clamp(33px, 4vw, 53px); font-weight: 800; color: #fff; line-height: 1.1; margin-bottom: 18px; }
.pack-sec-hd p { font-size: 15px; color: rgba(255,255,255,.48); max-width: 520px; margin: 0 auto; line-height: 1.7; }
.pack-cards { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
.pack-card { background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.07); overflow: hidden; transition: background .25s, transform .3s; cursor: pointer; border-radius: 8px; }
.pack-card:hover { background: rgba(255,255,255,.09); transform: translateY(-5px); }
.pack-card-img { aspect-ratio: 3/4; overflow: hidden; }
.pack-card-img img { width: 100%; height: 100%; object-fit: cover; transition: transform .6s ease; }
.pack-card:hover .pack-card-img img { transform: scale(1.06); }
.pack-card-body { padding: 20px 20px 26px; }
.pack-card-ico { width: 28px; height: 28px; color: var(--teal-light); margin-bottom: 12px; }
.pack-card-ico svg { width: 100%; height: 100%; }
.pack-card-name { font-family: "degular", sans-serif; font-size:16px; font-weight: 700; color: #fff; margin-bottom: 6px; }
.pack-card-desc { font-size: 11px; color: rgba(255,255,255,.4); line-height: 1.55; }
.pack-note { margin-top: 52px; padding-top: 44px; border-top: 1px solid rgba(255,255,255,.08); display: flex; align-items: center; justify-content: space-between; gap: 32px; flex-wrap: wrap; }
.pack-note-txt { font-family: "degular", sans-serif; font-size:clamp(19px, 2vw, 25px); font-weight: 700; color: #fff !important; max-width: 600px; line-height: 1.45; }
.pack-note-txt span { color: var(--coral) !important; }
.pack-note-val { text-align: right; }
.from-lbl { font-size:15px; color: rgba(255,255,255,.4); margin-bottom: 4px; font-family: "degular", sans-serif; letter-spacing: 1px; text-transform: uppercase; }
.big-price { font-family: "degular", sans-serif; font-size:clamp(41px, 4.5vw, 61px); font-weight: 800; color: #fff; line-height: 1; }
.all-in { font-size:14px; color: var(--teal-light); margin-top: 6px; font-family: "degular", sans-serif; letter-spacing: 1px; text-transform: uppercase; }

/* ── 3. TECHNOLOGIE DROPSTITCH ───────────────────────────────── */
.tech-ds { background: var(--offwhite); padding: 100px 48px; }
.tech-ds-in { max-width: 1280px; margin: 0 auto; display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: start; }
.tech-ds-text .label { color: var(--teal); display: inline-block; text-align: left; margin-bottom: 16px; }
.tech-ds-text h2 { font-family: "Plein", sans-serif; font-size: clamp(42px, 5vw, 68px); font-weight: 700; color: var(--text); line-height: .92; margin-bottom: 28px; }
.tech-ds-text h2 em { color: var(--coral-d); font-style: normal; }
.tech-ds-intro { font-size: 15px; color: var(--muted); line-height: 1.8; max-width: 440px; margin-bottom: 44px; }
.tech-ds-rows { display: flex; flex-direction: column; gap: 0; }
.tech-ds-row { display: grid; grid-template-columns: 44px 1fr; gap: 20px; padding: 22px 0; border-bottom: 1px solid rgba(42,87,84,.1); }
.tech-ds-row:last-child { border-bottom: none; }
.tech-ds-icon { display: flex; align-items: flex-start; padding-top: 2px; }
.tech-ds-row strong { display: block; font-family: "degular", sans-serif; font-size:16px; font-weight: 700; color: var(--text); letter-spacing: .5px; margin-bottom: 6px; }
.tech-ds-row p { font-size: 13px; color: var(--muted); line-height: 1.75; margin: 0; }
.tech-ds-visual { position: sticky; top: 100px; }
.tech-ds-img-wrap { position: relative; border-radius: 4px; overflow: hidden; margin-bottom: 24px; }
.tech-ds-img-wrap img { width: 100%; height: 460px; object-fit: cover; object-position: center; display: block; }
.tech-ds-badge { position: absolute; bottom: 20px; left: 20px; background: #d45a4d; color: #fff; padding: 10px 16px; border-radius: 4px; text-align: center; line-height: 1.1; }
.tech-ds-badge-num { display: block; font-family: "degular", sans-serif; font-size:25px; font-weight: 800; letter-spacing: 2px; }
.tech-ds-badge-lbl { display: block; font-family: "degular", sans-serif; font-size:12px; font-weight: 600; letter-spacing: 1px; text-transform: uppercase; opacity: .9; }
.tech-ds-specs { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.tech-ds-spec { background: var(--sand); border-radius: 4px; padding: 16px 18px; text-align: center; }
.tech-ds-spec-v { display: block; font-family: "Plein", sans-serif; font-size: 26px; font-weight: 700; color: var(--text); line-height: 1.1; margin-bottom: 4px; }
.tech-ds-spec-k { display: block; font-family: "degular", sans-serif; font-size:13px; font-weight: 600; color: var(--muted); letter-spacing: 1px; text-transform: uppercase; }

/* ── 4. SIMPLICITÉ ───────────────────────────────────────────── */
.simpl { position: relative; min-height: 720px; overflow: hidden; display: flex; align-items: center; }
.simpl-bg { position: absolute; inset: 0; }
.simpl-bg img { width: 100%; height: 100%; object-fit: cover; object-position: center 25%; transition: transform 8s ease; }
.simpl:hover .simpl-bg img { transform: scale(1.04); }
.simpl-ov { position: absolute; inset: 0; background: linear-gradient(110deg, rgba(14,22,36,.92) 0%, rgba(26,43,60,.68) 48%, rgba(26,43,60,.10) 100%); }
.simpl-in { position: relative; z-index: 2; max-width: 1280px; margin: 0 auto; padding: 80px 48px; display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: center; }
.simpl-content .label { color: var(--teal-light); margin-bottom: 20px; display: block; text-align: left; }
.simpl-content h2 { font-family: "Plein", sans-serif; font-size: clamp(46px, 5.5vw, 76px); font-weight: 700; color: #fff; line-height: .94; margin-bottom: 28px; }
.simpl-content h2 em { color: var(--coral); font-style: normal; }
.simpl-content p { font-size: 16px; color: rgba(255,255,255,.68); line-height: 1.8; margin-bottom: 40px; max-width: 440px; }
.simpl-steps { display: flex; flex-direction: column; background: rgba(14,22,36,.30); border-radius: 8px; padding: 8px 20px; backdrop-filter: blur(6px); }
.simpl-step { display: flex; gap: 20px; padding: 24px 0; border-bottom: 1px solid rgba(255,255,255,.14); }
.simpl-step:last-child { border-bottom: none; }
.step-n { font-family: "degular", sans-serif; font-size: 33px; font-weight: 800; color: rgba(255,255,255,.16); flex-shrink: 0; width: 40px; line-height: 1; padding-top: 4px; }
.step-ico { width: 38px; height: 38px; color: var(--teal-light); flex-shrink: 0; padding-top: 2px; }
.step-ico svg { width: 100%; height: 100%; }
.step-txt h4 { font-family: "degular", sans-serif; font-size: 17px; font-weight: 700; color: #fff; margin-bottom: 5px; }
.step-txt p { font-size: 12px; color: rgba(255,255,255,.75); line-height: 1.6; }

/* ── 5. SPECS — section wrapper + header (table déjà définie) ── */
.specs { background: var(--offwhite); padding: 100px 48px; }
.specs-in { max-width: 1280px; margin: 0 auto; display: grid; grid-template-columns: 1fr 1.6fr; gap: 80px; align-items: start; }
.specs-hd .label { color: var(--teal); margin-bottom: 16px; display: block; }
.specs-hd h2 { font-family: "degular", sans-serif; font-size:clamp(31px, 3vw, 43px); font-weight: 800; color: var(--navy); line-height: 1.1; margin-bottom: 20px; }
.specs-hd p { font-size: 15px; color: var(--muted); line-height: 1.7; margin-bottom: 32px; }
/* .specs-table · .spec-hl · .spec-badge → déjà définis plus haut */

/* ── 6. CROSS-SELL ───────────────────────────────────────────── */
.xsell { padding: 100px 0 80px; background: var(--white); }
.xsell-in { max-width: 1280px; margin: 0 auto; padding: 0 48px; }
.xsell-hd { display: flex; align-items: flex-end; justify-content: space-between; margin-bottom: 40px; }
.xsell-hd-l .label { color: var(--coral); margin-bottom: 10px; display: block; }
.xsell-hd-l h2 { font-family: "degular", sans-serif; font-size:clamp(27px, 3vw, 39px); font-weight: 800; color: var(--navy); line-height: 1.1; }
.xsell-ctrls { display: flex; gap: 10px; }
.xc-btn { width: 40px; height: 40px; border: 1.5px solid var(--teal); background: none; color: var(--teal); display: flex; align-items: center; justify-content: center; font-size: 16px; cursor: pointer; border-radius: 8px; transition: all .2s; }
.xc-btn:hover { background: var(--teal); color: #fff; }
.xsell-carousel { display: flex; overflow-x: auto; scroll-snap-type: x mandatory; scrollbar-width: none; gap: 20px; padding-bottom: 4px; }
.xsell-carousel::-webkit-scrollbar { display: none; }
.xc-card { scroll-snap-align: start; flex-shrink: 0; width: calc(25% - 15px); border: 1px solid rgba(0,0,0,.06); overflow: hidden; transition: box-shadow .3s, transform .3s; cursor: pointer; border-radius: 8px; }
.xc-card:hover { box-shadow: 0 12px 48px rgba(42,87,84,.12); transform: translateY(-4px); }
.xc-img { aspect-ratio: 1/1; overflow: hidden; position: relative; }
.xc-img img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s ease; }
.xc-card:hover .xc-img img { transform: scale(1.06); }
.xc-dots { position: absolute; bottom: 12px; right: 12px; display: flex; gap: 5px; }
.xc-dot { width: 18px; height: 18px; border-radius: 50%; border: 2px solid #fff; box-shadow: 0 1px 3px rgba(0,0,0,.25); }
.xc-body { padding: 18px 20px 22px; }
.xc-badge { display: inline-block; font-family: "degular", sans-serif; font-size:11px; font-weight: 700; letter-spacing: 2.5px; text-transform: uppercase; padding: 4px 10px; margin-bottom: 10px; border-radius: 4px; }
.xc-badge.col { background: var(--coral); color: #fff; }
.xc-badge.std { background: var(--teal); color: #fff; }
.xc-name { font-family: "degular", sans-serif; font-size:18px; font-weight: 800; color: var(--navy); margin-bottom: 3px; }
.xc-sub { font-size: 11px; color: var(--muted); margin-bottom: 16px; }
.xc-foot { display: flex; align-items: center; justify-content: space-between; }
.xc-price { font-family: "degular", sans-serif; font-size:23px; font-weight: 800; color: var(--navy); }
.xc-price-old { font-family: "degular", sans-serif; font-size:15px; font-weight: 400; color: var(--muted); text-decoration: line-through; display: block; line-height: 1.1; margin-bottom: 1px; }
.btn-xc { font-family: "degular", sans-serif; font-size:12px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; padding: 9px 16px; background: var(--teal); color: #fff; border: none; cursor: pointer; border-radius: 6px; transition: background .2s; }
.btn-xc:hover { background: var(--coral); }

/* ── RESPONSIVE ≤ 1023px ─────────────────────────────────────── */
@media (max-width: 1023px) {
  .pf-sec { padding: 90px 24px; }
  .pf-layout { grid-template-columns: 1fr; gap: 40px; }
  .pf-left { gap: 32px; }
  .pf-panel-img { min-height: 220px; }
  .pf-conn-svg { display: none; }
  .tech-ds { padding: 72px 24px; }
  .tech-ds-in { grid-template-columns: 1fr; gap: 48px; }
  .tech-ds-visual { position: static; }
}

@media (max-width: 600px) {
  .pf-sec { padding: 56px 20px; }
  .pf-thumbs { grid-template-columns: repeat(3, 1fr); gap: 10px; }
  .pf-thumb-lbl { font-size: 10px; }
  .pf-panel-img { height: 200px; }
  .tech-ds { padding: 56px 20px; }
  .tech-ds-specs { grid-template-columns: 1fr 1fr; }
}

/* ── RESPONSIVE ≤ 767px ──────────────────────────────────────── */
@media (max-width: 767px) {
  /* Polyvalence */
  .polv { grid-template-columns: 1fr; min-height: auto; }
  .polv-photo { height: 260px; }
  .polv-content { padding: 40px 20px 48px; }
  .p-stat { padding: 16px 10px; }
  .p-stat-val { font-size: 20px; }
  .dims { gap: 6px; }
  .dim-pill { font-size: 10px; padding: 5px 10px; }

  /* Points Forts */
  .pf-sec { padding: 56px 18px 48px; }
  .pf-layout { grid-template-columns: 1fr; gap: 24px; }
  .pf-left { gap: 0; }
  .pf-left-hd { margin-bottom: 24px; }
  .pf-left-hd h2 { font-size: clamp(30px, 8vw, 44px); }
  .pf-board-float { display: none !important; }
  .pf-conn-svg { display: none !important; }
  /* Cercles réduits — libère la carte sur mobile */
  .pf-thumbs { grid-template-columns: repeat(3, 1fr) !important; gap: 8px; margin-top: 0; margin-bottom: 16px; }
  .pf-thumb-wrap { max-width: 72px; margin: 0 auto; }
  .pf-thumb-lbl { font-size: 8px; margin-top: 4px; letter-spacing: .2px; line-height: 1.15; }
  .pf-panel { max-height: none; border-radius: 12px; }
  .pf-panel-img { flex: none; height: 180px; min-height: auto; }
  .pf-panel-body { padding: 16px 18px 20px; gap: 6px; }
  .pf-panel-ttl { font-size: 15px; }
  .pf-panel-desc { font-size: 11px; line-height: 1.65; }

  /* Pack Complet */
  .pack-sec { padding: 56px 0 40px; }
  .pack-sec-in { padding: 0 18px; }
  .pack-sec-hd { margin-bottom: 36px; }
  .pack-sec-hd h2 { font-size: clamp(24px, 7vw, 36px); }
  .pack-cards { grid-template-columns: 1fr; gap: 10px; }
  .pack-card { display: flex; flex-direction: row; border-radius: 10px; }
  .pack-card:hover { transform: none; }
  .pack-card-img { width: 110px; flex-shrink: 0; aspect-ratio: auto; min-height: 96px; }
  .pack-card-body { padding: 12px 14px; gap: 4px; display: flex; flex-direction: column; justify-content: center; }
  .pack-card-ico { width: 18px; height: 18px; margin-bottom: 2px; }
  .pack-card-name { font-size: 12px; }
  .pack-note { flex-direction: column; align-items: flex-start; gap: 16px; margin-top: 32px; padding-top: 28px; }
  .pack-note-val { text-align: left; }
  .big-price { font-size: clamp(36px, 9vw, 48px); }

  /* Technologie */
  .tech-ds-text h2 { font-size: clamp(36px, 10vw, 52px); }
  .tech-ds-img-wrap img { height: 260px; }

  /* Simplicité */
  .simpl { min-height: auto; }
  .simpl-in { grid-template-columns: 1fr; gap: 36px; padding: 56px 20px; }
  .simpl-content p { font-size: 14px; max-width: 100%; }
  .simpl-step { padding: 18px 0; gap: 14px; }
  .step-n { font-size: 22px; width: 30px; }
  .step-ico { width: 28px; height: 28px; }

  /* Specs */
  .specs { padding: 56px 20px; }
  .specs-in { grid-template-columns: 1fr; gap: 32px; }
  .specs-hd h2 { font-size: clamp(24px, 7vw, 34px); }

  /* Cross-sell */
  .xsell { padding: 56px 0; }
}

/* ============================================================

/* ============================================================
   FICHE PRODUIT — SECTION 15B : ENGAGEMENT RSE
   ============================================================ */
/*
 * ============================================================
 * SKIFFO — Section Engagement RSE (fiche produit)
 * ============================================================
 */

/* ── Section ─────────────────────────────────────────────── */
.eco-sec {
  background: linear-gradient(105deg, rgba(10,25,20,.80) 0%, rgba(10,25,20,.38) 100%),
              url('/themes/do_fitwear/assets/img/products/PM_DJI_0266.jpg') center/cover no-repeat !important;
  padding: 120px 48px !important;
  display: block !important;
  width: 100% !important;
}
.eco-in {
  max-width: 1280px;
  margin: 0 auto;
  display: grid !important;
  grid-template-columns: 1fr 1.5fr;
  gap: 80px;
  align-items: center;
}

/* ── Gauche : titre ──────────────────────────────────────── */
.eco-left .label {
  color: var(--teal-light);
  display: inline-block;
  text-align: left;
  margin-bottom: 14px;
}
.eco-left h2 {
  font-family: "Plein", sans-serif;
  font-size: clamp(36px, 4vw, 54px);
  font-weight: 700;
  color: #fff !important;
  line-height: .94;
  margin-bottom: 22px;
}
.eco-left h2 em {
  color: var(--coral) !important;
  font-style: normal;
  display: block;
}
.eco-left p {
  font-size: 15px;
  color: rgba(255,255,255,.52) !important;
  line-height: 1.8;
  max-width: 360px;
}

/* ── Droite : piliers ────────────────────────────────────── */
.eco-pillars {
  display: flex;
  flex-direction: column;
}
.eco-pillar {
  display: flex;
  gap: 20px;
  align-items: flex-start;
  padding: 24px 0;
  border-bottom: 1px solid rgba(255,255,255,.07);
}
.eco-pillar:last-child {
  border-bottom: none;
  padding-bottom: 0;
}
.eco-pillar:first-child {
  padding-top: 0;
}
.eco-pillar-ico {
  width: 44px;
  height: 44px;
  flex-shrink: 0;
  background: rgba(177,212,207,.1);
  border: 1px solid rgba(177,212,207,.2);
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--teal-light);
  transition: background .2s, border-color .2s;
}
.eco-pillar:hover .eco-pillar-ico {
  background: rgba(177,212,207,.18);
  border-color: rgba(177,212,207,.4);
}
.eco-pillar-ico svg {
  width: 20px;
  height: 20px;
}
.eco-pillar-txt strong {
  display: block;
  font-family: "degular", sans-serif;
  font-size:16px;
  font-weight: 700;
  color: #fff !important;
  margin-bottom: 5px;
  letter-spacing: .3px;
}
.eco-pillar-txt p {
  font-size: 12px;
  color: rgba(255,255,255,.45) !important;
  line-height: 1.65;
  margin: 0;
}

/* ── Responsive ≤ 1023px ─────────────────────────────────── */
@media (max-width: 1023px) {
  .eco-sec { padding: 64px 24px !important; }
  .eco-in { gap: 48px; }
}

/* ── Responsive ≤ 767px ──────────────────────────────────── */
@media (max-width: 767px) {
  .eco-sec { padding: 56px 20px !important; }
  .eco-in { grid-template-columns: 1fr; gap: 36px; }
  .eco-left p { max-width: 100%; font-size: 14px; }
  .eco-left h2 { margin-bottom: 16px; }
  .eco-pillar { padding: 18px 0; gap: 16px; }
  .eco-pillar-ico { width: 38px; height: 38px; }
  .eco-pillar-ico svg { width: 17px; height: 17px; }
}


/* ============================================================
   SKIFFO — Page Panier (body.page-cart)
   Minimal — product title + CTA buttons
   ============================================================ */

/* ── Nom de produit dans la ligne panier ───────────────────── */
body.page-cart .product-line-info a.label {
  font-family: "degular", sans-serif;
  font-size: 14px;
  font-weight: 600;
  color: var(--navy);
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: .04em;
  border: none;
  padding: 0;
  background: transparent;
  display: inline;
  transition: color .2s;
}
body.page-cart .product-line-info a.label:hover { color: #e86e61; }

/* ── Bouton "Commander" ────────────────────────────────────── */
body.page-cart .checkout.cart-detailed-actions .btn-primary,
body.page-cart .cart-detailed-actions a.btn-primary,
body.page-cart .btn-primary {
  background: #e86e61;
  color: #fff;
  border: none;
  border-radius: 6px;
  font-family: "Poppins", sans-serif;
  font-size: 13px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .12em;
  padding: 14px 24px;
  transition: background .2s, transform .18s;
  cursor: pointer;
  text-decoration: none;
}
body.page-cart .checkout.cart-detailed-actions .btn-primary:hover,
body.page-cart .cart-detailed-actions a.btn-primary:hover,
body.page-cart .btn-primary:hover {
  background: #d45f53;
  transform: translateY(-2px);
}

/* ── Bouton "Continuer vos achats" (.continue.btn.btn-primary) */
body.page-cart .continue.btn.btn-primary,
body.page-cart .cart-grid-body > a.label {
  background: transparent !important;
  color: #e86e61 !important;
  border: 1.5px solid #e86e61 !important;
  border-radius: 6px !important;
  font-family: "Poppins", sans-serif !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: .1em !important;
  padding: 10px 20px !important;
  text-decoration: none !important;
  display: inline-flex !important;
  align-items: center !important;
  transition: background .2s, color .2s !important;
  transform: none !important;
}
body.page-cart .continue.btn.btn-primary:hover,
body.page-cart .cart-grid-body > a.label:hover {
  background: #e86e61 !important;
  color: #fff !important;
  transform: none !important;
}


/*
 * ============================================================
 * SKIFFO — Page About / Notre Histoire
 * Leo Dashboard → Custom CSS (Global) = skiffo-ALL-PAGES.css
 * Préfixe classes : ab- (évite tout conflit avec autres pages)
 * ============================================================
 */

/* ── Masquer le titre H1 généré par PrestaShop CMS (page ID 4) ── */
body.cms-id-4 .page-header,
body.cms-id-4 h1.page-heading,
body.cms-id-4 #js-product-list-header,
body.page-cms #content-wrapper > .container > h1:first-child,
body.page-cms .cms h1 { display: none !important; }

/* ── Masquer fil d'Ariane sur la page About ── */
body.cms-id-4 nav.breadcrumb,
body.cms-id-4 .breadcrumb-wrapper,
body.cms-id-4 #wrapper > nav { display: none !important; }

/* ── Supprimer padding PrestaShop sur le content wrapper about ── */
body.cms-id-4 #content-wrapper,
body.cms-id-4 #content { padding: 0 !important; max-width: none !important; }

/* ── Supprimer marge basse du wrapper PrestaShop ── */
body.cms-id-4 #wrapper { padding-bottom: 0 !important; margin-bottom: 0 !important; }

/* ── Neutraliser le wrapper Leo natif header#header (always transparent) ── */
/* Notre .hdr#H gère lui-même transparent → blanc via la classe .scrolled */
body.cms-id-4 header#header {
  background: transparent !important;
  background-color: transparent !important;
  box-shadow: none !important;
}

/* ── Utilitaires About ── */
.ab-label { font-family: "degular", sans-serif; font-size: 11px; font-weight: 700; letter-spacing: 4px; text-transform: uppercase; }
.ab-btn { display: inline-flex; align-items: center; gap: 10px; font-family: "degular", sans-serif; font-size: 13px; font-weight: 600; letter-spacing: 2px; text-transform: uppercase; padding: 14px 32px; border: none; cursor: pointer; border-radius: 0; transition: all .25s ease; text-decoration: none; }
.ab-btn-coral { background: var(--coral); color: #fff; }
.ab-btn-coral:hover { background: var(--coral-d); transform: translateY(-4px); color: #fff; }
.ab-btn-outline-d { background: transparent; color: var(--teal); border: 1.5px solid var(--teal); }
.ab-btn-outline-d:hover { background: var(--teal); color: #fff; transform: translateY(-4px); }
.ab-btn-outline-w { background: transparent; color: #fff; border: 1.5px solid rgba(255,255,255,.6); }
.ab-btn-outline-w:hover { background: rgba(255,255,255,.12); border-color: #fff; transform: translateY(-4px); color: #fff; }

/* ── Animations reveal ── */
.ab-reveal { opacity: 0; transform: translateY(28px); transition: opacity .7s ease, transform .7s ease; }
.ab-is-visible { opacity: 1; transform: translateY(0); }
.ab-reveal-d1 { transition-delay: .10s; }
.ab-reveal-d2 { transition-delay: .22s; }
.ab-reveal-d3 { transition-delay: .36s; }

/* 01 — HERO */
.ab-hero { position: relative; height: 100vh; min-height: 640px; overflow: hidden; display: flex; align-items: flex-end; }
.ab-hero-bg { position: absolute; inset: 0; }
.ab-hero-bg img { width: 100%; height: 100%; object-fit: cover; object-position: center 35%; transform: scale(1.06); transition: transform 10s cubic-bezier(0.25, 0.46, 0.45, 0.94); will-change: transform; }
.ab-hero.ab-is-loaded .ab-hero-bg img { transform: scale(1); }
.ab-hero-ov { position: absolute; inset: 0; background: linear-gradient(to bottom, rgba(10,20,20,.10) 0%, rgba(10,20,20,.06) 40%, rgba(10,20,20,.62) 78%, rgba(10,20,20,.82) 100%); }
.ab-hero-in { position: relative; z-index: 2; width: 100%; padding: 0 8% 80px; }
.ab-hero-label { color: var(--coral); display: block; margin-bottom: 20px; }
.ab-hero-title { font-family: 'Plein', sans-serif; font-weight: 900; font-size: clamp(44px, 5.5vw, 80px); line-height: .9; color: #fff; letter-spacing: -1.5px; margin-bottom: 28px; }
.ab-hero-title em { color: var(--coral); font-style: normal; display: block; }
.ab-hero-sub { font-family: "degular-text", sans-serif; font-weight: 400; font-size: clamp(16px, 1.4vw, 20px); color: rgba(255,255,255,.72); letter-spacing: .3px; max-width: 480px; line-height: 1.7; }
.ab-scroll-hint { position: absolute; bottom: 40px; right: 8%; display: flex; flex-direction: column; align-items: center; gap: 10px; color: rgba(255,255,255,.45); font-family: "degular", sans-serif; font-size: 9px; letter-spacing: 3px; text-transform: uppercase; writing-mode: vertical-rl; }
.ab-scroll-line { width: 1px; height: 48px; background: linear-gradient(to bottom, rgba(255,255,255,.5), transparent); animation: abScrollPulse 2.2s ease-in-out infinite; }
@keyframes abScrollPulse { 0%, 100% { opacity: .5; } 50% { opacity: 1; transform: scaleY(.6); transform-origin: top; } }

/* 02 — MANIFESTE */
.ab-manifeste { background: var(--offwhite); padding: 120px 8%; display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: center; }
.ab-mani-overline { color: var(--coral); margin-bottom: 28px; display: block; }
.ab-mani-quote { font-family: 'Plein', sans-serif; font-weight: 700; font-size: clamp(30px, 4vw, 54px); color: var(--text); line-height: 1.05; letter-spacing: -1px; }
.ab-mani-quote em { color: var(--coral); font-style: normal; }
.ab-mani-accent { display: block; width: 56px; height: 3px; background: var(--coral); margin-top: 36px; }
.ab-mani-body { font-family: "degular-text", sans-serif; font-size: 17px; line-height: 1.85; color: rgba(60,60,60,.78); font-weight: 300; }
.ab-mani-body strong { font-weight: 600; color: var(--text); }
.ab-mani-sign { font-family: 'Plein', sans-serif; font-weight: 400; font-size: 16px; color: var(--teal); letter-spacing: 2px; margin-top: 16px; display: block; }

/* 03 — ADN */
.ab-adn { background: var(--sand); padding: 110px 8%; }
.ab-adn-head { text-align: center; margin-bottom: 72px; }
.ab-adn-head .ab-label { color: var(--teal); display: block; margin-bottom: 16px; }
.ab-adn-head h2 { font-family: 'Plein', sans-serif; font-weight: 900; font-size: clamp(36px, 4vw, 56px); color: var(--text); letter-spacing: -1.5px; line-height: .96; }
.ab-adn-head h2 em { color: var(--coral); font-style: normal; }
.ab-adn-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
.ab-adn-card { background: var(--white); padding: 48px 36px 44px; position: relative; overflow: hidden; transition: transform .3s ease, box-shadow .3s ease; }
.ab-adn-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px; background: var(--teal-light); transition: background .3s ease; }
.ab-adn-card:hover { transform: translateY(-4px); box-shadow: 0 24px 60px rgba(0,0,0,.08); }
.ab-adn-card:hover::before { background: var(--coral); }
.ab-adn-icon { width: 52px; height: 52px; display: flex; align-items: center; justify-content: center; margin-bottom: 28px; color: var(--teal); transition: color .3s; }
.ab-adn-card:hover .ab-adn-icon { color: var(--coral); }
.ab-adn-card h3 { font-family: 'Plein', sans-serif; font-weight: 700; font-size: 19px; color: var(--text); letter-spacing: -.3px; margin-bottom: 14px; }
.ab-adn-card p { font-family: "degular-text", sans-serif; font-size: 15px; line-height: 1.75; color: rgba(60,60,60,.68); font-weight: 300; }
.ab-adn-num { position: absolute; bottom: 20px; right: 24px; font-family: 'Plein', sans-serif; font-weight: 900; font-size: 72px; color: rgba(0,0,0,.04); line-height: 1; transition: color .3s; }
.ab-adn-card:hover .ab-adn-num { color: rgba(232,110,97,.07); }

/* 04 — IMMERSIVE */
.ab-immersive { position: relative; height: 80vh; min-height: 560px; overflow: hidden; display: flex; align-items: center; }
.ab-immersive-bg { position: absolute; inset: 0; }
.ab-immersive-bg img { width: 100%; height: 100%; object-fit: cover; object-position: center 20%; }
.ab-immersive-ov { position: absolute; inset: 0; background: linear-gradient(to right, rgba(0,0,0,.65) 30%, rgba(0,0,0,.06) 80%); }
.ab-immersive-in { position: relative; z-index: 2; padding: 0 8%; max-width: 52%; }
.ab-immersive-in .ab-label { color: var(--teal-light); display: block; margin-bottom: 20px; }
.ab-immersive-in h2 { font-family: 'Plein', sans-serif; font-weight: 700; font-size: clamp(40px, 5.5vw, 72px); color: #fff; line-height: .95; margin-bottom: 26px; }
.ab-immersive-in h2 em { color: var(--coral); font-style: normal; }
.ab-immersive-in p { font-family: "degular-text", sans-serif; font-size: 17px; line-height: 1.8; color: rgba(255,255,255,.68); font-weight: 300; max-width: 420px; margin-bottom: 40px; }

/* 05 — STATS */
.ab-stats { background: var(--text); padding: 100px 8%; }
.ab-stats-inner { max-width: 1200px; margin: 0 auto; }
.ab-stats-eyebrow { font-family: "degular", sans-serif; font-size: 10px; font-weight: 700; letter-spacing: 5px; text-transform: uppercase; color: var(--muted); display: block; margin-bottom: 56px; }
.ab-stats-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; }
.ab-stat-item { padding-right: 40px; margin-right: 40px; border-right: 1px solid rgba(255,255,255,.08); }
.ab-stat-item:last-child { border-right: none; margin-right: 0; padding-right: 0; }
.ab-stat-num { font-family: 'Plein', sans-serif; font-weight: 900; font-size: clamp(38px, 4.2vw, 64px); color: var(--coral); line-height: .9; letter-spacing: -2px; display: block; margin-bottom: 14px; white-space: nowrap; }
.ab-stat-suffix { font-size: .38em; letter-spacing: 0; font-weight: 700; vertical-align: super; }
.ab-stat-desc { font-family: "degular-text", sans-serif; font-size: 17px; font-weight: 300; color: rgba(255,255,255,.9); line-height: 1.4; display: block; margin-bottom: 8px; }
.ab-stat-label { font-family: "degular", sans-serif; font-size: 10px; font-weight: 600; letter-spacing: 3px; text-transform: uppercase; color: rgba(255,255,255,.3); display: block; }

/* 06 — NORMES */
.ab-normes { background: var(--offwhite); padding: 110px 8%; display: grid; grid-template-columns: 1fr 1.4fr; gap: 80px; align-items: center; }
.ab-normes-left .ab-label { color: var(--teal); display: block; margin-bottom: 20px; }
.ab-normes-left h2 { font-family: 'Plein', sans-serif; font-weight: 900; font-size: clamp(32px, 3.6vw, 50px); color: var(--text); line-height: .94; letter-spacing: -1.5px; margin-bottom: 24px; }
.ab-normes-left h2 em { color: var(--coral); font-style: normal; }
.ab-normes-left p { font-family: "degular-text", sans-serif; font-size: 16px; line-height: 1.82; color: rgba(60,60,60,.7); font-weight: 300; }
.ab-normes-right { display: flex; flex-direction: column; gap: 4px; }
.ab-norme-item { display: flex; align-items: flex-start; gap: 24px; padding: 28px 32px; border: 1px solid rgba(112,164,159,.15); background: var(--white); transition: border-color .25s, transform .25s; position: relative; }
.ab-norme-item::before { content: ''; position: absolute; left: 0; top: 0; bottom: 0; width: 3px; background: var(--teal-light); transition: background .25s; }
.ab-norme-item:hover { transform: translateX(4px); border-color: rgba(232,110,97,.2); }
.ab-norme-item:hover::before { background: var(--coral); }
.ab-norme-icon { width: 44px; height: 44px; flex-shrink: 0; display: flex; align-items: center; justify-content: center; color: var(--teal); }
.ab-norme-icon svg { width: 28px; height: 28px; }
.ab-norme-txt strong { display: block; font-family: "degular", sans-serif; font-size: 12px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; color: var(--text); margin-bottom: 6px; }
.ab-norme-txt span { font-family: "degular-text", sans-serif; font-size: 14px; line-height: 1.68; color: rgba(60,60,60,.65); font-weight: 300; }

/* 07 — GAMME + MOSAÏQUE */
.ab-gamme { background: var(--white); padding: 110px 8%; display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: center; }
.ab-gamme-left .ab-label { color: var(--coral); display: block; margin-bottom: 20px; }
.ab-gamme-left h2 { font-family: 'Plein', sans-serif; font-weight: 900; font-size: clamp(36px, 4vw, 54px); color: var(--text); line-height: .94; letter-spacing: -1.5px; margin-bottom: 28px; }
.ab-gamme-left h2 em { color: var(--coral); font-style: normal; }
.ab-gamme-left p { font-family: "degular-text", sans-serif; font-size: 16px; line-height: 1.82; color: rgba(60,60,60,.72); font-weight: 300; max-width: 420px; margin-bottom: 40px; }
.ab-gamme-btns { display: flex; gap: 16px; flex-wrap: wrap; }
.ab-mosaic { display: grid; grid-template-columns: 1.3fr 1fr 1fr; grid-template-rows: 220px 160px 160px; gap: 6px; }
.ab-gm { overflow: hidden; position: relative; }
.ab-gm img { width: 100%; height: 100%; object-fit: cover; transition: transform .6s ease; display: block; }
.ab-gm:hover img { transform: scale(1.06); }
.ab-gm1 { grid-column: 1; grid-row: 1 / 4; }
.ab-gm2 { grid-column: 2 / 4; grid-row: 1; }
.ab-gm3 { grid-column: 2; grid-row: 2; }
.ab-gm4 { grid-column: 3; grid-row: 2; }
.ab-gm5 { grid-column: 2; grid-row: 3; }
.ab-gm6 { grid-column: 3; grid-row: 3; }

/* 08 — CTA */
.ab-cta { position: relative; overflow: hidden; background: var(--teal); padding: 100px 8%; text-align: center; }
.ab-cta-bg { position: absolute; inset: 0; opacity: .12; }
.ab-cta-bg img { width: 100%; height: 100%; object-fit: cover; }
.ab-cta-in { position: relative; z-index: 2; max-width: 700px; margin: 0 auto; }
.ab-cta-in .ab-label { color: rgba(255,255,255,.6); display: block; margin-bottom: 20px; }
.ab-cta-in h2 { font-family: 'Plein', sans-serif; font-weight: 700; font-size: clamp(40px, 5.5vw, 70px); color: #fff; line-height: .98; margin-bottom: 24px; }
.ab-cta-in h2 em { color: var(--sand); font-style: normal; }
.ab-cta-in p { font-family: "degular-text", sans-serif; font-size: 16px; line-height: 1.8; color: rgba(255,255,255,.7); font-weight: 300; max-width: 480px; margin: 0 auto 44px; }
.ab-cta-btns { display: flex; gap: 16px; justify-content: center; flex-wrap: wrap; }

/* RESPONSIVE */
@media (max-width: 900px) {
  .ab-hero-in { padding: 0 6% 64px; }
  .ab-scroll-hint { display: none; }
  .ab-manifeste { grid-template-columns: 1fr; gap: 40px; padding: 72px 6%; }
  .ab-adn-grid { grid-template-columns: 1fr; gap: 20px; }
  .ab-adn { padding: 72px 6%; }
  .ab-immersive-in { max-width: 80%; }
  .ab-normes { grid-template-columns: 1fr; gap: 40px; padding: 72px 6%; }
  .ab-gamme { grid-template-columns: 1fr; gap: 40px; padding: 72px 6%; }
  .ab-mosaic { grid-template-columns: 1fr 1fr; grid-template-rows: 200px 140px 140px; }
  .ab-gm1 { grid-column: 1 / 3; grid-row: 1; }
  .ab-gm2 { grid-column: 1; grid-row: 2; }
  .ab-gm3 { grid-column: 2; grid-row: 2; }
  .ab-gm4 { grid-column: 1; grid-row: 3; }
  .ab-gm5 { grid-column: 2; grid-row: 3; }
  .ab-gm6 { display: none; }
  .ab-stats-grid { grid-template-columns: repeat(2, 1fr); gap: 48px 0; }
  .ab-stat-item { border-right: none; margin-right: 0; padding-right: 0; border-bottom: 1px solid rgba(255,255,255,.07); padding-bottom: 40px; }
  .ab-stat-item:last-child, .ab-stat-item:nth-last-child(2) { border-bottom: none; }
  .ab-cta { padding: 72px 6%; }
}
@media (max-width: 600px) {
  .ab-hero-title { letter-spacing: -1px; }
  .ab-gamme-btns, .ab-cta-btns { flex-direction: column; align-items: center; }
  .ab-stats { padding: 72px 6%; }
  .ab-stat-num { font-size: clamp(36px, 10vw, 56px); }
  .ab-immersive-in { max-width: 90%; }
}


/* ════════════════════════════════════════════════════════════════════
   PAGE CATÉGORIE — Stand Up Paddle Gonflable
   /fr/content/stand-up-paddle-gonflable
   Sections : Hero · Gamme Nav · Bands · Cards · Divider · Reas · SEO
   Source section : prestashop-integration/12-page-categorie/categorie.css
   ════════════════════════════════════════════════════════════════════ */

/* ════════════════════════════════════════════
   PAGE CATÉGORIE — Masquage PrestaShop
   ⚠ Remplacer "cms-id-XX" par le vrai ID
     de la page une fois créée dans le BO
   ════════════════════════════════════════════ */

/* Masquer header.page-header natif PS (bande 36px au-dessus du hero) */
body.page-cms header.page-header,
body.page-cms .page-header,
body.page-cms h1.page-heading { display: none !important; }

/* Supprime TOUS les espacements PrestaShop sur pages CMS (hero custom) */
body.page-cms #wrapper,
body.page-cms #content-wrapper,
body.page-cms #content { padding: 0 !important; margin-top: 0 !important; max-width: none !important; }

/* Masquer le breadcrumb natif PS (on a le nôtre dans le hero) */
body.page-cms nav.breadcrumb,
body.page-cms .breadcrumb-wrapper,
body.page-cms #wrapper > nav { display: none !important; }

/* Hero-block : zéro marge résiduelle */
.cat-hero-block { display: block; margin: 0 !important; padding: 0 !important; }

/* ── Utilitaires ── */
.section-anchor { display: block; position: relative; top: -144px; visibility: hidden; }

/* ── 01 Hero ── */
.cat-hero { position: relative; height: 55vh; min-height: 420px; overflow: hidden; display: flex; align-items: flex-end; }
.cat-hero-bg { position: absolute; inset: 0; }
.cat-hero-bg img { width: 100%; height: 100%; object-fit: cover; object-position: center 35%; transform: scale(1.04); transition: transform 10s ease; }
.cat-hero:hover .cat-hero-bg img { transform: scale(1); }
.cat-hero-ov { position: absolute; inset: 0; background: linear-gradient(to top, rgba(0,0,0,.75) 0%, rgba(0,0,0,.1) 55%, rgba(0,0,0,.25) 100%); }
.cat-hero-in { position: relative; z-index: 2; width: 100%; padding: 0 80px 60px; }
.cat-breadcrumb { display: flex; align-items: center; gap: 10px; font-family: "degular", sans-serif; font-size: 10px; font-weight: 600; letter-spacing: 3px; text-transform: uppercase; color: rgba(255,255,255,.4); margin-bottom: 18px; }
.cat-breadcrumb a { color: rgba(255,255,255,.4); transition: color .2s; }
.cat-breadcrumb a:hover { color: #fff; }
.cat-breadcrumb-current { color: rgba(255,255,255,.7); }
.cat-hero-h { font-family: 'Plein', sans-serif; font-size: clamp(44px, 5.5vw, 76px); color: #fff; line-height: .9; font-weight: 900; letter-spacing: -1px; margin-bottom: 18px; }
.cat-hero-sub { font-size: 13px; color: rgba(255,255,255,.5); font-weight: 300; letter-spacing: .5px; margin-bottom: 30px; }
.cat-hero-meta { display: flex; align-items: center; gap: 32px; }
.cat-meta-item { display: flex; align-items: center; gap: 8px; font-family: "degular", sans-serif; font-size: 10px; font-weight: 600; letter-spacing: 2px; text-transform: uppercase; color: rgba(255,255,255,.55); }
.cat-meta-item svg { flex-shrink: 0; color: var(--teal-light); }

/* ── 02 Gamme Nav (sticky, blanc, tabs boutons, intégrée dans 01-cat-hero.html) ── */
.gamme-nav {
  position: sticky; top: 72px; z-index: 800;
  background: var(--white);
  border-bottom: 1px solid rgba(0,0,0,.07);
  box-shadow: 0 2px 12px rgba(0,0,0,.07);
}
.gamme-nav-in {
  max-width: 1440px; margin: 0 auto;
  padding: 0 80px;
  display: flex; align-items: center;
  gap: 10px;
  height: 60px;
}
/* Tab — vrai bouton outlined */
.gnav-tab {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 0 22px;
  height: 38px;
  font-family: "degular", sans-serif;
  font-size: 10px; font-weight: 700; letter-spacing: 2.5px; text-transform: uppercase;
  color: var(--muted);
  background: transparent;
  border: 1.5px solid rgba(112,164,159,.35);
  border-radius: 0;
  cursor: pointer;
  transition: all .2s ease;
  text-decoration: none;
  white-space: nowrap;
}
.gnav-tab:hover {
  color: var(--teal);
  border-color: var(--teal);
  background: rgba(190,217,212,.12);
}
/* Onglet actif — rempli coral */
.gnav-tab.active {
  color: #fff;
  background: var(--coral);
  border-color: var(--coral);
}
.gnav-tab.active svg { color: rgba(255,255,255,.75); }
.gnav-tab svg { color: var(--muted); transition: color .2s; }
.gnav-price {
  font-weight: 400; letter-spacing: 0; text-transform: none;
  font-size: 10px; opacity: .65; margin-left: 2px;
}
.gnav-sep { width: 1px; height: 28px; background: rgba(0,0,0,.1); flex-shrink: 0; }
/* Infos à droite */
.gnav-right {
  margin-left: auto; display: flex; align-items: center; gap: 8px;
  font-family: "degular", sans-serif;
  font-size: 11px; font-weight: 400; letter-spacing: .3px;
  color: var(--muted);
}
.gnav-right svg { color: var(--teal-light); flex-shrink: 0; }
.gnav-count { font-family: "degular", sans-serif; font-size: 10px; font-weight: 600; letter-spacing: 1.5px; text-transform: uppercase; color: var(--muted); }

/* ── 03 Collector Band ── */
.cat-collector-band { position: relative; height: 400px; overflow: hidden; display: grid; grid-template-columns: 1fr 1fr; }
.ccb-photo { position: relative; overflow: hidden; }
.ccb-photo img { width: 100%; height: 100%; object-fit: cover; object-position: center 30%; transition: transform 8s ease; }
.cat-collector-band:hover .ccb-photo img { transform: scale(1.06); }
.ccb-photo-ov { position: absolute; inset: 0; background: linear-gradient(to right, rgba(0,0,0,.45) 0%, rgba(0,0,0,0) 65%); }
.ccb-content { display: flex; flex-direction: column; justify-content: center; padding: 52px 64px; background: #3d7a75; }
.ccb-badge { display: inline-flex; align-items: center; font-family: "degular", sans-serif; font-size: 9px; font-weight: 700; letter-spacing: 3.5px; text-transform: uppercase; padding: 5px 14px; background: var(--coral); color: #fff; margin-bottom: 24px; width: fit-content; }
.ccb-h { font-family: 'Plein', sans-serif; font-size: clamp(30px, 2.8vw, 46px); color: #fff; font-weight: 900; line-height: .9; letter-spacing: -.5px; margin-bottom: 16px; }
.ccb-p { font-size: 14px; color: rgba(255,255,255,.55); line-height: 1.8; max-width: 340px; }

/* ── 04 Product Section (shared wrapper) ── */
.cat-prod-section { padding: 48px 80px 64px; background: var(--white); }
.cat-prod-section.on-sand { background: var(--offwhite); }
.cat-ps-header { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 36px; }
.cat-ps-label { font-family: "degular", sans-serif; font-size: 10px; font-weight: 700; letter-spacing: 3.5px; text-transform: uppercase; color: var(--muted); }
.cat-ps-count { font-size: 12px; color: rgba(112,164,159,.4); font-family: "degular", sans-serif; }
.cat-prod-grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; }
.cat-prod-grid-2c { display: flex; justify-content: center; gap: 20px; }
.cat-prod-grid-2c .cat-pc { flex: 0 0 calc(25% - 10px); max-width: calc(25% - 10px); }
.cat-pc { background: var(--white); overflow: hidden; box-shadow: 0 2px 18px rgba(106,162,158,.08); transition: box-shadow .3s, transform .3s; cursor: pointer; display: flex; flex-direction: column; text-decoration: none; color: var(--text); }
.cat-pc:hover { box-shadow: 0 14px 44px rgba(106,162,158,.18); transform: translateY(-4px); }
.cat-pc-img { position: relative; aspect-ratio: 3/4; overflow: hidden; background: var(--sand); }
.cat-pc-img img { width: 100%; height: 100%; object-fit: cover; object-position: center top; transition: transform .7s ease; }
.cat-pc:hover .cat-pc-img img { transform: scale(1.05); }
.cat-pc-badge { position: absolute; top: 12px; left: 12px; font-family: "degular", sans-serif; font-size: 8px; font-weight: 700; letter-spacing: 2.5px; text-transform: uppercase; padding: 4px 10px; color: #fff; z-index: 2; }
.cat-pc-badge.coral { background: var(--coral); }
.cat-pc-badge.teal  { background: var(--teal); }
.cat-pc-swatch-row { position: absolute; bottom: 12px; right: 12px; display: flex; gap: 5px; z-index: 2; }
.cat-pc-swatch { width: 13px; height: 13px; border-radius: 50%; border: 2px solid rgba(255,255,255,.9); box-shadow: 0 1px 5px rgba(0,0,0,.3); }
.cat-pc-body { padding: 18px 20px 22px; flex: 1; display: flex; flex-direction: column; }
.cat-pc-name { font-family: 'Plein', sans-serif; font-size: 16px; font-weight: 700; color: var(--text); margin-bottom: 4px; letter-spacing: -.2px; }
.cat-pc-sub { font-size: 11px; color: var(--muted); margin-bottom: auto; padding-bottom: 14px; line-height: 1.5; }
.cat-pc-foot { display: flex; align-items: center; justify-content: space-between; padding-top: 14px; border-top: 1px solid rgba(106,162,158,.12); }
.cat-pc-price { font-family: "degular", sans-serif; font-size: 21px; font-weight: 700; color: var(--coral); line-height: 1; }
.cat-pc-price-note { font-size: 10px; color: rgba(112,164,159,.5); display: block; margin-top: 2px; }
.cat-pc-cta { font-family: "degular", sans-serif; font-size: 9px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; padding: 10px 18px; background: var(--coral); color: #fff; border: none; cursor: pointer; border-radius: 0; transition: background .2s, transform .2s; white-space: nowrap; display: inline-block; }
.cat-pc-cta:hover { background: var(--coral-d); transform: translateY(-1px); }
.cat-btn { display: inline-flex; align-items: center; gap: 10px; font-family: "degular", sans-serif; font-size: 11px; font-weight: 700; letter-spacing: 3px; text-transform: uppercase; padding: 14px 32px; border: none; cursor: pointer; border-radius: 0; transition: all .25s ease; text-decoration: none; width: fit-content; }
.cat-btn-coral { background: var(--coral); color: #fff; }
.cat-btn-coral:hover { background: var(--coral-d); transform: translateY(-2px); }

/* ── 05 Divider Pack ── */
.cat-divider { position: relative; overflow: hidden; min-height: 280px; display: flex; flex-direction: column; align-items: center; justify-content: center; padding: 56px 80px 52px; }
.cat-divider-bg { position: absolute; inset: 0; }
.cat-divider-bg img { width: 100%; height: 100%; object-fit: cover; object-position: center 30%; }
.cat-divider-ov { position: absolute; inset: 0; background: rgba(40,92,88,.85); }
.cat-divider-txt { position: relative; z-index: 2; text-align: center; margin-bottom: 44px; }
.cat-divider-txt p { font-family: 'Plein', sans-serif; font-size: clamp(24px, 3vw, 40px); color: #fff; font-weight: 900; letter-spacing: -.5px; }
.cat-divider-txt span { font-family: "degular", sans-serif; font-size: 10px; font-weight: 600; letter-spacing: 4px; text-transform: uppercase; color: rgba(255,255,255,.4); display: block; margin-top: 12px; }
.cat-pack-row { position: relative; z-index: 2; display: flex; align-items: center; width: 100%; max-width: 900px; }
.cat-pack-caption { font-family: "degular", sans-serif; font-size: 9px; font-weight: 700; letter-spacing: 3.5px; text-transform: uppercase; color: rgba(255,255,255,.35); white-space: nowrap; margin-right: 32px; flex-shrink: 0; }
.cat-pack-items { display: flex; justify-content: space-between; align-items: center; gap: 10px; flex: 1; }
.cat-pi { position: relative; display: flex; align-items: center; justify-content: center; z-index: 10; }
.cat-pi-circle { width: 58px; height: 58px; border-radius: 50%; border: 1.5px solid rgba(255,255,255,.22); display: flex; align-items: center; justify-content: center; transition: background .25s, border-color .25s, transform .25s; cursor: default; }
.cat-pi:hover .cat-pi-circle { background: var(--coral); border-color: var(--coral); transform: translateY(-3px); }
/* Icône CSS mask — même technique que les accessoires homepage */
.cat-pi-icon { display: block; width: 26px; height: 26px; background-color: rgba(255,255,255,.65); -webkit-mask-image: var(--icon); mask-image: var(--icon); -webkit-mask-repeat: no-repeat; mask-repeat: no-repeat; -webkit-mask-position: center; mask-position: center; -webkit-mask-size: contain; mask-size: contain; transition: background-color .22s; }
.cat-pi:hover .cat-pi-icon { background-color: #fff; }
.cat-pi-lbl { position: absolute; bottom: calc(100% + 10px); left: 50%; transform: translateX(-50%) translateY(4px); background: rgba(0,0,0,.75); color: #fff; font-family: "degular", sans-serif; font-size: 10px; font-weight: 600; white-space: nowrap; padding: 5px 12px; opacity: 0; pointer-events: none; transition: opacity .2s, transform .2s; z-index: 20; }
.cat-pi-lbl::after { content: ''; position: absolute; top: 100%; left: 50%; transform: translateX(-50%); border: 5px solid transparent; border-top-color: rgba(0,0,0,.75); }
.cat-pi:hover .cat-pi-lbl { opacity: 1; transform: translateX(-50%) translateY(0); }

/* ── 06 Rivage Band ── */
.cat-rivage-band { position: relative; height: 400px; overflow: hidden; display: grid; grid-template-columns: 1fr 1fr; }
.crb-content { display: flex; flex-direction: column; justify-content: center; padding: 52px 64px; background: var(--sand); }
.crb-badge { display: inline-flex; align-items: center; font-family: "degular", sans-serif; font-size: 9px; font-weight: 700; letter-spacing: 3.5px; text-transform: uppercase; padding: 5px 14px; background: var(--teal); color: #fff; margin-bottom: 24px; width: fit-content; }
.crb-h { font-family: 'Plein', sans-serif; font-size: clamp(30px, 2.8vw, 46px); color: #3d7a75; font-weight: 900; line-height: .9; letter-spacing: -.5px; margin-bottom: 16px; }
.crb-p { font-size: 14px; color: rgba(42,87,84,.58); line-height: 1.8; max-width: 340px; margin-bottom: 28px; }
.crb-photo { position: relative; overflow: hidden; }
.crb-photo img { width: 100%; height: 100%; object-fit: cover; object-position: center 25%; transition: transform 8s ease; }
.cat-rivage-band:hover .crb-photo img { transform: scale(1.06); }
.crb-photo-ov { position: absolute; inset: 0; background: linear-gradient(to left, rgba(0,0,0,.35) 0%, rgba(0,0,0,0) 65%); }

/* ── 08 Réassurance ── */
.cat-reas { background: var(--teal); }
.cat-reas-grid { display: grid; grid-template-columns: repeat(4, 1fr); max-width: 1280px; margin: 0 auto; }
.cat-reas-item { display: flex; align-items: center; gap: 18px; padding: 30px 40px; border-right: 1px solid rgba(255,255,255,.12); }
.cat-reas-item:last-child { border-right: none; }
.cat-r-ico { width: 32px; height: 32px; flex-shrink: 0; color: var(--teal-light); }
.cat-r-ico svg { width: 100%; height: 100%; }
.cat-r-txt h4 { font-family: "degular", sans-serif; font-size: 12px; font-weight: 700; color: #fff; margin-bottom: 3px; }
.cat-r-txt p { font-size: 11px; color: rgba(255,255,255,.38); line-height: 1.45; }

/* ── 09 SEO Block ── */
.cat-seo { background: var(--offwhite); padding: 72px 80px; }
.cat-seo-in { max-width: 820px; margin: 0 auto; }
.cat-seo-in h2 { font-family: 'Plein', sans-serif; font-size: 22px; font-weight: 700; color: var(--text); margin-bottom: 20px; line-height: 1.2; }
.cat-seo-in p { font-size: 14px; color: rgba(60,60,60,.5); line-height: 1.95; margin-bottom: 14px; }

/* ── Responsive tablette (≤1023px) ── */
@media (max-width: 1023px) {
  .cat-hero-in { padding: 0 40px 48px; }
  .gamme-nav-in { padding: 0 24px; }
  .gnav-tab { padding: 0 18px; height: 50px; }
  .gnav-price { display: none; }
  .gnav-right { display: none; }
  .cat-collector-band, .cat-rivage-band { grid-template-columns: 1fr; height: auto; }
  .ccb-photo, .crb-photo { height: 260px; }
  .ccb-content, .crb-content { padding: 40px; }
  .cat-prod-section { padding: 36px 40px 48px; }
  .cat-prod-grid-4 { grid-template-columns: repeat(2, 1fr); }
  .cat-prod-grid-2c .cat-pc { flex: 0 0 calc(50% - 10px); max-width: calc(50% - 10px); }
  .cat-divider { padding: 48px 40px; }
  .cat-pack-caption { display: none; }
  .cat-reas-grid { grid-template-columns: repeat(2, 1fr); }
  .cat-reas-item { border-right: none; border-bottom: 1px solid rgba(255,255,255,.1); }
  .cat-seo { padding: 56px 40px; }
}

/* ── Responsive mobile (≤767px) ── */
@media (max-width: 767px) {
  .cat-hero { height: 65vw; min-height: 340px; }
  .cat-hero-in { padding: 0 24px 36px; }
  .cat-hero-meta { flex-wrap: wrap; gap: 14px; }
  .gamme-nav-in { padding: 0 8px; }
  .gnav-tab { padding: 0 12px; height: 46px; letter-spacing: 1.5px; font-size: 9px; }
  .cat-prod-section { padding: 28px 20px 40px; }
  .cat-prod-grid-4 { grid-template-columns: repeat(2, 1fr); gap: 12px; }
  .cat-prod-grid-2c .cat-pc { flex: 0 0 calc(50% - 6px); max-width: calc(50% - 6px); }
  .cat-divider { padding: 40px 20px; }
  .cat-pack-items { gap: 6px; }
  .cat-pi-circle { width: 46px; height: 46px; }
  .cat-reas-grid { grid-template-columns: 1fr; }
  .cat-reas-item { padding: 20px 24px; }
  .cat-seo { padding: 40px 20px; }
  .ccb-content, .crb-content { padding: 32px 24px; }
}
