/********************************************************
  1) GLOBAL — SOCLE AMUP
********************************************************/

/* =====================================================
   1.1 — SUPPRESSION SIDEBARS + PLEIN ÉCRAN
===================================================== */

#left-sidebar,
#right-sidebar,
#secondary,
.sidebar-container {
    display: none !important;
}

#outer-wrap,
#wrap,
#main,
#content-wrap,
#primary,
.site-main,
.content-area {
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* Conteneur interne — respiration minimale */
.container {
    max-width: 100% !important;
    padding-left: 8px !important;
    padding-right: 8px !important;
}


/* =====================================================
   1.2 — TITRES GÉNÉRAUX
===================================================== */

.page-header,
.oceanwp-page-header {
    margin: 0 !important;
    padding: 0 !important;
}


/* =====================================================
   1.3 — MENU OCEANWP : COULEURS & HOVER
===================================================== */

#site-navigation-wrap .dropdown-menu > li.current-menu-item > a,
#site-navigation-wrap .dropdown-menu > li.current-menu-ancestor > a {
    border-color: #7bc3a4 !important;
}

#site-navigation-wrap .dropdown-menu > li > a:hover {
    border-color: #7bc3a4 !important;
    color: #7bc3a4 !important;
}

#site-navigation-wrap .dropdown-menu ul.sub-menu {
    border-top: 3px solid #7bc3a4 !important;
}

#site-logo #site-logo-inner a:hover {
    color: #87c9a5 !important;
}



/* =====================================================
   1.4 — HEADER : TRANSPARENCE TOTALE
===================================================== */

#site-header,
#site-header-wrap,
#site-navigation-wrap,
#top-bar,
#top-bar-wrap {
    background: transparent !important;
    box-shadow: none !important;
}


/* =========================================
   MOBILE MENU — FOND DYNAMIQUE JS
========================================= */

@media (max-width:1024px){

  /* 1) PANNEAU PRINCIPAL */
  .mobmenu-left-panel{
      background: var(--amup-mobmenu-bg) !important;
      background-color: var(--amup-mobmenu-bg) !important;
  }

  /* 2) CONTENEUR INTERNE */
  .mobmenu-left-panel .mobmenu-content{
      background: var(--amup-mobmenu-bg) !important;
      background-color: var(--amup-mobmenu-bg) !important;
  }

  /* 3) SOUS-MENUS */
  .mobmenu-left-panel .sub-menu,
  .mobmenu-left-panel ul{
      background: var(--amup-mobmenu-bg) !important;
      background-color: var(--amup-mobmenu-bg) !important;
  }

  /* 4) ITEMS */
  .mobmenu-left-panel li{
      background: var(--amup-mobmenu-bg) !important;
  }

  /* 5) LIENS */
  .mobmenu-left-panel li > a{
      background: var(--amup-mobmenu-bg) !important;
      color: var(--amup-mobmenu-text) !important;
  }

  /* 6) HOVER / ACTIF */
  .mobmenu-left-panel li > a:hover,
  .mobmenu-left-panel li.current-menu-item > a,
  .mobmenu-left-panel li.current-menu-ancestor > a{
      background: var(--amup-mobmenu-highlight) !important;
      color: #ffffff !important;
  }

}


/* =====================================================
   1.5 — SOCLE GLOBAL PAGES À FOND JS
===================================================== */

body.amup-bg-js {
    background: transparent !important;
}

body.amup-bg-js #outer-wrap,
body.amup-bg-js #wrap,
body.amup-bg-js #main {
    margin-top: 0 !important;
    padding-top: 0 !important;
}


/********************************************************
  2) COMPOSANTS VISUELS
********************************************************/

/* =====================================================
   2.1 — HERO / TITRE AVEC LOGO
===================================================== */

.am-hero-wrap {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    align-items: center;
    width: 100%;
    margin: 40px 0;

    color: #ffffff;
    font-weight: 800;

    text-shadow:
        0 4px 10px rgba(0,0,0,0.65),
        0 0 2px rgba(0,0,0,0.6);
}

.am-hero-wrap > .am-hero-text:first-of-type {
    justify-self: end;
    text-align: right;
    padding-right: 2vw;
}

.am-hero-wrap > .am-hero-text:last-of-type {
    justify-self: start;
    text-align: left;
    padding-left: 2vw;
}

.am-hero-text {
    font-size: clamp(24px, 3vw, 60px);
}

.am-hero-logo {
    justify-self: center;
    width: clamp(80px, 12vw, 260px);
    height: auto;
}


/* =====================================================
   2.2 — GALERIES : TEXTE UNIQUEMENT
===================================================== */

body.am-galerie .am-accordion,
body.am-galerie .am-accordion-inner {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 40px;
}


/* =====================================================
   2.3 — ZOOM : GESTES
===================================================== */

.zoom-img {
    transition: transform 0.25s ease-out;
    cursor: grab;
    touch-action: none;
}

.zoom-img:active {
    cursor: grabbing;
}


/* =====================================================
   2.4 — ACCORDÉON
===================================================== */

.am-accordion {
    margin: 4rem auto 3rem;
    padding: 0 6vw;
    text-align: center;
}

.am-accordion-toggle {
    width: 100%;
    background: transparent;
    border: none;
    border-bottom: 1px solid rgba(255,255,255,0.25);
    padding: 1.2rem 0;
    display: flex;
    justify-content: space-between;
    cursor: pointer;
}

.am-accordion-title {
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    opacity: 0.7;
}

/* =====================================================
   2.4.1 ACCORDÉON — COMPORTEMENT OUVERT / FERMÉ
===================================================== */

/* Fermé par défaut */
.am-accordion-content {
    display: none;
}


/********************************************************
  3) FOOTER — OCEANWP (CORRECTIFS AMUP)
********************************************************/

/* =====================================================
   3.1 — SUPPRESSION DES WIDGETS FOOTER
===================================================== */

#footer-widgets,
#footer-widgets.oceanwp-row,
#footer-widgets.clr {
    display: none !important;
    height: 0 !important;
    min-height: 0 !important;
    padding: 0 !important;
    margin: 0 !important;
    background: transparent !important;
}

#footer-widgets *,
.footer-widgets-inner,
.footer-box {
    display: none !important;
}


/* =====================================================
   3.2 — FOOTER & COPYRIGHT CONSERVÉS
===================================================== */

#footer,
#footer-inner,
#footer-bottom {
    background: transparent !important;
    box-shadow: none !important;
    min-height: 0 !important;
    padding-top: 0 !important;
    padding-bottom: 20vh !important;
}


/********************************************************
  4) MOBILE — SÉCURITÉ VIEWPORT
********************************************************/

@media (max-width: 768px) {

    html,
    body {
        overflow-x: hidden;
    }

    .pulse-btn.amup-next-page {
        top: 20px;
        right: 20px;
        width: 44px;
        height: 44px;
        font-size: 22px;
    }

    .am-hero-wrap{
        display:grid;
        grid-template-columns: 1fr;
        text-align:center;
        gap:8px;
        margin:20px 0;
        /*padding-top: calc(env(safe-area-inset-top) + 30px);*/
    }

    .am-hero-wrap > .am-hero-text:first-of-type,
    .am-hero-wrap > .am-hero-text:last-of-type{
        justify-self:center;
        text-align:center;
        padding:0;
    }

    .am-hero-logo{
        justify-self:center;
    }

    .am-hero-text{
        line-height:1.1;
    }
}

/********************************************************
  Mobile home slogan
********************************************************/
@media (max-width: 768px) {

  body.home .am-hero-wrap {
      display: grid !important;
      grid-template-columns: 1fr !important;
  }

}

/********************************************************
  5) LIENS CTA ACCORDÉON
********************************************************/

.am-accordion-presentation a{
    display:inline-block;
    padding:8px 18px;
    color:#2a2a2a;
    font-weight:600;
    border:2px solid rgba(70,110,100,0.9);
    border-radius:8px;
    text-decoration:none;
    transition:
        color 0.25s ease,
        border-color 0.25s ease,
        background 0.25s ease;
}

.am-accordion-presentation a:hover{
    color:#2b6cff;
    border-color:#2b6cff;
    background:rgba(43,108,255,0.08);
}

.am-accordion-presentation a:visited{
    color:#2a2a2a;
}

.am-accordion-presentation a *{
    background:none !important;
}

/* ======================================================
   5b) AMUP — PRESENTATION ACCESSIBILITÉ (EXTERNE PROPRE)
====================================================== */

/* ------------------------------------------------------
   a1) Le panneau devient la référence
------------------------------------------------------ */
.am-accordion-panel{
  position:relative;
  overflow:visible; /* autorise sortie à gauche */
}
/* ------------------------------------------------------
   a2) Zone hover invisible à gauche
   Permet de survoler les boutons sans quitter le panneau
------------------------------------------------------ */
.am-accordion-panel::before{
  content:"";
  position:absolute;
  left:-90px;   /* largeur zone hover gauche */
  top:0;
  width:90px;
  height:100%;
  background:transparent;
}

/* =====================================================
   AMUP — OUTILS DESCRIPTION (VERSION PROPRE STABLE)
   - même comportement desktop / mobile
   - invisible par défaut
   - visible uniquement si JS ajoute .is-visible
===================================================== */

/* conteneur boutons */
.amup-pres-tools{
  position:fixed;
  left:8px;
  top:50%;
  transform:translateY(-50%);
  z-index:9999;

  display:flex;
  flex-direction:column;
  gap:16px;

  opacity:0;
  pointer-events:none;
  transition:opacity .25s ease;
}

/* état visible (piloté par JS) */
.amup-pres-tools.is-visible{
  opacity:1;
  pointer-events:auto;
}


/* -----------------------------------------------------
   BOUTONS
----------------------------------------------------- */
.amup-pres-tools button{
  width:42px;
  height:42px;
  border-radius:50%;
  border:3px solid #e21c00;
  background:transparent;
  color:#111;
  font-size:18px;
  font-weight:600;

  display:flex;
  align-items:center;
  justify-content:center;

  cursor:pointer;
  position:relative;

  transition:
    background .2s ease,
    transform .15s ease;
}

.amup-pres-tools button:hover{
  background:rgba(255,255,255,0.9);
  transform:scale(1.05);
}


/* -----------------------------------------------------
   TOOLTIP
----------------------------------------------------- */
.amup-tip{
  position:absolute;
  left:120%;
  top:50%;
  transform:translateY(-50%);
  background:rgba(0,0,0,0.9);
  color:#fff;
  padding:6px 10px;
  border-radius:8px;
  font-size:12px;
  white-space:nowrap;
  opacity:0;
  pointer-events:none;
  transition:opacity .2s ease;
  z-index:10000;
}

.amup-pres-tools button:hover .amup-tip{
  opacity:1;
}


/* -----------------------------------------------------
   MOBILE — simplification visuelle
----------------------------------------------------- */
@media (max-width:768px){

  .amup-tip{
    display:none;
  }

  .am-accordion-panel > div[itemprop="description"]{
    padding-left:60px;
  }

}
/* ------------------------------------------------------
   MODE ¶ : utilise la couleur highlight du mobile menu
------------------------------------------------------ */
.amup-pres-opaque{
  background: var(--amup-pres-opaque-bg, rgba(255,255,255,0.94)) !important;
  border-radius:16px !important;
  padding:18px !important;
}

/* =========================================
    6) AMUP — SELECT GALERIES (VERSION PREMIUM)
========================================= */

.am-galeries-dropdown{
  max-width:600px;
  margin:60px auto;
  text-align:center;
}

.am-galeries-label{
  display:block;
  margin-bottom:20px;
  font-weight:700;
  letter-spacing:0.12em;
  text-transform:uppercase;
  font-size:14px;
  opacity:0.65;
}

/* wrapper esthétique */
.am-galeries-select{
  width:100%;
  padding:18px 50px 18px 24px;

  font-size:18px;
  font-weight:600;

  border:2px solid rgba(70,110,100,0.8);
  border-radius:16px;

  /*background:*/
   /* linear-gradient(to bottom, rgba(255,255,255,0.95), rgba(255,255,255,0.92));*/

 /* appearance:none;
  -webkit-appearance:none;
  -moz-appearance:none;*/

  cursor:pointer;
  transition:all 0.25s ease;
}

/* flèche custom */
.am-galeries-select{
  background-image:url("data:image/svg+xml;utf8,\
  <svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'>\
  <path d='M6 9l6 6 6-6' fill='none' stroke='%23466e64' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'/>\
  </svg>");
  background-repeat:no-repeat;
  background-position:right 18px center;
  background-size:18px;
}

.am-galeries-select:hover{
  border-color:#2b6cff;
}

.am-galeries-select:focus{
  outline:none;
  border-color:#2b6cff;
  box-shadow:0 0 0 4px rgba(43,108,255,0.12);
}


/* =========================================
   RÉACTIVATION FOOTER UNIQUEMENT SUR 2 PAGES
========================================= */

body.page-messages-recus-publies #footer-widgets,
body.page-form_message #footer-widgets {
    display: block !important;
    height: auto !important;
    min-height: auto !important;
}

body.page-messages-recus-publies #footer-widgets *,
body.page-form_message #footer-widgets * {
    display: revert !important;
}


/* =========================================
   AMUP — DROPDOWN GALERIES
========================================= */

.am-dropdown {
    position: relative;
    max-width: 600px;
    margin: 40px auto;
}

.am-dropdown-list {
    list-style: none;
    padding: 0;
    margin: 8px 0 0 0;
    max-height: 300px;
    overflow-y: auto;
    display: none;
    z-index: 9999;
}

.am-dropdown.open .am-dropdown-list {
    display: block;
}

.am-dropdown-list li {
    padding: 14px 20px;
    cursor: pointer;
    transition: background 0.2s ease;
}

.am-dropdown-list li:hover {
    background: rgba(43,108,255,0.08);
}

/* =====================================================
   AMUP — H1 SEO MASQUÉ (visible Google, invisible visuel)
===================================================== */
.am-seo-hidden{
    position:absolute !important;
    width:1px;
    height:1px;
    padding:0;
    margin:-1px;
    overflow:hidden;
    clip:rect(0,0,0,0);
    white-space:nowrap;
    border:0;
}

/* =====================================================
   ZOOM — ESPACE AVANT COPYRIGHT
===================================================== */

body.page-zoom #footer-bottom {
    margin-top: 120px !important;
}

/* FIX DRAG MOBILE ZOOM */
.amup-zoom-root img{
  touch-action: none;
}

/* ZOOM — autorise le drag mobile (sans scroll natif) */
body.amup-zoom-active .amup-zoom-root .zoom-slide-item.is-active img{
  touch-action: none; /* indispensable pour pointermove sur iOS */
}


/********************************************************
  AMUP — SLOGAN2 (GIF + LOGO SUPERPOSÉ)
  Extension du système existant (sans doublon)
********************************************************/

/* conteneur remplaçant l'image centrale */

.am-hero-wrap--slogan2 .am-logo-stack{

    position: relative;

    justify-self: center;

    width: clamp(80px, 12vw, 260px);
    aspect-ratio: 1 / 1;

}


/* GIF animé */

.am-hero-wrap--slogan2 .am-logo-gif{

    position: absolute;
    inset: 0;

    width: 100%;
    height: 100%;

    object-fit: cover;

    border-radius: 50%;

    z-index: 1;

}


/* le logo utilise toujours .am-hero-logo existant */

.am-hero-wrap--slogan2 .am-logo-stack .am-hero-logo{

    position: absolute;
    inset: 0;

    width: 100%;
    height: 100%;

    object-fit: contain;

    z-index: 2;

    pointer-events: none;

}
/* =====================================================
   TOOLTIP BOUTON NAVIGATION
===================================================== */

/* =====================================================
   TOOLTIP BOUTON NAVIGATION
   Compatible avec le bouton .pulse-btn.amup-next-page
===================================================== */

.pulse-btn.amup-next-page{
  position:fixed;
}

.pulse-btn.amup-next-page::after{

  content: attr(data-tooltip);

  position:absolute;
  right:calc(100% + 10px);
  top:50%;
  transform:translateY(-50%);

  background:rgba(0,0,0,0.9);
  color:#fff;

  font-size:13px;
  padding:8px 14px;

  border-radius:20px;

  white-space:nowrap;

  opacity:0;
  pointer-events:none;

  transition:opacity .2s ease, transform .2s ease;
  z-index:999999;
}

.pulse-btn.amup-next-page:hover::after{
  opacity:1;
  transform:translateY(-50%);
}