/**
 * Theme CSS - Modern Compact-v2
 * Generado automáticamente por el Generador de Themes
 * Estilos personalizados del theme
 */

/* =================================
   GLOBAL
   ================================= */

body {
    font-family: var(--font-family);
    line-height: var(--line-height-normal);
    color: var(--color-text);
    background-color: var(--color-bg);
}

/* Headings */
h1, h2, h3, h4, h5, h6 {
    font-family: var(--font-family-heading);
    font-weight: var(--font-weight-bold);
    line-height: var(--line-height-tight);
    color: var(--color-text-dark);
    margin-bottom: var(--spacing-md);
}

/* Links */
a {
    color: var(--color-primary);
    text-decoration: none;
    transition: var(--transition-base);
}

a:hover {
    color: var(--color-secondary);
}

/* =================================
   PRODUCT CARDS
   ================================= */

.product-card {
    border: var(--border-width) solid var(--color-border);
    border-radius: 0;
    box-shadow: var(--shadow-md);
    background: var(--glass-bg);
    backdrop-filter: blur(var(--blur-md));
    border: 1px solid var(--glass-border);
    transition: var(--transition-base);
}

.product-card:hover {
    transform: var(--transform-3d-lift) scale(1.02);
    box-shadow: var(--shadow-xl);
    background: var(--gradient-glass-hover, rgba(255, 255, 255, 0.85));
}

.product-info {
    padding-top: var(--spacing-lg);
    padding-left: var(--spacing-lg);
    padding-right: var(--spacing-lg);
    padding-bottom: 0;
    display: flex;
    flex-direction: column;
    flex: 1;
}

.product-buttons {
    display: flex;
    gap: var(--spacing-sm);
    margin-top: 10px;
    margin-bottom: 12px !important;
}

/* =================================
   BUTTONS
   ================================= */

.btn, .btn-primary, .btn-secondary, .btn-add-cart {
    padding: var(--spacing-sm) var(--spacing-lg);
    font-weight: var(--font-weight-semibold);
    transition: var(--transition-base);
    cursor: pointer;
    display: inline-block;
    text-align: center;
    border-radius: var(--border-radius-sm);
}

/* =================================
   BADGES
   ================================= */

.cart-badge {
    border-radius: 50% !important;
}

.mobile-menu-badge {
    border-radius: 50% !important;
}

.favorite-heart-card {
    border-radius: 50% !important;
}

.favorite-heart {
    border-radius: 50% !important;
}

/* =================================
   HEADER
   ================================= */

.header {
    background: var(--color-bg);
    border-bottom: var(--border-width) solid var(--color-border);
    box-shadow: var(--shadow-sm);
}

/* =================================
   PRODUCT VIEW
   ================================= */

.product-gallery {
    display: flex;
    flex-direction: row-reverse;
}

.product-thumbnails {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
    margin-right: var(--spacing-md);
}

.product-main-image {
    width: 100%;
    height: auto;
}

.product-thumbnail {
    width: 80px;
    height: 80px;
    object-fit: cover;
    cursor: pointer;
    border: 2px solid transparent;
    transition: var(--transition-base);
}

.product-thumbnail:hover,
.product-thumbnail.active {
    border-color: var(--color-primary);
}

.image-counter {
    display: none !important;
}

.product-gallery {
    width: 100%;
    max-width: 100%;
    margin: 0 auto;
}

/* =================================
   RESPONSIVE
   ================================= */

@media (max-width: 768px) {
    .product-grid {
        grid-template-columns: 1fr !important;
        gap: var(--spacing-lg) !important;
    }

    .product-gallery {
        max-width: 100% !important;
        margin: 0 !important;
    }

    .product-main-image {
        max-width: 100% !important;
    }

    .product-gallery {
        flex-direction: column !important;
    }

    .product-thumbnails {
        flex-direction: row !important;
        margin: var(--spacing-md) 0 0 0 !important;
        justify-content: center;
    }

}

@media (max-width: 480px) {
    .product-thumbnail {
        width: 60px !important;
        height: 60px !important;
    }
}

/* =================================
   HEADER & CONTAINERS 3D
   ================================= */

.header {
    background: rgba(255, 255, 255, 0.85);
    backdrop-filter: blur(var(--blur-md, 16px));
    -webkit-backdrop-filter: blur(var(--blur-md, 16px));
    border-bottom: 1px solid rgba(255, 255, 255, 0.3);
    box-shadow: var(--shadow-lg, 0 8px 24px rgba(0, 0, 0, 0.15));
    position: relative;
}

.product-container {
    background: rgba(255, 255, 255, 0.7);
    backdrop-filter: blur(var(--blur-md, 16px));
    -webkit-backdrop-filter: blur(var(--blur-md, 16px));
    border: 1px solid rgba(255, 255, 255, 0.3);
    border-radius: var(--border-radius-2xl, 32px);
    padding: var(--spacing-2xl, 48px);
    box-shadow: var(--shadow-2xl, 0 20px 48px rgba(0, 0, 0, 0.25));
}

.breadcrumb {
    margin-bottom: var(--spacing-md, 16px);
}

.breadcrumb ol {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px;
    list-style: none;
    margin: 0;
    padding: 0;
}

.breadcrumb li {
    display: flex;
    align-items: center;
    gap: 8px;
}

.breadcrumb a {
    color: var(--color-primary, #005461);
    text-decoration: none;
    transition: opacity 0.2s;
}

.breadcrumb a:hover {
    opacity: 0.7;
    text-decoration: underline;
}

.breadcrumb-separator {
    color: var(--color-text-light, #999);
    user-select: none;
}

/* =================================
   PRODUCT GALLERY LAYOUTS
   ================================= */

.main-image-container {
    border: 2px solid rgba(255, 255, 255, 0.3);
    background: rgba(255, 255, 255, 0.7);
    backdrop-filter: blur(10px);
    border-radius: var(--border-radius-xl, 24px);
    box-shadow: var(--shadow-xl, 0 24px 48px rgba(0, 0, 0, 0.3));
    position: relative;
    overflow: hidden;
}

.thumbnail {
    border: 3px solid var(--color-border, #e0e0e0);
    border-radius: var(--border-radius-md, 12px);
    transition: all var(--transition-base, 0.3s ease);
    opacity: 0.8;
    cursor: pointer;
    overflow: hidden;
}

.thumbnail:hover {
    opacity: 1;
    border-color: var(--color-primary, #005461);
    transform: scale(1.05);
}

.thumbnail.active {
    opacity: 1;
    border-color: var(--color-primary, #005461);
    box-shadow: 0 0 0 2px rgba(var(--color-primary-rgb, 0, 84, 97), 0.2);
}

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

.zoom-indicator {
    display: none;
}

.product-gallery.thumbnails-bottom {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.product-gallery.thumbnails-bottom .product-thumbnails {
    display: flex;
    flex-direction: row;
    gap: 12px;
    justify-content: center;
}

.product-gallery.thumbnails-left {
    display: flex;
    flex-direction: row-reverse;
    gap: 16px;
    align-items: flex-start;
}

.product-gallery.thumbnails-left .product-thumbnails {
    display: flex;
    flex-direction: column;
    gap: 12px;
    flex-shrink: 0;
    width: 100px;
}

.product-gallery.thumbnails-left .main-image-container {
    flex: 1;
    min-width: 0;
    max-width: 100%;
}

.product-gallery.thumbnails-left .main-image-container img {
    width: 100%;
    height: auto;
    max-height: 600px;
    object-fit: contain;
}

.product-gallery.thumbnails-right {
    display: flex;
    flex-direction: row;
    gap: 16px;
    align-items: flex-start;
}

.product-gallery.thumbnails-right .product-thumbnails {
    display: flex;
    flex-direction: column;
    gap: 12px;
    flex-shrink: 0;
    width: 100px;
}

.product-gallery.thumbnails-right .main-image-container {
    flex: 1;
    min-width: 0;
    max-width: 100%;
}

.product-gallery.thumbnails-right .main-image-container img {
    width: 100%;
    height: auto;
    max-height: 600px;
    object-fit: contain;
}

@media (max-width: 768px) {
    .product-gallery.thumbnails-left,
    .product-gallery.thumbnails-right {
        flex-direction: column !important;
    }

    .product-gallery.thumbnails-left .product-thumbnails,
    .product-gallery.thumbnails-right .product-thumbnails {
        flex-direction: row !important;
        max-width: none !important;
        justify-content: center;
    }
}

/* =================================
   CARRITO MEJORADO
   ================================= */

.cart-breadcrumb-row { max-width: 1400px; margin: 0 auto; padding: var(--spacing-md) var(--spacing-lg); display: flex; justify-content: space-between; align-items: center; gap: var(--spacing-lg); }
.cart-breadcrumb-left { flex: 1; }
.cart-page-title { display: flex; align-items: center; gap: var(--spacing-sm); }
.cart-page-title .cart-icon { stroke: var(--color-primary); }
.cart-page-title h1 { margin: 0; font-size: var(--font-size-2xl); white-space: nowrap; }
.cart-page-container { max-width: 1400px; margin: 0 auto; padding: 0 var(--spacing-lg) var(--spacing-2xl) var(--spacing-lg); }

.cart-layout { display: grid; grid-template-columns: 11fr 9fr; gap: var(--spacing-2xl); align-items: start; max-width: 1400px; }
@media (max-width: 1024px) { .cart-layout { grid-template-columns: 1fr; } }

.cart-items-section { background: var(--color-bg); border: 1px solid var(--color-border-light); border-radius: var(--border-radius-lg); padding: var(--spacing-2xl); box-shadow: var(--shadow-md); }
.cart-items-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: var(--spacing-xl); padding-bottom: var(--spacing-lg); border-bottom: 2px solid var(--color-border); }
.items-title { margin: 0; font-size: var(--font-size-2xl); }
.items-count { font-size: var(--font-size-base); color: var(--color-text-light); background: var(--color-background-alt); padding: var(--spacing-xs) var(--spacing-md); border-radius: var(--border-radius-full); font-weight: var(--font-weight-semibold); }

.cart-items-list { display: flex; flex-direction: column; gap: var(--spacing-lg); }

.cart-item-card { background: var(--color-bg); border: 1px solid var(--color-border-light); border-radius: var(--border-radius-md); padding: var(--spacing-lg); display: grid; grid-template-columns: 120px 1fr; gap: var(--spacing-lg); transition: var(--transition-base); }
.cart-item-card:hover { box-shadow: var(--shadow-lg); border-color: var(--color-primary); }
.cart-item-image { width: 120px; height: 120px; border-radius: var(--border-radius-md); overflow: hidden; background: var(--color-background-alt); display: flex; align-items: center; justify-content: center; }
.cart-item-image img { width: 100%; height: 100%; object-fit: cover; }
.no-image-placeholder { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; color: var(--color-text-light); font-size: var(--font-size-sm); background: var(--color-background-alt); }

.cart-item-info { display: flex; flex-direction: column; gap: var(--spacing-sm); }
.cart-item-header { display: flex; justify-content: space-between; align-items: flex-start; gap: var(--spacing-md); }
.cart-item-name { margin: 0; font-size: var(--font-size-lg); font-weight: var(--font-weight-semibold); color: var(--color-text); flex: 1; }
.cart-item-remove { background: transparent; border: none; padding: var(--spacing-xs); cursor: pointer; color: var(--color-text-light); transition: var(--transition-base); border-radius: var(--border-radius-md); }
.cart-item-remove:hover { background: var(--color-danger-light); color: var(--color-danger); }

.cart-item-badge { display: inline-flex; align-items: center; gap: var(--spacing-xs); font-size: var(--font-size-xs); padding: var(--spacing-xs) var(--spacing-sm); border-radius: var(--border-radius-md); font-weight: var(--font-weight-semibold); }
.badge-promotion { background: #FFE5E5; color: #C41E3A; }
.badge-coupon { background: #E5F3FF; color: #0066CC; }

.cart-item-pricing { display: flex; align-items: center; gap: var(--spacing-md); flex-wrap: wrap; }
.cart-item-price-group { display: flex; align-items: center; gap: var(--spacing-sm); }
.cart-item-price-original { text-decoration: line-through; color: var(--color-text-light); font-size: var(--font-size-base); }
.cart-item-price-discounted { font-size: var(--font-size-xl); font-weight: var(--font-weight-bold); color: var(--color-primary); }
.cart-item-price-single { font-size: var(--font-size-xl); font-weight: var(--font-weight-bold); color: var(--color-primary); }
.cart-item-quantity-label { color: var(--color-text-light); font-size: var(--font-size-base); }

.cart-item-footer { display: flex; justify-content: space-between; align-items: center; gap: var(--spacing-lg); margin-top: var(--spacing-sm); flex-wrap: wrap; }
.cart-item-stock { display: flex; align-items: center; gap: var(--spacing-xs); font-size: var(--font-size-sm); }
.cart-item-stock.stock-ok { color: var(--color-success); }
.cart-item-stock.stock-warning { color: var(--color-warning); }

.cart-item-quantity-control { display: flex; align-items: center; gap: var(--spacing-xs); background: var(--color-background-alt); border: 1px solid var(--color-border); border-radius: var(--border-radius-md); padding: var(--spacing-xs); }
.quantity-btn-minus, .quantity-btn-plus { width: 32px; height: 32px; border: none; background: var(--color-primary); color: white; border-radius: var(--border-radius-sm); cursor: pointer; display: flex; align-items: center; justify-content: center; transition: var(--transition-base); }
.quantity-btn-minus:hover, .quantity-btn-plus:hover { background: var(--color-primary-dark); }
.quantity-btn-minus:disabled, .quantity-btn-plus:disabled { opacity: 0.5; cursor: not-allowed; }
.quantity-input { width: 50px; text-align: center; border: none; background: transparent; font-size: var(--font-size-base); font-weight: var(--font-weight-semibold); color: var(--color-text); }

.empty-cart-state { text-align: center; padding: var(--spacing-4xl) var(--spacing-xl); }
.empty-cart-icon { margin: 0 auto var(--spacing-xl); opacity: 0.3; }
.empty-cart-icon svg { stroke: var(--color-text-light); }
.empty-cart-title { font-size: var(--font-size-3xl); margin-bottom: var(--spacing-md); }
.empty-cart-message { font-size: var(--font-size-lg); color: var(--color-text-light); margin-bottom: var(--spacing-2xl); }
.btn-shop-now { display: inline-flex; align-items: center; gap: var(--spacing-sm); background: var(--color-primary); color: white; padding: var(--spacing-md) var(--spacing-2xl); border-radius: var(--border-radius-lg); font-weight: var(--font-weight-semibold); font-size: var(--font-size-base); transition: var(--transition-base); box-shadow: var(--shadow-md); }
.btn-shop-now:hover { transform: translateY(-2px); box-shadow: var(--shadow-lg); background: var(--color-primary-dark); }

.cart-summary-sidebar { position: sticky; top: var(--spacing-xl); }
.summary-card { background: var(--color-bg); border: 1px solid var(--color-border-light); border-radius: var(--border-radius-lg); padding: var(--spacing-lg); box-shadow: var(--shadow-md); }
.summary-title { margin: 0 0 var(--spacing-md) 0; font-size: var(--font-size-xl); text-align: center; }

.currency-selector { margin-bottom: var(--spacing-md); padding-bottom: var(--spacing-md); border-bottom: 1px solid var(--color-border); }
.currency-label { display: block; font-size: var(--font-size-sm); color: var(--color-text-light); margin-bottom: var(--spacing-sm); font-weight: var(--font-weight-semibold); }
.currency-toggle-buttons { display: grid; grid-template-columns: 1fr 1fr; gap: var(--spacing-sm); }
.currency-btn { padding: var(--spacing-sm) var(--spacing-md); border: 2px solid var(--color-border); background: var(--color-bg); border-radius: var(--border-radius-md); cursor: pointer; transition: var(--transition-base); display: flex; align-items: center; justify-content: center; gap: var(--spacing-xs); font-weight: var(--font-weight-semibold); }
.currency-btn:hover { border-color: var(--color-primary); }
.currency-btn.active { background: var(--color-primary); border-color: var(--color-primary); color: white; }
.currency-symbol { font-weight: var(--font-weight-bold); }

.summary-coupon-section { margin-bottom: var(--spacing-md); padding-bottom: var(--spacing-md); border-bottom: 1px solid var(--color-border); }
.summary-totals-section { margin-bottom: var(--spacing-md); }
.summary-row { display: flex; justify-content: space-between; align-items: center; padding: var(--spacing-sm) 0; font-size: var(--font-size-base); }
.summary-row.total { font-size: var(--font-size-xl); font-weight: var(--font-weight-bold); padding-top: var(--spacing-md); border-top: 2px solid var(--color-border); margin-top: var(--spacing-md); }
.summary-row.total span:last-child { color: var(--color-primary); }
.summary-row.promotion, .summary-row.discount { color: var(--color-success); font-weight: var(--font-weight-semibold); }

.summary-actions { display: flex; flex-direction: column; gap: var(--spacing-sm); }
.btn-checkout { width: 100%; padding: var(--spacing-lg) var(--spacing-xl); background: var(--color-primary); color: white; border: none; border-radius: var(--border-radius-lg); font-size: var(--font-size-lg); font-weight: var(--font-weight-bold); cursor: pointer; display: flex; align-items: center; justify-content: center; gap: var(--spacing-sm); transition: var(--transition-base); box-shadow: var(--shadow-md); }
.btn-checkout:hover { transform: translateY(-2px); box-shadow: var(--shadow-lg); background: var(--color-primary-dark); }
.btn-continue-shopping { width: 100%; padding: var(--spacing-md) var(--spacing-lg); background: transparent; color: var(--color-text); border: 2px solid var(--color-border); border-radius: var(--border-radius-md); font-size: var(--font-size-base); font-weight: var(--font-weight-semibold); cursor: pointer; display: flex; align-items: center; justify-content: center; gap: var(--spacing-xs); transition: var(--transition-base); text-decoration: none; }
.btn-continue-shopping:hover { border-color: var(--color-primary); color: var(--color-primary); }

.summary-security { margin-top: var(--spacing-md); padding-top: var(--spacing-md); border-top: 1px solid var(--color-border); display: flex; align-items: center; justify-content: center; gap: var(--spacing-xs); font-size: var(--font-size-sm); color: var(--color-text-light); }
.summary-security svg { stroke: var(--color-success); }

.cart-loading { opacity: 0.6; pointer-events: none; }

@media (max-width: 768px) {
    .cart-breadcrumb-row { flex-direction: column; align-items: flex-start; gap: var(--spacing-sm); }
    .cart-page-title h1 { font-size: var(--font-size-xl); }
    .cart-item-card { grid-template-columns: 80px 1fr; }
    .cart-item-image { width: 80px; height: 80px; }
    .cart-item-footer { flex-direction: column; align-items: flex-start; }
}

