/* ==========================================
   HERO VARIANTS — Unique per page
   ========================================== */

/* --- Split Page Hero (Solutions, etc.) --- */
.hero--split-page {
  padding: 160px 0 80px;
  background: var(--color-bg);
}

.hero--split-page__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: center;
}

.hero--split-page__text h1 {
  font-size: clamp(2.25rem, 4.5vw, 3.25rem);
  margin-bottom: 16px;
  letter-spacing: -0.03em;
  line-height: 1.1;
}

.hero--split-page__text p {
  font-size: 1.0625rem;
  max-width: 500px;
  margin-bottom: 32px;
  color: var(--color-text-secondary);
}

.hero--split-page__actions {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}

.hero--split-page__visual {
  position: relative;
}

.hero--split-page__visual img {
  width: 100%;
  border-radius: var(--radius-xl);
  aspect-ratio: 4/3;
  object-fit: cover;
  display: block;
  border: 1px solid var(--color-border);
  box-shadow: 0 24px 64px rgba(0,0,0,0.08);
}

@media (max-width: 900px) {
  .hero--split-page { padding: 140px 0 60px; }
  .hero--split-page__grid { grid-template-columns: 1fr; gap: 40px; }
  .hero--split-page__visual { order: -1; }
}

/* --- Section Image --- */
.section-image {
  border-radius: var(--radius-xl);
  overflow: hidden;
  border: 1px solid var(--color-border);
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.04);
}

.section-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* --- Solution Detail --- */
.solution-detail {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: center;
  padding: 60px 0;
}

.solution-detail__content h3 {
  font-size: 1.75rem;
  margin-bottom: 16px;
}

.solution-detail__content p {
  margin-bottom: 16px;
}

.solution-detail__content ul {
  margin-top: 16px;
}

.solution-detail__content ul li {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 8px 0;
  font-size: 0.9375rem;
  color: var(--color-text-secondary);
}

.solution-detail__content ul li::before {
  content: '';
  flex-shrink: 0;
  width: 20px;
  height: 20px;
  margin-top: 2px;
  background: var(--color-bg-alt);
  border: 1px solid var(--color-border);
  border-radius: 50%;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23111111' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'%3E%3C/polyline%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: center;
  background-size: 10px;
}

.solution-detail__visual {
  border-radius: var(--radius-xl);
  aspect-ratio: 4/3;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  overflow: hidden;
  background: var(--color-bg-alt);
  border: 1px solid var(--color-border);
}

.solution-detail__visual img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

@media (max-width: 900px) {
  .solution-detail {
    grid-template-columns: 1fr;
    gap: 32px;
    padding: 40px 0;
  }
}
