/* Our Services Section Component Styles */

.our-services-section {
  position: relative;
  width: 100%;
  min-height: 100vh;
  height: 100vh;
  background: var(--Primary-100, #680144);
  display: flex;
  overflow: hidden;
}

.our-services-section-container {
  position: relative;
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: row;
}

/* Left Side: Fixed Image (50%) */
.our-services-section-image-wrapper {
  position: sticky;
  top: 0;
  width: 50%;
  height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  flex-shrink: 0;
}

.our-services-section-image {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}

.our-services-section-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

/* Right Side: Scrollable Content (50%) */
.our-services-section-content-wrapper {
  width: 50%;
  height: 100vh;
  overflow-y: auto;
  overflow-x: hidden;
  flex-shrink: 0;
}

.our-services-section-content {
  position: relative;
  width: 100%;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  padding: 4rem 3rem;
  gap: 2rem;
}

/* Initial Content */
.our-services-initial-content {
  display: flex;
  flex-direction: column;
  gap: 2rem;
  min-height: 100vh;
  justify-content: center;
  opacity: 1;
  transition: opacity 0.6s ease-out;
}

.our-services-initial-content.fade-out {
  opacity: 0;
  pointer-events: none;
}

/* Subtitle */
.our-services-subtitle {
  color: var(--Tertiary-100, #F6E0DF);
  font-family: "DM Sans", sans-serif;
  font-size: 18px;
  font-style: normal;
  font-weight: 500;
  line-height: 140%; /* 25.2px */
  letter-spacing: 0.9px;
  text-transform: uppercase;
}

/* Title */
.our-services-title {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.our-services-title-part-1 {
  color: var(--Tertiary-100, #F6E0DF);
  font-family: "DM Sans", sans-serif;
  font-size: 48px;
  font-style: normal;
  font-weight: 400;
  line-height: 140%; /* 67.2px */
  letter-spacing: -0.96px;
}

.our-services-title-part-2 {
  color: var(--Tertiary-100, #F6E0DF);
  font-family: Calluna, serif;
  font-size: 52px;
  font-style: italic;
  font-weight: 400;
  line-height: 110%;
  letter-spacing: -1.04px;
}

/* Description */
.our-services-description {
  color: var(--Tertiary-100, #F6E0DF);
  font-family: "DM Sans", sans-serif;
  font-size: 18px;
  font-style: normal;
  font-weight: 400;
  line-height: 140%; /* 25.2px */
  letter-spacing: -0.36px;
}

.our-services-description p {
  margin: 0;
  padding: 0;
  color: var(--Tertiary-100, #F6E0DF);
  font-family: "DM Sans", sans-serif;
  font-size: 18px;
  font-style: normal;
  font-weight: 400;
  line-height: 140%; /* 25.2px */
  letter-spacing: -0.36px;
}

/* Button Wrapper */
.our-services-button-wrapper {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  margin-top: 1rem;
}

/* Button */
.our-services-button {
  display: flex;
  width: 200px;
  padding: 16px;
  justify-content: center;
  align-items: center;
  gap: 10px;
  border-radius: 8px;
  border: 1px solid var(--Tertiary-100, #F6E0DF);
  background: transparent;
  color: var(--Tertiary-100, #F6E0DF);
  text-align: center;
  font-family: "DM Sans", sans-serif;
  font-size: 18px;
  font-style: normal;
  font-weight: 400;
  line-height: 140%; /* 25.2px */
  letter-spacing: -0.36px;
  text-decoration: none;
  transition: background-color 0.3s ease, color 0.3s ease;
  cursor: pointer;
}

.our-services-button:hover {
  background-color: var(--Tertiary-100, #F6E0DF);
  color: var(--Primary-100, #680144);
}

/* List Content */
.our-services-list-content {
  display: flex;
  flex-direction: column;
  gap: 0;
  padding-top: 2rem;
  opacity: 0;
  transition: opacity 0.6s ease-in;
}

.our-services-list-content.fade-in {
  opacity: 1;
}

/* List Item */
.our-services-list-item {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  padding: 2rem 0;
  border-top: 1px solid var(--Tertiary-100, #F6E0DF);
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 0.6s ease-out, transform 0.6s ease-out;
}

.our-services-list-item.visible {
  opacity: 1;
  transform: translateY(0);
}

.our-services-list-item:first-child {
  border-top: none;
}

/* List Item Header */
.our-services-list-item-header {
  display: flex;
  flex-direction: row;
  align-items: flex-start;
  gap: 1.5rem;
}

/* List Item Number */
.our-services-list-item-number {
  color: var(--Tertiary-100, #F6E0DF);
  font-family: "DM Sans", sans-serif;
  font-size: 16px;
  font-style: normal;
  font-weight: 400;
  line-height: 140%; /* 22.4px */
  letter-spacing: 0.8px;
  text-transform: uppercase;
  flex-shrink: 0;
  min-width: 60px;
}

/* List Item Title */
.our-services-list-item-title {
  color: var(--Tertiary-100, #F6E0DF);
  font-family: "DM Sans", sans-serif;
  font-size: 24px;
  font-style: normal;
  font-weight: 400;
  line-height: 120%; /* 28.8px */
  letter-spacing: -1.2px;
  margin: 0;
  padding: 0;
  flex: 1;
}

/* List Item Description */
.our-services-list-item-description {
  color: var(--Tertiary-100, #F6E0DF);
  font-family: "DM Sans", sans-serif;
  font-size: 18px;
  font-style: normal;
  font-weight: 400;
  line-height: 140%; /* 25.2px */
  letter-spacing: -0.36px;
  margin: 0;
  padding: 0;
  padding-left: calc(60px + 1.5rem); /* Align with title */
}

.our-services-list-item-description p {
  margin: 0;
  padding: 0;
  color: var(--Tertiary-100, #F6E0DF);
  font-family: "DM Sans", sans-serif;
  font-size: 18px;
  font-style: normal;
  font-weight: 400;
  line-height: 140%; /* 25.2px */
  letter-spacing: -0.36px;
}

/* See More Button Wrapper */
.our-services-see-more-button-wrapper {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  margin-top: 2rem;
  padding-top: 2rem;
}

/* See More Button */
.our-services-see-more-button {
  display: flex;
  width: 200px;
  padding: 16px;
  justify-content: center;
  align-items: center;
  gap: 10px;
  border-radius: 8px;
  border: 1px solid var(--Tertiary-100, #F6E0DF);
  background: transparent;
  color: var(--Tertiary-100, #F6E0DF);
  text-align: center;
  font-family: "DM Sans", sans-serif;
  font-size: 18px;
  font-style: normal;
  font-weight: 400;
  line-height: 140%; /* 25.2px */
  letter-spacing: -0.36px;
  text-decoration: none;
  transition: background-color 0.3s ease, color 0.3s ease;
  cursor: pointer;
}

.our-services-see-more-button:hover {
  background-color: var(--Tertiary-100, #F6E0DF);
  color: var(--Primary-100, #680144);
}

/* Responsive Styles - Tablet (768px - 1023px) */
@media (min-width: 768px) and (max-width: 1023px) {
  .our-services-section {
    flex-direction: column;
    height: auto;
    min-height: auto;
  }
  
  .our-services-section-container {
    flex-direction: column;
  }
  
  .our-services-section-image-wrapper {
    position: relative;
    width: 100%;
    height: 50vh;
    min-height: 400px;
    order: 1;
  }
  
  .our-services-section-content-wrapper {
    width: 100%;
    height: auto;
    min-height: 50vh;
    order: 2;
  }
  
  .our-services-section-content {
    padding: 3rem 2rem;
    min-height: auto;
  }
  
  .our-services-initial-content {
    min-height: auto;
    padding: 2rem 0;
  }
  
  .our-services-title-part-1 {
    font-size: 40px;
    letter-spacing: -0.8px;
  }
  
  .our-services-title-part-2 {
    font-size: 44px;
    letter-spacing: -0.88px;
  }
  
  .our-services-subtitle {
    font-size: 16px;
    letter-spacing: 0.8px;
  }
  
  .our-services-description {
    font-size: 16px;
    letter-spacing: -0.32px;
  }
  
  .our-services-button,
  .our-services-see-more-button {
    font-size: 16px;
    letter-spacing: -0.32px;
    padding: 14px;
  }
}

/* Responsive Styles - Mobile (max-width: 767px) */
@media (max-width: 767px) {
  .our-services-section {
    flex-direction: column;
    height: auto;
    min-height: auto;
  }
  
  .our-services-section-container {
    flex-direction: column;
  }
  
  .our-services-section-image-wrapper {
    position: relative;
    width: 100%;
    height: 40vh;
    min-height: 300px;
    order: 1;
  }
  
  .our-services-section-content-wrapper {
    width: 100%;
    height: auto;
    min-height: auto;
    order: 2;
  }
  
  .our-services-section-content {
    padding: 2rem 1.5rem;
    min-height: auto;
    gap: 1.5rem;
  }
  
  .our-services-initial-content {
    min-height: auto;
    padding: 1.5rem 0;
    gap: 1.5rem;
    opacity: 1;
    transition: opacity 0.6s ease-out;
  }
  
  .our-services-initial-content.fade-out {
    opacity: 0;
    pointer-events: none;
  }
  
  .our-services-subtitle {
    font-size: 16px;
    letter-spacing: 0.8px;
  }
  
  .our-services-title-part-1 {
    font-size: 32px;
    letter-spacing: -0.64px;
    line-height: 130%;
  }
  
  .our-services-title-part-2 {
    font-size: 36px;
    letter-spacing: -0.72px;
    line-height: 110%;
  }
  
  .our-services-description {
    font-size: 16px;
    letter-spacing: -0.32px;
  }
  
  .our-services-button,
  .our-services-see-more-button {
    width: 100%;
    max-width: 300px;
    font-size: 16px;
    letter-spacing: -0.32px;
    padding: 14px;
  }
  
  .our-services-list-item {
    padding: 1.5rem 0;
  }
  
  .our-services-list-item-header {
    flex-direction: column;
    gap: 0.75rem;
  }
  
  .our-services-list-item-number {
    font-size: 14px;
    letter-spacing: 0.7px;
    min-width: auto;
  }
  
  .our-services-list-item-title {
    font-size: 20px;
    letter-spacing: -1px;
  }
  
  .our-services-list-item-description {
    font-size: 16px;
    letter-spacing: -0.32px;
    padding-left: 0;
  }
  
  .our-services-see-more-button-wrapper {
    margin-top: 1.5rem;
    padding-top: 1.5rem;
  }
  
  /* On mobile, ensure list content is visible by default */
  .our-services-list-content {
    opacity: 1;
  }
  
  /* On mobile, items should be visible when scrolled into view */
  /* The JavaScript will add 'visible' class via Intersection Observer */
}
