/**
 * Single Property Content Section Styles
 * 
 * Styles for the property detail page content following BEM methodology
 * and using the wbl design system variables
 * 
 * @package wbl
 */

/* ================================================================
   BASE CONTAINER
   ================================================================ */

.content-property {
  padding-top: var(--spacing-xl);
  padding-bottom: var(--spacing-xl);
}

/* ================================================================
   MAIN GRID LAYOUT
   ================================================================ */

.content-property__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--spacing-xl);
  margin-bottom: var(--spacing-xl);
}

@media (min-width: 1024px) {
  .content-property__grid {
    grid-template-columns: 1fr 400px;
    gap: var(--spacing-xl);
  }
}

/* Left Column */
.content-property__main {
  /* Base styles handled by grid */
}

/* Right Column (Aside/Gallery) */
.content-property__aside {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-md);
  margin-bottom: var(--spacing-xl);
}

@media (min-width: 1024px) {
  .content-property__aside {
    position: sticky;
    top: calc(var(--spacing-lg) + 60px); /* Account for header */
    height: fit-content;
  }
}

/* ================================================================
   PROPERTY HEADER
   ================================================================ */

.content-property__title {
  font-size: var(--font-size-h2);
  color: var(--color-primary);
  font-weight: var(--font-weight-bold);
  margin-bottom: var(--spacing-xs);
}

@media (min-width: 768px) {
  .content-property__title {
    font-size: var(--font-size-h1);
  }
}

.content-property__location {
  font-size: var(--font-size-h5);
  color: var(--color-text-secondary);
  margin-bottom: var(--spacing-lg);
}

/* ================================================================
   STATUS & PRICE GRID
   ================================================================ */

.content-property__status-price {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--spacing-lg);
  margin-bottom: var(--spacing-xl);
  padding: var(--spacing-md);
  background-color: var(--color-bg-alt);
  border-radius: var(--radius-medium);
}

.content-property__status-price-item > div:first-child {
  font-size: var(--font-size-body);
  color: var(--color-text-secondary);
  margin-bottom: var(--spacing-xs);
}

.content-property__status-price-item > div:last-child {
  font-size: var(--font-size-h4);
  color: var(--color-text-primary);
  font-weight: var(--font-weight-medium);
}

.content-property__price-icon {
  font-size: var(--font-size-h5);
  color: var(--color-primary);
}


/* ================================================================
   BROCHURE SECTION
   ================================================================ */

.content-property__brochure {
  margin-top: var(--spacing-xl);
  padding: var(--spacing-md);
  background-color: var(--color-bg-alt);
  border-radius: var(--radius-medium);
  box-shadow: var(--shadow-light);
  display: flex;
  flex-direction: column;
  gap: var(--spacing-sm);
}

@media (min-width: 640px) {
  .content-property__brochure {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
  }
}

.content-property__brochure-content {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
}

.content-property__brochure-icon {
  width: 24px;
  height: 24px;
  flex-shrink: 0;
  color: var(--color-primary);
}

.content-property__brochure-text {
  color: var(--color-text-primary);
  font-weight: var(--font-weight-medium);
}

.content-property__brochure-button {
  flex-shrink: 0;
}

/* ================================================================
   DESCRIPTION SECTION
   ================================================================ */

.content-property__description-section {
  margin-top: var(--spacing-xl);
}

.content-property__description-title {
  font-size: var(--font-size-h3);
  font-weight: var(--font-weight-bold);
  margin-bottom: var(--spacing-md);
  color: var(--color-text-primary);
}

.content-property__description-content {
  color: var(--color-text-primary);
  font-size: var(--font-size-body);
  line-height: var(--line-height-body);
}

.content-property__description-content p {
  margin-bottom: var(--spacing-sm);
}

.content-property__description-content ul,
.content-property__description-content ol {
  margin-bottom: var(--spacing-sm);
  padding-inline-start: var(--spacing-lg);
}

.content-property__description-content li {
  margin-bottom: var(--spacing-xs);
}

/* ================================================================
   FEATURES SECTION
   ================================================================ */

.content-property__features-section {
  margin-top: var(--spacing-xl);
  padding-top: var(--spacing-lg);
  border-top: 1px solid rgba(0, 0, 0, 0.1);
}

.content-property__features-title {
  font-size: var(--font-size-h4);
  font-weight: var(--font-weight-bold);
  margin-bottom: var(--spacing-md);
  color: var(--color-text-primary);
}

.content-property__features-list {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--spacing-sm);
}

@media (min-width: 640px) {
  .content-property__features-list {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--spacing-sm) var(--spacing-md);
  }
}

.content-property__features-item {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  padding: var(--spacing-sm);
  background-color: var(--color-bg-alt);
  border-radius: var(--radius-small);
}

.content-property__features-icon {
  width: 24px;
  height: 24px;
  color: var(--color-primary);
  flex-shrink: 0;
}

.content-property__features-icon svg {
  width: 100%;
  height: 100%;
}

.content-property__features-label {
  color: var(--color-text-primary);
  font-size: var(--font-size-body);
}

/* ================================================================
   WARRANTIES SECTION
   ================================================================ */

.content-property__warranties-section {
  margin-top: var(--spacing-xl);
  padding-top: var(--spacing-lg);
  border-top: 1px solid rgba(0, 0, 0, 0.1);
}

.content-property__warranties-title {
  font-size: var(--font-size-h4);
  font-weight: var(--font-weight-bold);
  margin-bottom: var(--spacing-md);
  color: var(--color-text-primary);
}

.content-property__warranties-list {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--spacing-sm);
}

@media (min-width: 640px) {
  .content-property__warranties-list {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--spacing-sm) var(--spacing-md);
  }
}

.content-property__warranties-item {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  padding: var(--spacing-sm);
  background-color: var(--color-bg-alt);
  border-radius: var(--radius-small);
  border: 1px solid var(--color-primary-light);
}

.content-property__warranties-icon {
  width: 24px;
  height: 24px;
  color: var(--color-primary);
  flex-shrink: 0;
}

.content-property__warranties-icon svg {
  width: 100%;
  height: 100%;
}

.content-property__warranties-icon--default {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  font-weight: var(--font-weight-bold);
}

.content-property__warranties-label {
  color: var(--color-text-primary);
  font-size: var(--font-size-body);
}

/* ================================================================
   ADDITIONAL FEATURES SECTION
   ================================================================ */

.content-property__additional-features-section {
  margin-top: var(--spacing-xl);
  padding-top: var(--spacing-lg);
  border-top: 1px solid rgba(0, 0, 0, 0.1);
}

.content-property__additional-features-title {
  font-size: var(--font-size-h4);
  font-weight: var(--font-weight-bold);
  margin-bottom: var(--spacing-md);
  color: var(--color-text-primary);
}

.content-property__additional-features-list {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--spacing-sm);
}

@media (min-width: 640px) {
  .content-property__additional-features-list {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--spacing-sm) var(--spacing-md);
  }
}

.content-property__additional-features-item {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  padding: var(--spacing-sm);
  background-color: var(--color-bg-alt);
  border-radius: var(--radius-small);
}

.content-property__additional-features-icon {
  width: 24px;
  height: 24px;
  color: var(--color-primary);
  flex-shrink: 0;
}

.content-property__additional-features-icon svg {
  width: 100%;
  height: 100%;
}

.content-property__additional-features-icon--default {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
}

.content-property__additional-features-label {
  color: var(--color-text-primary);
  font-size: var(--font-size-body);
}

/* ================================================================
   PROXIMITY TO LANDMARKS SECTION
   ================================================================ */

.content-property__proximity-section {
  margin-top: var(--spacing-xl);
  padding-top: var(--spacing-lg);
  border-top: 1px solid rgba(0, 0, 0, 0.1);
}

.content-property__proximity-title {
  font-size: var(--font-size-h4);
  font-weight: var(--font-weight-bold);
  margin-bottom: var(--spacing-md);
  color: var(--color-text-primary);
}

.content-property__proximity-list {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--spacing-sm);
}

@media (min-width: 640px) {
  .content-property__proximity-list {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--spacing-sm) var(--spacing-md);
  }
}

.content-property__proximity-item {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  padding: var(--spacing-sm) var(--spacing-md);
  background-color: var(--color-bg-alt);
  border-radius: var(--radius-small);
}

.content-property__proximity-icon {
  width: 24px;
  height: 24px;
  color: var(--color-primary);
  flex-shrink: 0;
}

.content-property__proximity-text {
  color: var(--color-text-primary);
  font-size: var(--font-size-body);
  line-height: 1.4;
}

/* ================================================================
   ACTION BUTTONS
   ================================================================ */

.content-property__actions {
  margin-top: var(--spacing-lg);
  margin-bottom: var(--spacing-xl);
  display: flex;
  flex-direction: column;
  gap: var(--spacing-sm);
}

.content-property__actions--grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--spacing-sm);
}

@media (min-width: 640px) {
  .content-property__actions--grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

.content-property__action-button {
  display: block;
  width: 100%;
  text-align: center;
  padding: var(--spacing-sm) var(--spacing-md);
  border-radius: var(--radius-small);
  font-size: var(--font-size-body);
  font-weight: var(--font-weight-medium);
  transition: all var(--transition-fast);
  text-decoration: none;
}

/* ================================================================
   GALLERY (ASIDE)
   ================================================================ */

.content-property__featured-image {
  border-radius: var(--radius-medium);
  overflow: hidden;
  box-shadow: var(--shadow-medium);
}

.content-property__featured-image img {
  width: 100%;
  height: auto;
  object-fit: cover;
  aspect-ratio: 4 / 3;
  display: block;
}

.content-property__gallery-thumbnails {
  /* Container styles */
}

.content-property__gallery-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--spacing-xs);
}

@media (min-width: 640px) {
  .content-property__gallery-grid {
    grid-template-columns: repeat(4, 1fr);
  }
}

.content-property__gallery-thumb {
  display: block;
  border-radius: var(--radius-small);
  overflow: hidden;
  box-shadow: var(--shadow-light);
  aspect-ratio: 1 / 1;
  position: relative;
}

.content-property__gallery-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transition-medium);
}

.content-property__gallery-thumb:hover img {
  transform: scale(1.05);
}

/* ================================================================
   UNIT DETAILS SECTION
   ================================================================ */

.property-units {
  padding-top: var(--spacing-xxl);
  padding-bottom: var(--spacing-xxl);
  background-color: var(--color-bg-alt);
}

.property-units__title {
  font-size: var(--font-size-h2);
  font-weight: var(--font-weight-bold);
  margin-bottom: var(--spacing-xl);
  text-align: center;
  color: var(--color-text-primary);
}

.property-units__list {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-md);
}

/* Unit Item */
.property-unit {
  padding: var(--spacing-md);
  background-color: var(--color-white);
  border-radius: var(--radius-medium);
  box-shadow: var(--shadow-light);
  border: 1px solid rgba(0, 0, 0, 0.05);
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--spacing-sm);
}

@media (min-width: 768px) {
  .property-unit {
    grid-template-columns: 1fr auto auto;
    align-items: center;
  }
}

.property-unit__info {
  flex: 1;
}

.property-unit__title {
  font-size: var(--font-size-h5);
  font-weight: var(--font-weight-bold);
  color: var(--color-text-primary);
  margin-bottom: var(--spacing-xs);
}

.property-unit__meta {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  font-size: var(--font-size-small);
  color: var(--color-text-secondary);
  margin-bottom: var(--spacing-xs);
}

.property-unit__meta-divider {
  color: rgba(0, 0, 0, 0.2);
}

.property-unit__features-text {
  font-size: var(--font-size-small);
  color: var(--color-text-secondary);
  margin: 0;
}

.property-unit__actions {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-xs);
  align-items: flex-end;
}

@media (max-width: 767px) {
  .property-unit__actions {
    align-items: flex-start;
  }
}

.property-unit__price {
  font-size: var(--font-size-h5);
  font-weight: var(--font-weight-bold);
  color: var(--color-primary);
  margin: 0;
}

.property-unit__price-currency {
  font-size: var(--font-size-body);
  font-weight: var(--font-weight-regular);
}

.property-unit__status-wrapper {
  display: flex;
}

.property-unit__status {
  padding: 0.25rem 0.75rem;
  font-size: var(--font-size-small);
  font-weight: var(--font-weight-medium);
  border-radius: 9999px;
  display: inline-block;
}

.property-unit__status--available {
  background-color: #D1FAE5;
  color: #065F46;
}

.property-unit__status--sold {
  background-color: #FECACA;
  color: #991B1B;
}

.property-unit__status--reserved {
  background-color: #FEF3C7;
  color: #92400E;
}

.property-unit__status--rented {
  background-color: #E0E7FF;
  color: #3730A3;
}

.property-unit__floorplan {
  width: 80px;
  height: 80px;
  flex-shrink: 0;
}

@media (min-width: 640px) {
  .property-unit__floorplan {
    width: 100px;
    height: 100px;
  }
}

.property-unit__floorplan-link {
  display: block;
  width: 100%;
  height: 100%;
  border-radius: var(--radius-small);
  border: 1px solid rgba(0, 0, 0, 0.1);
  overflow: hidden;
  box-shadow: var(--shadow-light);
}

.property-unit__floorplan-link img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transition-medium);
}

.property-unit__floorplan-link:hover img {
  transform: scale(1.05);
}

/* ================================================================
   ANIMATIONS
   ================================================================ */

@media (prefers-reduced-motion: no-preference) {
  /* Base animation setup for all animatable elements */
  .content-property__title,
  .content-property__location,
  .content-property__status-price,
  .content-property__brochure,
  .content-property__description-section,
  .content-property__actions,
  .content-property__features-section,
  .content-property__warranties-section,
  .content-property__additional-features-section,
  .content-property__proximity-section,
  .content-property__aside > *,
  .property-unit {
    opacity: 0;
    transform: translateY(20px);
    animation: fadeInUp 0.6s ease forwards;
  }

  /* Staggered animation delays for main content sections */
  .content-property__title { animation-delay: 0.1s; }
  .content-property__location { animation-delay: 0.15s; }
  .content-property__status-price { animation-delay: 0.2s; }
  .content-property__brochure { animation-delay: 0.25s; }
  .content-property__description-section { animation-delay: 0.3s; }
  .content-property__actions { animation-delay: 0.35s; }
  .content-property__features-section { animation-delay: 0.4s; }
  .content-property__warranties-section { animation-delay: 0.45s; }
  .content-property__additional-features-section { animation-delay: 0.5s; }
  .content-property__proximity-section { animation-delay: 0.55s; }

  /* Animation for aside gallery */
  .content-property__aside > *:nth-child(1) { animation-delay: 0.2s; }
  .content-property__aside > *:nth-child(2) { animation-delay: 0.3s; }

  /* Animation for unit list items */
  .property-unit:nth-child(1) { animation-delay: 0.1s; }
  .property-unit:nth-child(2) { animation-delay: 0.15s; }
  .property-unit:nth-child(3) { animation-delay: 0.2s; }
  .property-unit:nth-child(4) { animation-delay: 0.25s; }
  .property-unit:nth-child(5) { animation-delay: 0.3s; }
  .property-unit:nth-child(6) { animation-delay: 0.35s; }
  .property-unit:nth-child(7) { animation-delay: 0.4s; }
  .property-unit:nth-child(8) { animation-delay: 0.45s; }
  .property-unit:nth-child(9) { animation-delay: 0.5s; }
  .property-unit:nth-child(10) { animation-delay: 0.55s; }

  @keyframes fadeInUp {
    to {
      opacity: 1;
      transform: translateY(0);
    }
  }
}