/*
Theme Name: Racketszone Theme
Theme URI: https://racketszone.jain.software
Description: Custom child theme for Racketszone - Sports & Badminton Equipment Store
Author: Racketszone
Author URI: https://racketszone.jain.software
Template: astra
Version: 1.0.0
Text Domain: racketzone-theme
*/

/* Import Parent Theme Styles */
@import url("../astra/style.css");

/* ===== DISABLE SMOOTH SCROLL - FORCE NORMAL SCROLL ===== */
html {
    scroll-behavior: auto !important;
    scroll-snap-type: none !important;
    height: 100% !important;
    width: 100% !important;
    overflow-y: scroll !important;
    /* Force always show scrollbar to prevent layout shift */
    overflow-x: hidden !important;
    overscroll-behavior: none !important;
}

body {
    scroll-behavior: auto !important;
    height: auto !important;
    min-height: 100% !important;
    width: 100% !important;
    overflow-y: visible !important;
    /* Body should NOT scroll, HTML does */
    overflow-x: hidden !important;
    overscroll-behavior: none !important;
    position: relative !important;
}

/* Prevent any other element from being a scroll container */
*:not(html) {
    overscroll-behavior: none !important;
}

/* Eliminate nested scroll containers */
#page,
.site,
.site-content,
.site-main,
.content-area,
#primary,
#main,
.ast-container,
.host-web-layout,
.ast-scroll-top-container,
.rz-home,
.rz-section,
.rz-products-grid {
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    overflow-y: visible !important;
    overflow-x: visible !important;
    /* Allow grid to spill if needed, but hidden by body */
}

/* Specific fix for slider to prevent it capturing scroll */
.rz-slider-container {
    overflow: hidden !important;
    /* Keep slider overflow hidden */
    max-height: calc(100vh - 130px) !important;
}

.rz-slider-container * {
    max-height: none !important;
    overflow: visible !important;
}

/* Product Grid Fix - Ensure it wraps */
.rz-products-grid {
    display: grid !important;
    width: 100% !important;
    overflow: visible !important;
}

/* Slider scroll fix */
.rz-slider-container,
.rz-slider,
.rz-slide {
    touch-action: pan-y !important;
    overscroll-behavior: none !important;
}

/* ===== CRITICAL LAYOUT FIXES ===== */
/* Force Astra to use block layout instead of flex/grid */
.site,
#page,
.ast-container,
.site-content,
#content,
.ast-separate-container,
.ast-plain-container,
.ast-page-builder-template,
.site-main,
#primary,
.content-area {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    float: none !important;
    flex: none !important;
    flex-direction: column !important;
    flex-wrap: nowrap !important;
}

/* Ensure main wrapper is full width */
.ast-separate-container .site-content>.ast-container,
.ast-plain-container .site-content>.ast-container {
    display: block !important;
    max-width: 100% !important;
    width: 100% !important;
    padding: 0 !important;
}

/* Hide sidebar completely */
#secondary,
.widget-area,
aside.widget-area {
    display: none !important;
    width: 0 !important;
}

/* Force footer to bottom */
footer.site-footer,
.site-footer,
.rz-custom-footer,
.ast-footer-overlay {
    display: block !important;
    width: 100% !important;
    clear: both !important;
    float: none !important;
    position: relative !important;
    margin-top: 0 !important;
}

/* Fix for Astra's row layout */
.ast-container,
.ast-row {
    display: block !important;
    flex-wrap: nowrap !important;
}

/* Content should not have flex behavior */
.entry-content,
.page-content,
article.post,
article.page {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* ===== RACKETZONE CUSTOM STYLES ===== */

/* CSS Variables - Color Scheme */
:root {
    --rz-primary: #000000;
    --rz-accent: #00BCD4;
    --rz-accent-dark: #0097A7;
    --rz-white: #FFFFFF;
    --rz-light-gray: #F5F5F5;
    --rz-dark-gray: #1a1a1a;
    --rz-text-dark: #333333;
    --rz-text-light: #FFFFFF;
    --rz-red: #E53935;
    --rz-gradient: linear-gradient(135deg, #00BCD4 0%, #0097A7 100%);
}

/* ===== TYPOGRAPHY ===== */
body {
    font-family: 'Inter', 'Segoe UI', Roboto, sans-serif;
    color: var(--rz-text-dark);
}

h1,
h2,
h3,
h4,
h5,
h6 {
    font-weight: 700;
    color: var(--rz-primary);
}

/* ===== HEADER STYLES ===== */
.site-header,
.ast-primary-header-bar {
    background-color: var(--rz-primary) !important;
}

.ast-header-break-point .site-header {
    background-color: var(--rz-primary) !important;
}

/* Top Bar */
.ast-above-header,
.ast-above-header-bar {
    background-color: var(--rz-dark-gray) !important;
    color: var(--rz-white);
    padding: 5px 0;
    font-size: 12px;
}

/* Navigation */
.ast-primary-menu-enabled>.main-navigation {
    background-color: var(--rz-primary);
}

.main-navigation ul li a,
.ast-menu-toggle {
    color: var(--rz-white) !important;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    font-size: 13px;
    padding: 10px 18px !important;
}

.main-navigation ul li a:hover {
    color: var(--rz-accent) !important;
}

/* Home Button - First menu item with Cyan background */
.main-navigation ul.main-header-menu>li:first-child>a {
    background-color: var(--rz-accent) !important;
    color: var(--rz-white) !important;
    border-radius: 4px;
    padding: 10px 20px !important;
}

.main-navigation ul.main-header-menu>li:first-child>a:hover {
    background-color: var(--rz-accent-dark) !important;
}

/* Current page highlight */
.main-navigation ul li.current-menu-item>a {
    color: var(--rz-accent) !important;
}

/* Site title/logo */
.site-title a,
.ast-site-identity .site-title a {
    color: var(--rz-white) !important;
    font-weight: 700;
    font-size: 24px;
}

/* ===== HERO SECTION ===== */
.rz-hero-section {
    background-color: var(--rz-primary);
    background-image: url('images/hero-pattern.png');
    background-size: cover;
    min-height: 500px;
    display: flex;
    align-items: center;
    position: relative;
    overflow: hidden;
}

.rz-hero-title {
    font-size: 72px;
    font-weight: 900;
    color: var(--rz-white);
    text-transform: uppercase;
    line-height: 1.1;
}

.rz-hero-title span {
    color: var(--rz-accent);
}

/* ===== BUTTONS ===== */
.rz-btn-primary,
.button,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit {
    background: var(--rz-accent) !important;
    color: var(--rz-white) !important;
    border: none !important;
    border-radius: 50px !important;
    padding: 12px 30px !important;
    font-weight: 600 !important;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    transition: all 0.3s ease;
}

.rz-btn-primary:hover,
.button:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover {
    background: var(--rz-accent-dark) !important;
    transform: translateY(-2px);
    box-shadow: 0 4px 15px rgba(0, 188, 212, 0.4);
}

.rz-btn-outline {
    background: transparent !important;
    border: 2px solid var(--rz-accent) !important;
    color: var(--rz-accent) !important;
}

.rz-btn-outline:hover {
    background: var(--rz-accent) !important;
    color: var(--rz-white) !important;
}

/* ===== PRODUCT CARDS ===== */
.woocommerce ul.products li.product {
    background: var(--rz-white);
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 2px 20px rgba(0, 0, 0, 0.08);
    transition: all 0.3s ease;
    padding: 15px;
    margin-bottom: 30px;
}

.woocommerce ul.products li.product:hover {
    transform: translateY(-5px);
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.15);
}

.woocommerce ul.products li.product .woocommerce-loop-product__title {
    font-size: 14px;
    font-weight: 600;
    color: var(--rz-text-dark);
    padding: 10px 0 5px;
}

/* Sale Badge */
.woocommerce span.onsale,
.rz-sale-badge {
    background: var(--rz-red) !important;
    color: var(--rz-white) !important;
    border-radius: 4px !important;
    padding: 5px 12px !important;
    font-size: 12px !important;
    font-weight: 600 !important;
    text-transform: uppercase;
    position: absolute;
    top: 10px;
    left: 10px;
}

/* Product Price */
.woocommerce ul.products li.product .price {
    color: var(--rz-accent);
    font-weight: 700;
    font-size: 16px;
}

.woocommerce ul.products li.product .price del {
    color: #999;
    font-weight: 400;
    font-size: 14px;
}

.woocommerce ul.products li.product .price ins {
    color: var(--rz-accent);
    text-decoration: none;
    font-weight: 700;
}

/* ===== SECTION STYLES ===== */
.rz-section {
    padding: 80px 0;
}

.rz-section-title {
    font-size: 32px;
    font-weight: 700;
    margin-bottom: 40px;
    position: relative;
}

.rz-section-title span {
    color: var(--rz-accent);
}

/* Precision Section - Blue Box */
.rz-precision-box {
    background: var(--rz-gradient);
    border-radius: 20px;
    padding: 50px;
    color: var(--rz-white);
    position: relative;
    overflow: hidden;
}

.rz-precision-box h2 {
    color: var(--rz-white);
    font-size: 48px;
    font-weight: 800;
}

/* ===== CATEGORIES SECTION ===== */
.rz-categories {
    display: flex;
    justify-content: space-around;
    flex-wrap: wrap;
    gap: 30px;
    padding: 40px 0;
}

.rz-category-item {
    text-align: center;
    transition: all 0.3s ease;
}

.rz-category-item:hover {
    transform: translateY(-10px);
}

.rz-category-icon {
    width: 80px;
    height: 80px;
    border-radius: 50%;
    background: var(--rz-light-gray);
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 15px;
}

/* ===== CTA BANNER ===== */
.rz-cta-banner {
    background: linear-gradient(rgba(0, 0, 0, 0.7), rgba(0, 0, 0, 0.7)), url('images/stadium-bg.jpg');
    background-size: cover;
    background-position: center;
    padding: 100px 0;
    text-align: center;
}

.rz-cta-banner h2 {
    color: var(--rz-white);
    font-size: 48px;
    font-weight: 800;
    text-transform: uppercase;
    margin-bottom: 30px;
}

/* ===== STATS SECTION ===== */
.rz-stats {
    background: var(--rz-gradient);
    padding: 60px 0;
}

.rz-stat-item {
    text-align: center;
    color: var(--rz-white);
}

.rz-stat-number {
    font-size: 48px;
    font-weight: 800;
}

.rz-stat-label {
    font-size: 14px;
    opacity: 0.9;
}

/* ===== TRUST BADGES ===== */
.rz-trust-badges {
    display: flex;
    justify-content: center;
    gap: 30px;
    flex-wrap: wrap;
    padding: 60px 0;
}

.rz-trust-badge {
    background: var(--rz-white);
    border: 1px solid #eee;
    border-radius: 12px;
    padding: 30px 40px;
    text-align: center;
    min-width: 250px;
    transition: all 0.3s ease;
}

.rz-trust-badge:hover {
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1);
    transform: translateY(-5px);
}

.rz-trust-badge h4 {
    margin-top: 15px;
    font-weight: 700;
}

/* ===== TESTIMONIALS ===== */
.rz-testimonial {
    background: var(--rz-white);
    border-radius: 20px;
    padding: 40px;
    text-align: center;
    max-width: 600px;
    margin: 0 auto;
    box-shadow: 0 5px 30px rgba(0, 0, 0, 0.1);
}

.rz-testimonial-text {
    font-style: italic;
    font-size: 16px;
    color: #666;
    margin-bottom: 20px;
}

.rz-testimonial-author {
    color: var(--rz-accent);
    font-weight: 700;
}

/* ===== TEAM SECTION ===== */
.rz-team-member {
    text-align: center;
    margin-bottom: 30px;
}

.rz-team-photo {
    width: 200px;
    height: 200px;
    border-radius: 50%;
    overflow: hidden;
    margin: 0 auto 20px;
    border: 4px solid var(--rz-accent);
}

/* ===== FOOTER ===== */
.site-footer,
.ast-footer-overlay {
    background-color: #0a2540 !important;
    color: var(--rz-white);
}

.footer-adv-overlay {
    background-color: #0a2540 !important;
}

.ast-footer-copyright {
    background-color: #051a2d !important;
}

.site-footer a,
.site-footer h4 {
    color: var(--rz-white) !important;
}

.site-footer a:hover {
    color: var(--rz-accent) !important;
}

/* ===== FEATURED TABS ===== */
.rz-featured-tabs {
    display: flex;
    gap: 15px;
    flex-wrap: wrap;
    margin-bottom: 30px;
}

.rz-tab {
    padding: 10px 25px;
    border-radius: 50px;
    background: var(--rz-light-gray);
    color: var(--rz-text-dark);
    font-weight: 500;
    cursor: pointer;
    transition: all 0.3s ease;
}

.rz-tab.active,
.rz-tab:hover {
    background: var(--rz-primary);
    color: var(--rz-white);
}

/* ===== RESPONSIVE STYLES ===== */
@media (max-width: 768px) {
    .rz-hero-title {
        font-size: 36px;
    }

    .rz-section {
        padding: 50px 0;
    }

    .rz-cta-banner h2 {
        font-size: 28px;
    }

    .rz-stat-number {
        font-size: 32px;
    }

    .rz-trust-badges {
        flex-direction: column;
        align-items: center;
    }
}

/* ===== ANIMATIONS ===== */
@keyframes fadeInUp {
    from {
        opacity: 0;
        transform: translateY(30px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.rz-animate {
    animation: fadeInUp 0.6s ease-out;
}

/* Scroll animations */
.rz-fade-in {
    opacity: 0;
    transform: translateY(20px);
    transition: all 0.6s ease;
}

.rz-fade-in.visible {
    opacity: 1;
    transform: translateY(0);
}

/* ===== WOOCOMMERCE SPECIFIC ===== */
.woocommerce-page .woocommerce-products-header__title {
    color: var(--rz-primary);
}

.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span.current {
    border-radius: 50%;
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.woocommerce nav.woocommerce-pagination ul li span.current {
    background: var(--rz-accent);
    color: var(--rz-white);
}

/* Add to Cart Icon */
.woocommerce ul.products li.product .add_to_cart_button {
    background: var(--rz-accent) !important;
    border-radius: 8px !important;
    padding: 10px 20px !important;
}

/* Quick View & Wishlist Icons */
.product-actions {
    position: absolute;
    top: 10px;
    right: 10px;
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.product-action-btn {
    width: 35px;
    height: 35px;
    background: var(--rz-white);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
    transition: all 0.3s ease;
}

.product-action-btn:hover {
    background: var(--rz-accent);
    color: var(--rz-white);
}

/* ===== WOOCOMMERCE PAGE LAYOUT FIXES ===== */
/* Cart Page */
.woocommerce-cart .woocommerce,
.woocommerce-checkout .woocommerce,
.woocommerce-account .woocommerce {
    max-width: 1200px;
    margin: 0 auto;
    padding: 40px 20px;
}

.woocommerce-cart .entry-content,
.woocommerce-checkout .entry-content,
.woocommerce-account .entry-content {
    padding: 0 !important;
}

/* My Account Page */
.woocommerce-account .woocommerce-MyAccount-navigation {
    background: #f8f9fa;
    border-radius: 12px;
    padding: 20px;
    margin-bottom: 30px;
}

.woocommerce-account .woocommerce-MyAccount-navigation ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.woocommerce-account .woocommerce-MyAccount-navigation ul li {
    margin-bottom: 5px;
}

.woocommerce-account .woocommerce-MyAccount-navigation ul li a {
    display: block;
    padding: 12px 20px;
    color: #333;
    text-decoration: none;
    border-radius: 8px;
    transition: all 0.3s ease;
}

.woocommerce-account .woocommerce-MyAccount-navigation ul li a:hover,
.woocommerce-account .woocommerce-MyAccount-navigation ul li.is-active a {
    background: var(--rz-accent);
    color: #fff;
}

.woocommerce-account .woocommerce-MyAccount-content {
    background: #fff;
    border-radius: 12px;
    padding: 30px;
    box-shadow: 0 2px 15px rgba(0, 0, 0, 0.05);
}

/* Form Styling */
.woocommerce form.login,
.woocommerce form.register,
.woocommerce-form-login,
.woocommerce-form-register {
    background: #fff;
    border-radius: 12px;
    padding: 30px;
    box-shadow: 0 2px 20px rgba(0, 0, 0, 0.08);
    max-width: 500px;
}

.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea {
    border: 2px solid #eee;
    border-radius: 8px;
    padding: 12px 15px;
    width: 100%;
    transition: border-color 0.3s ease;
}

.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row textarea:focus {
    border-color: var(--rz-accent);
    outline: none;
}

.woocommerce form .form-row label {
    font-weight: 600;
    color: #333;
    margin-bottom: 8px;
    display: block;
}

/* Order Table Styling */
.woocommerce-orders-table {
    border: 1px solid #eee;
    border-radius: 12px;
    overflow: hidden;
}

.woocommerce-orders-table th {
    background: #f8f9fa;
    font-weight: 600;
    text-transform: uppercase;
    font-size: 12px;
    padding: 15px;
}

.woocommerce-orders-table td {
    padding: 15px;
    border-bottom: 1px solid #eee;
}

/* Shop Page Fixes */
.woocommerce .woocommerce-result-count,
.woocommerce .woocommerce-ordering {
    margin-bottom: 20px;
}

.woocommerce .woocommerce-ordering select {
    padding: 10px 15px;
    border: 2px solid #eee;
    border-radius: 8px;
    font-size: 14px;
    cursor: pointer;
}

/* Product Image Placeholder Fix */
.woocommerce ul.products li.product img,
.rz-product-image,
.rz-shop-image {
    max-width: 100%;
    height: auto;
    object-fit: contain;
}

/* Breadcrumbs */
.woocommerce .woocommerce-breadcrumb {
    font-size: 13px;
    color: #666;
    margin-bottom: 20px;
    padding: 15px 0;
}

.woocommerce .woocommerce-breadcrumb a {
    color: var(--rz-accent);
}

/* Notice Styling */
.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
    border-radius: 8px;
    padding: 15px 20px 15px 50px !important;
    margin-bottom: 20px;
    position: relative;
}

.woocommerce-message::before,
.woocommerce-info::before,
.woocommerce-error::before {
    position: absolute !important;
    left: 15px !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    margin: 0 !important;
    font-size: 18px !important;
}

.woocommerce-message {
    background: #e8f5e9;
    color: #2e7d32;
    border-left: 4px solid #4caf50;
}

.woocommerce-info {
    background: #e3f2fd;
    color: #1565c0;
    border-left: 4px solid #2196f3;
}

.woocommerce-error {
    background: #ffebee;
    color: #c62828;
    border-left: 4px solid #f44336;
}

/* Checkout Page */
.woocommerce-checkout .woocommerce-billing-fields h3,
.woocommerce-checkout .woocommerce-shipping-fields h3,
.woocommerce-checkout #order_review_heading {
    font-size: 20px;
    font-weight: 700;
    margin-bottom: 20px;
    padding-bottom: 10px;
    border-bottom: 2px solid #eee;
}

.woocommerce-checkout #payment {
    background: #f8f9fa;
    border-radius: 12px;
    padding: 25px;
}

.woocommerce-checkout #payment ul.payment_methods {
    padding: 0;
    list-style: none;
}

.woocommerce-checkout #payment ul.payment_methods li {
    background: #fff;
    border-radius: 8px;
    padding: 15px;
    margin-bottom: 10px;
    border: 2px solid #eee;
}

/* Hide Astra's extra containers on template pages */
.page-template article.page>.entry-content>.ast-container,
.page-template-template-homepage .entry-content,
.page-template-template-cart .entry-content,
.page-template-template-checkout .entry-content,
.page-template-template-about .entry-content {
    padding: 0 !important;
    margin: 0 !important;
    max-width: 100% !important;
}

/* Fix page padding */
.page-template .site-main,
.page-template #primary {
    padding: 0 !important;
    margin: 0 !important;
}

/* Single Product Page - Hide WooCommerce Default Elements */
.single-product .woocommerce-product-gallery,
.single-product .woocommerce div.product div.images,
.single-product .woocommerce div.product div.summary,
.single-product .woocommerce-tabs,
.single-product .related.products,
.single-product .woocommerce-breadcrumb,
.single-product .woocommerce-Reviews,
.single-product .product_meta {
    display: none !important;
}

.single-product .woocommerce div.product {
    max-width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
}

.single-product #primary,
.single-product .site-main,
.single-product .content-area {
    padding: 0 !important;
    margin: 0 !important;
}

/* Allow our custom product page to show */
.single-product .rz-product-page {
    display: block !important;
}