﻿/* =============================================
   ESTILOS GLOBALES
   ============================================= */

@font-face {
    font-family: 'Lato';
    font-style: normal;
    font-weight: 400;
    src: url('../fuentes/lato-v25-latin-regular.woff2') format('woff2');
}

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

body {
    font-family: 'Lato', sans-serif;
    color: #2d2d2d;
    background-color: #fff;
    font-size: 16px;
    line-height: 1.6;
}

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

ul {
    list-style: none;
}

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

/* =============================================
   CABECERA Y NAVEGACION
   ============================================= */

.cabecera {
    padding: 16px 56px;
    background-color: #fff;
    border-bottom: 1px solid #f0f0f0;
    display: flex;
    align-items: center;
    justify-content: space-between;
    position: relative;
    z-index: 1000;
}

.logo {
    width: 60px;
    height: 60px;
}

.logo img {
    width: 100%;
    height: 100%;
    border-radius: 8px;
}

.nav-container {
    width: auto;
    margin-left: 64px;
}

.menu {
    display: flex;
    list-style: none;
    margin: 0;
    padding: 0;
}

.menu li {
    margin-right: 32px;
}

.menu a {
    display: block;
    line-height: 60px;
    font-size: 15px;
    font-weight: 600;
    color: #2d2d2d;
    text-decoration: none;
}

.menu a.activo {
    color: #20b2aa;
    border-bottom: 2px solid #20b2aa;
}

.botones-cabecera {
    display: flex;
    align-items: center;
}

.btn-regalar {
    background-color: #fff0f0;
    color: #e05050;
    border: none;
    border-radius: 24px;
    padding: 8px 16px;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    margin-right: 16px;
}

.btn-icono {
    background: none;
    border: none;
    cursor: pointer;
    font-size: 20px;
    color: #444;
    position: relative;
    margin-left: 8px;
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.globo-carrito {
    position: absolute;
    top: -8px;
    right: -8px;
    background-color: #20b2aa;
    color: #fff;
    font-size: 10px;
    font-weight: 700;
    border-radius: 50%;
    width: 16px;
    height: 16px;
    line-height: 16px;
    text-align: center;
}

/* =============================================
   PAGINA PRINCIPAL - INDEX
   ============================================= */

.portada {
    padding: 64px 72px;
    background-color: #f8faf8;
    min-height: 600px;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.hero-contenido {
    width: 50%;
    max-width: 520px;
}

.etiqueta-top {
    display: inline-block;
    background-color: #e8f5f0;
    color: #2d6a4f;
    font-size: 13px;
    font-weight: 600;
    padding: 8px 16px;
    border-radius: 20px;
    margin-bottom: 24px;
}

.etiqueta-top::before {
    content: "●";
    color: #2d6a4f;
    margin-right: 8px;
}

.hero-contenido h1 {
    font-family: 'Playfair Display', serif;
    font-size: 52px;
    font-weight: 800;
    color: #1a1a1a;
    line-height: 1.15;
    margin-bottom: 20px;
}

.lema {
    font-size: 20px;
    font-style: italic;
    color: #b8860b;
    margin-bottom: 20px;
    font-family: 'Playfair Display', serif;
}

.descripcion {
    font-size: 15px;
    color: #555;
    margin-bottom: 32px;
    line-height: 1.7;
}

.botones-accion {
    margin-bottom: 32px;
    display: flex;
}

.btn-oro {
    display: inline-block;
    background-color: #b8860b;
    color: #fff;
    padding: 14px 28px;
    border-radius: 30px;
    font-size: 15px;
    font-weight: 700;
    border: none;
    cursor: pointer;
}

.btn-borde-oro {
    display: inline-block;
    background-color: transparent;
    color: #b8860b;
    padding: 13px 26px;
    border-radius: 30px;
    font-size: 15px;
    font-weight: 600;
    border: 2px solid #b8860b;
    cursor: pointer;
}

.btn-borde-verde {
    display: inline-block;
    background-color: transparent;
    color: #20b2aa;
    padding: 12px 24px;
    border-radius: 28px;
    font-size: 15px;
    font-weight: 600;
    border: 2px solid #20b2aa;
    cursor: pointer;
}

.sellos-seguridad {
    border-top: 1px solid #e0e0e0;
    padding-top: 20px;
    display: flex;
}

.sellos-seguridad span {
    font-size: 14px;
    color: #555;
    margin-right: 24px;
}

.icono-verde {
    color: #20b2aa;
    font-weight: 700;
}

.icono-rojo {
    color: #e05050;
}

.hero-imagen {
    width: 45%;
    max-width: 580px;
    position: relative;
}

.hero-imagen img {
    width: 100%;
    height: 480px;
    border-radius: 20px;
}

.etiqueta-eco {
    position: absolute;
    top: 20px;
    right: -8px;
    background-color: #3a7d44;
    color: #fff;
    border-radius: 12px;
    padding: 12px 16px;
    text-align: center;
    font-size: 13px;
    font-weight: 600;
    min-width: 112px;
}

.icono-hoja {
    font-size: 20px;
    margin-bottom: 4px;
    display: block;
}

.tarjeta-certificada {
    position: absolute;
    bottom: -20px;
    left: 32px;
    background-color: #fff;
    border-radius: 16px;
    padding: 18px 24px;
    box-shadow: 0 8px 30px rgba(0,0,0,0.1);
    min-width: 200px;
    display: flex;
    align-items: center;
}

.fondo-cert {
    float: left;
    width: 44px;
    height: 44px;
    background-color: #fff8e0;
    border-radius: 50%;
    text-align: center;
    line-height: 44px;
    font-size: 22px;
    color: #b8860b;
}

.info-cert {
    float: left;
    margin-left: 16px;
}

.porcentaje-destacado {
    font-size: 24px;
    font-weight: 800;
    color: #1a1a1a;
}

.texto-certificado {
    font-size: 12px;
    color: #666;
    margin-bottom: 4px;
}

.aclaracion-certificado {
    font-size: 11px;
    color: #888;
}

/* --- CARACTERISTICAS --- */

.ventajas {
    padding: 80px;
    background-color: #fff;
    text-align: center;
    border-top: 1px solid #f0f0f0;
}

.contenedor-ventajas {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    padding: 0 40px;
}

.caja-ventaja {
    width: 280px;
    margin: 20px 32px;
    text-align: center;
}

.caja-icono {
    width: 72px;
    height: 72px;
    border-radius: 50%;
    margin: 0 auto 24px auto;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 30px;
}

.fondo-verde,
.bg-verde {
    background-color: #e8f5f0;
    color: #2d6a4f;
}

.fondo-rosa,
.bg-rosa,
.fondo-susc-rosa {
    background-color: #fdecea;
    color: #e05050;
}

.fondo-oliva {
    background-color: #f5f0e8;
    color: #8a7a40;
}

.caja-ventaja h3 {
    font-size: 18px;
    font-weight: 700;
    color: #1a1a1a;
    margin-bottom: 12px;
}

.caja-ventaja p {
    font-size: 14px;
    color: #666;
    line-height: 1.6;
}

/* --- NOSOTROS (INDEX) --- */

.nosotros {
    padding: 80px;
    background-color: #f0faf9;
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
}

.img-fondo {
    position: relative;
    width: 45%;
    min-width: 400px;
}

.img-fondo::before {
    content: "";
    position: absolute;
    top: -20px;
    left: -20px;
    right: 20px;
    bottom: 20px;
    background-color: #c8ede8;
    border-radius: 24px;
}

.img-fondo img {
    position: relative;
    width: 100%;
    height: 500px;
    border-radius: 20px;
}

.corazon-flotante {
    position: absolute;
    bottom: 20px;
    right: -20px;
    width: 52px;
    height: 52px;
    background-color: #fdecea;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 22px;
    color: #e05050;
    box-shadow: 0 4px 15px rgba(0,0,0,0.15);
}

.texto-nosotros {
    width: 50%;
    max-width: 560px;
}

.etiqueta-roja {
    display: inline-block;
    background-color: #fdecea;
    color: #e05050;
    font-size: 13px;
    font-weight: 600;
    padding: 8px 16px;
    border-radius: 20px;
    margin-bottom: 20px;
}

.texto-nosotros h2 {
    font-family: 'Playfair Display', serif;
    font-size: 38px;
    font-weight: 800;
    color: #1a1a1a;
    margin-bottom: 20px;
    line-height: 1.2;
}

.cita-autor {
    color: #20b2aa;
    font-style: italic;
    font-weight: 500;
    margin-bottom: 28px;
}

/* --- CESTAS (HOME) --- */

.productos {
    padding: 80px 20px;
    background-color: #fff;
    text-align: center;
}

.titulos-seccion {
    text-align: center;
    margin-bottom: 40px;
    padding: 0 20px;
}

.titulos-seccion h2 {
    font-family: 'Playfair Display', serif;
    font-size: 38px;
    font-weight: 800;
    color: #1a1a1a;
    margin-bottom: 16px;
}

.titulos-seccion p {
    color: #666;
    max-width: 600px;
    margin: 0 auto;
    line-height: 1.7;
}

.subtitulo {
    display: block;
    color: #b8860b;
    font-size: 14px;
    font-weight: 700;
    margin-bottom: 12px;
}

/* --- OPINIONES --- */

.opiniones {
    padding: 72px 40px;
    background-color: #f0faf9;
    text-align: center;
}

.rejilla-opiniones {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    margin-bottom: 40px;
}

.tarjeta-opinion {
    margin: 12px;
    background-color: #fff;
    border: 1px solid #eee;
    border-radius: 20px;
    padding: 32px 28px;
    width: 340px;
    text-align: left;
    box-shadow: 0 4px 15px rgba(0,0,0,0.05);
}

.icono-comillas {
    width: 44px;
    height: 44px;
    background-color: #e8f5f5;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #20b2aa;
    font-size: 20px;
    margin-bottom: 16px;
}

.estrellas {
    display: flex;
    margin-bottom: 16px;
}

.estrellas span {
    color: #20b2aa;
    font-size: 18px;
    margin-right: 4px;
}

.texto-opi {
    font-size: 14px;
    color: #555;
    line-height: 1.7;
    margin-bottom: 20px;
    font-style: italic;
}

.perfil {
    display: flex;
    align-items: center;
}

.avatar {
    width: 44px;
    height: 44px;
    background-color: #20b2aa;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-size: 18px;
    font-weight: 700;
}

.info-perfil {
    margin-left: 14px;
}

.nombre {
    font-size: 15px;
    font-weight: 700;
    color: #1a1a1a;
    display: block;
}

.tipo-cliente {
    font-size: 12px;
    color: #888;
    display: block;
}

.resumen-opiniones {
    display: inline-flex;
    align-items: center;
    background-color: #fff;
    border: 1px solid #eee;
    border-radius: 40px;
    padding: 14px 28px;
    box-shadow: 0 4px 15px rgba(0,0,0,0.05);
}

.caras-mini {
    display: flex;
}

.mini-avatar {
    width: 34px;
    height: 34px;
    background-color: #20b2aa;
    border-radius: 50%;
    border: 2px solid #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-size: 13px;
    font-weight: 700;
    margin-left: -8px;
}

.mini-avatar:first-child {
    margin-left: 0;
}

.txt-resumen {
    margin-left: 16px;
    text-align: left;
}

.texto-clientes {
    font-size: 15px;
    font-weight: 700;
    color: #1a1a1a;
    display: block;
}

.nota {
    font-size: 13px;
    color: #888;
}

.nota .estrellita {
    color: #b8860b;
}

/* --- PLANES (INDEX) --- */

.planes {
    padding: 80px 20px;
    background-color: #f8faf8;
    text-align: center;
}

.rejilla-planes {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    align-items: stretch;
    margin-top: 40px;
}

.tarjeta-plan {
    margin: 10px;
    background-color: #fff;
    border: 1px solid #e0ddd8;
    border-radius: 20px;
    padding: 40px 32px;
    width: 300px;
    text-align: center;
    position: relative;
    display: flex;
    flex-direction: column;
}

.tarjeta-plan.plan-vip {
    border: 2px solid #b8860b;
    z-index: 2;
    box-shadow: 0 20px 40px rgba(184,134,11,0.2);
}

.etiqueta-vip {
    position: absolute;
    top: -14px;
    left: 50%;
    margin-left: -40px;
    background-color: #e05050;
    color: #fff;
    font-size: 12px;
    font-weight: 700;
    padding: 4px 16px;
    border-radius: 20px;
    width: 80px;
}

.icono-grande {
    width: 60px;
    height: 60px;
    background-color: #f5f0e8;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 26px;
    color: #b8860b;
    margin: 0 auto 20px auto;
}

.titulo-plan {
    font-size: 22px;
    font-weight: 800;
    color: #1a1a1a;
    margin-bottom: 8px;
}

.sub-plan {
    font-size: 13px;
    color: #888;
    margin-bottom: 20px;
}

.txt-precio {
    font-size: 40px;
    font-weight: 900;
    color: #1a1a1a;
    margin-bottom: 8px;
}

.txt-precio span {
    font-size: 16px;
    font-weight: 500;
    color: #888;
}

.lista-check {
    text-align: left;
    margin: 24px 0 32px 0;
}

.lista-check li {
    padding: 8px 0;
    border-bottom: 1px solid #f5f5f5;
    font-size: 14px;
    color: #555;
    display: flex;
    align-items: flex-start;
}

.lista-check li span {
    margin-right: 8px;
    font-weight: 700;
}

.tick-verde {
    color: #20b2aa;
}

.tick-oro {
    color: #b8860b;
}

.tick-rojo {
    color: #e05050;
}

.btn-borde-negro {
    display: block;
    text-align: center;
    padding: 13px 24px;
    border-radius: 28px;
    font-size: 15px;
    font-weight: 600;
    cursor: pointer;
    width: 100%;
    border: 2px solid #1a1a1a;
    background-color: transparent;
    color: #1a1a1a;
}

.btn-oro-solido {
    display: block;
    text-align: center;
    padding: 13px 24px;
    border-radius: 28px;
    font-size: 15px;
    font-weight: 600;
    cursor: pointer;
    width: 100%;
    background-color: #b8860b;
    color: #fff;
    border: none;
    box-shadow: 0 10px 20px rgba(184,134,11,0.2);
}

.pie-planes {
    display: flex;
    justify-content: center;
    margin-top: 32px;
}

.pie-planes span {
    font-size: 13px;
    color: #666;
    margin: 0 16px;
    display: flex;
    align-items: center;
}

/* --- POR QUE ELEGIRNOS --- */

.motivos {
    padding: 72px 20px;
    background-color: #fff;
    text-align: center;
}

.rejilla-motivos {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    margin: 40px 0;
}

.caja-motivo {
    margin: 10px;
    background-color: #f8faf8;
    border-radius: 18px;
    padding: 32px 24px;
    width: 290px;
    text-align: left;
}

.icono-motivo {
    font-size: 22px;
    color: #b8860b;
    margin-bottom: 16px;
}

.barra-datos {
    background-color: #f5f3ef;
    border-radius: 16px;
    display: flex;
    max-width: 900px;
    margin: 0 auto;
}

.dato {
    width: 25%;
    padding: 28px 20px;
    text-align: center;
    border-right: 1px solid #e5e0d8;
}

.dato:last-child {
    border-right: none;
}

.num-grande {
    font-size: 28px;
    font-weight: 900;
    color: #1a1a1a;
    margin-bottom: 8px;
}

.txt-dato {
    font-size: 13px;
    color: #888;
}

/* --- BOLETIN --- */

.boletin {
    padding: 80px 48px;
    background-color: #20b2aa;
    text-align: center;
    position: relative;
    overflow: hidden;
}

.icono-correo {
    width: 64px;
    height: 64px;
    background-color: rgba(255,255,255,0.2);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-size: 28px;
    margin: 0 auto 24px auto;
}

.boletin h2 {
    font-family: 'Playfair Display', serif;
    font-size: 38px;
    font-weight: 800;
    color: #fff;
    margin-bottom: 16px;
}

.sub-boletin {
    font-size: 16px;
    color: rgba(255,255,255,0.85);
    max-width: 500px;
    margin: 0 auto 32px auto;
    line-height: 1.6;
}

.ventajas-boletin {
    display: flex;
    justify-content: center;
    margin-bottom: 40px;
}

.bloque-boletin {
    margin: 8px;
    background-color: rgba(255,255,255,0.18);
    border-radius: 16px;
    padding: 20px 24px;
    text-align: center;
    min-width: 160px;
}

.ico-bol {
    font-size: 26px;
    color: #fff;
    margin-bottom: 10px;
    display: block;
}

.tit-bol {
    font-size: 14px;
    font-weight: 700;
    color: #fff;
    margin-bottom: 4px;
}

.txt-bol {
    font-size: 12px;
    color: rgba(255,255,255,0.8);
}

.formulario {
    max-width: 480px;
    margin: 0 auto 16px auto;
    background-color: #fff;
    border-radius: 40px;
    padding: 8px 8px 8px 20px;
    display: flex;
    align-items: center;
}

.formulario input[type="email"] {
    width: 70%;
    border: none;
    font-size: 14px;
    color: #333;
    background: transparent;
    padding: 10px 0;
}

.btn-enviar {
    background-color: #1a1a1a;
    color: #fff;
    border: none;
    border-radius: 32px;
    padding: 12px 24px;
    font-size: 14px;
    font-weight: 700;
    cursor: pointer;
}

.aviso-correo {
    font-size: 12px;
    color: rgba(255,255,255,0.7);
}

.forma-fondo {
    position: absolute;
    font-size: 80px;
    opacity: 0.1;
    color: #fff;
}

/* =============================================
   PIE DE PAGINA
   ============================================= */

.pie-pagina {
    background-color: #2a2a2a;
    color: #ccc;
    padding: 64px 72px 32px 72px;
}

.fila-pie {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
}

.col-logo,
.col-enlaces,
.col-contacto,
.col-sellos {
    width: 22%;
    min-width: 200px;
    margin-right: 32px;
}

.col-logo img {
    width: 60px;
    height: 60px;
    border-radius: 8px;
}

.col-logo p {
    font-size: 14px;
    color: #aaa;
    max-width: 220px;
    line-height: 1.7;
    margin-bottom: 20px;
}

.redes-sociales {
    display: flex;
}

.enlace-red {
    width: 38px;
    height: 38px;
    background-color: #3a3a3a;
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 18px;
    color: #ccc;
    cursor: pointer;
    margin-right: 12px;
}

.col-enlaces h4,
.col-contacto h4,
.col-sellos h4 {
    font-size: 15px;
    font-weight: 700;
    color: #fff;
    margin-bottom: 20px;
}

.col-enlaces ul li {
    margin-bottom: 10px;
}

.col-enlaces ul li a {
    font-size: 14px;
    color: #aaa;
}

.linea-contacto {
    margin-bottom: 12px;
    font-size: 14px;
    color: #aaa;
    display: flex;
    align-items: center;
}

.linea-contacto i {
    width: 30px;
    font-size: 16px;
    color: #20b2aa;
}

.sello-pie {
    margin-bottom: 14px;
    display: flex;
    align-items: center;
}

.icono-sello {
    width: 34px;
    height: 34px;
    background-color: #3a3a3a;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 15px;
    color: #20b2aa;
}

.sello-pie span {
    margin-left: 12px;
    font-size: 14px;
    color: #aaa;
}

.copyright {
    text-align: center;
    border-top: 1px solid #3d3d3d;
    padding-top: 32px;
    margin-top: 40px;
    font-size: 13px;
    color: #888;
}

.btn-subir {
    position: fixed;
    bottom: 32px;
    right: 32px;
    width: 50px;
    height: 50px;
    background-color: #20b2aa;
    color: #fff;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 20px;
    box-shadow: 0 4px 12px rgba(0,0,0,0.2);
    z-index: 99;
}

/* =============================================
   PAGINA CATALOGO - CESTAS
   ============================================= */

.contenedor-cestas {
    background-color: #f8faf8;
    padding-bottom: 80px;
}

.cabecera-pagina-cestas {
    text-align: center;
    padding: 64px 20px 32px 20px;
    border-bottom: 1px solid #e5ebe5;
}

.cabecera-pagina-cestas h1 {
    font-family: 'Playfair Display', serif;
    font-size: 48px;
    font-weight: 800;
    color: #2d2d2d;
    margin-bottom: 20px;
}

.barra-herramientas {
    max-width: 1100px;
    margin: 40px auto 32px auto;
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0 20px;
}

.txt-resultados {
    font-size: 14px;
    color: #666;
}

.enlaces-herramientas {
    display: flex;
}

.enlace-herramienta {
    font-size: 14px;
    font-weight: 600;
    color: #b8860b;
    margin-left: 20px;
}

.rejilla-catalogo {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 20px;
}

.tarjeta-catalogo {
    margin: 16px;
    background-color: #fff;
    border-radius: 12px;
    overflow: hidden;
    width: 340px;
    box-shadow: 0 4px 15px rgba(0,0,0,0.05);
    text-align: left;
    cursor: pointer;
}

.caja-img-catalogo {
    position: relative;
    width: 100%;
    height: 340px;
    background-color: #f0f0f0;
    overflow: hidden;
}

.caja-img-catalogo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.etiqueta-sg-verde {
    position: absolute;
    top: 16px;
    left: 16px;
    background-color: #20b2aa;
    color: #fff;
    font-size: 11px;
    font-weight: 700;
    padding: 4px 10px;
    border-radius: 12px;
}

.etiqueta-desc-roja {
    position: absolute;
    top: 16px;
    left: 80px;
    background-color: #e05050;
    color: #fff;
    font-size: 11px;
    font-weight: 700;
    padding: 4px 10px;
    border-radius: 12px;
}

.btn-favorito-catalogo {
    position: absolute;
    top: 16px;
    right: 16px;
    background-color: #fff;
    border: none;
    border-radius: 50%;
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 16px;
    color: #ccc;
    cursor: pointer;
    box-shadow: 0 2px 8px rgba(0,0,0,0.1);
}

.capa-btn-carrito {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    padding: 20px;
    background-color: rgba(0,0,0,0.5);
    opacity: 0;
    z-index: 5;
    display: flex;
    align-items: center;
    justify-content: center;
    transition-property: opacity;
    transition-duration: 0.3s;
}

.tarjeta-catalogo:hover .capa-btn-carrito {
    opacity: 1;
}

.btn-anadir-carrito {
    width: 100%;
    background-color: #fff;
    color: #1a1a1a;
    border: none;
    border-radius: 8px;
    padding: 12px;
    font-size: 14px;
    font-weight: 700;
    cursor: pointer;
    text-align: center;
}

.info-catalogo {
    padding: 24px;
}

.titulo-cesta {
    font-family: 'Playfair Display', serif;
    font-size: 24px;
    font-weight: 700;
    color: #1a1a1a;
    margin-bottom: 8px;
}

.categoria-cesta,
.categoria-detalle {
    font-size: 12px;
    color: #888;
    margin-bottom: 8px;
}

.desc-cesta {
    font-size: 13px;
    color: #666;
    line-height: 1.6;
    margin-bottom: 12px;
}

.fila-precio-catalogo {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.bloque-precios {
    display: flex;
    align-items: center;
}

.precio-catalogo-nuevo {
    font-size: 22px;
    font-weight: 800;
    color: #1a1a1a;
    margin-right: 8px;
}

.precio-catalogo-viejo {
    font-size: 15px;
    color: #aaa;
    text-decoration: line-through;
}

.enlace-ver-mas {
    font-size: 14px;
    font-weight: 600;
    color: #b8860b;
}

/* =============================================
   PAGINA DETALLE DE PRODUCTO
   ============================================= */
.contenedor-detalle {
    background-color: #fff;
    padding-bottom: 85px;
}

.fila-ruta {
    max-width: 1200px;
    margin: 0 auto;
    padding: 25px 40px;
    font-size: 13px;
    color: #888;
    display: flex;
    align-items: center;
}

.fila-ruta a {
    margin-right: 5px;
}

.fila-ruta span {
    margin: 0 8px;
}

.seccion-producto {
    max-width: 1200px;
    margin: 0 auto;
    padding: 20px 40px;
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
}

.col-imagen {
    width: 45%;
    position: relative;
    min-width: 300px;
}

.col-imagen img {
    width: 100%;
    border-radius: 20px;
    /* Sombra suave y redondeada */
    box-shadow: 0 10px 30px rgba(0,0,0,0.1);
}

.etiqueta-sg-detalle {
    position: absolute;
    top: 30px;
    left: 30px;
    background-color: #8cba8c;
    color: #fff;
    font-size: 14px;
    font-weight: 700;
    padding: 8px 16px;
    border-radius: 6px;
    z-index: 2;
}

.col-info {
    width: 50%;
    min-width: 300px;
}

.col-info h1 {
    font-family: 'Playfair Display', serif;
    font-size: 42px;
    font-weight: 800;
    color: #1a1a1a;
    margin-bottom: 20px;
}

.bloque-precios-detalle {
    margin-bottom: 10px;
    display: flex;
    align-items: center;
}

.precio-detalle {
    font-size: 36px;
    font-weight: 900;
    color: #1a1a1a;
    margin-right: 15px;
}

.precio-viejo-detalle {
    font-size: 18px;
    color: #aaa;
    text-decoration: line-through;
    margin-right: 15px;
}

.dto-detalle {
    background: linear-gradient(135deg, #ff6b6b 0%, #ee5253 100%);
    color: #fff;
    font-size: 12px;
    font-weight: 700;
    padding: 4px 10px;
    border-radius: 6px;
}

.etiqueta-innovadores {
    color: #20b2aa;
    font-size: 14px;
    font-weight: 600;
    margin-bottom: 25px;
    padding-top: 10px;
    display: block;
}

.desc-detalle {
    font-size: 15px;
    color: #555;
    line-height: 1.8;
    margin-bottom: 30px;
}

.badges-social {
    display: flex;
    margin-bottom: 20px;
}

.badge-social {
    margin-right: 12px;
    padding: 6px 12px;
    border-radius: 6px;
    font-size: 12px;
    font-weight: 600;
}

.badge-social.verde { background-color: #e8f5f0; color: #2d6a4f; }
.badge-social.naranja { background-color: #fff8e0; color: #b8860b; }

.disponibilidad-container {
    margin-bottom: 40px;
}

.txt-dispo {
    display: flex;
    justify-content: space-between;
    font-size: 12px;
    color: #888;
    margin-bottom: 8px;
}

.barra-fondo {
    width: 100%;
    height: 6px;
    background-color: #eee;
    border-radius: 3px;
    overflow: hidden;
}

.barra-progreso {
    height: 100%;
    background-color: #b8860b;
}

.grid-iconos-detalle {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    margin-bottom: 40px;
}

.caja-icono-detalle {
    width: 48%;
    margin-bottom: 15px;
    background-color: #fafafa;
    border-radius: 12px;
    padding: 16px;
    display: flex;
    align-items: center;
}

.icono-det-circulo {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 18px;
}

.txt-icono-det {
    margin-left: 14px;
}

.bg-naranja { background-color: #fff8e0; color: #b8860b; }
.bg-teal { background-color: #e8f5f5; color: #20b2aa; }

.txt-icono-det h4 {
    font-size: 13px;
    font-weight: 700;
    color: #1a1a1a;
    margin-bottom: 2px;
}

.txt-icono-det p { font-size: 11px; color: #888; }

.fila-compra {
    display: flex;
    align-items: center;
    margin-top: 20px;
}

.selector-cantidad {
    background-color: #f5f5f5;
    border-radius: 12px;
    padding: 0 15px;
    margin-right: 15px;
    display: flex;
    align-items: center;
}

.selector-cantidad button {
    background: none;
    border: none;
    font-size: 18px;
    color: #666;
    cursor: pointer;
    padding: 10px 5px;
}

.selector-cantidad span {
    font-weight: 700;
    color: #1a1a1a;
    min-width: 20px;
    text-align: center;
    padding: 10px 5px;
}

.btn-anadir-detalle {
    width: 60%;
    background: linear-gradient(135deg, #20b2aa 0%, #48d1cc 100%);
    color: #fff;
    border: none;
    border-radius: 12px;
    padding: 18px;
    font-size: 16px;
    font-weight: 700;
    cursor: pointer;
    text-align: center;
    box-shadow: 0 4px 15px rgba(32,178,170,0.3);
}

.bloque-incluidos {
    max-width: 1200px;
    margin: 60px auto;
    padding: 0 40px;
}

.bloque-incluidos h2 {
    font-family: 'Playfair Display', serif;
    font-size: 28px;
    margin-bottom: 30px;
}

.grid-incluidos {
    background-color: #fafafa;
    padding: 40px;
    border-radius: 20px;
    display: flex;
    flex-wrap: wrap;
}

.item-incluido {
    width: 48%;
    margin-bottom: 12px;
    font-size: 15px;
    color: #444;
    display: flex;
    align-items: center;
}

.item-incluido i {
    color: #8cba8c;
    font-size: 18px;
    margin-right: 8px;
}

.bloque-recomendados {
    max-width: 1200px;
    margin: 80px auto;
    padding: 0 40px 85px 40px;
}

.cabecera-reco {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 40px;
}

.cabecera-reco h2 {
    font-family: 'Playfair Display', serif;
    font-size: 28px;
}

.ver-todas {
    color: #b8860b;
    font-weight: 600;
    font-size: 14px;
}

.rejilla-reco {
    display: flex;
    overflow-x: auto;
    padding-bottom: 20px;
    gap: 30px;
}

.rejilla-reco .tarjeta-catalogo {
    width: 340px;
    margin: 0;
}


/* =============================================
   PAGINA SUSCRIPCION, NOSOTROS Y CONTACTO
   ============================================= */

.hero-susc,
.hero-cont,
.hero-blog {
    background-color: #f8faf8;
    padding: 64px 20px 48px 20px;
    text-align: center;
}

.hero-nos {
    display: flex;
    align-items: center;
    background-color: #f0faf9;
    padding: 48px 64px;
    column-gap: 64px;
}

.cuerpo-cont {
    background-color: #f0faf9;
    padding: 48px 80px 72px 80px;
    display: flex;
    align-items: flex-start;
}

.planes-susc {
    background-color: #f8faf8;
    padding: 40px 40px 64px 40px;
    display: flex;
    justify-content: center;
    align-items: flex-start;
}

.origen {
    background-color: #fff;
    padding: 88px 40px;
    text-align: center;
}

.cta-nos {
    background-color: #b8860b;
    padding: 88px 40px;
    text-align: center;
    color: #fff;
}

.nota-cont {
    background-color: #f0faf9;
    padding: 20px 80px 48px 80px;
    text-align: center;
    font-size: 14px;
    color: #555;
}

.nota-cont i {
    color: #e05050;
    margin-right: 8px;
}

.stats-susc {
    background-color: #f0faf9;
    padding: 72px 40px;
    display: flex;
    justify-content: center;
}

.etiq-club,
.etiq-nos,
.etiq-cont,
.etiq-blog {
    display: inline-block;
    color: #b8860b;
    font-size: 14px;
    font-weight: 700;
    margin-bottom: 20px;
}

.sub-susc,
.sub-cont,
.sub-blog {
    color: #666;
    max-width: 600px;
    margin: 0 auto;
    line-height: 1.7;
}

.titulo-susc,
.titulo-nos,
.titulo-origen,
.titulo-cont,
.titulo-blog,
.cta-nos h2 {
    font-family: 'Playfair Display', serif;
    font-weight: 800;
    color: #1a1a1a;
}

.titulo-susc {
    font-size: 52px;
    margin-bottom: 16px;
}

.titulo-nos {
    font-size: 44px;
    line-height: 1.2;
    margin-bottom: 20px;
}

.titulo-cont {
    font-size: 48px;
    margin-bottom: 16px;
}

.titulo-nos span {
    color: #e05050;
}

.titulo-origen,
.cta-nos h2 {
    font-size: 38px;
    margin-bottom: 32px;
}

.cta-nos h2 {
    color: #fff;
    margin-bottom: 16px;
}

.texto-nos {
    font-size: 15px;
    color: #555;
    line-height: 1.8;
    margin-bottom: 32px;
}

.texto-origen {
    color: #424242;
    max-width: 700px;
    margin: 0 auto 24px auto;
    line-height: 1.8;
    text-align: center;
}

.col-datos p {
    color: rgba(255,255,255,0.85);
    line-height: 1.7;
    margin-bottom: 32px;
}

.cta-nos p {
    color: rgba(255,255,255,0.85);
    max-width: 500px;
    margin: 0 auto 36px auto;
    line-height: 1.7;
}

.tarjeta-susc,
.tarjeta-stat,
.col-form {
    background-color: #fff;
    border-radius: 20px;
    box-shadow: 0 4px 15px rgba(0,0,0,0.05);
}

.tarjeta-susc {
    border: 1px solid #e5e5e5;
    padding: 40px 32px;
    width: 300px;
    margin: 0 12px;
    text-align: center;
    position: relative;
    display: flex;
    flex-direction: column;
}

.tarjeta-susc.destacada {
    border: 2px solid #b8860b;
    box-shadow: 0 20px 40px rgba(184,134,11,0.15);
    padding-top: 56px;
}

.tarjeta-stat {
    border-radius: 16px;
    padding: 36px 44px;
    text-align: center;
    margin: 0 12px;
}

.badge-popular {
    position: absolute;
    top: -14px;
    left: 50%;
    margin-left: -45px;
    background-color: #e05050;
    color: #fff;
    font-size: 12px;
    font-weight: 700;
    padding: 5px 16px;
    border-radius: 20px;
}

.icono-plan {
    width: 64px;
    height: 64px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 26px;
    margin: 0 auto 20px auto;
}

.fondo-susc-verde {
    background-color: #e8f5f0;
    color: #20b2aa;
}

.fondo-susc-oro {
    background-color: #f5f0e8;
    color: #b8860b;
}

.nom-plan {
    font-size: 22px;
    font-weight: 800;
    color: #1a1a1a;
    margin-bottom: 8px;
}

.desc-plan {
    font-size: 13px;
    color: #888;
    margin-bottom: 20px;
}

.precio-susc {
    font-size: 44px;
    font-weight: 800;
    color: #1a1a1a;
    margin-bottom: 24px;
}

.mes-susc {
    font-size: 16px;
    font-weight: 400;
    color: #888;
}

.lista-susc {
    list-style: none;
    text-align: left;
    margin-bottom: 32px;
    border-top: 1px solid #f0f0f0;
    padding-top: 16px;
}

.lista-susc li {
    font-size: 14px;
    color: #555;
    padding: 8px 0;
    border-bottom: 1px solid #f5f5f5;
    display: flex;
    align-items: center;
}

.lista-susc li i {
    margin-right: 10px;
    font-size: 12px;
}

.garantias-susc {
    text-align: center;
    padding: 28px 20px 40px 20px;
    background-color: #f8faf8;
}

.garantias-susc span {
    font-size: 14px;
    color: #555;
    margin: 0 20px;
    display: inline-block;
}

.garantias-susc span i {
    color: #20b2aa;
    margin-right: 6px;
}

.num-stat {
    font-size: 36px;
    font-weight: 800;
    color: #1a1a1a;
    margin-bottom: 8px;
}

.txt-stat {
    font-size: 14px;
    color: #888;
}

.icono-stat {
    font-size: 28px;
    color: #b8860b;
    margin-bottom: 14px;
}

.icono-origen {
    font-size: 40px;
    color: #e05050;
    margin-bottom: 24px;
}

.icono-cta {
    font-size: 36px;
    margin-bottom: 20px;
}

.icono-datos {
    font-size: 28px;
    margin-bottom: 16px;
}

.btn-plan-rojo,
.btn-plan-oro,
.btn-blanco,
.btn-enviar-cont {
    display: block;
    border-radius: 30px;
    font-size: 15px;
    font-weight: 600;
    text-align: center;
    padding: 13px 20px;
    cursor: pointer;
}

.btn-plan-rojo {
    border: 2px solid #e05050;
    color: #e05050;
    background-color: transparent;
}

.btn-plan-rojo:hover {
    background-color: #e05050;
    color: #fff;
}

.btn-plan-oro,
.btn-enviar-cont {
    background-color: #b8860b;
    color: #fff;
    border: none;
    font-weight: 700;
}

.btn-plan-oro {
    padding: 14px 20px;
}

.btn-blanco {
    display: inline-block;
    background-color: #fff;
    color: #b8860b;
    padding: 16px 36px;
    font-size: 16px;
    font-weight: 700;
    border: none;
}

.btn-enviar-cont {
    padding: 15px 32px;
}

.col-txt-nos {
    width: 50%;
    padding: 40px 0;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.col-img-nos {
    width: 50%;
    position: relative;
    min-height: 600px;
    background-size: cover;
    background-position: center top;
    border-radius: 16px;
}

.cita-nos {
    position: absolute;
    bottom: 40px;
    left: -30px;
    background-color: #fff;
    border-radius: 16px;
    padding: 24px 28px;
    max-width: 280px;
    box-shadow: 0 8px 30px rgba(0,0,0,0.1);
}

.cita-nos .comillas {
    font-size: 28px;
    font-weight: 900;
    color: #b8860b;
    line-height: 1;
    margin-bottom: 8px;
}

.cita-nos p {
    font-size: 14px;
    color: #444;
    font-style: italic;
    line-height: 1.6;
    margin-bottom: 10px;
}

.cita-nos .autor {
    font-size: 13px;
    font-weight: 700;
    color: #b8860b;
}

.stats-nos {
    display: flex;
}

.stat-nos {
    margin-right: 36px;
}

.stat-nos .num {
    font-size: 22px;
    font-weight: 800;
    color: #b8860b;
}

.stat-nos .txt {
    font-size: 12px;
    color: #888;
}

.col-datos {
    width: 35%;
    background-color: #b8860b;
    border-radius: 20px;
    padding: 40px 36px;
    margin-right: 40px;
    color: #fff;
}

.col-datos h3 {
    font-size: 26px;
    font-weight: 800;
    margin-bottom: 14px;
}

.col-form {
    width: 65%;
    padding: 40px 44px;
}

.titulo-form {
    font-size: 22px;
    font-weight: 700;
    color: #1a1a1a;
    margin-bottom: 28px;
    display: flex;
    align-items: center;
}

.titulo-form i {
    color: #20b2aa;
    margin-right: 10px;
    font-size: 20px;
}

.fila-dato {
    display: flex;
    align-items: center;
    margin-bottom: 20px;
}

.circulo-dato,
.red-cont {
    background-color: rgba(255,255,255,0.2);
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
}

.circulo-dato {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    font-size: 16px;
    margin-right: 16px;
}

.red-cont {
    width: 38px;
    height: 38px;
    border-radius: 8px;
    font-size: 18px;
    margin-right: 10px;
}

.info-dato h4 {
    font-size: 14px;
    font-weight: 700;
    margin-bottom: 2px;
}

.info-dato span {
    font-size: 13px;
    color: rgba(255,255,255,0.8);
}

.titulo-redes {
    font-size: 14px;
    font-weight: 700;
    margin-top: 28px;
    margin-bottom: 14px;
}

.redes-cont {
    display: flex;
}

.fila-inputs {
    display: flex;
    margin-bottom: 20px;
    column-gap: 4%;
}

.grupo-input {
    width: 100%;
    margin-bottom: 20px;
}

.grupo-input.mitad {
    width: 48%;
    margin-bottom: 0;
}

.grupo-input label {
    display: block;
    font-size: 14px;
    font-weight: 600;
    color: #333;
    margin-bottom: 8px;
}

.grupo-input input,
.grupo-input textarea {
    width: 100%;
    border: 1px solid #e0e0e0;
    border-radius: 10px;
    padding: 14px 16px;
    font-size: 14px;
    color: #333;
    background-color: #fafafa;
    font-family: 'Lato', sans-serif;
}

.grupo-input textarea {
    height: 130px;
}

.grupo-input input:focus,
.grupo-input textarea:focus {
    border-color: #20b2aa;
    outline: none;
    background-color: #fff;
}

/* =============================================
   PAGINA BLOG
   ============================================= */

.titulo-blog {
    font-size: 48px;
    margin-bottom: 16px;
}

.filtros {
    background-color: #f0faf9;
    padding: 20px;
    text-align: center;
}

.btn-filtro {
    display: inline-block;
    border: 2px solid #ccc;
    color: #555;
    background-color: transparent;
    padding: 8px 20px;
    border-radius: 30px;
    font-size: 14px;
    font-weight: 600;
    margin: 4px;
    cursor: pointer;
}

.btn-filtro.activo {
    background-color: #b8860b;
    border-color: #b8860b;
    color: #fff;
}

.btn-filtro:hover {
    border-color: #b8860b;
    color: #b8860b;
}

.art-dest {
    background-color: #f8faf8;
    padding: 48px 64px;
    display: flex;
    align-items: center;
    column-gap: 64px;
}

.img-dest {
    width: 50%;
    min-height: 400px;
    background-size: cover;
    background-position: center center;
    border-radius: 16px;
}

.info-dest {
    width: 50%;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.cat-tag {
    display: inline-block;
    background-color: #fdecea;
    color: #e05050;
    font-size: 12px;
    font-weight: 700;
    padding: 4px 12px;
    border-radius: 20px;
    margin-bottom: 16px;
}

.cat-tag.verde {
    background-color: #e8f5f0;
    color: #20b2aa;
}

.cat-tag.oro {
    background-color: #fff8e0;
    color: #b8860b;
}

.titulo-art {
    font-family: 'Playfair Display', serif;
    font-size: 28px;
    font-weight: 800;
    color: #1a1a1a;
    line-height: 1.3;
    margin-bottom: 16px;
}

.resumen-art {
    font-size: 15px;
    color: #666;
    line-height: 1.7;
    margin-bottom: 24px;
}

.meta-art {
    font-size: 13px;
    color: #999;
    display: flex;
    align-items: center;
    margin-bottom: 20px;
}

.meta-art i {
    margin-right: 5px;
    color: #b8860b;
}

.meta-art span {
    margin-right: 20px;
}

.leer-mas,
.leer-blog {
    color: #b8860b;
    font-weight: 700;
}

.leer-mas {
    font-size: 14px;
}

.leer-mas:hover,
.leer-blog:hover {
    text-decoration: underline;
}

.rejilla-blog {
    background-color: #f0faf9;
    padding: 48px 64px;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    column-gap: 28px;
    row-gap: 28px;
}

.tarjeta-blog {
    background-color: #fff;
    border-radius: 16px;
    width: 420px;
    overflow: hidden;
    box-shadow: 0 4px 15px rgba(0,0,0,0.05);
}

.img-blog {
    width: 100%;
    height: 220px;
    background-size: cover;
    background-position: center center;
}

.info-blog {
    padding: 24px;
}

.titulo-tarjeta {
    font-size: 18px;
    font-weight: 800;
    color: #1a1a1a;
    line-height: 1.4;
    margin-bottom: 10px;
    margin-top: 12px;
}

.resumen-tarjeta {
    font-size: 13px;
    color: #666;
    line-height: 1.6;
    margin-bottom: 16px;
}

.pie-tarjeta {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 13px;
    color: #999;
}

.leer-blog {
    font-size: 13px;
}



/* =============================================
   PAGINA CARRITO
   ============================================= */

.seccion-carrito {
    max-width: 900px;
    margin: 0 auto;
    padding: 48px 40px 80px 40px;
}

.cabecera-carrito h1 {
    font-family: 'Playfair Display', serif;
    font-size: 36px;
    font-weight: 800;
    color: #1a1a1a;
    margin-bottom: 40px;
}

.carrito-vacio {
    text-align: center;
    padding: 80px 20px;
    color: #999;
}

.carrito-vacio i {
    font-size: 64px;
    margin-bottom: 16px;
    display: block;
    color: #ddd;
}

.carrito-vacio p {
    font-size: 18px;
}

.fila-carrito {
    display: flex;
    align-items: center;
    padding: 24px 0;
    border-bottom: 1px solid #f0f0f0;
    column-gap: 24px;
}

.img-carrito {
    width: 80px;
    height: 80px;
    border-radius: 12px;
    overflow: hidden;
}

.img-carrito img {
    width: 100%;
    height: 100%;
}

.info-carrito {
    width: 200px;
}

.nombre-carrito {
    font-size: 16px;
    font-weight: 700;
    color: #1a1a1a;
    margin-bottom: 4px;
}

.precio-carrito {
    font-size: 14px;
    color: #888;
}

.controles-carrito {
    display: flex;
    align-items: center;
    column-gap: 12px;
}

.btn-menos,
.btn-mas {
    width: 32px;
    height: 32px;
    border: 1px solid #ddd;
    background-color: #fff;
    border-radius: 8px;
    font-size: 18px;
    cursor: pointer;
    color: #555;
    text-align: center;
    line-height: 30px;
}

.btn-menos:hover,
.btn-mas:hover {
    border-color: #b8860b;
    color: #b8860b;
}

.cant-carrito {
    font-size: 16px;
    font-weight: 700;
    color: #1a1a1a;
    min-width: 24px;
    text-align: center;
}

.subtotal-carrito {
    font-size: 16px;
    font-weight: 700;
    color: #1a1a1a;
    margin-left: auto;
}

.btn-eliminar {
    background: none;
    border: none;
    color: #ccc;
    font-size: 16px;
    cursor: pointer;
    padding: 8px;
}

.btn-eliminar:hover {
    color: #e05050;
}

.total-carrito {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 24px 0;
    border-top: 2px solid #1a1a1a;
    margin-top: 8px;
    font-size: 18px;
    font-weight: 700;
    color: #1a1a1a;
}

.precio-total {
    font-size: 24px;
    color: #b8860b;
}

.acciones-carrito {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 32px;
}

.btn-vaciar {
    background: none;
    border: 1px solid #ddd;
    color: #888;
    padding: 12px 20px;
    border-radius: 10px;
    font-size: 14px;
    cursor: pointer;
}

.btn-vaciar:hover {
    border-color: #e05050;
    color: #e05050;
}

.btn-tramitar {
    background-color: #25d366;
    color: #fff;
    border: none;
    padding: 16px 32px;
    border-radius: 30px;
    font-size: 16px;
    font-weight: 700;
    cursor: pointer;
}

.btn-tramitar:hover {
    background-color: #05451d;
}