﻿:root {
    --taeef-blue: #111111;
    --taeef-blue-dark: #000000;
    --taeef-ink: #111827;
    --taeef-muted: #667085;
    --taeef-soft: #f7f7f7;
    --taeef-line: #e2e8f2;
    --taeef-card: #ffffff;
    --taeef-radius: 8px;
    --taeef-shadow: 0 18px 55px rgba(15, 23, 42, 0.08);
}


*,
*::before,
*::after {
    box-sizing: border-box;
}

html {
    scroll-behavior: smooth;
}

body {
    margin: 0;
    color: var(--taeef-ink);
    background: #fff;
    font-family: Manrope, Inter, -apple-system, BlinkMacSystemFont, "Segoe UI", Arial, sans-serif;
    font-size: 15px;
    line-height: 1.5;
    font-weight: 500;
    text-rendering: geometricPrecision;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

a {
    color: inherit;
    text-decoration: none;
}

img {
    max-width: 100%;
    height: auto;
}

button,
input,
select,
textarea {
    font: inherit;
}

.taeef-shell,
.taeef-container {
    width: 100%;
    max-width: none;
    margin-inline: auto;
}

.screen-reader-text,
.skip-link {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

.skip-link:focus {
    top: 12px;
    left: 12px;
    width: auto;
    height: auto;
    padding: 10px 14px;
    clip: auto;
    background: var(--taeef-blue);
    color: #fff;
    z-index: 9999;
}

.site-header {
    position: sticky;
    top: 0;
    z-index: 50;
    background: linear-gradient(120deg, #ffffff 0%, #ffffff 52%, #ffffff 78%, #050505 100%);
    border-bottom: 1px solid var(--taeef-line);
    box-shadow: 0 1px 0 rgba(15, 23, 42, 0.04);
    backdrop-filter: blur(16px);
}

.header-inner {
    min-height: 62px;
    display: grid;
    grid-template-columns: 42px 180px 1fr auto;
    align-items: center;
    gap: 18px;
    padding: 0 36px;
}

.header-menu-button {
    width: 36px;
    height: 36px;
    display: inline-grid;
    place-items: center;
    border: 0;
    background: transparent;
    cursor: pointer;
}

.header-menu-button span {
    width: 22px;
    height: 2px;
    display: block;
    margin: 3px 0;
    border-radius: 999px;
    background: #111827;
}

.taeef-logo,
.footer-brand {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    color: #111111;
    font-size: 35px;
    font-weight: 900;
    line-height: 1;
    letter-spacing: 0;
}

.taeef-logo {
    line-height: 0;
}

.taeef-logo-image {
    display: block;
    width: 154px;
    height: auto;
}

.custom-logo {
    max-height: 58px;
    width: auto;
}

.ui-icon {
    font-size: 21px;
    line-height: 1;
}

.main-navigation {
    display: none;
}

.header-actions {
    display: flex;
    align-items: center;
    gap: 8px;
    white-space: nowrap;
}

.login-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #111827;
    font-size: 14px;
    font-weight: 800;
}

.login-button {
    min-width: 110px;
    min-height: 40px;
    margin-left: 28px;
    border-radius: 4px;
    background: #111111;
    color: #fff;
}

.header-cart-button {
    position: relative;
    min-height: 40px;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 0 12px;
    border: 1px solid #e5e7eb;
    border-radius: 999px;
    background: #fff;
    color: #111827;
    font-size: 13px;
    font-weight: 900;
    cursor: pointer;
}

.header-cart-button svg {
    width: 19px;
    height: 19px;
    stroke: currentColor;
    stroke-width: 2;
    fill: none;
}

.header-cart-button em {
    min-width: 20px;
    height: 20px;
    display: inline-grid;
    place-items: center;
    border-radius: 999px;
    background: #111111;
    color: #fff;
    font-style: normal;
    font-size: 11px;
}

.header-cart-button:hover,
.header-cart-button:focus {
    border-color: #111111;
    outline: none;
}

.menu-toggle {
    display: none;
    width: 44px;
    height: 44px;
    border: 1px solid var(--taeef-line);
    border-radius: var(--taeef-radius);
    background: #fff;
}

.menu-toggle span:not(.screen-reader-text) {
    display: block;
    width: 20px;
    height: 2px;
    margin: 4px auto;
    background: var(--taeef-blue);
}

.taeef-home {
    padding: 0;
    background: #fff;
}

.drawer-backdrop {
    position: fixed;
    inset: 0;
    z-index: 58;
    background: rgba(17, 24, 39, 0.42);
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.2s ease;
}

.drawer-open .drawer-backdrop {
    opacity: 1;
    pointer-events: auto;
}

.cart-drawer-backdrop {
    position: fixed;
    inset: 0;
    z-index: 78;
    background: rgba(17, 24, 39, 0.42);
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.2s ease;
}

.cart-drawer-open .cart-drawer-backdrop {
    opacity: 1;
    pointer-events: auto;
}

.taeef-cart-drawer {
    position: fixed;
    top: 0;
    right: 0;
    z-index: 80;
    width: min(420px, 100vw);
    height: 100vh;
    display: flex;
    flex-direction: column;
    transform: translateX(100%);
    border-left: 1px solid #e5e7eb;
    background: #fff;
    box-shadow: -22px 0 55px rgba(15, 23, 42, 0.18);
    transition: transform 0.24s ease;
}

.taeef-cart-drawer.is-open {
    transform: translateX(0);
}

.cart-drawer-header {
    min-height: 88px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 22px 24px;
    border-bottom: 1px solid #edf0f4;
}

.cart-drawer-header span {
    display: block;
    color: #667085;
    font-size: 12px;
    font-weight: 800;
    text-transform: uppercase;
}

.cart-drawer-header strong {
    color: #111827;
    font-size: 24px;
    font-weight: 900;
}

.cart-drawer-header button {
    width: 38px;
    height: 38px;
    border: 1px solid #e5e7eb;
    border-radius: 999px;
    background: #fff;
    color: #111827;
    font-weight: 900;
    cursor: pointer;
}

.cart-drawer-body {
    flex: 1;
    overflow-y: auto;
    padding: 18px 24px;
}

.cart-drawer-body .woocommerce-mini-cart {
    margin: 0;
    padding: 0;
    list-style: none;
}

.cart-drawer-body .woocommerce-mini-cart-item {
    position: relative;
    display: grid;
    grid-template-columns: 78px minmax(0, 1fr);
    gap: 14px;
    min-height: 108px;
    padding: 16px 34px 16px 0;
    border-bottom: 1px solid #edf0f4;
}

.cart-drawer-body .woocommerce-mini-cart-item img {
    width: 78px;
    height: 78px;
    object-fit: cover;
    border-radius: 8px;
    background: #f6f7f9;
}

.cart-drawer-body .woocommerce-mini-cart-item a {
    color: #111827;
    font-weight: 900;
}

.cart-drawer-body .woocommerce-mini-cart-item > a:not(.remove) {
    display: contents;
}

.cart-drawer-body .woocommerce-mini-cart-item > a:not(.remove) img {
    grid-column: 1;
    grid-row: 1 / span 3;
}

.cart-drawer-body .woocommerce-mini-cart-item > a:not(.remove)::after {
    content: attr(title);
}

.cart-drawer-body .remove_from_cart_button {
    position: absolute;
    top: 16px;
    right: 0;
    width: 24px;
    height: 24px;
    display: inline-grid;
    place-items: center;
    border-radius: 999px;
    background: #f8fafc;
    color: #111827;
    font-size: 0;
    font-weight: 800;
}

.cart-drawer-body .remove_from_cart_button::before {
    content: "x";
    font-size: 14px;
    line-height: 1;
}

.cart-drawer-body .woocommerce-mini-cart-item .quantity,
.cart-drawer-body .woocommerce-mini-cart-item > .quantity {
    grid-column: 2;
    align-self: end;
}

.cart-drawer-body .quantity {
    display: block;
    margin-top: 8px;
    color: #667085;
    font-size: 13px;
    font-weight: 700;
}

.cart-drawer-body .quantity .woocommerce-Price-amount {
    color: #111827;
    font-weight: 900;
}

.cart-drawer-body .woocommerce-mini-cart__total {
    display: flex;
    justify-content: space-between;
    margin: 18px 0 0;
    padding-top: 16px;
    border-top: 1px solid #111827;
    color: #111827;
    font-size: 16px;
    font-weight: 900;
}

.cart-drawer-body .woocommerce-mini-cart__buttons {
    display: none;
}

.cart-drawer-body .woocommerce-mini-cart__empty-message {
    margin: 0;
    padding: 32px 0;
    color: #667085;
    font-size: 15px;
}

.taeef-mini-cart-list {
    display: grid;
    gap: 0;
    margin: 0;
    padding: 0;
    list-style: none;
}

.taeef-mini-cart-item {
    position: relative;
    display: grid;
    grid-template-columns: 78px minmax(0, 1fr) 26px;
    gap: 14px;
    align-items: start;
    padding: 16px 0;
    border-bottom: 1px solid #edf0f4;
}

.taeef-mini-cart-thumb {
    width: 78px;
    height: 78px;
    display: block;
    overflow: hidden;
    border-radius: 8px;
    background: #f6f7f9;
}

.taeef-mini-cart-thumb img {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
}

.taeef-mini-cart-info {
    min-width: 0;
    display: grid;
    gap: 8px;
}

.taeef-mini-cart-title {
    color: #111827;
    font-size: 15px;
    font-weight: 900;
    line-height: 1.28;
}

.taeef-mini-cart-meta {
    color: #667085;
    font-size: 13px;
    font-weight: 800;
}

.taeef-mini-cart-meta .woocommerce-Price-amount {
    color: #111827;
    font-weight: 900;
}

.taeef-mini-cart-remove {
    width: 26px;
    height: 26px;
    display: inline-grid;
    place-items: center;
    border-radius: 999px;
    background: #f8fafc;
    color: #111827;
    font-size: 12px;
    font-weight: 900;
}

.taeef-mini-cart-total {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    margin-top: 18px;
    padding-top: 16px;
    border-top: 1px solid #111827;
    color: #111827;
    font-size: 16px;
    font-weight: 900;
}

.cart-drawer-empty {
    margin: 0;
    padding: 34px 0;
    color: #667085;
    font-size: 15px;
    font-weight: 700;
}

.cart-drawer-actions {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
    padding: 18px 24px 24px;
    border-top: 1px solid #edf0f4;
}

.cart-drawer-actions a {
    min-height: 48px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 6px;
    font-weight: 900;
}

.cart-drawer-view {
    border: 1px solid #d0d5dd;
    color: #111827;
    background: #fff;
}

.cart-drawer-checkout {
    color: #111111;
    background: linear-gradient(180deg, #050505 0%, #050505 100%);
}

.woocommerce-checkout .page-content,
.woocommerce-checkout .entry-content,
.woocommerce-checkout .site-main > .woocommerce {
    width: min(1060px, calc(100% - 48px));
    margin: 0 auto;
}

.woocommerce-checkout {
    background: #f7f7f8;
}

.woocommerce-checkout .entry-title,
.woocommerce-checkout h1 {
    width: min(1060px, calc(100% - 48px));
    margin: 34px auto 14px;
    color: #111827;
    font-size: 34px;
    font-weight: 950;
    letter-spacing: 0;
}

.woocommerce-checkout .page-content .entry-title {
    width: min(1060px, calc(100% - 48px));
    margin-left: auto;
    margin-right: auto;
    font-size: 34px;
    line-height: 1.05;
}

.woocommerce-checkout .woocommerce {
    margin: 0 auto 56px;
}

.woocommerce-checkout .woocommerce-form-coupon-toggle,
.woocommerce-checkout form.checkout_coupon {
    display: none !important;
}

.woocommerce-checkout form.checkout {
    display: grid;
    grid-template-columns: minmax(0, 620px) 390px;
    justify-content: space-between;
    gap: 36px;
    align-items: start;
}

.woocommerce-checkout .woocommerce .col2-set,
.woocommerce-checkout .woocommerce-page .col2-set,
.woocommerce-checkout .woocommerce-checkout-review-order,
.woocommerce-checkout #customer_details,
.woocommerce-checkout #order_review {
    width: auto !important;
    float: none !important;
}

.woocommerce-checkout #customer_details,
.woocommerce-checkout #order_review {
    border: 1px solid #eceef2;
    border-radius: 10px;
    background: #ffffff;
    box-shadow: none;
}

.woocommerce-checkout #customer_details {
    padding: 24px 24px 26px;
    grid-column: 1;
    grid-row: 1;
}

.woocommerce-checkout #order_review {
    grid-column: 2;
    grid-row: 1;
    position: sticky;
    top: 112px;
    overflow: hidden;
}

.woocommerce-checkout .col2-set {
    width: 100%;
    float: none;
}

.woocommerce-checkout .col2-set .col-1,
.woocommerce-checkout .col2-set .col-2 {
    width: 100%;
    float: none;
}

.woocommerce-checkout .col2-set .col-2 {
    display: none;
}

.woocommerce-checkout h3 {
    margin: 0 0 20px;
    color: #111827;
    font-size: 20px;
    font-weight: 950;
}

.woocommerce-checkout .woocommerce-billing-fields h3::after {
    content: "Enter your delivery details. Bangladesh is selected by default.";
    display: block;
    margin-top: 6px;
    color: #667085;
    font-size: 13px;
    font-weight: 700;
}


.woocommerce-checkout .form-row {
    margin: 0 0 12px;
}

.woocommerce-checkout .woocommerce-billing-fields__field-wrapper {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px 18px;
}

.woocommerce-checkout .form-row-wide,
.woocommerce-checkout .taeef-phone-first,
.woocommerce-checkout .taeef-full-name,
.woocommerce-checkout .taeef-full-address,
.woocommerce-checkout .taeef-optional-email,
.woocommerce-checkout #billing_address_1_field,
.woocommerce-checkout #billing_address_2_field,
.woocommerce-checkout #billing_country_field {
    grid-column: 1 / -1;
}

.woocommerce-checkout .taeef-hidden-field,
.woocommerce-checkout .taeef-country-hidden,
.woocommerce-checkout #billing_last_name_field,
.woocommerce-checkout #billing_address_2_field,
.woocommerce-checkout #billing_postcode_field,
.woocommerce-checkout #billing_country_field {
    display: none !important;
}

.woocommerce-checkout #billing_state_field,
.woocommerce-checkout #billing_city_field {
    grid-column: auto;
}

.woocommerce-checkout #billing_state_field {
    grid-column: 1;
    order: 40;
}

.woocommerce-checkout #billing_city_field {
    grid-column: 2;
    order: 41;
}

.woocommerce-checkout #billing_first_name_field {
    order: 10;
}

.woocommerce-checkout #billing_phone_field {
    order: 20;
}

.woocommerce-checkout #billing_address_1_field {
    order: 30;
}

.woocommerce-checkout #billing_email_field {
    order: 50;
}

.woocommerce-checkout label {
    margin-bottom: 7px;
    color: #344054;
    font-size: 13px;
    font-weight: 900;
}

.woocommerce-checkout abbr.required {
    color: #dc2626;
    text-decoration: none;
}

.woocommerce-checkout input.input-text,
.woocommerce-checkout textarea,
.woocommerce-checkout select,
.woocommerce-checkout .select2-container .select2-selection--single {
    width: 100%;
    min-height: 42px;
    border: 1px solid #d8d8dc;
    border-radius: 7px;
    background: #ffffff;
    color: #111827;
    padding: 0 12px;
    font-size: 14px;
    font-weight: 650;
    box-shadow: none;
}

.woocommerce-checkout #billing_address_1 {
    min-height: 86px;
    padding-top: 12px;
    line-height: 1.5;
}

.woocommerce-checkout input.input-text:focus,
.woocommerce-checkout textarea:focus,
.woocommerce-checkout select:focus,
.woocommerce-checkout .select2-container--open .select2-selection--single {
    border-color: #111827;
    outline: 0;
    box-shadow: 0 0 0 3px rgba(17, 24, 39, 0.08);
}

.woocommerce-checkout .select2-container .select2-selection--single .select2-selection__rendered {
    padding-left: 0;
    color: #111827;
    line-height: 42px;
    font-weight: 800;
}

.woocommerce-checkout .select2-container .select2-selection--single .select2-selection__arrow {
    height: 42px;
}

.woocommerce-checkout #billing_phone_field input {
    border-color: #f2b500;
    background: #fffdf3;
    font-size: 15px;
    font-weight: 900;
}

.woocommerce-checkout #billing_first_name_field input {
    font-size: 16px;
    font-weight: 900;
}

.woocommerce-checkout .woocommerce-additional-fields,
.woocommerce-checkout .woocommerce-shipping-fields {
    margin-top: 18px;
}

.woocommerce-checkout #order_review_heading {
    display: none;
}

.woocommerce-checkout #order_review::before {
    content: "Your order";
    display: block;
    padding: 22px 22px 18px;
    border-bottom: 0;
    color: #111827;
    font-size: 22px;
    font-weight: 950;
}


.woocommerce-checkout .woocommerce-checkout-review-order-table {
    margin: 0;
    border: 0;
    border-collapse: collapse;
}

.woocommerce-checkout .woocommerce-checkout-review-order-table th,
.woocommerce-checkout .woocommerce-checkout-review-order-table td {
    padding: 10px 22px;
    border-color: #e8e8ec;
    color: #111827;
    font-size: 13px;
    font-weight: 800;
}

.woocommerce-checkout .woocommerce-checkout-review-order-table .product-name {
    line-height: 1.35;
}

.woocommerce-checkout .woocommerce-checkout-review-order-table tfoot .order-total th,
.woocommerce-checkout .woocommerce-checkout-review-order-table tfoot .order-total td {
    padding-top: 14px;
    font-size: 20px;
    font-weight: 950;
}

.woocommerce-checkout #payment {
    border-radius: 0;
    background: #ffffff;
}

.woocommerce-checkout #payment ul.payment_methods {
    padding: 18px 22px 10px;
    border-bottom: 0;
}

.woocommerce-checkout #payment div.payment_box {
    border-radius: 8px;
    background: #f4f5f7;
    color: #475467;
    font-size: 13px;
}

.woocommerce-checkout #payment div.form-row {
    padding: 16px 22px 22px;
}

.woocommerce-checkout #place_order {
    width: 100%;
    min-height: 48px;
    border: 0;
    border-radius: 8px;
    background: #050505;
    color: #ffffff;
    font-size: 15px;
    font-weight: 950;
}

.woocommerce-checkout .woocommerce-privacy-policy-text {
    color: #667085;
    font-size: 12px;
    line-height: 1.5;
}

.woocommerce-checkout .woocommerce-error,
.woocommerce-checkout .woocommerce-info,
.woocommerce-checkout .woocommerce-message {
    width: min(1060px, calc(100% - 48px));
    margin: 14px auto;
    border-radius: 10px;
}

.woocommerce-account .page-content,
.woocommerce-account .entry-content,
.woocommerce-account .site-main > .woocommerce {
    width: min(1180px, calc(100% - 48px));
    margin: 0 auto;
}

.woocommerce-account .entry-title,
.woocommerce-account h1 {
    margin: 44px 0 22px;
    color: #111827;
    font-size: 38px;
    font-weight: 950;
}

.woocommerce-account .woocommerce {
    margin-bottom: 72px;
}

.woocommerce-account .woocommerce-MyAccount-navigation {
    width: 280px;
    float: left;
    padding: 12px;
    border: 1px solid #e2e8f0;
    border-radius: 14px;
    background: #ffffff;
    box-shadow: 0 18px 44px rgba(15, 23, 42, 0.05);
}

.woocommerce-account .woocommerce-MyAccount-navigation ul {
    display: grid;
    gap: 4px;
    margin: 0;
    padding: 0;
    list-style: none;
}

.woocommerce-account .woocommerce-MyAccount-navigation li a {
    min-height: 44px;
    display: flex;
    align-items: center;
    padding: 0 14px;
    border-radius: 10px;
    color: #344054;
    font-size: 14px;
    font-weight: 900;
}

.woocommerce-account .woocommerce-MyAccount-navigation li.is-active a,
.woocommerce-account .woocommerce-MyAccount-navigation li a:hover,
.woocommerce-account .woocommerce-MyAccount-navigation li a:focus {
    background: #111111;
    color: #ffffff;
}

.woocommerce-account .woocommerce-MyAccount-content {
    width: calc(100% - 312px);
    float: right;
    min-height: 360px;
    padding: 28px;
    border: 1px solid #e2e8f0;
    border-radius: 14px;
    background: #ffffff;
    box-shadow: 0 18px 44px rgba(15, 23, 42, 0.05);
}

.woocommerce-account .woocommerce-MyAccount-content > p:first-child {
    margin-top: 0;
    color: #111827;
    font-size: 18px;
    font-weight: 800;
}

.woocommerce-account .woocommerce-MyAccount-content p {
    color: #475467;
    font-size: 15px;
    line-height: 1.65;
}

.woocommerce-account .woocommerce-MyAccount-content a {
    color: #111827;
    font-weight: 900;
    text-decoration: underline;
    text-decoration-thickness: 1px;
    text-underline-offset: 3px;
}

.woocommerce-account .woocommerce-orders-table,
.woocommerce-account .woocommerce-table {
    overflow: hidden;
    border: 1px solid #e2e8f0;
    border-radius: 12px;
    border-collapse: separate;
    border-spacing: 0;
}

.woocommerce-account table.shop_table th,
.woocommerce-account table.shop_table td {
    padding: 16px;
    border-color: #edf0f4;
    color: #111827;
    font-size: 14px;
}

.woocommerce-account table.shop_table th {
    background: #f8fafc;
    font-weight: 950;
}

.woocommerce-account .woocommerce-button,
.woocommerce-account button.button,
.woocommerce-account .button {
    min-height: 42px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 8px;
    background: #111111 !important;
    color: #ffffff !important;
    padding: 0 16px;
    font-weight: 900;
    text-decoration: none !important;
}

.woocommerce-account .woocommerce-Addresses {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px;
}

.woocommerce-account .woocommerce-Address {
    width: auto;
    float: none;
    padding: 20px;
    border: 1px solid #e2e8f0;
    border-radius: 12px;
    background: #f8fafc;
}

.woocommerce-account .woocommerce-Address-title {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
}

.woocommerce-account .woocommerce-Address-title h2,
.woocommerce-account .woocommerce-MyAccount-content h2,
.woocommerce-account .woocommerce-MyAccount-content h3 {
    margin: 0 0 14px;
    color: #111827;
    font-size: 20px;
    font-weight: 950;
}

.woocommerce-account form.login,
.woocommerce-account form.register,
.woocommerce-account form.woocommerce-EditAccountForm,
.woocommerce-account form.woocommerce-address-fields {
    padding: 26px;
    border: 1px solid #e2e8f0;
    border-radius: 14px;
    background: #ffffff;
    box-shadow: 0 18px 44px rgba(15, 23, 42, 0.05);
}

.woocommerce-account form.login,
.woocommerce-account form.register {
    max-width: 520px;
}

.woocommerce-account .woocommerce-form-row,
.woocommerce-account .form-row {
    margin-bottom: 14px;
}

.woocommerce-account label {
    display: block;
    margin-bottom: 7px;
    color: #344054;
    font-size: 13px;
    font-weight: 900;
}

.woocommerce-account input.input-text,
.woocommerce-account textarea,
.woocommerce-account select,
.woocommerce-account .select2-container .select2-selection--single {
    width: 100%;
    min-height: 48px;
    border: 1px solid #d6dce7;
    border-radius: 9px;
    background: #ffffff;
    color: #111827;
    padding: 0 14px;
    font-size: 15px;
    font-weight: 700;
}

.woocommerce-account input.input-text:focus,
.woocommerce-account textarea:focus,
.woocommerce-account select:focus {
    border-color: #111827;
    outline: 0;
    box-shadow: 0 0 0 3px rgba(17, 24, 39, 0.08);
}

.taeef-google-login {
    margin: 0 0 18px;
    padding: 16px;
    border: 1px solid #edf0f4;
    border-radius: 12px;
    background: #f8fafc;
}

.taeef-google-login > span {
    display: block;
    margin-bottom: 10px;
    color: #667085;
    font-size: 12px;
    font-weight: 900;
    text-transform: uppercase;
}

.taeef-google-login .taeef-google-setup,
.taeef-google-login .nsl-button {
    min-height: 44px;
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    width: 100%;
    border-radius: 8px !important;
    background: #ffffff !important;
    color: #111827 !important;
    border: 1px solid #d6dce7 !important;
    font-weight: 900 !important;
    text-decoration: none !important;
}

.taeef-google-login small {
    display: block;
    margin-top: 8px;
    color: #667085;
    font-size: 12px;
    line-height: 1.45;
}

.woocommerce-account .woocommerce-notices-wrapper .woocommerce-message,
.woocommerce-account .woocommerce-notices-wrapper .woocommerce-error,
.woocommerce-account .woocommerce-notices-wrapper .woocommerce-info {
    border-radius: 10px;
}

.woocommerce-account .page-content {
    width: 100%;
    max-width: none;
    padding: 0;
}

.woocommerce-account .page-content > article {
    display: grid;
    grid-template-columns: 250px minmax(0, 1fr);
    align-items: start;
}

.woocommerce-account .entry-header {
    grid-column: 2;
    width: min(100% - 72px, 1040px);
    margin: 0 auto;
    padding-top: 58px;
}

.woocommerce-account .entry-content {
    grid-column: 1 / -1;
    width: 100%;
    max-width: none;
    margin: 0;
}

.woocommerce-account .entry-content > .woocommerce {
    display: grid;
    grid-template-columns: 250px minmax(0, 1fr);
    gap: 0;
    width: 100%;
    margin: 0 0 72px;
}

.woocommerce-account:not(.logged-in) .page-content > article {
    display: block;
}

.woocommerce-account:not(.logged-in) .entry-header {
    width: min(100% - 48px, 520px);
    padding-top: 46px;
    text-align: center;
}

.woocommerce-account:not(.logged-in) .entry-title,
.woocommerce-account:not(.logged-in) h1 {
    display: none;
    margin: 0 0 32px;
    color: #111111;
    font-size: clamp(30px, 3vw, 38px);
    line-height: 1;
    letter-spacing: 0;
}

.woocommerce-account:not(.logged-in) .entry-content {
    width: min(100% - 48px, 520px);
    margin: 0 auto 84px;
}

.woocommerce-account:not(.logged-in) .entry-content > .woocommerce {
    display: block;
    margin: 0;
}

.woocommerce-account:not(.logged-in) .woocommerce .u-columns.col2-set {
    display: block;
    width: 100%;
    direction: ltr;
}

.woocommerce-account:not(.logged-in) .woocommerce .u-column1,
.woocommerce-account:not(.logged-in) .woocommerce .u-column2 {
    width: 100% !important;
    max-width: none;
    float: none !important;
    direction: ltr;
}

.woocommerce-account:not(.logged-in) .woocommerce .u-column1 {
    display: block;
}

.woocommerce-account:not(.logged-in) .woocommerce .u-column2 {
    display: block;
}

.taeef-auth-login .woocommerce-account:not(.logged-in) .woocommerce .u-column2,
.taeef-auth-login.woocommerce-account:not(.logged-in) .woocommerce .u-column2,
.taeef-auth-register .woocommerce-account:not(.logged-in) .woocommerce .u-column1,
.taeef-auth-register.woocommerce-account:not(.logged-in) .woocommerce .u-column1 {
    display: none;
}

.woocommerce-account:not(.logged-in) .woocommerce h2 {
    margin: 0 0 26px;
    color: #111111;
    font-size: 28px;
    font-weight: 950;
    text-align: center;
    line-height: 1.15;
}

.woocommerce-account:not(.logged-in) form.login,
.woocommerce-account:not(.logged-in) form.register {
    max-width: none;
    min-height: 0;
    margin: 0;
    padding: 34px;
    border: 1px solid #e5e7eb;
    border-radius: 16px;
    background: #ffffff;
    box-shadow: 0 18px 50px rgba(15, 23, 42, 0.06);
}

.woocommerce-account:not(.logged-in) form.register::before {
    content: "Join and enjoy original tech at your doorstep.";
    display: block;
    margin: -8px 0 28px;
    color: #667085;
    font-size: 15px;
    font-weight: 600;
    text-align: center;
}

.woocommerce-account:not(.logged-in) .woocommerce-form-login__rememberme {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    margin: 2px 0 18px;
}

.woocommerce-account:not(.logged-in) .woocommerce-form-login__rememberme input {
    width: 16px;
    height: 16px;
    margin: 0;
}

.woocommerce-account:not(.logged-in) .woocommerce-LostPassword {
    margin: 18px 0 0;
    text-align: center;
}

.woocommerce-account:not(.logged-in) .woocommerce-privacy-policy-text {
    margin-top: 12px;
    color: #475467;
    font-size: 13px;
    line-height: 1.55;
}

.woocommerce-account:not(.logged-in) .woocommerce-form-row {
    margin-bottom: 20px;
}

.woocommerce-account:not(.logged-in) label {
    color: #111827;
    font-size: 13px;
    font-weight: 900;
}

.woocommerce-account:not(.logged-in) input.input-text {
    min-height: 50px;
    border: 1px solid #d9dee8;
    border-radius: 10px;
    background: #ffffff;
    color: #111827;
    padding: 0 16px;
    font-size: 15px;
    font-weight: 700;
    box-shadow: none;
}

.woocommerce-account:not(.logged-in) input.input-text:focus {
    border-color: #111111;
    outline: 0;
    box-shadow: 0 0 0 3px rgba(17, 17, 17, 0.08);
}

.woocommerce-account:not(.logged-in) button.button,
.woocommerce-account:not(.logged-in) .woocommerce-button {
    width: 100%;
    min-height: 50px;
    border-radius: 10px;
    background: #111111 !important;
    color: #ffffff !important;
    font-size: 15px;
    font-weight: 950;
    box-shadow: none;
}

.woocommerce-account:not(.logged-in) button.button:hover,
.woocommerce-account:not(.logged-in) .woocommerce-button:hover {
    background: #000000 !important;
}

.taeef-auth-switch {
    min-height: 50px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: calc(100% - 4px);
    margin-top: 22px;
    border: 1px solid #111111;
    border-radius: 10px;
    color: #111111 !important;
    background: #ffffff;
    font-size: 15px;
    font-weight: 950;
    text-decoration: none !important;
}

.taeef-auth-switch:hover {
    background: #f7f7f7;
}

.taeef-auth-login-link {
    margin: 26px 0 0;
    padding-top: 22px;
    border-top: 1px solid #edf0f4;
    color: #667085;
    text-align: center;
    font-size: 14px;
}

.taeef-auth-login-link a {
    color: #111111 !important;
    font-weight: 950;
    text-decoration: none !important;
}

.woocommerce-account .entry-content > .woocommerce > .woocommerce-notices-wrapper {
    grid-column: 2;
    width: min(100% - 72px, 1040px);
    margin: 0 auto;
}

.woocommerce-account .woocommerce-MyAccount-navigation {
    position: sticky;
    grid-column: 1;
    grid-row: 1 / span 4;
    top: 88px;
    z-index: 9;
    width: 250px;
    height: calc(100vh - 88px);
    float: none;
    padding: 22px 16px;
    border: 0;
    border-right: 1px solid #d8d8d8;
    border-radius: 0;
    background: #ffffff;
    box-shadow: none;
}

.woocommerce-account .woocommerce-MyAccount-navigation ul {
    gap: 8px;
}

.woocommerce-account .woocommerce-MyAccount-navigation li a {
    min-height: 42px;
    gap: 10px;
    padding: 0 12px;
    border-radius: 8px;
}

.woocommerce-account .woocommerce-MyAccount-navigation li a::before {
    content: "";
    width: 22px;
    height: 22px;
    flex: 0 0 22px;
    display: inline-grid;
    place-items: center;
    border-radius: 6px;
    background: #f3f4f6;
    color: #111111;
    font-size: 10px;
    font-weight: 950;
}

.woocommerce-account .woocommerce-MyAccount-navigation-link--dashboard a::before {
    content: "DB";
}

.woocommerce-account .woocommerce-MyAccount-navigation-link--orders a::before {
    content: "OR";
}

.woocommerce-account .woocommerce-MyAccount-navigation-link--downloads a::before {
    content: "DL";
}

.woocommerce-account .woocommerce-MyAccount-navigation-link--edit-address a::before {
    content: "AD";
}

.woocommerce-account .woocommerce-MyAccount-navigation-link--edit-account a::before {
    content: "AC";
}

.woocommerce-account .woocommerce-MyAccount-navigation-link--customer-logout a::before {
    content: "LO";
}

.woocommerce-account .woocommerce-MyAccount-navigation li.is-active a::before,
.woocommerce-account .woocommerce-MyAccount-navigation li a:hover::before,
.woocommerce-account .woocommerce-MyAccount-navigation li a:focus::before {
    background: #ffffff;
    color: #111111;
}

.woocommerce-account .woocommerce-MyAccount-content {
    grid-column: 2;
    grid-row: 1;
    width: min(100% - 72px, 1040px);
    float: none;
    min-height: 360px;
    margin: 0 auto;
    padding: 28px;
}

.woocommerce-account .woocommerce-Addresses {
    width: 100% !important;
    float: none !important;
    clear: both;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    align-items: stretch;
}

.woocommerce-account .woocommerce-Addresses .woocommerce-Address,
.woocommerce-account .woocommerce-Addresses .u-column1,
.woocommerce-account .woocommerce-Addresses .u-column2 {
    width: 100% !important;
    max-width: none;
    float: none !important;
}

.woocommerce-account .woocommerce-Address {
    min-height: 210px;
    padding: 24px;
}

.woocommerce-account .woocommerce-Addresses .woocommerce-Address:nth-child(1) {
    grid-column: 1;
}

.woocommerce-account .woocommerce-Addresses .woocommerce-Address:nth-child(2) {
    grid-column: 2;
}

.woocommerce-account .woocommerce-Address-title h2 {
    max-width: 180px;
    margin: 0;
    font-size: 24px;
    line-height: 1.1;
}

.woocommerce-account .woocommerce-Address-title .edit {
    min-height: 34px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0 12px;
    border-radius: 999px;
    background: #111111;
    color: #ffffff;
    font-size: 12px;
    text-decoration: none;
}

.woocommerce-account .woocommerce-Address address {
    margin-top: 18px;
    color: #111827;
    font-size: 15px;
    font-style: normal;
    line-height: 1.55;
    word-break: break-word;
}

.home-grid {
    display: grid;
    grid-template-columns: 250px minmax(0, 1fr);
    gap: 0;
    padding-left: 0;
    transition: grid-template-columns 0.22s ease;
}

.desktop-sidebar-collapsed .home-grid {
    grid-template-columns: 0 minmax(0, 1fr);
}

.category-rail {
    position: sticky;
    top: 88px;
    z-index: 10;
    width: auto;
    max-width: none;
    height: calc(100vh - 88px);
    overflow-y: auto;
    transform: none;
    border-right: 1px solid #d8d8d8;
    padding-right: 0;
    background: #fff;
    box-shadow: none;
    transition: opacity 0.18s ease;
}

.desktop-sidebar-collapsed .category-rail {
    opacity: 0;
    pointer-events: none;
}

.drawer-top {
    height: 54px;
    display: none;
    align-items: center;
    justify-content: space-between;
    padding: 0 16px;
    border-bottom: 1px solid #e5e7eb;
}

.drawer-top strong {
    color: #111;
    font-size: 16px;
    font-weight: 900;
}

.drawer-top button {
    width: 34px;
    height: 34px;
    border: 1px solid #d1d5db;
    border-radius: 999px;
    background: #fff;
    color: #111;
    font-weight: 900;
    cursor: pointer;
}

.sidebar-quick-links {
    padding: 14px 12px 12px;
}

.sidebar-quick-links a {
    display: flex;
    align-items: center;
    gap: 9px;
    min-height: 36px;
    padding: 4px 0;
    color: #000000;
    font-size: 15px;
    font-weight: 500;
}

.sidebar-quick-links a:hover,
.sidebar-quick-links a:focus {
    color: #000000;
    background: transparent;
}

.quick-icon {
    width: 20px;
    height: 20px;
    display: inline-flex;
    flex: 0 0 20px;
    align-items: center;
    justify-content: center;
    border-radius: 5px;
}

.quick-icon svg {
    width: 18px;
    height: 18px;
    fill: currentColor;
    stroke: currentColor;
    stroke-width: 1.8;
}

.quick-icon.is-coupon {
    color: #2f8f55;
}

.quick-icon.is-offer {
    color: #5d7af2;
}

.quick-icon.is-favourite {
    color: #f04438;
}

.sidebar-quick-links .quick-text {
    margin-top: 12px;
    font-weight: 500;
}

.category-rail ul {
    margin: 0;
    padding: 10px 0 28px;
    border: 0;
    list-style: none;
}

.category-filter {
    padding: 12px 14px 8px;
    border-bottom: 1px solid #eef0f3;
}

.category-filter input {
    width: 100%;
    height: 38px;
    border: 1px solid #d8dee8;
    border-radius: 10px;
    outline: 0;
    padding: 0 12px;
    background: #fff;
    color: #111;
    font-size: 13px;
    font-weight: 700;
}

.category-filter input:focus {
    border-color: #050505;
    box-shadow: 0 0 0 3px rgba(243, 183, 27, 0.18);
}

.category-rail a,
.category-rail button.category-has-icon {
    display: grid;
    grid-template-columns: 22px minmax(0, 1fr) 12px;
    align-items: center;
    gap: 10px;
    width: 100%;
    min-height: 44px;
    padding: 7px 14px;
    border: 0;
    border-radius: 0;
    background: transparent;
    color: #111827;
    text-align: left;
    font: inherit;
    cursor: pointer;
}

.category-rail .category-no-icon {
    grid-template-columns: 1fr 12px;
}

.category-rail .category-no-icon strong {
    white-space: nowrap;
}

.category-rail a:hover,
.category-rail button.category-has-icon:hover,
.category-rail button.category-has-icon:focus {
    background: #f6f6f6;
    color: #000;
}

.category-rail button.category-has-icon:focus {
    outline: 2px solid rgba(243, 183, 27, 0.45);
    outline-offset: -2px;
}

.cat-icon {
    width: 22px;
    height: 22px;
    display: inline-grid;
    place-items: center;
    border-radius: 6px;
    background: #f3f4f6;
    color: #111111;
    font-size: 10px;
    font-weight: 900;
    text-align: center;
}

.category-rail strong,
.category-rail small {
    display: block;
}

.category-rail strong {
    overflow-wrap: anywhere;
    color: #111111;
    font-size: 14px;
    font-weight: 700;
    line-height: 1.18;
}

.category-rail small {
    color: #475569;
    font-size: 11px;
    font-weight: 500;
    line-height: 1.3;
}

.category-rail em {
    color: #475569;
    font-size: 17px;
    font-style: normal;
}

.category-rail .sidebar-quick-links a {
    display: flex;
    grid-template-columns: none;
    width: auto;
    min-height: 36px;
    padding: 4px 0;
    background: transparent;
    color: #000000;
}

.category-rail .sidebar-quick-links a:hover,
.category-rail .sidebar-quick-links a:focus {
    background: transparent;
    color: #000000;
}

.category-panels[hidden],
.category-panel[hidden],
.category-drill-overlay[hidden] {
    display: none !important;
}

.category-drill-overlay {
    position: fixed;
    inset: 0;
    z-index: 59;
    border: 0;
    background: rgba(17, 24, 39, 0.54);
    cursor: default;
}

.category-rail.is-drilling {
    z-index: 60;
}

.category-rail.is-drilling .category-filter,
.category-rail.is-drilling > ul,
.category-rail.is-drilling .deal-card,
.category-rail.is-drilling .sidebar-quick-links {
    display: none;
}

.category-panels {
    padding-bottom: 28px;
}

.category-panel-back {
    width: 100%;
    min-height: 52px;
    display: grid;
    grid-template-columns: 22px 1fr;
    align-items: center;
    gap: 10px;
    border: 0;
    border-bottom: 1px solid #242424;
    background: #111111;
    color: #ffffff;
    padding: 0 16px;
    text-align: left;
    font: inherit;
    font-size: 15px;
    font-weight: 900;
    cursor: pointer;
}

.category-panel-back span {
    font-size: 22px;
    line-height: 1;
}

.category-panel-title {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    min-height: 56px;
    padding: 13px 14px;
    border-bottom: 1px solid #eef0f3;
    background: #ffffff;
}

.category-panel-title strong {
    font-size: 16px;
    font-weight: 900;
    line-height: 1.2;
}

.category-panel-title a {
    display: inline-flex;
    width: auto;
    min-height: 30px;
    grid-template-columns: none;
    padding: 0 12px;
    border: 1px solid #e5e7eb;
    border-radius: 999px;
    background: #fafafa;
    color: #111111;
    font-size: 11px;
    font-weight: 900;
    white-space: nowrap;
}

.category-panel ul {
    padding: 8px 0 16px;
}

.category-panel a {
    grid-template-columns: minmax(0, 1fr) 14px;
    min-height: 48px;
    padding: 9px 16px;
}

.category-panel a strong {
    font-size: 14px;
    font-weight: 800;
}

.category-panel a small {
    margin-top: 3px;
    color: #64748b;
    font-size: 11px;
}

.category-panel .subcategory-view-all {
    margin: 6px 10px 8px;
    width: calc(100% - 20px);
    border: 1px solid #e5e7eb;
    border-radius: 12px;
    background: #f8fafc;
}

.deal-card {
    display: none !important;
}

.deal-card small {
    color: #667085;
}

.home-main {
    min-width: 0;
}

.grocery-hero {
    position: relative;
    min-height: 520px;
    display: grid;
    grid-template-columns: minmax(430px, 0.9fr) minmax(520px, 1.1fr);
    align-items: center;
    gap: 34px;
    overflow: hidden;
    padding: 72px 70px 74px 64px;
    background:
        radial-gradient(circle at 84% 18%, rgba(255, 183, 0, 0.34), transparent 28%),
        linear-gradient(135deg, #ffffff 0%, #f2f2f0 42%, #050505 100%);
}

.grocery-copy {
    max-width: 600px;
    display: grid;
    grid-template-rows: 148px 52px;
    align-content: center;
    gap: 24px;
}

.grocery-copy h1 {
    max-width: 560px;
    min-height: 0;
    height: 100%;
    display: flex;
    align-items: end;
    margin: 0;
    color: #050505;
    font-size: clamp(34px, 3.4vw, 54px);
    font-weight: 900;
    line-height: 1.16;
    letter-spacing: 0;
    transition: opacity 0.18s ease, transform 0.18s ease;
}

.grocery-copy h1.is-changing {
    opacity: 0;
    transform: translateY(6px);
}

.hero-search {
    position: relative;
    width: min(100%, 640px);
    height: 100%;
    display: grid;
    grid-template-columns: 1fr 54px;
    overflow: hidden;
    border: 1px solid #d5a31b;
    border-radius: 7px;
    background: #fff;
    box-shadow: 0 8px 22px rgba(143, 96, 0, 0.14);
}

.live-search-panel {
    position: absolute;
    top: calc(100% + 10px);
    left: 0;
    right: 0;
    z-index: 80;
    max-height: 440px;
    overflow-y: auto;
    padding: 10px;
    border: 1px solid #e2e8f0;
    border-radius: 16px;
    background: rgba(255, 255, 255, 0.98);
    box-shadow: 0 24px 55px rgba(15, 23, 42, 0.18);
    backdrop-filter: blur(18px);
}

.live-search-section + .live-search-section {
    margin-top: 10px;
    padding-top: 10px;
    border-top: 1px solid #eef2f7;
}

.live-search-section p {
    margin: 0 0 8px;
    color: #64748b;
    font-size: 11px;
    font-weight: 900;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.live-search-product,
.live-search-category {
    display: grid;
    align-items: center;
    gap: 12px;
    padding: 10px;
    border-radius: 12px;
    color: #111;
}

.live-search-product {
    grid-template-columns: 58px 1fr;
}

.live-search-category {
    grid-template-columns: 1fr;
}

.live-search-product:hover,
.live-search-category:hover {
    background: #fff7dc;
}

.live-search-product img,
.live-search-fallback {
    width: 58px;
    height: 58px;
    border-radius: 12px;
    object-fit: cover;
    background: #f3f4f6;
}

.live-search-product strong,
.live-search-category strong {
    display: block;
    color: #111;
    font-size: 14px;
    font-weight: 900;
    line-height: 1.25;
}

.live-search-product small,
.live-search-category small {
    display: block;
    margin-top: 2px;
    color: #64748b;
    font-size: 12px;
    line-height: 1.35;
}

.live-search-product em {
    display: block;
    margin-top: 4px;
    color: #111;
    font-size: 13px;
    font-style: normal;
    font-weight: 900;
}

.live-search-empty {
    padding: 16px;
    color: #64748b;
    font-size: 14px;
    font-weight: 700;
    text-align: center;
}

.hero-search input {
    min-width: 0;
    border: 0;
    outline: 0;
    padding: 0 16px;
    color: #111827;
    font-size: 16px;
    font-weight: 500;
}

.hero-search button {
    position: relative;
    border: 0;
    background: linear-gradient(180deg, #050505, #050505);
    cursor: pointer;
}

.hero-search button::before {
    content: "";
    position: absolute;
    top: 13px;
    left: 14px;
    width: 16px;
    height: 16px;
    border: 3px solid #111;
    border-radius: 50%;
}

.hero-search button::after {
    content: "";
    position: absolute;
    top: 29px;
    left: 31px;
    width: 12px;
    height: 3px;
    border-radius: 999px;
    background: #111;
    transform: rotate(45deg);
}

.hero-collage {
    position: relative;
    height: 390px;
}

.collage-card {
    position: absolute;
    overflow: hidden;
    border-radius: 10px;
    display: block;
    object-fit: cover;
    background: #fff;
    box-shadow: 0 5px 16px rgba(15, 23, 42, 0.18);
}

.collage-main {
    left: 0;
    top: 98px;
    width: 350px;
    height: 230px;
}

.collage-small.one {
    right: 286px;
    top: 24px;
    width: 190px;
    height: 140px;
}

.collage-small.two {
    right: 286px;
    bottom: 16px;
    width: 190px;
    height: 206px;
}

.collage-tall {
    right: 28px;
    top: 36px;
    width: 220px;
    height: 276px;
}

.collage-wide {
    right: 0;
    bottom: 28px;
    width: 230px;
    height: 116px;
}

.promise-row {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 24px;
    width: min(1180px, calc(100% - 72px));
    margin: 42px auto 0;
}

.promise-card {
    min-height: 108px;
    display: grid;
    grid-template-columns: 56px 1fr;
    align-items: center;
    gap: 16px;
    padding: 22px 24px;
    border: 1px solid #e5e7eb;
    border-radius: 9px;
    background: #fff;
    box-shadow: 0 2px 10px rgba(15, 23, 42, 0.04);
}

.promise-card span {
    width: 42px;
    height: 42px;
    display: grid;
    place-items: center;
    border-radius: 8px;
    background: #f3f4f6;
    color: #111827;
    font-weight: 900;
}

.promise-card p {
    margin: 0;
    color: #344054;
    font-size: 15px;
    line-height: 1.45;
}

.promise-card strong {
    display: inline;
    color: #000;
    font-weight: 900;
}

.mobile-bottom-nav {
    display: none;
}

.hero-button,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 48px;
    margin-top: 28px;
    padding: 0 24px;
    border: 1px solid var(--taeef-blue);
    border-radius: 6px;
    background: var(--taeef-blue);
    color: #fff;
    font-weight: 900;
    cursor: pointer;
}

.hero-button b {
    margin-left: 14px;
}

.laptop-art {
    position: absolute;
    top: 0;
    right: 0;
    width: 345px;
    height: 170px;
    transform: skew(-18deg) rotate(-2deg);
    border-radius: 0 0 18px 22px;
    background: linear-gradient(135deg, #d8d9dc, #6c7079 58%, #1e2430);
    box-shadow: -30px 32px 80px rgba(0, 0, 0, 0.55);
}

.laptop-art::after {
    content: "";
    position: absolute;
    top: 66px;
    left: 136px;
    width: 42px;
    height: 48px;
    border-radius: 50% 50% 46% 46%;
    background: rgba(0, 0, 0, 0.36);
}

.phone-art {
    position: absolute;
    right: 115px;
    bottom: 62px;
    width: 300px;
    height: 150px;
    transform: rotate(16deg);
    border-radius: 28px;
    background: linear-gradient(135deg, #1e2633, #aab0ba);
    box-shadow: -24px 26px 70px rgba(0, 0, 0, 0.55);
}

.phone-art::before {
    content: "";
    position: absolute;
    top: 22px;
    left: 24px;
    width: 82px;
    height: 82px;
    border-radius: 24px;
    background:
        radial-gradient(circle at 24px 24px, #0a0f18 0 10px, #e9edf4 11px 18px, transparent 19px),
        radial-gradient(circle at 58px 24px, #0a0f18 0 10px, #e9edf4 11px 18px, transparent 19px),
        radial-gradient(circle at 24px 58px, #0a0f18 0 10px, #e9edf4 11px 18px, transparent 19px),
        rgba(255, 255, 255, 0.18);
}

.watch-art {
    position: absolute;
    right: 390px;
    bottom: 42px;
    width: 86px;
    height: 105px;
    border-radius: 22px;
    background: #07101b;
    box-shadow: 0 25px 55px rgba(0, 0, 0, 0.5);
}

.watch-art::before,
.watch-art::after {
    content: "";
    position: absolute;
    left: 26px;
    width: 34px;
    height: 36px;
    border-radius: 12px;
    background: #d8dce3;
}

.watch-art::before {
    top: -31px;
}

.watch-art::after {
    bottom: -31px;
}

.buds-art {
    position: absolute;
    right: 72px;
    bottom: 85px;
    width: 82px;
    height: 52px;
    border-radius: 30px;
    background:
        radial-gradient(circle at 25px 20px, #e5e7eb 0 12px, #fff 13px 23px, transparent 24px),
        radial-gradient(circle at 58px 20px, #e5e7eb 0 12px, #fff 13px 23px, transparent 24px);
}

.headphone-art {
    position: absolute;
    top: 70px;
    right: 280px;
    width: 210px;
    height: 205px;
    border: 26px solid #070b11;
    border-bottom-color: transparent;
    border-radius: 130px 130px 70px 70px;
    transform: rotate(-12deg);
    filter: drop-shadow(0 35px 35px rgba(0, 0, 0, 0.55));
}

.headphone-art::before,
.headphone-art::after {
    content: "";
    position: absolute;
    bottom: 4px;
    width: 58px;
    height: 86px;
    border-radius: 28px;
    background: linear-gradient(135deg, #202633, #05070b);
}

.headphone-art::before {
    left: -30px;
}

.headphone-art::after {
    right: -30px;
}

.trust-panel {
    display: grid;
    border: 1px solid var(--taeef-line);
    border-radius: 7px;
    background: #fff;
}

.trust-item {
    display: grid;
    grid-template-columns: 46px 1fr;
    align-content: center;
    column-gap: 14px;
    min-height: 111px;
    padding: 18px;
    border-bottom: 1px solid var(--taeef-line);
}

.trust-item:last-child {
    border-bottom: 0;
}

.trust-item span {
    grid-row: span 2;
    width: 40px;
    height: 40px;
    display: inline-grid;
    place-items: center;
    border-radius: 7px;
    background: #eef4ff;
    color: var(--taeef-blue);
    font-size: 20px;
}

.trust-item strong {
    font-size: 14px;
    font-weight: 900;
}

.trust-item small {
    color: var(--taeef-muted);
    font-size: 13px;
}

.brand-strip {
    display: grid;
    grid-template-columns: repeat(8, 1fr) 140px;
    display: none;
    margin-top: 32px;
    border: 1px solid var(--taeef-line);
    border-radius: 6px;
    overflow: hidden;
}

.brand-strip a {
    min-height: 58px;
    display: grid;
    place-items: center;
    border-right: 1px solid var(--taeef-line);
    color: #101828;
    font-size: 19px;
    font-weight: 900;
}

.brand-strip a:nth-child(3),
.brand-strip .view-all {
    color: var(--taeef-blue);
}

.brand-strip .view-all {
    border-right: 0;
    font-size: 13px;
}

.home-section {
    width: min(1180px, calc(100% - 72px));
    margin: 42px auto 0;
}

.product-section {
    width: min(1368px, calc(100% - 48px));
    margin-top: 44px;
    padding: 20px 24px 28px;
    border: 1px solid #e6ebf3;
    border-radius: 8px;
    background: #fff;
    box-shadow: 0 1px 0 rgba(15, 23, 42, 0.03);
}

.section-heading {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 16px;
    margin-bottom: 20px;
}

.section-heading h2 {
    margin: 0;
    color: #101828;
    font-size: 22px;
    font-weight: 500;
    line-height: 1.15;
}

.product-section .section-heading {
    justify-content: space-between;
    position: relative;
    margin-bottom: 22px;
    padding-bottom: 17px;
    border-bottom: 1px solid #e6ebf3;
}

.product-section .section-heading::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: -1px;
    width: 120px;
    height: 2px;
    border-radius: 999px;
    background: #050505;
}

.product-section .section-heading h2 {
    font-size: 22px;
    font-weight: 900;
}

.product-section .section-heading a {
    position: static;
    min-height: 34px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0 18px;
    border-radius: 4px;
    background: #111;
    color: #fff;
    font-size: 13px;
}

.product-slider {
    position: relative;
}

.product-slider-arrow {
    position: absolute;
    top: 50%;
    z-index: 3;
    width: 44px;
    height: 44px;
    display: inline-grid;
    place-items: center;
    transform: translateY(-50%);
    border: 1px solid #dbe3ef;
    border-radius: 50%;
    background: #fff;
    color: #111;
    box-shadow: 0 12px 32px rgba(15, 23, 42, 0.16);
    cursor: pointer;
    transition: background 0.18s ease, color 0.18s ease, transform 0.18s ease;
}

.product-slider-arrow svg {
    width: 20px;
    height: 20px;
}

.product-slider-arrow i {
    color: currentColor;
    font-size: 18px;
    line-height: 1;
}

.product-slider-arrow:hover,
.product-slider-arrow:focus-visible {
    background: #111;
    color: #fff;
    outline: none;
    transform: translateY(-50%) scale(1.04);
}

.product-slider-prev {
    left: -22px;
}

.product-slider-next {
    right: -22px;
}

.section-heading a {
    position: absolute;
    right: max(48px, calc((100vw - 1420px) / 2));
    color: var(--taeef-blue);
    font-weight: 900;
}

.category-grid {
    display: grid;
    grid-template-columns: repeat(8, minmax(0, 1fr));
    gap: 16px;
}

.category-tile {
    min-height: 178px;
    display: grid;
    align-content: center;
    justify-items: center;
    gap: 14px;
    border: 1px solid var(--taeef-line);
    border-radius: 7px;
    background: linear-gradient(180deg, #fbfcff, #f5f6f9);
    color: #101828;
    font-size: 13px;
    font-weight: 900;
    text-align: center;
}

.category-tile img {
    width: 108px;
    height: 92px;
    display: block;
    object-fit: cover;
    border-radius: 12px;
    box-shadow: 0 10px 24px rgba(15, 23, 42, 0.08);
}

.category-tile:hover {
    border-color: #cbd5e1;
    background: #fff;
    box-shadow: 0 16px 34px rgba(15, 23, 42, 0.08);
    transform: translateY(-2px);
}

.product-art,
.demo-product-image,
.newsletter-products {
    position: relative;
    display: block;
}

.product-art {
    width: 72px;
    height: 78px;
}

.product-art-1,
.phone,
.product-art-2,
.product-art-3,
.headphone,
.product-art-4,
.watch,
.product-art-5,
.power,
.product-art-6,
.keyboard,
.earbuds {
    background-repeat: no-repeat;
}

.product-art-1,
.phone {
    border-radius: 14px;
    background: linear-gradient(135deg, #041028, #0e62dc);
    box-shadow: inset 8px 0 18px rgba(255, 255, 255, 0.16);
}

.product-art-2 {
    height: 52px;
    border-radius: 6px;
    background: linear-gradient(135deg, #101828, #3568af);
    box-shadow: 0 16px 0 -8px #2c3442;
}

.product-art-3,
.headphone {
    border: 10px solid #2b3038;
    border-bottom-color: transparent;
    border-radius: 46px;
}

.product-art-4,
.watch {
    width: 58px;
    border-radius: 15px;
    background: linear-gradient(135deg, #030712, #334155);
}

.product-art-5,
.power {
    width: 60px;
    height: 66px;
    border-radius: 10px;
    background: linear-gradient(135deg, #1f2937, #d1d5db);
}

.product-art-6 {
    width: 76px;
    height: 54px;
    border-radius: 24px;
    background: linear-gradient(135deg, #111827, #475569);
}

.product-section .woocommerce ul.products,
.demo-product-grid {
    display: grid;
    grid-template-columns: repeat(6, minmax(0, 1fr));
    gap: 20px;
    align-items: stretch;
}

.woocommerce ul.products::before,
.woocommerce ul.products::after {
    display: none;
}

.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product,
.demo-product {
    position: relative;
    width: 100% !important;
    float: none !important;
    min-width: 0;
    height: 450px;
    min-height: 450px;
    margin: 0 !important;
    padding: 14px;
    border: 1px solid var(--taeef-line);
    border-radius: 12px;
    background: #fff;
    overflow: hidden;
    transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}

.woocommerce ul.products[class*="columns-"] li.product,
.woocommerce-page ul.products[class*="columns-"] li.product {
    width: 100% !important;
    margin-right: 0 !important;
    clear: none !important;
}

.woocommerce ul.products li.product .woocommerce-LoopProduct-link {
    display: grid;
    grid-template-rows: 168px 48px 34px 18px 36px;
    row-gap: 6px;
    min-height: 310px;
    color: inherit;
}

.woocommerce ul.products li.product:hover,
.woocommerce-page ul.products li.product:hover,
.demo-product:hover {
    transform: translateY(-3px);
    border-color: #cbd5e1;
    box-shadow: 0 18px 38px rgba(15, 23, 42, 0.1);
}

.woocommerce ul.products li.product {
    display: flex;
    flex-direction: column;
}

.woocommerce ul.products li.product .add_to_cart_button,
.woocommerce ul.products li.product .product_type_simple {
    margin-top: auto;
}

.woocommerce ul.products li.product a img,
.woocommerce-page ul.products li.product a img,
.product-section .woocommerce ul.products li.product img {
    width: 100%;
    height: 168px !important;
    max-height: 168px !important;
    aspect-ratio: auto;
    object-fit: cover !important;
    padding: 0;
    border-radius: 10px;
    background: #f8fafc;
    margin: 0 !important;
}

.woocommerce ul.products li.product .woocommerce-loop-product__title,
.demo-product h3 {
    min-height: 0;
    height: 48px;
    margin: 0;
    color: #101828;
    font-size: 13px;
    font-weight: 900;
    line-height: 1.25;
    overflow: hidden;
}

.demo-product p,
.taeef-loop-excerpt {
    min-height: 0;
    height: 34px;
    margin: 0;
    color: #667085;
    font-size: 12px;
    line-height: 1.35;
    overflow: hidden;
}

.woocommerce span.onsale,
.sale-badge {
    position: absolute;
    top: 14px;
    left: 14px;
    z-index: 2;
    min-height: 0;
    padding: 4px 8px;
    border-radius: 3px;
    background: var(--taeef-blue);
    color: #fff;
    font-size: 11px;
    font-weight: 900;
    line-height: 1;
}

.demo-product button {
    position: absolute;
    top: 12px;
    right: 14px;
    border: 0;
    background: transparent;
    color: #98a2b3;
    font-size: 20px;
}

.demo-product-image {
    width: 100%;
    height: 120px;
    margin-top: 20px;
    background-position: center;
}

.earbuds {
    background:
        radial-gradient(circle at 42% 42%, #f8fafc 0 18px, #d9dee7 19px 28px, transparent 29px),
        radial-gradient(circle at 62% 42%, #f8fafc 0 18px, #d9dee7 19px 28px, transparent 29px),
        linear-gradient(180deg, transparent 0 64px, #f8fafc 65px 102px, transparent 103px);
}

.rating {
    color: #f59e0b;
    font-size: 12px;
    font-weight: 900;
}

.woocommerce .star-rating {
    color: #f59e0b;
    font-size: 13px;
    height: 16px;
    margin: 0;
}

.rating span {
    color: #667085;
    font-weight: 600;
}

.demo-product strong,
.woocommerce div.product p.price,
.woocommerce div.product span.price,
.woocommerce ul.products li.product .price {
    display: block;
    min-height: 0;
    height: 36px;
    margin-top: 0;
    color: #101828;
    font-size: 15px;
    font-weight: 900;
    line-height: 1.3;
    overflow: hidden;
}

.demo-product del,
.woocommerce ul.products li.product .price del {
    display: block;
    margin-left: 0;
    color: #98a2b3;
    font-size: 12px;
    font-weight: 700;
}

.demo-product > a,
.woocommerce ul.products li.product .button {
    width: 100%;
    min-height: 34px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-top: auto;
    border: 1px solid var(--taeef-blue);
    border-radius: 7px;
    background: #111;
    color: #fff;
    font-size: 13px;
    font-weight: 900;
    line-height: 1;
    text-align: center;
}

.woocommerce ul.products li.product .taeef-buy-now {
    width: 100%;
    min-height: 34px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-top: 8px;
    border: 1px solid #111;
    border-radius: 7px;
    background: #fff;
    color: #111;
    font-size: 13px;
    font-weight: 950;
    line-height: 1;
    text-align: center;
}

.woocommerce ul.products li.product .taeef-buy-now:hover,
.woocommerce ul.products li.product .taeef-buy-now:focus {
    background: #050505;
    border-color: #050505;
    color: #111;
}

.woocommerce ul.products li.product .button:hover {
    background: #050505;
    border-color: #050505;
    color: #111;
}

.product-section .woocommerce ul.products {
    grid-template-columns: none !important;
    grid-auto-flow: column;
    grid-auto-columns: calc((100% - 60px) / 4);
    overflow-x: auto;
    overflow-y: hidden;
    padding: 0 2px 8px;
    scroll-behavior: smooth;
    scroll-snap-type: x mandatory;
    scrollbar-width: none;
}

.product-section .woocommerce ul.products::-webkit-scrollbar {
    display: none;
}

.product-section .woocommerce ul.products li.product {
    scroll-snap-align: start;
}

.taeef-shop-layout {
    width: min(1180px, calc(100% - 72px));
    margin-inline: auto;
}

.taeef-shop-layout .woocommerce-products-header__title,
.taeef-shop-layout .page-title {
    margin: 0 0 24px;
    color: #111;
    font-size: 42px;
    line-height: 1.1;
}

.page-content {
    width: min(1060px, calc(100% - 48px));
    margin: 72px auto;
}

.page-content .entry-title {
    margin: 0 0 18px;
    color: #050505;
    font-size: clamp(34px, 5vw, 64px);
    font-weight: 900;
    line-height: 1.02;
}

.taeef-legal-page {
    width: min(980px, calc(100% - 48px));
}

.taeef-legal-page article {
    display: grid;
    grid-template-columns: 280px minmax(0, 1fr);
    gap: 54px;
    align-items: start;
    padding: 46px;
    border: 1px solid #e4e9f2;
    border-radius: 16px;
    background: #fff;
    box-shadow: 0 24px 70px rgba(15, 23, 42, 0.07);
}

.taeef-legal-page .entry-header {
    position: sticky;
    top: 92px;
}

.legal-kicker {
    display: inline-flex;
    margin-bottom: 14px;
    color: #9a6a00;
    font-size: 12px;
    font-weight: 900;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.taeef-legal-page .entry-title {
    margin-bottom: 14px;
    font-size: clamp(34px, 4vw, 52px);
}

.legal-updated {
    margin: 0;
    color: #667085;
    font-size: 14px;
    font-weight: 700;
}

.taeef-legal-page .entry-content {
    color: #344054;
    font-size: 16px;
    line-height: 1.8;
}

.taeef-legal-page .entry-content > h2:first-child {
    margin-top: 0;
}

.taeef-legal-page .entry-content h2 {
    margin: 0 0 18px;
    color: #111827;
    font-size: 28px;
    font-weight: 900;
    line-height: 1.15;
}

.taeef-legal-page .entry-content h3 {
    margin: 30px 0 8px;
    padding-top: 22px;
    border-top: 1px solid #edf1f7;
    color: #111827;
    font-size: 18px;
    font-weight: 900;
}

.taeef-legal-page .entry-content p {
    margin: 0 0 14px;
}

.taeef-search-page {
    width: 100%;
    margin: 0;
    padding: 0;
}

.search-layout {
    display: grid;
    grid-template-columns: 250px minmax(0, 1fr);
    gap: 0;
    align-items: start;
}

.mobile-filter-toggle,
.facet-close,
.filter-drawer-backdrop {
    display: none;
}

.search-content {
    width: calc(100% - 48px);
    margin: 24px 24px 64px 22px;
}

.search-hero {
    display: grid;
    grid-template-columns: 1fr;
    justify-items: start;
    gap: 16px;
    margin-bottom: 22px;
    padding: 0;
    border: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
    text-align: left;
}

.search-hero span {
    display: inline-block;
    margin-bottom: 8px;
    color: #775a00;
    font-size: 12px;
    font-weight: 900;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.search-hero h1 {
    margin: 0;
    color: #111111;
    font-size: 18px;
    font-weight: 900;
    line-height: 1.25;
}

.search-hero p {
    margin: 10px 0 0;
    color: #667085;
    font-size: 14px;
    font-weight: 700;
}

.search-refine {
    width: min(100%, 760px);
    justify-self: start;
    height: 50px;
    display: grid;
    grid-template-columns: 1fr 104px;
    overflow: hidden;
    border: 1px solid #d6dce7;
    border-radius: 10px;
    background: #ffffff;
}

.search-refine input {
    min-width: 0;
    border: 0;
    padding: 0 16px;
    color: #111827;
    font-size: 14px;
    font-weight: 700;
    outline: 0;
}

.search-refine button {
    border: 0;
    background: #111111;
    color: #ffffff;
    font-size: 13px;
    font-weight: 900;
    cursor: pointer;
}

.search-refine:focus-within {
    border-color: #050505;
    box-shadow: 0 0 0 4px rgba(243, 183, 27, 0.16);
}

.search-results-panel {
    border: 0;
    border-radius: 0;
    background: transparent;
}

.search-facets {
    position: sticky;
    top: 88px;
    min-height: calc(100vh - 88px);
    overflow-y: auto;
    border-right: 1px solid #d8d8d8;
    background: #ffffff;
}

.search-facets form {
    margin: 0;
}

.facet-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    min-height: 54px;
    padding: 0 16px;
    border-bottom: 1px solid #e5e7eb;
}

.facet-head strong {
    color: #111111;
    font-size: 16px;
    font-weight: 900;
}

.facet-head a {
    color: #475569;
    font-size: 12px;
    font-weight: 900;
}

.facet-group {
    padding: 14px;
    border-bottom: 1px solid #edf0f4;
}

.facet-group h2 {
    margin: 0 0 12px;
    color: #111111;
    font-size: 13px;
    font-weight: 900;
}

.facet-option {
    min-height: 44px;
    display: grid;
    grid-template-columns: 22px minmax(0, 1fr) auto;
    align-items: center;
    gap: 10px;
    margin: 0 -14px;
    padding: 7px 14px;
    color: #111827;
    font-size: 14px;
    font-weight: 800;
    cursor: pointer;
}

.facet-option .facet-label {
    white-space: nowrap;
}

.facet-group:last-of-type .facet-option {
    grid-template-columns: 22px minmax(160px, 1fr);
}

.facet-availability .facet-stock-option {
    display: flex;
    align-items: center;
    gap: 10px;
}

.facet-availability .facet-stock-option .facet-label {
    min-width: max-content;
    width: auto;
    overflow: visible;
    white-space: nowrap;
}

.facet-option input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.facet-option:hover,
.facet-option:focus-within {
    background: #f6f6f6;
}

.facet-code {
    width: 22px;
    height: 22px;
    display: inline-grid;
    place-items: center;
    border-radius: 6px;
    background: #f3f4f6;
    color: #111111;
    font-size: 10px;
    font-weight: 900;
}

.facet-option input:checked + .facet-code {
    background: #111111;
    color: #ffffff;
}

.facet-label {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
}

.facet-option em {
    margin-left: auto;
    color: #94a3b8;
    font-size: 12px;
    font-style: normal;
    font-weight: 800;
}

.facet-price {
    display: grid;
    grid-template-columns: 1fr;
    gap: 10px;
}

.facet-price label span {
    display: block;
    margin-bottom: 6px;
    color: #667085;
    font-size: 11px;
    font-weight: 900;
}

.facet-price input {
    width: 100%;
    height: 38px;
    border: 1px solid #d6dce7;
    border-radius: 10px;
    padding: 0 10px;
    color: #111827;
    font-size: 13px;
    font-weight: 800;
}

.facet-submit {
    width: calc(100% - 28px);
    min-height: 42px;
    margin: 14px;
    border: 0;
    border-radius: 9px;
    background: #111111;
    color: #ffffff;
    font-size: 13px;
    font-weight: 900;
    cursor: pointer;
}

.search-results-panel {
    min-width: 0;
    padding: 0;
}

.results-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 18px;
}

.results-toolbar strong,
.results-toolbar span {
    display: block;
}

.results-toolbar strong {
    color: #111111;
    font-size: 18px;
    font-weight: 900;
}

.results-toolbar span,
.results-toolbar label span {
    color: #667085;
    font-size: 12px;
    font-weight: 800;
}

.results-toolbar label {
    display: flex;
    align-items: center;
    gap: 10px;
}

.results-toolbar select {
    min-width: 178px;
    height: 40px;
    border: 1px solid #d6dce7;
    border-radius: 8px;
    background: #ffffff;
    color: #111827;
    padding: 0 10px;
    font-size: 13px;
    font-weight: 800;
}

.taeef-search-page ul.products {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(210px, 1fr));
    gap: 28px 20px;
    margin: 0;
    padding: 0;
}

.taeef-search-page .woocommerce ul.products li.product,
.taeef-search-page ul.products li.product {
    position: relative;
    display: flex;
    flex-direction: column;
    width: 100% !important;
    float: none !important;
    height: 368px;
    min-height: 368px;
    margin: 0 !important;
    padding: 12px;
    border: 1px solid #e7ebf2;
    border-radius: 12px;
    background: #ffffff;
    overflow: visible;
    box-shadow: 0 10px 24px rgba(15, 23, 42, 0.04);
}

.taeef-search-page .woocommerce ul.products li.product:hover,
.taeef-search-page ul.products li.product:hover {
    border-color: #d6dce7;
    box-shadow: 0 16px 34px rgba(15, 23, 42, 0.08);
    transform: translateY(-2px);
}

.taeef-search-page .woocommerce ul.products li.product a img,
.taeef-search-page ul.products li.product a img {
    width: 100%;
    height: 160px !important;
    max-height: 160px !important;
    object-fit: contain !important;
    padding: 10px;
    border-radius: 10px;
    background: #f8fafc;
    margin: 0 0 10px !important;
}

.taeef-search-page ul.products li.product .woocommerce-LoopProduct-link {
    display: grid;
    grid-template-rows: 170px 50px 18px 44px;
    row-gap: 7px;
    min-height: 292px;
    color: inherit;
}

.taeef-search-page ul.products li.product .woocommerce-loop-product__title {
    height: 50px;
    margin: 0;
    color: #101828;
    font-size: 15px;
    font-weight: 650;
    line-height: 1.28;
    overflow: hidden;
}

.taeef-search-page .taeef-loop-excerpt {
    display: none;
}

.taeef-search-page ul.products li.product .star-rating {
    color: #f59e0b;
    font-size: 13px;
    height: 18px;
    margin: 0;
    line-height: 18px;
}

.taeef-search-page ul.products li.product .price {
    display: block;
    height: 44px;
    margin: 0;
    color: #101828;
    font-size: 18px;
    font-weight: 900;
    line-height: 1.3;
    overflow: hidden;
}

.taeef-search-page ul.products li.product .price del {
    display: block;
    color: #98a2b3;
    font-size: 12px;
    font-weight: 700;
}

.taeef-search-page ul.products li.product .button {
    position: absolute;
    top: 126px;
    right: 20px;
    z-index: 3;
    width: 54px;
    min-width: 54px;
    height: 54px;
    min-height: 54px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin: 0;
    border: 2px solid #6d28d9;
    border-radius: 999px;
    background: #ffffff;
    color: #6d28d9;
    font-size: 0;
    font-weight: 900;
    line-height: 1;
    text-align: center;
    box-shadow: 0 8px 20px rgba(109, 40, 217, 0.12);
}

.taeef-search-page ul.products li.product .button:hover {
    background: #6d28d9;
    border-color: #6d28d9;
    color: #ffffff;
}

.taeef-search-page ul.products li.product .button::before {
    content: "+";
    font-size: 38px;
    font-weight: 400;
    line-height: 0.8;
}

.taeef-search-page span.onsale {
    position: absolute;
    top: 12px;
    left: 12px;
    z-index: 2;
    min-height: 0;
    padding: 4px 8px;
    border-radius: 3px;
    background: #111111;
    color: #ffffff;
    font-size: 11px;
    font-weight: 900;
    line-height: 1;
}

.taeef-search-page ul.products li.product .taeef-buy-now {
    width: 100%;
    min-height: 38px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin: auto 0 0;
    border: 1px solid #111111;
    border-radius: 9px;
    background: #111111;
    color: #ffffff;
    font-size: 13px;
    font-weight: 900;
    line-height: 1;
    text-align: center;
}

.taeef-search-page ul.products li.product .taeef-buy-now:hover,
.taeef-search-page ul.products li.product .taeef-buy-now:focus {
    background: #050505;
    border-color: #050505;
    color: #111111;
}

.taeef-search-page .page-numbers {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 38px;
    height: 38px;
    margin: 22px 4px 0 0;
    border: 1px solid #e5e7eb;
    border-radius: 8px;
    color: #111827;
    font-size: 13px;
    font-weight: 900;
}

.taeef-search-page .page-numbers.current {
    background: #111111;
    color: #ffffff;
}

.search-empty {
    padding: 54px 20px;
    text-align: center;
}

.search-empty h2 {
    margin: 0 0 8px;
    color: #111111;
    font-size: 24px;
    font-weight: 900;
}

.search-empty p {
    margin: 0 0 18px;
    color: #667085;
}

.search-empty a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 42px;
    padding: 0 18px;
    border-radius: 8px;
    background: #111111;
    color: #ffffff;
    font-size: 13px;
    font-weight: 900;
}

.single-product .product {
    width: min(1180px, calc(100% - 72px));
    margin: 42px auto;
    display: grid;
    grid-template-columns: minmax(320px, 0.9fr) minmax(360px, 1.1fr);
    gap: 52px;
    align-items: start;
}

.single-product div.product div.images,
.single-product div.product div.summary {
    width: auto;
    float: none;
}

.single-product div.product div.images img {
    border-radius: 18px;
    background: #f8fafc;
    box-shadow: 0 20px 45px rgba(15, 23, 42, 0.08);
}

.single-product div.product .product_title {
    color: #111;
    font-size: clamp(34px, 4vw, 56px);
    line-height: 1.05;
    margin-bottom: 14px;
}

.single-product div.product .woocommerce-product-rating {
    margin-bottom: 18px;
}

.single-product div.product p.price {
    color: #111;
    font-size: 30px;
    font-weight: 900;
}

.single-product div.product .woocommerce-product-details__short-description {
    color: #475569;
    font-size: 16px;
    line-height: 1.7;
}

.single-product div.product form.cart .button {
    min-height: 50px;
    padding-inline: 28px;
    border-radius: 10px;
    background: #111;
    color: #fff;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li {
    border-radius: 8px 8px 0 0;
}

.woocommerce div.product .woocommerce-tabs .panel {
    color: #334155;
    line-height: 1.75;
}

.newsletter-band {
    position: relative;
    min-height: 132px;
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(320px, 420px) 170px;
    align-items: center;
    gap: 28px;
    width: min(1180px, calc(100% - 72px));
    margin: 42px auto 28px;
    padding: 30px 34px;
    overflow: hidden;
    border: 1px solid #e5e7eb;
    border-radius: 12px;
    background: linear-gradient(90deg, #f7f7f7, #ffffff);
}

.newsletter-band strong {
    color: var(--taeef-blue);
    font-size: 18px;
    letter-spacing: 4px;
}

.newsletter-band h2 {
    max-width: 520px;
    margin: 8px 0 0;
    color: #111;
    font-size: 22px;
    line-height: 1.22;
}

.newsletter-band form {
    display: grid;
    grid-template-columns: 1fr 116px;
    height: 48px;
    border: 1px solid #d8dee8;
    border-radius: 8px;
    background: #fff;
    overflow: hidden;
}

.newsletter-band input {
    border: 0;
    outline: 0;
    padding: 0 18px;
}

.newsletter-band button {
    border: 0;
    margin: 4px;
    border-radius: 6px;
    background: var(--taeef-blue);
    color: #fff;
    font-weight: 900;
}

.newsletter-products {
    height: 104px;
}

.newsletter-products::before {
    content: "";
    position: absolute;
    right: 0;
    top: 0;
    width: 168px;
    height: 120px;
    background:
        radial-gradient(circle at 52% 55%, #111827 0 38px, transparent 39px),
        radial-gradient(circle at 70% 36%, #d7dde8 0 26px, transparent 27px),
        linear-gradient(135deg, #111827, #667085);
    border-radius: 18px;
}

.page-content,
.content-layout,
.taeef-shop-layout {
    padding-block: 48px;
}

.entry-title,
.page-title {
    color: #101828;
}

.entry-card {
    margin-bottom: 24px;
    padding: 24px;
    border: 1px solid var(--taeef-line);
    border-radius: var(--taeef-radius);
    background: #fff;
}

.entry-media img {
    display: block;
    width: 100%;
    border-radius: var(--taeef-radius);
}

.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
    border-top-color: var(--taeef-blue);
    background: #fff;
}

.woocommerce-message::before,
.woocommerce-info::before {
    color: var(--taeef-blue);
}

.site-footer {
    margin-top: 0;
    padding: 0 0 24px;
    background: #fff;
    color: #344054;
}

.footer-benefits {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    width: min(1180px, calc(100% - 72px));
    margin: 0 auto;
    border: 1px solid #e5e7eb;
    border-radius: 10px;
    overflow: hidden;
    background: #fff;
}

.footer-benefits div {
    display: grid;
    grid-template-columns: 38px 1fr;
    align-content: center;
    min-height: 76px;
    padding: 14px 18px;
    border-right: 1px solid #edf0f4;
}

.footer-benefits div:last-child {
    border-right: 0;
}

.footer-benefits span {
    grid-row: span 2;
    color: #101828;
    font-size: 18px;
    font-weight: 900;
}

.footer-benefits strong {
    color: #111;
    font-size: 12px;
    font-weight: 900;
}

.footer-benefits small {
    color: #667085;
    font-size: 11px;
    line-height: 1.35;
}

.footer-grid {
    display: grid;
    grid-template-columns: 1.35fr 0.9fr 1fr 0.9fr;
    gap: 52px;
    width: min(1180px, calc(100% - 72px));
    margin: 0 auto;
    padding: 34px 0 24px;
}

.footer-brand {
    margin: 0 0 12px;
    color: var(--taeef-blue);
    font-size: 32px;
}

.footer-grid p {
    max-width: 245px;
    margin: 0 0 20px;
    color: #344054;
    font-size: 14px;
    line-height: 1.5;
}

.social-row,
.payment-row {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.social-row a,
.payment-row span {
    min-width: 34px;
    height: 32px;
    display: inline-grid;
    place-items: center;
    border-radius: 5px;
    background: #f2f4f7;
    color: #101828;
    font-size: 12px;
    font-weight: 900;
}

.footer-links h3 {
    margin: 0 0 16px;
    color: #101828;
    font-size: 13px;
    font-weight: 900;
}

.footer-links a {
    display: block;
    margin-bottom: 10px;
    color: #667085;
    font-size: 13px;
}

.footer-widgets {
    display: none;
}

.footer-bottom {
    width: min(1180px, calc(100% - 72px));
    margin: 0 auto;
    padding-top: 18px;
    border-top: 1px solid #edf0f4;
    color: #667085;
    font-size: 13px;
}

.footer-bottom p {
    margin: 0;
}

@media (max-width: 1200px) {
    .header-inner {
        grid-template-columns: 42px 180px 1fr auto;
        padding-inline: 24px;
    }

    .home-grid {
        display: block;
        padding-left: 0;
    }

    .category-rail {
        position: fixed;
        left: 0;
        z-index: 60;
        width: 288px;
        max-width: calc(100vw - 44px);
        overflow-y: auto;
        transform: translateX(-100%);
        top: 62px;
        height: calc(100vh - 62px);
        box-shadow: 12px 0 30px rgba(15, 23, 42, 0.08);
        transition: transform 0.24s ease;
    }

    .drawer-top {
        display: flex;
    }

    .drawer-open .category-rail,
    .category-rail.is-open {
        transform: translateX(0);
    }

    .grocery-hero {
        grid-template-columns: 1fr;
        min-height: auto;
        padding: 64px 48px 56px;
    }

    .hero-collage {
        max-width: 720px;
        margin-inline: auto;
    }

    .brand-strip {
        grid-template-columns: repeat(4, 1fr);
    }

    .category-grid,
    .demo-product-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .product-section .woocommerce ul.products {
        grid-template-columns: none !important;
        grid-auto-columns: calc((100% - 40px) / 3);
    }

    .footer-benefits,
    .footer-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        width: min(100% - 48px, 1180px);
    }

    .footer-benefits div {
        border-right: 0;
        border-bottom: 1px solid #edf0f4;
    }

    .footer-bottom {
        width: min(100% - 48px, 1180px);
    }

    .single-product .product {
        width: min(100% - 48px, 1180px);
        grid-template-columns: 1fr;
        gap: 32px;
    }

    .taeef-search-page {
        width: 100%;
    }

    .search-hero {
        grid-template-columns: 1fr;
        align-items: start;
    }

    .search-layout {
        grid-template-columns: 250px minmax(0, 1fr);
    }

    .search-content {
        width: calc(100% - 32px);
        margin: 24px 16px 56px;
    }
}

@media (max-width: 980px) {
    .woocommerce-checkout form.checkout {
        grid-template-columns: 1fr;
    }

    .woocommerce-checkout #order_review {
        grid-column: auto;
        grid-row: auto;
        position: static;
    }
}

@media (max-width: 760px) {
    .taeef-shell,
    .taeef-container {
        width: 100%;
    }

    .header-inner {
        min-height: 62px;
        grid-template-columns: 44px 1fr 44px;
        gap: 8px;
        padding: 8px 16px;
    }

    .site-branding {
        justify-self: center;
    }

    .taeef-logo {
        font-size: 28px;
    }

    .taeef-logo-image {
        width: 126px;
    }

    .header-actions {
        min-width: 44px;
        justify-content: end;
        gap: 0;
    }

    .header-cart-button {
        width: 42px;
        min-width: 42px;
        padding: 0;
        justify-content: center;
    }

    .header-cart-button span {
        display: none;
    }

    .header-cart-button em {
        position: absolute;
        top: -5px;
        right: -5px;
        min-width: 18px;
        height: 18px;
        font-size: 10px;
    }

    .login-button {
        display: none;
    }

    .taeef-cart-drawer {
        width: min(360px, 100vw);
    }

    .cart-drawer-header {
        min-height: 74px;
        padding: 16px 18px;
    }

    .cart-drawer-body {
        padding: 14px 18px;
    }

    .cart-drawer-actions {
        padding: 14px 18px 18px;
    }

    .woocommerce-checkout .page-content,
    .woocommerce-checkout .entry-content,
    .woocommerce-checkout .site-main > .woocommerce,
    .woocommerce-checkout .woocommerce-error,
    .woocommerce-checkout .woocommerce-info,
    .woocommerce-checkout .woocommerce-message {
        width: min(100% - 28px, 680px);
    }

    .woocommerce-checkout .entry-title,
    .woocommerce-checkout h1 {
        margin-top: 26px;
        font-size: 30px;
    }

    .page-content,
    .taeef-legal-page {
        width: min(100% - 28px, 680px);
        margin: 34px auto 54px;
    }

    .taeef-legal-page article {
        display: block;
        padding: 24px 18px;
        border-radius: 14px;
    }

    .taeef-legal-page .entry-header {
        position: static;
        margin-bottom: 24px;
        padding-bottom: 20px;
        border-bottom: 1px solid #edf1f7;
    }

    .taeef-legal-page .entry-title {
        font-size: 34px;
    }

    .taeef-legal-page .entry-content {
        font-size: 15px;
        line-height: 1.75;
    }

    .woocommerce-checkout form.checkout {
        gap: 16px;
    }

    .woocommerce-checkout #customer_details {
        padding: 18px;
        border-radius: 12px;
    }

    .woocommerce-checkout .woocommerce-billing-fields__field-wrapper {
        grid-template-columns: 1fr;
        gap: 10px;
    }

    .woocommerce-checkout #billing_state_field,
    .woocommerce-checkout #billing_city_field {
        grid-column: 1 / -1;
    }

    .woocommerce-checkout #order_review {
        border-radius: 12px;
    }

    .woocommerce-checkout #order_review::before {
        padding: 18px;
        font-size: 20px;
    }

    .woocommerce-checkout .woocommerce-checkout-review-order-table th,
    .woocommerce-checkout .woocommerce-checkout-review-order-table td,
    .woocommerce-checkout #payment ul.payment_methods,
    .woocommerce-checkout #payment div.form-row {
        padding-left: 18px;
        padding-right: 18px;
    }

    .woocommerce-account .page-content,
    .woocommerce-account .entry-content,
    .woocommerce-account .site-main > .woocommerce {
        width: min(100% - 28px, 680px);
    }

    .woocommerce-account .page-content > article,
    .woocommerce-account .entry-content > .woocommerce {
        display: block;
    }

    .woocommerce-account:not(.logged-in) .entry-header,
    .woocommerce-account:not(.logged-in) .entry-content {
        width: min(100% - 28px, 680px);
    }

    .woocommerce-account:not(.logged-in) .entry-title,
    .woocommerce-account:not(.logged-in) h1 {
        margin-bottom: 20px;
        font-size: 36px;
        text-align: left;
    }

    .woocommerce-account:not(.logged-in) .woocommerce .u-columns.col2-set {
        grid-template-columns: 1fr;
        gap: 16px;
    }

    .woocommerce-account:not(.logged-in) .woocommerce .u-column1,
    .woocommerce-account:not(.logged-in) .woocommerce .u-column2 {
        grid-column: 1;
        grid-row: auto;
    }

    .woocommerce-account:not(.logged-in) form.login,
    .woocommerce-account:not(.logged-in) form.register {
        min-height: auto;
        padding: 22px;
        border-radius: 14px;
    }

    .woocommerce-account .entry-content > .woocommerce > .woocommerce-notices-wrapper {
        width: 100%;
    }

    .woocommerce-account .entry-header {
        width: min(100% - 28px, 680px);
        margin: 0 auto;
        padding-top: 26px;
    }

    .woocommerce-account .entry-title,
    .woocommerce-account h1 {
        margin-top: 26px;
        font-size: 30px;
    }

    .woocommerce-account .woocommerce-MyAccount-navigation,
    .woocommerce-account .woocommerce-MyAccount-content {
        width: 100%;
        float: none;
        grid-column: auto;
        grid-row: auto;
    }

    .woocommerce-account .woocommerce-MyAccount-navigation {
        position: relative;
        top: auto;
        z-index: 1;
        height: auto;
        padding: 10px;
        border: 1px solid #e2e8f0;
        border-radius: 12px;
        margin-bottom: 16px;
        overflow-x: auto;
    }

    .woocommerce-account .woocommerce-MyAccount-navigation ul {
        display: flex;
        gap: 8px;
        min-width: max-content;
    }

    .woocommerce-account .woocommerce-MyAccount-navigation li a {
        padding: 0 14px;
        white-space: nowrap;
    }

    .woocommerce-account .woocommerce-MyAccount-content {
        padding: 18px;
        min-height: auto;
    }

    .woocommerce-account .woocommerce-Addresses {
        grid-template-columns: 1fr;
    }

    .woocommerce-account .woocommerce-Addresses .woocommerce-Address:nth-child(1),
    .woocommerce-account .woocommerce-Addresses .woocommerce-Address:nth-child(2) {
        grid-column: 1;
    }

    .woocommerce-account form.login,
    .woocommerce-account form.register,
    .woocommerce-account form.woocommerce-EditAccountForm,
    .woocommerce-account form.woocommerce-address-fields {
        padding: 18px;
    }

    .category-rail {
        top: 74px;
        height: calc(100vh - 74px - 72px);
    }

    .grocery-hero {
        padding: 42px 18px 36px;
        gap: 28px;
    }

    .grocery-copy h1 {
        font-size: 36px;
        line-height: 1.14;
    }

    .grocery-copy {
        grid-template-rows: 132px 52px;
        gap: 20px;
    }

    .hero-search {
        width: 100%;
    }

    .hero-collage {
        height: 260px;
        transform: scale(0.82);
        transform-origin: top center;
        margin-bottom: -38px;
    }

    .promise-row,
    .home-section,
    .newsletter-band,
    .footer-benefits,
    .footer-grid,
    .footer-bottom {
        width: min(100% - 32px, 1180px);
    }

    .promise-row {
        grid-template-columns: 1fr;
        gap: 14px;
        margin-top: 28px;
    }

    .promise-card {
        min-height: 88px;
    }

    .brand-strip,
    .category-grid,
    .demo-product-grid,
    .footer-benefits,
    .footer-grid {
        grid-template-columns: 1fr 1fr;
    }

    .product-section {
        width: min(100% - 24px, 680px);
        padding: 16px 14px 18px;
        margin-top: 30px;
    }

    .product-section .section-heading {
        margin-bottom: 16px;
    }

    .product-section .section-heading h2 {
        font-size: 19px;
    }

    .product-section .section-heading a {
        min-height: 32px;
        padding-inline: 12px;
        font-size: 12px;
    }

    .product-section .woocommerce ul.products {
        grid-template-columns: none !important;
        grid-auto-columns: calc((100% - 12px) / 2);
        gap: 12px;
    }

    .product-slider-prev {
        left: -10px;
    }

    .product-slider-next {
        right: -10px;
    }

    .product-slider-arrow {
        width: 38px;
        height: 38px;
    }

    .product-section .woocommerce ul.products li.product {
        height: 342px;
        min-height: 342px;
        padding: 10px;
    }

    .product-section .woocommerce ul.products li.product .woocommerce-LoopProduct-link {
        grid-template-rows: 124px 42px 28px 16px 30px;
        min-height: 250px;
        row-gap: 5px;
    }

    .product-section .woocommerce ul.products li.product a img {
        height: 124px !important;
        max-height: 124px !important;
    }

    .newsletter-band form {
        grid-template-columns: 1fr;
        height: auto;
    }

    .newsletter-band button {
        min-height: 42px;
    }

    .newsletter-products {
        display: none;
    }

    .single-product .product {
        width: min(100% - 32px, 680px);
        display: block;
        margin: 28px auto 42px;
    }

    .single-product div.product div.images,
    .single-product div.product div.summary {
        width: 100% !important;
        float: none !important;
        clear: both;
    }

    .single-product div.product div.images {
        margin-bottom: 24px;
    }

    .single-product div.product div.images img {
        width: 100%;
        max-height: 360px;
        object-fit: contain;
        border-radius: 16px;
    }

    .single-product div.product .summary {
        padding: 0;
    }

    .single-product div.product .product_title {
        font-size: 34px;
        line-height: 1.1;
        margin: 0 0 12px;
        overflow-wrap: anywhere;
    }

    .single-product div.product p.price {
        font-size: 25px;
        line-height: 1.25;
        margin-bottom: 14px;
    }

    .single-product div.product .woocommerce-product-details__short-description {
        font-size: 15px;
        line-height: 1.65;
    }

    .woocommerce.single-product div.product form.cart,
    .single-product div.product form.cart {
        display: grid;
        grid-template-columns: 88px 1fr;
        gap: 12px;
        align-items: center;
        margin: 18px 0 24px;
    }

    .single-product div.product form.cart div.quantity,
    .single-product div.product form.cart .quantity {
        grid-column: 1;
        grid-row: 1;
        margin: 0 !important;
    }

    .single-product div.product form.cart .qty {
        width: 88px;
        min-height: 48px;
        border: 1px solid #d1d5db;
        border-radius: 10px;
        text-align: center;
    }

    .woocommerce.single-product div.product form.cart .button,
    .single-product div.product form.cart .button {
        grid-column: 2;
        grid-row: 1;
        width: 100%;
        min-height: 50px;
        margin: 0;
        border-radius: 10px;
        display: inline-flex;
        align-items: center;
        justify-content: center;
    }

    .single-product div.product .product_meta {
        display: grid;
        gap: 6px;
        padding-top: 16px;
        border-top: 1px solid #e5e7eb;
        color: #475569;
        font-size: 13px;
    }

    .woocommerce div.product .woocommerce-tabs {
        margin-top: 28px;
    }

    .woocommerce div.product .woocommerce-tabs ul.tabs {
        display: flex;
        gap: 8px;
        padding: 0;
        margin: 0 0 18px;
        overflow-x: auto;
        white-space: nowrap;
    }

    .woocommerce div.product .woocommerce-tabs ul.tabs::before {
        display: none;
    }

    .woocommerce div.product .woocommerce-tabs ul.tabs li {
        margin: 0;
        border: 1px solid #d1d5db;
        border-radius: 10px;
        background: #fff;
    }

    .woocommerce div.product .woocommerce-tabs ul.tabs li a {
        padding: 10px 14px;
        font-size: 13px;
    }

    .woocommerce div.product .woocommerce-tabs .panel {
        padding: 0;
    }

    .woocommerce div.product .woocommerce-tabs .panel h2 {
        font-size: 22px;
        margin-top: 0;
    }

    .single-product .related.products {
        width: min(100% - 32px, 680px);
        margin: 34px auto 0;
    }

    .single-product .related.products > h2 {
        font-size: 24px;
        margin-bottom: 18px;
    }

    .single-product .related.products ul.products {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 12px;
    }

    .single-product .related.products ul.products li.product {
        height: 330px;
        min-height: 330px;
        padding: 12px;
    }

    .single-product .related.products ul.products li.product .woocommerce-LoopProduct-link {
        grid-template-rows: 112px 40px 28px 16px 32px;
        min-height: 230px;
    }

    .single-product .related.products ul.products li.product a img {
        height: 112px !important;
        max-height: 112px !important;
    }

    .taeef-search-page {
        width: 100%;
        padding: 0 0 90px;
    }

    .mobile-filter-toggle {
        width: 48px;
        min-width: 48px;
        min-height: 42px;
        display: flex;
        align-items: center;
        justify-content: center;
        gap: 0;
        margin: 0;
        border: 0;
        border-radius: 10px;
        background: #111;
        color: #fff;
        font-size: 15px;
        font-weight: 950;
    }

    .mobile-filter-toggle span {
        position: absolute;
        width: 1px;
        height: 1px;
        overflow: hidden;
        clip: rect(0, 0, 0, 0);
        white-space: nowrap;
    }

    .filter-drawer-backdrop {
        position: fixed;
        inset: 0;
        z-index: 78;
        display: block;
        background: rgba(17, 24, 39, 0.42);
        opacity: 0;
        pointer-events: none;
        transition: opacity 0.2s ease;
    }

    .filter-drawer-open .filter-drawer-backdrop {
        opacity: 1;
        pointer-events: auto;
    }

    .search-hero {
        grid-template-columns: 1fr;
        gap: 18px;
        padding: 0;
        border-radius: 0;
    }

    .search-hero h1 {
        font-size: 17px;
    }

    .search-refine {
        grid-template-columns: 1fr 86px;
    }

    .search-layout {
        grid-template-columns: 1fr;
        gap: 16px;
    }

    .search-facets {
        position: fixed;
        top: 0;
        left: 0;
        z-index: 79;
        width: min(330px, calc(100vw - 42px));
        height: 100vh;
        min-height: 0;
        overflow-y: auto;
        transform: translateX(-100%);
        border-right: 1px solid #e5e7eb;
        border-bottom: 0;
        background: #fff;
        box-shadow: 18px 0 55px rgba(15, 23, 42, 0.18);
        transition: transform 0.22s ease;
    }

    .filter-drawer-open .search-facets,
    .search-facets.is-open {
        transform: translateX(0);
    }

    .facet-close {
        width: 34px;
        height: 34px;
        display: inline-grid;
        place-items: center;
        margin-left: auto;
        border: 0;
        border-radius: 999px;
        background: #f3f4f6;
        color: #111;
    }

    .search-content {
        width: min(100% - 28px, 980px);
        margin: 0 auto 32px;
    }

    .facet-group {
        padding: 14px;
    }

    .search-results-panel {
        padding: 0;
        border-radius: 0;
    }

    .results-toolbar {
        align-items: stretch;
        flex-direction: column;
    }

    .results-toolbar form {
        display: grid;
        grid-template-columns: 1fr 48px;
        gap: 10px;
        align-items: end;
    }

    .results-toolbar select {
        width: 100%;
    }

    .taeef-search-page ul.products {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 16px 12px;
    }

    .taeef-search-page ul.products li.product {
        height: 278px;
        min-height: 278px;
        padding: 9px;
    }

    .taeef-search-page ul.products li.product .woocommerce-LoopProduct-link {
        grid-template-rows: 112px 42px 16px 34px;
        min-height: 216px;
        row-gap: 5px;
    }

    .taeef-search-page ul.products li.product a img {
        height: 104px !important;
        max-height: 104px !important;
        padding: 6px;
    }

    .taeef-search-page ul.products li.product .woocommerce-loop-product__title {
        height: 42px;
        font-size: 13px;
    }

    .taeef-search-page ul.products li.product .price {
        height: 34px;
        font-size: 14px;
    }

    .taeef-search-page ul.products li.product .button {
        top: 74px;
        right: 12px;
        width: 42px;
        min-width: 42px;
        height: 42px;
        min-height: 42px;
    }

    .taeef-search-page ul.products li.product .button::before {
        font-size: 30px;
    }

    .taeef-search-page ul.products li.product .taeef-buy-now {
        width: 100%;
        min-height: 32px;
        margin-inline: 0;
    }

    .mobile-bottom-nav {
        position: fixed;
        left: 0;
        right: 0;
        bottom: 0;
        z-index: 70;
        display: grid;
        grid-template-columns: repeat(5, 1fr);
        min-height: 68px;
        padding: 7px 6px calc(7px + env(safe-area-inset-bottom));
        border-top: 1px solid #e5e7eb;
        background: rgba(255, 255, 255, 0.98);
        box-shadow: 0 -12px 28px rgba(15, 23, 42, 0.08);
        backdrop-filter: blur(16px);
    }

    .mobile-bottom-nav a,
    .mobile-bottom-nav button {
        display: grid;
        place-items: center;
        gap: 4px;
        border: 0;
        background: transparent;
        color: #111;
        font-size: 11px;
        font-weight: 800;
    }

    .mobile-bottom-nav svg {
        width: 23px;
        height: 23px;
        padding: 4px;
        border-radius: 10px;
        background: #f3f4f6;
        stroke: currentColor;
        stroke-width: 2;
        stroke-linecap: round;
        stroke-linejoin: round;
        fill: none;
        box-sizing: content-box;
    }

    .mobile-bottom-nav a:hover,
    .mobile-bottom-nav button:hover,
    .mobile-bottom-nav a:focus,
    .mobile-bottom-nav button:focus {
        color: #000;
    }

    .mobile-bottom-nav a:hover svg,
    .mobile-bottom-nav button:hover svg,
    .mobile-bottom-nav a:focus svg,
    .mobile-bottom-nav button:focus svg {
        background: #f2f2f0;
    }

    body {
        padding-bottom: 74px;
    }
}

@media (max-width: 480px) {
    .grocery-copy {
        grid-template-rows: 118px 50px;
        gap: 18px;
    }

    .grocery-copy h1 {
        font-size: 31px;
    }

    .hero-collage {
        height: 230px;
        transform: scale(0.68);
        margin-bottom: -76px;
    }

    .single-product .product {
        width: min(100% - 24px, 680px);
    }

    .single-product div.product .product_title {
        font-size: 30px;
    }

    .single-product div.product form.cart {
        grid-template-columns: 76px 1fr;
    }

    .single-product div.product form.cart .qty {
        width: 76px;
    }

    .taeef-search-page ul.products {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 26px 14px;
    }

    .brand-strip,
    .category-grid,
    .product-section .woocommerce ul.products,
    .demo-product-grid,
    .footer-benefits,
    .footer-grid {
        grid-template-columns: 1fr;
    }
}

/* Premium Taeef editorial refresh */
:root {
    --taeef-blue: #050505;
    --taeef-blue-dark: #000000;
    --taeef-ink: #050505;
    --taeef-muted: #5f6368;
    --taeef-soft: #f6f6f4;
    --taeef-line: #dedede;
    --taeef-card: #ffffff;
    --taeef-shadow: 0 16px 45px rgba(0, 0, 0, 0.06);
}

body {
    background: #ffffff;
    color: #050505;
}

.site-header {
    background: #ffffff;
    border-bottom: 1px solid #e4e4e4;
    box-shadow: none;
    backdrop-filter: none;
}

.header-inner {
    min-height: 70px;
    grid-template-columns: 44px 180px minmax(0, 1fr) auto;
    gap: 22px;
    padding: 0 34px;
}

.header-menu-button span {
    width: 24px;
    height: 1.5px;
    border-radius: 0;
    background: #050505;
}

.taeef-logo-image {
    width: 154px;
    filter: grayscale(1) contrast(1.15);
}

.header-actions {
    justify-self: end;
    gap: 18px;
}

.header-cart-button {
    min-height: 42px;
    padding: 0 18px;
    border-color: #dcdcdc;
    border-radius: 999px;
    background: #ffffff;
    color: #050505;
    font-size: 13px;
    box-shadow: none;
}

.header-cart-button em {
    background: #050505;
    color: #ffffff;
}

.login-button {
    min-width: 112px;
    min-height: 42px;
    margin-left: 8px;
    border: 1px solid #050505;
    border-radius: 3px;
    background: #050505;
    color: #ffffff;
    font-size: 13px;
}

.taeef-home,
.home-main {
    background: #ffffff;
}

.home-grid {
    grid-template-columns: 250px minmax(0, 1fr);
}

.category-rail {
    top: 70px;
    height: calc(100vh - 70px);
    border-right: 1px solid #e2e2e2;
    background: #ffffff;
}

.sidebar-quick-links {
    padding: 34px 20px 20px;
}

.sidebar-quick-links a,
.category-rail .sidebar-quick-links a {
    min-height: 32px;
    padding: 3px 0;
    color: #050505;
    font-size: 13px;
    font-weight: 500;
}

.quick-icon {
    color: #050505 !important;
    opacity: 0.78;
    filter: grayscale(1);
}

.sidebar-quick-links .quick-text {
    margin-top: 22px;
    color: #050505;
    font-size: 13px;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

.category-rail ul {
    padding: 12px 0 40px;
}

.category-rail a,
.category-rail button.category-has-icon {
    grid-template-columns: 34px minmax(0, 1fr) 12px;
    min-height: 46px;
    gap: 0;
    padding: 6px 20px;
    color: #050505;
}

.category-rail a:hover,
.category-rail button.category-has-icon:hover,
.category-rail button.category-has-icon:focus {
    background: #f4f4f2;
    color: #000000;
}

.category-rail button.category-has-icon:focus {
    outline: 1px solid #050505;
    outline-offset: -1px;
}

.cat-icon {
    width: 24px;
    height: 24px;
    border-radius: 0;
    background: #f2f2f0;
    color: #050505;
    font-size: 9px;
    font-weight: 700;
}

.category-rail strong {
    color: #050505;
    font-size: 13px;
    font-weight: 650;
    line-height: 1.18;
}

.category-rail small {
    margin-top: 2px;
    color: #666666;
    font-size: 11px;
    font-weight: 400;
}

.category-rail em {
    color: #050505;
    font-size: 16px;
}

.grocery-hero {
    min-height: calc(100vh - 70px);
    display: grid;
    grid-template-columns: minmax(420px, 0.92fr) minmax(420px, 1.08fr);
    align-items: stretch;
    gap: 0;
    padding: 0;
    background: #ffffff;
    border-bottom: 1px solid #e8e8e8;
}

.grocery-copy {
    max-width: none;
    min-height: inherit;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 0;
    padding: clamp(48px, 7vw, 108px);
}

.grocery-copy h1 {
    max-width: 620px;
    height: auto;
    display: block;
    margin: 0 0 30px;
    color: #050505;
    font-size: clamp(48px, 6vw, 92px);
    font-weight: 900;
    line-height: 0.94;
    letter-spacing: 0;
}

.grocery-copy p {
    max-width: 620px;
    margin: 0 0 18px;
    color: #181818;
    font-size: clamp(17px, 1.25vw, 22px);
    font-weight: 500;
    line-height: 1.48;
}

.grocery-copy p:first-of-type {
    color: #050505;
    font-weight: 800;
}

.hero-button {
    width: max-content;
    min-height: 44px;
    margin-top: 24px;
    padding: 0 26px;
    border: 1px solid #050505;
    border-radius: 999px;
    background: #050505;
    color: #ffffff;
    font-size: 13px;
    font-weight: 800;
}

.hero-button:hover,
.hero-button:focus {
    background: #ffffff;
    color: #050505;
    outline: none;
}

.hero-collage {
    position: relative;
    min-height: inherit;
    height: auto;
    margin: 0;
    overflow: hidden;
    background: #f3f3f1;
    transform: none;
}

.collage-card,
.collage-main {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    border-radius: 0;
    object-fit: cover;
    object-position: center;
    box-shadow: none;
    filter: grayscale(1) contrast(1.08);
}

.promise-row {
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 0;
    width: 100%;
    margin: 0;
    border-bottom: 1px solid #e8e8e8;
}

.promise-card {
    min-height: 192px;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: center;
    gap: 10px;
    padding: 34px 30px;
    border: 0;
    border-right: 1px solid #e8e8e8;
    border-radius: 0;
    background: #ffffff;
    box-shadow: none;
}

.promise-card:last-child {
    border-right: 0;
}

.promise-card span {
    width: auto;
    height: auto;
    display: block;
    border-radius: 0;
    background: transparent;
    color: #777777;
    font-size: 12px;
    font-weight: 600;
    letter-spacing: 0.12em;
}

.promise-card strong {
    display: block;
    color: #050505;
    font-size: clamp(24px, 2vw, 34px);
    font-weight: 900;
    line-height: 1;
}

.promise-card p {
    max-width: 190px;
    margin: 0;
    color: #4d4d4d;
    font-size: 14px;
    font-weight: 500;
    line-height: 1.5;
}

.home-section {
    width: min(1280px, calc(100% - 72px));
    margin: 74px auto 0;
}

.section-heading {
    justify-content: space-between;
    margin-bottom: 28px;
}

.section-heading h2 {
    color: #050505;
    font-size: clamp(26px, 2.8vw, 42px);
    font-weight: 900;
    letter-spacing: 0;
}

.section-heading a {
    position: static;
    color: #050505;
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.category-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1px;
    background: #e6e6e6;
    border: 1px solid #e6e6e6;
}

.category-tile {
    min-height: 260px;
    border: 0;
    border-radius: 0;
    background: #ffffff;
    color: #050505;
    font-size: 14px;
    font-weight: 800;
    box-shadow: none;
    transition: background 0.18s ease, color 0.18s ease;
}

.category-tile img {
    width: 142px;
    height: 116px;
    border-radius: 0;
    box-shadow: none;
    filter: grayscale(1);
}

.category-tile:hover {
    border-color: transparent;
    background: #050505;
    color: #ffffff;
    box-shadow: none;
    transform: none;
}

.product-section {
    width: min(1320px, calc(100% - 72px));
    margin-top: 74px;
    padding: 0;
    border: 0;
    border-radius: 0;
    background: #ffffff;
    box-shadow: none;
}

.product-section .section-heading {
    margin-bottom: 28px;
    padding-bottom: 0;
    border-bottom: 0;
}

.product-section .section-heading::after {
    display: none;
}

.product-section .section-heading h2 {
    font-size: clamp(26px, 2.8vw, 42px);
    font-weight: 900;
}

.product-section .section-heading a {
    min-height: 0;
    padding: 0;
    border-radius: 0;
    background: transparent;
    color: #050505;
}

.product-slider-arrow {
    border-color: #050505;
    border-radius: 0;
    background: #ffffff;
    box-shadow: none;
}

.product-slider-arrow:hover,
.product-slider-arrow:focus-visible {
    background: #050505;
    color: #ffffff;
}

.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit,
.taeef-buy-now,
.cart-drawer-checkout {
    border-radius: 3px !important;
    background: #050505 !important;
    color: #ffffff !important;
    box-shadow: none !important;
}

.newsletter-band {
    width: min(1320px, calc(100% - 72px));
    margin-top: 88px;
    border-radius: 0;
    background: #050505;
    color: #ffffff;
    box-shadow: none;
}

@media (max-width: 1200px) {
    .grocery-hero {
        grid-template-columns: 1fr;
        min-height: auto;
    }

    .grocery-copy {
        min-height: 560px;
        padding: 64px 42px;
    }

    .hero-collage {
        min-height: 420px;
    }

    .promise-row {
        grid-template-columns: repeat(5, minmax(220px, 1fr));
        overflow-x: auto;
    }

    .promise-card {
        min-width: 220px;
    }
}

@media (max-width: 760px) {
    body {
        overflow-x: hidden;
    }

    .home-grid {
        display: block;
        width: 100%;
    }

    .header-inner {
        min-height: 64px;
        grid-template-columns: 42px 1fr auto;
        padding: 0 18px;
        gap: 14px;
    }

    .site-branding {
        justify-self: start;
    }

    .taeef-logo-image {
        width: 126px;
    }

    .header-actions {
        gap: 8px;
    }

    .header-cart-button {
        width: 42px;
        min-width: 42px;
        padding: 0;
    }

    .login-button {
        display: none;
    }

    .category-rail {
        top: 64px;
        height: calc(100vh - 64px - 72px);
    }

    .grocery-copy {
        width: 100%;
        max-width: 100%;
        min-height: 520px;
        padding: 52px 24px;
        overflow: hidden;
        box-sizing: border-box;
    }

    .grocery-copy h1 {
        width: min(100%, 342px);
        max-width: 342px;
        font-size: clamp(42px, 15vw, 64px);
        line-height: 0.96;
        margin-bottom: 24px;
        white-space: normal;
    }

    .grocery-copy p {
        width: min(100%, 330px);
        max-width: 330px;
        font-size: 16px;
        overflow-wrap: break-word;
        white-space: normal;
    }

    .hero-collage {
        min-height: 320px;
        transform: none;
        margin-bottom: 0;
    }

    .promise-row {
        grid-template-columns: 1fr;
        overflow: visible;
    }

    .promise-card {
        min-width: 0;
        min-height: 146px;
        border-right: 0;
        border-bottom: 1px solid #e8e8e8;
        padding: 28px 24px;
    }

    .home-section,
    .product-section,
    .newsletter-band {
        width: min(100% - 32px, 680px);
        margin-top: 52px;
    }

    .section-heading {
        align-items: flex-end;
        gap: 12px;
    }

    .category-grid {
        grid-template-columns: 1fr 1fr;
    }

    .category-tile {
        min-height: 190px;
    }
}

/* Premium single product page */
body.single-product {
    background: #ffffff;
    color: #050505;
}

body.single-product .site-header {
    background: #ffffff;
    border-bottom: 0;
    box-shadow: none;
}

body.single-product .taeef-shop-layout {
    width: 100%;
    max-width: none;
    padding: 0 0 96px;
}

.woocommerce.single-product div.product,
body.single-product div.product {
    width: min(100% - 64px, 1480px) !important;
    margin: 34px auto 0 !important;
    display: grid !important;
    grid-template-columns: minmax(0, 1.15fr) minmax(360px, 0.85fr);
    gap: clamp(34px, 5vw, 86px);
    align-items: start;
}

.woocommerce.single-product div.product div.images,
.woocommerce.single-product div.product div.summary {
    width: auto !important;
    float: none !important;
    clear: none !important;
}

.woocommerce.single-product div.product div.images {
    margin: 0 !important;
}

.woocommerce.single-product div.product .woocommerce-product-gallery__wrapper {
    margin: 0;
}

.woocommerce.single-product div.product div.images .woocommerce-product-gallery__image {
    display: grid;
    place-items: center;
    min-height: clamp(520px, 55vw, 760px);
    margin: 0;
    background: #f5f5f5;
    overflow: hidden;
}

.woocommerce.single-product div.product div.images img {
    width: 100%;
    height: clamp(520px, 55vw, 760px);
    max-height: none;
    object-fit: contain;
    padding: clamp(18px, 3vw, 42px);
    border-radius: 0;
    background: #f5f5f5;
    box-shadow: none;
}

.woocommerce.single-product div.product div.images .flex-control-thumbs {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 10px;
    margin: 12px 0 0;
    padding: 0;
}

.woocommerce.single-product div.product div.images .flex-control-thumbs li {
    width: auto;
    float: none;
    margin: 0;
    background: #f5f5f5;
}

.woocommerce.single-product div.product div.images .flex-control-thumbs img {
    height: 118px !important;
    padding: 10px;
    opacity: 0.54;
    cursor: pointer;
}

.woocommerce.single-product div.product div.images .flex-control-thumbs img.flex-active,
.woocommerce.single-product div.product div.images .flex-control-thumbs img:hover {
    opacity: 1;
}

.woocommerce.single-product div.product .summary {
    position: sticky;
    top: 96px;
    max-width: 520px;
    padding: 14px 0 0;
}

.woocommerce.single-product div.product .product_title {
    max-width: 13ch;
    margin: 0 0 18px;
    color: #050505;
    font-size: clamp(42px, 5vw, 78px);
    font-weight: 800;
    line-height: 0.98;
    letter-spacing: 0;
    overflow-wrap: normal;
}

.woocommerce.single-product div.product .woocommerce-product-rating {
    margin: 0 0 18px;
}

.woocommerce.single-product div.product p.price {
    margin: 0 0 28px;
    color: #050505;
    font-size: 22px;
    font-weight: 760;
    line-height: 1.3;
}

.woocommerce.single-product div.product p.price del {
    margin-right: 10px;
    color: #8d8d8d;
    font-size: 18px;
    font-weight: 650;
}

.woocommerce.single-product div.product .woocommerce-product-details__short-description {
    max-width: 48ch;
    margin: 0 0 24px;
    color: #2b2b2b;
    font-size: 16px;
    font-weight: 520;
    line-height: 1.75;
}

.woocommerce.single-product div.product .stock {
    margin: 0 0 18px;
    color: #606060;
    font-size: 14px;
    font-weight: 720;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.woocommerce.single-product div.product form.cart {
    display: grid;
    grid-template-columns: 92px minmax(0, 1fr);
    gap: 12px;
    margin: 0 0 24px;
}

.woocommerce.single-product div.product form.cart .quantity {
    margin: 0 !important;
}

.woocommerce.single-product div.product form.cart .qty {
    width: 92px;
    height: 58px;
    border: 1px solid #d8d8d8;
    border-radius: 0;
    background: #ffffff;
    color: #050505;
    font-size: 16px;
    font-weight: 760;
    text-align: center;
}

.woocommerce.single-product div.product form.cart .button {
    width: 100%;
    min-height: 58px;
    margin: 0;
    border: 0;
    border-radius: 0;
    background: #050505;
    color: #ffffff;
    font-size: 15px;
    font-weight: 820;
    letter-spacing: 0;
}

.woocommerce.single-product div.product form.cart .button:hover,
.woocommerce.single-product div.product form.cart .button:focus {
    background: #2d2d2d;
}

.taeef-product-assurance {
    display: grid;
    gap: 0;
    margin: 26px 0 0;
    border-top: 1px solid #e5e5e5;
}

.taeef-product-assurance span {
    display: flex;
    align-items: center;
    min-height: 54px;
    border-bottom: 1px solid #e5e5e5;
    color: #1f1f1f;
    font-size: 14px;
    font-weight: 720;
}

.taeef-product-assurance span::before {
    content: "";
    width: 6px;
    height: 6px;
    margin-right: 14px;
    border-radius: 999px;
    background: #050505;
}

.woocommerce.single-product div.product .product_meta {
    display: grid;
    gap: 8px;
    margin: 24px 0 0;
    padding: 18px 0 0;
    border-top: 1px solid #e5e5e5;
    color: #767676;
    font-size: 13px;
    line-height: 1.6;
}

.woocommerce.single-product div.product .product_meta a {
    color: #050505;
    text-decoration: underline;
    text-underline-offset: 3px;
}

.woocommerce.single-product div.product .woocommerce-tabs {
    grid-column: 1 / -1;
    width: min(100%, 980px);
    margin: 42px 0 0;
    padding: clamp(34px, 5vw, 72px) 0 0;
    border-top: 1px solid #e5e5e5;
}

.woocommerce.single-product div.product .woocommerce-tabs ul.tabs {
    display: none;
}

.woocommerce.single-product div.product .woocommerce-tabs .panel {
    display: block !important;
    margin: 0 !important;
    padding: 0 !important;
    color: #1f1f1f;
    font-size: 14px;
    line-height: 1.75;
}

.woocommerce.single-product div.product .woocommerce-tabs #reviews,
.woocommerce.single-product div.product .woocommerce-tabs .woocommerce-Reviews {
    display: none !important;
}

.woocommerce.single-product div.product .woocommerce-tabs .panel h2 {
    margin: 0 0 18px;
    color: #050505;
    font-family: "Helvetica Neue", Arial, sans-serif;
    font-size: clamp(22px, 2.1vw, 30px);
    font-weight: 650;
    line-height: 1.14;
}

.woocommerce.single-product div.product .woocommerce-tabs .panel h3,
.woocommerce.single-product div.product .woocommerce-tabs .panel h4 {
    margin: 22px 0 10px;
    color: #050505;
    font-family: "Helvetica Neue", Arial, sans-serif;
    font-size: 18px;
    font-weight: 650;
}

.woocommerce.single-product div.product .woocommerce-tabs .panel p {
    max-width: 72ch;
    margin: 0 0 18px;
}

.woocommerce.single-product div.product .woocommerce-tabs .panel ul {
    display: grid;
    gap: 10px;
    max-width: 68ch;
    margin: 18px 0 0;
    padding: 0;
    list-style: none;
}

.woocommerce.single-product div.product .woocommerce-tabs .panel li {
    position: relative;
    padding-left: 22px;
}

.woocommerce.single-product div.product .woocommerce-tabs .panel li::before {
    content: "";
    position: absolute;
    top: 0.82em;
    left: 0;
    width: 6px;
    height: 6px;
    border-radius: 999px;
    background: #050505;
}

.single-product .related.products {
    grid-column: 1 / -1;
    width: 100%;
    margin: 72px 0 0;
    padding-top: 46px;
    border-top: 1px solid #e5e5e5;
}

.single-product .related.products > h2 {
    margin: 0 0 26px;
    color: #050505;
    font-family: "Helvetica Neue", Arial, sans-serif;
    font-size: clamp(20px, 2vw, 28px);
    font-weight: 650;
    line-height: 1.1;
}

.single-product .related.products ul.products {
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 42px 18px;
    margin: 0 !important;
}

.single-product .related.products ul.products li.product {
    position: relative;
    width: auto !important;
    min-height: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: #ffffff !important;
    box-shadow: none !important;
}

.single-product .related.products ul.products li.product a img {
    width: 100%;
    height: 300px !important;
    max-height: none !important;
    margin: 0 0 16px !important;
    padding: 18px;
    object-fit: contain !important;
    border-radius: 0;
    background: #f5f5f5;
    box-shadow: none;
}

.single-product .related.products ul.products li.product .woocommerce-loop-product__title {
    min-height: 0;
    margin: 0 0 6px;
    padding: 0;
    color: #050505;
    font-size: 15px;
    font-weight: 760;
    line-height: 1.32;
}

.single-product .related.products ul.products li.product .price {
    color: #050505;
    font-size: 14px;
    font-weight: 720;
}

.single-product .related.products ul.products li.product .button,
.single-product .related.products ul.products li.product .taeef-buy-now,
.single-product .related.products span.onsale,
.single-product .related.products .star-rating,
.single-product .related.products .taeef-loop-excerpt {
    display: none !important;
}

@media (max-width: 980px) {
    .woocommerce.single-product div.product,
    body.single-product div.product {
        width: min(100% - 32px, 720px) !important;
        display: block !important;
        margin-top: 22px !important;
    }

    .woocommerce.single-product div.product div.images {
        margin-bottom: 28px !important;
    }

    .woocommerce.single-product div.product div.images .woocommerce-product-gallery__image {
        min-height: 420px;
    }

    .woocommerce.single-product div.product div.images img {
        height: 420px;
    }

    .woocommerce.single-product div.product .summary {
        position: static;
        max-width: none;
        padding-top: 0;
    }

    .woocommerce.single-product div.product .product_title {
        max-width: 14ch;
        font-size: clamp(38px, 11vw, 58px);
    }

    .woocommerce.single-product div.product .woocommerce-tabs {
        width: 100%;
        margin-top: 40px;
    }

    .single-product .related.products ul.products {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 560px) {
    .woocommerce.single-product div.product,
    body.single-product div.product {
        width: calc(100% - 24px) !important;
    }

    .woocommerce.single-product div.product div.images .woocommerce-product-gallery__image {
        min-height: 340px;
    }

    .woocommerce.single-product div.product div.images img {
        height: 340px;
        padding: 14px;
    }

    .woocommerce.single-product div.product div.images .flex-control-thumbs {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }

    .woocommerce.single-product div.product div.images .flex-control-thumbs img {
        height: 82px !important;
    }

    .woocommerce.single-product div.product form.cart {
        grid-template-columns: 1fr;
    }

    .woocommerce.single-product div.product form.cart .qty {
        width: 100%;
    }

    .single-product .related.products ul.products {
        grid-template-columns: 1fr;
    }
}

/* Reference-style full landing page */
body.home {
    overflow-x: hidden;
    background: #f8f5ef;
}

body.home .site-header,
body.home .site-footer,
body.home .mobile-bottom-nav {
    display: none !important;
}

.taeef-landing {
    --landing-sidebar: 220px;
    --landing-bg: #f8f5ef;
    --landing-text: #11100f;
    --landing-muted: #58534d;
    --landing-line: rgba(20, 18, 15, 0.1);
    min-height: 100vh;
    display: grid;
    grid-template-columns: var(--landing-sidebar) minmax(0, 1fr);
    background: var(--landing-bg);
    color: var(--landing-text);
    font-family: Manrope, Inter, -apple-system, BlinkMacSystemFont, "Segoe UI", Arial, sans-serif;
}

.landing-sidebar {
    position: sticky;
    top: 0;
    z-index: 30;
    height: 100vh;
    display: flex;
    flex-direction: column;
    padding: 32px 34px 28px;
    background: linear-gradient(90deg, #fbfaf6 0%, #f2eee6 100%);
    border-right: 1px solid rgba(16, 14, 12, 0.08);
}

.landing-brand {
    display: inline-flex;
    width: 124px;
    margin-bottom: 82px;
}

.landing-brand img,
.landing-mobile-brand img {
    display: block;
    width: 100%;
    height: auto;
    filter: grayscale(1) contrast(1.2);
}

.landing-menu,
.landing-sidebar-group {
    display: grid;
    gap: 0;
}

.landing-menu a,
.landing-sidebar-group a {
    min-height: 34px;
    display: flex;
    align-items: center;
    gap: 12px;
    color: #11100f;
    font-size: 14px;
    font-weight: 650;
    line-height: 1;
}

.landing-menu a.is-active::before {
    content: "";
    width: 5px;
    height: 5px;
    margin-left: -16px;
    border-radius: 50%;
    background: #11100f;
}

.landing-sidebar-group {
    margin-top: 42px;
    padding-top: 32px;
    border-top: 1px solid var(--landing-line);
}

.landing-sidebar-group > span,
.landing-kicker,
.landing-hero-copy > span,
.landing-mission span {
    color: #11100f;
    font-size: 10px;
    font-weight: 900;
    letter-spacing: 0.45em;
    text-transform: uppercase;
}

.landing-sidebar-group > span {
    margin-bottom: 20px;
}

.landing-sidebar-group svg,
.landing-actions svg,
.landing-product-cart svg,
.landing-shipping svg {
    width: 18px;
    height: 18px;
    stroke: currentColor;
    stroke-width: 1.7;
    stroke-linecap: round;
    stroke-linejoin: round;
    fill: none;
}

.landing-sidebar-group svg path,
.landing-actions svg path,
.landing-actions svg circle,
.landing-product-cart svg path,
.landing-shipping svg path {
    fill: none;
    stroke: currentColor;
}

.landing-menu-secondary {
    margin-top: 38px;
    padding-top: 28px;
    border-top: 1px solid var(--landing-line);
}

.landing-shipping {
    margin-top: auto;
    display: grid;
    grid-template-columns: 24px 1fr;
    gap: 2px 12px;
    color: #11100f;
}

.landing-shipping svg {
    grid-row: span 3;
    width: 22px;
    height: 22px;
}

.landing-shipping strong {
    font-size: 13px;
    line-height: 1;
}

.landing-shipping small {
    color: #4f4a44;
    font-size: 11px;
    line-height: 1.25;
}

.landing-shipping em {
    margin-top: 14px;
    color: #11100f;
    font-size: 11px;
    font-style: normal;
    font-weight: 900;
}

.landing-page {
    min-width: 0;
}

.landing-topbar {
    position: absolute;
    top: 0;
    left: var(--landing-sidebar);
    right: 0;
    z-index: 20;
    min-height: 86px;
    display: flex;
    align-items: center;
    justify-content: flex-end;
    padding: 0 44px;
    color: #11100f;
}

.landing-mobile-brand {
    display: none;
}

.landing-actions {
    display: flex;
    align-items: center;
    gap: 54px;
}

.landing-actions a,
.landing-actions button {
    display: inline-flex;
    align-items: center;
    gap: 13px;
    border: 0;
    background: transparent;
    color: #ffffff;
    font: inherit;
    font-size: 13px;
    font-weight: 800;
    cursor: pointer;
}

.landing-hero {
    position: relative;
    min-height: 100vh;
    display: flex;
    align-items: center;
    overflow: hidden;
    padding: 120px 72px;
    color: #ffffff;
    background: #1f211f;
}

.landing-hero::before,
.landing-hero::after,
.pillar-card::after,
.landing-mission::after {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
}

.landing-hero::before {
    z-index: 1;
    background:
        linear-gradient(90deg, rgba(2, 18, 30, 0.5) 0%, rgba(2, 18, 30, 0.24) 45%, rgba(2, 18, 30, 0.12) 100%),
        linear-gradient(0deg, rgba(2, 18, 30, 0.16), rgba(2, 18, 30, 0.02));
}

.landing-hero img,
.landing-hero-media {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    transform: none;
    filter: saturate(0.95) contrast(1.05) brightness(0.9);
}

.landing-hero-media {
    display: block;
    background: #032a44;
    opacity: 0;
    transition: opacity 0.9s ease;
}

.landing-hero-media.is-active {
    opacity: 1;
}

.landing-hero h1,
.landing-hero p {
    transition: opacity 0.45s ease, transform 0.45s ease;
}

.landing-hero.is-copy-changing h1,
.landing-hero.is-copy-changing p {
    opacity: 0;
    transform: translateY(10px);
}

.landing-hero-copy {
    position: relative;
    z-index: 2;
    width: min(540px, 100%);
    margin-left: 24px;
    margin-top: 72px;
}

.landing-hero-copy > span,
.landing-mission span {
    color: rgba(255, 255, 255, 0.86);
}

.landing-hero h1 {
    margin: 34px 0 30px;
    color: #ffffff;
    font-size: clamp(56px, 6.2vw, 88px);
    font-weight: 300;
    line-height: 1.08;
    letter-spacing: -0.02em;
}

.landing-hero p {
    width: min(390px, 100%);
    margin: 0;
    color: rgba(255, 255, 255, 0.92);
    font-size: 16px;
    font-weight: 650;
    line-height: 1.65;
}

.landing-hero-ctas {
    display: flex;
    align-items: center;
    gap: 40px;
    margin-top: 54px;
}

.landing-hero-ctas a {
    min-width: 208px;
    min-height: 58px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    background: #ffffff;
    color: #11100f;
    font-size: 13px;
    font-weight: 900;
}

.landing-scroll {
    position: absolute;
    right: 44px;
    bottom: 62px;
    z-index: 2;
    color: #ffffff;
    font-size: 10px;
    font-weight: 900;
    letter-spacing: 0.32em;
    text-transform: uppercase;
}

.landing-scroll::after {
    content: "";
    position: absolute;
    top: 28px;
    right: 4px;
    width: 1px;
    height: 70px;
    background: rgba(255, 255, 255, 0.7);
}

.landing-section {
    padding: 52px 42px 0;
    background: #fbfaf6;
}

.landing-pillars h2,
.landing-section-head h2 {
    margin: 18px 0 28px;
    color: #11100f;
    font-size: 28px;
    font-weight: 650;
    line-height: 1.1;
}

.pillar-grid {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 5px;
}

.pillar-card {
    position: relative;
    min-height: 360px;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    overflow: hidden;
    padding: 36px 28px;
    color: #ffffff;
    background: #222;
}

.pillar-card::after {
    background: linear-gradient(180deg, rgba(0, 0, 0, 0.12), rgba(0, 0, 0, 0.62));
}

.pillar-card img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    filter: saturate(0.35) brightness(0.68);
}

.pillar-card span,
.pillar-card p,
.pillar-card em {
    position: relative;
    z-index: 2;
}

.pillar-card span {
    font-size: 27px;
    font-weight: 600;
    line-height: 1;
}

.pillar-card p {
    min-height: 48px;
    margin: 22px 0 32px;
    color: rgba(255, 255, 255, 0.9);
    font-size: 13px;
    font-weight: 650;
    line-height: 1.45;
}

.pillar-card em {
    width: 49px;
    height: 49px;
    display: grid;
    place-items: center;
    border: 1px solid rgba(255, 255, 255, 0.8);
    border-radius: 50%;
    color: #ffffff;
    font-size: 22px;
    font-style: normal;
}

.landing-products {
    padding-bottom: 56px;
}

.landing-section-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
}

.landing-section-head a {
    color: #11100f;
    font-size: 12px;
    font-weight: 900;
}

.landing-product-grid {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 16px;
}

.landing-product-card {
    min-height: 286px;
    display: grid;
    grid-template-rows: 1fr auto;
    padding: 18px;
    background: #ffffff;
    border: 1px solid rgba(17, 16, 15, 0.06);
    box-shadow: 0 12px 40px rgba(31, 28, 24, 0.04);
}

.landing-product-card > a {
    display: grid;
    gap: 18px;
    color: #11100f;
}

.landing-product-card img {
    width: 100%;
    aspect-ratio: 1.3;
    object-fit: contain;
    filter: saturate(0.3);
}

.landing-product-card strong {
    color: #11100f;
    font-size: 13px;
    font-weight: 700;
    line-height: 1.3;
}

.landing-product-card > div {
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 14px;
}

.landing-product-card span {
    color: #11100f;
    font-size: 13px;
    font-weight: 800;
}

.landing-product-cart {
    width: 34px;
    height: 34px;
    display: grid;
    place-items: center;
    border: 1px solid rgba(17, 16, 15, 0.12);
    border-radius: 8px;
    color: #11100f;
}

.landing-product-cart svg {
    width: 17px;
    height: 17px;
}

.landing-mission {
    position: relative;
    min-height: 304px;
    display: grid;
    grid-template-columns: 1fr minmax(320px, 460px);
    align-items: center;
    overflow: hidden;
    padding: 44px 76px;
    background: #211c16;
    color: #ffffff;
}

.landing-mission img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    filter: saturate(0.32) brightness(0.48);
}

.landing-mission::after {
    background: linear-gradient(90deg, rgba(30, 24, 16, 0.2), rgba(30, 24, 16, 0.84));
}

.landing-mission > div {
    position: relative;
    z-index: 2;
    grid-column: 2;
}

.landing-mission h2 {
    margin: 18px 0 14px;
    color: #ffffff;
    font-size: 30px;
    font-weight: 650;
    line-height: 1.08;
}

.landing-mission p {
    width: min(310px, 100%);
    margin: 0 0 20px;
    color: rgba(255, 255, 255, 0.86);
    font-size: 13px;
    font-weight: 650;
    line-height: 1.45;
}

.landing-mission a {
    min-height: 34px;
    display: inline-flex;
    align-items: center;
    padding: 0 18px;
    border: 1px solid rgba(255, 255, 255, 0.78);
    border-radius: 999px;
    color: #ffffff;
    font-size: 12px;
    font-weight: 900;
}

@media (max-width: 1180px) {
    .taeef-landing {
        grid-template-columns: 184px minmax(0, 1fr);
        --landing-sidebar: 184px;
    }

    .landing-sidebar {
        padding-inline: 24px;
    }

    .pillar-grid,
    .landing-product-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (max-width: 820px) {
    .taeef-landing {
        display: block;
    }

    .landing-sidebar {
        display: none;
    }

    .landing-topbar {
        position: fixed;
        left: 0;
        min-height: 66px;
        padding: 0 18px;
        background: rgba(248, 245, 239, 0.9);
        border-bottom: 1px solid rgba(17, 16, 15, 0.08);
        backdrop-filter: blur(14px);
    }

    .landing-mobile-brand {
        display: inline-flex;
        width: 116px;
        margin-right: auto;
    }

    .landing-actions {
        gap: 18px;
    }

    .landing-actions a {
        color: #11100f;
        font-size: 0;
        gap: 0;
    }

    .landing-actions button {
        color: #11100f;
        font-size: 0;
        gap: 0;
    }

    .landing-actions svg {
        width: 20px;
        height: 20px;
    }

    .landing-hero {
        min-height: 760px;
        padding: 108px 24px 70px;
        align-items: flex-end;
    }

    .landing-hero-copy {
        margin: 0;
        width: 100%;
    }

    .landing-hero h1 {
        font-size: clamp(48px, 15vw, 68px);
    }

    .landing-hero p {
        font-size: 15px;
    }

    .landing-hero-ctas {
        flex-wrap: wrap;
        gap: 18px;
        margin-top: 34px;
    }

    .landing-scroll {
        display: none;
    }

    .landing-section {
        padding: 42px 18px 0;
    }

    .pillar-grid,
    .landing-product-grid {
        grid-template-columns: 1fr;
    }

    .pillar-card {
        min-height: 320px;
    }

    .landing-section-head {
        align-items: flex-end;
    }

    .landing-mission {
        grid-template-columns: 1fr;
        min-height: 420px;
        padding: 42px 24px;
    }

    .landing-mission > div {
        grid-column: 1;
    }
}

/* Nike-style premium shop/archive surface */
body.post-type-archive-product,
body.tax-product_cat,
body.search-results {
    background: #ffffff;
}

body.post-type-archive-product .site-header,
body.tax-product_cat .site-header,
body.search-results .site-header {
    position: sticky;
    top: 0;
    background: #ffffff;
    border-bottom: 1px solid #e5e5e5;
    box-shadow: none;
}

body.post-type-archive-product .header-inner,
body.tax-product_cat .header-inner,
body.search-results .header-inner {
    grid-template-columns: 180px 1fr auto;
    min-height: 72px;
    padding-inline: clamp(24px, 4vw, 56px);
}

.taeef-search-page {
    background: #ffffff;
}

body.post-type-archive-product .header-menu-button,
body.tax-product_cat .header-menu-button,
body.search-results .header-menu-button,
body.post-type-archive-product .menu-toggle,
body.tax-product_cat .menu-toggle,
body.search-results .menu-toggle,
body.post-type-archive-product .site-header::after,
body.tax-product_cat .site-header::after,
body.search-results .site-header::after {
    display: none !important;
}

body.post-type-archive-product .site-header,
body.tax-product_cat .site-header,
body.search-results .site-header,
body.post-type-archive-product .header-inner,
body.tax-product_cat .header-inner,
body.search-results .header-inner {
    border: 0 !important;
    border-bottom: 0 !important;
    box-shadow: none !important;
}

.search-layout {
    grid-template-columns: 224px minmax(0, 1fr);
    gap: 0;
    width: min(100%, 1540px);
    margin: 0;
}

.search-content {
    width: auto;
    margin: 0;
    padding: 0 36px 84px 20px;
}

.search-hero {
    min-height: 92px;
    display: flex;
    align-items: end;
    justify-content: space-between;
    margin: 0;
    padding: 28px 0 24px;
    border: 0;
}

.search-hero span,
.search-hero p,
.results-toolbar > div {
    display: none;
}

.search-hero h1 {
    color: #050505;
    font-size: clamp(22px, 2vw, 30px);
    font-weight: 850;
    line-height: 1.1;
    letter-spacing: 0;
}

.search-facets {
    top: 72px;
    height: calc(100vh - 72px);
    min-height: 0;
    padding: 54px 22px 42px 24px;
    border-right: 0;
    background: #ffffff;
    scrollbar-width: thin;
}

.search-facets::-webkit-scrollbar {
    width: 5px;
}

.search-facets::-webkit-scrollbar-thumb {
    border-radius: 999px;
    background: #777777;
}

.facet-head {
    min-height: 0;
    padding: 0 0 24px;
    border-bottom: 1px solid #e5e5e5;
}

.facet-head strong {
    color: #050505;
    font-size: 18px;
    font-weight: 850;
}

.facet-head a {
    color: #050505;
    font-size: 12px;
    font-weight: 700;
}

.facet-group {
    padding: 22px 0;
    border-bottom: 1px solid #e5e5e5;
}

.facet-group h2 {
    margin: 0 0 16px;
    color: #050505;
    font-size: 15px;
    font-weight: 850;
}

.facet-option {
    min-height: 34px;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 12px;
    margin: 0;
    padding: 0;
    color: #050505;
    font-size: 15px;
    font-weight: 760;
}

.facet-option:hover,
.facet-option:focus-within {
    background: transparent;
    color: #666666;
}

.facet-code {
    display: none;
}

.facet-label {
    overflow: visible;
    text-overflow: clip;
}

.facet-option em {
    color: #777777;
    font-size: 12px;
}

.facet-link-list {
    display: grid;
    gap: 0;
}

.facet-link-list a {
    min-height: 31px;
    display: flex;
    align-items: center;
    color: #050505;
    font-size: 15px;
    font-weight: 760;
}

.facet-link-list a:hover,
.facet-link-list a:focus {
    color: #666666;
}

.facet-price {
    gap: 12px;
}

.facet-price label span {
    color: #5f5f5f;
    font-size: 12px;
    font-weight: 700;
}

.facet-price input {
    height: 42px;
    border: 1px solid #d7d7d7;
    border-radius: 0;
    color: #050505;
    font-size: 14px;
}

.facet-availability .facet-stock-option {
    min-height: 34px;
    padding: 0;
}

.facet-collapse {
    padding-block: 18px;
}

.facet-collapse h2 {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin: 0;
}

.facet-submit {
    width: 100%;
    min-height: 46px;
    margin: 22px 0 0;
    border-radius: 999px;
    background: #050505;
    color: #ffffff;
}

.results-toolbar {
    justify-content: flex-end;
    margin: -60px 0 32px;
}

.results-toolbar form {
    display: flex;
    align-items: center;
    gap: 24px;
}

.results-toolbar label {
    display: flex;
    align-items: center;
    gap: 12px;
    color: #050505;
    font-size: 15px;
    font-weight: 760;
}

.results-toolbar label span {
    color: #050505;
    font-size: 15px;
}

.results-toolbar select {
    min-width: 128px;
    height: 38px;
    border: 0;
    border-radius: 0;
    background: transparent;
    color: #050505;
    font-size: 15px;
    font-weight: 760;
    outline: 0;
}

.taeef-search-page ul.products {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 86px 18px;
    margin: 0 !important;
    padding: 0 !important;
}

.taeef-search-page .woocommerce ul.products li.product,
.taeef-search-page ul.products li.product {
    position: relative;
    width: auto !important;
    min-height: calc(clamp(310px, 25vw, 430px) + 112px) !important;
    display: block;
    padding: 0;
    border: 0;
    border-radius: 0;
    background: #ffffff;
    box-shadow: none;
    overflow: visible;
}

.taeef-search-page .woocommerce ul.products li.product:hover,
.taeef-search-page ul.products li.product:hover {
    transform: none;
    box-shadow: none;
}

.taeef-search-page ul.products li.product .woocommerce-LoopProduct-link {
    position: relative;
    display: block;
    min-height: calc(clamp(310px, 25vw, 430px) + 96px) !important;
}

.taeef-search-page .woocommerce ul.products li.product a img,
.taeef-search-page ul.products li.product a img {
    width: 100%;
    height: clamp(310px, 25vw, 430px) !important;
    max-height: none !important;
    margin: 0 0 16px !important;
    padding: 0;
    object-fit: contain !important;
    border-radius: 0;
    background: #f5f5f5;
    box-shadow: none;
}

.taeef-search-page ul.products li.product .woocommerce-LoopProduct-link::before {
    content: "";
    position: absolute;
    inset: 0 0 auto;
    height: clamp(310px, 25vw, 430px);
    background: #f5f5f5;
    z-index: -1;
}

.taeef-search-page span.onsale {
    display: none !important;
}

.taeef-search-page ul.products li.product .woocommerce-loop-product__title {
    min-height: 0;
    margin: 0 0 4px;
    padding: 0;
    color: #050505;
    font-size: 16px;
    font-weight: 760;
    line-height: 1.28;
}

.taeef-search-page .taeef-loop-excerpt,
.taeef-search-page ul.products li.product .star-rating {
    display: none;
}

.taeef-search-page ul.products li.product .price {
    display: block;
    min-height: 0;
    margin: 4px 0 0;
    color: #050505;
    font-size: 15px;
    font-weight: 760;
    line-height: 1.3;
}

.taeef-search-page ul.products li.product .price del {
    display: inline;
    margin-right: 6px;
    color: #767676;
    font-size: 14px;
    font-weight: 650;
}

.taeef-search-page ul.products li.product .button {
    position: absolute;
    right: 16px !important;
    top: calc(clamp(310px, 25vw, 430px) - 72px) !important;
    bottom: auto !important;
    width: 56px;
    min-width: 56px;
    height: 56px;
    min-height: 56px;
    margin: 0;
    padding: 0;
    border: 0;
    border-radius: 0;
    background: #050505 !important;
    color: transparent !important;
    overflow: hidden;
}

.taeef-search-page ul.products li.product .button::before {
    content: "+";
    position: static;
    display: grid;
    place-items: center;
    width: 100%;
    height: 100%;
    color: #ffffff;
    font-size: 34px;
    font-weight: 450;
    line-height: 1;
}

.taeef-search-page ul.products li.product .taeef-buy-now {
    display: none;
}

.taeef-search-page .page-numbers {
    margin-top: 54px;
}

@media (max-width: 1100px) {
    .search-layout {
        grid-template-columns: 204px minmax(0, 1fr);
    }

    .search-facets {
        padding-left: 26px;
        padding-right: 18px;
    }

    .search-content {
        padding-inline: 24px;
    }

    .taeef-search-page ul.products {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 760px) {
    .search-layout {
        display: block;
    }

    .search-content {
        padding: 0 16px 72px;
    }

    .search-hero {
        min-height: 86px;
        padding: 22px 0 18px;
    }

    .results-toolbar {
        margin: 0 0 22px;
    }

    .mobile-filter-toggle {
        display: inline-flex;
        align-items: center;
        gap: 8px;
        border: 0;
        background: transparent;
        color: #050505;
        font-size: 14px;
        font-weight: 800;
    }

    .search-facets {
        position: fixed;
        top: 62px;
        left: 0;
        z-index: 70;
        width: min(320px, calc(100vw - 44px));
        height: calc(100vh - 62px);
        padding: 22px;
        transform: translateX(-100%);
        border-right: 1px solid #e5e5e5;
        transition: transform 0.24s ease;
    }

    .filter-drawer-open .search-facets,
    .search-facets.is-open {
        transform: translateX(0);
    }

    .facet-close {
        display: inline-flex;
        border: 0;
        background: transparent;
    }

    .taeef-search-page ul.products {
        grid-template-columns: 1fr;
        gap: 64px;
    }

    .taeef-search-page .woocommerce ul.products li.product a img,
    .taeef-search-page ul.products li.product a img {
        height: 320px !important;
    }

    .taeef-search-page .woocommerce ul.products li.product,
    .taeef-search-page ul.products li.product,
    .taeef-search-page ul.products li.product .woocommerce-LoopProduct-link {
        min-height: 424px !important;
    }

    .taeef-search-page ul.products li.product .button {
        top: 248px !important;
        bottom: auto !important;
    }
}

/* Final single-product polish overrides */
body.single-product span.onsale {
    display: none !important;
}

body.single-product .woocommerce div.product .product_title,
.woocommerce.single-product div.product .product_title {
    max-width: 28ch;
    margin-bottom: 8px;
    font-family: "Helvetica Neue", Arial, sans-serif;
    font-size: clamp(18px, 1.75vw, 26px) !important;
    font-weight: 650;
    line-height: 1.16;
    overflow-wrap: break-word;
}

body.single-product .woocommerce div.product .summary,
.woocommerce.single-product div.product .summary {
    max-width: 390px;
    padding-top: 2px;
    font-family: "Helvetica Neue", Arial, sans-serif;
}

body.single-product .woocommerce div.product p.price,
.woocommerce.single-product div.product p.price {
    margin-bottom: 28px;
    font-size: 16px;
    font-weight: 650;
}

body.single-product .woocommerce div.product p.price del,
.woocommerce.single-product div.product p.price del {
    font-size: 14px;
    font-weight: 500;
}

body.single-product .woocommerce div.product .woocommerce-product-details__short-description,
.woocommerce.single-product div.product .woocommerce-product-details__short-description {
    max-width: 38ch;
    margin-bottom: 26px;
    color: #333333;
    font-size: 14px;
    font-weight: 400;
    line-height: 1.62;
}

body.single-product .woocommerce div.product .stock,
.woocommerce.single-product div.product .stock {
    margin-bottom: 16px;
    color: #111111;
    font-size: 11px;
    font-weight: 650;
    letter-spacing: 0.06em;
}

body.single-product .woocommerce div.product div.images .woocommerce-product-gallery__image,
.woocommerce.single-product div.product div.images .woocommerce-product-gallery__image {
    min-height: clamp(440px, 44vw, 600px);
}

body.single-product .woocommerce div.product div.images img,
.woocommerce.single-product div.product div.images img {
    height: clamp(440px, 44vw, 600px);
}

body.single-product .woocommerce div.product form.cart,
.woocommerce.single-product div.product form.cart {
    display: flex !important;
    align-items: stretch !important;
    gap: 12px !important;
}

body.single-product .woocommerce div.product form.cart div.quantity,
body.single-product .woocommerce div.product form.cart .quantity,
.woocommerce.single-product div.product form.cart div.quantity,
.woocommerce.single-product div.product form.cart .quantity {
    flex: 0 0 92px !important;
    float: none !important;
    margin: 0 !important;
}

body.single-product .woocommerce div.product form.cart .qty,
.woocommerce.single-product div.product form.cart .qty {
    width: 92px !important;
    height: 54px !important;
    border-color: #d7d7d7 !important;
    border-radius: 4px !important;
    font-size: 14px !important;
    font-weight: 500 !important;
}

body.single-product .woocommerce div.product form.cart .single_add_to_cart_button,
body.single-product .woocommerce div.product form.cart .button,
.woocommerce.single-product div.product form.cart .single_add_to_cart_button,
.woocommerce.single-product div.product form.cart .button {
    flex: 1 1 auto !important;
    width: auto !important;
    min-width: 220px !important;
    min-height: 54px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    float: none !important;
    white-space: nowrap !important;
    border-radius: 999px !important;
    font-size: 14px !important;
    font-weight: 650 !important;
}

body.single-product .taeef-product-assurance {
    margin-top: 24px;
    border-top: 0;
}

body.single-product .taeef-product-assurance span {
    min-height: 34px;
    border-bottom: 0;
    color: #242424;
    font-size: 12px;
    font-weight: 560;
}

body.single-product .taeef-product-assurance span::before {
    width: 4px;
    height: 4px;
    margin-right: 12px;
}

body.single-product .woocommerce div.product .product_meta,
.woocommerce.single-product div.product .product_meta {
    margin-top: 18px;
    padding-top: 12px;
    border-top: 0;
    color: #777777;
    font-size: 11px;
}

@media (max-width: 560px) {
    body.single-product .woocommerce div.product .product_title,
    .woocommerce.single-product div.product .product_title {
        max-width: 24ch;
        font-size: clamp(22px, 6.3vw, 28px) !important;
    }

    body.single-product .woocommerce div.product div.images .woocommerce-product-gallery__image,
    .woocommerce.single-product div.product div.images .woocommerce-product-gallery__image {
        min-height: 340px;
    }

    body.single-product .woocommerce div.product div.images img,
    .woocommerce.single-product div.product div.images img {
        height: 340px;
    }

    body.single-product .woocommerce div.product form.cart,
    .woocommerce.single-product div.product form.cart {
        display: grid !important;
        grid-template-columns: 1fr !important;
    }

    body.single-product .woocommerce div.product form.cart div.quantity,
    body.single-product .woocommerce div.product form.cart .quantity,
    .woocommerce.single-product div.product form.cart div.quantity,
    .woocommerce.single-product div.product form.cart .quantity {
        flex-basis: auto !important;
    }

    body.single-product .woocommerce div.product form.cart .qty,
    .woocommerce.single-product div.product form.cart .qty {
        width: 100% !important;
    }

    body.single-product .woocommerce div.product form.cart .single_add_to_cart_button,
    body.single-product .woocommerce div.product form.cart .button,
    .woocommerce.single-product div.product form.cart .single_add_to_cart_button,
    .woocommerce.single-product div.product form.cart .button {
        width: 100% !important;
        min-width: 0 !important;
    }
}

