* {
    padding: 0;
    margin: 0;
}

.producto p,
.producto h2 {
    margin: 0;
}

.producto {
    padding: 10rem 0 7rem 0;
    background: var(--bg-color-7);
    display: flex;
    justify-content: center;
}

.producto>div {
    width: 90%;
    max-width: 1000px;
}

/* 
####
BARRA DE PROGRESO PASO A PASO
####
*/
.producto .product-barraprogreso {
    display: flex;
    justify-content: end;
    margin-bottom: 2.5rem;
}

.producto .product-barraprogreso>div {
    width: 470px;
    height: 68px;
    background-color: var(--bg-color);
    border-radius: 10px;
    padding: 1.25rem;
}

.producto .product-barraprogreso .pasos {
    width: 17%;
    display: flex;
    text-align: start;
}

.producto .product-barraprogreso small {
    font-size: 10px;
    width: 53px;
}

.producto .product-barraprogreso .paso1 i {
    color: var(--bg-color-11);
}

.producto .product-barraprogreso .paso3 i,
.producto .product-barraprogreso .paso3 small {
    color: var(--txt-colo-5);
}

.producto .product-barraprogreso .pasos>div {
    margin-right: 8%;
}

.producto .product-barraprogreso .line1 {
    border: 1px solid var(--bg-color-10);
}

.producto .product-barraprogreso .line2 {
    border: 1px solid var(--txt-colo-5);
}

.producto .product-barraprogreso .line1,
.producto .product-barraprogreso .line2 {
    width: 15%;
}

.producto-content {
    display: flex;
    justify-content: space-around;
    align-items: start;
    box-shadow: 0px 0px 15px rgba(0, 0, 0, 0.05);
    padding: 8% 5%;
    border-radius: 15px;
    background: var(--bg-color-10);
    height: auto;
}

.producto-content .form-producto {
    width: 45%;
    display: flex;
    flex-direction: column;
}

.producto-content .form-producto .title-contacto {
    padding: 0 0 20px 0;
}

.producto-content .form-producto .title-direccion {
    padding: 30px 0 20px 0;
}

.producto-content .form-producto .title-contacto,
.producto-content .form-producto .title-direccion {
    width: 100%;
    font-size: 20px;
    line-height: 100%;
    letter-spacing: -3%;
    border-bottom: 1px solid var(--bg-color-border-1);
    font-weight: var(--txt-fw);
    color: var(--txt-color);
}

.producto-content .form-contacto>div {
    display: flex;
    justify-content: space-between;
    margin-top: 20px;
}

.producto-content .form-direccion>div {
    margin-top: 20px;
}

.producto-content .form-contacto,
.producto-content .form-direccion,
.producto-content .form-direccion>div {
    display: flex;
    flex-direction: column;
}

.producto-content .form-contacto .f-a {
    display: flex;
    flex-direction: column;
    width: 46%;
}

.producto-content .form-contacto .f-b {
    display: flex;
    flex-direction: column;
}

.producto-content .form-contacto label,
.producto-content .form-direccion label {
    font-size: 11px;
    line-height: 100%;
    letter-spacing: -3%;
    font-weight: var(--txt-fw);
    color: var(--txt-color);
}

.producto-content .form-contacto input,
.producto-content .form-direccion select,
.producto-content .form-direccion input {
    padding: 10px 15px;
    margin-top: 10px;
    border-radius: 5px;
    font-size: 11px;
    line-height: 100%;
    letter-spacing: -3%;
    font-weight: var(--txt-fw-2);
    color: var(--txt-color-cuerpo);
    background-color: var(--bg-color-4);
    outline: 0;
}

.producto-content .form-direccion select .option {
    background-color: #f44336 !important;
    color: white !important;
    border-radius: 4px;
    padding: 5px;
}

.div-option {
    background-color: #eeeeee !important;
    border: 1px solid #ccc;
    width: 300px !important;
}

.select2-results__option--highlighted {
    background-color: #2196f3 !important;
    color: white !important;
}

.select2-results__option--selected {
    background-color: #4caf50 !important;
    color: white !important;
}






.producto-content .dato-compra {
    width: 30%;
    height: 339px;
    border: 1px solid var(--bg-color-border-3);
    border-radius: 10px;
    padding: 1.2rem;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

.producto-content .dato-compra .txt1 {
    font-size: 11px;
    color: black;
}

.producto-content .dato-compra .cupon {
    width: 100%;
    height: 41px;
    display: flex;
    align-items: center;
    border-radius: 5px;
    border: 0.5px solid var(--bg-color);
    margin: 0 0 2% 0;
}

.producto-content .dato-compra .cupon input {
    width: 65%;
    height: 100%;
    padding: 4px 4px 4px 12px;
    ;
}

.producto-content .dato-compra .cupon .aplica-cupon {
    width: 35%;
    height: 33px;
    background-color: var(--bg-color);
    border-radius: 3px;
    color: var(--txt-color-1);
    margin: 1% 1% 1% 0;
    display: flex;
    justify-content: center;
    align-items: center;
    text-decoration: none;
}

.producto-content .dato-compra .cupon input,
.producto-content .dato-compra .cupon .aplica-cupon {
    font-size: 11px;
}

.producto-content .dato-compra .txt2 {
    font-size: 15px;
    font-weight: var(--txt-fw);
    line-height: 100%;
    letter-spacing: -3%;
    color: var(--txt-color);
    padding-top: 8%;
    border-top: 1px solid var(--bg-color-border-1);
}

.producto-content .dato-compra .compra-txt p {
    font-size: 12px;
    line-height: 17px;
    letter-spacing: 0%;
}

.producto-content .dato-compra .compra-txt .sub-total,
.producto-content .dato-compra .compra-txt .igv,
.producto-content .dato-compra .compra-txt .total-precio p {
    font-weight: var(--txt-fw-2);
    color: var(--txt-color-cuerpo);
    border-bottom: 1px solid var(--bg-color-border-1);
    padding: 5% 0;
}

.producto-content .dato-compra .next1 {
    font-size: 11px;
    width: 100%;
    height: 30px;
    border-radius: 5px;
    background-color: var(--bg-color-button);
    color: var(--txt-color-1);
    text-decoration: none;
    display: flex;
    align-items: center;
    justify-content: center;
}

/* 
####
DARK MODE
####
*/
.dark-mode .producto {
    background: var(--bg-dm-2);
}

.dark-mode .producto-content {
    background: var(--bg-dm-1);
}

.dark-mode .producto-content .form-producto .title-contacto,
.dark-mode .producto-content .form-producto .title-direccion,
.dark-mode .producto-content .form-contacto label,
.dark-mode .producto-content .form-direccion label,
.dark-mode .producto-content .dato-compra .txt1,
.dark-mode .producto-content .dato-compra .txt2,
.dark-mode .producto-content .dato-compra .compra-txt .total-precio p {
    color: var(--txt-color-1) !important;
}

.dark-mode .producto-content .form-contacto input,
.dark-mode .producto-content .form-direccion select,
.dark-mode .producto-content .form-direccion input {
    background-color: var(--bg-dm-2);
    color: var(--txt-color-1);
    border: 1px solid var(--bg-color-border-1);
}

.dark-mode .producto-content .dato-compra {
    border-color: var(--bg-dm-2);
}

.dark-mode .producto-content .dato-compra .cupon {
    border-color: var(--bg-color-1);
}

.dark-mode .producto-content .dato-compra .cupon input {
    background: var(--bg-dm-2);
    color: var(--txt-color-1);
    border: none;
}


/* 
####
RESPONSIBLE
####
*/

@media screen and (max-width: 768px) {
    .producto .product-barraprogreso>div {
        width: 100%;
    }

    .producto-content {
        flex-direction: column;
        align-items: center;
        width: 100%;
        height: auto;
        padding: 10% 0;
    }

    .producto-content .form-producto {
        width: 90%;
    }

    .producto-content .form-producto>h2 {
        padding: 0 5% 30px 5%;
    }

    .producto-content .form-producto-content {
        padding: 30px 5%;
        border-bottom: 1px solid var(--bg-color-border-1);
    }

    .producto-content .dato-compra {
        width: 90%;
        height: auto;
        margin-top: 30px;
    }

    .producto-content .dato-compra .cupon {
        margin: 3% 0 6% 0;
    }

}