/* ===== INTRO ===== */

.intro {
  background: white;
}

/* LAYOUT */
.intro__inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-2xl);
  align-items: center;
}

.intro__inner > * {
  min-width: 0;
}

.intro__visual {
  position: relative;
}

.intro__content {
  max-width: 520px;
  width: 100%;
}

/* IMAGE */
.intro__img-wrap {
  border-radius: var(--radius-lg);
  overflow: hidden;
  aspect-ratio: 4 / 5;
  background: #eee;
  position: relative;
}

.intro__img-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* BADGE */
.intro__badge {
  position: absolute;
  bottom: -20px;
  right: -20px;
  background: var(--color-primary);
  color: var(--color-white);
  border-radius: var(--radius-md);
  padding: var(--space-md) var(--space-lg);
  text-align: center;
  min-width: 120px;
}

.intro__badge-num {
  font-family: var(--font-heading);
  font-size: 2rem;
  font-weight: 700;
  line-height: 1;
  display: block;
  color: var(--color-primary-light);
}

.intro__badge-label {
  font-size: var(--text-sm);
  font-weight: 600;
  opacity: 0.85;
  margin-top: 4px;
}

/* DECORATION */
.intro__circle {
  position: absolute;
  top: -24px;
  left: -24px;
  width: 120px;
  height: 120px;
  border-radius: 50%;
  border: 2px dashed var(--color-primary-light);
  opacity: 0.25;
  animation: introSpin 20s linear infinite;
}

@keyframes introSpin {
  to {
    transform: rotate(360deg);
  }
}

/* CHECKLIST */
.intro__checklist {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}

.intro__checklist li {
  display: flex;
  align-items: flex-start;
  gap: var(--space-sm);
  font-size: var(--text-base);
  color: var(--color-text);
}

.intro__check-icon {
  width: 22px;
  height: 22px;
  background: rgba(45, 90, 39, 0.1);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  font-weight: 700;
  color: var(--color-primary);
  flex-shrink: 0;
}

/* RESPONSIVE */
@media (max-width: 1024px) {
  .intro__inner {
    grid-template-columns: 1fr;
    gap: var(--space-xl);
  }

  .intro__visual {
    max-width: 480px;
    margin: 0 auto;
  }
}

@media (max-width: 768px) {
  .intro__badge,
  .intro__circle {
    display: none;
  }
}
