
.modal-box,
.modal-box2 {
  display: none;
  /* display: flex; */
  position: fixed;
  top: -1px;
  left: 0;
  z-index: 6;
  width: 100%;
  height: 100%;
  background: #fff;
  border-bottom: 1px solid #aaa;
  border-radius: 4px;
  box-shadow: 0 3px 9px rgba(0, 0, 0, 0.5);
  border: 1px solid rgba(0, 0, 0, 0.1);
  background-clip: padding-box;
  justify-content: center;
  overflow: auto;
}

.modal-box header h3,
.modal-box2 header h3 { margin: 0; }

.modal-overlay,
.modal-overlay2 {
  opacity: 0;
  filter: alpha(opacity=0);
  position: fixed;
  top: 0;
  left: 0;
  z-index: 5;
  width: 100%;
  height: 100vh;
  background: rgba(0, 0, 0, 0.3) !important;
}
.modal-box {
  background-position: -256px bottom;
  background-repeat: no-repeat;
}
.modal-container {
  max-width: 1024px;
  width: 100%;
}
.modal-container.w1166 {
  max-width: 1166px;
}
.modal-container.w1110 {
  max-width: 1110px;
}
.modal-container header {
  display: flex;
  justify-content: space-between;
  padding: 20px 0 26px;
  border: 0 none;
}
.modal-container header.header {
  position: relative;
  display: flex;
  justify-content: center;
  padding: 32px 0 26px;
}
#joinmailing .modal-container header.header,
#getstarted .modal-container header.header,
.office-details .modal-container header.header {
  justify-content: flex-start;
}
.modal-container header .close-button {
  cursor: pointer;
}
.modal-container header.header .close-button {
  position: absolute;
  top: 34px;
  right: -14px;
}
.office-details .modal-container header.header {
  padding: 42px 0 30px;
}
.office-details .modal-container header.header h1 {
  font-size: 20px;
  color: #4D555A;
}
.office-details .modal-container header.header .close-button {
  top: 30px;
}
.modal-container header div {
  width: 50%;
}
#schedule .modal-container header div {
  width: 100%;
}

.modal-body .schedule-form {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  max-width: 1032px;
  margin-top: 20px;
  padding-bottom: 80px;
}
.modal-body .schedule-form img {
  width: 362px;
  flex: none;
}
.modal-body .schedule-form-holder {
  width: 606px;
}
.modal-body .schedule-form-holder h2 {
  font-family: 'Montserrat', sans-serif;
  font-size: 24px;
  line-height: 39px;
  font-weight: 400;
  color: #323638;
  margin: -91px 0 54px;
}
.modal-body .schedule-form-holder h2 strong {
  font-size: 24px;
  line-height: 39px;
  display: inline;
}
.modal-body .schedule-holder {
  width: 514px;
}
.modal-container .hleft {
  display: flex;
  align-items: left;
}
.modal-container .hleft.subscribe {
  display: flex;
  flex-direction: column;
  width: 100%;
}
.modal-container .hleft.subscribe p {
  margin-top: 10px;
}
.modal-container .hleft h1 {
  font-family: 'Montserrat', sans-serif;
  font-size: 26px;
  line-height: 32px;
  font-weight: 700;
  color: #323638;
}
.modal-container .hleft.modal-logo {
  align-items: center;
}
.modal-container .hleft.modal-logo img {
  height: 54px;
  margin-right: 16px;
}
.modal-container .hleft.modal-logo p {
  font-family: 'Montserrat', sans-serif;
  font-size: 14px;
  font-weight: 400;
}
.modal-container .hleft h3 {
  font-family: "sfprotext", sans-serif;
  font-size: 26px;
  font-weight: bold;
  line-height: 32px;
  color: #C7BDA0;
  margin: 0 0 0 20px;
  text-transform: uppercase;
}
.modal-container .hleft h3.nomargin {
  margin: 0;
}
.modal-container .hright {
  display: flex;
  justify-content: flex-end;
}
.modal-container .hright .button {
  width: 150px;
  position: relative;
  border: 0 none;
}
.modal-container .hright .button.guestbtn {
  width: auto;
  color: #2497CE;
  border: 1px solid #2497CE;
  margin-right: 16px;
}
.modal-container .button.bottom {
  width: 150px;
  display: none;
}
.modal-body {
  width: 100%;
  line-height: 28px;
}
.modal-body .get-started-holder {
  margin-top: 40px;
}
.modal-body p {
  font-size: 16px;
  line-height: 28px;
  color: #625226;
  display: block;
  width: 100%;
  margin: 0;
}
.modal-body h4 {
  font-family: "sfprotextmedium", sans-serif;
  font-size: 18px;
  font-weight: normal;
  line-height: 22px;
  margin: 0 0 20px;
  display: block;
  color: #444A5D;
}
.modal-body strong {
  font-size: 16px;
  font-weight: bold;
  line-height: 28px;
  color: #625226;
  display: block;
}
.modal-body p strong {
  display: inline-block;
}
.modal-body strong.head {
  font-size: 18px;
  font-weight: bold;
  line-height: 28px;
  color: #625226;
}
.modal-body strong.dark,
.modal-body p.dark {
  color: #212B35;
}
.modal-body .gallery-thumb {
  display: flex;
  justify-content: space-between;
  margin: 56px 0 52px;
}
.modal-body .gallery-thumb .thumb-img {
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  width: 140px;
  height: 140px;
  border-radius: 10px;
}
.modal-body .gallery-btn {
  display: flex;
  justify-content: center;
  margin: 0 0 60px;
}
.modal-body .gallery-btn button {
  padding: 0 22px;
  width: auto;
}
.modal-body .quotes {
  background: url('/images/quotes.png') no-repeat 0 0;
  height: 95px;
  padding-left: 90px;
  display: flex;
  align-items: end;
}
.modal-body .quotes span {
  font-family: "avenirbook", sans-serif;
  font-size: 26px;
  font-weight: 300;
  line-height: 32px;
  width: 288px;
  color: #625226;
  display: block;
}
.modal-body ul {
  padding: 0 0 24px;
  margin: 0;
  list-style-type: none;
}
.modal-body ul.accommodation li {
  display: flex;
  justify-content: space-between;
  width: 100%;
  margin-bottom: 54px;
}
.modal-body ul.accommodation li a {
  font-size: 22px;
  line-height: 26px;
  font-weight: bold;
  color: #2497CE;
  display: block;
  margin: 0 0 12px;
  text-decoration: none;
}
.modal-body ul.accommodation li .img-thumb-wrapper {
  width: 358px;
  flex: none;
}
.modal-body ul.accommodation li .img-thumb-wrapper span {
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  width: 332px;
  height: 216px;
  display: block;
  border-radius: 6px;
}
.modal-body ul.accommodation li .img-thumb-wrapper a {
  display: none;
}
.modal-body ul.accommodation li .img-text {
  width: 100%;
}
.modal-body .map {
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  width: 100%;
  max-width: 695px;
  height: 458px;
  display: block;
  margin: 8px 0;
}
.modal-body .tbl-head {
  display: flex;
  justify-content: space-between;
  margin-bottom: 20px;
}
.modal-body .tbl-head strong {
  width: 50%;
  color: #212B35;
}
.modal-body ul.itinerary {
  margin-bottom: 0 0 0 48px;
}
.modal-body ul.itinerary li {
  margin-bottom: 28px;
  display: flex;
  justify-content: space-between;
}
.modal-body ul.itinerary li span {
  font-size: 16px;
  display: block;
  color: #625226;
  width: 50%;
}
.modal-body ul.itinerary li span.small {
  font-size: 14px;
}
.modal-body ul.itinerary li strong {
  width: 50%;
}
.modal-body ul.itinerary li div {
  width: 50%;
}
.modal-body ul.itinerary li div span,
.modal-body ul.itinerary li div strong {
  width: 100%;
}
.modal-body ul.itinerary li span strong {
  width: auto;
  display: inline-block;
}
.modal-body ul.confirm-tbl {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  list-style-type: none;
  margin: 36px 0;
  padding: 28px 18px;
  border: 1px solid #C7BDA0;
  border-radius: 6px;
  font-size: 14px;
  color: #7E755D;
}
.modal-body ul.confirm-tbl li {
  display: flex;
  align-items: baseline;
  width: 50%;
  margin-bottom: 24px;
  padding: 0 18px;
}
.modal-body ul.confirm-tbl li .capital {
  text-transform: capitalize;
}
.modal-body ul.confirm-tbl li.block {
  display: block;
}
.modal-body ul.confirm-tbl li strong,
.modal-body ul.confirm-tbl li span {
  font-size: 14px;
  color: #7E755D;
  line-height: 22px;
}
.modal-body ul.confirm-tbl li strong {
  margin-right: 35px;
}
.modal-body ul.confirm-tbl li span strong {
  margin: 0;
  display: inline-block;
}
.modal-body ul.confirm-tbl li:nth-child(6) span:nth-child(1) {
  margin-right: 72px;
}
.modal-body a.instagram {
  font-family: "sfprotext", sans-serif;
  font-size: 20px;
  line-height: 20px;
  color: #6C6246;
  font-weight: normal;
  display: flex;
  align-items: center;
  text-decoration: none;
  margin-left: -4px
}
.modal-body a.instagram span {
  margin-left: 6px
}
.modal-body p button {
  width: 72px;
  height: 34px;
  margin: 0 8px;
}
.modal-body ul.guest {
  list-style-type: none;
  margin: 36px 0;
  padding: 28px 36px;
  border: 1px solid #C7BDA0;
  border-radius: 6px;
  font-size: 14px;
  color: #7E755D;
}
.modal-body ul.guest li {
  line-height: 22px;
}
.modal-body ul.guest li strong.black {
  color: #212B35;
}
.modal-container.gl .hleft h3 {
  margin: 0;
}
.modal-body.location {
  color: #91918F;
  line-height: 22px;
}
.modal-body.location strong {
  font-size: 18px;
  color: #444A5D;
}
.modal-body.location span {
  font-size: 14px;
  color: #91918F;
  display: block;
}
.modal-body.location label {
  font-size: 14px;
  color: #AFB2BC;
  display: block;
  margin: 0 0 18px;
}
.modal-body.location .gbtn {
  display: flex;
  justify-content: center;
  margin: 36px 0;
}
.modal-body.confirm-body {
  padding-bottom: 40px;
}
.modal-body .details {
  display: flex;
  justify-content: space-between;
}
.modal-body .details div.desc {
  font-size: 16px;
  line-height: 26px;
  margin-bottom: 55px;
  width: 354px;
}
.modal-body .details ul.thumb-nails {
  list-style-type: none;
  width: 385px;
  display: flex;
  flex-wrap: wrap;
}
.modal-body .details ul.thumb-nails li {
  width: 110px;
  height: 76px;
  margin-bottom: 20px;
  margin-right: 18px;
}
.modal-body .details ul.thumb-nails li span.img {
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  display: block;
  width: 100%;
  height: 100%;
  cursor: pointer;
}
.modal-body .details ul.thumb-nails li.show-img span.img {
  border: 5px solid #30699D;
  border-radius: 5px;
}
.modal-body .details ul.img-preview {
  list-style-type: none;
  width: 664px;
  height: 450px;
}
.modal-body .details ul.img-preview li {
  width: 100%;
  height: 100%;
  display: none;
}
.modal-body .details ul.img-preview li.show-img {
  display: block;
}
.modal-body .details ul.img-preview li span {
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  display: block;
  width: 100%;
  height: 100%;
}
.rsvp-form {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  width: 672px;
}
.rsvp-form .input-wrapper {
  position: relative;
  display: block;
}
.rsvp-form .input-wrapper span {
  position: absolute;
  left: 2px;
  bottom: 4px;
  font-size: 12px;
  color: #dc3545;
}
.rsvp-form .text-area .input-wrapper span {
  bottom: -10px;
}
.rsvp-form input,
.rsvp-form select {
  font-family: "sfprotext", sans-serif;
  font-size: 14px;
  font-weight: bold;
  width: 320px;
  height: 36px;
  border: 1px solid #C3CCD5;
  margin-bottom: 24px;
  padding: 0 12px;
  color: #7E755D;
  border-radius: 3px;
}
.rsvp-form input[placeholder="Contact Number"],
.rsvp-form input[placeholder="Dietary Restrictions"] {
  font-weight: normal;
}
.rsvp-form input[placeholder="Dietary Restrictions"] {
  font-weight: normal;
}
.rsvp-form .input-num {
  width: 320px;
  display: flex;
  align-items: center;
  margin-bottom: 24px;
}
.rsvp-form .input-num label {
  font-size: 14px;
  color: #7E755D;
  width: 68px;
  flex: none;
}
.rsvp-form .input-toggle {
  position: relative;
  width: 100%;
}
.rsvp-form .input-toggle .minus {
  position: absolute;
  top: 0;
  left: 0;
  border-top-left-radius: 3px;
  border-bottom-left-radius: 3px;
}
.rsvp-form .input-toggle .plus {
  position: absolute;
  top: 0;
  right: 0;
  border-top-right-radius: 3px;
  border-bottom-right-radius: 3px;
}
.rsvp-form .input-num input {
  margin: 0;
  width: 100%;
  text-align: center;
}
.rsvp-form .text-area {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.rsvp-form .text-area label {
  font-size: 14px;
  color: #7E755D;
  display: block;
  font-weight: bold;
  margin-bottom: 10px;
}
.rsvp-form .text-area div {
  width: 320px;
}
.rsvp-form .text-area div textarea {
  font-size: 14px;
  width: 100%;
  height: 100px;
  border-radius: 3px;
  border-color: #C3CCD5;
  padding: 12px;
  color: #7E755D;
}

.modal-body .imgs {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  width: 100%;
}
.modal-body .imgs img {
  margin-bottom: 32px;
  width: 246px;
  height: 246px;
  border-radius: 10px;
  cursor: pointer;
}
.modal-body .imgs .pic {
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  width: 246px;
  height: 246px;
  border-radius: 10px;
  cursor: pointer;
  margin-bottom: 32px;
}
.modal-body .imgs .more {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 32px;
  width: 246px;
  height: 246px;
  border-radius: 10px;
  border: 1px solid #2497CE;
  color: #2497CE;
  margin-bottom: 32px;
}
.photo-slider-container ul {
  width: 100%;
  height: calc(100vh - 100px);
}
.photo-slider-container li {
  width: 100%;
  height: 100%;
  display: flex;
  justify-content: center;
}
.photo-slider-container li div {
  background-position: top center;
  background-repeat: no-repeat;
  background-size: contain;
  height: 100%;
  width: 100%;
}

.splide__arrow {
  background-color: #7E755D;
  width: 50px;
  height: 36px;
  border-radius: 5px;
  opacity: 1;
  padding-bottom: 4px;
}
.splide__arrow svg {
  fill: #fff;
}

.splide__arrow--prev {
  top: -52px;
  right: 144px;
  left: inherit;
}
.splide__arrow--next {
  top: -52px;
  right: 74px;
}

#slider .modal-container .hleft h3 {
  margin-left: 0;
}

@keyframes spinnerloading {
  to {transform:rotate(1turn)}
}

button[loading="true"] .spinner{
  display: flex;
}
.spinner {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  align-items: center;
  justify-content: center;
  display: none;
}
.spinner svg {
  height: 2.4rem;
  width: 2.4rem;
  animation: spinnerloading .5s linear infinite;
  fill: #fff;
}
.guest-spinner {
  position: relative;
  width: 100%;
  margin-top: 18%;
}
.guest-spinner .spinner {
  display: flex;
}
.guest-spinner .spinner svg {
  fill: #C7BDA0;
}
#submitbtn.button {
  position: relative;
}

@media screen and (max-width: 1166px) {
  .modal-container .hleft.modal-logo img {
    height: 42px;
  }
  .modal-container {
    width: 100%;
    padding: 0 25px;
  }
  .modal-body .schedule-form {
    max-width: 100%;
  }
  .modal-body .schedule-form img {
    display: none;
  }
  .modal-body .schedule-form-holder {
    width: 100%;
  }
  .modal-body .schedule-form-holder h2 {
    margin: 0 0 54px;
  }
  .modal-body .schedule-holder {
    width: 100%;
  }
}

@media screen and (max-width: 1024px) {
  .modal-body .imgs {
    justify-content: space-evenly;
  }
  .modal-container.w100 header div {
    width: 100%;
  }
  .rsvp-form {
    width: 100%;
  }
  .modal-body .imgs .more {
    width: 214px;
    height: 214px;
  }
}

@media screen and (max-width: 768px) {
  .modal-body {
    padding-bottom: 44px;
  }
  .modal-body .schedule-form-holder h2,
  .modal-body .schedule-form-holder h2 strong {
    font-size: 20px;
    line-height: 32px;
  }
  .modal-body .gallery-thumb {
    margin: 50px 0 34px;
  }
  .modal-body .gallery-thumb .thumb-img {
    width: 120px;
    height: 120px;
  }
  .modal-body .gallery-btn {
    margin: 0 0 56px;
  }
  .modal-body .tbl-head {
    display: block;
  }
  .modal-body .tbl-head strong {
    width: 100%;
  }
  .modal-body .tbl-head strong.small {
    font-size: 14px;
  }
  .modal-body ul.itinerary li span,
  .modal-body ul.itinerary li strong {
    font-size: 14px;
    line-height: 22px;
  }
  .modal-body ul.confirm-tbl {
    flex-wrap: wrap;
    padding: 20px;
  }
  .modal-body ul.confirm-tbl li {
    width: 100%;
    order: 1;
  }
  .modal-body ul.confirm-tbl li:nth-child(5) {
    order: 2;
  }
  .modal-body ul.confirm-tbl li:nth-child(7),
  .modal-body ul.confirm-tbl li:nth-child(8) {
    order: 3;
  }
  .modal-body ul.guest {
    margin: 28px 0;
    padding: 28px;
  }
  .rsvp-form .text-area {
    flex-wrap: wrap;
    margin: 11px 0 22px;
  }
  .rsvp-form .input-wrapper {
    width: 100%;
  }
  .rsvp-form input,
  .rsvp-form select,
  .rsvp-form .input-num,
  .rsvp-form .text-area div {
    width: 100%;
  }
  .rsvp-form .text-area .input-wrapper {
    margin-bottom: 35px;
  }
  .modal-container .hright .button {
    display: none;
  }
  .modal-container .hright .button.guestbtn {
    display: flex;
    margin-right: 0;
  }
  .modal-container .button.bottom {
    display: flex;
  }
  .modal-body .imgs img {
    width: 148px;
    height: 148px;
    border-radius: 12px;
    margin: 0 0 12px;
  }
  .modal-body .imgs .pic {
    width: 148px;
    height: 148px;
    border-radius: 12px;
    margin: 0 0 12px;
  }
  .modal-body .imgs .more {
    width: 104px;
    height: 104px;
    margin: 0 12px 12px 0;
  }
  .modal-body .imgs .more {
    font-size: 18px;
  }
  .modal-body .map {
    max-width: 335px;
    height: 222px;
  }
  .splide__arrow--prev {
    top: -52px;
    left: 18px;
    right: inherit;
  }
  .splide__arrow--next {
    top: -52px;
    left: 92px;
    right: inherit;
  }
  #slider .hleft h3 {
    display: none;
  }
  #slider .modal-body {
    padding: 0;
  }
  #slider .modal-container {
    padding: 0;
  }
  #slider .modal-container header {
    padding: 20px 18px 26px;
  }
}
@media screen and (max-width: 660px) {
  .modal-body .gallery-thumb .thumb-img {
    width: 100px;
    height: 100px;
  }
  .modal-body ul.accommodation li {
    display: block;
    width: 100%;
    margin-bottom: 54px;
  }
  .modal-body ul.accommodation li a {
    display: none;
  }
  .modal-body ul.accommodation li .img-thumb-wrapper {
    width: 100%;
  }
  .modal-body ul.accommodation li .img-thumb-wrapper span{
    margin-bottom: 22px;
    width: 100%;
    max-width: 480px ;
  }
  .modal-body ul.accommodation li a {
    font-size: 18px;
  }
  .modal-body ul.accommodation li .img-thumb-wrapper a {
    display: block;
  }
}
@media screen and (max-width: 560px) {
  .modal-body .gallery-thumb .thumb-img {
    width: 90px;
    height: 90px;
  }
}
@media screen and (max-width: 510px) {
  .modal-body .gallery-thumb .thumb-img {
    width: 75px;
    height: 75px;
  }
  .modal-body .imgs .pic {
    width: 104px;
    height: 104px;
    border-radius: 10px;
    margin: 0 0 12px;
  }
}
@media screen and (max-width: 425px) {
  .modal-container .hleft h1 {
    font-size: 20px;
  }
  .modal-body .imgs img {
    width: 104px;
    height: 104px;
  }
  .modal-body .gallery-thumb .thumb-img {
    width: 60px;
    height: 60px;
  }
  .modal-body .quotes span {
    font-size: 20px;
    width: 220px;
  }
  #joinmailing .modal-container.w100 header div,
  #getstarted .modal-container.w100 header div {
    display: block;
  }
}
@media screen and (max-width: 374px) {
  .modal-body .imgs .more {
    width: 84px;
    height: 84px;
    margin: 0 10px 10px 0;
  }
  .modal-body .imgs .pic {
    width: 90px;
    height: 90px;
  }
}