@charset "UTF-8";

@font-face {
  src:
    url("https://www.sunsweptresorts.com/wp-content/uploads/fusion-icons/Spa-Icon-Set-v1.0/fonts/Spa-Icon-Set.ttf?ns74wv") format("truetype"),
    url("https://www.sunsweptresorts.com/wp-content/uploads/fusion-icons/Spa-Icon-Set-v1.0/fonts/Spa-Icon-Set.woff?ns74wv") format("woff"),
    url("https://www.sunsweptresorts.com/wp-content/uploads/fusion-icons/Spa-Icon-Set-v1.0/fonts/Spa-Icon-Set.svg?ns74wv#Spa-Icon-Set") format("svg");
  font-display: swap;
  font-family: "Spa-Icon-Set";
  font-style: normal;
  font-weight: normal;
}

[class^="icon-spa-"],
[class*=" icon-spa-"] {
  font-family: "Spa-Icon-Set" !important;
  font-style: normal;
  font-variant: normal;
  font-weight: normal;
  line-height: 1;
  text-transform: none;
  
  speak: never;
  
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
.icon-spa-angle-right-solid::before {
  content: "\e900";
}
.icon-spa-bookmark-solid::before {
  content: "\e901";
}
.icon-spa-envira-brands::before {
  content: "\e902";
}
.icon-spa-heart-solid::before {
  content: "\e903";
}
.icon-spa-home-solid::before {
  content: "\e904";
}
.icon-spa-hot-tub-solid::before {
  content: "\e905";
}
.icon-spa-male-solid::before {
  content: "\e906";
}
.icon-spa-moon-solid::before {
  content: "\e907";
}
.icon-spa-pagelines-brands::before {
  content: "\e908";
}
.icon-spa-plus-solid::before {
  content: "\e909";
}
.icon-spa-sign-language-solid::before {
  content: "\e90a";
}
.icon-spa-smile-solid::before {
  content: "\e90b";
}
.icon-spa-snowflake-solid::before {
  content: "\e90c";
}
.icon-spa-bars-solid::before {
  content: "\e90d";
}
.icon-spa-times-solid::before {
  content: "\e90e";
}

@import url("https://fonts.googleapis.com/css2?family=Lato:ital,wght@0,100;0,300;0,400;0,700;0,900;1,100;1,300;1,400;1,700;1,900&family=Libre+Baskerville:ital,wght@0,400;0,700;1,400&display=swap");

:root {
  --brand-light-grey: #B9AFA1;
  --brand-dark-grey: #6F727B;
  --brand-white: #FFFFFF;
  
  --body-background: #F6F6F6;
  
  --backtotop-background: #333333;
  
  --footer-background: #EBEAEA;
  --footer-text-color: #5D5B5D99;
  
  --brand-shadow: #0000001E 0px 1px 3px;
  
  --font-family-serif: "Libre Baskerville", var(), system-ui, sans-serif;
  
  --custom-transition: all 0.2s ease;
  
  --img-ratio-rate-primary: 4 / 3;
  --img-ratio-rate-primary-mobile: 4 / 3;
  --img-ratio-rate-secondary: 4 / 3;
  --img-ratio-rate-secondary-mobile: 4 / 3;
  --img-ratio-mda-secondary-rate: 4 / 3;
  --img-ratio-mda-secondary-rate-mobile: 4 / 3;
}

@media screen {
  
  .header a i,
  .backtotop a i,
  .footer a i {
    margin-right: 0px;
  }
  
  .main-be-area {
    background-color: transparent;
  }
  
  body {
    background-color: var(--body-background);
  }
  
  .header {
    display: flex;
    justify-content: center;
    align-items: center;
    
    background-color: var(--brand-white);
    box-shadow: var(--brand-shadow);
    
    min-height: 84px;
    padding-block: 0px;
    /* border-bottom: 1px solid var(--border-default); */
    z-index: 4;
  }
  
  .header .container {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    justify-content: space-between;
    align-items: center;
    align-self: stretch;
    
    width: min(100%, 1230px);
    padding-inline: 50px;
  }
  
  .header .invisible-flex-item {
    display: flex;
    align-self: stretch;
    
    width: 150px;
    height: 100%;
  }
  
  .header .logo {
    display: flex;
    justify-content: center;
    align-items: center;
  }
  
  .header .logo a img {
    display: block;
    
    width: 200px;
    height: auto;
    
    transition: var(--custom-transition);
  }
  
  .header .logo a:hover img {
    opacity: 80%;
  }
  
  .header .backtosite {
    display: flex;
    justify-content: flex-end;
    align-items: center;
    align-self: stretch;
  }
  
  .header .backtosite a {
    display: flex;
    justify-content: center;
    align-items: center;
    align-self: stretch;
    
    background-color: transparent;
    color: var(--brand-dark-grey);
    
    font-size: 14px;
    font-weight: 400;
    letter-spacing: 1px;
    line-height: 14px;
    text-align: center;
    text-transform: capitalize;
    
    padding-block: 15px;
    padding-inline: 35px;
    
    transition: var(--custom-transition);
  }
  
  .header .backtosite:hover a {
    background-color: var(--brand-light-grey);
    color: var(--brand-white);
  }
  
  h1, h2, h3, h4, h5, h6,
  .header1, .header2, .header3, .header4, .header5, .header6,
  .heading-1, .heading-2, .heading-3, .heading-4, .heading-5, .heading-6 {
    font-family: var(--font-family-serif);
  }
  
  .ipulse-decoration {
    display: flex;
    justify-content: center;
    align-items: center;
    
    width: min(100%, calc(1200px + (var(--spacing-2x) * 2)));
    padding-top: var(--spacing-2x);
    padding-bottom: var(--spacing-4x);
    padding-inline: var(--spacing-2x);
    margin-inline: auto;
  }
  
  .ipulse-decoration::before,
  .ipulse-decoration::after {
    content: "";
    display: block;
    
    background-color: var(--brand-light-grey);
    
    height: 1px;
    width: 100%;
  }
  
  .ipulse-decoration i {
    display: flex;
    justify-content: center;
    align-items: center;
    
    width: 31.5px;
    aspect-ratio: 1 / 1;
  }
  
  .backtotop {
    position: fixed;
    
    width: 48px;
    aspect-ratio: 4.8 / 3.5;
    bottom: 0px;
    right: 75px;
  }
  
  .backtotop a {
    display: flex;
    justify-content: center;
    align-items: center;
    
    background-color: var(--backtotop-background);
    color: var(--brand-white);
    opacity: 90%;
    
    font-size: 14px;
    
    width: 100%;
    height: 100%;
    border-top-left-radius: 4px;
    border-top-right-radius: 4px;
    
    transition: var(--custom-transition);
  }
  
  .backtotop a:hover {
    opacity: 100%;
  }
  
  .footer {
    display: flex;
    justify-content: center;
    align-items: center;
    
    background-color: var(--footer-background);
    color: var(--footer-text-color);
    
    font-size: 14px;
    font-weight: 400;
    line-height: 32px;
    text-align: center;
    
    padding-top: 20px;
    padding-bottom: 36px;
  }
  
  .footer .container {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    align-items: center;
    
    row-gap: 56px;
  }
  
  .footer .footer-logo {
    display: flex;
    justify-content: center;
    align-items: center;
  }
  
  .footer .footer-logo img {
    display: block;
    
    width: 200px;
    height: auto;
    
    transition: var(--custom-transition);
  }
  
  .footer .footer-logo:hover img {
    opacity: 80%;
  }
  
  .footer .copyright {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
    
    font-size: inherit;
    line-height: inherit;
    
    column-gap: var(--spacing-1x);
  }
  
  .footer .copyright p {
    margin-block: 0px;
  }
  
  .footer .copyright a {
    color: var(--footer-text-color);
    
    transition: var(--custom-transition);
  }
  
  .footer .copyright a:hover {
    color: var(--brand-color);
  }
  
}





/* ----- Tablet specific ----- */
@media screen and (max-width: 999px) {
  
  .header {
    min-height: 79px;
  }
  
  .header .container {
    grid-template-columns: repeat(2, auto);
    
    padding-inline: 25px;
  }

  .header .invisible-flex-item {
    display: none;
  }
  
  .backtotop {
    right: 37.75px;
  }
  
}



/* ----- Mobile specific ----- */
@media screen and (max-width: 499px) {
  
  .header {
    min-height: 74px;
  }
  
  .header .container {
    display: flex;
    justify-content: center;
    
    padding-inline: 0px;
  }
  
  .header .backtosite {
    display: none;
  }
  
  .backtotop {
    right: 17.5px;
  }
  
  .footer .copyright {
    flex-direction: column;
  }
  
  .footer .copyright > span {
    display: none;
  }
  
}