@import url("https://fonts.googleapis.com/css2?family=Playfair+Display&family=Raleway:wght@300;400;600&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Poppins:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,100;1,200;1,300;1,400;1,500;1,600;1,700;1,800;1,900&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Josefin+Sans:ital,wght@0,100..700;1,100..700&family=Jost:ital,wght@0,100..900;1,100..900&family=Manrope:wght@200..800&family=Roboto:ital,wght@0,100;0,300;0,400;0,500;0,700;0,900;1,100;1,300;1,400;1,500;1,700;1,900&display=swap");
/**
 * Modern Animation System
 * - Optimized for performance
 * - Supports delays and custom durations
 * - Uses will-change for hardware acceleration
 * - Prevents layout thrashing
 */
/* Base animation settings - universal for all fade animations */
.visible-after-animation {
  opacity: 1 !important; }

[class*=fade-] {
  opacity: 0;
  will-change: opacity,transform;
  animation-play-state: paused;
  backface-visibility: hidden;
  perspective: 1000px;
  animation-fill-mode: forwards !important; }

[class*=fade-].fade-in, [class*=fade-][class$="-active"] {
  animation-play-state: running;
  animation-duration: var(--anim-duration, 0.8s);
  animation-delay: var(--anim-delay, 0s);
  animation-timing-function: var(--anim-easing, cubic-bezier(0.25, 0.1, 0.25, 1));
  animation-fill-mode: forwards !important; }

.fade-in {
  animation-name: fadeIn;
  background-position: center !important;
  background-size: cover !important; }

.fade-up, .fade-up-active {
  animation-name: fadeUp; }

.fade-down, .fade-down-active {
  animation-name: fadeDown; }

.fade-down-large, .fade-down-large-active {
  animation-name: fadeDownLarge; }

.fade-left, .fade-left-active {
  animation-name: fadeLeft; }

.fade-right, .fade-right-active {
  animation-name: fadeRight; }

.fade-scale, .fade-scale-active {
  animation-name: fadeScale; }

.fade-scale-up, .fade-scale-up-active {
  animation-name: fadeScaleUp; }

@keyframes fadeIn {
  0% {
    opacity: 0; }
  100% {
    opacity: 1; } }
@keyframes fadeUp {
  0% {
    opacity: 0;
    transform: translateY(30px); }
  100% {
    opacity: 1;
    transform: translateY(0); } }
@keyframes fadeDown {
  0% {
    opacity: 0;
    transform: translateY(-30px); }
  100% {
    opacity: 1;
    transform: translateY(0); } }
@keyframes fadeDownLarge {
  0% {
    opacity: 0;
    transform: translateY(-1000px); }
  100% {
    opacity: 1;
    transform: translateY(0); } }
@keyframes fadeLeft {
  0% {
    opacity: 0;
    transform: translateX(30px); }
  100% {
    opacity: 1;
    transform: translateX(0); } }
@keyframes fadeRight {
  0% {
    opacity: 0;
    transform: translateX(-30px); }
  100% {
    opacity: 1;
    transform: translateX(0); } }
@keyframes fadeScale {
  0% {
    opacity: 0;
    transform: scale(0.9); }
  100% {
    opacity: 1;
    transform: scale(1); } }
@keyframes fadeScaleUp {
  0% {
    opacity: 0;
    transform: scale(0.9) translateY(30px); }
  100% {
    opacity: 1;
    transform: scale(1) translateY(0); } }
.delay-100 {
  --anim-delay:0.1s; }

.delay-200 {
  --anim-delay:0.2s; }

.delay-300 {
  --anim-delay:0.3s; }

.delay-400 {
  --anim-delay:0.4s; }

.delay-500 {
  --anim-delay:0.5s; }

.delay-800 {
  --anim-delay:0.8s; }

.delay-1000 {
  --anim-delay:1s; }

.duration-300 {
  --anim-duration:0.3s; }

.duration-500 {
  --anim-duration:0.5s; }

.duration-800 {
  --anim-duration:0.8s; }

.duration-1000 {
  --anim-duration:1s; }

.duration-1500 {
  --anim-duration:1.5s; }

.duration-2000 {
  --anim-duration:2s; }

.ease-linear {
  --anim-easing:linear; }

.ease-in {
  --anim-easing:cubic-bezier(0.42, 0, 1, 1); }

.ease-out {
  --anim-easing:cubic-bezier(0, 0, 0.58, 1); }

.ease-in-out {
  --anim-easing:cubic-bezier(0.42, 0, 0.58, 1); }

.ease-bounce {
  --anim-easing:cubic-bezier(0.68, -0.55, 0.265, 1.55); }

@media (prefers-reduced-motion: reduce) {
  [class*=fade-] {
    transition: opacity 0.1s ease-in-out !important;
    animation: none !important;
    transform: none !important; }

  .fade-in, [class*=fade-][class$="-active"] {
    opacity: 1; } }
.lazy {
  opacity: 0;
  transition: opacity .5s ease-in-out; }

html {
  font-size: 16px; }

/* CHIME ADJUSTMENTS */
/*.search-bar.layout3 .search-by-section .search-category .keyword-submit {
    min-width: 84px;
}*/
.search-bar.layout3 .search-by-section .search-category .keyword {
  height: 45px; }

.search-bar.layout3 .search-by-section .search-category .keyword-submit {
  height: 45px; }

.md-hero.layout3.banner-with-search-group.mg-bg {
  display: none; }

.md-custom-code, #app, main {
  background-color: transparent !important; }

.mg-container {
  max-width: 100% !important;
  width: 100% !important; }

.md-form.layout2 .info-agent, div.md-form.layout9.mg-bg div.f-col.md-form-container div.info-left {
  display: none; }

.md-form.layout9 .info-right,
.md-form.layout2 .info-right {
  flex-shrink: 0;
  flex-grow: 0;
  box-sizing: border-box;
  padding: 30px 50px 30px 40px;
  width: 100%; }

.md-form.layout9 .info-right,
.md-form.layout2 .info-right > div > h2 {
  margin-bottom: 20px;
  color: #000 !important; }

.md-form.layout9 .md-form-container {
  padding: 20px 0; }

.disclaimer-wrap.opt-in .disclaimer-content {
  font-size: 12px; }

div.info-right > form > div.input-content > div > div > p.title {
  margin-bottom: 10px;
  color: #000 !important; }

.md-form.layout4 .info-right .agent-info {
  display: none; }

.md-form {
  padding-top: 0px !important;
  padding-bottom: 0px !important; }

div.info-right > form > div.submit-content > div {
  text-align: center !important; }

div.info-right > form > div.submit-content > div > button {
  width: auto !important;
  padding-left: 15px;
  padding-right: 15px; }

.disclaimer-content.party-consent * {
  color: black !important; }

.md-form input, .md-form textarea {
  color: black !important; }

.email-suggestion .item {
  color: black !important; }

/* Pele Styles */
body {
  margin: 0;
  padding: 0; }
  body #cherieYoung {
    width: 100%;
    opacity: 1 !important; }
    body #cherieYoung #custom-content {
      width: 100%;
      position: relative;
      overflow: hidden;
      /* ----------------------- Background ----------------------- */
      /* ----------------------- Hero ----------------------- */
      /* ----------------------- Vacation Rentals (Base) ----------------------- */
      /* ----------------------- Kihei (4 columns) ----------------------- */
      /* ----------------------- Wailea (5 columns) ----------------------- */
      /* ----------------------- Waikiki (4 columns) ----------------------- */
      /* ----------------------- Responsive ----------------------- */ }
      body #cherieYoung #custom-content a {
        text-decoration: none !important; }
      body #cherieYoung #custom-content h1 {
        font-family: "Josefin Sans", Sans-serif;
        font-size: 8rem;
        font-weight: 300;
        color: #fff;
        text-align: center;
        margin-bottom: 0;
        margin-top: -10px;
        line-height: 95%; }
        body #cherieYoung #custom-content h1.large {
          font-size: 11rem; }
        @media (max-width: 1200px) {
          body #cherieYoung #custom-content h1 {
            font-size: 4rem; }
            body #cherieYoung #custom-content h1.large {
              font-size: 6rem; } }
        @media (max-width: 790px) {
          body #cherieYoung #custom-content h1 {
            font-size: 2.5rem;
            line-height: 100%; }
            body #cherieYoung #custom-content h1.large {
              font-size: 3rem; } }
      body #cherieYoung #custom-content h2 {
        font-family: "Josefin Sans", Sans-serif;
        font-size: 4.5rem;
        font-weight: 100;
        color: #fff;
        text-align: center;
        margin-bottom: 0;
        margin-top: 0;
        line-height: 95%; }
        @media (max-width: 1200px) {
          body #cherieYoung #custom-content h2 {
            font-size: 4rem; } }
        @media (max-width: 790px) {
          body #cherieYoung #custom-content h2 {
            font-size: 3.5rem; } }
      body #cherieYoung #custom-content h3 {
        font-family: "Josefin Sans", Sans-serif;
        font-size: 1.5rem;
        font-weight: 300;
        color: #fff;
        text-align: center;
        margin-bottom: 0;
        margin-top: 0; }
        @media (max-width: 1200px) {
          body #cherieYoung #custom-content h3 {
            font-size: 1.25rem; } }
        @media (max-width: 790px) {
          body #cherieYoung #custom-content h3 {
            font-size: 1rem; } }
      body #cherieYoung #custom-content p {
        font-family: "Josefin Sans", Sans-serif;
        font-size: 1.25rem;
        font-weight: 300;
        color: #fff;
        text-align: center;
        margin-bottom: 0;
        margin-top: 0;
        line-height: 32px; }
      body #cherieYoung #custom-content .background-content {
        position: fixed;
        z-index: -1;
        top: 0;
        left: 0;
        bottom: 0;
        right: 0;
        width: 100%;
        height: 100%;
        filter: brightness(0.7);
        background-position: center;
        background-size: cover; }
        body #cherieYoung #custom-content .background-content .video-wrapper {
          position: relative;
          width: 100%;
          height: 100%;
          overflow: hidden; }
        body #cherieYoung #custom-content .background-content #background-video {
          position: absolute;
          top: 50%;
          left: 50%;
          transform: translate(-50%, -50%);
          min-width: 100%;
          min-height: 100%;
          width: auto;
          height: auto;
          object-fit: cover;
          display: block; }
        body #cherieYoung #custom-content .background-content .embed-responsive {
          padding: 0 !important;
          height: 100vh !important;
          overflow: hidden;
          position: relative; }
        body #cherieYoung #custom-content .background-content .embed-responsive video {
          position: absolute;
          top: 50%;
          left: 50%;
          transform: translate(-50%, -50%);
          min-width: 100%;
          min-height: 100%;
          width: auto !important;
          height: auto !important;
          object-fit: cover; }
        @media (max-width: 991px) {
          body #cherieYoung #custom-content .background-content {
            background-image: url(""); }
            body #cherieYoung #custom-content .background-content #background-video {
              display: none !important; } }
      body #cherieYoung #custom-content .hero {
        height: 60vh;
        min-height: 500px; }
        @media (max-width: 991.98px) {
          body #cherieYoung #custom-content .hero {
            height: 65vh;
            min-height: 500px; } }
        @media (max-width: 600px) {
          body #cherieYoung #custom-content .hero {
            height: 40vh;
            min-height: 450px; } }
        body #cherieYoung #custom-content .hero .hero-content {
          height: 100%;
          width: 100%;
          text-align: center;
          display: flex;
          justify-content: center;
          align-items: center;
          position: relative;
          flex-direction: column;
          padding-bottom: 0; }
          body #cherieYoung #custom-content .hero .hero-content .hero-text {
            position: absolute;
            z-index: 3; }
            body #cherieYoung #custom-content .hero .hero-content .hero-text h2 {
              font-weight: 300;
              letter-spacing: 5px;
              font-size: 4rem; }
              @media (max-width: 1200px) {
                body #cherieYoung #custom-content .hero .hero-content .hero-text h2 {
                  font-size: 2.5rem; } }
              @media (max-width: 991px) {
                body #cherieYoung #custom-content .hero .hero-content .hero-text h2 {
                  padding-top: 10px;
                  font-size: 1.5rem; } }
      body #cherieYoung #custom-content .intro {
        background: #fff;
        padding: 60px 20px; }
        body #cherieYoung #custom-content .intro .container {
          width: 100%;
          max-width: 1300px;
          margin: 0 auto; }
        body #cherieYoung #custom-content .intro h2 {
          color: #001f54;
          text-align: center;
          font-family: "Josefin Sans", Sans-serif;
          font-size: 3rem;
          font-weight: 400;
          margin-bottom: 40px;
          text-transform: uppercase; }
        body #cherieYoung #custom-content .intro p, body #cherieYoung #custom-content .intro ul > li {
          font-family: Arial, Helvetica, sans-serif;
          text-align: left;
          line-height: 1.4;
          color: #001f54;
          font-size: 18px;
          margin-bottom: 15px; }
      body #cherieYoung #custom-content strong {
        font-weight: bold; }
      body #cherieYoung #custom-content .vacation-rentals {
        padding: 60px 20px;
        background-color: #fff;
        /* NEW LAYOUT */ }
        body #cherieYoung #custom-content .vacation-rentals .container {
          max-width: 1200px;
          margin: 0 auto; }
        body #cherieYoung #custom-content .vacation-rentals h2.section-title {
          text-align: center;
          font-family: "Josefin Sans", Sans-serif;
          font-size: 3rem;
          font-weight: 400;
          margin-bottom: 40px;
          color: #001f54; }
        body #cherieYoung #custom-content .vacation-rentals .vacation-rentals-grid {
          display: flex;
          flex-wrap: wrap;
          justify-content: center;
          gap: 20px; }
        body #cherieYoung #custom-content .vacation-rentals .rental-card {
          display: flex;
          flex-direction: column;
          align-items: center;
          flex: 0 1 calc(25% - 20px);
          max-width: calc(25% - 20px);
          text-align: center; }
        body #cherieYoung #custom-content .vacation-rentals .rental-item {
          width: 100%;
          display: block;
          background-color: #fff;
          transition: transform 0.3s ease; }
          body #cherieYoung #custom-content .vacation-rentals .rental-item:hover {
            transform: translateY(-3px); }
          body #cherieYoung #custom-content .vacation-rentals .rental-item .rental-image {
            width: 100%;
            aspect-ratio: 7 / 4;
            background-size: cover;
            background-position: center;
            background-repeat: no-repeat;
            border-radius: 4px; }
        body #cherieYoung #custom-content .vacation-rentals .rental-card h2 {
          margin-top: 14px;
          margin-bottom: 0;
          font-family: "Josefin Sans", Sans-serif;
          font-size: 1.1rem;
          font-weight: 400;
          color: #001f54; }
      body #cherieYoung #custom-content .vacation-rentals.kihei .rental-card {
        flex: 0 1 calc(25% - 20px);
        max-width: calc(25% - 20px); }
      body #cherieYoung #custom-content .vacation-rentals.kihei .rental-card:nth-last-child(-n+4) {
        flex-grow: 1; }
      body #cherieYoung #custom-content .vacation-rentals.wailea .rental-card {
        flex: 0 1 calc(20% - 20px);
        max-width: calc(20% - 20px); }
      body #cherieYoung #custom-content .vacation-rentals.waikiki .rental-card {
        flex: 0 1 calc(25% - 20px);
        max-width: calc(25% - 20px); }
      @media (max-width: 991px) {
        body #cherieYoung #custom-content .rental-card {
          flex: 0 1 calc(33.33% - 20px) !important;
          max-width: calc(33.33% - 20px) !important; } }
      @media (max-width: 600px) {
        body #cherieYoung #custom-content .rental-card {
          flex: 0 1 calc(50% - 20px) !important;
          max-width: calc(50% - 20px) !important; } }
      @media (max-width: 400px) {
        body #cherieYoung #custom-content .rental-card {
          flex: 0 1 100% !important;
          max-width: 100% !important; } }
