@import url("https://fonts.googleapis.com/css2?family=Inter:ital,opsz,wght@0,14..32,100..900;1,14..32,100..900&family=Libre+Baskerville:ital,wght@0,400..700;1,400..700&family=Raleway:ital,wght@0,100..900;1,100..900&family=Roboto:ital,wght@0,100..900;1,100..900&display=swap");

/* Variables */
:root {
  /* Font Family */
  --body-font-family: "Roboto", sans-serif;
  --heading-font-family: "Roboto", sans-serif;

  /* Colors */
  --primary: #b21c11;
  --primary-hover: #9b150c;
  --secondary: #eb8e16;
  --secondary-hover: #d77a14;
  --accent: #ff9305;
  --text: #333333;
  --dark: #000000;
  --dark-bg: #000000;
  --light: #ffffff;
  --border: #cccccc;
  --body-bg: #ffffff;

  /* Typography */
  --text-xs: 0.75rem;
  --text-sm: 0.875rem;
  --text-base: 1rem;
  --text-lg: 1.125rem;
  --text-xl: 1.25rem;
  --text-2xl: 1.5rem;
  --text-3xl: 1.875rem;
  --text-4xl: 2.25rem;
  --text-5xl: 3rem;
  --text-6xl: 3.75rem;
  --text-7xl: 4.5rem;

  /* Line Height */
  --line-height-base: 1.5;
  --line-height-heading: 1.2;

  /* Buttons */
  --btn-padding-x: 2rem;
  --btn-padding-y: 0.875rem;
  --btn-sm-padding-x: 1.5rem;
  --btn-sm-padding-y: 0.625rem;
  --btn-font-size: 1.125rem;
  --btn-sm-font-size: 0.875rem;
  --btn-font-weight: 500;
  --btn-border-radius: 0.25rem;

  /* Forms */
  --input-padding-x: 1rem;
  --input-padding-y: 0.875rem;
  --input-border-radius: 0.25rem;
  --input-bg: #ffffff;
  --input-color: #000000;
  --input-placeholder-color: #888888;
  --textarea-height: 6rem;

  /* Shadows */
  --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.05);
  --shadow-md: 0 4px 6px rgba(0, 0, 0, 0.1);
  --shadow-lg: 0 10px 15px rgba(0, 0, 0, 0.15);
  --shadow-xl: 0 20px 25px rgba(0, 0, 0, 0.2);

  /* Cards */
  --card-bg: #ffffff;
  --card-padding: 1rem;
  --card-border-radius: 0.5rem;

  /* Sections */
  --section-px: 2rem;
  --section-pt: 5rem;
  --section-pb: 5rem;
  --section-inner-spacing: 2.5rem;

  /* Container */
  --container-max-width: 1300px;

  /* Text Spacing */
  --text-spacing: 1.25rem;

  /* Spacing */
  --spacing-1: 0.25rem;
  --spacing-2: 0.5rem;
  --spacing-3: 0.75rem;
  --spacing-4: 1rem;
  --spacing-5: 1.25rem;
  --spacing-6: 1.5rem;
  --spacing-7: 1.75rem;
  --spacing-8: 2rem;
  --spacing-9: 2.25rem;
  --spacing-10: 2.5rem;
  --spacing-12: 3rem;
}

/* @media (prefers-color-scheme: dark) {
  :root {
    --primary: #0336df;
    --primary-hover: #0229b0;
    --secondary: #eb8e16;
    --secondary-hover: #d77a14;
    --accent: #16eb28;
    --text: #ffffff;
    --dark: #ffffff;
    --dark-bg: #000000;
    --light: #000000;
    --border: #444444;
    --body-bg: #000000; */

/* Form */
/* --input-bg: #1a1a1a;
    --input-color: #ffffff;
    --input-placeholder-color: #aaaaaa; */

/* Cards */
/* --card-bg: #1a1a1a;
  }
} */

@media (width < 992px) {
  :root {
    --section-px: 1.5rem;
  }
}

@media (width < 768px) {
  :root {
    --section-px: 1.25rem;
    --section-pt: 4rem;
    --section-pb: 4rem;
  }
}

* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

html,
body {
  scroll-behavior: smooth;
}

body {
  font-family: var(--body-font-family);
  line-height: var(--line-height-base);
  background-color: var(--body-bg);
  color: var(--text);
  font-size: var(--text-lg);
}

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

ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

a {
  text-decoration: none;
  color: var(--accent);
}

/* Typography */
h1,
h2,
h3,
h4,
h5,
h6 {
  font-family: var(--heading-font-family);
  line-height: var(--line-height-heading);
  color: var(--dark);
  font-weight: 600;
  line-height: 1.2;
  margin-bottom: 0.5rem;
}

h1 {
  font-size: var(--text-7xl);
}

h2 {
  font-size: var(--text-6xl);
}

h3 {
  font-size: var(--text-3xl);
}

h4 {
  font-size: var(--text-2xl);
}

h5 {
  font-size: var(--text-xl);
}

h6 {
  font-size: var(--text-lg);
}

/* Basic Utiility Classes */
.text-center {
  text-align: center;
}

.items-center {
  align-items: center;
}

.justify-center {
  justify-content: center;
}

.flex {
  display: flex;
}

.flex-wrap {
  flex-wrap: wrap;
}

.flex-nowrap {
  flex-wrap: nowrap;
}

.bg--center {
  background-position: center;
}

.bg--no-repeat {
  background-repeat: no-repeat;
}

.bg--cover {
  background-size: cover;
}

.bg--top {
  background-position: top;
}

.bg--overlay {
  position: relative;

  &::before {
    content: "";
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.45);
    z-index: 1;
  }

  > * {
    position: relative;
    z-index: 2;
  }
}

.bg--primary {
  background-color: var(--primary);
}

.bg--secondary {
  background-color: var(--secondary);
}

.bg--dark {
  background-color: var(--dark-bg);
}

.mb--20 {
  margin-bottom: var(--spacing-5);
}

.line-clamp {
  display: -webkit-box;
  -webkit-line-clamp: 1;
  -webkit-box-orient: vertical;
  overflow: hidden;

  &.line-clamp--2 {
    -webkit-line-clamp: 2;
  }

  &.line-clamp--3 {
    -webkit-line-clamp: 3;
  }
}

/* Section & Container */
section {
  padding-left: var(--section-px);
  padding-right: var(--section-px);
  padding-top: var(--section-pt);
  padding-bottom: var(--section-pb);
}

header,
footer {
  padding-left: var(--section-px);
  padding-right: var(--section-px);
}

.container {
  max-width: var(--container-max-width);
  margin-left: auto;
  margin-right: auto;
  padding-inline: 0;
}

.container-fluid {
  max-width: 1800px;
  margin-inline: auto;
  padding-inline: 0;
}

.section__top {
  margin-bottom: var(--section-inner-spacing);
}

.section {
  height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  /* margin-top: -1px; */

  > * {
    width: 100%;
  }
}

@media (width < 992px) {
  .section {
    height: auto;
  }
}

/* .section {
  height: auto;
  padding-top: var(--section-pt);
  padding-bottom: var(--section-pb);
} */

.has-span-highlight {
  span {
    color: var(--accent);
  }
}

.has-text-white {
  color: #fff;

  h1,
  h2,
  h3,
  h4,
  h5,
  h6 {
    color: #fff;
  }
}

.has-heading-uppercase {
  h1,
  h2 {
    text-transform: uppercase;
  }
}

/* Buttons */
.btn {
  display: inline-block;
  padding: var(--btn-padding-y) var(--btn-padding-x);
  font-size: var(--btn-font-size);
  font-weight: var(--btn-font-weight);
  border-radius: var(--btn-border-radius);
  border: 2px solid transparent;
  text-align: center;
  text-decoration: none;
  text-transform: uppercase;
  -webkit-transition:
    background-color 0.3s ease,
    color 0.3s ease;
  transition:
    background-color 0.3s ease,
    color 0.3s ease;
  cursor: pointer;
}

.btn--primary {
  background-color: var(--primary);
  border-color: var(--primary);
  color: #fff;

  &:hover {
    background-color: var(--primary-hover);
    border-color: var(--primary-hover);
    color: #fff;
  }
}

.btn--secondary {
  background-color: var(--secondary);
  border-color: var(--secondary);
  color: #fff;

  &:hover {
    background-color: var(--secondary-hover);
    border-color: var(--secondary-hover);
    color: #fff;
  }
}

.btn--primary-outline {
  background-color: transparent;
  border-color: var(--primary);
  color: var(--primary);

  &:hover {
    background-color: var(--primary);
    color: #fff;
  }
}

.btn--secondary-outline {
  background-color: transparent;
  border-color: var(--secondary);
  color: var(--secondary);

  &:hover {
    background-color: var(--secondary);
    color: #fff;
  }
}

.btn--white {
  background-color: #fff;
  border-color: #fff;
  color: #000;

  &:hover {
    color: var(--primary);
  }
}

.btn__icon {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

.btn--sm {
  padding: var(--btn-sm-padding-y) var(--btn-sm-padding-x);
  font-size: var(--btn-sm-font-size);
}

/* Form Layout */
.form__group {
  margin-bottom: 1rem;
  position: relative;
}

.form__field {
  width: 100%;
  padding: var(--input-padding-y) var(--input-padding-x);
  border: 1px solid var(--border);
  border-radius: var(--input-border-radius);
  font-size: var(--text-base);
  background-color: var(--input-bg);
  color: var(--input-color);

  &::placeholder {
    color: var(--input-placeholder-color);
  }

  &:focus {
    outline: none;
    border-color: var(--primary);
    box-shadow: var(--shadow-sm);
  }
}

textarea.form__field {
  height: var(--textarea-height);
}

.form__helper-text {
  font-size: var(--text-sm);
  margin-bottom: 0;
}

.form-grid {
  row-gap: 1.25rem;
  --bs-gutter-x: 1.25rem;
}

/* Carousel */
.full-page-swiper {
  width: 100%;
  height: 100vh;
}

/* .full-page-swiper {
  height: auto;

  .swiper-wrapper {
    flex-direction: column;
  }
} */

.swiper-btn {
  background-color: rgba(0, 0, 0, 0.3);
  color: #fff;
  border: 0;
  border-radius: 50%;
  width: 3rem;
  height: 3rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  z-index: 20;

  &:hover {
    background-color: var(--primary);
    color: #fff;
  }
}

.swiper-btn--prev {
  position: absolute;
  top: 50%;
  left: 0.25rem;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
}

.swiper-btn--next {
  position: absolute;
  top: 50%;
  right: 0.25rem;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
}

.swiper-pagination-bullet {
  width: 0.5rem;
  height: 0.5rem;
  background: var(--accent);
}

@media (width < 992px) {
  .full-page-swiper {
    height: auto;

    > .swiper-wrapper {
      flex-direction: column;
    }
  }
}

/* Animations */
.swiper {
  .fade-up {
    opacity: 0;
    transform: translateY(40px);
    transition:
      opacity 0.6s ease,
      transform 0.6s ease;
    transition-delay: 0.25s; /* stagger each child differently */
  }

  .fade-right {
    opacity: 0;
    transform: translateX(-40px);
    transition:
      opacity 0.6s ease,
      transform 0.6s ease;
    transition-delay: 0.25s; /* stagger each child differently */
  }

  .fade-left {
    opacity: 0;
    transform: translateX(40px);
    transition:
      opacity 0.6s ease,
      transform 0.6s ease;
    transition-delay: 0.25s; /* stagger each child differently */
  }
}

.swiper-slide-active {
  .fade-up {
    opacity: 1;
    -webkit-transform: translateY(0);
    transform: translateY(0);
  }

  .fade-right {
    opacity: 1;
    -webkit-transform: translateX(0);
    transform: translateX(0);
  }

  .fade-left {
    opacity: 1;
    -webkit-transform: translateX(0);
    transform: translateX(0);
  }
}

@media (width < 992px) {
  .swiper {
    .fade-up {
      opacity: 1;
      -webkit-transform: translateY(0);
      transform: translateY(0);
    }

    .fade-right {
      opacity: 1;
      -webkit-transform: translateX(0);
      transform: translateX(0);
    }

    .fade-left {
      opacity: 1;
      -webkit-transform: translateX(0);
      transform: translateX(0);
    }
  }
}

/* Accordion */
.accordn {
  border-bottom: 1px solid #fff;

  .accordn__btn {
    background-color: transparent;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    color: #fff;
    font-size: 1.25rem;
    border: 0;
    -webkit-box-shadow: none;
    box-shadow: none;
    padding: var(--spacing-3) 0;
    width: 100%;

    .accordn__btn-icon {
      font-size: 1.25rem;
      -ms-flex-negative: 0;
      flex-shrink: 0;
      margin-left: var(--spacing-4);
    }

    &.active {
      .accordn__btn-icon {
        -webkit-transform: rotate(180deg);
        transform: rotate(180deg);
        -webkit-transition: -webkit-transform 0.3s ease;
        transition: -webkit-transform 0.3s ease;
        transition: transform 0.3s ease;
        transition:
          transform 0.3s ease,
          -webkit-transform 0.3s ease;
      }
    }
  }

  .accordn__body {
    display: none;
    font-size: var(--text-lg);
    padding-block: var(--spacing-4);
  }
}

/* Header */
.header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1040;
  padding-block: var(--spacing-3);

  .header__logo {
    max-width: 15rem;
  }

  .header__nav {
    margin-top: var(--spacing-6);
    opacity: 0;
    -webkit-transform: translateX(1rem);
    transform: translateX(1rem);

    -webkit-transition: all 0.3s ease;

    transition: all 0.3s ease;
    -webkit-transition-delay: 0.1s;
    transition-delay: 0.1s;

    ul {
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -webkit-box-orient: vertical;
      -webkit-box-direction: normal;
      -ms-flex-direction: column;
      flex-direction: column;
      row-gap: var(--spacing-4);

      li {
        a {
          color: #fff;
          display: -webkit-box;
          display: -ms-flexbox;
          display: flex;
          -webkit-box-align: center;
          -ms-flex-align: center;
          align-items: center;
          -webkit-box-pack: justify;
          -ms-flex-pack: justify;
          justify-content: space-between;

          &:hover,
          &.active {
            color: var(--accent);
          }

          .dropdown-icon {
            color: #fff;
            background-color: rgba(255, 255, 255, 0.2);
            display: inline-block;
            padding: var(--spacing-1);
            border: 0;
            border-radius: 0.125rem;
            -webkit-transition: all 0.3s linear;
            transition: all 0.3s linear;

            &.active {
              -webkit-transform: rotate(180deg);
              transform: rotate(180deg);
            }
          }
        }

        .dropdown__menu {
          padding-left: var(--spacing-4);
          padding-block: var(--spacing-3);
          border-left: 1px solid #ffffff46;
          display: none;

          li:not(:last-child) {
            margin-bottom: var(--spacing-3);
          }
        }
      }
    }
  }

  .header__nav-toggler {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-column-gap: var(--spacing-2);
    -moz-column-gap: var(--spacing-2);
    column-gap: var(--spacing-2);

    span {
      line-height: 1;
      margin-bottom: 0.375rem;
      text-transform: uppercase;
    }

    button {
      background-color: transparent;
      border: 0;
      -webkit-box-shadow: none;
      box-shadow: none;

      span {
        display: block;
        width: 1.5rem;
        height: 0.125rem;
        background-color: #fff;
        margin-bottom: 0.5rem;
        -webkit-transition: all 0.3s ease;
        transition: all 0.3s ease;
      }
    }
  }

  .offcanvas {
    background-color: var(--dark-bg);

    .btn-close {
      -webkit-filter: brightness(0) invert(1);
      filter: brightness(0) invert(1);
    }

    .offcanvas-body {
      padding: var(--spacing-5);
    }

    .offcanvas__footer {
      position: absolute;
      bottom: 0;
      color: #fff;
      padding-bottom: var(--spacing-4);
      opacity: 0;
      -webkit-transform: translateX(1rem);
      transform: translateX(1rem);
      -webkit-transition: all 0.3s ease;
      transition: all 0.3s ease;
      -webkit-transition-delay: 0.5s;
      transition-delay: 0.5s;
    }

    &.show {
      .header__nav,
      .social-icons,
      .offcanvas__footer {
        opacity: 1;
        -webkit-transform: translateX(0);
        transform: translateX(0);
      }
    }
  }

  .social-icons {
    margin-top: var(--spacing-12);
    opacity: 0;
    -webkit-transform: translateX(1rem);
    transform: translateX(1rem);

    -webkit-transition: all 0.3s ease;

    transition: all 0.3s ease;
    -webkit-transition-delay: 0.3s;
    transition-delay: 0.3s;
  }
}

/* Footer */
.footer {
  background-color: var(--dark-bg);

  .footer__top {
    .row {
      > *:nth-child(1) {
        -webkit-transition-delay: 0.3s;
        transition-delay: 0.3s;
      }
      > *:nth-child(2) {
        -webkit-transition-delay: 0.5s;
        transition-delay: 0.5s;
      }
      > *:nth-child(3) {
        -webkit-transition-delay: 0.7s;
        transition-delay: 0.7s;
      }
      > *:nth-child(4) {
        -webkit-transition-delay: 0.9s;
        transition-delay: 0.9s;
      }
    }
  }

  .footer__bottom {
    padding-top: var(--spacing-12);
  }

  .footer__col-heading {
    font-size: var(--text-2xl);
    margin-bottom: var(--spacing-4);
    color: #fff;
  }

  .footer__menu {
    ul {
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -webkit-box-orient: vertical;
      -webkit-box-direction: normal;
      -ms-flex-direction: column;
      flex-direction: column;
      gap: var(--spacing-2);

      li {
        a {
          color: #fff;
          -webkit-transition: all 0.3s ease;
          transition: all 0.3s ease;

          &:hover {
            color: var(--accent);
            padding-left: var(--spacing-1);
          }
        }
      }
    }
  }

  .footer__logo {
  }

  .footer__copyright {
    padding-top: var(--spacing-6);
    border-top: 1px solid rgba(255, 255, 255, 0.1);
    color: #fff;
  }

  &:not(.section) {
    padding-top: var(--spacing-12);
    padding-bottom: var(--spacing-6);
  }
}

.view-cart-btn {
  position: fixed;
  right: -4rem;
  top: 50%;
  -webkit-transform: translateY(-50%) rotate(-90deg);
  transform: translateY(-50%) rotate(-90deg);
  z-index: 1000;
}

/* Social Icons */
.social-icons {
  ul {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    gap: var(--spacing-2);

    li {
      a {
        color: #fff;
        font-size: 1.125rem;
        -webkit-transition: color 0.3s ease;
        transition: color 0.3s ease;
        width: 2.25rem;
        height: 2.25rem;
        display: -webkit-inline-box;
        display: -ms-inline-flexbox;
        display: inline-flex;
        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items: center;
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;
        border-radius: 0.25rem;
        background-color: rgba(255, 255, 255, 0.2);

        &:hover {
          background-color: var(--primary);
        }
      }
    }
  }
}

.list-icons {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  gap: var(--spacing-3);

  li {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-column-gap: var(--spacing-2);
    -moz-column-gap: var(--spacing-2);
    column-gap: var(--spacing-2);

    span {
      color: #fff;
    }

    a {
      color: #fff;

      &:hover {
        color: var(--accent);
      }
    }
  }
}

/* Page Header */
.page-header {
  .page-header__title {
  }

  .page-header__breadcrumb {
    li {
      a {
        color: var(--accent);
        text-decoration: none;
        -webkit-transition: color 0.3s ease;
        transition: color 0.3s ease;

        &:hover {
          color: var(--primary);
        }
      }
      &::after {
        content: ">";
        margin: 0 0.5rem;
        color: var(--text);
      }

      &:last-child::after {
        content: "";
      }
    }
  }
}

/* Home */
.hero {
  h1 {
    font-size: 5rem;
    max-width: 50rem;
    line-height: 1.05;
    margin-inline: auto;
    font-weight: 900;
    -webkit-box-shadow: 0 2px 3px rgba(0, 0, 0, 0.1);
    box-shadow: 0 2px 3px rgba(0, 0, 0, 0.1);
  }

  p {
    margin-inline: auto;
    max-width: 50rem;
    margin-block: var(--spacing-6);
  }
}

.our-cabinets {
  .section__top {
    p {
      max-width: 40rem;
      margin-inline: auto;
    }
  }
}

.serv-card {
  background-color: rgba(0, 0, 0, 0.5);
  border-radius: var(--card-border-radius);
  padding: var(--spacing-5);
  border: 1px solid rgba(255, 255, 255, 0.4);

  .serv-card__icon {
    margin-bottom: var(--spacing-4);
    background-color: #fff;
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    width: 4rem;
    height: 4rem;
    border-radius: 50%;

    img {
      width: 2.5rem;
      height: 2.5rem;
    }
  }

  .serv-card__body {
    h3 {
      font-size: var(--text-2xl);
      margin-bottom: var(--spacing-3);
    }
  }
}

.services {
  .serv-cards-grid {
    > *:nth-child(1) {
      -webkit-transition-delay: 0.3s;
      transition-delay: 0.3s;
    }

    > *:nth-child(2) {
      -webkit-transition-delay: 0.5s;
      transition-delay: 0.5s;
    }

    > *:nth-child(3) {
      -webkit-transition-delay: 0.7s;
      transition-delay: 0.7s;
    }

    > *:nth-child(4) {
      -webkit-transition-delay: 0.9s;
      transition-delay: 0.9s;
    }
  }
}

.cta-section {
  h2 {
    max-width: 40rem;
    margin-bottom: var(--spacing-6);
  }

  p {
    max-width: 30rem;
    margin-bottom: var(--spacing-8);
  }
}

.showrooms {
  .showroom-card {
    background-color: #fff;
    padding: var(--spacing-3);
    border-radius: var(--card-border-radius);
    height: 100%;
    /* display: flex;
    flex-direction: column;
    justify-content: space-between; */

    img {
      border-radius: 0.375rem;
      width: 100%;
      aspect-ratio: 352/234;
      -o-object-fit: cover;
      object-fit: cover;
    }

    .showroom-card__body {
      margin-top: var(--spacing-4);

      h3 {
        color: var(--dark);
        font-size: var(--text-2xl);
        margin-bottom: var(--spacing-3);
      }

      .list-icons {
        margin-bottom: var(--spacing-4);
        font-size: var(--text-base);

        span {
          color: var(--dark);
        }

        i {
          color: var(--primary);
        }

        a {
          color: var(--dark);
        }
      }
    }

    .btn {
      i {
        -webkit-transform: rotate(45deg);
        transform: rotate(45deg);
      }
    }
  }

  .showrooms-cards-grid {
    > *:nth-child(1) {
      -webkit-transition-delay: 0.3s;
      transition-delay: 0.3s;
    }

    > *:nth-child(2) {
      -webkit-transition-delay: 0.5s;
      transition-delay: 0.5s;
    }

    > *:nth-child(3) {
      -webkit-transition-delay: 0.7s;
      transition-delay: 0.7s;
    }
  }
}

.showcase-swiper {
  padding-bottom: var(--spacing-12);

  img {
    aspect-ratio: 3/2;
    -o-object-fit: cover;
    object-fit: cover;
    width: 100%;
    border-radius: 0.375rem;
    border: 3px solid #fff;
  }
}

.prod-card {
  background-color: #fff;
  padding: var(--spacing-3);
  border-radius: var(--card-border-radius);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  min-height: 100%;

  .prod-card__img {
    margin-bottom: var(--spacing-3);

    img {
      aspect-ratio: 300/606;
      -o-object-fit: cover;
      object-fit: cover;
      width: 100%;
      border-radius: 0.375rem;
      max-width: 12rem;
      margin-inline: auto;
    }

    img.v2-img {
      aspect-ratio: 15/16;
      max-width: unset;
    }
  }

  .prod-card__title {
    font-size: var(--text-lg);
    color: var(--dark);
    margin-bottom: var(--spacing-3);
    line-height: 1.3;
    text-align: center;

    a {
      color: var(--dark);

      &:hover {
        color: var(--primary);
      }
    }
  }

  .prod-card__cta {
    margin-top: auto;
    padding-top: var(--spacing-2);

    .btn {
      width: 100%;
    }
  }
}

.blog-card {
  background-color: #fff;
  padding: var(--spacing-3);
  border-radius: var(--card-border-radius);

  .blog-card__image {
    margin-bottom: var(--spacing-4);

    img {
      aspect-ratio: 1200/512;
      border-radius: 0.375rem;
    }
  }

  .blog-card__title {
    font-size: var(--text-2xl);
    color: var(--dark);
    margin-bottom: var(--spacing-2);
    line-height: 1.3;

    a {
      color: var(--dark);

      &:hover {
        color: var(--primary);
      }
    }
  }

  .blog-card__meta {
    font-size: var(--text-sm);
    color: var(--primary);
    margin-bottom: var(--spacing-2);
  }

  .blog-card__cta {
    padding-top: var(--spacing-3);
  }
}

.blog {
  h2 {
    max-width: 50rem;
    margin-inline: auto;
  }
}

.join-program {
  h2 {
    margin-bottom: var(--spacing-6);
  }
}

.tm-card {
  background-color: #fff;
  padding: var(--spacing-5);
  border-radius: var(--card-border-radius);
  color: var(--dark);

  img {
    max-width: 3rem;
  }

  .tm-card__footer {
    img {
      border-radius: 50%;
      width: 3rem;
      height: 3rem;
      -o-object-fit: cover;
      object-fit: cover;
      margin-right: var(--spacing-3);
    }

    h3 {
      color: var(--dark);
      font-size: var(--text-lg);
      line-height: 1;
      margin-bottom: var(--spacing-1);
    }

    p {
      font-size: var(--text-sm);
      color: var(--primary);
      margin-bottom: 0;
      line-height: 1;
    }

    .tm-card__profile-fallback {
      width: 3rem;
      height: 3rem;
      font-size: 1rem;
      color: #fff;
      -ms-flex-negative: 0;
      flex-shrink: 0;
      margin-right: var(--spacing-3);
    }
  }
}

/* About Us */

/* Contact Us */

/* Products Archive */
.prod-archive {
  padding-top: 8rem;

  .section__top {
    h1 {
      font-size: var(--text-5xl);
    }
  }

  .prod-cards-grid {
    row-gap: var(--spacing-6);
  }

  .prod-archive__main {
    padding-left: var(--spacing-8);
  }

  .prod-cat-nav {
    position: sticky;
    top: 6.5rem;

    ul {
      li {
        &:not(:last-child) {
          border-bottom: 1px solid var(--border);
        }

        a {
          background-color: #fff;
          display: block;
          color: var(--dark);
          padding: var(--spacing-3);
          font-weight: 500;

          &:hover {
            background-color: var(--primary);
            color: #fff;
          }
        }
      }
    }
  }

  .prod-archive__cat-block {
    &:not(:first-child) {
      padding-top: 4rem;
    }

    > h3 {
      font-size: var(--text-4xl);
    }
  }
}

/* Product Single */
.prod-single {
  padding-top: 7.5rem;

  .prod-single__main {
  }

  .prod-single__img {
    padding: var(--spacing-2);
    border: 1px solid #fff;
    width: 100%;
  }

  .prod-single__title {
    font-size: var(--text-5xl);
    color: #fff;
  }

  .prod-single__sku {
    color: #fff;
    font-size: var(--text-lg);
  }

  .prod-single__cta {
    display: flex;
    column-gap: var(--spacing-2);
  }

  .prod-single__qty {
    width: 5rem;
    padding-inline: var(--spacing-4);
  }

  .prod-single__content {
    background-color: #fff;
    padding: var(--spacing-5);
    margin-top: var(--spacing-8);
    border-radius: var(--card-border-radius);

    > * {
      margin-bottom: var(--spacing-5);
    }

    h2 {
      font-size: var(--text-3xl);
    }

    h3 {
      font-size: var(--text-2xl);
    }
  }

  .prod-single__addi-blocks {
    background-color: #fff;
    padding: var(--spacing-6);
    border-radius: var(--card-border-radius);
    margin-top: 4rem;

    .prod-single__addi-block {
      margin-bottom: var(--spacing-10);

      h3 {
        margin-bottom: var(--spacing-6);
      }

      table {
        th {
          &:first-child {
            width: 12%;
          }

          &:last-child {
            width: 10%;
          }
        }

        td {
          &:last-child {
            text-align: center;
          }
        }
      }
    }
  }
}

table {
  border: 1px solid var(--border);
  width: 100%;
  color: var(--dark);

  th,
  td {
    border: 1px solid var(--border);
    padding: var(--spacing-3);
  }

  th {
    width: 25%;
  }
}

/* Blog Archive */
.blog-archive {
  .blog-archive__main {
  }

  .blog-archive__sidebar {
  }
  .blog-archive__pagination {
  }
}

/* Model Block */
.model-wrapper {
  height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;

  .model-block {
    max-width: 1200px;
    margin-inline: auto;
  }

  .model-block__cta {
    position: absolute;
    left: 0;
    right: 0;
    bottom: var(--spacing-5);
    width: 100%;
    display: flex;
    justify-content: center;

    ul {
      display: flex;
      column-gap: var(--spacing-1);
    }

    .btn {
      border-radius: 0;
    }
  }

  .model-block__default-img {
    img {
      max-width: 1000px;
    }
  }

  .model-block__inputs {
    position: absolute;
    left: var(--spacing-2);
    right: var(--spacing-2);
    bottom: 6rem;
    background-color: rgba(0, 0, 0, 0.5);
    padding: var(--spacing-5) var(--spacing-3);
    opacity: 0;
    visibility: hidden;
    transform: translateY(20px);
    z-index: 10;
    transition: all 0.3s ease-in-out;

    &.active {
      opacity: 1;
      visibility: visible;
      transform: translateY(0);
    }

    h2 {
      color: #fff;
      font-size: var(--text-2xl);
      margin-bottom: var(--spacing-5);
    }

    .model-block__btn-close {
      position: absolute;
      right: var(--spacing-2);
      top: var(--spacing-2);
      background-color: transparent;
      border: 0;
    }

    .model-block__input-list {
      display: grid;
      grid-template-columns: repeat(6, minmax(0, 1fr));
      gap: var(--spacing-2);
      max-height: 25rem;
      overflow-y: auto;
      padding: var(--spacing-1);

      button {
        background-color: transparent;
        border: 0;

        img {
          border: 3px solid #fff;
        }

        div {
          background-color: var(--dark-bg);
          color: #fff;
          font-size: var(--text-sm);
          padding: var(--spacing-1);
        }

        &:hover,
        &.active {
          outline: 4px solid var(--secondary);
        }
      }
    }
  }

  .model-block__img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
  }

  .model-wrapper__btn--back-to-home {
    position: absolute;
    top: var(--spacing-3);
    left: var(--spacing-3);
    color: #fff;
    background-color: rgba(255, 255, 255, 0.2);
    font-size: var(--text-sm);
    padding: var(--spacing-3);
    line-height: 1;
    border-radius: var(--btn-border-radius);

    &:hover {
      background-color: var(--primary);
    }
  }

  .model-block__loader {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    background-color: rgba(0, 0, 0, 0.4);
    backdrop-filter: blur(5px);
    display: none;
    align-items: center;
    justify-content: center;

    &.active {
      display: flex;
    }
  }
}

/* Custom Tab */
.tab-block {
  .tab-block__btns {
    display: flex;
    column-gap: var(--spacing-1);
    margin-bottom: var(--spacing-4);
    overflow-x: auto;

    .tab-block__btn {
      color: var(--dark);
      font-size: var(--text-sm);
      text-transform: uppercase;
      padding: var(--spacing-2) var(--spacing-3);
      border: 1px solid #fff;
      background-color: #fff;
      white-space: nowrap;
      -webkit-transition: all 0.3s ease-in-out;
      transition: all 0.3s ease-in-out;

      &:hover {
        background-color: #fff;
        color: var(--accent);
      }

      &.active {
        background-color: var(--accent);
        border-color: var(--accent);
        color: #fff;

        &:hover {
          color: #fff;
        }
      }
    }
  }

  .tab-block__content {
    display: none;

    &.active {
      display: block;
    }

    .tab-block__content-title {
      color: #fff;
      display: none;
    }
  }
}

/* Responsve Styles */
@media (width < 1600px) {
  h2 {
    font-size: var(--text-5xl);
  }
}

@media (width < 1400px) {
  body {
    font-size: var(--text-base);
  }

  .prod-single {
    & .prod-single__title {
      font-size: var(--text-4xl);
      color: #fff;
    }
  }

  .btn {
    font-size: var(--text-base);
  }
}

@media (width < 1200px) {
  .footer {
    padding-top: var(--spacing-12);
    padding-bottom: var(--spacing-6);

    .footer__logo {
      img {
        max-width: 13rem;
      }
    }

    .footer__col-heading {
      font-size: var(--text-xl);
    }
  }

  .prod-archive {
    .prod-cards-grid {
      justify-content: center;
    }
  }
}

@media (width < 992px) {
  h2 {
    font-size: var(--text-4xl);
  }

  .hero {
    padding-top: 12rem;

    & h1 {
      font-size: 4rem;
    }
  }

  .serv-card {
    & .serv-card__body {
      & h3 {
        font-size: var(--text-xl);
        margin-bottom: var(--spacing-2);
      }
    }
  }

  .cta-section {
    h2 {
      margin-inline: auto;
    }

    p {
      max-width: 30rem;
      margin-bottom: var(--spacing-8);
      margin-inline: auto;
    }
  }

  .blog-card {
    & .blog-card__title {
      font-size: var(--text-xl);
    }
  }

  .footer {
    .footer__top {
      .row {
        row-gap: var(--spacing-8);
      }
    }
  }

  .prod-archive {
    .section__top {
      h1 {
        font-size: var(--text-4xl);
      }
    }

    .prod-cards-grid {
      --bs-gutter-x: var(--spacing-5);
      justify-content: center;
    }
  }

  .prod-single {
    .prod-single__title {
      font-size: var(--text-3xl);
    }

    & .prod-single__content {
      & h2 {
        font-size: var(--text-2xl);
      }

      & h3 {
        font-size: var(--text-xl);
      }
    }

    .prod-single__addi-block {
      h3 {
        font-size: var(--text-2xl);
      }
    }
  }

  .prod-archive {
    .prod-archive__main {
      padding-left: 0;
      margin-top: var(--spacing-10);
    }

    & .prod-archive__cat-block {
      & > h3 {
        font-size: var(--text-3xl);
        text-align: center;
      }
    }
  }

  .model-wrapper {
    & .model-block {
      max-width: 720px;
      margin-inline: auto;
    }

    & .model-block__default-img {
      & img {
        max-width: 720px;
      }
    }

    & .model-block__cta {
      & .btn {
        border-radius: 0;
        font-size: 0.9375rem;
      }
    }

    & .model-block__inputs {
      & .model-block__input-list {
        display: grid;
        grid-template-columns: repeat(5, minmax(0, 1fr));
        gap: var(--spacing-2);
        max-height: 25rem;
        overflow-y: auto;
        padding: var(--spacing-1);
      }

      & h2 {
        font-size: var(--text-xl);
      }
    }
  }

  .tab-block {
    & .tab-block__btns {
      & .tab-block__btn {
        padding: var(--spacing-1) var(--spacing-2);
      }
    }
  }
}

@media (width < 768px) {
  h1 {
    font-size: var(--text-4xl);
  }

  .hero {
    & h1 {
      font-size: 3rem;
      margin-bottom: 0;
    }

    & p {
      margin-block: var(--spacing-4);
    }
  }

  .prod-single {
    .prod-single__title {
      font-size: var(--text-2xl);
    }

    .prod-single__sku {
      color: #fff;
      font-size: var(--text-base);
    }

    .prod-single__content {
      h2 {
        font-size: var(--text-xl);
      }

      h3 {
        font-size: var(--text-lg);
      }
    }

    .prod-single__addi-blocks {
      .prod-single__addi-block {
        h3 {
          margin-bottom: var(--spacing-6);
          text-align: center;
        }

        .prod-single__addi-img {
          display: block;
          margin-inline: auto;
          margin-bottom: var(--spacing-5);
        }
      }
    }
  }

  .model-wrapper {
    & .model-block {
      max-width: 100%;
      padding-inline: var(--spacing-2);
      height: 100%;
      padding-top: 7rem;
    }

    & .model-block__default-img {
      & img {
        max-width: 100%;
      }
    }

    & .model-block__img {
      top: 7rem;
      left: 0.5rem;
      width: calc(100% - 1rem);
      height: auto;
      right: 0.5rem;
    }

    & .model-block__cta {
      & .btn {
        border-radius: 0;
        font-size: var(--text-sm);
        padding: var(--spacing-2) var(--spacing-3);
      }
    }

    & .model-block__inputs {
      border: 1px solid rgba(255, 255, 255, 0.2);

      & .model-block__input-list {
        grid-template-columns: repeat(4, minmax(0, 1fr));
        max-height: 20rem;

        & button {
          & div {
            background-color: #171717;

            font-size: var(--text-xs);
          }
        }
      }
    }
  }

  .tab-block {
    & .tab-block__btns {
      & .tab-block__btn {
        font-size: var(--text-xs);
      }
    }
  }
}

@media (width < 576px) {
  h2 {
    font-size: var(--text-3xl);
  }

  .hero {
    min-height: 80vh;

    h1 {
      font-size: 2rem;
      line-height: 1.25;
    }

    .hero__cta {
      padding-top: var(--spacing-2);
    }
  }

  .serv-card {
    text-align: center;
  }

  .showrooms {
    & .showroom-card {
      & .showroom-card__body {
        & h3 {
          font-size: var(--text-xl);
        }
      }
    }

    .showrooms-cards-grid {
      row-gap: var(--spacing-6);
    }
  }

  .join-program {
    & h2 {
      font-size: var(--text-2xl);
      line-height: 1.4;
    }
  }

  .accordn {
    & .accordn__btn {
      font-size: 1.0625rem;

      span:first-child {
        text-align: left;
      }
    }
  }

  .footer {
    .footer__top {
      .row {
        row-gap: var(--spacing-6);
      }
    }
  }

  .prod-archive {
    padding-top: 6rem;

    .prod-cards-grid {
      --bs-gutter-x: var(--spacing-2);
      row-gap: var(--spacing-2);
    }

    .section__top {
      h1 {
        font-size: var(--text-3xl);
      }
    }

    & .prod-archive__cat-block {
      & > h3 {
        font-size: var(--text-2xl);
        text-align: center;
      }

      &:not(:first-child) {
        padding-top: 3rem;
      }
    }
  }

  .prod-card {
    .prod-card__title {
      font-size: var(--text-sm);
      margin-bottom: var(--spacing-1);
    }

    .prod-card__cta {
      .btn {
        font-size: 0.75rem;
        padding-inline: var(--spacing-2);
      }
    }
  }

  .prod-single {
    padding-top: 6.5rem;

    .prod-single__addi-blocks {
      padding: var(--spacing-5) var(--spacing-2);
      .prod-single__addi-block {
        h3 {
          font-size: var(--text-xl);
        }

        table {
          font-size: var(--text-sm);

          .btn {
            font-size: var(--text-xs);
            padding-inline: var(--spacing-3);
          }

          th {
            &:first-child {
              width: 15%;
            }
          }
        }
      }
    }
  }

  .model-wrapper {
    & .model-block__inputs {
      & .model-block__input-list {
        max-height: 15rem;
      }
    }

    & .model-block__cta {
      bottom: 4rem;
    }
  }
}
