/* =========================
   Gabbiano Pizza Menu
========================= */

body.tax-product_cat .site-content {
    background:
        radial-gradient(circle at top left, rgba(120,0,0,.18), transparent 35%),
        radial-gradient(circle at top right, rgba(255,60,0,.08), transparent 25%),
        #090909;

    color: #fff;
}

body.tax-product_cat .content-area {
    width: 100% !important;
    float: none !important;
    margin: 0 !important;
}

body.tax-product_cat .widget-area,
body.tax-product_cat .woocommerce-products-header,
body.tax-product_cat .woocommerce-pagination,
body.tax-product_cat ul.products li.product img {
    display: none !important;
}

body.tax-product_cat .site-main {
    max-width: none !important;
    margin: 0 !important;
    padding: 0 0 80px !important;
}

/* =========================
   Breadcrumb
========================= */

body.tax-product_cat .storefront-breadcrumb {
    margin: 0;
    padding: 16px 24px;
    background: #050505;
    border-top: 1px solid rgba(255,255,255,.04);
    border-bottom: 1px solid rgba(255,255,255,.04);

    color: rgba(255,255,255,.55);
    font-size: 13px;
}

body.tax-product_cat .storefront-breadcrumb a {
    color: #fff;
    text-decoration: none;
}

/* =========================
   Hero
========================= */

body.tax-product_cat .gabbiano-category-hero {
    width: 100vw;
    max-width: none;

    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);

    min-height: 420px;

    background-size: cover;
    background-position: center center;
}

body.tax-product_cat .gabbiano-category-hero__overlay {
    width: 100%;
    min-height: 420px;

    background:
        linear-gradient(
            180deg,
            rgba(0,0,0,.38),
            rgba(0,0,0,.68)
        );

    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;

    text-align: center;

    padding: 70px 24px;
}

body.tax-product_cat .gabbiano-category-hero h1 {
    color: #fff;

    font-size: clamp(54px, 8vw, 118px);
    line-height: .9;

    font-weight: 900;
    letter-spacing: -0.07em;
    text-transform: uppercase;

    margin: 0 0 16px;
}

body.tax-product_cat .gabbiano-category-hero p {
    max-width: 720px;

    color: rgba(255,255,255,.82);

    font-size: 18px;
    line-height: 1.6;

    margin: 0;
}

/* =========================
   Sorting
========================= */

body.tax-product_cat .storefront-sorting {
    max-width: 1120px;

    margin: 34px auto 26px;

    display: flex;
    align-items: center;
    justify-content: space-between;

    gap: 24px;
}

body.tax-product_cat .woocommerce-ordering,
body.tax-product_cat .woocommerce-result-count {
    float: none;
    margin: 0;
}

body.tax-product_cat .woocommerce-result-count {
    color: rgba(255,255,255,.42);
    font-size: 14px;
}

body.tax-product_cat .woocommerce-ordering select {
    min-width: 250px;
    height: 46px;

    padding: 0 18px;

    border-radius: 999px;
    border: 1px solid rgba(255,255,255,.12);

    background: rgba(255,255,255,.95);
    color: #111;

    font-size: 14px;
    font-weight: 500;
}

/* =========================
   Product List
========================= */

body.tax-product_cat ul.products {
    max-width: 1120px;

    margin: 0 auto;

    display: flex !important;
    flex-direction: column;

    gap: 16px;
}

body.tax-product_cat ul.products li.product {
    width: 100% !important;
    float: none !important;

    display: grid !important;
    grid-template-columns: 1fr auto auto;

    align-items: center;

    gap: 24px;

    margin: 0 !important;
    padding: 26px 28px !important;

    text-align: left !important;

    background:
        linear-gradient(
            135deg,
            rgba(255,255,255,.07),
            rgba(255,255,255,.025)
        );

    border: 1px solid rgba(255,255,255,.10);

    border-radius: 24px;

    box-shadow:
        0 22px 60px rgba(0,0,0,.30);

    backdrop-filter: blur(10px);

    transition:
        transform .2s ease,
        border-color .2s ease,
        background .2s ease;
}

body.tax-product_cat ul.products li.product:hover {
    transform: translateY(-3px);

    background:
        linear-gradient(
            135deg,
            rgba(255,255,255,.095),
            rgba(255,255,255,.035)
        );

    border-color: rgba(214,0,28,.45);
}

body.tax-product_cat .woocommerce-loop-product__title {
    color: #fff;

    font-size: 28px;
    line-height: 1.05;

    font-weight: 800;
    letter-spacing: -0.045em;

    margin: 0 0 8px;
    padding: 0;
}

.gabbiano-product-desc {
    max-width: 760px;

    color: rgba(255,255,255,.62);

    font-size: 15px;
    line-height: 1.65;
}

body.tax-product_cat ul.products li.product .price {
    color: #fff;

    font-size: 24px;
    font-weight: 800;

    letter-spacing: -0.03em;

    white-space: nowrap;
}

body.tax-product_cat ul.products li.product .button {
    width: 48px;
    height: 48px;

    border-radius: 18px;

    background:
        linear-gradient(
            135deg,
            #ff2742,
            #c00019
        ) !important;

    color: #fff !important;

    font-size: 0;

    padding: 0 !important;

    display: inline-flex !important;
    align-items: center;
    justify-content: center;

    border: 0;

    box-shadow:
        0 14px 30px rgba(214,0,28,.38);

    transition:
        transform .16s ease,
        filter .16s ease;
}

body.tax-product_cat ul.products li.product .button::before {
    content: "+";

    font-size: 30px;
    line-height: 1;

    font-weight: 700;
}

body.tax-product_cat ul.products li.product .button:hover {
    transform: scale(1.06);
    filter: brightness(1.08);
}

/* =========================
   Mobile
========================= */

@media (max-width: 768px) {

    body.tax-product_cat .storefront-breadcrumb {
        padding: 14px 16px;
        font-size: 12px;
    }

    body.tax-product_cat .gabbiano-category-hero,
    body.tax-product_cat .gabbiano-category-hero__overlay {
        min-height: 220px;
        height: 46vw;
        max-height: 300px;
    }

    body.tax-product_cat .gabbiano-category-hero__overlay {
        padding: 28px 18px;
    }

    body.tax-product_cat .gabbiano-category-hero h1 {
        font-size: clamp(42px, 12vw, 68px);
    }

    body.tax-product_cat .gabbiano-category-hero p {
        font-size: 14px;
        line-height: 1.5;
    }

    body.tax-product_cat .storefront-sorting {
        margin: 24px 14px 18px;

        flex-direction: column;
        align-items: stretch;

        gap: 14px;
    }

    body.tax-product_cat .woocommerce-ordering select {
        width: 100%;
        min-width: 0;
    }

    body.tax-product_cat .woocommerce-result-count {
        text-align: center;
    }

    body.tax-product_cat ul.products {
        margin: 0 14px;
        gap: 12px;
    }

    body.tax-product_cat ul.products li.product {
        grid-template-columns: 1fr auto;

        gap: 12px;

        padding: 20px !important;

        border-radius: 20px;
    }

    body.tax-product_cat .woocommerce-loop-product__title {
        font-size: 22px;
    }

    .gabbiano-product-desc {
        font-size: 14px;
        line-height: 1.55;
    }

    body.tax-product_cat ul.products li.product .price {
        font-size: 18px;
    }

    body.tax-product_cat ul.products li.product .button {
        width: 44px;
        height: 44px;

        border-radius: 16px;
    }
}

@media (max-width: 480px) {

    body.tax-product_cat .gabbiano-category-hero,
    body.tax-product_cat .gabbiano-category-hero__overlay {
        min-height: 190px;
        height: 52vw;
    }
}