/* ====================
CONTENT PANEL GRID ASPECT COMPONENT
==================== */
/* ====================
MAIN CONTAINER
==================== */
.content-panel-grid-aspect-section {
  display: flex;
  width: 100%;
  max-width: var(--max-width-lg);
  flex-direction: column;
  align-items: center;
  gap: var(--spacing-4x);
  position: relative;
  margin-bottom: var(--major-section-spacing);
}

/* ====================
HEADER SECTION
==================== */
.content-panel-grid-aspect-header {
  display: flex;
  width: 100%;
  max-width: 800px;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: var(--spacing-xl);
}

.content-panel-grid-aspect-title {
  color: var(--theme-text);
  font-size: var(--font-size-2xl-plus);
  font-weight: 500;
  line-height: var(--line-height-2xl-plus);
  margin: 0;
}

.content-panel-grid-aspect-description {
  color: var(--theme-text);
  font-size: var(--font-size-sm);
  font-weight: 400;
  line-height: var(--line-height-lg);
  margin: 0;
}

/* ====================
CONTENT CONTAINER
==================== */
.content-panel-grid-aspect-content {
  display: flex;
  width: 100%;
  align-items: stretch;
  gap: var(--spacing-md);
  flex-wrap: wrap;
  padding: var(--spacing-md);
  border-radius: var(--border-radius-outer);
  border: var(--theme-border-panel);
  background: transparent;
}

/* Full-width rows inside a single aspect content box (e.g. team photo + stacked rows) */
.content-panel-grid-aspect-content > .wide-images-container {
  flex: 1 1 100%;
}

.content-panel-grid-aspect-content > .content-panel-grid-aspect-row {
  display: flex;
  flex-wrap: wrap;
  width: 100%;
  flex: 1 1 100%;
  gap: var(--spacing-md);
  align-items: stretch;
}

.content-panel-grid-aspect-content > .content-panel-grid-aspect-row.progression-left-image {
  flex-direction: row-reverse;
}

.content-panel-grid-aspect-content > .content-panel-grid-aspect-row.progression-left-image .content-panel-grid-aspect-details-panel {
  flex: 0 0 40%;
  min-width: 280px;
}

.content-panel-grid-aspect-content > .content-panel-grid-aspect-row.progression-left-image .content-panel-grid-aspect-image-panel {
  flex: 1;
  min-width: 280px;
}

@media (max-width: 1024px) {
  .content-panel-grid-aspect-content > .content-panel-grid-aspect-row.progression-left-image {
    flex-direction: column-reverse;
  }
  .content-panel-grid-aspect-content > .content-panel-grid-aspect-row.progression-left-image .content-panel-grid-aspect-details-panel,
  .content-panel-grid-aspect-content > .content-panel-grid-aspect-row.progression-left-image .content-panel-grid-aspect-image-panel {
    flex: 1 1 100%;
    min-width: 0;
  }
}
/* ====================
CONCEPT DETAILS PANEL
==================== */
.content-panel-grid-aspect-details-panel {
  display: flex;
  flex-direction: column;
  flex: 0 0 40%; /* Fixed 40% width for smaller content */
  min-width: 280px;
  gap: var(--spacing-md);
  padding: var(--spacing-xl) var(--spacing-lg); /* Reduced horizontal padding from var(--spacing-2x) to var(--spacing-lg) */
  border-radius: var(--border-radius);
  border: var(--theme-border-panel);
  background: var(--zing-dark-background);
}

.content-panel-grid-aspect-details-title {
  color: var(--color-primary);
  font-size: var(--font-size-lg);
  font-weight: 500;
  line-height: calc(var(--line-height-2xl) + 0.5rem);
  margin: 0;
}

.content-panel-grid-aspect-details-divider {
  width: 100%;
  height: 1px;
  margin: var(--spacing-md) 0;
  border: var(--theme-border-divider); /* Use same stroke variable as boxes */
}

.content-panel-grid-aspect-details-list {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-md);
  margin: 0;
  padding: 0;
  list-style: none;
}

.content-panel-grid-aspect-details-item {
  display: flex;
  align-items: flex-start;
  gap: var(--spacing-md);
}

.content-panel-grid-aspect-details-icon {
  width: 24px;
  height: 24px;
  flex-shrink: 0;
  margin-top: 2px;
  padding-top: 2px;
}

.content-panel-grid-aspect-details-text {
  color: var(--theme-text);
  font-size: var(--font-size-sm);
  font-weight: 400;
  line-height: var(--line-height-lg);
  margin: 0;
}

/* ====================
IMAGE PANEL
==================== */
.content-panel-grid-aspect-image-panel {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 1fr 1fr;
  gap: var(--spacing-md);
  flex: 1; /* Changed from flex: 0 0 55% to flex: 1 to fill remaining space */
  min-width: 400px; /* Larger minimum width for images */
  border-radius: var(--border-radius);
  background: var(--zing-dark-background);
  padding: 0; /* Remove padding to give images more space */
}

/* ====================
ASPECT GRID BOXES (for screenshots/images)
==================== */
.aspect-grid-box {
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--border-radius);
  position: relative;
  min-height: 160px; /* Reduced from 200px to make images less tall */
  overflow: hidden; /* Ensure images don't overflow */
}

.aspect-grid-box.dynamic {
  background-color: var(--zing-dark-background); /* Deep purple */
}

.aspect-grid-box.authentic {
  background-color: #59FF60; /* Bright green */
}

.aspect-grid-box.helpful {
  background-color: #7445FC; /* Bright purple */
}

.aspect-grid-box.transparent {
  background-color: #FC57BA; /* Bright pink */
}

.aspect-grid-icon {
  width: 100%;
  height: 100%;
  object-fit: cover; /* Fill containers maintaining aspect ratio */
  object-position: center;
  border-radius: var(--border-radius);
  cursor: pointer; /* Add lightbox cursor */
  transition: transform 0.3s ease; /* Add hover transition */
}

.aspect-grid-box:hover .aspect-grid-icon {
  transform: scale(1.02); /* Add hover effect */
}

/* ====================
SINGLE IMAGE VARIANT
==================== */
.content-panel-grid-aspect-image-panel.single-image {
  display: flex !important;
  align-items: center;
  justify-content: center;
  padding: 0;
  grid-template-columns: none !important;
  grid-template-rows: none !important;
  gap: 0 !important;
}

.content-panel-grid-aspect-image-panel.single-image .aspect-grid-box {
  width: 100%;
  height: 100%;
  min-height: 400px;
  border-radius: var(--border-radius);
  border: var(--theme-border-panel);
  overflow: hidden;
}

.content-panel-grid-aspect-image-panel.single-image .aspect-grid-icon {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

.content-panel-grid-aspect-image-panel.single-image.contain-chart {
  padding: 0;
  align-items: stretch;
  justify-content: stretch;
  min-height: 0;
}

.content-panel-grid-aspect-image-panel.single-image.contain-chart .aspect-grid-box {
  width: 100%;
  min-height: 100%;
  height: 100%;
  flex: 1 1 auto;
  align-self: stretch;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--spacing-lg);
  box-sizing: border-box;
}

.content-panel-grid-aspect-image-panel.single-image.contain-chart .aspect-grid-icon {
  width: auto;
  height: auto;
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
  object-position: center;
}

.content-panel-grid-aspect-image-panel.single-image.contain-chart .aspect-grid-box:hover .aspect-grid-icon {
  transform: none;
}

/* ====================
LEFT IMAGE VARIANT
==================== */
.content-panel-grid-aspect-content.left-image {
  flex-direction: row-reverse !important;
}

.content-panel-grid-aspect-content.left-image .content-panel-grid-aspect-details-panel {
  flex: 0 0 40% !important;
  min-width: 280px;
}

.content-panel-grid-aspect-content.left-image .content-panel-grid-aspect-image-panel {
  flex: 1 !important;
  min-width: 400px;
}

/* Ensure left-image variant works on desktop */
@media (min-width: 1025px) {
  .content-panel-grid-aspect-content.left-image {
    flex-direction: row-reverse !important;
  }
}
/* ====================
RESPONSIVE BREAKPOINTS
==================== */
/* Tablet breakpoint (max-width: 1024px) */
@media (max-width: 1024px) {
  .content-panel-grid-aspect-section {
    gap: calc(var(--spacing-md) * 2);
  }
}
@media (max-width: 1024px) and (max-width: 1180px) {
  .content-panel-grid-aspect-section {
    gap: calc(var(--spacing-md) * 2);
  }
}
@media (max-width: 1024px) and (max-width: 1024px) {
  .content-panel-grid-aspect-section {
    gap: calc(var(--spacing-sm) * 2);
  }
}
@media (max-width: 1024px) and (max-width: 740px) {
  .content-panel-grid-aspect-section {
    gap: calc(var(--spacing-xs) * 2);
  }
}
@media (max-width: 1024px) {
  .content-panel-grid-aspect-header {
    gap: calc(var(--spacing-md) * 1.5);
  }
}
@media (max-width: 1024px) and (max-width: 1180px) {
  .content-panel-grid-aspect-header {
    gap: calc(var(--spacing-md) * 1.5);
  }
}
@media (max-width: 1024px) and (max-width: 1024px) {
  .content-panel-grid-aspect-header {
    gap: calc(var(--spacing-sm) * 1.5);
  }
}
@media (max-width: 1024px) and (max-width: 740px) {
  .content-panel-grid-aspect-header {
    gap: calc(var(--spacing-xs) * 1.5);
  }
}
@media (max-width: 1024px) {
  .content-panel-grid-aspect-title {
    font-size: var(--font-size-2xl);
    line-height: var(--line-height-xl);
  }
  .content-panel-grid-aspect-description {
    font-size: var(--font-size-sm);
    line-height: var(--line-height-lg);
  }
  .content-panel-grid-aspect-content {
    gap: calc(var(--spacing-md) * 1);
    padding: calc(var(--spacing-md) * 1);
  }
}
@media (max-width: 1024px) and (max-width: 1180px) {
  .content-panel-grid-aspect-content {
    gap: calc(var(--spacing-md) * 1);
  }
}
@media (max-width: 1024px) and (max-width: 1024px) {
  .content-panel-grid-aspect-content {
    gap: calc(var(--spacing-sm) * 1);
  }
}
@media (max-width: 1024px) and (max-width: 740px) {
  .content-panel-grid-aspect-content {
    gap: calc(var(--spacing-xs) * 1);
  }
}
@media (max-width: 1024px) and (max-width: 1180px) {
  .content-panel-grid-aspect-content {
    padding: calc(var(--spacing-md) * 1);
  }
}
@media (max-width: 1024px) and (max-width: 1024px) {
  .content-panel-grid-aspect-content {
    padding: calc(var(--spacing-sm) * 1);
  }
}
@media (max-width: 1024px) and (max-width: 740px) {
  .content-panel-grid-aspect-content {
    padding: calc(var(--spacing-xs) * 1);
  }
}
@media (max-width: 1024px) {
  .content-panel-grid-aspect-content.left-image {
    flex-direction: column;
  }
  .content-panel-grid-aspect-details-panel {
    padding: calc(var(--spacing-md) * 1);
    /* Reduced from 1.5 to 1 */
  }
}
@media (max-width: 1024px) and (max-width: 1180px) {
  .content-panel-grid-aspect-details-panel {
    padding: calc(var(--spacing-md) * 1);
  }
}
@media (max-width: 1024px) and (max-width: 1024px) {
  .content-panel-grid-aspect-details-panel {
    padding: calc(var(--spacing-sm) * 1);
  }
}
@media (max-width: 1024px) and (max-width: 740px) {
  .content-panel-grid-aspect-details-panel {
    padding: calc(var(--spacing-xs) * 1);
  }
}
@media (max-width: 1024px) {
  .content-panel-grid-aspect-details-title {
    font-size: var(--font-size-md);
    line-height: var(--line-height-md-plus);
  }
  .content-panel-grid-aspect-details-text {
    font-size: var(--font-size-sm);
    line-height: var(--line-height-md);
  }
  .content-panel-grid-aspect-image-panel {
    gap: calc(var(--spacing-md) * 1);
    min-width: 350px; /* Maintain larger minimum width on tablet */
    padding: 0; /* Ensure no padding on tablet */
  }
}
@media (max-width: 1024px) and (max-width: 1180px) {
  .content-panel-grid-aspect-image-panel {
    gap: calc(var(--spacing-md) * 1);
  }
}
@media (max-width: 1024px) and (max-width: 1024px) {
  .content-panel-grid-aspect-image-panel {
    gap: calc(var(--spacing-sm) * 1);
  }
}
@media (max-width: 1024px) and (max-width: 740px) {
  .content-panel-grid-aspect-image-panel {
    gap: calc(var(--spacing-xs) * 1);
  }
}
@media (max-width: 1024px) {
  .content-panel-grid-aspect-image-panel.single-image {
    padding: 0;
  }
  .content-panel-grid-aspect-image-panel.single-image .aspect-grid-box {
    min-height: 300px;
  }
  .aspect-grid-box {
    min-height: 120px; /* Reduced from 150px */
  }
  .aspect-grid-icon {
    width: 100%;
    height: 100%;
    object-fit: cover; /* Fill containers maintaining aspect ratio */
  }
  .content-panel-grid-aspect-image-panel.single-image.contain-chart .aspect-grid-box {
    padding: var(--spacing-md);
  }
}
/* Mobile breakpoint (max-width: 640px) */
@media (max-width: 740px) {
  .content-panel-grid-aspect-section {
    gap: var(--spacing-2x);
  }
  .content-panel-grid-aspect-header {
    gap: var(--spacing-lg);
  }
  .content-panel-grid-aspect-title {
    font-size: var(--font-size-xl);
    line-height: var(--line-height-2xl);
  }
  .content-panel-grid-aspect-description {
    font-size: var(--font-size-xs);
    line-height: var(--line-height-md);
  }
  .content-panel-grid-aspect-content {
    flex-direction: column;
    gap: calc(var(--spacing-md) * 1);
    padding: calc(var(--spacing-md) * 1);
  }
}
@media (max-width: 740px) and (max-width: 1180px) {
  .content-panel-grid-aspect-content {
    gap: calc(var(--spacing-md) * 1);
  }
}
@media (max-width: 740px) and (max-width: 1024px) {
  .content-panel-grid-aspect-content {
    gap: calc(var(--spacing-sm) * 1);
  }
}
@media (max-width: 740px) and (max-width: 740px) {
  .content-panel-grid-aspect-content {
    gap: calc(var(--spacing-xs) * 1);
  }
}
@media (max-width: 740px) and (max-width: 1180px) {
  .content-panel-grid-aspect-content {
    padding: calc(var(--spacing-md) * 1);
  }
}
@media (max-width: 740px) and (max-width: 1024px) {
  .content-panel-grid-aspect-content {
    padding: calc(var(--spacing-sm) * 1);
  }
}
@media (max-width: 740px) and (max-width: 740px) {
  .content-panel-grid-aspect-content {
    padding: calc(var(--spacing-xs) * 1);
  }
}
@media (max-width: 740px) {
  .content-panel-grid-aspect-content.left-image {
    flex-direction: column;
  }
  .content-panel-grid-aspect-details-panel {
    padding: var(--spacing-lg) var(--spacing-md);
    gap: calc(var(--spacing-md) * 1);
  }
}
@media (max-width: 740px) and (max-width: 1180px) {
  .content-panel-grid-aspect-details-panel {
    gap: calc(var(--spacing-md) * 1);
  }
}
@media (max-width: 740px) and (max-width: 1024px) {
  .content-panel-grid-aspect-details-panel {
    gap: calc(var(--spacing-sm) * 1);
  }
}
@media (max-width: 740px) and (max-width: 740px) {
  .content-panel-grid-aspect-details-panel {
    gap: calc(var(--spacing-xs) * 1);
  }
}
@media (max-width: 740px) {
  .content-panel-grid-aspect-details-title {
    font-size: var(--font-size-md);
    line-height: var(--line-height-md-plus);
  }
  .content-panel-grid-aspect-details-text {
    font-size: var(--font-size-xs);
    line-height: var(--line-height-sm);
  }
  .content-panel-grid-aspect-details-divider {
    margin: var(--spacing-md) 0;
  }
  .content-panel-grid-aspect-details-list {
    gap: var(--spacing-md);
    margin-top: var(--spacing-md);
  }
  .content-panel-grid-aspect-details-item {
    gap: var(--spacing-sm);
  }
  .content-panel-grid-aspect-details-icon {
    width: 20px;
    height: 20px;
  }
  .content-panel-grid-aspect-image-panel {
    gap: calc(var(--spacing-md) * 1);
    min-width: 350px; /* Maintain larger minimum width on tablet */
    padding: 0; /* Ensure no padding on tablet */
  }
}
@media (max-width: 740px) and (max-width: 1180px) {
  .content-panel-grid-aspect-image-panel {
    gap: calc(var(--spacing-md) * 1);
  }
}
@media (max-width: 740px) and (max-width: 1024px) {
  .content-panel-grid-aspect-image-panel {
    gap: calc(var(--spacing-sm) * 1);
  }
}
@media (max-width: 740px) and (max-width: 740px) {
  .content-panel-grid-aspect-image-panel {
    gap: calc(var(--spacing-xs) * 1);
  }
}
@media (max-width: 740px) {
  .content-panel-grid-aspect-image-panel.single-image {
    padding: 0;
  }
  .content-panel-grid-aspect-image-panel.single-image .aspect-grid-box {
    min-height: 250px;
  }
  .aspect-grid-box {
    min-height: 120px; /* Reduced from 150px */
  }
  .aspect-grid-icon {
    width: 100%;
    height: 100%;
    object-fit: cover; /* Fill containers maintaining aspect ratio */
  }
}
