/*
Theme Name: Mkarye Medical Technologies
Theme URI: http://mkaryemedicaltechnologies.co.ke/
Author: LexPanda
Author URI: http://mkaryemedicaltechnologies.co.ke/
Description: A bespoke, premium theme for Mkarye Medical Technologies Ltd., custom-tailored with a high-end corporate clinical aesthetic, responsive CSS Grid layouts, and smooth micro-interactions.
Version: 1.2.1
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: mkarye-tech
*/

/* ==========================================
   CSS Variables & Design System
   ========================================== */
:root {
    /* Color Palette - Blue (#163be7), White, and Black only */
    --color-primary: #163be7;      /* Royal clinical blue */
    --color-primary-hover: #0f29ad;
    --color-primary-light: rgba(22, 59, 231, 0.05);
    --color-primary-glow: rgba(22, 59, 231, 0.15);
    
    --color-secondary: #000000;    /* Pure Black */
    --color-secondary-light: #121212;
    --color-secondary-muted: #262626;
    
    --color-text-main: #171717;    /* Charcoal Black */
    --color-text-dark: #000000;    /* Pure Black */
    --color-text-muted: #525252;
    --color-text-light: #a3a3a3;
    
    --color-bg-base: #ffffff;      /* Pure White */
    --color-bg-card: #ffffff;      /* Pure White */
    --color-bg-accent: #f5f5f5;    /* Light White/Grey */
    --color-border: rgba(0, 0, 0, 0.1);
    
    /* Font Families */
    --font-heading: 'Outfit', sans-serif;
    --font-body: 'Inter', sans-serif;
    
    /* Layout & Shadows */
    --shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
    --shadow-md: 0 4px 6px -1px rgba(15, 23, 42, 0.08), 0 2px 4px -2px rgba(15, 23, 42, 0.08);
    --shadow-lg: 0 10px 15px -3px rgba(15, 23, 42, 0.08), 0 4px 6px -4px rgba(15, 23, 42, 0.08);
    --shadow-glow: 0 0 25px 0 rgba(22, 59, 231, 0.2);
    
    --radius-sm: 6px;
    --radius-md: 12px;
    --radius-lg: 20px;
    --radius-full: 9999px;
    
    --transition-fast: 0.2s cubic-bezier(0.4, 0, 0.2, 1);
    --transition-normal: 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    
    --container-max: 1280px;
}

/* ==========================================
   Base & Reset Styles
   ========================================== */
*, *::before, *::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

html {
    scroll-behavior: smooth;
    font-size: 16px;
}

body {
    font-family: var(--font-body);
    font-size: 1rem;
    line-height: 1.6;
    color: var(--color-text-main);
    background-color: var(--color-bg-base);
    overflow-x: hidden;
    -webkit-font-smoothing: antialiased;
}

/* Typography */
h1, h2, h3, h4, h5, h6 {
    font-family: var(--font-heading);
    color: var(--color-text-dark);
    font-weight: 700;
    line-height: 1.25;
}

h1 {
    font-size: clamp(2.25rem, 5vw, 3.5rem);
    letter-spacing: -0.02em;
}

h2 {
    font-size: clamp(1.75rem, 4vw, 2.5rem);
    letter-spacing: -0.01em;
}

h3 {
    font-size: clamp(1.25rem, 2.5vw, 1.75rem);
}

h4 {
    font-size: 1.25rem;
}

a {
    color: var(--color-primary);
    text-decoration: none;
    transition: var(--transition-fast);
}

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

img {
    max-width: 100%;
    height: auto;
    display: block;
    border-radius: var(--radius-md);
}

/* Skip Link for Accessibility */
.skip-link {
    position: absolute;
    top: -100px; /* Shifted further up to prevent the blue background from spilling onto the screen */
    left: 0;
    background: var(--color-primary);
    color: white;
    padding: 8px;
    z-index: 100;
    transition: var(--transition-fast);
}

.skip-link:focus {
    top: 0;
}

/* ==========================================
   Layout Components
   ========================================== */
.container {
    width: 100%;
    margin-right: auto;
    margin-left: auto;
    padding-right: 1.5rem;
    padding-left: 1.5rem;
}

/* Fluid Container Max-Widths for all breakpoints */
@media (min-width: 576px) {
    .container {
        max-width: 540px;
    }
}
@media (min-width: 768px) {
    .container {
        max-width: 720px;
    }
}
@media (min-width: 992px) {
    .container {
        max-width: 960px;
    }
}
@media (min-width: 1200px) {
    .container {
        max-width: 1140px;
    }
}
@media (min-width: 1400px) {
    .container {
        max-width: 1320px;
    }
}
@media (min-width: 1600px) {
    .container {
        max-width: 1520px; /* Ultra-wide screen support */
    }
}

.grid {
    display: grid !important;
    gap: 1.5rem;
}

.grid-2, .grid-3, .grid-4 {
    grid-template-columns: 1fr !important;
}

/* Small Screens (sm: min-width: 576px) */
@media (min-width: 576px) {
    .grid-2 {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }
}

/* Medium Screens (md: min-width: 768px) */
@media (min-width: 768px) {
    .grid-3 {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }
    .grid-4 {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }
}

/* Large Screens (lg: min-width: 992px) */
@media (min-width: 992px) {
    .grid-3 {
        grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    }
    .grid-4 {
        grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    }
}

/* Extra Large / Wide Screens (xl: min-width: 1200px) */
@media (min-width: 1200px) {
    .grid-1-2 { grid-template-columns: 1fr 2fr !important; }
    .grid-2-1 { grid-template-columns: 2fr 1fr !important; }
}

/* Section Header Styles */
.section-header {
    text-align: center;
    max-width: 700px;
    margin: 0 auto 3rem;
}

.section-header .subtitle {
    text-transform: uppercase;
    font-size: 0.875rem;
    font-weight: 700;
    letter-spacing: 0.15em;
    color: var(--color-primary);
    margin-bottom: 0.5rem;
    display: inline-block;
}

.section-header h2 {
    margin-bottom: 1rem;
    color: var(--color-text-dark);
}

.section-header p {
    color: var(--color-text-muted);
    font-size: 1.125rem;
}

/* Split Column Header Styles (Left Aligned, Full Width) */
.split-header {
    text-align: left;
    margin-bottom: 2rem;
    width: 100%;
}

.split-header .subtitle {
    text-transform: uppercase;
    font-size: 0.875rem;
    font-weight: 700;
    letter-spacing: 0.15em;
    color: var(--color-primary);
    margin-bottom: 0.5rem;
    display: inline-block;
}

.split-header h2 {
    margin-bottom: 1rem;
    color: var(--color-text-dark);
}

/* ==========================================
   Interactive UI Components
   ========================================== */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.75rem 1.75rem;
    font-family: var(--font-heading);
    font-size: 0.95rem;
    font-weight: 600;
    border-radius: var(--radius-md);
    transition: var(--transition-normal);
    cursor: pointer;
    border: 2px solid transparent;
}

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

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

.btn-secondary {
    background-color: transparent;
    color: var(--color-text-dark);
    border-color: var(--color-text-dark);
}

.btn-secondary:hover {
    background-color: var(--color-text-dark);
    color: white;
    transform: translateY(-2px);
}

.btn-white {
    background-color: #ffffff;
    color: var(--color-primary);
}

.btn-white:hover {
    background-color: var(--color-primary-light);
    color: var(--color-primary-hover);
    transform: translateY(-2px);
    box-shadow: 0 10px 20px rgba(0,0,0,0.05);
}

.card {
    background-color: var(--color-bg-card);
    border-radius: var(--radius-md);
    padding: 2rem;
    box-shadow: var(--shadow-sm);
    border: 1px solid var(--color-border);
    transition: var(--transition-normal);
}

.card:hover {
    transform: translateY(-5px);
    box-shadow: var(--shadow-lg);
    border-color: rgba(22, 59, 231, 0.2);
}

/* Glassmorphism Styles */
.glass-card {
    background: rgba(255, 255, 255, 0.7);
    backdrop-filter: blur(12px) saturate(180%);
    -webkit-backdrop-filter: blur(12px) saturate(180%);
    border: 1px solid rgba(255, 255, 255, 0.4);
    box-shadow: var(--shadow-md);
    border-radius: var(--radius-md);
    padding: 2rem;
    transition: var(--transition-normal);
}

.glass-card:hover {
    background: rgba(255, 255, 255, 0.85);
    box-shadow: var(--shadow-lg);
    border-color: rgba(22, 59, 231, 0.3);
}

/* ==========================================
   Header & Navigation
   ========================================== */
.site-header {
    background-color: rgba(255, 255, 255, 0.9);
    backdrop-filter: blur(8px);
    border-bottom: 1px solid var(--color-border);
    position: sticky;
    top: 0;
    z-index: 50;
    padding: 1rem 0;
    transition: var(--transition-fast);
}

.header-container {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.logo-link {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-family: var(--font-heading);
    font-size: 1.25rem;
    font-weight: 800;
    color: var(--color-secondary);
}

.logo-link span {
    color: var(--color-primary);
}

.main-nav {
    display: none;
}

.nav-menu {
    display: flex;
    list-style: none;
    gap: 2rem;
    align-items: center;
}

.nav-menu li {
    position: relative;
}

.nav-menu a {
    color: var(--color-text-muted);
    font-weight: 500;
    font-size: 0.95rem;
    padding: 0.5rem 0;
    display: inline-flex;
    align-items: center;
    position: relative;
}

.nav-menu a .dropdown-chevron {
    margin-left: 5px;
    transform: rotate(180deg);
    transition: transform var(--transition-normal);
    transform-origin: center;
}

.nav-menu li:hover > a .dropdown-chevron {
    transform: rotate(0deg);
}

.nav-menu a::after {
    content: '';
    position: absolute;
    width: 0;
    height: 2px;
    bottom: -2px;
    left: 0;
    background-color: var(--color-primary);
    transition: var(--transition-fast);
}

.nav-menu a:hover,
.nav-menu .current-menu-item > a {
    color: var(--color-primary);
}

.nav-menu a:hover::after,
.nav-menu .current-menu-item > a::after {
    width: 100%;
}

/* Desktop Dropdown Sub-menu */
.nav-menu .sub-menu {
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%) translateY(10px);
    background-color: var(--color-bg-card);
    min-width: 250px;
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-lg);
    border: 1px solid var(--color-border);
    padding: 0.75rem 0;
    list-style: none;
    opacity: 0;
    visibility: hidden;
    transition: var(--transition-normal);
    z-index: 100;
    display: block;
}

.nav-menu .menu-item-has-children:hover > .sub-menu {
    opacity: 1;
    visibility: visible;
    transform: translateX(-50%) translateY(5px);
}

.nav-menu .sub-menu li {
    width: 100%;
}

.nav-menu .sub-menu a {
    display: block;
    padding: 0.6rem 1.5rem;
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--color-text-muted);
    transition: var(--transition-fast);
    text-align: left;
    white-space: nowrap;
}

.nav-menu .sub-menu a::after {
    display: none !important;
}

.nav-menu .sub-menu a:hover {
    color: var(--color-primary);
    background-color: var(--color-primary-light);
}

.header-actions {
    display: flex;
    align-items: center;
    gap: 1.25rem;
    margin-left: auto;
    margin-right: 1rem;
}

@media (min-width: 1024px) {
    .header-actions {
        margin-left: 0;
        margin-right: 0;
    }
}

.header-search-form {
    display: none; /* Hidden on mobile */
}

.search-input-wrapper {
    position: relative;
    display: flex;
    align-items: center;
}

.header-search-form .search-input {
    width: 180px;
    padding: 0.5rem 2.25rem 0.5rem 1rem;
    font-family: var(--font-body);
    font-size: 0.875rem;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-full);
    background-color: var(--color-bg-accent);
    color: var(--color-text-main);
    transition: var(--transition-fast);
    outline: none;
}

.header-search-form .search-input:focus {
    width: 240px;
    border-color: var(--color-primary);
    background-color: var(--color-bg-base);
    box-shadow: 0 0 0 3px var(--color-primary-glow);
}

.search-button {
    position: absolute;
    right: 0.75rem;
    background: none;
    border: none;
    cursor: pointer;
    color: var(--color-text-muted);
    padding: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: var(--transition-fast);
}

.search-button:hover {
    color: var(--color-primary);
}

.search-button svg {
    display: block;
}

/* Cart Button */
.header-cart {
    display: flex;
    align-items: center;
}

.cart-btn {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border-radius: var(--radius-full);
    background-color: var(--color-primary-light);
    color: var(--color-primary);
    transition: var(--transition-normal);
}

.cart-btn:hover {
    background-color: var(--color-primary);
    color: white;
    box-shadow: var(--shadow-sm);
    transform: translateY(-1px);
}

.cart-count {
    position: absolute;
    top: -4px;
    right: -4px;
    background-color: var(--color-secondary);
    color: white;
    font-size: 0.7rem;
    font-weight: 700;
    min-width: 18px;
    height: 18px;
    padding: 0 4px;
    border-radius: var(--radius-full);
    display: flex;
    align-items: center;
    justify-content: center;
    border: 2px solid var(--color-bg-base);
}

/* Mobile Search Form */
.mobile-search-form {
    margin-bottom: 2rem;
    width: 100%;
}

.mobile-search-form .search-input-wrapper {
    width: 100%;
}

.mobile-search-form .search-input {
    width: 100%;
    padding: 0.75rem 2.75rem 0.75rem 1.25rem;
    font-family: var(--font-body);
    font-size: 0.95rem;
    border: 1px solid rgba(255, 255, 255, 0.15);
    border-radius: var(--radius-md);
    background-color: rgba(255, 255, 255, 0.05);
    color: white;
    transition: var(--transition-fast);
    outline: none;
}

.mobile-search-form .search-input::placeholder {
    color: rgba(255, 255, 255, 0.4);
}

.mobile-search-form .search-input:focus {
    border-color: var(--color-primary);
    background-color: rgba(255, 255, 255, 0.1);
}

.mobile-search-form .search-button {
    color: rgba(255, 255, 255, 0.5);
    right: 1rem;
}

.mobile-search-form .search-button:hover {
    color: var(--color-primary);
}

.nav-toggle {
    background: none;
    border: none;
    cursor: pointer;
    display: block;
    width: 30px;
    height: 20px;
    position: relative;
    z-index: 100;
}

.nav-toggle span {
    display: block;
    width: 100%;
    height: 2px;
    background-color: var(--color-text-dark);
    position: absolute;
    transition: var(--transition-fast);
}

.nav-toggle span:first-child { top: 0; }
.nav-toggle span:nth-child(2) { top: 9px; }
.nav-toggle span:last-child { top: 18px; }

.nav-active .nav-toggle span:first-child {
    transform: rotate(45deg);
    top: 9px;
}
.nav-active .nav-toggle span:nth-child(2) {
    opacity: 0;
}
.nav-active .nav-toggle span:last-child {
    transform: rotate(-45deg);
    top: 9px;
}

@media (min-width: 1024px) {
    .main-nav {
        display: block;
    }
    .header-search-form {
        display: block;
    }
    .nav-toggle {
        display: none;
    }
}

/* Mobile Nav Styles */
.mobile-nav-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(15, 23, 42, 0.96);
    z-index: 45;
    opacity: 0;
    visibility: hidden;
    transition: var(--transition-normal);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 2rem;
    overflow-y: auto;
}

body.nav-active {
    overflow: hidden;
}

.nav-active .mobile-nav-overlay {
    opacity: 1;
    visibility: visible;
}

.mobile-nav-overlay nav {
    width: 100%;
    max-width: 320px; /* Constrain overlay menu content width */
    margin: 0 auto;
}

.mobile-nav-overlay ul {
    list-style: none;
    text-align: left; /* Left-align menu links */
    width: 100%;
    padding-left: 0;
}

.mobile-nav-overlay li {
    margin: 1.5rem 0;
    position: relative;
    border-bottom: 1px solid rgba(255, 255, 255, 0.05); /* Clean horizontal separator */
    padding-bottom: 0.75rem;
}

.mobile-nav-overlay li:last-child {
    border-bottom: none;
}

.mobile-nav-overlay a {
    color: white;
    font-size: 1.35rem;
    font-family: var(--font-heading);
    font-weight: 600;
    display: flex;
    align-items: center;
    justify-content: space-between; /* Puts chevron on the far right */
    width: 100%;
    transition: color 0.3s ease;
}

.mobile-nav-overlay a:hover {
    color: var(--color-primary);
}

/* Mobile dropdown chevron rotation */
.mobile-dropdown-chevron {
    transform: rotate(180deg);
    transition: transform var(--transition-normal);
    transform-origin: center;
    color: rgba(255, 255, 255, 0.5);
    flex-shrink: 0;
}

.mobile-menu-parent.active .mobile-dropdown-chevron {
    transform: rotate(0deg);
    color: var(--color-primary);
}

/* Mobile Sub-menu styling (Only opens when clicked) */
.mobile-sub-menu {
    list-style: none;
    margin: 0 !important;
    padding-left: 1rem !important; /* Indent sub-links for hierarchy */
    display: block;
    max-height: 0;
    opacity: 0;
    overflow: hidden;
    transition: max-height 0.35s ease-out, opacity 0.35s ease-out, margin 0.35s ease-out;
    pointer-events: none;
}

.mobile-sub-menu.sub-menu-open {
    max-height: 400px; /* High enough value to reveal all elements */
    opacity: 1;
    pointer-events: auto;
    margin-top: 0.75rem !important;
    padding-bottom: 0.5rem;
}

.mobile-sub-menu li {
    margin: 0.75rem 0 !important;
    border-bottom: none !important;
    padding-bottom: 0 !important;
}

.mobile-sub-menu a {
    font-size: 1.05rem !important;
    color: rgba(255, 255, 255, 0.65) !important;
    font-weight: 500 !important;
    justify-content: flex-start !important; /* Left-align sub-menu links */
}

.mobile-sub-menu a:hover {
    color: var(--color-primary) !important;
}

/* ==========================================
   Home / Front Page Styling
   ========================================= */

/* Hero Section */
.hero-section {
    padding: 5rem 0;
    background: linear-gradient(135deg, #ffffff 0%, #f4f6ff 100%);
    position: relative;
    overflow: hidden;
}

.hero-section::before {
    content: '';
    position: absolute;
    width: 600px;
    height: 600px;
    background: radial-gradient(circle, var(--color-primary-glow) 0%, transparent 70%);
    top: -200px;
    right: -200px;
    z-index: 1;
    pointer-events: none;
}

.hero-content {
    position: relative;
    z-index: 2;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.hero-badge {
    display: inline-flex;
    align-items: center;
    background-color: var(--color-primary-light);
    color: var(--color-primary);
    padding: 0.35rem 1rem;
    border-radius: var(--radius-full);
    font-size: 0.85rem;
    font-weight: 700;
    margin-bottom: 1.5rem;
    align-self: flex-start;
    border: 1px solid rgba(22, 59, 231, 0.1);
}

.hero-content p {
    font-size: 1.125rem;
    color: var(--color-text-muted);
    margin: 1.5rem 0 2rem;
    max-width: 600px;
}

.hero-actions {
    display: flex;
    gap: 1rem;
    flex-wrap: wrap;
}

.hero-section .grid-2 {
    align-items: stretch;
}

.hero-image-wrapper {
    position: relative;
    display: flex;
    width: 100%;
    height: 320px; /* Default height on mobile */
}

@media (min-width: 768px) {
    .hero-image-wrapper {
        height: 100%;
        min-height: 480px; /* Balanced with the about us image section */
    }
}

.hero-image-wrapper::before,
.hero-image-decor {
    content: '';
    position: absolute;
    width: 85%;
    height: 85%;
    background-color: var(--color-primary-glow);
    border-radius: var(--radius-lg);
    z-index: 1;
    transform: rotate(3deg);
    top: 0;
    left: 0;
}

.hero-image {
    position: relative;
    z-index: 2;
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-lg);
    width: 100%;
    height: 100%;
    object-fit: cover; /* Stretch and fill the column grid cleanly without distortion */
    display: block;
}

/* About Us Section */
.about-section {
    padding: 6rem 0;
    background-color: #ffffff;
}

.about-details {
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.about-section .grid-2 {
    align-items: stretch;
    gap: 4rem;
}

.about-image-wrapper {
    width: 100%;
    height: 320px; /* Default height on mobile stack */
}

.about-image-wrapper img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-lg);
}

@media (min-width: 768px) {
    .about-image-wrapper {
        height: 100%;
        min-height: 480px;
    }
}

.about-details p {
    margin-bottom: 1.25rem;
    font-size: 1rem;
    color: var(--color-text-main);
}

.about-details p strong {
    color: var(--color-text-dark);
}

.about-stats {
    display: grid !important;
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 1.5rem;
    margin-top: 2rem;
}

.stat-item {
    border-left: 3px solid var(--color-primary);
    padding-left: 1rem;
}

.stat-item h4 {
    font-size: 1.75rem;
    color: var(--color-primary);
    margin-bottom: 0.25rem;
}

.stat-item p {
    font-size: 0.875rem;
    color: var(--color-text-muted);
    margin-bottom: 0;
}

/* Specialties & Services Section */
.specialties-section {
    padding: 6rem 0;
    background-color: var(--color-bg-accent);
}

.specialty-card {
    height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

.specialty-card-body h3 {
    margin-bottom: 1rem;
    color: var(--color-text-dark);
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.specialty-card-body h3 svg {
    color: var(--color-primary);
    flex-shrink: 0;
}

.specialty-card p {
    color: var(--color-text-muted);
    margin-bottom: 1.5rem;
}

/* Why Choose Us Section */
.why-choose-section {
    padding: 6rem 0;
    background-color: #ffffff;
}

.why-top-row {
    align-items: center;
    gap: 4rem;
    margin-bottom: 4rem;
}

.why-cards-flex {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 1.5rem;
    justify-content: center;
    width: 100%;
}

.why-cards-flex .why-card {
    flex: 1 1 calc(33.333% - 1.5rem);
    min-width: 280px;
    max-width: 100%;
    padding: 1.75rem;
    border-radius: var(--radius-md);
    background-color: var(--color-bg-base);
    border: 1px solid var(--color-border);
    transition: var(--transition-normal);
}

.why-cards-flex .why-card:hover {
    background-color: #ffffff;
    box-shadow: var(--shadow-md);
    border-color: rgba(22, 59, 231, 0.15);
    transform: translateY(-3px);
}

.why-card h3 {
    font-size: 1.125rem;
    margin-bottom: 0.75rem;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.why-card h3 svg {
    color: var(--color-primary);
    width: 20px;
    height: 20px;
}

.why-card p {
    font-size: 0.9rem;
    color: var(--color-text-muted);
    line-height: 1.5;
}

.why-visual-wrapper {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, #f4f6fc 0%, #eef2ff 100%);
    color: var(--color-text-dark);
    border-radius: var(--radius-lg);
    padding: 3.5rem;
    position: relative;
    overflow: hidden;
    box-shadow: var(--shadow-sm);
    border: 1px solid var(--color-border);
    text-align: center;
}

.brand-logo-card {
    margin-bottom: 1.5rem !important;
    width: 200px !important;
    height: auto !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    margin-left: auto !important;
    margin-right: auto !important;
}

.brand-logo-card figure.wp-block-image,
.brand-logo-card img {
    width: 100% !important;
    height: auto !important;
    object-fit: contain !important;
}

.why-visual-wrapper::before {
    content: '';
    position: absolute;
    width: 300px;
    height: 300px;
    background: radial-gradient(circle, rgba(22, 59, 231, 0.06) 0%, transparent 70%);
    top: -50px;
    left: -50px;
    pointer-events: none;
}

.commitment-meter {
    position: relative;
    width: 180px;
    height: 180px;
    margin-bottom: 2rem;
}

.commitment-meter svg {
    transform: rotate(-90deg);
}

.meter-bg {
    fill: none;
    stroke: rgba(255, 255, 255, 0.1);
    stroke-width: 8px;
}

.meter-fill {
    fill: none;
    stroke: var(--color-primary);
    stroke-width: 8px;
    stroke-linecap: round;
    stroke-dasharray: 502;
    stroke-dashoffset: 0; /* 100% commitment */
    transition: stroke-dashoffset 1.5s ease-out;
}

.meter-text {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    text-align: center;
}

.meter-text span {
    font-family: var(--font-heading);
    font-size: 2.5rem;
    font-weight: 800;
    color: white;
    display: block;
    line-height: 1;
}

.meter-text label {
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--color-primary);
    font-weight: 700;
}

.why-visual-wrapper h3 {
    color: var(--color-text-dark);
    margin-bottom: 0.5rem;
    font-size: 1.5rem;
}

.why-visual-wrapper p {
    color: var(--color-text-muted);
    font-size: 0.95rem;
    max-width: 280px;
}

/* Process Section */
.process-section {
    padding: 6rem 0;
    background-color: var(--color-bg-accent);
}

.process-grid {
    grid-template-columns: 1fr;
    gap: 2.5rem;
}

@media (min-width: 768px) {
    .process-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 1024px) {
    .process-grid {
        grid-template-columns: repeat(4, 1fr);
        position: relative;
    }
    
    .process-grid::before {
        content: '';
        position: absolute;
        top: 4.75rem;
        left: 12.5%;
        right: 12.5%;
        height: 2px;
        background: repeating-linear-gradient(90deg, var(--color-primary) 0, var(--color-primary) 8px, transparent 8px, transparent 16px);
        z-index: 1;
        pointer-events: none;
    }
}

.process-step {
    background-color: var(--color-bg-card);
    border-radius: var(--radius-md);
    padding: 3rem 2rem 2.5rem;
    box-shadow: var(--shadow-sm);
    border: 1px solid var(--color-border);
    position: relative;
    z-index: 2;
    transition: var(--transition-normal);
    text-align: center;
    overflow: hidden;
}

.process-step:hover {
    transform: translateY(-5px);
    box-shadow: var(--shadow-lg);
    border-color: var(--color-primary);
}

.process-step .step-bg-num {
    position: absolute !important;
    right: -10px !important;
    bottom: -20px !important;
    font-size: 7.5rem !important;
    font-family: var(--font-heading) !important;
    font-weight: 800 !important;
    color: rgba(22, 59, 231, 0.03) !important;
    line-height: 1 !important;
    pointer-events: none !important;
    transition: all var(--transition-normal) !important;
    z-index: 1 !important;
    margin: 0 !important;
}

.process-step:hover .step-bg-num {
    color: rgba(22, 59, 231, 0.08) !important;
    transform: translateY(-10px) scale(1.05) !important;
}

.step-icon {
    width: 3.5rem !important;
    height: 3.5rem !important;
    background-color: var(--color-primary-light) !important;
    color: var(--color-primary) !important;
    border-radius: var(--radius-md) !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    margin: 0 auto 1.5rem !important;
    position: relative !important;
    z-index: 2 !important;
    transition: var(--transition-normal) !important;
    border: 1px solid rgba(22, 59, 231, 0.1) !important;
}

.step-icon:hover, .process-step:hover .step-icon {
    background-color: var(--color-primary) !important;
    color: white !important;
    box-shadow: var(--shadow-glow) !important;
    border-color: var(--color-primary) !important;
}

.process-step h3 {
    font-size: 1.125rem;
    margin-bottom: 0.75rem;
    color: var(--color-text-dark);
    position: relative;
    z-index: 2;
}

.process-step p {
    font-size: 0.9rem;
    color: var(--color-text-muted);
    position: relative;
    z-index: 2;
}

/* Testimonial Section */
.testimonials-section {
    padding: 6rem 0 2rem;
    background-color: #ffffff;
    overflow: hidden;
}

.testimonial-marquee-container {
    width: 100%;
    overflow: hidden;
    position: relative;
    padding: 2rem 0;
    margin-top: 4.5rem; /* Increase margin to bring it down further and provide elegant breathing space */
    /* Soft-edge mask gradient fade to indicate scrollable content on both sides */
    -webkit-mask-image: linear-gradient(to right, transparent 0%, black 10%, black 90%, transparent 100%);
    mask-image: linear-gradient(to right, transparent 0%, black 10%, black 90%, transparent 100%);
}

.testimonial-marquee-track {
    display: flex;
    width: max-content;
    animation: scrollMarquee 45s linear infinite;
}

.testimonial-marquee-track:hover {
    animation-play-state: paused;
}

.testimonial-card {
    width: 420px;
    flex-shrink: 0;
    margin-right: 2.5rem; /* Space between cards */
    background-color: var(--color-bg-base);
    border-radius: var(--radius-md);
    padding: 2.5rem;
    border: 1px solid var(--color-border);
    position: relative;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.02);
    transition: border-color 0.3s ease, transform 0.3s ease, box-shadow 0.3s ease;
}

.testimonial-card:hover {
    border-color: var(--color-primary);
    transform: translateY(-5px);
    box-shadow: 0 12px 30px rgba(22, 59, 231, 0.08);
}

.testimonial-card::before {
    content: '“';
    position: absolute;
    top: 1rem;
    left: 1.5rem;
    font-size: 5rem;
    font-family: Georgia, serif;
    color: rgba(22, 59, 231, 0.08);
    line-height: 1;
}

.testimonial-content {
    position: relative;
    z-index: 2;
    margin-bottom: 1.5rem;
}

.testimonial-content p {
    font-size: 0.95rem;
    font-style: italic;
    color: var(--color-text-main);
    line-height: 1.7;
}

.testimonial-stars {
    color: #eab308; /* yellow star */
    margin-bottom: 1rem;
    display: flex;
    gap: 0.25rem;
}

@keyframes scrollMarquee {
    0% {
        transform: translateX(0);
    }
    100% {
        transform: translateX(-50%);
    }
}

.testimonial-author {
    display: flex;
    align-items: center;
    gap: 1rem;
}

.author-avatar {
    width: 3rem;
    height: 3rem;
    border-radius: var(--radius-full);
    background-color: var(--color-primary-light);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-primary);
    font-family: var(--font-heading);
    font-weight: 700;
}

.author-info h4 {
    font-size: 0.95rem;
    color: var(--color-text-dark);
}

.author-info p {
    font-size: 0.8rem;
    color: var(--color-text-muted);
}

/* Team / Organisational Structure Section */
.team-section {
    padding: 2rem 0 6rem;
    background-color: var(--color-bg-base);
}

.team-card {
    padding: 0;
    overflow: hidden;
    position: relative;
    display: flex;
    flex-direction: column;
    background-color: var(--color-bg-card); /* Pure White background */
    border: 1px solid var(--color-border); /* Standard light border */
}

.team-image-container {
    position: relative;
    background-color: #0b0f19; /* Sleek black background for the image frame */
    overflow: hidden;
    aspect-ratio: 1.05; /* Balanced aspect ratio to keep all card heights identical */
    padding: 1.25rem 1.25rem 0 1.25rem; /* Padding to make the image smaller and show the black background frame */
}

.team-image-container figure.wp-block-image img,
.team-image-container img {
    width: 100% !important;
    height: 100% !important;
    object-fit: contain !important; /* Prevent cropping of hair, buns, or shoulders */
    object-position: bottom center !important; /* Align portrait to the bottom */
    border-radius: var(--radius-sm) var(--radius-sm) 0 0 !important;
    transition: var(--transition-normal);
}

.team-card:hover .team-image-container img {
    transform: scale(1.05);
}

.team-hover-info {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(to top, rgba(15, 23, 42, 0.95) 0%, rgba(15, 23, 42, 0.7) 100%) !important;
    color: #ffffff !important;
    padding: 2rem;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    opacity: 0;
    transform: translateY(10px);
    transition: var(--transition-normal);
    z-index: 3;
}

.team-card:hover .team-hover-info,
.team-image-container:hover .team-hover-info {
    opacity: 1;
    transform: translateY(0);
}

.team-hover-info p {
    font-size: 0.85rem !important;
    line-height: 1.5 !important;
    color: #ffffff !important;
}

.team-member-details {
    padding: 1.5rem;
    text-align: center;
    background-color: var(--color-bg-card); /* White background behind the text details */
    border-top: 1px solid var(--color-border); /* Standard light divider line */
    position: relative;
    z-index: 2;
}

.team-member-details h3 {
    font-size: 1.125rem;
    margin-bottom: 0.25rem;
    color: var(--color-text-dark); /* Dark text color */
}

.team-member-details p {
    font-size: 0.85rem;
    color: var(--color-primary); /* Blue accent for roles */
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.team-social {
    display: flex;
    justify-content: center;
    margin-top: 0.75rem;
}

.team-social-link {
    color: var(--color-text-muted);
    transition: var(--transition-normal);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 30px;
    height: 30px;
    border-radius: var(--radius-full);
    background-color: rgba(0, 0, 0, 0.03);
}

.team-social-link:hover {
    color: #0077b5; /* LinkedIn brand color */
    background-color: rgba(0, 119, 181, 0.1);
    transform: translateY(-2px);
}

/* Dynamically style plain text Gutenberg LinkedIn profile links inside team member details as a circular icon logo */
.team-member-details p:has(a[href*="linkedin.com"]) {
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    margin: 0.75rem 0 0 0 !important;
    padding: 0 !important;
}

.team-member-details p a[href*="linkedin.com"] {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 32px !important;
    height: 32px !important;
    border-radius: var(--radius-full) !important;
    background-color: rgba(22, 59, 231, 0.05) !important;
    color: var(--color-primary) !important;
    font-size: 0 !important; /* Hide "LinkedIn Profile" text */
    transition: var(--transition-normal) !important;
    position: relative !important;
    border: 1px solid rgba(22, 59, 231, 0.1) !important;
    margin: 0 !important;
    padding: 0 !important;
    text-decoration: none !important;
}

.team-member-details p a[href*="linkedin.com"]::before {
    content: "" !important;
    position: absolute !important;
    top: 50% !important;
    left: 50% !important;
    transform: translate(-50%, -50%) !important;
    width: 14px !important;
    height: 14px !important;
    background-color: currentColor !important;
    mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M19 0h-14c-2.761 0-5 2.239-5 5v14c0 2.761 2.239 5 5 5h14c2.762 0 5-2.239 5-5v-14c0-2.761-2.238-5-5-5zm-11 19h-3v-11h3v11zm-1.5-12.268c-.966 0-1.75-.779-1.75-1.75s.784-1.75 1.75-1.75 1.75.779 1.75 1.75-.784 1.75-1.75 1.75zm13.5 12.268h-3v-5.604c0-3.368-4-3.113-4 0v5.604h-3v-11h3v1.765c1.396-2.586 7-2.777 7 2.476v6.759z'/%3E%3C/svg%3E") no-repeat center !important;
    -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M19 0h-14c-2.761 0-5 2.239-5 5v14c0 2.761 2.239 5 5 5h14c2.762 0 5-2.239 5-5v-14c0-2.761-2.238-5-5-5zm-11 19h-3v-11h3v11zm-1.5-12.268c-.966 0-1.75-.779-1.75-1.75s.784-1.75 1.75-1.75 1.75.779 1.75 1.75-.784 1.75-1.75 1.75zm13.5 12.268h-3v-5.604c0-3.368-4-3.113-4 0v5.604h-3v-11h3v1.765c1.396-2.586 7-2.777 7 2.476v6.759z'/%3E%3C/svg%3E") no-repeat center !important;
    mask-size: contain !important;
    -webkit-mask-size: contain !important;
}

.team-member-details p a[href*="linkedin.com"]:hover {
    background-color: #0077b5 !important;
    color: #ffffff !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 4px 6px rgba(0, 119, 181, 0.2) !important;
}

/* Newsletter Section */
.newsletter-section {
    padding: 5rem 0;
    background: linear-gradient(135deg, var(--color-secondary) 0%, var(--color-secondary-light) 100%);
    color: white;
    position: relative;
    overflow: hidden;
}

.newsletter-section::before {
    content: '';
    position: absolute;
    width: 400px;
    height: 400px;
    background: radial-gradient(circle, var(--color-primary-glow) 0%, transparent 70%);
    bottom: -150px;
    left: -150px;
    pointer-events: none;
}

.newsletter-container {
    max-width: 800px;
    margin: 0 auto;
    text-align: center;
    position: relative;
    z-index: 2;
}

.newsletter-container h2 {
    color: white;
    margin-bottom: 1rem;
}

.newsletter-container p {
    color: var(--color-text-light);
    margin-bottom: 2.5rem;
    max-width: 600px;
    margin-left: auto;
    margin-right: auto;
}

.newsletter-form {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    max-width: 500px;
    margin: 0 auto;
}

@media (min-width: 640px) {
    .newsletter-form {
        flex-direction: row;
        gap: 0;
        background-color: rgba(255, 255, 255, 0.08);
        border: 1px solid rgba(255, 255, 255, 0.15);
        border-radius: var(--radius-md);
        padding: 0.35rem;
    }
}

.newsletter-form input[type="email"] {
    background-color: rgba(255, 255, 255, 0.1);
    border: 1px solid rgba(255, 255, 255, 0.15);
    border-radius: var(--radius-md);
    color: white;
    padding: 0.85rem 1.25rem;
    flex: 1;
    font-family: var(--font-body);
    font-size: 0.95rem;
    transition: var(--transition-fast);
}

@media (min-width: 640px) {
    .newsletter-form input[type="email"] {
        background: transparent;
        border: none;
    }
}

.newsletter-form input[type="email"]:focus {
    outline: none;
    background-color: rgba(255, 255, 255, 0.15);
}

.newsletter-form .btn {
    border-radius: var(--radius-md);
}

/* ==========================================
   Footer Section
   ========================================= */
.site-footer {
    background-color: #0b0f19;
    color: var(--color-text-light);
    padding: 5rem 0 2rem;
    border-top: 1px solid rgba(255, 255, 255, 0.05);
}

.footer-grid {
    gap: 3rem;
    margin-bottom: 4rem;
}

.footer-logo {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    font-family: var(--font-heading);
    font-size: 1.25rem;
    font-weight: 800;
    color: white;
    margin-bottom: 1.25rem;
}

.footer-logo span {
    color: var(--color-primary);
}

.footer-col p {
    font-size: 0.9rem;
    line-height: 1.6;
    margin-bottom: 1.5rem;
}

.footer-social-links {
    display: flex;
    gap: 1rem;
}

.footer-social-link {
    width: 2.25rem;
    height: 2.25rem;
    background-color: rgba(255, 255, 255, 0.05);
    border-radius: var(--radius-full);
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    transition: var(--transition-fast);
    border: 1px solid rgba(255, 255, 255, 0.08);
}

.footer-social-link:hover {
    background-color: var(--color-primary);
    color: white;
    transform: translateY(-2px);
}

.footer-col h3 {
    color: white;
    font-size: 1.125rem;
    margin-bottom: 1.5rem;
    position: relative;
    padding-bottom: 0.5rem;
}

.footer-col h3::after {
    content: '';
    position: absolute;
    width: 30px;
    height: 2px;
    background-color: var(--color-primary);
    bottom: 0;
    left: 0;
}

.footer-col ul {
    list-style: none;
}

.footer-col li {
    margin-bottom: 0.75rem;
}

.footer-col a {
    color: var(--color-text-light);
    font-size: 0.9rem;
    transition: var(--transition-fast);
}

.footer-col a:hover {
    color: white;
    padding-left: 0.25rem;
}

.contact-info-list li {
    display: flex;
    gap: 0.75rem;
    font-size: 0.9rem;
    align-items: flex-start;
    margin-bottom: 1rem;
}

.contact-info-list svg {
    color: var(--color-primary);
    flex-shrink: 0;
    margin-top: 0.25rem;
    width: 18px;
    height: 18px;
}

.footer-bottom {
    border-top: 1px solid rgba(255, 255, 255, 0.05);
    padding-top: 2rem;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    font-size: 0.8rem;
}

@media (min-width: 768px) {
    .footer-bottom {
        flex-direction: row;
    }
}

.footer-bottom-links {
    display: flex;
    gap: 1.5rem;
}

.footer-bottom-links a {
    color: var(--color-text-light);
}

.footer-bottom-links a:hover {
    color: white;
}

/* ==========================================
   Fallback Pages / Gutenberg styling
   ========================================= */
.page-template-default, .post-template-default {
    background-color: #ffffff;
}

.page-content-wrapper {
    padding: 5rem 0;
}

.page-header-default {
    background: linear-gradient(135deg, #0f2c59 0%, #163be7 100%);
    padding: 5rem 0;
    text-align: center;
    position: relative;
    overflow: hidden;
    color: #ffffff;
}

.page-header-bg-decoration {
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    width: 30%;
    pointer-events: none;
    z-index: 1;
}

.page-header-bg-decoration svg {
    height: 100%;
    width: 100%;
    opacity: 0.15;
    fill: none;
    stroke: #ffffff;
    stroke-width: 0.8;
}

.page-header-inner {
    position: relative;
    z-index: 2;
}

.page-header-default .page-title {
    color: #ffffff !important;
    font-size: 2.75rem;
    font-weight: 700;
    margin-bottom: 0.5rem;
}

.page-header-default .page-breadcrumbs {
    font-size: 0.9rem;
    color: rgba(255, 255, 255, 0.75);
    font-family: var(--font-body);
    font-weight: 500;
}

.page-header-default .page-breadcrumbs a {
    color: rgba(255, 255, 255, 0.95);
    transition: var(--transition-fast);
}

.page-header-default .page-breadcrumbs a:hover {
    color: #ffffff;
    text-decoration: underline;
}

.page-content-inner {
    max-width: var(--container-max);
    margin: 0 auto;
}

.page-content-inner p {
    margin-bottom: 1.5rem;
}

/* Page Builder / Full Width Template Styling */
.page-builder-canvas {
    width: 100%;
    max-width: 100%;
    margin: 0;
    padding: 0;
    overflow-x: hidden;
}

/* ==========================================
   Gutenberg & Block Editor Layout Resets
   ========================================== */

/* Prevent Gutenberg Group inner wrapper from breaking grids and flex layouts */
.wp-block-group__inner-container {
    display: contents !important;
}

/* Remove default Gutenberg block width constraints inside our custom sections, excluding .container */
.hero-section .is-layout-constrained > :not(.container),
.about-section .is-layout-constrained > :not(.container),
.specialties-section .is-layout-constrained > :not(.container),
.why-choose-section .is-layout-constrained > :not(.container),
.process-section .is-layout-constrained > :not(.container),
.testimonials-section .is-layout-constrained > :not(.container),
.team-section .is-layout-constrained > :not(.container),
.newsletter-section .is-layout-constrained > :not(.container) {
    max-width: none !important;
    margin-left: unset !important;
    margin-right: unset !important;
}

/* Ensure Gutenberg image block wrapper is flexible */
figure.wp-block-image {
    margin: 0 !important;
    width: 100% !important;
    height: 100% !important;
    display: block !important;
}

figure.wp-block-image img {
    width: 100% !important;
    height: 100% !important;
    object-fit: inherit !important;
    border-radius: inherit !important;
}

/* Reset headings margins and padding inside block editors */
.wp-block-heading {
    margin-top: 0 !important;
    margin-bottom: 0.5rem !important;
}

.wp-block-paragraph {
    margin-top: 0 !important;
    margin-bottom: 1rem !important;
}

.wp-block-group {
    margin-top: 0 !important;
    margin-bottom: 0 !important;
}

/* ==========================================
   Block Editor Canvas Width Adjustments
   ========================================== */
.block-editor-writing-flow,
.block-editor-block-list__layout {
    max-width: none !important;
    background-color: #ffffff !important;
    padding: 0 !important;
    --wp--style--global--content-size: 1280px !important;
    --wp--style--global--wide-size: 1280px !important;
}

/* Force block layout writing flow to stretch wide */
.block-editor-writing-flow .wp-block,
.block-editor-block-list__layout .wp-block,
.block-editor-block-list__layout .block-editor-block-list__block {
    max-width: none !important;
}

/* Force top-level section block wrappers to be 100% wide in the editor (for edge-to-edge backgrounds) */
.block-editor-block-list__layout > .wp-block:has(.hero-section),
.block-editor-block-list__layout > .wp-block:has(.about-section),
.block-editor-block-list__layout > .wp-block:has(.specialties-section),
.block-editor-block-list__layout > .wp-block:has(.why-choose-section),
.block-editor-block-list__layout > .wp-block:has(.process-section),
.block-editor-block-list__layout > .wp-block:has(.testimonials-section),
.block-editor-block-list__layout > .wp-block:has(.team-section),
.block-editor-block-list__layout > .wp-block:has(.newsletter-section) {
    max-width: none !important;
    width: 100% !important;
}

/* Constrain the wrapper of any .container block inside the editor to 1280px and center it */
.block-editor-writing-flow .wp-block:has(> .container),
.block-editor-writing-flow .wp-block:has(> .wp-block-group.container) {
    max-width: 1280px !important;
    margin-left: auto !important;
    margin-right: auto !important;
    width: 100% !important;
}

/* Constrain and center our container blocks in the editor so they match the header */
.block-editor-writing-flow .container {
    max-width: 1280px !important;
    margin-left: auto !important;
    margin-right: auto !important;
    width: 100% !important;
}

/* Editor-specific alignment for team hover bio */
.block-editor-writing-flow .team-hover-info,
.block-editor-block-list__layout .team-hover-info {
    justify-content: center !important;
}

/* In the editor, show the hover info whenever the block or card is hovered, selected, or focused */
.block-editor-writing-flow .wp-block:hover .team-hover-info,
.block-editor-block-list__layout .wp-block:hover .team-hover-info,
.block-editor-writing-flow .wp-block.is-selected .team-hover-info,
.block-editor-block-list__layout .wp-block.is-selected .team-hover-info,
.block-editor-writing-flow .wp-block.is-hovered .team-hover-info,
.block-editor-block-list__layout .wp-block.is-hovered .team-hover-info,
.block-editor-writing-flow .team-image-container:hover .team-hover-info,
.block-editor-block-list__layout .team-image-container:hover .team-hover-info,
.block-editor-writing-flow .team-card:hover .team-hover-info,
.block-editor-block-list__layout .team-card:hover .team-hover-info,
.block-editor-writing-flow .team-card.is-selected .team-hover-info,
.block-editor-block-list__layout .team-card.is-selected .team-hover-info,
.wp-block.is-selected .team-hover-info,
.wp-block.is-hovered .team-hover-info,
.team-card.is-selected .team-hover-info,
.team-card.is-hovered .team-hover-info {
    opacity: 1 !important;
    transform: translateY(0) !important;
    pointer-events: auto !important;
}

.block-editor-writing-flow .team-hover-info .block-editor-block-list__layout,
.block-editor-block-list__layout .team-hover-info .block-editor-block-list__layout {
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
    height: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
}

.block-editor-writing-flow .team-hover-info .wp-block,
.block-editor-block-list__layout .team-hover-info .wp-block {
    margin: 0 !important;
    width: 100% !important;
}

.block-editor-writing-flow .team-hover-info p,
.block-editor-block-list__layout .team-hover-info p {
    font-size: 0.8rem !important;
    line-height: 1.4 !important;
    color: #ffffff !important;
    margin: 0 !important;
    text-align: center !important;
}

/* Editor-specific alignment for process step background numbers */
.block-editor-writing-flow .process-step .wp-block:has(> .step-bg-num) {
    position: absolute !important;
    right: -10px !important;
    bottom: -20px !important;
    max-width: none !important;
    width: auto !important;
    height: auto !important;
    margin: 0 !important;
    padding: 0 !important;
    z-index: 1 !important;
    pointer-events: none !important;
}

.block-editor-writing-flow .process-step .step-bg-num {
    position: static !important;
    font-size: 7.5rem !important;
    color: rgba(22, 59, 231, 0.03) !important;
    line-height: 1 !important;
}

/* Custom classes to replace inline paragraph styles (resolving Gutenberg validation errors) */
.hero-paragraph-lead {
    margin-top: 0 !important;
    font-weight: 500 !important;
    color: var(--color-secondary-muted) !important;
}

.why-intro-lead {
    font-size: 1.1rem !important;
    line-height: 1.7 !important;
    color: var(--color-text-muted) !important;
    margin-bottom: 1.5rem !important;
}

.why-intro-body {
    font-size: 1rem !important;
    color: var(--color-text-muted) !important;
}

/* ==========================================
   Products / Shop Page Styles
   ========================================== */

.shop-page-wrapper {
    width: 100%;
}

/* 1. Category Hero Grid */
.category-hero-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.5rem;
    margin-bottom: 3rem;
}

@media (min-width: 768px) {
    .category-hero-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

.category-card {
    background-size: cover;
    background-position: center;
    border-radius: var(--radius-md);
    height: 320px;
    display: flex;
    align-items: flex-end;
    padding: 2rem;
    position: relative;
    overflow: hidden;
    box-shadow: var(--shadow-sm);
    transition: var(--transition-normal);
}

.category-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(180deg, rgba(15, 44, 89, 0.2) 0%, rgba(15, 44, 89, 0.85) 100%);
    z-index: 1;
}

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

.category-card-content {
    position: relative;
    z-index: 2;
    color: #ffffff;
}

.category-card-content .category-tag {
    font-family: var(--font-heading);
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    color: #ffffff;
    background-color: var(--color-primary);
    padding: 0.25rem 0.75rem;
    border-radius: var(--radius-full);
    display: inline-block;
    margin-bottom: 0.75rem;
}

.category-card-content h3 {
    color: #ffffff !important;
    font-size: 1.5rem;
    font-weight: 700;
    margin-bottom: 0.5rem;
}

.category-card-content p {
    font-size: 0.9rem;
    color: rgba(255, 255, 255, 0.8);
    margin-bottom: 1.25rem;
    line-height: 1.4;
}

.category-link {
    color: #ffffff !important;
    font-family: var(--font-heading);
    font-weight: 600;
    font-size: 0.95rem;
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
}

.category-link svg {
    transition: transform var(--transition-fast);
}

.category-card:hover .category-link svg {
    transform: translateX(5px);
}

/* 2. Badges Bar */
.shop-badges-bar {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.5rem;
    padding: 2rem;
    background-color: var(--color-bg-accent);
    border-radius: var(--radius-md);
    margin-bottom: 4rem;
    border: 1px solid var(--color-border);
}

@media (min-width: 576px) {
    .shop-badges-bar {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 992px) {
    .shop-badges-bar {
        grid-template-columns: repeat(5, 1fr);
    }
}

.badge-item {
    display: flex;
    align-items: center;
    gap: 1rem;
}

.badge-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    border-radius: var(--radius-full);
    background-color: var(--color-primary-light);
    color: var(--color-primary);
    flex-shrink: 0;
}

.badge-info h4 {
    font-size: 0.9rem;
    font-weight: 700;
    color: var(--color-text-dark);
}

.badge-info p {
    font-size: 0.8rem;
    color: var(--color-text-muted);
}

/* 3. Product Group Sections */
.shop-group-section,
.wp-block-group.shop-group-section {
    margin-bottom: 4rem !important;
}

.section-title-clinical {
    font-family: var(--font-heading);
    font-size: 1.5rem;
    font-weight: 800;
    letter-spacing: -0.01em;
    color: var(--color-text-dark);
    margin-bottom: 1.5rem;
    padding-left: 0.75rem;
    border-left: 4px solid var(--color-primary);
    line-height: 1.2;
}

.product-group-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.5rem;
}

@media (min-width: 576px) {
    .product-group-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 992px) {
    .product-group-grid {
        grid-template-columns: repeat(4, 1fr);
    }
}

.product-group-card {
    background-color: var(--color-bg-card);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: 2rem;
    transition: var(--transition-normal);
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.product-group-card:hover {
    transform: translateY(-3px);
    border-color: rgba(22, 59, 231, 0.25);
    box-shadow: var(--shadow-md);
}

.group-card-icon {
    color: var(--color-primary);
    margin-bottom: 1rem;
}

.product-group-card h3 {
    font-size: 1.15rem;
    font-weight: 700;
    color: var(--color-text-dark);
    margin-bottom: 0.5rem;
}

.product-group-card p {
    font-size: 0.875rem;
    color: var(--color-text-muted);
    line-height: 1.4;
}

/* 4. Popular Products */
.section-header-flex {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 1.5rem;
}

.section-header-flex .section-title-clinical {
    margin-bottom: 0;
}

.view-all-link {
    font-family: var(--font-heading);
    font-size: 0.875rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    color: var(--color-primary);
    transition: var(--transition-fast);
}

.view-all-link:hover {
    color: var(--color-primary-hover);
    text-decoration: underline;
}

.popular-products-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.5rem;
}

@media (min-width: 576px) {
    .popular-products-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 992px) {
    .popular-products-grid {
        grid-template-columns: repeat(4, 1fr);
    }
}

@media (min-width: 1200px) {
    .popular-products-grid {
        grid-template-columns: repeat(5, 1fr);
    }
}

.product-item-card {
    background-color: var(--color-bg-card);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    overflow: hidden;
    transition: var(--transition-normal);
    display: flex;
    flex-direction: column;
}

.product-item-card:hover {
    transform: translateY(-5px);
    box-shadow: var(--shadow-lg);
    border-color: rgba(22, 59, 231, 0.25);
}

.product-item-image-wrapper {
    height: 180px;
    background-color: var(--color-bg-accent);
    display: flex;
    align-items: center;
    justify-content: center;
    border-bottom: 1px solid var(--color-border);
    position: relative;
    overflow: hidden;
}

.product-item-svg {
    color: var(--color-primary);
    opacity: 0.7;
    transition: transform var(--transition-normal);
}

.product-item-card:hover .product-item-svg {
    transform: scale(1.1);
    opacity: 1;
}

.product-item-details {
    padding: 1.25rem;
    display: flex;
    flex-direction: column;
    flex-grow: 1;
}

.product-item-title {
    font-size: 0.95rem;
    font-weight: 600;
    color: var(--color-text-dark);
    margin-bottom: 0.75rem;
    line-height: 1.4;
    min-height: 2.8rem;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.product-price-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: auto;
}

.product-price-row .price {
    font-family: var(--font-heading);
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--color-primary);
}

.add-to-cart-action {
    padding: 0.4rem 0.8rem !important;
    font-size: 0.8rem !important;
    border-radius: var(--radius-sm) !important;
}

/* 5. CTA Support Section */
.shop-cta-section {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.5rem;
    margin-top: 4rem;
}

@media (min-width: 768px) {
    .shop-cta-section {
        grid-template-columns: repeat(2, 1fr);
    }
}

.cta-card {
    background-color: var(--color-bg-card);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: 3rem 2rem;
    text-align: center;
    box-shadow: var(--shadow-sm);
    transition: var(--transition-normal);
}

.cta-card:hover {
    transform: translateY(-3px);
    box-shadow: var(--shadow-md);
}

.cta-card h3 {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--color-text-dark);
    margin-bottom: 0.75rem;
}

.cta-card p {
    font-size: 0.95rem;
    color: var(--color-text-muted);
    margin-bottom: 1.5rem;
}

.cta-special {
    background: linear-gradient(135deg, rgba(22, 59, 231, 0.02) 0%, rgba(22, 59, 231, 0.08) 100%);
    border-color: rgba(22, 59, 231, 0.15);
}

/* ==========================================
   Services Page Styles (Premium Redesign)
   ========================================== */
.services-intro-section {
    max-width: 800px;
    margin: 0 auto 4rem auto;
    text-align: center;
}

.section-tagline {
    display: inline-block;
    font-size: 0.85rem;
    font-weight: 700;
    color: var(--color-primary);
    text-transform: uppercase;
    letter-spacing: 0.15em;
    margin-bottom: 0.75rem;
}

.services-intro-section h2 {
    font-size: 2.5rem;
    font-weight: 800;
    color: var(--color-text-dark);
    margin-bottom: 1rem;
    line-height: 1.2;
}

.section-subtitle {
    font-size: 1.1rem;
    color: var(--color-text-muted);
    line-height: 1.6;
}

/* Services 3-Column Grid */
.services-card-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 2.5rem;
    margin-bottom: 6rem;
}

@media (min-width: 768px) {
    .services-card-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 1200px) {
    .services-card-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

.service-grid-card {
    background-color: var(--color-bg-card);
    border: 1px solid var(--color-border);
    border-radius: 16px;
    overflow: hidden;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.02);
    display: flex;
    flex-direction: column;
    transition: transform var(--transition-normal), box-shadow var(--transition-normal), border-color var(--transition-normal);
}

.service-grid-card:hover {
    transform: translateY(-8px);
    box-shadow: 0 12px 30px rgba(22, 59, 231, 0.08);
    border-color: rgba(22, 59, 231, 0.15);
}

.service-card-image-wrapper {
    position: relative;
    height: 220px;
    width: 100%;
    overflow: visible !important;
}

.service-card-image-wrapper::after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: linear-gradient(to bottom, rgba(15, 44, 89, 0) 30%, rgba(15, 44, 89, 0.4) 100%);
    z-index: 1;
    pointer-events: none;
    border-radius: 16px 16px 0 0;
}

.service-card-image-wrapper > .wp-block-group__inner-container {
    height: 100% !important;
    position: relative !important;
}

.service-card-image-wrapper .wp-block-image {
    height: 100% !important;
    margin: 0 !important;
    overflow: hidden !important;
    border-radius: 16px 16px 0 0 !important;
}

.service-card-image-wrapper .wp-block-image img {
    height: 100% !important;
    width: 100% !important;
    object-fit: cover !important;
    transition: transform 0.5s ease;
}

.service-grid-card:hover .service-card-image-wrapper .wp-block-image img {
    transform: scale(1.08);
}

.service-card-icon-floating {
    position: absolute;
    bottom: 0;
    left: 2rem;
    transform: translateY(50%);
    width: 50px;
    height: 50px;
    border-radius: 12px;
    background-color: var(--color-primary);
    color: #ffffff;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 4px 15px rgba(22, 59, 231, 0.3);
    z-index: 2;
}

.service-card-body {
    padding: 2.25rem 2rem 2rem 2rem;
    display: flex;
    flex-direction: column;
    flex-grow: 1;
    gap: 1.25rem;
}

.service-grid-card h3 {
    font-size: 1.35rem;
    font-weight: 700;
    color: var(--color-text-dark);
    margin-top: 0.25rem;
}

.service-card-description {
    font-size: 0.925rem;
    line-height: 1.6;
    color: var(--color-text-main);
}

.service-card-highlight {
    font-size: 0.875rem;
    line-height: 1.5;
    color: var(--color-text-muted);
    padding-left: 1rem;
    border-left: 3px solid var(--color-primary);
    background-color: rgba(22, 59, 231, 0.02);
    padding-top: 0.5rem;
    padding-bottom: 0.5rem;
    padding-right: 0.75rem;
    border-radius: 0 6px 6px 0;
}

.service-card-footer {
    margin-top: auto;
    padding-top: 1.5rem;
    border-top: 1px solid var(--color-border);
}

.service-contact-label {
    display: block;
    font-size: 0.75rem;
    font-weight: 700;
    color: var(--color-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-bottom: 0.5rem;
}

.service-card-footer .btn-outline {
    font-size: 0.85rem;
    text-align: center;
    border: 1px solid rgba(22, 59, 231, 0.2);
    color: var(--color-primary);
    background: transparent;
    padding: 0.65rem 1rem;
    border-radius: 8px;
    font-weight: 600;
    display: flex;
    align-items: center;
    justify-content: center;
    word-break: break-all;
    transition: all var(--transition-fast);
}

.service-card-footer .btn-outline:hover {
    background-color: var(--color-primary);
    border-color: var(--color-primary);
    color: #ffffff;
    box-shadow: 0 4px 12px rgba(22, 59, 231, 0.2);
}

/* Split Booking Section */
.booking-split-section {
    display: grid;
    grid-template-columns: 1fr;
    gap: 4rem;
    margin-top: 6rem;
    border-top: 1px solid var(--color-border);
    padding-top: 5rem;
}

@media (min-width: 992px) {
    .booking-split-section {
        grid-template-columns: 1.1fr 1fr;
    }
}

.booking-info-panel {
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
}

.panel-tag {
    font-size: 0.85rem;
    font-weight: 700;
    color: var(--color-primary);
    text-transform: uppercase;
    letter-spacing: 0.1em;
    margin-bottom: 0.5rem;
}

.booking-info-panel h2 {
    font-size: 2.25rem;
    font-weight: 800;
    color: var(--color-text-dark);
    margin-bottom: 1.5rem;
    line-height: 1.2;
}

.booking-info-panel > p {
    font-size: 1.05rem;
    color: var(--color-text-main);
    line-height: 1.6;
    margin-bottom: 2.5rem;
}

.booking-info-highlights {
    display: flex;
    flex-direction: column;
    gap: 2rem;
    margin-bottom: 2.5rem;
}

.highlight-item {
    display: flex;
    gap: 1.25rem;
    align-items: flex-start;
}

.highlight-icon {
    flex-shrink: 0;
    width: 44px;
    height: 44px;
    border-radius: 50%;
    background-color: rgba(22, 59, 231, 0.05);
    color: var(--color-primary);
    display: flex;
    align-items: center;
    justify-content: center;
}

.highlight-item h4 {
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--color-text-dark);
    margin-bottom: 0.35rem;
}

.highlight-item p {
    font-size: 0.925rem;
    color: var(--color-text-muted);
    line-height: 1.5;
}

.booking-info-note {
    background-color: var(--color-bg-accent);
    border-left: 3px solid var(--color-primary);
    padding: 1.25rem;
    border-radius: 0 8px 8px 0;
    font-size: 0.875rem;
    color: var(--color-text-main);
    line-height: 1.5;
}

.booking-form-panel {
    background-color: var(--color-bg-card);
    border: 1px solid var(--color-border);
    border-radius: 16px;
    padding: 3rem 2.5rem;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.03);
}

.booking-form-panel h3 {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--color-text-dark);
    margin-bottom: 2rem;
    border-bottom: 2px solid var(--color-primary);
    padding-bottom: 0.5rem;
    display: inline-block;
}

/* ==========================================
   Contact Page Styles (Premium Revamp)
   ========================================== */
.contact-main-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 4rem;
    align-items: start;
    margin-bottom: 5rem;
}

@media (min-width: 992px) {
    .contact-main-grid {
        grid-template-columns: 1.1fr 1fr;
    }
}

.contact-intro-block {
    margin-bottom: 2rem;
}

.contact-tag {
    font-size: 0.85rem;
    font-weight: 700;
    color: var(--color-primary);
    text-transform: uppercase;
    letter-spacing: 0.1em;
    margin-bottom: 0.5rem;
    display: inline-block;
}

.contact-intro-block h2 {
    font-size: 2.5rem;
    font-weight: 800;
    color: var(--color-text-dark);
    margin-bottom: 1rem;
    line-height: 1.2;
}

.contact-intro-block p {
    font-size: 1.05rem;
    color: var(--color-text-muted);
    line-height: 1.6;
}

.working-hours-card-v2 {
    background-color: var(--color-bg-card);
    border: 1px solid var(--color-border);
    border-radius: 16px;
    padding: 2rem;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.01);
    display: flex;
    gap: 1.25rem;
    align-items: flex-start;
    margin-bottom: 2rem;
}

.hours-icon-box {
    width: 44px;
    height: 44px;
    background-color: rgba(22, 59, 231, 0.05);
    color: var(--color-primary);
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.hours-details {
    flex-grow: 1;
}

.hours-details h3 {
    font-size: 1.2rem;
    font-weight: 700;
    color: var(--color-text-dark);
    margin-bottom: 0.75rem;
}

.hours-details ul {
    list-style: none;
}

.hours-details li {
    font-size: 0.925rem;
    display: flex;
    justify-content: space-between;
    padding-bottom: 0.5rem;
    border-bottom: 1px solid rgba(0, 0, 0, 0.03);
    margin-bottom: 0.5rem;
}

.hours-details li:last-child {
    border-bottom: none;
    margin-bottom: 0;
    padding-bottom: 0;
}

.holiday-note {
    color: #f2994a;
}

/* Quick Info Card */
.contact-quick-info-card {
    background-color: var(--color-bg-card);
    border: 1px solid var(--color-border);
    border-radius: 16px;
    padding: 2rem;
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.01);
}

.info-row {
    display: flex;
    align-items: center;
    gap: 1.25rem;
}

.info-icon {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background-color: rgba(22, 59, 231, 0.05);
    color: var(--color-primary);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.info-text h4 {
    font-size: 0.85rem;
    font-weight: 700;
    color: var(--color-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-bottom: 0.15rem;
}

.info-text a {
    font-size: 0.95rem;
    color: var(--color-primary);
    font-weight: 600;
}

.info-text a:hover {
    color: var(--color-primary-hover);
    text-decoration: underline;
}

.contact-form-card {
    background-color: var(--color-bg-card);
    border: 1px solid var(--color-border);
    border-radius: 16px;
    padding: 3rem 2.5rem;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.03);
}

.contact-form-card h3 {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--color-text-dark);
    margin-bottom: 2rem;
    border-bottom: 2px solid var(--color-primary);
    padding-bottom: 0.5rem;
    display: inline-block;
}

/* Bottom Directory Section */
.departments-directory-section {
    margin-top: 6rem;
    border-top: 1px solid var(--color-border);
    padding-top: 5rem;
}

.directory-section-header {
    max-width: 800px;
    margin: 0 auto 4rem auto;
    text-align: center;
}

.directory-tagline {
    display: inline-block;
    font-size: 0.85rem;
    font-weight: 700;
    color: var(--color-primary);
    text-transform: uppercase;
    letter-spacing: 0.15em;
    margin-bottom: 0.75rem;
}

.directory-section-header h2 {
    font-size: 2.25rem;
    font-weight: 800;
    color: var(--color-text-dark);
    margin-bottom: 1rem;
}

.directory-section-header p {
    font-size: 1.05rem;
    color: var(--color-text-muted);
    line-height: 1.6;
}

.departments-directory-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.5rem;
}

@media (min-width: 576px) {
    .departments-directory-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 992px) {
    .departments-directory-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

@media (min-width: 1200px) {
    .departments-directory-grid {
        grid-template-columns: repeat(4, 1fr);
    }
}

.directory-card-v3 {
    background-color: var(--color-bg-card);
    border: 1px solid var(--color-border);
    border-radius: 12px;
    padding: 2rem 1.5rem;
    text-align: center;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.01);
    transition: transform var(--transition-normal), border-color var(--transition-normal), box-shadow var(--transition-normal);
}

.directory-card-v3:hover {
    transform: translateY(-5px);
    border-color: rgba(22, 59, 231, 0.2);
    box-shadow: 0 8px 25px rgba(22, 59, 231, 0.06);
}

.dir-icon-v3 {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    background-color: rgba(22, 59, 231, 0.05);
    color: var(--color-primary);
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 1.25rem auto;
}

.directory-card-v3 h4 {
    font-size: 0.95rem;
    font-weight: 700;
    color: var(--color-text-dark);
    margin-bottom: 0.5rem;
}

.directory-card-v3 a {
    font-size: 0.8rem;
    color: var(--color-primary);
    font-weight: 600;
    word-break: break-all;
}

.directory-card-v3 a:hover {
    color: var(--color-primary-hover);
    text-decoration: underline;
}

/* Notice Card */
.directory-notice-card {
    background-color: rgba(22, 59, 231, 0.02);
    border-left: 3px solid var(--color-primary);
    border-radius: 0 12px 12px 0;
    padding: 2rem;
    margin-top: 3.5rem;
    display: flex;
    gap: 1.5rem;
    align-items: flex-start;
}

.notice-icon {
    width: 40px;
    height: 40px;
    background-color: rgba(22, 59, 231, 0.05);
    color: var(--color-primary);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.notice-text {
    flex-grow: 1;
}

.notice-text p {
    font-size: 0.875rem;
    color: var(--color-text-muted);
    line-height: 1.6;
    margin-bottom: 0.5rem;
}

.notice-text p:last-child {
    margin-bottom: 0;
}

.notice-text strong {
    color: var(--color-text-dark);
}


/* ==========================================
   Account Page Styles (Premium Redesign)
   ========================================== */
.account-card-centered {
    background-color: var(--color-bg-card);
    border: 1px solid var(--color-border);
    border-radius: 16px;
    max-width: 500px;
    margin: 0 auto;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.04);
    overflow: hidden;
}

.account-tabs-header {
    display: grid;
    grid-template-columns: 1fr 1fr;
    background-color: var(--color-bg-accent);
    border-bottom: 1px solid var(--color-border);
}

.account-tab-btn {
    background: transparent;
    border: none;
    padding: 1.25rem 1rem;
    font-size: 0.95rem;
    font-weight: 700;
    color: var(--color-text-muted);
    cursor: pointer;
    text-align: center;
    transition: all var(--transition-fast);
    position: relative;
    outline: none;
}

.account-tab-btn::after {
    content: "";
    position: absolute;
    bottom: -1px;
    left: 0;
    right: 0;
    height: 3px;
    background-color: transparent;
    transition: background-color var(--transition-fast);
}

.account-tab-btn.active {
    color: var(--color-primary);
    background-color: var(--color-bg-card);
}

.account-tab-btn.active::after {
    background-color: var(--color-primary);
}

.account-tabs-content {
    padding: 3rem 2.5rem;
}

.panel-intro {
    text-align: center;
    margin-bottom: 2rem;
}

.panel-intro h3 {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--color-text-dark);
    margin-bottom: 0.5rem;
}

.panel-intro p {
    font-size: 0.9rem;
    color: var(--color-text-muted);
    line-height: 1.5;
}

.form-password-group {
    display: flex;
    flex-direction: column;
}

.password-input-wrapper {
    position: relative;
    width: 100%;
}

.password-input-wrapper input {
    width: 100% !important;
    padding-right: 3rem !important;
}

.password-toggle-btn {
    position: absolute;
    right: 0.75rem;
    top: 50%;
    transform: translateY(-50%);
    background: transparent;
    border: none;
    color: var(--color-text-muted);
    cursor: pointer;
    padding: 0.5rem;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: color var(--transition-fast);
    outline: none;
}

.password-toggle-btn:hover {
    color: var(--color-primary);
}

.form-flex-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: -0.5rem;
    margin-bottom: 1.5rem;
}

.form-flex-row .form-group-checkbox {
    margin: 0;
}

.forgot-link-wrapper .forgot-link {
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--color-primary);
}

.forgot-link-wrapper .forgot-link:hover {
    color: var(--color-primary-hover);
    text-decoration: underline;
}

/* ==========================================
   Validation Error Feedbacks (:user-invalid)
   ========================================== */
.error-msg {
    display: none;
    font-size: 0.8rem;
    font-weight: 600;
    color: #eb5757;
    margin-top: 0.35rem;
    align-items: center;
    gap: 0.25rem;
}

/* Inputs visual validation using user interaction state */
.appointment-form input:user-invalid,
.appointment-form select:user-invalid,
.appointment-form textarea:user-invalid,
.appointment-form input.touched-invalid,
.appointment-form select.touched-invalid,
.appointment-form textarea.touched-invalid {
    border-color: #eb5757 !important;
    background-color: rgba(235, 87, 87, 0.02) !important;
}

/* Show error feedback matching user action */
.appointment-form input:user-invalid + .error-msg,
.appointment-form select:user-invalid + .error-msg,
.appointment-form textarea:user-invalid + .error-msg,
.appointment-form input.touched-invalid + .error-msg,
.appointment-form select.touched-invalid + .error-msg,
.appointment-form textarea.touched-invalid + .error-msg {
    display: flex !important;
}

/* Success visual feedback on correctly filled interactive values */
.appointment-form input:required:user-valid,
.appointment-form select:required:user-valid,
.appointment-form textarea:required:user-valid {
    border-color: #27ae60 !important;
    background-color: rgba(39, 174, 96, 0.01) !important;
}

/* ==========================================
   Generic Form Controls (Modern & Premium)
   ========================================== */
.appointment-form {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

.form-grid-2 {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.5rem;
}

@media (min-width: 768px) {
    .form-grid-2 {
        grid-template-columns: 1fr 1fr;
    }
}

.form-group {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.form-group label {
    font-size: 0.875rem;
    font-weight: 700;
    color: var(--color-text-dark);
    margin-bottom: 0.15rem;
    transition: color var(--transition-fast);
}

.form-group input,
.form-group select,
.form-group textarea {
    padding: 0.85rem 1.25rem;
    border: 1px solid rgba(15, 44, 89, 0.15);
    border-radius: 10px;
    font-family: var(--font-body);
    font-size: 0.95rem;
    background-color: #f8fafc;
    color: var(--color-text-main);
    transition: border-color var(--transition-fast), background-color var(--transition-fast), box-shadow var(--transition-fast);
    outline: none;
    min-height: 48px;
    box-sizing: border-box;
    width: 100%;
}

.form-group input::placeholder,
.form-group textarea::placeholder {
    color: var(--color-text-muted);
    opacity: 0.6;
}

.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
    border-color: var(--color-primary);
    background-color: #ffffff;
    box-shadow: 0 0 0 4px rgba(22, 59, 231, 0.08);
}

/* Style parent labels when input is focused or invalid using :has() if supported */
.form-group:has(input:focus) label,
.form-group:has(select:focus) label,
.form-group:has(textarea:focus) label {
    color: var(--color-primary);
}

/* Select specific customization */
.form-group select {
    appearance: none;
    background-image: url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%234f5e71' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");
    background-repeat: no-repeat;
    background-position: right 1.25rem center;
    background-size: 1.2rem;
    padding-right: 3rem;
    cursor: pointer;
}

/* Textarea specific */
.form-group textarea {
    min-height: 120px;
    resize: vertical;
    padding-top: 1rem;
    padding-bottom: 1rem;
}

.btn-full {
    width: 100%;
}

.form-group-checkbox {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    cursor: pointer;
}

.form-group-checkbox input[type="checkbox"] {
    width: 18px;
    height: 18px;
    border-radius: 4px;
    border: 1px solid rgba(15, 44, 89, 0.2);
    accent-color: var(--color-primary);
    cursor: pointer;
    min-height: auto;
}

.form-group-checkbox label {
    font-size: 0.9rem;
    color: var(--color-text-muted);
    font-weight: 500;
    margin: 0;
}

/* ==========================================================================
   Gutenberg & Spectra Grid Layout Overrides
   ========================================================================== */

/* 1. Global resets for Gutenberg layout constraint issues */
.wp-block-group.category-hero-grid,
.wp-block-group.shop-badges-bar,
.wp-block-group.product-group-grid,
.wp-block-group.popular-products-grid,
.wp-block-group.services-card-grid,
.wp-block-group.departments-directory-grid,
.wp-block-group.booking-split-section,
.wp-block-group.contact-main-grid,
.wp-block-group.services-intro-section,
.wp-block-group.departments-directory-section,
.wp-block-group.shop-group-section,
.wp-block-group.shop-cta-section,
.wp-block-group.account-page-wrapper {
    max-width: none !important;
    width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
}

/* Reset inner containers if they exist */
.wp-block-group.category-hero-grid > .wp-block-group__inner-container,
.wp-block-group.shop-badges-bar > .wp-block-group__inner-container,
.wp-block-group.product-group-grid > .wp-block-group__inner-container,
.wp-block-group.popular-products-grid > .wp-block-group__inner-container,
.wp-block-group.services-card-grid > .wp-block-group__inner-container,
.wp-block-group.departments-directory-grid > .wp-block-group__inner-container,
.wp-block-group.booking-split-section > .wp-block-group__inner-container,
.wp-block-group.contact-main-grid > .wp-block-group__inner-container,
.wp-block-group.services-intro-section > .wp-block-group__inner-container,
.wp-block-group.departments-directory-section > .wp-block-group__inner-container,
.wp-block-group.shop-group-section > .wp-block-group__inner-container,
.wp-block-group.shop-cta-section > .wp-block-group__inner-container,
.wp-block-group.account-page-wrapper > .wp-block-group__inner-container {
    max-width: none !important;
    width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
}

/* 2. Reset constraint properties on all child cards and items in our custom elements */
.category-hero-grid .category-card,
.shop-badges-bar .badge-item,
.product-group-grid .product-group-card,
.popular-products-grid .product-item-card,
.services-card-grid .service-grid-card,
.departments-directory-grid .directory-card-v3,
.booking-split-section .booking-info-panel,
.booking-split-section .booking-form-panel,
.contact-main-grid .contact-info-column,
.contact-main-grid .contact-form-column {
    max-width: none !important;
    width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
}

/* 3. Outer block groups containing an inner container become display: block to prevent nested grid containment */
.wp-block-group.category-hero-grid:has(> .wp-block-group__inner-container),
.wp-block-group.shop-badges-bar:has(> .wp-block-group__inner-container),
.wp-block-group.product-group-grid:has(> .wp-block-group__inner-container),
.wp-block-group.popular-products-grid:has(> .wp-block-group__inner-container),
.wp-block-group.services-card-grid:has(> .wp-block-group__inner-container),
.wp-block-group.departments-directory-grid:has(> .wp-block-group__inner-container),
.wp-block-group.booking-split-section:has(> .wp-block-group__inner-container),
.wp-block-group.contact-main-grid:has(> .wp-block-group__inner-container) {
    display: block !important;
}

/* 4. Re-enforce Grid Layouts */
.category-hero-grid:not(:has(> .wp-block-group__inner-container)),
.wp-block-group.category-hero-grid > .wp-block-group__inner-container {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 1.5rem !important;
    margin-bottom: 3rem !important;
}
@media (min-width: 768px) {
    .category-hero-grid:not(:has(> .wp-block-group__inner-container)),
    .wp-block-group.category-hero-grid > .wp-block-group__inner-container {
        grid-template-columns: repeat(3, 1fr) !important;
    }
}

.shop-badges-bar:not(:has(> .wp-block-group__inner-container)),
.wp-block-group.shop-badges-bar > .wp-block-group__inner-container {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 1.5rem !important;
    padding: 2rem !important;
    background-color: var(--color-bg-accent) !important;
    border-radius: var(--radius-md) !important;
    margin-bottom: 4rem !important;
    border: 1px solid var(--color-border) !important;
}
@media (min-width: 576px) {
    .shop-badges-bar:not(:has(> .wp-block-group__inner-container)),
    .wp-block-group.shop-badges-bar > .wp-block-group__inner-container {
        grid-template-columns: repeat(2, 1fr) !important;
    }
}
@media (min-width: 992px) {
    .shop-badges-bar:not(:has(> .wp-block-group__inner-container)),
    .wp-block-group.shop-badges-bar > .wp-block-group__inner-container {
        grid-template-columns: repeat(5, 1fr) !important;
    }
}

.product-group-grid:not(:has(> .wp-block-group__inner-container)),
.wp-block-group.product-group-grid > .wp-block-group__inner-container {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 1.5rem !important;
}
@media (min-width: 576px) {
    .product-group-grid:not(:has(> .wp-block-group__inner-container)),
    .wp-block-group.product-group-grid > .wp-block-group__inner-container {
        grid-template-columns: repeat(2, 1fr) !important;
    }
}
@media (min-width: 992px) {
    .product-group-grid:not(:has(> .wp-block-group__inner-container)),
    .wp-block-group.product-group-grid > .wp-block-group__inner-container {
        grid-template-columns: repeat(4, 1fr) !important;
    }
}

.popular-products-grid:not(:has(> .wp-block-group__inner-container)),
.wp-block-group.popular-products-grid > .wp-block-group__inner-container {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 1.5rem !important;
}
@media (min-width: 576px) {
    .popular-products-grid:not(:has(> .wp-block-group__inner-container)),
    .wp-block-group.popular-products-grid > .wp-block-group__inner-container {
        grid-template-columns: repeat(2, 1fr) !important;
    }
}
@media (min-width: 992px) {
    .popular-products-grid:not(:has(> .wp-block-group__inner-container)),
    .wp-block-group.popular-products-grid > .wp-block-group__inner-container {
        grid-template-columns: repeat(4, 1fr) !important;
    }
}
@media (min-width: 1200px) {
    .popular-products-grid:not(:has(> .wp-block-group__inner-container)),
    .wp-block-group.popular-products-grid > .wp-block-group__inner-container {
        grid-template-columns: repeat(5, 1fr) !important;
    }
}

.services-card-grid:not(:has(> .wp-block-group__inner-container)),
.wp-block-group.services-card-grid > .wp-block-group__inner-container {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 2.5rem !important;
    margin-bottom: 6rem !important;
}
@media (min-width: 768px) {
    .services-card-grid:not(:has(> .wp-block-group__inner-container)),
    .wp-block-group.services-card-grid > .wp-block-group__inner-container {
        grid-template-columns: repeat(2, 1fr) !important;
    }
}
@media (min-width: 1200px) {
    .services-card-grid:not(:has(> .wp-block-group__inner-container)),
    .wp-block-group.services-card-grid > .wp-block-group__inner-container {
        grid-template-columns: repeat(3, 1fr) !important;
    }
}

.departments-directory-grid:not(:has(> .wp-block-group__inner-container)),
.wp-block-group.departments-directory-grid > .wp-block-group__inner-container {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 1.5rem !important;
    margin-top: 3rem !important;
    margin-bottom: 4rem !important;
}
@media (min-width: 576px) {
    .departments-directory-grid:not(:has(> .wp-block-group__inner-container)),
    .wp-block-group.departments-directory-grid > .wp-block-group__inner-container {
        grid-template-columns: repeat(2, 1fr) !important;
    }
}
@media (min-width: 992px) {
    .departments-directory-grid:not(:has(> .wp-block-group__inner-container)),
    .wp-block-group.departments-directory-grid > .wp-block-group__inner-container {
        grid-template-columns: repeat(4, 1fr) !important;
    }
}

.booking-split-section:not(:has(> .wp-block-group__inner-container)),
.wp-block-group.booking-split-section > .wp-block-group__inner-container {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 3rem !important;
    background-color: var(--color-bg-accent) !important;
    border-radius: 24px !important;
    padding: 2.5rem !important;
    align-items: center !important;
}
@media (min-width: 992px) {
    .booking-split-section:not(:has(> .wp-block-group__inner-container)),
    .wp-block-group.booking-split-section > .wp-block-group__inner-container {
        grid-template-columns: 1.1fr 0.9fr !important;
        padding: 4.5rem !important;
    }
}

.contact-main-grid:not(:has(> .wp-block-group__inner-container)),
.wp-block-group.contact-main-grid > .wp-block-group__inner-container {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 3rem !important;
    margin-bottom: 6rem !important;
    align-items: stretch !important;
}
@media (min-width: 992px) {
    .contact-main-grid:not(:has(> .wp-block-group__inner-container)),
    .wp-block-group.contact-main-grid > .wp-block-group__inner-container {
        grid-template-columns: 1fr 1fr !important;
    }
}

/* ============================================================================
   WooCommerce Core Styling Overrides & Custom Favorites
   ============================================================================ */

/* 1. Global & Message Notices */
.woocommerce-message, 
.woocommerce-info, 
.woocommerce-error,
.woocommerce-notice {
    background-color: var(--color-bg-card) !important;
    border: 1px solid var(--color-border) !important;
    border-left: 4px solid var(--color-primary) !important;
    border-top: none !important;
    border-radius: var(--radius-md) !important;
    padding: 1.25rem 1.5rem 1.25rem 3.5rem !important;
    margin-bottom: 2rem !important;
    box-shadow: var(--shadow-md) !important;
    font-family: var(--font-body);
    font-size: 0.95rem;
    color: var(--color-text-main);
    position: relative;
}

.woocommerce-message {
    background-color: #f0fdf4 !important;
    border-color: #bbf7d0 !important;
    border-left-color: #10b981 !important;
    color: #166534 !important;
}

.woocommerce-info,
.woocommerce-notice {
    background-color: #eff6ff !important;
    border-color: #dbeafe !important;
    border-left-color: #163be7 !important;
    color: #1e40af !important;
}

.woocommerce-error {
    background-color: #fef2f2 !important;
    border-color: #fee2e2 !important;
    border-left-color: #ef4444 !important;
    color: #991b1b !important;
}

.woocommerce-message::before,
.woocommerce-info::before,
.woocommerce-notice::before,
.woocommerce-error::before {
    content: "" !important;
    position: absolute !important;
    left: 1.25rem !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    width: 20px !important;
    height: 20px !important;
    background-repeat: no-repeat !important;
    background-position: center !important;
    background-size: contain !important;
}

.woocommerce-message::before {
    background-image: url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2310b981' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3e%3cpath d='M22 11.08V12a10 10 0 1 1-5.93-9.14'%3e%3c/path%3e%3cpolyline points='22 4 12 14.01 9 11.01'%3e%3c/polyline%3e%3c/svg%3e") !important;
}

.woocommerce-info::before,
.woocommerce-notice::before {
    background-image: url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23163be7' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3e%3ccircle cx='12' cy='12' r='10'%3e%3c/circle%3e%3cline x1='12' y1='16' x2='12' y2='12'%3e%3c/line%3e%3cline x1='12' y1='8' x2='12.01' y2='8'%3e%3c/line%3e%3c/svg%3e") !important;
}

.woocommerce-error::before {
    background-image: url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23ef4444' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3e%3ccircle cx='12' cy='12' r='10'%3e%3c/circle%3e%3cline x1='12' y1='8' x2='12' y2='12'%3e%3c/line%3e%3cline x1='12' y1='16' x2='12.01' y2='16'%3e%3c/line%3e%3c/svg%3e") !important;
}

.woocommerce-message .button,
.woocommerce-info .button {
    background-color: var(--color-primary) !important;
    color: #ffffff !important;
    border-radius: var(--radius-sm) !important;
    padding: 0.5rem 1rem !important;
    font-size: 0.85rem !important;
    font-weight: 600 !important;
    float: right;
    margin-top: -3px;
    transition: var(--transition-fast) !important;
    border: none !important;
}

.woocommerce-message .button:hover,
.woocommerce-info .button:hover {
    background-color: var(--color-primary-hover) !important;
}

/* Forms & Inputs styling */
.woocommerce form .form-row {
    margin-bottom: 1.25rem !important;
}

.woocommerce form .form-row label {
    display: block;
    font-weight: 600;
    margin-bottom: 0.5rem;
    font-size: 0.9rem;
    color: var(--color-text-dark);
}

.woocommerce form .form-row input.input-text,
.woocommerce form .form-row select,
.woocommerce form .form-row textarea {
    width: 100% !important;
    padding: 0.85rem 1.25rem !important;
    border: 1px solid var(--color-border) !important;
    border-radius: var(--radius-md) !important;
    font-family: var(--font-body) !important;
    font-size: 0.95rem !important;
    background-color: var(--color-bg-base) !important;
    color: var(--color-text-main) !important;
    transition: all var(--transition-fast) !important;
    box-shadow: var(--shadow-sm) !important;
}

.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row select:focus,
.woocommerce form .form-row textarea:focus {
    border-color: var(--color-primary) !important;
    outline: none !important;
    box-shadow: 0 0 0 4px var(--color-primary-glow) !important;
    background-color: #ffffff !important;
}

/* WooCommerce Password Field & Eye icon styling */
.woocommerce form .form-row-wide {
    position: relative !important;
}

.woocommerce form .form-row .show-password-input {
    position: absolute !important;
    right: 16px !important;
    bottom: 14px !important;
    cursor: pointer !important;
    font-size: 0.85rem !important;
    color: var(--color-text-muted) !important;
    text-decoration: none !important;
    font-weight: 600 !important;
    z-index: 5 !important;
}

.woocommerce form .form-row .show-password-input:hover {
    color: var(--color-primary) !important;
}

/* 2. My Account Login/Register Forms */
.woocommerce-account .woocommerce {
    max-width: 1200px;
    margin: 0 auto;
}

.woocommerce-account .woocommerce-MyAccount-content {
    background-color: var(--color-bg-card);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: 2.5rem;
    box-shadow: var(--shadow-sm);
    width: 100%;
}

@media (min-width: 768px) {
    .woocommerce-account .woocommerce-MyAccount-navigation {
        float: left;
        width: 25%;
    }
    .woocommerce-account .woocommerce-MyAccount-content {
        float: right;
        width: 70%;
    }
}

.woocommerce-MyAccount-navigation ul {
    list-style: none;
    padding: 0;
    margin: 0 1.5rem 0 0;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.woocommerce-MyAccount-navigation ul li {
    margin: 0;
}

.woocommerce-MyAccount-navigation ul li a {
    display: block;
    padding: 0.85rem 1.25rem;
    color: var(--color-text-muted);
    font-weight: 600;
    border-radius: var(--radius-md);
    transition: var(--transition-fast);
    border: 1px solid transparent;
}

.woocommerce-MyAccount-navigation ul li a:hover {
    background-color: var(--color-primary-light);
    color: var(--color-primary);
}

.woocommerce-MyAccount-navigation ul li.is-active a {
    background-color: var(--color-primary);
    color: #ffffff;
    border-color: var(--color-primary);
}

/* Login/Registration layout (logged out) */
.woocommerce-account .woocommerce .u-columns.col2-set {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 3rem !important;
    margin-top: 2rem !important;
    max-width: 1000px !important;
    margin-left: auto !important;
    margin-right: auto !important;
    float: none !important;
}

@media (min-width: 768px) {
    .woocommerce-account .woocommerce .u-columns.col2-set {
        grid-template-columns: 1fr 1fr !important;
    }
    /* If registration is disabled, center the single login form */
    .woocommerce-account .woocommerce .u-columns.col2-set:not(:has(.col-2)) {
        grid-template-columns: 1fr !important;
        max-width: 500px !important;
    }
}

.woocommerce-account .woocommerce .col2-set .col-1, 
.woocommerce-account .woocommerce .col2-set .col-2 {
    background-color: var(--color-bg-card) !important;
    border: 1px solid var(--color-border) !important;
    border-radius: var(--radius-lg) !important;
    padding: 2.5rem !important;
    box-shadow: var(--shadow-md) !important;
    transition: var(--transition-normal) !important;
    width: 100% !important;
    float: none !important;
    margin: 0 !important;
}

.woocommerce-account .woocommerce .col2-set .col-1:hover, 
.woocommerce-account .woocommerce .col2-set .col-2:hover {
    border-color: rgba(22, 59, 231, 0.2) !important;
    box-shadow: var(--shadow-lg) !important;
}

.woocommerce-account .woocommerce .col2-set h2 {
    font-size: 1.6rem !important;
    margin-bottom: 1.5rem !important;
    border-bottom: 2px solid var(--color-primary-light) !important;
    padding-bottom: 0.75rem !important;
    font-weight: 700 !important;
    font-family: var(--font-heading) !important;
    color: var(--color-text-dark) !important;
}

.woocommerce-Button, 
.woocommerce-form-login__submit,
.woocommerce-form-register__submit {
    background-color: var(--color-primary) !important;
    color: #ffffff !important;
    border-radius: var(--radius-sm) !important;
    font-weight: 700 !important;
    padding: 0.75rem 1.5rem !important;
    font-size: 0.95rem !important;
    border: none !important;
    cursor: pointer;
    transition: var(--transition-fast) !important;
    width: 100%;
}

.woocommerce-Button:hover,
.woocommerce-form-login__submit:hover,
.woocommerce-form-register__submit:hover {
    background-color: var(--color-primary-hover) !important;
}

/* 3. Cart & Checkout Pages */
.woocommerce-cart .page-content-inner,
.woocommerce-checkout .page-content-inner {
    max-width: var(--container-max) !important;
    width: 100% !important;
}

.woocommerce-cart .woocommerce,
.woocommerce-checkout .woocommerce {
    max-width: 100% !important;
    margin: 0 auto !important;
}

/* Fix grid flow when notices or empty messages are shown */
.woocommerce-cart .woocommerce .woocommerce-notices-wrapper,
.woocommerce-cart .woocommerce .wc-empty-cart-message,
.woocommerce-cart .woocommerce .return-to-shop {
    grid-column: 1 / -1 !important;
}

@media (min-width: 992px) {
    .woocommerce-cart .woocommerce {
        display: grid !important;
        grid-template-columns: 1.6fr 0.9fr !important;
        gap: 2.5rem !important;
        align-items: flex-start !important;
    }
    .woocommerce-cart .woocommerce-cart-form {
        margin-bottom: 0 !important;
    }
    .woocommerce-cart .cart-collaterals {
        position: sticky !important;
        top: 120px !important;
        width: 100% !important;
        display: block !important;
    }
    .woocommerce-cart .cart-collaterals .cart_totals {
        max-width: none !important;
        width: 100% !important;
    }
}

@media (max-width: 991px) {
    .woocommerce-cart .woocommerce-cart-form {
        margin-bottom: 2rem !important;
    }
    .woocommerce-cart .cart-collaterals {
        width: 100% !important;
    }
}

/* Form container & Layout */
.woocommerce-cart-form {
    background-color: var(--color-bg-card) !important;
    border: 1px solid var(--color-border) !important;
    border-radius: var(--radius-lg) !important;
    padding: 2.25rem !important;
    box-shadow: var(--shadow-md) !important;
    overflow-x: visible !important; /* No scrollbar on desktop to prevent column hiding */
}

@media (max-width: 991px) {
    .woocommerce-cart-form {
        padding: 1.5rem !important;
        overflow-x: auto !important; /* Enable scrollbar only on mobile/tablet */
    }
}

/* Force Table Cells & Alignment (Prevents Stacking/Squishing) */
.woocommerce-cart table.shop_table {
    display: table !important;
    border-collapse: separate !important;
    border-spacing: 0 !important;
    width: 100% !important;
    border: none !important;
    table-layout: auto !important;
}

.woocommerce-cart table.shop_table thead {
    display: table-header-group !important;
}

.woocommerce-cart table.shop_table tbody {
    display: table-row-group !important;
}

.woocommerce-cart table.shop_table tr {
    display: table-row !important;
}

.woocommerce-cart table.shop_table th,
.woocommerce-cart table.shop_table td {
    display: table-cell !important;
    vertical-align: middle !important;
    padding: 1.1rem 0.75rem !important;
    text-align: left !important;
}

/* Header Cells styling */
.woocommerce-cart table.shop_table th {
    background-color: var(--color-bg-accent) !important;
    border-bottom: 2px solid var(--color-border) !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    font-size: 0.8rem !important;
    letter-spacing: 0.05em !important;
    color: var(--color-text-dark) !important;
    font-family: var(--font-heading) !important;
}

.woocommerce-cart table.shop_table th:first-child {
    border-top-left-radius: var(--radius-md) !important;
}
.woocommerce-cart table.shop_table th:last-child {
    border-top-right-radius: var(--radius-md) !important;
}

/* Column Dimensions (Compact to fit without horizontal scrolling) */
.woocommerce-cart table.shop_table td.product-remove {
    width: 45px !important;
    min-width: 45px !important;
    text-align: center !important;
}

.woocommerce-cart table.shop_table td.product-thumbnail {
    width: 80px !important;
    min-width: 80px !important;
    text-align: center !important;
}

.woocommerce-cart table.shop_table td.product-name {
    width: auto !important;
    min-width: 150px !important;
}

.woocommerce-cart table.shop_table td.product-price {
    width: 105px !important;
    min-width: 105px !important;
}

.woocommerce-cart table.shop_table td.product-quantity {
    width: 85px !important;
    min-width: 85px !important;
}

.woocommerce-cart table.shop_table td.product-subtotal {
    width: 115px !important;
    min-width: 115px !important;
}

.woocommerce-cart table.shop_table td {
    border-bottom: 1px solid var(--color-border) !important;
    color: var(--color-text-main) !important;
}

.woocommerce-cart table.shop_table tr:last-child td {
    border-bottom: none !important;
}

/* Remove button */
.woocommerce-cart .product-remove a.remove {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 26px !important;
    height: 26px !important;
    border-radius: var(--radius-full) !important;
    color: #ef4444 !important;
    font-size: 1.1rem !important;
    background-color: rgba(239, 68, 68, 0.05) !important;
    transition: all var(--transition-fast) !important;
    text-decoration: none !important;
    line-height: 1 !important;
    margin: 0 auto !important;
}

.woocommerce-cart .product-remove a.remove:hover {
    background-color: #ef4444 !important;
    color: #ffffff !important;
}

/* Thumbnail image preview (max-width: none forces image to stay square) */
.woocommerce-cart .product-thumbnail img {
    width: 60px !important;
    height: 60px !important;
    min-width: 60px !important;
    min-height: 60px !important;
    max-width: none !important;
    object-fit: contain !important;
    background-color: #ffffff !important;
    border: 1px solid var(--color-border) !important;
    border-radius: var(--radius-md) !important;
    padding: 4px !important;
    display: inline-block !important;
    transition: transform var(--transition-fast) !important;
    box-shadow: var(--shadow-sm) !important;
}

.woocommerce-cart .product-thumbnail img:hover {
    transform: scale(1.08) !important;
}

/* Product Titles */
.woocommerce-cart .product-name a {
    font-weight: 700 !important;
    color: var(--color-text-dark) !important;
    font-size: 0.925rem !important;
    transition: var(--transition-fast) !important;
    text-decoration: none !important;
    line-height: 1.4 !important;
}

.woocommerce-cart .product-name a:hover {
    color: var(--color-primary) !important;
}

/* Pricing columns */
.woocommerce-cart .product-price,
.woocommerce-cart .product-subtotal {
    font-family: var(--font-heading) !important;
    font-size: 0.95rem !important;
    font-weight: 600 !important;
    color: var(--color-text-dark) !important;
}

.woocommerce-cart .product-subtotal {
    color: var(--color-primary) !important;
    font-weight: 700 !important;
}

/* Quantity selector input */
.woocommerce-cart .product-quantity input.qty {
    width: 55px !important;
    height: 36px !important;
    padding: 0.3rem !important;
    border: 1px solid var(--color-border) !important;
    border-radius: var(--radius-md) !important;
    text-align: center !important;
    font-family: var(--font-body) !important;
    font-weight: 600 !important;
    font-size: 0.9rem !important;
    box-shadow: var(--shadow-sm) !important;
    background-color: #ffffff !important;
    outline: none !important;
    transition: all var(--transition-fast) !important;
}

.woocommerce-cart .product-quantity input.qty:focus {
    border-color: var(--color-primary) !important;
    box-shadow: 0 0 0 3px var(--color-primary-glow) !important;
}

/* Actions Row (Coupon + Update) */
.woocommerce-cart table.shop_table td.actions {
    padding: 1.5rem 0 0 0 !important;
    border: none !important;
}

.woocommerce-cart table.shop_table td.actions .actions-wrapper {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    flex-wrap: wrap !important;
    gap: 1.25rem !important;
}

.woocommerce-cart .coupon {
    display: flex !important;
    align-items: center !important;
    gap: 0.75rem !important;
    flex-wrap: wrap !important;
}

.woocommerce-cart .coupon input#coupon_code {
    width: 140px !important;
    height: 40px !important;
    padding: 0 0.85rem !important;
    border: 1px solid var(--color-border) !important;
    border-radius: var(--radius-md) !important;
    font-size: 0.875rem !important;
    background-color: #ffffff !important;
    box-shadow: var(--shadow-sm) !important;
    transition: all var(--transition-fast) !important;
    outline: none !important;
}

.woocommerce-cart .coupon input#coupon_code:focus {
    border-color: var(--color-primary) !important;
    box-shadow: 0 0 0 3px var(--color-primary-glow) !important;
}

.woocommerce-cart .coupon button.button,
.woocommerce-cart button[name="update_cart"] {
    height: 40px !important;
    padding: 0 1.5rem !important;
    font-size: 0.85rem !important;
    font-weight: 700 !important;
    border-radius: var(--radius-md) !important;
    transition: all var(--transition-fast) !important;
    cursor: pointer !important;
    text-transform: uppercase !important;
    letter-spacing: 0.03em !important;
}

.woocommerce-cart .coupon button.button {
    background-color: var(--color-text-dark) !important;
    color: #ffffff !important;
    border: none !important;
    box-shadow: var(--shadow-sm) !important;
}

.woocommerce-cart .coupon button.button:hover {
    background-color: var(--color-primary) !important;
}

.woocommerce-cart button[name="update_cart"] {
    background-color: transparent !important;
    color: var(--color-primary) !important;
    border: 2px solid var(--color-primary) !important;
}

.woocommerce-cart button[name="update_cart"]:hover {
    background-color: var(--color-primary) !important;
    color: #ffffff !important;
}

/* Cart Totals Box */
.woocommerce-cart .cart-collaterals {
    display: flex;
    justify-content: flex-end;
}

.woocommerce-cart .cart-collaterals .cart_totals {
    width: 100%;
    background-color: var(--color-bg-card) !important;
    border: 1px solid var(--color-border) !important;
    border-radius: var(--radius-lg) !important;
    padding: 2.25rem !important;
    box-shadow: var(--shadow-md) !important;
}

.woocommerce-cart .cart_totals h2 {
    font-family: var(--font-heading) !important;
    font-size: 1.35rem !important;
    font-weight: 700 !important;
    color: var(--color-text-dark) !important;
    margin-bottom: 1.5rem !important;
    border-bottom: 2px solid var(--color-primary-light) !important;
    padding-bottom: 0.75rem !important;
    text-transform: capitalize !important;
}

.woocommerce-cart .cart_totals table.shop_table {
    width: 100% !important;
    margin-bottom: 1.5rem !important;
    border-collapse: collapse !important;
}

.woocommerce-cart .cart_totals table.shop_table tr th,
.woocommerce-cart .cart_totals table.shop_table tr td {
    padding: 1.1rem 0 !important;
    border-bottom: 1px solid var(--color-border) !important;
    background: transparent !important;
    font-size: 0.95rem !important;
}

.woocommerce-cart .cart_totals table.shop_table tr th {
    font-weight: 600 !important;
    color: var(--color-text-muted) !important;
    width: 35% !important;
    text-transform: none !important;
    letter-spacing: normal !important;
    font-family: var(--font-body) !important;
}

.woocommerce-cart .cart_totals table.shop_table tr td {
    text-align: right !important;
    color: var(--color-text-dark) !important;
}

.woocommerce-cart .cart_totals table.shop_table tr.order-total th {
    font-size: 1.1rem !important;
    font-weight: 700 !important;
    color: var(--color-text-dark) !important;
}

.woocommerce-cart .cart_totals table.shop_table tr.order-total td {
    font-size: 1.25rem !important;
    font-weight: 700 !important;
    color: var(--color-primary) !important;
    font-family: var(--font-heading) !important;
}

.woocommerce-cart .cart_totals .wc-proceed-to-checkout {
    margin-top: 1.5rem !important;
}

.woocommerce-cart .cart_totals .wc-proceed-to-checkout a.checkout-button {
    display: block !important;
    background-color: var(--color-primary) !important;
    color: #ffffff !important;
    text-align: center !important;
    padding: 1.1rem 1.5rem !important;
    border-radius: var(--radius-md) !important;
    font-weight: 700 !important;
    font-size: 1.05rem !important;
    text-transform: uppercase !important;
    letter-spacing: 0.05em !important;
    transition: all var(--transition-fast) !important;
    border: none !important;
    box-shadow: 0 4px 14px rgba(22, 59, 231, 0.25) !important;
}

.woocommerce-cart .cart_totals .wc-proceed-to-checkout a.checkout-button:hover {
    background-color: var(--color-primary-hover) !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 6px 20px rgba(22, 59, 231, 0.4) !important;
}

/* Redesigned Empty Cart Page */
.woocommerce-cart .cart-empty {
    text-align: center !important;
    padding: 5rem 2rem !important;
    background-color: var(--color-bg-card) !important;
    border: 1px dashed var(--color-border) !important;
    border-radius: var(--radius-lg) !important;
    box-shadow: var(--shadow-sm) !important;
    margin: 2rem 0 !important;
}

.woocommerce-cart .cart-empty::before {
    content: "🛒" !important;
    display: block !important;
    font-size: 4rem !important;
    margin-bottom: 1.5rem !important;
    opacity: 0.5 !important;
}

.woocommerce-cart p.cart-empty {
    font-size: 1.35rem !important;
    font-weight: 700 !important;
    color: var(--color-text-dark) !important;
    font-family: var(--font-heading) !important;
    border: none !important;
}

.woocommerce-cart .return-to-shop {
    text-align: center !important;
    margin-top: 1.5rem !important;
}

.woocommerce-cart .return-to-shop a.button {
    background-color: var(--color-primary) !important;
    color: #ffffff !important;
    padding: 0.85rem 2rem !important;
    font-weight: 700 !important;
    border-radius: var(--radius-sm) !important;
    font-size: 0.95rem !important;
    text-transform: uppercase !important;
    letter-spacing: 0.05em !important;
    transition: all var(--transition-fast) !important;
    display: inline-block !important;
}

.woocommerce-cart .return-to-shop a.button:hover {
    background-color: var(--color-primary-hover) !important;
    transform: translateY(-2px) !important;
    box-shadow: var(--shadow-glow) !important;
}

/* Checkout Page columns layout & styling */
.woocommerce-checkout #customer_details::before,
.woocommerce-checkout #customer_details::after,
.woocommerce-checkout .col2-set::before,
.woocommerce-checkout .col2-set::after {
    display: none !important;
}

/* Force Customer Details to be a single column stack of Billing + Additional details */
.woocommerce-checkout #customer_details {
    display: flex !important;
    flex-direction: column !important;
    gap: 2.5rem !important;
    width: 100% !important;
    float: none !important;
    margin-bottom: 0 !important;
}

.woocommerce-checkout #customer_details .col-1,
.woocommerce-checkout #customer_details .col-2,
.woocommerce-checkout .col2-set .col-1,
.woocommerce-checkout .col2-set .col-2 {
    width: 100% !important;
    max-width: 100% !important;
    float: none !important;
    display: block !important;
    background-color: var(--color-bg-card) !important;
    border: 1px solid var(--color-border) !important;
    border-radius: var(--radius-lg) !important;
    padding: 3rem !important;
    box-shadow: var(--shadow-md) !important;
}

/* Spacing and titles inside checkout cards */
.woocommerce-checkout h3 {
    font-family: var(--font-heading) !important;
    font-size: 1.4rem !important;
    font-weight: 800 !important;
    color: var(--color-text-dark) !important;
    margin-top: 0 !important;
    margin-bottom: 2rem !important;
    border-bottom: 2px solid var(--color-primary-light) !important;
    padding-bottom: 0.85rem !important;
    letter-spacing: -0.01em !important;
}

/* Form inputs visual styling */
.woocommerce-checkout form .form-row {
    margin-bottom: 1.5rem !important;
}

.woocommerce-checkout form .form-row label {
    font-weight: 600 !important;
    color: var(--color-text-dark) !important;
    font-size: 0.9rem !important;
    margin-bottom: 0.5rem !important;
    display: block !important;
}

.woocommerce-checkout form .form-row input[type="text"],
.woocommerce-checkout form .form-row input[type="email"],
.woocommerce-checkout form .form-row input[type="tel"],
.woocommerce-checkout form .form-row input[type="number"],
.woocommerce-checkout form .form-row select,
.woocommerce-checkout form .form-row textarea {
    width: 100% !important;
    height: 48px !important;
    padding: 0 1.25rem !important;
    border: 1px solid var(--color-border) !important;
    border-radius: var(--radius-md) !important;
    background-color: #ffffff !important; /* Force white inputs inside card */
    font-family: var(--font-body) !important;
    font-size: 0.95rem !important;
    color: var(--color-text-dark) !important;
    transition: all var(--transition-fast) !important;
    outline: none !important;
    box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.02) !important;
}

.woocommerce-checkout form .form-row textarea {
    height: 120px !important;
    padding: 0.85rem 1.25rem !important;
}

.woocommerce-checkout form .form-row input[type="text"]:focus,
.woocommerce-checkout form .form-row input[type="email"]:focus,
.woocommerce-checkout form .form-row input[type="tel"]:focus,
.woocommerce-checkout form .form-row input[type="number"]:focus,
.woocommerce-checkout form .form-row select:focus,
.woocommerce-checkout form .form-row textarea:focus {
    border-color: var(--color-primary) !important;
    background-color: #ffffff !important;
    box-shadow: 0 0 0 3px var(--color-primary-glow) !important;
}

/* Select element appearance reset for consistent dropdowns */
.woocommerce-checkout form .form-row select {
    appearance: none !important;
    background-image: url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23525252' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e") !important;
    background-repeat: no-repeat !important;
    background-position: right 1.25rem center !important;
    background-size: 16px !important;
    padding-right: 2.5rem !important;
}

/* Select2 Container Overrides for Checkout */
.woocommerce-checkout .select2-container--default .select2-selection--single {
    background-color: #ffffff !important;
    border: 1px solid var(--color-border) !important;
    border-radius: var(--radius-md) !important;
    height: 48px !important;
    padding-left: 0.75rem !important;
    display: flex !important;
    align-items: center !important;
    outline: none !important;
    box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.02) !important;
    transition: all var(--transition-fast) !important;
}

.woocommerce-checkout .select2-container--default .select2-selection--single .select2-selection__rendered {
    color: var(--color-text-dark) !important;
    font-size: 0.95rem !important;
    font-family: var(--font-body) !important;
    padding-left: 0.5rem !important;
}

.woocommerce-checkout .select2-container--default .select2-selection--single .select2-selection__arrow {
    height: 46px !important;
    right: 12px !important;
}

.woocommerce-checkout .select2-container--default .select2-selection--single:focus,
.woocommerce-checkout .select2-container--default.select2-container--focus .select2-selection--single {
    border-color: var(--color-primary) !important;
    box-shadow: 0 0 0 3px var(--color-primary-glow) !important;
}

/* Coupon info toggle customizations */
.woocommerce-info a.showcoupon,
.woocommerce-info a.showlogin {
    color: var(--color-primary) !important;
    font-weight: 600 !important;
    text-decoration: none !important;
    transition: color var(--transition-fast) !important;
}

.woocommerce-info a.showcoupon:hover,
.woocommerce-info a.showlogin:hover {
    color: var(--color-primary-hover) !important;
    text-decoration: underline !important;
}

/* Form checkout coupon popup box customization */
form.checkout_coupon {
    background-color: var(--color-bg-card) !important;
    border: 1px solid var(--color-border) !important;
    border-radius: var(--radius-md) !important;
    padding: 2rem !important;
    margin-bottom: 2rem !important;
    box-shadow: var(--shadow-sm) !important;
    display: flex !important;
    gap: 1rem !important;
    align-items: center !important;
    flex-wrap: wrap !important;
}

form.checkout_coupon p {
    margin: 0 !important;
}

form.checkout_coupon input.input-text {
    width: 250px !important;
    height: 48px !important;
    border: 1px solid var(--color-border) !important;
    border-radius: var(--radius-md) !important;
    padding: 0 1.25rem !important;
    outline: none !important;
}

form.checkout_coupon button.button {
    height: 48px !important;
    padding: 0 2rem !important;
    background-color: var(--color-primary) !important;
    color: #ffffff !important;
    border: none !important;
    border-radius: var(--radius-md) !important;
    font-weight: 700 !important;
    cursor: pointer !important;
    transition: all var(--transition-fast) !important;
}

form.checkout_coupon button.button:hover {
    background-color: var(--color-primary-hover) !important;
}

/* Two-column layout for Form + Review */
@media (min-width: 992px) {
    .woocommerce-checkout form.checkout {
        display: grid !important;
        grid-template-columns: 1.2fr 0.8fr !important;
        gap: 4rem !important;
        align-items: start !important;
    }
    
    .woocommerce-checkout #customer_details {
        grid-column: 1 !important;
        grid-row: 1 / span 10 !important;
    }
    
    .woocommerce-checkout #order_review_heading {
        grid-column: 2 !important;
        grid-row: 1 !important;
        margin-top: 0 !important;
        border-bottom: none !important;
        padding-bottom: 0 !important;
        margin-bottom: 1.5rem !important;
    }
    
    .woocommerce-checkout #order_review {
        grid-column: 2 !important;
        grid-row: 2 !important;
        position: sticky !important;
        top: 120px !important;
    }
}

.woocommerce-checkout #order_review {
    background-color: var(--color-bg-card) !important;
    border: 1px solid var(--color-border) !important;
    border-radius: var(--radius-lg) !important;
    padding: 2.5rem !important;
    box-shadow: var(--shadow-md) !important;
}

.woocommerce-checkout table.shop_table {
    width: 100% !important;
    border-collapse: collapse !important;
    margin-bottom: 2rem !important;
}

.woocommerce-checkout table.shop_table,
.woocommerce-checkout table.shop_table td,
.woocommerce-checkout table.shop_table th {
    border: none !important;
}

.woocommerce-checkout table.shop_table tbody tr td,
.woocommerce-checkout table.shop_table tfoot tr td,
.woocommerce-checkout table.shop_table tfoot tr th {
    border-bottom: 1px solid var(--color-border) !important;
    padding: 1.25rem 0 !important;
    background: transparent !important;
}

.woocommerce-checkout table.shop_table tfoot tr.order-total th,
.woocommerce-checkout table.shop_table tfoot tr.order-total td {
    border-bottom: none !important;
}

.woocommerce-checkout table.shop_table th {
    font-weight: 600 !important;
    color: var(--color-text-muted) !important;
    text-align: left !important;
    font-family: var(--font-body) !important;
    font-size: 0.95rem !important;
}

.woocommerce-checkout table.shop_table td {
    text-align: right !important;
    color: var(--color-text-dark) !important;
    font-size: 0.95rem !important;
}

/* Wrap product name to look cleaner */
.woocommerce-checkout table.shop_table td.product-name {
    text-align: left !important;
    font-weight: 600 !important;
    font-size: 0.925rem !important;
    line-height: 1.5 !important;
}

.woocommerce-checkout table.shop_table td.product-name .product-quantity {
    color: var(--color-text-muted) !important;
    font-weight: 500 !important;
}

.woocommerce-checkout table.shop_table tr.cart-subtotal th,
.woocommerce-checkout table.shop_table tr.order-total th {
    font-family: var(--font-body) !important;
    font-weight: 700 !important;
    color: var(--color-text-dark) !important;
}

.woocommerce-checkout table.shop_table tr.order-total td {
    font-size: 1.35rem !important;
    font-weight: 800 !important;
    color: var(--color-primary) !important;
    font-family: var(--font-heading) !important;
}

/* Payment Gateway Box styling */
.woocommerce-checkout #payment {
    background: transparent !important;
    border: none !important;
    padding: 0 !important;
}

.woocommerce-checkout #payment ul.payment_methods {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 0 2rem 0 !important;
    border-bottom: 1px solid var(--color-border) !important;
}

.woocommerce-checkout #payment ul.payment_methods li {
    margin-bottom: 1.25rem !important;
    font-size: 0.95rem !important;
    color: var(--color-text-muted) !important;
}

.woocommerce-checkout #payment ul.payment_methods li input[type="radio"] {
    margin-top: 2px !important;
    vertical-align: top !important;
}

.woocommerce-checkout #payment ul.payment_methods li label {
    font-weight: 700 !important;
    color: var(--color-text-dark) !important;
    margin-left: 0.65rem !important;
    cursor: pointer !important;
}

.woocommerce-checkout #payment div.payment_box {
    background-color: var(--color-bg-accent) !important;
    border: 1px solid var(--color-border) !important;
    border-radius: var(--radius-md) !important;
    padding: 1.25rem !important;
    font-size: 0.875rem !important;
    color: var(--color-text-muted) !important;
    line-height: 1.5 !important;
    margin: 0.75rem 0 1rem 0 !important;
    position: relative !important;
}

.woocommerce-checkout .woocommerce-privacy-policy-text {
    font-size: 0.875rem !important;
    line-height: 1.6 !important;
    color: var(--color-text-muted) !important;
    margin-bottom: 1.5rem !important;
}

.woocommerce-checkout .woocommerce-privacy-policy-text a {
    color: var(--color-primary) !important;
    text-decoration: none !important;
    font-weight: 600 !important;
}

.woocommerce-checkout .woocommerce-privacy-policy-text a:hover {
    text-decoration: underline !important;
}

.woocommerce-checkout #place_order {
    display: block !important;
    width: 100% !important;
    background: linear-gradient(135deg, var(--color-primary) 0%, #0c2bba 100%) !important;
    color: #ffffff !important;
    text-align: center !important;
    padding: 1.1rem 1.5rem !important;
    border-radius: var(--radius-md) !important;
    font-weight: 700 !important;
    font-size: 1.05rem !important;
    text-transform: uppercase !important;
    letter-spacing: 0.05em !important;
    transition: all var(--transition-fast) !important;
    border: none !important;
    box-shadow: 0 4px 14px rgba(22, 59, 231, 0.25) !important;
    cursor: pointer !important;
}

.woocommerce-checkout #place_order:hover {
    background: linear-gradient(135deg, #1c45ff 0%, var(--color-primary) 100%) !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 6px 20px rgba(22, 59, 231, 0.4) !important;
}

.woocommerce-checkout #place_order:active {
    transform: translateY(0) !important;
}


/* 4. WooCommerce Catalog Products Override */
ul.products {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 1.5rem !important;
    list-style: none !important;
    padding: 0 !important;
    margin: 2rem 0 !important;
}

ul.products::before,
ul.products::after {
    display: none !important;
}

@media (min-width: 576px) {
    ul.products {
        grid-template-columns: repeat(2, 1fr) !important;
    }
}

@media (min-width: 992px) {
    ul.products {
        grid-template-columns: repeat(4, 1fr) !important;
    }
}

ul.products li.product {
    width: 100% !important;
    float: none !important;
    background-color: var(--color-bg-card) !important;
    border: 1px solid var(--color-border) !important;
    border-radius: var(--radius-md) !important;
    overflow: hidden !important;
    transition: var(--transition-normal) !important;
    display: flex !important;
    flex-direction: column !important;
    margin: 0 !important;
    position: relative !important;
}

ul.products li.product:hover {
    transform: translateY(-5px) !important;
    box-shadow: var(--shadow-lg) !important;
    border-color: rgba(22, 59, 231, 0.25) !important;
}

ul.products li.product a.woocommerce-LoopProduct-link {
    display: flex !important;
    flex-direction: column !important;
    flex-grow: 1 !important;
    color: inherit !important;
    text-decoration: none !important;
}

ul.products li.product img {
    width: 100% !important;
    height: 180px !important;
    object-fit: contain !important;
    background-color: var(--color-bg-accent) !important;
    border-bottom: 1px solid var(--color-border) !important;
    border-radius: 0 !important;
}

ul.products li.product h2.woocommerce-loop-product__title {
    padding: 1.25rem 1.25rem 0.5rem 1.25rem !important;
    font-size: 0.95rem !important;
    font-weight: 600 !important;
    color: var(--color-text-dark) !important;
    margin: 0 !important;
    line-height: 1.4 !important;
}

ul.products li.product .price {
    padding: 0 1.25rem 1.25rem 1.25rem !important;
    font-family: var(--font-heading) !important;
    font-size: 1.1rem !important;
    font-weight: 700 !important;
    color: var(--color-primary) !important;
    margin-top: auto !important;
}

ul.products li.product a.button {
    margin: 0 1.25rem 1.25rem 1.25rem !important;
    background-color: var(--color-primary) !important;
    color: #ffffff !important;
    text-align: center !important;
    padding: 0.5rem 1rem !important;
    border-radius: var(--radius-sm) !important;
    font-weight: 600 !important;
    font-size: 0.8rem !important;
    transition: var(--transition-fast) !important;
    display: block !important;
}

ul.products li.product a.button:hover {
    background-color: var(--color-primary-hover) !important;
}

/* 5. Custom Favorites Heart Icon button */
.mmt-favorite-btn {
    position: absolute;
    top: 12px;
    right: 12px;
    width: 36px;
    height: 36px;
    border-radius: var(--radius-full);
    background-color: rgba(255, 255, 255, 0.9);
    border: 1px solid var(--color-border);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-text-muted);
    cursor: pointer;
    z-index: 10;
    transition: all var(--transition-fast);
    box-shadow: var(--shadow-sm);
}

.mmt-favorite-btn:hover {
    transform: scale(1.1);
    color: #ef4444;
    background-color: #ffffff;
    box-shadow: var(--shadow-md);
}

.mmt-favorite-btn.active {
    color: #ef4444;
    background-color: #ffffff;
    border-color: rgba(239, 68, 68, 0.2);
}

.mmt-favorite-btn.active svg {
    fill: #ef4444;
}

.mmt-favorite-btn.loading {
    opacity: 0.5;
    pointer-events: none;
}

/* Empty State Favorites Card */
.empty-favorites {
    text-align: center;
    padding: 4rem 2rem;
    background-color: var(--color-bg-base);
    border: 1px dashed var(--color-border);
    border-radius: var(--radius-lg);
}

.empty-favorites p {
    font-size: 1.1rem;
    color: var(--color-text-muted);
    margin-bottom: 1.5rem;
}

.empty-favorites .btn {
    display: inline-block;
    padding: 0.75rem 2rem;
}

/* Account Favorites View Custom Headers */
.account-endpoint-title {
    margin-bottom: 2rem;
    font-size: 1.5rem;
    border-bottom: 2px solid var(--color-primary-light);
    padding-bottom: 0.75rem;
}

.woocommerce-MyAccount-content address {
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: 1.5rem;
    background-color: var(--color-bg-accent);
    line-height: 1.5;
    font-style: normal;
}

/* Custom AJAX Add to Cart & View Cart transitions */
.add-to-cart-action.added,
ul.products li.product a.button.added {
    display: none !important;
}

.product-price-row .added_to_cart.wc-forward,
ul.products li.product .added_to_cart.wc-forward {
    display: inline-block !important;
    padding: 0.45rem 1rem !important;
    font-size: 0.8rem !important;
    border-radius: var(--radius-sm) !important;
    background-color: var(--color-primary) !important;
    color: #ffffff !important;
    font-weight: 600 !important;
    text-align: center !important;
    transition: all var(--transition-fast) !important;
    border: none !important;
    box-shadow: var(--shadow-sm) !important;
    text-decoration: none !important;
    margin: 0 !important;
    cursor: pointer !important;
}

ul.products li.product .added_to_cart.wc-forward {
    margin: 0 1.25rem 1.25rem 1.25rem !important;
    font-size: 0.85rem !important;
    padding: 0.6rem 1.25rem !important;
}

.product-price-row .added_to_cart.wc-forward:hover,
ul.products li.product .added_to_cart.wc-forward:hover {
    background-color: var(--color-primary-hover) !important;
    color: #ffffff !important;
    transform: translateY(-2px) !important;
    box-shadow: var(--shadow-md) !important;
}

/* Loading state for Add to Cart */
.add-to-cart-action.loading,
ul.products li.product a.button.loading {
    opacity: 0.6 !important;
    cursor: not-allowed !important;
    pointer-events: none !important;
}

/* ============================================================================
   WooCommerce Single Product Page Redesign
   ============================================================================ */

/* 1. Breadcrumbs styling */
.single-product .woocommerce-breadcrumb {
    font-size: 0.85rem;
    color: var(--color-text-muted);
    font-family: var(--font-body);
    margin-bottom: 2.5rem;
    padding: 0.75rem 1.25rem;
    background-color: var(--color-bg-accent);
    border-radius: var(--radius-sm);
    display: inline-flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 0.4rem;
}

.single-product .woocommerce-breadcrumb a {
    color: var(--color-primary);
    text-decoration: none;
    font-weight: 500;
    transition: color var(--transition-fast);
}

.single-product .woocommerce-breadcrumb a:hover {
    color: var(--color-primary-hover);
    text-decoration: underline;
}

/* 2. Main layout grid structure */
.single-product div.product {
    display: grid;
    grid-template-columns: 1fr;
    gap: 2.5rem;
    margin-top: 1rem;
    margin-bottom: 4rem;
    position: relative;
}

@media (min-width: 992px) {
    .single-product div.product {
        grid-template-columns: 1fr 1fr; /* 50/50 balance */
        gap: 5rem;
        align-items: center; /* center vertically for balance */
    }
}

/* 3. Product Gallery Container */
.single-product .woocommerce-product-gallery {
    width: 100% !important;
    max-width: 100% !important;
    float: none !important;
    opacity: 1 !important;
    background-color: #ffffff;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: 2.5rem;
    box-shadow: var(--shadow-md);
    transition: all var(--transition-normal);
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    aspect-ratio: 1; /* perfect square for balance */
    position: relative;
    overflow: hidden;
}

.single-product .woocommerce-product-gallery:hover {
    box-shadow: var(--shadow-lg), var(--shadow-glow);
    border-color: rgba(22, 59, 231, 0.2);
}

.single-product .woocommerce-product-gallery__wrapper {
    width: 100% !important;
    height: 100% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

.single-product .woocommerce-product-gallery img {
    max-width: 100% !important;
    max-height: 100% !important;
    width: auto !important;
    height: auto !important;
    object-fit: contain !important;
    border-radius: var(--radius-md);
    transition: transform var(--transition-normal) ease;
}

.single-product .woocommerce-product-gallery:hover img {
    transform: scale(1.03);
}

/* 4. Product Summary Info styling */
.single-product .summary.entry-summary {
    width: 100% !important;
    max-width: 100% !important;
    float: none !important;
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 0;
}

.single-product .summary.entry-summary .product_title {
    font-size: clamp(2rem, 3.5vw, 2.75rem);
    font-weight: 800;
    color: var(--color-text-dark);
    margin-bottom: 0.75rem;
    letter-spacing: -0.02em;
    line-height: 1.15;
}

.single-product .summary.entry-summary .price {
    font-size: 1.85rem !important;
    font-weight: 700 !important;
    color: var(--color-primary) !important;
    font-family: var(--font-heading) !important;
    margin-bottom: 1.5rem !important;
    display: block;
}

.single-product .summary.entry-summary .price del {
    font-size: 1.25rem;
    color: var(--color-text-light);
    font-weight: 400;
    margin-right: 0.5rem;
}

.single-product .summary.entry-summary .price ins {
    text-decoration: none;
}

/* Description styling in summary */
.single-product .woocommerce-product-details__short-description {
    font-size: 1.05rem;
    line-height: 1.7;
    color: var(--color-text-muted);
    margin-bottom: 2rem;
}

/* 5. Add to Cart Form controls */
.single-product form.cart {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin-bottom: 2rem;
    padding-bottom: 2rem;
    border-bottom: 1px solid var(--color-border);
    flex-wrap: wrap;
}

.single-product form.cart .quantity {
    display: inline-flex;
    align-items: center;
}

.single-product form.cart .quantity input.qty {
    width: 70px !important;
    height: 48px !important;
    border: 1px solid var(--color-border) !important;
    border-radius: var(--radius-md) !important;
    font-size: 1.05rem !important;
    font-weight: 700 !important;
    color: var(--color-text-dark) !important;
    text-align: center !important;
    background-color: var(--color-bg-accent) !important;
    transition: all var(--transition-fast) !important;
    outline: none !important;
}

.single-product form.cart .quantity input.qty:focus {
    border-color: var(--color-primary) !important;
    background-color: #ffffff !important;
    box-shadow: 0 0 0 3px var(--color-primary-glow) !important;
}

.single-product .single_add_to_cart_button {
    height: 48px !important;
    padding: 0 2.5rem !important;
    font-size: 1rem !important;
    font-weight: 700 !important;
    background-color: var(--color-primary) !important;
    color: #ffffff !important;
    border: none !important;
    border-radius: var(--radius-md) !important;
    cursor: pointer !important;
    transition: all var(--transition-fast) !important;
    box-shadow: 0 4px 14px rgba(22, 59, 231, 0.25) !important;
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
}

.single-product .single_add_to_cart_button:hover {
    background-color: var(--color-primary-hover) !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 6px 20px rgba(22, 59, 231, 0.4) !important;
}

.single-product .single_add_to_cart_button:active {
    transform: translateY(0) !important;
}

/* 6. Product Meta card info */
.single-product .product_meta {
    font-size: 0.85rem;
    color: var(--color-text-muted);
    background: transparent !important;
    padding: 0 !important;
    border: none !important;
    border-radius: 0 !important;
    display: flex;
    flex-wrap: wrap;
    gap: 1.5rem;
}

.single-product .product_meta > span {
    display: inline-flex;
    align-items: center;
}

.single-product .product_meta a {
    color: var(--color-text-dark);
    font-weight: 600;
    text-decoration: none;
    transition: color var(--transition-fast);
    margin-left: 0.25rem;
}

.single-product .product_meta a:hover {
    color: var(--color-primary);
}

/* 7. Product Tabs section redesigned */
.single-product .woocommerce-tabs {
    grid-column: 1 / -1;
    margin-top: 0; /* managed by row gap */
    border-top: 1px solid var(--color-border);
    padding-top: 3.5rem;
}

.single-product .woocommerce-tabs ul.tabs {
    display: flex !important;
    list-style: none !important;
    padding: 0 !important;
    margin: 0 0 2rem 0 !important;
    border-bottom: 2px solid var(--color-border) !important;
    gap: 2.5rem !important;
    background: transparent !important;
    border-top: none !important;
    border-left: none !important;
    border-right: none !important;
}

.single-product .woocommerce-tabs ul.tabs li {
    padding: 0 !important;
    margin: 0 0 -2px 0 !important; /* overlap parent border perfectly */
    position: relative !important;
    background: transparent !important;
    border: none !important;
    border-radius: 0 !important;
    float: none !important;
}

.single-product .woocommerce-tabs ul.tabs li a {
    display: block !important;
    padding: 0.75rem 0 !important;
    font-family: var(--font-heading) !important;
    font-size: 1.1rem !important;
    font-weight: 700 !important;
    color: var(--color-text-muted) !important;
    text-decoration: none !important;
    transition: all var(--transition-fast) !important;
    background: transparent !important;
    border: none !important;
    border-bottom: 3px solid transparent !important;
}

.single-product .woocommerce-tabs ul.tabs li.active a {
    color: var(--color-primary) !important;
    background: transparent !important;
    border-bottom: 3px solid var(--color-primary) !important;
}

.single-product .woocommerce-tabs ul.tabs li a:hover {
    color: var(--color-text-dark) !important;
}

.single-product .woocommerce-tabs .woocommerce-Tabs-panel {
    background-color: transparent !important;
    border: none !important;
    border-radius: 0 !important;
    padding: 1rem 0 0 0 !important;
    box-shadow: none !important;
    animation: fadeIn var(--transition-normal) forwards;
}

@keyframes fadeIn {
    from { opacity: 0; transform: translateY(10px); }
    to { opacity: 1; transform: translateY(0); }
}

.single-product .woocommerce-tabs .woocommerce-Tabs-panel h2 {
    display: none !important;
}

/* 8. Reviews forms & layout */
.single-product .woocommerce-Reviews .woocommerce-noreviews {
    font-size: 1.05rem;
    color: var(--color-text-muted);
    background-color: var(--color-bg-accent);
    padding: 1.5rem;
    border-radius: var(--radius-md);
    text-align: center;
    border: 1px dashed var(--color-border);
}

.single-product #review_form_wrapper {
    margin-top: 3rem;
    padding-top: 2.5rem;
    border-top: 1px solid var(--color-border);
}

.single-product .comment-reply-title {
    font-family: var(--font-heading);
    font-size: 1.35rem;
    font-weight: 700;
    margin-bottom: 1.5rem;
    display: block;
}

.single-product form.comment-form {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.5rem;
}

@media (min-width: 768px) {
    .single-product form.comment-form {
        grid-template-columns: repeat(2, 1fr);
    }
    .single-product form.comment-form .comment-form-comment,
    .single-product form.comment-form .comment-form-rating,
    .single-product form.comment-form .form-submit,
    .single-product form.comment-form .comment-form-cookies-consent {
        grid-column: 1 / -1;
    }
}

.single-product form.comment-form label {
    display: block;
    font-weight: 600;
    margin-bottom: 0.5rem;
    font-size: 0.95rem;
}

.single-product form.comment-form input[type="text"],
.single-product form.comment-form input[type="email"],
.single-product form.comment-form textarea {
    width: 100%;
    padding: 0.85rem 1rem;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    background-color: var(--color-bg-accent);
    font-family: var(--font-body);
    font-size: 0.95rem;
    transition: all var(--transition-fast);
    outline: none;
}

.single-product form.comment-form input[type="text"]:focus,
.single-product form.comment-form input[type="email"]:focus,
.single-product form.comment-form textarea:focus {
    border-color: var(--color-primary);
    background-color: #ffffff;
    box-shadow: 0 0 0 3px var(--color-primary-glow);
}

.single-product form.comment-form .form-submit input[type="submit"] {
    background-color: var(--color-primary);
    color: #ffffff;
    border: none;
    padding: 0.85rem 2.5rem;
    font-size: 0.95rem;
    font-weight: 700;
    border-radius: var(--radius-md);
    cursor: pointer;
    transition: all var(--transition-fast);
    box-shadow: 0 4px 14px rgba(22, 59, 231, 0.25);
}

.single-product form.comment-form .form-submit input[type="submit"]:hover {
    background-color: var(--color-primary-hover);
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(22, 59, 231, 0.4);
}

.single-product .stars {
    display: inline-flex;
    gap: 0.25rem;
}

.single-product .stars a {
    color: #fbbf24;
    font-size: 1.25rem;
    text-decoration: none;
}

/* 9. Related Products section */
.single-product section.related.products {
    grid-column: 1 / -1;
    margin-top: 4.5rem;
    border-top: 1px solid var(--color-border);
    padding-top: 4rem;
}

.single-product section.related.products > h2 {
    font-size: 1.85rem;
    font-weight: 800;
    margin-bottom: 2.5rem;
    text-align: center;
    letter-spacing: -0.01em;
}


/* ============================================================================
   WooCommerce Logged-In Customer Dashboard Portal Redesign
   ============================================================================ */

/* 1. Hide public header, footer, and default headers on logged-in page */
body.logged-in.woocommerce-account header#masthead.site-header,
body.logged-in.woocommerce-account footer#colophon.site-footer,
body.logged-in.woocommerce-account .page-header-default {
    display: none !important;
}

/* 2. Setup full-screen application-style layout */
body.logged-in.woocommerce-account {
    height: 100vh !important;
    max-height: 100vh !important;
    overflow: hidden !important;
    background-color: #f8fafc !important;
}

body.logged-in.woocommerce-account main#primary-content {
    height: 100vh !important;
    max-height: 100vh !important;
    display: flex !important;
    flex-direction: column !important;
    overflow: hidden !important;
}

body.logged-in.woocommerce-account .mmt-dashboard-layout-wrapper {
    width: 100% !important;
    max-width: none !important;
    height: 100vh !important;
    display: flex !important;
    overflow: hidden !important;
}

body.logged-in.woocommerce-account .woocommerce {
    display: flex !important;
    width: 100vw !important;
    max-width: none !important;
    height: 100vh !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: hidden !important;
}

/* 3. Left Sidebar Container (Logo + Profile Card + Nav Menu) */
body.logged-in.woocommerce-account .mmt-dashboard-sidebar {
    width: 290px !important;
    min-width: 290px !important;
    height: 100vh !important;
    background-color: #ffffff !important;
    background: #ffffff !important;
    border-right: 1px solid #e2e8f0 !important;
    display: flex !important;
    flex-direction: column !important;
    padding: 2.25rem 1.75rem !important;
    overflow-y: auto !important;
    float: none !important;
    margin: 0 !important;
    scrollbar-width: thin !important;
    scrollbar-color: rgba(15, 23, 42, 0.1) transparent !important;
}

body.logged-in.woocommerce-account .woocommerce-MyAccount-navigation {
    width: 100% !important;
    min-width: 100% !important;
    background: transparent !important;
    border: none !important;
    padding: 0 !important;
    overflow: visible !important;
    display: block !important;
    float: none !important;
    margin: 0 !important;
}

/* 4. Sidebar Logo & Profile Card Info */
.mmt-dashboard-sidebar-header {
    display: flex !important;
    flex-direction: column !important;
    gap: 2rem !important;
    margin-bottom: 1.5rem !important;
    border-bottom: 1px solid #e2e8f0 !important;
    padding-bottom: 2rem !important;
}

.mmt-dashboard-logo {
    display: flex !important;
    align-items: center !important;
    padding-left: 1.1rem !important; /* Align with the navigation icons */
}

.mmt-dashboard-logo img {
    height: 42px !important;
    width: auto !important;
    object-fit: contain !important;
    max-width: 100% !important;
}

.mmt-dashboard-profile-card {
    display: flex !important;
    align-items: center !important;
    gap: 1rem !important;
    background-color: #f8fafc !important;
    padding: 1rem !important;
    border-radius: var(--radius-md) !important;
    border: 1px solid #e2e8f0 !important;
}

.mmt-profile-avatar-wrapper {
    position: relative !important;
    display: inline-flex !important;
}

.mmt-profile-avatar-wrapper img.mmt-avatar {
    border-radius: var(--radius-full) !important;
    border: 2px solid var(--color-primary) !important;
    width: 48px !important;
    height: 48px !important;
}

.mmt-online-badge {
    position: absolute !important;
    bottom: 2px !important;
    right: 2px !important;
    width: 12px !important;
    height: 12px !important;
    background-color: #10b981 !important; /* Online green */
    border: 2px solid #ffffff !important;
    border-radius: var(--radius-full) !important;
}

.mmt-profile-info {
    display: flex !important;
    flex-direction: column !important;
    overflow: hidden !important;
}

.mmt-profile-name {
    font-size: 0.95rem !important;
    font-weight: 700 !important;
    color: #0f172a !important;
    margin: 0 0 0.15rem 0 !important;
    font-family: var(--font-heading) !important;
    white-space: nowrap !important;
    text-overflow: ellipsis !important;
    overflow: hidden !important;
}

.mmt-profile-role {
    font-size: 0.775rem !important;
    color: #64748b !important;
    margin: 0 !important;
    white-space: nowrap !important;
    text-overflow: ellipsis !important;
    overflow: hidden !important;
}

/* 5. Navigation Links List */
.woocommerce-MyAccount-navigation ul {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 0.35rem !important;
    flex-grow: 1 !important;
}

.woocommerce-MyAccount-navigation ul li {
    margin: 0 !important;
    display: block !important;
}

.woocommerce-MyAccount-navigation ul li a {
    display: flex !important;
    align-items: center !important;
    gap: 0.85rem !important;
    padding: 0.85rem 1.1rem !important;
    color: #475569 !important; /* Slate-600 */
    font-size: 0.925rem !important;
    font-weight: 600 !important;
    border-radius: var(--radius-md) !important;
    transition: all var(--transition-fast) !important;
    text-decoration: none !important;
    border: none !important;
    background: transparent !important;
    position: relative !important;
}

.woocommerce-MyAccount-navigation ul li a:hover {
    background-color: #f1f5f9 !important;
    color: #0f172a !important;
}

.woocommerce-MyAccount-navigation ul li.is-active a {
    background-color: var(--color-primary) !important; /* Brand Royal Blue */
    color: #ffffff !important;
    box-shadow: 0 4px 12px rgba(22, 59, 231, 0.2) !important;
}

/* Link Prepending Icons (SVGs) */
.woocommerce-MyAccount-navigation ul li a::before {
    content: "" !important;
    display: inline-block !important;
    width: 18px !important;
    height: 18px !important;
    background-repeat: no-repeat !important;
    background-position: center !important;
    background-size: contain !important;
    opacity: 0.85 !important;
    transition: all var(--transition-fast) !important;
    filter: none !important;
}

.woocommerce-MyAccount-navigation ul li a:hover::before {
    opacity: 1 !important;
}

.woocommerce-MyAccount-navigation ul li.is-active a::before {
    opacity: 1 !important;
    filter: brightness(0) invert(1) !important;
}

/* Endpoint Icon SVGs (Slate stroke %2364748b) */
.woocommerce-MyAccount-navigation-link--dashboard a::before {
    background-image: url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3crect x='3' y='3' width='7' height='9'%3e%3c/rect%3e%3crect x='14' y='3' width='7' height='5'%3e%3c/rect%3e%3crect x='14' y='12' width='7' height='9'%3e%3c/rect%3e%3crect x='3' y='16' width='7' height='5'%3e%3c/rect%3e%3c/svg%3e") !important;
}

.woocommerce-MyAccount-navigation-link--orders a::before {
    background-image: url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpath d='M6 2L3 6v14a2 2 0 0 0 2 2h14a2 2 0 0 0 2-2V6l-3-4z'%3e%3c/path%3e%3cline x1='3' y1='6' x2='21' y2='6'%3e%3c/line%3e%3cpath d='M16 10a4 4 0 0 1-8 0'%3e%3c/path%3e%3c/svg%3e") !important;
}

.woocommerce-MyAccount-navigation-link--downloads a::before {
    background-image: url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpath d='M21 15v4a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2v-4'%3e%3c/path%3e%3cpolyline points='7 10 12 15 17 10'%3e%3c/polyline%3e%3cline x1='12' y1='15' x2='12' y2='3'%3e%3c/line%3e%3c/svg%3e") !important;
}

.woocommerce-MyAccount-navigation-link--edit-address a::before {
    background-image: url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpath d='M21 10c0 7-9 13-9 13s-9-6-9-13a9 9 0 0 1 18 0z'%3e%3c/path%3e%3ccircle cx='12' cy='10' r='3'%3e%3c/circle%3e%3c/svg%3e") !important;
}

.woocommerce-MyAccount-navigation-link--payment-methods a::before {
    background-image: url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3crect x='1' y='4' width='22' height='16' rx='2' ry='2'%3e%3c/rect%3e%3cline x1='1' y1='10' x2='23' y2='10'%3e%3c/line%3e%3c/svg%3e") !important;
}

.woocommerce-MyAccount-navigation-link--edit-account a::before {
    background-image: url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpath d='M20 21v-2a4 4 0 0 0-4-4H8a4 4 0 0 0-4 4v2'%3e%3c/path%3e%3ccircle cx='12' cy='7' r='4'%3e%3c/circle%3e%3c/svg%3e") !important;
}

.woocommerce-MyAccount-navigation-link--favorites a::before {
    background-image: url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpath d='M20.84 4.61a5.5 5.5 0 0 0-7.78 0L12 5.67l-1.06-1.06a5.5 5.5 0 0 0-7.78 7.78l1.06 1.06L12 21.23l7.78-7.78 1.06-1.06a5.5 5.5 0 0 0 0-7.78z'%3e%3c/path%3e%3c/svg%3e") !important;
}

.woocommerce-MyAccount-navigation-link--customer-logout a::before {
    background-image: url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpath d='M9 21H5a2 2 0 0 1-2-2V5a2 2 0 0 1 2-2h4'%3e%3c/path%3e%3cpolyline points='16 17 21 12 16 7'%3e%3c/polyline%3e%3cline x1='21' y1='12' x2='9' y2='12'%3e%3c/line%3e%3c/svg%3e") !important;
}

/* 6. Right Side Content Panel Area */
body.logged-in.woocommerce-account .woocommerce-MyAccount-content {
    flex-grow: 1 !important;
    width: auto !important;
    max-width: none !important;
    height: 100vh !important;
    overflow-y: auto !important;
    background-color: #ffffff !important; /* Keep the dashboard white */
    background: #ffffff !important;
    padding: 3.5rem 4.5rem !important;
    float: none !important;
    margin: 0 !important;
    border: none !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    scrollbar-width: thin !important;
    scrollbar-color: rgba(15, 23, 42, 0.1) transparent !important;
}

/* Content Dynamic Top Header */
.mmt-dashboard-content-header {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    margin-bottom: 3rem !important;
    border-bottom: 1px solid #e2e8f0 !important;
    padding-bottom: 2rem !important;
    gap: 2rem !important;
}

.mmt-dashboard-header-left {
    display: flex !important;
    flex-direction: column !important;
}

.mmt-dashboard-badge {
    align-self: flex-start !important;
    background-color: rgba(22, 59, 231, 0.08) !important;
    color: var(--color-primary) !important;
    font-size: 0.7rem !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.05em !important;
    padding: 0.25rem 0.75rem !important;
    border-radius: var(--radius-sm) !important;
    margin-bottom: 0.5rem !important;
}

.mmt-dashboard-title {
    font-size: 1.85rem !important;
    font-weight: 800 !important;
    color: var(--color-text-dark) !important;
    margin: 0 0 0.4rem 0 !important;
    font-family: var(--font-heading) !important;
    letter-spacing: -0.02em !important;
}

.mmt-dashboard-subtitle {
    font-size: 0.95rem !important;
    color: var(--color-text-muted) !important;
    margin: 0 !important;
}

.mmt-btn-outline {
    display: inline-flex !important;
    align-items: center !important;
    gap: 0.5rem !important;
    border: 1px solid #cbd5e1 !important; /* Slate-300 */
    border-radius: var(--radius-md) !important;
    padding: 0.65rem 1.25rem !important;
    font-size: 0.875rem !important;
    font-weight: 600 !important;
    color: #475569 !important; /* Slate-600 */
    text-decoration: none !important;
    background-color: #ffffff !important;
    transition: all var(--transition-fast) !important;
}

.mmt-btn-outline:hover {
    background-color: #f1f5f9 !important; /* Slate-100 */
    color: var(--color-text-dark) !important;
    border-color: #94a3b8 !important;
}

/* Styles inside the account content pane */
.woocommerce-account .woocommerce-MyAccount-content address {
    background-color: #ffffff !important;
    border: 1px solid var(--color-border) !important;
    box-shadow: var(--shadow-sm) !important;
    border-radius: var(--radius-md) !important;
}

/* Card metric wrapper inside WooCommerce dashboard welcome template */
.woocommerce-MyAccount-content > p {
    font-size: 1rem !important;
    line-height: 1.7 !important;
    color: var(--color-text-muted) !important;
    margin-bottom: 1.5rem !important;
}

.woocommerce-MyAccount-content > p strong {
    color: var(--color-text-dark) !important;
    font-weight: 700 !important;
}

/* ============================================================================
   Premium Dashboard Subpage Overhauls (Orders, Addresses, Account details, etc.)
   ============================================================================ */

/* 1. Dashboard Welcome Banner & Navigation Cards */
.mmt-dashboard-welcome-banner {
    background: linear-gradient(135deg, var(--color-primary) 0%, #3b82f6 100%) !important;
    border-radius: 16px !important;
    padding: 2.5rem !important;
    color: #ffffff !important;
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    gap: 3rem !important;
    margin-bottom: 3rem !important;
    box-shadow: 0 10px 25px -5px rgba(22, 59, 231, 0.15), 0 8px 10px -6px rgba(22, 59, 231, 0.15) !important;
}

.mmt-banner-text h3 {
    font-size: 1.85rem !important;
    font-weight: 800 !important;
    color: #ffffff !important;
    margin: 0 0 0.75rem 0 !important;
    font-family: var(--font-heading) !important;
    letter-spacing: -0.02em !important;
}

.mmt-banner-text p {
    font-size: 1rem !important;
    color: rgba(255, 255, 255, 0.9) !important;
    margin: 0 !important;
    line-height: 1.6 !important;
    max-width: 600px !important;
}

.mmt-btn-primary {
    display: inline-flex !important;
    align-items: center !important;
    gap: 0.75rem !important;
    background-color: #ffffff !important;
    color: var(--color-primary) !important;
    font-size: 0.95rem !important;
    font-weight: 700 !important;
    padding: 0.85rem 1.6rem !important;
    border-radius: var(--radius-md) !important;
    text-decoration: none !important;
    transition: all var(--transition-fast) !important;
    box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.05) !important;
    border: none !important;
    cursor: pointer !important;
    white-space: nowrap !important;
}

.mmt-btn-primary:hover {
    background-color: #f1f5f9 !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1) !important;
}

.mmt-dashboard-grid {
    display: grid !important;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)) !important;
    gap: 2rem !important;
    margin-bottom: 3rem !important;
}

.mmt-dashboard-card {
    background-color: #ffffff !important;
    border: 1px solid #e2e8f0 !important;
    border-radius: 16px !important;
    padding: 2rem !important;
    display: flex !important;
    flex-direction: column !important;
    transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1) !important;
    text-decoration: none !important;
    box-shadow: var(--shadow-sm) !important;
}

.mmt-dashboard-card:hover {
    border-color: var(--color-primary) !important;
    transform: translateY(-4px) !important;
    box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.05), 0 10px 10px -5px rgba(0, 0, 0, 0.04) !important;
}

.mmt-card-icon-wrapper {
    width: 48px !important;
    height: 48px !important;
    border-radius: 12px !important;
    background-color: rgba(22, 59, 231, 0.06) !important;
    color: var(--color-primary) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    margin-bottom: 1.5rem !important;
    transition: all var(--transition-fast) !important;
}

.mmt-dashboard-card:hover .mmt-card-icon-wrapper {
    background-color: var(--color-primary) !important;
    color: #ffffff !important;
}

.mmt-card-title {
    font-size: 1.2rem !important;
    font-weight: 700 !important;
    color: var(--color-text-dark) !important;
    margin: 0 0 0.5rem 0 !important;
}

.mmt-card-desc {
    font-size: 0.925rem !important;
    color: var(--color-text-muted) !important;
    margin: 0 0 1.5rem 0 !important;
    line-height: 1.5 !important;
    flex-grow: 1 !important;
}

.mmt-card-link {
    font-size: 0.9rem !important;
    font-weight: 700 !important;
    color: var(--color-primary) !important;
    display: inline-flex !important;
    align-items: center !important;
    gap: 0.35rem !important;
}

/* 2. WooCommerce Form Fields styling */
.woocommerce-MyAccount-content form .form-row {
    margin-bottom: 1.5rem !important;
}

.woocommerce-MyAccount-content form .form-row label {
    font-size: 0.875rem !important;
    font-weight: 600 !important;
    color: #334155 !important;
    margin-bottom: 0.5rem !important;
    display: block !important;
}

.woocommerce-MyAccount-content form input.input-text,
.woocommerce-MyAccount-content form select,
.woocommerce-MyAccount-content form textarea {
    width: 100% !important;
    padding: 0.875rem 1.125rem !important;
    border: 1px solid #cbd5e1 !important;
    border-radius: 8px !important;
    background-color: #ffffff !important;
    color: #0f172a !important;
    font-size: 0.95rem !important;
    transition: all var(--transition-fast) !important;
    outline: none !important;
}

.woocommerce-MyAccount-content form input.input-text:focus,
.woocommerce-MyAccount-content form select:focus,
.woocommerce-MyAccount-content form textarea:focus {
    border-color: var(--color-primary) !important;
    box-shadow: 0 0 0 3px rgba(22, 59, 231, 0.15) !important;
}

/* Form Buttons */
.woocommerce-MyAccount-content button.button {
    background-color: var(--color-primary) !important;
    color: #ffffff !important;
    border: none !important;
    font-size: 0.95rem !important;
    font-weight: 700 !important;
    padding: 1rem 2rem !important;
    border-radius: 8px !important;
    cursor: pointer !important;
    transition: all var(--transition-fast) !important;
    box-shadow: 0 4px 10px rgba(22, 59, 231, 0.15) !important;
}

.woocommerce-MyAccount-content button.button:hover {
    background-color: #1d4ed8 !important; /* darker blue */
    transform: translateY(-1px) !important;
    box-shadow: 0 6px 15px rgba(22, 59, 231, 0.25) !important;
}

/* 3. Address Panels styling */
.woocommerce-Addresses {
    display: grid !important;
    grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)) !important;
    gap: 2rem !important;
    margin-top: 1.5rem !important;
}

.woocommerce-Addresses .woocommerce-Address {
    padding: 0 !important;
    float: none !important;
    width: 100% !important;
}

.woocommerce-Addresses .woocommerce-Address-title {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    border-bottom: 1px solid #e2e8f0 !important;
    padding-bottom: 1rem !important;
    margin-bottom: 1.25rem !important;
}

.woocommerce-Addresses .woocommerce-Address-title h3 {
    font-size: 1.2rem !important;
    font-weight: 700 !important;
    color: var(--color-text-dark) !important;
    margin: 0 !important;
}

.woocommerce-Addresses .woocommerce-Address-title .edit {
    font-size: 0.85rem !important;
    font-weight: 600 !important;
    color: var(--color-primary) !important;
    text-decoration: none !important;
    border: 1px solid rgba(22, 59, 231, 0.2) !important;
    padding: 0.4rem 0.85rem !important;
    border-radius: 6px !important;
    background-color: rgba(22, 59, 231, 0.02) !important;
    transition: all var(--transition-fast) !important;
}

.woocommerce-Addresses .woocommerce-Address-title .edit:hover {
    background-color: var(--color-primary) !important;
    color: #ffffff !important;
    border-color: var(--color-primary) !important;
}

.woocommerce-Addresses address {
    background-color: #f8fafc !important;
    border: 1px solid #e2e8f0 !important;
    border-radius: 12px !important;
    padding: 1.5rem !important;
    font-style: normal !important;
    color: #475569 !important;
    line-height: 1.6 !important;
    font-size: 0.95rem !important;
}

/* 4. Orders & Downloads Tables styling */
.woocommerce-orders-table,
.woocommerce-MyAccount-downloads {
    width: 100% !important;
    border-collapse: collapse !important;
    margin-top: 1.5rem !important;
    border: 1px solid #e2e8f0 !important;
    border-radius: 12px !important;
    overflow: hidden !important;
    box-shadow: var(--shadow-sm) !important;
}

.woocommerce-orders-table thead,
.woocommerce-MyAccount-downloads thead {
    background-color: #f8fafc !important;
}

.woocommerce-orders-table th,
.woocommerce-MyAccount-downloads th {
    padding: 1.125rem 1.5rem !important;
    font-weight: 600 !important;
    color: #64748b !important;
    text-transform: uppercase !important;
    font-size: 0.775rem !important;
    letter-spacing: 0.05em !important;
    border-bottom: 1px solid #e2e8f0 !important;
    text-align: left !important;
}

.woocommerce-orders-table td,
.woocommerce-MyAccount-downloads td {
    padding: 1.25rem 1.5rem !important;
    color: #334155 !important;
    border-bottom: 1px solid #e2e8f0 !important;
    font-size: 0.95rem !important;
    vertical-align: middle !important;
}

.woocommerce-orders-table tr:last-child td,
.woocommerce-MyAccount-downloads tr:last-child td {
    border-bottom: none !important;
}

/* Order Status Badges */
.woocommerce-orders-table__cell-order-status span {
    display: inline-flex !important;
    align-items: center !important;
    padding: 0.25rem 0.75rem !important;
    border-radius: var(--radius-full) !important;
    font-size: 0.8rem !important;
    font-weight: 600 !important;
}

.woocommerce-orders-table__cell-order-status span.status-completed {
    background-color: rgba(16, 185, 129, 0.1) !important;
    color: #10b981 !important;
}

.woocommerce-orders-table__cell-order-status span.status-processing {
    background-color: rgba(22, 59, 231, 0.1) !important;
    color: var(--color-primary) !important;
}

.woocommerce-orders-table__cell-order-status span.status-on-hold,
.woocommerce-orders-table__cell-order-status span.status-pending {
    background-color: rgba(245, 158, 11, 0.1) !important;
    color: #f59e0b !important;
}

/* View/Action Button inside table */
.woocommerce-orders-table td.woocommerce-orders-table__cell-order-actions a.button,
.woocommerce-MyAccount-downloads td.download-file a.button {
    background: #ffffff !important;
    color: var(--color-primary) !important;
    border: 1px solid rgba(22, 59, 231, 0.25) !important;
    font-size: 0.85rem !important;
    font-weight: 600 !important;
    padding: 0.5rem 1rem !important;
    border-radius: 6px !important;
    box-shadow: none !important;
    text-decoration: none !important;
    transition: all var(--transition-fast) !important;
}

.woocommerce-orders-table td.woocommerce-orders-table__cell-order-actions a.button:hover,
.woocommerce-MyAccount-downloads td.download-file a.button:hover {
    background: var(--color-primary) !important;
    color: #ffffff !important;
    border-color: var(--color-primary) !important;
}

/* 5. Empty states */
.woocommerce-info,
.woocommerce-error,
.woocommerce-message {
    background-color: #f8fafc !important;
    border: 1px solid #e2e8f0 !important;
    border-left: 4px solid var(--color-primary) !important;
    border-radius: 8px !important;
    padding: 1.25rem 1.5rem !important;
    color: #475569 !important;
    font-size: 0.95rem !important;
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    gap: 1.5rem !important;
    margin-bottom: 2rem !important;
}

.woocommerce-info a.button,
.woocommerce-message a.button {
    background-color: var(--color-primary) !important;
    color: #ffffff !important;
    padding: 0.5rem 1.25rem !important;
    font-size: 0.85rem !important;
    font-weight: 600 !important;
    border-radius: 6px !important;
    border: none !important;
    text-decoration: none !important;
    transition: all var(--transition-fast) !important;
}

.woocommerce-info a.button:hover,
.woocommerce-message a.button:hover {
    background-color: #1d4ed8 !important;
}

/* 6. Product Item Card in Favorites (styling image and grid) */
.popular-products-grid {
    display: grid !important;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)) !important;
    gap: 2rem !important;
    margin-top: 1.5rem !important;
}

.product-item-card {
    background-color: #ffffff !important;
    border: 1px solid #e2e8f0 !important;
    border-radius: 12px !important;
    overflow: hidden !important;
    display: flex !important;
    flex-direction: column !important;
    box-shadow: var(--shadow-sm) !important;
    transition: all var(--transition-fast) !important;
}

.product-item-card:hover {
    transform: translateY(-4px) !important;
    box-shadow: 0 12px 20px -5px rgba(0,0,0,0.05) !important;
    border-color: #cbd5e1 !important;
}

.product-item-image-wrapper {
    position: relative !important;
    width: 100% !important;
    padding-top: 80% !important; /* Aspect ratio */
    background-color: #f8fafc !important;
    border-bottom: 1px solid #e2e8f0 !important;
    overflow: hidden !important;
}

.product-item-link {
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 1.5rem !important;
}

.product-item-image img.product-item-featured-image {
    max-width: 100% !important;
    max-height: 100% !important;
    object-fit: contain !important;
    transition: transform var(--transition-fast) !important;
}

.product-item-card:hover .product-item-image img.product-item-featured-image {
    transform: scale(1.05) !important;
}

.product-item-svg {
    color: #94a3b8 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

.product-item-details {
    padding: 1.25rem !important;
    display: flex !important;
    flex-direction: column !important;
    flex-grow: 1 !important;
}

.product-item-title {
    font-size: 0.95rem !important;
    font-weight: 700 !important;
    color: var(--color-text-dark) !important;
    margin: 0 0 0.75rem 0 !important;
    line-height: 1.4 !important;
    flex-grow: 1 !important;
}

.product-item-title a {
    color: inherit !important;
    text-decoration: none !important;
}

.product-item-title a:hover {
    color: var(--color-primary) !important;
}

.product-price-row {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    margin-top: auto !important;
}

.product-price-row .price {
    font-size: 1.1rem !important;
    font-weight: 800 !important;
    color: var(--color-primary) !important;
}

.product-price-row .add-to-cart-action {
    font-size: 0.8rem !important;
    font-weight: 700 !important;
    padding: 0.5rem 1rem !important;
    border-radius: 6px !important;
    text-decoration: none !important;
    background-color: var(--color-primary) !important;
    color: #ffffff !important;
    transition: all var(--transition-fast) !important;
}

.product-price-row .add-to-cart-action:hover {
    background-color: #1d4ed8 !important;
}

/* Favorite button absolute placement */
.mmt-favorite-btn {
    position: absolute !important;
    top: 10px !important;
    right: 10px !important;
    width: 32px !important;
    height: 32px !important;
    border-radius: 50% !important;
    background-color: #ffffff !important;
    border: 1px solid #e2e8f0 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    color: #94a3b8 !important;
    cursor: pointer !important;
    box-shadow: var(--shadow-sm) !important;
    transition: all var(--transition-fast) !important;
    z-index: 2 !important;
}

.mmt-favorite-btn:hover {
    transform: scale(1.1) !important;
    color: #ef4444 !important; /* Red */
    border-color: #fecaca !important;
}

.mmt-favorite-btn.active {
    color: #ef4444 !important;
    fill: #ef4444 !important;
    border-color: #fca5a5 !important;
}

/* 7. Mobile Viewports Styling (max-width: 767px) */
@media (max-width: 767px) {
    body.logged-in.woocommerce-account {
        height: auto !important;
        max-height: none !important;
        overflow: auto !important;
    }

    body.logged-in.woocommerce-account main#primary-content {
        height: auto !important;
        max-height: none !important;
        overflow: visible !important;
    }

    body.logged-in.woocommerce-account .mmt-dashboard-layout-wrapper {
        height: auto !important;
        flex-direction: column !important;
        overflow: visible !important;
    }

    body.logged-in.woocommerce-account .woocommerce {
        flex-direction: column !important;
        width: 100% !important;
        height: auto !important;
        overflow: visible !important;
    }

    body.logged-in.woocommerce-account .mmt-dashboard-sidebar {
        width: 100% !important;
        min-width: 100% !important;
        height: auto !important;
        background-color: #ffffff !important;
        background: #ffffff !important;
        padding: 1.5rem !important;
        border-right: none !important;
        border-bottom: 1px solid #e2e8f0 !important;
        position: relative !important;
        display: flex !important;
        flex-direction: column !important;
    }

    body.logged-in.woocommerce-account .woocommerce-MyAccount-navigation {
        width: 100% !important;
        min-width: 100% !important;
        height: auto !important;
        padding: 0 !important;
        border-right: none !important;
        border-bottom: none !important;
        position: relative !important;
    }

    .mmt-dashboard-sidebar-header {
        gap: 1.25rem !important;
        margin-bottom: 1.25rem !important;
        border-bottom: 1px solid #e2e8f0 !important;
        padding-bottom: 1.25rem !important;
    }

    .woocommerce-MyAccount-navigation ul {
        flex-direction: row !important;
        overflow-x: auto !important;
        padding-bottom: 0.5rem !important;
        gap: 0.5rem !important;
        -webkit-overflow-scrolling: touch !important;
    }

    .woocommerce-MyAccount-navigation ul::-webkit-scrollbar {
        height: 4px !important;
    }

    .woocommerce-MyAccount-navigation ul::-webkit-scrollbar-thumb {
        background-color: rgba(15, 23, 42, 0.1) !important;
        border-radius: var(--radius-full) !important;
    }

    .woocommerce-MyAccount-navigation ul li {
        flex-shrink: 0 !important;
    }

    .woocommerce-MyAccount-navigation ul li a {
        white-space: nowrap !important;
        padding: 0.65rem 1rem !important;
        font-size: 0.875rem !important;
    }

    body.logged-in.woocommerce-account .woocommerce-MyAccount-content {
        width: 100% !important;
        height: auto !important;
        padding: 2rem 1.5rem !important;
        overflow-y: visible !important;
    }

    .mmt-dashboard-content-header {
        flex-direction: column !important;
        align-items: flex-start !important;
        gap: 1.25rem !important;
        margin-bottom: 2rem !important;
        padding-bottom: 1.5rem !important;
    }

    .mmt-dashboard-title {
        font-size: 1.5rem !important;
    }
}






