/*
Theme Name: MRO Global Supply — Child
Theme URI: https://mroglobalsupply.com/
Template: mro-global-supply
Author: MRO Global Supply
Author URI: https://mroglobalsupply.com/
Description: Child theme for MRO Global Supply. Put all your customizations here so future parent-theme updates don't overwrite them.
Version: 2.1.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: mro-global-supply-child
*/

/* =============================================================
   MRO GLOBAL SUPPLY — CHILD THEME OVERRIDES v2.1
   Google Core Web Vitals + Readability Best Practices
   ─────────────────────────────────────────────────────────────
   Google's content readability guidelines require:
   • Min 16px body font, 1.5–1.8 line-height for paragraphs
   • Min 8px paragraph spacing (we use 1.5rem = 24px)
   • Content never flush with viewport edges (min 16px padding)
   • Max line length 65–75 characters (60–75ch max-width)
   • Sufficient contrast between text and background
   • Headings form a clear visual hierarchy (H1 > H2 > H3)
   ============================================================= */


/* ── 1. GLOBAL CONTAINER — 30px minimum edge margin ────────── */
/* Overrides the parent theme's container padding on all screens */

.mro-container,
.woocommerce .mro-container,
.woocommerce-page .mro-container {
    padding-left:  clamp(30px, 4vw, 80px);
    padding-right: clamp(30px, 4vw, 80px);
}

/* Ensure WooCommerce's own wrappers also never hit the edge */
.woocommerce,
.woocommerce-page {
    padding-left:  0;
    padding-right: 0;
}

.woocommerce #content,
.woocommerce-page #content,
.woocommerce #main,
.woocommerce-page #main {
    padding-left:  0;
    padding-right: 0;
}


/* ── 2. SINGLE PRODUCT PAGE — layout, spacing, margins ─────── */

/* Constrain full-width product content to readable max-width */
.woocommerce div.product {
    max-width:    var(--mro-container, 1280px);
    margin-left:  auto;
    margin-right: auto;
    padding:      clamp(30px, 4vw, 60px) clamp(30px, 4vw, 80px);
}

/* Product summary column — generous internal padding */
.woocommerce div.product .summary {
    padding:      0 0 0 clamp(20px, 3vw, 48px);
}

@media (max-width: 768px) {
    .woocommerce div.product .summary {
        padding: 24px 0 0 0;
    }
}

/* Product title — H1, clear hierarchy */
.woocommerce div.product .product_title {
    font-size:     clamp(1.6rem, 3vw, 2.2rem);
    font-weight:   800;
    line-height:   1.25;
    margin-bottom: 1rem;
    letter-spacing: -0.02em;
    color:         var(--mro-text, #1a2b3c);
}

/* Short description directly under title */
.woocommerce-product-details__short-description {
    font-size:   1rem;
    line-height: 1.75;
    color:       var(--mro-text-muted, #4a5568);
    margin-top:    0.5rem;
    margin-bottom: 1.75rem;
    max-width:     68ch; /* Google recommends 65–75ch max line length */
}

.woocommerce-product-details__short-description p {
    margin-bottom: 1rem;
}


/* ── 3. PRODUCT DESCRIPTION TAB — Google paragraph rules ───── */
/* Google explicitly scores paragraph spacing, font size,
   line-height, and content width for readability signals.    */

.woocommerce-tabs .woocommerce-Tabs-panel,
.woocommerce div.product .woocommerce-product-details__short-description,
.woocommerce div.product #tab-description {
    /* Font */
    font-size:   1rem;          /* 16px minimum — Google requirement */
    line-height: 1.8;           /* Optimal for body text readability */
    color:       var(--mro-text, #1a2b3c);

    /* Spacing */
    padding:        2rem clamp(20px, 3vw, 40px);
    margin-bottom:  0;

    /* Max width for readability — ~70 characters per line */
    max-width: 100%;
}

/* Every <p> inside product description */
.woocommerce div.product div.woocommerce-product-details__short-description p,
#tab-description p,
.woocommerce-Tabs-panel p,
.woocommerce-product-details p {
    font-size:      1rem;
    line-height:    1.8;
    margin-top:     0;
    margin-bottom:  1.5rem;   /* 24px — generous paragraph spacing */
    max-width:      72ch;     /* Optimal line length per Google/WCAG */
    color:          var(--mro-text, #1a2b3c);
}

/* Last paragraph no bottom margin */
#tab-description p:last-child,
.woocommerce-Tabs-panel p:last-child {
    margin-bottom: 0;
}

/* Headings inside description — clear hierarchy */
#tab-description h2,
.woocommerce-Tabs-panel h2 {
    font-size:     1.5rem;
    font-weight:   700;
    line-height:   1.3;
    margin-top:    2.5rem;
    margin-bottom: 0.75rem;
    color:         var(--mro-navy, #1a3a6e);
    border-bottom: 2px solid var(--mro-yellow, #f5c518);
    padding-bottom: 0.4rem;
}

#tab-description h3,
.woocommerce-Tabs-panel h3 {
    font-size:     1.2rem;
    font-weight:   700;
    line-height:   1.35;
    margin-top:    2rem;
    margin-bottom: 0.6rem;
    color:         var(--mro-navy, #1a3a6e);
}

#tab-description h4,
.woocommerce-Tabs-panel h4 {
    font-size:     1rem;
    font-weight:   700;
    margin-top:    1.5rem;
    margin-bottom: 0.5rem;
    color:         var(--mro-text, #1a2b3c);
}

/* Lists inside description */
#tab-description ul,
#tab-description ol,
.woocommerce-Tabs-panel ul,
.woocommerce-Tabs-panel ol {
    padding-left:  1.75rem;
    margin-bottom: 1.5rem;
    line-height:   1.8;
    font-size:     1rem;
    max-width:     72ch;
}

#tab-description li,
.woocommerce-Tabs-panel li {
    margin-bottom: 0.5rem;
}

/* Strong/bold inside paragraphs */
#tab-description strong,
.woocommerce-Tabs-panel strong {
    font-weight: 700;
    color:       var(--mro-navy, #1a3a6e);
}

/* Specification tables */
#tab-description table,
.woocommerce-Tabs-panel table {
    width:           100%;
    border-collapse: collapse;
    margin-bottom:   2rem;
    font-size:       0.9rem;
    line-height:     1.6;
}

#tab-description table th,
.woocommerce-Tabs-panel table th {
    background:    var(--mro-navy, #1a3a6e);
    color:         #fff;
    padding:       10px 14px;
    text-align:    left;
    font-weight:   700;
    font-size:     0.85rem;
    letter-spacing: 0.05em;
    text-transform: uppercase;
}

#tab-description table td,
.woocommerce-Tabs-panel table td {
    padding:       9px 14px;
    border-bottom: 1px solid var(--mro-border, #e2e8f0);
    vertical-align: top;
}

#tab-description table tr:nth-child(even) td,
.woocommerce-Tabs-panel table tr:nth-child(even) td {
    background: var(--mro-bg-alt, #f8fafc);
}


/* ── 4. PRODUCT TABS — visual polish ───────────────────────── */

.woocommerce-tabs ul.tabs {
    padding:       0;
    margin-bottom: 0;
    border-bottom: 2px solid var(--mro-border, #e2e8f0);
    display:       flex;
    gap:           4px;
    flex-wrap:     wrap;
}

.woocommerce-tabs ul.tabs li {
    margin:  0;
    padding: 0;
    border:  none;
    background: transparent;
}

.woocommerce-tabs ul.tabs li a {
    display:        block;
    padding:        12px 22px;
    font-size:      0.9rem;
    font-weight:    600;
    color:          var(--mro-text-muted, #64748b);
    border-radius:  6px 6px 0 0;
    transition:     all 0.15s;
    text-decoration: none;
    border:         1px solid transparent;
    border-bottom:  none;
    margin-bottom:  -2px;
}

.woocommerce-tabs ul.tabs li a:hover {
    color:      var(--mro-navy, #1a3a6e);
    background: var(--mro-bg-alt, #f8fafc);
}

.woocommerce-tabs ul.tabs li.active a {
    color:        var(--mro-navy, #1a3a6e);
    background:   #fff;
    border-color: var(--mro-border, #e2e8f0);
    border-bottom-color: #fff;
    font-weight:  700;
}

[data-theme="dark"] .woocommerce-tabs ul.tabs li.active a {
    background:   var(--mro-bg-elevated, #1a2234);
    border-color: var(--mro-border, #2a3550);
    border-bottom-color: var(--mro-bg-elevated, #1a2234);
    color:        #f1f5f9;
}

.woocommerce-tabs .panel {
    padding:        2rem clamp(20px, 3vw, 40px) 2.5rem;
    border:         1px solid var(--mro-border, #e2e8f0);
    border-top:     none;
    border-radius:  0 0 8px 8px;
    background:     #fff;
    margin-bottom:  2rem;
}

[data-theme="dark"] .woocommerce-tabs .panel {
    background:   var(--mro-bg-elevated, #1a2234);
    border-color: var(--mro-border, #2a3550);
}


/* ── 5. PRODUCT IMAGE AREA ──────────────────────────────────── */

.woocommerce div.product div.images {
    margin-bottom: 0;
}

.woocommerce div.product div.images img {
    border-radius: 10px;
    border:        1px solid var(--mro-border, #e2e8f0);
}

/* Image placeholder (when no photo uploaded) */
.woocommerce div.product div.images .woocommerce-placeholder {
    border-radius: 10px;
    border:        2px dashed var(--mro-border, #e2e8f0);
    background:    var(--mro-bg-alt, #f8fafc);
    padding:       40px;
    opacity:       0.6;
}


/* ── 6. BREADCRUMBS — orientation & spacing ─────────────────── */

.woocommerce .woocommerce-breadcrumb {
    font-size:    0.82rem;
    color:        var(--mro-text-muted, #64748b);
    padding:      16px clamp(30px, 4vw, 80px);
    margin:       0;
    line-height:  1.5;
    background:   var(--mro-bg-alt, #f8fafc);
    border-bottom: 1px solid var(--mro-border, #e2e8f0);
}

.woocommerce .woocommerce-breadcrumb a {
    color:           var(--mro-navy, #1a3a6e);
    text-decoration: none;
}

.woocommerce .woocommerce-breadcrumb a:hover {
    text-decoration: underline;
}


/* ── 7. RELATED PRODUCTS ────────────────────────────────────── */

.related.products {
    padding:    3rem clamp(30px, 4vw, 80px);
    background: var(--mro-bg-alt, #f8fafc);
    margin-top: 2rem;
}

.related.products h2 {
    font-size:     1.4rem;
    font-weight:   800;
    margin-bottom: 1.5rem;
    color:         var(--mro-navy, #1a3a6e);
}


/* ── 8. META (SKU, CATEGORIES, TAGS) ────────────────────────── */

.woocommerce div.product .product_meta {
    margin-top:  1.5rem;
    font-size:   0.85rem;
    line-height: 1.7;
    color:       var(--mro-text-muted, #64748b);
    padding-top: 1rem;
    border-top:  1px solid var(--mro-border, #e2e8f0);
}

.woocommerce div.product .product_meta span {
    display:       block;
    margin-bottom: 0.35rem;
}

.woocommerce div.product .product_meta a {
    color:           var(--mro-navy, #1a3a6e);
    text-decoration: none;
    font-weight:     600;
}

.woocommerce div.product .product_meta a:hover {
    text-decoration: underline;
}


/* ── 9. SHOP / ARCHIVE PAGE — 30px edge margins ─────────────── */

.woocommerce-page .site-main,
.woocommerce .site-main {
    padding-left:  0;
    padding-right: 0;
}

/* WooCommerce injects its own wrapper — ensure it has margins */
.woocommerce-page #primary .woocommerce,
.woocommerce-page .woocommerce {
    padding: 0 clamp(30px, 4vw, 80px);
}

/* Shop page title and result count */
.woocommerce-products-header {
    padding: 2rem 0 1rem;
}

.woocommerce-result-count,
.woocommerce-ordering {
    font-size: 0.9rem;
    color:     var(--mro-text-muted, #64748b);
}


/* ── 10. GLOBAL TYPOGRAPHY — Google recommended baseline ─────── */
/* These apply site-wide and improve Core Web Vitals scores      */

body {
    font-size:   1rem;    /* 16px — Google minimum recommendation */
    line-height: 1.65;    /* Body text comfortable reading rhythm */
}

/* All paragraphs site-wide — consistent spacing */
p {
    margin-top:    0;
    margin-bottom: 1.25rem;
    line-height:   1.75;
    max-width:     none; /* Let containers control width */
}

/* Blog/article paragraphs — tighter max-width for readability */
.mro-blog-content p,
.entry-content p,
.post-content p,
article p {
    max-width:   72ch;
    line-height: 1.8;
    margin-bottom: 1.5rem;
}

/* Heading hierarchy — consistent scale */
h1 { font-size: clamp(1.8rem, 4vw, 2.5rem);  line-height: 1.2; margin-bottom: 1rem; }
h2 { font-size: clamp(1.4rem, 3vw, 1.9rem);  line-height: 1.25; margin-bottom: 0.85rem; }
h3 { font-size: clamp(1.1rem, 2vw, 1.4rem);  line-height: 1.3;  margin-bottom: 0.75rem; }
h4 { font-size: 1.05rem; line-height: 1.35; margin-bottom: 0.6rem; }
h5 { font-size: 0.95rem; line-height: 1.4;  margin-bottom: 0.5rem; }
h6 { font-size: 0.85rem; line-height: 1.4;  margin-bottom: 0.5rem; }


/* ── 11. MOBILE RESPONSIVE — all screens get 30px minimum ───── */

@media (max-width: 768px) {

    /* Global container */
    .mro-container,
    .woocommerce .mro-container,
    .woocommerce-page .mro-container {
        padding-left:  20px;
        padding-right: 20px;
    }

    /* Product page */
    .woocommerce div.product {
        padding: 20px 20px 40px;
    }

    .woocommerce div.product .summary {
        padding: 20px 0 0;
    }

    /* Shop page */
    .woocommerce-page #primary .woocommerce,
    .woocommerce-page .woocommerce {
        padding-left:  20px;
        padding-right: 20px;
    }

    /* Breadcrumbs */
    .woocommerce .woocommerce-breadcrumb {
        padding-left:  20px;
        padding-right: 20px;
    }

    /* Related products */
    .related.products {
        padding: 2rem 20px;
    }

    /* Tab panels */
    .woocommerce-tabs .panel {
        padding: 1.5rem 16px 2rem;
    }

    /* Paragraph max-width removed on small screens */
    #tab-description p,
    .woocommerce-Tabs-panel p,
    .woocommerce-product-details__short-description p {
        max-width: 100%;
    }

    /* Headings scale down */
    .woocommerce div.product .product_title {
        font-size: 1.4rem;
    }
}

@media (max-width: 480px) {

    .mro-container,
    .woocommerce .mro-container,
    .woocommerce-page .mro-container {
        padding-left:  16px;
        padding-right: 16px;
    }

    .woocommerce div.product {
        padding: 16px 16px 32px;
    }

    .woocommerce-page #primary .woocommerce,
    .woocommerce-page .woocommerce {
        padding-left:  16px;
        padding-right: 16px;
    }

    .woocommerce .woocommerce-breadcrumb {
        padding-left:  16px;
        padding-right: 16px;
    }

    .related.products {
        padding: 1.5rem 16px;
    }
}



/* =============================================================
   4-COLUMN PRODUCT GRID
   Targets the actual rendered HTML structure:
   .mro-container > ul.products.columns-X > li.product > .mro-product-card
   ============================================================= */

/* ── 1. Remove container width constraint on product pages ──── */
/* The .mro-container inside brand/shop pages limits width.
   We override it to use full available width with proper padding */

.tax-product_brand .mro-section .mro-container,
.post-type-archive-product .mro-section .mro-container,
.woocommerce-page .mro-section .mro-container,
#mro-brand-products .mro-container {
    max-width: 100% !important;
    padding-left:  clamp(24px, 3vw, 60px) !important;
    padding-right: clamp(24px, 3vw, 60px) !important;
}

/* ── 2. Force 4-column grid on ALL WooCommerce product lists ─── */
/* Nuclear specificity — overrides WooCommerce's inline columns-X classes */

ul.products,
ul.products.columns-1,
ul.products.columns-2,
ul.products.columns-3,
ul.products.columns-4,
ul.products.columns-5,
.woocommerce ul.products,
.woocommerce-page ul.products,
.woocommerce ul.products.columns-1,
.woocommerce ul.products.columns-2,
.woocommerce ul.products.columns-3,
.woocommerce ul.products.columns-4,
.woocommerce ul.products.columns-5,
.woocommerce-page ul.products.columns-1,
.woocommerce-page ul.products.columns-2,
.woocommerce-page ul.products.columns-3,
.woocommerce-page ul.products.columns-4,
.woocommerce-page ul.products.columns-5 {
    display:               grid !important;
    grid-template-columns: repeat(4, 1fr) !important;
    gap:                   20px !important;
    margin-left:           0 !important;
    margin-right:          0 !important;
    padding:               0 !important;
    float:                 none !important;
    clear:                 both !important;
    width:                 100% !important;
}

/* ── 3. Individual li.product — reset WooCommerce floats ─────── */
.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product {
    float:          none !important;
    clear:          none !important;
    width:          100% !important;
    margin:         0 !important;
    padding:        0 !important;
    display:        flex !important;
    flex-direction: column !important;
}

/* ── 4. The actual card inside li.product ──────────────────────
   The theme wraps content in .mro-product-card div.
   Make it fill the full li height for uniform card rows. */

.woocommerce ul.products li.product .mro-product-card,
.woocommerce-page ul.products li.product .mro-product-card {
    flex:           1 !important;
    display:        flex !important;
    flex-direction: column !important;
    height:         100% !important;
    border-radius:  12px !important;
    border:         1px solid var(--mro-border, #e2e8f0) !important;
    overflow:       hidden !important;
    background:     var(--mro-bg-elevated, #fff) !important;
    transition:     transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease !important;
}

.woocommerce ul.products li.product .mro-product-card:hover,
.woocommerce-page ul.products li.product .mro-product-card:hover {
    transform:    translateY(-4px) !important;
    box-shadow:   0 10px 32px rgba(13,95,166,.14) !important;
    border-color: var(--mro-navy, #1a3a6e) !important;
}

/* ── 5. Product image — fixed height for uniform cards ─────────
   Without a fixed height, placeholder images cause uneven rows */

.woocommerce ul.products li.product .mro-product-image,
.woocommerce-page ul.products li.product .mro-product-image {
    aspect-ratio:   unset !important;
    height:         190px !important;
    min-height:     190px !important;
    flex-shrink:    0 !important;
    background:     var(--mro-bg-alt, #f0f4f8) !important;
    display:        flex !important;
    align-items:    center !important;
    justify-content:center !important;
    overflow:       hidden !important;
}

.woocommerce ul.products li.product .mro-product-image img,
.woocommerce-page ul.products li.product .mro-product-image img {
    width:       100% !important;
    height:      100% !important;
    object-fit:  cover !important;
}

/* WooCommerce placeholder when no image */
.woocommerce ul.products li.product .mro-product-image img.woocommerce-placeholder,
.woocommerce ul.products li.product .mro-product-image .wp-post-image[src*="placeholder"] {
    object-fit: contain !important;
    padding:    30px !important;
    opacity:    0.4 !important;
}

/* ── 6. Product info area — consistent padding ─────────────── */

.woocommerce ul.products li.product .mro-product-info,
.woocommerce-page ul.products li.product .mro-product-info {
    padding: 12px 14px 6px !important;
    flex:    1 !important;
    display: flex !important;
    flex-direction: column !important;
}

.woocommerce ul.products li.product .mro-product-brand,
.woocommerce-page ul.products li.product .mro-product-brand {
    font-size:     0.68rem !important;
    margin-bottom: 6px !important;
}

.woocommerce ul.products li.product .mro-product-title,
.woocommerce-page ul.products li.product .mro-product-title {
    font-size:   0.88rem !important;
    line-height: 1.35 !important;
    margin-bottom: var(--mro-space-2, 0.5rem) !important;
    -webkit-line-clamp: 2 !important;
    min-height: 2.4em !important;
}

.woocommerce ul.products li.product .mro-product-meta,
.woocommerce-page ul.products li.product .mro-product-meta {
    font-size: 0.75rem !important;
    flex: 1 !important;
    margin-bottom: 0 !important;
}

/* ── 7. Get Details button ─────────────────────────────────── */

.woocommerce ul.products li.product .mro-product-actions,
.woocommerce-page ul.products li.product .mro-product-actions {
    padding:    10px 14px 14px !important;
    margin-top: auto !important;
}

.woocommerce ul.products li.product .mro-add-to-quote,
.woocommerce-page ul.products li.product .mro-add-to-quote {
    width:     100% !important;
    font-size: 0.82rem !important;
    padding:   9px 10px !important;
}

/* ── 8. Pagination ─────────────────────────────────────────── */

.woocommerce nav.woocommerce-pagination {
    clear:      both !important;
    margin-top: 36px !important;
    text-align: center !important;
}

.woocommerce nav.woocommerce-pagination ul {
    display:   inline-flex !important;
    gap:       4px !important;
}

.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span {
    display:        flex !important;
    align-items:    center !important;
    justify-content:center !important;
    min-width:      38px !important;
    height:         38px !important;
    border-radius:  7px !important;
    font-size:      0.85rem !important;
    font-weight:    600 !important;
    border:         1px solid var(--mro-border, #e2e8f0) !important;
    text-decoration:none !important;
    transition:     all 0.15s !important;
    padding:        0 10px !important;
}

.woocommerce nav.woocommerce-pagination ul li a:hover {
    background:   var(--mro-navy, #1a3a6e) !important;
    color:        #fff !important;
    border-color: var(--mro-navy, #1a3a6e) !important;
}

.woocommerce nav.woocommerce-pagination ul li span.current {
    background:   var(--mro-navy, #1a3a6e) !important;
    color:        #fff !important;
    border-color: var(--mro-navy, #1a3a6e) !important;
}

/* ── 9. RESPONSIVE ─────────────────────────────────────────── */

/* 1400px and below: 4 columns, tighter gap */
@media (max-width: 1400px) {
    ul.products,
    ul.products[class*="columns-"],
    .woocommerce ul.products,
    .woocommerce ul.products[class*="columns-"],
    .woocommerce-page ul.products,
    .woocommerce-page ul.products[class*="columns-"] {
        grid-template-columns: repeat(4, 1fr) !important;
        gap: 16px !important;
    }
}

/* 600px: 2 columns (genuine mobile only) */
@media (max-width: 600px) {
    ul.products,
    ul.products[class*="columns-"],
    .woocommerce ul.products,
    .woocommerce ul.products[class*="columns-"],
    .woocommerce-page ul.products,
    .woocommerce-page ul.products[class*="columns-"] {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 12px !important;
    }

    .woocommerce ul.products li.product .mro-product-image {
        height: 140px !important;
        min-height: 140px !important;
    }

    .woocommerce ul.products li.product .mro-product-title {
        font-size: 0.8rem !important;
    }
}

/* 360px: 1 column */
@media (max-width: 360px) {
    ul.products,
    ul.products[class*="columns-"],
    .woocommerce ul.products,
    .woocommerce ul.products[class*="columns-"],
    .woocommerce-page ul.products,
    .woocommerce-page ul.products[class*="columns-"] {
        grid-template-columns: 1fr !important;
    }
}


/* =============================================================
   PRODUCT DESCRIPTION TAB — Fix whitespace & width issues
   ============================================================= */

/* ── Remove WooCommerce's default excessive top padding ─────── */
.woocommerce-tabs .woocommerce-Tabs-panel,
.woocommerce-tabs #tab-description,
.woocommerce-tabs #tab-reviews,
.woocommerce div.product .woocommerce-tabs .panel {
    padding:        24px 28px 32px !important;
    margin:         0 !important;
}

/* ── Remove the duplicate "Description" H2 WC injects ───────── */
/* WooCommerce adds an h2 inside the tab that duplicates the
   tab label — hide it for cleaner presentation               */
.woocommerce-tabs #tab-description > h2:first-child,
.woocommerce-tabs .woocommerce-Tabs-panel > h2:first-child {
    display: none !important;
}

/* ── Description text — use full width, not 72ch ────────────── */
/* 72ch was correct for blog articles but too narrow for
   product descriptions which benefit from full column width  */
#tab-description p,
.woocommerce-Tabs-panel--description p,
.woocommerce-Tabs-panel p,
.woocommerce-tabs .panel p {
    max-width:     100% !important;
    font-size:     0.95rem !important;
    line-height:   1.8 !important;
    margin-bottom: 1.25rem !important;
    color:         var(--mro-text, #1a2b3c) !important;
}

/* ── Tab panel border and background ────────────────────────── */
.woocommerce-tabs .woocommerce-Tabs-panel,
.woocommerce-tabs .panel {
    border:        1px solid var(--mro-border, #e2e8f0) !important;
    border-top:    none !important;
    border-radius: 0 0 10px 10px !important;
    background:    #fff !important;
    margin-bottom: 2rem !important;
}

[data-theme="dark"] .woocommerce-tabs .woocommerce-Tabs-panel,
[data-theme="dark"] .woocommerce-tabs .panel {
    background:   var(--mro-bg-elevated, #1a2234) !important;
    border-color: var(--mro-border, #2a3550) !important;
}

/* ── Tab nav bar ─────────────────────────────────────────────── */
.woocommerce-tabs ul.tabs {
    margin:        0 !important;
    padding:       0 !important;
    border-bottom: 2px solid var(--mro-border, #e2e8f0) !important;
    display:       flex !important;
    gap:           2px !important;
    list-style:    none !important;
}

.woocommerce-tabs ul.tabs::before,
.woocommerce-tabs ul.tabs::after {
    display: none !important;
}

.woocommerce-tabs ul.tabs li {
    border:     none !important;
    background: transparent !important;
    margin:     0 !important;
    padding:    0 !important;
}

.woocommerce-tabs ul.tabs li a {
    display:         block !important;
    padding:         11px 22px !important;
    font-size:       0.88rem !important;
    font-weight:     600 !important;
    color:           var(--mro-text-muted, #64748b) !important;
    border-radius:   6px 6px 0 0 !important;
    text-decoration: none !important;
    border:          1px solid transparent !important;
    border-bottom:   none !important;
    margin-bottom:   -2px !important;
    transition:      all 0.15s !important;
}

.woocommerce-tabs ul.tabs li a:hover {
    color:      var(--mro-navy, #1a3a6e) !important;
    background: var(--mro-bg-alt, #f5f8fc) !important;
}

.woocommerce-tabs ul.tabs li.active a {
    color:               var(--mro-navy, #1a3a6e) !important;
    background:          #fff !important;
    border-color:        var(--mro-border, #e2e8f0) !important;
    border-bottom-color: #fff !important;
    font-weight:         700 !important;
}

[data-theme="dark"] .woocommerce-tabs ul.tabs li.active a {
    background:          var(--mro-bg-elevated, #1a2234) !important;
    border-color:        var(--mro-border, #2a3550) !important;
    border-bottom-color: var(--mro-bg-elevated, #1a2234) !important;
    color:               #f1f5f9 !important;
}

/* ── Headings inside description ─────────────────────────────── */
#tab-description h2,
.woocommerce-Tabs-panel h2 {
    font-size:      1.3rem !important;
    font-weight:    700 !important;
    color:          var(--mro-navy, #1a3a6e) !important;
    margin-top:     2rem !important;
    margin-bottom:  0.6rem !important;
    padding-bottom: 0.35rem !important;
    border-bottom:  2px solid var(--mro-yellow, #f5c518) !important;
}

#tab-description h2:first-child,
.woocommerce-Tabs-panel h2:first-child {
    margin-top: 0 !important;
}

#tab-description h3,
.woocommerce-Tabs-panel h3 {
    font-size:     1.1rem !important;
    font-weight:   700 !important;
    color:         var(--mro-navy, #1a3a6e) !important;
    margin-top:    1.75rem !important;
    margin-bottom: 0.5rem !important;
}

/* ── Lists ───────────────────────────────────────────────────── */
#tab-description ul,
#tab-description ol,
.woocommerce-Tabs-panel ul,
.woocommerce-Tabs-panel ol {
    padding-left:  1.5rem !important;
    margin-bottom: 1.25rem !important;
    max-width:     100% !important;
    line-height:   1.8 !important;
}

#tab-description li,
.woocommerce-Tabs-panel li {
    margin-bottom: 0.4rem !important;
    font-size:     0.95rem !important;
}


/* =============================================================
   RELATED PRODUCTS & UPSELLS — Force 4 columns
   WooCommerce uses separate args for related products so they
   need their own CSS rules alongside the PHP filter fix.
   ============================================================= */

/* Related products section wrapper */
.related.products,
.upsells.products {
    margin-top:  3rem !important;
    clear:       both !important;
}

.related.products h2,
.upsells.products h2 {
    font-size:     1.3rem !important;
    font-weight:   800 !important;
    color:         var(--mro-navy, #1a3a6e) !important;
    margin-bottom: 1.25rem !important;
    padding-bottom: 0.4rem !important;
    border-bottom: 2px solid var(--mro-yellow, #f5c518) !important;
    display:       inline-block !important;
}

/* Force 4 columns on related/upsell product lists */
.related.products ul.products,
.upsells.products ul.products,
.related ul.products,
.upsells ul.products,
.related.products ul.products.columns-1,
.related.products ul.products.columns-2,
.related.products ul.products.columns-3,
.related.products ul.products.columns-4,
.related.products ul.products.columns-5,
.upsells.products ul.products.columns-1,
.upsells.products ul.products.columns-2,
.upsells.products ul.products.columns-3,
.upsells.products ul.products.columns-4,
.upsells.products ul.products.columns-5 {
    display:               grid !important;
    grid-template-columns: repeat(4, 1fr) !important;
    gap:                   20px !important;
    width:                 100% !important;
    margin:                0 !important;
    padding:               0 !important;
    float:                 none !important;
    list-style:            none !important;
}

/* Cards inside related products */
.related.products ul.products li.product,
.upsells.products ul.products li.product {
    float:          none !important;
    width:          100% !important;
    margin:         0 !important;
    padding:        0 !important;
    clear:          none !important;
    display:        flex !important;
    flex-direction: column !important;
}

/* ── Responsive for related products ─────────────────────────── */

@media (max-width: 600px) {
    .related.products ul.products,
    .upsells.products ul.products,
    .related.products ul.products[class*="columns-"],
    .upsells.products ul.products[class*="columns-"] {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 12px !important;
    }
}

@media (max-width: 360px) {
    .related.products ul.products,
    .upsells.products ul.products,
    .related.products ul.products[class*="columns-"],
    .upsells.products ul.products[class*="columns-"] {
        grid-template-columns: 1fr !important;
    }
}


/* =============================================================
   FIX: Blank first grid slot on brand/category pages
   The woocommerce_before_shop_loop hook fires result-count and
   ordering elements that can occupy the first grid cell.
   These are hidden on taxonomy pages via PHP but this CSS acts
   as a safety net for any stray block elements.
   ============================================================= */

/* Hide result count and ordering bar on brand/category pages */
.tax-product_brand .woocommerce-result-count,
.tax-product_brand .woocommerce-ordering,
.tax-product_cat .woocommerce-result-count,
.tax-product_cat .woocommerce-ordering {
    display: none !important;
}

/* Ensure ul.products is the first block-level child —
   any preceding empty divs or stray elements get removed visually */
.tax-product_brand ul.products,
.tax-product_cat ul.products {
    margin-top: 0 !important;
    clear: both !important;
}

/* Stray empty li or div inside the grid that creates blank cell */
.woocommerce ul.products > li:empty,
.woocommerce ul.products > div:empty,
.woocommerce-page ul.products > li:empty {
    display: none !important;
}

/* WooCommerce sometimes wraps the loop-start notice inside
   the grid — force it outside the grid flow */
.woocommerce ul.products > .woocommerce-notices-wrapper,
.woocommerce ul.products > .woocommerce-info,
.woocommerce ul.products > .woocommerce-message {
    grid-column: 1 / -1 !important;
    display:     block !important;
}
