/**
 * Rating Stars Styles for Bricks Form
 * Nomenclatura BEM
 *
 * @package GouFoody
 * @since 1.0.0
 */

/* ==========================================================================
   BLOCK: star-rating-field
   ========================================================================== */

.star-rating-field {
    --rating-color-full: #ffd64f;
    --rating-color-empty: #999;
    --rating-icon-size: 30px;
    --rating-gap: 0;
    
    display: inline-flex;
    position: relative;
    vertical-align: middle;
    align-items: center;
}

/* Modificador: LTR (left-to-right) */
.star-rating-field--ltr {
    direction: ltr;
}

/* ==========================================================================
   ELEMENT: star-rating-field__select (select oculto)
   ========================================================================== */

.star-rating-field__select {
    clip-path: inset(50%);
    height: 1px !important;
    margin: 0 !important;
    opacity: 0 !important;
    overflow: hidden !important;
    padding: 0 !important;
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    visibility: visible !important;
    white-space: nowrap !important;
    width: 1px !important;
}

/* ==========================================================================
   ELEMENT: star-rating-field__stars (contenedor de íconos)
   ========================================================================== */

.star-rating-field__stars {
    display: inline-flex;
    flex-direction: row;
    cursor: pointer;
    line-height: 1;
    gap: var(--rating-gap);
}

/* ==========================================================================
   ELEMENT: star-rating-field__icon (ícono individual)
   Soporta tanto <i> como <svg>
   ========================================================================== */

.star-rating-field__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    transition: color 0.15s ease, transform 0.15s ease, opacity 0.15s ease;
    font-size: var(--rating-icon-size);
}

/* Estilos para íconos de fuente (<i>) */
.star-rating-field__icon i {
    font-size: inherit;
    line-height: 1;
}

/* Estilos para íconos SVG */
.star-rating-field__icon svg {
    width: 1em;
    height: 1em;
    display: block;
    fill: currentColor;
}

/* Modificador: estado vacío */
.star-rating-field__icon--empty {
    color: var(--rating-color-empty);
}

.star-rating-field__icon--empty svg {
    fill: var(--rating-color-empty);
}

/* Modificador: estado lleno/activo */
.star-rating-field__icon--full {
    color: var(--rating-color-full);
}

.star-rating-field__icon--full svg {
    fill: var(--rating-color-full);
}

/* ==========================================================================
   Estados de Hover
   ========================================================================== */

/* Al hacer hover sobre el container, atenuar todas las estrellas */
/* .star-rating-field__stars:hover .star-rating-field__icon {
    opacity: 0.5;
} */

/* Al hacer hover sobre una estrella, activar esa y las anteriores (a la izquierda) */
/* .star-rating-field__stars .star-rating-field__icon:hover,
.star-rating-field__stars .star-rating-field__icon:hover ~ .star-rating-field__icon {
    opacity: 1;
} */

/* ==========================================================================
   Estados de Error y Focus
   ========================================================================== */

.star-rating-field--has-error .star-rating-field__icon--empty {
    color: #dc3545;
}

.star-rating-field--has-error .star-rating-field__icon--empty svg {
    fill: #dc3545;
}

.star-rating-field:focus-within {
    outline: 2px solid var(--rating-color-full, #ffd64f);
    outline-offset: 4px;
    border-radius: 4px;
}

/* ==========================================================================
   Animaciones
   ========================================================================== */

@keyframes starRatingPulse {
    0%, 100% {
        transform: scale(1);
    }
    50% {
        transform: scale(1.2);
    }
}

.star-rating-field__icon--selected {
    animation: starRatingPulse 0.3s ease;
    /* Solo animar una vez */
    animation-iteration-count: 1;
}

/* ==========================================================================
   Accesibilidad
   ========================================================================== */

.star-rating-field__stars:focus {
    outline: 2px solid var(--rating-color-full, #ffd64f);
    outline-offset: 2px;
}

/* Screen reader only */
.star-rating-field__sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}
