/* ============================================
   CHARVEL & CO - Service Detail Page Styles
   ============================================ */

/* ---- Benefits Grid ---- */
.benefits {
  background: var(--color-white);
}

.benefits__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-xl);
}

.benefits__grid--3 {
  grid-template-columns: repeat(3, 1fr);
}

.benefits__grid--2 {
  grid-template-columns: repeat(2, 1fr);
  max-width: 800px;
  margin-inline: auto;
}

.benefit-card {
  text-align: center;
  padding: var(--space-2xl) var(--space-lg);
  border-radius: var(--radius-md);
  border: 1px solid var(--color-gray-200);
  transition: all var(--transition-base);
}

.benefit-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg);
  border-color: var(--color-primary-20);
}

.benefit-card__icon {
  width: 56px;
  height: 56px;
  margin: 0 auto var(--space-lg);
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-md);
  background: var(--color-primary-10);
  font-size: var(--font-size-2xl);
}

.benefit-card__title {
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-semibold);
  margin-bottom: var(--space-sm);
}

.benefit-card__text {
  font-size: var(--font-size-sm);
  color: var(--color-text-light);
  line-height: var(--line-height-relaxed);
}

/* ---- Difference / Feature Split ---- */
.feature-split {
  background: var(--color-cream);
}

.feature-split__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-3xl);
  align-items: center;
}

.feature-split__image {
  border-radius: var(--radius-lg);
  overflow: hidden;
  aspect-ratio: 4/3;
}

.feature-split__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.feature-split__content h2 {
  margin-bottom: var(--space-lg);
}

.feature-split__content p {
  margin-bottom: var(--space-md);
  line-height: var(--line-height-relaxed);
}

/* ---- Highlight Bars ---- */
.highlights {
  background: var(--color-dark);
  padding: var(--space-xl) 0;
}

.highlights__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-xl);
  text-align: center;
}

.highlight-item {
  padding: var(--space-lg);
}

.highlight-item__icon {
  color: var(--color-primary);
  font-size: var(--font-size-2xl);
  margin-bottom: var(--space-sm);
}

.highlight-item__text {
  font-size: var(--font-size-sm);
  color: var(--color-gray-300);
  font-weight: var(--font-weight-medium);
}

/* ---- Coverage Table ---- */
.coverage-table {
  background: var(--color-white);
}

.coverage-table__wrapper {
  overflow-x: auto;
}

.coverage-table table {
  width: 100%;
  border-collapse: collapse;
  border-radius: var(--radius-md);
  overflow: hidden;
}

.coverage-table th {
  background: var(--color-cream);
  padding: var(--space-lg) var(--space-xl);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  text-align: left;
  color: var(--color-text);
  border-bottom: 2px solid var(--color-gray-200);
}

.coverage-table td {
  padding: var(--space-md) var(--space-xl);
  font-size: var(--font-size-sm);
  color: var(--color-text-light);
  border-bottom: 1px solid var(--color-gray-100);
}

.coverage-table tr:hover td {
  background: var(--color-cream);
}

.coverage-table .badge {
  display: inline-block;
  padding: 4px 12px;
  border-radius: var(--radius-full);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
}

.badge--included {
  background: #e8f5e9;
  color: #2e7d32;
}

.badge--optional {
  background: #fff3e0;
  color: #ef6c00;
}

.badge--covered {
  background: var(--color-primary-10);
  color: var(--color-primary-dark);
}

/* ---- Stats Section ---- */
.stat-highlight {
  background: var(--color-cream);
  border-radius: var(--radius-lg);
  padding: var(--space-2xl);
  text-align: center;
  margin-top: var(--space-2xl);
}

.stat-highlight__number {
  font-size: var(--font-size-5xl);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-primary);
  margin-bottom: var(--space-xs);
}

.stat-highlight__label {
  font-size: var(--font-size-sm);
  color: var(--color-text-light);
}

/* ---- Soporte y Gestión Digital (empresarial) ---- */
.soporte {
  background: var(--color-white);
}

.soporte .section-header p {
  font-size: var(--font-size-base);
  color: var(--color-text-light);
  margin-top: var(--space-md);
}

.soporte__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-2xl);
}

.soporte-card {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  padding: var(--space-3xl) var(--space-2xl);
  background: var(--color-gray-100);
  border-radius: var(--radius-xl);
  border: 1px solid var(--color-gray-200);
  transition: transform var(--transition-base),
              box-shadow var(--transition-base),
              border-color var(--transition-base);
}

.soporte-card:hover {
  transform: translateY(-6px);
  box-shadow: var(--shadow-lg);
  border-color: var(--color-primary-20);
}

/* Icon — SVG lineal en rose-gold, negro en hover */
.soporte-card__icon {
  width: 72px;
  height: 72px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-lg);
  background: var(--color-primary-10);
  color: var(--color-primary);
  margin-bottom: var(--space-xl);
  transition: color var(--transition-base),
              background var(--transition-base);
}

.soporte-card:hover .soporte-card__icon {
  color: var(--color-dark);
  background: var(--color-gray-200);
}

.soporte-card__body {
  flex: 1;
}

.soporte-card__title {
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-bold);
  color: var(--color-text);
  letter-spacing: -0.01em;
  margin-bottom: var(--space-md);
}

.soporte-card__text {
  font-size: var(--font-size-sm);
  color: var(--color-text-light);
  line-height: var(--line-height-relaxed);
}

/* CTA button — solidifies at the bottom of the card */
.soporte-card__btn {
  margin-top: var(--space-2xl);
  width: 100%;
  text-align: center;
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  letter-spacing: 0.1em;
}

/* ---- Tramites Page Specific ---- */
.tramites-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-xl);
}

.tramite-card {
  background: var(--color-white);
  border-radius: var(--radius-md);
  padding: var(--space-2xl);
  border: 1px solid var(--color-gray-200);
  transition: all var(--transition-base);
}

.tramite-card:hover {
  box-shadow: var(--shadow-md);
}

.tramite-card__header {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  margin-bottom: var(--space-lg);
}

.tramite-card__icon {
  width: 44px;
  height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-md);
  background: var(--color-primary-10);
  color: var(--color-primary);
  font-size: var(--font-size-xl);
}

.tramite-card__title {
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-semibold);
}

.tramite-card__ref {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-regular);
  color: var(--color-text-light);
}

.tramite-card__text {
  font-size: var(--font-size-sm);
  color: var(--color-text-light);
  line-height: var(--line-height-relaxed);
  margin-bottom: var(--space-lg);
}

.tramite-card__list {
  margin-bottom: var(--space-lg);
}

.tramite-card__list li {
  padding: var(--space-sm) 0;
  font-size: var(--font-size-sm);
  color: var(--color-text-light);
  display: flex;
  align-items: flex-start;
  gap: var(--space-sm);
}

.tramite-card__list li::before {
  content: '→';
  color: var(--color-primary);
  font-weight: var(--font-weight-bold);
  flex-shrink: 0;
}

.tramite-card__quote {
  font-style: italic;
  font-size: var(--font-size-sm);
  color: var(--color-primary-dark);
  padding: var(--space-lg);
  background: var(--color-primary-10);
  border-radius: var(--radius-md);
  border-left: 3px solid var(--color-primary);
  margin-bottom: var(--space-lg);
}

.tramite-card__links {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-sm);
}

.tramite-link {
  display: inline-block;
  padding: 8px 16px;
  border-radius: var(--radius-md);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  background: var(--color-primary);
  color: var(--color-white);
  transition: all var(--transition-fast);
}

.tramite-link:hover {
  background: var(--color-primary-dark);
  transform: translateY(-1px);
}

@media (max-width: 1024px) {
  .benefits__grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .soporte__grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 768px) {
  .benefits__grid,
  .benefits__grid--3,
  .highlights__grid,
  .feature-split__grid,
  .tramites-grid,
  .soporte__grid {
    grid-template-columns: 1fr;
  }

  .feature-split__image {
    aspect-ratio: 16/9;
  }

  .soporte-card {
    padding: var(--space-2xl) var(--space-xl);
  }
}
