/* ==========================================================================
   1Vuelos Directory — main.css
   Mobile-first. CSS custom properties. BEM-ish.
   ========================================================================== */

:root {
  /* Colors */
  --c-primary: #0B3D91;
  --c-primary-light: #1E6FD9;
  --c-primary-dark: #062659;
  --c-accent: #FF6B35;
  --c-accent-light: #FF8F66;
  --c-accent-dark: #E5521C;
  --c-success: #2ECC71;
  --c-warning: #F39C12;
  --c-danger: #E74C3C;
  --c-bg: #F8F9FA;
  --c-bg-alt: #FFFFFF;
  --c-text: #2C3E50;
  --c-text-light: #7F8C8D;
  --c-border: #E0E4E8;
  --c-shadow: rgba(11, 61, 145, 0.08);

  /* Typography */
  --f-primary: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  --f-heading: 'Poppins', var(--f-primary);

  /* Sizing */
  --s-xs: 4px;
  --s-sm: 8px;
  --s-md: 16px;
  --s-lg: 24px;
  --s-xl: 32px;
  --s-2xl: 48px;
  --s-3xl: 64px;

  /* Radius */
  --r-sm: 6px;
  --r-md: 12px;
  --r-lg: 16px;
  --r-full: 9999px;

  /* Shadow */
  --sh-sm: 0 1px 3px rgba(0,0,0,0.08);
  --sh-md: 0 4px 12px var(--c-shadow);
  --sh-lg: 0 8px 30px rgba(0,0,0,0.12);
  --sh-hover: 0 12px 40px rgba(0,0,0,0.15);

  /* Layout */
  --container-max: 1200px;
  --header-h: 72px;

  /* Transitions */
  --t-fast: 150ms ease;
  --t-med: 250ms ease;
}

/* Reset */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body { font-family: var(--f-primary); font-size: 16px; line-height: 1.6; color: var(--c-text); background: var(--c-bg); -webkit-font-smoothing: antialiased; }
h1, h2, h3, h4, h5, h6 { font-family: var(--f-heading); font-weight: 700; line-height: 1.25; color: var(--c-primary-dark); }
img, svg, video { max-width: 100%; height: auto; display: block; }
a { color: var(--c-primary); text-decoration: none; transition: color var(--t-fast); }
a:hover { color: var(--c-accent); }
button { font: inherit; cursor: pointer; border: none; background: transparent; color: inherit; }
ul, ol { padding: 0; list-style: none; }
input, textarea, select { font: inherit; }

.screen-reader-text { position: absolute !important; clip: rect(1px,1px,1px,1px); width: 1px; height: 1px; overflow: hidden; }
.skip-link { position: absolute; left: -9999px; }
.skip-link:focus { position: fixed; top: 10px; left: 10px; background: var(--c-primary); color: #fff; padding: 10px 16px; border-radius: var(--r-sm); z-index: 9999; }

.container { max-width: var(--container-max); margin: 0 auto; padding: 0 var(--s-md); }

/* ==========================================================================
   Buttons
   ========================================================================== */
.btn {
  display: inline-flex; align-items: center; gap: var(--s-sm);
  padding: 12px 24px;
  border-radius: var(--r-full);
  font-weight: 600;
  font-size: 15px;
  transition: all var(--t-med);
  cursor: pointer;
  text-align: center;
  justify-content: center;
  border: 2px solid transparent;
}
.btn--primary { background: var(--c-primary); color: #fff; }
.btn--primary:hover { background: var(--c-primary-light); color: #fff; transform: translateY(-2px); box-shadow: var(--sh-md); }
.btn--accent { background: var(--c-accent); color: #fff; }
.btn--accent:hover { background: var(--c-accent-dark); color: #fff; transform: translateY(-2px); box-shadow: 0 8px 20px rgba(255,107,53,0.35); }
.btn--outline { background: transparent; border-color: var(--c-primary); color: var(--c-primary); }
.btn--outline:hover { background: var(--c-primary); color: #fff; }
.btn--block { display: flex; width: 100%; }

/* ==========================================================================
   Header + nav
   ========================================================================== */
.site-header {
  position: sticky; top: 0; z-index: 100;
  background: rgba(255,255,255,0.95);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--c-border);
  min-height: var(--header-h);
}
.site-header__inner {
  display: flex; align-items: center; justify-content: space-between;
  min-height: var(--header-h);
  gap: var(--s-md);
}
.site-logo { display: block; }
.site-logo__svg { height: 40px; width: auto; }
.site-nav { display: none; }
.site-nav__list { display: flex; gap: var(--s-lg); align-items: center; }
.site-nav__list a { font-weight: 500; color: var(--c-text); padding: 8px 4px; position: relative; }
.site-nav__list a:hover { color: var(--c-primary); }
.site-nav__list .has-megamenu { position: static; }
/* Puente invisible: el trigger tiene area extendida hacia abajo para que el hover no se pierda al bajar al megamenu */
.site-nav__list .has-megamenu > a::after { content: ''; position: absolute; left: 0; top: 100%; width: 100%; height: 16px; }
.megamenu { position: absolute; top: 100%; left: 0; right: 0; background: #fff; box-shadow: var(--sh-lg); border-top: 1px solid var(--c-border); padding: var(--s-2xl) 0; opacity: 0; visibility: hidden; transform: translateY(-6px); pointer-events: none; transition: opacity 180ms ease, transform 180ms ease, visibility 0s linear 280ms; z-index: 50; }
.site-nav__list .has-megamenu:hover .megamenu,
.site-nav__list .has-megamenu:focus-within .megamenu,
.site-nav__list .has-megamenu .megamenu:hover { opacity: 1; visibility: visible; transform: translateY(0); pointer-events: auto; transition: opacity 180ms ease, transform 180ms ease, visibility 0s linear 0s; }
.megamenu__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--s-xl); }
.megamenu__col h4 { margin-bottom: var(--s-md); font-size: 14px; text-transform: uppercase; letter-spacing: 0.5px; color: var(--c-accent); }
.megamenu__col ul { display: flex; flex-direction: column; gap: 6px; }
.megamenu__col a { font-size: 14px; padding: 4px 0; display: block; }
.megamenu__col a:hover { color: var(--c-accent); }

.site-header__actions { display: flex; align-items: center; gap: var(--s-sm); }
.search-toggle, .menu-toggle {
  display: flex; align-items: center; justify-content: center;
  width: 44px; height: 44px; border-radius: var(--r-full);
  color: var(--c-primary);
}
.search-toggle:hover { background: rgba(11,61,145,0.08); }
.menu-toggle { flex-direction: column; gap: 5px; }
.menu-toggle span { width: 22px; height: 2px; background: var(--c-primary); border-radius: 2px; transition: all var(--t-med); }
.menu-toggle[aria-expanded="true"] span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.menu-toggle[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.menu-toggle[aria-expanded="true"] span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

.search-drawer { background: var(--c-primary-dark); padding: var(--s-xl) 0; }
.search-drawer[hidden] { display: none; }
.search-drawer__form { display: flex; gap: var(--s-sm); }
.search-drawer__form input {
  flex: 1; padding: 14px 20px;
  border: 2px solid transparent; border-radius: var(--r-full);
  background: #fff; font-size: 16px;
}
.search-drawer__form input:focus { outline: none; border-color: var(--c-accent); }
.search-drawer__form button {
  padding: 14px 28px; background: var(--c-accent); color: #fff;
  border-radius: var(--r-full); font-weight: 600;
}
.search-drawer__results { margin-top: var(--s-md); color: #fff; }

/* ==========================================================================
   Hero
   ========================================================================== */
.hero { position: relative; padding: var(--s-3xl) 0 var(--s-3xl); text-align: center; overflow: hidden; }
.hero__bg {
  position: absolute; inset: 0;
  background: linear-gradient(135deg, var(--c-primary-dark) 0%, var(--c-primary) 50%, var(--c-primary-light) 100%);
  z-index: -1;
}
.hero__bg::after {
  content: ''; position: absolute; inset: 0;
  background-image:
    radial-gradient(circle at 20% 30%, rgba(255,107,53,0.15) 0%, transparent 40%),
    radial-gradient(circle at 80% 70%, rgba(30,111,217,0.25) 0%, transparent 40%);
}
.hero__inner { color: #fff; max-width: 900px; margin: 0 auto; }
.hero__title { font-size: clamp(32px, 6vw, 56px); color: #fff; margin-bottom: var(--s-md); }
.hero__title span { color: var(--c-accent-light); display: inline-block; }
.hero__lead { font-size: clamp(16px, 2vw, 20px); opacity: 0.9; margin-bottom: var(--s-2xl); max-width: 640px; margin-left: auto; margin-right: auto; }

.hero-search {
  background: #fff; border-radius: var(--r-lg); box-shadow: var(--sh-lg);
  padding: var(--s-md); max-width: 780px; margin: 0 auto;
  text-align: left;
}
.hero-search__tabs { display: flex; gap: 4px; padding-bottom: var(--s-md); border-bottom: 1px solid var(--c-border); margin-bottom: var(--s-md); overflow-x: auto; }
.hero-search__tab {
  padding: 10px 16px; border-radius: var(--r-full);
  font-weight: 600; font-size: 14px; color: var(--c-text-light);
  white-space: nowrap;
}
.hero-search__tab.is-active { background: var(--c-primary); color: #fff; }
.hero-search__form { display: flex; gap: var(--s-sm); align-items: stretch; flex-direction: column; }
.hero-search__field { flex: 1; display: flex; flex-direction: column; gap: 4px; padding: 10px 14px; border-radius: var(--r-md); border: 1px solid var(--c-border); transition: border-color var(--t-fast); }
.hero-search__field:focus-within { border-color: var(--c-primary); }
.hero-search__field label { font-size: 11px; text-transform: uppercase; letter-spacing: 0.5px; color: var(--c-text-light); }
.hero-search__field input { border: none; outline: none; background: transparent; padding: 4px 0; font-size: 15px; }
.hero-search__submit { min-height: 56px; }
.hero-search__live:empty { display: none; }
.hero-search__live { margin-top: var(--s-md); padding: var(--s-md); background: var(--c-bg); border-radius: var(--r-md); }

/* ==========================================================================
   Sections
   ========================================================================== */
.section { padding: var(--s-3xl) 0; }
.section--alt { background: var(--c-bg-alt); }
.section--cta { padding: var(--s-2xl) 0; }
.section__head { display: flex; justify-content: space-between; align-items: center; margin-bottom: var(--s-xl); flex-wrap: wrap; gap: var(--s-md); }
.section__title { font-size: clamp(24px, 3vw, 32px); }
.section__cta { font-weight: 600; color: var(--c-accent); }
.section__cta:hover { color: var(--c-accent-dark); }

/* ==========================================================================
   Cards / Grids
   ========================================================================== */
.directory-grid, .posts-grid, .carousel--cards {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: var(--s-lg);
}
.carousel--cards { grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); }

.card {
  background: #fff; border-radius: var(--r-md); overflow: hidden;
  transition: all var(--t-med); box-shadow: var(--sh-sm);
}
.card:hover { transform: translateY(-4px); box-shadow: var(--sh-hover); }
.card__link { display: block; color: inherit; height: 100%; }
.card__link:hover { color: inherit; }
.card__thumb { aspect-ratio: 16/10; overflow: hidden; background: var(--c-bg); position: relative; }
.card__thumb img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--t-med); }
.card:hover .card__thumb img { transform: scale(1.05); }
.card__thumb--placeholder { display: flex; align-items: center; justify-content: center; font-size: 64px; color: var(--c-primary-light); background: linear-gradient(135deg, #f0f4fa, #e2ebfa); }
.card__body { padding: var(--s-md); }
.card__title { font-size: 18px; margin-bottom: var(--s-sm); }
.card__meta { font-size: 13px; color: var(--c-text-light); margin-bottom: 4px; }
.card__excerpt { font-size: 14px; color: var(--c-text-light); margin-bottom: var(--s-sm); }
.card__tag { display: inline-block; padding: 2px 10px; border-radius: var(--r-full); background: var(--c-primary); color: #fff; font-size: 11px; font-weight: 700; letter-spacing: 0.5px; }
.card__tag--iata { background: var(--c-accent); }
.card__price { font-size: 14px; color: var(--c-text); }
.card__price strong { color: var(--c-accent); font-size: 16px; }
.card__more { display: inline-block; margin-top: var(--s-sm); color: var(--c-accent); font-size: 13px; font-weight: 600; }
.card__logo { aspect-ratio: 3/2; display: flex; align-items: center; justify-content: center; padding: var(--s-md); background: #fff; }
.card__logo img { max-height: 80px; width: auto; object-fit: contain; }
.card__logo--placeholder { font-size: 48px; color: var(--c-primary-light); }
.card--aerolinea { text-align: center; padding: var(--s-md); }
.card--aerolinea .card__title { font-size: 14px; margin-top: var(--s-sm); }

.stars { color: var(--c-warning); font-size: 18px; letter-spacing: 2px; }
.stars--sm { font-size: 13px; letter-spacing: 1px; }

/* Continents */
.continents-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: var(--s-lg); }
.continent-card {
  background: linear-gradient(135deg, var(--c-primary) 0%, var(--c-primary-light) 100%);
  color: #fff; padding: var(--s-xl); border-radius: var(--r-md);
  text-align: center; transition: all var(--t-med); min-height: 200px;
  display: flex; flex-direction: column; justify-content: center; align-items: center; gap: var(--s-sm);
}
.continent-card:hover { transform: translateY(-4px) scale(1.02); box-shadow: var(--sh-hover); color: #fff; }
.continent-card__icon { font-size: 56px; }
.continent-card h3 { color: #fff; font-size: 22px; }
.continent-card p { font-size: 14px; opacity: 0.9; }

/* Viajes por estilo */
.viajes-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: var(--s-md); }
.viajes-card {
  position: relative; display: flex; align-items: flex-end;
  min-height: 180px; padding: var(--s-lg);
  border-radius: var(--r-md); overflow: hidden;
  background-color: var(--c-primary-dark);
  background-size: cover; background-position: center;
  color: #fff; text-decoration: none;
  transition: transform var(--t-med), box-shadow var(--t-med);
}
.viajes-card:hover { transform: translateY(-4px) scale(1.02); box-shadow: var(--sh-hover); color: #fff; }
.viajes-card__overlay {
  position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(6,38,89,0) 0%, rgba(6,38,89,0.75) 100%);
}
.viajes-card__title {
  position: relative; z-index: 1; margin: 0;
  font-size: 20px; font-weight: 700; color: #fff; line-height: 1.2;
}

/* Landing SEO */
.landing-seo { margin-top: var(--s-2xl); padding-top: var(--s-xl); border-top: 1px solid var(--c-border); }
.landing-seo__header { margin-bottom: var(--s-lg); }
.landing-seo__title { font-size: 26px; font-weight: 700; color: var(--c-primary-dark); margin: 0; }
.landing-seo.empty .empty-state { text-align: center; padding: var(--s-xl); color: var(--c-text-muted); }

/* Directorio hub */
.directorio-hub { margin-top: var(--s-2xl); }
.directorio-hub__group { margin-bottom: var(--s-2xl); padding-bottom: var(--s-xl); border-bottom: 1px solid var(--c-border); }
.directorio-hub__group:last-child { border-bottom: none; }
.directorio-hub__group-title { font-size: 24px; font-weight: 700; color: var(--c-primary-dark); margin: 0 0 var(--s-md); }
.directorio-hub__count { color: var(--c-text-muted); font-weight: 400; font-size: 16px; }
.directorio-hub__list { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: var(--s-sm); list-style: none; padding: 0; margin: 0; }
.directorio-hub__list li a { display: flex; justify-content: space-between; align-items: center; padding: var(--s-sm) var(--s-md); border: 1px solid var(--c-border); border-radius: var(--r-sm); color: var(--c-text); text-decoration: none; transition: all var(--t-fast); }
.directorio-hub__list li a:hover { border-color: var(--c-primary); color: var(--c-primary); background: var(--c-bg); }
.directorio-hub__item-count { background: var(--c-primary); color: #fff; font-size: 12px; font-weight: 600; padding: 2px 8px; border-radius: 999px; }

/* CTA outline "Ver todos" en single-ciudad */
.btn--landing { display: inline-block; margin: var(--s-md) var(--s-sm) 0 0; padding: var(--s-sm) var(--s-lg); border: 2px solid var(--c-primary); border-radius: var(--r-sm); color: var(--c-primary); font-weight: 600; text-decoration: none; transition: all var(--t-fast); }
.btn--landing:hover { background: var(--c-primary); color: #fff; }

/* Megamenu Viajes */
.megamenu--viajes .megamenu__col--full { width: 100%; }
.megamenu--viajes .megamenu__col--full ul {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: var(--s-sm); list-style: none; padding: 0; margin: 0;
}
.megamenu--viajes .megamenu__col--full li a {
  display: block; padding: var(--s-sm); border-radius: var(--r-sm);
  color: var(--c-text); text-decoration: none; transition: background var(--t-fast);
}
.megamenu--viajes .megamenu__col--full li a:hover { background: var(--c-bg); color: var(--c-primary); }

/* Airlines grid */
.airlines-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: var(--s-md); }

/* Post cards */
.post-card { background: #fff; border-radius: var(--r-md); overflow: hidden; box-shadow: var(--sh-sm); transition: all var(--t-med); }
.post-card:hover { transform: translateY(-2px); box-shadow: var(--sh-md); }
.post-card__thumb { aspect-ratio: 16/10; overflow: hidden; display: block; }
.post-card__thumb img { width: 100%; height: 100%; object-fit: cover; }
.post-card__body { padding: var(--s-md); }
.post-card__date { font-size: 12px; color: var(--c-text-light); text-transform: uppercase; letter-spacing: 0.5px; }
.post-card__title { font-size: 18px; margin: var(--s-sm) 0; }
.post-card__title a { color: var(--c-primary-dark); }
.post-card__title a:hover { color: var(--c-accent); }
.post-card__excerpt { font-size: 14px; color: var(--c-text-light); }
.post-card__more { font-size: 13px; font-weight: 600; color: var(--c-accent); display: inline-block; margin-top: var(--s-sm); }

/* CTA box */
.cta-box {
  background: linear-gradient(135deg, var(--c-primary-dark), var(--c-primary));
  color: #fff; padding: var(--s-2xl); border-radius: var(--r-lg);
  text-align: center;
}
.cta-box h2 { color: #fff; font-size: clamp(22px, 3vw, 28px); margin-bottom: var(--s-sm); }
.cta-box p { opacity: 0.9; margin-bottom: var(--s-xl); }
.cta-box .newsletter-form { max-width: 500px; margin: 0 auto; }

/* Newsletter */
.newsletter-form { display: flex; gap: var(--s-sm); flex-wrap: wrap; }
.newsletter-form input {
  flex: 1 1 240px; padding: 14px 20px;
  border: none; border-radius: var(--r-full);
  background: rgba(255,255,255,0.15); color: #fff;
  font-size: 15px;
}
.newsletter-form input::placeholder { color: rgba(255,255,255,0.7); }
.newsletter-form input:focus { outline: 2px solid var(--c-accent); background: rgba(255,255,255,0.2); }
.newsletter-form__msg { flex: 1 1 100%; font-size: 13px; min-height: 18px; }
.newsletter-form__msg.is-success { color: var(--c-success); }
.newsletter-form__msg.is-error { color: var(--c-accent-light); }

/* ==========================================================================
   Single CPT
   ========================================================================== */
.cpt-hero {
  background: linear-gradient(135deg, var(--c-primary-dark), var(--c-primary-light));
  background-size: cover !important;
  background-position: center !important;
  color: #fff;
  padding: var(--s-3xl) 0 var(--s-2xl);
  min-height: 420px;
  display: flex; align-items: flex-end;
}
.cpt-hero--compact { min-height: 220px; padding: var(--s-2xl) 0 var(--s-xl); }
.cpt-hero__title { font-size: clamp(32px, 5vw, 48px); color: #fff; margin-bottom: var(--s-sm); }
.cpt-hero__lead { font-size: clamp(16px, 2vw, 20px); opacity: 0.92; max-width: 720px; margin-bottom: var(--s-lg); }
.cpt-hero__facts { display: flex; flex-wrap: wrap; gap: var(--s-md) var(--s-xl); font-size: 15px; }
.cpt-hero__facts li { color: rgba(255,255,255,0.92); }
.cpt-hero__facts--inline { gap: var(--s-md); }
.cpt-hero__flex { display: flex; gap: var(--s-lg); align-items: center; flex-wrap: wrap; }
.cpt-hero__logo { background: #fff; border-radius: var(--r-md); padding: var(--s-sm); width: 120px; }

.cpt-body { display: grid; grid-template-columns: 1fr; gap: var(--s-2xl); padding: var(--s-2xl) var(--s-md); }
.cpt-body__content { max-width: 760px; }
.cpt-body__sidebar { position: sticky; top: calc(var(--header-h) + var(--s-md)); align-self: start; }

.cpt-tabs { display: flex; gap: 0; border-bottom: 2px solid var(--c-border); margin-bottom: var(--s-xl); overflow-x: auto; }
.cpt-tabs__tab { padding: var(--s-md) var(--s-lg); font-weight: 600; color: var(--c-text-light); border-bottom: 3px solid transparent; white-space: nowrap; }
.cpt-tabs__tab.is-active, .cpt-tabs__tab:hover { color: var(--c-primary); border-bottom-color: var(--c-accent); }
.cpt-section { padding: var(--s-xl) 0; scroll-margin-top: calc(var(--header-h) + 20px); }
.cpt-section h2 { margin-bottom: var(--s-lg); }

.info-box { background: #fff; border-radius: var(--r-md); box-shadow: var(--sh-md); padding: var(--s-lg); min-width: 280px; }
.info-box h3 { margin-bottom: var(--s-sm); font-size: 18px; }
.info-box__price { margin-bottom: var(--s-md); font-size: 14px; color: var(--c-text-light); }
.info-box__price strong { color: var(--c-accent); font-size: 20px; }
.info-box--booking { border: 2px solid var(--c-accent); }

.amenities, .checklist, .crosslist, .itinerary, .contact-list { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: var(--s-sm) var(--s-md); padding: var(--s-md) 0; }
.amenities li::before { content: '✓ '; color: var(--c-success); font-weight: 700; }
.checklist li::before { content: '✓ '; color: var(--c-success); font-weight: 700; }
.crosslist li::before { content: '✗ '; color: var(--c-danger); font-weight: 700; }
.itinerary { counter-reset: step; grid-template-columns: 1fr; }
.itinerary li { counter-increment: step; padding-left: 40px; position: relative; margin-bottom: var(--s-sm); }
.itinerary li::before { content: counter(step); position: absolute; left: 0; top: 0; width: 28px; height: 28px; border-radius: 50%; background: var(--c-primary); color: #fff; display: flex; align-items: center; justify-content: center; font-weight: 700; font-size: 13px; }
.contact-list { grid-template-columns: 1fr; gap: var(--s-sm); }
.contact-list li { padding: 6px 0; }

.cta-afiliado {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: var(--s-md); margin-top: var(--s-md);
}
.cta-afiliado__item { background: #fff; padding: var(--s-lg); border-radius: var(--r-md); box-shadow: var(--sh-sm); text-align: center; }
.cta-afiliado__icon { font-size: 36px; display: block; margin-bottom: var(--s-sm); }
.cta-afiliado__item h3 { font-size: 18px; margin-bottom: var(--s-sm); }
.cta-afiliado__item p { font-size: 13px; color: var(--c-text-light); margin-bottom: var(--s-md); }

/* Prose (content from editor) */
.prose { font-size: 16px; line-height: 1.7; }
.prose h2 { margin: var(--s-xl) 0 var(--s-md); font-size: 26px; }
.prose h3 { margin: var(--s-lg) 0 var(--s-sm); font-size: 20px; }
.prose p { margin-bottom: var(--s-md); }
.prose ul, .prose ol { margin-bottom: var(--s-md); padding-left: var(--s-lg); list-style: disc; }
.prose ol { list-style: decimal; }
.prose a { color: var(--c-primary); text-decoration: underline; }
.prose img { border-radius: var(--r-md); margin: var(--s-md) 0; }

/* Breadcrumbs */
.breadcrumbs ol { display: flex; flex-wrap: wrap; gap: var(--s-sm); font-size: 13px; align-items: center; }
.breadcrumbs li:not(:last-child)::after { content: '›'; margin-left: var(--s-sm); color: var(--c-text-light); }
.breadcrumbs a { color: inherit; opacity: 0.85; }
.breadcrumbs a:hover { opacity: 1; }
.cpt-hero .breadcrumbs { margin-bottom: var(--s-md); color: rgba(255,255,255,0.85); }

/* Search */
.search-form { display: flex; gap: var(--s-sm); max-width: 500px; margin: var(--s-md) 0; }
.search-form__field { flex: 1; padding: 12px 18px; border-radius: var(--r-full); border: 2px solid var(--c-border); font-size: 15px; }
.search-form__field:focus { outline: none; border-color: var(--c-primary); }
.search-form__submit { padding: 12px 24px; background: var(--c-primary); color: #fff; border-radius: var(--r-full); font-weight: 600; }
.search-result { padding: var(--s-md) 0; border-bottom: 1px solid var(--c-border); }
.search-result h3 { margin-bottom: 4px; }
.search-result__type { font-size: 12px; color: var(--c-accent); text-transform: uppercase; letter-spacing: 0.5px; }

/* Page layouts */
.page-container, .archive-container, .search-container, .single-post, .single-page { padding: var(--s-2xl) 0; }
.page-header { text-align: center; margin-bottom: var(--s-2xl); }
.page-title { font-size: clamp(28px, 4vw, 40px); margin-bottom: var(--s-sm); }
.page-subtitle { font-size: 17px; color: var(--c-text-light); max-width: 680px; margin: 0 auto; }
.single-post__title, .single-page .page-title { font-size: clamp(28px, 4vw, 42px); margin-bottom: var(--s-sm); }
.single-post__meta { color: var(--c-text-light); font-size: 14px; margin-bottom: var(--s-xl); }
.single-post__thumb { margin: var(--s-xl) 0; border-radius: var(--r-md); overflow: hidden; }
.single-post__thumb img { width: 100%; }
.single-post__article { max-width: 760px; margin: 0 auto; }
.single-page__content { max-width: 760px; margin: 0 auto; }
.page-excerpt { font-size: 18px; color: var(--c-text-light); max-width: 720px; margin: var(--s-sm) auto 0; line-height: 1.5; }
.page-hero { max-width: 1100px; margin: 0 auto var(--s-2xl); border-radius: var(--r-lg); overflow: hidden; box-shadow: 0 12px 32px rgba(11, 61, 145, 0.12); }
.page-hero img { display: block; width: 100%; height: auto; aspect-ratio: 12/5; object-fit: cover; }

/* Related blocks (auto-interlinking) */
.related-block { padding: var(--s-2xl) 0; border-top: 1px solid #e5e9f0; margin-top: var(--s-2xl); }
.related-block__group + .related-block__group { margin-top: var(--s-2xl); }
.related-block__title { font-size: clamp(20px, 2.5vw, 26px); margin-bottom: var(--s-lg); color: var(--c-primary-dark); }
.card--related { display: block; background: #fff; border-radius: var(--r-md); overflow: hidden; box-shadow: 0 4px 14px rgba(11, 61, 145, 0.08); text-decoration: none; color: inherit; transition: transform 180ms ease, box-shadow 180ms ease; }
.card--related:hover { transform: translateY(-2px); box-shadow: 0 10px 24px rgba(11, 61, 145, 0.14); }
.card--related .card__thumb { aspect-ratio: 16/10; overflow: hidden; }
.card--related .card__thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.card--related .card__body { padding: var(--s-md); }
.card--related .card__title { font-size: 17px; margin: 0 0 6px; color: var(--c-text); }
.card--related .card__excerpt { font-size: 14px; color: var(--c-text-light); margin: 0; line-height: 1.45; }

/* 404 */
.error-404 { padding: var(--s-3xl) 0; text-align: center; }
.error-404__inner { max-width: 560px; margin: 0 auto; }
.error-404__code { font-size: 120px; font-weight: 900; color: var(--c-primary-light); line-height: 1; margin-bottom: var(--s-md); font-family: var(--f-heading); }
.error-404__title { font-size: 32px; margin-bottom: var(--s-sm); }
.error-404__msg { color: var(--c-text-light); margin-bottom: var(--s-xl); }
.error-404__actions { display: flex; gap: var(--s-md); justify-content: center; flex-wrap: wrap; margin-top: var(--s-xl); }

.empty-state { text-align: center; padding: var(--s-2xl); color: var(--c-text-light); font-style: italic; }

/* Pagination */
.wp-pagenavi, .nav-links { display: flex; gap: var(--s-sm); justify-content: center; margin-top: var(--s-2xl); }
.page-numbers { display: inline-flex; align-items: center; justify-content: center; min-width: 40px; height: 40px; padding: 0 14px; border-radius: var(--r-full); background: #fff; color: var(--c-primary); font-weight: 600; border: 1px solid var(--c-border); }
.page-numbers.current, .page-numbers:hover { background: var(--c-primary); color: #fff; }

/* ==========================================================================
   Footer
   ========================================================================== */
.site-footer {
  background: var(--c-primary-dark); color: rgba(255,255,255,0.8);
  padding: var(--s-3xl) 0 var(--s-xl); margin-top: var(--s-3xl);
}
.site-footer__top { display: grid; grid-template-columns: 1fr; gap: var(--s-2xl); margin-bottom: var(--s-xl); }
.site-footer__brand { max-width: 380px; }
.site-footer__brand .site-logo svg { height: 48px; }
.site-footer__tagline { margin: var(--s-md) 0 var(--s-lg); opacity: 0.85; }
.site-footer__nav { display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); gap: var(--s-xl); }
.site-footer__col h4 { color: #fff; font-size: 14px; text-transform: uppercase; letter-spacing: 0.5px; margin-bottom: var(--s-md); }
.site-footer__col ul { display: flex; flex-direction: column; gap: var(--s-sm); }
.site-footer__col a { color: rgba(255,255,255,0.75); font-size: 14px; }
.site-footer__col a:hover { color: var(--c-accent-light); }
.site-footer__bottom { border-top: 1px solid rgba(255,255,255,0.1); padding-top: var(--s-lg); font-size: 13px; text-align: center; }
.site-footer__disclaimer { margin-top: 4px; opacity: 0.6; font-size: 12px; }

/* ==========================================================================
   Responsive
   ========================================================================== */
@media (min-width: 768px) {
  .hero-search__form { flex-direction: row; }
  .site-footer__top { grid-template-columns: 1fr 2fr; }
  .cpt-body { grid-template-columns: 2fr 1fr; padding: var(--s-2xl) var(--s-md); }
}

@media (min-width: 960px) {
  .site-nav { display: block; }
  .menu-toggle { display: none; }
  .hero { padding: var(--s-3xl) 0 var(--s-3xl); }
}

@media (max-width: 959px) {
  .site-nav {
    position: fixed; top: var(--header-h); right: 0; bottom: 0; width: 85%; max-width: 360px;
    background: #fff; box-shadow: var(--sh-lg);
    transform: translateX(100%); transition: transform var(--t-med);
    overflow-y: auto; padding: var(--s-lg);
  }
  .site-nav.is-open { display: block; transform: translateX(0); }
  .site-nav__list { flex-direction: column; align-items: stretch; gap: 0; }
  .site-nav__list li { border-bottom: 1px solid var(--c-border); }
  .site-nav__list a { display: block; padding: var(--s-md) 0; }
  .megamenu { position: static; box-shadow: none; padding: var(--s-md) 0; display: none; }
  .has-megamenu.is-open .megamenu { display: block; }
  .megamenu__grid { grid-template-columns: 1fr; gap: var(--s-lg); }
}
