@import url('https://fonts.googleapis.com/css2?family=Inter:ital,opsz,wght@0,14..32,100..900;1,14..32,100..900&family=Oswald:wght@200..700&display=swap');

:root {
  --bs-body-font-size: 16px;
  --bs-body-font-weight: 400;
  /*--bs-body-line-height: 1.625;*/

  /*font-family*/
  --bs-body-font-family: "Inter", sans-serif;
  --in-heading-font-family: "Oswald", sans-serif;

  --in-border-radius: 1rem;
  --in-box-shadow: 0 4px 20px -4px hsla(30 20% 20% / .03);
  --in-border-radius-sm: 0.5rem;
  --in-border: 1px solid rgba(var(--bs-body-color-rgb), 0.1);

  --in-body-color: color-mix(in hsl, var(--bs-body-color), var(--bs-body-bg) 30%);
}

/* ----- Section-bg overlay gradient ----- */
/*===========================================================================*/
.container--article .section-title.section-bg>* {
  max-width: unset;
}

.section-container.section-title.section-bg, .custom-motive .section-container.section-bg {
  position: relative;
}

.section-container.section-title.section-bg::before, .custom-motive .section-container.section-bg::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to bottom,
    rgba(0,0,0,.6),
    rgba(0,0,0,.6)
  );
  z-index: 0;
}

.custom-motive .section-container.section-bg::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to right,
    rgba(0,0,0,.8),
    rgba(0,0,0,.4)
  );
  z-index: 0;
}

.section-container.section-title.section-bg .row, .custom-motive .section-container.section-bg .row {
  position: relative;
  z-index: 1;
}

.section-container.section-title.section-bg h1,
.section-container.section-title.section-bg p {
  text-shadow: 0 2px 10px rgba(0,0,0,.65);
}

body {
  color: var(--in-body-color);
}

b, strong {
  font-weight: 600;
  color: var(--bs-body-color);
}

hr {
  opacity: .1;
}

#main {
  padding-bottom: 0;
  padding-top: 0;
  /*background-color: rgba(var(--bs-body-color-rgb), 0.01);*/
  background-color: color-mix(in hsl, var(--bs-body-bg), var(--bs-body-color) 2%);
}

.main>.container:first-child, .main>.motive__motto:first-child, .container--article, #main {
  padding-bottom: 0;
}

/* ----- TYPOGRAPHY ----- */
/*===========================================================================*/
h6, .h6, h5, .h5, h4, .cart-form__title, .account-form__title, .h4, h3, .h3, h2, .h2, h1, .h1, .motto__title {
  color: var(--bs-body-color);
  font-family: var(--in-heading-font-family);
  font-weight: 500;
  margin-bottom: 0.7em;
  text-transform: uppercase;
  text-wrap: balance;
}

h1,.h1 {
  font-size: 3rem;
}

@media(min-width: 1200px) {
  h1,.h1 {
    font-size: 4rem;
  }
}

h2,.h2 {
  font-size: 2rem;
}

@media(min-width: 1200px) {
  h2,.h2 {
    font-size: 3rem;
  }
}

h3,.h3 {
  font-size: 1.5rem;
}

@media(min-width: 1200px) {
  h3,.h3 {
    font-size: 2rem;
  }
}

h4,.cart-form__title,.account-form__title,.h4 {
  font-size: 1rem;
}

@media(min-width: 1200px) {
  h4,.cart-form__title,.account-form__title,.h4 {
    font-size: 1.25rem;
  }
}

.section--header h1,.section--header .h1,.section-title h1,.section-title .h1 {
  font-size: 3rem;
}

@media(min-width: 1200px) {
  .section--header h1,.section--header .h1,.section-title h1,.section-title .h1 {
    font-size: 4rem;
  }
}

.container--article p+h2, .container--article p+.h2 {
  margin-top: 1rem;
}

.container--article h1+p, .container--article .h1+p {
  margin-top: clamp(1rem, 4vw, 2.5rem);
}

.section-3-col-bottom-text h3, .section-3-col-bottom-text .h3, .section-3-col-top-text h3, .section-3-col-top-text .h3 {
  font-size: 1.5rem;
  font-weight: 500;
}

/* ----- HEADER ----- */
/*===========================================================================*/
.header {
  -webkit-box-shadow: var(--in-box-shadow);
  box-shadow: var(--in-box-shadow);
  border-bottom: var(--in-border);
}

.navbar {
  max-width: 1800px;
  margin: auto;
  row-gap: 1rem;
}

.navbar__menu-list {
  /*align-items: center;*/
  column-gap: 0.5rem;
}

.navbar__menu-link {
  font-size: 16px;
  font-weight: 500;
  text-transform: uppercase;
}

/* contactus */
.contactus-wrap {
  background-color: rgba(var(--bs-primary-rgb), 1);
}

.contactus__phone, .contactus__email, .contactus__phone-link, .contactus__phone-link:hover, .contactus__email-link, .contactus__email-link:hover {
  color: white;
}

@media (max-width: 991.98px) {
  .contactus::after {
    background-color: transparent;
  }
}

.navbar__brand-logo-img {
  max-width: unset;
  max-height: 2.5rem;
}

@media (min-width: 1200px) {
  .navbar__brand-logo-img {
    max-height: 3rem;
  }
}

/* ----- MOTIVE ----- */
/*===========================================================================*/
body:not(#index) .motive,
body:not(#index) .motive.fullscreen {
  display: none;
}

@media (min-width: 576px) {
  .motive {
    height: 60rem;
  }
}

@media (min-width: 576px) {
  .custom-motive, body:not(#index) .custom-motive {
    height: auto;
  }
}

.motive__overlay {
  opacity: 0.6;
}

.motto {
  max-width: 50em;
}

.motive__motto {
  justify-content: flex-start;
  text-align: left;
}

.motto__title, .motto__text {
  text-shadow: 1px 1px 3px rgba(0,0,0,.6), 3px 3px 10px rgba(0,0,0,.2);
}

.motto__title {
  font-weight: 800;
  font-size: 3rem;
  line-height: 1.4;
  letter-spacing: 0.05em;
  margin-bottom: .5em;
  text-wrap: balance;
}

@media (min-width: 768px) {
  .motto__title {
    font-size: 4.5rem;
  }
}

.motto__text {
  font-size: 18px;
  line-height: 1.6;
  text-wrap: balance;
}

@media (min-width: 768px) {
  .motto__text {
    font-size: 24px;
  }
}

.motto__button-link {
  margin-top: 2.5rem;
  font-size: 18px;
  padding: 12px 28px;
  border-radius: var(--in-border-radius-sm);
  font-weight: 500;
  text-transform: uppercase;
  font-family: "Oswald", sans-serif;
  letter-spacing: 0.05em;
}

/* ----- BUTTONS ----- */
/*===========================================================================*/
.btn {
  font-size: 16px;
  padding: 10px 28px;
  border-radius: var(--in-border-radius-sm);
  font-weight: 500;
  text-transform: uppercase;
  font-family: "Oswald", sans-serif;
  letter-spacing: 0.05em;
}

.btn-secondary, .btn-default {
  background-color: transparent;
  color: white;
  border-color: white;
}

.reservanto-button, .reservanto-managebooking-button {
  font-size: 20px !important;
  border-radius: var(--in-border-radius-sm) !important;
  padding: 8px 24px !important;
  font-weight: 600 !important;
  letter-spacing: 0.025em !important;
  font-family: "Oswald", sans-serif;
}

.reservanto-widget {
  height: 55px !important;
}

/* ----- SECTIONS ----- */
/*===========================================================================*/
section, .section {
  padding-top: clamp(3rem, 6vw, 6rem);
  padding-bottom: clamp(3rem, 6vw, 6rem);
}

@media (max-width: 575.98px) { 
  .section-2-col-right-text>.row, .section-2-col-left-text>.row {
    flex-direction: column-reverse;
    --bs-gutter-y: 2rem;
  } 
}

@media (min-width: 576px) {
  .section-2-col-right-text>.row, .section-2-col-left-text>.row {
    --bs-gutter-x: 4.5rem;
  }
}

.section-3-col-bottom-text, .section-3-col-top-text {
  align-items: stretch;
}

.section-2-col-left-text .section-content>img, .section-2-col-right-text .section-content>img {
  border-radius: var(--in-border-radius);
}

.section-3-col-bottom-text .section-cell-parent, .section-3-col-top-text .section-cell-parent {
  justify-content: center;
}

.section-3-col-bottom-text.cell-borders .section-cell-item, .section-3-col-top-text.cell-borders .section-cell-item {
  border: var(--in-border);
  border-radius: var(--in-border-radius);
  -webkit-box-shadow:  var(--in-box-shadow);
  box-shadow: var(--in-box-shadow);
  padding: 2rem;
  text-align: left;
}

@media (min-width: 992px) {
  .section-3-col-bottom-text h3, .section-3-col-bottom-text .h3, .section-3-col-bottom-text p, .section-3-col-top-text h3, .section-3-col-top-text .h3, .section-3-col-top-text p {
    max-width: unset;
  }
}

.section-3-col-bottom-text img {
  border-radius: var(--in-border-radius);
  margin-bottom: 1.5rem;
}

.section-3-col-top-text img {
  border-radius: var(--in-border-radius);
}

.section-3-col-bottom-text.cell-img-borders .section-cell-img {
  width: 100px;
  height: 75px;
  /*border: 8px solid var(--bs-body-bg);*/
  border: unset;
  margin-top: -70px;
  border-radius: var(--in-border-radius);
  outline: var(--in-border);
}

.section-3-col-bottom-text.cell-img-borders .section-cell-item {
  border: var(--in-border);
  border-radius: var(--in-border-radius);
  -webkit-box-shadow:  var(--in-box-shadow);
  box-shadow: var(--in-box-shadow);
  padding: 2rem;
}

.section-3-col-bottom-text.cell-borders .section-cell-item:hover {
  -webkit-transform: translateY(-8px);
  transform: translateY(-8px);
  -webkit-box-shadow: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -4px rgba(0, 0, 0, .1);
  box-shadow: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -4px rgba(0, 0, 0, .1);
}

.section-services li, .section--services li {
  background-color: var(--bs-body-bg);
  outline: var(--in-border);
  border-radius: var(--in-border-radius-sm);
  -webkit-box-shadow: var(--in-box-shadow);
  box-shadow: var(--in-box-shadow);
  border-left: 3px solid var(--bs-primary);
}

.section-contact .section-content {
  padding: 1.5rem;
  background-color: var(--bs-body-bg);
  border: var(--in-border);
  border-radius: var(--in-border-radius);
  -webkit-box-shadow: var(--in-box-shadow);
  box-shadow: var(--in-box-shadow);
  text-align: center;
}

.section-contact .social-icons {
  justify-content: center;
}

/*carousel*/
.carousel {
  border-radius: var(--in-border-radius);
  overflow: hidden;
}

/* ----- CATEGORIES ----- */
/*===========================================================================*/
.categories--root .category__thumbnail {
  border-radius: var(--in-border-radius);
  overflow: hidden;
}

.categories--root .category {
  background-color: var(--bs-body-bg);
  border: var(--in-border);
  border-radius: var(--in-border-radius);
  -webkit-box-shadow: var(--in-box-shadow);
  box-shadow: var(--in-box-shadow);
}

/* ----- FORM ----- */
/*===========================================================================*/
.form-control, .add-comment__input, .cart-form__input, .promo-code__input, .account-form__input, .search-form__input, .user-form__input, .locked__input, .navbar__search-input {
  background-color: rgba(var(--bs-primary-rgb), 0.03);
  border: var(--in-border);
  border-radius: var(--in-border-radius-sm);
}

.user-form {
  border-radius: var(--in-border-radius);
  box-shadow: var(--in-box-shadow);
  border: var(--in-border);
  background-color: var(--bs-body-bg);
}

.user-form__label {
  color: var(--bs-body-color);
}

/* ----- GALLERY ----- */
/*===========================================================================*/
.gallery__item-img {
  border-radius: var(--in-border-radius);
}

.gallery-detail #main {
  padding-bottom: 5rem;
}

/* ----- TABLE ----- */
/*===========================================================================*/
.table-responsive {
  box-shadow: var(--in-box-shadow);
  padding: 2rem;
  border-radius: var(--in-border-radius);
  border: var(--in-border);
  background-color: var(--bs-body-bg);
  margin-bottom: 1rem;
}

@media (min-width: 768px) {
  .table>:not(:first-child) {
    border-color: #e9ecef;
  }
}

.table>:not(:first-child) {
  border-top: 1px solid currentColor;
}

@media (min-width: 768px) {
  .table td {
    border-color: transparent;
  }
}

/* ----- CUSTOM ----- */
/*===========================================================================*/
.item-box {
  outline: var(--in-border);
  border-radius: var(--in-border-radius);
  -webkit-box-shadow:  var(--in-box-shadow);
  box-shadow: var(--in-box-shadow);
  background-color: rgba(var(--bs-body-bg-rgb), 1);
}

#map iframe {
  outline: var(--in-border);
  border-radius: var(--in-border-radius);
  -webkit-box-shadow:  var(--in-box-shadow);
  box-shadow: var(--in-box-shadow);
}

/* ----- FOOTER ----- */
/*===========================================================================*/
.footer p {
  margin: 0;
}

.footer .h6 {
  color: var(--bs-light);
  font-weight: 600;
}

.footer .logo-img {
  max-width: 200px;
  height: auto;
  margin-bottom: 2rem;
}

.footer .logo-text {
  margin-top: 2rem;
  max-width: 300px;
}

.footer, .footer a {
  color: rgba(var(--bs-light-rgb), 0.6);
  font-size: 15px;
}

.footer a:hover {
  color: var(--bs-light);
  text-decoration: underline;
  -webkit-text-decoration-color: var(--bs-primary);
  text-decoration-color: var(--bs-primary);
  text-underline-offset: 3px;
}

.footer .social-icons > li > a > img {
  -webkit-filter: saturate(0%) brightness(0%) invert(100%) opacity(0.6);
  filter: saturate(0%) brightness(0%) invert(100%) opacity(0.6);
  -webkit-transition: all 100ms ease-in;
  -o-transition: all 100ms ease-in;
  transition: all 100ms ease-in;
}

.footer .social-icons > li > a:hover > img {
  -webkit-filter: saturate(0%) brightness(0%) invert(100%) opacity(1);
  filter: saturate(0%) brightness(0%) invert(100%) opacity(1);
}

/*accordion*/
.accordion-button {
  color: var(--bs-body-color);
  background-color: var(--bs-body-bg);
  font-weight: 400;
  font-size: 1.3rem;
  padding: 1.5rem;
}

.accordion-button:not(.collapsed) {
  background-color: transparent;
  border-bottom: var(--in-border);
}


.accordion-item {
  border-top: var(--in-border-radius);
  border-left: var(--in-border-radius);
  border-right: var(--in-border-radius);
  border: var(--in-border);
}

.accordion-item:first-of-type {
  border-top-left-radius: var(--in-border-radius);
  border-top-right-radius: var(--in-border-radius);
}

.accordion-item:first-of-type .accordion-button {
  border-top-left-radius: var(--in-border-radius);
  border-top-right-radius: var(--in-border-radius);
}

.accordion-item:last-of-type {
  border-bottom-right-radius: var(--in-border-radius);
  border-bottom-left-radius: var(--in-border-radius);
}

.accordion-item:last-of-type .accordion-button.collapsed {
  border-bottom-right-radius: var(--in-border-radius);
  border-bottom-left-radius: var(--in-border-radius);
}

.accordion-item:last-of-type .accordion-collapse {
  border-bottom-right-radius: var(--in-border-radius);
  border-bottom-left-radius: var(--in-border-radius);
}

/*accordion*/
.accordion.section-cell-parent {
  box-shadow: var(--in-box-shadow);
  border-radius: var(--in-border-radius);
}

/* ----- Utils ----- */
/*===========================================================================*/
.text-balance {
  text-wrap: balance;
}

.text-pretty {
  text-wrap: pretty;
}

/* ----- Article ----- */
/*===========================================================================*/
.article-item {
  padding: 1.5rem;
  background-color: var(--bs-body-bg);
  border: var(--in-border);
  border-radius: var(--in-border-radius);
  -webkit-box-shadow: var(--in-box-shadow);
  box-shadow: var(--in-box-shadow);
}

.article-item__thumbnail, .product-item__thumbnail, .category__thumbnail {
  border-radius: var(--in-border-radius);
  overflow: hidden;
}