.packages-hero {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr);
  gap: var(--space-8);
  align-items: center;
}

.packages-hero-text {
  max-width: 36rem;
}

.packages-hero-cta {
  margin-top: var(--space-4);
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
}

.packages-hero-media {
  justify-self: center;
}

.packages-hero-image {
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-md);
  border: 1px solid rgba(148, 163, 184, 0.3);
}

.packages-section-header {
  max-width: 48rem;
  margin-bottom: var(--space-8);
}

.packages-section-heading-wrapper {
  margin-top: var(--space-2);
}

.packages-grid {
  align-items: stretch;
}

.packages-card {
  display: flex;
  flex-direction: column;
  height: 100%;
}

.packages-card-media {
  margin-bottom: var(--space-3);
}

.packages-card-image {
  border-radius: var(--radius-lg);
}

.packages-list {
  margin: 0;
  padding-left: 1.1rem;
  color: var(--color-text-muted);
  font-size: var(--font-size-sm);
}

.packages-list li + li {
  margin-top: 0.35rem;
}

.packages-list-compact {
  font-size: var(--font-size-xs);
}

.packages-card-footer {
  margin-top: var(--space-4);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.packages-card-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
}

.packages-shared-grid {
  align-items: flex-start;
  gap: var(--space-8);
}

.packages-text-cta {
  margin-top: var(--space-3);
  font-size: var(--font-size-sm);
}

.packages-callout-actions {
  margin-top: var(--space-3);
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
}

.packages-process-grid {
  align-items: flex-start;
  gap: var(--space-8);
}

.packages-steps {
  margin: 0;
  padding-left: 1.2rem;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.packages-steps h3 {
  font-size: var(--font-size-base);
  margin-bottom: 0.15rem;
}

.packages-steps p {
  font-size: var(--font-size-sm);
}

.packages-process-cta {
  margin-top: var(--space-4);
}

.packages-process-aside {
  display: flex;
}

.packages-faq-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr);
  gap: var(--space-8);
  align-items: flex-start;
}

.packages-faq-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.packages-faq-item {
  padding: 0;
  overflow: hidden;
}

.packages-faq-trigger {
  width: 100%;
  padding: var(--space-4) var(--space-5);
  background: transparent;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  cursor: pointer;
  text-align: left;
}

.packages-faq-trigger span:first-child {
  font-size: var(--font-size-sm);
  font-weight: 500;
}

.packages-faq-icon {
  width: 1.5rem;
  height: 1.5rem;
  border-radius: var(--radius-full);
  border: 1px solid var(--color-border-subtle);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
}

.packages-faq-panel {
  max-height: 0;
  overflow: hidden;
  padding: 0 var(--space-5);
  border-top: 1px solid rgba(148, 163, 184, 0.15);
  transition: max-height var(--transition-slow), padding-bottom var(--transition-base);
}

.packages-faq-panel p {
  font-size: var(--font-size-sm);
  padding-top: var(--space-3);
  padding-bottom: var(--space-4);
}

.packages-faq-item[data-open="true"] .packages-faq-panel {
  max-height: 300px;
  padding-bottom: var(--space-4);
}

.packages-faq-item[data-open="true"] .packages-faq-icon {
  transform: rotate(45deg);
}

.packages-faq-aside {
  display: flex;
}

.packages-faq-cta-card {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.packages-faq-cta-card h3 {
  margin-bottom: 0;
}

.packages-faq-cta-card p {
  font-size: var(--font-size-sm);
}

.packages-faq-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  margin-top: var(--space-2);
}

@media (max-width: 960px) {
  .packages-hero {
    grid-template-columns: minmax(0, 1fr);
  }

  .packages-hero-media {
    order: -1;
  }

  .packages-faq-grid {
    grid-template-columns: minmax(0, 1fr);
  }
}

@media (max-width: 768px) {
  .packages-hero-cta,
  .packages-card-actions,
  .packages-callout-actions,
  .packages-faq-actions {
    flex-direction: column;
    align-items: stretch;
  }

  .packages-faq-trigger {
    padding: var(--space-3) var(--space-4);
  }

  .packages-faq-panel {
    padding: 0 var(--space-4);
  }
}
