/**
 * Sistema de Marca de Agua CSS Overlay
 * Se aplica visualmente sin modificar las imágenes originales
 * Se puede activar/desactivar dinámicamente
 */

/* Contenedor con marca de agua */
.producto-imagen-con-marca {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    overflow: hidden;
}

/* Overlay de marca de agua */
.producto-imagen-con-marca::after {
    content: attr(data-marca-texto);
    position: absolute;
    color: rgba(255, 255, 255, 0.9);
    font-size: 24px;
    font-weight: bold;
    font-family: Arial, sans-serif;
    text-shadow: 
        2px 2px 4px rgba(0, 0, 0, 0.8),
        -1px -1px 2px rgba(0, 0, 0, 0.5);
    pointer-events: none;
    z-index: 10;
    white-space: nowrap;
}

/* Posiciones de marca de agua */
.marca-superior-izquierda::after {
    top: 20px;
    left: 20px;
}

.marca-superior-derecha::after {
    top: 20px;
    right: 20px;
}

.marca-inferior-izquierda::after {
    bottom: 20px;
    left: 20px;
}

.marca-inferior-derecha::after {
    bottom: 20px;
    right: 20px;
}

.marca-centro::after {
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}

/* Tamaños de marca */
.marca-pequena::after {
    font-size: 16px;
}

.marca-mediana::after {
    font-size: 24px;
}

.marca-grande::after {
    font-size: 36px;
}

.marca-extra-grande::after {
    font-size: 48px;
}

/* Opacidades */
.marca-opacidad-baja::after {
    color: rgba(255, 255, 255, 0.3);
}

.marca-opacidad-media::after {
    color: rgba(255, 255, 255, 0.6);
}

.marca-opacidad-alta::after {
    color: rgba(255, 255, 255, 0.9);
}

/* Imagen dentro del contenedor */
.producto-imagen-con-marca img {
    max-width: 100% !important;
    max-height: 100% !important;
    width: auto !important;
    height: auto !important;
    object-fit: contain !important;
}
