﻿.veg-nonveg-btn {
  padding: 0.5rem 1rem;
  background: #fcf1cc;
  border: 2px solid #F2BD12;
  border-radius: 1rem;
  color: #212121;
  margin: 0 0.3rem;
  cursor: pointer;
  font-weight: 700;
  transition: 0.2s;
}
.veg-nonveg-btn.active,
.veg-nonveg-btn:hover {
  background: #F2BD12;
  color: #fff;
}

/* ======================================================== */
/* Responsive Layout for Search Results / Menu Page         */
/* ======================================================== */

/* 1024px: Tablets and smaller laptops */
@media screen and (max-width: 1024px) {
  .filter-bar {
    justify-content: center;
    gap: 1rem;
    padding: 0 1rem;
    width: 100%;
    box-sizing: border-box;
  }
  
  .filter-bar input,
  .filter-bar .custom-select,
  .filter-bar button {
    flex: 1 1 calc(33.333% - 1rem); /* ~3 elements per row */
    min-width: 200px;
    font-size: 0.95rem; /* switch to rem-based size */
  }

  .card-list {
    gap: 1.5rem;
    padding: 0 1rem;
  }
}

/* 768px: Mobile layouts, tablets landscape/portrait */
@media screen and (max-width: 768px) {
  .filter-bar {
    flex-direction: column;
    align-items: stretch;
    padding: 0 1.5rem;
  }

  .filter-bar input#search,
  .filter-bar .custom-select,
  .filter-bar button,
  .veg-nonveg-btn,
  .fav-toggle {
    width: 100%;
    flex: 1 1 100%;
    max-width: 100%;
    margin: 0.25rem 0; /* consistent vertical spacing */
    box-sizing: border-box;
    height: 45px; /* Larger hit area */
    font-size: 1rem;
  }
  
  .card-list {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    width: 100%;
    padding: 0 1.5rem;
    box-sizing: border-box;
  }

  .order-card {
    flex-basis: auto; /* let grid handle sizing */
    width: 100%;
    max-width: 100%;
    margin: 0;
  }
  
  .order-card img {
    max-width: 100%;
    height: auto;
    object-fit: contain;
  }
}

/* 480px: Small mobile devices */
@media screen and (max-width: 480px) {
  .filter-bar {
    padding: 0 1rem;
  }
  
  .filter-bar input#search,
  .filter-bar .custom-select,
  .filter-bar button,
  .veg-nonveg-btn,
  .fav-toggle {
    height: 3rem; /* Increase touch target area for a11y */
    border-radius: 1.5rem; /* Match taller buttons */
  }

  .card-list {
    padding: 0 1rem;
    grid-template-columns: 1fr; /* 1 card per row */
  }

  .order-card {
    padding: 1rem;
    border-radius: 1.5rem;
  }
  
  .order-card img {
    width: 80%; /* Shrink image on very small screens */
    margin: 0 auto;
    display: block;
  }

  .order-card h4 {
    font-size: 1.25rem; /* slightly smaller headers */
    text-align: center;
  }
  
  .order-card .price {
    font-size: 1.2rem;
    text-align: center;
    padding: 0.5rem 0 1rem 0;
  }
}
