/* ============================================
   MOBILE & TABLET RESPONSIVE FIXES
   iPhone, iPad, and Mobile Device Optimizations
   ============================================ */

/* === VIEWPORT & SAFE AREA FIXES === */
:root {
  /* Safe area insets for notched devices (iPhone X+) */
  --safe-area-top: env(safe-area-inset-top, 0px);
  --safe-area-bottom: env(safe-area-inset-bottom, 0px);
  --safe-area-left: env(safe-area-inset-left, 0px);
  --safe-area-right: env(safe-area-inset-right, 0px);
}

/* Ensure proper touch behavior */
* {
  -webkit-tap-highlight-color: transparent;
  -webkit-touch-callout: none;
}

/* Prevent zoom on input focus (iOS) */
input, select, textarea {
  font-size: 16px !important;
}

/* === NAVBAR RESPONSIVE FIXES === */

/* iPhone SE, iPhone 8 (375px) */
@media (max-width: 375px) {
  .navbar {
    padding: 0 var(--spacing-sm) !important;
    height: 60px !important;
  }
  
  .nav-brand img {
    width: 36px !important;
    height: 36px !important;
  }
  
  .nav-brand span {
    font-size: 1rem !important;
    max-width: 120px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }
  
  .nav-icon-btn {
    width: 36px !important;
    height: 36px !important;
    font-size: 1rem !important;
  }
  
  .nav-icon-btn .badge {
    min-width: 16px !important;
    height: 16px !important;
    font-size: 0.6rem !important;
    top: -2px !important;
    right: -2px !important;
  }
  
  .nav-actions {
    gap: var(--spacing-xs) !important;
  }
  
  .nav-mobile-toggle {
    padding: 8px !important;
  }
  
  .nav-mobile-toggle span {
    width: 20px !important;
  }
}

/* iPhone 12/13/14, most Android phones (390px-430px) */
@media (min-width: 376px) and (max-width: 430px) {
  .navbar {
    padding: 0 var(--spacing-md) !important;
    height: 64px !important;
  }
  
  .nav-brand img {
    width: 40px !important;
    height: 40px !important;
  }
  
  .nav-brand span {
    font-size: 1.1rem !important;
    max-width: 140px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }
  
  .nav-icon-btn {
    width: 40px !important;
    height: 40px !important;
    font-size: 1.1rem !important;
  }
  
  .nav-actions {
    gap: var(--spacing-sm) !important;
  }
}

/* Larger phones / Phablets (431px-576px) */
@media (min-width: 431px) and (max-width: 576px) {
  .navbar {
    padding: 0 var(--spacing-lg) !important;
    height: 68px !important;
  }
  
  .nav-brand img {
    width: 44px !important;
    height: 44px !important;
  }
  
  .nav-brand span {
    font-size: 1.2rem !important;
  }
}

/* All mobile devices - hide desktop menu, show hamburger */
@media (max-width: 768px) {
  .nav-menu {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    flex-direction: column !important;
    background: var(--bg-white) !important;
    padding: 80px var(--spacing-lg) var(--spacing-lg) !important;
    gap: var(--spacing-xs) !important;
    transform: translateX(-100%) !important;
    opacity: 0 !important;
    visibility: hidden !important;
    transition: all 0.3s ease !important;
    z-index: 999 !important;
    overflow-y: auto !important;
  }
  
  .nav-menu.open {
    transform: translateX(0) !important;
    opacity: 1 !important;
    visibility: visible !important;
  }
  
  .nav-link {
    width: 100% !important;
    padding: var(--spacing-md) !important;
    text-align: center !important;
    font-size: 1.1rem !important;
    border-radius: var(--radius-md) !important;
  }
  
  .nav-mobile-toggle {
    display: flex !important;
    flex-direction: column !important;
    gap: 5px !important;
    z-index: 1001 !important;
  }
  
  /* Hamburger animation */
  .nav-mobile-toggle.active span:nth-child(1) {
    transform: rotate(45deg) translate(5px, 5px);
  }
  
  .nav-mobile-toggle.active span:nth-child(2) {
    opacity: 0;
  }
  
  .nav-mobile-toggle.active span:nth-child(3) {
    transform: rotate(-45deg) translate(7px, -6px);
  }
}

/* === iPad Mini (768px) === */
@media (min-width: 768px) and (max-width: 834px) {
  .navbar {
    padding: 0 var(--spacing-lg) !important;
  }
  
  .nav-brand img {
    width: 44px !important;
    height: 44px !important;
  }
  
  .nav-brand span {
    font-size: 1.25rem !important;
  }
  
  .nav-menu {
    gap: var(--spacing-sm) !important;
  }
  
  .nav-link {
    padding: var(--spacing-xs) var(--spacing-sm) !important;
    font-size: 0.85rem !important;
  }
  
  .nav-icon-btn {
    width: 40px !important;
    height: 40px !important;
  }
}

/* === iPad Air / iPad Pro 11" (820px-1024px) === */
@media (min-width: 835px) and (max-width: 1024px) {
  .navbar {
    padding: 0 var(--spacing-xl) !important;
  }
  
  .nav-brand img {
    width: 46px !important;
    height: 46px !important;
  }
  
  .nav-brand span {
    font-size: 1.35rem !important;
  }
  
  .nav-menu {
    gap: var(--spacing-md) !important;
  }
  
  .nav-link {
    padding: var(--spacing-sm) var(--spacing-md) !important;
    font-size: 0.9rem !important;
  }
}

/* === HERO SLIDER RESPONSIVE === */
@media (max-width: 576px) {
  .hero-slider {
    height: 400px !important;
  }
  
  .slide-content {
    padding: 0 var(--spacing-md) !important;
  }
  
  .slide-content h1 {
    font-size: 1.75rem !important;
    line-height: 1.3 !important;
  }
  
  .slide-content p {
    font-size: 0.95rem !important;
    margin-bottom: var(--spacing-md) !important;
  }
  
  .slider-arrow {
    width: 40px !important;
    height: 40px !important;
    font-size: 1rem !important;
  }
  
  .slider-arrows {
    padding: 0 var(--spacing-sm) !important;
  }
  
  .slider-nav {
    bottom: var(--spacing-md) !important;
  }
  
  .slider-dot {
    width: 10px !important;
    height: 10px !important;
  }
}

@media (min-width: 577px) and (max-width: 768px) {
  .hero-slider {
    height: 450px !important;
  }
  
  .slide-content h1 {
    font-size: 2.25rem !important;
  }
  
  .slide-content p {
    font-size: 1rem !important;
  }
}

@media (min-width: 769px) and (max-width: 1024px) {
  .hero-slider {
    height: 500px !important;
  }
  
  .slide-content h1 {
    font-size: 2.75rem !important;
  }
}

/* === SECTION & CONTAINER RESPONSIVE === */
@media (max-width: 576px) {
  .section {
    padding: var(--spacing-xl) 0 !important;
  }
  
  .container {
    padding: 0 var(--spacing-md) !important;
  }
  
  .section-title {
    font-size: 1.5rem !important;
  }
  
  .section-subtitle {
    font-size: 0.9rem !important;
  }
}

@media (min-width: 577px) and (max-width: 768px) {
  .section {
    padding: var(--spacing-xl) 0 !important;
  }
  
  .container {
    padding: 0 var(--spacing-lg) !important;
  }
  
  .section-title {
    font-size: 1.75rem !important;
  }
}

@media (min-width: 769px) and (max-width: 1024px) {
  .container {
    padding: 0 var(--spacing-xl) !important;
  }
  
  .section-title {
    font-size: 2rem !important;
  }
}

/* === PRODUCT GRID RESPONSIVE === */
@media (max-width: 480px) {
  .products-grid {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: var(--spacing-sm) !important;
  }
  
  .product-card {
    border-radius: var(--radius-md) !important;
  }
  
  .product-info {
    padding: var(--spacing-sm) !important;
  }
  
  .product-name {
    font-size: 0.85rem !important;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    line-clamp: 2;
    overflow: hidden;
  }
  
  .product-price {
    font-size: 1rem !important;
  }
  
  .product-badge {
    font-size: 0.65rem !important;
    padding: 2px 8px !important;
  }
  
  .product-actions .btn {
    font-size: 0.75rem !important;
    padding: var(--spacing-xs) var(--spacing-sm) !important;
  }
}

@media (min-width: 481px) and (max-width: 768px) {
  .products-grid {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: var(--spacing-md) !important;
  }
  
  .product-name {
    font-size: 0.9rem !important;
  }
  
  .product-price {
    font-size: 1.1rem !important;
  }
}

@media (min-width: 769px) and (max-width: 1024px) {
  .products-grid {
    grid-template-columns: repeat(3, 1fr) !important;
    gap: var(--spacing-lg) !important;
  }
}

/* === CART & WISHLIST DRAWER RESPONSIVE === */
@media (max-width: 576px) {
  .cart-drawer,
  .wishlist-drawer {
    width: 100% !important;
    max-width: 100% !important;
  }
  
  .cart-header,
  .wishlist-header {
    padding: var(--spacing-md) !important;
  }
  
  .cart-header h2,
  .wishlist-header h2 {
    font-size: 1.25rem !important;
  }
  
  .cart-items,
  .wishlist-items {
    padding: var(--spacing-sm) !important;
  }
  
  .cart-item,
  .wishlist-item {
    padding: var(--spacing-sm) !important;
    gap: var(--spacing-sm) !important;
  }
  
  .cart-item-image,
  .wishlist-item-image {
    width: 70px !important;
    height: 70px !important;
  }
  
  .cart-item-name,
  .wishlist-item-name {
    font-size: 0.9rem !important;
  }
  
  .cart-item-price,
  .wishlist-item-price {
    font-size: 0.95rem !important;
  }
  
  .cart-footer {
    padding: var(--spacing-md) !important;
  }
  
  .cart-total {
    font-size: 1.1rem !important;
  }
}

/* === PAGE HEADER RESPONSIVE === */
@media (max-width: 576px) {
  .page-header {
    padding: var(--spacing-xl) 0 !important;
  }
  
  .page-header h1 {
    font-size: 1.5rem !important;
  }
  
  .page-header p {
    font-size: 0.9rem !important;
  }
  
  .breadcrumb {
    font-size: 0.8rem !important;
    flex-wrap: wrap !important;
    justify-content: center !important;
  }
}

@media (min-width: 577px) and (max-width: 768px) {
  .page-header h1 {
    font-size: 1.75rem !important;
  }
}

/* === SHOP SIDEBAR RESPONSIVE === */
@media (max-width: 992px) {
  .shop-layout {
    flex-direction: column !important;
  }
  
  .shop-sidebar {
    width: 100% !important;
    position: relative !important;
    margin-bottom: var(--spacing-lg) !important;
  }
  
  .filter-card {
    margin-bottom: var(--spacing-md) !important;
  }
}

/* === FOOTER RESPONSIVE === */
@media (max-width: 576px) {
  .footer {
    padding: var(--spacing-xl) var(--spacing-md) !important;
  }
  
  .footer-grid {
    grid-template-columns: 1fr !important;
    gap: var(--spacing-lg) !important;
    text-align: center !important;
  }
  
  .footer-brand img {
    width: 50px !important;
    height: 50px !important;
    margin: 0 auto var(--spacing-sm) !important;
  }
  
  .footer-brand span {
    font-size: 1.25rem !important;
  }
  
  .footer h4 {
    font-size: 1rem !important;
    margin-bottom: var(--spacing-sm) !important;
  }
  
  .footer-links {
    gap: var(--spacing-xs) !important;
  }
  
  .footer-links a {
    font-size: 0.9rem !important;
  }
  
  .footer-bottom {
    flex-direction: column !important;
    gap: var(--spacing-md) !important;
    text-align: center !important;
  }
}

@media (min-width: 577px) and (max-width: 768px) {
  .footer-grid {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}

/* === BUTTONS RESPONSIVE === */
@media (max-width: 576px) {
  .btn {
    padding: var(--spacing-sm) var(--spacing-md) !important;
    font-size: 0.9rem !important;
  }
  
  .btn-lg {
    padding: var(--spacing-md) var(--spacing-lg) !important;
    font-size: 1rem !important;
  }
}

/* === FORM ELEMENTS RESPONSIVE === */
@media (max-width: 576px) {
  input[type="text"],
  input[type="email"],
  input[type="password"],
  input[type="tel"],
  input[type="number"],
  textarea,
  select {
    padding: var(--spacing-sm) var(--spacing-md) !important;
    font-size: 16px !important; /* Prevents zoom on iOS */
    border-radius: var(--radius-md) !important;
  }
  
  .form-group {
    margin-bottom: var(--spacing-md) !important;
  }
  
  label {
    font-size: 0.9rem !important;
    margin-bottom: var(--spacing-xs) !important;
  }
}

/* === BLOG GRID RESPONSIVE === */
@media (max-width: 576px) {
  .blog-grid {
    grid-template-columns: 1fr !important;
    gap: var(--spacing-md) !important;
  }
  
  .blog-card-info h3 {
    font-size: 1rem !important;
  }
  
  .blog-card-info p {
    font-size: 0.85rem !important;
  }
}

@media (min-width: 577px) and (max-width: 992px) {
  .blog-grid {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}

/* === PORTFOLIO GRID RESPONSIVE === */
@media (max-width: 576px) {
  .portfolio-grid {
    grid-template-columns: 1fr !important;
    gap: var(--spacing-md) !important;
  }
}

@media (min-width: 577px) and (max-width: 768px) {
  .portfolio-grid {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}

/* === CONTACT PAGE RESPONSIVE === */
@media (max-width: 768px) {
  .contact-layout {
    flex-direction: column !important;
  }
  
  .contact-info,
  .contact-form {
    width: 100% !important;
  }
}

/* === ABOUT PAGE RESPONSIVE === */
@media (max-width: 768px) {
  .about-content {
    flex-direction: column !important;
  }
  
  .about-text,
  .about-image {
    width: 100% !important;
  }
  
  .about-text {
    text-align: center !important;
  }
}

/* === PRODUCT DETAIL PAGE RESPONSIVE === */
@media (max-width: 768px) {
  .product-detail-layout {
    flex-direction: column !important;
    gap: var(--spacing-lg) !important;
  }
  
  .product-gallery,
  .product-details {
    width: 100% !important;
  }
  
  .product-gallery-main {
    max-height: 350px !important;
  }
  
  .product-title {
    font-size: 1.5rem !important;
  }
  
  .product-price-main {
    font-size: 1.5rem !important;
  }
}

/* === LANDSCAPE MODE FIXES (Mobile) === */
@media (max-width: 896px) and (orientation: landscape) {
  .hero-slider {
    height: 300px !important;
  }
  
  .slide-content h1 {
    font-size: 1.5rem !important;
  }
  
  .slide-content p {
    display: none !important;
  }
  
  .nav-wrapper {
    position: fixed !important;
  }
  
  .page-content {
    padding-top: 60px !important;
  }
}

/* === iOS SPECIFIC FIXES === */
@supports (-webkit-touch-callout: none) {
  /* Safari-only styles */
  body {
    /* Fix for iOS momentum scrolling */
    -webkit-overflow-scrolling: touch;
  }
  
  /* Fix 100vh issue on iOS Safari */
  .nav-menu.open,
  .mobile-menu,
  .cart-drawer,
  .wishlist-drawer {
    height: 100vh;
    height: -webkit-fill-available;
  }
  
  /* Fix for fixed positioning on iOS */
  .nav-wrapper {
    transform: translateZ(0);
    -webkit-transform: translateZ(0);
  }
}

/* === ACCESSIBILITY IMPROVEMENTS === */
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}

/* Focus states for touch devices */
@media (hover: none) and (pointer: coarse) {
  .btn:active,
  .nav-link:active,
  .product-card:active {
    transform: scale(0.98);
    opacity: 0.9;
  }
  
  /* Remove hover effects on touch devices */
  .product-card:hover {
    transform: none;
  }
  
  .product-card:active {
    transform: scale(0.98);
  }
}

/* High contrast mode support */
@media (prefers-contrast: high) {
  :root {
    --text-primary: #000000;
    --text-secondary: #333333;
    --border-light: #000000;
  }
  
  .btn-outline {
    border-width: 3px;
  }
}

/* Dark mode support (if implemented) */
@media (prefers-color-scheme: dark) {
  /* Ready for dark mode implementation */
}

/* Print optimizations */
@media print {
  .nav-wrapper,
  .nav-mobile-toggle,
  .cart-drawer,
  .wishlist-drawer,
  .cart-overlay,
  .wishlist-overlay {
    display: none !important;
  }
  
  .page-content {
    padding-top: 0 !important;
  }
  
  .section {
    break-inside: avoid;
  }
}

/* ============================================
   HERO SLIDER TEXT & BUTTON FIXES (MOBILE/TABLET)
   Make text and buttons smaller to fit within white box
   ============================================ */

/* iPhone SE and smaller phones */
@media (max-width: 375px) {
  .slide.has-image .slide-content {
    padding: var(--spacing-sm) var(--spacing-md) !important;
    max-width: calc(100% - 24px) !important;
    margin: 0 12px !important;
  }
  
  .slide-content h1 {
    font-size: 1.25rem !important;
    line-height: 1.25 !important;
    margin-bottom: var(--spacing-xs) !important;
  }
  
  .slide-content p {
    font-size: 0.8rem !important;
    line-height: 1.4 !important;
    margin-bottom: var(--spacing-sm) !important;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
  }
  
  .slide-content .btn {
    padding: 8px 16px !important;
    font-size: 0.75rem !important;
  }
}

/* iPhone 12/13/14 and similar phones */
@media (min-width: 376px) and (max-width: 430px) {
  .slide.has-image .slide-content {
    padding: var(--spacing-md) !important;
    max-width: calc(100% - 32px) !important;
    margin: 0 16px !important;
  }
  
  .slide-content h1 {
    font-size: 1.4rem !important;
    line-height: 1.3 !important;
    margin-bottom: var(--spacing-xs) !important;
  }
  
  .slide-content p {
    font-size: 0.85rem !important;
    line-height: 1.45 !important;
    margin-bottom: var(--spacing-sm) !important;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
  }
  
  .slide-content .btn {
    padding: 10px 18px !important;
    font-size: 0.8rem !important;
  }
}

/* Phablets and small tablets */
@media (min-width: 431px) and (max-width: 576px) {
  .slide.has-image .slide-content {
    padding: var(--spacing-md) var(--spacing-lg) !important;
    max-width: calc(100% - 48px) !important;
    margin: 0 24px !important;
  }
  
  .slide-content h1 {
    font-size: 1.5rem !important;
    line-height: 1.3 !important;
    margin-bottom: var(--spacing-sm) !important;
  }
  
  .slide-content p {
    font-size: 0.9rem !important;
    line-height: 1.5 !important;
    margin-bottom: var(--spacing-sm) !important;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
  }
  
  .slide-content .btn {
    padding: 10px 20px !important;
    font-size: 0.85rem !important;
  }
}

/* Tablets (iPad Mini, iPad) */
@media (min-width: 577px) and (max-width: 834px) {
  .slide.has-image .slide-content {
    padding: var(--spacing-lg) !important;
    max-width: 80% !important;
    margin: 0 auto !important;
  }
  
  .slide-content h1 {
    font-size: 1.75rem !important;
    line-height: 1.3 !important;
    margin-bottom: var(--spacing-sm) !important;
  }
  
  .slide-content p {
    font-size: 0.95rem !important;
    line-height: 1.5 !important;
    margin-bottom: var(--spacing-md) !important;
  }
  
  .slide-content .btn {
    padding: 12px 24px !important;
    font-size: 0.9rem !important;
  }
}

/* iPad Air and iPad Pro */
@media (min-width: 835px) and (max-width: 1024px) {
  .slide.has-image .slide-content {
    padding: var(--spacing-lg) var(--spacing-xl) !important;
    max-width: 550px !important;
  }
  
  .slide-content h1 {
    font-size: 2rem !important;
    line-height: 1.25 !important;
  }
  
  .slide-content p {
    font-size: 1rem !important;
    line-height: 1.5 !important;
  }
  
  .slide-content .btn {
    padding: 12px 28px !important;
    font-size: 0.95rem !important;
  }
}

/* ============================================
   HAMBURGER MOBILE MENU - MODERN SLEEK DESIGN
   ============================================ */
@media (max-width: 768px) {
  /* Modern slide-in menu panel */
  .nav-menu {
    padding: 90px 20px 30px 20px !important;
    gap: 6px !important;
    background: linear-gradient(180deg, #ffffff 0%, #fefafa 100%) !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
  }
  
  .nav-menu li {
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    list-style: none !important;
  }
  
  /* Sleek, minimal nav links */
  .nav-link {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 100% !important;
    padding: 14px 20px !important;
    text-align: center !important;
    font-size: 1rem !important;
    font-weight: 500 !important;
    letter-spacing: 0.3px !important;
    border-radius: 10px !important;
    background: transparent !important;
    color: #444444 !important;
    border: none !important;
    transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1) !important;
    margin-bottom: 4px !important;
    text-decoration: none !important;
    box-sizing: border-box !important;
    position: relative !important;
  }
  
  .nav-link::before {
    content: '' !important;
    position: absolute !important;
    left: 0 !important;
    top: 50% !important;
    transform: translateY(-50%) scaleY(0) !important;
    width: 3px !important;
    height: 60% !important;
    background: linear-gradient(180deg, #f8c8dc 0%, #e896b0 100%) !important;
    border-radius: 0 4px 4px 0 !important;
    transition: transform 0.25s ease !important;
  }
  
  .nav-link:hover,
  .nav-link:focus {
    background: rgba(248, 200, 220, 0.15) !important;
    color: #333 !important;
    transform: translateX(4px) !important;
  }
  
  .nav-link:hover::before,
  .nav-link:focus::before {
    transform: translateY(-50%) scaleY(1) !important;
  }
  
  .nav-link.active {
    background: rgba(248, 200, 220, 0.25) !important;
    color: #222 !important;
    font-weight: 600 !important;
  }
  
  .nav-link.active::before {
    transform: translateY(-50%) scaleY(1) !important;
    background: linear-gradient(180deg, #e896b0 0%, #d77a9a 100%) !important;
  }
}

/* ============================================
   FOOTER MOBILE LAYOUT
   Quick Links (left), Customer Service (right), Contact (below)
   ============================================ */
@media (max-width: 576px) {
  .footer-grid {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    grid-template-rows: auto auto auto !important;
    gap: var(--spacing-lg) var(--spacing-md) !important;
    text-align: left !important;
  }
  
  /* Footer about section - full width on top */
  .footer-about {
    grid-column: 1 / -1 !important;
    text-align: center !important;
    margin-bottom: var(--spacing-sm);
  }
  
  .footer-brand {
    justify-content: center !important;
  }
  
  .footer-about p {
    max-width: 320px;
    margin: 0 auto var(--spacing-md);
    font-size: 0.85rem !important;
  }
  
  .footer-social {
    justify-content: center !important;
  }
  
  /* Quick Links - left column */
  .footer-column:nth-of-type(1) {
    grid-column: 1 !important;
    grid-row: 2 !important;
  }
  
  /* Customer Service - right column */
  .footer-column:nth-of-type(2) {
    grid-column: 2 !important;
    grid-row: 2 !important;
  }
  
  /* Contact Us - full width below */
  .footer-column:nth-of-type(3) {
    grid-column: 1 / -1 !important;
    grid-row: 3 !important;
    text-align: center !important;
    border-top: 1px solid rgba(255, 255, 255, 0.1);
    padding-top: var(--spacing-md);
  }
  
  .footer-column:nth-of-type(3) .footer-links {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--spacing-xs);
  }
  
  .footer-column h4 {
    font-size: 0.9rem !important;
    margin-bottom: var(--spacing-sm) !important;
  }
  
  .footer-links a,
  .footer-links li {
    font-size: 0.85rem !important;
  }
  
  .footer-bottom {
    margin-top: var(--spacing-md);
    padding-top: var(--spacing-md);
  }
}

/* Tablet footer layout */
@media (min-width: 577px) and (max-width: 768px) {
  .footer-grid {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: var(--spacing-lg) !important;
  }
  
  .footer-about {
    grid-column: 1 / -1 !important;
  }
  
  .footer-column:nth-of-type(1),
  .footer-column:nth-of-type(2) {
    grid-column: auto !important;
  }
  
  .footer-column:nth-of-type(3) {
    grid-column: 1 / -1 !important;
    text-align: center;
  }
  
  .footer-column:nth-of-type(3) .footer-links {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: var(--spacing-sm) var(--spacing-lg);
  }
}

/* ============================================
   SHOP PAGE - MODERN CLEAN FILTERS
   ============================================ */
@media (max-width: 992px) {
  .shop-sidebar {
    position: relative !important;
    width: 100% !important;
    margin-bottom: 20px !important;
    padding: 0 !important;
  }
  
  /* Modern minimal filter cards */
  .filter-card {
    border: none !important;
    border-radius: 16px !important;
    margin-bottom: 10px !important;
    overflow: visible !important;
    background: #ffffff !important;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04) !important;
  }
  
  .filter-card h3.filter-title,
  .filter-card .filter-title {
    cursor: pointer !important;
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    padding: 14px 18px !important;
    margin: 0 !important;
    background: linear-gradient(135deg, #fefefe 0%, #f9f9f9 100%) !important;
    font-size: 0.9rem !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
    user-select: none !important;
    transition: all 0.2s ease !important;
    color: #555 !important;
    border-radius: 12px !important;
    border: 1px solid #eee !important;
  }
  
  .filter-card h3.filter-title:hover,
  .filter-card .filter-title:hover {
    background: linear-gradient(135deg, #fff5f8 0%, #fef0f5 100%) !important;
    border-color: #f8c8dc !important;
  }
  
  .filter-card h3.filter-title::after,
  .filter-card .filter-title::after {
    content: '' !important;
    width: 8px !important;
    height: 8px !important;
    border-right: 2px solid #888 !important;
    border-bottom: 2px solid #888 !important;
    transform: rotate(45deg) !important;
    transition: transform 0.3s ease !important;
    margin-right: 4px !important;
  }
  
  .filter-card.collapsed h3.filter-title::after,
  .filter-card.collapsed .filter-title::after {
    transform: rotate(-45deg) !important;
  }
  
  .filter-card .filter-options {
    padding: 12px 16px 16px 16px !important;
    max-height: 500px !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    transition: max-height 0.35s ease-out, padding 0.35s ease-out, opacity 0.25s ease-out !important;
    opacity: 1 !important;
    background: #fff !important;
    border-radius: 0 0 12px 12px !important;
    margin-top: -8px !important;
    border: 1px solid #eee !important;
    border-top: none !important;
  }
  
  .filter-card.collapsed .filter-options {
    max-height: 0 !important;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
    opacity: 0 !important;
    overflow: hidden !important;
    border: none !important;
    margin-top: 0 !important;
  }
  
  /* Search filter card - always visible, special styling */
  .filter-card:first-child {
    border: none !important;
    background: transparent !important;
    box-shadow: none !important;
    margin-bottom: 16px !important;
  }
  
  .filter-card:first-child h3.filter-title {
    display: none !important;
  }
  
  .filter-card:first-child .filter-options {
    max-height: none !important;
    opacity: 1 !important;
    padding: 0 !important;
    border: none !important;
    margin-top: 0 !important;
    background: transparent !important;
  }
  
  /* Modern search input */
  .filter-card:first-child .search-box,
  .shop-sidebar .search-box {
    position: relative !important;
  }
  
  .filter-card:first-child .search-box input,
  .shop-sidebar .search-box input,
  #searchInput {
    width: 100% !important;
    padding: 14px 48px 14px 18px !important;
    border: 1px solid #e0e0e0 !important;
    border-radius: 12px !important;
    font-size: 0.95rem !important;
    background: #fff !important;
    transition: all 0.2s ease !important;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04) !important;
  }
  
  .filter-card:first-child .search-box input:focus,
  .shop-sidebar .search-box input:focus,
  #searchInput:focus {
    border-color: #f8c8dc !important;
    box-shadow: 0 0 0 3px rgba(248, 200, 220, 0.2), 0 2px 8px rgba(0, 0, 0, 0.06) !important;
    outline: none !important;
  }
  
  /* Modern filter options / checkboxes */
  .filter-option {
    display: flex !important;
    align-items: center !important;
    padding: 10px 12px !important;
    margin: 4px 0 !important;
    border-radius: 8px !important;
    cursor: pointer !important;
    transition: background 0.15s ease !important;
  }
  
  .filter-option:hover {
    background: #f8f8f8 !important;
  }
  
  .filter-option input[type="checkbox"] {
    width: 18px !important;
    height: 18px !important;
    margin-right: 12px !important;
    accent-color: #e896b0 !important;
    cursor: pointer !important;
  }
  
  .filter-option span {
    font-size: 0.9rem !important;
    color: #444 !important;
  }
  
  .filter-option:has(input:checked) {
    background: rgba(248, 200, 220, 0.15) !important;
  }
  
  .filter-option:has(input:checked) span {
    color: #333 !important;
    font-weight: 500 !important;
  }
}
