@import url('https://fonts.googleapis.com/css2?family=Lato:ital,wght@0,100;0,300;0,400;0,700;0,900;1,100;1,300;1,400;1,700;1,900&display=swap');
@font-face {
    font-family: 'Autography';
    src: url('Autography.woff2') format('woff2'),
        url('Autography.woff') format('woff');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}


 :root {
    --black: #000;
    --white: #fff;
    --primary: #e229e2;
    --second: #a24c65;
    --back: #efefef;
    --gris: #616468;
}

body {
    padding: 0px;
    margin: 0px;
    font-family: "Lato", sans-serif;
    font-optical-sizing: auto;
    font-weight: normal;
    font-style: normal;
    font-weight: normal;
    overflow-x: hidden;
    background: var(--back);
}

ul {
    padding: 0px;
    margin: 0px;
}

a {
    text-decoration: none !important
}

.header {
    width: 100%;
    position: relative;
    margin: 0;
    z-index: 3;
    
}

.top {
    padding: 9px 15px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    background: var(--back);
    max-width: 1440px;
    margin: 0 auto;
}

.top span {
    font-size: 15px;
    font-weight: 300;
    display: block;
    line-height: 1.1;
    color: #000;
}

.top>div {
    margin: 0;
    display: flex;
    align-items: center;
    justify-content: flex-end;
    font-size: 14px;
}

.top>div:first-child {
    color: #b3afbd
}

.right-top {
    gap: 0px 22px;
}

.top>div:first-child {
    gap: 0px 15px;
}

.right-top .phone {
    color: #000!important;
    font-size: 17px;
    position: relative;
    z-index: 1;
    display: block;
    text-align: right;
    font-weight: 300;
    padding-right: 0;
}

.logo {
    width: 100%;
    text-align: center;
    position: absolute;
    height: 100%;
    display: flex;
    align-items: center;
}

.logo a {
    display: table;
    margin-bottom: 0;
}

.logo>div {
    position: relative;
    display: table;
    margin: 0;
    top: 85px;
}

.logo img {
    position: relative;
    z-index: 1;
    max-width: 100%;
}

/* end header */
/* menu */
.navbar-nav .nav-item {
    display: block;
    transition: 0.5s ease all;
    position: relative;
}
.dropdown-item{
    color: #fff;
    padding: 10px;
}
.navbar .navbar-nav .nav-item .nav-link {
    padding: 23px 34px;
    white-space: nowrap;
    transition: 0.3s ease all;
    font-size: 18px;
    text-align: left;
    font-weight: 400;
    color: #ffff;
    position: relative;
    display: flex;
    align-items: center;
}

.navbar .navbar-nav .nav-item .nav-link:hover {
    background: var(--second);
    color: var(--back);
}

.navbar .navbar-nav .nav-item:hover .nav-link {
    background: var(--second);
    color: var(--back);
}

.navbar .navbar-nav .nav-item:first-child {
    background: none;
}

.navbar .navbar-nav .nav-item .nav-link:after {
    z-index: 1
}

.navbar .navbar-nav .nav-item:last-child .nav-link:before {
    opacity: 0
}

.navbar .navbar-nav .nav-item:last-child .nav-link:after {
    display: none
}

.navbar .navbar-nav .nav-item .nav-link:hover:before {
    width: 100%;
}

.navbar-nav .nav-item:hover>.nav-link:before {
    width: 100%;
    opacity: 1 !important
}

.bloc-menu.fixed .btn-menu {
    display: table;
}

.bloc-menu {
    display: none;
    margin-right: 15px;
    position: relative;
    left: 45px;
    cursor: pointer;
    z-index: 10;
    transition: 0.3s ease all;
}

.btn-menu {
    display: table;
    margin: 0 auto;
    position: relative;
    transition: 0.3s ease all;
}

.btn-menu:hover {
    transform: rotate(180deg);
}

.menubox {
    transition: 0.3s ease all;
    padding: 0;
    width: 100%;
    position: relative;
    z-index: 20;
    max-width: 1400px;
    margin: 20px auto 0px;
    background: url(../images/menu.jpg) no-repeat;
}

.menubox.activemenu {
    transform: none;
}

.menubox.fixed {
    top: 0;
    z-index: 20;
    position: fixed;
    background: var(--primary);
    max-width: 100%;
    width: 100%;
    margin: 0 auto;
    left: 0;
    bottom: initial;
    padding: 0;
}

.inner-menubox {
    transition: 0.3s ease all;
    position: relative;
    max-width: 1400px;
    margin: 0 auto;
}

.fixed .inner-menubox {
    border: none;
}

.navbar {
    padding: 0;
    position: relative;
    z-index: 1;
}

.navbar-nav {
    margin: 0px !important;
    padding: 12px 15px;
    z-index: 9;
    width: 100%;
    flex-wrap: wrap;
}

.navbar-nav:last-child {
    padding: 0;
    justify-content: center;
    position: relative;
    margin: 0 auto !important;
    max-width: 1080px;
    margin: 0 auto;
    gap: 0;
    transition: 0.3s ease all;
}
.fixed .navbar-nav:last-child{
    background: none;
}

/****** end menu ***/
.flex-contact{
    justify-content: center;
    gap: 0px 29px;
    margin: 0 auto 100px;
}
.flex-contact b{
    color: var(--primary);
    font-size: 20px;
    font-weight: 800;
    letter-spacing: 1px;
    display: block;
    line-height: 1.1;
}
.flex-contact a{
    color: #000;
    font-size: 28px;
    font-weight: 800;
    letter-spacing: 1px;
}
.stone-section {
    max-width: 960px;
    margin: 0 auto 30px;
    padding: 180px 0px;
    background: url(../images/img.jpg) no-repeat;
    background-position: 0% 100%;
    border-radius: 0px 100px 0px 0px;
}

.container {
    width: 100%;
    max-width: 100%;
    margin: auto;
    padding: 0;
}

.top-block {
    gap: 0;
    position: relative;
}

.image-block {
    width: 70%;
    border-radius: 0px 140px;
    overflow: hidden;
}

/* IMAGE */
.image-block img {
    max-width: 100%;
    display: block;
}

/* CONTENT */
.content-block {
    color: white;
    position: relative;
    width: 80%;
}

.content-block>div {padding: 25px 50px;backdrop-filter: blur(9px);position: relative;}
.content-block>div h2{margin: 0;font-size: 55px;font-weight: 800;letter-spacing: 1px;text-shadow: 1px 1px 5px #000;letter-spacing: 2px;line-height: 1.1;}
.content-block p {
    margin: 5px 0;
    line-height: 1.5;
    font-size: 19.5px;
    margin-bottom: 8px;
    font-weight: 400;
    margin: 0;
}
.content-block>div:after{content:"";width: 50px;position: absolute;background: var(--primary);height: 100%;top: 0;left: -50px;}
.content-block p i {
    color: var(--primary);
    font-weight: 500;
}

.content-block p:before {
    content: "";
    height: 60px;
    display: block;
    background: #fff;
    width: 3px;
    margin-bottom: 20px;
}

.resine-section {
    padding-bottom: 80px;
    overflow: hidden;
    max-width: 1200px;
    margin: 0 auto;
}

.resine-wrapper {
    position: relative;
    width: 100%;
    height: 780px;
}

.resine-bg {
    width: 100%;
    height: 100%;
    background: url('../images/slider/slider1.jpg') center center/cover no-repeat;
}

.resine-box {
    position: absolute;
    padding: 45px;
    max-width: 600px;
    backdrop-filter: blur(10px);
    bottom: 100px;
    left: 60px;
}

.resine-box h2 {
    font-size: 29px;
    line-height: 1.2;
    color: #111;
    font-weight: 800;
    margin-bottom: 30px;
}

.resine-box p {
    font-size: 17px;
    line-height: 1.6;
    color: #fff;
    margin-bottom: 0;
}

.resine-box .italic {
    font-style: italic;
    margin: 0;
}


.gallery-section {
    padding: 40px 0px;
    max-width: 950px;
    margin: 0 auto;
}
.gallery-section h2{
    margin: 0;
  
}
.gallery-section h2 a{
    background: #a04a7b;
    color: #fff;
    display: block;
    padding: 50px 20px;
    text-align: center;
    font-size: 21px;
    transition: 0.3s ease all;
}
.gallery-section h2 a:hover{
    background:var(--second);letter-spacing:4px
}
.gallery-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-template-rows: auto auto;
    gap: 0px 25px;
    align-items: start;
    overflow: hidden;
}

.img img {
    max-width: 100%;
    display: block;
    margin-bottom: 20px;
}

.img1 {
    grid-column: 1 / 2;
    grid-row: 1 / 2;
    display: flex;
    flex-direction: column;
    align-items: flex-end;
}

.img2 {
    grid-column: 2 / 3;
    grid-row: 1 / 3;
}

.project-box {
    background: #a8c648;
    margin: 50px auto;
    border-bottom-right-radius: 70px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    position: relative;
    z-index: 5;
    border-radius: 45px 0px;
    max-width: 470px;
    padding: 25px 0px;
    transition: 0.3s ease all;
    color: #fff;
}
.project-box:hover{
    background: var(--second);
    color: var(--primary);
    letter-spacing: 3px;
}
.project-box span {
    font-size: 23px;
    font-weight: 800;
    margin-bottom: 0;
    letter-spacing: 1px;
}

.project-box strong {
    font-size: 37px;
    line-height: 1;
    font-weight: 800;
}

/* TEXTE BAS */
.bottom-text-center {
    max-width: 960px;
    margin: 40px auto 0px;
    text-align: justify;
    padding: 50px 15px 0px;
}

.bottom-text-center p {
    font-size: 19px;
    line-height: 1.5;
    color: #222;
    margin: 0;
}


.bottom-text {
    text-align: center;
    color: #fff;
    max-width: 1200px;
    margin: 100px auto;
    padding: 0px 15px;
    background: url(../images/top.png), url(../images/bottom.png);
    background-repeat: no-repeat;
    background-position: 0% 0%, 100% 100%;
}

.bottom-text p {
    margin: 0;
    font-size: 25px;
    color: var(--primary);
    padding: 80px 60px;
    margin: 0 auto;
    font-weight: 400;
    font-style: italic;
    line-height: 1.5;
}

.btn-intervention {
    display: flex;
    margin: 50px auto 100px;
    background: var(--primary);
    width: 650px;
    padding: 30px 30px;
    color: #fff;
    transition: 0.3s ease all;
    border-radius: 34px;
    align-items: center;
    justify-content: space-between;
}

.btn-intervention:hover {
    color: #000;
    letter-spacing: 3px;
    color: var(--primary);
    background: var(--second);
}

.btn-intervention b {
    display: block;
    font-size: 23px;
}

.btn-intervention span {
    display: block;
    font-weight: 300;
    line-height: 1;
}

/* BOTTOM LINE IMAGE */

/* Header */
.header {
    padding: 0;
    max-width: max-content;
    margin: 0 auto;
    overflow: hidden;
}
.banner-img{
    display: block;
    margin: 0 auto;
}
.page .banner-img{
    max-height: 480px;
    overflow: hidden;
}
.banner-img img{
    display: block;
    max-width: 100%;
}
h1 {
    font-size: 40px;
    margin: 10px 0;
}

.services-section {
    max-width: 1400px;
    margin: auto;
    display: grid;
    grid-template-columns: repeat(auto-fit,minmax(250px,1fr));
    gap: 21px;
}

.service-card {
    transition: 0.4s ease;
}

.service-card:hover {
    transform: translateY(-10px);
}

.service-image {
    overflow: hidden;
    border-radius: 0 70px 0 70px;
    display: table;
    margin: 0 auto;
}

.service-image img {
    transition: 0.5s ease;
    border-radius: 0 70px 0 70px;
    display: table;
    margin: 0 auto;
}

.service-card h3 {
    text-align: center;
    font-size: 24px;
    line-height: 1.1;
    font-weight: 500;
    margin: 15px auto 25px;
}

.service-card h3 span {
    font-weight: 300;
    font-size: 22px;
}


.flex-block-2 {
    max-width: 1080px;
    margin: 150px auto;
    overflow: hidden;
}
.flex-block-2 img{
    max-width:100%
}
.flex-block-2 p {
    font-size: 17.5px;
    line-height: 1.5;
    display: block;
    font-weight: 300;
    margin-bottom: 26px;
}
.flex-block-2 .col-sm-8 img{
    border-radius:0px 0px 100px 0px;
    display: flex;
    justify-content: flex-end;
    float: right;
}
.flex-block-2 p i{
    font-weight:normal
}
.flex-block-2 p:last-child {
    font-weight: 400;
}

.flex-block {
    position: relative;
    transition: 0.5s ease all;
    background-size: cover;
}

.flex-block h1 {
    font-size: 28px;
    margin: 0;
    font-weight: bold;
    font-weight: 900;
    margin: 0 auto;
}

.flex-block h1 {
    font-size: 70px;
    font-weight: 900;
    display: block;
    line-height: 1;
    margin: 0px 0px 40px;
}

.flex-block h1 strong {
    display: flex;
    font-size: 32px;
    color: #fff;
    align-items: center;
    gap: 0px 10px;
    font-weight: 200;
    margin-top: 7px;
}

.flex-block h1 strong b {
    color: #fff;
    font-weight: 700;
    font-size: 30px;
    font-style: italic;
}

.flex-block h1 b {
    font-size: 59px;
    display: block;
    letter-spacing: 1px;
    font-family: 'Autography';
    font-weight: normal;
}

.flex-block h1>span {
    font-size: 25px;
    display: block;
    font-weight: 300;
    margin: 0px 0px 20px;
    color: var(--primary);
}

.flex-block h1 span:after {
    content: ""
}

.flex-block h1:after {
    content: "";
}

.flex-block>div {
    display: flex;
    margin: 0 auto;
    flex-wrap: wrap;
    padding: 0;
    position: relative;
    z-index: 2;
    color: var(--color-title);
}


.presence-section {
    display: flex;
    align-items: center;
    justify-content: space-around;
    padding: 150px 0px 100px;
    flex-wrap: wrap;
    max-width: 1400px;
    margin: 0 auto 50px;
    background: var(--back);
    padding-left: 100px;
    background-repeat: no-repeat;
    background-position: 15px 70px;
}
.text-1{
    background-image: url(../images/text1.png);
}
.text-2{ background-image: url(../images/text2.png);}
.text-3{ background-image: url(../images/text3.png);}
.presence-image img {
    max-width: 100%;
    border-radius: 100px 0px 0px 0px;
    position: relative;
    z-index: 1;
}

.presence-content {
    width: 50%;
    max-width: 520px;
}

.right-text .presence-content {
    text-align: right;
    padding-right: 50px;
    padding-left: 0;
}

.right-text .presence-image img {
    border-radius: 45px 0px 100px 0px;
}

.presence-image {
    width: max-content;
    position: relative;
}
.presence-image:before{content:"";background: url(../images/masque.png) no-repeat;width: 100%;height: 100%;position: absolute;top: -25px;left: -25px;}
.presence-content h2 {
    font-size: 30px;
    line-height: 1.1;
    margin-bottom: 40px;
    font-weight: 600;
    color: var(--primary);
}
.presence-content h2 b{
    display: block;
    font-size: 60px;
}
.presence-content h2 span{
    display: block;
    font-size: 30px;
    font-weight: 800;
}
.presence-content p {
    font-size: 19px;
    line-height: 1.5;
    color: #000;
    margin-bottom: 22px;
    font-weight: 400;
}
.presence-content p i{
    font-weight: 300;
}
.presence-content ul{
    list-style: none;
    margin-bottom: 20px;
    text-align: left;
}
.presence-content ul li{
    color: var(--primary);
    font-size: 18px;
    display: flex;
    align-items: center;
    gap: 0px 8px;
}
.presence-content ul li:before{content:"";width: 13px;height: 13px;background: var(--primary);border-radius: 50%;display: block;}

.block-text-center {
    max-width: 890px;
    margin: 31px auto 120px;
    padding: 40px 15px;
    text-align: center;
}

.block-text-center h2 {
    font-size: 38px;
    margin-bottom: 40px;
    font-weight: 500;
    line-height: 1;
}

.block-text-center h2 b {
    display: block;
    font-weight: 600;
}

.block-text-center h2 span {
    display: block;
    font-weight: 200;
    font-style: italic;
}

.block-text-center p {
    font-size: 1rem;
    line-height: 1.4;
    font-size: 19px;
    font-weight: 300;
    color: #fff;
    font-style: italic;
}

img {
    transition: 0.3s ease all;
}
.btn-commande{
    display: table;
    font-size: 22px;
    color: #000;
    position: relative;
    margin: 0 auto 50px;
    padding: 0px 50px;
    transition: 0.3s ease all;
}
.btn-commande:hover span{
    letter-spacing: 5px;
    color: #000;
}
.btn-commande:before{content:"";width: 100%;position: absolute;height: 1px;background: var(--primary);top: 50%;left: 0;}
.btn-commande span{
    display: block;
    padding: 10px 40px;
    text-transform: uppercase;
    letter-spacing: 1px;
    background: var(--back);
    position: relative;
    z-index: 1;
    transition: 0.3s ease all;
}
.cuvee-section {
    position: relative;
    padding: 50px 0;
    max-width: 1250px;
    margin: 0 auto;
}
.cuvee-section:before{content:"";width: calc(100% + 100px);position: absolute;height: 40px;background: #fff;left: -50px;}

/* TEXTE FIXE */
.left-fixed {
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    z-index: 10;
}

.left-fixed h2 {
    color: var(--primary);
    font-size: 65px;
    line-height: 1.1;
    font-weight: 400;
    font-family: 'Autography';
}

/* SLIDER */
#cuveeCarousel {
    width: 65%;
    margin-left: auto;
    background: #d2d1d1 url(../images/fleure.png) no-repeat;
    background-position: 9% 100%;
}

.cuvee-content {
    position: relative;
    display: flex;
    align-items: center;
    padding: 0;
}
.cuvee-content:before{content:"";width: 100%;position: absolute;height: 40px;background: #fff;top: 0;left: 0;z-index: 3;}

/* BOUTEILLE */
.bottle-block {
    width: auto;
    text-align: center;
    position: relative;
    padding-top: 20px;
    padding-left: 40px;
    top: -20px;
    left: -40px;
    position: relative;
}
.bottle-block:before{content:"";width: 40px;height: 100%;position: absolute;background: #efefef;}

.bottle-img {
    position: relative;
    z-index: 10;
}

/* CONTENT */
.right-content {
    width: 50%;
    padding-left: 80px;
    padding-top: 50px;
}

.year {
    display: block;
    font-size: 58px;
    margin-bottom: 0;
    font-family: 'Autography';
    display: block;
    line-height: 1;
}

.right-content h3 {
    letter-spacing: 8px;
    font-size: 24px;
    margin-bottom: 16px;
    font-weight: 300;
}

.composition p {
    margin-bottom: 0px;
    font-size: 17px;
    font-weight: 300;
}

.description {
    margin-top: 30px;
    font-size: 17px;
    line-height: 1.2;
    font-weight: 300;
}

/* BOUTON */
.more-btn {
    position: absolute;
    right: 0;
    top: 54%;
    transform: translateY(-50%);
    writing-mode: vertical-lr;
    text-orientation: mixed;
    background: url(../images/btn.png);
    color: #fff;
    text-decoration: none;
    padding: 88px 13px;
    letter-spacing: 4px;
    font-size: 16px;
    white-space: nowrap;
}

.more-btn:hover {
    color: #fff;
    text-decoration: none;
}

/* SECTION */
.heritage-section {
    padding: 90px 0;
    overflow: hidden;
    max-width: 1200px;
    margin: 0 auto 50px;
}

.heritage-section .container {
    width: 90%;
    max-width: 1250px;
    margin: auto;
}

/* GRID */
.heritage-grid {
    display: flex;
    gap: 70px;
    align-items: flex-start;
    justify-content: space-between;
    flex-wrap: wrap;
}

/* CARD */
.heritage-card {
    flex: 1;
    min-width: 320px;
    cursor: pointer;
    transition: 0.3s ease all;
}
.heritage-card:hover{
    transform:translateY(-20px)
}
.heritage-card:hover h2{color:var(--primary);letter-spacing: 2px;}
/* IMAGE */
.heritage-image {
    position: relative;
    overflow: hidden;
    transition: 0.3s ease all;
}


.heritage-image img {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
    transition: all 0.3s ease;
}


.heritage-card:hover .heritage-image::after {
    width: 58px;
}

/* CONTENT */
.heritage-content {
    padding-top: 40px;
}

/* TITRE */
.heritage-content h2 {
    font-size: 50px;
    line-height: 1.15;
    font-weight: 400;
    color: #111;
    margin-bottom: 28px;
    font-family: 'Autography';
    transition: 0.3s ease all;
}


.heritage-content p {
    font-size: 17px;
    line-height: 1.4;
    color: #000;
    margin-bottom: 18px;
    font-weight: 300;
}

/* BUTTON */
.heritage-btn {
    display: inline-block;
    margin-top: 20px;
    padding: 15px 40px;
    background: #a4477a;
    color: #fff;
    text-decoration: none;
    border-radius: 40px;
    font-size: 11px;
    letter-spacing: 5px;
    text-transform: uppercase;
    transition: all 0.35s ease;
}

.heritage-btn:hover {
    background: #91376a;
    color: #fff;
    transform: translateY(-3px);
    text-decoration: none;
}




/****** page interne ***/
.text{
    margin: 0 auto;
    max-width: 1440px;
    padding: 60px 15px;
}
.text p{
    font-size: 17px;
    line-height: 1.5;
    font-weight: 300;
}
.logo-bottom-footer {
    max-width: 100%;
    display: table;
}

.logo-bottom {
    max-width: 1400px;
    margin: 100px auto 50px;
    background-position: center;
    padding: 0px 40px;
}

.logo-bottom a {
}

.footer {
    width: 100%;
    max-width: 1400px;
    margin: 100px auto 15px;
    position: relative;
    z-index: 1;
    padding: 0px 15px;
    overflow: hidden;
}
.block-contact{
    background: url(../images/footer.jpg);
    background-repeat: no-repeat;
    max-width: 1400px;
    margin: 0 auto;
    padding: 26px 15px;
    display: flex;
    justify-content: flex-end;
}

.footer-container {
    display: flex;
    align-items: flex-end;
    position: relative;
    margin: 0 auto;
    justify-content: space-between;
}

.footer-container>div:first-child {
    color: #000;
    font-size: 15px;
    font-weight: 400;
}
.footer-container>div:first-child span{display: block;font-weight: 300;font-size: 15px;line-height: 1.6;}
.footer-container .right-top span{
    color: var(--primary);
    font-weight: 800;
    display: block;
    line-height: 1.1;
}
.footer-container>div:last-child {
    display: flex;
    align-items: center;
    gap: 0px 22px;
    color: #fff;
    font-size: 15.5px;
}

.link-contact {
    display: table;
    color: #fff;
    font-size: 15px;
    font-weight: 300;
    transition: 0.3s ease all;
    border-bottom: 1px solid;
    line-height: 1;
    margin-bottom: 0;
}

.link-contact:hover {
    letter-spacing: 1px;
    color: var(--primary);
}

/****** end Contact ***/
.footer-ico {
    display: block;
    max-width: 120px;
    filter: brightness(0) saturate(100%) invert(42%) sepia(7%) saturate(3522%) hue-rotate(264deg) brightness(83%) contrast(85%);
}

/****** footer ***/
.boxfooter {
    overflow: hidden;
    padding: 16px 10px;
    z-index: 1;
    position: relative;
    margin: 0 auto 50px;
    max-width: 1440px;
}

.footerlink {
    color: #d0d0d0;
    font-size: 10px;
    font-family: verdana;
    text-align: right;
}

.footerlink ul {
    list-style: none;
    margin: 0px;
    padding: 0px;
    display: inline-block;
}

.footerlink ul li {
    display: inline-block;
}

.footerlink ul li a {
    text-decoration: none !important;
    transition: 0.3s ease all;
    color: #914e7e;
    padding: 0px 10px;
    font-size: 12px;
}

.footerlink ul li a:hover {
    color: var(--primary);
}

.inlineblock {
    display: inline-block;
}

.footerlink ul {
    padding: 0px;
    margin: 0px;
    list-style: none;
    background: none;
}

.boxfooter>div {
    width: 100%;
    margin: 0;
    align-items: center;
}

/****** footer ***/
/****** end page interne ***/
@media (max-width: 1280px) {
    .navbar .navbar-nav .nav-item .nav-link {
        text-align: center;
        font-size: 15px;
    }
    .cuvee-section{overflow:hidden;max-width: 100%;}

    .navbar-nav:after {
        height: 100%;
    }

    .logo img {
        max-width: 350px;
    }
}

@media (min-width: 991px) {
    .navbar-expand-lg .navbar-collapse {
        display: block !important;
    }

.dropdown-item:hover {
    background: var(--primary);
    color: #fff;
}

.navbar-nav .nav-item.dropdown:hover>.dropdown-menu {
    display: block;
}

.dropdown-menu {
    left: 0;
    top: initial;
    background: var(--second);
    border: 0;
    border-radius: 0;
    margin: 0;
    padding: 0;
    top: 100%;
}
}

@media (max-width: 1024px) {
    .link-contact {
    }
    .presence-section{
    padding: 40px 15px;
    gap: 40px 0px;
    text-align: center;
}
}

@media (max-width: 992px) {
    /* ---------- GLOBAL PADDING ---------- */ .flex-block>div {
        flex-direction: column;
    }

    .flex-block-2 p {
        text-align: center;
        padding: 0;
    }


    .gallery-section {
        max-width: 330px;
        margin: 0 auto;
        padding: 0;
    }

      .gallery-grid {
        display: flex;
        flex-direction: column;
        gap: 20px 0px;
        text-align: center;
    }
    .gallery-section h2{
    padding: 0;
    text-align: center;
    width: 100%;
}
    .footer-container {
        flex-direction: column;
        top: 0;
        align-items: center;
        gap: 10px 0px;
    }
.footer-container>div{
    flex-direction:column;
    gap: 15px 0px;
}
    .footer-container>div:last-child {
        flex-direction: column;
        gap: 14px 0px;
        justify-content: center;
        align-items: center;
    }

    .footer-container .right-top {
        flex-direction: column;
        gap: 20px 0px;
    }

    .link-contact {
        margin: 0 auto 10px;
    }

    .navbar .navbar-nav .nav-item .nav-link:before {
        display: none
    }

    .navbar {
        padding: 0px
    }

    .navbar-nav:after {
        display: none
    }

    .navbar-nav .nav-item .nav-link {
        text-align: left
    }

    .inner-menubox {
        padding: 0;
        background: none;
        left: 0;
        width: 100%;
        border: none;
        max-width: 100%;
    }

    .collapse:not(.show) {
        display: block;
    }

    .navbar-nav {
        align-items: center;
        flex-direction: column;
    }

    .navbar-nav:first-child {
        padding-bottom: 0;
    }

    .menubox.fixed .navbar-nav {
        flex-direction: column;
    }

    .navbar-nav:last-child {
        background: none;
        max-width: 100%;
        margin: 0 !important;
        padding-top: 0;
        border: none;
    }
    .dropdown-menu{
    border: none;
    border-radius: 0;
}

    .navbar-nav .nav-item:after {
        display: none
    }

    .navbar .navbar-nav .nav-item .nav-link {
        padding: 8px 10px;
        font-size: 17px;
        color: #fff;
        border: none;
        text-shadow: none;
        font-weight: 700;
    }

    .navbar .navbar-nav .nav-item {
        background: none;
        display: block;
    }
.dropdown-item{
    color: #000;
}
    .navbar-nav .nav-item:before, .menubox:before, .menubox:after {
        display: none
    }

    .navbar-nav:last-child:before {
        display: none
    }

    .menubox {
        width: 100%;
        top: 58px !important;
        border: none;
        background: var(--primary) !important;
        position: fixed;
        top: 0;
        left: 0;
        width: 100%;
        z-index: 10;
        max-width: 100%;
        transform: translateX(-100%);
        transition: 0.3s ease all;
        bottom: initial;
        padding: 50px 20px 0px !important;
        margin: 0;
        height: 100%;
        display: block;
    }

    .menubox.activemenu {
        transform: none;
    }
.inner-menubox:before{display:none}
    .logo img {
        max-width: 100%;
    }

    .logo {
        width: 100%;
        left: 0;
        padding: 25px 0px;
        position: relative;
        top: 0;
    }
.logo>div{
    margin: 0 auto;
    top: 0;
}
    .logo:after, .logo:before {
        display: none;
    }

    .logo a:first-child img {
        display: block;
        margin: 0 auto;
    }

    .top {
        display: none
    }

    .inner-menubox:after {
        display: none
    }

    .menubox:after {
        display: none
    }

    .header {
        position: relative;
        top: 0;
        margin-top: 58px;
        max-height: initial;
        border: none;
        margin-bottom: 0;
        display: block;
        background-position: top;
        padding: 0;
        background-size: contain;
        background-position: center;
    }

    .bloc-menu a {
        display: table;
        padding: 0;
        top: 11px;
        left: 11px;
        position: relative;
        margin: 0;
    }

    .btn-menu:after {
        display: none
    }

    .bloc-menu.fixed {
        left: 0;
        top: 0;
        box-shadow: none;
        border-radius: 0;
    }

    .bloc-menu {
        top: 0;
        left: 0;
        width: auto;
        position: fixed;
        top: 0px;
        width: 100%;
        height: 58px;
        overflow: hidden;
        z-index: 13;
        display: block;
        animation: none !important;
        background: var(--primary);
    }

    .bloc-menu.fixed .btn-menu {
        margin: 0;
        padding: 0;
        background: none;
        box-shadow: none;
    }

    .bloc-menu img {
        position: relative;
        left: 0;
        top: 0;
        width: 40px;
    }

    .btn_scroll {
        display: none
    }

    .header:before {
        display: none
    }

    .header:after {
        display: none
    }

    .block-text-center {
        text-align: center;
        margin: 0 auto;
    }
.flex-block-2 .col-sm-8 img{
    float: none;
    margin: 50px auto 0;
}
    .flex-block-2 {
        margin: 0 auto;
        padding: 40px 15px;
        margin-top: 20px;
    }
    .cuvee-section:before{display:none}
    .flex-block-2 .col-12{
    flex: 100%;
    max-width: 100%;
}
.bottom-text p{
    font-size: 18px;
}
    .flex-block h1 b {
        text-align: center;
        font-size: 40px;
        margin: 0px 0px 5px;
    }

    .flex-block h1 strong b {
        font-size: 18px;
        margin: 5px 0px;
    }

    .flex-block h1 span:after {
        display: none;
    }

    .flex-block h1>span {
        text-align: center;
        background: none;
        margin-bottom: 9px;
        font-size: 20px;
    }

    .flex-block h1 strong {
        background: none;
        text-align: center;
        padding: 0;
        font-size: 27px;
        margin-bottom: 20px;
        justify-content: center;
        display: block;
    }

    img {
        max-width: 100%;
        margin: 0 auto;
        display: block;
    }

    .flex-block h1 {
        text-align: left;
    }
}

@media (max-width: 991px) {

    .resine-wrapper {
        height: 550px;
        background: url(../images/back.jpg);
        background-size: cover;
        background-position: center bottom;
    }

    .resine-bg {
    }

    .resine-box {
    left: 0;
    }

    .resine-box h2 {
        font-size: 28px;
        text-align: center;
        text-shadow: 1px 1px 5px #fff;
    }

    .project-box {
        width: calc(100% - 40px);
        height: 120px;
    }

    .project-box strong {
        font-size: 34px;
    }

    .bottom-text p {
        font-size: 18px;
    }
	
	  .top-block {
        flex-direction: column;
        max-width: 100%;
        margin: 0 auto;
    }
    .content-block>div h2{
    font-size: 45px;
}

    .stone-section {
        padding: 100px 15px;
        border-radius: 0;
    }
    .flex-contact{
    flex-direction: column;
    text-align: center;
    gap: 15px 0px;
    margin-bottom: 40px;
}

    .image-block {
        width: 100%;
        padding: 0;
        border-radius: 0;
    }

    .content-block {
        top: 0;
        padding: 0;
        text-align: center;
        width: 100%;
    }

    .content-block>div {
        background: none
    }

    .content-block p:before {
        margin: 0 auto 15px;
    }

    .bottom-text {
        margin: 50px auto;
        padding: 0px 15px;
        max-width: calc(100vw - 30px);
    }
	 .heritage-grid {
        flex-direction: column;
        gap: 60px;
    }

    .heritage-content h2 {
        font-size: 42px;
        text-align: center;
    }
    .heritage-card{
        text-align:center
    }
	
}

@media (max-width: 768px) {

    .presence-content h2 {
        font-size: 38px;
        text-align: center;
    }

    .presence-content p {
        font-size: 18px;
        text-align: center;
    }

    .presence-section {
        gap: 40px;
        text-align: center !important;
    }

    .presence-section>div {
        width: 100%;
        max-width: 100%;
        padding: 0 !important;
    }
    .presence-content h2 b{
    font-size: 45px;
}
 .left-fixed {
        position: relative;
        left: auto;
        top: auto;
        transform: none;
        text-align: center;
        margin-bottom: 40px;
    }

    #cuveeCarousel {
        width: 100%;
        background-position: 0% 0%;
    }
    .btn-commande span{
    font-size: 15px;
}
    .cuvee-content:before{display:none}
    .cuvee-content {
        flex-direction: column;
        text-align: center;
        padding: 40px 20px 80px;
    }
.bottle-block:before{display:none}
    .bottle-block,
    .right-content {
        width: 100%;
        padding: 0;
        left: 0;
        top: 0;
        margin-bottom: 40px;
    }

    .left-fixed h2,
    .year {
        font-size: 50px;
        text-align: center;
        margin: 0;
    }

    .more-btn {
        position: relative;
        top: auto;
        right: auto;
        transform: none;
        writing-mode: initial;
        display: inline-block;
        margin-top: 25px;
        padding: 12px 30px;
    }
}

@media (max-width: 767px) {
    .block-text-center h2 {
        margin-bottom: 20px;
    }

    .footer {
    }

    .footer {
        padding: 40px 20px;
    }
.footer-container .right-top span{
    text-align:center
}
    .footer-container>div:first-child {
        width: 100%;
        padding: 0;
        flex-direction: column;
        gap: 10px 0px;
        text-align: center;
    }

    .btn-intervention {
        max-width: calc(100% - 30px);
        background-size: 100% 100%;
        flex-direction: column;
        gap: 20px 0px;
    }

    .footerlink {
        text-align: center;
    }

    .footerlink ul {
        display: flex;
        flex-direction: column;
    }

    .menubox:after {
        display: none;
    }

    .logo img {
        margin: 0 auto;
        display: block;
        max-width: 100%;
    }

    .logo a {
        margin: 0px;
        padding: 0px 25px;
    }

    .boxfooter img {
        margin: 0 auto 15px;
        display: block;
        max-width: 120px;
    }
}



@media (max-width: 767px) {

    .heritage-section {
        padding: 70px 0;
    }

    .heritage-content h2 {
        font-size: 34px;
    }

    .heritage-content p {
        font-size: 14px;
        line-height: 1.75;
    }

    .heritage-btn {
        padding: 13px 30px;
        letter-spacing: 3px;
    }

    .heritage-image {
        border-top-left-radius: 60px;
        border-bottom-right-radius: 60px;
    }

}