/*
Theme Name:  ColorCraft
Theme URI:   https://example.com/colorcraft
Author:      ColorCraft Theme
Description: A clean, fully customizable WordPress theme with live color editing for text, header, footer, background, and full WooCommerce support.
Version:     1.0.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 8.0
License:     GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: colorcraft
Tags:        custom-colors, custom-menu, custom-logo, e-commerce, woocommerce, full-width-template, left-sidebar, right-sidebar, two-columns, three-columns, grid-layout, footer-widgets, blog, portfolio, one-column
*/

/* ============================================================
   CSS CUSTOM PROPERTIES — edited live via the Customizer
   ============================================================ */
:root {
    --color-body-bg:        #f9f7f4;
    --color-body-text:      #1a1a2e;
    --color-header-bg:      #1a1a2e;
    --color-header-text:    #ffffff;
    --color-footer-bg:      #12121f;
    --color-footer-text:    #ccccdd;
    --color-primary:        #e85d4a;
    --color-primary-hover:  #c94232;
    --color-btn-text:       #ffffff;
    --color-secondary:      #4a90d9;
    --color-accent:         #f5a623;
    --color-border:         #e0ddd8;
    --color-card-bg:        #ffffff;
    --color-muted:          #7a7a8e;

    --font-heading:         'Playfair Display', Georgia, serif;
    --font-body:            'DM Sans', 'Helvetica Neue', sans-serif;
    --font-mono:            'JetBrains Mono', monospace;

    --radius:               6px;
    --radius-lg:            12px;
    --shadow-sm:            0 1px 3px rgba(0,0,0,.08);
    --shadow-md:            0 4px 16px rgba(0,0,0,.12);
    --shadow-lg:            0 8px 40px rgba(0,0,0,.16);
    --transition:           0.2s ease;
    --container-width:      1200px;
    --header-height:        72px;
}

/* ============================================================
   RESET & BASE
   ============================================================ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { font-size: 16px; scroll-behavior: smooth; }

body {
    background-color: var(--color-body-bg);
    color:            var(--color-body-text);
    font-family:      var(--font-body);
    font-size:        1rem;
    line-height:      1.7;
    -webkit-font-smoothing: antialiased;
}

img, video { max-width: 100%; height: auto; display: block; }
a { color: var(--color-primary); text-decoration: none; transition: color var(--transition); }
a:hover { color: var(--color-primary-hover); }
ul, ol { padding-left: 1.5rem; }

h1, h2, h3, h4, h5, h6 {
    font-family:    var(--font-heading);
    font-weight:    700;
    line-height:    1.25;
    color:          var(--color-body-text);
    margin-bottom:  0.5em;
}
h1 { font-size: clamp(2rem, 5vw, 3.5rem); }
h2 { font-size: clamp(1.6rem, 4vw, 2.5rem); }
h3 { font-size: clamp(1.3rem, 3vw, 1.8rem); }
h4 { font-size: 1.3rem; }
h5 { font-size: 1.1rem; }
h6 { font-size: 1rem; }

p { margin-bottom: 1.2rem; }
p:last-child { margin-bottom: 0; }

blockquote {
    border-left: 4px solid var(--color-primary);
    padding: 1rem 1.5rem;
    margin: 1.5rem 0;
    background: rgba(0,0,0,.03);
    font-style: italic;
    border-radius: 0 var(--radius) var(--radius) 0;
}

code, pre {
    font-family: var(--font-mono);
    background: rgba(0,0,0,.05);
    border-radius: var(--radius);
}
code { padding: 0.15em 0.45em; font-size: 0.88em; }
pre { padding: 1.2rem; overflow-x: auto; margin-bottom: 1.5rem; }
pre code { background: none; padding: 0; }

hr {
    border: none;
    border-top: 1px solid var(--color-border);
    margin: 2rem 0;
}

table { width: 100%; border-collapse: collapse; margin-bottom: 1.5rem; }
th, td { padding: .65rem 1rem; border: 1px solid var(--color-border); text-align: left; }
th { background: rgba(0,0,0,.04); font-weight: 600; }

/* ============================================================
   LAYOUT HELPERS
   ============================================================ */
.container {
    width:     100%;
    max-width: var(--container-width);
    margin:    0 auto;
    padding:   0 1.5rem;
}

.site-wrapper {
    display:        flex;
    flex-direction: column;
    min-height:     100vh;
}

.site-main {
    flex: 1;
    padding: 3rem 0;
}

.content-area {
    display: grid;
    grid-template-columns: 1fr 300px;
    gap: 2.5rem;
    align-items: start;
}
.content-area.no-sidebar { grid-template-columns: 1fr; }
.content-area.sidebar-left { grid-template-columns: 300px 1fr; }

@media (max-width: 900px) {
    .content-area,
    .content-area.sidebar-left { grid-template-columns: 1fr; }
}

/* ============================================================
   HEADER
   ============================================================ */
.site-header {
    background-color: var(--color-header-bg);
    color:            var(--color-header-text);
    position:         sticky;
    top:              0;
    z-index:          1000;
    box-shadow:       var(--shadow-md);
    transition:       background-color var(--transition);
}

.header-inner {
    display:         flex;
    align-items:     center;
    justify-content: space-between;
    gap:             1.5rem;
    height:          var(--header-height);
}

/* Logo */
.site-branding { display: flex; align-items: center; gap: .75rem; flex-shrink: 0; }
.site-branding a { display: flex; align-items: center; gap: .75rem; color: inherit; }
.custom-logo { height: 44px; width: auto; object-fit: contain; }

.site-title {
    font-family:   var(--font-heading);
    font-size:     1.4rem;
    font-weight:   700;
    color:         var(--color-header-text);
    line-height:   1;
    margin:        0;
}
.site-title a { color: inherit; }
.site-description { font-size: .75rem; opacity: .7; margin: 0; line-height: 1; }

/* Nav */
.main-navigation { display: flex; align-items: center; }
.main-navigation ul {
    display:     flex;
    align-items: center;
    gap:         .25rem;
    list-style:  none;
    padding:     0;
    margin:      0;
}
.main-navigation a {
    color:         var(--color-header-text);
    padding:       .5rem .85rem;
    border-radius: var(--radius);
    font-size:     .9rem;
    font-weight:   500;
    opacity:       .85;
    transition:    opacity var(--transition), background var(--transition);
    white-space:   nowrap;
}
.main-navigation a:hover,
.main-navigation .current-menu-item > a { opacity: 1; background: rgba(255,255,255,.12); }

/* Dropdown */
.main-navigation li { position: relative; }
.main-navigation .sub-menu {
    display:          none;
    position:         absolute;
    top:              100%;
    left:             0;
    min-width:        200px;
    background:       var(--color-header-bg);
    border-radius:    var(--radius-lg);
    box-shadow:       var(--shadow-lg);
    padding:          .5rem 0;
    z-index:          999;
    flex-direction:   column;
    gap:              0;
}
.main-navigation li:hover > .sub-menu { display: flex; }
.main-navigation .sub-menu a {
    display:       block;
    padding:       .6rem 1.2rem;
    border-radius: 0;
    font-size:     .875rem;
}

/* Header actions (search / cart) */
.header-actions { display: flex; align-items: center; gap: .5rem; }
.header-cart-link {
    position:      relative;
    color:         var(--color-header-text);
    display:       flex;
    align-items:   center;
    gap:           .35rem;
    padding:       .5rem .85rem;
    border-radius: var(--radius);
    font-size:     .9rem;
    font-weight:   500;
    opacity:       .85;
    transition:    opacity var(--transition), background var(--transition);
}
.header-cart-link:hover { opacity:1; background: rgba(255,255,255,.12); color: var(--color-header-text); }
.cart-count {
    background:    var(--color-primary);
    color:         #fff;
    border-radius: 999px;
    font-size:     .7rem;
    font-weight:   700;
    padding:       .1em .45em;
    min-width:     1.3em;
    text-align:    center;
    line-height:   1.4;
}

/* Hamburger */
.menu-toggle {
    display:          none;
    background:       transparent;
    border:           2px solid rgba(255,255,255,.4);
    border-radius:    var(--radius);
    color:            var(--color-header-text);
    cursor:           pointer;
    padding:          .4rem .6rem;
    font-size:        1.3rem;
    line-height:      1;
    transition:       border-color var(--transition);
}
.menu-toggle:hover { border-color: rgba(255,255,255,.8); }

@media (max-width: 768px) {
    .menu-toggle { display: block; }
    .main-navigation {
        display:        none;
        position:       absolute;
        top:            var(--header-height);
        left:           0;
        right:          0;
        background:     var(--color-header-bg);
        box-shadow:     var(--shadow-lg);
        padding:        1rem 1.5rem 1.5rem;
    }
    .main-navigation.toggled { display: block; }
    .main-navigation ul { flex-direction: column; align-items: stretch; gap: 0; }
    .main-navigation a { display: block; }
    .main-navigation .sub-menu {
        position:  static;
        box-shadow: none;
        padding:    0 0 0 1rem;
        display:    flex !important;
    }
}

/* ============================================================
   HERO / PAGE HEADER
   ============================================================ */
.page-header {
    background:  linear-gradient(135deg, var(--color-header-bg) 0%, color-mix(in srgb, var(--color-header-bg) 70%, var(--color-primary)) 100%);
    color:       #fff;
    padding:     3.5rem 0;
    text-align:  center;
    margin-bottom: 0;
}
.page-header-title {
    font-size:   clamp(1.8rem, 5vw, 3rem);
    color:       #fff;
    margin:      0;
}
.page-header .breadcrumb { font-size: .85rem; opacity: .75; margin-top: .5rem; }
.page-header .breadcrumb a { color: #fff; }

/* ============================================================
   CARDS / POSTS
   ============================================================ */
.posts-grid {
    display:               grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap:                   1.75rem;
}

.post-card {
    background:    var(--color-card-bg);
    border-radius: var(--radius-lg);
    overflow:      hidden;
    box-shadow:    var(--shadow-sm);
    transition:    transform var(--transition), box-shadow var(--transition);
    display:       flex;
    flex-direction: column;
}
.post-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); }

.post-card-thumb img {
    width:        100%;
    height:       200px;
    object-fit:   cover;
    transition:   transform 0.4s ease;
}
.post-card:hover .post-card-thumb img { transform: scale(1.04); }
.post-card-thumb { overflow: hidden; }

.post-card-body { padding: 1.4rem; flex: 1; display: flex; flex-direction: column; }
.post-card-meta { font-size: .8rem; color: var(--color-muted); margin-bottom: .6rem; }
.post-card-title { font-size: 1.15rem; margin-bottom: .6rem; }
.post-card-title a { color: var(--color-body-text); }
.post-card-title a:hover { color: var(--color-primary); }
.post-card-excerpt { font-size: .9rem; color: var(--color-muted); flex: 1; }
.post-card-footer { padding: 0 1.4rem 1.4rem; }

/* ============================================================
   SINGLE POST / PAGE
   ============================================================ */
.entry-header { margin-bottom: 2rem; }
.entry-meta { font-size: .85rem; color: var(--color-muted); margin-bottom: 1rem; }
.entry-meta a { color: var(--color-muted); }
.entry-meta a:hover { color: var(--color-primary); }
.entry-thumbnail { border-radius: var(--radius-lg); overflow: hidden; margin-bottom: 2rem; }
.entry-thumbnail img { width: 100%; height: auto; }
.entry-content > * + * { margin-top: 1.2rem; }

/* Author box */
.author-box {
    display:       flex;
    gap:           1.25rem;
    background:    var(--color-card-bg);
    border-radius: var(--radius-lg);
    padding:       1.5rem;
    margin:        2.5rem 0;
    box-shadow:    var(--shadow-sm);
    align-items:   flex-start;
}
.author-box img { border-radius: 50%; width: 72px; height: 72px; object-fit: cover; flex-shrink: 0; }
.author-box-name { font-weight: 700; margin-bottom: .3rem; }

/* Post navigation */
.post-navigation {
    display:               grid;
    grid-template-columns: 1fr 1fr;
    gap:                   1rem;
    margin-top:            2.5rem;
}
.post-navigation a {
    background:    var(--color-card-bg);
    border-radius: var(--radius-lg);
    padding:       1rem 1.25rem;
    color:         var(--color-body-text);
    box-shadow:    var(--shadow-sm);
    transition:    box-shadow var(--transition), transform var(--transition);
    display:       block;
}
.post-navigation a:hover { box-shadow: var(--shadow-md); transform: translateY(-2px); }
.post-navigation .nav-prev { text-align: left; }
.post-navigation .nav-next { text-align: right; }
.post-navigation .nav-label { font-size: .75rem; color: var(--color-muted); display: block; margin-bottom: .3rem; }
.post-navigation .nav-title { font-weight: 600; font-size: .95rem; }

/* ============================================================
   SIDEBAR / WIDGETS
   ============================================================ */
.widget-area { display: flex; flex-direction: column; gap: 1.75rem; }

.widget {
    background:    var(--color-card-bg);
    border-radius: var(--radius-lg);
    padding:       1.5rem;
    box-shadow:    var(--shadow-sm);
}
.widget-title {
    font-size:     1rem;
    font-weight:   700;
    text-transform: uppercase;
    letter-spacing: .08em;
    color:         var(--color-muted);
    margin-bottom: 1rem;
    padding-bottom: .65rem;
    border-bottom: 2px solid var(--color-border);
}
.widget ul { padding: 0; list-style: none; }
.widget ul li { padding: .4rem 0; border-bottom: 1px solid var(--color-border); font-size: .9rem; }
.widget ul li:last-child { border-bottom: none; }
.widget_search .search-form { display: flex; gap: .5rem; }
.widget_search input[type="search"] {
    flex: 1; padding: .55rem .85rem;
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    font-size: .9rem;
    background: var(--color-body-bg);
    color: var(--color-body-text);
}
.widget_search button { padding: .55rem 1rem; }

/* ============================================================
   FORMS & INPUTS
   ============================================================ */
input[type="text"],
input[type="email"],
input[type="url"],
input[type="password"],
input[type="number"],
input[type="tel"],
input[type="search"],
input[type="date"],
select,
textarea {
    width:         100%;
    padding:       .6rem .9rem;
    border:        1.5px solid var(--color-border);
    border-radius: var(--radius);
    background:    var(--color-card-bg);
    color:         var(--color-body-text);
    font-family:   var(--font-body);
    font-size:     .95rem;
    transition:    border-color var(--transition), box-shadow var(--transition);
    appearance:    none;
}
input:focus, select:focus, textarea:focus {
    outline:      none;
    border-color: var(--color-primary);
    box-shadow:   0 0 0 3px color-mix(in srgb, var(--color-primary) 20%, transparent);
}
textarea { min-height: 120px; resize: vertical; }
label { font-weight: 600; font-size: .9rem; display: block; margin-bottom: .4rem; }
.form-group { margin-bottom: 1.25rem; }

/* ============================================================
   BUTTONS
   ============================================================ */
.btn,
button,
input[type="submit"],
input[type="button"],
input[type="reset"],
.button {
    display:       inline-flex;
    align-items:   center;
    justify-content: center;
    gap:           .4rem;
    padding:       .65rem 1.5rem;
    background:    var(--color-primary);
    color:         var(--color-btn-text) !important;
    border:        none;
    border-radius: var(--radius);
    font-family:   var(--font-body);
    font-size:     .95rem;
    font-weight:   600;
    cursor:        pointer;
    transition:    background var(--transition), transform var(--transition), box-shadow var(--transition);
    line-height:   1.3;
    text-decoration: none;
    white-space:   nowrap;
}
.btn:hover,
button:hover,
input[type="submit"]:hover,
.button:hover {
    background:  var(--color-primary-hover);
    transform:   translateY(-1px);
    box-shadow:  var(--shadow-sm);
    color:       var(--color-btn-text) !important;
}
.btn:active { transform: translateY(0); }

.btn-outline {
    background:  transparent;
    border:      2px solid var(--color-primary);
    color:       var(--color-primary) !important;
}
.btn-outline:hover {
    background:  var(--color-primary);
    color:       var(--color-btn-text) !important;
}
.btn-secondary {
    background: var(--color-secondary);
}
.btn-secondary:hover { background: color-mix(in srgb, var(--color-secondary) 80%, #000); }

.btn-lg { padding: .85rem 2.2rem; font-size: 1.05rem; }
.btn-sm { padding: .4rem 1rem; font-size: .85rem; }

/* ============================================================
   PAGINATION
   ============================================================ */
.pagination {
    display:     flex;
    gap:         .4rem;
    justify-content: center;
    flex-wrap:   wrap;
    margin-top:  2.5rem;
}
.pagination .page-numbers {
    display:       flex;
    align-items:   center;
    justify-content: center;
    width:         40px;
    height:        40px;
    border-radius: var(--radius);
    background:    var(--color-card-bg);
    color:         var(--color-body-text);
    font-weight:   600;
    font-size:     .9rem;
    border:        1.5px solid var(--color-border);
    transition:    all var(--transition);
}
.pagination .page-numbers:hover { border-color: var(--color-primary); color: var(--color-primary); }
.pagination .current { background: var(--color-primary); color: #fff; border-color: var(--color-primary); }

/* ============================================================
   COMMENTS
   ============================================================ */
.comments-area { margin-top: 3rem; }
.comments-title { margin-bottom: 1.5rem; }
.comment-list { list-style: none; padding: 0; }
.comment-body {
    background:    var(--color-card-bg);
    border-radius: var(--radius-lg);
    padding:       1.25rem;
    margin-bottom: 1rem;
    box-shadow:    var(--shadow-sm);
}
.comment-author img { border-radius: 50%; width: 44px; height: 44px; float: left; margin-right: .85rem; }
.comment-meta { font-size: .8rem; color: var(--color-muted); margin-bottom: .5rem; }
.children { padding-left: 2rem; list-style: none; }
.comment-respond { margin-top: 2.5rem; }
.comment-form > p { margin-bottom: 1rem; }

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer {
    background-color: var(--color-footer-bg);
    color:            var(--color-footer-text);
    padding:          3rem 0 1.5rem;
    box-shadow:       0 -4px 16px rgba(0,0,0,.12);
    transition:       background-color var(--transition), color var(--transition);
}

.footer-widgets {
    display:               grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap:                   2rem;
    margin-bottom:         2.5rem;
}
.footer-widget-title {
    font-size:      .875rem;
    font-weight:    700;
    text-transform: uppercase;
    letter-spacing: .1em;
    color:          var(--color-footer-text);
    opacity:        .55;
    margin-bottom:  .9rem;
}
.footer-widget p,
.footer-widget li { font-size: .875rem; line-height: 1.6; }
.footer-widget ul { list-style: none; padding: 0; }
.footer-widget ul li { padding: .3rem 0; }
.footer-widget a { color: var(--color-footer-text); opacity: .75; }
.footer-widget a:hover { opacity: 1; }

.footer-bottom {
    display:         flex;
    align-items:     center;
    justify-content: space-between;
    padding-top:     1.5rem;
    border-top:      1px solid rgba(255,255,255,.1);
    font-size:       .825rem;
    opacity:         .65;
    flex-wrap:       wrap;
    gap:             .75rem;
}
.footer-bottom-right { display: flex; align-items: center; gap: 1.25rem; }
.footer-nav ul { display: flex; gap: 1rem; list-style: none; padding: 0; }
.footer-nav a { color: var(--color-footer-text); }
.footer-nav a:hover { opacity: 1; }

.footer-social { display: flex; align-items: center; gap: .6rem; }
.footer-social-link {
    display:         flex;
    align-items:     center;
    justify-content: center;
    width:           2rem;
    height:          2rem;
    border-radius:   50%;
    color:           var(--color-footer-text);
    opacity:         .75;
    transition:      opacity var(--transition), background var(--transition);
}
.footer-social-link:hover {
    opacity:    1;
    background: rgba(255,255,255,.12);
    color:      var(--color-footer-text);
}
.footer-social-link svg { width: 1.1rem; height: 1.1rem; fill: currentColor; display: block; }

@media (max-width: 600px) {
    .footer-bottom { flex-direction: column; text-align: center; }
    .footer-bottom-right { justify-content: center; }
}

/* ============================================================
   NOTICES / ALERTS
   ============================================================ */
.notice, .alert {
    padding:       1rem 1.25rem;
    border-radius: var(--radius);
    margin-bottom: 1.25rem;
    border-left:   4px solid currentColor;
    font-size:     .925rem;
}
.notice-success { background: #ecfdf5; color: #166534; }
.notice-error   { background: #fef2f2; color: #991b1b; }
.notice-warning { background: #fffbeb; color: #92400e; }
.notice-info    { background: #eff6ff; color: #1e40af; }

/* ============================================================
   SKIP LINK (ACCESSIBILITY)
   ============================================================ */
.skip-link {
    position:   absolute;
    top:        -100px;
    left:       1rem;
    background: var(--color-primary);
    color:      #fff;
    padding:    .5rem 1rem;
    border-radius: 0 0 var(--radius) var(--radius);
    z-index:    9999;
    font-weight: 600;
}
.skip-link:focus { top: 0; color: #fff; }

/* ============================================================
   WOOCOMMERCE — Core
   ============================================================ */
.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
    border-radius: var(--radius-lg) !important;
    padding:       1rem 1.25rem !important;
    font-size:     .925rem;
    margin-bottom: 1.5rem !important;
    list-style:    none !important;
}
.woocommerce-message { background: #ecfdf5; border-top-color: #166534 !important; color: #166534; }
.woocommerce-info    { background: #eff6ff; border-top-color: #1e40af !important; color: #1e40af; }
.woocommerce-error   { background: #fef2f2; border-top-color: #991b1b !important; color: #991b1b; }

/* ── WooCommerce global button text colour ──────────────────────────────────
   WooCommerce's own woocommerce.css hardcodes color:#fff on a.button and
   input[type=submit]. We need a wide net of selectors with !important to
   ensure var(--color-btn-text) wins everywhere — product loops, shortcodes,
   blocks, cart, checkout, single product, and my-account pages.
   ─────────────────────────────────────────────────────────────────────────── */
.woocommerce a.button,
.woocommerce a.button:visited,
.woocommerce a.button:link,
.woocommerce button.button,
.woocommerce input[type="submit"],
.woocommerce input[type="button"],
.woocommerce #respond input#submit,
.woocommerce-page a.button,
.woocommerce-page a.button:visited,
.woocommerce-page button.button,
.woocommerce-page input[type="submit"],
.woocommerce-page #respond input#submit,
.wc-block-components-button,
.wp-block-woocommerce-proceed-to-checkout-block a,
.wc-block-cart__submit-button,
.wc-block-components-checkout-place-order-button,
.wc-block-grid__product-add-to-cart a.button,
.wc-block-grid__product-add-to-cart a.button:visited,
.wc-block-grid__product-add-to-cart a.button:link,
.wp-block-woocommerce-all-products .wc-block-grid__product-add-to-cart a,
.wp-block-woocommerce-handpicked-products .wc-block-grid__product-add-to-cart a,
.wp-block-woocommerce-product-new .wc-block-grid__product-add-to-cart a,
.wp-block-woocommerce-product-best-sellers .wc-block-grid__product-add-to-cart a,
.wp-block-woocommerce-product-top-rated .wc-block-grid__product-add-to-cart a,
.wp-block-woocommerce-products-by-attribute .wc-block-grid__product-add-to-cart a,
.wc-block-grid a.button,
.wc-block-grid a.button:visited,
.wc-block-grid a.button:link {
    color: var(--color-btn-text) !important;
}

.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input[type="submit"]:hover,
.woocommerce #respond input#submit:hover,
.woocommerce-page a.button:hover,
.woocommerce-page button.button:hover,
.woocommerce-page input[type="submit"]:hover,
.wc-block-grid a.button:hover,
.wc-block-grid__product-add-to-cart a.button:hover,
.woocommerce-page #respond input#submit:hover {
    color: var(--color-btn-text) !important;
}

/* Shop grid — fully override WooCommerce's float + percentage-width column system.
   WooCommerce adds .columns-N to ul.products based on the Customizer setting.
   We honour that class for the column count but use CSS grid instead of floats. */
.woocommerce ul.products,
.woocommerce-page ul.products {
    display:               grid !important;
    grid-template-columns: repeat(3, 1fr) !important; /* default fallback */
    gap:                   1.5rem !important;
    list-style:            none !important;
    padding:               0 !important;
    margin:                0 !important;
    float:                 none !important;
    clear:                 both !important;
}

/* Honour the columns-N class that WooCommerce outputs from the Customizer */
.woocommerce ul.products.columns-1, .woocommerce-page ul.products.columns-1 { grid-template-columns: repeat(1, 1fr) !important; }
.woocommerce ul.products.columns-2, .woocommerce-page ul.products.columns-2 { grid-template-columns: repeat(2, 1fr) !important; }
.woocommerce ul.products.columns-3, .woocommerce-page ul.products.columns-3 { grid-template-columns: repeat(3, 1fr) !important; }
.woocommerce ul.products.columns-4, .woocommerce-page ul.products.columns-4 { grid-template-columns: repeat(4, 1fr) !important; }
.woocommerce ul.products.columns-5, .woocommerce-page ul.products.columns-5 { grid-template-columns: repeat(5, 1fr) !important; }
.woocommerce ul.products.columns-6, .woocommerce-page ul.products.columns-6 { grid-template-columns: repeat(6, 1fr) !important; }

@media (max-width: 900px) {
    .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;
    }
}
@media (max-width: 480px) {
    .woocommerce ul.products,
    .woocommerce ul.products[class*="columns-"],
    .woocommerce-page ul.products,
    .woocommerce-page ul.products[class*="columns-"] {
        grid-template-columns: 1fr !important;
    }
}

/* Kill the floats WooCommerce puts on individual product items */
.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product {
    background:     var(--color-card-bg) !important;
    border-radius:  var(--radius-lg) !important;
    overflow:       hidden !important;
    box-shadow:     var(--shadow-sm);
    transition:     transform var(--transition), box-shadow var(--transition);
    display:        flex !important;
    flex-direction: column !important;
    padding:        0 !important;
    margin:         0 !important;
    float:          none !important;
    width:          auto !important;
    clear:          none !important;
}
.woocommerce ul.products li.product:hover,
.woocommerce-page ul.products li.product:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-md);
}

/* Clear WooCommerce float pseudo-elements.
   IMPORTANT: ::before must also be cleared — woocommerce-layout.css sets
   content:" " display:table on BOTH ::before and ::after as a clearfix.
   When the parent is display:grid, ::before becomes a real first grid cell
   and pushes every product one column to the right. */
.woocommerce ul.products::before,
.woocommerce ul.products::after,
.woocommerce-page ul.products::before,
.woocommerce-page ul.products::after { display: none !important; }

/* Kill clear on .first / .last */
.woocommerce ul.products li.product.first,
.woocommerce ul.products li.product.last,
.woocommerce-page ul.products li.product.first,
.woocommerce-page ul.products li.product.last {
    clear: none !important;
    margin: 0 !important;
}

/* ── THE INDENT FIX ─────────────────────────────────────────────────────────
   li.product-category items ALSO carry the .product class in WooCommerce,
   so li:not(.product) misses them entirely. Target them explicitly.
   These render as invisible placeholders that consume a full grid slot
   and push every real product one column to the right. */
.woocommerce ul.products li.product-category,
.woocommerce-page ul.products li.product-category,
.woocommerce ul.products li.product:empty,
.woocommerce-page ul.products li.product:empty {
    display: none !important;
}

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

/* Product image — aspect-ratio container prevents squishing regardless of
   whatever width/height attributes WooCommerce outputs on the <img> tag */
.woocommerce ul.products li.product .woocommerce-loop-product__link {
    display:      block;
    overflow:     hidden;
}

.woocommerce ul.products li.product .woocommerce-loop-product__link .woocommerce-loop-product__link-image-wrapper,
.woocommerce ul.products li.product .woocommerce-loop-product__link > a:first-child,
.woocommerce ul.products li.product a.woocommerce-loop-product__link {
    display: block;
}

/* Wrap the image in a fixed aspect-ratio box */
.woocommerce ul.products li.product .woocommerce-loop-product__link img,
.woocommerce-page ul.products li.product .woocommerce-loop-product__link img {
    display:       block !important;
    width:         100% !important;
    height:        auto !important;
    aspect-ratio:  1 / 1;
    object-fit:    cover !important;
    object-position: center !important;
    border-radius: var(--radius-lg) var(--radius-lg) 0 0;
    transition:    transform 0.4s ease;
}
.woocommerce ul.products li.product:hover img { transform: scale(1.04); }

/* Product title & price */
.woocommerce ul.products li.product .woocommerce-loop-product__title {
    font-family: var(--font-heading) !important;
    font-size:   1.05rem !important;
    padding:     1rem 1rem .3rem !important;
    color:       var(--color-body-text) !important;
    margin:      0 !important;
}
.woocommerce ul.products li.product .price {
    padding:      0 1rem .5rem !important;
    font-weight:  700 !important;
    color:        var(--color-primary) !important;
    font-size:    1.1rem !important;
}
.woocommerce ul.products li.product .price del { color: var(--color-muted) !important; font-weight: 400 !important; font-size: .9em; }

/* Add to cart loop button */
.woocommerce ul.products li.product .button,
.woocommerce ul.products li.product .added_to_cart {
    margin:        .5rem 1rem 1rem !important;
    display:       block !important;
    text-align:    center;
    border-radius: var(--radius) !important;
    background:    var(--color-primary) !important;
    color:         var(--color-btn-text) !important;
    padding:       .6rem 1rem !important;
    font-weight:   600 !important;
    font-size:     .9rem !important;
    transition:    background var(--transition), transform var(--transition) !important;
}
.woocommerce ul.products li.product .button:hover { background: var(--color-primary-hover) !important; transform: translateY(-1px); }

/* Sale badge */
.woocommerce ul.products li.product .onsale,
.woocommerce span.onsale {
    background:    var(--color-primary) !important;
    border-radius: var(--radius) !important;
    font-size:     .75rem !important;
    font-weight:   700 !important;
    padding:       .25em .65em !important;
    top:           .75rem !important;
    left:          .75rem !important;
    min-width:     auto !important;
    min-height:    auto !important;
    line-height:   1.5 !important;
}

/* ── Single product layout ───────────────────────────────────────────────────
   The gallery and summary sit in a 2-column grid.
   The tabs (.woocommerce-tabs) is a sibling of both — span it full width. */
.woocommerce div.product {
    display:               grid;
    grid-template-columns: 1fr 1fr;
    gap:                   3rem;
    align-items:           start;
}
/* Tabs and related sections below the two columns span full width */
.woocommerce div.product .woocommerce-tabs,
.woocommerce div.product #reviews,
.woocommerce div.product .related,
.woocommerce div.product .up-sells {
    grid-column: 1 / -1;
}
@media (max-width: 768px) { .woocommerce div.product { grid-template-columns: 1fr; } }

.woocommerce div.product .woocommerce-product-gallery { border-radius: var(--radius-lg); overflow: hidden; }
.woocommerce div.product div.summary { padding-top: .5rem; }

.woocommerce div.product .product_title {
    font-family:   var(--font-heading) !important;
    font-size:     clamp(1.6rem, 3vw, 2.2rem) !important;
    color:         var(--color-body-text) !important;
    margin-bottom: .5rem !important;
}

/* Short description — sits directly under the title */
.woocommerce div.product .woocommerce-product-details__short-description {
    color:         var(--color-muted);
    font-size:     .975rem;
    line-height:   1.7;
    margin-bottom: 1.25rem;
    padding-bottom: 1.25rem;
    border-bottom: 1px solid var(--color-border);
}
.woocommerce div.product .woocommerce-product-details__short-description p:last-child { margin-bottom: 0; }

.woocommerce div.product p.price,
.woocommerce div.product span.price {
    color:       var(--color-primary) !important;
    font-size:   1.8rem !important;
    font-weight: 700 !important;
    margin:      .75rem 0 !important;
}
.woocommerce div.product .woocommerce-product-rating { margin-bottom: 1rem !important; }

.woocommerce #review_form #respond { padding: 0; }
.woocommerce div.product form.cart { margin-top: 1.5rem !important; }
.woocommerce div.product form.cart .qty {
    width:         80px;
    border-radius: var(--radius);
    border:        1.5px solid var(--color-border);
    padding:       .55rem;
    font-size:     1rem;
}
.woocommerce div.product form.cart .single_add_to_cart_button {
    background:    var(--color-primary) !important;
    border:        none !important;
    border-radius: var(--radius) !important;
    padding:       .75rem 2rem !important;
    font-size:     1rem !important;
    font-weight:   700 !important;
}
.woocommerce div.product form.cart .single_add_to_cart_button:hover { background: var(--color-primary-hover) !important; }

/* Full description in the Description tab */
.woocommerce-product-details__description { padding: .5rem 0; }
.woocommerce-product-details__description h2 {
    font-size:     1.3rem;
    margin-bottom: 1rem;
    padding-bottom: .65rem;
    border-bottom: 2px solid var(--color-border);
}
.woocommerce-product-details__description > * + * { margin-top: 1rem; }

/* Tabs */
.woocommerce div.product .woocommerce-tabs { margin-top: 3rem !important; }
.woocommerce div.product .woocommerce-tabs ul.tabs {
    display:       flex;
    gap:           .25rem;
    border-bottom: 2px solid var(--color-border) !important;
    padding:       0 !important;
    list-style:    none !important;
    margin:        0 0 1.5rem !important;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li {
    margin:        0 !important;
    border:        none !important;
    background:    transparent !important;
    border-radius: var(--radius) var(--radius) 0 0 !important;
    padding:       0 !important;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li a {
    padding:     .6rem 1.2rem !important;
    font-weight: 600 !important;
    font-size:   .9rem !important;
    color:       var(--color-muted) !important;
    display:     block;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a { color: var(--color-primary) !important; }
.woocommerce div.product .woocommerce-tabs ul.tabs li.active { border-bottom: 2px solid var(--color-primary) !important; margin-bottom: -2px !important; }

/* ============================================================
   WOOCOMMERCE — Cart & Checkout
   ============================================================ */
.woocommerce table.shop_table {
    border-radius: var(--radius-lg);
    overflow:      hidden;
    border:        none !important;
    box-shadow:    var(--shadow-sm);
}
.woocommerce table.shop_table th {
    background: color-mix(in srgb, var(--color-header-bg) 8%, transparent) !important;
    border:     none !important;
    padding:    .85rem 1rem !important;
    font-size:  .85rem;
    text-transform: uppercase;
    letter-spacing: .07em;
}
.woocommerce table.shop_table td { border: none !important; padding: .85rem 1rem !important; border-top: 1px solid var(--color-border) !important; }
.woocommerce table.shop_table .product-name a { font-weight: 600; color: var(--color-body-text); }

.woocommerce #payment { background: var(--color-card-bg) !important; border-radius: var(--radius-lg) !important; }
.woocommerce #payment div.payment_box { background: rgba(0,0,0,.03) !important; border-radius: var(--radius) !important; }

.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea {
    border-radius: var(--radius) !important;
    border:        1.5px solid var(--color-border) !important;
    padding:       .6rem .9rem !important;
}
.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row textarea:focus {
    border-color: var(--color-primary) !important;
    box-shadow:   0 0 0 3px color-mix(in srgb, var(--color-primary) 20%, transparent) !important;
    outline:      none !important;
}

/* Order button */
#place_order,
.woocommerce-checkout #place_order {
    background:    var(--color-primary) !important;
    border-radius: var(--radius) !important;
    font-size:     1.05rem !important;
    font-weight:   700 !important;
    padding:       .85rem 2rem !important;
    width:         100%;
}
#place_order:hover { background: var(--color-primary-hover) !important; }

/* Cart totals */
.woocommerce .cart-collaterals .cart_totals,
.woocommerce-page .cart-collaterals .cart_totals {
    background:    var(--color-card-bg);
    border-radius: var(--radius-lg);
    padding:       1.5rem !important;
    box-shadow:    var(--shadow-sm);
}
.woocommerce a.checkout-button,
.woocommerce .wc-proceed-to-checkout a.checkout-button {
    background:    var(--color-primary) !important;
    border-radius: var(--radius) !important;
    font-weight:   700 !important;
    padding:       .8rem !important;
    font-size:     1rem !important;
}

/* Coupon */
.woocommerce .coupon input[type="text"] { border-radius: var(--radius) 0 0 var(--radius) !important; }
.woocommerce .coupon button { border-radius: 0 var(--radius) var(--radius) 0 !important; }

/* My Account */
.woocommerce-account .woocommerce-MyAccount-navigation ul {
    list-style: none;
    padding: 0;
    background: var(--color-card-bg);
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow: var(--shadow-sm);
}
.woocommerce-account .woocommerce-MyAccount-navigation ul li a {
    display: block;
    padding: .75rem 1.25rem;
    color: var(--color-body-text);
    border-bottom: 1px solid var(--color-border);
    font-weight: 500;
    transition: background var(--transition), color var(--transition);
}
.woocommerce-account .woocommerce-MyAccount-navigation ul li:last-child a { border-bottom: none; }
.woocommerce-account .woocommerce-MyAccount-navigation ul li a:hover,
.woocommerce-account .woocommerce-MyAccount-navigation ul li.is-active a { background: var(--color-primary); color: #fff; }

/* Star ratings */
.woocommerce .star-rating span { color: var(--color-accent) !important; }
.woocommerce .star-rating::before { color: var(--color-border) !important; }

/* ============================================================
   WOOCOMMERCE — Widgets
   ============================================================ */
.widget_price_filter .ui-slider-range { background: var(--color-primary) !important; }
.widget_price_filter .ui-slider-handle { border-color: var(--color-primary) !important; }
.widget_price_filter .price_slider_amount button { font-size: .85rem; }
.woocommerce .widget_layered_nav ul li.chosen a { font-weight: 700; color: var(--color-primary); }

/* ============================================================
   WP BLOCK EDITOR (Gutenberg) compatibility
   ============================================================ */
.wp-block-image img   { border-radius: var(--radius-lg); }
.wp-block-quote       { border-left: 4px solid var(--color-primary); padding: 1rem 1.5rem; font-style: italic; }
.wp-block-button__link {
    background:    var(--color-primary) !important;
    border-radius: var(--radius) !important;
    font-weight:   600 !important;
}
.wp-block-separator { border-color: var(--color-border) !important; }
.wp-block-pullquote  { border-color: var(--color-primary) !important; }

/* ============================================================
   UTILITIES
   ============================================================ */
.sr-only { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; }
.text-center { text-align: center; }
.text-muted  { color: var(--color-muted); }
.mt-1 { margin-top: .5rem; }
.mt-2 { margin-top: 1rem; }
.mt-3 { margin-top: 1.5rem; }
.mb-1 { margin-bottom: .5rem; }
.mb-2 { margin-bottom: 1rem; }
.mb-3 { margin-bottom: 1.5rem; }
