@import url("https://fonts.googleapis.com/css2?family=Dosis:wght@400;500;600;700&family=Playfair+Display:ital,wght@0,400;0,600;0,700;1,400;1,500;1,600;1,700&display=swap");
* {
  -moz-osx-font-smoothing: grayscale;
  -webkit-font-smoothing: antialiased;
  font-smoothing: antialiased;
  font-family: "Dosis", sans-serif !important;
  font-size: 16px;
}

body {
  padding: 0;
  margin: 0;
  text-rendering: optimizeLegibility;
  font-weight: 400;
  background-color: #fff;
  font-family: "Dosis", sans-serif;
  font-size: 16px;
  background-image: url("https://marholmen.se/wp-content/uploads/2023/09/Marholmen-Dronarbilder-NY.jpg");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  backdrop-filter: blur(5px);
}

.dosis {
  font-family: "Dosis", sans-serif;
}

.playfair {
  font-family: "Playfair Display", serif;
}

h1, h2, h3, h4, h5 {
  font-family: "Playfair Display", serif !important;
}

h4 {
  font-size: 20px !important;
  font-weight: 600 !important;
  margin: 0 0 10px 0 !important;
}

label {
  font-family: "Dosis", sans-serif;
  font-size: 16px !important;
  font-weight: 600 !important;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  margin: 0 0 15px 0 !important;
}

.label {
  font-size: 16px !important;
}

.topbar-small {
  background-color: transparent !important;
  border-bottom: 2px solid hsla(0, 0%, 100%, 0.2) !important;
  height: auto !important;
}
.topbar-small .responsive-container {
  padding: 0;
}
@media (max-width: 767px) {
  .topbar-small .responsive-container {
    padding: 0 !important;
  }
}
.topbar-small .logo {
  margin: 0 auto !important;
  display: block !important;
  height: 56px !important;
  margin: 0 auto !important;
  max-width: 220px !important;
  background: url("https://omnis.reinvented-hospitality.com/themes/N6VAT0Y25SV8/Vit%20Logo%20transparent");
  background-repeat: no-repeat !important;
  background-size: contain !important;
  background-position: center !important;
  width: 100%;
}
@media (max-width: 767px) {
  .topbar-small .logo {
    height: 56px !important;
    max-width: 120px !important;
    margin: 0 0 0 15px !important;
  }
}

@media (max-width: 767px) {
  .language-selector {
    margin: 0 15px 0 0 !important;
  }
}

.btn-primary, .btn-secondary {
  border-radius: 5px !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  letter-spacing: 0.05em !important;
  text-decoration: none !important;
  text-transform: uppercase !important;
  transition: all 0.4s !important;
  background-color: #333 !important;
  color: #fffce5 !important;
  font-family: Dosis, sans-serif !important;
  outline: 2px solid #333 !important;
}
.btn-primary:hover, .btn-secondary:hover {
  cursor: pointer;
}

h1 {
  font-family: "Playfair Display", serif;
  color: #333 !important;
  font-size: 50px;
  font-weight: 700;
  letter-spacing: -2px;
  line-height: 1.4;
}
h1.sub {
  text-transform: uppercase !important;
  letter-spacing: -0.5px !important;
}

ul.stepper li {
  font-size: 20px;
}

footer {
  background-image: url(https://marholmen.se/wp-content/themes/marholmen/css/build/img/footer-bg.png);
  background-size: auto 60px;
  min-height: 200px;
  padding: 70px 50px;
  border: none;
  color: #fff;
  font-size: 16px;
  line-height: 26px;
  text-align: center;
}
footer .logo {
  margin: 0 auto;
  display: block;
  height: 56px;
  margin: 0 auto;
  max-width: 220px;
}
footer h3 {
  font-family: "Playfair Display", serif;
  color: #fff;
  font-size: 24px;
  font-weight: 700;
  letter-spacing: -1px;
  line-height: 1.4;
  margin: 0 auto;
}

.input-wrapper {
  background-color: #fff;
}

.hotel-booking-landing-page {
  background: transparent !important;
}
.hotel-booking-landing-page h1 {
  font-family: "Playfair Display", serif !important;
  color: #FFFCE5 !important;
  font-size: 50px !important;
  font-weight: 700 !important;
  letter-spacing: -2px !important;
  line-height: 1.4 !important;
  margin: 0 auto 15px auto !important;
}
.hotel-booking-landing-page .layout {
  margin: 30px auto;
}
.hotel-booking-landing-page .center-box {
  background-color: #FFFCE5;
  padding: 30px;
}
.hotel-booking-landing-page .discount[data-expanded=""] .sub {
  border-radius: 5px;
  font-size: 14px;
  font-weight: 600;
  letter-spacing: 0.05em;
  text-decoration: none;
  text-transform: uppercase;
  transition: all 0.4s;
  color: #333;
  font-family: Dosis, sans-serif !important;
}
.hotel-booking-landing-page .discount .sub {
  border-radius: 5px;
  font-size: 14px;
  font-weight: 600;
  letter-spacing: 0.05em;
  text-decoration: none;
  text-transform: uppercase;
  transition: all 0.4s;
  color: #333;
  font-family: Dosis, sans-serif !important;
}

.hotel-booking-form, .restaurant-booking-new, .booking-successful, .my-hotel-booking-layout, .edit-my-hotel-booking, .edit-my-hotel-room-bookings {
  background-color: #FFFCE5;
}

@media (max-width: 768px) {
  .room-types ul {
    margin: 0;
  }
}
.room-types ul li {
  max-width: 100% !important;
}
.room-types .header .count {
  font-size: 16px;
  color: #333 !important;
}
.room-types .room-type-card {
  background-color: #fff;
}
.room-types .room-type-card.selected .btn-secondary {
  background-color: #757E6F !important;
  outline: 2px solid #757E6F !important;
  color: #fff !important;
}
.room-types .room-type-card h3 {
  font-family: "Playfair Display", serif;
  color: #333 !important;
  font-size: 24px;
}
.room-types .room-type-card .info {
  padding: 20px;
}
.room-types .room-type-card .info dl dt {
  color: #757E6F;
}
.room-types .room-type-card .info dl dd {
  font-size: 16px;
  margin-right: 10px !important;
}
.room-types .room-type-card .info .nav-link {
  color: #333;
  font-size: 16px;
  display: block;
  margin: 10px 0 15px 0;
}
.room-types .room-type-card .info p {
  overflow: visible;
  white-space: normal;
  max-height: 30px;
  display: none;
}

.modal .modal-wrapper-1 .modal-wrapper-2 .modal-wrapper-3 {
  background-color: #FFFCE5;
  padding: 20px;
  max-height: 90vh;
  border-radius: 0;
  max-width: 80rem;
}
.modal .modal-wrapper-1 .modal-wrapper-2 .modal-wrapper-3 .header-description {
  font-size: 16px;
  color: #333 !important;
  margin: 15px 0;
  line-height: 1.4;
}
.modal .modal-wrapper-1 .modal-wrapper-2 .modal-wrapper-3 .close-container .close .icon-s {
  font-size: 30px;
}

.room-types ul {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 20px !important;
}
@media (min-width: 768px) {
  .room-types ul {
    grid-template-columns: repeat(3, 1fr) !important;
  }
}
.room-types ul li {
  max-width: 100%;
  transition: 0.4s all;
}
.room-types ul li:hover {
  box-shadow: 0 0 15px rgba(0, 0, 0, 0.1);
}

.hotel-bookings-nights-summary, .hotel-bookings-rooms-summary, .hotel-bookings-price-details {
  background-color: #fff;
}
.hotel-bookings-nights-summary ul, .hotel-bookings-rooms-summary ul, .hotel-bookings-price-details ul {
  font-size: 16px;
  color: #333 !important;
}
.hotel-bookings-nights-summary ul li, .hotel-bookings-rooms-summary ul li, .hotel-bookings-price-details ul li {
  font-size: 16px;
  color: #333 !important;
}
.hotel-bookings-nights-summary ul li .body-s, .hotel-bookings-nights-summary ul li .sub5, .hotel-bookings-rooms-summary ul li .body-s, .hotel-bookings-rooms-summary ul li .sub5, .hotel-bookings-price-details ul li .body-s, .hotel-bookings-price-details ul li .sub5 {
  font-size: 16px;
  color: #333 !important;
}
.hotel-bookings-nights-summary h4, .hotel-bookings-rooms-summary h4, .hotel-bookings-price-details h4 {
  margin: 5px 0 !important;
}
.hotel-bookings-nights-summary .room-type-and-rate-plan .nav-link, .hotel-bookings-rooms-summary .room-type-and-rate-plan .nav-link, .hotel-bookings-price-details .room-type-and-rate-plan .nav-link {
  font-size: 16px;
  color: #333 !important;
  margin: 0 0 10px 0;
}
.hotel-bookings-nights-summary .room-name, .hotel-bookings-rooms-summary .room-name, .hotel-bookings-price-details .room-name {
  font-size: 16px !important;
  color: #333 !important;
}
.hotel-bookings-nights-summary label, .hotel-bookings-rooms-summary label, .hotel-bookings-price-details label {
  font-size: 16px !important;
  color: #333 !important;
}

.rate-plans .btn-icon:hover {
  cursor: pointer;
}
.rate-plans .btn-icon span {
  font-size: 24px;
  margin-top: -6px;
}
.rate-plans .btn-icon h4 {
  font-size: 20px;
  margin: 0 0 0 10px;
}

.rate-plan-card.selected {
  border-color: #000 !important;
}
.rate-plan-card.selected .btn-secondary {
  background-color: #757E6F !important;
  outline: 2px solid #757E6F !important;
  color: #fff !important;
}
.rate-plan-card[data-expanded=""] {
  border-color: #333;
}
.rate-plan-card[data-expanded=""] .rate-name .icon {
  background-color: #333 !important;
  color: #fff;
}
.rate-plan-card .info .rate-name {
  font-size: 16px;
  color: #333 !important;
  font-family: "Playfair Display", serif;
  margin: 0 0 5px 0;
}
.rate-plan-card .info .rate-name .sub {
  font-family: "Playfair Display", serif;
  font-size: 18px;
}
.rate-plan-card .info ul {
  padding: 0;
}
.rate-plan-card .info ul li {
  font-size: 16px;
  color: #333 !important;
}

ul.tabs li.selected {
  background-color: #333;
  color: #fff;
  border: 1px solid #333;
}
ul.tabs li.normal {
  background-color: transparent !important;
  color: #333 !important;
  border: 1px solid #333 !important;
  opacity: 0.7;
}
ul.tabs li.normal:hover {
  cursor: pointer;
  opacity: 1;
  background-color: #333;
  color: #fff;
  border: 1px solid #333;
}
ul.tabs li label {
  font-size: 16px;
  margin: 0 !important;
  line-height: 1;
}

.room-type-booking-modal .booking-modal-content {
  padding-bottom: 150px !important;
}
@media (max-width: 639px) {
  .room-type-booking-modal .booking-modal-content .amenities .amenity {
    margin: 0 0 15px 0;
  }
}

.hotel-booking-layout .guest-details section.legal-terms a {
  color: #000;
}

.my-hotel-booking-layout .main .container section {
  padding: 20px;
}
.my-hotel-booking-layout .main .container section .booking-guest-info .guest-name span {
  font-family: "Playfair Display", serif;
}

.edit-my-hotel-booking .container .content .fields button.btn-tertiary {
  color: #000 !important;
}

.restaurang-bookings-step-title {
  letter-spacing: 0;
  text-transform: uppercase;
}

.restaurant-booking-new-container {
  background-color: #FFFCE5;
  padding: 0 0 50px 0;
}

body {
  display: flex;
  flex-direction: column;
  height: 100vh;
}

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

blockquote, dl, dd, h1, h2, h3, h4, h5, h6, hr, figure, p, pre {
  margin: 0;
}

fieldset {
  margin: 0;
  padding: 0;
}

h1, h2, h3, h4, h5, h6 {
  font-size: inherit;
  font-weight: inherit;
}

img, svg, video, canvas, audio, iframe, embed, object {
  display: block;
  vertical-align: middle;
}

img, video {
  max-width: 100%;
  height: auto;
}

*, ::before, ::after {
  border-width: 0;
  border-style: solid;
  border-color: black;
}

button {
  background: transparent;
}

[type=checkbox], [type=radio] {
  --webkit-appearance: none;
  --moz-appearance: none;
  appearance: none;
}

[type=checkbox]:checked,
[type=radio]:checked {
  background-color: currentColor;
  background-position: 50%;
  background-repeat: no-repeat;
  background-size: 100% 100%;
  border-color: rgba(0, 0, 0, 0);
}

[type=checkbox]:checked {
  background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23fff' viewBox='0 0 16 16'%3E%3Cpath d='M12.207 4.793a1 1 0 0 1 0 1.414l-5 5a1 1 0 0 1-1.414 0l-2-2a1 1 0 0 1 1.414-1.414L6.5 9.086l4.293-4.293a1 1 0 0 1 1.414 0z'/%3E%3C/svg%3E");
}

[type=radio]:checked {
  background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23fff' viewBox='0 0 16 16'%3E%3Ccircle cx='8' cy='8' r='3'/%3E%3C/svg%3E");
}

[type=checkbox]:checked:focus,
[type=checkbox]:checked:hover,
[type=checkbox]:indeterminate,
[type=radio]:checked:focus,
[type=radio]:checked:hover {
  background-color: currentColor;
  border-color: rgba(0, 0, 0, 0);
}

[type=checkbox]:indeterminate {
  background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 16 16'%3E%3Cpath stroke='%23fff' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M4 8h8'/%3E%3C/svg%3E");
  background-position: 50%;
  background-repeat: no-repeat;
  background-size: 100% 100%;
}

[type=checkbox]:indeterminate:focus,
[type=checkbox]:indeterminate:hover {
  background-color: currentColor;
  border-color: rgba(0, 0, 0, 0);
}

a {
  color: inherit;
  text-decoration: inherit;
}

[hidden] {
  display: none !important;
}

* {
  font-family: "Dosis", sans-serif;
}

h1.default, h2.default, h3.default, h4.default, h5.default, .h1, .h2, .h3, .h4, .h5 {
  font-family: "Playfair Display", serif;
}

h1.sub, h2.sub, h3.sub, h4.sub, h5.sub, .sub1, .sub2, .sub3, .sub4, .sub5 {
  font-family: "Dosis", sans-serif;
}

h1.default, .h1 {
  font-weight: 500;
  font-size: 28px;
  line-height: 36px;
}
@media (min-width: 640px) {
  h1.default, .h1 {
    font-size: 48px;
    line-height: 56px;
  }
}

h2.default, .h2 {
  font-weight: 500;
  font-size: 24px;
  line-height: 32px;
}
@media (min-width: 640px) {
  h2.default, .h2 {
    font-size: 36px;
    line-height: 48px;
  }
}

h3.default, .h3 {
  font-size: 32px;
  line-height: 40px;
  font-weight: 500;
}

h4.default, .h4 {
  font-size: 28px;
  line-height: 32px;
  font-weight: 500;
}

h5.default, .h5 {
  font-size: 24px;
  line-height: 32px;
  font-weight: 500;
}

h1.sub, .sub1 {
  font-size: 24px;
  line-height: 32px;
  font-weight: 600;
}

h2.sub, .sub2 {
  font-size: 20px;
  line-height: 24px;
  font-weight: 600;
}

h3.sub, .sub3 {
  font-weight: 600;
  font-size: 16px;
  line-height: 24px;
}
@media (min-width: 640px) {
  h3.sub, .sub3 {
    font-size: 18px;
    line-height: 24px;
  }
}

h4.sub, .sub4 {
  font-weight: 600;
  font-size: 14px;
  line-height: 20px;
}
@media (min-width: 640px) {
  h4.sub, .sub4 {
    font-size: 16px;
    line-height: 24px;
  }
}

h5.sub, .sub5 {
  font-size: 14px;
  line-height: 20px;
  font-weight: 600;
}

.label-s {
  font-size: 14px;
  font-weight: 500;
  line-height: 20px;
}

.label-m {
  font-weight: 500;
  font-size: 14px;
  line-height: 20px;
}
@media (min-width: 640px) {
  .label-m {
    font-size: 16px;
    line-height: 24px;
  }
}

.body-s {
  font-weight: 400;
  font-size: 12px;
  line-height: 16px;
}
@media (min-width: 640px) {
  .body-s {
    font-size: 14px;
    line-height: 20px;
  }
}

.body-m {
  font-weight: 400;
  font-size: 14px;
  line-height: 20px;
}
@media (min-width: 640px) {
  .body-m {
    font-size: 16px;
    line-height: 24px;
  }
}

.btn-primary {
  font-weight: 500;
  font-size: 14px;
  line-height: 20px;
}
@media (min-width: 640px) {
  .btn-primary {
    font-size: 16px;
    line-height: 24px;
  }
}
.btn-primary {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 8px 24px;
  gap: 6px;
  border-radius: 0;
  font-weight: 500;
  font-size: 14px;
  line-height: 20px;
}
@media (min-width: 640px) {
  .btn-primary {
    font-size: 16px;
    line-height: 24px;
  }
}
.btn-primary .icon {
  margin-left: -4px;
}
.btn-primary .vcenter-text-adjust {
  margin-top: -0.06em;
  margin-bottom: 0.06em;
}
.btn-primary {
  color: #fff;
  background-color: #333;
}
.btn-primary:disabled {
  color: rgba(255, 255, 255, 0.7);
  background-color: rgba(0, 0, 0, 0.1);
}

.btn-secondary {
  font-weight: 500;
  font-size: 14px;
  line-height: 20px;
}
@media (min-width: 640px) {
  .btn-secondary {
    font-size: 16px;
    line-height: 24px;
  }
}
.btn-secondary {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 8px 24px;
  gap: 6px;
  border-radius: 0;
  font-weight: 500;
  font-size: 14px;
  line-height: 20px;
}
@media (min-width: 640px) {
  .btn-secondary {
    font-size: 16px;
    line-height: 24px;
  }
}
.btn-secondary .icon {
  margin-left: -4px;
}
.btn-secondary .vcenter-text-adjust {
  margin-top: -0.06em;
  margin-bottom: 0.06em;
}
.btn-secondary {
  color: #333;
  background-color: transparent;
  outline: 1px solid #333;
}
.btn-secondary:disabled {
  color: rgba(255, 255, 255, 0.7);
  background-color: rgba(0, 0, 0, 0.1);
  outline-color: rgba(255, 255, 255, 0.7);
}
.btn-secondary:focus {
  outline-width: 2px;
}

.btn-tertiary {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  padding: 8px 0;
  gap: 8px;
  font-size: 16px;
  font-weight: 500;
  color: #333;
}
.btn-tertiary:disabled {
  color: rgba(0, 0, 0, 0.1);
}
.btn-tertiary .vcenter-text-adjust {
  margin-top: -0.06em;
  margin-bottom: 0.06em;
}

.btn-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  padding-top: 2px;
}
.btn-icon.small {
  width: 24px;
  height: 24px;
  padding: 0;
}
.btn-icon {
  color: #000;
}
.btn-icon:disabled {
  color: rgba(255, 255, 255, 0.7);
}

.btn-danger {
  background-color: #CE2121;
}

.breadcrumb .wrapper {
  font-size: 14px;
  font-weight: 500;
  line-height: 20px;
  display: flex;
  gap: 2px;
  align-items: center;
}
.breadcrumb a {
  display: inline-flex;
  padding: 2px 4px;
  color: #333;
}
.breadcrumb a:hover {
  color: #000;
  border-radius: 4px;
  background-color: transparent;
}
.breadcrumb a:focus {
  border-width: 2px;
  border-radius: 4px;
  border-color: #000;
}
.breadcrumb span.text {
  color: #0D0D0D;
  padding: 2px 4px;
}

.checkbox-wrapper {
  display: flex;
  gap: 6px;
}
.checkbox-wrapper input {
  border: 1px solid #B0B0B0;
  border-radius: 4px;
  width: 16px;
  min-width: 16px;
  height: 16px;
  margin-top: 4px;
}
.checkbox-wrapper input:checked {
  color: #333;
}
.checkbox-wrapper input:indeterminate {
  color: #333;
}
.checkbox-wrapper input:focus-visible {
  outline: 2px solid #333;
  outline-offset: 1px;
}
.checkbox-wrapper label {
  font-weight: 400;
  font-size: 14px;
  line-height: 20px;
}
@media (min-width: 640px) {
  .checkbox-wrapper label {
    font-size: 16px;
    line-height: 24px;
  }
}
.checkbox-wrapper label {
  color: #333;
  margin-bottom: 0.06em;
  margin-top: -0.06em;
}
.checkbox-wrapper.invalid label {
  color: #CE2121;
}
.checkbox-wrapper.disabled input {
  border-color: #D1D1D1;
  background-color: #D1D1D1;
}
.checkbox-wrapper.required label::after {
  content: "*";
  color: #CE2121;
}

.form-error-message {
  font-weight: 400;
  font-size: 12px;
  line-height: 16px;
}
@media (min-width: 640px) {
  .form-error-message {
    font-size: 14px;
    line-height: 20px;
  }
}
.form-error-message {
  margin-top: 4px;
  color: #CE2121;
  display: flex;
  gap: 0.2rem;
  justify-content: flex-start;
}
.form-error-message i:first-child {
  margin-top: 2px;
}

.label {
  display: block;
  font-weight: 600;
  color: #333;
  margin-bottom: 6px;
  font-size: 14px;
}
@media (min-width: 640px) {
  .label {
    font-size: 16px;
  }
}
.label.invalid {
  color: #CE2121;
}
.label.required::after {
  content: "*";
  margin-left: 3px;
  color: #CE2121;
}

.link-primary {
  background-color: #333;
  color: #fff;
  font-size: 16px;
  font-weight: 500;
  border-radius: 8px;
  border: 1px solid #333;
  padding: 8px 16px;
  line-height: 24px;
}

.nav-link {
  font-size: 14px;
  font-weight: 500;
  line-height: 20px;
  color: #333;
  text-decoration: underline;
}
.nav-link:hover {
  text-decoration: underline;
}

.notification-container {
  pointer-events: auto;
  display: flex;
  visibility: visible;
  min-height: 4rem;
  align-items: center;
  border-radius: 10px;
  padding: 16px;
  box-shadow: 0 2px 8px 0 rgba(22, 32, 62, 0.1490196078);
  background-color: #000;
  color: #fff;
}
.notification-container .wrapper {
  flex-grow: 1;
}
.notification-container .wrapper .title-icon {
  display: flex;
  gap: 6px;
}
.notification-container .wrapper .title-icon .icon {
  height: 16px;
  width: 16px;
}
.notification-container .wrapper .title-icon .text-success {
  color: #5BCD6F;
}
.notification-container .wrapper .title-icon .text-danger-400 {
  color: #CE2121;
}
.notification-container .wrapper .title-icon .icon-m {
  font-size: 20px;
  line-height: 1px;
}
.notification-container .wrapper .title-icon .text {
  font-weight: 500;
  font-size: 14px;
  line-height: 20px;
}
@media (min-width: 640px) {
  .notification-container .wrapper .title-icon .text {
    font-size: 16px;
    line-height: 24px;
  }
}
.notification-container .wrapper .title-icon .text {
  flex-grow: 1;
}
.notification-container .wrapper .title-icon .close-button {
  color: #fff;
  width: 16px;
  height: 16px;
  font-size: 16px;
  line-height: 1px;
}
.notification-container button.undo_action {
  font-weight: 400;
  font-size: 14px;
  line-height: 20px;
}
@media (min-width: 640px) {
  .notification-container button.undo_action {
    font-size: 16px;
    line-height: 24px;
  }
}
.notification-container button.undo_action {
  background-color: #3D3D3D;
  border-radius: 8px;
  padding: 0 16px;
  color: #FFFFFF;
}
.notification-container.transition-enter {
  --tw-translate-x: 0;
  --tw-translate-y: 0;
  --tw-rotate: 0;
  --tw-skew-x: 0;
  --tw-skew-y: 0;
  --tw-scale-x: 1;
  --tw-scale-y: 1;
  transform: translateX(var(--tw-translate-x)) translateY(var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
  transition-timing-function: cubic-bezier(0, 0, 0.2, 1);
  transition-duration: 300ms;
}
.notification-container.transition-enter-start {
  --tw-translate-y: 8px;
  --tw-translate-x: 8px;
  transform: translateX(var(--tw-translate-x)) translateY(var(--tw-translate-y));
  opacity: 0;
}
.notification-container.transition-enter-end {
  --tw-translate-y: 0px;
  --tw-translate-x: 0px;
  transform: translateX(var(--tw-translate-x)) translateY(var(--tw-translate-y));
  opacity: 1;
}
.notification-container.transition-leave {
  transition-timing-function: cubic-bezier(0.4, 0, 1, 1);
  transition-duration: 100ms;
}
.notification-container.transition-leave-start {
  opacity: 1;
}
.notification-container.transition-leave-end {
  opacity: 0;
}

.number-input {
  display: flex;
  align-items: center;
  gap: 4px;
}
.number-input .input-wrapper {
  width: 40px;
  padding: 0;
}
.number-input .input-wrapper input {
  text-align: center;
}

.select-wrapper {
  position: relative;
}
.select-wrapper:focus-within .input-wrapper {
  outline: 2px solid #000;
}
.select-wrapper .input-wrapper {
  position: relative;
  z-index: 10;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  min-height: 40px;
}
.select-wrapper .input-wrapper[data-disabled] .select-content {
  color: #D1D1D1;
}
.select-wrapper select {
  position: absolute;
  z-index: 20;
  top: 0;
  left: 0;
  display: block;
  width: 100%;
  height: 100%;
  opacity: 0;
}

.flag-sizing {
  height: 20px;
  width: 20px;
}

.stepper {
  display: flex;
  align-items: center;
  gap: 12px;
  border-bottom: 1px solid rgba(0, 0, 0, 0.2);
  position: relative;
  white-space: nowrap;
}
.stepper span.decor {
  position: relative;
  bottom: 4px;
}
.stepper li {
  font-weight: 500;
  font-size: 14px;
  line-height: 20px;
}
@media (min-width: 640px) {
  .stepper li {
    font-size: 16px;
    line-height: 24px;
  }
}
.stepper li {
  display: flex;
  align-items: center;
  gap: 6px;
  padding-bottom: 6px;
  padding-right: 8px;
  border-bottom: 2px solid transparent;
}
.stepper li .number {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 16px;
  height: 16px;
  border-width: 1px;
  border-radius: 999px;
}
.stepper li .number .icon {
  display: none;
  width: 16px;
  height: 16px;
}
.stepper li .number .value {
  display: block;
  font-size: 12px;
  line-height: 16px;
  font-weight: 500;
}
.stepper li.selected .number {
  color: #fff;
  border-color: #fff;
}
.stepper li.selected {
  border-bottom-color: #fff;
}
.stepper li.completed .number {
  color: #16A34A;
  border-color: #16A34A;
}
.stepper li.completed .number .icon {
  display: block;
}
.stepper li.completed .number .value {
  display: none;
}
.stepper li.disabled {
  color: #6D6D6D;
}
.stepper li.disabled .number {
  border-color: #6D6D6D;
}

ul.tabs {
  display: flex;
  gap: 12px;
}
ul.tabs li {
  font-weight: 500;
  font-size: 14px;
  line-height: 20px;
}
@media (min-width: 640px) {
  ul.tabs li {
    font-size: 16px;
    line-height: 24px;
  }
}
ul.tabs li {
  padding: 8px 16px;
  border-radius: 0;
  border-width: 1px;
}
ul.tabs li.normal {
  border-color: transparent;
  color: #000;
  background-color: #F5F5F5;
}
ul.tabs li.selected {
  border-color: #fff;
  color: #fff;
  background-color: #333;
}
ul.tabs li.disabled {
  border-color: transparent;
  color: #888888;
  background-color: #E7E7E7;
}

.input-wrapper {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 0 12px;
  outline: 1px solid rgba(0, 0, 0, 0.2);
  border-radius: 0;
  overflow: clip;
}
.input-wrapper.borderless {
  outline: none;
}
.input-wrapper:hover {
  outline-color: #333;
}
.input-wrapper:focus-within {
  outline: 2px solid #000;
}
.input-wrapper[data-disabled] {
  outline: 1px solid rgba(0, 0, 0, 0.2);
}
.input-wrapper[data-disabled].borderless {
  outline: none;
}
.input-wrapper[data-disabled] .icon {
  color: #D1D1D1;
}
.input-wrapper[data-invalid] {
  outline-color: #CE2121;
}
.input-wrapper .icon {
  color: #333;
}
.input-wrapper input, .input-wrapper button, .input-wrapper .select-content {
  font-weight: 400;
  font-size: 14px;
  line-height: 20px;
}
@media (min-width: 640px) {
  .input-wrapper input, .input-wrapper button, .input-wrapper .select-content {
    font-size: 16px;
    line-height: 24px;
  }
}
.input-wrapper input, .input-wrapper button, .input-wrapper .select-content {
  flex: 1;
  border: none;
  padding: 8px 0;
  text-align: left;
  width: 100%;
}
.input-wrapper input:focus, .input-wrapper button:focus, .input-wrapper .select-content:focus {
  border: none;
  box-shadow: none;
  outline: none;
}
.input-wrapper input:disabled, .input-wrapper button:disabled, .input-wrapper .select-content:disabled {
  color: #D1D1D1;
}
.input-wrapper input, .input-wrapper button {
  background-color: white;
}
.input-wrapper textarea {
  width: 100%;
  padding-top: 12px;
  padding-bottom: 12px;
  resize: none;
}
.input-wrapper textarea:focus {
  border: none;
  box-shadow: none;
  outline: none;
}

.images-slider {
  position: relative;
  margin-top: 20px;
}
.images-slider img {
  margin: auto;
  height: 288px;
  border-radius: 8px;
  display: none;
}
.images-slider img[data-selected] {
  display: block;
}
.images-slider .previous {
  position: absolute;
  top: 128px;
  left: 8px;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 32px;
  height: 32px;
  border-radius: 9999px;
  background-color: #e3e3e3;
  cursor: pointer;
}
.images-slider .next {
  position: absolute;
  top: 128px;
  right: 8px;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 32px;
  height: 32px;
  border-radius: 9999px;
  background-color: #e3e3e3;
  cursor: pointer;
}
.images-slider .selectors {
  position: absolute;
  bottom: 16px;
  display: flex;
  justify-content: center;
  gap: 8px;
  width: 100%;
}
.images-slider .selectors .selector {
  width: 8px;
  height: 8px;
  border-radius: 9999px;
  cursor: pointer;
  background-color: #b2b2b2;
}
.images-slider .selectors .selector[data-selected] {
  background-color: white;
}

.section-notification {
  pointer-events: auto;
  overflow: hidden;
  border-width: 1px;
  border-radius: 0.5rem;
  display: flex;
  align-items: center;
  padding: 0.75rem 1rem;
}
.section-notification.success {
  color: #5BCD6F;
  border-color: #5BCD6F;
}
.section-notification.error {
  color: #CE2121;
  border-color: #CE2121;
}
.section-notification .content {
  font-size: 14px;
  font-weight: 500;
  line-height: 20px;
  display: flex;
  align-items: flex-start;
  gap: 0.5rem;
}
.section-notification .content .icon {
  display: flex;
  justify-content: center;
  align-items: center;
  margin-top: 3px;
}
.section-notification .content .text {
  flex-grow: 1;
}

.my-hotel-booking-layout {
  display: flex;
  flex-direction: column;
  overflow-y: auto;
  flex: 1;
}
.my-hotel-booking-layout .main {
  overflow: auto;
  flex-grow: 1;
}
.my-hotel-booking-layout .container {
  display: flex;
  flex-direction: column;
  margin-bottom: 40px;
  margin-left: auto;
  margin-right: auto;
  color: #0D0D0D;
  max-width: 794px;
}
@media (max-width: 639px) {
  .my-hotel-booking-layout .container {
    margin-left: 16px;
    margin-right: 16px;
    margin-bottom: 20px;
  }
}
.my-hotel-booking-layout .container .body-s {
  color: #333;
}
@media (max-width: 639px) {
  .my-hotel-booking-layout .container .body-s {
    color: rgba(0, 0, 0, 0.5);
  }
}
.my-hotel-booking-layout .container .top {
  gap: 12px;
  margin-top: 20px;
}
.my-hotel-booking-layout .container .top h1 {
  font-weight: 500;
  font-size: 24px;
  line-height: 32px;
}
@media (min-width: 640px) {
  .my-hotel-booking-layout .container .top h1 {
    font-size: 36px;
    line-height: 48px;
  }
}
.my-hotel-booking-layout .container .top .payment-status-and-date {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.my-hotel-booking-layout .container .top .payment-status-and-date .booking-number {
  font-weight: 500;
  font-size: 14px;
  line-height: 20px;
}
@media (min-width: 640px) {
  .my-hotel-booking-layout .container .top .payment-status-and-date .booking-number {
    font-size: 16px;
    line-height: 24px;
  }
}
.my-hotel-booking-layout .container .top .payment-status-and-date .booking-number {
  color: #333;
}
.my-hotel-booking-layout .container .top .payment-status-and-date .payment-status {
  font-weight: 500;
  font-size: 14px;
  line-height: 20px;
}
@media (min-width: 640px) {
  .my-hotel-booking-layout .container .top .payment-status-and-date .payment-status {
    font-size: 16px;
    line-height: 24px;
  }
}
.my-hotel-booking-layout .container .top .payment-status-and-date .payment-status {
  text-align: end;
}
@media (max-width: 639px) {
  .my-hotel-booking-layout .container .top .payment-status-and-date .payment-status {
    display: flex;
  }
}
.my-hotel-booking-layout .container .top .status {
  display: flex;
  align-items: center;
  padding: 10px 12px 10px 12px;
  border-radius: 8px;
}
@media (max-width: 639px) {
  .my-hotel-booking-layout .container .top .status {
    font-size: 14px;
    padding: 8px 10px 8px 10px;
  }
}
.my-hotel-booking-layout .container .top .status.unpaid {
  background-color: #FBE7A9;
  color: #6D2403;
}
.my-hotel-booking-layout .container .top .status.paid {
  background-color: #C2F0C9;
  color: #1A4C24;
}
.my-hotel-booking-layout .container section {
  border-radius: 8px;
  border: 1px solid rgba(0, 0, 0, 0.2);
  display: flex;
  flex-direction: column;
  padding: 8px 20px 20px 20px;
}
@media (max-width: 639px) {
  .my-hotel-booking-layout .container section {
    padding: 8px 16px 16px 16px;
  }
}
.my-hotel-booking-layout .container .booking-guest-info {
  color: #0D0D0D;
  margin-top: 20px;
  margin-bottom: 20px;
}
@media (max-width: 639px) {
  .my-hotel-booking-layout .container .booking-guest-info {
    margin-top: 16px;
    margin-bottom: 16px;
  }
}
.my-hotel-booking-layout .container .booking-guest-info .guest-name {
  margin-bottom: 10px;
}
.my-hotel-booking-layout .container .booking-guest-info .guest-name span {
  font-size: 20px;
  line-height: 24px;
  font-weight: 600;
}
@media (max-width: 639px) {
  .my-hotel-booking-layout .container .booking-guest-info .guest-name span {
    font-size: 16px;
  }
}
.my-hotel-booking-layout .container .booking-guest-info .email-phone {
  display: flex;
  gap: 20px;
}
@media (max-width: 639px) {
  .my-hotel-booking-layout .container .booking-guest-info .email-phone {
    flex-direction: column;
    gap: 12px;
  }
}
.my-hotel-booking-layout .container .booking-guest-info .guest-contact {
  font-weight: 500;
  font-size: 14px;
  line-height: 20px;
}
@media (min-width: 640px) {
  .my-hotel-booking-layout .container .booking-guest-info .guest-contact {
    font-size: 16px;
    line-height: 24px;
  }
}
.my-hotel-booking-layout .container .booking-guest-info .guest-contact {
  gap: 8px;
}
@media (max-width: 639px) {
  .my-hotel-booking-layout .container .booking-guest-info .guest-contact {
    gap: 12px;
  }
}
.my-hotel-booking-layout .container .booking-guest-info .comment {
  margin-top: 16px;
}
@media (max-width: 639px) {
  .my-hotel-booking-layout .container .booking-guest-info .comment {
    margin-top: 12px;
  }
}
.my-hotel-booking-layout .container .row {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.my-hotel-booking-layout .container .row.align-content-right {
  justify-content: flex-end;
}
.my-hotel-booking-layout .container .column {
  display: flex;
  flex-direction: column;
}
.my-hotel-booking-layout .container .stay-summary {
  border-bottom: 1px solid rgba(0, 0, 0, 0.2);
  border-bottom-left-radius: 0;
  border-bottom-right-radius: 0;
}
.my-hotel-booking-layout .container .stay-summary .nights-summary ul.dates {
  margin-top: 10px;
  display: flex;
  gap: 40px;
}
@media (max-width: 639px) {
  .my-hotel-booking-layout .container .stay-summary .nights-summary ul.dates {
    gap: 12px;
    margin-top: 12px;
  }
}
.my-hotel-booking-layout .container .stay-summary .nights-summary ul.dates li {
  display: flex;
  flex-direction: column;
  gap: 4px;
  font-weight: 400;
  font-size: 14px;
  line-height: 20px;
}
@media (min-width: 640px) {
  .my-hotel-booking-layout .container .stay-summary .nights-summary ul.dates li {
    font-size: 16px;
    line-height: 24px;
  }
}
.my-hotel-booking-layout .container .stay-summary .nights-summary ul.dates .divider {
  width: 1px;
  background-color: #D1D1D1;
}
.my-hotel-booking-layout .container .stay-summary .nights-summary .nights-count {
  font-size: 20px;
  line-height: 24px;
  font-weight: 600;
}
@media (max-width: 639px) {
  .my-hotel-booking-layout .container .stay-summary .nights-summary .nights-count {
    font-size: 16px;
  }
}
.my-hotel-booking-layout .container .rooms-summary {
  border-top-left-radius: 0;
  border-top-right-radius: 0;
  border-top: 0;
  padding-top: 12px;
  gap: 4px;
}
@media (max-width: 639px) {
  .my-hotel-booking-layout .container .rooms-summary {
    padding-top: 8px;
  }
}
.my-hotel-booking-layout .container .rooms-summary.group-booking-rooms-summary {
  gap: 0px;
}
.my-hotel-booking-layout .container .rooms-summary.group-booking-rooms-summary .row {
  padding-top: 8px;
  padding-bottom: 2px;
}
@media (max-width: 639px) {
  .my-hotel-booking-layout .container .rooms-summary.group-booking-rooms-summary .row {
    padding-bottom: 0px;
  }
}
.my-hotel-booking-layout .container .rooms-summary .rooms-count {
  font-size: 20px;
  line-height: 24px;
  font-weight: 600;
}
@media (max-width: 639px) {
  .my-hotel-booking-layout .container .rooms-summary .rooms-count {
    font-size: 16px;
    padding-top: 8px;
  }
}
.my-hotel-booking-layout .container .rooms-summary .rooms-and-amount {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
@media (max-width: 639px) {
  .my-hotel-booking-layout .container .rooms-summary .rooms-and-amount {
    gap: 14px;
  }
}
.my-hotel-booking-layout .container .rooms-summary .rooms-and-amount .rooms-groups {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
@media (max-width: 639px) {
  .my-hotel-booking-layout .container .rooms-summary .rooms-and-amount .rooms-groups {
    gap: 6px;
  }
}
.my-hotel-booking-layout .container .rooms-summary .info {
  border-bottom: 1px solid rgba(0, 0, 0, 0.2);
  padding-bottom: 16px;
  gap: 8px;
  font-size: 16px;
  font-weight: 400;
}
.my-hotel-booking-layout .container .rooms-summary .info:last-child {
  border-bottom: none;
}
@media (max-width: 639px) {
  .my-hotel-booking-layout .container .rooms-summary .info {
    gap: 6px;
    margin-bottom: 14px;
    padding-bottom: 14px;
  }
}
.my-hotel-booking-layout .container .rooms-summary .info .room-nr {
  font-weight: 600;
  font-size: 16px;
  line-height: 24px;
}
@media (min-width: 640px) {
  .my-hotel-booking-layout .container .rooms-summary .info .room-nr {
    font-size: 18px;
    line-height: 24px;
  }
}
@media (max-width: 639px) {
  .my-hotel-booking-layout .container .rooms-summary .info .room-nr {
    font-size: 14px;
    line-height: 20px;
  }
}
.my-hotel-booking-layout .container .rooms-summary .info.group-room-booking {
  border-bottom: 2px solid rgba(0, 0, 0, 0.2);
}
.my-hotel-booking-layout .container .rooms-summary .info.group-room-booking .rooms-details {
  padding-top: 16px;
  padding-bottom: 16px;
}
@media (max-width: 639px) {
  .my-hotel-booking-layout .container .rooms-summary .info.group-room-booking .rooms-details {
    padding-top: 14px;
    padding-bottom: 14px;
  }
}
.my-hotel-booking-layout .container .rooms-summary .info.group-room-booking .rooms-details:last-child {
  padding-bottom: 0;
}
.my-hotel-booking-layout .container .rooms-summary .info.group-room-booking .rooms-details .room-info {
  display: flex;
  flex-direction: column;
  border-bottom: 1px solid rgba(0, 0, 0, 0.2);
  padding-top: 16px;
  padding-bottom: 16px;
  gap: 8px;
}
.my-hotel-booking-layout .container .rooms-summary .info.group-room-booking .rooms-details .room-info:first-child {
  border-top: 1px solid rgba(0, 0, 0, 0.2);
}
.my-hotel-booking-layout .container .rooms-summary .info.group-room-booking .rooms-details .room-info:last-child {
  border-bottom: none;
  padding-bottom: 0;
}
@media (max-width: 639px) {
  .my-hotel-booking-layout .container .rooms-summary .info.group-room-booking .rooms-details .room-info {
    padding-top: 14px;
    padding-bottom: 14px;
    gap: 6px;
  }
}
.my-hotel-booking-layout .container .rooms-summary .info.group-room-booking .rooms-details .room-info .guest-name {
  font-weight: 500;
  font-size: 14px;
  line-height: 20px;
}
@media (min-width: 640px) {
  .my-hotel-booking-layout .container .rooms-summary .info.group-room-booking .rooms-details .room-info .guest-name {
    font-size: 16px;
    line-height: 24px;
  }
}
.my-hotel-booking-layout .container .rooms-summary .info.group-room-booking .room-type-count {
  font-weight: 600;
  font-size: 16px;
  line-height: 24px;
}
@media (min-width: 640px) {
  .my-hotel-booking-layout .container .rooms-summary .info.group-room-booking .room-type-count {
    font-size: 18px;
    line-height: 24px;
  }
}
@media (max-width: 639px) {
  .my-hotel-booking-layout .container .rooms-summary .info.group-room-booking .room-type-count {
    font-size: 15px;
    line-height: 20px;
  }
}
.my-hotel-booking-layout .container .rooms-summary .info.group-room-booking .group-price-details {
  padding-bottom: 4px;
  font-weight: 400;
  font-size: 14px;
  line-height: 20px;
}
@media (min-width: 640px) {
  .my-hotel-booking-layout .container .rooms-summary .info.group-room-booking .group-price-details {
    font-size: 16px;
    line-height: 24px;
  }
}
.my-hotel-booking-layout .container .rooms-summary .info.group-room-booking .guest-name {
  padding-bottom: 4px;
}
.my-hotel-booking-layout .container .rooms-summary button {
  color: #333;
  gap: 6px;
  font-weight: 500;
  font-size: 14px;
  line-height: 20px;
}
@media (min-width: 640px) {
  .my-hotel-booking-layout .container .rooms-summary button {
    font-size: 16px;
    line-height: 24px;
  }
}
.my-hotel-booking-layout .container .rooms-summary .items {
  display: flex;
  gap: 12px;
  font-weight: 500;
  font-weight: 500;
  font-size: 14px;
  line-height: 20px;
}
@media (min-width: 640px) {
  .my-hotel-booking-layout .container .rooms-summary .items {
    font-size: 16px;
    line-height: 24px;
  }
}
@media (max-width: 639px) {
  .my-hotel-booking-layout .container .rooms-summary .items {
    flex-direction: column;
    gap: 6px;
  }
}
.my-hotel-booking-layout .container .rooms-summary .items .adults-child {
  display: flex;
  flex-direction: row;
  gap: 12px;
}
@media (max-width: 639px) {
  .my-hotel-booking-layout .container .rooms-summary .items .adults-child {
    gap: 8px;
  }
}
.my-hotel-booking-layout .container .rooms-summary .items .amenities {
  display: flex;
  flex-direction: row;
  gap: 12px;
}
@media (max-width: 639px) {
  .my-hotel-booking-layout .container .rooms-summary .items .amenities {
    gap: 8px;
  }
}
.my-hotel-booking-layout .container .rooms-summary .room-type {
  display: flex;
  gap: 8px;
  font-weight: 500;
  padding: 2px 0;
}
.my-hotel-booking-layout .container .rooms-summary .room-type .nav-link {
  text-decoration: underline;
}
.my-hotel-booking-layout .container .rooms-summary .price-details {
  font-weight: 400;
  font-size: 14px;
  line-height: 20px;
}
@media (min-width: 640px) {
  .my-hotel-booking-layout .container .rooms-summary .price-details {
    font-size: 16px;
    line-height: 24px;
  }
}
.my-hotel-booking-layout .container .rooms-summary .price-details {
  margin-bottom: 10px;
}
@media (max-width: 639px) {
  .my-hotel-booking-layout .container .rooms-summary .price-details {
    margin-bottom: 8px;
  }
}
.my-hotel-booking-layout .container .rooms-summary .price-details .row {
  margin-bottom: 8px;
}
@media (max-width: 639px) {
  .my-hotel-booking-layout .container .rooms-summary .price-details .row {
    margin-bottom: 6px;
  }
}
.my-hotel-booking-layout .container .rooms-summary .vat-info {
  font-weight: 400;
  font-size: 14px;
  line-height: 20px;
}
@media (min-width: 640px) {
  .my-hotel-booking-layout .container .rooms-summary .vat-info {
    font-size: 16px;
    line-height: 24px;
  }
}
.my-hotel-booking-layout .container .rooms-summary .vat-info {
  padding: 4px 0;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
@media (max-width: 639px) {
  .my-hotel-booking-layout .container .rooms-summary .vat-info {
    padding: 2px 0;
  }
}
.my-hotel-booking-layout .container .rooms-summary .vat-info .text-nowrap {
  text-wrap: nowrap;
}
.my-hotel-booking-layout .container .comment {
  display: flex;
  flex-direction: column;
  border: 1px solid rgba(0, 0, 0, 0.2);
  padding: 12px;
  border-radius: 8px;
  gap: 4px;
}
.my-hotel-booking-layout .container .comment .title {
  font-weight: 600;
  font-size: 14px;
  line-height: 20px;
}
@media (min-width: 640px) {
  .my-hotel-booking-layout .container .comment .title {
    font-size: 16px;
    line-height: 24px;
  }
}
.my-hotel-booking-layout .container .comment .text {
  font-weight: 400;
  font-size: 14px;
  line-height: 20px;
}
@media (min-width: 640px) {
  .my-hotel-booking-layout .container .comment .text {
    font-size: 16px;
    line-height: 24px;
  }
}
.my-hotel-booking-layout .total-amount, .my-hotel-booking-layout .paid-amount {
  font-weight: 400;
  font-size: 14px;
  line-height: 20px;
}
@media (min-width: 640px) {
  .my-hotel-booking-layout .total-amount, .my-hotel-booking-layout .paid-amount {
    font-size: 16px;
    line-height: 24px;
  }
}
.my-hotel-booking-layout .outstanding-balance {
  font-weight: 600;
  font-size: 16px;
  line-height: 24px;
}
@media (min-width: 640px) {
  .my-hotel-booking-layout .outstanding-balance {
    font-size: 18px;
    line-height: 24px;
  }
}
.my-hotel-booking-layout .hidden {
  display: none;
}
.my-hotel-booking-layout .icon-with-text {
  display: flex;
  align-items: center;
  gap: 6px;
}
.my-hotel-booking-layout .footer {
  border-top: 1px solid rgba(0, 0, 0, 0.2);
  justify-content: flex-end;
  padding: 20px 120px;
}
.my-hotel-booking-layout .register-names {
  font-weight: 500;
  font-size: 14px;
  line-height: 20px;
}
@media (min-width: 640px) {
  .my-hotel-booking-layout .register-names {
    font-size: 16px;
    line-height: 24px;
  }
}
.my-hotel-booking-layout .register-names {
  margin-top: 20px;
  padding: 12px 16px;
  border-radius: 0;
  border: 1px solid #14379B;
  color: #14379B;
  display: flex;
  justify-content: space-between;
}
@media (max-width: 639px) {
  .my-hotel-booking-layout .register-names {
    flex-direction: column;
    gap: 12px;
    padding: 16px;
  }
}
.my-hotel-booking-layout .register-names .icon-with-text {
  font-weight: 400;
}
@media (max-width: 639px) {
  .my-hotel-booking-layout .register-names .icon-with-text {
    align-items: start;
  }
}
@media (max-width: 639px) {
  .my-hotel-booking-layout .register-names .icon-with-text .icon {
    margin-top: 3px;
  }
}
.my-hotel-booking-layout .register-names .register-button {
  background-color: #FFFFFF;
  color: #14379B;
}
@media (max-width: 639px) {
  .my-hotel-booking-layout .register-names .register-button {
    text-align: center;
    width: 100%;
  }
}

[data-expanded] button .not-expanded {
  display: none;
}
[data-expanded] button .expanded {
  display: block;
}

.edit-my-hotel-booking {
  overflow-y: auto;
  flex: 1;
  display: flex;
  flex-direction: column;
}
.edit-my-hotel-booking .container {
  flex-grow: 1;
  overflow: auto;
}
.edit-my-hotel-booking .container .content {
  max-width: 794px;
  margin-left: auto;
  margin-right: auto;
  display: flex;
  flex-direction: column;
  padding: 16px;
  gap: 16px;
  flex: 1;
  overflow-y: auto;
}
@media (max-width: 639px) {
  .edit-my-hotel-booking .container .content {
    gap: 12px;
  }
}
.edit-my-hotel-booking .container .content .header {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
@media (max-width: 639px) {
  .edit-my-hotel-booking .container .content .header {
    gap: 2px;
  }
}
.edit-my-hotel-booking .container .content .fields {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
@media (max-width: 639px) {
  .edit-my-hotel-booking .container .content .fields {
    gap: 12px;
  }
}
.edit-my-hotel-booking .container .content .fields fieldset {
  display: grid;
  padding-inline: 0;
  grid-template-columns: 1fr;
  gap: 12px;
}
@media (min-width: 640px) {
  .edit-my-hotel-booking .container .content .fields fieldset {
    grid-template-columns: 1fr 1fr;
    gap: 16px;
  }
}
.edit-my-hotel-booking .container .content .fields fieldset .grid-span-2 {
  grid-column-start: span 1;
}
@media (min-width: 640px) {
  .edit-my-hotel-booking .container .content .fields fieldset .grid-span-2 {
    grid-column-start: span 2;
  }
}
.edit-my-hotel-booking .container .content .fields button.btn-tertiary {
  color: #246AFF;
  gap: 6px;
}
@media (max-width: 639px) {
  .edit-my-hotel-booking .container .content .comments {
    margin-top: -2px;
  }
}

.edit-my-hotel-room-bookings {
  overflow-y: auto;
  flex: 1;
  display: flex;
  flex-direction: column;
}
.edit-my-hotel-room-bookings .content {
  padding: 16px;
  display: flex;
  max-width: 1400px;
  margin: 0 auto;
}
@media (min-width: 640px) {
  .edit-my-hotel-room-bookings .content {
    overflow-x: auto;
    column-gap: 78px;
    row-gap: 40px;
  }
}
.edit-my-hotel-room-bookings .content .booking-header {
  display: flex;
  flex-direction: column;
  gap: 4px;
  margin-bottom: 12px;
}
@media (max-width: 639px) {
  .edit-my-hotel-room-bookings .content .booking-header {
    gap: 2px;
  }
}
.edit-my-hotel-room-bookings .content main {
  padding-bottom: 40px;
  width: 100%;
}
@media (max-width: 639px) {
  .edit-my-hotel-room-bookings .content main {
    padding-bottom: 20px;
  }
}
.edit-my-hotel-room-bookings .content main section:nth-of-type(1) {
  border-bottom: 1px solid rgba(0, 0, 0, 0.2);
  padding-bottom: 24px;
}
@media (max-width: 639px) {
  .edit-my-hotel-room-bookings .content main section:nth-of-type(1) {
    padding-bottom: 20px;
  }
}
.edit-my-hotel-room-bookings .content main section .edit-rooms-details {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.edit-my-hotel-room-bookings .content main section .edit-rooms-details .title {
  font-size: 24px;
  line-height: 32px;
  font-weight: 600;
  padding-top: 12px;
}
@media (max-width: 639px) {
  .edit-my-hotel-room-bookings .content main section .edit-rooms-details .title {
    font-size: 16px;
    line-height: 24px;
    padding-top: 20px;
  }
}
.edit-my-hotel-room-bookings .content main section .edit-rooms-details .edit-rooms-list {
  display: flex;
  flex-direction: column;
  gap: 20px;
}
@media (max-width: 639px) {
  .edit-my-hotel-room-bookings .content main section .edit-rooms-details .edit-rooms-list {
    gap: 16px;
  }
}
.edit-my-hotel-room-bookings .content main section .edit-rooms-details .edit-rooms-list .edit-room {
  display: flex;
  flex-direction: column;
  border-radius: 8px;
  border: 1px solid rgba(0, 0, 0, 0.2);
}
.edit-my-hotel-room-bookings .content main section .edit-rooms-details .edit-rooms-list .edit-room .room-title {
  font-weight: 600;
  font-size: 14px;
  line-height: 20px;
}
@media (min-width: 640px) {
  .edit-my-hotel-room-bookings .content main section .edit-rooms-details .edit-rooms-list .edit-room .room-title {
    font-size: 16px;
    line-height: 24px;
  }
}
.edit-my-hotel-room-bookings .content main section .edit-rooms-details .edit-rooms-list .edit-room .room-title {
  display: flex;
  gap: 12px;
  font-weight: 500;
  border-bottom: 1px solid rgba(0, 0, 0, 0.2);
  padding: 20px;
  align-items: center;
}
@media (max-width: 639px) {
  .edit-my-hotel-room-bookings .content main section .edit-rooms-details .edit-rooms-list .edit-room .room-title {
    gap: 6px;
    padding: 8px 16px 16px 16px;
    flex-direction: column;
    align-items: start;
  }
}
.edit-my-hotel-room-bookings .content main section .edit-rooms-details .edit-rooms-list .edit-room .room-title .room-type {
  display: flex;
  gap: 8px;
}
.edit-my-hotel-room-bookings .content main section .edit-rooms-details .edit-rooms-list .edit-room .room-name {
  font-weight: 600;
  font-size: 16px;
  line-height: 24px;
}
@media (min-width: 640px) {
  .edit-my-hotel-room-bookings .content main section .edit-rooms-details .edit-rooms-list .edit-room .room-name {
    font-size: 18px;
    line-height: 24px;
  }
}
@media (max-width: 639px) {
  .edit-my-hotel-room-bookings .content main section .edit-rooms-details .edit-rooms-list .edit-room .room-name {
    font-size: 15px;
    line-height: 20px;
    padding-top: 6px;
  }
}
.edit-my-hotel-room-bookings .content main section .edit-rooms-details .edit-rooms-list .edit-room .guest-and-comment {
  display: flex;
  flex-direction: column;
  padding: 20px 20px 12px 20px;
  gap: 8px;
}
@media (max-width: 639px) {
  .edit-my-hotel-room-bookings .content main section .edit-rooms-details .edit-rooms-list .edit-room .guest-and-comment {
    padding: 16px;
  }
}
@media (max-width: 639px) {
  .edit-my-hotel-room-bookings .content main section .edit-rooms-details .edit-rooms-list .edit-room .guest-and-comment button span {
    font-size: 14px;
    font-weight: 500;
    line-height: 20px;
  }
}
.edit-my-hotel-room-bookings .content main section .edit-rooms-details .edit-rooms-list .edit-room .guest-name {
  display: flex;
  gap: 16px;
  justify-content: space-between;
}
.edit-my-hotel-room-bookings .content main section .edit-rooms-details .edit-rooms-list .edit-room .guest-name div {
  width: 100%;
}
@media (max-width: 639px) {
  .edit-my-hotel-room-bookings .content main section .edit-rooms-details .edit-rooms-list .edit-room .guest-name {
    flex-direction: column;
    gap: 12px;
  }
}
.edit-my-hotel-room-bookings .content main section .edit-rooms-details .edit-rooms-list .edit-room .nav-link {
  font-weight: 600;
  font-size: 14px;
  line-height: 20px;
}
@media (min-width: 640px) {
  .edit-my-hotel-room-bookings .content main section .edit-rooms-details .edit-rooms-list .edit-room .nav-link {
    font-size: 16px;
    line-height: 24px;
  }
}
.edit-my-hotel-room-bookings .content main section .edit-rooms-details .edit-rooms-list .edit-room .nav-link {
  text-decoration: underline;
}
@media (max-width: 639px) {
  .edit-my-hotel-room-bookings .content main section .edit-rooms-details .edit-rooms-list .edit-room .nav-link {
    font-weight: 500;
  }
}
.edit-my-hotel-room-bookings .content main section .edit-rooms-details .edit-rooms-list .edit-room .room-child {
  border-top: 1px solid rgba(0, 0, 0, 0.2);
  padding: 0 20px;
}
@media (max-width: 639px) {
  .edit-my-hotel-room-bookings .content main h1.sub {
    font-size: 16px;
    line-height: 24px;
  }
}
.edit-my-hotel-room-bookings .content aside {
  display: flex;
  flex-direction: column;
  gap: 12px;
  min-width: 328px;
  padding: 16px 0px;
}
@media (max-width: 639px) {
  .edit-my-hotel-room-bookings .content aside {
    display: none;
  }
}

.icon-with-text {
  display: flex;
  align-items: center;
  gap: 6px;
}

.my-hotel-bookings-buttons {
  border-top: 1px solid rgba(0, 0, 0, 0.2);
  gap: 24px;
  padding: 24px 16px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
@media (max-width: 639px) {
  .my-hotel-bookings-buttons {
    flex-direction: column-reverse;
    text-align: center;
    padding: 16px 16px 12px 16px;
    gap: 8px;
  }
}
@media (max-width: 639px) {
  .my-hotel-bookings-buttons button {
    width: 100%;
  }
}
.my-hotel-bookings-buttons .nav-link {
  color: #CE2121;
}
@media (min-width: 640px) {
  .my-hotel-bookings-buttons .nav-link {
    margin-left: 16px;
  }
}
@media (min-width: 640px) {
  .my-hotel-bookings-buttons button {
    margin-right: 16px;
  }
}

.edit-my-hotel-group-booking {
  overflow-y: auto;
  flex: 1;
  display: flex;
  flex-direction: column;
}
.edit-my-hotel-group-booking .content {
  border-bottom: 1px solid rgba(0, 0, 0, 0.2);
  padding-bottom: 40px;
}
@media (max-width: 639px) {
  .edit-my-hotel-group-booking .content {
    padding: 16px;
    padding-bottom: 0;
  }
}
.edit-my-hotel-group-booking .content main {
  max-width: 794px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.edit-my-hotel-group-booking .content main .booking-header {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding-top: 18px;
}
@media (max-width: 639px) {
  .edit-my-hotel-group-booking .content main .booking-header {
    gap: 2px;
    padding-top: 12px;
  }
}
.edit-my-hotel-group-booking .content main section:nth-of-type(1) {
  border-bottom: none;
  padding-bottom: 24px;
}
@media (max-width: 639px) {
  .edit-my-hotel-group-booking .content main section:nth-of-type(1) {
    padding-bottom: 20px;
  }
}
.edit-my-hotel-group-booking .content main section .edit-rooms-details {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.edit-my-hotel-group-booking .content main section .edit-rooms-details .title {
  font-size: 24px;
  line-height: 32px;
  font-weight: 600;
}
@media (max-width: 639px) {
  .edit-my-hotel-group-booking .content main section .edit-rooms-details .title {
    font-size: 16px;
    line-height: 24px;
  }
}
.edit-my-hotel-group-booking .content main section .edit-rooms-details .edit-rooms-list {
  display: flex;
  flex-direction: column;
  gap: 20px;
}
@media (max-width: 639px) {
  .edit-my-hotel-group-booking .content main section .edit-rooms-details .edit-rooms-list {
    gap: 16px;
    padding-bottom: 16px;
  }
}
.edit-my-hotel-group-booking .content main section .edit-rooms-details .edit-rooms-list .edit-room {
  display: flex;
  flex-direction: column;
  border-radius: 8px;
  border: 1px solid rgba(0, 0, 0, 0.2);
}
.edit-my-hotel-group-booking .content main section .edit-rooms-details .edit-rooms-list .edit-room .group-room-title-button {
  display: flex;
  gap: 8px;
  padding: 20px;
}
@media (max-width: 639px) {
  .edit-my-hotel-group-booking .content main section .edit-rooms-details .edit-rooms-list .edit-room .group-room-title-button {
    flex-direction: row-reverse;
    align-items: start;
    justify-content: space-between;
    padding: 8px 16px 16px 16px;
  }
}
.edit-my-hotel-group-booking .content main section .edit-rooms-details .edit-rooms-list .edit-room .group-room-title-button h3 {
  font-weight: 600;
  font-size: 16px;
  line-height: 24px;
}
@media (min-width: 640px) {
  .edit-my-hotel-group-booking .content main section .edit-rooms-details .edit-rooms-list .edit-room .group-room-title-button h3 {
    font-size: 18px;
    line-height: 24px;
  }
}
@media (max-width: 639px) {
  .edit-my-hotel-group-booking .content main section .edit-rooms-details .edit-rooms-list .edit-room .group-room-title-button h3 {
    font-size: 15px;
    line-height: 20px;
    padding-top: 6px;
  }
}
.edit-my-hotel-group-booking .content main section .edit-rooms-details .edit-rooms-list .edit-room .group-room-title-button button.btn-tertiary {
  color: rgba(0, 0, 0, 0.5);
}
.edit-my-hotel-group-booking .content main section .edit-rooms-details .edit-rooms-list .edit-room .group-room-title-button button .expanded {
  background-color: #E7E7E7;
  border-radius: 6px;
  padding: 4px;
}
.edit-my-hotel-group-booking .content main section .edit-rooms-details .edit-rooms-list .edit-room .room-title {
  font-weight: 600;
  font-size: 14px;
  line-height: 20px;
}
@media (min-width: 640px) {
  .edit-my-hotel-group-booking .content main section .edit-rooms-details .edit-rooms-list .edit-room .room-title {
    font-size: 16px;
    line-height: 24px;
  }
}
.edit-my-hotel-group-booking .content main section .edit-rooms-details .edit-rooms-list .edit-room .room-title {
  padding: 0;
  border-bottom: none;
  display: flex;
  gap: 12px;
  font-weight: 500;
  align-items: center;
}
@media (max-width: 639px) {
  .edit-my-hotel-group-booking .content main section .edit-rooms-details .edit-rooms-list .edit-room .room-title {
    gap: 6px;
    flex-direction: column;
    align-items: start;
  }
}
.edit-my-hotel-group-booking .content main section .edit-rooms-details .edit-rooms-list .edit-room .room-title .room-type {
  display: flex;
  gap: 8px;
}
.edit-my-hotel-group-booking .content main section .edit-rooms-details .edit-rooms-list .edit-room .guest-name {
  display: flex;
  gap: 16px;
  justify-content: space-between;
  padding-bottom: 6px;
}
.edit-my-hotel-group-booking .content main section .edit-rooms-details .edit-rooms-list .edit-room .guest-name div {
  width: 100%;
}
@media (max-width: 639px) {
  .edit-my-hotel-group-booking .content main section .edit-rooms-details .edit-rooms-list .edit-room .guest-name {
    flex-direction: column;
    gap: 12px;
    padding-bottom: 4px;
  }
}
.edit-my-hotel-group-booking .content main section .edit-rooms-details .edit-rooms-list .edit-room nav-link {
  font-weight: 600;
  font-size: 14px;
  line-height: 20px;
}
@media (min-width: 640px) {
  .edit-my-hotel-group-booking .content main section .edit-rooms-details .edit-rooms-list .edit-room nav-link {
    font-size: 16px;
    line-height: 24px;
  }
}
.edit-my-hotel-group-booking .content main section .edit-rooms-details .edit-rooms-list .edit-room nav-link {
  text-decoration: underline;
}
@media (max-width: 639px) {
  .edit-my-hotel-group-booking .content main section .edit-rooms-details .edit-rooms-list .edit-room nav-link {
    font-weight: 500;
  }
}
.edit-my-hotel-group-booking .content main section .edit-rooms-details .edit-rooms-list .edit-room .room-info {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding-top: 16px;
  padding-bottom: 16px;
}
@media (max-width: 639px) {
  .edit-my-hotel-group-booking .content main section .edit-rooms-details .edit-rooms-list .edit-room .room-info {
    gap: 12px;
  }
}
.edit-my-hotel-group-booking .content main section .edit-rooms-details .edit-rooms-list .edit-room .room-info {
  border-bottom: 1px solid rgba(0, 0, 0, 0.2);
}
.edit-my-hotel-group-booking .content main section .edit-rooms-details .edit-rooms-list .edit-room .room-info:last-of-type {
  border-bottom: none;
}
.edit-my-hotel-group-booking .content main section .edit-rooms-details .edit-rooms-list .edit-room .room-info .room-name {
  font-weight: 600;
  font-size: 14px;
  line-height: 20px;
}
@media (min-width: 640px) {
  .edit-my-hotel-group-booking .content main section .edit-rooms-details .edit-rooms-list .edit-room .room-info .room-name {
    font-size: 16px;
    line-height: 24px;
  }
}
.edit-my-hotel-group-booking .content main section .edit-rooms-details .edit-rooms-list .edit-room .nav-link {
  font-weight: 600;
  font-size: 14px;
  line-height: 20px;
}
@media (min-width: 640px) {
  .edit-my-hotel-group-booking .content main section .edit-rooms-details .edit-rooms-list .edit-room .nav-link {
    font-size: 16px;
    line-height: 24px;
  }
}
.edit-my-hotel-group-booking .content main section .edit-rooms-details .edit-rooms-list .edit-room .nav-link {
  text-decoration: underline;
}
@media (max-width: 639px) {
  .edit-my-hotel-group-booking .content main section .edit-rooms-details .edit-rooms-list .edit-room .nav-link {
    font-weight: 500;
    border-top: 0;
  }
}
.edit-my-hotel-group-booking .content main section .edit-rooms-details .edit-rooms-list .edit-room .room-child {
  border-top: 1px solid rgba(0, 0, 0, 0.2);
  padding: 0 20px;
}
@media (max-width: 639px) {
  .edit-my-hotel-group-booking .content main h1.sub {
    font-size: 16px;
    line-height: 24px;
  }
}
@media (min-width: 640px) {
  .edit-my-hotel-group-booking .my-hotel-bookings-buttons {
    border-top: 0;
    margin-left: 120px;
    margin-right: 120px;
  }
}

.date-picker-calendar-wrapper {
  z-index: 10;
  background-color: #FFF;
  border-radius: 0;
  box-shadow: 0px 3px 6px -4px rgba(22, 32, 62, 0.12), 0px 6px 16px 0px rgba(22, 32, 62, 0.08), 0px 9px 28px 8px rgba(22, 32, 62, 0.05);
  padding: 8px;
}
@media (max-width: 639px) {
  .date-picker-calendar-wrapper {
    position: fixed;
    top: 0 !important;
    left: 0 !important;
    width: 100dvw;
    height: 100dvh;
    align-items: center;
  }
}
@media (min-width: 640px) {
  .date-picker-calendar-wrapper {
    position: absolute;
    inset: auto;
    margin-top: 4px;
    width: fit-content;
    height: fit-content;
  }
}

.date-picker-calendar {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
  height: 100%;
}
@media (min-width: 640px) {
  .date-picker-calendar {
    width: fit-content;
    height: fit-content;
  }
}
.date-picker-calendar .months {
  display: flex;
  gap: 24px;
  position: relative;
  overflow: auto;
  width: 100%;
  justify-content: center;
}
.date-picker-calendar .months a {
  position: absolute;
  top: 0;
}
.date-picker-calendar .months a:first-child {
  left: 0;
}
.date-picker-calendar .months a:last-child {
  right: 0;
}
.date-picker-calendar .months a {
  display: none;
}
@media (min-width: 640px) {
  .date-picker-calendar .months a {
    display: block;
  }
}
.date-picker-calendar .months .sections {
  display: flex;
  gap: 16px 24px;
  flex-direction: column;
  justify-content: start;
}
@media (min-width: 640px) {
  .date-picker-calendar .months .sections {
    flex-direction: row;
    justify-content: center;
  }
}
.date-picker-calendar .month {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  row-gap: 4px;
}
.date-picker-calendar .month .month-title {
  grid-column-start: 1;
  grid-column-end: -1;
  text-align: center;
  margin-bottom: 4px;
}
.date-picker-calendar .month .weekday {
  font-size: 14px;
  font-weight: 500;
  line-height: 20px;
  text-align: center;
  color: #5D5D5D;
  margin-bottom: 10px;
}
.date-picker-calendar .month .day {
  font-size: 14px;
  font-weight: 500;
  line-height: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
}
.date-picker-calendar .month .day button {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}
.date-picker-calendar .month .day[data-today] {
  outline: 1px solid #fff;
  outline-offset: -4px;
  border-radius: 8px;
}
.date-picker-calendar .month .day[data-disabled], .date-picker-calendar .month .day[data-temporary-disabled] {
  color: rgba(0, 0, 0, 0.3);
  pointer-events: none;
}
.date-picker-calendar .month .day[data-selected=begin], .date-picker-calendar .month .day[data-selected=end], .date-picker-calendar .month .day[data-selected=single] {
  color: #fff;
  background-color: #333;
}
.date-picker-calendar .month .day[data-selected=begin] {
  border-top-left-radius: 0;
  border-bottom-left-radius: 0;
  border-top-right-radius: 0;
  border-bottom-right-radius: 0;
}
.date-picker-calendar .month .day[data-selected=end] {
  border-top-right-radius: 0;
  border-bottom-right-radius: 0;
  border-top-left-radius: 0;
  border-bottom-left-radius: 0;
}
.date-picker-calendar .month .day[data-selected=single] {
  border-radius: 0;
}
.date-picker-calendar .month .day[data-selected=between] {
  background-color: #333;
}
.date-picker-calendar.availability-calendar [data-availability=full] {
  background-color: #E7E7E7;
  color: #B0B0B0;
}
.date-picker-calendar.availability-calendar [data-availability=some] {
  background-color: #FFF2C2;
  color: #0D0D0D;
}
.date-picker-calendar.availability-calendar [data-availability=free] {
  background-color: #C2F0C9;
  color: #0D0D0D;
}
.date-picker-calendar.availability-calendar .months {
  flex-wrap: wrap;
  border: 1px solid rgba(0, 0, 0, 0.2);
  border-radius: 0;
  padding: 8px;
}
.date-picker-calendar.availability-calendar .months .month {
  gap: 10px 8px;
}
.date-picker-calendar.availability-calendar .months .month .day {
  width: 24px;
  height: 24px;
  border-radius: 4px;
}
.date-picker-calendar.availability-calendar .legend {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  width: 100%;
  margin-top: 16px;
}
.date-picker-calendar.availability-calendar .legend .level {
  display: flex;
  align-items: center;
  gap: 6px;
}
.date-picker-calendar.availability-calendar .legend .marker {
  width: 24px;
  height: 24px;
  border-radius: 4px;
}
.date-picker-calendar.availability-calendar .legend span {
  font-size: 14px;
  font-weight: 500;
  line-height: 20px;
}

.messages {
  position: fixed;
  inset: 0;
  z-index: 50;
  display: flex;
  flex-direction: column;
  align-items: center;
  visibility: hidden;
  padding: 24px 16px;
}
.messages .messages-wrapper {
  justify-content: flex-end;
  display: flex;
  flex-direction: column;
  flex-grow: 1;
  max-width: 42rem;
  width: 100%;
}

.guest-details {
  display: flex;
  flex-direction: column;
  gap: 24px;
  padding: 0 16px;
  margin-top: 4px;
}
@media (min-width: 640px) {
  .guest-details {
    margin-top: 24px;
  }
}
.guest-details section:not(:first-child) {
  border-top: 1px solid rgba(0, 0, 0, 0.2);
  padding-top: 12px;
}
.guest-details section button[type=submit] {
  margin: 20px 0;
}
@media (max-width: 639px) {
  .guest-details section button[type=submit] {
    width: 100%;
  }
}
.guest-details fieldset {
  margin-top: 12px;
  display: grid;
  gap: 16px;
  padding-inline: 0;
  grid-template-columns: 1fr;
}
@media (min-width: 640px) {
  .guest-details fieldset {
    grid-template-columns: 1fr 1fr;
  }
}
.guest-details fieldset .grid-span-2 {
  grid-column-start: span 1;
}
@media (min-width: 640px) {
  .guest-details fieldset .grid-span-2 {
    grid-column-start: span 2;
  }
}
.guest-details button {
  margin-top: 12px;
}
.guest-details section.legal-terms h2 {
  margin-bottom: 12px;
}
.guest-details section.legal-terms a {
  color: #fff;
  text-decoration: underline;
}
.guest-details label > span {
  color: #E0172F;
}

.hotel-bookings-nights-summary {
  border: 1px solid rgba(0, 0, 0, 0.2);
  border-radius: 0;
  padding: 16px;
}
.hotel-bookings-nights-summary ul.dates {
  margin-top: 12px;
  display: flex;
  justify-content: space-between;
}
.hotel-bookings-nights-summary ul.dates li {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.hotel-bookings-nights-summary ul.dates li.divider {
  width: 1px;
  background-color: rgba(0, 0, 0, 0.2);
}

.hotel-bookings-price-details {
  border: 1px solid rgba(0, 0, 0, 0.2);
  border-radius: 0;
  padding: 16px 16px 4px 16px;
}
.hotel-bookings-price-details section {
  padding: 12px 0;
}
.hotel-bookings-price-details section.room, .hotel-bookings-price-details section.vat-and-discount {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.hotel-bookings-price-details section.room .room-name {
  font-weight: 400;
  font-size: 12px;
  line-height: 16px;
}
@media (min-width: 640px) {
  .hotel-bookings-price-details section.room .room-name {
    font-size: 14px;
    line-height: 20px;
  }
}
.hotel-bookings-price-details section.total {
  display: grid;
  grid-template-columns: 1fr auto;
}
.hotel-bookings-price-details section.vat-and-discount, .hotel-bookings-price-details section.total {
  border-top: 1px dashed rgba(0, 0, 0, 0.2);
}
.hotel-bookings-price-details dl {
  display: grid;
  grid-template-columns: 1fr auto;
  font-size: 14px;
  font-weight: 400;
  line-height: 20px;
  gap: 6px;
}
.hotel-bookings-price-details dl dd {
  text-align: right;
}

.rate-plan-card {
  border: 1px solid rgba(0, 0, 0, 0.2);
  border-radius: 0;
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 16px;
  position: relative;
}
@media (max-width: 639px) {
  .rate-plan-card {
    flex-direction: column;
  }
}
.rate-plan-card.selected {
  border-color: #fff;
}
.rate-plan-card.selected button.btn-secondary {
  background-color: #333;
}
.rate-plan-card .info {
  flex: 1;
  position: relative;
}
@media (max-width: 639px) {
  .rate-plan-card .info {
    width: 100%;
  }
}
.rate-plan-card .info .rate-name {
  display: flex;
  align-items: center;
  gap: 4px;
}
@media (max-width: 639px) {
  .rate-plan-card .info .rate-name {
    font-weight: 600;
    font-size: 16px;
    line-height: 24px;
    justify-content: space-between;
    width: 100%;
  }
}
@media (max-width: 639px) and (min-width: 640px) {
  .rate-plan-card .info .rate-name {
    font-size: 18px;
    line-height: 24px;
  }
}
@media (min-width: 640px) {
  .rate-plan-card .info .rate-name {
    font-weight: 600;
    font-size: 14px;
    line-height: 20px;
  }
}
@media (min-width: 640px) and (min-width: 640px) {
  .rate-plan-card .info .rate-name {
    font-size: 16px;
    line-height: 24px;
  }
}
.rate-plan-card .info .rate-name .icon {
  display: flex;
}
@media (max-width: 639px) {
  .rate-plan-card .info .rate-name .icon:first-child {
    display: none;
  }
}
@media (min-width: 640px) {
  .rate-plan-card .info .rate-name .icon:last-child {
    display: none;
  }
}
.rate-plan-card .info ul {
  margin-left: 25px;
  list-style: disc;
  padding-left: 1em;
  color: #4C536A;
}
.rate-plan-card .info ul li {
  font-size: 14px;
  font-weight: 500;
  line-height: 20px;
  display: none;
}
.rate-plan-card .info ul li:first-child {
  display: list-item;
}
.rate-plan-card .price-and-select {
  display: flex;
  align-items: center;
  gap: 16px;
}
@media (max-width: 639px) {
  .rate-plan-card .price-and-select {
    width: 100%;
  }
}
@media (max-width: 639px) {
  .rate-plan-card .price-and-select button {
    width: 100%;
  }
}
.rate-plan-card[data-expanded] .info ul li {
  display: list-item;
}
.rate-plan-card[data-expanded] .rate-name .icon {
  background-color: #E7E7E7;
  border-radius: 4px;
}
.rate-plan-card[data-expanded] .rate-name .icon .i-angle-right {
  rotate: 90deg;
}
.rate-plan-card[data-expanded] .rate-name .icon .i-angle-down {
  rotate: 180deg;
}

.rate-plans {
  display: none;
}
.rate-plans .header {
  display: flex;
  align-items: center;
}
.rate-plans ul.rate-plan-cards {
  margin-top: 20px;
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.rate-plans .btn-icon-color {
  color: rgb(93, 93, 93);
}

.sections[data-expanded] .rate-plans {
  display: block;
}

.rooms-and-guests {
  position: relative;
  z-index: 5;
}
.rooms-and-guests .dropdown-wrapper {
  position: relative;
}
@media (max-width: 639px) {
  .rooms-and-guests[data-expanded] #room-and-guests-dropdown {
    position: fixed;
    top: 0;
    left: 0;
    display: flex;
    flex-direction: column;
    height: 100dvh;
    overflow: auto;
  }
}
@media (min-width: 640px) {
  .rooms-and-guests[data-expanded] #room-and-guests-dropdown {
    position: absolute;
    top: 4px;
    left: 0;
  }
}

#room-and-guests-dropdown {
  width: 100%;
  background-color: #FFF;
  border-radius: 0;
  box-shadow: 0px 3px 6px -4px rgba(22, 32, 62, 0.12), 0px 6px 16px 0px rgba(22, 32, 62, 0.08), 0px 9px 28px 8px rgba(22, 32, 62, 0.05);
  z-index: 20;
  padding: 20px 16px 16px;
}
@media (min-width: 640px) {
  #room-and-guests-dropdown {
    padding: 16px;
  }
}
@media (max-width: 639px) {
  #room-and-guests-dropdown .section-container {
    flex: 1 0;
  }
}
#room-and-guests-dropdown .room-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
#room-and-guests-dropdown section:first-child .room-top button {
  display: none;
}
#room-and-guests-dropdown section {
  display: flex;
  flex-direction: column;
  gap: 8px;
  border-top: 1px solid rgba(0, 0, 0, 0.2);
  padding-top: 20px;
  margin-bottom: 20px;
}
@media (min-width: 640px) {
  #room-and-guests-dropdown section {
    padding-top: 14px;
    margin-bottom: 14px;
  }
}
#room-and-guests-dropdown section:first-child {
  border-top: none;
  padding-top: 0;
}
#room-and-guests-dropdown .adult-row {
  display: flex;
  align-items: center;
}
#room-and-guests-dropdown .adult-row label {
  flex: 1;
}
#room-and-guests-dropdown .child-row {
  display: flex;
  align-items: center;
  gap: 8px;
}
#room-and-guests-dropdown .child-row .select-wrapper {
  flex: 1;
}
#room-and-guests-dropdown .button-section {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
#room-and-guests-dropdown .button-section button {
  flex: 1;
}
#room-and-guests-dropdown .number-input .input-wrapper {
  width: 32px;
  height: 32px;
  padding: 0;
}
#room-and-guests-dropdown .number-input .input-wrapper input {
  text-align: center;
  height: 100%;
}

.hotel-bookings-rooms-summary {
  border: 1px solid rgba(0, 0, 0, 0.2);
  border-radius: 0;
  padding: 16px 16px 4px 16px;
  overflow: clip;
}
.hotel-bookings-rooms-summary ul.rooms {
  margin-top: 12px;
  display: flex;
  flex-direction: column;
}
.hotel-bookings-rooms-summary ul.rooms li {
  position: relative;
  padding: 12px 0;
  border-top: 1px solid rgba(0, 0, 0, 0.2);
}
.hotel-bookings-rooms-summary ul.rooms li .room {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 6px;
  z-index: 1;
}
.hotel-bookings-rooms-summary ul.rooms li .room .room-type-and-rate-plan {
  display: flex;
  gap: 4px;
}
@media (max-width: 639px) {
  .hotel-bookings-rooms-summary ul.rooms li .room .room-type-and-rate-plan {
    flex-direction: column;
  }
}
.hotel-bookings-rooms-summary ul.rooms li .room .room-type-and-rate-plan .nav-link {
  text-decoration: underline;
}
.hotel-bookings-rooms-summary ul.rooms li.selected:before {
  content: "";
  position: absolute;
  top: 0;
  left: -16px;
  width: calc(100% + 32px);
  height: 100%;
  z-index: 0;
  background-color: #333;
}
.hotel-bookings-rooms-summary ul.rooms li .guests-and-amenities {
  display: flex;
  gap: 8px;
  align-items: center;
}
.hotel-bookings-rooms-summary ul.rooms li .amenity {
  display: flex;
  align-items: center;
  gap: 4px;
}

.room-type-card {
  border: 1px solid rgba(0, 0, 0, 0.2);
  border-radius: 0;
  display: flex;
  flex-direction: column;
  flex-wrap: nowrap;
  overflow: hidden;
}
@media (min-width: 640px) {
  .room-type-card {
    height: 411px;
  }
}
.room-type-card.selected {
  border-color: #fff;
}
.room-type-card.selected button {
  background-color: #333;
}
.room-type-card .photo {
  aspect-ratio: 16/9;
  flex: none;
  background-color: rgba(0, 0, 0, 0.2);
  background-size: cover;
  background-position: center;
  background-image: var(--image-url);
}
.room-type-card .info {
  padding: 16px;
  flex: 1;
  display: flex;
  flex-direction: column;
  flex-wrap: nowrap;
  gap: 8px;
  overflow: hidden;
}
.room-type-card .info h3, .room-type-card .info dl, .room-type-card .info a, .room-type-card .info button {
  flex: none;
}
.room-type-card .info button {
  margin-top: 4px;
  text-align: center;
}
.room-type-card .info dl {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  align-items: center;
}
.room-type-card .info dl dd {
  font-size: 14px;
  font-weight: 500;
  line-height: 20px;
  margin-right: 4px;
}
.room-type-card .info dl dt {
  display: flex;
}
.room-type-card .info p {
  font-weight: 400;
  font-size: 12px;
  line-height: 16px;
}
@media (min-width: 640px) {
  .room-type-card .info p {
    font-size: 14px;
    line-height: 20px;
  }
}
.room-type-card .info p {
  flex: 1;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  color: #333;
}

.room-types .header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  margin-bottom: 20px;
  gap: 16px;
}
@media (max-width: 639px) {
  .room-types .header {
    flex-direction: column;
  }
}
.room-types .header .sub {
  margin-bottom: 4px;
}
.room-types .header .count {
  font-weight: 400;
  font-size: 12px;
  line-height: 16px;
}
@media (min-width: 640px) {
  .room-types .header .count {
    font-size: 14px;
    line-height: 20px;
  }
}
.room-types .header .count {
  color: #333;
}
.room-types .amenities {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}
.room-types ul {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
}
@media (max-width: 639px) {
  .room-types ul {
    margin: 0 16px;
    justify-content: center;
  }
}
.room-types ul li {
  width: 100%;
  max-width: 390px;
}

.sections[data-expanded] .room-types {
  display: none;
}

@media (max-width: 639px) {
  .stay-properties {
    border-bottom: 1px solid #d1d1d1;
    padding: 16px;
  }
  .stay-properties .expander {
    display: flex;
    justify-content: space-between;
    width: 100%;
    font-size: 12px;
  }
  .stay-properties .expander span:first-child {
    border-right: 1px solid #d1d1d1;
    padding-right: 6px;
  }
  .stay-properties .expander span:last-child {
    padding-left: 6px;
  }
  .stay-properties[data-expanded] .expander i {
    rotate: 180deg;
  }
  .stay-properties fieldset {
    margin-top: 24px;
    width: 100%;
    padding-inline: 0;
  }
  .stay-properties fieldset .dates {
    margin-bottom: 12px;
  }
  .stay-properties fieldset .guests {
    margin-bottom: 16px;
  }
  .stay-properties fieldset .discount {
    text-align: center;
  }
  .stay-properties fieldset .discount .discount-code-field {
    text-align: start;
    margin-top: 8px;
  }
  .stay-properties fieldset .discount .sub {
    font-weight: 600;
    font-size: 14px;
    line-height: 20px;
    margin: auto;
    display: flex;
    align-items: center;
    gap: 6px;
  }
}
@media (max-width: 639px) and (min-width: 640px) {
  .stay-properties fieldset .discount .sub {
    font-size: 16px;
    line-height: 24px;
  }
}
@media (max-width: 639px) {
  .stay-properties fieldset .discount[data-expanded] .sub {
    color: blue;
  }
  .stay-properties fieldset .discount[data-expanded] .sub i {
    rotate: 180deg;
  }
}
@media (min-width: 640px) {
  .stay-properties {
    padding: 16px 16px 0;
  }
  .stay-properties .expander {
    display: none;
  }
  .stay-properties fieldset {
    padding-inline: 0;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
  }
  .stay-properties fieldset .discount {
    display: none;
  }
}

.room-type-booking-modal {
  max-width: 548px;
  max-height: 100vh;
  overflow: auto;
  padding-top: 4px;
}
@media (min-width: 640px) {
  .room-type-booking-modal {
    width: 548px;
  }
}
.room-type-booking-modal .booking-modal-content {
  padding-bottom: 1.5rem;
  padding-left: 1.5rem;
  padding-right: 1.5rem;
}
@media (max-width: 639px) {
  .room-type-booking-modal .booking-modal-content {
    padding: 0px;
  }
}
.room-type-booking-modal .booking-modal-content header {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.room-type-booking-modal .booking-modal-content header h3 {
  font-size: 32px;
  line-height: 40px;
  font-weight: 500;
}
@media (max-width: 639px) {
  .room-type-booking-modal .booking-modal-content header h3 {
    text-align: center;
    font-size: 17px;
    font-weight: 500;
    line-height: 24px;
  }
}
.room-type-booking-modal .booking-modal-content header .header-content {
  font-weight: 400;
  font-size: 12px;
  line-height: 16px;
}
@media (min-width: 640px) {
  .room-type-booking-modal .booking-modal-content header .header-content {
    font-size: 14px;
    line-height: 20px;
  }
}
.room-type-booking-modal .booking-modal-content header .header-content {
  font-weight: 500;
  display: flex;
  column-gap: 0.75rem;
  row-gap: 0.5rem;
  flex-wrap: wrap;
  color: #000;
}
.room-type-booking-modal .booking-modal-content header .header-content span {
  display: flex;
  align-items: center;
  gap: 0.25rem;
}
.room-type-booking-modal .booking-modal-content header .header-description {
  font-weight: 400;
  font-size: 12px;
  line-height: 16px;
}
@media (min-width: 640px) {
  .room-type-booking-modal .booking-modal-content header .header-description {
    font-size: 14px;
    line-height: 20px;
  }
}
.room-type-booking-modal .booking-modal-content header .header-description {
  color: #333;
}
.room-type-booking-modal .booking-modal-content .desc-with-photo {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
}
@media (max-width: 639px) {
  .room-type-booking-modal .booking-modal-content .desc-with-photo {
    flex-direction: column-reverse;
    gap: 0.75rem;
    padding-right: 1rem;
    padding-left: 1rem;
  }
}
.room-type-booking-modal .booking-modal-content .desc-with-photo .images-slider {
  margin-top: 0px;
}
.room-type-booking-modal .booking-modal-content .amenities {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  padding-top: 1.25rem;
  padding-bottom: 1.25rem;
  padding-right: 1rem;
}
@media (max-width: 639px) {
  .room-type-booking-modal .booking-modal-content .amenities {
    padding: 0.75rem;
    padding-right: 0.5rem;
    padding-left: 1rem;
    gap: 0.75rem;
  }
}
.room-type-booking-modal .booking-modal-content .amenities .amenity {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.room-type-booking-modal .booking-modal-content .amenities .amenity h5 {
  font-weight: 600;
  font-size: 14px;
  line-height: 20px;
}
@media (min-width: 640px) {
  .room-type-booking-modal .booking-modal-content .amenities .amenity h5 {
    font-size: 16px;
    line-height: 24px;
  }
}
.room-type-booking-modal .booking-modal-content .amenities .amenity h5 {
  display: flex;
  align-items: center;
  gap: 0.375rem;
}
.room-type-booking-modal .booking-modal-content .amenities .amenity ul {
  font-weight: 400;
  font-size: 12px;
  line-height: 16px;
}
@media (min-width: 640px) {
  .room-type-booking-modal .booking-modal-content .amenities .amenity ul {
    font-size: 14px;
    line-height: 20px;
  }
}
.room-type-booking-modal .booking-modal-content .amenities .amenity ul {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  color: #0D0D0D;
}
.room-type-booking-modal .button-container {
  display: flex;
  justify-content: flex-end;
  padding: 1rem 1.5rem;
  border-top-width: 1px;
  border-color: rgb(229, 229, 229);
}

.rate-plan-booking-modal {
  min-width: 600px;
  padding: 16px 24px 24px 24px;
  min-height: 160px;
  overflow: auto;
  max-height: 100vh;
  color: #000;
}
@media (max-width: 639px) {
  .rate-plan-booking-modal {
    min-width: 320px;
    padding: 0px;
  }
}
.rate-plan-booking-modal h3 {
  font-size: 24px;
  line-height: 32px;
  font-weight: 500;
  margin-bottom: 4px;
}
@media (max-width: 639px) {
  .rate-plan-booking-modal h3 {
    min-height: 48px;
    border-bottom: 1px solid rgba(0, 0, 0, 0.2);
    padding-left: 14px;
    padding-right: 14px;
    text-align: center;
    color: #000;
    font-size: 17px;
    line-height: 24px;
    font-weight: 500;
  }
}
.rate-plan-booking-modal h5 {
  padding-bottom: 8px;
  font-size: 16px;
  font-weight: 600;
  line-height: 24px;
}
@media (max-width: 639px) {
  .rate-plan-booking-modal h5 {
    padding: 20px 16px 8px 16px;
  }
}
.rate-plan-booking-modal ul {
  font-size: 14px;
  font-weight: 400;
  line-height: 20px;
  list-style-type: disc;
  list-style-position: inside;
}
@media (max-width: 639px) {
  .rate-plan-booking-modal ul {
    color: #4C536A;
    padding: 0px 16px 20px 16px;
    list-style-position: outside;
    margin-left: 16px;
  }
}

.booking-successful {
  display: flex;
  flex-direction: column;
  flex: 1 0;
  align-items: center;
  justify-content: center;
  padding: 30px;
  text-align: center;
}
.booking-successful i {
  color: #5BCD6F;
  margin-bottom: 16px;
  font-size: 70px;
}
@media (min-width: 640px) {
  .booking-successful i {
    margin-bottom: 24px;
    font-size: 86px;
  }
}
.booking-successful h2 {
  font-weight: 500;
  font-size: 24px;
  line-height: 32px;
}
@media (min-width: 640px) {
  .booking-successful h2 {
    font-size: 36px;
    line-height: 48px;
  }
}
.booking-successful h2 {
  font-family: "Playfair Display", serif;
  margin-bottom: 8px;
}
.booking-successful .content {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  margin-bottom: 24px;
}
.booking-successful .content .what {
  margin-top: 16px;
}
.booking-successful .content .welcome {
  font-weight: 400;
  font-size: 14px;
  line-height: 20px;
}
@media (min-width: 640px) {
  .booking-successful .content .welcome {
    font-size: 16px;
    line-height: 24px;
  }
}
.booking-successful .content .dates {
  font-weight: 500;
  font-size: 14px;
  line-height: 20px;
}
@media (min-width: 640px) {
  .booking-successful .content .dates {
    font-size: 16px;
    line-height: 24px;
  }
}
.booking-successful .content .information-sent {
  font-weight: 400;
  font-size: 14px;
  line-height: 20px;
}
@media (min-width: 640px) {
  .booking-successful .content .information-sent {
    font-size: 16px;
    line-height: 24px;
  }
}
.booking-successful .content .information-sent b {
  font-weight: 500;
  font-size: 14px;
  line-height: 20px;
}
@media (min-width: 640px) {
  .booking-successful .content .information-sent b {
    font-size: 16px;
    line-height: 24px;
  }
}
.booking-successful .content .payment {
  font-weight: 400;
  font-size: 14px;
  line-height: 20px;
}
@media (min-width: 640px) {
  .booking-successful .content .payment {
    font-size: 16px;
    line-height: 24px;
  }
}

.hotel-services {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
@media (max-width: 639px) {
  .hotel-services {
    gap: 12px;
  }
}
.hotel-services .services-count {
  display: none;
}
@media (max-width: 639px) {
  .hotel-services .services-count {
    display: block;
  }
}
.hotel-services ul {
  display: grid;
  flex-wrap: wrap;
  gap: 16px;
}
@media (min-width: 640px) {
  .hotel-services ul {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    min-width: 500px;
  }
}
.hotel-services .header {
  display: flex;
  align-items: center;
  margin-bottom: 4px;
}
.hotel-services .header h1 {
  flex: 1;
}
@media (max-width: 639px) {
  .hotel-services .header h1 {
    font-size: 16px;
    display: flex;
  }
}
.hotel-services .header button {
  margin-top: 0;
  color: #333;
  gap: 6px;
  font-weight: 500;
  font-size: 14px;
  line-height: 20px;
}
@media (min-width: 640px) {
  .hotel-services .header button {
    font-size: 16px;
    line-height: 24px;
  }
}
@media (max-width: 639px) {
  .hotel-services .header button span {
    font-size: 14px;
    font-weight: 500;
    line-height: 20px;
  }
}
.hotel-services .toggle-btn {
  display: none;
}
.hotel-services ul li[data-hidden-services-on-desktop] {
  display: none;
}
@media (max-width: 639px) {
  .hotel-services ul li[data-hidden-services-on-mobile] {
    display: none;
  }
}
.hotel-services[data-show-btn-on-desktop] .toggle-btn {
  display: block;
}
@media (max-width: 639px) {
  .hotel-services[data-show-btn-on-mobile] .toggle-btn {
    display: block;
  }
}
.hotel-services[data-expanded][data-show-btn-on-desktop] [data-hidden-services-on-desktop] {
  display: block;
}
@media (max-width: 639px) {
  .hotel-services[data-expanded][data-show-btn-on-mobile] [data-hidden-services-on-mobile] {
    display: block;
  }
}

.hotel-services[data-expanded] .not-expanded {
  display: none;
}
.hotel-services[data-expanded] .expanded {
  display: block;
}

.service-card {
  border: 1px solid rgba(0, 0, 0, 0.2);
  border-radius: 8px;
  display: grid;
  grid-template-columns: 1fr 2fr;
}
@media (min-width: 640px) {
  .service-card {
    display: grid;
    grid-template-rows: 2fr 2fr;
    grid-template-columns: none;
    border: 1px solid rgba(0, 0, 0, 0.2);
    border-radius: 8px;
    height: 100%;
  }
}
.service-card .detail {
  display: flex;
  flex-direction: column;
  height: 100%;
  padding: 16px;
  gap: 12px;
}
@media (max-width: 639px) {
  .service-card .detail {
    padding: 16px;
  }
}
.service-card .photo {
  background-color: rgba(0, 0, 0, 0.2);
  background-position: center;
  background-size: cover;
  background-image: var(--image-url);
  border-radius: 8px 8px 0px 0px;
}
@media (max-width: 639px) {
  .service-card .photo {
    border-radius: 8px 0px 0px 8px;
  }
}
.service-card .info {
  flex: 1;
  display: flex;
  flex-direction: column;
  flex-wrap: nowrap;
  flex-grow: 1;
  gap: 4px;
}
.service-card .info h4 {
  font-size: 14px;
  line-height: 20px;
  font-weight: 600;
  color: #000;
}
.service-card .info .desc {
  color: #333;
  font-weight: 400;
  font-size: 12px;
  line-height: 16px;
}
@media (min-width: 640px) {
  .service-card .info .desc {
    font-size: 14px;
    line-height: 20px;
  }
}
.service-card .add-button {
  display: flex;
  flex-direction: column;
}
.service-card .add-button button {
  text-align: center;
  width: 100%;
}
@media (max-width: 639px) {
  .service-card .add-button button {
    padding: 8px 16px;
  }
}
@media (max-width: 639px) {
  .service-card .add-button input[type=checkbox] {
    width: 20px;
    height: 20px;
  }
}
.service-card .service-rooms-list {
  position: relative;
}
.service-card .service-rooms-list .service-rooms {
  display: flex;
  flex-direction: column;
  position: absolute;
  z-index: 10;
  background-color: #FFF;
  box-shadow: 0px 3px 6px -4px rgba(22, 32, 62, 0.12), 0px 6px 16px 0px rgba(22, 32, 62, 0.08), 0px 9px 28px 8px rgba(22, 32, 62, 0.05);
  border-radius: 8px;
  border-color: #FFF;
  width: 100%;
  top: 4px;
  min-width: 555px;
}
@media (max-width: 639px) {
  .service-card .service-rooms-list .service-rooms {
    position: fixed;
    top: 0;
    left: 0;
    display: flex;
    flex-direction: column;
    height: 100dvh;
    min-width: auto;
  }
}
.service-card .service-rooms-list .service-rooms .section-container {
  flex-direction: column;
  display: flex;
  padding: 8px 4px 8px 8px;
  gap: 4px;
}
@media (max-width: 639px) {
  .service-card .service-rooms-list .service-rooms .section-container {
    flex-grow: 1;
    padding: 0px 16px 0 16px;
  }
}
.service-card .service-rooms-list .service-rooms .service-all {
  padding: 8px;
}
@media (max-width: 639px) {
  .service-card .service-rooms-list .service-rooms .service-all {
    padding: 0px;
  }
}
.service-card .service-rooms-list .service-rooms .service-room {
  display: flex;
  padding: 8px;
  gap: 4px;
}
@media (max-width: 639px) {
  .service-card .service-rooms-list .service-rooms .service-room {
    padding: 0px;
    gap: 0px;
    padding-bottom: 20px;
  }
}
.service-card .service-rooms-list .service-rooms .service-room .room-name-and-type {
  color: #000;
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
@media (max-width: 639px) {
  .service-card .service-rooms-list .service-rooms .service-room .room-name-and-type {
    font-size: 14px;
    font-weight: 500;
    line-height: 20px;
  }
}
.service-card .service-rooms-list .service-rooms .service-room .room-name-and-type .room-name {
  font-weight: 500;
  font-size: 14px;
  line-height: 20px;
}
@media (min-width: 640px) {
  .service-card .service-rooms-list .service-rooms .service-room .room-name-and-type .room-name {
    font-size: 16px;
    line-height: 24px;
  }
}
.service-card .service-rooms-list .service-rooms .service-room .room-name-and-type .rooms-with-checkboxes {
  display: flex;
}
.service-card .service-rooms-list .service-rooms .row {
  display: flex;
  flex-direction: row;
  align-items: center;
}
.service-card .service-rooms-list .service-rooms .label {
  font-weight: 500;
  font-size: 14px;
  line-height: 20px;
}
@media (min-width: 640px) {
  .service-card .service-rooms-list .service-rooms .label {
    font-size: 16px;
    line-height: 24px;
  }
}
.service-card .service-rooms-list .service-rooms .label {
  flex: 1;
  display: flex;
  justify-content: space-between;
}
.service-card .service-rooms-list .service-rooms .guests-and-amenities {
  font-weight: 400;
  font-size: 12px;
  line-height: 16px;
}
@media (min-width: 640px) {
  .service-card .service-rooms-list .service-rooms .guests-and-amenities {
    font-size: 14px;
    line-height: 20px;
  }
}
.service-card .service-rooms-list .service-rooms .guests-and-amenities {
  font-weight: 500;
}
.service-card .service-rooms-list .service-rooms .room-type {
  font-weight: 400;
  font-size: 12px;
  line-height: 16px;
}
@media (min-width: 640px) {
  .service-card .service-rooms-list .service-rooms .room-type {
    font-size: 14px;
    line-height: 20px;
  }
}
.service-card .service-rooms-list .service-rooms .room-type {
  color: #333;
  font-weight: 500;
}
.service-card .service-rooms-list .service-rooms .number-input-with-checkbox {
  display: flex;
  gap: 8px;
  align-items: center;
}
@media (max-width: 639px) {
  .service-card .service-rooms-list .service-rooms .number-input-with-checkbox {
    gap: 0px;
  }
}
@media (max-width: 639px) {
  .service-card .service-rooms-list .bottom-separator {
    border-top: 1px solid rgba(0, 0, 0, 0.2);
    margin: 0 -16px 0 -16px;
  }
}
.service-card .service-rooms-list .add-service-button {
  display: flex;
  margin: 16px;
  width: auto;
}
@media (min-width: 640px) {
  .service-card .service-rooms-list .add-service-button {
    align-self: end;
  }
}
.service-card .service-rooms-list .guests-and-amenities {
  display: flex;
  gap: 12px;
  color: #333;
}
@media (max-width: 639px) {
  .service-card .service-rooms-list .guests-and-amenities .amenity {
    display: none;
  }
}
.service-card .service-rooms-list .number-input button {
  margin-top: 0;
  width: auto;
}
.service-card .service-rooms-list .number-input .input-wrapper {
  width: 32px;
  height: 32px;
}
@media (min-width: 640px) {
  .service-card .service-rooms-list .mobile-view {
    display: none;
  }
}
.service-card .service-rooms-list .mobile-view .photo {
  height: 110px;
}
.service-card .service-rooms-list .mobile-view .dropdown-header {
  display: flex;
  justify-content: space-between;
  padding: 0 14px;
  border-bottom: 1px solid rgba(0, 0, 0, 0.2);
  align-items: center;
}
.service-card .service-rooms-list .mobile-view .dropdown-header a {
  color: #333;
}
.service-card .service-rooms-list .mobile-view .dropdown-header button {
  padding: 0;
  width: auto;
  color: #5D5D5D;
}
.service-card .service-rooms-list .mobile-view .dropdown-header .sub {
  font-size: 17px;
  font-weight: 500;
  text-wrap: nowrap;
  line-height: 24px;
}
.service-card .service-rooms-list .mobile-view .service-desc {
  display: grid;
  grid-template-columns: 1fr 2fr;
  border: 1px solid rgba(0, 0, 0, 0.2);
  border-radius: 0;
  margin: 20px 16px;
}
.service-card .service-rooms-list .mobile-view .service-desc .detail {
  padding: 16px;
  gap: 4px;
  display: flex;
  flex-direction: column;
}

.hotel-bookings-legal-terms {
  display: flex;
  flex-direction: column;
  flex: 1 0;
  gap: 16px;
  padding: 32px;
}
.hotel-bookings-legal-terms .title {
  padding: 16px 0 12px;
}
.hotel-bookings-legal-terms .title h1 {
  font-weight: 500;
  font-size: 28px;
  line-height: 36px;
}
@media (min-width: 640px) {
  .hotel-bookings-legal-terms .title h1 {
    font-size: 48px;
    line-height: 56px;
  }
}
.hotel-bookings-legal-terms .content {
  font-weight: 400;
  font-size: 12px;
  line-height: 16px;
}
@media (min-width: 640px) {
  .hotel-bookings-legal-terms .content {
    font-size: 14px;
    line-height: 20px;
  }
}

.topbar-small {
  height: 64px;
  position: relative;
  border-bottom: 1px solid #d1d1d1;
}
.topbar-small .responsive-container {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 8px;
}

footer {
  display: flex;
  flex-direction: column;
  gap: 24px;
  padding: 24px 16px;
  border-top: 1px solid #d1d1d1;
}
footer .contact {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
footer .contact h3 {
  font-weight: 600;
}

.modal {
  position: fixed;
  width: 100%;
  top: 0;
  z-index: 50;
}
.modal.transition-enter {
  transition-timing-function: cubic-bezier(0, 0, 0.2, 1);
  transition-duration: 300ms;
}
.modal.transition-enter-start {
  opacity: 0;
}
.modal.transition-enter-end {
  opacity: 1;
}
.modal.transition-leave {
  transition-timing-function: cubic-bezier(0.4, 0, 1, 1);
  transition-duration: 200ms;
}
.modal.transition-leave-start {
  opacity: 1;
}
.modal.transition-leave-end {
  opacity: 0;
}
.modal .modal-wrapper-1 {
  position: fixed;
  inset: 0px;
  background-color: rgba(22, 32, 62, 0.75);
  transition-duration: 0.15s;
  transition-property: opacity;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
}
.modal .modal-wrapper-2 {
  display: flex;
  height: 100vh;
  align-items: center;
  justify-content: center;
  padding: 0;
  text-align: center;
  flex-direction: column;
}
@media (min-width: 640px) {
  .modal .modal-wrapper-2 {
    align-items: center;
    flex-direction: row;
  }
}
.modal .modal-wrapper-3 {
  position: relative;
  transform: translate(0, 0 0 0 0 1 1);
  overflow: hidden;
  border-radius: 0.625rem;
  background-color: rgb(255, 255, 255);
  text-align: left;
  box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1019607843), 0 8px 10px -6px rgba(0, 0, 0, 0.1019607843);
  transition-duration: 0.15s;
  transition-property: all;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
}
@media (max-width: 639px) {
  .modal .modal-wrapper-3 {
    width: 100%;
    border-bottom-left-radius: 0;
    border-bottom-right-radius: 0;
    margin-top: auto;
  }
}
@media (min-width: 640px) {
  .modal .modal-wrapper-3 {
    margin-bottom: 2rem;
    margin-top: 2rem;
    min-width: 0;
    max-width: 56rem;
  }
}
.modal .modal-wrapper-3.transition-enter-start, .modal .modal-wrapper-3.transition-leave-end {
  opacity: 0;
  transform: translateX(1rem);
}
@media (min-width: 640px) {
  .modal .modal-wrapper-3.transition-enter-start, .modal .modal-wrapper-3.transition-leave-end {
    transform: translateX(0px) scale(0.95);
  }
}
.modal .modal-wrapper-3.transition-enter-end, .modal .modal-wrapper-3.transition-leave-start {
  opacity: 1;
  transform: translateX(0px);
}
@media (min-width: 640px) {
  .modal .modal-wrapper-3.transition-enter-end, .modal .modal-wrapper-3.transition-leave-start {
    transform: translateX(0px) scale(1);
  }
}
.modal .close-container {
  position: relative;
  padding-top: 1.25rem;
}
.modal .close-container .close {
  position: absolute;
  right: 1rem;
}

.cancel-booking-modal {
  max-width: 680px;
  max-height: 100vh;
  overflow: auto;
}
@media (min-width: 640px) {
  .cancel-booking-modal {
    width: 548px;
  }
}
.cancel-booking-modal .body {
  padding: 0 24px 24px 24px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.cancel-booking-modal .body h1 {
  font-size: 24px;
  line-height: 32px;
  font-weight: 500;
}
.cancel-booking-modal .body .desc {
  font-weight: 400;
  font-size: 14px;
  line-height: 20px;
}
@media (min-width: 640px) {
  .cancel-booking-modal .body .desc {
    font-size: 16px;
    line-height: 24px;
  }
}
.cancel-booking-modal .body .desc {
  color: #333;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.cancel-booking-modal .body .desc .payment-info {
  display: grid;
  grid-template-columns: 1fr 1fr;
  column-gap: 12px;
  row-gap: 8px;
  max-width: 350px;
}
.cancel-booking-modal .body .desc .payment-info .value {
  font-weight: 600;
  text-align: right;
}
.cancel-booking-modal .footer {
  display: flex;
  justify-content: end;
  padding: 16px 24px;
  border-top: 1px solid rgba(0, 0, 0, 0.2);
  align-items: center;
  gap: 16px;
}
@media (max-width: 639px) {
  .cancel-booking-modal .footer {
    flex-direction: column-reverse;
    padding: 16px 16px 12px 16px;
    gap: 8px;
  }
}
@media (max-width: 639px) {
  .cancel-booking-modal .footer button {
    width: 100%;
  }
}

.restaurant-booking-not-bookable main {
  font-weight: 400;
  font-size: 14px;
  line-height: 20px;
}
@media (min-width: 640px) {
  .restaurant-booking-not-bookable main {
    font-size: 16px;
    line-height: 24px;
  }
}
.restaurant-booking-not-bookable main {
  color: #000;
  text-align: center;
  margin-top: 24px;
}
@media (min-width: 640px) {
  .restaurant-booking-not-bookable main {
    margin-top: 18vh;
  }
}
.restaurant-booking-not-bookable main h1 {
  margin-bottom: 24px;
}
.restaurant-booking-not-bookable main h3 {
  margin-bottom: 8px;
}
.restaurant-booking-not-bookable main p {
  margin-bottom: 4px;
}
.restaurant-booking-not-bookable main p.date {
  font-weight: 500;
  font-size: 14px;
  line-height: 20px;
}
@media (min-width: 640px) {
  .restaurant-booking-not-bookable main p.date {
    font-size: 16px;
    line-height: 24px;
  }
}
.restaurant-booking-not-bookable main .message {
  margin: 16px 0;
}
.restaurant-booking-not-bookable main .contact {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.restaurant-booking-not-bookable main .contact li a {
  font-weight: 500;
  font-size: 14px;
  line-height: 20px;
}
@media (min-width: 640px) {
  .restaurant-booking-not-bookable main .contact li a {
    font-size: 16px;
    line-height: 24px;
  }
}
.restaurant-booking-not-bookable main .contact li a {
  text-decoration: underline;
}

.restaurant-booking-new .main-title, .restaurant-booking-new .stepper {
  display: none;
}
.restaurant-booking-new .form-container {
  width: 100%;
  padding: 16px;
}
@media (min-width: 768px) {
  .restaurant-booking-new {
    padding: 0 16px;
  }
  .restaurant-booking-new .form-container {
    padding: 0;
  }
  .restaurant-booking-new .main-title {
    display: flex;
    margin: 20px 0;
  }
  .restaurant-booking-new .stepper {
    display: flex;
  }
  .restaurant-booking-new .content {
    display: flex;
    flex-direction: row-reverse;
    gap: 24px;
  }
}
@media (min-width: 768px) {
  .restaurant-booking-new .content {
    gap: 36px;
  }
}
@media (min-width: 1024px) {
  .restaurant-booking-new .content {
    gap: 78px;
  }
}
.restaurant-booking-new .stepper {
  margin-bottom: 24px;
}

.restaurang-bookings-step-title {
  margin: 0 0 4px 0;
  font-weight: 600;
  font-size: 14px;
  line-height: 20px;
}
@media (min-width: 640px) {
  .restaurang-bookings-step-title {
    font-size: 16px;
    line-height: 24px;
  }
}

.restaurant-booking-summary {
  padding: 8px 0;
  border-bottom: 1px solid rgba(0, 0, 0, 0.2);
}
.restaurant-booking-summary h3 {
  text-align: center;
  margin-bottom: 4px;
}
.restaurant-booking-summary ul {
  display: flex;
  justify-content: center;
}
.restaurant-booking-summary ul li {
  text-align: center;
  margin-left: 6px;
  padding-right: 6px;
  border-right: 1px solid rgba(0, 0, 0, 0.2);
}
.restaurant-booking-summary ul li:last-child {
  border-right: none;
}
.restaurant-booking-summary ul li .icon {
  display: none;
}
.restaurant-booking-summary ul li h4 {
  font-weight: 400;
  font-size: 12px;
  line-height: 16px;
}
@media (min-width: 640px) {
  .restaurant-booking-summary ul li h4 {
    font-size: 14px;
    line-height: 20px;
  }
}
.restaurant-booking-summary ul li h4 {
  color: rgba(0, 0, 0, 0.3);
  display: none;
}
.restaurant-booking-summary ul li p {
  font-size: 14px;
  font-weight: 500;
  line-height: 20px;
}
.restaurant-booking-summary ul li.empty h4 {
  display: unset;
}
@media (min-width: 768px) {
  .restaurant-booking-summary {
    width: 328px;
    height: max-content;
    padding: 16px 16px 8px 16px;
    border: 1px solid rgba(0, 0, 0, 0.2);
    border-radius: 0;
  }
  .restaurant-booking-summary h3 {
    text-align: left;
    margin-bottom: 8px;
  }
  .restaurant-booking-summary ul {
    flex-direction: column;
    justify-content: begin;
  }
  .restaurant-booking-summary ul h4 {
    font-weight: 600;
    font-size: 14px;
    line-height: 20px;
    color: #000;
    margin-bottom: 6px;
  }
}
@media (min-width: 768px) and (min-width: 640px) {
  .restaurant-booking-summary ul h4 {
    font-size: 16px;
    line-height: 24px;
  }
}
@media (min-width: 768px) {
  .restaurant-booking-summary ul li {
    text-align: left;
    margin-left: 0;
    padding: 12px 0;
    border-top: 1px solid rgba(0, 0, 0, 0.2);
    border-right: none;
  }
  .restaurant-booking-summary ul li:first-child {
    border-top: none;
    padding-top: 0;
  }
  .restaurant-booking-summary ul li p {
    display: flex;
    align-items: center;
  }
  .restaurant-booking-summary ul li span.icon {
    display: inline-block;
    margin-right: 4px;
  }
  .restaurant-booking-summary ul li.empty {
    display: none;
  }
}

.restaurant-bookings-select-nb-guests {
  margin-top: 12px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  max-width: 689px;
}
.restaurant-bookings-select-nb-guests li {
  height: 40px;
}
.restaurant-bookings-select-nb-guests li button {
  width: 100%;
  height: 100%;
}
@media (min-width: 768px) {
  .restaurant-bookings-select-nb-guests {
    gap: 16px;
  }
  .restaurant-bookings-select-nb-guests li {
    height: 80px;
  }
}

.restaurant-bookings-notifications, .take-away-bookings-notifications {
  padding: 10px 12px 12px 12px;
  border: 1px solid rgba(0, 0, 0, 0.2);
  border-radius: 0;
  display: flex;
  flex-direction: column;
  gap: 16px;
  margin-bottom: 24px;
}
.restaurant-bookings-notifications h4, .take-away-bookings-notifications h4 {
  margin-bottom: 2px;
}

.take-away-bookings-notifications {
  margin-top: 10px;
}

.take-away-bookings-menu {
  margin-bottom: 16px;
}
.take-away-bookings-menu li {
  display: flex;
  align-items: start;
  margin-bottom: 24px;
}
.take-away-bookings-menu li .number-input {
  margin-top: 24px;
}
.take-away-bookings-menu p.description {
  font-style: italic;
}
.take-away-bookings-menu p.allergens {
  font-weight: 400;
  font-size: 12px;
  line-height: 16px;
}
@media (min-width: 640px) {
  .take-away-bookings-menu p.allergens {
    font-size: 14px;
    line-height: 20px;
  }
}
.take-away-bookings-menu p.allergens {
  margin: 8px 0;
}
.take-away-bookings-menu p.price {
  font-weight: 500;
  font-size: 14px;
  line-height: 20px;
}
@media (min-width: 640px) {
  .take-away-bookings-menu p.price {
    font-size: 16px;
    line-height: 24px;
  }
}
.take-away-bookings-menu p.price {
  text-align: right;
}

.restaurant-bookings-select-time-slot h4.gig-name {
  margin-bottom: 8px;
  font-weight: 400;
  font-size: 14px;
  line-height: 20px;
}
@media (min-width: 640px) {
  .restaurant-bookings-select-time-slot h4.gig-name {
    font-size: 16px;
    line-height: 24px;
  }
}
.restaurant-bookings-select-time-slot ul.time-slots {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  margin-bottom: 24px;
}
.restaurant-bookings-select-time-slot ul.time-slots li {
  width: 82px;
}
.restaurant-bookings-select-time-slot ul.time-slots li button {
  width: 100%;
  display: flex;
  flex-direction: column;
}
.restaurant-bookings-select-time-slot ul.time-slots li.wide {
  width: 160px;
}
.restaurant-bookings-select-time-slot ul.time-slots li .time {
  font-weight: 600;
  font-size: 14px;
  line-height: 20px;
}
@media (min-width: 640px) {
  .restaurant-bookings-select-time-slot ul.time-slots li .time {
    font-size: 16px;
    line-height: 24px;
  }
}
.restaurant-bookings-select-time-slot ul.time-slots li .price {
  font-size: 14px;
  font-weight: 500;
  line-height: 20px;
}

.restaurant-bookings-guest-details fieldset {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
@media (min-width: 768px) {
  .restaurant-bookings-guest-details fieldset {
    display: grid;
    grid-template-columns: 1fr 1fr;
  }
}
.restaurant-bookings-guest-details .colspan-2 {
  grid-column: span 2;
}
.restaurant-bookings-guest-details .booking-comment {
  font-weight: 400;
  font-size: 12px;
  line-height: 16px;
}
@media (min-width: 640px) {
  .restaurant-bookings-guest-details .booking-comment {
    font-size: 14px;
    line-height: 20px;
  }
}
.restaurant-bookings-guest-details .booking-comment {
  margin-top: 6px;
  color: #333;
}
.restaurant-bookings-guest-details .consent {
  font-weight: 400;
  font-size: 14px;
  line-height: 20px;
}
@media (min-width: 640px) {
  .restaurant-bookings-guest-details .consent {
    font-size: 16px;
    line-height: 24px;
  }
}
.restaurant-bookings-guest-details .consent {
  margin-top: 16px;
}
.restaurant-bookings-guest-details .submit {
  margin-top: 16px;
  padding-top: 16px;
  border-top: 1px solid rgba(0, 0, 0, 0.2);
}
.restaurant-bookings-guest-details .submit button {
  width: 100%;
}
@media (min-width: 768px) {
  .restaurant-bookings-guest-details .submit {
    display: flex;
    justify-content: end;
    border-top: none;
  }
  .restaurant-bookings-guest-details .submit button {
    width: max-content;
  }
}

.visually-hidden:not(:focus):not(:active) {
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0, 0, 0, 0) !important;
  white-space: nowrap !important;
  border: 0 !important;
}

.hidden {
  display: none;
}

.with-counter-1 {
  counter-reset: index1-number 0;
}

.increment-counter-1 {
  counter-increment: index1-number 1;
}

.counter-1-value:before {
  content: counter(index1-number);
}

.with-counter-2 {
  counter-reset: index2-number 0;
}

.increment-counter-2 {
  counter-increment: index2-number 1;
}

.counter-2-value:before {
  content: counter(index2-number);
}

.responsive-container {
  width: 100%;
  margin: 0 auto;
}
@media (min-width: 640px) {
  .responsive-container {
    max-width: 640px;
  }
}
@media (min-width: 768px) {
  .responsive-container {
    max-width: 768px;
  }
}
@media (min-width: 1024px) {
  .responsive-container {
    max-width: 1024px;
  }
}
@media (min-width: 1280px) {
  .responsive-container {
    max-width: 1280px;
  }
}
@media (min-width: 1536px) {
  .responsive-container {
    max-width: 1536px;
  }
}

.hotel-booking-landing-page {
  flex: 1;
  background-color: #FFFCE5;
}
.hotel-booking-landing-page .layout {
  width: 80%;
  margin: 56px auto 96px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 24px;
}
.hotel-booking-landing-page .layout h1 {
  color: white;
  text-align: center;
}
.hotel-booking-landing-page .center-box {
  background-color: white;
  border-radius: 0;
  box-shadow: 0px 3px 6px -4px rgba(22, 32, 62, 0.12), 0px 6px 16px 0px rgba(22, 32, 62, 0.08), 0px 9px 28px 8px rgba(22, 32, 62, 0.05);
  width: 100%;
  padding: 16px;
}
@media (min-width: 640px) {
  .hotel-booking-landing-page .center-box {
    padding: 24px 16px;
  }
}
.hotel-booking-landing-page fieldset.main {
  display: grid;
  align-items: end;
  gap: 16px;
  grid-template-columns: 1fr;
}
@media (min-width: 640px) {
  .hotel-booking-landing-page fieldset.main {
    grid-template-columns: 1fr 1fr auto;
  }
}
.hotel-booking-landing-page .discount {
  display: flex;
  flex-direction: column;
  gap: 16px;
  align-items: center;
  margin: 8px auto 0;
}
@media (max-width: 640px) {
  .hotel-booking-landing-page .discount {
    width: 100%;
  }
}
@media (min-width: 640px) {
  .hotel-booking-landing-page .discount {
    order: 1;
    grid-column: 1/3;
  }
}
.hotel-booking-landing-page .discount .sub {
  font-weight: 600;
  font-size: 14px;
  line-height: 20px;
}
@media (min-width: 640px) {
  .hotel-booking-landing-page .discount .sub {
    font-size: 16px;
    line-height: 24px;
  }
}
.hotel-booking-landing-page .discount .sub {
  display: flex;
  gap: 6px;
  align-items: center;
  padding: 8px;
  cursor: pointer;
}
@media (max-width: 639px) {
  .hotel-booking-landing-page .discount .sub i:first-child {
    display: none !important;
  }
}
@media (min-width: 640px) {
  .hotel-booking-landing-page .discount .sub i:not(:first-child) {
    display: none !important;
  }
}
.hotel-booking-landing-page .discount[data-expanded] .sub {
  color: blue;
}
.hotel-booking-landing-page .discount[data-expanded] .sub i {
  rotate: 180deg;
}
.hotel-booking-landing-page .discount[data-expanded] .sub i.hidden {
  display: block;
}
.hotel-booking-landing-page .discount .discount-code-field {
  width: 100%;
  max-width: 416px;
}

.maintenance-message {
  font-size: 30px;
  align-self: center;
  margin: auto;
}

@media (max-width: 1023px) {
  .hotel-booking-title {
    display: none;
  }
}
.hotel-booking-title {
  margin-top: 16px;
  margin-bottom: 16px;
  margin-left: 16px;
}

.hotel-booking-form {
  overflow-y: auto;
  flex: 1;
  display: flex;
  flex-direction: column;
}

.hotel-booking-container {
  width: 100%;
  margin: 0 auto;
}
@media (min-width: 640px) {
  .hotel-booking-container {
    max-width: 640px;
  }
}
@media (min-width: 768px) {
  .hotel-booking-container {
    max-width: 768px;
  }
}
@media (min-width: 1024px) {
  .hotel-booking-container {
    max-width: 1024px;
  }
}
@media (min-width: 1280px) {
  .hotel-booking-container {
    max-width: 1280px;
  }
}
@media (min-width: 1536px) {
  .hotel-booking-container {
    max-width: 1536px;
  }
}
.hotel-booking-container {
  display: flex;
  flex-direction: column;
  overflow-y: auto;
  flex: 1;
}

.hotel-booking-navbar-container {
  border-top: 1px solid rgba(0, 0, 0, 0.2);
}

.hotel-booking-navbar {
  width: 100%;
  margin: 0 auto;
}
@media (min-width: 640px) {
  .hotel-booking-navbar {
    max-width: 640px;
  }
}
@media (min-width: 768px) {
  .hotel-booking-navbar {
    max-width: 768px;
  }
}
@media (min-width: 1024px) {
  .hotel-booking-navbar {
    max-width: 1024px;
  }
}
@media (min-width: 1280px) {
  .hotel-booking-navbar {
    max-width: 1280px;
  }
}
@media (min-width: 1536px) {
  .hotel-booking-navbar {
    max-width: 1536px;
  }
}
.hotel-booking-navbar {
  display: flex;
  justify-content: flex-end;
  gap: 16px;
  padding: 20px;
}
@media (max-width: 1023px) {
  .hotel-booking-navbar {
    flex-direction: column-reverse;
  }
}

.hotel-booking-layout {
  flex: 1;
  overflow-y: auto;
  display: grid;
}
.hotel-booking-layout main {
  margin-bottom: 48px;
}
@media (max-width: 1023px) {
  .hotel-booking-layout {
    grid-template-columns: 1fr;
    grid-template-rows: min-content min-content;
  }
  .hotel-booking-layout:not(:has(.guest-details)) aside {
    display: none;
  }
}
@media (min-width: 1024px) {
  .hotel-booking-layout {
    grid-template-columns: 1fr min-content;
    grid-template-rows: min-content auto;
  }
  .hotel-booking-layout:has(.guest-details) .stay-properties {
    display: none;
  }
}
.hotel-booking-layout header {
  grid-column: 1;
  grid-row: 1;
}
.hotel-booking-layout header .stepper {
  padding-left: 16px;
}
@media (max-width: 1023px) {
  .hotel-booking-layout header .stepper {
    display: none;
  }
}
.hotel-booking-layout header .errors {
  margin: 16px;
}
.hotel-booking-layout aside {
  grid-row: 2;
}
@media (min-width: 1024px) {
  .hotel-booking-layout aside {
    grid-column: 2;
    grid-row: span 2;
  }
}
.hotel-booking-layout aside {
  display: flex;
  flex-direction: column;
  gap: 12px;
  min-width: 328px;
  margin: 0 auto;
  padding: 16px;
}
@media (max-width: 1023px) {
  .hotel-booking-layout aside {
    width: 100%;
  }
}
.hotel-booking-layout main {
  grid-column: 1;
  grid-row: 3;
}
@media (min-width: 1024px) {
  .hotel-booking-layout main {
    grid-row: 2/5;
  }
}
.hotel-booking-layout main .discount-applied {
  font-size: 14px;
  font-weight: 500;
  line-height: 20px;
  margin: 16px 16px 0;
  padding: 16px;
  display: flex;
  gap: 6px;
  color: #1F5C2B;
  background-color: #E0F8E4;
  border-radius: 10px;
}
.hotel-booking-layout main .discount-applied i {
  margin-top: 2px;
  font-size: 18px;
}
@media (min-width: 1024px) {
  .hotel-booking-layout main .discount-applied {
    display: none;
  }
}
.hotel-booking-layout main .content {
  display: flex;
  flex-direction: column;
  gap: 20px;
  padding: 16px;
}