/* Mobile Menu Toggle */
.menu-toggle {
    display: none;
    color: #fff;
    cursor: pointer;
    background: transparent;
    padding: 10px;
    z-index: 1002;
    transition: var(--transition);
}

.menu-toggle svg {
    display: block;
    width: 24px;
    height: 24px;
    stroke: currentColor;
}

.menu-toggle:hover {
    color: var(--color-gold);
}

.close-menu {
    display: none;
    position: absolute;
    top: 20px;
    right: 20px;
    font-size: 2rem;
    color: #fff;
    background: transparent;
    border: none;
    cursor: pointer;
    z-index: 1003;
}

/* Mobile Adjustments */
@media (max-width: 768px) {
    .menu-toggle {
        display: block;
        /* Ensure it's visible */
        order: 1;
        /* Position it first if flex direction is row, but we want it left */
    }

    /* Reorder Nav for Mobile: Toggle -> Logo -> Group(Lang, Cart) */
    nav {
        display: flex;
        justify-content: space-between;
        align-items: center;
        width: 100%;
        padding: 0 10px;
    }

    .logo {
        font-size: 1.1rem;
        order: 2;
        margin: 0;
        text-align: center;
        flex-grow: 1;
        white-space: nowrap;
    }

    .menu-toggle {
        display: block;
        order: 1;
        padding-left: 0;
    }

    /* Cart/Lang container position */
    nav>div[style*="display: flex"] {
        order: 3;
        gap: 8px !important;
    }

    .lang-btn {
        padding: 4px 8px !important;
        font-size: 0.75rem !important;
    }

    .lang-btn svg {
        width: 14px;
        height: 14px;
    }

    /* Mobile Menu Overlay */
    .nav-links {
        display: flex;
        /* Overriding display:none from previous rules if any */
        position: fixed;
        top: 0;
        left: 0;
        width: 100%;
        height: 100vh;
        background: rgba(5, 5, 5, 0.98);
        backdrop-filter: blur(15px);
        flex-direction: column;
        justify-content: center;
        align-items: center;
        z-index: 2000;
        transform: translateX(-100%);
        /* Start hidden to the left */
        transition: transform 0.5s cubic-bezier(0.77, 0, 0.175, 1);
        gap: 30px;
        opacity: 0;
        visibility: hidden;
    }

    .nav-links.active {
        transform: translateX(0);
        opacity: 1;
        visibility: visible;
    }

    .nav-link {
        font-size: 1.5rem;
        /* Larger touch targets */
        opacity: 0;
        transform: translateY(20px);
        transition: opacity 0.4s ease, transform 0.4s ease;
    }

    /* Stagger Animation for links when menu opens */
    .nav-links.active .nav-link {
        opacity: 1;
        transform: translateY(0);
    }

    .nav-links.active .nav-link:nth-child(2) {
        transition-delay: 0.1s;
    }

    .nav-links.active .nav-link:nth-child(3) {
        transition-delay: 0.2s;
    }

    .nav-links.active .nav-link:nth-child(4) {
        transition-delay: 0.3s;
    }

    .nav-links.active .nav-link:nth-child(5) {
        transition-delay: 0.4s;
    }

    .close-menu {
        display: block;
    }

    /* Hero Text Adjustments */
    .hero-title {
        font-size: 2.2rem;
        /* Smaller for mobile */
        margin-top: 15px;
        line-height: 1.3;
    }

    .hero-bg {
        background-position: center;
    }

    /* Grid Adjustments */
    .features-grid {
        grid-template-columns: 1fr;
        gap: 20px;
    }

    .product-grid {
        grid-template-columns: repeat(2, 1fr);
        /* Two columns for mobile if possible */
        gap: 15px;
        padding: 0 10px;
    }

    /* For very small screens, go back to 1 column */
    @media (max-width: 480px) {
        .product-grid {
            grid-template-columns: 1fr;
        }
    }

    .product-card {
        max-width: 100%;
    }

    .product-image {
        height: 350px;
    }

    .product-info {
        padding: 20px 15px;
    }

    .product-name {
        font-size: 1.6rem;
    }

    .size-selector {
        flex-wrap: wrap;
    }

    .size-option {
        padding: 8px 15px;
        font-size: 0.85rem;
    }

    /* Cart Sidebar Width */
    .cart-sidebar {
        width: 100%;
        max-width: 100%;
    }

    /* Footer Social Links */
    .social-links {
        flex-wrap: wrap;
        gap: 15px;
    }

    .social-link {
        font-size: 0.8rem;
        padding: 5px 10px;
        background: rgba(255, 255, 255, 0.05);
        border-radius: 4px;
    }

    /* Contact Section Mobile Fixes */
    #contact .container>div {
        grid-template-columns: 1fr !important;
        text-align: center !important;
        gap: 30px !important;
    }

    #contact div[style*="text-align: right"] {
        text-align: center !important;
    }

    /* Modal padding for small screens */
    .modal {
        padding: 10px;
    }

    .modal-content {
        max-height: 95vh;
    }

    .modal-body {
        padding: 20px 15px;
    }
}