/* Portfolio case-study layout polish
   Scoped override for the CMS-generated portfolio case-study blocks. */

/* Reveal animations disabled sitewide.
   This keeps all content visible immediately and avoids mobile IntersectionObserver blank zones. */
[data-reveal],
[data-reveal].is-visible {
  opacity: 1 !important;
  transform: none !important;
  transition: none !important;
  animation: none !important;
}

.portfolio-page #case-studies .container {
  width: min(96vw, 1680px);
}

.portfolio-page #case-studies .section-head {
  max-width: min(100%, 1180px);
}

.portfolio-page #case-studies .case-study-detail {
  overflow: hidden;
}

.portfolio-page #case-studies .case-study-detail-grid,
.portfolio-page #case-studies .case-study-detail-grid > .latest-study-shell {
  display: grid;
  grid-template-columns: repeat(12, minmax(0, 1fr));
  gap: clamp(18px, 1.6vw, 28px);
  align-items: start;
}

.portfolio-page #case-studies .case-study-detail-grid > .latest-study-shell {
  grid-column: 1 / -1;
  width: 100%;
}

.portfolio-page #case-studies .case-study-detail-grid > *,
.portfolio-page #case-studies .case-study-detail-grid > .latest-study-shell > * {
  min-width: 0;
}

.portfolio-page #case-studies :is(.case-study-detail-grid, .case-study-detail-grid > .latest-study-shell) > .latest-study-metrics {
  grid-column: span 7;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 190px), 1fr));
  gap: clamp(14px, 1.1vw, 18px);
}

.portfolio-page #case-studies :is(.case-study-detail-grid, .case-study-detail-grid > .latest-study-shell) > :is(.latest-study-note, .source-note) {
  grid-column: span 5;
  margin: 0;
  max-width: none;
  padding: clamp(16px, 1.2vw, 22px);
  border-radius: var(--radius-lg);
  border: 1px solid var(--line);
  background: linear-gradient(145deg, rgba(31, 111, 235, 0.08), rgba(108, 192, 255, 0.06));
  color: var(--muted);
  line-height: 1.6;
}

.portfolio-page #case-studies :is(.case-study-detail-grid, .case-study-detail-grid > .latest-study-shell) > .latest-study-grid {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 260px), 1fr));
  gap: clamp(18px, 1.4vw, 24px);
}

.portfolio-page #case-studies .case-study-detail-grid > .info-card {
  grid-column: span 3;
}

.portfolio-page #case-studies .case-study-detail-grid > .latest-study-metrics + .latest-study-grid,
.portfolio-page #case-studies .case-study-detail-grid > .latest-study-shell > .latest-study-metrics + .latest-study-grid {
  margin-top: 0;
}

.portfolio-page #case-studies .metric-card {
  min-width: 0;
  min-height: clamp(126px, 9vw, 160px);
  padding: clamp(18px, 1.25vw, 24px);
  align-content: start;
  overflow: hidden;
}

.portfolio-page #case-studies .metric-card strong {
  font-size: clamp(1.15rem, 1.35vw, 1.78rem);
  line-height: 0.98;
  overflow-wrap: anywhere;
  hyphens: auto;
}

.portfolio-page #case-studies .metric-card span {
  font-size: clamp(0.74rem, 0.78vw, 0.88rem);
  line-height: 1.35;
}

.portfolio-page #case-studies .case-study-detail-grid .info-card,
.portfolio-page #case-studies .latest-study-grid .info-card {
  min-width: 0;
  overflow-wrap: break-word;
}

@media (min-width: 1280px) {
  .portfolio-page #case-studies .case-study-detail-shell {
    grid-template-columns: minmax(0, 0.9fr) minmax(460px, 1.1fr);
  }

  .portfolio-page #case-studies .case-study-detail-grid > .info-card {
    grid-column: span 3;
  }
}

@media (min-width: 1600px) {
  .portfolio-page #case-studies .case-study-detail-grid,
  .portfolio-page #case-studies .case-study-detail-grid > .latest-study-shell {
    gap: clamp(22px, 1.4vw, 32px);
  }

  .portfolio-page #case-studies :is(.case-study-detail-grid, .case-study-detail-grid > .latest-study-shell) > .latest-study-metrics {
    grid-template-columns: repeat(auto-fit, minmax(min(100%, 210px), 1fr));
  }

  .portfolio-page #case-studies :is(.case-study-detail-grid, .case-study-detail-grid > .latest-study-shell) > .latest-study-grid {
    grid-template-columns: repeat(auto-fit, minmax(min(100%, 285px), 1fr));
  }
}

@media (max-width: 1279px) {
  .portfolio-page #case-studies :is(.case-study-detail-grid, .case-study-detail-grid > .latest-study-shell) > .latest-study-metrics,
  .portfolio-page #case-studies :is(.case-study-detail-grid, .case-study-detail-grid > .latest-study-shell) > :is(.latest-study-note, .source-note),
  .portfolio-page #case-studies :is(.case-study-detail-grid, .case-study-detail-grid > .latest-study-shell) > .latest-study-grid {
    grid-column: 1 / -1;
  }

  .portfolio-page #case-studies .case-study-detail-grid > .info-card {
    grid-column: span 6;
  }
}

@media (max-width: 900px) {
  .portfolio-page [data-reveal] {
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
  }

  .portfolio-page .section {
    padding-block: clamp(44px, 12vw, 66px);
  }

  .portfolio-page :is(#latest-case-study, #case-studies) .container {
    width: min(92vw, 680px);
  }

  .portfolio-page #latest-case-study .section-head,
  .portfolio-page #case-studies .section-head {
    margin-bottom: clamp(22px, 7vw, 34px);
  }

  .portfolio-page #latest-case-study .section-head h2,
  .portfolio-page #case-studies .section-head h2 {
    font-size: clamp(2.15rem, 10vw, 3.35rem);
    line-height: 1.08;
    max-width: 100%;
  }

  .portfolio-page #latest-case-study .section-head p,
  .portfolio-page #case-studies .section-head p {
    max-width: 100%;
  }

  .portfolio-page #latest-case-study .latest-study-shell,
  .portfolio-page #latest-case-study .latest-study-metrics,
  .portfolio-page #latest-case-study .latest-study-grid,
  .portfolio-page #case-studies .case-study-detail-grid,
  .portfolio-page #case-studies .case-study-detail-grid > .latest-study-shell,
  .portfolio-page #case-studies :is(.case-study-detail-grid, .case-study-detail-grid > .latest-study-shell) > .latest-study-metrics,
  .portfolio-page #case-studies :is(.case-study-detail-grid, .case-study-detail-grid > .latest-study-shell) > .latest-study-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: clamp(16px, 5vw, 22px);
  }

  .portfolio-page #latest-case-study :is(.latest-study-shell, .latest-study-metrics, .latest-study-grid) > *,
  .portfolio-page #case-studies .case-study-detail-grid > *,
  .portfolio-page #case-studies .case-study-detail-grid > .latest-study-shell > * {
    grid-column: 1 / -1 !important;
    min-width: 0;
  }

  .portfolio-page #latest-case-study :is(.latest-study-note, .source-note),
  .portfolio-page #case-studies :is(.latest-study-note, .source-note) {
    margin: 0;
    max-width: none;
    padding: clamp(16px, 5vw, 22px);
    border-radius: var(--radius-lg);
    border: 1px solid var(--line);
    background: rgba(255, 255, 255, 0.04);
    line-height: 1.6;
  }

  .portfolio-page #latest-case-study .metric-card,
  .portfolio-page #case-studies .metric-card {
    min-height: auto;
    overflow: visible;
    padding: clamp(18px, 5vw, 22px);
  }

  .portfolio-page #latest-case-study .metric-card strong,
  .portfolio-page #case-studies .metric-card strong {
    font-size: clamp(1.45rem, 8vw, 2rem);
    line-height: 1.02;
  }

  .portfolio-page #latest-case-study .latest-study-grid .info-card,
  .portfolio-page #case-studies .case-study-detail-grid .info-card,
  .portfolio-page #case-studies .latest-study-grid .info-card {
    height: auto;
    min-height: 0;
    overflow: visible;
  }

  .portfolio-page #case-studies .case-study-detail {
    overflow: visible;
    padding: clamp(22px, 5vw, 28px);
  }

  .portfolio-page #case-studies .case-study-detail-shell {
    grid-template-columns: 1fr;
    gap: clamp(18px, 5vw, 24px);
    margin-bottom: clamp(18px, 5vw, 24px);
  }

  .portfolio-page #case-studies .case-study-detail-visual {
    min-height: 0;
  }

  .portfolio-page #case-studies .case-study-detail h3 {
    font-size: clamp(1.8rem, 8vw, 2.45rem);
    line-height: 1.15;
  }

  .portfolio-page #case-studies .case-study-detail-lead {
    font-size: clamp(1rem, 4.8vw, 1.15rem);
    line-height: 1.55;
    max-width: 100%;
  }

  .portfolio-page .tag-row {
    gap: 10px;
  }

  .portfolio-page .tag {
    white-space: normal;
  }
}

@media (max-width: 900px) {
  .portfolio-page :is(#latest-case-study, #case-studies),
  .portfolio-page :is(#latest-case-study, #case-studies) *:not(script):not(style):not(svg):not(path) {
    opacity: 1 !important;
    visibility: visible !important;
    transform: none !important;
    transition: none !important;
    animation: none !important;
    max-height: none !important;
    min-height: 0 !important;
    height: auto !important;
    overflow: visible !important;
    clip: auto !important;
    clip-path: none !important;
  }

  .portfolio-page #latest-case-study :is(.latest-study-shell, .latest-study-metrics, .latest-study-grid),
  .portfolio-page #case-studies :is(.case-study-detail-list, .case-study-detail-grid, .latest-study-shell, .latest-study-metrics, .latest-study-grid) {
    display: grid !important;
    grid-template-columns: 1fr !important;
    align-items: stretch !important;
    gap: 18px !important;
  }

  .portfolio-page #latest-case-study :is(.latest-study-shell, .latest-study-metrics, .latest-study-grid) > *,
  .portfolio-page #case-studies :is(.case-study-detail-list, .case-study-detail-grid, .latest-study-shell, .latest-study-metrics, .latest-study-grid) > * {
    grid-column: 1 / -1 !important;
    grid-row: auto !important;
  }

  .portfolio-page #latest-case-study :is(.metric-card, .info-card, .latest-study-note, .source-note),
  .portfolio-page #case-studies :is(.metric-card, .info-card, .latest-study-note, .source-note, .case-study-detail, .case-study-detail-shell, .case-study-detail-intro, .case-study-detail-visual) {
    position: static !important;
    display: block !important;
    margin-block: 0 !important;
  }

  .portfolio-page #latest-case-study .metric-card + .metric-card,
  .portfolio-page #latest-case-study .info-card + .info-card,
  .portfolio-page #case-studies .info-card + .info-card,
  .portfolio-page #case-studies .case-study-detail + .case-study-detail {
    margin-top: 18px !important;
  }

  .portfolio-page #latest-case-study .section-head,
  .portfolio-page #case-studies .section-head {
    padding-bottom: 0 !important;
  }

  .portfolio-page #latest-case-study img,
  .portfolio-page #case-studies img {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    object-fit: contain !important;
  }
}
