/* ==========================================================================
   BLOG — Archive + Single post
   ========================================================================== */

/* ==========================================================================
   A. ARCHIVE
   ========================================================================== */

/* --- Hero (uses .bg-brand-stripes from components.css via gradient fallback) --- */
.blog-archive__hero {
  background:
    repeating-linear-gradient(
      -45deg,
      transparent,
      transparent 40px,
      rgba(255, 255, 255, 0.015) 40px,
      rgba(255, 255, 255, 0.015) 42px
    ),
    linear-gradient(160deg, var(--color-secondary) 0%, #0f1114 60%, #1a0a0d 100%);
  color: var(--color-white);
  text-align: center;
  padding: var(--section-space-l) var(--gutter);
}

.blog-archive__hero-inner {
  max-width: var(--wide-width);
  margin-inline: auto;
}

.blog-archive__badge {
  display: inline-block;
  font-size: var(--text-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-primary);
  margin-bottom: var(--space-s);
}

.blog-archive__titulo {
  font-size: var(--text-5xl);
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.02em;
  margin-bottom: var(--space-s);
  color: var(--color-white);
  text-shadow: 0 2px 20px rgba(0, 0, 0, 0.5);
}

.blog-archive__highlight {
  color: var(--color-primary);
}

.blog-archive__subtitulo {
  font-size: var(--text-l);
  color: var(--color-foreground-light);
  max-width: 640px;
  margin-inline: auto;
}

/* --- Filters --- */
.blog-archive__filter-section {
  background: var(--color-white);
  padding: var(--space-l) var(--gutter);
  border-bottom: 1px solid var(--color-border);
}

.blog-archive__filter-inner {
  max-width: var(--wide-width);
  margin-inline: auto;
}

.blog-archive__filters {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-s);
}

/* Category pills */
.blog-archive__cats-wrap {
  width: 100%;
}

.blog-archive__cats {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
  gap: var(--space-3xs);
}

.blog-archive__cat {
  display: inline-block;
  padding: var(--space-3xs) var(--space-s);
  border-radius: var(--radius-full);
  font-size: var(--text-s);
  font-weight: 600;
  text-decoration: none;
  color: var(--color-foreground);
  background: var(--color-muted);
  white-space: nowrap;
  transition: background var(--transition-fast), color var(--transition-fast);
}

.blog-archive__cat:hover {
  background: var(--color-border);
  color: var(--color-foreground);
}

.blog-archive__cat--active {
  background: var(--color-primary);
  color: var(--color-white);
}

.blog-archive__cat--active:hover {
  background: var(--color-primary-dark);
}

@media (max-width: 768px) {
  .blog-archive__filter-section {
    padding: var(--space-s) 0;
  }
  .blog-archive__cats-wrap {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    padding: 0 var(--gutter);
  }
  .blog-archive__cats-wrap::-webkit-scrollbar {
    display: none;
  }
  .blog-archive__cats {
    flex-wrap: nowrap;
  }
  .blog-archive__cat {
    font-size: var(--text-xs);
    padding: var(--space-3xs) var(--space-xs);
  }
  color: var(--color-white);
}

/* Search bar moved to page-banner (components.css) */

/* --- Grid --- */
.blog-archive__grid-section {
  padding: var(--section-space-m) var(--gutter);
}

.blog-archive__grid-inner {
  max-width: var(--wide-width);
  margin-inline: auto;
}

.blog-archive__grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: var(--space-l);
}

.blog-archive__card {
  display: flex;
  flex-direction: column;
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-l);
  overflow: hidden;
  text-decoration: none;
  color: var(--color-foreground);
  transition: box-shadow var(--transition-base), border-color var(--transition-base);
}

.blog-archive__card:hover {
  box-shadow: var(--shadow-l);
  border-color: var(--color-primary);
}

.blog-archive__card-image {
  aspect-ratio: 16 / 9;
  overflow: hidden;
}

.blog-archive__card-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transition-slow);
}

.blog-archive__card:hover .blog-archive__card-img {
  transform: scale(1.05);
}

.blog-archive__card-body {
  padding: var(--space-m);
  display: flex;
  flex-direction: column;
  gap: var(--space-2xs);
  flex: 1;
}

.blog-archive__card-tags {
  display: flex;
  gap: var(--space-3xs);
}

.blog-archive__card-tag {
  font-size: var(--text-xs);
  font-weight: 600;
  color: var(--color-primary);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.blog-archive__card-title {
  font-size: var(--text-l);
  font-weight: 700;
  line-height: 1.3;
}

.blog-archive__card-excerpt {
  font-size: var(--text-s);
  color: var(--color-foreground-light);
  line-height: 1.5;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.blog-archive__card-date {
  font-size: var(--text-xs);
  color: var(--color-foreground-light);
  margin-top: auto;
}

/* --- Pagination --- */
.blog-archive__pagination {
  margin-top: var(--space-xl);
  text-align: center;
}

.blog-archive__pagination .page-numbers {
  display: inline-flex;
  gap: var(--space-2xs);
  list-style: none;
  padding: 0;
  margin: 0;
}

.blog-archive__pagination .page-numbers li a,
.blog-archive__pagination .page-numbers li span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 40px;
  height: 40px;
  padding: 0 var(--space-xs);
  border-radius: var(--radius-m);
  font-size: var(--text-s);
  font-weight: 600;
  text-decoration: none;
  color: var(--color-foreground);
  background: var(--color-muted);
  transition: background var(--transition-fast), color var(--transition-fast);
}

.blog-archive__pagination .page-numbers li a:hover {
  background: var(--color-primary);
  color: var(--color-white);
}

.blog-archive__pagination .page-numbers li span.current {
  background: var(--color-primary);
  color: var(--color-white);
}

/* --- No results --- */
.blog-archive__no-results {
  text-align: center;
  padding: var(--space-2xl) 0;
}

.blog-archive__no-results-text {
  font-size: var(--text-l);
  color: var(--color-foreground-light);
  margin-bottom: var(--space-m);
}

/* --- Archive CTA --- */
.blog-archive__cta {
  background: var(--color-primary);
  color: var(--color-white);
  text-align: center;
  padding: var(--section-space-m) var(--gutter);
}

.blog-archive__cta-inner {
  max-width: 640px;
  margin-inline: auto;
}

.blog-archive__cta-titulo {
  font-size: var(--text-3xl);
  font-weight: 800;
  text-transform: uppercase;
  margin-bottom: var(--space-s);
}

.blog-archive__cta-texto {
  font-size: var(--text-l);
  color: var(--color-foreground-light);
  margin-bottom: var(--space-l);
}

.blog-archive__cta-buttons {
  display: flex;
  justify-content: center;
  gap: var(--space-s);
  flex-wrap: wrap;
}

.blog-archive__cta .cta-btn--primary {
  background: var(--color-white);
  color: var(--color-primary);
}

.blog-archive__cta .cta-btn--primary:hover {
  background: var(--color-surface);
}

.blog-archive__cta .cta-btn--secondary {
  background: transparent;
  color: var(--color-white);
  border: 2px solid rgba(255, 255, 255, 0.4);
}

.blog-archive__cta .cta-btn--secondary:hover {
  border-color: var(--color-white);
  background: rgba(255, 255, 255, 0.1);
}

/* ==========================================================================
   B. SINGLE POST (.bs)
   ========================================================================== */

/* --- Hero --- */
.bs__hero {
  background:
    radial-gradient(ellipse at 80% 20%, rgba(200, 2, 38, 0.1) 0%, transparent 50%),
    repeating-linear-gradient(
      -45deg,
      transparent,
      transparent 40px,
      rgba(255, 255, 255, 0.012) 40px,
      rgba(255, 255, 255, 0.012) 42px
    ),
    linear-gradient(160deg, var(--color-secondary) 0%, #0f1114 60%, #1a0a0d 100%);
  color: var(--color-white);
  text-align: center;
  padding: var(--section-space-l) var(--gutter) var(--space-xl);
}

.bs__hero-inner {
  max-width: 768px;
  margin-inline: auto;
}

.bs__badge {
  display: inline-block;
  font-size: var(--text-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-primary);
  margin-bottom: var(--space-s);
}

.bs__titulo {
  font-size: var(--text-5xl);
  font-weight: 800;
  line-height: 1.05;
  margin-bottom: var(--space-s);
  color: var(--color-white);
  text-shadow: 0 2px 20px rgba(0, 0, 0, 0.5);
}

.bs__subtitulo {
  font-size: var(--text-l);
  color: var(--color-foreground-light);
  margin-bottom: var(--space-m);
}

.bs__meta {
  font-size: var(--text-s);
  color: var(--color-foreground-light);
  display: flex;
  justify-content: center;
  gap: var(--space-xs);
}

/* --- Body: article + sidebar --- */
.bs__body {
  padding: var(--space-l) var(--gutter) var(--section-space-m);
}

.bs__body-inner {
  max-width: 1080px;
  margin-inline: auto;
  display: grid;
  grid-template-columns: 1fr 380px;
  gap: var(--space-l);
  align-items: start;
}

/* --- Main article --- */
.bs__main {
  min-width: 0;
  max-width: 680px;
}

.bs__hero-image {
  border-radius: var(--radius-l);
  overflow: hidden;
  margin-bottom: var(--space-l);
}

.bs__hero-img {
  width: 100%;
  height: auto;
  display: block;
}

/*
 * LEGIBILIDAD — Reglas tipográficas para lectura confortable:
 * - Ancho máximo 680px (~65 caracteres/línea, el rango óptimo es 60-75)
 * - Interlineado 1.8 (más generoso que el estándar 1.5)
 * - Tamaño base 1.0625rem (17px) para lectura de largo formato
 * - Espaciado vertical generoso entre párrafos
 * - Color foreground al 90% para reducir contraste duro
 */
.bs__content {
  max-width: 680px;
  font-size: var(--text-l);
  line-height: 1.8;
  color: var(--color-foreground);
  letter-spacing: -0.01em;
}

.bs__content h2 {
  font-size: var(--text-2xl);
  font-weight: 700;
  margin-top: var(--space-xl);
  margin-bottom: var(--space-s);
  line-height: 1.25;
  letter-spacing: -0.02em;
}

.bs__content h3 {
  font-size: var(--text-xl);
  font-weight: 700;
  margin-top: var(--space-l);
  margin-bottom: var(--space-xs);
  line-height: 1.3;
}

.bs__content p {
  margin-bottom: var(--space-s);
}

.bs__content p + p {
  margin-top: 0;
}

.bs__content img {
  max-width: 100%;
  height: auto;
  border-radius: var(--radius-m);
  margin-block: var(--space-m);
}

/* Gallery — masonry-style asymmetric grid */
.bs__content .wp-block-gallery,
.bs__content .gallery {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  grid-auto-rows: 140px;
  gap: var(--space-2xs);
  margin-block: var(--space-m);
}

.bs__content .wp-block-gallery .wp-block-image,
.bs__content .gallery-item {
  margin: 0;
  overflow: hidden;
  border-radius: var(--radius-m);
}

/* 1st image — hero big (left, 2 rows) */
.bs__content .wp-block-gallery .wp-block-image:nth-child(1),
.bs__content .gallery-item:nth-child(1) {
  grid-column: span 7;
  grid-row: span 2;
}

/* 2nd image — top right */
.bs__content .wp-block-gallery .wp-block-image:nth-child(2),
.bs__content .gallery-item:nth-child(2) {
  grid-column: span 5;
  grid-row: span 1;
}

/* 3rd image — bottom right */
.bs__content .wp-block-gallery .wp-block-image:nth-child(3),
.bs__content .gallery-item:nth-child(3) {
  grid-column: span 5;
  grid-row: span 1;
}

/* 4th+ images — equal thirds */
.bs__content .wp-block-gallery .wp-block-image:nth-child(n+4),
.bs__content .gallery-item:nth-child(n+4) {
  grid-column: span 4;
  grid-row: span 1;
}

/* If only 2 images — split 50/50 */
.bs__content .wp-block-gallery .wp-block-image:first-child:nth-last-child(2),
.bs__content .wp-block-gallery .wp-block-image:first-child:nth-last-child(2) ~ .wp-block-image {
  grid-column: span 6;
  grid-row: span 2;
}

.bs__content .wp-block-gallery .wp-block-image img,
.bs__content .gallery-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  margin: 0;
  border-radius: var(--radius-m);
  transition: transform var(--transition-slow);
}

.bs__content .wp-block-gallery .wp-block-image:hover img,
.bs__content .gallery-item:hover img {
  transform: scale(1.05);
}

@media (max-width: 768px) {
  .bs__content .wp-block-gallery,
  .bs__content .gallery {
    grid-template-columns: repeat(2, 1fr);
    grid-auto-rows: 120px;
  }
  .bs__content .wp-block-gallery .wp-block-image:nth-child(1),
  .bs__content .gallery-item:nth-child(1) {
    grid-column: span 2;
    grid-row: span 2;
  }
  .bs__content .wp-block-gallery .wp-block-image:nth-child(n+2),
  .bs__content .gallery-item:nth-child(n+2) {
    grid-column: span 1;
    grid-row: span 1;
  }
}

.bs__content iframe,
.bs__content video,
.bs__content .wp-block-embed__wrapper {
  max-width: 100%;
  border-radius: var(--radius-m);
  margin-block: var(--space-m);
}

.bs__content .wp-block-embed {
  margin-block: var(--space-m);
}

.bs__content .wp-block-embed__wrapper {
  position: relative;
  padding-bottom: 56.25%;
  height: 0;
  overflow: hidden;
}

.bs__content .wp-block-embed__wrapper iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border: 0;
  border-radius: var(--radius-m);
}

.bs__content ul,
.bs__content ol {
  margin-bottom: var(--space-s);
  padding-left: var(--space-l);
}

.bs__content li {
  margin-bottom: var(--space-2xs);
  line-height: 1.7;
}

.bs__content li::marker {
  color: var(--color-primary);
}

/* Tables — clean line style */
.bs__content table {
  width: 100%;
  border: none;
  border-collapse: collapse;
  margin-block: var(--space-m);
}

.bs__content thead {
  display: none;
}

.bs__content tr {
  border: none;
  border-bottom: 1px solid var(--color-border);
}

.bs__content tr:last-child {
  border-bottom: none;
}

.bs__content th,
.bs__content td {
  border: none;
  padding: var(--space-xs) 0;
  font-size: var(--text-s);
  vertical-align: middle;
}

.bs__content td:first-child,
.bs__content th:first-child {
  text-align: left;
  font-weight: 500;
  color: var(--color-foreground);
}

.bs__content td:last-child,
.bs__content th:last-child {
  text-align: right;
  font-weight: 600;
  color: var(--color-foreground);
}

.bs__content a {
  color: var(--color-primary);
  text-decoration: underline;
  text-underline-offset: 2px;
  text-decoration-thickness: 1px;
}

.bs__content a:hover {
  text-decoration-thickness: 2px;
}

.bs__content blockquote {
  border-left: 4px solid var(--color-primary);
  padding: var(--space-s) var(--space-m);
  margin: var(--space-l) 0;
  background: var(--color-surface);
  border-radius: 0 var(--radius-m) var(--radius-m) 0;
  font-style: italic;
  font-size: var(--text-l);
  line-height: 1.7;
  color: var(--color-foreground-light);
}

.bs__content strong {
  font-weight: 700;
  color: var(--color-foreground);
}

/* Primer párrafo destacado (entradilla) */
.bs__content > p:first-child {
  font-size: var(--text-xl);
  line-height: 1.6;
  color: var(--color-foreground);
}

/* Separación visual entre secciones (antes de H2) */
.bs__content h2::before {
  content: "";
  display: block;
  width: 40px;
  height: 3px;
  background: var(--color-primary);
  margin-bottom: var(--space-s);
  border-radius: 2px;
}

/* --- Sidebar --- */
.bs__sidebar {
  position: relative;
}

.bs__sidebar-sticky {
  position: sticky;
  top: 100px;
  display: flex;
  flex-direction: column;
  gap: var(--space-m);
}

/* Agent card in sidebar — uses .agent-card from components.css.
   Only override max-width to fit the 340px sidebar. */
.bs__sidebar .agent-card {
  max-width: none;
}

/* Table of contents */
.bs__toc {
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-l);
  padding: var(--space-m);
}

.bs__toc-title {
  font-size: var(--text-s);
  font-weight: 700;
  color: var(--color-foreground);
  margin-bottom: var(--space-xs);
}

.bs__toc-list {
  list-style: none;
  padding: 0;
  margin: 0;
  counter-reset: toc;
}

.bs__toc-item {
  counter-increment: toc;
  margin-bottom: var(--space-3xs);
}

.bs__toc-link {
  display: block;
  font-size: var(--text-s);
  color: var(--color-foreground-light);
  text-decoration: none;
  padding: var(--space-3xs) 0;
  transition: color var(--transition-fast);
  line-height: 1.4;
}

.bs__toc-link::before {
  content: counter(toc) ". ";
  font-weight: 600;
  color: var(--color-primary);
}

.bs__toc-link:hover {
  color: var(--color-primary);
}

/* Sidebar cards (location, service) */
.bs__sidebar-related {
  display: flex;
  flex-direction: column;
  gap: var(--space-xs);
}

.bs__sidebar-card {
  display: flex;
  flex-direction: column;
  gap: var(--space-3xs);
  padding: var(--space-s);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-m);
  text-decoration: none;
  color: var(--color-foreground);
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}

.bs__sidebar-card:hover {
  border-color: var(--color-primary);
  box-shadow: var(--shadow-s);
}

.bs__sidebar-card-label {
  font-size: var(--text-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--color-primary);
}

.bs__sidebar-card-icon {
  font-size: var(--text-xl);
}

.bs__sidebar-card-name {
  font-size: var(--text-m);
  font-weight: 700;
}

.bs__sidebar-card-desc,
.bs__sidebar-card-phone {
  font-size: var(--text-xs);
  color: var(--color-foreground-light);
}

.bs__sidebar-card-arrow {
  font-size: var(--text-s);
  color: var(--color-primary);
  font-weight: 600;
}

/* --- Service CTA box --- */
.bs__service-cta {
  margin-top: var(--space-l);
  background: var(--color-primary);
  border-radius: var(--radius-l);
  padding: var(--space-l);
  color: var(--color-white);
}

.bs__service-cta-badge {
  font-size: var(--text-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: rgba(255, 255, 255, 0.7);
  margin-bottom: var(--space-xs);
}

.bs__service-cta-inner {
  display: flex;
  align-items: center;
  gap: var(--space-s);
  margin-bottom: var(--space-s);
}

.bs__service-cta-icon {
  font-size: var(--text-3xl);
  flex-shrink: 0;
  filter: brightness(0) invert(1);
}

.bs__service-cta-content {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: var(--space-3xs);
}

.bs__service-cta-title {
  font-size: var(--text-xl);
  font-weight: 800;
  color: var(--color-white);
}

.bs__service-cta-desc {
  font-size: var(--text-s);
  color: rgba(255, 255, 255, 0.8);
  line-height: 1.5;
}

.bs__service-cta-link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2xs);
  font-size: var(--text-m);
  font-weight: 700;
  color: var(--color-white);
  text-decoration: none;
  background: rgba(0, 0, 0, 0.25);
  padding: var(--space-xs) var(--space-m);
  border-radius: var(--radius-m);
  transition: background var(--transition-fast);
}

.bs__service-cta-link:hover {
  background: rgba(0, 0, 0, 0.4);
  color: var(--color-white);
}

/* --- Inline CTA (end of article) --- */
.bs__inline-cta {
  margin-top: var(--space-xl);
  background:
    radial-gradient(ellipse at 90% 30%, rgba(200, 2, 38, 0.1) 0%, transparent 50%),
    repeating-linear-gradient(
      -45deg,
      transparent,
      transparent 40px,
      rgba(255, 255, 255, 0.015) 40px,
      rgba(255, 255, 255, 0.015) 42px
    ),
    linear-gradient(160deg, var(--color-secondary) 0%, #0f1114 80%);
  border-radius: var(--radius-l);
  padding: var(--space-l) var(--space-xl);
  position: relative;
  overflow: hidden;
}

.bs__inline-cta::before {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  width: 30%;
  height: 100%;
  background: var(--color-primary);
  opacity: 0.07;
  clip-path: polygon(40% 0, 100% 0, 100% 100%, 10% 100%);
  pointer-events: none;
}

.bs__inline-cta-inner {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: var(--space-s);
}

.bs__inline-cta-header {
  display: flex;
  align-items: center;
  gap: var(--space-xs);
  color: var(--color-white);
}

.bs__inline-cta-header svg {
  color: var(--color-primary);
  flex-shrink: 0;
  display: block;
}

.bs__inline-cta-title {
  font-size: var(--text-xl);
  font-weight: 800;
  color: var(--color-white);
  margin: 0 !important;
  padding: 0;
  line-height: 1.2;
  margin: 0;
}

.bs__inline-cta-text {
  color: rgba(255, 255, 255, 0.75);
  font-size: var(--text-m);
  line-height: 1.6;
  margin: 0;
  max-width: 500px;
}

.bs__inline-cta-actions {
  display: flex;
  align-items: center;
  gap: var(--space-s);
  flex-wrap: wrap;
  margin-top: var(--space-2xs);
}

/* WhatsApp button — green, high contrast */
.bs__inline-cta-actions .cta-btn--primary {
  background: #25D366;
  color: #fff;
  border: none;
}

.bs__inline-cta-actions .cta-btn--primary:hover {
  background: #1da851;
}

/* Outline button — white border, visible */
.bs__inline-cta-actions .cta-btn--outline {
  border-color: rgba(255, 255, 255, 0.4);
  color: var(--color-white);
}

.bs__inline-cta-actions .cta-btn--outline:hover {
  background: rgba(255, 255, 255, 0.1);
  border-color: var(--color-white);
}

.bs__inline-cta-btn {
  min-width: 0;
}

.bs__inline-cta-link {
  font-size: var(--text-s);
  font-weight: 600;
  color: rgba(255, 255, 255, 0.5);
  text-decoration: none;
  transition: color var(--transition-fast);
}

.bs__inline-cta-link:hover {
  color: var(--color-white);
}

/* --- Recent posts --- */
.bs__recientes {
  background: var(--color-surface);
  padding: var(--section-space-m) var(--gutter);
}

.bs__recientes-inner {
  max-width: var(--wide-width);
  margin-inline: auto;
}

.bs__recientes-titulo {
  font-size: var(--text-2xl);
  font-weight: 800;
  text-transform: uppercase;
  text-align: center;
  margin-bottom: var(--space-l);
}

.bs__rec-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: var(--space-l);
}

.bs__rec-card {
  display: flex;
  flex-direction: column;
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-l);
  overflow: hidden;
  text-decoration: none;
  color: var(--color-foreground);
  transition: box-shadow var(--transition-base), border-color var(--transition-base);
}

.bs__rec-card:hover {
  box-shadow: var(--shadow-l);
  border-color: var(--color-primary);
}

.bs__rec-image {
  aspect-ratio: 16 / 9;
  overflow: hidden;
}

.bs__rec-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transition-slow);
}

.bs__rec-card:hover .bs__rec-img {
  transform: scale(1.05);
}

.bs__rec-body {
  padding: var(--space-m);
  display: flex;
  flex-direction: column;
  gap: var(--space-3xs);
}

.bs__rec-tag {
  font-size: var(--text-xs);
  font-weight: 600;
  color: var(--color-primary);
  text-transform: uppercase;
}

.bs__rec-title {
  font-size: var(--text-l);
  font-weight: 700;
  line-height: 1.3;
}

.bs__rec-date {
  font-size: var(--text-xs);
  color: var(--color-foreground-light);
}

.bs__recientes-cta {
  text-align: center;
  margin-top: var(--space-l);
}

.bs__ver-todos {
  font-size: var(--text-m);
  font-weight: 600;
  color: var(--color-primary);
  text-decoration: none;
}

.bs__ver-todos:hover {
  color: var(--color-primary-dark);
}

/* --- Final CTA --- */
.bs__cta {
  background: var(--color-primary);
  color: var(--color-white);
  text-align: center;
  padding: var(--section-space-m) var(--gutter);
}

.bs__cta-inner {
  max-width: 640px;
  margin-inline: auto;
}

.bs__cta-titulo {
  font-size: var(--text-3xl);
  font-weight: 800;
  text-transform: uppercase;
  margin-bottom: var(--space-s);
}

.bs__cta-texto {
  font-size: var(--text-l);
  color: rgba(255, 255, 255, 0.72);
  margin-bottom: var(--space-l);
}

.bs__cta-buttons {
  display: flex;
  justify-content: center;
  gap: var(--space-s);
  flex-wrap: wrap;
}

.bs__cta .cta-btn--primary {
  background: var(--color-white);
  color: var(--color-primary);
}

.bs__cta .cta-btn--primary:hover {
  background: var(--color-surface);
}

.bs__cta .cta-btn--secondary {
  background: transparent;
  color: var(--color-white);
  border: 2px solid rgba(255, 255, 255, 0.4);
}

.bs__cta .cta-btn--secondary:hover {
  border-color: var(--color-white);
  background: rgba(255, 255, 255, 0.1);
}

/* ==========================================================================
   C. RESPONSIVE
   ========================================================================== */

@media (max-width: 768px) {
  .bs__body-inner {
    grid-template-columns: 1fr;
  }

  .bs__sidebar {
    order: 2;
  }

  .bs__sidebar-sticky {
    position: static;
  }

  .bs__titulo {
    font-size: var(--text-3xl);
    text-shadow: 0 1px 10px rgba(0, 0, 0, 0.4);
  }

  .bs__content {
    font-size: var(--text-m);
    line-height: 1.7;
  }

  .bs__content > p:first-child {
    font-size: var(--text-l);
  }

  .bs__service-cta-inner {
    flex-direction: column;
  }

  .bs__inline-cta {
    padding: var(--space-m);
  }

  .bs__inline-cta-actions {
    flex-direction: column;
    align-items: stretch;
  }

  .bs__inline-cta-link {
    text-align: center;
  }


  .blog-archive__grid {
    grid-template-columns: 1fr;
  }

  .bs__rec-grid {
    grid-template-columns: 1fr;
  }

  .bs__inline-cta-inner {
    gap: var(--space-xs);
  }

  .bs__meta {
    flex-direction: column;
    gap: var(--space-3xs);
  }

  .bs__sep {
    display: none;
  }
}
