/*
 Theme Name:   Captains Vape Lounge Child
 Theme URI:    https://captainsvape.co.uk
 Description:  Custom child theme for Captains Vape Lounge - Vape E-Liquid & Hardware Store
 Author:       Captains Vape Lounge
 Author URI:   https://captainsvape.co.uk
 Template:     oceanwp
 Version:      1.0.0
 License:      GNU General Public License v2 or later
 License URI:  https://www.gnu.org/licenses/gpl-2.0.html
 Text Domain:  captains-vape-child
 Tags:         woocommerce, ecommerce, vape, eliquid
*/

/* ==========================================================================
   Parent theme: OceanWP (free from wordpress.org)
   If using a different parent theme, change "Template: oceanwp" above
   to match the parent theme's folder name in wp-content/themes/

   Verified theme folder names:
   - oceanwp        → OceanWP (recommended - most free WooCommerce features)
   - astra          → Astra (lightweight, fast)
   - flavor         → Flavor
   - flavor         → flavor

   Check wp-content/themes/ on your server for the exact folder name.
   ========================================================================== */

/* ==========================================================================
   CSS Variables - Brand Colors
   ========================================================================== */

:root {
    /* Primary Brand Colors - Pirate Captain Theme */
    --cv-primary: #1a1a1a;           /* Rich black - matches logo */
    --cv-primary-light: #2d2d2d;     /* Slightly lighter black */
    --cv-secondary: #c8102e;         /* Bold captain red */
    --cv-accent: #8b6914;            /* Aged gold / brass */
    --cv-gold: #d4a03c;              /* Treasure gold - premium accent */
    --cv-cream: #f5f0e8;             /* Aged parchment cream */

    /* Neutrals */
    --cv-white: #ffffff;
    --cv-off-white: #f7f5f0;         /* Warm off-white / parchment tint */
    --cv-light-grey: #e5e0d8;        /* Warm grey */
    --cv-mid-grey: #6b6560;          /* Warm mid grey */
    --cv-dark-grey: #3a3530;         /* Warm dark grey */
    --cv-black: #1a1a1a;             /* Matches logo black */

    /* Status Colors */
    --cv-success: #2d7a3a;
    --cv-warning: #d4a03c;
    --cv-danger: #c8102e;
    --cv-info: #2e6b8a;

    /* Typography - Western/Serif to match "THE CAPTAIN'S" logo text */
    --cv-font-primary: 'Libre Franklin', 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    --cv-font-heading: 'Playfair Display', 'Georgia', serif;
    --cv-font-display: 'Rye', 'Playfair Display', serif; /* Western display font matching logo */

    /* Spacing */
    --cv-section-gap: 60px;
    --cv-container-width: 1320px;
    --cv-border-radius: 6px;

    /* Shadows - slightly warmer */
    --cv-shadow-sm: 0 1px 3px rgba(26,26,26,0.08);
    --cv-shadow-md: 0 4px 12px rgba(26,26,26,0.12);
    --cv-shadow-lg: 0 8px 30px rgba(26,26,26,0.15);

    /* Transitions */
    --cv-transition: all 0.3s ease;
}

/* ==========================================================================
   Base & Typography
   ========================================================================== */

body {
    font-family: var(--cv-font-primary);
    color: var(--cv-black);
    line-height: 1.6;
    -webkit-font-smoothing: antialiased;
}

h1, h2, h3, h4, h5, h6 {
    font-family: var(--cv-font-heading);
    font-weight: 700;
    color: var(--cv-primary);
    line-height: 1.3;
}

/* Display headings use the Western font matching "THE CAPTAIN'S" */
.cv-section-header h2,
.cv-hero-content h1,
.cv-page-hero h1 {
    font-family: var(--cv-font-display);
    text-transform: uppercase;
    letter-spacing: 2px;
}

a {
    color: var(--cv-secondary);
    transition: var(--cv-transition);
}

a:hover {
    color: var(--cv-accent);
    text-decoration: none;
}

/* ==========================================================================
   Announcement Bar
   ========================================================================== */

.cv-announcement-bar {
    background: var(--cv-primary);
    color: var(--cv-white);
    text-align: center;
    padding: 8px 20px;
    font-size: 13px;
    font-weight: 500;
    letter-spacing: 0.5px;
    position: relative;
    z-index: 100;
    border-bottom: 2px solid var(--cv-gold);
}

.cv-announcement-bar a {
    color: var(--cv-gold);
    text-decoration: underline;
    font-weight: 600;
}

.cv-announcement-bar .cv-announcement-items {
    display: flex;
    justify-content: center;
    gap: 40px;
    flex-wrap: wrap;
}

.cv-announcement-bar .cv-announcement-item {
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

.cv-announcement-bar .cv-announcement-item svg {
    width: 16px;
    height: 16px;
    fill: var(--cv-gold);
}

/* ==========================================================================
   Header
   ========================================================================== */

.cv-header {
    background: var(--cv-white);
    box-shadow: var(--cv-shadow-sm);
    position: sticky;
    top: 0;
    z-index: 99;
}

.cv-header-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 15px 0;
    max-width: var(--cv-container-width);
    margin: 0 auto;
    padding-left: 20px;
    padding-right: 20px;
}

.cv-logo img {
    max-height: 50px;
    width: auto;
}

/* Logo combo: icon + text side by side */
.cv-logo-link {
    text-decoration: none !important;
    display: block;
}

.cv-logo-combo {
    display: flex;
    align-items: center;
    gap: 10px;
}

.cv-logo-icon {
    max-height: 50px;
    width: auto;
}

.cv-logo-text {
    display: flex;
    flex-direction: column;
    line-height: 1.1;
}

.cv-logo-name {
    font-family: var(--cv-font-display);
    font-size: 20px;
    font-weight: 400;
    color: var(--cv-black);
    text-transform: uppercase;
    letter-spacing: 2px;
    white-space: nowrap;
}

.cv-logo-tagline {
    font-family: var(--cv-font-primary);
    font-size: 11px;
    font-weight: 600;
    color: var(--cv-gold);
    text-transform: uppercase;
    letter-spacing: 3px;
}

.cv-search-form {
    flex: 1;
    max-width: 500px;
    margin: 0 30px;
    position: relative;
}

.cv-search-form input[type="search"] {
    width: 100%;
    padding: 12px 50px 12px 20px;
    border: 2px solid var(--cv-light-grey);
    border-radius: 50px;
    font-size: 14px;
    transition: var(--cv-transition);
    outline: none;
}

.cv-search-form input[type="search"]:focus {
    border-color: var(--cv-secondary);
    box-shadow: 0 0 0 3px rgba(233, 69, 96, 0.1);
}

.cv-search-form button {
    position: absolute;
    right: 5px;
    top: 50%;
    transform: translateY(-50%);
    background: var(--cv-secondary);
    border: none;
    border-radius: 50%;
    width: 38px;
    height: 38px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: var(--cv-transition);
}

.cv-search-form button:hover {
    background: var(--cv-accent);
}

.cv-search-form button svg {
    width: 18px;
    height: 18px;
    fill: var(--cv-white);
}

.cv-header-actions {
    display: flex;
    align-items: center;
    gap: 20px;
}

.cv-header-actions a {
    display: flex;
    align-items: center;
    gap: 6px;
    color: var(--cv-dark-grey);
    font-size: 14px;
    font-weight: 500;
}

.cv-header-actions a:hover {
    color: var(--cv-secondary);
}

.cv-cart-count {
    background: var(--cv-secondary);
    color: var(--cv-white);
    font-size: 11px;
    font-weight: 700;
    width: 20px;
    height: 20px;
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    position: relative;
    top: -8px;
    left: -5px;
}

/* ==========================================================================
   Navigation / Mega Menu Support
   ========================================================================== */

.cv-main-nav {
    background: var(--cv-primary);
}

.cv-main-nav .cv-nav-inner {
    max-width: var(--cv-container-width);
    margin: 0 auto;
    padding: 0 20px;
}

.cv-main-nav ul.cv-menu {
    display: flex;
    list-style: none;
    margin: 0;
    padding: 0;
}

.cv-main-nav ul.cv-menu > li > a {
    display: block;
    padding: 14px 20px;
    color: var(--cv-white);
    font-size: 14px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    transition: var(--cv-transition);
}

.cv-main-nav ul.cv-menu > li > a:hover,
.cv-main-nav ul.cv-menu > li.current-menu-item > a {
    background: var(--cv-secondary);
    color: var(--cv-white);
}

/* Gold accent line under nav */
.cv-main-nav {
    border-bottom: 3px solid var(--cv-gold);
}

/* Mega Menu Dropdown */
.cv-main-nav .mega-menu-wrap {
    position: absolute;
    left: 0;
    right: 0;
    background: var(--cv-white);
    box-shadow: var(--cv-shadow-lg);
    padding: 30px;
    display: none;
    z-index: 98;
}

.cv-main-nav li:hover .mega-menu-wrap {
    display: block;
}

.mega-menu-columns {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 30px;
    max-width: var(--cv-container-width);
    margin: 0 auto;
}

.mega-menu-column h4 {
    font-size: 14px;
    font-weight: 700;
    text-transform: uppercase;
    color: var(--cv-primary);
    margin-bottom: 15px;
    padding-bottom: 10px;
    border-bottom: 2px solid var(--cv-gold);
    font-family: var(--cv-font-heading);
    letter-spacing: 0.5px;
}

.mega-menu-column ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.mega-menu-column ul li a {
    display: block;
    padding: 5px 0;
    color: var(--cv-mid-grey);
    font-size: 14px;
    transition: var(--cv-transition);
}

.mega-menu-column ul li a:hover {
    color: var(--cv-secondary);
    padding-left: 5px;
}

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

.cv-hero-slider {
    position: relative;
    overflow: hidden;
}

.cv-hero-slide {
    position: relative;
    min-height: 450px;
    display: flex;
    align-items: center;
    background-size: cover;
    background-position: center;
}

.cv-hero-slide::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgba(26,26,26,0.9) 0%, rgba(26,26,26,0.5) 100%);
}

.cv-hero-content {
    position: relative;
    z-index: 2;
    max-width: var(--cv-container-width);
    margin: 0 auto;
    padding: 60px 20px;
    color: var(--cv-white);
}

.cv-hero-content h1 {
    font-size: 48px;
    font-weight: 400;
    color: var(--cv-white);
    margin-bottom: 15px;
    line-height: 1.1;
    font-family: var(--cv-font-display);
    text-transform: uppercase;
    letter-spacing: 3px;
}

.cv-hero-content h1::after {
    content: '';
    display: block;
    width: 80px;
    height: 3px;
    background: var(--cv-gold);
    margin-top: 15px;
}

.cv-hero-content p {
    font-size: 18px;
    margin-bottom: 25px;
    opacity: 0.9;
    max-width: 500px;
}

.cv-btn {
    display: inline-block;
    padding: 14px 32px;
    font-size: 15px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1px;
    border-radius: var(--cv-border-radius);
    transition: var(--cv-transition);
    cursor: pointer;
    text-decoration: none;
    border: none;
}

.cv-btn-primary {
    background: var(--cv-secondary);
    color: var(--cv-white);
}

.cv-btn-primary:hover {
    background: #d63851;
    transform: translateY(-2px);
    box-shadow: var(--cv-shadow-md);
    color: var(--cv-white);
}

.cv-btn-secondary {
    background: transparent;
    color: var(--cv-white);
    border: 2px solid var(--cv-white);
}

.cv-btn-secondary:hover {
    background: var(--cv-white);
    color: var(--cv-primary);
}

.cv-btn-gold {
    background: var(--cv-gold);
    color: var(--cv-primary);
    border: 2px solid var(--cv-gold);
}

.cv-btn-gold:hover {
    background: transparent;
    color: var(--cv-gold);
    border-color: var(--cv-gold);
    transform: translateY(-2px);
}

/* ==========================================================================
   Category Tiles
   ========================================================================== */

.cv-section {
    padding: var(--cv-section-gap) 0;
}

.cv-container {
    max-width: var(--cv-container-width);
    margin: 0 auto;
    padding: 0 20px;
}

.cv-section-header {
    text-align: center;
    margin-bottom: 40px;
}

.cv-section-header h2 {
    font-size: 32px;
    margin-bottom: 10px;
    font-family: var(--cv-font-display);
    text-transform: uppercase;
    letter-spacing: 2px;
}

.cv-section-header h2::after {
    content: '';
    display: block;
    width: 60px;
    height: 3px;
    background: var(--cv-gold);
    margin: 12px auto 0;
}

.cv-section-header p {
    color: var(--cv-mid-grey);
    font-size: 16px;
}

.cv-category-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
}

.cv-category-tile {
    position: relative;
    border-radius: var(--cv-border-radius);
    overflow: hidden;
    background: var(--cv-primary);
    transition: var(--cv-transition);
    aspect-ratio: 16/10;
}

.cv-category-tile:hover {
    transform: translateY(-5px);
    box-shadow: var(--cv-shadow-lg);
}

.cv-category-tile img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    opacity: 0.5;
    transition: var(--cv-transition);
}

.cv-category-tile:hover img {
    opacity: 0.3;
    transform: scale(1.05);
}

.cv-category-tile-content {
    position: absolute;
    inset: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 20px;
    text-align: center;
    z-index: 2;
}

.cv-category-tile h3 {
    color: var(--cv-white);
    font-size: 22px;
    font-weight: 700;
    margin-bottom: 5px;
    font-family: var(--cv-font-heading);
    text-transform: uppercase;
    letter-spacing: 1px;
}

.cv-category-tile span {
    color: var(--cv-gold);
    font-size: 13px;
    font-weight: 500;
    letter-spacing: 0.5px;
}

/* ==========================================================================
   Brand Carousel
   ========================================================================== */

.cv-brands-section {
    background: var(--cv-off-white);
}

.cv-brands-grid {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    gap: 40px;
}

.cv-brands-grid img {
    max-height: 50px;
    width: auto;
    filter: grayscale(100%);
    opacity: 0.6;
    transition: var(--cv-transition);
}

.cv-brands-grid img:hover {
    filter: grayscale(0%);
    opacity: 1;
}

/* ==========================================================================
   Multi-Buy Deals
   ========================================================================== */

.cv-deals-section {
    background: linear-gradient(135deg, var(--cv-primary) 0%, #2d2015 50%, var(--cv-primary) 100%);
    color: var(--cv-white);
    border-top: 3px solid var(--cv-gold);
    border-bottom: 3px solid var(--cv-gold);
}

.cv-deals-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 20px;
}

.cv-deal-card {
    background: rgba(255,255,255,0.1);
    border: 1px solid rgba(255,255,255,0.2);
    border-radius: var(--cv-border-radius);
    padding: 30px 20px;
    text-align: center;
    transition: var(--cv-transition);
}

.cv-deal-card:hover {
    background: rgba(255,255,255,0.15);
    transform: translateY(-3px);
}

.cv-deal-card .cv-deal-price {
    font-size: 36px;
    font-weight: 800;
    color: var(--cv-gold);
    line-height: 1;
    margin-bottom: 5px;
}

.cv-deal-card .cv-deal-label {
    font-size: 16px;
    font-weight: 600;
    margin-bottom: 15px;
    opacity: 0.9;
}

.cv-deal-card .cv-deal-desc {
    font-size: 13px;
    opacity: 0.7;
    margin-bottom: 20px;
}

/* ==========================================================================
   Product Grid (WooCommerce Override)
   ========================================================================== */

.woocommerce ul.products {
    display: grid !important;
    grid-template-columns: repeat(4, 1fr);
    gap: 20px;
}

.woocommerce ul.products li.product {
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    float: none !important;
    background: var(--cv-white);
    border-radius: var(--cv-border-radius);
    overflow: hidden;
    box-shadow: var(--cv-shadow-sm);
    transition: var(--cv-transition);
}

.woocommerce ul.products li.product:hover {
    box-shadow: var(--cv-shadow-md);
    transform: translateY(-3px);
}

.woocommerce ul.products li.product a img {
    border-radius: 0;
    margin: 0 !important;
}

.woocommerce ul.products li.product .woocommerce-loop-product__title {
    font-size: 14px !important;
    font-weight: 600;
    padding: 10px 15px 0 !important;
    color: var(--cv-dark-grey);
}

.woocommerce ul.products li.product .price {
    padding: 5px 15px;
    color: var(--cv-secondary) !important;
    font-weight: 700;
    font-size: 16px !important;
}

.woocommerce ul.products li.product .price del {
    color: var(--cv-mid-grey) !important;
    font-size: 13px !important;
}

.woocommerce ul.products li.product .price ins {
    color: var(--cv-secondary) !important;
    font-weight: 700;
    text-decoration: none;
}

.woocommerce ul.products li.product .button,
.woocommerce ul.products li.product .add_to_cart_button {
    display: block !important;
    width: calc(100% - 30px) !important;
    margin: 10px 15px 15px !important;
    padding: 10px !important;
    background: var(--cv-secondary) !important;
    color: var(--cv-white) !important;
    border-radius: var(--cv-border-radius) !important;
    text-align: center;
    font-weight: 600;
    font-size: 13px !important;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    transition: var(--cv-transition);
}

.woocommerce ul.products li.product .button:hover,
.woocommerce ul.products li.product .add_to_cart_button:hover {
    background: var(--cv-accent) !important;
}

/* Sale Badge */
.woocommerce ul.products li.product .onsale,
.woocommerce span.onsale {
    background: var(--cv-secondary) !important;
    color: var(--cv-white);
    border-radius: var(--cv-border-radius);
    padding: 5px 12px;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    min-height: auto;
    min-width: auto;
    line-height: 1.5;
    letter-spacing: 0.5px;
    font-family: var(--cv-font-primary);
}

/* Product badges - New, Bundle, etc */
.cv-product-badge {
    position: absolute;
    top: 10px;
    right: 10px;
    padding: 4px 10px;
    border-radius: 4px;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    z-index: 5;
}

.cv-badge-new {
    background: var(--cv-success);
    color: var(--cv-white);
}

.cv-badge-bundle {
    background: var(--cv-gold);
    color: var(--cv-primary);
}

.cv-badge-deal {
    background: var(--cv-secondary);
    color: var(--cv-white);
}

/* ==========================================================================
   Single Product Page
   ========================================================================== */

.woocommerce div.product {
    max-width: var(--cv-container-width);
    margin: 0 auto;
    padding: 30px 20px;
}

.woocommerce div.product .product_title {
    font-size: 28px;
    font-weight: 700;
    color: var(--cv-primary);
}

.woocommerce div.product p.price {
    font-size: 24px !important;
    color: var(--cv-secondary) !important;
    font-weight: 700;
}

/* Product meta - VG/PG, Nic Strength, etc. */
.cv-product-meta-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 10px;
    margin: 20px 0;
    padding: 20px;
    background: var(--cv-off-white);
    border-radius: var(--cv-border-radius);
}

.cv-product-meta-item {
    text-align: center;
}

.cv-product-meta-item .label {
    font-size: 11px;
    text-transform: uppercase;
    color: var(--cv-mid-grey);
    letter-spacing: 0.5px;
    display: block;
}

.cv-product-meta-item .value {
    font-size: 16px;
    font-weight: 700;
    color: var(--cv-primary);
    display: block;
}

/* Add to cart button */
.woocommerce div.product .single_add_to_cart_button {
    background: var(--cv-secondary) !important;
    color: var(--cv-white) !important;
    border-radius: var(--cv-border-radius) !important;
    padding: 14px 40px !important;
    font-size: 16px !important;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1px;
    transition: var(--cv-transition);
}

.woocommerce div.product .single_add_to_cart_button:hover {
    background: var(--cv-accent) !important;
    transform: translateY(-2px);
    box-shadow: var(--cv-shadow-md);
}

/* Quantity input */
.woocommerce div.product .quantity .qty {
    border: 2px solid var(--cv-light-grey);
    border-radius: var(--cv-border-radius);
    padding: 10px;
    font-size: 16px;
    width: 80px;
}

/* Tabs */
.woocommerce div.product .woocommerce-tabs ul.tabs li a {
    font-weight: 600;
    color: var(--cv-mid-grey);
}

.woocommerce div.product .woocommerce-tabs ul.tabs li.active a {
    color: var(--cv-secondary);
}

/* ==========================================================================
   Trust Badges / Why Choose Us
   ========================================================================== */

.cv-trust-section {
    background: var(--cv-off-white);
}

.cv-trust-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 30px;
}

.cv-trust-item {
    text-align: center;
    padding: 30px 20px;
}

.cv-trust-item .cv-trust-icon {
    width: 60px;
    height: 60px;
    margin: 0 auto 15px;
    background: var(--cv-primary);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 2px solid var(--cv-gold);
}

.cv-trust-item .cv-trust-icon svg {
    fill: var(--cv-gold);
}

.cv-trust-item .cv-trust-icon svg {
    width: 28px;
    height: 28px;
    fill: var(--cv-white);
}

.cv-trust-item h4 {
    font-size: 16px;
    margin-bottom: 8px;
}

.cv-trust-item p {
    font-size: 14px;
    color: var(--cv-mid-grey);
    margin: 0;
}

/* ==========================================================================
   Newsletter Section
   ========================================================================== */

.cv-newsletter-section {
    background: var(--cv-primary);
    color: var(--cv-white);
    text-align: center;
    border-top: 3px solid var(--cv-gold);
}

.cv-newsletter-section h2 {
    color: var(--cv-white);
    font-size: 28px;
    margin-bottom: 10px;
}

.cv-newsletter-section p {
    opacity: 0.8;
    margin-bottom: 25px;
}

.cv-newsletter-form {
    display: flex;
    justify-content: center;
    gap: 10px;
    max-width: 500px;
    margin: 0 auto;
}

.cv-newsletter-form input[type="email"] {
    flex: 1;
    padding: 14px 20px;
    border: none;
    border-radius: var(--cv-border-radius);
    font-size: 15px;
    outline: none;
}

.cv-newsletter-form button {
    padding: 14px 30px;
    background: var(--cv-secondary);
    color: var(--cv-white);
    border: none;
    border-radius: var(--cv-border-radius);
    font-weight: 700;
    font-size: 15px;
    cursor: pointer;
    transition: var(--cv-transition);
}

.cv-newsletter-form button:hover {
    background: #d63851;
}

/* ==========================================================================
   Footer
   ========================================================================== */

.cv-footer {
    background: var(--cv-primary);
    color: rgba(255,255,255,0.7);
    padding: 60px 0 0;
}

.cv-footer-grid {
    display: grid;
    grid-template-columns: 2fr 1fr 1fr 1fr;
    gap: 40px;
    max-width: var(--cv-container-width);
    margin: 0 auto;
    padding: 0 20px;
}

.cv-footer h4 {
    color: var(--cv-gold);
    font-size: 15px;
    margin-bottom: 20px;
    text-transform: uppercase;
    letter-spacing: 1px;
    font-family: var(--cv-font-heading);
    border-bottom: 1px solid rgba(212,160,60,0.3);
    padding-bottom: 10px;
}

.cv-footer p {
    font-size: 14px;
    line-height: 1.7;
}

.cv-footer ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.cv-footer ul li {
    margin-bottom: 8px;
}

.cv-footer ul li a {
    color: rgba(255,255,255,0.7);
    font-size: 14px;
    transition: var(--cv-transition);
}

.cv-footer ul li a:hover {
    color: var(--cv-gold);
    padding-left: 8px;
}

.cv-footer-social {
    display: flex;
    gap: 12px;
    margin-top: 20px;
}

.cv-footer-social a {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: rgba(255,255,255,0.1);
    display: flex;
    align-items: center;
    justify-content: center;
    transition: var(--cv-transition);
}

.cv-footer-social a:hover {
    background: var(--cv-secondary);
}

.cv-footer-social a svg {
    width: 18px;
    height: 18px;
    fill: var(--cv-white);
}

.cv-footer-bottom {
    border-top: 1px solid rgba(255,255,255,0.1);
    margin-top: 40px;
    padding: 20px 0;
    text-align: center;
    font-size: 13px;
}

.cv-footer-bottom .cv-age-notice {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: rgba(200,16,46,0.2);
    padding: 8px 16px;
    border-radius: 50px;
    margin-bottom: 15px;
    font-weight: 600;
    color: var(--cv-secondary);
    border: 1px solid rgba(200,16,46,0.3);
}

.cv-footer-payment {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 15px;
    margin-top: 15px;
}

.cv-footer-payment img {
    height: 30px;
    width: auto;
    opacity: 0.7;
}

/* ==========================================================================
   Age Gate Overlay
   ========================================================================== */

.cv-age-gate-overlay {
    position: fixed;
    inset: 0;
    background: rgba(26,26,26,0.95);
    z-index: 99999;
    display: flex;
    align-items: center;
    justify-content: center;
    backdrop-filter: blur(10px);
}

.cv-age-gate-box {
    background: var(--cv-white);
    border-radius: 16px;
    padding: 50px 40px;
    text-align: center;
    max-width: 450px;
    width: 90%;
    box-shadow: var(--cv-shadow-lg);
}

.cv-age-gate-box .cv-age-logo {
    max-width: 200px;
    margin-bottom: 25px;
}

.cv-age-gate-box h2 {
    font-size: 24px;
    margin-bottom: 10px;
    font-family: var(--cv-font-display);
    text-transform: uppercase;
    letter-spacing: 1px;
}

.cv-age-gate-box p {
    color: var(--cv-mid-grey);
    margin-bottom: 30px;
    font-size: 15px;
}

.cv-age-gate-buttons {
    display: flex;
    gap: 15px;
    justify-content: center;
}

.cv-age-gate-buttons .cv-btn {
    min-width: 140px;
}

.cv-age-gate-deny {
    background: var(--cv-light-grey);
    color: var(--cv-mid-grey);
}

.cv-age-gate-deny:hover {
    background: var(--cv-danger);
    color: var(--cv-white);
}

.cv-age-gate-footer {
    margin-top: 20px;
    font-size: 12px;
    color: var(--cv-mid-grey);
}

/* ==========================================================================
   WooCommerce Cart & Checkout
   ========================================================================== */

.woocommerce-cart .woocommerce table.shop_table {
    border-radius: var(--cv-border-radius);
    overflow: hidden;
    border: 1px solid var(--cv-light-grey);
}

.woocommerce-cart .woocommerce table.shop_table th {
    background: var(--cv-off-white);
    font-weight: 700;
    text-transform: uppercase;
    font-size: 12px;
    letter-spacing: 0.5px;
}

.woocommerce .cart-collaterals .cart_totals {
    background: var(--cv-off-white);
    padding: 25px;
    border-radius: var(--cv-border-radius);
}

.woocommerce #payment #place_order {
    background: var(--cv-secondary) !important;
    color: var(--cv-white) !important;
    border-radius: var(--cv-border-radius) !important;
    font-size: 16px !important;
    font-weight: 700;
    padding: 14px 30px !important;
    transition: var(--cv-transition);
}

.woocommerce #payment #place_order:hover {
    background: var(--cv-accent) !important;
}

/* ==========================================================================
   Breadcrumbs
   ========================================================================== */

.woocommerce .woocommerce-breadcrumb {
    font-size: 13px;
    color: var(--cv-mid-grey);
    padding: 15px 0;
    margin-bottom: 0;
}

.woocommerce .woocommerce-breadcrumb a {
    color: var(--cv-secondary);
}

/* ==========================================================================
   Product Filters Sidebar
   ========================================================================== */

.cv-shop-sidebar .widget {
    margin-bottom: 30px;
    padding: 20px;
    background: var(--cv-white);
    border-radius: var(--cv-border-radius);
    box-shadow: var(--cv-shadow-sm);
}

.cv-shop-sidebar .widget-title {
    font-size: 14px;
    font-weight: 700;
    text-transform: uppercase;
    margin-bottom: 15px;
    padding-bottom: 10px;
    border-bottom: 2px solid var(--cv-gold);
    font-family: var(--cv-font-heading);
    letter-spacing: 0.5px;
    color: var(--cv-primary);
}

/* ==========================================================================
   Responsive
   ========================================================================== */

@media (max-width: 1024px) {
    .cv-category-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .woocommerce ul.products {
        grid-template-columns: repeat(3, 1fr) !important;
    }

    .cv-deals-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .cv-trust-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .cv-footer-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 768px) {
    :root {
        --cv-section-gap: 40px;
    }

    .cv-announcement-bar .cv-announcement-items {
        flex-direction: column;
        gap: 5px;
    }

    .cv-header-inner {
        flex-wrap: wrap;
        gap: 10px;
    }

    .cv-search-form {
        order: 3;
        max-width: 100%;
        margin: 10px 0 0;
        flex-basis: 100%;
    }

    .cv-hero-content h1 {
        font-size: 32px;
    }

    .cv-hero-slide {
        min-height: 350px;
    }

    .cv-category-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 10px;
    }

    .woocommerce ul.products {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 10px;
    }

    .cv-deals-grid {
        grid-template-columns: 1fr 1fr;
        gap: 10px;
    }

    .cv-section-header h2 {
        font-size: 24px;
    }

    .cv-trust-grid {
        grid-template-columns: 1fr 1fr;
        gap: 15px;
    }

    .cv-footer-grid {
        grid-template-columns: 1fr;
        gap: 30px;
    }

    .cv-newsletter-form {
        flex-direction: column;
    }

    .mega-menu-columns {
        grid-template-columns: 1fr 1fr;
    }

    .cv-product-meta-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 480px) {
    .cv-category-grid {
        grid-template-columns: 1fr;
    }

    .woocommerce ul.products {
        grid-template-columns: 1fr 1fr !important;
    }

    .cv-deals-grid {
        grid-template-columns: 1fr;
    }

    .cv-hero-content h1 {
        font-size: 26px;
    }

    .cv-age-gate-box {
        padding: 30px 20px;
    }

    .cv-age-gate-buttons {
        flex-direction: column;
    }
}

/* ==========================================================================
   Utility Classes
   ========================================================================== */

.cv-text-center { text-align: center; }
.cv-text-left { text-align: left; }
.cv-text-right { text-align: right; }
.cv-mt-0 { margin-top: 0; }
.cv-mb-0 { margin-bottom: 0; }
.cv-hidden { display: none; }
.cv-visible { display: block; }

/* Loading spinner for AJAX */
.cv-loading {
    display: inline-block;
    width: 20px;
    height: 20px;
    border: 3px solid var(--cv-light-grey);
    border-top-color: var(--cv-secondary);
    border-radius: 50%;
    animation: cv-spin 0.8s linear infinite;
}

@keyframes cv-spin {
    to { transform: rotate(360deg); }
}


/* ==========================================================================
   COMPREHENSIVE MOBILE & TABLET OPTIMIZATION
   The Captain's Vape Lounge - Added for responsive perfection
   ========================================================================== */

/* --- GLOBAL MOBILE (under 768px) --- */
@media (max-width: 768px) {
    html, body { overflow-x: hidden !important; }
    .entry-content, .site-content, .content-area { overflow-x: hidden !important; }
    
    /* Announcement bar */
    .cv-announcement-bar { font-size: 11px !important; padding: 6px 10px !important; }
    .cv-announcement-bar .cv-announcement-items { flex-direction: column !important; gap: 3px !important; }
    .cv-announcement-bar .cv-announcement-item svg { width: 14px !important; height: 14px !important; }
    
    /* Header */
    .cv-header-inner { padding: 10px 15px !important; }
    .cv-logo img, .cv-logo-icon { max-height: 35px !important; }
    .cv-logo-name { font-size: 14px !important; letter-spacing: 1px !important; }
    .cv-logo-tagline { font-size: 9px !important; letter-spacing: 2px !important; }
    .cv-search-form input[type="search"] { padding: 10px 45px 10px 15px !important; font-size: 14px !important; }
    .cv-search-form button { width: 34px !important; height: 34px !important; }
    
    /* Hero */
    .cv-hero-slide { min-height: 300px !important; }
    .cv-hero-content { padding: 30px 15px !important; }
    .cv-hero-content h1 { font-size: 24px !important; letter-spacing: 1px !important; }
    .cv-hero-content h1::after { width: 50px !important; margin-top: 10px !important; }
    .cv-hero-content p { font-size: 14px !important; margin-bottom: 20px !important; }
    
    /* Sections */
    .cv-section { padding: 30px 0 !important; }
    .cv-container { padding: 0 15px !important; }
    .cv-section-header h2 { font-size: 20px !important; letter-spacing: 1px !important; }
    .cv-section-header h2::after { width: 40px !important; }
    .cv-section-header p { font-size: 14px !important; }
    
    /* Category tiles */
    .cv-category-grid { grid-template-columns: 1fr 1fr !important; gap: 8px !important; }
    .cv-category-tile { aspect-ratio: 1/1 !important; }
    .cv-category-tile h3 { font-size: 14px !important; }
    .cv-category-tile span { font-size: 10px !important; }
    
    /* Brands */
    .cv-brands-grid { gap: 15px !important; }
    .cv-brands-grid span { padding: 8px 12px !important; font-size: 11px !important; }
    
    /* Deals */
    .cv-deals-grid { grid-template-columns: 1fr 1fr !important; gap: 8px !important; }
    .cv-deal-card { padding: 15px 10px !important; }
    .cv-deal-card .cv-deal-price { font-size: 24px !important; }
    .cv-deal-card .cv-deal-label { font-size: 13px !important; }
    .cv-deal-card .cv-deal-desc { font-size: 11px !important; display: none !important; }
    
    /* Products */
    .woocommerce ul.products { grid-template-columns: 1fr 1fr !important; gap: 8px !important; }
    .woocommerce ul.products li.product .woocommerce-loop-product__title { font-size: 12px !important; padding: 8px 10px 0 !important; }
    .woocommerce ul.products li.product .price { font-size: 14px !important; padding: 3px 10px !important; }
    .woocommerce ul.products li.product .button,
    .woocommerce ul.products li.product .add_to_cart_button { font-size: 11px !important; padding: 8px !important; margin: 5px 10px 10px !important; width: calc(100% - 20px) !important; }
    
    /* Trust badges */
    .cv-trust-grid { grid-template-columns: 1fr 1fr !important; gap: 10px !important; }
    .cv-trust-item { padding: 15px 10px !important; }
    .cv-trust-item .cv-trust-icon { width: 45px !important; height: 45px !important; }
    .cv-trust-item h4 { font-size: 13px !important; }
    .cv-trust-item p { font-size: 12px !important; }
    
    /* Newsletter */
    .cv-newsletter-section h2 { font-size: 20px !important; }
    .cv-newsletter-form { flex-direction: column !important; }
    .cv-newsletter-form input[type="email"], .cv-newsletter-form button { width: 100% !important; box-sizing: border-box !important; }
    
    /* Footer */
    .cv-footer-grid { grid-template-columns: 1fr !important; gap: 25px !important; }
    .cv-footer h4 { font-size: 14px !important; }
    .cv-footer-social { justify-content: center !important; }
    .cv-footer-payment { flex-wrap: wrap !important; }
    
    /* Age gate */
    .cv-age-gate-box { padding: 25px 15px !important; width: 92% !important; }
    .cv-age-gate-box .cv-age-logo { max-width: 80px !important; }
    .cv-age-gate-box h2 { font-size: 18px !important; }
    .cv-age-gate-box p { font-size: 13px !important; margin-bottom: 20px !important; }
    .cv-age-gate-buttons { flex-direction: column !important; gap: 10px !important; }
    .cv-age-gate-buttons .cv-btn { min-width: unset !important; }
    
    /* Single product */
    .cv-product-layout { grid-template-columns: 1fr !important; gap: 20px !important; padding: 15px !important; }
    .woocommerce div.product .product_title { font-size: 20px !important; }
    .woocommerce div.product p.price { font-size: 20px !important; }
    .cv-product-meta-grid { grid-template-columns: repeat(2, 1fr) !important; gap: 8px !important; padding: 12px !important; }
    .cv-delivery-info-box { padding: 12px !important; }
    .cv-delivery-row { font-size: 12px !important; gap: 8px !important; }
    
    /* Cart/checkout */
    .woocommerce #payment #place_order { width: 100% !important; font-size: 15px !important; }
    
    /* About/Contact pages */
    .cv-about-section, .cv-contact-layout { grid-template-columns: 1fr !important; }
    .cv-page-hero { padding: 30px 15px !important; border-radius: 0 !important; }
    .cv-page-hero h1 { font-size: 24px !important; }
    
    /* Back to top */
    .cv-back-to-top { width: 38px !important; height: 38px !important; bottom: 15px !important; right: 15px !important; }
    
    /* WooCommerce tabs stack on mobile */
    .woocommerce div.product .woocommerce-tabs ul.tabs { padding-left: 0 !important; }
    .woocommerce div.product .woocommerce-tabs ul.tabs li { display: block !important; margin: 0 !important; }
}

/* --- TABLET (769-1024px) --- */
@media (min-width: 769px) and (max-width: 1024px) {
    .cv-hero-content h1 { font-size: 32px !important; }
    .cv-category-grid { grid-template-columns: repeat(3, 1fr) !important; gap: 12px !important; }
    .cv-deals-grid { grid-template-columns: repeat(2, 1fr) !important; }
    .woocommerce ul.products { grid-template-columns: repeat(3, 1fr) !important; }
    .cv-trust-grid { grid-template-columns: repeat(2, 1fr) !important; }
    .cv-footer-grid { grid-template-columns: repeat(2, 1fr) !important; }
    .cv-product-layout { gap: 25px !important; }
    .cv-contact-layout { grid-template-columns: 1.5fr 1fr !important; }
}

/* --- SMALL MOBILE (under 380px) --- */
@media (max-width: 380px) {
    .cv-hero-content h1 { font-size: 20px !important; }
    .cv-category-grid { grid-template-columns: 1fr !important; }
    .cv-deals-grid { grid-template-columns: 1fr !important; }
    .cv-trust-grid { grid-template-columns: 1fr !important; }
    .cv-section-header h2 { font-size: 18px !important; }
    .cv-age-gate-box h2 { font-size: 16px !important; }
}

/* --- TOUCH DEVICES --- */
@media (hover: none) and (pointer: coarse) {
    .cv-btn { min-height: 44px !important; }
    .woocommerce ul.products li.product .button,
    .woocommerce ul.products li.product .add_to_cart_button { min-height: 44px !important; display: flex !important; align-items: center !important; justify-content: center !important; }
    .cv-category-tile:hover { transform: none !important; }
    .cv-deal-card:hover { transform: none !important; }
    .cv-product-quick-info { opacity: 1 !important; }
}


/* ============================================
   SHOP & CATEGORY PAGES - Full Width, No Sidebar
   ============================================ */

/* Force full-width layout on shop/category pages */
.woocommerce #content-wrap,
.woocommerce-page #content-wrap { max-width: 1200px; margin: 0 auto; }
.woocommerce #primary,
.woocommerce-page #primary { width: 100% !important; float: none !important; max-width: 100% !important; }
.woocommerce #content-wrap,
.woocommerce-page #content-wrap { display: block !important; }
.woocommerce #right-sidebar,
.woocommerce-page #right-sidebar,
.woocommerce #left-sidebar,
.woocommerce-page #left-sidebar,
.woocommerce .sidebar-container,
.woocommerce-page .sidebar-container,
.woocommerce #secondary,
.woocommerce-page #secondary { display: none !important; }

/* Also hide the broken category image placeholder on left */
.woocommerce .term-thumbnail,
.woocommerce-page .term-thumbnail,
.archive .page-header-bg { display: none !important; }

/* Shop page header styling */
.woocommerce .page-header { background: #1a1a2e !important; padding: 30px 0 !important; }
.woocommerce .page-header-title { color: #fff !important; font-family: 'Rye', serif !important; }

/* Product grid - 4 columns */
.woocommerce ul.products { display: grid !important; grid-template-columns: repeat(4, 1fr) !important; gap: 20px !important; }
.woocommerce ul.products li.product { width: 100% !important; margin: 0 !important; float: none !important; }

/* Product card styling on shop pages */
.woocommerce ul.products li.product { background: #fff; border-radius: 12px; overflow: hidden; box-shadow: 0 4px 20px rgba(0,0,0,0.1); transition: all 0.3s; padding: 0 !important; }
.woocommerce ul.products li.product:hover { transform: translateY(-5px); box-shadow: 0 12px 35px rgba(0,0,0,0.18); }
.woocommerce ul.products li.product a img { border-radius: 0; padding: 10px; background: #f8f8f8; }
.woocommerce ul.products li.product .woocommerce-loop-product__title,
.woocommerce ul.products li.product h2 { font-size: 14px !important; font-weight: 600 !important; padding: 10px 15px 5px !important; color: #1a1a2e !important; }
.woocommerce ul.products li.product .price { color: #d4a843 !important; font-weight: 700 !important; font-size: 18px !important; padding: 0 15px 10px !important; }
.woocommerce ul.products li.product .price del { color: #999 !important; font-size: 14px !important; }
.woocommerce ul.products li.product .price ins { text-decoration: none; color: #d4a843 !important; }

/* Add to cart button on shop page */
.woocommerce ul.products li.product .button,
.woocommerce ul.products li.product a.add_to_cart_button { background: #d4a843 !important; color: #1a1a2e !important; border-radius: 0 0 12px 12px !important; width: 100% !important; margin: 0 !important; padding: 12px !important; font-weight: 700 !important; text-transform: uppercase !important; border: none !important; transition: all 0.3s !important; }
.woocommerce ul.products li.product .button:hover,
.woocommerce ul.products li.product a.add_to_cart_button:hover { background: #e6bc5a !important; }

/* Sale badge */
.woocommerce ul.products li.product .onsale,
.woocommerce span.onsale { background: #e74c3c !important; color: #fff !important; border-radius: 4px !important; padding: 4px 10px !important; font-size: 12px !important; font-weight: 700 !important; min-width: auto !important; min-height: auto !important; line-height: normal !important; }

/* Category filter pills */
.woocommerce .oceanwp-toolbar .cat-links a,
.woocommerce-page .category-filter a { background: #f0f0f0; border: 1px solid #ddd; border-radius: 6px; padding: 6px 14px; color: #1a1a2e; transition: all 0.3s; }
.woocommerce .oceanwp-toolbar .cat-links a:hover,
.woocommerce .oceanwp-toolbar .cat-links a.active { background: #d4a843; color: #1a1a2e; border-color: #d4a843; }

/* Sorting toolbar */
.woocommerce .oceanwp-toolbar { border-bottom: 2px solid #eee; padding-bottom: 15px; margin-bottom: 25px; }

/* ============================================
   SINGLE PRODUCT PAGE
   ============================================ */

/* Add to Cart button - gold */
.woocommerce div.product form.cart .button,
.woocommerce div.product .single_add_to_cart_button { background: #d4a843 !important; color: #1a1a2e !important; font-weight: 700 !important; font-size: 16px !important; padding: 15px 40px !important; border-radius: 8px !important; border: none !important; text-transform: uppercase !important; transition: all 0.3s !important; letter-spacing: 1px !important; }
.woocommerce div.product form.cart .button:hover,
.woocommerce div.product .single_add_to_cart_button:hover { background: #e6bc5a !important; transform: translateY(-2px) !important; box-shadow: 0 6px 25px rgba(212,168,67,0.5) !important; }

/* Product title */
.woocommerce div.product .product_title { font-family: 'Rye', serif !important; font-size: 28px !important; color: #1a1a2e !important; }

/* Product price */
.woocommerce div.product .price { color: #d4a843 !important; font-size: 24px !important; font-weight: 700 !important; }
.woocommerce div.product .price del { color: #999 !important; }
.woocommerce div.product .price ins { text-decoration: none !important; }

/* Quantity input */
.woocommerce div.product .quantity .qty { border: 2px solid #ddd !important; border-radius: 6px !important; padding: 10px !important; font-size: 16px !important; }

/* Product tabs */
.woocommerce div.product .woocommerce-tabs ul.tabs li a { color: #1a1a2e !important; font-weight: 600 !important; }
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a { color: #d4a843 !important; border-bottom-color: #d4a843 !important; }

/* Variable product swatches */
.woocommerce div.product .variations select { border: 2px solid #ddd !important; border-radius: 6px !important; padding: 10px 15px !important; font-size: 14px !important; }
.woocommerce div.product .variations label { font-weight: 700 !important; color: #1a1a2e !important; font-size: 14px !important; }

/* Product meta */
.woocommerce div.product .product_meta { border-top: 1px solid #eee; padding-top: 15px; margin-top: 20px; }
.woocommerce div.product .product_meta .sku_wrapper,
.woocommerce div.product .product_meta .posted_in,
.woocommerce div.product .product_meta .tagged_as { color: #666; font-size: 13px; }

/* Related products heading */
.woocommerce div.product .related > h2,
.woocommerce div.product .upsells > h2 { font-family: 'Rye', serif !important; font-size: 24px !important; color: #1a1a2e !important; }

/* ============================================
   CART PAGE
   ============================================ */
.woocommerce-cart .wc-block-cart__submit-button,
.woocommerce .cart .button,
.woocommerce a.checkout-button { background: #d4a843 !important; color: #1a1a2e !important; font-weight: 700 !important; border: none !important; border-radius: 8px !important; padding: 15px 30px !important; text-transform: uppercase !important; transition: all 0.3s !important; }
.woocommerce-cart .wc-block-cart__submit-button:hover,
.woocommerce .cart .button:hover { background: #e6bc5a !important; }

/* ============================================
   CHECKOUT PAGE
   ============================================ */
.woocommerce-checkout #place_order,
.wc-block-checkout__actions_row .wc-block-components-button { background: #d4a843 !important; color: #1a1a2e !important; font-weight: 700 !important; font-size: 18px !important; border: none !important; border-radius: 8px !important; padding: 18px 40px !important; text-transform: uppercase !important; letter-spacing: 1px !important; transition: all 0.3s !important; }
.woocommerce-checkout #place_order:hover { background: #e6bc5a !important; box-shadow: 0 6px 25px rgba(212,168,67,0.5) !important; }

/* Checkout form styling */
.woocommerce-checkout .form-row input,
.woocommerce-checkout .form-row select,
.woocommerce-checkout .form-row textarea { border: 2px solid #ddd !important; border-radius: 6px !important; padding: 12px 15px !important; }
.woocommerce-checkout .form-row input:focus,
.woocommerce-checkout .form-row select:focus { border-color: #d4a843 !important; box-shadow: 0 0 0 2px rgba(212,168,67,0.2) !important; }

/* ============================================
   MY ACCOUNT PAGE
   ============================================ */
.woocommerce-account .woocommerce-MyAccount-navigation ul { list-style: none; padding: 0; }
.woocommerce-account .woocommerce-MyAccount-navigation ul li a { display: block; padding: 14px 20px; color: #1a1a2e; font-weight: 600; border-left: 3px solid transparent; transition: all 0.3s; text-decoration: none; }
.woocommerce-account .woocommerce-MyAccount-navigation ul li a:hover,
.woocommerce-account .woocommerce-MyAccount-navigation ul li.is-active a { background: #f8f9fa; border-left-color: #d4a843; color: #d4a843; }

/* Login form styling */
.woocommerce-form-login .button,
.woocommerce-form-register .button { background: #d4a843 !important; color: #1a1a2e !important; font-weight: 700 !important; border: none !important; border-radius: 8px !important; padding: 14px 30px !important; }

/* ============================================
   GLOBAL WOOCOMMERCE OVERRIDES
   ============================================ */

/* All WooCommerce buttons gold */
.woocommerce .button,
.woocommerce .btn,
.woocommerce input[type=submit] { background: #d4a843 !important; color: #1a1a2e !important; border: none !important; }

/* Breadcrumbs */
.woocommerce .woocommerce-breadcrumb { font-size: 13px; color: #999; padding: 15px 0; }
.woocommerce .woocommerce-breadcrumb a { color: #d4a843; text-decoration: none; }

/* Star ratings */
.woocommerce .star-rating span::before { color: #d4a843 !important; }

/* Remove sidebar category images that show broken */
.woocommerce-page .term-description img,
.woocommerce .category-image-placeholder { display: none; }

/* Pagination */
.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span { border-radius: 6px !important; margin: 0 3px; }
.woocommerce nav.woocommerce-pagination ul li span.current { background: #d4a843 !important; color: #1a1a2e !important; border-color: #d4a843 !important; }

/* ============================================
   RESPONSIVE - SHOP PAGES
   ============================================ */
@media (max-width: 992px) {
  .woocommerce ul.products { grid-template-columns: repeat(3, 1fr) !important; }
}
@media (max-width: 768px) {
  .woocommerce ul.products { grid-template-columns: repeat(2, 1fr) !important; gap: 10px !important; }
  .woocommerce div.product .product_title { font-size: 22px !important; }
}
@media (max-width: 480px) {
  .woocommerce ul.products { grid-template-columns: repeat(2, 1fr) !important; gap: 8px !important; }
  .woocommerce ul.products li.product h2 { font-size: 12px !important; }
  .woocommerce ul.products li.product .price { font-size: 14px !important; }
}


/* ============================================
   CUSTOM SINGLE PRODUCT PAGE - Vape Club Style
   ============================================ */

.cv-single-product { background: #fff; }
.cv-sp-container { max-width: 1200px; margin: 0 auto; padding: 20px; }

/* Breadcrumbs */
.cv-sp-breadcrumbs { margin-bottom: 15px; }
.cv-sp-breadcrumbs .woocommerce-breadcrumb { font-size: 13px; color: #999; }
.cv-sp-breadcrumbs .woocommerce-breadcrumb a { color: #d4a843; text-decoration: none; }

/* Title Bar */
.cv-sp-title-bar { margin-bottom: 25px; border-bottom: 2px solid #eee; padding-bottom: 15px; }
.cv-sp-title { font-family: 'Rye', serif; font-size: 28px; color: #d4a843; margin-bottom: 5px; text-transform: uppercase; }
.cv-sp-subtitle { color: #666; font-size: 14px; margin: 0; }

/* 3-Column Main Layout */
.cv-sp-main { display: grid; grid-template-columns: 1fr 1fr 300px; gap: 30px; margin-bottom: 40px; }

/* Column 1: Gallery */
.cv-sp-gallery { }
.cv-sp-main-image { background: #f8f8f8; border-radius: 12px; overflow: hidden; margin-bottom: 15px; aspect-ratio: 1/1; display: flex; align-items: center; justify-content: center; }
.cv-sp-main-image img { max-width: 100%; max-height: 100%; object-fit: contain; }
.cv-sp-thumbs { display: flex; gap: 10px; }
.cv-sp-thumb { width: 70px; height: 70px; object-fit: contain; border: 2px solid #eee; border-radius: 6px; cursor: pointer; transition: all 0.3s; background: #f8f8f8; padding: 4px; }
.cv-sp-thumb:hover, .cv-sp-thumb.active { border-color: #d4a843; }

/* Column 2: Options */
.cv-sp-options { }
.cv-sp-price { margin-bottom: 20px; }
.cv-sp-price .price { font-size: 32px !important; font-weight: 700 !important; color: #d4a843 !important; }
.cv-sp-price .price del { color: #999 !important; font-size: 20px !important; }
.cv-sp-price .price ins { text-decoration: none !important; }

/* Variations */
.cv-sp-variations-wrap h3 { font-size: 16px; font-weight: 700; color: #1a1a2e; margin-bottom: 10px; }
.cv-sp-variations-wrap .variations { margin-bottom: 15px; }
.cv-sp-variations-wrap .variations td { display: block; padding: 5px 0; }
.cv-sp-variations-wrap .variations td label { font-weight: 700; color: #1a1a2e; font-size: 14px; margin-bottom: 5px; display: block; }
.cv-sp-variations-wrap .variations select,
.cv-sp-options select { width: 100%; padding: 12px 15px; border: 2px solid #ddd; border-radius: 8px; font-size: 14px; appearance: auto; background: #fff; transition: border-color 0.3s; }
.cv-sp-variations-wrap .variations select:focus,
.cv-sp-options select:focus { border-color: #d4a843; outline: none; }

/* Variation swatches - clickable buttons style */
.cv-sp-variations-wrap .variation-swatches .swatch { display: inline-block; padding: 8px 16px; border: 2px solid #ddd; border-radius: 6px; margin: 4px; cursor: pointer; font-size: 13px; transition: all 0.3s; }
.cv-sp-variations-wrap .variation-swatches .swatch:hover,
.cv-sp-variations-wrap .variation-swatches .swatch.selected { border-color: #d4a843; background: rgba(212,168,67,0.1); }

/* Add to Cart Button */
.cv-sp-options .single_add_to_cart_button,
.cv-sp-options .button { background: #d4a843 !important; color: #1a1a2e !important; font-weight: 700 !important; font-size: 18px !important; padding: 16px 40px !important; border-radius: 8px !important; border: none !important; width: 100% !important; text-transform: uppercase !important; letter-spacing: 1px !important; cursor: pointer !important; transition: all 0.3s !important; margin-top: 10px !important; }
.cv-sp-options .single_add_to_cart_button:hover,
.cv-sp-options .button:hover { background: #e6bc5a !important; transform: translateY(-2px) !important; box-shadow: 0 6px 25px rgba(212,168,67,0.5) !important; }

/* Quantity input */
.cv-sp-options .quantity { margin-bottom: 10px; }
.cv-sp-options .quantity .qty { width: 80px; padding: 12px; border: 2px solid #ddd; border-radius: 8px; font-size: 16px; text-align: center; }

/* Product Meta */
.cv-sp-meta { margin-top: 20px; padding-top: 15px; border-top: 1px solid #eee; }
.cv-sp-meta-item { font-size: 13px; color: #666; margin-bottom: 5px; }
.cv-sp-meta-item a { color: #d4a843; text-decoration: none; }

/* Column 3: Trust Badges */
.cv-sp-trust { background: #f8f9fa; border-radius: 12px; padding: 25px; height: fit-content; }
.cv-sp-trust-item { display: flex; gap: 12px; margin-bottom: 20px; padding-bottom: 20px; border-bottom: 1px solid #eee; }
.cv-sp-trust-item:last-child { margin-bottom: 0; padding-bottom: 0; border-bottom: none; }
.cv-trust-icon { font-size: 20px; flex-shrink: 0; }
.cv-trust-green { color: #27ae60; font-size: 15px; }
.cv-trust-gold { color: #d4a843; font-size: 15px; }
.cv-sp-trust-item p { font-size: 12px; color: #666; margin: 4px 0 0; line-height: 1.4; }

/* Product Tabs */
.cv-sp-tabs-section { margin-bottom: 40px; }
.cv-sp-tabs-section .woocommerce-tabs ul.tabs { list-style: none; padding: 0; margin: 0 0 25px; display: flex; gap: 0; border-bottom: 2px solid #eee; }
.cv-sp-tabs-section .woocommerce-tabs ul.tabs li { margin: 0; }
.cv-sp-tabs-section .woocommerce-tabs ul.tabs li a { display: block; padding: 14px 25px; font-weight: 700; font-size: 14px; color: #666; text-decoration: none; border-bottom: 3px solid transparent; transition: all 0.3s; }
.cv-sp-tabs-section .woocommerce-tabs ul.tabs li.active a { color: #d4a843; border-bottom-color: #d4a843; }
.cv-sp-tabs-section .woocommerce-tabs .panel { padding: 20px 0; }
.cv-sp-tabs-section .woocommerce-tabs .panel h2 { font-family: 'Rye', serif; font-size: 22px; color: #1a1a2e; margin-bottom: 15px; }

/* Related Products */
.cv-sp-related { margin-bottom: 40px; }
.cv-sp-related > h2, .cv-sp-related .related > h2 { font-family: 'Rye', serif; font-size: 24px; color: #1a1a2e; margin-bottom: 20px; }

/* Reset WooCommerce defaults that conflict */
.cv-single-product .woocommerce-variation-add-to-cart { display: flex; flex-wrap: wrap; gap: 10px; align-items: flex-end; }
.cv-single-product .reset_variations { font-size: 12px; color: #999; }
.cv-single-product .woocommerce-variation-price .price { font-size: 24px !important; }

/* Hide duplicate elements our template doesn't need */
.cv-single-product .woocommerce-product-gallery__trigger { display: none; }

/* ===== RESPONSIVE ===== */
@media (max-width: 992px) {
    .cv-sp-main { grid-template-columns: 1fr 1fr; }
    .cv-sp-trust { grid-column: 1 / -1; }
}
@media (max-width: 768px) {
    .cv-sp-main { grid-template-columns: 1fr; gap: 20px; }
    .cv-sp-title { font-size: 22px; }
    .cv-sp-price .price { font-size: 26px !important; }
    .cv-sp-thumbs { flex-wrap: wrap; }
}
