/*
 * BurgerBlitz – Main Stylesheet
 * Author  : Attanodsc
 * Version : 2.0
 * Concept : Bold Urban Street-Food — angular shapes, dark navbar, yellow accents
 *
 * TABLE OF CONTENTS
 * -----------------
 *  01. CSS Variables .............. :root color/font tokens
 *  02. General / Reset ............ base body, links, images
 *  03. Accessibility .............. skip-link, focus-visible
 *  04. Preloader .................. full-screen spinner
 *  05. Back to Top Button ......... floating scroll-up button
 *  06. Buttons .................... .btn-primary-custom etc.
 *  07. Topbar ..................... dark info bar above navbar
 *  08. Navbar ..................... dark bg, yellow accents
 *  09. Page Header (Sub-pages) .... hero strip with yellow bar
 *  10. Hero Swiper ................ homepage banner slider
 *  11. Category Cards ............. angular hover cards
 *  12. Menu Page .................. yellow border items
 *  13. Contact Page ............... feedback form + map
 *  14. App Section ................ dark download CTA
 *  15. Footer ..................... dark with yellow accents
 *  16. Gallery Page ............... angular image grid
 *  17. Blog Page .................. horizontal card layout
 *  18. Chefs Page ................. dark team cards
 *  19. Offers Page ................ deal badges
 *  20. FAQ Accordion .............. overrides
 *  21. Cart Utilities ............. used by cart.js
 *  22. Admin Panel ................ dashboard, orders, reservations
 *  23. Utility Classes ............ moved from inline styles
 *  24. Responsive Breakpoints ..... @media queries
 * -----------------
 */

/* -------------------------------------------
   CSS VARIABLES (Easy Customization)
------------------------------------------- */
:root {
  --primary-color: #FFC72C;    /* Bold Golden Yellow */
  --primary-hover: #EBB015;    /* Darker Gold for hover */
  --accent-color: #E51937;     /* Vibrant Red accent */
  --accent-hover: #C4122C;     /* Darker Red */
  --dark-color: #1A1A1A;       /* True Black */
  --dark-medium: #2D2D2D;      /* Medium Dark */
  --light-color: #FAFAFA;      /* Clean White */
  --body-color: #555;          /* Body Text */
  --border-radius: 8px;        /* Sharper than PizzaCraft's 50px pills */
  --font-main: 'Poppins', sans-serif;
  --font-display: 'Oswald', sans-serif;
  --transition-speed: 0.3s;
}

/* -------------------------------------------
   GENERAL
------------------------------------------- */
body {
  font-family: var(--font-main);
  background-color: var(--light-color);
  color: var(--body-color);
  overflow-x: hidden;
}

::selection { background-color: var(--primary-color); color: var(--dark-color); }
::-moz-selection { background-color: var(--primary-color); color: var(--dark-color); }

h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-display);
  font-weight: 800;
  color: var(--dark-color);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.text-white h1, .text-white h2, .text-white h3,
.text-white h4, .text-white h5, .text-white h6 { color: #fff; }
.bg-dark h1, .bg-dark h2, .bg-dark h3,
.bg-dark h4, .bg-dark h5, .bg-dark h6 { color: #fff; }

img { max-width: 100%; height: auto; }

/* -------------------------------------------
   ACCESSIBILITY
------------------------------------------- */
.skip-link {
  position: absolute;
  top: -100%;
  left: 16px;
  z-index: 10000;
  padding: 12px 24px;
  background: var(--primary-color);
  color: var(--dark-color);
  font-weight: 700;
  border-radius: 0 0 var(--border-radius) var(--border-radius);
  transition: top 0.3s ease;
}
.skip-link:focus { top: 0; color: var(--dark-color); }
*:focus-visible { outline: 3px solid var(--primary-color); outline-offset: 2px; }

/* -------------------------------------------
   PRELOADER
------------------------------------------- */
#preloader {
  position: fixed;
  top: 0; left: 0;
  width: 100%; height: 100%;
  background: var(--dark-color);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 99999;
  transition: opacity 0.5s ease, visibility 0.5s ease;
}
#preloader.loaded { opacity: 0; visibility: hidden; }
.spinner {
  width: 48px; height: 48px;
  border: 5px solid var(--dark-medium);
  border-top: 5px solid var(--primary-color);
  border-radius: 50%;
  animation: spin 0.7s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }

/* -------------------------------------------
   BACK TO TOP BUTTON
------------------------------------------- */
.back-to-top {
  position: fixed;
  bottom: 30px; right: 30px;
  width: 50px; height: 50px;
  background: var(--primary-color);
  color: var(--dark-color);
  border-radius: var(--border-radius);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.2rem;
  box-shadow: 0 4px 15px rgba(255, 199, 44, 0.4);
  opacity: 0; visibility: hidden;
  transform: translateY(20px);
  transition: all var(--transition-speed) ease;
  z-index: 9999;
}
.back-to-top.active { opacity: 1; visibility: visible; transform: translateY(0); }
.back-to-top:hover { background: var(--primary-hover); color: var(--dark-color); transform: translateY(-3px); }

/* -------------------------------------------
   BUTTONS (Angular, chunky — NOT pill-shaped)
------------------------------------------- */
.btn-primary-custom {
  background-color: var(--primary-color);
  color: var(--dark-color);
  border: 2px solid var(--primary-color);
  padding: 14px 32px;
  border-radius: var(--border-radius);
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 0.95rem;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  box-shadow: 0 4px 15px rgba(255, 199, 44, 0.3);
  transition: all var(--transition-speed);
}
.btn-primary-custom:hover {
  background-color: var(--primary-hover);
  border-color: var(--primary-hover);
  color: var(--dark-color);
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(255, 199, 44, 0.4);
}

.btn-accent-custom {
  background-color: var(--accent-color);
  color: #fff;
  border: 2px solid var(--accent-color);
  padding: 14px 32px;
  border-radius: var(--border-radius);
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 0.95rem;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  box-shadow: 0 4px 15px rgba(229, 25, 55, 0.2);
  transition: all var(--transition-speed);
}
.btn-accent-custom:hover {
  background-color: var(--accent-hover);
  border-color: var(--accent-hover);
  color: #fff;
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(229, 25, 55, 0.3);
}

.btn-outline-custom {
  background: transparent;
  color: var(--dark-color);
  border: 2px solid var(--dark-color);
  padding: 14px 32px;
  border-radius: var(--border-radius);
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 0.95rem;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  transition: all var(--transition-speed);
}
.btn-outline-custom:hover {
  background: var(--dark-color);
  color: var(--primary-color);
}

.btn-outline-light-custom {
  background: transparent;
  color: #fff;
  border: 2px solid #fff;
  padding: 14px 32px;
  border-radius: var(--border-radius);
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 0.95rem;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  transition: all var(--transition-speed);
}
.btn-outline-light-custom:hover { background: #fff; color: var(--dark-color); }

/* Keep old class name for backwards compat */
.btn-secondary-custom {
  background-color: var(--primary-color);
  color: var(--dark-color);
  border: 2px solid var(--primary-color);
  padding: 14px 32px;
  border-radius: var(--border-radius);
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 0.95rem;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  transition: all var(--transition-speed);
}
.btn-secondary-custom:hover {
  background-color: var(--primary-hover);
  border-color: var(--primary-hover);
  color: var(--dark-color);
  transform: translateY(-2px);
}

/* -------------------------------------------
   TOPBAR (Dark strip above navbar)
------------------------------------------- */
.topbar {
  background-color: var(--dark-medium);
  color: rgba(255,255,255,0.7);
  font-size: 0.82rem;
  padding: 8px 0;
  border-bottom: 1px solid rgba(255,255,255,0.08);
}
.topbar a {
  color: rgba(255,255,255,0.6);
  text-decoration: none;
  margin-left: 12px;
  transition: color var(--transition-speed);
}
.topbar a:hover { color: var(--primary-color); }
.topbar .border-start { border-color: rgba(255,255,255,0.15) !important; }

/* -------------------------------------------
   NAVBAR (Dark background, yellow accents — distinct from PizzaCraft)
------------------------------------------- */
.navbar {
  background-color: var(--dark-color) !important;
  box-shadow: 0 4px 20px rgba(0,0,0,0.3);
  padding: 12px 0;
}
.navbar-brand {
  font-family: var(--font-display);
  font-size: 2rem;
  font-weight: 900;
  color: var(--primary-color) !important;
  letter-spacing: 1px;
  text-transform: uppercase;
}
.navbar-brand span { color: #fff !important; }
.navbar .nav-link {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 0.9rem;
  color: rgba(255,255,255,0.85) !important;
  padding: 8px 16px !important;
  margin: 0 2px;
  border-radius: var(--border-radius);
  text-transform: uppercase;
  letter-spacing: 1px;
  transition: 0.3s;
}
.navbar .nav-link:hover { color: var(--primary-color) !important; background: rgba(255,255,255,0.05); }
.navbar .nav-link.active { color: var(--primary-color) !important; background: rgba(255,199,44,0.1); }
.navbar .dropdown-menu {
  background: var(--dark-medium);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: var(--border-radius);
  padding: 10px 0;
}
.navbar .dropdown-item {
  color: rgba(255,255,255,0.8);
  font-weight: 500;
  padding: 8px 20px;
}
.navbar .dropdown-item:hover,
.navbar .dropdown-item.active {
  background: rgba(255,199,44,0.15);
  color: var(--primary-color);
}
.navbar .dropdown-divider { border-color: rgba(255,255,255,0.1); }
.navbar-toggler {
  border-color: rgba(255,255,255,0.3);
  padding: 6px 10px;
}
.navbar-toggler-icon {
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba(255,199,44,1)' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");
}

/* Cart icon override for dark navbar */
.navbar .btn-outline-custom {
  color: #fff;
  border-color: rgba(255,255,255,0.3);
}
.navbar .btn-outline-custom:hover {
  background: rgba(255,255,255,0.1);
  border-color: var(--primary-color);
  color: var(--primary-color);
}

/* -------------------------------------------
   PAGE HEADER (Sub-pages) — Yellow accent bar
------------------------------------------- */
.page-header {
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  padding: 130px 0 70px;
  color: #fff;
  text-align: left;
  position: relative;
}
.page-header::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0; bottom: 0;
  background: linear-gradient(135deg, rgba(26,26,26,0.95) 0%, rgba(26,26,26,0.6) 100%);
}
.page-header .container { position: relative; z-index: 2; }
.page-header h1 {
  color: #fff;
  font-size: 3.5rem;
  display: inline-block;
  position: relative;
}
.page-header h1::after {
  content: "";
  display: block;
  width: 60px;
  height: 4px;
  background: var(--primary-color);
  margin-top: 15px;
}
.page-header p { color: rgba(255,255,255,0.7); }

/* -------------------------------------------
   HERO SWIPER (Bolder, darker overlay)
------------------------------------------- */
.hero-swiper { width: 100%; height: 550px; }
.hero-slide {
  background-size: cover;
  background-position: center;
  position: relative;
  width: 100%;
  height: 100%;
}
.hero-slide::before {
  content: "";
  position: absolute;
  top: 0; left: 0; width: 100%; height: 100%;
  background: linear-gradient(to right, rgba(26,26,26,0.95) 0%, rgba(26,26,26,0.3) 60%, transparent 100%);
}
.hero-slide-content {
  position: absolute;
  top: 50%;
  left: 0;
  right: 0;
  transform: translateY(-50%);
  z-index: 2;
  padding: 20px 0;
}
.hero-slide-content h1,
.hero-slide-content h2 {
  color: #fff !important;
  font-size: 3.5rem;
  line-height: 1.1;
}
.hero-slide-content p { color: rgba(255,255,255,0.8) !important; }

/* Yellow stripe accent for hero badges */
.hero-badge {
  display: inline-block;
  background: var(--primary-color);
  color: var(--dark-color);
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 0.85rem;
  padding: 6px 18px;
  letter-spacing: 2px;
  text-transform: uppercase;
  margin-bottom: 15px;
}

/* Swiper navigation arrows — white */
.hero-swiper .swiper-button-next,
.hero-swiper .swiper-button-prev {
  color: #fff;
}
.hero-swiper .swiper-button-next:hover,
.hero-swiper .swiper-button-prev:hover {
  color: var(--primary-color);
}
.hero-swiper .swiper-pagination-bullet { background: rgba(255,255,255,0.5); }
.hero-swiper .swiper-pagination-bullet-active { background: var(--primary-color); }

/* -------------------------------------------
   CATEGORY CARDS (Angular, bold borders)
------------------------------------------- */
.category-card {
  background: #fff;
  border: 2px solid transparent;
  border-radius: var(--border-radius);
  padding: 30px 20px;
  text-align: center;
  box-shadow: 0 5px 20px rgba(0,0,0,0.04);
  transition: 0.3s;
  cursor: pointer;
  position: relative;
  overflow: hidden;
}
.category-card::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 4px;
  background: var(--primary-color);
  transform: scaleX(0);
  transition: transform 0.3s ease;
}
.category-card:hover::before { transform: scaleX(1); }
.category-card:hover {
  transform: translateY(-8px);
  box-shadow: 0 15px 40px rgba(0,0,0,0.08);
  border-color: var(--primary-color);
}
.category-card img {
  width: 120px; height: 120px;
  object-fit: cover;
  border-radius: var(--border-radius);
  border: 3px solid var(--primary-color);
  margin-bottom: 18px;
}

/* -------------------------------------------
   MENU PAGE (Yellow left border accent)
------------------------------------------- */
.menu-sidebar-link {
  display: block;
  padding: 12px 20px;
  border-radius: var(--border-radius);
  color: var(--dark-color);
  text-decoration: none;
  font-weight: 600;
  border-left: 3px solid transparent;
  transition: 0.3s;
}
.menu-sidebar-link:hover,
.menu-sidebar-link.active {
  background: rgba(255,199,44,0.1);
  color: var(--dark-color);
  border-left-color: var(--primary-color);
}

.product-card {
  background: #fff;
  border-radius: var(--border-radius);
  overflow: hidden;
  box-shadow: 0 3px 15px rgba(0,0,0,0.05);
  border: 1px solid rgba(0,0,0,0.06);
  transition: 0.3s;
}
.product-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 25px rgba(0,0,0,0.1);
  border-color: var(--primary-color);
}
.product-card__img {
  width: 100%;
  height: 200px;
  object-fit: cover;
}
.product-card__body { padding: 20px; }

/* -------------------------------------------
   CONTACT PAGE
------------------------------------------- */
.contact-icon-box {
  width: 56px; height: 56px;
  background: var(--primary-color);
  color: var(--dark-color);
  line-height: 56px;
  text-align: center;
  border-radius: var(--border-radius);
  font-size: 1.3rem;
  font-weight: 700;
}
.map-container { border-radius: var(--border-radius); overflow: hidden; }
.map-container iframe { width: 100%; height: 400px; border: 0; display: block; }

/* -------------------------------------------
   APP SECTION (Dark instead of yellow gradient)
------------------------------------------- */
.app-section {
  background: var(--dark-color);
  padding: 80px 0;
  border-radius: 0;
  margin-top: 0;
  position: relative;
  overflow: hidden;
}
.app-section::before {
  content: "";
  position: absolute;
  top: -50px; right: -50px;
  width: 300px; height: 300px;
  background: var(--primary-color);
  border-radius: 50%;
  opacity: 0.1;
}
.app-section h2,
.app-section p { color: #fff !important; }
.app-section h2 span { color: var(--primary-color); }

/* -------------------------------------------
   FOOTER (Dark with yellow accents)
------------------------------------------- */
.footer {
  background-color: var(--dark-color);
  color: rgba(255,255,255,0.6);
  padding: 70px 0 20px;
  border-top: 4px solid var(--primary-color);
}
.footer-title {
  color: var(--primary-color) !important;
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 1.1rem;
  text-transform: uppercase;
  letter-spacing: 2px;
  margin-bottom: 25px;
}
.footer h5,
.footer h2 {
  color: var(--primary-color) !important;
  font-weight: 700;
  margin-bottom: 25px;
  letter-spacing: 2px;
}
.footer a {
  color: rgba(255,255,255,0.6);
  text-decoration: none;
  font-weight: 400;
  transition: 0.2s;
  display: block;
  margin-bottom: 10px;
}
.footer a:hover { color: var(--primary-color); }
.footer-links a:hover { padding-left: 5px; }
.footer-social a:hover { padding-left: 0; }
.footer ul { padding-left: 0; list-style: none; }
.footer-links li { margin-bottom: 4px; }
.footer-social a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px; height: 40px;
  background: rgba(255,255,255,0.05);
  color: #fff;
  border-radius: var(--border-radius);
  margin-right: 8px;
  transition: all var(--transition-speed);
}
.footer-social a:hover {
  background: var(--primary-color);
  color: var(--dark-color);
  transform: translateY(-3px);
}
.footer-bottom a {
  display: inline;
  margin-bottom: 0;
}
.footer-bottom {
  border-top: 1px solid rgba(255,255,255,0.08);
  margin-top: 50px;
  padding-top: 20px;
  text-align: center;
  font-size: 0.85rem;
}

/* -------------------------------------------
   RESPONSIVE BREAKPOINTS
------------------------------------------- */
@media (max-width: 1199.98px) {
  .hero-swiper { height: 480px; }
}

@media (max-width: 991.98px) {
  .hero-swiper { height: 420px; }
  .hero-slide-content h1 { font-size: 2.4rem; }
  .app-section { padding: 60px 0; }
  .page-header { padding: 100px 0 60px; }
  .page-header h1 { font-size: 2.5rem; }
  .navbar .navbar-collapse {
    background: var(--dark-medium);
    padding: 15px;
    border-radius: var(--border-radius);
    margin-top: 10px;
  }
}

@media (max-width: 767.98px) {
  .hero-swiper { height: 380px; }
  .hero-slide-content h1 { font-size: 1.8rem; }
  .hero-slide-content p { font-size: 0.95rem; }
  .category-card img { width: 90px; height: 90px; }
  .app-section { padding: 50px 20px; }
  .footer { padding: 50px 0 20px; }
  .page-header { padding: 90px 0 50px; }
  .page-header h1 { font-size: 2rem; }
  .map-container iframe { height: 300px; }
}

/* -------------------------------------------
   GALLERY PAGE (Angular style)
------------------------------------------- */
.gallery-card {
  position: relative;
  overflow: hidden;
  border-radius: var(--border-radius);
  cursor: pointer;
}
.gallery-card__img {
  width: 100%;
  height: 280px;
  object-fit: cover;
  transition: transform 0.5s ease;
}
.gallery-card:hover .gallery-card__img {
  transform: scale(1.08);
}
.gallery-card__overlay {
  position: absolute;
  top: 0; left: 0; right: 0; bottom: 0;
  background: rgba(26, 26, 26, 0.8);
  color: #fff;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: opacity 0.4s ease;
}
.gallery-card:hover .gallery-card__overlay { opacity: 1; }
.gallery-card__overlay i { color: var(--primary-color); }
.gallery-filter {
  border-radius: var(--border-radius) !important;
  font-family: var(--font-display);
  text-transform: uppercase;
  letter-spacing: 1px;
  font-weight: 600;
}
.gallery-filter.active {
  background-color: var(--dark-color) !important;
  color: var(--primary-color) !important;
  border-color: var(--dark-color) !important;
}

/* -------------------------------------------
   BLOG PAGE (Horizontal card layout — different from PizzaCraft's vertical)
------------------------------------------- */
.blog-card {
  background: #fff;
  border-radius: var(--border-radius);
  overflow: hidden;
  box-shadow: 0 2px 15px rgba(0,0,0,0.05);
  border: 1px solid rgba(0,0,0,0.06);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
  height: 100%;
}
.blog-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 8px 25px rgba(0,0,0,0.1);
  border-color: var(--primary-color);
}
.blog-card__img {
  width: 100%;
  height: 220px;
  object-fit: cover;
}
.blog-card__body { padding: 22px; }
.blog-card__meta {
  display: flex;
  gap: 15px;
  font-size: 0.8rem;
  color: #999;
  margin-bottom: 10px;
}
.blog-card__title {
  font-size: 1.1rem;
  font-weight: 700;
  margin-bottom: 10px;
}
.blog-card__title a { color: var(--dark-color); text-decoration: none; }
.blog-card__title a:hover { color: var(--accent-color); }
.blog-card__excerpt {
  font-size: 0.9rem;
  color: #666;
  margin-bottom: 15px;
}
.blog-card__link {
  color: var(--dark-color);
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 0.85rem;
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: 1px;
  border-bottom: 2px solid var(--primary-color);
  padding-bottom: 2px;
}
.blog-card__link:hover { color: var(--accent-color); border-color: var(--accent-color); }
.blog-sidebar-widget {
  background: #fff;
  padding: 25px;
  border-radius: var(--border-radius);
  box-shadow: 0 2px 15px rgba(0,0,0,0.05);
  border: 1px solid rgba(0,0,0,0.06);
}
.blog-content p { line-height: 1.9; margin-bottom: 18px; }
.pagination .page-link {
  border: none;
  color: var(--dark-color);
  font-family: var(--font-display);
  font-weight: 600;
  margin: 0 3px;
  border-radius: var(--border-radius);
}
.pagination .page-item.active .page-link {
  background-color: var(--dark-color);
  color: var(--primary-color);
}

/* -------------------------------------------
   CHEFS PAGE (Dark card style)
------------------------------------------- */
.chef-card {
  background: #fff;
  border-radius: var(--border-radius);
  overflow: hidden;
  box-shadow: 0 2px 15px rgba(0,0,0,0.06);
  border: 1px solid rgba(0,0,0,0.06);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.chef-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 10px 30px rgba(0,0,0,0.12);
  border-color: var(--primary-color);
}
.chef-card__img-wrapper {
  position: relative;
  overflow: hidden;
}
.chef-card__img {
  width: 100%;
  height: 320px;
  object-fit: cover;
  transition: transform 0.5s ease;
}
.chef-card:hover .chef-card__img { transform: scale(1.05); }
.chef-card__social {
  position: absolute;
  bottom: -50px;
  left: 0; right: 0;
  display: flex;
  justify-content: center;
  gap: 10px;
  padding: 15px;
  background: linear-gradient(transparent, rgba(26,26,26,0.8));
  transition: bottom 0.4s ease;
}
.chef-card:hover .chef-card__social { bottom: 0; }
.chef-card__social a {
  width: 36px; height: 36px;
  border-radius: var(--border-radius);
  background: rgba(255,255,255,0.15);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  transition: 0.3s;
}
.chef-card__social a:hover { background: var(--primary-color); color: var(--dark-color); }
.chef-card__body { padding: 20px; }

/* -------------------------------------------
   OFFERS PAGE
------------------------------------------- */
.offer-card {
  background: #fff;
  border-radius: var(--border-radius);
  overflow: hidden;
  box-shadow: 0 2px 15px rgba(0,0,0,0.05);
  border: 1px solid rgba(0,0,0,0.06);
  position: relative;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.offer-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 10px 30px rgba(0,0,0,0.1);
  border-color: var(--primary-color);
}
.offer-card__badge {
  position: absolute;
  top: 15px; right: 15px;
  background: var(--dark-color);
  color: var(--primary-color);
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 0.8rem;
  padding: 5px 14px;
  border-radius: var(--border-radius);
  letter-spacing: 1px;
  z-index: 2;
}
.offer-card__img {
  width: 100%;
  height: 200px;
  object-fit: cover;
}
.offer-card__body { padding: 20px; }

/* -------------------------------------------
   FAQ ACCORDION OVERRIDES
------------------------------------------- */
.accordion-button:not(.collapsed) {
  background-color: rgba(255,199,44,0.1);
  color: var(--dark-color);
  box-shadow: none;
}
.accordion-button:focus { box-shadow: 0 0 0 3px rgba(255,199,44,0.25); }

/* -------------------------------------------
   CART UTILITIES (Used by cart.js)
------------------------------------------- */
.cart-count {
  display: none;
  font-size: 0.65rem;
}
.cart-price-highlight { color: var(--primary-color); }
.cart-img-thumb { width: 60px; height: 60px; object-fit: cover; }
.cart-qty-btn { width: 26px; height: 26px; }
.cart-icon-xs { font-size: 0.65rem; }
.cart-icon-sm { font-size: 0.75rem; }
.cart-toast {
  position: fixed;
  bottom: 30px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--dark-color, #1A1A1A);
  color: #fff;
  padding: 12px 24px;
  border-radius: var(--border-radius);
  font-size: 0.9rem;
  font-weight: 600;
  z-index: 99999;
  box-shadow: 0 5px 20px rgba(0,0,0,0.3);
  transition: opacity 0.4s ease;
}
.cart-toast__icon { color: var(--primary-color, #FFC72C); }
.offer-banner-img { height: 350px; object-fit: cover; }

/* Mini-cart dropdown (navbar popup) */
.mini-cart-dropdown {
  position: absolute;
  top: 100%;
  right: 0;
  width: 340px;
  max-height: 420px;
  background: #fff;
  border-radius: var(--border-radius);
  box-shadow: 0 10px 40px rgba(0,0,0,0.2);
  z-index: 1050;
  display: none;
  overflow: hidden;
}
.mini-cart-dropdown.show { display: block; }
.mini-cart-dropdown__header {
  padding: 14px 16px;
  background: var(--dark-color);
  color: #fff;
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 0.9rem;
  text-transform: uppercase;
  letter-spacing: 1px;
}
.mini-cart-dropdown__body {
  max-height: 260px;
  overflow-y: auto;
  padding: 12px 16px;
}
.mini-cart-dropdown__footer {
  padding: 12px 16px;
  border-top: 1px solid #eee;
  background: var(--light-color);
}

/* -------------------------------------------
   EXTRA SMALL (portrait phones, less than 576px)
------------------------------------------- */
@media (max-width: 575.98px) {
  .hero-swiper { height: 320px; }
  .hero-slide-content h1 { font-size: 1.5rem; }
  .btn-primary-custom,
  .btn-accent-custom,
  .btn-secondary-custom,
  .btn-outline-custom,
  .btn-outline-light-custom {
    padding: 10px 22px;
    font-size: 0.8rem;
  }
  .category-card { padding: 20px 15px; }
  .product-card__img { height: 160px; }
}

/* -------------------------------------------
   23. UTILITY CLASSES (moved from inline styles)
------------------------------------------- */

/* Color helpers */
.text-primary-custom        { color: var(--primary-color) !important; }
.bg-primary-custom          { background-color: var(--primary-color) !important; }
.progress-bar-primary       { background-color: var(--accent-color); }

/* Admin stat-card icon boxes */
.admin-icon-warning  { width: 48px; height: 48px; background: rgba(255, 193, 7, .15); }
.admin-icon-info     { width: 48px; height: 48px; background: rgba(13, 202, 240, .12); }
.admin-icon-success  { width: 48px; height: 48px; background: rgba(25, 135, 84, .12); }

/* Admin sidebar layout */
.admin-sidebar        { width: 260px; min-height: 100vh; background: #1a1a1a; }

/* Admin sidebar helpers */
.admin-nav-icon       { width: 16px; flex-shrink: 0; }
.admin-sidebar-label  { font-size: .68rem; letter-spacing: .08em; }
.admin-user-email     { font-size: .72rem; }

/* Admin sidebar — counter global .nav-link rules */
.admin-sidebar .nav-link {
  color: rgba(255,255,255,.72) !important;
  background: transparent !important;
  border: none !important;
  font-size: .875rem !important;
  font-weight: 500 !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
  margin: 0 !important;
  padding: .45rem .75rem !important;
  border-radius: .375rem;
  transition: background .15s ease, color .15s ease;
}
.admin-sidebar .nav-link:hover {
  color: #fff !important;
  background: rgba(255,255,255,.08) !important;
}
.admin-sidebar .nav-pills .nav-link {
  border: none !important;
}
.admin-sidebar .nav-link.active {
  color: #fff !important;
  background: rgba(255,195,0,.15) !important;
  border-left: 3px solid var(--primary-color,#ffc300) !important;
  padding-left: 9px !important;
}

/* Avatar / image sizes */
.avatar-sm   { width: 36px; height: 36px; min-width: 36px; }
.avatar-md   { width: 56px; height: 56px; min-width: 56px; }
.img-xs      { width: 44px; height: 44px; object-fit: cover; flex-shrink: 0; }

/* Progress bar height */
.progress-xs { height: 4px; }

/* Order-tracking step circles */
.tracking-step         { width: 52px; height: 52px; flex-shrink: 0; }
.tracking-step-active  { background-color: var(--accent-color); }

/* Order-tracking connector lines */
.tracking-connector    { max-width: 40px; padding-top: 0; margin-top: -24px; }
.tracking-hr-active    { border-color: var(--accent-color) !important; border-width: 2px !important; }
.tracking-hr           { border-width: 2px !important; }

/* Map / delivery map placeholder */
.map-placeholder-wrap  { height: 260px; background: #f0ede8; display: flex; align-items: center; justify-content: center; }
.map-icon-xl           { font-size: 3rem; opacity: .3; }

/* Typography micro */
.text-xs               { font-size: .7rem; }

/* -------------------------------------------
   24. ADMIN PANEL — MOBILE RESPONSIVE
------------------------------------------- */
@media (max-width: 991.98px) {
  .admin-sidebar {
    width: 100%;
    min-height: auto;
    flex-direction: row !important;
    flex-wrap: wrap;
    padding: .75rem 1rem !important;
  }
  .admin-sidebar > a { margin-bottom: 0 !important; }
  .admin-sidebar .nav-pills.flex-column { flex-direction: row !important; flex-wrap: wrap; margin-bottom: 0 !important; }
  .admin-sidebar small.admin-sidebar-label { display: none; }
  .admin-sidebar hr { display: none; }
  .admin-sidebar > div:last-child { display: none !important; }
  .admin-sidebar .nav-link { padding: .3rem .6rem !important; font-size: .78rem !important; }
  .admin-sidebar ~ main { overflow-x: auto; }
  body > .d-flex { flex-direction: column !important; }
}

/* Admin tables — horizontal scroll on small screens */
.admin-table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }

/* -------------------------------------------
   25. COOKIE CONSENT BANNER
------------------------------------------- */
#cookieBanner {
  position: fixed;
  bottom: 1.25rem;
  left: 1.25rem;
  z-index: 9999;
  background: #1a1a1a;
  color: #f0f0f0;
  border-radius: var(--border-radius);
  padding: 1rem 1.25rem;
  max-width: 320px;
  box-shadow: 0 8px 30px rgba(0,0,0,0.35);
  font-size: .8rem;
  line-height: 1.5;
  display: none;
}
#cookieBanner.show { display: block; }
#cookieBanner p { margin-bottom: .65rem; color: rgba(240,240,240,.85); }
#cookieBanner a { color: var(--primary-color); text-decoration: underline; }
.cookie-btn-row { display: flex; gap: .5rem; flex-wrap: wrap; }
.cookie-btn-row button {
  flex: 1;
  padding: .3rem .5rem;
  font-size: .75rem;
  font-weight: 600;
  border-radius: 4px;
  cursor: pointer;
  border: 1px solid transparent;
  transition: opacity .2s;
}
.cookie-btn-row button:hover { opacity: .85; }
#cookieAccept  { background: var(--primary-color); color: #1a1a1a; border-color: var(--primary-color); }
#cookieDecline { background: transparent; color: #f0f0f0; border-color: rgba(255,255,255,.3); }
#cookieSettings{ background: transparent; color: #f0f0f0; border-color: rgba(255,255,255,.3); }
