/*--------------------------------------------------------------
WOOCOMMERCE for IXPAN
---------------------------------------------------------------- 

 * Index
 * Buttons
 * Notices
 * General form fields
 * Cart page
 * Checkout page
 * Order confirmation page
 * Loop 
 * Single product page
 * Subscription totals module

*/






/******************************************** 
 * BUTTONS
 *   
 */



/* Buttons RESET
 *
 * The styles for the buttons are copied from 
 * the main style.css file, from .btn
 * KEEP IT LIKE THAT
 */


body .ixn-wc-product .button,
body .wcs-switch-link,
.body .ixn-wc-product .button.btn-secondary {

    /* Required */

    cursor: pointer;
    -webkit-user-select: none;
    -moz-user-select: none;
    user-select: none;
    display: inline-block;
    vertical-align: middle;
    text-decoration: none;
    border: none;
    font: inherit;
    min-height: 40px;
    width: fit-content;
    width: -moz-fit-content;

}


/* Buttons PRIMARY
 *
 * The styles for the buttons are copied from 
 * the main style.css file, from .btn
 * KEEP IT LIKE THAT
 */

body .ixn-wc-product .button:not(.btn-secondary) {

    /* Theme */

    background: var(--ixn-color-primary) !important;
    color: var(--ixn-color-white);
    padding: var(--ixn-space-xxsm) var(--ixn-space-xsm);
    text-align: left;
    transition: var(--ixn-transtion-hover); 
    border-radius: var(--ixn-border-radius);
    font-family:  var(--ixn-type-primary);
    font-weight: light;
    font-size: var(--ixn-font-size-primary-body);
    letter-spacing: var(--ixn-letter-spacing-primary-body);
    line-height: 26pt;
}



/* Buttons SECONDARY
 *
 * The styles for the buttons are copied from 
 * the main style.css file, from .btn
 * KEEP IT LIKE THAT
 */

.body .ixn-wc-product .button.btn-secondary,
body .wcs-switch-link,
.woocommerce .ixn-wc-product a.button.btn-secondary {

    /* Theme */

    background: var(--ixn-color-primary--tint-10);
    color: var(--ixn-color-primary);
    padding: var(--ixn-space-xxsm) var(--ixn-space-xsm);
    text-align: left;
    transition: var(--ixn-transtion-hover); 
    border-radius: var(--ixn-border-radius);
    font-family:  var(--ixn-type-primary);
    font-weight: light;
    font-size: var(--ixn-font-size-primary-body);
    letter-spacing: var(--ixn-letter-spacing-primary-body);
    line-height: 26pt;

}



/* Buttons LINK
 *
 * Copied from style.css, .btn-link
 * KEEP IT LIKE THAT
 */

.woocommerce a.added_to_cart,
.woocommerce-message a.button {
    background:  none;
    border-radius: none;
    padding:  0;
    font-weight: normal;
    color: var(--ixn-color-primary);
    text-decoration: underline;
    border-bottom:  0;
    line-height: var(--ixn-line-height-body);

}





/******************************************** 
 * NOTICES
 *   
 */


/**
 * Woocommerce loop notices, hack em
 * The rest of notices are in template files
 */ 

.woocommerce-error, 
.woocommerce-info, 
.woocommerce-message {
    padding: var(--ixn-space-xxsm) var(--ixn-space-xsm);
    margin-bottom: var(--ixn-space-sm);
    position: relative;
    border: 1px solid transparent;
    border-top-color: transparent;
    border-right-color: transparent;
    border-bottom-color: transparent;
    border-left-color: transparent;

    /*
    background-color: transparent;
    color: var(--ixn-color-primary--tint-60);
    */
    word-wrap: break-word;
}

    .woocommerce-error {
        background-color: var(--ixn-color-red--tint-10);
        color: var(--ixn-color-red--tint-140);
        border-color: transparent;
    }

    .woocommerce-info {
        background-color: var(--ixn-color-blue--tint-10);
        color: var(--ixn-color-blue--tint-140);
        border-color: transparent;
    }

.woocommerce-error::before, 
.woocommerce-info::before, 
.woocommerce-message::before {
    content: "";
    display: none;
}


/* Password strength notice */
.woocommerce-password-strength.bad,
.woocommerce-password-strength.short {
    background-color: var(--ixn-color-red--tint-10);
    color: var(--ixn-color-red--tint-140);
    border-color: transparent;
}

.woocommerce-password-strength.good {
    background-color: var(--ixn-color-orange--tint-10);
    color: var(--ixn-color-orange--tint-140);
    border-color: transparent;
}

.woocommerce-password-strength.strong {
    border-color: transparent;
    background-color: var(--ixn-color-green--tint-10);
    color: var(--ixn-color-green--tint-140);
}

#add_payment_method .checkout .create-account small, 
.woocommerce-cart .checkout .create-account small, 
.woocommerce-checkout .checkout .create-account small,
.woocommerce-password-hint {

    /* Based on class: p--sm */
    font-size: var(--ixn-font-size-mini);
    letter-spacing: var(--ixn-letter-spacing-mini);
    line-height: var(--ixn-line-height-mini);
}





/******************************************** 
 * CART PAGE
 *   
 */


/*
 * Style "remove link (x)" in cart page
 */ 
.woocommerce .ixn-cart-remove, 
.ixn-cart-remove {
    
    /* Required */
    display: block;
    font-size: 1.5em;
    height: 1em;
    width: 1em;
    text-align: center;
    line-height: 1;
    text-decoration: none;
    font-weight: 700;
    border: 0;

    /* Theme */
    border-radius: var(--ixn-border-radius);
    color: var(--ixn-color-red);

}


/* .quantity field edit */
.quantity {
    display:  inline-block;
}




/*
 * Remove default styles for totals table
 * Need to keep cart_totals class for AJAX
 */

.woocommerce .cart-collaterals .cart_totals, 
.woocommerce-page .cart-collaterals .cart_totals {
    float:  none;
    width:  auto;
}




/******************************************** 
 * FORM FIELDS
 *   
 */

.woocommerce form .form-row .input-text,
.woocommerce form .form-row select {
    background-color: var(--ixn-color-white);
    border: var(--ixn-border-primary);
    margin: 0;
    padding: var(--ixn-space-xsm);
    font-family: var(--ixn-type-primary);
    color: var(--ixn-color-primary--tint-60); /*<-- Gray */
    font-size: var(--ixn-font-size-body);
    letter-spacing: var(--ixn-letter-spacing-body);
    line-height: var(--ixn-line-height-body);
    width: 100%;
    max-width: 100%;
    display: block;
    border-radius: var(--ixn-border-radius);
}


    /* Disabled form field */
    body .woocommerce form .form-row .input-text:disabled {
        background-color:  var(--ixn-color-primary--tint-10);
    }


/* 
 * Select2 dropdown 
 * Used in checkout fields
 */

.select2-dropdown {
    background-color: var(--ixn-color-white);
    border: var(--ixn-border-primary);
    border-radius: var(--ixn-border-radius);
}

.select2-close-mask{
    background-color: var(--ixn-color-white);
}

.select2-container--default .select2-selection--single{
    background-color: var(--ixn-color-white);
    border: var(--ixn-border-primary);
    border-radius: var(--ixn-border-radius);
}

.select2-container--default .select2-selection--single,
.wc-field-select .select2-container--default .select2-selection--single,
.select2-container--default .select2-search--dropdown .select2-search__field {

    border: var(--ixn-border-primary);
    border-radius: 0;
    height:  54px;
    padding: 0 var(--ixn-space-xsm);

}

    .select2-container--default .select2-search--dropdown .select2-search__field {
        font:  var(--ixn-font-body);
        height:  54px;

    }

    /* Has error */
    .select2-container--default.field-select2--valid-false .select2-selection--single {
        background-color: var(--ixn-color-red--tint-10);
        color: var(--ixn-color-red--tint-140);
        border: 1px solid  var(--ixn-color-red--tint-140);
    }


/* vertical align text */
.select2-container--default .select2-selection--single .select2-selection__rendered,
.wc-field-select .select2-container--default .select2-selection--single .select2-selection__rendered {
    line-height: 54px;
    color: var(--ixn-color-primary--tint-60);
    padding: 0;
}


/* Arrow */
.select2-container--default .select2-selection--single .select2-selection__arrow,
.wc-field-select .select2-container--default .select2-selection--single .select2-selection__arrow {
    top:  4px;
}


/* Selected state */
.select2-container--default .select2-results__option--highlighted[aria-selected],
.select2-container--default .select2-results__option--highlighted[data-selected],
.select2-container--default .select2-results__option[aria-selected=true],
.select2-container--default .select2-results__option[data-selected=true] {
    background-color: var(--ixn-color-secondary--tint-60);
    color: var(--ixn-color-primary);
}


.select2-container--default .select2-selection--single:focus{
    border: var(--ixn-border-primary);
}

/* Lighter text */
.select2-container--default .select2-selection--single .select2-selection__placeholder, 
.select2-container--default .select2-selection--multiple .select2-selection__placeholder,
.select2-container--default .select2-selection--multiple .select2-selection__choice__remove,
.select2-container--default .select2-results__option[aria-disabled=true] {
    color: var(--ixn-color-primary--tint-20);
}



/******************************************** 
 * CHECKOUT PAGE
 *   
 */




#add_payment_method #payment, 
.woocommerce-cart #payment, 
.woocommerce-checkout #payment,
.woocommerce-order-pay #payment {
    background: var(--ixn-color-primary--tint-10);
    border-radius: var(--ixn-border-radius);
}

/* Required  */

.woocommerce form .form-row .required,
.woocommerce form .form-row.woocommerce-invalid label {
    color:  var(--ixn-color-red--tint-140);
}


/* Invalid field */

.woocommerce form .form-row.woocommerce-invalid .select2-container, 
.woocommerce form .form-row.woocommerce-invalid input.input-text, 
.woocommerce form .form-row.woocommerce-invalid select {
    border-color:  var(--ixn-color-red--tint-140);
    background-color: var(--ixn-color-red--tint-10);
}


/* Valid field  */

.woocommerce form .form-row.woocommerce-validated .select2-container, 
.woocommerce form .form-row.woocommerce-validated input.input-text, 
.woocommerce form .form-row.woocommerce-validated select {
    border-color: var(--ixn-color-green--tint-140);
}


/* Login form */

.woocommerce-form-login p:first-child {
    margin-top:  0;
}


/* Coupon form */

.woocommerce form.checkout_coupon, 
.woocommerce form.login, 
.woocommerce form.register {
    border: var(--ixn-border-primary);
    padding: var(--ixn-space-sm);
    margin: var(--ixn-space-sm) 0;
    text-align: left;
    border-radius: var(--ixn-border-radius);
}

/* Subscriber checkbox consent */
#ixn_newsletter_subscribed_field {
    margin-top: var(--ixn-space-sm) !important;
}

/* Payment box */

.woocommerce-checkout #payment div.payment_box,
#add_payment_method #payment div.payment_box {
    position: relative;
    box-sizing: border-box;
    width: 100%;
    padding: var(--ixn-space-sm);
    margin: var(--ixn-space-xsm) 0;
    font-size: var(--ixn-font-size-body);
    border-radius: var(--ixn-border-radius);
    line-height: var(--ixn-line-height-body);
    background-color: var(--ixn-color-white);
    color: var(--ixn-color-primary--tint-60);
}

    .woocommerce-checkout #payment div.payment_box::before,
    #add_payment_method #payment div.payment_box::before {
        border-bottom-color: var(--ixn-color-white);
    }


#payment {
    margin-bottom:  var(--ixn-space-sm);
}

#payment p {
    margin-top:  0;
}

/* payment button */
.woocommerce #payment #place_order, 
.woocommerce-page #payment #place_order { 
    text-align: center; 
    float: none;
}


/* Stripe */

#wc-stripe-cc-form .form-row {
    margin-bottom:  0 !important;
}

.wc-stripe-elements-field, .wc-stripe-iban-element-field {
    border: var(--ixn-border-primary);
    margin: var(--ixn-space-xxsm) 0;
    padding: var(--ixn-space-xxsm);
    background-color: #fff;
    outline: 0;
}

#stripe-payment-data fieldset {
    border:  0;
}

#add_payment_method #payment div.form-row, 
.woocommerce-cart #payment div.form-row, 
.woocommerce-checkout #payment div.form-row {
    padding:  var(--ixn-space-sm);
}

    #stripe-payment-data div.form-row {
        padding-top:  var(--ixn-space-xxsm) !important;
        padding-bottom:  var(--ixn-space-xxsm) !important;
    }


/* Update payment methods for all subscriptions */

.update-all-subscriptions-payment-method-wrap {
    padding:  1em;
    display:  block;
}




/******************************************** 
 * ORDER CONFIRMATION PAGE
 *   
 */

.ixn_wc_order_received {

}




/******************************************** 
 * LOOP PAGE
 *   
 */

/* Sale */
.woocommerce span.onsale {
    background-color: var(--ixn-color-blue--tint-10);
    color: var(--ixn-color-blue--tint-140);
    padding: .4em;
    top:  -.7em;
    left:  -.7em;
}


/* Add to cart */
.woocommerce a.ixn-btn-wc-loop {
    margin-top:  var(--ixn-space-xsm);
}

    /* Loading state */
    .woocommerce a.ixn-btn-wc-loop.button.loading {
        padding-right:  2.610em;
    }

    .woocommerce #respond input#submit.loading::after, 
    .woocommerce a.button.loading::after, 
    .woocommerce button.button.loading::after, 
    .woocommerce input.button.loading::after {
        top: .4em;
    }


/* Added to cart */
.woocommerce a.added_to_cart {
    position: relative;
    top: 8px;
    left: 12px;
}



/******************************************** 
 * SINGLE PRODUCT PAGE
 *   
 */


/* Product info */

/* price */

.ixn-wc-price {
}


/* Tabs */

/* title for descripton tab, when there is only tab and it is not pure HTML */
.ixn-wc-product--no-tabs > h2:nth-child(1) {
    margin-top: 0;
}

.woocommerce div.product .woocommerce-tabs ul.tabs::before {
    border-bottom:  var(--ixn-border-primary);
}

.woocommerce div.product .woocommerce-tabs ul.tabs li {
    border: var(--ixn-border-primary);
    background-color: var(--ixn-color-primary--tint-10);
    border-radius: var(--ixn-border-radius) var(--ixn-border-radius) 0 0 ;
}

    .woocommerce div.product .woocommerce-tabs ul.tabs li::before {
        border-bottom-right-radius:  var(--ixn-border-radius);
    }

    .woocommerce div.product .woocommerce-tabs ul.tabs li::after {
        border-bottom-left-radius:  var(--ixn-border-radius);
    }

    /* Tab link */
    .woocommerce div.product .woocommerce-tabs ul.tabs li a {
        border-bottom:  0;
        color: var(--ixn-color-primary);
        cursor: pointer;
        font-weight: normal;
    }

    .woocommerce div.product .woocommerce-tabs ul.tabs li a:hover {
        background-color:  inherit;
    }


/* Tab content */

.woocommerce div.product .woocommerce-tabs .panel {
    margin-top: var(--ixn-space-md);
}

.ixn-wc-product__gallery {
    /*margin-bottom: var(--ixn-space-sm);*/
    position: relative;
} 

    .woocommerce div.product div.images {
        margin-bottom: 0;
    }

/* Reviews tab */


/* Reviews tab title */ 
.woocommerce #reviews #comments .woocommerce-Reviews-title + .commentlist {
    margin-top: var(--ixn-space-md);
}
.woocommerce #reviews .comment-reply-title {
    margin-bottom: var(--ixn-space-sm);
}


/* Fix avatar image alignment */ 
.woocommerce #content div.product #reviews .comment img, 
.woocommerce div.product #reviews .comment img, 
.woocommerce-page #content div.product #reviews .comment img, 
.woocommerce-page div.product #reviews .comment img {
    float: none;
}

/* Fix comment list paddings */ 
.woocommerce #reviews #comments ol.commentlist {
    padding-left: 0;
}

/* Fix star rating block alignement */
.woocommerce .star-rating {
    float: none;
}

/* Fix stars size on comment form  */
.woocommerce .comment-form-rating {
    margin-bottom: var(--ixn-space-sm);
}

.comment-form-rating .stars {
    font-size: 0;
}

.woocommerce p.stars a {
    width: 1.7em;
    height: 1.7em;
    border-bottom: none;
    font-size: var(--ixn-font-size-body);
}

    .woocommerce p.stars a:hover {
        background: none !important;
    }

.woocommerce p.stars a::before {
    font-size: 21pt;
}

/* Pagination */

#reviews .comments__pagination {
    margin-top: var(--ixn-space-sm);
    margin-bottom: var(--ixn-space-md);
}

    #reviews .comments__pagination.comment__pagination-top {
        margin-top: var(--ixn-space-md);
    }
    

/* Change color of stars on hover
.woocommerce p.stars a:hover~a::before {
    content: "\e021"
}

.woocommerce p.stars:hover a::before {
    content: "\e020";
    color: var(--ixn-color-secondary);
}

.woocommerce p.stars.selected a.active::before {
    content: "\e020";
    color: var(--ixn-color-secondary);
}

.woocommerce p.stars.selected a.active~a::before {
    content: "\e021"
}

.woocommerce p.stars.selected a:not(.active)::before {
    content: "\e020";
    color: var(--ixn-color-secondary);
}
*/

/******************************************** 
 * SUBSCRIPTIONS TOTALS MODULE
 *   
 */

.order_details .wcs-switch-link {
    margin-top: var(--ixn-space-xxsm);
}


/* Fix long domains an email overlapping in cart and order confirmation */
.woocommerce-cart-form__contents td,
/* Fix spacing inside cart item meta, etc */
.woocommerce td.product-name .wc-item-meta .wc-item-meta-label, 
.woocommerce td.product-name .wc-item-meta dt, 
.woocommerce td.product-name dl.variation .wc-item-meta-label, 
.woocommerce td.product-name dl.variation dt {
    word-break: break-word;
}



/* 
*  Styles for small screen size exclusively
*  Does not cascade.
*/

@media only screen and (max-width: 700px) {

    /* Woocommerce: for sm screens */

    .product-thumbnail {
        max-width:  100px;
    }

    #add_payment_method .cart-collaterals .cart_totals tr td, 
    #add_payment_method .cart-collaterals .cart_totals tr th, 
    .woocommerce-cart .cart-collaterals .cart_totals tr td, 
    .woocommerce-cart .cart-collaterals .cart_totals tr th, 
    .woocommerce-checkout .cart-collaterals .cart_totals tr td, 
    .woocommerce-checkout .cart-collaterals .cart_totals tr th {
        border:  none;
    }

}


@media only screen and (max-width: 1025px) {

    /* SINGLE PRODUCT */

    /* Fix layout for medium size */

    /* Image area */
    .woocommerce #content div.product div.images, 
    .woocommerce div.product div.images, 
    .woocommerce-page #content div.product div.images, 
    .woocommerce-page div.product div.images {
        float:  none;
        width:  100%;
        max-width:  600px;
    }

    /* Short description area */
    .woocommerce #content div.product div.summary, 
    .woocommerce div.product div.summary, 
    .woocommerce-page #content div.product div.summary, 
    .woocommerce-page div.product div.summary {
        float:  none;
        width:  100%;
    }

}



/* 
*  Landscape tablets and small desktop
*/

@media only screen and (min-width: 1025px) {

    /* Product gallery */

    .ixn-wc-product__gallery {
        float:  left;
        width:  48%;
    } 

        .woocommerce #content div.product div.images, 
        .woocommerce div.product div.images, 
        .woocommerce-page #content div.product div.images, 
        .woocommerce-page div.product div.images {
            float: none;
            width: auto;
        }

    /* Tabs */
    .woocommerce div.product .woocommerce-tabs ul.tabs {
        text-align: center;
        max-width: 604px;
        margin-left: auto;
        margin-right: auto;
    }

    .woocommerce #content div.product 
    .woocommerce-tabs, 
    .woocommerce div.product .woocommerce-tabs, 
    .woocommerce-page #content div.product .woocommerce-tabs, 
    .woocommerce-page div.product .woocommerce-tabs {
        margin-top: 0;
    }


    /* Tab content */

    .woocommerce div.product .woocommerce-tabs .panel {
        width:  604px;
        margin-left:  auto;
        margin-right:  auto;
    }


    /******************************************** 
     * ORDER CONFIRMATION PAGE
     *   
     */

    .ixn_wc_order_received {
        text-align: center;
    }



}