.olton-wrapper {
  font-family: "Montserrat", sans-serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
  color: var(--color-white);
  font-size: 16px;
}
    .header__nav>ul>li:hover>.header__nav__dropdown {
        cursor: auto;
        top: 46px !important;
    }

@media (min-width: 768px) {
  .olton-wrapper .page-container {
      padding-left: 20px;
      padding-right: 20px;
  }
}

@media (min-width: 992px) {
  .olton-wrapper .page-container {
      padding-left: 60px;
      padding-right: 60px;
  }
}


.page-container.landing-page-container .olton-wrapper {
  background: none !important;
  margin-top: 26px;
    margin-bottom: 26px;
}
.olton-wrapper .container {
  position: relative;
  z-index: 4;
  padding-left: 0;
  padding-right: 0;
}
@media (min-width: 992px) {
  .olton-wrapper .container {
    padding-left: 2rem;
    padding-right: 2rem;
  }
}
:root {
  /* Color Variables */
  --brown: #9a7d4a;
  --dark-brown: #664d22;
  --bright-green: #00844c;
  --dark-green: #009163;
  --bottle-green: #014025;
  --black: #000;
  --white: #fff;
  --beige: #F3EFE9;
  --dark-grey: #373A36;
  
  /* RAL Custom Colors */
  --ral-orange: #FF2D00;    /* RAL 2005 */
  --ral-green: #287233;     /* RAL 6001 */
  --ral-blue: #1F3A93;      /* RAL 5003 */
  --ral-burgundy: #641C34;  /* RAL 4004 */
  --ral-yellow: #F3A505;    /* RAL 1033 */
  --ral-red: #721422;       /* RAL 3032 */

  /* Gradient Variables */
  --brown-gradient-vertical: linear-gradient(
    162.69deg,
    #9a7d4a 11.88%,
    #342a19 88.66%
  );
  --brown-gradient-horizontal: linear-gradient(
    90deg,
    rgba(172, 150, 110, 0.2) 3.65%,
    #9a7d4a 80.28%
  );
  --green-gradient-vertical: linear-gradient(
    162.69deg,
    #00844c 11.88%,
    #014025 88.66%
  );
  --bottle-green-gradient-vertical: linear-gradient(
    162.69deg,
    #014025 11.88%,
    #001a0f 88.66%
  );
  --gold-brown-gradient-horizontal: linear-gradient(
    90deg,
    #70582E 3.65%,
    #9A7D4A 80.28%
  );

  /* Typography Variables - Mobile First */
  --font-h1: 3rem;
  --font-h2: 1.8rem;
  --font-h3: 1.4rem;
  --font-h4: 1.24rem;
  --font-h5: 1.02rem;
  --font-p: 0.94rem;
}


 .content-beige {
    background: var(--beige);
  }
  .content-green {
    background: var(--bright-green);
    color: var(--white);
  }
  .content-dark-grey {
    background: var(--dark-grey);
    color: var(--white);
  }
.color-brown {
  color: var(--brown);
}
.color-bright-green {
  color: var(--bright-green);
}
.color-dark-green {
  color: var(--dark-green);
}
.color-bottle-green {
  color: var(--bottle-green);
}
.color-black {
  color: var(--black);
}
.color-white {
  color: var(--white);
}

.bg-gold-brown-gradient {
  background: var(--gold-brown-gradient-horizontal);
}

/* Typography - Mobile First Approach */
.olton-wrapper h1 {
  font-size: var(--font-h1);
  line-height: 100%;
  text-align: left;
  padding: 0;
  margin: 0 0 1.8rem 0;
  color: var(--white);
}
.olton-wrapper h2 {
  font-size: var(--font-h2);
  line-height: 120%;
  margin: 0 0 1.4rem 0;
}
.olton-wrapper h3 {
  font-size: var(--font-h3);
  line-height: 120%;
}
.olton-wrapper h4 {
  font-size: var(--font-h4);
  line-height: 110%;
}
.olton-wrapper h5 {
  font-size: var(--font-h5);
  line-height: 110%;
}

.olton-wrapper p,
.olton-wrapper li {
  font-size: var(--font-p);
  line-height: 150%;
}

.olton-hero-title.cta-title {
  color: var(--white) !important;
  font-size: var(--font-h2) !important;
}
/* Lined List Style */
.lined-list {
  list-style: none;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 2rem;
  margin-top: 1.8rem;
  margin-bottom: 2.4rem;
}

.inset-text-column {
  position: relative;
}
.inset-text-column .graphic-wrapper {
  position: relative;
}
.inset-text-column .inset-text {
  background: #ffffff22;
    color: var(--white);
    margin-top: 1.4rem;
    padding: 1.24rem;
}
.inset-text-column .inset-text p {
    margin: 0;
}


.lined-list li svg {
    position: relative;
    width: 24px;
}
.lined-list li {
  display: flex;
  flex-direction: row;
  gap: 0.82rem;
  border-bottom: 1px solid rgba(255, 255, 255, 0.12);
}
.lined-list li p {
  margin: 0;
}
.lined-list li p.lined-list-title {
  font-weight: 700;
  font-size: var(--font-h5);
  text-transform: uppercase;
  margin: 0;
}

.lined-list li div {

}

.lined-list li:last-child {
  border-bottom: none;
  margin-bottom: 0;
  padding-bottom: 0;
}

/* Tablet - 768px and up */
@media (min-width: 768px) {
  :root {
    --font-h1: 3.6rem;
    --font-h2: 1.8rem;
    --font-h3: 1.24rem;
    --font-h4: 1.1rem;
    --font-h5: 1.04rem;
    --font-p: 0.98rem;
  }
  .olton-wrapper h1 {
    margin: 0 0 1.5rem 0;
  }
}

/* Large Tablet/Small Desktop - 992px and up */
@media (min-width: 992px) {
  :root {
    --font-h1: 4rem;
    --font-h2: 2rem;
    --font-h3: 1.6rem;
    --font-h4: 1.5rem;
    --font-h5: 1.1rem;
    --font-p: 1rem;
  }
  .olton-wrapper h1 {
    margin: 0 0 1.8rem 0;
  }
}

/* Desktop - 1200px and up */
@media (min-width: 1200px) {
  :root {
    --font-h1: 5rem;
    --font-h2: 2.2rem;
    --font-h3: 1.7rem;
    --font-h4: 1.3rem;
    --font-h5: 1.14rem;
    --font-p: 1rem;
  }
  .olton-wrapper h1 {
    line-height: 100%;
    margin: 0 0 2rem 0;
  }
}

/* Large Desktop - 1400px and up */
@media (min-width: 1400px) {
  :root {
    --font-h1: 5.2rem;
    --font-h2: 2.4rem;
    --font-h3: 1.8rem;
    --font-h4: 1.4rem;
    --font-h5: 1.2rem;
    --font-p: 1.04rem;
  }
}

p.larger-text {
    font-size: var(--font-h3) !important;
    line-height: 108% !important;
    margin: 0 0 1.4rem 0 !important;
    font-weight: 700 !important;
    font-family: 'Montserrat';
}
p.large-text {
    font-size: 1.12rem !important;
    line-height: 140% !important;
    margin: 0 0 1.42rem 0 !important;
    font-weight: 600 !important;
}

@media (min-width: 992px) {
  p.large-text {
    font-size: 2rem !important;
  }
}
.olton-wrapper h1,
.olton-wrapper h2,
.olton-wrapper h3,
.olton-wrapper h4,
.olton-wrapper h5,
.olton-wrapper h6 {
  font-family: "Montserrat", sans-serif;
  font-optical-sizing: auto;
  font-weight: 700;
  font-style: normal;
}
.olton-wrapper h1:after {
  display: none;
}
.olton-wrapper h1 {
  text-transform: uppercase;
}
.olton-wrapper .olton-intro {
  text-transform: uppercase;
  margin: 0;
  font-size: var(--font-h4);
  font-weight: 400;
  font-family: "Montserrat";
}
.olton-wrapper .olton-intro span {
  font-weight: 700;
}
.olton-wrapper .olton-strapline {
  text-transform: uppercase;
  font-weight: 700;
  letter-spacing: 0.04rem;
  margin: 0 0 1.6rem 0;
  color: var(--white);
}
.olton-wrapper .olton-strapline span {
  color: var(--bright-green);
}
.olton-wrapper .olton-hero-text {
}
.olton-wrapper .olton-hero-text p {
  margin: 0 0 1.2rem 0;
  color: var(--white);
  font-weight: 320;
}

.olton-wrapper .olton-hero h2 {
  font-size: var(--font-h3);
}

.hero-image-right {
    width: 70%;
    height: auto;
    object-fit: contain;
}

@media (min-width: 768px) {
  .hero-image-right {
    width: 92%;
  }
}

/* Buttons */
.btn-regular {
  font-weight: 600;
  font-size: var(--font-p);
  border-radius: 0px;
  text-transform: uppercase;
  display: flex;
  flex-direction: row;
  align-items: center;
  padding: 14px 28px;
  gap: 10px;
  color: var(--white);
  text-decoration: none;
  background: var(--dark-green);
  transition: background 300ms ease;
}
.btn-large {
    font-weight: 600;
    font-size: var(--font-h5);
    border-radius: 0px;
    display: inline-flex;
    align-self: flex-start;
    flex-direction: row;
    align-items: center;
    padding: 14px 38px;
  gap: 10px;
  color: var(--color-white);
  text-decoration: none;
  background: var(--dark-green);
  transition: background 300ms ease;
}
.btn-bright-green {
  background: var(--bright-green);
}
.btn-bright-green:hover {
  background: var(--bottle-green);
}
.btn-brown {
  background: var(--brown);
}
.btn-brown:hover {
  background: var(--dark-brown);
}

.btn-regular:hover, .btn-large:hover {
  color: var(--white);
}

/* Shapes */
.side-shape {
  position: absolute;
  width: 50vw;
  height: auto;
  z-index: 1;
  pointer-events: none;
}
.side-shape.green-one {
  left: 0;
  top: -30%;
}
.side-shape.brown-one {
  right: 0;
  top: 0%;
}
.background-shape {
    position: absolute;
    width: 100vw;
    top: -20%;
    height: auto;
    object-fit: cover;
    z-index: 2;
    pointer-events: none;
}

/* Hero Section */
.olton-hero {
    padding-top: 40px;
    padding-bottom: 40px;
    height: auto;
    min-height: auto;
    background: var(--black);
    overflow: hidden;
}
@media (min-width: 768px) {
  .olton-hero {
    padding-top: 80px;
    padding-bottom: 100px;
    min-height: 600px;
  }
}
@media (min-width: 992px) {
  .olton-hero {
    padding-top: 100px;
    padding-bottom: 120px;
    min-height: 600px;
  }
}
.olton-hero .container {
  position: relative;
  z-index: 2;
}
.olton-hero-title {
  text-transform: none;
  margin: 0 0 1.4rem 0 !important;
}
.olton-hero-image {
    position: absolute;
    top: 110px;
    right: 0;
    width: 100vw;
    height: auto;
    object-fit: contain;
    z-index: 0;
    opacity: 0.44;
}
@media (min-width: 768px) {
  .olton-hero-image {
      position: absolute;
      top: 0;
      right: 0;
      width: 60vw;
      height: 100%;
      object-fit: contain;
      z-index: 0;
      opacity: 0.44;
  }
}


/* Eco Slider */
.olton-eco-slider {
  padding: 60px 0;
}

@media (min-width: 992px) {
  .olton-eco-slider {
    padding: 140px 0;
  }
}


.olton-content-section {
  padding: 60px 0;
}
.olton-content-section.content-padding-tall {
  padding: 80px 0;
}
.olton-padding-box {
  
}
@media (min-width: 768px) {
  .olton-content-section {
    padding: 80px 0;
  }
  .olton-content-section.content-padding-tall {
    padding: 100px 0;
  }
  .olton-padding-box {
    padding: 100px 0;
  }
}

.side-by-side {

}
.side-by-side img {
  width: 100%;
  height: auto;
  margin-bottom: 1.8rem;
}
.side-by-side h3 {
  margin: 0 0 0.8rem 0;
}
.side-by-side p {
  color: #6C6E6C;
}

.olton-bar-section {
  color: var(--white);
  padding: 2.68rem 0;
  text-align: center;
}
.olton-bar-section h2 {
  font-weight: 300;
  text-transform: uppercase;
  font-size: var(--font-h4);
  margin: 0;
}
.olton-bar-section strong {
  font-weight: 600;
}
@media (min-width: 1400px) {
  .olton-bar-section h2 {
    font-size: var(--font-h3);
  }
}

/* Finishes Carousel Styles */
.olton-product-slider {
  color: var(--black);
}

.finish-navigation {
  margin: 0 auto;
  max-width: 100%;
}

.finish-group-wrapper {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  width: 100%;
}

.finish-group {
  display: flex;
  flex-direction: row;
  gap: 0.25rem;
  align-items: stretch;
  padding: 0.5rem 0.625rem;
  background: var(--black);
  border-radius: 0;
  width: 100%;
  flex-wrap: wrap;
  justify-content: center;
}


.finish-slide-content img {
    width: 100%;
    height: auto;
    object-fit: contain;
    transform: scale(1.24);
    z-index: -1;
    position: relative;
    margin-bottom: 1.4rem;
}

.finish-group-label {
  font-size: 0.88rem;
  font-weight: 700;
  color: var(--black);
  text-transform: uppercase;
  text-align: left;
  margin-bottom: 0.8rem;
  padding-left: 0;
}

.finish-select {
  width: 100%;
  padding: 0.625rem 0.75rem;
  background: var(--black);
  border: none;
  border-radius: 0;
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--white);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%23ffffff' d='M1.41 0L6 4.58 10.59 0 12 1.41l-6 6-6-6z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 0.75rem center;
  padding-right: 2.5rem;
  cursor: pointer;
}

.finish-select option {
  background: var(--black);
  color: var(--white);
  padding: 0.5rem;
}

.finish-buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 0.25rem;
  justify-content: center;
}

.finish-button {
  padding: 0.375rem 0.75rem;
  background: transparent;
  border: none;
  border-radius: 0;
  font-size: 0.625rem;
  font-weight: 600;
  color: var(--white);
  cursor: pointer;
  transition: all 0.2s ease;
  white-space: nowrap;
  text-transform: uppercase;
  user-select: none;
  letter-spacing: 0.05em;
  flex: 1 1 100%;
  text-align: center;
}

.finish-button:hover {
  background: rgba(255, 255, 255, 0.1);
}

.finish-button.active {
  background: var(--bright-green);
  color: var(--white);
}

.solid-finishes .finish-button.active {
  background: #535353;
  color: var(--white);
}

.finishes-swiper {
  width: 100%;
  padding: 1rem 0;
  overflow: visible !important;
}

.finishes-swiper .swiper-wrapper {
  align-items: center;
}

.finishes-swiper .swiper-slide {
  display: flex;
  align-items: center;
  justify-content: center;
  transition: opacity 0.3s ease;
  opacity: 0.4;
  height: auto;
}

.finishes-swiper .swiper-slide-active {
  opacity: 1 !important;
}

.finish-slide-content {
    background: none;
    padding: 0px !important;
    border-radius: 0px;
    text-align: center;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    flex-direction: column;
    gap: 20px;
}



.finish-slide-content h3 {
  font-size: var(--font-h4);
    font-weight: 700;
    margin: 0;
    color: var(--black);
    text-transform: uppercase;
}

@media (min-width: 768px) {
  .finish-navigation {
    flex-direction: row;
    align-items: flex-start;
    flex-wrap: wrap;
  }
  
  .finish-group-wrapper {
    width: auto;
    max-width: 100%;
  }
  
  .finish-group {
    flex-direction: row;
    gap: 0.25rem;
    padding: 0.625rem 0.875rem;
    align-items: center;
    width: auto;
    flex-wrap: wrap;
  }
  
  .finish-group-label {
    text-align: left;
    margin-bottom: 0;
  }
  
  .finish-button {
    flex: 0 1 auto;
    padding: 0.375rem 0.75rem;
    font-size: 0.625rem;
  }
  
  .finish-slide-content {
    padding: 5rem 3rem;
  }
}

@media (min-width: 992px) {
  .finish-button {
    padding: 0.375rem 0.875rem;
    font-size: 0.688rem;
  }
  
  .finish-slide-content {
    padding: 6rem 4rem;
  }
}

@media (min-width: 992px) and (max-width: 1300px) {
  .finish-group {
    gap: 0.125rem;
  }
  
  .finish-button {
    padding: 0.375rem 0.625rem;
    font-size: 0.625rem;
  }
}

@media (min-width: 1200px) {
  .finish-group {
    flex-wrap: nowrap;
  }
  
  .finish-button {
    padding: 0.375rem 1rem;
    font-size: 0.75rem;
  }
}