/* ==========================================================================
   SUAVES BOUTIQUE — Sistema de diseño del frontend
   Derivado de la maqueta aprobada (pixel-faithful).
   ========================================================================== */

:root{
  /* Paleta */
  --rojo:        #C8202A;
  --rojo-osc:    #A4151D;
  --rojo-claro:  #E0413B;
  --crema:       #FBF6EF;   /* fondo de página */
  --crema-2:     #F7EEE2;   /* secciones / barra de beneficios */
  --crema-3:     #F3E8D8;
  --cafe:        #3A281F;   /* títulos oscuros ("DE COCO") */
  --tinta:       #2B2018;   /* texto cuerpo */
  --tan:         #C79A5B;   /* script dorado ("El auténtico") */
  --gris:        #8A7F76;   /* texto secundario */
  --linea:       #ECE2D5;   /* bordes suaves */
  --blanco:      #FFFFFF;

  /* Tipografía */
  --font-display: 'Anton', 'Oswald', Impact, sans-serif;  /* títulos heavy */
  --font-script:  'Pacifico', 'Brush Script MT', cursive; /* script dorado */
  --font-body:    'Poppins', system-ui, -apple-system, 'Segoe UI', sans-serif;

  /* Escala */
  --container: 1200px;
  --radio:     14px;
  --radio-sm:  9px;
  --sombra:    0 6px 24px rgba(58,40,31,.08);
  --sombra-sm: 0 2px 10px rgba(58,40,31,.06);
}

/* Reset ------------------------------------------------------------------- */
*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0; font-family:var(--font-body); color:var(--tinta);
  background:var(--crema); line-height:1.55; font-size:15px;
  -webkit-font-smoothing:antialiased;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; }
ul{ margin:0; padding:0; list-style:none; }

.container{ width:100%; max-width:var(--container); margin:0 auto; padding:0 24px; }
.sr-only{ position:absolute; width:1px; height:1px; overflow:hidden; clip:rect(0,0,0,0); }

/* Ornamento de títulos de sección (las flechitas rojas de la maqueta) ------ */
.section-title{
  display:flex; align-items:center; justify-content:center; gap:14px;
  font-family:var(--font-display); letter-spacing:.5px;
  font-size:26px; color:var(--cafe); text-transform:uppercase;
  margin:0 0 28px; text-align:center;
}
.section-title::before,
.section-title::after{
  content:"➳"; color:var(--rojo); font-size:18px; transform:scaleY(.9);
}
.section-title::before{ transform:scaleX(-1) scaleY(.9); }

/* Botones ----------------------------------------------------------------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:9px;
  font-weight:600; font-size:13px; letter-spacing:.6px; text-transform:uppercase;
  padding:13px 24px; border-radius:8px; border:2px solid transparent;
  transition:transform .15s ease, background .15s ease, color .15s ease;
}
.btn:active{ transform:translateY(1px); }
.btn-rojo{ background:var(--rojo); color:#fff; }
.btn-rojo:hover{ background:var(--rojo-osc); }
.btn-outline{ background:transparent; color:var(--cafe); border-color:#d9cbb8; }
.btn-outline:hover{ border-color:var(--rojo); color:var(--rojo); }
.btn-blanco{ background:#fff; color:var(--rojo); }

/* ==========================================================================
   BARRA SUPERIOR
   ========================================================================== */
.topbar{ background:var(--crema-2); font-size:12.5px; color:var(--tinta); border-bottom:1px solid var(--linea); }
.topbar .container{ display:flex; align-items:center; gap:30px; min-height:48px; }
.topbar .tb-items{ display:flex; align-items:center; gap:34px; flex:1; }
.topbar .tb-item{ display:flex; align-items:center; gap:10px; }
.topbar .tb-item svg{ color:var(--rojo); flex:none; }
.topbar .tb-item strong{ display:block; font-weight:600; color:var(--cafe); }
.topbar .tb-item span{ color:var(--gris); font-size:11.5px; }
.topbar .tb-actions{ display:flex; align-items:center; gap:20px; }
.topbar .tb-actions a{ position:relative; color:var(--cafe); }
.cart-badge{
  position:absolute; top:-8px; right:-9px; background:var(--rojo); color:#fff;
  font-size:10px; font-weight:700; min-width:17px; height:17px; border-radius:50%;
  display:flex; align-items:center; justify-content:center; padding:0 4px;
}

/* ==========================================================================
   HEADER / NAV
   ========================================================================== */
.site-header{ background:#fff; }
.site-header .container{ display:flex; align-items:center; gap:40px; min-height:84px; }
.logo{ display:flex; align-items:center; flex:none; }
.logo img{ height:62px; }
.logo-text{ font-family:var(--font-display); color:var(--rojo); font-size:30px; line-height:.85; }
.logo-text small{ display:block; font-family:var(--font-body); font-weight:600; font-size:10px; letter-spacing:6px; color:var(--cafe); }

.main-nav ul{ display:flex; align-items:center; gap:34px; }
.main-nav a{
  font-size:13px; font-weight:600; letter-spacing:.7px; text-transform:uppercase;
  color:var(--cafe); padding:8px 0; position:relative;
}
.main-nav a.active{ color:var(--rojo); }
.main-nav a.active::after{
  content:""; position:absolute; left:0; right:0; bottom:-2px; height:2px; background:var(--rojo);
}
.main-nav a:hover{ color:var(--rojo); }
.nav-caret{ font-size:9px; margin-left:3px; }

.nav-toggle{ display:none; background:none; border:none; color:var(--cafe); }

/* ==========================================================================
   HERO / SLIDER
   ========================================================================== */
.hero{ padding:18px 0 0; }
.hero-slide{
  position:relative; background:linear-gradient(180deg,#FBF3E8 0%, #F7EAD8 100%);
  border-radius:var(--radio); overflow:hidden;
  display:grid; grid-template-columns:1fr 1fr; align-items:center; gap:10px;
  min-height:430px;
}
.hero-copy{ padding:48px 10px 48px 48px; z-index:2; }
.hero-eyebrow{ font-family:var(--font-script); color:var(--tan); font-size:30px; line-height:1; margin-bottom:2px; }
.hero-title{
  font-family:var(--font-display); line-height:.86; text-transform:uppercase; margin:4px 0 6px;
}
.hero-title .l1{ display:block; color:var(--rojo); font-size:74px; }
.hero-title .l2{ display:block; color:var(--cafe); font-size:74px; }
.hero-ribbon{
  display:inline-block; background:var(--rojo); color:#fff; font-family:var(--font-script);
  font-size:24px; padding:4px 26px 6px; border-radius:4px; position:relative; margin:6px 0 18px;
  box-shadow:var(--sombra-sm);
}
.hero-ribbon::before, .hero-ribbon::after{
  content:""; position:absolute; top:0; bottom:0; width:12px; background:var(--rojo-osc);
}
.hero-ribbon::before{ left:-12px; clip-path:polygon(0 50%,100% 0,100% 100%); }
.hero-ribbon::after{ right:-12px; clip-path:polygon(0 0,100% 50%,0 100%); }
.hero-text{ color:var(--tinta); max-width:330px; margin:0 0 24px; font-size:14.5px; }
.hero-ctas{ display:flex; gap:14px; flex-wrap:wrap; }

.hero-media{ position:relative; align-self:stretch; }
.hero-media img{ width:100%; height:100%; object-fit:cover; }
.hero-stamp{
  position:absolute; left:6%; bottom:14%; width:92px; height:92px; border-radius:50%;
  background:#fff; border:2px solid var(--cafe); display:flex; align-items:center; justify-content:center;
  font-size:10px; font-weight:700; color:var(--cafe); text-align:center; box-shadow:var(--sombra-sm);
}
.hero-dots{ position:absolute; left:48px; bottom:22px; display:flex; gap:7px; z-index:3; }
.hero-dots span{ width:9px; height:9px; border-radius:50%; background:#d8c4ab; }
.hero-dots span.active{ background:var(--rojo); }
.hero-arrow{
  position:absolute; top:50%; transform:translateY(-50%); z-index:4; background:rgba(255,255,255,.7);
  border:none; width:30px; height:30px; border-radius:50%; color:var(--cafe); font-size:16px;
}
.hero-arrow.prev{ left:8px; } .hero-arrow.next{ right:8px; }

/* ==========================================================================
   BARRA DE BENEFICIOS (5 features)
   ========================================================================== */
.beneficios{
  background:var(--crema-2); border-radius:var(--radio); margin:28px auto 0;
  padding:26px 30px; display:grid; grid-template-columns:repeat(5,1fr); gap:24px;
}
.beneficio{ display:flex; gap:13px; align-items:flex-start; position:relative; }
.beneficio:not(:last-child)::after{
  content:""; position:absolute; right:-12px; top:6px; bottom:6px; width:1px; background:#e3d6c4;
}
.beneficio .ico{ color:var(--rojo); flex:none; margin-top:2px; }
.beneficio strong{ display:block; font-size:12px; font-weight:700; color:var(--cafe); text-transform:uppercase; letter-spacing:.3px; line-height:1.3; }
.beneficio p{ margin:4px 0 0; font-size:12px; color:var(--gris); }

/* ==========================================================================
   CATEGORÍAS (círculos)
   ========================================================================== */
.section{ padding:54px 0; }
.cats{ display:grid; grid-template-columns:repeat(6,1fr); gap:18px; }
.cat{ text-align:center; }
.cat-circle{
  width:120px; height:120px; border-radius:50%; margin:0 auto 14px; position:relative;
  border:3px solid var(--rojo); overflow:hidden; box-shadow:var(--sombra-sm);
}
.cat-circle img{ width:100%; height:100%; object-fit:cover; }
.cat-pill{
  position:absolute; left:50%; bottom:-2px; transform:translateX(-50%);
  background:var(--rojo); color:#fff; font-size:10.5px; font-weight:600;
  padding:4px 12px; border-radius:20px; white-space:nowrap;
}
.cat-name{ font-weight:600; color:var(--cafe); font-size:14px; }

/* ==========================================================================
   PRODUCTOS (grid + card)
   ========================================================================== */
.section-head{ display:flex; align-items:center; justify-content:center; position:relative; margin-bottom:28px; }
.section-head .section-title{ margin:0; }
.section-head .ver-todos{ position:absolute; right:0; }

.productos{ display:grid; grid-template-columns:repeat(6,1fr); gap:14px; }
.pcard{ background:#fff; border:1px solid var(--linea); border-radius:var(--radio-sm); overflow:hidden; transition:box-shadow .18s ease, transform .18s ease; position:relative; }
.pcard:hover{ box-shadow:var(--sombra); transform:translateY(-3px); }
.pcard-img{ aspect-ratio:1/1; background:var(--crema-3); }
.pcard-img img{ width:100%; height:100%; object-fit:cover; }
.pcard-body{ padding:13px 13px 15px; }
.pcard-name{ font-size:13.5px; font-weight:600; color:var(--cafe); line-height:1.3; min-height:36px; }
.pcard-price{ color:var(--rojo); font-weight:700; font-size:15px; margin:7px 0 0; }
.pcard-price .desde{ display:block; font-size:10px; color:var(--gris); font-weight:500; letter-spacing:.5px; }
.pcard-foot{ display:flex; align-items:center; gap:8px; margin-top:12px; }

.qty{ display:flex; align-items:center; border:1px solid var(--linea); border-radius:7px; overflow:hidden; }
.qty button{ width:30px; height:34px; border:none; background:#fff; color:var(--cafe); font-size:16px; }
.qty button:hover{ background:var(--crema-2); }
.qty input{ width:34px; height:34px; border:none; text-align:center; font-size:14px; color:var(--cafe); -moz-appearance:textfield; }
.qty input::-webkit-outer-spin-button,.qty input::-webkit-inner-spin-button{ -webkit-appearance:none; }

.btn-cart{ flex:none; width:42px; height:36px; background:var(--rojo); color:#fff; border:none; border-radius:7px; display:flex; align-items:center; justify-content:center; }
.btn-cart:hover{ background:var(--rojo-osc); }
.btn-opciones{ flex:1; }

.badge-vendido{ position:absolute; left:9px; top:9px; background:var(--rojo); color:#fff; font-size:9.5px; font-weight:700; letter-spacing:.4px; padding:4px 9px; border-radius:5px; text-transform:uppercase; z-index:2; }

/* ==========================================================================
   BANNER WHATSAPP
   ========================================================================== */
.wa-banner{
  background:var(--rojo); border-radius:var(--radio); color:#fff; overflow:hidden;
  display:grid; grid-template-columns:1.1fr 1fr; align-items:center; margin-top:8px;
}
.wa-copy{ padding:38px 40px; }
.wa-copy h3{ display:flex; align-items:center; gap:12px; font-family:var(--font-display); font-size:24px; letter-spacing:.4px; margin:0 0 12px; }
.wa-copy p{ color:#ffe3e0; max-width:330px; margin:0 0 22px; font-size:14px; }
.wa-media{ height:100%; min-height:230px; background:#7a1015; }
.wa-media img{ width:100%; height:100%; object-fit:cover; }

/* ==========================================================================
   RAÍCES (storytelling con 4 íconos)
   ========================================================================== */
.raices{ background:var(--crema-2); border-radius:var(--radio); padding:40px 44px; display:grid; grid-template-columns:1.1fr 2fr; gap:30px; align-items:center; }
.raices-copy h3{ font-family:var(--font-display); color:var(--cafe); font-size:23px; line-height:1.05; margin:0 0 12px; text-transform:uppercase; }
.raices-copy p{ font-size:13.5px; color:var(--gris); margin:0 0 18px; }
.raices-items{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; text-align:center; }
.raices-item .ico{ color:var(--rojo); margin-bottom:10px; }
.raices-item strong{ font-size:12.5px; color:var(--cafe); text-transform:uppercase; letter-spacing:.3px; }

/* ==========================================================================
   STRIP DE GARANTÍAS (5 íconos sobre cinta crema con borde ondulado)
   ========================================================================== */
.garantias{ background:var(--crema-2); border-radius:var(--radio); padding:20px 30px; display:grid; grid-template-columns:repeat(5,1fr); gap:18px; margin-top:8px; }
.garantia{ display:flex; align-items:center; gap:10px; font-size:12.5px; color:var(--cafe); }
.garantia .ico{ color:var(--rojo); flex:none; }

/* ==========================================================================
   FOOTER
   ========================================================================== */
.site-footer{ background:var(--rojo); color:#fff; margin-top:54px; position:relative; }
.site-footer::before{
  content:""; position:absolute; top:-14px; left:0; right:0; height:14px;
  background:radial-gradient(circle at 10px -3px, var(--rojo) 8px, transparent 9px) repeat-x;
  background-size:20px 14px;
}
.footer-top{ display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr 1.3fr; gap:30px; padding:48px 0 36px; }
.footer-brand img{ height:58px; margin-bottom:14px; }
.footer-brand p{ font-size:12.5px; color:#ffd9d4; max-width:240px; margin:0 0 16px; }
.footer-social{ display:flex; gap:10px; }
.footer-social a{ width:32px; height:32px; border-radius:50%; border:1px solid rgba(255,255,255,.4); display:flex; align-items:center; justify-content:center; }
.footer-social a:hover{ background:#fff; color:var(--rojo); }
.footer-col h4{ font-size:12px; letter-spacing:1px; text-transform:uppercase; margin:0 0 16px; color:#fff; }
.footer-col ul li{ margin-bottom:9px; }
.footer-col ul a{ font-size:13px; color:#ffd9d4; }
.footer-col ul a:hover{ color:#fff; }
.footer-help h4{ font-size:13px; text-transform:uppercase; margin:0 0 16px; }
.footer-help li{ display:flex; align-items:center; gap:10px; font-size:13px; color:#ffe5e1; margin-bottom:12px; }
.footer-bottom{ border-top:1px solid rgba(255,255,255,.18); padding:16px 0; display:flex; align-items:center; justify-content:space-between; font-size:12px; color:#ffd9d4; }
.footer-pay{ display:flex; align-items:center; gap:8px; }
.footer-pay span{ background:#fff; color:var(--rojo); font-weight:700; font-size:10px; padding:3px 7px; border-radius:4px; }

/* ==========================================================================
   WHATSAPP FLOTANTE
   ========================================================================== */
.wa-float{ position:fixed; right:22px; bottom:22px; width:56px; height:56px; border-radius:50%; background:#25D366; color:#fff; display:flex; align-items:center; justify-content:center; box-shadow:0 6px 20px rgba(0,0,0,.25); z-index:50; }
.wa-float:hover{ transform:scale(1.05); }

/* ==========================================================================
   COOKIE BAR
   ========================================================================== */
.cookie-bar{ position:fixed; left:0; right:0; bottom:0; background:var(--cafe); color:#fff; padding:14px 22px; display:flex; align-items:center; gap:18px; justify-content:center; flex-wrap:wrap; z-index:60; font-size:13px; }
.cookie-bar.hidden{ display:none; }

/* ==========================================================================
   RESPONSIVE  (móvil — basado en la maqueta móvil)
   ========================================================================== */
@media (max-width:900px){
  .topbar{ display:none; }
  .site-header .container{ gap:14px; min-height:64px; }
  .nav-toggle{ display:block; order:-1; }
  .main-nav{ display:none; }
  .logo img{ height:46px; }

  .hero-slide{ grid-template-columns:1fr; min-height:auto; }
  .hero-media{ order:-1; height:300px; }
  .hero-copy{ padding:26px 24px 32px; text-align:left; }
  .hero-title .l1, .hero-title .l2{ font-size:52px; }
  .hero-eyebrow{ font-size:24px; }
  .hero-ctas .btn{ flex:1; }

  .beneficios{ grid-template-columns:1fr 1fr; gap:20px 16px; padding:22px; }
  .beneficio:not(:last-child)::after{ display:none; }

  .cats{ grid-template-columns:repeat(3,1fr); gap:22px 10px; }
  .cat-circle{ width:96px; height:96px; }

  .productos{ grid-template-columns:repeat(2,1fr); }
  .section-head .ver-todos{ position:static; }
  .section-head{ flex-wrap:wrap; gap:12px; }

  .wa-banner{ grid-template-columns:1fr; }
  .wa-media{ min-height:180px; order:-1; }

  .raices{ grid-template-columns:1fr; }
  .raices-items{ grid-template-columns:repeat(2,1fr); gap:24px 14px; }

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

  .footer-top{ grid-template-columns:1fr 1fr; gap:26px; }
  .footer-bottom{ flex-direction:column; gap:10px; text-align:center; }
}

@media (max-width:560px){
  .productos{ grid-template-columns:1fr 1fr; }
  .hero-title .l1, .hero-title .l2{ font-size:44px; }
  .footer-top{ grid-template-columns:1fr; }
}

/* Accesibilidad */
:focus-visible{ outline:2px solid var(--rojo); outline-offset:2px; }
@media (prefers-reduced-motion:reduce){ *{ animation:none!important; transition:none!important; scroll-behavior:auto; } }

/* ==========================================================================
   FASE 2 — Catálogo, ficha, carrito, checkout
   ========================================================================== */
.muted{ color:var(--gris); }
.container.narrow{ max-width:860px; }
.breadcrumb{ font-size:12.5px; color:var(--gris); padding:18px 0 6px; }
.breadcrumb a{ color:var(--gris); } .breadcrumb a:hover{ color:var(--rojo); }
.breadcrumb span{ margin:0 6px; } .breadcrumb strong{ color:var(--cafe); }
.aviso{ border-radius:var(--radio-sm); padding:12px 16px; font-size:14px; margin:14px 0; }
.aviso.ok{ background:#E6F6EC; color:#1c7a47; border:1px solid #bfe6cd; }
.aviso.err{ background:#FDECEC; color:#A4151D; border:1px solid #f3c9c9; }
.vacio-estado{ text-align:center; padding:60px 20px; color:var(--gris); }
.vacio-estado svg{ color:var(--linea); margin-bottom:10px; }
.vacio-estado h3{ color:var(--cafe); font-size:20px; margin:6px 0; }
.vacio-estado p{ margin:0 0 18px; }

/* Tarjeta: corazón de favorito */
.pcard-fav{ position:absolute; top:9px; right:9px; z-index:3; width:34px; height:34px; border-radius:50%;
  background:rgba(255,255,255,.92); border:1px solid var(--linea); color:var(--gris);
  display:flex; align-items:center; justify-content:center; box-shadow:var(--sombra-sm); }
.pcard-fav:hover{ color:var(--rojo); }
.pcard-fav.on{ color:var(--rojo); }

/* ---- Catálogo ---- */
.shop{ padding-bottom:50px; }
.shop-head{ display:flex; align-items:baseline; gap:14px; margin:6px 0 18px; }
.shop-head .section-title{ margin:0; }
.shop-layout{ display:grid; grid-template-columns:248px 1fr; gap:28px; align-items:start; }
.shop-aside{ position:sticky; top:16px; }
.shop-search{ display:flex; border:1px solid var(--linea); border-radius:9px; overflow:hidden; background:#fff; margin-bottom:18px; }
.shop-search input{ flex:1; border:none; padding:11px 14px; font:inherit; font-size:14px; outline:none; }
.shop-search button{ border:none; background:var(--rojo); color:#fff; padding:0 14px; }
.aside-block{ background:#fff; border:1px solid var(--linea); border-radius:var(--radio); padding:16px; margin-bottom:16px; }
.aside-block h3{ font-size:14px; color:var(--cafe); margin:0 0 10px; text-transform:uppercase; letter-spacing:.5px; }
.aside-cats li a{ display:flex; justify-content:space-between; padding:8px 10px; border-radius:7px; color:var(--tinta); font-size:14px; }
.aside-cats li a span{ color:var(--gris); font-size:12px; }
.aside-cats li a:hover{ background:var(--crema-2); color:var(--rojo); }
.aside-cats li a.active{ background:var(--rojo); color:#fff; } .aside-cats li a.active span{ color:#ffd9d4; }
.aside-help{ background:var(--crema-2); }
.aside-help p{ font-size:13px; color:var(--gris); margin:0 0 12px; }
.aside-help .btn{ width:100%; }
.shop-toolbar{ display:flex; align-items:center; justify-content:space-between; margin-bottom:16px; gap:12px; flex-wrap:wrap; }
.shop-toolbar .orden{ font-size:13px; color:var(--gris); }
.shop-toolbar select{ font:inherit; font-size:13px; padding:8px 10px; border:1px solid var(--linea); border-radius:8px; background:#fff; color:var(--tinta); }
.shop-grid{ grid-template-columns:repeat(3,1fr); }
.paginador{ display:flex; gap:6px; justify-content:center; margin-top:30px; flex-wrap:wrap; }
.paginador a{ min-width:38px; height:38px; padding:0 10px; display:flex; align-items:center; justify-content:center;
  border:1px solid var(--linea); border-radius:8px; color:var(--cafe); font-size:14px; background:#fff; }
.paginador a:hover{ border-color:var(--rojo); color:var(--rojo); }
.paginador a.active{ background:var(--rojo); color:#fff; border-color:var(--rojo); }

/* ---- Ficha de producto ---- */
.pdp{ padding-bottom:50px; }
.pdp-grid{ display:grid; grid-template-columns:1fr 1fr; gap:40px; margin-top:10px; }
.pdp-main{ border:1px solid var(--linea); border-radius:var(--radio); overflow:hidden; background:var(--crema-3); aspect-ratio:1/1; }
.pdp-main img{ width:100%; height:100%; object-fit:cover; }
.pdp-thumbs{ display:flex; gap:10px; margin-top:12px; flex-wrap:wrap; }
.pdp-thumb{ width:70px; height:70px; border:2px solid var(--linea); border-radius:9px; overflow:hidden; background:#fff; padding:0; }
.pdp-thumb img{ width:100%; height:100%; object-fit:cover; }
.pdp-thumb.active{ border-color:var(--rojo); }
.pdp-cat{ font-size:12px; text-transform:uppercase; letter-spacing:1px; color:var(--tan); font-weight:600; }
.pdp-title{ font-family:var(--font-display); font-size:34px; color:var(--cafe); line-height:1.05; margin:6px 0 10px; text-transform:uppercase; }
.pdp-rating{ display:flex; align-items:center; gap:8px; font-size:13px; margin-bottom:10px; }
.stars{ color:#E8A93B; letter-spacing:1px; }
.pdp-rating a{ color:var(--gris); }
.pdp-price{ display:flex; align-items:baseline; gap:10px; margin:6px 0 14px; }
.pdp-price #pdpPrice{ font-size:30px; font-weight:700; color:var(--rojo); }
.pdp-desde{ font-size:13px; color:var(--gris); }
.pdp-antes{ font-size:16px; color:var(--gris); text-decoration:line-through; }
.pdp-resumen{ color:var(--tinta); font-size:14.5px; margin:0 0 18px; }
.pdp-label{ display:block; font-size:13px; font-weight:600; color:var(--cafe); margin-bottom:8px; }
.var-pills{ display:flex; gap:8px; flex-wrap:wrap; margin-bottom:18px; }
.var-pill{ border:1.5px solid var(--linea); background:#fff; border-radius:9px; padding:9px 16px; font:inherit; font-size:14px; color:var(--cafe); }
.var-pill:hover{ border-color:var(--rojo); }
.var-pill.active{ border-color:var(--rojo); background:var(--rojo); color:#fff; }
.var-pill.agotado{ opacity:.4; text-decoration:line-through; cursor:not-allowed; }
.pdp-stock{ margin-bottom:16px; font-size:13.5px; }
.en-stock{ color:#1c7a47; font-weight:600; }
.agotado-txt{ color:var(--rojo); font-weight:600; }
.pdp-actions{ display:flex; align-items:center; gap:12px; margin-bottom:16px; flex-wrap:wrap; }
.pdp-actions .qty button{ width:40px; height:46px; font-size:18px; }
.pdp-actions .qty input{ width:46px; text-align:center; border:none; font:inherit; font-size:15px; }
.pdp-add{ flex:1; min-width:200px; height:46px; }
.pdp-fav{ width:46px; height:46px; border:1.5px solid var(--linea); border-radius:9px; background:#fff; color:var(--gris); display:flex; align-items:center; justify-content:center; }
.pdp-fav:hover, .pdp-fav.on{ color:var(--rojo); border-color:var(--rojo); }
.pdp-whats{ display:inline-flex; align-items:center; gap:8px; color:#1c7a47; font-weight:600; font-size:14px; margin-bottom:18px; }
.pdp-trust{ border-top:1px solid var(--linea); padding-top:16px; display:grid; gap:8px; font-size:13.5px; color:var(--gris); }
.pdp-detalle{ display:grid; grid-template-columns:1.5fr 1fr; gap:40px; margin-top:46px; align-items:start; }
.pdp-detalle .section-title{ justify-content:flex-start; font-size:22px; }
.pdp-detalle .section-title::before{ content:none; }
.rich{ font-size:14.5px; line-height:1.7; color:var(--tinta); }
.rich h3{ color:var(--cafe); margin:18px 0 6px; font-size:16px; }
.rich ul{ padding-left:20px; list-style:disc; } .rich li{ margin:4px 0; }
.pdp-sku{ margin-top:14px; font-size:12.5px; }
.resena-resumen{ display:flex; align-items:center; gap:16px; margin-bottom:16px; }
.resena-resumen .big{ font-size:40px; font-weight:700; color:var(--cafe); }
.resena-lista{ display:grid; gap:14px; margin-bottom:24px; }
.resena-lista li{ border:1px solid var(--linea); border-radius:var(--radio-sm); padding:13px 15px; }
.resena-lista .r-top{ display:flex; justify-content:space-between; align-items:center; margin-bottom:5px; }
.resena-lista p{ margin:4px 0; font-size:14px; }
.resena-lista time{ font-size:12px; }
.resena-form{ background:var(--crema-2); border-radius:var(--radio); padding:18px; }
.resena-form h3{ margin:0 0 12px; color:var(--cafe); font-size:16px; }
.estrellas-input{ display:inline-flex; flex-direction:row-reverse; gap:3px; margin-bottom:12px; }
.estrellas-input input{ display:none; }
.estrellas-input label{ font-size:26px; color:var(--linea); cursor:pointer; }
.estrellas-input input:checked ~ label,
.estrellas-input label:hover, .estrellas-input label:hover ~ label{ color:#E8A93B; }
.campo{ margin-bottom:12px; }
.campo label{ display:block; font-size:13px; font-weight:600; color:var(--cafe); margin-bottom:6px; }
.campo input, .campo textarea{ width:100%; border:1px solid var(--linea); border-radius:9px; padding:11px 13px; font:inherit; font-size:14px; background:#fff; }
.campo input:focus, .campo textarea:focus{ outline:none; border-color:var(--rojo); }
.pdp-rel{ margin-top:50px; }

/* ---- Carrito ---- */
.carrito{ padding-bottom:50px; }
.carrito-layout{ display:grid; grid-template-columns:1fr 360px; gap:28px; align-items:start; }
.carrito-items{ display:grid; gap:12px; }
.citem{ display:grid; grid-template-columns:84px 1fr auto auto auto; gap:14px; align-items:center;
  background:#fff; border:1px solid var(--linea); border-radius:var(--radio); padding:12px; }
.citem-img{ width:84px; height:84px; border-radius:9px; overflow:hidden; background:var(--crema-3); }
.citem-img img{ width:100%; height:100%; object-fit:cover; }
.citem-info h3{ font-size:14.5px; color:var(--cafe); margin:0 0 3px; }
.citem-info .muted{ font-size:12px; display:block; }
.citem-precio{ font-size:13px; color:var(--gris); }
.citem-sub{ font-weight:700; color:var(--rojo); min-width:80px; text-align:right; }
.citem-del{ border:none; background:none; color:var(--gris); padding:6px; }
.citem-del:hover{ color:var(--rojo); }
.carrito-acciones{ margin-top:14px; }
.carrito-resumen{ background:#fff; border:1px solid var(--linea); border-radius:var(--radio); padding:20px; position:sticky; top:16px; }
.carrito-resumen h3, .checkout-resumen h3{ font-size:16px; color:var(--cafe); margin:0 0 14px; }
.cupon-form{ border-bottom:1px solid var(--linea); padding-bottom:16px; margin-bottom:16px; }
.cupon-form label{ font-size:13px; font-weight:600; color:var(--cafe); display:block; margin-bottom:7px; }
.cupon-row{ display:flex; gap:8px; }
.cupon-row input{ flex:1; border:1px solid var(--linea); border-radius:8px; padding:10px 12px; font:inherit; font-size:14px; }
.cupon-row .btn{ padding:10px 16px; }
.cupon-msg{ font-size:12.5px; color:var(--rojo); margin:8px 0 0; }
.resumen-lineas{ display:grid; gap:9px; margin-bottom:12px; }
.resumen-lineas li{ display:flex; justify-content:space-between; font-size:14px; color:var(--tinta); }
.resumen-lineas li.desc b{ color:#1c7a47; }
.resumen-total{ display:flex; justify-content:space-between; align-items:center; border-top:1px solid var(--linea); padding-top:14px; margin-top:4px; font-size:16px; }
.resumen-total b{ font-size:22px; color:var(--rojo); }
.envio-hint{ font-size:12.5px; color:var(--gris); background:var(--crema-2); border-radius:8px; padding:9px 12px; margin:12px 0 0; }
.btn-checkout{ width:100%; margin-top:16px; height:48px; font-size:15px; }
.pago-seguro{ text-align:center; font-size:12px; color:var(--gris); margin:12px 0 0; }

/* ---- Checkout ---- */
.checkout{ padding-bottom:50px; }
.checkout-layout{ display:grid; grid-template-columns:1fr 360px; gap:28px; align-items:start; }
.ck-block{ background:#fff; border:1px solid var(--linea); border-radius:var(--radio); padding:20px; margin-bottom:16px; }
.ck-block h3{ font-size:16px; color:var(--cafe); margin:0 0 16px; }
.ck-row{ margin-bottom:0; }
.ck-row.dos{ display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.ck-row.tres{ display:grid; grid-template-columns:1fr 1fr 1fr; gap:14px; }
.ck-nota{ font-size:13px; margin:-6px 0 14px; }
.pago-opcion{ display:flex; align-items:flex-start; gap:11px; border:1.5px solid var(--linea); border-radius:9px; padding:13px 15px; margin-bottom:10px; cursor:pointer; }
.pago-opcion:hover{ border-color:var(--rojo); }
.pago-opcion input{ margin-top:3px; accent-color:var(--rojo); }
.pago-opcion b{ display:block; font-size:14px; color:var(--cafe); }
.pago-opcion small{ color:var(--gris); font-size:12.5px; }
.checkout-resumen{ background:#fff; border:1px solid var(--linea); border-radius:var(--radio); padding:20px; position:sticky; top:16px; }
.ck-items{ display:grid; gap:11px; border-bottom:1px solid var(--linea); padding-bottom:14px; margin-bottom:14px; }
.ck-items li{ display:flex; align-items:center; gap:11px; font-size:13.5px; }
.ck-items img{ width:46px; height:46px; border-radius:8px; object-fit:cover; background:var(--crema-3); }
.ck-items li > div{ flex:1; display:flex; flex-direction:column; }
.ck-items .n{ color:var(--cafe); }
.ck-volver{ display:block; text-align:center; margin-top:12px; font-size:13px; color:var(--gris); }
.ck-volver:hover{ color:var(--rojo); }
textarea{ font:inherit; width:100%; border:1px solid var(--linea); border-radius:9px; padding:11px 13px; font-size:14px; }

/* ---- Gracias ---- */
.gracias{ padding:30px 0 60px; }
.gracias-hero{ text-align:center; max-width:560px; margin:0 auto 30px; }
.check-ok{ width:72px; height:72px; border-radius:50%; background:#E6F6EC; color:#2FA968; display:flex; align-items:center; justify-content:center; margin:0 auto 14px; }
.gracias-hero p{ margin:4px 0; }
.gracias-grid{ display:grid; grid-template-columns:1.4fr 1fr; gap:24px; align-items:start; max-width:920px; margin:0 auto; }
.gr-detalle, .gr-pago{ background:#fff; border:1px solid var(--linea); border-radius:var(--radio); padding:22px; }
.gr-detalle h3, .gr-pago h3{ font-size:16px; color:var(--cafe); margin:0 0 14px; }
.datos-pago{ background:var(--crema-2); border-radius:9px; padding:14px; margin:12px 0 16px; font-size:13.5px; }
.datos-pago .muted{ font-size:12px; }

/* ---- Páginas de contenido ---- */
.pagina{ padding-bottom:50px; }
.pagina-cuerpo{ margin-top:14px; }
.raices-mini{ display:grid; grid-template-columns:repeat(3,1fr); gap:14px; margin-top:26px; }
.raices-mini div{ background:var(--crema-2); border-radius:var(--radio); padding:18px; text-align:center; }
.raices-mini b{ display:block; font-family:var(--font-display); color:var(--rojo); font-size:24px; }
.raices-mini span{ font-size:13px; color:var(--gris); }
.contacto-grid{ display:grid; grid-template-columns:1fr 1fr; gap:28px; margin-top:18px; }
.contacto-datos{ background:var(--crema-2); border-radius:var(--radio); padding:22px; }
.contacto-datos h3{ color:var(--cafe); margin:0 0 12px; }
.contacto-datos p{ margin:8px 0; }
.contacto-datos .btn{ margin-top:12px; }
.contacto-form{ background:#fff; border:1px solid var(--linea); border-radius:var(--radio); padding:22px; }
.contacto-form h3{ color:var(--cafe); margin:0 0 14px; }
.contacto-form .btn{ width:100%; }

/* ---- Responsive Fase 2 ---- */
@media (max-width:900px){
  .shop-layout{ grid-template-columns:1fr; }
  .shop-aside{ position:static; }
  .aside-help{ display:none; }
  .shop-grid{ grid-template-columns:repeat(2,1fr); }
  .pdp-grid{ grid-template-columns:1fr; gap:22px; }
  .pdp-detalle{ grid-template-columns:1fr; gap:30px; }
  .carrito-layout, .checkout-layout, .gracias-grid{ grid-template-columns:1fr; }
  .carrito-resumen, .checkout-resumen{ position:static; }
  .contacto-grid{ grid-template-columns:1fr; }
}
@media (max-width:560px){
  .shop-grid{ grid-template-columns:repeat(2,1fr); gap:10px; }
  .pdp-title{ font-size:27px; }
  .citem{ grid-template-columns:64px 1fr auto; grid-template-areas:"img info del" "img qty sub"; row-gap:10px; }
  .citem-img{ grid-area:img; width:64px; height:64px; }
  .citem-info{ grid-area:info; } .citem-qty{ grid-area:qty; } .citem-sub{ grid-area:sub; } .citem-del{ grid-area:del; justify-self:end; }
  .ck-row.tres{ grid-template-columns:1fr 1fr; }
  .raices-mini{ grid-template-columns:1fr; }
}

/* ---- Fase 3: opción de envío con precio en el checkout ---- */
.pago-opcion .ck-precio{ margin-left:auto; font-weight:700; color:var(--rojo); font-style:normal; font-size:14px; }
.pago-opcion span{ flex:1; }

/* ---- Fase 6: formulario de boletín en el pie ---- */
.footer-news{ display:flex; gap:6px; margin-top:8px; }
.footer-news input{ flex:1; min-width:0; height:40px; border:none; border-radius:8px; padding:0 12px; font-size:13px; }
.footer-news button{ background:var(--rojo); color:#fff; border:none; border-radius:8px; padding:0 14px; font-weight:600; font-size:13px; cursor:pointer; white-space:nowrap; }
.footer-news button:hover{ background:var(--rojo-osc); }
