/*
Theme Name: Peptigene
Theme URI: https://peptigene.co
Author: Peptigene
Author URI: https://peptigene.co
Description: Tema a medida para Peptigene · suplementos deportivos. Replica el diseño original (Fraunces + Outfit, paleta verde olivo) e integra WooCommerce para administrar el catálogo desde el panel.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: peptigene
WC requires at least: 6.0
WC tested up to: 9.0
*/

/* ============================================================
   VARIABLES (paleta y tokens del sitio original)
   ============================================================ */
:root {
  --cream-50: #ffffff;
  --cream-100: #f0fdf8;
  --cream-200: #d9fbeb;

  --olive-50: #e6fcf1;
  --olive-100: #bef7dc;
  --olive-200: #84f0c1;
  --olive-300: #43e6a2;
  --olive-400: #34d399;
  --olive-500: #10b981;
  --olive-600: #059669;
  --olive-700: #047857;
  --olive-800: #065f46;
  --olive-900: #064e3b;
  --olive-950: #022c22;

  --ink: #064e3b;
  --radius: 1rem;
  --radius-lg: 1.5rem;
  --maxw: 1280px;
}

/* ============================================================
   BASE
   ============================================================ */
*,
*::before,
*::after { box-sizing: border-box; }

html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }

body {
  margin: 0;
  background: var(--cream-50);
  color: var(--ink);
  font-family: "Outfit", system-ui, -apple-system, sans-serif;
  font-feature-settings: "ss01", "cv11";
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  line-height: 1.6;
}

img { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }

::selection { background: var(--olive-500); color: #fff; }

::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-track { background: var(--cream-50); }
::-webkit-scrollbar-thumb { background: var(--olive-500); border-radius: 4px; }
::-webkit-scrollbar-thumb:hover { background: var(--olive-900); }

h1, h2, h3, h4 { margin: 0; }
p { margin: 0; }

.pg-container {
  max-width: var(--maxw);
  margin: 0 auto;
  padding-left: 1.5rem;
  padding-right: 1.5rem;
}
@media (min-width: 1024px) {
  .pg-container { padding-left: 2rem; padding-right: 2rem; }
}

/* ============================================================
   TIPOGRAFÍA
   ============================================================ */
.font-display { font-family: "Fraunces", Georgia, serif; }
.font-mono { font-family: "JetBrains Mono", monospace; }

.display-xl {
  font-family: "Fraunces", Georgia, serif;
  font-weight: 500;
  font-variation-settings: "opsz" 144, "SOFT" 30;
  letter-spacing: -0.04em;
  line-height: 0.95;
}
.display-xl .italic { font-style: italic; font-weight: 400; color: var(--olive-700); }

.eyebrow {
  font-family: "JetBrains Mono", monospace;
  font-size: 0.75rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--olive-600);
  display: inline-block;
}

.lead { font-size: 1.125rem; color: rgba(6, 95, 70, 0.8); line-height: 1.7; }

/* ============================================================
   BOTONES
   ============================================================ */
.pg-btn {
  display: inline-block;
  border-radius: 999px;
  font-size: 0.875rem;
  font-weight: 500;
  padding: 0.65rem 1.25rem;
  cursor: pointer;
  border: 1px solid transparent;
  transition: background-color .25s ease, color .25s ease, border-color .25s ease, transform .25s ease;
  line-height: 1.2;
  text-align: center;
}
.pg-btn--primary { background: var(--olive-900); color: var(--cream-50); }
.pg-btn--primary:hover { background: var(--olive-800); }
.pg-btn--lg { padding: 1rem 2rem; }
.pg-btn--outline { border-color: var(--olive-900); color: var(--olive-900); background: transparent; }
.pg-btn--outline:hover { background: var(--olive-900); color: var(--cream-50); }
.pg-btn--light { background: var(--cream-50); color: var(--olive-900); }
.pg-btn--light:hover { background: var(--olive-200); }

.link-under { position: relative; display: inline-block; }
.link-under::after {
  content: ""; position: absolute; left: 0; bottom: -2px; width: 100%; height: 1px;
  background: currentColor; transform: scaleX(0); transform-origin: right; transition: transform .4s ease;
}
.link-under:hover::after { transform: scaleX(1); transform-origin: left; }

/* ============================================================
   HEADER
   ============================================================ */
.pg-header {
  position: sticky; top: 0; z-index: 50;
  background: rgba(255, 255, 255, 0.85);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--olive-200);
}
.pg-header__row {
  display: flex; align-items: center; justify-content: space-between;
  height: 64px;
}
@media (min-width: 768px) { .pg-header__row { height: 80px; } }

.pg-logo { display: flex; align-items: center; gap: .5rem; color: var(--olive-800); }
.pg-logo svg { height: 32px; width: auto; }
.pg-logo__word { font-family: "Fraunces", Georgia, serif; font-size: 1.25rem; font-weight: 500; letter-spacing: -0.02em; }

.pg-nav { display: none; align-items: center; gap: 2rem; font-size: .875rem; }
@media (min-width: 768px) { .pg-nav { display: flex; } }
.pg-nav a { color: var(--olive-800); }
.pg-nav a:hover { color: var(--olive-600); }
.pg-nav a.current-menu-item, .pg-nav .current-menu-item > a { color: var(--olive-600); }
.pg-nav ul, .pg-nav .pg-menu { display: flex; align-items: center; gap: 2rem; list-style: none; margin: 0; padding: 0; }
.pg-nav li { list-style: none; margin: 0; }

.pg-header__actions { display: flex; align-items: center; gap: .75rem; }
.pg-cart-btn {
  position: relative; display: inline-flex; align-items: center; gap: .5rem;
  padding: .5rem 1rem; background: var(--olive-800); color: var(--cream-50);
  border-radius: 999px; font-size: .875rem; transition: background-color .25s ease;
}
.pg-cart-btn:hover { background: var(--olive-700); }
.pg-cart-btn svg { width: 16px; height: 16px; }
.pg-cart-count {
  position: absolute; top: -4px; right: -4px; background: var(--olive-400); color: var(--olive-950);
  font-size: .7rem; font-weight: 700; width: 20px; height: 20px; border-radius: 999px;
  display: flex; align-items: center; justify-content: center;
}
.pg-burger { display: inline-flex; background: none; border: 0; color: var(--olive-800); padding: .5rem; cursor: pointer; }
@media (min-width: 768px) { .pg-burger { display: none; } }
.pg-burger svg { width: 24px; height: 24px; }

.pg-mobile-nav { display: none; flex-direction: column; gap: .25rem; padding-bottom: 1rem; }
.pg-mobile-nav.is-open { display: flex; }
.pg-mobile-nav ul, .pg-mobile-nav .pg-menu { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: .25rem; }
.pg-mobile-nav li { list-style: none; margin: 0; }
.pg-mobile-nav a { padding: .5rem 0; color: var(--olive-800); font-size: .9rem; }

/* ============================================================
   HERO
   ============================================================ */
.pg-hero { position: relative; overflow: hidden; background: var(--cream-50); }
.pg-hero__inner { padding-top: 4rem; padding-bottom: 6rem; }
@media (min-width: 768px) { .pg-hero__inner { padding-top: 5rem; padding-bottom: 8rem; } }
.pg-hero__grid { display: grid; gap: 3rem; align-items: center; }
@media (min-width: 1024px) { .pg-hero__grid { grid-template-columns: 1fr 1fr; } }

.pg-hero h1 { color: var(--olive-900); margin-bottom: 2rem; font-size: clamp(3rem, 8vw, 6rem); }
.pg-hero .pg-hero__lead { max-width: 36rem; margin-bottom: 2.5rem; font-size: 1.25rem; color: rgba(6,95,70,.8); }
.pg-hero__cta { display: flex; flex-wrap: wrap; gap: 1rem; }

.pg-stats { margin-top: 3rem; display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; max-width: 28rem; }
.pg-stats__num { font-family: "Fraunces", Georgia, serif; font-size: 1.875rem; color: var(--olive-900); }
.pg-stats__label { font-size: .75rem; color: rgba(4,120,87,.7); line-height: 1.2; }

.pg-hero__media { position: relative; }
.pg-hero__photo {
  position: relative; aspect-ratio: 4/5; border-radius: 1.5rem; overflow: hidden;
  background: linear-gradient(160deg, var(--olive-300), var(--olive-700) 55%, var(--olive-900));
}
.pg-hero__photo img { width: 100%; height: 100%; object-fit: cover; }
.pg-hero__photo::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(6,78,59,.30), transparent 55%);
}
.pg-badge-float {
  position: absolute; background: var(--cream-50); padding: .75rem 1.25rem; border-radius: 1rem;
  box-shadow: 0 20px 40px -16px rgba(6,78,59,.35); border: 1px solid var(--olive-100); max-width: 200px;
}
.pg-badge-float--tr { top: -1rem; right: -1rem; }
@media (min-width: 768px) { .pg-badge-float--tr { right: 1rem; } }
.pg-badge-float--bl { bottom: -1rem; left: -1rem; background: var(--olive-900); color: var(--cream-50); border: 0; }
@media (min-width: 768px) { .pg-badge-float--bl { left: 1rem; } }
.pg-badge-float p { line-height: 1.2; }
.pg-badge-float .pg-badge-title { font-family: "Fraunces", Georgia, serif; font-size: .875rem; }
.pg-badge-rings { position: absolute; z-index: -1; top: 50%; right: -5rem; width: 20rem; height: 20rem; color: var(--olive-200); opacity: .4; }

/* ============================================================
   MARQUEE
   ============================================================ */
.pg-marquee { background: var(--olive-900); color: var(--cream-50); padding: 1.5rem 0; overflow: hidden; }
.pg-marquee__track { display: flex; gap: 3rem; white-space: nowrap; width: max-content; animation: pg-marquee 30s linear infinite; }
.pg-marquee__group { display: flex; gap: 3rem; align-items: center; }
.pg-marquee .eyebrow { color: var(--cream-50); }
.pg-marquee .pg-diamond { color: var(--olive-400); }
@keyframes pg-marquee { 0% { transform: translateX(0); } 100% { transform: translateX(-50%); } }

/* ============================================================
   SECCIONES GENÉRICAS
   ============================================================ */
.pg-section { padding: 6rem 0; }
.pg-section--cream { background: var(--cream-50); }
.pg-section--olive { background: var(--olive-50); }

.pg-section-head { display: grid; gap: 3rem; margin-bottom: 4rem; }
@media (min-width: 1024px) { .pg-section-head { grid-template-columns: 1fr 1fr; } }
.pg-section-head h2 { color: var(--olive-900); font-size: clamp(2.25rem, 5vw, 3rem); }
.pg-section-head .lead { align-self: end; max-width: 32rem; }

.pg-heading-row { display: flex; flex-direction: column; gap: 1rem; margin-bottom: 3rem; }
@media (min-width: 768px) { .pg-heading-row { flex-direction: row; align-items: flex-end; justify-content: space-between; } }
.pg-heading-row h2 { color: var(--olive-900); font-size: clamp(2.25rem, 5vw, 3rem); }

/* CARDS de pasos / filosofía */
.pg-cards { display: grid; gap: 1.5rem; }
@media (min-width: 768px) { .pg-cards--3 { grid-template-columns: repeat(3, 1fr); } }
.pg-card {
  background: var(--olive-50); padding: 2rem; border-radius: 1rem; border: 1px solid var(--olive-100);
  transition: border-color .3s ease;
}
.pg-card--cream { background: var(--cream-50); }
.pg-card:hover { border-color: var(--olive-300); }
.pg-card__top { display: flex; align-items: center; justify-content: space-between; margin-bottom: 1.5rem; }
.pg-card__num { font-family: "Fraunces", Georgia, serif; font-size: 3rem; color: var(--olive-300); line-height: 1; }
.pg-card__icon { width: 32px; height: 32px; color: var(--olive-700); }
.pg-card h3 { font-family: "Fraunces", Georgia, serif; font-size: 1.5rem; color: var(--olive-900); margin-bottom: .75rem; }
.pg-card p { color: rgba(6,95,70,.8); }

/* FILOSOFÍA */
.pg-philo-grid { display: grid; gap: 3rem; align-items: center; margin-bottom: 3rem; }
@media (min-width: 1024px) { .pg-philo-grid { grid-template-columns: 7fr 5fr; } }
.pg-philo-grid h2 { color: var(--olive-900); font-size: clamp(2.25rem, 6vw, 3.75rem); margin-bottom: 1.5rem; }
.pg-philo-img {
  position: relative; aspect-ratio: 1/1; border-radius: 1.5rem; overflow: hidden;
  background: linear-gradient(160deg, var(--olive-200), var(--olive-600) 60%, var(--olive-900));
}
.pg-philo-img img { width: 100%; height: 100%; object-fit: cover; }

/* TESTIMONIOS */
.pg-quote { background: var(--cream-50); border: 1px solid var(--olive-100); border-radius: 1rem; padding: 2rem; display: flex; flex-direction: column; }
.pg-quote svg { width: 32px; height: 32px; color: var(--olive-300); margin-bottom: 1.5rem; }
.pg-quote blockquote { margin: 0 0 1.5rem; color: var(--olive-800); line-height: 1.7; flex: 1; }
.pg-quote figcaption .pg-quote-name { font-family: "Fraunces", Georgia, serif; font-size: 1.125rem; color: var(--olive-900); }

/* CTA */
.pg-cta { background: var(--olive-900); color: var(--cream-50); border-radius: 1.5rem; overflow: hidden; display: grid; }
@media (min-width: 1024px) { .pg-cta { grid-template-columns: 1fr 1fr; } }
.pg-cta__media { position: relative; aspect-ratio: 4/3; background: linear-gradient(135deg, var(--olive-600), var(--olive-900)); }
.pg-cta__media img { width: 100%; height: 100%; object-fit: cover; }
.pg-cta__body { padding: 2rem; display: flex; flex-direction: column; justify-content: center; }
@media (min-width: 768px) { .pg-cta__body { padding: 4rem; } }
.pg-cta__body .eyebrow { color: var(--olive-300); }
.pg-cta__body h2 { font-family: "Fraunces", Georgia, serif; font-size: clamp(2.25rem,5vw,3rem); margin: 1rem 0 1.5rem; letter-spacing: -.03em; line-height: 1; }
.pg-cta__body h2 .italic { font-style: italic; font-weight: 400; color: var(--olive-300); }
.pg-cta__body p { color: rgba(240,253,248,.8); margin-bottom: 2rem; max-width: 32rem; }

/* ============================================================
   FOOTER
   ============================================================ */
.pg-footer { background: var(--olive-900); color: var(--cream-100); margin-top: 6rem; }
.pg-footer__inner { padding: 4rem 0; }
.pg-footer__grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 2.5rem; }
@media (min-width: 768px) { .pg-footer__grid { grid-template-columns: repeat(4, 1fr); } }
.pg-footer__brand { grid-column: span 2; }
@media (min-width: 768px) { .pg-footer__brand { grid-column: span 1; } }
.pg-footer .pg-logo { color: var(--cream-50); }
.pg-footer__brand p { margin-top: 1rem; font-size: .875rem; color: rgba(240,253,248,.7); max-width: 18rem; }
.pg-footer h4 { margin-bottom: 1rem; color: var(--olive-300); }
.pg-footer ul { list-style: none; margin: 0; padding: 0; }
.pg-footer li { margin-bottom: .5rem; font-size: .875rem; }
.pg-footer a:hover { color: var(--olive-300); }
.pg-footer__contact li { color: rgba(240,253,248,.8); }
.pg-social { margin-top: 1rem; display: flex; gap: .75rem; }
.pg-social a { width: 36px; height: 36px; border-radius: 999px; border: 1px solid var(--olive-700); display: flex; align-items: center; justify-content: center; }
.pg-social a:hover { background: var(--olive-800); }
.pg-social svg { width: 16px; height: 16px; }
.pg-footer__bottom { margin-top: 3rem; padding-top: 2rem; border-top: 1px solid var(--olive-800); display: flex; flex-direction: column; gap: 1rem; font-size: .75rem; color: rgba(240,253,248,.6); }
@media (min-width: 768px) { .pg-footer__bottom { flex-direction: row; justify-content: space-between; } }

/* WhatsApp flotante */
.pg-whatsapp {
  position: fixed; bottom: 1.5rem; right: 1.5rem; z-index: 60;
  width: 56px; height: 56px; border-radius: 999px; background: #25d366; color: #fff;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 12px 28px -8px rgba(0,0,0,.4); transition: transform .2s ease;
}
.pg-whatsapp:hover { transform: scale(1.06); }
.pg-whatsapp svg { width: 28px; height: 28px; }

/* ============================================================
   PÁGINAS GENÉRICAS (page.php / index.php)
   ============================================================ */
.pg-page { padding: 4rem 0 2rem; }
.pg-page__header { margin-bottom: 2.5rem; }
.pg-page__header h1 { color: var(--olive-900); font-size: clamp(2.5rem, 6vw, 4.5rem); }
.pg-prose { max-width: 48rem; color: var(--olive-800); }
.pg-prose h2 { font-family: "Fraunces", Georgia, serif; color: var(--olive-900); font-size: 1.75rem; margin: 2rem 0 1rem; }
.pg-prose h3 { font-family: "Fraunces", Georgia, serif; color: var(--olive-900); font-size: 1.35rem; margin: 1.5rem 0 .75rem; }
.pg-prose p { margin-bottom: 1rem; line-height: 1.8; }
.pg-prose a { color: var(--olive-700); text-decoration: underline; }
.pg-prose ul { padding-left: 1.25rem; }

/* ============================================================
   WOOCOMMERCE
   ============================================================ */
.woocommerce, .woocommerce-page { color: var(--ink); }

/* contenedor general de tienda */
.pg-shop-wrap { max-width: var(--maxw); margin: 0 auto; padding: 4rem 1.5rem; }
@media (min-width: 1024px) { .pg-shop-wrap { padding-left: 2rem; padding-right: 2rem; } }

/* encabezado hero de la tienda */
.pg-shop-hero { margin-bottom: 3rem; }
.pg-shop-hero h1, .woocommerce-products-header__title {
  font-family: "Fraunces", Georgia, serif !important; font-weight: 500; color: var(--olive-900);
  font-size: clamp(2.75rem, 7vw, 4.5rem); letter-spacing: -.04em; line-height: .95; margin: 0;
}

/* barra de categorías (pills) */
.pg-cat-bar { display: flex; flex-wrap: wrap; gap: .5rem; margin: 1.5rem 0 2rem; }
.pg-cat-bar a {
  padding: .5rem 1rem; border-radius: 999px; font-size: .85rem; color: var(--olive-800);
  background: var(--olive-50); border: 1px solid var(--olive-100); transition: all .2s ease;
}
.pg-cat-bar a:hover { background: var(--olive-100); }
.pg-cat-bar a.is-active { background: var(--olive-900); color: var(--cream-50); border-color: var(--olive-900); }

/* result count + ordering */
.woocommerce .woocommerce-result-count { color: rgba(4,120,87,.75); font-size: .9rem; }
.woocommerce .woocommerce-ordering select {
  padding: .5rem .75rem; border: 1px solid var(--olive-200); border-radius: .6rem;
  background: var(--cream-50); color: var(--olive-800); font-family: inherit; font-size: .85rem;
}

/* GRID de productos */
.woocommerce ul.products, .woocommerce-page ul.products {
  display: grid !important; gap: 1.5rem; margin: 0; padding: 0; list-style: none;
  grid-template-columns: 1fr;
}
@media (min-width: 640px) { .woocommerce ul.products { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .woocommerce ul.products.columns-3 { grid-template-columns: repeat(3, 1fr); }
  .woocommerce ul.products.columns-4 { grid-template-columns: repeat(4, 1fr); } }

.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product {
  width: auto !important; margin: 0 !important; float: none !important; padding: 0 !important;
  background: var(--cream-50); border: 1px solid var(--olive-100); border-radius: 1rem; overflow: hidden;
  display: flex; flex-direction: column; position: relative;
  transition: transform .4s cubic-bezier(.2,.8,.2,1), box-shadow .4s ease;
}
.woocommerce ul.products li.product:hover { transform: translateY(-4px); box-shadow: 0 24px 48px -16px rgba(6,78,59,.18); }

.woocommerce ul.products li.product a.woocommerce-LoopProduct-link { display: block; position: relative; }
.woocommerce ul.products li.product .pg-loop-thumb,
.woocommerce ul.products li.product img {
  width: 100%; aspect-ratio: 1/1; object-fit: cover; margin: 0; background: var(--cream-100);
}
.woocommerce ul.products li.product .pg-loop-body { padding: 1.25rem; display: flex; flex-direction: column; flex: 1; }
.woocommerce ul.products li.product .pg-loop-cat { margin-bottom: .25rem; }
.woocommerce ul.products li.product .woocommerce-loop-product__title {
  font-family: "Fraunces", Georgia, serif !important; font-size: 1.125rem !important; line-height: 1.2;
  color: var(--olive-900); padding: 0 !important; margin: 0 0 .5rem !important; font-weight: 500;
}
.woocommerce ul.products li.product .pg-loop-tagline { font-size: .875rem; color: rgba(4,120,87,.8); margin-bottom: 1rem; }
.woocommerce ul.products li.product .price {
  color: var(--olive-900) !important; font-family: "Fraunces", Georgia, serif; font-size: 1.25rem !important;
  font-weight: 600; margin: 0;
}
.woocommerce ul.products li.product .price del { color: rgba(5,150,105,.6); font-size: .8rem; font-weight: 400; display: block; }
.woocommerce ul.products li.product .price ins { text-decoration: none; }

.woocommerce ul.products li.product .pg-loop-foot { margin-top: auto; display: flex; align-items: flex-end; justify-content: space-between; gap: .75rem; }

/* Botón "Agregar" */
.woocommerce a.button, .woocommerce button.button,
.woocommerce ul.products li.product .button, .woocommerce #respond input#submit,
.woocommerce input.button, .woocommerce .button.alt {
  background: var(--olive-800) !important; color: var(--cream-50) !important;
  border-radius: 999px !important; font-size: .8rem !important; font-weight: 500; padding: .55rem 1.1rem !important;
  border: 0 !important; text-transform: none; transition: background-color .25s ease; line-height: 1.2;
}
.woocommerce a.button:hover, .woocommerce button.button:hover, .woocommerce .button:hover, .woocommerce .button.alt:hover {
  background: var(--olive-700) !important; color: var(--cream-50) !important;
}
.woocommerce a.button.loading::after { color: var(--cream-50); }

/* etiqueta "Oferta" */
.woocommerce span.onsale {
  background: var(--olive-400); color: var(--olive-950); font-family: "JetBrains Mono", monospace;
  text-transform: uppercase; letter-spacing: .15em; font-size: .6rem; font-weight: 700; min-height: auto;
  min-width: auto; padding: .35rem .65rem; border-radius: 999px; top: .75rem; right: .75rem; left: auto; margin: 0;
}

/* badge categoría en loop */
.pg-loop-cat .eyebrow { font-size: .65rem; }

/* ---- PÁGINA DE PRODUCTO ---- */
.single-product div.product { display: grid; gap: 3rem; }
@media (min-width: 1024px) { .single-product div.product { grid-template-columns: 1fr 1fr; gap: 5rem; } }
.single-product div.product .woocommerce-product-gallery { margin: 0; }
.single-product div.product .woocommerce-product-gallery img { border-radius: 1.5rem; }
.single-product div.product .product_title {
  font-family: "Fraunces", Georgia, serif; color: var(--olive-900); font-size: clamp(2rem, 5vw, 3rem);
  letter-spacing: -.03em; line-height: 1; margin-bottom: 1rem;
}
.single-product div.product p.price, .single-product div.product span.price {
  color: var(--olive-900) !important; font-family: "Fraunces", Georgia, serif; font-size: 1.875rem !important;
  font-weight: 600; margin-bottom: 1.5rem;
}
.single-product div.product p.price del { color: rgba(5,150,105,.6); font-size: 1.125rem; font-weight: 400; }
.single-product .woocommerce-product-details__short-description { font-size: 1.125rem; color: var(--olive-700); margin-bottom: 1.5rem; }
.single-product .quantity input.qty {
  border: 1px solid var(--olive-200); border-radius: .6rem; padding: .55rem; color: var(--olive-900);
}
.single-product .cart .button { padding: .85rem 2rem !important; font-size: .9rem !important; }
.woocommerce-breadcrumb { font-size: .75rem; color: rgba(4,120,87,.7); margin-bottom: 2rem; }
.woocommerce-breadcrumb a:hover { color: var(--olive-900); }

/* pestañas / descripción */
.woocommerce-tabs { grid-column: 1 / -1; margin-top: 2rem; }
.woocommerce-tabs ul.tabs { padding: 0; }
.woocommerce-tabs ul.tabs li { background: var(--olive-50); border-color: var(--olive-100); border-radius: .6rem .6rem 0 0; }
.woocommerce-tabs ul.tabs li.active { background: var(--cream-50); }
.woocommerce-tabs .panel h2 { font-family: "Fraunces", Georgia, serif; color: var(--olive-900); }
.related.products, .upsells.products { grid-column: 1 / -1; }
.related.products > h2, .upsells.products > h2 { font-family: "Fraunces", Georgia, serif; color: var(--olive-900); font-size: 2rem; margin-bottom: 1.5rem; }

/* mensajes, notices */
.woocommerce-message, .woocommerce-info, .woocommerce-error {
  border-top-color: var(--olive-500); border-radius: .6rem; background: var(--olive-50);
}
.woocommerce-message::before, .woocommerce-info::before { color: var(--olive-600); }

/* carrito y checkout */
.woocommerce table.shop_table { border-radius: .8rem; border-color: var(--olive-100); }
.woocommerce table.shop_table th { color: var(--olive-900); }
.woocommerce-cart .cart-collaterals .cart_totals h2,
.woocommerce-checkout #order_review_heading, .woocommerce form .form-row label {
  color: var(--olive-900);
}
.woocommerce .cart-collaterals .cart_totals, .woocommerce-checkout #order_review { border-radius: .8rem; }
#add_payment_method #payment, .woocommerce-cart #payment, .woocommerce-checkout #payment { background: var(--olive-50); border-radius: .8rem; }

/* form inputs generales */
.woocommerce form .form-row input.input-text, .woocommerce form .form-row textarea, .woocommerce .select2-container .select2-selection {
  border: 1px solid var(--olive-200); border-radius: .6rem; padding: .65rem;
}

/* paginación */
.woocommerce nav.woocommerce-pagination ul { border-color: var(--olive-100); border-radius: .6rem; overflow: hidden; }
.woocommerce nav.woocommerce-pagination ul li a, .woocommerce nav.woocommerce-pagination ul li span { color: var(--olive-800); }
.woocommerce nav.woocommerce-pagination ul li span.current { background: var(--olive-900); color: var(--cream-50); }

/* placeholder de imagen de producto */
.woocommerce ul.products li.product img[src*="placeholder"], img.woocommerce-placeholder { background: var(--olive-50); }

/* utilidades */
.pg-mt-1 { margin-top: .5rem; }
.pg-center { text-align: center; }
.pg-hide { display: none; }
