/* ============================================
   MOBILE RESPONSIVE STYLES FOR WEBSITE
   Complete mobile optimization for all pages
============================================ */

/* ============================================
   HEADER & NAVIGATION - MOBILE
   (Main rules live in style.css — only
    non-conflicting overrides here)
============================================ */
@media (max-width: 991px) {
    /* Cart and User Icons ordering */
    .nav-cart { order: 2; }
}

/* ============================================
   HERO SECTION - MOBILE
============================================ */
@media (max-width: 991px) {
    .hero-section {
        margin: 40px auto;
        padding: 0 25px;
    }

    .hero-content {
        grid-template-columns: 1fr;
        gap: 40px;
        padding: 50px 30px;
    }

    .hero-title {
        font-size: 38px;
    }

    .hero-description {
        font-size: 16px;
        margin-bottom: 30px;
    }

    .cta-button {
        padding: 16px 35px;
        font-size: 15px;
    }

    .hero-image {
        order: -1;
    }

    .floating-card {
        padding: 12px 20px;
    }

    .floating-card i {
        font-size: 20px;
    }

    .floating-card span {
        font-size: 12px;
    }

    .card-1 {
        top: 20px;
        left: -15px;
    }

    .card-2 {
        bottom: 20px;
        right: -15px;
    }
}

@media (max-width: 768px) {
    .hero-section {
        margin: 30px auto;
        padding: 0 20px;
    }

    .hero-content {
        padding: 40px 25px;
        gap: 30px;
    }

    .hero-title {
        font-size: 32px;
    }

    .hero-description {
        font-size: 15px;
        margin-bottom: 25px;
    }

    .cta-button {
        padding: 14px 30px;
        font-size: 14px;
    }

    .floating-card {
        padding: 10px 15px;
    }

    .floating-card i {
        font-size: 18px;
    }

    .floating-card span {
        font-size: 11px;
    }
}

@media (max-width: 576px) {
    .hero-content {
        padding: 30px 20px;
    }

    .hero-title {
        font-size: 28px;
    }

    .hero-description {
        font-size: 14px;
    }

    .cta-button {
        padding: 12px 25px;
        font-size: 13px;
        gap: 8px;
    }

    .floating-card {
        display: none;
    }
}

/* ============================================
   FEATURED CATEGORIES - MOBILE
============================================ */
@media (max-width: 991px) {
    .featured-categories {
        padding: 60px 0 40px;
    }

    .categories-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 20px;
    }

    .category-card {
        padding: 30px 20px;
    }

    .category-icon {
        width: 65px;
        height: 65px;
        font-size: 28px;
    }

    .category-card h4 {
        font-size: 18px;
    }

    .category-card p {
        font-size: 13px;
    }
}

@media (max-width: 576px) {
    .featured-categories {
        padding: 40px 0 30px;
    }

    .categories-grid {
        grid-template-columns: 1fr;
        gap: 15px;
    }

    .category-card {
        padding: 25px 15px;
    }

    .category-icon {
        width: 55px;
        height: 55px;
        font-size: 24px;
    }

    .category-card h4 {
        font-size: 16px;
    }
}

/* ============================================
   PRODUCTS SECTION - MOBILE
============================================ */
@media (max-width: 991px) {
    .products-section,
    .products-container {
        margin: 60px auto;
        padding: 0 25px;
    }

    .section-header {
        margin-bottom: 40px;
    }

    .section-title {
        font-size: 36px;
    }

    .section-subtitle {
        font-size: 16px;
    }

    .products-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 20px;
    }

    .product-card {
        border-radius: 15px;
    }

    .product-image {
        height: 220px;
    }

    .product-info {
        padding: 18px;
    }

    .product-name {
        font-size: 15px;
        min-height: 42px;
    }

    .product-price-current {
        font-size: 20px;
    }

    .product-price-old {
        font-size: 16px;
    }

    .quick-view-btn,
    .add-to-cart-btn {
        padding: 10px 20px;
        font-size: 13px;
    }

    .view-all-section {
        margin-top: 40px;
    }

    .view-all-btn {
        padding: 14px 35px;
        font-size: 15px;
    }
}

@media (max-width: 768px) {
    .products-section,
    .products-container {
        margin: 50px auto;
        padding: 0 20px;
    }

    .section-title {
        font-size: 30px;
    }

    .section-subtitle {
        font-size: 15px;
    }

    .products-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 15px;
    }

    .product-image {
        height: 180px;
    }

    .product-info {
        padding: 15px;
    }

    .product-name {
        font-size: 14px;
        min-height: 38px;
    }

    .product-price-current {
        font-size: 18px;
    }

    .product-rating .stars i {
        font-size: 12px;
    }

    .rating-count {
        font-size: 12px;
    }

    .badge {
        font-size: 10px;
        padding: 5px 10px;
    }

    .stock-status {
        font-size: 11px;
        padding: 5px 10px;
    }
}

@media (max-width: 576px) {
    .products-section,
    .products-container {
        margin: 40px auto;
        padding: 0 15px;
    }

    .section-badge {
        font-size: 12px;
        padding: 6px 16px;
    }

    .section-title {
        font-size: 26px;
    }

    .section-subtitle {
        font-size: 14px;
    }

    .products-grid {
        grid-template-columns: 1fr;
        gap: 20px;
    }

    .product-image {
        height: 250px;
    }

    .product-info {
        padding: 18px;
    }

    .product-name {
        font-size: 15px;
        min-height: auto;
    }

    .product-price-current {
        font-size: 20px;
    }

    .quick-view-btn,
    .add-to-cart-btn {
        padding: 12px 25px;
        font-size: 14px;
        gap: 8px;
    }

    /* Ensure overlay buttons have breathing room on mobile */
    .product-overlay {
        gap: 12px;
        padding: 16px;
    }

    /* Full-width buttons on small screens */
    .product-overlay .quick-view-btn,
    .product-overlay .add-to-cart-btn {
        width: 100%;
        justify-content: center;
    }

    .view-all-btn {
        padding: 12px 30px;
        font-size: 14px;
    }
}

/* ============================================
   FEATURES SECTION - MOBILE
============================================ */
@media (max-width: 991px) {
    .features-section {
        padding: 60px 0;
    }

    .features-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 20px;
    }

    .feature-card {
        padding: 30px 15px;
    }

    .feature-icon {
        width: 60px;
        height: 60px;
        font-size: 24px;
    }

    .feature-card h4 {
        font-size: 18px;
    }

    .feature-card p {
        font-size: 13px;
    }
}

@media (max-width: 576px) {
    .features-section {
        padding: 40px 0;
    }

    .features-grid {
        grid-template-columns: 1fr;
        gap: 15px;
    }

    .feature-card {
        padding: 25px 15px;
    }

    .feature-icon {
        width: 55px;
        height: 55px;
        font-size: 22px;
    }

    .feature-card h4 {
        font-size: 16px;
    }
}

/* ============================================
   PRODUCT DETAIL PAGE - MOBILE
============================================ */
@media (max-width: 991px) {
    .product-detail {
        grid-template-columns: 1fr;
        border-radius: 15px;
    }

    .image-section {
        padding: 25px;
    }

    .main-image {
        width: 100% !important;
        height: 350px !important;
        max-width: 100%;
    }

    .thumbnail-images {
        max-width: 100%;
    }

    .info-section {
        padding: 30px 25px;
    }

    .product-title {
        font-size: 28px;
    }

    .current-price {
        font-size: 32px;
    }

    .original-price {
        font-size: 20px;
    }

    .info-cards {
        grid-template-columns: 1fr;
        gap: 10px;
    }
}

@media (max-width: 768px) {
    .breadcrumb {
        font-size: 12px;
        flex-wrap: wrap;
    }

    .image-section {
        padding: 20px;
    }

    .main-image {
        height: 300px !important;
    }

    .thumbnail {
        height: 60px;
    }

    .info-section {
        padding: 25px 20px;
    }

    .product-title {
        font-size: 24px;
    }

    .current-price {
        font-size: 28px;
    }

    .original-price {
        font-size: 18px;
    }

    .description {
        font-size: 13px;
    }

    .features li {
        font-size: 13px;
    }

    .action-buttons {
        flex-direction: column;
    }

    .btn {
        width: 100%;
    }

    .btn-icon {
        width: 100%;
        height: 48px;
    }
}

@media (max-width: 576px) {
    .main-image {
        height: 250px !important;
    }

    .thumbnail-images {
        grid-template-columns: repeat(3, 1fr);
    }

    .product-title {
        font-size: 20px;
    }

    .current-price {
        font-size: 24px;
    }

    .original-price {
        font-size: 16px;
    }

    .discount-badge {
        font-size: 11px;
        padding: 3px 10px;
    }
}

/* ============================================
   CONTACT SECTION - MOBILE
============================================ */
@media (max-width: 991px) {
    .contact-section {
        margin: 60px auto;
        padding: 0 25px;
    }

    .contact-wrapper {
        grid-template-columns: 1fr;
        border-radius: 20px;
    }

    .contact-map {
        height: 350px;
        order: 2;
    }

    .contact-form {
        padding: 40px 30px;
        order: 1;
    }

    .form-group input,
    .form-group textarea {
        padding: 16px 18px 16px 45px;
        font-size: 14px;
    }

    .form-group i {
        left: 18px;
        font-size: 15px;
    }

    .submit-btn {
        padding: 16px;
        font-size: 15px;
    }
}

@media (max-width: 768px) {
    .contact-section {
        margin: 50px auto;
        padding: 0 20px;
    }

    .contact-map {
        height: 300px;
    }

    .contact-form {
        padding: 30px 25px;
    }

    .form-group {
        margin-bottom: 20px;
    }

    .form-group input,
    .form-group textarea {
        padding: 14px 16px 14px 42px;
        font-size: 13px;
    }

    .submit-btn {
        padding: 14px;
        font-size: 14px;
    }
}

@media (max-width: 576px) {
    .contact-section {
        margin: 40px auto;
        padding: 0 15px;
    }

    .contact-map {
        height: 250px;
    }

    .contact-form {
        padding: 25px 20px;
    }
}

/* ============================================
   FOOTER - MOBILE
============================================ */
@media (max-width: 991px) {
    .footer-section {
        margin: 60px 25px 25px;
        padding: 50px 0 25px;
        border-radius: 20px;
    }

    .footer-container {
        padding: 0 30px;
    }

    .footer-content {
        grid-template-columns: 1fr;
        gap: 35px;
        text-align: center;
    }

    .footer-column {
        display: flex;
        flex-direction: column;
        align-items: center;
    }

    .newsletter-form {
        flex-direction: column;
        max-width: 400px;
        margin: 0 auto;
    }

    .newsletter-form input,
    .newsletter-form button {
        width: 100%;
    }

    .contact-info {
        align-items: center;
    }

    .social-links {
        gap: 15px;
    }

    .social-links a {
        width: 45px;
        height: 45px;
    }
}

@media (max-width: 768px) {
    .footer-section {
        margin: 50px 20px 20px;
        padding: 40px 0 20px;
    }

    .footer-container {
        padding: 0 25px;
    }

    .footer-top h6 {
        font-size: 15px;
    }

    .footer-column h6 {
        font-size: 15px;
    }

    .footer-column p {
        font-size: 13px;
    }

    .newsletter-form input,
    .newsletter-form button {
        padding: 10px 18px;
        font-size: 13px;
    }

    .contact-info a {
        font-size: 13px;
    }

    .footer-bottom p {
        font-size: 13px;
    }
}

@media (max-width: 576px) {
    .footer-section {
        margin: 40px 15px 15px;
        padding: 30px 0 15px;
    }

    .footer-container {
        padding: 0 20px;
    }

    .footer-content {
        gap: 30px;
    }

    .social-links a {
        width: 40px;
        height: 40px;
        font-size: 16px;
    }

    .contact-info i {
        width: 30px;
        height: 30px;
        font-size: 14px;
    }
}

/* ============================================
   ALL PRODUCTS PAGE - MOBILE
============================================ */
@media (max-width: 991px) {
    .page-header-section {
        padding: 60px 0 40px;
    }

    .page-title {
        font-size: 38px;
    }

    .page-subtitle {
        font-size: 16px;
    }

    .filters-section {
        padding: 25px 0;
    }

    .filters-wrapper {
        flex-direction: column;
        align-items: stretch;
        gap: 15px;
    }

    .search-box {
        max-width: 100%;
    }

    .filter-buttons {
        justify-content: center;
        gap: 8px;
    }

    .filter-btn {
        padding: 10px 20px;
        font-size: 13px;
    }

    .sort-dropdown {
        margin-left: 0;
    }

    .sort-select {
        width: 100%;
    }
}

@media (max-width: 768px) {
    .page-header-section {
        padding: 50px 0 35px;
    }

    .page-title {
        font-size: 32px;
    }

    .page-subtitle {
        font-size: 15px;
    }

    .breadcrumb-nav {
        font-size: 13px;
        padding: 8px 20px;
    }

    .filters-section {
        padding: 20px 0;
    }

    .search-input {
        padding: 12px 18px 12px 45px;
        font-size: 14px;
    }

    .filter-btn {
        padding: 9px 18px;
        font-size: 12px;
    }

    .sort-select {
        padding: 10px 35px 10px 18px;
        font-size: 13px;
    }

    .wishlist-btn {
        width: 36px;
        height: 36px;
    }

    .wishlist-btn i {
        font-size: 16px;
    }
}

@media (max-width: 576px) {
    .page-header-section {
        padding: 40px 0 30px;
    }

    .page-title {
        font-size: 26px;
    }

    .page-subtitle {
        font-size: 14px;
    }

    .breadcrumb-nav {
        font-size: 12px;
        padding: 7px 18px;
    }

    .filters-section {
        padding: 15px 0;
    }

    .search-input {
        padding: 11px 16px 11px 42px;
        font-size: 13px;
    }

    .filter-buttons {
        gap: 6px;
    }

    .filter-btn {
        padding: 8px 16px;
        font-size: 11px;
    }

    .sort-select {
        padding: 9px 32px 9px 16px;
        font-size: 12px;
    }

    .results-info {
        font-size: 13px;
    }

    .no-results-icon {
        font-size: 60px;
    }

    .no-results h3 {
        font-size: 22px;
    }

    .no-results p {
        font-size: 14px;
    }
}

/* ============================================
   PAGINATION - MOBILE
============================================ */
@media (max-width: 768px) {
    .pagination-wrapper {
        margin-top: 40px;
    }

    .pagination-wrapper .pagination {
        gap: 8px;
    }

    .pagination-wrapper .page-link {
        min-width: 40px;
        height: 40px;
        font-size: 14px;
        padding: 0 12px;
    }
}

@media (max-width: 576px) {
    .pagination-wrapper {
        margin-top: 30px;
    }

    .pagination-wrapper .pagination {
        gap: 6px;
        flex-wrap: wrap;
        justify-content: center;
    }

    .pagination-wrapper .page-link {
        min-width: 36px;
        height: 36px;
        font-size: 13px;
        padding: 0 10px;
    }
}

/* ============================================
   REVIEWS SECTION - MOBILE
============================================ */
@media (max-width: 991px) {
    .reviews-container {
        margin: 50px auto;
        padding: 0 25px;
    }

    .add-review-section {
        padding: 25px;
    }

    .reviews-list {
        grid-template-columns: 1fr;
        gap: 20px;
    }

    .review-card {
        padding: 20px;
    }
}

@media (max-width: 768px) {
    .reviews-container {
        margin: 40px auto;
        padding: 0 20px;
    }

    .add-review-section {
        padding: 20px;
    }

    .star-rating i {
        font-size: 20px;
    }

    .reviews-list-title {
        font-size: 20px;
    }

    .review-card {
        padding: 18px;
    }

    .review-header h4 {
        font-size: 15px;
    }

    .review-text {
        font-size: 13px;
    }

    .action-btn {
        padding: 7px 12px;
        font-size: 11px;
    }
}

@media (max-width: 576px) {
    .reviews-container {
        margin: 30px auto;
        padding: 0 15px;
    }

    .add-review-section {
        padding: 18px;
    }

    .star-rating i {
        font-size: 18px;
    }

    .reviews-list-title {
        font-size: 18px;
    }

    .review-card {
        padding: 15px;
    }
}

/* ============================================
   NOTIFICATION TOAST - MOBILE
============================================ */
@media (max-width: 768px) {
    .notification-toast {
        min-width: auto;
        max-width: calc(100% - 40px);
        right: -100%;
        padding: 15px 20px;
    }

    .notification-toast.show {
        right: 20px;
    }

    .notification-toast i {
        font-size: 20px;
    }

    .notification-toast span {
        font-size: 14px;
    }
}

@media (max-width: 576px) {
    .notification-toast {
        top: 80px;
        left: 15px;
        right: 15px;
        max-width: none;
    }

    .notification-toast.show {
        right: 15px;
    }

    .notification-toast i {
        font-size: 18px;
    }

    .notification-toast span {
        font-size: 13px;
    }
}

/* ============================================
   UTILITY CLASSES - MOBILE
============================================ */
@media (max-width: 991px) {
    .container {
        padding: 0 25px;
    }
}

@media (max-width: 768px) {
    .container {
        padding: 0 20px;
    }
}

@media (max-width: 576px) {
    .container {
        padding: 0 15px;
    }
}

/* ============================================
   TOUCH IMPROVEMENTS
============================================ */
@media (hover: none) and (pointer: coarse) {
    /* Increase tap targets for mobile */
    .nav-menu a,
    .nav-link-btn,
    .logout-button,
    .filter-btn,
    .btn,
    .quick-view-btn,
    .add-to-cart-btn {
        min-height: 44px;
        min-width: 44px;
    }

    /* Remove hover effects on touch devices */
    .product-card:hover {
        transform: none;
    }

    .product-overlay {
        opacity: 1;
        background: rgba(26, 26, 46, 0.7);
    }

    /* Make buttons more touch-friendly */
    .cart-icon,
    .nav-link,
    .wishlist-btn {
        padding: 8px;
    }
}

/* ============================================
   LANDSCAPE ORIENTATION
============================================ */
@media (max-height: 600px) and (orientation: landscape) {
    .hero-content {
        padding: 30px 25px;
    }

    .hero-title {
        font-size: 28px;
    }

    .hero-description {
        font-size: 14px;
        margin-bottom: 20px;
    }

    .nav-menu {
        height: calc(100vh - 60px);
        padding: 20px 25px;
    }

    .floating-card {
        display: none;
    }
}

/* ============================================
   PRINT STYLES
============================================ */
@media print {
    .modern-header,
    .mobile-menu-toggle,
    .nav-actions,
    .cart-icon,
    .footer-section,
    .contact-section,
    .cta-button,
    .quick-view-btn,
    .add-to-cart-btn,
    .wishlist-btn,
    .filters-section {
        display: none !important;
    }

    .product-card,
    .category-card,
    .feature-card {
        break-inside: avoid;
    }
}
