/**
 * ============================================================================
 * NETT CUSTOM CSS — CUSTOM POST TYPES
 * ============================================================================
 *
 * Applies to: Custom post type single & archive pages:
 *   - WooCommerce Products  (single-product.php, archive-product.php)
 *   - Portfolio, Team, Event, etc. (any registered CPT)
 *   Body classes targeted: .single-{post-type} and .post-type-archive-{post-type}
 *
 * Depends on: _master-variables.css or _master-variables-[project-id].css
 *
 * PRIORITY: Font families & color palette are the most critical declarations.
 * ============================================================================
 */

/* ============================================================
 * BASE TYPOGRAPHY — highest priority for font rendering
 * ============================================================ */
.single-product,
.post-type-archive,
.post-type-archive-product,
.tax-product_cat,
.tax-product_tag,
[class*="single-"][class*=" nett-custom-post"],
[class*="post-type-archive-"] {
    font-family: var(--nett-font-body);
    font-size: var(--nett-body-size);
    font-weight: var(--nett-body-weight);
    line-height: var(--nett-body-line-height);
    color: var(--nett-body-color);
    background-color: var(--nett-bg-secondary);
}

/* ============================================================
 * CUSTOM POST TYPE ARCHIVE HEADER
 * ============================================================ */
.post-type-archive .archive-header,
.post-type-archive .page-header {
    background: var(--nett-gradient-primary);
    color: var(--nett-white);
    padding: var(--nett-space-12) var(--nett-space-6);
    text-align: center;
    margin-bottom: var(--nett-space-10);
    border-radius: var(--nett-radius-2xl);
    box-shadow: var(--nett-shadow-primary);
    position: relative;
    overflow: hidden;
}

.post-type-archive .archive-title,
.post-type-archive .page-title {
    font-family: var(--nett-font-display);
    font-size: var(--nett-h1-size);
    font-weight: var(--nett-display-weight);
    line-height: var(--nett-h1-line-height);
    letter-spacing: var(--nett-tracking-tight);
    color: var(--nett-white);
    margin: 0 0 var(--nett-space-3);
}

.post-type-archive .archive-description {
    font-family: var(--nett-font-lead);
    font-size: var(--nett-lead-size);
    color: rgba(255, 255, 255, 0.9);
    max-width: 65ch;
    margin: 0 auto;
}

/* ============================================================
 * WOO PRODUCT SHOP / ARCHIVE
 * ============================================================ */
.woocommerce-shop h1.woocommerce-products-header__title,
.woocommerce-shop h1.page-title,
.post-type-archive-product h1 {
    font-family: var(--nett-font-heading);
    font-size: var(--nett-h2-size);
    font-weight: var(--nett-h2-weight);
    color: var(--nett-h2-color);
    margin-bottom: var(--nett-space-6);
}

/* Shop Toolbar */
.woocommerce-page .woocommerce-ordering select,
.woocommerce-page .woocommerce-result-count {
    font-family: var(--nett-font-body);
    font-size: var(--nett-text-sm);
    color: var(--nett-text-secondary);
}

.woocommerce-page .woocommerce-ordering select {
    background-color: var(--nett-input-bg);
    border: var(--nett-border-1) solid var(--nett-input-border);
    border-radius: var(--nett-input-radius);
    padding: var(--nett-space-2) var(--nett-space-4);
    outline: none;
    transition: border-color var(--nett-duration) var(--nett-ease);
}

.woocommerce-page .woocommerce-ordering select:focus {
    border-color: var(--nett-input-border-focus);
}

/* Product Loop Grid */
.woocommerce-page ul.products,
.woocommerce ul.products {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: var(--nett-gap-lg);
    list-style: none;
    padding: 0;
    margin: 0 0 var(--nett-space-10);
}

/* Product Card */
.woocommerce-page ul.products li.product,
.woocommerce ul.products li.product {
    background-color: var(--nett-card-bg);
    border: var(--nett-border-1) solid var(--nett-card-border);
    border-radius: var(--nett-card-radius);
    box-shadow: var(--nett-card-shadow);
    overflow: hidden;
    transition: box-shadow var(--nett-duration) var(--nett-ease),
                transform var(--nett-duration) var(--nett-ease);
    display: flex;
    flex-direction: column;
    position: relative;
}

.woocommerce-page ul.products li.product:hover,
.woocommerce ul.products li.product:hover {
    box-shadow: var(--nett-card-shadow-hover);
    transform: translateY(-4px);
}

/* Product Image */
.woocommerce-page ul.products li.product .woocommerce-loop-product__thumb,
.woocommerce ul.products li.product .woocommerce-loop-product__thumb {
    overflow: hidden;
    aspect-ratio: 1 / 1;
}

.woocommerce-page ul.products li.product img,
.woocommerce ul.products li.product img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--nett-duration-500) var(--nett-ease);
}

.woocommerce-page ul.products li.product:hover img,
.woocommerce ul.products li.product:hover img {
    transform: scale(1.05);
}

/* Product Badges — Sale, New, etc. */
.woocommerce-page ul.products li.product .onsale,
.woocommerce ul.products li.product .onsale {
    position: absolute;
    top: var(--nett-space-3);
    left: var(--nett-space-3);
    background-color: var(--nett-error);
    color: var(--nett-white);
    font-family: var(--nett-font-badge);
    font-size: var(--nett-badge-font-size);
    font-weight: var(--nett-badge-font-weight);
    padding: var(--nett-badge-padding);
    border-radius: var(--nett-badge-radius);
    z-index: 2;
    text-transform: uppercase;
    letter-spacing: var(--nett-tracking-wide);
}

/* Product Info Area */
.woocommerce-page ul.products li.product .woocommerce-loop-product__link,
.woocommerce ul.products li.product .woocommerce-loop-product__link {
    padding: var(--nett-card-padding);
    display: flex;
    flex-direction: column;
    flex: 1;
    text-decoration: none;
}

/* Product Category */
.woocommerce-page ul.products li.product .product-category,
.woocommerce ul.products li.product .product-category,
.woocommerce-page ul.products li.product .wc-block-components-product-category {
    font-family: var(--nett-font-overline);
    font-size: var(--nett-overline-size);
    font-weight: var(--nett-overline-weight);
    letter-spacing: var(--nett-overline-tracking);
    text-transform: var(--nett-overline-transform);
    color: var(--nett-overline-color);
    margin-bottom: var(--nett-space-2);
}

/* Product Title */
.woocommerce-page ul.products li.product .woocommerce-loop-product__title,
.woocommerce ul.products li.product h2.woocommerce-loop-product__title {
    font-family: var(--nett-font-heading);
    font-size: var(--nett-h5-size);
    font-weight: var(--nett-h5-weight);
    line-height: var(--nett-h5-line-height);
    color: var(--nett-h5-color);
    margin: 0 0 var(--nett-space-3);
    transition: var(--nett-transition-colors);
}

.woocommerce-page ul.products li.product:hover .woocommerce-loop-product__title {
    color: var(--nett-primary);
}

/* Product Price */
.woocommerce-page ul.products li.product .price,
.woocommerce ul.products li.product .price {
    font-family: var(--nett-font-heading);
    font-size: var(--nett-text-xl);
    font-weight: var(--nett-font-bold);
    color: var(--nett-primary);
    margin-bottom: var(--nett-space-3);
}

.woocommerce-page ul.products li.product .price del,
.woocommerce ul.products li.product .price del {
    color: var(--nett-text-muted);
    font-weight: var(--nett-font-normal);
    font-size: var(--nett-text-base);
    margin-right: var(--nett-space-2);
}

.woocommerce-page ul.products li.product .price ins,
.woocommerce ul.products li.product .price ins {
    color: var(--nett-error);
    text-decoration: none;
}

/* Star Ratings */
.woocommerce-page .star-rating,
.woocommerce .star-rating {
    color: var(--nett-testimonial-star-color);
    font-size: var(--nett-text-sm);
    margin-bottom: var(--nett-space-3);
}

/* Add To Cart Button */
.woocommerce-page ul.products li.product .button,
.woocommerce ul.products li.product .button,
.woocommerce-page ul.products li.product .add_to_cart_button {
    width: 100%;
    text-align: center;
    justify-content: center;
    margin-top: auto;
}

/* ============================================================
 * SINGLE PRODUCT PAGE
 * ============================================================ */
.single-product .product {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--nett-space-10);
    align-items: start;
}

/* Product Images */
.single-product .woocommerce-product-gallery__image img {
    border-radius: var(--nett-card-radius);
    width: 100%;
    height: auto;
}

.single-product .woocommerce-product-gallery .flex-control-thumbs img {
    border-radius: var(--nett-radius-md);
    border: var(--nett-border-2) solid transparent;
    transition: border-color var(--nett-duration) var(--nett-ease);
    cursor: pointer;
}

.single-product .woocommerce-product-gallery .flex-control-thumbs .flex-active img,
.single-product .woocommerce-product-gallery .flex-control-thumbs img:hover {
    border-color: var(--nett-primary);
}

/* Product Title */
.single-product .product .product_title {
    font-family: var(--nett-font-display);
    font-size: var(--nett-h2-size);
    font-weight: var(--nett-h2-weight);
    line-height: var(--nett-h2-line-height);
    color: var(--nett-h2-color);
    margin-bottom: var(--nett-space-3);
}

/* Product Rating */
.single-product .product .woocommerce-product-rating {
    display: flex;
    align-items: center;
    gap: var(--nett-space-3);
    margin-bottom: var(--nett-space-4);
    font-family: var(--nett-font-meta);
    font-size: var(--nett-meta-size);
    color: var(--nett-meta-color);
}

/* Product SKU / Categories / Tags */
.single-product .product .product_meta {
    font-family: var(--nett-font-body);
    font-size: var(--nett-text-sm);
    color: var(--nett-text-secondary);
    margin: var(--nett-space-5) 0;
    display: flex;
    flex-direction: column;
    gap: var(--nett-space-2);
}

.single-product .product .product_meta .label {
    font-weight: var(--nett-font-semibold);
    color: var(--nett-text-primary);
}

.single-product .product .product_meta a {
    color: var(--nett-text-link);
    text-decoration: none;
    transition: var(--nett-transition-colors);
}

.single-product .product .product_meta a:hover {
    color: var(--nett-text-link-hover);
}

/* Product Price */
.single-product .product .price {
    font-family: var(--nett-font-heading);
    font-size: var(--nett-h3-size);
    font-weight: var(--nett-font-bold);
    color: var(--nett-primary);
    margin-bottom: var(--nett-space-5);
}

.single-product .product .price del {
    color: var(--nett-text-muted);
    font-size: var(--nett-text-xl);
    font-weight: var(--nett-font-normal);
    margin-right: var(--nett-space-3);
}

.single-product .product .price ins {
    color: var(--nett-error);
    text-decoration: none;
}

/* Short Description */
.single-product .product .woocommerce-product-details__short-description {
    font-family: var(--nett-font-body);
    font-size: var(--nett-body-size);
    line-height: var(--nett-body-line-height);
    color: var(--nett-text-secondary);
    margin-bottom: var(--nett-space-5);
    padding-bottom: var(--nett-space-5);
    border-bottom: var(--nett-border-1) solid var(--nett-border-color);
}

/* Variations */
.single-product .variations label {
    font-family: var(--nett-font-label);
    font-size: var(--nett-label-size);
    font-weight: var(--nett-label-weight);
    color: var(--nett-label-color);
    letter-spacing: var(--nett-label-tracking);
}

.single-product .variations select {
    background-color: var(--nett-input-bg);
    border: var(--nett-border-1) solid var(--nett-input-border);
    border-radius: var(--nett-input-radius);
    padding: var(--nett-input-padding);
    font-family: var(--nett-font-body);
    font-size: var(--nett-input-font-size);
    color: var(--nett-text-primary);
    outline: none;
    transition: border-color var(--nett-duration) var(--nett-ease);
}

.single-product .variations select:focus {
    border-color: var(--nett-input-border-focus);
}

/* Add To Cart Section */
.single-product .product form.cart {
    display: flex;
    align-items: center;
    gap: var(--nett-space-4);
    flex-wrap: wrap;
    margin-bottom: var(--nett-space-6);
}

.single-product .product form.cart .qty {
    width: 80px;
    text-align: center;
    font-family: var(--nett-font-heading);
    font-size: var(--nett-text-lg);
    font-weight: var(--nett-font-bold);
    border: var(--nett-border-1) solid var(--nett-input-border);
    border-radius: var(--nett-input-radius);
    padding: var(--nett-space-3);
    color: var(--nett-text-primary);
}

.single-product .product .single_add_to_cart_button {
    flex: 1;
    text-align: center;
    justify-content: center;
    font-size: var(--nett-text-base) !important;
    padding: var(--nett-space-4) var(--nett-space-8) !important;
    background: var(--nett-gradient-primary) !important;
    box-shadow: var(--nett-shadow-primary);
}

/* Product Tabs */
.single-product .woocommerce-tabs ul.tabs {
    display: flex;
    gap: 0;
    border-bottom: var(--nett-border-2) solid var(--nett-border-color);
    list-style: none;
    margin: var(--nett-space-8) 0 0;
    padding: 0;
}

.single-product .woocommerce-tabs ul.tabs li a {
    font-family: var(--nett-font-nav);
    font-size: var(--nett-nav-link-size);
    font-weight: var(--nett-font-medium);
    color: var(--nett-text-secondary);
    text-decoration: none;
    display: block;
    padding: var(--nett-space-3) var(--nett-space-5);
    border-bottom: 3px solid transparent;
    margin-bottom: -2px;
    transition: var(--nett-transition-colors);
}

.single-product .woocommerce-tabs ul.tabs li a:hover {
    color: var(--nett-primary);
}

.single-product .woocommerce-tabs ul.tabs li.active a {
    color: var(--nett-primary);
    font-weight: var(--nett-font-semibold);
    border-bottom-color: var(--nett-primary);
}

.single-product .woocommerce-tabs .woocommerce-Tabs-panel {
    padding: var(--nett-space-6) 0;
    font-family: var(--nett-font-body);
    font-size: var(--nett-body-size);
    line-height: var(--nett-body-line-height);
    color: var(--nett-body-color);
}

.single-product .woocommerce-tabs .woocommerce-Tabs-panel h2 {
    font-family: var(--nett-font-heading);
    font-size: var(--nett-h4-size);
    font-weight: var(--nett-h4-weight);
    color: var(--nett-h4-color);
    margin-bottom: var(--nett-space-4);
}

/* ============================================================
 * GENERIC CPT SINGLE PAGE
 * ============================================================ */
[class*="single-"] .entry-header {
    margin-bottom: var(--nett-space-8);
    padding-bottom: var(--nett-space-6);
    border-bottom: var(--nett-border-1) solid var(--nett-border-color);
}

[class*="single-"] .entry-title {
    font-family: var(--nett-font-heading);
    font-size: var(--nett-h1-size);
    font-weight: var(--nett-h1-weight);
    line-height: var(--nett-h1-line-height);
    letter-spacing: var(--nett-h1-tracking);
    color: var(--nett-h1-color);
    margin: 0 0 var(--nett-space-4);
}

[class*="single-"] .entry-meta {
    font-family: var(--nett-font-meta);
    font-size: var(--nett-meta-size);
    color: var(--nett-meta-color);
    display: flex;
    flex-wrap: wrap;
    gap: var(--nett-gap-sm);
    align-items: center;
}

[class*="single-"] .entry-content {
    font-family: var(--nett-font-body);
    font-size: var(--nett-body-size);
    line-height: var(--nett-body-line-height);
    color: var(--nett-body-color);
}

[class*="single-"] .entry-content h2 {
    font-family: var(--nett-font-heading);
    font-size: var(--nett-h2-size);
    font-weight: var(--nett-h2-weight);
    color: var(--nett-h2-color);
    margin: var(--nett-space-8) 0 var(--nett-space-4);
}

[class*="single-"] .entry-content h3 {
    font-family: var(--nett-font-heading);
    font-size: var(--nett-h3-size);
    font-weight: var(--nett-h3-weight);
    color: var(--nett-h3-color);
    margin: var(--nett-space-6) 0 var(--nett-space-3);
}

[class*="single-"] .entry-content p {
    margin-bottom: var(--nett-space-5);
}

[class*="single-"] .entry-content a {
    color: var(--nett-text-link);
    text-decoration: underline;
    text-underline-offset: 3px;
    transition: var(--nett-transition-colors);
}

[class*="single-"] .entry-content a:hover {
    color: var(--nett-text-link-hover);
}

/* ============================================================
 * PAGINATION (archive)
 * ============================================================ */
.post-type-archive .pagination,
.post-type-archive .nav-links {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: var(--nett-space-2);
    margin: var(--nett-space-10) 0;
    font-family: var(--nett-font-btn);
}

.post-type-archive .pagination .page-numbers,
.post-type-archive .nav-links .page-numbers,
.woocommerce-page nav.woocommerce-pagination .page-numbers {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 40px;
    height: 40px;
    padding: var(--nett-space-2) var(--nett-space-3);
    background-color: var(--nett-white);
    border: var(--nett-border-1) solid var(--nett-border-color);
    border-radius: var(--nett-radius-lg);
    font-size: var(--nett-text-sm);
    font-weight: var(--nett-font-medium);
    color: var(--nett-text-secondary);
    text-decoration: none;
    transition: var(--nett-transition-all);
    box-shadow: var(--nett-shadow-sm);
}

.post-type-archive .pagination .page-numbers:hover,
.post-type-archive .nav-links .page-numbers:hover,
.woocommerce-page nav.woocommerce-pagination .page-numbers:hover {
    background-color: var(--nett-primary-50);
    border-color: var(--nett-primary);
    color: var(--nett-primary);
}

.post-type-archive .pagination .page-numbers.current,
.post-type-archive .nav-links .page-numbers.current,
.woocommerce-page nav.woocommerce-pagination .page-numbers.current {
    background-color: var(--nett-primary);
    border-color: var(--nett-primary);
    color: var(--nett-white);
    box-shadow: var(--nett-shadow-primary);
}

/* ============================================================
 * RESPONSIVE
 * ============================================================ */
@media (max-width: 1024px) {
    .woocommerce-page ul.products,
    .woocommerce ul.products {
        grid-template-columns: repeat(3, 1fr);
    }
}

@media (max-width: 768px) {
    .single-product .product {
        grid-template-columns: 1fr;
    }

    .woocommerce-page ul.products,
    .woocommerce ul.products {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 480px) {
    .woocommerce-page ul.products,
    .woocommerce ul.products {
        grid-template-columns: 1fr;
    }
}
