/* ============================================================
   CATERING SERVICE — UPGRADED STYLESHEET v2
   Theme: Professional Blue | Font: Arial Rounded MT Bold (headings)
   ============================================================ */

/* ---- GOOGLE FONTS — closest web alternative to Arial Rounded ---- */
@import url('https://fonts.googleapis.com/css2?family=Nunito:wght@400;500;600;700;800;900&family=Open+Sans:wght@300;400;500;600&display=swap');

/* ---- CSS VARIABLES — BLUE THEME ---- */
:root {
  /* Primary Blue Palette */
  --primary:        #1565C0;   /* deep blue */
  --primary-dark:   #0D47A1;
  --primary-light:  #BBDEFB;
  --primary-mid:    #1976D2;
  --secondary:      #0A1628;   /* very dark navy */
  --secondary-light:#0D2137;
  --accent:         #2196F3;   /* bright blue accent */
  --accent-light:   #64B5F6;

  /* Neutrals */
  --dark:           #111827;
  --light:          #F0F4FF;   /* very light blue-white */
  --white:          #FFFFFF;
  --text:           #1A2A3A;
  --text-light:     #5A6A7A;
  --border:         #C8D8E8;

  /* Shadows / Effects */
  --shadow:         0 4px 24px rgba(21,101,192,0.08);
  --shadow-hover:   0 12px 40px rgba(21,101,192,0.20);

  /* Layout */
  --radius:         12px;
  --radius-lg:      20px;
  --radius-sm:      8px;
  --transition:     all 0.32s cubic-bezier(0.4,0,0.2,1);

  /* ---- FONTS ---- */
  /* Headings: Arial Rounded MT Bold via Nunito (closest web font) */
  --font-heading: 'Nunito', 'Arial Rounded MT Bold', 'Arial', sans-serif;
  /* Body: clean Arial / Open Sans */
  --font-body:    'Open Sans', 'Arial', 'Helvetica Neue', sans-serif;
  /* Script accent (used sparingly) */
  --font-script:  'Nunito', cursive;
}

/* ---- RESET & BASE ---- */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; }
body {
  font-family: var(--font-body);
  color: var(--text);
  background: var(--white);
  line-height: 1.7;
  overflow-x: hidden;
}

/* ---- HEADINGS — Arial Rounded feel via Nunito ---- */
h1,h2,h3,h4,h5,h6 {
  font-family: var(--font-heading);
  font-weight: 800;
  line-height: 1.25;
  color: var(--secondary);
  letter-spacing: -0.01em;
}
p, span, li, td, th, label, input, textarea, select {
  font-family: var(--font-body);
}

a { text-decoration: none; color: var(--primary); transition: var(--transition); }
a:hover { color: var(--primary-dark); }
img { max-width: 100%; height: auto; display: block; }

/* ---- PRELOADER ---- */
#preloader {
  position: fixed; inset: 0; background: var(--secondary);
  z-index: 99999; display: flex; align-items: center; justify-content: center;
  transition: opacity 0.5s, visibility 0.5s;
}
#preloader.hidden { opacity: 0; visibility: hidden; }
.preloader-logo {
  font-family: var(--font-heading); font-size: 2rem; font-weight: 800;
  color: var(--accent); margin-bottom: 20px; letter-spacing: 1px; text-align: center;
}
.preloader-spinner {
  width: 50px; height: 50px;
  border: 3px solid rgba(33,150,243,0.3); border-top-color: var(--primary);
  border-radius: 50%; animation: spin 0.9s linear infinite; margin: 0 auto;
}
@keyframes spin { to { transform: rotate(360deg); } }

/* ---- TOP BAR ---- */
.top-bar {
  background: var(--secondary); padding: 7px 0; font-size: 0.82rem;
  border-bottom: 2px solid var(--primary);
}
.top-bar-link { color: rgba(255,255,255,0.8); margin-right: 16px; font-size: 0.82rem; }
.top-bar-link:hover { color: var(--accent-light); }
.top-bar-link i { margin-right: 5px; color: var(--accent); }
.social-icon {
  width: 28px; height: 28px; border-radius: 50%; background: rgba(255,255,255,0.1);
  display: inline-flex; align-items: center; justify-content: center;
  color: rgba(255,255,255,0.8); font-size: 0.75rem; transition: var(--transition);
}
.social-icon:hover { background: var(--primary); color: var(--white); }
.admin-link { color: rgba(255,255,255,0.6); font-size: 0.78rem; }
.admin-link:hover { color: var(--accent-light); }

/* ---- HEADER / NAVBAR ---- */
.site-header {
  position: sticky; top: 0; z-index: 1000;
  background: var(--white); box-shadow: 0 2px 20px rgba(21,101,192,0.08);
  transition: var(--transition);
}
.site-header.scrolled { box-shadow: 0 4px 30px rgba(21,101,192,0.14); }
.navbar { padding: 12px 0; }

.text-logo { display: flex; flex-direction: column; }
.logo-main {
  font-family: var(--font-heading); font-size: 1.5rem; font-weight: 900;
  color: var(--primary); line-height: 1; letter-spacing: -0.5px;
}
.logo-sub { font-size: 0.67rem; color: var(--text-light); text-transform: uppercase; letter-spacing: 2px; }
.logo-img { height: 55px; width: auto; }

.nav-link {
  font-family: var(--font-body); font-size: 0.9rem; font-weight: 600;
  color: var(--text) !important; padding: 8px 14px !important;
  border-radius: var(--radius-sm); position: relative; transition: var(--transition);
}
.nav-link::after {
  content: ''; position: absolute; bottom: 2px; left: 14px; right: 14px;
  height: 2px; background: var(--primary); transform: scaleX(0); transition: var(--transition);
}
.nav-link:hover, .nav-link.active { color: var(--primary) !important; }
.nav-link:hover::after, .nav-link.active::after { transform: scaleX(1); }

.btn-nav-cta {
  background: var(--primary); color: var(--white) !important;
  padding: 9px 22px !important; border-radius: 30px !important;
  font-family: var(--font-heading); font-weight: 700; font-size: 0.87rem;
  box-shadow: 0 4px 15px rgba(21,101,192,0.30); transition: var(--transition);
}
.btn-nav-cta:hover { background: var(--primary-dark); transform: translateY(-1px); box-shadow: 0 6px 20px rgba(21,101,192,0.40); }

/* Navbar Toggler */
.navbar-toggler { border: none; padding: 8px; background: transparent; }
.navbar-toggler:focus { box-shadow: none; }
.toggler-icon { display: block; width: 25px; height: 2.5px; background: var(--secondary); margin: 5px 0; border-radius: 2px; transition: var(--transition); }

/* Offcanvas */
.offcanvas { background: var(--secondary); }
.offcanvas-title { color: var(--white); font-family: var(--font-heading); }
.offcanvas .nav-link { color: rgba(255,255,255,0.8) !important; border-bottom: 1px solid rgba(255,255,255,0.06); padding: 12px 0 !important; }
.offcanvas .nav-link.active, .offcanvas .nav-link:hover { color: var(--accent-light) !important; }
.offcanvas-contact { color: rgba(255,255,255,0.6); font-size: 0.85rem; }

/* ---- BUTTONS ---- */
.btn-primary-custom {
  background: linear-gradient(135deg, var(--primary), var(--primary-dark));
  color: var(--white); border: none; padding: 12px 30px; border-radius: 30px;
  font-family: var(--font-heading); font-weight: 700; font-size: 0.92rem;
  box-shadow: 0 4px 18px rgba(21,101,192,0.30); transition: var(--transition);
  display: inline-flex; align-items: center;
}
.btn-primary-custom:hover {
  color: var(--white); transform: translateY(-2px);
  box-shadow: 0 8px 28px rgba(21,101,192,0.45);
  background: linear-gradient(135deg, var(--primary-dark), var(--primary-mid));
}
.btn-outline-primary-custom {
  background: transparent; color: var(--primary); border: 2px solid var(--primary);
  padding: 10px 28px; border-radius: 30px;
  font-family: var(--font-heading); font-weight: 700;
  transition: var(--transition); display: inline-flex; align-items: center;
}
.btn-outline-primary-custom:hover { background: var(--primary); color: var(--white); transform: translateY(-2px); }
.btn-service-link {
  display: inline-flex; align-items: center; color: var(--primary);
  font-weight: 700; font-size: 0.87rem; padding: 0; background: none; border: none;
  font-family: var(--font-heading); transition: var(--transition);
}
.btn-service-link:hover { color: var(--primary-dark); gap: 6px; }

/* ---- SECTION HEADERS ---- */
.section-tag {
  display: inline-block; font-family: var(--font-heading); font-size: 0.85rem;
  font-weight: 700; color: var(--primary); margin-bottom: 8px;
  text-transform: uppercase; letter-spacing: 2px;
  padding: 4px 14px; background: rgba(21,101,192,0.08); border-radius: 20px;
}
.tag-light { color: var(--accent-light); background: rgba(255,255,255,0.12); }
.section-title { font-size: clamp(1.7rem, 3vw, 2.5rem); font-weight: 900; margin-bottom: 14px; }
.text-accent { color: var(--primary); }
.section-subtitle { color: var(--text-light); max-width: 600px; margin: 0 auto; font-size: 1rem; }
.section-lead { font-size: 1.05rem; color: var(--text-light); line-height: 1.8; }
.section-header { margin-bottom: 40px; }
.bg-light-custom { background: var(--light) !important; }

/* ---- PAGE BANNER ---- */
.page-banner {
  min-height: 280px; display: flex; align-items: center;
  background-size: cover; background-position: center; position: relative; padding: 60px 0;
}
.page-banner-overlay { position: absolute; inset: 0; background: linear-gradient(135deg, rgba(10,22,40,0.88) 0%, rgba(21,101,192,0.50) 100%); }
.page-banner-content { position: relative; z-index: 1; text-align: center; color: var(--white); }
.page-banner-content h1 { font-size: clamp(2rem, 5vw, 3rem); color: var(--white); margin-bottom: 12px; }
.breadcrumb-item a { color: var(--accent-light); }
.breadcrumb-item.active, .breadcrumb-item+.breadcrumb-item::before { color: rgba(255,255,255,0.6); }

/* ---- HERO SLIDER ---- */
.hero-slider { position: relative; }
.hero-swiper { height: 100vh; min-height: 600px; max-height: 900px; }
.hero-slide { background-size: cover; background-position: center; display: flex; align-items: center; }
.hero-overlay { position: absolute; inset: 0; background: linear-gradient(to right, rgba(10,22,40,0.90) 0%, rgba(21,101,192,0.30) 60%, transparent 100%); }
.hero-content { position: relative; z-index: 2; color: var(--white); padding: 40px 0; }
.hero-badge {
  display: inline-block; background: rgba(33,150,243,0.2); border: 1px solid var(--accent);
  color: var(--accent-light); padding: 6px 18px; border-radius: 30px;
  font-size: 0.84rem; font-weight: 600; margin-bottom: 20px;
  backdrop-filter: blur(4px); letter-spacing: 1.5px; font-family: var(--font-body);
}
.hero-title { font-size: clamp(2.2rem,5vw,4rem); font-weight: 900; color: var(--white); line-height: 1.1; margin-bottom: 20px; }
.hero-desc { font-size: 1.1rem; color: rgba(255,255,255,0.85); max-width: 560px; margin-bottom: 35px; }
.hero-actions { display: flex; gap: 16px; flex-wrap: wrap; }
.btn-outline-custom {
  background: rgba(255,255,255,0.1); color: var(--white); border: 2px solid rgba(255,255,255,0.5);
  padding: 12px 30px; border-radius: 30px; font-family: var(--font-heading); font-weight: 700;
  backdrop-filter: blur(4px); transition: var(--transition); display: inline-flex; align-items: center;
}
.btn-outline-custom:hover { background: var(--white); color: var(--primary); border-color: var(--white); }

.hero-next, .hero-prev { color: var(--white) !important; background: rgba(21,101,192,0.4) !important; border-radius: 50% !important; width: 50px !important; height: 50px !important; }
.hero-next:hover, .hero-prev:hover { background: var(--primary) !important; }
.hero-next::after, .hero-prev::after { display: none; }
.hero-pagination .swiper-pagination-bullet { background: rgba(255,255,255,0.5); width: 10px; height: 10px; }
.hero-pagination .swiper-pagination-bullet-active { background: var(--accent); width: 30px; border-radius: 5px; }

.hero-bottom-bar { background: var(--secondary); border-top: 2px solid var(--primary); }
.hero-feature-item { display: flex; align-items: center; gap: 14px; padding: 20px 24px; color: var(--white); }
.hero-feature-item i { font-size: 1.8rem; color: var(--accent); flex-shrink: 0; }
.hero-feature-item strong { display: block; font-family: var(--font-heading); font-size: 0.95rem; color: var(--white); }
.hero-feature-item span { font-size: 0.8rem; color: rgba(255,255,255,0.6); }
.border-x { border-left: 1px solid rgba(255,255,255,0.1); border-right: 1px solid rgba(255,255,255,0.1); }

/* ---- ABOUT ---- */
.about-img-wrapper { position: relative; display: inline-block; }
.rounded-custom { border-radius: var(--radius-lg); }
.about-badge {
  position: absolute; bottom: 30px; left: -20px;
  background: linear-gradient(135deg, var(--primary), var(--primary-dark));
  color: var(--white); padding: 20px; border-radius: var(--radius);
  text-align: center; box-shadow: var(--shadow-hover); min-width: 110px;
}
.badge-number { display: block; font-family: var(--font-heading); font-size: 2.2rem; font-weight: 900; line-height: 1; }
.badge-text { font-size: 0.75rem; opacity: 0.9; font-family: var(--font-body); }
.why-mini-card { display: flex; align-items: center; gap: 12px; padding: 12px; background: var(--light); border-radius: var(--radius-sm); border-left: 3px solid var(--primary); }
.why-mini-icon { width: 38px; height: 38px; background: var(--primary); border-radius: 50%; display: flex; align-items: center; justify-content: center; color: var(--white); flex-shrink: 0; }
.why-mini-card h6 { margin: 0; font-size: 0.88rem; font-family: var(--font-heading); }

.mission-card { background: var(--white); padding: 40px; border-radius: var(--radius-lg); border-top: 4px solid var(--primary); box-shadow: var(--shadow); height: 100%; }
.mission-card.vision { border-top-color: var(--primary-dark); }
.mission-icon { font-size: 2.5rem; color: var(--primary); margin-bottom: 16px; }

/* ---- STATS ---- */
.stats-section {
  background: linear-gradient(135deg, var(--secondary) 0%, var(--secondary-light) 100%);
  padding: 60px 0; position: relative; overflow: hidden;
}
.stats-section::before { content:''; position:absolute; top:0; left:0; right:0; height:4px; background:linear-gradient(90deg, var(--primary), var(--accent), var(--primary)); }
.stat-card { text-align: center; padding: 30px 20px; }
.stat-icon { font-size: 2.5rem; color: var(--accent); margin-bottom: 12px; }
.stat-number { font-family: var(--font-heading); font-size: 2.8rem; font-weight: 900; color: var(--white); line-height: 1; margin-bottom: 8px; }
.stat-label { color: rgba(255,255,255,0.65); font-size: 0.84rem; text-transform: uppercase; letter-spacing: 1px; font-family: var(--font-body); }

/* ---- SERVICE CARDS ---- */
.service-card { background: var(--white); border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow); transition: var(--transition); height: 100%; display: flex; flex-direction: column; }
.service-card:hover { transform: translateY(-8px); box-shadow: var(--shadow-hover); }
.service-card-img { position: relative; overflow: hidden; height: 220px; }
.service-card-img img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.5s ease; }
.service-card:hover .service-card-img img { transform: scale(1.08); }
.service-badge { position: absolute; top: 14px; right: 14px; background: var(--primary); color: var(--white); padding: 4px 12px; border-radius: 20px; font-size: 0.74rem; font-weight: 700; font-family: var(--font-heading); }
.service-card-body { padding: 24px; flex: 1; display: flex; flex-direction: column; }
.service-category { font-size: 0.72rem; font-weight: 700; text-transform: uppercase; letter-spacing: 1.5px; color: var(--primary); margin-bottom: 8px; display: block; font-family: var(--font-body); }
.service-title { font-size: 1.2rem; margin-bottom: 10px; font-family: var(--font-heading); }
.service-desc { color: var(--text-light); font-size: 0.88rem; flex: 1; margin-bottom: 14px; }
.service-features-mini { list-style: none; padding: 0; margin: 0 0 14px; }
.service-features-mini li { font-size: 0.82rem; color: var(--text-light); margin-bottom: 4px; display: flex; align-items: center; gap: 6px; }
.service-features-mini i { color: var(--primary); font-size: 0.7rem; }
.service-price { font-family: var(--font-heading); font-size: 1.1rem; font-weight: 800; color: var(--primary); margin-bottom: 14px; }

/* Service Detail */
.service-detail-img img { max-height: 500px; width: 100%; object-fit: cover; }
.service-detail-title { font-size: 2rem; font-family: var(--font-heading); }
.service-detail-price { font-size: 1.3rem; color: var(--primary); font-weight: 800; font-family: var(--font-heading); }
.service-detail-content { color: var(--text); line-height: 1.8; }
.service-detail-content p { margin-bottom: 14px; }
.feature-item { display: flex; align-items: center; gap: 8px; padding: 10px 14px; background: var(--light); border-radius: var(--radius-sm); font-size: 0.9rem; }
.faq-item { border: 1px solid var(--border); border-radius: var(--radius-sm); margin-bottom: 10px; overflow: hidden; }
.faq-item .accordion-button { font-family: var(--font-heading); font-weight: 700; background: var(--light); color: var(--secondary); }
.faq-item .accordion-button:not(.collapsed) { background: var(--primary); color: var(--white); box-shadow: none; }
.faq-item .accordion-button:not(.collapsed)::after { filter: invert(1); }

/* Sidebar */
.sidebar-widget { background: var(--white); border-radius: var(--radius-lg); padding: 28px; box-shadow: var(--shadow); }
.widget-title { font-size: 1.2rem; border-bottom: 2px solid var(--primary); padding-bottom: 12px; margin-bottom: 20px; font-family: var(--font-heading); }
.related-service-item { display: flex; gap: 14px; align-items: center; padding: 12px 0; border-bottom: 1px solid var(--border); color: var(--text); transition: var(--transition); }
.related-service-item:hover { color: var(--primary); }
.related-service-item img { width: 70px; height: 50px; object-fit: cover; border-radius: var(--radius-sm); flex-shrink: 0; }
.related-service-item h6 { margin: 0; font-size: 0.88rem; font-family: var(--font-heading); }
.related-service-item span { font-size: 0.78rem; color: var(--primary); }
.contact-widget-item { display: flex; align-items: center; gap: 12px; padding: 12px 0; color: var(--text); border-bottom: 1px solid var(--border); font-size: 0.9rem; }
.contact-widget-item i { color: var(--primary); width: 20px; text-align: center; }
.contact-widget-item.whatsapp i { color: #25D366; }

/* Filter Tabs */
.filter-tabs { display: flex; gap: 10px; flex-wrap: wrap; justify-content: center; }
.filter-btn {
  padding: 8px 22px; border-radius: 30px; border: 2px solid var(--border);
  background: var(--white); color: var(--text); font-weight: 600; font-size: 0.87rem;
  cursor: pointer; transition: var(--transition); font-family: var(--font-heading);
}
.filter-btn:hover, .filter-btn.active { background: var(--primary); color: var(--white); border-color: var(--primary); }
.filter-item.hidden { display: none !important; }

/* ---- WHY CHOOSE US ---- */
.why-card { background: var(--white); padding: 36px 28px; border-radius: var(--radius-lg); box-shadow: var(--shadow); height: 100%; transition: var(--transition); position: relative; overflow: hidden; }
.why-card::before { content:''; position:absolute; top:0; left:0; right:0; height:4px; background:linear-gradient(90deg, var(--primary), var(--accent)); }
.why-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-hover); }
.why-icon-wrap { display: flex; align-items: center; gap: 16px; margin-bottom: 18px; }
.why-icon { width: 56px; height: 56px; background: linear-gradient(135deg, var(--primary), var(--primary-dark)); border-radius: 14px; display: flex; align-items: center; justify-content: center; color: var(--white); font-size: 1.4rem; flex-shrink: 0; }
.why-number { font-family: var(--font-heading); font-size: 2.5rem; font-weight: 900; color: var(--border); line-height: 1; }
.why-title { font-size: 1.1rem; margin-bottom: 10px; font-family: var(--font-heading); }
.why-desc { color: var(--text-light); font-size: 0.9rem; margin: 0; }

/* ---- GALLERY ---- */
.gallery-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 14px; }
@media(max-width:992px){.gallery-grid{grid-template-columns:repeat(3,1fr);}}
@media(max-width:576px){.gallery-grid{grid-template-columns:repeat(2,1fr);}}
.gallery-grid-item:nth-child(1),.gallery-grid-item:nth-child(6){grid-column:span 2;}
.gallery-item-inner,.gallery-card{position:relative;overflow:hidden;border-radius:var(--radius);cursor:pointer;}
.gallery-item-inner img,.gallery-card img{width:100%;height:220px;object-fit:cover;transition:transform 0.5s ease;}
.gallery-grid-item:nth-child(1) .gallery-item-inner img,.gallery-grid-item:nth-child(6) .gallery-item-inner img{height:300px;}
.gallery-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(10,22,40,0.9) 0%,transparent 60%);display:flex;align-items:flex-end;padding:20px;opacity:0;transition:var(--transition);}
.gallery-item-inner:hover .gallery-overlay,.gallery-card:hover .gallery-card-overlay{opacity:1;}
.gallery-item-inner:hover img,.gallery-card:hover img{transform:scale(1.08);}
.gallery-overlay-content,.gallery-card-content{color:var(--white);}
.gallery-overlay-content i,.gallery-card-content i{font-size:1.5rem;display:block;margin-bottom:6px;color:var(--accent);}
.gallery-overlay-content h6,.gallery-card-content h6{font-size:0.9rem;margin:0;color:var(--white);font-family:var(--font-heading);}
.gallery-card-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(10,22,40,0.9) 0%,transparent 60%);display:flex;align-items:flex-end;padding:16px;opacity:0;transition:var(--transition);}
.gallery-card-content span{font-size:0.75rem;color:var(--accent-light);}

/* ---- MENU ---- */
.menu-tabs{gap:8px;}
.menu-tab-btn{background:var(--light);border:none;padding:10px 20px;border-radius:30px;font-family:var(--font-heading);font-weight:700;cursor:pointer;transition:var(--transition);font-size:0.87rem;color:var(--text);}
.menu-tab-btn.active,.menu-tab-btn:hover{background:var(--primary);color:var(--white);}
.menu-count{background:rgba(255,255,255,0.2);padding:2px 8px;border-radius:12px;font-size:0.75rem;margin-left:6px;}
.menu-tab-btn:not(.active) .menu-count{background:rgba(0,0,0,0.08);}
.menu-item-card{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;background:var(--white);padding:18px;border-radius:var(--radius);border:1px solid var(--border);transition:var(--transition);height:100%;}
.menu-item-card:hover{border-color:var(--primary-light);box-shadow:var(--shadow);}
.menu-item-header{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:6px;}
.veg-dot{width:14px;height:14px;border-radius:2px;flex-shrink:0;border:1.5px solid;}
.veg-dot.veg{border-color:#27ae60;background:rgba(39,174,96,0.15);}
.veg-dot.veg::after{content:'';display:block;width:6px;height:6px;background:#27ae60;border-radius:50%;margin:3px;}
.veg-dot.non-veg{border-color:#e74c3c;background:rgba(231,76,60,0.15);}
.veg-dot.non-veg::after{content:'';display:block;width:0;height:0;border-left:5px solid transparent;border-right:5px solid transparent;border-bottom:7px solid #e74c3c;margin:2px;}
.veg-dot.egg{border-color:#f39c12;background:rgba(243,156,18,0.15);}
.veg-dot.egg::after{content:'';display:block;width:6px;height:6px;background:#f39c12;border-radius:50%;margin:3px;}
.menu-item-name{font-size:0.95rem;font-weight:700;margin:0;font-family:var(--font-heading);}
.menu-item-desc{font-size:0.82rem;color:var(--text-light);margin:0;}
.badge-special{background:rgba(21,101,192,0.10);color:var(--primary);padding:2px 8px;border-radius:12px;font-size:0.7rem;font-weight:700;border:1px solid var(--primary-light);}
.badge-spicy{background:rgba(231,76,60,0.1);color:#c0392b;padding:2px 8px;border-radius:12px;font-size:0.7rem;font-weight:700;}
.menu-item-img{width:80px;height:80px;border-radius:var(--radius-sm);overflow:hidden;flex-shrink:0;}
.menu-item-img img{width:100%;height:100%;object-fit:cover;}
.menu-type-filter{display:flex;gap:10px;justify-content:center;}
.menu-filter-btn{padding:8px 22px;border-radius:30px;border:2px solid var(--border);background:var(--white);cursor:pointer;transition:var(--transition);font-weight:700;display:flex;align-items:center;gap:8px;font-family:var(--font-heading);}
.menu-filter-btn.active,.menu-filter-btn:hover{border-color:var(--primary);background:var(--primary);color:var(--white);}
.veg-indicator{width:12px;height:12px;border-radius:2px;border:1.5px solid;}
.veg-indicator.veg{border-color:#27ae60;background:rgba(39,174,96,0.2);}
.veg-indicator.non-veg{border-color:#e74c3c;background:rgba(231,76,60,0.2);}
.menu-cta-inner{background:linear-gradient(135deg,var(--secondary),var(--secondary-light));padding:50px;border-radius:var(--radius-lg);color:var(--white);}
.menu-cta-inner h3{color:var(--white);margin-bottom:12px;font-family:var(--font-heading);}
.menu-cta-inner p{color:rgba(255,255,255,0.75);margin-bottom:24px;}

/* ---- TESTIMONIALS ---- */
.testimonial-swiper{padding-bottom:50px!important;}
.testimonial-card{background:var(--white);padding:36px;border-radius:var(--radius-lg);box-shadow:var(--shadow);margin:10px;transition:var(--transition);border-bottom:3px solid transparent;}
.testimonial-card:hover,.testimonial-card-full:hover{border-bottom-color:var(--primary);box-shadow:var(--shadow-hover);}
.testimonial-card-full{background:var(--white);padding:30px;border-radius:var(--radius-lg);box-shadow:var(--shadow);transition:var(--transition);display:flex;flex-direction:column;border-bottom:3px solid transparent;}
.testimonial-rating{display:flex;gap:3px;}
.fa-star{color:var(--border);font-size:0.9rem;}
.fa-star.filled{color:#f39c12;}
.testimonial-text{color:var(--text);font-style:italic;line-height:1.8;margin:16px 0;flex:1;}
.testimonial-author{display:flex;align-items:center;gap:14px;margin-top:auto;}
.testimonial-author img{width:52px;height:52px;border-radius:50%;object-fit:cover;flex-shrink:0;border:2px solid var(--primary-light);}
.testimonial-author h6{font-size:0.95rem;margin:0 0 2px;font-family:var(--font-heading);}
.testimonial-author span{font-size:0.78rem;color:var(--text-light);}
.event-badge{font-size:0.7rem;background:var(--light);color:var(--primary);padding:2px 10px;border-radius:12px;display:inline-block;}
.event-type-badge{background:var(--primary-light);color:var(--primary-dark);padding:4px 14px;border-radius:20px;font-size:0.78rem;font-weight:700;}
.testimonial-pagination .swiper-pagination-bullet{background:var(--border);}
.testimonial-pagination .swiper-pagination-bullet-active{background:var(--primary);}

/* ---- CTA SECTION ---- */
.section-cta{background:linear-gradient(135deg,var(--secondary),var(--secondary-light));padding:80px 0;position:relative;overflow:hidden;}
.section-cta::before{content:'';position:absolute;top:-50%;right:-10%;width:600px;height:600px;background:radial-gradient(circle,rgba(21,101,192,0.2) 0%,transparent 70%);}
.cta-inner{position:relative;}
.cta-title{font-size:clamp(1.5rem,3vw,2.2rem);color:var(--white);margin-bottom:14px;font-family:var(--font-heading);}
.cta-desc{color:rgba(255,255,255,0.75);font-size:1rem;}
.btn-cta-main{background:var(--accent);color:var(--white);border:none;padding:14px 36px;border-radius:30px;font-family:var(--font-heading);font-weight:800;font-size:1rem;display:inline-flex;align-items:center;box-shadow:0 4px 20px rgba(33,150,243,0.40);transition:var(--transition);}
.btn-cta-main:hover{background:var(--primary-dark);color:var(--white);transform:translateY(-2px);box-shadow:0 8px 30px rgba(21,101,192,0.50);}
.cta-phone a{color:rgba(255,255,255,0.85);font-size:1rem;font-weight:600;}
.cta-phone a:hover{color:var(--accent-light);}

/* ---- CONTACT ---- */
.contact-form-card{background:var(--white);padding:40px;border-radius:var(--radius-lg);box-shadow:var(--shadow);}
.custom-input{border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:12px 16px;font-size:0.92rem;transition:var(--transition);background:var(--white);font-family:var(--font-body);}
.custom-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(21,101,192,0.10);outline:none;}
.form-label{font-weight:600;font-size:0.87rem;margin-bottom:6px;color:var(--text);font-family:var(--font-heading);}
.contact-info-cards{display:flex;flex-direction:column;gap:16px;}
.contact-info-card{display:flex;align-items:flex-start;gap:16px;padding:20px;background:var(--light);border-radius:var(--radius);border-left:4px solid var(--primary);}
.contact-info-icon{width:44px;height:44px;background:var(--primary);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--white);flex-shrink:0;}
.contact-info-card h6{margin:0 0 4px;font-size:0.87rem;color:var(--text-light);font-weight:700;text-transform:uppercase;letter-spacing:1px;font-family:var(--font-heading);}
.contact-info-card a,.contact-info-card p{color:var(--text);margin:0;font-size:0.9rem;}
.contact-info-card a:hover{color:var(--primary);}
.whatsapp-contact-btn{display:inline-flex;align-items:center;background:#25D366;color:var(--white);padding:12px 24px;border-radius:30px;font-weight:700;margin-top:8px;transition:var(--transition);font-family:var(--font-heading);}
.whatsapp-contact-btn:hover{background:#128c7e;color:var(--white);transform:translateY(-2px);}
.contact-info-list{list-style:none;padding:0;}
.contact-info-list li{display:flex;align-items:center;gap:12px;margin-bottom:10px;color:var(--text);}
.contact-info-list i{color:var(--primary);width:20px;}
.contact-info-list a{color:var(--text);}
.contact-map .map-container{height:420px;}
.contact-map iframe{height:100%;filter:grayscale(10%) contrast(1.05);}
.form-message{padding:12px 16px;border-radius:var(--radius-sm);font-size:0.9rem;}
.form-message.success{background:rgba(39,174,96,0.1);color:#27ae60;border:1px solid rgba(39,174,96,0.3);}
.form-message.error{background:rgba(231,76,60,0.1);color:#c0392b;border:1px solid rgba(231,76,60,0.3);}

/* ---- TEAM ---- */
.team-card{background:var(--white);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow);transition:var(--transition);}
.team-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-hover);}
.team-img{position:relative;overflow:hidden;height:260px;}
.team-img img{width:100%;height:100%;object-fit:cover;transition:transform 0.5s;}
.team-card:hover .team-img img{transform:scale(1.05);}
.team-social{position:absolute;bottom:-50px;left:0;right:0;display:flex;justify-content:center;gap:10px;padding:14px;background:linear-gradient(to top,rgba(10,22,40,0.9),transparent);transition:var(--transition);}
.team-card:hover .team-social{bottom:0;}
.team-social a{width:36px;height:36px;background:var(--primary);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--white);font-size:0.8rem;}
.team-info{padding:20px;text-align:center;}
.team-info h5{margin:0 0 4px;font-size:1.1rem;font-family:var(--font-heading);}
.team-info span{color:var(--primary);font-size:0.85rem;font-weight:600;}
.team-bio{font-size:0.82rem;color:var(--text-light);margin-top:10px;}

/* ---- FOOTER ---- */
.site-footer{background:var(--secondary);color:rgba(255,255,255,0.75);}
.footer-top{padding:70px 0 50px;}
.footer-brand{display:block;margin-bottom:16px;}
.footer-logo-text{font-family:var(--font-heading);font-size:1.8rem;font-weight:900;color:var(--accent-light);}
.footer-about{font-size:0.88rem;line-height:1.8;margin-bottom:20px;}
.footer-widget-title{font-family:var(--font-heading);font-size:1.1rem;color:var(--white);font-weight:800;margin-bottom:20px;padding-bottom:12px;border-bottom:2px solid var(--primary);}
.footer-links{list-style:none;padding:0;}
.footer-links li{margin-bottom:10px;}
.footer-links a{color:rgba(255,255,255,0.65);font-size:0.88rem;transition:var(--transition);display:flex;align-items:center;}
.footer-links a:hover{color:var(--accent-light);padding-left:4px;}
.footer-contact-list{list-style:none;padding:0;}
.footer-contact-list li{display:flex;gap:12px;margin-bottom:12px;align-items:flex-start;font-size:0.85rem;}
.footer-contact-list i{color:var(--accent);margin-top:3px;flex-shrink:0;}
.footer-contact-list a{color:rgba(255,255,255,0.65);}
.footer-contact-list a:hover{color:var(--accent-light);}
.footer-social{display:flex;gap:10px;flex-wrap:wrap;}
.footer-social-link{width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,0.08);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,0.7);transition:var(--transition);font-size:0.85rem;}
.footer-social-link:hover{background:var(--primary);color:var(--white);transform:translateY(-3px);}
.footer-bottom{background:rgba(0,0,0,0.3);padding:18px 0;font-size:0.82rem;color:rgba(255,255,255,0.5);}
.footer-bottom-link{color:rgba(255,255,255,0.5);}
.footer-bottom-link:hover{color:var(--accent-light);}

/* ---- FLOAT BUTTONS ---- */
.whatsapp-float{position:fixed;bottom:100px;right:24px;z-index:9000;width:58px;height:58px;background:#25D366;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--white);font-size:1.7rem;box-shadow:0 4px 20px rgba(37,211,102,0.5);transition:var(--transition);}
.whatsapp-float:hover{background:#128c7e;color:var(--white);transform:scale(1.1);}
.whatsapp-tooltip{position:absolute;right:70px;background:#25D366;color:var(--white);padding:6px 14px;border-radius:20px;font-size:0.8rem;white-space:nowrap;opacity:0;pointer-events:none;transition:var(--transition);}
.whatsapp-float:hover .whatsapp-tooltip{opacity:1;}
.call-float{position:fixed;bottom:170px;right:24px;z-index:9000;width:52px;height:52px;background:var(--primary);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--white);font-size:1.3rem;box-shadow:0 4px 20px rgba(21,101,192,0.5);transition:var(--transition);}
.call-float:hover{transform:scale(1.1);color:var(--white);}
.scroll-top{position:fixed;bottom:30px;right:24px;z-index:9000;width:44px;height:44px;background:var(--secondary);border-radius:50%;border:2px solid var(--primary);display:flex;align-items:center;justify-content:center;color:var(--white);cursor:pointer;transition:var(--transition);opacity:0;transform:translateY(20px);}
.scroll-top.visible{opacity:1;transform:translateY(0);}
.scroll-top:hover{background:var(--primary);}

/* ---- ERROR PAGE ---- */
.error-page{min-height:60vh;display:flex;align-items:center;}
.error-number{font-family:var(--font-heading);font-size:8rem;font-weight:900;color:var(--primary);line-height:1;}
.error-title{font-size:2rem;margin-bottom:16px;font-family:var(--font-heading);}
.error-desc{color:var(--text-light);max-width:500px;margin:0 auto 24px;}

/* ---- CKEditor content display in frontend ---- */
.ck-content h1,.ck-content h2,.ck-content h3,.ck-content h4 { font-family:var(--font-heading); margin-bottom:12px; color:var(--secondary); }
.ck-content p { margin-bottom:14px; }
.ck-content ul,.ck-content ol { padding-left:22px; margin-bottom:14px; }
.ck-content li { margin-bottom:6px; }
.ck-content a { color:var(--primary); }
.ck-content strong { font-weight:700; }

/* ---- RESPONSIVE ---- */
@media(max-width:992px){
  .hero-swiper{height:80vh;min-height:500px;}
  .hero-bottom-bar{display:none;}
  .about-badge{left:10px;}
}
@media(max-width:768px){
  .hero-swiper{height:70vh;min-height:420px;}
  .hero-title{font-size:1.8rem;}
  .hero-desc{font-size:0.95rem;}
  .btn-primary-custom,.btn-outline-custom{padding:10px 22px;font-size:0.87rem;}
  .stat-number{font-size:2rem;}
  .contact-form-card{padding:24px;}
  .section-title{font-size:1.6rem;}
  .footer-top{padding:50px 0 30px;}
  .whatsapp-float{bottom:80px;right:16px;}
  .scroll-top{bottom:20px;right:16px;}
}
@media(max-width:576px){
  .hero-swiper{min-height:380px;}
  .gallery-grid{grid-template-columns:repeat(2,1fr);}
  .gallery-grid-item:nth-child(1),.gallery-grid-item:nth-child(6){grid-column:span 1;}
  .gallery-grid-item:nth-child(1) .gallery-item-inner img,
  .gallery-grid-item:nth-child(6) .gallery-item-inner img{height:220px;}
}
/* ============================================================
   ARCHITECT LEVEL CATEGORY WIDGET (Ultra-Premium SaaS Look)
   ============================================================ */
.category-widget {
    background: #ffffff;
    border-radius: 24px; /* Super smooth corners */
    box-shadow: 0 20px 40px -10px rgba(15, 23, 42, 0.05), 
                0 0 0 1px rgba(226, 232, 240, 0.6); /* 3D glowing border effect */
    padding: 24px; /* Internal breathing room */
}

/* Typography & Layout */
.category-widget .widget-title {
    font-size: 1.1rem;
    font-weight: 800;
    color: #0f172a;
    margin-bottom: 24px;
    display: flex;
    align-items: center;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    border-bottom: none; /* No ugly lines */
}

/* Gradient Icon for Pro Feel */
.category-widget .widget-title i {
    background: linear-gradient(135deg, var(--primary-color, #2563eb), #8b5cf6);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    font-size: 1.3rem;
    margin-right: 12px;
}

/* Container for links (Using GAP instead of borders) */
.category-widget .list-group {
    display: flex;
    flex-direction: column;
    gap: 8px; /* Smooth spacing between items */
}

.category-widget .list-group-item {
    border: none !important; /* Force kill Bootstrap borders */
    padding: 0 !important;
    background: transparent !important;
}

/* The Link Magic */
.category-link {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 14px 18px;
    border-radius: 14px;
    color: #64748b; /* Sleek slate grey */
    font-weight: 500;
    font-size: 0.95rem;
    text-decoration: none;
    transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1); /* Apple-like physics */
    position: relative;
    overflow: hidden;
    z-index: 1;
}

/* Hidden Hover Background */
.category-link::before {
    content: '';
    position: absolute;
    inset: 0;
    background: #f8fafc;
    border-radius: 14px;
    z-index: -1;
    transform: scale(0.95);
    opacity: 0;
    transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}

/* Text & Background animate on Hover */
.category-link:hover::before {
    transform: scale(1);
    opacity: 1;
}

.category-link:hover {
    color: #0f172a;
    padding-left: 22px; /* Slight bump inward */
}

/* ACTIVE STATE (The Masterpiece) */
.category-link.active {
    color: var(--primary-color, #2563eb);
    font-weight: 700;
    background: rgba(37, 99, 235, 0.04);
    box-shadow: inset 4px 0 0 0 var(--primary-color, #2563eb); /* Clean inner border */
}

/* Micro-interaction on Arrow Icon */
.category-link .cat-icon {
    font-size: 0.75rem;
    opacity: 0; /* Hidden by default */
    transform: translateX(-10px);
    transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1);
    color: var(--primary-color, #2563eb);
}

/* Arrow glides in on hover/active */
.category-link:hover .cat-icon,
.category-link.active .cat-icon {
    opacity: 1;
    transform: translateX(0);
}

/* Custom Invisible Scrollbar */
.cat-scrollbar {
    max-height: 400px;
    overflow-y: auto;
    padding-right: 5px;
}
.cat-scrollbar::-webkit-scrollbar { width: 4px; }
.cat-scrollbar::-webkit-scrollbar-track { background: transparent; }
.cat-scrollbar::-webkit-scrollbar-thumb { background: #e2e8f0; border-radius: 10px; }
.cat-scrollbar::-webkit-scrollbar-thumb:hover { background: #cbd5e1; }