p {
  line-height: 1.25em;
}

hr {
  border: none;
  border-top: 1px solid #646464;
  margin: 1rem 0;
}

fieldset {
  border: 1px solid #646464;
  margin: 1rem 0;
  padding: 0.5rem 1rem;
}
fieldset legend {
  font-weight: bold;
  font-size: 0.875rem;
}
fieldset > p {
  border-left: 0.5rem solid #f8f6ef;
  font-size: 0.875rem;
  padding-left: 0.5rem;
}
fieldset > p.av-label-error {
  border-left-color: red;
}

dialog {
  border-color: #B4A05A;
  width: 50vw;
  padding: 1rem;
}
dialog::backdrop {
  background-color: rgba(100, 100, 100, 0.4588235294);
}

@media screen and (max-width: 1080px) {
  dialog {
    width: calc(100vw - 2rem);
  }
}
.av-select {
  border: 1px solid #B4A05A;
  background-color: white;
  font-family: inherit;
  font-size: inherit;
  padding: 0.5rem;
  border-radius: 0.5rem;
  color: inherit;
  flex: 1 1 auto;
  max-width: 100%;
}

.av-button-outlined,
.av-button-solid {
  height: 2.5rem;
  padding: 0 1rem;
  border: 1px solid #B4A05A;
  display: inline-flex;
  box-sizing: border-box;
  align-items: center;
  text-decoration: none;
  gap: 0.5rem;
  cursor: pointer;
  font-family: inherit;
  font-size: inherit;
  background-color: white;
  color: inherit;
  border-radius: 0.25rem;
  transition-property: background-color;
  -webkit-transition-property: background-color;
  -moz-transition-property: background-color;
  transition-duration: 0.2s;
  -webkit-transition-duration: 0.2s;
  -moz-transition-duration: 0.2s;
  transition-timing-function: ease-in;
  -webkit-transition-timing-function: ease-in;
  -moz-transition-timing-function: ease-in;
}

.av-button-outlined:hover {
  background-color: #f8f6ef;
}

.av-button-solid {
  background-color: #B4A05A;
  color: white;
}
.av-button-solid:hover {
  background-color: #a7934c;
}
.av-button-solid.full-width {
  width: 100%;
  margin: 2rem 0;
  justify-content: center;
}

.av-main-column, .av-cms-horizontal-menu, .av-cms-vertical-menu > *, .av-cms-text, .av-admin-text {
  width: 75vw;
  margin: 0 auto;
}

@media screen and (max-width: 1080px) {
  .av-main-column, .av-cms-horizontal-menu, .av-cms-vertical-menu > *, .av-cms-text, .av-admin-text {
    width: initial;
    padding: 0 1rem;
  }
}
.av-h2, .av-cms-text h2, .av-admin-text h2 {
  margin: 3rem auto 1rem;
  font-size: 1.75rem;
  font-weight: normal;
  text-transform: uppercase;
  position: relative;
  display: flex;
  align-items: center;
  gap: 1rem;
}
.av-h2::after, .av-cms-text h2::after, .av-admin-text h2::after {
  content: "";
  flex-grow: 1;
  border-top: 2px solid #B4A05A;
  display: block;
}

.av-h3, .av-cms-text h3, .av-admin-text h3 {
  text-transform: uppercase;
  border-bottom: 1px solid #B4A05A;
  padding-bottom: 0.5rem;
  margin: 2rem auto 1rem;
}

.av-pagination {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  justify-content: center;
}
.av-pagination label {
  line-height: 1.5rem;
  padding: 0 0.5rem;
  min-width: 1rem;
  cursor: pointer;
  text-align: center;
  border-radius: 0.5rem;
  border: 1px solid #B4A05A;
}
.av-pagination label:hover {
  background-color: #f8f6ef;
}
.av-pagination label.active {
  background-color: #B4A05A;
  color: white;
}

@media screen and (max-width: 1080px) {
  .av-pagination {
    justify-content: space-evenly;
    flex-wrap: wrap;
  }
}
.av-form-label {
  margin: 1rem 0 0.5rem;
  display: block;
}
.av-form-label::first-line {
  font-weight: bold;
  line-height: 2rem;
}
.av-form-label input[type=text],
.av-form-label input[type=password],
.av-form-label input[type=email],
.av-form-label input[type=number],
.av-form-label input[type=date],
.av-form-label input[type=tel],
.av-form-label input[type=file] {
  border: 1px solid #646464;
  font-size: inherit;
  font-family: inherit;
  line-height: 2rem;
  padding: calc(0.25rem - 1px) 0.5rem;
  display: block;
  width: 100%;
  box-sizing: border-box;
}
.av-form-label select {
  height: 2.5rem;
  display: block;
  font-size: inherit;
  font-family: inherit;
  width: 100%;
  padding: 0 0.5rem;
  border: 1px solid #646464;
}
.av-form-label textarea {
  display: block;
  border: 1px solid #646464;
  font-size: inherit;
  font-family: inherit;
  width: 100%;
  box-sizing: border-box;
  line-height: 2rem;
  padding: calc(0.25rem - 1px) 0.5rem;
}
.av-form-label:has(input[type=checkbox]) {
  display: flex;
  gap: 1rem;
  align-items: center;
  line-height: 1.25rem;
}
.av-form-label:has(input[type=checkbox]) input {
  margin: 0;
  width: 1rem;
  height: 1rem;
}

.av-label-success {
  color: #80A038;
  font-size: 0.875rem;
  border-bottom: 1px solid #80A038;
  line-height: 1.5rem;
}

.av-label-error {
  color: #D01828;
  margin-top: 0.5rem;
  font-size: 0.875rem;
  border-bottom: 1px solid #D01828;
  line-height: 1.5rem;
}

/* CMS cover block */
.av-cms-cover {
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  aspect-ratio: 4.8/1;
  display: flex;
  flex-direction: column;
  justify-content: center;
  text-align: center;
  gap: 1rem;
  position: relative;
  box-sizing: border-box;
  padding: 0 1rem;
}
.av-cms-cover.light {
  color: white;
  text-shadow: 0 0 2px black;
}
.av-cms-cover.dark {
  color: black;
  text-shadow: 0 0 2px white;
}
.av-cms-cover h1 {
  text-transform: uppercase;
  font-weight: normal;
  font-size: 3rem;
}
.av-cms-cover p.subtitle {
  text-transform: uppercase;
  font-size: 2rem;
  margin: 0 0 1rem;
}
.av-cms-cover p.credits {
  position: absolute;
  bottom: 0;
  right: 0;
  font-size: 0.625rem;
  margin: 0;
  padding: 0.5rem 1rem;
}

@media screen and (max-width: 1080px) {
  .av-cms-cover h1 {
    font-size: 2rem;
  }
  .av-cms-cover p.subtitle {
    font-size: 1rem;
  }
  .av-cms-cover p.credits {
    display: none;
  }
}
/* CMS text block */
.av-cms-text, .av-admin-text {
  margin: 2rem auto;
  position: relative;
}
.av-cms-text p, .av-admin-text p, .av-cms-text li, .av-admin-text li {
  line-height: 1.375rem;
}
.av-cms-text a, .av-admin-text a {
  color: #B4A05A;
}
.av-cms-text .av-button-solid, .av-admin-text .av-button-solid {
  color: white;
}
.av-cms-text .av-button-outlined, .av-admin-text .av-button-outlined {
  color: black;
}
.av-cms-text table td, .av-admin-text table td, .av-cms-text table th, .av-admin-text table th {
  padding: 0.5rem;
}
.av-cms-text img, .av-admin-text img {
  max-width: 100%;
}

@media screen and (max-width: 1080px) {
  .av-cms-text, .av-admin-text {
    width: initial;
    padding: 0 1rem;
  }
}
/* CMS vertical menu (image left, links right) */
.av-cms-vertical-menu {
  padding: 3rem 0;
}
.av-cms-vertical-menu.dark {
  background-color: #646464;
  color: white;
}
.av-cms-vertical-menu.dark h2 span {
  background-color: #646464;
}
.av-cms-vertical-menu.light h2 span {
  background-color: white;
}
.av-cms-vertical-menu.light > div > div {
  color: white;
}
.av-cms-vertical-menu h2 {
  margin: 0 auto 3rem;
  font-size: 1.75rem;
  font-weight: normal;
  text-transform: uppercase;
  position: relative;
}
.av-cms-vertical-menu h2 span {
  z-index: 1;
  position: relative;
  padding-right: 1rem;
}
.av-cms-vertical-menu h2::before {
  content: "";
  border-top: 2px solid #B4A05A;
  position: absolute;
  top: 50%;
  width: 100%;
  display: block;
}
.av-cms-vertical-menu > div {
  display: flex;
}
.av-cms-vertical-menu > div > div {
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  width: 50%;
  aspect-ratio: 1.6/1;
  position: relative;
}
.av-cms-vertical-menu > div > div span {
  position: absolute;
  font-size: 0.5rem;
  bottom: 0;
  right: 0;
  line-height: 1rem;
  padding: 0 0.5rem;
}
.av-cms-vertical-menu > div > ul {
  display: flex;
  width: 50%;
  flex-direction: column;
  justify-content: space-evenly;
  list-style: none;
  margin: 0;
  padding: 0 0 0 3rem;
}
.av-cms-vertical-menu > div > ul a {
  text-decoration: none;
  color: inherit;
  display: flex;
  align-items: center;
  font-size: 1.375rem;
  letter-spacing: 0.25rem;
  gap: 3rem;
  text-transform: uppercase;
  transition-property: "transform";
  -webkit-transition-property: "transform";
  -moz-transition-property: "transform";
  transition-duration: 0.2s;
  -webkit-transition-duration: 0.2s;
  -moz-transition-duration: 0.2s;
  transition-timing-function: ease-in;
  -webkit-transition-timing-function: ease-in;
  -moz-transition-timing-function: ease-in;
}
.av-cms-vertical-menu > div > ul a:hover i:last-child {
  transform: translateX(1rem);
}
.av-cms-vertical-menu > div > ul a i:first-child {
  color: #B4A05A;
}

@media screen and (max-width: 1080px) {
  .av-cms-vertical-menu {
    padding: 1rem;
  }
  .av-cms-vertical-menu > h2 {
    width: initial;
    margin-bottom: 1rem;
  }
  .av-cms-vertical-menu > h2 span {
    padding: 0;
  }
  .av-cms-vertical-menu > h2::before {
    content: none;
  }
  .av-cms-vertical-menu > div {
    display: block;
    width: initial;
  }
  .av-cms-vertical-menu > div > div {
    display: none;
  }
  .av-cms-vertical-menu > div ul {
    padding: 0;
    width: initial;
  }
  .av-cms-vertical-menu > div ul li {
    margin: 1rem 0;
  }
  .av-cms-vertical-menu > div ul a {
    gap: 1rem;
    letter-spacing: normal;
  }
}
/* CMS horizontal menu (up to 4 links arranged horizontally with background images) */
.av-cms-horizontal-menu h2 {
  text-align: center;
  margin: 0 auto 2rem;
  font-size: 1.75rem;
  font-weight: normal;
  text-transform: uppercase;
  position: relative;
}
.av-cms-horizontal-menu h2 span {
  z-index: 1;
  display: inline-block;
  position: relative;
  background-color: white;
  padding: 0 1rem;
}
.av-cms-horizontal-menu h2::before {
  content: "";
  border-top: 2px solid #B4A05A;
  position: absolute;
  top: 50%;
  width: 100%;
  display: block;
}
.av-cms-horizontal-menu ul {
  display: flex;
  list-style: none;
  margin: 2rem 0;
  flex-wrap: wrap;
  padding: 0;
  gap: 2rem;
  position: relative;
  justify-content: center;
}
.av-cms-horizontal-menu ul li {
  background-size: cover;
  background-position: center;
  border: 1px solid #B4A05A;
  width: 16rem;
  min-width: min-content;
  aspect-ratio: 1/1.6;
  text-align: center;
  position: relative;
  transition-property: box-shadow;
  -webkit-transition-property: box-shadow;
  -moz-transition-property: box-shadow;
  transition-duration: 0.2s;
  -webkit-transition-duration: 0.2s;
  -moz-transition-duration: 0.2s;
  transition-timing-function: ease-in;
  -webkit-transition-timing-function: ease-in;
  -moz-transition-timing-function: ease-in;
}
.av-cms-horizontal-menu ul li:hover {
  box-shadow: 0 0 4px black;
}
.av-cms-horizontal-menu ul li:hover div {
  background-color: white;
}
.av-cms-horizontal-menu ul li:hover p:first-child {
  color: #B4A05A;
}
.av-cms-horizontal-menu ul li:hover p:last-child span:nth-child(2) {
  color: #B4A05A;
}
.av-cms-horizontal-menu ul li a {
  display: flex;
  height: 100%;
  align-items: flex-end;
  color: inherit;
  text-decoration: none;
}
.av-cms-horizontal-menu ul li a div {
  background-color: rgba(255, 255, 255, 0.75);
  margin: 1rem;
  padding: 1rem;
  flex-grow: 1;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  transition-property: background-color;
  -webkit-transition-property: background-color;
  -moz-transition-property: background-color;
  transition-duration: 0.2s;
  -webkit-transition-duration: 0.2s;
  -moz-transition-duration: 0.2s;
  transition-timing-function: ease-in;
  -webkit-transition-timing-function: ease-in;
  -moz-transition-timing-function: ease-in;
}
.av-cms-horizontal-menu ul li a div p {
  margin: 0;
}
.av-cms-horizontal-menu ul li a div p:first-child {
  font-size: 1.375rem;
  text-transform: uppercase;
  transition-property: color;
  -webkit-transition-property: color;
  -moz-transition-property: color;
  transition-duration: 0.2s;
  -webkit-transition-duration: 0.2s;
  -moz-transition-duration: 0.2s;
  transition-timing-function: ease-in;
  -webkit-transition-timing-function: ease-in;
  -moz-transition-timing-function: ease-in;
}
.av-cms-horizontal-menu ul li a div p:last-child {
  font-size: 0.813rem;
  margin-top: 0.5rem;
  display: flex;
  gap: 1rem;
  align-items: center;
}
.av-cms-horizontal-menu ul li a div p:last-child span:not(:nth-child(2)) {
  flex-grow: 1;
  border-top: 1px solid #B4A05A;
}

@media screen and (max-width: 1080px) {
  .av-cms-horizontal-menu {
    width: initial;
    padding: 0 1rem;
  }
}
/* CMS face book */
.av-cms-face-book {
  background-color: #646464;
  color: white;
  padding: 3rem 0;
}
.av-cms-face-book > * {
  width: 75vw;
  margin: 0 auto;
}
.av-cms-face-book > h2 {
  font-size: 1.75rem;
  font-weight: normal;
  text-transform: uppercase;
  display: flex;
  gap: 1rem;
  align-items: center;
}
.av-cms-face-book > h2 span {
  border: 1px solid #B4A05A;
  flex-grow: 1;
}
.av-cms-face-book > div {
  margin: 2rem auto;
}
.av-cms-face-book > ul {
  display: flex;
  gap: 2rem;
  list-style: none;
  padding: 0;
  flex-wrap: wrap;
  justify-content: center;
  text-align: center;
}
.av-cms-face-book > ul li {
  width: 16rem;
}
.av-cms-face-book > ul li div {
  height: 16rem;
  background-color: black;
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
  position: relative;
}
.av-cms-face-book > ul li div span {
  position: absolute;
  bottom: 0;
  right: 0;
  font-size: 0.625rem;
  padding: 0.5rem 1rem;
}
.av-cms-face-book > ul li p {
  margin: 1rem 0;
}
.av-cms-face-book > ul li div + p {
  font-size: 1.25rem;
}

.av-cms-reassurance {
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center;
  height: 40vh;
  position: relative;
}
.av-cms-reassurance ul {
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
  flex-wrap: wrap;
  text-align: center;
  color: white;
  background-color: rgba(100, 100, 100, 0.85);
}
.av-cms-reassurance ul li {
  width: max(300px, 20vw);
  padding: 1rem 0;
}
.av-cms-reassurance ul li > * {
  display: block;
}
.av-cms-reassurance ul li strong {
  font-size: 4rem;
  color: #B4A05A;
}

@media screen and (max-width: 1080px) {
  .av-cms-reassurance {
    height: initial;
  }
}
.av-admin-text {
  width: auto;
}

table.av-table {
  border: 1px solid #646464;
  border-collapse: collapse;
  width: 100%;
}
table.av-table thead tr {
  background-color: #646464;
  color: white;
}
table.av-table tbody tr {
  transition-property: background-color;
  -webkit-transition-property: background-color;
  -moz-transition-property: background-color;
  transition-duration: 0.2s;
  -webkit-transition-duration: 0.2s;
  -moz-transition-duration: 0.2s;
  transition-timing-function: ease-in;
  -webkit-transition-timing-function: ease-in;
  -moz-transition-timing-function: ease-in;
}
table.av-table tbody tr:hover {
  background-color: #f8f6ef;
}
table.av-table th, table.av-table td {
  padding: 0.5rem;
  line-height: 1.5em;
  border-left: 1px solid #646464;
  border-right: 1px solid #646464;
}
table.av-table th {
  white-space: nowrap;
  font-weight: normal;
}

tr[is=av-booking] {
  transition-property: background-color, color;
  -webkit-transition-property: background-color, color;
  -moz-transition-property: background-color, color;
  transition-duration: 0.2s;
  -webkit-transition-duration: 0.2s;
  -moz-transition-duration: 0.2s;
  transition-timing-function: ease-in;
  -webkit-transition-timing-function: ease-in;
  -moz-transition-timing-function: ease-in;
}
tr[is=av-booking][empty], tr[is=av-booking]:has(input:invalid) {
  background-color: #D01828;
  color: white;
}
tr[is=av-booking][empty] a, tr[is=av-booking]:has(input:invalid) a {
  color: white;
}
tr[is=av-booking] td[av-booking-rate] div {
  white-space: nowrap;
}

/*# sourceMappingURL=system.css.map */
