.main-div
{
    padding: 1.5rem;
    padding-top: 8rem;
}

.product-type-title
{
    margin-top: 8%;
    margin-bottom: 3%;
    font-weight: 700;
    font-size: 12px;
    line-height: 16px;
    letter-spacing: 0.8px;
    color: #404040;
}

.type-title-mobile
{
    display: block;
}

.type-title-desktop
{
    display: none;
}

.product-name
{
    font-weight: 500;
    font-size: 28px;
    line-height: 32px;
    color: #154193;
}

.name-mobile
{
    display: block;
}

.name-desktop
{
    display: none;
}

.main-image-container
{
    display: flex;
    justify-content: center;
    border-radius: 8px;
    background-color: #fff;
}

.main-img
{
    margin-top: 3%;
    margin-bottom: 3%;
    width: 100%;
}

.not-found
{
    background-color: transparent;
}

.images
{
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-start;
}

.img-div
{
    flex-basis: 27%;
    margin: 0.5rem;
    display: flex;
    justify-content: center;
    align-items: center;
    border-radius: 8px;
    background-color: #fff;
}

.img-icon
{
    width: 100%;
}

.selected-main-img
{
    border: 2px solid #154193;
}

.product-colors
{
    display: flex;
    justify-content: space-between;
}

.color-type-div
{
    width: 93px;
    height: 93px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    border-radius: 8px 8px 0 0;
}

.selected
{
    background-color: rgba(237, 175, 0, 0.16);
    border-bottom: 2px solid #154193;
}

.not-selected
{
    background-color: rgba(237, 175, 0, 0.04);
}

.without-color
{
    width: 17px;
    height: 17px;
}

.color-type-text
{
    margin-top: 5%;
    font-weight: 600;
    font-size: 16px;
    line-height: 20px;
    letter-spacing: 0.4px;
    color: #154193;
}

.items-to-cart
{
    display: flex;
    justify-content: start;
    align-items: center;
    margin-top: 10%;
    margin-bottom: 10%;
}

.add-or-remove
{
    display: flex;
    justify-content: center;
    align-items: center;
    min-width: 48px;
    min-height: 32px;
    border: 2px solid rgba(21, 65, 147, 0.25);
}

.add-remove-text
{
    font-family: 'Work Sans';
    font-weight: 500;
    font-size: 14px;
    line-height: 16px;
    letter-spacing: 0.6px;
    color: rgba(21, 65, 147, 0.25);
}

#remove-from-cart
{
    border-radius: 8px 0 0 8px;
}

#add-to-cart
{
    border-radius: 0 8px 8px 0;
}

.items-to-cart-input
{
    width: 54px;
    height: 32px;
    font-weight: 500;
    font-size: 12px;
    line-height: 16px;
    letter-spacing: 0.6px;
    text-align: center;
    color: #154193;
    border: 2px solid #154193;
}

.price
{
    margin-top: 2rem;
    margin-bottom: 3%;
    font-weight: 600;
    font-size: 32px;
    line-height: 20px;
    letter-spacing: 0.4px;
    color: #000;
}

.anchor
{
    font-weight: 600;
    font-size: 14px;
    line-height: 24px;
    letter-spacing: 0.2px;
}

.add-to-cart
{
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
}

.button
{
    max-width: 312px;
    width: 312px;
    margin-top: 10%;
}

.basic-info
{
    margin-top: 12%;
    display: flex;
    justify-content: center;
}

.basic-info-desktop
{
    display: none;
}

.info-div
{
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    align-items: center;
}

.info-left
{
    width: 88px;
    border-right: 1px solid rgba(21, 65, 147, 0.25);
}

.info-middle
{
    width: 126px;
    margin-left: 0.5rem;
    margin-right: 0.5rem;
}

.info-right
{
    width: 96px;
    border-left: 1px solid rgba(21, 65, 147, 0.25);
}

.info-img
{
    min-height: 26px;
    margin-bottom: 10%;
}

.info-title
{
    font-weight: 500;
    font-size: 24px;
    line-height: 28px;
    letter-spacing: 0.4px;
    color: #404040;
}

.info-text
{
    min-height: 48px;
    font-weight: 500;
    font-size: 14px;
    line-height: 16px;
    text-align: center;
    color: #404040;
}

.vertical-line
{
    height: 100%;
    border-left: 1px solid rgba(21, 65, 147, 0.25);
}

.about
{
    padding: 8%;
}

.about-img-container
{
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
}

.about-img
{
    /* padding: 2rem; */
    position: absolute;
    /* top: 12%; */
    left: -33.7%;
    transform: rotate(-1.4deg);
    clip-path: inset(24% 0 23% 40% round 8px);
}

.desktop-plane
{
    display: none;
}

.about-title
{
    font-weight: 500;
    font-size: 28px;
    line-height: 32px;
    color: #154193;
}

.description-mobile
{
    display: block;
}

.description-desktop
{
    display: none;
}

.about-description
{
    font-weight: 500;
    font-size: 16px;
    line-height: 24px;
    text-align: justify;
    color: #404040;
}

.specs
{
    overflow: hidden;
    padding: 8%;
    display: flex;
    flex-direction: column;
    align-items: center;
}

.specs-title-div
{
    margin-bottom: 15%;
    display: flex;
    justify-content: center;
    align-items: center;
}

.specs-title
{
    font-weight: 500;
    font-size: 28px;
    line-height: 32px;
    color: #154193;
}

.specs-description
{
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}

.specs-container
{
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}

.specs-icon
{
    width: 52px;
    height: 52px;
    margin-bottom: 1rem;
    display: flex;
    justify-content: center;
    align-items: center;
    border-radius: 50%;
}

.specs-text
{
    margin-bottom: 1rem;
    font-weight: 700;
    font-size: 20px;
    line-height: 24px;
    letter-spacing: 0.2px;
    text-align: center;
    color: #404040;
}

.specs-img-container
{
    display: none;
}

.orange-icons
{
    display: none;
}

.product-opinion
{
    padding: 8%;
    display: flex;
    position: relative;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}

.opinion-title
{
    font-family: 'Don José';
    font-size: 29px;
    line-height: 36px;
    text-align: center;
    color: #154193;
}

.reviews-link
{
    margin: 2rem 0;
    padding: 0.5rem 1rem;
    border: 2px solid #154193;
    border-radius: 8px;
    color: #154193;
    text-align: center;
}

.reviews-link:hover, .reviews-link:checked
{
    padding: 0.5rem 1rem;
    background-color: #fff;
    border: 2px solid #154193;
    border-radius: 8px;
    color: #154193;
}

.link-mobile
{
    display: block;
}

.link-desktop
{
    display: none;
}

.opinion-mobile
{
    display: block;
}

.opinion-desktop
{
    display: none;
}

.bubble-fish {
    position: absolute;
    width: 3rem;
    left: 0;
    top: 6rem;
    z-index: 100;
}

@media(min-width: 768px)
{
    .product-type-title
    {
        font-size: 14px;
    }

    .product-name
    {
        font-size: 40px;
        line-height: 48px;
    }

    .color-type-div
    {
        width: 230px;
    }

    .without-color
    {
        width: 20px;
        height: 20px;
    }

    .with-color
    {
        width: 98px;
        height: 20px;
    }

    .color-type-text
    {
        font-size: 20px;
    }

    .items-to-cart
    {
        margin-top: 5%;
        margin-bottom: 5%;
    }

    .add-or-remove
    {
        width: 72px;
        height: 48px;
    }

    .add-remove-text
    {
        font-size: 16px;
    }

    .items-to-cart-input
    {
        width: 81px;
        height: 48px;
    }

    .price
    {
        font-size: 42px;
    }

    .anchor
    {
        font-size: 20px;
    }

    .button
    {
        max-width: 100%;
        width: 100%;
        margin-top: 5%;
    }

    .img-div
    {
        flex-basis: 25%;
    }

    .basic-info
    {
        width: 100%;
    }

    .info-div
    {
        width: 100%;
    }

    .info-img
    {
        margin-bottom: 5%;
    }

    .info-title
    {
        font-size: 25px;
        line-height: 35px;
    }

    .info-text
    {
        font-size: 18px;
        line-height: 20px;
    }

    .product-colors
    {
        margin-top: 2rem;
        justify-content: flex-start;
    }

    .about
    {
        padding-left: 20%;
        padding-right: 20%;
        display: flex;
        flex-direction: column;
        justify-content: center;
        align-items: center;
    }

    .about-title
    {
        font-size: 40px;
        line-height: 48px;
    }

    .about-description
    {
        font-size: 18px;
    }

    .about-img
    {
        /* padding: 3rem; */
    }

    .specs-title-div
    {
        margin-bottom: 5%;
    }

    .specs-title
    {
        font-size: 40px;
        line-height: 48px;
    }

    .shine
    {
        width: 21px;
        height: 24px;
    }

    .product-opinion
    {
        padding: 4% 8%;
    }

    .opinion-title
    {
        margin: 2rem 0;
        font-size: 36px;
    }

    .reviews-link
    {
        padding: 0.5rem 1.5rem;
        font-weight: 700;
        font-size: 20px;
        line-height: 27px;
        letter-spacing: 0em;
    }

    .bubble-fish {
        left: 2rem;
        top: 8rem;
    }
}

@media (min-width: 1025px)
{
    .product-type-title
    {
        margin-top: 1rem;
    }

    .type-title-mobile
    {
        display: none;
    }

    .type-title-desktop
    {
        display: block;
    }

    .name-mobile
    {
        display: none;
    }

    .name-desktop
    {
        display: block;
    }

    .images-color
    {
        display: flex;
        flex-wrap: wrap;
        justify-content: space-between;
        align-items: flex-start;
    }

    .main-img-images
    {
        min-height: 350px;
        display: flex;
        flex-wrap: wrap;
        flex-direction: row-reverse;
        justify-content: flex-end;
        align-items: flex-start;
    }

    .main-img-info-div
    {
        width: 480px;
    }

    .main-image-container
    {
        width: 480px;
        height: 480px;
        display: flex;
        flex-direction: column;
    }

    .main-img
    {
        margin: 0;
    }

    .images
    {
        margin-right: 0.5rem;
        height: 480px;
        flex-basis: auto;
        flex-direction: column;
        align-items: center;
    }

    .img-div
    {
        width: 72px;
        max-height: 72px;
        flex-basis: 20%;
        margin: 0.25rem;
        padding: 0;
    }

    .img-icon
    {
        width: 100%;
    }

    .colors-details
    {
        flex-basis: 40%;
        margin-top: 5rem;
    }

    .color-type-text
    {
        font-size: 16px;
    }

    .price
    {
        font-size: 32px;
    }

    .anchor
    {
        font-size: 16px;
    }

    .add-to-cart
    {
        justify-content: flex-start;
    }

    .add-to-cart-link
    {
        width: 350px;
    }

    .color-type-div
    {
        width: 94px;
        height: 75px;
    }

    .type-div-right
    {
        margin-left: 2rem;
    }

    .without-color
    {
        width: 14px;
        height: 14px;
    }

    .with-color
    {
        width: 74px;
        height: 14px;
    }

    .basic-info
    {
        display: none;
    }

    .basic-info-desktop
    {
        display: flex !important;
        margin-top: 2rem;
    }

    .info-div
    {
        justify-content: flex-start;
    }

    .info-img
    {
        margin-bottom: 0;
    }

    .info-title
    {
        font-size: 18px;
        line-height: 24px;
    }

    .info-text
    {
        font-size: 14px;
        line-height: 14px;
    }

    .about
    {
        flex-direction: row;
        flex-wrap: wrap;
        justify-content: space-around;
        align-items: flex-start;
        padding: 2rem;
        padding-left: 3rem;
        padding-right: 3rem;
    }

    .about-img
    {
        /* padding: 4rem; */
    }

    .desktop-plane
    {
        height: 100%;
        display: block;
        position: absolute;
        z-index: 1;
        right: -1rem;
        bottom: -6rem;
    }

    .description-mobile
    {
        display: none;
    }

    .description-desktop
    {
        display: block;
    }

    .about-description
    {
        margin-top: 1rem;
    }

    .specs
    {
        position: relative;
        padding: 2rem;
        padding-left: 15rem;
        padding-right: 15rem;
        padding-bottom: 0;
    }

    .specs-description
    {
        width: 100%;
        max-width: 588px;
        flex-direction: row;
        flex-wrap: wrap;
        justify-content: space-around;
        align-items: flex-start;
    }

    .specs-container
    {
        flex-basis: 33%;
    }

    .specs-img-container
    {
        display: block;
        width: 100%;
        max-width: 588px;
    }

    .orange-icons
    {
        display: block;
        position: absolute;
    }

    .right-cloud
    {
        top: 15rem;
        right: -1rem;
    }

    .left-cloud
    {
        left: -1rem;
        bottom: 5rem;
    }

    .plane
    {
        top: 7rem;
        left: 8rem;
    }

    .product-opinion
    {
        padding: 8% 4%;
        flex-direction: row;
    }

    .title-reviews-div
    {
        display: flex;
        flex-direction: column;
        justify-content: space-between;
    }

    .opinion-title
    {
        width: 70%;
        text-align: start;
    }

    .reviews-link
    {
        font-size: 18px;
        line-height: 24px;
        width: 50%;
        margin: 0;
        padding: 0.75rem;
    }

    .link-mobile
    {
        display: none;
    }

    .link-desktop
    {
        display: block;
    }

    .opinion-mobile
    {
        display: none;
    }

    .opinion-desktop
    {
        display: block;
    }

    .bubble-fish {
        width: 4rem;
        left: 40%;
        top: 18rem;
    }
}

@media (min-width: 1280px)
{
    .main-image-container
    {
        width: 600px;
        height: 600px;
    }

    .main-img-info-div
    {
        width: 600px;
    }

    .colors-details
    {
        margin-top: 7rem;
    }

    .add-to-cart
    {
        width: 90%;
    }

    .product-opinion
    {
        padding: 8%;
    }

    .opinion-title
    {
        width: 80%;
        font-size: 48px;
        line-height: 56px;
    }

    .reviews-link
    {
        width: 40%;
    }

    .bubble-fish
    {
        left: 38%;
        top: 22rem;
    }
}

@media (min-width: 1500px)
{
    .product-name
    {
        font-size: 44px;
    }

    .images-color
    {
        justify-content: space-around;
    }

    .main-img-images
    {
        flex-basis: auto;
        width: auto;
    }

    .img-div
    {
        width: 88px;
        max-height: 88px;
    }

    .add-to-cart
    {
        width: 100%;
    }

    .about-title-description
    {
        margin-top: 2rem;
    }

    .about-title
    {
        font-size: 44px;
    }

    .specs
    {
        padding-top: 4rem;
    }

    .shine
    {
        width: 2rem;
        height: 2rem;
    }

    .specs-title
    {
        font-size: 44px;
    }

    .product-opinion
    {
        padding: 4%;
    }

    .opinion-title
    {
        width: 70%;
        font-size: 56px;
        line-height: 64px;
    }

    .reviews-link
    {
        width: 35%;
        font-size: 24px;
        line-height: 32px;
    }

    .bubble-fish
    {
        left: 40%;
        top: 18rem;
    }

    .plane
    {
        left: 15rem;
    }

    .right-cloud
    {
        right: 10rem;
    }

    .left-cloud
    {
        left: 5rem;
    }
}
