/* ============================================================
   AFIKO — Estilos de plantillas (pages.css)
   CSS por página que en el prototipo vivía en <style> inline.
   Se carga después de afiko.css y motion.css.
   ============================================================ */

/* ─────────────────────────────────────────
   HOME · Hero
───────────────────────────────────────── */
.hero { position: relative; overflow: hidden; }
.hero__inner { display: grid; grid-template-columns: 1.05fr 1fr; gap: clamp(32px,5vw,72px); align-items: center; padding-block: clamp(40px,6vw,84px); }
.hero__eyebrow { margin-bottom: 22px; }
.hero h1 { margin-bottom: 22px; }
.hero h1 em { color: var(--color-primary-hover); }
.hero__lead { max-width: 440px; margin-bottom: 30px; }
.hero__cta { display: flex; gap: 14px; flex-wrap: wrap; align-items: center; }
.hero__trust { display: flex; gap: 22px; flex-wrap: wrap; margin-top: 30px; padding-top: 26px; border-top: 1px solid var(--color-border); }
.hero__trust-item { display: flex; flex-direction: column; gap: 2px; }
.hero__trust-item b { font-size: 17px; }
.hero__trust-item span { font-size: 12.5px; color: var(--color-text-muted); }
.hero__visual { position: relative; }
.hero__photo { width: 100%; aspect-ratio: 4/5; border-radius: var(--radius-xl); box-shadow: var(--shadow-xl); object-fit: cover; }
.hero__panel { position: absolute; inset: -22px -22px auto auto; width: 64%; height: 70%; background: var(--color-secondary-light); border-radius: var(--radius-xl); z-index: -1; }
.hero__panel2 { position: absolute; left: -26px; bottom: -26px; width: 120px; height: 120px; border-radius: 50%; background: var(--color-accent-light); z-index: -1; }
.hero__float {
  position: absolute; left: -28px; bottom: 34px; background: var(--color-white); border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg); padding: 14px 16px; display: flex; align-items: center; gap: 12px; max-width: 250px;
  border: 1px solid var(--color-border);
}
.hero__float .ic { width: 42px; height: 42px; border-radius: 12px; background: var(--color-accent-light); color: var(--color-accent-dark); display: grid; place-items: center; flex-shrink: 0; }
.hero__float .ic svg { width: 22px; height: 22px; }
.hero__float b { font-size: 14px; display: block; }
.hero__float span { font-size: 12px; color: var(--color-text-muted); }

/* ─────────────────────────────────────────
   Grillas compartidas
───────────────────────────────────────── */
.grid-products { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
.grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }

/* Packs: composición asimétrica — 1 protagonista + 2 apilados */
.grid-packs { display: grid; grid-template-columns: 1.3fr 1fr; gap: 24px; }
.grid-packs .product-card:first-child { grid-row: 1 / span 2; }
.grid-packs .product-card:first-child .product-card__media { aspect-ratio: auto; flex: 1; min-height: 320px; }

/* ─────────────────────────────────────────
   Split editorial (historia / origen)
───────────────────────────────────────── */
.split { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(28px,5vw,68px); align-items: center; }
.split__media { position: relative; }
.split__media .ph { width: 100%; aspect-ratio: 5/4; border-radius: var(--radius-xl); box-shadow: var(--shadow-lg); object-fit: cover; }
.pillars { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 24px; }

/* ─────────────────────────────────────────
   Banda B2B / mayoristas
───────────────────────────────────────── */
.wholesale { position: relative; background: linear-gradient(120deg, var(--color-deep), var(--color-deep-soft)); color: #EAF1F5; border-radius: var(--radius-xl); overflow: hidden; padding: clamp(36px,5vw,64px); }
.wholesale__inner { position: relative; display: grid; grid-template-columns: 1.3fr 1fr; gap: 40px; align-items: center; z-index: 1; }
.wholesale h2 { color: #fff; }
.wholesale__deco { position: absolute; inset: auto -60px -80px auto; width: 320px; height: 320px; border-radius: 50%; background: radial-gradient(circle, rgba(238,172,92,.34), transparent 70%); }
.wholesale__list { display: grid; gap: 14px; }
.wholesale__list li { display: flex; gap: 12px; font-size: 15px; align-items: flex-start; }
.wholesale__list svg { width: 20px; height: 20px; color: var(--color-primary); flex-shrink: 0; margin-top: 1px; }
.wholesale__card { background: rgba(255,255,255,.07); border: 1px solid rgba(255,255,255,.16); border-radius: var(--radius-lg); padding: 26px; backdrop-filter: blur(4px); }

/* ─────────────────────────────────────────
   Cierre (CTA final) — azul marino profundo
───────────────────────────────────────── */
.closer { text-align: center; max-width: 620px; margin-inline: auto; }
.closer-deep { background: linear-gradient(180deg, var(--color-deep-soft), var(--color-deep)); }
.closer-deep .t-h1 { color: #fff; }

/* ─────────────────────────────────────────
   TIENDA · cabecera, chips, paginación
───────────────────────────────────────── */
.shop-header { display: flex; align-items: flex-end; justify-content: space-between; gap: 24px; flex-wrap: wrap; }
.shop-header__actions { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.chip--active { background: var(--color-text); color: #fff; border-color: var(--color-text); }
.shop-sort select { background: var(--color-white); border: 1.5px solid var(--color-border); border-radius: var(--radius-pill); padding: 9px 16px; font-size: 14px; color: var(--color-text); }
.shop-pagination .page-numbers { display: inline-flex; align-items: center; justify-content: center; min-width: 40px; height: 40px; padding: 0 8px; border-radius: 50%; font-weight: 600; font-size: 14.5px; color: var(--color-text); transition: var(--transition); }
.shop-pagination .page-numbers:hover { background: var(--color-neutral-light); }
.shop-pagination .page-numbers.current { background: var(--color-primary-hover); color: #fff; }

/* ─────────────────────────────────────────
   PRODUCTO · detalle
───────────────────────────────────────── */
.product-detail { display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: start; }
.trust-badge { display: inline-flex; align-items: center; gap: 7px; font-size: 13px; font-weight: 600; color: var(--color-accent-dark); }
.trust-badge svg { width: 16px; height: 16px; }

/* ─────────────────────────────────────────
   NOSOTROS · valores y proceso
───────────────────────────────────────── */
.tag { display: inline-flex; align-items: center; font-size: 13px; font-weight: 600; color: var(--color-primary-hover); background: var(--color-primary-light); padding: 6px 14px; border-radius: var(--radius-pill); }
.value-card { background: var(--color-white); border: 1px solid var(--color-border); border-radius: var(--radius-lg); padding: 28px 24px; transition: var(--transition); }
.value-card:hover { box-shadow: var(--shadow-md); transform: translateY(-3px); }
.value-card__ic { width: 48px; height: 48px; border-radius: 14px; background: var(--color-accent-light); color: var(--color-accent-dark); display: grid; place-items: center; margin-bottom: 16px; }
.value-card__ic svg { width: 24px; height: 24px; }
.value-card__title { font-size: 17px; margin-bottom: 8px; font-weight: 700; font-family: var(--sans); }
.value-card__desc { font-size: 13.5px; color: var(--color-text-muted); line-height: 1.55; }
.process-list { display: flex; flex-direction: column; gap: 28px; counter-reset: step; padding: 0; }
.process-step { display: flex; gap: 22px; align-items: flex-start; }
.process-step__num { font-family: var(--serif); font-size: 28px; color: var(--color-primary-hover); line-height: 1.1; flex-shrink: 0; min-width: 48px; }
.process-step strong { font-size: 16.5px; }

/* ─────────────────────────────────────────
   Contenido genérico (page.php / entradas)
───────────────────────────────────────── */
.prose { line-height: 1.75; }
.prose p { margin-bottom: 1.1em; }
.prose h2 { font-family: var(--sans); font-weight: 700; font-size: clamp(22px,2.6vw,30px); margin: 1.6em 0 .6em; }
.prose h3 { font-size: 19px; font-weight: 700; margin: 1.4em 0 .5em; }
.prose ul { list-style: disc; padding-left: 1.4em; margin-bottom: 1.1em; }
.prose ol { list-style: decimal; padding-left: 1.4em; margin-bottom: 1.1em; }
.prose li { margin-bottom: .4em; }
.prose img { border-radius: var(--radius-lg); }
.prose a { color: var(--color-primary-hover); font-weight: 500; text-decoration: underline; }

/* ─────────────────────────────────────────
   RESPONSIVE
───────────────────────────────────────── */
@media (max-width: 900px) {
  .hero__inner { grid-template-columns: 1fr; gap: 40px; }
  .hero__visual { max-width: 460px; margin-inline: auto; width: 100%; }
  .grid-products { grid-template-columns: repeat(2, 1fr); gap: 16px; }
  .grid-3, .grid-4 { grid-template-columns: 1fr; }
  .grid-packs { grid-template-columns: 1fr; }
  .grid-packs .product-card:first-child { grid-row: auto; }
  .grid-packs .product-card:first-child .product-card__media { aspect-ratio: 1/1; min-height: 0; }
  .split { grid-template-columns: 1fr; }
  .split.rev .split__media { order: -1; }
  .wholesale__inner { grid-template-columns: 1fr; }
  .product-detail { grid-template-columns: 1fr; gap: 36px; }
}
@media (max-width: 640px) {
  .grid-4 { grid-template-columns: 1fr; }
}
@media (max-width: 480px) {
  .hero__trust { gap: 16px; }
  .hero__float { left: 8px; }
  .grid-products { grid-template-columns: 1fr; }
}

/* ─── Selector de idioma (GTranslate) en el header ─── */
.header__lang { display: flex; align-items: center; margin-right: 4px; }
.header__lang select { border: 1.5px solid var(--color-border); border-radius: var(--radius-pill); padding: 7px 10px; font-size: 13px; font-weight: 500; color: var(--color-text); background: var(--color-white); cursor: pointer; }
.header__lang img { display: inline-block; vertical-align: middle; }
@media (max-width: 1000px){ .header__lang { display: none; } }

/* ─────────────────────────────────────────
   RECETA · formato tipo Thermomix
   Ingredientes (lista) → tarjeta · Preparación (lista numerada) → pasos
───────────────────────────────────────── */
.recipe-body h2 { font-family: var(--sans); font-weight: 700; font-size: 22px; margin: 1.8em 0 .7em; color: var(--color-primary-hover); }
.recipe-body h3 { font-size: 18px; margin: 1.4em 0 .5em; }

/* Lista de ingredientes → tarjeta con viñetas tipo punto */
.recipe-body ul { list-style: none; padding: 24px 26px; margin: 0 0 1.6em; background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-lg); display: grid; gap: 11px; }
.recipe-body ul li { position: relative; padding-left: 26px; line-height: 1.5; }
.recipe-body ul li::before { content: ""; position: absolute; left: 4px; top: 9px; width: 9px; height: 9px; border-radius: 50%; background: var(--color-primary); }

/* Lista numerada → pasos con número grande */
.recipe-body ol { list-style: none; counter-reset: paso; padding: 0; margin: 0 0 1.4em; display: grid; gap: 20px; }
.recipe-body ol li { counter-increment: paso; position: relative; padding: 4px 0 0 56px; min-height: 40px; line-height: 1.6; }
.recipe-body ol li::before { content: counter(paso); position: absolute; left: 0; top: 0; width: 40px; height: 40px; border-radius: 50%; background: var(--color-primary-hover); color: #fff; display: grid; place-items: center; font-family: var(--serif); font-size: 20px; }

/* ─────────────────────────────────────────
   PUNTOS DE VENTA · mapa decorativo
───────────────────────────────────────── */
.pv-layout { display: grid; grid-template-columns: 1fr 1.2fr; gap: clamp(24px,4vw,48px); align-items: start; }
.map { position: relative; width: 100%; aspect-ratio: 4/5; border-radius: var(--radius-xl); overflow: hidden; box-shadow: var(--shadow-md); border: 1px solid var(--color-border); background: linear-gradient(160deg, var(--color-secondary-light), var(--color-surface)); }
.map__pin { position: absolute; width: 28px; height: 28px; border-radius: 50% 50% 50% 0; background: var(--color-primary); transform: rotate(-45deg); box-shadow: var(--shadow-md); }
.map__pin::after { content: ""; position: absolute; inset: 8px; background: #fff; border-radius: 50%; }
.map__label { position: absolute; left: 50%; bottom: 18px; transform: translateX(-50%); background: #fff; border: 1px solid var(--color-border); border-radius: var(--radius-pill); padding: 8px 16px; font-size: 13px; font-weight: 600; box-shadow: var(--shadow-sm); display: flex; gap: 8px; align-items: center; white-space: nowrap; }
.map__label svg { width: 15px; height: 15px; color: var(--color-primary-hover); }
@media (max-width: 900px) { .pv-layout { grid-template-columns: 1fr; } .map { aspect-ratio: 3/2; order: -1; } }

/* ─────────────────────────────────────────
   PUNTOS DE VENTA · lista de tiendas por zona
───────────────────────────────────────── */
.pv-stores { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 32px 40px; align-items: start; }
.pv-zone__t { display: flex; align-items: center; gap: 8px; font-family: var(--sans); font-weight: 700; font-size: 17px; color: var(--color-primary-hover); margin-bottom: 10px; }
.pv-zone__t svg { width: 18px; height: 18px; }
.pv-city { margin: 0 0 12px; }
.pv-city__name { font-weight: 700; font-size: 14px; color: var(--color-text); text-transform: uppercase; letter-spacing: .03em; }
.pv-city__list { list-style: none; padding: 4px 0 0; margin: 0; display: grid; gap: 4px; }
.pv-city__list li { position: relative; padding-left: 18px; font-size: 14.5px; color: var(--color-text-muted); }
.pv-city__list li::before { content: ""; position: absolute; left: 2px; top: 8px; width: 6px; height: 6px; border-radius: 50%; background: var(--color-primary); }

.map__pin { z-index: 2; }

.map__chile { position: absolute; inset: 0; width: 100%; height: 100%; }
.map__chile path { fill: var(--color-secondary-dark); opacity: .9; }
.map__chile circle { fill: var(--color-secondary-dark); opacity: .8; }
.map__pin { z-index: 2; }
