/*
Theme Name: Shopkeeper - The Child Theme
Theme URI: https://shopkeeper.getbowtied.com
Description: This is the Child Theme for Shopkeeper - a Hassle-free Worpress Theme with great design and extensive functionality.
Author: Get Bowtied
Author URI: https://getbowtied.com
Template: shopkeeper
Version: 8.2
*/

/* ============================================================
   SECTION 1: Nav — typography + active state
   ============================================================ */

/* Sentence case + regular weight */
.show-for-large.main-navigation > ul > li > a {
    text-transform: none !important;
    font-weight: 400 !important;
    letter-spacing: 0.01em;
    font-size: 15px !important;
    position: relative;
    text-decoration: none;
}

/* Underline pseudo-element */
.show-for-large.main-navigation > ul > li > a::after {
    content: '';
    position: absolute;
    bottom: -2px;
    left: 0;
    width: 0;
    height: 1px;
    background: currentColor;
    transition: width 0.35s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

/* Active underline — current page only, never ancestor */
.show-for-large.main-navigation > ul > li:hover > a::after,
.show-for-large.main-navigation > ul > li.current-menu-item > a::after,
.show-for-large.main-navigation > ul > li.sk-nav-active > a::after {
    width: 100%;
}

.show-for-large.main-navigation > ul > li.current-menu-ancestor > a::after {
    width: 0 !important;
}

/* Sibling fade on hover */
.show-for-large.main-navigation > ul:hover > li > a {
    opacity: 0.4;
    transition: opacity 0.3s ease;
}

.show-for-large.main-navigation > ul > li:hover > a,
.show-for-large.main-navigation > ul > li.current-menu-item > a,
.show-for-large.main-navigation > ul > li.sk-nav-active > a {
    opacity: 1;
    transition: opacity 0.3s ease;
}

.show-for-large.main-navigation > ul > li.current-menu-ancestor > a {
    opacity: 0.4 !important;
}

/* Shop page category pills — sentence case */
.woocommerce-products-header .list_shop_categories .category_name {
    text-transform: none !important;
    font-size: 14px;
    letter-spacing: 0.01em;
}


/* ============================================================
   SECTION 2: Shop UI — filter icon + sort arrow
   ============================================================ */

.filters-text .lucide-icon {
    display: inline-flex;
    align-items: center;
    vertical-align: middle;
    margin-right: 6px;
}

.woocommerce-ordering .select2-selection__arrow {
    display: flex;
    align-items: center;
    justify-content: center;
}

.woocommerce-ordering .lucide-sort-arrow {
    display: inline-flex;
    align-items: center;
    position: absolute;
    right: 8px;
    top: 50%;
    transform: translateY(-50%);
}

.woocommerce-ordering .select2-selection__arrow b {
    display: none !important;
}

.woocommerce-ordering .select2-selection__rendered {
    text-transform: none !important;
    font-size: 14px;
    letter-spacing: 0.02em;
}

.select2-results__option {
    text-transform: none !important;
}

.woocommerce ul.products li.product .woocommerce-loop-product__title,
.wc-block-grid__products .wc-block-grid__product .wc-block-grid__product-link .wc-block-grid__product-title {
    font-size: 14px !important;
}


/* ============================================================
   SECTION 3: Archive headers — all category pages + shop page
   ============================================================ */

/* Black header */
.tax-product_cat .woocommerce-products-header.shop_header,
.woocommerce-shop .woocommerce-products-header.shop_header {
    background: #000 !important;
    min-height: 700px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 104px 60px;
    box-sizing: border-box;
    text-align: center;
}

/* Page title */
.tax-product_cat .woocommerce-products-header .page-title.on-shop,
.woocommerce-shop .woocommerce-products-header .page-title.on-shop {
    color: #fff !important;
    font-size: 32px !important;
    font-weight: 400;
    letter-spacing: 0.04em;
    margin-bottom: 16px;
}

/* Description */
.tax-product_cat .woocommerce-products-header .term-description,
.tax-product_cat .woocommerce-products-header .term-description p,
.woocommerce-shop .woocommerce-products-header .term-description,
.woocommerce-shop .aaboux-shop-description {
    color: rgba(255, 255, 255, 0.7);
    font-size: 14px;
    line-height: 1.8;
    max-width: 760px;
    width: 100%;
    margin: 0 auto 16px;
    text-align: center;
    display: block;
}

/* Category link list */
.tax-product_cat .woocommerce-products-header .list_shop_categories,
.woocommerce-shop .woocommerce-products-header .list_shop_categories {
    display: flex !important;
    flex-wrap: wrap;
    justify-content: center;
    list-style: none;
    margin: 32px 0 0;
    padding: 0;
    gap: 6px 20px;
}

.tax-product_cat .woocommerce-products-header .list_shop_categories .category_item,
.woocommerce-shop .woocommerce-products-header .list_shop_categories .category_item {
    margin: 0;
    padding: 0;
}

.tax-product_cat .woocommerce-products-header .list_shop_categories .category_item_link,
.woocommerce-shop .woocommerce-products-header .list_shop_categories .category_item_link {
    text-decoration: none;
}

.tax-product_cat .woocommerce-products-header .list_shop_categories .category_name,
.woocommerce-shop .woocommerce-products-header .list_shop_categories .category_name {
    font-size: 14px;
    letter-spacing: 0.2em;
    color: rgba(255, 255, 255, 0.7);
    position: relative;
    padding-bottom: 2px;
    transition: color 0.2s ease;
    display: inline-block;
}

.tax-product_cat .woocommerce-products-header .list_shop_categories .category_item_link:hover .category_name,
.woocommerce-shop .woocommerce-products-header .list_shop_categories .category_item_link:hover .category_name {
    color: #fff;
}

.tax-product_cat .woocommerce-products-header .list_shop_categories .category_name::after,
.woocommerce-shop .woocommerce-products-header .list_shop_categories .category_name::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 0;
    height: 1px;
    background: #fff;
    transition: width 0.25s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.tax-product_cat .woocommerce-products-header .list_shop_categories .category_item_link:hover .category_name::after,
.woocommerce-shop .woocommerce-products-header .list_shop_categories .category_item_link:hover .category_name::after {
    width: 100%;
}

/* All Bags — hide auto list, replaced by PHP output */
.term-bags .woocommerce-products-header .list_shop_categories {
    display: none !important;
}

/* Hide Uncategorized */
.woocommerce-products-header .list_shop_categories .category_item a[href*="uncategorized"] {
    display: none;
}

/* Column width fix */
.tax-product_cat .woocommerce-products-header .large-6.large-centered,
.woocommerce-shop .woocommerce-products-header .large-6.large-centered {
    width: 100% !important;
    max-width: 900px !important;
}

/* Category pills — correct weight and size */
.woocommerce-products-header .list_shop_categories .category_item_link .category_name {
    font-weight: 300 !important;
    font-size: 14px !important;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}


/* ============================================================
   SECTION 4: All Bags hook content
   ============================================================ */

.aaboux-cat-groups {
    width: 100%;
    max-width: 900px;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    gap: 32px;
    padding: 32px 0 0;
    margin-bottom: 16px;
    text-align: center;
}

.aaboux-cat-group {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 14px;
    padding-bottom: 8px;
}

.aaboux-cat-group__label {
    font-size: 14px;
    letter-spacing: 0.1em;
    color: rgba(255, 255, 255, 0.5);
    display: block;
}

.aaboux-cat-row {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 16px 20px;
}

.aaboux-cat-row li {
    margin: 0;
    padding: 0;
}

.aaboux-cat-row a {
    font-size: 14px;
    color: #fff;
    text-decoration: none;
    opacity: 0.75;
    position: relative;
    padding-bottom: 2px;
    transition: opacity 0.2s ease;
}

.aaboux-cat-row a::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 0;
    height: 1px;
    background: #fff;
    transition: width 0.25s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.aaboux-cat-row a:hover {
    opacity: 1;
}

.aaboux-cat-row a:hover::after {
    width: 100%;
}

.aaboux-archive-hero__desc {
    color: rgba(255, 255, 255, 0.7);
    font-size: 14px;
    line-height: 1.8;
    max-width: 760px !important;
    width: 100% !important;
    margin: 0 auto 16px;
    text-align: center;
}

.term-description {
    color: rgba(255, 255, 255, 0.7);
    font-size: 14px;
    line-height: 1.8;
    max-width: 760px !important;
    width: 100% !important;
    margin: 0 auto 16px;
    text-align: center;
}


/* ============================================================
   SECTION 5: Product grid — centred alignment
   ============================================================ */

.woocommerce ul.products {
    text-align: center;
}

.woocommerce ul.products li.product {
    text-align: center;
}

/* Add to basket button — sentence case */
.button.add_to_cart_button {
    text-transform: none !important;
    letter-spacing: 0.02em;
}


/* ============================================================
   SECTION 6: Layout
   ============================================================ */

.content-area {
    padding: 5px 0 0 0;
}


/* ============================================================
   SECTION 7: Footer
   ============================================================ */

/* Widget titles */
.site-footer-widget-area .widget-title {
    font-size: 14px;
    font-weight: 500;
    letter-spacing: 0.12em;
    margin-bottom: 24px;
    color: #fff;
}

/* Nav menu links */
.site-footer-widget-area .widget_nav_menu .menu {
    list-style: none;
    margin: 0;
    padding: 0;
}

.site-footer-widget-area .widget_nav_menu .menu li {
    margin: 0 0 12px;
    padding: 0;
}

.site-footer-widget-area .widget_nav_menu .menu a {
    font-size: 14px;
    font-weight: 300;
    color: rgba(255, 255, 255, 0.75);
    text-decoration: none;
    letter-spacing: 0.02em;
    transition: color 0.2s ease;
    text-transform: none;
}

.site-footer-widget-area .widget_nav_menu .menu a:hover {
    color: #fff;
}

/* Footer newsletter */
.site-footer-widget-area .widget_mc4wp_form_widget .widget-title {
    margin-bottom: 12px;
}

.site-footer-widget-area .mc4wp-form label {
    display: none !important;
}

.site-footer-widget-area .mc4wp-form-fields {
    font-size: 13px;
    font-weight: 300;
    color: rgba(255, 255, 255, 0.75);
    line-height: 1.7;
    background: transparent !important;
    display: block !important;
    padding: 0 !important;
}

.site-footer-widget-area .mc4wp-form-fields p {
    margin: 0 0 8px;
}

/* Pill wrapper created by JS */
.aaboux-newsletter-pill {
    display: flex;
    align-items: center;
    background: #fff;
    border-radius: 12px;
    padding: 4px 4px 4px 16px;
    gap: 8px;
    margin-top: 12px;
}

.aaboux-newsletter-pill input[type="email"] {
    flex: 1 1 auto !important;
    min-width: 0 !important;
    width: auto !important;
    background: transparent !important;
    border: none !important;
    border-radius: 0 !important;
    padding: 8px 0 !important;
    font-size: 13px !important;
    color: #000 !important;
    outline: none !important;
    margin: 0 !important;
    box-shadow: none !important;
    font-family: inherit;
}

.site-footer-widget-area .mc4wp-form input[type="email"] {
    flex: 1;
    background: transparent !important;
    border: none !important;
    border-radius: 0 !important;
    padding: 8px 0 !important;
    font-size: 13px !important;
    color: #000 !important;
    outline: none !important;
    margin: 0 !important;
    box-shadow: none !important;
    font-family: inherit;
    min-width: 0;
}

.site-footer-widget-area .mc4wp-form input[type="email"]::placeholder {
    color: rgba(0, 0, 0, 0.4);
}

.site-footer-widget-area .mc4wp-form input[type="submit"],
.aaboux-newsletter-pill input[type="submit"] {
    flex-shrink: 0;
    flex: 0 0 auto !important;
    width: auto !important;
    background: #000 !important;
    border: none !important;
    border-radius: 10px !important;
    padding: 10px 20px !important;
    font-size: 12px !important;
    font-weight: 400 !important;
    letter-spacing: 0.08em !important;
    text-decoration: none !important;
    color: #fff !important;
    cursor: pointer !important;
    margin: 0 !important;
    font-family: inherit;
    transition: background 0.2s ease !important;
    white-space: nowrap;
}

.site-footer-widget-area .mc4wp-form input[type="submit"]:hover,
.aaboux-newsletter-pill input[type="submit"]:hover {
    background: #323570 !important;
}


/* ============================================================
   SECTION 8: PDP Accordions — Materials, Dimensions, Care
   ============================================================ */

.aaboux-accordions {
    margin: 24px 0;
    border-top: 1px solid #e8e8e8;
}

.aaboux-accordion {
    border-bottom: 1px solid #e8e8e8;
}

.aaboux-accordion__trigger {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    background: none;
    border: none;
    padding: 18px 0;
    cursor: pointer;
    text-align: left;
    color: inherit;
    font-family: inherit;
}

.aaboux-accordion__title {
    font-size: 14px;
    font-weight: 500;
    letter-spacing: 0.02em;
    color: #000;
}

.aaboux-accordion__icon {
    display: flex;
    align-items: center;
    transition: transform 0.25s ease;
    color: #000;
    flex-shrink: 0;
}

.aaboux-accordion.is-open .aaboux-accordion__icon {
    transform: rotate(180deg);
}

.aaboux-accordion__body {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.3s ease;
}

.aaboux-accordion__content {
    padding: 0 0 20px;
}

.aaboux-accordion__content p {
    font-size: 14px;
    line-height: 1.7;
    color: #333;
    margin: 0 0 6px;
}

.aaboux-accordion__content p:last-child {
    margin-bottom: 0;
}

.aaboux-attr-label {
    font-weight: 400;
    color: #000;
}

/* PDP — product description font size */
.single-product .woocommerce-product-details__short-description p {
    font-size: 14px !important;
    line-height: 1.8;
}

/* PDP Price */
.product_layout_classic .product_content_wrapper .product_infos .price {
    font-size: 20px !important;
    font-weight: 700;
}

/* Product title */
.woocommerce #content div.product .product_title,
.woocommerce div.product .product_title,
.woocommerce-page #content div.product .product_title,
.woocommerce-page div.product .product_title {
    font-size: 32px;
    font-weight: 700;
}

/* Quantity input */
.single-product .quantity.default {
    display: flex !important;
    align-items: center;
}

.single-product .quantity.default input.qty {
    -webkit-appearance: none !important;
    appearance: none !important;
    display: inline-block !important;
    width: 48px !important;
    height: 48px !important;
    text-align: center;
    border: 1px solid #e8e8e8;
    border-radius: 12px;
    font-size: 14px;
    font-family: inherit;
    background: #fff;
    color: #000;
}

/* Add to bag button */
.single-product .single_add_to_cart_button.button {
    border-radius: 12px !important;
    background: #000 !important;
    color: #fff !important;
    border: none !important;
    font-size: 13px !important;
    font-weight: 400 !important;
    letter-spacing: 0.04em !important;
    text-transform: none !important;
    padding: 14px 32px !important;
    transition: background 0.2s ease !important;
}

.single-product .single_add_to_cart_button.button:hover {
    background: #323570 !important;
    color: #fff !important;
}

.woocommerce:where(body:not(.woocommerce-uses-block-theme)) div.product .stock {
    color: #A3A3A3;
}

/* Cookie Buttons */
.wt-cli-accept-all-btn {
    border-radius: 12px !important;
}


/* ============================================================
   SECTION 9: FAQ Page — Elementor Nested Accordion
   ============================================================ */

.e-n-accordion {
    border-top: 1px solid #e8e8e8 !important;
}

.e-n-accordion-item {
    border-bottom: 1px solid #e8e8e8 !important;
    background: transparent !important;
}

.e-n-accordion-item-title {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    padding: 18px 0 !important;
    cursor: pointer;
    list-style: none;
    background: transparent !important;
    border: none !important;
    gap: 16px;
}

.e-n-accordion-item-title::-webkit-details-marker {
    display: none;
}

.e-n-accordion-item-title-header {
    flex: 1 !important;
}

.e-n-accordion-item-title-icon {
    flex-shrink: 0 !important;
    margin-left: auto !important;
}

.e-n-accordion-item-title-icon svg path {
    fill: #000 !important;
}

.elementor-widget-n-accordion .e-n-accordion-item-title-text {
    font-weight: 400 !important;
    font-size: 14px !important;
    letter-spacing: 0.02em !important;
    color: #000 !important;
    font-family: inherit !important;
}

.elementor-widget-n-accordion {
    --n-accordion-title-font-size: 14px;
}

.e-n-accordion-item > .e-con {
    padding-top: 0 !important;
    padding-bottom: 20px !important;
}

.e-n-accordion-item .elementor-widget-text-editor p {
    font-size: 13px !important;
    line-height: 1.8 !important;
    color: #333 !important;
    margin: 0 0 8px !important;
    font-family: inherit !important;
}

.e-n-accordion-item .elementor-widget-text-editor p:last-child {
    margin-bottom: 0 !important;
}

/* FAQ category label — left column */
.elementor-widget-heading .elementor-heading-title {
    font-size: 11px !important;
    font-weight: 500 !important;
    letter-spacing: 0.12em !important;
    text-transform: uppercase !important;
    color: #000 !important;
}