/* Added fallbacks to help with CLS, feel free to remove if it doesn't help on your project */
/* Colours */
/* Fluid heading sizes - set your min/max sizes and you're done! */
/* Some device sizes to use with min-width */
/* adjusted breakpoints for above */
/* 100% widths look better than "Snapping" IMO */
/* Utility */
/* Additional Spacers -- don't think you'll need more than 7, but if you do -- maybe just use a custom class  :)  */
/* Added fallbacks to help with CLS, feel free to remove if it doesn't help on your project */
/* Colours */
/* Fluid heading sizes - set your min/max sizes and you're done! */
/* Some device sizes to use with min-width */
/* adjusted breakpoints for above */
/* 100% widths look better than "Snapping" IMO */
/* Utility */
/* Additional Spacers -- don't think you'll need more than 7, but if you do -- maybe just use a custom class  :)  */
#hero {
  position: relative;
  min-height: 504px;
  display: flex;
  align-items: center;
}
#hero h1 {
  margin-bottom: 24px;
}
#hero h1, #hero h2, #hero h3, #hero h4, #hero h5, #hero h6, #hero p {
  color: #FFFFFF;
}
#hero h1, #hero h2, #hero h3, #hero h4, #hero h5, #hero h6 {
  font-weight: 600;
}
#hero .hero-desktop {
  max-width: 100% !important;
  width: 100% !important;
  height: 100% !important;
}
#hero .hero-desktop img {
  min-height: 705px;
  height: 100% !important;
  object-fit: cover;
}
#hero .hero-mobile {
  max-width: 100% !important;
  width: 100% !important;
  height: 100% !important;
}
#hero .hero-mobile img {
  min-height: 504px;
  height: 100% !important;
  object-fit: cover;
}
#hero .container-content {
  position: relative;
  padding-top: 40px;
}
#hero .main-paragraph {
  font-weight: 600;
  max-width: 1064px;
  font-size: clamp(1.125rem, 18px + (24 - 18) * (100vw - 320px) / 1600, 1.5rem) !important;
  line-height: clamp(2rem, 32px + (40 - 32) * (100vw - 320px) / 1600, 2.5rem) !important;
}
@media screen and (min-width: 1025px) {
  #hero {
    display: block;
  }
  #hero,
  #hero .hero-desktop {
    min-height: 705px;
  }
  #hero .hero-mobile {
    min-height: 504px;
  }
  #hero .container-content {
    padding-top: 380px;
  }
}

/*Breadcrumb*/
#breadcrumb {
  background: #FFC60A;
}
#breadcrumb a {
  color: #2F2F2F !important;
}
#breadcrumb .icon-home {
  color: #1A1A1A;
}
#breadcrumb .separator {
  padding-left: 5px;
  padding-right: 5px;
}
#breadcrumb p {
  font: normal normal 600 16px/40px "Roobert", "sans-serif";
}
@media screen and (min-width: 1025px) {
  #breadcrumb {
    height: 56px;
    display: flex;
    align-items: center;
  }
}

body {
  background: #F8F8F8;
}

.woocommerce-notices-wrapper {
  display: none;
}

.woocommerce nav.woocommerce-pagination ul li {
  border-right: 0;
}

#hero h1 {
  margin-bottom: 30px;
}

/*Shop*/
#shop #start-time,
#shop #end-time {
  border: 0;
  width: 100%;
}
#shop .container-categories {
  gap: 26px;
  flex-basis: 100%;
  flex-wrap: wrap;
}
#shop label,
#shop h1 {
  font-weight: 600;
}
#shop label {
  display: block;
  margin-bottom: 6px;
}
#shop .container-input {
  height: 56px;
  border: 1px solid #1A1A1A;
  border-radius: 2px;
}
#shop .container-input input {
  border: 0;
}
#shop .container-icon {
  width: 50px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-left: 1px solid #1A1A1A;
  background: #FFFFFF;
}
#shop .container-icons-date-time {
  gap: 25px;
}
#shop .h2-alt {
  margin-bottom: 25px;
}
#shop .container-inner-icon {
  flex-basis: 100%;
}
#shop .container-inner-icon input {
  width: 100%;
}
#shop .link-search {
  height: 56px;
  max-width: 219px;
  width: 100%;
}
#shop .note-disclaimer {
  font: normal normal normal 18px/40px "Roobert", "sans-serif";
}
#shop h2.title-available {
  font-size: clamp(2.25rem, 36px + (40 - 36) * (100vw - 320px) / 1600, 2.5rem) !important;
  line-height: clamp(2.1875rem, 35px + (49 - 35) * (100vw - 320px) / 1600, 3.0625rem) !important;
  font-weight: 600;
}
#shop .category-item .common-button {
  height: 60px;
}
#shop .common-button:hover, #shop .common-button.active {
  background: #FFC60A;
  border: 2px solid #FFC60A;
}
@media screen and (min-width: 1025px) {
  #shop .container-categories {
    flex-basis: unset;
  }
}

/*Products*/
#products {
  /* Added fallbacks to help with CLS, feel free to remove if it doesn't help on your project */
  /* Colours */
  /* Fluid heading sizes - set your min/max sizes and you're done! */
  /* Some device sizes to use with min-width */
  /* adjusted breakpoints for above */
  /* 100% widths look better than "Snapping" IMO */
  /* Utility */
  /* Additional Spacers -- don't think you'll need more than 7, but if you do -- maybe just use a custom class  :)  */
}
#products .price {
  margin-top: 20px;
}
#products .short-description {
  font-size: clamp(1rem, 16px + (18 - 16) * (100vw - 320px) / 1600, 1.125rem) !important;
  line-height: clamp(1.625rem, 26px + (34 - 26) * (100vw - 320px) / 1600, 2.125rem) !important;
  margin-top: 8px;
}
#products .product-item {
  display: grid;
  grid-template-rows: auto 1fr auto auto;
  height: 100%;
}
#products .product-item img {
  border-radius: 16px 16px 0 0 !important;
}
#products .product-item picture img {
  border-radius: 16px 16px 0 0 !important;
  height: 286px !important;
  object-fit: cover;
}
#products .card-content {
  background: #FFFFFF;
  padding: 25px;
  display: flex;
  flex-direction: column;
}
#products .card-content p.h4 {
  margin-bottom: 0;
  font-weight: 600;
}
#products .card-content ul {
  font-size: clamp(1rem, 16px + (18 - 16) * (100vw - 320px) / 1600, 1.125rem) !important;
  line-height: clamp(1.625rem, 26px + (34 - 26) * (100vw - 320px) / 1600, 2.125rem) !important;
  list-style: none;
  padding-left: 0;
  padding-top: 14px;
  padding-bottom: 14px;
  margin-bottom: 0;
}
#products .card-content ul li {
  position: relative;
  padding-left: 28px;
}
#products .card-content ul li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 5px;
  width: 10px;
  height: 10px;
  background-color: #1A1A1A;
  border-radius: 50%;
}
@media screen and (min-width: 1025px) {
  #products .card-content ul li::before {
    top: 14px;
  }
}
#products .link-book-now {
  border-top: 1px solid #C1C1C1;
  background: #FFFFFF;
  width: 100%;
  display: flex;
  padding: 20px 25px;
  color: #1A1A1A !important;
  border-radius: 0px 0px 16px 16px;
}
#products .link-book-now:hover {
  background: #FFC60A;
}
#products .line-divider {
  background: #1A1A1A 0% 0% no-repeat padding-box;
  border-radius: 20px;
  width: 100%;
  height: 20px;
  opacity: 0.1;
}
#products .container-image .available {
  background: #FFC60A;
}
#products .container-image .reserved {
  background: #F47174;
}
#products .container-image p {
  width: fit-content;
  padding-left: 18px;
  padding-right: 18px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 10px;
  color: #FFFFFF;
  font: normal normal 600 18px/40px "Roobert", "sans-serif" !important;
  top: 18px;
  left: 18px;
}
@media screen and (min-width: 1025px) {
  #products .container-image .container-image p {
    top: 37px;
    left: 37px;
  }
}
#products .page-numbers {
  display: flex;
  list-style: none;
  flex-wrap: wrap;
  justify-content: center;
  gap: 12px;
  padding: 0;
  border: 0;
  margin-top: 2em;
  margin-bottom: 2em;
}
#products .page-numbers.current {
  background: #FFC60A;
}
#products .page-numbers span,
#products .page-numbers a {
  width: 60px;
  height: 60px;
  display: flex;
  justify-content: center;
  align-items: center;
  border: 2px solid #1A1A1A;
  border-radius: 5px;
  color: #1A1A1A;
  font-weight: 600;
}
#products .page-numbers span:hover,
#products .page-numbers a:hover {
  background: #FFC60A;
}
#products #products-loading {
  min-height: 600px;
}
#products .product-item:not(.unavailable):hover {
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
  border-radius: 16px;
  cursor: pointer;
}
#products .product-item:not(.unavailable):hover a {
  background: #FFC60A;
}
@media screen and (min-width: 1025px) {
  #products {
    padding-bottom: 8em;
  }
}

/*Get*/
#get {
  background: #FFC60A;
  padding-top: 4em;
  padding-bottom: 4em;
}
#get h1, #get h2, #get h3, #get h4, #get h5, #get h6 {
  font-weight: 600;
}
#get .common-button {
  width: fit-content;
}
#get .common-button:hover {
  background: #2F2F2F;
  color: #FFFFFF;
}
#get .main-paragraph {
  max-width: 945px;
}
#get .container-buttons {
  gap: 20px;
}
@media screen and (min-width: 1025px) {
  #get {
    padding-top: 5em;
    padding-bottom: 5em;
  }
  #get .main-paragraph {
    font-weight: 600;
  }
  #get .common-button {
    width: 100%;
  }
}

#products-container .product-item img {
  height: 286px !important;
  object-fit: cover;
}