/* ========================================
   VILLA ARDORE - EXPERIENCES PAGE STYLES
   ======================================== */

/* ==================
   BASE STYLES
   ================== */
.experiences-page {
    background-color: #fffbf6;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
    color: #4a4a4a;
    line-height: 1.7;
}

.experiences-page * {
    box-sizing: border-box;
}

/* ==================
   SECTION CONTAINERS
   ================== */
.exp-section {
    width: 100%;
    margin: 0 auto;
    padding: 100px 40px;
}

.exp-section-inner {
    max-width: 1400px;
    margin: 0 auto;
}

/* ==================
   HERO SECTION (PAGE 1)
   ================== */
.va-exp-hero {
    display: grid !important;
    grid-template-columns: 70% 40% !important;
    min-height: 100vh !important;
    width: 100% !important;
    max-width: 100% !important;
    padding: 0 !important;
    margin: 0 !important;
    background: none !important;
}

.va-exp-hero-image {
    position: relative !important;
    overflow: hidden !important;
    height: 100vh !important;
    display: flex !important;
    align-items: flex-start !important;
    justify-content: center !important;
    padding-top: 80px !important;
}

.va-exp-hero-image img {
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    object-position: center !important;
    display: block !important;
    z-index: 1 !important;
}

.va-exp-hero-logo {
    position: relative !important;
    z-index: 2 !important;
    max-width: 300px !important;
    width: 100% !important;
}

.va-exp-hero-logo img {
    width: 100% !important;
    height: auto !important;
    display: block !important;
}

  .va-exp-hero-content {
      background-color: #ffffff !important;
      padding: 5vh 8vw 15vh 4vw !important;
      display: flex !important;
      flex-direction: column !important;
      justify-content: flex-end !important;
      align-items: flex-start !important;
      width: 80%;
  }


.va-exp-hero-title {
    font-size: 18px !important;
    font-weight: 600 !important;
    color: #4a4a4a !important;
    margin: 0 0 24px 0 !important;
    line-height: 1.3 !important;
    letter-spacing: -0.3px !important;
    max-width: 320px !important;
   text-transform: none !important;
   text-shadow: none;
}

.va-exp-hero-description {
    font-size: 14px !important;
    line-height: 1.7 !important;
    color: #4a4a4a !important;
    margin: 0 !important;
    max-width: 320px !important;
}

  .va-exp-content-top {
      justify-content: flex-start !important;
      padding: 15vh 8vw 5vh 8vw !important;
  }

  /* Page number badge */
  .va-exp-page-number {
      position: absolute !important;
      bottom: 60px !important;
      right: 60px !important;
      width: 32px !important;
      height: 32px !important;
      border: 2px solid #4a4a4a !important;
      display: flex !important;
      align-items: center !important;
      justify-content: center !important;
      font-size: 14px !important;
      font-weight: 600 !important;
      color: #4a4a4a !important;
      background-color: transparent !important;
  }

/* ==================
   TABLE OF CONTENTS (PAGE 2)
   ================== */
.va-exp-toc {
    position: relative !important;
    min-height: 100vh !important;
    width: 100% !important;
    max-width: 100% !important;
    padding: 0 !important;
    margin: 0 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: flex-end !important;
    overflow: hidden !important;
}

.va-exp-toc-image {
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
    z-index: 1 !important;
}

.va-exp-toc-image img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    object-position: center !important;
    display: block !important;
}

.va-exp-toc-content {
    position: relative !important;
    z-index: 2 !important;
    background-color: transparent !important;
    padding: 60px !important;
    max-width: 380px !important;
    width: 30% !important;
    margin-right: 15% !important;
}
.va-exp-toc-title {
    font-size: 22px !important;
    font-weight: 600 !important;
    color: #ffffff !important;
    margin: 0 0 12px 0 !important;
    letter-spacing: -0.3px !important;
    text-align: left;
}

.va-exp-toc-list {
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
}

.va-exp-toc-item {
    display: flex !important;
    justify-content: space-between !important;
    align-items: baseline !important;
    padding: 2px 0 !important;
}

.va-exp-toc-item:first-child {
}

.va-exp-toc-link {
    font-size: 15px !important;
    color: #ffffff !important;
    text-decoration: none !important;
    transition: color 0.3s ease !important;
    flex: 1 !important;
    font-weight: 400 !important;
}

.va-exp-toc-link:hover {
    color: #bc9366 !important;
}

.va-exp-toc-page {
    font-size: 15px !important;
    color: #ffffff !important;
    margin-left: 20px !important;
    min-width: 25px !important;
    text-align: right !important;
}

.va-exp-download-btn {
    display: inline-block !important;
    margin-top: 35px !important;
    padding: 12px 32px !important;
    background-color: #bc9366 !important;
    color: #ffffff !important;
    text-decoration: none !important;
    font-size: 14px !important;
    font-weight: 500 !important;
    border-radius: 3px !important;
    transition: all 0.3s ease !important;
    border: 2px solid #bc9366 !important;
}

.va-exp-download-btn:hover {
    background-color: rgba(255, 255, 255, 0.1) !important;
    color: #ffffff !important;
    border-color: #ffffff !important;
}

  /* ==================
     PAGE 4 LAYOUT - Private Spa
     ================== */
  .va-exp-page-4 {
      display: grid !important;
      grid-template-columns: 40% 60% !important;
      min-height: 100vh !important;
      max-height: 100vh !important;
      width: 100% !important;
      max-width: 100% !important;
      padding: 0 !important;
      margin: 0 !important;
      background-color: #ffffff !important;
  }

.va-exp-page-4-content {
    background-color: #ffffff !important;
    padding: 5vh 8vw 25vh 5vw !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: flex-end !important;
    position: relative !important;
}

  .va-exp-section-title-main {
      font-size: 24px !important;
      font-weight: 600 !important;
      color: #4a4a4a !important;
      margin: 0 0 24px 0 !important;
      line-height: 1.3 !important;
      max-width: 280px !important;
      text-shadow: none;
      text-align: left;
  }

  .va-exp-section-text-main {
      font-size: 15px !important;
      line-height: 1.7 !important;
      color: #4a4a4a !important;
      margin: 0 !important;
      max-width: 320px !important;
  }

  .va-exp-page-4 .va-exp-page-number {
      position: absolute !important;
      bottom: 60px !important;
      left: 60px !important;
      right: auto !important;
  }

  .va-exp-page-4-image {
      display: flex !important;
      align-items: center !important;
      justify-content: center !important;
      padding: 60px 80px 60px 40px !important;
      background-color: #ffffff !important;
      height: 100vh !important;
      overflow: hidden !important;
  }

  .va-exp-page-4-image img {
      width: 100% !important;
      height: 100% !important;
      object-fit: cover !important;
      object-position: top center !important;
      display: block !important;
  }

/* ==================
   CONTENT SECTIONS
   ================== */
.exp-content-section {
    padding: 100px 40px;
}

.exp-two-col {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 80px;
    align-items: center;
    max-width: 1400px;
    margin: 0 auto;
}

.exp-two-col.reverse {
    grid-template-columns: 1fr 1fr;
}

.exp-two-col.reverse .exp-col-image {
    order: 2;
}

.exp-two-col.reverse .exp-col-content {
    order: 1;
}

.exp-col-image {
    position: relative;
    overflow: hidden;
    border-radius: 4px;
}

.exp-col-image img {
    width: 100%;
    height: auto;
    display: block;
}

.exp-col-content {
    padding: 0 40px;
}

.exp-section-title {
    font-size: 36px;
    font-weight: 600;
    margin: 0 0 30px 0;
    color: #4a4a4a;
    line-height: 1.3;
}

.exp-section-text {
    font-size: 18px;
    line-height: 1.8;
    margin: 0 0 25px 0;
    color: #4a4a4a;
}

.exp-section-text:last-child {
    margin-bottom: 0;
}

/* ==================
   PAGE NUMBER BADGES
   ================== */
.exp-page-number {
    display: inline-block;
    width: 32px;
    height: 32px;
    border: 2px solid #4a4a4a;
    border-radius: 4px;
    text-align: center;
    line-height: 40px;
    font-size: 14px;
    font-weight: 600;
    color: #4a4a4a;
    margin-top: 40px;
}

/* ==================
   MOBILE STYLES
   ================== */
@media (max-width: 1024px) {
    .exp-section {
        padding: 60px 30px;
    }

    .exp-hero-content {
        grid-template-columns: 1fr;
        padding: 40px 30px;
        gap: 40px;
    }

    .exp-hero-text {
        padding-left: 0;
        text-align: center;
    }

    .exp-hero-title {
        font-size: 32px;
    }

    .exp-hero-description {
        font-size: 16px;
    }

    .exp-toc-inner {
        grid-template-columns: 1fr;
    }

    .exp-toc-image {
        min-height: 400px;
    }

    .exp-toc-content {
        padding: 60px 30px;
    }

    .exp-toc-title {
        font-size: 36px;
        margin-bottom: 40px;
    }

    .exp-two-col,
    .exp-two-col.reverse {
        grid-template-columns: 1fr;
        gap: 40px;
    }

    .exp-two-col.reverse .exp-col-image,
    .exp-two-col.reverse .exp-col-content {
        order: initial;
    }

    .exp-col-content {
        padding: 0 20px;
    }

    .exp-section-title {
        font-size: 28px;
    }

    .exp-section-text {
        font-size: 16px;
    }
}

@media (max-width: 768px) {
    .exp-hero-logo img {
        max-width: 280px;
    }

    .exp-hero-title {
        font-size: 28px;
    }

    .exp-toc-title {
        font-size: 32px;
    }

    .exp-toc-link,
    .exp-toc-page {
        font-size: 18px;
    }

    .exp-download-btn {
        width: 100%;
        text-align: center;
    }
}

/* ==================
   UTILITY CLASSES
   ================== */
.text-center {
    text-align: center;
}

.mb-0 {
    margin-bottom: 0 !important;
}

.mt-60 {
    margin-top: 60px;
}
