 /*
Theme Name: Coton d'idées
Author: Akatomy
*/

/* Reset CSS
 * --------------------------------------- */
 
* {
    box-sizing: border-box;
}

body,div,dl,dt,dd,ul,ol,li,h1,h2,h3,h4,h5,h6,pre,
form,fieldset,input,textarea,p,blockquote,th,td {
    padding: 0;
    margin: 0;

}
a{
  text-decoration:none;
  color: inherit;
}
table {
    border-spacing: 0;
}
fieldset,img {
    border: 0;
}
address,caption,cite,code,dfn,em,strong,th,var {
    font-weight: normal;
    font-style: normal;
}
strong{
  font-weight: bold;
}
nav ol, nav ul {
    list-style: none;
    margin:0;
    padding:0;
}
caption,th {
    text-align: left;

}
h1,h2,h3,h4,h5,h6 {
    font-weight: normal;
    font-size: 100%;
    margin:0;
    padding:0;
    color:#333;
}
q:before,q:after {
    content:'';
}
abbr,acronym { border: 0;
}

/* Global
 * --------------------------------------- */

:root {
    --wp--preset--font-size--small: 18px !important;
}

html {
    -webkit-text-size-adjust: 100%; /* Prevent font scaling in landscape while allowing user zoom */
}

body {
    background-color: #fdf9f2;
    color: #373536;
    position: relative;
    font-family: "thermal-variable", sans-serif;
    font-size: 18px;
    line-height: 26px;
    font-variation-settings: 'wght' 300, 'opsz' 900;
    color: rgba(21,27,35,0.8);
}

body.customize-support header {
  top: 32px;
}

header {
    background-color: #a3d3bc;
    font-family: "thermal-variable", sans-serif;
    font-size: 20px;
    line-height: 28px;
    color: rgba(10,20,30,0.8);
    padding: 25px 36px 20px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    position: sticky;
    top: 0;
    z-index: 100;
    transition: 0.2s;
}

header.scrolled {
    padding: 20px;
}

header .logo img {
    width: 110px;
    height: auto;
    /*margin-bottom: 35px;*/
    margin-bottom: 15px;
    transition: 0.2s;
}

    header.scrolled .logo img {
        margin-bottom: 10px;
    }

header.scrolled .logo img {
    width: 70px;
}

footer .logo img {
    width: 90px;
    height: auto;
    border: 1px solid rgba(0,0,0,0.25);
}

footer .container {
    padding-top: 30px;
    padding-bottom: 30px;
}

    footer > div {
        display: flex;
        gap: 60px;
        align-items: stretch;
    }

    footer nav {
        display: flex;
        gap: 60px;
        align-items: stretch;
    }

    footer nav div {
        border-left: 1px solid rgba(0,0,0,0.15);
        padding-left: 60px;
    }

        footer nav .social {
            list-style: none;
            display: flex;
            gap: 10px;
            margin-top: 10px;
        }

        footer nav .social i {
            font-size: 40px;
        }

        footer a:hover {
            text-decoration: underline dotted;
        }

@media screen and (max-width: 1360px) {

    footer > div {
        gap: 40px;
    }

    footer nav {
        gap: 40px;
    }

    footer nav div {
        padding-left: 40px;
    }

}

@media screen and (max-width: 1200px) {

    footer .logo img {
        width: 60px;
    }

    footer > div {
        gap: 30px;
    }

    footer nav {
        gap: 30px;
    }

    footer nav div {
        padding-left: 30px;
    }

}

@media screen and (max-width: 640px) {

        footer > div.container {
            display: flex;
            gap: 20px;
            align-items: stretch;
            padding: 20px;
        }

        footer nav {
            display: flex;
            flex-direction: column;
            gap: 0px;
        }

        footer nav div {
            border-left: 0px solid rgba(0,0,0,0.15);
            padding-left: 0px;
        }

}

div.mainNav {
    position: relative;
    width: 100%;
    max-width: 1240px;
}

nav.main ul {
    display: flex;
    justify-content: center;
}

nav.main ul li {
    padding: 0px 0px;
}

nav.main ul li:not(:first-child):before {
    display: inline-block;
    vertical-align: middle;
    content: " ";
    width: 9px;
    height: 9px;
    background-image: url(../img/puce.svg);
    background-size: contain;
    background-repeat: no-repeat;
    margin: 0 15px;
}

nav.main ul a {
    letter-spacing: 0.4px;
    font-variation-settings: 'wght' 500, 'opsz' 900;
    transition: 0.2s;
}

nav.main ul a:hover {
    color: #fff;
}

@media screen and (max-width: 1300px) {

    nav.main ul li:not(:first-child):before {
        margin: 0 10px;
        width: 6px;
        height: 6px;
    }

    nav.main ul li {
        font-size: 16px;
    }

}

@media screen and (max-width: 900px) {

    header {
        padding: 20px;
        display: flex;
        flex-direction: row;
        align-items: center;
    }

    header .logo {
        font-size: 0;
        line-height: 0;
        margin-right: 10px;
        width: 54px !important;
    }

    header .logo img {
        width: 54px;
        margin-bottom: 0px;
    }

    header.scrolled .logo img {
        width: 54px;
    }

    div.mainNav {
        width: auto;
        flex: 1 1 auto;
    }

    nav.main {
        position: fixed;
        z-index: 2000;
        background-color: #84b79c;
        color: #fff;
        top: 0;
        bottom: 0;
        right: -100%;
        width: 100%;
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        font-size: 24px;
        padding: 30px;
    }

    nav.main ul {
        flex-direction: column;
        color: rgba(21,27,35,0.8);
        text-align: center;
    }

    nav.main ul li {
        padding: 10px;
        font-size: 24px;
    }

}

.tools {
    display: flex; 
    position: absolute;
    right: 0;
    top: -65px;
    transition: 0.2s;
}

@media screen and (min-width: 901px) {

    header.scrolled .tools {
        top: -60px;
    }

}

.tools a {
    width: 50px;
    height: 50px;
    border-radius: 6px;
    display: flex;
    justify-content: center;
    align-items: center;
    transition: 0.2s;
    cursor: pointer;
}

    .tools a:hover {
        background: rgba(255,249,242,0.5);
    }

        .tools a img {
            height: 28px;
            width: auto;
        }

.burger, .close {
    display: none;
}

@media screen and (max-width: 900px) {

    .mainNav {
        display: flex;
        justify-content: space-between;
    }

    .tools {
        display: flex; 
        position: relative;
        right: 0;
        top: auto;
    }

        .tools a img {
            height: 26px;
            width: auto;
        }

    .burger {
        display: flex;
    }

    .close {
        display: flex;
        position: absolute;
        top: 20px;
        right: 20px;
        z-index: 200;
    }

    nav.main ul li:not(:first-child):before {
        display: none;
    }

}

.burger a, .close a {
    width: 54px;
    height: 54px;
    border-radius: 6px;
    display: flex;
    justify-content: center;
    align-items: center;
    transition: 0.2s;
    background: rgba(255,249,242,0.5);
    cursor: pointer;
}

        .burger a img, .close a img {
            height: 20px;
            width: auto;
        }

.search-wrapper {
    position: relative;
    display: flex;
    align-items: center;
}

.search-icon {
    cursor: pointer;
}

.search-input {
    width: 0;
    opacity: 0;
    border: 1px solid #ccc;
    border-radius: 4px;
    transition: width 0.3s ease, opacity 0.3s ease;
    pointer-events: none;
    font-family: "thermal-variable", sans-serif;
    font-size: 20px;
    line-height: 30px;
    font-variation-settings: 'wght' 300, 'opsz' 900;
    color: rgba(21,27,35,0.8);
}

/* Active state */
.search-wrapper.active .search-icon {
    /*transform: translateX(-10px);*/
}

.search-wrapper.active {
    border-radius: 6px;
    background-color: #fff9f2;
}

.search-wrapper.active .search-input {
    width: 160px;
    opacity: 1;
    pointer-events: auto;
    padding: 8px;
    margin-left: 0px;
    border: none;
    outline: none;
    border-radius: 0;
    background-color: #fff9f2;
}

@media screen and (max-width: 900px) {

    .search-input {
        font-size: 16px;
        line-height: 20px;
    }

    .search-wrapper.active .search-input {
        width: 120px;
        padding: 6px;
    }

}

.container, .containerSlider {
    width: 100%;
    max-width: 1400px;
    margin: auto;
    padding: 50px 65px;
}

.containerProduct {
    width: 100%;
    max-width: 1400px;
    margin: auto;
    /*padding: 80px 0px;*/
    padding: 0px 0px;
}

div.product.type-product {
    padding: 0px 65px;
}

@media screen and (max-width: 900px) {

    .container {
        width: 100%;
        max-width: 1400px;
        margin: auto;
        padding: 40px 30px;
    }

    .containerSlider {
        padding: 40px 65px;
    }

    .containerProduct {
        padding: 40px 0px;
    }

    div.product.type-product {
        padding: 0px 0px;
    }

}

h1 {
    font-family: "thermal-variable", sans-serif;
    font-size: 36px;
    line-height: 44px;
    font-variation-settings: 'wght' 800, 'opsz' 900;
    text-align: center;
    color: rgba(10,20,30,0.9);
    margin-bottom: 35px;
    letter-spacing: 0.4px;
}

h2 {
    font-family: "thermal-variable", sans-serif;
    font-size: 36px;
    line-height: 44px;
    font-variation-settings: 'wght' 800, 'opsz' 900;
    text-align: center;
    color: rgba(10,20,30,0.9);
    margin-bottom: 35px;
    letter-spacing: 0.4px;
}

h3 {
    font-family: "thermal-variable", sans-serif;
    font-size: 24px;
    line-height: 32px;
    font-variation-settings: 'wght' 500, 'opsz' 100;
    text-align: center;
    color: rgba(10,20,30,0.9);
    letter-spacing: 0.4px;
}

h4 {
    font-family: "thermal-variable", sans-serif;
    font-size: 20px;
    line-height: 28px;
    font-variation-settings: 'wght' 400, 'opsz' 100;
    text-align: center;
    color: rgba(10,20,30,0.9);
    letter-spacing: 0.4px;
}

/* the slides */
  .slick-slide {
      margin: 0 12px;
  }

  /* the parent */
  .slick-list {
      margin: 0 -12px;
      /*display: flex;*/
      justify-content: center;
      flex-wrap: wrap;
      align-items: stretch;
  }

  .slick-track {
      display: flex !important;
    }

    .slick-slide {
  height: inherit !important;
  position: relative;
}

.slick-slide > div {
  height: 100%;
}

  .slick-arrow {
    width: 75px;
    height: 75px;
    background: none;
    border: none;
    font-size: 0;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 10;
    cursor: pointer;
  }

  .slick-next {
    background-image: url(../img/next.svg);
    background-size: contain;
    right: -65px;
  }

  .slick-prev {
    background-image: url(../img/prev.svg);
    background-size: contain;
    left: -65px;
  }

  ul.flex-direction-nav {
    list-style: none;
  }

  ol.flex-control-thumbs {
    display: none;
  }

  .flex-next {
    display: block;
    width: 75px;
    height: 75px;
    background: none;
    border: none;
    font-size: 0;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 10;
    background-image: url(../img/next.svg);
    background-size: contain;
    right: -38px;
}

  .flex-prev {
    display: block;
    width: 75px;
    height: 75px;
    background: none;
    border: none;
    font-size: 0;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 10;
    background-image: url(../img/prev.svg);
    background-size: contain;
    left: -38px;
}

.woocommerce-product-gallery .flex-next {
    background-image: url(../img/next-alt.svg);
}

.woocommerce-product-gallery .flex-prev {
    background-image: url(../img/prev-alt.svg);
}


@media screen and (max-width: 900px) {

      .flex-next {
        top: auto;
        bottom: -38px;
        right: 20%;
        transform: none;
    }

      .flex-prev {
        top: auto;
        bottom: -38px;
        left: 20%;
        transform: none;
    }

}

.sliderItem {
    display: flex !important;
    text-align: center;
}

ul {list-style:disc inside;}

.sliderItem {
    display: flex !important;
    flex-direction: column;
    align-items: stretch;
    border-radius: 9px;
    background-color: #fff9f2;
    height: 100%;
    transition: 0.2s;
}

.sliderImg {
    padding: 20px 20px 10px;
}

    .sliderImg img {
        width: 100%;
        height: auto;
        border-radius: 7px;
    }

.sliderDesc {
    padding: 0px 20px 15px;
    margin: 0px 15px;
    flex-basis: 30%; 
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}

    .sliderDesc h4 {
        text-align: center !important;
        margin-bottom: 0 !important;
    }

.sliderItem:hover {
    background-color: #f3eadb;
}

/*.sliderItem:hover h4 {
    color: #fff;
}*/

ul.products {
    display: flex;
    flex-wrap: wrap;
    margin: auto;
    justify-content: center;
}

ul.products .product {
    display: flex !important;
    flex-direction: column;
    align-items: stretch;
    border-radius: 9px;
    background-color: #f3eadb;
    margin: 0 10px 20px 10px !important;
    transition: 0.2s;
}

    ul.products .product:hover {
        background-color: #a3d3bc;
    }

ul.products .product a {
    display: flex !important;
    flex-direction: column;
    align-items: stretch;
    padding: 20px 20px 10px;
    height: 100%;
}

    ul.products .product a img {
        width: 100%;
        height: auto;
        border-radius: 7px;
        aspect-ratio: 1/1 !important;
        margin: 0 !important;
        flex: 0 0 auto;
    }

.woocommerce ul.products li.product .woocommerce-loop-product__title {
    font-family: "thermal-variable", sans-serif;
    font-size: 22px;
    line-height: 26px;
    font-variation-settings: 'wght' 400, 'opsz' 100;
    text-align: center;
    color: rgba(10,20,30,0.9);
    letter-spacing: 0.4px;
    padding: 0 !important;
    margin: 0 !important;
}

.woocommerce ul.products li.product .price {
    color: rgba(10,20,30,0.9) !important;
    text-align: center;
    font-size: 22px !important;
    line-height: 26px;
}

.productDesc {
    padding: 0px 10px 15px;
    margin: 15px 15px 0;
    flex-basis: 30%; 
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}

.arches {
    display: flex;
    justify-content: center;
    width: 100%;
    max-width: 1315px;
    margin: auto;
    flex-wrap: wrap;
    gap: 30px;
}

.archItem {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    align-items: stretch;
    /*background: linear-gradient(to top, #f3eadb 0%, #f3eadb 30%, rgba(0,0,0,0) 30%,  rgba(0,0,0,0) 100%);*/
    margin: 30px 0;
    flex: 1 1 calc((100% - 3 * 30px) / 4);
}

@media screen and (max-width: 800px) {

    .archItem {
        flex: 1 1 calc((100% - 1 * 30px) / 2);
    }

    .archItem {
        margin: 10px 0px;
    }

}

@media screen and (max-width: 480px) {

    .arches {
        flex-direction: column;
    }

    .archItem {
        flex-basis: 80%;
    }

}

    .archItem > div:nth-child(1) {
        background-color: #f3eadb;
        padding: 20px 20px 10px;
        border-top-left-radius: 100%; 
        border-top-right-radius: 100%;
        transition: 0.2s;
    }

        .archItem > div:nth-child(1) img {
            width: 100%;
            height: auto;
            border-top-left-radius: 100%; 
            border-top-right-radius: 100%;
        }

    .archItem > div:nth-child(2) {
        background-color: #f3eadb;
        padding: 0px 20px 20px;
        flex: 1 1 auto;
        display: flex;
        align-items: center;
        justify-content: center;
        border-bottom-left-radius: 10px; 
        border-bottom-right-radius: 10px;
        transition: 0.2s;
    }

    .archItem:hover > div:nth-child(1), .archItem:hover > div:nth-child(2) {
        background-color: #a3d3bc;
    }

    /*.archItem:hover h3 {
        color: #fff;
    }*/

@media screen and (max-width: 900px) {

    /*.archItem {
        margin: 15px 15px;
        flex-basis: calc(100%/3 - 30px);
    }

    .archItem > div:nth-child(1) {
        padding: 15px;
    }

    .archItem > div:nth-child(2) {
        padding: 0px 15px 15px;
    }*/

}

.greenBackground .archItem {
    background: linear-gradient(to top, #fff9f2 0%, #fff9f2 30%, rgba(0,0,0,0) 30%,  rgba(0,0,0,0) 100%);
}

    .greenBackground .archItem > div:nth-child(1) {
        background-color: #fff9f2;
    }

    .greenBackground .archItem > div:nth-child(2) {
        background-color: #fff9f2;
    }

.centered {
    max-width: 880px;
    width: 100%;
    margin: auto;
    text-align: center;
    font-size: 24px;
    line-height: 32px;
    font-variation-settings: 'wght' 300, 'opsz' 900;
    margin-bottom: 40px !important;
}

/** product page tweaks **
*************************/

.product-main-wrapper {
    position: relative;
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
}

.woocommerce-product-gallery {
    width: 50% !important;
}

.summary.entry-summary {
    width: 42% !important;
}

.woocommerce div.product div.images.woocommerce-product-gallery {
  position: sticky !important;
    /*top: var(--box-height);*/
    top: 230px;
}

    .woocommerce div.product div.images {
        margin-bottom: 50px !important;
    }

@media screen and (max-width: 900px) {

    .product-main-wrapper {
        flex-direction: column;
    }

    .woocommerce div.product div.images.woocommerce-product-gallery {
      position: relative !important;
      top: auto;
    }

    div.summary.entry-summary {
        padding: 30px;
    }

    .woocommerce-product-gallery {
        width: 100% !important;
        clear: both;
    }

    .summary.entry-summary {
        width: 100% !important;
        clear: both;
    }

    .woocommerce div.product div.images {
        margin-bottom: 0px !important;
    }

}

body.single-product h1 {
    font-family: "thermal-variable", sans-serif;
    font-size: 36px;
    line-height: 44px;
    font-variation-settings: 'wght' 800, 'opsz' 900;
    padding: 50px 0 20px 0 !important;
    color: #151b23;
    text-align: center;
    background-color: #fdf9f2;
}

div.woocommerce-product-gallery__image {
    border-radius: 10px !important;
}

@media screen and (max-width: 900px) {

    div.woocommerce-product-gallery__image {
        border-radius: 0px !important;
    }

}

span.onsale {
    display: none;
}

.woocommerce-product-details__short-description {
    width: 100%;
    margin: 0 auto 50px;
    max-width: 1080px;
}

@media screen and (max-width: 900px) {

    body.single-product h1 {
        padding: 30px 30px 0px !important;
        margin-bottom: 0px;
    }

    .woocommerce-product-details__short-description {
        /*padding: 0 30px;*/
    }

}

.woocommerce-product-details__short-description p {
    font-family: "thermal-variable", sans-serif;
    font-size: 20px;
    line-height: 28px;
    font-variation-settings: 'wght' 300, 'opsz' 900;
}

.yith-wcwl-add-to-wishlist-button span {
    display: none;
}

.custom-add-to-cart-wrapper {
    display: flex;
    gap: 9px;
    margin-top: 9px;
    margin-bottom: 20px;
}

/*.wishlist-button, .quantity, .single_add_to_cart_button {*/
.wishlist-button, .qib-button-wrapper, .single_add_to_cart_button {
    flex: 1 1 auto;
    background-color: #b1d2bc;
    height: 60px !important;
}

.custom-add-to-cart-wrapper .qib-button-wrapper {
    margin: 0 !important;
}

.wishlist-button {
    border-radius: 10px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}

.yith-add-to-wishlist-button-block.yith-add-to-wishlist-button-block--single {
    justify-content: center !important;
    align-items: center !important;
    margin: auto;
}

.yith-wcwl-add-to-wishlist-button.yith-wcwl-add-to-wishlist-button--anchor svg.yith-wcwl-icon-svg {
    width: auto !important;
    height: 35px !important;
}

.single_add_to_cart_button {
    background-image: url('../img/add-to-cart.svg') !important;
    background-position:  center center;
    background-repeat: no-repeat;
    background-size: 30px;
    height: 50px; /* match image height */
    background-color: #b1d2bc !important;
    border-top-right-radius: 10px !important;
    border-bottom-right-radius: 10px !important;
    border-top-left-radius: 0px !important;
    border-bottom-left-radius: 0px !important;
}

.single_add_to_cart_button:hover {
    opacity: 0.9;
}

ul.image-variable-items-wrapper, ul.variable-items-wrapper {
    gap: 9px;
}

.variations th.label span, a.reset_variations {
    display: none !important;
}

.variations th.label {
    font-family: "thermal-variable", sans-serif;
    font-size: 24px !important;
    color: #293248 !important;
    font-variation-settings: 'wght' 700, 'opsz' 900;
}

li.image-variable-item {
  width: calc((100% - 36px) / 5) !important;
}

li.image-variable-item.selected img {
    width: 73% !important;
    height: 73% !important;
}

.woo-variation-swatches .variable-items-wrapper .variable-item:not(.radio-variable-item).image-variable-item.selected:not(.no-stock) .variable-item-contents::before {
    display: none !important;
}

.woo-variation-swatches .variable-items-wrapper .variable-item:not(.radio-variable-item) img {
    border-radius: 10px !important;
}

ul[aria-label="Motif"] li, ul[aria-label="Modèle"] li, ul[aria-label="Motif - Je crée pour vous"] li {
    height: unset !important;
    aspect-ratio: 1 / 1 !important;
    padding: 0 !important;
    border-radius: 10px !important;
    box-shadow: none !important;
    margin: 0 !important;
    background-color: #fdf9f2 !important;
}

ul[aria-label="Taille"] li {
    height: unset !important;
    aspect-ratio: 1 / 1 !important;
    padding: 0 !important;
    border-radius: 10px !important;
    box-shadow: none !important;
    margin: 0 !important;
    width: 60px !important;
    background-color: #b1d2bc !important;
    font-family: "thermal-variable", sans-serif;
    font-size: 24px;
    line-height: 24px;
    font-variation-settings: 'wght' 700, 'opsz' 100;
}

ul[aria-label="Taille"] li.selected {
    background-color: #293248 !important;
    color: #fff !important;
}

p.price {
    display: flex;
    height: 60px;
    border-radius: 10px;
    background-color: #f0e9db;
    justify-content: center;
    align-items: center;
    font-family: "thermal-variable", sans-serif;
    font-size: 30px !important;
    color: #293248 !important;
    font-variation-settings: 'wght' 700, 'opsz' 100;
}

p.price del {
    opacity: 0.2 !important;
    margin-right: 40px;
}

p.price ins {
    text-decoration: none;
}

.single-product .product_meta {
    display: none;
}

/*.quantity*/
.qib-button-wrapper {
    position: relative;
    margin: 0 !important;
    border-top-left-radius: 10px;
    border-bottom-left-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
}

/*.quantity*/
.qib-button-wrapper:before {
    width: 16px;
    height: 100%;
    position: absolute;
    top: 0;
    right: -25px;
    bottom: 0;
    content: " ";
  background: #fff;
  clip-path: polygon(
    0% 0%,
    85% 50%,
    100% 50%,
    85% 50%,
    0% 100%
  );
  z-index: 1;
}

.quantity:after {
    width: 16px;
    height: 100%;
    position: absolute;
    top: 0;
    right: -16px;
    bottom: 0;
    content: " ";
  background: #b1d2bc;
  clip-path: polygon(
    0% 0%,
    85% 50%,
    100% 50%,
    85% 50%,
    0% 100%
  );
  z-index: 2;
}

@media screen and (max-width: 900px) {

    li.image-variable-item {
      width: calc((100% - 27px) / 5) !important;
    }

    .woo-variation-swatches .variable-items-wrapper .variable-item:not(.radio-variable-item) img {
        border-radius: 7px !important;
    }

    ul[aria-label="Motif"] li {
        border-radius: 7px !important;
    }

    ul[aria-label="Taille"] li {
        border-radius: 7px !important;
    }

    p.price {
        border-radius: 7px;
    }

    .quantity {
        border-top-left-radius: 7px;
        border-bottom-left-radius: 7px;
    }

}

div.container p:not(:last-child), div.container ul:not(:last-child), div.container ol:not(:last-child), div.containerProduct p:not(:last-child), div.containerProduct ul:not(:last-child), div.containerProduct ol:not(:last-child) {
    margin-bottom: 20px;
}

div.container strong, div.containerProduct strong {
    font-variation-settings: 'wght' 700, 'opsz' 100;
}

div.woocommerce-variation.single_variation {
    margin-bottom: 20px;
}

.woocommerce:where(body:not(.woocommerce-uses-block-theme)) div.product .stock {
  font-family: "thermal-variable", sans-serif;
  color: #293248 !important;
}

.woocommerce:where(body:not(.woocommerce-uses-block-theme)) div.product span.price {
  font-family: "thermal-variable", sans-serif;
  font-size: 37px !important;
  color: #293248 !important;
  font-variation-settings: 'wght' 700, 'opsz' 100;
}

.wp-singular:not(.home) h3 {
    text-align: left;
    margin-bottom: 30px;
}

.wp-singular:not(.home) h4 {
    text-align: left;
    margin-bottom: 30px;
}

.videoContainer {
    border-radius: 11px;
    width: 100%;
    max-width: 810px;
    margin: auto;
    background: #f3eadb;
    padding: 28px;
}

.page-template-template-a-propos .videoContainer {
    background: #fff9f2;
}

.page-template-template-a-propos .introAPropos figure {
    width: 100%;
    max-width: 810px;
    margin: 40px auto 0;
    font-family: "thermal-variable",sans-serif;
    font-style: italic;
    font-variation-settings: 'wght' 100, 'opsz' 100;
    letter-spacing: 0.5px;
}

.page-template-template-a-propos blockquote {
    font-size: 40px;
    line-height: 50px;
    text-align: center;
}

.page-template-template-a-propos cite {
    font-size: 40px;
    line-height: 50px;
    font-family: "thermal-variable",sans-serif;
    font-style: italic;
    font-variation-settings: 'wght' 100, 'opsz' 100;
    letter-spacing: 0.5px;
    text-align: right;
    display: block;
}

.videoContainer video {
    border-radius: 9px;
}

.container .wp-block-image .alignleft {
  float: left;
  margin: .5em 2em 2em 0;
}

.container .wp-block-image .alignright {
  float: right;
  margin: .5em 0 2em 2em;
}

.container .wp-block-image img {
    border-radius: 11px;
}

@media screen and (max-width: 640px) {

    .container .wp-block-image .alignleft, .container .wp-block-image .alignright  {
        clear: both;
        width: 100%;
        margin: .5em 0 2em 0;
    }

    .container .wp-block-image .alignleft img, .container .wp-block-image .alignright img {
        width: 100%;
        height: auto;
    }

}

.woocommerce div.product form.cart {
  margin-bottom: 0 !important;
}

.term-description {
    margin-bottom: 40px;
}

.term-description p {
    text-align: center;
}

main .woocommerce-info {
  border-top-color: #a3d3bc;
  background-color: #f3eadb;
}

main .woocommerce-info::before {
  color: #a3d3bc;
}

.woocommerce-Address h2 {
    font-size: 22px;
    margin-bottom: 15px;
}

.woocommerce-Address-title {
    margin-bottom: 20px;
}

main .woocommerce-ordering select {
    font-family: "thermal-variable", sans-serif;
    font-size: 16px;
    color: rgba(21,27,35,0.8);
}

main .woocommerce .quantity .qty {
    font-family: "thermal-variable", sans-serif;
    font-size: 16px;
    color: rgba(21,27,35,0.8);
    font-variation-settings: 'wght' 700, 'opsz' 900;
}

main .woocommerce .wc-forward.button, main .woocommerce .woocommerce-form-login .woocommerce-form-login__submit, main .wc-block-cart__submit-button, main .wc-block-components-checkout-place-order-button, main .woocommerce-Button.button {
  font-family: "thermal-variable", sans-serif;
  background-color: #a3d3bc !important;
  color: #293248 !important;
  border-radius: 5px;
  border: none;
  font-size: 18px;
  font-variation-settings: 'wght' 700, 'opsz' 900;
}

main .woocommerce .wc-forward.button:hover, main .woocommerce .woocommerce-form-login .woocommerce-form-login__submit:hover, main .wc-block-cart__submit-button:hover, main .wc-block-components-checkout-place-order-button:hover, main .woocommerce-Button.button:hover {
    background-color: #a3d3bc;
    opacity: 0.9;
}

main .woocommerce-notices-wrapper {
    margin: auto;
    width: 100%;
    max-width: 1400px;
    border-radius: 10px;
}

main .woocommerce-notices-wrapper:focus, main .woocommerce-notices-wrapper *:focus  {
    outline: none;
}

main .woocommerce-message {
    border-radius: 10px;
    border-top: 3px solid #a3d3bc;
    color: #151b23;
    background-color: #f0e9db;
}

main .woocommerce-error {
    border-top-color: #151b23;
    color: #151b23;
    background-color: #f0e9db;
}

main .woocommerce-message::before {
  color: #a3d3bc;
}

main .woocommerce-error::before {
  color: #151b23;
}

main .wc-block-components-quantity-selector input.wc-block-components-quantity-selector__input {
  font-family: "thermal-variable", sans-serif;
}

.woocommerce-wishlist code {
    font-family: inherit;
}

.woocommerce-wishlist .wishlist-title-container {
    display: none;
}

.woocommerce-wishlist .wishlist_table thead tr th {
    background: #f3eadb;
}

.woocommerce-wishlist .woocommerce table.shop_table.wishlist_table tr td {
    background: none;
}

@media screen and (max-width: 768px) {

    .woocommerce ul.products[class*="columns-"] li.product, .woocommerce-page ul.products[class*="columns-"] li.product {
        width: 44% !important;
    }

}

@media screen and (max-width: 480px) {

    .woocommerce ul.products[class*="columns-"] li.product, .woocommerce-page ul.products[class*="columns-"] li.product {
        width: 100% !important;
    }

}

span.price ins {
    text-decoration: none !important;
}

ul.page-numbers {
    margin: auto;
    display: flex;
    gap: 10px;
    justify-content: center;
}

.woocommerce .quantity .qty {
    font-size: 22px !important;
}

.term-description p, .woocommerce div.product p.stock {
    font-size: 20px !important;
    line-height: 28px !important;
}