/* Brand variables */
:root {
  --brand-bg: #BFE9C2;
  --brand-text: #191616;
  --brand-yellow: #EDC900;
  --brand-red: #E8380E;
  --brand-green: #375011;
  --brand-offwhite: #FBF4CF;
  --brand-cart-icon: #F7F9F8;
  --shadow-sm: 0 4px 12px rgba(0,0,0,0.08);
  --nav-height-desktop: 140px;
  --nav-height-tablet: 120px;
  --nav-height-mobile: 90px;
  --icon-offset: 0px; /* not used for centered icons */
  --nav-extra-offset: 16px; /* small cushion below fixed navbar */
}

/* Remove blanket hide; visibility handled per state below */

/* Force collapsed navbar between 992px and 1450px to avoid overlap */
@media (min-width: 992px) and (max-width: 1450px) {
  /* Layout orders in the flex container */
  .custom-navbar .container-fluid { display: flex; align-items: center; }
  .navbar-brand { order: 1; }
  .navbar-collapse { order: 2; position: static; width: 100%; background: var(--brand-bg); overflow: hidden; max-height: 0; transition: max-height 240ms ease; }
  .nav-actions { order: 3; margin-right: 24px !important; display: none !important; }
  .navbar-toggler { order: 4; display: block !important; margin-left: auto; }

  /* Hide links until toggled open */
  .navbar-collapse { display: block !important; } /* keep element in flow for max-height animation */
  .navbar-collapse.show { max-height: 420px; }
  .navbar-nav { flex-direction: column; align-items: center; justify-content: center; row-gap: 10px; padding: 0.35rem 0 0.5rem; margin: 0; }
  .nav-list { margin-right: 0; }

  /* Size adjustments to fit space better */
  .brand-logo { height: 160px; left: 24px; }
  .navbar .nav-link { font-size: 0.95rem; }
  .circle-btn { width: 40px; height: 40px; }
  .icon-svg { width: 18px; height: 18px; }
  /* When menu opens, show actions centered below the list */
  .navbar-collapse.show + .nav-actions { display: flex !important; justify-content: center; width: 100%; margin: 0 auto !important; padding: 0.35rem 0 0.9rem; position: static; }
}

@font-face {
  font-family: "Turkey Sandwich";
  src: url("../fonts/Turkeys.ttf") format("truetype");
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}


/* Base */
*, *::before, *::after { box-sizing: border-box; }
html { height: 100%; margin: 0; padding: 0; overflow-x: hidden; }
body { height: 100%; margin: 0; padding: 0; font-family: 'Poppins', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; color: var(--brand-text); padding-top: calc(var(--nav-height-desktop) + var(--nav-extra-offset)); }

/* Overlay (commented in HTML for now) */
.corner-overlay { position: absolute; top: 0; right: 0; width: min(40vw, 560px); height: 100%; background: var(--brand-offwhite); z-index: 1; pointer-events: none; clip-path: polygon(100% 0%, 62% 0%, 100% 85%); opacity: 0.9; }

/* Navbar */
.custom-navbar { background: var(--brand-bg) !important; z-index: 1030; box-shadow: var(--shadow-sm); position: fixed; left: 0; right: 0; top: 0; min-height: var(--nav-height-desktop); overflow: visible; padding: 10px 0; width: 100%; max-width: 100%; box-sizing: border-box; }
.custom-navbar { background-color: var(--brand-bg) !important; opacity: 1; backdrop-filter: none; }
.custom-navbar .container, .custom-navbar .container-fluid, .custom-nav-container { position: relative; z-index: 2; box-sizing: border-box; }
.navbar-brand { position: relative; display: block; min-height: var(--nav-height-desktop); align-items: flex-start; }
.brand-logo { position: absolute; top: 0; left: 48px; height: 260px; width: auto; }

/* =============================== */
/* Above 990px: full inline navbar */
/* =============================== */
@media (min-width: 991px) and (max-width: 1199.98px) {
  /* Restore inline layout (override any collapse) */
  .navbar-expand-lg .navbar-collapse { display: flex !important; }
  .navbar-collapse { max-height: none; overflow: visible; background: transparent; padding: 0; margin-left: 160px; }
  /* Nav stays right of logo, can overlap actions on right */
  .navbar-nav { flex-direction: row; align-items: center; justify-content: flex-start; column-gap: 10px; padding-right: 0; margin-left: 0; flex-wrap: nowrap; white-space: nowrap; }
  .nav-list { margin-right: 0 !important; }
  .navbar .nav-link { padding: 0.24rem 0.2rem; font-size: 0.78rem; }
  /* Give last nav item (Contact Us) right margin for breathing room */
  .navbar .nav-item:last-child .nav-link { margin-right: 120px; }
  /* Actions anchored to right edge, matching logo's left margin */
  .nav-actions { display: flex !important; margin-right: 24px !important; gap: 6px; position: absolute; right: 0; z-index: -1; }
  .circle-btn { width: 28px; height: 28px; }
  .icon-svg { width: 13px; height: 13px; }
  .navbar-toggler { display: none !important; }
  /* Scale down logo */
  .brand-logo { height: 120px; left: 24px; }
}

@media (min-width: 1200px) and (max-width: 1450px) {
  .navbar-expand-lg .navbar-collapse { display: flex !important; }
  .navbar-collapse { max-height: none; overflow: visible; background: transparent; padding: 0; margin-left: 180px; }
  /* Nav stays right of logo, can overlap actions on right */
  .navbar-nav { flex-direction: row; align-items: center; justify-content: flex-start; column-gap: 20px; padding-right: 0; margin-left: 0; flex-wrap: nowrap; white-space: nowrap; }
  .nav-list { margin-right: 0 !important; }
  .navbar .nav-link { padding: 0.33rem 0.28rem; font-size: 0.9rem; }
  /* Give last nav item (Contact Us) right margin for breathing room */
  .navbar .nav-item:last-child .nav-link { margin-right: 140px; }
  /* Actions anchored to right edge, matching logo's left margin */
  .nav-actions { display: flex !important; margin-right: 32px !important; gap: 8px; position: absolute; right: 0; z-index: -1; }
  .circle-btn { width: 34px; height: 34px; }
  .icon-svg { width: 15px; height: 15px; }
  .navbar-toggler { display: none !important; }
  .brand-logo { height: 152px; left: 32px; }
}

/* Layout: left brand, center-left nav, right actions */
.navbar-collapse { display: flex; align-items: flex-start; flex: 1 1 auto; }
.navbar-nav { display: flex; flex: 1 1 0; justify-content: right; column-gap: 64px; padding-right: 192px;}
.nav-list { margin-right: 8px; }
.nav-actions { margin-right: 48px !important; }

/* Nav links */
.navbar .nav-link { color: var(--brand-text) !important; position: relative; padding: 0.65rem 0.5rem; transition: color 160ms ease, opacity 160ms ease; font-weight: 600; font-size: 18px; z-index: 0; }
.navbar .nav-link:hover { color: var(--brand-text) !important; }
.navbar .nav-link::after { content: ''; position: absolute; left: 0.2rem; right: 0.2rem; bottom: 0.15rem; height: 3px; background: var(--brand-yellow); transform: scaleX(0); transform-origin: left; transition: transform 180ms ease; border-radius: 2px; }
.navbar .nav-link.active::after { transform: scaleX(1); }
/* Brush-stroke underlay for active/hover links */
.navbar .nav-link::before {
  content: '';
  position: absolute;
  left: -8px;
  right: -8px;
  top: 50%;
  height: 1.7em;
  transform: translateY(-50%) scale(0.94);
  z-index: -1;
  opacity: 0;
  background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='140' height='40' viewBox='0 0 140 40'><defs><linearGradient id='g' x1='0' x2='1' y1='0' y2='0'><stop offset='0' stop-color='%23EDC900' stop-opacity='0.0'/><stop offset='0.12' stop-color='%23EDC900' stop-opacity='0.6'/><stop offset='0.88' stop-color='%23EDC900' stop-opacity='0.6'/><stop offset='1' stop-color='%23EDC900' stop-opacity='0.0'/></linearGradient></defs><path d='M5 20c18-12 48-15 70-12 22 3 48 10 60 6-8 10-30 18-48 21-28 5-64 3-82-2 0 0-6-6 0-13z' fill='url(%23g)'/></svg>") center/100% 100% no-repeat;
  transition: opacity 220ms ease, transform 220ms ease;
  pointer-events: none;
}
.navbar .nav-link:hover::before,
.navbar .nav-link.active::before,
.navbar .nav-link:focus-visible::before {
  opacity: 1;
  transform: translateY(-50%) scale(1);
}
.navbar .nav-link.active::after { height: 4px; }

/* Right action circles */
.circle-btn { display: inline-flex; align-items: center; justify-content: center; width: 52px; height: 52px; border-radius: 999px; border: none; outline: none; background: #ccc; cursor: pointer; transition: transform 160ms ease, box-shadow 160ms ease, opacity 160ms ease; text-decoration: none; position: relative; }
.circle-btn:hover { transform: translateY(-1px); box-shadow: var(--shadow-sm); }
.circle-btn:active { transform: translateY(0); }
.circle-yellow { background: var(--brand-yellow); }
.circle-red { background: var(--brand-red); }
.circle-green { background: var(--brand-green); }
/* Font Awesome fallback colors */
.icon-black { color: var(--brand-text); }
.icon-outline-black { color: var(--brand-text); }
.icon-white { color: var(--brand-cart-icon); }

/* Inline SVG icon styling (preferred for reliability) */
.icon-svg { width: 24px; height: 24px; margin-top: 0; display: block; }
.icon-svg path, .icon-svg circle, .icon-svg line, .icon-svg polyline { stroke-width: 2.2; stroke-linecap: round; stroke-linejoin: round; }
.icon-svg--black { stroke: var(--brand-text); fill: none; }
.icon-svg--white { stroke: var(--brand-cart-icon); fill: none; }

/* Notification badge for cart (numeric) */
.badge-dot { position: absolute; top: -4px; right: -4px; min-width: 18px; height: 18px; padding: 0 4px; border-radius: 999px; background: var(--brand-green); border: 2px solid var(--brand-cart-icon); display: inline-flex; align-items: center; justify-content: center; font-size: 12px; line-height: 1; color: var(--brand-cart-icon); }
.badge-dot::after { content: attr(data-count); }

/* Cart Dropdown */
.cart-dropdown {
  position: fixed;
  top: 120px;
  right: 20px;
  width: 380px;
  max-width: calc(100vw - 40px);
  background: white;
  border-radius: 12px;
  box-shadow: 0 20px 60px rgba(0,0,0,0.15);
  z-index: 9999;
  transform: translateX(100%) scale(0.9);
  opacity: 0;
  transition: all 300ms cubic-bezier(0.4, 0, 0.2, 1);
  border: 1px solid rgba(0,0,0,0.1);
  overflow: hidden;
}

.cart-dropdown.show {
  transform: translateX(0) scale(1);
  opacity: 1;
}

.cart-dropdown__header {
  padding: 20px 20px 16px;
  border-bottom: 1px solid rgba(0,0,0,0.1);
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.cart-dropdown__header h3 {
  font-family: "Poppins", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-weight: 600;
  font-size: 18px;
  color: var(--brand-text);
  margin: 0;
}

.cart-item-count {
  font-family: "Poppins", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-size: 14px;
  color: var(--brand-text);
  opacity: 0.7;
}

.cart-dropdown__items {
  max-height: 300px;
  overflow-y: auto;
  padding: 0;
}

.cart-empty {
  padding: 40px 20px;
  text-align: center;
  color: var(--brand-text);
  opacity: 0.6;
  font-family: "Poppins", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
}

.cart-dropdown-item {
  padding: 16px 20px;
  border-bottom: 1px solid rgba(0,0,0,0.05);
  display: flex;
  align-items: center;
  gap: 12px;
  transition: background-color 200ms ease;
}

.cart-dropdown-item:hover {
  background: rgba(191, 233, 194, 0.1);
}

.cart-dropdown-item:last-child {
  border-bottom: none;
}

.cart-dropdown-item .item-info {
  flex: 1;
}

.cart-dropdown-item .item-info h4 {
  font-family: "Poppins", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-weight: 600;
  font-size: 14px;
  color: var(--brand-text);
  margin: 0 0 4px 0;
  line-height: 1.3;
}

.cart-dropdown-item .item-info p {
  font-family: "Poppins", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-size: 12px;
  color: var(--brand-text);
  opacity: 0.7;
  margin: 0;
}

.cart-dropdown-item .item-total {
  font-family: "Poppins", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-weight: 600;
  font-size: 14px;
  color: var(--brand-yellow);
  margin-right: 8px;
}

.cart-dropdown-item .remove-item {
  width: 24px;
  height: 24px;
  border: none;
  background: rgba(220, 53, 69, 0.1);
  color: #dc3545;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all 200ms ease;
  flex-shrink: 0;
}

.cart-dropdown-item .remove-item:hover {
  background: #dc3545;
  color: white;
}

.cart-dropdown__footer {
  padding: 16px 20px 20px;
  border-top: 1px solid rgba(0,0,0,0.1);
  background: rgba(191, 233, 194, 0.05);
}

.cart-total {
  margin-bottom: 16px;
  text-align: center;
}

.cart-total strong {
  font-family: "Poppins", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-size: 16px;
  color: var(--brand-text);
}

.cart-actions {
  display: flex;
  gap: 10px;
}

.btn-view-cart,
.btn-checkout {
  flex: 1;
  padding: 10px 16px;
  border-radius: 6px;
  font-family: "Poppins", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-weight: 600;
  font-size: 14px;
  text-decoration: none;
  text-align: center;
  cursor: pointer;
  transition: all 200ms ease;
  border: none;
}

.btn-view-cart {
  background: transparent;
  color: var(--brand-text);
  border: 2px solid var(--brand-text);
}

.btn-view-cart:hover {
  background: var(--brand-text);
  color: white;
}

.btn-checkout {
  background: var(--brand-yellow);
  color: var(--brand-text);
}

.btn-checkout:hover {
  background: #d4b800;
  color: var(--brand-text);
}

/* Responsive cart dropdown */
@media (max-width: 767.98px) {
  .cart-dropdown {
    top: 90px;
    right: 10px;
    left: 10px;
    width: auto;
    max-width: none;
  }
}

/* Account Dropdown */
.account-dropdown {
  position: fixed;
  top: 120px;
  right: 20px;
  width: 280px;
  max-width: calc(100vw - 40px);
  background: white;
  border-radius: 12px;
  box-shadow: 0 20px 60px rgba(0,0,0,0.15);
  z-index: 9999;
  transform: translateX(100%) scale(0.9);
  opacity: 0;
  transition: all 300ms cubic-bezier(0.4, 0, 0.2, 1);
  border: 1px solid rgba(0,0,0,0.1);
  overflow: hidden;
}

.account-dropdown.show {
  transform: translateX(0) scale(1);
  opacity: 1;
}

.account-dropdown__header {
  padding: 20px;
  background: linear-gradient(135deg, var(--brand-yellow) 0%, #d4b800 100%);
  color: var(--brand-text);
  text-align: center;
}

.account-dropdown__user-icon {
  width: 60px;
  height: 60px;
  background: white;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 12px;
  box-shadow: 0 4px 12px rgba(0,0,0,0.1);
}

.account-dropdown__user-icon i {
  font-size: 28px;
  color: var(--brand-text);
}

.account-dropdown__greeting {
  font-family: "Poppins", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-size: 16px;
  font-weight: 600;
  margin: 0;
}

.account-dropdown__menu {
  padding: 12px 0;
}

.account-dropdown__item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 20px;
  color: var(--brand-text);
  text-decoration: none;
  font-family: "Poppins", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-size: 14px;
  font-weight: 500;
  transition: all 200ms ease;
  border-left: 3px solid transparent;
}

.account-dropdown__item:hover {
  background: #f8f8f8;
  border-left-color: var(--brand-yellow);
  padding-left: 24px;
}

.account-dropdown__item i {
  font-size: 18px;
  color: var(--brand-yellow);
  width: 20px;
  text-align: center;
}

.account-dropdown__divider {
  height: 1px;
  background: #e0e0e0;
  margin: 8px 0;
}

.account-dropdown__item--logout {
  color: #ef4444;
}

.account-dropdown__item--logout i {
  color: #ef4444;
}

.account-dropdown__item--logout:hover {
  background: #fef2f2;
  border-left-color: #ef4444;
}

/* Responsive */
@media (max-width: 575.98px) {
  .account-dropdown {
    top: 90px;
    right: 10px;
    left: 10px;
    width: auto;
    max-width: none;
  }
}

/* Toggler */
.navbar-light .navbar-toggler { border-color: rgba(0,0,0,0.15); }
.navbar-light .navbar-toggler:focus { box-shadow: none; }
/* Ensure toggler stays above the collapsing panel */
.navbar-toggler { position: relative; z-index: 4; }

/* Header corner vector (top-right above circles) */
.corner-overlay--header {
  position: absolute;
  top: 0;
  right: 0;
  width: clamp(160px, 18vw, 280px);
  height: clamp(90px, 12vh, 140px);
  background: var(--brand-offwhite);
  clip-path: ellipse(75% 100% at 100% 0%);
  z-index: 1; /* below navbar content (which is z-index:2) */
  pointer-events: none;
}

/* Responsive */
@media (max-width: 1199.98px) {
  .custom-navbar { min-height: var(--nav-height-tablet); }
  .navbar-brand { min-height: var(--nav-height-tablet); }
  .brand-logo { height: 180px; }
  .navbar-nav { column-gap: 28px; }
  .icon-svg { width: 20px; height: 20px; }
  body { padding-top: calc(var(--nav-height-tablet) + var(--nav-extra-offset)); }
}

/* Tablet and below: enable burger menu collapse */
@media (max-width: 991.98px) {
  .custom-navbar { min-height: var(--nav-height-tablet); }
  .navbar-brand { min-height: var(--nav-height-tablet); }
  /* Make logo participate in layout so content stacks below */
  .brand-logo { position: relative; height: 120px; left: 0; display: block; }
  .circle-btn { width: 40px; height: 40px; }

  /* Collapsing panel uses max-height animation and sits below logo */
  .navbar-collapse { position: static; width: 100%; background: var(--brand-bg); padding: 0; z-index: 2; overflow: hidden; max-height: 0; transition: max-height 240ms ease; }
  .navbar-collapse.show { max-height: 420px; }

  /* Center links and remove desktop offsets */
  .navbar-nav { justify-content: center; column-gap: 22px; padding: 0.25rem 0 0.5rem; margin-left: 0; width: 100%; flex-direction: column; align-items: center; row-gap: 10px; }
  .nav-list { margin-right: 0; }
  .nav-actions { margin-right: 16px !important; z-index: 3; }
  /* Tablet: hidden by default; show centered when open */
  .navbar-collapse + .nav-actions { display: none !important; }
  .navbar-collapse.show + .nav-actions { display: flex !important; justify-content: center; width: 100%; margin: 0 auto !important; padding: 0.35rem 0 0.9rem; position: static; }
  .icon-svg { width: 19px; height: 19px; }
  body { padding-top: calc(var(--nav-height-tablet) + var(--nav-extra-offset)); }
}

/* Mobile */
@media (max-width: 767.98px) {
  .custom-navbar { min-height: var(--nav-height-mobile); }
  .navbar-brand { min-height: var(--nav-height-mobile); }
  /* Edge balance: rely on container padding (px-3 = 16px) */
  .brand-logo { position: relative; height: 96px; left: 0; display: block; }
  /* Force equal gutters on both sides */
  .custom-navbar .container-fluid { padding-left: 16px !important; padding-right: 16px !important; }
  .circle-btn { width: 36px; height: 36px; }
  #mainNav .nav-actions { padding: 0.5rem 0.25rem 0.75rem; }
  #mainNav .navbar-nav { padding-top: 0.25rem; padding-bottom: 0.5rem; margin-left: 0; column-gap: 18px; row-gap: 10px; }
  /* Ensure collapsed panel sits below logo with safe padding */
  .navbar-collapse { padding-top: 0; }
  /* Hide right-side actions and push burger to far right */
  .nav-actions { display: none !important; }
  .navbar-toggler { margin-left: auto; padding: 6px 8px; }
  /* Mobile: show centered when open */
  .navbar-collapse.show + .nav-actions { display: flex !important; justify-content: center; width: 100%; margin: 0 auto !important; padding: 0.4rem 0 0.9rem; }
  .icon-svg { width: 18px; height: 18px; }
  body { padding-top: calc(var(--nav-height-mobile) + var(--nav-extra-offset)); }
}

@media (max-width: 575.98px) {
  .brand-text { display: none; }
  .navbar .nav-link { padding: 0.45rem 0.4rem; }
  .circle-btn { width: 34px; height: 34px; }
  .navbar-nav { column-gap: 14px; }
}

/* =========================== */
/* Hero section (Little Gem)   */
/* =========================== */
.lgs-hero { min-height: 100vh; padding-top: var(--nav-offset, 120px); padding-bottom: 80px; isolation: isolate; background: #0d0d0d; overflow: hidden; position: relative; z-index: 3; display: flex; align-items: center; }
.lgs-hero-bg { position: absolute; inset: 0; z-index: 0; background-image: linear-gradient(90deg, rgba(0,0,0,0.35) 0%, rgba(0,0,0,0.25) 30%, rgba(0,0,0,0.15) 55%, rgba(0,0,0,0) 70%), url('../imgs/Hero Banner 01.png'); background-size: cover; background-repeat: no-repeat; background-position: center center; }
.lgs-hero .container { position: relative; z-index: 2; min-height: calc(85vh - var(--nav-offset, 120px)); }
.lgs-hero-inner { display: flex; align-items: center; }

.lgs-eyebrow { font-family: 'Poppins', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; font-weight: 400; color: #f1f1f1; letter-spacing: 0.02em; font-size: clamp(18px, 2.6vw, 26px); }
.lgs-title { font-family: 'Turkey Sandwich', 'Poppins', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; color: #efcb02; font-weight: 400; font-size: clamp(48px, 8vw, 96px); line-height: 1.02; white-space: nowrap; }
.lgs-subtitle { font-family: 'Poppins', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; font-weight: 500; color: #f1f1f1; font-size: clamp(18px, 2.6vw, 26px); }
.lgs-icon-creative { width: 22px; height: 22px; stroke: #b4826b; fill: none; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; flex: 0 0 auto; }

.lgs-cta { background-color: #edc900; color: #191717; border: none; box-shadow: 0 6px 18px rgba(0,0,0,0.18); border-radius: 999px !important; padding: 0.7rem 1.6rem; min-width: 180px; transition: all 0.3s ease; }
.lgs-cta:hover { filter: brightness(0.95); color: #FFFFFF; transform: translateY(-2px); box-shadow: 0 8px 24px rgba(0,0,0,0.25); }
.lgs-cta:active { filter: brightness(0.92); transform: translateY(0); }

.lgs-rail { position: absolute; top: 50%; right: 18px; transform: translateY(-50%); gap: 14px; z-index: 3; }
.lgs-dot { width: 10px; height: 10px; border-radius: 999px; background: #dac498; border: none; outline: none; position: relative; cursor: pointer; transition: transform 160ms ease, background 160ms ease; }
.lgs-dot:hover { transform: scale(1.08); }
.lgs-dot.active { background: #f1cd00; width: 12px; height: 12px; }
.lgs-dot.is-active { background: #f1cd00; width: 12px; height: 12px; }
.lgs-dot-label { position: absolute; top: 50%; left: -36px; transform: translateY(-50%); color: #f1f1f1; font-family: 'Poppins', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; font-weight: 500; font-size: 12px; letter-spacing: 0.1em; opacity: 0; transition: opacity 200ms ease; }
.lgs-dot.active .lgs-dot-label { opacity: 1; }

/* Hero Carousel */
.hero-carousel { position: absolute; inset: 0; z-index: 0; }
.hero-slide { position: absolute; inset: 0; opacity: 0; transform: translateX(100%); transition: opacity 800ms ease, transform 800ms cubic-bezier(0.4, 0, 0.2, 1); pointer-events: none; }
.hero-slide.active { opacity: 1; transform: translateX(0); pointer-events: auto; }
.hero-slide.exit-left { transform: translateX(-100%); opacity: 0; }
.hero-slide .lgs-hero-bg { background-image: linear-gradient(90deg, rgba(0,0,0,0.35) 0%, rgba(0,0,0,0.25) 30%, rgba(0,0,0,0.15) 55%, rgba(0,0,0,0) 70%), var(--slide-bg); background-size: cover; background-repeat: no-repeat; background-position: center center; }

.lgs-wave { position: absolute; left: 0; right: 0; bottom: -10px; height: 140px; z-index: 10; background-image: url('../imgs/BannerLayer.png'); background-size: cover; background-position: center; background-repeat: no-repeat; pointer-events: none; }
.lgs-wave::after { content: ''; position: absolute; bottom: -20px; left: 0; right: 0; height: 120px; background: linear-gradient(to bottom, transparent 0%, rgba(191, 233, 194, 0.2) 20%, rgba(191, 233, 194, 0.5) 40%, rgba(191, 233, 194, 0.8) 70%, rgba(191, 233, 194, 1) 100%); z-index: 2; }

.lgs-hero-content { opacity: 0; transform: translateY(12px); margin-bottom: 60px; margin-left: 60px; }
.lgs-hero-content.is-visible { opacity: 1; transform: translateY(0); transition: opacity 600ms ease 80ms, transform 600ms ease 80ms; }

@media (max-width: 991.98px) { 
  .lgs-rail { right: 12px; gap: 12px; } 
  .lgs-dot-label { left: -30px; } 
  .lgs-hero-content { margin-bottom: 50px; margin-left: 50px; } 
  .lgs-hero { min-height: 90vh; padding-bottom: 60px; }
  .lgs-hero-bg { background-position: 65% center; background-size: cover; }
}
@media (max-width: 767.98px) {
  .lgs-hero { min-height: 85vh; padding-top: calc(var(--nav-offset, 90px) + 20px); padding-bottom: 60px; align-items: center; }
  .lgs-hero-bg { background-position: 70% center; }
  .lgs-title { font-size: clamp(36px, 9vw, 56px); white-space: normal; }
  .lgs-eyebrow { font-size: clamp(16px, 2.5vw, 22px); }
  .lgs-subtitle { font-size: clamp(16px, 2.5vw, 22px); }
  .lgs-hero-content { margin-left: 50px; margin-bottom: 60px; }
  /* Show left rail horizontally below Shop Now button */
  .lgs-left-rail { 
    position: static;
    transform: none;
    flex-direction: row;
    margin-top: 20px;
    gap: 12px;
    justify-content: flex-start;
  }
  /* Hide Follow Us text on mobile */
  .lgs-left-rail-label { 
    display: none;
  }
  .lgs-left-rail-icon { width: 36px; height: 36px; }
  .lgs-left-rail-icon svg { width: 18px; height: 18px; }
  /* Hide right rail on mobile */
  .lgs-rail { display: none; }
}
@media (max-width: 575.98px) { 
  .lgs-title { font-size: clamp(32px, 10vw, 48px); } 
  .lgs-wave { height: 80px; } 
  .lgs-hero-content { margin-bottom: 50px; margin-left: 45px; } 
  .lgs-hero { min-height: 80vh; padding-bottom: 50px; }
  .lgs-hero-bg { background-position: 75% center; }
  .lgs-cta { padding: 0.6rem 1.4rem; min-width: 160px; font-size: 15px; }
  /* Keep left rail horizontal on very small screens */
  .lgs-left-rail-icon { width: 32px; height: 32px; }
  .lgs-left-rail-icon svg { width: 16px; height: 16px; }
  .lgs-left-rail { gap: 10px; }
}

/* Left social rail */
.lgs-hero img { max-width: 100%; height: auto; object-fit: cover; display: block; }
.lgs-left-rail { position: absolute; top: 50%; left: 12px; transform: translateY(-50%); gap: 10px; z-index: 3; color: #f1f1f1; }
.lgs-left-rail-label { writing-mode: vertical-rl; transform: rotate(180deg); font-family: 'Poppins', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; font-weight: 500; letter-spacing: 0.12em; font-size: 12px; opacity: 0.9; margin-bottom: 8px; }
.lgs-left-rail-icon { width: 28px; height: 28px; display: grid; place-items: center; border-radius: 999px; background: rgba(255,255,255,0.08); border: 1px solid rgba(255,255,255,0.18); transition: transform 160ms ease, background 160ms ease, border-color 160ms ease; }
.lgs-left-rail-icon:hover { transform: translateX(1px); background: rgba(255,255,255,0.12); border-color: rgba(255,255,255,0.3); }
.lgs-left-rail-icon svg { width: 16px; height: 16px; }
.lgs-left-rail-icon svg *, .lgs-left-rail-icon svg path, .lgs-left-rail-icon svg rect, .lgs-left-rail-icon svg circle, .lgs-left-rail-icon svg line { fill: none; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }
/* Social brand strokes */
.lgs-left-rail-icon--fb svg * { stroke: #1877F2; }
.lgs-left-rail-icon--ig svg * { stroke: #C13584; }
.lgs-left-rail-icon--cam svg * { stroke: #b4826b; }
.lgs-left-rail-icon--yt svg * { stroke: #FF0000; }

/* Left rail responsive adjustments */
@media (max-width: 991.98px) and (min-width: 768px) {
  .lgs-left-rail { left: 10px; gap: 9px; }
  .lgs-left-rail-icon { width: 26px; height: 26px; }
  .lgs-left-rail-icon svg { width: 15px; height: 15px; }
  .lgs-left-rail-label { font-size: 11px; }
}

@media (max-width: 767.98px) and (min-width: 576px) { 
  .lgs-left-rail { left: 8px; gap: 8px; } 
  .lgs-left-rail-icon { width: 24px; height: 24px; } 
  .lgs-left-rail-icon svg { width: 14px; height: 14px; } 
  .lgs-left-rail-label { font-size: 10px; margin-bottom: 6px; }
}

/* =========================== */
/* Services section            */
/* =========================== */
.lgs-services { background: var(--brand-bg) url('../imgs/ServiceSecBackground.png') center/cover; padding-top: 80px; padding-bottom: 80px; position: relative; margin-top: -50px; }
.lgs-services::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 220px; background: linear-gradient(to bottom, rgba(191, 233, 194, 1) 0%, rgba(191, 233, 194, 0.7) 40%, rgba(191, 233, 194, 0.3) 80%, transparent 100%); z-index: 1; pointer-events: none; }
.lgs-services__header, .lgs-services__grid { opacity: 0; transform: translateY(12px); position: relative; z-index: 2; }
.lgs-services.is-visible .lgs-services__header,
.lgs-services.is-visible .lgs-services__grid { opacity: 1; transform: translateY(0); transition: opacity 600ms ease 80ms, transform 600ms ease 80ms; }

.services-title { font-family: 'Turkey Sandwich', 'Poppins', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; color: #181616; font-weight: 400; letter-spacing: 0.04em; text-shadow: 0 2px 8px rgba(0,0,0,0.08); font-size: clamp(32px, 6vw, 64px); }

/* Service item structure */
.service-item { display: flex; flex-direction: column; height: 100%; }
.service-item--pattern-a { margin-top: 0; }
.service-item--pattern-b { margin-top: 40px; }

/* Service card (image only) */
.service-card { background: #ffffff; border-radius: 14px; overflow: hidden; box-shadow: 0 10px 28px rgba(0,0,0,0.10); border: none; transition: transform 180ms ease; aspect-ratio: 4/3; }
.service-item:hover .service-card { border: 2px solid #edc900; transform: translateY(-2px); }

.service-img { width: 100%; height: 100%; object-fit: cover; transform: scale(1); transition: transform 240ms ease; }
.service-item:hover .service-img { transform: scale(1.06); }

/* Service content (outside card) */
.service-content { padding: 20px 0 0; color: #171517; }
.service-name { font-family: 'Poppins', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; font-weight: 600; color: #171517; font-size: 18px; margin-bottom: 8px; }
.service-text { font-family: 'Poppins', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; font-weight: 400; color: #171517; font-size: 14px; opacity: 0.9; margin-bottom: 12px; }

.service-link { font-family: 'Poppins', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; font-weight: 600; color: #171517; text-decoration: none; position: relative; }
.service-link .arrow-wrap { display: inline-flex; align-items: center; justify-content: center; width: 18px; height: 18px; border-radius: 999px; background: #edc900; margin-left: 6px; }
.service-link .arrow { display: inline-block; line-height: 1; transform: translateY(-1px); font-size: 12px; color: #171517; }
.service-link:hover { opacity: 0.9; }


.view-more { background: #edc900; color: #191717; font-family: 'Poppins', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; font-weight: 400; border: none; }
.view-more:hover { background: #d4b800; color: #191717; }

.services-bottom-line { position: absolute; left: 0; right: 0; bottom: 0; height: 3px; background: #edc900; }

/* Responsive adjustments */
@media (max-width: 991.98px) {
  .service-item--pattern-b { margin-top: 20px; }
}

@media (max-width: 767.98px) {
  .service-item--pattern-a, .service-item--pattern-b { margin-top: 0; }
}

/* =========================== */
/* Featured Products section   */
/* =========================== */
.featured-products { background: url('../imgs/FeaturedProductsBackground.png') center/cover; padding-top: 80px; padding-bottom: 80px; position: relative; }
.featured-products__header { opacity: 0; transform: translateY(12px); }
.featured-products.is-visible .featured-products__header { opacity: 1; transform: translateY(0); transition: opacity 600ms ease 80ms, transform 600ms ease 80ms; }

.featured-title { font-family: 'Turkey Sandwich', 'Poppins', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; color: #edc900; font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em; font-size: clamp(32px, 6vw, 56px); }

/* Category Tabs */
.category-tabs { display: flex; justify-content: center; gap: 24px; flex-wrap: wrap; }
.category-tab { background: none; border: none; font-family: 'Poppins', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; font-weight: 600; font-size: 16px; color: #f7f9f8; padding: 8px 16px; cursor: pointer; position: relative; transition: color 200ms ease; }
.category-tab--active, .category-tab:hover { color: #edc900; }

/* Carousel Container */
.carousel-wrapper { position: relative; margin: 0 80px; padding-right: 40px; }
.products-carousel { display: flex; gap: 24px; overflow-x: auto; scroll-behavior: smooth; padding: 20px 0; scrollbar-width: none; -ms-overflow-style: none; }
.products-carousel::-webkit-scrollbar { display: none; }

/* Product Items */
.product-item { flex: 0 0 calc((100% - 72px) / 3.5); display: flex; flex-direction: column; min-width: 280px; max-width: 320px; }
.product-card { background: #ffffff; border-radius: 16px; overflow: hidden; box-shadow: 0 12px 32px rgba(0,0,0,0.12); transition: transform 300ms ease, box-shadow 300ms ease; aspect-ratio: 4/3; }
.product-item:hover .product-card { transform: translateY(-8px) scale(1.02); box-shadow: 0 20px 40px rgba(0,0,0,0.18); }

.product-img { width: 100%; height: 100%; object-fit: cover; transition: transform 400ms ease; }
.product-item:hover .product-img { transform: scale(1.08); }

/* Product content (outside card) */
.product-content { padding: 15px 0 0; }
.product-info-row { display: flex; justify-content: space-between; align-items: center; margin-bottom: 8px; }
.product-name { font-family: 'Poppins', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; font-weight: 500; color: #ffffff; font-size: 18px; margin: 0; }
.product-price { font-family: 'Poppins', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; font-weight: 700; color: #ffffff; font-size: 20px; margin: 0; }

.product-rating { display: flex; gap: 2px; }
.product-rating i { color: #f6a62a; font-size: 14px; }

/* Carousel Navigation */
.carousel-btn { position: absolute; top: 50%; transform: translateY(-50%); width: 40px; height: 40px; border-radius: 50%; background: #edc900; border: none; color: #191717; display: flex; align-items: center; justify-content: center; cursor: pointer; transition: background-color 200ms ease, transform 200ms ease; box-shadow: 0 4px 12px rgba(0,0,0,0.15); z-index: 2; }
.carousel-btn:hover { background: #d4b800; transform: translateY(-50%) scale(1.1); }
.carousel-btn-left { left: -60px; }
.carousel-btn-right { right: -20px; }
.carousel-btn i { font-size: 18px; }

/* View More Button */
.featured-view-more { background: #edc900; color: #191717; font-family: 'Poppins', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; font-weight: 400; border: none; }
.featured-view-more:hover { background: #d4b800; color: #191717; }

/* Featured bottom line */
.featured-bottom-line { position: absolute; left: 0; right: 0; bottom: 0; height: 3px; background: #edc900; }

/* =========================== */
/* Gallery section             */
/* =========================== */
.lgs-gallery { background: var(--brand-bg); padding-top: 80px; padding-bottom: 80px; position: relative; }
.lgs-gallery__header { opacity: 1; transform: translateY(0); }
.lgs-gallery.is-visible .lgs-gallery__header { opacity: 1; transform: translateY(0); transition: opacity 600ms ease 80ms, transform 600ms ease 80ms; }

.gallery-title { font-family: 'Turkey Sandwich', 'Poppins', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; color: #181616; font-weight: 400; letter-spacing: 0.04em; text-shadow: 0 2px 8px rgba(0,0,0,0.08); font-size: clamp(32px, 6vw, 64px); }

/* Gallery grid layout */
.gallery-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; max-width: 1200px; margin: 0 auto; align-items: stretch; }

/* Large image (left side) */
.gallery-item--large { height: 100%; }

/* Small images grid (right side) */
.gallery-small-grid { display: grid; grid-template-columns: 1fr 1fr; grid-template-rows: 1fr 1fr; gap: 20px; height: 100%; }

/* Gallery item styling */
.gallery-item { overflow: hidden; border-radius: 10px; transition: transform 0.3s ease, border 0.3s ease; border: 2px solid transparent; cursor: pointer; }

.gallery-img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform 0.3s ease; }

/* Hover effects */
.gallery-item:hover { border-color: #FFFF00; transform: scale(1.05); }
.gallery-item:hover .gallery-img { transform: scale(1.02); }

/* Remove fixed aspect ratios to allow height matching */

/* Gallery responsive design */
@media (max-width: 991.98px) {
  .gallery-grid { grid-template-columns: 1fr 1fr; gap: 15px; }
  .gallery-small-grid { gap: 15px; }
}

@media (max-width: 767.98px) {
  .gallery-grid { grid-template-columns: 1fr 1fr; gap: 12px; }
  .gallery-small-grid { grid-template-columns: 1fr; gap: 12px; }
  .gallery-item--large { aspect-ratio: 4/3; }
  .gallery-item--small { aspect-ratio: 4/3; }
}

@media (max-width: 575.98px) {
  .gallery-grid { grid-template-columns: 1fr; gap: 15px; }
  .gallery-small-grid { grid-template-columns: 1fr; gap: 15px; }
  .gallery-item--large { aspect-ratio: 4/3; }
  .gallery-item--small { aspect-ratio: 4/3; }
}

/* =========================== */
/* Testimonials section        */
/* =========================== */
.lgs-testimonials { background: var(--brand-bg); padding-top: 80px; padding-bottom: 80px; position: relative; }
.lgs-testimonials__header { opacity: 1; transform: translateY(0); }

.testimonials-title { font-family: 'Turkey Sandwich', 'Poppins', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; color: #efcb02; font-weight: 400; letter-spacing: 0.04em; text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.15); font-size: clamp(32px, 6vw, 64px); }

/* Testimonial content layout */
.testimonials-content { max-width: 1200px; margin: 0 auto; position: relative; z-index: 2; }

/* Testimonials slider */
.testimonials-slider { position: relative; }
.testimonial-slide { display: none; }
.testimonial-slide.active { display: block; }

/* Animate only the testimonial card */
.testimonial-slide .testimonial-card {
  opacity: 0;
  transform: translateX(100px);
}

.testimonial-slide.active .testimonial-card {
  animation: slideInCard 0.8s cubic-bezier(0.4, 0, 0.2, 1) forwards;
}

@keyframes slideInCard {
  from { 
    opacity: 0; 
    transform: translateX(100px);
  }
  to { 
    opacity: 1; 
    transform: translateX(0);
  }
}

/* Left side - Customer image */
.testimonial-image-wrapper { display: flex; justify-content: flex-start; align-items: center; position: relative; z-index: 1; }
.testimonial-main-img { 
  width: 100%; 
  max-width: 500px; 
  height: auto; 
  border-radius: 10px; 
  box-shadow: 0 8px 28px rgba(0,0,0,0.15); 
  transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1); 
}
.testimonial-main-img:hover { 
  transform: translateY(-8px) scale(1.02); 
  box-shadow: 0 16px 40px rgba(0,0,0,0.25);
}

/* Right side - Testimonial card */
.testimonial-card { 
  background: #000000; 
  border-radius: 10px; 
  padding: 30px; 
  position: relative; 
  box-shadow: 4px 0 0 #EDC900, 0 8px 28px rgba(0,0,0,0.15); 
  max-width: 600px; 
  margin-left: -200px; 
  z-index: 2; 
  transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}
.testimonial-card:hover {
  transform: translateY(-5px);
  box-shadow: 6px 0 0 #EDC900, 0 16px 40px rgba(0,0,0,0.3);
  background: linear-gradient(135deg, #000000 0%, #1a1a1a 100%);
}

/* Quote mark */
.quote-mark { 
  position: absolute; 
  top: -10px; 
  right: 20px; 
  font-size: 60px; 
  color: #EDC900; 
  font-family: serif; 
  line-height: 1; 
  transition: all 0.3s ease;
  opacity: 0.9;
}
.testimonial-card:hover .quote-mark {
  transform: scale(1.1) rotate(-5deg);
  opacity: 1;
  color: #F1CD00;
}

/* Customer info */
.customer-info { display: flex; align-items: center; gap: 15px; margin-bottom: 20px; }

.customer-avatar-wrapper {
  width: 90px;
  height: 90px;
  border-radius: 50%;
  border: 4px solid #EDC900;
  padding: 0;
  overflow: hidden;
  position: relative; /* ensure absolutely positioned img fills circle */
  transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  box-shadow: 0 4px 12px rgba(237, 201, 0, 0.3);
  flex-shrink: 0;
}

.customer-avatar-wrapper:hover {
  transform: scale(1.1) rotate(5deg);
  border-color: #F1CD00;
  box-shadow: 0 8px 20px rgba(237, 201, 0, 0.5);
}

.customer-avatar {
  position: absolute; /* guarantees full bleed inside the circle */
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}
.customer-name { 
  font-family: 'Poppins', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; 
  font-weight: 500; 
  color: #FFFFFF; 
  margin: 0; 
  font-size: 18px; 
  transition: color 0.3s ease;
}
.testimonial-card:hover .customer-name {
  color: #EDC900;
}

/* Testimonial text */
.testimonial-text { 
  font-family: 'Poppins', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; 
  font-weight: 400; 
  color: #f1f1f1; 
  font-size: 16px; 
  line-height: 1.6; 
  margin-bottom: 20px; 
  transition: color 0.3s ease;
}
.testimonial-card:hover .testimonial-text {
  color: #ffffff;
}

/* Rating stars */
.testimonial-rating { display: flex; gap: 2px; margin-bottom: 15px; }
.star-filled { 
  color: #EDC900; 
  font-size: 20px; 
  transition: all 0.3s ease;
  display: inline-block;
}
.star-filled:hover {
  transform: scale(1.3) rotate(15deg);
  color: #F1CD00;
}
.testimonial-card:hover .star-filled {
  animation: starPulse 1.5s ease infinite;
}

@keyframes starPulse {
  0%, 100% { transform: scale(1); }
  50% { transform: scale(1.1); }
}

/* Pagination dots */
.testimonial-pagination { 
  display: flex; 
  gap: 10px; 
  margin-top: 30px; 
  justify-content: center;
}
.pagination-dot { 
  width: 10px; 
  height: 10px; 
  border-radius: 50%; 
  background: #DAC498; 
  cursor: pointer; 
  transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  border: 2px solid transparent;
}
.pagination-dot--active { 
  background: #F1CD00; 
  width: 14px; 
  height: 14px; 
  border-color: #EDC900;
  box-shadow: 0 0 12px rgba(241, 205, 0, 0.6);
}
.pagination-dot:hover { 
  transform: scale(1.3); 
  background: #EDC900;
  box-shadow: 0 0 8px rgba(237, 201, 0, 0.4);
}

/* Testimonials responsive design */
@media (max-width: 991.98px) {
  .testimonial-card { max-width: 100%; margin-left: -120px; }
  .testimonial-main-img { max-width: 400px; }
}

@media (max-width: 767.98px) {
  .testimonial-card { padding: 25px; margin-top: 30px; margin-left: 0; }
  .testimonials-title { font-size: clamp(28px, 5vw, 48px); }
  .quote-mark { font-size: 50px; top: -8px; right: 15px; }
  .testimonial-image-wrapper { justify-content: center; }
}

/* =========================== */
/* Quick Contact section       */
/* =========================== */
.lgs-quick-contact { position: relative; min-height: 100vh; display: flex; align-items: center; padding-top: 80px; padding-bottom: 80px; margin-top: -50px; }

/* Background with forest image and gradient overlay */
.quick-contact-bg { position: absolute; inset: 0; z-index: 0; background-image: linear-gradient(to bottom, var(--brand-bg) 0%, rgba(191, 233, 194, 0.8) 15%, rgba(191, 233, 194, 0.5) 40%, rgba(191, 233, 194, 0.2) 70%, transparent 90%), url('../imgs/Quick Contact BG.png'); background-size: cover; background-repeat: no-repeat; background-position: center center; }

.lgs-quick-contact .container { position: relative; z-index: 2; }
.lgs-quick-contact__header { opacity: 1; transform: translateY(0); margin-bottom: 1.5rem !important; }

.quick-contact-title { font-family: 'Turkey Sandwich', 'Poppins', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; color: #181616; font-weight: 400; letter-spacing: 0.04em; text-shadow: 0 2px 8px rgba(0,0,0,0.08); font-size: clamp(32px, 6vw, 64px); margin-bottom: 0; }

/* Form wrapper and layout */
.quick-contact-form-wrapper { max-width: 800px; margin: 0 auto; }
.quick-contact-form { background: transparent; padding: 40px 20px; }

/* Form groups */
.quick-contact-form .form-group { margin-bottom: 20px; }
.quick-contact-form .row { margin-left: -10px; margin-right: -10px; }
.quick-contact-form .col-12 { padding-left: 10px; padding-right: 10px; }

/* Form inputs styling */
.quick-contact-input { background: #FFFFFF; color: #191717; font-family: 'Poppins', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; font-weight: 400; border: none; border-radius: 10px; padding: 12px 16px; font-size: 16px; box-shadow: 0 4px 12px rgba(0,0,0,0.1); transition: all 0.3s ease; width: 100%; }

.quick-contact-input:hover { box-shadow: 0 6px 18px rgba(0,0,0,0.15); transform: translateY(-1px); border: 2px solid rgba(237, 201, 0, 0.3); }

.quick-contact-input:focus { outline: none; box-shadow: 0 6px 20px rgba(237, 201, 0, 0.3); transform: translateY(-2px); border: 2px solid rgba(237, 201, 0, 0.5); }

.quick-contact-input::placeholder { color: #666666; }

/* Textarea specific styling */
.quick-contact-textarea { resize: vertical; min-height: 120px; }

/* Submit button */
.quick-contact-btn { background: #EDC900; color: #191717; font-family: 'Poppins', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; font-weight: 500; border: none; border-radius: 30px; padding: 12px 40px; font-size: 16px; letter-spacing: 0.5px; transition: all 0.3s ease; box-shadow: 0 6px 18px rgba(0,0,0,0.15); }

.quick-contact-btn:hover { background: #d4b800; transform: translateY(-2px); box-shadow: 0 8px 25px rgba(0,0,0,0.2); }

.quick-contact-btn:active { transform: translateY(0); }

/* Quick Contact responsive design */
@media (max-width: 767.98px) {
  .quick-contact-form { padding: 30px 20px; }
  .quick-contact-title { font-size: clamp(28px, 5vw, 48px); }
  .lgs-quick-contact { min-height: auto; }
}

@media (max-width: 575.98px) {
  .quick-contact-form { padding: 25px 15px; }
  .quick-contact-input { font-size: 14px; }
}

/* =========================== */
/* Footer section              */
/* =========================== */
.lgs-footer { position: relative; }

/* Footer background with forest image and lighter overlay */
.footer-bg { position: absolute; inset: 0; z-index: 0; background-image: linear-gradient(rgba(24, 22, 22, 0.3), rgba(24, 22, 22, 0.3)), url('../imgs/Footer BG.png'); background-size: cover; background-repeat: no-repeat; background-position: center center; }

.lgs-footer .container { position: relative; z-index: 2; }

/* Floating logo pinned to left, vertically centered */
.footer-floating-logo { position: absolute; top: 50%; left: 60px; transform: translateY(-50%); z-index: 3; }
.footer-floating-logo .footer-logo { max-width: 140px; height: auto; display: block; }

/* Footer content */
.footer-content { padding-top: 60px; padding-bottom: 48px; }

/* Logo */
.footer-logo { max-width: 180px; height: auto; }

/* Section titles */
.footer-section-title { font-family: 'Poppins', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; font-weight: 600; color: #FFFFFF; font-size: 18px; margin-bottom: 20px; }

/* Contact Details */
.contact-info { display: flex; flex-direction: column; gap: 15px; }
.footer-contact-item { display: flex; align-items: flex-start; gap: 12px; }
.footer-contact-icon { width: 20px; height: 20px; color: #FFFFFF; flex-shrink: 0; margin-top: 2px; }
.contact-text { font-family: 'Poppins', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; font-weight: 400; color: #F7F9F8; font-size: 14px; line-height: 1.5; }

/* Newsletter */
.newsletter-text { font-family: 'Poppins', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; font-weight: 400; color: #F7F9F8; font-size: 14px; margin-bottom: 20px; line-height: 1.5; }

.newsletter-input-wrapper { display: flex; gap: 8px; }
.newsletter-input { flex: 1; background: #FFFFFF; color: #181616; font-family: 'Poppins', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; font-weight: 400; border: none; border-radius: 8px; padding: 10px 14px; font-size: 14px; }
.newsletter-input:focus { outline: none; box-shadow: 0 0 0 2px rgba(237, 201, 0, 0.3); }

.newsletter-btn { background: #EDC900; color: #191717; font-family: 'Poppins', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; font-weight: 500; border: none; border-radius: 8px; padding: 10px 20px; font-size: 14px; transition: all 0.3s ease; white-space: nowrap; }
.newsletter-btn:hover { background: #d4b800; transform: translateY(-1px); }

/* Grid-based footer layout */
.footer-grid-container { width: 100%; }

/* Top row: Contact and Newsletter */
.footer-top-row { display: grid; grid-template-columns: 1fr 1fr; gap: 60px; margin-bottom: 40px; }

/* Logo + Contact Details wrapper */
.logo-contact-wrapper { display: flex; align-items: flex-start; gap: 30px; }
.footer-logo-wrapper { flex-shrink: 0; }
.contact-details-wrapper { flex: 1; }


/* Navigation section (between top row and divider) */
.footer-navigation-section { margin: 40px 0 30px 0; display: flex; justify-content: flex-start; }

/* Divider above navigation */
.footer-divider--top { border: none; height: 2px; background: rgba(255, 255, 255, 0.3); margin: 0 0 30px 0; }

/* Divider below navigation */
.footer-divider { border: none; height: 2px; background: rgba(255, 255, 255, 0.3); margin: 0 0 30px 0; }

/* Thin divider above the footer nav inside Contact Details */
.footer-subdivider { border: none; height: 1px; width: 100%; background: rgba(255, 255, 255, 0.25); margin: 20px 0 16px 0; }

/* Bottom row: Copyright left, Social right */
.footer-bottom-row { display: flex; justify-content: space-between; align-items: center; gap: 60px; }

/* Copyright column on the left */
.footer-copyright-column { flex: 0 0 auto; }

/* Social column on the right */
.footer-social-column { flex: 0 0 auto; }

/* Navigation */
.footer-nav { display: flex; align-items: center; flex-wrap: wrap; gap: 8px; }
.footer-nav-link { font-family: 'Poppins', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; font-weight: 400; color: #F7F9F8; font-size: 14px; text-decoration: none; transition: color 0.3s ease; }
.footer-nav-link:hover { color: #EDC900; }
.nav-separator { color: #F7F9F8; font-size: 14px; }

/* Larger footer nav variant for main navigation section */
.footer-nav--large { gap: 24px; }
.footer-nav--large .footer-nav-link { font-size: 16px; font-weight: 500; }
.footer-nav--large .nav-separator { font-size: 16px; opacity: 0.85; }

/* Social Media Icons */
.footer-social { display: flex; align-items: center; gap: 12px; }
.social-icon { display: flex; align-items: center; justify-content: center; width: 40px; height: 40px; border: 2px solid #FFFFFF; border-radius: 50%; color: #FFFFFF; transition: all 0.3s ease; text-decoration: none; }
.social-icon svg { width: 18px; height: 18px; }
.social-icon:hover { background: #EDC900; border-color: #EDC900; color: #191717; transform: translateY(-2px); }

/* Copyright */
.copyright-text { font-family: 'Poppins', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; font-weight: 400; color: #F7F9F8; font-size: 14px; margin: 0; }
.domain-highlight { color: #EDC900; font-weight: 600; }

/* Footer responsive design */

/* Medium screens (768px-1199px): Two-row layout */
@media (max-width: 1199.98px) and (min-width: 768px) {
  .footer-content { padding-top: 50px; padding-bottom: 44px; }
  /* Logo stays vertically centered but smaller */
  .footer-floating-logo { left: 40px; }
  .footer-floating-logo .footer-logo { max-width: 100px; }
  /* Contact and Newsletter side by side */
  .footer-top-row { grid-template-columns: 1fr 1fr; gap: 40px; margin-bottom: 32px; }
  .footer-contact-section, .footer-newsletter-section { text-align: left; }
  /* Navigation section */
  .footer-navigation-section { margin: 32px 0 24px 0; }
  /* Dividers */
  .footer-divider--top { margin: 0 0 24px 0; }
  .footer-divider { margin: 0 0 24px 0; }
  /* Adjust container padding */
  .lgs-footer .container { padding-left: 140px; }
}

/* Tablet/Small desktop (768px-991px): Tighter spacing */
@media (max-width: 991.98px) and (min-width: 768px) {
  .footer-top-row { gap: 32px; }
  .footer-bottom-row { gap: 32px; }
  .footer-navigation-section { margin: 28px 0 20px 0; }
  .footer-nav--large .footer-nav-link { font-size: 17px; }
  .footer-nav--large .nav-separator { font-size: 17px; }
  .newsletter-input-wrapper { max-width: 100%; }
  .contact-info { gap: 12px; }
  .footer-section-title { font-size: 16px; margin-bottom: 16px; }
  .contact-text, .newsletter-text, .footer-nav-link { font-size: 13px; }
  .social-icon { width: 36px; height: 36px; }
  .social-icon svg { width: 16px; height: 16px; }
}

/* Small screens (<768px): Stack all sections vertically */
@media (max-width: 767.98px) {
  .footer-content { padding-top: 60px; padding-bottom: 40px; }
  /* Hide logo on mobile screens */
  .footer-floating-logo { display: none; }
  /* Stack all sections, keep left-aligned */
  .footer-top-row { grid-template-columns: 1fr; gap: 28px; margin-bottom: 28px; }
  .footer-contact-section { max-width: calc(100% - 75px); }
  .footer-contact-section, .footer-newsletter-section { text-align: left; }
  /* Reset container padding */
  .lgs-footer .container { padding-left: 15px; }
  /* Keep contact items left-aligned */
  .contact-info { gap: 14px; }
  .contact-item { text-align: left; }
  /* Newsletter full width on mobile */
  .newsletter-input-wrapper { flex-direction: column; gap: 10px; max-width: 100%; }
  .newsletter-input, .newsletter-btn { width: 100%; }
  /* Navigation section */
  .footer-navigation-section { margin: 24px 0 20px 0; justify-content: flex-start; }
  .footer-nav--large { gap: 18px; }
  .footer-nav--large .footer-nav-link { font-size: 16px; }
  .footer-nav--large .nav-separator { font-size: 16px; }
  /* Divider with top border */
  .footer-divider { margin: 20px 0 16px 0; border-top: 2px solid rgba(255, 255, 255, 0.3); }
  /* Stack bottom row, keep left-aligned */
  .footer-bottom-row { flex-direction: column; align-items: flex-start; gap: 16px; }
  /* Keep navigation left-aligned */
  .footer-nav { justify-content: flex-start; flex-wrap: wrap; row-gap: 6px; }
  .footer-social { justify-content: flex-start; }
  /* Scale down text and icons */
  .footer-section-title { font-size: 16px; margin-bottom: 14px; }
  .contact-text, .newsletter-text, .footer-nav-link, .copyright-text { font-size: 13px; }
  .footer-contact-icon { width: 18px; height: 18px; }
  .social-icon { width: 38px; height: 38px; }
  .social-icon svg { width: 17px; height: 17px; }
  .newsletter-btn { padding: 12px 20px; }
  .footer-copyright { text-align: left; }
}

/* Desktop (>=1200px): Logo on left, vertically centered */
@media (min-width: 1200px) {
  /* Reserve a left gutter inside the green content area */
  .lgs-footer .container { position: relative; padding-left: 220px; overflow: visible; }
  /* Keep the logo vertically centered */
  .footer-floating-logo { left: 60px; }
  .footer-floating-logo .footer-logo { max-width: 160px; height: auto; }
}

/* Extra small screens (<576px): Even tighter */
@media (max-width: 575.98px) {
  .footer-content { padding-top: 50px; padding-bottom: 32px; }
  /* Hide logo on extra small screens */
  .footer-floating-logo { display: none; }
  .footer-contact-section { max-width: calc(100% - 70px); }
  .footer-top-row { gap: 24px; margin-bottom: 24px; }
  .footer-section-title { font-size: 15px; margin-bottom: 12px; }
  .footer-navigation-section { margin: 20px 0 16px 0; }
  .footer-nav--large { gap: 14px; }
  .footer-nav--large .footer-nav-link { font-size: 14px; }
  .footer-nav--large .nav-separator { font-size: 14px; }
  .contact-text, .newsletter-text, .footer-nav-link, .copyright-text { font-size: 12px; }
  .footer-contact-icon { width: 16px; height: 16px; }
  .social-icon { width: 36px; height: 36px; }
  .social-icon svg { width: 16px; height: 16px; }
  .footer-divider { margin: 18px 0 14px 0; }
  .footer-bottom-row { gap: 14px; }
  .footer-nav--large { gap: 12px; }
}

/* Featured Products Responsive (keeping existing) */
@media (max-width: 991.98px) {
  .carousel-wrapper { margin: 0 60px; padding-right: 30px; }
  .product-item { flex: 0 0 calc((100% - 48px) / 3.5); min-width: 240px; max-width: 280px; }
  .carousel-btn-left { left: -40px; }
  .carousel-btn-right { right: -15px; }
}

@media (max-width: 767.98px) {
  .carousel-wrapper { margin: 0 40px; padding-right: 20px; }
  .product-item { flex: 0 0 calc((100% - 24px) / 2.5); min-width: 200px; max-width: 240px; }
  .carousel-btn { width: 36px; height: 36px; }
  .carousel-btn i { font-size: 16px; }
  .carousel-btn-left { left: -25px; }
  .carousel-btn-right { right: -10px; }
  .category-tabs { gap: 16px; }
  .category-tab { font-size: 14px; }
}

/* =========================== */
/* About Us section            */
/* =========================== */
.lgs-about { background: var(--brand-bg) url('../imgs/AboutusSection4Background.png') center/cover; opacity: 1; transform: none; position: relative; z-index: 1; margin-top: 0; padding-bottom: 160px; }
.lgs-about::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 220px; background: linear-gradient(to bottom, rgba(191, 233, 194, 1) 0%, rgba(191, 233, 194, 0.8) 30%, rgba(191, 233, 194, 0.4) 70%, transparent 100%); z-index: 1; pointer-events: none; }
.lgs-about::after { content: ''; position: absolute; bottom: 0; left: 0; right: 0; height: 260px; background: linear-gradient(to bottom, transparent 0%, rgba(191, 233, 194, 0.4) 30%, rgba(191, 233, 194, 0.8) 70%, rgba(191, 233, 194, 1) 100%); z-index: 1; pointer-events: none; }
.lgs-about.is-visible { opacity: 1; transform: none; transition: none; }

/* Spacing helper (Bootstrap has no py-6) */
@media (min-width: 992px) { .py-lg-6 { padding-top: 4.5rem !important; padding-bottom: 4.5rem !important; } }

/* Overlapping circular images */
.about-media { position: relative; width: min(520px, 90%); height: min(460px, 70vw); z-index: 2; }
.about-circle { position: absolute; display: grid; place-items: center; filter: drop-shadow(0 8px 28px rgba(0,0,0,0.15)); }
.about-circle--big { width: 500px; height: 500px; top: 0; left: 50%; transform: translateX(-52%); }
.about-circle--small { width: 200px; height: 200px; bottom: 100px; left: 60px; background-image: url('../imgs/AboutusSection2.png'); background-size: cover; background-position: center; border-radius: 999px; display: none; }
.about-circle__frame { background: #edc900; border: 6px solid #edc900; width: 100%; height: 100%; border-radius: 999px; overflow: hidden; display: grid; place-items: center; }
.about-circle__frame--main { overflow: visible; }
.about-circle--big .about-circle__frame { background: transparent; border: none; }
.about-circle__img { width: 100%; height: 100%; object-fit: cover; }

/* Copy column */
.about-copy { max-width: 560px; margin-left: auto; margin-right: auto; position: relative; z-index: 2; }
.about-eyebrow { font-family: 'Poppins', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; font-weight: 500; color: #131212; font-size: clamp(18px, 2.2vw, 22px); }
.about-title { font-family: 'Turkey Sandwich', 'Poppins', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; color: #efcb02; font-weight: 400; font-size: clamp(34px, 5.5vw, 64px); line-height: 1.05; }
.about-subtitle { font-family: 'Poppins', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; font-weight: 500; color: #131212; font-size: clamp(18px, 2.2vw, 22px); }
.about-body { font-family: 'Poppins', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; font-weight: 400; color: #131212; opacity: 0.95; font-size: clamp(15px, 1.6vw, 18px); }

.about-cta { background-color: #edc900; color: #191717; border: none; border-radius: 999px !important; padding: 0.7rem 1.6rem; min-width: 172px; transition: filter 160ms ease, transform 160ms ease, box-shadow 160ms ease; box-shadow: 0 6px 18px rgba(0,0,0,0.12); }
.about-cta:hover { filter: brightness(0.95); transform: translateY(-1px); box-shadow: 0 8px 22px rgba(0,0,0,0.16); }
.about-cta:active { filter: brightness(0.92); transform: translateY(0); }

/* Right decorative container (ready for tree image) */
.about-deco { position: absolute; top: 0; bottom: 0; right: -40px; width: 220px; background: transparent; }

/* Right framed circle (yellow fill, no border) */
.about-circle--right { position: absolute; right: 60px; bottom: 80px; width: 180px; height: 180px; display: none; place-items: center; filter: drop-shadow(0 8px 28px rgba(0,0,0,0.15)); z-index: 2; }
.about-circle--right .about-circle__frame { background: var(--brand-yellow); border: none; }
.about-circle__img--transparent { object-fit: contain; background: transparent; }

/* Responsive tweaks */
@media (min-width: 1700px) {
  .about-circle--small { display: block; }
}
@media (min-width: 992px) {
  .about-circle--right { display: grid; }
}
@media (max-width: 991.98px) {
  .about-media { margin-left: auto; margin-right: auto; width: 380px; height: 340px; }
  .about-circle--big { width: 320px; height: 320px; transform: translateX(-50%); }
  .about-circle--small { width: 140px; height: 140px; left: -20%; bottom: -80px; }
  .about-copy { text-align: center; max-width: 100%; padding: 0 20px; }
  .lgs-about { padding-bottom: 100px; }
}
@media (max-width: 767.98px) {
  .about-media { width: 300px; height: 280px; }
  .about-circle--big { width: 280px; height: 280px; }
  .about-circle--small { width: 120px; height: 120px; left: -15%; bottom: -70px; }
  .about-title { font-size: clamp(28px, 8vw, 48px); }
  .about-eyebrow { font-size: 16px; }
  .about-subtitle { font-size: 16px; }
  .about-body { font-size: 14px; }
}
@media (max-width: 575.98px) {
  .about-media { width: 260px; height: 240px; }
  .about-circle--big { width: 240px; height: 240px; }
  .about-circle--small { display: none; }
  .about-title { font-size: clamp(24px, 9vw, 40px); }
  .about-cta { min-width: 140px; padding: 0.6rem 1.3rem; font-size: 14px; }
}
