
button {
    cursor: pointer;
}

.btn-color {
    cursor:  pointer;
}

.error {
    color: red;
}
.error-input {
    border: 1px solid red !important;
}
.required {
    color: red;
}

.text-uppercase {
    text-transform: uppercase;
}
.text-thin {
    font-weight: 300;
}

.mt-10 {
    margin-top: 10px;
}
.mt-20 {
    margin-top: 20px;
}
.mb-10 {
    margin-bottom: 10px;
}
.mb-20 {
    margin-bottom: 20px;
}


@media (min-width: 992px) {

    .menufixed {
        position: fixed;
        top: 0;
    }
}

@media (max-width: 1024px) {
    .banner .owl-controls .owl-pagination {
        bottom: 0 !important;
    }
}

.fotorama__video {
    top: 0;
}

.search-box .input-text {
    border-top-left-radius: 20px !important;
    border-bottom-left-radius: 20px !important;
    padding-left: 20px !important;
}

#previewModal {
    position:fixed;
    top:0;
    right:40px;
    padding:10px 20px;
    width:250px;
    background-color:red;
    color:white;
    border-radius: 0 0 10px 10px;
    z-index:999999;
    cursor: pointer;
    box-shadow: 2px 2px 4px #FAFAFA;
}
#previewModal:hover {
    background-color: #dc2b00;
}

.product-size .table tr th {
    text-align: center;
}

.main-attribute {
    cursor: pointer;
}
.main-attribute td {
    text-align: center;
}
.main-attribute td:nth-child(even) {
    background-color: #FAFAFA;
}

.search-section .main-attribute td:nth-child(even) {
    background-color: white;
}

.main-search {
    position: relative;
}

.dropdown-menu>li>a {
    display: block;
    padding: 10px 22px 10px 10px;
    clear: both;
    font-weight: 400;
    line-height: 1.42857143;
    color: #333;
    white-space: nowrap;
}
.dropdown-menu>li>a:hover {
    background-color: #EEEEEE;
}

.ais-search-box--reset {
    right: 55px !important;
}

.points-selector {
    padding: 5px 1px 5px 5px;
    width: 60px;
    border-radius: 4px;
    border: 1px solid #DDDDDD;
    text-align: center;
}
#pointsRangeButton {
    width: 35px;
    height: 35px;
    text-align: center;
    border-radius: 20px;
    background-color: #17B7AC;
    color: #222222;
    line-height: 35px;
    display: inline-block;
}
.clearFilterButton {
    color: #FFE585;
}

#hits {
    background-color: white;
    padding: 0;
    border: 1px solid #DDDDDD;
    position: absolute;
    width: 94%;
    top: 45px;
    left: 15px;
    z-index: 1000;
    max-height: 400px;
    overflow: auto;
}
#hits a {
    width: 100%;
}
#hits img {
    float: left;
    margin-right: 20px;
}
#hits .media {
    padding: 10px 20px;
    border-bottom: 1px solid #FAFAFA;
}
#hits .media:hover {
    background-color: #FAFAFA;
}
#hits .media .media-body {
    margin-left: 10px;
    float: left;
}
#hits .media .title {
    margin-top: 10px;
    color: #1f1f2f;
    font-size: 16px;
    font-weight: 400;
    font-family: Poppins, sans-serif;
}
#hits .media .root {
    font-size: 14px;
    font-weight: 200;
    font-family: Poppins, sans-serif;
}


.picture-tag {
    position: absolute;
    z-index: 1;
}

.picture-tag.pos_top_left {
    top: 0;
    left: 0;
}
.picture-tag.pos_top_center {
    top: 0;
    left: 0;
    right: 0;
    margin-left: auto;
    margin-right: auto;
}
.picture-tag.pos_top_right {
    top: 0;
    right: 0;
}
.picture-tag.pos_bottom_right {
    bottom: 0;
    right: 0;
}
.picture-tag.pos_bottom_center {
    left: 0;
    right: 0;
    margin-left: auto;
    margin-right: auto;
    bottom: 0;
}
.picture-tag.pos_bottom_left {
    bottom: 0;
    left: 0;
}
.picture-tag.pos_middle_left {
    top: 50%;
    left: 0;
}
.picture-tag.pos_middle_center {
    top: 50%;
    left: 0;
    right: 0;
    margin-left: auto;
    margin-right: auto;
}
.picture-tag.pos_middle_right {
    top: 50%;
    right: 0;
}

.product-item .favourite-button,
.product-item-details .favourite-button,
#data-favoritos .favourite-button {
    color: #17B7AC;
    font-size: 25px;
    position: absolute;
    top: 10px;
    right: 10px;
    z-index: 1;
    text-shadow: 1px 0 4px rgba(255, 255, 255, 0.6);
    cursor: pointer;
}
.product-item-details .favourite-button,
#data-favoritos .favourite-button {
    position: relative;
    top: 0;
    right: 0;
    margin-right: 10px;
}
.product-item .favourite-button:hover,
.product-item-details .favourite-button:hover,
#data-favoritos .favourite-button {
    color: #17B7AC;
    text-shadow: 1px 0 7px rgba(255, 255, 255, 0.6);
}

.search-section .product-item-details .root {
    font-weight: 200;
    color: #1F1F2F;
}

.search-section .product-item-details table {
    font-size: 12px;
}

.search-section  .product-item-details table th {
    text-align: center;
    font-weight: 600;
}

.search-section .product-item-details table .fa.fa-plane {
    font-size: 19px;
}

.search-section .carousel-control-prev-icon {
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23555' viewBox='0 0 8 8'%3E%3Cpath d='M5.25 0l-4 4 4 4 1.5-1.5-2.5-2.5 2.5-2.5-1.5-1.5z'/%3E%3C/svg%3E");
    opacity: 0;
}

.search-section .carousel-control-next-icon {
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23555' viewBox='0 0 8 8'%3E%3Cpath d='M2.75 0l-1.5 1.5 2.5 2.5-2.5 2.5 1.5 1.5 4-4-4-4z'/%3E%3C/svg%3E");
    opacity: 0;
}

.search-section .carousel:hover .carousel-control-prev-icon,
.search-section .carousel:hover .carousel-control-next-icon {
    opacity: 1;
}


.addCartContainer {
    width: 240px;
}

.product-size .table th {
    font-size: 12px;
}

#customizeButton {
    margin-top: 20px;
    border-radius: 4px;
    background-color: white;
    border: 1px solid #CCCCCC;
    color: #999;
    font-size: 13px;
    padding: 8px 41px;
    font-weight: 600;
}
#customizeButton:hover {
    background-color: #FAFAFA;
}

.repeat-order-button,
.update-address-button {
    border-radius: 4px;
    padding: 10px 5px;
    font-size: 12px;
}
.repeat-order-button i,
.update-address-button i {
    font-size: 12px !important;
}

.fa.fa-messenger {
    background: url('../../images/facebook-messenger.png');
    background-repeat: no-repeat;
    background-position: 0 1px;
    background-size: 100% 100%;
    width: 27px;
    height: 27px;
}
@media (max-width: 640px) {
    .fa.fa-messenger {
        background-position: 0 0;
        width: 16px;
        height: 16px;
    }
}

.whatsapp-button {
    position: fixed;
    bottom: 20px;
    right: 20px;
    background-color: #25d366;
    font-size: 36px;
    width: 60px;
    height: 60px;
    border-radius: 60px;
    padding: 12px;
    text-align: center;
    box-shadow: 0 2px 10px rgba(0,0,0,0.2)
}
.whatsapp-button i {
    color: white !important;
}
@media (max-width: 1000px) {
    .whatsapp-button {
        right: 25px;
    }
}

#data-reservas table th {
    padding: 15px 2px;
}

#data-reservas table th li {
    margin-right: 10px;
}

#data-reservas .view-order-detail-button {
    color: #17B7AC;
}

#data-reservas .detail {
    display: none;
    background-color: #fafafa;
}

#data-reservas .detail .btn-seconday {
    border: 1px solid #DDDDDD;
}

#data-facturas .cart-item-table .table tbody tr td {
    padding: 20px;
}

.address-item {
    padding:10px;
    background-color:#FAFAFA;
    border-bottom: 1px solid #FAFAFA;
    padding-bottom: 10px;
    margin-bottom: 15px;
}

.address-item.selected {
    border: 2px solid orange;
}


.contact-mobile {
    display: none !important;
}

#contact-numbers-container {
    right: 10px;
}
#contact-numbers-container b {
    font-size: 12px;
}
#contact-numbers-container .col-2 {
    line-height: 14px;
}

@media (max-width: 991px) {

    #contact-numbers-container {
        right: 110px;
    }
}

@media (max-width: 640px) {
    #contact-numbers-container {
        display: none;
    }
    .contact-mobile {
        display: block !important;
    }
}


.promoproduct-item {
    border: 1px solid #DDDDDD;
    padding: 20px;
    border-radius: 10px;
}
.promoproduct-item:hover {
    box-shadow: 2px 2px 5px #EEEEEE;
}
.promoproduct-item .promoproduct-detail {
    margin: 0;
    padding-top: 15px;
    border-top: 1px solid #DDDDDD;
}
.promoproduct-item .promoproduct-detail h5,
.promoproduct-item .promoproduct-detail p {
    margin: 0;
}
.promoproduct-item .carousel-inner {
    height: 252px;
}

#promoProductDetailModal .btn-nopoints {
    background-color: #EFEFEF;
    color: #DDDDDD;
    cursor: not-allowed;
}

.catalog-section .promoproduct-item .carousel-inner {
    height: 285px !important;
}


.steps-container {
    margin-top: 30px;
    padding: 30px 30px 30px 0;
    background-color: #FAFAFA;
    overflow: hidden;
}
.steps-nav {
    float: left;
    width: 180px;
}
.steps-nav .step {
    padding: 10px 20px;
    font-size: 20px;
    font-weight: normal;
    color: #777777;
}
.steps-nav .step.active {
    background-color: #17B7AC;
    color: #666666;
    font-weight: bold;
    display: block;
}
.step-content {
    padding: 0 20px 30px 40px;
    float: left;
}
@media (max-width:1000px) {
    .steps-nav {
        float: none;
        width: initial;
        margin-bottom: 20px;
    }
    .steps-nav .step {
        display: inline-block;
    }
    .steps-nav .step.active {
        display: inline-block;
    }
}


.cotization-selection {
    padding: 10px 20px;
    border-radius: 20px;
    text-align: left;
    color: white;
    background-color: #0275d8;
    margin-bottom:10px;
    cursor: pointer;
}
.cotization-selection:hover {
    background-color: #0259ba;
    box-shadow: 2px 2px 2px #CCCCCC;
}
.cotization-selection i {
    font-size: 24px;
}

.cotization-section .upload-placeholder {
    padding: 30px 15px;
    border: 1px solid #CCCCCC;
    border-radius: 5px;
    font-size: 14px;
}

.cotization-section .upload-placeholder i {
    font-size: 32px;
    margin-bottom: 10px;
}

.cotization-item-name {
    padding: 0 10px;
    height: 30px;
    border-color: #EEEEEE;
    font-size: 14px;
}

.product-minimum-container {
    float: left;
    display: block;
    max-width: 350px;
    background-color: #EEEEEE;
    text-align: left;
    padding: 10px;
    border-bottom-right-radius: 25px;
    border-top-right-radius: 25px;
    width: 100%;
}
.product-minimun-label {
    font-size: 12px;
    line-height: 20px;
    display: inline-block;
}

.kit-minimum-container {
    float: left;
    display: block;
    max-width: 200px;
    background-color: #EEEEEE;
    text-align: left;
    padding: 5px 10px 5px 10px;
    border-bottom-right-radius: 25px;
    border-top-right-radius: 25px;
}
.kit-minimun-label {
    font-size: 12px;
    line-height: 15px;
    display: inline-block;
}
@media (max-width: 1200px) {
    .kit-minimum-container {
        width: 100%;
        max-width: initial;
        margin-bottom: 10px;
    }
}

.packaging-slider {
    /*padding-top: 45px !important;*/
}
.packaging-slider .owl-prev,
.packaging-slider .owl-next {
    /*top: 25px !important;*/
}

tr.main-attribute .badge{
    font-size: 100%;
}