/* ==========================================================================
   Global Styles
   ========================================================================== */

body {
    font-family: "Montserrat", sans-serif;
    font-optical-sizing: auto;
    font-weight: 400;
    font-style: normal;
    color: #353739;
    position:relative;
    overflow-x: hidden;
}
h1, h2, h3, h4 {
    font-family: "Montserrat", sans-serif;
    font-weight: 600;
}

h3 {
    font-size: 16px;
}

.bold-text {
    font-weight: 600;
}

.weight500 {
    font-weight: 500;
}

.desktop {
        display: block;
    }

.mobile {
    display:none;
}


/* Homepage  & General Styles
   ========================================================================== */

#home h1 {
    font-size:2.563rem;
    font-weight: 600;
    -webkit-transition: font-size .5s ease;
    -moz-transition: font-size .5s ease;
    -o-transition: font-size .5s ease;
    transition: font-size .5s ease;
}

.bg-callout-content h2 {
    font-size: 1.5rem !important;
    margin: 1rem auto;
}

.bg-callout-content p {
   font-size: 1.188rem; 
}

.bg-callout-content a:hover {
    
}

.bg-callout-content a .underline:after {
    content: '';
    position:absolute;
    width: 100%;
    border-top: solid 5px;
    left: 0;
    bottom: 0px;
    height: 8px;
    z-index: -1;
}

.bg-partners-content h1 {
    margin: 0 15rem;
}

.bg-dark-subtle {
    background-color: #EEECE8 !important;
}

/* Homepage Slider
   ========================================================================== */

#mainSlider {
    height:auto;
    z-index:3;
}

.carousel-inner {
    height:auto;
    /*padding: 0 3rem;*/
}

#mainSlider .carousel-indicators [data-bs-target] {
    box-sizing: content-box;
    flex: 0 1 auto;
    width: 15px;
    height: 15px;
    padding: 0;
    margin-right: 3px;
    margin-left: 3px;
    text-indent: -999px;
    cursor: pointer;
    border: 1px solid #fff !important;
    opacity: 1;
    transition: opacity .6s ease;
    border-radius: 10px;
    border-color: rgba(255, 255, 255, 1);
    background-color:transparent !important;
}

#mainSlider .carousel-indicators {
    position: absolute;
    right: 0;
    bottom: 170px !important;
    left: 0;
    z-index: 2;
    display: flex;
    justify-content: left;
    padding: 0;
    margin: 0 !important;
    height: 20px;
}

#mainSlider .carousel-indicators .active {
    opacity: 1 !important;
    background-color:rgba(255, 255, 255, 1)!important;
}

.bg-slider {
    height: 520px;
    border-radius: 0 0 99px 99px;
    background-size: 100% 100%; 
    background-position: 0px 0px,0px 0px,0px 0px,0px 0px,0px 0px,0px 0px,0px 0px,0px 0px,0px 0px,0px 0px,0px 0px; 
    background-image: radial-gradient(75% 75% at 92% 94%, #ED1C24 28%, #ED1C2400 100%),radial-gradient(75% 75% at 94% 25%, #9DCA39 50%, #9DCA3900 100%),radial-gradient(75% 75% at 27% 94%, #FFCB05 35%, #FFCB0500 100%),radial-gradient(75% 75% at 50% 22%, #00BFF3 60%, #00BFF300 100%);
    padding: 3rem !important;
    position: relative;
    z-index:1;
}

.slider-img img {
    border-radius: 3.188rem;
    width: 42.438rem !important;
    height:33.688rem;
    object-fit: cover;
}

.slider-text {
    font-size: 27px;
    -webkit-transition: font-size .5s ease;
    -moz-transition: font-size .5s ease;
    -o-transition: font-size .5s ease;
    transition: font-size .5s ease;
}

/* Page Headers & Page Content
   ========================================================================== */

.bg-page-header {
    height: 276px;
    border-radius: 0px 0px 99px 99px;
    padding: 4rem !important;
    position: relative;
    color: #fff;
}

#contact .bg-page-header {
    background-color: #EEECE8;
    border-radius: 0 !important;
    padding: 20px 60px !important;
    height: 260px;
}

#contact .contact-header h1 {
    color: #353739;
    font-size: 24px;
}

#contact .contact-header img,
#contact .google-map img{
    border-radius: 31px;
}

#contact .contact-info h2 {
    font-size: 27px;
}

#contact .contact-form h2 {
    font-size: 24px;
    text-transform: uppercase;
}

#contact .contact-form textarea {
    min-height: 170px;
}

#contact .contact-form .btn-submit:hover {
    border: 1px solid #353739;
}

#contact .contact-form .btn-submit:hover path {
    fill: #353739;
}

#contact .hours-callout {
    margin-top: 60px;
    padding: 50px;
    background-color: #353739;
    color: #fff;
    border-radius: 31px;
}

#contact .google-map {
    width: 100%;
    margin: 100px 0 0 0;
    padding: 0;
}

#contact .google-map img {
     width: 100%;
}

.bg-page-header .header-description {
    width: 850px;
    margin: 0 auto;
}

.cart .bg-page-header {
    border-radius: 99px 99px 0px 0px ; 
    background-color: #F6F5F3;
    height: 150px;
    padding: 2.5rem 0 0 0 !important;
}

.cart.cart-merci .bg-page-header {
    border-radius: 99px 99px 0px 0px ; 
    background-color: #F6F5F3;
    height: 75px;
    padding: 2.5rem 0 0 0 !important;
}

.cart #page-bottom {
    background-color: #EEECE8;
}

.cart .bg-page-bottom {
    border-radius:  0px 0px 99px 99px; 
    background-color: #F6F5F3;
    height: 75px;
    padding: 0 0 2.5rem  0 !important;
}

.bg-page-header h1 {
    text-transform:uppercase;
    font-size: 1.938rem;
}

.underline-text {
    position: relative;
    z-index:1;
}

.underline-text::after {
	content: "";
	width: 100%;
	height: 30px;
	background-image: url("../images/img-underline-yellow.svg");
    background-position: center;
    background-size:contain;
    background-repeat: no-repeat;
    position: absolute;
    bottom: -5px;
    left:0;
    z-index:-1; 

}

.intro-groupes {
    font-size: 1.188rem;
    line-height: 1.688rem;
}

.intro-solo {
    font-size: 1.438rem;
    line-height: 1.688rem;
}

.btn-dark {
    background-color: #353739;
    border-radius: 2.063rem;
}

.btn-home {
    text-transform:uppercase;
    font-weight:600;
    font-size:1.063rem;
    padding: 1.125rem 2.75rem;
}

.btn-home:hover {
    background-color: #EEECE8 !important;
    border: 1px solid #353739;
    color: #353739;
}

.callout-histoire,
.callout-intro {
    padding-top: 4.688rem;
    padding-bottom: 8rem;
    margin-top: 5rem;
}

.bg-callout-content,
.bg-partners-content {
    background-color: #fff;
    padding: 3rem;
    border-radius: 4.438rem;
}

.bg-callout-content img {
    display: block;
}

.bg-callout-content img.mobile {
    display: none;
}

.bg-callout-content .image-callout img {
    border-radius: 3.188rem;
    max-width: 100%;
    width: 40.375rem !important;
    height:auto;
}

.bg-callout-ski-sportifs {
    background: linear-gradient(161deg, #00BFF3 31.32%, #FB1016 88.16%);
    border-radius: 6.25rem;
    padding: 4rem;
}

.bg-partners-content {
    padding-bottom: 5rem;
}

.callout-partners {
    margin: 0;
    padding:0;
    background: linear-gradient(0deg, #EEECE8 50%, #000 50%);
}

/* Navigation Styles
   ========================================================================== */

.navbar header.mobile {
    display: none !important;
}

.navbar>.container, 
.navbar>.container-fluid, 
.navbar>.container-lg, 
.navbar>.container-md, 
.navbar>.container-sm, 
.navbar>.container-xl, 
.navbar>.container-xxl {
     display:block !important;
}

.nav-styles {
    text-transform: uppercase;
    font-size: 1.25rem;
    font-weight:700;
}
.nav-link {
    color: #353739 !important;
}

.btn-hamburger {
    margin: 0;
    padding: 0;
}

.sidebar {
    position: fixed;
    top: 0;
    left: -375px;
    width: 375px;
    height: 100%;
    background: #EEECE8;
    color: #353739;
    z-index: 1050;
    transition: left 0.3s ease;
    padding: 1rem 1.5rem;
    overflow-y: auto;
    max-height: 100vh;
}

.sidebar.open {
  left: 0;
}

.overlay {
  position: fixed;
  top: 0; left: 0;
  width: 100vw;
  height: 100vh;
  background-color: rgba(0, 0, 0, 0.5);
  display: none;
  z-index: 1040;
}

.overlay.show {
  display: block;
}

.sidebar .close-btn {
  font-size: 1.5rem;
  cursor: pointer;
  text-align: right;
  color: #fff;
  margin-bottom: 1rem;
}

.menu-item {
    cursor: pointer;
    padding: 0.75rem 0;
    color: #353739;
    background: none;
    border: none;
    text-align: left;
    font-weight: 700;
    font-size: 21px;
    text-transform: uppercase;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.menu-item .arrow {
  transition: transform 0.3s ease;
    margin-left: 10px;
}

.menu-item.active .arrow {
  transform: rotate(180deg);
}

.dropdown-container {
  overflow: hidden;
  max-height: 0;
  transition: max-height 0.3s ease;
}

.dropdown-container.show {
  max-height: 500px;
}

.dropdown-container a {
    color: #353739;
    font-size: 18px;
    font-weight: 500;
    display: block;
    padding: 0 0 0.5rem 0;
    text-decoration: none;
}

.dropdown-container a:hover {
  background-color: #495057;
}

.sidebar .bold-link {
    font-size: 21px;
    font-weight: 500;
}

.sidebar .quick-links li {
    padding-bottom: 15px;
}

.sidebar .quick-links.privacy-terms li {
    padding-bottom: 0;
}

.sidebar .quick-links a {
    font-size: 21px;
    font-weight: 400;
    color: #353739;
    text-decoration:none;
    
}

.sidebar .quick-links.privacy-terms a {
    font-size: 13px;
    text-decoration:underline;
    
}

.sidebar .social-links li {
    display: inline-block;
}

.bold-link {
    font-weight: 700;
    text-decoration: none;
    color: #353739;
    transition: opacity .3s ease;
    -webkit-transition: opacity .3s ease;
    -moz-transition: opacity .3s ease;
}

.bold-link:hover{
    text-decoration: none;
    color: #9A9B9C;
    opacity: 0.5;
}

.bold-link:hover svg path,
.bold-link:hover svg rect {
    stroke: #9A9B9C;
    transition: color .3s ease-in-out, background-color .3s ease-in-out, border-color .3s ease-in-out;
}

.basic-link {
    text-decoration: none;
    color:#353739;
}

.basic-link:hover {
    font-weight:700;
    transition: color .3s ease-in-out, background-color .3s ease-in-out, border-color .3s ease-in-out;
}

.active-link {
    font-weight: 700;
}

#navbarNav .dropdown:hover .dropdown-menu {
    display:block
}

#navbarNav .dropdown-menu, .dropdown-menu.show {
    left:-1.875rem;
    background-color: #353739 !important;
    border-radius: 17px !important;
    padding: 1.125rem;
}

/* Content Carousel Styles
   ========================================================================== */


/* Staff Carousel */

.carousel-wrapper {
    position: relative;
    overflow: hidden;
    margin-bottom: 3rem;
    padding-bottom: 3rem;
}

.card-track {
  display: flex;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scroll-behavior: smooth;
  -webkit-overflow-scrolling: touch;
  padding-bottom: 1rem;
  /*padding-left: 1rem;*/
}

.card-track::-webkit-scrollbar {
  display: none;
}

.carousel-card {
  flex: 0 0 auto;
  scroll-snap-align: start;
  margin-right: 1rem;
  width: calc((100% - 2rem) / 3);
}

@media (max-width: 768px) {
  
    .callout-staff h1 {
        margin-bottom: 30px;
    }
    
    .carousel-card {
    width: 85% !important;
    margin-right: 1rem;
  }
    .callout-staff .carousel-card {
        width: 40% !important;
        margin-right: 1rem;
    }

  .carousel-controls {
    display: none !important;
  }
    
    .carousel-card .card-body img {
        max-height: 100%;
        max-width: 100%;
        width: 22.438rem;
        height: 14.375rem;
        object-fit: cover;
        border-radius: 17px !important;
    }
    
    .callout-staff .carousel-card .card-body img {
        border-radius: 64.125rem !important;
        width: 157px;
        height: auto;
    }
    
    .carousel-card .card-body {
        padding: 0;
    }
    
    .callout-staff .carousel-card .card-title {
        font-size: 15px !important;
        margin: 10px 0 0 0;
    }
    
    .callout-staff .carousel-card .card-text {
        font-size: 11px !important;
    }
    
    .carousel-wrapper {
        margin-bottom: 0;
        padding-bottom: 0;
    }
        
}

.carousel-controls {
  position: absolute;
  bottom: 0;
  right: 60px;
  z-index: 10;
}

.carousel-controls button {
  background: none;
  border: none;
  margin-left: 2rem;
  cursor: pointer;
  padding: 0;
}

.carousel-controls i {
  font-size: 55px;
  color: #7F7F7F;
  transition: color 0.2s ease;
}

.carousel-controls button:hover i {
  color: #353739;
}

.carousel-wrapper .carousel-card {
    background: transparent;
    border: 0;
}

.carousel-card .card-body img {
    border-radius: 64.125rem;
}

.carousel-card .card-title {
    font-size: 1.313rem;
    font-weight: 700;
}

/* Popular Packages Carousel */

.popular-packages .carousel-wrapper {
    position: relative;
    overflow: hidden;
    margin-bottom: 0;
    padding-bottom: 0;
}

.popular-packages .carousel-card .card-content {
    padding: 16px 0;
}

.popular-packages .carousel-card .card-title {
    font-size: 17px;
    text-transform: uppercase;
}

.popular-packages .carousel-card .card-text {
    font-size: 17px;
    font-weight: 500;
}

.popular-packages .carousel-card .card-price {
    font-size: 16px;
    font-weight: 400;
}

#home .popular-packages .carousel-card .card-body img {
    width: 400px;
    height: 260px;
    object-fit: cover;
    border-radius: 23.5px;
}

.popular-packages .carousel-card:last-child {
    margin-right: 0;
}

/* Default card width: 3 cards */
.carousel-wrapper.three-cards .carousel-card {
  width: calc((100% - 2rem) / 3);
}

/* Default card width: 4 cards */
.carousel-wrapper.four-cards .carousel-card {
  width: calc((100% - 3rem) / 4);
}


/* 5-card layout */
.carousel-wrapper.five-cards .carousel-card {
  width: calc((100% - 4rem) / 5);
}

.btn-packages {
    border-radius: 3.525rem;
    padding: 1.125rem 2.75rem;
    text-transform: uppercase;
    font-weight:700;
}

/* Partner Logos Carousel */

.logos {
    overflow: hidden;
    padding: 0;
    background: white;
    white-space: nowrap;
    position: relative;
}

.logos:before,
.logos:after {
    position: absolute;
    top: 0;
    width: 250px;
    height: 100%;
    content: "";
    z-index: 2;
}

.logos:before {
    left: 0;
}

.logos:after {
    right: 0;
}

.logos-slider {
    display: inline-block;
    animation: 20s slide infinite linear;
    animation-direction: reverse;
}

.logos-slider img {
    height: 60px;
    margin: 0 40px;
}


/* Image Gallery Styles
   ========================================================================== */

.image-gallery {
    border-radius: 71px 71px 0 0;
    background: linear-gradient(180deg, #414042 34.15%, #000 58.31%);
    padding: 50px;
}

.gallery-grid {
  display: none;
}

.gallery-scroll {
  display: flex;
  overflow-x: auto;
  gap: 1rem;
  padding-bottom: 1rem;
  scroll-snap-type: x mandatory;
}

.gallery-scroll .gallery-item {
  flex: 0 0 auto;
  width: 80%;
  max-width: 300px;
  scroll-snap-align: start;
}

.gallery-scroll img,
.gallery-grid img {
    width: 100%;
    height: 200px;              /* Fixed height */
    object-fit: cover;          /* Crop to fill */
    border-radius: 0.5rem;
    cursor: pointer;
}

/* Show masonry on medium and up */
@media (min-width: 768px) {
    .gallery-scroll {
        display: none;
    }

    .gallery-grid {
        display: flex;
    }
    
    .gallery-grid .gallery-item {
        margin-bottom: 25px;
    }
    
    .gallery-scroll img,
    .gallery-grid img {
        width: 100%;
        height: 100%;
        border-radius: 31px;
        cursor: pointer;
    }
}

/* Newsletter Signup Styles
   ========================================================================== */

.newsletter {
    padding: 3rem 0;
}

.newsletter-text {
    text-align: left;
}
.newsletter-text h2 {
    color: #353739;
    font-size: 21px;
    font-weight: 600;
    margin-bottom: 0;
    margin-top: 6px;
}
.newsletter-text p {
    margin-bottom: 0;
    margin-top: 8px;
    line-height: 20px;
}
.newsletter-wrapper {
    overflow: hidden;
}

.newsletter2-wrapper .newsletter-form input {
    background: none;
    border: 1px solid #353739;
    border-radius: 0.563rem;
    color: #353739;
    display: inline-block;
    font-size: 1.188rem;
    font-weight: 400;
    height: 57px;
    margin-right: 17px;
 }

.newsletter2-wrapper .newsletter-form .form-check-input[type=checkbox] {
    width: 1.188rem;
    height: 1.188rem;
    margin-right: 0.5rem;
    background-color: transparent;
    border: 1px solid #353739;
    box-shadow: none;
    border-radius: .25em;
}

.newsletter2-wrapper .newsletter-form .form-check-input:checked[type=checkbox] {
    background-color: #353739;
    border-color: #353739;
    color: #fff;
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'%3e%3cpath fill='none' stroke='%23fff' stroke-linecap='round' stroke-linejoin='round' stroke-width='3' d='m6 10 3 3 6-6'/%3e%3c/svg%3e");
}

.newsletter2-wrapper .newsletter-form label.form-check-label {
    font-size: 13px;
    padding-top: 5px;
} 
.newsletter2-wrapper .newsletter-form .btn-newsletter,
#contact .contact-form .btn-submit {
    background: #353739 !important;
    border-radius: 2.063rem;
    color: #ffffff !important;
    display: inline-block;
    font-size: 1.125rem;
    font-weight: 600;
    line-height: normal;
    letter-spacing: 0.54px;
    text-transform: uppercase;
    padding: 18px 46px;
    transition: all 0.3s ease 0s;
    margin:0;
}

.newsletter2-wrapper .newsletter-form .btn-newsletter:hover,
#contact .contact-form .btn-submit:hover {
    background: transparent !important;
    color: #353739 !important;
}

.newsletter2-wrapper .newsletter-form .btn-newsletter.mobile {
    display: none;
}

.newsletter2-wrapper .newsletter-form button i {
    font-size: 18px;
    padding-left: 5px;
}

.divider .divider-line {
    height: 1.5px;
    opacity: 0.5;
    background: #353739;
    margin-bottom: 3rem;
}

.newsletter2-wrapper .newsletter-form input.form-control:focus {
    box-shadow:none;
}

.newsletter-form .invalid-feedback {
    width: 57%;
}

.newsletter-form .form-fields {
    width: 100%;
}

.newsletter-form .confirmations {
    margin-top: 8px;
}

#packages {
    background-color: #fff;
}

#packages .card img {
    max-height: 100%;
    max-width: 100%;
    height: 270px;
    border-radius: 1.656rem;
    object-fit: cover;
}

#packages .list-view .card img {
    max-height: 100%;
    max-width: 100%;
    width: 300px;
    height: 200px;
}

#packages .card {
    margin: 0 0 4rem 0;
    padding: 0 2rem;
    border: none;
    border-radius: 0;
    justify-content: center;
}

#packages .card-body {
    max-width: 100%;
    width: 359px;
    padding-right: 0;
    padding-left: 0;
    padding-bottom: 0;
}

#packages .card-title {
    text-transform: uppercase;
    font-size: 1.122rem;
    font-weight: 700;  
}

#packages .card-text {
    font-size: 1.122rem; 
}

/* Packages Grid General Styles
   ========================================================================== */

.packages-grid {
    position:relative;
    overflow: hidden;
}
#packages .item-img,
#groupes .popular-packages .item-img {
    position: relative;
    display: flex;
    padding: 0;
}

#packages .item-img .icon, 
#groupes .popular-packages .item-img .icon {
    position: absolute;
    text-align: center;
    width: 26px;
    height: 26px;
    color: #fff;
    border-radius: 26px;
    right: 1.5rem;
    cursor: pointer;
    transition: 0.5s;
}

#packages .item-img .icon {
    top: 225px;
}

#packages .list-view .item-img .icon {
    top: 160px;
    right: 90px;
}

#groupes .popular-packages .item-img .icon {
    top: 192px;
}

#packages .item-img .icon:hover,
#groupes .popular-packages .item-img .icon:hover {
    width: 125px;
}

#packages .item-img .icon .icon-i,
#groupes .popular-packages .item-img .icon .icon-i {
    opacity: 1;
    font-weight: 500;
}

#packages .item-img .icon:hover .icon-i,
#groupes .popular-packages .item-img .icon:hover .icon-i{
    opacity: 0;
}

#packages .item-img .icon .icon-label,
#groupes .popular-packages .item-img .icon .icon-label{    
    text-transform: uppercase;
    font-weight: 500;
    opacity: 0;
}

#packages .item-img .icon:hover .icon-label,
#groupes .popular-packages .item-img .icon:hover .icon-label{
    color: #fff;
    opacity:1;
    margin-right: 10px;
    transition-delay: 0.25s;
}

.clear-view {
    padding: 20px 80px;
    text-align: right;
}

.reset-filters,
.list-toggle {
    color: #888; 
    font-size: 19px;
    font-weight: 500;
}

.reset-filters {
    margin-right: 80px;
}

.card.item {
  opacity: 1;
  overflow: hidden;
  transition:  opacity 0.5s ease, visibility 0s ease 0.3s;
  visibility: visible;
  pointer-events: auto;
}

/* Step 1: Animate fade, shrink, slide up */
.card.item.filtered-out {
  opacity: 0;
    transition: opacity 0.5s ease, visibility 0 ease 0.3s;
  visibility: hidden;
  pointer-events: none;
}

/* Step 2: Remove from layout */
.card.item.gone {
  display: none !important;
}

#cardContainer {
    padding: 0 40px;
}

#cardContainer.list-view .card-wrapper {
  display: flex;
  gap: 1rem;
  align-items: flex-start;
  flex-wrap: wrap;
}

#cardContainer.list-view .item-img {
  flex: 0 0 25%;
  max-width: 25%;
}

#cardContainer.list-view .card-body {
  flex: 1 1 auto;
  min-width: 40%;
}

#cardContainer.list-view .button-column {
  flex: 0 0 20%;
  max-width: 20%;
  display: flex;
  justify-content: flex-end;
  align-items: flex-start;
  padding-top: 0.5rem;
}

/* Optional: remove default Bootstrap spacing for list layout */
#cardContainer.list-view .card {
    padding: 0.75rem;
    margin-bottom: 15px;
}

/* Side Filter Panel Styles */

.filter-panel {
    position: absolute;
    top: 100px;
    right: -315px;
    width: 315px;
    padding: 20px;
    padding-top:0;
    background-color: #F6F5F3;
    border-left: 1px solid #dee2e6;
    box-shadow: -3px 0 10px rgba(0,0,0,0.1);
    transition: right 0.2s ease;
    z-index: 1050;
}
.filter-panel.open {
  right: 0;
}
.filter-tab {
    position: absolute;
    top: 35px;
    left: -85px;
    width: 120px;
    height: 50px;
    background-color: #000;
    color: white;
    text-transform: uppercase;
    text-align: center;
    line-height: 1.5;
    transform: rotate(270deg);
    cursor: pointer;
    font-weight: 600;
    border-radius: 7px 7px 0 0;
    padding-top: 14px;
    box-shadow: -1px 1px 4px rgba(0,0,0,0.2);
}

.filter-panel select {
    background-color: #F6F5F3;
    border: 1px solid #888;
    border-radius: 0.563rem;
    color: #888;
    padding: 15px 29px;
    font-size: 19px;
    font-weight: 500;
}

.filter-panel select:focus {
    box-shadow: none;
    border: 1px solid #888;
}

#packages .grid-bottom {
    background-color: #656565;
    height: 50px
}

#packages .grid-bottom .col {
    background-color: #fff;
    border-radius: 0 0 4.438rem 4.438rem;
}

/* Promotions Callout Styles
   ========================================================================== */

#promotions {
    background-color: #EEECE8;
    align-content: center;
    text-align: center;
}

#cart.cart-merci #promotions {
    background-color: transparent;
}

#promotions .row {
    width: 100%;
    height: 530px;
    padding: 60px 0;
    background: linear-gradient(180deg, #656565 34.15%, #171717 58.31%); 
    border-radius: 0 0 4.438rem 4.438rem;
}

#cart.cart-merci #promotions .row {
    width: 100%;
    height: 500px;
    padding: 3rem;
    background: linear-gradient(180deg, #414042 34.15%, #000 58.31%); 
    border-radius: 4.438rem;
}

#promotions .promo-img img {
    width: 600px;
    border-radius: 1.938rem;
}

/* Shopping Checkout Styles
   ========================================================================== */

#etape1 .form-control.is-valid, 
#etape1 .was-validated .form-control:valid,
#etape2 .form-control.is-valid, 
#etape2 .was-validated .form-control:valid,
#groupes .form-control.is-valid, 
#groupes .was-validated .form-control:valid,
#contact .form-control.is-valid, 
#contact .was-validated .form-control:valid,
#espace-client .form-control.is-valid, 
#espace-client .was-validated .form-control:valid,
#portail-groupes .form-control.is-valid, 
#portail-groupes .was-validated .form-control:valid {
    background-image: none !important;
    border-color: #dee2e6 !important;
}

#etape1 .form-control.is-invalid, 
#etape1 .was-validated .form-control:invalid,
#etape2 .form-control.is-invalid, 
#etape2 .was-validated .form-control:invalid,
#groupes .form-control.is-invalid, 
#groupes .was-validated .form-control:invalid,
#contact .form-control.is-invalid, 
#contact .was-validated .form-control:invalid,
#espace-client .form-control.is-invalid, 
#espace-client .was-validated .form-control:invalid,
#portail-groupes .form-control.is-invalid, 
#portail-groupes .was-validated .form-control:invalid {
    background-image: none !important;
}

#etape1 .form-select.is-valid:not([multiple]):not([size]), 
#etape1 .form-select.is-valid:not([multiple])[size="1"], 
#etape1 .was-validated .form-select:valid:not([multiple]):not([size]), 
#etape1 .was-validated .form-select:valid:not([multiple])[size="1"],
#etape2 .form-select.is-valid:not([multiple]):not([size]), 
#etape2 .form-select.is-valid:not([multiple])[size="1"], 
#etape2 .was-validated .form-select:valid:not([multiple]):not([size]), 
#etape2 .was-validated .form-select:valid:not([multiple])[size="1"],
#groupes .form-select.is-valid:not([multiple]):not([size]), 
#groupes .form-select.is-valid:not([multiple])[size="1"], 
#groupes .was-validated .form-select:valid:not([multiple]):not([size]), 
#groupes .was-validated .form-select:valid:not([multiple])[size="1"],
#contact .form-select.is-valid:not([multiple]):not([size]), 
#contact .form-select.is-valid:not([multiple])[size="1"], 
#contact .was-validated .form-select:valid:not([multiple]):not([size]), 
#contact .was-validated .form-select:valid:not([multiple])[size="1"],
#espace-client .form-select.is-valid:not([multiple]):not([size]), 
#espace-client .form-select.is-valid:not([multiple])[size="1"], 
#espace-client .was-validated .form-select:valid:not([multiple]):not([size]), 
#espace-client .was-validated .form-select:valid:not([multiple])[size="1"] {
    background-image: none !important;
}

#etape1 .form-select.is-invalid:not([multiple]):not([size]), 
#etape1 .form-select.is-invalid:not([multiple])[size="1"], 
#etape1 .was-validated .form-select:invalid:not([multiple]):not([size]), 
#etape1 .was-validated .form-select:invalid:not([multiple])[size="1"] {
    background-image: var(--bs-form-select-bg-img);
}

#etape2 .form-select.is-invalid:not([multiple]):not([size]), 
#etape2 .form-select.is-invalid:not([multiple])[size="1"], 
#etape2 .was-validated .form-select:invalid:not([multiple]):not([size]), 
#etape2 .was-validated .form-select:invalid:not([multiple])[size="1"] {
    background-image: none !important;
}

#groupes .form-select.is-invalid:not([multiple]):not([size]), 
#groupes .form-select.is-invalid:not([multiple])[size="1"], 
#groupes .was-validated .form-select:invalid:not([multiple]):not([size]), 
#groupes .was-validated .form-select:invalid:not([multiple])[size="1"] {
    background-image: none !important;
}

#contact .form-select.is-invalid:not([multiple]):not([size]), 
#contact .form-select.is-invalid:not([multiple])[size="1"], 
#contact .was-validated .form-select:invalid:not([multiple]):not([size]), 
#contact .was-validated .form-select:invalid:not([multiple])[size="1"] {
    background-image: none !important;
}

#etape1 .form-control,
#etape2 .form-control,
#groupes .form-control,
#contact .form-control,
#etape1 .form-control:focus,
#etape2 .form-control:focus,
#groupes .form-control:focus,
#contact .form-control:focus,
#espace-client .form-control:focus,
#etape1 .form-select,
#etape2 .form-select,
#groupes .form-select,
#contact .form-select,
#etape1 .form-select:focus,
#etape2 .form-select:focus,
#groupes .form-select:focus,
#contact .form-select:focus,
#espace-client .form-select:focus {
    border: 1px solid #888;
    outline: 0;
    box-shadow: none;
    /*padding: 0.75rem;
    padding-bottom: 0.25rem;*/
}

#contact #contact-reason.form-select {
    background-color: #EEECE8;
}

#etape1 .form-select.chambres {
    width: 100px;
}

#groupes .callout-form textarea {
    min-height: 170px;   
}

.form-floating>.form-control-plaintext~label, 
.form-floating>.form-control:focus~label, 
.form-floating>.form-control:not(:placeholder-shown)~label, 
.form-floating>.form-select~label {
    transform: scale(.85) translateY(-.75rem) translateX(.15rem) !important;
}

#etape2 h2 {
    font-size: 1.688rem;
    font-weight: normal;
}

#etape2 h3 {
    font-size: 1.5rem;
    font-weight: 500;
}

#etape2 h4 {
    color: #888;
    font-size: 1.188rem;
    font-weight: 500;
    text-transform: uppercase;
}

#etape2 h5 {
    margin-top: 1rem;
    color: #888;
    font-size: 1.188rem;
}

#etape2 .btn-clear {
    text-transform: uppercase;
    font-size: 0.938rem;
}

#cart #etape2 {
    padding: 0;
}

/* Footer Styles
   ========================================================================== */

#footer,
#cart.cart-merci #footer {
    background: #EEECE8 !important;
    min-height: 750px;
    padding:0;
}

#cart #footer {
    background: #F6F5F3 !important;
    min-height: 175px;
}


#footer.footer-cart {
    height: 175px;
    padding-top: 5rem;
}

#footer h5 {
    color:#353739;
    text-transform: uppercase;
    font-weight: 700;
}

#footer a {
    color: #353739;
    text-decoration: none !important;
    background-color: transparent;
    -webkit-text-decoration-skip: objects;
}

#footer .footer-links {
    padding: 0 2rem;
}

#footer ul.quick-links li a {
	color:#353739;
}

#footer ul.quick-links.privacy-terms li a {
	font-weight: 700;
    text-decoration: underline !important;
}

#footer.footer-cart ul.quick-links.privacy-terms li a {
	font-weight: 400;
    font-size: 0.875rem;
    text-decoration: underline !important;
    line-height: 1rem;
}

#footer ul.quick-links li {
	padding: 3px 0;
	-webkit-transition: .5s all ease;
	-moz-transition: .5s all ease;
	transition: .5s all ease;
}

#footer ul.quick-links li:hover {
	padding: 3px 0;
	margin-left:5px;
    opacity: 0.5;
}

#footer ul.social-links li,
#contact ul.social-links li{
    display:inline-block;
    -webkit-transition: opacity .5s ease;
	-moz-transition: opacity .5s ease;
	transition: opacity .5s ease;
}

#footer ul.social-links li a:hover {
    opacity: 0.5;
}

#footer ul.privacy-terms,
#footer ul.social-links {
    margin-top: 6rem !important;
}

#footer .copyright-text {
    font-weight: 400;
    font-size: 12px;
    margin-top: 16px;
}

#footer.footer-cart ul.privacy-terms {
    margin: 0 !important;
}

@media (max-width:767px){
	#footer h5 {
        padding-left: 0;
        padding-bottom: 0px;
        margin-bottom: 10px;
    }
}

#footer .footer-links img {
    width: 200px;
}

.legal-text {
    font-size: 12px;
    text-align: center;
}

.credits {
    padding-bottom: 30px;
}

.credits p {
    margin: 0;
    font-size: 12px;
    text-align: center;
}

/* Bottom Scrolling Text Styles */

.scrolling-container {
  background-color: #EEECE8;
  background-size: cover;
  overflow: hidden;
  white-space: nowrap;
  position: relative;
  height: 215px;
  display: flex;
  align-items: center;
}

.scrolling-text {
    display: inline-block;
  white-space: nowrap;
  animation: scroll-left 30s linear infinite;
    
}

.scrolling-text span {
   display: inline-block;
    padding-right: 50px;
    color: #353739;
    font-size: 211px;
    font-style: normal;
    font-weight: 700;
    line-height: 211px; /* 100% */
    text-transform: uppercase;
    opacity: 0.05; 
}

@keyframes scroll-left {
  0% {
    transform: translateX(0%);
  }
  100% {
    transform: translateX(-50%);
  }
}

/* Cookie Notice Styles
   ========================================================================== */

#cb-cookie-banner { 
    position: fixed; 
    bottom: 0; 
    left: 0; 
    width: 100%; 
    z-index: 1021; 
    border-radius: 0; 
    display: none; 
    background-color: #EEECE8;
    padding: 2rem 8rem;
}

#btn-back-to-top {
    position: fixed;
    bottom: 20px;
    right: 20px;
    background-color: #353739;
    border: 1px solid #353739;
    border-radius: 9px;
    display: none;
}

#cb-cookie-banner p {
    max-width: 960px;
}

#cb-cookie-banner .cookie-btn {
    font-size: 0.875rem;
    font-weight: 700;
    text-transform: uppercase;
    border-radius: 0.35rem;
    padding: 0.75rem 1.45rem;
}

#cb-cookie-banner .cookie-btn.refuse {
    color: #353739;
    border: 1px solid #353739;
    background-color:transparent;
    opacity: 0.75;
}
#cb-cookie-banner .cookie-btn.refuse:hover {
    color: #fff;
    background-color: #353739;
}

#cb-cookie-banner .cookie-btn.accept {
    color: #fff;
    border: 1px solid #353739;
    background-color:#353739;
}

#cb-cookie-banner .cookie-btn.accept:hover {
    color: #353739;
    background-color: transparent;
}

#cb-cookie-banner .cookie-link {
    font-size: 0.813rem;
    color: #000;
}

#cb-cookie-banner .cookie-link:hover {
    text-decoration: none;
}

#cart .navbar h2 {
    font-weight: 400;
}

#cart .content-wrapper {
    background-color: #F6F5F3;
    padding: 2rem 4rem 0 4rem;
}

@keyframes slide {
    from {
        transform: translateX(0);
    }
    to {
        transform: translateX(-100%);
    }
}


/* Sticky Callout Button Styles
   ========================================================================== */

.callout-container {
    position: fixed;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    z-index: 1000;
    max-width:835px;
}

.callout-box {
    background: #000;
    border-top-left-radius: 16px;
    border-top-right-radius: 16px;
    box-shadow: 0 4px 16px rgba(0,0,0,0.2);
    width: 835px;
    height: 63px;
    text-align: center;
    transition: all 0.3s ease;
    padding: 0 20px;
}

.callout-box .text-wrapper {
    align-self: center;
}

.callout-box .callout-text {
    color: #FFCB05;
    font-size: 23px;
    font-weight: 600;
    display: block;
    line-height: 63px;
}

.callout-box .callout-button {
    width: 114.45px;
    padding: 10px 20px;
    margin: 0 30px;
    justify-content: center;
    align-items: center;
    gap: 10.5px;
    border-radius: 34.65px;
    border: 1px solid #fff;
    line-height: 63px;
}

.callout-box .callout-button a {
    color: #fff;
    font-size: 13px;
    font-weight: 700;
}

.callout-box .callout-button.mobile {
    display: none;
}

.callout-box .callout-minimize button {
    background: none;
    padding:0;
    margin:0;
    border:0;
}
.callout-circle {
    position: fixed;
    bottom: 10px;
    left: 50%;
    transform: translateX(-50%);
    width: 70px;
    height: 70px;
    background: #000;
    color: white;
    border-radius: 50%;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    align-items: center;
    box-shadow: 0 4px 16px rgba(0,0,0,0.2);
    cursor: pointer;
    font-size: 13px;
    font-weight: 600;
    text-transform: uppercase;
    padding-top: 10px;
    z-index: 1000;
}

.callout-circle .callout-arrow,
.callout-circle .open-callout {
    display:block;
}

.callout-circle .callout-arrow {
    color: #FFCB05;
}

.hidden {
    display: none;
}

/* Grid Filter Options Styles
   ========================================================================== */

.packages-info .options-menu ul li {
    background-color: #fff;
    color: #353739;
    border-radius: 7px;
    border: 1px solid #353739;
    text-transform: uppercase;
    font-weight: 500;
    min-width: 120px;
    text-align: center;
    line-height: 50px;
    padding: 0;
}

.packages-info .options-menu ul li a {
    padding: 15px 29px;
}

.filters .options-menu ul li {
    background-color: #fff;
    color: #353739;
    border-radius: 7px;
    padding: 15px 29px;
    border: 1px solid #353739;
    text-transform: uppercase;
    font-weight: 500;
    min-width: 120px;
    text-align: center;
}

.bg-page-header .filters .options-menu .btn.all:hover,
.bg-page-header .filters .options-menu .btn.all.active {
    background-color: #fff !important;
    border: 1px solid #fff;
    color: #353739;
    opacity: 1.0;
}

.options-menu {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch; /* smooth scrolling on iOS */
}

.swipeable-options {
    display: flex;
    flex-wrap: nowrap;
    overflow-x: auto;
    gap: 1rem;
    padding: 0;
    margin: 0;
    list-style: none;
    scroll-snap-type: x mandatory;
}

.swipeable-options li {
    scroll-snap-align: start;
    flex: 0 0 auto;
    white-space: nowrap;
    padding: 0.5rem 1rem;
    background-color: #eee;
    border-radius: 5px;
    cursor: pointer;
}

/* Optional: center on desktop */
@media (min-width: 768px) {
  #groupes .faq .swipeable-options {
    justify-content: center;
  }
}

/* About & Contact Page Styles
   ========================================================================== */

#about #page-header {
    padding: 70px;
    background-color: #EEECE8;
}

#about .bg-about-header {
    display: flex;
    background-color: #353739;
    min-height: 465px;
    border-radius: 51px;
    color: #fff;
}

#about .about-info,
#contact .bg-page-content .contact-info {
    background-color: #fff;
    border-radius: 4.438rem;
    padding: 3rem 5rem;
}

#about .bg-page-content,
#contact .bg-page-content {
    background-color: #EEECE8;
}

#about .bg-page-header {
    background-color: #EEECE8;
    border-radius: 0;
    padding: 4rem;
    height: 600px;
}

#about .bg-page-content .about-content {
    margin-bottom: 15px;
}

#about .about-image {
    margin: 30px 0 60px 0;
}

#about .about-image img {
    max-width: 100%;
    border-radius: 51px;
    object-fit: cover;
}

#about .about-image .left-column,
#about .about-image .right-column {
    padding: 30px 20px;
}


#about .about-image .right-column img {
    max-width: 100%;
    height: 100%;
    border-radius: 51px;
    object-fit: cover;
}

#about .btn-about {
    background-color: #00BFF3 !important;
    border: 1px solid #00BFF3;
    color: #fff;
    text-transform: uppercase;
    font-weight: 600;
    font-size: 1.063rem;
    padding: 1.125rem 2.75rem;
    border-radius: 2.063rem;
    margin-top: 30px;
}

#about .btn-about:hover {
    background-color: #fff !important;
    border: 1px solid #00BFF3;
    color: #00BFF3;
}

/* Mobile Styles
   ========================================================================== */

@media (max-width:767.98px) { /* applies to small devices (landscape phones, less than 768px)*/
    
    .navbar header.desktop {
        display: none !important;
    }
    
    .navbar header.mobile {
        display: block !important;
    }
    
    .navbar .navbar-brand img {
        width: 111px;
    }
    
    #home h1, 
    #groupes h1 {
        font-size: 1.25rem;
    }
    
    #contact .contact-header h1 {
        font-size: 24px;
        color: #fff;
    }
    
    #contact .contact-header img {
        border-radius: 31px;
        width: 100%;
    }
    
    .bg-page-header .header-description {
        width: 100%;
        margin: 0 auto;
    }
    
    .callout-histoire h1 {
        font-size: 1.188rem !important;
    }
    
    .bg-slider {
        height: 475px;
        border-radius: 0px 0px 25px 25px;
        padding: 30px !important;
    }
    
    .carousel-inner {
        height: auto;
        min-height: 420px;
        padding: 0;
    }
    
    .slider-img {
        margin-bottom: 20px;
    }
    
    .slider-img img {
        border-radius: 17px;
        height: 185px;;
    }
    
    .slider-text {
        font-size: 1rem;
    }
    
    #mainSlider .carousel-indicators {
        bottom: 10px !important;
        justify-content: center;
    }
    
    .callout-histoire, 
    .callout-intro {
        padding: 2rem;
        margin-top: 0;
    }
    
    .btn-home {
        font-size: 0.813rem;
        padding: 13.5px 33px;
        margin: 20px 0;
    }
    .intro-groupes {
        font-size: 1rem;
        line-height: 1.688rem;
    }
    
    .bg-callout-content .row, 
    .bg-partners-content .row {
        padding: 0 !important;
    }

    .bg-callout-content, 
    .bg-partners-content,
    .bg-callout-ski-sportifs{
        padding: 20px;
        border-radius: 17px;
    }
    
    .bg-partners-content {
        padding: 50px 20px !important;
    }
    
    .bg-callout-content .image-callout img {
        border-radius: 17px;
    }
    
    .bg-callout-content .image-callout img.mobile {
        width: 160px !important;
        margin-bottom: 10px;
        display: block;
    }
    
    #popularPackages .cards-wrapper, 
    #carouselPackages .cards-wrapper, 
    #carouselStaff .cards-wrapper, 
    #carouselTestimonials .cards-wrapper, 
    #carouselPartners .cards-wrapper {
        display: block;
    }
    
    #popularPackages .card {
        margin: 0;
        padding: 0 2rem;
        border: none;
        border-radius: 0;
        width: 100%;
        justify-content: center;
    }
    
    #home .popular-packages .carousel-card .card-title {
        margin: 15px 0;
        text-align: left;
    }
    
    .image-gallery {
        border-radius: 25px 25px 0 0;
        padding: 20px;
    }
    
    .image-gallery .col img {
        border-radius: 17px;
    }
    
    .bg-partners-content h1 {
        margin: 0;
        font-size: 1.25rem;
    }
    
    .bg-callout-content {
        text-align:center;
    }
    
    .bg-callout-content h2 {
        font-size: 1.125rem !important;
        font-weight: 600;
        margin: 1rem auto;
        text-align: left !important;
    }
    
    .bg-callout-content p,
    .popular-packages .carousel-card .card-text {
        font-size: 0.938rem;
        text-align: left !important;
    }
    
    .intro-solo {
        font-size: 0.938rem;
        line-height: 19px;
    }
    
    #etape2 .btn-clear {
       padding: 0;
    }
    
    #etape2 .btn-clear svg {
        width: 21px;
        height: 21px;
    }
    
    #etape2 h4 {
        font-size: 15px;  
    }
    
    .newsletter {
        padding: 40px 0;
    }
    .newsletter-text {
        text-align: center;
    }
    .newsletter-text h2 {
        font-size: 1.25rem;
        padding: 0 0 20px 0;
    }
    
    .newsletter2-wrapper .newsletter-form .btn-newsletter.mobile {
        display: block;
        padding: 10px 25px;
    }
    
    /*.newsletter2-wrapper .newsletter-form .btn-newsletter {
        display: none;
    }*/
    
    .newsletter2-wrapper .newsletter-form .form-control[type=email] {
        font-size: 1rem;
        height: 42px;
        min-height: 42px;
    }
    
    .newsletter2-wrapper .newsletter-form .form-check-input[type=checkbox] {
        width: 1.188rem;
        height: 1.188rem;
        margin-right: 0.5rem;
        background-color: transparent;
        border: 1px solid #353739;
        box-shadow: none;
        border-radius: .25em;
    }
    
    .newsletter2-wrapper .newsletter-form label {
        padding: .5rem .75rem;
    }
    
    .newsletter2-wrapper .newsletter-form label.form-check-label {
        font-size: 13px;
        padding: 5px 0;
        width: 85%;
    }
    
    .callout-box {
        width:100%;
        min-width:375px;
        padding: 10px 20px;
    }
    
    .callout-box .text-wrapper {
        align-self: unset;
    }
    
    .callout-box .callout-text {
        font-size: 14px;
        line-height: 19px;
        display: block;
        text-align: left;
    }
    
    .callout-box .callout-button {
        display:none;

    }
    
    .callout-box .callout-button.mobile {
        padding: 5px 20px;
        margin: 0;
        width: 60px;
        display: inline-block;
        line-height: 23px;
    }
    
    .scrolling-container.mobile {
        display: none;
    }
    
    .desktop {
        display: none !important;
    }
    
    .mobile {
        display:block;
    }
    
    .footer-links .col-xs-12 {
        margin-bottom: 30px;    
    }
    
    #footer ul.privacy-terms, 
    #footer ul.social-links {
        margin-top: 70px !important;
    }
    
    .bg-page-header {
        height: 255px;
        border-radius: 0px 0px 25px 25px;
        padding: 2rem 1rem !important;
    }
    
    .bg-page-header h1 {
        font-size: 1.563rem;
    }
    
    #promotions .promo-img img {
        width: 100%;
        border-radius: 17px;
    }
    
    #cb-cookie-banner {
        position: fixed;
        bottom: 0;
        left: 0;
        width: 100%;
        z-index: 1021;
        border-radius: 0;
        display: none;
        background-color: #EEECE8;
        padding: 20px;
    }
    
    #cb-cookie-banner h3 {
        font-size: 14px;
        font-weight: 600;
    }
    
    #cb-cookie-banner p,
    #cb-cookie-banner .cookie-link {
        font-size: 13px;
    }
    
    #about #page-header {
        padding: 0px;
        background-color: #fff;
    }
    
    #about .bg-about-header {
        display: flex;
        background-color: #353739;
        min-height: 275px;
        border-radius: 0 0 25px 25px;
        color: #fff;
    }
    
    #about .bg-page-content,
    #contact .bg-page-content {
        background-color: #fff;
    }
    
    #about .about-info {
        background-color: #fff;
        border-radius: 0;
        padding: 20px 0;
    }
    
    #about .bg-page-content .about-content {
        padding: 0 20px;
        margin: 0;
    }
    
    
    #about .about-content h1 {
        font-size: 21px;
        text-align: center;
    }
    
    #about .about-image {
        margin: 30px 0;
        padding: 0;
    }
    
    #about .about-image img {
        border-radius: 25px;
    }
    
    #about .about-image .left-column,
    #about .about-image .right-column {
        padding: 10px;
    }
    
    #about .about-image .left-column img,
    #about .about-image .right-column img {
        border-radius: 17px;
    }
    
    #contact .bg-page-header {
        display: flex;
        background-color: #353739;
        min-height: 275px;
        border-radius: 0 0 25px 25px !important;
        color: #fff;
        padding: 20px 60px !important;
    }
    
    #contact .bg-page-content .contact-info {
        background-color: #fff;
        border-radius: 0;
        padding: 20px 0 0 0;
    }
    
    #contact .bg-page-content .contact-info .left-column {
        padding: 0 35px;
    }
    
    #contact .contact-form {
        margin-top: 20px;
        padding: 20px 20px 100px 20px;
        background-color: #F6F5F3;
        border-top-left-radius: 25px;
        border-top-right-radius: 25px;
    }
    
    #contact .hours-callout {
        margin-top: 0;
        margin-bottom: 30px;
        padding: 40px;
        border-radius: 17px;
    }
    
    #contact .contact-form .btn-submit, 
    #contact .newsletter2-wrapper .newsletter-form .btn-newsletter {
        font-size: 14px;
        padding: 12px 26px 12px 26px;
    }
    
    #contact .google-map {
        margin: 0;
        background-color: #F6F5F3;
    }
    
    #contact .google-map img {
        border-top-left-radius: 25px;
        border-top-right-radius: 25px;
        border-bottom-left-radius: 0;
        border-bottom-right-radius: 0;
        width: 100%;
    }
    
    #contact .newsletter {
        background-color: #fff;
        border-radius: 25px;
        margin-bottom: 50px
    }
    
   
    #viewToggleBtn {
        display: none;
    }
    
    #cardContainer {
        padding: 0;
    }
    
    #packages .card img {
        height: 215px;
        border-radius: 17px;
    }
    
    #packages .item-img .icon {
        top: 170px;
    }
    
    .clear-view {
        padding: 20px;
    }


}
