/* ── Container ── */
.container {
  width: 100%;
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 0 var(--space-6);
}
.container--wide {
  max-width: var(--container-wide);
}

/* ── Section spacing ── */
.section {
  padding: var(--space-24) 0;
}
.section--sm {
  padding: var(--space-16) 0;
}

/* ── Eyebrow invertido (SEO H1 + headline emocional) ── */
.eyebrow-block {}
.eyebrow-block__kw {
  font-size: var(--text-sm);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: var(--tracking-wide);
  color: var(--color-accent);
  margin-bottom: var(--space-3);
}
.eyebrow-block__headline {
  font-size: var(--text-5xl);
  font-weight: 800;
  line-height: var(--leading-tight);
  letter-spacing: var(--tracking-tight);
}
@media (max-width: 768px) {
  .eyebrow-block__headline { font-size: var(--text-4xl); }
}
@media (max-width: 480px) {
  .eyebrow-block__headline { font-size: var(--text-3xl); }
}

/* ── Glass card (Bento) ── */
.card {
  background: var(--glass-bg);
  backdrop-filter: blur(var(--glass-blur));
  -webkit-backdrop-filter: blur(var(--glass-blur));
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-lg);
  padding: var(--space-8);
  box-shadow: var(--glass-shadow);
  transition: transform var(--duration-normal) var(--ease-out),
              box-shadow var(--duration-normal) var(--ease-out),
              background var(--duration-normal) var(--ease-out);
}
.card:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.1), 0 0 0 1px rgba(249, 115, 22, 0.1);
  background: var(--glass-bg-hover);
}
.card--solid {
  background: var(--color-surface);
  backdrop-filter: none;
}
.card--accent {
  background: linear-gradient(135deg, var(--color-accent-50), var(--color-accent-100));
  border-color: var(--color-accent-200);
}
.card--accent:hover {
  background: linear-gradient(135deg, var(--color-accent-100), var(--color-accent-200));
}
.card__icon {
  width: 48px;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-md);
  background: var(--color-accent-glow);
  color: var(--color-accent);
  font-size: var(--text-2xl);
  margin-bottom: var(--space-5);
  transition: transform 0.3s var(--ease-out), box-shadow 0.3s var(--ease-out);
}
.card:hover .card__icon {
  transform: scale(1.08);
  box-shadow: 0 4px 16px rgba(249, 115, 22, 0.15);
}
.card__title {
  font-size: var(--text-xl);
  font-weight: 700;
  margin-bottom: var(--space-2);
  color: var(--color-text);
}
.card__desc {
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
  line-height: var(--leading-normal);
}
.card__link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-accent);
  margin-top: var(--space-4);
  transition: gap var(--duration-fast) var(--ease-out);
}
.card__link:hover { gap: var(--space-3); }
.card__link::after { content: '\2192'; }
.card__link:has(svg)::after { content: none; }
.card__link svg {
  transition: transform var(--duration-fast) var(--ease-out);
}
.card__link:hover svg {
  transform: translateX(3px);
}

/* ── Bento grid ── */
.bento {
  display: grid;
  gap: var(--space-6);
}
.bento--2 { grid-template-columns: repeat(2, 1fr); }
.bento--3 { grid-template-columns: repeat(3, 1fr); }
.bento--4 { grid-template-columns: repeat(4, 1fr); }

@media (max-width: 900px) {
  .bento--3, .bento--4 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
  .bento--2, .bento--3, .bento--4 { grid-template-columns: 1fr; }
  /* En 1 columna, una card con grid-column inline (p.ej. span 2) crea una columna
     implicita que descuadra el grid (cards a 2 por fila y cortadas). Ancho completo. */
  .bento > [style*="grid-column"] { grid-column: 1 / -1 !important; }
  /* .spec-grid define grid-template-columns inline (1fr 1fr) y no colapsaba en mobile */
  .spec-grid { grid-template-columns: 1fr !important; }
}

/* ── Section header ── */
.section-header {
  margin-bottom: var(--space-12);
}
.section-header__label {
  font-size: var(--text-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: var(--tracking-wide);
  color: var(--color-accent);
  margin-bottom: var(--space-3);
  display: flex;
  align-items: center;
  gap: var(--space-2);
}
.section-header__label::before {
  content: '';
  display: inline-block;
  width: 20px;
  height: 2px;
  background: var(--color-accent);
}
.section-header__title {
  font-size: var(--text-3xl);
  font-weight: 800;
  margin-bottom: var(--space-3);
}
.section-header__desc {
  font-size: var(--text-lg);
  color: var(--color-text-secondary);
  max-width: 600px;
}

/* ── CTA banner ── */
.cta-banner {
  background: linear-gradient(135deg, var(--color-accent), var(--color-accent-700));
  border-radius: var(--radius-xl);
  padding: var(--space-16) var(--space-12);
  text-align: center;
  color: #fff;
  position: relative;
  overflow: hidden;
  isolation: isolate;
}
.cta-banner::before {
  content: '';
  position: absolute;
  top: -60px;
  right: -60px;
  width: 200px;
  height: 200px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.1);
  animation: orb-float 6s ease-in-out infinite alternate;
}
.cta-banner::after {
  content: '';
  position: absolute;
  bottom: -40px;
  left: -40px;
  width: 150px;
  height: 150px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.08);
  animation: orb-float 8s ease-in-out 1s infinite alternate-reverse;
}
.cta-banner__shimmer {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    105deg,
    transparent 40%,
    rgba(255, 255, 255, 0.06) 45%,
    rgba(255, 255, 255, 0.12) 50%,
    rgba(255, 255, 255, 0.06) 55%,
    transparent 60%
  );
  background-size: 200% 100%;
  animation: cta-shimmer 5s ease-in-out infinite;
  pointer-events: none;
  z-index: 0;
}
@keyframes cta-shimmer {
  0% { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}
@keyframes orb-float {
  0% { transform: translate(0, 0) scale(1); }
  100% { transform: translate(30px, -20px) scale(1.05); }
}
.cta-banner h2 {
  color: #fff;
  font-size: var(--text-3xl);
  margin-bottom: var(--space-4);
  position: relative;
}
.cta-banner p {
  color: rgba(255, 255, 255, 0.85);
  font-size: var(--text-lg);
  margin-bottom: var(--space-8);
  max-width: 500px;
  margin-left: auto;
  margin-right: auto;
  position: relative;
}
.cta-banner .btn--primary {
  background: #fff;
  color: var(--color-accent-700);
  border-color: #fff;
  position: relative;
}
.cta-banner .btn--primary:hover {
  background: var(--color-accent-50);
  color: var(--color-accent-700);
  box-shadow: 0 4px 24px rgba(0, 0, 0, 0.2);
}
/* El boton del CTA puede llevar texto largo: debe envolver y nunca recortarse
   (el banner tiene overflow:hidden). Acotado al banner para no afectar nav/cards,
   que dependen del white-space:nowrap global de .btn. */
.cta-banner .btn {
  max-width: 100%;
  white-space: normal;
  line-height: 1.3;
  height: auto;
}
@media (max-width: 600px) {
  .cta-banner {
    padding: var(--space-12) var(--space-6);
  }
}

/* ── Step cards (numbered) ── */
.card--step {
  position: relative;
  padding-top: var(--space-12);
}
.card--step::before {
  content: attr(data-step);
  position: absolute;
  top: var(--space-4);
  right: var(--space-4);
  font-family: var(--font-mono);
  font-size: var(--text-5xl);
  font-weight: 800;
  color: var(--color-accent-glow);
  line-height: 1;
  pointer-events: none;
}

/* ── Card framework meta ── */
.card--framework .card__meta {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  margin-top: var(--space-4);
}
.card--framework .card__stars {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
}
.card--framework .card__stars svg {
  fill: var(--color-accent);
  stroke: var(--color-accent);
  width: 12px;
  height: 12px;
}

/* ── Card screenshot thumbnail ── */
.card__screenshot {
  width: 100%;
  height: auto;
  border-radius: var(--radius-sm);
  margin: var(--space-3) 0;
  border: 1px solid var(--color-border);
  transition: opacity var(--duration-fast) var(--ease-out);
}
.card:hover .card__screenshot {
  opacity: .85;
}

/* ── Industry card color variants ── */
.card--industry-1 .card__icon { background: rgba(249, 115, 22, 0.12); color: #f97316; }
.card--industry-2 .card__icon { background: rgba(59, 130, 246, 0.12); color: #3b82f6; }
.card--industry-3 .card__icon { background: rgba(16, 185, 129, 0.12); color: #10b981; }
.card--industry-4 .card__icon { background: rgba(139, 92, 246, 0.12); color: #8b5cf6; }
.card--industry-5 .card__icon { background: rgba(239, 68, 68, 0.12);  color: #ef4444; }
.card--industry-6 .card__icon { background: rgba(107, 114, 128, 0.12); color: #6b7280; }
.card--industry-7 .card__icon { background: rgba(20, 184, 166, 0.12); color: #14b8a6; }
.card--industry-8 .card__icon { background: rgba(236, 72, 153, 0.12); color: #ec4899; }

.card--industry-1:hover { border-color: rgba(249, 115, 22, 0.3); box-shadow: 0 8px 32px rgba(249, 115, 22, 0.1); }
.card--industry-2:hover { border-color: rgba(59, 130, 246, 0.3); box-shadow: 0 8px 32px rgba(59, 130, 246, 0.1); }
.card--industry-3:hover { border-color: rgba(16, 185, 129, 0.3); box-shadow: 0 8px 32px rgba(16, 185, 129, 0.1); }
.card--industry-4:hover { border-color: rgba(139, 92, 246, 0.3); box-shadow: 0 8px 32px rgba(139, 92, 246, 0.1); }
.card--industry-5:hover { border-color: rgba(239, 68, 68, 0.3); box-shadow: 0 8px 32px rgba(239, 68, 68, 0.1); }
.card--industry-6:hover { border-color: rgba(107, 114, 128, 0.3); box-shadow: 0 8px 32px rgba(107, 114, 128, 0.1); }
.card--industry-7:hover { border-color: rgba(20, 184, 166, 0.3); box-shadow: 0 8px 32px rgba(20, 184, 166, 0.1); }
.card--industry-8:hover { border-color: rgba(236, 72, 153, 0.3); box-shadow: 0 8px 32px rgba(236, 72, 153, 0.1); }

/* ── Model brand cards ── */
.card--model {
  border-top: 3px solid transparent;
  transition: border-color 0.3s var(--ease-out), transform var(--duration-normal) var(--ease-out),
              box-shadow var(--duration-normal) var(--ease-out), background var(--duration-normal) var(--ease-out);
}
.card--model:hover {
  border-top-color: var(--model-color, var(--color-accent));
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.1), 0 -2px 16px var(--model-glow, rgba(249, 115, 22, 0.1));
}

/* ── Scroll reveal animations ── */
.reveal {
  opacity: 0;
  transform: translateY(32px);
  transition: opacity 0.7s var(--ease-out), transform 0.7s var(--ease-out);
}
.reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}
.reveal--scale {
  opacity: 0;
  transform: scale(0.92);
  transition: opacity 0.7s var(--ease-out), transform 0.7s var(--ease-out);
}
.reveal--scale.is-visible {
  opacity: 1;
  transform: scale(1);
}
.reveal--left {
  opacity: 0;
  transform: translateX(-32px);
  transition: opacity 0.7s var(--ease-out), transform 0.7s var(--ease-out);
}
.reveal--left.is-visible {
  opacity: 1;
  transform: translateX(0);
}
.reveal--right {
  opacity: 0;
  transform: translateX(32px);
  transition: opacity 0.7s var(--ease-out), transform 0.7s var(--ease-out);
}
.reveal--right.is-visible {
  opacity: 1;
  transform: translateX(0);
}
.reveal-group .reveal:nth-child(1) { transition-delay: 0ms; }
.reveal-group .reveal:nth-child(2) { transition-delay: 80ms; }
.reveal-group .reveal:nth-child(3) { transition-delay: 160ms; }
.reveal-group .reveal:nth-child(4) { transition-delay: 240ms; }
.reveal-group .reveal:nth-child(5) { transition-delay: 320ms; }
.reveal-group .reveal:nth-child(6) { transition-delay: 400ms; }
.reveal-group .reveal:nth-child(7) { transition-delay: 480ms; }
.reveal-group .reveal:nth-child(8) { transition-delay: 560ms; }

@media (prefers-reduced-motion: reduce) {
  .reveal, .reveal--scale, .reveal--left, .reveal--right {
    opacity: 1;
    transform: none;
    transition: none;
  }
}

/* ── Section variants ── */
.section--gradient {
  position: relative;
  overflow: hidden;
}
.section--gradient::before {
  content: '';
  position: absolute;
  top: -200px;
  right: -200px;
  width: 600px;
  height: 600px;
  border-radius: 50%;
  background: radial-gradient(circle, var(--color-accent-glow) 0%, transparent 70%);
  pointer-events: none;
}
.section--gradient::after {
  content: '';
  position: absolute;
  bottom: -150px;
  left: -150px;
  width: 400px;
  height: 400px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(249, 115, 22, 0.06) 0%, transparent 70%);
  pointer-events: none;
}
.section--tinted {
  background: linear-gradient(180deg, var(--color-border-subtle) 0%, var(--color-bg) 100%);
}
.section--visual {
  position: relative;
  overflow: hidden;
}
.section__bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}
.section__bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0.08;
}
.section__bg::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, var(--color-bg) 0%, transparent 15%, transparent 85%, var(--color-bg) 100%);
}
.section--visual::before {
  content: '';
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 60%;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--color-accent-200), transparent);
  z-index: 1;
}
.section--visual > .container {
  position: relative;
  z-index: 1;
}

/* ── Section image (inline illustration) ── */
.section-img {
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--glass-shadow);
}
.section-img img {
  width: 100%;
  height: auto;
  display: block;
}
.section-img--landscape {
  aspect-ratio: 16 / 9;
}
.section-img--landscape img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* ── Buttons ── */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  font-weight: 600;
  padding: var(--space-3) var(--space-6);
  border-radius: var(--radius-full);
  border: 1.5px solid transparent;
  cursor: pointer;
  transition: all var(--duration-fast) var(--ease-out);
  text-decoration: none;
  line-height: 1;
  white-space: nowrap;
}
.btn--primary {
  background: var(--color-accent);
  color: #fff;
  border-color: var(--color-accent);
}
.btn--primary:hover {
  background: var(--color-accent-hover);
  border-color: var(--color-accent-hover);
  color: #fff;
  transform: translateY(-1px);
  box-shadow: 0 4px 16px var(--color-accent-glow);
}
.btn--outline {
  background: transparent;
  color: var(--color-text);
  border-color: var(--color-border);
}
.btn--outline:hover {
  border-color: var(--color-accent);
  color: var(--color-accent);
}
.btn--lg {
  font-size: var(--text-base);
  padding: var(--space-4) var(--space-8);
}
.btn--sm {
  font-size: var(--text-xs);
  padding: var(--space-2) var(--space-4);
}

/* ── Badge / Tag ── */
.badge {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  margin-top: var(--space-4);
  font-size: var(--text-xs);
  font-weight: 600;
  padding: var(--space-1) var(--space-3);
  border-radius: var(--radius-full);
  background: var(--color-accent-glow);
  color: var(--color-accent-700);
}
.badge--neutral {
  background: var(--color-border-subtle);
  color: var(--color-text-secondary);
}

/* ── Breadcrumbs ── */
.breadcrumbs {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  margin-bottom: var(--space-6);
}
.breadcrumbs a { color: var(--color-text-secondary); }
.breadcrumbs a:hover { color: var(--color-accent); }
.breadcrumbs__sep { color: var(--color-border); }

/* ── Image placeholder ── */
.placeholder-img {
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, #f1f5f9, #e2e8f0);
  border-radius: var(--radius-md);
  color: var(--color-text-muted);
  font-size: var(--text-sm);
  text-align: center;
  padding: var(--space-8);
  min-height: 200px;
  border: 2px dashed var(--color-border);
}

/* ── Stats counter ── */
.stat {
  text-align: center;
}
.stat__number {
  display: block;
  font-size: var(--text-4xl);
  font-weight: 800;
  letter-spacing: var(--tracking-tight);
  color: var(--color-accent);
  line-height: 1;
}
.stat__label {
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
  margin-top: var(--space-2);
}

/* ── Updated date ── */
.updated-date {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-sm);
  color: var(--color-text-muted);
}
.updated-date time {
  font-weight: 600;
  color: var(--color-text-secondary);
}
