@charset "UTF-8";
/* ====================
CONTENT PANEL IMAGE RIGHT COMPONENT
==================== */
/* ====================
MAIN CONTAINER
==================== */
.content-panel-image-right-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);
}

/* When a header-only narrative section introduces a following image showcase
   (e.g. "Logo" → wide logo image), the two blocks form a single intro+image
   unit. Default stacking leaves the full --major-section-spacing (200px /
   160px / 64px) between them which reads as a disconnect. Pull the showcase
   up so the final visual gap matches the intra-section gap (--spacing-4x,
   64px) used when header + content are siblings inside one panel section
   (like "Typographic approach"). At mobile --major-section-spacing already
   equals --spacing-4x, so the calc resolves to 0 and nothing changes. */
.content-panel-image-right-section + .content-showcase-section {
  margin-top: calc(var(--spacing-4x) - var(--major-section-spacing));
}

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

.content-panel-image-right-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-image-right-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-image-right-content {
  display: flex;
  width: 100%;
  align-items: stretch;
  gap: var(--spacing-md);
  justify-content: center;
  flex-wrap: wrap;
  padding: var(--spacing-md);
  border-radius: var(--border-radius-outer);
  border: var(--theme-border-panel);
  background: transparent;
}
.content-panel-image-right-content .wide-images-container {
  width: calc(100% + var(--spacing-md) * 2);
  flex-basis: 100%;
  margin-left: calc(var(--spacing-md) * -1);
  margin-right: calc(var(--spacing-md) * -1);
  margin-top: 0;
  margin-bottom: 0;
  display: block;
}
.content-panel-image-right-content .wide-images-container .wide-image {
  display: block;
  width: 100%;
}
.content-panel-image-right-content .wide-images-container .wide-image .wide-image-content {
  display: block;
  width: 100%;
  height: auto;
}

/* ====================
CONCEPT DETAILS PANEL
==================== */
.content-panel-image-right-details-panel {
  display: flex;
  flex-direction: column;
  flex: 1;
  min-width: 280px;
  gap: var(--spacing-md);
  padding: var(--spacing-xl) var(--spacing-2x);
  border-radius: var(--border-radius);
  border: var(--theme-border-panel);
  background: var(--zing-dark-background);
}
.content-panel-image-right-details-panel.wider {
  flex: 1.6;
}

.content-panel-image-right-details-title {
  color: var(--color-primary);
  font-size: var(--font-size-lg);
  font-weight: 500;
  line-height: var(--line-height-2xl);
  margin: 0;
}

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

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

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

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

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

/* ====================
FEATURE LIST
Titled list-items with body-sized descriptions, separated by hairline
dividers. Sits inside `.content-panel-image-right-header` in header-only
narrative sections. Use for listing tiered options (pricing plans,
service levels, feature packages) where each item needs a short label
and a readable description. Distinct from `-details-list` (which is
icon+text, no per-item title) and from `.role-list` (which is scoped to
`.table-myrole` and uses 2xs text for the compact sidebar use case).
==================== */
.content-panel-image-right-feature-panel {
  width: 100%;
  max-width: 600px;
  padding: var(--spacing-xl) var(--spacing-2x);
  border-radius: var(--border-radius);
  border: var(--theme-border-panel);
  background: var(--zing-dark-background);
}

.content-panel-image-right-feature-list {
  list-style: none;
  margin: 0;
  padding: 0;
  width: 100%;
  text-align: left;
}

.content-panel-image-right-feature-item {
  padding: var(--spacing-lg) 0;
  border-bottom: var(--theme-border-divider);
}
.content-panel-image-right-feature-item:first-child {
  padding-top: 0;
}
.content-panel-image-right-feature-item:last-child {
  border-bottom: none;
  padding-bottom: 0;
}

.content-panel-image-right-feature-title {
  display: block;
  color: var(--theme-text);
  font-family: var(--font-family);
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-medium);
  line-height: var(--line-height-lg);
  margin: 0 0 4px 0;
}

.content-panel-image-right-feature-description {
  display: block;
  color: var(--theme-text);
  font-family: var(--font-family);
  font-size: var(--font-size-xs);
  font-weight: 400;
  line-height: var(--line-height-lg);
  margin: 0;
}

/* ====================
IMAGE PANEL
==================== */
.content-panel-image-right-image-panel {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  flex: 1;
  min-width: 280px;
  min-height: 400px;
  border-radius: var(--border-radius);
  border: var(--theme-border-panel);
  background: var(--zing-dark-background);
  background-image: url("../img/projects/zing/project_stages/founding/alpha_proof_of_concept.png");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}
.content-panel-image-right-image-panel.smaller {
  flex: 1;
}
.content-panel-image-right-image-panel:has(img), .content-panel-image-right-image-panel.has-image {
  background-image: none !important;
  background: var(--zing-dark-background) !important;
  overflow: hidden;
  padding: 0;
  justify-content: flex-end;
  align-items: stretch;
  display: flex;
  flex-direction: column;
  min-height: auto;
  height: auto;
}
.content-panel-image-right-image-panel img {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
  width: 100%;
  height: auto;
  max-width: 100%;
  object-fit: contain;
  border-radius: 0;
  margin: 0;
  align-self: stretch;
  margin-top: auto;
}

/* ====================
RESPONSIVE BREAKPOINTS
==================== */
/* Tablet breakpoint (max-width: 1024px) */
@media (max-width: 1024px) {
  .content-panel-image-right-section {
    gap: calc(var(--spacing-md) * 2);
  }
}
@media (max-width: 1024px) and (max-width: 1180px) {
  .content-panel-image-right-section {
    gap: calc(var(--spacing-md) * 2);
  }
}
@media (max-width: 1024px) and (max-width: 1024px) {
  .content-panel-image-right-section {
    gap: calc(var(--spacing-sm) * 2);
  }
}
@media (max-width: 1024px) and (max-width: 740px) {
  .content-panel-image-right-section {
    gap: calc(var(--spacing-xs) * 2);
  }
}
@media (max-width: 1024px) {
  .content-panel-image-right-header {
    gap: calc(var(--spacing-md) * 1.5);
  }
}
@media (max-width: 1024px) and (max-width: 1180px) {
  .content-panel-image-right-header {
    gap: calc(var(--spacing-md) * 1.5);
  }
}
@media (max-width: 1024px) and (max-width: 1024px) {
  .content-panel-image-right-header {
    gap: calc(var(--spacing-sm) * 1.5);
  }
}
@media (max-width: 1024px) and (max-width: 740px) {
  .content-panel-image-right-header {
    gap: calc(var(--spacing-xs) * 1.5);
  }
}
@media (max-width: 1024px) {
  .content-panel-image-right-title {
    font-size: var(--font-size-2xl);
    line-height: var(--line-height-xl);
  }
  .content-panel-image-right-description {
    font-size: var(--font-size-sm);
    line-height: var(--line-height-lg);
  }
  .content-panel-image-right-content {
    gap: calc(var(--spacing-md) * 1);
    padding: calc(var(--spacing-md) * 1);
  }
}
@media (max-width: 1024px) and (max-width: 1180px) {
  .content-panel-image-right-content {
    gap: calc(var(--spacing-md) * 1);
  }
}
@media (max-width: 1024px) and (max-width: 1024px) {
  .content-panel-image-right-content {
    gap: calc(var(--spacing-sm) * 1);
  }
}
@media (max-width: 1024px) and (max-width: 740px) {
  .content-panel-image-right-content {
    gap: calc(var(--spacing-xs) * 1);
  }
}
@media (max-width: 1024px) and (max-width: 1180px) {
  .content-panel-image-right-content {
    padding: calc(var(--spacing-md) * 1);
  }
}
@media (max-width: 1024px) and (max-width: 1024px) {
  .content-panel-image-right-content {
    padding: calc(var(--spacing-sm) * 1);
  }
}
@media (max-width: 1024px) and (max-width: 740px) {
  .content-panel-image-right-content {
    padding: calc(var(--spacing-xs) * 1);
  }
}
@media (max-width: 1024px) {
  .content-panel-image-right-details-panel {
    padding: calc(var(--spacing-md) * 1.5);
  }
}
@media (max-width: 1024px) and (max-width: 1180px) {
  .content-panel-image-right-details-panel {
    padding: calc(var(--spacing-md) * 1.5);
  }
}
@media (max-width: 1024px) and (max-width: 1024px) {
  .content-panel-image-right-details-panel {
    padding: calc(var(--spacing-sm) * 1.5);
  }
}
@media (max-width: 1024px) and (max-width: 740px) {
  .content-panel-image-right-details-panel {
    padding: calc(var(--spacing-xs) * 1.5);
  }
}
@media (max-width: 1024px) {
  .content-panel-image-right-details-title {
    font-size: var(--font-size-md);
    line-height: var(--line-height-md-plus);
  }
  .content-panel-image-right-details-text {
    font-size: var(--font-size-sm);
    line-height: var(--line-height-md);
  }
  .content-panel-image-right-feature-panel {
    padding: calc(var(--spacing-md) * 1.5);
  }
}
@media (max-width: 1024px) and (max-width: 1180px) {
  .content-panel-image-right-feature-panel {
    padding: calc(var(--spacing-md) * 1.5);
  }
}
@media (max-width: 1024px) and (max-width: 1024px) {
  .content-panel-image-right-feature-panel {
    padding: calc(var(--spacing-sm) * 1.5);
  }
}
@media (max-width: 1024px) and (max-width: 740px) {
  .content-panel-image-right-feature-panel {
    padding: calc(var(--spacing-xs) * 1.5);
  }
}
@media (max-width: 1024px) {
  .content-panel-image-right-feature-item {
    padding: var(--spacing-md) 0;
  }
  .content-panel-image-right-image-panel {
    min-height: 350px;
  }
}
/* Mobile breakpoint (max-width: 640px) */
@media (max-width: 740px) {
  .content-panel-image-right-section {
    gap: var(--spacing-2x);
  }
  .content-panel-image-right-header {
    gap: var(--spacing-lg);
  }
  .content-panel-image-right-title {
    font-size: var(--font-size-xl);
    line-height: var(--line-height-2xl);
  }
  .content-panel-image-right-description {
    font-size: var(--font-size-xs);
    line-height: var(--line-height-md);
  }
  .content-panel-image-right-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-image-right-content {
    gap: calc(var(--spacing-md) * 1);
  }
}
@media (max-width: 740px) and (max-width: 1024px) {
  .content-panel-image-right-content {
    gap: calc(var(--spacing-sm) * 1);
  }
}
@media (max-width: 740px) and (max-width: 740px) {
  .content-panel-image-right-content {
    gap: calc(var(--spacing-xs) * 1);
  }
}
@media (max-width: 740px) and (max-width: 1180px) {
  .content-panel-image-right-content {
    padding: calc(var(--spacing-md) * 1);
  }
}
@media (max-width: 740px) and (max-width: 1024px) {
  .content-panel-image-right-content {
    padding: calc(var(--spacing-sm) * 1);
  }
}
@media (max-width: 740px) and (max-width: 740px) {
  .content-panel-image-right-content {
    padding: calc(var(--spacing-xs) * 1);
  }
}
@media (max-width: 740px) {
  .content-panel-image-right-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-image-right-details-panel {
    gap: calc(var(--spacing-md) * 1);
  }
}
@media (max-width: 740px) and (max-width: 1024px) {
  .content-panel-image-right-details-panel {
    gap: calc(var(--spacing-sm) * 1);
  }
}
@media (max-width: 740px) and (max-width: 740px) {
  .content-panel-image-right-details-panel {
    gap: calc(var(--spacing-xs) * 1);
  }
}
@media (max-width: 740px) {
  .content-panel-image-right-details-title {
    font-size: var(--font-size-md);
    line-height: var(--line-height-md-plus);
  }
  .content-panel-image-right-details-text {
    font-size: var(--font-size-xs);
    line-height: var(--line-height-sm);
  }
  .content-panel-image-right-details-divider {
    margin: var(--spacing-md) 0;
  }
  .content-panel-image-right-details-list {
    gap: var(--spacing-md);
    margin-top: var(--spacing-md);
  }
  .content-panel-image-right-details-item {
    gap: var(--spacing-sm);
  }
  .content-panel-image-right-details-icon {
    width: 20px;
    height: 20px;
  }
  .content-panel-image-right-feature-panel {
    padding: var(--spacing-lg) var(--spacing-md);
  }
  .content-panel-image-right-feature-item {
    padding: var(--spacing-sm) 0;
  }
  .content-panel-image-right-image-panel {
    min-height: 300px;
  }
}
