/*
Theme Name: Nony's Jams — Bold Edition
Theme URI: https://nonysjams.com
Description: Dark, bold child theme for Nony's Jams & Chutneys WooCommerce shop. High-contrast design with warm accent colors.
Author: Jelle
Author URI: https://nonysjams.com
Template: astra
Version: 1.0.0
Text Domain: astra-nonys-jams
License: GPL v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
*/

/* ══════════════════════════════════════════════════════════
   NONY'S JAMS — BOLD THEME
   Based on Theme C: Dark background, high-contrast accents
   ══════════════════════════════════════════════════════════ */

/* ── CSS CUSTOM PROPERTIES ── */
:root {
    --nj-primary: #C45D3E;
    --nj-primary-hover: #d96a4e;
    --nj-secondary: #8B2635;
    --nj-accent: #2D5A5A;
    --nj-bg-dark: #1a1a1a;
    --nj-bg-darker: #111111;
    --nj-card-bg: #222222;
    --nj-text-light: #f5f5f5;
    --nj-text-muted: rgba(255, 255, 255, 0.5);
    --nj-highlight: #E8A87C;
    --nj-border-subtle: rgba(255, 255, 255, 0.06);
    --nj-border-card: rgba(255, 255, 255, 0.05);
}

/* ── GLOBAL RESET & BASE ── */
body,
.ast-separate-container,
.ast-plain-container {
    background-color: var(--nj-bg-dark);
    color: var(--nj-text-light);
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
    line-height: 1.6;
}

a {
    color: var(--nj-text-muted);
    text-decoration: none;
    transition: color 0.3s ease;
}

a:hover,
a:focus {
    color: var(--nj-primary);
}

::selection {
    background: var(--nj-primary);
    color: #fff;
}

/* ── TYPOGRAPHY ── */
h1, h2, h3, h4, h5, h6,
.entry-title,
.woocommerce-loop-product__title,
.product_title,
.ast-archive-title {
    font-family: 'Playfair Display', Georgia, serif;
    font-weight: 900;
    color: #fff;
    letter-spacing: -0.5px;
}

.ast-archive-description p,
.woocommerce-result-count {
    color: var(--nj-text-muted);
    font-weight: 300;
}

/* ── HEADER / NAVIGATION ── */
.ast-primary-header-bar,
.ast-main-header-bar-alignment,
.site-header,
.main-header-bar {
    background-color: rgba(26, 26, 26, 0.92) !important;
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    border-bottom: 1px solid var(--nj-border-subtle) !important;
}

.site-title a,
.ast-site-identity .site-title a,
.site-header .site-title a {
    font-family: 'Playfair Display', serif !important;
    font-weight: 900 !important;
    color: #fff !important;
    letter-spacing: -0.5px;
    font-size: 1.5rem !important;
}

/* Logo dot accent */
.site-title a::after {
    content: '.';
    color: var(--nj-primary);
}

.main-header-menu > .menu-item > a,
.ast-header-break-point .ast-button-wrap .menu-toggle,
.ast-masthead .ast-inline-search .search-field {
    color: var(--nj-text-muted) !important;
    font-size: 0.85rem !important;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    font-weight: 500;
}

.main-header-menu > .menu-item > a:hover,
.main-header-menu > .menu-item.current-menu-item > a {
    color: var(--nj-primary) !important;
}

/* Cart icon in header */
.ast-site-header-cart .ast-cart-menu-wrap,
.ast-site-header-cart a {
    color: #fff !important;
}

.ast-site-header-cart .count {
    background-color: var(--nj-primary) !important;
    color: #fff !important;
    font-size: 0.6rem;
}

/* Mobile menu */
.ast-mobile-popup-drawer .ast-mobile-popup-inner,
.ast-mobile-header-content,
.ast-header-break-point .main-header-menu {
    background-color: var(--nj-bg-dark) !important;
    border-color: var(--nj-border-subtle) !important;
}

.ast-header-break-point .main-header-menu .menu-item a {
    color: var(--nj-text-muted) !important;
}

/* ── HERO SECTION (via homepage block/widget) ── */
.nj-hero {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    position: relative;
    overflow: hidden;
    background: var(--nj-bg-darker);
}

.nj-hero::before {
    content: '';
    position: absolute;
    top: -50%;
    left: -50%;
    width: 200%;
    height: 200%;
    background:
        radial-gradient(circle at 30% 60%, rgba(196, 93, 62, 0.15) 0%, transparent 50%),
        radial-gradient(circle at 70% 30%, rgba(139, 38, 53, 0.1) 0%, transparent 50%);
    animation: njSlowDrift 20s ease-in-out infinite alternate;
}

@keyframes njSlowDrift {
    0% { transform: translate(0, 0); }
    100% { transform: translate(-3%, 3%); }
}

.nj-hero-content {
    position: relative;
    z-index: 2;
    max-width: 900px;
    padding: 2rem;
}

.nj-hero-eyebrow {
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 5px;
    color: var(--nj-primary);
    margin-bottom: 2rem;
    font-weight: 600;
    display: block;
}

.nj-hero h1 {
    font-size: clamp(3.5rem, 8vw, 7rem);
    line-height: 0.95;
    letter-spacing: -2px;
    margin-bottom: 1.5rem;
}

.nj-hero h1 .accent {
    color: var(--nj-primary);
}

.nj-hero p {
    font-size: 1.1rem;
    color: var(--nj-text-muted);
    max-width: 550px;
    margin: 0 auto 2.5rem;
    font-weight: 300;
    line-height: 1.8;
}

.nj-scroll-indicator {
    position: absolute;
    bottom: 2rem;
    left: 50%;
    transform: translateX(-50%);
    color: var(--nj-text-muted);
    font-size: 0.75rem;
    letter-spacing: 2px;
    text-transform: uppercase;
    animation: njBounce 2s infinite;
}

@keyframes njBounce {
    0%, 100% { transform: translateX(-50%) translateY(0); }
    50% { transform: translateX(-50%) translateY(8px); }
}

/* ── BUTTONS ── */
.nj-btn,
.button,
.wp-element-button,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit {
    font-family: 'Inter', sans-serif;
    font-size: 0.85rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 2px;
    transition: all 0.3s ease;
    cursor: pointer;
    border-radius: 0;
}

/* Primary button — fire style */
.nj-btn-fire,
.woocommerce a.button.alt,
.woocommerce button.button.alt,
.woocommerce input.button.alt,
.woocommerce #respond input#submit.alt,
.checkout-button,
.single_add_to_cart_button {
    background-color: var(--nj-primary) !important;
    color: #fff !important;
    border: none !important;
    padding: 1rem 3rem !important;
    clip-path: polygon(0 0, 100% 0, 96% 100%, 4% 100%);
}

.nj-btn-fire:hover,
.woocommerce a.button.alt:hover,
.woocommerce button.button.alt:hover,
.woocommerce input.button.alt:hover,
.checkout-button:hover,
.single_add_to_cart_button:hover {
    background-color: var(--nj-primary-hover) !important;
    transform: scale(1.03);
}

/* Outline button */
.nj-btn-outline,
.woocommerce a.button:not(.alt),
.woocommerce button.button:not(.alt) {
    background: transparent !important;
    color: var(--nj-primary) !important;
    border: 2px solid var(--nj-primary) !important;
    padding: 0.7rem 1.6rem !important;
}

.nj-btn-outline:hover,
.woocommerce a.button:not(.alt):hover,
.woocommerce button.button:not(.alt):hover {
    background: var(--nj-primary) !important;
    color: #fff !important;
}

/* ── USP BANNER ── */
.nj-usp-banner {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    background: var(--nj-card-bg);
    border-top: 2px solid var(--nj-primary);
}

.nj-usp-item {
    text-align: center;
    padding: 2.5rem 1rem;
    border-right: 1px solid var(--nj-border-subtle);
    transition: background 0.3s ease;
}

.nj-usp-item:last-child {
    border-right: none;
}

.nj-usp-item:hover {
    background: rgba(196, 93, 62, 0.05);
}

.nj-usp-icon {
    margin-bottom: 0.8rem;
}

.nj-usp-icon svg {
    width: 28px;
    height: 28px;
    stroke: var(--nj-primary);
}

.nj-usp-label {
    font-size: 0.8rem;
    text-transform: uppercase;
    letter-spacing: 2px;
    font-weight: 700;
    color: #fff;
}

.nj-usp-sub {
    font-size: 0.73rem;
    color: var(--nj-text-muted);
    margin-top: 0.3rem;
}

/* ── WOOCOMMERCE: SHOP PAGE ── */
.woocommerce .products,
.woocommerce-page .products {
    max-width: 1200px;
    margin: 0 auto;
}

.ast-woocommerce-container {
    background: transparent !important;
}

/* Section headers */
.woocommerce-products-header__title,
.ast-archive-title {
    font-size: clamp(2.5rem, 5vw, 4rem) !important;
    text-align: center;
    margin-bottom: 0.5rem !important;
}

/* ── WOOCOMMERCE: PRODUCT CARDS ── */
.woocommerce ul.products li.product,
.ast-woo-shop-archive .product {
    background: var(--nj-card-bg);
    border: 1px solid var(--nj-border-card);
    border-radius: 0;
    overflow: hidden;
    position: relative;
    transition: all 0.4s ease;
    margin-bottom: 2rem;
}

/* Top accent line on hover */
.woocommerce ul.products li.product::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: var(--nj-primary);
    transform: scaleX(0);
    transition: transform 0.4s ease;
    z-index: 5;
}

.woocommerce ul.products li.product:hover::before {
    transform: scaleX(1);
}

.woocommerce ul.products li.product:hover {
    border-color: rgba(196, 93, 62, 0.3);
    transform: translateY(-6px);
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
}

/* Product image container */
.woocommerce ul.products li.product .astra-shop-thumbnail-wrap,
.woocommerce ul.products li.product a img,
.woocommerce ul.products li.product .woocommerce-loop-product__link img {
    border-radius: 0;
}

.woocommerce ul.products li.product .astra-shop-thumbnail-wrap {
    position: relative;
    overflow: hidden;
}

/* Product title */
.woocommerce ul.products li.product .woocommerce-loop-product__title,
.woocommerce ul.products li.product .astra-shop-summary-wrap .woocommerce-loop-product__title {
    font-family: 'Playfair Display', serif !important;
    font-size: 1.5rem !important;
    font-weight: 900 !important;
    color: #fff !important;
    letter-spacing: -0.5px;
    margin-bottom: 0.5rem;
}

/* Product description */
.woocommerce ul.products li.product .astra-shop-summary-wrap .ast-woo-product-category {
    color: var(--nj-text-muted);
    font-size: 0.88rem;
    font-weight: 300;
}

/* Product price */
.woocommerce ul.products li.product .price,
.woocommerce ul.products li.product .price .woocommerce-Price-amount {
    font-family: 'Playfair Display', serif !important;
    font-size: 1.4rem !important;
    font-weight: 700 !important;
    color: var(--nj-primary) !important;
}

.woocommerce ul.products li.product .price .woocommerce-Price-currencySymbol {
    color: var(--nj-primary) !important;
}

/* Add to cart button on product card */
.woocommerce ul.products li.product .button.add_to_cart_button {
    background: transparent !important;
    color: var(--nj-primary) !important;
    border: 2px solid var(--nj-primary) !important;
    padding: 0.7rem 1.6rem !important;
    font-size: 0.78rem !important;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    font-weight: 700;
    border-radius: 0 !important;
}

.woocommerce ul.products li.product .button.add_to_cart_button:hover {
    background: var(--nj-primary) !important;
    color: #fff !important;
}

/* Spice level badge (added via hook) */
.nj-spice-badge {
    position: absolute;
    bottom: 1rem;
    right: 1rem;
    background: rgba(0, 0, 0, 0.6);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    padding: 0.4rem 0.8rem;
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--nj-text-light);
    border: 1px solid rgba(255, 255, 255, 0.1);
    z-index: 4;
}

/* ── WOOCOMMERCE: SINGLE PRODUCT PAGE ── */
.single-product .site-content,
.single-product .ast-container {
    background: var(--nj-bg-dark);
}

.single-product .product .product_title {
    font-size: clamp(2rem, 4vw, 3rem) !important;
    margin-bottom: 0.5rem;
}

.single-product .product .price {
    font-family: 'Playfair Display', serif !important;
    font-size: 2rem !important;
    color: var(--nj-primary) !important;
}

.single-product .product .woocommerce-product-details__short-description,
.single-product .product .woocommerce-Tabs-panel p,
.single-product .product .description p {
    color: var(--nj-text-muted);
    font-weight: 300;
    line-height: 1.8;
}

/* Spice level on single product */
.nj-spice-level-single {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    background: rgba(0, 0, 0, 0.4);
    border: 1px solid rgba(255, 255, 255, 0.1);
    padding: 0.5rem 1rem;
    margin-bottom: 1rem;
    font-size: 0.85rem;
    font-weight: 600;
}

/* Product tabs */
.single-product .woocommerce-tabs ul.tabs {
    border-bottom: 1px solid var(--nj-border-subtle) !important;
    background: transparent !important;
}

.single-product .woocommerce-tabs ul.tabs li {
    background: transparent !important;
    border: none !important;
}

.single-product .woocommerce-tabs ul.tabs li a {
    color: var(--nj-text-muted) !important;
    font-size: 0.85rem;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    font-weight: 500;
}

.single-product .woocommerce-tabs ul.tabs li.active a {
    color: var(--nj-primary) !important;
}

.single-product .woocommerce-tabs .woocommerce-Tabs-panel {
    background: transparent !important;
    border: none !important;
    color: var(--nj-text-muted);
}

/* Quantity input */
.woocommerce .quantity .qty {
    background: var(--nj-card-bg) !important;
    color: var(--nj-text-light) !important;
    border: 1px solid var(--nj-border-subtle) !important;
    border-radius: 0;
}

/* Related products */
.single-product .related.products h2 {
    font-size: 2rem !important;
    text-align: center;
    margin-bottom: 2rem !important;
}

/* ── WOOCOMMERCE: CART ── */
.woocommerce-cart .woocommerce table.shop_table,
.woocommerce-cart .cart_totals table {
    background: var(--nj-card-bg) !important;
    border: 1px solid var(--nj-border-card) !important;
    border-radius: 0;
}

.woocommerce table.shop_table th,
.woocommerce table.shop_table td {
    border-color: var(--nj-border-subtle) !important;
    color: var(--nj-text-light);
}

.woocommerce table.shop_table td.product-name a {
    color: #fff !important;
    font-family: 'Playfair Display', serif;
    font-weight: 700;
}

.woocommerce table.shop_table td.product-name a:hover {
    color: var(--nj-primary) !important;
}

.woocommerce table.shop_table td.product-price,
.woocommerce table.shop_table td.product-subtotal {
    color: var(--nj-primary) !important;
    font-family: 'Playfair Display', serif;
    font-weight: 700;
}

.woocommerce .cart_totals h2 {
    color: #fff;
}

/* Remove button */
.woocommerce a.remove {
    color: var(--nj-primary) !important;
}

.woocommerce a.remove:hover {
    background: var(--nj-primary) !important;
    color: #fff !important;
}

/* ── WOOCOMMERCE: CHECKOUT ── */
.woocommerce-checkout .woocommerce-billing-fields h3,
.woocommerce-checkout .woocommerce-shipping-fields h3,
.woocommerce-checkout h3#order_review_heading {
    color: #fff;
    font-family: 'Playfair Display', serif;
}

.woocommerce form .form-row label {
    color: var(--nj-text-muted);
}

.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select,
.select2-container--default .select2-selection--single {
    background: var(--nj-card-bg) !important;
    color: var(--nj-text-light) !important;
    border: 1px solid var(--nj-border-subtle) !important;
    border-radius: 0 !important;
    padding: 0.8rem 1rem;
}

.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row textarea:focus {
    border-color: var(--nj-primary) !important;
    box-shadow: 0 0 0 1px var(--nj-primary) !important;
    outline: none;
}

.woocommerce-checkout #payment {
    background: var(--nj-card-bg) !important;
    border: 1px solid var(--nj-border-card) !important;
    border-radius: 0;
}

.woocommerce-checkout #payment ul.payment_methods {
    border-bottom: 1px solid var(--nj-border-subtle) !important;
}

.woocommerce-checkout #payment div.payment_box {
    background: rgba(0, 0, 0, 0.2) !important;
    color: var(--nj-text-muted);
}

/* ── WOOCOMMERCE: MY ACCOUNT ── */
.woocommerce-account .woocommerce-MyAccount-navigation ul li a {
    color: var(--nj-text-muted);
    border-bottom: 1px solid var(--nj-border-subtle);
    padding: 0.8rem 0;
}

.woocommerce-account .woocommerce-MyAccount-navigation ul li.is-active a,
.woocommerce-account .woocommerce-MyAccount-navigation ul li a:hover {
    color: var(--nj-primary);
}

/* ── QUOTE / CTA SECTION ── */
.nj-cta-section {
    padding: 6rem 2rem;
    text-align: center;
    position: relative;
    overflow: hidden;
    background: var(--nj-bg-darker);
}

.nj-cta-section::before {
    content: '\201C';
    position: absolute;
    top: -1rem;
    left: 50%;
    transform: translateX(-50%);
    font-family: 'Playfair Display', serif;
    font-size: 15rem;
    color: rgba(196, 93, 62, 0.06);
    line-height: 1;
}

.nj-cta-section blockquote {
    font-family: 'Playfair Display', serif;
    font-size: clamp(1.5rem, 3.5vw, 2.5rem);
    font-style: italic;
    max-width: 700px;
    margin: 0 auto 1rem;
    line-height: 1.4;
    position: relative;
    z-index: 1;
    color: var(--nj-text-light);
}

.nj-cta-section cite {
    font-style: normal;
    color: var(--nj-primary);
    font-family: 'Inter', sans-serif;
    font-size: 0.9rem;
    font-weight: 600;
}

/* ── FOOTER ── */
.site-footer,
.ast-footer-overlay,
.ast-small-footer {
    background-color: var(--nj-bg-darker) !important;
    border-top: 1px solid var(--nj-border-subtle) !important;
    color: var(--nj-text-muted) !important;
}

.site-footer .widget-title,
.ast-small-footer .widget-title {
    color: var(--nj-primary) !important;
    font-size: 0.75rem !important;
    text-transform: uppercase;
    letter-spacing: 3px;
}

.site-footer a,
.ast-small-footer a {
    color: var(--nj-text-muted) !important;
}

.site-footer a:hover,
.ast-small-footer a:hover {
    color: var(--nj-primary) !important;
}

.ast-small-footer .ast-footer-copyright {
    color: var(--nj-text-muted) !important;
    font-size: 0.75rem;
}

/* Payment badges in footer */
.nj-payment-row {
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;
}

.nj-payment-pill {
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.08);
    padding: 0.3rem 0.7rem;
    font-size: 0.7rem;
    color: var(--nj-text-muted);
    letter-spacing: 0.5px;
}

/* Social links */
.nj-social-link {
    display: inline-flex;
    width: 42px;
    height: 42px;
    border: 1px solid rgba(255, 255, 255, 0.1);
    align-items: center;
    justify-content: center;
    transition: all 0.3s ease;
    margin-right: 0.5rem;
}

.nj-social-link:hover {
    border-color: var(--nj-primary);
    background: rgba(196, 93, 62, 0.1);
}

.nj-social-link svg {
    width: 18px;
    height: 18px;
    fill: currentColor;
}

/* ── WOOCOMMERCE: NOTICES ── */
.woocommerce-message,
.woocommerce-info {
    background-color: var(--nj-card-bg) !important;
    border-top-color: var(--nj-primary) !important;
    color: var(--nj-text-light) !important;
}

.woocommerce-message::before,
.woocommerce-info::before {
    color: var(--nj-primary) !important;
}

.woocommerce-error {
    background-color: var(--nj-card-bg) !important;
    border-top-color: var(--nj-secondary) !important;
    color: var(--nj-text-light) !important;
}

/* ── WOOCOMMERCE: SALE BADGE ── */
.woocommerce span.onsale,
.ast-onsale-card {
    background-color: var(--nj-primary) !important;
    color: #fff !important;
    border-radius: 0 !important;
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1px;
}

/* ── WOOCOMMERCE: STAR RATINGS ── */
.woocommerce .star-rating span::before {
    color: var(--nj-primary) !important;
}

.woocommerce .star-rating::before {
    color: rgba(255, 255, 255, 0.15) !important;
}

/* ── PAGINATION ── */
.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span {
    background: var(--nj-card-bg) !important;
    color: var(--nj-text-muted) !important;
    border-color: var(--nj-border-subtle) !important;
}

.woocommerce nav.woocommerce-pagination ul li span.current,
.woocommerce nav.woocommerce-pagination ul li a:hover {
    background: var(--nj-primary) !important;
    color: #fff !important;
    border-color: var(--nj-primary) !important;
}

/* ── BREADCRUMBS ── */
.ast-breadcrumbs,
.woocommerce-breadcrumb {
    color: var(--nj-text-muted) !important;
    font-size: 0.8rem;
}

.woocommerce-breadcrumb a {
    color: var(--nj-text-muted) !important;
}

.woocommerce-breadcrumb a:hover {
    color: var(--nj-primary) !important;
}

/* ── SIDEBAR WIDGETS (if used) ── */
.widget {
    background: var(--nj-card-bg);
    border: 1px solid var(--nj-border-card);
    padding: 1.5rem;
}

.widget .widget-title {
    color: #fff;
    font-family: 'Playfair Display', serif;
}

/* ── SCROLLBAR ── */
::-webkit-scrollbar {
    width: 8px;
}

::-webkit-scrollbar-track {
    background: var(--nj-bg-darker);
}

::-webkit-scrollbar-thumb {
    background: rgba(255, 255, 255, 0.15);
    border-radius: 4px;
}

::-webkit-scrollbar-thumb:hover {
    background: var(--nj-primary);
}

/* ── RESPONSIVE ── */
@media (max-width: 900px) {
    .nj-usp-banner {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 768px) {
    .nj-usp-banner {
        grid-template-columns: repeat(2, 1fr);
    }

    .nj-hero h1 {
        letter-spacing: -1px;
    }

    .nj-usp-item {
        padding: 1.5rem 0.8rem;
    }
}

@media (max-width: 480px) {
    .nj-usp-banner {
        grid-template-columns: 1fr;
    }
}

/* ── REDUCED MOTION ── */
@media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }
}
