/* ════════════════════════════════════════════════════════════
   PANISSE ÓPTICA — style.css
   Diseño: minimalista premium, modo claro, cristalismo sutil
════════════════════════════════════════════════════════════ */

/* ── RESET & BASE ─────────────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Parisienne&display=swap');

*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  font-size: 16px;
  scroll-behavior: smooth;
  -webkit-font-smoothing: antialiased;
}

body {
  font-family: 'Lato', sans-serif;
  font-weight: 400;
  color: #1a1a1a;
  background-color: #fafaf8;
  overflow-x: hidden;
}

img {
  display: block;
  max-width: 100%;
}

a {
  color: inherit;
  text-decoration: none;
}

/* ── VARIABLES ────────────────────────────────────────────── */
:root {
  --color-black:      #0d0d0d;
  --color-white:      #ffffff;
  --color-bg:         #ffffff;
  --color-surface:    #f5f5f3;
  --color-border:     #e8e8e2;
  --color-text:       #1a1a1a;
  --color-muted:      #7a7a74;
  --color-accent:     #c7dbd6;   /* sage verde, acento de marca */
  --color-accent-dk:  #8aafa9;

  --font-display:     'Cormorant Garamond', Georgia, serif;
  --font-body:        'Lato', system-ui, sans-serif;

  --radius-sm:  4px;
  --radius-md:  8px;
  --radius-lg:  16px;

  --shadow-sm:  0 1px 4px rgba(0,0,0,0.06);
  --shadow-md:  0 4px 20px rgba(0,0,0,0.08);
  --shadow-lg:  0 12px 40px rgba(0,0,0,0.12);

  --transition: 0.32s cubic-bezier(0.25, 0.46, 0.45, 0.94);

  --container-max: 1200px;
  --container-pad: clamp(20px, 5vw, 64px);
}

/* ── ANIMACIONES GLOBALES ─────────────────────────────────── */
@keyframes ticker-scroll {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

@keyframes fade-up {
  from { opacity: 0; transform: translateY(20px); }
  to   { opacity: 1; transform: translateY(0); }
}

@keyframes fade-in {
  from { opacity: 0; }
  to   { opacity: 1; }
}

/* ── UTILIDADES ───────────────────────────────────────────── */
.container {
  max-width: var(--container-max);
  margin-inline: auto;
  padding-inline: var(--container-pad);
}

/* ── BOTONES ──────────────────────────────────────────────── */
.btn {
  display: inline-block;
  font-family: var(--font-body);
  font-size: 0.6875rem;   /* 11px */
  font-weight: 700;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  padding: 14px 40px;
  border: 1px solid transparent;
  cursor: pointer;
  transition: background var(--transition), color var(--transition),
              border-color var(--transition), transform var(--transition);
  white-space: nowrap;
}

.btn:hover {
  transform: translateY(-1px);
}

.btn--primary {
  background: var(--color-white);
  color: var(--color-black);
  border-color: var(--color-white);
}

.btn--primary:hover {
  background: transparent;
  color: var(--color-white);
  border-color: var(--color-white);
}

.btn--secondary {
  background: var(--color-black);
  color: var(--color-white);
  border-color: var(--color-black);
}

.btn--secondary:hover {
  background: transparent;
  color: var(--color-black);
}

.btn--outline {
  background: transparent;
  color: var(--color-black);
  border-color: var(--color-black);
}

.btn--outline:hover {
  background: var(--color-black);
  color: var(--color-white);
}

/* ── ENCABEZADO DE SECCIÓN ────────────────────────────────── */
.section-header {
  text-align: center;
  margin-bottom: 52px;
}

.section-header__label {
  font-size: 0.625rem;   /* 10px */
  font-weight: 700;
  letter-spacing: 0.35em;
  text-transform: uppercase;
  color: var(--color-muted);
  margin-bottom: 10px;
}

.section-header__title {
  font-family: var(--font-display);
  font-size: clamp(1.75rem, 3vw, 2.5rem);
  font-weight: 400;
  color: var(--color-black);
  position: relative;
  display: inline-block;
  padding-bottom: 16px;
}

.section-header__desc {
  margin-top: 20px;
  font-size: 0.9375rem;
  line-height: 1.7;
  color: var(--color-muted);
  max-width: 560px;
  margin-inline: auto;
}

.section-header__title::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 36px;
  height: 1px;
  background: var(--color-border);
}

/* ════════════════════════════════════════════════════════════
   SECCIÓN 1: HERO
════════════════════════════════════════════════════════════ */
.hero {
  position: relative;
  width: 100%;
  height: 100svh;
  min-height: 560px;
  overflow: hidden;
  background-color: #1a1a18;

  /* Imagen de fondo — reemplazar con imagen real */
  background-image: url('https://placehold.co/1920x1080/1a1a18/c7dbd6?text=');
  background-size: cover;
  background-position: center;
}

.hero__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to top,
    rgba(10, 10, 10, 0.72) 0%,
    rgba(10, 10, 10, 0.28) 55%,
    rgba(10, 10, 10, 0.10) 100%
  );
  z-index: 1;
}

.hero__content {
  position: relative;
  z-index: 2;
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 0 var(--container-pad) clamp(48px, 8vh, 100px);
  max-width: calc(var(--container-max) + var(--container-pad) * 2);
  margin-inline: auto;
}

.hero__eyebrow {
  display: block;
  font-size: 0.625rem;
  font-weight: 700;
  letter-spacing: 0.35em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.7);
  margin-bottom: 16px;
}

.hero__title {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 600;
  color: var(--color-white);
  line-height: 0.88;
  font-size: clamp(72px, 11vw, 148px);
  margin-bottom: 24px;
  letter-spacing: -0.01em;
  text-shadow: 0 2px 32px rgba(0,0,0,0.22), 0 0 80px rgba(0,0,0,0.1);
}

.hero__title em {
  font-style: italic;
}

.hero__subtitle {
  font-size: clamp(0.9375rem, 1.5vw, 1.0625rem);
  font-weight: 300;
  font-style: italic;
  color: rgba(255, 255, 255, 0.85);
  line-height: 1.55;
  margin-bottom: 40px;
  max-width: 400px;
}

.hero__actions {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
}

.btn--ghost {
  display: inline-block;
  font-family: var(--font-body);
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  padding: 14px 28px;
  border: 1px solid rgba(255,255,255,0.55);
  color: var(--color-white);
  background: transparent;
  transition: border-color 0.28s ease, background 0.28s ease;
}

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

/* ════════════════════════════════════════════════════════════
   SECCIÓN 2: TICKER
════════════════════════════════════════════════════════════ */
.ticker {
  background: var(--color-black);
  color: var(--color-white);
  padding: 10px 0;
  overflow: hidden;
  user-select: none;
}

@keyframes ticker-scroll {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

.ticker__track {
  display: inline-flex;
  align-items: center;
  white-space: nowrap;
  animation: ticker-scroll 30s linear infinite;
  gap: 0;
}

.ticker:hover .ticker__track {
  animation-play-state: paused;
}

.ticker__item {
  font-size: 0.625rem;     /* 10px */
  font-weight: 700;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  padding-inline: 20px;
}

.ticker__sep {
  font-size: 0.5rem;
  color: var(--color-accent);
  padding-inline: 8px;
  flex-shrink: 0;
}

/* ════════════════════════════════════════════════════════════
   SECCIÓN 3: PRODUCTOS DESTACADOS
════════════════════════════════════════════════════════════ */
.productos {
  padding-block: clamp(60px, 8vw, 100px);
  background: var(--color-bg);
}

/* Grid: 4 columnas en escritorio */
.productos__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px 16px;
}

/* CTA inferior */
.productos__cta {
  display: flex;
  justify-content: center;
  gap: 14px;
  margin-top: 56px;
  flex-wrap: wrap;
}

/* ── Tarjeta de producto ──────────────────────────────────── */
.product-card {
  display: flex;
  flex-direction: column;
  cursor: pointer;
  transition: opacity 0.32s ease;
}

.product-card:hover {
  opacity: 0.92;
}

.product-card__image-wrap {
  position: relative;
  overflow: hidden;
  aspect-ratio: 5 / 4;
  background: var(--color-surface);
  border-radius: 0;
  margin-bottom: 14px;
}

.product-card__image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  will-change: transform;
}

/* Zoom hover */
.product-card:hover .product-card__image {
  transform: scale(1.06);
}

/* Badge "Nuevo" */
.product-card__badge {
  position: absolute;
  top: 12px;
  left: 12px;
  background: var(--color-black);
  color: var(--color-white);
  font-size: 0.5625rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  padding: 4px 10px;
  border-radius: 2px;
  pointer-events: none;
}

.product-card__info {
  padding-inline: 2px;
}

.product-card__name {
  font-size: 0.75rem;     /* 12px */
  font-weight: 400;
  color: var(--color-text);
  line-height: 1.4;
  margin-bottom: 3px;
}

.product-card__variant {
  display: block;
  font-size: 0.6875rem;   /* 11px */
  color: var(--color-muted);
  margin-bottom: 8px;
}

.product-card__price {
  font-family: var(--font-display);
  font-size: 1rem;
  font-weight: 600;
  color: var(--color-black);
  letter-spacing: 0.02em;
}

/* ════════════════════════════════════════════════════════════
   RESPONSIVE
════════════════════════════════════════════════════════════ */

/* Tablet: 2 columnas */
@media (max-width: 1024px) {
  .productos__grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 24px 16px;
  }
}

/* Móvil grande */
@media (max-width: 600px) {
  .hero__title {
    font-size: clamp(56px, 14vw, 80px);
  }

  .hero__subtitle {
    display: none;
  }

  .productos__grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 16px 12px;
  }

  .product-card__name {
    font-size: 0.6875rem;
  }

  .productos__cta {
    flex-direction: column;
    align-items: center;
  }
}

/* ════════════════════════════════════════════════════════════
   FOOTER
════════════════════════════════════════════════════════════ */
.footer {
  background: #111110;
  color: rgba(255, 255, 255, 0.72);
}

.footer__inner {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1.3fr 1.2fr;
  gap: 48px 40px;
  padding-block: clamp(56px, 7vw, 88px);
}

/* ── Columna 1: Marca ─────────────────────────────────────── */
.footer__logo {
  display: inline-block;
  font-family: 'Parisienne', cursive;
  font-size: 2.4rem;
  color: var(--color-white);
  line-height: 1.15;
  white-space: nowrap;
  margin-bottom: 20px;
  transition: opacity var(--transition);
}

.footer__logo em {
  font-style: normal;
  font-weight: normal;
  color: inherit;
}

.footer__logo:hover {
  opacity: 0.75;
}

.footer__mission {
  font-size: 0.8125rem;
  line-height: 1.7;
  color: rgba(255, 255, 255, 0.55);
  margin-bottom: 24px;
  max-width: 240px;
}

.footer__social {
  display: flex;
  gap: 12px;
}

.footer__social-link {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: var(--radius-sm);
  color: rgba(255, 255, 255, 0.6);
  transition: background var(--transition), color var(--transition),
              border-color var(--transition);
}

.footer__social-link:hover {
  background: var(--color-accent);
  border-color: var(--color-accent);
  color: var(--color-black);
}

/* ── Columna 2: Navegación ────────────────────────────────── */
.footer__heading {
  font-size: 0.625rem;
  font-weight: 700;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--color-white);
  margin-bottom: 18px;
}

.footer__list {
  list-style: none;
}

.footer__link {
  display: inline-block;
  font-size: 0.8125rem;
  color: rgba(255, 255, 255, 0.55);
  padding-block: 5px;
  position: relative;
  transition: color var(--transition);
}

.footer__link::after {
  content: '';
  position: absolute;
  bottom: 3px;
  left: 0;
  width: 0;
  height: 1px;
  background: var(--color-accent);
  transition: width var(--transition);
}

.footer__link:hover {
  color: var(--color-white);
}

.footer__link:hover::after {
  width: 100%;
}

/* ── Columna 3: Tiendas ───────────────────────────────────── */
.footer__store-name {
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-white);
  margin-bottom: 6px;
}

.footer__address {
  font-style: normal;
  font-size: 0.8125rem;
  color: rgba(255, 255, 255, 0.55);
  line-height: 1.6;
  margin-bottom: 12px;
}

.footer__store-details {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.footer__store-details li {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  font-size: 0.75rem;
  color: rgba(255, 255, 255, 0.5);
  line-height: 1.5;
}

.footer__store-details svg {
  flex-shrink: 0;
  margin-top: 2px;
  color: var(--color-accent);
}

.footer__store-details a {
  color: inherit;
  transition: color var(--transition);
}

.footer__store-details a:hover {
  color: var(--color-accent);
}

/* ── Columna 4: Newsletter ────────────────────────────────── */
.footer__newsletter-text {
  font-size: 0.8125rem;
  color: rgba(255, 255, 255, 0.55);
  line-height: 1.65;
  margin-bottom: 24px;
}

.footer__form-group {
  display: flex;
  align-items: center;
  border-bottom: 1px solid rgba(255, 255, 255, 0.3);
  padding-bottom: 10px;
  transition: border-color var(--transition);
}

.footer__form-group:focus-within {
  border-bottom-color: var(--color-white);
}

.footer__input {
  flex: 1;
  min-width: 0;
  background: transparent;
  border: none;
  outline: none;
  padding: 0;
  font-family: var(--font-body);
  font-size: 0.8125rem;
  color: var(--color-white);
  letter-spacing: 0.03em;
}

.footer__input::placeholder {
  color: rgba(255, 255, 255, 0.35);
}

.footer__submit {
  display: flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  border: none;
  cursor: pointer;
  color: rgba(255, 255, 255, 0.6);
  font-size: 1.1rem;
  padding: 0 0 0 12px;
  transition: color var(--transition);
  flex-shrink: 0;
}

.footer__submit:hover {
  color: var(--color-white);
}

.footer__submit svg {
  pointer-events: none;
}

.footer__newsletter-legal {
  font-size: 0.7rem;
  color: rgba(255, 255, 255, 0.3);
  margin-top: 14px;
  line-height: 1.5;
}

.footer__newsletter-legal a {
  color: rgba(255, 255, 255, 0.45);
  text-decoration: underline;
}

.footer__form-msg {
  font-size: 0.75rem;
  margin-top: 8px;
  min-height: 18px;
  transition: color var(--transition);
}

.footer__form-msg--ok  { color: #6ee7b7; }
.footer__form-msg--err { color: #fca5a5; }

/* Métodos de pago */
.footer__payments {
  margin-top: 28px;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  padding-top: 20px;
}

.footer__payments-label {
  font-size: 0.625rem;
  font-weight: 700;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.35);
  margin-bottom: 12px;
}

.footer__payments-icons {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.pay-badge {
  display: inline-block;
  background: rgba(255, 255, 255, 0.07);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 3px;
  padding: 4px 10px;
  font-size: 0.5625rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.5);
}

/* ── Barra inferior ───────────────────────────────────────── */
.footer__bottom {
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  padding-block: 20px;
}

.footer__bottom-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}

.footer__copy {
  font-size: 0.75rem;
  color: rgba(255, 255, 255, 0.3);
}

.footer__legal {
  display: flex;
  gap: 24px;
}

.footer__legal-link {
  font-size: 0.6875rem;
  color: rgba(255, 255, 255, 0.3);
  transition: color var(--transition);
}

.footer__legal-link:hover {
  color: rgba(255, 255, 255, 0.7);
}

/* ════════════════════════════════════════════════════════════
   BOTÓN FLOTANTE WHATSAPP
════════════════════════════════════════════════════════════ */
.whatsapp-float {
  position: fixed;
  bottom: 28px;
  right: 28px;
  z-index: 9000;

  display: flex;
  align-items: center;
  gap: 10px;

  background: #25d366;
  color: #ffffff;
  border-radius: 50px;
  padding: 13px 20px 13px 16px;

  box-shadow: 0 4px 20px rgba(37, 211, 102, 0.4),
              0 2px 8px  rgba(0, 0, 0, 0.15);

  transition: transform var(--transition), box-shadow var(--transition),
              padding var(--transition);
  text-decoration: none;
}

.whatsapp-float:hover {
  transform: translateY(-3px) scale(1.03);
  box-shadow: 0 8px 28px rgba(37, 211, 102, 0.5),
              0 4px 12px rgba(0, 0, 0, 0.15);
}

.whatsapp-float__tooltip {
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  white-space: nowrap;
  max-width: 0;
  overflow: hidden;
  opacity: 0;
  transition: max-width 0.35s ease, opacity 0.25s ease;
}

.whatsapp-float:hover .whatsapp-float__tooltip {
  max-width: 120px;
  opacity: 1;
}

/* ── Footer responsive ────────────────────────────────────── */
@media (max-width: 1024px) {
  .footer__inner {
    grid-template-columns: 1fr 1fr;
    gap: 40px 32px;
  }
}

@media (max-width: 600px) {
  .footer__inner {
    grid-template-columns: 1fr;
    gap: 36px;
  }

  .footer__bottom-inner {
    flex-direction: column;
    align-items: flex-start;
    gap: 10px;
  }

  .whatsapp-float {
    bottom: 20px;
    right: 20px;
    border-radius: 50%;
    padding: 14px;
  }

  .whatsapp-float__tooltip {
    display: none;
  }
}


/* ════════════════════════════════════════════════════════════
   HEADER
════════════════════════════════════════════════════════════ */

/* ── Base ─────────────────────────────────────────────────── */
.header {
  position: fixed;
  inset-block-start: 0;
  inset-inline: 0;
  z-index: 900;
  height: 72px;
  display: flex;
  align-items: center;
  /* Transparente sobre el hero */
  background: transparent;
  color: var(--color-white);
  transition:
    background var(--transition),
    box-shadow var(--transition),
    color var(--transition);
}

/* ── Scrolled: fondo blanco + sombra ─────────────────────── */
.header.is-scrolled {
  background: rgba(250, 250, 248, 0.96);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  box-shadow: 0 1px 0 rgba(0,0,0,0.07);
  color: var(--color-text);
}

/* ── Inner layout ─────────────────────────────────────────── */
.header__inner {
  width: 100%;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
  align-items: center;
  gap: 24px;
}

/* ── Logo ─────────────────────────────────────────────────── */
.header__logo {
  grid-column: 2;
  justify-self: center;
  padding-inline: 72px;
  font-family: 'Parisienne', cursive;
  font-size: clamp(22px, 2vw, 26px);
  color: inherit;
  white-space: nowrap;
  transition: opacity var(--transition);
}
.header__logo em {
  font-style: normal;
  font-weight: normal;
}
.header__logo:hover {
  opacity: 0.75;
}

/* ── Nav principal (desktop) ──────────────────────────────── */
.header__nav-main {
  grid-column: 1;
}

.header__nav-main .header__nav-list {
  justify-content: flex-end;
}

.header__nav-list {
  list-style: none;
  display: flex;
  align-items: center;
  gap: 4px;
}

/* ── Nav derecha + wrapper ─────────────────────────────────── */
.header__right {
  grid-column: 3;
  display: flex;
  align-items: center;
  gap: 4px;
}

.header__nav-right {
  display: flex;
  align-items: center;
}

.nav-link {
  display: flex;
  align-items: center;
  gap: 5px;
  background: none;
  border: none;
  cursor: pointer;
  font-family: var(--font-body);
  font-size: 0.6875rem;       /* 11px */
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: inherit;
  padding: 6px 10px;
  border-radius: var(--radius-sm);
  position: relative;
  transition: opacity var(--transition), background var(--transition);
  white-space: nowrap;
}
.nav-link::after {
  content: '';
  position: absolute;
  bottom: 3px;
  left: 10px;
  right: 10px;
  height: 1px;
  background: currentColor;
  transform: scaleX(0);
  transform-origin: center;
  transition: transform 0.28s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.nav-link:hover::after,
.nav-link--active::after {
  transform: scaleX(1);
}
.nav-link:hover,
.nav-link:focus-visible {
  opacity: 0.75;
  outline: none;
}
.header.is-scrolled .nav-link:hover {
  opacity: 1;
  background: var(--color-surface);
}

/* Caret */
.nav-caret {
  display: inline-block;
  width: 0;
  height: 0;
  border-left: 3.5px solid transparent;
  border-right: 3.5px solid transparent;
  border-top: 4px solid currentColor;
  transition: transform 0.22s ease;
}
.nav-item.is-open > .nav-link .nav-caret {
  transform: rotate(180deg);
}

/* ── Dropdown panels ──────────────────────────────────────── */
.nav-item {
  position: relative;
}

.dropdown {
  position: absolute;
  inset-block-start: calc(100% + 12px);
  inset-inline-start: 50%;
  transform: translateX(-50%) translateY(-6px);
  min-width: 200px;
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-lg);
  padding: 12px 0;
  opacity: 0;
  pointer-events: none;
  visibility: hidden;
  transition:
    opacity 0.22s ease,
    transform 0.22s ease,
    visibility 0.22s ease;
  color: var(--color-text);
}

.dropdown.is-open {
  opacity: 1;
  pointer-events: auto;
  visibility: visible;
  transform: translateX(-50%) translateY(0);
}

/* Wide dropdown para Marcas */
.dropdown--wide {
  min-width: 560px;
  padding: 20px 0 0;
  inset-inline-start: 0;
  transform: translateX(0) translateY(-6px);
}
.dropdown--wide.is-open {
  transform: translateX(0) translateY(0);
}

/* Grid de marcas */
.dropdown__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 2px 0;
  padding: 0 20px 16px;
}

/* Enlace genérico de dropdown */
.dropdown__link {
  display: block;
  padding: 9px 20px;
  font-family: var(--font-body);
  font-size: 0.8125rem;       /* 13px */
  font-weight: 400;
  color: var(--color-text);
  letter-spacing: 0.02em;
  transition: background var(--transition), color var(--transition);
  border-radius: 0;
}
.dropdown__link:hover {
  background: var(--color-surface);
  color: var(--color-black);
}

/* En el grid de marcas el padding es menor */
.dropdown__grid .dropdown__link {
  padding: 7px 8px;
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

/* Barra inferior del wide dropdown */
.dropdown__footer-bar {
  border-top: 1px solid var(--color-border);
  padding: 12px 20px;
  display: flex;
  justify-content: flex-end;
}

.dropdown__all {
  font-family: var(--font-body);
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--color-muted);
  transition: color var(--transition);
}
.dropdown__all:hover {
  color: var(--color-black);
}

/* ── Selector de idioma ───────────────────────────────────── */
.nav-lang-toggle {
  margin-right: auto;
}
.lang-flag-btn {
  background: none;
  border: none;
  cursor: pointer;
  font-size: 17px;
  line-height: 1;
  padding: 5px 6px;
  border-radius: var(--radius-sm);
  opacity: 0.7;
  transition: opacity var(--transition);
  display: flex;
  align-items: center;
}
.lang-flag-btn:hover {
  opacity: 1;
}
/* Ocultar la barra flotante de Google Translate */
.goog-te-banner-frame,
iframe.skiptranslate { display: none !important; }
.goog-te-gadget, #goog-gt-tt { display: none !important; }
body, body.translated-ltr, body.translated-rtl { top: 0 !important; margin-top: 0 !important; }

/* ── Acciones derecha ─────────────────────────────────────── */
.header__actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 4px;
}

.header__cta-link {
  font-family: var(--font-body);
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: inherit;
  padding: 7px 14px;
  border: 1px solid currentColor;
  border-radius: var(--radius-sm);
  transition: background var(--transition), color var(--transition), border-color var(--transition);
  white-space: nowrap;
  margin-inline-end: 6px;
}
.header__cta-link:hover {
  background: var(--color-white);
  color: var(--color-black);
  border-color: var(--color-white);
}
.header.is-scrolled .header__cta-link:hover {
  background: var(--color-black);
  color: var(--color-white);
  border-color: var(--color-black);
}

.header__icon-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  background: none;
  border: none;
  cursor: pointer;
  color: inherit;
  padding: 8px;
  border-radius: var(--radius-sm);
  transition: opacity var(--transition), background var(--transition);
}
.header__icon-btn:hover {
  opacity: 0.65;
}
.header.is-scrolled .header__icon-btn:hover {
  opacity: 1;
  background: var(--color-surface);
}

/* Carrito con badge */
.header__cart-btn {
  position: relative;
}
.header__cart-count {
  position: absolute;
  inset-block-start: 2px;
  inset-inline-end: 2px;
  min-width: 14px;
  height: 14px;
  background: var(--color-accent-dk);
  color: var(--color-white);
  font-family: var(--font-body);
  font-size: 0.5rem;
  font-weight: 700;
  line-height: 14px;
  text-align: center;
  border-radius: 50%;
  padding-inline: 2px;
}

/* ── Hamburger ────────────────────────────────────────────── */
.header__hamburger {
  display: none;     /* visible solo en móvil */
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 5px;
  background: none;
  border: none;
  cursor: pointer;
  padding: 8px;
  color: inherit;
  width: 36px;
  height: 36px;
}

.header__hamburger span {
  display: block;
  width: 20px;
  height: 1.5px;
  background: currentColor;
  border-radius: 2px;
  transform-origin: center;
  transition: transform 0.28s ease, opacity 0.2s ease, width 0.28s ease;
}

/* Animación → X */
.header__hamburger.is-active span:nth-child(1) {
  transform: translateY(6.5px) rotate(45deg);
}
.header__hamburger.is-active span:nth-child(2) {
  opacity: 0;
  width: 0;
}
.header__hamburger.is-active span:nth-child(3) {
  transform: translateY(-6.5px) rotate(-45deg);
}

/* ════════════════════════════════════════════════════════════
   MENÚ MÓVIL
════════════════════════════════════════════════════════════ */

.mobile-menu {
  position: fixed;
  inset-block: 0;
  inset-inline-end: 0;
  width: min(360px, 100vw);
  background: var(--color-white);
  z-index: 1000;
  display: flex;
  flex-direction: column;
  transform: translateX(100%);
  transition: transform 0.38s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  overflow: hidden;
}

.mobile-menu.is-open {
  transform: translateX(0);
}

/* Overlay */
.mobile-overlay {
  position: fixed;
  inset: 0;
  background: rgba(13,13,13,0.45);
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
  z-index: 999;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.35s ease;
}
.mobile-overlay.is-visible {
  opacity: 1;
  pointer-events: auto;
}

/* Header del panel */
.mobile-menu__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 20px 24px;
  border-bottom: 1px solid var(--color-border);
  flex-shrink: 0;
}

.mobile-menu__logo {
  font-family: 'Parisienne', cursive;
  font-size: 28px;
  color: var(--color-text);
}
.mobile-menu__logo em {
  font-style: normal;
  font-weight: normal;
}

.mobile-menu__close {
  display: flex;
  align-items: center;
  justify-content: center;
  background: none;
  border: none;
  cursor: pointer;
  color: var(--color-text);
  padding: 6px;
  border-radius: var(--radius-sm);
  transition: opacity var(--transition);
}
.mobile-menu__close:hover {
  opacity: 0.6;
}

/* Body scrollable */
.mobile-menu__body {
  flex: 1;
  overflow-y: auto;
  overscroll-behavior: contain;
  padding-block: 8px;
}

.mobile-menu__list {
  list-style: none;
}

/* Item */
.mobile-item {
  border-bottom: 1px solid var(--color-border);
}
.mobile-item:last-child {
  border-bottom: none;
}

/* Botón/link de primer nivel */
.mobile-link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  background: none;
  border: none;
  cursor: pointer;
  font-family: var(--font-body);
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--color-text);
  padding: 16px 24px;
  text-align: left;
  transition: background var(--transition);
}
.mobile-link:hover {
  background: var(--color-surface);
}
.mobile-link--plain {
  justify-content: flex-start;
}

/* Flecha giratoria */
.mobile-arrow {
  font-size: 1.1rem;
  line-height: 1;
  display: inline-block;
  transition: transform 0.25s ease;
  color: var(--color-muted);
}
.mobile-item.is-expanded > .mobile-link .mobile-arrow {
  transform: rotate(90deg);
}

/* Submenú acordeón */
.mobile-submenu {
  list-style: none;
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.32s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  background: var(--color-surface);
}
.mobile-item.is-expanded > .mobile-submenu {
  max-height: 600px;
}

.mobile-sublink {
  display: block;
  padding: 11px 24px 11px 32px;
  font-family: var(--font-body);
  font-size: 0.8125rem;
  font-weight: 400;
  color: var(--color-text);
  letter-spacing: 0.02em;
  transition: color var(--transition), padding-inline-start var(--transition);
}
.mobile-sublink:hover {
  color: var(--color-black);
  padding-inline-start: 36px;
}
.mobile-sublink--all {
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-muted);
  padding-block: 14px;
  border-top: 1px solid var(--color-border);
  margin-top: 4px;
}
.mobile-sublink--all:hover {
  color: var(--color-black);
}

/* Footer del panel móvil */
.mobile-menu__footer {
  padding: 24px;
  border-top: 1px solid var(--color-border);
  display: flex;
  flex-direction: column;
  gap: 16px;
  flex-shrink: 0;
}

.mobile-menu__cta {
  display: block;
  text-align: center;
  font-family: var(--font-body);
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--color-white);
  background: var(--color-black);
  padding: 14px 20px;
  border-radius: var(--radius-sm);
  transition: background var(--transition);
}
.mobile-menu__cta:hover {
  background: #333;
}

.mobile-menu__social {
  display: flex;
  gap: 20px;
  align-items: center;
}

.mobile-menu__social a {
  font-family: var(--font-body);
  font-size: 0.625rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--color-muted);
  transition: color var(--transition);
}
.mobile-menu__social a:hover {
  color: var(--color-black);
}

/* ════════════════════════════════════════════════════════════
   HEADER RESPONSIVE
════════════════════════════════════════════════════════════ */

/* Tablet: ocultar parte del nav */
@media (max-width: 1024px) {
  .header__nav-main,
  .header__nav-right {
    display: none;
  }

  .header__inner {
    grid-template-columns: auto 1fr auto;
  }

  .header__hamburger {
    display: flex;
  }

  .header__logo {
    grid-column: 2;
    justify-self: center;
  }

  .header__right {
    grid-column: 3;
  }
}

/* Móvil */
@media (max-width: 600px) {
  .header {
    height: 60px;
  }

  .header__logo {
    font-size: 24px;
  }

  .header__cta-link {
    display: none;
  }

  .header__icon-btn:not(.header__cart-btn) {
    display: none;
  }
}


/* ════════════════════════════════════════════════════════════
   SECCIÓN: MARCAS
════════════════════════════════════════════════════════════ */
.marcas {
  padding-block: clamp(72px, 8vw, 112px);
  background: var(--color-surface);
}

.marcas__grid {
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 8px 6px;
  margin-bottom: 48px;
}

.marcas__item {
  display: inline-block;
  font-family: var(--font-body);
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-muted);
  padding: 9px 18px;
  border: 1px solid var(--color-border);
  border-radius: 100px;
  background: var(--color-white);
  transition:
    color var(--transition),
    border-color var(--transition),
    background var(--transition),
    transform var(--transition);
}

.marcas__item:hover {
  color: var(--color-black);
  border-color: var(--color-black);
  background: var(--color-black);
  color: var(--color-white);
  transform: translateY(-2px);
}

.marcas__cta {
  text-align: center;
}


/* ════════════════════════════════════════════════════════════
   SECCIÓN: EDITORIAL / MANIFESTO
════════════════════════════════════════════════════════════ */
.editorial {
  padding-block: clamp(72px, 8vw, 120px);
  overflow: hidden;
}

.editorial__inner {
  max-width: var(--container-max);
  margin-inline: auto;
  padding-inline: var(--container-pad);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(48px, 6vw, 96px);
  align-items: center;
}

/* Columna imagen */
.editorial__image-col {
  position: relative;
}

.editorial__image-wrap {
  position: relative;
  overflow: hidden;
  border-radius: var(--radius-lg);
}

.editorial__image {
  width: 100%;
  aspect-ratio: 4 / 5;
  object-fit: cover;
  object-position: center center;
  display: block;
  transition: transform 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.editorial__image-wrap:hover .editorial__image {
  transform: scale(1.04);
}

.editorial__image-caption {
  position: absolute;
  inset-block-end: 20px;
  inset-inline-start: 20px;
  font-family: var(--font-body);
  font-size: 0.625rem;
  font-weight: 700;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.8);
  background: rgba(13,13,13,0.45);
  backdrop-filter: blur(6px);
  padding: 6px 12px;
  border-radius: 100px;
}

/* Columna texto */
.editorial__text-col {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.editorial__label {
  display: inline-block;
  font-family: var(--font-body);
  font-size: 0.625rem;
  font-weight: 700;
  letter-spacing: 0.35em;
  text-transform: uppercase;
  color: var(--color-muted);
  margin-bottom: 20px;
}

.editorial__title {
  font-family: var(--font-display);
  font-size: clamp(2.5rem, 4vw, 3.75rem);
  font-weight: 400;
  line-height: 1.05;
  color: var(--color-black);
  margin-bottom: 36px;
}

.editorial__title em {
  font-style: italic;
  font-weight: 600;
  color: var(--color-accent-dk);
}

.editorial__body {
  display: flex;
  flex-direction: column;
  gap: 18px;
  margin-bottom: 44px;
}

.editorial__body p {
  font-size: 0.9375rem;
  line-height: 1.75;
  color: var(--color-muted);
}

.editorial__actions {
  display: flex;
  align-items: center;
  gap: 32px;
  flex-wrap: wrap;
}

.editorial__link {
  font-family: var(--font-body);
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--color-muted);
  transition: color var(--transition);
}
.editorial__link:hover {
  color: var(--color-black);
}

/* Responsivo editorial */
@media (max-width: 860px) {
  .editorial__inner {
    grid-template-columns: 1fr;
  }
  .editorial__image-col {
    order: -1;
  }
  .editorial__image {
    aspect-ratio: 4 / 3;
  }
}


/* ════════════════════════════════════════════════════════════
   SECCIÓN: SERVICIOS (teaser)
════════════════════════════════════════════════════════════ */
.servicios-teaser {
  padding-block: clamp(72px, 8vw, 112px);
  background: var(--color-black);
  color: var(--color-white);
}

.servicios-teaser .section-header__label {
  color: var(--color-accent);
}

.servicios-teaser .section-header__title {
  color: var(--color-white);
}

.servicios-teaser .section-header__title::after {
  background: rgba(255,255,255,0.15);
}

.servicios-teaser__grid {
  list-style: none;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 2px;
  margin-bottom: 56px;
}

.servicio-card {
  padding: clamp(28px, 3vw, 44px) clamp(24px, 2.5vw, 36px);
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.07);
  display: flex;
  flex-direction: column;
  gap: 16px;
  transition: background var(--transition);
}

.servicio-card:hover {
  background: rgba(199,219,214,0.08);
}

.servicio-card__icon {
  color: var(--color-accent);
  flex-shrink: 0;
}

.servicio-card__title {
  font-family: var(--font-display);
  font-size: 1.25rem;
  font-weight: 400;
  color: var(--color-white);
  line-height: 1.2;
}

.servicio-card__desc {
  font-size: 0.875rem;
  line-height: 1.65;
  color: rgba(255,255,255,0.55);
  flex: 1;
}

.servicio-card__link {
  font-family: var(--font-body);
  font-size: 0.625rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--color-accent);
  transition: color var(--transition);
  margin-top: auto;
}

.servicio-card__link:hover {
  color: var(--color-white);
}

.servicios-teaser__cta {
  text-align: center;
}

.servicios-teaser .btn--outline {
  border-color: rgba(255,255,255,0.35);
  color: var(--color-white);
}

.servicios-teaser .btn--outline:hover {
  background: var(--color-white);
  color: var(--color-black);
  border-color: var(--color-white);
}

/* Responsivo servicios */
@media (max-width: 1024px) {
  .servicios-teaser__grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 540px) {
  .servicios-teaser__grid {
    grid-template-columns: 1fr;
  }
  .marcas__item {
    font-size: 0.625rem;
    padding: 7px 14px;
  }
}


/* ════════════════════════════════════════════════════════════
   PÁGINA: CATÁLOGO
════════════════════════════════════════════════════════════ */

/* Header forzado a estado oscuro en páginas interiores */
.interior-page .header {
  background: rgba(250, 250, 248, 0.97);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  color: var(--color-text);
  box-shadow: 0 1px 0 rgba(0,0,0,0.07);
}

/* Cabecera de página (page-hero) */
.page-hero {
  padding-block-start: calc(72px + 56px);
  padding-block-end: 48px;
  background: var(--color-bg);
  border-bottom: 1px solid var(--color-border);
}

.breadcrumb {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 20px;
}

.breadcrumb__link {
  font-family: var(--font-body);
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-muted);
  transition: color var(--transition);
}
.breadcrumb__link:hover { color: var(--color-black); }

.breadcrumb__sep {
  color: var(--color-border);
  font-size: 0.8rem;
}

.breadcrumb__current {
  font-family: var(--font-body);
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-text);
}

.page-hero__title {
  font-family: var(--font-display);
  font-size: clamp(2.25rem, 4vw, 3.5rem);
  font-weight: 400;
  color: var(--color-black);
  margin-bottom: 10px;
}

.page-hero__desc {
  font-size: 0.9375rem;
  color: var(--color-muted);
}

/* Barra de filtros */
.filter-bar {
  position: sticky;
  top: 72px;
  z-index: 800;
  background: rgba(250,250,248,0.97);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border-bottom: 1px solid var(--color-border);
  padding-block: 14px;
}

.filter-bar__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}

/* Pestañas de tipo */
.filter-tabs {
  display: flex;
  gap: 4px;
}

.filter-tab {
  background: none;
  border: 1px solid transparent;
  cursor: pointer;
  font-family: var(--font-body);
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--color-muted);
  padding: 7px 16px;
  border-radius: 100px;
  transition: color var(--transition), border-color var(--transition), background var(--transition);
}

.filter-tab:hover {
  color: var(--color-black);
  border-color: var(--color-border);
}

.filter-tab.is-active {
  color: var(--color-black);
  border-color: var(--color-black);
  background: var(--color-black);
  color: var(--color-white);
}

/* Selects de filtro */
.filter-bar__right {
  display: flex;
  gap: 10px;
  align-items: center;
}

.filter-select-wrap {
  position: relative;
}

.filter-select {
  appearance: none;
  -webkit-appearance: none;
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  font-family: var(--font-body);
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-text);
  padding: 8px 32px 8px 14px;
  cursor: pointer;
  outline: none;
  transition: border-color var(--transition);
}

.filter-select:focus,
.filter-select:hover {
  border-color: var(--color-black);
}

.filter-select-arrow {
  position: absolute;
  inset-inline-end: 12px;
  inset-block-start: 50%;
  transform: translateY(-50%);
  pointer-events: none;
  width: 0;
  height: 0;
  border-left: 3.5px solid transparent;
  border-right: 3.5px solid transparent;
  border-top: 4px solid var(--color-muted);
}

/* Meta / contador */
.catalog-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding-block: 20px;
  flex-wrap: wrap;
}

.catalog-count {
  font-size: 0.8125rem;
  color: var(--color-muted);
}

.catalog-count strong {
  color: var(--color-text);
}

/* Filtros activos */
.active-filters {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.active-filter-tag {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-body);
  font-size: 0.625rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-text);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: 100px;
  padding: 5px 12px;
}

.active-filter-tag__remove {
  background: none;
  border: none;
  cursor: pointer;
  color: var(--color-muted);
  padding: 0;
  line-height: 1;
  font-size: 1rem;
  transition: color var(--transition);
}
.active-filter-tag__remove:hover {
  color: var(--color-black);
}

/* Grid del catálogo */
.catalog-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(20px, 2.5vw, 32px);
  padding-bottom: 64px;
}

/* Card en catálogo: nombre de marca visible */
.product-card__link {
  display: block;
  color: inherit;
}

.product-card__brand {
  display: block;
  font-family: var(--font-body);
  font-size: 0.5625rem;
  font-weight: 700;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--color-muted);
  margin-bottom: 4px;
}

/* Botón wishlist en imagen */
.product-card__wishlist {
  position: absolute;
  inset-block-start: 12px;
  inset-inline-end: 12px;
  background: rgba(255,255,255,0.9);
  border: none;
  border-radius: 50%;
  width: 34px;
  height: 34px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  color: var(--color-muted);
  opacity: 0;
  transform: translateY(-4px);
  transition: opacity var(--transition), transform var(--transition), color var(--transition);
}
.product-card:hover .product-card__wishlist {
  opacity: 1;
  transform: translateY(0);
}
.product-card__wishlist:hover {
  color: #e03;
}
.product-card__wishlist.is-active {
  color: #e03;
  opacity: 1;
}

/* Card oculta durante filtrado */
.product-card.is-hidden {
  display: none;
}

/* Animación de entrada al filtrar */
.product-card.is-visible {
  animation: fadeInUp 0.28s ease forwards;
}

@keyframes fadeInUp {
  from { opacity: 0; transform: translateY(12px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Estado vacío */
.catalog-empty {
  grid-column: 1 / -1;
  text-align: center;
  padding: 80px 20px;
  color: var(--color-muted);
}
.catalog-empty p {
  margin-block: 16px;
  font-size: 0.9375rem;
}

/* Load more */
.catalog-loadmore {
  text-align: center;
  padding-bottom: 80px;
}

/* Responsivo catálogo */
@media (max-width: 1024px) {
  .catalog-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (max-width: 768px) {
  .catalog-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .filter-bar__inner {
    gap: 10px;
  }
}

@media (max-width: 480px) {
  .catalog-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 14px;
  }
  .filter-tabs {
    width: 100%;
    justify-content: space-between;
  }
  .filter-tab {
    flex: 1;
    text-align: center;
  }
  .filter-bar__right {
    width: 100%;
  }
  .filter-select {
    flex: 1;
    min-width: 0;
  }
}


/* ════════════════════════════════════════════════════════════
   CATÁLOGO: LAYOUT SIDEBAR + GRID
════════════════════════════════════════════════════════════ */

.catalog-layout {
  display: grid;
  grid-template-columns: 240px 1fr;
  gap: clamp(28px, 4vw, 52px);
  padding-block: 40px 80px;
  align-items: start;
}

/* ── Sidebar ── */
.catalog-sidebar {
  position: sticky;
  top: calc(72px + 24px);
}

.sidebar-toggle {
  display: none;
  align-items: center;
  gap: 8px;
  font-family: var(--font-body);
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--color-text);
  background: none;
  border: 1px solid var(--color-border);
  border-radius: 2px;
  padding: 11px 16px;
  cursor: pointer;
  width: 100%;
}

.sidebar-toggle__count {
  background: var(--color-accent);
  color: var(--color-text);
  font-size: 0.5625rem;
  font-weight: 700;
  border-radius: 100px;
  padding: 2px 7px;
  margin-left: 4px;
}

.sidebar-group {
  border-bottom: 1px solid var(--color-border);
  padding-block: 20px;
}

.sidebar-group:first-child {
  padding-block-start: 0;
}

.sidebar-group:last-child {
  border-bottom: none;
}

.sidebar-group__title {
  font-family: var(--font-body);
  font-size: 0.5625rem;
  font-weight: 700;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--color-muted);
  margin-block-end: 14px;
}

.sidebar-radio-list,
.sidebar-check-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
  max-height: 260px;
  overflow-y: auto;
}

.sidebar-radio-list {
  max-height: none;
  overflow: visible;
}

.sidebar-radio,
.sidebar-check {
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: var(--font-body);
  font-size: 0.875rem;
  color: var(--color-text);
  cursor: pointer;
  line-height: 1.3;
}

.sidebar-radio input,
.sidebar-check input {
  accent-color: var(--color-black);
  width: 14px;
  height: 14px;
  flex-shrink: 0;
  cursor: pointer;
}

.sidebar-clear {
  margin-block-start: 20px;
  font-family: var(--font-body);
  font-size: 0.625rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-muted);
  background: none;
  border: none;
  padding: 0;
  cursor: pointer;
  text-decoration: underline;
  text-underline-offset: 3px;
  transition: color var(--transition);
}

.sidebar-clear:hover {
  color: var(--color-text);
}

/* ── Zona de productos ── */
.catalog-main {
  min-width: 0;
}

.catalog-topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-block-end: 18px;
  border-bottom: 1px solid var(--color-border);
  margin-block-end: 28px;
}

/* ── Responsive sidebar ── */
@media (max-width: 900px) {
  .catalog-layout {
    grid-template-columns: 1fr;
    gap: 16px;
  }

  .catalog-sidebar {
    position: static;
  }

  .sidebar-toggle {
    display: flex;
  }

  .sidebar-inner {
    overflow: hidden;
    max-height: 0;
    transition: max-height 0.35s cubic-bezier(0.4, 0, 0.2, 1);
  }

  .sidebar-inner.is-open {
    max-height: 3000px;
  }
}

/* ════════════════════════════════════════════════════════════
   PÁGINA: FICHA DE PRODUCTO
════════════════════════════════════════════════════════════ */

.product-breadcrumb {
  padding-block-start: calc(72px + 28px);
  padding-block-end: 8px;
}

/* Layout 2 columnas */
.product-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(40px, 5vw, 80px);
  padding-block: 40px 80px;
  align-items: start;
}

/* ── Galería ── */
.product-gallery {
  display: grid;
  grid-template-columns: 80px 1fr;
  gap: 12px;
  position: sticky;
  top: calc(72px + 20px);
}

.product-gallery__thumbs {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.product-gallery__thumb {
  display: block;
  width: 100%;
  aspect-ratio: 5 / 4;
  background: var(--color-surface);
  border: 2px solid transparent;
  padding: 0;
  margin: 0;
  cursor: pointer;
  border-radius: var(--radius-sm);
  overflow: hidden;
  transition: all 0.3s ease;
  position: relative;
}
.product-gallery__thumb:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-sm);
}
.product-gallery__thumb.is-active {
  border-color: var(--color-black);
}
.product-gallery__thumb img {
  position: absolute;
  top: 0; left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  opacity: 1 !important; /* Las miniaturas siempre visibles — no tienen loading=lazy */
}

.product-gallery__main {
  position: relative;
  border-radius: var(--radius-md);
  overflow: hidden;
  background: var(--color-surface);
}

.product-gallery__main-img {
  width: 100%;
  aspect-ratio: 5 / 4;
  object-fit: cover;
  display: block;
  transition: transform 0.5s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.product-gallery__main:hover .product-gallery__main-img {
  transform: scale(1.03);
}

.product-gallery__badge {
  position: absolute;
  inset-block-start: 16px;
  inset-inline-start: 16px;
  background: var(--color-black);
  color: var(--color-white);
  font-family: var(--font-body);
  font-size: 0.5625rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  padding: 5px 10px;
  border-radius: 100px;
}

.product-gallery__zoom {
  position: absolute;
  inset-block-end: 14px;
  inset-inline-end: 14px;
  background: var(--color-white);
  border: none;
  border-radius: 50%;
  width: 38px;
  height: 38px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  color: var(--color-black);
  box-shadow: var(--shadow-sm);
  transition: all var(--transition);
  z-index: 10;
}
.product-gallery__zoom:hover { 
  transform: scale(1.1);
  background: var(--color-black);
  color: var(--color-white);
}

/* Lightbox */
.product-lightbox {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.92);
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  visibility: hidden;
  transition: all 0.4s ease;
  backdrop-filter: blur(8px);
}
.product-lightbox.is-active {
  opacity: 1;
  visibility: visible;
}
.product-lightbox__close {
  position: absolute;
  top: 30px;
  right: 30px;
  background: none;
  border: none;
  color: white;
  font-size: 40px;
  cursor: pointer;
  z-index: 10;
}
.product-lightbox__content {
  max-width: 90%;
  max-height: 90vh;
  transform: scale(0.9);
  transition: transform 0.4s ease;
}
.product-lightbox.is-active .product-lightbox__content {
  transform: scale(1);
}
.product-lightbox img {
  max-width: 100%;
  max-height: 85vh;
  object-fit: contain;
  border-radius: 4px;
  box-shadow: 0 20px 50px rgba(0,0,0,0.5);
}

/* ── Info panel ── */
.product-info {
  display: flex;
  flex-direction: column;
  gap: 28px;
}

.product-info__header {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.product-info__brand {
  font-family: var(--font-body);
  font-size: 0.625rem;
  font-weight: 700;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--color-muted);
  transition: color var(--transition);
}
.product-info__brand:hover { color: var(--color-black); }

.product-info__title {
  font-family: var(--font-display);
  font-size: clamp(2rem, 3.5vw, 2.75rem);
  font-weight: 400;
  color: var(--color-black);
  line-height: 1.1;
}

.product-info__subtitle {
  font-size: 0.875rem;
  color: var(--color-muted);
}

.product-info__price {
  font-family: var(--font-display);
  font-size: 2rem;
  font-weight: 600;
  color: var(--color-black);
  line-height: 1;
}
.product-info__price span {
  font-size: 1.25rem;
  font-weight: 400;
}

/* Sección con label */
.product-info__section {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.product-info__label {
  font-family: var(--font-body);
  font-size: 0.75rem;
  font-weight: 400;
  color: var(--color-muted);
}
.product-info__label strong {
  color: var(--color-text);
  font-weight: 700;
}

/* Swatches de color */
.product-colors {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.product-color {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  border: 2px solid transparent;
  outline: 2px solid transparent;
  outline-offset: 3px;
  cursor: pointer;
  transition: outline-color var(--transition);
}
.product-color.is-active {
  outline-color: var(--color-black);
}
.product-color:hover {
  outline-color: var(--color-muted);
}

/* Botones de talla */
.product-sizes {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.product-size {
  background: none;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  font-family: var(--font-body);
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  color: var(--color-muted);
  padding: 8px 18px;
  cursor: pointer;
  transition: border-color var(--transition), color var(--transition), background var(--transition);
}
.product-size:hover {
  border-color: var(--color-text);
  color: var(--color-text);
}
.product-size.is-active {
  border-color: var(--color-black);
  background: var(--color-black);
  color: var(--color-white);
}

.product-info__guide-link {
  font-size: 0.75rem;
  color: var(--color-muted);
  text-decoration: underline;
  text-underline-offset: 3px;
  transition: color var(--transition);
}
.product-info__guide-link:hover { color: var(--color-black); }

/* Acciones add-to-cart */
.product-info__actions {
  display: flex;
  gap: 10px;
  align-items: stretch;
}

.product-add-btn {
  flex: 1;
  text-align: center;
}

.product-info__wishlist-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 50px;
  flex-shrink: 0;
  background: none;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  cursor: pointer;
  color: var(--color-muted);
  transition: color var(--transition), border-color var(--transition);
}
.product-info__wishlist-btn:hover,
.product-info__wishlist-btn[aria-pressed="true"] {
  color: #e03;
  border-color: #e03;
}

/* Banner cita */
.product-info__cita-banner {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  background: var(--color-surface);
  border-radius: var(--radius-md);
  padding: 16px 18px;
  font-size: 0.875rem;
  color: var(--color-muted);
  line-height: 1.5;
}
.product-info__cita-banner svg {
  flex-shrink: 0;
  margin-top: 2px;
  color: var(--color-accent-dk);
}
.product-info__cita-banner a {
  color: var(--color-black);
  font-weight: 700;
  text-decoration: underline;
  text-underline-offset: 3px;
}

/* Nav-link activo (página actual) */
.nav-link--active {
  opacity: 0.6;
  pointer-events: none;
}

/* Page-hero variante oscura */
.page-hero--dark {
  background: var(--color-black);
  color: var(--color-white);
}
.page-hero--dark .breadcrumb__link,
.page-hero--dark .breadcrumb__current { color: rgba(255,255,255,0.6); }
.page-hero--dark .breadcrumb__link:hover { color: var(--color-white); }
.page-hero--dark .breadcrumb__sep { color: rgba(255,255,255,0.3); }
.page-hero--dark .page-hero__title { color: var(--color-white); }
.page-hero--dark .page-hero__title em { font-style: italic; color: var(--color-accent); }
.page-hero--dark .page-hero__desc { color: rgba(255,255,255,0.6); }

.page-hero__title em {
  font-style: italic;
  color: var(--color-accent-dk);
}

/* ── Acordeón de detalles ── */
.product-accordion {
  border-top: 1px solid var(--color-border);
}

.product-accordion__item {
  border-bottom: 1px solid var(--color-border);
}

.product-accordion__trigger {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  background: none;
  border: none;
  cursor: pointer;
  font-family: var(--font-body);
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--color-text);
  padding: 18px 0;
  text-align: left;
  transition: color var(--transition);
}
.product-accordion__trigger:hover {
  color: var(--color-muted);
}

.product-accordion__icon {
  width: 12px;
  height: 12px;
  position: relative;
  flex-shrink: 0;
}
.product-accordion__icon::before,
.product-accordion__icon::after {
  content: '';
  position: absolute;
  background: currentColor;
  transition: opacity 0.22s ease, transform 0.22s ease;
}
.product-accordion__icon::before {
  width: 12px; height: 1px;
  top: 50%; left: 0;
  transform: translateY(-50%);
}
.product-accordion__icon::after {
  width: 1px; height: 12px;
  top: 0; left: 50%;
  transform: translateX(-50%);
}
.product-accordion__item.is-open .product-accordion__icon::after {
  opacity: 0;
  transform: translateX(-50%) rotate(90deg);
}

.product-accordion__body {
  display: none;
  padding-bottom: 20px;
}
.product-accordion__item.is-open .product-accordion__body {
  display: block;
}
.product-accordion__body p {
  font-size: 0.9rem;
  line-height: 1.7;
  color: var(--color-muted);
  margin-bottom: 12px;
}
.product-accordion__body p:last-child { margin-bottom: 0; }

/* Specs table */
.product-specs {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 0;
}
.product-specs li {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  padding: 9px 0;
  border-bottom: 1px solid var(--color-border);
  font-size: 0.8125rem;
}
.product-specs li:last-child { border-bottom: none; }
.product-specs li span:first-child {
  color: var(--color-muted);
  font-weight: 400;
}
.product-specs li span:last-child {
  color: var(--color-text);
  font-weight: 700;
  text-align: right;
}

/* Shipping list */
.product-shipping {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.product-shipping li {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 0.875rem;
  color: var(--color-muted);
}
.product-shipping li svg {
  color: var(--color-accent-dk);
  flex-shrink: 0;
}

/* Productos relacionados */
.related-products {
  padding-block: 80px;
  background: var(--color-surface);
}

.related-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(20px, 2.5vw, 32px);
}

/* Responsivo ficha de producto */
@media (max-width: 900px) {
  .product-layout {
    grid-template-columns: 1fr;
  }
  .product-gallery {
    position: static;
  }
}

@media (max-width: 600px) {
  .product-gallery {
    grid-template-columns: 1fr;
  }
  .product-gallery__thumbs {
    flex-direction: row;
    overflow-x: auto;
  }
  .product-gallery__thumb {
    flex-shrink: 0;
    width: 72px;
  }
  .related-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}


/* ── Descripción poética (visible, sin acordeón) ── */
.product-info__desc {
  font-size: 0.9375rem;
  line-height: 1.8;
  color: var(--color-muted);
  padding-block: 4px;
}
.product-info__desc strong {
  color: var(--color-text);
  font-weight: 400;
}

/* ── Specs inline ── */
.product-info__specs-inline {
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.product-info__specs-heading {
  font-family: var(--font-body);
  font-size: 0.5625rem;
  font-weight: 700;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--color-muted);
}

/* ── CTA wrap: botón grande + wishlist ── */
.product-info__cta-wrap {
  display: flex;
  gap: 10px;
  align-items: stretch;
}

/* Botón principal de cita */
.product-cta-main {
  flex: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  background: var(--color-black);
  color: var(--color-white);
  font-family: var(--font-body);
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  padding: 19px 24px;
  border: 1px solid var(--color-black);
  transition: background var(--transition), color var(--transition),
              transform var(--transition);
  text-align: center;
  cursor: pointer;
}
.product-cta-main:hover {
  background: transparent;
  color: var(--color-black);
  transform: translateY(-1px);
}
.product-cta-main svg {
  flex-shrink: 0;
  opacity: 0.7;
  transition: opacity var(--transition);
}
.product-cta-main:hover svg {
  opacity: 1;
}

/* ════════════════════════════════════════════════════════════
   PÁGINA: SERVICIOS
════════════════════════════════════════════════════════════ */

/* Intro + índice */
.servicios-intro {
  padding-block: 60px;
  border-bottom: 1px solid var(--color-border);
}
.servicios-intro__inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(40px, 5vw, 80px);
  align-items: start;
}
.servicios-intro__text {
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.servicios-intro__text p {
  font-size: 0.9375rem;
  line-height: 1.75;
  color: var(--color-muted);
}

.servicios-nav {
  background: var(--color-surface);
  border-radius: var(--radius-md);
  padding: 28px 32px;
}
.servicios-nav ul {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 0;
}
.servicios-nav li {
  border-bottom: 1px solid var(--color-border);
}
.servicios-nav li:last-child { border-bottom: none; }
.servicios-nav a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 13px 0;
  font-family: var(--font-body);
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-text);
  transition: color var(--transition);
}
.servicios-nav a::after {
  content: '→';
  color: var(--color-muted);
  transition: transform var(--transition), color var(--transition);
}
.servicios-nav a:hover { color: var(--color-black); }
.servicios-nav a:hover::after { transform: translateX(4px); color: var(--color-black); }

/* Secciones de servicio alternadas */
.servicio-section {
  padding-block: clamp(72px, 8vw, 120px);
}
.servicio-section--alt {
  background: var(--color-surface);
}

.servicio-section__inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(48px, 6vw, 100px);
  align-items: center;
}

.servicio-section__img-wrap {
  border-radius: var(--radius-lg);
  overflow: hidden;
}
.servicio-section__img-wrap img {
  width: 100%;
  aspect-ratio: 5 / 4;
  object-fit: cover;
  display: block;
  transition: transform 0.7s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.servicio-section__img-wrap:hover img {
  transform: scale(1.04);
}

.servicio-section__content {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.servicio-section__num {
  font-family: var(--font-display);
  font-size: 4rem;
  font-weight: 300;
  color: var(--color-border);
  line-height: 1;
}

.servicio-section__title {
  font-family: var(--font-display);
  font-size: clamp(2rem, 3.5vw, 2.75rem);
  font-weight: 400;
  color: var(--color-black);
  line-height: 1.1;
}
.servicio-section__title em {
  font-style: italic;
  font-weight: 600;
  color: var(--color-accent-dk);
}

.servicio-section__content p {
  font-size: 0.9375rem;
  line-height: 1.75;
  color: var(--color-muted);
}

.servicio-section__list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding-block: 4px;
}
.servicio-section__list li {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 0.875rem;
  color: var(--color-text);
}
.servicio-section__list li::before {
  content: '';
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: var(--color-accent-dk);
  flex-shrink: 0;
}

/* Servicios extra (tarjetas) */
.servicios-extra {
  padding-block: clamp(72px, 8vw, 112px);
}

.servicios-extra__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2px;
}

.servicio-extra-card {
  padding: clamp(28px, 3vw, 44px);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  display: flex;
  flex-direction: column;
  gap: 16px;
  transition: background var(--transition);
}
.servicio-extra-card:hover {
  background: var(--color-white);
}

.servicio-extra-card__num {
  font-family: var(--font-display);
  font-size: 3rem;
  font-weight: 300;
  color: var(--color-border);
  line-height: 1;
}

.servicio-extra-card__title {
  font-family: var(--font-display);
  font-size: 1.5rem;
  font-weight: 400;
  color: var(--color-black);
}

.servicio-extra-card p {
  font-size: 0.875rem;
  line-height: 1.7;
  color: var(--color-muted);
  flex: 1;
}

.servicio-extra-card__link {
  font-family: var(--font-body);
  font-size: 0.625rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--color-muted);
  margin-top: auto;
  transition: color var(--transition);
}
.servicio-extra-card__link:hover { color: var(--color-black); }

/* CTA final */
.servicios-cta {
  padding-block: clamp(80px, 10vw, 140px);
  background: var(--color-black);
  color: var(--color-white);
}
.servicios-cta__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 24px;
}
.servicios-cta__title {
  font-family: var(--font-display);
  font-size: clamp(2.5rem, 5vw, 4rem);
  font-weight: 400;
  color: var(--color-white);
  line-height: 1.05;
}
.servicios-cta__title em {
  font-style: italic;
  font-weight: 600;
  color: var(--color-accent);
}
.servicios-cta__desc {
  font-size: 0.9375rem;
  color: rgba(255,255,255,0.6);
  max-width: 480px;
}
.servicios-cta__actions {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
  justify-content: center;
}
.servicios-cta .btn--primary {
  background: var(--color-white);
  color: var(--color-black);
  border-color: var(--color-white);
}
.servicios-cta .btn--primary:hover {
  background: transparent;
  color: var(--color-white);
}
.servicios-cta .btn--outline {
  border-color: rgba(255,255,255,0.35);
  color: var(--color-white);
}
.servicios-cta .btn--outline:hover {
  background: var(--color-white);
  color: var(--color-black);
}

/* Responsivo servicios */
@media (max-width: 860px) {
  .servicios-intro__inner,
  .servicio-section__inner {
    grid-template-columns: 1fr;
  }
  .servicio-section--alt .servicio-section__content {
    order: -1;
  }
  .servicios-extra__grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 600px) {
  .servicios-extra__grid {
    grid-template-columns: 1fr;
  }
}


/* ════════════════════════════════════════════════════════════
   PÁGINA: NOSOTROS
════════════════════════════════════════════════════════════ */

.nosotros-hero {
  padding-block-start: calc(72px + 60px);
  padding-block-end: 0;
  overflow: hidden;
}

.nosotros-hero__inner {
  max-width: var(--container-max);
  margin-inline: auto;
  padding-inline: var(--container-pad);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(48px, 6vw, 96px);
  align-items: end;
}

.nosotros-hero__text {
  padding-block-end: clamp(48px, 6vw, 80px);
}

.nosotros-hero__eyebrow {
  display: block;
  font-family: var(--font-body);
  font-size: 0.625rem;
  font-weight: 700;
  letter-spacing: 0.35em;
  text-transform: uppercase;
  color: var(--color-muted);
  margin-bottom: 20px;
}

.nosotros-hero__title {
  font-family: var(--font-display);
  font-size: clamp(2.5rem, 5vw, 4.5rem);
  font-weight: 400;
  line-height: 1.05;
  color: var(--color-black);
  margin-bottom: 28px;
}
.nosotros-hero__title em {
  font-style: italic;
  font-weight: 600;
  color: var(--color-accent-dk);
}

.nosotros-hero__desc {
  font-size: 1rem;
  line-height: 1.75;
  color: var(--color-muted);
  max-width: 440px;
  margin-bottom: 36px;
}

.nosotros-hero__img-col {
  align-self: stretch;
}
.nosotros-hero__img-col img {
  width: 100%;
  height: 100%;
  min-height: 480px;
  object-fit: cover;
  display: block;
  border-radius: var(--radius-lg) var(--radius-lg) 0 0;
}

/* Manifiesto */
.nosotros-manifiesto {
  padding-block: clamp(72px, 8vw, 120px);
  background: var(--color-black);
}

.nosotros-manifiesto__inner {
  max-width: 760px;
  margin-inline: auto;
  padding-inline: var(--container-pad);
  text-align: center;
}

.nosotros-manifiesto blockquote {
  font-family: var(--font-display);
  font-size: clamp(1.5rem, 3vw, 2.5rem);
  font-style: italic;
  font-weight: 400;
  color: var(--color-white);
  line-height: 1.4;
  margin-bottom: 24px;
}

.nosotros-manifiesto__author {
  font-family: var(--font-body);
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--color-accent);
}

/* Valores */
.nosotros-valores {
  padding-block: clamp(72px, 8vw, 112px);
}

.nosotros-valores__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2px;
  margin-top: 56px;
}

.valor-card {
  padding: clamp(28px, 3vw, 48px);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
}

.valor-card__num {
  font-family: var(--font-display);
  font-size: 4rem;
  font-weight: 300;
  color: var(--color-border);
  line-height: 1;
  margin-bottom: 16px;
}

.valor-card__title {
  font-family: var(--font-display);
  font-size: 1.5rem;
  font-weight: 400;
  color: var(--color-black);
  margin-bottom: 14px;
}

.valor-card p {
  font-size: 0.875rem;
  line-height: 1.7;
  color: var(--color-muted);
}

/* Equipo */
.nosotros-equipo {
  padding-block: clamp(72px, 8vw, 112px);
  background: var(--color-surface);
}

.equipo-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(24px, 3vw, 40px);
  margin-top: 56px;
}

.miembro-card {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.miembro-card__img-wrap {
  border-radius: var(--radius-md);
  overflow: hidden;
}
.miembro-card__img-wrap img {
  width: 100%;
  aspect-ratio: 3 / 4;
  object-fit: cover;
  display: block;
  transition: transform 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.miembro-card:hover .miembro-card__img-wrap img {
  transform: scale(1.04);
}

.miembro-card__name {
  font-family: var(--font-display);
  font-size: 1.25rem;
  font-weight: 400;
  color: var(--color-black);
}

.miembro-card__role {
  font-family: var(--font-body);
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-muted);
}

.miembro-card__bio {
  font-size: 0.875rem;
  line-height: 1.65;
  color: var(--color-muted);
}

.miembro-card__langs {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 4px;
}

.miembro-card__lang {
  font-size: 0.625rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--color-accent-dk);
  border: 1px solid var(--color-accent);
  padding: 4px 10px;
  border-radius: 20px;
}

/* Responsivo nosotros */
@media (max-width: 860px) {
  .nosotros-hero__inner { grid-template-columns: 1fr; }
  .nosotros-hero__img-col { display: none; }
  .nosotros-valores__grid,
  .equipo-grid { grid-template-columns: 1fr; }
}

@media (max-width: 600px) {
  .nosotros-valores__grid { grid-template-columns: 1fr; }
  .equipo-grid { grid-template-columns: repeat(2, 1fr); }
}


/* ════════════════════════════════════════════════════════════
   PÁGINA: CONTACTO / CITA PREVIA
════════════════════════════════════════════════════════════ */

.contacto-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: 100vh;
}

/* Columna izquierda: info tiendas */
.contacto-info {
  padding: clamp(80px, 8vw, 120px) clamp(32px, 5vw, 72px);
  padding-block-start: calc(72px + 60px);
  background: var(--color-black);
  color: var(--color-white);
}

.contacto-info__eyebrow {
  display: block;
  font-family: var(--font-body);
  font-size: 0.625rem;
  font-weight: 700;
  letter-spacing: 0.35em;
  text-transform: uppercase;
  color: var(--color-accent);
  margin-bottom: 20px;
}

.contacto-info__title {
  font-family: var(--font-display);
  font-size: clamp(2rem, 3.5vw, 3rem);
  font-weight: 400;
  color: var(--color-white);
  line-height: 1.1;
  margin-bottom: 40px;
}
.contacto-info__title em {
  font-style: italic;
  font-weight: 600;
  color: var(--color-accent);
}

/* Bloque de tienda */
.contacto-tienda {
  padding-block: 32px;
  border-top: 1px solid rgba(255,255,255,0.1);
}
.contacto-tienda:last-of-type {
  border-bottom: 1px solid rgba(255,255,255,0.1);
  margin-bottom: 40px;
}

.contacto-tienda__name {
  font-family: var(--font-display);
  font-size: 1.25rem;
  font-weight: 400;
  color: var(--color-white);
  margin-bottom: 12px;
}

.contacto-tienda__address {
  font-style: normal;
  font-size: 0.875rem;
  line-height: 1.6;
  color: rgba(255,255,255,0.55);
  margin-bottom: 14px;
}

.contacto-tienda__details {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.contacto-tienda__details li {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 0.8125rem;
  color: rgba(255,255,255,0.55);
}
.contacto-tienda__details li svg {
  color: var(--color-accent);
  flex-shrink: 0;
}
.contacto-tienda__details a {
  color: rgba(255,255,255,0.7);
  transition: color var(--transition);
}
.contacto-tienda__details a:hover { color: var(--color-white); }

/* Mapa placeholder */
.contacto-map-placeholder {
  width: 100%;
  height: 180px;
  background: rgba(255,255,255,0.05);
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.75rem;
  color: rgba(255,255,255,0.3);
  margin-top: 16px;
  border: 1px solid rgba(255,255,255,0.08);
  cursor: pointer;
  transition: background var(--transition);
}
.contacto-map-placeholder:hover {
  background: rgba(255,255,255,0.08);
}

/* Columna izquierda: formulario */
.contacto-form-col {
  padding: clamp(80px, 8vw, 120px) clamp(32px, 5vw, 72px);
  padding-block-start: calc(72px + 16px);
  background: var(--color-bg);
  overflow-y: auto;
}

.contacto-form-col__title {
  font-family: var(--font-display);
  font-size: clamp(1.75rem, 3vw, 2.5rem);
  font-weight: 400;
  color: var(--color-black);
  margin-bottom: 8px;
}
.contacto-form-col__title em {
  font-style: italic;
  font-weight: 600;
}

/* ── Cita Previa — marca y encabezado ─────────────────── */

/* Logotipo Panisse en la columna de reserva */
.cita-brand-mark {
  display: flex;
  align-items: center;
  gap: 20px;
  margin-bottom: 16px;
}

.cita-brand-mark__logo {
  font-family: 'Parisienne', cursive;
  font-size: 1.75rem;
  font-weight: 400;
  color: var(--color-black);
  white-space: nowrap;
}

.cita-brand-mark__logo em {
  font-style: normal;
}

.cita-brand-mark__line {
  flex: 1;
  height: 1px;
  background: var(--color-border);
}

.contacto-form-col__eyebrow {
  display: block;
  font-family: var(--font-body);
  font-size: 0.5625rem;
  font-weight: 700;
  letter-spacing: 0.35em;
  text-transform: uppercase;
  color: var(--color-accent-dk);
  margin-bottom: 14px;
}

.contacto-form-col__desc {
  font-size: 0.875rem;
  color: var(--color-muted);
  line-height: 1.7;
  margin-bottom: 32px;
}

/* ── Benefits — fila horizontal editorial ─────────────── */
.cita-benefits-row {
  display: flex;
  align-items: center;
  padding: 15px 0;
  margin-bottom: 36px;
  border-top: 1px solid var(--color-border);
  border-bottom: 1px solid var(--color-border);
}

.cita-benefits-row__item {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  font-family: var(--font-body);
  font-size: 0.6875rem;
  letter-spacing: 0.06em;
  color: var(--color-muted);
}

.cita-benefits-row__item svg {
  color: var(--color-accent-dk);
  flex-shrink: 0;
}

.cita-benefits-row__sep {
  width: 1px;
  height: 24px;
  background: var(--color-border);
}

/* ── Calendly con cabecera Panisse nativa ─────────────── */
.cita-calendly-outer {
  border: 1px solid var(--color-border);
  overflow: hidden; /* solo clipea las esquinas del borde */
}

/* Cabecera premium — reemplaza visualmente la cabecera de Calendly */
.cita-calendly-header {
  background: var(--color-black);
  padding: 22px 28px 20px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.cita-calendly-header__top {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
}

.cita-calendly-header__brand {
  font-family: 'Parisienne', cursive;
  font-size: 1.375rem;
  font-weight: 400;
  color: var(--color-white);
}

.cita-calendly-header__brand em {
  font-style: normal;
}

.cita-calendly-header__badge {
  font-family: var(--font-body);
  font-size: 0.5rem;
  font-weight: 700;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--color-black);
  background: var(--color-accent);
  padding: 3px 10px;
}

.cita-calendly-header__meta {
  display: flex;
  align-items: center;
  gap: 16px;
}

.cita-calendly-header__meta span {
  display: flex;
  align-items: center;
  gap: 5px;
  font-family: var(--font-body);
  font-size: 0.6875rem;
  letter-spacing: 0.05em;
  color: rgba(255, 255, 255, 0.45);
}

.cita-calendly-header__meta svg {
  color: var(--color-accent-dk);
  flex-shrink: 0;
}

/* Clip container: solo recorta el iframe, NO la cabecera Panisse */
.cita-calendly-clip {
  overflow: hidden;
  height: 630px; /* altura visible del calendario */
}

.cita-calendly-clip .calendly-inline-widget {
  display: block;
  margin-top: -52px; /* empuja arriba para ocultar la mini-cabecera de Calendly */
  height: 688px !important; /* 630 + 52 = area total del iframe */
}

/* Formulario de cita (legacy — kept for reference) */
.cita-form {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.form-group {
  display: flex;
  flex-direction: column;
  gap: 7px;
}

.form-label {
  font-family: var(--font-body);
  font-size: 0.625rem;
  font-weight: 700;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--color-muted);
}

.form-input,
.form-select,
.form-textarea {
  width: 100%;
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  font-family: var(--font-body);
  font-size: 0.875rem;
  color: var(--color-text);
  padding: 13px 16px;
  outline: none;
  transition: border-color var(--transition);
}
.form-input:focus,
.form-select:focus,
.form-textarea:focus {
  border-color: var(--color-black);
}
.form-input::placeholder,
.form-textarea::placeholder {
  color: var(--color-border);
}

.form-select {
  appearance: none;
  -webkit-appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%237a7a74' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 14px center;
  padding-right: 38px;
}

.form-textarea {
  resize: vertical;
  min-height: 100px;
}

.form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}

.form-check-group {
  display: flex;
  align-items: flex-start;
  gap: 12px;
}

.form-check {
  width: 18px;
  height: 18px;
  flex-shrink: 0;
  accent-color: var(--color-black);
  margin-top: 1px;
  cursor: pointer;
}

.form-check-label {
  font-size: 0.8125rem;
  line-height: 1.5;
  color: var(--color-muted);
}
.form-check-label a {
  color: var(--color-text);
  text-decoration: underline;
  text-underline-offset: 3px;
}

.cita-form .btn {
  align-self: flex-start;
}

.form-success {
  display: none;
  padding: 24px;
  background: rgba(199,219,214,0.2);
  border: 1px solid var(--color-accent);
  border-radius: var(--radius-md);
  font-size: 0.9375rem;
  color: var(--color-text);
  text-align: center;
}

/* Responsivo contacto */
@media (max-width: 900px) {
  .contacto-layout {
    grid-template-columns: 1fr;
    min-height: auto;
  }
  .contacto-form-col {
    padding-block-start: calc(60px + 40px);
  }
  .contacto-info {
    padding-block-start: clamp(48px, 6vw, 80px);
  }
}

@media (max-width: 480px) {
  .cita-brand-mark__logo { font-size: 1.375rem; }
  .cita-calendly-header { padding: 18px 20px 16px; }
  .cita-calendly-header__badge { display: none; }
  .cita-benefits-row__item { font-size: 0.625rem; gap: 5px; }
}


/* ════════════════════════════════════════════════════════════
   SECCIÓN: RESEÑAS GOOGLE
════════════════════════════════════════════════════════════ */

.resenas {
  padding-block: clamp(64px, 8vw, 100px);
  background: var(--color-bg);
}

.resenas__header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 40px;
  margin-block-end: 52px;
  flex-wrap: wrap;
}

.resenas__left {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.resenas__google-badge {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  font-family: var(--font-body);
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--color-muted);
}

.resenas__aggregate {
  display: flex;
  align-items: center;
  gap: 18px;
}

.resenas__score {
  font-family: var(--font-display);
  font-size: clamp(3rem, 5vw, 4.5rem);
  font-weight: 300;
  line-height: 1;
  color: var(--color-text);
  letter-spacing: -0.02em;
}

.resenas__stars-big {
  color: #f5a623;
  font-size: 1.0625rem;
  letter-spacing: 3px;
  display: block;
  margin-block-end: 4px;
}

.resenas__count {
  font-family: var(--font-body);
  font-size: 0.6875rem;
  color: var(--color-muted);
  display: block;
}

/* ── Carrusel wrapper ──────────────────────────────────────── */
.resenas-carousel {
  position: relative;
  margin-block-end: 0;
}

.resenas-carousel__viewport {
  overflow: hidden;
  border-radius: var(--radius-sm);
}

.resenas-carousel__track {
  display: flex;
  gap: 20px;
  transition: transform 0.52s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  will-change: transform;
}

/* Tamaño de cada tarjeta: 3 visibles en escritorio */
.resenas-carousel__track .resena-card {
  flex: 0 0 calc((100% - 40px) / 3);
  min-width: 0;
}

/* Controles: flechas + dots */
.resenas-carousel__controls {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 20px;
  margin-top: 36px;
}

.resenas-carousel__btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  border: 1px solid var(--color-border);
  background: var(--color-white);
  color: var(--color-text);
  cursor: pointer;
  flex-shrink: 0;
  transition: background var(--transition), border-color var(--transition),
              color var(--transition), transform var(--transition);
}
.resenas-carousel__btn:hover:not(:disabled) {
  background: var(--color-black);
  border-color: var(--color-black);
  color: var(--color-white);
  transform: scale(1.06);
}
.resenas-carousel__btn:disabled {
  opacity: 0.3;
  cursor: default;
  pointer-events: none;
}

.resenas-carousel__dots {
  display: flex;
  align-items: center;
  gap: 8px;
}

.resenas-carousel__dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  border: none;
  background: var(--color-border);
  cursor: pointer;
  padding: 0;
  transition: background var(--transition), transform var(--transition);
}
.resenas-carousel__dot.is-active {
  background: var(--color-black);
  transform: scale(1.45);
}

/* Responsive */
@media (max-width: 900px) {
  .resenas-carousel__track .resena-card {
    flex: 0 0 calc((100% - 20px) / 2);
  }
}
@media (max-width: 600px) {
  .resenas-carousel__track .resena-card {
    flex: 0 0 100%;
  }
  .resenas-carousel__controls {
    gap: 14px;
  }
}

.resena-card {
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: 4px;
  padding: clamp(20px, 2.5vw, 32px);
  display: flex;
  flex-direction: column;
  gap: 14px;
  transition: box-shadow var(--transition), transform var(--transition);
}

.resena-card:hover {
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.07);
  transform: translateY(-2px);
}

.resena-card__header {
  display: flex;
  align-items: center;
  gap: 12px;
}

.resena-card__avatar {
  width: 42px;
  height: 42px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-display);
  font-size: 1.125rem;
  font-weight: 600;
  color: var(--color-text);
  flex-shrink: 0;
  background: var(--color-accent);
  overflow: hidden;
}
.resena-card__avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.resena-card__avatar--b { background: #e8d4c0; }
.resena-card__avatar--c { background: #d4dce8; }
.resena-card__avatar--d { background: #e0d4e8; }
.resena-card__avatar--e { background: #d4e8d8; }
.resena-card__avatar--f { background: #e8e4d4; }

.resena-card__meta {
  flex: 1;
  min-width: 0;
}

.resena-card__name {
  display: block;
  font-family: var(--font-body);
  font-size: 0.875rem;
  font-weight: 700;
  color: var(--color-text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.resena-card__date {
  font-family: var(--font-body);
  font-size: 0.6875rem;
  color: var(--color-muted);
}

.resena-card__stars {
  color: #f5a623;
  font-size: 0.875rem;
  letter-spacing: 2px;
  line-height: 1;
}

.resena-card__text {
  font-family: var(--font-body);
  font-size: 0.875rem;
  line-height: 1.72;
  color: var(--color-text);
  font-style: italic;
  flex: 1;
}

.resenas__cta {
  text-align: center;
}

@media (max-width: 900px) {
  .resenas__header {
    flex-direction: column;
    align-items: flex-start;
    gap: 28px;
  }
  .resenas__grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 600px) {
  .resenas__grid {
    grid-template-columns: 1fr;
  }
}

/* Mapa en contacto */
/* ════════════════════════════════════════════════════════════
   SECCIÓN: BLOG PREVIEW
════════════════════════════════════════════════════════════ */
.blog-preview {
  padding-block: clamp(72px, 8vw, 112px);
  background: var(--color-surface);
}

.blog-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(20px, 2.5vw, 32px);
  margin-block-end: 52px;
}

.blog-card {
  display: flex;
  flex-direction: column;
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  overflow: hidden;
  transition: box-shadow var(--transition), transform var(--transition);
}
.blog-card:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-3px);
}

.blog-card__image-wrap {
  aspect-ratio: 16 / 10;
  overflow: hidden;
  background: var(--color-accent);
}
.blog-card__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.62s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.blog-card:hover .blog-card__img {
  transform: scale(1.05);
}

.blog-card__body {
  display: flex;
  flex-direction: column;
  flex: 1;
  padding: clamp(18px, 2.5vw, 28px);
  gap: 10px;
}

.blog-card__cat {
  font-family: var(--font-body);
  font-size: 0.5625rem;
  font-weight: 700;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--color-accent-dk);
}

.blog-card__title {
  font-family: var(--font-display);
  font-size: clamp(0.975rem, 1.35vw, 1.175rem);
  font-weight: 400;
  line-height: 1.38;
  color: var(--color-black);
}
.blog-card__title a {
  transition: color var(--transition);
}
.blog-card__title a:hover {
  color: var(--color-accent-dk);
}

.blog-card__excerpt {
  font-family: var(--font-body);
  font-size: 0.8125rem;
  line-height: 1.68;
  color: var(--color-muted);
  flex: 1;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.blog-card__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-top: 14px;
  border-top: 1px solid var(--color-border);
  margin-top: auto;
}
.blog-card__date {
  font-size: 0.6875rem;
  color: var(--color-muted);
  letter-spacing: 0.04em;
}
.blog-card__read-more {
  font-size: 0.625rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--color-black);
  transition: color var(--transition), letter-spacing var(--transition);
}
.blog-card__read-more:hover {
  color: var(--color-accent-dk);
  letter-spacing: 0.2em;
}

.blog-preview__cta {
  text-align: center;
}

@media (max-width: 900px) {
  .blog-grid { grid-template-columns: repeat(2, 1fr); }
  .blog-card:last-child { grid-column: 1 / -1; }
  .blog-card:last-child .blog-card__image-wrap { aspect-ratio: 21 / 9; }
}
@media (max-width: 600px) {
  .blog-grid { grid-template-columns: 1fr; }
  .blog-card:last-child { grid-column: auto; }
  .blog-card:last-child .blog-card__image-wrap { aspect-ratio: 16 / 10; }
}

/* ════════════════════════════════════════════════════════════ */

.contacto-map {
  margin-block-start: 24px;
  border-radius: 4px;
  overflow: hidden;
}

.contacto-map iframe {
  display: block;
  width: 100%;
  height: 280px;
  border: none;
}

/* ════════════════════════════════════════════════════════════
   SCROLL REVEAL
════════════════════════════════════════════════════════════ */
.reveal {
  opacity: 0;
  transform: translateY(18px);
  transition:
    opacity 0.7s cubic-bezier(0.25, 0.46, 0.45, 0.94),
    transform 0.7s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.reveal.is-visible {
  opacity: 1;
  transform: none;
}
.reveal--delay-1 { transition-delay: 0.08s; }
.reveal--delay-2 { transition-delay: 0.16s; }
.reveal--delay-3 { transition-delay: 0.24s; }
.reveal--delay-4 { transition-delay: 0.32s; }

/* ════════════════════════════════════════════════════════════
   SKELETON LOADING (Google Reviews)
════════════════════════════════════════════════════════════ */
@keyframes skeleton-shimmer {
  0%   { background-position: -400px 0; }
  100% { background-position: 400px 0; }
}
.resena-card--skeleton {
  pointer-events: none;
}
.resena-card--skeleton .skel {
  border-radius: 3px;
  background: linear-gradient(
    90deg,
    var(--color-surface) 25%,
    var(--color-border) 50%,
    var(--color-surface) 75%
  );
  background-size: 800px 100%;
  animation: skeleton-shimmer 1.4s ease-in-out infinite;
}
.skel-avatar  { width: 42px; height: 42px; border-radius: 50%; }
.skel-line    { height: 10px; margin-block: 4px; }
.skel-line--sm { width: 60%; }
.skel-line--md { width: 80%; }
.skel-line--xs { width: 40%; }
.skel-para    { height: 9px; }
.skel-para + .skel-para { margin-top: 6px; }

/* Skeleton: product cards (catálogo dinámico) */
.product-card--skeleton {
  pointer-events: none;
  cursor: default;
}
.skeleton-box,
.skeleton-line {
  border-radius: 3px;
  background: linear-gradient(
    90deg,
    var(--color-surface) 25%,
    var(--color-border)  50%,
    var(--color-surface) 75%
  );
  background-size: 800px 100%;
  animation: skeleton-shimmer 1.4s ease-in-out infinite;
}
.skeleton-box {
  aspect-ratio: 5 / 4;
  border-radius: var(--radius-sm);
  margin-bottom: 14px;
}
.skeleton-line {
  margin-bottom: 0;
  border-radius: 2px;
}

/* ══════════════════════════════════════
   CITA PREVIA - CALENDLY
══════════════════════════════════════ */
.contacto-form-col__eyebrow {
  display: block;
  font-size: 0.85rem;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--color-primary);
  margin-bottom: 0.5rem;
  font-weight: 600;
}

.cita-benefits {
  list-style: none;
  padding: 0;
  margin: 1.5rem 0 2rem;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.cita-benefits__item {
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: 0.95rem;
  color: var(--color-text-light);
}

.cita-benefits__item svg {
  color: var(--color-primary);
  flex-shrink: 0;
}

.cita-calendly-outer {
  position: relative;
  overflow: hidden;
  border-radius: 8px;
  background: var(--color-surface);
  margin-top: 1rem;
  border: 1px solid var(--color-border);
}

/* Recorte ninja de la cabecera del iframe de Calendly para limpieza visual */
.cita-calendly-outer .calendly-inline-widget {
  margin-top: -55px;
  height: 715px !important;
}

/* ════════════════════════════════════════════════════════════
   SCROLL REVEAL — variantes extendidas
════════════════════════════════════════════════════════════ */
.reveal--delay-5 { transition-delay: 0.40s; }
.reveal--delay-6 { transition-delay: 0.48s; }
.reveal--delay-7 { transition-delay: 0.56s; }
.reveal--delay-8 { transition-delay: 0.64s; }

.reveal--from-left {
  opacity: 0;
  transform: translateX(-28px);
}
.reveal--from-left.is-visible {
  opacity: 1;
  transform: none;
}
.reveal--from-right {
  opacity: 0;
  transform: translateX(28px);
}
.reveal--from-right.is-visible {
  opacity: 1;
  transform: none;
}
.reveal--scale {
  opacity: 0;
  transform: scale(0.96) translateY(10px);
}
.reveal--scale.is-visible {
  opacity: 1;
  transform: none;
}

/* Stagger automático: añade .reveal--stagger al contenedor */
.reveal--stagger > * {
  opacity: 0;
  transform: translateY(16px);
  transition:
    opacity  0.55s cubic-bezier(0.25, 0.46, 0.45, 0.94),
    transform 0.55s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.reveal--stagger.is-visible > *:nth-child(1) { opacity:1; transform:none; transition-delay:0.00s; }
.reveal--stagger.is-visible > *:nth-child(2) { opacity:1; transform:none; transition-delay:0.07s; }
.reveal--stagger.is-visible > *:nth-child(3) { opacity:1; transform:none; transition-delay:0.14s; }
.reveal--stagger.is-visible > *:nth-child(4) { opacity:1; transform:none; transition-delay:0.21s; }
.reveal--stagger.is-visible > *:nth-child(5) { opacity:1; transform:none; transition-delay:0.28s; }
.reveal--stagger.is-visible > *:nth-child(6) { opacity:1; transform:none; transition-delay:0.35s; }
.reveal--stagger.is-visible > *:nth-child(n+7) { opacity:1; transform:none; transition-delay:0.40s; }

/* ════════════════════════════════════════════════════════════
   MICRO-ANIMACIONES PREMIUM
════════════════════════════════════════════════════════════ */

/* Línea decorativa bajo nav-links en hover */
.header__nav-list .nav-link {
  position: relative;
}
.header__nav-list .nav-link::after {
  content: '';
  position: absolute;
  bottom: -2px;
  left: 0;
  right: 0;
  height: 1px;
  background: var(--color-black);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.30s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.header__nav-list .nav-link:hover::after {
  transform: scaleX(1);
}

/* Footer links: micro-deslizamiento */
.footer__link {
  transition: color var(--transition), padding-left var(--transition);
}
.footer__link:hover {
  padding-left: 5px;
}

/* Botones: shimmer de luz en hover */
.btn {
  position: relative;
  overflow: hidden;
}
.btn::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    105deg,
    transparent 40%,
    rgba(255,255,255,0.10) 50%,
    transparent 60%
  );
  transform: translateX(-120%);
  transition: transform 0.55s ease;
  pointer-events: none;
}
.btn:hover::after {
  transform: translateX(120%);
}

/* Imágenes lazy: fade-in en carga */
img[loading="lazy"] {
  opacity: 0;
  transition: opacity 0.45s ease;
}
img[loading="lazy"].is-loaded {
  opacity: 1;
}

/* ════════════════════════════════════════════════════════════
   BLOG: artículo editorial
════════════════════════════════════════════════════════════ */
.blog-article {
  padding-block: 60px 80px;
}
.blog-article__header {
  max-width: 780px;
  margin-inline: auto;
  margin-bottom: 28px;
  text-align: center;
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.blog-article__meta {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 20px;
}
.blog-article__category {
  font-family: var(--font-body);
  font-size: 0.5625rem;
  font-weight: 700;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--color-accent-dk);
}
.blog-article__date {
  font-size: 0.75rem;
  color: var(--color-muted);
}
.blog-article__title {
  font-family: var(--font-display);
  font-size: clamp(2rem, 4.5vw, 3.25rem);
  font-weight: 300;
  line-height: 1.12;
  color: var(--color-black);
}
.blog-article__title em {
  font-style: italic;
  color: var(--color-accent-dk);
  font-weight: 300;
}
.blog-article__lead {
  font-family: var(--font-display);
  font-size: clamp(1.0625rem, 1.8vw, 1.25rem);
  font-weight: 300;
  line-height: 1.65;
  color: var(--color-muted);
  max-width: 640px;
  margin-inline: auto;
}
.blog-article__author {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
}
.blog-article__author-name {
  font-size: 0.8125rem;
  font-weight: 700;
  color: var(--color-text);
}
.blog-article__author-role {
  display: block;
  font-size: 0.6875rem;
  color: var(--color-muted);
}
.blog-article__hero-img {
  max-width: 820px;
  margin-inline: auto;
  margin-bottom: 52px;
  border-radius: var(--radius-md);
  overflow: hidden;
  height: 420px;
}
.blog-article__hero-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
  display: block;
}
.blog-article__body {
  max-width: 720px;
  margin-inline: auto;
  display: flex;
  flex-direction: column;
  gap: 48px;
}
.blog-section {
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.blog-section__title {
  font-family: var(--font-display);
  font-size: 1.5rem;
  font-weight: 400;
  color: var(--color-black);
  line-height: 1.25;
}
.blog-article__body p {
  font-size: 1rem;
  line-height: 1.82;
  color: var(--color-muted);
}
.blog-article__body p em  { font-style: italic; color: var(--color-text); }
.blog-article__body p strong { color: var(--color-text); font-weight: 700; }

/* Blockquote */
.blog-quote {
  border-left: 2px solid var(--color-black);
  padding: 18px 0 18px 32px;
  margin: 0;
}
.blog-quote p {
  font-family: var(--font-display);
  font-size: clamp(1.125rem, 2vw, 1.375rem) !important;
  font-weight: 300;
  font-style: italic;
  color: var(--color-black) !important;
  line-height: 1.55 !important;
}
.blog-quote--light { border-color: var(--color-accent-dk); }
.blog-quote--light p { color: var(--color-accent-dk) !important; }

/* Tabla comparativa */
.blog-compare {
  display: grid;
  grid-template-columns: 1fr 1fr;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  overflow: hidden;
}
.blog-compare__col {
  padding: 28px 28px 32px;
  background: var(--color-surface);
}
.blog-compare__col--accent { background: var(--color-black); }
.blog-compare__title {
  font-family: var(--font-body);
  font-size: 0.5625rem;
  font-weight: 700;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--color-muted);
  margin-bottom: 18px;
}
.blog-compare__col--accent .blog-compare__title { color: var(--color-accent); }
.blog-compare__list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 11px;
}
.blog-compare__list li {
  font-size: 0.875rem;
  line-height: 1.45;
  color: var(--color-muted);
  padding-left: 14px;
  position: relative;
}
.blog-compare__list li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0.6em;
  width: 5px;
  height: 1px;
  background: var(--color-border);
}
.blog-compare__col--accent .blog-compare__list li { color: rgba(255,255,255,0.65); }
.blog-compare__col--accent .blog-compare__list li::before { background: var(--color-accent-dk); }

/* Footer del artículo */
.blog-article__footer {
  max-width: 720px;
  margin-inline: auto;
  margin-top: 64px;
  padding-top: 40px;
  border-top: 1px solid var(--color-border);
  display: flex;
  flex-direction: column;
  gap: 28px;
}
.blog-article__cta {
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
}
.blog-article__cta-text {
  font-size: 0.9375rem;
  color: var(--color-muted);
  flex: 1;
  min-width: 180px;
  line-height: 1.5 !important;
}
.blog-article__tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.blog-tag {
  font-family: var(--font-body);
  font-size: 0.625rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-muted);
  border: 1px solid var(--color-border);
  border-radius: 100px;
  padding: 5px 12px;
  transition: color var(--transition), border-color var(--transition);
}
.blog-tag:hover {
  color: var(--color-black);
  border-color: var(--color-black);
}

/* Coming soon */
.blog-coming-soon {
  background: var(--color-surface);
  border-top: 1px solid var(--color-border);
  padding-block: 72px;
  text-align: center;
}
.blog-coming-soon__label {
  font-family: var(--font-body);
  font-size: 0.5625rem;
  font-weight: 700;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--color-accent-dk);
  margin-bottom: 14px;
}
.blog-coming-soon__title {
  font-family: var(--font-display);
  font-size: clamp(1.5rem, 3vw, 2rem);
  font-weight: 300;
  color: var(--color-black);
  margin-bottom: 18px;
}
.blog-coming-soon__text {
  max-width: 520px;
  margin-inline: auto;
  font-size: 0.9375rem;
  line-height: 1.75;
  color: var(--color-muted);
}

@media (max-width: 640px) {
  .blog-compare {
    grid-template-columns: 1fr;
  }
  .blog-article__cta {
    flex-direction: column;
    align-items: flex-start;
  }
  .blog-article__hero-img {
    border-radius: 0;
    margin-inline: calc(-1 * var(--container-pad));
  }
}

/* ════════════════════════════════════════════════════════════
   PÁGINAS LEGALES (aviso-legal, privacidad)
════════════════════════════════════════════════════════════ */
.legal-doc {
  max-width: 820px;
  margin: 0 auto;
  padding: 4rem 0 6rem;
  font-size: 0.9375rem;
  line-height: 1.75;
  color: var(--color-text);
}

.legal-doc h2 {
  font-family: var(--font-display);
  font-size: 1.375rem;
  font-weight: 400;
  color: var(--color-black);
  margin-top: 2.5rem;
  margin-bottom: 0.75rem;
  padding-bottom: 0.4rem;
  border-bottom: 1px solid var(--color-border);
}

.legal-doc h2:first-child {
  margin-top: 0;
  font-size: 1.1rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-family: var(--font-body);
  font-weight: 700;
  color: var(--color-muted);
  border-bottom: 2px solid var(--color-border);
  padding-bottom: 0.6rem;
}

.legal-doc p {
  margin-bottom: 1rem;
  color: var(--color-muted);
}

.legal-doc ul {
  margin: 0.5rem 0 1rem 1.25rem;
  color: var(--color-muted);
}

.legal-doc ul li {
  margin-bottom: 0.4rem;
}

.legal-doc a {
  color: var(--color-accent-dk);
  text-decoration: underline;
  text-underline-offset: 3px;
}

.legal-doc a:hover {
  color: var(--color-black);
}

.legal-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.8125rem;
  margin: 1rem 0 1.5rem;
  color: var(--color-muted);
}

.legal-table th {
  background: var(--color-surface);
  color: var(--color-text);
  font-weight: 700;
  font-size: 0.6875rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 10px 14px;
  text-align: left;
  border-bottom: 2px solid var(--color-border);
}

.legal-table td {
  padding: 10px 14px;
  border-bottom: 1px solid var(--color-border);
  vertical-align: top;
}

.legal-table tr:last-child td {
  border-bottom: none;
}

.legal-divider {
  border: none;
  border-top: 2px solid var(--color-border);
  margin: 3rem 0;
}

@media (max-width: 768px) {
  .legal-table {
    display: block;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }

}

/* ════════════════════════════════════════════════════════════
   SECCIÓN: RESEÑAS — Carrusel premium
════════════════════════════════════════════════════════════ */
.resenas {
  padding-block: clamp(72px, 8vw, 112px);
  background: var(--color-bg);
  overflow: hidden;
}

/* ── Cabecera de tres columnas ──────────────────────────── */
.resenas__top {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 32px;
  margin-bottom: 48px;
}

/* Puntuación */
.resenas__score-block {
  display: flex;
  align-items: center;
  gap: 14px;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: 16px 24px;
  white-space: nowrap;
}

.resenas__score-number {
  font-family: var(--font-display);
  font-size: 2.75rem;
  font-weight: 600;
  color: var(--color-black);
  line-height: 1;
}

.resenas__score-meta {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.resenas__stars {
  font-size: 1rem;
  color: #c9a84c;
  letter-spacing: 2px;
}

.resenas__count {
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-muted);
}

/* Títulos centrales */
.resenas__heading-col {
  text-align: center;
}

.resenas__eyebrow {
  display: block;
  font-size: 0.625rem;
  font-weight: 700;
  letter-spacing: 0.35em;
  text-transform: uppercase;
  color: var(--color-muted);
  margin-bottom: 8px;
}

.resenas__title {
  font-family: var(--font-display);
  font-size: clamp(1.75rem, 3vw, 2.5rem);
  font-weight: 400;
  color: var(--color-black);
}

/* Botones prev/next */
.resenas__nav {
  display: flex;
  gap: 8px;
}

.resenas__arrow {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  border: 1px solid var(--color-border);
  border-radius: 50%;
  background: var(--color-white);
  color: var(--color-text);
  cursor: pointer;
  transition:
    background var(--transition),
    border-color var(--transition),
    color var(--transition),
    transform var(--transition);
  flex-shrink: 0;
}

.resenas__arrow:hover:not(:disabled) {
  background: var(--color-black);
  border-color: var(--color-black);
  color: var(--color-white);
  transform: scale(1.05);
}

.resenas__arrow:disabled {
  opacity: 0.35;
  cursor: default;
}

/* ── Viewport del carrusel ──────────────────────────────── */
.resenas-carousel__viewport {
  overflow: hidden;
  width: 100%;
}

.resenas-carousel__track {
  display: flex;
  gap: 20px;
  transition: transform 0.52s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  will-change: transform;
  list-style: none;
}

/* ── Tarjeta de reseña ──────────────────────────────────── */
.resena-card {
  flex: 0 0 calc((100% - 40px) / 3);
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: clamp(24px, 2.5vw, 32px);
  display: flex;
  flex-direction: column;
  gap: 16px;
  box-shadow: var(--shadow-sm);
  transition: box-shadow var(--transition), transform var(--transition);
}

.resena-card:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-3px);
}

.resena-card__header {
  display: flex;
  align-items: center;
  gap: 12px;
}

.resena-card__avatar {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  overflow: hidden;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-body);
  font-size: 0.875rem;
  font-weight: 700;
  color: var(--color-black);
}

.resena-card__meta {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}

.resena-card__name {
  font-size: 0.875rem;
  font-weight: 700;
  color: var(--color-black);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.resena-card__date {
  font-size: 0.75rem;
  color: var(--color-muted);
}

.resena-card__stars {
  font-size: 0.9rem;
  color: #c9a84c;
  letter-spacing: 2px;
  line-height: 1;
}

.resena-card__text {
  font-size: 0.9rem;
  line-height: 1.7;
  color: var(--color-muted);
  flex: 1;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 5;
  overflow: hidden;
}

/* ── Footer: dots + CTA ─────────────────────────────────── */
.resenas__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 32px;
  flex-wrap: wrap;
  gap: 16px;
}

.resenas-carousel__dots {
  display: flex;
  gap: 7px;
  align-items: center;
}

.resenas-carousel__dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--color-border);
  border: none;
  cursor: pointer;
  padding: 0;
  transition: background var(--transition), transform var(--transition);
}

.resenas-carousel__dot.is-active {
  background: var(--color-black);
  transform: scale(1.3);
}

.resenas__cta-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-body);
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--color-muted);
  transition: color var(--transition);
}

.resenas__cta-link:hover {
  color: var(--color-black);
}

/* ── Responsivo reseñas ─────────────────────────────────── */
@media (max-width: 900px) {
  .resena-card {
    flex: 0 0 calc((100% - 20px) / 2);
  }
  .resenas__top {
    grid-template-columns: 1fr 1fr;
  }
  .resenas__score-block { grid-column: 1; grid-row: 1; }
  .resenas__nav         { grid-column: 2; grid-row: 1; justify-content: flex-end; }
  .resenas__heading-col { grid-column: 1 / -1; grid-row: 2; text-align: left; }
}

@media (max-width: 600px) {
  .resena-card {
    flex: 0 0 100%;
  }
  .resenas__top {
    grid-template-columns: 1fr auto;
    gap: 16px;
  }
  .resenas__score-block { grid-column: 1; grid-row: 1; padding: 12px 16px; }
  .resenas__score-number { font-size: 2rem; }
  .resenas__nav { grid-column: 2; grid-row: 1; }
  .resenas__heading-col { grid-column: 1 / -1; grid-row: 2; text-align: left; }
  .resenas__footer { flex-direction: column; align-items: flex-start; }
}


/* ════════════════════════════════════════════════════════════
   SECCIÓN: CTA REVISIÓN GRATUITA — Premium dark
════════════════════════════════════════════════════════════ */
.cta-revision {
  position: relative;
  padding-block: clamp(80px, 10vw, 128px);
  background: #0d0d0b;
  color: var(--color-white);
  overflow: hidden;
}

.cta-revision__bg {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 70% 60% at 15% 50%, rgba(199, 219, 214, 0.10) 0%, transparent 70%),
    radial-gradient(ellipse 50% 80% at 85% 20%, rgba(138, 175, 169, 0.07) 0%, transparent 65%);
  pointer-events: none;
}

.cta-revision__inner {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 28px;
  max-width: 680px;
}

.cta-revision__badge {
  display: inline-block;
  font-family: var(--font-body);
  font-size: 0.5625rem;
  font-weight: 700;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--color-accent);
  border: 1px solid rgba(199, 219, 214, 0.4);
  border-radius: 100px;
  padding: 5px 14px;
}

.cta-revision__title {
  font-family: var(--font-display);
  font-size: clamp(2.5rem, 5vw, 4rem);
  font-weight: 400;
  line-height: 1.05;
  color: var(--color-white);
}

.cta-revision__title em {
  font-style: italic;
  font-weight: 600;
  color: var(--color-accent);
}

.cta-revision__desc {
  font-size: clamp(0.9rem, 1.4vw, 1rem);
  line-height: 1.75;
  color: rgba(255, 255, 255, 0.6);
  max-width: 540px;
}

.cta-revision__features {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 24px;
}

.cta-revision__feature {
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-body);
  font-size: 0.8125rem;
  color: rgba(255, 255, 255, 0.75);
}

.cta-revision__feature svg {
  color: var(--color-accent);
  flex-shrink: 0;
}

.cta-revision__actions {
  display: flex;
  align-items: center;
  gap: 28px;
  flex-wrap: wrap;
}

.cta-revision .btn--primary {
  background: var(--color-white);
  color: var(--color-black);
  border-color: var(--color-white);
}

.cta-revision .btn--primary:hover {
  background: transparent;
  color: var(--color-white);
  border-color: var(--color-white);
}

.cta-revision__tel {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-body);
  font-size: 0.875rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  color: rgba(255, 255, 255, 0.65);
  transition: color var(--transition);
}

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

@media (max-width: 480px) {
  .cta-revision__actions {
    flex-direction: column;
    align-items: flex-start;
    gap: 16px;
  }
  .cta-revision .btn--primary {
    width: 100%;
    text-align: center;
  }
}


/* ════════════════════════════════════════════════════════════
   SECCIÓN: PRODUCTOS DESTACADOS (index.html aliases)
════════════════════════════════════════════════════════════ */
.products-section {
  padding-block: clamp(60px, 8vw, 100px);
  background: var(--color-bg);
}

.products-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px 16px;
}

.products-section__cta {
  display: flex;
  justify-content: center;
  margin-top: 48px;
}

.section-title {
  font-family: var(--font-display);
  font-size: clamp(1.75rem, 3vw, 2.5rem);
  font-weight: 400;
  color: var(--color-black);
  margin-bottom: 8px;
}

.section-subtitle {
  font-size: 0.9375rem;
  color: var(--color-muted);
  line-height: 1.6;
}

@media (max-width: 1024px) {
  .products-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 480px) {
  .products-grid { grid-template-columns: repeat(2, 1fr); gap: 14px 10px; }
}

/* ════════════════════════════════════════════════════════════
   PANISSE MAGAZINE — Layout editorial + cronología
════════════════════════════════════════════════════════════ */

/* ── Masthead ───────────────────────────────────────────── */
.magazine-masthead {
  padding: clamp(64px, 10vw, 120px) 0 clamp(48px, 7vw, 80px);
  text-align: center;
  border-bottom: 1px solid var(--color-border);
}
.magazine-masthead__issue {
  font-size: 0.7rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--color-muted);
  margin-bottom: 1.25rem;
}
.magazine-masthead__title {
  font-family: var(--font-display);
  font-size: clamp(3.5rem, 9vw, 7rem);
  font-weight: 300;
  line-height: 0.95;
  letter-spacing: -0.02em;
  color: var(--color-black);
  margin-bottom: 1rem;
}
.magazine-masthead__title em {
  font-style: italic;
  color: var(--color-accent-dk);
}
.magazine-masthead__tagline {
  font-size: 0.72rem;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: var(--color-muted);
  margin-bottom: 2.5rem;
}
.magazine-masthead__ornament {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  color: var(--color-muted);
  font-size: 0.65rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
}
.magazine-masthead__ornament::before,
.magazine-masthead__ornament::after {
  content: '';
  width: 40px;
  height: 1px;
  background: var(--color-border);
}

/* ── Timeline ───────────────────────────────────────────── */
.magazine-timeline {
  padding: clamp(64px, 8vw, 100px) 0 clamp(48px, 6vw, 80px);
}
.magazine-timeline__inner {
  position: relative;
  padding-left: 160px;
}
.magazine-timeline__line {
  position: absolute;
  left: 148px;
  top: 0;
  bottom: 0;
  width: 1px;
  background: var(--color-border);
}

.timeline-entry {
  display: flex;
  gap: 0;
  margin-bottom: clamp(56px, 7vw, 96px);
  align-items: flex-start;
}
.timeline-entry:last-child { margin-bottom: 0; }

.timeline-entry__aside {
  position: absolute;
  left: 0;
  width: 148px;
  text-align: right;
  padding-right: 28px;
  padding-top: 20px;
}
.timeline-entry__dot {
  position: absolute;
  right: -5px;
  top: 24px;
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: var(--color-accent-dk);
  border: 2px solid var(--color-bg);
  box-shadow: 0 0 0 1px var(--color-accent-dk);
}
.timeline-entry__date {
  display: block;
  font-size: 0.68rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--color-muted);
  line-height: 1.4;
}

.timeline-entry__main {
  flex: 1;
  padding-left: 40px;
}

/* ── Timeline Card ──────────────────────────────────────── */
.timeline-card {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: 36px;
  align-items: start;
  cursor: pointer;
}
.timeline-card__img {
  aspect-ratio: 16 / 10;
  overflow: hidden;
  border-radius: var(--radius-lg);
  background: var(--color-surface);
}
.timeline-card__img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.5s ease;
}
.timeline-card:hover .timeline-card__img img {
  transform: scale(1.04);
}
.timeline-card__body {
  padding-top: 8px;
}
.timeline-card__cat {
  display: block;
  font-size: 0.65rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--color-accent-dk);
  margin-bottom: 0.75rem;
}
.timeline-card__title {
  font-family: var(--font-display);
  font-size: clamp(1.35rem, 2.2vw, 1.75rem);
  font-weight: 400;
  line-height: 1.2;
  color: var(--color-black);
  margin-bottom: 1rem;
}
.timeline-card__title em { font-style: italic; }
.timeline-card__excerpt {
  font-size: 0.9375rem;
  color: var(--color-muted);
  line-height: 1.75;
  margin-bottom: 1.5rem;
}
.timeline-card__link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 0.78rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-text);
  text-decoration: none;
  border-bottom: 1px solid var(--color-text);
  padding-bottom: 2px;
  transition: color 0.2s, border-color 0.2s;
}
.timeline-card__link:hover {
  color: var(--color-accent-dk);
  border-color: var(--color-accent-dk);
}

/* ── Separador entre timeline y artículos ─────────────────── */
.magazine-divider {
  display: flex;
  align-items: center;
  gap: 20px;
  margin: 0 0 clamp(56px, 7vw, 96px);
  color: var(--color-muted);
  font-size: 0.65rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
}
.magazine-divider::before,
.magazine-divider::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--color-border);
}

/* ── Contenedor artículos completos ─────────────────────── */
.magazine-articles {
  padding-bottom: clamp(64px, 8vw, 120px);
}
.magazine-articles .blog-article {
  border-top: 1px solid var(--color-border);
  padding-top: clamp(56px, 7vw, 96px);
  margin-bottom: clamp(56px, 7vw, 96px);
}
.magazine-articles .blog-article:first-child { border-top: none; }

/* ── Responsive ─────────────────────────────────────────── */
@media (max-width: 900px) {
  .magazine-timeline__inner { padding-left: 0; }
  .magazine-timeline__line  { display: none; }
  .timeline-entry__aside    { position: static; width: auto; text-align: left; padding-right: 0; padding-top: 0; display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
  .timeline-entry__dot      { position: static; right: auto; top: auto; }
  .timeline-entry__main     { padding-left: 0; }
  .timeline-card            { grid-template-columns: 1fr; }
  .timeline-card__img       { aspect-ratio: 16 / 9; }
}
