/* ==========================================================================
   ÓPTICA RENOVATIO - MASTER STYLESHEET
   Unificación de Módulos (Home, Tienda, Servicios, Nosotros, Políticas)
   ========================================================================== */

/* --- 1. VARIABLES GLOBALES --- */
:root {
    /* Paleta de Colores Principal */
    --rv-black: #000000;
    --rv-gold: #D0A550;
    --rv-pink: #E9504A;
    --rv-pink-hover: #c43e38;
    --rv-bg-white: #ffffff;
    --rv-bg-soft: #FFF5F5;
    --rv-bg-gray: #fafafa;
    
    /* Escala de Grises */
    --rv-gray-100: #F3F4F6;
    --rv-gray-200: #E5E7EB;
    --rv-gray-400: #9CA3AF;
    --rv-gray-500: #6B7280;
    --rv-gray-900: #111827;

    /* Sombras y Radios */
    --rv-shadow-luxury: 0 20px 40px -5px rgba(233, 80, 74, 0.15);
    --rv-shadow-card: 0 10px 30px rgba(0, 0, 0, 0.08);
    --rv-radius: 16px;
    
    /* Layout Variables (compatibilidad con IDs legacy) */
    --header-height: 4rem;
    --wp-admin-bar: 0px;
    --ob-primary: var(--rv-black);
    --ob-accent: var(--rv-gold);
    --ob-pink: var(--rv-pink);
    --ob-bg: var(--rv-bg-white);
    --cta-pink: var(--rv-pink);
    --cta-accent: var(--rv-gold);
    --unified-radius: var(--rv-radius);
}

/* Ajustes barra de administración WP */
.admin-bar { --wp-admin-bar: 32px; }
@media (max-width: 782px) { .admin-bar { --wp-admin-bar: 46px; } }
@media (max-width: 1024px) { :root { --header-height: 3.5rem; } }

/* --- 2. BASE, TIPOGRAFÍA Y UTILIDADES --- */
html { scroll-behavior: smooth; }
html, body { height: 100%; overflow-x: hidden; }
body {
    margin: 0; padding: 0;
    font-family: 'Inter', sans-serif;
    color: var(--rv-black);
    background-color: var(--rv-bg-white);
    -webkit-font-smoothing: antialiased;
}

/* Elementor HTML widget a ancho completo — NO eliminar en modo Elementor */
.elementor-widget-html {
    width: 100vw !important; position: relative;
    left: 50%; right: 50%; margin-left: -50vw !important; margin-right: -50vw !important;
}

/* Tipografía */
.font-display { font-family: 'Playfair Display', serif !important; }
.font-body { font-family: 'Lato', sans-serif !important; }
.font-sans { font-family: 'Inter', sans-serif !important; }
.font-index { font-family: 'Cormorant Garamond', serif !important; }

/* Contenedores de Sección */
.fp-section {
    min-height: 100vh; width: 100%; position: relative;
    display: flex; flex-direction: column; justify-content: center;
    align-items: center; overflow: hidden; box-sizing: border-box;
}

/* --- 3. COMPONENTES GLOBALES (Botones y Orbes) --- */
.btn-renovatio, .btn-black, .btn-white, .btn-outline-dark, .btn-white-outline, .ren-btn-checkout, .btn-outline-gold {
    padding: 0.875rem 2rem; border-radius: 50px; font-weight: 700;
    letter-spacing: 1px; transition: all 0.3s ease; display: inline-flex;
    align-items: center; justify-content: center; min-height: 48px;
    font-size: 0.85rem; cursor: pointer; border: none; text-decoration: none !important;
}
.btn-renovatio, .ren-btn-checkout { background: var(--rv-pink) !important; color: white !important; }
.btn-renovatio:hover, .ren-btn-checkout:hover { background: var(--rv-pink-hover) !important; transform: translateY(-2px); box-shadow: 0 5px 15px rgba(233, 80, 74, 0.3); }

.btn-black { background: var(--rv-black) !important; color: white !important; }
.btn-black:hover { background: #333 !important; transform: translateY(-2px); }

.btn-white { background: white !important; color: var(--rv-black) !important; box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1); }
.btn-white:hover { background: var(--rv-gold) !important; color: white !important; transform: translateY(-2px); }

.btn-outline-dark { background: transparent; color: var(--rv-black); border: 2px solid rgba(0, 0, 0, 0.2); }
.btn-outline-dark:hover { background: var(--rv-black); color: white !important; border-color: var(--rv-black); transform: translateY(-2px); }

.btn-white-outline { background: transparent; border: 1px solid white; color: white !important; }
.btn-white-outline:hover { background: white !important; color: var(--rv-black) !important; transform: translateY(-2px); }

.btn-outline-gold { background: transparent; color: var(--rv-gold); border: 2px solid var(--rv-gold); }
.btn-outline-gold:hover { background: var(--rv-gold) !important; color: white !important; border-color: var(--rv-gold); transform: translateY(-2px); box-shadow: 0 5px 15px rgba(208, 165, 80, 0.3); }

/* Atmósferas Globales (Orbes flotantes) */
.atmo-orb { position: absolute; border-radius: 50%; pointer-events: none; filter: blur(80px); opacity: 0.4; }
.loading-pulse {
    background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
    background-size: 200% 100%; animation: loading-shimmer 1.5s infinite;
}

/* --- 4. HEADER --- */
#renovatio-header-module { font-family: 'Lato', sans-serif; }
.ob-header {
    position: fixed; top: var(--wp-admin-bar); left: 0; width: 100%;
    height: var(--header-height); background: rgba(255, 255, 255, 0.1);
    backdrop-filter: blur(12px); border-bottom: 1px solid rgba(255, 255, 255, 0.1);
    z-index: 9999; display: flex; align-items: center; justify-content: space-between;
    padding: 0 5%; transition: all 0.4s ease;
}
.ob-header.scrolled { background: rgba(255, 255, 255, 0.95); border-bottom: 1px solid rgba(0, 0, 0, 0.05); box-shadow: 0 4px 30px rgba(0, 0, 0, 0.08); }
.ob-logo-img { max-height: 36px; width: auto; object-fit: contain; }
.ob-nav-menu { flex-grow: 1; display: flex; justify-content: center; height: 100%; }
.ob-menu-list { display: flex; list-style: none; gap: 2.5rem; height: 100%; align-items: center; margin: 0; padding: 0; }
.ob-menu-item > a { color: var(--rv-black); text-transform: uppercase; font-size: 0.75rem; font-weight: 700; letter-spacing: 2px; transition: color 0.3s; text-decoration: none; }
.ob-menu-item > a:hover { color: var(--rv-gold); }

/* Header Dropdown */
.ob-has-dropdown { position: relative; }
.ob-has-dropdown > a { display: flex; align-items: center; }
.ob-dropdown {
    position: absolute; top: 100%; left: 50%; transform: translateX(-50%) translateY(10px);
    background: white; border-radius: 12px; box-shadow: 0 15px 40px rgba(0, 0, 0, 0.15);
    min-width: 220px; padding: 0.75rem 0; list-style: none; opacity: 0; visibility: hidden;
    transition: all 0.3s ease; z-index: 100; margin: 0;
}
.ob-has-dropdown:hover .ob-dropdown { opacity: 1; visibility: visible; transform: translateX(-50%) translateY(0); }
.ob-dropdown li a { display: block; padding: 0.75rem 1.5rem; color: var(--rv-black) !important; font-size: 0.8rem; text-decoration: none; transition: 0.3s ease; }
.ob-dropdown li a:hover { background: #f8f8f8; color: var(--rv-gold) !important; padding-left: 1.75rem; }

/* Header Acciones & Carrito */
.ob-header-actions { display: flex; gap: 1.25rem; align-items: center; height: 100%; }
.ob-action-btn { background: transparent !important; border: none; cursor: pointer; font-size: 1.35rem; color: var(--rv-black); transition: color 0.3s ease; padding: 0.5rem; display: flex; align-items: center; outline: none; text-decoration: none; }
.ob-action-btn:hover { color: var(--rv-gold); }
.cart-icon-wrapper { position: relative; display: flex; align-items: center; }
.header-cart-badge {
    position: absolute; top: -4px; right: -6px; background-color: var(--rv-black);
    color: white; font-size: 9px; font-weight: 700; height: 15px; min-width: 15px;
    border-radius: 50%; display: flex; align-items: center; justify-content: center;
    border: 2px solid #ffffff; box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
}
.header-spacer { height: calc(var(--header-height) + var(--wp-admin-bar, 0px)); }

/* Header Búsqueda & Overlay Móvil (Resumen) */
.ob-search-overlay, .ob-overlay { position: fixed; top: 0; left: 0; width: 100%; height: 100%; background: rgba(0, 0, 0, 0.6); backdrop-filter: blur(4px); z-index: 100002; opacity: 0; visibility: hidden; transition: all 0.3s ease; }
.ob-search-overlay.active, .ob-overlay.active { opacity: 1; visibility: visible; }
.ob-search-panel { position: fixed; top: 0; left: 0; width: 100%; background: white; z-index: 10004; transform: translateY(-100%); transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1); box-shadow: 0 10px 40px rgba(0, 0, 0, 0.15); }
.ob-search-panel.active { transform: translateY(0); }
.ob-mobile-menu { position: fixed; top: 0; right: -100%; width: 85%; max-width: 320px; height: 100vh; background: white; z-index: 100003; transition: right 0.4s; padding: 2rem; display: flex; flex-direction: column; gap: 1.5rem; box-shadow: -5px 0 25px rgba(0,0,0,0.15); }
.ob-mobile-menu.active { right: 0; }
.ob-search-input { width: 100%; padding: 1rem 1.25rem 1rem 3rem; font-size: 1rem; border: 2px solid #eee; border-radius: 50px; outline: none; transition: 0.3s; }
.ob-search-input:focus { border-color: var(--rv-pink); box-shadow: 0 0 0 4px rgba(233, 80, 74, 0.1); }
.ob-search-submit { background: var(--rv-pink); color: white; border: none; padding: 1rem 2rem; border-radius: 50px; font-weight: 700; cursor: pointer; transition: 0.3s; display: flex; align-items: center; gap: 0.5rem; }

/* --- 5. TARJETAS DE PRODUCTO GLOBALES (Home y Tienda) --- */
.rv-product-card, .carousel-card {
    background: white; border-radius: var(--rv-radius); overflow: hidden;
    box-shadow: var(--rv-shadow-card); transition: all 0.3s ease; border: 1px solid #f0f0f0; cursor: pointer;
    display: flex; flex-direction: column;
}
.rv-product-card:hover, .carousel-card:hover { transform: translateY(-8px); box-shadow: var(--rv-shadow-luxury); border-color: transparent; }
.product-img-wrap, .card-img-wrap, .product-img-container { position: relative; background: #fff; overflow: hidden; display: flex; align-items: center; justify-content: center; }
.product-img-wrap { aspect-ratio: 4/5; }
.card-img-wrap { height: 220px; }
.product-img, .card-img-wrap img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.6s ease; pointer-events: none; }
.rv-product-card:hover .product-img, .carousel-card:hover .card-img-wrap img { transform: scale(1.08); }

.product-category, .card-category { font-size: 9px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.1em; color: var(--rv-pink); margin: 0 0 0.25rem 0; }
.product-info h3, .card-title { font-family: 'Playfair Display', serif; font-weight: 700; color: var(--rv-gray-900); transition: color 0.3s; line-height: 1.3; margin: 0 0 0.5rem 0;}
.product-info h3 { font-size: 0.95rem; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; min-height: 2.6em; }
.card-title { font-size: 1rem; white-space: nowrap; text-overflow: ellipsis; overflow: hidden;}
.rv-product-card:hover .product-info h3, .carousel-card:hover .card-title { color: var(--rv-pink); }
.product-price, .card-price { color: var(--rv-gold); font-weight: 700; font-size: 1rem; }

/* Botones Quick Add */
.quick-add, .btn-add-cart {
    position: absolute; bottom: 1rem; right: 1rem; width: 2.75rem; height: 2.75rem;
    border-radius: 50%; background: white; display: flex; align-items: center; justify-content: center;
    color: var(--rv-gray-900); border: none; cursor: pointer; transition: all 0.3s ease;
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.15); z-index: 5;
}
.quick-add { opacity: 0; transform: translateY(20px); }
.btn-add-cart { bottom: 0.75rem; right: 0.75rem; width: 2.5rem; height: 2.5rem; opacity: 0; transform: scale(0.8); }
.rv-product-card:hover .quick-add { transform: translateY(0); opacity: 1; }
.carousel-card:hover .btn-add-cart { opacity: 1; transform: scale(1); }
.quick-add:hover, .btn-add-cart:hover { background: var(--rv-pink); color: white; transform: scale(1.1); box-shadow: 0 10px 25px rgba(233, 80, 74, 0.3); }


/* --- 6. HOME MODULES --- */
/* Home Hero */
#renovatio-home-hero {
    background: var(--rv-bg-soft);
    min-height: calc(100vh - var(--header-height));
    height: auto;
    padding: 3rem 5%;
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: center;
    box-sizing: border-box;
}
#renovatio-home-hero .hero-content {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    position: relative;
    z-index: 2;
}
/* Atmósfera de orbes */
#renovatio-home-hero .pink-atmosphere {
    position: absolute;
    top: 0; left: 0;
    width: 100%; height: 100%;
    overflow: hidden;
    z-index: 1;
    pointer-events: none;
}
#renovatio-home-hero .atmo-orb {
    position: absolute;
    border-radius: 50%;
    filter: blur(80px);
    opacity: 0.4;
}
#renovatio-home-hero .atmo-orb-1 {
    width: 40vw; height: 40vw;
    max-width: 500px;
    background: radial-gradient(circle, rgba(255,182,193,0.6) 0%, rgba(233,80,74,0.3) 50%, transparent 70%);
    top: -10%; left: -10%;
}
#renovatio-home-hero .atmo-orb-2 {
    width: 35vw; height: 35vw;
    max-width: 450px;
    background: radial-gradient(circle, rgba(255,218,185,0.5) 0%, rgba(208,165,80,0.2) 50%, transparent 70%);
    bottom: -5%; right: -5%;
}
/* Card del producto */
#renovatio-home-hero .hero-product-card {
    background: white;
    border-radius: var(--rv-radius);
    box-shadow: var(--rv-shadow-luxury);
    transition: all 0.5s ease;
    border: 1px solid rgba(255,255,255,0.2);
}
/* Texto resaltado en el título */
#renovatio-home-hero .text-hero-bold {
    color: var(--rv-pink);
    font-weight: 900;
}
/* Botón dorado circular "ver producto" */
#renovatio-home-hero .btn-gold-icon {
    width: 48px; height: 48px;
    min-width: 48px;
    border-radius: 50%;
    background: var(--rv-gold);
    display: flex; align-items: center; justify-content: center;
    transition: 0.3s;
    text-decoration: none !important;
    flex-shrink: 0;
}
#renovatio-home-hero .btn-gold-icon:hover { background: #b88d3b; transform: scale(1.1); }
/* Botones de navegación del carrusel */
#renovatio-home-hero .hero-product-nav {
    display: flex; justify-content: center; gap: 0.5rem; margin-top: 1rem;
}
#renovatio-home-hero .hero-nav-btn {
    width: 40px; height: 40px; min-width: 40px; min-height: 40px;
    aspect-ratio: 1 / 1;
    border-radius: 50%;
    background: var(--rv-gold);
    border: none;
    display: flex; align-items: center; justify-content: center;
    cursor: pointer; transition: 0.3s;
    color: white; padding: 0; line-height: 1;
    box-shadow: 0 4px 12px rgba(208,165,80,0.3);
}
#renovatio-home-hero .hero-nav-btn:hover { background: #b88d3b; transform: scale(1.1); }
/* Indicador de scroll */
#renovatio-home-hero .scroll-indicator {
    position: absolute; bottom: 2.5rem; left: 50%;
    transform: translateX(-50%);
    display: flex; flex-direction: column; align-items: center; gap: 0.25rem;
    color: var(--rv-pink); opacity: 0.9;
    animation: bounce 2s infinite;
    z-index: 10; cursor: pointer; font-weight: 600;
}
/* Responsive hero */
@media (max-width: 768px) {
    #renovatio-home-hero {
        min-height: calc(100svh - var(--header-height));
        padding: 1.5rem 1.5rem 4rem;
    }
    #renovatio-home-hero .hero-product-card { margin-bottom: 2rem; }
    #renovatio-home-hero .scroll-indicator { bottom: 1rem; }
}
/* Imagen dinámica con transición de opacidad */
#renovatio-home-hero .hero-dynamic-content { opacity: 1; transition: opacity 0.5s ease; }
/* Spinner de carga sobre la imagen del producto */
#renovatio-home-hero .hero-loading {
    position: absolute; inset: 0;
    display: flex; align-items: center; justify-content: center;
    background: #f8f8f8;
}
#renovatio-home-hero .hero-loading i { font-size: 2rem; color: #ccc; animation: spin 1s linear infinite; }
/* Botón circular para ver producto — mismo color que el CTA */
#renovatio-home-hero .btn-gold-icon {
    width: 48px; height: 48px; min-width: 48px;
    border-radius: 50%;
    background: var(--rv-pink);
    display: flex; align-items: center; justify-content: center;
    transition: 0.3s; text-decoration: none !important; flex-shrink: 0;
    box-shadow: 0 4px 12px rgba(233,80,74,0.3);
}
#renovatio-home-hero .btn-gold-icon:hover { background: var(--rv-pink-hover); transform: scale(1.1); }
/* Keyframe spin (para loader del hero) */
@keyframes spin { to { transform: rotate(360deg); } }

/* Home Colecciones */
#renovatio-home-collections { background: var(--rv-bg-gray); padding: 4rem 5%; }
#renovatio-home-collections .collections-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.5rem; justify-content: center; }
#renovatio-home-collections .collection-card { position: relative; border-radius: var(--rv-radius); overflow: hidden; box-shadow: var(--rv-shadow-card); aspect-ratio: 3/4; transition: 0.3s; background: #000; display: block; }
#renovatio-home-collections .collection-card img { width: 100%; height: 100%; object-fit: cover; transition: 0.8s; opacity: 0.85; }
#renovatio-home-collections .collection-card:hover img { transform: scale(1.1); opacity: 0.75; }
#renovatio-home-collections .collection-overlay { position: absolute; bottom: 0; left: 0; right: 0; padding: 2.5rem 1.25rem 1.5rem; background: linear-gradient(to top, rgba(0,0,0,0.98), transparent); color: white; display: flex; flex-direction: column; justify-content: flex-end; }

/* Home Productos (Carousel) */
#renovatio-home-products { background: var(--rv-bg-soft); padding: 4rem 0; }
#renovatio-home-products .carousel-track { display: flex; gap: 1.5rem; width: max-content; animation: products-scroll 45s linear infinite; cursor: grab; }
#renovatio-home-products .carousel-track:hover, #renovatio-home-products .carousel-track.dragging { animation-play-state: paused; }
#renovatio-home-products .carousel-card { flex: 0 0 260px; min-width: 260px; }

/* Home Testimonios & Marcas */
#renovatio-home-testimonials { background: var(--rv-bg-soft); padding: 4rem 5% 3rem; }
#renovatio-home-testimonials .testimonial-track { display: flex; gap: 1.5rem; animation: marquee 60s linear infinite; width: max-content; }
#renovatio-home-testimonials .testimonial-card { background: white; border-radius: var(--rv-radius); padding: 1.5rem; text-align: center; box-shadow: 0 15px 25px -5px rgba(0,0,0,0.08); min-width: 18rem; border: 1px solid #f0f0f0; }
#renovatio-home-testimonials .brand-logo { height: 50px; max-width: 140px; object-fit: contain; filter: grayscale(40%); opacity: 0.8; transition: 0.3s; }
#renovatio-home-testimonials .brand-logo:hover { filter: grayscale(0%); opacity: 1; transform: scale(1.05); }

/* Home Video */
#renovatio-home-video { min-height: 80vh; position: relative; color: white; text-align: center; }
#renovatio-home-video .hero-video { position: absolute; top: 0; left: 0; width: 100%; height: 100%; object-fit: cover; z-index: 0; }
#renovatio-home-video .hero-overlay { position: absolute; inset: 0; background: rgba(0,0,0,0.5); z-index: 1; }

/* Home Instagram */
#renovatio-home-instagram { background: var(--rv-bg-gray); padding: 4rem 5%; }
#renovatio-home-instagram #sb_instagram #sbi_images { display: grid !important; grid-template-columns: repeat(6, 1fr) !important; gap: 1rem !important; }
#renovatio-home-instagram #sb_instagram .sbi_item { width: 100% !important; padding: 0 !important; }

/* --- 7. TIENDA Y CATÁLOGO --- */
#renovatio-shop-hero { padding-top: 6rem; padding-bottom: 4rem; text-align: center; position: relative; overflow: hidden; background: var(--rv-bg-soft); }
#renovatio-shop-hero .category-filters { display: flex; flex-wrap: wrap; justify-content: center; gap: 0.75rem; margin-top: 2rem; }
#renovatio-shop-hero .filter-btn { background: white; color: var(--rv-black); padding: 0.75rem 1.5rem; border-radius: 50px; font-weight: 700; font-size: 0.7rem; text-transform: uppercase; border: 1px solid #eee; cursor: pointer; transition: 0.3s; }
#renovatio-shop-hero .filter-btn.active, #renovatio-shop-hero .filter-btn:hover { background: var(--rv-black); color: white; border-color: var(--rv-black); }

#renovatio-shop-grid { background: var(--rv-bg-white); padding: 4rem 1.5rem; }
#renovatio-shop-grid .products-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1rem; }
#renovatio-shop-grid .shop-toolbar { display: flex; flex-direction: column; gap: 1rem; margin-bottom: 2.5rem; padding-bottom: 1.5rem; border-bottom: 1px solid var(--rv-gray-100); }

#renovatio-cta-widget .renovatio-cta-area { background: linear-gradient(135deg, var(--rv-pink) 0%, #d63f3a 100%); color: white; padding: 4rem 2rem; text-align: center; }

/* Tienda Sidebar / Acordeón */
.widget-yith { margin-bottom: 2.5rem; }
.yith-wcca-list > li > a { display: flex; justify-content: space-between; padding: 0.5rem 0; color: #555; font-size: 0.9rem; transition: 0.3s; cursor: pointer; text-decoration: none;}
.yith-wcca-list > li > a:hover { color: var(--rv-gold); padding-left: 5px; }
.yith-wcca-list li.active > a { color: var(--rv-black); font-weight: 700; }
.yith-wcca-submenu { padding-left: 1rem; border-left: 1px solid #eee; margin-top: 0.25rem; display: none; list-style: none; }

/* --- 8. SOBRE NOSOTROS --- */
#renovatio-about-hero .hero-fullscreen { height: 100vh; display: flex; align-items: center; justify-content: center; position: relative; background: var(--rv-bg-soft); }
#renovatio-about-hero .scroll-indicator { position: absolute; bottom: 40px; left: 50%; transform: translateX(-50%); z-index: 50; cursor: pointer; }
#renovatio-about-content .story-nav { position: sticky; top: 120px; max-height: calc(100vh - 160px); overflow-y: auto; }
#renovatio-about-content .story-link { display: flex; gap: 0.75rem; padding: 0.65rem 0; color: #888; text-decoration: none; transition: 0.3s; position: relative; }
#renovatio-about-content .story-link.active { color: var(--rv-black); font-weight: 700; }
#renovatio-about-content .story-link::before { content: ''; position: absolute; left: -1rem; width: 2px; height: 0; background: var(--rv-gold); transition: 0.3s; }
#renovatio-about-content .story-link.active::before { height: 100%; }
#renovatio-about-content .story-section { padding: 5rem 0; border-bottom: 1px solid #f0f0f0; }

/* --- 9. SERVICIOS --- */
#renovatio-services-hero, #renovatio-aesthet-hero, #renovatio-clinical-hero, #renovatio-integral-hero, #renovatio-integral-content { background: var(--rv-bg-soft); }
#renovatio-integral-hero { background: var(--rv-bg-soft); }
#renovatio-services-content .service-card-img { transition: transform 0.8s ease; width: 100%; height: 100%; object-fit: cover; }
#renovatio-services-content .group:hover .service-card-img { transform: scale(1.05); }

/* FAQ Interno de Servicios y Estilos Compartidos */
#renovatio-aesthet-content details > summary, #renovatio-clinical-content details > summary, #renovatio-integral-content details > summary { list-style: none; }
#renovatio-aesthet-content details > summary::-webkit-details-marker, #renovatio-clinical-content details > summary::-webkit-details-marker, #renovatio-integral-content details > summary::-webkit-details-marker { display: none; }
#renovatio-aesthet-content details[open] summary ~ *, #renovatio-clinical-content details[open] summary ~ *, #renovatio-integral-content details[open] summary ~ * { animation: sweep .3s ease-in-out; }
#renovatio-aesthet-content details[open] .icon-toggle, #renovatio-clinical-content details[open] .icon-toggle, #renovatio-integral-content details[open] .icon-toggle { transform: rotate(180deg); color: var(--rv-pink); }

/* --- 10. POLÍTICAS Y GARANTÍAS / TÉRMINOS LEGALES --- */
#renovatio-policies-hero, #renovatio-terms-hero { background: var(--rv-bg-soft); }
#renovatio-policies-content .legal-nav, #renovatio-terms-content .legal-nav { position: sticky; top: 150px; }
#renovatio-policies-content .legal-nav .index-title, #renovatio-terms-content .legal-nav .index-title { font-family: 'Cormorant Garamond', serif; font-size: 0.9rem; font-weight: 600; letter-spacing: 0.15em; text-transform: uppercase; color: var(--rv-gold); margin-bottom: 1.25rem; padding-bottom: 0.75rem; border-bottom: 1px solid rgba(208, 165, 80, 0.3); }
#renovatio-policies-content .legal-nav a, #renovatio-terms-content .legal-nav a { display: block; padding: 0.6rem 0; font-family: 'Cormorant Garamond', serif; color: #666; font-size: 1rem; font-weight: 500; transition: all 0.3s ease; border-left: 2px solid transparent; padding-left: 1rem; text-decoration: none; letter-spacing: 0.02em; }
#renovatio-policies-content .legal-nav a:hover, #renovatio-terms-content .legal-nav a:hover { color: var(--rv-gold); border-left-color: var(--rv-gold); padding-left: 1.25rem; }
#renovatio-policies-content .legal-nav a.active, #renovatio-terms-content .legal-nav a.active { color: var(--rv-gold); border-left-color: var(--rv-gold); font-weight: 700; }
#renovatio-policies-content .legal-nav a.highlight-link, #renovatio-terms-content .legal-nav a.highlight-link { color: var(--rv-pink); font-weight: 600; }
#renovatio-policies-content .legal-nav a.highlight-link:hover, #renovatio-policies-content .legal-nav a.highlight-link.active, #renovatio-terms-content .legal-nav a.highlight-link:hover, #renovatio-terms-content .legal-nav a.highlight-link.active { color: var(--rv-pink); border-left-color: var(--rv-pink); }
#renovatio-policies-content .legal-content h2, #renovatio-terms-content .legal-content h2 { border-left: 3px solid var(--rv-gold); padding-left: 1rem; margin-top: 2.5rem; margin-bottom: 1rem; font-family: 'Playfair Display', serif; }
#renovatio-policies-content .legal-content p, #renovatio-policies-content .legal-content ul, #renovatio-policies-content .legal-content ol, #renovatio-terms-content .legal-content p, #renovatio-terms-content .legal-content ul, #renovatio-terms-content .legal-content ol { font-family: 'Lato', sans-serif; color: #555; line-height: 1.8; margin-bottom: 1.5rem; font-size: 0.95rem; }

/* --- 11. FOOTER & SIDE CART --- */
.ob-footer-wrapper {
    background-color: var(--rv-black); color: var(--rv-bg-white);
    width: 100vw; position: relative; left: 50%; right: 50%;
    margin-left: -50vw; margin-right: -50vw;
    padding: 4rem 5% 2rem; box-sizing: border-box;
}
.ob-footer-grid { display: grid; grid-template-columns: 1.5fr 1fr 1fr 1.2fr; gap: 3rem; max-width: 1400px; margin: 0 auto; }
.ob-logo { max-width: 160px; filter: brightness(0) invert(1); margin-bottom: 1.2rem; display: block; }
.ob-desc { color: #aaa; font-size: 0.9rem; line-height: 1.6; margin-bottom: 1.5rem; max-width: 300px; }
.ob-title { font-family: 'Playfair Display', serif; color: white; font-size: 1.1rem; margin-bottom: 1.2rem; position: relative; display: inline-block; }
.ob-title::after { content: ''; position: absolute; left: 0; bottom: -5px; width: 30px; height: 2px; background: var(--rv-gold); }
.ob-list { list-style: none; padding: 0; margin: 0; }
.ob-list li { margin-bottom: 0.6rem; }
.ob-list a { text-decoration: none; color: #999; font-size: 0.95rem; transition: 0.3s; display: flex; align-items: center; gap: 6px; }
.ob-list a:hover { color: var(--rv-gold); transform: translateX(5px); }
.ob-socials { display: flex; gap: 10px; }
.ob-social-icon { width: 38px; height: 38px; border-radius: 50%; background: rgba(255,255,255,0.1); display: flex; align-items: center; justify-content: center; color: white; transition: 0.3s; text-decoration: none; font-size: 1.1rem; }
.ob-social-icon:hover { background: var(--rv-pink); transform: translateY(-3px); }
.ob-contact-row { display: flex; gap: 10px; margin-bottom: 1rem; color: #aaa; font-size: 0.9rem; align-items: flex-start; }
.ob-contact-row i { color: var(--rv-gold); font-size: 1.2rem; flex-shrink: 0; }
.ob-contact-row a { color: #aaa; text-decoration: none; transition: 0.3s; }
.ob-contact-row a:hover { color: white; }
.ob-bottom { border-top: 1px solid rgba(255,255,255,0.1); margin-top: 3rem; padding-top: 2rem; display: flex; justify-content: space-between; flex-wrap: wrap; gap: 1rem; max-width: 1400px; margin-left: auto; margin-right: auto; }
.ob-bottom span { color: #666; font-size: 0.85rem; }
.ob-legal a { color: #666; margin-left: 15px; text-decoration: none; font-size: 0.85rem; transition: 0.3s; }
.ob-legal a:hover { color: white; }

/* Side Cart (Drawer) */
.ren-overlay { position: fixed; inset: 0; background: rgba(0,0,0,0.6); backdrop-filter: blur(5px); z-index: 999998 !important; opacity: 0; visibility: hidden; transition: 0.4s; pointer-events: none; }
.ren-overlay.is-active { opacity: 1; visibility: visible; pointer-events: auto; }
.ren-drawer {
    position: fixed; top: 0; right: 0; bottom: 0; width: 100%; max-width: 450px; height: 100vh;
    background: var(--rv-bg-white); z-index: 999999 !important; box-shadow: -10px 0 50px rgba(0,0,0,0.2);
    transform: translateX(110%); transition: transform 0.5s cubic-bezier(0.23, 1, 0.32, 1);
    display: flex; flex-direction: column;
}
.ren-drawer.is-active { transform: translateX(0); }
.ren-cart-head { padding: 1.5rem; border-bottom: 1px solid #f0f0f0; flex-shrink: 0; display: flex; justify-content: space-between; align-items: center; }
.ren-cart-title { font-family: 'Playfair Display', serif; font-size: 1.5rem; margin: 0; color: black; font-weight: 700; }
.ren-count { background: black; color: white; font-size: 0.75rem; padding: 2px 8px; border-radius: 10px; position: relative; top: -3px; }
.ren-close {
    background: transparent !important; border: none !important; outline: none !important;
    box-shadow: none !important; font-size: 1.8rem; cursor: pointer; color: #aaa;
    padding: 0; line-height: 1; transition: 0.3s;
}
.ren-close:hover { color: var(--rv-pink) !important; transform: rotate(90deg); background: transparent !important; }
.ren-cart-body { flex-grow: 1; overflow-y: auto; padding: 1.5rem; position: relative; background: white; }
.ren-loader { position: absolute; inset: 0; background: rgba(255,255,255,0.8); z-index: 50; display: none; align-items: center; justify-content: center; }
.ren-drawer.processing .ren-loader { display: flex; }
.ren-item { display: flex; gap: 1rem; margin-bottom: 1.5rem; padding-bottom: 1.5rem; border-bottom: 1px solid #f5f5f5; position: relative; }
.ren-img { width: 80px; height: 100px; object-fit: cover; border-radius: 6px; background: #f9f9f9; }
.ren-info { flex: 1; display: flex; flex-direction: column; justify-content: space-between; }
.ren-prod-name { font-weight: 700; font-size: 1rem; color: black; text-decoration: none; margin: 0 0 4px; display: block; line-height: 1.2; }
.ren-controls { display: flex; justify-content: space-between; align-items: center; margin-top: 8px; }
.ren-qty-box { display: flex; align-items: center; border: 1px solid #ddd; border-radius: 50px; height: 32px; }
.ren-qty-btn {
    background: transparent !important; border: none !important; width: 30px; height: 100%;
    font-size: 1.1rem; color: #555; cursor: pointer; display: flex; align-items: center;
    justify-content: center; outline: none !important; box-shadow: none !important;
}
.ren-qty-btn:hover { color: black !important; background: transparent !important; }
.ren-qty-input { width: 30px; border: none; text-align: center; font-weight: bold; font-size: 0.9rem; outline: none; -moz-appearance: textfield; background: transparent !important; }
.ren-qty-input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.ren-price { font-weight: 700; color: var(--rv-gold); font-size: 1rem; }
.ren-remove {
    position: absolute; top: 0; right: 0; background: transparent !important; border: none !important;
    font-size: 1.2rem; color: #ccc; cursor: pointer; display: flex; padding: 5px;
    outline: none !important; box-shadow: none !important;
}
.ren-remove:hover { color: var(--rv-pink) !important; background: transparent !important; }
.ren-cart-foot { padding: 1.5rem 1.5rem 2rem; border-top: 1px solid #f0f0f0; background: white; flex-shrink: 0; box-shadow: 0 -5px 20px rgba(0,0,0,0.03); }
.ren-subtotal { display: flex; justify-content: space-between; align-items: flex-end; margin-bottom: 1rem; }
.ren-lbl { text-transform: uppercase; font-size: 0.75rem; font-weight: 700; color: #888; letter-spacing: 1px; }
.ren-tot-val { font-family: 'Playfair Display', serif; font-size: 1.8rem; font-weight: 700; color: black; }
.ren-btn-checkout {
    display: block; width: 100%; padding: 1rem; background: var(--rv-pink); color: white;
    text-align: center; border-radius: 50px; text-decoration: none; font-weight: 700;
    text-transform: uppercase; letter-spacing: 1px; font-size: 0.9rem; transition: 0.3s; border: none; box-sizing: border-box;
}
.ren-btn-checkout:hover { background: var(--rv-pink-hover); transform: translateY(-2px); box-shadow: 0 5px 15px rgba(233,80,74,0.3); color: white !important; }
.ren-link-back { display: block; text-align: center; margin-top: 1rem; font-size: 0.8rem; text-transform: uppercase; letter-spacing: 1px; color: black; text-decoration: none; }
.ren-link-back:hover { text-decoration: underline; color: var(--rv-pink); }

/* Footer responsive */

/* --- 12. ANIMACIONES GLOBALES --- */

/* --- HOME: ROSTROS (Polaroid) --- */
#renovatio-home-faces { background: var(--rv-bg-gray); padding: 5rem 5%; overflow: hidden; }
#renovatio-home-faces .faces-container { max-width: 1200px; margin: 0 auto; }
.polaroid-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 2rem; margin-top: 3rem; }
.polaroid-item {
    background: white; padding: 1rem 1rem 3rem 1rem;
    box-shadow: 0 10px 25px rgba(0,0,0,0.1);
    transform: rotate(var(--rotation, -2deg));
    transition: all 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
    cursor: pointer; position: relative;
}
.polaroid-item:nth-child(even) { --rotation: 3deg; margin-top: 1rem; }
.polaroid-item:hover { transform: rotate(0deg) scale(1.05); z-index: 10; box-shadow: 0 15px 35px rgba(233, 80, 74, 0.2); }
.polaroid-img-wrap { width: 100%; aspect-ratio: 1/1; overflow: hidden; background: #eee; margin-bottom: 1.5rem; border: 1px solid #f0f0f0; }
.polaroid-img-wrap img { width: 100%; height: 100%; object-fit: cover; filter: sepia(0.2) contrast(1.1); }
.polaroid-text { font-family: 'Permanent Marker', cursive, sans-serif; text-align: center; color: #333; font-size: 1.1rem; line-height: 1.2; }
.polaroid-text small { display: block; font-family: 'Lato', sans-serif; font-size: 0.7rem; text-transform: uppercase; letter-spacing: 1px; color: var(--rv-pink); margin-top: 0.5rem; font-weight: 700; }

/* --- TIENDA: FILTRO OFERTAS EN SIDEBAR --- */
#rv-shop-module .rv-filter-ofertas {
    color: var(--rv-pink) !important;
    font-weight: 700 !important;
}
#rv-shop-module .rv-filter-ofertas:hover,
#rv-shop-module .rv-filter-ofertas.rv-active {
    color: var(--rv-pink) !important;
    font-weight: 800 !important;
    padding-left: 5px;
}

/* --- TIENDA: SECCIÓN GIFT CARDS --- */
.rv-giftcards-section {
    margin-top: 5rem;
    padding: 5rem 0 4rem;
    border-top: 1px solid rgba(233, 80, 74, 0.08);
    position: relative;
    overflow: hidden;
}
.rv-giftcards-section::before {
    content: '';
    position: absolute;
    top: -6rem; right: -6rem;
    width: 30rem; height: 30rem;
    background: radial-gradient(circle, rgba(208,165,80,0.08) 0%, transparent 70%);
    border-radius: 50%;
    pointer-events: none;
}

/* Header */
.rv-giftcards-header {
    margin-bottom: 3rem;
    text-align: center;
}
.rv-giftcards-tag {
    display: inline-block;
    font-size: 0.7rem;
    font-weight: 800;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--rv-gold);
    background: rgba(208, 165, 80, 0.08);
    padding: 0.4rem 1rem;
    border-radius: 2rem;
    margin-bottom: 0.75rem;
    border: 1px solid rgba(208, 165, 80, 0.2);
}
.rv-giftcards-title {
    font-size: 2.2rem;
    font-weight: 700;
    color: var(--rv-black);
    margin: 0.5rem 0 0.75rem;
    line-height: 1.15;
}
@media (min-width: 768px) { .rv-giftcards-title { font-size: 2.8rem; } }
.rv-giftcards-desc {
    color: var(--rv-gray-500);
    font-size: 0.95rem;
    max-width: 480px;
    margin: 0 auto;
    line-height: 1.65;
}

/* Grid: 1 col en móvil, 2 en tablet, hasta 3 en desktop */
.rv-giftcards-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.75rem;
}
@media (min-width: 600px)  { .rv-giftcards-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1100px) { .rv-giftcards-grid { grid-template-columns: repeat(3, 1fr); } }

/* Loader gift cards */
.rv-giftcards-loader {
    grid-column: 1 / -1;
    display: flex;
    justify-content: center;
    padding: 3rem 0;
}

/* Card */
.giftcard-card {
    background: white;
    border-radius: 1.25rem;
    overflow: hidden;
    box-shadow: 0 8px 30px rgba(0,0,0,0.07);
    border: 1px solid #f0ede8;
    display: flex;
    flex-direction: column;
    transition: transform 0.4s ease, box-shadow 0.4s ease;
}
.giftcard-card:hover {
    transform: translateY(-8px);
    box-shadow: 0 20px 45px rgba(208,165,80,0.15);
    border-color: rgba(208,165,80,0.25);
}

/* Imagen panorámica con rotación suave */
.giftcard-img-wrap {
    display: block;
    position: relative;
    aspect-ratio: 1866 / 744;   /* ratio original 1866×744 */
    overflow: hidden;
    background: #f5f0e8;
    text-decoration: none;
}
.gc-img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: opacity 1.2s ease;
}
.gc-img-a { opacity: 1; }
.gc-img-b { opacity: 0; }
.giftcard-card:hover .gc-img-a,
.giftcard-card:hover .gc-img-b {
    /* no interrumpir la rotación JS al hacer hover */
}

/* Cuerpo de la card */
.giftcard-body {
    padding: 1.25rem 1.5rem 1.5rem;
    display: flex;
    flex-direction: column;
    gap: 1rem;
    flex-grow: 1;
    background: linear-gradient(135deg, #ffffff 0%, #fffdf8 100%);
}
.giftcard-info {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
}
.giftcard-label {
    font-size: 0.65rem;
    font-weight: 800;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    color: var(--rv-gray-400);
}
.giftcard-badge {
    font-family: 'Playfair Display', serif;
    font-size: 1.6rem;
    font-weight: 700;
    color: var(--rv-gold);
    line-height: 1;
    letter-spacing: -0.02em;
}

/* Botones gift card */
.giftcard-actions {
    display: flex;
    gap: 0.6rem;
    align-items: stretch;
}
.giftcard-actions .btn-view {
    flex: 1;
    background: #f4f4f5;
    color: var(--rv-black) !important;
    padding: 0.65rem 0.75rem;
    border-radius: 3rem;
    font-size: 0.7rem;
    font-weight: 800;
    text-decoration: none;
    transition: background 0.3s ease;
    letter-spacing: 0.05em;
    white-space: nowrap;
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 2.5rem;
}
.giftcard-actions .btn-view:hover { background: #e5e7eb; }

/* Botón REGALAR — dorado para gift cards */
.giftcard-actions .gc-add-btn {
    flex: 1.6 !important;
    width: auto !important;
    min-width: 0 !important;
    max-width: none !important;
    height: auto !important;
    min-height: 2.5rem !important;
    border-radius: 3rem !important;
    background: var(--rv-gold) !important;
    color: white !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 0.35rem !important;
    font-size: 0.7rem !important;
    font-weight: 800 !important;
    letter-spacing: 0.05em !important;
    text-transform: uppercase !important;
    border: none !important;
    cursor: pointer !important;
    transition: background 0.3s ease, transform 0.3s ease, box-shadow 0.3s ease !important;
    text-decoration: none !important;
    padding: 0.65rem 0.75rem !important;
    line-height: 1.2 !important;
    box-shadow: 0 6px 18px rgba(208,165,80,0.3) !important;
    white-space: nowrap !important;
    box-sizing: border-box !important;
}
.giftcard-actions .gc-add-btn:hover {
    background: #b88d3b !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 10px 24px rgba(208,165,80,0.4) !important;
    color: white !important;
}
.giftcard-actions .gc-add-btn.loading {
    opacity: 0.7 !important;
    pointer-events: none !important;
    transform: none !important;
}
.giftcard-actions .gc-add-btn.added {
    background: #4ade80 !important;
    box-shadow: none !important;
    transform: none !important;
}

/* Responsive: en pantallas muy pequeñas ocultar ícono */
@media (max-width: 400px) {
    .giftcard-actions .gc-add-btn { font-size: 0.62rem !important; }
    .giftcard-actions .gc-add-btn .ph { display: none !important; }
}

/* --- 12b. ANIMACIONES GLOBALES --- */
@keyframes loading-shimmer { 0% { background-position: -200% 0; } 100% { background-position: 200% 0; } }
@keyframes products-scroll { 0% { transform: translateX(0); } 100% { transform: translateX(-50%); } }
@keyframes marquee { 0% { transform: translateX(0); } 100% { transform: translateX(-50%); } }
@keyframes bounce { 0%, 100% { transform: translateX(-50%) translateY(0); } 50% { transform: translateX(-50%) translateY(8px); } }
@keyframes bounce-arrow { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(6px); } }
@keyframes renSpin { to { transform: rotate(360deg); } }
@keyframes spin { to { transform: rotate(360deg); } }

/* --- 14. PREGUNTAS FRECUENTES (FAQ) --- */
#renovatio-faq-hero { background: var(--rv-bg-soft); padding-top: 5rem; padding-bottom: 5rem; text-align: center; position: relative; overflow: hidden; }
#renovatio-faq-content .faq-nav { position: sticky; top: 150px; align-self: start; }
#renovatio-faq-content .faq-nav .index-title { font-family: 'Cormorant Garamond', serif; font-size: 0.9rem; font-weight: 600; letter-spacing: 0.15em; text-transform: uppercase; color: var(--rv-gold); margin-bottom: 1.25rem; padding-bottom: 0.75rem; border-bottom: 1px solid rgba(208, 165, 80, 0.3); }
#renovatio-faq-content .faq-nav a { display: block; padding: 0.6rem 0; font-family: 'Cormorant Garamond', serif; color: #666; font-size: 1rem; font-weight: 500; transition: all 0.3s ease; border-left: 2px solid transparent; padding-left: 1rem; text-decoration: none; letter-spacing: 0.02em; }
#renovatio-faq-content .faq-nav a:hover { color: var(--rv-gold); border-left-color: var(--rv-gold); padding-left: 1.25rem; }
#renovatio-faq-content .faq-nav a.active { color: var(--rv-gold); border-left-color: var(--rv-gold); font-weight: 700; }
#renovatio-faq-content details > summary { list-style: none; }
#renovatio-faq-content details > summary::-webkit-details-marker { display: none; }
#renovatio-faq-content details[open] summary ~ * { animation: sweep .3s ease-in-out; }
#renovatio-faq-content details[open] .faq-question, #renovatio-faq-content details[open] .icon-toggle { color: var(--rv-pink); }
#renovatio-faq-content details[open] .icon-toggle { transform: rotate(180deg); }
#renovatio-faq-content .section-title { font-family: 'Playfair Display', serif; font-size: 1.5rem; font-weight: 700; margin-top: 2rem; margin-bottom: 1.5rem; color: black; border-left: 3px solid var(--rv-gold); padding-left: 1rem; }

/* --- 15. CHECKOUT (WOOCOMMERCE) --- */
#renovatio-checkout-hero { background: var(--rv-bg-soft); padding-top: 5rem; padding-bottom: 5rem; text-align: center; position: relative; overflow: hidden; }
.renovatio-checkout-wrapper .woocommerce-notices-wrapper .woocommerce-message { display: none !important; }
.renovatio-info-banner { background: linear-gradient(135deg, #FFF8E1 0%, #FFECB3 100%); border-left: 4px solid var(--rv-gold); padding: 1.5rem 2rem; border-radius: 0 16px 16px 0; margin-bottom: 1.5rem; display: flex; flex-wrap: wrap; align-items: center; gap: 1.25rem; }
.renovatio-info-banner.pink { background: linear-gradient(135deg, #FFF5F5 0%, #FFE4E4 100%); border-left-color: var(--rv-pink); }
.renovatio-info-banner .banner-icon { font-size: 2rem; flex-shrink: 0; }
.renovatio-info-banner .banner-content { flex: 1; min-width: 200px; }
.renovatio-info-banner .banner-content h4 { margin: 0 0 6px 0; font-size: 1.1rem; font-weight: 700; color: #000; }
.renovatio-whatsapp-btn { display: inline-flex; align-items: center; gap: 0.5rem; background: #25D366; color: white; padding: 0.75rem 1.5rem; border-radius: 999px; font-weight: 700; font-size: 1rem; transition: 0.3s; text-decoration: none !important; border-bottom: none !important; }
.renovatio-whatsapp-btn:hover { background: #128C7E; color: white; text-decoration: none !important;}
.renovatio-link-pink { color: var(--rv-pink); font-weight: 700; text-decoration: underline; }

/* WooCommerce UI Overrides */
.renovatio-checkout-wrapper .woocommerce-form-coupon-toggle { display: block !important; background: #f9f9f9; padding: 16px 20px; border-radius: 12px; margin-bottom: 20px; border: none;}
.renovatio-checkout-wrapper .woocommerce-form-coupon-toggle .woocommerce-info { background: transparent; border: none; padding: 0; margin: 0; display: block !important;}
.renovatio-checkout-wrapper .woocommerce-form-coupon-toggle .woocommerce-info::before, .renovatio-checkout-wrapper .woocommerce-info::before { display: none !important; content: none !important;}
.renovatio-checkout-wrapper .showcoupon { color: var(--rv-pink); font-weight: 700; }
.renovatio-checkout-wrapper .checkout_coupon { background: #f9f9f9; padding: 20px; border-radius: 12px; margin-bottom: 24px; border: none; }
.renovatio-checkout-wrapper .checkout_coupon .button { background: var(--rv-pink) !important; color: white !important; border-radius: 999px; }
.renovatio-checkout-wrapper .woocommerce input[type="text"], .renovatio-checkout-wrapper .woocommerce input[type="email"], .renovatio-checkout-wrapper .woocommerce input[type="tel"], .renovatio-checkout-wrapper .woocommerce input[type="password"], .renovatio-checkout-wrapper .woocommerce textarea, .renovatio-checkout-wrapper .woocommerce select { border-radius: 8px; border: 1px solid #ddd; padding: 12px 16px; transition: 0.3s; }
.renovatio-checkout-wrapper .woocommerce input:focus, .renovatio-checkout-wrapper .woocommerce textarea:focus, .renovatio-checkout-wrapper .woocommerce select:focus { border-color: var(--rv-pink); box-shadow: 0 0 0 3px rgba(233, 80, 74, 0.1); outline: none; }
.renovatio-checkout-wrapper .woocommerce label { font-size: 0.8rem; font-weight: 600; color: #555; text-transform: uppercase; letter-spacing: 0.03em; }
.renovatio-checkout-wrapper .woocommerce .required { color: var(--rv-pink); }
.renovatio-checkout-wrapper .woocommerce .amount { color: var(--rv-gold); font-weight: 700; }
.renovatio-checkout-wrapper .woocommerce-checkout-review-order, .renovatio-checkout-wrapper #order_review { background: transparent; padding: 0; border: none; }
.renovatio-checkout-wrapper .woocommerce-checkout-review-order-table, .renovatio-checkout-wrapper #order_review table.shop_table { border: none; border-collapse: separate; border-spacing: 0; border-radius: 16px; overflow: hidden; box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08); }
.renovatio-checkout-wrapper .woocommerce-checkout-review-order-table thead th, .renovatio-checkout-wrapper .shop_table thead th, .renovatio-checkout-wrapper table.shop_table thead th { background: #FFF0F0 !important; padding: 20px 28px !important; font-size: 0.85rem; font-weight: 700; color: #333; border: none !important; }
.renovatio-checkout-wrapper .woocommerce-checkout-review-order-table tbody td, .renovatio-checkout-wrapper .woocommerce-checkout-review-order-table tfoot td, .renovatio-checkout-wrapper .woocommerce-checkout-review-order-table tfoot th, .renovatio-checkout-wrapper .shop_table tbody td, .renovatio-checkout-wrapper .shop_table tfoot td, .renovatio-checkout-wrapper .shop_table tfoot th, .renovatio-checkout-wrapper table.shop_table tbody td, .renovatio-checkout-wrapper table.shop_table tfoot td, .renovatio-checkout-wrapper table.shop_table tfoot th { padding: 20px 28px !important; background: white; border: none !important; border-bottom: 1px solid #f5f5f5 !important; }
.renovatio-checkout-wrapper .woocommerce-checkout-review-order-table tfoot tr:last-child td, .renovatio-checkout-wrapper .woocommerce-checkout-review-order-table tfoot tr:last-child th, .renovatio-checkout-wrapper .shop_table tfoot tr:last-child td, .renovatio-checkout-wrapper .shop_table tfoot tr:last-child th { border-bottom: none; }
.renovatio-checkout-wrapper .woocommerce-shipping-methods { background: white; border-radius: 12px; padding: 8px; margin: 0; list-style: none; }
.renovatio-checkout-wrapper .woocommerce-shipping-methods li { padding: 14px 16px; border-radius: 8px; margin-bottom: 6px; transition: 0.3s; display: flex !important; align-items: center !important; gap: 12px !important; background: #fafafa; position: static !important; }
.renovatio-checkout-wrapper .woocommerce-shipping-methods li:hover { background: #f0f0f0; }
.renovatio-checkout-wrapper .woocommerce-shipping-methods label::before,
.renovatio-checkout-wrapper .woocommerce-shipping-methods label::after { display: none !important; content: none !important; }
.renovatio-checkout-wrapper .woocommerce-shipping-methods input[type="radio"] { accent-color: var(--rv-pink); flex-shrink: 0 !important; position: static !important; float: none !important; margin: 0 !important; padding: 0 !important; width: 16px !important; height: 16px !important; opacity: 1 !important; visibility: visible !important; display: block !important; clip: auto !important; clip-path: none !important; transform: none !important; }
.renovatio-checkout-wrapper .wc_payment_method input[type="radio"], .renovatio-checkout-wrapper .woocommerce-form__input-checkbox { accent-color: var(--rv-pink); margin-top: 4px; flex-shrink: 0; }
.renovatio-checkout-wrapper .woocommerce-shipping-methods label { text-transform: none; font-size: 0.9rem; line-height: 1.5; cursor: pointer; padding: 0 !important; text-indent: 0 !important; position: static !important; float: none !important; margin: 0 !important; flex: 1 !important; text-align: left !important; }
.renovatio-checkout-wrapper .wc_payment_methods { background: #f5f5f5; border-radius: 12px; overflow: hidden; padding: 8px; }
.renovatio-checkout-wrapper .wc_payment_method { background: white; border-radius: 8px; margin-bottom: 4px; overflow: hidden; }
.renovatio-checkout-wrapper .wc_payment_method > label { text-transform: none; font-weight: 600; padding: 16px; display: flex; align-items: center; gap: 10px; cursor: pointer; }
.renovatio-checkout-wrapper .wc_payment_method label img { margin-left: 8px; padding: 6px 10px; background: #f9f9f9; border-radius: 6px; }
.renovatio-checkout-wrapper .payment_box { padding: 12px 16px 16px 44px; font-size: 0.85rem; color: #666; line-height: 1.5; }
.renovatio-checkout-wrapper .woocommerce-terms-and-conditions-wrapper { margin-top: 16px; }
.renovatio-checkout-wrapper .woocommerce-form__label-for-checkbox { display: flex !important; align-items: flex-start !important; gap: 12px; font-size: 0.9rem; text-transform: none; line-height: 1.5; color: #444; }
.renovatio-checkout-wrapper .woocommerce-privacy-policy-text { font-size: 0.85rem; color: #666; margin-bottom: 16px; line-height: 1.6; }
.renovatio-checkout-wrapper .woocommerce-privacy-policy-text a, .renovatio-checkout-wrapper .woocommerce-terms-and-conditions-wrapper a { color: var(--rv-pink); }
.renovatio-checkout-wrapper .place-order, .renovatio-checkout-wrapper .form-row.place-order { margin-top: 24px; padding-top: 24px; }
.renovatio-checkout-wrapper .woocommerce #place_order, .renovatio-checkout-wrapper .woocommerce button.button.alt { background-color: var(--rv-pink); color: white; border: none; border-radius: 999px; padding: 16px 32px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.1em; transition: 0.3s; cursor: pointer; width: 100%; margin-top: 16px; }
.renovatio-checkout-wrapper .woocommerce #place_order:hover { background-color: var(--rv-pink-hover); transform: translateY(-2px); }
.renovatio-checkout-wrapper .woocommerce .button:not(#place_order):not(.alt) { background: #000; color: white; border-radius: 999px; padding: 12px 24px; font-weight: 600; border: none; }
.renovatio-trust-badge { text-align: center; padding: 2rem 0; color: #999; font-size: 0.9rem; display: flex; justify-content: center; align-items: center; gap: 0.5rem; }

/* --- 16. BLOG (ARCHIVE & SINGLE) --- */
#renovatio-blog-hero { background: var(--rv-bg-soft); padding-top: 5rem; padding-bottom: 5rem; text-align: center; position: relative; overflow: hidden; }
#renovatio-blog-content .blog-card { transition: all 0.4s ease; height: 100%; display: flex; flex-direction: column; }
#renovatio-blog-content .blog-card:hover { transform: translateY(-5px); }
#renovatio-blog-content .blog-card:hover h3 { color: var(--rv-pink) !important; }
#renovatio-blog-content .blog-img { transition: transform 0.5s ease; width: 100%; height: 100%; display: block; }
#renovatio-blog-content .blog-card:hover .blog-img { transform: scale(1.05); }
#renovatio-blog-content .cat-link { display: flex; justify-content: space-between; padding: 0.5rem 0; border-bottom: 1px solid #f3f3f3; transition: 0.3s; color: #666; cursor: pointer; }
#renovatio-blog-content .cat-link:hover { color: var(--rv-pink); padding-left: 5px; }
#renovatio-blog-content .promo-banner { background: linear-gradient(135deg, #FFF5F5 0%, #FFE4E4 100%); position: relative; overflow: hidden; }
#renovatio-blog-content .promo-banner::before { content: ''; position: absolute; top: -50%; right: -30%; width: 200px; height: 200px; background: #FFD1D1; border-radius: 50%; filter: blur(60px); opacity: 0.6; }

/* Single Post */
#renovatio-single-post .post-hero { background: linear-gradient(135deg, #FFF5F5 0%, #FFE4E4 100%); position: relative; overflow: hidden; }
#renovatio-single-post .post-hero::before { content: ''; position: absolute; top: -100px; right: -100px; width: 400px; height: 400px; background: #FFD1D1; border-radius: 50%; filter: blur(120px); opacity: 0.5; }
#renovatio-single-post .post-content { font-family: 'Lato', sans-serif; font-size: 1.1rem; line-height: 1.9; color: #333; }
#renovatio-single-post .post-content p { margin-bottom: 1.5rem; }
#renovatio-single-post .post-content h2 { font-family: 'Playfair Display', serif; font-size: 1.75rem; font-weight: 700; margin: 2.5rem 0 1rem; color: black; }
#renovatio-single-post .post-content h3 { font-family: 'Playfair Display', serif; font-size: 1.35rem; font-weight: 700; margin: 2rem 0 0.75rem; color: black; }
#renovatio-single-post .post-content ul, #renovatio-single-post .post-content ol { margin: 1.5rem 0; padding-left: 1.5rem; }
#renovatio-single-post .post-content li { margin-bottom: 0.5rem; }
#renovatio-single-post .post-content blockquote { border-left: 4px solid var(--rv-pink); padding: 1rem 1.5rem; margin: 2rem 0; background: #f9f9f9; font-style: italic; color: #555; }
#renovatio-single-post .post-content img { border-radius: 12px; margin: 2rem 0; max-width: 100%; height: auto; }
#renovatio-single-post .post-content a { color: var(--rv-pink); border-bottom: 1px solid transparent; transition: 0.3s; }
#renovatio-single-post .post-content a:hover { border-color: var(--rv-pink); }
#renovatio-single-post .category-badge { background: white; color: var(--rv-pink); padding: 0.35rem 1rem; border-radius: 50px; font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.15em; box-shadow: 0 2px 10px rgba(0, 0, 0, 0.08); display: inline-block; }
#renovatio-single-post .share-btn { width: 40px; height: 40px; border-radius: 50%; display: flex; align-items: center; justify-content: center; background: #f5f5f5; color: #666; transition: 0.3s; border: none; cursor: pointer; }
#renovatio-single-post .share-btn:hover { background: var(--rv-pink); color: white; }
#renovatio-single-post .related-card { transition: all 0.4s ease; display: block; }
#renovatio-single-post .related-card:hover { transform: translateY(-5px); }
#renovatio-single-post .related-card:hover h4 { color: var(--rv-pink); }
#renovatio-single-post .related-card img { transition: transform 0.5s ease; }
#renovatio-single-post .related-card:hover img { transform: scale(1.05); }

/* =============================================
   18. RESPONSIVE COMPARTIDO
   ============================================= */
@media (max-width: 1024px) {
    .ob-nav-menu { display: none; }
    .mobile-trigger { display: flex !important; }
    .ob-header { justify-content: space-between; }
    .ob-logo-link { order: 1; }
    .ob-header-actions { order: 2; display: flex; }
    #ob-hamburger { order: 3; }
    .ob-footer-grid { grid-template-columns: 1fr 1fr; }
    #renovatio-home-collections .collections-grid { grid-template-columns: repeat(2, 1fr); gap: 1rem; }
    #renovatio-home-instagram #sb_instagram #sbi_images { grid-template-columns: repeat(3, 1fr) !important; }
    .polaroid-grid { grid-template-columns: repeat(3, 1fr); gap: 1.5rem; }
}

@media (max-width: 768px) {
    :root { --header-height: 3.5rem; }
    .ob-search-form { flex-direction: column; }
    .ob-search-submit { width: 100%; justify-content: center; }
    .ob-search-submit-text { display: none; }
    .ob-search-submit::after { content: 'Buscar'; }
    .ob-footer-grid { grid-template-columns: 1fr; text-align: center; gap: 2.5rem; }
    .ob-title::after { left: 50%; transform: translateX(-50%); }
    .ob-desc, .ob-logo { margin-left: auto; margin-right: auto; }
    .ob-socials { justify-content: center; }
    .ob-contact-row { justify-content: center; }
    .ob-bottom { flex-direction: column; text-align: center; }
    .ob-legal a { margin: 0 10px; }
    #renovatio-home-hero { min-height: calc(100svh - var(--header-height)); padding: 1.5rem 1.5rem 4rem; }
    #renovatio-home-products .carousel-card { flex: 0 0 220px; min-width: 220px; }
    #renovatio-home-products .carousel-track { animation-duration: 35s; }
    #renovatio-home-testimonials .testimonial-card { min-width: 15rem; }
    #renovatio-home-testimonials .testimonial-track { animation-duration: 45s; }
    #renovatio-home-video { min-height: 70vh; }
    #renovatio-services-content .service-card-img { filter: none !important; }
    #renovatio-services-content .group h3 { transform: none !important; }
    #renovatio-services-content .group p { opacity: 1 !important; transform: none !important; }
    #renovatio-services-content .group a[class*="opacity-0"], #renovatio-services-content .group a { opacity: 1 !important; transform: none !important; }
    #renovatio-home-faces { padding: 4rem 4%; }
}

@media (max-width: 640px) {
    .polaroid-grid { grid-template-columns: repeat(2, 1fr); gap: 1rem; }
    #renovatio-home-collections .collections-grid { grid-template-columns: repeat(2, 1fr); gap: 0.75rem; }
    #renovatio-home-collections .collection-overlay { padding: 1.5rem 1rem 1rem; min-height: 100px; }
    #renovatio-home-collections .collection-overlay h3 { font-size: 0.95rem; }
}

@media (max-width: 480px) {
    #renovatio-home-products .carousel-card { flex: 0 0 180px; min-width: 180px; }
    #renovatio-home-products .carousel-track { animation-duration: 30s; }
    #renovatio-home-instagram #sb_instagram #sbi_images { grid-template-columns: repeat(2, 1fr) !important; }
}


/* ==========================================================================
   HEADER GLOBAL RENOVATIO
   ========================================================================== */

#renovatio-header-module {
    font-family: 'Lato', sans-serif;
}

.ob-header {
    position: fixed;
    top: var(--wp-admin-bar);
    left: 0;
    width: 100%;
    height: var(--header-height);
    background: rgba(255, 255, 255, 0.1);
    -webkit-backdrop-filter: blur(12px);
    backdrop-filter: blur(12px);
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
    z-index: 9999;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 5%;
    transition: all 0.4s ease;
}
.ob-header.scrolled {
    background: rgba(255, 255, 255, 0.95);
    border-bottom: 1px solid rgba(0, 0, 0, 0.05);
    box-shadow: 0 4px 30px rgba(0, 0, 0, 0.08);
}
.ob-logo-img {
    max-height: 36px;
    width: auto;
    object-fit: contain;
}

/* MENÚ ESCRITORIO */
.ob-nav-menu {
    flex-grow: 1;
    display: flex;
    justify-content: center;
    height: 100%;
}
.ob-menu-list {
    display: flex;
    list-style: none;
    gap: 2.5rem;
    height: 100%;
    align-items: center;
    margin: 0;
    padding: 0;
}
.ob-menu-item > a {
    text-decoration: none;
    color: var(--ob-primary);
    text-transform: uppercase;
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 2px;
    transition: color 0.3s;
}
.ob-menu-item > a:hover {
    color: var(--ob-accent);
}

/* DROPDOWN */
.ob-has-dropdown {
    position: relative;
}
.ob-has-dropdown > a {
    display: flex;
    align-items: center;
}
.ob-dropdown {
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%) translateY(10px);
    background: white;
    border-radius: 12px;
    box-shadow: 0 15px 40px rgba(0, 0, 0, 0.15);
    min-width: 220px;
    padding: 0.75rem 0;
    list-style: none;
    opacity: 0;
    visibility: hidden;
    transition: all 0.3s ease;
    z-index: 100;
    margin: 0;
}
.ob-has-dropdown:hover .ob-dropdown {
    opacity: 1;
    visibility: visible;
    transform: translateX(-50%) translateY(0);
}
.ob-dropdown li a {
    display: block;
    padding: 0.75rem 1.5rem;
    color: var(--ob-primary) !important;
    font-size: 0.8rem;
    text-transform: none;
    letter-spacing: 0.5px;
    transition: 0.3s ease;
    text-decoration: none;
}
.ob-dropdown li a:hover {
    background: #f8f8f8;
    color: var(--ob-accent) !important;
    padding-left: 1.75rem;
}

/* ACCIONES */
.ob-header-actions {
    display: flex;
    gap: 1.25rem;
    align-items: center;
    height: 100%;
}
.ob-action-btn {
    background: transparent !important;
    border: none;
    cursor: pointer;
    font-size: 1.35rem;
    color: var(--ob-primary);
    transition: color 0.3s ease;
    padding: 0.5rem;
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
    outline: none;
    text-decoration: none;
}
.ob-action-btn:hover {
    color: var(--ob-accent);
}

/* BADGE CARRITO */
.cart-icon-wrapper {
    position: relative;
    display: flex;
    align-items: center;
}
.header-cart-badge {
    position: absolute;
    top: -4px;
    right: -6px;
    background-color: var(--ob-primary);
    color: white;
    font-size: 9px;
    font-weight: 700;
    height: 15px;
    min-width: 15px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: 'Lato', sans-serif;
    pointer-events: none;
    border: 2px solid #ffffff;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
    line-height: 1;
}

/* PANEL DE BÚSQUEDA */
.ob-search-overlay {
    position: fixed;
    top: 0; left: 0;
    width: 100%; height: 100%;
    background: rgba(0, 0, 0, 0.6);
    backdrop-filter: blur(4px);
    z-index: 10003;
    opacity: 0;
    visibility: hidden;
    transition: all 0.3s ease;
}
.ob-search-overlay.active {
    opacity: 1;
    visibility: visible;
}
.ob-search-panel {
    position: fixed;
    top: 0; left: 0;
    width: 100%;
    background: white;
    z-index: 10004;
    transform: translateY(-100%);
    transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1);
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.15);
}
.ob-search-panel.active {
    transform: translateY(0);
}
.ob-search-container {
    max-width: 800px;
    margin: 0 auto;
    padding: 2rem 5%;
}
.ob-search-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 1.5rem;
}
.ob-search-title {
    font-family: 'Playfair Display', serif;
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--ob-primary);
    margin: 0;
}
.ob-search-close {
    background: none;
    border: none;
    font-size: 1.5rem;
    cursor: pointer;
    color: var(--ob-primary);
    padding: 0.5rem;
    transition: color 0.3s;
}
.ob-search-close:hover { color: var(--ob-pink); }
.ob-search-form {
    display: flex;
    gap: 0.75rem;
    align-items: center;
}
.ob-search-input-wrap {
    flex: 1;
    position: relative;
}
.ob-search-input {
    width: 100%;
    padding: 1rem 1.25rem 1rem 3.5rem !important;
    font-size: 1rem;
    border: 2px solid #eee;
    border-radius: 50px;
    outline: none;
    font-family: 'Lato', sans-serif;
    transition: all 0.3s ease;
    box-sizing: border-box;
}
.ob-search-input:focus {
    border-color: var(--ob-pink);
    box-shadow: 0 0 0 4px rgba(233, 80, 74, 0.1);
}
.ob-search-input::placeholder { color: #aaa; }
.ob-search-icon {
    position: absolute;
    left: 1.25rem;
    top: 50%;
    transform: translateY(-50%);
    color: #aaa;
    font-size: 1.1rem;
    pointer-events: none;
    z-index: 2;
}
.ob-search-submit {
    background: var(--ob-pink);
    color: white;
    border: none;
    padding: 1rem 2rem;
    border-radius: 50px;
    font-weight: 700;
    font-size: 0.9rem;
    cursor: pointer;
    transition: all 0.3s ease;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}
.ob-search-submit:hover {
    background: var(--rv-pink-hover);
    transform: translateY(-2px);
}
.ob-search-suggestions {
    margin-top: 1.5rem;
    padding-top: 1.5rem;
    border-top: 1px solid #eee;
}
.ob-search-suggestions-title {
    font-size: 0.75rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: #888;
    margin-bottom: 0.75rem;
}
.ob-search-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}
.ob-search-tag {
    background: #f5f5f5;
    color: var(--ob-primary);
    padding: 0.5rem 1rem;
    border-radius: 50px;
    font-size: 0.85rem;
    text-decoration: none;
    transition: all 0.3s ease;
}
.ob-search-tag:hover {
    background: var(--ob-pink);
    color: white;
}

/* MENÚ MÓVIL */
.ob-mobile-menu {
    position: fixed;
    top: 0;
    right: -100%;
    left: auto;
    width: 85%;
    max-width: 320px;
    height: 100vh;
    background: white;
    z-index: 10002;
    transition: right 0.4s cubic-bezier(0.16, 1, 0.3, 1);
    padding: 2rem;
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
    box-shadow: -5px 0 25px rgba(0, 0, 0, 0.15);
    box-sizing: border-box;
}
.ob-mobile-menu.active { right: 0; }
.ob-mobile-submenu {
    list-style: none;
    padding: 0;
    margin: 0 0 0 1rem;
}
.ob-mobile-submenu li { margin: 0; }
.ob-mobile-submenu a {
    text-decoration: none;
    color: #666;
    font-size: 0.9rem;
    font-weight: 600;
    padding: 0.6rem 0;
    display: block;
    transition: 0.3s;
}
.ob-mobile-submenu a:hover {
    color: var(--ob-pink);
    padding-left: 0.5rem;
}
.ob-overlay {
    position: fixed;
    top: 0; left: 0;
    width: 100%; height: 100%;
    background: rgba(0, 0, 0, 0.6);
    z-index: 10001;
    opacity: 0;
    visibility: hidden;
    transition: 0.3s;
    backdrop-filter: blur(4px);
}
.ob-overlay.active {
    opacity: 1;
    visibility: visible;
}
.ob-mobile-link {
    text-decoration: none;
    color: var(--ob-primary);
    font-size: 1.1rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1px;
    padding: 1rem 0;
    border-bottom: 1px solid #eee;
    display: block;
}
.ob-mobile-search {
    display: flex;
    gap: 0.5rem;
    padding: 0.75rem 0;
    border-bottom: 1px solid #eee;
}
.ob-mobile-search-input {
    flex: 1;
    padding: 0.75rem 1rem !important;
    border: 2px solid #eee;
    border-radius: 50px;
    font-size: 0.9rem;
    outline: none;
    box-sizing: border-box;
}
.ob-mobile-search-input:focus { border-color: var(--ob-pink); }
.ob-mobile-search-btn {
    background: var(--ob-pink);
    color: white;
    border: none;
    width: 44px;
    height: 44px;
    border-radius: 50%;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.1rem;
    flex-shrink: 0;
}
.btn-renovatio {
    background: var(--ob-pink);
    color: white;
    padding: 0.875rem 2rem;
    border-radius: 50px;
    font-weight: 700;
    letter-spacing: 1px;
    transition: 0.3s;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    font-size: 0.85rem;
    border: none;
}
.btn-renovatio:hover {
    background: var(--rv-pink-hover);
    color: white;
}
.mobile-trigger { display: none; }
.ob-search-submit-text { display: inline; }
.header-spacer {
    height: calc(var(--header-height) + var(--wp-admin-bar, 0px));
}

/* RESPONSIVE HEADER */
@media (max-width: 1024px) {
    .ob-nav-menu { display: none; }
    .mobile-trigger { display: flex !important; }
    .ob-logo-link { order: 1; }
    .ob-header-actions { order: 2; display: flex; align-items: center; }
    #ob-hamburger { order: 3; }
}
@media (max-width: 768px) {
    .ob-search-container { padding: 1.5rem 5%; }
    .ob-search-title { font-size: 1.25rem; }
    .ob-search-form { flex-direction: column; }
    .ob-search-input-wrap { width: 100%; }
    .ob-search-input { padding-left: 3rem !important; }
    .ob-search-submit { width: 100%; justify-content: center; }
    .ob-search-submit-text { display: none; }
    .ob-search-submit::after { content: 'Buscar'; }
}


/* ==========================================================================
   MÓDULO TIENDA — RV SHOP
   ========================================================================== */

#rv-shop-module {
    font-family: 'Inter', sans-serif;
    color: var(--rv-black);
    width: 100%;
    box-sizing: border-box;
    padding: 2rem 1.5rem 5rem;
    clear: both;
    overflow: hidden;
}
@media (min-width: 1024px) { #rv-shop-module { padding: 4rem 6% 6rem; } }
#rv-shop-module * { box-sizing: border-box; }
#rv-shop-module .font-display { font-family: 'Playfair Display', serif; }

/* HERO */
#rv-shop-module .rv-hero {
    text-align: center; padding: 4.5rem 1rem;
    background: #fdfdfd; border-radius: 2rem; margin-bottom: 4rem;
    border: 1px solid #f3f3f3;
}
#rv-shop-module .rv-hero .tagline { font-size: 0.8rem; font-weight: 800; color: var(--rv-pink); letter-spacing: 0.15em; text-transform: uppercase; margin-bottom: 0.75rem; display: block; }
#rv-shop-module .rv-hero .title { font-size: 2.6rem; font-weight: 700; margin-bottom: 1.5rem; line-height: 1.1; color: var(--rv-black); }
@media (min-width: 768px) { #rv-shop-module .rv-hero .title { font-size: 3.8rem; } }
#rv-shop-module .rv-hero-pills { display: flex; justify-content: center; flex-wrap: wrap; gap: 0.8rem; }
#rv-shop-module .rv-hero-pill {
    padding: 0.75rem 1.75rem; border-radius: 3rem; background: white; color: var(--rv-gray, #71717a);
    font-weight: 700; font-size: 0.9rem; text-decoration: none; border: 1px solid #e5e7eb;
    transition: 0.3s cubic-bezier(0.19, 1, 0.22, 1); cursor: pointer;
}
#rv-shop-module .rv-hero-pill:hover,
#rv-shop-module .rv-hero-pill.active { background: var(--rv-black); color: #fff; border-color: var(--rv-black); transform: translateY(-3px); box-shadow: 0 10px 20px rgba(0,0,0,0.1); }
#rv-shop-module .rv-hero-pill.ofertas { color: var(--rv-pink); border-color: rgba(233,80,74,0.2); }
#rv-shop-module .rv-hero-pill.ofertas:hover,
#rv-shop-module .rv-hero-pill.ofertas.active { background: var(--rv-pink); color: white; border-color: var(--rv-pink); }

/* FIX CRÍTICO: Forzar shortcode widget a romper fuera de su contenedor Elementor */
/* Elementor da solo ~304px al widget. Usamos el truco de 100vw para expandir. */
.elementor-widget-shortcode:has(#rv-shop-module) {
    width: 100vw !important;
    max-width: 100vw !important;
    position: relative !important;
    left: 50% !important;
    margin-left: -50vw !important;
    margin-right: -50vw !important;
    overflow: hidden !important;
    box-sizing: border-box !important;
    padding: 0 5% !important;
}
 /* FIX SAFARI: Fallback para versiones de Safari que no soportan :has() */
.elementor-widget-shortcode > .elementor-widget-container > .elementor-shortcode > #rv-shop-module {
     width: 100vw !important;
     position: relative !important;
     left: 50% !important;
     transform: translateX(-50%) !important;
     margin: 0 !important;
 }

/* Fallback por data-id para navegadores sin :has() */
.elementor-element-b0528ea {
    width: 100vw !important;
    max-width: 100vw !important;
    position: relative !important;
    left: 50% !important;
    margin-left: -50vw !important;
    margin-right: -50vw !important;
    overflow: hidden !important;
    box-sizing: border-box !important;
    padding: 0 5% !important;
}
.elementor-element-b0528ea > .elementor-widget-container,
.elementor-element-b0528ea > .elementor-widget-container > .elementor-shortcode {
    width: 100% !important; max-width: 100% !important; min-width: 0 !important;
}

/* LAYOUT */
#rv-shop-module .rv-layout { display: flex; flex-direction: column; gap: 2.5rem; width: 100% !important; min-width: 0 !important; max-width: 100% !important; overflow: hidden !important; }
#rv-shop-module .rv-sidebar { display: none; }

@media (min-width: 1024px) {
    #rv-shop-module .rv-layout {
        display: grid !important;
        grid-template-columns: 260px 1fr;
        gap: 3.5rem;
        align-items: start;
    }
    #rv-shop-module .rv-sidebar { display: block; }
    #rv-shop-module .rv-main { min-width: 0; width: 100% !important; flex: 1 !important; }
}

/* SIDEBAR */
#rv-shop-module .rv-widget { margin-bottom: 3rem; }
#rv-shop-module .rv-widget-title { font-size: 1.15rem; font-weight: 800; margin-bottom: 1.5rem; border-bottom: 2px solid #f3f4f6; padding-bottom: 0.8rem; color: var(--rv-black); }
#rv-shop-module .rv-widget-list { list-style: none; padding: 0; margin: 0; }
#rv-shop-module .rv-widget-list li { margin-bottom: 0.5rem; }
#rv-shop-module .rv-filter-link { display: flex; justify-content: space-between; padding: 6px 0; color: #71717a; font-size: 0.95rem; cursor: pointer; text-decoration: none; transition: 0.2s; font-weight: 500; }
#rv-shop-module .rv-filter-link:hover { color: var(--rv-pink); padding-left: 5px; }
#rv-shop-module .rv-filter-link.rv-active { color: var(--rv-pink); font-weight: 800; }

/* GRID */
#rv-shop-module .rv-grid { 
    display: grid !important; 
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important; 
    gap: 20px !important; 
    width: 100% !important;
    min-height: 600px;
    align-content: start;
}

#rv-shop-module .rv-grid::before,
#rv-shop-module .rv-grid::after {
     display: none !important;
     content: none !important;
 }
@media (min-width: 768px) { #rv-shop-module .rv-grid { gap: 30px !important; } }
@media (min-width: 1200px) { #rv-shop-module .rv-grid { grid-template-columns: repeat(3, minmax(0, 1fr)) !important; } }

/* CARDS */
#rv-shop-module .rv-product-card,
#rv-shop-module .rv-item,
#rv-shop-module .type-product {
    background: #fff; border-radius: 1.5rem; border: 1px solid #f3f4f6;
    display: flex !important; flex-direction: column; overflow: hidden;
    height: auto !important; min-height: 450px !important;
    position: relative !important; float: none !important;
    transition: transform 0.4s ease, box-shadow 0.4s ease; text-decoration: none;
    width: 100% !important;
    grid-column: span 1 !important;
}
#rv-shop-module .rv-product-card:hover { transform: translateY(-10px); box-shadow: 0 25px 50px rgba(0,0,0,0.06); }
#rv-shop-module .image-wrap,
#rv-shop-module .rv-img-wrap { 
    position: relative !important; 
    width: 100% !important;
    height: 0 !important;
    padding-bottom: 125% !important; /* Proporción 4:5 manual para compatibilidad */
    background: #fff; 
    overflow: hidden; 
    display: block !important;
    flex-shrink: 0 !important; /* FIX SAFARI: Evita el colapso de altura en flexbox */
  }
}
#rv-shop-module .image-wrap img,
#rv-shop-module .rv-img-wrap img { 
    position: absolute !important;
    top: 0; left: 0;
    width: 100% !important; 
    height: 100% !important; 
    object-fit: contain !important; 
    transition: transform 0.8s ease; 
}
#rv-shop-module .rv-product-card:hover img { transform: scale(1.1); }

/* Badge de Oferta */
#rv-shop-module .rv-badge-sale {
    position: absolute; top: 1rem; left: 1rem;
    background: var(--rv-pink); color: white;
    padding: 4px 12px; border-radius: 30px;
    font-weight: 800; font-size: 10px; z-index: 10;
    box-shadow: 0 4px 10px rgba(233, 80, 74, 0.3);
}

/* Placeholder para cuando no hay imagen */
#rv-shop-module .rv-placeholder-img {
    width: 100%; height: 100%; display: flex;
    align-items: center; justify-content: center;
    background: #f8f8f8; color: #ccc; font-size: 3rem;
}
#rv-shop-module .card-content,
#rv-shop-module .rv-card-body { padding: 1rem; display: flex; flex-direction: column; flex-grow: 1; }
@media (min-width: 768px) {
    #rv-shop-module .card-content,
    #rv-shop-module .rv-card-body { padding: 1.75rem; }
}
#rv-shop-module .rv-product-card h3,
#rv-shop-module .rv-card-title { font-size: 0.95rem; font-weight: 700; margin: 0 0 0.4rem; color: var(--rv-black); line-height: 1.25; }
@media (min-width: 768px) {
    #rv-shop-module .rv-product-card h3,
    #rv-shop-module .rv-card-title { font-size: 1.15rem; }
}
#rv-shop-module .category-name,
#rv-shop-module .rv-card-desc { font-size: 0.65rem; color: #9ca3af; margin-bottom: 1rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.05em; }
@media (min-width: 768px) {
    #rv-shop-module .category-name,
    #rv-shop-module .rv-card-desc { font-size: 0.75rem; margin-bottom: 1.5rem; }
}

/* CARD FOOTER — precio y botones */
#rv-shop-module .card-footer,
#rv-shop-module .rv-card-footer { margin-top: auto; display: flex; flex-wrap: wrap; justify-content: space-between; align-items: center; padding-top: 1rem; border-top: 1px solid #f9f9f9; gap: 0.5rem; }

/* Título con Playfair — igual que página de producto */
#rv-shop-module .rv-product-card h3,
#rv-shop-module .rv-card-title {
    font-family: 'Playfair Display', serif;
    font-size: 0.95rem; font-weight: 700; margin: 0 0 0.4rem; color: var(--rv-black); line-height: 1.25;
}
@media (min-width: 768px) {
    #rv-shop-module .rv-product-card h3,
    #rv-shop-module .rv-card-title { font-size: 1.1rem; }
}

/* Precio en rosa — igual que página de producto individual */
#rv-shop-module .price,
#rv-shop-module .rv-price { color: var(--rv-pink); font-weight: 800; font-size: 1.05rem; width: 100%; }
@media (min-width: 768px) {
    #rv-shop-module .price,
    #rv-shop-module .rv-price { font-size: 1.2rem; }
}

/* Descripción corta en cards de tienda */
#rv-shop-module .rv-card-short-desc {
    font-size: 0.72rem;
    color: #9ca3af;
    line-height: 1.5;
    margin: 0.35rem 0 0.75rem;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

/* Descripción corta en cards de accesorios (página de producto) */
html body #renovatio-product-module .rv-product-card-desc {
    font-size: 0.78rem !important;
    color: var(--rv-gray-600) !important;
    line-height: 1.5 !important;
    margin: 0.25rem 0 0.5rem !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 2 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
}

/* Botones del card — VER + AL CARRO side by side */
#rv-shop-module .card-actions {
    display: flex;
    flex-direction: row;
    align-items: stretch;
    gap: 0.5rem;
    width: 100%;
    margin-top: 0.5rem;
}

#rv-shop-module .btn-view {
    flex: 1;
    background: #f4f4f5; color: var(--rv-black) !important;
    padding: 0.65rem 0.75rem; border-radius: 3rem;
    font-size: 0.7rem; font-weight: 800;
    text-decoration: none; transition: background 0.3s ease;
    letter-spacing: 0.05em; white-space: nowrap;
    display: flex; align-items: center; justify-content: center;
    min-height: 2.5rem;
}
#rv-shop-module .btn-view:hover { background: #e5e7eb; }

/* Botón AL CARRO — pill redondeado, permanente (desktop + móvil) */
#rv-shop-module .btn-add-circle,
#rv-shop-module .quick-add,
#rv-shop-module .add_to_cart_button {
    /* Anula el opacity:0/transform global — siempre visible */
    opacity: 1 !important;
    transform: none !important;
    position: static !important;   /* saca del absolute del global */

    flex: 1 !important;
    width: auto !important;
    min-width: 0 !important;
    max-width: none !important;
    height: auto !important;
    min-height: 2.5rem !important;
    border-radius: 3rem !important;
    background: var(--rv-pink) !important;
    color: white !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 0.35rem !important;
    font-size: 0.7rem !important;
    font-weight: 800 !important;
    letter-spacing: 0.05em !important;
    text-transform: uppercase !important;
    border: none !important;
    cursor: pointer !important;
    transition: background 0.3s ease, box-shadow 0.3s ease, transform 0.3s ease !important;
    text-decoration: none !important;
    flex-shrink: 1 !important;
    padding: 0.65rem 0.75rem !important;
    line-height: 1.2 !important;
    box-shadow: 0 6px 18px rgba(233,80,74,0.25) !important;
    white-space: nowrap !important;
    box-sizing: border-box !important;
}
#rv-shop-module .btn-add-circle:hover,
#rv-shop-module .quick-add:hover,
#rv-shop-module .add_to_cart_button:hover {
    background: #d4453f !important;
    color: white !important;
    box-shadow: 0 10px 24px rgba(233,80,74,0.35) !important;
    transform: translateY(-2px) !important;
}
#rv-shop-module .add_to_cart_button.loading {
    opacity: 0.7 !important;
    pointer-events: none !important;
    transform: none !important;
}
#rv-shop-module .add_to_cart_button.added {
    background: var(--rv-gold) !important;
    box-shadow: 0 4px 12px rgba(208,165,80,0.3) !important;
    transform: none !important;
}

/* En móviles muy pequeños: texto e ícono más compactos */
@media (max-width: 400px) {
    #rv-shop-module .btn-view,
    #rv-shop-module .quick-add,
    #rv-shop-module .add_to_cart_button {
        font-size: 0.62rem !important;
        padding: 0.55rem 0.5rem !important;
    }
    #rv-shop-module .quick-add .ph,
    #rv-shop-module .add_to_cart_button .ph { display: none !important; }
}

/* PAGINACIÓN */
#rv-shop-module .rv-pagination {
    display: flex; justify-content: center; align-items: center; gap: 0.5rem; flex-wrap: wrap;
    margin-top: 4.5rem; padding-top: 2rem; border-top: 1px solid #f3f4f6; grid-column: 1 / -1;
}
#rv-shop-module .rv-pag-btn {
    width: 3.2rem; height: 3.2rem; border-radius: 50%; background: white;
    color: var(--rv-black); border: 1px solid #e5e7eb; font-weight: 800;
    cursor: pointer; transition: 0.3s; font-size: 1rem;
    display: flex; align-items: center; justify-content: center;
}
#rv-shop-module .rv-pag-btn:hover,
#rv-shop-module .rv-pag-btn.active { background: var(--rv-black); color: white; border-color: var(--rv-black); transform: translateY(-3px); box-shadow: 0 8px 15px rgba(0,0,0,0.1); }
#rv-shop-module .rv-pag-dots { color: #71717a; font-weight: 800; font-size: 1.2rem; display: flex; align-items: center; padding: 0 0.2rem; }

/* LOADER y EMPTY */
#rv-shop-module .rv-loader { grid-column: 1 / -1; text-align: center; padding: 6rem 1rem; }
#rv-shop-module .rv-spinner { width: 50px; height: 50px; border: 4px solid #f3f4f6; border-top-color: var(--rv-gold); border-radius: 50%; animation: spin 1s linear infinite; margin: 0 auto 1.5rem; }
#rv-shop-module .rv-empty { display: none; text-align: center; padding: 6.5rem 1rem; grid-column: 1 / -1; border-radius: 2rem; background: #fafafa; border: 2px dashed #eee; }

/* Estado error temporal — botones AL CARRO y REGALAR */
#rv-shop-module .quick-add.rv-btn-error,
#rv-shop-module .add_to_cart_button.rv-btn-error,
.giftcard-actions .gc-add-btn.rv-btn-error {
    background: #ef4444 !important;
    box-shadow: 0 4px 12px rgba(239, 68, 68, 0.3) !important;
    transform: none !important;
    opacity: 1 !important;
}


/* ==========================================================================
   MÓDULO PÁGINA DE PRODUCTO — #renovatio-product-module
   Extraído del HTML inline — v5.5
   ========================================================================== */

html body #renovatio-product-module,
html body #renovatio-product-module *,
html body #renovatio-product-module *::before,
html body #renovatio-product-module *::after {
    box-sizing: border-box !important;
    margin: 0 !important;
    padding: 0 !important;
}
html body #renovatio-product-module {
    --rv-primary: #000000;
    --rv-accent: #D0A550;
    --rv-pink: #E9504A;
    --rv-bg: #FFF5F5;
    --rv-white: #ffffff;
    --rv-gray-100: #F3F4F6;
    --rv-gray-200: #E5E7EB;
    --rv-gray-400: #9CA3AF;
    --rv-gray-600: #6B7280;
    --rv-gray-900: #111827;
    font-family: 'Inter', sans-serif !important;
    width: 100% !important;
    min-height: 800px !important;
    background-color: var(--rv-bg) !important;
    position: relative !important;
    z-index: 100 !important;
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
}
html body #renovatio-product-module .font-display { font-family: 'Playfair Display', serif !important; }
html body #renovatio-product-module .font-body    { font-family: 'Lato', sans-serif !important; }

/* Contenedor */
html body #renovatio-product-module .rv-section {
    padding: 3rem 1.5rem !important;
    max-width: 1280px !important;
    margin: 0 auto !important;
    position: relative !important;
    z-index: 10 !important;
}
@media (min-width: 1024px) {
    html body #renovatio-product-module .rv-section { padding: 5rem 1.5rem !important; }
}

/* Orbs decorativos */
html body #renovatio-product-module .rv-bg-decoration {
    position: absolute !important; top: 0 !important; left: 0 !important;
    width: 100% !important; height: 100% !important;
    overflow: hidden !important; pointer-events: none !important; z-index: 0 !important;
}
html body #renovatio-product-module .atmo-orb {
    position: absolute !important; border-radius: 9999px !important; filter: blur(100px) !important;
}
html body #renovatio-product-module .atmo-orb:nth-child(1) {
    top: -5rem !important; left: -5rem !important;
    width: 20rem !important; height: 20rem !important;
    background-color: #FFD1D1 !important; opacity: 0.4 !important;
}
html body #renovatio-product-module .atmo-orb:nth-child(2) {
    bottom: 10rem !important; right: 0 !important;
    width: 24rem !important; height: 24rem !important;
    background-color: #FFE4E4 !important; opacity: 0.5 !important;
}

/* Grid producto */
html body #renovatio-product-module .rv-product-grid {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 3rem !important;
    position: relative !important;
    z-index: 10 !important;
}
@media (min-width: 1024px) {
    html body #renovatio-product-module .rv-product-grid {
        grid-template-columns: 1fr 1fr !important;
        gap: 4rem !important;
    }
}

/* Galería */
html body #renovatio-product-module .rv-gallery {
    display: flex !important; flex-direction: column !important; gap: 1rem !important;
}
html body #renovatio-product-module .rv-main-image-container {
    aspect-ratio: 4/5 !important;
    background: var(--rv-white) !important;
    border-radius: 1rem !important;
    overflow: hidden !important;
    position: relative !important;
    border: 1px solid rgba(233, 80, 74, 0.1) !important;
    box-shadow: 0 20px 25px -5px rgba(233, 80, 74, 0.05) !important;
}
html body #renovatio-product-module .rv-main-image {
    width: 90% !important; height: 90% !important; object-fit: contain !important;
    transition: transform 0.7s ease !important; display: block !important; margin: 5% auto !important;
}
html body #renovatio-product-module .rv-main-image-container:hover .rv-main-image { transform: scale(1.05) !important; }
html body #renovatio-product-module .rv-badge-new {
    position: absolute !important; top: 1rem !important; left: 1rem !important;
    background: var(--rv-white) !important; color: var(--rv-primary) !important;
    font-size: 10px !important; font-weight: 700 !important;
    padding: 0.5rem 1rem !important; border-radius: 9999px !important;
    border: 1px solid var(--rv-pink) !important; letter-spacing: 0.1em !important; z-index: 5 !important;
}

/* Miniaturas */
html body #renovatio-product-module .rv-thumbnails {
    display: grid !important; grid-template-columns: repeat(4, 1fr) !important; gap: 0.75rem !important;
}
html body #renovatio-product-module .rv-thumb {
    aspect-ratio: 1 !important; background: var(--rv-white) !important;
    border-radius: 0.75rem !important; overflow: hidden !important; cursor: pointer !important;
    border: 2px solid transparent !important; padding: 0.25rem !important; transition: border-color 0.3s !important;
}
html body #renovatio-product-module .rv-thumb.active  { border-color: var(--rv-pink) !important; }
html body #renovatio-product-module .rv-thumb:hover   { border-color: rgba(233, 80, 74, 0.5) !important; }
html body #renovatio-product-module .rv-thumb img {
    width: 100% !important; height: 100% !important; object-fit: cover !important;
    border-radius: 0.5rem !important; display: block !important;
}

/* Columna de info */
html body #renovatio-product-module .rv-info { display: flex !important; flex-direction: column !important; }
html body #renovatio-product-module .rv-breadcrumb {
    font-size: 10px !important; letter-spacing: 0.2em !important; color: var(--rv-gray-400) !important;
    text-transform: uppercase !important; margin-bottom: 1rem !important; font-weight: 700 !important;
}
html body #renovatio-product-module .rv-breadcrumb a {
    color: inherit !important; text-decoration: none !important; transition: color 0.3s !important;
}
html body #renovatio-product-module .rv-breadcrumb a:hover { color: var(--rv-pink) !important; }
html body #renovatio-product-module .rv-title {
    font-family: 'Playfair Display', serif !important;
    font-size: 2.5rem !important; font-weight: 700 !important;
    color: var(--rv-gray-900) !important; line-height: 1.2 !important; margin-bottom: 1rem !important;
}
@media (min-width: 1024px) {
    html body #renovatio-product-module .rv-title { font-size: 3.5rem !important; }
}
html body #renovatio-product-module .rv-title-accent { color: var(--rv-pink) !important; }

/* Precio */
html body #renovatio-product-module .rv-price-box {
    display: flex !important; align-items: baseline !important; gap: 1rem !important;
    padding-bottom: 1.5rem !important; margin-bottom: 1.5rem !important;
    border-bottom: 1px solid var(--rv-gray-200) !important;
}
html body #renovatio-product-module .rv-price {
    color: var(--rv-pink) !important; font-weight: 700 !important;
    font-size: 2rem !important; letter-spacing: -0.025em !important;
}
html body #renovatio-product-module .rv-price-old {
    color: var(--rv-gray-400) !important; text-decoration: line-through !important; font-size: 1rem !important;
}

/* Descripción */
html body #renovatio-product-module .rv-description {
    font-family: 'Lato', sans-serif !important; color: var(--rv-gray-600) !important;
    line-height: 1.7 !important; font-size: 0.9rem !important; margin-bottom: 1.5rem !important;
}
html body #renovatio-product-module .rv-link-specs {
    display: inline-flex !important; align-items: center !important; gap: 0.25rem !important;
    color: var(--rv-pink) !important; font-weight: 700 !important; font-size: 11px !important;
    text-transform: uppercase !important; letter-spacing: 0.15em !important;
    border-bottom: 1px solid rgba(233, 80, 74, 0.3) !important; padding-bottom: 2px !important;
    text-decoration: none !important; transition: all 0.3s !important;
}
html body #renovatio-product-module .rv-link-specs:hover { border-color: var(--rv-pink) !important; }

/* Variantes */
html body #renovatio-product-module .rv-variants-box {
    background: var(--rv-white) !important; padding: 1.5rem !important;
    border-radius: 1rem !important; border: 1px solid var(--rv-gray-100) !important; margin-bottom: 1.5rem !important;
}
html body #renovatio-product-module .rv-variants-label {
    font-size: 10px !important; font-weight: 700 !important; letter-spacing: 0.15em !important;
    text-transform: uppercase !important; color: var(--rv-gray-400) !important;
    margin-bottom: 1rem !important; display: block !important;
}
html body #renovatio-product-module .rv-variants { display: flex !important; gap: 1rem !important; }
html body #renovatio-product-module .rv-variant-btn {
    width: 2.5rem !important; height: 2.5rem !important; border-radius: 9999px !important;
    border: 2px solid var(--rv-gray-200) !important; cursor: pointer !important; transition: all 0.3s !important;
}
html body #renovatio-product-module .rv-variant-btn:hover { transform: scale(1.1) !important; }
html body #renovatio-product-module .rv-variant-btn.selected {
    transform: scale(1.15) !important;
    box-shadow: 0 0 0 3px var(--rv-white), 0 0 0 5px var(--rv-pink) !important;
}

/* Formulario de compra */
html body #renovatio-product-module .rv-purchase-form {
    display: flex !important; flex-direction: column !important;
    gap: 1rem !important; margin-bottom: 1.5rem !important;
}
html body #renovatio-product-module .rv-purchase-controls { display: flex !important; gap: 1rem !important; }
html body #renovatio-product-module .rv-qty-selector {
    display: flex !important; align-items: center !important;
    border: 1px solid var(--rv-gray-200) !important; border-radius: 9999px !important;
    padding: 0 1rem !important; height: 3.5rem !important; width: 7rem !important;
    justify-content: space-between !important; background: var(--rv-gray-100) !important;
}
html body #renovatio-product-module .rv-qty-btn {
    color: var(--rv-gray-400) !important; cursor: pointer !important;
    background: none !important; border: none !important;
    font-size: 1.25rem !important; padding: 0.5rem !important;
    transition: color 0.3s !important; line-height: 1 !important;
}
html body #renovatio-product-module .rv-qty-btn:hover  { color: var(--rv-pink) !important; }
html body #renovatio-product-module .rv-qty-display    { font-weight: 700 !important; font-size: 1rem !important; color: var(--rv-gray-900) !important; }
html body #renovatio-product-module .rv-add-btn {
    flex: 1 !important; background: var(--rv-pink) !important; color: var(--rv-white) !important;
    height: 3.5rem !important; border-radius: 9999px !important;
    font-weight: 700 !important; font-size: 12px !important; letter-spacing: 0.2em !important;
    text-transform: uppercase !important; border: none !important; cursor: pointer !important;
    display: flex !important; align-items: center !important; justify-content: center !important;
    gap: 0.75rem !important; transition: all 0.3s !important;
    box-shadow: 0 10px 25px -5px rgba(233, 80, 74, 0.3) !important;
}
html body #renovatio-product-module .rv-add-btn:hover {
    background: #d4453f !important; transform: translateY(-2px) !important;
    box-shadow: 0 15px 30px -5px rgba(233, 80, 74, 0.4) !important;
}
html body #renovatio-product-module .rv-add-btn i { font-size: 1.25rem !important; transition: transform 0.3s !important; }
html body #renovatio-product-module .rv-add-btn:hover i { transform: rotate(12deg) !important; }
html body #renovatio-product-module .rv-add-btn.rv-loading { pointer-events: none !important; opacity: 0.7 !important; }
@keyframes rv-spin { to { transform: rotate(360deg); } }
html body #renovatio-product-module .rv-purchase-note {
    font-size: 11px !important; color: var(--rv-gray-400) !important;
    text-align: center !important; font-style: italic !important; line-height: 1.6 !important;
}

/* Tags de servicio */
html body #renovatio-product-module .rv-services {
    display: flex !important; flex-wrap: wrap !important; gap: 1rem !important; margin-top: 2rem !important;
}
html body #renovatio-product-module .rv-service-tag {
    display: flex !important; align-items: center !important; gap: 0.75rem !important;
    padding: 0.75rem !important; border-radius: 0.75rem !important; transition: all 0.3s !important;
}
html body #renovatio-product-module .rv-service-tag:hover {
    background: var(--rv-white) !important; box-shadow: 0 4px 6px -1px rgba(0,0,0,0.05) !important;
}
html body #renovatio-product-module .rv-service-icon {
    width: 2.5rem !important; height: 2.5rem !important; border-radius: 9999px !important;
    background: var(--rv-white) !important; display: flex !important; align-items: center !important;
    justify-content: center !important; color: var(--rv-pink) !important; font-size: 1.25rem !important;
    border: 1px solid var(--rv-gray-100) !important; box-shadow: 0 2px 4px rgba(0,0,0,0.05) !important;
    flex-shrink: 0 !important;
}
html body #renovatio-product-module .rv-service-text {
    font-size: 10px !important; font-weight: 700 !important; text-transform: uppercase !important;
    letter-spacing: 0.1em !important; color: var(--rv-gray-900) !important; line-height: 1.4 !important;
}

/* Tabs */
html body #renovatio-product-module .rv-tabs-section {
    margin-top: 4rem !important; padding-top: 3rem !important;
    border-top: 1px solid rgba(233, 80, 74, 0.1) !important;
    max-width: 900px !important; margin-left: auto !important; margin-right: auto !important;
}
html body #renovatio-product-module .rv-tabs-nav {
    display: flex !important; border-bottom: 1px solid var(--rv-gray-200) !important;
    margin-bottom: 2rem !important; overflow-x: auto !important;
}
html body #renovatio-product-module .rv-tab-btn {
    padding: 1rem 1.5rem !important; font-size: 12px !important; font-weight: 700 !important;
    letter-spacing: 0.15em !important; text-transform: uppercase !important;
    color: var(--rv-gray-400) !important; background: none !important; border: none !important;
    border-bottom: 2px solid transparent !important; cursor: pointer !important;
    white-space: nowrap !important; transition: all 0.3s !important;
}
html body #renovatio-product-module .rv-tab-btn:hover { color: var(--rv-gray-900) !important; }
html body #renovatio-product-module .rv-tab-btn.active {
    color: var(--rv-pink) !important; border-bottom-color: var(--rv-pink) !important;
}
html body #renovatio-product-module .rv-tab-content {
    display: none !important; color: var(--rv-gray-600) !important;
    font-family: 'Lato', sans-serif !important; line-height: 1.8 !important;
}
html body #renovatio-product-module .rv-tab-content.active { display: block !important; }
html body #renovatio-product-module .rv-tab-content h3 {
    font-family: 'Playfair Display', serif !important; font-size: 1.5rem !important;
    color: var(--rv-gray-900) !important; margin-bottom: 1rem !important;
}
html body #renovatio-product-module .rv-tab-content p { margin-bottom: 1rem !important; }
html body #renovatio-product-module .rv-features-grid {
    display: grid !important; grid-template-columns: 1fr !important;
    gap: 1rem !important; margin: 1.5rem 0 !important;
}
@media (min-width: 768px) {
    html body #renovatio-product-module .rv-features-grid { grid-template-columns: 1fr 1fr !important; }
}
html body #renovatio-product-module .rv-feature-item {
    display: flex !important; align-items: flex-start !important; gap: 0.75rem !important; font-size: 0.9rem !important;
}
html body #renovatio-product-module .rv-feature-item i { color: var(--rv-pink) !important; font-size: 1.25rem !important; margin-top: 2px !important; }

/* Sección Excelencia */
html body #renovatio-product-module .rv-excellence {
    margin-top: 4rem !important; padding-top: 3rem !important;
    border-top: 1px solid rgba(233, 80, 74, 0.1) !important;
}
html body #renovatio-product-module .rv-excellence-title {
    font-family: 'Playfair Display', serif !important; font-size: 2rem !important;
    font-weight: 700 !important; text-align: center !important;
    margin-bottom: 3rem !important; color: var(--rv-gray-900) !important;
}
html body #renovatio-product-module .rv-excellence-grid {
    display: grid !important; grid-template-columns: 1fr !important;
    gap: 2rem !important; max-width: 1000px !important; margin: 0 auto !important;
}
@media (min-width: 768px) {
    html body #renovatio-product-module .rv-excellence-grid { grid-template-columns: repeat(3, 1fr) !important; }
}
html body #renovatio-product-module .rv-excellence-item { display: flex !important; flex-direction: column !important; gap: 0.75rem !important; }
html body #renovatio-product-module .rv-excellence-item i { font-size: 2rem !important; color: var(--rv-accent) !important; }
html body #renovatio-product-module .rv-excellence-item h4 {
    font-size: 11px !important; font-weight: 700 !important; letter-spacing: 0.15em !important;
    text-transform: uppercase !important; color: var(--rv-gray-900) !important;
}
html body #renovatio-product-module .rv-excellence-item p {
    font-size: 0.875rem !important; color: var(--rv-gray-600) !important;
    line-height: 1.7 !important; font-weight: 300 !important;
}

/* Sección Productos Relacionados (Accesorios) */
html body #renovatio-product-module .rv-related {
    background: var(--rv-white) !important; padding: 4rem 1.5rem !important; margin-top: 4rem !important;
}
html body #renovatio-product-module .rv-related-inner { max-width: 1280px !important; margin: 0 auto !important; }
html body #renovatio-product-module .rv-related-header {
    display: flex !important; justify-content: space-between !important; align-items: center !important;
    margin-bottom: 2rem !important; flex-wrap: wrap !important; gap: 1rem !important;
}
html body #renovatio-product-module .rv-related-title {
    font-family: 'Playfair Display', serif !important; font-size: 1.75rem !important;
    font-weight: 700 !important; color: var(--rv-gray-900) !important;
}
html body #renovatio-product-module .rv-related-link {
    font-size: 11px !important; font-weight: 700 !important; letter-spacing: 0.15em !important;
    text-transform: uppercase !important; color: var(--rv-pink) !important; text-decoration: none !important;
    display: flex !important; align-items: center !important; gap: 0.5rem !important; transition: opacity 0.3s !important;
}
html body #renovatio-product-module .rv-related-link:hover { opacity: 0.7 !important; }
html body #renovatio-product-module .rv-products-grid {
    display: grid !important; grid-template-columns: repeat(2, 1fr) !important; gap: 1.5rem !important;
}
@media (min-width: 768px) {
    html body #renovatio-product-module .rv-products-grid { grid-template-columns: repeat(4, 1fr) !important; }
}
html body #renovatio-product-module .rv-product-card {
    background: var(--rv-bg) !important; border-radius: 1rem !important; overflow: hidden !important;
    transition: all 0.3s !important; border: 1px solid transparent !important;
    text-decoration: none !important; display: block !important;
}
html body #renovatio-product-module .rv-product-card:hover {
    transform: translateY(-5px) !important;
    box-shadow: 0 15px 30px -10px rgba(233, 80, 74, 0.15) !important;
    border-color: rgba(233, 80, 74, 0.1) !important;
}
html body #renovatio-product-module .rv-product-card-image {
    aspect-ratio: 1 !important; overflow: hidden !important; background: var(--rv-gray-100) !important;
}
html body #renovatio-product-module .rv-product-card-image img {
    width: 100% !important; height: 100% !important; object-fit: cover !important;
    transition: transform 0.5s !important; display: block !important;
}
html body #renovatio-product-module .rv-product-card:hover .rv-product-card-image img { transform: scale(1.08) !important; }
html body #renovatio-product-module .rv-product-card-info { padding: 1rem !important; }
html body #renovatio-product-module .rv-product-card-cat {
    font-size: 9px !important; font-weight: 700 !important; letter-spacing: 0.15em !important;
    text-transform: uppercase !important; color: var(--rv-pink) !important;
    margin-bottom: 0.25rem !important; display: block !important;
}
html body #renovatio-product-module .rv-product-card-name {
    font-family: 'Playfair Display', serif !important; font-size: 1rem !important;
    font-weight: 600 !important; color: var(--rv-gray-900) !important;
    margin-bottom: 0.5rem !important; line-height: 1.3 !important;
}
html body #renovatio-product-module .rv-product-card-price {
    font-weight: 700 !important; color: var(--rv-gray-900) !important; font-size: 0.9rem !important;
}
html body #renovatio-product-module .rv-products-loading {
    text-align: center !important; padding: 3rem !important;
    color: var(--rv-gray-400) !important; grid-column: 1 / -1 !important;
}
html body #renovatio-product-module .rv-products-loading i {
    font-size: 2rem !important; animation: rv-spin 1s linear infinite !important;
    display: block !important; margin-bottom: 0.5rem !important;
}

/* ==========================================================================
   MÓDULO ASESORÍA ESTÉTICA — #renovatio-aesthet-wrapper
   ========================================================================== */
#renovatio-aesthet-wrapper {
    --ob-primary: #000000;
    --ob-accent: #D0A550;
    --ob-pink: #E9504A;
    --ob-bg: #ffffff;
    --luxury-shadow: 0 20px 40px -5px rgba(233, 80, 74, 0.15);
    
    font-family: 'Inter', sans-serif;
    color: var(--ob-primary);
    background-color: var(--ob-bg);
    width: 100%;
    position: relative;
    line-height: 1.5;
}

#renovatio-aesthet-wrapper h1,
#renovatio-aesthet-wrapper h2,
#renovatio-aesthet-wrapper h3,
#renovatio-aesthet-wrapper h4 {
    line-height: 1.2;
    margin-top: 0;
}

#renovatio-aesthet-wrapper p { margin-bottom: 1rem; }
#renovatio-aesthet-wrapper a { text-decoration: none; color: inherit; }
#renovatio-aesthet-wrapper ul { list-style: none; padding: 0; margin: 0; }

#renovatio-aesthet-wrapper .font-display { font-family: 'Playfair Display', serif; }
#renovatio-aesthet-wrapper .font-body { font-family: 'Lato', sans-serif; }

#renovatio-aesthet-wrapper button { border: none; background: transparent; cursor: pointer; }

#renovatio-aesthet-wrapper .btn-renovatio {
    background: var(--ob-pink);
    color: white;
    transition: 0.3s;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

#renovatio-aesthet-wrapper .btn-renovatio:hover {
    background: #c43e38;
    transform: translateY(-3px);
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.2);
}

#renovatio-aesthet-wrapper .btn-outline-gold {
    background: transparent;
    border: 1px solid var(--ob-accent);
    color: var(--ob-accent);
    transition: 0.3s;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

#renovatio-aesthet-wrapper .btn-outline-gold:hover {
    background: var(--ob-accent);
    color: white;
}

#renovatio-aesthet-wrapper .process-card {
    border: 1px solid rgba(0, 0, 0, 0.05);
    transition: 0.4s ease;
}

#renovatio-aesthet-wrapper .process-card:hover {
    border-color: var(--ob-accent);
    transform: translateY(-5px);
    box-shadow: var(--luxury-shadow);
}

#renovatio-aesthet-wrapper details > summary { list-style: none; }
#renovatio-aesthet-wrapper details > summary::-webkit-details-marker { display: none; }

/* ==========================================================================
   MÓDULO ASESORÍA OFTALMOLÓGICA — #renovatio-oftalmo-wrapper
   ========================================================================== */
#renovatio-oftalmo-wrapper {
    --ob-primary: #000000;
    --ob-accent: #D0A550;
    --ob-pink: #E9504A;
    --ob-bg: #ffffff;
    --luxury-shadow: 0 20px 40px -5px rgba(233, 80, 74, 0.15);
    
    font-family: 'Inter', sans-serif;
    color: var(--ob-primary);
    background-color: var(--ob-bg);
    width: 100%;
    position: relative;
    line-height: 1.5;
}

#renovatio-oftalmo-wrapper h1,
#renovatio-oftalmo-wrapper h2,
#renovatio-oftalmo-wrapper h3,
#renovatio-oftalmo-wrapper h4 {
    line-height: 1.2;
    margin-top: 0;
}

#renovatio-oftalmo-wrapper p { margin-bottom: 1rem; }
#renovatio-oftalmo-wrapper a { text-decoration: none; color: inherit; }
#renovatio-oftalmo-wrapper ul { list-style: none; padding: 0; margin: 0; }

#renovatio-oftalmo-wrapper .font-display { font-family: 'Playfair Display', serif; }
#renovatio-oftalmo-wrapper .font-body { font-family: 'Lato', sans-serif; }

#renovatio-oftalmo-wrapper button { border: none; background: transparent; cursor: pointer; }

#renovatio-oftalmo-wrapper .btn-renovatio {
    background: var(--ob-pink);
    color: white;
    transition: 0.3s;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

#renovatio-oftalmo-wrapper .btn-renovatio:hover {
    background: #c43e38;
    transform: translateY(-3px);
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.2);
}

#renovatio-oftalmo-wrapper .btn-outline-gold {
    background: transparent;
    border: 1px solid var(--ob-accent);
    color: var(--ob-accent);
    transition: 0.3s;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

#renovatio-oftalmo-wrapper .btn-outline-gold:hover {
    background: var(--ob-accent);
    color: white;
}

#renovatio-oftalmo-wrapper .process-card {
    border: 1px solid rgba(0, 0, 0, 0.05);
    transition: 0.4s ease;
}

#renovatio-oftalmo-wrapper .process-card:hover {
    border-color: var(--ob-accent);
    transform: translateY(-5px);
    box-shadow: var(--luxury-shadow);
}

#renovatio-oftalmo-wrapper details > summary { list-style: none; }
#renovatio-oftalmo-wrapper details > summary::-webkit-details-marker { display: none; }

/* ==========================================================================
   MÓDULO ASESORÍA INTEGRAL — #renovatio-integral-wrapper
   ========================================================================== */
#renovatio-integral-wrapper {
    --ob-primary: #000000;
    --ob-accent: #D0A550;
    --ob-pink: #E9504A;
    --ob-bg: #ffffff;
    --luxury-shadow: 0 20px 40px -5px rgba(233, 80, 74, 0.15);
    
    font-family: 'Inter', sans-serif;
    color: var(--ob-primary);
    background-color: var(--ob-bg);
    width: 100%;
    position: relative;
    line-height: 1.5;
}

#renovatio-integral-wrapper h1,
#renovatio-integral-wrapper h2,
#renovatio-integral-wrapper h3,
#renovatio-integral-wrapper h4 {
    line-height: 1.2;
    margin-top: 0;
}

#renovatio-integral-wrapper p { margin-bottom: 1rem; }
#renovatio-integral-wrapper a { text-decoration: none; color: inherit; }
#renovatio-integral-wrapper ul { list-style: none; padding: 0; margin: 0; }

#renovatio-integral-wrapper .font-display { font-family: 'Playfair Display', serif; }
#renovatio-integral-wrapper .font-body { font-family: 'Lato', sans-serif; }

#renovatio-integral-wrapper button { border: none; background: transparent; cursor: pointer; }

#renovatio-integral-wrapper .btn-renovatio {
    background: var(--ob-pink);
    color: white;
    transition: 0.3s;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

#renovatio-integral-wrapper .btn-renovatio:hover {
    background: #c43e38;
    transform: translateY(-3px);
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.2);
}

#renovatio-integral-wrapper .btn-outline-gold {
    background: transparent;
    border: 1px solid var(--ob-accent);
    color: var(--ob-accent);
    transition: 0.3s;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

#renovatio-integral-wrapper .btn-outline-gold:hover {
    background: var(--ob-accent);
    color: white;
}

#renovatio-integral-wrapper .process-card {
    border: 1px solid rgba(0, 0, 0, 0.05);
    transition: 0.4s ease;
}

#renovatio-integral-wrapper .process-card:hover {
    border-color: var(--ob-accent);
    transform: translateY(-5px);
    box-shadow: var(--luxury-shadow);
}

#renovatio-integral-wrapper details > summary { list-style: none; }
#renovatio-integral-wrapper details > summary::-webkit-details-marker { display: none; }

/* ==========================================================================
   MÓDULO ARCHIVO BLOG — #renovatio-blog-content
   ========================================================================== */
#renovatio-blog-content {
    --ob-primary: #000000;
    --ob-accent: #D0A550;
    --ob-pink: #E9504A;
    --ob-bg: #ffffff;
    font-family: 'Inter', sans-serif;
    color: var(--ob-primary);
    background-color: var(--ob-bg);
    width: 100%;
    position: relative;
    line-height: 1.5;
}
#renovatio-blog-content h1,
#renovatio-blog-content h2,
#renovatio-blog-content h3,
#renovatio-blog-content h4 {
    line-height: 1.2;
    margin: 0;
}
#renovatio-blog-content p { margin-bottom: 1rem; }
#renovatio-blog-content .font-display { font-family: 'Playfair Display', serif; }
#renovatio-blog-content .font-body { font-family: 'Lato', sans-serif; }
#renovatio-blog-content a { text-decoration: none; color: inherit; }

#renovatio-blog-content .blog-card {
    transition: all 0.4s ease;
    height: 100%;
    display: flex;
    flex-direction: column;
}
#renovatio-blog-content .blog-card:hover { transform: translateY(-5px); }
#renovatio-blog-content .blog-card:hover h3 { color: var(--ob-pink) !important; }
#renovatio-blog-content .blog-card h3 { margin-bottom: 1rem !important; }
#renovatio-blog-content .blog-card p { margin-top: 0.25rem; }

#renovatio-blog-content .blog-img {
    transition: transform 0.5s ease;
    width: 100%;
    height: 100%;
    display: block;
}
#renovatio-blog-content .blog-card:hover .blog-img { transform: scale(1.05); }

#renovatio-blog-content .blog-widget-title {
    font-size: 1.15rem; font-weight: 800; margin-bottom: 1.5rem; 
    border-bottom: 2px solid #f3f4f6; padding-bottom: 0.8rem; color: var(--ob-primary);
}

#renovatio-blog-content ul { list-style: none; padding: 0; margin: 0; }
#renovatio-blog-content .cat-link {
    display: flex;
    justify-content: space-between;
    padding: 6px 0;
    transition: 0.2s;
    color: #71717a;
    font-size: 0.95rem;
    font-weight: 500;
    cursor: pointer;
}
#renovatio-blog-content .cat-link:hover { color: var(--ob-pink); padding-left: 5px; }
#renovatio-blog-content .cat-link.active { color: var(--ob-pink); font-weight: 800; }

#renovatio-blog-content .promo-banner {
    background: linear-gradient(135deg, #FFF5F5 0%, #FFE4E4 100%);
    position: relative;
    overflow: hidden;
}
#renovatio-blog-content .promo-banner::before {
    content: '';
    position: absolute;
    top: -50%;
    right: -30%;
    width: 200px;
    height: 200px;
    background: #FFD1D1;
    border-radius: 50%;
    filter: blur(60px);
    opacity: 0.6;
}
@media (min-width: 768px) {
    #renovatio-blog-content .blog-card .md-show { display: flex !important; }
    #renovatio-blog-content .blog-card .md-block { display: block !important; }
}

/* ==========================================================================
   MÓDULO SINGLE POST — #renovatio-single-post
   ========================================================================== */
#renovatio-single-post {
    --ob-primary: #000000;
    --ob-accent: #D0A550;
    --ob-pink: #E9504A;
    --ob-bg: #ffffff;
    font-family: 'Inter', sans-serif;
    color: var(--ob-primary);
    background-color: var(--ob-bg);
    width: 100%;
    line-height: 1.6;
}
#renovatio-single-post .post-hero {
    background: linear-gradient(135deg, #FFF5F5 0%, #FFE4E4 100%);
    position: relative;
    overflow: hidden;
}
#renovatio-single-post .category-badge {
    display: inline-block;
    background: #E9504A;
    color: white;
    font-size: 0.75rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    padding: 0.4rem 1rem;
    border-radius: 2rem;
}
#renovatio-single-post .font-display { font-family: 'Playfair Display', serif; }
#renovatio-single-post .font-body { font-family: 'Lato', sans-serif; }
#renovatio-single-post .post-content {
    font-size: 1.125rem;
    color: #4a4a4a;
}
#renovatio-single-post .post-content h1,
#renovatio-single-post .post-content h2,
#renovatio-single-post .post-content h3 {
    font-family: 'Playfair Display', serif;
    color: black;
    font-weight: 700;
    margin-top: 2.5rem;
    margin-bottom: 1rem;
    line-height: 1.3;
}
#renovatio-single-post .post-content h2 { font-size: 2rem; }
#renovatio-single-post .post-content h3 { font-size: 1.5rem; }
#renovatio-single-post .post-content p {
    margin-bottom: 1.5rem;
}
#renovatio-single-post .post-content blockquote {
    font-family: 'Playfair Display', serif;
    font-size: 1.5rem;
    font-style: italic;
    color: var(--ob-accent);
    border-left: 4px solid var(--ob-accent);
    padding-left: 1.5rem;
    margin: 2.5rem 0;
    line-height: 1.4;
}
#renovatio-single-post .post-content ul,
#renovatio-single-post .post-content ol {
    margin-bottom: 1.5rem;
    padding-left: 1.5rem;
}
#renovatio-single-post .post-content ul li {
    list-style-type: disc;
    margin-bottom: 0.5rem;
}
#renovatio-single-post .post-content img {
    border-radius: 1rem;
    margin: 2rem 0;
    width: 100%;
    height: auto;
}

/* Forzar Botones Internos del Contenido a Diseño Luxury (Gutenberg/Elementor) */
#renovatio-single-post .post-content .wp-block-button__link,
#renovatio-single-post .post-content .elementor-button,
#renovatio-single-post .post-content a.button {
    background-color: #000000 !important;
    color: #ffffff !important;
    border-radius: 50px !important;
    padding: 14px 36px !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.15em !important;
    font-size: 0.8rem !important;
    transition: all 0.4s ease !important;
    border: 1px solid #000000 !important;
    text-decoration: none !important;
    display: inline-block !important;
    box-shadow: 0 10px 30px rgba(0,0,0,0.1) !important;
}
#renovatio-single-post .post-content .wp-block-button__link:hover,
#renovatio-single-post .post-content .elementor-button:hover,
#renovatio-single-post .post-content a.button:hover {
    background-color: transparent !important;
    color: #D0A550 !important;
    border-color: #D0A550 !important;
    transform: translateY(-3px) !important;
    box-shadow: 0 15px 35px rgba(208, 165, 80, 0.15) !important;
}

/* Botones de Compartir Luxury */
#renovatio-single-post .share-btn {
    width: 45px;
    height: 45px;
    border-radius: 50%;
    background: #000000;
    color: #D0A550;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.4s ease;
    font-size: 1.35rem;
    border: 1px solid #000000;
    cursor: pointer;
    text-decoration: none;
    box-shadow: 0 5px 15px rgba(0,0,0,0.1);
}
#renovatio-single-post .share-btn:hover {
    background: transparent;
    color: #D0A550;
    border-color: #D0A550;
    transform: translateY(-4px) rotate(8deg);
    box-shadow: 0 10px 20px rgba(208, 165, 80, 0.2);
}

/* ==========================================================================
   MÓDULO CHECKOUT — .renovatio-checkout-wrapper
   ========================================================================== */
.renovatio-checkout-wrapper {
    --pink: #E9504A;
    --pink-light: #FFF5F5;
    --gold: #D0A550;
    --dark: #000000;
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
}
.renovatio-checkout-wrapper h1,
.renovatio-checkout-wrapper h2,
.renovatio-checkout-wrapper h3 {
    font-family: 'Playfair Display', serif;
}

/* Layout Responsive Checkout */
.renovatio-checkout-wrapper form.checkout {
    margin-top: 2rem;
}
/* Ocultar zona de coincidencia por defecto (mensajes de Woo) */
.renovatio-checkout-wrapper .woocommerce-notices-wrapper .woocommerce-message {
    display: none !important;
}

/* Banners de info */
.renovatio-info-banner {
    background: linear-gradient(135deg, #FFF8E1 0%, #FFECB3 100%);
    border-left: 4px solid #D0A550;
    padding: 1.5rem 2rem;
    border-radius: 0 16px 16px 0;
    margin-bottom: 1.5rem;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 1.25rem;
}
.renovatio-info-banner.pink {
    background: linear-gradient(135deg, #FFF5F5 0%, #FFE4E4 100%);
    border-left-color: #E9504A;
}
.renovatio-info-banner .banner-icon { font-size: 2rem; flex-shrink: 0; }
.renovatio-info-banner .banner-content { flex: 1; min-width: 200px; }
.renovatio-info-banner .banner-content h4 {
    margin: 0 0 6px 0; font-size: 1.1rem; font-weight: 700; color: #000;
}
.renovatio-info-banner .banner-content p {
    margin: 0; font-size: 1rem; color: #555; line-height: 1.5;
}

.renovatio-whatsapp-btn {
    display: inline-flex; align-items: center; gap: 0.5rem;
    background: #25D366; color: white; padding: 0.75rem 1.5rem;
    border-radius: 999px; font-weight: 700; font-size: 1rem;
    text-decoration: none !important; border-bottom: none !important;
    transition: 0.3s;
}
.renovatio-whatsapp-btn:hover { background: #128C7E; color: white; text-decoration: none !important; }
.renovatio-link-pink { color: #E9504A; font-weight: 700; text-decoration: underline; }

/* Cupón */
.renovatio-checkout-wrapper .woocommerce-form-coupon-toggle {
    display: block !important;
    background: #f9f9f9; padding: 16px 20px; border-radius: 12px; margin-bottom: 20px; border: none;
}
.renovatio-checkout-wrapper .woocommerce-form-coupon-toggle .woocommerce-info {
    display: block !important; background: transparent; border: none; padding: 0; margin: 0;
}
.renovatio-checkout-wrapper .woocommerce-form-coupon-toggle .woocommerce-info::before,
.renovatio-checkout-wrapper .woocommerce-info::before {
    display: none !important; content: none !important;
}
.renovatio-checkout-wrapper .showcoupon { color: #E9504A; font-weight: 700; }
.renovatio-checkout-wrapper .checkout_coupon {
    background: #f9f9f9; padding: 20px; border-radius: 12px; margin-bottom: 24px; border: none;
}
.renovatio-checkout-wrapper .checkout_coupon .button {
    background: #E9504A !important; color: white !important; border-radius: 999px;
}

/* Inputs form */
.renovatio-checkout-wrapper .woocommerce input[type="text"],
.renovatio-checkout-wrapper .woocommerce input[type="email"],
.renovatio-checkout-wrapper .woocommerce input[type="tel"],
.renovatio-checkout-wrapper .woocommerce input[type="password"],
.renovatio-checkout-wrapper .woocommerce textarea,
.renovatio-checkout-wrapper .woocommerce select {
    border-radius: 8px !important; border: 1px solid #ddd !important; padding: 12px 16px !important; transition: 0.3s !important; width: 100% !important; box-sizing: border-box !important;
}
.renovatio-checkout-wrapper .woocommerce input:focus,
.renovatio-checkout-wrapper .woocommerce textarea:focus,
.renovatio-checkout-wrapper .woocommerce select:focus {
    border-color: #E9504A !important; box-shadow: 0 0 0 3px rgba(233, 80, 74, 0.1) !important; outline: none !important;
}
.renovatio-checkout-wrapper .woocommerce label {
    font-size: 0.8rem; font-weight: 600; color: #555; text-transform: uppercase; letter-spacing: 0.03em;
}
.renovatio-checkout-wrapper .woocommerce .required { color: #E9504A; }
.renovatio-checkout-wrapper .woocommerce .amount { color: #D0A550; font-weight: 700; }

/* Tabla Checkout */
.renovatio-checkout-wrapper .woocommerce-checkout-review-order-table {
    border: 1px solid #f0f0f0 !important; border-collapse: separate !important; border-spacing: 0 !important; border-radius: 16px !important; overflow: hidden !important;
    box-shadow: 0 10px 30px rgba(0,0,0,0.03) !important; margin-bottom: 1.5rem !important;
    width: 100% !important; background: #fff !important;
}
.renovatio-checkout-wrapper .woocommerce-checkout-review-order-table thead th {
    background: #FFF0F0 !important; padding: 16px !important; font-size: 0.85rem !important; font-weight: 700 !important; color: #333 !important; border: none !important;
}
.renovatio-checkout-wrapper .woocommerce-checkout-review-order-table tbody td,
.renovatio-checkout-wrapper .woocommerce-checkout-review-order-table tfoot td,
.renovatio-checkout-wrapper .woocommerce-checkout-review-order-table tfoot th {
    padding: 14px 16px !important; background: white !important; border: none !important; border-bottom: 1px solid #f5f5f5 !important;
    vertical-align: middle !important; font-size: 0.9rem !important;
}
.renovatio-checkout-wrapper .woocommerce-checkout-review-order-table tfoot tr:last-child td,
.renovatio-checkout-wrapper .woocommerce-checkout-review-order-table tfoot tr:last-child th { border-bottom: none !important; }

/* Anulación extra-específica para Astra en #order_review */
html body .renovatio-checkout-wrapper #order_review .woocommerce-shipping-methods li {
    padding: 12px !important; border: 1px solid #f0f0f0; align-items: center !important;
}
html body .renovatio-checkout-wrapper #order_review .woocommerce-shipping-methods input[type="radio"] {
    width: 16px !important; height: 16px !important; margin: 0 !important; display: block !important;
    visibility: visible !important; clip: auto !important; clip-path: none !important;
}

/* Métodos de Pago */
.renovatio-checkout-wrapper .wc_payment_methods {
    background: transparent; border-radius: 12px; overflow: hidden; padding: 0;
}
.renovatio-checkout-wrapper .wc_payment_method {
    background: white; border-radius: 12px; margin-bottom: 8px; overflow: hidden; border: 1px solid #eee;
}
.renovatio-checkout-wrapper .wc_payment_method>label {
    text-transform: none; font-weight: 600; padding: 16px; display: flex; align-items: center; gap: 10px; flex-wrap: wrap; cursor: pointer; margin: 0;
}
.renovatio-checkout-wrapper .wc_payment_method input[type="radio"] { accent-color: #E9504A; width: 16px; height: 16px; flex-shrink: 0; margin: 0 !important; position: relative !important; float: none !important; }
.renovatio-checkout-wrapper .wc_payment_method label img { max-width: 80px; height: auto; margin-left: auto; padding: 4px; background: #f9f9f9; border-radius: 6px; flex-shrink: 0; }
.renovatio-checkout-wrapper .payment_box { padding: 0 16px 16px 16px; font-size: 0.85rem; color: #666; line-height: 1.5; }

/* Términos */
.renovatio-checkout-wrapper .woocommerce-terms-and-conditions-wrapper { margin-top: 16px; }
.renovatio-checkout-wrapper .woocommerce-form__label-for-checkbox {
    display: flex !important; align-items: flex-start !important; gap: 10px; font-size: 0.85rem; text-transform: none; color: #444; line-height: 1.4;
}
.renovatio-checkout-wrapper .woocommerce-form__input-checkbox { accent-color: #E9504A; width: 16px; height: 16px; flex-shrink: 0; margin-top: 2px !important; }

/* Place Order Btn */
.renovatio-checkout-wrapper .place-order { margin-top: 24px; padding-top: 24px; border-top: 1px solid #eee; }
.renovatio-checkout-wrapper .woocommerce #place_order {
    background-color: #000; color: white; border: none; border-radius: 50px; padding: 16px 32px; font-weight: 700;
    text-transform: uppercase; letter-spacing: 0.1em; transition: 0.3s; width: 100%; box-shadow: 0 5px 15px rgba(0,0,0,0.1);
}
.renovatio-checkout-wrapper .woocommerce #place_order:hover {
    background-color: transparent; color: #D0A550; border: 1px solid #D0A550; box-shadow: 0 8px 20px rgba(208, 165, 80, 0.15); transform: translateY(-2px);
}

.renovatio-trust-badge { text-align: center; padding: 2rem 0; color: #999; font-size: 0.9rem; display: flex; justify-content: center; align-items: center; gap: 0.5rem; }

/* Mobile Adjustments Checkout */
@media (max-width: 768px) {
    /* Reconstruir tabla como flexbox para evitar desbordes */
    .renovatio-checkout-wrapper .woocommerce-checkout-review-order-table {
        display: block !important;
        border: none !important;
        box-shadow: none !important;
        padding: 0 !important;
        background: transparent !important;
    }
    .renovatio-checkout-wrapper .woocommerce-checkout-review-order-table thead {
        display: none !important; /* Ocultar cabeceras "Producto" "Subtotal" en movil */
    }
    .renovatio-checkout-wrapper .woocommerce-checkout-review-order-table tbody,
    .renovatio-checkout-wrapper .woocommerce-checkout-review-order-table tfoot {
        display: block !important;
        width: 100% !important;
        background: white !important;
        border-radius: 12px !important;
        padding: 10px 16px !important;
        margin-bottom: 1rem !important;
        box-shadow: 0 4px 15px rgba(0,0,0,0.03) !important;
    }
    .renovatio-checkout-wrapper .woocommerce-checkout-review-order-table tr {
        display: flex !important;
        flex-wrap: wrap !important;
        justify-content: space-between !important;
        align-items: center !important;
        padding: 12px 0 !important;
        border-bottom: 1px solid #f0f0f0 !important;
    }
    .renovatio-checkout-wrapper .woocommerce-checkout-review-order-table tr:last-child {
        border-bottom: none !important;
    }
    .renovatio-checkout-wrapper .woocommerce-checkout-review-order-table th,
    .renovatio-checkout-wrapper .woocommerce-checkout-review-order-table td {
        display: block !important;
        width: auto !important;
        border: none !important;
        padding: 0 !important;
        background: transparent !important;
        white-space: normal;
    }
    .renovatio-checkout-wrapper .woocommerce-checkout-review-order-table td.product-name {
        width: 60% !important;
        text-align: left !important;
    }
    .renovatio-checkout-wrapper .woocommerce-checkout-review-order-table td.product-total {
        width: 40% !important;
        text-align: right !important;
        white-space: nowrap !important; /* Prevenir que el precio caiga en multiples lineas */
    }
    .renovatio-checkout-wrapper .woocommerce-checkout-review-order-table tfoot th,
    .renovatio-checkout-wrapper .woocommerce-checkout-review-order-table tfoot td {
        white-space: nowrap !important;
    }
    /* Fila de Envío Especial */
    .renovatio-checkout-wrapper .woocommerce-checkout-review-order-table tr.woocommerce-shipping-totals {
        flex-direction: column !important;
        align-items: flex-start !important;
    }
    .renovatio-checkout-wrapper .woocommerce-checkout-review-order-table tr.woocommerce-shipping-totals th {
        width: 100% !important;
        margin-bottom: 10px !important;
    }
    .renovatio-checkout-wrapper .woocommerce-checkout-review-order-table tr.woocommerce-shipping-totals td {
        width: 100% !important;
        white-space: normal !important;
    }
}

/* Ocultar Avisos Nativos Molestos (Ej: Zona de coincidencia) en página de producto */
html body #renovatio-product-module .woocommerce-notices-wrapper,
html body #renovatio-product-module .woocommerce-message,
html body #renovatio-product-module .woocommerce-info {
    display: none !important;
}

/* ============================================================
   LANDING PAGES — COMEDIANTES (rv-lp-)
   Reutilizable: cambiar foto, nombre y productos por comediante
   ============================================================ */

.rv-lp-comedian { width: 100%; overflow-x: hidden; }

/* Botones */
.rv-lp-btn { display: inline-block; padding: 14px 28px; border-radius: var(--rv-radius); font-family: 'Inter', sans-serif; font-weight: 600; font-size: 0.9rem; text-decoration: none; transition: all 0.25s ease; cursor: pointer; border: 2px solid transparent; letter-spacing: 0.02em; text-align: center; }
.rv-lp-btn--primary { background: var(--rv-pink); color: #fff; border-color: var(--rv-pink); }
.rv-lp-btn--primary:hover { background: var(--rv-pink-hover); border-color: var(--rv-pink-hover); transform: translateY(-2px); color: #fff; }
.rv-lp-btn--outline { background: transparent; color: var(--rv-pink); border-color: var(--rv-pink); }
.rv-lp-btn--outline:hover { background: var(--rv-pink); color: #fff; }
.rv-lp-btn--ghost { background: transparent; color: #fff; border-color: #fff; }
.rv-lp-btn--ghost:hover { background: #fff; color: var(--rv-black); }

/* Hero */
.rv-lp-hero { display: grid; grid-template-columns: 1fr 1fr; min-height: 85vh; background: var(--rv-bg-soft); }
.rv-lp-hero__image { position: relative; overflow: hidden; }
.rv-lp-hero__image img { width: 100%; height: 100%; object-fit: cover; object-position: top center; display: block; }
.rv-lp-hero__image::after { content: ''; position: absolute; inset: 0; pointer-events: none; background: linear-gradient(to right, transparent 45%, rgba(255,245,245,0.55) 72%, #FFF5F5 100%), linear-gradient(to bottom, transparent 60%, rgba(255,245,245,0.4) 100%), linear-gradient(to left, transparent 85%, rgba(255,245,245,0.3) 100%); }
.rv-lp-hero__content { display: flex; flex-direction: column; justify-content: center; padding: 60px 56px; gap: 20px; }
.rv-lp-hero__eyebrow { font-family: 'Inter', sans-serif; font-size: 0.75rem; font-weight: 700; letter-spacing: 0.15em; text-transform: uppercase; color: var(--rv-pink); }
.rv-lp-hero__title { font-family: 'Playfair Display', serif; font-size: clamp(2.2rem, 4vw, 3.5rem); font-weight: 700; line-height: 1.1; color: var(--rv-black); margin: 0; }
.rv-lp-hero__title--accent { color: var(--rv-gold); }
.rv-lp-hero__desc { font-family: 'Inter', sans-serif; font-size: 1rem; line-height: 1.7; color: #555; margin: 0; max-width: 420px; }
.rv-lp-hero__quote { border-left: 3px solid var(--rv-gold); padding-left: 20px; margin: 8px 0; }
.rv-lp-hero__quote p { font-family: 'Cormorant Garamond', 'Playfair Display', serif; font-size: 1.2rem; font-style: italic; color: var(--rv-black); line-height: 1.6; margin: 0 0 6px 0; }
.rv-lp-hero__quote cite { font-family: 'Inter', sans-serif; font-size: 0.8rem; font-style: normal; font-weight: 700; color: var(--rv-gold); letter-spacing: 0.05em; }

/* Carousel */
.rv-lp-carousel { padding: 80px 40px; background: #fafafa; }
.rv-lp-carousel__header { text-align: center; margin-bottom: 40px; }
.rv-lp-carousel__eyebrow { font-family: 'Inter', sans-serif; font-size: 0.75rem; font-weight: 700; letter-spacing: 0.2em; text-transform: uppercase; color: var(--rv-pink); display: block; margin-bottom: 8px; }
.rv-lp-carousel__header h2 { font-family: 'Playfair Display', serif; font-size: clamp(1.8rem, 3vw, 2.8rem); font-weight: 700; color: var(--rv-black); margin: 0; }
.rv-lp-carousel__nav { display: flex; align-items: center; gap: 16px; max-width: 1200px; margin: 0 auto; }
.rv-lp-carousel__track { flex: 1; display: flex; gap: 1.5rem; overflow-x: auto; scroll-snap-type: x proximity; scrollbar-width: none; -ms-overflow-style: none; padding: 8px 4px 20px; scroll-behavior: auto; }
.rv-lp-carousel__track::-webkit-scrollbar { display: none; }
/* Tarjeta estilo colecciones */
.rv-lp-carousel__card { flex: 0 0 240px; scroll-snap-align: start; position: relative; border-radius: var(--rv-radius); overflow: hidden; cursor: pointer; box-shadow: var(--rv-shadow-card); aspect-ratio: 3/4; background: #000; border: 1px solid #f0f0f0; transition: all 0.3s ease; display: block; text-decoration: none; }
.rv-lp-carousel__card:hover { transform: translateY(-8px); box-shadow: var(--rv-shadow-luxury); border-color: transparent; }
.rv-lp-carousel__card img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; transition: transform 0.8s ease; pointer-events: none; opacity: 0.85; }
.rv-lp-carousel__card:hover img { transform: scale(1.1); opacity: 0.75; }
.rv-lp-carousel__overlay { position: absolute; bottom: 0; left: 0; right: 0; padding: 2.5rem 1.25rem 1.5rem; background: linear-gradient(to top, rgba(0,0,0,0.98) 0%, rgba(0,0,0,0.9) 40%, rgba(0,0,0,0.6) 70%, transparent 100%); color: #fff; min-height: 140px; display: flex; flex-direction: column; justify-content: flex-end; gap: 4px; }
.rv-lp-carousel__label { color: #FFB6C1; font-weight: 700; font-size: 10px; text-transform: uppercase; letter-spacing: 0.15em; }
.rv-lp-carousel__card h3 { font-family: 'Playfair Display', serif; color: #fff !important; margin: 0; font-size: 1rem; line-height: 1.3; }
.rv-lp-carousel__price { font-family: 'Inter', sans-serif; font-size: 0.9rem; font-weight: 700; color: rgba(255,255,255,0.9); }
.rv-lp-carousel__link { font-family: 'Inter', sans-serif; font-size: 0.78rem; color: rgba(255,255,255,0.7); margin-top: 4px; transition: color 0.2s; }
.rv-lp-carousel__card:hover .rv-lp-carousel__link { color: #fff; }
/* Flechas — inline, no absolutas */
.rv-lp-carousel__arrow { flex-shrink: 0; width: 44px; height: 44px; min-width: 44px; min-height: 44px; max-width: 44px; max-height: 44px; aspect-ratio: 1 / 1; border-radius: 50%; background: #fff; border: 1.5px solid #e0e0e0; display: flex; align-items: center; justify-content: center; cursor: pointer; box-shadow: 0 2px 8px rgba(0,0,0,0.08); transition: all 0.2s; color: #333; padding: 0; }
.rv-lp-carousel__arrow:hover { background: var(--rv-pink); color: #fff; border-color: var(--rv-pink); box-shadow: 0 4px 16px rgba(233,80,74,0.3); }

/* SEO */
.rv-lp-seo { background: var(--rv-bg-soft); padding: 80px 40px; }
.rv-lp-seo__content { max-width: 780px; margin: 0 auto 60px auto; }
.rv-lp-seo__content h2 { font-family: 'Playfair Display', serif; font-size: clamp(1.6rem, 2.5vw, 2.4rem); font-weight: 700; color: var(--rv-black); margin: 0 0 24px 0; }
.rv-lp-seo__content p { font-family: 'Inter', sans-serif; font-size: 0.95rem; line-height: 1.8; color: #555; margin: 0 0 16px 0; }

/* FAQ */
.rv-lp-faq { max-width: 780px; margin: 0 auto; }
.rv-lp-faq__title { font-family: 'Playfair Display', serif; font-size: clamp(1.4rem, 2vw, 2rem); font-weight: 700; color: var(--rv-black); margin: 0 0 32px 0; }
.rv-lp-faq__item { border-bottom: 1px solid #e8e8e8; }
.rv-lp-faq__item:last-child { border-bottom: none; }
.rv-lp-faq__question { font-family: 'Inter', sans-serif; font-size: 0.95rem; font-weight: 600; color: var(--rv-black); padding: 18px 40px 18px 0; cursor: pointer; list-style: none; position: relative; transition: color 0.2s; }
.rv-lp-faq__question::-webkit-details-marker { display: none; }
.rv-lp-faq__question::after { content: '+'; position: absolute; right: 4px; top: 50%; transform: translateY(-50%); font-size: 1.4rem; font-weight: 300; color: var(--rv-pink); transition: transform 0.2s; }
.rv-lp-faq__item[open] .rv-lp-faq__question { color: var(--rv-pink); }
.rv-lp-faq__item[open] .rv-lp-faq__question::after { transform: translateY(-50%) rotate(45deg); }
.rv-lp-faq__answer { padding: 0 0 18px 0; }
.rv-lp-faq__answer p { font-family: 'Inter', sans-serif; font-size: 0.9rem; line-height: 1.7; color: #666; margin: 0; }

/* CTA */
.rv-lp-cta { background: var(--rv-black); padding: 80px 40px; text-align: center; }
.rv-lp-cta__content h2 { font-family: 'Playfair Display', serif; font-size: clamp(1.8rem, 3vw, 2.8rem); font-weight: 700; color: #fff; margin: 0 0 16px 0; }
.rv-lp-cta__content p { font-family: 'Inter', sans-serif; font-size: 1rem; color: rgba(255,255,255,0.7); margin: 0 0 36px 0; }
.rv-lp-cta__buttons { display: flex; gap: 16px; justify-content: center; flex-wrap: wrap; }

/* Responsive */
@media (max-width: 768px) {
    .rv-lp-hero { grid-template-columns: 1fr; min-height: auto; }
    .rv-lp-hero__image { height: 60vw; min-height: 280px; max-height: 420px; }
    .rv-lp-hero__content { padding: 36px 24px; gap: 16px; }
    .rv-lp-hero__desc { max-width: 100%; }
    .rv-lp-carousel { padding: 56px 16px; }
    .rv-lp-carousel__arrow { display: none; }
    .rv-lp-carousel__card { flex: 0 0 72vw; max-width: 260px; }
    .rv-lp-seo { padding: 56px 24px; }
    .rv-lp-cta { padding: 56px 24px; }
}


/* ==========================================================================
   MÓDULO BÚSQUEDA — #rv-search-module
   v1.0 — Solo productos, diseño igual a tienda
   ========================================================================== */

#rv-search-module {
    font-family: 'Inter', sans-serif;
    color: var(--rv-black);
    width: 100%;
    box-sizing: border-box;
    clear: both;
    overflow: hidden;
}
#rv-search-module * { box-sizing: border-box; }
#rv-search-module .font-display { font-family: 'Playfair Display', serif; }

/* ── HERO ── */
.rvs-hero {
    position: relative;
    background: linear-gradient(160deg, #FFF5F5 0%, #fff 65%);
    padding: 5.5rem 1.5rem 4rem;
    text-align: center;
    border-bottom: 1px solid #f3f4f6;
    overflow: hidden;
}
@media (min-width: 1024px) { .rvs-hero { padding: 8rem 6% 5.5rem; } }

/* Orbs decorativos */
.rvs-orb {
    position: absolute;
    border-radius: 50%;
    pointer-events: none;
}
.rvs-orb-1 {
    top: -15%;
    right: -8%;
    width: 500px;
    height: 500px;
    background: #FFE4E4;
    filter: blur(100px);
    opacity: 0.5;
}
.rvs-orb-2 {
    bottom: -10%;
    left: -5%;
    width: 300px;
    height: 300px;
    background: #FFD1D1;
    filter: blur(80px);
    opacity: 0.35;
}

.rvs-hero-inner {
    position: relative;
    z-index: 1;
    max-width: 700px;
    margin: 0 auto;
}

.rvs-tagline {
    display: block;
    font-size: 0.78rem;
    font-weight: 800;
    color: var(--rv-pink);
    letter-spacing: 0.18em;
    text-transform: uppercase;
    margin-bottom: 1rem;
}

.rvs-title {
    font-size: 2.4rem;
    font-weight: 700;
    color: var(--rv-black);
    line-height: 1.1;
    margin: 0 0 2.5rem;
}
@media (min-width: 768px) { .rvs-title { font-size: 3.2rem; } }

/* ── Barra de búsqueda ── */
.rvs-search-wrap {
    position: relative;
    max-width: 580px;
    margin: 0 auto 2rem;
    border-bottom: 2px solid #e5e7eb;
    transition: border-color 0.3s;
}
.rvs-search-wrap:focus-within {
    border-color: var(--rv-pink);
}

.rvs-search-icon {
    position: absolute;
    left: 0.25rem;
    bottom: 0.75rem;
    font-size: 1.35rem;
    color: #d1d5db;
    transition: color 0.3s;
}
.rvs-search-wrap:focus-within .rvs-search-icon {
    color: var(--rv-pink);
}

.rvs-search-input {
    width: 100%;
    border: none;
    background: transparent;
    font-size: clamp(1.2rem, 3vw, 2rem);
    color: var(--rv-black);
    text-align: center;
    padding: 0 2rem 0.65rem 2.5rem;
    outline: none;
    caret-color: var(--rv-pink);
}
.rvs-search-input::placeholder { color: #d1d5db; }

/* ── Pills ── */
.rvs-pills {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: 0.6rem;
    margin-bottom: 1.5rem;
}

.rvs-pill {
    display: inline-block;
    padding: 0.6rem 1.4rem;
    border-radius: 3rem;
    background: white;
    color: #71717a;
    font-weight: 700;
    font-size: 0.85rem;
    text-decoration: none;
    border: 1px solid #e5e7eb;
    cursor: pointer;
    transition: all 0.3s cubic-bezier(0.19, 1, 0.22, 1);
}
.rvs-pill:hover,
.rvs-pill.active {
    background: var(--rv-black);
    color: #fff;
    border-color: var(--rv-black);
    transform: translateY(-3px);
    box-shadow: 0 10px 20px rgba(0,0,0,0.1);
}
.rvs-pill.rvs-pill-sale {
    color: var(--rv-pink);
    border-color: rgba(233,80,74,0.25);
}
.rvs-pill.rvs-pill-sale:hover,
.rvs-pill.rvs-pill-sale.active {
    background: var(--rv-pink);
    color: white;
    border-color: var(--rv-pink);
}

/* Contador de resultados */
.rvs-count {
    font-size: 0.82rem;
    color: #9ca3af;
    font-style: italic;
    margin: 0;
    min-height: 1.2em;
}

/* ── Cuerpo ── */
.rvs-body {
    padding: 3rem 1.5rem 5rem;
    max-width: 1400px;
    margin: 0 auto;
}
@media (min-width: 1024px) { .rvs-body { padding: 4rem 6% 6rem; } }

/* ── Grid (más columnas que tienda: sin sidebar) ── */
.rvs-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1rem;
    position: relative;
}
@media (min-width: 640px)  { .rvs-grid { gap: 1.5rem; } }
@media (min-width: 900px)  { .rvs-grid { grid-template-columns: repeat(3, 1fr); gap: 2rem; } }
@media (min-width: 1200px) { .rvs-grid { grid-template-columns: repeat(4, 1fr); } }

/* ── Tarjeta (misma estructura que tienda) ── */
.rvs-card {
    background: #fff;
    border-radius: 1.5rem;
    border: 1px solid #f3f4f6;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    height: 100%;
    transition: transform 0.4s ease, box-shadow 0.4s ease;
}
.rvs-card:hover {
    transform: translateY(-10px);
    box-shadow: 0 25px 50px rgba(0,0,0,0.06);
}

/* Imagen */
.rvs-card-img {
    position: relative;
    aspect-ratio: 4/5;
    background: #fafafa;
    overflow: hidden;
    display: block;
}
.rvs-card-img img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    transition: transform 0.8s ease;
    display: block;
}
.rvs-card:hover .rvs-card-img img { transform: scale(1.05); }

/* Badge SALE */
.rvs-sale-badge {
    position: absolute;
    top: 1rem;
    left: 1rem;
    background: var(--rv-pink);
    color: white;
    padding: 4px 10px;
    border-radius: 30px;
    font-weight: 800;
    font-size: 10px;
    z-index: 10;
    letter-spacing: 0.05em;
}

/* Contenido */
.rvs-card-body {
    padding: 1rem;
    display: flex;
    flex-direction: column;
    flex-grow: 1;
}
@media (min-width: 768px) { .rvs-card-body { padding: 1.5rem; } }

.rvs-card-title {
    font-size: 0.95rem;
    font-weight: 700;
    margin: 0 0 0.35rem;
    color: var(--rv-black);
    line-height: 1.25;
}
@media (min-width: 768px) { .rvs-card-title { font-size: 1.05rem; } }

.rvs-card-cat {
    font-size: 0.65rem;
    color: #9ca3af;
    margin: 0 0 1rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

/* Footer de card */
.rvs-card-footer {
    margin-top: auto;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
    padding-top: 1rem;
    border-top: 1px solid #f9f9f9;
    gap: 0.5rem;
}

.rvs-card-price {
    color: var(--rv-pink);
    font-weight: 800;
    font-size: 1.05rem;
    width: 100%;
}
@media (min-width: 768px) { .rvs-card-price { font-size: 1.15rem; } }

/* Botones de card */
.rvs-card-actions {
    display: flex;
    flex-direction: row;
    align-items: stretch;
    gap: 0.5rem;
    width: 100%;
    margin-top: 0.5rem;
}

.rvs-btn-view {
    flex: 1;
    background: #f4f4f5;
    color: var(--rv-black) !important;
    padding: 0.65rem 0.75rem;
    border-radius: 3rem;
    font-size: 0.7rem;
    font-weight: 800;
    text-decoration: none;
    transition: background 0.3s ease;
    letter-spacing: 0.05em;
    white-space: nowrap;
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 2.5rem;
}
.rvs-btn-view:hover { background: #e5e7eb; }

.rvs-card .rvs-btn-cart,
.rvs-card .quick-add,
.rvs-card .add_to_cart_button {
    opacity: 1 !important;
    transform: none !important;
    position: static !important;
    flex: 1 !important;
    width: auto !important;
    height: auto !important;
    min-height: 2.5rem !important;
    border-radius: 3rem !important;
    background: var(--rv-pink) !important;
    color: white !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 0.35rem !important;
    font-size: 0.7rem !important;
    font-weight: 800 !important;
    letter-spacing: 0.05em !important;
    text-transform: uppercase !important;
    border: none !important;
    cursor: pointer !important;
    transition: background 0.3s ease, transform 0.3s ease !important;
    text-decoration: none !important;
    padding: 0.65rem 0.75rem !important;
    box-shadow: 0 6px 18px rgba(233,80,74,0.25) !important;
    white-space: nowrap !important;
    box-sizing: border-box !important;
}
.rvs-card .rvs-btn-cart:hover,
.rvs-card .quick-add:hover,
.rvs-card .add_to_cart_button:hover {
    background: #d4453f !important;
    transform: translateY(-2px) !important;
}
.rvs-card .add_to_cart_button.loading  { opacity: 0.7 !important; pointer-events: none !important; transform: none !important; }
.rvs-card .add_to_cart_button.added    { background: var(--rv-gold) !important; transform: none !important; }
.rvs-card .add_to_cart_button.rv-btn-error { background: #ef4444 !important; }

@media (max-width: 400px) {
    .rvs-btn-view,
    .rvs-card .rvs-btn-cart,
    .rvs-card .add_to_cart_button { font-size: 0.62rem !important; padding: 0.55rem 0.5rem !important; }
    .rvs-card .add_to_cart_button .ph { display: none !important; }
}

/* ── Paginación ── */
.rvs-pagination {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 0.5rem;
    flex-wrap: wrap;
    margin-top: 4rem;
    padding-top: 2rem;
    border-top: 1px solid #f3f4f6;
}

.rvs-pag-btn {
    width: 3.2rem;
    height: 3.2rem;
    border-radius: 50%;
    background: white;
    color: var(--rv-black);
    border: 1px solid #e5e7eb;
    font-weight: 800;
    cursor: pointer;
    transition: all 0.3s;
    font-size: 1rem;
    display: flex;
    align-items: center;
    justify-content: center;
}
.rvs-pag-btn:hover,
.rvs-pag-btn.active {
    background: var(--rv-black);
    color: white;
    border-color: var(--rv-black);
    transform: translateY(-3px);
    box-shadow: 0 8px 15px rgba(0,0,0,0.1);
}
.rvs-pag-dots {
    color: #71717a;
    font-weight: 800;
    display: flex;
    align-items: center;
    padding: 0 0.2rem;
}

/* ── Loader y Empty ── */
.rvs-loader {
    grid-column: 1 / -1;
    text-align: center;
    padding: 6rem 1rem;
}
.rvs-spinner {
    width: 50px;
    height: 50px;
    border: 4px solid #f3f4f6;
    border-top-color: var(--rv-gold);
    border-radius: 50%;
    animation: spin 1s linear infinite;
    margin: 0 auto 1.5rem;
}
.rvs-empty-state {
    text-align: center;
    padding: 6rem 1rem;
    border-radius: 2rem;
    background: #fafafa;
    border: 2px dashed #eee;
}


/* ==========================================================================
   MÓDULO BLOG ARCHIVE — layout sin Tailwind
   #renovatio-blog-content mejoras v2.0
   ========================================================================== */

/* Contenedor principal */
#renovatio-blog-content .blog-container {
    max-width: 1400px;
    margin: 0 auto;
    padding: 4rem 1.5rem 5rem;
}
@media (min-width: 1024px) {
    #renovatio-blog-content .blog-container { padding: 5rem 6% 6rem; }
}

/* Layout sidebar + main */
#renovatio-blog-content .blog-layout {
    display: flex;
    flex-direction: column;
    gap: 2.5rem;
}
@media (min-width: 1024px) {
    #renovatio-blog-content .blog-layout {
        flex-direction: row;
        align-items: flex-start;
        gap: 5rem;
    }
}

/* Sidebar */
#renovatio-blog-content .blog-sidebar {
    width: 100%;
}
@media (min-width: 1024px) {
    #renovatio-blog-content .blog-sidebar {
        width: 240px;
        min-width: 240px;
        flex-shrink: 0;
        position: sticky;
        top: 120px;
    }
}

/* Sección móvil (visible solo en móvil) */
#renovatio-blog-content .blog-mobile-filters { display: block; }
@media (min-width: 1024px) { #renovatio-blog-content .blog-mobile-filters { display: none; } }

/* Sección desktop (visible solo en desktop) */
#renovatio-blog-content .blog-sidebar-desktop { display: none; }
@media (min-width: 1024px) { #renovatio-blog-content .blog-sidebar-desktop { display: block; } }

/* Título del sidebar */
#renovatio-blog-content .blog-sidebar-title {
    font-size: 1rem;
    font-weight: 700;
    color: var(--rv-black, #000);
    margin: 0 0 1rem;
}

/* Widget block */
#renovatio-blog-content .blog-widget { margin-bottom: 2.5rem; }

/* Pills móviles */
#renovatio-blog-content .blog-pills {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-top: 0.75rem;
}

#renovatio-blog-content .cat-pill {
    display: inline-block;
    padding: 0.45rem 1rem;
    border-radius: 3rem;
    font-size: 0.78rem;
    font-weight: 700;
    cursor: pointer;
    background: #f3f4f6;
    color: #555;
    border: none;
    transition: all 0.25s;
}
#renovatio-blog-content .cat-pill.active,
#renovatio-blog-content .cat-pill:hover {
    background: var(--rv-pink, #E9504A);
    color: white;
}

/* Links del sidebar desktop (los existentes en la hoja ya tienen estilos,
   aquí forzamos solo el estado active que el JS necesita) */
#renovatio-blog-content .cat-link.active { color: var(--ob-pink, #E9504A); font-weight: 800; }

/* Banner promo */
#renovatio-blog-content .blog-promo-banner {
    padding: 1.5rem;
    border-radius: 1rem;
    text-align: center;
}
#renovatio-blog-content .blog-promo-title {
    font-size: 1.15rem;
    font-weight: 700;
    margin: 0 0 0.5rem;
    color: var(--rv-black, #000);
}
#renovatio-blog-content .blog-promo-text {
    font-size: 0.82rem;
    color: #666;
    margin: 0 0 1rem;
    line-height: 1.5;
}
#renovatio-blog-content .blog-promo-link {
    font-size: 0.82rem;
    font-weight: 700;
    color: var(--ob-pink, #E9504A);
    border-bottom: 1px solid currentColor;
    padding-bottom: 2px;
    text-decoration: none;
    display: inline-block;
    transition: 0.3s;
}
#renovatio-blog-content .blog-promo-link:hover { color: #000; }

/* Main de artículos */
#renovatio-blog-content .blog-main {
    flex: 1;
    min-width: 0; /* evita overflow en flex */
}


/* ==========================================================================
   PÁGINA NOSOTROS — Hero (#renovatio-about-hero)
   ========================================================================== */

html { scroll-behavior: smooth; }

#renovatio-about-hero {
    --ob-accent: #D0A550;
    --ob-pink:   #E9504A;
    font-family: 'Inter', sans-serif;
    color: #000;
    width: 100%;
    position: relative;
    margin: 0; padding: 0;
}
#renovatio-about-hero .font-display { font-family: 'Playfair Display', serif; }
#renovatio-about-hero .font-body    { font-family: 'Lato', sans-serif; }

/* ── Hero fullscreen ── */
.rvn-hero {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    background: #FFF5F5;
    overflow: hidden;
}

/* ── Orbs decorativos ── */
.rvn-orbs-wrap {
    position: absolute;
    inset: 0;
    overflow: hidden;
    pointer-events: none;
}
.rvn-orb {
    position: absolute;
    border-radius: 50%;
}
.rvn-orb-1 {
    top: -15%; right: -10%;
    width: 600px; height: 600px;
    background: #FFE4E4;
    filter: blur(150px);
    opacity: 0.6;
}
.rvn-orb-2 {
    bottom: -10%; left: -5%;
    width: 500px; height: 500px;
    background: #FFD1D1;
    filter: blur(120px);
    opacity: 0.4;
}
.rvn-orb-3 {
    top: 40%; left: 30%;
    width: 300px; height: 300px;
    background: #FFEAEA;
    filter: blur(100px);
    opacity: 0.3;
}

/* ── Contenido hero ── */
.rvn-hero-content {
    position: relative;
    z-index: 10;
    text-align: center;
    padding: 0 1.5rem;
    max-width: 900px;
    opacity: 0; /* GSAP lo revela; fallback CSS lo anima si GSAP falla */
    animation: rvn-hero-fadein 0.6s ease 0.8s forwards;
}
/* Fallback: si GSAP carga, sobreescribe opacity a tiempo. Si no carga, esta animación garantiza visibilidad. */
@keyframes rvn-hero-fadein {
    to { opacity: 1; }
}

/* Badge "Desde 2015" */
.rvn-hero-badge {
    display: inline-block;
    background: rgba(255,255,255,0.85);
    backdrop-filter: blur(10px);
    color: var(--ob-pink);
    font-weight: 700;
    font-size: 0.72rem;
    letter-spacing: 0.25em;
    text-transform: uppercase;
    padding: 0.45rem 1.25rem;
    border-radius: 30px;
    box-shadow: 0 2px 12px rgba(0,0,0,0.08);
    margin-bottom: 1.5rem;
}

/* Línea decorativa dorada */
.rvn-accent-line {
    width: 60px;
    height: 2px;
    background: linear-gradient(90deg, var(--ob-accent), var(--ob-pink));
    margin: 0 auto 1.5rem;
    border-radius: 2px;
}

/* Título */
.rvn-hero-title {
    font-size: clamp(3rem, 8vw, 6rem);
    font-weight: 700;
    color: #000;
    line-height: 1.05;
    margin: 0 0 1.5rem;
}
.rvn-hero-accent { color: var(--ob-pink); }

/* Subtítulo */
.rvn-hero-desc {
    color: #6B7280;
    font-size: clamp(1rem, 2vw, 1.25rem);
    font-weight: 300;
    line-height: 1.7;
    max-width: 600px;
    margin: 0 auto;
}

/* ── Botón scroll ── */
.rvn-scroll-btn {
    position: absolute;
    bottom: 2.5rem;
    left: 50%;
    transform: translateX(-50%);
    z-index: 20;
    cursor: pointer;
    opacity: 0;
    animation: rvn-hero-fadein 0.4s ease 1.2s forwards; /* fallback si GSAP falla */
    border: none;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 6px;
    padding: 0.75rem 1.25rem;
    background: rgba(255,255,255,0.9);
    backdrop-filter: blur(10px);
    border-radius: 30px;
    box-shadow: 0 4px 20px rgba(0,0,0,0.1);
    transition: transform 0.3s ease;
}
.rvn-scroll-btn:hover { transform: translateX(-50%) translateY(-5px); }

.rvn-scroll-text {
    font-size: 0.68rem;
    font-weight: 600;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    color: #4B5563;
    line-height: 1;
}
.rvn-scroll-icon {
    font-size: 1.15rem;
    color: var(--ob-pink);
    animation: rvn-bounce 1.5s ease-in-out infinite;
}
@keyframes rvn-bounce {
    0%, 100% { transform: translateY(0); }
    50%       { transform: translateY(5px); }
}


/* ==========================================================================
   PÁGINA NOSOTROS — Contenido (#renovatio-about-content)
   ========================================================================== */

#renovatio-about-content {
    --ob-accent: #D0A550;
    --ob-pink:   #E9504A;
    --luxury-shadow: 0 20px 40px -5px rgba(233,80,74,0.12);
    font-family: 'Inter', sans-serif;
    color: #000;
    background: #fff;
    width: 100%;
    line-height: 1.7;
}
#renovatio-about-content h1,
#renovatio-about-content h2,
#renovatio-about-content h3 { line-height: 1.15; margin-top: 0; }
#renovatio-about-content p  { margin-bottom: 1rem; }
#renovatio-about-content .font-display { font-family: 'Playfair Display', serif; }
#renovatio-about-content .font-body    { font-family: 'Lato', sans-serif; }
#renovatio-about-content .font-index   { font-family: 'Cormorant Garamond', serif; }
#renovatio-about-content ul { list-style: none; padding: 0; margin: 0; }

/* Sombra de entrada */
#renovatio-about-content .content-overlay {
    background: white;
    position: relative;
    z-index: 10;
    box-shadow: 0 -10px 40px rgba(0,0,0,0.08);
}

/* ── Navegación lateral sticky ── */
#renovatio-about-content .story-nav {
    position: sticky;
    top: 120px;
    max-height: calc(100vh - 160px);
    overflow-y: auto;
    padding-right: 1rem;
}
#renovatio-about-content .nav-title {
    font-family: 'Cormorant Garamond', serif;
    font-size: 0.85rem;
    font-weight: 600;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    color: var(--ob-accent);
    margin-bottom: 1.5rem;
    padding-bottom: 0.75rem;
    border-bottom: 1px solid rgba(208,165,80,0.3);
}
#renovatio-about-content .story-link {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.65rem 0;
    font-family: 'Cormorant Garamond', serif;
    color: #888;
    font-size: 0.95rem;
    font-weight: 500;
    transition: all 0.3s ease;
    text-decoration: none;
    cursor: pointer;
    letter-spacing: 0.02em;
}
#renovatio-about-content .story-link .nav-number {
    font-family: 'Inter', sans-serif;
    font-size: 0.7rem;
    font-weight: 600;
    color: #ccc;
    width: 20px;
    transition: all 0.3s ease;
}
#renovatio-about-content .story-link:hover         { color: var(--rv-pink) !important; }
#renovatio-about-content .story-link:hover .nav-number { color: var(--ob-accent); }
#renovatio-about-content .story-link.active        { color: #000; font-weight: 700; }
#renovatio-about-content .story-link.active .nav-number { color: var(--ob-pink); }

/* ── Secciones ── */
#renovatio-about-content .story-section {
    padding: 5rem 0;
    border-bottom: 1px solid #f0f0f0;
    scroll-margin-top: 120px; /* compensa header fijo */
}
#renovatio-about-content .story-section:last-child { border-bottom: none; }

/* Badge de capítulo */
#renovatio-about-content .chapter-badge {
    display: inline-block;
    font-family: 'Inter', sans-serif;
    font-size: 0.7rem;
    font-weight: 700;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--ob-accent);
    background: linear-gradient(135deg, #FFF9E6 0%, #FFF5F5 100%);
    padding: 0.5rem 1rem;
    border-radius: 20px;
    margin-bottom: 1.25rem;
    display: inline-block;
}

/* ── Imágenes ── */
#renovatio-about-content .story-image {
    border-radius: 20px;
    overflow: hidden;
    box-shadow: var(--luxury-shadow);
    transition: transform 0.5s ease-out;
}
#renovatio-about-content .story-image:hover     { transform: translateY(-5px); }
#renovatio-about-content .story-image img       { width: 100%; height: 100%; object-fit: cover; transition: transform 0.6s ease; display: block; }
#renovatio-about-content .story-image:hover img { transform: scale(1.05); }

/* ── Quote destacada ── */
#renovatio-about-content .featured-quote {
    font-family: 'Playfair Display', serif;
    font-size: 1.1rem;
    font-style: italic;
    color: #000;
    border-left: 3px solid var(--ob-accent);
    padding-left: 1.25rem;
    margin: 1.5rem 0;
}

/* ── Lista de características ── */
#renovatio-about-content .feature-list { margin: 1.5rem 0; }
#renovatio-about-content .feature-list li {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    padding: 0.5rem 0;
    font-family: 'Lato', sans-serif;
    color: #555;
}
#renovatio-about-content .feature-list li i {
    color: var(--ob-accent);
    font-size: 1.1rem;
    flex-shrink: 0;
    margin-top: 0.15rem;
}

/* ── Card oscura (boutique) ── */
#renovatio-about-content .dark-card {
    background: linear-gradient(135deg, #0a0a0a 0%, #1a1a1a 100%);
    border-radius: 2rem;
    overflow: hidden;
}
#renovatio-about-content .dark-card-label {
    display: inline-block;
    color: var(--ob-accent);
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    margin-bottom: 1rem;
}
#renovatio-about-content .dark-badge {
    display: inline-block;
    background: rgba(255,255,255,0.1);
    color: rgba(255,255,255,0.9);
    padding: 0.4rem 1rem;
    border-radius: 30px;
    font-size: 0.75rem;
    font-weight: 500;
}

/* ── Box de info (salud visual) ── */
#renovatio-about-content .story-info-box {
    background: #FFF5F5;
    border-left: 4px solid var(--ob-accent);
    padding: 1rem 1.25rem;
    margin-top: 1rem;
    border-radius: 0 0.5rem 0.5rem 0;
    font-size: 0.9rem;
    color: #374151;
}

/* ── Card de tienda (sección 08) ── */
#renovatio-about-content .story-store-card {
    background: white;
    border-radius: 1.5rem;
    box-shadow: 0 10px 40px rgba(0,0,0,0.08);
    border: 1px solid #f3f4f6;
    overflow: hidden;
}
#renovatio-about-content .store-info-col {
    background: linear-gradient(135deg, #FFF8F8 0%, #FFF5F5 100%);
    padding: 2.5rem;
    display: flex;
    flex-direction: column;
    justify-content: center;
}
#renovatio-about-content .store-subtitle {
    font-size: 0.85rem;
    color: #6B7280;
    margin-bottom: 2rem;
}
#renovatio-about-content .store-details { margin-bottom: 2rem; }
#renovatio-about-content .store-detail-item {
    display: flex;
    align-items: flex-start;
    gap: 1rem;
    margin-bottom: 1.25rem;
}
#renovatio-about-content .store-icon-wrap {
    width: 2.5rem;
    height: 2.5rem;
    border-radius: 50%;
    background: white;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 2px 8px rgba(0,0,0,0.08);
    color: var(--ob-pink);
    font-size: 1.1rem;
    flex-shrink: 0;
}
#renovatio-about-content .store-detail-title {
    font-weight: 600;
    color: #111;
    font-size: 0.9rem;
    display: block;
}
#renovatio-about-content .store-detail-sub {
    font-size: 0.75rem;
    color: #6B7280;
    display: block;
}
#renovatio-about-content .store-cta {
    display: block;
    text-align: center;
}
#renovatio-about-content .store-img-col {
    position: relative;
    min-height: 400px;
}
#renovatio-about-content .store-img-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(0,0,0,0.15), transparent);
    pointer-events: none;
}

/* ── Botón CTA (local — no sobreescribe .btn-renovatio global) ── */
#renovatio-about-content .btn-renovatio {
    display: inline-block;
    background: var(--ob-pink);
    color: white !important;
    padding: 1rem 2rem;
    border-radius: 30px;
    font-size: 0.8rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    text-decoration: none;
    transition: all 0.3s ease;
    box-shadow: 0 10px 30px rgba(233,80,74,0.25);
}
#renovatio-about-content .btn-renovatio:hover {
    background: #c43e38;
    transform: translateY(-3px);
    box-shadow: 0 15px 40px rgba(233,80,74,0.35);
}

/* ── Responsive tienda card ── */
@media (max-width: 767px) {
    #renovatio-about-content .store-info-col { padding: 2rem 1.5rem; }
    #renovatio-about-content .store-img-col  { min-height: 280px; }
}

/* ==============================================
   MÓDULO STORYTELLING — #renovatio-elementor-wrapper
   ============================================== */
#renovatio-elementor-wrapper {
    --ob-primary: #000000;
    --ob-accent: #D0A550;
    --ob-pink: #E9504A;
    --ob-bg: #ffffff;
    --luxury-shadow: 0 20px 40px -5px rgba(233, 80, 74, 0.15);
    font-family: 'Inter', sans-serif;
    color: var(--ob-primary);
    background-color: var(--ob-bg);
    width: 100%;
    position: relative;
}

#renovatio-elementor-wrapper h1, 
#renovatio-elementor-wrapper h2, 
#renovatio-elementor-wrapper h3 {
    line-height: 1.2;
}

#renovatio-elementor-wrapper .font-display { font-family: 'Playfair Display', serif; }
#renovatio-elementor-wrapper .font-body { font-family: 'Lato', sans-serif; }

#renovatio-elementor-wrapper .scroll-section,
#renovatio-elementor-wrapper .hero-section-snap {
    min-height: 90vh;
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding-top: 4rem;
    padding-bottom: 4rem;
    position: relative;
}

#renovatio-elementor-wrapper .btn-renovatio {
    background: var(--ob-pink);
    color: white;
    transition: 0.3s;
    display: inline-block;
    text-decoration: none;
}
#renovatio-elementor-wrapper .btn-renovatio:hover {
    background: #c43e38;
    transform: translateY(-3px);
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.2);
}

#renovatio-elementor-wrapper .story-nav {
    position: -webkit-sticky;
    position: sticky;
    top: 150px;
    height: fit-content;
    z-index: 50;
    align-self: start;
    padding-bottom: 2rem;
}

#renovatio-elementor-wrapper .story-link {
    display: block;
    padding: 0.75rem 0;
    color: #ccc;
    font-size: 0.85rem;
    font-weight: 400;
    transition: all 0.4s ease;
    position: relative;
    cursor: pointer;
    letter-spacing: 0.05em;
    text-decoration: none;
}

#renovatio-elementor-wrapper .story-link::before {
    content: '';
    position: absolute;
    left: -1.5rem;
    top: 50%;
    transform: translateY(-50%);
    width: 0;
    height: 1px;
    background: var(--ob-accent);
    transition: width 0.3s;
}

#renovatio-elementor-wrapper .story-link.active {
    color: var(--ob-primary);
    font-weight: 700;
    padding-left: 0.5rem;
    transform: scale(1.05);
}

#renovatio-elementor-wrapper .story-link.active::before {
    width: 1rem;
}

#renovatio-elementor-wrapper .story-image-container {
    border-radius: 16px;
    overflow: hidden;
    box-shadow: var(--luxury-shadow);
    transform: translateY(0);
    transition: transform 0.5s ease-out;
}

#renovatio-elementor-wrapper .story-chapter {
    font-family: 'Inter', sans-serif;
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--ob-accent);
    margin-bottom: 1rem;
    display: block;
}

#renovatio-elementor-wrapper ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

/* ==============================================
   MÓDULO ROSTROS QUE NOS PREFIEREN — #renovatio-home-faces
   ============================================== */
#renovatio-home-faces {
    background: #fafafa;
    padding: 5rem 5%;
    overflow: hidden;
}
#renovatio-home-faces .faces-container {
    max-width: 1200px;
    margin: 0 auto;
}
/* Estilo Polaroid (Carrusel en Desktop) */
#renovatio-home-faces .polaroid-grid {
    display: flex;
    overflow-x: auto;
    gap: 2rem;
    margin-top: 3rem;
    padding-bottom: 2rem; /* Espacio para scroll y sombra */
    scroll-snap-type: x mandatory;
    scrollbar-width: thin;
    scrollbar-color: #E9504A transparent;
}
/* Ocultar scrollbar en WebKit para un look más limpio (opcional, pero recomendado) */
#renovatio-home-faces .polaroid-grid::-webkit-scrollbar {
    height: 8px;
}
#renovatio-home-faces .polaroid-grid::-webkit-scrollbar-track {
    background: transparent;
}
#renovatio-home-faces .polaroid-grid::-webkit-scrollbar-thumb {
    background-color: #E9504A;
    border-radius: 20px;
}

#renovatio-home-faces .polaroid-item {
    background: white;
    padding: 1rem 1rem 3rem 1rem;
    box-shadow: 0 10px 25px rgba(0,0,0,0.1);
    transform: rotate(var(--rotation, -2deg));
    transition: all 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
    cursor: pointer;
    position: relative;
    flex: 0 0 calc(20% - 1.6rem); /* 5 items visibles en desktop */
    scroll-snap-align: start;
}
#renovatio-home-faces .polaroid-item:nth-child(even) {
    --rotation: 3deg;
    margin-top: 1rem;
}
#renovatio-home-faces .polaroid-item:hover {
    transform: rotate(0deg) scale(1.05);
    z-index: 10;
    box-shadow: 0 15px 35px rgba(233, 80, 74, 0.2);
}
#renovatio-home-faces .polaroid-img-wrap {
    width: 100%;
    aspect-ratio: 1/1;
    overflow: hidden;
    background: #eee;
    margin-bottom: 1.5rem;
    border: 1px solid #f0f0f0;
}
#renovatio-home-faces .polaroid-img-wrap img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    filter: sepia(0.2) contrast(1.1);
}
#renovatio-home-faces .polaroid-text {
    font-family: 'Permanent Marker', cursive, sans-serif;
    text-align: center;
    color: #333;
    font-size: 1.1rem;
    line-height: 1.2;
}
#renovatio-home-faces .polaroid-text small {
    display: block;
    font-family: 'Lato', sans-serif;
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: var(--ob-pink, #E9504A);
    margin-top: 0.5rem;
    font-weight: 700;
}
/* Mobile Responsive y Animaciones */
@media (min-width: 1025px) {
    #renovatio-home-faces .polaroid-grid {
        overflow: visible;
        width: max-content;
        animation: scrollMarquee 30s linear infinite;
        scroll-snap-type: none; /* Quitamos el snap en desktop para el marquee */
    }
    #renovatio-home-faces .polaroid-grid:hover {
        animation-play-state: paused;
    }
    #renovatio-home-faces .polaroid-item {
        flex: 0 0 260px; /* Ancho fijo para el carrusel infinito */
    }
}

@keyframes scrollMarquee {
    0% { transform: translateX(0); }
    100% { transform: translateX(calc(-50% - 1rem)); } /* 1rem es la mitad del gap (2rem) */
}

@media (max-width: 1024px) {
    #renovatio-home-faces .polaroid-grid {
        gap: 1.5rem;
    }
    #renovatio-home-faces .polaroid-item {
        flex: 0 0 calc(33.333% - 1rem); /* 3 items visibles en tablet */
    }
}
@media (max-width: 640px) {
    #renovatio-home-faces {
        padding: 4rem 4%;
    }
    #renovatio-home-faces .polaroid-grid {
        gap: 1rem;
    }
    #renovatio-home-faces .polaroid-item {
        flex: 0 0 calc(50% - 0.5rem); /* 2 items visibles en mobile */
    }
}

/* ==========================================================================
   FIXES CHECKOUT ASTRA
   ========================================================================== */
.renovatio-checkout-wrapper .woocommerce-checkout .form-row label { 
    display: block !important; 
    position: static !important; 
    transform: none !important; 
    opacity: 1 !important; 
    padding: 0 0 5px 0 !important; 
    height: auto !important; 
    pointer-events: auto !important; 
    font-size: 0.85rem !important;
}
.renovatio-checkout-wrapper .woocommerce-checkout .form-row input, 
.renovatio-checkout-wrapper .woocommerce-checkout .form-row select, 
.renovatio-checkout-wrapper .woocommerce-checkout .form-row textarea { 
    padding: 12px 16px !important; 
    box-sizing: border-box !important; 
    width: 100% !important; 
    margin-bottom: 0 !important;
}
.renovatio-checkout-wrapper .woocommerce-checkout .form-row .woocommerce-input-wrapper { 
    width: 100% !important; 
    display: block !important; 
}
.select2-container--default .select2-selection--single { 
    height: auto !important; 
    padding: 10px !important; 
}
.renovatio-checkout-wrapper .woocommerce-checkout .form-row {
    margin-bottom: 1.2rem !important;
}

/* Fix Tabla Checkout Border Cutoff */
.renovatio-checkout-wrapper .woocommerce-checkout-review-order-table {
    border: none !important; 
    box-shadow: 0 0 0 1px #e5e5e5, 0 10px 30px rgba(0,0,0,0.03) !important;
    box-sizing: border-box !important;
    width: 100% !important;
    max-width: 100% !important;
    table-layout: fixed !important; /* Fuerza a que la tabla no se expanda más allá de su contenedor */
    word-wrap: break-word !important;
}

/* Fix Ancho de las columnas de la tabla (Solo Escritorio) */
@media (min-width: 769px) {
    .renovatio-checkout-wrapper .woocommerce-checkout-review-order-table th.product-name,
    .renovatio-checkout-wrapper .woocommerce-checkout-review-order-table td.product-name {
        width: 50% !important;
    }
    
    /* Desvincular la fila de Envío de las columnas de la tabla para darle todo el espacio posible */
    .renovatio-checkout-wrapper .woocommerce-checkout-review-order-table tr.woocommerce-shipping-totals {
        display: flex !important;
        align-items: flex-start !important;
        width: 100% !important;
        border-bottom: 1px solid #f5f5f5 !important;
        flex-wrap: nowrap !important;
    }
    .renovatio-checkout-wrapper .woocommerce-checkout-review-order-table tr.woocommerce-shipping-totals th {
        flex: 0 0 auto !important; /* Ocupa solo el ancho exacto de la palabra "Envío" */
        width: auto !important;
        max-width: none !important;
        padding-right: 15px !important;
        border-bottom: none !important;
        white-space: nowrap !important; 
        word-wrap: normal !important;
    }
    .renovatio-checkout-wrapper .woocommerce-checkout-review-order-table tr.woocommerce-shipping-totals td {
        flex: 1 !important; /* Ocupa TODO el espacio sobrante hacia la izquierda */
        width: auto !important;
        max-width: none !important;
        border-bottom: none !important;
        padding-left: 0 !important;
    }
}

/* Fix Radio Buttons Alineación Arriba para textos largos */
html body .renovatio-checkout-wrapper #order_review .woocommerce-shipping-methods li {
    align-items: flex-start !important;
}
html body .renovatio-checkout-wrapper #order_review .woocommerce-shipping-methods input[type="radio"] {
    margin-top: 2px !important;
}

/* Fix Distribución del Precio en el Label y Overflow */
.renovatio-checkout-wrapper .woocommerce-shipping-methods {
    box-sizing: border-box !important;
    width: 100% !important;
    max-width: 100% !important;
    padding-left: 0 !important; /* Evitar que el theme empuje la lista a la derecha */
    margin-left: 0 !important;
    text-align: left !important;
}
.renovatio-checkout-wrapper .woocommerce-shipping-methods li {
    box-sizing: border-box !important;
    width: 100% !important;
    max-width: 100% !important;
    white-space: normal !important;
}
.renovatio-checkout-wrapper .woocommerce-shipping-methods label {
    display: flex !important;
    flex-wrap: wrap !important;
    justify-content: space-between !important;
    align-items: flex-start !important;
    gap: 8px !important;
    box-sizing: border-box !important;
    flex: 1 !important;
    min-width: 0 !important; 
    word-break: normal !important; 
}
.renovatio-checkout-wrapper .woocommerce-shipping-methods label .amount {
    margin-left: auto;
    white-space: nowrap !important;
}