/* =============================================================
   UGLOW Single Product Page — 2026 Redesign
   Loaded on is_product() pages only (via header.php)
   ============================================================= */
body .ugs-wrapper main#ugs-main {
    padding-top: 100px;
}
/* ── Variables ──────────────────────────────────────────────── */
.usp-page-wrap {
    --usp-black:   #111111;
    --usp-blue:    #0E8FCC;
    --usp-muted:   #666666;
    --usp-border:  #dcdcdc;
    --usp-soft:    #f5f5f5;
    --usp-red:     #d8332a;
    --usp-radius:  4px;
    --usp-font:    "Lato", sans-serif;
}

/* ── Page container ─────────────────────────────────────────── */
.usp-page-wrap {
    font-family: var(--usp-font);
    color: var(--usp-black);
    max-width: 1280px;
    margin: 0 auto;
    padding: 0 24px 60px;
    box-sizing: border-box;
}
.usp-page-wrap *,
.usp-page-wrap *::before,
.usp-page-wrap *::after { box-sizing: border-box; }

/* ── Two-column layout ──────────────────────────────────────── */
.usp-layout {
    display: grid;
    grid-template-columns: 40fr 60fr;
    gap: 56px;
    align-items: start;
    padding-top: 20px;
}

/* Ensure summary column stacks vertically — prevent inherited flex row */
.usp-col-summary {
    display: block !important;
}
/* Gallery column: sticky as a whole so intro moves with it */
.usp-col-gallery {
    display: block !important;
    min-width: 0;
    position: sticky;
    top: 80px;
    align-self: start;
}

/* ── Breadcrumb (matches ugc-breadcrumb from category listing) ── */
.usp-breadcrumb {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 5px;
    font-size: 11px;
    color: var(--usp-muted);
    letter-spacing: .08em;
    text-transform: uppercase;
    margin: 0 0 14px;
    font-family: var(--usp-font);
}
.usp-breadcrumb a {
    color: var(--usp-muted);
    text-decoration: none;
    transition: color .15s;
}
nav.usp-breadcrumb a:hover {
    color: #00a3db !important;
}
.usp-crumb-sep { opacity: .4; font-size: 13px; }
.usp-crumb-current { color: var(--usp-black); font-weight: 600; }

/* ── Product title ──────────────────────────────────────────── */
.usp-title {
    font-size: 25px;
    font-weight: 700;
    line-height: 1.2;
    margin: 0 0 8px;
    letter-spacing: -.01em;
    display: block !important;
    float: none !important;
    width: 100% !important;
    clear: both !important;
}

/* ── Specs subtitle (legacy — kept for old markup) ──────────── */
.usp-specs-subtitle {
    font-size: 13px;
    color: var(--usp-muted);
    margin: 0 0 14px;
    letter-spacing: .02em;
}

/* ── Gallery intro: product_intro big headline below images ─── */
.usp-gallery-intro {
    margin-top: 22px;
    padding-top: 22px;
    border-top: 1px solid var(--usp-border);
    clear: both;
    display: block;
    position: relative;
    z-index: 1;
}
.usp-gallery-intro p {
    font-size: 22px;
    font-weight: 700;
    line-height: 1.45;
    color: var(--usp-black);
    margin: 0;
    letter-spacing: -.02em;
}

/* ── Weight + tag badges under title ────────────────────────── */
.usp-meta-row {
    display: flex !important;
    align-items: center !important;
    flex-wrap: wrap !important;
    gap: 6px !important;
    margin: 14px 0 12px !important;
    float: none !important;
    width: auto !important;
}
.usp-weight-badge,
.usp-tag-badge {
    display: inline-block !important;
    font-size: 11px !important;
    font-weight: 600 !important;
    letter-spacing: .06em !important;
    text-transform: uppercase !important;
    padding: 3px 10px !important;
    border-radius: 20px !important;
    border: 1px solid var(--usp-border) !important;
    line-height: 1.5 !important;
    white-space: nowrap !important;
    float: none !important;
    width: auto !important;
    max-width: none !important;
    background-image: none !important;
    box-shadow: none !important;
}
.usp-weight-badge {
    background: #fff !important;
    color: var(--usp-black) !important;
}
.usp-tag-badge {
    background: #fff !important;
    color: var(--usp-muted) !important;
}

/* ── Star rating row ─────────────────────────────────────────── */
.usp-rating-row {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
    margin-bottom: 16px;
    margin-top: 20px;
}
.usp-rating-wrap {
    display: flex;
    align-items: center;
    gap: 6px;
    cursor: pointer;
    text-decoration: none;
    color: inherit;
    flex-shrink: 0;
}
.usp-rating-wrap:hover .usp-rating-count { text-decoration: underline; }

/* Write a Review button */
.usp-write-review-btn {
    display: inline-block;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: .06em;
    text-transform: uppercase;
    color: var(--usp-blue);
    text-decoration: underline;
    text-underline-offset: 3px;
    text-decoration-thickness: 1.5px;
    cursor: pointer;
    padding: 0;
    border: none;
    background: none;
    font-family: var(--usp-font);
    transition: color .15s;
}
.usp-write-review-btn:hover { color: var(--usp-black); }
.usp-stars {
    position: relative;
    display: inline-block;
    width: 80px;
    height: 15px;
    background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='80' height='15' viewBox='0 0 80 15'><g fill='%23ddd'><polygon points='7,1.5 9,6 13.5,6.5 10.5,9.5 11.5,14 7,11.5 2.5,14 3.5,9.5 0.5,6.5 5,6'/><polygon points='23,1.5 25,6 29.5,6.5 26.5,9.5 27.5,14 23,11.5 18.5,14 19.5,9.5 16.5,6.5 21,6'/><polygon points='40,1.5 42,6 46.5,6.5 43.5,9.5 44.5,14 40,11.5 35.5,14 36.5,9.5 33.5,6.5 38,6'/><polygon points='57,1.5 59,6 63.5,6.5 60.5,9.5 61.5,14 57,11.5 52.5,14 53.5,9.5 50.5,6.5 55,6'/><polygon points='73,1.5 75,6 79.5,6.5 76.5,9.5 77.5,14 73,11.5 68.5,14 69.5,9.5 66.5,6.5 71,6'/></g></svg>") no-repeat;
    background-size: 80px 15px;
    flex-shrink: 0;
}
.usp-stars-fg {
    position: absolute;
    top: 0; left: 0;
    height: 100%;
    background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='80' height='15' viewBox='0 0 80 15'><g fill='%23f1c945'><polygon points='7,1.5 9,6 13.5,6.5 10.5,9.5 11.5,14 7,11.5 2.5,14 3.5,9.5 0.5,6.5 5,6'/><polygon points='23,1.5 25,6 29.5,6.5 26.5,9.5 27.5,14 23,11.5 18.5,14 19.5,9.5 16.5,6.5 21,6'/><polygon points='40,1.5 42,6 46.5,6.5 43.5,9.5 44.5,14 40,11.5 35.5,14 36.5,9.5 33.5,6.5 38,6'/><polygon points='57,1.5 59,6 63.5,6.5 60.5,9.5 61.5,14 57,11.5 52.5,14 53.5,9.5 50.5,6.5 55,6'/><polygon points='73,1.5 75,6 79.5,6.5 76.5,9.5 77.5,14 73,11.5 68.5,14 69.5,9.5 66.5,6.5 71,6'/></g></svg>") no-repeat;
    background-size: 80px 15px;
    overflow: hidden;
}
.usp-rating-num { font-size: 13px; font-weight: 600; color: var(--usp-black); }
.usp-rating-sep { font-size: 13px; color: var(--usp-muted); }
.usp-rating-count { font-size: 13px; color: var(--usp-blue); }
.usp-rating-wrap:hover .usp-rating-count { text-decoration: underline; }

/* ── Price ──────────────────────────────────────────────────── */
.usp-price-wrap { margin-bottom: 20px; }
.usp-price-wrap .price {
    font-size: 26px;
    font-weight: 700;
    color: var(--usp-black);
}
.usp-price-wrap .price del { opacity: .5; font-size: 18px; font-weight: 400; margin-right: 6px; }
.usp-price-wrap .price ins { text-decoration: none; color: var(--usp-red); }

.usp-price-wrap span.woocommerce-Price-amount.amount {
    font-size: 35px;
    font-weight: 700;
    letter-spacing: 0px;
}

/* ── Color swatches ─────────────────────────────────────────── */
.usp-color-row {
    margin-bottom: 16px;
}
.usp-color-label {
    font-size: 13px;
    text-transform: uppercase;
    letter-spacing: .05em;
    margin-bottom: 10px;
}
.usp-color-label span { font-weight: 600; }
.usp-swatches { display: flex; gap: 10px; flex-wrap: wrap; }
.usp-swatch {
    width: 30px;
    height: 30px;
    border-radius: 50%;
    cursor: pointer;
    border: 2px solid transparent;
    box-shadow: 0 0 0 1px rgba(0,0,0,.15);
    transition: box-shadow .15s;
    position: relative;
}
.usp-swatch.active,
.usp-swatch:hover {
    box-shadow: 0 0 0 1px rgba(0,0,0,.15), 0 0 0 3px #fff, 0 0 0 5px var(--usp-black);
}

/* ── Size selector ──────────────────────────────────────────── */
.usp-size-row { margin-bottom: 8px; }
.usp-size-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 10px;
}
.usp-size-header-label {
    font-size: 13px;
    text-transform: uppercase;
    letter-spacing: .05em;
}
.usp-size-header-label .selected-size { font-weight: 700; }
.usp-size-guide-link {
    font-size: 12px;
    color: var(--usp-blue);
    text-decoration: underline;
    text-decoration-style: dashed;
    text-underline-offset: 3px;
}
.usp-size-guide-link:hover { color: var(--usp-black); }

.usp-size-btns {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    margin-bottom: 10px;
}
.usp-size-btn {
    min-width: 52px;
    height: 48px;
    padding: 0 12px;
    border: 1.5px solid #dcdcdc !important;
    background: #fff;
    font-size: 13px;
    font-weight: 700;
    font-family: var(--usp-font);
    cursor: pointer;
    transition: border-color .12s, background .12s, color .12s;
    letter-spacing: .02em;
    text-transform: uppercase;
    border-radius: var(--usp-radius);
    position: relative;
}
.usp-size-btn:hover { border-color: var(--usp-black); }
.usp-size-btn.active {
    border-color: var(--usp-black);
    background: var(--usp-black);
    color: #fff;
}
.usp-size-btn.oos {
    color: #bbb;
    cursor: not-allowed;
    position: relative;
    overflow: hidden;
}
.usp-size-btn.oos::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 6px;
    right: 6px;
    height: 1px;
    background: #ccc;
    transform: rotate(-20deg);
}
.usp-size-btn.oos:hover { border-color: var(--usp-border); }

/* Hide native WC variation select (we use buttons above) */
.usp-page-wrap .variations,
.usp-page-wrap .woocommerce-variation-availability,
.usp-page-wrap .reset_variations { display: none !important; }

/* ── Low-stock signal ───────────────────────────────────────── */
.usp-low-stock {
    display: none;
    color: var(--usp-red);
    font-size: 13px;
    font-weight: 600;
    margin-bottom: 10px;
}
.usp-low-stock.is-visible { display: block; }

/* ── Short description (full-width, between layout and callouts) ── */
.usp-short-desc {
    margin-top: 48px;
    padding: 36px 40px;
    background: var(--usp-soft);
    border-radius: 8px;
    columns: 2;
    column-gap: 48px;
    font-size: 14px;
    line-height: 1.8;
    color: #444444;
}
.usp-short-desc p {
    margin: 0 0 14px;
    break-inside: avoid;
}
.usp-short-desc p:last-child { margin-bottom: 0; }
.usp-short-desc strong {
    display: block;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: .1em;
    text-transform: uppercase;
    color: var(--usp-black);
    margin-bottom: 6px;
}
/* If no <p> tags — treat direct text nodes with inline <strong> labels */
.usp-short-desc > strong {
    display: block;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: .1em;
    text-transform: uppercase;
    color: var(--usp-black);
    margin: 14px 0 4px;
}
.usp-short-desc > strong:first-child { margin-top: 0; }

/* ── Quantity control ───────────────────────────────────────── */
.usp-qty-wrap {
    display: flex;
    align-items: center;
    gap: 0;
    border: 1.5px solid #dcdcdc;
    border-color: #111111;
    border-radius: var(--usp-radius);
    overflow: hidden;
    width: fit-content;
    margin: 30px 0 30px;
}
.usp-qty-btn {
    width: 44px;
    height: 44px;
    background: #fff;
    border: none;
    cursor: pointer;
    font-size: 18px;
    font-weight: 400;
    color: var(--usp-black);
    line-height: 1;
    transition: background .12s;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
}
.usp-qty-btn:hover { background: var(--usp-soft); }
.usp-qty-input {
    width: 52px;
    height: 44px;
    text-align: center;
    border: none;
    border-left: 1.5px solid #dcdcdc;
    border-right: 1.5px solid #dcdcdc;
    font-size: 14px;
    font-weight: 700;
    font-family: var(--usp-font);
    color: var(--usp-black);
    background: #fff;
    -moz-appearance: textfield;
}
.usp-qty-input::-webkit-outer-spin-button,
.usp-qty-input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.usp-qty-input:focus { outline: none; }

/* Hide native WC quantity (replaced by our custom control above) */
.usp-page-wrap .quantity,
.usp-page-wrap .woocommerce-variation-add-to-cart .quantity { display: none !important; }

/* ── Add to Cart button ─────────────────────────────────────── */
.usp-atc-wrap { margin-bottom: 20px; }
/* Target every possible class WC/theme may assign */
.usp-page-wrap .single_add_to_cart_button,
.usp-page-wrap button.single_add_to_cart_button,
.usp-page-wrap .button.single_add_to_cart_button,
.usp-page-wrap input.single_add_to_cart_button,
.usp-page-wrap .wp-element-button.single_add_to_cart_button,
.usp-page-wrap .woocommerce-variation-add-to-cart .single_add_to_cart_button,
.usp-page-wrap form.cart .single_add_to_cart_button,
.usp-page-wrap .button.alt.single_add_to_cart_button,
.usp-page-wrap button.button.alt {
    display: block !important;
    width: 100% !important;
    padding: 16px 24px !important;
    background: #111111 !important;
    background-color: #111111 !important;
    color: #ffffff !important;
    border: 2px solid #111111 !important;
    font-size: 14px !important;
    font-weight: 700 !important;
    font-family: var(--usp-font) !important;
    letter-spacing: .06em !important;
    text-transform: uppercase !important;
    cursor: pointer !important;
    border-radius: var(--usp-radius) !important;
    transition: background .15s, border-color .15s !important;
    text-align: center !important;
    box-shadow: none !important;
    outline: none !important;
    line-height: 1.4 !important;
    vertical-align: top !important;
    -webkit-appearance: none !important;
}
.usp-page-wrap .single_add_to_cart_button:hover,
.usp-page-wrap button.single_add_to_cart_button:hover,
.usp-page-wrap .wp-element-button.single_add_to_cart_button:hover,
.usp-page-wrap button.button.alt:hover {
    background: #333333 !important;
    background-color: #333333 !important;
    border-color: #333333 !important;
    color: #ffffff !important;
}
.usp-page-wrap .single_add_to_cart_button:disabled,
.usp-page-wrap button.single_add_to_cart_button:disabled,
.usp-page-wrap button.button.alt:disabled,
.usp-page-wrap .wc-variation-selection-needed {
    background: #555555 !important;
    background-color: #555555 !important;
    border-color: #555555 !important;
    color: #cccccc !important;
    cursor: not-allowed !important;
    opacity: 1 !important;
}

/* ── Shipping perks ─────────────────────────────────────────── */
.usp-perks {
    display: flex;
    flex-direction: column;
    gap: 0;
    margin: 28px 0 25px;
}
.usp-perk {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 14px 0;
    font-size: 14px;
    color: var(--usp-muted);
    border-bottom: 1px solid var(--usp-border);
}
.usp-perk:first-child { border-top: 1px solid var(--usp-border); }
.usp-perk-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 20px;
    flex-shrink: 0;
    color: var(--usp-black);
}
.usp-perk-icon svg { display: block; }

/* ── Performance DNA heading ────────────────────────────────── */
.usp-dna-heading {
    font-size: 10px;
    font-weight: 700;
    letter-spacing: .18em;
    text-transform: uppercase;
    color: var(--usp-muted);
    margin: 0 0 16px;
    padding-bottom: 12px;
    border-bottom: 1px solid var(--usp-border);
}

/* ── Performance DNA (reuse existing sproduct styles with wrapper) ── */
.usp-dna-section {
    margin-top: 6px;
    margin-bottom: 0;
    padding-top: 20px;
}
.usp-dna-section h2.usp-dna-heading {
    font-size: 20px;
}
.usp-dna-section .weather-conditions-sec {
    margin-top: 48px;
}
.usp-dna-section .key-features-rating { margin-top: 0; }
.usp-dna-section .key-feature-block { margin-top: 20px; }
/* Remove any inherited border-top from weather inner wrapper */
.usp-dna-section .weather-conditions-inn,
.usp-dna-section .weather-conditions-sec {
    border-top: none !important;
    padding-top: 0 !important;
}

/* ── Feature callouts (full-width section after two-column block) ── */
.usp-callouts-section {
    margin-top: 48px;
    padding-top: 40px;
    border-top: 1px solid var(--usp-border);
}
.usp-callouts-heading {
    font-size: 22px;
    font-weight: 700;
    margin: 0 0 32px;
    letter-spacing: -.01em;
    padding-bottom: 16px;
    border-bottom: 1px solid var(--usp-border);
}
.usp-callouts-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 24px;
}
.usp-callout {
    padding: 20px;
    background: var(--usp-soft);
    border-radius: var(--usp-radius);
}
.usp-callout-headline {
    font-size: 14px;
    font-weight: 700;
    margin: 0 0 8px;
    letter-spacing: .01em;
}
.usp-callout-body {
    font-size: 13px;
    color: var(--usp-muted);
    margin: 0;
    line-height: 1.55;
}

/* ── Feature tags (pill badges) ─────────────────────────────── */
.usp-page-wrap .feature-tags { margin-bottom: 8px; margin-top: 0; }

/* ── Product info tiles (Key Features / Fabric & Care / About) ── */
.usp-info-tiles {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 2px;
    margin-top: 56px;
    background: var(--usp-border);
    border: 1px solid var(--usp-border);
    border-radius: 10px;
    overflow: hidden;
}
.usp-info-tile {
    background: #fff;
    padding: 32px 28px 28px;
    display: flex;
    flex-direction: column;
}
.usp-info-tile__icon {
    width: 52px;
    height: 52px;
    border-radius: 12px;
    background: var(--usp-soft);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--usp-blue);
    margin-bottom: 18px;
    flex-shrink: 0;
}
.usp-info-tile__heading {
    font-size: 13px;
    font-weight: 700;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: var(--usp-black);
    margin: 0 0 14px;
}
.usp-info-tile__body {
    font-size: 13.5px;
    line-height: 1.75;
    color: #444;
    flex: 1;
    overflow-y: auto;
    max-height: 280px;
    scrollbar-width: thin;
    scrollbar-color: #dcdcdc transparent;
}
.usp-info-tile__body::-webkit-scrollbar { width: 3px; }
.usp-info-tile__body::-webkit-scrollbar-thumb { background: #dcdcdc; border-radius: 2px; }
.usp-info-tile__body p { margin: 0 0 10px; }
.usp-info-tile__body p:last-child { margin-bottom: 0; }
.usp-info-tile__body ul,
.usp-info-tile__body ol { margin: 0 0 10px; padding-left: 18px; }
.usp-info-tile__body li { margin-bottom: 5px; }
.usp-info-tile__body strong { color: var(--usp-black); font-weight: 700; }

/* ── Review popup modal ──────────────────────────────────────── */
body.usp-modal-open { overflow: hidden; }

.usp-review-modal {
    position: fixed;
    inset: 0;
    z-index: 99999;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px;
}
.usp-review-modal[hidden] { display: none; }

.usp-review-modal__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(10,10,10,.6);
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
    cursor: pointer;
    animation: usp-fade-in .22s ease;
}

.usp-review-modal__dialog {
    position: relative;
    background: #fff;
    border-radius: 14px;
    width: 100%;
    max-width: 560px;
    max-height: 88vh;
    display: flex;
    flex-direction: column;
    box-shadow: 0 32px 80px rgba(0,0,0,.22);
    animation: usp-slide-up .26s cubic-bezier(.22,.61,.36,1);
    overflow: hidden;
    outline: none;
}

/* Header */
.usp-review-modal__header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
    padding: 24px 28px 20px;
    border-bottom: 1px solid var(--usp-border);
    flex-shrink: 0;
    background: #fff;
}
.usp-review-modal__title {
    font-size: 17px;
    font-weight: 700;
    margin: 0 0 3px;
    letter-spacing: -.01em;
    color: var(--usp-black);
}
.usp-review-modal__subtitle {
    font-size: 12px;
    color: var(--usp-muted);
    margin: 0;
    font-weight: 400;
}
.usp-review-modal__close {
    width: 32px;
    height: 32px;
    min-width: 32px;
    border: 1.5px solid var(--usp-border);
    border-radius: 50%;
    background: transparent;
    cursor: pointer;
    font-size: 18px;
    line-height: 1;
    color: var(--usp-muted);
    display: flex;
    align-items: center;
    justify-content: center;
    transition: border-color .15s, color .15s, background .15s;
    margin-top: 2px;
}
.usp-review-modal__close:hover {
    border-color: var(--usp-black);
    color: var(--usp-black);
    background: var(--usp-soft);
}

/* Scrollable body */
.usp-review-modal__body {
    overflow-y: auto;
    padding: 28px 28px 36px;
    flex: 1;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: thin;
    scrollbar-color: var(--usp-border) transparent;
}
.usp-review-modal__body::-webkit-scrollbar { width: 4px; }
.usp-review-modal__body::-webkit-scrollbar-thumb { background: var(--usp-border); border-radius: 2px; }

/* "Reviewing as" notice */
.usp-review-logged-as {
    font-size: 12.5px;
    color: var(--usp-muted);
    margin: 0 0 22px;
    padding: 10px 14px;
    background: var(--usp-soft);
    border-radius: 6px;
}
.usp-review-logged-as strong { color: var(--usp-black); }
.usp-review-logged-as a { color: var(--usp-blue); }

/* Blocked state */
.usp-review-blocked {
    text-align: center;
    padding: 20px 0 8px;
}
.usp-review-blocked__icon {
    color: var(--usp-muted);
    margin-bottom: 14px;
}
.usp-review-blocked p {
    font-size: 14px;
    color: var(--usp-muted);
    line-height: 1.6;
}
.usp-review-blocked a { color: var(--usp-blue); text-decoration: underline; }

/* Form rows */
.usp-review-form { margin: 0; }
.usp-form-row { margin-bottom: 20px; }
.usp-form-row:last-child { margin-bottom: 0; }
.usp-form-label {
    display: block;
    font-size: 10.5px;
    font-weight: 700;
    letter-spacing: .1em;
    text-transform: uppercase;
    color: var(--usp-muted);
    margin-bottom: 8px;
}
.usp-form-label .required { color: var(--usp-blue); margin-left: 2px; }
.usp-form-input,
.usp-form-textarea {
    width: 100%;
    border: 1.5px solid #dcdcdc;
    border-radius: 7px;
    padding: 11px 14px;
    font-size: 14px;
    font-family: var(--usp-font);
    color: var(--usp-black);
    background: #fff;
    transition: border-color .15s, box-shadow .15s;
    box-sizing: border-box;
    -webkit-appearance: none;
}
.usp-form-input:focus,
.usp-form-textarea:focus {
    border-color: var(--usp-blue);
    box-shadow: 0 0 0 3px rgba(14,143,204,.12);
    outline: none;
}
.usp-form-textarea { min-height: 110px; resize: vertical; line-height: 1.6; }
.usp-form-hint {
    display: block;
    font-size: 11px;
    color: var(--usp-muted);
    margin-top: 5px;
}
.usp-field-error {
    display: block;
    font-size: 11.5px;
    color: #c0392b;
    margin-top: 6px;
    font-weight: 600;
}

/* Star rating row */
.usp-form-row--rating { margin-bottom: 24px; }
.usp-star-select { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.usp-star-select__stars {
    display: flex;
    gap: 4px;
}
.usp-star-select__stars a {
    font-size: 28px;
    color: #dcdcdc !important;
    text-decoration: none !important;
    line-height: 1;
    transition: color .1s, transform .1s;
    cursor: pointer;
}
.usp-star-select__stars a.hovered,
.usp-star-select__stars a.selected {
    color: var(--usp-blue) !important;
    transform: scale(1.12);
}
.usp-star-select__label {
    font-size: 12px;
    color: var(--usp-muted);
    font-style: italic;
}
.usp-rating-select { display: none; } /* hidden — driven by star clicks */

/* Submit button */
.usp-form-row--submit { margin-top: 28px; }
.usp-review-submit {
    width: 100%;
    background: var(--usp-black);
    color: #fff;
    border: 2px solid var(--usp-black);
    border-radius: 7px;
    padding: 14px 24px;
    font-size: 13px;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
    cursor: pointer;
    font-family: var(--usp-font);
    transition: background .15s, color .15s;
}
.usp-review-submit:hover {
    background: transparent;
    color: var(--usp-black);
}

/* Login state ------------------------------------------------- */
.usp-login-prompt {
    padding: 4px 0 8px;
}
.usp-login-prompt__msg {
    font-size: 13.5px;
    color: var(--usp-muted);
    margin: 0 0 20px;
    line-height: 1.6;
    text-align: center;
}
.usp-login-prompt__msg strong { color: var(--usp-black); }
.usp-login-form-wrap {
    background: var(--usp-soft);
    border-radius: 10px;
    padding: 24px 20px 20px;
}
.usp-login-form-wrap form { margin: 0; }
.usp-login-form-wrap p { margin: 0 0 16px; }
.usp-login-form-wrap p.login-remember {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 12.5px;
    color: var(--usp-muted);
    margin-bottom: 16px;
}
.usp-login-form-wrap p.login-remember input[type="checkbox"] {
    width: auto;
    margin: 0;
    accent-color: var(--usp-blue);
}
.usp-login-form-wrap label {
    display: block;
    font-size: 10.5px;
    font-weight: 700;
    letter-spacing: .1em;
    text-transform: uppercase;
    color: var(--usp-muted);
    margin-bottom: 6px;
}
.usp-login-form-wrap input[type="text"],
.usp-login-form-wrap input[type="password"] {
    width: 100%;
    border: 1.5px solid #dcdcdc;
    border-radius: 7px;
    padding: 11px 14px;
    font-size: 14px;
    font-family: var(--usp-font);
    color: var(--usp-black);
    background: #fff;
    box-sizing: border-box;
    transition: border-color .15s, box-shadow .15s;
    -webkit-appearance: none;
}
.usp-login-form-wrap input[type="text"]:focus,
.usp-login-form-wrap input[type="password"]:focus {
    border-color: var(--usp-blue);
    box-shadow: 0 0 0 3px rgba(14,143,204,.12);
    outline: none;
}
.usp-login-form-wrap input[type="submit"],
.usp-login-form-wrap input[type="submit"].button,
.usp-login-form-wrap input[type="submit"].button-primary {
    width: 100% !important;
    background: var(--usp-black) !important;
    color: #fff !important;
    border: 2px solid var(--usp-black) !important;
    border-radius: 7px !important;
    padding: 13px 24px !important;
    font-size: 13px !important;
    font-weight: 700 !important;
    letter-spacing: .08em !important;
    text-transform: uppercase !important;
    cursor: pointer !important;
    font-family: var(--usp-font) !important;
    transition: background .15s, color .15s !important;
    box-shadow: none !important;
}
.usp-login-form-wrap input[type="submit"]:hover,
.usp-login-form-wrap input[type="submit"].button:hover,
.usp-login-form-wrap input[type="submit"].button-primary:hover {
    background: #333 !important;
    color: #fff !important;
}
.usp-login-form-wrap .usp-login-error {
    display: block;
    font-size: 11.5px;
    color: #c0392b;
    font-weight: 600;
    margin-top: 6px;
}
.usp-login-form-links {
    display: flex;
    justify-content: space-between;
    margin-top: 14px;
    padding-top: 14px;
    border-top: 1px solid var(--usp-border);
}
.usp-login-form-links a {
    font-size: 12px;
    color: var(--usp-blue);
    text-decoration: none;
}
.usp-login-form-links a:hover { text-decoration: underline; }

/* Admin state ------------------------------------------------- */
.usp-admin-badge {
    display: flex;
    align-items: center;
    gap: 8px;
    background: rgba(14,143,204,.08);
    border: 1px solid rgba(14,143,204,.22);
    border-radius: 8px;
    padding: 10px 14px;
    margin-bottom: 22px;
    font-size: 12.5px;
    font-weight: 700;
    letter-spacing: .04em;
    color: var(--usp-blue);
}
.usp-admin-badge svg { flex-shrink: 0; }
.usp-admin-fields {
    background: rgba(14,143,204,.04);
    border: 1px dashed rgba(14,143,204,.3);
    border-radius: 8px;
    padding: 16px 16px 12px;
    margin-bottom: 14px;
}

@keyframes usp-fade-in {
    from { opacity: 0; }
    to   { opacity: 1; }
}
@keyframes usp-slide-up {
    from { opacity: 0; transform: translateY(28px) scale(.98); }
    to   { opacity: 1; transform: translateY(0) scale(1); }
}

/* ── Product tabs section ───────────────────────────────────── */
.usp-tabs-section {
    margin-top: 56px;
}

/* ── Reviews section ────────────────────────────────────────── */
.usp-reviews-section {
    margin-top: 64px;
    padding-top: 48px;
    border-top: 1px solid var(--usp-border);
}

/* Header: "LATEST REVIEWS" + arrows on right */
.usp-reviews-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 36px;
}
.usp-reviews-title {
    font-size: 13px;
    font-weight: 400;
    letter-spacing: .16em;
    text-transform: uppercase;
    margin: 0;
    color: var(--usp-muted);
}
.usp-reviews-title span {
    font-weight: 700;
    color: var(--usp-blue);
}

/* Arrow controls next to header */
.usp-reviews-arrows {
    display: flex;
    gap: 8px;
}
.usp-reviews-arrow {
    width: 36px;
    height: 36px;
    border: 1.5px solid var(--usp-border);
    background: #fff;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--usp-radius);
    font-size: 16px;
    transition: border-color .12s, background .12s;
    color: var(--usp-black);
}
.usp-reviews-arrow:hover {
    border-color: var(--usp-black);
    background: var(--usp-black);
    color: #fff;
}

/* Score summary block */
.usp-reviews-summary {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 32px;
}
.usp-reviews-score {
    font-size: 44px;
    font-weight: 700;
    line-height: 1;
    color: var(--usp-black);
}
.usp-reviews-score-meta {
    font-size: 12px;
    color: var(--usp-muted);
    display: block;
    letter-spacing: .04em;
}
.usp-reviews-score-block { text-align: center; }
.usp-reviews-stars {
    display: flex;
    flex-direction: column;
    gap: 4px;
    justify-content: center;
}
.usp-reviews-count { font-size: 13px; color: var(--usp-muted); }

/* Reviews carousel */
.usp-reviews-carousel { margin-bottom: 8px; }
.usp-reviews-carousel .item {
    padding: 0 8px;
    height: 320px !important;      /* fixed tile height for all cards */
}

/* Review card — white with border + shadow */
.usp-review-card {
    background: #ffffff;
    border: 1px solid #e8e8e8;
    border-radius: 6px;
    box-shadow: 0 2px 12px rgba(0,0,0,.05);
    padding: 24px 24px 20px;
    display: flex;
    flex-direction: column;
    height: 100%;
    box-sizing: border-box;
}

/* Stars — UGLOW blue */
.usp-review-stars {
    font-size: 18px;
    color: var(--usp-blue);
    letter-spacing: 3px;
    margin-bottom: 14px;
    line-height: 1;
    flex-shrink: 0;
}

/* Review body text — scrollable when content overflows */
.usp-review-body {
    font-size: 14px;
    line-height: 1.65;
    color: #333333;
    margin: 0;
    flex: 1;
    overflow-y: auto;
    scrollbar-width: thin;
    scrollbar-color: #dcdcdc transparent;
}
.usp-review-body::-webkit-scrollbar {
    width: 4px;
}
.usp-review-body::-webkit-scrollbar-track {
    background: transparent;
}
.usp-review-body::-webkit-scrollbar-thumb {
    background: #dcdcdc;
    border-radius: 2px;
}

/* Divider before footer */
.usp-review-footer-divider {
    height: 1px;
    background: var(--usp-border);
    margin: 16px 0 14px;
    flex-shrink: 0;
}

/* Footer: avatar | name+date | VERIFIED */
.usp-review-footer {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-shrink: 0;
}
.usp-review-avatar,
.usp-reviews-section .owl-item img.usp-review-avatar,
.usp-reviews-carousel .owl-item img.usp-review-avatar {
    width: 40px !important;
    height: 40px !important;
    min-width: 40px !important;
    max-width: 40px !important;
    border-radius: 50% !important;
    object-fit: cover !important;
    background: #d9d9d9;
    flex-shrink: 0;
    display: block;
}
.usp-review-avatar--initials {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: #d9d9d9;
    color: #666;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 14px;
    font-weight: 700;
    flex-shrink: 0;
}
.usp-review-author {
    font-size: 13px;
    font-weight: 700;
    display: block;
    color: var(--usp-black);
    letter-spacing: .01em;
}
.usp-review-date {
    font-size: 11px;
    color: var(--usp-muted);
    text-transform: uppercase;
    letter-spacing: .07em;
    display: block;
    margin-top: 2px;
}
.usp-review-verified {
    margin-left: auto;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: #fff;
    background: var(--usp-blue);
    padding: 4px 10px;
    border-radius: 3px;
    flex-shrink: 0;
}

.usp-reviews-view-all {
    display: inline-block;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: .06em;
    text-transform: uppercase;
    color: var(--usp-blue);
    text-decoration: underline;
    text-decoration-thickness: 1.5px;
    text-underline-offset: 3px;
}
.usp-reviews-view-all:hover { color: var(--usp-black); }

/* ── Complete the Look ──────────────────────────────────────── */
.usp-complete-look {
    margin-top: 96px;
    padding-top: 48px;
    border-top: 2px solid var(--usp-border);
    clear: both;
    display: block;
    width: 100%;
}
.usp-complete-look-header {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    margin-bottom: 24px;
}
.usp-complete-look-title {
    font-size: 22px;
    font-weight: 700;
    margin: 0;
}
.usp-look-carousel { position: relative; }
.usp-look-arrows { display: flex; gap: 8px; }
.usp-look-arrow {
    width: 36px;
    height: 36px;
    border: 1.5px solid var(--usp-border);
    background: #fff;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--usp-radius);
    transition: border-color .12s;
}
.usp-look-arrow:hover { border-color: var(--usp-black); }

/* Look product card */
.usp-look-card { padding: 0 8px; }
.usp-look-card-inner { }
.usp-look-img-wrap {
    position: relative;
    overflow: hidden;
    background: var(--usp-soft);
    margin-bottom: 10px;
    border-radius: var(--usp-radius);
}
.usp-look-img-wrap img {
    width: 100%;
    aspect-ratio: 4/5;
    object-fit: cover;
    display: block;
    transition: transform .4s ease;
}
.usp-look-card-inner:hover .usp-look-img-wrap img { transform: scale(1.03); }
.usp-look-name {
    font-size: 14px;
    font-weight: 600;
    margin: 0 0 4px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.usp-look-price { font-size: 14px; color: var(--usp-muted); margin-bottom: 10px; }
.usp-look-quick-add {
    display: block;
    width: 100%;
    padding: 10px;
    border: 1.5px solid var(--usp-black);
    background: transparent;
    font-size: 12px;
    font-weight: 700;
    font-family: var(--usp-font);
    letter-spacing: .05em;
    text-transform: uppercase;
    cursor: pointer;
    border-radius: var(--usp-radius);
    transition: background .12s, color .12s;
    text-align: center;
    text-decoration: none;
    color: var(--usp-black);
}
.usp-look-quick-add:hover { background: var(--usp-black); color: #fff; }

/* ─── Gallery ───────────────────────────────────────────────── */
.usp-gallery-wrap {
    position: static; /* col-gallery handles sticky positioning */
}

/* Desktop gallery */
.usp-gallery-desktop { display: block; }
.usp-gallery-mobile  { display: none; }

.usp-main-image-wrap {
    position: relative;
    background: var(--usp-soft);
    overflow: hidden;
    border-radius: var(--usp-radius);
    cursor: zoom-in;
}
.usp-main-image-wrap img,
.usp-main-image-wrap .usp-main-img {
    width: 100%;
    aspect-ratio: 4 / 5;
    object-fit: cover;
    display: block;
    transition: opacity .2s;
}
.usp-main-image-loading { opacity: .4; }

/* Thumbnail strip */
.usp-thumb-strip {
    display: flex;
    gap: 8px;
    margin-top: 10px;
    overflow-x: auto;
    padding-bottom: 4px;
    scrollbar-width: thin;
    scrollbar-color: var(--usp-border) transparent;
}
.usp-thumb-strip::-webkit-scrollbar { height: 4px; }
.usp-thumb-strip::-webkit-scrollbar-thumb { background: var(--usp-border); border-radius: 2px; }

.usp-thumb {
    flex-shrink: 0;
    width: 72px;
    height: 72px;
    border: 2px solid transparent;
    border-radius: var(--usp-radius);
    overflow: hidden;
    cursor: pointer;
    transition: border-color .12s;
    background: var(--usp-soft);
}
.usp-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.usp-thumb:hover { border-color: #999; }
.usp-thumb.active { border-color: var(--usp-black); }

/* Video thumb indicator */
.usp-thumb-video { position: relative; }
.usp-thumb-video::after {
    content: '▶';
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(0,0,0,.4);
    color: #fff;
    font-size: 16px;
}

/* Video embed in main area */
.usp-main-video {
    position: relative;
    background: #000;
    border-radius: var(--usp-radius);
    overflow: hidden;
    aspect-ratio: 4/5;
}
.usp-main-video iframe,
.usp-main-video video {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* Mobile carousel */
.usp-mobile-counter {
    position: absolute;
    top: 12px;
    right: 12px;
    background: rgba(0,0,0,.55);
    color: #fff;
    font-size: 11px;
    font-weight: 600;
    padding: 4px 10px;
    border-radius: 20px;
    z-index: 10;
    letter-spacing: .04em;
    pointer-events: none;
}
.usp-gallery-mobile .usp-main-image-wrap {
    aspect-ratio: auto;
}
.usp-gallery-mobile .owl-carousel .item {
    position: relative;
}
.usp-gallery-mobile .owl-carousel img {
    width: 100%;
    display: block;
}

/* ─── Modern Product Tabs ────────────────────────────────────── */
.uglow-product-tabs {
    border: 1px solid var(--usp-border);
    border-radius: 8px;
    overflow: hidden;
}

/* ── Tab nav bar ────────────────────────────────────────────── */
.uglow-tabs-nav {
    display: flex;
    border-bottom: 1px solid var(--usp-border);
    background: #f8f8f8;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    /* No gap — buttons are separated by divider borders */
}
.uglow-tabs-nav::-webkit-scrollbar { display: none; }

/* ── Tab button ─────────────────────────────────────────────── */
.uglow-tab-btn {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 16px 24px;
    border: none;
    border-right: 1px solid var(--usp-border);
    border-bottom: 3px solid transparent;
    background: transparent;
    font-size: 11px;
    font-weight: 700;
    font-family: var(--usp-font);
    letter-spacing: .1em;
    text-transform: uppercase;
    color: var(--usp-muted);
    cursor: pointer;
    white-space: nowrap;
    flex-shrink: 0;
    transition: color .18s, background .18s, border-bottom-color .18s;
}
.uglow-tab-btn:last-child { border-right: none; }
.uglow-tab-btn svg {
    flex-shrink: 0;
    opacity: .45;
    transition: opacity .18s;
    width: 14px;
    height: 14px;
}
.uglow-tab-btn:hover {
    color: var(--usp-black);
    background: #efefef;
}
.uglow-tab-btn:hover svg { opacity: .7; }
.uglow-tab-btn.active {
    color: var(--usp-blue);
    background: #fff;
    border-bottom-color: var(--usp-blue);
}
.uglow-tab-btn.active svg { opacity: 1; stroke: var(--usp-blue); }

/* ── Tab panels ─────────────────────────────────────────────── */
.uglow-tab-panel {
    display: none;
}
.uglow-tab-panel.active {
    display: block;
}
.uglow-tab-content {
    padding: 32px 36px 28px;
    background: #fff;
}

/* KEY FEATURES panel content */
.uglow-tab-content h2 { font-size: 18px; margin: 0 0 16px; }
.uglow-tab-content h3 { font-size: 15px; margin: 20px 0 8px; }
.uglow-tab-content p  { font-size: 14px; line-height: 1.65; color: var(--usp-black); margin: 0 0 12px; }
.uglow-tab-content ul,
.uglow-tab-content ol {
    font-size: 14px;
    line-height: 1.65;
    color: var(--usp-black);
    margin: 0 0 16px;
    padding-left: 20px;
}
.uglow-tab-content li { margin-bottom: 6px; }
.uglow-tab-content strong { font-weight: 700; }
.uglow-tab-content table { width: 100%; border-collapse: collapse; font-size: 13px; margin: 16px 0; }
.uglow-tab-content table th,
.uglow-tab-content table td { padding: 10px 12px; text-align: left; border-bottom: 1px solid var(--usp-border); }
.uglow-tab-content table th { font-weight: 700; background: var(--usp-soft); }

/* FABRIC & CARE panel */
.uglow-tab-content .fabric-care-content { font-size: 14px; line-height: 1.65; }
.uglow-tab-content .fabric-care-content img { max-width: 100%; height: auto; }

/* Ratings panel */
.uglow-ratings-panel { }
.uglow-ratings-summary {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 24px;
    padding-bottom: 24px;
    border-bottom: 1px solid var(--usp-border);
}
.uglow-ratings-score {
    font-size: 48px;
    font-weight: 700;
    line-height: 1;
    color: var(--usp-black);
}
.uglow-ratings-stars {
    font-size: 20px;
    color: #f1c945;
    letter-spacing: 3px;
    display: block;
    margin-bottom: 4px;
}
.uglow-ratings-count { font-size: 13px; color: var(--usp-muted); }

/* Rating custom override — WC review form inside tabs */
.uglow-tab-content .rating-custom,
.uglow-tab-content #reviews { padding: 0; margin: 0; }
.uglow-tab-content .woocommerce-Reviews-title { display: none; }

/* ─── Old WC tabs wrapper — hide to prevent double rendering ── */
.usp-tabs-section .woocommerce-tabs ul.tabs { display: none !important; }
.usp-tabs-section .woocommerce-tabs .panel { display: none !important; }

/* ─── Tabs section wrapper — used by content-single-product.php ── */
.usp-tabs-section { margin-top: 0; }

/* ─── Mobile responsive ──────────────────────────────────────── */
@media (max-width: 767px) {
    .usp-page-wrap { padding: 0 16px 80px; }

    .usp-layout {
        grid-template-columns: 1fr;
        gap: 24px;
        padding-top: 8px;
    }

    /* Kill sticky on mobile — gallery must scroll with the page */
    .usp-col-gallery {
        position: static !important;
        top: auto !important;
        background: #fff;
        z-index: auto;
    }

    .usp-gallery-wrap { position: static; }
    .usp-gallery-desktop { display: none; }
    .usp-gallery-mobile  { display: block; }

    .usp-gallery-intro { margin-top: 16px; padding-top: 16px; }
    .usp-gallery-intro p { font-size: 17px; }

    .usp-title { font-size: 22px !important; }
    .usp-price-wrap .price { font-size: 22px; }

    .usp-short-desc { columns: 1; padding: 24px 20px; margin-top: 32px; }
    .usp-callouts-grid { grid-template-columns: 1fr; }
    .usp-info-tiles { grid-template-columns: 1fr; margin-top: 36px; }
    .usp-info-tile { padding: 24px 20px; }
    .usp-info-tile__body { max-height: none; overflow-y: visible; }
    .usp-review-modal { align-items: flex-end; padding: 0; }
    .usp-review-modal__dialog { max-height: 92vh; border-radius: 16px 16px 0 0; width: 100%; max-width: 100%; }
    .usp-review-modal__header { padding: 20px 20px 16px; }
    .usp-review-modal__body { padding: 22px 20px 32px; }

    /* Sticky ATC on mobile */
    .usp-page-wrap .usp-atc-wrap {
        position: sticky;
        bottom: 0;
        z-index: 100;
        background: #fff;
        padding: 12px 0 0;
        margin: 0 -16px;
        padding-left: 16px;
        padding-right: 16px;
        box-shadow: 0 -4px 16px rgba(0,0,0,.1);
    }
    .usp-page-wrap .single_add_to_cart_button,
    .usp-page-wrap button.single_add_to_cart_button,
    .usp-page-wrap button.button.alt {
        border-radius: 4px !important;
        width: 100% !important;
    }

    /* Qty wrap mobile */
    .usp-qty-wrap { display: none; }

    /* Tabs on mobile: tighter, horizontal scroll, hide icons */
    .uglow-product-tabs { border-radius: 6px; }
    .uglow-tabs-nav { overflow-x: auto; -webkit-overflow-scrolling: touch; }
    .uglow-tab-btn { padding: 13px 16px; font-size: 10px; gap: 0; letter-spacing: .08em; }
    .uglow-tab-btn svg { display: none; }
    .uglow-tab-content { padding: 24px 20px 20px; }
}

@media (min-width: 768px) and (max-width: 1024px) {
    .usp-layout { grid-template-columns: 1fr 1fr; gap: 32px; }
    /* Reduce sticky offset on tablet — shorter header */
    .usp-col-gallery { top: 64px; }
    .usp-short-desc { columns: 1; padding: 28px 28px; }
    .usp-callouts-grid { grid-template-columns: repeat(2, 1fr); }
    .usp-info-tiles { grid-template-columns: repeat(2, 1fr); }
    .usp-title { font-size: 24px; }
}

@media (min-width: 600px) and (max-width: 899px) {
    .usp-callouts-grid { grid-template-columns: repeat(2, 1fr); }
}

/* ─── Utility / override cleanup ────────────────────────────── */
/* Keep WC summary hidden — our template renders inline */
.usp-page-wrap .product-inner-main { display: none !important; }
.usp-page-wrap .entry-summary { display: none !important; }
/* The old owl review slider in content-single-product.php */
.usp-page-wrap .review_slider { display: none !important; }

/* Remove WC default single product layout interference */
.usp-page-wrap .woocommerce-product-gallery { display: none !important; }

/* ugc-card inside Complete the Look carousel */
.usp-look-carousel .item { padding: 0 4px; }
.usp-look-carousel .ugc-card { width: 100%; }

/* Ensure the ugc-wrap wrapper doesn't add extra padding inside carousel */
.usp-complete-look .ugc-wrap {
    max-width: none;
    padding: 0;
}

/* Owl Carousel dots theming for reviews */
.usp-reviews-section .owl-dots { margin-top: 16px; }
.usp-reviews-section .owl-dot span {
    width: 8px;
    height: 8px;
    background: var(--usp-border) !important;
    margin: 4px !important;
}
.usp-reviews-section .owl-dot.active span { background: var(--usp-black) !important; }
