﻿:root {
    --pl-green: #66745f;
    --pl-green-dark: #4f5d49;
    --pl-green-soft: #eef1e8;
    --pl-beige: #f7f1e6;
    --pl-beige-soft: #fbf7ef;
    --pl-cream: #fffaf2;
    --pl-card: rgba(255, 250, 242, 0.92);
    --pl-card-strong: #fffaf2;
    --pl-text: #2f332d;
    --pl-text-soft: #6d7168;
    --pl-border: rgba(102, 116, 95, 0.18);
    --pl-shadow: 0 18px 45px rgba(59, 70, 54, 0.12);
    --pl-shadow-soft: 0 12px 28px rgba(59, 70, 54, 0.08);
    --pl-radius-large: 34px;
    --pl-radius-medium: 24px;
    --pl-radius-small: 16px;
}

/* Page shell */

.category-page {
    background: radial-gradient(circle at top left, rgba(255, 250, 242, 0.95), transparent 34rem), linear-gradient(180deg, var(--pl-green-soft) 0%, var(--pl-beige) 42%, var(--pl-cream) 100%);
    color: var(--pl-text);
    min-height: 100vh;
    padding: 3rem 1.25rem 4rem;
}

.category-page-inner,
.category-shell,
.category-content {
    width: min(1180px, 100%);
    margin: 0 auto;
}

/* Hero */

.category-hero {
    width: min(1180px, 100%);
    margin: 0 auto 2rem;
    display: grid;
    grid-template-columns: minmax(0, 1.1fr) minmax(280px, 0.9fr);
    gap: 2rem;
    align-items: center;
    background: rgba(255, 250, 242, 0.72);
    border: 1px solid var(--pl-border);
    border-radius: var(--pl-radius-large);
    box-shadow: var(--pl-shadow);
    padding: clamp(1.4rem, 3vw, 2.4rem);
    overflow: hidden;
}

.category-hero-content {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.category-eyebrow,
.collection-eyebrow {
    display: inline-flex;
    width: fit-content;
    align-items: center;
    gap: 0.45rem;
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--pl-green-dark);
    background: rgba(102, 116, 95, 0.11);
    border: 1px solid rgba(102, 116, 95, 0.14);
    border-radius: 999px;
    padding: 0.45rem 0.8rem;
}

.category-hero h1,
.category-title {
    margin: 0;
    font-size: clamp(2.35rem, 5vw, 4.8rem);
    line-height: 0.95;
    letter-spacing: -0.055em;
    color: var(--pl-green-dark);
}

.category-hero p,
.category-description {
    margin: 0;
    max-width: 62ch;
    font-size: clamp(1rem, 1.35vw, 1.14rem);
    line-height: 1.75;
    color: var(--pl-text-soft);
}

.category-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.8rem;
    margin-top: 0.35rem;
}

.category-hero-media {
    position: relative;
    min-height: 360px;
    border-radius: 28px;
    overflow: hidden;
    background: linear-gradient(135deg, rgba(102, 116, 95, 0.14), rgba(255, 250, 242, 0.72));
    border: 1px solid rgba(102, 116, 95, 0.14);
}

    .category-hero-media img {
        width: 100%;
        height: 100%;
        min-height: 360px;
        display: block;
        object-fit: cover;
    }

.category-hero-card {
    position: absolute;
    right: 1rem;
    bottom: 1rem;
    max-width: 250px;
    background: rgba(255, 250, 242, 0.9);
    border: 1px solid rgba(102, 116, 95, 0.14);
    border-radius: 22px;
    padding: 1rem;
    box-shadow: var(--pl-shadow-soft);
    backdrop-filter: blur(10px);
}

    .category-hero-card h2,
    .category-hero-card h3 {
        margin: 0 0 0.35rem;
        font-size: 1rem;
        color: var(--pl-green-dark);
    }

    .category-hero-card p {
        margin: 0;
        font-size: 0.9rem;
        line-height: 1.55;
    }

/* Buttons */

.category-button,
.category-link-button,
.product-button,
.collection-button,
.primary-button,
.secondary-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 44px;
    border-radius: 999px;
    padding: 0.75rem 1.2rem;
    font-size: 0.95rem;
    font-weight: 700;
    line-height: 1;
    text-decoration: none;
    transition: transform 180ms ease, box-shadow 180ms ease, background 180ms ease, border-color 180ms ease;
}

.category-button,
.product-button,
.primary-button {
    color: var(--pl-cream);
    background: var(--pl-green);
    border: 1px solid var(--pl-green);
    box-shadow: 0 10px 22px rgba(79, 93, 73, 0.16);
}

.category-link-button,
.collection-button,
.secondary-button {
    color: var(--pl-green-dark);
    background: rgba(255, 250, 242, 0.8);
    border: 1px solid rgba(102, 116, 95, 0.24);
}

    .category-button:hover,
    .category-link-button:hover,
    .product-button:hover,
    .collection-button:hover,
    .primary-button:hover,
    .secondary-button:hover {
        transform: translateY(-2px);
        box-shadow: 0 14px 28px rgba(79, 93, 73, 0.16);
    }

/* Intro sections */

.category-intro,
.category-benefits,
.category-section,
.collection-intro {
    width: min(1180px, 100%);
    margin: 0 auto 2rem;
}

.category-intro-grid,
.category-benefits-grid,
.collection-intro-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
}

.category-intro-card,
.category-benefit-card,
.collection-intro-card,
.category-info-card {
    background: var(--pl-card);
    border: 1px solid var(--pl-border);
    border-radius: var(--pl-radius-medium);
    padding: 1.25rem;
    box-shadow: var(--pl-shadow-soft);
}

    .category-intro-card h2,
    .category-intro-card h3,
    .category-benefit-card h2,
    .category-benefit-card h3,
    .collection-intro-card h2,
    .collection-intro-card h3,
    .category-info-card h2,
    .category-info-card h3 {
        margin: 0 0 0.55rem;
        font-size: 1.08rem;
        color: var(--pl-green-dark);
    }

    .category-intro-card p,
    .category-benefit-card p,
    .collection-intro-card p,
    .category-info-card p {
        margin: 0;
        color: var(--pl-text-soft);
        line-height: 1.65;
    }

/* Section headings */

.section-heading,
.category-section-heading {
    width: min(1180px, 100%);
    margin: 0 auto 1.2rem;
}

    .section-heading.center,
    .category-section-heading.center {
        text-align: center;
    }

    .section-heading h2,
    .category-section-heading h2 {
        margin: 0;
        font-size: clamp(1.65rem, 3vw, 2.65rem);
        line-height: 1.08;
        letter-spacing: -0.035em;
        color: var(--pl-green-dark);
    }

    .section-heading p,
    .category-section-heading p {
        margin: 0.65rem auto 0;
        max-width: 720px;
        color: var(--pl-text-soft);
        line-height: 1.7;
    }

/* Product and category grids */

.category-products,
.category-collections,
.product-list-section,
.collection-list-section {
    width: min(1180px, 100%);
    margin: 0 auto 2.5rem;
}

.product-grid,
.category-product-grid,
.collection-grid,
.category-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1.15rem;
}

/* Cards */

.product-card,
.collection-card,
.category-card {
    display: flex;
    flex-direction: column;
    overflow: hidden;
    background: var(--pl-card);
    border: 1px solid var(--pl-border);
    border-radius: var(--pl-radius-medium);
    box-shadow: var(--pl-shadow-soft);
    text-decoration: none;
    color: inherit;
    min-height: 100%;
    transition: transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease;
}

    .product-card:hover,
    .collection-card:hover,
    .category-card:hover {
        transform: translateY(-4px);
        border-color: rgba(102, 116, 95, 0.32);
        box-shadow: var(--pl-shadow);
    }

.product-card-image,
.collection-card-image,
.category-card-image,
.product-card-media,
.collection-card-media,
.category-card-media {
    position: relative;
    overflow: hidden;
    background: linear-gradient(135deg, rgba(102, 116, 95, 0.09), rgba(255, 250, 242, 0.88));
    aspect-ratio: 4 / 5;
}

    .product-card-image img,
    .collection-card-image img,
    .category-card-image img,
    .product-card-media img,
    .collection-card-media img,
    .category-card-media img {
        width: 100%;
        height: 100%;
        display: block;
        object-fit: cover;
        transition: transform 240ms ease;
    }

.product-card:hover .product-card-image img,
.collection-card:hover .collection-card-image img,
.category-card:hover .category-card-image img,
.product-card:hover .product-card-media img,
.collection-card:hover .collection-card-media img,
.category-card:hover .category-card-media img {
    transform: scale(1.035);
}

.product-card-content,
.collection-card-content,
.category-card-content {
    display: flex;
    flex: 1;
    flex-direction: column;
    gap: 0.65rem;
    padding: 1.15rem;
}

    .product-card-content h2,
    .product-card-content h3,
    .collection-card-content h2,
    .collection-card-content h3,
    .category-card-content h2,
    .category-card-content h3 {
        margin: 0;
        font-size: 1.18rem;
        line-height: 1.2;
        color: var(--pl-green-dark);
    }

    .product-card-content p,
    .collection-card-content p,
    .category-card-content p {
        margin: 0;
        color: var(--pl-text-soft);
        line-height: 1.6;
    }

.product-card-meta,
.collection-card-meta,
.category-card-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
    margin-top: auto;
    padding-top: 0.35rem;
}

.product-card-tag,
.collection-card-tag,
.category-card-tag {
    display: inline-flex;
    align-items: center;
    width: fit-content;
    border-radius: 999px;
    background: rgba(102, 116, 95, 0.1);
    color: var(--pl-green-dark);
    font-size: 0.76rem;
    font-weight: 700;
    padding: 0.35rem 0.65rem;
}

/* Card badges */

.product-card-badge,
.collection-card-badge,
.category-card-badge {
    position: absolute;
    top: 0.85rem;
    left: 0.85rem;
    z-index: 2;
    border-radius: 999px;
    background: rgba(255, 250, 242, 0.88);
    border: 1px solid rgba(102, 116, 95, 0.16);
    color: var(--pl-green-dark);
    font-size: 0.74rem;
    font-weight: 800;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    padding: 0.4rem 0.65rem;
    backdrop-filter: blur(8px);
}

/* Feature banners */

.category-banner,
.collection-banner,
.category-feature-banner {
    width: min(1180px, 100%);
    margin: 2rem auto;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 1.2rem;
    align-items: center;
    background: radial-gradient(circle at top right, rgba(255, 250, 242, 0.9), transparent 20rem), linear-gradient(135deg, rgba(102, 116, 95, 0.16), rgba(255, 250, 242, 0.9));
    border: 1px solid var(--pl-border);
    border-radius: var(--pl-radius-large);
    box-shadow: var(--pl-shadow-soft);
    padding: clamp(1.25rem, 3vw, 2rem);
}

    .category-banner h2,
    .collection-banner h2,
    .category-feature-banner h2 {
        margin: 0 0 0.55rem;
        font-size: clamp(1.45rem, 2.5vw, 2.15rem);
        line-height: 1.12;
        color: var(--pl-green-dark);
    }

    .category-banner p,
    .collection-banner p,
    .category-feature-banner p {
        margin: 0;
        max-width: 760px;
        line-height: 1.7;
        color: var(--pl-text-soft);
    }

/* Empty or coming soon states */

.category-empty,
.category-coming-soon {
    width: min(760px, 100%);
    margin: 2rem auto;
    text-align: center;
    background: var(--pl-card);
    border: 1px solid var(--pl-border);
    border-radius: var(--pl-radius-large);
    box-shadow: var(--pl-shadow-soft);
    padding: clamp(1.5rem, 4vw, 2.5rem);
}

    .category-empty h2,
    .category-coming-soon h2 {
        margin: 0 0 0.65rem;
        color: var(--pl-green-dark);
    }

    .category-empty p,
    .category-coming-soon p {
        margin: 0 auto;
        max-width: 58ch;
        color: var(--pl-text-soft);
        line-height: 1.7;
    }

/* Responsive */

@media (max-width: 1080px) {
    .category-page {
        padding-top: 2rem;
    }

    .category-hero {
        grid-template-columns: 1fr;
    }

    .category-hero-media,
    .category-hero-media img {
        min-height: 320px;
    }

    .product-grid,
    .category-product-grid,
    .collection-grid,
    .category-grid,
    .category-intro-grid,
    .category-benefits-grid,
    .collection-intro-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 760px) {
    .category-page {
        padding: 1rem 0.85rem 3rem;
    }

    .category-hero {
        border-radius: 26px;
        padding: 1.1rem;
    }

    .category-hero-media,
    .category-hero-media img {
        min-height: 260px;
    }

    .category-hero-card {
        position: static;
        max-width: none;
        margin: 0.8rem;
    }

    .category-actions {
        flex-direction: column;
    }

    .category-button,
    .category-link-button,
    .product-button,
    .collection-button,
    .primary-button,
    .secondary-button {
        width: 100%;
    }

    .category-banner,
    .collection-banner,
    .category-feature-banner {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 620px) {
    .product-grid,
    .category-product-grid,
    .collection-grid,
    .category-grid,
    .category-intro-grid,
    .category-benefits-grid,
    .collection-intro-grid {
        grid-template-columns: 1fr;
    }

    .product-card-content,
    .collection-card-content,
    .category-card-content,
    .category-intro-card,
    .category-benefit-card,
    .collection-intro-card,
    .category-info-card {
        padding: 1rem;
    }

    .product-card-image,
    .collection-card-image,
    .category-card-image,
    .product-card-media,
    .collection-card-media,
    .category-card-media {
        aspect-ratio: 4 / 5;
    }
}
