/* Shop-specific styles for WooCommerce pages */

/* Mentorpiece Brand Styling - Import Roboto Font */
@import url('https://fonts.googleapis.com/css2?family=Roboto:wght@300;400;500;600;700&display=swap');

/* Mentorpiece Brand Variables */
:root {
  --mp-orange: #FB6B00;
  --mp-primary-blue: #007bff;
  --mp-success-green: #28a745;
  --mp-danger-red: #dc3545;
  --mp-body-bg: #f8f9fa;
  --mp-card-bg: #ffffff;
  --mp-glass-bg: rgba(255, 255, 255, 0.25);
  --mp-primary-text: #212529;
  --mp-secondary-text: #6c757d;
  --mp-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
  --mp-shadow-hover: 0 4px 8px rgba(0, 0, 0, 0.15);
}

/* Global Brand Styling for WooCommerce pages */
.woocommerce body,
.woocommerce-page body {
  font-family: 'Roboto', sans-serif !important;
  background-color: var(--mp-body-bg) !important;
  color: var(--mp-primary-text) !important;
  line-height: 1.6 !important;
}

/* Cart Page Brand Styling */
.page-cart {
  background-color: var(--mp-body-bg);
  padding: 20px;
}

.page-cart h1 {
  font-size: 2.8rem !important;
  font-weight: 700 !important;
  color: var(--mp-primary-text) !important;
  border-bottom: 3px solid var(--mp-orange) !important;
  padding-bottom: 0.5rem !important;
  margin-bottom: 2rem !important;
  text-align: center !important;
}

/* Hide only "added to cart" notification message - specific targeting */
.woocommerce-message,
.woocommerce .woocommerce-message,
div.woocommerce-message {
  display: none !important;
}

/* Show login info blocks back */
.woocommerce-info {
  display: block !important;
}

/* Make data processing consent text match subscription text style */
.woocommerce-privacy-policy-text,
.woocommerce .woocommerce-privacy-policy-text {
  font-size: 13px !important;
  line-height: 1.4 !important;
  font-weight: normal !important;
  color: var(--mp-primary-text) !important;
  background-color: #f8f9fa !important;
  padding: 8px 12px !important;
  border-radius: 4px !important;
  margin: 8px 0 !important;
}

/* Keep subscription checkboxes at normal size */
.xoo-aff-required label,
.woocommerce .xoo-aff-required label,
.checkboxesBlock__body label {
  font-size: 13px !important;
  line-height: 1.4 !important;
  font-weight: normal !important;
  color: var(--mp-primary-text) !important;
}

/* Hide "Ваш заказ" heading - comprehensive approach for all heading levels */
.cart-collaterals h1,
.cart-collaterals h2,
.cart-collaterals h3,
.cart-collaterals h4,
.woocommerce-cart .cart-collaterals h1,
.woocommerce-cart .cart-collaterals h2,
.woocommerce-cart .cart-collaterals h3,
.cart_totals h1,
.cart_totals h2,
.cart_totals h3,
.woocommerce .cart_totals h1,
.woocommerce .cart_totals h2,
.woocommerce .cart_totals h3,
.woocommerce-cart-form + .cart-collaterals h1,
.woocommerce-cart-form + .cart-collaterals h2,
.woocommerce-cart-form + .cart-collaterals h3,
.cart-collaterals .cart_totals h1,
.cart-collaterals .cart_totals h2,
.cart-collaterals .cart_totals h3,
.cart_totals > h1,
.cart_totals > h2,
.cart_totals > h3,
.woocommerce .cart-collaterals h1,
.woocommerce .cart-collaterals h2,
.woocommerce .cart-collaterals h3,
.woocommerce-page .cart-collaterals h1,
.woocommerce-page .cart-collaterals h2,
.woocommerce-page .cart-collaterals h3,
.cart-subtotal h1,
.cart-subtotal h2,
.cart-subtotal h3,
body.woocommerce-cart .cart-collaterals h1,
body.woocommerce-cart .cart-collaterals h2,
body.woocommerce-cart .cart-collaterals h3 {
  display: none !important;
  visibility: hidden !important;
  height: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  text-indent: -9999px !important;
  font-size: 0 !important;
  line-height: 0 !important;
}

/* Cart page main container styling */
.woocommerce .entry-content {
  max-width: 800px !important;
  margin: 0 auto !important;
  padding: 0 20px !important;
}

/* Login notification boxes */
.woocommerce .woocommerce-info,
.woocommerce .wc-block-components-notice-banner {
  background-color: var(--mp-card-bg) !important;
  border: 1px solid #3498db !important;
  border-left: 4px solid #3498db !important;
  border-radius: 0.5rem !important;
  padding: 20px !important;
  margin-bottom: 20px !important;
  box-shadow: var(--mp-shadow) !important;
}

.woocommerce .woocommerce-info::before {
  display: none !important;
}

/* Info box text styling */
.woocommerce .woocommerce-info {
  color: var(--mp-primary-text) !important;
  font-family: 'Roboto', sans-serif !important;
  text-align: center !important;
}

/* Coupon notification box */
.woocommerce .wc-block-components-notice-banner {
  text-align: center !important;
  color: var(--mp-primary-text) !important;
  font-family: 'Roboto', sans-serif !important;
}

/* Product summary section */
.woocommerce .shop_table,
.woocommerce table.cart {
  background-color: var(--mp-card-bg) !important;
  border-radius: 0.5rem !important;
  box-shadow: var(--mp-shadow) !important;
  padding: 20px !important;
  margin: 20px 0 !important;
  border: none !important;
  width: 100% !important;
}

.woocommerce .shop_table thead {
  display: none !important;
}

.woocommerce .shop_table tr {
  border: none !important;
}

.woocommerce .shop_table td {
  border: none !important;
  padding: 30px 0 !important;
  vertical-align: middle !important;
  min-height: 45px !important;
}


.woocommerce .product-name {
  font-family: 'Roboto', sans-serif !important;
  font-weight: 500 !important;
  color: var(--mp-primary-text) !important;
}

.woocommerce .product-quantity,
.woocommerce .product-price,
.woocommerce .product-subtotal {
  text-align: right !important;
  font-family: 'Roboto', sans-serif !important;
  font-weight: 600 !important;
}

.woocommerce .cartBlock,
.woocommerce-page .cartBlock {
  background-color: var(--mp-card-bg) !important;
  border-radius: 0.5rem !important;
  box-shadow: var(--mp-shadow) !important;
  padding: 2rem !important;
  margin: 0 0 2rem 0 !important;
  transition: box-shadow 0.3s ease, transform 0.3s ease !important;
}

.woocommerce .cartBlock:hover,
.woocommerce-page .cartBlock:hover {
  box-shadow: var(--mp-shadow-hover) !important;
  transform: translateY(-1px) !important;
}

.woocommerce .cartBlock .container,
.woocommerce-page .cartBlock .container {
  max-width: 1000px !important;
  margin: 0 auto !important;
}

/* WooCommerce Cart Blocks Styling */
.wp-block-woocommerce-cart,
.is-large.wc-block-cart {
  background: transparent !important;
}

.wc-block-cart-items,
.wp-block-woocommerce-cart-order-summary-block {
  background-color: var(--mp-card-bg) !important;
  border-radius: 0.5rem !important;
  box-shadow: var(--mp-shadow) !important;
  padding: 1.5rem !important;
  margin-bottom: 1.5rem !important;
  border: 1px solid #e9ecef !important;
}

/* Button Styling for WooCommerce */
.woocommerce .nbtn,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce .cartBlock button[type="submit"],
.woocommerce .add_to_cart_button {
	background: var(--mp-orange) !important;
	border-radius: 0.375rem !important;
	font-weight: 500 !important;
	font-family: 'Roboto', sans-serif !important;
}

.woocommerce .nbtn:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce .cartBlock button[type="submit"]:hover,
.woocommerce .add_to_cart_button:hover {
	background: #e55d00 !important;
	transform: translateY(-1px) !important;
}

/* Form Styling for WooCommerce */
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce select {
    border: 1px solid #e9ecef !important;
    background: var(--mp-card-bg) !important;
    border-radius: 0.375rem !important;
    font-family: 'Roboto', sans-serif !important;
    font-size: 0.9rem !important;
    transition: border-color 0.3s ease, box-shadow 0.3s ease !important;
    padding: 12px 15px !important;
    width: 100% !important;
}

/* Dropdown options styling - target both native and JavaScript dropdowns */
.woocommerce select option,
select option,
.select2-container .select2-results,
.select2-container--default .select2-results__option,
.select2-dropdown .select2-results__option,
.select2-results__option {
    font-size: 0.85rem !important;
    padding: 8px !important;
}

/* Select2 dropdown styling */
.select2-container--default .select2-results__option {
    font-size: 0.85rem !important;
    line-height: 1.4 !important;
    padding: 8px 12px !important;
}

.select2-dropdown {
    font-size: 0.85rem !important;
}

.select2-results {
    font-size: 0.85rem !important;
}

.select2-results__option {
    font-size: 0.85rem !important;
    padding: 8px 12px !important;
}

/* Select2 selection (placeholder) text */
.select2-container--default .select2-selection--single .select2-selection__rendered,
.select2-selection__rendered {
    font-size: 0.85rem !important;
    line-height: 1.4 !important;
}

.select2-container--default .select2-selection--single {
    font-size: 0.85rem !important;
}

.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row textarea:focus,
.woocommerce select:focus {
    border-color: var(--mp-orange) !important;
    box-shadow: 0 0 0 0.2rem rgba(251, 107, 0, 0.25) !important;
    outline: none !important;
}

/* Payment methods styling */
.woocommerce ul.payment_methods {
    background: transparent !important;
    border: none !important;
    padding: 0 !important;
    margin: 20px 0 !important;
    margin-bottom: 0px !important;
}

.woocommerce ul.payment_methods li {
    background: var(--mp-card-bg) !important;
    border: 1px solid #e9ecef !important;
    border-radius: 0.375rem !important;
    margin-bottom: 10px !important;
    padding: 15px !important;
    box-shadow: var(--mp-shadow) !important;
}

.woocommerce ul.payment_methods li.wc_payment_method {
    list-style: none !important;
}

.woocommerce ul.payment_methods li input[type="radio"] {
    margin-right: 10px !important;
}

.woocommerce ul.payment_methods li label {
    font-family: 'Roboto', sans-serif !important;
    font-weight: 500 !important;
    color: var(--mp-primary-text) !important;
}

/* Payment icons styling */
.woocommerce ul.payment_methods li img {
    margin-left: 10px !important;
    vertical-align: middle !important;
}

/* Header Styling for WooCommerce */
.woocommerce .headerBlock,
.woocommerce-page .headerBlock {
	background: var(--mp-body-bg) !important;
	border-radius: 0 0 0.5rem 0.5rem !important;
	box-shadow: var(--mp-shadow) !important;
}

/* Logo Hover Effect for WooCommerce */
.woocommerce .headerBlock__logo img,
.woocommerce-page .headerBlock__logo img {
	transition: transform 0.3s ease !important;
}

.woocommerce .headerBlock__logo img:hover,
.woocommerce-page .headerBlock__logo img:hover {
	transform: scale(1.05) !important;
}


/* Message Element for WooCommerce */
.woocommerce .msgEl,
.woocommerce-page .msgEl {
    background: var(--mp-orange) !important;
    border-radius: 0.5rem !important;
    font-family: 'Roboto', sans-serif !important;
    font-weight: 500 !important;
    box-shadow: var(--mp-shadow) !important;
}

/* Login Block Styling for WooCommerce */
.woocommerce .wc-block-components-notice-banner__content .mo-openid-app-icons,
.woocommerce-page .wc-block-components-notice-banner__content .mo-openid-app-icons {
    text-align: center !important;
    background: transparent !important;
    margin: 0 auto !important;
}

/* Form labels styling */
.woocommerce .form-row label {
    font-family: 'Roboto', sans-serif !important;
    font-weight: 500 !important;
    color: var(--mp-primary-text) !important;
    margin-bottom: 8px !important;
    display: block !important;
}

.woocommerce .form-row label .required {
    color: var(--mp-danger-red) !important;
}

/* Subscription Title for WooCommerce */
.woocommerce .subscription-title,
.woocommerce-page .subscription-title {
    margin-top: 1.5rem !important;
    font-size: 16px !important;
    color: var(--mp-primary-text) !important;
    font-weight: 600 !important;
    font-family: 'Roboto', sans-serif !important;
    margin-bottom: 15px !important;
}

/* Subscription checkboxes styling */
.woocommerce .checkboxesBlock__body {
    margin-bottom: 20px !important;
}

.woocommerce .xoo-aff-group {
    margin-bottom: 10px !important;
}

.woocommerce .xoo-aff-group label {
    font-family: 'Roboto', sans-serif !important;
    font-weight: 400 !important;
    color: var(--mp-primary-text) !important;
    margin-bottom: 0 !important;
    display: inline !important;
}

.woocommerce .xoo-aff-group input[type="checkbox"] {
    margin-right: 8px !important;
    vertical-align: middle !important;
}

/* Terms and conditions styling */
.woocommerce .woocommerce-terms-and-conditions-checkbox-text {
    font-family: 'Roboto', sans-serif !important;
    font-size: 14px !important;
    color: var(--mp-primary-text) !important;
}

/* Order Summary Compact Styling for WooCommerce */
.woocommerce .woocommerce-checkout-review-order h3,
.woocommerce .checkoutBlock h3,
.woocommerce .cartBlock h3 {
    display: none !important;
}

.woocommerce .woocommerce-checkout-review-order-table .cart-subtotal,
.woocommerce .woocommerce-checkout-review-order-table tr.cart-subtotal,
.woocommerce .woocommerce-checkout-review-order-table .order-total,
.woocommerce .woocommerce-checkout-review-order-table tr.order-total {
    display: none !important;
}

.woocommerce .woocommerce-checkout-review-order-table td {
    padding: 0 !important;
    height: 30px !important;
    line-height: 1.2 !important;
    font-family: 'Roboto', sans-serif !important;
    font-size: 18px !important;
    font-weight: 600 !important;
}

.woocommerce .woocommerce-checkout-review-order-table td:first-child {
    text-align: left !important;
    padding-left: 20px !important;
    padding-right: 10px !important;
}

.woocommerce .woocommerce-checkout-review-order-table td:last-child {
    text-align: right !important;
    padding-right: 20px !important;
    padding-left: 10px !important;
}

.woocommerce .woocommerce-checkout-review-order-table thead {
    display: none !important;
}

.woocommerce .woocommerce-checkout-review-order-table {
    border: none !important;
    border-spacing: 0 !important;
    border-collapse: collapse !important;
}

.woocommerce .woocommerce-checkout-review-order-table td,
.woocommerce .woocommerce-checkout-review-order-table th {
    border: none !important;
}

/* Desktop Payment Button for WooCommerce */
@media (min-width: 768px) {
    .woocommerce #place_order,
    .woocommerce button[id="place_order"] {
        width: 100% !important;
        padding: 15px 30px !important;
        font-size: 18px !important;
        font-weight: 600 !important;
        margin-top: 20px;
    }

    .woocommerce .woocommerce-checkout #payment,
    .woocommerce .checkoutBlock,
    .woocommerce .cartBlock {
        text-align: center !important;
    }

    .woocommerce .woocommerce-checkout .form-row,
    .woocommerce .checkoutBlock .form-row,
    .woocommerce .cartBlock .form-row {
        text-align: left !important;
    }

    .woocommerce .woocommerce-checkout label,
    .woocommerce .checkoutBlock label,
    .woocommerce .cartBlock label {
        text-align: left !important;
    }
}

/* Fix z-index for auth modal to appear above dropdowns */
.xoo-el-container,
.xoo-el-opac,
.xoo-el-modal,
.xoo-el-wrap,
.xoo-el-main {
    z-index: 999999 !important;
}

/* Ensure dropdowns don't appear above modal */
.select2-container,
.select2-dropdown,
.select2-container--default .select2-results,
select {
    z-index: 1000 !important;
}

/* When modal is open, force dropdown z-index lower */
body.xoo-el-popup-active .select2-container,
body.xoo-el-popup-active .select2-dropdown,
body.xoo-el-popup-active select {
    z-index: 100 !important;
}

/* Style specific checkout page links with consistent text color and orange underline */
.wc-block-components-notice-banner__content a,
.woocommerce-info a,
.showlogin,
a.showlogin,
.woocommerce-terms-and-conditions-checkbox-text a,
.woocommerce .checkboxesBlock__body a,
.woocommerce .xoo-aff-group a,
a[href*="policy"],
a[href*="политик"],
a[href*="privacy"],
a[href*="персональных"],
a[href*="данных"],
.woocommerce-terms-and-conditions-checkbox-text a,
.woocommerce-terms-and-conditions-checkbox-text a[href*="policy"],
.woocommerce-terms-and-conditions-checkbox-text a[href*="политик"],
.woocommerce-terms-and-conditions-checkbox-text a[href*="privacy"],
.woocommerce-terms-and-conditions-checkbox-text a[href*="персональных"],
.woocommerce-terms-and-conditions-checkbox-text a[href*="данных"] {
    color: var(--mp-primary-text) !important;
    text-decoration: underline !important;
    text-decoration-color: var(--mp-orange) !important;
    transition: color 0.3s ease !important;
    font-weight: normal !important;
}

.wc-block-components-notice-banner__content a:hover,
.woocommerce-info a:hover,
.showlogin:hover,
a.showlogin:hover,
.woocommerce-terms-and-conditions-checkbox-text a:hover,
.woocommerce .checkboxesBlock__body a:hover,
.woocommerce .xoo-aff-group a:hover,
a[href*="policy"]:hover,
a[href*="политик"]:hover,
a[href*="privacy"]:hover,
a[href*="персональных"]:hover,
a[href*="данных"]:hover,
.woocommerce-terms-and-conditions-checkbox-text a:hover,
.woocommerce-terms-and-conditions-checkbox-text a[href*="policy"]:hover,
.woocommerce-terms-and-conditions-checkbox-text a[href*="политик"]:hover,
.woocommerce-terms-and-conditions-checkbox-text a[href*="privacy"]:hover,
.woocommerce-terms-and-conditions-checkbox-text a[href*="персональных"]:hover,
.woocommerce-terms-and-conditions-checkbox-text a[href*="данных"]:hover {
    color: var(--mp-orange) !important;
}

/* Center coupon code section when visible */
.woocommerce-form-coupon:not([style*="display: none"]),
.wc-block-components-totals-coupon:not([style*="display: none"]),
.coupon:not([style*="display: none"]) {
    text-align: center !important;
}

.woocommerce-form-coupon:not([style*="display: none"]) p,
.wc-block-components-totals-coupon:not([style*="display: none"]) p,
.coupon:not([style*="display: none"]) p {
    text-align: center !important;
    margin-bottom: 10px !important;
    font-size: 0.85rem !important;
}

.woocommerce-form-coupon:not([style*="display: none"]) .form-row,
.wc-block-components-totals-coupon:not([style*="display: none"]) .form-row {
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    gap: 10px !important;
}

/* Don't override display property for coupon forms */
.woocommerce-form-coupon[style*="display: none"],
.wc-block-components-totals-coupon[style*="display: none"],
.coupon[style*="display: none"] {
    display: none !important;
}

/* Enhanced WooCommerce Cart Blocks Styling */
.wc-block-cart-items__header,
.wc-block-cart-items .wc-block-cart-item {
  border-bottom: 1px solid #e9ecef !important;
}

.wc-block-cart-items .wc-block-cart-item:last-child {
  border-bottom: none !important;
}

/* Cart Item Product Names */
.wc-block-cart-item__product .wc-block-components-product-name {
  color: var(--mp-primary-text) !important;
  font-weight: 500 !important;
  font-size: 1.1rem !important;
}

/* Cart Item Prices */
.wc-block-cart-item__total .wc-block-formatted-money-amount,
.wc-block-components-totals-item .wc-block-formatted-money-amount {
  color: var(--mp-primary-text) !important;
  font-weight: 600 !important;
}

/* Cart Totals */
.wp-block-woocommerce-cart-order-summary-totals-block {
  background-color: #f8f9fa !important;
  border-radius: 0.375rem !important;
  padding: 1rem !important;
  margin: 1rem 0 !important;
}

/* Quantity Controls */
.wc-block-components-quantity-selector {
  border: 1px solid #e9ecef !important;
  border-radius: 0.375rem !important;
  background-color: var(--mp-card-bg) !important;
}

.wc-block-components-quantity-selector input {
  border: none !important;
  background: transparent !important;
  text-align: center !important;
  font-weight: 500 !important;
}

.wc-block-components-quantity-selector button {
  background-color: var(--mp-orange) !important;
  color: white !important;
  border: none !important;
  border-radius: 0.25rem !important;
  transition: background-color 0.3s ease !important;
}

.wc-block-components-quantity-selector button:hover {
  background-color: #e55d00 !important;
}

/* Remove Item Button */
.wc-block-cart-item__remove-link {
  color: var(--mp-danger-red) !important;
  transition: color 0.3s ease !important;
}

.wc-block-cart-item__remove-link:hover {
  color: #c82333 !important;
}

/* Checkout Button */
.wc-block-cart__submit-container .wc-block-cart__submit-button,
.wp-block-woocommerce-proceed-to-checkout-block .wc-block-cart__submit-button {
  background-color: var(--mp-primary-blue) !important;
  color: white !important;
  border: none !important;
  border-radius: 0.375rem !important;
  padding: 1rem 2rem !important;
  font-size: 1.1rem !important;
  font-weight: 600 !important;
  transition: background-color 0.3s ease, transform 0.3s ease !important;
  width: 100% !important;
}

.wc-block-cart__submit-container .wc-block-cart__submit-button:hover,
.wp-block-woocommerce-proceed-to-checkout-block .wc-block-cart__submit-button:hover {
  background-color: var(--mp-success-green) !important;
  transform: translateY(-1px) !important;
}

/* Empty Cart Styling */
.wp-block-woocommerce-empty-cart-block {
  background-color: var(--mp-card-bg) !important;
  border-radius: 0.5rem !important;
  box-shadow: var(--mp-shadow) !important;
  padding: 3rem !important;
  text-align: center !important;
  margin: 2rem 0 !important;
}

.wp-block-woocommerce-empty-cart-block h2 {
  color: var(--mp-secondary-text) !important;
  font-size: 1.5rem !important;
  margin-bottom: 1rem !important;
}

/* Continue Shopping Button */
.wc-block-cart__empty-cart-wrapper .wp-block-button__link {
  background-color: var(--mp-orange) !important;
  color: white !important;
  border-radius: 0.375rem !important;
  padding: 0.75rem 1.5rem !important;
  text-decoration: none !important;
  transition: background-color 0.3s ease !important;
}

.wc-block-cart__empty-cart-wrapper .wp-block-button__link:hover {
  background-color: #e55d00 !important;
}

/* Cross-sells Styling */
.wp-block-woocommerce-cart-cross-sells-block {
  background-color: var(--mp-card-bg) !important;
  border-radius: 0.5rem !important;
  box-shadow: var(--mp-shadow) !important;
  padding: 1.5rem !important;
  margin-top: 2rem !important;
}

.wp-block-woocommerce-cart-cross-sells-block h2 {
  color: var(--mp-primary-text) !important;
  font-size: 1.5rem !important;
  font-weight: 600 !important;
  margin-bottom: 1rem !important;
}

/* Mobile Responsive */
@media (max-width: 767.98px) {
  .page-cart h1 {
    font-size: 2rem !important;
  }

  .woocommerce .cartBlock,
  .woocommerce-page .cartBlock {
    margin: 1rem 0 !important;
    padding: 1rem !important;
  }

  .woocommerce .cartBlock .container,
  .woocommerce-page .cartBlock .container {
    margin: 0 10px !important;
  }

  .wc-block-cart-items,
  .wp-block-woocommerce-cart-order-summary-block {
    padding: 1rem !important;
  }

  /* Truncate product name on mobile with word wrap */
  .woocommerce .product-name {
    font-size: 14px !important;
    line-height: 1.3 !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 2 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    word-wrap: break-word !important;
    max-height: 2.6em !important;
  }
}