.rossa-summary-booking{
    display: flex;
    flex-direction: column;
    max-width: 1200px;
    width: 100%;
    height: 100%;
    padding: 1em;
    gap: 1em;
}

@media (min-width: 300px){
    .rossa-summary-booking{
        flex-direction: row;
        justify-content: space-between;
        align-items: center;
    }
}


.rossa-summary-booking__info{
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
}

@media (min-width: 300px){
    .rossa-summary-booking__info{
        flex-direction: column;
        justify-content: flex-start;
        align-items: flex-start;
    }
}


.rossa-summary-booking__info__title{
    all: unset;
    display: block;
    font-size: .875em;
    font-weight: 400;
    color: var(--rossa-color-default);
    margin: 0;
    padding: 0;
    line-height: normal;
}

.rossa-summary-booking__info__price{
    all: unset;
    display: block;
    font-size: 1.5em;
    font-weight: bolder;
    color: var(--rossa-color-black);
    margin: 0;
    padding: 0;
    line-height: normal;
}

.rossa-summary-booking__buttons{
    display: flex;
    justify-content: center;
    gap: .5em;
}

/* Estado bloqueado del botón */
[data-rossa-pay-summary-booking].rossa-pay-blocked{
    opacity: .5;
    pointer-events: none;
    cursor: not-allowed;
}

/* Estado bloqueado de los botones de eliminar/limpiar mientras hay
 * una navegación al checkout en curso. */
[data-rossa-clear-summary-booking].rossa-remove-blocked,
.rossa-booking-item__clear.rossa-remove-blocked,
.rossa-accommodation__remove.rossa-remove-blocked{
    opacity: .5;
    pointer-events: none;
    cursor: not-allowed;
}

/* Separamos el último botón (Continuar, acción primaria) */
.rossa-summary-booking__buttons > .rossa-button:last-child{
    margin-left: 1em;
}
@media (min-width: 520px){
    .rossa-summary-booking__buttons > .rossa-button:last-child{
        margin-left: 1.5em;
    }
}

.rossa-summary-booking__buttons .rossa-button{
    min-width: 0;
    width: fit-content;
}

.rossa-summary-booking__buttons .rossa-button span{
    display: none;
}

/* Excepción: el botón Continuar (primario)*/
.rossa-summary-booking__buttons .rossa-button.rossa-button-pay span{
    display: block;
}
.rossa-summary-booking__buttons .rossa-button.rossa-button-pay{
    min-width: 100px;
    width: auto;
}

@media (min-width: 520px) {
    .rossa-summary-booking__buttons .rossa-button{
        min-width: 100px;
        width: auto;
    }

    .rossa-summary-booking__buttons .rossa-button span{
        display: block;
    }
}

.rossa-summary-booking__content{
    display: flex;
    flex-direction: column;
    gap: 1em;
}

/* ITEM */

.rossa-booking-item{
    display: flex;
    flex-direction: column;
    gap: 1em;
    padding: 1em;
    border: 1px solid var(--rossa-color-gray);
    border-radius: .5em;
}

.rossa-booking-item__header{
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
    gap: 1em;
}

.rossa-booking-item__title{
    all: unset;
    display: block;
    font-size: 1.25em;
    font-weight: 600;
    color: var(--rossa-color-black);
    margin: 0;
    padding: 0;
    line-height: normal;
}

.rossa-booking-item__clear{
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    cursor: pointer;
    color: var(--rossa-config-color-primary);
}

@media (hover: hover){
    .rossa-booking-item__clear:hover{
        background-color: var(--rossa-color-bg-gray);
    }
}

.rossa-booking-item__clear svg{
    width: 22px;
    height: 22px;
    color: var(--rossa-config-color-primary);
}

/* Estado "eliminando": item atenuado y deshabilitado */
.rossa-booking-item.rossa-booking-item--removing{
    opacity: .6;
    pointer-events: none;
    transition: opacity .15s ease;
}
/* Oculta el icono de papelera y muestra un spinner girando centrado
 * en el botón mientras la eliminación está en marcha. */
.rossa-booking-item__clear.is-loading svg{
    visibility: hidden;
}
.rossa-booking-item__clear.is-loading::after{
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    width: 18px;
    height: 18px;
    margin-top: -9px;
    margin-left: -9px;
    border-radius: 50%;
    border: 2px solid transparent;
    border-top-color: var(--rossa-config-color-primary);
    border-right-color: var(--rossa-config-color-primary);
    animation: rossa-spinner-loading .7s linear infinite;
}

.rossa-booking-item__body{
    display: flex;
    flex-direction: column;
    gap: 1em;
}

.rossa-booking-item__box{
    display: flex;
    flex-direction: column;
}

.rossa-booking-item__box__title{
    all: unset;
    display: block;
    font-size: .875em;
    font-weight: 400;
    color: var(--rossa-color-default-text);
    margin: 0;
    padding: 0;
    line-height: normal;
}

.rossa-booking-item__box__value{
    all: unset;
    display: block;
    font-size: 1em;
    font-weight: 500;
    color: var(--rossa-color-black);
    margin: 0;
    padding: 0;
    line-height: normal;
}

.rossa-booking-item__footer{
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
    gap: 1em;
    padding-top: 1em;
    border-top: 1px solid var(--rossa-color-gray);
}

.rossa-booking-item__title-price{
    display: block;
    font-size: 1em;
    font-weight: 400;
    color: var(--rossa-color-default-text);
    margin: 0;
    padding: 0;
    line-height: normal;
}

.rossa-booking-item__price{
    all: unset;
    display: block;
    font-size: 1.25em;
    font-weight: 600;
    color: var(--rossa-color-black);
    margin: 0;
    padding: 0;
    line-height: normal;
}

/* Nombre de la tarifa (board) bajo el título del alojamiento en el resumen. */
.rossa-booking-item__subtitle{
    all: unset;
    display: block;
    font-size: .9em;
    font-weight: 400;
    color: var(--rossa-color-default-text);
    margin: .25em 0 0 0;
    line-height: normal;
}
/* Header con grid `1fr auto`*/
.rossa-booking-item__header{
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 1em;
    align-items: start;
}
.rossa-booking-item__header .rossa-booking-item__title{
    min-width: 0;
    word-break: break-word;
}
.rossa-booking-item__header .rossa-booking-item__clear{
    align-self: start;
}

/* Separación entre items consecutivos del resumen (alojamientos, boxes
 * de servicios extras, fianzas, descuentos, total). */
.rossa-summary-booking__content > .rossa-booking-item + .rossa-booking-item,
.rossa-summary-booking__content > .rossa-booking-item + .rossa-price-option-box,
.rossa-summary-booking__content > .rossa-price-option-box + .rossa-booking-item,
.rossa-summary-booking__content > .rossa-price-option-box + .rossa-price-option-box{
    margin-top: 1em;
}

/* Fila/total final del resumen. */
.rossa-booking-item.rossa-booking-item--grand-total{
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
    background-color: var(--rossa-color-bg-gray);
    border: 0;
}
.rossa-booking-item.rossa-booking-item--grand-total .rossa-booking-item__title-price{
    font-weight: 600;
    color: var(--rossa-color-black);
}
.rossa-booking-item.rossa-booking-item--grand-total .rossa-booking-item__price{
    font-size: 1.5em;
    color: var(--rossa-color-primary);
}

/* Mensaje cuando el carrito está vacío. */
.rossa-booking-item.rossa-booking-item--empty{
    color: var(--rossa-color-default-text);
    text-align: center;
    border-style: dashed;
}

/* Pie del modal Resumen */
.rossa-summary-booking__modal-footer{
    display: flex;
    flex-direction: column;
    gap: .75em;
    margin-top: 1em;
}

.rossa-summary-booking__grand-total{
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
    gap: 1em;
    padding: 1em 1.25em;
    border-radius: .5em;
    background-color: var(--rossa-color-bg-gray);
    border: 1px solid var(--rossa-color-gray);
}

/* Botones Limpiar (izquierda) / Pagar (derecha) dentro del modal Resumen.
 * En pantallas estrechas se apilan para que ambos botones queden cómodos. */
.rossa-summary-booking__modal-actions{
    display: flex;
    flex-direction: row;
    gap: .75em;
    align-items: stretch;
}
.rossa-summary-booking__modal-actions > .rossa-button{
    flex: 1 1 0;
    min-width: 0;
}
@media (max-width: 419px){
    .rossa-summary-booking__modal-actions{
        flex-direction: column;
    }
}
.rossa-summary-booking__grand-total__label{
    font-size: 1em;
    font-weight: 600;
    color: var(--rossa-color-black);
}
.rossa-summary-booking__grand-total__price{
    font-size: 1.5em;
    font-weight: 700;
    /* Color primario configurable por el cliente (Apariencia → Color
     * primario). Lo expone GetDynamicStyles a partir de AppearanceOption. */
    color: var(--rossa-config-color-primary);
    font-variant-numeric: tabular-nums;
    white-space: nowrap;
}

/* BOX SUMMARY BOOKING */
.rossa-box-summary-list-booking{
    display: flex;
    flex-direction: column;
    width: 100%;
    border-radius: .5em;
    background-color: var(--rossa-color-white);
    border: 1px solid var(--rossa-color-gray);
}

.rossa-box-summary-list-booking__header{
    display: flex;
    flex-direction: column;
    padding: 1.5em;
    gap: 1em;
}

.rossa-box-summary-list-booking__title{
    all:unset;
    display: flex;
    align-items: center;
    font-size: 1.5em;
    font-weight: 600;
    color: var(--rossa-color-black);
    line-height: normal;
    padding: 0;
    margin: 0;
}

.rossa-box-summary-list-booking__title svg{
    width: 24px;
    height: 24px;
    color: inherit;
    margin-right: .5em;
}

.rossa-box-summary-list-booking--checkout .rossa-box-summary-list-booking__title{
    font-size: 1.25em;
    font-weight: bold;
}

.rossa-box-summary-list-booking__description{
    all:unset;
    display: block;
    font-size: .875em;
    font-weight: 400;
    color: var(--rossa-color-default-text);
    line-height: normal;
    padding: 0;
    margin: 0;
}

.rossa-box-summary-list-booking__body{
    all: unset;
    display: flex;
    flex-direction: column;
    width: 100%;
    padding: 0 1.5em 0 1.5em;
    overflow-y: auto;
    max-height: 400px;
    scrollbar-width: thin;
}


.rossa-box-summary-list-booking--checkout .rossa-box-summary-list-booking__body{
    padding: 0 1.5em 1.5em 1.5em;
}

.rossa-box-summary-list-booking__item{
    display: flex;
    flex-direction: column;
    width: 100%;
    padding-bottom: .5em;
    border-bottom: 1px solid var(--rossa-color-gray);
    margin-bottom: .5em;
    gap: .5em;
}

.rossa-box-summary-list-booking--checkout .rossa-box-summary-list-booking__item{
    padding-bottom: 1em;
}
.rossa-box-summary-list-booking--checkout .rossa-box-summary-list-booking__item:last-child{
    border-bottom: none;
    padding-bottom: 0;
}

.rossa-box-summary-list-booking__item__header{
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    width: 100%;
    gap: 1em;
}

.rossa-box-summary-list-booking__item__info{
    display: flex;
    flex-direction: column;
}

.rossa-box-summary-list-booking__item__name,
.rossa-box-summary-list-booking__item__price{
    font-size: 1em;
    font-weight: 500;
    color: var(--rossa-color-black);
}

.rossa-box-summary-list-booking__item__description{
    font-size: .875em;
    font-weight: 400;
    color: var(--rossa-color-default-text);
    line-height: normal;
}

.rossa-box-summary-list-booking__item__price{
    text-wrap: nowrap;
}

.rossa-box-summary-list-booking__item__list{
    all:unset;
    display: flex;
    flex-direction: column;
    width: 100%;
    gap: .5em;
    padding-left: 1.5em;
}

.rossa-box-summary-list-booking__subitem{
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    width: 100%;
}

.rossa-box-summary-list-booking__subitem__name{
    display: flex;
    flex-direction: row;
    width: 100%;
    gap: .5em;
    font-size: .875em;
    font-weight: 400;
    color: var(--rossa-color-default-text);
    line-height: normal;
    align-items: center;
}

.rossa-box-summary-list-booking__subitem__name svg{
    width: 12px;
    height: 12px;
    color: var(--rossa-color-default-text);
}

.rossa-box-summary-list-booking__subitem__price{
    font-size: .875em;
    font-weight: 400;
    color: var(--rossa-color-default-text);
    line-height: normal;
    text-wrap: nowrap;
}

/* Box Summary Prices */
.rossa-box-summary-list-booking__footer{
    padding: 0 1.5em 1.5em 1.5em;
}

.rossa-box-summary-list-booking--checkout .rossa-box-summary-list-booking__footer{
    border-top: 1px solid var(--rossa-color-gray);
    padding: 1.5em;
}

.rossa-box-summary-list-booking__summary-prices{
    all: unset;
    display: flex;
    flex-direction: column;
    width: 100%;
}

.rossa-box-summary-list-booking__summary-prices__row{
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    width: 100%;
    font-size: 1em;
    font-weight: 400;
    color: var(--rossa-color-default-text);
}


.rossa-box-summary-list-booking__summary-prices__row.rossa-box-summary-list-booking__summary-prices__row--total-paid {
    font-size: .875em;
    color: var(--rossa-color-green);
    margin-top: .5em;
}

.rossa-box-summary-list-booking__summary-prices__row.rossa-box-summary-list-booking__summary-prices__row--total-remaining {
    margin-top: .5em;
    border-top: 1px solid var(--rossa-color-gray);
    padding-top: .5em;
    font-size: 1.25em;
    font-weight: bold;
    color: var(--rossa-color-black);
}

.rossa-box-summary-list-booking--checkout .rossa-box-summary-list-booking__footer--simple .rossa-box-summary-list-booking__summary-prices__row--total-remaining{
    margin-top: 0;
    border-top: none;
    padding-top: 0;
}

.rossa-box-summary-list-booking__taxes-note{
    align-self: flex-end;
    margin-top: .25em;
    font-size: .75em;
    color: var(--rossa-color-default-text);
    opacity: 0.7;
}

/* Header Dates */
.rossa-box-summary-list-booking__dates{
    display: grid;
    grid-template-columns: 1fr;
}

@media (min-width: 300px){
    .rossa-box-summary-list-booking__dates{
        grid-template-columns: 1fr 1fr;
    }
}

.rossa-box-summary-list-booking__dates__item{
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}

.rossa-box-summary-list-booking__dates__item__label{
    font-weight: bold;
    color: var(--rossa-color-black);
}

/* Chipsets */
.rossa-box-summary-list-booking__chipsets{
    display: flex;
    justify-content: center;
    flex-direction: row;
    flex-wrap: wrap;
    gap: .5em;
}

.rossa-box-summary-list-booking__chipset{
    background-color: var(--rossa-color-bg-gray);
    padding: .5em 1em;
    border-radius: .5em;
    font-size: .875em;
    font-weight: 400;
    color: var(--rossa-color-default-text);
    line-height: normal;
}