/* Fade-in JS */
.to-load { opacity: 0; transform: translatey(-50px); transition: opacity 240ms ease, transform 300ms ease;}
.to-load.loaded { opacity: 1 !important; transform: translatey(0px) !important; transition: opacity 240ms ease, transform 300ms ease ; }

.to-load-slow { opacity: 0; transform: translatey(50px); transition: opacity 540ms ease, transform 400ms ease;}
.to-load-slow.loaded { opacity: 1 !important; transform: translatey(0px) !important; transition: opacity 540ms ease, transform 400ms ease ; }

.summary.entry-summary.to-load { opacity: 0; transform: translatex(50px) !important; transition: opacity 240ms ease, transform 300ms ease;}
.summary.entry-summary.to-load.loaded { opacity: 1 !important; transform: translatex(0px) !important; transition: opacity 240ms ease, transform 300ms ease !important; }

.hob-reassurance-item {
    font-size: 14px;
    letter-spacing: 0.01em;
    color: var(--hob-bm-muted);
    display: flex;
}
.hob-reassurance-ico {
    width: 35px;
    max-width: 35px;
    height: auto;
    display: block;

}
.hob-bm__reassurance {
    padding: 28px 34px 24px 34px;
}

.hob-reassurance-inner {
    display: grid;
    gap: 24px;
    margin-bottom: 30px;
}

.hob-reassurance-img-container {
    min-width: 40px;
    width: 40px;
	    margin-right: 7px;
}
/* Icônes réassurance */
.hob-reassurance-ico {
    width: 26px;
    max-width: 26px;
    opacity: 0.75;
    height: auto;

}

.hob-reassurance-ico--artisanat {
    width: 22px;
    max-width: 22px;
    left: 2px;
    position: relative;
}


.hob-payments{
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: nowrap;
}

.hob-payments__img{
  width: 28px;
  max-width: 28px;
  height: auto;
  display: block;
}


#qodef-back-to-top {
    bottom: 100px;
}


.long-reassurance .hob-reassurance-img-container {
    min-width: auto;
    width: auto;
    margin-right: 12px;
}

.long-reassurance .hob-reassurance-ico {
    width: 32px;
    max-width: 32px;
    opacity: 0.75;
    height: auto;
}

.long-reassurance .hob-reassurance-ico--artisanat {
    width: 27px;
    max-width: 27px;
    left: 2px;
    position: relative;
}

.hob-reassurance-item-long {
    font-size: 14px;
    letter-spacing: 0.01em;
    color: var(--hob-bm-muted);
    display: flex;
    width: 100%;
    align-items: center;
    gap: 3px;
    justify-content: flex-start;
    flex-wrap: wrap;
    max-width: 380px;
}

.hob-reassurance-text{
  width: 100%;
  justify-content: center;
}

.product_meta .hob-reassurance-inner.hob-reassurance-inner--short {
    display: flex;
    flex-direction: column;
    margin: 30px 0px 0px !important;
    gap: 14px;
    padding: 18px 30px;
    border: 1px solid #00000029;
    border-radius: 6px;
    width: max-content;
}
.single-product .qodef-accordion.qodef-layout--simple .qodef-accordion-title {

    font-size: 22px;

}

.page-id-30 div#qodef-content-bottom {
    display: none;
}

.page-id-30 div#qodef-page-footer-top-area-inner {
    display: none;
}

.page-id-30 .qodef-divided-header-left-wrapper {
    display: none !important;
}

.page-id-30 .qodef-divided-header-right-wrapper {
    display: none !important;
}

.page-id-30 div#qodef-page-footer-bottom-area {
    margin-top: 80px;
}

@media only screen and (max-width: 1024px) {
	.single-product .qodef-accordion.qodef-layout--simple .qodef-accordion-title {
    font-size: 16px;
}
    .page-id-30 #qodef-page-inner {
        padding: 20px 0px 0px 0px;
    }
	
    .page-id-30 a.qodef-opener-icon.qodef-m.qodef-source--predefined.qodef-side-area-mobile-header-opener {
    display: none;
}
	
	 .page-id-30 #qodef-page-mobile-header .qodef-mobile-header-logo-link img.qodef--main {
    max-height: 78px;
    padding-top: 10px;
}
	    .page-id-30 #qodef-page-mobile-header-inner {
    border-bottom-width: 0px;
    
}
	    .page-id-30 a.qodef-mobile-header-logo-link.qodef-height--not-set.qodef-source--image {
    margin: auto;
}
}

.page-id-30 .hob-reassurance-inner.long-reassurance {
    margin-top: 30px;
    padding: 22px 22px 24px;
    border: 1px solid #e5e5e5;
    border-radius: 6px;
}
.is-style-without-price button.wc-block-components-button.wp-element-button.wc-block-components-checkout-place-order-button.wc-block-components-checkout-place-order-button--full-width.contained {
    background: #000;
    border: 0;
    color: #fff;
    font-family: 'Jost';
    text-transform: uppercase;
    letter-spacing: 1px;
    font-weight: 500;
    font-size: 15px;
		transition: opacity 0.3s ease;
}


.is-style-without-price button.wc-block-components-button.wp-element-button.wc-block-components-checkout-place-order-button.wc-block-components-checkout-place-order-button--full-width.contained:hover {
   opacity: 0.9;
	transition: opacity 0.3s ease;
}


@media (min-width: 1024px) {
  .wc-block-components-sidebar.wc-block-checkout__sidebar {
    will-change: transform;
    transform: translate3d(0,0,0);
    backface-visibility: hidden;
  }
}


.wc-block-components-form .wc-block-components-text-input input[type=email], .wc-block-components-form .wc-block-components-text-input input[type=number], .wc-block-components-form .wc-block-components-text-input input[type=password], .wc-block-components-form .wc-block-components-text-input input[type=tel], .wc-block-components-form .wc-block-components-text-input input[type=text], .wc-block-components-form .wc-block-components-text-input input[type=url], .wc-block-components-text-input input[type=email], .wc-block-components-text-input input[type=number], .wc-block-components-text-input input[type=password], .wc-block-components-text-input input[type=tel], .wc-block-components-text-input input[type=text], .wc-block-components-text-input input[type=url] {

    border: 1px solid hsl(0deg 0% 89.8%) !important;
}
.wc-blocks-components-select .wc-blocks-components-select__select {
  
    border: 1px solid hsl(0deg 0% 89.8%) !important;

}
.wc-block-components-radio-control--highlight-checked .wc-block-components-radio-control-accordion-option--checked-option-highlighted, .wc-block-components-radio-control--highlight-checked label.wc-block-components-radio-control__option--checked-option-highlighted {
    box-shadow: inset 0 0 0 1px rgb(0 0 0 / 52%) !important;
}

.wc-block-components-checkbox .wc-block-components-checkbox__input[type=checkbox]:focus {
    outline: none !important;

}




.woocommerce-error, .woocommerce-info, .woocommerce-message {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    padding: 20px 30px;
    margin-bottom: 30px;
    border: 1px solid #ccc;
    list-style: none;
    gap: 20px;
}

@media only screen and (max-width: 680px) {
    .woocommerce-error, .woocommerce-info, .woocommerce-message {
           flex-direction: column;
        gap: 20px;
        align-items: center;
        display: flex;
        text-align: center;
    }
	.woocommerce-error .button, .woocommerce-info .button, .woocommerce-message .button {
    margin-top: 0px!important;
    margin-left: 0!important;
		
}
      
}



@media (min-width: 1024px) {
	.woocommerce-notices-wrapper {
    padding: 0px 60px;
}
.archive #qodef-page-content.qodef-grid{
    margin-bottom: 0px;
    padding: 0px 120px;
}
.archive.qodef-content-grid-1400 .qodef-content-grid {
    width: 100%;
}

}

.qodef-page-sidebar-section .qodef-grid.qodef-gutter--small.qodef--no-bottom-space {
    padding: 0;
}




/* Hover image derrière + reveal propre */
.qodef-woo-product-image{
  position: relative;
  overflow: hidden;
}

/* Les 2 images superposées */
.qodef-woo-product-image > img{
  display: block;
  width: 100%;
  height: auto;
}

/* Image principale au-dessus */
.qodef-woo-product-image > img.attachment-woocommerce_thumbnail{
  position: relative;
  z-index: 2;
  transform: scale(1);
  transition: transform 520ms cubic-bezier(.2,.8,.2,1), opacity 520ms cubic-bezier(.2,.8,.2,1);
  will-change: transform, opacity;
}

/* Image hover derrière, masquée */
.qodef-woo-product-image > img.hob-custom-img-hover{
  position: absolute;
  inset: 0;
  z-index: 1;
  opacity: 0;
  transform: scale(1.05);
  transition: transform 720ms cubic-bezier(.2,.8,.2,1), opacity 520ms cubic-bezier(.2,.8,.2,1);
  will-change: transform, opacity;
  pointer-events: none;
}

/* Hover sur la carte (image ou lien) */
.qodef-woo-product-image:hover > img.hob-custom-img-hover,
.qodef-woo-product-image:focus-within > img.hob-custom-img-hover{
  opacity: 1;
  transform: scale(1);
}

/* On "efface" légèrement la principale pour révéler la hover */
.qodef-woo-product-image:hover > img.attachment-woocommerce_thumbnail,
.qodef-woo-product-image:focus-within > img.attachment-woocommerce_thumbnail{
  opacity: 0;
  transform: scale(1.02);
}

/* S'assure que le lien reste cliquable au-dessus */
.qodef-woo-product-image > a.woocommerce-LoopProduct-link{
  position: absolute;
  inset: 0;
  z-index: 3;
}







/* HOB > Loop color dots (Jimugo) */
.hob-loop-color-dots{
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  margin-top: 12px;
  line-height: 1;
}

/* un point */
.hob-loop-color-dot{
  width: 12px;
  height: 12px;
  border-radius: 999px;
  display: inline-block;
  flex: 0 0 auto;

  /* rendu premium, sobre */
  border: 1px solid rgba(0,0,0,.10);
  box-shadow:
    0 1px 2px rgba(0,0,0,.06),
    inset 0 0 0 1px rgba(255,255,255,.35);

  transform: translateZ(0);
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease, opacity .25s ease;
}

/* hover doux */
@media (hover:hover){
  .hob-loop-color-dots:hover .hob-loop-color-dot{ opacity: .75; }
  .hob-loop-color-dot:hover{
    opacity: 1;
    transform: scale(1.08);
    border-color: rgba(0,0,0,.18);
    box-shadow:
      0 6px 16px rgba(0,0,0,.10),
      inset 0 0 0 1px rgba(255,255,255,.45);
  }
}

/* accessibilité clavier */
.hob-loop-color-dot:focus-visible{
  outline: 2px solid rgba(0,0,0,.35);
  outline-offset: 2px;
}

/* si tu veux plus "old money" : un poil plus grand sur desktop */
@media (min-width: 1024px){
  .hob-loop-color-dot{
    width: 13px;
    height: 13px;
  }
}

/* si le fond est sombre (rare en loop) */
.qodef-dark-scheme .hob-loop-color-dot{
  border-color: rgba(255,255,255,.22);
  box-shadow:
    0 1px 2px rgba(0,0,0,.25),
    inset 0 0 0 1px rgba(255,255,255,.22);
}

.qodef-woo-results {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 7px;
    display: none;
}


.archive #qodef-woo-page .qodef-woo-product-list .button.add_to_cart_button {
    width: auto;
    height: auto;
    padding: 0;
    border: none;
    font-size: 13px;
    font-weight: 600;
    color: #000;
    background-color: transparent;
}
header.woocommerce-products-header {
    margin-bottom: -20px;
    position: relative;
    top: -10px;
}


















/* Middle footer, séparation + ligne langue/legal
   Sobre, net, responsive, compatible thèmes "premium" */

.hob-middle-footer {
  width: 100%;
}

.hob-middle-footer__separator {
  width: 100%;
  border-top: 1px solid rgba(0, 0, 0, 0.10);
}

.hob-middle-footer__inner {
    width: 100%;
    padding: 15px 70px 17px;
}

.hob-middle-footer__row {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
}

.hob-middle-footer__col {
  min-width: 0;
}

.hob-middle-footer__col--left {
  display: flex;
  align-items: center;
  gap: 10px;
}

.hob-middle-footer__label {
  font-size: 12px;
  line-height: 18px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  opacity: 0.75;
  white-space: nowrap;
}

.hob-middle-footer__lang {
  display: flex;
  align-items: center;
  gap: 8px;
}

.hob-middle-footer__col--right {
  display: flex;
  justify-content: flex-end;
}

.hob-middle-footer__legal {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.hob-middle-footer__legal-link {
  font-size: 12px;
  line-height: 18px;
  text-decoration: none;
  opacity: 0.82;
  transition: opacity 180ms ease, text-decoration-color 180ms ease;
  text-underline-offset: 3px;
}

.hob-middle-footer__legal-link:hover,
.hob-middle-footer__legal-link:focus-visible {
  opacity: 1;
  text-decoration: underline;
}

.hob-middle-footer__dot {
  font-size: 10px;
  line-height: 1;
  opacity: 0.35;
}

/* Responsive */
@media (max-width: 680px) {
.hob-middle-footer__inner {
    width: 100%;
    padding: 15px 25px 17px;
}
	.hob-middle-footer {
    
    margin-top: 50px;
}
  .hob-middle-footer__row {
    flex-direction: column;
    align-items: flex-start;
    gap: 10px;
  }

  .hob-middle-footer__col--right {
    justify-content: flex-start;
    width: 100%;
  }

  .hob-middle-footer__legal {
    justify-content: flex-start;
    gap: 8px;
  }
}






@media only screen and (max-width: 1024px) {
    #qodef-page-footer-bottom-area-inner .qodef-grid-inner {
        gap: 8px !important;
    }
}



.hob-socials {
  width: 100%;
}

.hob-socials__list {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.hob-socials__item {
  margin: 0;
  padding: 0;
}

.hob-socials__link {
  width: 36px;
  height: 36px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  text-decoration: none;
  transition: transform 160ms ease, background-color 160ms ease, opacity 160ms ease;
  background: rgba(0, 0, 0, 0.04);
  opacity: 0.9;
}

.hob-socials__link:hover,
.hob-socials__link:focus-visible {
  opacity: 1;
  transform: translateY(-1px);
  background: rgba(0, 0, 0, 0.07);
}

.hob-socials .hob-icon {
  width: 18px;
  height: 18px;
  display: block;
  fill: currentColor;
}

.hob-socials__sr {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* Mobile, un peu plus compact */
@media (max-width: 680px) {
  .hob-socials__link {
    width: 34px;
    height: 34px;
  }

  .hob-socials .hob-icon {
    width: 17px;
    height: 17px;
  }
}

li.hob-socials__item {
    margin: 0 !important;
}

















.reassurance-meta {
    max-width: 400px;
}

/* Marquee réassurance */
.hob-rmq{
  --hob-rmq-gap: 26px;
  --hob-rmq-item-gap: 10px;
  --hob-rmq-speed: 28; /* px/sec, plus petit = plus lent */
  position: relative;
  width: 100%;
}

.hob-rmq__viewport{
  overflow: hidden;
  position: relative;

  /* fade premium aux bords */
  -webkit-mask-image: linear-gradient(to right, transparent, #000 8%, #000 92%, transparent);
  mask-image: linear-gradient(to right, transparent, #000 8%, #000 92%, transparent);
}

.hob-rmq__track{
  display: flex;
  align-items: center;
  gap: var(--hob-rmq-gap);
  white-space: nowrap;
  will-change: transform;
  transform: translateX(0);
}

.hob-rmq__group{
  display: flex;
  align-items: center;
  gap: var(--hob-rmq-gap);
}

.hob-rmq__item{
  display: inline-flex;
  align-items: center;
  gap: var(--hob-rmq-item-gap);
  padding: 6px 0;
}

.hob-rmq__img{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
}

.hob-rmq__ico{
  width: 24px;
  max-width: 24px;
  height: auto;
  display: block;
}



.hob-rmq__title {
    display: inline-block;
    white-space: nowrap;
    font-weight: 400 !important;
    font-size: 14px;
}

/* Animation (de gauche vers droite) */
.hob-rmq.is-ready .hob-rmq__track{
  animation: hob-rmq-move var(--hob-rmq-duration, 28s) linear infinite;
}

/* On part de -shift (affiche le clone), on va vers 0 (affiche l’original) */
@keyframes hob-rmq-move{
  from { transform: translateX(calc(var(--hob-rmq-shift, 0px) * -1)); }
  to   { transform: translateX(0px); }
}

@media (prefers-reduced-motion: reduce){
  .hob-rmq__track{ animation: none !important; transform: none !important; }
  .hob-rmq__viewport{
    -webkit-mask-image: none;
    mask-image: none;
  }
}


.hob-wc-archive-banner {
    height: 400px;
    background-size: cover;
    background-position: center;
    position: relative;
    overflow: hidden;
}

.hob-wc-archive-banner::before{
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.28);
}

.hob-wc-archive-banner__inner{
  position: relative;
  z-index: 1;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
}
.hob-wc-archive-banner__title {
    color: #fff;
    margin: 0;
    text-align: center;
    text-transform: uppercase;
    letter-spacing: 2px;
}


#link-se-balader,
#link-se-reposer {
    cursor: pointer;
}

#link-se-balader .hob-full-link,
#link-se-reposer .hob-full-link {
    display: block;
    width: 100%;
    height: 100%;
    text-decoration: none;
    color: inherit;
    cursor: pointer;
}

a.hob-overlay-link {
    width: 100%;
    height: 100%;
    position: absolute;
    left: 0;
    top: 0;
}

body {
    font-size: 14px;
}